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,200 +1,200 @@
1
1
  <template>
2
- <Modal
3
- :title="props.item ? '\u0E41\u0E01\u0E49\u0E44\u0E02\u0E1A\u0E31\u0E15\u0E23\u0E1B\u0E23\u0E30\u0E0A\u0E32\u0E0A\u0E19' : '\u0E2D\u0E31\u0E1B\u0E42\u0E2B\u0E25\u0E14\u0E1A\u0E31\u0E15\u0E23\u0E1B\u0E23\u0E30\u0E0A\u0E32\u0E0A\u0E19'"
4
- width="499"
5
- divider
6
- :gap="imageFile ? 0 : 16"
7
- @close="onCancel"
8
- v-model="isOpenModal"
9
- >
10
- <div v-if="!imageFile" class="flex flex-col gap-[16px]">
11
- <div class="px-[16px]">
12
- <ul
13
- class="list-disc list-inside flex flex-col gap-[8px] font-body-medium-prominent text-gray"
14
- >
15
- <li>จัดวางรูปหน้าและตราครุฑตรงช่องกรอบ</li>
16
- <li>ต้องชัดเจน อ่านง่าย ไม่เบลอ</li>
17
- <li>มีแสงสว่างเพียงพอ และไม่มีแสงสะท้อน</li>
18
- <li>ไม่มีนิ้วมือมาปิดบังบัตรประชาชน</li>
19
- <li>บัตรประชาชนต้องไม่หมดอายุ</li>
20
- </ul>
21
- </div>
22
- <div v-if="props.item" class="px-[16px]">
23
- <div class="relative w-[467px] h-[263px]">
24
- <Image
25
- :src="props.item"
26
- width="467"
27
- height="263"
28
- class="rounded-[8px]"
29
- />
30
- <div class="absolute bottom-0 w-full">
31
- <input
32
- ref="fileInputRef"
33
- type="file"
34
- accept="image/*"
35
- class="hidden"
36
- @change="onSelectFile"
37
- />
38
- <div
39
- class="cursor-pointer text-white bg-black/50 flex gap-[4px] items-center justify-center py-[8px] rounded-b-[8px]"
40
- @click="onTriggerFileInput"
41
- >
42
- <div>
43
- <Icon name="lucide:upload" :size="24" />
44
- </div>
45
- <div class="font-body-medium">อัปโหลดรูปภาพบัตรประชาชน</div>
46
- </div>
47
- </div>
48
- </div>
49
- </div>
50
- <div v-else class="px-[16px]">
51
- <input
52
- ref="fileInputRef"
53
- type="file"
54
- accept="image/*"
55
- class="hidden"
56
- @change="onSelectFile"
57
- />
58
- <div
59
- class="w-[467px] h-[263px] flex flex-col justify-center items-center gap-[4px] cursor-pointer border-[2px] border-dashed rounded-[8px]"
2
+ <Modal
3
+ :title="props.item ? '\u0E41\u0E01\u0E49\u0E44\u0E02\u0E1A\u0E31\u0E15\u0E23\u0E1B\u0E23\u0E30\u0E0A\u0E32\u0E0A\u0E19' : '\u0E2D\u0E31\u0E1B\u0E42\u0E2B\u0E25\u0E14\u0E1A\u0E31\u0E15\u0E23\u0E1B\u0E23\u0E30\u0E0A\u0E32\u0E0A\u0E19'"
4
+ width="499"
5
+ divider
6
+ :gap="imageFile ? 0 : 16"
7
+ @close="onCancel"
8
+ v-model="isOpenModal"
9
+ >
10
+ <div v-if="!imageFile" class="flex flex-col gap-[16px]">
11
+ <div class="px-[16px]">
12
+ <ul
13
+ class="list-disc list-inside flex flex-col gap-[8px] font-body-medium-prominent text-gray"
14
+ >
15
+ <li>จัดวางรูปหน้าและตราครุฑตรงช่องกรอบ</li>
16
+ <li>ต้องชัดเจน อ่านง่าย ไม่เบลอ</li>
17
+ <li>มีแสงสว่างเพียงพอ และไม่มีแสงสะท้อน</li>
18
+ <li>ไม่มีนิ้วมือมาปิดบังบัตรประชาชน</li>
19
+ <li>บัตรประชาชนต้องไม่หมดอายุ</li>
20
+ </ul>
21
+ </div>
22
+ <div v-if="props.item" class="px-[16px]">
23
+ <div class="relative w-[467px] h-[263px]">
24
+ <Image
25
+ :src="props.item"
26
+ width="467"
27
+ height="263"
28
+ class="rounded-[8px]"
29
+ />
30
+ <div class="absolute bottom-0 w-full">
31
+ <input
32
+ ref="fileInputRef"
33
+ type="file"
34
+ accept="image/*"
35
+ class="hidden"
36
+ @change="onSelectFile"
37
+ />
38
+ <div
39
+ class="cursor-pointer text-white bg-black/50 flex gap-[4px] items-center justify-center py-[8px] rounded-b-[8px]"
40
+ @click="onTriggerFileInput"
41
+ >
42
+ <div>
43
+ <Icon name="lucide:upload" :size="24" />
44
+ </div>
45
+ <div class="font-body-medium">อัปโหลดรูปภาพบัตรประชาชน</div>
46
+ </div>
47
+ </div>
48
+ </div>
49
+ </div>
50
+ <div v-else class="px-[16px]">
51
+ <input
52
+ ref="fileInputRef"
53
+ type="file"
54
+ accept="image/*"
55
+ class="hidden"
56
+ @change="onSelectFile"
57
+ />
58
+ <div
59
+ class="w-[467px] h-[263px] flex flex-col justify-center items-center gap-[4px] cursor-pointer border-[2px] border-dashed rounded-[8px]"
60
60
  :class="
