pukaad-ui-lib 1.282.0 → 1.282.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 (346) hide show
  1. package/dist/module.json +1 -1
  2. package/dist/runtime/assets/json/social-icon.json +76 -76
  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/map-location-dot.svg +9 -9
  11. package/dist/runtime/assets/svg/map-pin.svg +6 -6
  12. package/dist/runtime/assets/svg/memsg-circle.svg +7 -7
  13. package/dist/runtime/assets/svg/memsg-fade.svg +5 -5
  14. package/dist/runtime/assets/svg/memsg-logo-outline.svg +3 -3
  15. package/dist/runtime/assets/svg/memsg-square.svg +9 -9
  16. package/dist/runtime/assets/svg/message.svg +3 -3
  17. package/dist/runtime/assets/svg/page-not-found.svg +9 -9
  18. package/dist/runtime/assets/svg/share-from-square.svg +3 -3
  19. package/dist/runtime/assets/svg/share.svg +2 -2
  20. package/dist/runtime/assets/svg/shopping-cart.svg +16 -16
  21. package/dist/runtime/assets/svg/socials/Email.svg +12 -12
  22. package/dist/runtime/assets/svg/socials/Facebook.svg +4 -4
  23. package/dist/runtime/assets/svg/socials/Line.svg +11 -11
  24. package/dist/runtime/assets/svg/socials/LinkedIn.svg +5 -5
  25. package/dist/runtime/assets/svg/socials/Pinterest.svg +4 -4
  26. package/dist/runtime/assets/svg/socials/SnapChat.svg +5 -5
  27. package/dist/runtime/assets/svg/socials/Threads.svg +12 -12
  28. package/dist/runtime/assets/svg/socials/{TikTok.svg → Tiktok.svg} +6 -6
  29. package/dist/runtime/assets/svg/socials/Tumblr.svg +4 -4
  30. package/dist/runtime/assets/svg/socials/Website.svg +11 -11
  31. package/dist/runtime/assets/svg/socials/Whatsapp.svg +5 -5
  32. package/dist/runtime/assets/svg/socials/X.svg +4 -4
  33. package/dist/runtime/assets/svg/socials/{YouTube.svg → Youtube.svg} +5 -5
  34. package/dist/runtime/assets/svg/socials/{Instagram.svg → instagram.svg} +14 -14
  35. package/dist/runtime/assets/svg/tag-empty.svg +25 -25
  36. package/dist/runtime/assets/svg/thumbs-up-regular.svg +9 -9
  37. package/dist/runtime/assets/svg/thumbs-up-solid.svg +2 -2
  38. package/dist/runtime/assets/svg/vector.svg +2 -2
  39. package/dist/runtime/assets/svg/verify.svg +10 -10
  40. package/dist/runtime/assets/svg/write-review.svg +15 -15
  41. package/dist/runtime/components/avatar-profile.vue +29 -29
  42. package/dist/runtime/components/avatar.vue +20 -20
  43. package/dist/runtime/components/button.vue +9 -9
  44. package/dist/runtime/components/card/card-announce2.vue +102 -104
  45. package/dist/runtime/components/card/card-blog.vue +45 -45
  46. package/dist/runtime/components/card/card-place-detail.vue +51 -51
  47. package/dist/runtime/components/card/card-place.vue +28 -28
  48. package/dist/runtime/components/card/card-profile-about.vue +81 -81
  49. package/dist/runtime/components/card/card-profile-header.d.vue.ts +1 -1
  50. package/dist/runtime/components/card/card-profile-header.vue +94 -94
  51. package/dist/runtime/components/card/card-profile-header.vue.d.ts +1 -1
  52. package/dist/runtime/components/card/card-reaction.d.vue.ts +1 -1
  53. package/dist/runtime/components/card/card-reaction.vue +23 -23
  54. package/dist/runtime/components/card/card-reaction.vue.d.ts +1 -1
  55. package/dist/runtime/components/card/card-recommend-blog.vue +42 -42
  56. package/dist/runtime/components/card/card-recommend-place.vue +45 -45
  57. package/dist/runtime/components/card/card-recommend-profile.vue +46 -46
  58. package/dist/runtime/components/card/card-review.vue +57 -57
  59. package/dist/runtime/components/card/card-user-blog.vue +76 -76
  60. package/dist/runtime/components/card/card-user-item.vue +24 -24
  61. package/dist/runtime/components/card/card.vue +29 -29
  62. package/dist/runtime/components/carousel.vue +31 -31
  63. package/dist/runtime/components/chip.vue +10 -10
  64. package/dist/runtime/components/collapse/collapse-multiple.vue +42 -42
  65. package/dist/runtime/components/collapse/collapse.vue +23 -23
  66. package/dist/runtime/components/comment.vue +204 -204
  67. package/dist/runtime/components/data-list.vue +49 -49
  68. package/dist/runtime/components/data-table.vue +131 -131
  69. package/dist/runtime/components/display/display-image-place.d.vue.ts +1 -1
  70. package/dist/runtime/components/display/display-image-place.vue +88 -88
  71. package/dist/runtime/components/display/display-image-place.vue.d.ts +1 -1
  72. package/dist/runtime/components/display/display-image-review.vue +10 -10
  73. package/dist/runtime/components/display/display-image.vue +49 -49
  74. package/dist/runtime/components/display/display-rating-summary.vue +34 -34
  75. package/dist/runtime/components/divider.vue +8 -8
  76. package/dist/runtime/components/draggable.vue +15 -15
  77. package/dist/runtime/components/drawer/drawer-post-blog.vue +70 -70
  78. package/dist/runtime/components/drawer/drawer-post-review.vue +67 -67
  79. package/dist/runtime/components/drawer/drawer-profile-about.vue +52 -52
  80. package/dist/runtime/components/drawer/drawer-profile-network.d.vue.ts +1 -1
  81. package/dist/runtime/components/drawer/drawer-profile-network.vue +136 -136
  82. package/dist/runtime/components/drawer/drawer-profile-network.vue.d.ts +1 -1
  83. package/dist/runtime/components/drawer/drawer-suggest-place/drawer-suggest-place.vue +92 -92
  84. package/dist/runtime/components/drawer/drawer-suggest-place/suggest-place-form.vue +70 -70
  85. package/dist/runtime/components/drawer/drawer-suggest-place/suggest-place-map.vue +5 -5
  86. package/dist/runtime/components/drawer/drawer.vue +24 -24
  87. package/dist/runtime/components/dropdown.vue +8 -8
  88. package/dist/runtime/components/filter/filter-list-chip.vue +10 -10
  89. package/dist/runtime/components/filter/filter-list.vue +17 -17
  90. package/dist/runtime/components/icons.vue +1 -1
  91. package/dist/runtime/components/image/image-cropper.vue +9 -9
  92. package/dist/runtime/components/image/image.vue +27 -27
  93. package/dist/runtime/components/input/input-OTP.vue +27 -27
  94. package/dist/runtime/components/input/input-address.vue +147 -147
  95. package/dist/runtime/components/input/input-autocomplete.d.vue.ts +2 -2
  96. package/dist/runtime/components/input/input-autocomplete.vue +80 -80
  97. package/dist/runtime/components/input/input-autocomplete.vue.d.ts +2 -2
  98. package/dist/runtime/components/input/input-birth-date.vue +20 -20
  99. package/dist/runtime/components/input/input-checkbox.vue +17 -17
  100. package/dist/runtime/components/input/input-combobox.vue +100 -100
  101. package/dist/runtime/components/input/input-comment.vue +6 -6
  102. package/dist/runtime/components/input/input-content.vue +32 -32
  103. package/dist/runtime/components/input/input-date-opening.vue +96 -96
  104. package/dist/runtime/components/input/input-date-picker.vue +102 -102
  105. package/dist/runtime/components/input/input-email.vue +9 -9
  106. package/dist/runtime/components/input/input-file.vue +125 -125
  107. package/dist/runtime/components/input/input-link.vue +35 -35
  108. package/dist/runtime/components/input/input-media.vue +36 -36
  109. package/dist/runtime/components/input/input-password.vue +43 -43
  110. package/dist/runtime/components/input/input-phone.vue +11 -11
  111. package/dist/runtime/components/input/input-profile-name.vue +10 -10
  112. package/dist/runtime/components/input/input-radio.vue +55 -55
  113. package/dist/runtime/components/input/input-rating.vue +13 -13
  114. package/dist/runtime/components/input/input-recaptcha.vue +19 -19
  115. package/dist/runtime/components/input/input-search.vue +71 -71
  116. package/dist/runtime/components/input/input-select-province.vue +94 -94
  117. package/dist/runtime/components/input/input-select-tag.vue +51 -51
  118. package/dist/runtime/components/input/input-select.vue +52 -52
  119. package/dist/runtime/components/input/input-slider.vue +19 -19
  120. package/dist/runtime/components/input/input-switch.vue +25 -25
  121. package/dist/runtime/components/input/input-tag.vue +145 -145
  122. package/dist/runtime/components/input/input-text-field.vue +90 -90
  123. package/dist/runtime/components/input/input-textarea.vue +58 -58
  124. package/dist/runtime/components/label/label-announce-time.vue +9 -9
  125. package/dist/runtime/components/label/label-card-atom.vue +8 -8
  126. package/dist/runtime/components/list/list-menu.vue +13 -13
  127. package/dist/runtime/components/loading.vue +8 -8
  128. package/dist/runtime/components/modal/modal-2FA-generate.vue +48 -48
  129. package/dist/runtime/components/modal/modal-2FA.vue +28 -28
  130. package/dist/runtime/components/modal/modal-account-disabled-alert.vue +33 -33
  131. package/dist/runtime/components/modal/modal-account-disabled-confirmed.vue +32 -32
  132. package/dist/runtime/components/modal/modal-account-disabled-reason.vue +45 -45
  133. package/dist/runtime/components/modal/modal-account-disabled.vue +9 -9
  134. package/dist/runtime/components/modal/modal-display-image.vue +38 -38
  135. package/dist/runtime/components/modal/modal-email-OTP.vue +32 -32
  136. package/dist/runtime/components/modal/modal-forgot-password.vue +9 -9
  137. package/dist/runtime/components/modal/modal-media-view.vue +12 -12
  138. package/dist/runtime/components/modal/modal-password-confirmed.vue +30 -30
  139. package/dist/runtime/components/modal/modal-password-new.vue +14 -14
  140. package/dist/runtime/components/modal/modal-password-verify.vue +13 -13
  141. package/dist/runtime/components/modal/modal-personal-card-ID.vue +167 -167
  142. package/dist/runtime/components/modal/modal-phone-OTP.vue +49 -49
  143. package/dist/runtime/components/modal/modal-profile-edit.vue +69 -71
  144. package/dist/runtime/components/modal/modal-province-domain.vue +23 -23
  145. package/dist/runtime/components/modal/modal-report.vue +47 -47
  146. package/dist/runtime/components/modal/modal-review-detail.vue +118 -118
  147. package/dist/runtime/components/modal/modal-secure.d.vue.ts +1 -1
  148. package/dist/runtime/components/modal/modal-secure.vue +7 -7
  149. package/dist/runtime/components/modal/modal-secure.vue.d.ts +1 -1
  150. package/dist/runtime/components/modal/modal-share.vue +20 -20
  151. package/dist/runtime/components/modal/modal-user-account-search.vue +69 -69
  152. package/dist/runtime/components/modal/modal.vue +27 -27
  153. package/dist/runtime/components/pagination.vue +47 -47
  154. package/dist/runtime/components/picker/picker-image-cover-profile.vue +80 -80
  155. package/dist/runtime/components/picker/picker-image-profile.vue +102 -102
  156. package/dist/runtime/components/picker/picker-option-menu/picker-option-menu-user.vue +18 -18
  157. package/dist/runtime/components/picker/picker-option-menu/picker-option-menu.vue +26 -26
  158. package/dist/runtime/components/profile-cover.vue +80 -80
  159. package/dist/runtime/components/progress-bar.vue +9 -9
  160. package/dist/runtime/components/read-more-text.vue +1 -1
  161. package/dist/runtime/components/tab_old.vue +78 -78
  162. package/dist/runtime/components/table.vue +79 -79
  163. package/dist/runtime/components/tooltip.vue +12 -12
  164. package/dist/runtime/components/ui/accordion/Accordion.vue +3 -3
  165. package/dist/runtime/components/ui/accordion/AccordionContent.vue +9 -9
  166. package/dist/runtime/components/ui/accordion/AccordionItem.vue +8 -8
  167. package/dist/runtime/components/ui/accordion/AccordionTrigger.vue +16 -16
  168. package/dist/runtime/components/ui/alert/Alert.vue +7 -7
  169. package/dist/runtime/components/ui/alert/AlertDescription.vue +6 -6
  170. package/dist/runtime/components/ui/alert/AlertTitle.vue +6 -6
  171. package/dist/runtime/components/ui/alert-dialog/AlertDialog.vue +3 -3
  172. package/dist/runtime/components/ui/alert-dialog/AlertDialogAction.vue +3 -3
  173. package/dist/runtime/components/ui/alert-dialog/AlertDialogCancel.vue +6 -6
  174. package/dist/runtime/components/ui/alert-dialog/AlertDialogContent.d.vue.ts +4 -4
  175. package/dist/runtime/components/ui/alert-dialog/AlertDialogContent.vue +13 -13
  176. package/dist/runtime/components/ui/alert-dialog/AlertDialogContent.vue.d.ts +4 -4
  177. package/dist/runtime/components/ui/alert-dialog/AlertDialogDescription.vue +7 -7
  178. package/dist/runtime/components/ui/alert-dialog/AlertDialogFooter.vue +6 -6
  179. package/dist/runtime/components/ui/alert-dialog/AlertDialogHeader.vue +6 -6
  180. package/dist/runtime/components/ui/alert-dialog/AlertDialogTitle.vue +7 -7
  181. package/dist/runtime/components/ui/alert-dialog/AlertDialogTrigger.vue +3 -3
  182. package/dist/runtime/components/ui/avatar/Avatar.vue +6 -6
  183. package/dist/runtime/components/ui/avatar/AvatarFallback.vue +7 -7
  184. package/dist/runtime/components/ui/avatar/AvatarImage.vue +7 -7
  185. package/dist/runtime/components/ui/badge/Badge.vue +7 -7
  186. package/dist/runtime/components/ui/breadcrumb/Breadcrumb.vue +7 -7
  187. package/dist/runtime/components/ui/breadcrumb/BreadcrumbEllipsis.vue +11 -11
  188. package/dist/runtime/components/ui/breadcrumb/BreadcrumbItem.vue +6 -6
  189. package/dist/runtime/components/ui/breadcrumb/BreadcrumbLink.vue +8 -8
  190. package/dist/runtime/components/ui/breadcrumb/BreadcrumbList.vue +6 -6
  191. package/dist/runtime/components/ui/breadcrumb/BreadcrumbPage.vue +9 -9
  192. package/dist/runtime/components/ui/breadcrumb/BreadcrumbSeparator.vue +10 -10
  193. package/dist/runtime/components/ui/button/Button.vue +8 -8
  194. package/dist/runtime/components/ui/calendar/Calendar.vue +128 -128
  195. package/dist/runtime/components/ui/calendar/CalendarCell.vue +7 -7
  196. package/dist/runtime/components/ui/calendar/CalendarCellTrigger.vue +7 -7
  197. package/dist/runtime/components/ui/calendar/CalendarGrid.vue +7 -7
  198. package/dist/runtime/components/ui/calendar/CalendarGridBody.vue +6 -6
  199. package/dist/runtime/components/ui/calendar/CalendarGridHead.vue +6 -6
  200. package/dist/runtime/components/ui/calendar/CalendarGridRow.vue +6 -6
  201. package/dist/runtime/components/ui/calendar/CalendarHeadCell.vue +7 -7
  202. package/dist/runtime/components/ui/calendar/CalendarHeader.vue +7 -7
  203. package/dist/runtime/components/ui/calendar/CalendarHeading.vue +10 -10
  204. package/dist/runtime/components/ui/calendar/CalendarNextButton.vue +9 -9
  205. package/dist/runtime/components/ui/calendar/CalendarPrevButton.vue +9 -9
  206. package/dist/runtime/components/ui/card/Card.vue +8 -8
  207. package/dist/runtime/components/ui/card/CardAction.vue +6 -6
  208. package/dist/runtime/components/ui/card/CardContent.vue +6 -6
  209. package/dist/runtime/components/ui/card/CardDescription.vue +6 -6
  210. package/dist/runtime/components/ui/card/CardFooter.vue +6 -6
  211. package/dist/runtime/components/ui/card/CardHeader.vue +6 -6
  212. package/dist/runtime/components/ui/card/CardTitle.vue +6 -6
  213. package/dist/runtime/components/ui/carousel/Carousel.vue +10 -10
  214. package/dist/runtime/components/ui/carousel/CarouselContent.vue +12 -12
  215. package/dist/runtime/components/ui/carousel/CarouselItem.vue +8 -8
  216. package/dist/runtime/components/ui/carousel/CarouselNext.vue +13 -13
  217. package/dist/runtime/components/ui/carousel/CarouselPrevious.vue +13 -13
  218. package/dist/runtime/components/ui/checkbox/Checkbox.vue +8 -8
  219. package/dist/runtime/components/ui/command/Command.vue +7 -7
  220. package/dist/runtime/components/ui/command/CommandDialog.vue +11 -11
  221. package/dist/runtime/components/ui/command/CommandEmpty.vue +16 -16
  222. package/dist/runtime/components/ui/command/CommandGroup.vue +16 -16
  223. package/dist/runtime/components/ui/command/CommandInput.vue +13 -13
  224. package/dist/runtime/components/ui/command/CommandItem.vue +11 -11
  225. package/dist/runtime/components/ui/command/CommandList.vue +9 -9
  226. package/dist/runtime/components/ui/command/CommandSeparator.vue +7 -7
  227. package/dist/runtime/components/ui/command/CommandShortcut.vue +6 -6
  228. package/dist/runtime/components/ui/dialog/Dialog.vue +3 -3
  229. package/dist/runtime/components/ui/dialog/DialogClose.vue +3 -3
  230. package/dist/runtime/components/ui/dialog/DialogContent.d.vue.ts +4 -4
  231. package/dist/runtime/components/ui/dialog/DialogContent.vue +26 -26
  232. package/dist/runtime/components/ui/dialog/DialogContent.vue.d.ts +4 -4
  233. package/dist/runtime/components/ui/dialog/DialogDescription.vue +7 -7
  234. package/dist/runtime/components/ui/dialog/DialogFooter.vue +6 -6
  235. package/dist/runtime/components/ui/dialog/DialogHeader.vue +6 -6
  236. package/dist/runtime/components/ui/dialog/DialogOverlay.vue +7 -7
  237. package/dist/runtime/components/ui/dialog/DialogScrollContent.d.vue.ts +4 -4
  238. package/dist/runtime/components/ui/dialog/DialogScrollContent.vue +20 -20
  239. package/dist/runtime/components/ui/dialog/DialogScrollContent.vue.d.ts +4 -4
  240. package/dist/runtime/components/ui/dialog/DialogTitle.vue +7 -7
  241. package/dist/runtime/components/ui/dialog/DialogTrigger.vue +3 -3
  242. package/dist/runtime/components/ui/dropdown-menu/DropdownMenu.vue +6 -6
  243. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuCheckboxItem.vue +12 -12
  244. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuContent.d.vue.ts +2 -2
  245. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuContent.vue +10 -10
  246. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuContent.vue.d.ts +2 -2
  247. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuGroup.vue +6 -6
  248. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuItem.vue +9 -9
  249. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuLabel.vue +8 -8
  250. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuRadioGroup.vue +6 -6
  251. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuRadioItem.vue +16 -16
  252. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSeparator.vue +5 -5
  253. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuShortcut.vue +6 -6
  254. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSub.vue +3 -3
  255. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSubContent.d.vue.ts +4 -4
  256. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSubContent.vue +7 -7
  257. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSubContent.vue.d.ts +4 -4
  258. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSubTrigger.vue +8 -8
  259. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuTrigger.vue +6 -6
  260. package/dist/runtime/components/ui/form/FormControl.vue +8 -8
  261. package/dist/runtime/components/ui/form/FormDescription.vue +7 -7
  262. package/dist/runtime/components/ui/form/FormItem.vue +3 -3
  263. package/dist/runtime/components/ui/form/FormLabel.vue +8 -8
  264. package/dist/runtime/components/ui/form/FormMessage.vue +7 -7
  265. package/dist/runtime/components/ui/input/Input.vue +7 -7
  266. package/dist/runtime/components/ui/input-group/InputGroup.vue +7 -7
  267. package/dist/runtime/components/ui/input-group/InputGroupAddon.vue +9 -9
  268. package/dist/runtime/components/ui/input-group/InputGroupButton.vue +8 -8
  269. package/dist/runtime/components/ui/input-group/InputGroupInput.vue +5 -5
  270. package/dist/runtime/components/ui/input-group/InputGroupText.vue +5 -5
  271. package/dist/runtime/components/ui/input-group/InputGroupTextarea.vue +4 -4
  272. package/dist/runtime/components/ui/label/Label.vue +7 -7
  273. package/dist/runtime/components/ui/native-select/NativeSelect.vue +19 -19
  274. package/dist/runtime/components/ui/native-select/NativeSelectOptGroup.vue +3 -3
  275. package/dist/runtime/components/ui/native-select/NativeSelectOption.vue +3 -3
  276. package/dist/runtime/components/ui/pagination/Pagination.vue +8 -8
  277. package/dist/runtime/components/ui/pagination/PaginationContent.vue +8 -8
  278. package/dist/runtime/components/ui/pagination/PaginationEllipsis.vue +10 -10
  279. package/dist/runtime/components/ui/pagination/PaginationFirst.vue +10 -10
  280. package/dist/runtime/components/ui/pagination/PaginationItem.vue +7 -7
  281. package/dist/runtime/components/ui/pagination/PaginationLast.vue +10 -10
  282. package/dist/runtime/components/ui/pagination/PaginationNext.vue +10 -10
  283. package/dist/runtime/components/ui/pagination/PaginationPrevious.vue +10 -10
  284. package/dist/runtime/components/ui/pin-input/PinInput.vue +7 -7
  285. package/dist/runtime/components/ui/pin-input/PinInputGroup.vue +7 -7
  286. package/dist/runtime/components/ui/pin-input/PinInputSeparator.vue +3 -3
  287. package/dist/runtime/components/ui/pin-input/PinInputSlot.vue +5 -5
  288. package/dist/runtime/components/ui/popover/Popover.vue +7 -7
  289. package/dist/runtime/components/ui/popover/PopoverAnchor.vue +6 -6
  290. package/dist/runtime/components/ui/popover/PopoverContent.d.vue.ts +4 -4
  291. package/dist/runtime/components/ui/popover/PopoverContent.vue +9 -9
  292. package/dist/runtime/components/ui/popover/PopoverContent.vue.d.ts +4 -4
  293. package/dist/runtime/components/ui/popover/PopoverTrigger.vue +6 -6
  294. package/dist/runtime/components/ui/scroll-area/ScrollArea.vue +14 -14
  295. package/dist/runtime/components/ui/scroll-area/ScrollBar.vue +10 -10
  296. package/dist/runtime/components/ui/select/Select.vue +7 -7
  297. package/dist/runtime/components/ui/select/SelectContent.d.vue.ts +2 -2
  298. package/dist/runtime/components/ui/select/SelectContent.vue +10 -10
  299. package/dist/runtime/components/ui/select/SelectContent.vue.d.ts +2 -2
  300. package/dist/runtime/components/ui/select/SelectGroup.vue +6 -6
  301. package/dist/runtime/components/ui/select/SelectItem.vue +17 -17
  302. package/dist/runtime/components/ui/select/SelectItemText.vue +6 -6
  303. package/dist/runtime/components/ui/select/SelectLabel.vue +6 -6
  304. package/dist/runtime/components/ui/select/SelectScrollDownButton.vue +9 -9
  305. package/dist/runtime/components/ui/select/SelectScrollUpButton.vue +9 -9
  306. package/dist/runtime/components/ui/select/SelectSeparator.vue +5 -5
  307. package/dist/runtime/components/ui/select/SelectTrigger.vue +11 -11
  308. package/dist/runtime/components/ui/select/SelectValue.vue +6 -6
  309. package/dist/runtime/components/ui/separator/Separator.vue +5 -5
  310. package/dist/runtime/components/ui/sheet/Sheet.vue +3 -3
  311. package/dist/runtime/components/ui/sheet/SheetClose.vue +3 -3
  312. package/dist/runtime/components/ui/sheet/SheetContent.d.vue.ts +4 -4
  313. package/dist/runtime/components/ui/sheet/SheetContent.vue +26 -26
  314. package/dist/runtime/components/ui/sheet/SheetContent.vue.d.ts +4 -4
  315. package/dist/runtime/components/ui/sheet/SheetDescription.vue +7 -7
  316. package/dist/runtime/components/ui/sheet/SheetFooter.vue +6 -6
  317. package/dist/runtime/components/ui/sheet/SheetHeader.vue +6 -6
  318. package/dist/runtime/components/ui/sheet/SheetOverlay.vue +7 -7
  319. package/dist/runtime/components/ui/sheet/SheetTitle.vue +7 -7
  320. package/dist/runtime/components/ui/sheet/SheetTrigger.vue +3 -3
  321. package/dist/runtime/components/ui/skeleton/Skeleton.vue +4 -4
  322. package/dist/runtime/components/ui/spinner/Spinner.vue +6 -6
  323. package/dist/runtime/components/ui/table/Table.vue +5 -5
  324. package/dist/runtime/components/ui/table/TableBody.vue +6 -6
  325. package/dist/runtime/components/ui/table/TableCaption.vue +6 -6
  326. package/dist/runtime/components/ui/table/TableCell.vue +6 -6
  327. package/dist/runtime/components/ui/table/TableEmpty.vue +15 -15
  328. package/dist/runtime/components/ui/table/TableFooter.vue +6 -6
  329. package/dist/runtime/components/ui/table/TableHead.vue +6 -6
  330. package/dist/runtime/components/ui/table/TableHeader.vue +6 -6
  331. package/dist/runtime/components/ui/table/TableRow.vue +6 -6
  332. package/dist/runtime/components/ui/tabs/Tabs.vue +8 -8
  333. package/dist/runtime/components/ui/tabs/TabsContent.vue +7 -7
  334. package/dist/runtime/components/ui/tabs/TabsList.vue +7 -7
  335. package/dist/runtime/components/ui/tabs/TabsTrigger.vue +7 -7
  336. package/dist/runtime/components/ui/textarea/Textarea.vue +5 -5
  337. package/dist/runtime/components/ui/tooltip/Tooltip.vue +7 -7
  338. package/dist/runtime/components/ui/tooltip/TooltipContent.vue +13 -13
  339. package/dist/runtime/components/ui/tooltip/TooltipProvider.vue +3 -3
  340. package/dist/runtime/components/ui/tooltip/TooltipTrigger.vue +6 -6
  341. package/dist/runtime/components/video.vue +2 -2
  342. package/dist/runtime/composables/useApi.d.ts +1 -1
  343. package/dist/runtime/composables/useApi.js +6 -77
  344. package/dist/runtime/geo/README.md +87 -87
  345. package/dist/runtime/geo/postal_codes.json +5569 -5569
  346. package/package.json +2 -2
