@winchsa/ui 0.1.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 (305) hide show
  1. package/README.md +166 -0
  2. package/dist/components/Breadcrumbs.vue +46 -0
  3. package/dist/components/Breadcrumbs.vue.d.ts +6 -0
  4. package/dist/components/Drawer.vue +60 -0
  5. package/dist/components/Drawer.vue.d.ts +44 -0
  6. package/dist/components/IconBtn.vue +18 -0
  7. package/dist/components/IconBtn.vue.d.ts +30 -0
  8. package/dist/components/Modal.vue +155 -0
  9. package/dist/components/Modal.vue.d.ts +0 -0
  10. package/dist/components/SiteTitle.vue +14 -0
  11. package/dist/components/SiteTitle.vue.d.ts +2 -0
  12. package/dist/components/Toaster.vue +19 -0
  13. package/dist/components/Toaster.vue.d.ts +5 -0
  14. package/dist/components/cards/CheckboxesCard.vue +76 -0
  15. package/dist/components/cards/CheckboxesCard.vue.d.ts +20 -0
  16. package/dist/components/cards/HeaderCard.vue +31 -0
  17. package/dist/components/cards/HeaderCard.vue.d.ts +8 -0
  18. package/dist/components/cards/ImageCard.vue +73 -0
  19. package/dist/components/cards/ImageCard.vue.d.ts +63 -0
  20. package/dist/components/cards/InputCard.vue +60 -0
  21. package/dist/components/cards/InputCard.vue.d.ts +41 -0
  22. package/dist/components/cards/StaticCard.vue +37 -0
  23. package/dist/components/cards/StaticCard.vue.d.ts +33 -0
  24. package/dist/components/core/AppBarSearch.vue +345 -0
  25. package/dist/components/core/AppBarSearch.vue.d.ts +1587 -0
  26. package/dist/components/core/AppDrawerHeaderSection.vue +21 -0
  27. package/dist/components/core/AppDrawerHeaderSection.vue.d.ts +30 -0
  28. package/dist/components/core/AppSearchHeader.vue +72 -0
  29. package/dist/components/core/AppSearchHeader.vue.d.ts +7 -0
  30. package/dist/components/core/AppStepper.vue +232 -0
  31. package/dist/components/core/AppStepper.vue.d.ts +25 -0
  32. package/dist/components/core/CustomizerSection.vue +19 -0
  33. package/dist/components/core/CustomizerSection.vue.d.ts +25 -0
  34. package/dist/components/core/DialogCloseBtn.vue +20 -0
  35. package/dist/components/core/DialogCloseBtn.vue.d.ts +9 -0
  36. package/dist/components/core/MoreBtn.vue +27 -0
  37. package/dist/components/core/MoreBtn.vue.d.ts +25 -0
  38. package/dist/components/core/ScrollToTop.vue +39 -0
  39. package/dist/components/core/ScrollToTop.vue.d.ts +2 -0
  40. package/dist/components/core/app-form-elements/AppCombobox.vue +67 -0
  41. package/dist/components/core/app-form-elements/AppCombobox.vue.d.ts +0 -0
  42. package/dist/components/core/app-form-elements/AppSelect.vue +98 -0
  43. package/dist/components/core/app-form-elements/AppSelect.vue.d.ts +0 -0
  44. package/dist/components/core/app-form-elements/AppSwitch.vue +59 -0
  45. package/dist/components/core/app-form-elements/AppSwitch.vue.d.ts +27 -0
  46. package/dist/components/core/app-form-elements/AppTextField.vue +66 -0
  47. package/dist/components/core/app-form-elements/AppTextField.vue.d.ts +26 -0
  48. package/dist/components/core/app-form-elements/AppTextarea.vue +69 -0
  49. package/dist/components/core/app-form-elements/AppTextarea.vue.d.ts +26 -0
  50. package/dist/components/core/app-form-elements/CustomCheckboxes.vue +69 -0
  51. package/dist/components/core/app-form-elements/CustomCheckboxes.vue.d.ts +39 -0
  52. package/dist/components/core/app-form-elements/CustomCheckboxesWithIcon.vue +80 -0
  53. package/dist/components/core/app-form-elements/CustomCheckboxesWithIcon.vue.d.ts +39 -0
  54. package/dist/components/core/app-form-elements/CustomCheckboxesWithImage.vue +67 -0
  55. package/dist/components/core/app-form-elements/CustomCheckboxesWithImage.vue.d.ts +15 -0
  56. package/dist/components/core/app-form-elements/CustomRadios.vue +69 -0
  57. package/dist/components/core/app-form-elements/CustomRadios.vue.d.ts +40 -0
  58. package/dist/components/core/app-form-elements/CustomRadiosWithIcon.vue +98 -0
  59. package/dist/components/core/app-form-elements/CustomRadiosWithIcon.vue.d.ts +45 -0
  60. package/dist/components/core/app-form-elements/CustomRadiosWithImage.vue +69 -0
  61. package/dist/components/core/app-form-elements/CustomRadiosWithImage.vue.d.ts +53 -0
  62. package/dist/components/core/cards/AppCard.vue +45 -0
  63. package/dist/components/core/cards/AppCard.vue.d.ts +26 -0
  64. package/dist/components/core/cards/AppCardActions.vue +126 -0
  65. package/dist/components/core/cards/AppCardActions.vue.d.ts +79 -0
  66. package/dist/components/core/cards/CardStatisticsHorizontal.vue +29 -0
  67. package/dist/components/core/cards/CardStatisticsHorizontal.vue.d.ts +10 -0
  68. package/dist/components/forms/Accordion.vue +43 -0
  69. package/dist/components/forms/Accordion.vue.d.ts +35 -0
  70. package/dist/components/forms/AppLabel.vue +47 -0
  71. package/dist/components/forms/AppLabel.vue.d.ts +36 -0
  72. package/dist/components/forms/AppLink.vue +50 -0
  73. package/dist/components/forms/AppLink.vue.d.ts +27 -0
  74. package/dist/components/forms/AppNumberField.vue +85 -0
  75. package/dist/components/forms/AppNumberField.vue.d.ts +45 -0
  76. package/dist/components/forms/AppOtpInput.vue +84 -0
  77. package/dist/components/forms/AppOtpInput.vue.d.ts +16 -0
  78. package/dist/components/forms/AttachmentCropperInput.vue +228 -0
  79. package/dist/components/forms/AttachmentCropperInput.vue.d.ts +25 -0
  80. package/dist/components/forms/AttachmentInput.vue +116 -0
  81. package/dist/components/forms/AttachmentInput.vue.d.ts +20 -0
  82. package/dist/components/forms/AutocompleteInput.vue +759 -0
  83. package/dist/components/forms/AutocompleteInput.vue.d.ts +0 -0
  84. package/dist/components/forms/BankSelect.vue +43 -0
  85. package/dist/components/forms/BankSelect.vue.d.ts +19 -0
  86. package/dist/components/forms/BaseButton.vue +42 -0
  87. package/dist/components/forms/BaseButton.vue.d.ts +31 -0
  88. package/dist/components/forms/CounterInput.vue +71 -0
  89. package/dist/components/forms/CounterInput.vue.d.ts +15 -0
  90. package/dist/components/forms/DatePicker.vue +400 -0
  91. package/dist/components/forms/DatePicker.vue.d.ts +34 -0
  92. package/dist/components/forms/DatePickerRange.vue +129 -0
  93. package/dist/components/forms/DatePickerRange.vue.d.ts +23 -0
  94. package/dist/components/forms/DraggedUploadFile.vue +120 -0
  95. package/dist/components/forms/DraggedUploadFile.vue.d.ts +10 -0
  96. package/dist/components/forms/ImageCardInput.vue +234 -0
  97. package/dist/components/forms/ImageCardInput.vue.d.ts +0 -0
  98. package/dist/components/forms/InputValidationWrapper.vue +24 -0
  99. package/dist/components/forms/InputValidationWrapper.vue.d.ts +33 -0
  100. package/dist/components/forms/LicensePlateInput.vue +159 -0
  101. package/dist/components/forms/LicensePlateInput.vue.d.ts +16 -0
  102. package/dist/components/forms/ManualDate.vue +262 -0
  103. package/dist/components/forms/ManualDate.vue.d.ts +17 -0
  104. package/dist/components/forms/MobileInput.vue +118 -0
  105. package/dist/components/forms/MobileInput.vue.d.ts +49 -0
  106. package/dist/components/forms/PasswordInput.vue +29 -0
  107. package/dist/components/forms/PasswordInput.vue.d.ts +13 -0
  108. package/dist/components/forms/RangeInput.vue +48 -0
  109. package/dist/components/forms/RangeInput.vue.d.ts +5 -0
  110. package/dist/components/forms/Tabs.vue +35 -0
  111. package/dist/components/forms/Tabs.vue.d.ts +42 -0
  112. package/dist/components/forms/TimePicker.vue +370 -0
  113. package/dist/components/forms/TimePicker.vue.d.ts +23 -0
  114. package/dist/components/icons/EndMarker.vue +25 -0
  115. package/dist/components/icons/EndMarker.vue.d.ts +17 -0
  116. package/dist/components/icons/RedXIcon.vue +36 -0
  117. package/dist/components/icons/RedXIcon.vue.d.ts +2 -0
  118. package/dist/components/icons/StarFillIcon.vue +28 -0
  119. package/dist/components/icons/StarFillIcon.vue.d.ts +2 -0
  120. package/dist/components/icons/StartMarker.vue +25 -0
  121. package/dist/components/icons/StartMarker.vue.d.ts +17 -0
  122. package/dist/components/icons/WorkerIcon.vue +39 -0
  123. package/dist/components/icons/WorkerIcon.vue.d.ts +2 -0
  124. package/dist/components/loading/LoadingBar.vue +31 -0
  125. package/dist/components/loading/LoadingBar.vue.d.ts +5 -0
  126. package/dist/components/loading/LoadingDialog.vue +41 -0
  127. package/dist/components/loading/LoadingDialog.vue.d.ts +11 -0
  128. package/dist/components/loading/LoadingItem.vue +66 -0
  129. package/dist/components/loading/LoadingItem.vue.d.ts +47 -0
  130. package/dist/components/table/DataTable.vue +319 -0
  131. package/dist/components/table/DataTable.vue.d.ts +0 -0
  132. package/dist/components/table/EditableDataTable.vue +329 -0
  133. package/dist/components/table/EditableDataTable.vue.d.ts +73 -0
  134. package/dist/components/table/EditableDataTableRow.vue +243 -0
  135. package/dist/components/table/EditableDataTableRow.vue.d.ts +18 -0
  136. package/dist/components/table/FilterGenerator.vue +232 -0
  137. package/dist/components/table/FilterGenerator.vue.d.ts +14 -0
  138. package/dist/components/table/StaticTable.vue +152 -0
  139. package/dist/components/table/StaticTable.vue.d.ts +25 -0
  140. package/dist/components/table/TablePagination.vue +73 -0
  141. package/dist/components/table/TablePagination.vue.d.ts +13 -0
  142. package/dist/composables/use-is-mobile.d.ts +1 -0
  143. package/dist/composables/use-is-mobile.js +10 -0
  144. package/dist/composables/use-is-mobile.mjs +4 -0
  145. package/dist/composables/use-table-filters.d.ts +23 -0
  146. package/dist/composables/use-table-filters.js +196 -0
  147. package/dist/composables/use-table-filters.mjs +183 -0
  148. package/dist/fonts/NotoSans-Medium.ttf +0 -0
  149. package/dist/fonts/NotoSansArabic-Medium.ttf +0 -0
  150. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.eot +0 -0
  151. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.svg +9 -0
  152. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.ttf +0 -0
  153. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.woff +0 -0
  154. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.woff2 +0 -0
  155. package/dist/images/avatar.png +0 -0
  156. package/dist/images/sa.svg +1 -0
  157. package/dist/images/successful-registration.svg +15 -0
  158. package/dist/index.d.ts +66 -0
  159. package/dist/index.js +447 -0
  160. package/dist/index.mjs +128 -0
  161. package/dist/styles/@core/scss/base/_components.scss +164 -0
  162. package/dist/styles/@core/scss/base/_dark.scss +16 -0
  163. package/dist/styles/@core/scss/base/_default-layout-w-vertical-nav.scss +106 -0
  164. package/dist/styles/@core/scss/base/_default-layout.scss +16 -0
  165. package/dist/styles/@core/scss/base/_index.scss +47 -0
  166. package/dist/styles/@core/scss/base/_layouts.scss +63 -0
  167. package/dist/styles/@core/scss/base/_misc.scss +20 -0
  168. package/dist/styles/@core/scss/base/_mixins.scss +84 -0
  169. package/dist/styles/@core/scss/base/_route-transitions.scss +70 -0
  170. package/dist/styles/@core/scss/base/_utilities.scss +418 -0
  171. package/dist/styles/@core/scss/base/_utils.scss +100 -0
  172. package/dist/styles/@core/scss/base/_variables.scss +190 -0
  173. package/dist/styles/@core/scss/base/_vertical-nav.scss +264 -0
  174. package/dist/styles/@core/scss/base/libs/_perfect-scrollbar.scss +35 -0
  175. package/dist/styles/@core/scss/base/libs/vuetify/_index.scss +1 -0
  176. package/dist/styles/@core/scss/base/libs/vuetify/_overrides.scss +385 -0
  177. package/dist/styles/@core/scss/base/libs/vuetify/_variables.scss +48 -0
  178. package/dist/styles/@core/scss/base/placeholders/_default-layout-vertical-nav.scss +48 -0
  179. package/dist/styles/@core/scss/base/placeholders/_default-layout.scss +3 -0
  180. package/dist/styles/@core/scss/base/placeholders/_index.scss +5 -0
  181. package/dist/styles/@core/scss/base/placeholders/_misc.scss +7 -0
  182. package/dist/styles/@core/scss/base/placeholders/_nav.scss +26 -0
  183. package/dist/styles/@core/scss/base/placeholders/_vertical-nav.scss +84 -0
  184. package/dist/styles/@core/scss/base/skins/_bordered.scss +60 -0
  185. package/dist/styles/@core/scss/base/skins/_index.scss +1 -0
  186. package/dist/styles/@core/scss/template/_components.scss +1035 -0
  187. package/dist/styles/@core/scss/template/_default-layout-w-vertical-nav.scss +20 -0
  188. package/dist/styles/@core/scss/template/_utilities.scss +20 -0
  189. package/dist/styles/@core/scss/template/_variables.scss +67 -0
  190. package/dist/styles/@core/scss/template/_vertical-nav.scss +41 -0
  191. package/dist/styles/@core/scss/template/index.css +18764 -0
  192. package/dist/styles/@core/scss/template/index.scss +15 -0
  193. package/dist/styles/@core/scss/template/libs/apex-chart.css +90 -0
  194. package/dist/styles/@core/scss/template/libs/apex-chart.scss +99 -0
  195. package/dist/styles/@core/scss/template/libs/shepherd.css +82 -0
  196. package/dist/styles/@core/scss/template/libs/shepherd.scss +88 -0
  197. package/dist/styles/@core/scss/template/libs/vuetify/_variables.scss +461 -0
  198. package/dist/styles/@core/scss/template/libs/vuetify/index.css +741 -0
  199. package/dist/styles/@core/scss/template/libs/vuetify/index.scss +1 -0
  200. package/dist/styles/@core/scss/template/pages/misc.css +16 -0
  201. package/dist/styles/@core/scss/template/pages/misc.scss +20 -0
  202. package/dist/styles/@core/scss/template/placeholders/_default-layout-vertical-nav.scss +9 -0
  203. package/dist/styles/@core/scss/template/placeholders/_index.scss +3 -0
  204. package/dist/styles/@core/scss/template/placeholders/_nav.scss +15 -0
  205. package/dist/styles/@core/scss/template/placeholders/_vertical-nav.scss +18 -0
  206. package/dist/styles/@core/scss/template/skins/_bordered.scss +36 -0
  207. package/dist/styles/@core/scss/template/skins/_index.scss +1 -0
  208. package/dist/styles/@layouts/styles/_classes.scss +3 -0
  209. package/dist/styles/@layouts/styles/_dashboard-layout.scss +43 -0
  210. package/dist/styles/@layouts/styles/_global.scss +10 -0
  211. package/dist/styles/@layouts/styles/_mixins.scss +28 -0
  212. package/dist/styles/@layouts/styles/_placeholders.scss +53 -0
  213. package/dist/styles/@layouts/styles/_rtl.scss +7 -0
  214. package/dist/styles/@layouts/styles/_variables.scss +22 -0
  215. package/dist/styles/@layouts/styles/index.css +14 -0
  216. package/dist/styles/@layouts/styles/index.scss +2 -0
  217. package/dist/styles/assets/scss/styles.css +16099 -0
  218. package/dist/styles/assets/scss/styles.scss +246 -0
  219. package/dist/styles/assets/scss/variables/_template.scss +1 -0
  220. package/dist/styles/assets/scss/variables/_vuetify.scss +1 -0
  221. package/dist/types.d.ts +226 -0
  222. package/dist/utils/apiUrl.d.ts +1 -0
  223. package/dist/utils/apiUrl.js +15 -0
  224. package/dist/utils/apiUrl.mjs +8 -0
  225. package/dist/utils/client.d.ts +9 -0
  226. package/dist/utils/client.js +39 -0
  227. package/dist/utils/client.mjs +25 -0
  228. package/dist/utils/files.d.ts +2 -0
  229. package/dist/utils/files.js +35 -0
  230. package/dist/utils/files.mjs +22 -0
  231. package/dist/utils/formValidation.d.ts +7 -0
  232. package/dist/utils/formValidation.js +20 -0
  233. package/dist/utils/formValidation.mjs +13 -0
  234. package/dist/utils/formatters.d.ts +12 -0
  235. package/dist/utils/formatters.js +84 -0
  236. package/dist/utils/formatters.mjs +56 -0
  237. package/dist/utils/index.d.ts +9 -0
  238. package/dist/utils/index.js +104 -0
  239. package/dist/utils/index.mjs +9 -0
  240. package/dist/utils/queryParams.d.ts +4 -0
  241. package/dist/utils/queryParams.js +26 -0
  242. package/dist/utils/queryParams.mjs +18 -0
  243. package/dist/utils/ruleValidator.d.ts +28 -0
  244. package/dist/utils/ruleValidator.js +158 -0
  245. package/dist/utils/ruleValidator.mjs +144 -0
  246. package/dist/utils/toaster.d.ts +12 -0
  247. package/dist/utils/toaster.js +71 -0
  248. package/dist/utils/toaster.mjs +59 -0
  249. package/dist/utils/utils.d.ts +8 -0
  250. package/dist/utils/utils.js +70 -0
  251. package/dist/utils/utils.mjs +56 -0
  252. package/package.json +79 -0
  253. package/src/styles/@core/scss/base/_components.scss +164 -0
  254. package/src/styles/@core/scss/base/_dark.scss +16 -0
  255. package/src/styles/@core/scss/base/_default-layout-w-vertical-nav.scss +106 -0
  256. package/src/styles/@core/scss/base/_default-layout.scss +16 -0
  257. package/src/styles/@core/scss/base/_index.scss +47 -0
  258. package/src/styles/@core/scss/base/_layouts.scss +63 -0
  259. package/src/styles/@core/scss/base/_misc.scss +20 -0
  260. package/src/styles/@core/scss/base/_mixins.scss +84 -0
  261. package/src/styles/@core/scss/base/_route-transitions.scss +70 -0
  262. package/src/styles/@core/scss/base/_utilities.scss +418 -0
  263. package/src/styles/@core/scss/base/_utils.scss +100 -0
  264. package/src/styles/@core/scss/base/_variables.scss +190 -0
  265. package/src/styles/@core/scss/base/_vertical-nav.scss +264 -0
  266. package/src/styles/@core/scss/base/libs/_perfect-scrollbar.scss +35 -0
  267. package/src/styles/@core/scss/base/libs/vuetify/_index.scss +1 -0
  268. package/src/styles/@core/scss/base/libs/vuetify/_overrides.scss +385 -0
  269. package/src/styles/@core/scss/base/libs/vuetify/_variables.scss +48 -0
  270. package/src/styles/@core/scss/base/placeholders/_default-layout-vertical-nav.scss +48 -0
  271. package/src/styles/@core/scss/base/placeholders/_default-layout.scss +3 -0
  272. package/src/styles/@core/scss/base/placeholders/_index.scss +5 -0
  273. package/src/styles/@core/scss/base/placeholders/_misc.scss +7 -0
  274. package/src/styles/@core/scss/base/placeholders/_nav.scss +26 -0
  275. package/src/styles/@core/scss/base/placeholders/_vertical-nav.scss +84 -0
  276. package/src/styles/@core/scss/base/skins/_bordered.scss +60 -0
  277. package/src/styles/@core/scss/base/skins/_index.scss +1 -0
  278. package/src/styles/@core/scss/template/_components.scss +1035 -0
  279. package/src/styles/@core/scss/template/_default-layout-w-vertical-nav.scss +20 -0
  280. package/src/styles/@core/scss/template/_utilities.scss +20 -0
  281. package/src/styles/@core/scss/template/_variables.scss +67 -0
  282. package/src/styles/@core/scss/template/_vertical-nav.scss +41 -0
  283. package/src/styles/@core/scss/template/index.scss +15 -0
  284. package/src/styles/@core/scss/template/libs/apex-chart.scss +99 -0
  285. package/src/styles/@core/scss/template/libs/shepherd.scss +88 -0
  286. package/src/styles/@core/scss/template/libs/vuetify/_variables.scss +461 -0
  287. package/src/styles/@core/scss/template/libs/vuetify/index.scss +1 -0
  288. package/src/styles/@core/scss/template/pages/misc.scss +20 -0
  289. package/src/styles/@core/scss/template/placeholders/_default-layout-vertical-nav.scss +9 -0
  290. package/src/styles/@core/scss/template/placeholders/_index.scss +3 -0
  291. package/src/styles/@core/scss/template/placeholders/_nav.scss +15 -0
  292. package/src/styles/@core/scss/template/placeholders/_vertical-nav.scss +18 -0
  293. package/src/styles/@core/scss/template/skins/_bordered.scss +36 -0
  294. package/src/styles/@core/scss/template/skins/_index.scss +1 -0
  295. package/src/styles/@layouts/styles/_classes.scss +3 -0
  296. package/src/styles/@layouts/styles/_dashboard-layout.scss +43 -0
  297. package/src/styles/@layouts/styles/_global.scss +10 -0
  298. package/src/styles/@layouts/styles/_mixins.scss +28 -0
  299. package/src/styles/@layouts/styles/_placeholders.scss +53 -0
  300. package/src/styles/@layouts/styles/_rtl.scss +7 -0
  301. package/src/styles/@layouts/styles/_variables.scss +22 -0
  302. package/src/styles/@layouts/styles/index.scss +2 -0
  303. package/src/styles/assets/scss/styles.scss +246 -0
  304. package/src/styles/assets/scss/variables/_template.scss +1 -0
  305. package/src/styles/assets/scss/variables/_vuetify.scss +1 -0
