@privyid/persona 0.3.0 → 0.5.0

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 (330) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +4 -0
  3. package/dist/components/app/App.vue +3 -2
  4. package/dist/components/aspect-ratio/index.d.ts +3 -0
  5. package/dist/components/aspect-ratio/index.mjs +21 -0
  6. package/dist/components/aspect-ratio/utils/calculate-ratio.d.ts +7 -0
  7. package/dist/components/aspect-ratio/utils/calculate-ratio.mjs +10 -0
  8. package/dist/components/aspect-ratio/utils/resize-observer.d.ts +1 -0
  9. package/dist/components/aspect-ratio/utils/resize-observer.mjs +22 -0
  10. package/dist/components/avatar/Avatar.vue +1 -1
  11. package/dist/components/avatar/Avatar.vue.d.ts +1 -2
  12. package/dist/components/avatar/index.d.ts +2 -0
  13. package/dist/components/avatar/index.mjs +0 -0
  14. package/dist/components/badge/Badge.vue +33 -58
  15. package/dist/components/badge/Badge.vue.d.ts +1 -2
  16. package/dist/components/badge/index.d.ts +2 -0
  17. package/dist/components/badge/index.mjs +0 -0
  18. package/dist/components/banner/Banner.vue +23 -9
  19. package/dist/components/banner/Banner.vue.d.ts +1 -1
  20. package/dist/components/banner/index.d.ts +1 -0
  21. package/dist/components/banner/index.mjs +0 -0
  22. package/dist/components/button/Button.vue +74 -77
  23. package/dist/components/button/Button.vue.d.ts +1 -3
  24. package/dist/components/button/index.d.ts +3 -0
  25. package/dist/components/button/index.mjs +0 -0
  26. package/dist/components/button-group/ButtonGroup.vue +126 -63
  27. package/dist/components/button-group/ButtonGroup.vue.d.ts +1 -0
  28. package/dist/components/calendar/Calendar.vue +31 -30
  29. package/dist/components/calendar/adapter/adapter.d.ts +7 -0
  30. package/dist/components/calendar/adapter/adapter.mjs +8 -0
  31. package/dist/components/calendar/adapter/date.mjs +6 -4
  32. package/dist/components/calendar/adapter/month.mjs +2 -3
  33. package/dist/components/camera/Camera.vue +383 -0
  34. package/dist/components/camera/Camera.vue.d.ts +94 -0
  35. package/dist/components/camera/adapter/adapter.d.ts +41 -0
  36. package/dist/components/camera/adapter/adapter.mjs +3 -0
  37. package/dist/components/camera/adapter/capture.d.ts +5 -0
  38. package/dist/components/camera/adapter/capture.mjs +12 -0
  39. package/dist/components/camera/adapter/liveness.d.ts +5 -0
  40. package/dist/components/camera/adapter/liveness.mjs +46 -0
  41. package/dist/components/camera/adapter/qr-code.d.ts +2 -0
  42. package/dist/components/camera/adapter/qr-code.mjs +19 -0
  43. package/dist/components/camera/assets/shutter.wav +0 -0
  44. package/dist/components/camera/utils/motion.d.ts +29 -0
  45. package/dist/components/camera/utils/motion.mjs +88 -0
  46. package/dist/components/camera/utils/take-picture.d.ts +1 -0
  47. package/dist/components/camera/utils/take-picture.mjs +14 -0
  48. package/dist/components/caption/Caption.vue +60 -7
  49. package/dist/components/caption/Caption.vue.d.ts +27 -7
  50. package/dist/components/card/Card.vue +14 -8
  51. package/dist/components/card/Card.vue.d.ts +10 -1
  52. package/dist/components/card/CardSection.vue +2 -1
  53. package/dist/components/card/index.d.ts +1 -0
  54. package/dist/components/card/index.mjs +0 -0
  55. package/dist/components/chart/Chart.vue +6 -3
  56. package/dist/components/chart/Chart.vue.d.ts +1 -2
  57. package/dist/components/chart/index.d.ts +2 -0
  58. package/dist/components/chart/index.mjs +0 -0
  59. package/dist/components/chart/{use-chart.d.ts → utils/use-chart.d.ts} +0 -0
  60. package/dist/components/chart/{use-chart.mjs → utils/use-chart.mjs} +0 -0
  61. package/dist/components/checkbox/Checkbox.vue +47 -14
  62. package/dist/components/checkbox/Checkbox.vue.d.ts +0 -4
  63. package/dist/components/checkbox/{use-checkbox.d.ts → index.d.ts} +1 -1
  64. package/dist/components/checkbox/{use-checkbox.mjs → index.mjs} +0 -0
  65. package/dist/components/collapse/Collapse.vue +88 -0
  66. package/dist/components/collapse/Collapse.vue.d.ts +29 -0
  67. package/dist/components/contextual-bar/ContextualBar.vue +292 -0
  68. package/dist/components/contextual-bar/ContextualBar.vue.d.ts +78 -0
  69. package/dist/components/contextual-bar/assets/images/img-background-contextualbar.svg +14 -0
  70. package/dist/components/contextual-bar/assets/images/img-bg-contextualbar.svg +19 -0
  71. package/dist/components/contextual-bar/index.d.ts +1 -0
  72. package/dist/components/contextual-bar/index.mjs +0 -0
  73. package/dist/components/cropper/Cropper.vue +423 -0
  74. package/dist/components/cropper/Cropper.vue.d.ts +149 -0
  75. package/dist/components/cropper/assets/ps-neutral.png +0 -0
  76. package/dist/components/cropper/assets/sample-1.jpg +0 -0
  77. package/dist/components/cropper/utils/crop-image.d.ts +44 -0
  78. package/dist/components/cropper/utils/crop-image.mjs +43 -0
  79. package/dist/components/cropper/utils/use-pinch.d.ts +8 -0
  80. package/dist/components/cropper/utils/use-pinch.mjs +42 -0
  81. package/dist/components/cropper/utils/use-ratio.d.ts +9 -0
  82. package/dist/components/cropper/utils/use-ratio.mjs +24 -0
  83. package/dist/components/datepicker/Datepicker.vue +14 -5
  84. package/dist/components/datepicker/Datepicker.vue.d.ts +9 -0
  85. package/dist/components/dialog/Dialog.vue +2 -0
  86. package/dist/components/dialog/Dialog.vue.d.ts +1 -1
  87. package/dist/components/dialog/DialogFooter.vue +4 -2
  88. package/dist/components/dialog/DialogFooter.vue.d.ts +2 -1
  89. package/dist/components/dialog/index.d.ts +31 -6
  90. package/dist/components/dialog/index.mjs +32 -5
  91. package/dist/components/divider/Divider.vue +22 -2
  92. package/dist/components/dot/Dot.vue +27 -20
  93. package/dist/components/dot/Dot.vue.d.ts +10 -1
  94. package/dist/components/dot/index.d.ts +2 -0
  95. package/dist/components/dot/index.mjs +0 -0
  96. package/dist/components/dropdown/Dropdown.vue +73 -21
  97. package/dist/components/dropdown/Dropdown.vue.d.ts +16 -12
  98. package/dist/components/dropdown/DropdownItem.vue +3 -3
  99. package/dist/components/dropdown/index.d.ts +9 -0
  100. package/dist/components/dropdown/index.mjs +1 -0
  101. package/dist/components/dropdown/utils/use-focus.d.ts +1 -1
  102. package/dist/components/dropdown/utils/use-focus.mjs +4 -2
  103. package/dist/components/dropdown-subitem/DropdownSubitem.vue +12 -12
  104. package/dist/components/dropdown-subitem/DropdownSubitem.vue.d.ts +1 -1
  105. package/dist/components/dropdown-subitem/{use-dropdown-subitem.d.ts → index.d.ts} +0 -0
  106. package/dist/components/dropdown-subitem/{use-dropdown-subitem.mjs → index.mjs} +0 -0
  107. package/dist/components/dropzone/Dropzone.vue +202 -0
  108. package/dist/components/dropzone/Dropzone.vue.d.ts +93 -0
  109. package/dist/components/dropzone/index.d.ts +4 -0
  110. package/dist/components/dropzone/index.mjs +0 -0
  111. package/dist/components/dropzone/utils/accept.d.ts +1 -0
  112. package/dist/components/dropzone/utils/accept.mjs +17 -0
  113. package/dist/components/filterbar/Filterbar.vue +7 -5
  114. package/dist/components/filterbar/Filterbar.vue.d.ts +1 -1
  115. package/dist/components/filterbar/{use-filterbar.d.ts → index.d.ts} +1 -1
  116. package/dist/components/filterbar/{use-filterbar.mjs → index.mjs} +0 -0
  117. package/dist/components/filterbar/pinned/Date.vue +9 -7
  118. package/dist/components/filterbar/pinned/Date.vue.d.ts +1 -1
  119. package/dist/components/filterbar/pinned/Multiselect.vue +16 -13
  120. package/dist/components/filterbar/pinned/Multiselect.vue.d.ts +2 -2
  121. package/dist/components/filterbar/pinned/Select.vue +11 -8
  122. package/dist/components/filterbar/pinned/Select.vue.d.ts +2 -2
  123. package/dist/components/filterbar/pinned/Toggle.vue +2 -1
  124. package/dist/components/filterbar/pinned/Toggle.vue.d.ts +1 -1
  125. package/dist/components/form-group/FormGroup.vue +103 -0
  126. package/dist/components/form-group/FormGroup.vue.d.ts +61 -0
  127. package/dist/components/global/context.d.ts +24 -0
  128. package/dist/components/global/context.mjs +18 -0
  129. package/dist/components/global/router.d.ts +23 -0
  130. package/dist/components/global/router.mjs +7 -0
  131. package/dist/components/global/use-singleton.d.ts +17 -2
  132. package/dist/components/global/use-singleton.mjs +18 -10
  133. package/dist/components/heading/Heading.vue +50 -0
  134. package/dist/components/heading/Heading.vue.d.ts +19 -1
  135. package/dist/components/heading/index.d.ts +3 -0
  136. package/dist/components/heading/index.mjs +0 -0
  137. package/dist/components/input/Input.vue +119 -24
  138. package/dist/components/input/Input.vue.d.ts +38 -2
  139. package/dist/components/input/{use-input.d.ts → index.d.ts} +0 -0
  140. package/dist/components/input/{use-input.mjs → index.mjs} +0 -0
  141. package/dist/components/input-file/InputFile.vue +171 -0
  142. package/dist/components/input-file/InputFile.vue.d.ts +120 -0
  143. package/dist/components/input-group/InputGroup.vue +131 -0
  144. package/dist/components/input-group/InputGroup.vue.d.ts +45 -0
  145. package/dist/components/input-group/InputGroupAddon.vue +43 -0
  146. package/dist/components/input-password/InputPassword.vue +62 -0
  147. package/dist/components/input-password/InputPassword.vue.d.ts +5 -0
  148. package/dist/components/input-password/index.d.ts +2 -0
  149. package/dist/components/input-password/index.mjs +17 -0
  150. package/dist/components/input-pin/InputPin.vue +145 -0
  151. package/dist/components/input-pin/InputPin.vue.d.ts +64 -0
  152. package/dist/components/input-range/InputRange.vue +274 -0
  153. package/dist/components/input-range/InputRange.vue.d.ts +108 -0
  154. package/dist/components/input-range/utils/use-drag.d.ts +3 -0
  155. package/dist/components/input-range/utils/use-drag.mjs +19 -0
  156. package/dist/components/label/Label.vue +29 -41
  157. package/dist/components/label/Label.vue.d.ts +1 -1
  158. package/dist/components/markdown/index.d.ts +20 -0
  159. package/dist/components/markdown/index.mjs +15 -0
  160. package/dist/components/modal/Modal.vue +71 -5
  161. package/dist/components/modal/Modal.vue.d.ts +30 -0
  162. package/dist/components/nav/Nav.vue +16 -14
  163. package/dist/components/nav/Nav.vue.d.ts +3 -4
  164. package/dist/components/nav/NavForm.vue +19 -0
  165. package/dist/components/nav/NavItem.vue +14 -4
  166. package/dist/components/nav/NavItem.vue.d.ts +3 -4
  167. package/dist/components/nav/NavItemDropdown.vue +5 -1
  168. package/dist/components/nav/NavItemDropdown.vue.d.ts +9 -0
  169. package/dist/components/nav/NavSubItem.vue +5 -5
  170. package/dist/components/nav/index.d.ts +2 -0
  171. package/dist/components/nav/index.mjs +0 -0
  172. package/dist/components/navbar/Navbar.vue +143 -0
  173. package/dist/components/navbar/Navbar.vue.d.ts +57 -0
  174. package/dist/components/navbar/NavbarBrand.vue +33 -0
  175. package/dist/components/navbar/NavbarBrand.vue.d.ts +14 -0
  176. package/dist/components/navbar/NavbarNav.vue +109 -0
  177. package/dist/components/navbar/NavbarNav.vue.d.ts +19 -0
  178. package/dist/components/navbar/NavbarToggle.vue +74 -0
  179. package/dist/components/navbar/NavbarToggle.vue.d.ts +6 -0
  180. package/dist/components/navbar/index.d.ts +10 -0
  181. package/dist/components/navbar/index.mjs +1 -0
  182. package/dist/components/navbar-menu/NavbarNavMenu.vue +62 -0
  183. package/dist/components/navbar-menu/NavbarNavMenu.vue.d.ts +16 -0
  184. package/dist/components/overlay/Overlay.vue +8 -3
  185. package/dist/components/overlay/Overlay.vue.d.ts +14 -3
  186. package/dist/components/overlay/{use-overlay.d.ts → index.d.ts} +0 -0
  187. package/dist/components/overlay/{use-overlay.mjs → index.mjs} +0 -0
  188. package/dist/components/progress/Progress.vue +200 -0
  189. package/dist/components/progress/Progress.vue.d.ts +42 -0
  190. package/dist/components/progress/ProgressItem.vue +50 -0
  191. package/dist/components/progress/ProgressItem.vue.d.ts +25 -0
  192. package/dist/components/radio/Radio.vue +88 -31
  193. package/dist/components/radio/Radio.vue.d.ts +6 -6
  194. package/dist/components/radio/{use-radio.d.ts → index.d.ts} +1 -1
  195. package/dist/components/radio/{use-radio.mjs → index.mjs} +0 -0
  196. package/dist/components/select/Select.vue +10 -4
  197. package/dist/components/select/Select.vue.d.ts +11 -2
  198. package/dist/components/select/adapter/adapter.d.ts +1 -1
  199. package/dist/components/select/adapter/async-adapter.d.ts +1 -1
  200. package/dist/components/select/{use-select.d.ts → index.d.ts} +0 -0
  201. package/dist/components/select/{use-select.mjs → index.mjs} +0 -0
  202. package/dist/components/sidebar/Sidebar.vue +3 -3
  203. package/dist/components/sidebar/Sidebar.vue.d.ts +4 -9
  204. package/dist/components/sidebar/SidebarNav.vue +11 -11
  205. package/dist/components/sidebar/SidebarNav.vue.d.ts +2 -2
  206. package/dist/components/sidebar/index.d.ts +9 -0
  207. package/dist/components/sidebar/index.mjs +1 -0
  208. package/dist/components/sidebar-menu/SidebarMenu.vue.d.ts +4 -2
  209. package/dist/components/sidebar-menu/{use-sidebar-menu.d.ts → index.d.ts} +2 -0
  210. package/dist/components/sidebar-menu/{use-sidebar-menu.mjs → index.mjs} +0 -0
  211. package/dist/components/signature-draw/SignatureDraw.vue +1 -1
  212. package/dist/components/signature-draw/SignatureDrawDesktop.vue +5 -5
  213. package/dist/components/signature-draw/SignatureDrawMobile.vue +17 -5
  214. package/dist/components/signature-draw/utils/canvas.d.ts +7 -1
  215. package/dist/components/signature-draw/utils/canvas.mjs +8 -2
  216. package/dist/components/signature-draw/utils/use-draw.mjs +6 -5
  217. package/dist/components/signature-text/SignatureText.vue +1 -1
  218. package/dist/components/signature-text/SignatureText.vue.d.ts +1 -1
  219. package/dist/components/signature-text/utils/formatter.mjs +1 -1
  220. package/dist/components/spinner/Spinner.vue +1 -0
  221. package/dist/components/spinner/SpinnerRing.vue +1 -0
  222. package/dist/components/spread/Spread.vue +55 -0
  223. package/dist/components/spread/Spread.vue.d.ts +14 -0
  224. package/dist/components/steps/Step.vue +55 -0
  225. package/dist/components/steps/Step.vue.d.ts +32 -0
  226. package/dist/components/steps/StepSlider.vue +39 -0
  227. package/dist/components/steps/StepSlider.vue.d.ts +25 -0
  228. package/dist/components/steps/Steps.vue +111 -0
  229. package/dist/components/steps/Steps.vue.d.ts +56 -0
  230. package/dist/components/steps/index.d.ts +26 -0
  231. package/dist/components/steps/index.mjs +52 -0
  232. package/dist/components/steps/utils/hook.d.ts +10 -0
  233. package/dist/components/steps/utils/hook.mjs +34 -0
  234. package/dist/components/strengthbar/Strengthbar.vue +96 -0
  235. package/dist/components/strengthbar/Strengthbar.vue.d.ts +45 -0
  236. package/dist/components/subheading/Subheading.vue +65 -20
  237. package/dist/components/subheading/Subheading.vue.d.ts +23 -5
  238. package/dist/components/subheading/index.d.ts +1 -0
  239. package/dist/components/subheading/index.mjs +0 -0
  240. package/dist/components/table/Table.vue +21 -9
  241. package/dist/components/table/Table.vue.d.ts +1 -1
  242. package/dist/components/table/{use-table.d.ts → index.d.ts} +0 -0
  243. package/dist/components/table/{use-table.mjs → index.mjs} +0 -0
  244. package/dist/components/tabs/TabContent.vue +2 -2
  245. package/dist/components/tabs/Tabs.vue +12 -9
  246. package/dist/components/tabs/Tabs.vue.d.ts +2 -1
  247. package/dist/components/textarea/Textarea.vue +27 -16
  248. package/dist/components/textarea/Textarea.vue.d.ts +10 -1
  249. package/dist/components/toast/Toast.vue +102 -72
  250. package/dist/components/toast/Toast.vue.d.ts +1 -1
  251. package/dist/components/toast/ToastContainer.vue +1 -1
  252. package/dist/components/toast/ToastContainer.vue.d.ts +3 -3
  253. package/dist/components/toast/{use-toast.d.ts → index.d.ts} +1 -1
  254. package/dist/components/toast/index.mjs +6 -0
  255. package/dist/components/toggle/Toggle.vue +17 -21
  256. package/dist/components/tooltip/Tooltip.vue +161 -0
  257. package/dist/components/tooltip/Tooltip.vue.d.ts +51 -0
  258. package/dist/components/tooltip/TooltipContainer.vue +66 -0
  259. package/dist/components/tooltip/TooltipContainer.vue.d.ts +11 -0
  260. package/dist/components/tooltip/index.d.ts +14 -0
  261. package/dist/components/tooltip/index.mjs +82 -0
  262. package/dist/components/tooltip/utils/create-handler.d.ts +9 -0
  263. package/dist/components/tooltip/utils/create-handler.mjs +16 -0
  264. package/dist/components/tooltip/utils/parse-bindings.d.ts +22 -0
  265. package/dist/components/tooltip/utils/parse-bindings.mjs +45 -0
  266. package/dist/components/tour/Tour.vue +105 -0
  267. package/dist/components/tour/Tour.vue.d.ts +11 -0
  268. package/dist/components/tour/TourDialog.vue +204 -0
  269. package/dist/components/tour/TourDialog.vue.d.ts +108 -0
  270. package/dist/components/tour/TourHighlight.vue +57 -0
  271. package/dist/components/tour/TourHighlight.vue.d.ts +15 -0
  272. package/dist/components/tour/core/base.d.ts +59 -0
  273. package/dist/components/tour/core/base.mjs +43 -0
  274. package/dist/components/tour/core/step/action.d.ts +15 -0
  275. package/dist/components/tour/core/step/action.mjs +14 -0
  276. package/dist/components/tour/core/step/conditional.d.ts +26 -0
  277. package/dist/components/tour/core/step/conditional.mjs +69 -0
  278. package/dist/components/tour/core/step/delay.d.ts +8 -0
  279. package/dist/components/tour/core/step/delay.mjs +9 -0
  280. package/dist/components/tour/core/step/dialog.d.ts +11 -0
  281. package/dist/components/tour/core/step/dialog.mjs +25 -0
  282. package/dist/components/tour/core/step/visit.d.ts +9 -0
  283. package/dist/components/tour/core/step/visit.mjs +18 -0
  284. package/dist/components/tour/core/step.d.ts +37 -0
  285. package/dist/components/tour/core/step.mjs +30 -0
  286. package/dist/components/tour/core/story.d.ts +130 -0
  287. package/dist/components/tour/core/story.mjs +85 -0
  288. package/dist/components/tour/core/tour.d.ts +120 -0
  289. package/dist/components/tour/core/tour.mjs +133 -0
  290. package/dist/components/tour/index.d.ts +3 -0
  291. package/dist/components/tour/index.mjs +4 -0
  292. package/dist/components/tour/utils/is-visible.d.ts +2 -0
  293. package/dist/components/tour/utils/is-visible.mjs +35 -0
  294. package/dist/components/tour/utils/use-selector.d.ts +3 -0
  295. package/dist/components/tour/utils/use-selector.mjs +25 -0
  296. package/dist/components/tour/utils/wait-element.d.ts +6 -0
  297. package/dist/components/tour/utils/wait-element.mjs +44 -0
  298. package/dist/components/utils/base64.d.ts +8 -0
  299. package/dist/components/utils/base64.mjs +29 -0
  300. package/dist/components/utils/color.d.ts +6 -1
  301. package/dist/components/utils/color.mjs +4 -0
  302. package/dist/components/utils/value.mjs +2 -1
  303. package/dist/components/utils/vnode.d.ts +14 -1
  304. package/dist/components/utils/vnode.mjs +5 -2
  305. package/dist/components/wizard/Wizard.vue +85 -0
  306. package/dist/components/wizard/Wizard.vue.d.ts +72 -0
  307. package/dist/components/wizard/WizardBody.vue +50 -0
  308. package/dist/components/wizard/WizardBody.vue.d.ts +23 -0
  309. package/dist/components/wizard/WizardHeader.vue +38 -0
  310. package/dist/components/wizard/WizardHeader.vue.d.ts +16 -0
  311. package/dist/components/wizard/WizardStep.vue +20 -0
  312. package/dist/components/wizard/WizardStep.vue.d.ts +34 -0
  313. package/dist/core/index.d.ts +16 -6
  314. package/dist/core/index.mjs +37 -6
  315. package/dist/directive/index.d.ts +3 -0
  316. package/dist/directive/index.mjs +12 -0
  317. package/dist/module.d.ts +9 -2
  318. package/dist/module.json +1 -1
  319. package/dist/module.mjs +1613 -4
  320. package/dist/runtime/plugin.d.ts +2 -0
  321. package/dist/runtime/plugin.mjs +14 -0
  322. package/dist/types.d.ts +5 -1
  323. package/package.json +46 -9
  324. package/dist/components/dialog/use-dialog.d.ts +0 -28
  325. package/dist/components/dialog/use-dialog.mjs +0 -31
  326. package/dist/components/dropdown/utils/use-popper.d.ts +0 -6
  327. package/dist/components/dropdown/utils/use-popper.mjs +0 -32
  328. package/dist/components/input/InputGroup.vue +0 -25
  329. package/dist/components/toast/use-toast.mjs +0 -5
  330. package/dist/core/index.cjs +0 -75
