lwc 2.6.1 → 2.7.2

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 (41) hide show
  1. package/dist/engine-dom/esm/es2017/engine-dom.js +590 -394
  2. package/dist/engine-dom/iife/es2017/engine-dom.js +590 -394
  3. package/dist/engine-dom/iife/es2017/engine-dom.min.js +1 -9
  4. package/dist/engine-dom/iife/es2017/engine-dom_debug.js +564 -370
  5. package/dist/engine-dom/iife/es5/engine-dom.js +648 -351
  6. package/dist/engine-dom/iife/es5/engine-dom.min.js +1 -9
  7. package/dist/engine-dom/iife/es5/engine-dom_debug.js +616 -327
  8. package/dist/engine-dom/umd/es2017/engine-dom.js +590 -394
  9. package/dist/engine-dom/umd/es2017/engine-dom.min.js +1 -9
  10. package/dist/engine-dom/umd/es2017/engine-dom_debug.js +564 -370
  11. package/dist/engine-dom/umd/es5/engine-dom.js +648 -351
  12. package/dist/engine-dom/umd/es5/engine-dom.min.js +1 -9
  13. package/dist/engine-dom/umd/es5/engine-dom_debug.js +616 -327
  14. package/dist/engine-server/commonjs/es2017/engine-server.js +670 -472
  15. package/dist/engine-server/commonjs/es2017/engine-server.min.js +1 -9
  16. package/dist/engine-server/esm/es2017/engine-server.js +670 -472
  17. package/dist/synthetic-shadow/esm/es2017/synthetic-shadow.js +74 -9
  18. package/dist/synthetic-shadow/iife/es2017/synthetic-shadow.js +74 -9
  19. package/dist/synthetic-shadow/iife/es2017/synthetic-shadow.min.js +2 -2
  20. package/dist/synthetic-shadow/iife/es2017/synthetic-shadow_debug.js +74 -9
  21. package/dist/synthetic-shadow/iife/es5/synthetic-shadow.js +85 -12
  22. package/dist/synthetic-shadow/iife/es5/synthetic-shadow.min.js +2 -2
  23. package/dist/synthetic-shadow/iife/es5/synthetic-shadow_debug.js +85 -12
  24. package/dist/synthetic-shadow/umd/es2017/synthetic-shadow.js +74 -9
  25. package/dist/synthetic-shadow/umd/es2017/synthetic-shadow.min.js +2 -2
  26. package/dist/synthetic-shadow/umd/es2017/synthetic-shadow_debug.js +74 -9
  27. package/dist/synthetic-shadow/umd/es5/synthetic-shadow.js +85 -12
  28. package/dist/synthetic-shadow/umd/es5/synthetic-shadow.min.js +2 -2
  29. package/dist/synthetic-shadow/umd/es5/synthetic-shadow_debug.js +85 -12
  30. package/dist/wire-service/esm/es2017/wire-service.js +2 -2
  31. package/dist/wire-service/iife/es2017/wire-service.js +2 -2
  32. package/dist/wire-service/iife/es2017/wire-service_debug.js +2 -2
  33. package/dist/wire-service/iife/es5/wire-service.js +11 -11
  34. package/dist/wire-service/iife/es5/wire-service.min.js +1 -1
  35. package/dist/wire-service/iife/es5/wire-service_debug.js +11 -11
  36. package/dist/wire-service/umd/es2017/wire-service.js +2 -2
  37. package/dist/wire-service/umd/es2017/wire-service_debug.js +2 -2
  38. package/dist/wire-service/umd/es5/wire-service.js +11 -11
  39. package/dist/wire-service/umd/es5/wire-service.min.js +1 -1
  40. package/dist/wire-service/umd/es5/wire-service_debug.js +11 -11
  41. package/package.json +8 -8
@@ -24,7 +24,7 @@
24
24
 
25
25
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
26
26
 
27
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
27
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
28
28
 
29
29
  function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
30
30
 
@@ -42,7 +42,7 @@
42
42
 
43
43
  function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
44
44
 
45
- function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
45
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
46
46
 
47
47
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
48
48
 
@@ -56,7 +56,7 @@
56
56
 
57
57
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
58
58
 
59
- function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
59
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
60
60
 
61
61
  /* proxy-compat-disable */
62
62
 
@@ -344,7 +344,7 @@
344
344
  CACHED_PROPERTY_ATTRIBUTE_MAPPING.set(propName, attributeName);
345
345
  return attributeName;
346
346
  }
347
- /** version: 2.6.1 */
347
+ /** version: 2.7.2 */
348
348
 
349
349
  /*
350
350
  * Copyright (c) 2018, salesforce.com, inc.
@@ -456,7 +456,6 @@
456
456
  ENABLE_NODE_LIST_PATCH: null,
457
457
  ENABLE_HTML_COLLECTIONS_PATCH: null,
458
458
  ENABLE_NODE_PATCH: null,
459
- ENABLE_MIXED_SHADOW_MODE: null,
460
459
  ENABLE_WIRE_SYNC_EMIT: null
461
460
  };
462
461
 
@@ -515,7 +514,7 @@
515
514
 
516
515
  function setFeatureFlagForTest(name, value) {
517
516
  }
518
- /** version: 2.6.1 */
517
+ /** version: 2.7.2 */
519
518
 
520
519
  /* proxy-compat-disable */
521
520
 
@@ -558,6 +557,243 @@
558
557
 
559
558
  return s4() + s4() + '-' + s4() + '-' + s4() + '-' + s4() + '-' + s4() + s4() + s4();
560
559
  } // Borrowed from Vue template compiler.
