<div dir="ltr">On Mon, Aug 18, 2008 at 4:40 PM, Ian Hickson <span dir="ltr"><ian@hixie.ch></span> wrote:<br><div class="gmail_quote"><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
<div class="Ih2E3d">On Mon, 18 Aug 2008, Robert O'Callahan wrote:<br>> > Note that the default width and height are adjusted for seamless<br>
> > iframes to match the width that the element would have if it was a<br>
> > non-replaced block-level element with 'width: auto', and the height of<br>
> > the bounding box around the content rendered in the iframe at its<br>
> > current width, respectively.<br>
><br>
> "The bounding box" is a bit ambiguous. If the content overflows<br>
> vertically above the iframe's viewport, does that contribute to the<br>
> height of the bounding box?<br>
<br>
</div></blockquote><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">As far as I can tell there is no ambiguity to the concept of the bounding<br>

box of the content in the canvas, especially given the way the initial<br>
containing block is forced to zero height.</blockquote><div><br>What's the answer to my question then? Should I have been able to derive it somehow?<br><br></div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
> For greater seamlessness, I'd prefer to make the intrinsic height be the<br><div class="Ih2E3d">
> height of the iframe's root element.<br>
<br>
</div>Why would that be more seamless? Surely that would be less seamless if<br>
there were things like negative margins, since then you'd have unsightly<br>
scrollbars appearing.</blockquote><div><br>You mean the scrollbars associated with the iframe viewport?<br><br>Well, viewport scrollbars are already a bit magical. The CSS initial value of 'overflow' is 'visible', yet all browsers use 'auto' for viewport scrollbars unless another value is propagated up from the root element or HTML <body>. So I'd suggest that for seamless iframes, the viewport overflow be 'visible' unless another value propagates up.<br>
<br>I just realized that using the height of the root element won't make much sense if the root element is positioned. I'm not sure how much to care about that.<br><br></div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
> Plus, as dbaron suggested, we'd like 'overflow' to apply to the content<br><div class="Ih2E3d">
> of seamless iframes so that horizontal and vertical overflowing content<br>
> can be rendered as if the iframe was a regular overflow:visible block.<br>
> (We might want to recommend that the UA style sheet contain "iframe {<br>
> overflow:hidden; }" to make it easier for authors to avoid spoofing<br>
> attacks via seamless sandboxed iframes using clever positioning.)<br>
<br>
</div>Well, I guess I'm ok with that, but that will presumably require<br>
significantly changes to the CSS spec to define how it all works (e.g.<br>
with compositing and so forth).</blockquote><div><br>We can make the iframe a stacking context. Then I don't see any problems with compositing.<br> </div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
 The current definition is intended to be<br>
really easy to implement without needing any changes to the CSS model.<br>
</blockquote><div> </div></div>I think that's a good goal, but we also want it to be reasonably "seamless".<br><br>I'm concerned about the use case of very wide content in the iframe (i.e. content overflowing the root element horizontally); for example a forum with many wide messages, each of which is a seamless iframe. Right now it seems the choices are to either have a horizontal scrollbar in each message or clip each message horizontally, there's no way to make it work like a forum page.<br>
<br>Actually I'm not 100% sure you mean by "the width that the element would have if it was a non-replaced
     block-level element with 'width: auto'". You mean if it was such a block-level element containing the root element of the iframe's document?<br><br>Rob<br>-- <br>"He was pierced for our transgressions, he was crushed for our iniquities; the punishment that brought us peace was upon him, and by his wounds we are healed. We all, like sheep, have gone astray, each of us has turned to his own way; and the LORD has laid on him the iniquity of us all." [Isaiah 53:5-6]<br>

</div>