-
-
Notifications
You must be signed in to change notification settings - Fork 983
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Rounding up calculated height value to non-decimal number to prevent scrollbar from showing #1228
Comments
This will be fix in The upcoming V5. Would love some feedback if you want to give it a go. #1212 |
@davidjbradshaw if you have an npm alpha version published for this package and |
Thanks for your quick reply! I've just seen the implemented fix for V5. Looks like it's better than my suggestion - so no additional feedback there. Any timeframe when V5 is being officially released or "it's ready when it's ready"? |
@RenoLooijmans sorry for slow response, have been unwell for the last few days. I've just published the alpha of version 5 to NPM. It is now split into two different packages.
in addition I have created jQuery and React plugins for the parent page as well. If you want to try either of these they can be used instead of the
I'm still putting together the first draft of a new documentation website, but you can find details of all the changes here. A number of the config options have been revised, but if your not using any then the basic setup is unchanged. Please let me know if you have any questions. |
@davidjbradshaw no worries there! I'm already happy it's being dealt with :-). I'm away next week myself, so I'll definitely have a look at it when I am back. Get well soon. |
Thanks, very rough docs now online at https://iframe-resizer.github.io/docs/ |
Wonderful! @davidjbradshaw one example that would great to add to the docs would be loading the |
That's a fair point, currently I plan to add examples for CommonJS and ES Modules, so can do a CDN example as well. |
Just moved doc site to http://iframe-resizer.github.io/docs/ |
@jlarmstrongiv added jsDeliver CDN |
Hey @davidjbradshaw what’s this about
Where can I see the pricing? I saw ua-parser-js do the same thing recently. I’m building a small app (probably won’t make money, but you never know), so I guess I would need to look into a business license. One thing I would like to see clarified is I’m planning to make webpages that can be embedded in other websites, so clarification that that use-case is included in the license is important to me. That would include, for example, me building a simple react library or wordpress plugin to help non-technical users with my webapp-specific embeds and options. I can’t legally try out v5 until all of that clarified. |
Hey @jlarmstrongiv if you would like to help me test this and provide feedback, then I'll be happy to give you a free license, once we have a full release version.. For now you can use the key Still need to build the licensing bit out, but yes your use case will be covered, that was one of the original design goals of this project. |
Thank you for clarifying @davidjbradshaw
That sounds good to me! I’ll update the react and cdn versions and let you know how it goes
Just a couple followup questions about the key actually. I assume the answer is no from the code I read in the I assume from the usage examples that the API key does not need to be kept secret? |
This is going to be pretty simple and I couldn't afford the server infrastructure to have it phone home. The current version is used on a surprisingly large amount of the world's top websites. |
I sure hope they will pay to help maintain it then! I’m curious how your pricing experiment with In the meantime, I received this error trying to use
I did see that the types were included in the |
Yeah those types were my best guess, I'm not much of a TS coder. Any chance you could have a quick look and make a PR on the |
I had a chat with the guy behind fullpage.js, who was able to turn that into a full time job. But I expect his market is mainly WordPress templates. |
I took a stab at it. These days, I code 95% of my projects in TypeScript and ESM so the PR reflects that. I wasn’t able to get it to play nicely with the module or namespace syntax.
I can see that. I like that he still offers one-time payments. Everything turning to subscriptions these days is rather painful. |
Thanks for the PR, I left a comment on it, looking at the changes I spotted an issue in the old version that might have been the issue. I had not changed the module name from I still need to build a test page in the example folder for react and write some tests for it. I'm glad to hear it worked for you as I have literally never even ran it yet! It was there to test the build and deploy scripts. The full page guy said the subscription option was pretty much unused. I don't think it makes a lot of sense for things like this. |
Oh! 😂 Why didn’t I see that? Must not have been awake yet first thing this morning when I looked at it. You’re right—updating the module name
I wouldn’t go that far 😅 I’m more of a one-error-at-a-time kind of guy. Once the types are fixed, I’ll move onto the next error (or hopefully it works)
I agree, nice to hear a real-world anecdote |
@jlarmstrongiv Hopefully this should now work in Alpha.8 release |
@davidjbradshaw I tried out the alpha release: I’m getting the TypeScript error In the console, I’m getting:
As well as
Apart from the other miscellaneous logs, it seems to work so long as I pass it the license key (fails without it) |
Good spot on The strange ignore message was due to it seeing something come in via postMessage that it was not expecting. I've change this so it will display objects, as we non longer have to worry about IE not supporting this and lowered the level so it will only show in dev builds. The above release as The Will dig in more when I get time to go through this backlog of issues |
Figured out the PropType thing, seems that was down to me following esLint's incorrect advice.... I've removed it and also added an old PR that I had missed from |
@davidjbradshaw here’s an example on how |
@davidjbradshaw incoming warning on the previous major version of
With the recently released |
I just saw that yesterday, I’ve updated it to remove |
@jlarmstrongiv website is now fully done, was wondering if you had any feedback on it? Just need to tie up a few last bits, so hope to be live by the end of this week. |
@davidjbradshaw I’m traveling right now, but I’ll be able to give it a good review on Wednesday/Thursday when I get back home. If the packages are ready to be released, I can try updating my website to use them too. I look forward to the upcoming launch 🚀 |
@jlarmstrongiv Thanks packages should be ready later this week, I will let you know. I will also need your email address to send you a key |
Great @davidjbradshaw ! Let me know when the packages are published, and I’ll do both at the same time. My email is my GitHub username @gmail.com |
@jlarmstrongiv just sent you an email |
@RenoLooijmans your original issue is now fixed in v5.0.0-RC.1. Value is no longer rounded. |
Describe the bug
When, for example, the height is calculated by using "heightCalculationMethod: 'lowestElement'", and because of css the calculated value is a decimal number (say 1436.3348343943), the iframe height seems to be rounded to 1436 instead of 1437. Because it is rounded down a scrollbar is shown inside the iframe (when the iframe height is 100%). This scrollbar scrolls 1px or something, which renders it completely useless and annoying (because the parent page cannot be scrolled).
To Reproduce
See above. I am unsure what css cause a non-rounded value but most likely this is line height of font size related.
Expected behavior
Rounding up the calculated height value so a scrollbar is not shown.
Desktop (please complete the following information):
Smartphone (please complete the following information):
Additional context
Possible fix.
Change file iframeResizer.contentWindow.js, line 980:
lowestElement: function getBestHeight() { return Math.max( getHeight.bodyOffset() || getHeight.documentElementOffset(), getMaxElement('bottom', getAllElements()) ) },
to
lowestElement: function getBestHeight() { return Math.ceil(Math.max( getHeight.bodyOffset() || getHeight.documentElementOffset(), getMaxElement('bottom', getAllElements()) )) },
Please note the added Math.ceil()-function.
Perhaps this should also be applied to the other results, and instead fix it on line 1053:
currentHeight = undefined === customHeight ? getHeight[heightCalcMode]() : customHeight
to
currentHeight = undefined === customHeight ? Math.ceil(getHeight[heightCalcMode]()) : customHeight
I'm happy to provide additional details.
The text was updated successfully, but these errors were encountered: