pukaad-ui-lib 1.2.0 → 1.3.2

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 (268) hide show
  1. package/dist/module.json +1 -1
  2. package/dist/runtime/assets/json/social-icon.json +77 -77
  3. package/dist/runtime/assets/svg/bell-outline.svg +3 -3
  4. package/dist/runtime/assets/svg/bookmark-solid.svg +2 -2
  5. package/dist/runtime/assets/svg/box.svg +22 -22
  6. package/dist/runtime/assets/svg/camera-plus.svg +9 -9
  7. package/dist/runtime/assets/svg/clock-fading.svg +46 -46
  8. package/dist/runtime/assets/svg/coin.svg +20 -20
  9. package/dist/runtime/assets/svg/empty-document.svg +15 -15
  10. package/dist/runtime/assets/svg/memsg-circle.svg +7 -7
  11. package/dist/runtime/assets/svg/memsg-fade.svg +5 -5
  12. package/dist/runtime/assets/svg/memsg-logo-outline.svg +3 -3
  13. package/dist/runtime/assets/svg/memsg-square.svg +9 -9
  14. package/dist/runtime/assets/svg/message.svg +3 -3
  15. package/dist/runtime/assets/svg/page-not-found.svg +9 -9
  16. package/dist/runtime/assets/svg/share-from-square.svg +3 -3
  17. package/dist/runtime/assets/svg/share.svg +2 -2
  18. package/dist/runtime/assets/svg/shopping-cart.svg +16 -16
  19. package/dist/runtime/assets/svg/socials/Email.svg +12 -12
  20. package/dist/runtime/assets/svg/socials/{facebook.svg → Facebook.svg} +4 -4
  21. package/dist/runtime/assets/svg/socials/Line.svg +11 -11
  22. package/dist/runtime/assets/svg/socials/LinkedIn.svg +5 -5
  23. package/dist/runtime/assets/svg/socials/Pinterest.svg +4 -4
  24. package/dist/runtime/assets/svg/socials/SnapChat.svg +5 -5
  25. package/dist/runtime/assets/svg/socials/Threads.svg +12 -12
  26. package/dist/runtime/assets/svg/socials/Tiktok.svg +6 -6
  27. package/dist/runtime/assets/svg/socials/Tumblr.svg +4 -4
  28. package/dist/runtime/assets/svg/socials/Website.svg +11 -11
  29. package/dist/runtime/assets/svg/socials/Whatsapp.svg +5 -5
  30. package/dist/runtime/assets/svg/socials/X.svg +4 -4
  31. package/dist/runtime/assets/svg/socials/Youtube.svg +5 -5
  32. package/dist/runtime/assets/svg/socials/instagram.svg +14 -14
  33. package/dist/runtime/assets/svg/thumbs-up-regular.svg +9 -9
  34. package/dist/runtime/assets/svg/thumbs-up-solid.svg +2 -2
  35. package/dist/runtime/assets/svg/vector.svg +2 -2
  36. package/dist/runtime/assets/svg/verify.svg +10 -10
  37. package/dist/runtime/assets/svg/write-review.svg +15 -15
  38. package/dist/runtime/components/button.vue +8 -8
  39. package/dist/runtime/components/card/card-announce2.vue +102 -104
  40. package/dist/runtime/components/card/card-place-detail.vue +90 -90
  41. package/dist/runtime/components/card/card-profile-about.vue +50 -50
  42. package/dist/runtime/components/card/card-profile-header.vue +94 -94
  43. package/dist/runtime/components/card/card-reaction.vue +29 -29
  44. package/dist/runtime/components/card/card-recommend-blog.vue +49 -49
  45. package/dist/runtime/components/card/card-recommend-place.vue +50 -50
  46. package/dist/runtime/components/card/card-recommend-publisher.vue +51 -51
  47. package/dist/runtime/components/card/card-review.vue +74 -74
  48. package/dist/runtime/components/card/card-user-blog.vue +66 -66
  49. package/dist/runtime/components/card/card-user-item.vue +54 -54
  50. package/dist/runtime/components/card/card.vue +25 -25
  51. package/dist/runtime/components/carousel.vue +29 -29
  52. package/dist/runtime/components/chip.vue +12 -12
  53. package/dist/runtime/components/collapse/collapse-multiple.vue +38 -38
  54. package/dist/runtime/components/collapse/collapse.vue +23 -23
  55. package/dist/runtime/components/comment.vue +216 -216
  56. package/dist/runtime/components/dialog/dialog-2FA-generate.vue +58 -58
  57. package/dist/runtime/components/dialog/dialog-2FA.vue +20 -20
  58. package/dist/runtime/components/dialog/dialog-email-OTP.vue +26 -26
  59. package/dist/runtime/components/dialog/dialog-phone-OTP.vue +25 -25
  60. package/dist/runtime/components/display/display-image-place.vue +4 -4
  61. package/dist/runtime/components/display/display-image-review.vue +16 -16
  62. package/dist/runtime/components/display/display-image.vue +49 -49
  63. package/dist/runtime/components/divider.vue +8 -8
  64. package/dist/runtime/components/draggable.vue +13 -13
  65. package/dist/runtime/components/drawer/drawer-notification.vue +286 -286
  66. package/dist/runtime/components/drawer/drawer-post-blog.vue +80 -80
  67. package/dist/runtime/components/drawer/drawer-profile-about.vue +38 -38
  68. package/dist/runtime/components/drawer/drawer.vue +16 -16
  69. package/dist/runtime/components/dropdown.vue +8 -8
  70. package/dist/runtime/components/filter/filter-list-chip.vue +15 -15
  71. package/dist/runtime/components/filter/filter-list.vue +17 -17
  72. package/dist/runtime/components/icons.vue +1 -1
  73. package/dist/runtime/components/image/image-cropper.vue +9 -9
  74. package/dist/runtime/components/image/image.vue +29 -29
  75. package/dist/runtime/components/input/input-OTP.vue +16 -16
  76. package/dist/runtime/components/input/input-address.vue +81 -81
  77. package/dist/runtime/components/input/input-autocomplete.d.vue.ts +1 -1
  78. package/dist/runtime/components/input/input-autocomplete.vue +80 -80
  79. package/dist/runtime/components/input/input-autocomplete.vue.d.ts +1 -1
  80. package/dist/runtime/components/input/input-checkbox.vue +103 -103
  81. package/dist/runtime/components/input/input-combobox.d.vue.ts +5 -1
  82. package/dist/runtime/components/input/input-combobox.vue +97 -81
  83. package/dist/runtime/components/input/input-combobox.vue.d.ts +5 -1
  84. package/dist/runtime/components/input/input-comment.vue +6 -6
  85. package/dist/runtime/components/input/input-content.vue +5 -5
  86. package/dist/runtime/components/input/input-date-opening.vue +175 -176
  87. package/dist/runtime/components/input/input-email.vue +8 -8
  88. package/dist/runtime/components/input/input-file.d.vue.ts +1 -1
  89. package/dist/runtime/components/input/input-file.vue +76 -76
  90. package/dist/runtime/components/input/input-file.vue.d.ts +1 -1
  91. package/dist/runtime/components/input/input-link.vue +39 -39
  92. package/dist/runtime/components/input/input-media.vue +36 -36
  93. package/dist/runtime/components/input/input-password.vue +40 -40
  94. package/dist/runtime/components/input/input-phone.vue +6 -6
  95. package/dist/runtime/components/input/input-radio.d.vue.ts +4 -4
  96. package/dist/runtime/components/input/input-radio.vue +87 -87
  97. package/dist/runtime/components/input/input-radio.vue.d.ts +4 -4
  98. package/dist/runtime/components/input/input-rating.vue +13 -13
  99. package/dist/runtime/components/input/input-recaptcha.vue +19 -19
  100. package/dist/runtime/components/input/input-search.vue +69 -69
  101. package/dist/runtime/components/input/input-select-tag.vue +51 -51
  102. package/dist/runtime/components/input/input-select.vue +42 -42
  103. package/dist/runtime/components/input/input-slider.vue +19 -19
  104. package/dist/runtime/components/input/input-switch.vue +25 -25
  105. package/dist/runtime/components/input/input-tag.vue +37 -37
  106. package/dist/runtime/components/input/input-text-field.vue +83 -83
  107. package/dist/runtime/components/input/input-textarea.vue +54 -54
  108. package/dist/runtime/components/label/label-announce-time.vue +9 -9
  109. package/dist/runtime/components/label/label-card-atom.vue +8 -8
  110. package/dist/runtime/components/list/list-menu.vue +13 -13
  111. package/dist/runtime/components/modal/modal-2FA-generate.vue +62 -62
  112. package/dist/runtime/components/modal/modal-2FA.vue +21 -21
  113. package/dist/runtime/components/modal/modal-account-disabled-alert.vue +33 -33
  114. package/dist/runtime/components/modal/modal-account-disabled-confirmed.vue +32 -32
  115. package/dist/runtime/components/modal/modal-account-disabled-reason.vue +45 -45
  116. package/dist/runtime/components/modal/modal-account-disabled.vue +9 -9
  117. package/dist/runtime/components/modal/modal-email-OTP.vue +31 -31
  118. package/dist/runtime/components/modal/modal-password-new.vue +27 -27
  119. package/dist/runtime/components/modal/modal-password.vue +27 -27
  120. package/dist/runtime/components/modal/modal-personal-card-ID.vue +194 -194
  121. package/dist/runtime/components/modal/modal-phone-OTP.vue +38 -38
  122. package/dist/runtime/components/modal/modal-profile-edit.vue +165 -165
  123. package/dist/runtime/components/modal/modal-province-domain.vue +23 -23
  124. package/dist/runtime/components/modal/modal-report.vue +49 -49
  125. package/dist/runtime/components/modal/modal-review-detail.vue +118 -118
  126. package/dist/runtime/components/modal/modal-secure.vue +10 -10
  127. package/dist/runtime/components/modal/modal-share.vue +24 -24
  128. package/dist/runtime/components/modal/modal-user-account-list.vue +29 -29
  129. package/dist/runtime/components/modal/modal-user-account-search.vue +24 -24
  130. package/dist/runtime/components/modal/modal.vue +27 -27
  131. package/dist/runtime/components/pagination.vue +43 -43
  132. package/dist/runtime/components/picker/picker-image-cover-profile.vue +91 -91
  133. package/dist/runtime/components/picker/picker-image-profile.vue +82 -82
  134. package/dist/runtime/components/picker/picker-option-menu/picker-option-menu-user.vue +14 -14
  135. package/dist/runtime/components/picker/picker-option-menu/picker-option-menu.vue +27 -27
  136. package/dist/runtime/components/profile-cover.vue +80 -80
  137. package/dist/runtime/components/progress-bar.vue +9 -9
  138. package/dist/runtime/components/read-more-text.vue +1 -1
  139. package/dist/runtime/components/tab.vue +78 -78
  140. package/dist/runtime/components/table.d.vue.ts +6 -6
  141. package/dist/runtime/components/table.vue +82 -82
  142. package/dist/runtime/components/table.vue.d.ts +6 -6
  143. package/dist/runtime/components/tooltip.vue +19 -19
  144. package/dist/runtime/components/ui/alert/Alert.vue +7 -7
  145. package/dist/runtime/components/ui/alert/AlertDescription.vue +6 -6
  146. package/dist/runtime/components/ui/alert/AlertTitle.vue +6 -6
  147. package/dist/runtime/components/ui/alert-dialog/AlertDialog.vue +3 -3
  148. package/dist/runtime/components/ui/alert-dialog/AlertDialogAction.vue +3 -3
  149. package/dist/runtime/components/ui/alert-dialog/AlertDialogCancel.vue +6 -6
  150. package/dist/runtime/components/ui/alert-dialog/AlertDialogContent.vue +13 -13
  151. package/dist/runtime/components/ui/alert-dialog/AlertDialogDescription.vue +7 -7
  152. package/dist/runtime/components/ui/alert-dialog/AlertDialogFooter.vue +6 -6
  153. package/dist/runtime/components/ui/alert-dialog/AlertDialogHeader.vue +6 -6
  154. package/dist/runtime/components/ui/alert-dialog/AlertDialogTitle.vue +7 -7
  155. package/dist/runtime/components/ui/alert-dialog/AlertDialogTrigger.vue +3 -3
  156. package/dist/runtime/components/ui/avatar/Avatar.vue +6 -6
  157. package/dist/runtime/components/ui/avatar/AvatarFallback.vue +7 -7
  158. package/dist/runtime/components/ui/avatar/AvatarImage.vue +7 -7
  159. package/dist/runtime/components/ui/button/Button.vue +8 -8
  160. package/dist/runtime/components/ui/card/Card.vue +8 -8
  161. package/dist/runtime/components/ui/card/CardAction.vue +6 -6
  162. package/dist/runtime/components/ui/card/CardContent.vue +6 -6
  163. package/dist/runtime/components/ui/card/CardDescription.vue +6 -6
  164. package/dist/runtime/components/ui/card/CardFooter.vue +6 -6
  165. package/dist/runtime/components/ui/card/CardHeader.vue +6 -6
  166. package/dist/runtime/components/ui/card/CardTitle.vue +6 -6
  167. package/dist/runtime/components/ui/checkbox/Checkbox.vue +14 -14
  168. package/dist/runtime/components/ui/command/Command.vue +7 -7
  169. package/dist/runtime/components/ui/command/CommandDialog.d.vue.ts +1 -1
  170. package/dist/runtime/components/ui/command/CommandDialog.vue +11 -11
  171. package/dist/runtime/components/ui/command/CommandDialog.vue.d.ts +1 -1
  172. package/dist/runtime/components/ui/command/CommandEmpty.vue +10 -10
  173. package/dist/runtime/components/ui/command/CommandGroup.vue +12 -12
  174. package/dist/runtime/components/ui/command/CommandInput.vue +13 -13
  175. package/dist/runtime/components/ui/command/CommandItem.vue +11 -11
  176. package/dist/runtime/components/ui/command/CommandList.vue +9 -9
  177. package/dist/runtime/components/ui/command/CommandSeparator.vue +7 -7
  178. package/dist/runtime/components/ui/command/CommandShortcut.vue +6 -6
  179. package/dist/runtime/components/ui/dialog/Dialog.vue +3 -3
  180. package/dist/runtime/components/ui/dialog/DialogClose.vue +3 -3
  181. package/dist/runtime/components/ui/dialog/DialogContent.vue +21 -21
  182. package/dist/runtime/components/ui/dialog/DialogDescription.vue +7 -7
  183. package/dist/runtime/components/ui/dialog/DialogFooter.vue +3 -3
  184. package/dist/runtime/components/ui/dialog/DialogHeader.vue +6 -6
  185. package/dist/runtime/components/ui/dialog/DialogOverlay.vue +7 -7
  186. package/dist/runtime/components/ui/dialog/DialogScrollContent.vue +20 -20
  187. package/dist/runtime/components/ui/dialog/DialogTitle.vue +7 -7
  188. package/dist/runtime/components/ui/dialog/DialogTrigger.vue +3 -3
  189. package/dist/runtime/components/ui/dropdown-menu/DropdownMenu.vue +6 -6
  190. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuCheckboxItem.vue +12 -12
  191. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuContent.vue +9 -9
  192. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuGroup.vue +6 -6
  193. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuItem.vue +9 -9
  194. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuLabel.vue +8 -8
  195. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuRadioGroup.vue +6 -6
  196. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuRadioItem.vue +16 -16
  197. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSeparator.vue +5 -5
  198. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuShortcut.vue +6 -6
  199. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSub.vue +3 -3
  200. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSubContent.vue +7 -7
  201. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSubTrigger.vue +8 -8
  202. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuTrigger.vue +6 -6
  203. package/dist/runtime/components/ui/form/FormControl.vue +8 -8
  204. package/dist/runtime/components/ui/form/FormDescription.vue +7 -7
  205. package/dist/runtime/components/ui/form/FormItem.vue +3 -3
  206. package/dist/runtime/components/ui/form/FormLabel.vue +8 -8
  207. package/dist/runtime/components/ui/form/FormMessage.vue +7 -7
  208. package/dist/runtime/components/ui/input/Input.vue +5 -5
  209. package/dist/runtime/components/ui/input-group/InputGroup.vue +7 -7
  210. package/dist/runtime/components/ui/input-group/InputGroupAddon.vue +9 -9
  211. package/dist/runtime/components/ui/input-group/InputGroupButton.vue +7 -7
  212. package/dist/runtime/components/ui/input-group/InputGroupInput.vue +4 -4
  213. package/dist/runtime/components/ui/input-group/InputGroupText.vue +5 -5
  214. package/dist/runtime/components/ui/input-group/InputGroupTextarea.vue +4 -4
  215. package/dist/runtime/components/ui/label/Label.vue +7 -7
  216. package/dist/runtime/components/ui/pagination/Pagination.vue +8 -8
  217. package/dist/runtime/components/ui/pagination/PaginationContent.vue +8 -8
  218. package/dist/runtime/components/ui/pagination/PaginationEllipsis.vue +10 -10
  219. package/dist/runtime/components/ui/pagination/PaginationFirst.vue +10 -10
  220. package/dist/runtime/components/ui/pagination/PaginationItem.vue +7 -7
  221. package/dist/runtime/components/ui/pagination/PaginationLast.vue +10 -10
  222. package/dist/runtime/components/ui/pagination/PaginationNext.vue +10 -10
  223. package/dist/runtime/components/ui/pagination/PaginationPrevious.vue +10 -10
  224. package/dist/runtime/components/ui/pin-input/PinInput.vue +8 -8
  225. package/dist/runtime/components/ui/pin-input/PinInputGroup.vue +7 -7
  226. package/dist/runtime/components/ui/pin-input/PinInputSeparator.vue +3 -3
  227. package/dist/runtime/components/ui/pin-input/PinInputSlot.vue +5 -5
  228. package/dist/runtime/components/ui/popover/Popover.vue +7 -7
  229. package/dist/runtime/components/ui/popover/PopoverAnchor.vue +6 -6
  230. package/dist/runtime/components/ui/popover/PopoverContent.vue +5 -5
  231. package/dist/runtime/components/ui/popover/PopoverTrigger.vue +6 -6
  232. package/dist/runtime/components/ui/select/Select.vue +7 -7
  233. package/dist/runtime/components/ui/select/SelectContent.vue +10 -10
  234. package/dist/runtime/components/ui/select/SelectGroup.vue +6 -6
  235. package/dist/runtime/components/ui/select/SelectItem.vue +17 -17
  236. package/dist/runtime/components/ui/select/SelectItemText.vue +6 -6
  237. package/dist/runtime/components/ui/select/SelectLabel.vue +6 -6
  238. package/dist/runtime/components/ui/select/SelectScrollDownButton.vue +6 -6
  239. package/dist/runtime/components/ui/select/SelectScrollUpButton.vue +6 -6
  240. package/dist/runtime/components/ui/select/SelectSeparator.vue +5 -5
  241. package/dist/runtime/components/ui/select/SelectTrigger.vue +11 -11
  242. package/dist/runtime/components/ui/select/SelectValue.vue +6 -6
  243. package/dist/runtime/components/ui/sheet/Sheet.vue +3 -3
  244. package/dist/runtime/components/ui/sheet/SheetClose.vue +3 -3
  245. package/dist/runtime/components/ui/sheet/SheetContent.vue +20 -20
  246. package/dist/runtime/components/ui/sheet/SheetDescription.vue +7 -7
  247. package/dist/runtime/components/ui/sheet/SheetFooter.vue +6 -6
  248. package/dist/runtime/components/ui/sheet/SheetHeader.vue +6 -6
  249. package/dist/runtime/components/ui/sheet/SheetOverlay.vue +7 -7
  250. package/dist/runtime/components/ui/sheet/SheetTitle.vue +7 -7
  251. package/dist/runtime/components/ui/sheet/SheetTrigger.vue +3 -3
  252. package/dist/runtime/components/ui/spinner/Spinner.vue +5 -5
  253. package/dist/runtime/components/ui/table/Table.vue +5 -5
  254. package/dist/runtime/components/ui/table/TableBody.vue +6 -6
  255. package/dist/runtime/components/ui/table/TableCaption.vue +6 -6
  256. package/dist/runtime/components/ui/table/TableCell.vue +6 -6
  257. package/dist/runtime/components/ui/table/TableEmpty.vue +10 -10
  258. package/dist/runtime/components/ui/table/TableFooter.vue +6 -6
  259. package/dist/runtime/components/ui/table/TableHead.vue +6 -6
  260. package/dist/runtime/components/ui/table/TableHeader.vue +6 -6
  261. package/dist/runtime/components/ui/table/TableRow.vue +6 -6
  262. package/dist/runtime/components/ui/tabs/Tabs.vue +8 -8
  263. package/dist/runtime/components/ui/tabs/TabsContent.vue +7 -7
  264. package/dist/runtime/components/ui/tabs/TabsList.vue +7 -7
  265. package/dist/runtime/components/ui/tabs/TabsTrigger.vue +7 -7
  266. package/dist/runtime/components/ui/textarea/Textarea.vue +5 -5
  267. package/dist/runtime/components/video.vue +2 -2
  268. package/package.json +2 -2
@@ -1,87 +1,87 @@
1
1
  <template>
2
- <div class="space-y-[4px]">
3
- <div class="flex flex-wrap gap-[8px]">
4
- <Draggable v-model="arrFiles">
5
- <template #item="{ item, index }">
6
- <div class="relative">
7
- <video
8
- v-if="item.type.startsWith('video')"
9
- :src="createBlobUrl(item)"
10
- class="rounded-[4px] object-cover w-[98px] h-[98px]"
11
- />
12
- <Image
13
- v-else-if="item.type.startsWith('image')"
14
- width="98"
15
- height="98"
16
- :src="createBlobUrl(item)"
17
- class="rounded-[4px]"
18
- />
19
- <div
20
- v-else
21
- class="w-[98px] h-[98px] rounded-[4px] flex justify-center items-center"
22
- >
23
- <Icon
24
- name="material-symbols:lab-profile-rounded"
25
- size="34"
26
- ></Icon>
27
- </div>
28
- <div
29
- class="absolute top-[2px] right-[2px] p-[1px] w-[20px] h-[20px] bg-white rounded-full cursor-pointer flex justify-center items-center"
30
- @click="onDeleteImage(index)"
31
- >
32
- <Icon name="gravity-ui:xmark" size="16"></Icon>
33
- </div>
34
- </div>
35
- </template>
36
- </Draggable>
37
-
38
- <label
39
- v-if="props.limit == 0 || arrFiles.length < props.limit"
2
+ <div class="space-y-[4px]">
3
+ <div class="flex flex-wrap gap-[8px]">
4
+ <Draggable v-model="arrFiles">
5
+ <template #item="{ item, index }">
6
+ <div class="relative">
7
+ <video
8
+ v-if="item.type.startsWith('video')"
9
+ :src="createBlobUrl(item)"
10
+ class="rounded-[4px] object-cover w-[98px] h-[98px]"
11
+ />
12
+ <Image
13
+ v-else-if="item.type.startsWith('image')"
14
+ width="98"
15
+ height="98"
16
+ :src="createBlobUrl(item)"
17
+ class="rounded-[4px]"
18
+ />
19
+ <div
20
+ v-else
21
+ class="w-[98px] h-[98px] rounded-[4px] flex justify-center items-center"
22
+ >
23
+ <Icon
24
+ name="material-symbols:lab-profile-rounded"
25
+ size="34"
26
+ ></Icon>
27
+ </div>
28
+ <div
29
+ class="absolute top-[2px] right-[2px] p-[1px] w-[20px] h-[20px] bg-white rounded-full cursor-pointer flex justify-center items-center"
30
+ @click="onDeleteImage(index)"
31
+ >
32
+ <Icon name="gravity-ui:xmark" size="16"></Icon>
33
+ </div>
34
+ </div>
35
+ </template>
36
+ </Draggable>
37
+
38
+ <label
39
+ v-if="props.limit == 0 || arrFiles.length < props.limit"
40
40
  :class="[
41
41
  'relative flex flex-col gap-[4px] justify-center items-center cursor-pointer',
42
42
  'rounded-[4px] border-dashed',
43
43
  actionOnDrop
44
- ]"
44
+ ]"
45
45
  :style="{
46
46
  width: props.fullWidth ? '100%' : props.width,
47
47
  height: props.fullHeight ? '100%' : props.height
48
- }"
49
- @dragover.prevent="onDragOver"
50
- @dragenter.prevent
51
- @dragleave.prevent="onDragLeave"
52
- @drop.prevent="onSelectFile"
53
- >
54
- <input
55
- class="absolute w-full h-full cursor-pointer hidden"
56
- type="file"
57
- :accept="props.accept"
58
- multiple
59
- @change="onSelectFile"
60
- />
61
- <slot name="default" :label="label">
62
- <div
63
- class="flex flex-col gap-[4px] justify-center items-center w-[98px] h-[98px] rounded-[4px]"
64
- >
65
- <Icon
66
- :class="isDrag ? 'text-primary' : 'text-gray'"
67
- :name="labelIcon"
68
- size="34"
69
- ></Icon>
70
- <div class="font-body-large">{{ `\u0E40\u0E1E\u0E34\u0E48\u0E21${label}` }}</div>
71
- </div>
72
- </slot>
73
- </label>
74
- </div>
75
-
76
- <div
77
- v-if="!props.disabledErrorMessage && errorMessage"
78
- class="font-body-small text-error"
79
- >
80
- <slot name="error">
81
- {{ errorMessage }}
82
- </slot>
83
- </div>
84
- </div>
48
+ }"
49
+ @dragover.prevent="onDragOver"
50
+ @dragenter.prevent
51
+ @dragleave.prevent="onDragLeave"
52
+ @drop.prevent="onSelectFile"
53
+ >
54
+ <input
55
+ class="absolute w-full h-full cursor-pointer hidden"
56
+ type="file"
57
+ :accept="props.accept"
58
+ multiple
59
+ @change="onSelectFile"
60
+ />
61
+ <slot name="default" :label="label">
62
+ <div
63
+ class="flex flex-col gap-[4px] justify-center items-center w-[98px] h-[98px] rounded-[4px]"
64
+ >
65
+ <Icon
66
+ :class="isDrag ? 'text-primary' : 'text-gray'"
67
+ :name="labelIcon"
68
+ size="34"
69
+ ></Icon>
70
+ <div class="font-body-large">{{ `\u0E40\u0E1E\u0E34\u0E48\u0E21${label}` }}</div>
71
+ </div>
72
+ </slot>
73
+ </label>
74
+ </div>
75
+
76
+ <div
77
+ v-if="!props.disabledErrorMessage && errorMessage"
78
+ class="font-body-small text-error"
79
+ >
80
+ <slot name="error">
81
+ {{ errorMessage }}
82
+ </slot>
83
+ </div>
84
+ </div>
85
85
  </template>
86
86
 
87
87
  <script setup>
@@ -5,7 +5,7 @@ type __VLS_ModelProps = {
5
5
  };
6
6
  type __VLS_PublicProps = __VLS_Props & __VLS_ModelProps;
7
7
  declare var __VLS_22: {
8
- label: any;
8
+ label: string;
9
9
  }, __VLS_29: {};
10
10
  type __VLS_Slots = {} & {
11
11
  default?: (props: typeof __VLS_22) => any;
@@ -1,43 +1,43 @@
1
1
  <template>
2
- <div class="relative">
3
- <div class="font-body-large-prominent text-gray">ช่องทางการติดต่อ</div>
4
- <ul class="flex flex-col gap-[16px]">
5
- <li
6
- v-for="(link, i) in linkValue"
7
- :key="i"
8
- class="flex items-start gap-[8px] font-body-large"
9
- >
10
- <InputSelect
11
- :name="`${props.name}[${i}]name`"
12
- width="172"
13
- :items="listOption"
14
- @select="onSelectSocial(i)"
15
- v-model="link.name"
16
- />
17
- <div class="flex-1">
18
- <InputTextField
19
- :name="`${props.name}[${i}]link`"
20
- full-width
21
- :placeholder="listSocial.find((f) => f.name === link.name)?.example"
22
- :rules="(v) => rules(v, link.name)"
23
- @change="onChangeLink(link, i)"
24
- v-model="link.link"
25
- />
26
- </div>
27
- </li>
28
- <li>
29
- <Button
30
- type="text"
31
- variant="primary"
32
- disabled-padding
33
- prepend-icon="lucide:plus"
34
- @click="addLink"
35
- >
36
- เพิ่มช่องทาง
37
- </Button>
38
- </li>
39
- </ul>
40
- </div>
2
+ <div class="relative">
3
+ <div class="font-body-large-prominent text-gray">ช่องทางการติดต่อ</div>
4
+ <ul class="flex flex-col gap-[16px]">
5
+ <li
6
+ v-for="(link, i) in linkValue"
7
+ :key="i"
8
+ class="flex items-start gap-[8px] font-body-large"
9
+ >
10
+ <InputSelect
11
+ :name="`${props.name}[${i}]name`"
12
+ width="172"
13
+ :items="listOption"
14
+ @select="onSelectSocial(i)"
15
+ v-model="link.name"
16
+ />
17
+ <div class="flex-1">
18
+ <InputTextField
19
+ :name="`${props.name}[${i}]link`"
20
+ full-width
21
+ :placeholder="listSocial.find((f) => f.name === link.name)?.example"
22
+ :rules="(v) => rules(v, link.name)"
23
+ @change="onChangeLink(link, i)"
24
+ v-model="link.link"
25
+ />
26
+ </div>
27
+ </li>
28
+ <li>
29
+ <Button
30
+ type="text"
31
+ variant="primary"
32
+ disabled-padding
33
+ prepend-icon="lucide:plus"
34
+ @click="addLink"
35
+ >
36
+ เพิ่มช่องทาง
37
+ </Button>
38
+ </li>
39
+ </ul>
40
+ </div>
41
41
  </template>
42
42
 
43
43
  <script setup>
@@ -1,45 +1,45 @@
1
1
  <template>
2
- <InputFile
3
- v-if="files.length == 0"
4
- :name="props.name"
5
- :accept="`${acceptImage},${acceptVideo}`"
6
- full-width
7
- full-height
2
+ <InputFile
3
+ v-if="files.length == 0"
4
+ :name="props.name"
5
+ :accept="`${acceptImage},${acceptVideo}`"
6
+ full-width
7
+ full-height
8
8
  :limit="
9
9
  props.limitImage > props.limitVideo ? props.limitImage : props.limitVideo
10
- "
11
- @select="onSelect"
12
- v-model="files"
13
- >
14
- <div
15
- class="flex flex-col justify-center items-center gap-[4px] p-[10px]"
10
+ "
11
+ @select="onSelect"
12
+ v-model="files"
13
+ >
14
+ <div
15
+ class="flex flex-col justify-center items-center gap-[4px] p-[10px]"
16
16
  :style="{
17
17
  width: props.fullWidth ? '100%' : props.width,
18
18
  height: props.fullHeight ? '100%' : props.height
19
- }"
20
- >
21
- <Icon name="fa6-solid:cloud-arrow-up" size="24" />
22
- <div class="font-body-large">เพิ่มรูปภาพ/วิดีโอ</div>
23
- <div class="font-body-small">หรือลากและวาง</div>
24
- </div>
25
- </InputFile>
26
-
27
- <template v-else>
28
- <InputFile
29
- v-if="fileType == 'image'"
30
- :name="props.name"
31
- :accept="acceptImage"
32
- :limit="props.limitImage"
33
- v-model="files"
34
- />
35
- <InputFile
36
- v-if="fileType == 'video'"
37
- :name="props.name"
38
- :accept="acceptVideo"
39
- :limit="props.limitVideo"
40
- v-model="files"
41
- />
42
- </template>
19
+ }"
20
+ >
21
+ <Icon name="fa6-solid:cloud-arrow-up" size="24" />
22
+ <div class="font-body-large">เพิ่มรูปภาพ/วิดีโอ</div>
23
+ <div class="font-body-small">หรือลากและวาง</div>
24
+ </div>
25
+ </InputFile>
26
+
27
+ <template v-else>
28
+ <InputFile
29
+ v-if="fileType == 'image'"
30
+ :name="props.name"
31
+ :accept="acceptImage"
32
+ :limit="props.limitImage"
33
+ v-model="files"
34
+ />
35
+ <InputFile
36
+ v-if="fileType == 'video'"
37
+ :name="props.name"
38
+ :accept="acceptVideo"
39
+ :limit="props.limitVideo"
40
+ v-model="files"
41
+ />
42
+ </template>
43
43
  </template>
44
44
 
45
45
  <script setup>
@@ -1,46 +1,46 @@
1
1
  <template>
2
- <InputTextField
3
- v-bind="props"
4
- :type="isShowPassword ? 'text' : 'password'"
5
- :icon-append="isShowPassword ? 'lucide:eye' : 'lucide:eye-off'"
6
- :disabled-error-message="props.new"
7
- :rules="defaultRules || props.rules"
8
- @click-icon-append="switchEye"
9
- v-model="modelValue"
10
- >
11
- <template #label>
12
- <ShadFormLabel class="w-full flex justify-between">
13
- <div>
14
- {{ props.label }}
15
- <span v-if="props.required" class="text-destructive">*</span>
16
- </div>
17
- <div
18
- v-if="!props.disabledForgotPassword"
19
- class="font-body-medium text-primary"
20
- @click="handleForgotPassword"
21
- >
22
- ลืมรหัสผ่าน
23
- </div>
24
- </ShadFormLabel>
25
- </template>
26
- </InputTextField>
27
- <div v-if="props.new" class="space-y-[4px]">
28
- <div
29
- v-for="(item, i) in listValid"
30
- :key="i"
31
- class="font-body-large text-gray flex gap-[8px] items-center"
32
- >
33
- <Icon
2
+ <InputTextField
3
+ v-bind="props"
4
+ :type="isShowPassword ? 'text' : 'password'"
5
+ :icon-append="isShowPassword ? 'lucide:eye' : 'lucide:eye-off'"
6
+ :disabled-error-message="props.new"
7
+ :rules="defaultRules || props.rules"
8
+ @click-icon-append="switchEye"
9
+ v-model="modelValue"
10
+ >
11
+ <template #label>
12
+ <ShadFormLabel class="w-full flex justify-between">
13
+ <div>
14
+ {{ props.label }}
15
+ <span v-if="props.required" class="text-destructive">*</span>
16
+ </div>
17
+ <div
18
+ v-if="!props.disabledForgotPassword"
19
+ class="font-body-medium text-primary"
20
+ @click="handleForgotPassword"
21
+ >
22
+ ลืมรหัสผ่าน
23
+ </div>
24
+ </ShadFormLabel>
25
+ </template>
26
+ </InputTextField>
27
+ <div v-if="props.new" class="space-y-[4px]">
28
+ <div
29
+ v-for="(item, i) in listValid"
30
+ :key="i"
31
+ class="font-body-large text-gray flex gap-[8px] items-center"
32
+ >
33
+ <Icon
34
34
  :name="
35
35
  item.valid ? 'fa6-solid:circle-check' : 'fa6-solid:circle-exclamation'
36
- "
37
- :class="colorValidate(item.valid)"
38
- />
39
- <div>
40
- {{ item.label }}
41
- </div>
42
- </div>
43
- </div>
36
+ "
37
+ :class="colorValidate(item.valid)"
38
+ />
39
+ <div>
40
+ {{ item.label }}
41
+ </div>
42
+ </div>
43
+ </div>
44
44
  </template>
45
45
 
46
46
  <script setup>
@@ -1,10 +1,10 @@
1
1
  <template>
2
- <InputTextField
3
- ref="phoneRef"
4
- v-bind="props"
5
- :rules="defaultRules || props.rules"
6
- v-model="phoneCode"
7
- />
2
+ <InputTextField
3
+ ref="phoneRef"
4
+ v-bind="props"
5
+ :rules="defaultRules || props.rules"
6
+ v-model="phoneCode"
7
+ />
8
8
  </template>
9
9
 
10
10
  <script setup>
@@ -5,10 +5,10 @@ type __VLS_ModelProps = {
5
5
  };
6
6
  type __VLS_PublicProps = __VLS_Props & __VLS_ModelProps;
7
7
  declare var __VLS_7: {
8
- item: any;
9
- }, __VLS_10: `label-${any}-text`, __VLS_11: {}, __VLS_14: `label-${any}-text`, __VLS_15: {}, __VLS_17: {
10
- item: any;
11
- }, __VLS_20: `label-${any}-text`, __VLS_21: {}, __VLS_24: `label-${any}-text`, __VLS_25: {}, __VLS_27: {};
8
+ item: number | import("@/types/components/input/input-radio").InputRadioItem;
9
+ }, __VLS_10: `label-${string}-text` | `label-${number}-text`, __VLS_11: {}, __VLS_14: `label-${string}-text` | `label-${number}-text`, __VLS_15: {}, __VLS_17: {
10
+ item: string | number;
11
+ }, __VLS_20: `label-${string}-text` | `label-${number}-text`, __VLS_21: {}, __VLS_24: `label-${string}-text` | `label-${number}-text`, __VLS_25: {}, __VLS_27: {};
12
12
  type __VLS_Slots = {} & {
13
13
  [K in NonNullable<typeof __VLS_10>]?: (props: typeof __VLS_11) => any;
14
14
  } & {
@@ -1,105 +1,105 @@
1
1
  <template>
2
- <Field
3
- :name="props.name"
4
- v-slot="{ field, errorMessage }"
5
- :standalone="props.standalone"
6
- :rules="rules"
7
- v-model="modelValue"
8
- >
9
- <div
10
- :class="[layout, layoutGapClass]"
2
+ <Field
3
+ :name="props.name"
4
+ v-slot="{ field, errorMessage }"
5
+ :standalone="props.standalone"
6
+ :rules="rules"
7
+ v-model="modelValue"
8
+ >
9
+ <div
10
+ :class="[layout, layoutGapClass]"
11
11
  :style="{
12
12
  gap: layoutGapStyle
13
- }"
14
- >
15
- <template v-if="items.length > 0" v-for="(item, i) in items" :key="i">
16
- <slot name="default" :item="item">
17
- <label
13
+ }"
14
+ >
15
+ <template v-if="items.length > 0" v-for="(item, i) in items" :key="i">
16
+ <slot name="default" :item="item">
17
+ <label
18
18
  :class="[
