adata-ui 2.1.22 → 2.1.24

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 (413) hide show
  1. package/-error.vue +170 -170
  2. package/.editorconfig +12 -12
  3. package/.gitlab-ci.yml +16 -16
  4. package/.nuxtrc +1 -1
  5. package/.nvmrc +1 -1
  6. package/.playground/app.config.ts +5 -5
  7. package/.playground/nuxt.config.ts +3 -3
  8. package/README.md +75 -75
  9. package/app.config.ts +28 -28
  10. package/app.vue +8 -8
  11. package/assets/styles/index.scss +104 -104
  12. package/assets/styles/modules/_base.scss +5 -5
  13. package/assets/styles/modules/_typography.scss +152 -152
  14. package/components/elements/README.md +1 -1
  15. package/components/elements/a-select-row/index.vue +140 -140
  16. package/components/elements/accordion/AAccordion.vue +197 -197
  17. package/components/elements/accordion/AAccordionGroup/AAccordionGroup.vue +145 -145
  18. package/components/elements/accordion/AAccordionGroup/types.ts +20 -20
  19. package/components/elements/accordion/AAccordionGroup/ui.config.ts +22 -22
  20. package/components/elements/accordion/types.ts +14 -14
  21. package/components/elements/accordion/ui.config.ts +22 -22
  22. package/components/elements/alert/AAlert.vue +65 -65
  23. package/components/elements/banner/ABanner.vue +49 -49
  24. package/components/elements/bg-block/ABgBlock.vue +11 -11
  25. package/components/elements/button/AButton.vue +188 -188
  26. package/components/elements/button/types.ts +24 -24
  27. package/components/elements/button-login/index.vue +21 -21
  28. package/components/elements/calendar/ACalendar.vue +83 -83
  29. package/components/elements/carousel/ACarousel.vue +159 -159
  30. package/components/elements/carousel/config.ui.ts +15 -15
  31. package/components/elements/carousel/types.ts +18 -18
  32. package/components/elements/chip-wrapper/AChipWrapper.vue +80 -80
  33. package/components/elements/chip-wrapper/types.ts +12 -12
  34. package/components/elements/chips/AChips.vue +32 -32
  35. package/components/elements/companies/AOurClients.vue +42 -42
  36. package/components/elements/curve-block/ACurveBlock.vue +291 -291
  37. package/components/elements/digit-badge/ADigitBadge.vue +83 -83
  38. package/components/elements/error-template/index.vue +48 -48
  39. package/components/elements/error-template/types.ts +23 -23
  40. package/components/elements/feature-description/AFeatureDescription.vue +112 -112
  41. package/components/elements/illustrations/noAccess.vue +71 -71
  42. package/components/elements/infinite-carousel/AInfiniteCarousel.vue +57 -57
  43. package/components/elements/infinite-scroll/AInfiniteScroll.vue +33 -33
  44. package/components/elements/leave-note/ALeaveNote.vue +78 -78
  45. package/components/elements/pagination/APagination.vue +110 -110
  46. package/components/elements/photos-animation/APhotosAnimation.vue +85 -85
  47. package/components/elements/select/ASelect.vue +445 -445
  48. package/components/elements/select/ASelectMobile.vue +186 -186
  49. package/components/elements/select/ui/select-button.vue +112 -112
  50. package/components/elements/select/ui/select-list.vue +99 -99
  51. package/components/elements/show-more/AShowMore.vue +35 -35
  52. package/components/elements/skeleton/ASkeleton.vue +44 -44
  53. package/components/elements/star-rating/AStarRating.vue +181 -181
  54. package/components/elements/star-rating/types.ts +7 -7
  55. package/components/elements/star-rating/ui/Star.vue +74 -74
  56. package/components/elements/status-badge/AStatusBadge.vue +74 -74
  57. package/components/elements/table/ATable.vue +93 -93
  58. package/components/elements/table/table.config.ts +32 -32
  59. package/components/elements/tree-select/ATreeSelect.vue +169 -169
  60. package/components/elements/tree-select/TreeService.ts +249 -249
  61. package/components/elements/tree-select/components/tree-select-nodes.vue +90 -90
  62. package/components/elements/tree-select/types.ts +34 -34
  63. package/components/elements/tree-select-mobile/ATreeSelectMobile.vue +79 -79
  64. package/components/elements/tree-select-mobile/components/ATreeSelectNodesMobile.vue +175 -175
  65. package/components/features/color-mode/AColorMode.client.vue +53 -53
  66. package/components/features/dropdown/ADropdown.vue +124 -124
  67. package/components/features/go-top/GoTop.vue +58 -58
  68. package/components/features/lang-switcher/lang-switcher.vue +63 -63
  69. package/components/features/payment/banner/BasicPlusLimitBanner.vue +104 -104
  70. package/components/features/payment/banner/PaymentBanner.vue +108 -108
  71. package/components/features/payment/banner/UpSellBanner.vue +125 -125
  72. package/components/features/payment/process/PaymentKaspiQrSidePanel.vue +161 -161
  73. package/components/features/payment/process/PaymentKaspiRedirectSidePanel.vue +112 -112
  74. package/components/features/payment/process/PaymentMethodSidePanel.vue +121 -121
  75. package/components/features/payment/process/PaymentProcess.vue +138 -138
  76. package/components/features/payment/process/PaymentTopUpSidePanel.vue +133 -133
  77. package/components/features/pk-mobile-services/APkMobileServices.vue +149 -149
  78. package/components/features//321/201hange-version/AChangeVersion.vue +20 -20
  79. package/components/forms/README.md +1 -1
  80. package/components/forms/checkbox/ACheckbox.vue +149 -149
  81. package/components/forms/feedback-form/FeedbackForm.vue +177 -177
  82. package/components/forms/input/button/AInputButton.vue +53 -53
  83. package/components/forms/input/date/AInputDate.vue +213 -213
  84. package/components/forms/input/password/AInputPassword.vue +53 -53
  85. package/components/forms/input/standard/AInputStandard.vue +412 -412
  86. package/components/forms/input/textarea/ATextarea.vue +200 -200
  87. package/components/forms/radio-button/ARadioButton.vue +95 -95
  88. package/components/forms/request-demo/ARequestDemo.vue +108 -108
  89. package/components/forms/toggle/AToggle.vue +157 -157
  90. package/components/forms/toggle/types.ts +16 -16
  91. package/components/modals/AConfirmationEmail.vue +40 -40
  92. package/components/modals/AboutTariffModal.vue +114 -114
  93. package/components/modals/AnotherDeviceModal.vue +60 -60
  94. package/components/modals/ApplicationAcceptedModal.vue +47 -47
  95. package/components/modals/ConnectingTariffModal.vue +67 -67
  96. package/components/modals/ContactsMobileModel.vue +182 -182
  97. package/components/modals/ContentNavigationModal.vue +355 -355
  98. package/components/modals/Insufficient-funds-modal.vue +77 -77
  99. package/components/modals/LimitReachedModal.vue +30 -30
  100. package/components/modals/NoAccessModal.vue +37 -37
  101. package/components/modals/PaymentMethodModal.vue +101 -101
  102. package/components/modals/RedirectsBanksModal.vue +69 -69
  103. package/components/modals/ReplenishModal.vue +132 -132
  104. package/components/modals/ReportBugConfirmModal.vue +30 -30
  105. package/components/modals/ReportBugModal.vue +158 -156
  106. package/components/modals/Resend.vue +82 -82
  107. package/components/modals/SubmitApplicationModal.vue +123 -123
  108. package/components/modals/id/AuthModal.vue +82 -82
  109. package/components/modals/id/IdAutoLogoutModal.vue +45 -45
  110. package/components/modals/id/IdBanner.vue +61 -61
  111. package/components/modals/id/IdConfirmAccountOtpModal.vue +186 -186
  112. package/components/modals/id/IdConfirmSuccessfulModal.vue +41 -41
  113. package/components/modals/id/IdLoginModal.vue +330 -330
  114. package/components/modals/id/IdModals.vue +114 -114
  115. package/components/modals/id/IdNewPasswordModal.vue +129 -129
  116. package/components/modals/id/IdOtpInput.vue +155 -155
  117. package/components/modals/id/IdPasswordSuccessfulModal.vue +25 -25
  118. package/components/modals/id/IdRecoveryModal.vue +117 -117
  119. package/components/modals/id/IdRegistrationModal.vue +215 -215
  120. package/components/modals/id/IdResetPasswordOtpModal.vue +158 -158
  121. package/components/modals/id/IdTwoFactorModal.vue +130 -130
  122. package/components/navigation/README.md +1 -1
  123. package/components/navigation/bottom-navigation/ABottomNavigation.vue +106 -106
  124. package/components/navigation/breadcrumbs/ABreadcrumbs.vue +66 -66
  125. package/components/navigation/breadcrumbs/types.ts +4 -4
  126. package/components/navigation/footer/AFooter.vue +279 -279
  127. package/components/navigation/footer/ui/a-footer-accordion.vue +118 -118
  128. package/components/navigation/header/AHeader.vue +217 -217
  129. package/components/navigation/header/AlmatyContacts.vue +145 -145
  130. package/components/navigation/header/AstanaContacts.vue +67 -67
  131. package/components/navigation/header/CardGallery.vue +249 -249
  132. package/components/navigation/header/ContactMenu.vue +114 -114
  133. package/components/navigation/header/HeaderLink.vue +275 -267
  134. package/components/navigation/header/ListItem.vue +31 -31
  135. package/components/navigation/header/NavCard.vue +41 -41
  136. package/components/navigation/header/NavList.vue +131 -131
  137. package/components/navigation/header/NotificationsMenu.vue +51 -51
  138. package/components/navigation/header/ProductMenu.vue +143 -143
  139. package/components/navigation/header/ProfileMenu.vue +194 -194
  140. package/components/navigation/header/TopHeader.vue +194 -194
  141. package/components/navigation/header/types.ts +28 -28
  142. package/components/navigation/line-tabs/ALineTabs.vue +111 -111
  143. package/components/navigation/line-tabs/types.ts +21 -21
  144. package/components/navigation/mobile-navigation/AMobileNavigation.vue +104 -104
  145. package/components/navigation/pill-tabs/APillTabs.vue +171 -171
  146. package/components/navigation/pill-tabs/types.ts +23 -23
  147. package/components/navigation/side-navigation/ASideNavigation.vue +406 -406
  148. package/components/overlays/README.md +1 -1
  149. package/components/overlays/modal/AModal.vue +332 -332
  150. package/components/overlays/side-panel/ASidePanel.vue +439 -439
  151. package/components/overlays/sideover/ASlideover.vue +351 -351
  152. package/components/overlays/tooltip/ATooltip.vue +237 -237
  153. package/components/transitions/ATransitionHeight.vue +67 -67
  154. package/components/utils/index.ts +19 -19
  155. package/components/utils/removeTrailingSlash.ts +7 -7
  156. package/composables/highlight.ts +18 -18
  157. package/composables/modalsState.ts +8 -8
  158. package/composables/projectState.ts +2 -2
  159. package/composables/useAdaptive.ts +46 -46
  160. package/composables/useBuyTariffs.ts +91 -91
  161. package/composables/useCarouselScroll.ts +49 -49
  162. package/composables/useHeaderNavigationLinks.ts +453 -453
  163. package/composables/useIdModals.ts +36 -36
  164. package/composables/usePayment.ts +74 -74
  165. package/composables/useUIValidation.ts +16 -16
  166. package/composables/useUrls.ts +21 -21
  167. package/eslint.config.mjs +45 -45
  168. package/i18n/i18n.config.ts +21 -21
  169. package/i18n.config.ts +21 -21
  170. package/icons/adata-logo.vue +17 -17
  171. package/icons/ai-assistant.vue +13 -13
  172. package/icons/akimat.vue +20 -20
  173. package/icons/arrow/arrow-bottom-left-on-square.vue +5 -5
  174. package/icons/arrow/arrow-circle-down.vue +16 -16
  175. package/icons/arrow/arrow-circle-reset.vue +16 -16
  176. package/icons/arrow/arrow-corner.vue +9 -9
  177. package/icons/arrow/arrow-graph-down.vue +13 -13
  178. package/icons/arrow/arrow-graph-up.vue +14 -14
  179. package/icons/arrow/arrow-square-down.vue +15 -15
  180. package/icons/arrow/arrow-top-right-on-square.vue +6 -6
  181. package/icons/arrow-currency-gray.vue +5 -5
  182. package/icons/arrow-currency-green.vue +5 -5
  183. package/icons/arrow-currency-red.vue +5 -5
  184. package/icons/arrow-side-up.vue +6 -6
  185. package/icons/avatar.vue +12 -12
  186. package/icons/bank.vue +5 -5
  187. package/icons/block.vue +16 -16
  188. package/icons/bookmark/bookmark-filled.vue +18 -18
  189. package/icons/bookmark/bookmark.vue +5 -5
  190. package/icons/browsers/browser-duck.vue +65 -65
  191. package/icons/browsers/browser-google.vue +30 -30
  192. package/icons/browsers/browser-yandex.vue +13 -13
  193. package/icons/building-vector.vue +7 -7
  194. package/icons/calculator.vue +7 -7
  195. package/icons/calendar.vue +24 -24
  196. package/icons/car.vue +7 -7
  197. package/icons/chart-bar.vue +5 -5
  198. package/icons/chart-pie.vue +16 -16
  199. package/icons/check/check-circle.vue +6 -6
  200. package/icons/check/check-shield.vue +14 -14
  201. package/icons/check/check.vue +17 -17
  202. package/icons/check/checkmark-circle.vue +6 -6
  203. package/icons/check-sb.vue +7 -7
  204. package/icons/checkbox/checkbox-active.vue +17 -17
  205. package/icons/checkbox/checkbox-empty.vue +10 -10
  206. package/icons/checkbox/checkbox-intermediate.vue +7 -7
  207. package/icons/chevron/chevron-down.vue +5 -5
  208. package/icons/chevron/chevron-left.vue +5 -5
  209. package/icons/chevron/chevron-right.vue +5 -5
  210. package/icons/chevron/chevron-up.vue +5 -5
  211. package/icons/chevron/double-chevron-right.vue +12 -12
  212. package/icons/clipboard-text.vue +7 -7
  213. package/icons/clock.vue +25 -25
  214. package/icons/close.vue +16 -16
  215. package/icons/company/company-bazis.vue +21 -21
  216. package/icons/company/company-bereke.vue +25 -25
  217. package/icons/company/company-bigroup.vue +16 -16
  218. package/icons/company/company-erg.vue +17 -17
  219. package/icons/company/company-forte.vue +21 -21
  220. package/icons/company/company-halyk.vue +15 -15
  221. package/icons/company/company-jusan.vue +31 -31
  222. package/icons/company/company-kaspi.vue +14 -14
  223. package/icons/company/company-mycar.vue +13 -13
  224. package/icons/company/company-samruk.vue +21 -21
  225. package/icons/company-egov-small.vue +15 -15
  226. package/icons/company.vue +8 -8
  227. package/icons/copy.vue +7 -7
  228. package/icons/currency/currency-dollar.vue +16 -16
  229. package/icons/currency/currency-down.vue +22 -22
  230. package/icons/currency/currency-eur.vue +57 -57
  231. package/icons/currency/currency-rub.vue +7 -7
  232. package/icons/currency/currency-tenge.vue +9 -9
  233. package/icons/currency/currency-usd.vue +221 -221
  234. package/icons/currency/currency-yuan.vue +25 -25
  235. package/icons/default-avatar.vue +20 -20
  236. package/icons/delete.vue +7 -7
  237. package/icons/document.vue +5 -5
  238. package/icons/download.vue +11 -11
  239. package/icons/edit.vue +7 -7
  240. package/icons/education.vue +16 -16
  241. package/icons/egov-small.vue +7 -7
  242. package/icons/excel-icon.vue +14 -14
  243. package/icons/expand-window.vue +7 -7
  244. package/icons/eye-closed.vue +26 -26
  245. package/icons/eye-open.vue +7 -7
  246. package/icons/eye-opened.vue +23 -23
  247. package/icons/file/file.vue +16 -16
  248. package/icons/file/files.vue +16 -16
  249. package/icons/filter.vue +5 -5
  250. package/icons/flag.vue +7 -7
  251. package/icons/gift.vue +8 -8
  252. package/icons/globe.vue +16 -16
  253. package/icons/google.vue +41 -41
  254. package/icons/gradiend-icons/files-gradient.vue +22 -0
  255. package/icons/gradiend-icons/hammer-gradient.vue +62 -0
  256. package/icons/graph-pie.vue +14 -14
  257. package/icons/hand/hand-thumb-up-filled.vue +5 -5
  258. package/icons/hand/hand-thumb-up.vue +5 -5
  259. package/icons/hand-with-phone/hand-with-phone-dark.vue +52 -52
  260. package/icons/hand-with-phone/hand-with-phone-light.vue +52 -52
  261. package/icons/handshake.vue +5 -5
  262. package/icons/hcheck.vue +14 -14
  263. package/icons/hdocument.vue +7 -7
  264. package/icons/history.vue +5 -5
  265. package/icons/horizontal-more.vue +13 -13
  266. package/icons/hot-line.vue +6 -6
  267. package/icons/hummer.vue +16 -16
  268. package/icons/id.vue +7 -7
  269. package/icons/info/info-circle.vue +29 -29
  270. package/icons/invoice.vue +7 -7
  271. package/icons/judge.vue +14 -14
  272. package/icons/kaspi-qr.vue +13 -13
  273. package/icons/link-chain.vue +28 -28
  274. package/icons/link.vue +7 -7
  275. package/icons/linkedin.vue +24 -24
  276. package/icons/loader-circle.vue +27 -27
  277. package/icons/location.vue +8 -8
  278. package/icons/lock.vue +5 -5
  279. package/icons/logo.vue +15 -15
  280. package/icons/logout.vue +16 -16
  281. package/icons/magnify/magnifying-glass-minus.vue +8 -8
  282. package/icons/magnify/magnifying-glass-plus.vue +9 -9
  283. package/icons/magnify/magnifying-glass.vue +9 -9
  284. package/icons/mail.vue +7 -7
  285. package/icons/mailru.vue +34 -34
  286. package/icons/main-filter.vue +5 -5
  287. package/icons/map/map-pin-filled.vue +7 -7
  288. package/icons/map/map-pin-rect.vue +15 -15
  289. package/icons/map/map-pin.vue +7 -7
  290. package/icons/map-marker-start.vue +7 -7
  291. package/icons/map-paper.vue +5 -5
  292. package/icons/medal.vue +7 -7
  293. package/icons/menu-filled.vue +20 -20
  294. package/icons/menu.vue +8 -8
  295. package/icons/message/message.vue +12 -12
  296. package/icons/minus/minus-circle.vue +10 -10
  297. package/icons/money.vue +5 -5
  298. package/icons/monitoring.vue +10 -10
  299. package/icons/moon.vue +8 -8
  300. package/icons/more.vue +29 -29
  301. package/icons/note-pencil.vue +14 -14
  302. package/icons/note.vue +14 -14
  303. package/icons/notification.vue +16 -16
  304. package/icons/paperclip.vue +7 -7
  305. package/icons/payment/payment-card.vue +6 -6
  306. package/icons/payment/payment-kaspi.vue +11 -11
  307. package/icons/person-vector.vue +7 -7
  308. package/icons/person-with-briefcase.vue +10 -10
  309. package/icons/phone-filled.vue +5 -5
  310. package/icons/phone.vue +7 -7
  311. package/icons/plus/plus-circle.vue +8 -8
  312. package/icons/plus/plus.vue +13 -13
  313. package/icons/profile.vue +5 -5
  314. package/icons/radio/radio-check.vue +8 -8
  315. package/icons/radio/radio-empty.vue +10 -10
  316. package/icons/receipt.vue +8 -8
  317. package/icons/robot.vue +14 -14
  318. package/icons/sanctions.vue +8 -8
  319. package/icons/scales/scale.vue +16 -16
  320. package/icons/scales/scales.vue +5 -5
  321. package/icons/scales/standing-scales.vue +15 -15
  322. package/icons/search.vue +27 -27
  323. package/icons/share/share-alt.vue +5 -5
  324. package/icons/share/share.vue +14 -14
  325. package/icons/ship.vue +8 -8
  326. package/icons/socials/face-book.vue +15 -15
  327. package/icons/socials/instagram.vue +19 -19
  328. package/icons/socials/telegram.vue +15 -15
  329. package/icons/socials/tik-tok.vue +15 -15
  330. package/icons/socials/youtube.vue +16 -16
  331. package/icons/sort/sort-asc.vue +15 -15
  332. package/icons/sort/sort-desc.vue +15 -15
  333. package/icons/splitting-arrows.vue +8 -8
  334. package/icons/star/star-filled.vue +40 -40
  335. package/icons/star/star-half-filled.vue +20 -20
  336. package/icons/star/star.vue +25 -25
  337. package/icons/sun.vue +14 -14
  338. package/icons/sviazi.vue +5 -5
  339. package/icons/tag.vue +30 -30
  340. package/icons/tasks.vue +10 -10
  341. package/icons/tender-search.vue +11 -11
  342. package/icons/toasts/check-circle-toast.vue +6 -6
  343. package/icons/toasts/warning-triangle-toast.vue +7 -7
  344. package/icons/trash.vue +13 -13
  345. package/icons/triangle.vue +10 -10
  346. package/icons/truck.vue +7 -7
  347. package/icons/user-square.vue +14 -14
  348. package/icons/user.vue +22 -22
  349. package/icons/users-focus.vue +8 -8
  350. package/icons/users-three.vue +7 -7
  351. package/icons/users.vue +8 -8
  352. package/icons/warning/warning-circle.vue +29 -29
  353. package/icons/warning/warning-triangle-filled.vue +12 -12
  354. package/icons/warning/warning-triangle.vue +28 -28
  355. package/icons/whatsapp.vue +8 -8
  356. package/icons/work-bag.vue +11 -11
  357. package/icons/work-case.vue +9 -9
  358. package/icons/work-search.vue +10 -10
  359. package/icons/work.vue +5 -5
  360. package/icons/x-mark.vue +15 -15
  361. package/icons/yandex.vue +28 -28
  362. package/illustrations/address-location.vue +38 -38
  363. package/illustrations/ball-with-chain.vue +120 -120
  364. package/illustrations/bill.vue +133 -133
  365. package/illustrations/buildings.vue +82 -82
  366. package/illustrations/calendar.vue +156 -156
  367. package/illustrations/chains.vue +152 -152
  368. package/illustrations/coin-percent.vue +126 -126
  369. package/illustrations/coins-stack.vue +202 -202
  370. package/illustrations/delete-dark.vue +31 -31
  371. package/illustrations/delete.vue +32 -32
  372. package/illustrations/doc-with-stamp.vue +126 -126
  373. package/illustrations/document.vue +64 -64
  374. package/illustrations/door.vue +74 -74
  375. package/illustrations/empty-box.vue +77 -77
  376. package/illustrations/empty-wallet.vue +161 -161
  377. package/illustrations/graph-in-coin.vue +119 -119
  378. package/illustrations/hammer.vue +156 -156
  379. package/illustrations/hand-cash.vue +108 -108
  380. package/illustrations/info.vue +39 -39
  381. package/illustrations/mail.vue +68 -68
  382. package/illustrations/ok.vue +62 -62
  383. package/illustrations/people-group.vue +237 -237
  384. package/illustrations/person-with-phone.vue +187 -187
  385. package/illustrations/person.vue +159 -159
  386. package/illustrations/phone-check.vue +90 -90
  387. package/illustrations/phone-payment-method.vue +223 -223
  388. package/illustrations/search.vue +14 -0
  389. package/illustrations/stop-hand.vue +77 -77
  390. package/illustrations/stop-sign.vue +34 -34
  391. package/illustrations/suit.vue +111 -111
  392. package/illustrations/suitcase.vue +105 -105
  393. package/illustrations/terminal-dark.vue +48 -48
  394. package/illustrations/terminal.vue +234 -234
  395. package/illustrations/trash-can.vue +108 -108
  396. package/illustrations/turn-on-tariff.vue +38 -38
  397. package/illustrations/two-persons.vue +169 -169
  398. package/lang/en.ts +835 -834
  399. package/lang/kk.ts +837 -836
  400. package/lang/ru.ts +838 -837
  401. package/layouts/default.vue +13 -13
  402. package/nuxt.config.ts +88 -88
  403. package/package.json +69 -69
  404. package/plugins/maska.ts +4 -4
  405. package/plugins/toast.client.ts +58 -58
  406. package/public/kaspi/logo.svg +4 -4
  407. package/shared/constans/pages.ts +90 -89
  408. package/tailwind.config.ts +163 -163
  409. package/tests/AButton.test.ts +81 -81
  410. package/tsconfig.json +6 -6
  411. package/utils/getMaxZindex.ts +25 -25
  412. package/utils/localizedNavigation.ts +36 -36
  413. package/vitest.config.ts +14 -14
