pukaad-ui-lib 1.271.2 → 1.272.0

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 (321) 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/{instagram.svg → Instagram.svg} +14 -14
  24. package/dist/runtime/assets/svg/socials/Line.svg +11 -11
  25. package/dist/runtime/assets/svg/socials/LinkedIn.svg +5 -5
  26. package/dist/runtime/assets/svg/socials/Pinterest.svg +4 -4
  27. package/dist/runtime/assets/svg/socials/SnapChat.svg +5 -5
  28. package/dist/runtime/assets/svg/socials/Threads.svg +12 -12
  29. package/dist/runtime/assets/svg/socials/{Tiktok.svg → TikTok.svg} +6 -6
  30. package/dist/runtime/assets/svg/socials/Tumblr.svg +4 -4
  31. package/dist/runtime/assets/svg/socials/Website.svg +11 -11
  32. package/dist/runtime/assets/svg/socials/Whatsapp.svg +5 -5
  33. package/dist/runtime/assets/svg/socials/X.svg +4 -4
  34. package/dist/runtime/assets/svg/socials/{Youtube.svg → YouTube.svg} +5 -5
  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 +104 -102
  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.vue +94 -94
  50. package/dist/runtime/components/card/card-reaction.vue +23 -23
  51. package/dist/runtime/components/card/card-recommend-blog.vue +42 -42
  52. package/dist/runtime/components/card/card-recommend-place.vue +45 -45
  53. package/dist/runtime/components/card/card-recommend-profile.vue +46 -46
  54. package/dist/runtime/components/card/card-review.vue +57 -57
  55. package/dist/runtime/components/card/card-user-blog.vue +76 -76
  56. package/dist/runtime/components/card/card-user-item.vue +24 -24
  57. package/dist/runtime/components/card/card.vue +29 -29
  58. package/dist/runtime/components/carousel.vue +31 -31
  59. package/dist/runtime/components/chip.vue +10 -10
  60. package/dist/runtime/components/collapse/collapse-multiple.vue +42 -42
  61. package/dist/runtime/components/collapse/collapse.vue +23 -23
  62. package/dist/runtime/components/comment.vue +204 -204
  63. package/dist/runtime/components/data-list.vue +49 -49
  64. package/dist/runtime/components/data-table.vue +131 -131
  65. package/dist/runtime/components/display/display-image-place.vue +88 -88
  66. package/dist/runtime/components/display/display-image-review.vue +10 -10
  67. package/dist/runtime/components/display/display-image.vue +49 -49
  68. package/dist/runtime/components/display/display-rating-summary.vue +34 -34
  69. package/dist/runtime/components/divider.vue +8 -8
  70. package/dist/runtime/components/draggable.vue +15 -15
  71. package/dist/runtime/components/drawer/drawer-post-blog.vue +70 -70
  72. package/dist/runtime/components/drawer/drawer-post-review.vue +67 -67
  73. package/dist/runtime/components/drawer/drawer-profile-about.vue +52 -52
  74. package/dist/runtime/components/drawer/drawer-profile-network.vue +136 -136
  75. package/dist/runtime/components/drawer/drawer-suggest-place/drawer-suggest-place.vue +92 -92
  76. package/dist/runtime/components/drawer/drawer-suggest-place/suggest-place-form.vue +70 -70
  77. package/dist/runtime/components/drawer/drawer-suggest-place/suggest-place-map.vue +5 -5
  78. package/dist/runtime/components/drawer/drawer.vue +24 -24
  79. package/dist/runtime/components/dropdown.vue +8 -8
  80. package/dist/runtime/components/filter/filter-list-chip.vue +10 -10
  81. package/dist/runtime/components/filter/filter-list.vue +17 -17
  82. package/dist/runtime/components/icons.vue +1 -1
  83. package/dist/runtime/components/image/image-cropper.vue +9 -9
  84. package/dist/runtime/components/image/image.vue +27 -27
  85. package/dist/runtime/components/input/input-OTP.vue +27 -27
  86. package/dist/runtime/components/input/input-address.vue +147 -147
  87. package/dist/runtime/components/input/input-autocomplete.vue +80 -80
  88. package/dist/runtime/components/input/input-birth-date.vue +20 -20
  89. package/dist/runtime/components/input/input-checkbox.vue +17 -17
  90. package/dist/runtime/components/input/input-combobox.vue +100 -100
  91. package/dist/runtime/components/input/input-comment.vue +6 -6
  92. package/dist/runtime/components/input/input-content.vue +32 -32
  93. package/dist/runtime/components/input/input-date-opening.vue +96 -96
  94. package/dist/runtime/components/input/input-date-picker.vue +102 -102
  95. package/dist/runtime/components/input/input-email.vue +9 -9
  96. package/dist/runtime/components/input/input-file.vue +125 -125
  97. package/dist/runtime/components/input/input-link.vue +35 -35
  98. package/dist/runtime/components/input/input-media.vue +36 -36
  99. package/dist/runtime/components/input/input-password.vue +43 -43
  100. package/dist/runtime/components/input/input-phone.vue +11 -11
  101. package/dist/runtime/components/input/input-profile-name.vue +10 -10
  102. package/dist/runtime/components/input/input-radio.vue +55 -55
  103. package/dist/runtime/components/input/input-rating.vue +13 -13
  104. package/dist/runtime/components/input/input-recaptcha.vue +19 -19
  105. package/dist/runtime/components/input/input-search.vue +71 -71
  106. package/dist/runtime/components/input/input-select-province.vue +94 -94
  107. package/dist/runtime/components/input/input-select-tag.vue +51 -51
  108. package/dist/runtime/components/input/input-select.vue +52 -52
  109. package/dist/runtime/components/input/input-slider.vue +19 -19
  110. package/dist/runtime/components/input/input-switch.vue +25 -25
  111. package/dist/runtime/components/input/input-tag.vue +145 -145
  112. package/dist/runtime/components/input/input-text-field.vue +90 -90
  113. package/dist/runtime/components/input/input-textarea.vue +58 -58
  114. package/dist/runtime/components/label/label-announce-time.vue +9 -9
  115. package/dist/runtime/components/label/label-card-atom.vue +8 -8
  116. package/dist/runtime/components/list/list-menu.vue +13 -13
  117. package/dist/runtime/components/loading.vue +8 -8
  118. package/dist/runtime/components/modal/modal-2FA-generate.vue +48 -48
  119. package/dist/runtime/components/modal/modal-2FA.vue +28 -28
  120. package/dist/runtime/components/modal/modal-account-disabled-alert.vue +33 -33
  121. package/dist/runtime/components/modal/modal-account-disabled-confirmed.vue +32 -32
  122. package/dist/runtime/components/modal/modal-account-disabled-reason.vue +45 -45
  123. package/dist/runtime/components/modal/modal-account-disabled.vue +9 -9
  124. package/dist/runtime/components/modal/modal-display-image.vue +38 -38
  125. package/dist/runtime/components/modal/modal-email-OTP.vue +32 -32
  126. package/dist/runtime/components/modal/modal-forgot-password.vue +9 -9
  127. package/dist/runtime/components/modal/modal-media-view.vue +12 -12
  128. package/dist/runtime/components/modal/modal-password-confirmed.vue +30 -30
  129. package/dist/runtime/components/modal/modal-password-new.vue +34 -34
  130. package/dist/runtime/components/modal/modal-password-verify.vue +13 -13
  131. package/dist/runtime/components/modal/modal-personal-card-ID.vue +167 -167
  132. package/dist/runtime/components/modal/modal-phone-OTP.vue +49 -49
  133. package/dist/runtime/components/modal/modal-profile-edit.vue +71 -69
  134. package/dist/runtime/components/modal/modal-province-domain.vue +23 -23
  135. package/dist/runtime/components/modal/modal-report.vue +47 -47
  136. package/dist/runtime/components/modal/modal-review-detail.vue +118 -118
  137. package/dist/runtime/components/modal/modal-secure.vue +6 -6
  138. package/dist/runtime/components/modal/modal-share.vue +20 -20
  139. package/dist/runtime/components/modal/modal-user-account-search.vue +69 -69
  140. package/dist/runtime/components/modal/modal.vue +27 -27
  141. package/dist/runtime/components/pagination.vue +47 -47
  142. package/dist/runtime/components/picker/picker-image-cover-profile.vue +80 -80
  143. package/dist/runtime/components/picker/picker-image-profile.vue +102 -102
  144. package/dist/runtime/components/picker/picker-option-menu/picker-option-menu-user.d.vue.ts +2 -2
  145. package/dist/runtime/components/picker/picker-option-menu/picker-option-menu-user.vue +18 -18
  146. package/dist/runtime/components/picker/picker-option-menu/picker-option-menu-user.vue.d.ts +2 -2
  147. package/dist/runtime/components/picker/picker-option-menu/picker-option-menu.vue +26 -26
  148. package/dist/runtime/components/profile-cover.vue +80 -80
  149. package/dist/runtime/components/progress-bar.vue +9 -9
  150. package/dist/runtime/components/read-more-text.vue +1 -1
  151. package/dist/runtime/components/tab_old.vue +78 -78
  152. package/dist/runtime/components/table.vue +79 -79
  153. package/dist/runtime/components/tooltip.vue +12 -12
  154. package/dist/runtime/components/ui/accordion/Accordion.vue +3 -3
  155. package/dist/runtime/components/ui/accordion/AccordionContent.vue +9 -9
  156. package/dist/runtime/components/ui/accordion/AccordionItem.vue +8 -8
  157. package/dist/runtime/components/ui/accordion/AccordionTrigger.vue +16 -16
  158. package/dist/runtime/components/ui/alert/Alert.vue +7 -7
  159. package/dist/runtime/components/ui/alert/AlertDescription.vue +6 -6
  160. package/dist/runtime/components/ui/alert/AlertTitle.vue +6 -6
  161. package/dist/runtime/components/ui/alert-dialog/AlertDialog.vue +3 -3
  162. package/dist/runtime/components/ui/alert-dialog/AlertDialogAction.vue +3 -3
  163. package/dist/runtime/components/ui/alert-dialog/AlertDialogCancel.vue +6 -6
  164. package/dist/runtime/components/ui/alert-dialog/AlertDialogContent.vue +13 -13
  165. package/dist/runtime/components/ui/alert-dialog/AlertDialogDescription.vue +7 -7
  166. package/dist/runtime/components/ui/alert-dialog/AlertDialogFooter.vue +6 -6
  167. package/dist/runtime/components/ui/alert-dialog/AlertDialogHeader.vue +6 -6
  168. package/dist/runtime/components/ui/alert-dialog/AlertDialogTitle.vue +7 -7
  169. package/dist/runtime/components/ui/alert-dialog/AlertDialogTrigger.vue +3 -3
  170. package/dist/runtime/components/ui/avatar/Avatar.vue +6 -6
  171. package/dist/runtime/components/ui/avatar/AvatarFallback.vue +7 -7
  172. package/dist/runtime/components/ui/avatar/AvatarImage.vue +7 -7
  173. package/dist/runtime/components/ui/badge/Badge.vue +7 -7
  174. package/dist/runtime/components/ui/breadcrumb/Breadcrumb.vue +7 -7
  175. package/dist/runtime/components/ui/breadcrumb/BreadcrumbEllipsis.vue +11 -11
  176. package/dist/runtime/components/ui/breadcrumb/BreadcrumbItem.vue +6 -6
  177. package/dist/runtime/components/ui/breadcrumb/BreadcrumbLink.vue +8 -8
  178. package/dist/runtime/components/ui/breadcrumb/BreadcrumbList.vue +6 -6
  179. package/dist/runtime/components/ui/breadcrumb/BreadcrumbPage.vue +9 -9
  180. package/dist/runtime/components/ui/breadcrumb/BreadcrumbSeparator.vue +10 -10
  181. package/dist/runtime/components/ui/button/Button.vue +8 -8
  182. package/dist/runtime/components/ui/calendar/Calendar.vue +128 -128
  183. package/dist/runtime/components/ui/calendar/CalendarCell.vue +7 -7
  184. package/dist/runtime/components/ui/calendar/CalendarCellTrigger.vue +7 -7
  185. package/dist/runtime/components/ui/calendar/CalendarGrid.vue +7 -7
  186. package/dist/runtime/components/ui/calendar/CalendarGridBody.vue +6 -6
  187. package/dist/runtime/components/ui/calendar/CalendarGridHead.vue +6 -6
  188. package/dist/runtime/components/ui/calendar/CalendarGridRow.vue +6 -6
  189. package/dist/runtime/components/ui/calendar/CalendarHeadCell.vue +7 -7
  190. package/dist/runtime/components/ui/calendar/CalendarHeader.vue +7 -7
  191. package/dist/runtime/components/ui/calendar/CalendarHeading.vue +10 -10
  192. package/dist/runtime/components/ui/calendar/CalendarNextButton.vue +9 -9
  193. package/dist/runtime/components/ui/calendar/CalendarPrevButton.vue +9 -9
  194. package/dist/runtime/components/ui/card/Card.vue +8 -8
  195. package/dist/runtime/components/ui/card/CardAction.vue +6 -6
  196. package/dist/runtime/components/ui/card/CardContent.vue +6 -6
  197. package/dist/runtime/components/ui/card/CardDescription.vue +6 -6
  198. package/dist/runtime/components/ui/card/CardFooter.vue +6 -6
  199. package/dist/runtime/components/ui/card/CardHeader.vue +6 -6
  200. package/dist/runtime/components/ui/card/CardTitle.vue +6 -6
  201. package/dist/runtime/components/ui/carousel/Carousel.vue +10 -10
  202. package/dist/runtime/components/ui/carousel/CarouselContent.vue +12 -12
  203. package/dist/runtime/components/ui/carousel/CarouselItem.vue +8 -8
  204. package/dist/runtime/components/ui/carousel/CarouselNext.vue +13 -13
  205. package/dist/runtime/components/ui/carousel/CarouselPrevious.vue +13 -13
  206. package/dist/runtime/components/ui/checkbox/Checkbox.vue +8 -8
  207. package/dist/runtime/components/ui/command/Command.vue +7 -7
  208. package/dist/runtime/components/ui/command/CommandDialog.vue +11 -11
  209. package/dist/runtime/components/ui/command/CommandEmpty.vue +16 -16
  210. package/dist/runtime/components/ui/command/CommandGroup.vue +16 -16
  211. package/dist/runtime/components/ui/command/CommandInput.vue +13 -13
  212. package/dist/runtime/components/ui/command/CommandItem.vue +11 -11
  213. package/dist/runtime/components/ui/command/CommandList.vue +9 -9
  214. package/dist/runtime/components/ui/command/CommandSeparator.vue +7 -7
  215. package/dist/runtime/components/ui/command/CommandShortcut.vue +6 -6
  216. package/dist/runtime/components/ui/dialog/Dialog.vue +3 -3
  217. package/dist/runtime/components/ui/dialog/DialogClose.vue +3 -3
  218. package/dist/runtime/components/ui/dialog/DialogContent.vue +26 -26
  219. package/dist/runtime/components/ui/dialog/DialogDescription.vue +7 -7
  220. package/dist/runtime/components/ui/dialog/DialogFooter.vue +6 -6
  221. package/dist/runtime/components/ui/dialog/DialogHeader.vue +6 -6
  222. package/dist/runtime/components/ui/dialog/DialogOverlay.vue +7 -7
  223. package/dist/runtime/components/ui/dialog/DialogScrollContent.vue +20 -20
  224. package/dist/runtime/components/ui/dialog/DialogTitle.vue +7 -7
  225. package/dist/runtime/components/ui/dialog/DialogTrigger.vue +3 -3
  226. package/dist/runtime/components/ui/dropdown-menu/DropdownMenu.vue +6 -6
  227. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuCheckboxItem.vue +12 -12
  228. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuContent.vue +10 -10
  229. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuGroup.vue +6 -6
  230. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuItem.vue +9 -9
  231. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuLabel.vue +8 -8
  232. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuRadioGroup.vue +6 -6
  233. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuRadioItem.vue +16 -16
  234. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSeparator.vue +5 -5
  235. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuShortcut.vue +6 -6
  236. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSub.vue +3 -3
  237. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSubContent.vue +7 -7
  238. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuSubTrigger.vue +8 -8
  239. package/dist/runtime/components/ui/dropdown-menu/DropdownMenuTrigger.vue +6 -6
  240. package/dist/runtime/components/ui/form/FormControl.vue +8 -8
  241. package/dist/runtime/components/ui/form/FormDescription.vue +7 -7
  242. package/dist/runtime/components/ui/form/FormItem.vue +3 -3
  243. package/dist/runtime/components/ui/form/FormLabel.vue +8 -8
  244. package/dist/runtime/components/ui/form/FormMessage.vue +7 -7
  245. package/dist/runtime/components/ui/input/Input.vue +7 -7
  246. package/dist/runtime/components/ui/input-group/InputGroup.vue +7 -7
  247. package/dist/runtime/components/ui/input-group/InputGroupAddon.vue +9 -9
  248. package/dist/runtime/components/ui/input-group/InputGroupButton.vue +8 -8
  249. package/dist/runtime/components/ui/input-group/InputGroupInput.vue +5 -5
  250. package/dist/runtime/components/ui/input-group/InputGroupText.vue +5 -5
  251. package/dist/runtime/components/ui/input-group/InputGroupTextarea.vue +4 -4
  252. package/dist/runtime/components/ui/label/Label.vue +7 -7
  253. package/dist/runtime/components/ui/native-select/NativeSelect.vue +19 -19
  254. package/dist/runtime/components/ui/native-select/NativeSelectOptGroup.vue +3 -3
  255. package/dist/runtime/components/ui/native-select/NativeSelectOption.vue +3 -3
  256. package/dist/runtime/components/ui/pagination/Pagination.vue +8 -8
  257. package/dist/runtime/components/ui/pagination/PaginationContent.vue +8 -8
  258. package/dist/runtime/components/ui/pagination/PaginationEllipsis.vue +10 -10
  259. package/dist/runtime/components/ui/pagination/PaginationFirst.vue +10 -10
  260. package/dist/runtime/components/ui/pagination/PaginationItem.vue +7 -7
  261. package/dist/runtime/components/ui/pagination/PaginationLast.vue +10 -10
  262. package/dist/runtime/components/ui/pagination/PaginationNext.vue +10 -10
  263. package/dist/runtime/components/ui/pagination/PaginationPrevious.vue +10 -10
  264. package/dist/runtime/components/ui/pin-input/PinInput.vue +7 -7
  265. package/dist/runtime/components/ui/pin-input/PinInputGroup.vue +7 -7
  266. package/dist/runtime/components/ui/pin-input/PinInputSeparator.vue +3 -3
  267. package/dist/runtime/components/ui/pin-input/PinInputSlot.vue +5 -5
  268. package/dist/runtime/components/ui/popover/Popover.vue +7 -7
  269. package/dist/runtime/components/ui/popover/PopoverAnchor.vue +6 -6
  270. package/dist/runtime/components/ui/popover/PopoverContent.vue +9 -9
  271. package/dist/runtime/components/ui/popover/PopoverTrigger.vue +6 -6
  272. package/dist/runtime/components/ui/scroll-area/ScrollArea.vue +14 -14
  273. package/dist/runtime/components/ui/scroll-area/ScrollBar.vue +10 -10
  274. package/dist/runtime/components/ui/select/Select.vue +7 -7
  275. package/dist/runtime/components/ui/select/SelectContent.vue +10 -10
  276. package/dist/runtime/components/ui/select/SelectGroup.vue +6 -6
  277. package/dist/runtime/components/ui/select/SelectItem.vue +17 -17
  278. package/dist/runtime/components/ui/select/SelectItemText.vue +6 -6
  279. package/dist/runtime/components/ui/select/SelectLabel.vue +6 -6
  280. package/dist/runtime/components/ui/select/SelectScrollDownButton.vue +9 -9
  281. package/dist/runtime/components/ui/select/SelectScrollUpButton.vue +9 -9
  282. package/dist/runtime/components/ui/select/SelectSeparator.vue +5 -5
  283. package/dist/runtime/components/ui/select/SelectTrigger.vue +11 -11
  284. package/dist/runtime/components/ui/select/SelectValue.vue +6 -6
  285. package/dist/runtime/components/ui/separator/Separator.vue +5 -5
  286. package/dist/runtime/components/ui/sheet/Sheet.vue +3 -3
  287. package/dist/runtime/components/ui/sheet/SheetClose.vue +3 -3
  288. package/dist/runtime/components/ui/sheet/SheetContent.vue +26 -26
  289. package/dist/runtime/components/ui/sheet/SheetDescription.vue +7 -7
  290. package/dist/runtime/components/ui/sheet/SheetFooter.vue +6 -6
  291. package/dist/runtime/components/ui/sheet/SheetHeader.vue +6 -6
  292. package/dist/runtime/components/ui/sheet/SheetOverlay.vue +7 -7
  293. package/dist/runtime/components/ui/sheet/SheetTitle.vue +7 -7
  294. package/dist/runtime/components/ui/sheet/SheetTrigger.vue +3 -3
  295. package/dist/runtime/components/ui/skeleton/Skeleton.vue +4 -4
  296. package/dist/runtime/components/ui/spinner/Spinner.vue +6 -6
  297. package/dist/runtime/components/ui/table/Table.vue +5 -5
  298. package/dist/runtime/components/ui/table/TableBody.vue +6 -6
  299. package/dist/runtime/components/ui/table/TableCaption.vue +6 -6
  300. package/dist/runtime/components/ui/table/TableCell.vue +6 -6
  301. package/dist/runtime/components/ui/table/TableEmpty.vue +15 -15
  302. package/dist/runtime/components/ui/table/TableFooter.vue +6 -6
  303. package/dist/runtime/components/ui/table/TableHead.vue +6 -6
  304. package/dist/runtime/components/ui/table/TableHeader.vue +6 -6
  305. package/dist/runtime/components/ui/table/TableRow.vue +6 -6
  306. package/dist/runtime/components/ui/tabs/Tabs.vue +8 -8
  307. package/dist/runtime/components/ui/tabs/TabsContent.vue +7 -7
  308. package/dist/runtime/components/ui/tabs/TabsList.vue +7 -7
  309. package/dist/runtime/components/ui/tabs/TabsTrigger.vue +7 -7
  310. package/dist/runtime/components/ui/textarea/Textarea.vue +5 -5
  311. package/dist/runtime/components/ui/tooltip/Tooltip.vue +7 -7
  312. package/dist/runtime/components/ui/tooltip/TooltipContent.vue +13 -13
  313. package/dist/runtime/components/ui/tooltip/TooltipProvider.vue +3 -3
  314. package/dist/runtime/components/ui/tooltip/TooltipTrigger.vue +6 -6
  315. package/dist/runtime/components/video.vue +2 -2
  316. package/dist/runtime/composables/useApi.js +1 -1
  317. package/dist/runtime/composables/useThaiAddress.js +6 -6
  318. package/dist/runtime/geo/README.md +87 -87
  319. package/dist/runtime/geo/postal_codes.json +5569 -5569
  320. package/dist/runtime/plugins/toast.js +3 -3
  321. package/package.json +2 -2
