Donate to Remove ads

Got a credit card? use our Credit Card & Finance Calculators

Thanks to eyeball08,Wondergirly,bofh,johnstevens77,Bhoddhisatva, for Donating to support the site

Iframe from 3rd party - Can I edit what gets displayed

Seek assistance with all types of tech. - computer, phone, TV, heating controls etc.
Clariman
Lemon Quarter
Posts: 3270
Joined: November 4th, 2016, 12:17 am
Has thanked: 3085 times
Been thanked: 1557 times

Iframe from 3rd party - Can I edit what gets displayed

#251218

Postby Clariman » September 11th, 2019, 9:37 pm

I have a website for our holiday cottages which used an iframe to show the calendar from our main booking agent. That meant (a) our website had an up to date calendar, (b) I didn't have to maintain my own calendar and (c) anyone clicking on the calendar went to the agent's website so they got the booking. Everyone won. However, they have changed systems and use a different technology so this no longer works.

I've managed to pull the calendar from our other agent's website, displayed via an iframe but it includes specifics of their Ts & Cs and a drop-down box to select any of their other properties. All I want is the calendar in the middle. Can I do something on my web page to remove or obscure the bits I don't want?

Many thanks
C

mc2fool
Lemon Half
Posts: 7880
Joined: November 4th, 2016, 11:24 am
Has thanked: 7 times
Been thanked: 3039 times

Re: Iframe from 3rd party - Can I edit what gets displayed

#251248

Postby mc2fool » September 11th, 2019, 11:42 pm

Hmm...well I doubt you could do anything reliable with HTML/CSS. You could try putting the iframe inside a div of an appropriate height & width and positioning the iframe within it so that only the rectangle of the agent's website that you want to show is visible (use position: absolute on the iframe and overflow: hidden on the div).

However, getting that to work reliably across different browsers and different operating systems and different screen resolutions, fonts, zoom levels, etc, etc, etc will be really problematic. It's made more difficult (if not impossible) 'cos as the inside of the iframe is from another site (not the "same origin") you can't access it with JavaScript to dynamically figure out the position and dimensions of the bits you want to see.

There's one way you could do it but it'd be a lot of work, being to write a CGI script (e.g. in PERL) on your website that goes out and fetches the agent's page and scrapes it and returns to your website what is needed, but if on me saying that you don't already have an idea of how then you're in for a heck of a learning curve ... :D

gbjbaanb
Lemon Slice
Posts: 582
Joined: November 4th, 2016, 1:17 pm
Has thanked: 192 times
Been thanked: 126 times

Re: Iframe from 3rd party - Can I edit what gets displayed

#251606

Postby gbjbaanb » September 13th, 2019, 12:17 pm

Clariman wrote: Can I do something on my web page to remove or obscure the bits I don't want?



Calendars are a doddle, I put zabuto on a site I'm working recently and it was very simple. So why not embed the calendar directly and avoid the iframe (which can be a security risk) and the hassle of dealing with 3rd party.

If you still want a 3rd party one, a search will show plenty you can drop in, but this looks interesting- plain javascript and html.

Drop me a PM and I'll help you out.

Clariman
Lemon Quarter
Posts: 3270
Joined: November 4th, 2016, 12:17 am
Has thanked: 3085 times
Been thanked: 1557 times

Re: Iframe from 3rd party - Can I edit what gets displayed

#251670

Postby Clariman » September 13th, 2019, 5:21 pm

gbjbaanb wrote:
Clariman wrote: Can I do something on my web page to remove or obscure the bits I don't want?



Calendars are a doddle, I put zabuto on a site I'm working recently and it was very simple. So why not embed the calendar directly and avoid the iframe (which can be a security risk) and the hassle of dealing with 3rd party.

If you still want a 3rd party one, a search will show plenty you can drop in, but this looks interesting- plain javascript and html.

Drop me a PM and I'll help you out.


Thanks
It's not just any calendar I want, but the calendar from the booking agent, which is automatically kept up to date.

gbjbaanb
Lemon Slice
Posts: 582
Joined: November 4th, 2016, 1:17 pm
Has thanked: 192 times
Been thanked: 126 times

Re: Iframe from 3rd party - Can I edit what gets displayed

#251676

Postby gbjbaanb » September 13th, 2019, 6:13 pm

Clariman wrote:
gbjbaanb wrote:
Clariman wrote: Can I do something on my web page to remove or obscure the bits I don't want?



Calendars are a doddle, I put zabuto on a site I'm working recently and it was very simple. So why not embed the calendar directly and avoid the iframe (which can be a security risk) and the hassle of dealing with 3rd party.

If you still want a 3rd party one, a search will show plenty you can drop in, but this looks interesting- plain javascript and html.

Drop me a PM and I'll help you out.