19
19
  'flex items-center font-body-large',
20
20
  columnGapClass,
21
21
  cursor
22
- ]"
23
- :style="{ gap: columnGapStyle }"
24
- >
25
- <template v-if="props.labelPosition == 'left'">
26
- <slot
27
- :name="`label-${typeof item === 'object' ? item.value : item}-text`"
28
- >
29
- {{ typeof item === "object" ? item.label : item }}
30
- </slot>
31
- </template>
32
-
33
- <input
34
- v-bind="field"
35
- :class="['border-[1px] accent-primary', cursor]"
36
- type="radio"
37
- :name="props.name"
38
- :style="{ width: `${props.size}px`, height: `${props.size}px` }"
39
- :value="typeof item === 'object' ? item.value : item"
22
+ ]"
23
+ :style="{ gap: columnGapStyle }"
24
+ >
25
+ <template v-if="props.labelPosition == 'left'">
26
+ <slot
27
+ :name="`label-${typeof item === 'object' ? item.value : item}-text`"
28
+ >
29
+ {{ typeof item === "object" ? item.label : item }}
30
+ </slot>
31
+ </template>
32
+
33
+ <input
34
+ v-bind="field"
35
+ :class="['border-[1px] accent-primary', cursor]"
36
+ type="radio"
37
+ :name="props.name"
38
+ :style="{ width: `${props.size}px`, height: `${props.size}px` }"
39
+ :value="typeof item === 'object' ? item.value : item"
40
40
  :disabled="
