@stencil/core 2.18.0 → 2.19.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/cli/index.cjs +275 -218
  2. package/cli/index.d.ts +3 -0
  3. package/cli/index.js +275 -218
  4. package/cli/package.json +1 -1
  5. package/compiler/package.json +1 -1
  6. package/compiler/stencil.d.ts +2 -2
  7. package/compiler/stencil.js +49510 -47947
  8. package/compiler/stencil.min.js +2 -2
  9. package/dependencies.json +1 -1
  10. package/dev-server/client/index.d.ts +2 -2
  11. package/dev-server/client/index.js +241 -241
  12. package/dev-server/client/package.json +1 -1
  13. package/dev-server/connector.html +3 -3
  14. package/dev-server/index.d.ts +1 -1
  15. package/dev-server/index.js +2 -2
  16. package/dev-server/package.json +1 -1
  17. package/dev-server/server-process.js +1230 -1199
  18. package/internal/app-data/package.json +1 -1
  19. package/internal/client/css-shim.js +2 -2
  20. package/internal/client/dom.js +1 -1
  21. package/internal/client/index.js +619 -601
  22. package/internal/client/package.json +1 -1
  23. package/internal/client/patch-browser.js +1 -1
  24. package/internal/client/patch-esm.js +1 -1
  25. package/internal/client/polyfills/css-shim.js +1 -1
  26. package/internal/client/shadow-css.js +1 -1
  27. package/internal/hydrate/index.js +119 -119
  28. package/internal/hydrate/package.json +1 -1
  29. package/internal/hydrate/runner.d.ts +1 -1
  30. package/internal/hydrate/runner.js +100 -100
  31. package/internal/package.json +1 -1
  32. package/internal/stencil-core/index.d.ts +8 -10
  33. package/internal/stencil-private.d.ts +104 -42
  34. package/internal/stencil-public-compiler.d.ts +12 -2
  35. package/internal/stencil-public-docs.d.ts +20 -0
  36. package/internal/stencil-public-runtime.d.ts +20 -4
  37. package/internal/testing/index.js +148 -148
  38. package/internal/testing/package.json +1 -1
  39. package/mock-doc/index.cjs +655 -645
  40. package/mock-doc/index.js +655 -645
  41. package/mock-doc/package.json +1 -1
  42. package/package.json +29 -37
  43. package/readme.md +27 -33
  44. package/screenshot/index.d.ts +1 -1
  45. package/screenshot/index.js +3 -3
  46. package/screenshot/package.json +1 -1
  47. package/screenshot/pixel-match.js +983 -849
  48. package/sys/node/autoprefixer.js +5 -5
  49. package/sys/node/glob.js +1 -1
  50. package/sys/node/graceful-fs.js +1 -1
  51. package/sys/node/index.d.ts +4 -0
  52. package/sys/node/index.js +373 -374
  53. package/sys/node/package.json +1 -1
  54. package/sys/node/prompts.js +1 -1
  55. package/sys/node/worker.js +1 -1
  56. package/testing/index.d.ts +6 -6
  57. package/testing/index.js +468 -467
  58. package/testing/jest/jest-config.d.ts +1 -1
  59. package/testing/matchers/index.d.ts +3 -3
  60. package/testing/mock-fetch.d.ts +1 -1
  61. package/testing/mocks.d.ts +2 -2
  62. package/testing/package.json +1 -1
  63. package/testing/puppeteer/puppeteer-element.d.ts +2 -2
  64. package/testing/puppeteer/puppeteer-events.d.ts +1 -1
  65. package/testing/testing-logger.d.ts +1 -1
  66. package/testing/testing.d.ts +1 -1