560
+ // Primitives
561
+ //
562
+
563
+
564
+ var ssr$1;
565
+
566
+ function setSsr(ssrImpl) {
567
+ ssr$1 = ssrImpl;
568
+ }
569
+
570
+ var isNativeShadowDefined$1;
571
+
572
+ function setIsNativeShadowDefined(isNativeShadowDefinedImpl) {
573
+ isNativeShadowDefined$1 = isNativeShadowDefinedImpl;
574
+ }
575
+
576
+ var isSyntheticShadowDefined$1;
577
+
578
+ function setIsSyntheticShadowDefined(isSyntheticShadowDefinedImpl) {
579
+ isSyntheticShadowDefined$1 = isSyntheticShadowDefinedImpl;
580
+ }
581
+
582
+ var HTMLElementExported$1;
583
+
584
+ function setHTMLElement(HTMLElementImpl) {
585
+ HTMLElementExported$1 = HTMLElementImpl;
586
+ }
587
+
588
+ var isHydrating$1;
589
+
590
+ function setIsHydrating$1(isHydratingImpl) {
591
+ isHydrating$1 = isHydratingImpl;
592
+ }
593
+
594
+ var insert$1;
595
+
596
+ function setInsert(insertImpl) {
597
+ insert$1 = insertImpl;
598
+ }
599
+
600
+ var remove$1;
601
+
602
+ function setRemove(removeImpl) {
603
+ remove$1 = removeImpl;
604
+ }
605
+
606
+ var createElement$2;
607
+
608
+ function setCreateElement(createElementImpl) {
609
+ createElement$2 = createElementImpl;
610
+ }
611
+
612
+ var createText$1;
613
+
614
+ function setCreateText(createTextImpl) {
615
+ createText$1 = createTextImpl;
616
+ }
617
+
618
+ var createComment$1;
619
+
620
+ function setCreateComment(createCommentImpl) {
621
+ createComment$1 = createCommentImpl;
622
+ }
623
+
624
+ var nextSibling$1;
625
+
626
+ function setNextSibling(nextSiblingImpl) {
627
+ nextSibling$1 = nextSiblingImpl;
628
+ }
629
+
630
+ var attachShadow$1;
631
+
632
+ function setAttachShadow(attachShadowImpl) {
633
+ attachShadow$1 = attachShadowImpl;
634
+ }
635
+
636
+ var getProperty$1;
637
+
638
+ function setGetProperty(getPropertyImpl) {
639
+ getProperty$1 = getPropertyImpl;
640
+ }
641
+
642
+ var setProperty$1;
643
+
644
+ function setSetProperty(setPropertyImpl) {
645
+ setProperty$1 = setPropertyImpl;
646
+ }
647
+
648
+ var setText$1;
649
+
650
+ function setSetText(setTextImpl) {
651
+ setText$1 = setTextImpl;
652
+ }
653
+
654
+ var getAttribute$1;
655
+
656
+ function setGetAttribute(getAttributeImpl) {
657
+ getAttribute$1 = getAttributeImpl;
658
+ }
659
+
660
+ var setAttribute$1;
661
+
662
+ function setSetAttribute(setAttributeImpl) {
663
+ setAttribute$1 = setAttributeImpl;
664
+ }
665
+
666
+ var removeAttribute$1;
667
+
668
+ function setRemoveAttribute(removeAttributeImpl) {
669
+ removeAttribute$1 = removeAttributeImpl;
670
+ }
671
+
672
+ var addEventListener$1;
673
+
674
+ function setAddEventListener(addEventListenerImpl) {
675
+ addEventListener$1 = addEventListenerImpl;
676
+ }
677
+
678
+ var removeEventListener$1;
679
+
680
+ function setRemoveEventListener(removeEventListenerImpl) {
681
+ removeEventListener$1 = removeEventListenerImpl;
682
+ }
683
+
684
+ var dispatchEvent$1;
685
+
686
+ function setDispatchEvent(dispatchEventImpl) {
687
+ dispatchEvent$1 = dispatchEventImpl;
688
+ }
689
+
690
+ var getClassList$1;
691
+
692
+ function setGetClassList(getClassListImpl) {
693
+ getClassList$1 = getClassListImpl;
694
+ }
695
+
696
+ var setCSSStyleProperty$1;
697
+
698
+ function setSetCSSStyleProperty(setCSSStylePropertyImpl) {
699
+ setCSSStyleProperty$1 = setCSSStylePropertyImpl;
700
+ }
701
+
702
+ var getBoundingClientRect$1;
703
+
704
+ function setGetBoundingClientRect(getBoundingClientRectImpl) {
705
+ getBoundingClientRect$1 = getBoundingClientRectImpl;
706
+ }
707
+
708
+ var querySelector$1;
709
+
710
+ function setQuerySelector(querySelectorImpl) {
711
+ querySelector$1 = querySelectorImpl;
712
+ }
713
+
714
+ var querySelectorAll$1;
715
+
716
+ function setQuerySelectorAll(querySelectorAllImpl) {
717
+ querySelectorAll$1 = querySelectorAllImpl;
718
+ }
719
+
720
+ var getElementsByTagName$1;
721
+
722
+ function setGetElementsByTagName(getElementsByTagNameImpl) {
723
+ getElementsByTagName$1 = getElementsByTagNameImpl;
724
+ }
725
+
726
+ var getElementsByClassName$1;
727
+
728
+ function setGetElementsByClassName(getElementsByClassNameImpl) {
729
+ getElementsByClassName$1 = getElementsByClassNameImpl;
730
+ }
731
+
732
+ var getChildren$1;
733
+
734
+ function setGetChildren(getChildrenImpl) {
735
+ getChildren$1 = getChildrenImpl;
736
+ }
737
+
738
+ var getChildNodes$1;
739
+
740
+ function setGetChildNodes(getChildNodesImpl) {
741
+ getChildNodes$1 = getChildNodesImpl;
742
+ }
743
+
744
+ var getFirstChild$1;
745
+
746
+ function setGetFirstChild(getFirstChildImpl) {
747
+ getFirstChild$1 = getFirstChildImpl;
748
+ }
749
+
750
+ var getFirstElementChild$1;
751
+
752
+ function setGetFirstElementChild(getFirstElementChildImpl) {
753
+ getFirstElementChild$1 = getFirstElementChildImpl;
754
+ }
755
+
756
+ var getLastChild$1;
757
+
758
+ function setGetLastChild(getLastChildImpl) {
759
+ getLastChild$1 = getLastChildImpl;
760
+ }
761
+
762
+ var getLastElementChild$1;
763
+
764
+ function setGetLastElementChild(getLastElementChildImpl) {
765
+ getLastElementChild$1 = getLastElementChildImpl;
766
+ }
767
+
768
+ var isConnected$1;
769
+
770
+ function setIsConnected(isConnectedImpl) {
771
+ isConnected$1 = isConnectedImpl;
772
+ }
773
+
774
+ var insertGlobalStylesheet$1;
775
+
776
+ function setInsertGlobalStylesheet(insertGlobalStylesheetImpl) {
777
+ insertGlobalStylesheet$1 = insertGlobalStylesheetImpl;
778
+ }
779
+
780
+ var insertStylesheet$1;
781
+
782
+ function setInsertStylesheet(insertStylesheetImpl) {
783
+ insertStylesheet$1 = insertStylesheetImpl;
784
+ }
785
+
786
+ var defineCustomElement$1;
787
+
788
+ function setDefineCustomElement(defineCustomElementImpl) {
789
+ defineCustomElement$1 = defineCustomElementImpl;
790
+ }
791
+
792
+ var getCustomElement$1;
793
+
794
+ function setGetCustomElement(getCustomElementImpl) {
795
+ getCustomElement$1 = getCustomElementImpl;
796
+ }
561
797
  /*
562
798
  * Copyright (c) 2019, salesforce.com, inc.
563
799
  * All rights reserved.
@@ -798,8 +1034,7 @@
798
1034
 
799
1035
  function createAllEventListeners(vnode) {
800
1036
  var elm = vnode.elm,
801
- on = vnode.data.on,
802
- renderer = vnode.owner.renderer;
1037
+ on = vnode.data.on;
803
1038
 
804
1039
  if (isUndefined$1(on)) {
805
1040
  return;
@@ -810,7 +1045,7 @@
810
1045
  var name;
811
1046
 
812
1047
  for (name in on) {
813
- renderer.addEventListener(elm, name, listener);
1048
+ addEventListener$1(elm, name, listener);
814
1049
  }
815
1050
  }
816
1051
 
@@ -949,8 +1184,7 @@
949
1184
  var ColonCharCode = 58;
950
1185
 
951
1186
  function updateAttrs(oldVnode, vnode) {
952
- var attrs = vnode.data.attrs,
953
- renderer = vnode.owner.renderer;
1187
+ var attrs = vnode.data.attrs;
954
1188
 
955
1189
  if (isUndefined$1(attrs)) {
956
1190
  return;
@@ -963,8 +1197,6 @@
963
1197
  }
964
1198
 
965
1199
  var elm = vnode.elm;
966
- var setAttribute = renderer.setAttribute,
967
- removeAttribute = renderer.removeAttribute;
968
1200
  var key;
969
1201
  oldAttrs = isUndefined$1(oldAttrs) ? EmptyObject : oldAttrs; // update modified attributes, add new attributes
970
1202
  // this routine is only useful for data-* attributes in all kind of elements
@@ -979,14 +1211,14 @@
979
1211
 
980
1212
  if (StringCharCodeAt.call(key, 3) === ColonCharCode) {
981
1213
  // Assume xml namespace
982
- setAttribute(elm, key, cur, xmlNS);
1214
+ setAttribute$1(elm, key, cur, xmlNS);
983
1215
  } else if (StringCharCodeAt.call(key, 5) === ColonCharCode) {
984
1216
  // Assume xlink namespace
985
- setAttribute(elm, key, cur, xlinkNS);
986
- } else if (isNull(cur)) {
987
- removeAttribute(elm, key);
1217
+ setAttribute$1(elm, key, cur, xlinkNS);
1218
+ } else if (isNull(cur) || isUndefined$1(cur)) {
1219
+ removeAttribute$1(elm, key);
988
1220
  } else {
989
- setAttribute(elm, key, cur);
1221
+ setAttribute$1(elm, key, cur);
990
1222
  }
991
1223
 
992
1224
  lockAttribute();
@@ -1031,14 +1263,13 @@
1031
1263
 
1032
1264
  var isFirstPatch = isUndefined$1(oldProps);
1033
1265
  var elm = vnode.elm,
1034
- sel = vnode.sel,
1035
- renderer = vnode.owner.renderer;
1266
+ sel = vnode.sel;
1036
1267
 
1037
1268
  for (var key in props) {
1038
1269
  var cur = props[key]; // if it is the first time this element is patched, or the current value is different to the previous value...
1039
1270
 
1040
- if (isFirstPatch || cur !== (isLiveBindingProp(sel, key) ? renderer.getProperty(elm, key) : oldProps[key])) {
1041
- renderer.setProperty(elm, key, cur);
1271
+ if (isFirstPatch || cur !== (isLiveBindingProp(sel, key) ? getProperty$1(elm, key) : oldProps[key])) {
1272
+ setProperty$1(elm, key, cur);
1042
1273
  }
1043
1274
  }
1044
1275
  }
@@ -1101,15 +1332,14 @@
1101
1332
 
1102
1333
  function updateClassAttribute(oldVnode, vnode) {
1103
1334
  var elm = vnode.elm,
1104
- newClass = vnode.data.className,
1105
- renderer = vnode.owner.renderer;
1335
+ newClass = vnode.data.className;
1106
1336
  var oldClass = oldVnode.data.className;
1107
1337
 
1108
1338
  if (oldClass === newClass) {
1109
1339
  return;
1110
1340
  }
1111
1341
 
1112
- var classList = renderer.getClassList(elm);
1342
+ var classList = getClassList$1(elm);
1113
1343
  var newClassMap = getMapFromClassName(newClass);
1114
1344
  var oldClassMap = getMapFromClassName(oldClass);
1115
1345
  var name;
@@ -1146,19 +1376,16 @@
1146
1376
 
1147
1377
  function updateStyleAttribute(oldVnode, vnode) {
1148
1378
  var elm = vnode.elm,
1149
- newStyle = vnode.data.style,
1150
- renderer = vnode.owner.renderer;
1151
- var setAttribute = renderer.setAttribute,
1152
- removeAttribute = renderer.removeAttribute;
1379
+ newStyle = vnode.data.style;
1153
1380
 
1154
1381
  if (oldVnode.data.style === newStyle) {
1155
1382
  return;
1156
1383
  }
1157
1384
 
1158
1385
  if (!isString(newStyle) || newStyle === '') {
1159
- removeAttribute(elm, 'style');
1386
+ removeAttribute$1(elm, 'style');
1160
1387
  } else {
1161
- setAttribute(elm, 'style', newStyle);
1388
+ setAttribute$1(elm, 'style', newStyle);
1162
1389
  }
1163
1390
  }
1164
1391
 
@@ -1182,14 +1409,13 @@
1182
1409
 
1183
1410
  function createClassAttribute(vnode) {
1184
1411
  var elm = vnode.elm,
1185
- classMap = vnode.data.classMap,
1186
- renderer = vnode.owner.renderer;
1412
+ classMap = vnode.data.classMap;
1187
1413
 
1188
1414
  if (isUndefined$1(classMap)) {
1189
1415
  return;
1190
1416
  }
1191
1417
 
1192
- var classList = renderer.getClassList(elm);
1418
+ var classList = getClassList$1(elm);
1193
1419
 
1194
1420
  for (var name in classMap) {
1195
1421
  classList.add(name);
@@ -1210,8 +1436,7 @@
1210
1436
 
1211
1437
  function createStyleAttribute(vnode) {
1212
1438
  var elm = vnode.elm,
1213
- styleDecls = vnode.data.styleDecls,
1214
- renderer = vnode.owner.renderer;
1439
+ styleDecls = vnode.data.styleDecls;
1215
1440
 
1216
1441
  if (isUndefined$1(styleDecls)) {
1217
1442
  return;
@@ -1223,7 +1448,7 @@
1223
1448
  value = _styleDecls$_i[1],
1224
1449
  important = _styleDecls$_i[2];
1225
1450
 
1226
- renderer.setCSSStyleProperty(elm, prop, value, important);
1451
+ setCSSStyleProperty$1(elm, prop, value, important);
1227
1452
  }
1228
1453
  }
1229
1454
 
@@ -1237,15 +1462,6 @@
1237
1462
  * For full license text, see the LICENSE file in the repo root or https://opensource.org/licenses/MIT
1238
1463
  */
