@affinda/wc 0.0.26 → 0.0.28

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 (894) hide show
  1. package/dist/affinda/af-accordion-item.entry.esm.js.map +1 -0
  2. package/dist/affinda/af-accordion.entry.esm.js.map +1 -0
  3. package/dist/affinda/af-aspect-ratio.entry.esm.js.map +1 -0
  4. package/dist/affinda/af-button-group.entry.esm.js.map +1 -0
  5. package/dist/affinda/af-button.entry.esm.js.map +1 -0
  6. package/dist/affinda/af-card.entry.esm.js.map +1 -0
  7. package/dist/affinda/af-center.entry.esm.js.map +1 -0
  8. package/dist/affinda/af-checkbox.entry.esm.js.map +1 -0
  9. package/dist/affinda/af-client-carousel.entry.esm.js.map +1 -0
  10. package/dist/affinda/af-color-swatch.entry.esm.js.map +1 -0
  11. package/dist/affinda/af-contact-item.entry.esm.js.map +1 -0
  12. package/dist/affinda/af-container.entry.esm.js.map +1 -0
  13. package/dist/affinda/af-divider.entry.esm.js.map +1 -0
  14. package/dist/affinda/af-feature-accordion.entry.esm.js.map +1 -0
  15. package/dist/affinda/af-feature-card.entry.esm.js.map +1 -0
  16. package/dist/affinda/af-feature-grid.entry.esm.js.map +1 -0
  17. package/dist/affinda/af-fieldset.entry.esm.js.map +1 -0
  18. package/dist/affinda/af-footer-column.entry.esm.js.map +1 -0
  19. package/dist/affinda/af-footer-link.entry.esm.js.map +1 -0
  20. package/dist/affinda/af-footer.entry.esm.js.map +1 -0
  21. package/dist/affinda/af-grid-callout.entry.esm.js.map +1 -0
  22. package/dist/affinda/af-grid.entry.esm.js.map +1 -0
  23. package/dist/affinda/af-heading.af-logo.af-nav-item.af-navbar.af-text.entry.esm.js.map +1 -0
  24. package/dist/affinda/af-icon-box.entry.esm.js.map +1 -0
  25. package/dist/affinda/af-icon-button.entry.esm.js.map +1 -0
  26. package/dist/affinda/af-icon-text.entry.esm.js.map +1 -0
  27. package/dist/affinda/af-icon.entry.esm.js.map +1 -0
  28. package/dist/affinda/af-illustrated-card.entry.esm.js.map +1 -0
  29. package/dist/affinda/af-image.entry.esm.js.map +1 -0
  30. package/dist/affinda/af-in-page-banner.entry.esm.js.map +1 -0
  31. package/dist/affinda/af-inline.entry.esm.js.map +1 -0
  32. package/dist/affinda/af-input.entry.esm.js.map +1 -0
  33. package/dist/affinda/af-logo-well.entry.esm.js.map +1 -0
  34. package/dist/affinda/af-nav-accordion-item.entry.esm.js.map +1 -0
  35. package/dist/affinda/af-nav-accordion.entry.esm.js.map +1 -0
  36. package/dist/affinda/af-nav-card.entry.esm.js.map +1 -0
  37. package/dist/affinda/af-nav-menu-nest.entry.esm.js.map +1 -0
  38. package/dist/affinda/af-nav-menu.entry.esm.js.map +1 -0
  39. package/dist/affinda/af-number-badge.entry.esm.js.map +1 -0
  40. package/dist/affinda/af-progress-line.entry.esm.js.map +1 -0
  41. package/dist/affinda/af-radio.entry.esm.js.map +1 -0
  42. package/dist/affinda/af-section.entry.esm.js.map +1 -0
  43. package/dist/affinda/af-show.entry.esm.js.map +1 -0
  44. package/dist/affinda/af-social-link.entry.esm.js.map +1 -0
  45. package/dist/affinda/af-spacer.entry.esm.js.map +1 -0
  46. package/dist/affinda/af-split-section.entry.esm.js.map +1 -0
  47. package/dist/affinda/af-stack.entry.esm.js.map +1 -0
  48. package/dist/affinda/af-stepper-step.entry.esm.js.map +1 -0
  49. package/dist/affinda/af-stepper.entry.esm.js.map +1 -0
  50. package/dist/affinda/af-switch.entry.esm.js.map +1 -0
  51. package/dist/affinda/af-tab-bar.entry.esm.js.map +1 -0
  52. package/dist/affinda/af-tab.entry.esm.js.map +1 -0
  53. package/dist/affinda/af-tag.entry.esm.js.map +1 -0
  54. package/dist/affinda/af-testimonial-carousel.entry.esm.js.map +1 -0
  55. package/dist/affinda/af-testimonial-stat.entry.esm.js.map +1 -0
  56. package/dist/affinda/af-testimonial.entry.esm.js.map +1 -0
  57. package/dist/affinda/af-text-image-nest.entry.esm.js.map +1 -0
  58. package/dist/affinda/af-text-image.entry.esm.js.map +1 -0
  59. package/dist/affinda/af-textarea.entry.esm.js.map +1 -0
  60. package/dist/affinda/af-theme-override.entry.esm.js.map +1 -0
  61. package/dist/affinda/af-typography-lockup.entry.esm.js.map +1 -0
  62. package/dist/affinda/af-video-container.entry.esm.js.map +1 -0
  63. package/dist/affinda/af-visually-hidden.entry.esm.js.map +1 -0
  64. package/dist/affinda/affinda.css +1 -1
  65. package/dist/affinda/affinda.esm.js +2 -1
  66. package/dist/affinda/affinda.esm.js.map +1 -0
  67. package/dist/affinda/index.esm.js +2 -1
  68. package/dist/affinda/index.esm.js.map +1 -0
  69. package/dist/affinda/loader.esm.js.map +1 -0
  70. package/dist/affinda/p-07f9580c.entry.js +2 -0
  71. package/dist/affinda/p-07f9580c.entry.js.map +1 -0
  72. package/dist/affinda/p-0f3267ea.entry.js +2 -0
  73. package/dist/affinda/p-0f3267ea.entry.js.map +1 -0
  74. package/dist/affinda/p-102e8b8c.entry.js +2 -0
  75. package/dist/affinda/p-102e8b8c.entry.js.map +1 -0
  76. package/dist/affinda/p-11e7ddf3.entry.js +2 -0
  77. package/dist/affinda/p-11e7ddf3.entry.js.map +1 -0
  78. package/dist/affinda/p-12652bf5.entry.js +2 -0
  79. package/dist/affinda/p-12652bf5.entry.js.map +1 -0
  80. package/dist/affinda/p-159fe9b1.entry.js +2 -0
  81. package/dist/affinda/p-159fe9b1.entry.js.map +1 -0
  82. package/dist/affinda/p-1dff35bf.entry.js +2 -0
  83. package/dist/affinda/p-1dff35bf.entry.js.map +1 -0
  84. package/dist/affinda/p-2140698f.entry.js +2 -0
  85. package/dist/affinda/p-2140698f.entry.js.map +1 -0
  86. package/dist/affinda/p-23aa03dc.entry.js +2 -0
  87. package/dist/affinda/p-23aa03dc.entry.js.map +1 -0
  88. package/dist/affinda/p-2aa112c2.entry.js +2 -0
  89. package/dist/affinda/p-2aa112c2.entry.js.map +1 -0
  90. package/dist/affinda/{p-cf4d0d8e.entry.js → p-2c655ae2.entry.js} +2 -1
  91. package/dist/affinda/p-2c655ae2.entry.js.map +1 -0
  92. package/dist/affinda/p-3ca3e4dc.entry.js +2 -0
  93. package/dist/affinda/p-3ca3e4dc.entry.js.map +1 -0
  94. package/dist/affinda/p-3ecf43aa.entry.js +2 -0
  95. package/dist/affinda/p-3ecf43aa.entry.js.map +1 -0
  96. package/dist/affinda/p-401fc5b1.entry.js +2 -0
  97. package/dist/affinda/p-401fc5b1.entry.js.map +1 -0
  98. package/dist/affinda/p-432c7bfc.entry.js +2 -0
  99. package/dist/affinda/p-432c7bfc.entry.js.map +1 -0
  100. package/dist/affinda/p-4cbdf940.entry.js +2 -0
  101. package/dist/affinda/p-4cbdf940.entry.js.map +1 -0
  102. package/dist/affinda/p-4e8bd716.entry.js +2 -0
  103. package/dist/affinda/p-4e8bd716.entry.js.map +1 -0
  104. package/dist/affinda/p-50590601.entry.js +2 -0
  105. package/dist/affinda/p-50590601.entry.js.map +1 -0
  106. package/dist/affinda/p-570283f6.entry.js +2 -0
  107. package/dist/affinda/p-570283f6.entry.js.map +1 -0
  108. package/dist/affinda/p-5ab389c6.entry.js +2 -0
  109. package/dist/affinda/p-5ab389c6.entry.js.map +1 -0
  110. package/dist/affinda/p-5b3ff010.entry.js +2 -0
  111. package/dist/affinda/p-5b3ff010.entry.js.map +1 -0
  112. package/dist/affinda/p-5e444a9a.entry.js +2 -0
  113. package/dist/affinda/p-5e444a9a.entry.js.map +1 -0
  114. package/dist/affinda/p-5e5d16dd.entry.js +2 -0
  115. package/dist/affinda/p-5e5d16dd.entry.js.map +1 -0
  116. package/dist/affinda/p-636045e8.entry.js +2 -0
  117. package/dist/affinda/p-636045e8.entry.js.map +1 -0
  118. package/dist/affinda/p-648e2d76.entry.js +2 -0
  119. package/dist/affinda/p-648e2d76.entry.js.map +1 -0
  120. package/dist/affinda/p-6bb831c5.entry.js +2 -0
  121. package/dist/affinda/p-6bb831c5.entry.js.map +1 -0
  122. package/dist/affinda/p-6eca2722.entry.js +2 -0
  123. package/dist/affinda/p-6eca2722.entry.js.map +1 -0
  124. package/dist/affinda/p-7238fc21.entry.js +2 -0
  125. package/dist/affinda/p-7238fc21.entry.js.map +1 -0
  126. package/dist/affinda/p-77ed47d5.entry.js +2 -0
  127. package/dist/affinda/p-77ed47d5.entry.js.map +1 -0
  128. package/dist/affinda/p-7b7d9c6a.entry.js +2 -0
  129. package/dist/affinda/p-7b7d9c6a.entry.js.map +1 -0
  130. package/dist/affinda/p-80c96efd.entry.js +2 -0
  131. package/dist/affinda/p-80c96efd.entry.js.map +1 -0
  132. package/dist/affinda/p-816deae3.entry.js +2 -0
  133. package/dist/affinda/p-816deae3.entry.js.map +1 -0
  134. package/dist/affinda/p-892f9bc3.entry.js +2 -0
  135. package/dist/affinda/p-892f9bc3.entry.js.map +1 -0
  136. package/dist/affinda/p-8d9d0cb3.entry.js +2 -0
  137. package/dist/affinda/p-8d9d0cb3.entry.js.map +1 -0
  138. package/dist/affinda/p-8da30e7a.entry.js +2 -0
  139. package/dist/affinda/p-8da30e7a.entry.js.map +1 -0
  140. package/dist/affinda/p-8f6884c8.entry.js +2 -0
  141. package/dist/affinda/p-8f6884c8.entry.js.map +1 -0
  142. package/dist/affinda/p-9229defb.entry.js +2 -0
  143. package/dist/affinda/p-9229defb.entry.js.map +1 -0
  144. package/dist/affinda/p-94adb381.entry.js +2 -0
  145. package/dist/affinda/p-94adb381.entry.js.map +1 -0
  146. package/dist/affinda/p-97ac8f5f.entry.js +2 -0
  147. package/dist/affinda/p-97ac8f5f.entry.js.map +1 -0
  148. package/dist/affinda/p-9bb5202e.entry.js +2 -0
  149. package/dist/affinda/p-9bb5202e.entry.js.map +1 -0
  150. package/dist/affinda/p-a002c784.entry.js +2 -0
  151. package/dist/affinda/p-a002c784.entry.js.map +1 -0
  152. package/dist/affinda/p-a3865306.entry.js +2 -0
  153. package/dist/affinda/p-a3865306.entry.js.map +1 -0
  154. package/dist/affinda/p-a4d39bdd.entry.js +2 -0
  155. package/dist/affinda/p-a4d39bdd.entry.js.map +1 -0
  156. package/dist/affinda/p-aa5c6cc0.entry.js +2 -0
  157. package/dist/affinda/p-aa5c6cc0.entry.js.map +1 -0
  158. package/dist/affinda/p-ab0b621e.entry.js +2 -0
  159. package/dist/affinda/p-ab0b621e.entry.js.map +1 -0
  160. package/dist/affinda/p-af3f6e16.entry.js +2 -0
  161. package/dist/affinda/p-af3f6e16.entry.js.map +1 -0
  162. package/dist/affinda/p-b14c1a4b.entry.js +2 -0
  163. package/dist/affinda/p-b14c1a4b.entry.js.map +1 -0
  164. package/dist/affinda/p-be45f85c.entry.js +2 -0
  165. package/dist/affinda/p-be45f85c.entry.js.map +1 -0
  166. package/dist/affinda/p-bf941fa7.entry.js +2 -0
  167. package/dist/affinda/p-bf941fa7.entry.js.map +1 -0
  168. package/dist/affinda/p-bfc17d0c.entry.js +2 -0
  169. package/dist/affinda/p-bfc17d0c.entry.js.map +1 -0
  170. package/dist/affinda/{p-54d85947.entry.js → p-c7ba4e7f.entry.js} +2 -1
  171. package/dist/affinda/p-c7ba4e7f.entry.js.map +1 -0
  172. package/dist/affinda/p-cc22a8da.entry.js +2 -0
  173. package/dist/affinda/p-cc22a8da.entry.js.map +1 -0
  174. package/dist/affinda/p-d54abc45.entry.js +2 -0
  175. package/dist/affinda/p-d54abc45.entry.js.map +1 -0
  176. package/dist/affinda/p-d60d1943.entry.js +2 -0
  177. package/dist/affinda/p-d60d1943.entry.js.map +1 -0
  178. package/dist/affinda/p-d7e29257.entry.js +2 -0
  179. package/dist/affinda/p-d7e29257.entry.js.map +1 -0
  180. package/dist/affinda/p-da999c10.entry.js +2 -0
  181. package/dist/affinda/p-da999c10.entry.js.map +1 -0
  182. package/dist/affinda/p-e0163836.entry.js +2 -0
  183. package/dist/affinda/p-e0163836.entry.js.map +1 -0
  184. package/dist/affinda/p-e78112d9.entry.js +2 -0
  185. package/dist/affinda/p-e78112d9.entry.js.map +1 -0
  186. package/dist/affinda/p-e9f8ef54.entry.js +2 -0
  187. package/dist/affinda/p-e9f8ef54.entry.js.map +1 -0
  188. package/dist/affinda/p-eb96f29b.entry.js +2 -0
  189. package/dist/affinda/p-eb96f29b.entry.js.map +1 -0
  190. package/dist/affinda/p-ef41e743.entry.js +2 -0
  191. package/dist/affinda/p-ef41e743.entry.js.map +1 -0
  192. package/dist/affinda/p-f9b6d1c6.entry.js +2 -0
  193. package/dist/affinda/p-f9b6d1c6.entry.js.map +1 -0
  194. package/dist/affinda/p-f9e3c2b7.entry.js +2 -0
  195. package/dist/affinda/p-f9e3c2b7.entry.js.map +1 -0
  196. package/dist/affinda/p-nb89SRN6.js +3 -0
  197. package/dist/affinda/p-nb89SRN6.js.map +1 -0
  198. package/dist/cjs/af-accordion-item.cjs.entry.js +5 -6
  199. package/dist/cjs/af-accordion-item.entry.cjs.js.map +1 -0
  200. package/dist/cjs/af-accordion.cjs.entry.js +5 -6
  201. package/dist/cjs/af-accordion.entry.cjs.js.map +1 -0
  202. package/dist/cjs/af-aspect-ratio.cjs.entry.js +4 -3
  203. package/dist/cjs/af-aspect-ratio.entry.cjs.js.map +1 -0
  204. package/dist/cjs/af-button-group.cjs.entry.js +4 -3
  205. package/dist/cjs/af-button-group.entry.cjs.js.map +1 -0
  206. package/dist/cjs/af-button.cjs.entry.js +4 -3
  207. package/dist/cjs/af-button.entry.cjs.js.map +1 -0
  208. package/dist/cjs/af-card.cjs.entry.js +4 -3
  209. package/dist/cjs/af-card.entry.cjs.js.map +1 -0
  210. package/dist/cjs/af-center.cjs.entry.js +4 -3
  211. package/dist/cjs/af-center.entry.cjs.js.map +1 -0
  212. package/dist/cjs/af-checkbox.cjs.entry.js +4 -3
  213. package/dist/cjs/af-checkbox.entry.cjs.js.map +1 -0
  214. package/dist/cjs/af-client-carousel.cjs.entry.js +4 -3
  215. package/dist/cjs/af-client-carousel.entry.cjs.js.map +1 -0
  216. package/dist/cjs/af-color-swatch.cjs.entry.js +4 -3
  217. package/dist/cjs/af-color-swatch.entry.cjs.js.map +1 -0
  218. package/dist/cjs/af-contact-item.cjs.entry.js +4 -3
  219. package/dist/cjs/af-contact-item.entry.cjs.js.map +1 -0
  220. package/dist/cjs/af-container.cjs.entry.js +4 -3
  221. package/dist/cjs/af-container.entry.cjs.js.map +1 -0
  222. package/dist/cjs/af-divider.cjs.entry.js +4 -3
  223. package/dist/cjs/af-divider.entry.cjs.js.map +1 -0
  224. package/dist/cjs/af-feature-accordion.cjs.entry.js +5 -6
  225. package/dist/cjs/af-feature-accordion.entry.cjs.js.map +1 -0
  226. package/dist/cjs/af-feature-card.cjs.entry.js +4 -3
  227. package/dist/cjs/af-feature-card.entry.cjs.js.map +1 -0
  228. package/dist/cjs/af-feature-grid.cjs.entry.js +5 -6
  229. package/dist/cjs/af-feature-grid.entry.cjs.js.map +1 -0
  230. package/dist/cjs/af-fieldset.cjs.entry.js +4 -3
  231. package/dist/cjs/af-fieldset.entry.cjs.js.map +1 -0
  232. package/dist/cjs/af-footer-column.cjs.entry.js +4 -3
  233. package/dist/cjs/af-footer-column.entry.cjs.js.map +1 -0
  234. package/dist/cjs/af-footer-link.cjs.entry.js +4 -3
  235. package/dist/cjs/af-footer-link.entry.cjs.js.map +1 -0
  236. package/dist/cjs/af-footer.cjs.entry.js +4 -3
  237. package/dist/cjs/af-footer.entry.cjs.js.map +1 -0
  238. package/dist/cjs/af-grid-callout.cjs.entry.js +4 -3
  239. package/dist/cjs/af-grid-callout.entry.cjs.js.map +1 -0
  240. package/dist/cjs/af-grid.cjs.entry.js +4 -3
  241. package/dist/cjs/af-grid.entry.cjs.js.map +1 -0
  242. package/dist/cjs/af-heading.af-logo.af-nav-item.af-navbar.af-text.entry.cjs.js.map +1 -0
  243. package/dist/cjs/af-heading_5.cjs.entry.js +12 -11
  244. package/dist/cjs/af-icon-box.cjs.entry.js +4 -3
  245. package/dist/cjs/af-icon-box.entry.cjs.js.map +1 -0
  246. package/dist/cjs/af-icon-button.cjs.entry.js +4 -3
  247. package/dist/cjs/af-icon-button.entry.cjs.js.map +1 -0
  248. package/dist/cjs/af-icon-text.cjs.entry.js +4 -3
  249. package/dist/cjs/af-icon-text.entry.cjs.js.map +1 -0
  250. package/dist/cjs/af-icon.cjs.entry.js +4 -3
  251. package/dist/cjs/af-icon.entry.cjs.js.map +1 -0
  252. package/dist/cjs/af-illustrated-card.cjs.entry.js +4 -3
  253. package/dist/cjs/af-illustrated-card.entry.cjs.js.map +1 -0
  254. package/dist/cjs/af-image.cjs.entry.js +4 -3
  255. package/dist/cjs/af-image.entry.cjs.js.map +1 -0
  256. package/dist/cjs/af-in-page-banner.cjs.entry.js +4 -3
  257. package/dist/cjs/af-in-page-banner.entry.cjs.js.map +1 -0
  258. package/dist/cjs/af-inline.cjs.entry.js +4 -3
  259. package/dist/cjs/af-inline.entry.cjs.js.map +1 -0
  260. package/dist/cjs/af-input.cjs.entry.js +4 -3
  261. package/dist/cjs/af-input.entry.cjs.js.map +1 -0
  262. package/dist/cjs/af-logo-well.cjs.entry.js +4 -3
  263. package/dist/cjs/af-logo-well.entry.cjs.js.map +1 -0
  264. package/dist/cjs/af-nav-accordion-item.cjs.entry.js +5 -6
  265. package/dist/cjs/af-nav-accordion-item.entry.cjs.js.map +1 -0
  266. package/dist/cjs/af-nav-accordion.cjs.entry.js +4 -3
  267. package/dist/cjs/af-nav-accordion.entry.cjs.js.map +1 -0
  268. package/dist/cjs/af-nav-card.cjs.entry.js +4 -3
  269. package/dist/cjs/af-nav-card.entry.cjs.js.map +1 -0
  270. package/dist/cjs/af-nav-menu-nest.cjs.entry.js +4 -3
  271. package/dist/cjs/af-nav-menu-nest.entry.cjs.js.map +1 -0
  272. package/dist/cjs/af-nav-menu.cjs.entry.js +4 -3
  273. package/dist/cjs/af-nav-menu.entry.cjs.js.map +1 -0
  274. package/dist/cjs/af-number-badge.cjs.entry.js +4 -3
  275. package/dist/cjs/af-number-badge.entry.cjs.js.map +1 -0
  276. package/dist/cjs/af-progress-line.cjs.entry.js +4 -3
  277. package/dist/cjs/af-progress-line.entry.cjs.js.map +1 -0
  278. package/dist/cjs/af-radio.cjs.entry.js +4 -3
  279. package/dist/cjs/af-radio.entry.cjs.js.map +1 -0
  280. package/dist/cjs/af-section.cjs.entry.js +4 -3
  281. package/dist/cjs/af-section.entry.cjs.js.map +1 -0
  282. package/dist/cjs/af-show.cjs.entry.js +4 -3
  283. package/dist/cjs/af-show.entry.cjs.js.map +1 -0
  284. package/dist/cjs/af-social-link.cjs.entry.js +4 -3
  285. package/dist/cjs/af-social-link.entry.cjs.js.map +1 -0
  286. package/dist/cjs/af-spacer.cjs.entry.js +4 -3
  287. package/dist/cjs/af-spacer.entry.cjs.js.map +1 -0
  288. package/dist/cjs/af-split-section.cjs.entry.js +4 -3
  289. package/dist/cjs/af-split-section.entry.cjs.js.map +1 -0
  290. package/dist/cjs/af-stack.cjs.entry.js +4 -3
  291. package/dist/cjs/af-stack.entry.cjs.js.map +1 -0
  292. package/dist/cjs/af-stepper-step.cjs.entry.js +4 -3
  293. package/dist/cjs/af-stepper-step.entry.cjs.js.map +1 -0
  294. package/dist/cjs/af-stepper.cjs.entry.js +4 -3
  295. package/dist/cjs/af-stepper.entry.cjs.js.map +1 -0
  296. package/dist/cjs/af-switch.cjs.entry.js +4 -3
  297. package/dist/cjs/af-switch.entry.cjs.js.map +1 -0
  298. package/dist/cjs/af-tab-bar.cjs.entry.js +4 -3
  299. package/dist/cjs/af-tab-bar.entry.cjs.js.map +1 -0
  300. package/dist/cjs/af-tab.cjs.entry.js +4 -3
  301. package/dist/cjs/af-tab.entry.cjs.js.map +1 -0
  302. package/dist/cjs/af-tag.cjs.entry.js +4 -3
  303. package/dist/cjs/af-tag.entry.cjs.js.map +1 -0
  304. package/dist/cjs/af-testimonial-carousel.cjs.entry.js +4 -3
  305. package/dist/cjs/af-testimonial-carousel.entry.cjs.js.map +1 -0
  306. package/dist/cjs/af-testimonial-stat.cjs.entry.js +4 -3
  307. package/dist/cjs/af-testimonial-stat.entry.cjs.js.map +1 -0
  308. package/dist/cjs/af-testimonial.cjs.entry.js +4 -3
  309. package/dist/cjs/af-testimonial.entry.cjs.js.map +1 -0
  310. package/dist/cjs/af-text-image-nest.cjs.entry.js +4 -3
  311. package/dist/cjs/af-text-image-nest.entry.cjs.js.map +1 -0
  312. package/dist/cjs/af-text-image.cjs.entry.js +4 -3
  313. package/dist/cjs/af-text-image.entry.cjs.js.map +1 -0
  314. package/dist/cjs/af-textarea.cjs.entry.js +4 -3
  315. package/dist/cjs/af-textarea.entry.cjs.js.map +1 -0
  316. package/dist/cjs/af-theme-override.cjs.entry.js +4 -3
  317. package/dist/cjs/af-theme-override.entry.cjs.js.map +1 -0
  318. package/dist/cjs/af-typography-lockup.cjs.entry.js +4 -3
  319. package/dist/cjs/af-typography-lockup.entry.cjs.js.map +1 -0
  320. package/dist/cjs/af-video-container.cjs.entry.js +4 -3
  321. package/dist/cjs/af-video-container.entry.cjs.js.map +1 -0
  322. package/dist/cjs/af-visually-hidden.cjs.entry.js +4 -3
  323. package/dist/cjs/af-visually-hidden.entry.cjs.js.map +1 -0
  324. package/dist/cjs/affinda.cjs.js +4 -3
  325. package/dist/cjs/affinda.cjs.js.map +1 -0
  326. package/dist/cjs/{index-C1ry3YPK.js → index-CcvVbx1D.js} +260 -462
  327. package/dist/cjs/index-CcvVbx1D.js.map +1 -0
  328. package/dist/cjs/index.cjs.js +21 -20
  329. package/dist/cjs/index.cjs.js.map +1 -0
  330. package/dist/cjs/loader.cjs.js +3 -2
  331. package/dist/cjs/loader.cjs.js.map +1 -0
  332. package/dist/collection/collection-manifest.json +2 -3
  333. package/dist/collection/components/af-accordion/af-accordion.js +1 -0
  334. package/dist/collection/components/af-accordion/af-accordion.js.map +1 -0
  335. package/dist/collection/components/af-accordion-item/af-accordion-item.js +1 -0
  336. package/dist/collection/components/af-accordion-item/af-accordion-item.js.map +1 -0
  337. package/dist/collection/components/af-aspect-ratio/af-aspect-ratio.js +1 -0
  338. package/dist/collection/components/af-aspect-ratio/af-aspect-ratio.js.map +1 -0
  339. package/dist/collection/components/af-button/af-button.js +1 -0
  340. package/dist/collection/components/af-button/af-button.js.map +1 -0
  341. package/dist/collection/components/af-button-group/af-button-group.js +1 -0
  342. package/dist/collection/components/af-button-group/af-button-group.js.map +1 -0
  343. package/dist/collection/components/af-card/af-card.js +1 -0
  344. package/dist/collection/components/af-card/af-card.js.map +1 -0
  345. package/dist/collection/components/af-center/af-center.js +1 -0
  346. package/dist/collection/components/af-center/af-center.js.map +1 -0
  347. package/dist/collection/components/af-checkbox/af-checkbox.js +1 -0
  348. package/dist/collection/components/af-checkbox/af-checkbox.js.map +1 -0
  349. package/dist/collection/components/af-client-carousel/af-client-carousel.js +1 -0
  350. package/dist/collection/components/af-client-carousel/af-client-carousel.js.map +1 -0
  351. package/dist/collection/components/af-color-swatch/af-color-swatch.js +1 -0
  352. package/dist/collection/components/af-color-swatch/af-color-swatch.js.map +1 -0
  353. package/dist/collection/components/af-contact-item/af-contact-item.js +1 -0
  354. package/dist/collection/components/af-contact-item/af-contact-item.js.map +1 -0
  355. package/dist/collection/components/af-container/af-container.js +1 -0
  356. package/dist/collection/components/af-container/af-container.js.map +1 -0
  357. package/dist/collection/components/af-divider/af-divider.js +1 -0
  358. package/dist/collection/components/af-divider/af-divider.js.map +1 -0
  359. package/dist/collection/components/af-feature-accordion/af-feature-accordion.js +1 -0
  360. package/dist/collection/components/af-feature-accordion/af-feature-accordion.js.map +1 -0
  361. package/dist/collection/components/af-feature-card/af-feature-card.js +1 -0
  362. package/dist/collection/components/af-feature-card/af-feature-card.js.map +1 -0
  363. package/dist/collection/components/af-feature-grid/af-feature-grid.js +1 -0
  364. package/dist/collection/components/af-feature-grid/af-feature-grid.js.map +1 -0
  365. package/dist/collection/components/af-fieldset/af-fieldset.js +1 -0
  366. package/dist/collection/components/af-fieldset/af-fieldset.js.map +1 -0
  367. package/dist/collection/components/af-footer/af-footer.js +1 -0
  368. package/dist/collection/components/af-footer/af-footer.js.map +1 -0
  369. package/dist/collection/components/af-footer-column/af-footer-column.js +1 -0
  370. package/dist/collection/components/af-footer-column/af-footer-column.js.map +1 -0
  371. package/dist/collection/components/af-footer-link/af-footer-link.js +1 -0
  372. package/dist/collection/components/af-footer-link/af-footer-link.js.map +1 -0
  373. package/dist/collection/components/af-grid/af-grid.js +1 -0
  374. package/dist/collection/components/af-grid/af-grid.js.map +1 -0
  375. package/dist/collection/components/af-grid-callout/af-grid-callout.js +1 -0
  376. package/dist/collection/components/af-grid-callout/af-grid-callout.js.map +1 -0
  377. package/dist/collection/components/af-heading/af-heading.js +1 -0
  378. package/dist/collection/components/af-heading/af-heading.js.map +1 -0
  379. package/dist/collection/components/af-icon/af-icon.js +3 -3
  380. package/dist/collection/components/af-icon/af-icon.js.map +1 -0
  381. package/dist/collection/components/af-icon-box/af-icon-box.js +3 -3
  382. package/dist/collection/components/af-icon-box/af-icon-box.js.map +1 -0
  383. package/dist/collection/components/af-icon-button/af-icon-button.js +1 -0
  384. package/dist/collection/components/af-icon-button/af-icon-button.js.map +1 -0
  385. package/dist/collection/components/af-icon-text/af-icon-text.js +3 -3
  386. package/dist/collection/components/af-icon-text/af-icon-text.js.map +1 -0
  387. package/dist/collection/components/af-illustrated-card/af-illustrated-card.js +1 -0
  388. package/dist/collection/components/af-illustrated-card/af-illustrated-card.js.map +1 -0
  389. package/dist/collection/components/af-image/af-image.js +1 -0
  390. package/dist/collection/components/af-image/af-image.js.map +1 -0
  391. package/dist/collection/components/af-in-page-banner/af-in-page-banner.css +7 -7
  392. package/dist/collection/components/af-in-page-banner/af-in-page-banner.js +1 -0
  393. package/dist/collection/components/af-in-page-banner/af-in-page-banner.js.map +1 -0
  394. package/dist/collection/components/af-inline/af-inline.js +1 -0
  395. package/dist/collection/components/af-inline/af-inline.js.map +1 -0
  396. package/dist/collection/components/af-input/af-input.js +1 -0
  397. package/dist/collection/components/af-input/af-input.js.map +1 -0
  398. package/dist/collection/components/af-logo/af-logo.js +1 -0
  399. package/dist/collection/components/af-logo/af-logo.js.map +1 -0
  400. package/dist/collection/components/af-logo-well/af-logo-well.js +1 -0
  401. package/dist/collection/components/af-logo-well/af-logo-well.js.map +1 -0
  402. package/dist/collection/components/af-nav-accordion/af-nav-accordion.js +1 -0
  403. package/dist/collection/components/af-nav-accordion/af-nav-accordion.js.map +1 -0
  404. package/dist/collection/components/af-nav-accordion-item/af-nav-accordion-item.js +1 -0
  405. package/dist/collection/components/af-nav-accordion-item/af-nav-accordion-item.js.map +1 -0
  406. package/dist/collection/components/af-nav-card/af-nav-card.js +1 -0
  407. package/dist/collection/components/af-nav-card/af-nav-card.js.map +1 -0
  408. package/dist/collection/components/af-nav-item/af-nav-item.js +1 -0
  409. package/dist/collection/components/af-nav-item/af-nav-item.js.map +1 -0
  410. package/dist/collection/components/af-nav-menu/af-nav-menu.js +1 -0
  411. package/dist/collection/components/af-nav-menu/af-nav-menu.js.map +1 -0
  412. package/dist/collection/components/af-nav-menu-nest/af-nav-menu-nest.js +1 -0
  413. package/dist/collection/components/af-nav-menu-nest/af-nav-menu-nest.js.map +1 -0
  414. package/dist/collection/components/af-navbar/af-navbar.js +1 -0
  415. package/dist/collection/components/af-navbar/af-navbar.js.map +1 -0
  416. package/dist/collection/components/af-number-badge/af-number-badge.js +3 -2
  417. package/dist/collection/components/af-number-badge/af-number-badge.js.map +1 -0
  418. package/dist/collection/components/af-progress-line/af-progress-line.js +1 -0
  419. package/dist/collection/components/af-progress-line/af-progress-line.js.map +1 -0
  420. package/dist/collection/components/af-radio/af-radio.js +1 -0
  421. package/dist/collection/components/af-radio/af-radio.js.map +1 -0
  422. package/dist/collection/components/af-section/af-section.js +1 -0
  423. package/dist/collection/components/af-section/af-section.js.map +1 -0
  424. package/dist/collection/components/af-show/af-show.js +1 -0
  425. package/dist/collection/components/af-show/af-show.js.map +1 -0
  426. package/dist/collection/components/af-social-link/af-social-link.js +1 -0
  427. package/dist/collection/components/af-social-link/af-social-link.js.map +1 -0
  428. package/dist/collection/components/af-spacer/af-spacer.js +1 -0
  429. package/dist/collection/components/af-spacer/af-spacer.js.map +1 -0
  430. package/dist/collection/components/af-split-section/af-split-section.js +1 -0
  431. package/dist/collection/components/af-split-section/af-split-section.js.map +1 -0
  432. package/dist/collection/components/af-stack/af-stack.js +1 -0
  433. package/dist/collection/components/af-stack/af-stack.js.map +1 -0
  434. package/dist/collection/components/af-stepper/af-stepper.js +1 -0
  435. package/dist/collection/components/af-stepper/af-stepper.js.map +1 -0
  436. package/dist/collection/components/af-stepper-step/af-stepper-step.js +1 -0
  437. package/dist/collection/components/af-stepper-step/af-stepper-step.js.map +1 -0
  438. package/dist/collection/components/af-switch/af-switch.js +1 -0
  439. package/dist/collection/components/af-switch/af-switch.js.map +1 -0
  440. package/dist/collection/components/af-tab/af-tab.js +2 -1
  441. package/dist/collection/components/af-tab/af-tab.js.map +1 -0
  442. package/dist/collection/components/af-tab-bar/af-tab-bar.js +3 -2
  443. package/dist/collection/components/af-tab-bar/af-tab-bar.js.map +1 -0
  444. package/dist/collection/components/af-tag/af-tag.js +3 -2
  445. package/dist/collection/components/af-tag/af-tag.js.map +1 -0
  446. package/dist/collection/components/af-testimonial/af-testimonial.js +1 -0
  447. package/dist/collection/components/af-testimonial/af-testimonial.js.map +1 -0
  448. package/dist/collection/components/af-testimonial-carousel/af-testimonial-carousel.js +1 -0
  449. package/dist/collection/components/af-testimonial-carousel/af-testimonial-carousel.js.map +1 -0
  450. package/dist/collection/components/af-testimonial-stat/af-testimonial-stat.js +1 -0
  451. package/dist/collection/components/af-testimonial-stat/af-testimonial-stat.js.map +1 -0
  452. package/dist/collection/components/af-text/af-text.js +1 -0
  453. package/dist/collection/components/af-text/af-text.js.map +1 -0
  454. package/dist/collection/components/af-text-image/af-text-image.js +1 -0
  455. package/dist/collection/components/af-text-image/af-text-image.js.map +1 -0
  456. package/dist/collection/components/af-text-image-nest/af-text-image-nest.js +1 -0
  457. package/dist/collection/components/af-text-image-nest/af-text-image-nest.js.map +1 -0
  458. package/dist/collection/components/af-textarea/af-textarea.js +1 -0
  459. package/dist/collection/components/af-textarea/af-textarea.js.map +1 -0
  460. package/dist/collection/components/af-theme-override/af-theme-override.js +1 -0
  461. package/dist/collection/components/af-theme-override/af-theme-override.js.map +1 -0
  462. package/dist/collection/components/af-typography-lockup/af-typography-lockup.js +1 -0
  463. package/dist/collection/components/af-typography-lockup/af-typography-lockup.js.map +1 -0
  464. package/dist/collection/components/af-video-container/af-video-container.js +1 -0
  465. package/dist/collection/components/af-video-container/af-video-container.js.map +1 -0
  466. package/dist/collection/components/af-visually-hidden/af-visually-hidden.js +1 -0
  467. package/dist/collection/components/af-visually-hidden/af-visually-hidden.js.map +1 -0
  468. package/dist/collection/components.js +1 -0
  469. package/dist/collection/components.js.map +1 -0
  470. package/dist/collection/index.js +1 -0
  471. package/dist/collection/index.js.map +1 -0
  472. package/dist/components/af-accordion-item.js +107 -1
  473. package/dist/components/af-accordion-item.js.map +1 -0
  474. package/dist/components/af-accordion.js +128 -1
  475. package/dist/components/af-accordion.js.map +1 -0
  476. package/dist/components/af-aspect-ratio.js +9 -1
  477. package/dist/components/af-aspect-ratio.js.map +1 -0
  478. package/dist/components/af-button-group.js +9 -1
  479. package/dist/components/af-button-group.js.map +1 -0
  480. package/dist/components/af-button.js +9 -1
  481. package/dist/components/af-button.js.map +1 -0
  482. package/dist/components/af-card.js +9 -1
  483. package/dist/components/af-card.js.map +1 -0
  484. package/dist/components/af-center.js +66 -1
  485. package/dist/components/af-center.js.map +1 -0
  486. package/dist/components/af-checkbox.js +9 -1
  487. package/dist/components/af-checkbox.js.map +1 -0
  488. package/dist/components/af-client-carousel.js +80 -1
  489. package/dist/components/af-client-carousel.js.map +1 -0
  490. package/dist/components/af-color-swatch.js +9 -1
  491. package/dist/components/af-color-swatch.js.map +1 -0
  492. package/dist/components/af-contact-item.js +44 -1
  493. package/dist/components/af-contact-item.js.map +1 -0
  494. package/dist/components/af-container.js +9 -1
  495. package/dist/components/af-container.js.map +1 -0
  496. package/dist/components/af-divider.js +66 -1
  497. package/dist/components/af-divider.js.map +1 -0
  498. package/dist/components/af-feature-accordion.js +136 -1
  499. package/dist/components/af-feature-accordion.js.map +1 -0
  500. package/dist/components/af-feature-card.js +9 -1
  501. package/dist/components/af-feature-card.js.map +1 -0
  502. package/dist/components/af-feature-grid.js +124 -1
  503. package/dist/components/af-feature-grid.js.map +1 -0
  504. package/dist/components/af-fieldset.js +9 -1
  505. package/dist/components/af-fieldset.js.map +1 -0
  506. package/dist/components/af-footer-column.js +41 -1
  507. package/dist/components/af-footer-column.js.map +1 -0
  508. package/dist/components/af-footer-link.js +44 -1
  509. package/dist/components/af-footer-link.js.map +1 -0
  510. package/dist/components/af-footer.js +53 -1
  511. package/dist/components/af-footer.js.map +1 -0
  512. package/dist/components/af-grid-callout.js +82 -1
  513. package/dist/components/af-grid-callout.js.map +1 -0
  514. package/dist/components/af-grid.js +71 -1
  515. package/dist/components/af-grid.js.map +1 -0
  516. package/dist/components/af-heading.js +9 -1
  517. package/dist/components/af-heading.js.map +1 -0
  518. package/dist/components/af-icon-box.js +9 -1
  519. package/dist/components/af-icon-box.js.map +1 -0
  520. package/dist/components/af-icon-button.js +9 -1
  521. package/dist/components/af-icon-button.js.map +1 -0
  522. package/dist/components/af-icon-text.js +78 -1
  523. package/dist/components/af-icon-text.js.map +1 -0
  524. package/dist/components/af-icon.js +9 -1
  525. package/dist/components/af-icon.js.map +1 -0
  526. package/dist/components/af-illustrated-card.js +9 -1
  527. package/dist/components/af-illustrated-card.js.map +1 -0
  528. package/dist/components/af-image.js +9 -1
  529. package/dist/components/af-image.js.map +1 -0
  530. package/dist/components/af-in-page-banner.js +82 -1
  531. package/dist/components/af-in-page-banner.js.map +1 -0
  532. package/dist/components/af-inline.js +83 -1
  533. package/dist/components/af-inline.js.map +1 -0
  534. package/dist/components/af-input.js +9 -1
  535. package/dist/components/af-input.js.map +1 -0
  536. package/dist/components/af-logo-well.js +38 -1
  537. package/dist/components/af-logo-well.js.map +1 -0
  538. package/dist/components/af-logo.js +9 -1
  539. package/dist/components/af-logo.js.map +1 -0
  540. package/dist/components/af-nav-accordion-item.js +133 -1
  541. package/dist/components/af-nav-accordion-item.js.map +1 -0
  542. package/dist/components/af-nav-accordion.js +106 -1
  543. package/dist/components/af-nav-accordion.js.map +1 -0
  544. package/dist/components/af-nav-card.js +62 -1
  545. package/dist/components/af-nav-card.js.map +1 -0
  546. package/dist/components/af-nav-item.js +9 -1
  547. package/dist/components/af-nav-item.js.map +1 -0
  548. package/dist/components/af-nav-menu-nest.js +67 -1
  549. package/dist/components/af-nav-menu-nest.js.map +1 -0
  550. package/dist/components/af-nav-menu.js +65 -1
  551. package/dist/components/af-nav-menu.js.map +1 -0
  552. package/dist/components/af-navbar.js +9 -1
  553. package/dist/components/af-navbar.js.map +1 -0
  554. package/dist/components/af-number-badge.js +66 -1
  555. package/dist/components/af-number-badge.js.map +1 -0
  556. package/dist/components/af-progress-line.js +9 -1
  557. package/dist/components/af-progress-line.js.map +1 -0
  558. package/dist/components/af-radio.js +9 -1
  559. package/dist/components/af-radio.js.map +1 -0
  560. package/dist/components/af-section.js +54 -1
  561. package/dist/components/af-section.js.map +1 -0
  562. package/dist/components/af-show.js +46 -1
  563. package/dist/components/af-show.js.map +1 -0
  564. package/dist/components/af-social-link.js +63 -1
  565. package/dist/components/af-social-link.js.map +1 -0
  566. package/dist/components/af-spacer.js +69 -1
  567. package/dist/components/af-spacer.js.map +1 -0
  568. package/dist/components/af-split-section.js +71 -1
  569. package/dist/components/af-split-section.js.map +1 -0
  570. package/dist/components/af-stack.js +90 -1
  571. package/dist/components/af-stack.js.map +1 -0
  572. package/dist/components/af-stepper-step.js +44 -1
  573. package/dist/components/af-stepper-step.js.map +1 -0
  574. package/dist/components/af-stepper.js +55 -1
  575. package/dist/components/af-stepper.js.map +1 -0
  576. package/dist/components/af-switch.js +9 -1
  577. package/dist/components/af-switch.js.map +1 -0
  578. package/dist/components/af-tab-bar.js +9 -1
  579. package/dist/components/af-tab-bar.js.map +1 -0
  580. package/dist/components/af-tab.js +9 -1
  581. package/dist/components/af-tab.js.map +1 -0
  582. package/dist/components/af-tag.js +9 -1
  583. package/dist/components/af-tag.js.map +1 -0
  584. package/dist/components/af-testimonial-carousel.js +131 -1
  585. package/dist/components/af-testimonial-carousel.js.map +1 -0
  586. package/dist/components/af-testimonial-stat.js +57 -1
  587. package/dist/components/af-testimonial-stat.js.map +1 -0
  588. package/dist/components/af-testimonial.js +88 -1
  589. package/dist/components/af-testimonial.js.map +1 -0
  590. package/dist/components/af-text-image-nest.js +51 -1
  591. package/dist/components/af-text-image-nest.js.map +1 -0
  592. package/dist/components/af-text-image.js +95 -1
  593. package/dist/components/af-text-image.js.map +1 -0
  594. package/dist/components/af-text.js +9 -1
  595. package/dist/components/af-text.js.map +1 -0
  596. package/dist/components/af-textarea.js +9 -1
  597. package/dist/components/af-textarea.js.map +1 -0
  598. package/dist/components/af-theme-override.js +44 -1
  599. package/dist/components/af-theme-override.js.map +1 -0
  600. package/dist/components/af-typography-lockup.js +9 -1
  601. package/dist/components/af-typography-lockup.js.map +1 -0
  602. package/dist/components/af-video-container.js +70 -1
  603. package/dist/components/af-video-container.js.map +1 -0
  604. package/dist/components/af-visually-hidden.js +45 -1
  605. package/dist/components/af-visually-hidden.js.map +1 -0
  606. package/dist/components/index.d.ts +0 -2
  607. package/dist/components/index.js +27 -1
  608. package/dist/components/index.js.map +1 -0
  609. package/dist/components/p-B3Yr4Hxx.js +141 -0
  610. package/dist/components/p-B3Yr4Hxx.js.map +1 -0
  611. package/dist/components/p-BHAWxoQE.js +55 -0
  612. package/dist/components/p-BHAWxoQE.js.map +1 -0
  613. package/dist/components/p-BO4blShf.js +53 -0
  614. package/dist/components/p-BO4blShf.js.map +1 -0
  615. package/dist/components/p-Bw8fdMnn.js +59 -0
  616. package/dist/components/p-Bw8fdMnn.js.map +1 -0
  617. package/dist/components/p-C0R_vg0S.js +48 -0
  618. package/dist/components/p-C0R_vg0S.js.map +1 -0
  619. package/dist/components/p-CAUqW6Mp.js +45 -0
  620. package/dist/components/p-CAUqW6Mp.js.map +1 -0
  621. package/dist/components/p-CB9GFAlk.js +89 -0
  622. package/dist/components/p-CB9GFAlk.js.map +1 -0
  623. package/dist/components/p-CHLm_AuW.js +74 -0
  624. package/dist/components/p-CHLm_AuW.js.map +1 -0
  625. package/dist/components/p-CKcuq0NU.js +48 -0
  626. package/dist/components/p-CKcuq0NU.js.map +1 -0
  627. package/dist/components/p-CNuja1ax.js +92 -0
  628. package/dist/components/p-CNuja1ax.js.map +1 -0
  629. package/dist/components/p-CSsp_M05.js +70 -0
  630. package/dist/components/p-CSsp_M05.js.map +1 -0
  631. package/dist/components/p-CqQyDZ-4.js +1781 -0
  632. package/dist/components/p-CqQyDZ-4.js.map +1 -0
  633. package/dist/components/p-D30gSxh2.js +50 -0
  634. package/dist/components/p-D30gSxh2.js.map +1 -0
  635. package/dist/components/p-D3oGtcJ5.js +93 -0
  636. package/dist/components/p-D3oGtcJ5.js.map +1 -0
  637. package/dist/components/p-DAYoQm46.js +71 -0
  638. package/dist/components/p-DAYoQm46.js.map +1 -0
  639. package/dist/components/p-DCu8UsJv.js +35 -0
  640. package/dist/components/p-DCu8UsJv.js.map +1 -0
  641. package/dist/components/p-DENib4OL.js +58 -0
  642. package/dist/components/p-DENib4OL.js.map +1 -0
  643. package/dist/components/p-DGBMGvZK.js +57 -0
  644. package/dist/components/p-DGBMGvZK.js.map +1 -0
  645. package/dist/components/p-DMOGClIa.js +44 -0
  646. package/dist/components/p-DMOGClIa.js.map +1 -0
  647. package/dist/components/p-DRujYIJW.js +196 -0
  648. package/dist/components/p-DRujYIJW.js.map +1 -0
  649. package/dist/components/p-DkaLi-uL.js +102 -0
  650. package/dist/components/p-DkaLi-uL.js.map +1 -0
  651. package/dist/components/p-DqgLTGE0.js +108 -0
  652. package/dist/components/p-DqgLTGE0.js.map +1 -0
  653. package/dist/components/p-DwhGQrZK.js +52 -0
  654. package/dist/components/p-DwhGQrZK.js.map +1 -0
  655. package/dist/components/p-Dxa6cHAb.js +81 -0
  656. package/dist/components/p-Dxa6cHAb.js.map +1 -0
  657. package/dist/components/p-Dz4dEIxw.js +127 -0
  658. package/dist/components/p-Dz4dEIxw.js.map +1 -0
  659. package/dist/components/p-N0xV1Erp.js +151 -0
  660. package/dist/components/p-N0xV1Erp.js.map +1 -0
  661. package/dist/components/p-TfjpcU9q.js +68 -0
  662. package/dist/components/p-TfjpcU9q.js.map +1 -0
  663. package/dist/components/p-XrKBGe-M.js +94 -0
  664. package/dist/components/p-XrKBGe-M.js.map +1 -0
  665. package/dist/components/p-aAVeavhK.js +372 -0
  666. package/dist/components/p-aAVeavhK.js.map +1 -0
  667. package/dist/esm/af-accordion-item.entry.js +5 -6
  668. package/dist/esm/af-accordion-item.entry.js.map +1 -0
  669. package/dist/esm/af-accordion.entry.js +5 -6
  670. package/dist/esm/af-accordion.entry.js.map +1 -0
  671. package/dist/esm/af-aspect-ratio.entry.js +4 -3
  672. package/dist/esm/af-aspect-ratio.entry.js.map +1 -0
  673. package/dist/esm/af-button-group.entry.js +4 -3
  674. package/dist/esm/af-button-group.entry.js.map +1 -0
  675. package/dist/esm/af-button.entry.js +4 -3
  676. package/dist/esm/af-button.entry.js.map +1 -0
  677. package/dist/esm/af-card.entry.js +4 -3
  678. package/dist/esm/af-card.entry.js.map +1 -0
  679. package/dist/esm/af-center.entry.js +4 -3
  680. package/dist/esm/af-center.entry.js.map +1 -0
  681. package/dist/esm/af-checkbox.entry.js +4 -3
  682. package/dist/esm/af-checkbox.entry.js.map +1 -0
  683. package/dist/esm/af-client-carousel.entry.js +4 -3
  684. package/dist/esm/af-client-carousel.entry.js.map +1 -0
  685. package/dist/esm/af-color-swatch.entry.js +4 -3
  686. package/dist/esm/af-color-swatch.entry.js.map +1 -0
  687. package/dist/esm/af-contact-item.entry.js +4 -3
  688. package/dist/esm/af-contact-item.entry.js.map +1 -0
  689. package/dist/esm/af-container.entry.js +4 -3
  690. package/dist/esm/af-container.entry.js.map +1 -0
  691. package/dist/esm/af-divider.entry.js +4 -3
  692. package/dist/esm/af-divider.entry.js.map +1 -0
  693. package/dist/esm/af-feature-accordion.entry.js +5 -6
  694. package/dist/esm/af-feature-accordion.entry.js.map +1 -0
  695. package/dist/esm/af-feature-card.entry.js +4 -3
  696. package/dist/esm/af-feature-card.entry.js.map +1 -0
  697. package/dist/esm/af-feature-grid.entry.js +5 -6
  698. package/dist/esm/af-feature-grid.entry.js.map +1 -0
  699. package/dist/esm/af-fieldset.entry.js +4 -3
  700. package/dist/esm/af-fieldset.entry.js.map +1 -0
  701. package/dist/esm/af-footer-column.entry.js +4 -3
  702. package/dist/esm/af-footer-column.entry.js.map +1 -0
  703. package/dist/esm/af-footer-link.entry.js +4 -3
  704. package/dist/esm/af-footer-link.entry.js.map +1 -0
  705. package/dist/esm/af-footer.entry.js +4 -3
  706. package/dist/esm/af-footer.entry.js.map +1 -0
  707. package/dist/esm/af-grid-callout.entry.js +4 -3
  708. package/dist/esm/af-grid-callout.entry.js.map +1 -0
  709. package/dist/esm/af-grid.entry.js +4 -3
  710. package/dist/esm/af-grid.entry.js.map +1 -0
  711. package/dist/esm/af-heading.af-logo.af-nav-item.af-navbar.af-text.entry.js.map +1 -0
  712. package/dist/esm/af-heading_5.entry.js +12 -11
  713. package/dist/esm/af-icon-box.entry.js +4 -3
  714. package/dist/esm/af-icon-box.entry.js.map +1 -0
  715. package/dist/esm/af-icon-button.entry.js +4 -3
  716. package/dist/esm/af-icon-button.entry.js.map +1 -0
  717. package/dist/esm/af-icon-text.entry.js +4 -3
  718. package/dist/esm/af-icon-text.entry.js.map +1 -0
  719. package/dist/esm/af-icon.entry.js +4 -3
  720. package/dist/esm/af-icon.entry.js.map +1 -0
  721. package/dist/esm/af-illustrated-card.entry.js +4 -3
  722. package/dist/esm/af-illustrated-card.entry.js.map +1 -0
  723. package/dist/esm/af-image.entry.js +4 -3
  724. package/dist/esm/af-image.entry.js.map +1 -0
  725. package/dist/esm/af-in-page-banner.entry.js +4 -3
  726. package/dist/esm/af-in-page-banner.entry.js.map +1 -0
  727. package/dist/esm/af-inline.entry.js +4 -3
  728. package/dist/esm/af-inline.entry.js.map +1 -0
  729. package/dist/esm/af-input.entry.js +4 -3
  730. package/dist/esm/af-input.entry.js.map +1 -0
  731. package/dist/esm/af-logo-well.entry.js +4 -3
  732. package/dist/esm/af-logo-well.entry.js.map +1 -0
  733. package/dist/esm/af-nav-accordion-item.entry.js +5 -6
  734. package/dist/esm/af-nav-accordion-item.entry.js.map +1 -0
  735. package/dist/esm/af-nav-accordion.entry.js +4 -3
  736. package/dist/esm/af-nav-accordion.entry.js.map +1 -0
  737. package/dist/esm/af-nav-card.entry.js +4 -3
  738. package/dist/esm/af-nav-card.entry.js.map +1 -0
  739. package/dist/esm/af-nav-menu-nest.entry.js +4 -3
  740. package/dist/esm/af-nav-menu-nest.entry.js.map +1 -0
  741. package/dist/esm/af-nav-menu.entry.js +4 -3
  742. package/dist/esm/af-nav-menu.entry.js.map +1 -0
  743. package/dist/esm/af-number-badge.entry.js +4 -3
  744. package/dist/esm/af-number-badge.entry.js.map +1 -0
  745. package/dist/esm/af-progress-line.entry.js +4 -3
  746. package/dist/esm/af-progress-line.entry.js.map +1 -0
  747. package/dist/esm/af-radio.entry.js +4 -3
  748. package/dist/esm/af-radio.entry.js.map +1 -0
  749. package/dist/esm/af-section.entry.js +4 -3
  750. package/dist/esm/af-section.entry.js.map +1 -0
  751. package/dist/esm/af-show.entry.js +4 -3
  752. package/dist/esm/af-show.entry.js.map +1 -0
  753. package/dist/esm/af-social-link.entry.js +4 -3
  754. package/dist/esm/af-social-link.entry.js.map +1 -0
  755. package/dist/esm/af-spacer.entry.js +4 -3
  756. package/dist/esm/af-spacer.entry.js.map +1 -0
  757. package/dist/esm/af-split-section.entry.js +4 -3
  758. package/dist/esm/af-split-section.entry.js.map +1 -0
  759. package/dist/esm/af-stack.entry.js +4 -3
  760. package/dist/esm/af-stack.entry.js.map +1 -0
  761. package/dist/esm/af-stepper-step.entry.js +4 -3
  762. package/dist/esm/af-stepper-step.entry.js.map +1 -0
  763. package/dist/esm/af-stepper.entry.js +4 -3
  764. package/dist/esm/af-stepper.entry.js.map +1 -0
  765. package/dist/esm/af-switch.entry.js +4 -3
  766. package/dist/esm/af-switch.entry.js.map +1 -0
  767. package/dist/esm/af-tab-bar.entry.js +4 -3
  768. package/dist/esm/af-tab-bar.entry.js.map +1 -0
  769. package/dist/esm/af-tab.entry.js +4 -3
  770. package/dist/esm/af-tab.entry.js.map +1 -0
  771. package/dist/esm/af-tag.entry.js +4 -3
  772. package/dist/esm/af-tag.entry.js.map +1 -0
  773. package/dist/esm/af-testimonial-carousel.entry.js +4 -3
  774. package/dist/esm/af-testimonial-carousel.entry.js.map +1 -0
  775. package/dist/esm/af-testimonial-stat.entry.js +4 -3
  776. package/dist/esm/af-testimonial-stat.entry.js.map +1 -0
  777. package/dist/esm/af-testimonial.entry.js +4 -3
  778. package/dist/esm/af-testimonial.entry.js.map +1 -0
  779. package/dist/esm/af-text-image-nest.entry.js +4 -3
  780. package/dist/esm/af-text-image-nest.entry.js.map +1 -0
  781. package/dist/esm/af-text-image.entry.js +4 -3
  782. package/dist/esm/af-text-image.entry.js.map +1 -0
  783. package/dist/esm/af-textarea.entry.js +4 -3
  784. package/dist/esm/af-textarea.entry.js.map +1 -0
  785. package/dist/esm/af-theme-override.entry.js +4 -3
  786. package/dist/esm/af-theme-override.entry.js.map +1 -0
  787. package/dist/esm/af-typography-lockup.entry.js +4 -3
  788. package/dist/esm/af-typography-lockup.entry.js.map +1 -0
  789. package/dist/esm/af-video-container.entry.js +4 -3
  790. package/dist/esm/af-video-container.entry.js.map +1 -0
  791. package/dist/esm/af-visually-hidden.entry.js +4 -3
  792. package/dist/esm/af-visually-hidden.entry.js.map +1 -0
  793. package/dist/esm/affinda.js +5 -4
  794. package/dist/esm/affinda.js.map +1 -0
  795. package/dist/esm/{index-CPfAC9fk.js → index-nb89SRN6.js} +260 -462
  796. package/dist/esm/index-nb89SRN6.js.map +1 -0
  797. package/dist/esm/index.js +3 -2
  798. package/dist/esm/index.js.map +1 -0
  799. package/dist/esm/loader.js +4 -3
  800. package/dist/esm/loader.js.map +1 -0
  801. package/dist/types/components.d.ts +131 -508
  802. package/dist/types/stencil-public-runtime.d.ts +6 -110
  803. package/package.json +17 -13
  804. package/dist/affinda/p-00a226ba.entry.js +0 -1
  805. package/dist/affinda/p-020bd9db.entry.js +0 -1
  806. package/dist/affinda/p-08dc48a4.entry.js +0 -1
  807. package/dist/affinda/p-0979ad4d.entry.js +0 -1
  808. package/dist/affinda/p-14c85efd.entry.js +0 -1
  809. package/dist/affinda/p-1e37fea2.entry.js +0 -1
  810. package/dist/affinda/p-1f810e9c.entry.js +0 -1
  811. package/dist/affinda/p-203a908b.entry.js +0 -1
  812. package/dist/affinda/p-23f9e0cc.entry.js +0 -1
  813. package/dist/affinda/p-29d0a985.entry.js +0 -1
  814. package/dist/affinda/p-2ab645a3.entry.js +0 -1
  815. package/dist/affinda/p-30c704f8.entry.js +0 -1
  816. package/dist/affinda/p-37977b9d.entry.js +0 -1
  817. package/dist/affinda/p-3b3f69a5.entry.js +0 -1
  818. package/dist/affinda/p-40456eb5.entry.js +0 -1
  819. package/dist/affinda/p-4196ab5d.entry.js +0 -1
  820. package/dist/affinda/p-4521a8f3.entry.js +0 -1
  821. package/dist/affinda/p-46c9b92e.entry.js +0 -1
  822. package/dist/affinda/p-485cfd5d.entry.js +0 -1
  823. package/dist/affinda/p-50a6a219.entry.js +0 -1
  824. package/dist/affinda/p-5136a894.entry.js +0 -1
  825. package/dist/affinda/p-542fd771.entry.js +0 -1
  826. package/dist/affinda/p-666fc4a6.entry.js +0 -1
  827. package/dist/affinda/p-687f157a.entry.js +0 -1
  828. package/dist/affinda/p-76b6d6e0.entry.js +0 -1
  829. package/dist/affinda/p-81eb85ec.entry.js +0 -1
  830. package/dist/affinda/p-82674a06.entry.js +0 -1
  831. package/dist/affinda/p-82fb88df.entry.js +0 -1
  832. package/dist/affinda/p-87daf220.entry.js +0 -1
  833. package/dist/affinda/p-90edefa8.entry.js +0 -1
  834. package/dist/affinda/p-9133ff23.entry.js +0 -1
  835. package/dist/affinda/p-92904a41.entry.js +0 -1
  836. package/dist/affinda/p-CPfAC9fk.js +0 -2
  837. package/dist/affinda/p-a12a37b6.entry.js +0 -1
  838. package/dist/affinda/p-a5179afb.entry.js +0 -1
  839. package/dist/affinda/p-a6210fab.entry.js +0 -1
  840. package/dist/affinda/p-ace3c850.entry.js +0 -1
  841. package/dist/affinda/p-ae43f07b.entry.js +0 -1
  842. package/dist/affinda/p-aec05709.entry.js +0 -1
  843. package/dist/affinda/p-b049555b.entry.js +0 -1
  844. package/dist/affinda/p-b477c08a.entry.js +0 -1
  845. package/dist/affinda/p-b8dde234.entry.js +0 -1
  846. package/dist/affinda/p-c03893bd.entry.js +0 -1
  847. package/dist/affinda/p-ca14e17a.entry.js +0 -1
  848. package/dist/affinda/p-cb889d6b.entry.js +0 -1
  849. package/dist/affinda/p-cd138311.entry.js +0 -1
  850. package/dist/affinda/p-cdfaffc6.entry.js +0 -1
  851. package/dist/affinda/p-cfb90374.entry.js +0 -1
  852. package/dist/affinda/p-cfe018f1.entry.js +0 -1
  853. package/dist/affinda/p-d3e3653e.entry.js +0 -1
  854. package/dist/affinda/p-d7129564.entry.js +0 -1
  855. package/dist/affinda/p-d8ad81a4.entry.js +0 -1
  856. package/dist/affinda/p-d9cfea73.entry.js +0 -1
  857. package/dist/affinda/p-da2759a0.entry.js +0 -1
  858. package/dist/affinda/p-dd47655f.entry.js +0 -1
  859. package/dist/affinda/p-e0915179.entry.js +0 -1
  860. package/dist/affinda/p-ebb36c5f.entry.js +0 -1
  861. package/dist/affinda/p-ecab0884.entry.js +0 -1
  862. package/dist/affinda/p-f3d5d1be.entry.js +0 -1
  863. package/dist/affinda/p-f617ae1d.entry.js +0 -1
  864. package/dist/affinda/p-fcb04e98.entry.js +0 -1
  865. package/dist/affinda/p-fd603900.entry.js +0 -1
  866. package/dist/components/p--UJ_xE9Z.js +0 -1
  867. package/dist/components/p-0KrQFK77.js +0 -1
  868. package/dist/components/p-BCCbAFc1.js +0 -1
  869. package/dist/components/p-BGeRQgDo.js +0 -1
  870. package/dist/components/p-BLzlyxBT.js +0 -1
  871. package/dist/components/p-BUFbtjxU.js +0 -1
  872. package/dist/components/p-BeVM-2kH.js +0 -1
  873. package/dist/components/p-BeX5VmwL.js +0 -1
  874. package/dist/components/p-BlfywPKX.js +0 -1
  875. package/dist/components/p-BqUK0ZTO.js +0 -1
  876. package/dist/components/p-BvLGR36l.js +0 -1
  877. package/dist/components/p-BwpItMWU.js +0 -1
  878. package/dist/components/p-BzH2LxRQ.js +0 -1
  879. package/dist/components/p-C5_nFNYV.js +0 -1
  880. package/dist/components/p-CDCZfKNt.js +0 -1
  881. package/dist/components/p-CSpMqpfj.js +0 -1
  882. package/dist/components/p-CTFMTG3E.js +0 -1
  883. package/dist/components/p-CVQiSujq.js +0 -1
  884. package/dist/components/p-CYXTWxXF.js +0 -1
  885. package/dist/components/p-C_BrhG1Q.js +0 -1
  886. package/dist/components/p-DRm58pvc.js +0 -1
  887. package/dist/components/p-DX19jO3u.js +0 -1
  888. package/dist/components/p-DsNqeD3z.js +0 -1
  889. package/dist/components/p-Dvos4xtG.js +0 -1
  890. package/dist/components/p-Dx31qPzk.js +0 -1
  891. package/dist/components/p-HhMv1A3-.js +0 -1
  892. package/dist/components/p-HkfUr6-S.js +0 -1
  893. package/dist/components/p-oawfHsaK.js +0 -1
  894. package/dist/components/p-vWuqpbX0.js +0 -1
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afAccordionItemCss = () => `:host{display:block;width:100%}.accordion-item{width:100%}.trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 0;background:transparent;border:none;border-bottom:1px solid var(--af-background-border-subtle, #e8eeed);cursor:pointer;font:inherit;text-align:left;color:var(--af-typography-body-dark, #14343b);transition:background-color 0.2s ease}.trigger:hover:not(:disabled){background-color:var(--af-background-base-hover, rgba(20, 52, 59, 0.02))}.trigger:focus-visible{outline:2px solid var(--af-background-border-active, #8a7049);outline-offset:-2px}.trigger:disabled{cursor:not-allowed;opacity:0.5}.trigger-content{flex:1;min-width:0}.chevron{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;color:var(--af-typography-body-dark, #14343b);transition:transform 0.3s ease}.chevron.is-open{transform:rotate(180deg)}.content-wrapper{overflow:hidden;transition:max-height 0.3s ease}.content{padding:0}:host(.is-disabled) .trigger{cursor:not-allowed;opacity:0.5}:host(.is-disabled) .trigger:hover{background-color:transparent}:host(.is-open) .trigger{border-bottom-color:transparent}`;
5
+ const afAccordionItemCss = ":host{display:block;width:100%}.accordion-item{width:100%}.trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 0;background:transparent;border:none;border-bottom:1px solid var(--af-background-border-subtle, #e8eeed);cursor:pointer;font:inherit;text-align:left;color:var(--af-typography-body-dark, #14343b);transition:background-color 0.2s ease}.trigger:hover:not(:disabled){background-color:var(--af-background-base-hover, rgba(20, 52, 59, 0.02))}.trigger:focus-visible{outline:2px solid var(--af-background-border-active, #8a7049);outline-offset:-2px}.trigger:disabled{cursor:not-allowed;opacity:0.5}.trigger-content{flex:1;min-width:0}.chevron{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;color:var(--af-typography-body-dark, #14343b);transition:transform 0.3s ease}.chevron.is-open{transform:rotate(180deg)}.content-wrapper{overflow:hidden;transition:max-height 0.3s ease}.content{padding:0}:host(.is-disabled) .trigger{cursor:not-allowed;opacity:0.5}:host(.is-disabled) .trigger:hover{background-color:transparent}:host(.is-open) .trigger{border-bottom-color:transparent}";
6
6
 
