placer-toolkit 0.5.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 (848) hide show
  1. package/LICENSE.md +9 -0
  2. package/README.md +66 -0
  3. package/dist/animations/attention_seekers/bounce.d.ts +16 -0
  4. package/dist/animations/attention_seekers/bounce.js +45 -0
  5. package/dist/animations/attention_seekers/flash.d.ts +4 -0
  6. package/dist/animations/attention_seekers/flash.js +9 -0
  7. package/dist/animations/attention_seekers/headShake.d.ts +4 -0
  8. package/dist/animations/attention_seekers/headShake.js +10 -0
  9. package/dist/animations/attention_seekers/heartBeat.d.ts +4 -0
  10. package/dist/animations/attention_seekers/heartBeat.js +9 -0
  11. package/dist/animations/attention_seekers/jello.d.ts +4 -0
  12. package/dist/animations/attention_seekers/jello.js +17 -0
  13. package/dist/animations/attention_seekers/pulse.d.ts +4 -0
  14. package/dist/animations/attention_seekers/pulse.js +7 -0
  15. package/dist/animations/attention_seekers/rubberBand.d.ts +4 -0
  16. package/dist/animations/attention_seekers/rubberBand.js +11 -0
  17. package/dist/animations/attention_seekers/shake.d.ts +4 -0
  18. package/dist/animations/attention_seekers/shake.js +15 -0
  19. package/dist/animations/attention_seekers/shakeX.d.ts +4 -0
  20. package/dist/animations/attention_seekers/shakeX.js +15 -0
  21. package/dist/animations/attention_seekers/shakeY.d.ts +4 -0
  22. package/dist/animations/attention_seekers/shakeY.js +15 -0
  23. package/dist/animations/attention_seekers/swing.d.ts +4 -0
  24. package/dist/animations/attention_seekers/swing.js +9 -0
  25. package/dist/animations/attention_seekers/tada.d.ts +4 -0
  26. package/dist/animations/attention_seekers/tada.js +42 -0
  27. package/dist/animations/attention_seekers/wobble.d.ts +4 -0
  28. package/dist/animations/attention_seekers/wobble.js +26 -0
  29. package/dist/animations/back_entrances/backInDown.d.ts +5 -0
  30. package/dist/animations/back_entrances/backInDown.js +7 -0
  31. package/dist/animations/back_entrances/backInLeft.d.ts +5 -0
  32. package/dist/animations/back_entrances/backInLeft.js +7 -0
  33. package/dist/animations/back_entrances/backInRight.d.ts +5 -0
  34. package/dist/animations/back_entrances/backInRight.js +7 -0
  35. package/dist/animations/back_entrances/backInUp.d.ts +5 -0
  36. package/dist/animations/back_entrances/backInUp.js +7 -0
  37. package/dist/animations/back_exits/backOutDown.d.ts +5 -0
  38. package/dist/animations/back_exits/backOutDown.js +7 -0
  39. package/dist/animations/back_exits/backOutLeft.d.ts +5 -0
  40. package/dist/animations/back_exits/backOutLeft.js +7 -0
  41. package/dist/animations/back_exits/backOutRight.d.ts +5 -0
  42. package/dist/animations/back_exits/backOutRight.js +7 -0
  43. package/dist/animations/back_exits/backOutUp.d.ts +5 -0
  44. package/dist/animations/back_exits/backOutUp.js +7 -0
  45. package/dist/animations/bouncing_entrances/bounceIn.d.ts +16 -0
  46. package/dist/animations/bouncing_entrances/bounceIn.js +16 -0
  47. package/dist/animations/bouncing_entrances/bounceInDown.d.ts +16 -0
  48. package/dist/animations/bouncing_entrances/bounceInDown.js +22 -0
  49. package/dist/animations/bouncing_entrances/bounceInLeft.d.ts +16 -0
  50. package/dist/animations/bouncing_entrances/bounceInLeft.js +22 -0
  51. package/dist/animations/bouncing_entrances/bounceInRight.d.ts +16 -0
  52. package/dist/animations/bouncing_entrances/bounceInRight.js +22 -0
  53. package/dist/animations/bouncing_entrances/bounceInUp.d.ts +16 -0
  54. package/dist/animations/bouncing_entrances/bounceInUp.js +22 -0
  55. package/dist/animations/bouncing_exits/bounceOut.d.ts +9 -0
  56. package/dist/animations/bouncing_exits/bounceOut.js +8 -0
  57. package/dist/animations/bouncing_exits/bounceOutDown.d.ts +9 -0
  58. package/dist/animations/bouncing_exits/bounceOutDown.js +20 -0
  59. package/dist/animations/bouncing_exits/bounceOutLeft.d.ts +5 -0
  60. package/dist/animations/bouncing_exits/bounceOutLeft.js +14 -0
  61. package/dist/animations/bouncing_exits/bounceOutRight.d.ts +5 -0
  62. package/dist/animations/bouncing_exits/bounceOutRight.js +14 -0
  63. package/dist/animations/bouncing_exits/bounceOutUp.d.ts +9 -0
  64. package/dist/animations/bouncing_exits/bounceOutUp.js +20 -0
  65. package/dist/animations/easings/easings.d.ts +31 -0
  66. package/dist/animations/easings/easings.js +33 -0
  67. package/dist/animations/fading_entrances/fadeIn.d.ts +4 -0
  68. package/dist/animations/fading_entrances/fadeIn.js +6 -0
  69. package/dist/animations/fading_entrances/fadeInBottomLeft.d.ts +5 -0
  70. package/dist/animations/fading_entrances/fadeInBottomLeft.js +6 -0
  71. package/dist/animations/fading_entrances/fadeInBottomRight.d.ts +5 -0
  72. package/dist/animations/fading_entrances/fadeInBottomRight.js +6 -0
  73. package/dist/animations/fading_entrances/fadeInDown.d.ts +5 -0
  74. package/dist/animations/fading_entrances/fadeInDown.js +6 -0
  75. package/dist/animations/fading_entrances/fadeInDownBig.d.ts +5 -0
  76. package/dist/animations/fading_entrances/fadeInDownBig.js +6 -0
  77. package/dist/animations/fading_entrances/fadeInLeft.d.ts +5 -0
  78. package/dist/animations/fading_entrances/fadeInLeft.js +6 -0
  79. package/dist/animations/fading_entrances/fadeInLeftBig.d.ts +5 -0
  80. package/dist/animations/fading_entrances/fadeInLeftBig.js +6 -0
  81. package/dist/animations/fading_entrances/fadeInRight.d.ts +5 -0
  82. package/dist/animations/fading_entrances/fadeInRight.js +6 -0
  83. package/dist/animations/fading_entrances/fadeInRightBig.d.ts +5 -0
  84. package/dist/animations/fading_entrances/fadeInRightBig.js +6 -0
  85. package/dist/animations/fading_entrances/fadeInTopLeft.d.ts +5 -0
  86. package/dist/animations/fading_entrances/fadeInTopLeft.js +6 -0
  87. package/dist/animations/fading_entrances/fadeInTopRight.d.ts +5 -0
  88. package/dist/animations/fading_entrances/fadeInTopRight.js +6 -0
  89. package/dist/animations/fading_entrances/fadeInUp.d.ts +5 -0
  90. package/dist/animations/fading_entrances/fadeInUp.js +6 -0
  91. package/dist/animations/fading_entrances/fadeInUpBig.d.ts +5 -0
  92. package/dist/animations/fading_entrances/fadeInUpBig.js +6 -0
  93. package/dist/animations/fading_exits/fadeOut.d.ts +4 -0
  94. package/dist/animations/fading_exits/fadeOut.js +6 -0
  95. package/dist/animations/fading_exits/fadeOutBottomLeft.d.ts +5 -0
  96. package/dist/animations/fading_exits/fadeOutBottomLeft.js +6 -0
  97. package/dist/animations/fading_exits/fadeOutBottomRight.d.ts +5 -0
  98. package/dist/animations/fading_exits/fadeOutBottomRight.js +6 -0
  99. package/dist/animations/fading_exits/fadeOutDown.d.ts +9 -0
  100. package/dist/animations/fading_exits/fadeOutDown.js +6 -0
  101. package/dist/animations/fading_exits/fadeOutDownBig.d.ts +9 -0
  102. package/dist/animations/fading_exits/fadeOutDownBig.js +6 -0
  103. package/dist/animations/fading_exits/fadeOutLeft.d.ts +9 -0
  104. package/dist/animations/fading_exits/fadeOutLeft.js +6 -0
  105. package/dist/animations/fading_exits/fadeOutLeftBig.d.ts +9 -0
  106. package/dist/animations/fading_exits/fadeOutLeftBig.js +6 -0
  107. package/dist/animations/fading_exits/fadeOutRight.d.ts +9 -0
  108. package/dist/animations/fading_exits/fadeOutRight.js +6 -0
  109. package/dist/animations/fading_exits/fadeOutRightBig.d.ts +9 -0
  110. package/dist/animations/fading_exits/fadeOutRightBig.js +6 -0
  111. package/dist/animations/fading_exits/fadeOutTopLeft.d.ts +5 -0
  112. package/dist/animations/fading_exits/fadeOutTopLeft.js +6 -0
  113. package/dist/animations/fading_exits/fadeOutTopRight.d.ts +5 -0
  114. package/dist/animations/fading_exits/fadeOutTopRight.js +6 -0
  115. package/dist/animations/fading_exits/fadeOutUp.d.ts +9 -0
  116. package/dist/animations/fading_exits/fadeOutUp.js +6 -0
  117. package/dist/animations/fading_exits/fadeOutUpBig.d.ts +9 -0
  118. package/dist/animations/fading_exits/fadeOutUpBig.js +6 -0
  119. package/dist/animations/flippers/flip.d.ts +5 -0
  120. package/dist/animations/flippers/flip.js +29 -0
  121. package/dist/animations/flippers/flipInX.d.ts +21 -0
  122. package/dist/animations/flippers/flipInX.js +22 -0
  123. package/dist/animations/flippers/flipInY.d.ts +21 -0
  124. package/dist/animations/flippers/flipInY.js +22 -0
  125. package/dist/animations/flippers/flipOutX.d.ts +9 -0
  126. package/dist/animations/flippers/flipOutX.js +15 -0
  127. package/dist/animations/flippers/flipOutY.d.ts +9 -0
  128. package/dist/animations/flippers/flipOutY.js +15 -0
  129. package/dist/animations/index.d.ts +99 -0
  130. package/dist/animations/index.js +101 -0
  131. package/dist/animations/lightspeed/lightSpeedInLeft.d.ts +9 -0
  132. package/dist/animations/lightspeed/lightSpeedInLeft.js +12 -0
  133. package/dist/animations/lightspeed/lightSpeedInRight.d.ts +9 -0
  134. package/dist/animations/lightspeed/lightSpeedInRight.js +12 -0
  135. package/dist/animations/lightspeed/lightSpeedOutLeft.d.ts +9 -0
  136. package/dist/animations/lightspeed/lightSpeedOutLeft.js +10 -0
  137. package/dist/animations/lightspeed/lightSpeedOutRight.d.ts +9 -0
  138. package/dist/animations/lightspeed/lightSpeedOutRight.js +10 -0
  139. package/dist/animations/rotating_entrances/rotateIn.d.ts +5 -0
  140. package/dist/animations/rotating_entrances/rotateIn.js +6 -0
  141. package/dist/animations/rotating_entrances/rotateInDownLeft.d.ts +5 -0
  142. package/dist/animations/rotating_entrances/rotateInDownLeft.js +6 -0
  143. package/dist/animations/rotating_entrances/rotateInDownRight.d.ts +5 -0
  144. package/dist/animations/rotating_entrances/rotateInDownRight.js +6 -0
  145. package/dist/animations/rotating_entrances/rotateInUpLeft.d.ts +5 -0
  146. package/dist/animations/rotating_entrances/rotateInUpLeft.js +6 -0
  147. package/dist/animations/rotating_entrances/rotateInUpRight.d.ts +5 -0
  148. package/dist/animations/rotating_entrances/rotateInUpRight.js +6 -0
  149. package/dist/animations/rotating_exits/rotateOut.d.ts +9 -0
  150. package/dist/animations/rotating_exits/rotateOut.js +6 -0
  151. package/dist/animations/rotating_exits/rotateOutDownLeft.d.ts +9 -0
  152. package/dist/animations/rotating_exits/rotateOutDownLeft.js +6 -0
  153. package/dist/animations/rotating_exits/rotateOutDownRight.d.ts +9 -0
  154. package/dist/animations/rotating_exits/rotateOutDownRight.js +6 -0
  155. package/dist/animations/rotating_exits/rotateOutUpLeft.d.ts +9 -0
  156. package/dist/animations/rotating_exits/rotateOutUpLeft.js +6 -0
  157. package/dist/animations/rotating_exits/rotateOutUpRight.d.ts +9 -0
  158. package/dist/animations/rotating_exits/rotateOutUpRight.js +6 -0
  159. package/dist/animations/sliding_entrances/slideInDown.d.ts +9 -0
  160. package/dist/animations/sliding_entrances/slideInDown.js +6 -0
  161. package/dist/animations/sliding_entrances/slideInLeft.d.ts +9 -0
  162. package/dist/animations/sliding_entrances/slideInLeft.js +6 -0
  163. package/dist/animations/sliding_entrances/slideInRight.d.ts +9 -0
  164. package/dist/animations/sliding_entrances/slideInRight.js +6 -0
  165. package/dist/animations/sliding_entrances/slideInUp.d.ts +9 -0
  166. package/dist/animations/sliding_entrances/slideInUp.js +6 -0
  167. package/dist/animations/sliding_exits/slideOutDown.d.ts +9 -0
  168. package/dist/animations/sliding_exits/slideOutDown.js +6 -0
  169. package/dist/animations/sliding_exits/slideOutLeft.d.ts +9 -0
  170. package/dist/animations/sliding_exits/slideOutLeft.js +6 -0
  171. package/dist/animations/sliding_exits/slideOutRight.d.ts +9 -0
  172. package/dist/animations/sliding_exits/slideOutRight.js +6 -0
  173. package/dist/animations/sliding_exits/slideOutUp.d.ts +9 -0
  174. package/dist/animations/sliding_exits/slideOutUp.js +6 -0
  175. package/dist/animations/specials/hinge.d.ts +21 -0
  176. package/dist/animations/specials/hinge.js +28 -0
  177. package/dist/animations/specials/jackInTheBox.d.ts +16 -0
  178. package/dist/animations/specials/jackInTheBox.js +13 -0
  179. package/dist/animations/specials/rollIn.d.ts +5 -0
  180. package/dist/animations/specials/rollIn.js +10 -0
  181. package/dist/animations/specials/rollOut.d.ts +9 -0
  182. package/dist/animations/specials/rollOut.js +10 -0
  183. package/dist/animations/zooming_entrances/zoomIn.d.ts +9 -0
  184. package/dist/animations/zooming_entrances/zoomIn.js +6 -0
  185. package/dist/animations/zooming_entrances/zoomInDown.d.ts +6 -0
  186. package/dist/animations/zooming_entrances/zoomInDown.js +16 -0
  187. package/dist/animations/zooming_entrances/zoomInLeft.d.ts +6 -0
  188. package/dist/animations/zooming_entrances/zoomInLeft.js +16 -0
  189. package/dist/animations/zooming_entrances/zoomInRight.d.ts +6 -0
  190. package/dist/animations/zooming_entrances/zoomInRight.js +16 -0
  191. package/dist/animations/zooming_entrances/zoomInUp.d.ts +6 -0
  192. package/dist/animations/zooming_entrances/zoomInUp.js +16 -0
  193. package/dist/animations/zooming_exits/zoomOut.d.ts +9 -0
  194. package/dist/animations/zooming_exits/zoomOut.js +7 -0
  195. package/dist/animations/zooming_exits/zoomOutDown.d.ts +6 -0
  196. package/dist/animations/zooming_exits/zoomOutDown.js +16 -0
  197. package/dist/animations/zooming_exits/zoomOutLeft.d.ts +5 -0
  198. package/dist/animations/zooming_exits/zoomOutLeft.js +14 -0
  199. package/dist/animations/zooming_exits/zoomOutRight.d.ts +5 -0
  200. package/dist/animations/zooming_exits/zoomOutRight.js +14 -0
  201. package/dist/animations/zooming_exits/zoomOutUp.d.ts +6 -0
  202. package/dist/animations/zooming_exits/zoomOutUp.js +16 -0
  203. package/dist/components/animation/animation.component.d.ts +65 -0
  204. package/dist/components/animation/animation.component.js +247 -0
  205. package/dist/components/animation/animation.d.ts +8 -0
  206. package/dist/components/animation/animation.js +5 -0
  207. package/dist/components/animation/animation.styles.d.ts +1 -0
  208. package/dist/components/animation/animation.styles.js +9 -0
  209. package/dist/components/animation/animations.d.ts +4 -0
  210. package/dist/components/animation/animations.js +13 -0
  211. package/dist/components/avatar/avatar.component.d.ts +43 -0
  212. package/dist/components/avatar/avatar.component.js +137 -0
  213. package/dist/components/avatar/avatar.d.ts +8 -0
  214. package/dist/components/avatar/avatar.js +5 -0
  215. package/dist/components/avatar/avatar.styles.d.ts +1 -0
  216. package/dist/components/avatar/avatar.styles.js +68 -0
  217. package/dist/components/badge/badge.component.d.ts +21 -0
  218. package/dist/components/badge/badge.component.js +64 -0
  219. package/dist/components/badge/badge.d.ts +8 -0
  220. package/dist/components/badge/badge.js +5 -0
  221. package/dist/components/badge/badge.styles.d.ts +1 -0
  222. package/dist/components/badge/badge.styles.js +76 -0
  223. package/dist/components/button/button.component.d.ts +104 -0
  224. package/dist/components/button/button.component.js +346 -0
  225. package/dist/components/button/button.d.ts +8 -0
  226. package/dist/components/button/button.js +5 -0
  227. package/dist/components/button/button.styles.d.ts +1 -0
  228. package/dist/components/button/button.styles.js +322 -0
  229. package/dist/components/button-group/button-group.component.d.ts +26 -0
  230. package/dist/components/button-group/button-group.component.js +93 -0
  231. package/dist/components/button-group/button-group.d.ts +8 -0
  232. package/dist/components/button-group/button-group.js +5 -0
  233. package/dist/components/button-group/button-group.styles.d.ts +1 -0
  234. package/dist/components/button-group/button-group.styles.js +14 -0
  235. package/dist/components/callout/callout.component.d.ts +22 -0
  236. package/dist/components/callout/callout.component.js +63 -0
  237. package/dist/components/callout/callout.d.ts +8 -0
  238. package/dist/components/callout/callout.js +5 -0
  239. package/dist/components/callout/callout.styles.d.ts +1 -0
  240. package/dist/components/callout/callout.styles.js +68 -0
  241. package/dist/components/card/card.component.d.ts +29 -0
  242. package/dist/components/card/card.component.js +59 -0
  243. package/dist/components/card/card.d.ts +8 -0
  244. package/dist/components/card/card.js +5 -0
  245. package/dist/components/card/card.styles.d.ts +1 -0
  246. package/dist/components/card/card.styles.js +65 -0
  247. package/dist/components/checkbox/checkbox.component.d.ts +44 -0
  248. package/dist/components/checkbox/checkbox.component.js +287 -0
  249. package/dist/components/checkbox/checkbox.d.ts +8 -0
  250. package/dist/components/checkbox/checkbox.js +5 -0
  251. package/dist/components/checkbox/checkbox.styles.d.ts +1 -0
  252. package/dist/components/checkbox/checkbox.styles.js +166 -0
  253. package/dist/components/comparer/comparer.component.d.ts +43 -0
  254. package/dist/components/comparer/comparer.component.js +181 -0
  255. package/dist/components/comparer/comparer.d.ts +8 -0
  256. package/dist/components/comparer/comparer.js +5 -0
  257. package/dist/components/comparer/comparer.styles.d.ts +1 -0
  258. package/dist/components/comparer/comparer.styles.js +75 -0
  259. package/dist/components/copy-button/copy-button.component.d.ts +75 -0
  260. package/dist/components/copy-button/copy-button.component.js +289 -0
  261. package/dist/components/copy-button/copy-button.d.ts +8 -0
  262. package/dist/components/copy-button/copy-button.js +5 -0
  263. package/dist/components/copy-button/copy-button.styles.d.ts +1 -0
  264. package/dist/components/copy-button/copy-button.styles.js +61 -0
  265. package/dist/components/details/details.component.d.ts +25 -0
  266. package/dist/components/details/details.component.js +243 -0
  267. package/dist/components/details/details.d.ts +8 -0
  268. package/dist/components/details/details.js +5 -0
  269. package/dist/components/details/details.styles.d.ts +1 -0
  270. package/dist/components/details/details.styles.js +86 -0
  271. package/dist/components/dialog/dialog.component.d.ts +84 -0
  272. package/dist/components/dialog/dialog.component.js +362 -0
  273. package/dist/components/dialog/dialog.d.ts +8 -0
  274. package/dist/components/dialog/dialog.js +5 -0
  275. package/dist/components/dialog/dialog.styles.d.ts +1 -0
  276. package/dist/components/dialog/dialog.styles.js +123 -0
  277. package/dist/components/divider/divider.component.d.ts +20 -0
  278. package/dist/components/divider/divider.component.js +51 -0
  279. package/dist/components/divider/divider.d.ts +8 -0
  280. package/dist/components/divider/divider.js +5 -0
  281. package/dist/components/divider/divider.styles.d.ts +1 -0
  282. package/dist/components/divider/divider.styles.js +29 -0
  283. package/dist/components/drawer/drawer.component.d.ts +95 -0
  284. package/dist/components/drawer/drawer.component.js +509 -0
  285. package/dist/components/drawer/drawer.d.ts +8 -0
  286. package/dist/components/drawer/drawer.js +5 -0
  287. package/dist/components/drawer/drawer.styles.d.ts +1 -0
  288. package/dist/components/drawer/drawer.styles.js +157 -0
  289. package/dist/components/dropdown/dropdown.component.d.ts +44 -0
  290. package/dist/components/dropdown/dropdown.component.js +385 -0
  291. package/dist/components/dropdown/dropdown.d.ts +8 -0
  292. package/dist/components/dropdown/dropdown.js +5 -0
  293. package/dist/components/dropdown/dropdown.styles.d.ts +1 -0
  294. package/dist/components/dropdown/dropdown.styles.js +52 -0
  295. package/dist/components/icon/icon.component.d.ts +47 -0
  296. package/dist/components/icon/icon.component.js +225 -0
  297. package/dist/components/icon/icon.d.ts +8 -0
  298. package/dist/components/icon/icon.js +5 -0
  299. package/dist/components/icon/icon.styles.d.ts +1 -0
  300. package/dist/components/icon/icon.styles.js +49 -0
  301. package/dist/components/icon/library.d.ts +14 -0
  302. package/dist/components/icon/library.default.d.ts +3 -0
  303. package/dist/components/icon/library.default.js +8 -0
  304. package/dist/components/icon/library.js +34 -0
  305. package/dist/components/icon/library.system.d.ts +3 -0
  306. package/dist/components/icon/library.system.js +130 -0
  307. package/dist/components/icon-button/icon-button.component.d.ts +27 -0
  308. package/dist/components/icon-button/icon-button.component.js +151 -0
  309. package/dist/components/icon-button/icon-button.d.ts +8 -0
  310. package/dist/components/icon-button/icon-button.js +5 -0
  311. package/dist/components/icon-button/icon-button.styles.d.ts +1 -0
  312. package/dist/components/icon-button/icon-button.styles.js +53 -0
  313. package/dist/components/input/input.component.d.ts +78 -0
  314. package/dist/components/input/input.component.js +513 -0
  315. package/dist/components/input/input.d.ts +8 -0
  316. package/dist/components/input/input.js +5 -0
  317. package/dist/components/input/input.styles.d.ts +1 -0
  318. package/dist/components/input/input.styles.js +308 -0
  319. package/dist/components/menu/menu.component.d.ts +20 -0
  320. package/dist/components/menu/menu.component.js +123 -0
  321. package/dist/components/menu/menu.d.ts +8 -0
  322. package/dist/components/menu/menu.js +5 -0
  323. package/dist/components/menu/menu.styles.d.ts +1 -0
  324. package/dist/components/menu/menu.styles.js +20 -0
  325. package/dist/components/menu-item/menu-item.component.d.ts +34 -0
  326. package/dist/components/menu-item/menu-item.component.js +211 -0
  327. package/dist/components/menu-item/menu-item.d.ts +8 -0
  328. package/dist/components/menu-item/menu-item.js +5 -0
  329. package/dist/components/menu-item/menu-item.styles.d.ts +1 -0
  330. package/dist/components/menu-item/menu-item.styles.js +157 -0
  331. package/dist/components/menu-item/submenu-controller.d.ts +34 -0
  332. package/dist/components/menu-item/submenu-controller.js +246 -0
  333. package/dist/components/menu-label/menu-label.component.d.ts +15 -0
  334. package/dist/components/menu-label/menu-label.component.js +25 -0
  335. package/dist/components/menu-label/menu-label.d.ts +8 -0
  336. package/dist/components/menu-label/menu-label.js +5 -0
  337. package/dist/components/menu-label/menu-label.styles.d.ts +1 -0
  338. package/dist/components/menu-label/menu-label.styles.js +22 -0
  339. package/dist/components/option/option.component.d.ts +42 -0
  340. package/dist/components/option/option.component.js +161 -0
  341. package/dist/components/option/option.d.ts +8 -0
  342. package/dist/components/option/option.js +5 -0
  343. package/dist/components/option/option.styles.d.ts +1 -0
  344. package/dist/components/option/option.styles.js +108 -0
  345. package/dist/components/popup/popup.component.d.ts +44 -0
  346. package/dist/components/popup/popup.component.js +483 -0
  347. package/dist/components/popup/popup.d.ts +8 -0
  348. package/dist/components/popup/popup.js +6 -0
  349. package/dist/components/popup/popup.styles.d.ts +1 -0
  350. package/dist/components/popup/popup.styles.js +64 -0
  351. package/dist/components/qr-code/qr-code.component.d.ts +16 -0
  352. package/dist/components/qr-code/qr-code.component.js +94 -0
  353. package/dist/components/qr-code/qr-code.d.ts +8 -0
  354. package/dist/components/qr-code/qr-code.js +5 -0
  355. package/dist/components/qr-code/qr-code.styles.d.ts +1 -0
  356. package/dist/components/qr-code/qr-code.styles.js +9 -0
  357. package/dist/components/radio/radio.component.d.ts +19 -0
  358. package/dist/components/radio/radio.component.js +120 -0
  359. package/dist/components/radio/radio.d.ts +8 -0
  360. package/dist/components/radio/radio.js +5 -0
  361. package/dist/components/radio/radio.styles.d.ts +1 -0
  362. package/dist/components/radio/radio.styles.js +132 -0
  363. package/dist/components/radio-button/radio-button.component.d.ts +22 -0
  364. package/dist/components/radio-button/radio-button.component.js +131 -0
  365. package/dist/components/radio-button/radio-button.d.ts +8 -0
  366. package/dist/components/radio-button/radio-button.js +5 -0
  367. package/dist/components/radio-button/radio-button.styles.d.ts +1 -0
  368. package/dist/components/radio-button/radio-button.styles.js +25 -0
  369. package/dist/components/radio-group/radio-group.component.d.ts +46 -0
  370. package/dist/components/radio-group/radio-group.component.js +379 -0
  371. package/dist/components/radio-group/radio-group.d.ts +8 -0
  372. package/dist/components/radio-group/radio-group.js +5 -0
  373. package/dist/components/radio-group/radio-group.styles.d.ts +1 -0
  374. package/dist/components/radio-group/radio-group.styles.js +42 -0
  375. package/dist/components/rating/rating.component.d.ts +37 -0
  376. package/dist/components/rating/rating.component.js +308 -0
  377. package/dist/components/rating/rating.d.ts +8 -0
  378. package/dist/components/rating/rating.js +5 -0
  379. package/dist/components/rating/rating.styles.d.ts +1 -0
  380. package/dist/components/rating/rating.styles.js +94 -0
  381. package/dist/components/resize-observer/resize-observer.component.d.ts +26 -0
  382. package/dist/components/resize-observer/resize-observer.component.js +89 -0
  383. package/dist/components/resize-observer/resize-observer.d.ts +8 -0
  384. package/dist/components/resize-observer/resize-observer.js +5 -0
  385. package/dist/components/resize-observer/resize-observer.styles.d.ts +1 -0
  386. package/dist/components/resize-observer/resize-observer.styles.js +9 -0
  387. package/dist/components/select/select.component.d.ts +174 -0
  388. package/dist/components/select/select.component.js +960 -0
  389. package/dist/components/select/select.d.ts +8 -0
  390. package/dist/components/select/select.js +5 -0
  391. package/dist/components/select/select.styles.d.ts +1 -0
  392. package/dist/components/select/select.styles.js +363 -0
  393. package/dist/components/spinner/spinner.component.d.ts +20 -0
  394. package/dist/components/spinner/spinner.component.js +47 -0
  395. package/dist/components/spinner/spinner.d.ts +8 -0
  396. package/dist/components/spinner/spinner.js +5 -0
  397. package/dist/components/spinner/spinner.styles.d.ts +1 -0
  398. package/dist/components/spinner/spinner.styles.js +61 -0
  399. package/dist/components/switch/switch.component.d.ts +84 -0
  400. package/dist/components/switch/switch.component.js +281 -0
  401. package/dist/components/switch/switch.d.ts +8 -0
  402. package/dist/components/switch/switch.js +5 -0
  403. package/dist/components/switch/switch.styles.d.ts +1 -0
  404. package/dist/components/switch/switch.styles.js +178 -0
  405. package/dist/components/tab/tab.component.d.ts +22 -0
  406. package/dist/components/tab/tab.component.js +112 -0
  407. package/dist/components/tab/tab.d.ts +8 -0
  408. package/dist/components/tab/tab.js +5 -0
  409. package/dist/components/tab/tab.styles.d.ts +1 -0
  410. package/dist/components/tab/tab.styles.js +85 -0
  411. package/dist/components/tab-group/tab-group.component.d.ts +51 -0
  412. package/dist/components/tab-group/tab-group.component.js +513 -0
  413. package/dist/components/tab-group/tab-group.d.ts +8 -0
  414. package/dist/components/tab-group/tab-group.js +5 -0
  415. package/dist/components/tab-group/tab-group.styles.d.ts +1 -0
  416. package/dist/components/tab-group/tab-group.styles.js +219 -0
  417. package/dist/components/tab-panel/tab-panel.component.d.ts +12 -0
  418. package/dist/components/tab-panel/tab-panel.component.js +56 -0
  419. package/dist/components/tab-panel/tab-panel.d.ts +8 -0
  420. package/dist/components/tab-panel/tab-panel.js +5 -0
  421. package/dist/components/tab-panel/tab-panel.styles.d.ts +1 -0
  422. package/dist/components/tab-panel/tab-panel.styles.js +18 -0
  423. package/dist/components/tag/tag.component.d.ts +38 -0
  424. package/dist/components/tag/tag.component.js +109 -0
  425. package/dist/components/tag/tag.d.ts +8 -0
  426. package/dist/components/tag/tag.js +5 -0
  427. package/dist/components/tag/tag.styles.d.ts +1 -0
  428. package/dist/components/tag/tag.styles.js +155 -0
  429. package/dist/components/tooltip/tooltip.component.d.ts +38 -0
  430. package/dist/components/tooltip/tooltip.component.js +267 -0
  431. package/dist/components/tooltip/tooltip.d.ts +8 -0
  432. package/dist/components/tooltip/tooltip.js +5 -0
  433. package/dist/components/tooltip/tooltip.styles.d.ts +1 -0
  434. package/dist/components/tooltip/tooltip.styles.js +59 -0
  435. package/dist/default.css +1005 -0
  436. package/dist/events/events.d.ts +33 -0
  437. package/dist/events/events.js +1 -0
  438. package/dist/events/pc-after-collapse.d.ts +6 -0
  439. package/dist/events/pc-after-collapse.js +1 -0
  440. package/dist/events/pc-after-expand.d.ts +6 -0
  441. package/dist/events/pc-after-expand.js +1 -0
  442. package/dist/events/pc-after-hide.d.ts +6 -0
  443. package/dist/events/pc-after-hide.js +1 -0
  444. package/dist/events/pc-after-show.d.ts +6 -0
  445. package/dist/events/pc-after-show.js +1 -0
  446. package/dist/events/pc-blur.d.ts +6 -0
  447. package/dist/events/pc-blur.js +1 -0
  448. package/dist/events/pc-cancel.d.ts +6 -0
  449. package/dist/events/pc-cancel.js +1 -0
  450. package/dist/events/pc-change.d.ts +6 -0
  451. package/dist/events/pc-change.js +1 -0
  452. package/dist/events/pc-clear.d.ts +6 -0
  453. package/dist/events/pc-clear.js +1 -0
  454. package/dist/events/pc-close.d.ts +6 -0
  455. package/dist/events/pc-close.js +1 -0
  456. package/dist/events/pc-collapse.d.ts +6 -0
  457. package/dist/events/pc-collapse.js +1 -0
  458. package/dist/events/pc-copy.d.ts +8 -0
  459. package/dist/events/pc-copy.js +1 -0
  460. package/dist/events/pc-error.d.ts +8 -0
  461. package/dist/events/pc-error.js +1 -0
  462. package/dist/events/pc-expand.d.ts +6 -0
  463. package/dist/events/pc-expand.js +1 -0
  464. package/dist/events/pc-finish.d.ts +6 -0
  465. package/dist/events/pc-finish.js +1 -0
  466. package/dist/events/pc-focus.d.ts +6 -0
  467. package/dist/events/pc-focus.js +1 -0
  468. package/dist/events/pc-hide.d.ts +6 -0
  469. package/dist/events/pc-hide.js +1 -0
  470. package/dist/events/pc-hover.d.ts +9 -0
  471. package/dist/events/pc-hover.js +1 -0
  472. package/dist/events/pc-initial-focus.d.ts +6 -0
  473. package/dist/events/pc-initial-focus.js +1 -0
  474. package/dist/events/pc-input.d.ts +6 -0
  475. package/dist/events/pc-input.js +1 -0
  476. package/dist/events/pc-invalid.d.ts +6 -0
  477. package/dist/events/pc-invalid.js +1 -0
  478. package/dist/events/pc-lazy-change.d.ts +6 -0
  479. package/dist/events/pc-lazy-change.js +1 -0
  480. package/dist/events/pc-lazy-load.d.ts +6 -0
  481. package/dist/events/pc-lazy-load.js +1 -0
  482. package/dist/events/pc-load.d.ts +6 -0
  483. package/dist/events/pc-load.js +1 -0
  484. package/dist/events/pc-mutation.d.ts +8 -0
  485. package/dist/events/pc-mutation.js +1 -0
  486. package/dist/events/pc-remove.d.ts +6 -0
  487. package/dist/events/pc-remove.js +1 -0
  488. package/dist/events/pc-reposition.d.ts +6 -0
  489. package/dist/events/pc-reposition.js +1 -0
  490. package/dist/events/pc-request-close.d.ts +8 -0
  491. package/dist/events/pc-request-close.js +1 -0
  492. package/dist/events/pc-resize.d.ts +8 -0
  493. package/dist/events/pc-resize.js +1 -0
  494. package/dist/events/pc-select.d.ts +9 -0
  495. package/dist/events/pc-select.js +1 -0
  496. package/dist/events/pc-selection-change.js +1 -0
  497. package/dist/events/pc-show.d.ts +6 -0
  498. package/dist/events/pc-show.js +1 -0
  499. package/dist/events/pc-slide-change.js +1 -0
  500. package/dist/events/pc-start.d.ts +6 -0
  501. package/dist/events/pc-start.js +1 -0
  502. package/dist/events/pc-tab-hide.d.ts +8 -0
  503. package/dist/events/pc-tab-hide.js +1 -0
  504. package/dist/events/pc-tab-show.d.ts +8 -0
  505. package/dist/events/pc-tab-show.js +1 -0
  506. package/dist/global-shims.d.ts +18 -0
  507. package/dist/global-shims.js +96 -0
  508. package/dist/internal/active-elements.d.ts +2 -0
  509. package/dist/internal/active-elements.js +16 -0
  510. package/dist/internal/animate.d.ts +10 -0
  511. package/dist/internal/animate.js +45 -0
  512. package/dist/internal/close-active-element.d.ts +1 -0
  513. package/dist/internal/close-active-element.js +8 -0
  514. package/dist/internal/debounce.d.ts +1 -0
  515. package/dist/internal/debounce.js +14 -0
  516. package/dist/internal/default-value.d.ts +2 -0
  517. package/dist/internal/default-value.js +26 -0
  518. package/dist/internal/drag.d.ts +7 -0
  519. package/dist/internal/drag.js +27 -0
  520. package/dist/internal/emit.d.ts +1 -0
  521. package/dist/internal/emit.js +14 -0
  522. package/dist/internal/event.d.ts +1 -0
  523. package/dist/internal/event.js +13 -0
  524. package/dist/internal/form.d.ts +41 -0
  525. package/dist/internal/form.js +282 -0
  526. package/dist/internal/math.d.ts +1 -0
  527. package/dist/internal/math.js +12 -0
  528. package/dist/internal/modal.d.ts +19 -0
  529. package/dist/internal/modal.js +116 -0
  530. package/dist/internal/offset.d.ts +4 -0
  531. package/dist/internal/offset.js +10 -0
  532. package/dist/internal/scroll.d.ts +3 -0
  533. package/dist/internal/scroll.js +70 -0
  534. package/dist/internal/scrollend-polyfill.d.ts +1 -0
  535. package/dist/internal/scrollend-polyfill.js +65 -0
  536. package/dist/internal/slot.d.ts +14 -0
  537. package/dist/internal/slot.js +75 -0
  538. package/dist/internal/string.d.ts +1 -0
  539. package/dist/internal/string.js +5 -0
  540. package/dist/internal/tabbable.d.ts +5 -0
  541. package/dist/internal/tabbable.js +145 -0
  542. package/dist/internal/watch.d.ts +11 -0
  543. package/dist/internal/watch.js +32 -0
  544. package/dist/native-styles.css +261 -0
  545. package/dist/placer-autoloader.d.ts +1 -0
  546. package/dist/placer-autoloader.js +41 -0
  547. package/dist/placer.d.ts +44 -0
  548. package/dist/placer.js +43 -0
  549. package/dist/style-utilities/fouce.css +13 -0
  550. package/dist/style-utilities/style-utilities.css +2 -0
  551. package/dist/style-utilities/visually-hidden.css +12 -0
  552. package/dist/utilities/animation-registry.d.ts +14 -0
  553. package/dist/utilities/animation-registry.js +39 -0
  554. package/dist/utilities/animation.d.ts +1 -0
  555. package/dist/utilities/animation.js +1 -0
  556. package/dist/utilities/base-path.d.ts +2 -0
  557. package/dist/utilities/base-path.js +8 -0
  558. package/dist/utilities/form.d.ts +2 -0
  559. package/dist/utilities/form.js +39 -0
  560. package/dist/utilities/icon-library.d.ts +1 -0
  561. package/dist/utilities/icon-library.js +1 -0
  562. package/dist/utility.css +41 -0
  563. package/package.json +82 -0
  564. package/src/animations/attention_seekers/bounce.ts +43 -0
  565. package/src/animations/attention_seekers/flash.ts +7 -0
  566. package/src/animations/attention_seekers/headShake.ts +8 -0
  567. package/src/animations/attention_seekers/heartBeat.ts +7 -0
  568. package/src/animations/attention_seekers/jello.ts +15 -0
  569. package/src/animations/attention_seekers/pulse.ts +5 -0
  570. package/src/animations/attention_seekers/rubberBand.ts +9 -0
  571. package/src/animations/attention_seekers/shake.ts +13 -0
  572. package/src/animations/attention_seekers/shakeX.ts +13 -0
  573. package/src/animations/attention_seekers/shakeY.ts +13 -0
  574. package/src/animations/attention_seekers/swing.ts +7 -0
  575. package/src/animations/attention_seekers/tada.ts +40 -0
  576. package/src/animations/attention_seekers/wobble.ts +24 -0
  577. package/src/animations/back_entrances/backInDown.ts +5 -0
  578. package/src/animations/back_entrances/backInLeft.ts +5 -0
  579. package/src/animations/back_entrances/backInRight.ts +5 -0
  580. package/src/animations/back_entrances/backInUp.ts +5 -0
  581. package/src/animations/back_exits/backOutDown.ts +5 -0
  582. package/src/animations/back_exits/backOutLeft.ts +5 -0
  583. package/src/animations/back_exits/backOutRight.ts +5 -0
  584. package/src/animations/back_exits/backOutUp.ts +5 -0
  585. package/src/animations/bouncing_entrances/bounceIn.ts +14 -0
  586. package/src/animations/bouncing_entrances/bounceInDown.ts +20 -0
  587. package/src/animations/bouncing_entrances/bounceInLeft.ts +20 -0
  588. package/src/animations/bouncing_entrances/bounceInRight.ts +20 -0
  589. package/src/animations/bouncing_entrances/bounceInUp.ts +20 -0
  590. package/src/animations/bouncing_exits/bounceOut.ts +6 -0
  591. package/src/animations/bouncing_exits/bounceOutDown.ts +18 -0
  592. package/src/animations/bouncing_exits/bounceOutLeft.ts +12 -0
  593. package/src/animations/bouncing_exits/bounceOutRight.ts +12 -0
  594. package/src/animations/bouncing_exits/bounceOutUp.ts +18 -0
  595. package/src/animations/easings/easings.ts +31 -0
  596. package/src/animations/fading_entrances/fadeIn.ts +4 -0
  597. package/src/animations/fading_entrances/fadeInBottomLeft.ts +4 -0
  598. package/src/animations/fading_entrances/fadeInBottomRight.ts +4 -0
  599. package/src/animations/fading_entrances/fadeInDown.ts +4 -0
  600. package/src/animations/fading_entrances/fadeInDownBig.ts +4 -0
  601. package/src/animations/fading_entrances/fadeInLeft.ts +4 -0
  602. package/src/animations/fading_entrances/fadeInLeftBig.ts +4 -0
  603. package/src/animations/fading_entrances/fadeInRight.ts +4 -0
  604. package/src/animations/fading_entrances/fadeInRightBig.ts +4 -0
  605. package/src/animations/fading_entrances/fadeInTopLeft.ts +4 -0
  606. package/src/animations/fading_entrances/fadeInTopRight.ts +4 -0
  607. package/src/animations/fading_entrances/fadeInUp.ts +4 -0
  608. package/src/animations/fading_entrances/fadeInUpBig.ts +4 -0
  609. package/src/animations/fading_exits/fadeOut.ts +4 -0
  610. package/src/animations/fading_exits/fadeOutBottomLeft.ts +4 -0
  611. package/src/animations/fading_exits/fadeOutBottomRight.ts +4 -0
  612. package/src/animations/fading_exits/fadeOutDown.ts +4 -0
  613. package/src/animations/fading_exits/fadeOutDownBig.ts +4 -0
  614. package/src/animations/fading_exits/fadeOutLeft.ts +4 -0
  615. package/src/animations/fading_exits/fadeOutLeftBig.ts +4 -0
  616. package/src/animations/fading_exits/fadeOutRight.ts +4 -0
  617. package/src/animations/fading_exits/fadeOutRightBig.ts +4 -0
  618. package/src/animations/fading_exits/fadeOutTopLeft.ts +4 -0
  619. package/src/animations/fading_exits/fadeOutTopRight.ts +4 -0
  620. package/src/animations/fading_exits/fadeOutUp.ts +4 -0
  621. package/src/animations/fading_exits/fadeOutUpBig.ts +4 -0
  622. package/src/animations/flippers/flip.ts +32 -0
  623. package/src/animations/flippers/flipInX.ts +20 -0
  624. package/src/animations/flippers/flipInY.ts +20 -0
  625. package/src/animations/flippers/flipOutX.ts +13 -0
  626. package/src/animations/flippers/flipOutY.ts +13 -0
  627. package/src/animations/index.ts +101 -0
  628. package/src/animations/lightspeed/lightSpeedInLeft.ts +10 -0
  629. package/src/animations/lightspeed/lightSpeedInRight.ts +10 -0
  630. package/src/animations/lightspeed/lightSpeedOutLeft.ts +8 -0
  631. package/src/animations/lightspeed/lightSpeedOutRight.ts +8 -0
  632. package/src/animations/rotating_entrances/rotateIn.ts +4 -0
  633. package/src/animations/rotating_entrances/rotateInDownLeft.ts +4 -0
  634. package/src/animations/rotating_entrances/rotateInDownRight.ts +4 -0
  635. package/src/animations/rotating_entrances/rotateInUpLeft.ts +4 -0
  636. package/src/animations/rotating_entrances/rotateInUpRight.ts +4 -0
  637. package/src/animations/rotating_exits/rotateOut.ts +4 -0
  638. package/src/animations/rotating_exits/rotateOutDownLeft.ts +4 -0
  639. package/src/animations/rotating_exits/rotateOutDownRight.ts +4 -0
  640. package/src/animations/rotating_exits/rotateOutUpLeft.ts +4 -0
  641. package/src/animations/rotating_exits/rotateOutUpRight.ts +4 -0
  642. package/src/animations/sliding_entrances/slideInDown.ts +4 -0
  643. package/src/animations/sliding_entrances/slideInLeft.ts +4 -0
  644. package/src/animations/sliding_entrances/slideInRight.ts +4 -0
  645. package/src/animations/sliding_entrances/slideInUp.ts +4 -0
  646. package/src/animations/sliding_exits/slideOutDown.ts +4 -0
  647. package/src/animations/sliding_exits/slideOutLeft.ts +4 -0
  648. package/src/animations/sliding_exits/slideOutRight.ts +4 -0
  649. package/src/animations/sliding_exits/slideOutUp.ts +4 -0
  650. package/src/animations/specials/hinge.ts +26 -0
  651. package/src/animations/specials/jackInTheBox.ts +11 -0
  652. package/src/animations/specials/rollIn.ts +8 -0
  653. package/src/animations/specials/rollOut.ts +8 -0
  654. package/src/animations/zooming_entrances/zoomIn.ts +4 -0
  655. package/src/animations/zooming_entrances/zoomInDown.ts +14 -0
  656. package/src/animations/zooming_entrances/zoomInLeft.ts +14 -0
  657. package/src/animations/zooming_entrances/zoomInRight.ts +14 -0
  658. package/src/animations/zooming_entrances/zoomInUp.ts +14 -0
  659. package/src/animations/zooming_exits/zoomOut.ts +5 -0
  660. package/src/animations/zooming_exits/zoomOutDown.ts +14 -0
  661. package/src/animations/zooming_exits/zoomOutLeft.ts +12 -0
  662. package/src/animations/zooming_exits/zoomOutRight.ts +12 -0
  663. package/src/animations/zooming_exits/zoomOutUp.ts +14 -0
  664. package/src/components/animation/animation.component.ts +224 -0
  665. package/src/components/animation/animation.styles.ts +7 -0
  666. package/src/components/animation/animation.ts +10 -0
  667. package/src/components/animation/animations.ts +13 -0
  668. package/src/components/avatar/avatar.component.ts +113 -0
  669. package/src/components/avatar/avatar.styles.ts +66 -0
  670. package/src/components/avatar/avatar.ts +10 -0
  671. package/src/components/badge/badge.component.ts +54 -0
  672. package/src/components/badge/badge.styles.ts +74 -0
  673. package/src/components/badge/badge.ts +10 -0
  674. package/src/components/button/button.component.ts +335 -0
  675. package/src/components/button/button.styles.ts +320 -0
  676. package/src/components/button/button.ts +10 -0
  677. package/src/components/button-group/button-group.component.ts +101 -0
  678. package/src/components/button-group/button-group.styles.ts +12 -0
  679. package/src/components/button-group/button-group.ts +10 -0
  680. package/src/components/callout/callout.component.ts +60 -0
  681. package/src/components/callout/callout.styles.ts +66 -0
  682. package/src/components/callout/callout.ts +10 -0
  683. package/src/components/card/card.component.ts +59 -0
  684. package/src/components/card/card.styles.ts +63 -0
  685. package/src/components/card/card.ts +10 -0
  686. package/src/components/checkbox/checkbox.component.ts +244 -0
  687. package/src/components/checkbox/checkbox.styles.ts +164 -0
  688. package/src/components/checkbox/checkbox.ts +10 -0
  689. package/src/components/comparer/comparer.component.ts +188 -0
  690. package/src/components/comparer/comparer.styles.ts +73 -0
  691. package/src/components/comparer/comparer.ts +10 -0
  692. package/src/components/copy-button/copy-button.component.ts +272 -0
  693. package/src/components/copy-button/copy-button.styles.ts +59 -0
  694. package/src/components/copy-button/copy-button.ts +10 -0
  695. package/src/components/details/details.component.ts +259 -0
  696. package/src/components/details/details.styles.ts +84 -0
  697. package/src/components/details/details.ts +10 -0
  698. package/src/components/dialog/dialog.component.ts +403 -0
  699. package/src/components/dialog/dialog.styles.ts +121 -0
  700. package/src/components/dialog/dialog.ts +10 -0
  701. package/src/components/divider/divider.component.ts +42 -0
  702. package/src/components/divider/divider.styles.ts +27 -0
  703. package/src/components/divider/divider.ts +10 -0
  704. package/src/components/drawer/drawer.component.ts +565 -0
  705. package/src/components/drawer/drawer.styles.ts +155 -0
  706. package/src/components/drawer/drawer.ts +10 -0
  707. package/src/components/dropdown/dropdown.component.ts +430 -0
  708. package/src/components/dropdown/dropdown.styles.ts +50 -0
  709. package/src/components/dropdown/dropdown.ts +10 -0
  710. package/src/components/icon/icon.component.ts +239 -0
  711. package/src/components/icon/icon.styles.ts +47 -0
  712. package/src/components/icon/icon.ts +10 -0
  713. package/src/components/icon/library.default.ts +10 -0
  714. package/src/components/icon/library.system.ts +136 -0
  715. package/src/components/icon/library.ts +54 -0
  716. package/src/components/icon-button/icon-button.component.ts +129 -0
  717. package/src/components/icon-button/icon-button.styles.ts +51 -0
  718. package/src/components/icon-button/icon-button.ts +10 -0
  719. package/src/components/input/input.component.ts +496 -0
  720. package/src/components/input/input.styles.ts +306 -0
  721. package/src/components/input/input.ts +10 -0
  722. package/src/components/menu/menu.component.ts +161 -0
  723. package/src/components/menu/menu.styles.ts +18 -0
  724. package/src/components/menu/menu.ts +10 -0
  725. package/src/components/menu-item/menu-item.component.ts +190 -0
  726. package/src/components/menu-item/menu-item.styles.ts +155 -0
  727. package/src/components/menu-item/menu-item.ts +10 -0
  728. package/src/components/menu-item/submenu-controller.ts +337 -0
  729. package/src/components/menu-label/menu-label.component.ts +22 -0
  730. package/src/components/menu-label/menu-label.styles.ts +20 -0
  731. package/src/components/menu-label/menu-label.ts +10 -0
  732. package/src/components/option/option.component.ts +141 -0
  733. package/src/components/option/option.styles.ts +106 -0
  734. package/src/components/option/option.ts +10 -0
  735. package/src/components/popup/popup.component.ts +540 -0
  736. package/src/components/popup/popup.styles.ts +63 -0
  737. package/src/components/popup/popup.ts +12 -0
  738. package/src/components/qr-code/qr-code.component.ts +70 -0
  739. package/src/components/qr-code/qr-code.styles.ts +7 -0
  740. package/src/components/qr-code/qr-code.ts +10 -0
  741. package/src/components/radio/radio.component.ts +100 -0
  742. package/src/components/radio/radio.styles.ts +130 -0
  743. package/src/components/radio/radio.ts +10 -0
  744. package/src/components/radio-button/radio-button.component.ts +116 -0
  745. package/src/components/radio-button/radio-button.styles.ts +23 -0
  746. package/src/components/radio-button/radio-button.ts +10 -0
  747. package/src/components/radio-group/radio-group.component.ts +404 -0
  748. package/src/components/radio-group/radio-group.styles.ts +40 -0
  749. package/src/components/radio-group/radio-group.ts +10 -0
  750. package/src/components/rating/rating.component.ts +319 -0
  751. package/src/components/rating/rating.styles.ts +92 -0
  752. package/src/components/rating/rating.ts +10 -0
  753. package/src/components/resize-observer/resize-observer.component.ts +91 -0
  754. package/src/components/resize-observer/resize-observer.styles.ts +7 -0
  755. package/src/components/resize-observer/resize-observer.ts +10 -0
  756. package/src/components/select/select.component.ts +1013 -0
  757. package/src/components/select/select.styles.ts +361 -0
  758. package/src/components/select/select.ts +10 -0
  759. package/src/components/spinner/spinner.component.ts +38 -0
  760. package/src/components/spinner/spinner.styles.ts +59 -0
  761. package/src/components/spinner/spinner.ts +10 -0
  762. package/src/components/switch/switch.component.ts +253 -0
  763. package/src/components/switch/switch.styles.ts +176 -0
  764. package/src/components/switch/switch.ts +10 -0
  765. package/src/components/tab/tab.component.ts +87 -0
  766. package/src/components/tab/tab.styles.ts +83 -0
  767. package/src/components/tab/tab.ts +10 -0
  768. package/src/components/tab-group/tab-group.component.ts +607 -0
  769. package/src/components/tab-group/tab-group.styles.ts +217 -0
  770. package/src/components/tab-group/tab-group.ts +10 -0
  771. package/src/components/tab-panel/tab-panel.component.ts +43 -0
  772. package/src/components/tab-panel/tab-panel.styles.ts +16 -0
  773. package/src/components/tab-panel/tab-panel.ts +10 -0
  774. package/src/components/tag/tag.component.ts +94 -0
  775. package/src/components/tag/tag.styles.ts +153 -0
  776. package/src/components/tag/tag.ts +10 -0
  777. package/src/components/tooltip/tooltip.component.ts +276 -0
  778. package/src/components/tooltip/tooltip.styles.ts +57 -0
  779. package/src/components/tooltip/tooltip.ts +10 -0
  780. package/src/default.css +1005 -0
  781. package/src/events/events.ts +35 -0
  782. package/src/events/pc-after-collapse.ts +7 -0
  783. package/src/events/pc-after-expand.ts +7 -0
  784. package/src/events/pc-after-hide.ts +7 -0
  785. package/src/events/pc-after-show.ts +7 -0
  786. package/src/events/pc-blur.ts +7 -0
  787. package/src/events/pc-cancel.ts +7 -0
  788. package/src/events/pc-change.ts +7 -0
  789. package/src/events/pc-clear.ts +7 -0
  790. package/src/events/pc-close.ts +7 -0
  791. package/src/events/pc-collapse.ts +7 -0
  792. package/src/events/pc-copy.ts +7 -0
  793. package/src/events/pc-error.ts +7 -0
  794. package/src/events/pc-expand.ts +7 -0
  795. package/src/events/pc-finish.ts +7 -0
  796. package/src/events/pc-focus.ts +7 -0
  797. package/src/events/pc-hide.ts +7 -0
  798. package/src/events/pc-hover.ts +10 -0
  799. package/src/events/pc-initial-focus.ts +7 -0
  800. package/src/events/pc-input.ts +7 -0
  801. package/src/events/pc-invalid.ts +7 -0
  802. package/src/events/pc-lazy-change.ts +7 -0
  803. package/src/events/pc-lazy-load.ts +7 -0
  804. package/src/events/pc-load.ts +7 -0
  805. package/src/events/pc-mutation.ts +7 -0
  806. package/src/events/pc-remove.ts +7 -0
  807. package/src/events/pc-reposition.ts +7 -0
  808. package/src/events/pc-request-close.ts +9 -0
  809. package/src/events/pc-resize.ts +7 -0
  810. package/src/events/pc-select.ts +9 -0
  811. package/src/events/pc-selection-change.ts +10 -0
  812. package/src/events/pc-show.ts +7 -0
  813. package/src/events/pc-slide-change.ts +13 -0
  814. package/src/events/pc-start.ts +7 -0
  815. package/src/events/pc-tab-hide.ts +7 -0
  816. package/src/events/pc-tab-show.ts +7 -0
  817. package/src/global-shims.ts +126 -0
  818. package/src/global.d.ts +31 -0
  819. package/src/internal/active-elements.ts +21 -0
  820. package/src/internal/animate.ts +62 -0
  821. package/src/internal/close-active-element.ts +7 -0
  822. package/src/internal/debounce.ts +25 -0
  823. package/src/internal/default-value.ts +40 -0
  824. package/src/internal/drag.ts +36 -0
  825. package/src/internal/emit.ts +19 -0
  826. package/src/internal/event.ts +12 -0
  827. package/src/internal/form.ts +389 -0
  828. package/src/internal/math.ts +14 -0
  829. package/src/internal/modal.ts +157 -0
  830. package/src/internal/offset.ts +12 -0
  831. package/src/internal/scroll.ts +95 -0
  832. package/src/internal/scrollend-polyfill.ts +99 -0
  833. package/src/internal/slot.ts +110 -0
  834. package/src/internal/string.ts +3 -0
  835. package/src/internal/tabbable.ts +207 -0
  836. package/src/internal/watch.ts +58 -0
  837. package/src/native-styles.css +261 -0
  838. package/src/placer-autoloader.ts +53 -0
  839. package/src/placer.ts +53 -0
  840. package/src/style-utilities/fouce.css +13 -0
  841. package/src/style-utilities/style-utilities.css +2 -0
  842. package/src/style-utilities/visually-hidden.css +12 -0
  843. package/src/utilities/animation-registry.ts +72 -0
  844. package/src/utilities/animation.ts +4 -0
  845. package/src/utilities/base-path.ts +39 -0
  846. package/src/utilities/form.ts +41 -0
  847. package/src/utilities/icon-library.ts +4 -0
  848. package/src/utility.css +41 -0