1239
1464
 
1240
- /**
1241
- @license
1242
- Copyright (c) 2015 Simon Friis Vindum.
1243
- This code may only be used under the MIT License found at
1244
- https://github.com/snabbdom/snabbdom/blob/master/LICENSE
1245
- Code distributed by Snabbdom as part of the Snabbdom project at
1246
- https://github.com/snabbdom/snabbdom/
1247
- */
1248
-
1249
1465
  function isUndef(s) {
1250
1466
  return s === undefined;
1251
1467
  }
@@ -1333,7 +1549,7 @@
1333
1549
  } else if (sameVnode(oldStartVnode, newEndVnode)) {
1334
1550
  // Vnode moved right
1335
1551
  patchVnode(oldStartVnode, newEndVnode);
1336
- newEndVnode.hook.move(oldStartVnode, parentElm, oldEndVnode.owner.renderer.nextSibling(oldEndVnode.elm));
1552
+ newEndVnode.hook.move(oldStartVnode, parentElm, nextSibling$1(oldEndVnode.elm));
1337
1553
  oldStartVnode = oldCh[++oldStartIdx];
1338
1554
  newEndVnode = newCh[--newEndIdx];
1339
1555
  } else if (sameVnode(oldEndVnode, newStartVnode)) {
@@ -1446,7 +1662,7 @@
1446
1662
  }
1447
1663
  }
1448
1664
  /*
1449
- * Copyright (c) 2020, salesforce.com, inc.
1665
+ * Copyright (c) 2018, salesforce.com, inc.
1450
1666
  * All rights reserved.
1451
1667
  * SPDX-License-Identifier: MIT
1452
1668
  * For full license text, see the LICENSE file in the repo root or https://opensource.org/licenses/MIT
@@ -2217,8 +2433,7 @@
2217
2433
 
2218
2434
 
2219
2435
  var LightningElement = function LightningElement() {
2220
-
2221
-
2436
+ // This should be as performant as possible, while any initialization should be done lazily
2222
2437
  if (isNull(vmBeingConstructed)) {
2223
2438
  throw new ReferenceError('Illegal constructor');
2224
2439
  }
@@ -2226,7 +2441,6 @@
2226
2441
  var vm = vmBeingConstructed;
2227
2442
  var def = vm.def,
2228
2443
  elm = vm.elm;
2229
- vm.renderer;
2230
2444
  var bridge = def.bridge;
2231
2445
 
2232
2446
  var component = this;
@@ -2255,21 +2469,20 @@
2255
2469
  if (vm.renderMode === 1
2256
2470
  /* Shadow */
2257
2471
  ) {
2258
- attachShadow(vm);
2472
+ doAttachShadow(vm);
2259
2473
  } // Adding extra guard rails in DEV mode.
2260
2474
 
2261
2475
  return this;
2262
2476
  };
2263
2477
 