61
61
  isDrag ? 'bg-info border-primary text-primary' : 'bg-white border-mercury text-gray'
62
- "
63
- @click="onTriggerFileInput"
64
- @dragover.prevent="onDragOver"
65
- @dragleave.prevent="onDragLeave"
66
- @drop.prevent="onDrop"
67
- >
68
- <div class="flex flex-col gap-[4px] items-center">
69
- <div class="flex justify-center">
70
- <Icon name="lucide:upload" :size="24" />
71
- </div>
72
- <div class="font-body-large">อัปโหลดรูปภาพบัตรประชาชน</div>
73
- <div class="font-body-small">หรือลากและวาง</div>
74
- </div>
75
- </div>
76
- </div>
77
- </div>
78
- <div v-if="imageFile">
79
- <div class="h-[406px] flex justify-center items-center overflow-hidden">
80
- <div class="relative cropper-shell">
81
- <ImageCropper
82
- ref="cropperRef"
83
- :src="imageUrl"
84
- :container-style="cropperContainerSize"
85
- drag-mode="move"
86
- :view-mode="3"
87
- :guides="false"
88
- :movable="true"
89
- :crop-box-movable="false"
90
- :crop-box-resizable="false"
91
- :background="false"
92
- :center="false"
93
- :rotatable="true"
94
- :highlight="false"
95
- :auto-crop-area="1"
96
- :responsive="true"
97
- :zoom-on-wheel="false"
98
- :zoom-on-touch="false"
99
- :modal="false"
100
- @zoom="onZoom"
101
- />
102
- <div
103
- class="absolute inset-0 border-[6px] border-primary rounded-[18px] pointer-events-none w-[470px] h-[296px] mx-auto my-auto"
104
- >
105
- <div
106
- class="absolute top-[8px] left-[8px] border-[6px] border-primary rounded-full w-[58px] h-[58px]"
107
- />
108
- <div
109
- class="absolute bottom-[24px] right-[12px] border-[6px] border-primary w-[103px] h-[127px]"
110
- />
111
- </div>
112
- </div>
113
- </div>
114
- <div class="p-[16px] flex gap-[40px] items-center">
115
- <div class="flex gap-[16px] items-center">
116
- <div>
117
- <Icon name="lucide:zoom-in" :size="20" />
118
- </div>
119
- <Button
120
- variant="text"
121
- disabled-padding
122
- :disabled="!imageFile"
123
- @click="onZoomOut"
124
- >
125
- <div>
126
- <Icon name="f7:minus" :size="16" />
127
- </div>
128
- </Button>
129
- <InputSlider
130
- :thumb-size="16"
131
- :min="isZoomMin"
132
- :max="isZoomMax"
133
- :step="isZoomStep"
134
- :disabled="!imageFile"
135
- full-width
136
- v-model="isZoom"
137
- />
138
- <Button
139
- variant="text"
140
- disabled-padding
141
- :disabled="!imageFile"
142
- @click="onZoomIn"
143
- >
144
- <div>
145
- <Icon name="f7:plus" :size="16" />
146
- </div>
147
- </Button>
148
- </div>
149
- <div class="flex gap-[16px] items-center">
150
- <div>
151
- <Icon name="lucide:refresh-cw" :size="20" />
152
- </div>
153
- <Button
154
- variant="text"
155
- disabled-padding
156
- :disabled="!imageFile"
157
- @click="onRotateLeft"
158
- >
159
- <div>
160
- <Icon name="f7:minus" size="16" />
161
- </div>
162
- </Button>
163
- <InputSlider
164
- :thumb-size="16"
165
- :min="isRotateMin"
166
- :max="isRotateMax"
167
- :step="isRotateStep"
168
- :disabled="!imageFile"
169
- full-width
170
- v-model="isRotate"
171
- />
172
- <Button
173
- variant="text"
174
- disabled-padding
175
- :disabled="!imageFile"
176
- @click="onRotateRight"
177
- aria-label="หมุนขวา"
178
- >
179
- <Icon name="f7:plus" :size="16" />
180
- </Button>
181
- </div>
182
- </div>
183
- </div>
184
- <template #footer>
185
- <div class="flex gap-[16px] w-full">
186
- <Button variant="outline" full-width @click="onCancel">ยกเลิก</Button>
187
- <Button
188
- color="primary"
189
- full-width
190
- :disabled="!imageFile"
191
- @click="onCropImage"
192
- >
193
- ยืนยัน
194
- </Button>
195
- </div>
196
- </template>
197
- </Modal>
62
+ "
63
+ @click="onTriggerFileInput"
64
+ @dragover.prevent="onDragOver"
65
+ @dragleave.prevent="onDragLeave"
66
+ @drop.prevent="onDrop"
67
+ >
68
+ <div class="flex flex-col gap-[4px] items-center">
69
+ <div class="flex justify-center">
70
+ <Icon name="lucide:upload" :size="24" />
71
+ </div>
72
+ <div class="font-body-large">อัปโหลดรูปภาพบัตรประชาชน</div>
73
+ <div class="font-body-small">หรือลากและวาง</div>
74
+ </div>
75
+ </div>
76
+ </div>
77
+ </div>
78
+ <div v-if="imageFile">
79
+ <div class="h-[406px] flex justify-center items-center overflow-hidden">
80
+ <div class="relative cropper-shell">
81
+ <ImageCropper
82
+ ref="cropperRef"
83
+ :src="imageUrl"
84
+ :container-style="cropperContainerSize"
85
+ drag-mode="move"
86
+ :view-mode="3"
87
+ :guides="false"
88
+ :movable="true"
89
+ :crop-box-movable="false"
90
+ :crop-box-resizable="false"
91
+ :background="false"
92
+ :center="false"
93
+ :rotatable="true"
94
+ :highlight="false"
95
+ :auto-crop-area="1"
96
+ :responsive="true"
97
+ :zoom-on-wheel="false"
98
+ :zoom-on-touch="false"
99
+ :modal="false"
100
+ @zoom="onZoom"
101
+ />
102
+ <div
103
+ class="absolute inset-0 border-[6px] border-primary rounded-[18px] pointer-events-none w-[470px] h-[296px] mx-auto my-auto"
104
+ >
105
+ <div
106
+ class="absolute top-[8px] left-[8px] border-[6px] border-primary rounded-full w-[58px] h-[58px]"
107
+ />
108
+ <div
109
+ class="absolute bottom-[24px] right-[12px] border-[6px] border-primary w-[103px] h-[127px]"
110
+ />
111
+ </div>
112
+ </div>
113
+ </div>
114
+ <div class="p-[16px] flex gap-[40px] items-center">
115
+ <div class="flex gap-[16px] items-center">
116
+ <div>
117
+ <Icon name="lucide:zoom-in" :size="20" />
118
+ </div>
119
+ <Button
120
+ variant="text"
121
+ disabled-padding
122
+ :disabled="!imageFile"
123
+ @click="onZoomOut"
124
+ >
125
+ <div>
126
+ <Icon name="f7:minus" :size="16" />
127
+ </div>
128
+ </Button>
129
+ <InputSlider
130
+ :thumb-size="16"
131
+ :min="isZoomMin"
132
+ :max="isZoomMax"
133
+ :step="isZoomStep"
134
+ :disabled="!imageFile"
135
+ full-width
136
+ v-model="isZoom"
137
+ />
138
+ <Button
139
+ variant="text"
140
+ disabled-padding
141
+ :disabled="!imageFile"
142
+ @click="onZoomIn"
143
+ >
144
+ <div>
145
+ <Icon name="f7:plus" :size="16" />
146
+ </div>
147
+ </Button>
148
+ </div>
149
+ <div class="flex gap-[16px] items-center">
150
+ <div>
151
+ <Icon name="lucide:refresh-cw" :size="20" />
152
+ </div>
153
+ <Button
154
+ variant="text"
155
+ disabled-padding
156
+ :disabled="!imageFile"
157
+ @click="onRotateLeft"
158
+ >
159
+ <div>
160
+ <Icon name="f7:minus" size="16" />
161
+ </div>
162
+ </Button>
163
+ <InputSlider
164
+ :thumb-size="16"
165
+ :min="isRotateMin"
166
+ :max="isRotateMax"
167
+ :step="isRotateStep"
168
+ :disabled="!imageFile"
169
+ full-width
170
+ v-model="isRotate"
171
+ />
172
+ <Button
173
+ variant="text"
174
+ disabled-padding
175
+ :disabled="!imageFile"
176
+ @click="onRotateRight"
177
+ aria-label="หมุนขวา"
178
+ >
179
+ <Icon name="f7:plus" :size="16" />
180
+ </Button>
181
+ </div>
182
+ </div>
183
+ </div>
184
+ <template #footer>
185
+ <div class="flex gap-[16px] w-full">
186
+ <Button variant="outline" full-width @click="onCancel">ยกเลิก</Button>
187
+ <Button
188
+ color="primary"
189
+ full-width
190
+ :disabled="!imageFile"
191
+ @click="onCropImage"
192
+ >
193
+ ยืนยัน
194
+ </Button>
195
+ </div>
196
+ </template>
197
+ </Modal>
198
198
  </template>