41
41
  props.disabled || typeof item === 'object' && item.disabled
42
- "
42
+ "
43
43
  :checked="
44
44
  modelValue === (typeof item === 'object' ? item.value : item)
45
- "
46
- />
47
-
48
- <template v-if="props.labelPosition == 'right'">
49
- <slot
50
- :name="`label-${typeof item === 'object' ? item.value : item}-text`"
51
- >
52
- {{ typeof item === "object" ? item.label : item }}
53
- </slot>
54
- </template>
55
- </label>
56
- </slot>
57
- </template>
58
- <template v-else>
59
- <slot name="default" :item="item">
60
- <label
45
+ "
46
+ />
47
+
48
+ <template v-if="props.labelPosition == 'right'">
49
+ <slot
50
+ :name="`label-${typeof item === 'object' ? item.value : item}-text`"
51
+ >
52
+ {{ typeof item === "object" ? item.label : item }}
53
+ </slot>
54
+ </template>
55
+ </label>
56
+ </slot>
57
+ </template>
58
+ <template v-else>
59
+ <slot name="default" :item="item">
60
+ <label
61
61
  :class="[
62
62
  'flex items-center font-body-large',
63
63
  columnGapClass,
64
64
  cursor
65
- ]"
66
- :style="{ gap: columnGapStyle }"
67
- >
68
- <template v-if="props.labelPosition == 'left'">
69
- <slot :name="`label-${item}-text`">
70
- {{ item }}
71
- </slot>
72
- </template>
73
-
74
- <input
75
- v-bind="field"
76
- :class="['border-[1px] accent-primary', cursor]"
77
- type="radio"
78
- :name="props.name"
79
- :style="{ width: `${props.size}px`, height: `${props.size}px` }"
80
- :value="item"
81
- :disabled="props.disabled"
82
- />
83
-
84
- <template v-if="props.labelPosition == 'right'">
85
- <slot :name="`label-${item}-text`">
86
- {{ item }}
87
- </slot>
88
- </template>
89
- </label>
90
- </slot>
91
- </template>
92
-
93
- <div
94
- v-if="!props.disabledErrorMessage && errorMessage"
95
- class="font-body-small text-error"
96
- >
97
- <slot name="error">
98
- {{ errorMessage }}
99
- </slot>
100
- </div>
101
- </div>
102
- </Field>
65
+ ]"
66
+ :style="{ gap: columnGapStyle }"
67
+ >
68
+ <template v-if="props.labelPosition == 'left'">
69
+ <slot :name="`label-${item}-text`">
70
+ {{ item }}
71
+ </slot>
72
+ </template>
73
+
74
+ <input
75
+ v-bind="field"
76
+ :class="['border-[1px] accent-primary', cursor]"
77
+ type="radio"
78
+ :name="props.name"
79
+ :style="{ width: `${props.size}px`, height: `${props.size}px` }"
80
+ :value="item"
81
+ :disabled="props.disabled"
82
+ />
83
+
84
+ <template v-if="props.labelPosition == 'right'">
85
+ <slot :name="`label-${item}-text`">
86
+ {{ item }}
87
+ </slot>
88
+ </template>
89
+ </label>
90
+ </slot>
91
+ </template>
92
+
93
+ <div
94
+ v-if="!props.disabledErrorMessage && errorMessage"
95
+ class="font-body-small text-error"
96
+ >
97
+ <slot name="error">
98
+ {{ errorMessage }}
99
+ </slot>
100
+ </div>
101
+ </div>
102
+ </Field>
103
103
  </template>
104
104
 
105
105
  <script setup>