Thanks
It's not just any calendar I want, but the calendar from the booking agent, which is automatically kept up to date.


How many agents do you have? But anyway... it depends how you're getting it, if you are linking to a webpage of theirs then you're going to get all of their content, if you're linking to a section (a div or similar) then target a smaller part of the div.

However, regardless of all that, you can use a bit of javascript to find the parts you don't want and remove them from the DOM - in your page's window.onload event, use document.getElementbyID (or getElementsbyClass) to find the relevant bit and use .remove() to delete it. Its difficult to say more without knowing the html markup.

mc2fool
Lemon Half
Posts: 7880
Joined: November 4th, 2016, 11:24 am
Has thanked: 7 times
Been thanked: 3039 times

Re: Iframe from 3rd party - Can I edit what gets displayed

#251687

Postby mc2fool » September 13th, 2019, 7:21 pm

gbjbaanb wrote:... it depends how you're getting it, if you are linking to a webpage of theirs then you're going to get all of their content, if you're linking to a section (a div or similar) then target a smaller part of the div.

He's not wanting to link to the agent's page but to embed it, using an iframe, and in either case tacking the id of a div onto the url will only cause the browser to automatically scroll down to that div. It won't result in it only showing that div.

gbjbaanb wrote:However, regardless of all that, you can use a bit of javascript to find the parts you don't want and remove them from the DOM - in your page's window.onload event, use document.getElementbyID (or getElementsbyClass) to find the relevant bit and use .remove() to delete it. Its difficult to say more without knowing the html markup.

That only works for pages on your site. You cannot access the DOM of a page on another site that's in an iframe, frame or window.

https://en.wikipedia.org/wiki/Same-origin_policy
https://javascript.info/cross-window-communication

gbjbaanb
Lemon Slice
Posts: 582
Joined: November 4th, 2016, 1:17 pm
Has thanked: 192 times
Been thanked: 126 times

Re: Iframe from 3rd party - Can I edit what gets displayed

#251721

Postby gbjbaanb » September 13th, 2019, 9:56 pm

mc2fool wrote:
gbjbaanb wrote:... it depends how you're getting it, if you are linking to a webpage of theirs then you're going to get all of their content, if you're linking to a section (a div or similar) then target a smaller part of the div.

He's not wanting to link to the agent's page but to embed it, using an iframe, and in either case tacking the id of a div onto the url will only cause the browser to automatically scroll down to that div. It won't result in it only showing that div.

gbjbaanb wrote:However, regardless of all that, you can use a bit of javascript to find the parts you don't want and remove them from the DOM - in your page's window.onload event, use document.getElementbyID (or getElementsbyClass) to find the relevant bit and use .remove() to delete it. Its difficult to say more without knowing the html markup.

That only works for pages on your site. You cannot access the DOM of a page on another site that's in an iframe, frame or window.

https://en.wikipedia.org/wiki/Same-origin_policy
https://javascript.info/cross-window-communication


An iframe still has to have the "link" (ie the src reference) to get the data from. That's what I was referring to, and the idea of manipulating the returned data was (sure I had forgotten XSS) to take the html returned by that url and put it in his own page, rather than in an iframe, because there is no way to manipulate what gets displayed otherwise.

mc2fool
Lemon Half
Posts: 7880
Joined: November 4th, 2016, 11:24 am
Has thanked: 7 times
Been thanked: 3039 times

Re: Iframe from 3rd party - Can I edit what gets displayed

#251734

Postby mc2fool » September 13th, 2019, 11:11 pm

gbjbaanb wrote:
mc2fool wrote:
gbjbaanb wrote:... it depends how you're getting it, if you are linking to a webpage of theirs then you're going to get all of their content, if you're linking to a section (a div or similar) then target a smaller part of the div.

He's not wanting to link to the agent's page but to embed it, using an iframe, and in either case tacking the id of a div onto the url will only cause the browser to automatically scroll down to that div. It won't result in it only showing that div.
:

An iframe still has to have the "link" (ie the src reference) to get the data from. That's what I was referring to, and the idea of manipulating the returned data was (sure I had forgotten XSS) to take the html returned by that url and put it in his own page, rather than in an iframe, because there is no way to manipulate what gets displayed otherwise.

Yes, hence why I said in either case about linking to a page or using an iframe with tacking the id of a div onto the url. But having the iframe "link" (src) refer to a div or similar will still get all of the page content into the iframe; it doesn't return just that div, it simply just automatically scrolls to it.

I pointed out the same-origin problem in my first post in the thread and, as I say there, the way to get round it is with a CGI script, but if Clariman isn't already familiar with that it's a steep learning curve....


Return to “Technology - Computers, TV, Phones etc.”

Who is online

Users browsing this forum: No registered users and 34 guests