199
199
 
200
200
  <script setup>
@@ -1,42 +1,42 @@
1
1
  <template>
2
- <Modal
3
- title="ป้อนรหัสรักษาความปลอดภัย (OTP)"
4
- title-position="center"
5
- :loading="loadingModal"
6
- @close="emit('close')"
7
- @submit="onVerifyOTP"
8
- v-model="isOpen"
9
- >
10
- <div class="space-y-[16px]">
11
- <div class="text-center font-body-large">
12
- <div>
13
- ส่งรหัส 6 หลักไปที่เบอร์โทรศัพท์
14
- <span>{{ props.phoneLabel || props.phone }}</span>
15
- </div>
16
- <div v-if="textRef">(Ref : {{ textRef }})</div>
17
- </div>
18
-
19
- <div class="flex justify-center">
20
- <InputOTP name="otp" columnGap="auto" v-model="valueOTP" />
21
- </div>
22
-
23
- <div class="text-center font-body-large">
24
- กรุณารอ <span class="text-primary">04.59</span> นาที
25
- จะส่งรหัสยืนยันอีกครั้ง
26
- </div>
27
- </div>
28
- <template #footer="{ meta }">
29
- <Button
30
- type="submit"
31
- color="primary"
32
- full-width
33
- :disabled="!meta.valid"
34
- class="w-full"
35
- >
36
- {{ props.confirmedText }}
37
- </Button>
38
- </template>
39
- </Modal>
2
+ <Modal
3
+ title="ป้อนรหัสรักษาความปลอดภัย (OTP)"
4
+ title-position="center"
5
+ :loading="loadingModal"
6
+ @close="emit('close')"
7
+ @submit="onVerifyOTP"
8
+ v-model="isOpen"
9
+ >
10
+ <div class="space-y-[16px]">
11
+ <div class="text-center font-body-large">
12
+ <div>
13
+ ส่งรหัส 6 หลักไปที่เบอร์โทรศัพท์
14
+ <span>{{ props.phoneLabel || props.phone }}</span>
15
+ </div>
16
+ <div v-if="textRef">(Ref : {{ textRef }})</div>
17
+ </div>
18
+
19
+ <div class="flex justify-center">
20
+ <InputOTP name="otp" columnGap="auto" v-model="valueOTP" />
21
+ </div>
22
+
23
+ <div class="text-center font-body-large">
24
+ กรุณารอ <span class="text-primary">04.59</span> นาที
25
+ จะส่งรหัสยืนยันอีกครั้ง
26
+ </div>
27
+ </div>
28
+ <template #footer="{ meta }">
29
+ <Button
30
+ type="submit"
31
+ color="primary"
32
+ full-width
33
+ :disabled="!meta.valid"
34
+ class="w-full"
35
+ >
36
+ {{ props.confirmedText }}
37
+ </Button>
38
+ </template>
39
+ </Modal>
40
40
  </template>
41
41
 
42
42
  <script setup>