2264
- function attachShadow(vm) {
2265
- var _renderer$attachShado;
2478
+ function doAttachShadow(vm) {
2479
+ var _attachShadow$;
2266
2480
 
2267
2481
  var elm = vm.elm,
2268
2482
  mode = vm.mode,
2269
- renderer = vm.renderer,
2270
2483
  shadowMode = vm.shadowMode,
2271
2484
  ctor = vm.def.ctor;
2272
- var cmpRoot = renderer.attachShadow(elm, (_renderer$attachShado = {}, _defineProperty(_renderer$attachShado, KEY__SYNTHETIC_MODE, shadowMode === 1), _defineProperty(_renderer$attachShado, "delegatesFocus", Boolean(ctor.delegatesFocus)), _defineProperty(_renderer$attachShado, "mode", mode), _renderer$attachShado));
2485
+ var cmpRoot = attachShadow$1(elm, (_attachShadow$ = {}, _defineProperty(_attachShadow$, KEY__SYNTHETIC_MODE, shadowMode === 1), _defineProperty(_attachShadow$, "delegatesFocus", Boolean(ctor.delegatesFocus)), _defineProperty(_attachShadow$, "mode", mode), _attachShadow$));
2273
2486
  vm.cmpRoot = cmpRoot;
2274
2487
  associateVM(cmpRoot, vm);
2275
2488
  }
@@ -2279,112 +2492,98 @@
2279
2492
  constructor: LightningElement,
2280
2493
  dispatchEvent: function dispatchEvent(event) {
2281
2494
  var _getAssociatedVM = getAssociatedVM(this),
2282
- elm = _getAssociatedVM.elm,
2283
- dispatchEvent = _getAssociatedVM.renderer.dispatchEvent;
2495
+ elm = _getAssociatedVM.elm;
2284
2496
 
2285
- return dispatchEvent(elm, event);
2497
+ return dispatchEvent$1(elm, event);
2286
2498
  },
2287
2499
  addEventListener: function addEventListener(type, listener, options) {
2288
2500
  var vm = getAssociatedVM(this);
2289
- var elm = vm.elm,
2290
- addEventListener = vm.renderer.addEventListener;
2501
+ var elm = vm.elm;
2291
2502
 
2292
2503
  var wrappedListener = getWrappedComponentsListener(vm, listener);
2293
- addEventListener(elm, type, wrappedListener, options);
2504
+ addEventListener$1(elm, type, wrappedListener, options);
2294
2505
  },
2295
2506
  removeEventListener: function removeEventListener(type, listener, options) {
2296
2507
  var vm = getAssociatedVM(this);
2297
- var elm = vm.elm,
2298
- removeEventListener = vm.renderer.removeEventListener;
2508
+ var elm = vm.elm;
2299
2509
  var wrappedListener = getWrappedComponentsListener(vm, listener);
2300
- removeEventListener(elm, type, wrappedListener, options);
2510
+ removeEventListener$1(elm, type, wrappedListener, options);
2301
2511
  },
2302
2512
  hasAttribute: function hasAttribute(name) {
2303
2513
  var _getAssociatedVM2 = getAssociatedVM(this),
2304
- elm = _getAssociatedVM2.elm,
2305
- getAttribute = _getAssociatedVM2.renderer.getAttribute;
2514
+ elm = _getAssociatedVM2.elm;
2306
2515
 
2307
- return !isNull(getAttribute(elm, name));
2516
+ return !isNull(getAttribute$1(elm, name));
2308
2517
  },
2309
2518
  hasAttributeNS: function hasAttributeNS(namespace, name) {
2310
2519
  var _getAssociatedVM3 = getAssociatedVM(this),
2311
- elm = _getAssociatedVM3.elm,
2312
- getAttribute = _getAssociatedVM3.renderer.getAttribute;
2520
+ elm = _getAssociatedVM3.elm;
2313
2521
 
2314
- return !isNull(getAttribute(elm, name, namespace));
2522
+ return !isNull(getAttribute$1(elm, name, namespace));
2315
2523
  },
2316
2524
  removeAttribute: function removeAttribute(name) {
2317
2525
  var _getAssociatedVM4 = getAssociatedVM(this),
2318
- elm = _getAssociatedVM4.elm,
2319
- removeAttribute = _getAssociatedVM4.renderer.removeAttribute;
2526
+ elm = _getAssociatedVM4.elm;
2320
2527
 
2321
2528
  unlockAttribute(elm, name);
2322
- removeAttribute(elm, name);
2529
+ removeAttribute$1(elm, name);
2323
2530
  lockAttribute();
2324
2531
  },
2325
2532
  removeAttributeNS: function removeAttributeNS(namespace, name) {
2326
2533
  var _getAssociatedVM5 = getAssociatedVM(this),
2327
- elm = _getAssociatedVM5.elm,
2328
- removeAttribute = _getAssociatedVM5.renderer.removeAttribute;
2534
+ elm = _getAssociatedVM5.elm;
2329
2535
 
2330
2536
  unlockAttribute(elm, name);
2331
- removeAttribute(elm, name, namespace);
2537
+ removeAttribute$1(elm, name, namespace);
2332
2538
  lockAttribute();
2333
2539
  },
2334
2540
  getAttribute: function getAttribute(name) {
2335
2541
  var _getAssociatedVM6 = getAssociatedVM(this),
2336
- elm = _getAssociatedVM6.elm,
2337
- getAttribute = _getAssociatedVM6.renderer.getAttribute;
2542
+ elm = _getAssociatedVM6.elm;
2338
2543
 
2339
- return getAttribute(elm, name);
2544
+ return getAttribute$1(elm, name);
2340
2545
  },
2341
2546
  getAttributeNS: function getAttributeNS(namespace, name) {
2342
2547
  var _getAssociatedVM7 = getAssociatedVM(this),
2343
- elm = _getAssociatedVM7.elm,
2344
- getAttribute = _getAssociatedVM7.renderer.getAttribute;
2548
+ elm = _getAssociatedVM7.elm;
2345
2549
 
2346
- return getAttribute(elm, name, namespace);
2550
+ return getAttribute$1(elm, name, namespace);
2347
2551
  },
2348
2552
  setAttribute: function setAttribute(name, value) {
2349
2553
  var vm = getAssociatedVM(this);
2350
- var elm = vm.elm,
2351
- setAttribute = vm.renderer.setAttribute;
2554
+ var elm = vm.elm;
2352
2555
 
2353
2556
  unlockAttribute(elm, name);
2354
- setAttribute(elm, name, value);
2557
+ setAttribute$1(elm, name, value);
2355
2558
  lockAttribute();
2356
2559
  },
2357
2560
  setAttributeNS: function setAttributeNS(namespace, name, value) {
2358
2561
  var vm = getAssociatedVM(this);
2359
- var elm = vm.elm,
2360
- setAttribute = vm.renderer.setAttribute;
2562
+ var elm = vm.elm;
2361
2563
 
2362
2564
  unlockAttribute(elm, name);
2363
- setAttribute(elm, name, value, namespace);
2565
+ setAttribute$1(elm, name, value, namespace);
2364
2566
  lockAttribute();
2365
2567
  },
2366
2568
  getBoundingClientRect: function getBoundingClientRect() {
2367
2569
  var vm = getAssociatedVM(this);
2368
- var elm = vm.elm,
2369
- getBoundingClientRect = vm.renderer.getBoundingClientRect;
2570
+ var elm = vm.elm;
2370
2571
 
2371
- return getBoundingClientRect(elm);
2572
+ return getBoundingClientRect$1(elm);
2372
2573
  },
2373
2574
 
2374
2575
  get isConnected() {
2375
2576
  var _getAssociatedVM8 = getAssociatedVM(this),
2376
- elm = _getAssociatedVM8.elm,
2377
- isConnected = _getAssociatedVM8.renderer.isConnected;
2577
+ elm = _getAssociatedVM8.elm;
2378
2578
 
2379
- return isConnected(elm);
2579
+ return isConnected$1(elm);
2380
2580
  },
2381
2581
 
2382
2582
  get classList() {
2383
2583
  var vm = getAssociatedVM(this);
2384
- var elm = vm.elm,
2385
- getClassList = vm.renderer.getClassList;
2584
+ var elm = vm.elm;
2386
2585
 
2387
- return getClassList(elm);
2586
+ return getClassList$1(elm);
2388
2587
  },
2389
2588
 
2390
2589
  get template() {
@@ -2408,21 +2607,43 @@
2408
2607
  return "[object ".concat(vm.def.name, "]");
2409
2608
  }
2410
2609
  };
2411
- var queryAndChildGetterDescriptors = create(null);
2412
- var childGetters = [['children', 'getChildren'], ['childNodes', 'getChildNodes'], ['firstChild', 'getFirstChild'], ['firstElementChild', 'getFirstElementChild'], ['lastChild', 'getLastChild'], ['lastElementChild', 'getLastElementChild']]; // Generic passthrough for child getters on HTMLElement to the relevant Renderer APIs
2610
+ var queryAndChildGetterDescriptors = create(null); // The reason we don't just call `import * as renderer from '../renderer'` here is that the bundle size
2611
+ // is smaller if we reference each function individually. Otherwise Rollup will create one big frozen
2612
+ // object representing the renderer, with a lot of methods we don't actually need.
2413
2613
 