@@ -12,8 +12,8 @@ declare const __VLS_export: import("vue").DefineComponent<__VLS_PublicProps, {},
12
12
  "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
13
13
  onComplete?: ((state: ModalSecureState, data?: any) => any) | undefined;
14
14
  }>, {
15
- phone: string;
16
15
  email: string;
16
+ phone: string;
17
17
  twoFaEnabled: boolean;
18
18
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
19
19
  declare const _default: typeof __VLS_export;
@@ -1,11 +1,11 @@
1
1
  <template>
2
- <component v-for="modal in modals" :key="modal.key" :is="modal.component" :email="props.email" :phone="props.phone"
3
- mode="secure" @complete="(data) => handleComplete(modal.key, data)"
4
- :confirmed-text="isLastStep ? '\u0E22\u0E37\u0E19\u0E22\u0E31\u0E19' : '\u0E16\u0E31\u0E14\u0E44\u0E1B'" @close="isOpen = false" v-model="modalStates[modal.key]"
5
- :request-path="modal.key === 'phoneOTP' ? '/otp/phone-request' : void 0"
6
- :verify-path="modal.key === 'phoneOTP' ? '/otp/phone-verify' : void 0" :reset-token="resetTokenState"
7
- :old-password="oldPasswordState"
8
- :two-fa-code="twoFaCodeState" />
2
+ <component v-for="modal in modals" :key="modal.key" :is="modal.component" :email="props.email" :phone="props.phone"
3
+ mode="secure" @complete="(data) => handleComplete(modal.key, data)"
4
+ :confirmed-text="isLastStep ? '\u0E22\u0E37\u0E19\u0E22\u0E31\u0E19' : '\u0E16\u0E31\u0E14\u0E44\u0E1B'" @close="isOpen = false" v-model="modalStates[modal.key]"
5
+ :request-path="modal.key === 'phoneOTP' ? '/otp/phone-request' : void 0"
6
+ :verify-path="modal.key === 'phoneOTP' ? '/otp/phone-verify' : void 0" :reset-token="resetTokenState"
7
+ :old-password="oldPasswordState"
8
+ :two-fa-code="twoFaCodeState" />
9
9
  </template>
10
10
 
11
11
  <script setup>
@@ -12,8 +12,8 @@ declare const __VLS_export: import("vue").DefineComponent<__VLS_PublicProps, {},
12
12
  "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
13
13
  onComplete?: ((state: ModalSecureState, data?: any) => any) | undefined;
14
14
  }>, {
15
- phone: string;
16
15
  email: string;
16
+ phone: string;
17
17
  twoFaEnabled: boolean;
18
18
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
19
19
  declare const _default: typeof __VLS_export;
@@ -1,24 +1,24 @@
1
1
  <template>
2
- <Modal title="แชร์" class="w-[426px]" v-model="isOpen" :loading="false">
3
- <div class="flex flex-col gap-[16px]">
4
- <Divider />
5
- <div class="flex justify-between">
6
- <div v-for="(share, i) of listShares" :key="i" @click="share.action()"
7
- class="flex flex-col gap-[4px] items-center cursor-pointer w-[73px]">
8
- <Icon :name="share.icon" size="40" />
9
- <div class="font-body-large text-gray">
10
- {{ share.label }}
11
- </div>
12
- </div>
13
- <div class="flex flex-col gap-[4px] items-center cursor-pointer w-[73px]" @click="onCopyLink">
14
- <div class="w-[40px] h-[40px] rounded-full bg-dark text-white flex items-center justify-center">
15
- <Icon name="fa6-solid:link" size="20" />
16
- </div>
17
- <div class="font-body-large text-gray text-nowrap">คัดลอกลิงค์</div>
18
- </div>
19
- </div>
20
- </div>
21
- </Modal>
2
+ <Modal title="แชร์" class="w-[426px]" v-model="isOpen" :loading="false">
3
+ <div class="flex flex-col gap-[16px]">
4
+ <Divider />
5
+ <div class="flex justify-between">
6
+ <div v-for="(share, i) of listShares" :key="i" @click="share.action()"
7
+ class="flex flex-col gap-[4px] items-center cursor-pointer w-[73px]">
8
+ <Icon :name="share.icon" size="40" />
9
+ <div class="font-body-large text-gray">
10
+ {{ share.label }}
11
+ </div>
12
+ </div>
13
+ <div class="flex flex-col gap-[4px] items-center cursor-pointer w-[73px]" @click="onCopyLink">
14
+ <div class="w-[40px] h-[40px] rounded-full bg-dark text-white flex items-center justify-center">
15
+ <Icon name="fa6-solid:link" size="20" />
16
+ </div>
17
+ <div class="font-body-large text-gray text-nowrap">คัดลอกลิงค์</div>
18
+ </div>
19
+ </div>
20
+ </div>
21
+ </Modal>
22
22
  </template>
23
23
 
24
24
  <script setup>
@@ -1,73 +1,73 @@
1
1
  <template>
2
- <Modal
3
- :title="step === 'search' ? '\u0E04\u0E49\u0E19\u0E2B\u0E32\u0E1A\u0E31\u0E0D\u0E0A\u0E35\u0E02\u0E2D\u0E07\u0E04\u0E38\u0E13' : '\u0E40\u0E25\u0E37\u0E2D\u0E01\u0E27\u0E34\u0E18\u0E35\u0E15\u0E23\u0E27\u0E08\u0E2A\u0E2D\u0E1A'"
4
- v-model="modelValue"
5
- width="425px"
6
- :loading="isLoading"
7
- >
8
- <!-- Step 1: phone + recaptcha -->
9
- <div v-if="step === 'search'" class="flex flex-col gap-[24px]">
10
- <p class="font-body-large">
11
- ป้อนเบอร์โทรศัพท์ที่เชื่อมโยงกับบัญชีของคุณ เพื่อเปลี่ยนรหัสผ่าน
12
- </p>
13
- <InputPhone
14
- label="เบอร์โทรศัพท์"
15
- placeholder="กรอกเบอร์โทรศัพท์"
16
- v-model="phone"
17
- />
18
- <InputRecaptcha ref="recaptchaRef" name="recaptcha" v-model="recaptcha" />
19
- </div>
20
-
21
- <!-- Step 2: select OTP method -->
22
- <div v-else-if="step === 'list'" class="flex flex-col">
23
- <template v-for="(item, index) in accountItems" :key="index">
24
- <div class="py-[12px] px-[16px]">
25
- <InputRadio
26
- :item="item.value"
27
- label-position="left"
28
- v-model="selectedMethod"
29
- >
30
- <template v-slot:[`label-${item.value}-text`]>
31
- <div
32
- class="flex flex-col w-full text-gray font-body-medium-prominent"
33
- >
34
- <div v-if="item.type === 'email'">ส่งรหัสไปทางอีเมล</div>
35
- <div v-else-if="item.type === 'phone'">ส่งรหัสไปทาง SMS</div>
36
- <div>{{ item.label }}</div>
37
- </div>
38
- </template>
39
- </InputRadio>
40
- </div>
41
- <Divider v-if="index !== accountItems.length - 1" />
42
- </template>
43
- </div>
44
-
45
- <!-- Footer slot (must be direct child of Modal) -->
46
- <template #footer>
47
- <Button
48
- v-if="step === 'search'"
49
- class="w-full"
50
- color="primary"
51
- :disabled="!phone || !recaptcha || isLoading"
52
- @click="onSearchNext"
53
- >
54
- ถัดไป
55
- </Button>
56
- <div v-else-if="step === 'list'" class="flex flex-col gap-[8px] w-full">
57
- <Button
58
- class="w-full"
59
- color="primary"
60
- :disabled="!selectedMethod"
61
- @click="onListConfirm"
62
- >
63
- {{ props.confirmedText }}
64
- </Button>
65
- <Button variant="text" color="primary" class="w-full" @click="goBack"
66
- >ไม่ใช่คุณใช่ไหม?</Button
67
- >
68
- </div>
69
- </template>
70
- </Modal>
2
+ <Modal
3
+ :title="step === 'search' ? '\u0E04\u0E49\u0E19\u0E2B\u0E32\u0E1A\u0E31\u0E0D\u0E0A\u0E35\u0E02\u0E2D\u0E07\u0E04\u0E38\u0E13' : '\u0E40\u0E25\u0E37\u0E2D\u0E01\u0E27\u0E34\u0E18\u0E35\u0E15\u0E23\u0E27\u0E08\u0E2A\u0E2D\u0E1A'"
4
+ v-model="modelValue"
5
+ width="425px"
6
+ :loading="isLoading"
7
+ >
8
+ <!-- Step 1: phone + recaptcha -->
9
+ <div v-if="step === 'search'" class="flex flex-col gap-[24px]">
10
+ <p class="font-body-large">
11
+ ป้อนเบอร์โทรศัพท์ที่เชื่อมโยงกับบัญชีของคุณ เพื่อเปลี่ยนรหัสผ่าน
12
+ </p>
13
+ <InputPhone
14
+ label="เบอร์โทรศัพท์"
15
+ placeholder="กรอกเบอร์โทรศัพท์"
16
+ v-model="phone"
17
+ />
18
+ <InputRecaptcha ref="recaptchaRef" name="recaptcha" v-model="recaptcha" />
19
+ </div>
20
+
21
+ <!-- Step 2: select OTP method -->
22
+ <div v-else-if="step === 'list'" class="flex flex-col">
23
+ <template v-for="(item, index) in accountItems" :key="index">
24
+ <div class="py-[12px] px-[16px]">
25
+ <InputRadio
26
+ :item="item.value"
27
+ label-position="left"
28
+ v-model="selectedMethod"
29
+ >
30
+ <template v-slot:[`label-${item.value}-text`]>
31
+ <div
32
+ class="flex flex-col w-full text-gray font-body-medium-prominent"
33
+ >
34
+ <div v-if="item.type === 'email'">ส่งรหัสไปทางอีเมล</div>
35
+ <div v-else-if="item.type === 'phone'">ส่งรหัสไปทาง SMS</div>
36
+ <div>{{ item.label }}</div>
37
+ </div>
38
+ </template>
39
+ </InputRadio>
40
+ </div>
41
+ <Divider v-if="index !== accountItems.length - 1" />
42
+ </template>
43
+ </div>
44
+
45
+ <!-- Footer slot (must be direct child of Modal) -->
46
+ <template #footer>
47
+ <Button
48
+ v-if="step === 'search'"
49
+ class="w-full"
50
+ color="primary"
51
+ :disabled="!phone || !recaptcha || isLoading"
52
+ @click="onSearchNext"
53
+ >
54
+ ถัดไป
55
+ </Button>
56
+ <div v-else-if="step === 'list'" class="flex flex-col gap-[8px] w-full">
57
+ <Button
58
+ class="w-full"
59
+ color="primary"
60
+ :disabled="!selectedMethod"
61
+ @click="onListConfirm"
62
+ >
63
+ {{ props.confirmedText }}
64
+ </Button>
65
+ <Button variant="text" color="primary" class="w-full" @click="goBack"
66
+ >ไม่ใช่คุณใช่ไหม?</Button
67
+ >
68
+ </div>
69
+ </template>
70
+ </Modal>
71
71
  </template>
72
72
 
73
73
  <script setup>
@@ -1,33 +1,33 @@
1
1
  <template>
2
- <ShadDialog v-model:open="isOpen">
3
- <ShadDialogContent :class="props.class" :disabled-close-btn="props.disabledCloseBtn"
4
- :no-padding="props.disablePadding" :disable-outside-pointer-events="false" v-slot="{ meta }" @submit="onSubmit"
5
- @close="onClose">
6
- <Loading :loading="props.loading" :text="props.loadingText" />
7
- <ShadDialogHeader :class="props.disablePadding ? 'bg-background' : ''">
8
- <slot name="header">
9
- <ShadDialogTitle>
10
- <slot name="title">
11
- {{ props.title }}
12
- </slot>
13
- </ShadDialogTitle>
14
- <ShadDialogDescription v-if="props.description || $slots.description">
15
- <slot name="description">
16
- {{ props.description }}
17
- </slot>
18
- </ShadDialogDescription>
19
- </slot>
20
- </ShadDialogHeader>
2
+ <ShadDialog v-model:open="isOpen">
3
+ <ShadDialogContent :class="props.class" :disabled-close-btn="props.disabledCloseBtn"
4
+ :no-padding="props.disablePadding" :disable-outside-pointer-events="false" v-slot="{ meta }" @submit="onSubmit"
5
+ @close="onClose">
6
+ <Loading :loading="props.loading" :text="props.loadingText" />
7
+ <ShadDialogHeader :class="props.disablePadding ? 'bg-background' : ''">
8
+ <slot name="header">
9
+ <ShadDialogTitle>
10
+ <slot name="title">
11
+ {{ props.title }}
12
+ </slot>
13
+ </ShadDialogTitle>
14
+ <ShadDialogDescription v-if="props.description || $slots.description">
15
+ <slot name="description">
16
+ {{ props.description }}
17
+ </slot>
18
+ </ShadDialogDescription>
19
+ </slot>
20
+ </ShadDialogHeader>
21
21
  <div :class="props.contentMaxHeight ? '-mx-6 px-6' : void 0" :style="
22
22
  props.contentMaxHeight ? { maxHeight: `${props.contentMaxHeight}px`, overflowY: 'auto' } : void 0
23
- ">
24
- <slot name="default" :meta="meta" />
25
- </div>
26
- <ShadDialogFooter v-if="$slots.footer">
27
- <slot name="footer" :meta="meta" />
28
- </ShadDialogFooter>
29
- </ShadDialogContent>
30
- </ShadDialog>
23
+ ">
24
+ <slot name="default" :meta="meta" />
25
+ </div>
26
+ <ShadDialogFooter v-if="$slots.footer">
27
+ <slot name="footer" :meta="meta" />
28
+ </ShadDialogFooter>
29
+ </ShadDialogContent>
30
+ </ShadDialog>
31
31
  </template>
32
32
 
33
33
  <script setup>
@@ -1,51 +1,51 @@
1
1
  <template>
2
- <ShadPagination
3
- v-slot="{ page }"
4
- :items-per-page="itemPerPage"
5
- :total="totalItems"
6
- :show-edges="true"
7
- v-model:page="pageModel"
8
- >
9
- <ShadPaginationContent v-slot="{ items }">
10
- <ShadPaginationFirst />
11
- <ShadPaginationPrevious />
12
- <template v-for="(item, index) in items" :key="index">
13
- <ShadPaginationItem
14
- v-if="item.type === 'page'"
15
- :value="item.value"
16
- :is-active="item.value === page"
17
- >
18
- {{ item.value }}
19
- </ShadPaginationItem>
20
- <ShadPaginationEllipsis
21
- v-else-if="item.type === 'ellipsis'"
22
- :index="index"
23
- />
24
- </template>
25
- <ShadPaginationNext />
26
- <ShadPaginationLast />
27
-
28
- <ShadDropdownMenu>
29
- <ShadDropdownMenuTrigger>
30
- <Button variant="outline">
31
- <div class="flex gap-2 items-center">
32
- <div>{{ itemPerPage }} / หน้า</div>
33
- <Icon name="lucide:chevron-down" />
34
- </div>
35
- </Button>
36
- </ShadDropdownMenuTrigger>
37
- <ShadDropdownMenuContent class="max-h-96">
38
- <ShadDropdownMenuItem
39
- v-for="n in [10, 50, 100]"
40
- :key="n"
41
- @click="onSlectItemPerPage(n)"
42
- >
43
- {{ n }} / หน้า
44
- </ShadDropdownMenuItem>
45
- </ShadDropdownMenuContent>
46
- </ShadDropdownMenu>
47
- </ShadPaginationContent>
48
- </ShadPagination>
2
+ <ShadPagination
3
+ v-slot="{ page }"
4
+ :items-per-page="itemPerPage"
5
+ :total="totalItems"
6
+ :show-edges="true"
7
+ v-model:page="pageModel"
8
+ >
9
+ <ShadPaginationContent v-slot="{ items }">
10
+ <ShadPaginationFirst />
11
+ <ShadPaginationPrevious />
12
+ <template v-for="(item, index) in items" :key="index">
13
+ <ShadPaginationItem
14
+ v-if="item.type === 'page'"
15
+ :value="item.value"
16
+ :is-active="item.value === page"
17
+ >
18
+ {{ item.value }}
19
+ </ShadPaginationItem>
20
+ <ShadPaginationEllipsis
21
+ v-else-if="item.type === 'ellipsis'"
22
+ :index="index"
23
+ />
24
+ </template>
25
+ <ShadPaginationNext />
26
+ <ShadPaginationLast />
27
+
28
+ <ShadDropdownMenu>
29
+ <ShadDropdownMenuTrigger>
30
+ <Button variant="outline">
31
+ <div class="flex gap-2 items-center">
32
+ <div>{{ itemPerPage }} / หน้า</div>
33
+ <Icon name="lucide:chevron-down" />
34
+ </div>
35
+ </Button>
36
+ </ShadDropdownMenuTrigger>
37
+ <ShadDropdownMenuContent class="max-h-96">
38
+ <ShadDropdownMenuItem
39
+ v-for="n in [10, 50, 100]"
40
+ :key="n"
41
+ @click="onSlectItemPerPage(n)"
42
+ >
43
+ {{ n }} / หน้า
44
+ </ShadDropdownMenuItem>
45
+ </ShadDropdownMenuContent>
46
+ </ShadDropdownMenu>
47
+ </ShadPaginationContent>
48
+ </ShadPagination>
49
49
  </template>
50
50
 
51
51
  <script setup>
@@ -1,84 +1,84 @@
1
1
  <template>
2
- <div class="w-full">
3
- <ShadDropdownMenu>
4
- <ShadDropdownMenuTrigger as-child>
5
- <Button variant="outline" class="bg-white">
6
- <Icon name="lucide:camera" /> แก้ไขรูปภาพหน้าปก
7
- </Button>
8
- </ShadDropdownMenuTrigger>
9
-
10
- <ShadDropdownMenuContent align="start">
11
- <ShadDropdownMenuItem
12
- v-if="hasImage"
13
- class="flex gap-[4px] items-center cursor-pointer"
14
- @click="onEditImage"
15
- >
16
- <Icon name="lucide:crop" :size="16" />
17
- <span class="font-body-medium">จัดตำแหน่ง</span>
18
- </ShadDropdownMenuItem>
19
- <ShadDropdownMenuItem
20
- class="flex gap-[4px] items-center cursor-pointer"
21
- @click="onUploadImage"
22
- >
23
- <Icon name="lucide:upload" :size="16" />
24
- <span class="font-body-medium">อัปโหลดรูปภาพ</span>
25
- </ShadDropdownMenuItem>
26
- </ShadDropdownMenuContent>
27
- </ShadDropdownMenu>
28
- <input
29
- ref="fileInputRef"
30
- type="file"
31
- accept="image/*"
32
- class="hidden"
33
- @change="onFileChange"
34
- />
35
- <Modal
36
- title="ปรับแต่งรูปภาพหน้าปก"
37
- class="w-[512px]"
38
- v-model="isOpenModal"
39
- @close="onCancel"
40
- >
41
- <div
42
- ref="containerRef"
43
- class="relative w-full h-[261px] overflow-hidden select-none cursor-move group"
44
- @mousedown="startDrag"
45
- @touchstart="startDrag"
46
- >
47
- <img
48
- v-if="imageUrl"
49
- :src="imageUrl"
50
- class="absolute inset-0 w-full h-full object-cover pointer-events-none"
51
- :style="{ objectPosition: `${posX}% ${posY}%` }"
52
- @load="onImageLoad"
53
- alt="Cover Preview"
54
- draggable="false"
55
- />
56
-
57
- <div
58
- class="absolute top-1/2 left-1/2 transform -translate-x-1/2 -translate-y-1/2 pointer-events-none transition-opacity"
59
- :class="{ 'opacity-0': isDragging, 'opacity-100': !isDragging }"
60
- >
61
- <div
62
- class="flex items-center gap-[8px] px-[8px] py-[6px] rounded-[8px] bg-black/50"
63
- >
64
- <Icon name="lucide:move" class="text-white" :size="16" />
65
- <span class="text-white font-body-medium">ลากเพื่อจัดตำแหน่ง</span>
66
- </div>
67
- </div>
68
- </div>
69
-
70
- <template #footer>
71
- <div class="flex items-center gap-[16px] w-full">
72
- <Button variant="outline" class="w-full" @click="onCancel">
73
- ยกเลิก
74
- </Button>
75
- <Button color="primary" class="w-full" @click="onSave">
76
- บันทึก
77
- </Button>
78
- </div>
79
- </template>
80
- </Modal>
81
- </div>
2
+ <div class="w-full">
3
+ <ShadDropdownMenu>
4
+ <ShadDropdownMenuTrigger as-child>
5
+ <Button variant="outline" class="bg-white">
6
+ <Icon name="lucide:camera" /> แก้ไขรูปภาพหน้าปก
7
+ </Button>
8
+ </ShadDropdownMenuTrigger>
9
+
10
+ <ShadDropdownMenuContent align="start">
11
+ <ShadDropdownMenuItem
12
+ v-if="hasImage"
13
+ class="flex gap-[4px] items-center cursor-pointer"
14
+ @click="onEditImage"
15
+ >
16
+ <Icon name="lucide:crop" :size="16" />
17
+ <span class="font-body-medium">จัดตำแหน่ง</span>
18
+ </ShadDropdownMenuItem>
19
+ <ShadDropdownMenuItem
20
+ class="flex gap-[4px] items-center cursor-pointer"
21
+ @click="onUploadImage"
22
+ >
23
+ <Icon name="lucide:upload" :size="16" />
24
+ <span class="font-body-medium">อัปโหลดรูปภาพ</span>
25
+ </ShadDropdownMenuItem>
26
+ </ShadDropdownMenuContent>
27
+ </ShadDropdownMenu>
28
+ <input
29
+ ref="fileInputRef"
30
+ type="file"
31
+ accept="image/*"
32
+ class="hidden"
33
+ @change="onFileChange"
34
+ />
35
+ <Modal
36
+ title="ปรับแต่งรูปภาพหน้าปก"
37
+ class="w-[512px]"
38
+ v-model="isOpenModal"
39
+ @close="onCancel"
40
+ >
41
+ <div
42
+ ref="containerRef"
43
+ class="relative w-full h-[261px] overflow-hidden select-none cursor-move group"
44
+ @mousedown="startDrag"
45
+ @touchstart="startDrag"
46
+ >
47
+ <img
48
+ v-if="imageUrl"
49
+ :src="imageUrl"
50
+ class="absolute inset-0 w-full h-full object-cover pointer-events-none"
51
+ :style="{ objectPosition: `${posX}% ${posY}%` }"
52
+ @load="onImageLoad"
53
+ alt="Cover Preview"
54
+ draggable="false"
55
+ />
56
+
57
+ <div
58
+ class="absolute top-1/2 left-1/2 transform -translate-x-1/2 -translate-y-1/2 pointer-events-none transition-opacity"
59
+ :class="{ 'opacity-0': isDragging, 'opacity-100': !isDragging }"
60
+ >
61
+ <div
62
+ class="flex items-center gap-[8px] px-[8px] py-[6px] rounded-[8px] bg-black/50"
63
+ >
64
+ <Icon name="lucide:move" class="text-white" :size="16" />
65
+ <span class="text-white font-body-medium">ลากเพื่อจัดตำแหน่ง</span>
66
+ </div>
67
+ </div>
68
+ </div>
69
+
70
+ <template #footer>
71
+ <div class="flex items-center gap-[16px] w-full">
72
+ <Button variant="outline" class="w-full" @click="onCancel">
73
+ ยกเลิก
74
+ </Button>
75
+ <Button color="primary" class="w-full" @click="onSave">
76
+ บันทึก
77
+ </Button>
78
+ </div>
79
+ </template>
80
+ </Modal>
81
+ </div>
82
82
  </template>
83
83
 
84
84
  <script setup>