crmbonus-component-wake 2.0.75 → 2.0.77

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 (159) hide show
  1. package/dist/cjs/app-modal.cjs.entry.js +2 -2
  2. package/dist/cjs/countdown-timer_4.cjs.entry.js +6 -6
  3. package/dist/cjs/crm-bonus-form.cjs.entry.js +2 -2
  4. package/dist/cjs/crm-bonus-note.cjs.entry.js +4 -4
  5. package/dist/cjs/crm-bonus.cjs.entry.js +19 -2
  6. package/dist/cjs/crm-bonus.cjs.entry.js.map +1 -1
  7. package/dist/cjs/crm-button.cjs.entry.js +1 -1
  8. package/dist/cjs/{crm-giftback-form.cjs.entry.js → crm-giftback-form_2.cjs.entry.js} +22 -7
  9. package/dist/cjs/crm-giftback-form_2.cjs.entry.js.map +1 -0
  10. package/dist/cjs/crmbonus-component-wake.cjs.js +2 -2
  11. package/dist/cjs/giftback-finish_4.cjs.entry.js +5 -5
  12. package/dist/cjs/{index-e3122e18.js → index-8243a0e3.js} +286 -5
  13. package/dist/{esm/index-c477a8b3.js.map → cjs/index-8243a0e3.js.map} +1 -1
  14. package/dist/cjs/loader.cjs.js +2 -2
  15. package/dist/cjs/loading-spinner.cjs.entry.js +2 -2
  16. package/dist/cjs/pedido-finalizado.cjs.entry.js +2 -2
  17. package/dist/cjs/phone-cancel-input.cjs.entry.js +2 -2
  18. package/dist/cjs/phone-input-mask.cjs.entry.js +2 -2
  19. package/dist/cjs/phone-input.cjs.entry.js +2 -2
  20. package/dist/collection/collection-manifest.json +1 -0
  21. package/dist/collection/components/crm-bonus/crm-bonus.js +45 -2
  22. package/dist/collection/components/crm-bonus/crm-bonus.js.map +1 -1
  23. package/dist/collection/components/crm-bonus-form/crm-bonus-form.js +1 -1
  24. package/dist/collection/components/crm-bonus-form/subcomponents/giftback-finish/giftback-finish.js +1 -1
  25. package/dist/collection/components/crm-bonus-form/subcomponents/giftback-pin/giftback-pin.js +1 -1
  26. package/dist/collection/components/crm-bonus-form/subcomponents/giftback-progress/giftback-progress.js +1 -1
  27. package/dist/collection/components/crm-bonus-form/subcomponents/name-input/name-input.js +1 -1
  28. package/dist/collection/components/crm-bonus-form/subcomponents/phone/phone.input.js +1 -1
  29. package/dist/collection/components/crm-bonus-form/subcomponents/phone-cancel/phone.cancel.input.js +1 -1
  30. package/dist/collection/components/giftback-form/giftback-form.js +5 -5
  31. package/dist/collection/components/giftback-form/giftback-form.js.map +1 -1
  32. package/dist/collection/components/giftback-form/subcomponents/giftback-info/giftback-info.js +3 -3
  33. package/dist/collection/components/giftback-form/subcomponents/phone-form/phone-form.js +1 -1
  34. package/dist/collection/components/giftback-form/subcomponents/pin-form/pin-form.js +1 -1
  35. package/dist/collection/components/loading-container/loading-container.css +47 -0
  36. package/dist/collection/components/loading-container/loading-container.js +43 -0
  37. package/dist/collection/components/loading-container/loading-container.js.map +1 -0
  38. package/dist/collection/components/loading-spinner/loading-spinner.js +1 -1
  39. package/dist/collection/components/modal/app-modal.js +1 -1
  40. package/dist/collection/components/note/crm-bonus-note.js +3 -3
  41. package/dist/collection/components/pedido/pedido.js +1 -1
  42. package/dist/collection/components/phone/phone-input-mask.js +1 -1
  43. package/dist/components/app-modal.js +2 -2
  44. package/dist/components/countdown-timer.js +1 -1
  45. package/dist/components/crm-bonus-form.js +7 -7
  46. package/dist/components/crm-bonus-note.js +4 -4
  47. package/dist/components/crm-bonus.js +40 -15
  48. package/dist/components/crm-bonus.js.map +1 -1
  49. package/dist/components/crm-button.js +1 -1
  50. package/dist/components/crm-giftback-form.js +1 -1
  51. package/dist/components/giftback-finish.js +1 -1
  52. package/dist/components/giftback-info.js +1 -1
  53. package/dist/components/giftback-pin.js +1 -1
  54. package/dist/components/giftback-progress.js +1 -1
  55. package/dist/components/index.js +1 -1
  56. package/dist/components/loading-container.d.ts +11 -0
  57. package/dist/components/loading-container.js +8 -0
  58. package/dist/components/loading-container.js.map +1 -0
  59. package/dist/components/loading-spinner.js +1 -1
  60. package/dist/components/name-input.js +1 -1
  61. package/dist/components/{p-c933623f.js → p-0a29a684.js} +3 -3
  62. package/dist/components/{p-c933623f.js.map → p-0a29a684.js.map} +1 -1
  63. package/dist/components/{p-8bc69d9b.js → p-0ef696a9.js} +2 -2
  64. package/dist/components/{p-8bc69d9b.js.map → p-0ef696a9.js.map} +1 -1
  65. package/dist/components/{p-5f330088.js → p-27554f4e.js} +4 -4
  66. package/dist/components/{p-5f330088.js.map → p-27554f4e.js.map} +1 -1
  67. package/dist/components/{p-2db8985c.js → p-29622725.js} +3 -3
  68. package/dist/components/{p-2db8985c.js.map → p-29622725.js.map} +1 -1
  69. package/dist/components/{p-c1d19bba.js → p-56757e8d.js} +6 -6
  70. package/dist/components/{p-c1d19bba.js.map → p-56757e8d.js.map} +1 -1
  71. package/dist/components/{p-2a4df0a2.js → p-58ee9506.js} +4 -4
  72. package/dist/components/{p-2a4df0a2.js.map → p-58ee9506.js.map} +1 -1
  73. package/dist/components/{p-c2358b51.js → p-6592ce84.js} +4 -4
  74. package/dist/components/{p-c2358b51.js.map → p-6592ce84.js.map} +1 -1
  75. package/dist/components/{p-b289b82d.js → p-959f4cc8.js} +286 -5
  76. package/dist/{crmbonus-component-wake/p-45c0296c.js.map → components/p-959f4cc8.js.map} +1 -1
  77. package/dist/components/{p-d4cfdf80.js → p-998b6c7d.js} +5 -5
  78. package/dist/components/{p-d4cfdf80.js.map → p-998b6c7d.js.map} +1 -1
  79. package/dist/components/{p-984bc7d0.js → p-9ceca803.js} +14 -14
  80. package/dist/components/{p-984bc7d0.js.map → p-9ceca803.js.map} +1 -1
  81. package/dist/components/p-c7fc1cb6.js +36 -0
  82. package/dist/components/p-c7fc1cb6.js.map +1 -0
  83. package/dist/components/{p-e957883c.js → p-ca3d612c.js} +6 -6
  84. package/dist/components/{p-e957883c.js.map → p-ca3d612c.js.map} +1 -1
  85. package/dist/components/{p-bfe98629.js → p-f1639e26.js} +3 -3
  86. package/dist/components/{p-bfe98629.js.map → p-f1639e26.js.map} +1 -1
  87. package/dist/components/{p-24d29b6b.js → p-fbcbb1aa.js} +3 -3
  88. package/dist/components/{p-24d29b6b.js.map → p-fbcbb1aa.js.map} +1 -1
  89. package/dist/components/pedido-finalizado.js +2 -2
  90. package/dist/components/phone-cancel-input.js +4 -4
  91. package/dist/components/phone-form.js +1 -1
  92. package/dist/components/phone-input-mask.js +1 -1
  93. package/dist/components/phone-input.js +4 -4
  94. package/dist/components/pin-form.js +1 -1
  95. package/dist/crmbonus-component-wake/crmbonus-component-wake.esm.js +1 -1
  96. package/dist/crmbonus-component-wake/crmbonus-component-wake.esm.js.map +1 -1
  97. package/dist/crmbonus-component-wake/{p-0152eebc.entry.js → p-2086a755.entry.js} +2 -2
  98. package/dist/crmbonus-component-wake/p-24616d67.js +3 -0
  99. package/dist/crmbonus-component-wake/p-24616d67.js.map +1 -0
  100. package/dist/crmbonus-component-wake/{p-a465c900.entry.js → p-282b201b.entry.js} +2 -2
  101. package/dist/crmbonus-component-wake/p-304d3f89.entry.js +2 -0
  102. package/dist/crmbonus-component-wake/p-4d351ad2.entry.js +2 -0
  103. package/dist/crmbonus-component-wake/p-81d3a170.entry.js +2 -0
  104. package/dist/crmbonus-component-wake/p-81d3a170.entry.js.map +1 -0
  105. package/dist/crmbonus-component-wake/{p-b7103956.entry.js → p-8bd25376.entry.js} +2 -2
  106. package/dist/crmbonus-component-wake/p-92fe1963.entry.js +2 -0
  107. package/dist/crmbonus-component-wake/{p-5d209c28.entry.js → p-9ad0650e.entry.js} +2 -2
  108. package/dist/crmbonus-component-wake/{p-c121f6fc.entry.js → p-b7925fc7.entry.js} +2 -2
  109. package/dist/crmbonus-component-wake/{p-da97c793.entry.js → p-c8445f78.entry.js} +2 -2
  110. package/dist/crmbonus-component-wake/{p-0160f5f5.entry.js → p-cd95574b.entry.js} +2 -2
  111. package/dist/crmbonus-component-wake/{p-feadb94b.entry.js → p-d8e5a526.entry.js} +2 -2
  112. package/dist/crmbonus-component-wake/p-d8e5a526.entry.js.map +1 -0
  113. package/dist/crmbonus-component-wake/p-db4f04a8.entry.js +2 -0
  114. package/dist/esm/app-modal.entry.js +2 -2
  115. package/dist/esm/countdown-timer_4.entry.js +6 -6
  116. package/dist/esm/crm-bonus-form.entry.js +2 -2
  117. package/dist/esm/crm-bonus-note.entry.js +4 -4
  118. package/dist/esm/crm-bonus.entry.js +19 -2
  119. package/dist/esm/crm-bonus.entry.js.map +1 -1
  120. package/dist/esm/crm-button.entry.js +1 -1
  121. package/dist/esm/{crm-giftback-form.entry.js → crm-giftback-form_2.entry.js} +22 -8
  122. package/dist/esm/crm-giftback-form_2.entry.js.map +1 -0
  123. package/dist/esm/crmbonus-component-wake.js +3 -3
  124. package/dist/esm/giftback-finish_4.entry.js +5 -5
  125. package/dist/esm/{index-c477a8b3.js → index-84fba7ef.js} +286 -5
  126. package/dist/esm/index-84fba7ef.js.map +1 -0
  127. package/dist/esm/loader.js +3 -3
  128. package/dist/esm/loading-spinner.entry.js +2 -2
  129. package/dist/esm/pedido-finalizado.entry.js +2 -2
  130. package/dist/esm/phone-cancel-input.entry.js +2 -2
  131. package/dist/esm/phone-input-mask.entry.js +2 -2
  132. package/dist/esm/phone-input.entry.js +2 -2
  133. package/dist/types/components/crm-bonus/crm-bonus.d.ts +2 -0
  134. package/dist/types/components/loading-container/loading-container.d.ts +4 -0
  135. package/dist/types/components.d.ts +16 -0
  136. package/package.json +1 -1
  137. package/dist/cjs/crm-giftback-form.cjs.entry.js.map +0 -1
  138. package/dist/cjs/index-e3122e18.js.map +0 -1
  139. package/dist/components/p-b289b82d.js.map +0 -1
  140. package/dist/crmbonus-component-wake/p-450423b5.entry.js +0 -2
  141. package/dist/crmbonus-component-wake/p-45c0296c.js +0 -3
  142. package/dist/crmbonus-component-wake/p-5881e9d8.entry.js +0 -2
  143. package/dist/crmbonus-component-wake/p-5881e9d8.entry.js.map +0 -1
  144. package/dist/crmbonus-component-wake/p-64441d8f.entry.js +0 -2
  145. package/dist/crmbonus-component-wake/p-a950d747.entry.js +0 -2
  146. package/dist/crmbonus-component-wake/p-d95bd37f.entry.js +0 -2
  147. package/dist/crmbonus-component-wake/p-feadb94b.entry.js.map +0 -1
  148. package/dist/esm/crm-giftback-form.entry.js.map +0 -1
  149. /package/dist/crmbonus-component-wake/{p-0152eebc.entry.js.map → p-2086a755.entry.js.map} +0 -0
  150. /package/dist/crmbonus-component-wake/{p-a465c900.entry.js.map → p-282b201b.entry.js.map} +0 -0
  151. /package/dist/crmbonus-component-wake/{p-64441d8f.entry.js.map → p-304d3f89.entry.js.map} +0 -0
  152. /package/dist/crmbonus-component-wake/{p-a950d747.entry.js.map → p-4d351ad2.entry.js.map} +0 -0
  153. /package/dist/crmbonus-component-wake/{p-b7103956.entry.js.map → p-8bd25376.entry.js.map} +0 -0
  154. /package/dist/crmbonus-component-wake/{p-450423b5.entry.js.map → p-92fe1963.entry.js.map} +0 -0
  155. /package/dist/crmbonus-component-wake/{p-5d209c28.entry.js.map → p-9ad0650e.entry.js.map} +0 -0
  156. /package/dist/crmbonus-component-wake/{p-c121f6fc.entry.js.map → p-b7925fc7.entry.js.map} +0 -0
  157. /package/dist/crmbonus-component-wake/{p-da97c793.entry.js.map → p-c8445f78.entry.js.map} +0 -0
  158. /package/dist/crmbonus-component-wake/{p-0160f5f5.entry.js.map → p-cd95574b.entry.js.map} +0 -0
  159. /package/dist/crmbonus-component-wake/{p-d95bd37f.entry.js.map → p-db4f04a8.entry.js.map} +0 -0