@@ -1,412 +1,412 @@
1
- <script generic="T, K extends keyof T" lang="ts" setup>
2
- import {twMerge, twJoin} from 'tailwind-merge'
3
- import AAlert from '#adata-ui/components/elements/alert/AAlert.vue'
4
-
5
- interface Props {
6
- disabled?: boolean
7
- label?: string
8
- size?: 'sm' | 'md'
9
- error?: string | boolean
10
- required?: boolean
11
- readonly?: boolean
12
- clearable?: boolean
13
- startIcon?: string | object
14
- endIcon?: string | object
15
- autocompleteList?: T[]
16
- type?: 'number' | 'text' | 'email' | 'tel' | 'search'
17
- autocompleteOption?: K
18
- autocompleteKey?: K
19
- autocompleteFn?: (item: T) => string
20
- colorClasses?:string
21
- }
22
-
23
- const props = withDefaults(defineProps<Props>(), {
24
- disabled: false,
25
- label: '',
26
- size: 'md',
27
- error: false,
28
- required: false,
29
- readonly: false,
30
- clearable: false,
31
- startIcon: '',
32
- endIcon: '',
33
- type: 'text',
34
- autocompleteList: () => [],
35
- autocompleteOption: undefined,
36
- autocompleteKey: undefined,
37
- autocompleteFn: undefined
38
- })
39
-
40
- const {t} = useI18n()
41
-
42
- const uiConfig = {
43
- wrapper: 'transition duration-500 w-full',
44
- 'input-wrapper': {
45
- base: 'relative inline-block w-full text-sm sm:min-w-full',
46
- readonly: 'pointer-events-none user-select-none',
47
- disabled: 'pointer-events-none user-select-none opacity-40'
48
- },
49
- base: 'w-full border-0 rounded-md text-deepblue-900 dark:text-gray-200 hover:outline outline-offset-[-1px] hover:outline-1 hover:outline-blue-700 hover:dark:outline-blue-500 focus:outline focus:outline-blue-700 focus:dark:outline-blue-500 mt-0',
50
- size: {
51
- sm: 'h-8 px-4 py-1.5 sm',
52
- md: 'h-10 px-4 pb-1.5 pt-[18px] md',
53
- smEx: 'h-8 pl-4 pr-10 py-1.5 sm',
54
- mdEx: 'h-10 pl-4 pr-10 pb-1.5 pt-[18px] md'
55
- },
56
- color: 'bg-deepblue-50 dark:bg-gray-200 dark:bg-opacity-5',
57
- error:
58
- 'outline outline-1 outline-red-500 focus:outline-0 focus:border-red-500 hover:border-red-500',
59
- readonly: 'bg-white opacity-30',
60
- label: {
61
- base: 'absolute left-4 top-[50%] d-flex text-gray-500 pointer-events-none transition-all ease duration-300 transform translate-y-[-50%] whitespace-nowrap text-ellipsis md:max-w-[90%] overflow-hidden',
62
- 'move-label': '!left-10 md:max-w-[calc(90%-40px)]'
63
- },
64
- default: {
65
- size: 'md',
66
- color: 'gray'
67
- },
68
- 'move-input': '!ps-10',
69
- 'move-input-left': '!pe-10'
70
- }
71
-
72
- type AutocompleteValue = T | (typeof T)[keyof typeof T]
73
-
74
- const emit = defineEmits<{
75
- (e: 'updateValue', value: string | number): void
76
- (e: 'onEnter', value : AutocompleteValue): void
77
- (e: 'clear'): void
78
- (e: 'selectOption', value: AutocompleteValue): void
79
- }>()
80
-
81
- function customTrim(input: string): string {
82
- if (input === undefined || input === null) {
83
- return ''
84
- }
85
- // Проверка, является ли строка пустой или состоит только из чисел
86
- if (input === ' ' || /\d/.test(input)) {
87
- return input.trim()
88
- }
89
-
90
- // Возвращаем оригинальное значение, если условия не выполнены
91
- return input
92
- }
93
-
94
- const input = ref<HTMLInputElement>()
95
- const [modelValue, modelModifiers] = defineModel<string | number | AutocompleteValue>({default: '', set(value) {
96
- if (modelModifiers['custom-trim']) {
97
- return customTrim(value)
98
- }
99
- return value
100
- }})
101
- const isFocused = ref()
102
-
103
- const isClearable = computed<boolean>(
104
- () => props.clearable && !props.disabled && !!modelValue.value
105
- )
106
-
107
- const mobileAutocomMoved = ref(false)
108
-
109
- const wrapperClass = uiConfig.wrapper
110
-
111
- const inputWrapperClass = computed(() =>
112
- twMerge(
113
- twJoin(
114
- uiConfig['input-wrapper'].base,
115
- props.readonly ? uiConfig['input-wrapper'].readonly : '',
116
- props.disabled ? uiConfig['input-wrapper'].disabled : ''
117
- )
118
- )
119
- )
120
-
121
- const inputClass = computed(() =>
122
- twMerge(
123
- twJoin(
124
- uiConfig.base,
125
- uiConfig.size[
126
- (props.clearable ? `${props.size}Ex` : props.size) as 'sm' | 'md' | 'smEx' | 'mdEx'
127
- ],
128
- props.error ? uiConfig.error : '',
129
- props.startIcon ? uiConfig['move-input'] : '',
130
- props.endIcon ? uiConfig['move-input-left'] : '',
131
- props.readonly ? uiConfig.readonly : '',
132
- props.colorClasses ? props.colorClasses : uiConfig.color
133
- )
134
- )
135
- )
136
-
137
- const labelClass = computed(() =>
138
- twMerge(twJoin(uiConfig.label.base, isClearable.value ? 'max-w-[calc(80%-40px)]' : 'max-w-[80%]', props.startIcon ? uiConfig.label['move-label'] : ''))
139
- )
140
-
141
- const currentItemIndex = ref<number>(-1)
142
-
143
- const assignValue = () => {
144
- if (props.autocompleteFn) {
145
- modelValue.value = props.autocompleteFn(props.autocompleteList[currentItemIndex.value])
146
- } else {
147
- modelValue.value = props.autocompleteKey
148
- ? props.autocompleteList[currentItemIndex.value][props.autocompleteKey]
149
- : props.autocompleteList[currentItemIndex.value]
150
- }
151
- }
152
-
153
-
154
- const handleKeydown = (e: KeyboardEvent) => {
155
- if (!props.autocompleteList.length) return
156
- if (e.key === 'ArrowDown' && currentItemIndex.value < props.autocompleteList.length - 1) {
157
- e.preventDefault()
158
- currentItemIndex.value++
159
- assignValue()
160
- } else if (e.key === 'ArrowUp' && currentItemIndex.value > 0) {
161
- e.preventDefault()
162
- currentItemIndex.value--
163
- assignValue()
164
- } else if (e.key === 'Enter') {
165
- if (currentItemIndex.value !== -1) assignValue()
166
- emit('onEnter', props.autocompleteList[currentItemIndex.value])
167
- input.value?.blur()
168
- }
169
- }
170
-
171
- const onSelectOption = (item: T) => {
172
- if (props.autocompleteKey) {
173
- modelValue.value = item[props.autocompleteKey]
174
- emit('selectOption', item[props.autocompleteKey])
175
- } else {
176
- modelValue.value = item
177
- emit('selectOption', item)
178
- }
179
- }
180
- const onSelectOptionMobile = (item: T) => {
181
- if (!mobileAutocomMoved.value) {
182
- onSelectOption(item)
183
- } else {
184
- mobileAutocomMoved.value = false
185
- }
186
- }
187
-
188
- const onClear = () => {
189
- modelValue.value = ''
190
- emit('clear')
191
- }
192
- const autocompleteContainer = ref()
193
-
194
- const scrollToElement = (container: HTMLElement) => {
195
- if (container) {
196
- const selectedItem = container.children[currentItemIndex.value] as HTMLElement;
197
- const containerHeight = container.clientHeight;
198
- const itemTop = selectedItem.offsetTop;
199
- const itemHeight = selectedItem.clientHeight;
200
-
201
- if (itemTop < container.scrollTop) {
202
- container.scrollTop = itemTop;
203
- } else if (itemTop + itemHeight > container.scrollTop + containerHeight) {
204
- container.scrollTop = itemTop + itemHeight - containerHeight;
205
- }
206
- }
207
- }
208
- const focus = () => {
209
- input.value?.focus();
210
- };
211
-
212
- watch(currentItemIndex, () => {
213
- scrollToElement(autocompleteContainer.value)
214
- })
215
-
216
- const isDropdownUp = ref(false)
217
- const checkDropdownPosition = () => {
218
- const rect = input.value?.getBoundingClientRect();
219
- const dropdownHeight = 250;
220
-
221
- const windowHeight = window.visualViewport ? window.visualViewport.height : window.innerHeight;
222
-
223
- if (rect) {
224
- isDropdownUp.value = (windowHeight - rect.bottom) < dropdownHeight;
225
- }
226
- };
227
- watch(isFocused, (newVal) => {
228
- if (newVal) {
229
- checkDropdownPosition();
230
- }
231
- });
232
-
233
- watch(modelValue, () => {
234
- checkDropdownPosition();
235
- });
236
-
237
-
238
-
239
- defineExpose({
240
- focus
241
- })
242
- </script>
243
- <template>
244
- <div :class="wrapperClass">
245
- <div :class="inputWrapperClass">
246
- <Transition name="autocomplete-fade">
247
- <div
248
- v-if="autocompleteList.length && isFocused"
249
- :class="[
250
- 'absolute z-[31] w-full flex flex-col gap-4 rounded bg-gray-200 p-2 dark:bg-gray-800',
251
- isDropdownUp ? 'bottom-[44px]' : 'top-[44px]'
252
- ]"
253
- >
254
- <ul
255
- ref="autocompleteContainer"
256
- class="max-h-[250px] w-full overflow-y-auto"
257
- >
258
- <li
259
- v-for="(item, idx) in autocompleteList"
260
- :key="idx"
261
- class="cursor-pointer rounded px-4 py-[10px] transition-colors hover:bg-gray-50 hover:dark:bg-gray-900"
262
- :class="{ 'bg-gray-100 dark:bg-gray-700': currentItemIndex === idx }"
263
- @mousedown="onSelectOption(item)"
264
- @touchend="onSelectOptionMobile(item)"
265
- @touchmove="mobileAutocomMoved = true"
266
- >
267
- <slot
268
- name="autocomplete-option"
269
- :item="item"
270
- >
271
- {{ autocompleteOption ? item[autocompleteOption as K] : item }}
272
- </slot>
273
- </li>
274
- </ul>
275
- <slot name='autocomplete-buttons' :value='modelValue' />
276
- </div>
277
- </Transition>
278
- <input
279
- :id="label"
280
- ref="input"
281
- v-model="modelValue"
282
- :type="type"
283
- :class="inputClass"
284
- class="input"
285
- required
286
- :tabindex="disabled ? -1 : 0"
287
- v-bind="$attrs"
288
- @input="emit('updateValue', modelValue)"
289
- @keydown="handleKeydown"
290
- @focus="isFocused = true"
291
- @blur="isFocused = false"
292
- >
293
- <label
294
- :for="label"
295
- :class="[{ '!translate-y-[-17px] !text-[10px]': modelValue }, labelClass]"
296
- class="label"
297
- >
298
- <span class="text">{{ label }}</span>
299
- <span
300
- v-if="required"
301
- class="text-red-600"
302
- > *</span>
303
- </label>
304
-
305
- <component
306
- :is="startIcon"
307
- v-if="startIcon"
308
- class="pointer-events-none absolute left-4 top-1/2 translate-y-[-50%] transform fill-gray-500 text-base text-gray-500"
309
- filled
310
- />
311
- <component
312
- :is="endIcon"
313
- v-if="endIcon"
314
- class="pointer-events-none absolute right-4 top-1/2 translate-y-[-50%] transform fill-gray-500 text-base text-gray-500"
315
- filled
316
- />
317
- <button
318
- v-if="isClearable"
319
- class="pointer-events-click absolute right-4 top-1/2 translate-y-[-50%] transform rounded-full bg-deepblue-900 bg-opacity-10 p-1 text-2xl hover:opacity-80 dark:bg-gray-200 dark:bg-opacity-10"
320
- type="button"
321
- @click="onClear"
322
- >
323
- <a-icon-x-mark
324
- filled
325
- class="!mb-0 fill-gray-600 dark:fill-gray-300"
326
- />
327
- </button>
328
- <slot name="endButton" />
329
- </div>
330
- <Transition name="slide-in">
331
- <div
332
- v-if="error && typeof error === 'string'"
333
- class="mt-1"
334
- >
335
- <a-alert
336
- :size="size === 'sm' ? 'xs' : 'sm'"
337
- :color="'red'"
338
- icon-type="triangle"
339
- >
340
- <template #default>
341
- <div class="flex flex-col">
342
- <span
343
- v-for="(err, index) in error.split(', ')"
344
- :key="index"
345
- >{{ err }}<br></span>
346
- </div>
347
- </template>
348
- </a-alert>
349
- </div>
350
- </Transition>
351
- </div>
352
- </template>
353
- <style scoped>
354
- .input {
355
- &:focus ~ .label,
356
- &:not(:focus):valid ~ .label,
357
- &:-webkit-autofill ~ .label {
358
- font-size: 10px;
359
- transform: translateY(-17px);
360
- }
361
-
362
- &.sm {
363
- &:focus ~ .label,
364
- &:not(:focus):valid ~ .label,
365
- &:-webkit-autofill ~ .label {
366
- display: none;
367
- }
368
- }
369
-
370
- &::-ms-reveal,
371
- &::-ms-clear {
372
- display: none;
373
- }
374
- }
375
-
376
- .slide-in-enter-active {
377
- z-index: 0;
378
- opacity: 0;
379
- transform: translateY(-50%);
380
- transition: transform 0.5s;
381
- }
382
-
383
- .slide-in-enter-to {
384
- z-index: auto;
385
- opacity: 1;
386
- transform: translateY(0);
387
- }
388
-
389
- .slide-in-leave-active {
390
- opacity: 1;
391
- transform: translateY(0);
392
- }
393
-
394
- .slide-in-leave-to {
395
- opacity: 0;
396
- transform: translateY(-100%);
397
- }
398
-
399
- .autocomplete-fade-enter-active,
400
- .autocomplete-fade-leave-active {
401
- transition: opacity 150ms ease;
402
- }
403
-
404
- .autocomplete-fade-enter-from,
405
- .autocomplete-fade-leave-to {
406
- opacity: 0;
407
- }
408
-
409
- .move-input {
410
- padding-left: 40px !important;
411
- }
412
- </style>
1
+ <script generic="T, K extends keyof T" lang="ts" setup>
2
+ import {twMerge, twJoin} from 'tailwind-merge'
3
+ import AAlert from '#adata-ui/components/elements/alert/AAlert.vue'
4
+
5
+ interface Props {
6
+ disabled?: boolean
7
+ label?: string
8
+ size?: 'sm' | 'md'
9
+ error?: string | boolean
10
+ required?: boolean
11
+ readonly?: boolean
12
+ clearable?: boolean
13
+ startIcon?: string | object
14
+ endIcon?: string | object
15
+ autocompleteList?: T[]
16
+ type?: 'number' | 'text' | 'email' | 'tel' | 'search'
17
+ autocompleteOption?: K
18
+ autocompleteKey?: K
19
+ autocompleteFn?: (item: T) => string
20
+ colorClasses?:string
21
+ }
22
+
23
+ const props = withDefaults(defineProps<Props>(), {
24
+ disabled: false,
25
+ label: '',
26
+ size: 'md',
27
+ error: false,
28
+ required: false,
29
+ readonly: false,
30
+ clearable: false,
31
+ startIcon: '',
32
+ endIcon: '',
33
+ type: 'text',
34
+ autocompleteList: () => [],
35
+ autocompleteOption: undefined,
36
+ autocompleteKey: undefined,
37
+ autocompleteFn: undefined
38
+ })
39
+
40
+ const {t} = useI18n()
41
+
42
+ const uiConfig = {
43
+ wrapper: 'transition duration-500 w-full',
44
+ 'input-wrapper': {
45
+ base: 'relative inline-block w-full text-sm sm:min-w-full',
46
+ readonly: 'pointer-events-none user-select-none',
47
+ disabled: 'pointer-events-none user-select-none opacity-40'
48
+ },
49
+ base: 'w-full border-0 rounded-md text-deepblue-900 dark:text-gray-200 hover:outline outline-offset-[-1px] hover:outline-1 hover:outline-blue-700 hover:dark:outline-blue-500 focus:outline focus:outline-blue-700 focus:dark:outline-blue-500 mt-0',
50
+ size: {
51
+ sm: 'h-8 px-4 py-1.5 sm',
52
+ md: 'h-10 px-4 pb-1.5 pt-[18px] md',
53
+ smEx: 'h-8 pl-4 pr-10 py-1.5 sm',
54
+ mdEx: 'h-10 pl-4 pr-10 pb-1.5 pt-[18px] md'
55
+ },
56
+ color: 'bg-deepblue-50 dark:bg-gray-200 dark:bg-opacity-5',
57
+ error:
58
+ 'outline outline-1 outline-red-500 focus:outline-0 focus:border-red-500 hover:border-red-500',
59
+ readonly: 'bg-white opacity-30',
60
+ label: {
61
+ base: 'absolute left-4 top-[50%] d-flex text-gray-500 pointer-events-none transition-all ease duration-300 transform translate-y-[-50%] whitespace-nowrap text-ellipsis md:max-w-[90%] overflow-hidden',
62
+ 'move-label': '!left-10 md:max-w-[calc(90%-40px)]'
63
+ },
64
+ default: {
65
+ size: 'md',
66
+ color: 'gray'
67
+ },
68
+ 'move-input': '!ps-10',
69
+ 'move-input-left': '!pe-10'
70
+ }
71
+
72
+ type AutocompleteValue = T | (typeof T)[keyof typeof T]
73
+
74
+ const emit = defineEmits<{
75
+ (e: 'updateValue', value: string | number): void
76
+ (e: 'onEnter', value : AutocompleteValue): void
77
+ (e: 'clear'): void
78
+ (e: 'selectOption', value: AutocompleteValue): void
79
+ }>()
80
+
81
+ function customTrim(input: string): string {
82
+ if (input === undefined || input === null) {
83
+ return ''
84
+ }
85
+ // Проверка, является ли строка пустой или состоит только из чисел
86
+ if (input === ' ' || /\d/.test(input)) {
87
+ return input.trim()
88
+ }
89
+
90
+ // Возвращаем оригинальное значение, если условия не выполнены
91
+ return input
92
+ }
93
+
94
+ const input = ref<HTMLInputElement>()
95
+ const [modelValue, modelModifiers] = defineModel<string | number | AutocompleteValue>({default: '', set(value) {
96
+ if (modelModifiers['custom-trim']) {
97
+ return customTrim(value)
98
+ }
99
+ return value
100
+ }})
101
+ const isFocused = ref()
102
+
103
+ const isClearable = computed<boolean>(
104
+ () => props.clearable && !props.disabled && !!modelValue.value
105
+ )
106
+
107
+ const mobileAutocomMoved = ref(false)
108
+
109
+ const wrapperClass = uiConfig.wrapper
110
+
111
+ const inputWrapperClass = computed(() =>
112
+ twMerge(
113
+ twJoin(
114
+ uiConfig['input-wrapper'].base,
115
+ props.readonly ? uiConfig['input-wrapper'].readonly : '',
116
+ props.disabled ? uiConfig['input-wrapper'].disabled : ''
117
+ )
118
+ )
119
+ )
120
+
121
+ const inputClass = computed(() =>
122
+ twMerge(
123
+ twJoin(
124
+ uiConfig.base,
125
+ uiConfig.size[
126
+ (props.clearable ? `${props.size}Ex` : props.size) as 'sm' | 'md' | 'smEx' | 'mdEx'
127
+ ],
128
+ props.error ? uiConfig.error : '',
129
+ props.startIcon ? uiConfig['move-input'] : '',
130
+ props.endIcon ? uiConfig['move-input-left'] : '',
131
+ props.readonly ? uiConfig.readonly : '',
132
+ props.colorClasses ? props.colorClasses : uiConfig.color
133
+ )
134
+ )
135
+ )
136
+
137
+ const labelClass = computed(() =>
138
+ twMerge(twJoin(uiConfig.label.base, isClearable.value ? 'max-w-[calc(80%-40px)]' : 'max-w-[80%]', props.startIcon ? uiConfig.label['move-label'] : ''))
139
+ )
140
+
141
+ const currentItemIndex = ref<number>(-1)
142
+
143
+ const assignValue = () => {
144
+ if (props.autocompleteFn) {
145
+ modelValue.value = props.autocompleteFn(props.autocompleteList[currentItemIndex.value])
146
+ } else {
147
+ modelValue.value = props.autocompleteKey
148
+ ? props.autocompleteList[currentItemIndex.value][props.autocompleteKey]
149
+ : props.autocompleteList[currentItemIndex.value]
150
+ }
151
+ }
152
+
153
+
154
+ const handleKeydown = (e: KeyboardEvent) => {
155
+ if (!props.autocompleteList.length) return
156
+ if (e.key === 'ArrowDown' && currentItemIndex.value < props.autocompleteList.length - 1) {
157
+ e.preventDefault()
158
+ currentItemIndex.value++
159
+ assignValue()
160
+ } else if (e.key === 'ArrowUp' && currentItemIndex.value > 0) {
161
+ e.preventDefault()
162
+ currentItemIndex.value--
163
+ assignValue()
164
+ } else if (e.key === 'Enter') {
165
+ if (currentItemIndex.value !== -1) assignValue()
166
+ emit('onEnter', props.autocompleteList[currentItemIndex.value])
167
+ input.value?.blur()
168
+ }
169
+ }
170
+
171
+ const onSelectOption = (item: T) => {
172
+ if (props.autocompleteKey) {
173
+ modelValue.value = item[props.autocompleteKey]
174
+ emit('selectOption', item[props.autocompleteKey])
175
+ } else {
176
+ modelValue.value = item
177
+ emit('selectOption', item)
178
+ }
179
+ }
180
+ const onSelectOptionMobile = (item: T) => {
181
+ if (!mobileAutocomMoved.value) {
182
+ onSelectOption(item)
183
+ } else {
184
+ mobileAutocomMoved.value = false
185
+ }
186
+ }
187
+
188
+ const onClear = () => {
189
+ modelValue.value = ''
190
+ emit('clear')
191
+ }
192
+ const autocompleteContainer = ref()
193
+
194
+ const scrollToElement = (container: HTMLElement) => {
195
+ if (container) {
196
+ const selectedItem = container.children[currentItemIndex.value] as HTMLElement;
197
+ const containerHeight = container.clientHeight;
198
+ const itemTop = selectedItem.offsetTop;
199
+ const itemHeight = selectedItem.clientHeight;
200
+
201
+ if (itemTop < container.scrollTop) {
202
+ container.scrollTop = itemTop;
203
+ } else if (itemTop + itemHeight > container.scrollTop + containerHeight) {
204
+ container.scrollTop = itemTop + itemHeight - containerHeight;
205
+ }
206
+ }
207
+ }
208
+ const focus = () => {
209
+ input.value?.focus();
210
+ };
211
+
212
+ watch(currentItemIndex, () => {
213
+ scrollToElement(autocompleteContainer.value)
214
+ })
215
+
216
+ const isDropdownUp = ref(false)
217
+ const checkDropdownPosition = () => {
218
+ const rect = input.value?.getBoundingClientRect();
219
+ const dropdownHeight = 250;
220
+
221
+ const windowHeight = window.visualViewport ? window.visualViewport.height : window.innerHeight;
222
+
223
+ if (rect) {
224
+ isDropdownUp.value = (windowHeight - rect.bottom) < dropdownHeight;
225
+ }
226
+ };
227
+ watch(isFocused, (newVal) => {
228
+ if (newVal) {
229
+ checkDropdownPosition();
230
+ }
231
+ });
232
+
233
+ watch(modelValue, () => {
234
+ checkDropdownPosition();
235
+ });
236
+
237
+
238
+
239
+ defineExpose({
240
+ focus
241
+ })
242
+ </script>
243
+ <template>
244
+ <div :class="wrapperClass">
245
+ <div :class="inputWrapperClass">
246
+ <Transition name="autocomplete-fade">
247
+ <div
248
+ v-if="autocompleteList.length && isFocused"
249
+ :class="[
250
+ 'absolute z-[31] w-full flex flex-col gap-4 rounded bg-gray-200 p-2 dark:bg-gray-800',
251
+ isDropdownUp ? 'bottom-[44px]' : 'top-[44px]'
252
+ ]"
253
+ >
254
+ <ul
255
+ ref="autocompleteContainer"
256
+ class="max-h-[250px] w-full overflow-y-auto"
257
+ >
258
+ <li
259
+ v-for="(item, idx) in autocompleteList"
260
+ :key="idx"
261
+ class="cursor-pointer rounded px-4 py-[10px] transition-colors hover:bg-gray-50 hover:dark:bg-gray-900"
262
+ :class="{ 'bg-gray-100 dark:bg-gray-700': currentItemIndex === idx }"
263
+ @mousedown="onSelectOption(item)"
264
+ @touchend="onSelectOptionMobile(item)"
265
+ @touchmove="mobileAutocomMoved = true"
266
+ >
267
+ <slot
268
+ name="autocomplete-option"
269
+ :item="item"
270
+ >
271
+ {{ autocompleteOption ? item[autocompleteOption as K] : item }}
272
+ </slot>
273
+ </li>
274
+ </ul>
275
+ <slot name='autocomplete-buttons' :value='modelValue' />
276
+ </div>
277
+ </Transition>
278
+ <input
279
+ :id="label"
280
+ ref="input"
281
+ v-model="modelValue"
282
+ :type="type"
283
+ :class="inputClass"
284
+ class="input"
285
+ required
286
+ :tabindex="disabled ? -1 : 0"
287
+ v-bind="$attrs"
288
+ @input="emit('updateValue', modelValue)"
289
+ @keydown="handleKeydown"
290
+ @focus="isFocused = true"
291
+ @blur="isFocused = false"
292
+ >
293
+ <label
294
+ :for="label"
295
+ :class="[{ '!translate-y-[-17px] !text-[10px]': modelValue }, labelClass]"
296
+ class="label"
297
+ >
298
+ <span class="text">{{ label }}</span>
299
+ <span
300
+ v-if="required"
301
+ class="text-red-600"
302
+ > *</span>
303
+ </label>
304
+
305
+ <component
306
+ :is="startIcon"
307
+ v-if="startIcon"
308
+ class="pointer-events-none absolute left-4 top-1/2 translate-y-[-50%] transform fill-gray-500 text-base text-gray-500"
309
+ filled
310
+ />
311
+ <component
312
+ :is="endIcon"
313
+ v-if="endIcon"
314
+ class="pointer-events-none absolute right-4 top-1/2 translate-y-[-50%] transform fill-gray-500 text-base text-gray-500"
315
+ filled
316
+ />
317
+ <button
318
+ v-if="isClearable"
319
+ class="pointer-events-click absolute right-4 top-1/2 translate-y-[-50%] transform rounded-full bg-deepblue-900 bg-opacity-10 p-1 text-2xl hover:opacity-80 dark:bg-gray-200 dark:bg-opacity-10"
320
+ type="button"
321
+ @click="onClear"
322
+ >
323
+ <a-icon-x-mark
324
+ filled
325
+ class="!mb-0 fill-gray-600 dark:fill-gray-300"
326
+ />
327
+ </button>
328
+ <slot name="endButton" />
329
+ </div>
330
+ <Transition name="slide-in">
331
+ <div
332
+ v-if="error && typeof error === 'string'"
333
+ class="mt-1"
334
+ >
335
+ <a-alert
336
+ :size="size === 'sm' ? 'xs' : 'sm'"
337
+ :color="'red'"
338
+ icon-type="triangle"
339
+ >
340
+ <template #default>
341
+ <div class="flex flex-col">
342
+ <span
343
+ v-for="(err, index) in error.split(', ')"
344
+ :key="index"
345
+ >{{ err }}<br></span>
346
+ </div>
347
+ </template>
348
+ </a-alert>
349
+ </div>
350
+ </Transition>
351
+ </div>
352
+ </template>
353
+ <style scoped>
354
+ .input {
355
+ &:focus ~ .label,
356
+ &:not(:focus):valid ~ .label,
357
+ &:-webkit-autofill ~ .label {
358
+ font-size: 10px;
359
+ transform: translateY(-17px);
360
+ }
361
+
362
+ &.sm {
363
+ &:focus ~ .label,
364
+ &:not(:focus):valid ~ .label,
365
+ &:-webkit-autofill ~ .label {
366
+ display: none;
367
+ }
368
+ }
369
+
370
+ &::-ms-reveal,
371
+ &::-ms-clear {
372
+ display: none;
373
+ }
374
+ }
375
+
376
+ .slide-in-enter-active {
377
+ z-index: 0;
378
+ opacity: 0;
379
+ transform: translateY(-50%);
380
+ transition: transform 0.5s;
381
+ }
382
+
383
+ .slide-in-enter-to {
384
+ z-index: auto;
385
+ opacity: 1;
386
+ transform: translateY(0);
387
+ }
388
+
389
+ .slide-in-leave-active {
390
+ opacity: 1;
391
+ transform: translateY(0);
392
+ }
393
+
394
+ .slide-in-leave-to {
395
+ opacity: 0;
396
+ transform: translateY(-100%);
397
+ }
398
+
399
+ .autocomplete-fade-enter-active,
400
+ .autocomplete-fade-leave-active {
401
+ transition: opacity 150ms ease;
402
+ }
403
+
404
+ .autocomplete-fade-enter-from,
405
+ .autocomplete-fade-leave-to {
406
+ opacity: 0;
407
+ }
408
+
409
+ .move-input {
410
+ padding-left: 40px !important;
411
+ }
412
+ </style>