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,124 +1,124 @@
1
1
  <template>
2
- <Modal
3
- v-model="modelValue"
4
- :title="props.title"
5
- :width="1280"
6
- divider
7
- @close="onClosed"
8
- >
9
- <Carousel
10
- :items="props.items"
11
- :select-index="currentIndex"
12
- @clicked-image="switcComment = false"
13
- :width="1280"
14
- :height="768"
15
- >
16
- <Card v-if="switcComment" full-width>
17
- <div class="flex gap-[16px] max-h-[318px]">
18
- <div>
19
- <!-- <Avatar :src="props.review.user?.avatar" :name="props.review.user?.name" /> -->
20
- </div>
21
- <div class="flex flex-col gap-[8px] w-full">
22
- <div class="flex flex-col gap-[2px]">
23
- <div class="flex justify-between items-center">
24
- <div class="font-body-large">{{ props.review.user?.name }}</div>
25
- <div class="flex gap-[8px] items-center">
26
- <Button
27
- type="text"
28
- :variant="liked ? 'primary' : 'black'"
29
- :icon-size="20"
30
- size="tiny"
2
+ <Modal
3
+ v-model="modelValue"
4
+ :title="props.title"
5
+ :width="1280"
6
+ divider
7
+ @close="onClosed"
8
+ >
9
+ <Carousel
10
+ :items="props.items"
11
+ :select-index="currentIndex"
12
+ @clicked-image="switcComment = false"
13
+ :width="1280"
14
+ :height="768"
15
+ >
16
+ <Card v-if="switcComment" full-width>
17
+ <div class="flex gap-[16px] max-h-[318px]">
18
+ <div>
19
+ <!-- <Avatar :src="props.review.user?.avatar" :name="props.review.user?.name" /> -->
20
+ </div>
21
+ <div class="flex flex-col gap-[8px] w-full">
22
+ <div class="flex flex-col gap-[2px]">
23
+ <div class="flex justify-between items-center">
24
+ <div class="font-body-large">{{ props.review.user?.name }}</div>
25
+ <div class="flex gap-[8px] items-center">
26
+ <Button
27
+ type="text"
28
+ :variant="liked ? 'primary' : 'black'"
29
+ :icon-size="20"
30
+ size="tiny"
31
31
  :prepend-icon="
32
32
  liked ? 'pukaad:thumbs-up-solid' : 'pukaad:thumbs-up-regular'
33
- "
34
- :aria-pressed="liked"
35
- @click="toggleLike"
36
- disabled-padding
37
- >
38
- <div>
39
- {{ likeCount }}
40
- </div>
41
- </Button>
42
- <PickerOptionMenuUser :state="menuType" disabled-padding />
43
- </div>
44
- </div>
45
- <div class="flex flex-col gap-[6px]">
46
- <div class="font-body-small">
47
- {{ props.review.user?.review_count }} รีวิว •
48
- {{ props.review.user?.like_count }} ชื่นชอบรีวิว
49
- </div>
50
- <div class="flex gap-[8px] items-center">
51
- <InputRating
52
- :size="16"
53
- readonly
54
- :model-value="props.review.review?.rating"
55
- />
56
- <div class="font-body-small">
57
- {{ props.review.review?.created_at }}
58
- </div>
59
- </div>
60
- </div>
61
- </div>
62
- <div
63
- v-if="props.review.review?.description"
64
- class="font-body-large max-h-[208px] overflow-y-auto"
65
- >
66
- {{ props.review.review?.description }}
67
- </div>
68
- </div>
69
- </div>
70
- </Card>
71
- <div
72
- v-else
73
- class="w-full bg-gradient-to-b from-transparent to-black/70 p-[16px] text-white flex gap-[16px]"
74
- >
75
- <div>
76
- <!-- <Avatar
77
- :src="props.review.user?.avatar"
78
- :name="props.review.user?.name"
79
- /> -->
80
- </div>
81
- <div class="flex flex-col gap-[8px] w-full">
82
- <div class="flex flex-col gap-[2px]">
83
- <div class="flex justify-between items-center">
84
- <div class="font-body-large">{{ props.review.user?.name }}</div>
85
- <div class="flex gap-[8px] items-center">
86
- <Button variant="text" disabled-padding @click="toggleComment">
87
- <Icon
88
- name="lucide:message-square-warning"
89
- :size="20"
90
- color="white"
91
- />
92
- </Button>
93
- </div>
94
- </div>
95
- <div class="flex flex-col gap-[6px]">
96
- <div class="font-body-small">
97
- {{ props.review.user?.review_count }} รีวิว •
98
- {{ props.review.user?.like_count }} ชื่นชอบรีวิว
99
- </div>
100
- <div class="flex gap-[8px] items-center">
101
- <InputRating
102
- :size="16"
103
- readonly
104
- :model-value="props.review.review?.rating"
105
- />
106
- <div class="font-body-small">
107
- {{ props.review.review?.created_at }}
108
- </div>
109
- </div>
110
- </div>
111
- </div>
112
- <div
113
- v-if="props.review.review?.description"
114
- class="font-body-large line-clamp-1"
115
- >
116
- {{ props.review.review?.description }}
117
- </div>
118
- </div>
119
- </div>
120
- </Carousel>
121
- </Modal>
33
+ "
34
+ :aria-pressed="liked"
35
+ @click="toggleLike"
36
+ disabled-padding
37
+ >
38
+ <div>
39
+ {{ likeCount }}
40
+ </div>
41
+ </Button>
42
+ <PickerOptionMenuUser :state="menuType" disabled-padding />
43
+ </div>
44
+ </div>
45
+ <div class="flex flex-col gap-[6px]">
46
+ <div class="font-body-small">
47
+ {{ props.review.user?.review_count }} รีวิว •
48
+ {{ props.review.user?.like_count }} ชื่นชอบรีวิว
49
+ </div>
50
+ <div class="flex gap-[8px] items-center">
51
+ <InputRating
52
+ :size="16"
53
+ readonly
54
+ :model-value="props.review.review?.rating"
55
+ />
56
+ <div class="font-body-small">
57
+ {{ props.review.review?.created_at }}
58
+ </div>
59
+ </div>
60
+ </div>
61
+ </div>
62
+ <div
63
+ v-if="props.review.review?.description"
64
+ class="font-body-large max-h-[208px] overflow-y-auto"
65
+ >
66
+ {{ props.review.review?.description }}
67
+ </div>
68
+ </div>
69
+ </div>
70
+ </Card>
71
+ <div
72
+ v-else
73
+ class="w-full bg-gradient-to-b from-transparent to-black/70 p-[16px] text-white flex gap-[16px]"
74
+ >
75
+ <div>
76
+ <!-- <Avatar
77
+ :src="props.review.user?.avatar"
78
+ :name="props.review.user?.name"
79
+ /> -->
80
+ </div>
81
+ <div class="flex flex-col gap-[8px] w-full">
82
+ <div class="flex flex-col gap-[2px]">
83
+ <div class="flex justify-between items-center">
84
+ <div class="font-body-large">{{ props.review.user?.name }}</div>
85
+ <div class="flex gap-[8px] items-center">
86
+ <Button variant="text" disabled-padding @click="toggleComment">
87
+ <Icon
88
+ name="lucide:message-square-warning"
89
+ :size="20"
90
+ color="white"
91
+ />
92
+ </Button>
93
+ </div>
94
+ </div>
95
+ <div class="flex flex-col gap-[6px]">
96
+ <div class="font-body-small">
97
+ {{ props.review.user?.review_count }} รีวิว •
98
+ {{ props.review.user?.like_count }} ชื่นชอบรีวิว
99
+ </div>
100
+ <div class="flex gap-[8px] items-center">
101
+ <InputRating
102
+ :size="16"
103
+ readonly
104
+ :model-value="props.review.review?.rating"
105
+ />
106
+ <div class="font-body-small">
107
+ {{ props.review.review?.created_at }}
108
+ </div>
109
+ </div>
110
+ </div>
111
+ </div>
112
+ <div
113
+ v-if="props.review.review?.description"
114
+ class="font-body-large line-clamp-1"
115
+ >
116
+ {{ props.review.review?.description }}
117
+ </div>
118
+ </div>
119
+ </div>
120
+ </Carousel>
121
+ </Modal>
122
122
  </template>
123
123
 
124
124
  <script setup>
@@ -1,14 +1,14 @@
1
1
  <template>
