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,54 +1,54 @@
1
1
  <template>
2
- <!-- <Card full-width variant="outline">
3
- <template #header>
4
- <div class="flex justify-between items-center">
5
- <div class="font-title-medium-prominent">เกี่ยวกับ</div>
6
- <Button
7
- v-if="props.isEdit"
8
- variant="text"
9
- color="primary"
10
- prependIcon="lucide:square-pen"
11
- :iconSize="20"
12
- @click="isShowEdit = true"
13
- >
14
- แก้ไข
15
- </Button>
16
- </div>
17
- </template>
18
- <div class="flex flex-col gap-[8px] font-body-large">
19
- <div v-for="(item, i) in itemDetail" :key="i" class="flex gap-[8px]">
20
- <div class="pt-[3px]">
21
- <Icon :name="item.icon" :size="20" class="text-primary" />
22
- </div>
23
- <div :class="item.isDefault ? 'text-cloud' : ''">
24
- {{ item.value }}
25
- </div>
26
- </div>
27
-
28
- <div
29
- v-for="(linkItem, i) in props.item.links"
30
- :key="i"
31
- class="flex gap-[8px]"
32
- v-if="props.item.links.length > 0"
33
- >
34
- <div class="pt-[3px]">
35
- <Icon
36
- :name="`pukaad-social:${linkItem.name}`"
37
- :size="20"
38
- class="text-primary"
39
- />
40
- </div>
41
- <div
42
- class="cursor-pointer hover:underline"
43
- @click="onClickLink(linkItem.link)"
44
- >
45
- {{ linkItem.link }}
46
- </div>
47
- </div>
48
- </div>
49
- </Card>
50
-
51
- <DrawerProfileAbout @submit="onSubmit" :item="item" v-model="isShowEdit" /> -->
2
+ <!-- <Card full-width variant="outline">
3
+ <template #header>
4
+ <div class="flex justify-between items-center">
5
+ <div class="font-title-medium-prominent">เกี่ยวกับ</div>
6
+ <Button
7
+ v-if="props.isEdit"
8
+ variant="text"
9
+ color="primary"
10
+ prependIcon="lucide:square-pen"
11
+ :iconSize="20"
12
+ @click="isShowEdit = true"
13
+ >
14
+ แก้ไข
15
+ </Button>
16
+ </div>
17
+ </template>
18
+ <div class="flex flex-col gap-[8px] font-body-large">
19
+ <div v-for="(item, i) in itemDetail" :key="i" class="flex gap-[8px]">
20
+ <div class="pt-[3px]">
21
+ <Icon :name="item.icon" :size="20" class="text-primary" />
22
+ </div>
23
+ <div :class="item.isDefault ? 'text-cloud' : ''">
24
+ {{ item.value }}
25
+ </div>
26
+ </div>
27
+
28
+ <div
29
+ v-for="(linkItem, i) in props.item.links"
30
+ :key="i"
31
+ class="flex gap-[8px]"
32
+ v-if="props.item.links.length > 0"
33
+ >
34
+ <div class="pt-[3px]">
35
+ <Icon
36
+ :name="`pukaad-social:${linkItem.name}`"
37
+ :size="20"
38
+ class="text-primary"
39
+ />
40
+ </div>
41
+ <div
42
+ class="cursor-pointer hover:underline"
43
+ @click="onClickLink(linkItem.link)"
44
+ >
45
+ {{ linkItem.link }}
46
+ </div>
47
+ </div>
48
+ </div>
49
+ </Card>
50
+
51
+ <DrawerProfileAbout @submit="onSubmit" :item="item" v-model="isShowEdit" /> -->
52
52
  </template>
53
53
 
54
54
  <script setup>
@@ -1,98 +1,98 @@
1
1
  <template>
2
- <!-- <div
3
- :class="[
4
- 'flex gap-[16px] items-center justify-between',
5
- !props.disabledPadding && 'py-[16px]',
6
- ]"
7
- >
8
- <Avatar
9
- :src="props.item.profile_image.url"
10
- size="40"
11
- class="cursor-pointer"
12
- @click="onProfileClick"
13
- />
14
- <div class="flex-1 flex flex-col gap-[4px]">
15
- <div class="flex gap-[4px] font-body-large-prominent items-center">
16
- <div class="cursor-pointer" @click="onProfileClick">
17
- {{ props.item.profile_name }}
18
- </div>
19
- <Icon
20
- v-if="props.item.profile_verified"
21
- name="pukaad-verify"
22
- size="16"
23
- />
24
- <div v-if="!props.actionsHidden">•</div>
25
-
26
- <Button
27
- type="text"
28
- variant="primary"
29
- @click="!props.preview ? toggleFollow() : null"
30
- v-if="!props.actionsHidden"
31
- :disabled="props.preview"
32
- disabled-padding
33
- >
34
- {{ isFollowing ? "เลิกติดตาม" : "ติดตาม" }}
35
- </Button>
36
- </div>
37
-
38
- <div v-if="props.type !== 'media'">
39
- <div
40
- v-if="type === 'article'"
41
- class="text-gray font-body-large flex gap-[4px]"
42
- >
43
- {{ props.item.time }} • {{ props.item.view }}
44
- </div>
45
- <div v-else class="flex gap-[16px] font-body-large">
46
- <div class="text-gray flex gap-[4px]">
47
- ผู้ติดตาม
48
- <div class="text-black">{{ props.item.profile_follower }}</div>
49
- </div>
50
- <div class="text-gray flex gap-[4px]">
51
- กำลังเผยแพร่
52
- <div class="text-black">{{ props.item.profile_following }}</div>
53
- </div>
54
- <div class="text-gray flex gap-[4px]">
55
- อัตราตอบแชท
56
- <div class="text-black">{{ props.item.profile_response_rate }}</div>
57
- </div>
58
- <div v-if="type === 'sale-info'" class="text-gray flex gap-[4px]">
59
- สั่งซื้อสำเร็จ
60
- <div class="text-black">{{ props.item.profile_response_rate }}</div>
61
- </div>
62
- <div v-if="type === 'sale-info'" class="text-gray flex gap-[4px]">
63
- ผู้ขายยกเลิก
64
- <div class="text-black">{{ props.item.profile_response_rate }}</div>
65
- </div>
66
- </div>
67
- </div>
68
- </div>
69
-
70
- <div v-if="!actionsHidden && type !== 'media'" class="flex gap-[16px]">
71
- <Button
72
- prepend-icon="lucide:message-circle"
73
- full-rounded
74
- :icon-size="20"
75
- @click="onChat"
76
- :disabled="props.preview"
77
- >
78
- แชท
79
- </Button>
80
- <PickerOptionMenuUser
81
- :variant="optionMenuButtonType"
82
- circle
83
- :state="profileType"
84
- :disabled="props.preview"
85
- />
86
- </div>
87
-
88
- <PickerOptionMenuUser
89
- v-else-if="!actionsHidden"
90
- :variant="optionMenuButtonType"
91
- circle
92
- :state="profileType"
93
- :disabled="props.preview"
94
- />
95
- </div> -->
2
+ <!-- <div
3
+ :class="[
4
+ 'flex gap-[16px] items-center justify-between',
5
+ !props.disabledPadding && 'py-[16px]',
6
+ ]"
7
+ >
8
+ <Avatar
9
+ :src="props.item.profile_image.url"
10
+ size="40"
11
+ class="cursor-pointer"
12
+ @click="onProfileClick"
13
+ />
14
+ <div class="flex-1 flex flex-col gap-[4px]">
15
+ <div class="flex gap-[4px] font-body-large-prominent items-center">
16
+ <div class="cursor-pointer" @click="onProfileClick">
17
+ {{ props.item.profile_name }}
18
+ </div>
19
+ <Icon
20
+ v-if="props.item.profile_verified"
21
+ name="pukaad-verify"
22
+ size="16"
23
+ />
24
+ <div v-if="!props.actionsHidden">•</div>
25
+
26
+ <Button
27
+ type="text"
28
+ variant="primary"
29
+ @click="!props.preview ? toggleFollow() : null"
30
+ v-if="!props.actionsHidden"
31
+ :disabled="props.preview"
32
+ disabled-padding
33
+ >
34
+ {{ isFollowing ? "เลิกติดตาม" : "ติดตาม" }}
35
+ </Button>
36
+ </div>
37
+
38
+ <div v-if="props.type !== 'media'">
39
+ <div
40
+ v-if="type === 'article'"
41
+ class="text-gray font-body-large flex gap-[4px]"
42
+ >
43
+ {{ props.item.time }} • {{ props.item.view }}
44
+ </div>
45
+ <div v-else class="flex gap-[16px] font-body-large">
46
+ <div class="text-gray flex gap-[4px]">
47
+ ผู้ติดตาม
48
+ <div class="text-black">{{ props.item.profile_follower }}</div>
49
+ </div>
50
+ <div class="text-gray flex gap-[4px]">
51
+ กำลังเผยแพร่
52
+ <div class="text-black">{{ props.item.profile_following }}</div>
53
+ </div>
54
+ <div class="text-gray flex gap-[4px]">
55
+ อัตราตอบแชท
56
+ <div class="text-black">{{ props.item.profile_response_rate }}</div>
57
+ </div>
58
+ <div v-if="type === 'sale-info'" class="text-gray flex gap-[4px]">
59
+ สั่งซื้อสำเร็จ
60
+ <div class="text-black">{{ props.item.profile_response_rate }}</div>
61
+ </div>
62
+ <div v-if="type === 'sale-info'" class="text-gray flex gap-[4px]">
63
+ ผู้ขายยกเลิก
64
+ <div class="text-black">{{ props.item.profile_response_rate }}</div>
65
+ </div>
66
+ </div>
67
+ </div>
68
+ </div>
69
+
70
+ <div v-if="!actionsHidden && type !== 'media'" class="flex gap-[16px]">
71
+ <Button
72
+ prepend-icon="lucide:message-circle"
73
+ full-rounded
74
+ :icon-size="20"
75
+ @click="onChat"
76
+ :disabled="props.preview"
77
+ >
78
+ แชท
79
+ </Button>
80
+ <PickerOptionMenuUser
81
+ :variant="optionMenuButtonType"
82
+ circle
83
+ :state="profileType"
84
+ :disabled="props.preview"
85
+ />
86
+ </div>
87
+
88
+ <PickerOptionMenuUser
89
+ v-else-if="!actionsHidden"
90
+ :variant="optionMenuButtonType"
91
+ circle
92
+ :state="profileType"
93
+ :disabled="props.preview"
94
+ />
95
+ </div> -->
96
96
  </template>