2414
- var _loop = function _loop() {
2415
- var _childGetters$_i = _slicedToArray(_childGetters[_i9], 2),
2416
- elementProp = _childGetters$_i[0],
2417
- rendererMethod = _childGetters$_i[1];
2614
+ var childGetters = ['children', 'childNodes', 'firstChild', 'firstElementChild', 'lastChild', 'lastElementChild'];
2615
+
2616
+ function getChildGetter(methodName) {
2617
+ switch (methodName) {
2618
+ case 'children':
2619
+ return getChildren$1;
2620
+
2621
+ case 'childNodes':
2622
+ return getChildNodes$1;
2623
+
2624
+ case 'firstChild':
2625
+ return getFirstChild$1;
2626
+
2627
+ case 'firstElementChild':
2628
+ return getFirstElementChild$1;
2418
2629
 
2419
- queryAndChildGetterDescriptors[elementProp] = {
2630
+ case 'lastChild':
2631
+ return getLastChild$1;
2632
+
2633
+ case 'lastElementChild':
2634
+ return getLastElementChild$1;
2635
+ }
2636
+ } // Generic passthrough for child getters on HTMLElement to the relevant Renderer APIs
2637
+
2638
+
2639
+ var _loop = function _loop() {
2640
+ var childGetter = _childGetters[_i9];
2641
+ queryAndChildGetterDescriptors[childGetter] = {
2420
2642
  get: function get() {
2421
2643
  var vm = getAssociatedVM(this);
2422
- var elm = vm.elm,
2423
- renderer = vm.renderer;
2644
+ var elm = vm.elm;
2424
2645
 
2425
- return renderer[rendererMethod](elm);
2646
+ return getChildGetter(childGetter)(elm);
2426
2647
  },
2427
2648
  configurable: true,
2428
2649
  enumerable: true
@@ -2433,17 +2654,33 @@
2433
2654
  _loop();
2434
2655
  }
2435
2656
 
2436
- var queryMethods = ['getElementsByClassName', 'getElementsByTagName', 'querySelector', 'querySelectorAll']; // Generic passthrough for query APIs on HTMLElement to the relevant Renderer APIs
2657
+ var queryMethods = ['getElementsByClassName', 'getElementsByTagName', 'querySelector', 'querySelectorAll'];
2658
+
2659
+ function getQueryMethod(methodName) {
2660
+ switch (methodName) {
2661
+ case 'getElementsByClassName':
2662
+ return getElementsByClassName$1;
2663
+
2664
+ case 'getElementsByTagName':
2665
+ return getElementsByTagName$1;
2666
+
2667
+ case 'querySelector':
2668
+ return querySelector$1;
2669
+
2670
+ case 'querySelectorAll':
2671
+ return querySelectorAll$1;
2672
+ }
2673
+ } // Generic passthrough for query APIs on HTMLElement to the relevant Renderer APIs
2674
+
2437
2675
 
2438
2676
  var _loop2 = function _loop2() {
2439
2677
  var queryMethod = _queryMethods[_i10];
2440
2678
  queryAndChildGetterDescriptors[queryMethod] = {
2441
2679
  value: function value(arg) {
2442
2680
  var vm = getAssociatedVM(this);
2443
- var elm = vm.elm,
2444
- renderer = vm.renderer;
2681
+ var elm = vm.elm;
2445
2682
 
2446
- return renderer[queryMethod](elm, arg);
2683
+ return getQueryMethod(queryMethod)(elm, arg);
2447
2684
  },
2448
2685
  configurable: true,
2449
2686
  enumerable: true,
@@ -3003,7 +3240,7 @@
3003
3240
  return _super4.apply(this, arguments);
3004
3241
  }
3005
3242
 
3006
- return HTMLBridgeElement;
3243
+ return _createClass(HTMLBridgeElement);
3007
3244
  }(SuperClass);
3008
3245
  } else {
3009
3246
  HTMLBridgeElement = function HTMLBridgeElement() {
@@ -3371,31 +3608,28 @@
3371
3608
  var token = cmpTemplate === null || cmpTemplate === void 0 ? void 0 : cmpTemplate.stylesheetToken;
3372
3609
 
3373
3610
  if (!isUndefined$1(token) && context.hasScopedStyles) {
3374
- owner.renderer.getClassList(elm).add(token);
3611
+ getClassList$1(elm).add(token);
3375
3612
  }
3376
3613
  }
3377
3614
 
3378
3615
  function updateNodeHook(oldVnode, vnode) {
3379
3616
  var elm = vnode.elm,
3380
- text = vnode.text,
3381
- renderer = vnode.owner.renderer;
3617
+ text = vnode.text;
3382
3618
 
3383
3619
  if (oldVnode.text !== text) {
3384
3620
 
3385
- renderer.setText(elm, text);
3621
+ setText$1(elm, text);
3386
3622
  }
3387
3623
  }
3388
3624
 
3389
3625
  function insertNodeHook(vnode, parentNode, referenceNode) {
3390
- var renderer = vnode.owner.renderer;
3391
3626
 
3392
- renderer.insert(vnode.elm, parentNode, referenceNode);
3627
+ insert$1(vnode.elm, parentNode, referenceNode);
3393
3628
  }
3394
3629
 
3395
3630
  function removeNodeHook(vnode, parentNode) {
3396
- var renderer = vnode.owner.renderer;
3397
3631
 
3398
- renderer.remove(vnode.elm, parentNode);
3632
+ remove$1(vnode.elm, parentNode);
3399
3633
  }
3400
3634
 
3401
3635
  function createElmHook(vnode) {
@@ -3456,12 +3690,14 @@
3456
3690
  }
3457
3691
 
3458
3692
  function updateChildrenHook(oldVnode, vnode) {
3459
- var children = vnode.children,
3460
- owner = vnode.owner;
3461
- var fn = hasDynamicChildren(children) ? updateDynamicChildren : updateStaticChildren;
3462
- runWithBoundaryProtection(owner, owner.owner, noop, function () {
3463
- fn(vnode.elm, oldVnode.children, children);
3464
- }, noop);
3693
+ var elm = vnode.elm,
3694
+ children = vnode.children;
3695
+
3696
+ if (hasDynamicChildren(children)) {
3697
+ updateDynamicChildren(elm, oldVnode.children, children);
3698
+ } else {
3699
+ updateStaticChildren(elm, oldVnode.children, children);
3700
+ }
3465
3701
  }
3466
3702
 
3467
3703
  function allocateChildrenHook(vnode, vm) {
@@ -3521,8 +3757,7 @@
3521
3757
  createVM(elm, def, {
3522
3758
  mode: mode,
3523
3759
  owner: owner,
3524
- tagName: sel,
3525
- renderer: owner.renderer
3760
+ tagName: sel
3526
3761
  });
3527
3762
  }
3528
3763
 
@@ -3614,12 +3849,12 @@
3614
3849
  */
3615
3850
 
3616
3851
 
3617
- function getUpgradableConstructor(tagName, renderer) {
3852
+ function getUpgradableConstructor(tagName) {
3618
3853
  // Should never get a tag with upper case letter at this point, the compiler should
3619
3854
  // produce only tags with lowercase letters
3620
3855
  // But, for backwards compatibility, we will lower case the tagName
3621
3856
  tagName = tagName.toLowerCase();
3622
- var CE = renderer.getCustomElement(tagName);
3857
+ var CE = getCustomElement$1(tagName);
3623
3858
 
3624
3859
  if (!isUndefined$1(CE)) {
3625
3860
  return CE;
@@ -3630,8 +3865,8 @@
3630
3865
  */
3631
3866
 
3632
3867
 
3633
- CE = /*#__PURE__*/function (_renderer$HTMLElement) {
3634
- _inherits(LWCUpgradableElement, _renderer$HTMLElement);
3868
+ CE = /*#__PURE__*/function (_HTMLElementExported$) {
3869
+ _inherits(LWCUpgradableElement, _HTMLElementExported$);
3635
3870
 
3636
3871
  var _super5 = _createSuper(LWCUpgradableElement);
3637
3872
 
@@ -3649,10 +3884,10 @@
3649
3884
  return _this4;
3650
3885
  }
3651
3886
 
3652
- return LWCUpgradableElement;
3653
- }(renderer.HTMLElement);
3887
+ return _createClass(LWCUpgradableElement);
3888
+ }(HTMLElementExported$1);
3654
3889
 
3655
- renderer.defineCustomElement(tagName, CE);
3890
+ defineCustomElement$1(tagName, CE);
3656
3891
  return CE;
3657
3892
  }
3658
3893
  /*
@@ -3668,8 +3903,7 @@
3668
3903
  var TextHook = {
3669
3904
  create: function create(vnode) {
3670
3905
  var owner = vnode.owner;
3671
- var renderer = owner.renderer;
3672
- var elm = renderer.createText(vnode.text);
3906
+ var elm = createText$1(vnode.text);
3673
3907
  linkNodeToShadow(elm, owner);
3674
3908
  vnode.elm = elm;
3675
3909
  },
@@ -3689,8 +3923,7 @@
3689
3923
  create: function create(vnode) {
3690
3924
  var owner = vnode.owner,
3691
3925
  text = vnode.text;
3692
- var renderer = owner.renderer;
3693
- var elm = renderer.createComment(text);
3926
+ var elm = createComment$1(text);
3694
3927
  linkNodeToShadow(elm, owner);
3695
3928
  vnode.elm = elm;
3696
3929
  },
@@ -3716,9 +3949,8 @@
3716
3949
  var sel = vnode.sel,
3717
3950
  owner = vnode.owner,
3718
3951
  svg = vnode.data.svg;
3719
- var renderer = owner.renderer;
3720
3952
  var namespace = isTrue(svg) ? SVG_NAMESPACE : undefined;
3721
- var elm = renderer.createElement(sel, namespace);
3953
+ var elm = createElement$2(sel, namespace);
3722
3954
  linkNodeToShadow(elm, owner);
3723
3955
  fallbackElmHook(elm, vnode);
3724
3956
  vnode.elm = elm;
@@ -3772,8 +4004,7 @@
3772
4004
  create: function create(vnode) {
3773
4005
  var sel = vnode.sel,
3774
4006
  owner = vnode.owner;
3775
- var renderer = owner.renderer;
3776
- var UpgradableConstructor = getUpgradableConstructor(sel, renderer);
4007
+ var UpgradableConstructor = getUpgradableConstructor(sel);
3777
4008
  /**
3778
4009
  * Note: if the upgradable constructor does not expect, or throw when we new it
3779
4010
  * with a callback as the first argument, we could implement a more advanced
@@ -3856,8 +4087,7 @@
3856
4087
  createVM(elm, def, {
3857
4088
  mode: mode,
3858
4089
  owner: owner,
3859
- tagName: sel,
3860
- renderer: owner.renderer
4090
+ tagName: sel
3861
4091
  });
3862
4092
  vnode.elm = elm;
3863
4093
  var vm = getAssociatedVM(elm);
@@ -3879,11 +4109,10 @@
3879
4109
  };
3880
4110
 
3881
4111
  function linkNodeToShadow(elm, owner) {
3882
- var renderer = owner.renderer,
3883
- renderMode = owner.renderMode,
4112
+ var renderMode = owner.renderMode,
3884
4113
  shadowMode = owner.shadowMode; // TODO [#1164]: this should eventually be done by the polyfill directly
3885
4114
 
3886
- if (renderer.isSyntheticShadowDefined) {
4115
+ if (isSyntheticShadowDefined$1) {
3887
4116
  if (shadowMode === 1
3888
4117
  /* Synthetic */
3889
4118
  || renderMode === 0
@@ -4282,7 +4511,6 @@
4282
4511
  function updateStylesheetToken(vm, template) {
4283
4512
  var elm = vm.elm,
4284
4513
  context = vm.context,
4285
- renderer = vm.renderer,
4286
4514
  renderMode = vm.renderMode,
4287
4515
  shadowMode = vm.shadowMode;
4288
4516
  var newStylesheets = template.stylesheets,
@@ -4302,11 +4530,11 @@
4302
4530
  oldHasTokenInAttribute = context.hasTokenInAttribute;
4303
4531
 
4304
4532
  if (oldHasTokenInClass) {
4305
- renderer.getClassList(elm).remove(makeHostToken(oldToken));
4533
+ getClassList$1(elm).remove(makeHostToken(oldToken));
4306
4534
  }
4307
4535
 
4308
4536
  if (oldHasTokenInAttribute) {
4309
- renderer.removeAttribute(elm, makeHostToken(oldToken));
4537
+ removeAttribute$1(elm, makeHostToken(oldToken));
4310
4538
  } // Apply the new template styling token to the host element, if the new template has any
4311
4539
  // associated stylesheets. In the case of light DOM, also ensure there is at least one scoped stylesheet.
4312
4540
 
@@ -4318,12 +4546,12 @@
4318
4546
 
4319
4547
  if (!isUndefined$1(newToken)) {
4320
4548
  if (hasScopedStyles) {
4321
- renderer.getClassList(elm).add(makeHostToken(newToken));
4549
+ getClassList$1(elm).add(makeHostToken(newToken));
4322
4550
  newHasTokenInClass = true;
4323
4551
  }
4324
4552
 
4325
4553
  if (isSyntheticShadow) {
4326
- renderer.setAttribute(elm, makeHostToken(newToken), '');
4554
+ setAttribute$1(elm, makeHostToken(newToken), '');
4327
4555
  newHasTokenInAttribute = true;
4328
4556
  }
4329
4557
  } // Update the styling tokens present on the context object.
@@ -4435,8 +4663,7 @@
4435
4663
  }
4436
4664
 
4437
4665
  function createStylesheet(vm, stylesheets) {
4438
- var renderer = vm.renderer,
4439
- renderMode = vm.renderMode,
4666
+ var renderMode = vm.renderMode,
4440
4667
  shadowMode = vm.shadowMode;
4441
4668
 
4442
4669
  if (renderMode === 1
@@ -4445,9 +4672,9 @@
4445
4672
  /* Synthetic */
4446
4673
  ) {
4447
4674
  for (var _i17 = 0; _i17 < stylesheets.length; _i17++) {
4448
- renderer.insertGlobalStylesheet(stylesheets[_i17]);
4675
+ insertGlobalStylesheet$1(stylesheets[_i17]);
4449
4676
  }
4450
- } else if (renderer.ssr || renderer.isHydrating()) {
4677
+ } else if (ssr$1 || isHydrating$1()) {
4451
4678
  // Note: We need to ensure that during hydration, the stylesheets method is the same as those in ssr.
4452
4679
  // This works in the client, because the stylesheets are created, and cached in the VM
4453
4680
  // the first time the VM renders.
@@ -4461,10 +4688,10 @@
4461
4688
 
4462
4689
  for (var _i18 = 0; _i18 < stylesheets.length; _i18++) {
4463
4690
  if (isGlobal) {
4464
- renderer.insertGlobalStylesheet(stylesheets[_i18]);
4691
+ insertGlobalStylesheet$1(stylesheets[_i18]);
4465
4692
  } else {
4466
4693
  // local level
4467
- renderer.insertStylesheet(stylesheets[_i18], root.cmpRoot);
4694
+ insertStylesheet$1(stylesheets[_i18], root.cmpRoot);
4468
4695
  }
4469
4696
  }
4470
4697
  }
@@ -4501,7 +4728,7 @@
4501
4728
  if (isProfilerEnabled) {
4502
4729
  currentDispatcher(opId, 0
4503
4730
  /* Start */
4504
- , vm.tagName, vm.idx);
4731
+ , vm.tagName, vm.idx, vm.renderMode, vm.shadowMode);
4505
4732
  }
4506
4733
  }
4507
4734
 
@@ -4510,7 +4737,7 @@
4510
4737
  if (isProfilerEnabled) {
4511
4738
  currentDispatcher(opId, 1
4512
4739
  /* Stop */
4513
- , vm.tagName, vm.idx);
4740
+ , vm.tagName, vm.idx, vm.renderMode, vm.shadowMode);
4514
4741
  }
4515
4742
  }
4516
4743
 
@@ -4519,7 +4746,7 @@
4519
4746
  if (isProfilerEnabled) {
4520
4747
  currentDispatcher(opId, 0
4521
4748
  /* Start */
4522
- , vm === null || vm === void 0 ? void 0 : vm.tagName, vm === null || vm === void 0 ? void 0 : vm.idx);
4749
+ , vm === null || vm === void 0 ? void 0 : vm.tagName, vm === null || vm === void 0 ? void 0 : vm.idx, vm === null || vm === void 0 ? void 0 : vm.renderMode, vm === null || vm === void 0 ? void 0 : vm.shadowMode);
4523
4750
  }