@@ -1,33 +1,33 @@
1
1
  <template>
2
- <div>
3
- <Divider v-if="!props.disabledDividerTop" :height="0" />
4
- <div class="flex justify-between w-full font-body-large text-gray">
5
- <div
6
- v-for="(react, i) in listReaction"
7
- :key="i"
2
+ <div>
3
+ <Divider v-if="!props.disabledDividerTop" :height="0" />
4
+ <div class="flex justify-between w-full font-body-large text-gray">
5
+ <div
6
+ v-for="(react, i) in listReaction"
7
+ :key="i"
8
8
  :class="[
9
9
  'flex items-center gap-[4px] justify-center w-full',
10
10
  react.action && 'cursor-pointer hover:bg-bright',
11
11
  props.disabled && 'pointer-events-none'
12
- ]"
12
+ ]"
13
13
  :style="{
14
14
  padding: `${computedPadding}px`
15
- }"
16
- :aria-disabled="props.disabled || !react.action"
17
- @click="react.action"
18
- >
19
- <Icon
20
- :name="react.reacted ? react.iconReacted : react.icon"
21
- :size="props.iconSize"
22
- />
23
- <div :class="[react.reacted && 'text-primary']">
24
- {{ $convert.convertNumber(react.count) }}
25
- </div>
26
- </div>
27
- </div>
28
- <Divider v-if="!props.disabledDividerBottom" :height="0" />
29
- <ModalShare v-model="isOpenModalShare" />
30
- </div>
15
+ }"
16
+ :aria-disabled="props.disabled || !react.action"
17
+ @click="react.action"
18
+ >
19
+ <Icon
20
+ :name="react.reacted ? react.iconReacted : react.icon"
21
+ :size="props.iconSize"
22
+ />
23
+ <div :class="[react.reacted && 'text-primary']">
24
+ {{ $convert.convertNumber(react.count) }}
25
+ </div>
26
+ </div>
27
+ </div>
28
+ <Divider v-if="!props.disabledDividerBottom" :height="0" />
29
+ <ModalShare v-model="isOpenModalShare" />
30
+ </div>
31
31
  </template>
32
32
 
33
33
  <script setup>
@@ -1,46 +1,46 @@
1
1
  <template>
2
- <Card title="เรื่องอื่นๆ ที่เกี่ยวข้อง" class="w-[380px]" variant="outline">
3
- <div class="min-h-[440px]">
4
- <div v-if="props.items.length > 0" class="flex flex-col gap-[16px]">
5
- <div v-for="(item, index) in props.items" :key="index">
6
- <div v-if="item.image" class="flex gap-[8px]">
7
- <Image
8
- width="100"
9
- height="100"
10
- :src="item.image"
11
- class="rounded-[4px]"
12
- />
13
- <div class="flex flex-col gap-[4px]">
14
- <div class="line-clamp-3 font-body-large-prominent">
15
- {{ item.title }}
16
- </div>
17
- <div class="text-primary font-body-small cursor-pointer">
18
- {{ item.name }}
19
- </div>
20
- </div>
21
- </div>
22
- <div v-else class="flex flex-col gap-[4px]">
23
- <div class="font-body-large-prominent line-clamp-2">
24
- {{ item.title }}
25
- </div>
26
- <div class="text-primary font-body-small cursor-pointer">
27
- {{ item.name }}
28
- </div>
29
- <div class="text-gray font-body-medium line-clamp-1">
30
- {{ item.description }}
31
- </div>
32
- </div>
33
- </div>
34
- </div>
35
- <div
36
- v-else
37
- class="flex flex-col gap-[8px] items-center justify-center h-[440px]"
38
- >
39
- <Icon name="pukaad:page-not-found" size="60" />
40
- <div class="font-body-large text-gray">ไม่พบข้อมูล</div>
41
- </div>
42
- </div>
43
- </Card>
2
+ <Card title="เรื่องอื่นๆ ที่เกี่ยวข้อง" class="w-[380px]" variant="outline">
3
+ <div class="min-h-[440px]">
4
+ <div v-if="props.items.length > 0" class="flex flex-col gap-[16px]">
5
+ <div v-for="(item, index) in props.items" :key="index">
6
+ <div v-if="item.image" class="flex gap-[8px]">
7
+ <Image
8
+ width="100"
9
+ height="100"
10
+ :src="item.image"
11
+ class="rounded-[4px]"
12
+ />
13
+ <div class="flex flex-col gap-[4px]">
14
+ <div class="line-clamp-3 font-body-large-prominent">
15
+ {{ item.title }}
16
+ </div>
17
+ <div class="text-primary font-body-small cursor-pointer">
18
+ {{ item.name }}
19
+ </div>
20
+ </div>
21
+ </div>
22
+ <div v-else class="flex flex-col gap-[4px]">
23
+ <div class="font-body-large-prominent line-clamp-2">
24
+ {{ item.title }}
25
+ </div>
26
+ <div class="text-primary font-body-small cursor-pointer">
27
+ {{ item.name }}
28
+ </div>
29
+ <div class="text-gray font-body-medium line-clamp-1">
30
+ {{ item.description }}
31
+ </div>
32
+ </div>
33
+ </div>
34
+ </div>
35
+ <div
36
+ v-else
37
+ class="flex flex-col gap-[8px] items-center justify-center h-[440px]"
38
+ >
39
+ <Icon name="pukaad:page-not-found" size="60" />
40
+ <div class="font-body-large text-gray">ไม่พบข้อมูล</div>
41
+ </div>
42
+ </div>
43
+ </Card>
44
44
  </template>
45
45
 
46
46
  <script setup>
@@ -1,49 +1,49 @@
1
1
  <template>
2
- <Card title="ที่ไหนน่าสนใจ" class="w-[380px]" variant="outline">
3
- <template v-if="props.items.length > 0" #header>
4
- <div class="flex justify-between items-center">
5
- <div class="font-title-medium-prominent">ที่ไหนน่าสนใจ</div>
6
- <Button color="primary" variant="text" @click="onViewAll">
7
- <div class="flex items-center gap-[2px] font-body-small">
8
- ดูทั้งหมด
9
- <Icon name="lucide:chevron-right" size="16" />
10
- </div>
11
- </Button>
12
- </div>
13
- </template>
14
-
15
- <div v-if="props.items.length > 0" class="flex flex-col gap-[16px]">
16
- <div
17
- v-for="item in props.items"
18
- :key="item.id"
19
- class="flex items-center gap-[16px] cursor-pointer"
20
- @click="handleClickCard(item)"
21
- >
22
- <Image
23
- :src="item.image"
24
- width="100"
25
- height="56"
26
- class="rounded-[4px]"
27
- />
28
- <div class="flex flex-col gap-[4px]">
29
- <div class="font-body-large w-[232px] truncate">
30
- {{ item.title }}
31
- </div>
32
- <div class="flex items-center gap-[4px] text-gray font-body-small">
33
- <InputRating v-model="item.rating" readonly :rating-size="10" />
34
- {{ $format.number(item.review_count) }}
35
- </div>
36
- </div>
37
- </div>
38
- </div>
39
- <div
40
- v-else
41
- class="flex flex-col gap-[8px] items-center justify-center h-[334px]"
42
- >
43
- <Icon name="pukaad:page-not-found" size="60" />
44
- <div class="font-body-large text-gray">ไม่พบสถานที่</div>
45
- </div>
46
- </Card>
2
+ <Card title="ที่ไหนน่าสนใจ" class="w-[380px]" variant="outline">
3
+ <template v-if="props.items.length > 0" #header>
4
+ <div class="flex justify-between items-center">
5
+ <div class="font-title-medium-prominent">ที่ไหนน่าสนใจ</div>
6
+ <Button color="primary" variant="text" @click="onViewAll">
7
+ <div class="flex items-center gap-[2px] font-body-small">
8
+ ดูทั้งหมด
9
+ <Icon name="lucide:chevron-right" size="16" />
10
+ </div>
11
+ </Button>
12
+ </div>
13
+ </template>
14
+
15
+ <div v-if="props.items.length > 0" class="flex flex-col gap-[16px]">
16
+ <div
17
+ v-for="item in props.items"
18
+ :key="item.id"
19
+ class="flex items-center gap-[16px] cursor-pointer"
20
+ @click="handleClickCard(item)"
21
+ >
22
+ <Image
23
+ :src="item.image"
24
+ width="100"
25
+ height="56"
26
+ class="rounded-[4px]"
27
+ />
28
+ <div class="flex flex-col gap-[4px]">
29
+ <div class="font-body-large w-[232px] truncate">
30
+ {{ item.title }}
31
+ </div>
32
+ <div class="flex items-center gap-[4px] text-gray font-body-small">
33
+ <InputRating v-model="item.rating" readonly :rating-size="10" />
34
+ {{ $format.number(item.review_count) }}
35
+ </div>
36
+ </div>
37
+ </div>
38
+ </div>
39
+ <div
40
+ v-else
41
+ class="flex flex-col gap-[8px] items-center justify-center h-[334px]"
42
+ >
43
+ <Icon name="pukaad:page-not-found" size="60" />
44
+ <div class="font-body-large text-gray">ไม่พบสถานที่</div>
45
+ </div>
46
+ </Card>
47
47
  </template>
48
48
 
49
49
  <script setup>
@@ -1,50 +1,50 @@
1
1
  <template>
2
- <Card title="ติดตามใครดี" variant="outline" class="w-[380px]">
3
- <template v-if="props.items.length > 0" #header>
4
- <div class="flex justify-between items-center">
5
- <div class="font-title-medium-prominent">ติดตามใครดี</div>
6
- <Button color="primary" variant="text" @click="onViewAll">
7
- <div class="flex items-center gap-[2px] font-body-small">
8
- ดูทั้งหมด<Icon name="lucide:chevron-right" size="16" />
9
- </div>
10
- </Button>
11
- </div>
12
- </template>
13
- <div v-if="props.items.length > 0" class="flex flex-col gap-[16px]">
14
- <div
15
- v-for="item in props.items"
16
- :key="item.id"
17
- class="flex items-center gap-[16px] cursor-pointer"
18
- @click="handleClickCard(item)"
19
- >
20
- <Avatar :src="item.image" alt="image" size="40" />
21
- <div class="flex flex-col gap-[4px]">
22
- <div class="flex items-center gap-[4px]">
23
- <div class="font-body-large max-w-[272px] truncate">
24
- {{ item.name }}
25
- </div>
26
- <Icon
27
- v-if="item.verified === true"
28
- name="pukaad-verify"
29
- :size="13"
30
- />
31
- </div>
32
- <div class="text-gray font-body-small">
33
- กำลังเผยแพร่ {{ $format.number(item.post_count) }} • ผู้ติดตาม
34
- {{ $format.number(item.follower_count) }}
35
- </div>
36
- </div>
37
- </div>
38
- </div>
39
- <div v-else>
40
- <div
41
- class="flex flex-col items-center justify-center h-[310px] gap-[10px]"
42
- >
43
- <Icon name="pukaad:page-not-found" size="60" />
44
- <div class="font-body-large text-gray">ไม่พบข้อมูล</div>
45
- </div>
46
- </div>
47
- </Card>
2
+ <Card title="ติดตามใครดี" variant="outline" class="w-[380px]">
3
+ <template v-if="props.items.length > 0" #header>
4
+ <div class="flex justify-between items-center">
5
+ <div class="font-title-medium-prominent">ติดตามใครดี</div>
6
+ <Button color="primary" variant="text" @click="onViewAll">
7
+ <div class="flex items-center gap-[2px] font-body-small">
8
+ ดูทั้งหมด<Icon name="lucide:chevron-right" size="16" />
9
+ </div>
10
+ </Button>
11
+ </div>
12
+ </template>
13
+ <div v-if="props.items.length > 0" class="flex flex-col gap-[16px]">
14
+ <div
15
+ v-for="item in props.items"
16
+ :key="item.id"
17
+ class="flex items-center gap-[16px] cursor-pointer"
18
+ @click="handleClickCard(item)"
19
+ >
20
+ <Avatar :src="item.image" alt="image" size="40" />
21
+ <div class="flex flex-col gap-[4px]">
22
+ <div class="flex items-center gap-[4px]">
23
+ <div class="font-body-large max-w-[272px] truncate">
24
+ {{ item.name }}
25
+ </div>
26
+ <Icon
27
+ v-if="item.verified === true"
28
+ name="pukaad-verify"
29
+ :size="13"
30
+ />
31
+ </div>
32
+ <div class="text-gray font-body-small">
33
+ กำลังเผยแพร่ {{ $format.number(item.post_count) }} • ผู้ติดตาม
34
+ {{ $format.number(item.follower_count) }}
35
+ </div>
36
+ </div>
37
+ </div>
38
+ </div>
39
+ <div v-else>
40
+ <div
41
+ class="flex flex-col items-center justify-center h-[310px] gap-[10px]"
42
+ >
43
+ <Icon name="pukaad:page-not-found" size="60" />
44
+ <div class="font-body-large text-gray">ไม่พบข้อมูล</div>
45
+ </div>
46
+ </div>
47
+ </Card>
48
48
  </template>
49
49
 
50
50
  <script setup>
@@ -1,61 +1,61 @@
1
1
  <template>
2
- <div class="py-[16px] border-b-[1px] border-mercury flex gap-[16px] w-full">
3
- <div v-if="props.item.user.avatar">
4
- <Avatar :src="props.item.user.avatar" alt="profile_myProfile" :size="30" class="cursor-pointer"
5
- @click="NavigateToProfile(props.item.user.path_name)" />
6
- </div>
7
- <div class="flex flex-col gap-[24px] w-full">
8
- <div class="flex flex-col gap-[8px]">
9
- <div class="flex flex-col gap-[6px]">
10
- <div class="flex flex-col gap-[4px]">
11
- <div class="flex justify-between items-center">
12
- <div @click="NavigateToProfile(props.item.user.path_name)" class="font-body-large cursor-pointer">
13
- {{ props.item.user?.name }}
14
- </div>
15
- <div class="flex gap-[8px] items-center">
16
- <Button variant="text" :color="liked ? 'primary' : 'default'" :disabled="props.disabledLike"
17
- :aria-pressed="liked" @click="toggleLike">
18
- <Icon :name="liked ? 'fa6-solid:thumbs-up' : 'fa6-regular:thumbs-up'" :size="20" />
19
- {{ convertNumber(likeCount) }}
20
- </Button>
21
- <PickerOptionMenuUser v-if="!props.disabledMenu" :state="menuType" disabled-padding />
22
- </div>
23
- </div>
24
- <div class="text-gray font-body-small">
25
- {{ convertNumber(props.item.user?.review_count ?? 0) }} รีวิว •
26
- {{ convertNumber(props.item.user?.like_count ?? 0) }} ชื่นชอบรีวิว
27
- </div>
28
- </div>
29
- <div class="flex gap-[8px] items-center">
30
- <InputRating :size="16" readonly :model-value="props.item.review?.rating" />
31
- <div class="text-gray font-body-small">
32
- {{ props.item.review?.created_at }}
33
- </div>
34
- </div>
35
- </div>
36
-
37
- <div v-if="props.item.review?.description" class="font-body-large">
38
- {{ props.item.review?.description }}
39
- </div>
40
-
41
- <div v-if="props.item.review?.images?.length" class="flex gap-[8px]">
42
- <DisplayImageReview :items="props.item.review?.images" @select="selectImage" />
43
- </div>
44
- </div>
45
- <div v-if="props.item.replies">
46
- <div class="p-[16px] rounded-sm bg-bright">
47
- <div class="text-gray font-body-large">
48
- การตอบกลับจาก {{ props.item.replies?.author }}
49
- </div>
50
- <div class="font-body-large">
51
- {{ props.item.replies?.description }}
52
- </div>
53
- </div>
54
- </div>
55
- </div>
56
- </div>
57
-
58
- <ModalMediaView v-model="isOpen" :items="props.item.review?.images" :start-index="startIndex" title="รูปภาพรีวิว" />
2
+ <div class="py-[16px] border-b-[1px] border-mercury flex gap-[16px] w-full">
3
+ <div v-if="props.item.user.avatar">
4
+ <Avatar :src="props.item.user.avatar" alt="profile_myProfile" :size="30" class="cursor-pointer"
5
+ @click="NavigateToProfile(props.item.user.path_name)" />
6
+ </div>
7
+ <div class="flex flex-col gap-[24px] w-full">
8
+ <div class="flex flex-col gap-[8px]">
9
+ <div class="flex flex-col gap-[6px]">
10
+ <div class="flex flex-col gap-[4px]">
11
+ <div class="flex justify-between items-center">
12
+ <div @click="NavigateToProfile(props.item.user.path_name)" class="font-body-large cursor-pointer">
13
+ {{ props.item.user?.name }}
14
+ </div>
15
+ <div class="flex gap-[8px] items-center">
16
+ <Button variant="text" :color="liked ? 'primary' : 'default'" :disabled="props.disabledLike"
17
+ :aria-pressed="liked" @click="toggleLike">
18
+ <Icon :name="liked ? 'fa6-solid:thumbs-up' : 'fa6-regular:thumbs-up'" :size="20" />
19
+ {{ convertNumber(likeCount) }}
20
+ </Button>
21
+ <PickerOptionMenuUser v-if="!props.disabledMenu" :state="menuType" disabled-padding />
22
+ </div>
23
+ </div>
24
+ <div class="text-gray font-body-small">
25
+ {{ convertNumber(props.item.user?.review_count ?? 0) }} รีวิว •
26
+ {{ convertNumber(props.item.user?.like_count ?? 0) }} ชื่นชอบรีวิว
27
+ </div>
28
+ </div>
29
+ <div class="flex gap-[8px] items-center">
30
+ <InputRating :size="16" readonly :model-value="props.item.review?.rating" />
31
+ <div class="text-gray font-body-small">
32
+ {{ props.item.review?.created_at }}
33
+ </div>
34
+ </div>
35
+ </div>
36
+
37
+ <div v-if="props.item.review?.description" class="font-body-large">
38
+ {{ props.item.review?.description }}
39
+ </div>
40
+
41
+ <div v-if="props.item.review?.images?.length" class="flex gap-[8px]">
42
+ <DisplayImageReview :items="props.item.review?.images" @select="selectImage" />
43
+ </div>
44
+ </div>
45
+ <div v-if="props.item.replies">
46
+ <div class="p-[16px] rounded-sm bg-bright">
47
+ <div class="text-gray font-body-large">
48
+ การตอบกลับจาก {{ props.item.replies?.author }}
49
+ </div>
50
+ <div class="font-body-large">
51
+ {{ props.item.replies?.description }}
52
+ </div>
53
+ </div>
54
+ </div>
55
+ </div>
56
+ </div>
57
+
58
+ <ModalMediaView v-model="isOpen" :items="props.item.review?.images" :start-index="startIndex" title="รูปภาพรีวิว" />
59
59
  </template>
60
60
 
61
61
  <script setup>
@@ -1,88 +1,88 @@
1
1
  <template>
2
- <div class="flex flex-col gap-[16px] w-[668px] border-mercury border-b-[1px]">
3
- <div class="flex gap-[16px] items-center w-full">
4
- <div class="flex gap-[8px] items-center w-full">
5
- <Avatar
6
- :src="props.item.user.avatar"
7
- :size="40"
8
- class="cursor-pointer"
9
- @click="onProfileClick"
10
- />
11
- <div class="flex flex-col gap-[4px]">
12
- <div>
13
- <span
14
- class="font-body-large cursor-pointer"
15
- @click="onProfileClick"
16
- >{{ props.item.user.name }}</span
17
- ><Icon
18
- v-if="props.item.user.verified"
19
- name="pukaad:verify"
20
- :size="16"
21
- class="inline-block align-middle ml-[8px]"
22
- />
23
- </div>
24
- <div class="text-gray font-body-small flex gap-[4px] items-center">
25
- <div>
26
- {{ convertDateTorelativeText(props.item.create_at) }}
27
- </div>
28
- <div>•</div>
29
- <div>{{ convertNumber(props.item.view_count) }} วิว</div>
30
- </div>
31
- </div>
32
- </div>
33
- <Icon v-if="isPinned" name="lucide:pin" :size="20" />
34
- <PickerOptionMenuUser
2
+ <div class="flex flex-col gap-[16px] w-[668px] border-mercury border-b-[1px]">
3
+ <div class="flex gap-[16px] items-center w-full">
4
+ <div class="flex gap-[8px] items-center w-full">
5
+ <Avatar
6
+ :src="props.item.user.avatar"
7
+ :size="40"
8
+ class="cursor-pointer"
9
+ @click="onProfileClick"
10
+ />
11
+ <div class="flex flex-col gap-[4px]">
12
+ <div>
13
+ <span
14
+ class="font-body-large cursor-pointer"
15
+ @click="onProfileClick"
16
+ >{{ props.item.user.name }}</span
17
+ ><Icon
18
+ v-if="props.item.user.verified"
19
+ name="pukaad:verify"
20
+ :size="16"
21
+ class="inline-block align-middle ml-[8px]"
22
+ />
23
+ </div>
24
+ <div class="text-gray font-body-small flex gap-[4px] items-center">
25
+ <div>
26
+ {{ convertDateTorelativeText(props.item.create_at) }}
27
+ </div>
28
+ <div>•</div>
29
+ <div>{{ convertNumber(props.item.view_count) }} วิว</div>
30
+ </div>
31
+ </div>
32
+ </div>
33
+ <Icon v-if="isPinned" name="lucide:pin" :size="20" />
34
+ <PickerOptionMenuUser
35
35
  :state="