97
97
 
98
98
  <script setup>
@@ -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"
8
- :class="[
9
- 'flex items-center gap-[4px] justify-center w-full',
10
- react.action && 'cursor-pointer hover:bg-bright',
11
- props.disabled && 'pointer-events-none',
12
- ]"
13
- :style="{
14
- padding: `${props.padding}px`,
15
- }"
16
- :aria-disabledd="props.disabled || !react.action"
17
- @click="react.action"
18
- >
19
- <Icon
20
- :name="react.reacted ? react.iconReacted : react.icon"
21
- :size="props.size"
22
- />
23
- <div :class="[react.reacted && 'text-primary']">
24
- {{ react.count }}
25
- </div>
26
- </div>
27
- </div>
28
- <Divider v-if="!props.disabledDividerBottom" :height="0" />
29
- </div>
30
- <ModalShare v-model="isOpenModalShare" /> -->
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
+ :class="[
9
+ 'flex items-center gap-[4px] justify-center w-full',
10
+ react.action && 'cursor-pointer hover:bg-bright',
11
+ props.disabled && 'pointer-events-none',
12
+ ]"
13
+ :style="{
14
+ padding: `${props.padding}px`,
15
+ }"
16
+ :aria-disabledd="props.disabled || !react.action"
17
+ @click="react.action"
18
+ >
19
+ <Icon
20
+ :name="react.reacted ? react.iconReacted : react.icon"
21
+ :size="props.size"
22
+ />
23
+ <div :class="[react.reacted && 'text-primary']">
24
+ {{ react.count }}
25
+ </div>
26
+ </div>
27
+ </div>
28
+ <Divider v-if="!props.disabledDividerBottom" :height="0" />
29
+ </div>
30
+ <ModalShare v-model="isOpenModalShare" /> -->
31
31
  </template>
32
32
 
33
33
  <script setup>
@@ -1,53 +1,53 @@
1
1
  <template>
2
- <Card variant="outline" width="380">
3
- <div class="w-auto max-h-[626px] flex flex-col gap-[8px]">
4
- <div class="flex">
5
- <div class="text-surface font-title-medium-prominent">
6
- เรื่องอื่นๆ ที่เกี่ยวข้อง
7
- </div>
8
- </div>
9
- <div v-if="props.items.length > 0">
10
- <div v-for="(item, index) in props.items" :key="index">
11
- <div v-if="item.image" class="flex gap-[16px] py-[8px] items-center">
12
- <div>
13
- <Image
14
- width="100"
15
- height="100"
16
- :src="item.image"
17
- class="rounded-[4px]"
18
- />
19
- </div>
20
- <div class="flex flex-col gap-[4px]">
21
- <div class="line-clamp-3 font-body-large">
22
- {{ item.title }}
23
- </div>
24
- <div class="text-primary font-body-small cursor-pointer">
25
- {{ item.author.profile_name }}
26
- </div>
27
- </div>
28
- </div>
29
- <div v-else class="flex flex-col py-[8px] w-[348px] gap-[4px]">
30
- <div class="font-body-large line-clamp-2">
31
- {{ item.title }}
32
- </div>
33
- <div class="text-primary font-body-small cursor-pointer">
34
- {{ item.author.profile_name }}
35
- </div>
36
- <div class="text-gray font-body-medium line-clamp-1">
37
- {{ item.description }}
38
- </div>
39
- </div>
40
- </div>
41
- </div>
42
- <div
43
- v-else
44
- class="w-[348px] flex flex-col gap-[10px] items-center justify-center"
45
- >
46
- <Icon name="pukaad:page-not-found" size="60" class="text-primary" />
47
- <div class="font-body-large">ไม่พบสถานที่</div>
48
- </div>
49
- </div>
50
- </Card>
2
+ <Card variant="outline" width="380">
3
+ <div class="w-auto max-h-[626px] flex flex-col gap-[8px]">
4
+ <div class="flex">
5
+ <div class="text-surface font-title-medium-prominent">
6
+ เรื่องอื่นๆ ที่เกี่ยวข้อง
7
+ </div>
8
+ </div>
9
+ <div v-if="props.items.length > 0">
10
+ <div v-for="(item, index) in props.items" :key="index">
11
+ <div v-if="item.image" class="flex gap-[16px] py-[8px] items-center">
12
+ <div>
13
+ <Image
14
+ width="100"
15
+ height="100"
16
+ :src="item.image"
17
+ class="rounded-[4px]"
18
+ />
19
+ </div>
20
+ <div class="flex flex-col gap-[4px]">
21
+ <div class="line-clamp-3 font-body-large">
22
+ {{ item.title }}
23
+ </div>
24
+ <div class="text-primary font-body-small cursor-pointer">
25
+ {{ item.author.profile_name }}
26
+ </div>
27
+ </div>
28
+ </div>
29
+ <div v-else class="flex flex-col py-[8px] w-[348px] gap-[4px]">
30
+ <div class="font-body-large line-clamp-2">
31
+ {{ item.title }}
32
+ </div>
33
+ <div class="text-primary font-body-small cursor-pointer">
34
+ {{ item.author.profile_name }}
35
+ </div>
36
+ <div class="text-gray font-body-medium line-clamp-1">
37
+ {{ item.description }}
38
+ </div>
39
+ </div>
40
+ </div>
41
+ </div>
42
+ <div
43
+ v-else
44
+ class="w-[348px] flex flex-col gap-[10px] items-center justify-center"
45
+ >
46
+ <Icon name="pukaad:page-not-found" size="60" class="text-primary" />
47
+ <div class="font-body-large">ไม่พบสถานที่</div>
48
+ </div>
49
+ </div>
50
+ </Card>
51
51
  </template>