@@ -21,7 +21,7 @@ function _interopNamespace(e) {
21
21
  }
22
22
 
23
23
  const NAMESPACE = 'crmbonus-component-wake';
24
- const BUILD = /* crmbonus-component-wake */ { allRenderFn: true, appendChildSlotFix: false, asyncLoading: true, asyncQueue: false, attachStyles: true, cloneNodeFix: false, cmpDidLoad: false, cmpDidRender: false, cmpDidUnload: false, cmpDidUpdate: false, cmpShouldUpdate: false, cmpWillLoad: true, cmpWillRender: false, cmpWillUpdate: false, connectedCallback: false, constructableCSS: true, cssAnnotations: true, devTools: false, disconnectedCallback: true, element: false, event: true, experimentalScopedSlotChanges: false, experimentalSlotFixes: false, formAssociated: false, hasRenderFn: true, hostListener: false, hostListenerTarget: false, hostListenerTargetBody: false, hostListenerTargetDocument: false, hostListenerTargetParent: false, hostListenerTargetWindow: false, hotModuleReplacement: false, hydrateClientSide: false, hydrateServerSide: false, hydratedAttribute: false, hydratedClass: true, hydratedSelectorName: "hydrated", initializeNextTick: false, invisiblePrehydration: true, isDebug: false, isDev: false, isTesting: false, lazyLoad: true, lifecycle: true, lifecycleDOMEvents: false, member: true, method: true, mode: false, observeAttribute: true, profile: false, prop: true, propBoolean: true, propMutable: false, propNumber: true, propString: true, reflect: true, scoped: true, scopedSlotTextContentFix: false, scriptDataOpts: false, shadowDelegatesFocus: false, shadowDom: true, slot: true, slotChildNodesFix: false, slotRelocation: false, state: true, style: true, svg: false, taskQueue: true, transformTagName: false, updatable: true, vdomAttribute: true, vdomClass: true, vdomFunctional: false, vdomKey: true, vdomListener: true, vdomPropOrAttr: true, vdomRef: true, vdomRender: true, vdomStyle: true, vdomText: true, vdomXlink: false, watchCallback: true };
24
+ const BUILD = /* crmbonus-component-wake */ { allRenderFn: true, appendChildSlotFix: false, asyncLoading: true, asyncQueue: false, attachStyles: true, cloneNodeFix: false, cmpDidLoad: false, cmpDidRender: false, cmpDidUnload: false, cmpDidUpdate: false, cmpShouldUpdate: false, cmpWillLoad: true, cmpWillRender: false, cmpWillUpdate: false, connectedCallback: false, constructableCSS: true, cssAnnotations: true, devTools: false, disconnectedCallback: true, element: false, event: true, experimentalScopedSlotChanges: false, experimentalSlotFixes: false, formAssociated: false, hasRenderFn: true, hostListener: false, hostListenerTarget: false, hostListenerTargetBody: false, hostListenerTargetDocument: false, hostListenerTargetParent: false, hostListenerTargetWindow: false, hotModuleReplacement: false, hydrateClientSide: false, hydrateServerSide: false, hydratedAttribute: false, hydratedClass: true, hydratedSelectorName: "hydrated", initializeNextTick: false, invisiblePrehydration: true, isDebug: false, isDev: false, isTesting: false, lazyLoad: true, lifecycle: true, lifecycleDOMEvents: false, member: true, method: true, mode: false, observeAttribute: true, profile: false, prop: true, propBoolean: true, propMutable: false, propNumber: true, propString: true, reflect: true, scoped: true, scopedSlotTextContentFix: false, scriptDataOpts: false, shadowDelegatesFocus: false, shadowDom: true, slot: true, slotChildNodesFix: false, slotRelocation: true, state: true, style: true, svg: false, taskQueue: true, transformTagName: false, updatable: true, vdomAttribute: true, vdomClass: true, vdomFunctional: false, vdomKey: true, vdomListener: true, vdomPropOrAttr: true, vdomRef: true, vdomRender: true, vdomStyle: true, vdomText: true, vdomXlink: false, watchCallback: true };
25
25
 
