@ptcwebops/ptcw-design 6.2.20-beta → 6.2.21-beta

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 (111) hide show
  1. package/dist/cjs/{component-4dd13907.js → component-6a178a16.js} +1 -1
  2. package/dist/cjs/event-jumbotron-example.cjs.entry.js +146 -0
  3. package/dist/cjs/icon-asset.cjs.entry.js +65 -0
  4. package/dist/cjs/list-item.cjs.entry.js +48 -0
  5. package/dist/cjs/loader.cjs.js +1 -1
  6. package/dist/cjs/ptc-breadcrumb.cjs.entry.js +47 -0
  7. package/dist/cjs/ptc-button.cjs.entry.js +87 -0
  8. package/dist/cjs/ptc-card-bottom_2.cjs.entry.js +155 -0
  9. package/dist/cjs/ptc-card-content.cjs.entry.js +76 -0
  10. package/dist/cjs/ptc-close-icon_2.cjs.entry.js +239 -0
  11. package/dist/cjs/ptc-data-lookup.cjs.entry.js +1 -1
  12. package/dist/cjs/ptc-form-checkbox_4.cjs.entry.js +1 -1
  13. package/dist/cjs/ptc-img.cjs.entry.js +133 -0
  14. package/dist/cjs/ptc-link.cjs.entry.js +87 -0
  15. package/dist/cjs/ptc-para.cjs.entry.js +127 -0
  16. package/dist/cjs/ptc-scroll-button.cjs.entry.js +136 -0
  17. package/dist/cjs/ptc-spacer.cjs.entry.js +38 -0
  18. package/dist/cjs/ptc-sticky-title.cjs.entry.js +2 -2
  19. package/dist/cjs/ptc-title.cjs.entry.js +152 -0
  20. package/dist/cjs/ptc-value-led-layout.cjs.entry.js +1 -1
  21. package/dist/cjs/ptcw-design.cjs.js +1 -1
  22. package/dist/collection/components/ptc-sticky-title/ptc-sticky-title.js +2 -2
  23. package/dist/collection/components/ptc-value-led-layout/ptc-value-led-layout.js +1 -1
  24. package/dist/custom-elements/index.js +4 -4
  25. package/dist/esm/blog-detail-content_2.entry.js +1 -1
  26. package/dist/esm/blog-detail-layout.entry.js +1 -1
  27. package/dist/esm/blogs-search-section.entry.js +1 -1
  28. package/dist/esm/{component-9c921cc6.js → component-80f298b4.js} +1 -1
  29. package/dist/esm/event-jumbotron-example.entry.js +142 -0
  30. package/dist/esm/homepage-jumbotron.entry.js +1 -1
  31. package/dist/esm/homepage-toggled-content.entry.js +1 -1
  32. package/dist/esm/icon-asset.entry.js +61 -0
  33. package/dist/esm/list-item.entry.js +44 -0
  34. package/dist/esm/loader.js +1 -1
  35. package/dist/esm/most-popular-news.entry.js +1 -1
  36. package/dist/esm/my-component.entry.js +1 -1
  37. package/dist/esm/ptc-accordion-item.entry.js +1 -1
  38. package/dist/esm/ptc-background-video.entry.js +1 -1
  39. package/dist/esm/ptc-breadcrumb.entry.js +43 -0
  40. package/dist/esm/ptc-button.entry.js +83 -0
  41. package/dist/esm/ptc-card-bottom_2.entry.js +150 -0
  42. package/dist/esm/ptc-card-content.entry.js +72 -0
  43. package/dist/esm/ptc-close-icon_2.entry.js +234 -0
  44. package/dist/esm/ptc-collapse-list.entry.js +1 -1
  45. package/dist/esm/ptc-data-lookup.entry.js +1 -1
  46. package/dist/esm/ptc-form-checkbox_4.entry.js +2 -2
  47. package/dist/esm/ptc-homepage-image-feature.entry.js +1 -1
  48. package/dist/esm/ptc-homepage-video-background.entry.js +1 -1
  49. package/dist/esm/ptc-icon-card.entry.js +1 -1
  50. package/dist/esm/ptc-img.entry.js +129 -0
  51. package/dist/esm/ptc-link.entry.js +83 -0
  52. package/dist/esm/ptc-media-card.entry.js +1 -1
  53. package/dist/esm/ptc-para.entry.js +123 -0
  54. package/dist/esm/ptc-pricing-packaging-table.entry.js +1 -1
  55. package/dist/esm/ptc-pricing-tabs.entry.js +1 -1
  56. package/dist/esm/ptc-scroll-button.entry.js +132 -0
  57. package/dist/esm/ptc-social-icons-footer.entry.js +1 -1
  58. package/dist/esm/ptc-spacer.entry.js +34 -0
  59. package/dist/esm/ptc-sticky-title.entry.js +2 -2
  60. package/dist/esm/ptc-title.entry.js +148 -0
  61. package/dist/esm/ptc-value-led-layout.entry.js +1 -1
  62. package/dist/esm/ptcw-design.js +1 -1
  63. package/dist/esm/{utils-ff65c75b.js → utils-63eab4bd.js} +1 -1
  64. package/dist/ptcw-design/p-01075feb.entry.js +1 -0
  65. package/dist/ptcw-design/p-0c69ea52.entry.js +1 -0
  66. package/dist/ptcw-design/p-1070f8a3.entry.js +1 -0
  67. package/dist/ptcw-design/{p-e0b873d0.entry.js → p-16e70f20.entry.js} +1 -1
  68. package/dist/ptcw-design/{p-ae970a60.entry.js → p-17f6e145.entry.js} +1 -1
  69. package/dist/ptcw-design/p-25a25451.entry.js +1 -0
  70. package/dist/ptcw-design/p-28371371.entry.js +1 -0
  71. package/dist/ptcw-design/{p-e4000363.entry.js → p-28be539b.entry.js} +1 -1
  72. package/dist/ptcw-design/{p-a3b57ede.entry.js → p-291072b4.entry.js} +1 -1
  73. package/dist/ptcw-design/{p-d9abe7e8.entry.js → p-48c33817.entry.js} +1 -1
  74. package/dist/ptcw-design/{p-e3f8e5d5.entry.js → p-49e54079.entry.js} +1 -1
  75. package/dist/ptcw-design/{p-2c6fc745.entry.js → p-4ee98a3e.entry.js} +1 -1
  76. package/dist/ptcw-design/{p-d10cb999.entry.js → p-627103d8.entry.js} +1 -1
  77. package/dist/ptcw-design/{p-c95f423e.entry.js → p-6a3caf2b.entry.js} +1 -1
  78. package/dist/ptcw-design/{p-7a9611b4.entry.js → p-6f5fecae.entry.js} +1 -1
  79. package/dist/ptcw-design/p-72825cf6.entry.js +1 -0
  80. package/dist/ptcw-design/p-7793babb.entry.js +1 -0
  81. package/dist/ptcw-design/{p-8872161f.js → p-77b1221e.js} +1 -1
  82. package/dist/ptcw-design/p-7fe4d383.entry.js +1 -0
  83. package/dist/ptcw-design/{p-c37a3bd2.entry.js → p-821f0ff9.entry.js} +1 -1
  84. package/dist/ptcw-design/p-92d22c78.entry.js +1 -0
  85. package/dist/ptcw-design/p-9e9ae28c.entry.js +1 -0
  86. package/dist/ptcw-design/p-b651c1cb.entry.js +1 -0
  87. package/dist/ptcw-design/p-b8ee8699.entry.js +1 -0
  88. package/dist/ptcw-design/p-bf18b622.entry.js +1 -0
  89. package/dist/ptcw-design/{p-1b257420.entry.js → p-c01ea76f.entry.js} +1 -1
  90. package/dist/ptcw-design/p-c378ee48.entry.js +1 -0
  91. package/dist/ptcw-design/{p-6d3326da.entry.js → p-cbee4653.entry.js} +1 -1
  92. package/dist/ptcw-design/p-d0b980c0.entry.js +1 -0
  93. package/dist/ptcw-design/{p-11e0edaf.entry.js → p-d2825140.entry.js} +1 -1
  94. package/dist/ptcw-design/{p-c66b8926.entry.js → p-d3229458.entry.js} +1 -1
  95. package/dist/ptcw-design/{p-da82dc93.entry.js → p-e577ad62.entry.js} +1 -1
  96. package/dist/ptcw-design/{p-808ec62a.entry.js → p-eec2f3da.entry.js} +1 -1
  97. package/dist/ptcw-design/p-fb5fd29f.entry.js +1 -0
  98. package/dist/ptcw-design/{p-0fdfd4ad.entry.js → p-fc0348a7.entry.js} +1 -1
  99. package/dist/ptcw-design/{p-36007a57.entry.js → p-fd394e84.entry.js} +1 -1
  100. package/dist/ptcw-design/ptcw-design.esm.js +1 -1
  101. package/package.json +1 -1
  102. package/readme.md +1 -1
  103. package/dist/cjs/event-jumbotron-example_15.cjs.entry.js +0 -1394
  104. package/dist/cjs/ptc-card-bottom.cjs.entry.js +0 -67
  105. package/dist/esm/event-jumbotron-example_15.entry.js +0 -1376
  106. package/dist/esm/ptc-card-bottom.entry.js +0 -63
  107. package/dist/ptcw-design/p-43b4b4e2.entry.js +0 -1
  108. package/dist/ptcw-design/p-9fe0c27d.entry.js +0 -1
  109. package/dist/ptcw-design/p-a8b6714a.entry.js +0 -1
  110. package/dist/ptcw-design/p-fec1acdf.entry.js +0 -1
  111. /package/dist/ptcw-design/{p-bcab66bf.js → p-672a349f.js} +0 -0
