Skip to content
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

report: introduce the new report api, add dom.rootEl #13277

Merged
merged 48 commits into from
Nov 3, 2021

Conversation

paulirish
Copy link
Member

following #12772, this PR adds a nice and minimal API for rendering the report. since earlier discussion the report API proposal has even shrank. We no longer need the renderPartials() approach we previously discussed.

In this PR:

  • Add dom.rootEl as the root DOM element of this report. Critical to have this for our PSI-like case of multiple reports in the same document. You'll spot a bunch of changes from _document to rootEl in report-ui-features. All of those cases would otherwise be bugs.
  • Keep legacy reportRenderer.renderReport API, but deprecate it. It will still work, but it emits a console warning.
  • Introduce new renderReport(lhr, opts) API.
    • add omitTopbar and disableAutoDarkModeAndFireworks options.
    • onDetailsItemRendered, onSaveGist and getStandaloneReportHTML are not yet here, but those are next.

*/
export function renderReport(lhr, opts = {}) {
const rootEl = document.createElement('main');
rootEl.classList.add('lh-root', 'lh-vars');
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The standalone template HTML already includes these classes in a main tag. WDYT about making rootEl a normal div, and removing the classes from the template files?

Standalone renderer would still look for the main tag.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

basically did the same kinda thing. just avoiding a double-main scenario. :)


reportFragment.appendChild(topbarDocumentFragment);
if (!this._opts.omitTopbar) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The topbar is removed separately in report.tsx. Can we replace that logic with this new option now?

@@ -216,6 +229,8 @@ export class DOM {
}

/**
* ONLY use if `dom.rootEl` isn't sufficient for your needs. It is preferred for all scoping,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Got a little confused on first read

Suggested change
* ONLY use if `dom.rootEl` isn't sufficient for your needs. It is preferred for all scoping,
* ONLY use if `dom.rootEl` isn't sufficient for your needs. `dom.rootEl` is preferred for all scoping,

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

thx


<div class="drop_zone"></div>
<div class="renderer-container"></div>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

FWIW my suggestion was to keep this as a main tag and have generated report contents as divs. Generating main in renderReport might create nested mains in the flow report.

<noscript>Lighthouse report requires JavaScript. Please enable.</noscript>

<main><!-- report populated here --></main>
<main class="flow-vars lh-root lh-vars"><!-- report populated here --></main>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Todo for me to add these programmatically in the flow report.

@@ -21,12 +21,11 @@
<meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1">
<link rel="icon" href="">
<title>Lighthouse Report</title>
<style>body {margin: 0}</style>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you add this to the flow template as well, or maybe put in shared styles somehow?

Copy link
Member

@adamraine adamraine left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm looks like the report is rendering in the flow report

Copy link
Member

@adamraine adamraine left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Cool, thanks for fixing those!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants