adata-ui 2.1.23 → 2.1.25

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 -158
  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,83 +1,83 @@
1
- <script lang='ts' setup>
2
- import {twMerge} from "tailwind-merge";
3
-
4
- defineOptions({name: 'ADigitBadge'})
5
-
6
- interface Props {
7
- type?: 'primary' | 'success' | 'danger' | 'gray' | 'orange' | 'warning'
8
- view?: 'default' | 'inverted'
9
- size?: 'sm' | 'md' | 'lg'
10
- value: string | number
11
- disabled?: boolean
12
- customClasses?: string
13
- prefix?: string
14
- }
15
-
16
- const props = withDefaults(defineProps<Props>(), {
17
- type: 'primary',
18
- view: 'default',
19
- size: 'lg',
20
- disabled: false,
21
- customClasses: '',
22
- prefix: ''
23
- })
24
- const formattedValue = computed(() => {
25
- return Number(props.value).toLocaleString('ru-RU');
26
- });
27
- const classes = computed(() =>
28
- [
29
- props.disabled ? 'text-gray-500 bg-deepblue-900/5' : typeSwitchValues[props.view][props.type],
30
- 'inline-flex items-center justify-center font-medium rounded-full select-none inline-flex outline-none',
31
- sizeSwitchValues[props.size],
32
- props.value && props.value.toString().length > 2 ? 'w-auto' : '',
33
- ])
34
-
35
- export type StateType = {
36
- [key in 'primary' | 'success' | 'danger' | 'gray' | 'orange' | 'warning']?: string;
37
- };
38
- type ViewType = {
39
- default: StateType
40
- inverted: StateType
41
- transparent: StateType
42
- };
43
-
44
- type SizeSwitchValues = {
45
- [key in 'sm' | 'md' | 'lg']: string;
46
- };
47
-
48
- const typeSwitchValues: ViewType = {
49
- default: {
50
- primary: 'bg-blue-700 text-white dark:bg-blue-500 dark:text-gray-900',
51
- success: 'bg-green-500 text-white dark:bg-green-400 dark:text-gray-900',
52
- danger: 'bg-red-500 text-white dark:bg-red-400 dark:text-gray-900',
53
- warning: 'bg-yellow-400 text-white dark:text-gray-900',
54
- gray: 'bg-gray-50 text-gray-500 dark:text-gray-900',
55
- orange: 'bg-orange-600 text-white dark:bg-orange-500 dark:text-gray-900'
56
- },
57
- inverted: {
58
- primary: 'bg-white text-blue-700 dark:text-blue-500 dark:bg-gray-900',
59
- success: 'bg-white text-green-500 dark:text-green-400 dark:bg-gray-900',
60
- danger: 'bg-white text-red-500 dark:text-red-400 dark:bg-gray-900',
61
- warning: 'bg-white text-yellow-400 dark:bg-gray-900',
62
- gray: 'bg-white text-gray-500 dark:text-gray-200 dark:bg-gray-200/10',
63
- orange: 'bg-white text-deepblue-900 dark:text-orange-500 dark:bg-gray-900',
64
- },
65
- transparent: {
66
- success: 'bg-green-500/20 text-green-500',
67
- danger: 'bg-red-500/20 text-red-500 dark:text-red-400',
68
- }
69
- }
70
-
71
- const sizeSwitchValues: SizeSwitchValues = {
72
- sm: 'w-4 h-4 px-1 text-[9.5px]',
73
- md: 'w-5 h-5 px-1 text-[10px]',
74
- lg: 'px-2 w-6 h-6 text-xs font-semibold'
75
- }
76
- </script>
77
- <template>
78
- <div
79
- :class="twMerge(...classes, customClasses)"
80
- >
81
- {{ prefix }}{{ formattedValue }}
82
- </div>
83
- </template>
1
+ <script lang='ts' setup>
2
+ import {twMerge} from "tailwind-merge";
3
+
4
+ defineOptions({name: 'ADigitBadge'})
5
+
6
+ interface Props {
7
+ type?: 'primary' | 'success' | 'danger' | 'gray' | 'orange' | 'warning'
8
+ view?: 'default' | 'inverted'
9
+ size?: 'sm' | 'md' | 'lg'
10
+ value: string | number
11
+ disabled?: boolean
12
+ customClasses?: string
13
+ prefix?: string
14
+ }
15
+
16
+ const props = withDefaults(defineProps<Props>(), {
17
+ type: 'primary',
18
+ view: 'default',
19
+ size: 'lg',
20
+ disabled: false,
21
+ customClasses: '',
22
+ prefix: ''
23
+ })
24
+ const formattedValue = computed(() => {
25
+ return Number(props.value).toLocaleString('ru-RU');
26
+ });
27
+ const classes = computed(() =>
28
+ [
29
+ props.disabled ? 'text-gray-500 bg-deepblue-900/5' : typeSwitchValues[props.view][props.type],
30
+ 'inline-flex items-center justify-center font-medium rounded-full select-none inline-flex outline-none',
31
+ sizeSwitchValues[props.size],
32
+ props.value && props.value.toString().length > 2 ? 'w-auto' : '',
33
+ ])
34
+
35
+ export type StateType = {
36
+ [key in 'primary' | 'success' | 'danger' | 'gray' | 'orange' | 'warning']?: string;
37
+ };
38
+ type ViewType = {
39
+ default: StateType
40
+ inverted: StateType
41
+ transparent: StateType
42
+ };
43
+
44
+ type SizeSwitchValues = {
45
+ [key in 'sm' | 'md' | 'lg']: string;
46
+ };
47
+
48
+ const typeSwitchValues: ViewType = {
49
+ default: {
50
+ primary: 'bg-blue-700 text-white dark:bg-blue-500 dark:text-gray-900',
51
+ success: 'bg-green-500 text-white dark:bg-green-400 dark:text-gray-900',
52
+ danger: 'bg-red-500 text-white dark:bg-red-400 dark:text-gray-900',
53
+ warning: 'bg-yellow-400 text-white dark:text-gray-900',
54
+ gray: 'bg-gray-50 text-gray-500 dark:text-gray-900',
55
+ orange: 'bg-orange-600 text-white dark:bg-orange-500 dark:text-gray-900'
56
+ },
57
+ inverted: {
58
+ primary: 'bg-white text-blue-700 dark:text-blue-500 dark:bg-gray-900',
59
+ success: 'bg-white text-green-500 dark:text-green-400 dark:bg-gray-900',
60
+ danger: 'bg-white text-red-500 dark:text-red-400 dark:bg-gray-900',
61
+ warning: 'bg-white text-yellow-400 dark:bg-gray-900',
62
+ gray: 'bg-white text-gray-500 dark:text-gray-200 dark:bg-gray-200/10',
63
+ orange: 'bg-white text-deepblue-900 dark:text-orange-500 dark:bg-gray-900',
64
+ },
65
+ transparent: {
66
+ success: 'bg-green-500/20 text-green-500',
67
+ danger: 'bg-red-500/20 text-red-500 dark:text-red-400',
68
+ }
69
+ }
70
+
71
+ const sizeSwitchValues: SizeSwitchValues = {
72
+ sm: 'w-4 h-4 px-1 text-[9.5px]',
73
+ md: 'w-5 h-5 px-1 text-[10px]',
74
+ lg: 'px-2 w-6 h-6 text-xs font-semibold'
75
+ }
76
+ </script>
77
+ <template>
78
+ <div
79
+ :class="twMerge(...classes, customClasses)"
80
+ >
81
+ {{ prefix }}{{ formattedValue }}
82
+ </div>
83
+ </template>
@@ -1,48 +1,48 @@
1
- <script setup lang="ts">
2
- import type { ErrorTemplateData } from './types'
3
-
4
- interface Props {
5
- error: ErrorTemplateData
6
- }
7
-
8
- defineProps<Props>()
9
- </script>
10
-
11
- <template>
12
- <div class="flex items-center justify-center gap-14">
13
- <slot name="icon">
14
- <div class="hidden lg:block max-w-[600px]">
15
- <img
16
- :src="error.icon"
17
- class="hidden lg:block"
18
- alt="error-icon"
19
- >
20
- </div>
21
- </slot>
22
- <div class="flex min-h-screen flex-col lg:min-h-0">
23
- <div class="flex-1 px-4 py-8 lg:p-0">
24
- <slot name="status">
25
- <p class="mb-6 text-4xl font-bold">
26
- {{ error.statusCode }}
27
- </p>
28
- </slot>
29
- <slot name="title">
30
- <h2 class="lg:heading-03 text-2xl font-bold ">
31
- {{ error.title }}
32
- </h2>
33
- </slot>
34
- <slot
35
- name="content"
36
- :data="error"
37
- />
38
- </div>
39
- <div class="sticky bottom-0 z-[10000] lg:static lg:flex">
40
- <slot name="default" />
41
- </div>
42
- </div>
43
- </div>
44
- </template>
45
-
46
- <style scoped>
47
-
48
- </style>
1
+ <script setup lang="ts">
2
+ import type { ErrorTemplateData } from './types'
3
+
4
+ interface Props {
5
+ error: ErrorTemplateData
6
+ }
7
+
8
+ defineProps<Props>()
9
+ </script>
10
+
11
+ <template>
12
+ <div class="flex items-center justify-center gap-14">
13
+ <slot name="icon">
14
+ <div class="hidden lg:block max-w-[600px]">
15
+ <img
16
+ :src="error.icon"
17
+ class="hidden lg:block"
18
+ alt="error-icon"
19
+ >
20
+ </div>
21
+ </slot>
22
+ <div class="flex min-h-screen flex-col lg:min-h-0">
23
+ <div class="flex-1 px-4 py-8 lg:p-0">
24
+ <slot name="status">
25
+ <p class="mb-6 text-4xl font-bold">
26
+ {{ error.statusCode }}
27
+ </p>
28
+ </slot>
29
+ <slot name="title">
30
+ <h2 class="lg:heading-03 text-2xl font-bold ">
31
+ {{ error.title }}
32
+ </h2>
33
+ </slot>
34
+ <slot
35
+ name="content"
36
+ :data="error"
37
+ />
38
+ </div>
39
+ <div class="sticky bottom-0 z-[10000] lg:static lg:flex">
40
+ <slot name="default" />
41
+ </div>
42
+ </div>
43
+ </div>
44
+ </template>
45
+
46
+ <style scoped>
47
+
48
+ </style>
@@ -1,23 +1,23 @@
1
- import type { DefineComponent } from 'vue'
2
-
3
- export interface List {
4
- id: number
5
- label: string
6
- link: boolean
7
- }
8
-
9
- export interface Content {
10
- title: string
11
- subTitle: string
12
- subTitleSecond?:string
13
- list: List[]
14
- }
15
-
16
- export interface ErrorTemplateData {
17
- icon: string
18
- statusCode: number
19
- title: string
20
- subTitle: string | string[]
21
- subTitleSecond: string | string[]
22
- content?: Content
23
- }
1
+ import type { DefineComponent } from 'vue'
2
+
3
+ export interface List {
4
+ id: number
5
+ label: string
6
+ link: boolean
7
+ }
8
+
9
+ export interface Content {
10
+ title: string
11
+ subTitle: string
12
+ subTitleSecond?:string
13
+ list: List[]
14
+ }
15
+
16
+ export interface ErrorTemplateData {
17
+ icon: string
18
+ statusCode: number
19
+ title: string
20
+ subTitle: string | string[]
21
+ subTitleSecond: string | string[]
22
+ content?: Content
23
+ }
@@ -1,112 +1,112 @@
1
- <script setup lang="ts">
2
- interface FeatureInfo {
3
- icon: Component
4
- title: string
5
- description: string
6
- }
7
-
8
- const props = defineProps<{
9
- features: FeatureInfo[]
10
- }>()
11
-
12
- const selected = defineModel<number>({ default: 0 })
13
- const duration = 5000
14
- let timer: ReturnType<typeof setTimeout> | null = null
15
-
16
- const nextFeature = () => {
17
- selected.value = (selected.value + 1) % props.features.length
18
- startTimer()
19
- }
20
-
21
- const startTimer = () => {
22
- clearTimer()
23
- timer = setTimeout(() => {
24
- nextFeature()
25
- }, duration)
26
- }
27
-
28
- const clearTimer = () => {
29
- if (timer) {
30
- clearTimeout(timer)
31
- timer = null
32
- }
33
- }
34
-
35
- function selectFeature(idx: number) {
36
- selected.value = idx
37
- startTimer()
38
- }
39
-
40
- onMounted(() => startTimer())
41
- onUnmounted(() => clearTimer())
42
- </script>
43
-
44
- <template>
45
- <div
46
- v-for="(item, idx) in features"
47
- :key="idx"
48
- class="relative flex flex-col pl-3 cursor-pointer"
49
- @click="selectFeature(idx)"
50
- >
51
- <div
52
- v-if="selected === idx"
53
- class="absolute left-0 top-0 w-[2px] bg-blue-700 dark:bg-blue-500 z-20 h-full rounded-full"
54
- :class="{ 'fill-animation': selected === idx }"
55
- />
56
-
57
- <div
58
- class="absolute left-0 top-0 w-[2px] bg-gray-500/50 z-10 h-full rounded-full"
59
- />
60
-
61
- <div class="flex items-center gap-2 relative z-10">
62
- <div
63
- :class="[
64
- 'transition-all duration-300 ease-in-out',
65
- selected === idx ? 'rounded-md bg-blue-700 dark:bg-blue-500 p-2 icon-bg' : 'size-fit'
66
- ]"
67
- >
68
- <component
69
- :is="item.icon"
70
- class="shrink-0 size-6 transition-colors duration-300 ease-in-out"
71
- :class="selected === idx ? 'text-white dark:text-gray-900' : 'text-gray-600 dark:text-[#9DA3AC]'"
72
- />
73
- </div>
74
- <p
75
- class="font-semibold text-base lg:text-xl transition-colors duration-300 ease-in-out"
76
- :class="selected === idx ? 'dark:text-[#E3E5E8]' : 'text-gray-600 dark:text-[#9DA3AC]'"
77
- >
78
- {{ item.title }}
79
- </p>
80
- </div>
81
-
82
- <a-transition-height
83
- :transition="{
84
- enterActiveClass: 'overflow-hidden transition-[height] duration-[1s] ease-in-out',
85
- leaveActiveClass: 'overflow-hidden transition-[height] duration-[1s] ease-in-out'
86
- }"
87
- >
88
- <div
89
- v-if="selected === idx"
90
- >
91
- <p class="text-xs lg:text-sm pt-3">
92
- {{ item.description }}
93
- </p>
94
- </div>
95
- </a-transition-height>
96
- </div>
97
- </template>
98
-
99
- <style lang="scss" scoped>
100
- .icon-bg {
101
- box-shadow: -4px 4px 0px 0px #007AFF1A;
102
- }
103
-
104
- .fill-animation {
105
- animation: borderFill 5s linear forwards;
106
- }
107
-
108
- @keyframes borderFill {
109
- 0% { height: 0; }
110
- 100% { height: 100%; }
111
- }
112
- </style>
1
+ <script setup lang="ts">
2
+ interface FeatureInfo {
3
+ icon: Component
4
+ title: string
5
+ description: string
6
+ }
7
+
8
+ const props = defineProps<{
9
+ features: FeatureInfo[]
10
+ }>()
11
+
12
+ const selected = defineModel<number>({ default: 0 })
13
+ const duration = 5000
14
+ let timer: ReturnType<typeof setTimeout> | null = null
15
+
16
+ const nextFeature = () => {
17
+ selected.value = (selected.value + 1) % props.features.length
18
+ startTimer()
19
+ }
20
+
21
+ const startTimer = () => {
22
+ clearTimer()
23
+ timer = setTimeout(() => {
24
+ nextFeature()
25
+ }, duration)
26
+ }
27
+
28
+ const clearTimer = () => {
29
+ if (timer) {
30
+ clearTimeout(timer)
31
+ timer = null
32
+ }
33
+ }
34
+
35
+ function selectFeature(idx: number) {
36
+ selected.value = idx
37
+ startTimer()
38
+ }
39
+
40
+ onMounted(() => startTimer())
41
+ onUnmounted(() => clearTimer())
42
+ </script>
43
+
44
+ <template>
45
+ <div
46
+ v-for="(item, idx) in features"
47
+ :key="idx"
48
+ class="relative flex flex-col pl-3 cursor-pointer"
49
+ @click="selectFeature(idx)"
50
+ >
51
+ <div
52
+ v-if="selected === idx"
53
+ class="absolute left-0 top-0 w-[2px] bg-blue-700 dark:bg-blue-500 z-20 h-full rounded-full"
54
+ :class="{ 'fill-animation': selected === idx }"
55
+ />
56
+
57
+ <div
58
+ class="absolute left-0 top-0 w-[2px] bg-gray-500/50 z-10 h-full rounded-full"
59
+ />
60
+
61
+ <div class="flex items-center gap-2 relative z-10">
62
+ <div
63
+ :class="[
64
+ 'transition-all duration-300 ease-in-out',
65
+ selected === idx ? 'rounded-md bg-blue-700 dark:bg-blue-500 p-2 icon-bg' : 'size-fit'
66
+ ]"
67
+ >
68
+ <component
69
+ :is="item.icon"
70
+ class="shrink-0 size-6 transition-colors duration-300 ease-in-out"
71
+ :class="selected === idx ? 'text-white dark:text-gray-900' : 'text-gray-600 dark:text-[#9DA3AC]'"
72
+ />
73
+ </div>
74
+ <p
75
+ class="font-semibold text-base lg:text-xl transition-colors duration-300 ease-in-out"
76
+ :class="selected === idx ? 'dark:text-[#E3E5E8]' : 'text-gray-600 dark:text-[#9DA3AC]'"
77
+ >
78
+ {{ item.title }}
79
+ </p>
80
+ </div>
81
+
82
+ <a-transition-height
83
+ :transition="{
84
+ enterActiveClass: 'overflow-hidden transition-[height] duration-[1s] ease-in-out',
85
+ leaveActiveClass: 'overflow-hidden transition-[height] duration-[1s] ease-in-out'
86
+ }"
87
+ >
88
+ <div
89
+ v-if="selected === idx"
90
+ >
91
+ <p class="text-xs lg:text-sm pt-3">
92
+ {{ item.description }}
93
+ </p>
94
+ </div>
95
+ </a-transition-height>
96
+ </div>
97
+ </template>
98
+
99
+ <style lang="scss" scoped>
100
+ .icon-bg {
101
+ box-shadow: -4px 4px 0px 0px #007AFF1A;
102
+ }
103
+
104
+ .fill-animation {
105
+ animation: borderFill 5s linear forwards;
106
+ }
107
+
108
+ @keyframes borderFill {
109
+ 0% { height: 0; }
110
+ 100% { height: 100%; }
111
+ }
112
+ </style>
@@ -1,71 +1,71 @@
1
- <script setup lang="ts">
2
- import { type LocalizedNavigationParams, navigateToLocalizedPage } from '#adata-ui/utils/localizedNavigation'
3
- import { useUrls } from '#adata-ui/composables/useUrls'
4
-
5
- interface Props {
6
- illClass?: string
7
- text?: string
8
- textClass?:string
9
- buttonName?: string
10
- to?: LocalizedNavigationParams
11
- noIll?: boolean
12
- noText?: boolean
13
- noBtn?: boolean
14
- }
15
- const props = defineProps<Props>()
16
-
17
- const appConfig = useAppConfig()
18
- const { login } = useUrls()
19
- const authMode = appConfig.myLayer.authMode
20
- const device = useAdaptive()
21
- const { t, locale } = useI18n()
22
-
23
- const { loginModal } = useIdModals()
24
-
25
- function goAuth() {
26
- if (authMode === 'local') {
27
- loginModal.value = true
28
- return
29
- }
30
-
31
- if (window) {
32
- if (props.to) {
33
- navigateToLocalizedPage(props.to)
34
- } else {
35
- const fullPath = encodeURIComponent(window.location.toString())
36
- navigateToLocalizedPage({
37
- locale,
38
- projectUrl: login,
39
- path: `/?url=${fullPath}`,
40
- target: '_self'
41
- })
42
- }
43
- }
44
- }
45
- </script>
46
-
47
- <template>
48
- <div class="flex flex-col items-center gap-4 text-center text-sm">
49
- <div v-if="!noIll">
50
- <slot name="illustration">
51
- <a-ill-door :class="illClass" />
52
- </slot>
53
- </div>
54
- <p
55
- v-if="!noText"
56
- :class="textClass"
57
- >
58
- {{ text ?? t('illustrations.afterLogInBlock.tariff') }}
59
- </p>
60
- <slot name="button">
61
- <a-button
62
- v-if="!noBtn"
63
- :block="device.isMobile"
64
- view="outline"
65
- @click="goAuth"
66
- >
67
- {{ buttonName ?? t('illustrations.afterLogInBlock.login') }}
68
- </a-button>
69
- </slot>
70
- </div>
71
- </template>
1
+ <script setup lang="ts">
2
+ import { type LocalizedNavigationParams, navigateToLocalizedPage } from '#adata-ui/utils/localizedNavigation'
3
+ import { useUrls } from '#adata-ui/composables/useUrls'
4
+
5
+ interface Props {
6
+ illClass?: string
7
+ text?: string
8
+ textClass?:string
9
+ buttonName?: string
10
+ to?: LocalizedNavigationParams
11
+ noIll?: boolean
12
+ noText?: boolean
13
+ noBtn?: boolean
14
+ }
15
+ const props = defineProps<Props>()
16
+
17
+ const appConfig = useAppConfig()
18
+ const { login } = useUrls()
19
+ const authMode = appConfig.myLayer.authMode
20
+ const device = useAdaptive()
21
+ const { t, locale } = useI18n()
22
+
23
+ const { loginModal } = useIdModals()
24
+
25
+ function goAuth() {
26
+ if (authMode === 'local') {
27
+ loginModal.value = true
28
+ return
29
+ }
30
+
31
+ if (window) {
32
+ if (props.to) {
33
+ navigateToLocalizedPage(props.to)
34
+ } else {
35
+ const fullPath = encodeURIComponent(window.location.toString())
36
+ navigateToLocalizedPage({
37
+ locale,
38
+ projectUrl: login,
39
+ path: `/?url=${fullPath}`,
40
+ target: '_self'
41
+ })
42
+ }
43
+ }
44
+ }
45
+ </script>
46
+
47
+ <template>
48
+ <div class="flex flex-col items-center gap-4 text-center text-sm">
49
+ <div v-if="!noIll">
50
+ <slot name="illustration">
51
+ <a-ill-door :class="illClass" />
52
+ </slot>
53
+ </div>
54
+ <p
55
+ v-if="!noText"
56
+ :class="textClass"
57
+ >
58
+ {{ text ?? t('illustrations.afterLogInBlock.tariff') }}
59
+ </p>
60
+ <slot name="button">
61
+ <a-button
62
+ v-if="!noBtn"
63
+ :block="device.isMobile"
64
+ view="outline"
65
+ @click="goAuth"
66
+ >
67
+ {{ buttonName ?? t('illustrations.afterLogInBlock.login') }}
68
+ </a-button>
69
+ </slot>
70
+ </div>
71
+ </template>