-
Notifications
You must be signed in to change notification settings - Fork 9.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
misc(treemap): initialize app structure (#11635)
- Loading branch information
1 parent
0a4598a
commit fea7ffc
Showing
20 changed files
with
21,955 additions
and
41 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
/** | ||
* @license Copyright 2020 The Lighthouse Authors. All Rights Reserved. | ||
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 | ||
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. | ||
*/ | ||
'use strict'; | ||
|
||
const fs = require('fs'); | ||
const GhPagesApp = require('./gh-pages-app.js'); | ||
|
||
/** | ||
* Build treemap app, optionally deploying to gh-pages if `--deploy` flag was set. | ||
*/ | ||
async function run() { | ||
const app = new GhPagesApp({ | ||
name: 'treemap', | ||
appDir: `${__dirname}/../lighthouse-treemap/app`, | ||
html: {path: 'index.html'}, | ||
stylesheets: [ | ||
{path: 'styles/*'}, | ||
], | ||
javascripts: [ | ||
fs.readFileSync(require.resolve('webtreemap-cdt'), 'utf8'), | ||
{path: 'src/*'}, | ||
], | ||
assets: [ | ||
{path: 'debug.json'}, | ||
], | ||
}); | ||
|
||
await app.build(); | ||
|
||
const argv = process.argv.slice(2); | ||
if (argv.includes('--deploy')) { | ||
await app.deploy(); | ||
} | ||
} | ||
|
||
run(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
# Lighthouse Treemap Viewer | ||
|
||
## Development | ||
|
||
```sh | ||
yarn serve-treemap | ||
|
||
# in separate terminal, start build watch | ||
# dependency: `brew install entr` | ||
find lighthouse-treemap | entr -s 'DEBUG=1 yarn build-treemap' | ||
open http://localhost:8000/treemap/?debug | ||
``` |
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
<!-- | ||
Copyright 2020 The Lighthouse Authors. All Rights Reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. | ||
--> | ||
|
||
<!doctype html> | ||
<html> | ||
|
||
<head> | ||
<meta charset="utf-8"> | ||
<meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1"> | ||
<title>Lighthouse Treemap</title> | ||
<link rel="icon" | ||
href=""> | ||
<meta name="theme-color" content="#304ffe"> | ||
<link rel="stylesheet" href="styles/bundled.css"> | ||
</head> | ||
|
||
<body> | ||
<main> | ||
<!-- Inject LHR here. --> | ||
</main> | ||
|
||
<script src="src/bundled.js"></script> | ||
|
||
<!-- Google Analytics --> | ||
<script> | ||
(function (i, s, o, g, r, a, m) { | ||
i['GoogleAnalyticsObject'] = r; i[r] = i[r] || function () { | ||
(i[r].q = i[r].q || []).push(arguments) | ||
}, i[r].l = 1 * new Date(); a = s.createElement(o), | ||
m = s.getElementsByTagName(o)[0]; a.async = 1; a.src = g; m.parentNode.insertBefore(a, m) | ||
})(window, document, 'script', 'https://www.google-analytics.com/analytics.js', 'ga'); | ||
|
||
ga('create', 'UA-85519014-2', 'auto'); | ||
ga('send', 'pageview'); | ||
</script> | ||
</body> | ||
|
||
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
/** | ||
* @license Copyright 2020 The Lighthouse Authors. All Rights Reserved. | ||
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 | ||
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. | ||
*/ | ||
'use strict'; | ||
|
||
/* eslint-env browser */ | ||
|
||
/* globals webtreemap TreemapUtil */ | ||
|
||
/** | ||
* Allows for saving the document and loading with data intact. | ||
* @param {LH.Treemap.Options} options | ||
*/ | ||
function injectOptions(options) { | ||
if (window.__treemapOptions) return; | ||
|
||
const scriptEl = document.createElement('script'); | ||
scriptEl.textContent = ` | ||
window.__treemapOptions = ${JSON.stringify(options)}; | ||
`; | ||
document.head.append(scriptEl); | ||
} | ||
|
||
/** | ||
* @param {LH.Treemap.Options} options | ||
*/ | ||
function init(options) { | ||
// ==== temporary | ||
TreemapUtil.find('main').textContent = JSON.stringify(options.lhr); | ||
// eslint-disable-next-line no-console | ||
console.log({webtreemap}); | ||
// ==== temporary | ||
|
||
injectOptions(options); | ||
|
||
// eslint-disable-next-line no-console | ||
console.log('window.__treemapOptions', window.__treemapOptions); | ||
} | ||
|
||
/** | ||
* @param {string} message | ||
*/ | ||
function showError(message) { | ||
document.body.textContent = message; | ||
} | ||
|
||
async function main() { | ||
if (window.__treemapOptions) { | ||
// Prefer the hardcoded options from a saved HTML file above all. | ||
init(window.__treemapOptions); | ||
} else if (new URLSearchParams(window.location.search).has('debug')) { | ||
const response = await fetch('debug.json'); | ||
init(await response.json()); | ||
} else { | ||
window.addEventListener('message', e => { | ||
if (e.source !== self.opener) return; | ||
|
||
/** @type {LH.Treemap.Options} */ | ||
const options = e.data; | ||
const {lhr} = options; | ||
if (!lhr) return showError('Error: Invalid options'); | ||
|
||
const documentUrl = lhr.requestedUrl; | ||
if (!documentUrl) return showError('Error: Invalid options'); | ||
|
||
init(options); | ||
}); | ||
} | ||
|
||
// If the page was opened as a popup, tell the opening window we're ready. | ||
if (self.opener && !self.opener.closed) { | ||
self.opener.postMessage({opened: true}, '*'); | ||
} | ||
} | ||
|
||
document.addEventListener('DOMContentLoaded', main); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
/** | ||
* @license Copyright 2020 The Lighthouse Authors. All Rights Reserved. | ||
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 | ||
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. | ||
*/ | ||
'use strict'; | ||
|
||
/* eslint-env browser */ | ||
|
||
/** @typedef {HTMLElementTagNameMap & {[id: string]: HTMLElement}} HTMLElementByTagName */ | ||
|
||
class TreemapUtil { | ||
/** | ||
* @template {string} T | ||
* @param {T} name | ||
* @param {string=} className | ||
* @param {Object<string, (string|undefined)>=} attrs Attribute key/val pairs. | ||
* Note: if an attribute key has an undefined value, this method does not | ||
* set the attribute on the node. | ||
* @return {HTMLElementByTagName[T]} | ||
*/ | ||
static createElement(name, className, attrs = {}) { | ||
const element = document.createElement(name); | ||
if (className) { | ||
element.className = className; | ||
} | ||
Object.keys(attrs).forEach(key => { | ||
const value = attrs[key]; | ||
if (typeof value !== 'undefined') { | ||
element.setAttribute(key, value); | ||
} | ||
}); | ||
return element; | ||
} | ||
|
||
/** | ||
* @template {string} T | ||
* @param {Element} parentElem | ||
* @param {T} elementName | ||
* @param {string=} className | ||
* @param {Object<string, (string|undefined)>=} attrs Attribute key/val pairs. | ||
* Note: if an attribute key has an undefined value, this method does not | ||
* set the attribute on the node. | ||
* @return {HTMLElementByTagName[T]} | ||
*/ | ||
static createChildOf(parentElem, elementName, className, attrs) { | ||
const element = this.createElement(elementName, className, attrs); | ||
parentElem.appendChild(element); | ||
return element; | ||
} | ||
|
||
/** | ||
* Guaranteed context.querySelector. Always returns an element or throws if | ||
* nothing matches query. | ||
* @param {string} query | ||
* @param {ParentNode=} context | ||
* @return {HTMLElement} | ||
*/ | ||
static find(query, context = document) { | ||
/** @type {?HTMLElement} */ | ||
const result = context.querySelector(query); | ||
if (result === null) { | ||
throw new Error(`query ${query} not found`); | ||
} | ||
return result; | ||
} | ||
} | ||
|
||
// node export for testing. | ||
if (typeof module !== 'undefined' && module.exports) { | ||
module.exports = TreemapUtil; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
/** | ||
* @license Copyright 2020 The Lighthouse Authors. All Rights Reserved. | ||
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 | ||
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. | ||
*/ | ||
|
||
body { | ||
margin: 0; | ||
overflow-y: hidden; | ||
} |
Oops, something went wrong.