@@ -0,0 +1,43 @@
1
+ import { LitElement } from "lit";
2
+ import type { CSSResultGroup } from "lit";
3
+ import { PcIcon } from "../icon/icon.js";
4
+ /**
5
+ * @summary Compare visual differences between similar content with a sliding panel.
6
+ * @status experimental
7
+ * @since 0.5.1
8
+ *
9
+ * @dependency pc-icon
10
+ *
11
+ * @slot before — The before content, often an `<img>` or `<svg>` element.
12
+ * @slot after — The after content, often an `<img>` or `<svg>` element.
13
+ * @slot handle — The icon used inside the handle.
14
+ *
15
+ * @event pc-change — Emitted when the position of the handle changes.
16
+ *
17
+ * @csspart base — The component’s base wrapper.
18
+ * @csspart before — The container that wraps the before content.
19
+ * @csspart after — The container that wraps the after content.
20
+ * @csspart divider — The divider that separates both sides.
21
+ * @csspart handle — The handle that the user drags to expose the after content.
22
+ *
23
+ * @cssproperty --divider-width — The width of the dividing line.
24
+ * @cssproperty --handle-size — The size of the compare handle.
25
+ */
26
+ export declare class PcComparer extends LitElement {
27
+ static styles: CSSResultGroup;
28
+ /** @internal This is an internal property. */
29
+ static scopedElement: {
30
+ "pc-icon": typeof PcIcon;
31
+ };
32
+ /** @internal This is an internal property. */
33
+ base: HTMLElement;
34
+ /** @internal This is an internal property. */
35
+ handle: HTMLElement;
36
+ /** The position of the divider as a percentage. */
37
+ position: number;
38
+ private handleDrag;
39
+ private handleKeyDown;
40
+ /** @internal This is an internal property. */
41
+ handlePositionChange(): void;
42
+ render(): import("lit-html").TemplateResult<1>;
43
+ }
@@ -0,0 +1,181 @@
1
+ import { __decorate, __metadata } from 'tslib';
2
+ import { LitElement, html } from 'lit';
3
+ import { query, property, customElement } from 'lit/decorators.js';
4
+ import { classMap } from 'lit/directives/class-map.js';
5
+ import { styleMap } from 'lit/directives/style-map.js';
6
+ import { clamp } from '../../internal/math.js';
7
+ import { drag } from '../../internal/drag.js';
8
+ import { watch } from '../../internal/watch.js';
9
+ import { emit } from '../../internal/emit.js';
10
+ import { PcIcon } from '../icon/icon.component.js';
11
+ import { styles } from './comparer.styles.js';
12
+
13
+ /**
14
+ * @summary Compare visual differences between similar content with a sliding panel.
15
+ * @status experimental
16
+ * @since 0.5.1
17
+ *
18
+ * @dependency pc-icon
19
+ *
20
+ * @slot before — The before content, often an `<img>` or `<svg>` element.
21
+ * @slot after — The after content, often an `<img>` or `<svg>` element.
22
+ * @slot handle — The icon used inside the handle.
23
+ *
24
+ * @event pc-change — Emitted when the position of the handle changes.
25
+ *
26
+ * @csspart base — The component’s base wrapper.
27
+ * @csspart before — The container that wraps the before content.
28
+ * @csspart after — The container that wraps the after content.
29
+ * @csspart divider — The divider that separates both sides.
30
+ * @csspart handle — The handle that the user drags to expose the after content.
31
+ *
32
+ * @cssproperty --divider-width — The width of the dividing line.
33
+ * @cssproperty --handle-size — The size of the compare handle.
34
+ */
35
+ let PcComparer = class PcComparer extends LitElement {
36
+ constructor() {
37
+ super(...arguments);
38
+ /** The position of the divider as a percentage. */
39
+ this.position = 50;
40
+ }
41
+ handleDrag(event) {
42
+ const { width } = this.base.getBoundingClientRect();
43
+ const isRTL = document.documentElement.dir === "rtl" ||
44
+ (!document.documentElement.dir &&
45
+ getComputedStyle(document.documentElement).direction === "rtl");
46
+ event.preventDefault();
47
+ drag(this.base, {
48
+ onMove: (x) => {
49
+ this.position = parseFloat(clamp((x / width) * 100, 0, 100).toFixed(2));
50
+ if (isRTL) {
51
+ this.position = 100 - this.position;
52
+ }
53
+ },
54
+ initialEvent: event,
55
+ });
56
+ }
57
+ handleKeyDown(event) {
58
+ const isLTR = document.documentElement.dir === "ltr" ||
59
+ (document.documentElement.dir === "" &&
60
+ getComputedStyle(document.documentElement).direction === "ltr");
61
+ const isRTL = document.documentElement.dir === "rtl" ||
62
+ (!document.documentElement.dir &&
63
+ getComputedStyle(document.documentElement).direction === "rtl");
64
+ if (["ArrowLeft", "ArrowRight", "Home", "End"].includes(event.key)) {
65
+ const increment = event.shiftKey ? 10 : 1;
66
+ let newPosition = this.position;
67
+ event.preventDefault();
68
+ if ((isLTR && event.key === "ArrowLeft") ||
69
+ (isRTL && event.key === "ArrowRight")) {
70
+ newPosition -= increment;
71
+ }
72
+ if ((isLTR && event.key === "ArrowRight") ||
73
+ (isRTL && event.key === "ArrowLeft")) {
74
+ newPosition += increment;
75
+ }
76
+ if (event.key === "Home") {
77
+ newPosition = 0;
78
+ }
79
+ if (event.key === "End") {
80
+ newPosition = 100;
81
+ }
82
+ newPosition = clamp(newPosition, 0, 100);
83
+ this.position = newPosition;
84
+ }
85
+ }
86
+ /** @internal This is an internal property. */
87
+ handlePositionChange() {
88
+ emit(this, "pc-change");
89
+ }
90
+ render() {
91
+ const isRTL = document.documentElement.dir === "rtl" ||
92
+ (!document.documentElement.dir &&
93
+ getComputedStyle(document.documentElement).direction === "rtl");
94
+ return html `
95
+ <div
96
+ part="base"
97
+ class=${classMap({
98
+ "comparer": true,
99
+ "comparer-rtl": isRTL === true,
100
+ })}
101
+ id="comparer"
102
+ @keydown=${this.handleKeyDown}
103
+ >
104
+ <div class="comparer-content">
105
+ <div part="before" class="comparer-before-content">
106
+ <slot name="before"></slot>
107
+ </div>
108
+
109
+ <div
110
+ part="after"
111
+ class="comparer-after-content"
112
+ style=${styleMap({
113
+ clipPath: isRTL
114
+ ? `inset(0 0 0 ${100 - this.position}%)`
115
+ : `inset(0 ${100 - this.position}% 0 0)`,
116
+ })}
117
+ >
118
+ <slot name="after"></slot>
119
+ </div>
120
+ </div>
121
+
122
+ <div
123
+ part="divider"
124
+ class="comparer-divider"
125
+ style=${styleMap({
126
+ left: isRTL
127
+ ? `${100 - this.position}%`
128
+ : `${this.position}%`,
129
+ })}
130
+ @mousedown=${this.handleDrag}
131
+ @touchstart=${this.handleDrag}
132
+ >
133
+ <div
134
+ part="handle"
135
+ class="comparer-handle"
136
+ role="scrollbar"
137
+ aria-valuenow=${this.position}
138
+ aria-valuemin="0"
139
+ aria-valuemax="100"
140
+ aria-controls="comparer"
141
+ tabindex="0"
142
+ >
143
+ <slot name="handle">
144
+ <pc-icon
145
+ library="system"
146
+ icon-style="solid"
147
+ name="grip-vertical"
148
+ ></pc-icon>
149
+ </slot>
150
+ </div>
151
+ </div>
152
+ </div>
153
+ `;
154
+ }
155
+ };
156
+ PcComparer.styles = styles;
157
+ /** @internal This is an internal property. */
158
+ PcComparer.scopedElement = { "pc-icon": PcIcon };
159
+ __decorate([
160
+ query(".comparer"),
161
+ __metadata("design:type", HTMLElement)
162
+ ], PcComparer.prototype, "base", void 0);
163
+ __decorate([
164
+ query(".comparer-handle"),
165
+ __metadata("design:type", HTMLElement)
166
+ ], PcComparer.prototype, "handle", void 0);
167
+ __decorate([
168
+ property({ type: Number, reflect: true }),
169
+ __metadata("design:type", Object)
170
+ ], PcComparer.prototype, "position", void 0);
171
+ __decorate([
172
+ watch("position", { waitUntilFirstUpdate: true }),
173
+ __metadata("design:type", Function),
174
+ __metadata("design:paramtypes", []),
175
+ __metadata("design:returntype", void 0)
176
+ ], PcComparer.prototype, "handlePositionChange", null);
177
+ PcComparer = __decorate([
178
+ customElement("pc-comparer")
179
+ ], PcComparer);
180
+
181
+ export { PcComparer };
@@ -0,0 +1,8 @@
1
+ import { PcComparer } from "./comparer.component.js";
2
+ export * from "./comparer.component.js";
3
+ export default PcComparer;
4
+ declare global {
5
+ interface HTMLElementTagNameMap {
6
+ "pc-comparer": PcComparer;
7
+ }
8
+ }
@@ -0,0 +1,5 @@
1
+ import { PcComparer as PcComparer$1 } from './comparer.component.js';
2
+
3
+ var PcComparer = PcComparer$1;
4
+
5
+ export { PcComparer$1 as PcComparer, PcComparer as default };
@@ -0,0 +1 @@
1
+ export declare const styles: import("lit").CSSResult;
@@ -0,0 +1,75 @@
1
+ import { css } from 'lit';
2
+
3
+ const styles = css `
4
+ :host {
5
+ --divider-width: 2px;
6
+ --handle-size: 2.5rem;
7
+ display: inline-block;
8
+ position: relative;
9
+ }
10
+
11
+ .comparer {
12
+ max-width: 100%;
13
+ max-height: 100%;
14
+ overflow: hidden;
15
+ }
16
+
17
+ .comparer-before-content,
18
+ .comparer-after-content {
19
+ display: block;
20
+ pointer-events: none;
21
+ }
22
+
23
+ .comparer-before-content ::slotted(*),
24
+ .comparer-after-content ::slotted(*) {
25
+ display: block;
26
+ max-width: 100% !important;
27
+ height: auto;
28
+ border-radius: var(--pc-border-radius-m);
29
+ }
30
+
31
+ .comparer-after-content {
32
+ position: absolute;
33
+ top: 0;
34
+ left: 0;
35
+ width: 100%;
36
+ height: 100%;
37
+ }
38
+
39
+ .comparer-divider {
40
+ display: flex;
41
+ position: absolute;
42
+ align-items: center;
43
+ justify-content: center;
44
+ top: 0;
45
+ width: var(--divider-width);
46
+ height: 100%;
47
+ background-color: var(--pc-color-neutral-0);
48
+ translate: calc(var(--divider-width) / -2);
49
+ cursor: ew-resize;
50
+ }
51
+
52
+ .comparer-handle {
53
+ display: flex;
54
+ position: absolute;
55
+ align-items: center;
56
+ justify-content: center;
57
+ top: calc(50% - (var(--handle-size) / 2));
58
+ width: var(--handle-size);
59
+ height: var(--handle-size);
60
+ background-color: var(--pc-color-neutral-0);
61
+ border-radius: var(--pc-border-radius-circle);
62
+ font-size: calc(var(--handle-size) * 0.5);
63
+ color: var(--pc-color-neutral-700);
64
+ cursor: inherit;
65
+ z-index: 10;
66
+ transition: outline var(--pc-transition-fast) ease-in-out;
67
+ }
68
+
69
+ .comparer-handle:focus-visible {
70
+ outline: var(--pc-focus-ring);
71
+ outline-offset: var(--pc-focus-ring);
72
+ }
73
+ `;
74
+
75
+ export { styles };
@@ -0,0 +1,75 @@
1
+ import { LitElement } from "lit";
2
+ import type { CSSResultGroup } from "lit";
3
+ import { PcIcon } from "../icon/icon.js";
4
+ import { PcTooltip } from "../tooltip/tooltip.js";
5
+ /**
6
+ * @summary Copies text data to the clipboard when the user clicks the trigger.
7
+ * @status experimental
8
+ * @since 0.5.1
9
+ *
10
+ * @dependency pc-icon
11
+ * @dependency pc-tooltip
12
+ *
13
+ * @slot copy-icon — The icon to show in the default copy state. Works best with `<pc-icon>`.
14
+ * @slot success-icon — The icon to show when the content is copied. Works best with `<pc-icon>`.
15
+ * @slot error-icon — The icon to show when a copy error occurs. Works best with `<pc-icon>`.
16
+ *
17
+ * @event pc-copy — Emitted when the data has been copied.
18
+ * @event pc-error — Emitted when the data could not be copied.
19
+ *
20
+ * @csspart button — The internal `<button>` element.
21
+ * @csspart copy-icon — The container that holds the copy icon.
22
+ * @csspart success-icon — The container that holds the success icon.
23
+ * @csspart error-icon — The container that holds the error icon.
24
+ * @csspart tooltip__base — The tooltip’s `base` part.
25
+ * @csspart tooltip__base__popup — The tooltip’s `popup` part.
26
+ * @csspart tooltip__base__arrow — The tooltip’s `arrow` part.
27
+ * @csspart tooltip__body — The tooltip’s `body` part.
28
+ *
29
+ * @cssproperty --success-color — The colour to use for success feedback.
30
+ * @cssproperty --error-color — The colour to use for error feedback.
31
+ *
32
+ * @animation copy.in — The animation to use when the icons animate in.
33
+ * @animation copy.out — The animation to use when the icons animate out.
34
+ */
35
+ export declare class PcCopyButton extends LitElement {
36
+ static styles: CSSResultGroup;
37
+ /** @internal This is an internal property. */
38
+ static dependencies: {
39
+ "pc-icon": typeof PcIcon;
40
+ "pc-tooltip": typeof PcTooltip;
41
+ };
42
+ /** @internal This is an internal property. */
43
+ copyIcon: HTMLSlotElement;
44
+ /** @internal This is an internal property. */
45
+ successIcon: HTMLSlotElement;
46
+ /** @internal This is an internal property. */
47
+ errorIcon: HTMLSlotElement;
48
+ /** @internal This is an internal property. */
49
+ tooltip: PcTooltip;
50
+ /** @internal This is an internal property. */
51
+ isCopying: boolean;
52
+ /** @internal This is an internal property. */
53
+ status: "rest" | "success" | "error";
54
+ /** The text value to copy. */
55
+ value: string;
56
+ /**An id that references an element in the same document from which data will be copied. If both this and `value` are present, this value will take precedence. By default, the target element’s `textContent` will be copied. To copy an attribute, append the attribute name wrapped in square brackets (e.g., `from="element[value]"`). To copy a property, append a dot and the property name (e.g., `from="element.value"`). */
57
+ from: string;
58
+ /** Disables the copy button. */
59
+ disabled: boolean;
60
+ /** A custom label to show in the tooltip. */
61
+ copyLabel: string;
62
+ /** A custom label to show in the tooltip after copying. */
63
+ successLabel: string;
64
+ /** A custom label to show in the tooltip when a copy error occurs. */
65
+ errorLabel: string;
66
+ /** The length of time to show feedback before restoring the default trigger. */
67
+ feedbackDuration: number;
68
+ /** The preferred placement of the tooltip. */
69
+ tooltipPlacement: "top" | "right" | "bottom" | "left";
70
+ /** Enable this option to prevent the tooltip from being clipped when the component is placed inside a container with `overflow: auto|hidden|scroll`. Hoisting uses a fixed positioning strategy that works in many, but not all situations. */
71
+ hoist: boolean;
72
+ private handleCopy;
73
+ private showStatus;
74
+ render(): import("lit-html").TemplateResult<1>;
75
+ }
@@ -0,0 +1,289 @@
1
+ import { __decorate, __metadata } from 'tslib';
2
+ import { LitElement, html } from 'lit';
3
+ import { query, state, property, customElement } from 'lit/decorators.js';
4
+ import { classMap } from 'lit/directives/class-map.js';
5
+ import { setDefaultAnimation, getAnimation } from '../../utilities/animation-registry.js';
6
+ import { emit } from '../../internal/emit.js';
7
+ import { PcIcon } from '../icon/icon.component.js';
8
+ import { PcTooltip } from '../tooltip/tooltip.component.js';
9
+ import { styles } from './copy-button.styles.js';
10
+
11
+ setDefaultAnimation("copy.in", {
12
+ keyframes: [
13
+ { scale: "0.6", opacity: "0" },
14
+ { scale: "1.1", opacity: "1" },
15
+ { scale: "0.95", opacity: "1" },
16
+ { scale: "1", opacity: "1" },
17
+ ],
18
+ options: {
19
+ duration: 350,
20
+ easing: "cubic-bezier(0.34, 1.56, 0.64, 1)",
21
+ },
22
+ });
23
+ setDefaultAnimation("copy.out", {
24
+ keyframes: [
25
+ { scale: "1", opacity: "1" },
26
+ { scale: "0.85", opacity: "0" },
27
+ ],
28
+ options: {
29
+ duration: 200,
30
+ easing: "cubic-bezier(0.75, 0, 0.9, 0.05)",
31
+ },
32
+ });
33
+ /**
34
+ * @summary Copies text data to the clipboard when the user clicks the trigger.
35
+ * @status experimental
36
+ * @since 0.5.1
37
+ *
38
+ * @dependency pc-icon
39
+ * @dependency pc-tooltip
40
+ *
41
+ * @slot copy-icon — The icon to show in the default copy state. Works best with `<pc-icon>`.
42
+ * @slot success-icon — The icon to show when the content is copied. Works best with `<pc-icon>`.
43
+ * @slot error-icon — The icon to show when a copy error occurs. Works best with `<pc-icon>`.
44
+ *
45
+ * @event pc-copy — Emitted when the data has been copied.
46
+ * @event pc-error — Emitted when the data could not be copied.
47
+ *
48
+ * @csspart button — The internal `<button>` element.
49
+ * @csspart copy-icon — The container that holds the copy icon.
50
+ * @csspart success-icon — The container that holds the success icon.
51
+ * @csspart error-icon — The container that holds the error icon.
52
+ * @csspart tooltip__base — The tooltip’s `base` part.
53
+ * @csspart tooltip__base__popup — The tooltip’s `popup` part.
54
+ * @csspart tooltip__base__arrow — The tooltip’s `arrow` part.
55
+ * @csspart tooltip__body — The tooltip’s `body` part.
56
+ *
57
+ * @cssproperty --success-color — The colour to use for success feedback.
58
+ * @cssproperty --error-color — The colour to use for error feedback.
59
+ *
60
+ * @animation copy.in — The animation to use when the icons animate in.
61
+ * @animation copy.out — The animation to use when the icons animate out.
62
+ */
63
+ let PcCopyButton = class PcCopyButton extends LitElement {
64
+ constructor() {
65
+ super(...arguments);
66
+ /** @internal This is an internal property. */
67
+ this.isCopying = false;
68
+ /** @internal This is an internal property. */
69
+ this.status = "rest";
70
+ /** The text value to copy. */
71
+ this.value = "";
72
+ /**An id that references an element in the same document from which data will be copied. If both this and `value` are present, this value will take precedence. By default, the target element’s `textContent` will be copied. To copy an attribute, append the attribute name wrapped in square brackets (e.g., `from="element[value]"`). To copy a property, append a dot and the property name (e.g., `from="element.value"`). */
73
+ this.from = "";
74
+ /** Disables the copy button. */
75
+ this.disabled = false;
76
+ /** A custom label to show in the tooltip. */
77
+ this.copyLabel = "";
78
+ /** A custom label to show in the tooltip after copying. */
79
+ this.successLabel = "";
80
+ /** A custom label to show in the tooltip when a copy error occurs. */
81
+ this.errorLabel = "";
82
+ /** The length of time to show feedback before restoring the default trigger. */
83
+ this.feedbackDuration = 1000;
84
+ /** The preferred placement of the tooltip. */
85
+ this.tooltipPlacement = "top";
86
+ /** Enable this option to prevent the tooltip from being clipped when the component is placed inside a container with `overflow: auto|hidden|scroll`. Hoisting uses a fixed positioning strategy that works in many, but not all situations. */
87
+ this.hoist = false;
88
+ }
89
+ async handleCopy() {
90
+ if (this.disabled || this.isCopying) {
91
+ return;
92
+ }
93
+ this.isCopying = true;
94
+ let valueToCopy = this.value;
95
+ if (this.from) {
96
+ const root = this.getRootNode();
97
+ const isProperty = this.from.includes(".");
98
+ const isAttribute = this.from.includes("[") && this.from.includes("]");
99
+ let id = this.from;
100
+ let field = "";
101
+ if (isProperty) {
102
+ [id, field] = this.from.trim().split(".");
103
+ }
104
+ else if (isAttribute) {
105
+ [id, field] = this.from.trim().replace(/\]$/, "").split("[");
106
+ }
107
+ const target = "getElementById" in root ? root.getElementById(id) : null;
108
+ if (target) {
109
+ if (isAttribute) {
110
+ valueToCopy = target.getAttribute(field) || "";
111
+ }
112
+ else if (isProperty) {
113
+ // @ts-expect-error — Accessing a property with dynamic types
114
+ valueToCopy = target[field] || "";
115
+ }
116
+ else {
117
+ valueToCopy = target.textContent || "";
118
+ }
119
+ }
120
+ else {
121
+ this.showStatus("error");
122
+ emit(this, "pc-error");
123
+ }
124
+ }
125
+ if (!valueToCopy) {
126
+ this.showStatus("error");
127
+ emit(this, "pc-error");
128
+ }
129
+ else {
130
+ try {
131
+ await navigator.clipboard.writeText(valueToCopy);
132
+ this.showStatus("success");
133
+ emit(this, "pc-copy", {
134
+ detail: {
135
+ value: valueToCopy,
136
+ },
137
+ });
138
+ }
139
+ catch {
140
+ this.showStatus("error");
141
+ emit(this, "pc-error");
142
+ }
143
+ }
144
+ }
145
+ async showStatus(status) {
146
+ const copyLabel = this.copyLabel || "Copy";
147
+ const successLabel = this.successLabel || "Copied!";
148
+ const errorLabel = this.errorLabel || "Error";
149
+ const iconToShow = status === "success" ? this.successIcon : this.errorIcon;
150
+ const showAnimation = getAnimation(this, "copy.in", { dir: "ltr" });
151
+ const hideAnimation = getAnimation(this, "copy.out", { dir: "ltr" });
152
+ this.tooltip.content = status === "success" ? successLabel : errorLabel;
153
+ await this.copyIcon.animate(hideAnimation.keyframes, hideAnimation.options).finished;
154
+ this.copyIcon.hidden = true;
155
+ this.status = status;
156
+ iconToShow.hidden = false;
157
+ await iconToShow.animate(showAnimation.keyframes, showAnimation.options)
158
+ .finished;
159
+ setTimeout(async () => {
160
+ await iconToShow.animate(hideAnimation.keyframes, hideAnimation.options).finished;
161
+ iconToShow.hidden = true;
162
+ this.status = "rest";
163
+ this.copyIcon.hidden = false;
164
+ await this.copyIcon.animate(showAnimation.keyframes, showAnimation.options).finished;
165
+ this.tooltip.content = copyLabel;
166
+ this.isCopying = false;
167
+ }, this.feedbackDuration);
168
+ }
169
+ render() {
170
+ const copyLabel = this.copyLabel || "Copy";
171
+ return html `
172
+ <pc-tooltip
173
+ class=${classMap({
174
+ "copy-button-container": true,
175
+ "copy-button-success": this.status === "success",
176
+ "copy-button-error": this.status === "error",
177
+ })}
178
+ content=${copyLabel}
179
+ placement=${this.tooltipPlacement}
180
+ ?disabled=${this.disabled}
181
+ ?hoist=${this.hoist}
182
+ exportparts="
183
+ base:tooltip__base,
184
+ base-popup:tooltip__base__popup,
185
+ base-arrow:tooltip__base__arrow,
186
+ body:tooltip__body
187
+ "
188
+ >
189
+ <button
190
+ class="copy-button"
191
+ type="button"
192
+ part="button"
193
+ ?disabled=${this.disabled}
194
+ @click=${this.handleCopy}
195
+ >
196
+ <slot part="copy-icon" name="copy-icon">
197
+ <pc-icon
198
+ library="system"
199
+ icon-style="regular"
200
+ name="copy"
201
+ ></pc-icon>
202
+ </slot>
203
+ <slot part="success-icon" name="success-icon" hidden>
204
+ <pc-icon
205
+ library="system"
206
+ icon-style="solid"
207
+ name="check"
208
+ ></pc-icon>
209
+ </slot>
210
+ <slot part="error-icon" name="error-icon" hidden>
211
+ <pc-icon
212
+ library="system"
213
+ icon-style="solid"
214
+ name="xmark"
215
+ ></pc-icon>
216
+ </slot>
217
+ </button>
218
+ </pc-tooltip>
219
+ `;
220
+ }
221
+ };
222
+ PcCopyButton.styles = styles;
223
+ /** @internal This is an internal property. */
224
+ PcCopyButton.dependencies = { "pc-icon": PcIcon, "pc-tooltip": PcTooltip };
225
+ __decorate([
226
+ query('slot[name="copy-icon"]'),
227
+ __metadata("design:type", HTMLSlotElement)
228
+ ], PcCopyButton.prototype, "copyIcon", void 0);
229
+ __decorate([
230
+ query('slot[name="success-icon"]'),
231
+ __metadata("design:type", HTMLSlotElement)
232
+ ], PcCopyButton.prototype, "successIcon", void 0);
233
+ __decorate([
234
+ query('slot[name="error-icon"]'),
235
+ __metadata("design:type", HTMLSlotElement)
236
+ ], PcCopyButton.prototype, "errorIcon", void 0);
237
+ __decorate([
238
+ query("pc-tooltip"),
239
+ __metadata("design:type", PcTooltip)
240
+ ], PcCopyButton.prototype, "tooltip", void 0);
241
+ __decorate([
242
+ state(),
243
+ __metadata("design:type", Object)
244
+ ], PcCopyButton.prototype, "isCopying", void 0);
245
+ __decorate([
246
+ state(),
247
+ __metadata("design:type", String)
248
+ ], PcCopyButton.prototype, "status", void 0);
249
+ __decorate([
250
+ property(),
251
+ __metadata("design:type", Object)
252
+ ], PcCopyButton.prototype, "value", void 0);
253
+ __decorate([
254
+ property(),
255
+ __metadata("design:type", Object)
256
+ ], PcCopyButton.prototype, "from", void 0);
257
+ __decorate([
258
+ property({ type: Boolean, reflect: true }),
259
+ __metadata("design:type", Object)
260
+ ], PcCopyButton.prototype, "disabled", void 0);
261
+ __decorate([
262
+ property({ attribute: "copy-label" }),
263
+ __metadata("design:type", Object)
264
+ ], PcCopyButton.prototype, "copyLabel", void 0);
265
+ __decorate([
266
+ property({ attribute: "success-label" }),
267
+ __metadata("design:type", Object)
268
+ ], PcCopyButton.prototype, "successLabel", void 0);
269
+ __decorate([
270
+ property({ attribute: "error-label" }),
271
+ __metadata("design:type", Object)
272
+ ], PcCopyButton.prototype, "errorLabel", void 0);
273
+ __decorate([
274
+ property({ attribute: "feedback-duration", type: Number }),
275
+ __metadata("design:type", Object)
276
+ ], PcCopyButton.prototype, "feedbackDuration", void 0);
277
+ __decorate([
278
+ property({ attribute: "tooltip-placement" }),
279
+ __metadata("design:type", String)
280
+ ], PcCopyButton.prototype, "tooltipPlacement", void 0);
281
+ __decorate([
282
+ property({ type: Boolean }),
283
+ __metadata("design:type", Object)
284
+ ], PcCopyButton.prototype, "hoist", void 0);
285
+ PcCopyButton = __decorate([
286
+ customElement("pc-copy-button")
287
+ ], PcCopyButton);
288
+
289
+ export { PcCopyButton };