@ptcwebops/ptcw-design 0.7.4 → 0.7.6

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 (282) hide show
  1. package/LICENSE +21 -21
  2. package/dist/cjs/dropdown-item.cjs.entry.js +10 -10
  3. package/dist/cjs/icon-asset.cjs.entry.js +54 -54
  4. package/dist/cjs/list-item.cjs.entry.js +19 -19
  5. package/dist/cjs/loader.cjs.js +1 -1
  6. package/dist/cjs/lottie-player.cjs.entry.js +354 -354
  7. package/dist/cjs/my-component.cjs.entry.js +12 -12
  8. package/dist/cjs/ptc-accordion-item.cjs.entry.js +97 -97
  9. package/dist/cjs/ptc-accordion.cjs.entry.js +38 -38
  10. package/dist/cjs/ptc-announcement.cjs.entry.js +63 -38
  11. package/dist/cjs/ptc-breadcrumb.cjs.entry.js +12 -12
  12. package/dist/cjs/ptc-button.cjs.entry.js +65 -65
  13. package/dist/cjs/ptc-card-bottom.cjs.entry.js +31 -31
  14. package/dist/cjs/ptc-card-content.cjs.entry.js +35 -35
  15. package/dist/cjs/ptc-card-plm.cjs.entry.js +16 -16
  16. package/dist/cjs/ptc-card_6.cjs.entry.js +535 -535
  17. package/dist/cjs/ptc-checkbox.cjs.entry.js +31 -31
  18. package/dist/cjs/ptc-collapse-list.cjs.entry.js +335 -335
  19. package/dist/cjs/ptc-container.cjs.entry.js +35 -35
  20. package/dist/cjs/ptc-dropdown.cjs.entry.js +64 -64
  21. package/dist/cjs/ptc-dynamic-card.cjs.entry.js +40 -40
  22. package/dist/cjs/ptc-ellipsis-dropdown.cjs.entry.js +37 -37
  23. package/dist/cjs/ptc-filter-tag.cjs.entry.js +56 -56
  24. package/dist/cjs/ptc-hero-footer-cta.cjs.entry.js +8 -8
  25. package/dist/cjs/ptc-hero.cjs.entry.js +18 -18
  26. package/dist/cjs/ptc-icon-list.cjs.entry.js +32 -32
  27. package/dist/cjs/ptc-icon-minimize.cjs.entry.js +35 -35
  28. package/dist/cjs/ptc-link.cjs.entry.js +42 -42
  29. package/dist/cjs/ptc-list.cjs.entry.js +50 -50
  30. package/dist/cjs/ptc-lottie.cjs.entry.js +12 -12
  31. package/dist/cjs/ptc-minimized-footer.cjs.entry.js +8 -8
  32. package/dist/cjs/ptc-minimized-header.cjs.entry.js +11 -11
  33. package/dist/cjs/ptc-mobile-select.cjs.entry.js +69 -69
  34. package/dist/cjs/ptc-modal.cjs.entry.js +155 -155
  35. package/dist/cjs/ptc-nav-item.cjs.entry.js +83 -83
  36. package/dist/cjs/ptc-nav.cjs.entry.js +8 -8
  37. package/dist/cjs/ptc-overlay.cjs.entry.js +20 -20
  38. package/dist/cjs/ptc-pagenation.cjs.entry.js +105 -105
  39. package/dist/cjs/ptc-previous-url.cjs.entry.js +8 -8
  40. package/dist/cjs/ptc-pricing-block.cjs.entry.js +15 -15
  41. package/dist/cjs/ptc-quote.cjs.entry.js +25 -25
  42. package/dist/cjs/ptc-readmore_2.cjs.entry.js +118 -0
  43. package/dist/cjs/ptc-responsive-wrapper.cjs.entry.js +54 -54
  44. package/dist/cjs/ptc-shopping-cart.cjs.entry.js +49 -49
  45. package/dist/cjs/ptc-social-share.cjs.entry.js +64 -64
  46. package/dist/cjs/ptc-span.cjs.entry.js +23 -23
  47. package/dist/cjs/ptc-svg-btn.cjs.entry.js +75 -75
  48. package/dist/cjs/ptc-tab-list.cjs.entry.js +122 -122
  49. package/dist/cjs/ptc-text-copy-with-background.cjs.entry.js +24 -24
  50. package/dist/cjs/ptc-title.cjs.entry.js +74 -74
  51. package/dist/cjs/ptc-two-column-media.cjs.entry.js +14 -14
  52. package/dist/cjs/ptcw-design.cjs.js +1 -1
  53. package/dist/cjs/tab-content.cjs.entry.js +26 -26
  54. package/dist/cjs/tab-header.cjs.entry.js +43 -43
  55. package/dist/cjs/{utils-2ac2a528.js → utils-5245e89c.js} +79 -79
  56. package/dist/collection/collection-manifest.json +2 -0
  57. package/dist/collection/components/dropdown-item/dropdown-item.js +56 -56
  58. package/dist/collection/components/icon-asset/icon-asset.css +4 -4
  59. package/dist/collection/components/icon-asset/icon-asset.js +217 -217
  60. package/dist/collection/components/icon-asset/media/brands.svg +1381 -1381
  61. package/dist/collection/components/icon-asset/media/designer.svg +379 -368
  62. package/dist/collection/components/icon-asset/media/regular.svg +463 -463
  63. package/dist/collection/components/icon-asset/media/solid.svg +3013 -3013
  64. package/dist/collection/components/icon-asset/media/svg-with-js.min.css +4 -4
  65. package/dist/collection/components/list-item/list-item.js +103 -103
  66. package/dist/collection/components/my-component/my-component.css +3 -3
  67. package/dist/collection/components/my-component/my-component.js +73 -73
  68. package/dist/collection/components/ptc-accordion/ptc-accordion-item/ptc-accordion-item.js +296 -296
  69. package/dist/collection/components/ptc-accordion/ptc-accordion.js +74 -74
  70. package/dist/collection/components/ptc-announcement/ptc-announcement.css +86 -80
  71. package/dist/collection/components/ptc-announcement/ptc-announcement.js +249 -210
  72. package/dist/collection/components/ptc-breadcrumb/ptc-breadcrumb.js +21 -21
  73. package/dist/collection/components/ptc-button/ptc-button.js +293 -293
  74. package/dist/collection/components/ptc-card/ptc-card.css +137 -69
  75. package/dist/collection/components/ptc-card/ptc-card.js +342 -342
  76. package/dist/collection/components/ptc-card-bottom/ptc-card-bottom.js +105 -105
  77. package/dist/collection/components/ptc-card-content/ptc-card-content.js +109 -109
  78. package/dist/collection/components/ptc-card-plm/ptc-card-plm.js +97 -97
  79. package/dist/collection/components/ptc-checkbox/ptc-checkbox.js +114 -114
  80. package/dist/collection/components/ptc-collapse-list/ptc-collapse-list.js +557 -557
  81. package/dist/collection/components/ptc-container/ptc-container.js +119 -119
  82. package/dist/collection/components/ptc-date/ptc-date.js +201 -201
  83. package/dist/collection/components/ptc-dropdown/ptc-dropdown.js +157 -157
  84. package/dist/collection/components/ptc-dynamic-card/ptc-dynamic-card.js +156 -156
  85. package/dist/collection/components/ptc-ellipsis-dropdown/ptc-ellipsis-dropdown.js +115 -115
  86. package/dist/collection/components/ptc-filter-tag/ptc-filter-tag.js +105 -105
  87. package/dist/collection/components/ptc-hero/ptc-hero.js +67 -67
  88. package/dist/collection/components/ptc-hero-footer-cta/ptc-hero-footer-cta.js +77 -77
  89. package/dist/collection/components/ptc-icon-list/ptc-icon-list.js +145 -145
  90. package/dist/collection/components/ptc-icon-minimize/ptc-icon-minimize.js +86 -86
  91. package/dist/collection/components/ptc-img/ptc-img.js +313 -313
  92. package/dist/collection/components/ptc-link/ptc-link.js +198 -198
  93. package/dist/collection/components/ptc-list/ptc-list.js +95 -95
  94. package/dist/collection/components/ptc-lottie/ptc-lottie.css +5 -5
  95. package/dist/collection/components/ptc-lottie/ptc-lottie.js +58 -58
  96. package/dist/collection/components/ptc-minimized-footer/ptc-minimized-footer.js +17 -17
  97. package/dist/collection/components/ptc-minimized-header/ptc-minimized-header.js +80 -80
  98. package/dist/collection/components/ptc-mobile-select/ptc-mobile-select.js +221 -221
  99. package/dist/collection/components/ptc-modal/ptc-modal.js +359 -359
  100. package/dist/collection/components/ptc-nav/ptc-nav.js +21 -21
  101. package/dist/collection/components/ptc-nav-item/ptc-nav-item.js +252 -252
  102. package/dist/collection/components/ptc-overlay/ptc-overlay.js +99 -99
  103. package/dist/collection/components/ptc-pagenation/ptc-pagenation.css +10 -2
  104. package/dist/collection/components/ptc-pagenation/ptc-pagenation.js +317 -317
  105. package/dist/collection/components/ptc-para/ptc-para.js +195 -195
  106. package/dist/collection/components/ptc-picture/ptc-picture.js +473 -473
  107. package/dist/collection/components/ptc-previous-url/ptc-previous-url.js +54 -54
  108. package/dist/collection/components/ptc-pricing-block/ptc-pricing-block.js +45 -45
  109. package/dist/collection/components/ptc-quote/ptc-quote.js +154 -154
  110. package/dist/collection/components/ptc-readmore/ptc-readmore.css +66 -0
  111. package/dist/collection/components/ptc-readmore/ptc-readmore.js +139 -0
  112. package/dist/collection/components/ptc-responsive-wrapper/ptc-responsive-wrapper.css +3 -3
  113. package/dist/collection/components/ptc-responsive-wrapper/ptc-responsive-wrapper.js +62 -62
  114. package/dist/collection/components/ptc-shopping-cart/ptc-shopping-cart.js +91 -91
  115. package/dist/collection/components/ptc-social-share/ptc-social-share.js +206 -206
  116. package/dist/collection/components/ptc-spacer/ptc-spacer.css +322 -322
  117. package/dist/collection/components/ptc-spacer/ptc-spacer.js +99 -99
  118. package/dist/collection/components/ptc-span/ptc-span.js +89 -89
  119. package/dist/collection/components/ptc-svg-btn/ptc-svg-btn.js +71 -71
  120. package/dist/collection/components/ptc-tab-list/ptc-tab-list.js +149 -149
  121. package/dist/collection/components/ptc-text-copy-with-background/ptc-text-copy-with-background.js +129 -129
  122. package/dist/collection/components/ptc-title/ptc-title.css +1 -1
  123. package/dist/collection/components/ptc-title/ptc-title.js +297 -297
  124. package/dist/collection/components/ptc-tooltip/ptc-tooltip.css +112 -0
  125. package/dist/collection/components/ptc-tooltip/ptc-tooltip.js +180 -0
  126. package/dist/collection/components/ptc-two-column-media/ptc-two-column-media.js +40 -40
  127. package/dist/collection/components/tab-content/tab-content.js +74 -74
  128. package/dist/collection/components/tab-header/tab-header.js +106 -106
  129. package/dist/collection/index.js +1 -1
  130. package/dist/collection/media/svg-imgs/Back-arrow.svg +11 -11
  131. package/dist/collection/media/svg-imgs/close.svg +10 -10
  132. package/dist/collection/media/svg-imgs/ptc-shopping-cart-black.svg +3 -3
  133. package/dist/collection/media/svg-imgs/ptc-shopping-cart-white.svg +3 -3
  134. package/dist/collection/media/svg-imgs/slider-arrow-left.svg +18 -18
  135. package/dist/collection/media/svg-imgs/slider-arrow-right.svg +18 -18
  136. package/dist/collection/media/svg-imgs/union.svg +3 -3
  137. package/dist/collection/utils/component.js +3 -3
  138. package/dist/collection/utils/interfaces.js +11 -11
  139. package/dist/collection/utils/utils.js +81 -81
  140. package/dist/custom-elements/index.d.ts +12 -0
  141. package/dist/custom-elements/index.js +3522 -3379
  142. package/dist/esm/dropdown-item.entry.js +10 -10
  143. package/dist/esm/icon-asset.entry.js +54 -54
  144. package/dist/esm/list-item.entry.js +19 -19
  145. package/dist/esm/loader.js +1 -1
  146. package/dist/esm/lottie-player.entry.js +354 -354
  147. package/dist/esm/my-component.entry.js +12 -12
  148. package/dist/esm/polyfills/core-js.js +0 -0
  149. package/dist/esm/polyfills/dom.js +0 -0
  150. package/dist/esm/polyfills/es5-html-element.js +0 -0
  151. package/dist/esm/polyfills/index.js +0 -0
  152. package/dist/esm/polyfills/system.js +0 -0
  153. package/dist/esm/ptc-accordion-item.entry.js +97 -97
  154. package/dist/esm/ptc-accordion.entry.js +38 -38
  155. package/dist/esm/ptc-announcement.entry.js +63 -38
  156. package/dist/esm/ptc-breadcrumb.entry.js +12 -12
  157. package/dist/esm/ptc-button.entry.js +65 -65
  158. package/dist/esm/ptc-card-bottom.entry.js +31 -31
  159. package/dist/esm/ptc-card-content.entry.js +35 -35
  160. package/dist/esm/ptc-card-plm.entry.js +16 -16
  161. package/dist/esm/ptc-card_6.entry.js +535 -535
  162. package/dist/esm/ptc-checkbox.entry.js +31 -31
  163. package/dist/esm/ptc-collapse-list.entry.js +335 -335
  164. package/dist/esm/ptc-container.entry.js +35 -35
  165. package/dist/esm/ptc-dropdown.entry.js +64 -64
  166. package/dist/esm/ptc-dynamic-card.entry.js +40 -40
  167. package/dist/esm/ptc-ellipsis-dropdown.entry.js +37 -37
  168. package/dist/esm/ptc-filter-tag.entry.js +56 -56
  169. package/dist/esm/ptc-hero-footer-cta.entry.js +8 -8
  170. package/dist/esm/ptc-hero.entry.js +18 -18
  171. package/dist/esm/ptc-icon-list.entry.js +32 -32
  172. package/dist/esm/ptc-icon-minimize.entry.js +35 -35
  173. package/dist/esm/ptc-link.entry.js +42 -42
  174. package/dist/esm/ptc-list.entry.js +50 -50
  175. package/dist/esm/ptc-lottie.entry.js +12 -12
  176. package/dist/esm/ptc-minimized-footer.entry.js +8 -8
  177. package/dist/esm/ptc-minimized-header.entry.js +11 -11
  178. package/dist/esm/ptc-mobile-select.entry.js +69 -69
  179. package/dist/esm/ptc-modal.entry.js +155 -155
  180. package/dist/esm/ptc-nav-item.entry.js +83 -83
  181. package/dist/esm/ptc-nav.entry.js +8 -8
  182. package/dist/esm/ptc-overlay.entry.js +20 -20
  183. package/dist/esm/ptc-pagenation.entry.js +105 -105
  184. package/dist/esm/ptc-previous-url.entry.js +8 -8
  185. package/dist/esm/ptc-pricing-block.entry.js +15 -15
  186. package/dist/esm/ptc-quote.entry.js +25 -25
  187. package/dist/esm/ptc-readmore_2.entry.js +113 -0
  188. package/dist/esm/ptc-responsive-wrapper.entry.js +54 -54
  189. package/dist/esm/ptc-shopping-cart.entry.js +49 -49
  190. package/dist/esm/ptc-social-share.entry.js +64 -64
  191. package/dist/esm/ptc-span.entry.js +23 -23
  192. package/dist/esm/ptc-svg-btn.entry.js +75 -75
  193. package/dist/esm/ptc-tab-list.entry.js +122 -122
  194. package/dist/esm/ptc-text-copy-with-background.entry.js +24 -24
  195. package/dist/esm/ptc-title.entry.js +74 -74
  196. package/dist/esm/ptc-two-column-media.entry.js +14 -14
  197. package/dist/esm/ptcw-design.js +1 -1
  198. package/dist/esm/tab-content.entry.js +26 -26
  199. package/dist/esm/tab-header.entry.js +43 -43
  200. package/dist/esm/{utils-2dbb41dc.js → utils-646cc62f.js} +79 -79
  201. package/dist/ptcw-design/media/brands.svg +1381 -1381
  202. package/dist/ptcw-design/media/designer.svg +379 -368
  203. package/dist/ptcw-design/media/regular.svg +463 -463
  204. package/dist/ptcw-design/media/solid.svg +3013 -3013
  205. package/dist/ptcw-design/media/svg-with-js.min.css +4 -4
  206. package/dist/ptcw-design/p-1743d0ef.entry.js +1 -0
  207. package/dist/ptcw-design/{p-10f6d8ae.entry.js → p-2de688ba.entry.js} +1 -1
  208. package/dist/ptcw-design/p-2f6ecdf8.entry.js +1 -0
  209. package/dist/ptcw-design/p-3b87cd6f.entry.js +1 -0
  210. package/dist/ptcw-design/p-493b2571.entry.js +1 -0
  211. package/dist/ptcw-design/{p-bb4485e3.entry.js → p-87f9430f.entry.js} +1 -1
  212. package/dist/ptcw-design/p-8e2e81c8.entry.js +1 -0
  213. package/dist/ptcw-design/ptcw-design.esm.js +1 -1
  214. package/dist/types/components/dropdown-item/dropdown-item.d.ts +5 -5
  215. package/dist/types/components/icon-asset/icon-asset.d.ts +40 -40
  216. package/dist/types/components/list-item/list-item.d.ts +8 -8
  217. package/dist/types/components/my-component/my-component.d.ts +16 -16
  218. package/dist/types/components/ptc-accordion/ptc-accordion-item/ptc-accordion-item.d.ts +59 -59
  219. package/dist/types/components/ptc-accordion/ptc-accordion.d.ts +13 -13
  220. package/dist/types/components/ptc-announcement/ptc-announcement.d.ts +51 -43
  221. package/dist/types/components/ptc-breadcrumb/ptc-breadcrumb.d.ts +4 -4
  222. package/dist/types/components/ptc-button/ptc-button.d.ts +56 -56
  223. package/dist/types/components/ptc-card/ptc-card.d.ts +62 -62
  224. package/dist/types/components/ptc-card-bottom/ptc-card-bottom.d.ts +15 -15
  225. package/dist/types/components/ptc-card-content/ptc-card-content.d.ts +15 -15
  226. package/dist/types/components/ptc-card-plm/ptc-card-plm.d.ts +8 -8
  227. package/dist/types/components/ptc-checkbox/ptc-checkbox.d.ts +11 -11
  228. package/dist/types/components/ptc-collapse-list/ptc-collapse-list.d.ts +56 -56
  229. package/dist/types/components/ptc-container/ptc-container.d.ts +12 -12
  230. package/dist/types/components/ptc-date/ptc-date.d.ts +41 -41
  231. package/dist/types/components/ptc-dropdown/ptc-dropdown.d.ts +19 -19
  232. package/dist/types/components/ptc-dynamic-card/ptc-dynamic-card.d.ts +16 -16
  233. package/dist/types/components/ptc-ellipsis-dropdown/ptc-ellipsis-dropdown.d.ts +12 -12
  234. package/dist/types/components/ptc-filter-tag/ptc-filter-tag.d.ts +17 -17
  235. package/dist/types/components/ptc-hero/ptc-hero.d.ts +12 -12
  236. package/dist/types/components/ptc-hero-footer-cta/ptc-hero-footer-cta.d.ts +6 -6
  237. package/dist/types/components/ptc-icon-list/ptc-icon-list.d.ts +21 -21
  238. package/dist/types/components/ptc-icon-minimize/ptc-icon-minimize.d.ts +9 -9
  239. package/dist/types/components/ptc-img/ptc-img.d.ts +51 -51
  240. package/dist/types/components/ptc-link/ptc-link.d.ts +36 -36
  241. package/dist/types/components/ptc-list/ptc-list.d.ts +8 -8
  242. package/dist/types/components/ptc-lottie/ptc-lottie.d.ts +12 -12
  243. package/dist/types/components/ptc-minimized-footer/ptc-minimized-footer.d.ts +3 -3
  244. package/dist/types/components/ptc-minimized-header/ptc-minimized-header.d.ts +6 -6
  245. package/dist/types/components/ptc-mobile-select/ptc-mobile-select.d.ts +40 -40
  246. package/dist/types/components/ptc-modal/ptc-modal.d.ts +59 -59
  247. package/dist/types/components/ptc-nav/ptc-nav.d.ts +3 -3
  248. package/dist/types/components/ptc-nav-item/ptc-nav-item.d.ts +53 -53
  249. package/dist/types/components/ptc-overlay/ptc-overlay.d.ts +20 -20
  250. package/dist/types/components/ptc-pagenation/ptc-pagenation.d.ts +27 -27
  251. package/dist/types/components/ptc-para/ptc-para.d.ts +34 -34
  252. package/dist/types/components/ptc-picture/ptc-picture.d.ts +93 -93
  253. package/dist/types/components/ptc-previous-url/ptc-previous-url.d.ts +5 -5
  254. package/dist/types/components/ptc-pricing-block/ptc-pricing-block.d.ts +5 -5
  255. package/dist/types/components/ptc-quote/ptc-quote.d.ts +29 -29
  256. package/dist/types/components/ptc-readmore/ptc-readmore.d.ts +27 -0
  257. package/dist/types/components/ptc-responsive-wrapper/ptc-responsive-wrapper.d.ts +8 -8
  258. package/dist/types/components/ptc-shopping-cart/ptc-shopping-cart.d.ts +6 -6
  259. package/dist/types/components/ptc-social-share/ptc-social-share.d.ts +25 -25
  260. package/dist/types/components/ptc-spacer/ptc-spacer.d.ts +16 -16
  261. package/dist/types/components/ptc-span/ptc-span.d.ts +16 -16
  262. package/dist/types/components/ptc-svg-btn/ptc-svg-btn.d.ts +12 -12
  263. package/dist/types/components/ptc-tab-list/ptc-tab-list.d.ts +15 -15
  264. package/dist/types/components/ptc-text-copy-with-background/ptc-text-copy-with-background.d.ts +25 -25
  265. package/dist/types/components/ptc-title/ptc-title.d.ts +50 -50
  266. package/dist/types/components/ptc-tooltip/ptc-tooltip.d.ts +34 -0
  267. package/dist/types/components/ptc-two-column-media/ptc-two-column-media.d.ts +9 -9
  268. package/dist/types/components/tab-content/tab-content.d.ts +12 -12
  269. package/dist/types/components/tab-header/tab-header.d.ts +13 -13
  270. package/dist/types/components.d.ts +144 -38
  271. package/dist/types/global.d.ts +1072 -1072
  272. package/dist/types/index.d.ts +1 -1
  273. package/dist/types/utils/component.d.ts +1 -1
  274. package/dist/types/utils/interfaces.d.ts +31 -31
  275. package/dist/types/utils/utils.d.ts +4 -4
  276. package/package.json +60 -59
  277. package/readme.md +11 -11
  278. package/dist/ptcw-design/p-21a381bd.entry.js +0 -1
  279. package/dist/ptcw-design/p-7f044112.entry.js +0 -1
  280. package/dist/ptcw-design/p-b1bfc20f.entry.js +0 -1
  281. package/dist/ptcw-design/p-c26e343e.entry.js +0 -1
  282. /package/dist/ptcw-design/{p-5e98555a.js → p-e121ff2a.js} +0 -0