2
- <component
3
- v-for="modal in modals"
4
- :key="modal.key"
5
- :is="modal.component"
6
- :email="props.email"
7
- @complete="handleComplete(modal.key)"
8
- :confirmed-text="isLastStep ? '\u0E22\u0E37\u0E19\u0E22\u0E31\u0E19' : '\u0E16\u0E31\u0E14\u0E44\u0E1B'"
9
- @close="isOpen = false"
10
- v-model="modalStates[modal.key]"
11
- />
2
+ <component
3
+ v-for="modal in modals"
4
+ :key="modal.key"
5
+ :is="modal.component"
6
+ :email="props.email"
7
+ @complete="handleComplete(modal.key)"
8
+ :confirmed-text="isLastStep ? '\u0E22\u0E37\u0E19\u0E22\u0E31\u0E19' : '\u0E16\u0E31\u0E14\u0E44\u0E1B'"
9
+ @close="isOpen = false"
10
+ v-model="modalStates[modal.key]"
11
+ />
12
12
  </template>
13
13
 
14
14
  <script setup>
@@ -1,28 +1,28 @@
1
1
  <template>
2
- <Modal title="แชร์" width="396" v-model="isOpen">
3
- <div class="flex justify-between">
4
- <div
5
- v-for="(share, i) of listShares"
6
- :key="i"
7
- @click="share.action()"
8
- class="flex flex-col gap-[4px] items-center cursor-pointer w-[73px]"
9
- >
10
- <Icon :name="share.icon" size="40" />
11
- <div class="font-body-large text-gray">
12
- {{ share.label }}
13
- </div>
14
- </div>
15
- <div
16
- class="flex flex-col gap-[4px] items-center cursor-pointer w-[73px]"
17
- @click="onCopyLink"
18
- >
19
- <ShadAvatar size="40">
20
- <Icon name="fa6-solid:link" size="40" />
21
- </ShadAvatar>
22
- <div class="font-body-large text-gray text-nowrap">คัดลอกลิงค์</div>
23
- </div>
24
- </div>
25
- </Modal>
2
+ <Modal title="แชร์" width="396" v-model="isOpen">
3
+ <div class="flex justify-between">
4
+ <div
5
+ v-for="(share, i) of listShares"
6
+ :key="i"
7
+ @click="share.action()"
8
+ class="flex flex-col gap-[4px] items-center cursor-pointer w-[73px]"
9
+ >
10
+ <Icon :name="share.icon" size="40" />
11
+ <div class="font-body-large text-gray">
12
+ {{ share.label }}
13
+ </div>
14
+ </div>
15
+ <div
16
+ class="flex flex-col gap-[4px] items-center cursor-pointer w-[73px]"
17
+ @click="onCopyLink"
18
+ >
19
+ <ShadAvatar size="40">
20
+ <Icon name="fa6-solid:link" size="40" />
21
+ </ShadAvatar>
22
+ <div class="font-body-large text-gray text-nowrap">คัดลอกลิงค์</div>
23
+ </div>
24
+ </div>
25
+ </Modal>
26
26
  </template>
27
27
 
28
28
  <script setup>
@@ -1,33 +1,33 @@
1
1
  <template>
2
- <Modal title="เลือกวิธีตรวจสอบ" v-model="modelValue">
3
- <template v-for="(item, index) in props.items" :key="index">
4
- <div class="py-[12px] px-[16px]">
5
- <InputRadio :item="item.value" label-position="left" v-model="selected">
6
- <template v-slot:[`label-${item.value}-text`]>
7
- <div
8
- class="flex flex-col w-full text-gray font-body-medium-prominent"
9
- >
10
- <div v-if="item.type === 'email'">ส่งรหัสไปทางอีเมล</div>
11
- <div v-else-if="item.type === 'phone'">ส่งรหัสไปทาง SMS</div>
12
- <div>{{ item.label }}</div>
13
- </div>
14
- </template>
15
- </InputRadio>
16
- </div>
17
- <Divider v-if="index !== props.items.length - 1" />
18
- </template>
19
-
20
- <template #footer>
21
- <Button
22
- color="primary"
23
- full-width
24
- @click="onConfirm"
25
- :disabled="!selected"
26
- >
27
- ยืนยัน
28
- </Button>
29
- </template>
30
- </Modal>
2
+ <Modal title="เลือกวิธีตรวจสอบ" v-model="modelValue">
3
+ <template v-for="(item, index) in props.items" :key="index">
4
+ <div class="py-[12px] px-[16px]">
5
+ <InputRadio :item="item.value" label-position="left" v-model="selected">
6
+ <template v-slot:[`label-${item.value}-text`]>
7
+ <div
8
+ class="flex flex-col w-full text-gray font-body-medium-prominent"
9
+ >
10
+ <div v-if="item.type === 'email'">ส่งรหัสไปทางอีเมล</div>
11
+ <div v-else-if="item.type === 'phone'">ส่งรหัสไปทาง SMS</div>
12
+ <div>{{ item.label }}</div>
13
+ </div>
14
+ </template>
15
+ </InputRadio>
16
+ </div>
17
+ <Divider v-if="index !== props.items.length - 1" />
18
+ </template>
19
+
20
+ <template #footer>
21
+ <Button
22
+ color="primary"
23
+ full-width
24
+ @click="onConfirm"
25
+ :disabled="!selected"
26
+ >
27
+ ยืนยัน
28
+ </Button>
29
+ </template>
30
+ </Modal>
31
31
  </template>
32
32
 
33
33
  <script setup>
@@ -1,28 +1,28 @@
1
1
  <template>
2
- <Modal title="ค้นหาบัญชีของคุณ" v-model="modelValue">
3
- <div class="flex flex-col gap-[16px]">
4
- <div class="font-body-large text-2xl text-center px-[50px]">
5
- ป้อนเบอร์โทรศัพท์ที่เชื่อมโยงกับบัญชีของคุณ เพื่อเปลี่ยนรหัสผ่าน
6
- </div>
7
- <InputPhone
8
- label="เบอร์โทรศัพท์"
9
- placeholder="กรอกเบอร์โทรศัพท์"
10
- v-model="phone"
11
- full-width
12
- />
13
- <InputRecaptcha ref="recaptchaRef" name="recaptcha" v-model="recaptcha" />
14
- </div>
15
- <template #footer>
16
- <Button
17
- full-width
18
- variant="primary"
19
- :disabled="!phone || !recaptcha"
20
- @click="onNext"
21
- >
22
- {{ props.confirmedText }}
23
- </Button>
24
- </template>
25
- </Modal>
2
+ <Modal title="ค้นหาบัญชีของคุณ" v-model="modelValue">
3
+ <div class="flex flex-col gap-[16px]">
4
+ <div class="font-body-large text-2xl text-center px-[50px]">
5
+ ป้อนเบอร์โทรศัพท์ที่เชื่อมโยงกับบัญชีของคุณ เพื่อเปลี่ยนรหัสผ่าน
6
+ </div>
7
+ <InputPhone
8
+ label="เบอร์โทรศัพท์"
9
+ placeholder="กรอกเบอร์โทรศัพท์"
10
+ v-model="phone"
11
+ full-width
12
+ />
13
+ <InputRecaptcha ref="recaptchaRef" name="recaptcha" v-model="recaptcha" />
14
+ </div>
15
+ <template #footer>
16
+ <Button
17
+ full-width
18
+ variant="primary"
19
+ :disabled="!phone || !recaptcha"
20
+ @click="onNext"
21
+ >
22
+ {{ props.confirmedText }}
23
+ </Button>
24
+ </template>
25
+ </Modal>
26
26
  </template>
27
27
 
28
28
  <script setup>
@@ -1,31 +1,31 @@
1
1
  <template>
2
- <ShadDialog v-model:open="isOpen">
3
- <ShadDialogContent
4
- :class="props.class"
5
- :disabled-close-btn="props.disabledCloseBtn"
6
- v-slot="{ meta }"
7
- @submit="onSubmit"
8
- >
9
- <ShadDialogHeader>
10
- <slot name="header">
11
- <ShadDialogTitle>
12
- <slot name="title">
13
- {{ props.title }}
14
- </slot>
15
- </ShadDialogTitle>
16
- <ShadDialogDescription>
17
- <slot name="description">
18
- {{ props.description }}
19
- </slot>
20
- </ShadDialogDescription>
21
- </slot>
22
- </ShadDialogHeader>
23
- <slot name="default" :meta="meta" />
24
- <ShadDialogFooter>
25
- <slot name="footer" :meta="meta" />
26
- </ShadDialogFooter>
27
- </ShadDialogContent>
28
- </ShadDialog>
2
+ <ShadDialog v-model:open="isOpen">
3
+ <ShadDialogContent
4
+ :class="props.class"
5
+ :disabled-close-btn="props.disabledCloseBtn"
6
+ v-slot="{ meta }"
7
+ @submit="onSubmit"
8
+ >
9
+ <ShadDialogHeader>
10
+ <slot name="header">
11
+ <ShadDialogTitle>
12
+ <slot name="title">
13
+ {{ props.title }}
14
+ </slot>
15
+ </ShadDialogTitle>
16
+ <ShadDialogDescription>
17
+ <slot name="description">
18
+ {{ props.description }}
19
+ </slot>
20
+ </ShadDialogDescription>
21
+ </slot>
22
+ </ShadDialogHeader>
23
+ <slot name="default" :meta="meta" />
24
+ <ShadDialogFooter>
25
+ <slot name="footer" :meta="meta" />
26
+ </ShadDialogFooter>
27
+ </ShadDialogContent>
28
+ </ShadDialog>
29
29
  </template>
