@bethinkpl/design-system 25.0.10 → 26.0.1

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 (550) hide show
  1. package/.github/workflows/build-to-review-on-trigger.yml +17 -0
  2. package/.github/workflows/storybook.yml +1 -0
  3. package/.storybook/main.ts +42 -0
  4. package/.storybook/{manager.js → manager.ts} +1 -1
  5. package/.storybook/preview-head.html +1 -0
  6. package/.storybook/preview.scss +3 -0
  7. package/.storybook/{preview.js → preview.ts} +11 -18
  8. package/.storybook/scss-preview-styles-plugin.ts +43 -0
  9. package/{lib/styles → .storybook}/storybook.scss +10 -10
  10. package/deploy_storybook_to_s3.sh +16 -1
  11. package/dist/design-system.umd.cjs +1032 -0
  12. package/dist/design-system.umd.cjs.map +1 -0
  13. package/dist/lib/js/components/BadgeScore/BadgeScore.vue.d.ts +33 -65
  14. package/dist/lib/js/components/BadgeScore/index.d.ts +2 -1
  15. package/dist/lib/js/components/Banner/Banner.vue.d.ts +265 -311
  16. package/dist/lib/js/components/Banner/index.d.ts +2 -1
  17. package/dist/lib/js/components/Buttons/Button/Button.vue.d.ts +258 -305
  18. package/dist/lib/js/components/Buttons/Button/index.d.ts +2 -1
  19. package/dist/lib/js/components/Buttons/IconButton/IconButton.vue.d.ts +274 -320
  20. package/dist/lib/js/components/Buttons/IconButton/index.d.ts +2 -1
  21. package/dist/lib/js/components/Cards/Card/Card.consts.d.ts +1 -0
  22. package/dist/lib/js/components/Cards/Card/Card.vue.d.ts +92 -2
  23. package/dist/lib/js/components/Cards/Card/index.d.ts +2 -1
  24. package/dist/lib/js/components/Cards/CardExpandable/CardExpandable.vue.d.ts +274 -258
  25. package/dist/lib/js/components/Cards/CardExpandable/index.d.ts +2 -1
  26. package/dist/lib/js/components/Chip/Chip.vue.d.ts +259 -306
  27. package/dist/lib/js/components/Chip/index.d.ts +2 -1
  28. package/dist/lib/js/components/DatePickers/DatePicker/DatePicker.consts.d.ts +1 -0
  29. package/dist/lib/js/components/DatePickers/DatePicker/DatePicker.vue.d.ts +1 -106
  30. package/dist/lib/js/components/DatePickers/DatePicker/index.d.ts +2 -1
  31. package/dist/lib/js/components/DatePickers/DatePickerBox/DatePickerBox.vue.d.ts +1 -274
  32. package/dist/lib/js/components/DatePickers/DatePickerBox/index.d.ts +2 -1
  33. package/dist/lib/js/components/Divider/Divider.vue.d.ts +40 -26
  34. package/dist/lib/js/components/Divider/index.d.ts +2 -1
  35. package/dist/lib/js/components/Drawer/Drawer.vue.d.ts +34 -19
  36. package/dist/lib/js/components/Drawer/DrawerContent/DrawerContent.vue.d.ts +1 -3
  37. package/dist/lib/js/components/Drawer/DrawerDivider/DrawerDivider.vue.d.ts +24 -17
  38. package/dist/lib/js/components/Drawer/DrawerHeader/DrawerHeader.vue.d.ts +2 -3
  39. package/dist/lib/js/components/Drawer/DrawerListItem/DrawerListItem.vue.d.ts +226 -3
  40. package/dist/lib/js/components/Drawer/DrawerListItemGroup/DrawerListItemGroup.vue.d.ts +1 -3
  41. package/dist/lib/js/components/Drawer/DrawerSection/DrawerSection.vue.d.ts +236 -302
  42. package/dist/lib/js/components/Drawer/DrawerTile/DrawerTile.vue.d.ts +129 -66
  43. package/dist/lib/js/components/Drawer/index.d.ts +2 -1
  44. package/dist/lib/js/components/Dropdown/Dropdown.vue.d.ts +2 -66
  45. package/dist/lib/js/components/Dropdown/index.d.ts +2 -1
  46. package/dist/lib/js/components/Form/Checkbox/Checkbox.vue.d.ts +219 -239
  47. package/dist/lib/js/components/Form/RadioButton/RadioButton.vue.d.ts +219 -239
  48. package/dist/lib/js/components/Form/SelectionControl/SelectionControl.sb.shared.d.ts +2 -1
  49. package/dist/lib/js/components/Form/SelectionControl/SelectionControl.vue.d.ts +29 -66
  50. package/dist/lib/js/components/Headers/OverlayHeader/OverlayHeader.vue.d.ts +274 -316
  51. package/dist/lib/js/components/Headers/OverlayHeader/index.d.ts +2 -1
  52. package/dist/lib/js/components/Headers/PageHeader/PageHeader.vue.d.ts +12 -32
  53. package/dist/lib/js/components/Headers/PageHeader/index.d.ts +2 -1
  54. package/dist/lib/js/components/Headers/SectionHeader/SectionHeader.consts.d.ts +1 -0
  55. package/dist/lib/js/components/Headers/SectionHeader/SectionHeader.vue.d.ts +255 -333
  56. package/dist/lib/js/components/Headers/SectionHeader/index.d.ts +2 -1
  57. package/dist/lib/js/components/IconText/IconText.vue.d.ts +1 -71
  58. package/dist/lib/js/components/IconText/index.d.ts +2 -1
  59. package/dist/lib/js/components/Icons/FeatureIcon/FeatureIcon.vue.d.ts +25 -48
  60. package/dist/lib/js/components/Icons/FeatureIcon/index.d.ts +2 -1
  61. package/dist/lib/js/components/Icons/Icon/Icon.consts.d.ts +195 -194
  62. package/dist/lib/js/components/Icons/Icon/Icon.vue.d.ts +76 -44
  63. package/dist/lib/js/components/Icons/Icon/index.d.ts +2 -1
  64. package/dist/lib/js/components/Image/Image.vue.d.ts +3 -11
  65. package/dist/lib/js/components/Image/index.d.ts +2 -1
  66. package/dist/lib/js/components/Layouts/ThreeColumnLayout/ThreeColumnLayout.vue.d.ts +16 -46
  67. package/dist/lib/js/components/Layouts/ThreeColumnLayout/index.d.ts +2 -1
  68. package/dist/lib/js/components/LoadingBar/LoadingBar.consts.d.ts +1 -0
  69. package/dist/lib/js/components/LoadingBar/LoadingBar.vue.d.ts +37 -26
  70. package/dist/lib/js/components/LoadingBar/index.d.ts +2 -1
  71. package/dist/lib/js/components/Modal/Modal.vue.d.ts +235 -230
  72. package/dist/lib/js/components/Modal/index.d.ts +2 -1
  73. package/dist/lib/js/components/Modals/Modal/Modal.vue.d.ts +275 -362
  74. package/dist/lib/js/components/Modals/Modal/index.d.ts +2 -1
  75. package/dist/lib/js/components/Modals/ModalDialog/ModalDialog.vue.d.ts +20 -74
  76. package/dist/lib/js/components/Modals/ModalDialog/index.d.ts +2 -1
  77. package/dist/lib/js/components/NumberInCircle/index.d.ts +2 -1
  78. package/dist/lib/js/components/Outline/OutlineDivider/OutlineDivider.vue.d.ts +24 -17
  79. package/dist/lib/js/components/Outline/OutlineDivider/index.d.ts +2 -1
  80. package/dist/lib/js/components/Outline/OutlineItem/OutlineItem.vue.d.ts +231 -297
  81. package/dist/lib/js/components/Outline/OutlineItem/index.d.ts +2 -1
  82. package/dist/lib/js/components/Outline/OutlineSectionHeader/OutlineSectionHeader.vue.d.ts +10 -8
  83. package/dist/lib/js/components/Outline/OutlineSectionHeader/index.d.ts +2 -1
  84. package/dist/lib/js/components/Pagination/Pagination.vue.d.ts +259 -288
  85. package/dist/lib/js/components/Pagination/index.d.ts +2 -1
  86. package/dist/lib/js/components/PopOver/index.d.ts +2 -1
  87. package/dist/lib/js/components/ProgressBar/ProgressBar.vue.d.ts +1 -301
  88. package/dist/lib/js/components/ProgressBar/index.d.ts +2 -1
  89. package/dist/lib/js/components/ProgressDonutChart/ProgressDonutChart.vue.d.ts +1 -253
  90. package/dist/lib/js/components/ProgressDonutChart/index.d.ts +2 -1
  91. package/dist/lib/js/components/RichList/BasicRichListItem/BasicRichListItem.vue.d.ts +21 -135
  92. package/dist/lib/js/components/RichList/BasicRichListItem/index.d.ts +2 -1
  93. package/dist/lib/js/components/RichList/GroupRichListItem/GroupRichListItem.consts.d.ts +1 -0
  94. package/dist/lib/js/components/RichList/GroupRichListItem/GroupRichListItem.vue.d.ts +51 -30
  95. package/dist/lib/js/components/RichList/GroupRichListItem/index.d.ts +2 -1
  96. package/dist/lib/js/components/RichList/RichListItem/RichListItem.consts.d.ts +2 -0
  97. package/dist/lib/js/components/RichList/RichListItem/RichListItem.vue.d.ts +254 -344
  98. package/dist/lib/js/components/RichList/RichListItem/index.d.ts +2 -1
  99. package/dist/lib/js/components/SectionTitle/SectionTitle.vue.d.ts +32 -2
  100. package/dist/lib/js/components/SelectList/SelectList.vue.d.ts +2 -3
  101. package/dist/lib/js/components/SelectList/SelectListItem/SelectListItem.vue.d.ts +234 -3
  102. package/dist/lib/js/components/SelectList/SelectListItemDivider/SelectListItemDivider.vue.d.ts +1 -7
  103. package/dist/lib/js/components/SelectList/SelectListItemTile/SelectListItemTile.vue.d.ts +127 -65
  104. package/dist/lib/js/components/SelectList/SelectListItemToggle/SelectListItemToggle.vue.d.ts +21 -56
  105. package/dist/lib/js/components/SelectList/SelectListSectionTitle/SelectListSectionTitle.vue.d.ts +21 -13
  106. package/dist/lib/js/components/SelectionTile/SelectionTile.vue.d.ts +197 -197
  107. package/dist/lib/js/components/SelectionTile/index.d.ts +2 -1
  108. package/dist/lib/js/components/Skeleton/Skeleton.vue.d.ts +42 -2
  109. package/dist/lib/js/components/Skeleton/index.d.ts +2 -1
  110. package/dist/lib/js/components/Statuses/AccessStatus/AccessStatus.vue.d.ts +227 -231
  111. package/dist/lib/js/components/Statuses/AccessStatus/index.d.ts +2 -1
  112. package/dist/lib/js/components/Statuses/BlockadeStatus/BlockadeStatus.vue.d.ts +227 -231
  113. package/dist/lib/js/components/Statuses/BlockadeStatus/index.d.ts +2 -1
  114. package/dist/lib/js/components/SurveyQuestions/SurveyQuestionOpenEnded/SurveyQuestionOpenEnded.vue.d.ts +246 -3
  115. package/dist/lib/js/components/SurveyQuestions/SurveyQuestionOpenEnded/index.d.ts +2 -1
  116. package/dist/lib/js/components/SurveyQuestions/SurveyQuestionScale/SurveyQuestionScale.vue.d.ts +2 -3
  117. package/dist/lib/js/components/SurveyQuestions/SurveyQuestionScale/index.d.ts +2 -1
  118. package/dist/lib/js/components/SurveyQuestions/SurveyQuestionTextarea.vue.d.ts +31 -21
  119. package/dist/lib/js/components/SurveyQuestions/index.d.ts +2 -1
  120. package/dist/lib/js/components/SurveyToggle/SurveyToggle.vue.d.ts +39 -3
  121. package/dist/lib/js/components/SurveyToggle/index.d.ts +2 -1
  122. package/dist/lib/js/components/Switch/Switch.consts.d.ts +1 -0
  123. package/dist/lib/js/components/Switch/Switch.vue.d.ts +246 -296
  124. package/dist/lib/js/components/Switch/index.d.ts +2 -1
  125. package/dist/lib/js/components/TabItem/TabItem.vue.d.ts +1 -47
  126. package/dist/lib/js/components/TabItem/index.d.ts +2 -1
  127. package/dist/lib/js/components/TextGroup/TextGroup.vue.d.ts +7 -6
  128. package/dist/lib/js/components/TextGroup/index.d.ts +2 -1
  129. package/dist/lib/js/components/Tile/Tile.consts.d.ts +1 -0
  130. package/dist/lib/js/components/Tile/Tile.sb.shared.d.ts +195 -194
  131. package/dist/lib/js/components/Tile/Tile.shared.d.ts +1 -0
  132. package/dist/lib/js/components/Tile/Tile.vue.d.ts +342 -282
  133. package/dist/lib/js/components/Tile/index.d.ts +2 -1
  134. package/dist/lib/js/components/Toast/Toast.consts.d.ts +1 -0
  135. package/dist/lib/js/components/Toggles/CounterToggle/CounterToggle.vue.d.ts +21 -47
  136. package/dist/lib/js/components/Toggles/CounterToggle/index.d.ts +2 -1
  137. package/dist/lib/js/components/Toggles/ToggleButton/ToggleButton.consts.d.ts +1 -0
  138. package/dist/lib/js/components/Toggles/ToggleButton/ToggleButton.vue.d.ts +242 -301
  139. package/dist/lib/js/components/Toggles/ToggleButton/index.d.ts +2 -1
  140. package/dist/lib/js/components/Tooltip/Tooltip.vue.d.ts +4 -5
  141. package/dist/lib/js/components/Tooltip/index.d.ts +2 -1
  142. package/dist/lib/js/components/Well/index.d.ts +2 -1
  143. package/dist/lib/js/composables/hover-state.d.ts +11 -0
  144. package/dist/lib/js/icons/fontawesome.d.ts +195 -195
  145. package/dist/lib/js/index.d.ts +2 -1
  146. package/dist/lib/js/styles/TokenTypes.d.ts +1 -0
  147. package/dist/lib/js/utils/device.d.ts +1 -0
  148. package/docs/.nojekyll +0 -0
  149. package/docs/assets/AccessStatus-DVtD0BrS.js +1 -0
  150. package/docs/assets/AccessStatus.stories-CM9qms_d.js +9 -0
  151. package/docs/assets/BadgeScore-B0MHArlW.js +1 -0
  152. package/docs/assets/BadgeScore.stories-BsFc_8XV.js +40 -0
  153. package/docs/assets/Banner-Dkt_I8P3.js +1 -0
  154. package/docs/assets/Banner.stories-dLLxP9rS.js +62 -0
  155. package/docs/assets/BasicRichListItem-CCXQ4iJg.js +1 -0
  156. package/docs/assets/BasicRichListItem.stories-Bh_UBJkl.js +194 -0
  157. package/docs/assets/BlockadeStatus-9_pI8WM1.js +1 -0
  158. package/docs/assets/BlockedeStatus.stories-IunhqK0I.js +9 -0
  159. package/docs/assets/BorderSizes.stories-COOhe637.js +31 -0
  160. package/docs/assets/Button-CBZkgukP.js +1 -0
  161. package/docs/assets/Button.stories-BLj-_0Vw.js +47 -0
  162. package/docs/assets/Card-B7j8o0GU.js +1 -0
  163. package/docs/assets/Card.stories-KO99dol6.js +49 -0
  164. package/docs/assets/CardExpandable-XN3wcRwV.js +1 -0
  165. package/docs/assets/CardExpandable.stories-B9-JtWRG.js +37 -0
  166. package/docs/assets/Checkbox-D_geau8n.js +1 -0
  167. package/docs/assets/Checkbox.stories-DLfdA87Q.js +21 -0
  168. package/docs/assets/Chip-CBqrZ-va.js +1 -0
  169. package/docs/assets/Chip.stories-DQLbtbRo.js +43 -0
  170. package/docs/assets/Color-ERTF36HU-B622yQt4.js +1 -0
  171. package/docs/assets/Colors.stories-CRIOJbgv.js +11 -0
  172. package/docs/assets/ColorsThemes.stories-BVtVblv7.js +11 -0
  173. package/docs/assets/ColorsTokensLms.stories-Ds9sWwL0.js +11 -0
  174. package/docs/assets/ColorsTokensPrimaryBodywork.stories-D9nLEENe.js +11 -0
  175. package/docs/assets/ColorsTokensPrimaryWnl.stories-Cuz6HvAj.js +11 -0
  176. package/docs/assets/CounterToggle-BzxnFqH7.js +1 -0
  177. package/docs/assets/CounterToggle.stories-DdAjSFMr.js +19 -0
  178. package/docs/assets/DatePicker-CvT_E45n.js +2 -0
  179. package/docs/assets/DatePicker.stories-Ub_1x6To.js +91 -0
  180. package/docs/assets/Divider-D2yDhW46.js +1 -0
  181. package/docs/assets/Divider.stories-f9QUckyE.js +15 -0
  182. package/docs/assets/DocsRenderer-CFRXHY34-D5Eulb6H.js +639 -0
  183. package/docs/assets/Drawer-CH5Qyc5B.js +1 -0
  184. package/docs/assets/Drawer.stories-jrbLBaPT.js +21 -0
  185. package/docs/assets/DrawerContent-DGzdUSmd.js +1 -0
  186. package/docs/assets/DrawerContent.stories-CYzQPPIy.js +17 -0
  187. package/docs/assets/DrawerDivider-DNbYnPjf.js +1 -0
  188. package/docs/assets/DrawerDivider.stories-BG6MKk49.js +15 -0
  189. package/docs/assets/DrawerHeader-DOWojdwp.js +1 -0
  190. package/docs/assets/DrawerHeader.stories-CwaoQykQ.js +54 -0
  191. package/docs/assets/DrawerListItem-aepUTcTm.js +1 -0
  192. package/docs/assets/DrawerListItem.stories-vHXkwtyS.js +13 -0
  193. package/docs/assets/DrawerListItemGroup-CnH532Dv.js +1 -0
  194. package/docs/assets/DrawerListItemGroup.stories-D0DeZ6IG.js +20 -0
  195. package/docs/assets/DrawerSection-pMhA5dsS.js +1 -0
  196. package/docs/assets/DrawerSection.stories-BF7A4VyW.js +67 -0
  197. package/docs/assets/DrawerTile-W2mt6fAk.js +1 -0
  198. package/docs/assets/DrawerTile.stories-CUMznN1H.js +10 -0
  199. package/docs/assets/Dropdown-BfX0EVaK.js +1 -0
  200. package/docs/assets/Dropdown.stories-DrILA_TR.js +45 -0
  201. package/docs/assets/FeatureIcon-n65RPvyA.js +1 -0
  202. package/docs/assets/FeatureIcon.stories-DSUzxIPB.js +14 -0
  203. package/docs/assets/GroupRichListItem-DMiaeyaS.js +1 -0
  204. package/docs/assets/GroupRichListItem.stories-DCEq0Kil.js +137 -0
  205. package/docs/assets/Icon-BiVaixmr.js +762 -0
  206. package/docs/assets/Icon.stories-BFJuE2aE.js +27 -0
  207. package/docs/assets/IconButton-COzU-vlz.js +1 -0
  208. package/docs/assets/IconButton.stories-DGmn7bfg.js +119 -0
  209. package/docs/assets/IconText-DDrVXWHS.js +1 -0
  210. package/docs/assets/IconText.stories-CSt7q9Mf.js +32 -0
  211. package/docs/assets/Image-Drmyqqsn.js +1 -0
  212. package/docs/assets/Image.stories-DxQ22AFP.js +21 -0
  213. package/docs/assets/ItemsList-B-vw083o.js +1 -0
  214. package/docs/assets/LoadingBar-D0iVLCyJ.js +1 -0
  215. package/docs/assets/LoadingBar.stories-IJRD91mF.js +9 -0
  216. package/docs/assets/Modal-CJ0d6Je9.js +1 -0
  217. package/docs/assets/Modal.stories-q_qdiakg.js +53 -0
  218. package/docs/assets/ModalDialog-CbDAxfV_.js +1 -0
  219. package/docs/assets/ModalDialog.stories-CKcR8rIW.js +43 -0
  220. package/docs/assets/NumberInCircle-DV0Qrx8H.js +1 -0
  221. package/docs/assets/NumberInCircle.stories-DriLGDDl.js +9 -0
  222. package/docs/assets/OutlineDivider-Cez9NlcH.js +1 -0
  223. package/docs/assets/OutlineDivider.stories-D0zYoHBw.js +11 -0
  224. package/docs/assets/OutlineItem-CUHef8Bo.js +1 -0
  225. package/docs/assets/OutlineItem.stories-BgFzRhaY.js +41 -0
  226. package/docs/assets/OutlineSectionHeader-DSJ4uxfr.js +1 -0
  227. package/docs/assets/OutlineSectionHeader.stories-HOf2NwY-.js +9 -0
  228. package/docs/assets/OverlayHeader-jylszhPO.js +1 -0
  229. package/docs/assets/OverlayHeader.stories-bjFfL93l.js +67 -0
  230. package/docs/assets/PageHeader-CTbdU4IG.js +1 -0
  231. package/docs/assets/PageHeader.stories-DeNf1zoa.js +9 -0
  232. package/docs/assets/Pagination-dSOJSh7t.js +1 -0
  233. package/docs/assets/Pagination.stories-CMg8WaRV.js +31 -0
  234. package/docs/assets/PopOver-BPD1Ttq1.js +1 -0
  235. package/docs/assets/PopOver.stories-Cl1k59cl.js +15 -0
  236. package/docs/assets/ProgressBar-4gBRbr7a.js +1 -0
  237. package/docs/assets/ProgressBar.stories-9xVTh0RH.js +57 -0
  238. package/docs/assets/ProgressDonutChart-D5uvUZva.js +1 -0
  239. package/docs/assets/ProgressDonutChart.stories-DBpwl5Vn.js +17 -0
  240. package/docs/assets/RadioButton-BwCzYjOu.js +1 -0
  241. package/docs/assets/RadioButton.stories-CLWvDUrd.js +21 -0
  242. package/docs/assets/RichListItem.stories-DhkQky0J.js +182 -0
  243. package/docs/assets/SectionHeader-DVwe52kA.js +1 -0
  244. package/docs/assets/SectionHeader.stories-Dd3li5ER.js +24 -0
  245. package/docs/assets/SectionTitle-XTc-98O5.js +1 -0
  246. package/docs/assets/SectionTitle.stories-BFNagAeb.js +9 -0
  247. package/docs/assets/SelectList-CTXM5G8Z.js +1 -0
  248. package/docs/assets/SelectList.stories-B2Pq8auf.js +91 -0
  249. package/docs/assets/SelectListItem-_c4CA-YM.js +1 -0
  250. package/docs/assets/SelectListItem.stories-PSDnI18x.js +36 -0
  251. package/docs/assets/SelectListItemDivider-BOgD7wrO.js +1 -0
  252. package/docs/assets/SelectListItemDivider.stories-DvANKn2s.js +8 -0
  253. package/docs/assets/SelectListItemTile-BL3qYL_0.js +1 -0
  254. package/docs/assets/SelectListItemTile.stories-CVYmG0Ta.js +19 -0
  255. package/docs/assets/SelectListItemToggle-BjjMPWy0.js +1 -0
  256. package/docs/assets/SelectListItemToggle.stories-D5QL3Gd2.js +51 -0
  257. package/docs/assets/SelectListSectionTitle-FihJb1eM.js +1 -0
  258. package/docs/assets/SelectListSectionTitle.stories-DCyB86A1.js +16 -0
  259. package/docs/assets/SelectionControl-BxCh7N21.js +1 -0
  260. package/docs/assets/SelectionControl.sb.shared-BWifjoMU.js +2 -0
  261. package/docs/assets/SelectionTile-T03MPtEm.js +2 -0
  262. package/docs/assets/SelectionTile.stories-CEufLR64.js +47 -0
  263. package/docs/assets/Skeleton-BbafKE6W.js +179 -0
  264. package/docs/assets/Skeleton.stories-B_4TqUB5.js +15 -0
  265. package/docs/assets/Spacings.stories-DxxukMX7.js +43 -0
  266. package/docs/assets/SurveyQuestionOpenEnded-DRFBouQB.js +1 -0
  267. package/docs/assets/SurveyQuestionOpenEnded.stories-DW7tQU04.js +20 -0
  268. package/docs/assets/SurveyQuestionScale-nNC7H5k0.js +1 -0
  269. package/docs/assets/SurveyQuestionScale.stories-DC8qXbl8.js +72 -0
  270. package/docs/assets/SurveyToggle-DzZyc41b.js +1 -0
  271. package/docs/assets/SurveyToggle.stories-Yf0fJ_p2.js +14 -0
  272. package/docs/assets/Switch-BWGPo7tP.js +1 -0
  273. package/docs/assets/Switch.stories-BzeYFsr2.js +48 -0
  274. package/docs/assets/TabItem-Cx2nQ_YR.js +1 -0
  275. package/docs/assets/TabItem.stories-C-gV8JMj.js +15 -0
  276. package/docs/assets/TextGroup-DQmg5luv.js +1 -0
  277. package/docs/assets/TextGroup.stories-j5MNzn7U.js +48 -0
  278. package/docs/assets/ThreeColumnLayout-Lm3LIbid.js +1 -0
  279. package/docs/assets/ThreeColumnLayout.stories-C5cNwOWv.js +47 -0
  280. package/docs/assets/Tile-DnH9h0Kq.js +1 -0
  281. package/docs/assets/Tile.sb.shared-2W1FnncR.js +15 -0
  282. package/docs/assets/Tile.stories-Bj7yp21N.js +14 -0
  283. package/docs/assets/Toast.stories-Bad7itWi.js +58 -0
  284. package/docs/assets/ToggleButton-BZ0tVYFv.js +1 -0
  285. package/docs/assets/ToggleButton.stories-D0YPR0-y.js +42 -0
  286. package/docs/assets/Tooltip-BxZlo6cR.js +1 -0
  287. package/docs/assets/Tooltip.stories-CaTsoTim.js +119 -0
  288. package/docs/assets/TypographyTokensLms.stories-D-CrlX5A.js +11 -0
  289. package/docs/assets/TypographyVariables.stories-Bmxi44f1.js +11 -0
  290. package/docs/assets/Well-vFI2CbIA.js +1 -0
  291. package/docs/assets/Well.stories-Be73GX2h.js +6 -0
  292. package/docs/assets/_commonjsHelpers-Chg3vePA.js +1 -0
  293. package/docs/assets/_plugin-vue_export-helper-DlAUqK2U.js +1 -0
  294. package/docs/assets/decorator-CSnIf-k5.js +1 -0
  295. package/docs/assets/device-9fgosCm4.js +1 -0
  296. package/docs/assets/entry-preview-Dw8qwUcN.js +1 -0
  297. package/docs/assets/entry-preview-docs-BBVW7MF3.js +16 -0
  298. package/docs/assets/iframe-BosoHOVU.js +63 -0
  299. package/docs/assets/index-CBmJdl9t.js +5 -0
  300. package/docs/assets/index-CgF2Ctku.js +1 -0
  301. package/docs/assets/index-CqU62QSU.js +1 -0
  302. package/docs/assets/index-vG0co4wr.js +8 -0
  303. package/docs/assets/pl-Cy1N1vsP.js +1 -0
  304. package/docs/assets/preview-16ImHjAt.js +64 -0
  305. package/docs/assets/preview-B_ruAZiw.js +2 -0
  306. package/docs/assets/preview-DFmD0pui.js +1 -0
  307. package/docs/assets/preview-DFphXfmq.js +1 -0
  308. package/docs/assets/string-CxIy_vwz.js +1 -0
  309. package/docs/assets/user-DY5hg_iu.js +1 -0
  310. package/docs/assets/v4-BZawosSj.js +1 -0
  311. package/docs/assets/vue-popper-BJbr8Gin.js +24 -0
  312. package/docs/assets/vue.esm-bundler-BSCmGRHc.js +7 -0
  313. package/docs/favicon.svg +1 -0
  314. package/docs/iframe.html +332 -56
  315. package/docs/index.html +157 -51
  316. package/docs/index.json +1 -0
  317. package/docs/nunito-sans-bold-italic.woff2 +0 -0
  318. package/docs/nunito-sans-bold.woff2 +0 -0
  319. package/docs/nunito-sans-italic.woff2 +0 -0
  320. package/docs/nunito-sans-regular.woff2 +0 -0
  321. package/docs/preview.css +2993 -0
  322. package/docs/project.json +1 -1
  323. package/docs/sb-addons/actions-1/manager-bundle.js +3 -0
  324. package/docs/sb-addons/actions-1/manager-bundle.js.LEGAL.txt +0 -0
  325. package/docs/sb-addons/controls-3/manager-bundle.js +394 -0
  326. package/docs/sb-addons/controls-3/manager-bundle.js.LEGAL.txt +0 -0
  327. package/docs/sb-addons/designs-2/register-panel-bundle.js +665 -0
  328. package/docs/sb-addons/designs-2/register-panel-bundle.js.LEGAL.txt +127 -0
  329. package/docs/sb-addons/storybook-6/manager-bundle.js +3 -0
  330. package/docs/sb-addons/storybook-6/manager-bundle.js.LEGAL.txt +0 -0
  331. package/docs/sb-addons/storybook-core-core-server-presets-0/common-manager-bundle.js +3 -0
  332. package/docs/sb-addons/storybook-core-core-server-presets-0/common-manager-bundle.js.LEGAL.txt +0 -0
  333. package/docs/sb-addons/storysource-4/manager-bundle.js +3 -0
  334. package/docs/sb-addons/storysource-4/manager-bundle.js.LEGAL.txt +0 -0
  335. package/docs/sb-addons/viewport-5/manager-bundle.js +3 -0
  336. package/docs/sb-addons/viewport-5/manager-bundle.js.LEGAL.txt +0 -0
  337. package/docs/sb-common-assets/favicon.svg +1 -0
  338. package/docs/sb-common-assets/nunito-sans-bold-italic.woff2 +0 -0
  339. package/docs/sb-common-assets/nunito-sans-bold.woff2 +0 -0
  340. package/docs/sb-common-assets/nunito-sans-italic.woff2 +0 -0
  341. package/docs/sb-common-assets/nunito-sans-regular.woff2 +0 -0
  342. package/docs/sb-manager/globals-module-info.js +1006 -0
  343. package/docs/sb-manager/globals-runtime.js +54400 -0
  344. package/docs/sb-manager/globals.js +48 -0
  345. package/docs/sb-manager/runtime.js +12089 -0
  346. package/docs/sb-preview/globals.js +33 -0
  347. package/docs/sb-preview/runtime.js +9498 -0
  348. package/jest.config.js +14 -11
  349. package/lib/js/components/BadgeScore/BadgeScore.stories.ts +13 -10
  350. package/lib/js/components/BadgeScore/BadgeScore.vue +5 -5
  351. package/lib/js/components/Banner/Banner.stories.ts +58 -55
  352. package/lib/js/components/Banner/Banner.vue +3 -3
  353. package/lib/js/components/Buttons/Button/Button.stories.ts +31 -21
  354. package/lib/js/components/Buttons/Button/Button.vue +4 -6
  355. package/lib/js/components/Buttons/IconButton/IconButton.stories.ts +37 -34
  356. package/lib/js/components/Buttons/IconButton/IconButton.vue +14 -7
  357. package/lib/js/components/Cards/Card/Card.stories.ts +17 -14
  358. package/lib/js/components/Cards/Card/Card.vue +4 -3
  359. package/lib/js/components/Cards/CardExpandable/CardExpandable.stories.ts +8 -7
  360. package/lib/js/components/Cards/CardExpandable/CardExpandable.vue +3 -2
  361. package/lib/js/components/Chip/Chip.stories.ts +13 -9
  362. package/lib/js/components/Chip/Chip.vue +3 -3
  363. package/lib/js/components/DatePickers/DatePicker/DatePicker.stories.ts +67 -64
  364. package/lib/js/components/DatePickers/DatePicker/DatePicker.vue +3 -3
  365. package/lib/js/components/DatePickers/DatePickerBox/DatePickerBox.vue +3 -3
  366. package/lib/js/components/Divider/Divider.stories.ts +5 -5
  367. package/lib/js/components/Divider/Divider.vue +4 -2
  368. package/lib/js/components/Drawer/Drawer.stories.ts +3 -3
  369. package/lib/js/components/Drawer/Drawer.vue +3 -3
  370. package/lib/js/components/Drawer/DrawerContent/DrawerContent.stories.ts +1 -1
  371. package/lib/js/components/Drawer/DrawerContent/DrawerContent.vue +4 -2
  372. package/lib/js/components/Drawer/DrawerDivider/DrawerDivider.stories.ts +5 -5
  373. package/lib/js/components/Drawer/DrawerDivider/DrawerDivider.vue +4 -2
  374. package/lib/js/components/Drawer/DrawerHeader/DrawerHeader.stories.ts +16 -16
  375. package/lib/js/components/Drawer/DrawerHeader/DrawerHeader.vue +3 -3
  376. package/lib/js/components/Drawer/DrawerListItem/DrawerListItem.stories.ts +4 -3
  377. package/lib/js/components/Drawer/DrawerListItem/DrawerListItem.vue +3 -3
  378. package/lib/js/components/Drawer/DrawerListItemGroup/DrawerListItemGroup.stories.ts +1 -1
  379. package/lib/js/components/Drawer/DrawerListItemGroup/DrawerListItemGroup.vue +4 -2
  380. package/lib/js/components/Drawer/DrawerSection/DrawerSection.stories.ts +60 -57
  381. package/lib/js/components/Drawer/DrawerSection/DrawerSection.vue +3 -3
  382. package/lib/js/components/Drawer/DrawerTile/DrawerTile.stories.ts +1 -1
  383. package/lib/js/components/Drawer/DrawerTile/DrawerTile.vue +4 -2
  384. package/lib/js/components/Dropdown/Dropdown.stories.ts +9 -9
  385. package/lib/js/components/Dropdown/Dropdown.vue +4 -2
  386. package/lib/js/components/Form/Checkbox/Checkbox.stories.ts +21 -14
  387. package/lib/js/components/Form/Checkbox/Checkbox.vue +3 -3
  388. package/lib/js/components/Form/RadioButton/RadioButton.stories.ts +21 -14
  389. package/lib/js/components/Form/RadioButton/RadioButton.vue +3 -3
  390. package/lib/js/components/Form/SelectionControl/SelectionControl.sb.shared.ts +13 -10
  391. package/lib/js/components/Form/SelectionControl/SelectionControl.vue +3 -3
  392. package/lib/js/components/Headers/OverlayHeader/OverlayHeader.stories.ts +9 -9
  393. package/lib/js/components/Headers/OverlayHeader/OverlayHeader.vue +5 -3
  394. package/lib/js/components/Headers/PageHeader/PageHeader.stories.ts +11 -13
  395. package/lib/js/components/Headers/PageHeader/PageHeader.vue +4 -2
  396. package/lib/js/components/Headers/SectionHeader/SectionHeader.stories.ts +65 -63
  397. package/lib/js/components/Headers/SectionHeader/SectionHeader.vue +6 -6
  398. package/lib/js/components/IconText/IconText.stories.ts +6 -5
  399. package/lib/js/components/IconText/IconText.vue +3 -3
  400. package/lib/js/components/Icons/FeatureIcon/FeatureIcon.stories.ts +15 -11
  401. package/lib/js/components/Icons/FeatureIcon/FeatureIcon.vue +3 -3
  402. package/lib/js/components/Icons/Icon/Icon.stories.ts +10 -8
  403. package/lib/js/components/Icons/Icon/Icon.vue +3 -3
  404. package/lib/js/components/Image/Image.stories.ts +5 -5
  405. package/lib/js/components/Image/Image.vue +0 -11
  406. package/lib/js/components/Layouts/ThreeColumnLayout/ThreeColumnLayout.stories.ts +8 -8
  407. package/lib/js/components/Layouts/ThreeColumnLayout/ThreeColumnLayout.vue +3 -3
  408. package/lib/js/components/LoadingBar/LoadingBar.stories.ts +5 -5
  409. package/lib/js/components/LoadingBar/LoadingBar.vue +3 -3
  410. package/lib/js/components/Modal/Modal.vue +4 -2
  411. package/lib/js/components/Modals/Modal/Modal.stories.ts +31 -31
  412. package/lib/js/components/Modals/Modal/Modal.vue +3 -3
  413. package/lib/js/components/Modals/ModalDialog/ModalDialog.stories.ts +20 -20
  414. package/lib/js/components/Modals/ModalDialog/ModalDialog.vue +3 -3
  415. package/lib/js/components/NumberInCircle/NumberInCircle.stories.ts +5 -5
  416. package/lib/js/components/NumberInCircle/NumberInCircle.vue +4 -2
  417. package/lib/js/components/Outline/OutlineDivider/OutlineDivider.stories.ts +12 -7
  418. package/lib/js/components/Outline/OutlineDivider/OutlineDivider.vue +4 -2
  419. package/lib/js/components/Outline/OutlineItem/OutlineItem.stories.ts +40 -29
  420. package/lib/js/components/Outline/OutlineItem/OutlineItem.vue +4 -4
  421. package/lib/js/components/Outline/OutlineSectionHeader/OutlineSectionHeader.stories.ts +6 -4
  422. package/lib/js/components/Outline/OutlineSectionHeader/OutlineSectionHeader.vue +4 -2
  423. package/lib/js/components/Pagination/Pagination.stories.ts +34 -21
  424. package/lib/js/components/Pagination/Pagination.vue +3 -2
  425. package/lib/js/components/PopOver/PopOver.stories.ts +9 -9
  426. package/lib/js/components/PopOver/PopOver.vue +6 -4
  427. package/lib/js/components/ProgressBar/ProgressBar.stories.ts +48 -41
  428. package/lib/js/components/ProgressBar/ProgressBar.vue +3 -3
  429. package/lib/js/components/ProgressDonutChart/ProgressDonutChart.spec.ts +1 -1
  430. package/lib/js/components/ProgressDonutChart/ProgressDonutChart.stories.ts +28 -24
  431. package/lib/js/components/ProgressDonutChart/ProgressDonutChart.vue +4 -3
  432. package/lib/js/components/RichList/BasicRichListItem/BasicRichListItem.stories.ts +82 -73
  433. package/lib/js/components/RichList/BasicRichListItem/BasicRichListItem.vue +3 -3
  434. package/lib/js/components/RichList/GroupRichListItem/GroupRichListItem.stories.ts +26 -20
  435. package/lib/js/components/RichList/GroupRichListItem/GroupRichListItem.vue +3 -3
  436. package/lib/js/components/RichList/RichListItem/RichListItem.consts.ts +5 -7
  437. package/lib/js/components/RichList/RichListItem/RichListItem.stories.ts +25 -18
  438. package/lib/js/components/RichList/RichListItem/RichListItem.vue +9 -5
  439. package/lib/js/components/SectionTitle/SectionTitle.stories.ts +5 -4
  440. package/lib/js/components/SectionTitle/SectionTitle.vue +3 -2
  441. package/lib/js/components/SelectList/SelectList.stories.ts +1 -1
  442. package/lib/js/components/SelectList/SelectList.vue +4 -2
  443. package/lib/js/components/SelectList/SelectListItem/SelectListItem.stories.ts +9 -5
  444. package/lib/js/components/SelectList/SelectListItem/SelectListItem.vue +3 -3
  445. package/lib/js/components/SelectList/SelectListItemDivider/SelectListItemDivider.vue +4 -2
  446. package/lib/js/components/SelectList/SelectListItemTile/SelectListItemTile.stories.ts +5 -2
  447. package/lib/js/components/SelectList/SelectListItemTile/SelectListItemTile.vue +4 -2
  448. package/lib/js/components/SelectList/SelectListItemToggle/SelectListItemToggle.stories.ts +51 -42
  449. package/lib/js/components/SelectList/SelectListItemToggle/SelectListItemToggle.vue +3 -3
  450. package/lib/js/components/SelectList/SelectListSectionTitle/SelectListSectionTitle.stories.ts +11 -9
  451. package/lib/js/components/SelectList/SelectListSectionTitle/SelectListSectionTitle.vue +4 -2
  452. package/lib/js/components/SelectionTile/SelectionTile.stories.ts +46 -38
  453. package/lib/js/components/Skeleton/Skeleton.stories.ts +5 -5
  454. package/lib/js/components/Statuses/AccessStatus/AccessStatus.stories.ts +3 -3
  455. package/lib/js/components/Statuses/AccessStatus/AccessStatus.vue +3 -2
  456. package/lib/js/components/Statuses/BlockadeStatus/BlockadeStatus.vue +4 -2
  457. package/lib/js/components/Statuses/BlockadeStatus/BlockedeStatus.stories.ts +3 -3
  458. package/lib/js/components/SurveyQuestions/SurveyQuestionOpenEnded/SurveyQuestionOpenEnded.stories.ts +22 -17
  459. package/lib/js/components/SurveyQuestions/SurveyQuestionOpenEnded/SurveyQuestionOpenEnded.vue +4 -2
  460. package/lib/js/components/SurveyQuestions/SurveyQuestionScale/SurveyQuestionScale.stories.ts +73 -55
  461. package/lib/js/components/SurveyQuestions/SurveyQuestionScale/SurveyQuestionScale.vue +3 -2
  462. package/lib/js/components/SurveyQuestions/SurveyQuestionTextarea.vue +4 -2
  463. package/lib/js/components/SurveyToggle/SurveyToggle.stories.ts +19 -12
  464. package/lib/js/components/SurveyToggle/SurveyToggle.vue +4 -2
  465. package/lib/js/components/Switch/Switch.stories.ts +16 -14
  466. package/lib/js/components/Switch/Switch.vue +3 -3
  467. package/lib/js/components/TabItem/TabItem.stories.ts +12 -11
  468. package/lib/js/components/TabItem/TabItem.vue +3 -3
  469. package/lib/js/components/TextGroup/TextGroup.stories.ts +20 -16
  470. package/lib/js/components/TextGroup/TextGroup.vue +1 -1
  471. package/lib/js/components/Tile/Tile.sb.shared.ts +9 -8
  472. package/lib/js/components/Tile/Tile.stories.ts +43 -45
  473. package/lib/js/components/Tile/Tile.vue +3 -2
  474. package/lib/js/components/Toast/Toast.stories.ts +10 -12
  475. package/lib/js/components/Toast/Toast.vue +3 -3
  476. package/lib/js/components/Toggles/CounterToggle/CounterToggle.stories.ts +10 -10
  477. package/lib/js/components/Toggles/CounterToggle/CounterToggle.vue +3 -3
  478. package/lib/js/components/Toggles/ToggleButton/ToggleButton.stories.ts +17 -17
  479. package/lib/js/components/Toggles/ToggleButton/ToggleButton.vue +3 -3
  480. package/lib/js/components/Tooltip/Tooltip.stories.ts +9 -9
  481. package/lib/js/components/Tooltip/Tooltip.vue +2 -10
  482. package/lib/js/components/Well/Well.stories.ts +36 -29
  483. package/lib/js/components/Well/Well.vue +4 -2
  484. package/lib/js/composables/hover-state.ts +39 -0
  485. package/lib/js/icons/fontawesome.ts +1 -1
  486. package/lib/js/index.ts +2 -1
  487. package/lib/js/styles/Colors/Colors.stories.ts +1 -1
  488. package/lib/js/styles/ColorsThemes/ColorsThemes.stories.ts +1 -1
  489. package/lib/js/styles/ColorsTokensLms/ColorsTokensLms.stories.ts +1 -1
  490. package/lib/js/styles/ColorsTokensPrimaryBodywork/ColorsTokensPrimaryBodywork.stories.ts +1 -1
  491. package/lib/js/styles/ColorsTokensPrimaryWnl/ColorsTokensPrimaryWnl.stories.ts +1 -1
  492. package/lib/js/styles/ItemsColor.vue +3 -3
  493. package/lib/js/styles/ItemsList.vue +4 -3
  494. package/lib/js/styles/ItemsTypography.vue +3 -3
  495. package/lib/js/styles/TypographyTokensLms/TypographyTokensLms.stories.ts +1 -1
  496. package/lib/js/styles/TypographyVariables/TypographyVariables.stories.ts +1 -1
  497. package/lib/js/typings.d.ts +3 -4
  498. package/lib/js/utils/device.ts +7 -0
  499. package/package.json +27 -26
  500. package/tsconfig.json +12 -5
  501. package/vite.config.ts +38 -0
  502. package/.storybook/main.js +0 -86
  503. package/babel.config.json +0 -12
  504. package/docs/117.1156a7c503a067ad8241.manager.bundle.js +0 -2
  505. package/docs/117.1156a7c503a067ad8241.manager.bundle.js.LICENSE.txt +0 -8
  506. package/docs/247.6eaf240e.iframe.bundle.js +0 -1
  507. package/docs/255.721b3744029f102ac772.manager.bundle.js +0 -2
  508. package/docs/255.721b3744029f102ac772.manager.bundle.js.LICENSE.txt +0 -12
  509. package/docs/286.23828fb3.iframe.bundle.js +0 -2
  510. package/docs/286.23828fb3.iframe.bundle.js.LICENSE.txt +0 -31
  511. package/docs/295.4e52f65e605e88f7b915.manager.bundle.js +0 -1
  512. package/docs/315.76786aa14c329ce07ff9.manager.bundle.js +0 -2
  513. package/docs/315.76786aa14c329ce07ff9.manager.bundle.js.LICENSE.txt +0 -94
  514. package/docs/317.bb9fa3422a439c11ef07.manager.bundle.js +0 -1
  515. package/docs/363.5eecfb3735eae61195ab.manager.bundle.js +0 -586
  516. package/docs/363.5eecfb3735eae61195ab.manager.bundle.js.LICENSE.txt +0 -23
  517. package/docs/39.0fa13ab1.iframe.bundle.js +0 -2
  518. package/docs/39.0fa13ab1.iframe.bundle.js.LICENSE.txt +0 -14
  519. package/docs/407.e7bfe1ea814fec553911.manager.bundle.js +0 -2
  520. package/docs/407.e7bfe1ea814fec553911.manager.bundle.js.LICENSE.txt +0 -31
  521. package/docs/594.bb1a9f64.iframe.bundle.js +0 -2
  522. package/docs/594.bb1a9f64.iframe.bundle.js.LICENSE.txt +0 -12
  523. package/docs/600.5586e4df861d64de85f8.manager.bundle.js +0 -1
  524. package/docs/651.3a01b956.iframe.bundle.js +0 -1
  525. package/docs/690.46a1e07a.iframe.bundle.js +0 -1
  526. package/docs/701.691b9947.iframe.bundle.js +0 -1
  527. package/docs/935.19d3d944.iframe.bundle.js +0 -2
  528. package/docs/935.19d3d944.iframe.bundle.js.LICENSE.txt +0 -17
  529. package/docs/949.b11a185a.iframe.bundle.js +0 -2
  530. package/docs/949.b11a185a.iframe.bundle.js.LICENSE.txt +0 -69
  531. package/docs/962.ec348c19.iframe.bundle.js +0 -2
  532. package/docs/962.ec348c19.iframe.bundle.js.LICENSE.txt +0 -8
  533. package/docs/977.a265714880f883237672.manager.bundle.js +0 -1
  534. package/docs/favicon.ico +0 -0
  535. package/docs/main.2c610e68.iframe.bundle.js +0 -2
  536. package/docs/main.2c610e68.iframe.bundle.js.LICENSE.txt +0 -1
  537. package/docs/main.ec4e5d4f1933fc03f588.manager.bundle.js +0 -1
  538. package/docs/runtime~main.8a21756dfcf63c109f1d.manager.bundle.js +0 -1
  539. package/docs/runtime~main.c8f2837a.iframe.bundle.js +0 -1
  540. package/vue.config.js +0 -67
  541. /package/{.eslintrc.js → .eslintrc.cjs} +0 -0
  542. /package/docs/{static/media/lato-ext-300.dd124df8.woff2 → ~design-system/lib/fonts/lato/lato-ext-300.woff2} +0 -0
  543. /package/docs/{static/media/lato-ext-700.4223b364.woff2 → ~design-system/lib/fonts/lato/lato-ext-700.woff2} +0 -0
  544. /package/docs/{static/media/lato-ext.b267ec5a.woff2 → ~design-system/lib/fonts/lato/lato-ext.woff2} +0 -0
  545. /package/docs/{static/media/lato-latin-300.917632e3.woff2 → ~design-system/lib/fonts/lato/lato-latin-300.woff2} +0 -0
  546. /package/docs/{static/media/lato-latin-700.f1405bd8.woff2 → ~design-system/lib/fonts/lato/lato-latin-700.woff2} +0 -0
  547. /package/docs/{static/media/lato-latin.65e877e5.woff2 → ~design-system/lib/fonts/lato/lato-latin.woff2} +0 -0
  548. /package/lib/js/tests/{emptyModule.ts → emptyModule.cjs} +0 -0
  549. /package/lib/js/tests/{emptyTransformer.ts → emptyTransformer.cjs} +0 -0
  550. /package/{stylelint.config.js → stylelint.config.cjs} +0 -0