26
26
  /*
27
27
  Stencil Client Platform v4.22.2 | MIT Licensed | https://stenciljs.com
@@ -222,6 +222,7 @@ var uniqueTime = (key, measureText) => {
222
222
  var h = (nodeName, vnodeData, ...children) => {
223
223
  let child = null;
224
224
  let key = null;
225
+ let slotName = null;
225
226
  let simple = false;
226
227
  let lastSimple = false;
227
228
  const vNodeChildren = [];
@@ -248,6 +249,9 @@ var h = (nodeName, vnodeData, ...children) => {
248
249
  if (vnodeData.key) {
249
250
  key = vnodeData.key;
250
251
  }
252
+ if (vnodeData.name) {
253
+ slotName = vnodeData.name;
254
+ }
251
255
  {
252
256
  const classData = vnodeData.className || vnodeData.class;
253
257
  if (classData) {
@@ -263,6 +267,9 @@ var h = (nodeName, vnodeData, ...children) => {
263
267
  {
264
268
  vnode.$key$ = key;
265
269
  }
270
+ {
271
+ vnode.$name$ = slotName;
272
+ }
266
273
  return vnode;
267
274
  };
268
275
  var newVNode = (tag, text) => {
@@ -279,6 +286,9 @@ var newVNode = (tag, text) => {
279
286
  {
280
287
  vnode.$key$ = null;
281
288
  }
289
+ {
290
+ vnode.$name$ = null;
291
+ }
282
292
  return vnode;
283
293
  };
284
294
  var Host = {};
@@ -534,16 +544,41 @@ function sortedAttrNames(attrNames) {
534
544
 
535
545
  // src/runtime/vdom/vdom-render.ts
536
546
  var scopeId;
547
+ var contentRef;
537
548
  var hostTagName;
538
549
  var useNativeShadowDom = false;
550
+ var checkSlotFallbackVisibility = false;
551
+ var checkSlotRelocate = false;
539
552
  var isSvgMode = false;
540
553
  var createElm = (oldParentVNode, newParentVNode, childIndex, parentElm) => {
554
+ var _a;
541
555
  const newVNode2 = newParentVNode.$children$[childIndex];
542
556
  let i2 = 0;
543
557
  let elm;
544
558
  let childNode;
559
+ let oldVNode;
560
+ if (!useNativeShadowDom) {
561
+ checkSlotRelocate = true;
562
+ if (newVNode2.$tag$ === "slot") {
563
+ if (scopeId) {
564
+ parentElm.classList.add(scopeId + "-s");
565
+ }
566
+ newVNode2.$flags$ |= newVNode2.$children$ ? (
567
+ // slot element has fallback content
568
+ // still create an element that "mocks" the slot element
569
+ 2 /* isSlotFallback */
570
+ ) : (
571
+ // slot element does not have fallback content
572
+ // create an html comment we'll use to always reference
573
+ // where actual slot content should sit next to
574
+ 1 /* isSlotReference */
575
+ );
576
+ }
577
+ }
545
578
  if (newVNode2.$text$ !== null) {
546
579
  elm = newVNode2.$elm$ = doc.createTextNode(newVNode2.$text$);
580
+ } else if (newVNode2.$flags$ & 1 /* isSlotReference */) {
581
+ elm = newVNode2.$elm$ = doc.createTextNode("");
547
582
  } else {
548
583
  elm = newVNode2.$elm$ = doc.createElement(
549
584
  !useNativeShadowDom && BUILD.slotRelocation && newVNode2.$flags$ & 2 /* isSlotFallback */ ? "slot-fb" : newVNode2.$tag$
@@ -569,10 +604,50 @@ var createElm = (oldParentVNode, newParentVNode, childIndex, parentElm) => {
569
604
  }
570
605
  }
571
606
  elm["s-hn"] = hostTagName;
607
+ {
608
+ if (newVNode2.$flags$ & (2 /* isSlotFallback */ | 1 /* isSlotReference */)) {
609
+ elm["s-sr"] = true;
610
+ elm["s-cr"] = contentRef;
611
+ elm["s-sn"] = newVNode2.$name$ || "";
612
+ elm["s-rf"] = (_a = newVNode2.$attrs$) == null ? void 0 : _a.ref;
613
+ oldVNode = oldParentVNode && oldParentVNode.$children$ && oldParentVNode.$children$[childIndex];
614
+ if (oldVNode && oldVNode.$tag$ === newVNode2.$tag$ && oldParentVNode.$elm$) {
615
+ {
616
+ putBackInOriginalLocation(oldParentVNode.$elm$, false);
617
+ }
618
+ }
619
+ }
620
+ }
572
621
  return elm;
573
622
  };