@@ -0,0 +1,29 @@
1
+ <script setup>
2
+ import { VCard, VCardText, VAvatar } from "vuetify/components";
3
+ defineProps({
4
+ title: { type: String, required: true },
5
+ color: { type: String, required: false, default: "primary" },
6
+ icon: { type: String, required: true },
7
+ stats: { type: String, required: true }
8
+ });
9
+ </script>
10
+
11
+ <template>
12
+ <VCard>
13
+ <VCardText class="d-flex align-center justify-space-between">
14
+ <div>
15
+ <div class="d-flex align-center flex-wrap">
16
+ <span class="text-h5">{{ stats }}</span>
17
+ </div>
18
+ <span class="text-body-2">{{ title }}</span>
19
+ </div>
20
+
21
+ <VAvatar
22
+ :icon="icon"
23
+ :color="color"
24
+ :size="42"
25
+ variant="tonal"
26
+ />
27
+ </VCardText>
28
+ </VCard>
29
+ </template>
@@ -0,0 +1,10 @@
1
+ type __VLS_Props = {
2
+ title: string;
3
+ color?: string;
4
+ icon: string;
5
+ stats: string;
6
+ };
7
+ declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
8
+ color: string;
9
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
10
+ export default _default;
@@ -0,0 +1,43 @@
1
+ <script setup>
2
+ import { VExpansionPanels, VExpansionPanel, VExpansionPanelTitle, VExpansionPanelText, VIcon } from "vuetify/components";
3
+ import { ref } from "vue";
4
+ import BaseButton from "./BaseButton.vue";
5
+ const props = defineProps({
6
+ title: { type: String, required: false },
7
+ isOpen: { type: Boolean, required: false, default: true }
8
+ });
9
+ const panel = ref(props.isOpen ? 0 : null);
10
+ </script>
11
+
12
+ <template>
13
+ <VExpansionPanels v-model="panel">
14
+ <VExpansionPanel elevation="0">
15
+ <div class="d-flex align-center">
16
+ <VExpansionPanelTitle v-slot="{ expanded }" class="pe-2" hide-actions>
17
+ <BaseButton
18
+ color="primary"
19
+ size="32"
20
+ >
21
+ <VIcon
22
+ :icon="!expanded ? 'tabler-chevron-down' : 'tabler-chevron-up'"
23
+ />
24
+ </BaseButton>
25
+ </VExpansionPanelTitle>
26
+
27
+ <slot name="title">
28
+ {{ title }}
29
+ </slot>
30
+ </div>
31
+
32
+ <VExpansionPanelText>
33
+ <slot />
34
+ </VExpansionPanelText>
35
+ </VExpansionPanel>
36
+ </VExpansionPanels>
37
+ </template>
38
+
39
+ <style scoped>
40
+ :deep(.v-expansion-panel-title) {
41
+ width: fit-content !important;
42
+ }
43
+ </style>
@@ -0,0 +1,35 @@
1
+ import { VExpansionPanels, VExpansionPanel, VExpansionPanelTitle, VExpansionPanelText, VIcon } from 'vuetify/components';
2
+ import BaseButton from './BaseButton.vue';
3
+ type __VLS_Props = {
4
+ title?: string;
5
+ isOpen?: boolean;
6
+ };
7
+ declare const panel: import("vue").Ref<number | null, number | null>;
8
+ declare const __VLS_ctx: InstanceType<__VLS_PickNotAny<typeof __VLS_self, new () => {}>>;
9
+ declare var __VLS_21: {}, __VLS_27: {};
10
+ type __VLS_Slots = __VLS_PrettifyGlobal<__VLS_OmitStringIndex<typeof __VLS_ctx.$slots> & {
11
+ title?: (props: typeof __VLS_21) => any;
12
+ } & {
13
+ default?: (props: typeof __VLS_27) => any;
14
+ }>;
15
+ declare const __VLS_self: import("vue").DefineComponent<__VLS_Props, {
16
+ VExpansionPanels: typeof VExpansionPanels;
17
+ VExpansionPanel: typeof VExpansionPanel;
18
+ VExpansionPanelTitle: typeof VExpansionPanelTitle;
19
+ VExpansionPanelText: typeof VExpansionPanelText;
20
+ VIcon: typeof VIcon;
21
+ BaseButton: typeof BaseButton;
22
+ panel: typeof panel;
23
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
24
+ isOpen: boolean;
25
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
26
+ declare const __VLS_component: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
27
+ isOpen: boolean;
28
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
29
+ declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
30
+ export default _default;
31
+ type __VLS_WithSlots<T, S> = T & {
32
+ new (): {
33
+ $slots: S;
34
+ };
35
+ };
@@ -0,0 +1,47 @@
1
+ <script setup>
2
+ import { VValidation, VLabel, VMessages } from "vuetify/components";
3
+ import { computed } from "vue";
4
+ import { useI18n } from "vue-i18n";
5
+ defineEmits(["update:modelValue"]);
6
+ const props = defineProps({
7
+ class: { type: String, required: false },
8
+ label: { type: String, required: false },
9
+ rules: { type: Array, required: false },
10
+ errorMessages: { type: String, required: false },
11
+ modelValue: { type: null, required: false }
12
+ });
13
+ const { t } = useI18n();
14
+ const LangLabel = computed(() => props.label ? t(props.label) : "");
15
+ </script>
16
+
17
+ <template>
18
+ <div>
19
+ <VValidation
20
+ v-slot="{ errorMessages: validationErrors, isValid }"
21
+ :model-value="modelValue"
22
+ :rules="rules"
23
+ validate-on="input lazy"
24
+ @update:model-value="val => $emit('update:modelValue', val)"
25
+ >
26
+ <div
27
+ class="d-flex flex-column w-100"
28
+ :class="props.class"
29
+ >
30
+ <VLabel
31
+ v-if="label"
32
+ class="mb-2 text-body-2 text-high-emphasis app-font-size-13"
33
+ :text="LangLabel"
34
+ />
35
+
36
+ <slot />
37
+
38
+ <VMessages
39
+ v-if="isValid.value === false || errorMessages?.length !== 0"
40
+ class="text-start"
41
+ :messages="[validationErrors.value, errorMessages]"
42
+ :active="isValid.value === false || errorMessages?.length !== 0"
43
+ />
44
+ </div>
45
+ </VValidation>
46
+ </div>
47
+ </template>
@@ -0,0 +1,36 @@
1
+ import { VValidation, VLabel, VMessages } from 'vuetify/components';
2
+ type __VLS_Props = {
3
+ class?: string;
4
+ label?: string;
5
+ rules?: ((value: unknown) => string)[];
6
+ errorMessages?: string;
7
+ modelValue?: string | number | undefined | null;
8
+ };
9
+ declare const LangLabel: import("vue").ComputedRef<string>;
10
+ declare const __VLS_ctx: InstanceType<__VLS_PickNotAny<typeof __VLS_self, new () => {}>>;
11
+ declare var __VLS_13: {};
12
+ type __VLS_Slots = __VLS_PrettifyGlobal<__VLS_OmitStringIndex<typeof __VLS_ctx.$slots> & {
13
+ default?: (props: typeof __VLS_13) => any;
14
+ }>;
15
+ declare const __VLS_self: import("vue").DefineComponent<__VLS_Props, {
16
+ VValidation: typeof VValidation;
17
+ VLabel: typeof VLabel;
18
+ VMessages: typeof VMessages;
19
+ LangLabel: typeof LangLabel;
20
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
21
+ "update:modelValue": (value: string | number | null | undefined) => any;
22
+ }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
23
+ "onUpdate:modelValue"?: ((value: string | number | null | undefined) => any) | undefined;
24
+ }>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
25
+ declare const __VLS_component: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
26
+ "update:modelValue": (value: string | number | null | undefined) => any;
27
+ }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
28
+ "onUpdate:modelValue"?: ((value: string | number | null | undefined) => any) | undefined;
29
+ }>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
30
+ declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
31
+ export default _default;
32
+ type __VLS_WithSlots<T, S> = T & {
33
+ new (): {
34
+ $slots: S;
35
+ };
36
+ };
@@ -0,0 +1,50 @@
1
+ <script setup>
2
+ import { RouterLink } from "vue-router";
3
+ import { computed } from "vue";
4
+ defineOptions({
5
+ inheritAttrs: false
6
+ });
7
+ const props = defineProps({
8
+ // add @ts-ignore if using TypeScript
9
+ ...RouterLink.props,
10
+ to: {
11
+ type: [String, Object],
12
+ default: void 0
13
+ },
14
+ withoutDefaultClass: {
15
+ type: Boolean,
16
+ default: false
17
+ }
18
+ });
19
+ const isExternalLink = computed(() => {
20
+ return typeof props.to === "string" && (props.to.startsWith("http") || props.to.startsWith("https"));
21
+ });
22
+ </script>
23
+
24
+ <template>
25
+ <a
26
+ v-if="isExternalLink"
27
+ v-bind="$attrs"
28
+ :href="to"
29
+ target="_blank"
30
+ :class="[{ 'hover-underline': !withoutDefaultClass }, ...($attrs?.class || [])]"
31
+ >
32
+ <slot />
33
+ </a>
34
+
35
+ <RouterLink
36
+ v-else-if="to"
37
+ v-bind="$attrs"
38
+ :to="to"
39
+ :class="[{ 'hover-underline': !withoutDefaultClass }, ...($attrs?.class || [])]"
40
+ >
41
+ <slot />
42
+ </RouterLink>
43
+
44
+ <span
45
+ v-else
46
+ v-bind="$attrs"
47
+ >
48
+ <slot />
49
+ </span>
50
+ </template>
@@ -0,0 +1,27 @@
1
+ import { RouterLink } from 'vue-router';
2
+ declare const isExternalLink: import("vue").ComputedRef<boolean>;
3
+ declare const __VLS_ctx: InstanceType<__VLS_PickNotAny<typeof __VLS_self, new () => {}>>;
4
+ declare var __VLS_1: {}, __VLS_8: {}, __VLS_10: {};
5
+ type __VLS_Slots = __VLS_PrettifyGlobal<__VLS_OmitStringIndex<typeof __VLS_ctx.$slots> & {
6
+ default?: (props: typeof __VLS_1) => any;
7
+ } & {
8
+ default?: (props: typeof __VLS_8) => any;
9
+ } & {
10
+ default?: (props: typeof __VLS_10) => any;
11
+ }>;
12
+ declare const __VLS_self: import("vue").DefineComponent<{}, {
13
+ RouterLink: typeof RouterLink;
14
+ isExternalLink: typeof isExternalLink;
15
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {} | {
16
+ [x: string]: any;
17
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
18
+ declare const __VLS_component: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {} | {
19
+ [x: string]: any;
20
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
21
+ declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
22
+ export default _default;
23
+ type __VLS_WithSlots<T, S> = T & {
24
+ new (): {
25
+ $slots: S;
26
+ };
27
+ };
@@ -0,0 +1,85 @@
1
+ <script setup>
2
+ import { ref, watch, useAttrs, computed } from "vue";
3
+ import { VTextField, VLabel } from "vuetify/components";
4
+ import { useI18n } from "vue-i18n";
5
+ defineOptions({
6
+ name: "AppTextField",
7
+ inheritAttrs: false
8
+ });
9
+ const props = defineProps({
10
+ modelValue: { type: [String, null], required: false, default: null }
11
+ });
12
+ const { t } = useI18n();
13
+ const numberValue = ref(null);
14
+ const elementId = computed(() => {
15
+ const attrs = useAttrs();
16
+ const _elementIdToken = attrs.id || attrs.label;
17
+ return _elementIdToken ? `AppTextField-${_elementIdToken}-${Math.random().toString(36).slice(2, 7)}` : void 0;
18
+ });
19
+ const label = computed(() => useAttrs()?.label);
20
+ const LangLabel = computed(() => label.value ? t(label.value) : "");
21
+ const emit = defineEmits(["update:modelValue"]);
22
+ const placeholder = computed(() => {
23
+ if (useAttrs()?.placeholder) {
24
+ return useAttrs()?.placeholder;
25
+ }
26
+ if (label.value) {
27
+ return t("inputs.placeholder", {
28
+ name: LangLabel.value
29
+ });
30
+ }
31
+ return "";
32
+ });
33
+ watch(() => props.modelValue, () => {
34
+ numberValue.value = props.modelValue?.replace(/\D/g, "");
35
+ emit("update:modelValue", numberValue.value);
36
+ }, {
37
+ immediate: true
38
+ });
39
+ const validateInput = (event) => {
40
+ const input = event.target;
41
+ numberValue.value = numberValue.value?.replace(/\D/g, "") ?? null;
42
+ input.value = numberValue.value ?? "";
43
+ emit("update:modelValue", numberValue.value);
44
+ };
45
+ </script>
46
+
47
+ <template>
48
+ <div
49
+ class="AppTextField flex-grow-1"
50
+ :class="$attrs.class"
51
+ >
52
+ <VLabel
53
+ v-if="label"
54
+ :for="elementId"
55
+ class="mb-2 text-body-2 text-high-emphasis app-font-size-13"
56
+ :text="LangLabel"
57
+ />
58
+ <VTextField
59
+ v-bind="{
60
+ ...$attrs,
61
+ class: null,
62
+ label: void 0,
63
+ variant: 'outlined',
64
+ id: elementId
65
+ }"
66
+ v-model="numberValue"
67
+ :placeholder="placeholder"
68
+ class="app-font-size-13"
69
+ @input="validateInput"
70
+ >
71
+ <template
72
+ v-for="(_, name) in $slots"
73
+ #[name]="slotProps"
74
+ >
75
+ <slot
76
+ :name="name"
77
+ v-bind="slotProps || {}"
78
+ />
79
+ </template>
80
+ <template #details>
81
+ <span class="app-h-10px" />
82
+ </template>
83
+ </VTextField>
84
+ </div>
85
+ </template>
@@ -0,0 +1,45 @@
1
+ import { VTextField, VLabel } from 'vuetify/components';
2
+ type __VLS_Props = {
3
+ modelValue?: string | null;
4
+ };
5
+ declare const numberValue: import("vue").Ref<string | null, string | null>;
6
+ declare const elementId: import("vue").ComputedRef<string | undefined>;
7
+ declare const label: import("vue").ComputedRef<string | null>;
8
+ declare const LangLabel: import("vue").ComputedRef<string>;
9
+ declare const placeholder: import("vue").ComputedRef<string>;
10
+ declare const validateInput: (event: InputEvent) => void;
11
+ declare const __VLS_ctx: InstanceType<__VLS_PickNotAny<typeof __VLS_self, new () => {}>>;
12
+ declare var __VLS_14: any, __VLS_15: any;
13
+ type __VLS_Slots = __VLS_PrettifyGlobal<__VLS_OmitStringIndex<typeof __VLS_ctx.$slots> & {
14
+ [K in NonNullable<typeof __VLS_14>]?: (props: typeof __VLS_15) => any;
15
+ }>;
16
+ declare const __VLS_self: import("vue").DefineComponent<__VLS_Props, {
17
+ VTextField: typeof VTextField;
18
+ VLabel: typeof VLabel;
19
+ numberValue: typeof numberValue;
20
+ elementId: typeof elementId;
21
+ label: typeof label;
22
+ LangLabel: typeof LangLabel;
23
+ placeholder: typeof placeholder;
24
+ validateInput: typeof validateInput;
25
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
26
+ "update:modelValue": (value: string | null) => any;
27
+ }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
28
+ "onUpdate:modelValue"?: ((value: string | null) => any) | undefined;
29
+ }>, {
30
+ modelValue: string | null;
31
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
32
+ declare const __VLS_component: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
33
+ "update:modelValue": (value: string | null) => any;
34
+ }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
35
+ "onUpdate:modelValue"?: ((value: string | null) => any) | undefined;
36
+ }>, {
37
+ modelValue: string | null;
38
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
39
+ declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
40
+ export default _default;
41
+ type __VLS_WithSlots<T, S> = T & {
42
+ new (): {
43
+ $slots: S;
44
+ };
45
+ };
@@ -0,0 +1,84 @@
1
+ <script setup>
2
+ import { onMounted, ref } from "vue";
3
+ import { useI18n } from "vue-i18n";
4
+ import AppTextField from "../core/app-form-elements/AppTextField.vue";
5
+ const props = defineProps({
6
+ totalInput: { type: Number, required: false, default: 4 },
7
+ modelValue: { type: String, required: false, default: "" },
8
+ errorMessages: { type: String, required: false, default: "" },
9
+ isAppRtl: { type: Boolean, required: false }
10
+ });
11
+ const { t } = useI18n();
12
+ const emit = defineEmits(["update:modelValue"]);
13
+ const digits = ref([]);
14
+ const refOtpComp = ref(null);
15
+ onMounted(() => {
16
+ if (props.modelValue) {
17
+ digits.value = props.modelValue.split("");
18
+ }
19
+ });
20
+ const handleBackspace = (event, index) => {
21
+ digits.value[index - 1] = "";
22
+ if (refOtpComp.value !== null && index > 1) {
23
+ const inputEl = refOtpComp.value.children[index - 2].querySelector("input");
24
+ if (inputEl) {
25
+ inputEl.focus();
26
+ }
27
+ }
28
+ };
29
+ const handleNextInput = (event, index) => {
30
+ digits.value[index - 1] = event.key;
31
+ if (refOtpComp.value !== null && index !== 0 && index < refOtpComp.value.children.length) {
32
+ const inputEl = refOtpComp.value.children[index].querySelector("input");
33
+ if (inputEl) {
34
+ inputEl.focus();
35
+ }
36
+ }
37
+ };
38
+ const handleKeyDown = (event, index) => {
39
+ if (event.code !== "Tab" && event.code !== "ArrowRight" && event.code !== "ArrowLeft") {
40
+ event.preventDefault();
41
+ }
42
+ if (event.code === "Backspace") {
43
+ handleBackspace(event, index);
44
+ }
45
+ if (/^([0-9])$/.test(event.key)) {
46
+ handleNextInput(event, index);
47
+ }
48
+ emit("update:modelValue", digits.value.join(""));
49
+ };
50
+ </script>
51
+
52
+ <template>
53
+ <div>
54
+ <h6 class="text-h6 mb-3">
55
+ {{ t('mobile_verification_enter_code') }}
56
+ </h6>
57
+ <div
58
+ ref="refOtpComp"
59
+ class="d-flex align-center gap-4 otp-input"
60
+ :class="{
61
+ 'flex-row-reverse': isAppRtl
62
+ }"
63
+ >
64
+ <AppTextField
65
+ v-for="i in props.totalInput"
66
+ :key="i"
67
+ :model-value="digits[i - 1]"
68
+ maxlength="1"
69
+ :error="errorMessages?.length > 0"
70
+ @keydown="handleKeyDown($event, i)"
71
+ />
72
+ </div>
73
+ <div class="text-error mt-2">
74
+ {{ errorMessages }}
75
+ </div>
76
+ </div>
77
+ </template>
78
+
79
+ <style>
80
+ .otp-input input {
81
+ font-size: 1.25rem;
82
+ text-align: center;
83
+ }
84
+ </style>
@@ -0,0 +1,16 @@
1
+ type __VLS_Props = {
2
+ totalInput?: number;
3
+ modelValue?: string;
4
+ errorMessages?: string;
5
+ isAppRtl?: boolean;
6
+ };
7
+ declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
8
+ "update:modelValue": (value: string | number) => any;
9
+ }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
10
+ "onUpdate:modelValue"?: ((value: string | number) => any) | undefined;
11
+ }>, {
12
+ modelValue: string;
13
+ errorMessages: string;
14
+ totalInput: number;
15
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
16
+ export default _default;