30
30
 
31
31
  <script setup>
@@ -1,47 +1,47 @@
1
1
  <template>
2
- <ShadPagination
3
- v-slot="{ page }"
4
- :items-per-page="itemPerPage"
5
- :total="props.totalPage"
6
- v-model:page="pageModel"
7
- >
8
- <ShadPaginationContent v-slot="{ items }">
9
- <ShadPaginationFirst />
10
- <ShadPaginationPrevious />
11
- <template v-for="(item, index) in items" :key="index">
12
- <ShadPaginationItem
13
- v-if="item.type === 'page'"
14
- :value="item.value"
15
- :is-active="item.value === page"
16
- >
17
- {{ item.value }}
18
- </ShadPaginationItem>
19
- </template>
20
- <ShadPaginationEllipsis />
21
- <ShadPaginationNext />
22
- <ShadPaginationLast />
23
-
24
- <ShadDropdownMenu>
25
- <ShadDropdownMenuTrigger>
26
- <Button variant="outline">
27
- <div class="flex gap-2 items-center">
28
- <div>{{ itemPerPage }} / หน้า</div>
29
- <Icon name="lucide:chevron-down" />
30
- </div>
31
- </Button>
32
- </ShadDropdownMenuTrigger>
33
- <ShadDropdownMenuContent class="max-h-96">
34
- <ShadDropdownMenuItem
35
- v-for="n in [10, 50, 100]"
36
- :key="n"
37
- @click="onSlectItemPerPage(n)"
38
- >
39
- {{ n }} / หน้า
40
- </ShadDropdownMenuItem>
41
- </ShadDropdownMenuContent>
42
- </ShadDropdownMenu>
43
- </ShadPaginationContent>
44
- </ShadPagination>
2
+ <ShadPagination
3
+ v-slot="{ page }"
4
+ :items-per-page="itemPerPage"
5
+ :total="props.totalPage"
6
+ v-model:page="pageModel"
7
+ >
8
+ <ShadPaginationContent v-slot="{ items }">
9
+ <ShadPaginationFirst />
10
+ <ShadPaginationPrevious />
11
+ <template v-for="(item, index) in items" :key="index">
12
+ <ShadPaginationItem
13
+ v-if="item.type === 'page'"
14
+ :value="item.value"
15
+ :is-active="item.value === page"
16
+ >
17
+ {{ item.value }}
18
+ </ShadPaginationItem>
19
+ </template>
20
+ <ShadPaginationEllipsis />
21
+ <ShadPaginationNext />
22
+ <ShadPaginationLast />
23
+
24
+ <ShadDropdownMenu>
25
+ <ShadDropdownMenuTrigger>
26
+ <Button variant="outline">
27
+ <div class="flex gap-2 items-center">
28
+ <div>{{ itemPerPage }} / หน้า</div>
29
+ <Icon name="lucide:chevron-down" />
30
+ </div>
31
+ </Button>
32
+ </ShadDropdownMenuTrigger>
33
+ <ShadDropdownMenuContent class="max-h-96">
34
+ <ShadDropdownMenuItem
35
+ v-for="n in [10, 50, 100]"
36
+ :key="n"
37
+ @click="onSlectItemPerPage(n)"
38
+ >
39
+ {{ n }} / หน้า
40
+ </ShadDropdownMenuItem>
41
+ </ShadDropdownMenuContent>
42
+ </ShadDropdownMenu>
43
+ </ShadPaginationContent>
44
+ </ShadPagination>
45
45
  </template>
46
46
 
47
47
  <script setup>