7
7
  const AfAccordionItem = class {
8
8
  constructor(hostRef) {
@@ -70,11 +70,10 @@ const AfAccordionItem = class {
70
70
  }
71
71
  get el() { return index.getElement(this); }
72
72
  static get watchers() { return {
73
- "open": [{
74
- "handleOpenChange": 0
75
- }]
73
+ "open": ["handleOpenChange"]
76
74
  }; }
77
75
  };
78
- AfAccordionItem.style = afAccordionItemCss();
76
+ AfAccordionItem.style = afAccordionItemCss;
79
77
 
80
78
  exports.af_accordion_item = AfAccordionItem;
79
+ //# sourceMappingURL=af-accordion-item.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-accordion-item.entry.cjs.js","sources":["src/components/af-accordion-item/af-accordion-item.css?tag=af-accordion-item&encapsulation=shadow","src/components/af-accordion-item/af-accordion-item.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n}\n\n.accordion-item {\n width: 100%;\n}\n\n/* Trigger button - clickable header */\n.trigger {\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n padding: 16px 0;\n background: transparent;\n border: none;\n border-bottom: 1px solid var(--af-background-border-subtle, #e8eeed);\n cursor: pointer;\n font: inherit;\n text-align: left;\n color: var(--af-typography-body-dark, #14343b);\n transition: background-color 0.2s ease;\n}\n\n.trigger:hover:not(:disabled) {\n background-color: var(--af-background-base-hover, rgba(20, 52, 59, 0.02));\n}\n\n.trigger:focus-visible {\n outline: 2px solid var(--af-background-border-active, #8a7049);\n outline-offset: -2px;\n}\n\n.trigger:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n\n.trigger-content {\n flex: 1;\n min-width: 0;\n}\n\n/* Chevron indicator */\n.chevron {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n color: var(--af-typography-body-dark, #14343b);\n transition: transform 0.3s ease;\n}\n\n.chevron.is-open {\n transform: rotate(180deg);\n}\n\n/* Content wrapper - handles animation */\n.content-wrapper {\n overflow: hidden;\n transition: max-height 0.3s ease;\n}\n\n.content {\n padding: 0;\n}\n\n/* Disabled state */\n:host(.is-disabled) .trigger {\n cursor: not-allowed;\n opacity: 0.5;\n}\n\n:host(.is-disabled) .trigger:hover {\n background-color: transparent;\n}\n\n/* Open state styling */\n:host(.is-open) .trigger {\n border-bottom-color: transparent;\n}\n\n","import { Component, h, Prop, Host, Event, EventEmitter, Element, State, Watch, Method } from '@stencil/core';\n\n/**\n * A single collapsible accordion item with header and content.\n * Can be used standalone or within an af-accordion container.\n *\n * @slot trigger - The clickable header content\n * @slot - The collapsible content (default slot)\n */\n@Component({\n tag: 'af-accordion-item',\n styleUrl: 'af-accordion-item.css',\n shadow: true,\n})\nexport class AfAccordionItem {\n @Element() el!: HTMLElement;\n\n /**\n * Unique identifier for this accordion item.\n * Used by parent af-accordion to track open state.\n */\n @Prop({ reflect: true }) itemId!: string;\n\n /**\n * Whether this item is currently expanded\n */\n @Prop({ reflect: true, mutable: true }) open: boolean = false;\n\n /**\n * Whether this item is disabled (cannot be toggled)\n */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /**\n * Emitted when the accordion item is toggled\n */\n @Event({ eventName: 'af-accordion-toggle' }) accordionToggle!: EventEmitter<{ itemId: string; open: boolean }>;\n\n @State() contentHeight: number = 0;\n\n private contentRef?: HTMLElement;\n private resizeObserver?: ResizeObserver;\n\n @Watch('open')\n handleOpenChange(newValue: boolean) {\n if (newValue) {\n this.measureContent();\n }\n }\n\n componentDidLoad() {\n if (this.open) {\n this.measureContent();\n }\n\n this.resizeObserver = new ResizeObserver(() => {\n if (this.open && this.contentRef) {\n this.contentHeight = this.contentRef.scrollHeight;\n }\n });\n\n if (this.contentRef) {\n this.resizeObserver.observe(this.contentRef);\n }\n }\n\n disconnectedCallback() {\n if (this.resizeObserver) {\n this.resizeObserver.disconnect();\n }\n }\n\n /**\n * Programmatically toggle the accordion item\n */\n @Method()\n async toggle() {\n if (!this.disabled) {\n this.open = !this.open;\n this.accordionToggle.emit({ itemId: this.itemId, open: this.open });\n }\n }\n\n private measureContent() {\n requestAnimationFrame(() => {\n if (this.contentRef) {\n this.contentHeight = this.contentRef.scrollHeight;\n }\n });\n }\n\n private handleTriggerClick = () => {\n if (!this.disabled) {\n this.toggle();\n }\n };\n\n render() {\n const contentStyle = {\n maxHeight: this.open ? `${this.contentHeight}px` : '0px'\n };\n\n return (\n <Host class={{ 'is-open': this.open, 'is-disabled': this.disabled }}>\n <div class=\"accordion-item\">\n <button\n class=\"trigger\"\n onClick={this.handleTriggerClick}\n aria-expanded={this.open ? 'true' : 'false'}\n aria-controls={`content-${this.itemId}`}\n disabled={this.disabled}\n type=\"button\"\n >\n <div class=\"trigger-content\">\n <slot name=\"trigger\"></slot>\n </div>\n <div class={{ 'chevron': true, 'is-open': this.open }}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\">\n <path d=\"M6 9l6 6 6-6\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </div>\n </button>\n <div\n id={`content-${this.itemId}`}\n class=\"content-wrapper\"\n style={contentStyle}\n aria-hidden={!this.open ? 'true' : 'false'}\n >\n <div class=\"content\" ref={(el) => (this.contentRef = el)}>\n <slot></slot>\n </div>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"names":["h","Host"],"mappings":"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"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afAccordionCss = () => `.sc-af-accordion-h{display:block;width:100%}.accordion.sc-af-accordion{display:flex;flex-direction:column;width:100%}.sc-af-accordion-s>af-accordion-item{display:block}.sc-af-accordion-s>af-accordion-item:last-child{--accordion-item-border:transparent}`;
5
+ const afAccordionCss = ".sc-af-accordion-h{display:block;width:100%}.accordion.sc-af-accordion{display:flex;flex-direction:column;width:100%}.sc-af-accordion-s>af-accordion-item{display:block}.sc-af-accordion-s>af-accordion-item:last-child{--accordion-item-border:transparent}";
6
6
 
7
7
  const AfAccordion = class {
8
8
  constructor(hostRef) {
@@ -93,11 +93,10 @@ const AfAccordion = class {
93
93
  }
94
94
  get el() { return index.getElement(this); }
95
95
  static get watchers() { return {
96
- "value": [{
97
- "handleValueChange": 0
98
- }]
96
+ "value": ["handleValueChange"]
99
97
  }; }
100
98
  };
101
- AfAccordion.style = afAccordionCss();
99
+ AfAccordion.style = afAccordionCss;
102
100
 
103
101
  exports.af_accordion = AfAccordion;
102
+ //# sourceMappingURL=af-accordion.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-accordion.entry.cjs.js","sources":["src/components/af-accordion/af-accordion.css?tag=af-accordion&encapsulation=scoped","src/components/af-accordion/af-accordion.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n}\n\n.accordion {\n display: flex;\n flex-direction: column;\n width: 100%;\n}\n\n/* Ensure proper stacking for accordion items */\n::slotted(af-accordion-item) {\n display: block;\n}\n\n/* Remove bottom border from last item */\n::slotted(af-accordion-item:last-child) {\n --accordion-item-border: transparent;\n}\n\n","import { Component, h, Prop, Host, Event, EventEmitter, Element, State, Watch, Listen } from '@stencil/core';\n\n/**\n * Accordion container that manages multiple accordion items.\n * Controls which items are open based on mode (independent or exclusive).\n * \n * @slot - Place af-accordion-item components here\n */\n@Component({\n tag: 'af-accordion',\n styleUrl: 'af-accordion.css',\n shadow: false,\n scoped: true,\n})\nexport class AfAccordion {\n @Element() el!: HTMLElement;\n\n /**\n * Behavior mode for the accordion.\n * - `independent`: Multiple items can be open simultaneously\n * - `exclusive`: Only one item can be open at a time\n */\n @Prop() mode: 'independent' | 'exclusive' = 'independent';\n\n /**\n * Currently open item(s) for controlled mode.\n * In independent mode, can be an array of item IDs.\n * In exclusive mode, should be a single item ID or null.\n */\n @Prop({ mutable: true }) value?: string | string[];\n\n /**\n * Default open item(s) for uncontrolled mode.\n * Used as initial state when value prop is not provided.\n */\n @Prop() defaultValue?: string | string[];\n\n /**\n * Emitted when the open state of items changes.\n * Returns the new value (string[] for independent, string | null for exclusive).\n */\n @Event({ eventName: 'af-accordion-change' }) accordionChange!: EventEmitter<{ value: string | string[] | null }>;\n\n @State() internalValue: string[] = [];\n\n private isControlled(): boolean {\n return this.value !== undefined;\n }\n\n componentWillLoad() {\n // Initialize internal value from defaultValue or value\n const initialValue = this.isControlled() ? this.value : this.defaultValue;\n this.internalValue = this.normalizeValue(initialValue);\n }\n\n @Watch('value')\n handleValueChange(newValue: string | string[] | undefined) {\n if (this.isControlled()) {\n this.internalValue = this.normalizeValue(newValue);\n this.syncItems();\n }\n }\n\n componentDidLoad() {\n this.syncItems();\n }\n\n /**\n * Listen for toggle events from child accordion items\n */\n @Listen('af-accordion-toggle')\n handleItemToggle(event: CustomEvent<{ itemId: string; open: boolean }>) {\n event.stopPropagation();\n const { itemId, open } = event.detail;\n\n let newValue: string[];\n\n if (this.mode === 'exclusive') {\n // In exclusive mode, only one item can be open\n newValue = open ? [itemId] : [];\n } else {\n // In independent mode, toggle the item\n if (open) {\n newValue = [...this.internalValue, itemId];\n } else {\n newValue = this.internalValue.filter(id => id !== itemId);\n }\n }\n\n if (!this.isControlled()) {\n this.internalValue = newValue;\n this.syncItems();\n }\n\n // Emit change event\n const emitValue = this.mode === 'exclusive' \n ? (newValue.length > 0 ? newValue[0] : null)\n : newValue;\n this.accordionChange.emit({ value: emitValue });\n }\n\n /**\n * Normalize value prop to array format for internal use\n */\n private normalizeValue(value: string | string[] | undefined): string[] {\n if (value === undefined || value === null) {\n return [];\n }\n if (Array.isArray(value)) {\n // In exclusive mode, only keep the first item\n return this.mode === 'exclusive' ? value.slice(0, 1) : value;\n }\n return [value];\n }\n\n /**\n * Sync the open state of all child accordion items\n */\n private syncItems() {\n const items = this.el.querySelectorAll('af-accordion-item');\n items.forEach((element) => {\n const item = element as HTMLElement & { itemId?: string; open?: boolean };\n if (item.itemId) {\n item.open = this.internalValue.includes(item.itemId);\n }\n });\n }\n\n render() {\n return (\n <Host class={{ [`mode-${this.mode}`]: true }}>\n <div class=\"accordion\">\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n\n"],"names":["h","Host"],"mappings":"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"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afAspectRatioCss = () => `:host{display:block;width:100%}.aspect-ratio-container{width:100%;position:relative;overflow:hidden}.aspect-ratio-container ::slotted(*){position:absolute;inset:0;width:100%;height:100%;object-fit:cover}`;
5
+ const afAspectRatioCss = ":host{display:block;width:100%}.aspect-ratio-container{width:100%;position:relative;overflow:hidden}.aspect-ratio-container ::slotted(*){position:absolute;inset:0;width:100%;height:100%;object-fit:cover}";
6
6
 
7
7
  const AfAspectRatio = class {
8
8
  constructor(hostRef) {
@@ -77,6 +77,7 @@ const AfAspectRatio = class {
77
77
  return (index.h("div", { key: '02bfa5463911ecd25903521e90a0570bb3bca0ad', class: "aspect-ratio-container", style: { aspectRatio: ratioValue } }, index.h("slot", { key: '9575c859052e8f1b1b362d9395fdfdf43d46b0b4' })));
78
78
  }
79
79
  };
80
- AfAspectRatio.style = afAspectRatioCss();
80
+ AfAspectRatio.style = afAspectRatioCss;
81
81
 
82
82
  exports.af_aspect_ratio = AfAspectRatio;
83
+ //# sourceMappingURL=af-aspect-ratio.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-aspect-ratio.entry.cjs.js","sources":["src/components/af-aspect-ratio/af-aspect-ratio.css?tag=af-aspect-ratio&encapsulation=shadow","src/components/af-aspect-ratio/af-aspect-ratio.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n}\n\n.aspect-ratio-container {\n width: 100%;\n position: relative;\n overflow: hidden;\n}\n\n/* Ensure slotted content fills the container */\n.aspect-ratio-container ::slotted(*) {\n position: absolute;\n inset: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n}\n","import { Component, h, Prop } from '@stencil/core';\n\n/**\n * A container component that maintains a fixed aspect ratio for its content.\n * Useful for images, videos, or any content that needs to maintain specific proportions.\n */\n@Component({\n tag: 'af-aspect-ratio',\n styleUrl: 'af-aspect-ratio.css',\n shadow: true\n})\nexport class AfAspectRatio {\n /**\n * The aspect ratio to maintain. Can be:\n * - A predefined ratio: '1:1', '16:9', '4:3', 'golden-portrait', 'golden-landscape', 'a4-portrait', 'a4-landscape', 'letter-portrait', 'letter-landscape', etc.\n * - A custom ratio in format 'width / height': '16 / 9', '4 / 3', '1.618 / 1', etc.\n *\n * @example\n * <af-aspect-ratio ratio=\"16:9\">Content</af-aspect-ratio>\n * <af-aspect-ratio ratio=\"1.618 / 1\">Content</af-aspect-ratio>\n */\n @Prop() ratio: string = '1:1';\n\n private getRatioValue(): string {\n // Map common ratio shortcuts to actual CSS aspect-ratio values\n const ratioMap: { [key: string]: string } = {\n // Common ratios\n '1:1': '1 / 1',\n '1:2': '1 / 2',\n '2:1': '2 / 1',\n '2:3': '2 / 3',\n '3:1': '3 / 1',\n '3:2': '3 / 2',\n '3:4': '3 / 4',\n '4:1': '4 / 1',\n '4:3': '4 / 3',\n '4:5': '4 / 5',\n '5:2': '5 / 2',\n '5:4': '5 / 4',\n '8:3': '8 / 3',\n '8:5': '8 / 5',\n // Screen ratios\n '9:8': '9 / 8',\n '9:16': '9 / 16',\n '9:21': '9 / 21',\n '10:16': '10 / 16',\n '14:3': '14 / 3',\n '16:5': '16 / 5',\n '16:9': '16 / 9',\n '16:10': '16 / 10',\n '21:9': '21 / 9',\n '32:9': '32 / 9',\n // Golden ratio variants\n 'golden-portrait': '1 / 1.618',\n 'golden-landscape': '1.618 / 1',\n 'golden-portrait-half': '1 / 0.809',\n 'golden-landscape-half': '0.809 / 1',\n // Paper sizes - A4\n 'a4-portrait': '1 / 1.414',\n 'a4-landscape': '1.414 / 1',\n 'a4-portrait-half': '1 / 0.707',\n 'a4-landscape-half': '0.707 / 1',\n // Paper sizes - Letter\n 'letter-portrait': '1 / 1.294',\n 'letter-landscape': '1.294 / 1',\n 'letter-portrait-half': '1 / 0.647',\n 'letter-landscape-half': '0.647 / 1',\n // Special\n '6:7': '6 / 7'\n };\n\n // If it's a predefined ratio, return the mapped value\n if (ratioMap[this.ratio]) {\n return ratioMap[this.ratio];\n }\n\n // Otherwise, assume it's a custom ratio already in the correct format\n return this.ratio;\n }\n\n render() {\n const ratioValue = this.getRatioValue();\n\n return (\n <div\n class=\"aspect-ratio-container\"\n style={{ aspectRatio: ratioValue }}\n >\n <slot></slot>\n </div>\n );\n }\n}\n"],"names":["h"],"mappings":";;;;AAAA,MAAM,gBAAgB,GAAG,6MAA6M;;MCWzN,aAAa,GAAA,MAAA;AAL1B,IAAA,WAAA,CAAA,OAAA,EAAA;;AAME;;;;;;;;AAQG;AACK,QAAA,IAAK,CAAA,KAAA,GAAW,KAAK;AAuE9B;IArES,aAAa,GAAA;;AAEnB,QAAA,MAAM,QAAQ,GAA8B;;AAE1C,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,KAAK,EAAE,OAAO;;AAEd,YAAA,KAAK,EAAE,OAAO;AACd,YAAA,MAAM,EAAE,QAAQ;AAChB,YAAA,MAAM,EAAE,QAAQ;AAChB,YAAA,OAAO,EAAE,SAAS;AAClB,YAAA,MAAM,EAAE,QAAQ;AAChB,YAAA,MAAM,EAAE,QAAQ;AAChB,YAAA,MAAM,EAAE,QAAQ;AAChB,YAAA,OAAO,EAAE,SAAS;AAClB,YAAA,MAAM,EAAE,QAAQ;AAChB,YAAA,MAAM,EAAE,QAAQ;;AAEhB,YAAA,iBAAiB,EAAE,WAAW;AAC9B,YAAA,kBAAkB,EAAE,WAAW;AAC/B,YAAA,sBAAsB,EAAE,WAAW;AACnC,YAAA,uBAAuB,EAAE,WAAW;;AAEpC,YAAA,aAAa,EAAE,WAAW;AAC1B,YAAA,cAAc,EAAE,WAAW;AAC3B,YAAA,kBAAkB,EAAE,WAAW;AAC/B,YAAA,mBAAmB,EAAE,WAAW;;AAEhC,YAAA,iBAAiB,EAAE,WAAW;AAC9B,YAAA,kBAAkB,EAAE,WAAW;AAC/B,YAAA,sBAAsB,EAAE,WAAW;AACnC,YAAA,uBAAuB,EAAE,WAAW;;AAEpC,YAAA,KAAK,EAAE;SACR;;AAGD,QAAA,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;AACxB,YAAA,OAAO,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC;;;QAI7B,OAAO,IAAI,CAAC,KAAK;;IAGnB,MAAM,GAAA;AACJ,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE;AAEvC,QAAA,QACEA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAC,wBAAwB,EAC9B,KAAK,EAAE,EAAE,WAAW,EAAE,UAAU,EAAE,EAAA,EAElCA,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACT;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afButtonGroupCss = () => `:host{display:inline-block}.button-group{display:inline-flex;align-items:center;box-sizing:border-box}.direction-horizontal{flex-direction:row}.direction-vertical{flex-direction:column}::slotted(*){flex-shrink:0}`;
5
+ const afButtonGroupCss = ":host{display:inline-block}.button-group{display:inline-flex;align-items:center;box-sizing:border-box}.direction-horizontal{flex-direction:row}.direction-vertical{flex-direction:column}::slotted(*){flex-shrink:0}";
6
6
 
7
7
  const AfButtonGroup = class {
8
8
  constructor(hostRef) {
@@ -24,6 +24,7 @@ const AfButtonGroup = class {
24
24
  return (index.h(index.Host, { key: 'abd684c0b9a003fa1c8cad9f0f37a450d068c24a' }, index.h("div", { key: 'a4f5b89ac0fab2f2a853d10b8dd8f7b20e98cbe7', class: classes, style: { gap: this.gap } }, index.h("slot", { key: '764d1d9b7b1283452c75b8a69adf6ff34c8b26a2' }))));
25
25
  }
26
26
  };
27
- AfButtonGroup.style = afButtonGroupCss();
27
+ AfButtonGroup.style = afButtonGroupCss;
28
28
 
29
29
  exports.af_button_group = AfButtonGroup;
30
+ //# sourceMappingURL=af-button-group.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-button-group.entry.cjs.js","sources":["src/components/af-button-group/af-button-group.css?tag=af-button-group&encapsulation=shadow","src/components/af-button-group/af-button-group.tsx"],"sourcesContent":[":host {\n display: inline-block;\n}\n\n.button-group {\n display: inline-flex;\n align-items: center;\n box-sizing: border-box;\n}\n\n.direction-horizontal {\n flex-direction: row;\n}\n\n.direction-vertical {\n flex-direction: column;\n}\n\n/* Ensure slotted buttons align properly */\n::slotted(*) {\n flex-shrink: 0;\n}\n","import { Component, h, Host, Prop } from '@stencil/core';\n\n@Component({\n tag: 'af-button-group',\n styleUrl: 'af-button-group.css',\n shadow: true\n})\nexport class AfButtonGroup {\n /**\n * Layout direction of the button group\n */\n @Prop() direction: 'horizontal' | 'vertical' = 'horizontal';\n\n /**\n * Gap between buttons\n */\n @Prop() gap: string = '8px';\n\n render() {\n const classes = {\n 'button-group': true,\n [`direction-${this.direction}`]: true\n };\n\n return (\n <Host>\n <div class={classes} style={{ gap: this.gap }}>\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"],"names":["h","Host"],"mappings":";;;;AAAA,MAAM,gBAAgB,GAAG,sNAAsN;;MCOlO,aAAa,GAAA,MAAA;AAL1B,IAAA,WAAA,CAAA,OAAA,EAAA;;AAME;;AAEG;AACK,QAAA,IAAS,CAAA,SAAA,GAA8B,YAAY;AAE3D;;AAEG;AACK,QAAA,IAAG,CAAA,GAAA,GAAW,KAAK;AAgB5B;IAdC,MAAM,GAAA;AACJ,QAAA,MAAM,OAAO,GAAG;AACd,YAAA,cAAc,EAAE,IAAI;AACpB,YAAA,CAAC,aAAa,IAAI,CAAC,SAAS,CAAE,CAAA,GAAG;SAClC;QAED,QACEA,QAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACHD,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,EAAA,EAC3CA,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACT,CACD;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afButtonCss = () => `:host{display:inline-block}:host([variant="primary"]){color:var(--af-button-primary-icon, var(--colour-brand-inkwell, #14343B))}:host([variant="secondary"]){color:var(--af-button-secondary-icon, var(--af-typography-body-dark, var(--colour-brand-inkwell, #14343B)))}:host([variant="ghost"]){color:var(--af-button-ghost-icon, var(--colour-brand-inkwell, #14343B))}:host([full-width]),:host(.full-width){display:block;width:100%}:host([full-width]) .button,:host(.full-width) .button{width:100%}.button{display:inline-flex;align-items:center;justify-content:center;gap:0;border-radius:9999px;font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-weight:500;text-decoration:none;cursor:pointer;transition:all 0.2s ease;border:1px solid transparent;box-sizing:border-box;white-space:nowrap;width:var(--af-button-width, auto)}.size-default{padding:12px 24px;font-size:17px;line-height:20px}.size-thin{padding:8px 16px;font-size:14px;line-height:16px}.icon-left,.icon-right{display:none;align-items:center;justify-content:center;flex-shrink:0}.icon-left.has-content,.icon-right.has-content{display:flex}.size-default .icon-left,.size-default .icon-right{width:24px;height:24px}.size-thin .icon-left,.size-thin .icon-right{width:20px;height:20px}.size-default .icon-left.has-content{margin-right:12px}.size-default .icon-right.has-content{margin-left:12px}.size-thin .icon-left.has-content{margin-right:8px}.size-thin .icon-right.has-content{margin-left:8px}.label{flex:0 1 auto;display:flex;align-items:center;justify-content:center}.size-default .label{height:24px}.size-thin .label{height:20px}.variant-primary{background:var(--af-button-primary-bg, var(--colour-brand-ice, #a6fffb));border-color:var(--af-button-primary-stroke, var(--colour-brand-inkwell, #14343b));color:var(--af-button-primary-text, var(--colour-brand-inkwell, #14343b))}.variant-primary .icon-left,.variant-primary .icon-right{color:var(--af-button-primary-icon, var(--colour-brand-inkwell, #14343b))}.variant-primary:hover:not(.disabled){background:var(--af-button-primary-bg-hover, #95E6E2);border-color:var(--af-button-primary-stroke, #14343B)}.variant-primary:focus:not(.disabled),.variant-primary:focus-visible:not(.disabled){background:var(--af-button-primary-bg, #A6FFFB);border-color:var(--af-button-primary-stroke, #14343B);box-shadow:0 0 0 4px var(--af-background-base, #FFF), 0 0 0 5px var(--af-button-primary-stroke, #14343B);outline:none}.variant-primary:active:not(.disabled){background:var(--af-button-primary-bg-hover, #95E6E2)}.variant-secondary{background:var(--af-button-secondary-bg, transparent);border-color:var(--af-button-secondary-stroke, var(--colour-brand-inkwell, #14343b));color:var(--af-button-secondary-text, var(--colour-brand-inkwell, #14343b))}.variant-secondary .icon-left,.variant-secondary .icon-right{color:var(--af-button-secondary-icon, var(--colour-brand-inkwell, #14343b))}.variant-secondary:hover:not(.disabled){background:var(--af-button-secondary-bg-hover, rgba(128, 128, 128, 0.1));border-color:var(--af-button-secondary-stroke, currentColor)}.variant-secondary:focus:not(.disabled),.variant-secondary:focus-visible:not(.disabled){background:var(--af-background-base, #FFF);border-color:var(--af-button-secondary-stroke, currentColor);box-shadow:0 0 0 4px var(--af-background-base, #FFF), 0 0 0 5px var(--af-button-secondary-stroke, currentColor);outline:none}.variant-secondary:active:not(.disabled){background:var(--af-button-secondary-bg-hover, rgba(128, 128, 128, 0.1))}.variant-ghost{background:transparent;border-color:transparent;border-radius:0;color:var(--af-button-ghost-text, var(--colour-brand-inkwell, #14343b));padding-left:0;padding-right:0}.variant-ghost .label{border-bottom:2px solid var(--af-button-ghost-stroke, var(--colour-brand-soft-clay, #B09670))}.variant-ghost .icon-left,.variant-ghost .icon-right{color:var(--af-button-ghost-icon, var(--colour-brand-inkwell, #14343b))}.variant-ghost:hover:not(.disabled){opacity:0.8}.variant-ghost:focus:not(.disabled),.variant-ghost:focus-visible:not(.disabled){outline:none}.variant-ghost:focus-visible:not(.disabled) .label{box-shadow:0 4px 0 0 var(--af-button-ghost-stroke, var(--colour-brand-soft-clay, #B09670))}.variant-ghost:active:not(.disabled){opacity:0.6}.disabled{cursor:not-allowed;pointer-events:none}.variant-primary.disabled{border:1px solid var(--af-button-primary-stroke, #14343B);background:var(--af-button-primary-bg, #A6FFFB);opacity:0.6}.variant-secondary.disabled{border:1px solid var(--af-button-secondary-stroke, currentColor);opacity:0.6}.variant-ghost.disabled{opacity:0.6}button.button{font:inherit;cursor:pointer}button.button.variant-primary{background:var(--af-button-primary-bg, var(--colour-brand-ice, #a6fffb));border:1px solid var(--af-button-primary-stroke, var(--colour-brand-inkwell, #14343b))}button.button.variant-secondary{background:var(--af-button-secondary-bg, transparent);border:1px solid var(--af-button-secondary-stroke, var(--colour-brand-inkwell, #14343b))}button.button.variant-ghost{background:transparent;border:none}a.button{text-decoration:none;color:inherit}a.button.variant-primary{background:var(--af-button-primary-bg, var(--colour-brand-ice, #a6fffb));border:1px solid var(--af-button-primary-stroke, var(--colour-brand-inkwell, #14343b))}a.button.variant-secondary{background:var(--af-button-secondary-bg, transparent);border:1px solid var(--af-button-secondary-stroke, var(--colour-brand-inkwell, #14343b))}a.button.variant-ghost{background:transparent;border:none}`;
5
+ const afButtonCss = ":host{display:inline-block}:host([variant=\"primary\"]){color:var(--af-button-primary-icon, var(--colour-brand-inkwell, #14343B))}:host([variant=\"secondary\"]){color:var(--af-button-secondary-icon, var(--af-typography-body-dark, var(--colour-brand-inkwell, #14343B)))}:host([variant=\"ghost\"]){color:var(--af-button-ghost-icon, var(--colour-brand-inkwell, #14343B))}:host([full-width]),:host(.full-width){display:block;width:100%}:host([full-width]) .button,:host(.full-width) .button{width:100%}.button{display:inline-flex;align-items:center;justify-content:center;gap:0;border-radius:9999px;font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-weight:500;text-decoration:none;cursor:pointer;transition:all 0.2s ease;border:1px solid transparent;box-sizing:border-box;white-space:nowrap;width:var(--af-button-width, auto)}.size-default{padding:12px 24px;font-size:17px;line-height:20px}.size-thin{padding:8px 16px;font-size:14px;line-height:16px}.icon-left,.icon-right{display:none;align-items:center;justify-content:center;flex-shrink:0}.icon-left.has-content,.icon-right.has-content{display:flex}.size-default .icon-left,.size-default .icon-right{width:24px;height:24px}.size-thin .icon-left,.size-thin .icon-right{width:20px;height:20px}.size-default .icon-left.has-content{margin-right:12px}.size-default .icon-right.has-content{margin-left:12px}.size-thin .icon-left.has-content{margin-right:8px}.size-thin .icon-right.has-content{margin-left:8px}.label{flex:0 1 auto;display:flex;align-items:center;justify-content:center}.size-default .label{height:24px}.size-thin .label{height:20px}.variant-primary{background:var(--af-button-primary-bg, var(--colour-brand-ice, #a6fffb));border-color:var(--af-button-primary-stroke, var(--colour-brand-inkwell, #14343b));color:var(--af-button-primary-text, var(--colour-brand-inkwell, #14343b))}.variant-primary .icon-left,.variant-primary .icon-right{color:var(--af-button-primary-icon, var(--colour-brand-inkwell, #14343b))}.variant-primary:hover:not(.disabled){background:var(--af-button-primary-bg-hover, #95E6E2);border-color:var(--af-button-primary-stroke, #14343B)}.variant-primary:focus:not(.disabled),.variant-primary:focus-visible:not(.disabled){background:var(--af-button-primary-bg, #A6FFFB);border-color:var(--af-button-primary-stroke, #14343B);box-shadow:0 0 0 4px var(--af-background-base, #FFF), 0 0 0 5px var(--af-button-primary-stroke, #14343B);outline:none}.variant-primary:active:not(.disabled){background:var(--af-button-primary-bg-hover, #95E6E2)}.variant-secondary{background:var(--af-button-secondary-bg, transparent);border-color:var(--af-button-secondary-stroke, var(--colour-brand-inkwell, #14343b));color:var(--af-button-secondary-text, var(--colour-brand-inkwell, #14343b))}.variant-secondary .icon-left,.variant-secondary .icon-right{color:var(--af-button-secondary-icon, var(--colour-brand-inkwell, #14343b))}.variant-secondary:hover:not(.disabled){background:var(--af-button-secondary-bg-hover, rgba(128, 128, 128, 0.1));border-color:var(--af-button-secondary-stroke, currentColor)}.variant-secondary:focus:not(.disabled),.variant-secondary:focus-visible:not(.disabled){background:var(--af-background-base, #FFF);border-color:var(--af-button-secondary-stroke, currentColor);box-shadow:0 0 0 4px var(--af-background-base, #FFF), 0 0 0 5px var(--af-button-secondary-stroke, currentColor);outline:none}.variant-secondary:active:not(.disabled){background:var(--af-button-secondary-bg-hover, rgba(128, 128, 128, 0.1))}.variant-ghost{background:transparent;border-color:transparent;border-radius:0;color:var(--af-button-ghost-text, var(--colour-brand-inkwell, #14343b));padding-left:0;padding-right:0}.variant-ghost .label{border-bottom:2px solid var(--af-button-ghost-stroke, var(--colour-brand-soft-clay, #B09670))}.variant-ghost .icon-left,.variant-ghost .icon-right{color:var(--af-button-ghost-icon, var(--colour-brand-inkwell, #14343b))}.variant-ghost:hover:not(.disabled){opacity:0.8}.variant-ghost:focus:not(.disabled),.variant-ghost:focus-visible:not(.disabled){outline:none}.variant-ghost:focus-visible:not(.disabled) .label{box-shadow:0 4px 0 0 var(--af-button-ghost-stroke, var(--colour-brand-soft-clay, #B09670))}.variant-ghost:active:not(.disabled){opacity:0.6}.disabled{cursor:not-allowed;pointer-events:none}.variant-primary.disabled{border:1px solid var(--af-button-primary-stroke, #14343B);background:var(--af-button-primary-bg, #A6FFFB);opacity:0.6}.variant-secondary.disabled{border:1px solid var(--af-button-secondary-stroke, currentColor);opacity:0.6}.variant-ghost.disabled{opacity:0.6}button.button{font:inherit;cursor:pointer}button.button.variant-primary{background:var(--af-button-primary-bg, var(--colour-brand-ice, #a6fffb));border:1px solid var(--af-button-primary-stroke, var(--colour-brand-inkwell, #14343b))}button.button.variant-secondary{background:var(--af-button-secondary-bg, transparent);border:1px solid var(--af-button-secondary-stroke, var(--colour-brand-inkwell, #14343b))}button.button.variant-ghost{background:transparent;border:none}a.button{text-decoration:none;color:inherit}a.button.variant-primary{background:var(--af-button-primary-bg, var(--colour-brand-ice, #a6fffb));border:1px solid var(--af-button-primary-stroke, var(--colour-brand-inkwell, #14343b))}a.button.variant-secondary{background:var(--af-button-secondary-bg, transparent);border:1px solid var(--af-button-secondary-stroke, var(--colour-brand-inkwell, #14343b))}a.button.variant-ghost{background:transparent;border:none}";
6
6
 
7
7
  const AfButton = class {
8
8
  constructor(hostRef) {
@@ -61,6 +61,7 @@ const AfButton = class {
61
61
  return (index.h(index.Host, null, index.h("button", { type: this.type, disabled: this.disabled, class: classes }, content)));
62
62
  }
63
63
  };
64
- AfButton.style = afButtonCss();
64
+ AfButton.style = afButtonCss;
65
65
 
66
66
  exports.af_button = AfButton;
67
+ //# sourceMappingURL=af-button.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-button.entry.cjs.js","sources":["src/components/af-button/af-button.css?tag=af-button&encapsulation=shadow","src/components/af-button/af-button.tsx"],"sourcesContent":[":host {\n display: inline-block;\n}\n\n/* Set color on host for slotted content (icons) inheritance */\n:host([variant=\"primary\"]) {\n color: var(--af-button-primary-icon, var(--colour-brand-inkwell, #14343B));\n}\n\n:host([variant=\"secondary\"]) {\n color: var(--af-button-secondary-icon, var(--af-typography-body-dark, var(--colour-brand-inkwell, #14343B)));\n}\n\n:host([variant=\"ghost\"]) {\n color: var(--af-button-ghost-icon, var(--colour-brand-inkwell, #14343B));\n}\n\n/* Full-width mode - when host is display: block */\n:host([full-width]),\n:host(.full-width) {\n display: block;\n width: 100%;\n}\n\n:host([full-width]) .button,\n:host(.full-width) .button {\n width: 100%;\n}\n\n.button {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n gap: 0;\n border-radius: 9999px;\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-weight: 500;\n text-decoration: none;\n cursor: pointer;\n transition: all 0.2s ease;\n border: 1px solid transparent;\n box-sizing: border-box;\n white-space: nowrap;\n /* Allow width to be controlled from outside via CSS custom property */\n width: var(--af-button-width, auto);\n}\n\n/* Size variants */\n.size-default {\n padding: 12px 24px;\n font-size: 17px;\n line-height: 20px;\n}\n\n.size-thin {\n padding: 8px 16px;\n font-size: 14px;\n line-height: 16px;\n}\n\n/* Icon slots - only show when they have slotted content */\n.icon-left,\n.icon-right {\n display: none;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n}\n\n.icon-left.has-content,\n.icon-right.has-content {\n display: flex;\n}\n\n.size-default .icon-left,\n.size-default .icon-right {\n width: 24px;\n height: 24px;\n}\n\n.size-thin .icon-left,\n.size-thin .icon-right {\n width: 20px;\n height: 20px;\n}\n\n/* Add spacing between icon and label only when icon is present */\n.size-default .icon-left.has-content {\n margin-right: 12px;\n}\n\n.size-default .icon-right.has-content {\n margin-left: 12px;\n}\n\n.size-thin .icon-left.has-content {\n margin-right: 8px;\n}\n\n.size-thin .icon-right.has-content {\n margin-left: 8px;\n}\n\n/* Label styling */\n.label {\n flex: 0 1 auto;\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n.size-default .label {\n height: 24px;\n}\n\n.size-thin .label {\n height: 20px;\n}\n\n/* ==========================================================================\n Primary Button\n Filled background with ice color, inkwell text\n ========================================================================== */\n\n.variant-primary {\n background: var(--af-button-primary-bg, var(--colour-brand-ice, #a6fffb));\n border-color: var(--af-button-primary-stroke, var(--colour-brand-inkwell, #14343b));\n color: var(--af-button-primary-text, var(--colour-brand-inkwell, #14343b));\n}\n\n.variant-primary .icon-left,\n.variant-primary .icon-right {\n color: var(--af-button-primary-icon, var(--colour-brand-inkwell, #14343b));\n}\n\n.variant-primary:hover:not(.disabled) {\n background: var(--af-button-primary-bg-hover, #95E6E2);\n border-color: var(--af-button-primary-stroke, #14343B);\n}\n\n.variant-primary:focus:not(.disabled),\n.variant-primary:focus-visible:not(.disabled) {\n background: var(--af-button-primary-bg, #A6FFFB);\n border-color: var(--af-button-primary-stroke, #14343B);\n box-shadow: 0 0 0 4px var(--af-background-base, #FFF), 0 0 0 5px var(--af-button-primary-stroke, #14343B);\n outline: none;\n}\n\n.variant-primary:active:not(.disabled) {\n background: var(--af-button-primary-bg-hover, #95E6E2);\n}\n\n/* ==========================================================================\n Secondary Button\n Transparent background with visible border\n ========================================================================== */\n\n.variant-secondary {\n background: var(--af-button-secondary-bg, transparent);\n border-color: var(--af-button-secondary-stroke, var(--colour-brand-inkwell, #14343b));\n color: var(--af-button-secondary-text, var(--colour-brand-inkwell, #14343b));\n}\n\n.variant-secondary .icon-left,\n.variant-secondary .icon-right {\n color: var(--af-button-secondary-icon, var(--colour-brand-inkwell, #14343b));\n}\n\n.variant-secondary:hover:not(.disabled) {\n background: var(--af-button-secondary-bg-hover, rgba(128, 128, 128, 0.1));\n border-color: var(--af-button-secondary-stroke, currentColor);\n}\n\n.variant-secondary:focus:not(.disabled),\n.variant-secondary:focus-visible:not(.disabled) {\n background: var(--af-background-base, #FFF);\n border-color: var(--af-button-secondary-stroke, currentColor);\n box-shadow: 0 0 0 4px var(--af-background-base, #FFF), 0 0 0 5px var(--af-button-secondary-stroke, currentColor);\n outline: none;\n}\n\n.variant-secondary:active:not(.disabled) {\n background: var(--af-button-secondary-bg-hover, rgba(128, 128, 128, 0.1));\n}\n\n/* ==========================================================================\n Tertiary Button\n Text-only link style with underline, no border or background\n ========================================================================== */\n\n.variant-ghost {\n background: transparent;\n border-color: transparent;\n border-radius: 0;\n color: var(--af-button-ghost-text, var(--colour-brand-inkwell, #14343b));\n padding-left: 0;\n padding-right: 0;\n}\n\n.variant-ghost .label {\n border-bottom: 2px solid var(--af-button-ghost-stroke, var(--colour-brand-soft-clay, #B09670));\n}\n\n.variant-ghost .icon-left,\n.variant-ghost .icon-right {\n color: var(--af-button-ghost-icon, var(--colour-brand-inkwell, #14343b));\n}\n\n.variant-ghost:hover:not(.disabled) {\n opacity: 0.8;\n}\n\n.variant-ghost:focus:not(.disabled),\n.variant-ghost:focus-visible:not(.disabled) {\n outline: none;\n}\n\n.variant-ghost:focus-visible:not(.disabled) .label {\n box-shadow: 0 4px 0 0 var(--af-button-ghost-stroke, var(--colour-brand-soft-clay, #B09670));\n}\n\n.variant-ghost:active:not(.disabled) {\n opacity: 0.6;\n}\n\n/* ==========================================================================\n Disabled states\n ========================================================================== */\n\n.disabled {\n cursor: not-allowed;\n pointer-events: none;\n}\n\n.variant-primary.disabled {\n border: 1px solid var(--af-button-primary-stroke, #14343B);\n background: var(--af-button-primary-bg, #A6FFFB);\n opacity: 0.6;\n}\n\n.variant-secondary.disabled {\n border: 1px solid var(--af-button-secondary-stroke, currentColor);\n opacity: 0.6;\n}\n\n.variant-ghost.disabled {\n opacity: 0.6;\n}\n\n/* ==========================================================================\n Reset button element styles\n ========================================================================== */\n\nbutton.button {\n font: inherit;\n cursor: pointer;\n}\n\nbutton.button.variant-primary {\n background: var(--af-button-primary-bg, var(--colour-brand-ice, #a6fffb));\n border: 1px solid var(--af-button-primary-stroke, var(--colour-brand-inkwell, #14343b));\n}\n\nbutton.button.variant-secondary {\n background: var(--af-button-secondary-bg, transparent);\n border: 1px solid var(--af-button-secondary-stroke, var(--colour-brand-inkwell, #14343b));\n}\n\nbutton.button.variant-ghost {\n background: transparent;\n border: none;\n}\n\n/* ==========================================================================\n Reset anchor element styles (when using href prop)\n ========================================================================== */\n\na.button {\n text-decoration: none;\n color: inherit;\n}\n\na.button.variant-primary {\n background: var(--af-button-primary-bg, var(--colour-brand-ice, #a6fffb));\n border: 1px solid var(--af-button-primary-stroke, var(--colour-brand-inkwell, #14343b));\n}\n\na.button.variant-secondary {\n background: var(--af-button-secondary-bg, transparent);\n border: 1px solid var(--af-button-secondary-stroke, var(--colour-brand-inkwell, #14343b));\n}\n\na.button.variant-ghost {\n background: transparent;\n border: none;\n}\n","import { Component, h, Prop, Host, State } from '@stencil/core';\n\n/**\n * Button component that inherits colors from theme context.\n * Colors are determined by the parent theme (af-section, af-card, etc.)\n * via CSS custom properties.\n * \n * @slot - Button label text\n * @slot icon-left - Icon displayed before the label\n * @slot icon-right - Icon displayed after the label\n */\n@Component({\n tag: 'af-button',\n styleUrl: 'af-button.css',\n shadow: true\n})\nexport class AfButton {\n /**\n * The visual variant of the button.\n * - `primary` - Main CTA with filled background (use sparingly, 1-2 per view)\n * - `secondary` - Supporting action with outlined style\n * - `ghost` - Link-style with themed underline on the label; commonly paired\n * with a right-pointing icon. Matches Webflow's \"button ghost\" variant.\n */\n @Prop({ reflect: true }) variant: 'primary' | 'secondary' | 'ghost' = 'primary';\n\n /**\n * The size of the button.\n * - `default` - Standard size for primary CTAs (12/24px padding)\n * - `thin` - Compact inline/secondary size (8/16px padding)\n */\n @Prop() size: 'default' | 'thin' = 'default';\n\n /**\n * Whether the button is disabled\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Button type (when not using href)\n */\n @Prop() type: 'button' | 'submit' | 'reset' = 'button';\n\n /**\n * Optional href to render as a link instead of a button\n */\n @Prop() href?: string;\n\n @State() hasIconLeft: boolean = false;\n @State() hasIconRight: boolean = false;\n\n private handleSlotChange = (slotName: 'icon-left' | 'icon-right') => (event: Event) => {\n const slot = event.target as HTMLSlotElement;\n const hasContent = slot.assignedNodes().length > 0;\n if (slotName === 'icon-left') {\n this.hasIconLeft = hasContent;\n } else {\n this.hasIconRight = hasContent;\n }\n };\n\n render() {\n const classes = {\n 'button': true,\n [`variant-${this.variant}`]: true,\n [`size-${this.size}`]: true,\n 'disabled': this.disabled\n };\n\n const content = [\n <span class={{ 'icon-left': true, 'has-content': this.hasIconLeft }}>\n <slot name=\"icon-left\" onSlotchange={this.handleSlotChange('icon-left')}></slot>\n </span>,\n <span class=\"label\">\n <slot></slot>\n </span>,\n <span class={{ 'icon-right': true, 'has-content': this.hasIconRight }}>\n <slot name=\"icon-right\" onSlotchange={this.handleSlotChange('icon-right')}></slot>\n </span>\n ];\n\n // Render as anchor if href is provided (and not disabled)\n if (this.href && !this.disabled) {\n return (\n <Host>\n <a href={this.href} class={classes}>\n {content}\n </a>\n </Host>\n );\n }\n\n return (\n <Host>\n <button type={this.type} disabled={this.disabled} class={classes}>\n {content}\n </button>\n </Host>\n );\n }\n}\n"],"names":["h","Host"],"mappings":";;;;AAAA,MAAM,WAAW,GAAG,s5KAAs5K;;MCgB75K,QAAQ,GAAA,MAAA;AALrB,IAAA,WAAA,CAAA,OAAA,EAAA;;AAME;;;;;;AAMG;AACsB,QAAA,IAAO,CAAA,OAAA,GAAsC,SAAS;AAE/E;;;;AAIG;AACK,QAAA,IAAI,CAAA,IAAA,GAAuB,SAAS;AAE5C;;AAEG;AACK,QAAA,IAAQ,CAAA,QAAA,GAAY,KAAK;AAEjC;;AAEG;AACK,QAAA,IAAI,CAAA,IAAA,GAAkC,QAAQ;AAO7C,QAAA,IAAW,CAAA,WAAA,GAAY,KAAK;AAC5B,QAAA,IAAY,CAAA,YAAA,GAAY,KAAK;QAE9B,IAAgB,CAAA,gBAAA,GAAG,CAAC,QAAoC,KAAK,CAAC,KAAY,KAAI;AACpF,YAAA,MAAM,IAAI,GAAG,KAAK,CAAC,MAAyB;YAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC;AAClD,YAAA,IAAI,QAAQ,KAAK,WAAW,EAAE;AAC5B,gBAAA,IAAI,CAAC,WAAW,GAAG,UAAU;;iBACxB;AACL,gBAAA,IAAI,CAAC,YAAY,GAAG,UAAU;;AAElC,SAAC;AAyCF;IAvCC,MAAM,GAAA;AACJ,QAAA,MAAM,OAAO,GAAG;AACd,YAAA,QAAQ,EAAE,IAAI;AACd,YAAA,CAAC,WAAW,IAAI,CAAC,OAAO,CAAE,CAAA,GAAG,IAAI;AACjC,YAAA,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAE,CAAA,GAAG,IAAI;YAC3B,UAAU,EAAE,IAAI,CAAC;SAClB;AAED,QAAA,MAAM,OAAO,GAAG;AACd,YAAAA,OAAA,CAAA,MAAA,EAAA,EAAM,KAAK,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,CAAC,WAAW,EAAE,EAAA,EACjEA,OAAA,CAAA,MAAA,EAAA,EAAM,IAAI,EAAC,WAAW,EAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,GAAS,CAC3E;AACP,YAAAA,OAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,OAAO,EAAA,EACjBA,OAAA,CAAA,MAAA,EAAA,IAAA,CAAa,CACR;AACP,YAAAA,OAAA,CAAA,MAAA,EAAA,EAAM,KAAK,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,CAAC,YAAY,EAAE,EAAA,EACnEA,OAAA,CAAA,MAAA,EAAA,EAAM,IAAI,EAAC,YAAY,EAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,GAAS;SAErF;;QAGD,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC/B,QACEA,QAACC,UAAI,EAAA,IAAA,EACHD,OAAA,CAAA,GAAA,EAAA,EAAG,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,EAC/B,EAAA,OAAO,CACN,CACC;;AAIX,QAAA,QACEA,QAACC,UAAI,EAAA,IAAA,EACHD,OAAQ,CAAA,QAAA,EAAA,EAAA,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAA,EAC7D,OAAO,CACD,CACJ;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afCardCss = () => `.sc-af-card-h{display:block;width:100%}[stretch].sc-af-card-h{display:flex;flex-direction:column;height:100%}[stretch].sc-af-card-h .card.sc-af-card{flex:1 1 auto}[stretch].sc-af-card-h .card__content.sc-af-card{flex:1 1 auto}.card.sc-af-card{border-radius:var(--border-radius-card-level-1, 32px);overflow:hidden;position:relative;display:flex;flex-direction:column;box-sizing:border-box}.card.theme-white.sc-af-card{background-color:var(--colour-brand-white, #ffffff);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-background-level-1:var(--colour-mistgreen-200, #e8eeed)}.card.theme-white-ivory.sc-af-card{background-color:var(--colour-brand-ivory-paper, #fff9ee);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-background-level-1:var(--colour-ivory-200, #ffefcc)}.card.theme-inkwell.sc-af-card{background-color:var(--colour-brand-inkwell, #14343b);--af-typography-heading-primary:var(--colour-brand-mist-green, #c6d5d1);--af-typography-body-default:var(--colour-inkwell-100, #d0d6d8);--af-background-level-1:var(--colour-inkwell-450, #203e45);--af-button-secondary-text:var(--colour-brand-white, #ffffff);--af-button-secondary-stroke:var(--colour-brand-white, #ffffff);--af-button-ghost-text:var(--colour-brand-white, #ffffff);--af-button-ghost-icon:var(--colour-brand-white, #ffffff);--af-form-control-bg:var(--colour-inkwell-450, #203e45);--af-form-control-bg-checked:var(--colour-brand-mist-green, #c6d5d1);--af-form-control-bg-disabled:var(--colour-inkwell-400, #2b484f);--af-form-control-bg-checked-disabled:var(--colour-mistgreen-700, #9eaaa7);--af-form-control-stroke:var(--colour-inkwell-350, #60767b);--af-form-control-stroke-hover:var(--colour-brand-white, #ffffff);--af-form-control-stroke-disabled:var(--colour-inkwell-400, #2b484f);--af-form-control-icon:var(--colour-brand-inkwell, #14343b);--af-form-control-label:var(--colour-brand-white, #ffffff)}.card.theme-mist-green.sc-af-card{background-color:var(--colour-brand-mist-green, #c6d5d1);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-background-level-1:var(--colour-mistgreen-300, #dde6e3)}.card.theme-soft-clay.sc-af-card{background-color:var(--colour-softclay-400, #c0ab8d);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-heading-secondary:var(--colour-brand-ivory-paper, #fff9ee);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-background-level-1:var(--colour-softclay-500, #b09670)}.card__content.sc-af-card{position:relative;padding:var(--af-card-padding, 40px);display:flex;flex-direction:column;gap:var(--af-card-gap, 24px);flex:1;box-sizing:border-box;z-index:1}.card__content.sc-af-card-s>af-heading,.card__content .sc-af-card-s>af-heading{margin-bottom:0}.card__content.sc-af-card-s>af-text,.card__content .sc-af-card-s>af-text{line-height:1.44}`;
5
+ const afCardCss = ".sc-af-card-h{display:block;width:100%}[stretch].sc-af-card-h{display:flex;flex-direction:column;height:100%}[stretch].sc-af-card-h .card.sc-af-card{flex:1 1 auto}[stretch].sc-af-card-h .card__content.sc-af-card{flex:1 1 auto}.card.sc-af-card{border-radius:var(--border-radius-card-level-1, 32px);overflow:hidden;position:relative;display:flex;flex-direction:column;box-sizing:border-box}.card.theme-white.sc-af-card{background-color:var(--colour-brand-white, #ffffff);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-background-level-1:var(--colour-mistgreen-200, #e8eeed)}.card.theme-white-ivory.sc-af-card{background-color:var(--colour-brand-ivory-paper, #fff9ee);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-background-level-1:var(--colour-ivory-200, #ffefcc)}.card.theme-inkwell.sc-af-card{background-color:var(--colour-brand-inkwell, #14343b);--af-typography-heading-primary:var(--colour-brand-mist-green, #c6d5d1);--af-typography-body-default:var(--colour-inkwell-100, #d0d6d8);--af-background-level-1:var(--colour-inkwell-450, #203e45);--af-button-secondary-text:var(--colour-brand-white, #ffffff);--af-button-secondary-stroke:var(--colour-brand-white, #ffffff);--af-button-ghost-text:var(--colour-brand-white, #ffffff);--af-button-ghost-icon:var(--colour-brand-white, #ffffff);--af-form-control-bg:var(--colour-inkwell-450, #203e45);--af-form-control-bg-checked:var(--colour-brand-mist-green, #c6d5d1);--af-form-control-bg-disabled:var(--colour-inkwell-400, #2b484f);--af-form-control-bg-checked-disabled:var(--colour-mistgreen-700, #9eaaa7);--af-form-control-stroke:var(--colour-inkwell-350, #60767b);--af-form-control-stroke-hover:var(--colour-brand-white, #ffffff);--af-form-control-stroke-disabled:var(--colour-inkwell-400, #2b484f);--af-form-control-icon:var(--colour-brand-inkwell, #14343b);--af-form-control-label:var(--colour-brand-white, #ffffff)}.card.theme-mist-green.sc-af-card{background-color:var(--colour-brand-mist-green, #c6d5d1);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-background-level-1:var(--colour-mistgreen-300, #dde6e3)}.card.theme-soft-clay.sc-af-card{background-color:var(--colour-softclay-400, #c0ab8d);--af-typography-heading-primary:var(--colour-brand-inkwell, #14343b);--af-typography-heading-secondary:var(--colour-brand-ivory-paper, #fff9ee);--af-typography-body-default:var(--colour-inkwell-400, #2b484f);--af-background-level-1:var(--colour-softclay-500, #b09670)}.card__content.sc-af-card{position:relative;padding:var(--af-card-padding, 40px);display:flex;flex-direction:column;gap:var(--af-card-gap, 24px);flex:1;box-sizing:border-box;z-index:1}.card__content.sc-af-card-s>af-heading,.card__content .sc-af-card-s>af-heading{margin-bottom:0}.card__content.sc-af-card-s>af-text,.card__content .sc-af-card-s>af-text{line-height:1.44}";
6
6
 
7
7
  const AfCard = class {
8
8
  constructor(hostRef) {
@@ -28,6 +28,7 @@ const AfCard = class {
28
28
  return (index.h(index.Host, { key: '9847c934dc643291c0b19a5bbd7a5a1f95171573' }, index.h("div", { key: 'ef75699eb880055c79cfb605821167e5e9958aa5', class: classes }, index.h("div", { key: '48b0ca5f605d7af698564d6907e38dedf2a4beef', class: "card__content" }, index.h("slot", { key: 'fa2832e5ff3796fc80b72d5a4cb630e978a4b083' })))));
29
29
  }
30
30
  };
31
- AfCard.style = afCardCss();
31
+ AfCard.style = afCardCss;
32
32
 
33
33
  exports.af_card = AfCard;
34
+ //# sourceMappingURL=af-card.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-card.entry.cjs.js","sources":["src/components/af-card/af-card.css?tag=af-card&encapsulation=scoped","src/components/af-card/af-card.tsx"],"sourcesContent":["/* Theme CSS custom properties follow the global token structure from @affinda/tokens */\n\n:host {\n display: block;\n width: 100%;\n}\n\n/* ==========================================================================\n Stretch Mode\n \n When stretch attribute is present, the card fills its container height\n and uses flexbox to distribute space between children. This enables\n equal-height cards in grid/flex layouts.\n ========================================================================== */\n\n:host([stretch]) {\n display: flex;\n flex-direction: column;\n height: 100%;\n}\n\n:host([stretch]) .card {\n flex: 1 1 auto;\n}\n\n:host([stretch]) .card__content {\n flex: 1 1 auto;\n}\n\n/* ==========================================================================\n Base Card Styles\n ========================================================================== */\n\n.card {\n border-radius: var(--border-radius-card-level-1, 32px);\n overflow: hidden;\n position: relative;\n display: flex;\n flex-direction: column;\n box-sizing: border-box;\n}\n\n/* ==========================================================================\n Theme Variants\n \n Background colors from Figma tokens:\n - white: #ffffff (Colour/Brand/White)\n - white-ivory: #fff9ee (Colour/Brand/Ivory-Paper)\n - inkwell: #14343b (Colour/Brand/Inkwell)\n - mist-green: #c6d5d1 (Colour/Brand/Mist-Green)\n - soft-clay: #c0ab8d (Colour/Softclay/400)\n ========================================================================== */\n\n/* WHITE THEME */\n.card.theme-white {\n background-color: var(--colour-brand-white, #ffffff);\n \n /* Typography */\n --af-typography-heading-primary: var(--colour-brand-inkwell, #14343b);\n --af-typography-body-default: var(--colour-inkwell-400, #2b484f);\n --af-background-level-1: var(--colour-mistgreen-200, #e8eeed);\n}\n\n/* WHITE-IVORY THEME */\n.card.theme-white-ivory {\n background-color: var(--colour-brand-ivory-paper, #fff9ee);\n \n /* Typography */\n --af-typography-heading-primary: var(--colour-brand-inkwell, #14343b);\n --af-typography-body-default: var(--colour-inkwell-400, #2b484f);\n --af-background-level-1: var(--colour-ivory-200, #ffefcc);\n}\n\n/* INKWELL THEME (Dark) */\n.card.theme-inkwell {\n background-color: var(--colour-brand-inkwell, #14343b);\n \n /* Typography - light colors on dark background */\n --af-typography-heading-primary: var(--colour-brand-mist-green, #c6d5d1);\n --af-typography-body-default: var(--colour-inkwell-100, #d0d6d8);\n --af-background-level-1: var(--colour-inkwell-450, #203e45);\n \n /* Button variants for dark theme */\n --af-button-secondary-text: var(--colour-brand-white, #ffffff);\n --af-button-secondary-stroke: var(--colour-brand-white, #ffffff);\n --af-button-ghost-text: var(--colour-brand-white, #ffffff);\n --af-button-ghost-icon: var(--colour-brand-white, #ffffff);\n \n /* Form control tokens (checkbox, radio, switch) */\n --af-form-control-bg: var(--colour-inkwell-450, #203e45);\n --af-form-control-bg-checked: var(--colour-brand-mist-green, #c6d5d1);\n --af-form-control-bg-disabled: var(--colour-inkwell-400, #2b484f);\n --af-form-control-bg-checked-disabled: var(--colour-mistgreen-700, #9eaaa7);\n --af-form-control-stroke: var(--colour-inkwell-350, #60767b);\n --af-form-control-stroke-hover: var(--colour-brand-white, #ffffff);\n --af-form-control-stroke-disabled: var(--colour-inkwell-400, #2b484f);\n --af-form-control-icon: var(--colour-brand-inkwell, #14343b);\n --af-form-control-label: var(--colour-brand-white, #ffffff);\n}\n\n/* MIST-GREEN THEME */\n.card.theme-mist-green {\n background-color: var(--colour-brand-mist-green, #c6d5d1);\n \n /* Typography */\n --af-typography-heading-primary: var(--colour-brand-inkwell, #14343b);\n --af-typography-body-default: var(--colour-inkwell-400, #2b484f);\n --af-background-level-1: var(--colour-mistgreen-300, #dde6e3);\n}\n\n/* SOFT-CLAY THEME */\n.card.theme-soft-clay {\n background-color: var(--colour-softclay-400, #c0ab8d);\n \n /* Typography */\n --af-typography-heading-primary: var(--colour-brand-inkwell, #14343b);\n --af-typography-heading-secondary: var(--colour-brand-ivory-paper, #fff9ee);\n --af-typography-body-default: var(--colour-inkwell-400, #2b484f);\n --af-background-level-1: var(--colour-softclay-500, #b09670);\n}\n\n/* ==========================================================================\n Card Content\n ========================================================================== */\n\n.card__content {\n position: relative;\n padding: var(--af-card-padding, 40px);\n display: flex;\n flex-direction: column;\n gap: var(--af-card-gap, 24px);\n flex: 1;\n box-sizing: border-box;\n z-index: 1;\n}\n\n/* Heading spacing within cards */\n.card__content ::slotted(af-heading) {\n margin-bottom: 0;\n}\n\n/* Text line-height within cards */\n.card__content ::slotted(af-text) {\n line-height: 1.44;\n}\n","import { Component, Prop, h, Host } from '@stencil/core';\n\n/**\n * Card atom component - a themed container with consistent styling.\n * Provides theme context to children via CSS custom properties.\n * \n * This is a base building block used by molecule components like\n * af-feature-card and af-illustrated-card.\n */\n@Component({\n tag: 'af-card',\n styleUrl: 'af-card.css',\n shadow: false,\n scoped: true,\n})\nexport class AfCard {\n /**\n * Theme - sets background color and provides theme context to children.\n * Defaults to 'mist-green' if not specified.\n */\n @Prop() theme?: 'white' | 'white-ivory' | 'inkwell' | 'mist-green' | 'soft-clay' = 'mist-green';\n\n /**\n * When true, the card stretches to fill its container height.\n * Use this when the card is in a flex/grid container and needs to\n * participate in equal-height layouts. The card's content will use\n * flexbox to distribute space between children.\n */\n @Prop({ reflect: true }) stretch: boolean = false;\n\n render() {\n const classes = {\n 'card': true,\n [`theme-${this.theme}`]: true\n };\n\n return (\n <Host>\n <div class={classes}>\n <div class=\"card__content\">\n <slot></slot>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"names":["h","Host"],"mappings":";;;;AAAA,MAAM,SAAS,GAAG,i/FAAi/F;;MCet/F,MAAM,GAAA,MAAA;AANnB,IAAA,WAAA,CAAA,OAAA,EAAA;;AAOE;;;AAGG;AACK,QAAA,IAAK,CAAA,KAAA,GAAsE,YAAY;AAE/F;;;;;AAKG;AACsB,QAAA,IAAO,CAAA,OAAA,GAAY,KAAK;AAkBlD;IAhBC,MAAM,GAAA;AACJ,QAAA,MAAM,OAAO,GAAG;AACd,YAAA,MAAM,EAAE,IAAI;AACZ,YAAA,CAAC,SAAS,IAAI,CAAC,KAAK,CAAE,CAAA,GAAG;SAC1B;QAED,QACEA,QAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACHD,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,OAAO,EAAA,EACjBA,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,eAAe,EAAA,EACxBA,OAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAa,CACT,CACF,CACD;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afCenterCss = () => `:host{display:flex;box-sizing:border-box}:host([hidden]){display:none}`;
5
+ const afCenterCss = ":host{display:flex;box-sizing:border-box}:host([hidden]){display:none}";
6
6
 
7
7
  const AfCenter = class {
8
8
  constructor(hostRef) {
@@ -36,6 +36,7 @@ const AfCenter = class {
36
36
  return (index.h(index.Host, { key: 'fc1bcaef9b11c0c5f69e9ef95d58adf61b4f244a', style: style }, index.h("slot", { key: '09dc75e0a80760d56e370ad0b52231f4143549e8' })));
37
37
  }
38
38
  };
39
- AfCenter.style = afCenterCss();
39
+ AfCenter.style = afCenterCss;
40
40
 
41
41
  exports.af_center = AfCenter;
42
+ //# sourceMappingURL=af-center.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-center.entry.cjs.js","sources":["src/components/af-center/af-center.css?tag=af-center&encapsulation=shadow","src/components/af-center/af-center.tsx"],"sourcesContent":[":host {\n display: flex;\n box-sizing: border-box;\n}\n\n:host([hidden]) {\n display: none;\n}\n\n","import { Component, h, Host, Prop } from '@stencil/core';\n\ntype Axis = 'horizontal' | 'vertical' | 'both';\n\n/**\n * Center layout component for quickly centering content.\n * Supports horizontal, vertical, or both axes.\n *\n * @slot - Content to center\n */\n@Component({\n tag: 'af-center',\n styleUrl: 'af-center.css',\n shadow: true,\n})\nexport class AfCenter {\n /**\n * Which axis to center on.\n * - 'horizontal': Center horizontally (justify-content: center)\n * - 'vertical': Center vertically (align-items: center)\n * - 'both': Center on both axes\n */\n @Prop() axis: Axis = 'both';\n\n /**\n * Use inline-flex instead of flex.\n * Useful when the center container should only take up as much space as needed.\n */\n @Prop() inline: boolean = false;\n\n /**\n * Set a minimum height. Useful for vertical centering in a viewport.\n * Accepts any valid CSS value (e.g., '100vh', '400px').\n */\n @Prop() minHeight?: string;\n\n render() {\n const style: Record<string, string> = {\n display: this.inline ? 'inline-flex' : 'flex',\n };\n\n if (this.axis === 'horizontal' || this.axis === 'both') {\n style.justifyContent = 'center';\n }\n\n if (this.axis === 'vertical' || this.axis === 'both') {\n style.alignItems = 'center';\n }\n\n if (this.minHeight) {\n style.minHeight = this.minHeight;\n }\n\n return (\n <Host style={style}>\n <slot></slot>\n </Host>\n );\n }\n}\n\n"],"names":["h","Host"],"mappings":";;;;AAAA,MAAM,WAAW,GAAG,wEAAwE;;MCe/E,QAAQ,GAAA,MAAA;AALrB,IAAA,WAAA,CAAA,OAAA,EAAA;;AAME;;;;;AAKG;AACK,QAAA,IAAI,CAAA,IAAA,GAAS,MAAM;AAE3B;;;AAGG;AACK,QAAA,IAAM,CAAA,MAAA,GAAY,KAAK;AA+BhC;IAvBC,MAAM,GAAA;AACJ,QAAA,MAAM,KAAK,GAA2B;YACpC,OAAO,EAAE,IAAI,CAAC,MAAM,GAAG,aAAa,GAAG,MAAM;SAC9C;AAED,QAAA,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;AACtD,YAAA,KAAK,CAAC,cAAc,GAAG,QAAQ;;AAGjC,QAAA,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;AACpD,YAAA,KAAK,CAAC,UAAU,GAAG,QAAQ;;AAG7B,QAAA,IAAI,IAAI,CAAC,SAAS,EAAE;AAClB,YAAA,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS;;QAGlC,QACEA,OAAC,CAAAC,UAAI,EAAC,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,KAAK,EAAA,EAChBD,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACR;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afCheckboxCss = () => `:host{display:inline-block}.checkbox{display:inline-flex;align-items:center;gap:12px;cursor:pointer;font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-size:14px;line-height:20px;color:var(--af-form-control-label, var(--colour-brand-inkwell, #14343b));user-select:none}.checkbox.disabled{cursor:not-allowed;opacity:0.5}.input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}.control{position:relative;display:block;flex-shrink:0;width:20px;height:20px;border-radius:var(--radii-checkbox, 4px);border:none;box-shadow:inset 0 0 0 1px var(--af-form-control-stroke, var(--colour-mistgreen-500, #d0d6d8));background:var(--af-form-control-bg, var(--colour-brand-white, #ffffff));transition:all 0.15s ease;box-sizing:border-box}.control.checked{background:var(--af-form-control-bg-checked, var(--colour-brand-inkwell, #14343b));box-shadow:none}.control.disabled{background:var(--af-form-control-bg-disabled, var(--colour-mistgreen-200, #e8ebeb));box-shadow:inset 0 0 0 1px var(--af-form-control-stroke-disabled, var(--colour-mistgreen-500, #d0d6d8))}.control.checked.disabled{background:var(--af-form-control-bg-checked-disabled, var(--colour-inkwell-350, #708380));box-shadow:none}.checkbox:not(.disabled):hover .control:not(.checked){box-shadow:inset 0 0 0 1px var(--af-form-control-stroke-hover, var(--colour-brand-inkwell, #14343b))}.input:focus-visible+.control{outline:none;box-shadow:inset 0 0 0 1px var(--af-form-control-stroke, var(--colour-mistgreen-500, #d0d6d8)), 0 0 0 4px var(--af-background-base, var(--colour-brand-white, #ffffff)), 0 0 0 5px var(--af-form-control-stroke-hover, var(--colour-brand-inkwell, #14343b))}.input:focus-visible+.control.checked{box-shadow:0 0 0 4px var(--af-background-base, var(--colour-brand-white, #ffffff)), 0 0 0 5px var(--af-form-control-stroke-hover, var(--colour-brand-inkwell, #14343b))}.icon{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:16px;height:16px;color:var(--af-form-control-icon, var(--colour-brand-white, #ffffff))}.label{display:flex;align-items:center;min-height:24px}.label:empty{display:none}`;
5
+ const afCheckboxCss = ":host{display:inline-block}.checkbox{display:inline-flex;align-items:center;gap:12px;cursor:pointer;font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-size:14px;line-height:20px;color:var(--af-form-control-label, var(--colour-brand-inkwell, #14343b));user-select:none}.checkbox.disabled{cursor:not-allowed;opacity:0.5}.input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}.control{position:relative;display:block;flex-shrink:0;width:20px;height:20px;border-radius:var(--radii-checkbox, 4px);border:none;box-shadow:inset 0 0 0 1px var(--af-form-control-stroke, var(--colour-mistgreen-500, #d0d6d8));background:var(--af-form-control-bg, var(--colour-brand-white, #ffffff));transition:all 0.15s ease;box-sizing:border-box}.control.checked{background:var(--af-form-control-bg-checked, var(--colour-brand-inkwell, #14343b));box-shadow:none}.control.disabled{background:var(--af-form-control-bg-disabled, var(--colour-mistgreen-200, #e8ebeb));box-shadow:inset 0 0 0 1px var(--af-form-control-stroke-disabled, var(--colour-mistgreen-500, #d0d6d8))}.control.checked.disabled{background:var(--af-form-control-bg-checked-disabled, var(--colour-inkwell-350, #708380));box-shadow:none}.checkbox:not(.disabled):hover .control:not(.checked){box-shadow:inset 0 0 0 1px var(--af-form-control-stroke-hover, var(--colour-brand-inkwell, #14343b))}.input:focus-visible+.control{outline:none;box-shadow:inset 0 0 0 1px var(--af-form-control-stroke, var(--colour-mistgreen-500, #d0d6d8)),\n 0 0 0 4px var(--af-background-base, var(--colour-brand-white, #ffffff)), \n 0 0 0 5px var(--af-form-control-stroke-hover, var(--colour-brand-inkwell, #14343b))}.input:focus-visible+.control.checked{box-shadow:0 0 0 4px var(--af-background-base, var(--colour-brand-white, #ffffff)), \n 0 0 0 5px var(--af-form-control-stroke-hover, var(--colour-brand-inkwell, #14343b))}.icon{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:16px;height:16px;color:var(--af-form-control-icon, var(--colour-brand-white, #ffffff))}.label{display:flex;align-items:center;min-height:24px}.label:empty{display:none}";
6
6
 
7
7
  const AfCheckbox = class {
8
8
  constructor(hostRef) {
@@ -52,6 +52,7 @@ const AfCheckbox = class {
52
52
  return (index.h(index.Host, { key: 'ac1342168fe00b6f44c4c66b0209b757f9e7aeea' }, index.h("label", { key: 'af654777ec1ab09e5adf5893c1c5d3b5b1d9cb05', class: checkboxClasses }, index.h("input", { key: '7e59073ceb227f2440a2aca07de4ba3bb9f5460e', type: "checkbox", class: "input", ref: (el) => this.inputEl = el ?? undefined, checked: this.checked, disabled: this.disabled, name: this.name, value: this.value, onChange: this.handleChange }), index.h("span", { key: '7e07dc92184ea28516d2789dfd3eccf5fc0066da', class: controlClasses }, this.checked && !this.indeterminate && (index.h("svg", { key: '10da3ed00d0d94d494a89532f44c64012ed775ce', class: "icon", viewBox: "0 0 16 16", fill: "none" }, index.h("path", { key: 'aae8aa17285c64b5448546504286a054a76873d9', d: "M13.5 4L6 11.5L2.5 8", stroke: "currentColor", "stroke-width": "2", "stroke-linecap": "round", "stroke-linejoin": "round" }))), this.indeterminate && (index.h("svg", { key: '900391d075f2284e1f80891f34e9d4d24e635b2c', class: "icon", viewBox: "0 0 16 16", fill: "none" }, index.h("path", { key: '43cd04ad38021b0d9641ed3b5d7efa15b7e1281e', d: "M3 8H13", stroke: "currentColor", "stroke-width": "2", "stroke-linecap": "round" })))), index.h("span", { key: 'c5eea42915108d23d6eb104ada070e843a6a24f1', class: "label" }, index.h("slot", { key: '8572b7a2c909d201c6800737dfb528baa52de573' })))));
53
53
  }
54
54
  };
55
- AfCheckbox.style = afCheckboxCss();
55
+ AfCheckbox.style = afCheckboxCss;
56
56
 
57
57
  exports.af_checkbox = AfCheckbox;
58
+ //# sourceMappingURL=af-checkbox.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-checkbox.entry.cjs.js","sources":["src/components/af-checkbox/af-checkbox.css?tag=af-checkbox&encapsulation=shadow","src/components/af-checkbox/af-checkbox.tsx"],"sourcesContent":[":host {\n display: inline-block;\n}\n\n.checkbox {\n display: inline-flex;\n align-items: center;\n gap: 12px;\n cursor: pointer;\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-size: 14px;\n line-height: 20px;\n color: var(--af-form-control-label, var(--colour-brand-inkwell, #14343b));\n user-select: none;\n}\n\n.checkbox.disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n\n/* Hidden native input */\n.input {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n}\n\n/* Custom checkbox control */\n.control {\n position: relative;\n display: block;\n flex-shrink: 0;\n width: 20px;\n height: 20px;\n border-radius: var(--radii-checkbox, 4px);\n /* Use inset box-shadow instead of border to prevent layout shift */\n border: none;\n box-shadow: inset 0 0 0 1px var(--af-form-control-stroke, var(--colour-mistgreen-500, #d0d6d8));\n background: var(--af-form-control-bg, var(--colour-brand-white, #ffffff));\n transition: all 0.15s ease;\n box-sizing: border-box;\n}\n\n/* Checked/indeterminate state */\n.control.checked {\n background: var(--af-form-control-bg-checked, var(--colour-brand-inkwell, #14343b));\n box-shadow: none;\n}\n\n/* Disabled state */\n.control.disabled {\n background: var(--af-form-control-bg-disabled, var(--colour-mistgreen-200, #e8ebeb));\n box-shadow: inset 0 0 0 1px var(--af-form-control-stroke-disabled, var(--colour-mistgreen-500, #d0d6d8));\n}\n\n.control.checked.disabled {\n background: var(--af-form-control-bg-checked-disabled, var(--colour-inkwell-350, #708380));\n box-shadow: none;\n}\n\n/* Hover state */\n.checkbox:not(.disabled):hover .control:not(.checked) {\n box-shadow: inset 0 0 0 1px var(--af-form-control-stroke-hover, var(--colour-brand-inkwell, #14343b));\n}\n\n/* Focus state */\n.input:focus-visible + .control {\n outline: none;\n box-shadow: \n inset 0 0 0 1px var(--af-form-control-stroke, var(--colour-mistgreen-500, #d0d6d8)),\n 0 0 0 4px var(--af-background-base, var(--colour-brand-white, #ffffff)), \n 0 0 0 5px var(--af-form-control-stroke-hover, var(--colour-brand-inkwell, #14343b));\n}\n\n.input:focus-visible + .control.checked {\n box-shadow: \n 0 0 0 4px var(--af-background-base, var(--colour-brand-white, #ffffff)), \n 0 0 0 5px var(--af-form-control-stroke-hover, var(--colour-brand-inkwell, #14343b));\n}\n\n/* Icon styling - absolutely positioned to prevent layout shift */\n.icon {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: 16px;\n height: 16px;\n color: var(--af-form-control-icon, var(--colour-brand-white, #ffffff));\n}\n\n/* Label styling */\n.label {\n display: flex;\n align-items: center;\n min-height: 24px;\n}\n\n/* Empty label - hide if no content */\n.label:empty {\n display: none;\n}\n","import { Component, h, Prop, Host, Event, EventEmitter } from '@stencil/core';\n\n/**\n * Checkbox component for selecting multiple options.\n * Supports checked, unchecked, and indeterminate states.\n * \n * @slot - Checkbox label text\n */\n@Component({\n tag: 'af-checkbox',\n styleUrl: 'af-checkbox.css',\n shadow: true\n})\nexport class AfCheckbox {\n /**\n * Whether the checkbox is checked\n */\n @Prop({ mutable: true, reflect: true }) checked: boolean = false;\n\n /**\n * Whether the checkbox is in an indeterminate state\n */\n @Prop({ reflect: true }) indeterminate: boolean = false;\n\n /**\n * Whether the checkbox is disabled\n */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /**\n * The name of the checkbox for form submission\n */\n @Prop() name?: string;\n\n /**\n * The value of the checkbox for form submission\n */\n @Prop() value?: string;\n\n /**\n * Emitted when the checkbox checked state changes\n */\n @Event() afChange!: EventEmitter<{ checked: boolean }>;\n\n private inputEl?: HTMLInputElement;\n\n private handleChange = () => {\n if (this.disabled) return;\n this.checked = !this.checked;\n this.afChange.emit({ checked: this.checked });\n };\n\n componentDidLoad() {\n if (this.inputEl) {\n this.inputEl.indeterminate = this.indeterminate;\n }\n }\n\n componentDidUpdate() {\n if (this.inputEl) {\n this.inputEl.indeterminate = this.indeterminate;\n }\n }\n\n render() {\n const checkboxClasses = {\n 'checkbox': true,\n 'checked': this.checked,\n 'indeterminate': this.indeterminate,\n 'disabled': this.disabled\n };\n\n const controlClasses = {\n 'control': true,\n 'checked': this.checked || this.indeterminate,\n 'disabled': this.disabled\n };\n\n return (\n <Host>\n <label class={checkboxClasses}>\n <input\n type=\"checkbox\"\n class=\"input\"\n ref={(el) => this.inputEl = el ?? undefined}\n checked={this.checked}\n disabled={this.disabled}\n name={this.name}\n value={this.value}\n onChange={this.handleChange}\n />\n <span class={controlClasses}>\n {this.checked && !this.indeterminate && (\n <svg class=\"icon\" viewBox=\"0 0 16 16\" fill=\"none\">\n <path \n d=\"M13.5 4L6 11.5L2.5 8\" \n stroke=\"currentColor\" \n stroke-width=\"2\" \n stroke-linecap=\"round\" \n stroke-linejoin=\"round\"\n />\n </svg>\n )}\n {this.indeterminate && (\n <svg class=\"icon\" viewBox=\"0 0 16 16\" fill=\"none\">\n <path \n d=\"M3 8H13\" \n stroke=\"currentColor\" \n stroke-width=\"2\" \n stroke-linecap=\"round\"\n />\n </svg>\n )}\n </span>\n <span class=\"label\">\n <slot></slot>\n </span>\n </label>\n </Host>\n );\n }\n}\n\n"],"names":["h","Host"],"mappings":"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"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afClientCarouselCss = () => `.sc-af-client-carousel-h{display:block;width:100%}.client-carousel.sc-af-client-carousel{padding:48px 0;display:flex;flex-direction:column;align-items:center;width:100%;overflow:hidden}.carousel-container.sc-af-client-carousel{display:flex;flex-direction:column;gap:var(--space-4, 16px);width:100%;overflow:hidden}.carousel-row.sc-af-client-carousel{display:flex;width:100%;overflow:hidden;position:relative}.logo-track.sc-af-client-carousel{display:flex;gap:var(--space-4, 16px);animation-timing-function:linear;animation-iteration-count:infinite}.scroll-left.sc-af-client-carousel .logo-track.sc-af-client-carousel{animation-name:scroll-left;animation-duration:40s}.scroll-right.sc-af-client-carousel .logo-track.sc-af-client-carousel{animation-name:scroll-right;animation-duration:40s}.sc-af-client-carousel-h:hover .logo-track.sc-af-client-carousel{animation-play-state:paused}@media (prefers-reduced-motion: reduce){.logo-track.sc-af-client-carousel,.scroll-left.sc-af-client-carousel .logo-track.sc-af-client-carousel,.scroll-right.sc-af-client-carousel .logo-track.sc-af-client-carousel{animation:none;transform:translateX(0)}}@keyframes scroll-left{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}@keyframes scroll-right{0%{transform:translateX(-50%)}100%{transform:translateX(0)}}.logo-track.sc-af-client-carousel>*.sc-af-client-carousel{display:flex;flex-shrink:0;gap:var(--space-4, 16px);align-items:center}.theme-inkwell.sc-af-client-carousel-h,.client-carousel.theme-inkwell.sc-af-client-carousel{background-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-well-bg:var(--colour-background-level1-dark, #203e45);--af-carousel-logo-color:white;--af-carousel-logo-filter:brightness(0) invert(1)}.theme-white.sc-af-client-carousel-h,.client-carousel.theme-white.sc-af-client-carousel{background-color:var(--colour-brand-white, #FFFFFF);--af-carousel-logo-well-bg:var(--colour-background-level1, #e8eeed);--af-carousel-logo-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-filter:none}.theme-mist-green.sc-af-client-carousel-h,.client-carousel.theme-mist-green.sc-af-client-carousel{background-color:var(--colour-brand-mist-green, #C6D5D1);--af-carousel-logo-well-bg:var(--colour-mistgreen-300, #dde6e3);--af-carousel-logo-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-filter:none}.theme-soft-clay.sc-af-client-carousel-h,.client-carousel.theme-soft-clay.sc-af-client-carousel{background-color:var(--colour-softclay-400, #c0ab8d);--af-carousel-logo-well-bg:var(--colour-softclay-200, #d5c5b0);--af-carousel-logo-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-filter:none}.theme-white-ivory.sc-af-client-carousel-h,.client-carousel.theme-white-ivory.sc-af-client-carousel{background-color:var(--colour-brand-ivory-paper, #fff9ee);--af-carousel-logo-well-bg:var(--colour-softclay-100, #f2eadc);--af-carousel-logo-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-filter:none}@media (max-width: 1024px){.client-carousel.sc-af-client-carousel{padding:32px 0}}@media (max-width: 767px){.client-carousel.sc-af-client-carousel{padding:24px 0}.carousel-container.sc-af-client-carousel{gap:var(--space-3, 12px)}.logo-track.sc-af-client-carousel{gap:var(--space-3, 12px)}.sc-af-client-carousel-s>*{gap:var(--space-3, 12px)}}`;
5
+ const afClientCarouselCss = ".sc-af-client-carousel-h{display:block;width:100%}.client-carousel.sc-af-client-carousel{padding:48px 0;display:flex;flex-direction:column;align-items:center;width:100%;overflow:hidden}.carousel-container.sc-af-client-carousel{display:flex;flex-direction:column;gap:var(--space-4, 16px);width:100%;overflow:hidden}.carousel-row.sc-af-client-carousel{display:flex;width:100%;overflow:hidden;position:relative}.logo-track.sc-af-client-carousel{display:flex;gap:var(--space-4, 16px);animation-timing-function:linear;animation-iteration-count:infinite}.scroll-left.sc-af-client-carousel .logo-track.sc-af-client-carousel{animation-name:scroll-left;animation-duration:40s}.scroll-right.sc-af-client-carousel .logo-track.sc-af-client-carousel{animation-name:scroll-right;animation-duration:40s}.sc-af-client-carousel-h:hover .logo-track.sc-af-client-carousel{animation-play-state:paused}@media (prefers-reduced-motion: reduce){.logo-track.sc-af-client-carousel,.scroll-left.sc-af-client-carousel .logo-track.sc-af-client-carousel,.scroll-right.sc-af-client-carousel .logo-track.sc-af-client-carousel{animation:none;transform:translateX(0)}}@keyframes scroll-left{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}@keyframes scroll-right{0%{transform:translateX(-50%)}100%{transform:translateX(0)}}.logo-track.sc-af-client-carousel>*.sc-af-client-carousel{display:flex;flex-shrink:0;gap:var(--space-4, 16px);align-items:center}.theme-inkwell.sc-af-client-carousel-h,.client-carousel.theme-inkwell.sc-af-client-carousel{background-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-well-bg:var(--colour-background-level1-dark, #203e45);--af-carousel-logo-color:white;--af-carousel-logo-filter:brightness(0) invert(1)}.theme-white.sc-af-client-carousel-h,.client-carousel.theme-white.sc-af-client-carousel{background-color:var(--colour-brand-white, #FFFFFF);--af-carousel-logo-well-bg:var(--colour-background-level1, #e8eeed);--af-carousel-logo-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-filter:none}.theme-mist-green.sc-af-client-carousel-h,.client-carousel.theme-mist-green.sc-af-client-carousel{background-color:var(--colour-brand-mist-green, #C6D5D1);--af-carousel-logo-well-bg:var(--colour-mistgreen-300, #dde6e3);--af-carousel-logo-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-filter:none}.theme-soft-clay.sc-af-client-carousel-h,.client-carousel.theme-soft-clay.sc-af-client-carousel{background-color:var(--colour-softclay-400, #c0ab8d);--af-carousel-logo-well-bg:var(--colour-softclay-200, #d5c5b0);--af-carousel-logo-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-filter:none}.theme-white-ivory.sc-af-client-carousel-h,.client-carousel.theme-white-ivory.sc-af-client-carousel{background-color:var(--colour-brand-ivory-paper, #fff9ee);--af-carousel-logo-well-bg:var(--colour-softclay-100, #f2eadc);--af-carousel-logo-color:var(--colour-brand-inkwell, #14343B);--af-carousel-logo-filter:none}@media (max-width: 1024px){.client-carousel.sc-af-client-carousel{padding:32px 0}}@media (max-width: 767px){.client-carousel.sc-af-client-carousel{padding:24px 0}.carousel-container.sc-af-client-carousel{gap:var(--space-3, 12px)}.logo-track.sc-af-client-carousel{gap:var(--space-3, 12px)}.sc-af-client-carousel-s>*{gap:var(--space-3, 12px)}}";
6
6
 
7
7
  const AfClientCarousel = class {
8
8
  constructor(hostRef) {
@@ -52,6 +52,7 @@ const AfClientCarousel = class {
52
52
  }
53
53
  get el() { return index.getElement(this); }
54
54
  };
55
- AfClientCarousel.style = afClientCarouselCss();
55
+ AfClientCarousel.style = afClientCarouselCss;
56
56
 
57
57
  exports.af_client_carousel = AfClientCarousel;
58
+ //# sourceMappingURL=af-client-carousel.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-client-carousel.entry.cjs.js","sources":["src/components/af-client-carousel/af-client-carousel.css?tag=af-client-carousel&encapsulation=scoped","src/components/af-client-carousel/af-client-carousel.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n}\n\n.client-carousel {\n padding: 48px 0;\n display: flex;\n flex-direction: column;\n align-items: center;\n width: 100%;\n overflow: hidden;\n}\n\n.carousel-container {\n display: flex;\n flex-direction: column;\n gap: var(--space-4, 16px);\n width: 100%;\n overflow: hidden;\n}\n\n.carousel-row {\n display: flex;\n width: 100%;\n overflow: hidden;\n position: relative;\n}\n\n.logo-track {\n display: flex;\n gap: var(--space-4, 16px);\n animation-timing-function: linear;\n animation-iteration-count: infinite;\n}\n\n/* Scroll left animation */\n.scroll-left .logo-track {\n animation-name: scroll-left;\n animation-duration: 40s;\n}\n\n/* Scroll right animation */\n.scroll-right .logo-track {\n animation-name: scroll-right;\n animation-duration: 40s;\n}\n\n/* Pause animation on hover */\n:host(:hover) .logo-track {\n animation-play-state: paused;\n}\n\n/* Respect reduced motion: stop the infinite scroll and hold at a\n * stable frame so logos remain visible instead of being offscreen. */\n@media (prefers-reduced-motion: reduce) {\n .logo-track,\n .scroll-left .logo-track,\n .scroll-right .logo-track {\n animation: none;\n transform: translateX(0);\n }\n}\n\n@keyframes scroll-left {\n 0% {\n transform: translateX(0);\n }\n 100% {\n transform: translateX(-50%);\n }\n}\n\n@keyframes scroll-right {\n 0% {\n transform: translateX(-50%);\n }\n 100% {\n transform: translateX(0);\n }\n}\n\n/* Style slotted children (originals projected through the slot) and\n * JS-appended clones as flex rows. In scoped mode Stencil keeps all\n * this in light DOM, so a direct-descendant selector covers both. */\n.logo-track > * {\n display: flex;\n flex-shrink: 0;\n gap: var(--space-4, 16px);\n align-items: center;\n}\n\n/* ==========================================================================\n Theme Variants\n ========================================================================== */\n\n/* INKWELL THEME (Default) */\n:host(.theme-inkwell),\n.client-carousel.theme-inkwell {\n background-color: var(--colour-brand-inkwell, #14343B);\n --af-carousel-logo-well-bg: var(--colour-background-level1-dark, #203e45);\n --af-carousel-logo-color: white;\n --af-carousel-logo-filter: brightness(0) invert(1);\n}\n\n/* WHITE THEME */\n:host(.theme-white),\n.client-carousel.theme-white {\n background-color: var(--colour-brand-white, #FFFFFF);\n --af-carousel-logo-well-bg: var(--colour-background-level1, #e8eeed);\n --af-carousel-logo-color: var(--colour-brand-inkwell, #14343B);\n --af-carousel-logo-filter: none;\n}\n\n/* MIST-GREEN THEME */\n:host(.theme-mist-green),\n.client-carousel.theme-mist-green {\n background-color: var(--colour-brand-mist-green, #C6D5D1);\n --af-carousel-logo-well-bg: var(--colour-mistgreen-300, #dde6e3);\n --af-carousel-logo-color: var(--colour-brand-inkwell, #14343B);\n --af-carousel-logo-filter: none;\n}\n\n/* SOFT-CLAY THEME */\n:host(.theme-soft-clay),\n.client-carousel.theme-soft-clay {\n background-color: var(--colour-softclay-400, #c0ab8d);\n --af-carousel-logo-well-bg: var(--colour-softclay-200, #d5c5b0);\n --af-carousel-logo-color: var(--colour-brand-inkwell, #14343B);\n --af-carousel-logo-filter: none;\n}\n\n/* WHITE-IVORY THEME */\n:host(.theme-white-ivory),\n.client-carousel.theme-white-ivory {\n background-color: var(--colour-brand-ivory-paper, #fff9ee);\n --af-carousel-logo-well-bg: var(--colour-softclay-100, #f2eadc);\n --af-carousel-logo-color: var(--colour-brand-inkwell, #14343B);\n --af-carousel-logo-filter: none;\n}\n\n/* ==========================================================================\n Responsive Adjustments\n ========================================================================== */\n\n/* Tablet adjustments */\n/* ≤ tablet */\n@media (max-width: 1024px) {\n .client-carousel {\n padding: 32px 0;\n }\n}\n\n/* Mobile adjustments */\n/* ≤ mobile */\n@media (max-width: 767px) {\n .client-carousel {\n padding: 24px 0;\n }\n \n .carousel-container {\n gap: var(--space-3, 12px);\n }\n \n .logo-track {\n gap: var(--space-3, 12px);\n }\n \n ::slotted(*) {\n gap: var(--space-3, 12px);\n }\n}\n","import { Component, Element, h, Host, Prop } from '@stencil/core';\n\ntype Theme = 'white' | 'inkwell' | 'mist-green' | 'soft-clay' | 'white-ivory';\n\n/**\n * Infinite scrolling carousel for client logos.\n *\n * This is a section-level component that spans full width.\n * Renders one or two scrolling rows; single row matches the Webflow\n * reference, two rows (scrolling opposite directions) is the denser\n * variant.\n *\n * For headlines, use a separate TypographyLockup or Heading component\n * above this carousel.\n *\n * **Seamless loop:** the CSS animation translates the track from 0% to\n * -50% (or vice versa), which only looks continuous if the track holds\n * two identical copies of the content end-to-end. Shadow DOM slots can\n * only project content once, so we clone the slotted nodes in\n * `componentDidLoad` and append the copies to the track.\n */\n@Component({\n tag: 'af-client-carousel',\n styleUrl: 'af-client-carousel.css',\n // Scoped (not shadow) so that cloned nodes inherit the consumer's\n // external CSS (e.g. Astro-scoped `.logo-pill` on the SiteHeader\n // carousel). Shadow DOM would seal the clones off from outer styles.\n shadow: false,\n scoped: true,\n})\nexport class AfClientCarousel {\n @Element() el!: HTMLElement;\n\n /** Theme - sets background color and provides theme context to children */\n @Prop() theme: Theme = 'inkwell';\n\n /**\n * Number of scrolling rows.\n * - `1` (default) — single row scrolling left, matches the Webflow reference.\n * - `2` — two rows scrolling in opposite directions.\n *\n * When `rows=\"2\"`, slot `row-1` and `row-2` independently.\n * When `rows=\"1\"`, slot the default slot (unnamed) or `row-1`.\n */\n @Prop() rows: 1 | 2 = 1;\n\n private row1TrackRef?: HTMLElement;\n private row2TrackRef?: HTMLElement;\n\n componentDidLoad() {\n this.duplicateTrackContent(this.row1TrackRef);\n if (Number(this.rows) === 2) {\n this.duplicateTrackContent(this.row2TrackRef);\n }\n }\n\n /**\n * Append clones of every existing track child into the track so the\n * -50% translate animation loops seamlessly. Marks clones with\n * `aria-hidden` and `data-carousel-clone` so assistive tech ignores\n * them and we can skip them when re-duplicating.\n *\n * In scoped mode, slotted content is moved into the track as regular\n * children (there's no `<slot>` element to read from), so we just\n * iterate direct children that aren't themselves prior clones.\n */\n private duplicateTrackContent(track: HTMLElement | undefined) {\n if (!track) return;\n const originals = Array.from(track.children).filter(\n (child) => !(child as HTMLElement).hasAttribute('data-carousel-clone'),\n );\n originals.forEach((el) => {\n const clone = el.cloneNode(true) as HTMLElement;\n clone.setAttribute('data-carousel-clone', '');\n clone.setAttribute('aria-hidden', 'true');\n track.appendChild(clone);\n });\n }\n\n render() {\n const rows = Number(this.rows);\n return (\n <Host class={`theme-${this.theme}`}>\n <div class={`client-carousel theme-${this.theme} rows-${rows}`}>\n <div class=\"carousel-container\">\n <div class=\"carousel-row scroll-left\">\n <div class=\"logo-track\" ref={(el) => (this.row1TrackRef = el)}>\n <slot name=\"row-1\">\n <slot></slot>\n </slot>\n </div>\n </div>\n\n {rows === 2 && (\n <div class=\"carousel-row scroll-right\">\n <div class=\"logo-track\" ref={(el) => (this.row2TrackRef = el)}>\n <slot name=\"row-2\"></slot>\n </div>\n </div>\n )}\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"names":["h","Host"],"mappings":";;;;AAAA,MAAM,mBAAmB,GAAG,yuGAAyuG;;MC8BxvG,gBAAgB,GAAA,MAAA;AAT7B,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAaU,QAAA,IAAK,CAAA,KAAA,GAAU,SAAS;AAEhC;;;;;;;AAOG;AACK,QAAA,IAAI,CAAA,IAAA,GAAU,CAAC;AA6DxB;IAxDC,gBAAgB,GAAA;AACd,QAAA,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,YAAY,CAAC;QAC7C,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;AAC3B,YAAA,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,YAAY,CAAC;;;AAIjD;;;;;;;;;AASG;AACK,IAAA,qBAAqB,CAAC,KAA8B,EAAA;AAC1D,QAAA,IAAI,CAAC,KAAK;YAAE;QACZ,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,MAAM,CACjD,CAAC,KAAK,KAAK,CAAE,KAAqB,CAAC,YAAY,CAAC,qBAAqB,CAAC,CACvE;AACD,QAAA,SAAS,CAAC,OAAO,CAAC,CAAC,EAAE,KAAI;YACvB,MAAM,KAAK,GAAG,EAAE,CAAC,SAAS,CAAC,IAAI,CAAgB;AAC/C,YAAA,KAAK,CAAC,YAAY,CAAC,qBAAqB,EAAE,EAAE,CAAC;AAC7C,YAAA,KAAK,CAAC,YAAY,CAAC,aAAa,EAAE,MAAM,CAAC;AACzC,YAAA,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC;AAC1B,SAAC,CAAC;;IAGJ,MAAM,GAAA;QACJ,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;QAC9B,QACEA,OAAC,CAAAC,UAAI,EAAC,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,CAAA,MAAA,EAAS,IAAI,CAAC,KAAK,EAAE,EAAA,EAChCD,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,CAAA,sBAAA,EAAyB,IAAI,CAAC,KAAK,SAAS,IAAI,CAAA,CAAE,EAAA,EAC5DA,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,oBAAoB,EAAA,EAC7BA,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,0BAA0B,EAAA,EACnCA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAC,YAAY,EAAC,GAAG,EAAE,CAAC,EAAE,MAAM,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,EAAA,EAC3DA,OAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,IAAI,EAAC,OAAO,EAAA,EAChBA,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACR,CACH,CACF,EAEL,IAAI,KAAK,CAAC,KACTA,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,2BAA2B,EAAA,EACpCA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAC,YAAY,EAAC,GAAG,EAAE,CAAC,EAAE,MAAM,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,EAAA,EAC3DA,OAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,IAAI,EAAC,OAAO,EAAQ,CAAA,CACtB,CACF,CACP,CACG,CACF,CACD;;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afColorSwatchCss = () => `:host{display:block}.swatch{display:flex;flex-direction:column;border-radius:8px;overflow:hidden;border:1px solid #ece6f5;background:white}.color-preview{width:100%;height:120px;flex-shrink:0}.size-large .color-preview{height:140px}.color-info{padding:16px;display:flex;flex-direction:column;gap:4px}.color-name{font-family:'NeuSans', 'Inter', system-ui, sans-serif;font-size:16px;font-weight:500;color:#14343B}.color-value{font-family:'Helvetica', 'Inter', monospace, system-ui, sans-serif;font-size:14px;color:#708380}`;
5
+ const afColorSwatchCss = ":host{display:block}.swatch{display:flex;flex-direction:column;border-radius:8px;overflow:hidden;border:1px solid #ece6f5;background:white}.color-preview{width:100%;height:120px;flex-shrink:0}.size-large .color-preview{height:140px}.color-info{padding:16px;display:flex;flex-direction:column;gap:4px}.color-name{font-family:'NeuSans', 'Inter', system-ui, sans-serif;font-size:16px;font-weight:500;color:#14343B}.color-value{font-family:'Helvetica', 'Inter', monospace, system-ui, sans-serif;font-size:14px;color:#708380}";
6
6
 
7
7
  const AfColorSwatch = class {
8
8
  constructor(hostRef) {
@@ -17,6 +17,7 @@ const AfColorSwatch = class {
17
17
  }, part: "base" }, index.h("div", { key: '505252d9fbfb36df24f1907cd5a30278e55bf268', class: "color-preview", part: "preview", style: { backgroundColor: this.color } }), index.h("div", { key: '095621914872670c129c23825aa012bbba4e33bb', class: "color-info", part: "info" }, index.h("div", { key: '86b6164f0aed4a938a8faa210651bbc6746dd4f2', class: "color-name", part: "name" }, this.name), index.h("div", { key: '1d533780d3756b119ae36a6e8fa0c2b6b3acb7b4', class: "color-value", part: "value" }, this.color))));
18
18
  }
19
19
  };
20
- AfColorSwatch.style = afColorSwatchCss();
20
+ AfColorSwatch.style = afColorSwatchCss;
21
21
 
22
22
  exports.af_color_swatch = AfColorSwatch;
23
+ //# sourceMappingURL=af-color-swatch.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-color-swatch.entry.cjs.js","sources":["src/components/af-color-swatch/af-color-swatch.css?tag=af-color-swatch&encapsulation=shadow","src/components/af-color-swatch/af-color-swatch.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.swatch {\n display: flex;\n flex-direction: column;\n border-radius: 8px;\n overflow: hidden;\n border: 1px solid #ece6f5;\n background: white;\n}\n\n.color-preview {\n width: 100%;\n height: 120px;\n flex-shrink: 0;\n}\n\n.size-large .color-preview {\n height: 140px;\n}\n\n.color-info {\n padding: 16px;\n display: flex;\n flex-direction: column;\n gap: 4px;\n}\n\n.color-name {\n font-family: 'NeuSans', 'Inter', system-ui, sans-serif;\n font-size: 16px;\n font-weight: 500;\n color: #14343B;\n}\n\n.color-value {\n font-family: 'Helvetica', 'Inter', monospace, system-ui, sans-serif;\n font-size: 14px;\n color: #708380;\n}\n","import { Component, h, Prop } from '@stencil/core';\n\n@Component({\n tag: 'af-color-swatch',\n styleUrl: 'af-color-swatch.css',\n shadow: true\n})\nexport class AfColorSwatch {\n /** Color value (hex) */\n @Prop() color!: string;\n\n /** Color name */\n @Prop() name!: string;\n\n /** Size variant */\n @Prop() size: 'default' | 'large' = 'default';\n\n render() {\n return (\n <div class={{\n 'swatch': true,\n [`size-${this.size}`]: true\n }} part=\"base\">\n <div\n class=\"color-preview\"\n part=\"preview\"\n style={{ backgroundColor: this.color }}\n ></div>\n <div class=\"color-info\" part=\"info\">\n <div class=\"color-name\" part=\"name\">{this.name}</div>\n <div class=\"color-value\" part=\"value\">{this.color}</div>\n </div>\n </div>\n );\n }\n}\n"],"names":["h"],"mappings":";;;;AAAA,MAAM,gBAAgB,GAAG,0gBAA0gB;;MCOthB,aAAa,GAAA,MAAA;AAL1B,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAaU,QAAA,IAAI,CAAA,IAAA,GAAwB,SAAS;AAoB9C;IAlBC,MAAM,GAAA;QACJ,QACEA,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE;AACV,gBAAA,QAAQ,EAAE,IAAI;AACd,gBAAA,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAE,CAAA,GAAG;aACxB,EAAE,IAAI,EAAC,MAAM,EAAA,EACZA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAC,eAAe,EACrB,IAAI,EAAC,SAAS,EACd,KAAK,EAAE,EAAE,eAAe,EAAE,IAAI,CAAC,KAAK,EAAE,EACjC,CAAA,EACPA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAC,YAAY,EAAC,IAAI,EAAC,MAAM,EAAA,EACjCA,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,YAAY,EAAC,IAAI,EAAC,MAAM,EAAE,EAAA,IAAI,CAAC,IAAI,CAAO,EACrDA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAC,aAAa,EAAC,IAAI,EAAC,OAAO,EAAE,EAAA,IAAI,CAAC,KAAK,CAAO,CACpD,CACF;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afContactItemCss = () => `.sc-af-contact-item-h{display:block}.contact-item.sc-af-contact-item{display:flex;flex-direction:column;gap:4px}.contact-item__label.sc-af-contact-item{font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-size:14px;font-weight:600;color:var(--colour-tints-mistGreen-200, #C6D5D1);margin:0}.contact-item__value.sc-af-contact-item{font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-size:14px;font-weight:400;color:rgba(198, 213, 209, 0.7);margin:0}`;
5
+ const afContactItemCss = ".sc-af-contact-item-h{display:block}.contact-item.sc-af-contact-item{display:flex;flex-direction:column;gap:4px}.contact-item__label.sc-af-contact-item{font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-size:14px;font-weight:600;color:var(--colour-tints-mistGreen-200, #C6D5D1);margin:0}.contact-item__value.sc-af-contact-item{font-family:var(--typography-primaryfont, 'NeuSans', sans-serif);font-size:14px;font-weight:400;color:rgba(198, 213, 209, 0.7);margin:0}";
6
6
 
7
7
  const AfContactItem = class {
8
8
  constructor(hostRef) {
@@ -16,6 +16,7 @@ const AfContactItem = class {
16
16
  return (index.h(index.Host, { key: '1a52a5ea61e7ef04f3b86e8338ed6984a57101a2' }, index.h("div", { key: '9c69396e916f489d572f045e78daf990a72e0d24', class: "contact-item" }, this.label && (index.h("h5", { key: '7575301c7a83aa2034aaaf9b9bdb2a0bd5e072bb', class: "contact-item__label" }, this.label)), this.value && (index.h("p", { key: '5cbca2b4420b2184fb08ac7f1edb22bce50b9c4c', class: "contact-item__value" }, this.value)), index.h("slot", { key: '45624be318ed9146a9ec0f2b81af110f8cb82ff6' }))));
17
17
  }
18
18
  };
19
- AfContactItem.style = afContactItemCss();
19
+ AfContactItem.style = afContactItemCss;
20
20
 
21
21
  exports.af_contact_item = AfContactItem;
22
+ //# sourceMappingURL=af-contact-item.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-contact-item.entry.cjs.js","sources":["src/components/af-contact-item/af-contact-item.css?tag=af-contact-item&encapsulation=scoped","src/components/af-contact-item/af-contact-item.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.contact-item {\n display: flex;\n flex-direction: column;\n gap: 4px;\n}\n\n.contact-item__label {\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-size: 14px;\n font-weight: 600;\n color: var(--colour-tints-mistGreen-200, #C6D5D1);\n margin: 0;\n}\n\n.contact-item__value {\n font-family: var(--typography-primaryfont, 'NeuSans', sans-serif);\n font-size: 14px;\n font-weight: 400;\n color: rgba(198, 213, 209, 0.7);\n margin: 0;\n}\n\n","import { Component, h, Host, Prop } from '@stencil/core';\n\n/**\n * Contact item component for footer\n * Displays a label and value pair (e.g., \"Sales enquiries\" / \"contact@example.com\")\n */\n@Component({\n tag: 'af-contact-item',\n styleUrl: 'af-contact-item.css',\n shadow: false,\n scoped: true,\n})\nexport class AfContactItem {\n /** Contact label (e.g., \"Sales enquiries\") */\n @Prop() label: string = '';\n\n /** Contact value (e.g., email address) */\n @Prop() value: string = '';\n\n render() {\n return (\n <Host>\n <div class=\"contact-item\">\n {this.label && (\n <h5 class=\"contact-item__label\">{this.label}</h5>\n )}\n {this.value && (\n <p class=\"contact-item__value\">{this.value}</p>\n )}\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n\n"],"names":["h","Host"],"mappings":";;;;AAAA,MAAM,gBAAgB,GAAG,oeAAoe;;MCYhf,aAAa,GAAA,MAAA;AAN1B,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAQU,QAAA,IAAK,CAAA,KAAA,GAAW,EAAE;;AAGlB,QAAA,IAAK,CAAA,KAAA,GAAW,EAAE;AAiB3B;IAfC,MAAM,GAAA;AACJ,QAAA,QACEA,QAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACHD,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,cAAc,EAAA,EACtB,IAAI,CAAC,KAAK,KACTA,OAAI,CAAA,IAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,qBAAqB,EAAE,EAAA,IAAI,CAAC,KAAK,CAAM,CAClD,EACA,IAAI,CAAC,KAAK,KACTA,OAAG,CAAA,GAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,qBAAqB,EAAE,EAAA,IAAI,CAAC,KAAK,CAAK,CAChD,EACDA,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACT,CACD;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afContainerCss = () => `:host{display:block;width:100%}.container{width:100%;margin-left:auto;margin-right:auto;box-sizing:border-box;padding-left:20px;padding-right:20px}@media (min-width: 768px){.container{padding-left:32px;padding-right:32px}.max-width-medium{max-width:768px}}@media (min-width: 1024px){.container{padding-left:64px;padding-right:64px}.max-width-large{max-width:1024px}.max-width-medium{max-width:768px}}@media (min-width: 1440px){.container{padding-left:80px;padding-right:80px}.max-width-xlarge{max-width:1440px}.max-width-large{max-width:1024px}.max-width-medium{max-width:768px}}.max-width-fluid{max-width:none}`;
5
+ const afContainerCss = ":host{display:block;width:100%}.container{width:100%;margin-left:auto;margin-right:auto;box-sizing:border-box;padding-left:20px;padding-right:20px}@media (min-width: 768px){.container{padding-left:32px;padding-right:32px}.max-width-medium{max-width:768px}}@media (min-width: 1024px){.container{padding-left:64px;padding-right:64px}.max-width-large{max-width:1024px}.max-width-medium{max-width:768px}}@media (min-width: 1440px){.container{padding-left:80px;padding-right:80px}.max-width-xlarge{max-width:1440px}.max-width-large{max-width:1024px}.max-width-medium{max-width:768px}}.max-width-fluid{max-width:none}";
6
6
 
7
7
  const AfContainer = class {
8
8
  constructor(hostRef) {
@@ -20,6 +20,7 @@ const AfContainer = class {
20
20
  return (index.h("div", { key: '4a40fad6df79915adeb7273a7c71ed26b327ff8f', class: `container max-width-${this.maxWidth}` }, index.h("slot", { key: 'a1759c05860511cdb6b916e44925df7f7a80bcf1' })));
21
21
  }
22
22
  };
23
- AfContainer.style = afContainerCss();
23
+ AfContainer.style = afContainerCss;
24
24
 
25
25
  exports.af_container = AfContainer;
26
+ //# sourceMappingURL=af-container.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-container.entry.cjs.js","sources":["src/components/af-container/af-container.css?tag=af-container&encapsulation=shadow","src/components/af-container/af-container.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n}\n\n.container {\n width: 100%;\n margin-left: auto;\n margin-right: auto;\n box-sizing: border-box;\n\n /* Mobile first: base padding (applies below 768px) */\n padding-left: 20px;\n padding-right: 20px;\n}\n\n/* ≥ mobile */\n/* Medium breakpoint (768px) */\n@media (min-width: 768px) {\n .container {\n padding-left: 32px;\n padding-right: 32px;\n }\n\n .max-width-medium {\n max-width: 768px;\n }\n}\n\n/* ≥ tablet */\n/* Large breakpoint (1024px) */\n@media (min-width: 1024px) {\n .container {\n padding-left: 64px;\n padding-right: 64px;\n }\n\n .max-width-large {\n max-width: 1024px;\n }\n\n .max-width-medium {\n max-width: 768px;\n }\n}\n\n/* ≥ desktop-wide */\n/* XLarge breakpoint (1440px) */\n@media (min-width: 1440px) {\n .container {\n padding-left: 80px;\n padding-right: 80px;\n }\n\n .max-width-xlarge {\n max-width: 1440px;\n }\n\n .max-width-large {\n max-width: 1024px;\n }\n\n .max-width-medium {\n max-width: 768px;\n }\n}\n\n/* Fluid has no max-width */\n.max-width-fluid {\n max-width: none;\n}\n","import { Component, h, Prop } from '@stencil/core';\n\n/**\n * A responsive container component that provides consistent margins and max-width\n * constraints based on the Affinda grid system.\n */\n@Component({\n tag: 'af-container',\n styleUrl: 'af-container.css',\n shadow: true\n})\nexport class AfContainer {\n /**\n * Maximum width constraint for the container\n * - 'xlarge': 1440px container (default)\n * - 'large': 1024px container\n * - 'medium': 768px container\n * - 'fluid': No max-width constraint, full width with margins\n */\n @Prop() maxWidth: 'xlarge' | 'large' | 'medium' | 'fluid' = 'xlarge';\n\n render() {\n return (\n <div class={`container max-width-${this.maxWidth}`}>\n <slot></slot>\n </div>\n );\n }\n}\n"],"names":["h"],"mappings":";;;;AAAA,MAAM,cAAc,GAAG,qmBAAqmB;;MCW/mB,WAAW,GAAA,MAAA;AALxB,IAAA,WAAA,CAAA,OAAA,EAAA;;AAME;;;;;;AAMG;AACK,QAAA,IAAQ,CAAA,QAAA,GAA4C,QAAQ;AASrE;IAPC,MAAM,GAAA;AACJ,QAAA,QACEA,kEAAK,KAAK,EAAE,uBAAuB,IAAI,CAAC,QAAQ,CAAA,CAAE,EAAA,EAChDA,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACT;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-C1ry3YPK.js');
3
+ var index = require('./index-CcvVbx1D.js');
4
4
 
5
- const afDividerCss = () => `:host{box-sizing:border-box;flex-shrink:0}:host([hidden]){display:none}:host(.divider--horizontal){display:block;width:100%;height:1px;background-color:var(--colour-tints-inkwell-100, #d4d4d4)}:host(.divider--vertical){display:inline-block;width:1px;height:100%;min-height:1em;background-color:var(--colour-tints-inkwell-100, #d4d4d4);align-self:stretch}`;
5
+ const afDividerCss = ":host{box-sizing:border-box;flex-shrink:0}:host([hidden]){display:none}:host(.divider--horizontal){display:block;width:100%;height:1px;background-color:var(--colour-tints-inkwell-100, #d4d4d4)}:host(.divider--vertical){display:inline-block;width:1px;height:100%;min-height:1em;background-color:var(--colour-tints-inkwell-100, #d4d4d4);align-self:stretch}";
6
6
 
7
7
  const AfDivider = class {
8
8
  constructor(hostRef) {
@@ -37,6 +37,7 @@ const AfDivider = class {
37
37
  }, style: style, role: "separator", "aria-orientation": this.orientation }));
38
38
  }
39
39
  };
40
- AfDivider.style = afDividerCss();
40
+ AfDivider.style = afDividerCss;
41
41
 
42
42
  exports.af_divider = AfDivider;
43
+ //# sourceMappingURL=af-divider.entry.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"af-divider.entry.cjs.js","sources":["src/components/af-divider/af-divider.css?tag=af-divider&encapsulation=shadow","src/components/af-divider/af-divider.tsx"],"sourcesContent":[":host {\n box-sizing: border-box;\n flex-shrink: 0;\n}\n\n:host([hidden]) {\n display: none;\n}\n\n:host(.divider--horizontal) {\n display: block;\n width: 100%;\n height: 1px;\n background-color: var(--colour-tints-inkwell-100, #d4d4d4);\n}\n\n:host(.divider--vertical) {\n display: inline-block;\n width: 1px;\n height: 100%;\n min-height: 1em;\n background-color: var(--colour-tints-inkwell-100, #d4d4d4);\n align-self: stretch;\n}\n\n","import { Component, h, Host, Prop } from '@stencil/core';\n\ntype Orientation = 'horizontal' | 'vertical';\ntype Spacing = 'none' | '1' | '2' | '3' | '4' | '5' | '6' | '8';\n\n/**\n * Divider component for visual separation between content.\n * Supports horizontal and vertical orientations with theme-aware styling.\n */\n@Component({\n tag: 'af-divider',\n styleUrl: 'af-divider.css',\n shadow: true,\n})\nexport class AfDivider {\n /**\n * Orientation of the divider.\n */\n @Prop() orientation: Orientation = 'horizontal';\n\n /**\n * Spacing (margin) around the divider using space tokens.\n * For horizontal: margin-top and margin-bottom\n * For vertical: margin-left and margin-right\n */\n @Prop() spacing: Spacing = '4';\n\n render() {\n const isVertical = this.orientation === 'vertical';\n const spacingValue = this.spacing === 'none' ? '0' : `var(--space-${this.spacing})`;\n\n const style: Record<string, string> = isVertical\n ? {\n marginLeft: spacingValue,\n marginRight: spacingValue,\n }\n : {\n marginTop: spacingValue,\n marginBottom: spacingValue,\n };\n\n return (\n <Host\n class={{\n 'divider': true,\n 'divider--horizontal': !isVertical,\n 'divider--vertical': isVertical,\n }}\n style={style}\n role=\"separator\"\n aria-orientation={this.orientation}\n ></Host>\n );\n }\n}\n\n"],"names":["h","Host"],"mappings":";;;;AAAA,MAAM,YAAY,GAAG,oWAAoW;;MCc5W,SAAS,GAAA,MAAA;AALtB,IAAA,WAAA,CAAA,OAAA,EAAA;;AAME;;AAEG;AACK,QAAA,IAAW,CAAA,WAAA,GAAgB,YAAY;AAE/C;;;;AAIG;AACK,QAAA,IAAO,CAAA,OAAA,GAAY,GAAG;AA6B/B;IA3BC,MAAM,GAAA;AACJ,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,KAAK,UAAU;AAClD,QAAA,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,KAAK,MAAM,GAAG,GAAG,GAAG,CAAA,YAAA,EAAe,IAAI,CAAC,OAAO,GAAG;QAEnF,MAAM,KAAK,GAA2B;AACpC,cAAE;AACE,gBAAA,UAAU,EAAE,YAAY;AACxB,gBAAA,WAAW,EAAE,YAAY;AAC1B;AACH,cAAE;AACE,gBAAA,SAAS,EAAE,YAAY;AACvB,gBAAA,YAAY,EAAE,YAAY;aAC3B;QAEL,QACEA,OAAA,CAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EACH,KAAK,EAAE;AACL,gBAAA,SAAS,EAAE,IAAI;gBACf,qBAAqB,EAAE,CAAC,UAAU;AAClC,gBAAA,mBAAmB,EAAE,UAAU;AAChC,aAAA,EACD,KAAK,EAAE,KAAK,EACZ,IAAI,EAAC,WAAW,EAAA,kBAAA,EACE,IAAI,CAAC,WAAW,EAAA,CAC5B;;;;;;;"}