adata-ui 2.1.19 → 2.1.21

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 +162 -158
  73. package/components/features/payment/process/PaymentKaspiRedirectSidePanel.vue +113 -112
  74. package/components/features/payment/process/PaymentMethodSidePanel.vue +122 -121
  75. package/components/features/payment/process/PaymentProcess.vue +138 -138
  76. package/components/features/payment/process/PaymentTopUpSidePanel.vue +134 -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 -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 +156 -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 -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,194 +1,194 @@
1
- <script setup lang="ts">
2
- import ArrowCurrency from '#adata-ui/icons/currency/currency-down.vue'
3
- import UsdIcon from '#adata-ui/icons/currency/currency-usd.vue'
4
- import EurIcon from '#adata-ui/icons/currency/currency-eur.vue'
5
- import RubIcon from '#adata-ui/icons/currency/currency-rub.vue'
6
- import YuanIcon from '#adata-ui/icons/currency/currency-yuan.vue'
7
-
8
- interface Props {
9
- daysRemaining: number
10
- limitRemaining: number
11
- moduleName: string
12
- isAuthenticated: boolean
13
- }
14
-
15
- const props = withDefaults(defineProps<Props>(), {
16
- moduleName: 'counterparty'
17
- })
18
-
19
- const { t, locale } = useI18n()
20
-
21
- interface ResponseData<DataResult> {
22
- success: boolean
23
- message: string
24
- data: DataResult
25
- }
26
-
27
- interface Currency {
28
- buy: number
29
- buy_state: string
30
- currency: 'USD' | 'EUR' | 'RUB' | 'CNY'
31
- sell: number
32
- sell_state: string
33
- }
34
-
35
- interface Currencies {
36
- currencies: Currency[]
37
- request_time: string
38
- time: string
39
- }
40
-
41
- const currencies = ref<Currency[]>([])
42
- const systemMessage = ref(null)
43
- const isOpenNotification = ref(false)
44
- const message = useCookie('message')
45
-
46
- const { myLayer } = useAppConfig()
47
- const env = myLayer.mode
48
-
49
- const mode = computed(() => {
50
- if (props.moduleName === 'pk') {
51
- return 'counterparty'
52
- } else {
53
- return props.moduleName
54
- }
55
- })
56
-
57
- const fetchCurrencies = async () => {
58
- try {
59
- const response = await fetch('https://users.adata.kz/api/v1/information/currency')
60
- const { data } = await response.json()
61
-
62
- if (data.currencies) {
63
- currencies.value = data.currencies
64
- }
65
- } catch (e) {
66
- console.error(e.message)
67
- }
68
- }
69
-
70
- const Symbols = {
71
- USD: UsdIcon,
72
- EUR: EurIcon,
73
- RUB: RubIcon,
74
- CNY: YuanIcon
75
- }
76
-
77
- const computedClass = (state: string) =>
78
- state === 'UP' ? 'text-green-400 rotate-180' : 'text-red-400'
79
-
80
- const fetchNotification = async () => {
81
- try {
82
- if (message.value === undefined) {
83
- const link = `https://users.${env}.kz/api/v1/system-messages/active-list/?module_name=${mode.value}`
84
- const response = await fetch(link)
85
- const { data } = await response.json()
86
-
87
- if (data.details?.length) {
88
- switch (locale.value) {
89
- case 'ru':
90
- systemMessage.value = data.details[0].message
91
- break
92
- case 'en':
93
- systemMessage.value = data.details[0].message_en
94
- break
95
- case 'kk':
96
- systemMessage.value = data.details[0].message_kz
97
- break
98
- }
99
- isOpenNotification.value = true
100
- }
101
- }
102
- } catch (e) {
103
- console.error(e.message)
104
- }
105
- }
106
-
107
- onBeforeMount(() => {
108
- fetchNotification()
109
- fetchCurrencies()
110
- })
111
-
112
- const closeMessage = () => {
113
- message.value = false
114
- isOpenNotification.value = false
115
- }
116
- </script>
117
-
118
- <template>
119
- <div class="min-h-[40px]" :class="[isOpenNotification && systemMessage ? '' : 'hidden lg:block']">
120
- <transition name="fade">
121
- <div
122
- v-if="isOpenNotification && systemMessage"
123
- class="bg-[#FFF5E6] px-2 py-3 text-[#FCA204] dark:bg-[#161617] md:px-0"
124
- >
125
- <div class="a-container flex items-center justify-between">
126
- <div class="flex items-center gap-2">
127
- <a-icon-info-circle
128
- class="max-h-[16px] w-full max-w-[16px] stroke-orange-500 dark:stroke-orange-500"
129
- />
130
- <span class="text-sm font-semibold text-orange-500">{{ systemMessage }}</span>
131
- </div>
132
- <a-icon-x-mark
133
- class="max-h-[16px] w-full max-w-[16px] cursor-pointer stroke-orange-500"
134
- @click="closeMessage"
135
- />
136
- </div>
137
- </div>
138
- </transition>
139
- <div
140
- v-if="!isOpenNotification || !systemMessage"
141
- class="hidden min-h-10 bg-gray-50 dark:bg-gray-950 lg:block"
142
- >
143
- <div class="a-container flex justify-between py-2 items-center text-sm">
144
- <div class="flex items-center leading-[24px]">
145
- <div v-for="currency in currencies" :key="currency.currency" class="mr-4 flex gap-2">
146
- <div class="flex items-center">
147
- <component
148
- :is="Symbols[currency.currency]"
149
- class="mr-2 size-4 rounded-sm border border-solid border-[#E0E3E6] dark:border-[#2B2B2C]"
150
- />
151
- {{ currency.buy }}
152
- <div :class="computedClass(currency.sell_state)">
153
- <arrow-currency />
154
- </div>
155
- </div>
156
- <div class="flex items-center">
157
- {{ currency.sell }}
158
- <div :class="computedClass(currency.sell_state)">
159
- <arrow-currency />
160
- </div>
161
- </div>
162
- </div>
163
- </div>
164
- <div v-if="isAuthenticated" class="flex items-center gap-5">
165
- <div v-if="limitRemaining != null || limitRemaining != undefined">
166
- <span class="mr-2 text-xs">{{ t('header.top.requestLimit') }}</span>
167
- <a-status-badge size="sm">
168
- {{ limitRemaining }}
169
- </a-status-badge>
170
- </div>
171
- <div v-if="daysRemaining">
172
- <span class="mr-2 text-xs">{{ t('header.top.daysLeft') }}</span>
173
- <a-status-badge size="sm">
174
- {{ daysRemaining }}
175
- </a-status-badge>
176
- </div>
177
- </div>
178
- </div>
179
- </div>
180
- </div>
181
- </template>
182
-
183
- <style scoped>
184
- .fade-enter-active,
185
- .fade-leave-active {
186
- transition: 0.1s ease;
187
- }
188
-
189
- .fade-enter,
190
- .fade-leave-to {
191
- opacity: 0;
192
- top: 0px;
193
- }
194
- </style>
1
+ <script setup lang="ts">
2
+ import ArrowCurrency from '#adata-ui/icons/currency/currency-down.vue'
3
+ import UsdIcon from '#adata-ui/icons/currency/currency-usd.vue'
4
+ import EurIcon from '#adata-ui/icons/currency/currency-eur.vue'
5
+ import RubIcon from '#adata-ui/icons/currency/currency-rub.vue'
6
+ import YuanIcon from '#adata-ui/icons/currency/currency-yuan.vue'
7
+
8
+ interface Props {
9
+ daysRemaining: number
10
+ limitRemaining: number
11
+ moduleName: string
12
+ isAuthenticated: boolean
13
+ }
14
+
15
+ const props = withDefaults(defineProps<Props>(), {
16
+ moduleName: 'counterparty'
17
+ })
18
+
19
+ const { t, locale } = useI18n()
20
+
21
+ interface ResponseData<DataResult> {
22
+ success: boolean
23
+ message: string
24
+ data: DataResult
25
+ }
26
+
27
+ interface Currency {
28
+ buy: number
29
+ buy_state: string
30
+ currency: 'USD' | 'EUR' | 'RUB' | 'CNY'
31
+ sell: number
32
+ sell_state: string
33
+ }
34
+
35
+ interface Currencies {
36
+ currencies: Currency[]
37
+ request_time: string
38
+ time: string
39
+ }
40
+
41
+ const currencies = ref<Currency[]>([])
42
+ const systemMessage = ref(null)
43
+ const isOpenNotification = ref(false)
44
+ const message = useCookie('message')
45
+
46
+ const { myLayer } = useAppConfig()
47
+ const env = myLayer.mode
48
+
49
+ const mode = computed(() => {
50
+ if (props.moduleName === 'pk') {
51
+ return 'counterparty'
52
+ } else {
53
+ return props.moduleName
54
+ }
55
+ })
56
+
57
+ const fetchCurrencies = async () => {
58
+ try {
59
+ const response = await fetch('https://users.adata.kz/api/v1/information/currency')
60
+ const { data } = await response.json()
61
+
62
+ if (data.currencies) {
63
+ currencies.value = data.currencies
64
+ }
65
+ } catch (e) {
66
+ console.error(e.message)
67
+ }
68
+ }
69
+
70
+ const Symbols = {
71
+ USD: UsdIcon,
72
+ EUR: EurIcon,
73
+ RUB: RubIcon,
74
+ CNY: YuanIcon
75
+ }
76
+
77
+ const computedClass = (state: string) =>
78
+ state === 'UP' ? 'text-green-400 rotate-180' : 'text-red-400'
79
+
80
+ const fetchNotification = async () => {
81
+ try {
82
+ if (message.value === undefined) {
83
+ const link = `https://users.${env}.kz/api/v1/system-messages/active-list/?module_name=${mode.value}`
84
+ const response = await fetch(link)
85
+ const { data } = await response.json()
86
+
87
+ if (data.details?.length) {
88
+ switch (locale.value) {
89
+ case 'ru':
90
+ systemMessage.value = data.details[0].message
91
+ break
92
+ case 'en':
93
+ systemMessage.value = data.details[0].message_en
94
+ break
95
+ case 'kk':
96
+ systemMessage.value = data.details[0].message_kz
97
+ break
98
+ }
99
+ isOpenNotification.value = true
100
+ }
101
+ }
102
+ } catch (e) {
103
+ console.error(e.message)
104
+ }
105
+ }
106
+
107
+ onBeforeMount(() => {
108
+ fetchNotification()
109
+ fetchCurrencies()
110
+ })
111
+
112
+ const closeMessage = () => {
113
+ message.value = false
114
+ isOpenNotification.value = false
115
+ }
116
+ </script>
117
+
118
+ <template>
119
+ <div class="min-h-[40px]" :class="[isOpenNotification && systemMessage ? '' : 'hidden lg:block']">
120
+ <transition name="fade">
121
+ <div
122
+ v-if="isOpenNotification && systemMessage"
123
+ class="bg-[#FFF5E6] px-2 py-3 text-[#FCA204] dark:bg-[#161617] md:px-0"
124
+ >
125
+ <div class="a-container flex items-center justify-between">
126
+ <div class="flex items-center gap-2">
127
+ <a-icon-info-circle
128
+ class="max-h-[16px] w-full max-w-[16px] stroke-orange-500 dark:stroke-orange-500"
129
+ />
130
+ <span class="text-sm font-semibold text-orange-500">{{ systemMessage }}</span>
131
+ </div>
132
+ <a-icon-x-mark
133
+ class="max-h-[16px] w-full max-w-[16px] cursor-pointer stroke-orange-500"
134
+ @click="closeMessage"
135
+ />
136
+ </div>
137
+ </div>
138
+ </transition>
139
+ <div
140
+ v-if="!isOpenNotification || !systemMessage"
141
+ class="hidden min-h-10 bg-gray-50 dark:bg-gray-950 lg:block"
142
+ >
143
+ <div class="a-container flex justify-between py-2 items-center text-sm">
144
+ <div class="flex items-center leading-[24px]">
145
+ <div v-for="currency in currencies" :key="currency.currency" class="mr-4 flex gap-2">
146
+ <div class="flex items-center">
147
+ <component
148
+ :is="Symbols[currency.currency]"
149
+ class="mr-2 size-4 rounded-sm border border-solid border-[#E0E3E6] dark:border-[#2B2B2C]"
150
+ />
151
+ {{ currency.buy }}
152
+ <div :class="computedClass(currency.sell_state)">
153
+ <arrow-currency />
154
+ </div>
155
+ </div>
156
+ <div class="flex items-center">
157
+ {{ currency.sell }}
158
+ <div :class="computedClass(currency.sell_state)">
159
+ <arrow-currency />
160
+ </div>
161
+ </div>
162
+ </div>
163
+ </div>
164
+ <div v-if="isAuthenticated" class="flex items-center gap-5">
165
+ <div v-if="limitRemaining != null || limitRemaining != undefined">
166
+ <span class="mr-2 text-xs">{{ t('header.top.requestLimit') }}</span>
167
+ <a-status-badge size="sm">
168
+ {{ limitRemaining }}
169
+ </a-status-badge>
170
+ </div>
171
+ <div v-if="daysRemaining">
172
+ <span class="mr-2 text-xs">{{ t('header.top.daysLeft') }}</span>
173
+ <a-status-badge size="sm">
174
+ {{ daysRemaining }}
175
+ </a-status-badge>
176
+ </div>
177
+ </div>
178
+ </div>
179
+ </div>
180
+ </div>
181
+ </template>
182
+
183
+ <style scoped>
184
+ .fade-enter-active,
185
+ .fade-leave-active {
186
+ transition: 0.1s ease;
187
+ }
188
+
189
+ .fade-enter,
190
+ .fade-leave-to {
191
+ opacity: 0;
192
+ top: 0px;
193
+ }
194
+ </style>
@@ -1,28 +1,28 @@
1
- export type NavChild = {
2
- key: string,
3
- name: string
4
- items: NavChildItem[]
5
- }
6
- export type NavChildItem = {
7
- title: string
8
- subtitle?: string
9
- icon?: any
10
- to: string
11
- }
12
-
13
- export type NavLink = {
14
- label: string
15
- to: string
16
- items?: NavChild[],
17
- options?:any
18
- icon?: any
19
- }
20
- export type ProjectKeys =
21
- | 'counterparty'
22
- | 'pk'
23
- | 'work'
24
- | 'tenders'
25
- | 'fines'
26
- | 'analytics'
27
- | 'fea'
28
- | 'compliance';
1
+ export type NavChild = {
2
+ key: string,
3
+ name: string
4
+ items: NavChildItem[]
5
+ }
6
+ export type NavChildItem = {
7
+ title: string
8
+ subtitle?: string
9
+ icon?: any
10
+ to: string
11
+ }
12
+
13
+ export type NavLink = {
14
+ label: string
15
+ to: string
16
+ items?: NavChild[],
17
+ options?:any
18
+ icon?: any
19
+ }
20
+ export type ProjectKeys =
21
+ | 'counterparty'
22
+ | 'pk'
23
+ | 'work'
24
+ | 'tenders'
25
+ | 'fines'
26
+ | 'analytics'
27
+ | 'fea'
28
+ | 'compliance';
@@ -1,111 +1,111 @@
1
- <template>
2
- <div
3
- class="whitespace-nowrap overflow-auto"
4
- :class="props.wrapper === 'row'? 'flex':'flex flex-col'"
5
- >
6
- <button
7
- v-for="(option) in options"
8
- :key="option.key"
9
- :disabled="option.disabled"
10
- :class="activeTab === option.key ? selectedClasses() : defaultClasses()"
11
- @click="() => handleClick(option)"
12
- >
13
- <slot
14
- name="option"
15
- :option="option"
16
- >
17
- <span
18
- class="flex gap-1 "
19
- :class="[align === 'left' ? 'justify-between' : 'justify-center' ]"
20
- >
21
- <span>
22
- {{ option.name }}
23
- </span>
24
- <a-digit-badge
25
- v-if="option.count!== undefined"
26
- size="md"
27
- class="font-normal justify-self-start"
28
- >
29
- {{ option.count }}
30
- </a-digit-badge>
31
- <a-icon-warning-circle
32
- v-if="option.warning"
33
- class="text-black justify-self-end"
34
- />
35
- </span>
36
- </slot>
37
- </button>
38
- </div>
39
- </template>
40
-
41
- <script setup lang="ts">
42
- import type { Tab, ViewType} from "./types";
43
-
44
- defineOptions({name: 'ALineTabs'})
45
-
46
- interface Props {
47
- options: Tab[]
48
- view: 'bottom' | 'right' | "left"
49
- size?: 'lg' | 'sm'
50
- align: 'left' | 'center'
51
- block?: boolean
52
- wrapper?: 'row' | 'column'
53
- }
54
-
55
- const props = withDefaults(defineProps<Props>(), {
56
- view: 'bottom',
57
- size: 'sm',
58
- align: 'center',
59
- block: false,
60
- wrapper: 'row',
61
- })
62
- const emit = defineEmits(['selectOption']);
63
- const activeTab = defineModel<any>({
64
- default: 1
65
- })
66
-
67
-
68
- const viewTypeValues: ViewType = {
69
- bottom: {
70
- default: 'border-b-2 border-white dark:border-gray-900 pt-[3px] ',
71
- selected: 'border-b-2 border-blue-700 dark:border-blue-500 pt-[3px]'
72
- },
73
- right: {
74
- default: 'text-deepblue-900 bg-transparent',
75
- selected: 'border-r-2 border-deepblue-900'
76
- },
77
- left: {
78
- default: 'text-deepblue-900 bg-transparent',
79
- selected: 'border-l-2 border-deepblue-900'
80
- },
81
- };
82
-
83
-
84
-
85
-
86
- const defaultClasses = () =>
87
- [
88
- 'disabled:cursor-not-allowed disabled:text-gray-500 hover:bg-deepblue-900 disabled:dark:text-gray-300 body-s-400 cursor-pointer text-deepblue-900 dark:text-gray-200 bg-transparent select-none hover:bg-opacity-5 hover:disabled:bg-transparent focus-visible:shadow-[0_0_0_4px#1B64B3]',
89
- viewTypeValues[props.view]['default'],
90
- props.size == 'sm'? 'px-4 py-[7.5px]' : 'px-4 py-[11.5px]',
91
- props.block ? 'w-full' : '',
92
- ]
93
-
94
- const selectedClasses = () =>
95
- [
96
- 'body-s-400 cursor-pointer transition duration-200 select-none font-semibold focus-visible:shadow-[0_0_0_4px#1B64B3]',
97
- viewTypeValues[props.view]['selected'],
98
- props.size == 'sm'? 'px-4 py-[7.5px]' : 'px-4 py-[11.5px]',
99
- props.block ? 'w-full' : '',
100
- ]
101
-
102
- const handleClick = (option:Tab) => {
103
- activeTab.value = option.key
104
- emit('selectOption', option);
105
- }
106
-
107
- </script>
108
-
109
- <style>
110
- /* Add any additional styles here */
111
- </style>
1
+ <template>
2
+ <div
3
+ class="whitespace-nowrap overflow-auto"
4
+ :class="props.wrapper === 'row'? 'flex':'flex flex-col'"
5
+ >
6
+ <button
7
+ v-for="(option) in options"
8
+ :key="option.key"
9
+ :disabled="option.disabled"
10
+ :class="activeTab === option.key ? selectedClasses() : defaultClasses()"
11
+ @click="() => handleClick(option)"
12
+ >
13
+ <slot
14
+ name="option"
15
+ :option="option"
16
+ >
17
+ <span
18
+ class="flex gap-1 "
19
+ :class="[align === 'left' ? 'justify-between' : 'justify-center' ]"
20
+ >
21
+ <span>
22
+ {{ option.name }}
23
+ </span>
24
+ <a-digit-badge
25
+ v-if="option.count!== undefined"
26
+ size="md"
27
+ class="font-normal justify-self-start"
28
+ >
29
+ {{ option.count }}
30
+ </a-digit-badge>
31
+ <a-icon-warning-circle
32
+ v-if="option.warning"
33
+ class="text-black justify-self-end"
34
+ />
35
+ </span>
36
+ </slot>
37
+ </button>
38
+ </div>
39
+ </template>
40
+
41
+ <script setup lang="ts">
42
+ import type { Tab, ViewType} from "./types";
43
+
44
+ defineOptions({name: 'ALineTabs'})
45
+
46
+ interface Props {
47
+ options: Tab[]
48
+ view: 'bottom' | 'right' | "left"
49
+ size?: 'lg' | 'sm'
50
+ align: 'left' | 'center'
51
+ block?: boolean
52
+ wrapper?: 'row' | 'column'
53
+ }
54
+
55
+ const props = withDefaults(defineProps<Props>(), {
56
+ view: 'bottom',
57
+ size: 'sm',
58
+ align: 'center',
59
+ block: false,
60
+ wrapper: 'row',
61
+ })
62
+ const emit = defineEmits(['selectOption']);
63
+ const activeTab = defineModel<any>({
64
+ default: 1
65
+ })
66
+
67
+
68
+ const viewTypeValues: ViewType = {
69
+ bottom: {
70
+ default: 'border-b-2 border-white dark:border-gray-900 pt-[3px] ',
71
+ selected: 'border-b-2 border-blue-700 dark:border-blue-500 pt-[3px]'
72
+ },
73
+ right: {
74
+ default: 'text-deepblue-900 bg-transparent',
75
+ selected: 'border-r-2 border-deepblue-900'
76
+ },
77
+ left: {
78
+ default: 'text-deepblue-900 bg-transparent',
79
+ selected: 'border-l-2 border-deepblue-900'
80
+ },
81
+ };
82
+
83
+
84
+
85
+
86
+ const defaultClasses = () =>
87
+ [
88
+ 'disabled:cursor-not-allowed disabled:text-gray-500 hover:bg-deepblue-900 disabled:dark:text-gray-300 body-s-400 cursor-pointer text-deepblue-900 dark:text-gray-200 bg-transparent select-none hover:bg-opacity-5 hover:disabled:bg-transparent focus-visible:shadow-[0_0_0_4px#1B64B3]',
89
+ viewTypeValues[props.view]['default'],
90
+ props.size == 'sm'? 'px-4 py-[7.5px]' : 'px-4 py-[11.5px]',
91
+ props.block ? 'w-full' : '',
92
+ ]
93
+
94
+ const selectedClasses = () =>
95
+ [
96
+ 'body-s-400 cursor-pointer transition duration-200 select-none font-semibold focus-visible:shadow-[0_0_0_4px#1B64B3]',
97
+ viewTypeValues[props.view]['selected'],
98
+ props.size == 'sm'? 'px-4 py-[7.5px]' : 'px-4 py-[11.5px]',
99
+ props.block ? 'w-full' : '',
100
+ ]
101
+
102
+ const handleClick = (option:Tab) => {
103
+ activeTab.value = option.key
104
+ emit('selectOption', option);
105
+ }
106
+
107
+ </script>
108
+
109
+ <style>
110
+ /* Add any additional styles here */
111
+ </style>