package/dependencies.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "dependencies": [
3
3
  {
4
4
  "name": "@stencil/core",
5
- "version": "2.18.0",
5
+ "version": "2.19.0",
6
6
  "main": "compiler/stencil.js",
7
7
  "resources": [
8
8
  "package.json",
@@ -1,6 +1,6 @@
1
1
  export { appError, clearAppErrorModal } from './app-error';
2
2
  export { emitBuildLog, emitBuildResults, emitBuildStatus, onBuildLog, onBuildResults, onBuildStatus } from './events';
3
+ export { hmrWindow } from './hmr-window';
4
+ export { logBuild, logDiagnostic, logDisabled, logReload, logWarn } from './logger';
3
5
  export { initBuildProgress } from './progress';
4
6
  export { initBuildStatus } from './status';
5
- export { logBuild, logDiagnostic, logDisabled, logReload, logWarn } from './logger';
6
- export { hmrWindow } from './hmr-window';
@@ -1,5 +1,5 @@
1
1
  /*!
2
- Stencil Dev Server Client v2.18.0 | MIT Licensed | https://stenciljs.com
2
+ Stencil Dev Server Client v2.19.0 | MIT Licensed | https://stenciljs.com
3
3
  */
4
4
  var appErrorCss = "#dev-server-modal * { box-sizing: border-box !important; } #dev-server-modal { direction: ltr !important; display: block !important; position: absolute !important; top: 0 !important; right: 0 !important; bottom: 0 !important; left: 0 !important; z-index: 100000; margin: 0 !important; padding: 0 !important; font-family: -apple-system, 'Roboto', BlinkMacSystemFont, 'Segoe UI', 'Helvetica Neue', sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol' !important; font-size: 14px !important; line-height: 1.5 !important; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; text-size-adjust: none; word-wrap: break-word; color: #333 !important; background-color: white !important; box-sizing: border-box !important; overflow: hidden; user-select: auto; } #dev-server-modal-inner { position: relative !important; padding: 0 0 30px 0 !important; width: 100% !important; height: 100%; overflow-x: hidden; overflow-y: scroll; -webkit-overflow-scrolling: touch; } .dev-server-diagnostic { margin: 20px !important; border: 1px solid #ddd !important; border-radius: 3px !important; } .dev-server-diagnostic-masthead { padding: 8px 12px 12px 12px !important; } .dev-server-diagnostic-title { margin: 0 !important; font-weight: bold !important; color: #222 !important; } .dev-server-diagnostic-message { margin-top: 4px !important; color: #555 !important; } .dev-server-diagnostic-file { position: relative !important; border-top: 1px solid #ddd !important; } .dev-server-diagnostic-file-header { display: block !important; padding: 5px 10px !important; color: #555 !important; border-bottom: 1px solid #ddd !important; border-top-left-radius: 2px !important; border-top-right-radius: 2px !important; background-color: #f9f9f9 !important; font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace !important; font-size: 12px !important; } a.dev-server-diagnostic-file-header { color: #0000ee !important; text-decoration: underline !important; } a.dev-server-diagnostic-file-header:hover { text-decoration: none !important; background-color: #f4f4f4 !important; } .dev-server-diagnostic-file-name { font-weight: bold !important; } .dev-server-diagnostic-blob { overflow-x: auto !important; overflow-y: hidden !important; border-bottom-right-radius: 3px !important; border-bottom-left-radius: 3px !important; } .dev-server-diagnostic-table { margin: 0 !important; padding: 0 !important; border-spacing: 0 !important; border-collapse: collapse !important; border-width: 0 !important; border-style: none !important; -moz-tab-size: 2; tab-size: 2; } .dev-server-diagnostic-table td, .dev-server-diagnostic-table th { padding: 0 !important; border-width: 0 !important; border-style: none !important; } td.dev-server-diagnostic-blob-num { padding-right: 10px !important; padding-left: 10px !important; width: 1% !important; min-width: 50px !important; font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace !important; font-size: 12px !important; line-height: 20px !important; color: rgba(0, 0, 0, 0.3) !important; text-align: right !important; white-space: nowrap !important; vertical-align: top !important; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; border: solid #eee !important; border-width: 0 1px 0 0 !important; } td.dev-server-diagnostic-blob-num::before { content: attr(data-line-number) !important; } .dev-server-diagnostic-error-line td.dev-server-diagnostic-blob-num { background-color: #ffdddd !important; border-color: #ffc9c9 !important; } .dev-server-diagnostic-error-line td.dev-server-diagnostic-blob-code { background: rgba(255, 221, 221, 0.25) !important; z-index: -1; } .dev-server-diagnostic-open-in-editor td.dev-server-diagnostic-blob-num:hover { cursor: pointer; background-color: #ffffe3 !important; font-weight: bold; } .dev-server-diagnostic-open-in-editor.dev-server-diagnostic-error-line td.dev-server-diagnostic-blob-num:hover { background-color: #ffdada !important; } td.dev-server-diagnostic-blob-code { position: relative !important; padding-right: 10px !important; padding-left: 10px !important; line-height: 20px !important; vertical-align: top !important; overflow: visible !important; font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace !important; font-size: 12px !important; color: #333 !important; word-wrap: normal !important; white-space: pre !important; } td.dev-server-diagnostic-blob-code::before { content: '' !important; } .dev-server-diagnostic-error-chr { position: relative !important; } .dev-server-diagnostic-error-chr::before { position: absolute !important; z-index: -1; top: -3px !important; left: 0px !important; width: 8px !important; height: 20px !important; background-color: #ffdddd !important; content: '' !important; } /** * GitHub Gist Theme * Author : Louis Barranqueiro - https://github.com/LouisBarranqueiro * https://highlightjs.org/ */ .hljs-comment, .hljs-meta { color: #969896; } .hljs-string, .hljs-variable, .hljs-template-variable, .hljs-strong, .hljs-emphasis, .hljs-quote { color: #df5000; } .hljs-keyword, .hljs-selector-tag, .hljs-type { color: #a71d5d; } .hljs-literal, .hljs-symbol, .hljs-bullet, .hljs-attribute { color: #0086b3; } .hljs-section, .hljs-name { color: #63a35c; } .hljs-tag { color: #333333; } .hljs-title, .hljs-attr, .hljs-selector-id, .hljs-selector-class, .hljs-selector-attr, .hljs-selector-pseudo { color: #795da3; } .hljs-addition { color: #55a532; background-color: #eaffea; } .hljs-deletion { color: #bd2c00; background-color: #ffecec; } .hljs-link { text-decoration: underline; }";
5
5
 
@@ -260,246 +260,6 @@ const BUILD_LOG = `devserver:buildlog`;
260
260
  const BUILD_RESULTS = `devserver:buildresults`;
261
261
  const BUILD_STATUS = `devserver:buildstatus`;
262
262
 
263
- const initBuildProgress = (data) => {
264
- const win = data.window;
265
- const doc = win.document;
266
- const barColor = `#5851ff`;
267
- const errorColor = `#b70c19`;
268
- let addBarTimerId;
269
- let removeBarTimerId;
270
- let opacityTimerId;
271
- let incIntervalId;
272
- let progressIncrease;
273
- let currentProgress = 0;
274
- function update() {
275
- clearTimeout(opacityTimerId);
276
- clearTimeout(removeBarTimerId);
277
- const progressBar = getProgressBar();
278
- if (!progressBar) {
279
- createProgressBar();
280
- addBarTimerId = setTimeout(update, 16);
281
- return;
282
- }
283
- progressBar.style.background = barColor;
284
- progressBar.style.opacity = `1`;
285
- progressBar.style.transform = `scaleX(${Math.min(1, displayProgress())})`;
286
- if (incIntervalId == null) {
287
- incIntervalId = setInterval(() => {
288
- progressIncrease += Math.random() * 0.05 + 0.01;
289
- if (displayProgress() < 0.9) {
290
- update();
291
- }
292
- else {
293
- clearInterval(incIntervalId);
294
- }
295
- }, 800);
296
- }
297
- }
298
- function reset() {
299
- clearInterval(incIntervalId);
300
- progressIncrease = 0.05;
301
- incIntervalId = null;
302
- clearTimeout(opacityTimerId);
303
- clearTimeout(addBarTimerId);
304
- clearTimeout(removeBarTimerId);
305
- const progressBar = getProgressBar();
306
- if (progressBar) {
307
- if (currentProgress >= 1) {
308
- progressBar.style.transform = `scaleX(1)`;
309
- }
310
- opacityTimerId = setTimeout(() => {
311
- try {
312
- const progressBar = getProgressBar();
313
- if (progressBar) {
314
- progressBar.style.opacity = `0`;
315
- }
316
- }
317
- catch (e) { }
318
- }, 150);
319
- removeBarTimerId = setTimeout(() => {
320
- try {
321
- const progressBar = getProgressBar();
322
- if (progressBar) {
323
- progressBar.parentNode.removeChild(progressBar);
324
- }
325
- }
326
- catch (e) { }
327
- }, 1000);
328
- }
329
- }
330
- function displayProgress() {
331
- const p = currentProgress + progressIncrease;
332
- return Math.max(0, Math.min(1, p));
333
- }
334
- reset();
335
- onBuildLog(win, (buildLog) => {
336
- currentProgress = buildLog.progress;
337
- if (currentProgress >= 0 && currentProgress < 1) {
338
- update();
339
- }
340
- else {
341
- reset();
342
- }
343
- });
344
- onBuildResults(win, (buildResults) => {
345
- if (buildResults.hasError) {
346
- const progressBar = getProgressBar();
347
- if (progressBar) {
348
- progressBar.style.transform = `scaleX(1)`;
349
- progressBar.style.background = errorColor;
350
- }
351
- }
352
- reset();
353
- });
354
- onBuildStatus(win, (buildStatus) => {
355
- if (buildStatus === 'disabled') {
356
- reset();
357
- }
358
- });
359
- if (doc.head.dataset.tmpl === 'tmpl-initial-load') {
360
- update();
361
- }
362
- const PROGRESS_BAR_ID = `dev-server-progress-bar`;
363
- function getProgressBar() {
364
- return doc.getElementById(PROGRESS_BAR_ID);
365
- }
366
- function createProgressBar() {
367
- const progressBar = doc.createElement('div');
368
- progressBar.id = PROGRESS_BAR_ID;
369
- progressBar.style.position = `absolute`;
370
- progressBar.style.top = `0`;
371
- progressBar.style.left = `0`;
372
- progressBar.style.zIndex = `100001`;
373
- progressBar.style.width = `100%`;
374
- progressBar.style.height = `2px`;
375
- progressBar.style.transform = `scaleX(0)`;
376
- progressBar.style.opacity = `1`;
377
- progressBar.style.background = barColor;
378
- progressBar.style.transformOrigin = `left center`;
379
- progressBar.style.transition = `transform .1s ease-in-out, opacity .5s ease-in`;
380
- progressBar.style.contain = `strict`;
381
- doc.body.appendChild(progressBar);
382
- }
383
- };
384
-
385
- const initBuildStatus = (data) => {
386
- const win = data.window;
387
- const doc = win.document;
388
- const iconElms = getFavIcons(doc);
389
- iconElms.forEach((iconElm) => {
390
- if (iconElm.href) {
391
- iconElm.dataset.href = iconElm.href;
392
- iconElm.dataset.type = iconElm.type;
393
- }
394
- });
395
- onBuildStatus(win, (buildStatus) => {
396
- updateBuildStatus(doc, buildStatus);
397
- });
398
- };
399
- const updateBuildStatus = (doc, status) => {
400
- const iconElms = getFavIcons(doc);
401
- iconElms.forEach((iconElm) => {
402
- updateFavIcon(iconElm, status);
403
- });
404
- };
405
- const updateFavIcon = (linkElm, status) => {
406
- if (status === 'pending') {
407
- linkElm.href = ICON_PENDING;
408
- linkElm.type = ICON_TYPE;
409
- linkElm.setAttribute('data-status', status);
410
- }
411
- else if (status === 'error') {
412
- linkElm.href = ICON_ERROR;
413
- linkElm.type = ICON_TYPE;
414
- linkElm.setAttribute('data-status', status);
415
- }
416
- else if (status === 'disabled') {
417
- linkElm.href = ICON_DISABLED;
418
- linkElm.type = ICON_TYPE;
419
- linkElm.setAttribute('data-status', status);
420
- }
421
- else {
422
- linkElm.removeAttribute('data-status');
423
- if (linkElm.dataset.href) {
424
- linkElm.href = linkElm.dataset.href;
425
- linkElm.type = linkElm.dataset.type;
426
- }
427
- else {
428
- linkElm.href = ICON_DEFAULT;
429
- linkElm.type = ICON_TYPE;
430
- }
431
- }
432
- };
433
- const getFavIcons = (doc) => {
434
- const iconElms = [];
435
- const linkElms = doc.querySelectorAll('link');
436
- for (let i = 0; i < linkElms.length; i++) {
437
- if (linkElms[i].href &&
438
- linkElms[i].rel &&
439
- (linkElms[i].rel.indexOf('shortcut') > -1 || linkElms[i].rel.indexOf('icon') > -1)) {
440
- iconElms.push(linkElms[i]);
441
- }
442
- }
443
- if (iconElms.length === 0) {
444
- const linkElm = doc.createElement('link');
445
- linkElm.rel = 'shortcut icon';
446
- doc.head.appendChild(linkElm);
447
- iconElms.push(linkElm);
448
- }
449
- return iconElms;
450
- };
451
- const ICON_DEFAULT = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMAAAADACAMAAABlApw1AAAAnFBMVEUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD4jUzeAAAAM3RSTlMAsGDs4wML8QEbBvr2FMhAM7+ILCUPnNzXrX04otO6j3RiT0ggzLSTcmtWUUWoZlknghZc2mZzAAACrklEQVR42u3dWXLiUAyFYWEwg40x8wxhSIAwJtH+99ZVeeinfriXVpWk5Hyr+C2VrgkAAAAAAAAAAAw5sZQ7aUhYypw07FjKC2ko2yxk2SQFgwYLOWSkYFhlIZ06KWhNWMhqRApGKxYyaZGCeoeFVIekIDuwkEaXFDSXLKRdkoYjS9mRhjlLSUjDO0s5kYYzS+mThn3OQsYqAbQQC7hZSgoGYgHUy0jBa42FvKkEUDERC6CCFIzeWEjtlRRkPbGAG5CCtCIWQAtS0ByzkHxPGvos5UEaNizlnTRsWconhbM4wTpSFHMTrFtKCroNFrLGBOsJLbGAWxWkoFiJBRAmWE/I1r4nWOmNheTeJ1gX0vDJUrYUweAEa04aHs5XePvc9wpPboJ1SCmOsRVkr04aromUEQEAgB9lxaZ++ATFpNDv6Y8qm1QdBk9QTAr9ni6mbFK7DJ6g2LQLXoHZlFCQdMY2nYJXYDb1g1dgNo2boSswm2Zp6ArMptCFyIVtCl2IlDmbNC0QcPEQcD8l4HLvAXdxHnBb5wG3QcDFQ8D9mIDrIeCiIeDiA25oNeA+EHDREHDxAbdmmxBwT0HARQbciW0KDbiEbQoNuB3bFBxwbTYJAfcUBFxkwFG/YlNJAADgxzCRcqUY9m7KGgNSUEx9H3XXO76Puv/OY5wedX/flHk+6j46v2maO79purPvm6Yz+75puua+b5q6Dd/PEsrNMyZfFM5gAMW+ymPtWciYV3ksBpBOwKUH3wHXXLKUM2l4cR5wG+cBlzgPuJ3zgJNb6FRwlP4Ln1X8wrOKeFbxP6Qz3wEn+KzilWLYe5UnMuDwY5BvD+cBt899B9zC+49Bqr4DrlXzHXDF1HfA1Tu+Ay5b+w649OY74OjoO+Bo7jzg7s4DDgAAAAAAAAAA/u0POrfnVIaqz/QAAAAASUVORK5CYII=';
452
- const ICON_PENDING = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMAAAADACAMAAABlApw1AAAAjVBMVEUAAAD8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjLn7xn3AAAALnRSTlMAsFBgAaDxfPpAdTMcD/fs47kDBhVXJQpvLNbInIiBRvSqIb+TZ2OOONxdzUxpgKSpAAAAA69JREFUeNrt3FtvskAQxvERFQXFioqnCkqth572+3+8947dN00TliF5ZpP53ZOAveg/OzCklFJKKaWUUkoppQTZm77cCGFo+jIhhG/TlwchJAvTk/GIAA6x6Um+JoDti+nJ644A5h+mJ8eMALKj6cnHnAB2r80NLJ4jf3Vz+cuWANZ5cwPTM/l7by6PZwQwGptGQf4q++dLCOHdNIbkb2IvjwjAvYEf8pe6j4/wYxopr/9SQih4BXa3l5eEcJ7a++c9/gkSQE8bcCWvXwcrAjjYADrxHv8KCbi3JasgD5fm8i9IAG1swMXzDv0X2wDaEED21dzA5UDeVoPm8uUbAayvvAI42YA7EIDzA5pv8lc6/UoAoxMv4CZuvyKUpnHn9VNBAG6B7XkBtCeEO6/AbvbyihAiXsB92svfCcA9wap4j19DAmgWs37AZCrnBKvu8vgX9AmWE3BZh/6L7QkWJIA2RxtwHQpml9sAQp9gXWbkbxz4CdYDfIK1qk1j3IV9fPgJFlNECJXhYfSfsBHkhBCKwEd452nYI7wncwQJP8GKTU+uO0I4D/uSkVJKqXAkA5nK9icoIi3nrU9QRHrZtj5BESmetT5BEantPCh7NTJFrUdgMg1bj8BkSv1HYJ8RmjMQKf1HYDdC+/R/IyQFzbD4AxH+CIyPPxCJoEdQ/IFIMgXNEPkDkd8jMLQs5wRcTXA1J+By/BGO+0ovYwQGU3kPRLJfIzCkCSfgpgmhpc5AxD/gIkLb8wKO0DTgoNyaGQQecNfQAy7TgGtHA04DLtyA24UecHngAVdrwIkJuAitU8DJ1Dbghkam9gEnU+uAWxiRjhsdoXagI1TPgKNyIBO+ZpRSSrW3HfblTAA9/juPDwTAfiMK9VG3PY/hwX7Ubc9j+AoCWNWGp+NSH4HflE2IgXUEGPI3TTfmN4ndv2kSsRUJvpUn4W1FShbYb5rc84ySAtzKs3W3IgW4lWfO24q0zsFbebIjaysSjbtt5RHzUf0DHHCrAW8gVYEDzl0LGYW4lefB24uYQgOOfwN7dMANeW/k3DkBJ2CrUNE54GRsFYIHnPNR+iPEgHPWKo5DDDhnrWKeBRhwzlrFeNtlq5CgtYqzAAPODaBzgAH331rFAAOOqsDXKjL3IqboN7ILJ4BCDDh3r3SIAfd0AijEgHP3So/8wQNuvjRBbxVij5A6Bpy8EZJnwIkbIfkFnLwRkm/ASRshXbwDTtYICRRwt7BHqEoppZRSSimllFLqD/8AOXJZHefotiIAAAAASUVORK5CYII=';
453
- const ICON_ERROR = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMAAAADACAMAAABlApw1AAAAkFBMVEUAAAD5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0HYvLBZAAAAL3RSTlMAsGDjA/rsC/ElHRUBBssz9pFCvoh0UEcsD9ec3K19OLiiaNLEYlmoVeiCbmE+GuMl4I8AAAKQSURBVHja7d1njupQDIZhAymEUIZQQu9taN7/7q50pfl/TmTJtvQ9q3hzLDsEAAAAAAAAAACGzFjKiTS0WcqONMxZypg0fH5YyLFPChZdFnIYkILil4VcclLw3bCQ85IULM8sZPMlBfmFhfwWpGBwYCHdESnoH1nIz4c0jFnKnDTsWEqbNJxYyow03FjKlDTUKQtZqwTQXizgtgkpWGQsZKIScL0OCxmqBFC5EQugkhQshyyk0yMFgwkLyRakIGmJBdCeFPTXLCStScOUpdwogsEXrBdpuLKUJ4XDC9afKmUh94QUjLy/YGViAZRTOIMBtypJQXn2HUC5WMBleMFqILmzkLSicBZfsB6k4clSrqTh5XyEd3MeQHXqe4Qn94LVSiicwRHkJScNdVvKkgAAwI+qZdM0/AXFpE4v+AXFpKwIfkExKfR7ulyxSWkV/IJi0zx4BGbTm4IkW7ZpFjwCs2kaPAKzad0PHYHZtE1CR2A2TQahIzCbhnnwCMykVYmAi4aAQ8BZ4T3grgi4BhBwCDgbEHCNIOAQcCYg4BpCwCHgLEDAaYgPuDfbhIBrBAGHgDMhNOBo2rKpIgAA8KNoS6kplq2dsu6CFJQr30vd+dD3Uvf/nTLHS93J3flZwrHznaad852mE/veaXqw752mKvW90zTq+j5LWGS+r/J8xQKoU1AUa2chm1zlsXQWUifgkoPvgOsffQccjZ0H3Mx5wL2dB9zcecB9sJTePOBM3cU+46wiziq6C7hk6zvg3J9VfDK7vir0ch5wN+cBV6e+A27v/ccgme+AkxshTXKKYW6EFH0X29gIKTLgzI2QYgPO2ggpLuDsvaDEBZy9EVJcwBkcIT0IAAAAAAAAAADs+AdjeyF69/r87QAAAABJRU5ErkJggg==';
454
- const ICON_DISABLED = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMAAAADACAMAAABlApw1AAAAeFBMVEUAAAC4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7/uGGySAAAAJ3RSTlMAsGAE7OMcAQvxJRX69kHWyL8zq5GIdEcsD5zcfVg4uKLNa1JPZoK/xdPIAAACiklEQVR42u3dW5KqUAyF4QgCCggqIt7t9pb5z/Ccvjz2w95UqpJ0r28Uf2WTQAAAAAAAAAAAYMiWpTxJQ8JSTqThwVI2pKFZsJC3ghTs5izkmpKCcspCljNSkB9ZSLsnBfuWhRxzUjBbspBpSQrSKwuZr0lB8cZCFg1p2LCUB2k4sZSENNxYypY0nFlKTxqGmoUcClJwEQu4SUoKdmIBtEpJQZ6xkHeVAKqOYgFUkYL9OwvJclKQrsQCbkcK0olYAF1IQXFgIfVAGnqWcqZwFidYN4phb4L1onCYYMlPsLqUFKwxwRozwTIYcG1FCqrWdwBhgqU7wUo7FlJ7n2DdScPL+RPezfkT3tl5AA217yc89xMssYBbzUjDkEjZEwAA+NFMbOrDJygmZXnwBMWkaRk8QTFpvg6eoJi0aIInKDY9gp/AbEqCJyg2bYOfwGzqKUzPNh2K0Ccwm0IfRBK2KfSLkDvbFPog0tRsUlsh4EZAwP2SgKu9B9wdATcOAg4BZwACbgQEHALOCATcCAg4BJwVCLhREHB/LOAebFNwwC3YJATcKAi4yICjfmJTQwAA4EeZSBkojrWdsvmO4hjbKYtd6ra2Uxa71G1tp0xnqbvo+IPfpe4Nf3K703Ridr3T9OQPfnea7szseaepqX3vNH3NM/xe5fmeZ7i9yiMXQFlJEeydhYy4ymMygCICzmQAxQactbOQMQFnMoBiAs7iVaHIgDN3VSgq4AxeFYoOOGNXhbCUPkaJs4o4q/iXzyp2vgPO/VnFl/OAu/F/jq8KnZ0H3FD7DriL9x+DTH0HXJ75Driq9R1ws6XvgEuvvgOu6HwHHG18BxydnAfc03nAAQAAAAAAAADAz/4BoL2Us9XM2zMAAAAASUVORK5CYII=';
455
- const ICON_TYPE = 'image/x-icon';
456
-
457
- const logBuild = (msg) => log(BLUE, 'Build', msg);
458
- const logReload = (msg) => logWarn('Reload', msg);
459
- const logWarn = (prefix, msg) => log(YELLOW, prefix, msg);
460
- const logDisabled = (prefix, msg) => log(GRAY, prefix, msg);
461
- const logDiagnostic = (diag) => {
462
- const diagnostic = diag;
463
- let color = RED;
464
- let prefix = 'Error';
465
- if (diagnostic.level === 'warn') {
466
- color = YELLOW;
467
- prefix = 'Warning';
468
- }
469
- if (diagnostic.header) {
470
- prefix = diagnostic.header;
471
- }
472
- let msg = ``;
473
- if (diagnostic.relFilePath) {
474
- msg += diagnostic.relFilePath;
475
- if (typeof diagnostic.lineNumber === 'number' && diagnostic.lineNumber > 0) {
476
- msg += ', line ' + diagnostic.lineNumber;
477
- if (typeof diagnostic.columnNumber === 'number' && diagnostic.columnNumber > 0) {
478
- msg += ', column ' + diagnostic.columnNumber;
479
- }
480
- }
481
- msg += `\n`;
482
- }
483
- msg += diagnostic.messageText;
484
- log(color, prefix, msg);
485
- };
486
- const log = (color, prefix, msg) => {
487
- if (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.indexOf('Trident') > -1) {
488
- console.log(prefix, msg);
489
- }
490
- else {
491
- console.log.apply(console, [
492
- '%c' + prefix,
493
- `background: ${color}; color: white; padding: 2px 3px; border-radius: 2px; font-size: 0.8em;`,
494
- msg,
495
- ]);
496
- }
497
- };
498
- const YELLOW = `#f39c12`;
499
- const RED = `#c0392b`;
500
- const BLUE = `#3498db`;
501
- const GRAY = `#717171`;
502
-
503
263
  const getHmrHref = (versionId, fileName, testUrl) => {
504
264
  if (typeof testUrl === 'string' && testUrl.trim() !== '') {
505
265
  if (getUrlFileName(fileName) === getUrlFileName(testUrl)) {
@@ -805,4 +565,244 @@ const hmrWindow = (data) => {
805
565
  return results;
806
566
  };
807
567
 
568
+ const logBuild = (msg) => log(BLUE, 'Build', msg);
569
+ const logReload = (msg) => logWarn('Reload', msg);
570
+ const logWarn = (prefix, msg) => log(YELLOW, prefix, msg);
571
+ const logDisabled = (prefix, msg) => log(GRAY, prefix, msg);
572
+ const logDiagnostic = (diag) => {
573
+ const diagnostic = diag;
574
+ let color = RED;
575
+ let prefix = 'Error';
576
+ if (diagnostic.level === 'warn') {
577
+ color = YELLOW;
578
+ prefix = 'Warning';
579
+ }
580
+ if (diagnostic.header) {
581
+ prefix = diagnostic.header;
582
+ }
583
+ let msg = ``;
584
+ if (diagnostic.relFilePath) {
585
+ msg += diagnostic.relFilePath;
586
+ if (typeof diagnostic.lineNumber === 'number' && diagnostic.lineNumber > 0) {
587
+ msg += ', line ' + diagnostic.lineNumber;
588
+ if (typeof diagnostic.columnNumber === 'number' && diagnostic.columnNumber > 0) {
589
+ msg += ', column ' + diagnostic.columnNumber;
590
+ }
591
+ }
592
+ msg += `\n`;
593
+ }
594
+ msg += diagnostic.messageText;
595
+ log(color, prefix, msg);
596
+ };
597
+ const log = (color, prefix, msg) => {
598
+ if (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.indexOf('Trident') > -1) {
599
+ console.log(prefix, msg);
600
+ }
601
+ else {
602
+ console.log.apply(console, [
603
+ '%c' + prefix,
604
+ `background: ${color}; color: white; padding: 2px 3px; border-radius: 2px; font-size: 0.8em;`,
605
+ msg,
606
+ ]);
607
+ }
608
+ };
609
+ const YELLOW = `#f39c12`;
610
+ const RED = `#c0392b`;
611
+ const BLUE = `#3498db`;
612
+ const GRAY = `#717171`;
613
+
614
+ const initBuildProgress = (data) => {
615
+ const win = data.window;
616
+ const doc = win.document;
617
+ const barColor = `#5851ff`;
618
+ const errorColor = `#b70c19`;
619
+ let addBarTimerId;
620
+ let removeBarTimerId;
621
+ let opacityTimerId;
622
+ let incIntervalId;
623
+ let progressIncrease;
624
+ let currentProgress = 0;
625
+ function update() {
626
+ clearTimeout(opacityTimerId);
627
+ clearTimeout(removeBarTimerId);
628
+ const progressBar = getProgressBar();
629
+ if (!progressBar) {
630
+ createProgressBar();
631
+ addBarTimerId = setTimeout(update, 16);
632
+ return;
633
+ }
634
+ progressBar.style.background = barColor;
635
+ progressBar.style.opacity = `1`;
636
+ progressBar.style.transform = `scaleX(${Math.min(1, displayProgress())})`;
637
+ if (incIntervalId == null) {
638
+ incIntervalId = setInterval(() => {
639
+ progressIncrease += Math.random() * 0.05 + 0.01;
640
+ if (displayProgress() < 0.9) {
641
+ update();
642
+ }
643
+ else {
644
+ clearInterval(incIntervalId);
645
+ }
646
+ }, 800);
647
+ }
648
+ }
649
+ function reset() {
650
+ clearInterval(incIntervalId);
651
+ progressIncrease = 0.05;
652
+ incIntervalId = null;
653
+ clearTimeout(opacityTimerId);
654
+ clearTimeout(addBarTimerId);
655
+ clearTimeout(removeBarTimerId);
656
+ const progressBar = getProgressBar();
657
+ if (progressBar) {
658
+ if (currentProgress >= 1) {
659
+ progressBar.style.transform = `scaleX(1)`;
660
+ }
661
+ opacityTimerId = setTimeout(() => {
662
+ try {
663
+ const progressBar = getProgressBar();
664
+ if (progressBar) {
665
+ progressBar.style.opacity = `0`;
666
+ }
667
+ }
668
+ catch (e) { }
669
+ }, 150);
670
+ removeBarTimerId = setTimeout(() => {
671
+ try {
672
+ const progressBar = getProgressBar();
673
+ if (progressBar) {
674
+ progressBar.parentNode.removeChild(progressBar);
675
+ }
676
+ }
677
+ catch (e) { }
678
+ }, 1000);
679
+ }
680
+ }
681
+ function displayProgress() {
682
+ const p = currentProgress + progressIncrease;
683
+ return Math.max(0, Math.min(1, p));
684
+ }
685
+ reset();
686
+ onBuildLog(win, (buildLog) => {
687
+ currentProgress = buildLog.progress;
688
+ if (currentProgress >= 0 && currentProgress < 1) {
689
+ update();
690
+ }
691
+ else {
692
+ reset();
693
+ }
694
+ });
695
+ onBuildResults(win, (buildResults) => {
696
+ if (buildResults.hasError) {
697
+ const progressBar = getProgressBar();
698
+ if (progressBar) {
699
+ progressBar.style.transform = `scaleX(1)`;
700
+ progressBar.style.background = errorColor;
701
+ }
702
+ }
703
+ reset();
704
+ });
705
+ onBuildStatus(win, (buildStatus) => {
706
+ if (buildStatus === 'disabled') {
707
+ reset();
708
+ }
709
+ });
710
+ if (doc.head.dataset.tmpl === 'tmpl-initial-load') {
711
+ update();
712
+ }
713
+ const PROGRESS_BAR_ID = `dev-server-progress-bar`;
714
+ function getProgressBar() {
715
+ return doc.getElementById(PROGRESS_BAR_ID);
716
+ }
717
+ function createProgressBar() {
718
+ const progressBar = doc.createElement('div');
719
+ progressBar.id = PROGRESS_BAR_ID;
720
+ progressBar.style.position = `absolute`;
721
+ progressBar.style.top = `0`;
722
+ progressBar.style.left = `0`;
723
+ progressBar.style.zIndex = `100001`;
724
+ progressBar.style.width = `100%`;
725
+ progressBar.style.height = `2px`;
726
+ progressBar.style.transform = `scaleX(0)`;
727
+ progressBar.style.opacity = `1`;
728
+ progressBar.style.background = barColor;
729
+ progressBar.style.transformOrigin = `left center`;
730
+ progressBar.style.transition = `transform .1s ease-in-out, opacity .5s ease-in`;
731
+ progressBar.style.contain = `strict`;
732
+ doc.body.appendChild(progressBar);
733
+ }
734
+ };
735
+
736
+ const initBuildStatus = (data) => {
737
+ const win = data.window;
738
+ const doc = win.document;
739
+ const iconElms = getFavIcons(doc);
740
+ iconElms.forEach((iconElm) => {
741
+ if (iconElm.href) {
742
+ iconElm.dataset.href = iconElm.href;
743
+ iconElm.dataset.type = iconElm.type;
744
+ }
745
+ });
746
+ onBuildStatus(win, (buildStatus) => {
747
+ updateBuildStatus(doc, buildStatus);
748
+ });
749
+ };
750
+ const updateBuildStatus = (doc, status) => {
751
+ const iconElms = getFavIcons(doc);
752
+ iconElms.forEach((iconElm) => {
753
+ updateFavIcon(iconElm, status);
754
+ });
755
+ };
756
+ const updateFavIcon = (linkElm, status) => {
757
+ if (status === 'pending') {
758
+ linkElm.href = ICON_PENDING;
759
+ linkElm.type = ICON_TYPE;
760
+ linkElm.setAttribute('data-status', status);
761
+ }
762
+ else if (status === 'error') {
763
+ linkElm.href = ICON_ERROR;
764
+ linkElm.type = ICON_TYPE;
765
+ linkElm.setAttribute('data-status', status);
766
+ }
767
+ else if (status === 'disabled') {
768
+ linkElm.href = ICON_DISABLED;
769
+ linkElm.type = ICON_TYPE;
770
+ linkElm.setAttribute('data-status', status);
771
+ }
772
+ else {
773
+ linkElm.removeAttribute('data-status');
774
+ if (linkElm.dataset.href) {
775
+ linkElm.href = linkElm.dataset.href;
776
+ linkElm.type = linkElm.dataset.type;
777
+ }
778
+ else {
779
+ linkElm.href = ICON_DEFAULT;
780
+ linkElm.type = ICON_TYPE;
781
+ }
782
+ }
783
+ };
784
+ const getFavIcons = (doc) => {
785
+ const iconElms = [];
786
+ const linkElms = doc.querySelectorAll('link');
787
+ for (let i = 0; i < linkElms.length; i++) {
788
+ if (linkElms[i].href &&
789
+ linkElms[i].rel &&
790
+ (linkElms[i].rel.indexOf('shortcut') > -1 || linkElms[i].rel.indexOf('icon') > -1)) {
791
+ iconElms.push(linkElms[i]);
792
+ }
793
+ }
794
+ if (iconElms.length === 0) {
795
+ const linkElm = doc.createElement('link');
796
+ linkElm.rel = 'shortcut icon';
797
+ doc.head.appendChild(linkElm);
798
+ iconElms.push(linkElm);
799
+ }
800
+ return iconElms;
801
+ };
802
+ const ICON_DEFAULT = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMAAAADACAMAAABlApw1AAAAnFBMVEUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD4jUzeAAAAM3RSTlMAsGDs4wML8QEbBvr2FMhAM7+ILCUPnNzXrX04otO6j3RiT0ggzLSTcmtWUUWoZlknghZc2mZzAAACrklEQVR42u3dWXLiUAyFYWEwg40x8wxhSIAwJtH+99ZVeeinfriXVpWk5Hyr+C2VrgkAAAAAAAAAAAw5sZQ7aUhYypw07FjKC2ko2yxk2SQFgwYLOWSkYFhlIZ06KWhNWMhqRApGKxYyaZGCeoeFVIekIDuwkEaXFDSXLKRdkoYjS9mRhjlLSUjDO0s5kYYzS+mThn3OQsYqAbQQC7hZSgoGYgHUy0jBa42FvKkEUDERC6CCFIzeWEjtlRRkPbGAG5CCtCIWQAtS0ByzkHxPGvos5UEaNizlnTRsWconhbM4wTpSFHMTrFtKCroNFrLGBOsJLbGAWxWkoFiJBRAmWE/I1r4nWOmNheTeJ1gX0vDJUrYUweAEa04aHs5XePvc9wpPboJ1SCmOsRVkr04aromUEQEAgB9lxaZ++ATFpNDv6Y8qm1QdBk9QTAr9ni6mbFK7DJ6g2LQLXoHZlFCQdMY2nYJXYDb1g1dgNo2boSswm2Zp6ArMptCFyIVtCl2IlDmbNC0QcPEQcD8l4HLvAXdxHnBb5wG3QcDFQ8D9mIDrIeCiIeDiA25oNeA+EHDREHDxAbdmmxBwT0HARQbciW0KDbiEbQoNuB3bFBxwbTYJAfcUBFxkwFG/YlNJAADgxzCRcqUY9m7KGgNSUEx9H3XXO76Puv/OY5wedX/flHk+6j46v2maO79purPvm6Yz+75puua+b5q6Dd/PEsrNMyZfFM5gAMW+ymPtWciYV3ksBpBOwKUH3wHXXLKUM2l4cR5wG+cBlzgPuJ3zgJNb6FRwlP4Ln1X8wrOKeFbxP6Qz3wEn+KzilWLYe5UnMuDwY5BvD+cBt899B9zC+49Bqr4DrlXzHXDF1HfA1Tu+Ay5b+w649OY74OjoO+Bo7jzg7s4DDgAAAAAAAAAA/u0POrfnVIaqz/QAAAAASUVORK5CYII=';
803
+ const ICON_PENDING = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMAAAADACAMAAABlApw1AAAAjVBMVEUAAAD8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjL8kjLn7xn3AAAALnRSTlMAsFBgAaDxfPpAdTMcD/fs47kDBhVXJQpvLNbInIiBRvSqIb+TZ2OOONxdzUxpgKSpAAAAA69JREFUeNrt3FtvskAQxvERFQXFioqnCkqth572+3+8947dN00TliF5ZpP53ZOAveg/OzCklFJKKaWUUkoppQTZm77cCGFo+jIhhG/TlwchJAvTk/GIAA6x6Um+JoDti+nJ644A5h+mJ8eMALKj6cnHnAB2r80NLJ4jf3Vz+cuWANZ5cwPTM/l7by6PZwQwGptGQf4q++dLCOHdNIbkb2IvjwjAvYEf8pe6j4/wYxopr/9SQih4BXa3l5eEcJ7a++c9/gkSQE8bcCWvXwcrAjjYADrxHv8KCbi3JasgD5fm8i9IAG1swMXzDv0X2wDaEED21dzA5UDeVoPm8uUbAayvvAI42YA7EIDzA5pv8lc6/UoAoxMv4CZuvyKUpnHn9VNBAG6B7XkBtCeEO6/AbvbyihAiXsB92svfCcA9wap4j19DAmgWs37AZCrnBKvu8vgX9AmWE3BZh/6L7QkWJIA2RxtwHQpml9sAQp9gXWbkbxz4CdYDfIK1qk1j3IV9fPgJFlNECJXhYfSfsBHkhBCKwEd452nYI7wncwQJP8GKTU+uO0I4D/uSkVJKqXAkA5nK9icoIi3nrU9QRHrZtj5BESmetT5BEantPCh7NTJFrUdgMg1bj8BkSv1HYJ8RmjMQKf1HYDdC+/R/IyQFzbD4AxH+CIyPPxCJoEdQ/IFIMgXNEPkDkd8jMLQs5wRcTXA1J+By/BGO+0ovYwQGU3kPRLJfIzCkCSfgpgmhpc5AxD/gIkLb8wKO0DTgoNyaGQQecNfQAy7TgGtHA04DLtyA24UecHngAVdrwIkJuAitU8DJ1Dbghkam9gEnU+uAWxiRjhsdoXagI1TPgKNyIBO+ZpRSSrW3HfblTAA9/juPDwTAfiMK9VG3PY/hwX7Ubc9j+AoCWNWGp+NSH4HflE2IgXUEGPI3TTfmN4ndv2kSsRUJvpUn4W1FShbYb5rc84ySAtzKs3W3IgW4lWfO24q0zsFbebIjaysSjbtt5RHzUf0DHHCrAW8gVYEDzl0LGYW4lefB24uYQgOOfwN7dMANeW/k3DkBJ2CrUNE54GRsFYIHnPNR+iPEgHPWKo5DDDhnrWKeBRhwzlrFeNtlq5CgtYqzAAPODaBzgAH331rFAAOOqsDXKjL3IqboN7ILJ4BCDDh3r3SIAfd0AijEgHP3So/8wQNuvjRBbxVij5A6Bpy8EZJnwIkbIfkFnLwRkm/ASRshXbwDTtYICRRwt7BHqEoppZRSSimllFLqD/8AOXJZHefotiIAAAAASUVORK5CYII=';
804
+ const ICON_ERROR = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMAAAADACAMAAABlApw1AAAAkFBMVEUAAAD5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0H5Q0HYvLBZAAAAL3RSTlMAsGDjA/rsC/ElHRUBBssz9pFCvoh0UEcsD9ec3K19OLiiaNLEYlmoVeiCbmE+GuMl4I8AAAKQSURBVHja7d1njupQDIZhAymEUIZQQu9taN7/7q50pfl/TmTJtvQ9q3hzLDsEAAAAAAAAAACGzFjKiTS0WcqONMxZypg0fH5YyLFPChZdFnIYkILil4VcclLw3bCQ85IULM8sZPMlBfmFhfwWpGBwYCHdESnoH1nIz4c0jFnKnDTsWEqbNJxYyow03FjKlDTUKQtZqwTQXizgtgkpWGQsZKIScL0OCxmqBFC5EQugkhQshyyk0yMFgwkLyRakIGmJBdCeFPTXLCStScOUpdwogsEXrBdpuLKUJ4XDC9afKmUh94QUjLy/YGViAZRTOIMBtypJQXn2HUC5WMBleMFqILmzkLSicBZfsB6k4clSrqTh5XyEd3MeQHXqe4Qn94LVSiicwRHkJScNdVvKkgAAwI+qZdM0/AXFpE4v+AXFpKwIfkExKfR7ulyxSWkV/IJi0zx4BGbTm4IkW7ZpFjwCs2kaPAKzad0PHYHZtE1CR2A2TQahIzCbhnnwCMykVYmAi4aAQ8BZ4T3grgi4BhBwCDgbEHCNIOAQcCYg4BpCwCHgLEDAaYgPuDfbhIBrBAGHgDMhNOBo2rKpIgAA8KNoS6kplq2dsu6CFJQr30vd+dD3Uvf/nTLHS93J3flZwrHznaad852mE/veaXqw752mKvW90zTq+j5LWGS+r/J8xQKoU1AUa2chm1zlsXQWUifgkoPvgOsffQccjZ0H3Mx5wL2dB9zcecB9sJTePOBM3cU+46wiziq6C7hk6zvg3J9VfDK7vir0ch5wN+cBV6e+A27v/ccgme+AkxshTXKKYW6EFH0X29gIKTLgzI2QYgPO2ggpLuDsvaDEBZy9EVJcwBkcIT0IAAAAAAAAAADs+AdjeyF69/r87QAAAABJRU5ErkJggg==';
805
+ const ICON_DISABLED = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMAAAADACAMAAABlApw1AAAAeFBMVEUAAAC4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7+4t7/uGGySAAAAJ3RSTlMAsGAE7OMcAQvxJRX69kHWyL8zq5GIdEcsD5zcfVg4uKLNa1JPZoK/xdPIAAACiklEQVR42u3dW5KqUAyF4QgCCggqIt7t9pb5z/Ccvjz2w95UqpJ0r28Uf2WTQAAAAAAAAAAAYMiWpTxJQ8JSTqThwVI2pKFZsJC3ghTs5izkmpKCcspCljNSkB9ZSLsnBfuWhRxzUjBbspBpSQrSKwuZr0lB8cZCFg1p2LCUB2k4sZSENNxYypY0nFlKTxqGmoUcClJwEQu4SUoKdmIBtEpJQZ6xkHeVAKqOYgFUkYL9OwvJclKQrsQCbkcK0olYAF1IQXFgIfVAGnqWcqZwFidYN4phb4L1onCYYMlPsLqUFKwxwRozwTIYcG1FCqrWdwBhgqU7wUo7FlJ7n2DdScPL+RPezfkT3tl5AA217yc89xMssYBbzUjDkEjZEwAA+NFMbOrDJygmZXnwBMWkaRk8QTFpvg6eoJi0aIInKDY9gp/AbEqCJyg2bYOfwGzqKUzPNh2K0Ccwm0IfRBK2KfSLkDvbFPog0tRsUlsh4EZAwP2SgKu9B9wdATcOAg4BZwACbgQEHALOCATcCAg4BJwVCLhREHB/LOAebFNwwC3YJATcKAi4yICjfmJTQwAA4EeZSBkojrWdsvmO4hjbKYtd6ra2Uxa71G1tp0xnqbvo+IPfpe4Nf3K703Ridr3T9OQPfnea7szseaepqX3vNH3NM/xe5fmeZ7i9yiMXQFlJEeydhYy4ymMygCICzmQAxQactbOQMQFnMoBiAs7iVaHIgDN3VSgq4AxeFYoOOGNXhbCUPkaJs4o4q/iXzyp2vgPO/VnFl/OAu/F/jq8KnZ0H3FD7DriL9x+DTH0HXJ75Driq9R1ws6XvgEuvvgOu6HwHHG18BxydnAfc03nAAQAAAAAAAADAz/4BoL2Us9XM2zMAAAAASUVORK5CYII=';
806
+ const ICON_TYPE = 'image/x-icon';
807
+
808
808
  export { appError, clearAppErrorModal, emitBuildLog, emitBuildResults, emitBuildStatus, hmrWindow, initBuildProgress, initBuildStatus, logBuild, logDiagnostic, logDisabled, logReload, logWarn, onBuildLog, onBuildResults, onBuildStatus };
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stencil/core/dev-server/client",
3
- "version": "2.18.0",
3
+ "version": "2.19.0",
4
4
  "description": "Stencil Dev Server Client.",
5
5
  "main": "./index.js",
6
6
  "types": "./index.d.ts",