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,291 +1,291 @@
1
- <script setup lang="ts">
2
- import { NuxtLinkLocale } from '#components'
3
-
4
- const props = defineProps<{
5
- icon: Component
6
- title: string
7
- description: string
8
- to?: string
9
- wide?: boolean
10
- }>()
11
- </script>
12
-
13
- <template>
14
- <component
15
- :is="to ? NuxtLinkLocale : 'button'"
16
- :to="to"
17
- class="curve-block relative w-full cursor-pointer"
18
- active-class="active-item"
19
- >
20
- <svg
21
- v-if="wide"
22
- class="w-full"
23
- viewBox="-2 -4 416 188"
24
- fill="none"
25
- preserveAspectRatio="none"
26
- xmlns="http://www.w3.org/2000/svg"
27
- >
28
- <path
29
- class="border-path border-path--large"
30
- d="M413.333 105.936C413.333 116.008 399.074 123 389.001 123C369.671 123 354.001 138.67 354.001 158C354.001 168.009 347.088 182 337.079 182H16.3334C7.49682 182 0.333374 174.837 0.333374 166V16C0.333374 7.16344 7.49682 0 16.3334 0H397.333C406.17 0 413.333 7.16344 413.333 16V105.936Z"
31
- stroke-width="2"
32
- fill="transparent"
33
- />
34
- <defs>
35
- <linearGradient
36
- id="gradient-light"
37
- x1="164.372"
38
- y1="-137.957"
39
- x2="-20.5433"
40
- y2="68.1723"
41
- gradientUnits="userSpaceOnUse"
42
- >
43
- <stop stop-color="#479FFF" />
44
- <stop
45
- offset="1"
46
- stop-color="#0070EB"
47
- />
48
- </linearGradient>
49
-
50
- <linearGradient
51
- id="gradient-dark"
52
- x1="164.372"
53
- y1="-137.957"
54
- x2="-20.5433"
55
- y2="68.1723"
56
- gradientUnits="userSpaceOnUse"
57
- >
58
- <stop stop-color="#4FBDFF" />
59
- <stop
60
- offset="1"
61
- stop-color="#1B98E2"
62
- />
63
- </linearGradient>
64
- </defs>
65
- </svg>
66
-
67
- <svg
68
- v-else
69
- class="w-full"
70
- viewBox="-1 -1 308 184"
71
- xmlns="http://www.w3.org/2000/svg"
72
- >
73
- <path
74
- class="border-path"
75
- d="M306 106.077C306 116.087 292.009 123 282 123C262.67 123 247 138.67 247 158C247 168.009 240.087 182 230.077 182H16C7.16344 182 0 174.837 0 166V16C0 7.16344 7.16344 0 16 0H290C298.837 0 306 7.16344 306 16V106.077Z"
76
- stroke-width="2"
77
- fill="transparent"
78
- />
79
- <defs>
80
- <linearGradient
81
- id="gradient-light"
82
- x1="164.372"
83
- y1="-137.957"
84
- x2="-20.5433"
85
- y2="68.1723"
86
- gradientUnits="userSpaceOnUse"
87
- >
88
- <stop stop-color="#479FFF" />
89
- <stop
90
- offset="1"
91
- stop-color="#0070EB"
92
- />
93
- </linearGradient>
94
-
95
- <linearGradient
96
- id="gradient-dark"
97
- x1="164.372"
98
- y1="-137.957"
99
- x2="-20.5433"
100
- y2="68.1723"
101
- gradientUnits="userSpaceOnUse"
102
- >
103
- <stop stop-color="#4FBDFF" />
104
- <stop
105
- offset="1"
106
- stop-color="#1B98E2"
107
- />
108
- </linearGradient>
109
- </defs>
110
- </svg>
111
-
112
- <div class="absolute left-6 top-6 flex flex-col gap-4 pr-6">
113
- <div class="flex items-center gap-2 title">
114
- <div class="rounded-[4px] icon-item bg-deepblue-900/5 dark:bg-gray-200/5 p-1">
115
- <component
116
- :is="icon"
117
- class="size-6 shrink-0"
118
- />
119
- </div>
120
- <p class="text-base font-semibold">
121
- {{ title }}
122
- </p>
123
- </div>
124
- <p class="text-left text-sm text-gray-600 dark:text-gray-200">
125
- {{ description }}
126
- </p>
127
- </div>
128
-
129
- <svg
130
- class="absolute bottom-0 right-0 size-12 2xl:size-14"
131
- viewBox="0 0 48 48"
132
- xmlns="http://www.w3.org/2000/svg"
133
- >
134
- <rect
135
- x="1"
136
- y="1"
137
- width="46"
138
- height="46"
139
- rx="23"
140
- fill="transparent"
141
- />
142
- <rect
143
- class="animated-border"
144
- x="1"
145
- y="1"
146
- width="46"
147
- height="46"
148
- rx="23"
149
- stroke-width="2"
150
- fill="transparent"
151
- />
152
- <path
153
- class="arrow"
154
- fill-rule="evenodd"
155
- clip-rule="evenodd"
156
- d="M17.1155 16C16.4994 16 16 16.4994 16 17.1155C16 17.7315 16.4994 18.231 17.1155 18.231L28.1915 18.231L16.3267 30.0958C15.8911 30.5314 15.8911 31.2377 16.3267 31.6733C16.7623 32.1089 17.4686 32.1089 17.9042 31.6733L29.769 19.8085L29.769 30.8845C29.769 31.5006 30.2685 32 30.8845 32C31.5006 32 32 31.5006 32 30.8845L32 17.1155C32 16.9642 31.9699 16.82 31.9154 16.6885C31.8617 16.5589 31.7826 16.4373 31.678 16.3315C31.6749 16.3283 31.6717 16.3251 31.6685 16.322C31.5627 16.2174 31.4411 16.1383 31.3115 16.0846C31.18 16.0301 31.0358 16 30.8845 16L17.1155 16Z"
157
- />
158
- <defs>
159
- <linearGradient
160
- id="gradient-circle-light"
161
- x1="25.7838"
162
- y1="-36.3843"
163
- x2="-19.403"
164
- y2="-6.42519"
165
- gradientUnits="userSpaceOnUse"
166
- >
167
- <stop stop-color="#479FFF" />
168
- <stop
169
- offset="1"
170
- stop-color="#0070EB"
171
- />
172
- </linearGradient>
173
-
174
- <linearGradient
175
- id="gradient-circle-dark"
176
- x1="25.7838"
177
- y1="-36.3843"
178
- x2="-19.403"
179
- y2="-6.42519"
180
- gradientUnits="userSpaceOnUse"
181
- >
182
- <stop stop-color="#4FBDFF" />
183
- <stop
184
- offset="1"
185
- stop-color="#1B98E2"
186
- />
187
- </linearGradient>
188
- </defs>
189
- </svg>
190
- </component>
191
- </template>
192
-
193
- <style lang="scss" scoped>
194
- .border-path {
195
- stroke-dasharray: 1200;
196
- stroke-dashoffset: 1200;
197
- fill: #F4F5F6;
198
- }
199
-
200
- .border-path--large {
201
- stroke-dasharray: 1400;
202
- stroke-dashoffset: 1400;
203
- }
204
-
205
- .animated-border {
206
- stroke-dasharray: 180;
207
- stroke-dashoffset: 180;
208
- fill: #F4F5F6;
209
- }
210
-
211
- .active-item .title {
212
- color: #0070EB;
213
- }
214
- .active-item .border-path {
215
- fill: #0070EB1A;
216
- }
217
- .active-item .icon-item {
218
- background: #2C3E500D;
219
- }
220
-
221
- .curve-block:hover .border-path,
222
- .curve-block:hover .animated-border {
223
- transition: stroke-dashoffset 2s ease, fill 2s ease;
224
- stroke-dashoffset: 0;
225
- fill: white;
226
- }
227
-
228
- .curve-block:hover .icon-item {
229
- background-color: #E0EFFF;
230
- color: #0070EB;
231
- transition: all 2s ease, fill 2s ease;
232
- }
233
-
234
- .border-path {
235
- stroke: url(#gradient-light);
236
- }
237
-
238
- .dark .border-path {
239
- stroke: url(#gradient-dark);
240
- }
241
-
242
- .animated-border {
243
- stroke: url(#gradient-circle-light);
244
- }
245
-
246
- .dark .animated-border {
247
- stroke: url(#gradient-circle-dark);
248
- }
249
-
250
- .arrow {
251
- fill: #0070EB;
252
- }
253
-
254
- .dark {
255
- .border-path,
256
- .animated-border {
257
- fill: #26282b;
258
- }
259
-
260
- .active-item .title {
261
- color: #1b98e2;
262
- }
263
-
264
- .active-item .border-path {
265
- fill: #1B98E21A;
266
- }
267
-
268
- .active-item .icon-item {
269
- background: #E3E5E80D;
270
- }
271
-
272
-
273
- .curve-block:hover .icon-item {
274
- background-color: rgba(30, 88, 156, 0.6);
275
- color: #1b98e2;
276
- transition: all 2s ease, fill 2s ease;
277
- }
278
-
279
-
280
- .curve-block:hover .border-path,
281
- .curve-block:hover .animated-border {
282
- fill: #131415;
283
-
284
- }
285
- .arrow {
286
- fill: #1b98e2;
287
- }
288
- }
289
- </style>
290
-
291
-
1
+ <script setup lang="ts">
2
+ import { NuxtLinkLocale } from '#components'
3
+
4
+ const props = defineProps<{
5
+ icon: Component
6
+ title: string
7
+ description: string
8
+ to?: string
9
+ wide?: boolean
10
+ }>()
11
+ </script>
12
+
13
+ <template>
14
+ <component
15
+ :is="to ? NuxtLinkLocale : 'button'"
16
+ :to="to"
17
+ class="curve-block relative w-full cursor-pointer"
18
+ active-class="active-item"
19
+ >
20
+ <svg
21
+ v-if="wide"
22
+ class="w-full"
23
+ viewBox="-2 -4 416 188"
24
+ fill="none"
25
+ preserveAspectRatio="none"
26
+ xmlns="http://www.w3.org/2000/svg"
27
+ >
28
+ <path
29
+ class="border-path border-path--large"
30
+ d="M413.333 105.936C413.333 116.008 399.074 123 389.001 123C369.671 123 354.001 138.67 354.001 158C354.001 168.009 347.088 182 337.079 182H16.3334C7.49682 182 0.333374 174.837 0.333374 166V16C0.333374 7.16344 7.49682 0 16.3334 0H397.333C406.17 0 413.333 7.16344 413.333 16V105.936Z"
31
+ stroke-width="2"
32
+ fill="transparent"
33
+ />
34
+ <defs>
35
+ <linearGradient
36
+ id="gradient-light"
37
+ x1="164.372"
38
+ y1="-137.957"
39
+ x2="-20.5433"
40
+ y2="68.1723"
41
+ gradientUnits="userSpaceOnUse"
42
+ >
43
+ <stop stop-color="#479FFF" />
44
+ <stop
45
+ offset="1"
46
+ stop-color="#0070EB"
47
+ />
48
+ </linearGradient>
49
+
50
+ <linearGradient
51
+ id="gradient-dark"
52
+ x1="164.372"
53
+ y1="-137.957"
54
+ x2="-20.5433"
55
+ y2="68.1723"
56
+ gradientUnits="userSpaceOnUse"
57
+ >
58
+ <stop stop-color="#4FBDFF" />
59
+ <stop
60
+ offset="1"
61
+ stop-color="#1B98E2"
62
+ />
63
+ </linearGradient>
64
+ </defs>
65
+ </svg>
66
+
67
+ <svg
68
+ v-else
69
+ class="w-full"
70
+ viewBox="-1 -1 308 184"
71
+ xmlns="http://www.w3.org/2000/svg"
72
+ >
73
+ <path
74
+ class="border-path"
75
+ d="M306 106.077C306 116.087 292.009 123 282 123C262.67 123 247 138.67 247 158C247 168.009 240.087 182 230.077 182H16C7.16344 182 0 174.837 0 166V16C0 7.16344 7.16344 0 16 0H290C298.837 0 306 7.16344 306 16V106.077Z"
76
+ stroke-width="2"
77
+ fill="transparent"
78
+ />
79
+ <defs>
80
+ <linearGradient
81
+ id="gradient-light"
82
+ x1="164.372"
83
+ y1="-137.957"
84
+ x2="-20.5433"
85
+ y2="68.1723"
86
+ gradientUnits="userSpaceOnUse"
87
+ >
88
+ <stop stop-color="#479FFF" />
89
+ <stop
90
+ offset="1"
91
+ stop-color="#0070EB"
92
+ />
93
+ </linearGradient>
94
+
95
+ <linearGradient
96
+ id="gradient-dark"
97
+ x1="164.372"
98
+ y1="-137.957"
99
+ x2="-20.5433"
100
+ y2="68.1723"
101
+ gradientUnits="userSpaceOnUse"
102
+ >
103
+ <stop stop-color="#4FBDFF" />
104
+ <stop
105
+ offset="1"
106
+ stop-color="#1B98E2"
107
+ />
108
+ </linearGradient>
109
+ </defs>
110
+ </svg>
111
+
112
+ <div class="absolute left-6 top-6 flex flex-col gap-4 pr-6">
113
+ <div class="flex items-center gap-2 title">
114
+ <div class="rounded-[4px] icon-item bg-deepblue-900/5 dark:bg-gray-200/5 p-1">
115
+ <component
116
+ :is="icon"
117
+ class="size-6 shrink-0"
118
+ />
119
+ </div>
120
+ <p class="text-base font-semibold">
121
+ {{ title }}
122
+ </p>
123
+ </div>
124
+ <p class="text-left text-sm text-gray-600 dark:text-gray-200">
125
+ {{ description }}
126
+ </p>
127
+ </div>
128
+
129
+ <svg
130
+ class="absolute bottom-0 right-0 size-12 2xl:size-14"
131
+ viewBox="0 0 48 48"
132
+ xmlns="http://www.w3.org/2000/svg"
133
+ >
134
+ <rect
135
+ x="1"
136
+ y="1"
137
+ width="46"
138
+ height="46"
139
+ rx="23"
140
+ fill="transparent"
141
+ />
142
+ <rect
143
+ class="animated-border"
144
+ x="1"
145
+ y="1"
146
+ width="46"
147
+ height="46"
148
+ rx="23"
149
+ stroke-width="2"
150
+ fill="transparent"
151
+ />
152
+ <path
153
+ class="arrow"
154
+ fill-rule="evenodd"
155
+ clip-rule="evenodd"
156
+ d="M17.1155 16C16.4994 16 16 16.4994 16 17.1155C16 17.7315 16.4994 18.231 17.1155 18.231L28.1915 18.231L16.3267 30.0958C15.8911 30.5314 15.8911 31.2377 16.3267 31.6733C16.7623 32.1089 17.4686 32.1089 17.9042 31.6733L29.769 19.8085L29.769 30.8845C29.769 31.5006 30.2685 32 30.8845 32C31.5006 32 32 31.5006 32 30.8845L32 17.1155C32 16.9642 31.9699 16.82 31.9154 16.6885C31.8617 16.5589 31.7826 16.4373 31.678 16.3315C31.6749 16.3283 31.6717 16.3251 31.6685 16.322C31.5627 16.2174 31.4411 16.1383 31.3115 16.0846C31.18 16.0301 31.0358 16 30.8845 16L17.1155 16Z"
157
+ />
158
+ <defs>
159
+ <linearGradient
160
+ id="gradient-circle-light"
161
+ x1="25.7838"
162
+ y1="-36.3843"
163
+ x2="-19.403"
164
+ y2="-6.42519"
165
+ gradientUnits="userSpaceOnUse"
166
+ >
167
+ <stop stop-color="#479FFF" />
168
+ <stop
169
+ offset="1"
170
+ stop-color="#0070EB"
171
+ />
172
+ </linearGradient>
173
+
174
+ <linearGradient
175
+ id="gradient-circle-dark"
176
+ x1="25.7838"
177
+ y1="-36.3843"
178
+ x2="-19.403"
179
+ y2="-6.42519"
180
+ gradientUnits="userSpaceOnUse"
181
+ >
182
+ <stop stop-color="#4FBDFF" />
183
+ <stop
184
+ offset="1"
185
+ stop-color="#1B98E2"
186
+ />
187
+ </linearGradient>
188
+ </defs>
189
+ </svg>
190
+ </component>
191
+ </template>
192
+
193
+ <style lang="scss" scoped>
194
+ .border-path {
195
+ stroke-dasharray: 1200;
196
+ stroke-dashoffset: 1200;
197
+ fill: #F4F5F6;
198
+ }
199
+
200
+ .border-path--large {
201
+ stroke-dasharray: 1400;
202
+ stroke-dashoffset: 1400;
203
+ }
204
+
205
+ .animated-border {
206
+ stroke-dasharray: 180;
207
+ stroke-dashoffset: 180;
208
+ fill: #F4F5F6;
209
+ }
210
+
211
+ .active-item .title {
212
+ color: #0070EB;
213
+ }
214
+ .active-item .border-path {
215
+ fill: #0070EB1A;
216
+ }
217
+ .active-item .icon-item {
218
+ background: #2C3E500D;
219
+ }
220
+
221
+ .curve-block:hover .border-path,
222
+ .curve-block:hover .animated-border {
223
+ transition: stroke-dashoffset 2s ease, fill 2s ease;
224
+ stroke-dashoffset: 0;
225
+ fill: white;
226
+ }
227
+
228
+ .curve-block:hover .icon-item {
229
+ background-color: #E0EFFF;
230
+ color: #0070EB;
231
+ transition: all 2s ease, fill 2s ease;
232
+ }
233
+
234
+ .border-path {
235
+ stroke: url(#gradient-light);
236
+ }
237
+
238
+ .dark .border-path {
239
+ stroke: url(#gradient-dark);
240
+ }
241
+
242
+ .animated-border {
243
+ stroke: url(#gradient-circle-light);
244
+ }
245
+
246
+ .dark .animated-border {
247
+ stroke: url(#gradient-circle-dark);
248
+ }
249
+
250
+ .arrow {
251
+ fill: #0070EB;
252
+ }
253
+
254
+ .dark {
255
+ .border-path,
256
+ .animated-border {
257
+ fill: #26282b;
258
+ }
259
+
260
+ .active-item .title {
261
+ color: #1b98e2;
262
+ }
263
+
264
+ .active-item .border-path {
265
+ fill: #1B98E21A;
266
+ }
267
+
268
+ .active-item .icon-item {
269
+ background: #E3E5E80D;
270
+ }
271
+
272
+
273
+ .curve-block:hover .icon-item {
274
+ background-color: rgba(30, 88, 156, 0.6);
275
+ color: #1b98e2;
276
+ transition: all 2s ease, fill 2s ease;
277
+ }
278
+
279
+
280
+ .curve-block:hover .border-path,
281
+ .curve-block:hover .animated-border {
282
+ fill: #131415;
283
+
284
+ }
285
+ .arrow {
286
+ fill: #1b98e2;
287
+ }
288
+ }
289
+ </style>
290
+
291
+