@@ -0,0 +1,55 @@
1
+ <template>
2
+ <div
3
+ class="step"
4
+ data-testid="step">
5
+ <slot
6
+ :step="step"
7
+ :next="next"
8
+ :prev="prev"
9
+ :can-prev="canPrev"
10
+ :can-next="canNext"
11
+ :to-step="toStep" />
12
+ </div>
13
+ </template>
14
+
15
+ <script>
16
+ import {
17
+ defineComponent
18
+ } from "vue-demi";
19
+ import { useStep } from ".";
20
+ export default defineComponent({
21
+ name: "Step",
22
+ props: {
23
+ onBeforePrev: {
24
+ type: Function,
25
+ default: () => true
26
+ },
27
+ onBeforeNext: {
28
+ type: Function,
29
+ default: () => true
30
+ }
31
+ },
32
+ setup(props) {
33
+ const {
34
+ canNext,
35
+ canPrev,
36
+ toStep,
37
+ step,
38
+ next,
39
+ prev,
40
+ onBeforeNext,
41
+ onBeforePrev
42
+ } = useStep();
43
+ onBeforeNext(props.onBeforeNext);
44
+ onBeforePrev(props.onBeforePrev);
45
+ return {
46
+ canNext,
47
+ canPrev,
48
+ toStep,
49
+ prev,
50
+ next,
51
+ step
52
+ };
53
+ }
54
+ });
55
+ </script>
@@ -0,0 +1,32 @@
1
+ import { PropType } from 'vue-demi';
2
+ import { TravelHook } from '.';
3
+ declare const _default: import("vue-demi").DefineComponent<{
4
+ onBeforePrev: {
5
+ type: PropType<TravelHook>;
6
+ default: () => boolean;
7
+ };
8
+ onBeforeNext: {
9
+ type: PropType<TravelHook>;
10
+ default: () => boolean;
11
+ };
12
+ }, {
13
+ canNext: import("vue-demi").Ref<boolean>;
14
+ canPrev: import("vue-demi").Ref<boolean>;
15
+ toStep: (...args: any[]) => void;
16
+ prev: (...args: any[]) => void;
17
+ next: (...args: any[]) => void;
18
+ step: import("vue-demi").Ref<number>;
19
+ }, unknown, {}, {}, import("vue-demi").ComponentOptionsMixin, import("vue-demi").ComponentOptionsMixin, {}, string, import("vue-demi").VNodeProps & import("vue-demi").AllowedComponentProps & import("vue-demi").ComponentCustomProps, Readonly<import("vue-demi").ExtractPropTypes<{
20
+ onBeforePrev: {
21
+ type: PropType<TravelHook>;
22
+ default: () => boolean;
23
+ };
24
+ onBeforeNext: {
25
+ type: PropType<TravelHook>;
26
+ default: () => boolean;
27
+ };
28
+ }>>, {
29
+ onBeforePrev: TravelHook;
30
+ onBeforeNext: TravelHook;
31
+ }>;
32
+ export default _default;
@@ -0,0 +1,39 @@
1
+ <script>
2
+ import {
3
+ defineComponent,
4
+ h,
5
+ KeepAlive,
6
+ ref,
7
+ Transition,
8
+ watch
9
+ } from "vue-demi";
10
+ import { findAllChildren } from "../utils/vnode";
11
+ export default defineComponent({
12
+ props: {
13
+ active: {
14
+ type: Number,
15
+ default: 0
16
+ },
17
+ keepAlive: {
18
+ type: Boolean,
19
+ default: false
20
+ }
21
+ },
22
+ setup(props, { slots }) {
23
+ const transition = ref("slide-left");
24
+ watch(() => props.active, (value, old) => {
25
+ transition.value = value > old ? "slide-left" : "slide-right";
26
+ });
27
+ return () => {
28
+ const step = findAllChildren(slots.default(), "Step").at(props.active);
29
+ const body = () => {
30
+ return props.keepAlive ? h(KeepAlive, () => h(step, { key: props.active })) : h(step, { key: props.active });
31
+ };
32
+ return h(Transition, {
33
+ name: transition.value,
34
+ mode: "out-in"
35
+ }, body);
36
+ };
37
+ }
38
+ });
39
+ </script>
@@ -0,0 +1,25 @@
1
+ declare const _default: import("vue-demi").DefineComponent<{
2
+ active: {
3
+ type: NumberConstructor;
4
+ default: number;
5
+ };
6
+ keepAlive: {
7
+ type: BooleanConstructor;
8
+ default: boolean;
9
+ };
10
+ }, () => import("vue-demi").VNode<import("vue-demi").RendererNode, import("vue-demi").RendererElement, {
11
+ [key: string]: any;
12
+ }>, unknown, {}, {}, import("vue-demi").ComponentOptionsMixin, import("vue-demi").ComponentOptionsMixin, {}, string, import("vue-demi").VNodeProps & import("vue-demi").AllowedComponentProps & import("vue-demi").ComponentCustomProps, Readonly<import("vue-demi").ExtractPropTypes<{
13
+ active: {
14
+ type: NumberConstructor;
15
+ default: number;
16
+ };
17
+ keepAlive: {
18
+ type: BooleanConstructor;
19
+ default: boolean;
20
+ };
21
+ }>>, {
22
+ active: number;
23
+ keepAlive: boolean;
24
+ }>;
25
+ export default _default;
@@ -0,0 +1,111 @@
1
+ <template>
2
+ <div
3
+ class="steps"
4
+ data-testid="steps">
5
+ <StepSlider
6
+ :active="model - 1"
7
+ :keep-alive="keepAlive">
8
+ <slot />
9
+ </StepSlider>
10
+ </div>
11
+ </template>
12
+
13
+ <script>
14
+ import {
15
+ computed,
16
+ defineComponent,
17
+ provide,
18
+ ref
19
+ } from "vue-demi";
20
+ import StepSlider from "./StepSlider.vue";
21
+ import { useVModel } from "../input";
22
+ import { findAllChildren } from "../utils/vnode";
23
+ import {
24
+ STEPS_CONTEXT
25
+ } from ".";
26
+ import { syncRef } from "@vueuse/core";
27
+ import { useClamp } from "@vueuse/math";
28
+ import { runAllHooks } from "./utils/hook";
29
+ import { noop } from "lodash-es";
30
+ export default defineComponent({
31
+ components: { StepSlider },
32
+ props: {
33
+ modelValue: {
34
+ type: Number,
35
+ default: 1
36
+ },
37
+ keepAlive: {
38
+ type: Boolean,
39
+ default: false
40
+ },
41
+ onBeforePrev: {
42
+ type: Function,
43
+ default: () => true
44
+ },
45
+ onBeforeNext: {
46
+ type: Function,
47
+ default: () => true
48
+ },
49
+ onFinished: {
50
+ type: Function,
51
+ default: noop
52
+ }
53
+ },
54
+ models: {
55
+ prop: "modelValue",
56
+ event: "update:modelValue"
57
+ },
58
+ emits: ["update:modelValue"],
59
+ setup(props, { slots }) {
60
+ const onNextHooks = ref([props.onBeforeNext]);
61
+ const onPrevHooks = ref([props.onBeforePrev]);
62
+ const model = useVModel(props);
63
+ const total = computed(() => {
64
+ return findAllChildren(slots.default(), "Step").length;
65
+ });
66
+ const step = useClamp(model, 1, total);
67
+ const canNext = computed(() => {
68
+ return model.value <= total.value;
69
+ });
70
+ const canPrev = computed(() => {
71
+ return model.value > 1;
72
+ });
73
+ async function next() {
74
+ if (canNext.value)
75
+ await toStep(model.value + 1);
76
+ }
77
+ async function prev() {
78
+ if (canPrev.value)
79
+ await toStep(model.value - 1);
80
+ }
81
+ async function toStep(to) {
82
+ const from = model.value;
83
+ const hooks = to > from ? onNextHooks.value : onPrevHooks.value;
84
+ if (await runAllHooks(hooks, to, from)) {
85
+ if (to <= total.value)
86
+ step.value = to;
87
+ else
88
+ await props.onFinished();
89
+ }
90
+ }
91
+ syncRef(step, model);
92
+ provide(STEPS_CONTEXT, {
93
+ step,
94
+ next,
95
+ prev,
96
+ canNext,
97
+ canPrev,
98
+ toStep,
99
+ onPrevHooks,
100
+ onNextHooks
101
+ });
102
+ return { model };
103
+ }
104
+ });
105
+ </script>
106
+
107
+ <style lang="postcss">
108
+ .steps {
109
+ @apply w-full;
110
+ }
111
+ </style>
@@ -0,0 +1,56 @@
1
+ import { PropType } from 'vue-demi';
2
+ import { TravelHook, FinishedHook } from '.';
3
+ declare const _default: import("vue-demi").DefineComponent<{
4
+ modelValue: {
5
+ type: NumberConstructor;
6
+ default: number;
7
+ };
8
+ keepAlive: {
9
+ type: BooleanConstructor;
10
+ default: boolean;
11
+ };
12
+ onBeforePrev: {
13
+ type: PropType<TravelHook>;
14
+ default: () => boolean;
15
+ };
16
+ onBeforeNext: {
17
+ type: PropType<TravelHook>;
18
+ default: () => boolean;
19
+ };
20
+ onFinished: {
21
+ type: PropType<FinishedHook>;
22
+ default: (...args: any[]) => void;
23
+ };
24
+ }, {
25
+ model: import("vue-demi").Ref<number>;
26
+ }, unknown, {}, {}, import("vue-demi").ComponentOptionsMixin, import("vue-demi").ComponentOptionsMixin, "update:modelValue"[], "update:modelValue", import("vue-demi").VNodeProps & import("vue-demi").AllowedComponentProps & import("vue-demi").ComponentCustomProps, Readonly<import("vue-demi").ExtractPropTypes<{
27
+ modelValue: {
28
+ type: NumberConstructor;
29
+ default: number;
30
+ };
31
+ keepAlive: {
32
+ type: BooleanConstructor;
33
+ default: boolean;
34
+ };
35
+ onBeforePrev: {
36
+ type: PropType<TravelHook>;
37
+ default: () => boolean;
38
+ };
39
+ onBeforeNext: {
40
+ type: PropType<TravelHook>;
41
+ default: () => boolean;
42
+ };
43
+ onFinished: {
44
+ type: PropType<FinishedHook>;
45
+ default: (...args: any[]) => void;
46
+ };
47
+ }>> & {
48
+ "onUpdate:modelValue"?: (...args: any[]) => any;
49
+ }, {
50
+ modelValue: number;
51
+ onBeforePrev: TravelHook;
52
+ onBeforeNext: TravelHook;
53
+ keepAlive: boolean;
54
+ onFinished: FinishedHook;
55
+ }>;
56
+ export default _default;
@@ -0,0 +1,26 @@
1
+ import { ComputedRef, InjectionKey, Ref } from 'vue-demi';
2
+ export declare type TravelHook = (to: number, from: number) => boolean | Promise<boolean>;
3
+ export declare type FinishedHook = () => void | Promise<void>;
4
+ export interface StepContext {
5
+ next: () => void;
6
+ prev: () => void;
7
+ toStep: (step: number) => void;
8
+ step: Ref<number>;
9
+ canPrev: ComputedRef<boolean>;
10
+ canNext: ComputedRef<boolean>;
11
+ onPrevHooks: Ref<TravelHook[]>;
12
+ onNextHooks: Ref<TravelHook[]>;
13
+ }
14
+ export declare const STEPS_CONTEXT: InjectionKey<StepContext>;
15
+ export declare function useStep(): {
16
+ onBeforePrev: (hook: TravelHook) => void;
17
+ onBeforeNext: (hook: TravelHook) => void;
18
+ next: (...args: any[]) => void;
19
+ prev: (...args: any[]) => void;
20
+ toStep: (...args: any[]) => void;
21
+ step: Ref<number>;
22
+ canPrev: Ref<boolean>;
23
+ canNext: Ref<boolean>;
24
+ onPrevHooks: Ref<any[]>;
25
+ onNextHooks: Ref<any[]>;
26
+ };
@@ -0,0 +1,52 @@
1
+ import { tryOnUnmounted } from "@vueuse/core";
2
+ import { runAllHooks } from "./utils/hook.mjs";
3
+ import { noop } from "lodash-es";
4
+ import {
5
+ inject,
6
+ ref
7
+ } from "vue-demi";
8
+ export const STEPS_CONTEXT = Symbol("STEPS_CONTEXT");
9
+ export function useStep() {
10
+ const context = inject(STEPS_CONTEXT, () => {
11
+ console.warn("<p-step> must be placed inside <p-steps>");
12
+ return {
13
+ next: noop,
14
+ prev: noop,
15
+ toStep: noop,
16
+ step: ref(1),
17
+ canPrev: ref(false),
18
+ canNext: ref(false),
19
+ onPrevHooks: ref([]),
20
+ onNextHooks: ref([])
21
+ };
22
+ }, true);
23
+ const localPrevHooks = ref([]);
24
+ const localNextHooks = ref([]);
25
+ function onBeforePrev(hook) {
26
+ localPrevHooks.value.unshift(hook);
27
+ }
28
+ function onBeforeNext(hook) {
29
+ localNextHooks.value.unshift(hook);
30
+ }
31
+ const onPrevHookTrap = async (...args) => {
32
+ return await runAllHooks(localPrevHooks.value, ...args);
33
+ };
34
+ const onNextHookTrap = async (...args) => {
35
+ return await runAllHooks(localNextHooks.value, ...args);
36
+ };
37
+ context.onPrevHooks.value.unshift(onPrevHookTrap);
38
+ context.onNextHooks.value.unshift(onNextHookTrap);
39
+ tryOnUnmounted(() => {
40
+ const pi = context.onPrevHooks.value.indexOf(onPrevHookTrap);
41
+ const ni = context.onNextHooks.value.indexOf(onNextHookTrap);
42
+ if (pi > -1)
43
+ context.onPrevHooks.value.splice(pi, 1);
44
+ if (ni > -1)
45
+ context.onNextHooks.value.splice(ni, 1);
46
+ });
47
+ return {
48
+ ...context,
49
+ onBeforePrev,
50
+ onBeforeNext
51
+ };
52
+ }
@@ -0,0 +1,10 @@
1
+ export declare type HookFn = (...args: unknown[]) => unknown | Promise<unknown>;
2
+ export declare function runHook<H extends HookFn>(hook: H, ...args: Parameters<H>): Promise<boolean>;
3
+ export declare function runAllHooks<H extends HookFn>(hooks: Iterable<H>, ...args: Parameters<H>): Promise<boolean>;
4
+ export declare class Hook<H extends HookFn> {
5
+ protected hooks: H[];
6
+ constructor();
7
+ add(hook: H): this;
8
+ remove(hook: H): this;
9
+ run(...args: Parameters<H>): Promise<boolean>;
10
+ }
@@ -0,0 +1,34 @@
1
+ export async function runHook(hook, ...args) {
2
+ try {
3
+ return await hook(...args) !== false;
4
+ } catch {
5
+ return false;
6
+ }
7
+ }
8
+ export async function runAllHooks(hooks, ...args) {
9
+ let result = true;
10
+ for (const hook of hooks) {
11
+ result = await runHook(hook, ...args);
12
+ if (!result)
13
+ break;
14
+ }
15
+ return result;
16
+ }
17
+ export class Hook {
18
+ constructor() {
19
+ this.hooks = [];
20
+ }
21
+ add(hook) {
22
+ this.hooks.unshift(hook);
23
+ return this;
24
+ }
25
+ remove(hook) {
26
+ const index = this.hooks.indexOf(hook);
27
+ if (index > -1)
28
+ this.hooks.splice(index, 1);
29
+ return this;
30
+ }
31
+ async run(...args) {
32
+ return await runAllHooks(this.hooks, ...args);
33
+ }
34
+ }
@@ -0,0 +1,96 @@
1
+ <template>
2
+ <div
3
+ class="strengthbar"
4
+ :data-status="status">
5
+ <div
6
+ v-for="(active, i) in items"
7
+ :key="i"
8
+ class="strengthbar__bar"
9
+ :class="{ 'strengthbar--active': active }" />
10
+ </div>
11
+ </template>
12
+
13
+ <script>
14
+ import { useToNumber } from "@vueuse/core";
15
+ import {
16
+ computed,
17
+ defineComponent,
18
+ toRef
19
+ } from "vue-demi";
20
+ export default defineComponent({
21
+ props: {
22
+ length: {
23
+ type: [Number, String],
24
+ default: 6
25
+ },
26
+ value: {
27
+ type: [Number, String],
28
+ default: 0
29
+ },
30
+ min: {
31
+ type: [Number, String],
32
+ default: 0
33
+ },
34
+ max: {
35
+ type: [Number, String],
36
+ default: 6
37
+ }
38
+ },
39
+ setup(props) {
40
+ const min = useToNumber(toRef(props, "min"), { nanToZero: true });
41
+ const max = useToNumber(toRef(props, "max"), { nanToZero: true });
42
+ const value = useToNumber(toRef(props, "value"), { nanToZero: true });
43
+ const length = useToNumber(toRef(props, "length"), { nanToZero: true });
44
+ const strength = computed(() => {
45
+ return (value.value - min.value) / (max.value - min.value);
46
+ });
47
+ const items = computed(() => {
48
+ return Array.from({ length: length.value }).map((_, i) => {
49
+ return Math.round(strength.value * length.value) >= i + 1;
50
+ });
51
+ });
52
+ const status = computed(() => {
53
+ const val = strength.value * 3;
54
+ if (val > 2)
55
+ return "high";
56
+ else if (val > 1)
57
+ return "mid";
58
+ else
59
+ return "low";
60
+ });
61
+ return {
62
+ strength,
63
+ items,
64
+ status
65
+ };
66
+ }
67
+ });
68
+ </script>
69
+
70
+ <style lang="postcss">
71
+ .strengthbar {
72
+ @apply flex w-full space-x-4;
73
+
74
+ &__bar {
75
+ @apply rounded-full h-1 bg-subtle-alpha flex-grow transition-colors duration-150;
76
+ }
77
+
78
+ &&[data-status="low"] {
79
+ .strengthbar--active {
80
+ @apply bg-danger-emphasis;
81
+ }
82
+ }
83
+
84
+ &&[data-status="mid"] {
85
+ .strengthbar--active {
86
+ @apply bg-warning-emphasis;
87
+ }
88
+ }
89
+
90
+ &&[data-status="high"] {
91
+ .strengthbar--active {
92
+ @apply bg-success-emphasis;
93
+ }
94
+ }
95
+ }
96
+ </style>
@@ -0,0 +1,45 @@
1
+ declare const _default: import("vue-demi").DefineComponent<{
2
+ length: {
3
+ type: (StringConstructor | NumberConstructor)[];
4
+ default: number;
5
+ };
6
+ value: {
7
+ type: (StringConstructor | NumberConstructor)[];
8
+ default: number;
9
+ };
10
+ min: {
11
+ type: (StringConstructor | NumberConstructor)[];
12
+ default: number;
13
+ };
14
+ max: {
15
+ type: (StringConstructor | NumberConstructor)[];
16
+ default: number;
17
+ };
18
+ }, {
19
+ strength: import("vue-demi").ComputedRef<number>;
20
+ items: import("vue-demi").ComputedRef<boolean[]>;
21
+ status: import("vue-demi").ComputedRef<"high" | "mid" | "low">;
22
+ }, unknown, {}, {}, import("vue-demi").ComponentOptionsMixin, import("vue-demi").ComponentOptionsMixin, {}, string, import("vue-demi").VNodeProps & import("vue-demi").AllowedComponentProps & import("vue-demi").ComponentCustomProps, Readonly<import("vue-demi").ExtractPropTypes<{
23
+ length: {
24
+ type: (StringConstructor | NumberConstructor)[];
25
+ default: number;
26
+ };
27
+ value: {
28
+ type: (StringConstructor | NumberConstructor)[];
29
+ default: number;
30
+ };
31
+ min: {
32
+ type: (StringConstructor | NumberConstructor)[];
33
+ default: number;
34
+ };
35
+ max: {
36
+ type: (StringConstructor | NumberConstructor)[];
37
+ default: number;
38
+ };
39
+ }>>, {
40
+ length: string | number;
41
+ value: string | number;
42
+ min: string | number;
43
+ max: string | number;
44
+ }>;
45
+ export default _default;