4524
4751
  }
4525
4752
 
@@ -4528,7 +4755,7 @@
4528
4755
  if (isProfilerEnabled) {
4529
4756
  currentDispatcher(opId, 1
4530
4757
  /* Stop */
4531
- , vm === null || vm === void 0 ? void 0 : vm.tagName, vm === null || vm === void 0 ? void 0 : vm.idx);
4758
+ , vm === null || vm === void 0 ? void 0 : vm.tagName, vm === null || vm === void 0 ? void 0 : vm.idx, vm === null || vm === void 0 ? void 0 : vm.renderMode, vm === null || vm === void 0 ? void 0 : vm.shadowMode);
4532
4759
  }
4533
4760
  }
4534
4761
  /*
@@ -4991,7 +5218,6 @@
4991
5218
  function createVM(elm, def, options) {
4992
5219
  var mode = options.mode,
4993
5220
  owner = options.owner,
4994
- renderer = options.renderer,
4995
5221
  tagName = options.tagName;
4996
5222
  var vm = {
4997
5223
  elm: elm,
@@ -5005,7 +5231,6 @@
5005
5231
  tagName: tagName,
5006
5232
  mode: mode,
5007
5233
  owner: owner,
5008
- renderer: renderer,
5009
5234
  children: EmptyArray,
5010
5235
  aChildren: EmptyArray,
5011
5236
  velements: EmptyArray,
@@ -5047,13 +5272,10 @@
5047
5272
  }
5048
5273
 
5049
5274
  function computeShadowMode(vm) {
5050
- var def = vm.def,
5051
- renderer = vm.renderer;
5052
- var isNativeShadowDefined = renderer.isNativeShadowDefined,
5053
- isSyntheticShadowDefined = renderer.isSyntheticShadowDefined;
5275
+ var def = vm.def;
5054
5276
  var shadowMode;
5055
5277
 
5056
- if (isSyntheticShadowDefined) {
5278
+ if (isSyntheticShadowDefined$1) {
5057
5279
  if (def.renderMode === 0
5058
5280
  /* Light */
5059
5281
  ) {
@@ -5062,7 +5284,7 @@
5062
5284
  shadowMode = 0
5063
5285
  /* Native */
5064
5286
  ;
5065
- } else if (isNativeShadowDefined) {
5287
+ } else if (isNativeShadowDefined$1) {
5066
5288
  if (def.shadowSupportMode === "any"
5067
5289
  /* Any */
5068
5290
  ) {
@@ -5183,10 +5405,9 @@
5183
5405
  }
5184
5406
 
5185
5407
  function runRenderedCallback(vm) {
5186
- var renderer = vm.renderer,
5187
- renderedCallback = vm.def.renderedCallback;
5408
+ var renderedCallback = vm.def.renderedCallback;
5188
5409
 
5189
- if (isTrue(renderer.ssr)) {
5410
+ if (isTrue(ssr$1)) {
5190
5411
  return;
5191
5412
  }
5192
5413
 
@@ -5386,15 +5607,14 @@
5386
5607
 
5387
5608
 
5388
5609
  function resetComponentRoot(vm) {
5389
- var children = vm.children,
5390
- renderer = vm.renderer;
5610
+ var children = vm.children;
5391
5611
  var rootNode = getRenderRoot(vm);
5392
5612
 
5393
5613
  for (var _i25 = 0, _len9 = children.length; _i25 < _len9; _i25++) {
5394
5614
  var child = children[_i25];
5395
5615
 
5396
5616
  if (!isNull(child) && !isUndefined$1(child.elm)) {
5397
- renderer.remove(child.elm, rootNode);
5617
+ remove$1(child.elm, rootNode);
5398
5618
  }
5399
5619
  }
5400
5620
 
@@ -5404,7 +5624,7 @@
5404
5624
  }
5405
5625
 
5406
5626
  function scheduleRehydration(vm) {
5407
- if (isTrue(vm.renderer.ssr) || isTrue(vm.isScheduled)) {
5627
+ if (isTrue(ssr$1) || isTrue(vm.isScheduled)) {
5408
5628
  return;
5409
5629
  }
5410
5630
 
@@ -5567,7 +5787,7 @@
5567
5787
  return _this5;
5568
5788
  }
5569
5789
 
5570
- return WireContextRegistrationEvent;
5790
+ return _createClass(WireContextRegistrationEvent);
5571
5791
  }( /*#__PURE__*/_wrapNativeSuper(CustomEvent));
5572
5792
 
5573
5793
  function createFieldDataCallback(vm, name) {
@@ -5634,7 +5854,6 @@
5634
5854
  }
5635
5855
 
5636
5856
  var elm = vm.elm,
5637
- renderer = vm.renderer,
5638
5857
  _vm$context = vm.context,
5639
5858
  wiredConnecting = _vm$context.wiredConnecting,
5640
5859
  wiredDisconnecting = _vm$context.wiredDisconnecting; // waiting for the component to be connected to formally request the context via the token
@@ -5657,7 +5876,7 @@
5657
5876
  ArrayPush$1.call(wiredDisconnecting, disconnectCallback);
5658
5877
  }
5659
5878
  });
5660
- renderer.dispatchEvent(elm, contextRegistrationEvent);
5879
+ dispatchEvent$1(elm, contextRegistrationEvent);
5661
5880
  });
5662
5881
  }
5663
5882
 