@@ -1,296 +1,296 @@
1
- import { Component, Host, h, Prop, State, Element, Method, Event, } from '@stencil/core';
2
- import { hasSlot } from '../../../utils/component';
3
- export class PtcAccordionItem {
4
- constructor() {
5
- /**
6
- * Heading text.
7
- * This will be overwritten by `heading` slot
8
- */
9
- this.heading = null;
10
- /**
11
- * The HTML tag to be applied to the heading text.
12
- * This will be overwritten by `heading` slot
13
- */
14
- this.headingTag = 'h3';
15
- /**
16
- * If expanded height should be automatically calculated. If set, the `--ptc-accordion-item-body-max-height` CSS variable will be set automatically to the content height
17
- */
18
- this.autoHeight = false;
19
- /**
20
- * If the accordion item should be opened by default
21
- */
22
- this.active = false;
23
- this.hasHeadingSlot = true;
24
- this.hasArrowSlot = true;
25
- }
26
- componentWillLoad() {
27
- this.hasHeadingSlot = hasSlot(this.el, 'heading');
28
- this.hasArrowSlot = hasSlot(this.el, 'arrow');
29
- }
30
- componentDidLoad() {
31
- if (this.autoHeight) {
32
- this.bodyEl.style.setProperty('--ptc-accordion-item-body-max-height', this.bodyEl.scrollHeight + 2 + 'px');
33
- }
34
- this.onTransitionEnd();
35
- this.bodyEl.addEventListener('transitionstart', () => {
36
- this.onTransitionStart();
37
- });
38
- this.bodyEl.addEventListener('transitionend', () => {
39
- this.onTransitionEnd();
40
- });
41
- this.hasHeadingSlot = hasSlot(this.el, 'heading');
42
- this.hasArrowSlot = hasSlot(this.el, 'arrow');
43
- }
44
- onTransitionEnd() {
45
- if (this.active) {
46
- this.bodyEl.style.overflow = 'auto';
47
- this.opened.emit();
48
- }
49
- else {
50
- this.bodyEl.style.overflow = 'hidden';
51
- this.bodyEl.style.visibility = 'hidden';
52
- this.closed.emit();
53
- }
54
- }
55
- onTransitionStart() {
56
- if (this.active) {
57
- this.bodyEl.style.visibility = 'visible';
58
- this.opening.emit();
59
- }
60
- else {
61
- this.closing.emit();
62
- }
63
- }
64
- /**
65
- * Toggle open state of accordion item
66
- */
67
- async toggle() {
68
- if (this.active) {
69
- this.close();
70
- }
71
- else {
72
- this.open();
73
- }
74
- }
75
- /**
76
- * Closes the accordion item
77
- */
78
- async close() {
79
- this.active = false;
80
- }
81
- /**
82
- * Opens the accordion item.
83
- */
84
- async open() {
85
- this.active = true;
86
- }
87
- render() {
88
- const { active, autoHeight, headingTag: HeadingTag } = this;
89
- return (h(Host, { class: { active, autoHeight } },
90
- h("button", { class: "heading", role: "button", onClick: () => this.toggle() },
91
- h("span", { class: "arrow" }, this.hasArrowSlot ? (h("slot", { name: "arrow" })) : (h("svg", { focusable: "false", viewBox: "0 0 24 24", "aria-hidden": "true" },
92
- h("path", { d: "M16.59 8.59L12 13.17 7.41 8.59 6 10l6 6 6-6z" })))),
93
- this.hasHeadingSlot ? (h("slot", { name: "heading" })) : (h(HeadingTag, { class: "heading-text" }, this.heading))),
94
- h("div", { class: "body-container", ref: el => (this.bodyEl = el) },
95
- h("div", { class: "body" },
96
- h("slot", null)))));
97
- }
98
- static get is() { return "ptc-accordion-item"; }
99
- static get encapsulation() { return "shadow"; }
100
- static get originalStyleUrls() { return {
101
- "$": ["ptc-accordion-item.scss"]
102
- }; }
103
- static get styleUrls() { return {
104
- "$": ["ptc-accordion-item.css"]
105
- }; }
106
- static get properties() { return {
107
- "heading": {
108
- "type": "string",
109
- "mutable": false,
110
- "complexType": {
111
- "original": "string",
112
- "resolved": "string",
113
- "references": {}
114
- },
115
- "required": false,
116
- "optional": true,
117
- "docs": {
118
- "tags": [],
119
- "text": "Heading text.\nThis will be overwritten by `heading` slot"
120
- },
121
- "attribute": "heading",
122
- "reflect": false,
123
- "defaultValue": "null"
124
- },
125
- "headingTag": {
126
- "type": "string",
127
- "mutable": false,
128
- "complexType": {
129
- "original": "string",
130
- "resolved": "string",
131
- "references": {}
132
- },
133
- "required": false,
134
- "optional": true,
135
- "docs": {
136
- "tags": [],
137
- "text": "The HTML tag to be applied to the heading text.\nThis will be overwritten by `heading` slot"
138
- },
139
- "attribute": "heading-tag",
140
- "reflect": false,
141
- "defaultValue": "'h3'"
142
- },
143
- "autoHeight": {
144
- "type": "boolean",
145
- "mutable": false,
146
- "complexType": {
147
- "original": "boolean",
148
- "resolved": "boolean",
149
- "references": {}
150
- },
151
- "required": false,
152
- "optional": true,
153
- "docs": {
154
- "tags": [],
155
- "text": "If expanded height should be automatically calculated. If set, the `--ptc-accordion-item-body-max-height` CSS variable will be set automatically to the content height"
156
- },
157
- "attribute": "auto-height",
158
- "reflect": false,
159
- "defaultValue": "false"
160
- },
161
- "active": {
162
- "type": "boolean",
163
- "mutable": true,
164
- "complexType": {
165
- "original": "boolean",
166
- "resolved": "boolean",
167
- "references": {}
168
- },
169
- "required": false,
170
- "optional": true,
171
- "docs": {
172
- "tags": [],
173
- "text": "If the accordion item should be opened by default"
174
- },
175
- "attribute": "active",
176
- "reflect": true,
177
- "defaultValue": "false"
178
- }
179
- }; }
180
- static get states() { return {
181
- "hasHeadingSlot": {},
182
- "hasArrowSlot": {}
183
- }; }
184
- static get events() { return [{
185
- "method": "opened",
186
- "name": "opened",
187
- "bubbles": true,
188
- "cancelable": true,
189
- "composed": true,
190
- "docs": {
191
- "tags": [],
192
- "text": "Emitted when accordion item has opened"
193
- },
194
- "complexType": {
195
- "original": "any",
196
- "resolved": "any",
197
- "references": {}
198
- }
199
- }, {
200
- "method": "opening",
201
- "name": "opening",
202
- "bubbles": true,
203
- "cancelable": true,
204
- "composed": true,
205
- "docs": {
206
- "tags": [],
207
- "text": "Emitted when accordion item started opening"
208
- },
209
- "complexType": {
210
- "original": "any",
211
- "resolved": "any",
212
- "references": {}
213
- }
214
- }, {
215
- "method": "closed",
216
- "name": "closed",
217
- "bubbles": true,
218
- "cancelable": true,
219
- "composed": true,
220
- "docs": {
221
- "tags": [],
222
- "text": "Emitted when accordion item has closed"
223
- },
224
- "complexType": {
225
- "original": "any",
226
- "resolved": "any",
227
- "references": {}
228
- }
229
- }, {
230
- "method": "closing",
231
- "name": "closing",
232
- "bubbles": true,
233
- "cancelable": true,
234
- "composed": true,
235
- "docs": {
236
- "tags": [],
237
- "text": "Emitted when accordion item started closing"
238
- },
239
- "complexType": {
240
- "original": "any",
241
- "resolved": "any",
242
- "references": {}
243
- }
244
- }]; }
245
- static get methods() { return {
246
- "toggle": {
247
- "complexType": {
248
- "signature": "() => Promise<void>",
249
- "parameters": [],
250
- "references": {
251
- "Promise": {
252
- "location": "global"
253
- }
254
- },
255
- "return": "Promise<void>"
256
- },
257
- "docs": {
258
- "text": "Toggle open state of accordion item",
259
- "tags": []
260
- }
261
- },
262
- "close": {
263
- "complexType": {
264
- "signature": "() => Promise<void>",
265
- "parameters": [],
266
- "references": {
267
- "Promise": {
268
- "location": "global"
269
- }
270
- },
271
- "return": "Promise<void>"
272
- },
273
- "docs": {
274
- "text": "Closes the accordion item",
275
- "tags": []
276
- }
277
- },
278
- "open": {
279
- "complexType": {
280
- "signature": "() => Promise<void>",
281
- "parameters": [],
282
- "references": {
283
- "Promise": {
284
- "location": "global"
285
- }
286
- },
287
- "return": "Promise<void>"
288
- },
289
- "docs": {
290
- "text": "Opens the accordion item.",
291
- "tags": []
292
- }
293
- }
294
- }; }
295
- static get elementRef() { return "el"; }
296
- }
1
+ import { Component, Host, h, Prop, State, Element, Method, Event, } from '@stencil/core';
2
+ import { hasSlot } from '../../../utils/component';
3
+ export class PtcAccordionItem {
4
+ constructor() {
5
+ /**
6
+ * Heading text.
7
+ * This will be overwritten by `heading` slot
8
+ */
9
+ this.heading = null;
10
+ /**
11
+ * The HTML tag to be applied to the heading text.
12
+ * This will be overwritten by `heading` slot
13
+ */
14
+ this.headingTag = 'h3';
15
+ /**
16
+ * If expanded height should be automatically calculated. If set, the `--ptc-accordion-item-body-max-height` CSS variable will be set automatically to the content height
17
+ */
18
+ this.autoHeight = false;
19
+ /**
20
+ * If the accordion item should be opened by default
21
+ */
22
+ this.active = false;
23
+ this.hasHeadingSlot = true;
24
+ this.hasArrowSlot = true;
25
+ }
26
+ componentWillLoad() {
27
+ this.hasHeadingSlot = hasSlot(this.el, 'heading');
28
+ this.hasArrowSlot = hasSlot(this.el, 'arrow');
29
+ }
30
+ componentDidLoad() {
31
+ if (this.autoHeight) {
32
+ this.bodyEl.style.setProperty('--ptc-accordion-item-body-max-height', this.bodyEl.scrollHeight + 2 + 'px');
33
+ }
34
+ this.onTransitionEnd();
35
+ this.bodyEl.addEventListener('transitionstart', () => {
36
+ this.onTransitionStart();
37
+ });
38
+ this.bodyEl.addEventListener('transitionend', () => {
39
+ this.onTransitionEnd();
40
+ });
41
+ this.hasHeadingSlot = hasSlot(this.el, 'heading');
42
+ this.hasArrowSlot = hasSlot(this.el, 'arrow');
43
+ }
44
+ onTransitionEnd() {
45
+ if (this.active) {
46
+ this.bodyEl.style.overflow = 'auto';
47
+ this.opened.emit();
48
+ }
49
+ else {
50
+ this.bodyEl.style.overflow = 'hidden';
51
+ this.bodyEl.style.visibility = 'hidden';
52
+ this.closed.emit();
53
+ }
54
+ }
55
+ onTransitionStart() {
56
+ if (this.active) {
57
+ this.bodyEl.style.visibility = 'visible';
58
+ this.opening.emit();
59
+ }
60
+ else {
61
+ this.closing.emit();
62
+ }
63
+ }
64
+ /**
65
+ * Toggle open state of accordion item
66
+ */
67
+ async toggle() {
68
+ if (this.active) {
69
+ this.close();
70
+ }
71
+ else {
72
+ this.open();
73
+ }
74
+ }
75
+ /**
76
+ * Closes the accordion item
77
+ */
78
+ async close() {
79
+ this.active = false;
80
+ }
81
+ /**
82
+ * Opens the accordion item.
83
+ */
84
+ async open() {
85
+ this.active = true;
86
+ }
87
+ render() {
88
+ const { active, autoHeight, headingTag: HeadingTag } = this;
89
+ return (h(Host, { class: { active, autoHeight } },
90
+ h("button", { class: "heading", role: "button", onClick: () => this.toggle() },
91
+ h("span", { class: "arrow" }, this.hasArrowSlot ? (h("slot", { name: "arrow" })) : (h("svg", { focusable: "false", viewBox: "0 0 24 24", "aria-hidden": "true" },
92
+ h("path", { d: "M16.59 8.59L12 13.17 7.41 8.59 6 10l6 6 6-6z" })))),
93
+ this.hasHeadingSlot ? (h("slot", { name: "heading" })) : (h(HeadingTag, { class: "heading-text" }, this.heading))),
94
+ h("div", { class: "body-container", ref: el => (this.bodyEl = el) },
95
+ h("div", { class: "body" },
96
+ h("slot", null)))));
97
+ }
98
+ static get is() { return "ptc-accordion-item"; }
99
+ static get encapsulation() { return "shadow"; }
100
+ static get originalStyleUrls() { return {
101
+ "$": ["ptc-accordion-item.scss"]
102
+ }; }
103
+ static get styleUrls() { return {
104
+ "$": ["ptc-accordion-item.css"]
105
+ }; }
106
+ static get properties() { return {
107
+ "heading": {
108
+ "type": "string",
109
+ "mutable": false,
110
+ "complexType": {
111
+ "original": "string",
112
+ "resolved": "string",
113
+ "references": {}
114
+ },
115
+ "required": false,
116
+ "optional": true,
117
+ "docs": {
118
+ "tags": [],
119
+ "text": "Heading text.\r\nThis will be overwritten by `heading` slot"
120
+ },
121
+ "attribute": "heading",
122
+ "reflect": false,
123
+ "defaultValue": "null"
124
+ },
125
+ "headingTag": {
126
+ "type": "string",
127
+ "mutable": false,
128
+ "complexType": {
129
+ "original": "string",
130
+ "resolved": "string",
131
+ "references": {}
132
+ },
133
+ "required": false,
134
+ "optional": true,
135
+ "docs": {
136
+ "tags": [],
137
+ "text": "The HTML tag to be applied to the heading text.\r\nThis will be overwritten by `heading` slot"
138
+ },
139
+ "attribute": "heading-tag",
140
+ "reflect": false,
141
+ "defaultValue": "'h3'"
142
+ },
143
+ "autoHeight": {
144
+ "type": "boolean",
145
+ "mutable": false,
146
+ "complexType": {
147
+ "original": "boolean",
148
+ "resolved": "boolean",
149
+ "references": {}
150
+ },
151
+ "required": false,
152
+ "optional": true,
153
+ "docs": {
154
+ "tags": [],
155
+ "text": "If expanded height should be automatically calculated. If set, the `--ptc-accordion-item-body-max-height` CSS variable will be set automatically to the content height"
156
+ },
157
+ "attribute": "auto-height",
158
+ "reflect": false,
159
+ "defaultValue": "false"
160
+ },
161
+ "active": {
162
+ "type": "boolean",
163
+ "mutable": true,
164
+ "complexType": {
165
+ "original": "boolean",
166
+ "resolved": "boolean",
167
+ "references": {}
168
+ },
169
+ "required": false,
170
+ "optional": true,
171
+ "docs": {
172
+ "tags": [],
173
+ "text": "If the accordion item should be opened by default"
174
+ },
175
+ "attribute": "active",
176
+ "reflect": true,
177
+ "defaultValue": "false"
178
+ }
179
+ }; }
180
+ static get states() { return {
181
+ "hasHeadingSlot": {},
182
+ "hasArrowSlot": {}
183
+ }; }
184
+ static get events() { return [{
185
+ "method": "opened",
186
+ "name": "opened",
187
+ "bubbles": true,
188
+ "cancelable": true,
189
+ "composed": true,
190
+ "docs": {
191
+ "tags": [],
192
+ "text": "Emitted when accordion item has opened"
193
+ },
194
+ "complexType": {
195
+ "original": "any",
196
+ "resolved": "any",
197
+ "references": {}
198
+ }
199
+ }, {
200
+ "method": "opening",
201
+ "name": "opening",
202
+ "bubbles": true,
203
+ "cancelable": true,
204
+ "composed": true,
205
+ "docs": {
206
+ "tags": [],
207
+ "text": "Emitted when accordion item started opening"
208
+ },
209
+ "complexType": {
210
+ "original": "any",
211
+ "resolved": "any",
212
+ "references": {}
213
+ }
214
+ }, {
215
+ "method": "closed",
216
+ "name": "closed",
217
+ "bubbles": true,
218
+ "cancelable": true,
219
+ "composed": true,
220
+ "docs": {
221
+ "tags": [],
222
+ "text": "Emitted when accordion item has closed"
223
+ },
224
+ "complexType": {
225
+ "original": "any",
226
+ "resolved": "any",
227
+ "references": {}
228
+ }
229
+ }, {
230
+ "method": "closing",
231
+ "name": "closing",
232
+ "bubbles": true,
233
+ "cancelable": true,
234
+ "composed": true,
235
+ "docs": {
236
+ "tags": [],
237
+ "text": "Emitted when accordion item started closing"
238
+ },
239
+ "complexType": {
240
+ "original": "any",
241
+ "resolved": "any",
242
+ "references": {}
243
+ }
244
+ }]; }
245
+ static get methods() { return {
246
+ "toggle": {
247
+ "complexType": {
248
+ "signature": "() => Promise<void>",
249
+ "parameters": [],
250
+ "references": {
251
+ "Promise": {
252
+ "location": "global"
253
+ }
254
+ },
255
+ "return": "Promise<void>"
256
+ },
257
+ "docs": {
258
+ "text": "Toggle open state of accordion item",
259
+ "tags": []
260
+ }
261
+ },
262
+ "close": {
263
+ "complexType": {
264
+ "signature": "() => Promise<void>",
265
+ "parameters": [],
266
+ "references": {
267
+ "Promise": {
268
+ "location": "global"
269
+ }
270
+ },
271
+ "return": "Promise<void>"
272
+ },
273
+ "docs": {
274
+ "text": "Closes the accordion item",
275
+ "tags": []
276
+ }
277
+ },
278
+ "open": {
279
+ "complexType": {
280
+ "signature": "() => Promise<void>",
281
+ "parameters": [],
282
+ "references": {
283
+ "Promise": {
284
+ "location": "global"
285
+ }
286
+ },
287
+ "return": "Promise<void>"
288
+ },
289
+ "docs": {
290
+ "text": "Opens the accordion item.",
291
+ "tags": []
292
+ }
293
+ }
294
+ }; }
295
+ static get elementRef() { return "el"; }
296
+ }