52
52
 
53
53
  <script setup>
@@ -1,54 +1,54 @@
1
1
  <template>
2
- <Card column-gap="8" variant="outline" width="380">
3
- <template #header>
4
- <div class="flex justify-between items-center">
5
- <div class="font-title-medium-prominent">ที่ไหนน่าสนใจ</div>
6
- <Button
7
- color="primary"
8
- variant="text"
9
- disabled-padding
10
- size="tiny"
11
- append-icon="lucide:chevron-right"
12
- :icon-size="16"
13
- @click="emit('view-all')"
14
- >
15
- ดูทั้งหมด
16
- </Button>
17
- </div>
18
- </template>
19
- <div v-if="!props.items || props.items.length === 0">
20
- <div
21
- class="flex flex-col items-center justify-center h-[392px] gap-[10px]"
22
- >
23
- <Icon name="pukaad:page-not-found" size="60" />
24
- <div class="font-body-large text-gray">ไม่พบข้อมูล</div>
25
- </div>
26
- </div>
27
- <div
28
- v-else
29
- v-for="item in props.items"
30
- :key="item.id"
31
- class="flex items-center gap-[16px] cursor-pointer py-[8px]"
32
- @click="handleClickCard(item)"
33
- >
34
- <Image
35
- :src="item.image"
36
- alt="image"
37
- width="100"
38
- height="56"
39
- class="rounded-[4px]"
40
- />
41
- <div class="flex flex-col gap-[4px]">
42
- <div class="font-body-large max-w-[232px] truncate">
43
- {{ item.title }}
44
- </div>
45
- <div class="flex gap-[8px] text-gray font-body-medium">
46
- <InputRating v-model="item.rating" readonly :rating-size="14" />
47
- {{ item.review_count }} พัน
48
- </div>
49
- </div>
50
- </div>
51
- </Card>
2
+ <Card column-gap="8" variant="outline" width="380">
3
+ <template #header>
4
+ <div class="flex justify-between items-center">
5
+ <div class="font-title-medium-prominent">ที่ไหนน่าสนใจ</div>
6
+ <Button
7
+ color="primary"
8
+ variant="text"
9
+ disabled-padding
10
+ size="tiny"
11
+ append-icon="lucide:chevron-right"
12
+ :icon-size="16"
13
+ @click="emit('view-all')"
14
+ >
15
+ ดูทั้งหมด
16
+ </Button>
17
+ </div>
18
+ </template>
19
+ <div v-if="!props.items || props.items.length === 0">
20
+ <div
21
+ class="flex flex-col items-center justify-center h-[392px] gap-[10px]"
22
+ >
23
+ <Icon name="pukaad:page-not-found" size="60" />
24
+ <div class="font-body-large text-gray">ไม่พบข้อมูล</div>
25
+ </div>
26
+ </div>
27
+ <div
28
+ v-else
29
+ v-for="item in props.items"
30
+ :key="item.id"
31
+ class="flex items-center gap-[16px] cursor-pointer py-[8px]"
32
+ @click="handleClickCard(item)"
33
+ >
34
+ <Image
35
+ :src="item.image"
36
+ alt="image"
37
+ width="100"
38
+ height="56"
39
+ class="rounded-[4px]"
40
+ />
41
+ <div class="flex flex-col gap-[4px]">
42
+ <div class="font-body-large max-w-[232px] truncate">
43
+ {{ item.title }}
44
+ </div>
45
+ <div class="flex gap-[8px] text-gray font-body-medium">
46
+ <InputRating v-model="item.rating" readonly :rating-size="14" />
47
+ {{ item.review_count }} พัน
48
+ </div>
49
+ </div>
50
+ </div>
51
+ </Card>
52
52
  </template>
53
53
 
54
54
  <script setup>