adata-ui 2.1.17 → 2.1.19

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 (410) 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 +158 -158
  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 +130 -130
  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 -171
  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 -103
  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 +156 -156
  106. package/components/modals/Resend.vue +82 -82
  107. package/components/modals/SubmitApplicationModal.vue +123 -115
  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 +326 -326
  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 +267 -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/graph-pie.vue +14 -14
  255. package/icons/hand/hand-thumb-up-filled.vue +5 -5
  256. package/icons/hand/hand-thumb-up.vue +5 -5
  257. package/icons/hand-with-phone/hand-with-phone-dark.vue +52 -52
  258. package/icons/hand-with-phone/hand-with-phone-light.vue +52 -52
  259. package/icons/handshake.vue +5 -5
  260. package/icons/hcheck.vue +14 -14
  261. package/icons/hdocument.vue +7 -7
  262. package/icons/history.vue +5 -5
  263. package/icons/horizontal-more.vue +13 -13
  264. package/icons/hot-line.vue +6 -6
  265. package/icons/hummer.vue +16 -16
  266. package/icons/id.vue +7 -7
  267. package/icons/info/info-circle.vue +29 -29
  268. package/icons/invoice.vue +7 -7
  269. package/icons/judge.vue +14 -14
  270. package/icons/kaspi-qr.vue +13 -13
  271. package/icons/link-chain.vue +28 -28
  272. package/icons/link.vue +7 -7
  273. package/icons/linkedin.vue +24 -24
  274. package/icons/loader-circle.vue +27 -27
  275. package/icons/location.vue +8 -8
  276. package/icons/lock.vue +5 -5
  277. package/icons/logo.vue +15 -15
  278. package/icons/logout.vue +16 -16
  279. package/icons/magnify/magnifying-glass-minus.vue +8 -8
  280. package/icons/magnify/magnifying-glass-plus.vue +9 -9
  281. package/icons/magnify/magnifying-glass.vue +9 -9
  282. package/icons/mail.vue +7 -7
  283. package/icons/mailru.vue +34 -34
  284. package/icons/main-filter.vue +5 -5
  285. package/icons/map/map-pin-filled.vue +7 -7
  286. package/icons/map/map-pin-rect.vue +15 -15
  287. package/icons/map/map-pin.vue +7 -7
  288. package/icons/map-marker-start.vue +7 -7
  289. package/icons/map-paper.vue +5 -5
  290. package/icons/medal.vue +7 -7
  291. package/icons/menu-filled.vue +20 -20
  292. package/icons/menu.vue +8 -8
  293. package/icons/message/message.vue +12 -12
  294. package/icons/minus/minus-circle.vue +10 -10
  295. package/icons/money.vue +5 -5
  296. package/icons/monitoring.vue +10 -10
  297. package/icons/moon.vue +8 -8
  298. package/icons/more.vue +29 -29
  299. package/icons/note-pencil.vue +14 -14
  300. package/icons/note.vue +14 -14
  301. package/icons/notification.vue +16 -16
  302. package/icons/paperclip.vue +7 -7
  303. package/icons/payment/payment-card.vue +6 -6
  304. package/icons/payment/payment-kaspi.vue +11 -11
  305. package/icons/person-vector.vue +7 -7
  306. package/icons/person-with-briefcase.vue +10 -10
  307. package/icons/phone-filled.vue +5 -5
  308. package/icons/phone.vue +7 -7
  309. package/icons/plus/plus-circle.vue +8 -8
  310. package/icons/plus/plus.vue +13 -13
  311. package/icons/profile.vue +5 -5
  312. package/icons/radio/radio-check.vue +8 -8
  313. package/icons/radio/radio-empty.vue +10 -10
  314. package/icons/receipt.vue +8 -8
  315. package/icons/robot.vue +14 -14
  316. package/icons/sanctions.vue +8 -8
  317. package/icons/scales/scale.vue +16 -16
  318. package/icons/scales/scales.vue +5 -5
  319. package/icons/scales/standing-scales.vue +15 -15
  320. package/icons/search.vue +27 -27
  321. package/icons/share/share-alt.vue +5 -5
  322. package/icons/share/share.vue +14 -14
  323. package/icons/ship.vue +8 -8
  324. package/icons/socials/face-book.vue +15 -15
  325. package/icons/socials/instagram.vue +19 -19
  326. package/icons/socials/telegram.vue +15 -15
  327. package/icons/socials/tik-tok.vue +15 -15
  328. package/icons/socials/youtube.vue +16 -16
  329. package/icons/sort/sort-asc.vue +15 -15
  330. package/icons/sort/sort-desc.vue +15 -15
  331. package/icons/splitting-arrows.vue +8 -8
  332. package/icons/star/star-filled.vue +40 -40
  333. package/icons/star/star-half-filled.vue +20 -20
  334. package/icons/star/star.vue +25 -25
  335. package/icons/sun.vue +14 -14
  336. package/icons/sviazi.vue +5 -5
  337. package/icons/tag.vue +30 -30
  338. package/icons/tasks.vue +10 -10
  339. package/icons/tender-search.vue +11 -11
  340. package/icons/toasts/check-circle-toast.vue +6 -6
  341. package/icons/toasts/warning-triangle-toast.vue +7 -7
  342. package/icons/trash.vue +13 -13
  343. package/icons/triangle.vue +10 -10
  344. package/icons/truck.vue +7 -7
  345. package/icons/user-square.vue +14 -14
  346. package/icons/user.vue +22 -22
  347. package/icons/users-focus.vue +8 -8
  348. package/icons/users-three.vue +7 -7
  349. package/icons/users.vue +8 -8
  350. package/icons/warning/warning-circle.vue +29 -29
  351. package/icons/warning/warning-triangle-filled.vue +12 -12
  352. package/icons/warning/warning-triangle.vue +28 -28
  353. package/icons/whatsapp.vue +8 -8
  354. package/icons/work-bag.vue +11 -11
  355. package/icons/work-case.vue +9 -9
  356. package/icons/work-search.vue +10 -10
  357. package/icons/work.vue +5 -5
  358. package/icons/x-mark.vue +15 -15
  359. package/icons/yandex.vue +28 -28
  360. package/illustrations/address-location.vue +38 -38
  361. package/illustrations/ball-with-chain.vue +120 -120
  362. package/illustrations/bill.vue +133 -133
  363. package/illustrations/buildings.vue +82 -82
  364. package/illustrations/calendar.vue +156 -156
  365. package/illustrations/chains.vue +152 -152
  366. package/illustrations/coin-percent.vue +126 -126
  367. package/illustrations/coins-stack.vue +202 -202
  368. package/illustrations/delete-dark.vue +31 -31
  369. package/illustrations/delete.vue +32 -32
  370. package/illustrations/doc-with-stamp.vue +126 -126
  371. package/illustrations/document.vue +64 -64
  372. package/illustrations/door.vue +74 -74
  373. package/illustrations/empty-box.vue +77 -77
  374. package/illustrations/empty-wallet.vue +161 -161
  375. package/illustrations/graph-in-coin.vue +119 -119
  376. package/illustrations/hammer.vue +156 -156
  377. package/illustrations/hand-cash.vue +108 -108
  378. package/illustrations/info.vue +39 -39
  379. package/illustrations/mail.vue +68 -68
  380. package/illustrations/ok.vue +62 -62
  381. package/illustrations/people-group.vue +237 -237
  382. package/illustrations/person-with-phone.vue +187 -187
  383. package/illustrations/person.vue +159 -159
  384. package/illustrations/phone-check.vue +90 -90
  385. package/illustrations/phone-payment-method.vue +223 -223
  386. package/illustrations/stop-hand.vue +77 -77
  387. package/illustrations/stop-sign.vue +34 -34
  388. package/illustrations/suit.vue +111 -111
  389. package/illustrations/suitcase.vue +105 -105
  390. package/illustrations/terminal-dark.vue +48 -48
  391. package/illustrations/terminal.vue +234 -234
  392. package/illustrations/trash-can.vue +108 -108
  393. package/illustrations/turn-on-tariff.vue +38 -38
  394. package/illustrations/two-persons.vue +169 -169
  395. package/lang/en.ts +834 -834
  396. package/lang/kk.ts +836 -836
  397. package/lang/ru.ts +837 -837
  398. package/layouts/default.vue +13 -13
  399. package/nuxt.config.ts +88 -88
  400. package/package.json +69 -69
  401. package/plugins/maska.ts +4 -4
  402. package/plugins/toast.client.ts +58 -58
  403. package/public/kaspi/logo.svg +4 -4
  404. package/shared/constans/pages.ts +89 -89
  405. package/tailwind.config.ts +163 -163
  406. package/tests/AButton.test.ts +81 -81
  407. package/tsconfig.json +6 -6
  408. package/utils/getMaxZindex.ts +25 -25
  409. package/utils/localizedNavigation.ts +36 -36
  410. package/vitest.config.ts +14 -14