@@ -5901,7 +6120,7 @@
5901
6120
  hooksAreSet = true;
5902
6121
  setSanitizeHtmlContentHook(hooks.sanitizeHtmlContent);
5903
6122
  }
5904
- /* version: 2.6.1 */
6123
+ /* version: 2.7.2 */
5905
6124
 
5906
6125
  /*
5907
6126
  * Copyright (c) 2018, salesforce.com, inc.
@@ -5921,7 +6140,9 @@
5921
6140
  var styleElements = create(null);
5922
6141
  var styleSheets = create(null);
5923
6142
  var nodesToStyleSheets = new WeakMap();
5924
- var getCustomElement, defineCustomElement, HTMLElementConstructor;
6143
+ var getCustomElement;
6144
+ var defineCustomElement;
6145
+ var HTMLElementConstructor;
5925
6146
 
5926
6147
  function isCustomElementRegistryAvailable() {
5927
6148
  if (typeof customElements === 'undefined') {
@@ -5948,7 +6169,7 @@
5948
6169
  return _super7.apply(this, arguments);
5949
6170
  }
5950
6171
 
5951
- return clazz;
6172
+ return _createClass(clazz);
5952
6173
  }(HTMLElementAlias);
5953
6174
 
5954
6175
  customElements.define('lwc-test-' + Math.floor(Math.random() * 1000000), clazz);
@@ -6046,146 +6267,213 @@
6046
6267
  HTMLElementConstructor.prototype = HTMLElement.prototype;
6047
6268
  }
6048
6269
 
6049
- var _isHydrating = false;
6270
+ var hydrating = false;
6050
6271
 
6051
- function setIsHydrating(v) {
6052
- _isHydrating = v;
6272
+ function setIsHydrating(value) {
6273
+ hydrating = value;
6053
6274
  }
6054
6275
 
6055
- var renderer = {
6056
- ssr: false,
6057
- isHydrating: function isHydrating() {
6058
- return _isHydrating;
6059
- },
6060
- isNativeShadowDefined: _globalThis[KEY__IS_NATIVE_SHADOW_ROOT_DEFINED],
6061
- isSyntheticShadowDefined: hasOwnProperty$1.call(Element.prototype, KEY__SHADOW_TOKEN),
6062
- createElement: function createElement(tagName, namespace) {
6063
- return isUndefined$1(namespace) ? document.createElement(tagName) : document.createElementNS(namespace, tagName);
6064
- },
6065
- createText: function createText(content) {
6066
- return document.createTextNode(content);
6067
- },
6068
- createComment: function createComment(content) {
6069
- return document.createComment(content);
6070
- },
6071
- insert: function insert(node, parent, anchor) {
6072
- parent.insertBefore(node, anchor);
6073
- },
6074
- remove: function remove(node, parent) {
6075
- parent.removeChild(node);
6076
- },
6077
- nextSibling: function nextSibling(node) {
6078
- return node.nextSibling;
6079
- },
6080
- attachShadow: function attachShadow(element, options) {
6081
- if (_isHydrating) {
6082
- return element.shadowRoot;
6083
- }
6276
+ var ssr = false;
6084
6277
 
6085
- return element.attachShadow(options);
6086
- },
6087
- setText: function setText(node, content) {
6088
- node.nodeValue = content;
6089
- },
6090
- getProperty: function getProperty(node, key) {
6091
- return node[key];
6092
- },
6093
- setProperty: function setProperty(node, key, value) {
6278
+ function isHydrating() {
6279
+ return hydrating;
6280
+ }
6094
6281
 
6095
- node[key] = value;
6096
- },
6097
- getAttribute: function getAttribute(element, name, namespace) {
6098
- return isUndefined$1(namespace) ? element.getAttribute(name) : element.getAttributeNS(namespace, name);
6099
- },
6100
- setAttribute: function setAttribute(element, name, value, namespace) {
6101
- return isUndefined$1(namespace) ? element.setAttribute(name, value) : element.setAttributeNS(namespace, name, value);
6102
- },
6103
- removeAttribute: function removeAttribute(element, name, namespace) {
6104
- if (isUndefined$1(namespace)) {
6105
- element.removeAttribute(name);
6106
- } else {
6107
- element.removeAttributeNS(namespace, name);
6108
- }
6109
- },
6110
- addEventListener: function addEventListener(target, type, callback, options) {
6111
- target.addEventListener(type, callback, options);
6112
- },
6113
- removeEventListener: function removeEventListener(target, type, callback, options) {
6114
- target.removeEventListener(type, callback, options);
6115
- },
6116
- dispatchEvent: function dispatchEvent(target, event) {
6117
- return target.dispatchEvent(event);
6118
- },
6119
- getClassList: function getClassList(element) {
6120
- return element.classList;
6121
- },
6122
- setCSSStyleProperty: function setCSSStyleProperty(element, name, value, important) {
6123
- // TODO [#0]: How to avoid this type casting? Shall we use a different type interface to
6124
- // represent elements in the engine?
6125
- element.style.setProperty(name, value, important ? 'important' : '');
6126
- },
6127
- getBoundingClientRect: function getBoundingClientRect(element) {
6128
- return element.getBoundingClientRect();
6129
- },
6130
- querySelector: function querySelector(element, selectors) {
6131
- return element.querySelector(selectors);
6132
- },
6133
- querySelectorAll: function querySelectorAll(element, selectors) {
6134
- return element.querySelectorAll(selectors);
6135
- },
6136
- getElementsByTagName: function getElementsByTagName(element, tagNameOrWildCard) {
6137
- return element.getElementsByTagName(tagNameOrWildCard);
6138
- },
6139
- getElementsByClassName: function getElementsByClassName(element, names) {
6140
- return element.getElementsByClassName(names);
6141
- },
6142
- getChildren: function getChildren(element) {
6143
- return element.children;
6144
- },
6145
- getChildNodes: function getChildNodes(element) {
6146
- return element.childNodes;
6147
- },
6148
- getFirstChild: function getFirstChild(element) {
6149
- return element.firstChild;
6150
- },
6151
- getFirstElementChild: function getFirstElementChild(element) {
6152
- return element.firstElementChild;
6153
- },
6154
- getLastChild: function getLastChild(element) {
6155
- return element.lastChild;
6156
- },
6157
- getLastElementChild: function getLastElementChild(element) {
6158
- return element.lastElementChild;
6159
- },
6160
- isConnected: function isConnected(node) {
6161
- return node.isConnected;
6162
- },
6163
- insertGlobalStylesheet: function insertGlobalStylesheet(content) {
6164
- if (!isUndefined$1(globalStylesheets[content])) {
6165
- return;
6166
- }
6282
+ var isNativeShadowDefined = _globalThis[KEY__IS_NATIVE_SHADOW_ROOT_DEFINED];
6283
+ var isSyntheticShadowDefined = hasOwnProperty$1.call(Element.prototype, KEY__SHADOW_TOKEN);
6167
6284
 
6168
- globalStylesheets[content] = true;
6169
- var elm = document.createElement('style');
6170
- elm.type = 'text/css';
6171
- elm.textContent = content;
6172
- globalStylesheetsParentElement.appendChild(elm);
6173
- },
6174
- insertStylesheet: function insertStylesheet(content, target) {
6175
- if (supportsConstructableStyleSheets) {
6176
- insertConstructableStyleSheet(content, target);
6177
- } else {
6178
- // Fall back to <style> element
6179
- insertStyleElement(content, target);
6180
- }
6181
- },
6182
- assertInstanceOfHTMLElement: function assertInstanceOfHTMLElement(elm, msg) {
6183
- assert.invariant(elm instanceof HTMLElement, msg);
6184
- },
6185
- defineCustomElement: defineCustomElement,
6186
- getCustomElement: getCustomElement,
6187
- HTMLElement: HTMLElementConstructor
6188
- };
6285
+ function createElement$1(tagName, namespace) {
6286
+ return isUndefined$1(namespace) ? document.createElement(tagName) : document.createElementNS(namespace, tagName);
6287
+ }
6288
+
6289
+ function createText(content) {
6290
+ return document.createTextNode(content);
6291
+ }
6292
+
6293
+ function createComment(content) {
6294
+ return document.createComment(content);
6295
+ }
6296
+
6297
+ function insert(node, parent, anchor) {
6298
+ parent.insertBefore(node, anchor);
6299
+ }
6300
+
6301
+ function remove(node, parent) {
6302
+ parent.removeChild(node);
6303
+ }
6304
+
6305
+ function nextSibling(node) {
6306
+ return node.nextSibling;
6307
+ }
6308
+
6309
+ function attachShadow(element, options) {
6310
+ if (hydrating) {
6311
+ return element.shadowRoot;
6312
+ }
6313
+
6314
+ return element.attachShadow(options);
6315
+ }
6316
+
6317
+ function setText(node, content) {
6318
+ node.nodeValue = content;
6319
+ }
6320
+
6321
+ function getProperty(node, key) {
6322
+ return node[key];
6323
+ }
6324
+
6325
+ function setProperty(node, key, value) {
6326
+
6327
+ node[key] = value;
6328
+ }
6329
+
6330
+ function getAttribute(element, name, namespace) {
6331
+ return isUndefined$1(namespace) ? element.getAttribute(name) : element.getAttributeNS(namespace, name);
6332
+ }
6333
+
6334
+ function setAttribute(element, name, value, namespace) {
6335
+ return isUndefined$1(namespace) ? element.setAttribute(name, value) : element.setAttributeNS(namespace, name, value);
6336
+ }
6337
+
6338
+ function removeAttribute(element, name, namespace) {
6339
+ if (isUndefined$1(namespace)) {
6340
+ element.removeAttribute(name);
6341
+ } else {
6342
+ element.removeAttributeNS(namespace, name);
6343
+ }
6344
+ }
6345
+
6346
+ function addEventListener(target, type, callback, options) {
6347
+ target.addEventListener(type, callback, options);
6348
+ }
6349
+
6350
+ function removeEventListener(target, type, callback, options) {
6351
+ target.removeEventListener(type, callback, options);
6352
+ }
6353
+
6354
+ function dispatchEvent(target, event) {
6355
+ return target.dispatchEvent(event);
6356
+ }
6357
+
6358
+ function getClassList(element) {
6359
+ return element.classList;
6360
+ }
6361
+
6362
+ function setCSSStyleProperty(element, name, value, important) {
6363
+ // TODO [#0]: How to avoid this type casting? Shall we use a different type interface to
6364
+ // represent elements in the engine?
6365
+ element.style.setProperty(name, value, important ? 'important' : '');
6366
+ }
6367
+
6368
+ function getBoundingClientRect(element) {
6369
+ return element.getBoundingClientRect();
6370
+ }
6371
+
6372
+ function querySelector(element, selectors) {
6373
+ return element.querySelector(selectors);
6374
+ }
6375
+
6376
+ function querySelectorAll(element, selectors) {
6377
+ return element.querySelectorAll(selectors);
6378
+ }
6379
+
6380
+ function getElementsByTagName(element, tagNameOrWildCard) {
6381
+ return element.getElementsByTagName(tagNameOrWildCard);
6382
+ }
6383
+
6384
+ function getElementsByClassName(element, names) {
6385
+ return element.getElementsByClassName(names);
6386
+ }
6387
+
6388
+ function getChildren(element) {
6389
+ return element.children;
6390
+ }
6391
+
6392
+ function getChildNodes(element) {
6393
+ return element.childNodes;
6394
+ }
6395
+
6396
+ function getFirstChild(element) {
6397
+ return element.firstChild;
6398
+ }
6399
+
6400
+ function getFirstElementChild(element) {
6401
+ return element.firstElementChild;
6402
+ }
6403
+
6404
+ function getLastChild(element) {
6405
+ return element.lastChild;
6406
+ }
6407
+
6408
+ function getLastElementChild(element) {
6409
+ return element.lastElementChild;
6410
+ }
6411
+
6412
+ function isConnected(node) {
6413
+ return node.isConnected;
6414
+ }
6415
+
6416
+ function insertGlobalStylesheet(content) {
6417
+ if (!isUndefined$1(globalStylesheets[content])) {
6418
+ return;
6419
+ }
6420
+
6421
+ globalStylesheets[content] = true;
6422
+ var elm = document.createElement('style');
6423
+ elm.type = 'text/css';
6424
+ elm.textContent = content;
6425
+ globalStylesheetsParentElement.appendChild(elm);
6426
+ }
6427
+
6428
+ function insertStylesheet(content, target) {
6429
+ if (supportsConstructableStyleSheets) {
6430
+ insertConstructableStyleSheet(content, target);
6431
+ } else {
6432
+ // Fall back to <style> element
6433
+ insertStyleElement(content, target);
6434
+ }
6435
+ }
6436
+
6437
+ var HTMLElementExported = HTMLElementConstructor;
6438
+ setAttachShadow(attachShadow);
6439
+ setCreateComment(createComment);
6440
+ setCreateElement(createElement$1);
6441
+ setCreateText(createText);
6442
+ setDefineCustomElement(defineCustomElement);
6443
+ setDispatchEvent(dispatchEvent);
6444
+ setGetAttribute(getAttribute);
6445
+ setGetBoundingClientRect(getBoundingClientRect);
6446
+ setGetChildNodes(getChildNodes);
6447
+ setGetChildren(getChildren);
6448
+ setGetClassList(getClassList);
6449
+ setGetCustomElement(getCustomElement);
6450
+ setGetElementsByClassName(getElementsByClassName);
6451
+ setGetElementsByTagName(getElementsByTagName);
6452
+ setGetFirstChild(getFirstChild);
6453
+ setGetFirstElementChild(getFirstElementChild);
6454
+ setGetLastChild(getLastChild);
6455
+ setGetLastElementChild(getLastElementChild);
6456
+ setGetProperty(getProperty);
6457
+ setHTMLElement(HTMLElementExported);
6458
+ setInsert(insert);
6459
+ setInsertGlobalStylesheet(insertGlobalStylesheet);
6460
+ setInsertStylesheet(insertStylesheet);
6461
+ setIsConnected(isConnected);
6462
+ setIsHydrating$1(isHydrating);
6463
+ setIsNativeShadowDefined(isNativeShadowDefined);
6464
+ setIsSyntheticShadowDefined(isSyntheticShadowDefined);
6465
+ setNextSibling(nextSibling);
6466
+ setQuerySelector(querySelector);
6467
+ setQuerySelectorAll(querySelectorAll);
6468
+ setRemove(remove);
6469
+ setRemoveAttribute(removeAttribute);
6470
+ setRemoveEventListener(removeEventListener);
6471
+ setSetAttribute(setAttribute);
6472
+ setSetCSSStyleProperty(setCSSStyleProperty);
6473
+ setSetProperty(setProperty);
6474
+ setSetText(setText);
6475
+ setSsr(ssr);
6476
+ setAddEventListener(addEventListener);
6189
6477
  /*
6190
6478
  * Copyright (c) 2018, salesforce.com, inc.
6191
6479
  * All rights reserved.
@@ -6264,7 +6552,7 @@
6264
6552
  throw new TypeError("\"createElement\" function expects an \"is\" option with a valid component constructor.");
6265
6553
  }
6266
6554
 
6267
- var UpgradableConstructor = getUpgradableConstructor(sel, renderer);
6555
+ var UpgradableConstructor = getUpgradableConstructor(sel);
6268
6556
  var wasComponentUpgraded = false; // the custom element from the registry is expecting an upgrade callback
6269
6557
 
6270
6558
  /**
@@ -6279,8 +6567,7 @@
6279
6567
  createVM(elm, def, {
6280
6568
  tagName: sel,
6281
6569
  mode: options.mode !== 'closed' ? 'open' : 'closed',
6282
- owner: null,
6283
- renderer: renderer
6570
+ owner: null
6284
6571
  });
6285
6572
  ConnectingSlot.set(elm, connectRootElement);
6286
6573
  DisconnectingSlot.set(elm, disconnectRootElement);
@@ -6305,6 +6592,10 @@
6305
6592
  function hydrateComponent(element, Ctor) {
6306
6593
  var props = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
6307
6594
 
6595
+ if (!(element instanceof Element)) {
6596
+ throw new TypeError("\"hydrateComponent\" expects a valid DOM element as the first parameter but instead received ".concat(element, "."));
6597
+ }
6598
+
6308
6599
  if (!isFunction$1(Ctor)) {
6309
6600
  throw new TypeError("\"hydrateComponent\" expects a valid component constructor as the second parameter but instead received ".concat(Ctor, "."));
6310
6601
  }
@@ -6322,7 +6613,6 @@
6322
6613
  createVM(element, def, {
6323
6614
  mode: 'open',
6324
6615
  owner: null,
6325
- renderer: renderer,
6326
6616
  tagName: element.tagName.toLowerCase()
6327
6617
  });
6328
6618
 
@@ -6405,8 +6695,7 @@
6405
6695
  createVM(_assertThisInitialized(_this6), def, {
6406
6696
  mode: 'open',
6407
6697
  owner: null,
6408
- tagName: _this6.tagName,
6409
- renderer: renderer
6698
+ tagName: _this6.tagName
6410
6699
  });
6411
6700
  return _this6;
6412
6701
  }
@@ -6479,7 +6768,7 @@
6479
6768
  return false;
6480
6769
  }
6481
6770
 
6482
- if (renderer.isSyntheticShadowDefined) {
6771
+ if (isSyntheticShadowDefined) {
6483
6772
  // TODO [#1252]: old behavior that is still used by some pieces of the platform,
6484
6773
  // specifically, nodes inserted manually on places where `lwc:dom="manual"` directive is not
6485
6774
  // used, will be considered global elements.
@@ -6531,7 +6820,7 @@
6531
6820
  });
6532
6821
  freeze(LightningElement);
6533
6822
  seal(LightningElement.prototype);
6534
- /* version: 2.6.1 */
6823
+ /* version: 2.7.2 */
6535
6824
 
6536
6825
  exports.LightningElement = LightningElement;
6537
6826
  exports.__unstable__ProfilerControl = profilerControl;