@@ -0,0 +1,133 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-63ddc79c.js');
6
+ const interfaces = require('./interfaces-574e6df7.js');
7
+
8
+ const ptcImgCss = "h1,h2,h3,h4,h5,h6,p,ul,li,ptc-subnav,ptc-tab-list,ptc-link,ptc-square-card,.hyphenate-text,ptc-footer{word-break:break-word;hyphens:manual;-webkit-hyphens:manual;-moz-hyphens:manual;-ms-hyphens:manual}@supports (hyphenate-limit-chars: 12 3 3){h1,h2,h3,h4,h5,h6,p,ul,li,ptc-subnav,ptc-tab-list,ptc-link,ptc-square-card,.hyphenate-text,ptc-footer{hyphens:auto;-webkit-hyphenate-limit-before:3;-webkit-hyphenate-limit-after:3;hyphenate-limit-chars:12 3 3;hyphenate-limit-lines:2;hyphenate-limit-last:always;hyphenate-limit-zone:6%;-webkit-hyphens:auto;-webkit-hyphenate-limit-before:3;-webkit-hyphenate-limit-after:3;-webkit-hyphenate-limit-chars:12 3 3;-webkit-hyphenate-limit-lines:2;-moz-hyphens:auto;-moz-hyphenate-limit-chars:12 3 3;-moz-hyphenate-limit-lines:2;-ms-hyphens:auto;-ms-hyphenate-limit-chars:12 3 3;-ms-hyphenate-limit-lines:2}}.smart-bg{width:100%;height:100%;background-size:cover;background-repeat:no-repeat;background-position:50% 50%}.smart-img{position:absolute;display:block;width:100%;height:100%;top:0;left:0;background-size:cover;background-repeat:no-repeat;background-position:50% 50%}.radius-standard{border-radius:var(--ptc-border-radius-standard)}.radius-standard-top{border-top-left-radius:var(--ptc-border-radius-standard);border-top-right-radius:var(--ptc-border-radius-standard)}.radius-large{border-radius:var(--ptc-border-radius-large)}.radius-large-top{border-top-left-radius:var(--ptc-border-radius-large);border-top-right-radius:var(--ptc-border-radius-large)}.lazy-bg{background-image:none !important;background-color:var(--color-gray-03)}@media only screen and (min-width: 768px){.hidden-xs{display:none !important}}@media (min-width: 768px) and (max-width: 991px){.hidden-sm{display:none !important}}@media (min-width: 992px) and (max-width: 1199px){.hidden-md{display:none !important}}@media only screen and (min-width: 768px){.hidden-lg{display:none !important}}";
9
+
10
+ const PtcImg = class {
11
+ constructor(hostRef) {
12
+ index.registerInstance(this, hostRef);
13
+ this.sizeXs = '510x340';
14
+ this.sizeSm = '1240x496';
15
+ this.sizeMd = '1366x500';
16
+ this.sizeLg = '1920x1080';
17
+ this.imgUrl = undefined;
18
+ this.imageType = 'smart-bg';
19
+ this.borderRadius = '';
20
+ this.loadMode = 'lazy-bg';
21
+ this.styles = undefined;
22
+ }
23
+ /**
24
+ * Image Z Index
25
+ */
26
+ // @Prop() imageZIndex: 'z-index-auto' | 'z-index-n-2' | 'z-index-n-1' | 'z-index-p-1' | 'z-index-p-2' = 'z-index-auto';
27
+ WindowResize() {
28
+ this.setResponsiveBg();
29
+ }
30
+ render() {
31
+ const classMap = this.getCssClassMap();
32
+ return (index.h(index.Host, null, this.styles && index.h("style", null, this.styles), index.h("div", { class: classMap, "data-xs": `${this.imgUrl}`, "data-sm": `${this.imgUrl}`, "data-md": `${this.imgUrl}`, "data-lg": `${this.imgUrl}` }, this.imageType == 'smart-bg' ? index.h("slot", null) : null)));
33
+ }
34
+ componentDidLoad() {
35
+ this.addIntersectionObserver();
36
+ this.setResponsiveBg();
37
+ }
38
+ componentWillUpdate() {
39
+ this.addIntersectionObserver();
40
+ this.setResponsiveBg();
41
+ }
42
+ //responsive image
43
+ setResponsiveBg() {
44
+ // Define local variables
45
+ let backgrounds = (this.el || document).querySelectorAll(interfaces.ResponsiveBgVariables.selector), el, elData, currentBreakpoint = this.getCurrentBreakPoints();
46
+ // Loop through all target elements
47
+ for (var i = 0, len = backgrounds.length; i < len; i++) {
48
+ // Set current variables
49
+ el = backgrounds[i];
50
+ elData = el.getAttribute('data-' + currentBreakpoint);
51
+ // If the data attribute exists, set the background
52
+ if (elData !== null) {
53
+ el.style.backgroundImage = "url('" + elData + "')";
54
+ }
55
+ else {
56
+ if (typeof console == 'object') {
57
+ console.warn('Data attribute: data-' + currentBreakpoint + ' not found on element:\n\n' + el.outerHTML + '\n\n\n');
58
+ }
59
+ }
60
+ }
61
+ }
62
+ //lazy loading
63
+ addIntersectionObserver() {
64
+ if (!this.imgUrl) {
65
+ console.log('no image!');
66
+ return;
67
+ }
68
+ if ('IntersectionObserver' in window) {
69
+ let lazyLoadBgs = (this.el || document).querySelectorAll('.lazy-bg');
70
+ let bgObserver = new IntersectionObserver(entries => {
71
+ entries.forEach(entry => {
72
+ if (entry.isIntersecting) {
73
+ const image = entry.target;
74
+ image.classList.remove('lazy-bg');
75
+ bgObserver.unobserve(image);
76
+ }
77
+ });
78
+ });
79
+ lazyLoadBgs.forEach(image => {
80
+ bgObserver.observe(image);
81
+ });
82
+ }
83
+ }
84
+ getCssClassMap() {
85
+ return {
86
+ [this.imageType]: true,
87
+ 'ptc-img': true,
88
+ [this.borderRadius]: true,
89
+ [this.loadMode]: true,
90
+ // [this.imageZIndex] : true
91
+ };
92
+ }
93
+ getCurrentBreakPoints() {
94
+ // Define local variables
95
+ let doc = window.document, temp = doc.createElement('div'), env;
96
+ // Append test node
97
+ doc.body.appendChild(temp);
98
+ // Loop through breakpoints
99
+ for (let i = interfaces.ResponsiveBgVariables.envs.length - 1; i >= 0; i--) {
100
+ env = interfaces.ResponsiveBgVariables.envs[i];
101
+ // Add classes
102
+ temp.className = 'hidden-' + env;
103
+ // Found breakpoint
104
+ if (temp.offsetParent === null) {
105
+ // Remove our test node
106
+ doc.body.removeChild(temp);
107
+ // Return current breakpoint
108
+ return env;
109
+ }
110
+ }
111
+ // Breakpoint not found, try fallback
112
+ doc.body.removeChild(temp);
113
+ return this.getFallbackBreakpoint();
114
+ }
115
+ getFallbackBreakpoint() {
116
+ if (window.matchMedia('(min-width: 992px)').matches) {
117
+ return 'lg';
118
+ }
119
+ else if (window.matchMedia('(min-width: 768px)').matches) {
120
+ return 'md';
121
+ }
122
+ else if (window.matchMedia('(min-width: 576px)').matches) {
123
+ return 'sm';
124
+ }
125
+ else {
126
+ return 'xs';
127
+ }
128
+ }
129
+ get el() { return index.getElement(this); }
130
+ };
131
+ PtcImg.style = ptcImgCss;
132
+
133
+ exports.ptc_img = PtcImg;
@@ -0,0 +1,87 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-63ddc79c.js');
6
+ const utils = require('./utils-ad441b07.js');
7
+
8
+ const ptcLinkCss = "h1,h2,h3,h4,h5,h6,p,ul,li,ptc-subnav,ptc-tab-list,ptc-link,ptc-square-card,.hyphenate-text,ptc-footer{word-break:break-word;hyphens:manual;-webkit-hyphens:manual;-moz-hyphens:manual;-ms-hyphens:manual}@supports (hyphenate-limit-chars: 12 3 3){h1,h2,h3,h4,h5,h6,p,ul,li,ptc-subnav,ptc-tab-list,ptc-link,ptc-square-card,.hyphenate-text,ptc-footer{hyphens:auto;-webkit-hyphenate-limit-before:3;-webkit-hyphenate-limit-after:3;hyphenate-limit-chars:12 3 3;hyphenate-limit-lines:2;hyphenate-limit-last:always;hyphenate-limit-zone:6%;-webkit-hyphens:auto;-webkit-hyphenate-limit-before:3;-webkit-hyphenate-limit-after:3;-webkit-hyphenate-limit-chars:12 3 3;-webkit-hyphenate-limit-lines:2;-moz-hyphens:auto;-moz-hyphenate-limit-chars:12 3 3;-moz-hyphenate-limit-lines:2;-ms-hyphens:auto;-ms-hyphenate-limit-chars:12 3 3;-ms-hyphenate-limit-lines:2}}:host{display:block}.disabled{pointer-events:none;cursor:default;text-decoration:none}.ptc-link{display:inline-block;color:var(--color-gray-10);font-weight:var(--ptc-font-weight-extrabold);position:relative;line-height:var(--ptc-line-height-densest);outline:none;text-decoration:none;transition:color var(--ptc-transition-fast) var(--ptc-ease-inout)}.ptc-link.focus-state-dark-background{border:2px solid transparent;margin:-2px}.ptc-link:active{transition:none}.ptc-link:focus-visible{border-radius:var(--ptc-border-radius-standard);outline:5px solid var(--keyboard-nav-outline)}.ptc-link:focus-visible .focus-state-dark-background:focus-visible{border-radius:var(--ptc-border-radius-standard);border:2px solid white;outline:5px solid var(--keyboard-nav-outline);transition:none;text-decoration-line:none}.simple{text-decoration:underline;text-underline-offset:5px;text-decoration-color:var(--color-green-06);text-decoration-thickness:2px;transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.simple.focus-state-dark-background{border:2px solid transparent;margin:-2px}.simple:hover{color:var(--color-green-06);transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.simple:active{transition:none}.simple:focus-visible{border-radius:var(--ptc-border-radius-standard);outline:5px solid var(--keyboard-nav-outline);transition:none;color:var(--color-green-06);transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.simple:focus-visible.focus-state-dark-background{border-radius:var(--ptc-border-radius-standard);border:2px solid white;outline:5px solid var(--keyboard-nav-outline);transition:none;text-decoration-line:none}.global{font-style:var(--ptc-letter-spacing-normal);font-weight:var(--ptc-font-weight-bold);font-size:var(--ptc-font-size-x-small);text-decoration-line:underline;color:var(--color-hyperlink);transition:color var(--ptc-transition-medium) var(--ptc-ease-out)}.global:visited{color:var(--color-blue-10)}.global:active,.global:visited:active{color:var(--color-blue-09);transition:none}.global:hover,.global:visited:hover{color:var(--color-blue-08)}.global.disabled{color:var(--color-gray-04) !important;cursor:not-allowed}.product-link{font-weight:var(--ptc-font-weight-extrabold);text-decoration:underline;text-underline-offset:5px;text-decoration-color:var(--color-green-06);text-decoration-thickness:2px;transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.product-link:hover{color:var(--color-green-06);transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.product-link:active{transition:none}.underline{border-bottom:2px solid var(--color-green-06)}.underline:hover{color:#00890B;border-bottom:2px solid #00890B}.underline:active{transition:none}.small{font-size:var(--ptc-font-size-xx-small)}.medium{font-size:var(--ptc-font-size-x-small)}.medium-large{font-size:var(--ptc-font-size-small)}.large{font-size:var(--ptc-font-size-medium)}.nav-title:focus,.nav-title-link:focus,.nav-card-link:focus,.primary-nav-link:focus,.secondary-nav-link:focus,.footer-nav-link:focus,.copyright-link:focus{outline:3px solid var(--color-blue-07);outline-offset:2px}.nav-title:active,.nav-title-link:active,.nav-card-link:active,.primary-nav-link:active,.secondary-nav-link:active,.footer-nav-link:active,.copyright-link:active{transition:none}.nav-title{box-sizing:border-box;color:var(--color-white);display:inline-block;font-size:var(--ptc-font-size-x-small);font-stretch:100%;font-weight:var(--ptc-font-weight-extrabold);letter-spacing:var(--ptc-letter-spacing-normal);line-height:var(--ptc-line-height-dense);list-style:none;margin-bottom:var(--ptc-element-spacing-02);text-align:left}.primary-nav-link{background-color:transparent;box-sizing:border-box;color:var(--color-gray-01);display:inline-block;font-size:var(--ptc-font-size-x-small);font-stretch:100%;font-weight:var(--ptc-font-weight-extrabold);letter-spacing:var(--ptc-letter-spacing-normal);line-height:var(--ptc-line-height-dense);list-style:none;margin:var(--ptc-element-spacing-01) var(--ptc-element-spacing-03);padding:var(--ptc-element-spacing-02) var(--ptc-element-spacing-06);position:relative;text-decoration:none;transition:background-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.primary-nav-link:hover{border-radius:var(--ptc-border-radius-standard);background-color:var(--color-gray-12);text-decoration:none;outline:none}.primary-nav-link:active{transition:none}.nav-title-link{background-color:transparent;box-sizing:border-box;color:var(--color-white);font-size:var(--ptc-font-size-xxx-small);font-stretch:100%;font-weight:var(--ptc-font-weight-extrabold);line-height:var(--ptc-line-height-densest);list-style:none;text-align:left;text-decoration-color:var(--color-white);text-decoration:none;transition:border-color var(--ptc-transition-medium) var(--ptc-ease-inout);border-bottom:1.5px solid transparent;display:inline-block}.nav-title-link:hover{color:var(--color-white);border-bottom:1.5px solid var(--color-green-06)}.nav-title-link:active{transition:none}.nav-card-link{background-color:transparent;box-sizing:border-box;color:var(--color-white);font-stretch:100%;font-weight:var(--ptc-font-weight-extrabold);line-height:var(--ptc-line-height-densest);list-style:none;text-align:left;text-decoration:none;text-decoration-color:var(--color-white);transition:border-color var(--ptc-transition-medium) var(--ptc-ease-inout);display:inline-block;font-size:var(--ptc-font-size-small)}@media only screen and (min-width: 1200px){.nav-card-link{font-size:var(--ptc-font-size-xxx-small)}}.nav-card-link:hover{color:var(--color-white);text-decoration:underline var(--color-green-06) solid 1px;text-underline-offset:2px}.nav-card-link:active{transition:none}.secondary-nav-link{display:inline-block;background-color:transparent;box-sizing:border-box;color:var(--color-white);font-size:var(--ptc-font-size-xxx-small);font-stretch:100%;font-style:normal;font-weight:var(--ptc-font-weight-semibold);letter-spacing:var(--ptc-letter-spacing-normal);line-height:var(--ptc-line-height-densest);list-style:none;margin-bottom:var(--ptc-element-spacing-03);text-align:left;text-decoration:none;transition:border-color var(--ptc-transition-medium) var(--ptc-ease-inout);border-bottom:1.5px solid transparent;white-space:nowrap}.secondary-nav-link:hover{color:var(--color-white);border-bottom:1.5px solid var(--color-green-06);border-radius:0;text-decoration:none}.secondary-nav-link:active{transition:none}.footer-nav-link{color:var(--color-white);transition:border var(--ptc-transition-medium) var(--ptc-ease-inout), color var(--ptc-transition-medium) var(--ptc-ease-inout);border-bottom:1px solid transparent;outline:none;text-decoration:none;font-weight:var(--ptc-font-weight-semibold);letter-spacing:var(--ptc-letter-spacing-normal);line-height:var(--ptc-line-height-densest);text-align:left;font-size:var(--ptc-font-size-x-small)}.footer-nav-link:hover{outline:none;text-decoration:none;border-bottom:0.1rem solid var(--color-green-06);color:var(--color-green-06)}.footer-nav-link:active{transition:none}.copyright-link{color:var(--color-white);font-size:var(--ptc-font-size-xx-small);font-weight:var(--ptc-font-weight-normal);line-height:var(--ptc-line-height-loose);display:inline-block}.d-green-underline{color:var(--color-white);font-weight:var(--ptc-font-weight-extrabold);line-height:var(--ptc-line-height-densest);text-decoration:underline;text-decoration-thickness:2px;text-decoration-color:var(--color-green-06);text-underline-offset:5px;transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.d-green-underline:hover{color:var(--color-green-06)}.d-green-underline:active{transition:none}.d-green-underline:focus-visible{border-radius:var(--ptc-border-radius-standard);outline:5px solid var(--keyboard-nav-outline);transition:none;transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.d-green-underline:focus-visible.focus-state-dark-background{border-radius:var(--ptc-border-radius-standard);border:2px solid white;outline:5px solid var(--keyboard-nav-outline);transition:none;text-decoration-line:none}.d-white-underline{color:var(--color-white);font-weight:var(--ptc-font-weight-extrabold);line-height:var(--ptc-line-height-densest);text-decoration:underline;text-decoration-thickness:2px;text-decoration-color:var(--color-white);text-underline-offset:5px}.link-area-cover-parent{position:static}.link-area-cover-parent::after{content:\"\";position:absolute;width:100%;height:100%;inset:0;z-index:2}.standard-link,.blog-link{font-weight:800;line-height:1;display:flex;align-items:center;color:var(--color-gray-10);text-decoration:underline;text-decoration-thickness:2px;text-decoration-color:var(--color-green-06);text-underline-offset:5px;transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.standard-link:hover,.blog-link:hover{color:var(--color-green-06)}.standard-link:active,.blog-link:active{transition:none}.w-thin{font-weight:var(--ptc-font-weight-thin)}.w-regular{font-weight:var(--ptc-font-weight-regular)}.w-medium{font-weight:var(--ptc-font-weight-medium)}.w-semibold{font-weight:var(--ptc-font-weight-semibold)}.w-bold{font-weight:var(--ptc-font-weight-bold)}.w-extrabold{font-weight:var(--ptc-font-weight-extrabold)}.w-black{font-weight:var(--ptc-font-weight-black)}.utility-nav-link{background-color:transparent;box-sizing:border-box;color:var(--color-gray-13);font-stretch:100%;font-weight:var(--ptc-font-weight-semibold);line-height:var(--ptc-line-height-densest);list-style:none;text-align:left;text-decoration:none;text-decoration-color:var(--color-green-06);transition:border-color var(--ptc-transition-medium) var(--ptc-ease-inout);display:inline-block;font-size:var(--ptc-font-size-x-small)}.utility-nav-link:hover{text-decoration:underline;text-underline-offset:5px;text-decoration-color:var(--color-green-06);text-decoration-thickness:2px;transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}.utility-nav-link:active{transition:none}.tracker-div{display:inline}:host(.event-podcast) a{color:var(--color-green-06);transition:text-decoration-color var(--ptc-transition-medium) var(--ptc-ease-inout)}";
9
+
10
+ const PtcLink = class {
11
+ constructor(hostRef) {
12
+ index.registerInstance(this, hostRef);
13
+ this.disabled = false;
14
+ this.external = false;
15
+ this.href = undefined;
16
+ this.target = '_self';
17
+ this.linkTitle = undefined;
18
+ this.theme = 'simple';
19
+ this.fontSize = 'medium';
20
+ this.fontWeight = undefined;
21
+ this.linkArea = undefined;
22
+ this.seoCompatibilityMode = false;
23
+ this.styles = undefined;
24
+ this.trackerId = undefined;
25
+ this.tabNav = 0;
26
+ this.darkFocusState = false;
27
+ }
28
+ componentWillLoad() {
29
+ utils.CheckDarkFocusState(this, this.el);
30
+ }
31
+ seoCompRender() {
32
+ const classMap = this.getCssClassMap();
33
+ const [TagType, firstChild] = utils.getSeoTagType(this.el, "a");
34
+ const html = firstChild && firstChild.innerHTML;
35
+ if (this.el == firstChild) {
36
+ this.el.innerHTML = '';
37
+ }
38
+ return (index.h(index.Host, null, this.styles && index.h("style", null, this.styles), index.h("div", { id: this.trackerId, class: "tracker-div mf-listen" }, index.h(TagType, Object.assign({ class: classMap, innerHTML: html, href: this.href, target: this.external ? '_blank' : this.target, title: this.linkTitle }, (!!this.tabNav ? { tabindex: -1 } : { tabindex: 0 })), index.h("slot", null)))));
39
+ }
40
+ standardRender() {
41
+ const classMap = this.getCssClassMap();
42
+ return (index.h(index.Host, null, this.styles && index.h("style", null, this.styles), index.h("div", { id: this.trackerId, class: "tracker-div mf-listen" }, index.h("a", Object.assign({ class: classMap, href: this.href, target: this.external ? '_blank' : this.target, title: this.linkTitle }, (!!this.tabNav ? { tabindex: -1 } : { tabindex: 0 })), index.h("slot", null)))));
43
+ }
44
+ render() {
45
+ if (this.seoCompatibilityMode) {
46
+ return this.seoCompRender();
47
+ }
48
+ else {
49
+ return this.standardRender();
50
+ }
51
+ }
52
+ getCssClassMap() {
53
+ const classOptions = [
54
+ 'simple',
55
+ 'underline',
56
+ 'nav-title',
57
+ 'primary-nav-link',
58
+ 'nav-title-link',
59
+ 'nav-card-link',
60
+ 'secondary-nav-link',
61
+ 'footer-nav-link',
62
+ 'copyright-link',
63
+ 'product-link',
64
+ 'd-green-underline',
65
+ 'd-white-underline',
66
+ 'global',
67
+ 'utility-nav-link'
68
+ ];
69
+ let mainClass = this.theme;
70
+ if (classOptions.indexOf(mainClass) < 0) {
71
+ mainClass = 'simple'; // fallback to simple class if theme is unavailable
72
+ }
73
+ return {
74
+ ['ptc-link']: true,
75
+ [mainClass]: true,
76
+ ['disabled']: this.disabled,
77
+ [this.fontSize]: true,
78
+ [this.linkArea]: this.linkArea ? true : false,
79
+ [this.fontWeight]: this.fontWeight ? true : false,
80
+ ['focus-state-dark-background']: this.darkFocusState
81
+ };
82
+ }
83
+ get el() { return index.getElement(this); }
84
+ };
85
+ PtcLink.style = ptcLinkCss;
86
+
87
+ exports.ptc_link = PtcLink;
@@ -0,0 +1,127 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-63ddc79c.js');
6
+ const utils = require('./utils-ad441b07.js');
7
+
8
+ const ptcParaCss = "h1,h2,h3,h4,h5,h6,p,ul,li,ptc-subnav,ptc-tab-list,ptc-link,ptc-square-card,.hyphenate-text,ptc-footer{word-break:break-word;hyphens:manual;-webkit-hyphens:manual;-moz-hyphens:manual;-ms-hyphens:manual}@supports (hyphenate-limit-chars: 12 3 3){h1,h2,h3,h4,h5,h6,p,ul,li,ptc-subnav,ptc-tab-list,ptc-link,ptc-square-card,.hyphenate-text,ptc-footer{hyphens:auto;-webkit-hyphenate-limit-before:3;-webkit-hyphenate-limit-after:3;hyphenate-limit-chars:12 3 3;hyphenate-limit-lines:2;hyphenate-limit-last:always;hyphenate-limit-zone:6%;-webkit-hyphens:auto;-webkit-hyphenate-limit-before:3;-webkit-hyphenate-limit-after:3;-webkit-hyphenate-limit-chars:12 3 3;-webkit-hyphenate-limit-lines:2;-moz-hyphens:auto;-moz-hyphenate-limit-chars:12 3 3;-moz-hyphenate-limit-lines:2;-ms-hyphens:auto;-ms-hyphenate-limit-chars:12 3 3;-ms-hyphenate-limit-lines:2}}:host{position:relative;z-index:1}:host .tooltip-enabled{position:relative}:host(.white){color:var(--color-white)}:host(.z-1){z-index:1}:host(.z-2){z-index:2}:host(.z-3){z-index:3}:host(.z-99){z-index:99}:host(.z-999){z-index:999}:host(.z-auto){z-index:auto}p.default{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;}p.main{text-shadow:0 3px 6px var(--color-white);line-height:var(--ptc-line-height-dense);color:var(--color-gray-10)}p.primary-grey{color:var(--color-gray-10)}p.primary-green{color:var(--color-green-06)}p.gray-darker{color:var(--color-gray-11)}p.white{color:var(--color-white)}p.xxx-small{font-size:var(--ptc-font-size-xxx-small)}p.xx-small{font-size:var(--ptc-font-size-xx-small)}p.x-small{font-size:var(--ptc-font-size-x-small)}p.small{font-size:var(--ptc-font-size-small)}p.medium{font-size:var(--ptc-font-size-medium)}p.large{font-size:var(--ptc-font-size-large)}p.x-large{font-size:var(--ptc-font-size-x-large)}p.xx-large{font-size:var(--ptc-font-size-xx-large)}p.xxx-large{font-size:var(--ptc-font-size-xxx-large)}p.xxxx-large{font-size:var(--ptc-font-size-xxxx-large)}p.htmlquote-para{font-size:var(--ptc-font-size-small)}@media only screen and (min-width: 992px){p.htmlquote-para{font-size:var(--ptc-font-size-large)}}p.w-3{font-weight:var(--ptc-font-weight-thin)}p.w-4{font-weight:var(--ptc-font-weight-regular)}p.w-5{font-weight:var(--ptc-font-weight-medium)}p.w-6{font-weight:var(--ptc-font-weight-semibold)}p.w-7{font-weight:var(--ptc-font-weight-bold)}p.w-8{font-weight:var(--ptc-font-weight-extrabold)}p.w-8 ::slotted(a){font-weight:var(--ptc-font-weight-extrabold) !important}p.w-9{font-weight:var(--ptc-font-weight-black)}p.w-9 ::slotted(a){font-weight:var(--ptc-font-weight-black) !important}p.margin-flush{margin-top:0;margin-bottom:0}p.margin-top-1{margin-top:var(--ptc-element-spacing-01);margin-bottom:0}p.margin-top-2{margin-top:var(--ptc-element-spacing-02);margin-bottom:0}p.margin-top-3{margin-top:var(--ptc-element-spacing-03);margin-bottom:0}p.margin-top-4{margin-top:var(--ptc-element-spacing-04);margin-bottom:0}p.margin-top-5{margin-top:var(--ptc-element-spacing-05);margin-bottom:0}p.margin-top-6{margin-top:var(--ptc-element-spacing-06);margin-bottom:0}p.margin-bottom-1{margin-bottom:var(--ptc-element-spacing-01);margin-top:0}p.margin-bottom-2{margin-bottom:var(--ptc-element-spacing-02);margin-top:0}p.margin-bottom-3{margin-bottom:var(--ptc-element-spacing-03);margin-top:0}p.margin-bottom-4{margin-bottom:var(--ptc-element-spacing-04);margin-top:0}p.margin-bottom-5{margin-bottom:var(--ptc-element-spacing-05);margin-top:0}p.margin-bottom-6{margin-bottom:var(--ptc-element-spacing-06);margin-top:0}p.margin-1{margin-top:var(--ptc-element-spacing-01);margin-bottom:var(--ptc-element-spacing-01)}p.margin-2{margin-top:var(--ptc-element-spacing-02);margin-bottom:var(--ptc-element-spacing-02)}p.margin-3{margin-top:var(--ptc-element-spacing-03);margin-bottom:var(--ptc-element-spacing-03)}p.margin-4{margin-top:var(--ptc-element-spacing-04);margin-bottom:var(--ptc-element-spacing-04)}p.margin-5{margin-top:var(--ptc-element-spacing-05);margin-bottom:var(--ptc-element-spacing-05)}p.margin-6{margin-top:var(--ptc-element-spacing-06);margin-bottom:var(--ptc-element-spacing-06)}p.line-height-densest{line-height:var(--ptc-line-height-densest)}p.line-height-denser{line-height:var(--ptc-line-height-denser)}p.line-height-p{line-height:var(--ptc-line-height-p)}p.line-height-dense{line-height:var(--ptc-line-height-dense)}p.line-height-normal{line-height:var(--ptc-line-height-normal)}p.line-height-loose{line-height:var(--ptc-line-height-loose)}p.line-height-looser{line-height:var(--ptc-line-height-looser)}p.left{text-align:left}p.right{text-align:right}p.center{text-align:center}p.justify{text-align:justify}p.announcement{text-transform:uppercase;font-size:var(--ptc-font-size-small);color:var(--color-gray-07);line-height:var(--ptc-line-height-looser);letter-spacing:var(--ptc-letter-spacing-loose)}p.ellipsis-boxing{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;overflow-wrap:break-word}p.line-clamp-title{display:-webkit-box !important;-webkit-box-orient:vertical;overflow:hidden}@media (max-width: 768px){:host(.hide-tooltip-on-mobile) .line-clamp-title{-webkit-line-clamp:initial !important}}";
9
+
10
+ const PtcPara = class {
11
+ constructor(hostRef) {
12
+ index.registerInstance(this, hostRef);
13
+ this.fontSize = 'x-small';
14
+ this.fontWeight = 'w-4';
15
+ this.paraStyle = 'default';
16
+ this.paraColor = 'primary-grey';
17
+ this.paraLineH = 'line-height-normal';
18
+ this.paraMargin = undefined;
19
+ this.paraAlign = undefined;
20
+ this.ellipsisLineCutoff = undefined;
21
+ this.paraZIndex = undefined;
22
+ this.styles = undefined;
23
+ this.seoCompatibilityMode = false;
24
+ this.tooltipZIndex = 'auto';
25
+ this.tooltipPosition = 'bottom';
26
+ this.tooltipTheme = 'standard';
27
+ this.enableTooltip = false;
28
+ this.maxChars = undefined;
29
+ this.maxLines = undefined;
30
+ this.hideTooltipOnMobile = false;
31
+ this.ismob = undefined;
32
+ this.noOverflow = false;
33
+ this.tooltipWidth = 'default';
34
+ }
35
+ // Tooltip Properties ends
36
+ render() {
37
+ if (this.seoCompatibilityMode) {
38
+ utils.seoSlotReset(this.el);
39
+ }
40
+ return this.standardRender();
41
+ }
42
+ //tooltip code
43
+ getSortedText(content) {
44
+ if (!this.enableTooltip)
45
+ return;
46
+ const trimmedContent = content.trim();
47
+ const shouldTruncate = (trimmedContent.length > this.maxChars) && !this.maxLines;
48
+ return shouldTruncate ? `${trimmedContent.slice(0, this.maxChars).trimEnd()}\u00A0\u2026` : trimmedContent;
49
+ }
50
+ componentDidLoad() {
51
+ if (this.hideTooltipOnMobile) {
52
+ this.el.classList.add('hide-tooltip-on-mobile');
53
+ }
54
+ this.el.addEventListener('mouseenter', () => { this.toggleTitleTooltip(true); });
55
+ this.el.addEventListener('mouseleave', () => { this.toggleTitleTooltip(false); });
56
+ if (this.enableTooltip) {
57
+ let paraContent = this.el.innerText || this.el.textContent;
58
+ this.tooltipText = paraContent.trim();
59
+ this.el.innerText = this.getSortedText(paraContent);
60
+ }
61
+ }
62
+ toggleTitleTooltip(show) {
63
+ const tooltipClass = 'tooltip-box';
64
+ const existingTooltip = this.el.querySelector(`.${tooltipClass}`);
65
+ const text = this.el.shadowRoot.querySelectorAll('.line-clamp-title');
66
+ let maxLinesShowCheck = false;
67
+ if (text) {
68
+ text.forEach(t => {
69
+ maxLinesShowCheck = t.scrollHeight > t.clientHeight;
70
+ });
71
+ }
72
+ const ifCharExceeds = this.maxChars ? (this.tooltipText.length > this.maxChars) && !this.maxLines : false;
73
+ const ifLinesExceeds = this.maxLines && maxLinesShowCheck;
74
+ if (show && this.enableTooltip) {
75
+ if (((!existingTooltip && ifCharExceeds) || (!existingTooltip && ifLinesExceeds)) && !this.noOverflow) {
76
+ const tooltipMarkup = document.createElement('div');
77
+ tooltipMarkup.className = tooltipClass;
78
+ tooltipMarkup.innerText = this.tooltipText;
79
+ tooltipMarkup.style.zIndex = String(this.tooltipZIndex); // Ensures zIndex is a string
80
+ tooltipMarkup.classList.add(this.tooltipPosition, this.tooltipTheme, this.tooltipWidth);
81
+ if (this.hideTooltipOnMobile) {
82
+ tooltipMarkup.classList.add('hide-tooltip-mobile');
83
+ }
84
+ this.el.appendChild(tooltipMarkup);
85
+ }
86
+ }
87
+ else {
88
+ existingTooltip === null || existingTooltip === void 0 ? void 0 : existingTooltip.remove();
89
+ }
90
+ }
91
+ //tooltip code ends
92
+ standardRender() {
93
+ const classMap = this.getCssClassMap();
94
+ const colorClass = this.addWhiteClass();
95
+ const cutOff = this.getLineCuttoff();
96
+ return (index.h(index.Host, { class: `${colorClass} ${this.paraZIndex} trunc-text` }, this.styles && index.h("style", null, this.styles), index.h("p", { class: classMap, part: "part-para", style: cutOff }, index.h("slot", null))));
97
+ }
98
+ getCssClassMap() {
99
+ return {
100
+ [this.fontSize]: true,
101
+ [this.fontWeight]: true,
102
+ [this.paraStyle]: true,
103
+ [this.paraMargin]: !!this.paraMargin ? true : false,
104
+ [this.paraColor]: true,
105
+ [this.paraLineH]: true,
106
+ [this.paraAlign]: !!this.paraAlign ? true : false,
107
+ ['ellipsis-boxing']: this.ellipsisLineCutoff && this.ellipsisLineCutoff > 0,
108
+ ['line-clamp-title']: this.maxLines && this.maxLines > 0, //tooltip code,
109
+ };
110
+ }
111
+ //WEB-2392
112
+ addWhiteClass() {
113
+ if (this.paraColor == 'white') {
114
+ return {
115
+ [this.paraColor]: true,
116
+ };
117
+ }
118
+ }
119
+ getLineCuttoff() {
120
+ const lineClamp = this.ellipsisLineCutoff > 0 ? this.ellipsisLineCutoff : this.maxLines;
121
+ return lineClamp > 0 ? { '-webkit-line-clamp': `${lineClamp}` } : {};
122
+ }
123
+ get el() { return index.getElement(this); }
124
+ };
125
+ PtcPara.style = ptcParaCss;
126
+
127
+ exports.ptc_para = PtcPara;
@@ -0,0 +1,136 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-63ddc79c.js');
6
+
7
+ const ptcScrollButtonCss = "h1,h2,h3,h4,h5,h6,p,ul,li,ptc-subnav,ptc-tab-list,ptc-link,ptc-square-card,.hyphenate-text,ptc-footer{word-break:break-word;hyphens:manual;-webkit-hyphens:manual;-moz-hyphens:manual;-ms-hyphens:manual}@supports (hyphenate-limit-chars: 12 3 3){h1,h2,h3,h4,h5,h6,p,ul,li,ptc-subnav,ptc-tab-list,ptc-link,ptc-square-card,.hyphenate-text,ptc-footer{hyphens:auto;-webkit-hyphenate-limit-before:3;-webkit-hyphenate-limit-after:3;hyphenate-limit-chars:12 3 3;hyphenate-limit-lines:2;hyphenate-limit-last:always;hyphenate-limit-zone:6%;-webkit-hyphens:auto;-webkit-hyphenate-limit-before:3;-webkit-hyphenate-limit-after:3;-webkit-hyphenate-limit-chars:12 3 3;-webkit-hyphenate-limit-lines:2;-moz-hyphens:auto;-moz-hyphenate-limit-chars:12 3 3;-moz-hyphenate-limit-lines:2;-ms-hyphens:auto;-ms-hyphenate-limit-chars:12 3 3;-ms-hyphenate-limit-lines:2}}:host{display:block}.scroll-btn{position:absolute;top:50%;transform:translate(0%, -50%);display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:0px 4px 4px 0px;background:var(--color-gray-12);box-shadow:var(--ptc-shadow-medium);width:36px;height:36px;padding:var(--ptc-element-spacing-02)}.scroll-btn.left{left:0%}.scroll-btn.right{left:100%;transform:translate(-100%, -50%)}.scroll-btn:focus{outline:none}.scroll-btn[tabIndex=\"0\"]:focus-visible{border-radius:var(--ptc-border-radius-standard);outline:5px solid var(--keyboard-nav-outline)}.scroll-btn icon-asset{width:20px;height:20px}";
8
+
9
+ const PtcScrollButton = class {
10
+ constructor(hostRef) {
11
+ index.registerInstance(this, hostRef);
12
+ //slider!: HTMLElement;
13
+ this.startX = 0;
14
+ this.scrollLeft = 0;
15
+ this.startDragging = (e) => {
16
+ this.isMouseDown = true;
17
+ this.isDragging = false;
18
+ this.containerCards.forEach((card) => {
19
+ card.disabled = false;
20
+ });
21
+ this.startX = e.pageX;
22
+ this.scrollLeft = this.scrollContainer.scrollLeft;
23
+ };
24
+ this.performDragging = (e) => {
25
+ if (!this.isMouseDown)
26
+ return;
27
+ const x = e.pageX - this.scrollContainer.offsetLeft;
28
+ const walk = x - this.startX;
29
+ this.isDragging = Math.abs(walk) > 5;
30
+ this.scrollContainer.scrollLeft = this.scrollLeft - walk;
31
+ this.containerCards.forEach((card) => {
32
+ card.disabled = true;
33
+ });
34
+ };
35
+ this.stopDragging = () => {
36
+ this.isMouseDown = false;
37
+ this.containerCards.forEach((card) => {
38
+ card.disabled = false;
39
+ });
40
+ };
41
+ this.handleScroll = () => {
42
+ this.updateVisibility();
43
+ };
44
+ this.handleClick = () => {
45
+ if (!this.scrollContainer)
46
+ return;
47
+ const scrollValue = this.scrollAmount * (this.direction === 'left' || this.direction === 'up' ? -1 : 1);
48
+ if (this.orientation === 'horizontal') {
49
+ console.log('hello, left/right scroll click!');
50
+ this.scrollContainer.scrollBy({
51
+ left: scrollValue,
52
+ behavior: 'smooth',
53
+ });
54
+ }
55
+ else if (this.orientation === 'vertical') {
56
+ this.scrollContainer.scrollBy({
57
+ top: scrollValue,
58
+ behavior: 'smooth',
59
+ });
60
+ }
61
+ };
62
+ this.direction = undefined;
63
+ this.scrollContainerClass = undefined;
64
+ this.scrollAmount = 100;
65
+ this.orientation = 'horizontal';
66
+ this.trackerId = undefined;
67
+ this.styles = undefined;
68
+ this.isVisible = true;
69
+ this.isDragging = false;
70
+ this.isMouseDown = false;
71
+ }
72
+ componentWillLoad() {
73
+ this.scrollContainer = document.querySelector(`.${this.scrollContainerClass}`);
74
+ if (this.scrollContainer) {
75
+ this.scrollContainer.classList.add('hide-scrollbar');
76
+ this.updateVisibility(); // Initial visibility check
77
+ this.scrollContainer.addEventListener('scroll', this.handleScroll);
78
+ }
79
+ else {
80
+ console.error('scrollContainer ele not found');
81
+ }
82
+ }
83
+ componentDidLoad() {
84
+ this.containerCards = document.querySelectorAll(`.${this.scrollContainerClass} ptc-card-wrapper`);
85
+ if (this.scrollContainer) {
86
+ this.enableDragging();
87
+ }
88
+ }
89
+ disconnectedCallback() {
90
+ if (this.scrollContainer) {
91
+ this.scrollContainer.removeEventListener('scroll', this.handleScroll);
92
+ this.disableDragging();
93
+ }
94
+ }
95
+ async initVisibility() {
96
+ this.updateVisibility();
97
+ }
98
+ enableDragging() {
99
+ this.scrollContainer.addEventListener('mousedown', this.startDragging);
100
+ this.scrollContainer.addEventListener('mousemove', this.performDragging);
101
+ ['mouseup', 'mouseleave'].forEach(event => this.scrollContainer.addEventListener(event, this.stopDragging));
102
+ }
103
+ disableDragging() {
104
+ this.scrollContainer.removeEventListener('mousedown', this.startDragging);
105
+ this.scrollContainer.removeEventListener('mousemove', this.performDragging);
106
+ ['mouseup', 'mouseleave'].forEach(event => this.scrollContainer.removeEventListener(event, this.stopDragging));
107
+ }
108
+ updateVisibility() {
109
+ if (!this.scrollContainer)
110
+ return;
111
+ const { scrollLeft, scrollTop, scrollWidth, scrollHeight, clientWidth, clientHeight } = this.scrollContainer;
112
+ if (this.orientation === 'horizontal') {
113
+ if (this.direction === 'left') {
114
+ this.isVisible = scrollLeft > 0;
115
+ }
116
+ else if (this.direction === 'right') {
117
+ this.isVisible = scrollLeft + clientWidth + 1 < scrollWidth; // "+1" adjustments after adding margin-right 40px
118
+ // console.log('scorllLeft: ' + scrollLeft + ", scrollWidth: " + scrollWidth + ", clientWidth: " + clientWidth);
119
+ }
120
+ }
121
+ else if (this.orientation === 'vertical') {
122
+ if (this.direction === 'up') {
123
+ this.isVisible = scrollTop > 0;
124
+ }
125
+ else if (this.direction === 'down') {
126
+ this.isVisible = scrollTop + clientHeight < scrollHeight;
127
+ }
128
+ }
129
+ }
130
+ render() {
131
+ return (index.h(index.Host, { "is-dragging": this.isDragging }, this.styles && index.h("style", null, this.styles), this.isVisible && (index.h("button", { id: this.trackerId, onClick: this.handleClick, class: `scroll-btn ${this.direction}`, "aria-label": this.direction, tabindex: "0" }, this.direction === 'left' && index.h("icon-asset", { name: "left-scroll-arrow", size: "small", color: "white", type: "ptc", "injected-style": "svg:focus{outline:none;}" }), this.direction === 'right' && index.h("icon-asset", { name: "right-scroll-arrow", size: "small", color: "white", type: "ptc", "injected-style": "svg:focus{outline:none;}" }), this.direction === 'up' && '▲', this.direction === 'down' && '▼'))));
132
+ }
133
+ };
134
+ PtcScrollButton.style = ptcScrollButtonCss;
135
+
136
+ exports.ptc_scroll_button = PtcScrollButton;
@@ -0,0 +1,38 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-63ddc79c.js');
6
+
7
+ const ptcSpacerCss = ":host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;position:relative;display:block;width:12px;min-width:12px;height:12px}@media (min-width: 36em){:host{width:16px;min-width:16px;height:16px}}:host(.ptc-spacer-horizontal){display:inline-block;height:100% !important}:host(.ptc-spacer-horizontal.xx-small){width:4px;min-width:4px;height:100%}@media (min-width: 36em){:host(.ptc-spacer-horizontal.xx-small){width:4px;min-width:4px}}:host(.ptc-spacer-horizontal.x-small){width:4px;min-width:4px;height:100%}@media (min-width: 36em){:host(.ptc-spacer-horizontal.x-small){width:8px;min-width:8px}}:host(.ptc-spacer-horizontal.small){width:8px;min-width:8px;height:100%}@media (min-width: 36em){:host(.ptc-spacer-horizontal.small){width:12px;min-width:12px}}:host(.ptc-spacer-horizontal.medium){height:100%}:host(.ptc-spacer-horizontal.large){width:16px;min-width:16px;height:100%}@media (min-width: 36em){:host(.ptc-spacer-horizontal.large){width:20px;min-width:20px}}:host(.ptc-spacer-horizontal.x-large){width:20px;min-width:20px;height:100%}@media (min-width: 36em){:host(.ptc-spacer-horizontal.x-large){width:28px;min-width:28px}}:host(.ptc-spacer-horizontal.xx-large){width:28px;min-width:28px;height:100%}@media (min-width: 36em){:host(.ptc-spacer-horizontal.xx-large){width:36px;min-width:36px}}:host(.ptc-spacer-horizontal.xxx-large){width:36px;min-width:36px;height:100%}@media (min-width: 36em){:host(.ptc-spacer-horizontal.xxx-large){width:48px;min-width:48px}}:host(.ptc-spacer-horizontal.xxxx-large){width:48px;min-width:48px;height:100%}@media (min-width: 36em){:host(.ptc-spacer-horizontal.xxxx-large){width:72px;min-width:72px}}:host(.ptc-spacer-vertical.xx-small){width:100%;height:4px;min-height:4px}:host(.ptc-spacer-vertical.x-small){width:100%;height:4px;min-height:4px}@media (min-width: 36em){:host(.ptc-spacer-vertical.x-small){height:8px;min-height:8px}}:host(.ptc-spacer-vertical.small){width:100%;height:8px;min-height:8px}@media (min-width: 36em){:host(.ptc-spacer-vertical.small){height:12px;min-height:12px}}:host(.ptc-spacer-vertical.medium){width:100%}:host(.ptc-spacer-vertical.large){width:100%;height:16px;min-height:16px}@media (min-width: 36em){:host(.ptc-spacer-vertical.large){height:20px;min-height:20px}}:host(.ptc-spacer-vertical.x-large){width:100%;height:20px;min-height:20px}@media (min-width: 36em){:host(.ptc-spacer-vertical.x-large){height:28px;min-height:28px}}:host(.ptc-spacer-vertical.xx-large){width:100%;height:28px;min-height:28px}@media (min-width: 36em){:host(.ptc-spacer-vertical.xx-large){height:36px;min-height:36px}}:host(.ptc-spacer-vertical.xxx-large){width:100%;height:36px;min-height:36px}@media (min-width: 36em){:host(.ptc-spacer-vertical.xxx-large){height:48px;min-height:48px}}:host(.ptc-spacer-vertical.xxxx-large){width:100%;height:48px;min-height:48px}@media (min-width: 36em){:host(.ptc-spacer-vertical.xxxx-large){height:72px;min-height:72px}}:host(.ptc-spacer-vertical.space-144){width:100%;height:144px;min-height:144px}:host(.ptc-spacer-vertical.space-120){width:100%;height:120px;min-height:120px}:host(.ptc-spacer-vertical.space-128){width:100%;height:128px;min-height:128px}:host(.ptc-spacer-xx-small){display:none}@media (max-width: 22.5em){:host(.ptc-spacer-xx-small){display:block}}:host(.ptc-spacer-x-small){display:none}@media (max-width: 35.99em){:host(.ptc-spacer-x-small){display:block}}:host(.ptc-spacer-small){display:none}@media (min-width: 36em){:host(.ptc-spacer-small){display:block}}:host(.ptc-spacer-medium){display:none}@media (min-width: 48em){:host(.ptc-spacer-medium){display:block}}:host(.ptc-spacer-large){display:none}@media (min-width: 62em){:host(.ptc-spacer-large){display:block}}:host(.ptc-spacer-x-large){display:none}@media (min-width: 64.0625em){:host(.ptc-spacer-x-large){display:block}}:host(.ptc-spacer-xx-large){display:none}@media (min-width: 75em){:host(.ptc-spacer-xx-large){display:block}}:host(.ptc-spacer-xxx-large){display:none}@media (min-width: 90em){:host(.ptc-spacer-xxx-large){display:block}}";
8
+
9
+ const PtcSpacer = class {
10
+ constructor(hostRef) {
11
+ index.registerInstance(this, hostRef);
12
+ this.breakpoint = '';
13
+ this.size = 'medium';
14
+ this.direction = 'vertical';
15
+ }
16
+ render() {
17
+ const classMap = this.getCssClassMap();
18
+ return (index.h(index.Host, { class: classMap }));
19
+ }
20
+ getCssClassMap() {
21
+ return {
22
+ [this.size]: true,
23
+ ['ptc-spacer-horizontal']: this.direction === 'horizontal',
24
+ ['ptc-spacer-vertical']: this.direction === 'vertical',
25
+ ['ptc-spacer-xx-small']: this.breakpoint === 'xx-small',
26
+ ['ptc-spacer-x-small']: this.breakpoint === 'x-small',
27
+ ['ptc-spacer-small']: this.breakpoint === 'small',
28
+ ['ptc-spacer-medium']: this.breakpoint === 'medium',
29
+ ['ptc-spacer-large']: this.breakpoint === 'large',
30
+ ['ptc-spacer-x-large']: this.breakpoint === 'x-large',
31
+ ['ptc-spacer-xx-large']: this.breakpoint === 'xx-large',
32
+ ['ptc-spacer-xxx-large']: this.breakpoint === 'xxx-large',
33
+ };
34
+ }
35
+ };
36
+ PtcSpacer.style = ptcSpacerCss;
37
+
38
+ exports.ptc_spacer = PtcSpacer;
@@ -25,9 +25,9 @@ const PtcStickyTitle = class {
25
25
  }
26
26
  componentDidLoad() {
27
27
  const shareicon = this.hostEl.querySelectorAll('ptc-social-share');
28
- shareicon.forEach((icon, i) => {
28
+ shareicon.forEach((icon) => {
29
29
  icon.addEventListener('focus', () => {
30
- if (window.scrollY === 0 && i === 0) {
30
+ if (window.scrollY === 0) {
31
31
  window.scrollBy(0, 262);
32
32
  }
33
33
  this.isSticky = true;