@@ -1,21 +1,21 @@
1
-
2
- export type StateType = {
3
- [key in 'default' | 'selected']: string;
4
- };
5
-
6
- export type ViewType = {
7
- bottom: StateType;
8
- left: StateType;
9
- right: StateType;
10
- };
11
-
12
-
13
-
14
- export interface Tab {
15
- name: string
16
- key: string | number
17
- count?: number
18
- disabled?: boolean
19
- warning?:boolean
20
- url?: string
21
- }
1
+
2
+ export type StateType = {
3
+ [key in 'default' | 'selected']: string;
4
+ };
5
+
6
+ export type ViewType = {
7
+ bottom: StateType;
8
+ left: StateType;
9
+ right: StateType;
10
+ };
11
+
12
+
13
+
14
+ export interface Tab {
15
+ name: string
16
+ key: string | number
17
+ count?: number
18
+ disabled?: boolean
19
+ warning?:boolean
20
+ url?: string
21
+ }
@@ -1,104 +1,104 @@
1
- <script setup lang="ts">
2
- import IconMenu from '#adata-ui/icons/menu-filled.vue'
3
- import IconInvoice from '#adata-ui/icons/invoice.vue'
4
- import ContentNavigationModal from '#adata-ui/components/modals/ContentNavigationModal.vue'
5
- import ContactsMobileModel from '#adata-ui/components/modals/ContactsMobileModel.vue'
6
- import ProfileMenu from '#adata-ui/components/navigation/header/ProfileMenu.vue'
7
- import type { ProjectKeys } from '#adata-ui/components/navigation/header/types'
8
- import { useCurrentModule } from '#adata-ui/composables/projectState'
9
- import AModal from "#adata-ui/components/overlays/modal/AModal.vue";
10
- import { useUrls } from '#adata-ui/composables/useUrls'
11
-
12
- interface Props {
13
- replenish?: string
14
- hasNotification?: boolean
15
- email: string | undefined
16
- rate: string
17
- daysRemaining: number
18
- limitRemaining: number
19
- balance: number
20
- isAuthenticated: boolean
21
- showLogIn?: boolean
22
- module?: ProjectKeys
23
- oldVersion?: string
24
- }
25
- const props = withDefaults(defineProps<Props>(), {
26
- limitRemaining: 0,
27
- daysRemaining: 0,
28
- balance: 0,
29
- rate: 'Базовый',
30
- showLogIn: true,
31
- module: 'pk'
32
- })
33
- const emit = defineEmits(['logout'])
34
- useCurrentModule().value = props.module
35
- const { landing } = useUrls()
36
- const activeModule = ref<string | null>(null)
37
- const isMain = ref(false)
38
- const isContacts = ref(false)
39
- const isProfile = ref(false)
40
- const { t } = useI18n()
41
- const items = [
42
- {
43
- label: 'modals.mobile_navigation.type_tariff',
44
- icon: IconInvoice,
45
- value: 'tariff'
46
- },
47
- {
48
- label: 'modals.mobile_navigation.type_main',
49
- icon: IconMenu,
50
- value: 'main'
51
- }
52
- ]
53
- function onLogout() {
54
- emit('logout')
55
- isProfile.value = false
56
- }
57
- watch(activeModule, (e) => {
58
- if (e === 'main') {
59
- isMain.value = true
60
- } else if (e === 'contacts') {
61
- isContacts.value = true
62
- } else if (e === 'profile') {
63
- isProfile.value = true
64
- } else if (e === 'tariff') {
65
- navigateTo(`${landing}/tariffs`, { external: true })
66
- }
67
- activeModule.value = ''
68
- })
69
- </script>
70
-
71
- <template>
72
- <div>
73
- <content-navigation-modal v-model="isMain" @push-main="isMain = false" />
74
- <contacts-mobile-model v-model="isContacts" @push-main="isContacts = false" />
75
- <a-modal v-model="isProfile" @logout="isProfile = false" @push-main="isProfile = false">
76
- <div class="-mx-4">
77
- <profile-menu
78
- :balance="balance"
79
- :days-remaining="daysRemaining"
80
- :limit-remaining="limitRemaining"
81
- :rate="rate"
82
- :replenish="replenish"
83
- :old-version="oldVersion"
84
- @logout="onLogout"
85
- />
86
- </div>
87
- </a-modal>
88
- <div ref="bottom" class="sticky bottom-0 z-[10000] lg:hidden">
89
- <a-bottom-navigation
90
- :is-authenticated="isAuthenticated"
91
- :email="email"
92
- :days-remaining="daysRemaining"
93
- :limit-remaining="limitRemaining"
94
- :rate="rate"
95
- :balance="balance"
96
- @logout="onLogout"
97
- v-model="activeModule"
98
- :items="items"
99
- />
100
- </div>
101
- </div>
102
- </template>
103
-
104
- <style scoped></style>
1
+ <script setup lang="ts">
2
+ import IconMenu from '#adata-ui/icons/menu-filled.vue'
3
+ import IconInvoice from '#adata-ui/icons/invoice.vue'
4
+ import ContentNavigationModal from '#adata-ui/components/modals/ContentNavigationModal.vue'
5
+ import ContactsMobileModel from '#adata-ui/components/modals/ContactsMobileModel.vue'
6
+ import ProfileMenu from '#adata-ui/components/navigation/header/ProfileMenu.vue'
7
+ import type { ProjectKeys } from '#adata-ui/components/navigation/header/types'
8
+ import { useCurrentModule } from '#adata-ui/composables/projectState'
9
+ import AModal from "#adata-ui/components/overlays/modal/AModal.vue";
10
+ import { useUrls } from '#adata-ui/composables/useUrls'
11
+
12
+ interface Props {
13
+ replenish?: string
14
+ hasNotification?: boolean
15
+ email: string | undefined
16
+ rate: string
17
+ daysRemaining: number
18
+ limitRemaining: number
19
+ balance: number
20
+ isAuthenticated: boolean
21
+ showLogIn?: boolean
22
+ module?: ProjectKeys
23
+ oldVersion?: string
24
+ }
25
+ const props = withDefaults(defineProps<Props>(), {
26
+ limitRemaining: 0,
27
+ daysRemaining: 0,
28
+ balance: 0,
29
+ rate: 'Базовый',
30
+ showLogIn: true,
31
+ module: 'pk'
32
+ })
33
+ const emit = defineEmits(['logout'])
34
+ useCurrentModule().value = props.module
35
+ const { landing } = useUrls()
36
+ const activeModule = ref<string | null>(null)
37
+ const isMain = ref(false)
38
+ const isContacts = ref(false)
39
+ const isProfile = ref(false)
40
+ const { t } = useI18n()
41
+ const items = [
42
+ {
43
+ label: 'modals.mobile_navigation.type_tariff',
44
+ icon: IconInvoice,
45
+ value: 'tariff'
46
+ },
47
+ {
48
+ label: 'modals.mobile_navigation.type_main',
49
+ icon: IconMenu,
50
+ value: 'main'
51
+ }
52
+ ]
53
+ function onLogout() {
54
+ emit('logout')
55
+ isProfile.value = false
56
+ }
57
+ watch(activeModule, (e) => {
58
+ if (e === 'main') {
59
+ isMain.value = true
60
+ } else if (e === 'contacts') {
61
+ isContacts.value = true
62
+ } else if (e === 'profile') {
63
+ isProfile.value = true
64
+ } else if (e === 'tariff') {
65
+ navigateTo(`${landing}/tariffs`, { external: true })
66
+ }
67
+ activeModule.value = ''
68
+ })
69
+ </script>
70
+
71
+ <template>
72
+ <div>
73
+ <content-navigation-modal v-model="isMain" @push-main="isMain = false" />
74
+ <contacts-mobile-model v-model="isContacts" @push-main="isContacts = false" />
75
+ <a-modal v-model="isProfile" @logout="isProfile = false" @push-main="isProfile = false">
76
+ <div class="-mx-4">
77
+ <profile-menu
78
+ :balance="balance"
79
+ :days-remaining="daysRemaining"
80
+ :limit-remaining="limitRemaining"
81
+ :rate="rate"
82
+ :replenish="replenish"
83
+ :old-version="oldVersion"
84
+ @logout="onLogout"
85
+ />
86
+ </div>
87
+ </a-modal>
88
+ <div ref="bottom" class="sticky bottom-0 z-[10000] lg:hidden">
89
+ <a-bottom-navigation
90
+ :is-authenticated="isAuthenticated"
91
+ :email="email"
92
+ :days-remaining="daysRemaining"
93
+ :limit-remaining="limitRemaining"
94
+ :rate="rate"
95
+ :balance="balance"
96
+ @logout="onLogout"
97
+ v-model="activeModule"
98
+ :items="items"
99
+ />
100
+ </div>
101
+ </div>
102
+ </template>
103
+
104
+ <style scoped></style>
@@ -1,171 +1,171 @@
1
- <template>
2
- <div
3
- ref="tabs"
4
- class="scroll-container overflow-auto whitespace-nowrap"
5
- :class="[
6
- props.wrapper === 'row' ? 'flex gap-1' : 'flex flex-col gap-1',
7
- isSegmented ? 'rounded-[12px] bg-gray-50 p-1 shadow-[inset_2px_2px_4px_0_#00000014] dark:bg-gray-800' : ''
8
- ]"
9
- >
10
-
11
- <button
12
- v-for="option in options"
13
- :key="option.key"
14
- :disabled="option.disabled || disabled"
15
- :data-active="activeTab === option.key"
16
- :class="[
17
- activeTab === option.key ? selectedClasses() : defaultClasses(!!option.disabled),
18
- sizeOptions[size]
19
- ]"
20
- @click="onChanged(option, $event)"
21
- >
22
- <slot name="option" :option="option">
23
- <span
24
- class="flex items-center gap-1 whitespace-nowrap"
25
- :class="[align === 'left' ? 'justify-start' : 'justify-center']"
26
- >
27
- <span>
28
- {{ t(option.name) }}
29
- </span>
30
- <template v-if="option.count !== undefined">
31
- <a-digit-badge
32
- v-if="props.countView === 'badge'"
33
- :value="option.count"
34
- :type="option.badgeColor ? option.badgeColor : 'primary'"
35
- :disabled="(option.disabled || option.count === 0) && activeTab !== option.key"
36
- :view="activeTab === option.key ? 'inverted' : 'default'"
37
- :size="badgeSize"
38
- />
39
- <span v-else-if="props.countView === 'brackets'"> ({{ option.count }}) </span>
40
- </template>
41
- </span>
42
- </slot>
43
- </button>
44
- </div>
45
- </template>
46
-
47
- <script setup lang="ts">
48
- import type { Tab, ViewType } from './types'
49
-
50
- defineOptions({ name: 'APillTabs' })
51
- const emit = defineEmits(['selectOption', 'prevent'])
52
-
53
- interface Props {
54
- options: Tab[]
55
- // TODO: переименовать segmented
56
- view?: 'transparent' | 'main' | 'gray' | 'blue' | 'mobile' | 'segmented'
57
- size?: 'lg' | 'md' | 'sm' | 'xs' | 'ss'
58
- badgeSize?: 'sm' | 'md' | 'lg'
59
- align?: 'left' | 'center'
60
- block?: boolean
61
- wrapper?: 'column' | 'row'
62
- countView?: 'badge' | 'brackets'
63
- disabled?: boolean
64
- }
65
-
66
- const props = withDefaults(defineProps<Props>(), {
67
- view: 'main',
68
- size: 'md',
69
- align: 'center',
70
- badgeSize: 'lg',
71
- block: false,
72
- wrapper: 'row',
73
- countView: 'badge'
74
- })
75
- const tabs = ref<HTMLDivElement | null>(null)
76
- const activeTab = defineModel<any>({ default: 1 })
77
- const { t } = useI18n()
78
-
79
-
80
- // todo: вынести в пропc
81
- const isSegmented = computed(() => props.view === 'segmented')
82
-
83
- const viewTypeValues: ViewType = {
84
- main: {
85
- default:
86
- 'text-deepblue-900 bg-deepblue-900/5 hover:bg-deepblue-900/10 dark:bg-gray-200/5 dark:text-gray-200 dark:hover:bg-gray-800 ',
87
- selected: 'bg-blue-700 font-semibold text-white dark:text-gray-900 dark:bg-blue-500'
88
- },
89
- transparent: {
90
- default: 'text-deepblue-900 bg-transparent hover:bg-deepblue-100',
91
- selected: 'font-semibold bg-white text-deepblue-900 '
92
- },
93
- gray: {
94
- default:
95
- 'bg-deepblue-900/5 hover:bg-deepblue-900/20 dark:bg-gray-50/10 dark:hover:bg-gray-50/20 dark:text-gray-50',
96
- selected: 'text-white bg-deepblue-900 dark:bg-gray-50 dark:text-gray-900'
97
- },
98
- blue: {
99
- default:
100
- 'text-deepblue-900 bg-white font-semibold leading-5 dark:bg-gray-900 dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-deepblue-100 ',
101
- selected: 'bg-blue-700 font-semibold leading-5 text-white dark:text-gray-900 dark:bg-blue-500'
102
- },
103
- mobile: {
104
- default:
105
- 'bg-white dark:text-gray-200 font-semibold dark:bg-gray-900 dark:hover:bg-gray-500 hover:bg-deepblue-100 ',
106
- selected: 'text-white dark:text-gray-900 font-semibold dark:bg-white bg-deepblue-900'
107
- },
108
- segmented: {
109
- default: 'text-deepblue-900 bg-transparent hover:bg-black/5 dark:hover:bg-white/10 dark:text-gray-200',
110
- selected: 'bg-white text-deepblue-900 font-semibold shadow dark:bg-gray-900 dark:text-gray-200 shadow-[2px_2px_4px_0_#00000014]'
111
- }
112
- }
113
-
114
- const defaultClasses = (isDisabled: boolean) => [
115
- 'text-sm rounded-md outline-none select-none focus-visible:shadow-[0_0_0_4px#1B64B3]',
116
- isDisabled ? 'bg-deepblue-900/5 dark:bg-gray-200/5 text-gray-500 dark:text-gray-500' : '',
117
- props.view === 'transparent' && isDisabled ? 'bg-transparent' : '',
118
- viewTypeValues[props.view]['default'],
119
- props.block ? 'w-full' : ''
120
- ]
121
- const selectedClasses = () => [
122
- 'text-sm rounded-md select-none focus-visible:shadow-[0_0_0_4px#1B64B3]',
123
- viewTypeValues[props.view]['selected'],
124
- props.block ? 'w-full' : ''
125
- ]
126
-
127
- const sizeOptions = {
128
- lg: 'px-4 py-2.5',
129
- sm: 'px-4 py-[7.5px]',
130
- md: 'px-4 py-2',
131
- ss: 'px-3 py-1.5',
132
- xs: 'px-3 py-[4px]'
133
- }
134
-
135
- const onChanged = (option: Tab, event) => {
136
- if (option.prevent) {
137
- emit('prevent', option)
138
- return
139
- }
140
- activeTab.value = option.key
141
- emit('selectOption', option)
142
- event.preventDefault()
143
- event.currentTarget.scrollIntoView({
144
- behavior: 'smooth',
145
- inline: 'start',
146
- block: 'nearest'
147
- })
148
- }
149
-
150
- onMounted(() => {
151
- const isDesktop = window.matchMedia('(min-width: 1024px)').matches
152
-
153
- if (tabs.value && !isDesktop) {
154
- const activeTab = tabs.value.querySelector('[data-active="true"]')
155
-
156
- if (activeTab) {
157
- activeTab.scrollIntoView({
158
- inline: 'start',
159
- block: 'nearest',
160
- })
161
- }
162
- }
163
- })
164
- </script>
165
-
166
- <style scoped>
167
- /* Add any additional styles here */
168
- .scroll-container::-webkit-scrollbar {
169
- display: none; /* для браузеров на основе WebKit */
170
- }
171
- </style>
1
+ <template>
2
+ <div
3
+ ref="tabs"
4
+ class="scroll-container overflow-auto whitespace-nowrap"
5
+ :class="[
6
+ props.wrapper === 'row' ? 'flex gap-1' : 'flex flex-col gap-1',
7
+ isSegmented ? 'rounded-[12px] bg-gray-50 p-1 shadow-[inset_2px_2px_4px_0_#00000014] dark:bg-gray-800' : ''
8
+ ]"
9
+ >
10
+
11
+ <button
12
+ v-for="option in options"
13
+ :key="option.key"
14
+ :disabled="option.disabled || disabled"
15
+ :data-active="activeTab === option.key"
16
+ :class="[
17
+ activeTab === option.key ? selectedClasses() : defaultClasses(!!option.disabled),
18
+ sizeOptions[size]
19
+ ]"
20
+ @click="onChanged(option, $event)"
21
+ >
22
+ <slot name="option" :option="option">
23
+ <span
24
+ class="flex items-center gap-1 whitespace-nowrap"
25
+ :class="[align === 'left' ? 'justify-start' : 'justify-center']"
26
+ >
27
+ <span>
28
+ {{ t(option.name) }}
29
+ </span>
30
+ <template v-if="option.count !== undefined">
31
+ <a-digit-badge
32
+ v-if="props.countView === 'badge'"
33
+ :value="option.count"
34
+ :type="option.badgeColor ? option.badgeColor : 'primary'"
35
+ :disabled="(option.disabled || option.count === 0) && activeTab !== option.key"
36
+ :view="activeTab === option.key ? 'inverted' : 'default'"
37
+ :size="badgeSize"
38
+ />
39
+ <span v-else-if="props.countView === 'brackets'"> ({{ option.count }}) </span>
40
+ </template>
41
+ </span>
42
+ </slot>
43
+ </button>
44
+ </div>
45
+ </template>
46
+
47
+ <script setup lang="ts">
48
+ import type { Tab, ViewType } from './types'
49
+
50
+ defineOptions({ name: 'APillTabs' })
51
+ const emit = defineEmits(['selectOption', 'prevent'])
52
+
53
+ interface Props {
54
+ options: Tab[]
55
+ // TODO: переименовать segmented
56
+ view?: 'transparent' | 'main' | 'gray' | 'blue' | 'mobile' | 'segmented'
57
+ size?: 'lg' | 'md' | 'sm' | 'xs' | 'ss'
58
+ badgeSize?: 'sm' | 'md' | 'lg'
59
+ align?: 'left' | 'center'
60
+ block?: boolean
61
+ wrapper?: 'column' | 'row'
62
+ countView?: 'badge' | 'brackets'
63
+ disabled?: boolean
64
+ }
65
+
66
+ const props = withDefaults(defineProps<Props>(), {
67
+ view: 'main',
68
+ size: 'md',
69
+ align: 'center',
70
+ badgeSize: 'lg',
71
+ block: false,
72
+ wrapper: 'row',
73
+ countView: 'badge'
74
+ })
75
+ const tabs = ref<HTMLDivElement | null>(null)
76
+ const activeTab = defineModel<any>({ default: 1 })
77
+ const { t } = useI18n()
78
+
79
+
80
+ // todo: вынести в пропc
81
+ const isSegmented = computed(() => props.view === 'segmented')
82
+
83
+ const viewTypeValues: ViewType = {
84
+ main: {
85
+ default:
86
+ 'text-deepblue-900 bg-deepblue-900/5 hover:bg-deepblue-900/10 dark:bg-gray-200/5 dark:text-gray-200 dark:hover:bg-gray-800 ',
87
+ selected: 'bg-blue-700 font-semibold text-white dark:text-gray-900 dark:bg-blue-500'
88
+ },
89
+ transparent: {
90
+ default: 'text-deepblue-900 bg-transparent hover:bg-deepblue-100',
91
+ selected: 'font-semibold bg-white text-deepblue-900 '
92
+ },
93
+ gray: {
94
+ default:
95
+ 'bg-deepblue-900/5 hover:bg-deepblue-900/20 dark:bg-gray-50/10 dark:hover:bg-gray-50/20 dark:text-gray-50',
96
+ selected: 'text-white bg-deepblue-900 dark:bg-gray-50 dark:text-gray-900'
97
+ },
98
+ blue: {
99
+ default:
100
+ 'text-deepblue-900 bg-white font-semibold leading-5 dark:bg-gray-900 dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-deepblue-100 ',
101
+ selected: 'bg-blue-700 font-semibold leading-5 text-white dark:text-gray-900 dark:bg-blue-500'
102
+ },
103
+ mobile: {
104
+ default:
105
+ 'bg-white dark:text-gray-200 font-semibold dark:bg-gray-900 dark:hover:bg-gray-500 hover:bg-deepblue-100 ',
106
+ selected: 'text-white dark:text-gray-900 font-semibold dark:bg-white bg-deepblue-900'
107
+ },
108
+ segmented: {
109
+ default: 'text-deepblue-900 bg-transparent hover:bg-black/5 dark:hover:bg-white/10 dark:text-gray-200',
110
+ selected: 'bg-white text-deepblue-900 font-semibold shadow dark:bg-gray-900 dark:text-gray-200 shadow-[2px_2px_4px_0_#00000014]'
111
+ }
112
+ }
113
+
114
+ const defaultClasses = (isDisabled: boolean) => [
115
+ 'text-sm rounded-md outline-none select-none focus-visible:shadow-[0_0_0_4px#1B64B3]',
116
+ isDisabled ? 'bg-deepblue-900/5 dark:bg-gray-200/5 text-gray-500 dark:text-gray-500' : '',
117
+ props.view === 'transparent' && isDisabled ? 'bg-transparent' : '',
118
+ viewTypeValues[props.view]['default'],
119
+ props.block ? 'w-full' : ''
120
+ ]
121
+ const selectedClasses = () => [
122
+ 'text-sm rounded-md select-none focus-visible:shadow-[0_0_0_4px#1B64B3]',
123
+ viewTypeValues[props.view]['selected'],
124
+ props.block ? 'w-full' : ''
125
+ ]
126
+
127
+ const sizeOptions = {
128
+ lg: 'px-4 py-2.5',
129
+ sm: 'px-4 py-[7.5px]',
130
+ md: 'px-4 py-2',
131
+ ss: 'px-3 py-1.5',
132
+ xs: 'px-3 py-[4px]'
133
+ }
134
+
135
+ const onChanged = (option: Tab, event) => {
136
+ if (option.prevent) {
137
+ emit('prevent', option)
138
+ return
139
+ }
140
+ activeTab.value = option.key
141
+ emit('selectOption', option)
142
+ event.preventDefault()
143
+ event.currentTarget.scrollIntoView({
144
+ behavior: 'smooth',
145
+ inline: 'start',
146
+ block: 'nearest'
147
+ })
148
+ }
149
+
150
+ onMounted(() => {
151
+ const isDesktop = window.matchMedia('(min-width: 1024px)').matches
152
+
153
+ if (tabs.value && !isDesktop) {
154
+ const activeTab = tabs.value.querySelector('[data-active="true"]')
155
+
156
+ if (activeTab) {
157
+ activeTab.scrollIntoView({
158
+ inline: 'start',
159
+ block: 'nearest',
160
+ })
161
+ }
162
+ }
163
+ })
164
+ </script>
165
+
166
+ <style scoped>
167
+ /* Add any additional styles here */
168
+ .scroll-container::-webkit-scrollbar {
169
+ display: none; /* для браузеров на основе WebKit */
170
+ }
171
+ </style>
@@ -1,23 +1,23 @@
1
-
2
- export type StateType = {
3
- [key in 'default' | 'selected']: string;
4
- };
5
-
6
- export type ViewType = {
7
- transparent: StateType;
8
- main: StateType;
9
- gray: StateType;
10
- blue: StateType;
11
- mobile: StateType;
12
- segmented: StateType;
13
- };
14
-
15
-
16
- export interface Tab {
17
- name: string
18
- key: string | number
19
- count?: number
20
- disabled?: boolean
21
- prevent?:boolean
22
- badgeColor?: 'primary' | 'success' | 'danger' | 'gray' | 'orange' | 'warning'
23
- }
1
+
2
+ export type StateType = {
3
+ [key in 'default' | 'selected']: string;
4
+ };
5
+
6
+ export type ViewType = {
7
+ transparent: StateType;
8
+ main: StateType;
9
+ gray: StateType;
10
+ blue: StateType;
11
+ mobile: StateType;
12
+ segmented: StateType;
13
+ };
14
+
15
+
16
+ export interface Tab {
17
+ name: string
18
+ key: string | number
19
+ count?: number
20
+ disabled?: boolean
21
+ prevent?:boolean
22
+ badgeColor?: 'primary' | 'success' | 'danger' | 'gray' | 'orange' | 'warning'
23
+ }