36
36
  props.isMyProfile ? isPinned ? 'my-blog-pined' : 'my-blog' : 'report-announce'
37
- "
38
- disabled-padding
39
- @blog-unpin="onBlogUnpin"
40
- @blog-pin="onBlogPin"
41
- @blog-edit="onBlogEdit"
42
- @blog-delete="onBlogDelete"
43
- />
44
- </div>
45
- <div class="flex flex-col gap-[16px] cursor-pointer" @click="onBlogClick">
46
- <Image
47
- v-if="props.item.image"
48
- :src="props.item.image"
49
- :width="668"
50
- :height="376"
51
- fit="fill"
52
- />
53
- <div class="font-title-medium-prominent">
54
- {{ props.item.title }}
55
- </div>
56
- <div
57
- v-if="!props.item.image"
58
- class="text-gray font-body-large line-clamp-4"
59
- >
60
- {{ props.item.description }}
61
- </div>
62
- </div>
63
- <CardReaction
64
- disabled-divider-top
65
- disabled-divider-bottom
66
- :id="props.item.id"
37
+ "
38
+ disabled-padding
39
+ @blog-unpin="onBlogUnpin"
40
+ @blog-pin="onBlogPin"
41
+ @blog-edit="onBlogEdit"
42
+ @blog-delete="onBlogDelete"
43
+ />
44
+ </div>
45
+ <div class="flex flex-col gap-[16px] cursor-pointer" @click="onBlogClick">
46
+ <Image
47
+ v-if="props.item.image"
48
+ :src="props.item.image"
49
+ :width="668"
50
+ :height="376"
51
+ fit="fill"
52
+ />
53
+ <div class="font-title-medium-prominent">
54
+ {{ props.item.title }}
55
+ </div>
56
+ <div
57
+ v-if="!props.item.image"
58
+ class="text-gray font-body-large line-clamp-4"
59
+ >
60
+ {{ props.item.description }}
61
+ </div>
62
+ </div>
63
+ <CardReaction
64
+ disabled-divider-top
65
+ disabled-divider-bottom
66
+ :id="props.item.id"
67
67
  :item-count="{
68
68
  liked: props.item.like_count,
69
69
  commented: props.item.comment_count,
70
70
  shared: props.item.share_count
71
- }"
71
+ }"
72
72
  :itemActive="{
73
73
  liked: props.item.liked
74
- }"
75
- state="blog"
76
- />
77
-
78
- <!-- Edit Blog Drawer — อยู่ใน root เดียวกันเพื่อหลีกเลี่ยง fragment -->
79
- <DrawerPostBlog
80
- v-if="editBlogItem"
81
- v-model="isEditDrawerOpen"
82
- :item="editBlogItem"
83
- @success="onEditSuccess"
84
- />
85
- </div>
74
+ }"
75
+ state="blog"
76
+ />
77
+
78
+ <!-- Edit Blog Drawer — อยู่ใน root เดียวกันเพื่อหลีกเลี่ยง fragment -->
79
+ <DrawerPostBlog
80
+ v-if="editBlogItem"
81
+ v-model="isEditDrawerOpen"
82
+ :item="editBlogItem"
83
+ @success="onEditSuccess"
84
+ />
85
+ </div>
86
86
  </template>
87
87
 
88
88
  <script setup>