623
+ var putBackInOriginalLocation = (parentElm, recursive) => {
624
+ plt.$flags$ |= 1 /* isTmpDisconnected */;
625
+ const oldSlotChildNodes = Array.from(parentElm.childNodes);
626
+ if (parentElm["s-sr"] && BUILD.experimentalSlotFixes) {
627
+ let node = parentElm;
628
+ while (node = node.nextSibling) {
629
+ if (node && node["s-sn"] === parentElm["s-sn"] && node["s-sh"] === hostTagName) {
630
+ oldSlotChildNodes.push(node);
631
+ }
632
+ }
633
+ }
634
+ for (let i2 = oldSlotChildNodes.length - 1; i2 >= 0; i2--) {
635
+ const childNode = oldSlotChildNodes[i2];
636
+ if (childNode["s-hn"] !== hostTagName && childNode["s-ol"]) {
637
+ insertBefore(parentReferenceNode(childNode), childNode, referenceNode(childNode));
638
+ childNode["s-ol"].remove();
639
+ childNode["s-ol"] = void 0;
640
+ childNode["s-sh"] = void 0;
641
+ checkSlotRelocate = true;
642
+ }
643
+ if (recursive) {
644
+ putBackInOriginalLocation(childNode, recursive);
645
+ }
646
+ }
647
+ plt.$flags$ &= ~1 /* isTmpDisconnected */;
648
+ };
574
649
  var addVnodes = (parentElm, before, parentVNode, vnodes, startIdx, endIdx) => {
575
- let containerElm = parentElm;
650
+ let containerElm = parentElm["s-cr"] && parentElm["s-cr"].parentNode || parentElm;
576
651
  let childNode;
577
652
  if (containerElm.shadowRoot && containerElm.tagName === hostTagName) {
578
653
  containerElm = containerElm.shadowRoot;
@@ -582,7 +657,7 @@ var addVnodes = (parentElm, before, parentVNode, vnodes, startIdx, endIdx) => {
582
657
  childNode = createElm(null, parentVNode, startIdx, parentElm);
583
658
  if (childNode) {
584
659
  vnodes[startIdx].$elm$ = childNode;
585
- insertBefore(containerElm, childNode, before);
660
+ insertBefore(containerElm, childNode, referenceNode(before) );
586
661
  }
587
662
  }
588
663
  }
@@ -594,6 +669,14 @@ var removeVnodes = (vnodes, startIdx, endIdx) => {
594
669
  const elm = vnode.$elm$;
595
670
  nullifyVNodeRefs(vnode);
596
671
  if (elm) {
672
+ {
673
+ checkSlotFallbackVisibility = true;
674
+ if (elm["s-ol"]) {
675
+ elm["s-ol"].remove();
676
+ } else {
677
+ putBackInOriginalLocation(elm, true);
678
+ }
679
+ }
597
680
  elm.remove();
598
681
  }
599
682
  }
@@ -630,11 +713,17 @@ var updateChildren = (parentElm, oldCh, newVNode2, newCh, isInitialRender = fals
630
713
  oldEndVnode = oldCh[--oldEndIdx];
631
714
  newEndVnode = newCh[--newEndIdx];
632
715
  } else if (isSameVnode(oldStartVnode, newEndVnode, isInitialRender)) {
716
+ if ((oldStartVnode.$tag$ === "slot" || newEndVnode.$tag$ === "slot")) {
717
+ putBackInOriginalLocation(oldStartVnode.$elm$.parentNode, false);
718
+ }
633
719
  patch(oldStartVnode, newEndVnode, isInitialRender);
634
720
  insertBefore(parentElm, oldStartVnode.$elm$, oldEndVnode.$elm$.nextSibling);
635
721
  oldStartVnode = oldCh[++oldStartIdx];
636
722
  newEndVnode = newCh[--newEndIdx];
637
723
  } else if (isSameVnode(oldEndVnode, newStartVnode, isInitialRender)) {
724
+ if ((oldStartVnode.$tag$ === "slot" || newEndVnode.$tag$ === "slot")) {
725
+ putBackInOriginalLocation(oldEndVnode.$elm$.parentNode, false);
726
+ }
638
727
  patch(oldEndVnode, newStartVnode, isInitialRender);
639
728
  insertBefore(parentElm, oldEndVnode.$elm$, oldStartVnode.$elm$);
640
729
  oldEndVnode = oldCh[--oldEndIdx];
@@ -665,7 +754,7 @@ var updateChildren = (parentElm, oldCh, newVNode2, newCh, isInitialRender = fals
665
754
  }
666
755
  if (node) {
667
756
  {
668
- insertBefore(oldStartVnode.$elm$.parentNode, node, oldStartVnode.$elm$);
757
+ insertBefore(parentReferenceNode(oldStartVnode.$elm$), node, referenceNode(oldStartVnode.$elm$));
669
758
  }
670
759
  }
671
760
  }
@@ -685,6 +774,18 @@ var updateChildren = (parentElm, oldCh, newVNode2, newCh, isInitialRender = fals
685
774
  };
686
775
  var isSameVnode = (leftVNode, rightVNode, isInitialRender = false) => {
687
776
  if (leftVNode.$tag$ === rightVNode.$tag$) {
777
+ if (leftVNode.$tag$ === "slot") {
778
+ if (
779
+ // The component gets hydrated and no VDOM has been initialized.
780
+ // Here the comparison can't happen as $name$ property is not set for `leftNode`.
781
+ "$nodeId$" in leftVNode && isInitialRender && // `leftNode` is not from type HTMLComment which would cause many
782
+ // hydration comments to be removed
783
+ leftVNode.$elm$.nodeType !== 8
784
+ ) {
785
+ return false;
786
+ }
787
+ return leftVNode.$name$ === rightVNode.$name$;
788
+ }
688
789
  if (!isInitialRender) {
689
790
  return leftVNode.$key$ === rightVNode.$key$;
690
791
  }
@@ -692,12 +793,17 @@ var isSameVnode = (leftVNode, rightVNode, isInitialRender = false) => {
692
793
  }
693
794
  return false;
694
795
  };
796
+ var referenceNode = (node) => {
797
+ return node && node["s-ol"] || node;
798
+ };
799
+ var parentReferenceNode = (node) => (node["s-ol"] ? node["s-ol"] : node).parentNode;
695
800
  var patch = (oldVNode, newVNode2, isInitialRender = false) => {
696
801
  const elm = newVNode2.$elm$ = oldVNode.$elm$;
697
802
  const oldChildren = oldVNode.$children$;
698
803
  const newChildren = newVNode2.$children$;
699
804
  const tag = newVNode2.$tag$;
700
805
  const text = newVNode2.$text$;
806
+ let defaultHolder;
701
807
  if (text === null) {
702
808
  {
703
809
  if (tag === "slot" && !useNativeShadowDom) ; else {
@@ -717,10 +823,103 @@ var patch = (oldVNode, newVNode2, isInitialRender = false) => {
717
823
  ) {
718
824
  removeVnodes(oldChildren, 0, oldChildren.length - 1);
719
825
  }
826
+ } else if ((defaultHolder = elm["s-cr"])) {
827
+ defaultHolder.parentNode.textContent = text;
720
828
  } else if (oldVNode.$text$ !== text) {
721
829
  elm.data = text;
722
830
  }
723
831
  };
832
+ var updateFallbackSlotVisibility = (elm) => {
833
+ const childNodes = elm.childNodes;
834
+ for (const childNode of childNodes) {
835
+ if (childNode.nodeType === 1 /* ElementNode */) {
836
+ if (childNode["s-sr"]) {
837
+ const slotName = childNode["s-sn"];
838
+ childNode.hidden = false;
839
+ for (const siblingNode of childNodes) {
840
+ if (siblingNode !== childNode) {
841
+ if (siblingNode["s-hn"] !== childNode["s-hn"] || slotName !== "") {
842
+ if (siblingNode.nodeType === 1 /* ElementNode */ && (slotName === siblingNode.getAttribute("slot") || slotName === siblingNode["s-sn"]) || siblingNode.nodeType === 3 /* TextNode */ && slotName === siblingNode["s-sn"]) {
843
+ childNode.hidden = true;
844
+ break;
845
+ }
846
+ } else {
847
+ if (siblingNode.nodeType === 1 /* ElementNode */ || siblingNode.nodeType === 3 /* TextNode */ && siblingNode.textContent.trim() !== "") {
848
+ childNode.hidden = true;
849
+ break;
850
+ }
851
+ }
852
+ }
853
+ }
854
+ }
855
+ updateFallbackSlotVisibility(childNode);
856
+ }
857
+ }
858
+ };
859
+ var relocateNodes = [];
860
+ var markSlotContentForRelocation = (elm) => {
861
+ let node;
862
+ let hostContentNodes;
863
+ let j;
864
+ for (const childNode of elm.childNodes) {
865
+ if (childNode["s-sr"] && (node = childNode["s-cr"]) && node.parentNode) {
866
+ hostContentNodes = node.parentNode.childNodes;
867
+ const slotName = childNode["s-sn"];
868
+ for (j = hostContentNodes.length - 1; j >= 0; j--) {
869
+ node = hostContentNodes[j];
870
+ if (!node["s-cn"] && !node["s-nr"] && node["s-hn"] !== childNode["s-hn"] && (!BUILD.experimentalSlotFixes )) {
871
+ if (isNodeLocatedInSlot(node, slotName)) {
872
+ let relocateNodeData = relocateNodes.find((r) => r.$nodeToRelocate$ === node);
873
+ checkSlotFallbackVisibility = true;
874
+ node["s-sn"] = node["s-sn"] || slotName;
875
+ if (relocateNodeData) {
876
+ relocateNodeData.$nodeToRelocate$["s-sh"] = childNode["s-hn"];
877
+ relocateNodeData.$slotRefNode$ = childNode;
878
+ } else {
879
+ node["s-sh"] = childNode["s-hn"];
880
+ relocateNodes.push({
881
+ $slotRefNode$: childNode,
882
+ $nodeToRelocate$: node
883
+ });
884
+ }
885
+ if (node["s-sr"]) {
886
+ relocateNodes.map((relocateNode) => {
887
+ if (isNodeLocatedInSlot(relocateNode.$nodeToRelocate$, node["s-sn"])) {
888
+ relocateNodeData = relocateNodes.find((r) => r.$nodeToRelocate$ === node);
889
+ if (relocateNodeData && !relocateNode.$slotRefNode$) {
890
+ relocateNode.$slotRefNode$ = relocateNodeData.$slotRefNode$;
891
+ }
892
+ }
893
+ });
894
+ }
895
+ } else if (!relocateNodes.some((r) => r.$nodeToRelocate$ === node)) {
896
+ relocateNodes.push({
897
+ $nodeToRelocate$: node
898
+ });
899
+ }
900
+ }
901
+ }
902
+ }
903
+ if (childNode.nodeType === 1 /* ElementNode */) {
904
+ markSlotContentForRelocation(childNode);
905
+ }
906
+ }
907
+ };
908
+ var isNodeLocatedInSlot = (nodeToRelocate, slotName) => {
909
+ if (nodeToRelocate.nodeType === 1 /* ElementNode */) {
910
+ if (nodeToRelocate.getAttribute("slot") === null && slotName === "") {
911
+ return true;
912
+ }
913
+ if (nodeToRelocate.getAttribute("slot") === slotName) {
914
+ return true;
915
+ }
916
+ return false;
917
+ }
918
+ if (nodeToRelocate["s-sn"] === slotName) {
919
+ return true;
920
+ }
921
+ return slotName === "";
922
+ };
724
923
  var nullifyVNodeRefs = (vNode) => {
725
924
  {
726
925
  vNode.$attrs$ && vNode.$attrs$.ref && vNode.$attrs$.ref(null);
@@ -761,6 +960,7 @@ var updateElementScopeIds = (element, parent, iterateChildNodes = false) => {
761
960
  }
762
961
  };
763
962
  var renderVdom = (hostRef, renderFnResults, isInitialLoad = false) => {
963
+ var _a, _b, _c, _d;
764
964
  const hostElm = hostRef.$hostElement$;
765
965
  const cmpMeta = hostRef.$cmpMeta$;
766
966
  const oldVNode = hostRef.$vnode$ || newVNode(null, null);
@@ -787,7 +987,75 @@ var renderVdom = (hostRef, renderFnResults, isInitialLoad = false) => {
787
987
  scopeId = hostElm["s-sc"];
788
988
  }
789
989
  useNativeShadowDom = (cmpMeta.$flags$ & 1 /* shadowDomEncapsulation */) !== 0;
990
+ {
991
+ contentRef = hostElm["s-cr"];
992
+ checkSlotFallbackVisibility = false;
993
+ }
790
994
  patch(oldVNode, rootVnode, isInitialLoad);
995
+ {
996
+ plt.$flags$ |= 1 /* isTmpDisconnected */;
997
+ if (checkSlotRelocate) {
998
+ markSlotContentForRelocation(rootVnode.$elm$);
999
+ for (const relocateData of relocateNodes) {
1000
+ const nodeToRelocate = relocateData.$nodeToRelocate$;
1001
+ if (!nodeToRelocate["s-ol"]) {
1002
+ const orgLocationNode = doc.createTextNode("");
1003
+ orgLocationNode["s-nr"] = nodeToRelocate;
1004
+ insertBefore(nodeToRelocate.parentNode, nodeToRelocate["s-ol"] = orgLocationNode, nodeToRelocate);
1005
+ }
1006
+ }
1007
+ for (const relocateData of relocateNodes) {
1008
+ const nodeToRelocate = relocateData.$nodeToRelocate$;
1009
+ const slotRefNode = relocateData.$slotRefNode$;
1010
+ if (slotRefNode) {
1011
+ const parentNodeRef = slotRefNode.parentNode;
1012
+ let insertBeforeNode = slotRefNode.nextSibling;
1013
+ {
1014
+ let orgLocationNode = (_a = nodeToRelocate["s-ol"]) == null ? void 0 : _a.previousSibling;
1015
+ while (orgLocationNode) {
1016
+ let refNode = (_b = orgLocationNode["s-nr"]) != null ? _b : null;
1017
+ if (refNode && refNode["s-sn"] === nodeToRelocate["s-sn"] && parentNodeRef === refNode.parentNode) {
1018
+ refNode = refNode.nextSibling;
1019
+ while (refNode === nodeToRelocate || (refNode == null ? void 0 : refNode["s-sr"])) {
1020
+ refNode = refNode == null ? void 0 : refNode.nextSibling;
1021
+ }
1022
+ if (!refNode || !refNode["s-nr"]) {
1023
+ insertBeforeNode = refNode;
1024
+ break;
1025
+ }
1026
+ }
1027
+ orgLocationNode = orgLocationNode.previousSibling;
1028
+ }
1029
+ }
1030
+ if (!insertBeforeNode && parentNodeRef !== nodeToRelocate.parentNode || nodeToRelocate.nextSibling !== insertBeforeNode) {
1031
+ if (nodeToRelocate !== insertBeforeNode) {
1032
+ if (!nodeToRelocate["s-hn"] && nodeToRelocate["s-ol"]) {
1033
+ nodeToRelocate["s-hn"] = nodeToRelocate["s-ol"].parentNode.nodeName;
1034
+ }
1035
+ insertBefore(parentNodeRef, nodeToRelocate, insertBeforeNode);
1036
+ if (nodeToRelocate.nodeType === 1 /* ElementNode */) {
1037
+ nodeToRelocate.hidden = (_c = nodeToRelocate["s-ih"]) != null ? _c : false;
1038
+ }
1039
+ }
1040
+ }
1041
+ nodeToRelocate && typeof slotRefNode["s-rf"] === "function" && slotRefNode["s-rf"](nodeToRelocate);
1042
+ } else {
1043
+ if (nodeToRelocate.nodeType === 1 /* ElementNode */) {
1044
+ if (isInitialLoad) {
1045
+ nodeToRelocate["s-ih"] = (_d = nodeToRelocate.hidden) != null ? _d : false;
1046
+ }
1047
+ nodeToRelocate.hidden = true;
1048
+ }
1049
+ }
1050
+ }
1051
+ }
1052
+ if (checkSlotFallbackVisibility) {
1053
+ updateFallbackSlotVisibility(rootVnode.$elm$);
1054
+ }
1055
+ plt.$flags$ &= ~1 /* isTmpDisconnected */;
1056
+ relocateNodes.length = 0;
1057
+ }
1058
+ contentRef = void 0;
791
1059
  };
792
1060
 
793
1061
  // src/runtime/update-component.ts
@@ -1135,6 +1403,12 @@ var connectedCallback = (elm) => {
1135
1403
  const endConnected = createTime("connectedCallback", cmpMeta.$tagName$);
1136
1404
  if (!(hostRef.$flags$ & 1 /* hasConnected */)) {
1137
1405
  hostRef.$flags$ |= 1 /* hasConnected */;
1406
+ {
1407
+ if (// TODO(STENCIL-854): Remove code related to legacy shadowDomShim field
1408
+ cmpMeta.$flags$ & (4 /* hasSlotRelocation */ | 8 /* needsShadowDomShim */)) {
1409
+ setContentReference(elm);
1410
+ }
1411
+ }
1138
1412
  {
1139
1413
  let ancestorComponent = elm;
1140
1414
  while (ancestorComponent = ancestorComponent.parentNode || ancestorComponent.host) {
@@ -1164,6 +1438,13 @@ var connectedCallback = (elm) => {
1164
1438
  endConnected();
1165
1439
  }
1166
1440
  };
1441
+ var setContentReference = (elm) => {
1442
+ const contentRefElm = elm["s-cr"] = doc.createComment(
1443
+ ""
1444
+ );
1445
+ contentRefElm["s-cn"] = true;
1446
+ insertBefore(elm, contentRefElm, elm.firstChild);
1447
+ };
1167
1448
  var disconnectInstance = (instance) => {
1168
1449
  {
1169
1450
  safeCall(instance, "disconnectedCallback");
@@ -1311,4 +1592,4 @@ exports.promiseResolve = promiseResolve;
1311
1592
  exports.registerInstance = registerInstance;
1312
1593
  exports.setNonce = setNonce;
1313
1594
 
1314
- //# sourceMappingURL=index-e3122e18.js.map
1595
+ //# sourceMappingURL=index-8243a0e3.js.map