@@ -1,586 +0,0 @@
1
- /*! For license information please see 363.5eecfb3735eae61195ab.manager.bundle.js.LICENSE.txt */
2
- "use strict";(self.webpackChunk_bethinkpl_design_system=self.webpackChunk_bethinkpl_design_system||[]).push([[363],{5363:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{__webpack_require__.r(__webpack_exports__),__webpack_require__.d(__webpack_exports__,{Figspec:()=>Figspec,default:()=>components_Figspec});var react=__webpack_require__(67294),react_namespaceObject=__webpack_require__.t(react,2);const css_tag_t=window,css_tag_e=css_tag_t.ShadowRoot&&(void 0===css_tag_t.ShadyCSS||css_tag_t.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,s=Symbol(),n=new WeakMap;class css_tag_o{constructor(t,e,n){if(this._$cssResult$=!0,n!==s)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=t,this.t=e}get styleSheet(){let t=this.o;const s=this.t;if(css_tag_e&&void 0===t){const e=void 0!==s&&1===s.length;e&&(t=n.get(s)),void 0===t&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),e&&n.set(s,t))}return t}toString(){return this.cssText}}const i=(t,...e)=>{const n=1===t.length?t[0]:e.reduce(((e,s,n)=>e+(t=>{if(!0===t._$cssResult$)return t.cssText;if("number"==typeof t)return t;throw Error("Value passed to 'css' function must be a 'css' function result: "+t+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(s)+t[n+1]),t[0]);return new css_tag_o(n,t,s)},c=css_tag_e?t=>t:t=>t instanceof CSSStyleSheet?(t=>{let e="";for(const s of t.cssRules)e+=s.cssText;return(t=>new css_tag_o("string"==typeof t?t:t+"",void 0,s))(e)})(t):t;var reactive_element_s;const reactive_element_e=window,reactive_element_r=reactive_element_e.trustedTypes,h=reactive_element_r?reactive_element_r.emptyScript:"",reactive_element_o=reactive_element_e.reactiveElementPolyfillSupport,reactive_element_n={toAttribute(t,i){switch(i){case Boolean:t=t?h:null;break;case Object:case Array:t=null==t?t:JSON.stringify(t)}return t},fromAttribute(t,i){let s=t;switch(i){case Boolean:s=null!==t;break;case Number:s=null===t?null:Number(t);break;case Object:case Array:try{s=JSON.parse(t)}catch(t){s=null}}return s}},a=(t,i)=>i!==t&&(i==i||t==t),l={attribute:!0,type:String,converter:reactive_element_n,reflect:!1,hasChanged:a};class d extends HTMLElement{constructor(){super(),this._$Ei=new Map,this.isUpdatePending=!1,this.hasUpdated=!1,this._$El=null,this.u()}static addInitializer(t){var i;this.finalize(),(null!==(i=this.h)&&void 0!==i?i:this.h=[]).push(t)}static get observedAttributes(){this.finalize();const t=[];return this.elementProperties.forEach(((i,s)=>{const e=this._$Ep(s,i);void 0!==e&&(this._$Ev.set(e,s),t.push(e))})),t}static createProperty(t,i=l){if(i.state&&(i.attribute=!1),this.finalize(),this.elementProperties.set(t,i),!i.noAccessor&&!this.prototype.hasOwnProperty(t)){const s="symbol"==typeof t?Symbol():"__"+t,e=this.getPropertyDescriptor(t,s,i);void 0!==e&&Object.defineProperty(this.prototype,t,e)}}static getPropertyDescriptor(t,i,s){return{get(){return this[i]},set(e){const r=this[t];this[i]=e,this.requestUpdate(t,r,s)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)||l}static finalize(){if(this.hasOwnProperty("finalized"))return!1;this.finalized=!0;const t=Object.getPrototypeOf(this);if(t.finalize(),void 0!==t.h&&(this.h=[...t.h]),this.elementProperties=new Map(t.elementProperties),this._$Ev=new Map,this.hasOwnProperty("properties")){const t=this.properties,i=[...Object.getOwnPropertyNames(t),...Object.getOwnPropertySymbols(t)];for(const s of i)this.createProperty(s,t[s])}return this.elementStyles=this.finalizeStyles(this.styles),!0}static finalizeStyles(i){const s=[];if(Array.isArray(i)){const e=new Set(i.flat(1/0).reverse());for(const i of e)s.unshift(c(i))}else void 0!==i&&s.push(c(i));return s}static _$Ep(t,i){const s=i.attribute;return!1===s?void 0:"string"==typeof s?s:"string"==typeof t?t.toLowerCase():void 0}u(){var t;this._$E_=new Promise((t=>this.enableUpdating=t)),this._$AL=new Map,this._$Eg(),this.requestUpdate(),null===(t=this.constructor.h)||void 0===t||t.forEach((t=>t(this)))}addController(t){var i,s;(null!==(i=this._$ES)&&void 0!==i?i:this._$ES=[]).push(t),void 0!==this.renderRoot&&this.isConnected&&(null===(s=t.hostConnected)||void 0===s||s.call(t))}removeController(t){var i;null===(i=this._$ES)||void 0===i||i.splice(this._$ES.indexOf(t)>>>0,1)}_$Eg(){this.constructor.elementProperties.forEach(((t,i)=>{this.hasOwnProperty(i)&&(this._$Ei.set(i,this[i]),delete this[i])}))}createRenderRoot(){var t;const s=null!==(t=this.shadowRoot)&&void 0!==t?t:this.attachShadow(this.constructor.shadowRootOptions);return((s,n)=>{css_tag_e?s.adoptedStyleSheets=n.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet)):n.forEach((e=>{const n=document.createElement("style"),o=css_tag_t.litNonce;void 0!==o&&n.setAttribute("nonce",o),n.textContent=e.cssText,s.appendChild(n)}))})(s,this.constructor.elementStyles),s}connectedCallback(){var t;void 0===this.renderRoot&&(this.renderRoot=this.createRenderRoot()),this.enableUpdating(!0),null===(t=this._$ES)||void 0===t||t.forEach((t=>{var i;return null===(i=t.hostConnected)||void 0===i?void 0:i.call(t)}))}enableUpdating(t){}disconnectedCallback(){var t;null===(t=this._$ES)||void 0===t||t.forEach((t=>{var i;return null===(i=t.hostDisconnected)||void 0===i?void 0:i.call(t)}))}attributeChangedCallback(t,i,s){this._$AK(t,s)}_$EO(t,i,s=l){var e;const r=this.constructor._$Ep(t,s);if(void 0!==r&&!0===s.reflect){const h=(void 0!==(null===(e=s.converter)||void 0===e?void 0:e.toAttribute)?s.converter:reactive_element_n).toAttribute(i,s.type);this._$El=t,null==h?this.removeAttribute(r):this.setAttribute(r,h),this._$El=null}}_$AK(t,i){var s;const e=this.constructor,r=e._$Ev.get(t);if(void 0!==r&&this._$El!==r){const t=e.getPropertyOptions(r),h="function"==typeof t.converter?{fromAttribute:t.converter}:void 0!==(null===(s=t.converter)||void 0===s?void 0:s.fromAttribute)?t.converter:reactive_element_n;this._$El=r,this[r]=h.fromAttribute(i,t.type),this._$El=null}}requestUpdate(t,i,s){let e=!0;void 0!==t&&(((s=s||this.constructor.getPropertyOptions(t)).hasChanged||a)(this[t],i)?(this._$AL.has(t)||this._$AL.set(t,i),!0===s.reflect&&this._$El!==t&&(void 0===this._$EC&&(this._$EC=new Map),this._$EC.set(t,s))):e=!1),!this.isUpdatePending&&e&&(this._$E_=this._$Ej())}async _$Ej(){this.isUpdatePending=!0;try{await this._$E_}catch(t){Promise.reject(t)}const t=this.scheduleUpdate();return null!=t&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){var t;if(!this.isUpdatePending)return;this.hasUpdated,this._$Ei&&(this._$Ei.forEach(((t,i)=>this[i]=t)),this._$Ei=void 0);let i=!1;const s=this._$AL;try{i=this.shouldUpdate(s),i?(this.willUpdate(s),null===(t=this._$ES)||void 0===t||t.forEach((t=>{var i;return null===(i=t.hostUpdate)||void 0===i?void 0:i.call(t)})),this.update(s)):this._$Ek()}catch(t){throw i=!1,this._$Ek(),t}i&&this._$AE(s)}willUpdate(t){}_$AE(t){var i;null===(i=this._$ES)||void 0===i||i.forEach((t=>{var i;return null===(i=t.hostUpdated)||void 0===i?void 0:i.call(t)})),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t)}_$Ek(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$E_}shouldUpdate(t){return!0}update(t){void 0!==this._$EC&&(this._$EC.forEach(((t,i)=>this._$EO(i,this[i],t))),this._$EC=void 0),this._$Ek()}updated(t){}firstUpdated(t){}}var lit_html_t;d.finalized=!0,d.elementProperties=new Map,d.elementStyles=[],d.shadowRootOptions={mode:"open"},null==reactive_element_o||reactive_element_o({ReactiveElement:d}),(null!==(reactive_element_s=reactive_element_e.reactiveElementVersions)&&void 0!==reactive_element_s?reactive_element_s:reactive_element_e.reactiveElementVersions=[]).push("1.6.1");const lit_html_i=window,lit_html_s=lit_html_i.trustedTypes,lit_html_e=lit_html_s?lit_html_s.createPolicy("lit-html",{createHTML:t=>t}):void 0,lit_html_o=`lit$${(Math.random()+"").slice(9)}$`,lit_html_n="?"+lit_html_o,lit_html_l=`<${lit_html_n}>`,lit_html_h=document,lit_html_r=(t="")=>lit_html_h.createComment(t),lit_html_d=t=>null===t||"object"!=typeof t&&"function"!=typeof t,u=Array.isArray,lit_html_c=t=>u(t)||"function"==typeof(null==t?void 0:t[Symbol.iterator]),v=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,lit_html_a=/-->/g,f=/>/g,_=RegExp(">|[ \t\n\f\r](?:([^\\s\"'>=/]+)([ \t\n\f\r]*=[ \t\n\f\r]*(?:[^ \t\n\f\r\"'`<>=]|(\"|')|))|$)","g"),m=/'/g,p=/"/g,$=/^(?:script|style|textarea|title)$/i,g=t=>(i,...s)=>({_$litType$:t,strings:i,values:s}),lit_html_y=g(1),w=g(2),x=Symbol.for("lit-noChange"),b=Symbol.for("lit-nothing"),T=new WeakMap,A=lit_html_h.createTreeWalker(lit_html_h,129,null,!1),E=(t,i)=>{const s=t.length-1,n=[];let h,r=2===i?"<svg>":"",d=v;for(let i=0;i<s;i++){const s=t[i];let e,u,c=-1,g=0;for(;g<s.length&&(d.lastIndex=g,u=d.exec(s),null!==u);)g=d.lastIndex,d===v?"!--"===u[1]?d=lit_html_a:void 0!==u[1]?d=f:void 0!==u[2]?($.test(u[2])&&(h=RegExp("</"+u[2],"g")),d=_):void 0!==u[3]&&(d=_):d===_?">"===u[0]?(d=null!=h?h:v,c=-1):void 0===u[1]?c=-2:(c=d.lastIndex-u[2].length,e=u[1],d=void 0===u[3]?_:'"'===u[3]?p:m):d===p||d===m?d=_:d===lit_html_a||d===f?d=v:(d=_,h=void 0);const y=d===_&&t[i+1].startsWith("/>")?" ":"";r+=d===v?s+lit_html_l:c>=0?(n.push(e),s.slice(0,c)+"$lit$"+s.slice(c)+lit_html_o+y):s+lit_html_o+(-2===c?(n.push(void 0),i):y)}const u=r+(t[s]||"<?>")+(2===i?"</svg>":"");if(!Array.isArray(t)||!t.hasOwnProperty("raw"))throw Error("invalid template strings array");return[void 0!==lit_html_e?lit_html_e.createHTML(u):u,n]};class C{constructor({strings:t,_$litType$:i},e){let l;this.parts=[];let h=0,d=0;const u=t.length-1,c=this.parts,[v,a]=E(t,i);if(this.el=C.createElement(v,e),A.currentNode=this.el.content,2===i){const t=this.el.content,i=t.firstChild;i.remove(),t.append(...i.childNodes)}for(;null!==(l=A.nextNode())&&c.length<u;){if(1===l.nodeType){if(l.hasAttributes()){const t=[];for(const i of l.getAttributeNames())if(i.endsWith("$lit$")||i.startsWith(lit_html_o)){const s=a[d++];if(t.push(i),void 0!==s){const t=l.getAttribute(s.toLowerCase()+"$lit$").split(lit_html_o),i=/([.?@])?(.*)/.exec(s);c.push({type:1,index:h,name:i[2],strings:t,ctor:"."===i[1]?M:"?"===i[1]?k:"@"===i[1]?H:lit_html_S})}else c.push({type:6,index:h})}for(const i of t)l.removeAttribute(i)}if($.test(l.tagName)){const t=l.textContent.split(lit_html_o),i=t.length-1;if(i>0){l.textContent=lit_html_s?lit_html_s.emptyScript:"";for(let s=0;s<i;s++)l.append(t[s],lit_html_r()),A.nextNode(),c.push({type:2,index:++h});l.append(t[i],lit_html_r())}}}else if(8===l.nodeType)if(l.data===lit_html_n)c.push({type:2,index:h});else{let t=-1;for(;-1!==(t=l.data.indexOf(lit_html_o,t+1));)c.push({type:7,index:h}),t+=lit_html_o.length-1}h++}}static createElement(t,i){const s=lit_html_h.createElement("template");return s.innerHTML=t,s}}function P(t,i,s=t,e){var o,n,l,h;if(i===x)return i;let r=void 0!==e?null===(o=s._$Co)||void 0===o?void 0:o[e]:s._$Cl;const u=lit_html_d(i)?void 0:i._$litDirective$;return(null==r?void 0:r.constructor)!==u&&(null===(n=null==r?void 0:r._$AO)||void 0===n||n.call(r,!1),void 0===u?r=void 0:(r=new u(t),r._$AT(t,s,e)),void 0!==e?(null!==(l=(h=s)._$Co)&&void 0!==l?l:h._$Co=[])[e]=r:s._$Cl=r),void 0!==r&&(i=P(t,r._$AS(t,i.values),r,e)),i}class V{constructor(t,i){this.u=[],this._$AN=void 0,this._$AD=t,this._$AM=i}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}v(t){var i;const{el:{content:s},parts:e}=this._$AD,o=(null!==(i=null==t?void 0:t.creationScope)&&void 0!==i?i:lit_html_h).importNode(s,!0);A.currentNode=o;let n=A.nextNode(),l=0,r=0,d=e[0];for(;void 0!==d;){if(l===d.index){let i;2===d.type?i=new N(n,n.nextSibling,this,t):1===d.type?i=new d.ctor(n,d.name,d.strings,this,t):6===d.type&&(i=new I(n,this,t)),this.u.push(i),d=e[++r]}l!==(null==d?void 0:d.index)&&(n=A.nextNode(),l++)}return o}p(t){let i=0;for(const s of this.u)void 0!==s&&(void 0!==s.strings?(s._$AI(t,s,i),i+=s.strings.length-2):s._$AI(t[i])),i++}}class N{constructor(t,i,s,e){var o;this.type=2,this._$AH=b,this._$AN=void 0,this._$AA=t,this._$AB=i,this._$AM=s,this.options=e,this._$Cm=null===(o=null==e?void 0:e.isConnected)||void 0===o||o}get _$AU(){var t,i;return null!==(i=null===(t=this._$AM)||void 0===t?void 0:t._$AU)&&void 0!==i?i:this._$Cm}get parentNode(){let t=this._$AA.parentNode;const i=this._$AM;return void 0!==i&&11===t.nodeType&&(t=i.parentNode),t}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(t,i=this){t=P(this,t,i),lit_html_d(t)?t===b||null==t||""===t?(this._$AH!==b&&this._$AR(),this._$AH=b):t!==this._$AH&&t!==x&&this.g(t):void 0!==t._$litType$?this.$(t):void 0!==t.nodeType?this.T(t):lit_html_c(t)?this.k(t):this.g(t)}O(t,i=this._$AB){return this._$AA.parentNode.insertBefore(t,i)}T(t){this._$AH!==t&&(this._$AR(),this._$AH=this.O(t))}g(t){this._$AH!==b&&lit_html_d(this._$AH)?this._$AA.nextSibling.data=t:this.T(lit_html_h.createTextNode(t)),this._$AH=t}$(t){var i;const{values:s,_$litType$:e}=t,o="number"==typeof e?this._$AC(t):(void 0===e.el&&(e.el=C.createElement(e.h,this.options)),e);if((null===(i=this._$AH)||void 0===i?void 0:i._$AD)===o)this._$AH.p(s);else{const t=new V(o,this),i=t.v(this.options);t.p(s),this.T(i),this._$AH=t}}_$AC(t){let i=T.get(t.strings);return void 0===i&&T.set(t.strings,i=new C(t)),i}k(t){u(this._$AH)||(this._$AH=[],this._$AR());const i=this._$AH;let s,e=0;for(const o of t)e===i.length?i.push(s=new N(this.O(lit_html_r()),this.O(lit_html_r()),this,this.options)):s=i[e],s._$AI(o),e++;e<i.length&&(this._$AR(s&&s._$AB.nextSibling,e),i.length=e)}_$AR(t=this._$AA.nextSibling,i){var s;for(null===(s=this._$AP)||void 0===s||s.call(this,!1,!0,i);t&&t!==this._$AB;){const i=t.nextSibling;t.remove(),t=i}}setConnected(t){var i;void 0===this._$AM&&(this._$Cm=t,null===(i=this._$AP)||void 0===i||i.call(this,t))}}class lit_html_S{constructor(t,i,s,e,o){this.type=1,this._$AH=b,this._$AN=void 0,this.element=t,this.name=i,this._$AM=e,this.options=o,s.length>2||""!==s[0]||""!==s[1]?(this._$AH=Array(s.length-1).fill(new String),this.strings=s):this._$AH=b}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(t,i=this,s,e){const o=this.strings;let n=!1;if(void 0===o)t=P(this,t,i,0),n=!lit_html_d(t)||t!==this._$AH&&t!==x,n&&(this._$AH=t);else{const e=t;let l,h;for(t=o[0],l=0;l<o.length-1;l++)h=P(this,e[s+l],i,l),h===x&&(h=this._$AH[l]),n||(n=!lit_html_d(h)||h!==this._$AH[l]),h===b?t=b:t!==b&&(t+=(null!=h?h:"")+o[l+1]),this._$AH[l]=h}n&&!e&&this.j(t)}j(t){t===b?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,null!=t?t:"")}}class M extends lit_html_S{constructor(){super(...arguments),this.type=3}j(t){this.element[this.name]=t===b?void 0:t}}const R=lit_html_s?lit_html_s.emptyScript:"";class k extends lit_html_S{constructor(){super(...arguments),this.type=4}j(t){t&&t!==b?this.element.setAttribute(this.name,R):this.element.removeAttribute(this.name)}}class H extends lit_html_S{constructor(t,i,s,e,o){super(t,i,s,e,o),this.type=5}_$AI(t,i=this){var s;if((t=null!==(s=P(this,t,i,0))&&void 0!==s?s:b)===x)return;const e=this._$AH,o=t===b&&e!==b||t.capture!==e.capture||t.once!==e.once||t.passive!==e.passive,n=t!==b&&(e===b||o);o&&this.element.removeEventListener(this.name,this,e),n&&this.element.addEventListener(this.name,this,t),this._$AH=t}handleEvent(t){var i,s;"function"==typeof this._$AH?this._$AH.call(null!==(s=null===(i=this.options)||void 0===i?void 0:i.host)&&void 0!==s?s:this.element,t):this._$AH.handleEvent(t)}}class I{constructor(t,i,s){this.element=t,this.type=6,this._$AN=void 0,this._$AM=i,this.options=s}get _$AU(){return this._$AM._$AU}_$AI(t){P(this,t)}}const z=lit_html_i.litHtmlPolyfillSupport;null==z||z(C,N),(null!==(lit_html_t=lit_html_i.litHtmlVersions)&&void 0!==lit_html_t?lit_html_t:lit_html_i.litHtmlVersions=[]).push("2.6.1");var lit_element_l,lit_element_o;class lit_element_s extends d{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){var t,e;const i=super.createRenderRoot();return null!==(t=(e=this.renderOptions).renderBefore)&&void 0!==t||(e.renderBefore=i.firstChild),i}update(t){const i=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this._$Do=((t,i,s)=>{var e,o;const n=null!==(e=null==s?void 0:s.renderBefore)&&void 0!==e?e:i;let l=n._$litPart$;if(void 0===l){const t=null!==(o=null==s?void 0:s.renderBefore)&&void 0!==o?o:null;n._$litPart$=l=new N(i.insertBefore(lit_html_r(),t),t,void 0,null!=s?s:{})}return l._$AI(t),l})(i,this.renderRoot,this.renderOptions)}connectedCallback(){var t;super.connectedCallback(),null===(t=this._$Do)||void 0===t||t.setConnected(!0)}disconnectedCallback(){var t;super.disconnectedCallback(),null===(t=this._$Do)||void 0===t||t.setConnected(!1)}render(){return x}}lit_element_s.finalized=!0,lit_element_s._$litElement$=!0,null===(lit_element_l=globalThis.litElementHydrateSupport)||void 0===lit_element_l||lit_element_l.call(globalThis,{LitElement:lit_element_s});const lit_element_n=globalThis.litElementPolyfillSupport;null==lit_element_n||lit_element_n({LitElement:lit_element_s});(null!==(lit_element_o=globalThis.litElementVersions)&&void 0!==lit_element_o?lit_element_o:globalThis.litElementVersions=[]).push("3.2.2");const property_i=(i,e)=>"method"===e.kind&&e.descriptor&&!("value"in e.descriptor)?{...e,finisher(n){n.createProperty(e.key,i)}}:{kind:"field",key:Symbol(),placement:"own",descriptor:{},originalKey:e.key,initializer(){"function"==typeof e.initializer&&(this[e.key]=e.initializer.call(this))},finisher(n){n.createProperty(e.key,i)}};function property_e(e){return(n,t)=>void 0!==t?((i,e,n)=>{e.constructor.createProperty(n,i)})(e,n,t):property_i(e,n)}var query_assigned_elements_n;null===(query_assigned_elements_n=window.HTMLSlotElement)||void 0===query_assigned_elements_n||query_assigned_elements_n.prototype.assignedElements;const ErrorMessage=({title,children})=>lit_html_y`
3
- <div class="error-background">
4
- <div class="error-container">
5
- <span class="error-title"
6
- ><span class="error-badge">Error</span>${title}</span
7
- >
8
- <span class="error-description">${children}</span>
9
- </div>
10
- </div>
11
- `,ErrorMessage_styles=i`
12
- .error-background {
13
- position: absolute;
14
- top: 0;
15
- left: 0;
16
- width: 100%;
17
- height: 100%;
18
-
19
- background: var(--error-bg);
20
- color: var(--error-fg);
21
- }
22
-
23
- .error-container {
24
- max-width: 800px;
25
- margin: auto;
26
- padding: 1em;
27
- }
28
-
29
- .error-badge {
30
- display: inline-block;
31
- font-size: 0.8em;
32
- padding: 0.2em 0.5em;
33
- margin-inline-end: 0.5em;
34
-
35
- background: var(--error-color);
36
- border-radius: 2px;
37
- color: var(--error-bg);
38
- text-transform: uppercase;
39
- }
40
-
41
- .error-title {
42
- display: block;
43
- font-size: 1.2em;
44
-
45
- font-weight: bold;
46
- text-transform: capitalize;
47
- }
48
-
49
- .error-description {
50
- display: block;
51
- margin-block-start: 1em;
52
- }
53
- `,directive_t_ATTRIBUTE=1;class directive_i{constructor(t){}get _$AU(){return this._$AM._$AU}_$AT(t,e,i){this._$Ct=t,this._$AM=e,this._$Ci=i}_$AS(t,e){return this.update(t,e)}update(t,e){return this.render(...e)}}const style_map_i=(t=>(...e)=>({_$litDirective$:t,values:e}))(class extends directive_i{constructor(t){var e;if(super(t),t.type!==directive_t_ATTRIBUTE||"style"!==t.name||(null===(e=t.strings)||void 0===e?void 0:e.length)>2)throw Error("The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.")}render(t){return Object.keys(t).reduce(((e,r)=>{const s=t[r];return null==s?e:e+`${r=r.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${s};`}),"")}update(e,[r]){const{style:s}=e.element;if(void 0===this.vt){this.vt=new Set;for(const t in r)this.vt.add(t);return this.render(r)}this.vt.forEach((t=>{null==r[t]&&(this.vt.delete(t),t.includes("-")?s.removeProperty(t):s[t]="")}));for(const t in r){const e=r[t];null!=e&&(this.vt.add(t),t.includes("-")?s.setProperty(t,e):s[t]=e)}return x}});function absRect(rect){return{top:rect.y,right:rect.x+rect.width,bottom:rect.y+rect.height,left:rect.x}}function round(n){return Math.round(100*n)/100}function extendStyles(left,right){return[...stylesToArray(left),...stylesToArray(right)]}function stylesToArray(styles){return styles?styles instanceof Array?styles:[styles]:[]}var __decorate=function(decorators,target,key,desc){var d,c=arguments.length,r=c<3?target:null===desc?desc=Object.getOwnPropertyDescriptor(target,key):desc;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)r=Reflect.decorate(decorators,target,key,desc);else for(var i=decorators.length-1;i>=0;i--)(d=decorators[i])&&(r=(c<3?d(r):c>3?d(target,key,r):d(target,key))||r);return c>3&&r&&Object.defineProperty(target,key,r),r};const NodeSelectableMixin=superClass=>{class NodeSelectable extends superClass{constructor(...args){super(...args),this.selectedNode=null}updated(changedProperties){super.updated(changedProperties),changedProperties.has("selectedNode")&&this.dispatchEvent(new CustomEvent("nodeselect",{detail:{selectedNode:this.selectedNode}}))}}return __decorate([property_e({attribute:!1})],NodeSelectable.prototype,"selectedNode",void 0),NodeSelectable};function shouldSkipEvent(ev){return 0===ev.touches.length||ev.touches.length>2}const TouchGestureMixin=superClass=>class CTouchGesture extends superClass{constructor(...args){super(...args),this.previousTouches=null,this.addEventListener("touchstart",(ev=>{shouldSkipEvent(ev)||(ev.preventDefault(),this.previousTouches=ev.touches)})),this.addEventListener("touchend",(ev=>{shouldSkipEvent(ev)||(ev.preventDefault(),this.previousTouches=null)})),this.addEventListener("touchcancel",(ev=>{shouldSkipEvent(ev)||(ev.preventDefault(),this.previousTouches=null)})),this.addEventListener("touchmove",(ev=>{if(shouldSkipEvent(ev))return;const previousTouches=Array.from(this.previousTouches||[]),currentTouches=Array.from(ev.touches);this.previousTouches=ev.touches,currentTouches.length===previousTouches.length&&currentTouches.every((t=>previousTouches.some((pt=>pt.identifier===t.identifier))))&&(1!==currentTouches.length?this.onTouchPinch(function getDistance(a,b){return Math.sqrt(Math.pow(a.x-b.x,2)+Math.pow(a.y-b.y,2))}({x:currentTouches[0].pageX,y:currentTouches[0].pageY},{x:previousTouches[0].pageX,y:previousTouches[0].pageY})):this.onTouchPan({x:currentTouches[0].pageX-previousTouches[0].pageX,y:currentTouches[0].pageY-previousTouches[0].pageY}))}))}get isTouching(){return!!(this.previousTouches&&this.previousTouches.length>0)}onTouchPan(delta){}onTouchPinch(delta){}};var PositionedMixin_decorate=function(decorators,target,key,desc){var d,c=arguments.length,r=c<3?target:null===desc?desc=Object.getOwnPropertyDescriptor(target,key):desc;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)r=Reflect.decorate(decorators,target,key,desc);else for(var i=decorators.length-1;i>=0;i--)(d=decorators[i])&&(r=(c<3?d(r):c>3?d(target,key,r):d(target,key))||r);return c>3&&r&&Object.defineProperty(target,key,r),r},__classPrivateFieldGet=function(receiver,privateMap){if(!privateMap.has(receiver))throw new TypeError("attempted to get private field on non-instance");return privateMap.get(receiver)},__classPrivateFieldSet=function(receiver,privateMap,value){if(!privateMap.has(receiver))throw new TypeError("attempted to set private field on non-instance");return privateMap.set(receiver,value),value};const PositionedMixin=superClass=>{var _isDragModeOn,_movePanel,_keyDown,_keyUp,_listenToKeyboardEvents;class Positioned extends(TouchGestureMixin(superClass)){constructor(...args){super(...args),this.panX=0,this.panY=0,this.scale=1,this.zoomSpeed=500,this.panSpeed=500,_isDragModeOn.set(this,!1),_movePanel.set(this,((shiftX,shiftY)=>{this.panX+=shiftX/this.scale/window.devicePixelRatio,this.panY+=shiftY/this.scale/window.devicePixelRatio})),_keyDown.set(this,(event=>{"Space"!==event.code||__classPrivateFieldGet(this,_isDragModeOn)||(__classPrivateFieldSet(this,_isDragModeOn,!0),document.body.style.cursor="grab")})),_keyUp.set(this,(event=>{"Space"===event.code&&__classPrivateFieldGet(this,_isDragModeOn)&&(__classPrivateFieldSet(this,_isDragModeOn,!1),document.body.style.cursor="auto")})),_listenToKeyboardEvents.set(this,(()=>{document.addEventListener("keyup",__classPrivateFieldGet(this,_keyUp)),document.addEventListener("keydown",__classPrivateFieldGet(this,_keyDown))})),this.addEventListener("wheel",(ev=>{if(this.isMovable)if(ev.preventDefault(),ev.ctrlKey){let{deltaY}=ev;1===ev.deltaMode&&(deltaY*=15);const prevScale=this.scale;this.scale*=1-deltaY/(.5*(1e3-this.zoomSpeed));const offsetX=ev.offsetX-this.offsetWidth/2,offsetY=ev.offsetY-this.offsetHeight/2;this.panX+=offsetX/this.scale-offsetX/prevScale,this.panY+=offsetY/this.scale-offsetY/prevScale}else{const speed=.002*this.panSpeed;this.panX-=ev.deltaX*speed/this.scale,this.panY-=ev.deltaY*speed/this.scale}}),{passive:!1});let gestureStartScale=1;this.addEventListener("gesturestart",(ev=>{ev.preventDefault(),gestureStartScale=this.scale})),this.addEventListener("gesturechange",(_ev=>{const ev=_ev;ev.preventDefault(),this.scale=gestureStartScale*ev.scale})),this.addEventListener("pointermove",(ev=>{4&ev.buttons&&(ev.preventDefault(),__classPrivateFieldGet(this,_movePanel).call(this,ev.movementX,ev.movementY))})),__classPrivateFieldGet(this,_listenToKeyboardEvents).call(this),this.onmousedown=()=>{__classPrivateFieldGet(this,_isDragModeOn)&&(document.body.style.cursor="grabbing",this.onmousemove=({movementX,movementY})=>{__classPrivateFieldGet(this,_movePanel).call(this,movementX,movementY)},this.onmouseup=()=>{document.body.style.cursor="grab",this.onmousemove=null,this.onmouseup=null})}}get isMovable(){return!0}get canvasTransform(){return[`scale(${this.scale})`,`translate(${this.panX}px, ${this.panY}px)`]}disconnectedCallback(){document.removeEventListener("keyup",__classPrivateFieldGet(this,_keyUp)),document.removeEventListener("keydown",__classPrivateFieldGet(this,_keyDown)),super.disconnectedCallback()}updated(changedProperties){super.updated(changedProperties),changedProperties.has("scale")&&this.dispatchEvent(new CustomEvent("scalechange",{detail:{scale:this.scale}})),(changedProperties.has("panX")||changedProperties.has("panY"))&&this.dispatchEvent(new CustomEvent("positionchange",{detail:{x:this.panX,y:this.panY}}))}onTouchPan(delta){this.panX+=delta.x/this.scale,this.panY+=delta.y/this.scale}onTouchPinch(delta){this.scale*=1-delta/1e3}}return _isDragModeOn=new WeakMap,_movePanel=new WeakMap,_keyDown=new WeakMap,_keyUp=new WeakMap,_listenToKeyboardEvents=new WeakMap,PositionedMixin_decorate([property_e({attribute:!1})],Positioned.prototype,"panX",void 0),PositionedMixin_decorate([property_e({attribute:!1})],Positioned.prototype,"panY",void 0),PositionedMixin_decorate([property_e({attribute:!1})],Positioned.prototype,"scale",void 0),PositionedMixin_decorate([property_e({type:Number,attribute:"zoom-speed"})],Positioned.prototype,"zoomSpeed",void 0),PositionedMixin_decorate([property_e({type:Number,attribute:"pan-speed"})],Positioned.prototype,"panSpeed",void 0),Positioned},guidesCache=new Map,Guides=({node,distanceTo,reverseScale,fontSize})=>{const combinedId=node.id+"\n"+distanceTo.id;let guides=guidesCache.get(combinedId);return guides||(guides=function getDistanceGuides(selected,compared){const a=absRect(selected),b=absRect(compared),isYIntersecting=!(a.top>b.bottom||a.bottom<b.top),isXIntersecting=!(a.left>b.right||a.right<b.left);if(isXIntersecting&&isYIntersecting){const intersectCenter={x:(Math.max(a.left,b.left)+Math.min(a.right,b.right))/2,y:(Math.max(a.top,b.top)+Math.min(a.bottom,b.bottom))/2};return[{points:[{x:a.left,y:intersectCenter.y},{x:b.left,y:intersectCenter.y}]},{points:[{x:a.right,y:intersectCenter.y},{x:b.right,y:intersectCenter.y}]},{points:[{y:a.top,x:intersectCenter.x},{y:b.top,x:intersectCenter.x}]},{points:[{y:a.bottom,x:intersectCenter.x},{y:b.bottom,x:intersectCenter.x}]}]}const isALeft=a.left>b.right,isABelow=a.top>b.bottom,selectedCenter={x:selected.x+selected.width/2,y:selected.y+selected.height/2};return[isXIntersecting?null:{points:[{x:isALeft?a.left:a.right,y:selectedCenter.y},{x:isALeft?b.right:b.left,y:selectedCenter.y}],bisector:isYIntersecting?void 0:[{x:isALeft?b.right:b.left,y:selectedCenter.y},{x:isALeft?b.right:b.left,y:isABelow?b.bottom:b.top}]},isYIntersecting?null:{points:[{y:isABelow?a.top:a.bottom,x:selectedCenter.x},{y:isABelow?b.bottom:b.top,x:selectedCenter.x}],bisector:isXIntersecting?void 0:[{y:isABelow?b.bottom:b.top,x:selectedCenter.x},{y:isABelow?b.bottom:b.top,x:isALeft?b.right:b.left}]}].filter((x=>!!x))}(node.absoluteBoundingBox,distanceTo.absoluteBoundingBox),guidesCache.set(combinedId,guides)),[...guides.map((guide=>(({guide,reverseScale})=>{const xLength=Math.abs(guide.points[0].x-guide.points[1].x),yLength=Math.abs(guide.points[0].y-guide.points[1].y);return 0===xLength&&0===yLength?null:w`
54
- <line
55
- class="distance-line"
56
- x1=${guide.points[0].x}
57
- y1=${guide.points[0].y}
58
- x2=${guide.points[1].x}
59
- y2=${guide.points[1].y}
60
- />
61
-
62
- ${guide.bisector&&w`
63
- <line
64
- class="distance-line"
65
- x1=${guide.bisector[0].x}
66
- y1=${guide.bisector[0].y}
67
- x2=${guide.bisector[1].x}
68
- y2=${guide.bisector[1].y}
69
- style=${style_map_i({strokeDasharray:""+4*reverseScale})}
70
- shape-rendering="geometricPrecision"
71
- fill="none"
72
- />
73
- `}
74
- `})({guide,reverseScale}))),...guides.map((guide=>(({guide,reverseScale,fontSize})=>{const xLength=Math.abs(guide.points[0].x-guide.points[1].x),yLength=Math.abs(guide.points[0].y-guide.points[1].y);if(0===xLength&&0===yLength)return null;const text=round(Math.max(xLength,yLength)).toString(10),width=text.length*fontSize*.5,startMargin=.25*fontSize,vPadding=.25*fontSize,hPadding=.5*fontSize,x=xLength>yLength?(guide.points[0].x+guide.points[1].x)/2-width/2:guide.points[0].x,y=xLength>yLength?guide.points[0].y:(guide.points[0].y+guide.points[1].y)/2-fontSize/2,transform=[`scale(${reverseScale})`,xLength>yLength?`translate(0, ${startMargin+vPadding})`:`translate(${startMargin+hPadding}, 0)`].join(" "),cx=x+width/2,transformOrigin=xLength>yLength?`${cx} ${y}`:`${x} ${y+fontSize/2}`;return w`
75
- <g class="distance-tooltip">
76
- <rect
77
- x=${x-hPadding}
78
- y=${y-vPadding}
79
- rx="2"
80
- width=${width+2*hPadding}
81
- height=${fontSize+2*vPadding}
82
- transform=${transform}
83
- transform-origin=${transformOrigin}
84
- stroke="none"
85
- />
86
-
87
- <text
88
- x=${cx}
89
- y=${y+fontSize-vPadding/2}
90
- text-anchor="middle"
91
- transform=${transform}
92
- transform-origin=${transformOrigin}
93
- stroke="none"
94
- fill="white"
95
- style="font-size: ${fontSize}px"
96
- >
97
- ${text}
98
- </text>
99
- </g>
100
- `})({guide,reverseScale,fontSize})))]},DistanceGuide_styles=i`
101
- .distance-line {
102
- shape-rendering: geometricPrecision;
103
- fill: none;
104
- opacity: 0;
105
- }
106
-
107
- .distance-tooltip {
108
- opacity: 0;
109
- }
110
-
111
- .guide:hover ~ .distance-line,
112
- .guide:hover ~ .distance-tooltip {
113
- opacity: 1;
114
- }
115
- `,CopyIcon=({onClick=()=>{}})=>w`
116
- <svg @click=${onClick} title="copy icon" width="14" height="14" viewBox="0 0 30 30" fill="none">
117
- <path d="M21 25.5C21 24.9477 20.5523 24.5 20 24.5C19.4477 24.5 19 24.9477 19 25.5H21ZM13 2H25V0H13V2ZM28 5V21H30V5H28ZM25 24H13V26H25V24ZM10 21V5H8V21H10ZM13 24C11.3431 24 10 22.6569 10 21H8C8 23.7614 10.2386 26 13 26V24ZM28 21C28 22.6569 26.6569 24 25 24V26C27.7614 26 30 23.7614 30 21H28ZM25 2C26.6569 2 28 3.34315 28 5H30C30 2.23858 27.7614 0 25 0V2ZM13 0C10.2386 0 8 2.23858 8 5H10C10 3.34315 11.3431 2 13 2V0ZM16.5 28H5V30H16.5V28ZM2 25V10H0V25H2ZM5 28C3.34315 28 2 26.6569 2 25H0C0 27.7614 2.23858 30 5 30V28ZM5 7H8V5H5V7ZM2 10C2 8.34315 3.34315 7 5 7V5C2.23858 5 0 7.23858 0 10H2ZM16.5 30C18.9853 30 21 27.9853 21 25.5H19C19 26.8807 17.8807 28 16.5 28V30Z" fill="#B3B3B3"/>
118
- </svg>
119
- `,extractColorStyle=color=>0===color.a?"transparent":color.a<1?`rgba(${rgbToIntArray(color).join(", ")}, ${color.a.toFixed(2)})`:rgbToHex(color);class Gradient{constructor(data){this.gradientHandles={start:data.gradientHandlePositions[0],end:data.gradientHandlePositions[1]},this.colors=data.gradientStops,this.colorObjects=this.createColorObjects(this.colors),this.angle=this.calculateAngle(this.gradientHandles.start,this.gradientHandles.end)}get cssGradientArray(){return this.colorObjects.map(((color,index)=>color+" "+this.floatToPercent(this.colors[index].position)))}get cssColor(){const cssGradientArray=this.cssGradientArray;return cssGradientArray.unshift(this.angle+"deg"),`linear-gradient(${cssGradientArray.join(", ")})`}createColorObjects(colors){return colors.map((({color})=>extractColorStyle(color)))}floatToPercent(value){return(value*=100).toFixed(0)+"%"}calculateAngle(startHandle,endHandle){const radians=Math.atan(this.calculateGradient(startHandle,endHandle));return parseInt(this.radToDeg(radians).toFixed(1))}calculateGradient(startHandle,endHandle){return(endHandle.y-startHandle.y)/(endHandle.x-startHandle.x)*-1}radToDeg(radian){return 180*radian/Math.PI}}class NodeStyles{constructor(node){var _a,_b,_c;if(this.hasPadding=!1,this.height=`${Math.trunc(node.absoluteBoundingBox.height)}px`,this.width=`${Math.trunc(node.absoluteBoundingBox.width)}px`,(node.horizontalPadding||node.verticalPadding)&&(this.hasPadding=!0,this.horizontalPadding=`${node.horizontalPadding}px`,this.verticalPadding=`${node.verticalPadding}px`),node.style&&(this.fontFamily=node.style.fontFamily,this.fontPostScriptName=null===(_a=node.style.fontPostScriptName)||void 0===_a?void 0:_a.replace("-"," "),this.fontWeight=node.style.fontWeight,this.fontSize=`${Math.ceil(node.style.fontSize)}px`,this.lineHeight=`${Math.trunc(node.style.lineHeightPx)}px`),node.rectangleCornerRadii&&(this.borderRadius=node.rectangleCornerRadii.filter((radius=>radius===node.cornerRadius)).length<4?`${node.rectangleCornerRadii.join("px ")}px`:`${node.cornerRadius}px`),node.backgroundColor||node.backgroundColor){const color=node.backgroundColor||(null===(_b=node.background)||void 0===_b?void 0:_b[0].color);this.background=extractColorStyle(color)}const fillColor=null===(_c=node.fills)||void 0===_c?void 0:_c[0];if(fillColor&&!1!==fillColor.visible&&("TEXT"===node.type?this.color=extractColorStyle(fillColor.color):fillColor.type.includes("GRADIENT")?this.backgroundImage=new Gradient(fillColor).cssColor:"SOLID"===fillColor.type&&(this.background=extractColorStyle(fillColor.color))),node.strokes&&node.strokes.length>0&&(this.borderColor=extractColorStyle(node.strokes[0].color),this.border=`${node.strokeWeight}px solid ${this.borderColor}`),node.effects&&node.effects.length>0){const{offset,radius,color}=node.effects[0];this.boxShadowColor=extractColorStyle(color),this.boxShadow=`${(null==offset?void 0:offset.x)||0}px ${(null==offset?void 0:offset.y)||0}px 0 ${radius} ${this.boxShadowColor}`}}getStyles(){return[this.height&&{property:"height",value:this.height},this.width&&{property:"width",value:this.width},this.fontFamily&&{property:"font-family",value:this.fontFamily},this.fontSize&&{property:"font-size",value:this.fontSize},this.fontWeight&&{property:"font-weight",value:this.fontWeight},this.lineHeight&&{property:"line-height",value:this.lineHeight},this.borderRadius&&{property:"border-radius",value:this.borderRadius},this.backgroundImage&&{property:"background-image",value:this.backgroundImage},this.boxShadow&&{property:"box-shadow",value:this.boxShadow,color:this.boxShadowColor},this.border&&{property:"border",value:this.border,color:this.borderColor},this.background&&{property:"background",value:this.background,color:this.background},this.color&&{property:"color",value:this.color,color:this.color}].filter(Boolean)}getStyleSheet(){return this.getStyles().map(getStyleRule).join("\n")}}const rgbToIntArray=color=>[Math.trunc(255*color.r),Math.trunc(255*color.g),Math.trunc(255*color.b)],rgbToHex=color=>{const[r,g,b]=rgbToIntArray(color);return"#"+((1<<24)+(r<<16)+(g<<8)+b).toString(16).slice(1)},getStyleRule=({property,value})=>`${property}: ${value};`;var __awaiter=function(thisArg,_arguments,P,generator){return new(P||(P=Promise))((function(resolve,reject){function fulfilled(value){try{step(generator.next(value))}catch(e){reject(e)}}function rejected(value){try{step(generator.throw(value))}catch(e){reject(e)}}function step(result){result.done?resolve(result.value):function adopt(value){return value instanceof P?value:new P((function(resolve){resolve(value)}))}(result.value).then(fulfilled,rejected)}step((generator=generator.apply(thisArg,_arguments||[])).next())}))};const copy=text=>__awaiter(void 0,void 0,void 0,(function*(){yield navigator.clipboard.writeText(text)})),View=({node,onClose})=>{if(!node)return null;const nodeStyles=new NodeStyles(node),stopPropagation=ev=>ev.stopPropagation();return lit_html_y`
120
- <div
121
- class="inspector-view"
122
- @click=${stopPropagation}
123
- @wheel=${stopPropagation}
124
- @keydown=${stopPropagation}
125
- @keyup=${stopPropagation}
126
- @pointermove=${stopPropagation}
127
- >
128
- <div class="inspector-section selectable-content">
129
- <div class="title-section">
130
- <h4>${node.name}</h4>
131
- ${(({onClick=()=>{}})=>w`
132
- <svg @click=${onClick} title="close icon" width="14" height="14" viewBox="0 0 20 20" fill="none">
133
- <path d="M1 19L19 1M19 19L1 1" stroke="#B3B3B3" stroke-width="2"/>
134
- </svg>
135
- `)({onClick:onClose})}
136
- </div>
137
- <div class="properties-overview">
138
- <div class="title-section">
139
- <p class="inspector-property">
140
- <span>W: </span>${nodeStyles.width}
141
- </p>
142
- <p class="inspector-property" style="margin-left: 16px;">
143
- <span>H: </span>${nodeStyles.height}
144
- </p>
145
- </div>
146
- ${nodeStyles.fontPostScriptName?lit_html_y`<p class="inspector-property">
147
- <span>Font:</span>
148
- ${nodeStyles.fontPostScriptName}
149
- </p>`:null}
150
- </div>
151
- </div>
152
- ${nodeStyles.hasPadding?lit_html_y`<div class="inspector-section">
153
- <h4>Layout</h4>
154
- ${nodeStyles.horizontalPadding&&lit_html_y`<p class="inspector-property">
155
- ${w`
156
- <svg title="horizontal padding" width="14" height="14" viewBox="0 0 29 28" fill="none">
157
- <rect x="7" y="8" width="14" height="14" stroke="#B3B3B3" stroke-width="2"/>
158
- <path d="M27 1V28" stroke="#B3B3B3" stroke-width="2"/>
159
- <path d="M1 0V28" stroke="#B3B3B3" stroke-width="2"/>
160
- </svg>
161
- `} ${nodeStyles.horizontalPadding}
162
- </p>`}
163
- ${nodeStyles.verticalPadding&&lit_html_y`<p class="inspector-property">
164
- ${w`
165
- <svg title="vertical padding" width="14" height="14" viewBox="0 0 29 28" fill="none" xmlns="http://www.w3.org/2000/svg">
166
- <rect x="8" y="21" width="14" height="14" transform="rotate(-90 8 21)" stroke="#B3B3B3" stroke-width="2"/>
167
- <path d="M1 1L28 0.999999" stroke="#B3B3B3" stroke-width="2"/>
168
- <path d="M0 27L28 27" stroke="#B3B3B3" stroke-width="2"/>
169
- </svg>
170
- `} ${nodeStyles.verticalPadding}
171
- </p>`}
172
- </div>`:null}
173
- ${node.characters?lit_html_y`<div class="inspector-section">
174
- <div class="title-section">
175
- <h4>Content</h4>
176
- ${CopyIcon({onClick:()=>copy(node.characters)})}
177
- </div>
178
- <p class="node-content code-section selectable-content">
179
- ${node.characters}
180
- </p>
181
- </div>`:null}
182
- ${StylesSection(nodeStyles)}
183
- </div>
184
- `},StylesSection=nodeStyles=>{const styles=nodeStyles.getStyles();return lit_html_y`<div class="inspector-section">
185
- <div class="title-section style-section">
186
- <h4>CSS</h4>
187
- ${CopyIcon({onClick:()=>copy(nodeStyles.getStyleSheet())})}
188
- </div>
189
- <div class="code-section selectable-content">
190
- ${styles.map(CSSProperty)}
191
- </div>
192
- </div>`},CSSProperty=cssProperty=>{const{property,value,color}=cssProperty;let coloredSquare=null;switch(property){case"background":case"fill":case"border":case"box-shadow":case"color":coloredSquare=lit_html_y`<span
193
- class="color-preview"
194
- style="background-color: ${color}"
195
- ></span>`;break;case"background-image":coloredSquare=lit_html_y`<span
196
- class="color-preview"
197
- style="background-image: ${value}"
198
- ></span>`}return lit_html_y`<div class="css-property" @click=${()=>copy(getStyleRule(cssProperty))}>
199
- <span>${property}:</span>${coloredSquare}<span class="css-value">${value}</span>;</span>
200
- </div>`},InspectorView_styles=i`
201
- .inspector-view {
202
- height: 100%;
203
- width: 300px;
204
- position: absolute;
205
- right: 0;
206
- background: white;
207
- border-left: 1px solid #ccc;
208
- overflow-y: auto;
209
- z-index: calc(var(--z-index) + 2);
210
- }
211
-
212
- .inspector-view h4 {
213
- font-size: 16px;
214
- margin: 0;
215
- }
216
-
217
- .style-section {
218
- margin-bottom: 12px;
219
- }
220
-
221
- .title-section {
222
- display: flex;
223
- align-items: center;
224
- }
225
-
226
- .code-section {
227
- padding: 8px;
228
- background: #f3f3f3;
229
- font-family: monospace;
230
- }
231
-
232
- .title-section svg {
233
- cursor: pointer;
234
- margin-left: auto;
235
- }
236
-
237
- .inspector-section {
238
- padding: 16px;
239
- border-bottom: 1px solid #eee;
240
- }
241
-
242
- .properties-overview {
243
- font-family: monospace;
244
- color: #518785;
245
- }
246
-
247
- .properties-overview p span {
248
- color: #121212;
249
- }
250
-
251
- .inspector-property {
252
- display: flex;
253
- align-items: center;
254
- margin-bottom: 0;
255
- }
256
-
257
- .inspector-property span {
258
- color: #b3b3b3;
259
- margin-right: 4px;
260
- }
261
-
262
- .inspector-property svg {
263
- margin-right: 8px;
264
- }
265
-
266
- .css-property {
267
- margin: 8px;
268
- transition: background-color ease-in-out 100ms;
269
- }
270
-
271
- .css-property:hover {
272
- cursor: pointer;
273
- background-color: #e8e8e8;
274
- }
275
-
276
- .css-value {
277
- color: #518785;
278
- margin-left: 4px;
279
- }
280
-
281
- .color-preview {
282
- display: inline-block;
283
- width: 12px;
284
- height: 12px;
285
- border: 1px solid #ccc;
286
- margin-left: 4px;
287
- vertical-align: middle;
288
- }
289
-
290
- .selectable-content {
291
- cursor: text;
292
- user-select: text;
293
- }
294
- `,Outline=({node,selected=!1,computedThickness,onClick})=>{const{x,y,width,height}=node.absoluteBoundingBox,radius="cornerRadius"in node&&node.cornerRadius?{topLeft:node.cornerRadius,topRight:node.cornerRadius,bottomRight:node.cornerRadius,bottomLeft:node.cornerRadius}:"rectangleCornerRadii"in node&&node.rectangleCornerRadii?{topLeft:node.rectangleCornerRadii[0],topRight:node.rectangleCornerRadii[1],bottomRight:node.rectangleCornerRadii[2],bottomLeft:node.rectangleCornerRadii[3]}:{topLeft:0,topRight:0,bottomRight:0,bottomLeft:0},shift=computedThickness/2,lineTo=(x,y)=>`L${x},${y}`,arcTo=(r,x,y)=>`A${r},${r} 0 0 1 ${x},${y}`,boxPath=[((x,y)=>`M${x},${y}`)(radius.topLeft+shift,shift),lineTo(width-radius.topRight,shift),arcTo(radius.topRight-shift,width-shift,radius.topRight),lineTo(width-shift,height-radius.bottomRight),arcTo(radius.bottomRight-shift,width-radius.bottomRight,height-shift),lineTo(radius.bottomLeft,height-shift),arcTo(radius.bottomLeft-shift,shift,height-radius.bottomLeft),lineTo(shift,radius.topLeft),arcTo(radius.topLeft-shift,radius.topLeft,shift),"Z"].join(" ");return w`
295
- <path
296
- class="guide"
297
- d=${boxPath}
298
- shape-rendering="geometricPrecision"
299
- fill="none"
300
- transform="translate(${x}, ${y})"
301
- ?data-selected=${selected}
302
- @click=${onClick}
303
- />
304
- `},Node_styles=i`
305
- .guide {
306
- /*
307
- * SVGs cannot be pixel perfect, especially floating values.
308
- * Since many platform renders them visually incorrectly (probably they
309
- * are following the spec), it's safe to set overflow to visible.
310
- * Cropped borders are hard to visible and ugly.
311
- */
312
- overflow: visible;
313
-
314
- pointer-events: all;
315
-
316
- opacity: 0;
317
- }
318
- .guide:hover {
319
- opacity: 1;
320
- }
321
- .guide[data-selected] {
322
- opacity: 1;
323
- stroke: var(--guide-selected-color);
324
- }
325
-
326
- .tooltip {
327
- position: absolute;
328
- padding: 0.25em 0.5em;
329
- font-size: var(--guide-tooltip-font-size);
330
-
331
- color: var(--guide-selected-tooltip-fg);
332
- background-color: var(--guide-selected-tooltip-bg);
333
- border-radius: 2px;
334
- pointer-events: none;
335
- z-index: calc(var(--z-index) + 1);
336
-
337
- transform-origin: top center;
338
- }
339
- `,DAY=864e5,intervals=[{gte:31536e6,divisor:31536e6,unit:"year"},{gte:2592e6,divisor:2592e6,unit:"month"},{gte:6048e5,divisor:6048e5,unit:"week"},{gte:DAY,divisor:DAY,unit:"day"},{gte:36e5,divisor:36e5,unit:"hour"},{gte:6e4,divisor:6e4,unit:"minute"},{gte:3e4,divisor:1e3,unit:"seconds"},{gte:0,divisor:1,text:"just now"}],getTime=targetDate=>("object"==typeof targetDate?targetDate:new Date(targetDate)).getTime(),Footer_styles=i`
340
- .figma-footer {
341
- flex: 0;
342
- z-index: calc(var(--z-index) + 1);
343
- border-top: 1px solid #ccc;
344
- min-height: 48px;
345
- padding: 0 16px;
346
- text-decoration: none;
347
- display: flex;
348
- flex-direction: row;
349
- justify-content: start;
350
- align-items: center;
351
- background-color: #fff;
352
- overflow-x: auto;
353
- cursor: pointer;
354
- font-size: 12px;
355
- color: rgba(0, 0, 0, 0.8);
356
- }
357
-
358
- .figma-footer--icon {
359
- margin-right: 12px;
360
- }
361
-
362
- .figma-footer--title {
363
- font-weight: 600;
364
- margin-right: 4px;
365
-
366
- white-space: nowrap;
367
- overflow: hidden;
368
- text-overflow: ellipsis;
369
- }
370
-
371
- .figma-footer--timestamp {
372
- white-space: nowrap;
373
- overflow: hidden;
374
- }
375
- `,Footer=metadata=>{if(!metadata||!metadata.link||void 0===metadata.link||"undefined"===metadata.link)return null;const{link,timestamp,fileName}=metadata;return lit_html_y`<a
376
- class="figma-footer"
377
- target="_blank"
378
- rel="noopener"
379
- title="Open in Figma"
380
- href="${link}"
381
- >
382
- <span class="figma-footer--icon"> ${w`
383
- <svg title="figma logo" width="11" height="16" viewBox="0 0 12 17" xmlns="http://www.w3.org/2000/svg">
384
- <path
385
- d="M5.5 1.5h-2c-1.105 0-2 .895-2 2 0 1.105.895 2 2 2h2v-4zm-5 2c0 1.043.533 1.963 1.341 2.5C1.033 6.537.5 7.457.5 8.5c0 1.043.533 1.963 1.341 2.5C1.033 11.537.5 12.457.5 13.5c0 1.657 1.343 3 3 3 1.657 0 3-1.343 3-3V10.736c.53.475 1.232.764 2 .764 1.657 0 3-1.343 3-3 0-1.043-.533-1.963-1.341-2.5.808-.537 1.341-1.457 1.341-2.5 0-1.657-1.343-3-3-3h-5c-1.657 0-3 1.343-3 3zm1 5c0-1.105.895-2 2-2h2v4h-2c-1.105 0-2-.895-2-2zm0 5c0-1.105.895-2 2-2h2v2c0 1.105-.895 2-2 2-1.105 0-2-.895-2-2zm7-3c-1.105 0-2-.895-2-2 0-1.105.895-2 2-2 1.105 0 2 .895 2 2 0 1.105-.895 2-2 2zm0-5h-2v-4h2c1.105 0 2 .895 2 2 0 1.105-.895 2-2 2z"
386
- fill-rule="evenodd"
387
- fill-opacity="1"
388
- fill="#000"
389
- stroke="none"
390
- ></path>
391
- </svg>
392
- `} </span>
393
- <span class="figma-footer--title"> ${fileName} </span>
394
- <span
395
- title="Last time edited: ${new Date(timestamp).toUTCString()}"
396
- class="figma-footer--timestamp"
397
- >
398
- Edited ${((date,nowDate=Date.now(),rft=new Intl.RelativeTimeFormat(void 0,{numeric:"auto"}))=>{const diff=getTime(nowDate)-getTime(date),diffAbs=Math.abs(diff);for(const interval of intervals)if(diffAbs>=interval.gte){const x=Math.round(Math.abs(diff)/interval.divisor),isInFuture=diff<0,intervalUnit=interval.unit;return intervalUnit?rft.format(isInFuture?x:-x,intervalUnit):interval.text}})(timestamp)}
399
- </span>
400
- </a>`};var ViewerMixin_decorate=function(decorators,target,key,desc){var d,c=arguments.length,r=c<3?target:null===desc?desc=Object.getOwnPropertyDescriptor(target,key):desc;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)r=Reflect.decorate(decorators,target,key,desc);else for(var i=decorators.length-1;i>=0;i--)(d=decorators[i])&&(r=(c<3?d(r):c>3?d(target,key,r):d(target,key))||r);return c>3&&r&&Object.defineProperty(target,key,r),r},ViewerMixin_classPrivateFieldGet=function(receiver,privateMap){if(!privateMap.has(receiver))throw new TypeError("attempted to get private field on non-instance");return privateMap.get(receiver)},ViewerMixin_classPrivateFieldSet=function(receiver,privateMap,value){if(!privateMap.has(receiver))throw new TypeError("attempted to set private field on non-instance");return privateMap.set(receiver,value),value};const ViewerMixin=superClass=>{var _canvasSize,_effectMargins,_flattenedNodes,_handleNodeClick,_getNodeById;class Viewer extends(NodeSelectableMixin(PositionedMixin(superClass))){constructor(...args){super(...args),this.zoomMargin=50,this.link="",_canvasSize.set(this,void 0),_effectMargins.set(this,void 0),_flattenedNodes.set(this,void 0),_handleNodeClick.set(this,(node=>ev=>{ev.preventDefault(),ev.stopPropagation(),this.selectedNode=node})),_getNodeById.set(this,(id=>{var _a,_b;return null!==(_b=null===(_a=ViewerMixin_classPrivateFieldGet(this,_flattenedNodes))||void 0===_a?void 0:_a.find((n=>n.id===id)))&&void 0!==_b?_b:null}))}static get styles(){return extendStyles(super.styles,[i`
401
- :host {
402
- --default-error-bg: #fff;
403
- --default-error-fg: #333;
404
-
405
- --bg: var(--figspec-viewer-bg, #e5e5e5);
406
- --z-index: var(--figspec-viewer-z-index, 0);
407
- --error-bg: var(--figspec-viewer-error-bg, var(--default-error-bg));
408
- --error-fg: var(--figspec-viewer-error-fg, var(--default-error-fg));
409
- --error-color: var(--figspec-viewer-error-color, tomato);
410
-
411
- --guide-thickness: var(--figspec-viewer-guide-thickness, 1.5px);
412
- --guide-color: var(--figspec-viewer-guide-color, tomato);
413
- --guide-selected-color: var(
414
- --figspec-viewer-guide-selected-color,
415
- dodgerblue
416
- );
417
- --guide-tooltip-fg: var(--figspec-viewer-guide-tooltip-fg, white);
418
- --guide-selected-tooltip-fg: var(
419
- --figspec-viewer-guide-selected-tooltip-fg,
420
- white
421
- );
422
- --guide-tooltip-bg: var(
423
- --figspec-viewer-guide-tooltip-bg,
424
- var(--guide-color)
425
- );
426
- --guide-selected-tooltip-bg: var(
427
- --figspec-viewer-guide-selected-tooltip-bg,
428
- var(--guide-selected-color)
429
- );
430
- --guide-tooltip-font-size: var(
431
- --figspec-viewer-guide-tooltip-font-size,
432
- 12px
433
- );
434
-
435
- position: relative;
436
- display: block;
437
-
438
- background-color: var(--bg);
439
- user-select: none;
440
- overflow: hidden;
441
- z-index: var(--z-index);
442
- }
443
-
444
- @media (prefers-color-scheme: dark) {
445
- :host {
446
- --default-error-bg: #222;
447
- --default-error-fg: #fff;
448
- }
449
- }
450
-
451
- .spec-canvas-wrapper {
452
- position: absolute;
453
- top: 0;
454
- left: 0;
455
- width: 100%;
456
- height: 100%;
457
- display: flex;
458
- flex-direction: column-reverse;
459
- }
460
-
461
- .canvas {
462
- position: absolute;
463
- top: 50%;
464
- left: 50%;
465
- flex: 1;
466
- }
467
-
468
- .rendered-image {
469
- position: absolute;
470
- top: 0;
471
- left: 0;
472
- }
473
-
474
- .guides {
475
- position: absolute;
476
-
477
- overflow: visible;
478
- stroke: var(--guide-color);
479
- fill: var(--guide-color);
480
- pointer-events: none;
481
- z-index: calc(var(--z-index) + 2);
482
- }
483
- `,Node_styles,ErrorMessage_styles,DistanceGuide_styles,InspectorView_styles,Footer_styles])}get __images(){return{}}deselectNode(){this.selectedNode=null}get error(){return ViewerMixin_classPrivateFieldGet(this,_canvasSize)&&ViewerMixin_classPrivateFieldGet(this,_flattenedNodes)?null:ErrorMessage({title:"Error",children:"Please call `__updateTree/1` method with a valid parameter."})}render(){if(this.error)return this.error instanceof Error?ErrorMessage({title:this.error.name||"Error",children:this.error.message}):"string"==typeof this.error?ErrorMessage({title:"Error",children:this.error}):this.error;const canvasSize=ViewerMixin_classPrivateFieldGet(this,_canvasSize),reverseScale=1/this.scale,guideThickness=`calc(var(--guide-thickness) * ${reverseScale})`,computedGuideThickness=parseFloat(getComputedStyle(this).getPropertyValue("--guide-thickness")),computedGuideTooltipFontSize=parseFloat(getComputedStyle(this).getPropertyValue("--guide-tooltip-font-size"));return lit_html_y`
484
- <div class="spec-canvas-wrapper" @click=${this.deselectNode}>
485
- <div
486
- class="canvas"
487
- style="
488
- width: ${canvasSize.width}px;
489
- height: ${canvasSize.height}px;
490
-
491
- transform: translate(-50%, -50%) ${this.canvasTransform.join(" ")}
492
- "
493
- >
494
- ${Object.entries(this.__images).map((([nodeId,uri])=>{var _a;const node=ViewerMixin_classPrivateFieldGet(this,_getNodeById).call(this,nodeId);if(!node||!("absoluteBoundingBox"in node)||!(null===(_a=ViewerMixin_classPrivateFieldGet(this,_effectMargins))||void 0===_a?void 0:_a[node.id]))return null;const margin=ViewerMixin_classPrivateFieldGet(this,_effectMargins)[node.id];return lit_html_y`
495
- <img class="rendered-image" src="${uri}"
496
- style=${style_map_i({top:node.absoluteBoundingBox.y-canvasSize.y+"px",left:node.absoluteBoundingBox.x-canvasSize.x+"px",marginTop:-margin.top+"px",marginLeft:-margin.left+"px",width:node.absoluteBoundingBox.width+margin.left+margin.right+"px",height:node.absoluteBoundingBox.height+margin.top+margin.bottom+"px"})}"
497
- " />
498
- `}))}
499
- ${this.selectedNode&&(({nodeSize:{x,y,width,height},offsetX,offsetY,reverseScale})=>lit_html_y`
500
- <div class="tooltip" style="${style_map_i({top:`${offsetY+y+height}px`,left:`${offsetX+x+width/2}px`,transform:`translateX(-50%) scale(${reverseScale}) translateY(0.25em)`})}">
501
- ${round(width)} x ${round(height)}
502
- </div>
503
- `)({nodeSize:this.selectedNode.absoluteBoundingBox,offsetX:-canvasSize.x,offsetY:-canvasSize.y,reverseScale})}
504
- ${w`
505
- <svg
506
- class="guides"
507
- viewBox="0 0 5 5"
508
- width="5"
509
- height="5"
510
- style=${style_map_i({left:-canvasSize.x+"px",top:-canvasSize.y+"px",strokeWidth:guideThickness})}
511
- >
512
- ${this.selectedNode&&Outline({node:this.selectedNode,selected:!0,computedThickness:computedGuideThickness*reverseScale})}
513
-
514
- ${ViewerMixin_classPrivateFieldGet(this,_flattenedNodes).map((node=>{var _a;return node.id===(null===(_a=this.selectedNode)||void 0===_a?void 0:_a.id)?null:w`
515
- <g>
516
- ${Outline({node,computedThickness:computedGuideThickness*reverseScale,onClick:ViewerMixin_classPrivateFieldGet(this,_handleNodeClick).call(this,node)})}
517
- ${this.selectedNode&&Guides({node,distanceTo:this.selectedNode,reverseScale,fontSize:computedGuideTooltipFontSize})}
518
- </g>
519
- `}))}
520
- </svg>
521
- `}
522
- </div>
523
- ${View({node:this.selectedNode,onClose:this.deselectNode})}
524
- ${Footer(this.getMetadata())}
525
- </div>
526
- `}getMetadata(){}connectedCallback(){super.connectedCallback(),this.resetZoom()}updated(changedProperties){super.updated(changedProperties)}__updateTree(node){if("CANVAS"!==node.type&&"FRAME"!==node.type&&"COMPONENT"!==node.type&&"COMPONENT_SET"!==node.type)throw new Error("Cannot update node tree: Top level node MUST be one of CANVAS, FRAME, COMPONENT, or COMPONENT_SET");ViewerMixin_classPrivateFieldSet(this,_canvasSize,"CANVAS"===node.type?function getCanvasSize(node){const left=[],right=[],top=[],bottom=[];for(const child of node.children){if("FRAME"!==child.type&&"COMPONENT"!==child.type)continue;const{x,y,width,height}=child.absoluteBoundingBox;left.push(x),right.push(x+width),top.push(y),bottom.push(y+height)}const minX=Math.min(...left),minY=Math.min(...top);return{x:minX,y:minY,width:Math.abs(Math.max(...right)-minX),height:Math.abs(Math.min(...bottom)-minY)}}(node):node.absoluteBoundingBox),ViewerMixin_classPrivateFieldSet(this,_flattenedNodes,flattenNode(node)),this.requestUpdate()}__updateEffectMargins(){if(!this.__images)return;const containers=Object.keys(this.__images).map(ViewerMixin_classPrivateFieldGet(this,_getNodeById)).filter((n=>!!n));ViewerMixin_classPrivateFieldSet(this,_effectMargins,containers.reduce(((margin,node)=>"absoluteBoundingBox"in node?Object.assign(Object.assign({},margin),{[node.id]:getEffectMargin(node,flattenNode(node))}):margin),{})),this.requestUpdate()}resetZoom(){if(ViewerMixin_classPrivateFieldGet(this,_canvasSize)){const{width,height}=ViewerMixin_classPrivateFieldGet(this,_canvasSize),{width:elementWidth,height:elementHeight}=this.getBoundingClientRect(),wDiff=elementWidth/(width+2*this.zoomMargin),hDiff=elementHeight/(height+2*this.zoomMargin);this.scale=Math.min(wDiff,hDiff,1)}}}return _canvasSize=new WeakMap,_effectMargins=new WeakMap,_flattenedNodes=new WeakMap,_handleNodeClick=new WeakMap,_getNodeById=new WeakMap,ViewerMixin_decorate([property_e({type:Number,attribute:"zoom-margin"})],Viewer.prototype,"zoomMargin",void 0),ViewerMixin_decorate([property_e({type:String,attribute:"link"})],Viewer.prototype,"link",void 0),Viewer};function getEffectMargin(container,nodes){const points=nodes.map((node=>{if(!("effects"in node))return{top:node.absoluteBoundingBox.y,right:node.absoluteBoundingBox.x+node.absoluteBoundingBox.width,bottom:node.absoluteBoundingBox.y+node.absoluteBoundingBox.height,left:node.absoluteBoundingBox.x};const blurRadiuses=node.effects.filter((effect=>effect.visible&&"LAYER_BLUR"===effect.type)).map((effect=>effect.radius)),shadowMargins=node.effects.filter((effect=>effect.visible&&"DROP_SHADOW"===effect.type&&!!effect.offset)).map((effect=>({left:effect.radius-effect.offset.x,top:effect.radius-effect.offset.y,right:effect.radius+effect.offset.x,bottom:effect.radius+effect.offset.y}))),margin_top=Math.max(0,...blurRadiuses,...shadowMargins.map((margin=>margin.top))),margin_right=Math.max(0,...blurRadiuses,...shadowMargins.map((margin=>margin.right))),margin_bottom=Math.max(0,...blurRadiuses,...shadowMargins.map((margin=>margin.bottom))),margin_left=Math.max(0,...blurRadiuses,...shadowMargins.map((margin=>margin.left)));return{top:node.absoluteBoundingBox.y-margin_top,right:node.absoluteBoundingBox.x+node.absoluteBoundingBox.width+margin_right,bottom:node.absoluteBoundingBox.y+node.absoluteBoundingBox.height+margin_bottom,left:node.absoluteBoundingBox.x-margin_left}})),bounds_top=Math.min(...points.map((p=>p.top))),bounds_right=Math.max(...points.map((p=>p.right))),bounds_bottom=Math.max(...points.map((p=>p.bottom))),bounds_left=Math.min(...points.map((p=>p.left)));return{top:container.absoluteBoundingBox.y-bounds_top,right:bounds_right-container.absoluteBoundingBox.x-container.absoluteBoundingBox.width,bottom:bounds_bottom-container.absoluteBoundingBox.y-container.absoluteBoundingBox.height,left:container.absoluteBoundingBox.x-bounds_left}}function flattenNode(node,depth=0){return"absoluteBoundingBox"in node?"children"in node&&0!==node.children.length?[Object.assign(Object.assign({},node),{depth}),...node.children.map((child=>flattenNode(child,depth+1))).flat()]:[Object.assign(Object.assign({},node),{depth})]:node.children.map((child=>flattenNode(child,depth+1))).flat()}var FigspecFrameViewer_decorate=function(decorators,target,key,desc){var d,c=arguments.length,r=c<3?target:null===desc?desc=Object.getOwnPropertyDescriptor(target,key):desc;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)r=Reflect.decorate(decorators,target,key,desc);else for(var i=decorators.length-1;i>=0;i--)(d=decorators[i])&&(r=(c<3?d(r):c>3?d(target,key,r):d(target,key))||r);return c>3&&r&&Object.defineProperty(target,key,r),r};class FigspecFrameViewer extends(ViewerMixin(lit_element_s)){constructor(){super(...arguments),this.nodes=null,this.renderedImage=null}get isMovable(){return!!(this.nodes&&this.renderedImage&&this.documentNode)}get documentNode(){if(!this.nodes)return null;const documentNode=Object.values(this.nodes.nodes)[0];return documentNode&&"absoluteBoundingBox"in documentNode.document?documentNode.document:null}get __images(){return this.documentNode&&this.renderedImage?{[this.documentNode.id]:this.renderedImage}:{}}get error(){return this.nodes&&this.renderedImage?this.documentNode?super.error?super.error:void 0:ErrorMessage({title:"Parameter Error",children:lit_html_y`
527
- <span> Document node is empty or does not have size. </span>
528
- `}):ErrorMessage({title:"Parameter error",children:lit_html_y`<span>
529
- Both <code>nodes</code> and <code>rendered-image</code> are required.
530
- </span>`})}getMetadata(){return{fileName:this.nodes.name,timestamp:this.nodes.lastModified,link:this.link}}connectedCallback(){super.connectedCallback(),this.documentNode&&(this.__updateTree(this.documentNode),this.__updateEffectMargins(),this.resetZoom())}updated(changedProperties){if(super.updated(changedProperties),changedProperties.has("nodes")){if(!this.documentNode)return;this.__updateTree(this.documentNode),this.resetZoom()}changedProperties.has("renderedImage")&&this.__updateEffectMargins()}}FigspecFrameViewer_decorate([property_e({type:Object})],FigspecFrameViewer.prototype,"nodes",void 0),FigspecFrameViewer_decorate([property_e({type:String,attribute:"rendered-image"})],FigspecFrameViewer.prototype,"renderedImage",void 0);var _selectFirstPage,_handlePageChange,FigspecFileViewer_decorate=function(decorators,target,key,desc){var d,c=arguments.length,r=c<3?target:null===desc?desc=Object.getOwnPropertyDescriptor(target,key):desc;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)r=Reflect.decorate(decorators,target,key,desc);else for(var i=decorators.length-1;i>=0;i--)(d=decorators[i])&&(r=(c<3?d(r):c>3?d(target,key,r):d(target,key))||r);return c>3&&r&&Object.defineProperty(target,key,r),r},FigspecFileViewer_classPrivateFieldGet=function(receiver,privateMap){if(!privateMap.has(receiver))throw new TypeError("attempted to get private field on non-instance");return privateMap.get(receiver)};class FigspecFileViewer extends(ViewerMixin(lit_element_s)){constructor(){super(...arguments),this.documentNode=null,this.renderedImages=null,this.selectedPage=null,_selectFirstPage.set(this,(()=>{var _a;this.documentNode?this.selectedPage=null!==(_a=this.documentNode.document.children.filter((c=>"CANVAS"===c.type))[0])&&void 0!==_a?_a:null:this.selectedPage=null})),_handlePageChange.set(this,(ev=>{var _a,_b;const target=ev.currentTarget;this.selectedPage=null!==(_b=null===(_a=this.documentNode)||void 0===_a?void 0:_a.document.children.find((c=>c.id===target.value)))&&void 0!==_b?_b:null,this.selectedPage&&(this.__updateTree(this.selectedPage),this.resetZoom(),this.__updateEffectMargins(),this.panX=0,this.panY=0)}))}get isMovable(){return!(!this.renderedImages||!this.documentNode)}get __images(){return this.renderedImages||{}}get error(){return this.documentNode&&this.renderedImages?super.error?super.error:void 0:ErrorMessage({title:"Parameter error",children:lit_html_y`<span>
531
- Both <code>document-node</code> and <code>rendered-images</code> are
532
- required.
533
- </span>`})}static get styles(){return extendStyles(super.styles,[i`
534
- :host {
535
- --figspec-control-bg-default: #fcfcfc;
536
- --figspec-control-fg-default: #333;
537
-
538
- --control-bg: var(
539
- --figspec-control-bg,
540
- var(--figspec-control-bg-default)
541
- );
542
- --control-fg: var(
543
- --figspec-control-bg,
544
- var(--figspec-control-fg-default)
545
- );
546
- --control-shadow: var(
547
- --figspec-control-shadow,
548
- 0 2px 4px rgba(0, 0, 0, 0.3)
549
- );
550
- --padding: var(--figspec-control-padding, 8px 16px);
551
-
552
- display: flex;
553
- flex-direction: column;
554
- }
555
-
556
- @media (prefers-color-scheme: dark) {
557
- :host {
558
- --figspec-control-bg-default: #222;
559
- --figspec-control-fg-default: #fff;
560
- }
561
- }
562
-
563
- .controls {
564
- flex-shrink: 0;
565
- padding: var(--padding);
566
-
567
- background-color: var(--control-bg);
568
- box-shadow: var(--control-shadow);
569
- color: var(--control-fg);
570
- z-index: 1;
571
- }
572
-
573
- .view {
574
- position: relative;
575
- flex-grow: 1;
576
- flex-shrink: 1;
577
- }
578
- `])}render(){var _a;return lit_html_y`
579
- <div class="controls">
580
- <select @change=${FigspecFileViewer_classPrivateFieldGet(this,_handlePageChange)}>
581
- ${null===(_a=this.documentNode)||void 0===_a?void 0:_a.document.children.map((c=>lit_html_y`<option value=${c.id}>${c.name}</option>`))}
582
- </select>
583
- </div>
584
-
585
- <div class="view">${super.render()}</div>
586
- `}getMetadata(){return{fileName:this.documentNode.name,timestamp:this.documentNode.lastModified,link:this.link}}connectedCallback(){super.connectedCallback(),this.documentNode&&(FigspecFileViewer_classPrivateFieldGet(this,_selectFirstPage).call(this),this.selectedPage&&(this.__updateTree(this.selectedPage),this.resetZoom()))}updated(changedProperties){super.updated(changedProperties),changedProperties.has("documentNode")&&(FigspecFileViewer_classPrivateFieldGet(this,_selectFirstPage).call(this),this.selectedPage&&(this.__updateTree(this.selectedPage),this.resetZoom())),changedProperties.has("renderedImages")&&this.__updateEffectMargins()}}_selectFirstPage=new WeakMap,_handlePageChange=new WeakMap,FigspecFileViewer_decorate([property_e({type:Object,attribute:"document-node"})],FigspecFileViewer.prototype,"documentNode",void 0),FigspecFileViewer_decorate([property_e({type:Object,attribute:"rendered-images"})],FigspecFileViewer.prototype,"renderedImages",void 0),customElements.get("figspec-file-viewer")||customElements.define("figspec-file-viewer",FigspecFileViewer),customElements.get("figspec-frame-viewer")||customElements.define("figspec-frame-viewer",FigspecFrameViewer);const create_component_t=new Set(["children","localName","ref","style","className"]),create_component_e=new WeakMap,create_component_n=(t,n,s,i,o)=>{const l=null==o?void 0:o[n];void 0===l||s===i?null==s&&n in HTMLElement.prototype?t.removeAttribute(n):t[n]=s:((t,n,s)=>{let i=create_component_e.get(t);void 0===i&&create_component_e.set(t,i=new Map);let o=i.get(n);void 0!==s?void 0===o?(i.set(n,o={handleEvent:s}),t.addEventListener(n,o)):o.handleEvent=s:void 0!==o&&(i.delete(n),t.removeEventListener(n,o))})(t,l,s)};function create_component_s(e=window.React,s,i,o,l){let d,c,a;if(void 0===s){const t=e;({tagName:c,elementClass:a,events:o,displayName:l}=t),d=t.react}else d=e,a=i,c=s;const r=d.Component,h=d.createElement,u=new Set(Object.keys(null!=o?o:{}));class f extends r{constructor(){super(...arguments),this.o=null}t(t){if(null!==this.o)for(const e in this.i)create_component_n(this.o,e,this.props[e],t?t[e]:void 0,o)}componentDidMount(){this.t()}componentDidUpdate(t){this.t(t)}render(){const{_$Gl:e,...n}=this.props;this.h!==e&&(this.u=t=>{null!==e&&((t,e)=>{"function"==typeof t?t(e):t.current=e})(e,t),this.o=t,this.h=e}),this.i={};const s={ref:this.u};for(const[e,i]of Object.entries(n))create_component_t.has(e)?s["className"===e?"class":e]=i:u.has(e)||e in a.prototype?this.i[e]=i:s[e]=i;return h(c,s)}}f.displayName=null!=l?l:a.name;const v=d.forwardRef(((t,e)=>h(f,{...t,_$Gl:e},null==t?void 0:t.children)));return v.displayName=f.displayName,v}const es2015_FigspecFrameViewer=create_component_s(react_namespaceObject,"figspec-frame-viewer",FigspecFrameViewer,{onNodeSelect:"nodeselect",onPositionChange:"positionchange",onScaleChange:"scalechange"}),es2015_FigspecFileViewer=create_component_s(react_namespaceObject,"figspec-file-viewer",FigspecFileViewer,{onNodeSelect:"nodeselect",onPositionChange:"positionchange",onScaleChange:"scalechange"});var index_681e4b07=__webpack_require__(12898),esm=__webpack_require__(65316),Figma=__webpack_require__(38570),process=__webpack_require__(34155),__makeTemplateObject=function(cooked,raw){return Object.defineProperty?Object.defineProperty(cooked,"raw",{value:raw}):cooked.raw=raw,cooked},__assign=function(){return __assign=Object.assign||function(t){for(var s,i=1,n=arguments.length;i<n;i++)for(var p in s=arguments[i])Object.prototype.hasOwnProperty.call(s,p)&&(t[p]=s[p]);return t},__assign.apply(this,arguments)},Figspec_awaiter=function(thisArg,_arguments,P,generator){return new(P||(P=Promise))((function(resolve,reject){function fulfilled(value){try{step(generator.next(value))}catch(e){reject(e)}}function rejected(value){try{step(generator.throw(value))}catch(e){reject(e)}}function step(result){result.done?resolve(result.value):function adopt(value){return value instanceof P?value:new P((function(resolve){resolve(value)}))}(result.value).then(fulfilled,rejected)}step((generator=generator.apply(thisArg,_arguments||[])).next())}))},__generator=function(thisArg,body){var f,y,t,g,_={label:0,sent:function(){if(1&t[0])throw t[1];return t[1]},trys:[],ops:[]};return g={next:verb(0),throw:verb(1),return:verb(2)},"function"==typeof Symbol&&(g[Symbol.iterator]=function(){return this}),g;function verb(n){return function(v){return function step(op){if(f)throw new TypeError("Generator is already executing.");for(;_;)try{if(f=1,y&&(t=2&op[0]?y.return:op[0]?y.throw||((t=y.return)&&t.call(y),0):y.next)&&!(t=t.call(y,op[1])).done)return t;switch(y=0,t&&(op=[2&op[0],t.value]),op[0]){case 0:case 1:t=op;break;case 4:return _.label++,{value:op[1],done:!1};case 5:_.label++,y=op[1],op=[0];continue;case 7:op=_.ops.pop(),_.trys.pop();continue;default:if(!(t=_.trys,(t=t.length>0&&t[t.length-1])||6!==op[0]&&2!==op[0])){_=0;continue}if(3===op[0]&&(!t||op[1]>t[0]&&op[1]<t[3])){_.label=op[1];break}if(6===op[0]&&_.label<t[1]){_.label=t[1],t=op;break}if(t&&_.label<t[2]){_.label=t[2],_.ops.push(op);break}t[2]&&_.ops.pop(),_.trys.pop();continue}op=body.call(thisArg,_)}catch(e){op=[6,e],y=0}finally{f=t=0}if(5&op[0])throw op[1];return{value:op[0]?op[1]:void 0,done:!0}}([n,v])}}},fullscreen=(0,esm.iv)(templateObject_1||(templateObject_1=__makeTemplateObject(["\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n"],["\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n"])));function unwrapJson(res){return 200!==res.status?Promise.reject(res.statusText):res.json()}var Figspec=function(_a){var config=_a.config,_b=(0,react.useState)({state:"loading"}),state=_b[0],setState=_b[1],fetchDetails=function(signal){return Figspec_awaiter(void 0,void 0,void 0,(function(){var match,fileKey,url,nodeId,accessToken,headers,nodeUrl,imageUrl,documentNode,frames_1,images_1,_a,nodes,images,err_1;return __generator(this,(function(_b){switch(_b.label){case 0:setState({state:"loading"}),_b.label=1;case 1:if(_b.trys.push([1,6,,7]),!(match=config.url.match(Figma.sC)))throw new Error(config.url+" is not a valid Figma URL.");if(fileKey=match[3],url=new URL(config.url),nodeId=url.searchParams.get("node-id"),accessToken=function getAccessToken(cfg){var _a;if(cfg.accessToken)return cfg.accessToken;try{return null!==(_a=process.env.STORYBOOK_FIGMA_ACCESS_TOKEN)&&void 0!==_a?_a:null}catch(err){return null}}(config),!accessToken)throw new Error("Personal Access Token is required.");return headers={"X-FIGMA-TOKEN":accessToken},nodeUrl=new URL("https://api.figma.com/v1/files/"+fileKey),(imageUrl=new URL("https://api.figma.com/v1/images/"+fileKey)).searchParams.set("format","svg"),nodeId?[3,4]:[4,fetch(nodeUrl.href,{headers,signal}).then(unwrapJson)];case 2:return documentNode=_b.sent(),frames_1=listAllFrames(documentNode.document),imageUrl.searchParams.set("ids",frames_1.map((function(frame){return frame.id})).join(",")),[4,fetch(imageUrl.href,{headers,signal}).then(unwrapJson)];case 3:return images_1=_b.sent(),setState({state:"fetched",value:{type:"file",props:{documentNode,renderedImages:images_1.images,link:config.url}}}),[2];case 4:return nodeUrl.pathname+="/nodes",nodeUrl.searchParams.set("ids",nodeId),imageUrl.searchParams.set("ids",nodeId),[4,Promise.all([fetch(nodeUrl.href,{headers,signal}).then(unwrapJson),fetch(imageUrl.href,{headers,signal}).then(unwrapJson)])];case 5:return _a=_b.sent(),nodes=_a[0],images=_a[1],setState({state:"fetched",value:{type:"frame",props:{nodes,renderedImage:Object.values(images.images)[0],link:config.url}}}),[3,7];case 6:return(err_1=_b.sent())instanceof DOMException&&err_1.code===DOMException.ABORT_ERR?[2]:(console.error(err_1),setState({state:"failed",error:err_1 instanceof Error?err_1.message:String(err_1)}),[3,7]);case 7:return[2]}}))}))};switch((0,react.useEffect)((function(){var fulfilled=!1,fulfil=function(){fulfilled=!0},ac=new AbortController;return fetchDetails(ac.signal).then(fulfil,fulfil),function(){fulfilled||ac.abort()}}),[config.url]),state.state){case"loading":return(0,esm.tZ)(index_681e4b07.a7,null,(0,esm.tZ)(react.Fragment,null,"Loading Figma file..."));case"failed":return(0,esm.tZ)(index_681e4b07.a7,null,(0,esm.tZ)(react.Fragment,null,"Failed to load Figma file"),(0,esm.tZ)(react.Fragment,null,state.error));case"fetched":return"file"===state.value.type?(0,esm.tZ)(es2015_FigspecFileViewer,__assign({css:fullscreen},state.value.props)):(0,esm.tZ)(es2015_FigspecFrameViewer,__assign({css:fullscreen},state.value.props))}};const components_Figspec=Figspec;function listAllFrames(node){return"absoluteBoundingBox"in node?[node]:node.children&&0!==node.children.length?node.children.map(listAllFrames).flat():[]}var templateObject_1}}]);