@feedmepos/mf-order-setting 0.0.2 → 0.0.6

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 (372) hide show
  1. package/.env.dev +13 -0
  2. package/.env.example +11 -0
  3. package/.env.prod +12 -0
  4. package/.eslintrc.cjs +15 -0
  5. package/.nvmrc +1 -0
  6. package/.prettierrc.json +8 -0
  7. package/.vscode/extensions.json +8 -0
  8. package/README.md +31 -0
  9. package/dist/KioskSettingView-BTDNtWJ1.js +4 -0
  10. package/{app-gcisgtft.js → dist/app-XcwzVa60.js} +7363 -7390
  11. package/dist/app.js +6 -0
  12. package/dist/frontend/mf-order/src/app.d.ts +4 -0
  13. package/dist/frontend/mf-order/src/router/routes.d.ts +3 -0
  14. package/dist/frontend/mf-order/src/views/order-settings/sms/SmsSetting.vue.d.ts +2 -0
  15. package/dist/frontend/mf-order/tsconfig.app.tsbuildinfo +1 -0
  16. package/env.d.ts +95 -0
  17. package/index.html +16 -0
  18. package/package.json +5 -4
  19. package/postcss.config.js +6 -0
  20. package/public/favicon.ico +0 -0
  21. package/src/App.vue +19 -0
  22. package/src/Entry.vue +42 -0
  23. package/src/api/auth/index.ts +20 -0
  24. package/src/api/delivery/index.ts +15 -0
  25. package/src/api/index.ts +171 -0
  26. package/src/api/kiosk/index.ts +22 -0
  27. package/src/api/menu/index.ts +13 -0
  28. package/src/api/order/index.ts +15 -0
  29. package/src/api/order-setting/index.ts +25 -0
  30. package/src/api/public-setting/index.ts +11 -0
  31. package/src/api/remoteOrder/index.ts +142 -0
  32. package/src/api/restaurant-setting/index.ts +55 -0
  33. package/src/api/table-setting/index.ts +30 -0
  34. package/src/app.ts +7 -0
  35. package/src/assets/base.css +6 -0
  36. package/src/assets/images/no-data.svg +35 -0
  37. package/src/assets/logo.svg +1 -0
  38. package/src/assets/main.css +1 -0
  39. package/src/components/GoogleMap.vue +216 -0
  40. package/src/components/RestaurantSelection.vue +34 -0
  41. package/src/components/index.ts +7 -0
  42. package/src/components/snackbar.ts +44 -0
  43. package/src/components/type.ts +103 -0
  44. package/src/composables/index.ts +7 -0
  45. package/src/composables/loading/index.ts +51 -0
  46. package/src/composables/search.ts +18 -0
  47. package/src/helpers/currency.ts +6 -0
  48. package/src/helpers/date.ts +29 -0
  49. package/src/helpers/iteration.ts +87 -0
  50. package/src/helpers/map.ts +92 -0
  51. package/src/helpers/menu.ts +166 -0
  52. package/src/helpers/number.ts +25 -0
  53. package/src/helpers/object.ts +12 -0
  54. package/src/helpers/profile.ts +52 -0
  55. package/src/i18n.ts +43 -0
  56. package/src/index.d.ts +3 -0
  57. package/src/main.ts +77 -0
  58. package/src/modules/kiosk/interface.ts +16 -0
  59. package/src/modules/order-setting/interface.ts +4 -0
  60. package/src/modules/order-setting/kiosk/interface.ts +52 -0
  61. package/src/plugins/google-maps.ts +28 -0
  62. package/src/router/index.ts +10 -0
  63. package/src/router/routes.ts +43 -0
  64. package/src/stores/app/index.ts +58 -0
  65. package/src/stores/iframe/index.ts +23 -0
  66. package/src/stores/kiosk/index.ts +40 -0
  67. package/src/stores/kiosk/mapper.ts +25 -0
  68. package/src/stores/menu/menu.ts +258 -0
  69. package/src/stores/order-setting/index.ts +61 -0
  70. package/src/stores/order-setting/mapper.ts +104 -0
  71. package/src/stores/restaurant/index.ts +138 -0
  72. package/src/stores/table-settings.ts +160 -0
  73. package/src/stores/type.ts +65 -0
  74. package/src/utils/constants/route.ts +15 -0
  75. package/src/utils/number.ts +16 -0
  76. package/src/utils/object.ts +15 -0
  77. package/src/views/all-orders/ActionMenuCell.vue +92 -0
  78. package/src/views/all-orders/FilterRestaurant.vue +71 -0
  79. package/src/views/all-orders/FilterStatus.vue +121 -0
  80. package/src/views/all-orders/FilterStatusMenu.vue +44 -0
  81. package/src/views/all-orders/Orders.vue +524 -0
  82. package/src/views/all-orders/ReflowOrder.vue +105 -0
  83. package/src/views/all-orders/UpdateDeliveryOrderDialog.vue +313 -0
  84. package/src/views/all-orders/order.ts +584 -0
  85. package/src/views/feedme-express/FeedMeExpress.vue +139 -0
  86. package/src/views/feedme-express/FeedMeExpressSummary.vue +62 -0
  87. package/src/views/kiosk/KioskSummary.vue +74 -0
  88. package/src/views/kiosk/KioskView.vue +140 -0
  89. package/src/views/kiosk/devices/KioskDeviceCard.vue +105 -0
  90. package/src/views/kiosk/devices/KioskDeviceDetail.vue +28 -0
  91. package/src/views/kiosk/devices/KioskDevicesView.vue +27 -0
  92. package/src/views/kiosk/devices/KioskOtpDialog.vue +15 -0
  93. package/src/views/kiosk/devices/KioskUnbindConfirm.vue +28 -0
  94. package/src/views/kiosk/settings/KioskDineInSection.vue +86 -0
  95. package/src/views/kiosk/settings/KioskDisplayStandSection.vue +98 -0
  96. package/src/views/kiosk/settings/KioskPickAtCounterSection.vue +25 -0
  97. package/src/views/kiosk/settings/KioskSettingView.vue +61 -0
  98. package/src/views/kiosk/settings/KioskTakeawaySection.vue +39 -0
  99. package/src/views/order-settings/OrderSettingsView.vue +52 -0
  100. package/src/views/order-settings/components/RestaurantSelector.vue +77 -0
  101. package/src/views/order-settings/delivery/DeliverySetting.vue +799 -0
  102. package/src/views/order-settings/delivery/LocalDelivery.vue +0 -0
  103. package/src/views/order-settings/delivery/components/ManualIntegratedDeliverySetting.vue +167 -0
  104. package/src/views/order-settings/delivery/delivery.data.ts +75 -0
  105. package/src/views/order-settings/delivery/delivery.ts +41 -0
  106. package/src/views/order-settings/delivery/inhouse/CurrencyInput.vue +47 -0
  107. package/src/views/order-settings/delivery/inhouse/DeliveryCustomTime.vue +235 -0
  108. package/src/views/order-settings/delivery/inhouse/DeliveryOrder.vue +236 -0
  109. package/src/views/order-settings/delivery/inhouse/DeliveryTime.vue +143 -0
  110. package/src/views/order-settings/delivery/inhouse/InHouseDelivery.vue +186 -0
  111. package/src/views/order-settings/delivery/inhouse/TimePicker.vue +76 -0
  112. package/src/views/order-settings/delivery/inhouse/ZoneDialog.vue +143 -0
  113. package/src/views/order-settings/delivery/integrated-delivery/FeedmeDelivery.vue +244 -0
  114. package/src/views/order-settings/delivery/integrated-delivery/FoodpandaCampaignDialog.vue +110 -0
  115. package/src/views/order-settings/delivery/integrated-delivery/FoodpandaSetting.vue +261 -0
  116. package/src/views/order-settings/delivery/integrated-delivery/GrabfoodSetting.vue +128 -0
  117. package/src/views/order-settings/delivery/integrated-delivery/IntegratedDelivery.vue +272 -0
  118. package/src/views/order-settings/delivery/integrated-delivery/ShopeefoodSetting.vue +135 -0
  119. package/src/views/order-settings/delivery/integrated.data.interface.ts +0 -0
  120. package/src/views/order-settings/dinein/DineInSetting.vue +128 -0
  121. package/src/views/order-settings/dinein/OfflinePaymentTypeDialog.vue +51 -0
  122. package/src/views/order-settings/dinein/OfflinePaymentTypeDialogContent.vue +44 -0
  123. package/src/views/order-settings/dinein/PaymentType.vue +172 -0
  124. package/src/views/order-settings/pickup/AddressInput.vue +48 -0
  125. package/src/views/order-settings/pickup/CustomPayment.vue +84 -0
  126. package/src/views/order-settings/pickup/PaymentSidesheet.vue +167 -0
  127. package/src/views/order-settings/pickup/PickUpPointDialog.vue +125 -0
  128. package/src/views/order-settings/pickup/PickUpPointDialogContent.vue +95 -0
  129. package/src/views/order-settings/pickup/PickUpSetting.vue +233 -0
  130. package/src/views/order-settings/pickup/PickUpSettingDialog.vue +148 -0
  131. package/src/views/order-settings/pickup/PickUpSideSheet.vue +15 -0
  132. package/src/views/order-settings/pickup/Preorder.vue +139 -0
  133. package/src/views/order-settings/servicecharge/RateInput.vue +34 -0
  134. package/src/views/order-settings/servicecharge/ServiceChargeRule.vue +453 -0
  135. package/src/views/order-settings/servicecharge/ServiceChargeSetting.vue +233 -0
  136. package/src/views/order-settings/sms/SmsSetting.vue +162 -0
  137. package/tailwind.config.js +20 -0
  138. package/tsconfig.app.json +25 -0
  139. package/tsconfig.json +18 -0
  140. package/tsconfig.node.json +16 -0
  141. package/vite.config.ts +60 -0
  142. package/KioskSettingView-BRJpaAwI.js +0 -4
  143. package/app.js +0 -5
  144. package/frontend/mf-order/src/app.d.ts +0 -2
  145. package/frontend/mf-order/tsconfig.app.tsbuildinfo +0 -1
  146. package/style.css +0 -1
  147. package/{common → dist/common}/booking/index.d.ts +0 -0
  148. package/{common → dist/common}/config/bank/index.d.ts +0 -0
  149. package/{common → dist/common}/config/bank/malaysia.d.ts +0 -0
  150. package/{common → dist/common}/config/bank/singapore.d.ts +0 -0
  151. package/{common → dist/common}/config/index.d.ts +0 -0
  152. package/{common → dist/common}/convertor/index.d.ts +0 -0
  153. package/{common → dist/common}/index.d.ts +0 -0
  154. package/{common → dist/common}/number/index.d.ts +0 -0
  155. package/{common → dist/common}/sms/index.d.ts +0 -0
  156. package/{common → dist/common}/util/index.d.ts +0 -0
  157. package/{favicon.ico → dist/favicon.ico} +0 -0
  158. package/{frontend → dist/frontend}/mf-order/src/App.vue.d.ts +0 -0
  159. package/{frontend/mf-order/src/views/all-orders/Orders.vue.d.ts → dist/frontend/mf-order/src/Entry.vue.d.ts} +0 -0
  160. package/{frontend → dist/frontend}/mf-order/src/api/auth/index.d.ts +0 -0
  161. package/{frontend → dist/frontend}/mf-order/src/api/delivery/index.d.ts +0 -0
  162. package/{frontend → dist/frontend}/mf-order/src/api/index.d.ts +0 -0
  163. package/{frontend → dist/frontend}/mf-order/src/api/kiosk/index.d.ts +0 -0
  164. package/{frontend → dist/frontend}/mf-order/src/api/menu/index.d.ts +0 -0
  165. package/{frontend → dist/frontend}/mf-order/src/api/order/index.d.ts +0 -0
  166. package/{frontend → dist/frontend}/mf-order/src/api/order-setting/index.d.ts +0 -0
  167. package/{frontend → dist/frontend}/mf-order/src/api/public-setting/index.d.ts +0 -0
  168. package/{frontend → dist/frontend}/mf-order/src/api/remoteOrder/index.d.ts +0 -0
  169. package/{frontend → dist/frontend}/mf-order/src/api/restaurant-setting/index.d.ts +0 -0
  170. package/{frontend → dist/frontend}/mf-order/src/api/table-setting/index.d.ts +0 -0
  171. package/{frontend → dist/frontend}/mf-order/src/components/GoogleMap.vue.d.ts +0 -0
  172. package/{frontend → dist/frontend}/mf-order/src/components/RestaurantSelection.vue.d.ts +0 -0
  173. package/{frontend → dist/frontend}/mf-order/src/components/index.d.ts +0 -0
  174. package/{frontend → dist/frontend}/mf-order/src/components/snackbar.d.ts +0 -0
  175. package/{frontend → dist/frontend}/mf-order/src/components/type.d.ts +0 -0
  176. package/{frontend → dist/frontend}/mf-order/src/composables/index.d.ts +0 -0
  177. package/{frontend → dist/frontend}/mf-order/src/composables/loading/index.d.ts +0 -0
  178. package/{frontend → dist/frontend}/mf-order/src/composables/search.d.ts +0 -0
  179. package/{frontend → dist/frontend}/mf-order/src/helpers/currency.d.ts +0 -0
  180. package/{frontend → dist/frontend}/mf-order/src/helpers/date.d.ts +0 -0
  181. package/{frontend → dist/frontend}/mf-order/src/helpers/iteration.d.ts +0 -0
  182. package/{frontend → dist/frontend}/mf-order/src/helpers/map.d.ts +0 -0
  183. package/{frontend → dist/frontend}/mf-order/src/helpers/menu.d.ts +0 -0
  184. package/{frontend → dist/frontend}/mf-order/src/helpers/number.d.ts +0 -0
  185. package/{frontend → dist/frontend}/mf-order/src/helpers/object.d.ts +0 -0
  186. package/{frontend → dist/frontend}/mf-order/src/helpers/profile.d.ts +0 -0
  187. package/{frontend → dist/frontend}/mf-order/src/i18n.d.ts +0 -0
  188. package/{frontend → dist/frontend}/mf-order/src/main.d.ts +0 -0
  189. package/{frontend → dist/frontend}/mf-order/src/modules/kiosk/interface.d.ts +0 -0
  190. package/{frontend → dist/frontend}/mf-order/src/modules/order-setting/interface.d.ts +0 -0
  191. package/{frontend → dist/frontend}/mf-order/src/modules/order-setting/kiosk/interface.d.ts +0 -0
  192. package/{frontend → dist/frontend}/mf-order/src/plugins/google-maps.d.ts +0 -0
  193. package/{frontend → dist/frontend}/mf-order/src/router/index.d.ts +0 -0
  194. package/{frontend → dist/frontend}/mf-order/src/stores/app/index.d.ts +0 -0
  195. package/{frontend → dist/frontend}/mf-order/src/stores/iframe/index.d.ts +0 -0
  196. package/{frontend → dist/frontend}/mf-order/src/stores/kiosk/index.d.ts +0 -0
  197. package/{frontend → dist/frontend}/mf-order/src/stores/kiosk/mapper.d.ts +0 -0
  198. package/{frontend → dist/frontend}/mf-order/src/stores/menu/menu.d.ts +0 -0
  199. package/{frontend → dist/frontend}/mf-order/src/stores/order-setting/index.d.ts +0 -0
  200. package/{frontend → dist/frontend}/mf-order/src/stores/order-setting/mapper.d.ts +0 -0
  201. package/{frontend → dist/frontend}/mf-order/src/stores/restaurant/index.d.ts +0 -0
  202. package/{frontend → dist/frontend}/mf-order/src/stores/table-settings.d.ts +0 -0
  203. package/{frontend → dist/frontend}/mf-order/src/stores/type.d.ts +0 -0
  204. package/{frontend → dist/frontend}/mf-order/src/utils/constants/route.d.ts +0 -0
  205. package/{frontend → dist/frontend}/mf-order/src/utils/number.d.ts +0 -0
  206. package/{frontend → dist/frontend}/mf-order/src/utils/object.d.ts +0 -0
  207. package/{frontend → dist/frontend}/mf-order/src/views/all-orders/ActionMenuCell.vue.d.ts +0 -0
  208. package/{frontend → dist/frontend}/mf-order/src/views/all-orders/FilterRestaurant.vue.d.ts +0 -0
  209. package/{frontend → dist/frontend}/mf-order/src/views/all-orders/FilterStatus.vue.d.ts +0 -0
  210. package/{frontend → dist/frontend}/mf-order/src/views/all-orders/FilterStatusMenu.vue.d.ts +0 -0
  211. package/{frontend/mf-order/src/views/feedme-express/FeedMeExpress.vue.d.ts → dist/frontend/mf-order/src/views/all-orders/Orders.vue.d.ts} +0 -0
  212. package/{frontend → dist/frontend}/mf-order/src/views/all-orders/ReflowOrder.vue.d.ts +0 -0
  213. package/{frontend → dist/frontend}/mf-order/src/views/all-orders/UpdateDeliveryOrderDialog.vue.d.ts +0 -0
  214. package/{frontend → dist/frontend}/mf-order/src/views/all-orders/order.d.ts +2 -2
  215. package/{frontend/mf-order/src/views/kiosk/KioskView.vue.d.ts → dist/frontend/mf-order/src/views/feedme-express/FeedMeExpress.vue.d.ts} +0 -0
  216. package/{frontend → dist/frontend}/mf-order/src/views/feedme-express/FeedMeExpressSummary.vue.d.ts +0 -0
  217. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/KioskSummary.vue.d.ts +0 -0
  218. package/{frontend/mf-order/src/views/order-settings/OrderSettingsView.vue.d.ts → dist/frontend/mf-order/src/views/kiosk/KioskView.vue.d.ts} +0 -0
  219. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/devices/KioskDeviceCard.vue.d.ts +0 -0
  220. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/devices/KioskDeviceDetail.vue.d.ts +0 -0
  221. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/devices/KioskDevicesView.vue.d.ts +0 -0
  222. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/devices/KioskOtpDialog.vue.d.ts +0 -0
  223. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/devices/KioskUnbindConfirm.vue.d.ts +0 -0
  224. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/settings/KioskDineInSection.vue.d.ts +0 -0
  225. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/settings/KioskDisplayStandSection.vue.d.ts +0 -0
  226. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/settings/KioskPickAtCounterSection.vue.d.ts +0 -0
  227. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/settings/KioskSettingView.vue.d.ts +0 -0
  228. package/{frontend → dist/frontend}/mf-order/src/views/kiosk/settings/KioskTakeawaySection.vue.d.ts +0 -0
  229. package/{frontend/mf-order/src/views/order-settings/delivery/LocalDelivery.vue.d.ts → dist/frontend/mf-order/src/views/order-settings/OrderSettingsView.vue.d.ts} +0 -0
  230. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/components/RestaurantSelector.vue.d.ts +0 -0
  231. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/DeliverySetting.vue.d.ts +0 -0
  232. package/{frontend/mf-order/src/views/order-settings/dinein/DineInSetting.vue.d.ts → dist/frontend/mf-order/src/views/order-settings/delivery/LocalDelivery.vue.d.ts} +0 -0
  233. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/components/ManualIntegratedDeliverySetting.vue.d.ts +0 -0
  234. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/delivery.d.ts +0 -0
  235. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/delivery.data.d.ts +0 -0
  236. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/inhouse/CurrencyInput.vue.d.ts +0 -0
  237. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/inhouse/DeliveryCustomTime.vue.d.ts +0 -0
  238. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/inhouse/DeliveryOrder.vue.d.ts +0 -0
  239. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/inhouse/DeliveryTime.vue.d.ts +0 -0
  240. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/inhouse/InHouseDelivery.vue.d.ts +0 -0
  241. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/inhouse/TimePicker.vue.d.ts +0 -0
  242. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/inhouse/ZoneDialog.vue.d.ts +0 -0
  243. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/integrated-delivery/FeedmeDelivery.vue.d.ts +0 -0
  244. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/integrated-delivery/FoodpandaCampaignDialog.vue.d.ts +0 -0
  245. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/integrated-delivery/FoodpandaSetting.vue.d.ts +0 -0
  246. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/integrated-delivery/GrabfoodSetting.vue.d.ts +0 -0
  247. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/integrated-delivery/IntegratedDelivery.vue.d.ts +0 -0
  248. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/integrated-delivery/ShopeefoodSetting.vue.d.ts +0 -0
  249. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/delivery/integrated.data.interface.d.ts +0 -0
  250. package/{frontend/mf-order/src/views/order-settings/pickup/PickUpSideSheet.vue.d.ts → dist/frontend/mf-order/src/views/order-settings/dinein/DineInSetting.vue.d.ts} +0 -0
  251. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/dinein/OfflinePaymentTypeDialog.vue.d.ts +0 -0
  252. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/dinein/OfflinePaymentTypeDialogContent.vue.d.ts +0 -0
  253. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/dinein/PaymentType.vue.d.ts +0 -0
  254. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/pickup/AddressInput.vue.d.ts +0 -0
  255. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/pickup/CustomPayment.vue.d.ts +0 -0
  256. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/pickup/PaymentSidesheet.vue.d.ts +0 -0
  257. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/pickup/PickUpPointDialog.vue.d.ts +0 -0
  258. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/pickup/PickUpPointDialogContent.vue.d.ts +0 -0
  259. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/pickup/PickUpSetting.vue.d.ts +0 -0
  260. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/pickup/PickUpSettingDialog.vue.d.ts +0 -0
  261. package/{frontend/mf-order/src/views/order-settings/servicecharge/ServiceChargeSetting.vue.d.ts → dist/frontend/mf-order/src/views/order-settings/pickup/PickUpSideSheet.vue.d.ts} +0 -0
  262. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/pickup/Preorder.vue.d.ts +0 -0
  263. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/servicecharge/RateInput.vue.d.ts +0 -0
  264. package/{frontend → dist/frontend}/mf-order/src/views/order-settings/servicecharge/ServiceChargeRule.vue.d.ts +0 -0
  265. package/{frontend/mf-order/src/views/order-settings/sms/SmsSetting.vue.d.ts → dist/frontend/mf-order/src/views/order-settings/servicecharge/ServiceChargeSetting.vue.d.ts} +0 -0
  266. package/{package → dist/package}/entity/booking/booking.do.d.ts +0 -0
  267. package/{package → dist/package}/entity/booking/booking.dto.d.ts +0 -0
  268. package/{package → dist/package}/entity/booking/booking.enum.d.ts +0 -0
  269. package/{package → dist/package}/entity/business/business.dto.d.ts +0 -0
  270. package/{package → dist/package}/entity/clickup/clickup.dto.d.ts +0 -0
  271. package/{package → dist/package}/entity/cursor/cursor.dto.d.ts +0 -0
  272. package/{package → dist/package}/entity/delivery/delivery.do.d.ts +0 -0
  273. package/{package → dist/package}/entity/delivery/delivery.dto.d.ts +28 -28
  274. package/{package → dist/package}/entity/delivery/delivery.enum.d.ts +0 -0
  275. package/{package → dist/package}/entity/delivery/gateway/grab.dto.d.ts +0 -0
  276. package/{package → dist/package}/entity/delivery/gateway/grab.enum.d.ts +0 -0
  277. package/{package → dist/package}/entity/delivery/gateway/kosmo.dto.d.ts +0 -0
  278. package/{package → dist/package}/entity/delivery/gateway/kosmo.enum.d.ts +0 -0
  279. package/{package → dist/package}/entity/delivery/gateway/manual.dto.d.ts +0 -0
  280. package/{package → dist/package}/entity/delivery/gateway/manual.enum.d.ts +0 -0
  281. package/{package → dist/package}/entity/delivery/gateway/pandago.dto.d.ts +2 -2
  282. package/{package → dist/package}/entity/delivery/gateway/pandago.enum.d.ts +0 -0
  283. package/{package → dist/package}/entity/delivery/linked-delivery.do.d.ts +0 -0
  284. package/{package → dist/package}/entity/food-court/food-court.do.d.ts +0 -0
  285. package/{package → dist/package}/entity/food-court/food-court.dto.d.ts +0 -0
  286. package/{package → dist/package}/entity/food-court/food-court.enum.d.ts +0 -0
  287. package/{package → dist/package}/entity/food-court/order.do.d.ts +0 -0
  288. package/{package → dist/package}/entity/food-court/order.dto.d.ts +0 -0
  289. package/{package → dist/package}/entity/general/dateTime.dto.d.ts +0 -0
  290. package/{package → dist/package}/entity/general/number.dto.d.ts +0 -0
  291. package/{package → dist/package}/entity/general/search.dto.d.ts +0 -0
  292. package/{package → dist/package}/entity/incoming-order/incoming-order-to-bill.dto.d.ts +0 -0
  293. package/{package → dist/package}/entity/incoming-order/incoming-order.do.d.ts +0 -0
  294. package/{package → dist/package}/entity/incoming-order/incoming-order.dto.d.ts +0 -0
  295. package/{package → dist/package}/entity/incoming-order/incoming-order.enum.d.ts +0 -0
  296. package/{package → dist/package}/entity/index.d.ts +0 -0
  297. package/{package → dist/package}/entity/kiosk/kiosk.do.d.ts +0 -0
  298. package/{package → dist/package}/entity/kiosk/kiosk.dto.d.ts +0 -0
  299. package/{package → dist/package}/entity/kiosk/marketing/marketing.dto.d.ts +0 -0
  300. package/{package → dist/package}/entity/kiosk/scanner/scanner.do.d.ts +0 -0
  301. package/{package → dist/package}/entity/kiosk/scanner/scanner.dto.d.ts +0 -0
  302. package/{package → dist/package}/entity/kiosk/scanner/scanner.enum.d.ts +0 -0
  303. package/{package → dist/package}/entity/marketing/marketing.dto.d.ts +0 -0
  304. package/{package → dist/package}/entity/member/member.dto.d.ts +0 -0
  305. package/{package → dist/package}/entity/money/money.enum.d.ts +0 -0
  306. package/{package → dist/package}/entity/order/dine-in/dine-in.do.d.ts +0 -0
  307. package/{package → dist/package}/entity/order/dine-in/dine-in.dto.d.ts +0 -0
  308. package/{package → dist/package}/entity/order/dine-in/qr.do.d.ts +0 -0
  309. package/{package → dist/package}/entity/order/dine-in/reservation.do.d.ts +0 -0
  310. package/{package → dist/package}/entity/order/dine-in/reservation.dto.d.ts +0 -0
  311. package/{package → dist/package}/entity/order/effects/effect.dto.d.ts +0 -0
  312. package/{package → dist/package}/entity/order/effects/effect.enum.d.ts +0 -0
  313. package/{package → dist/package}/entity/order/menu/menu.dto.d.ts +0 -0
  314. package/{package → dist/package}/entity/order/order-item/order-item.dto.d.ts +0 -0
  315. package/{package → dist/package}/entity/order/order.do.d.ts +0 -0
  316. package/{package → dist/package}/entity/order/order.dto.d.ts +4 -4
  317. package/{package → dist/package}/entity/order/order.enum.d.ts +0 -0
  318. package/{package → dist/package}/entity/order/payment/payment.dto.d.ts +0 -0
  319. package/{package → dist/package}/entity/order/pickup/pickup.do.d.ts +0 -0
  320. package/{package → dist/package}/entity/order/pickup/pickup.dto.d.ts +0 -0
  321. package/{package → dist/package}/entity/order/timeslot/timeslot.dto.d.ts +0 -0
  322. package/{package → dist/package}/entity/order/timeslot/timeslot.enum.d.ts +0 -0
  323. package/{package → dist/package}/entity/order-platform/base-integration.do.d.ts +0 -0
  324. package/{package → dist/package}/entity/order-platform/foodpanda/foodpanda-menu.dto.d.ts +48 -48
  325. package/{package → dist/package}/entity/order-platform/foodpanda/foodpanda-order.do.d.ts +16 -16
  326. package/{package → dist/package}/entity/order-platform/foodpanda/foodpanda-order.dto.d.ts +6 -6
  327. package/{package → dist/package}/entity/order-platform/foodpanda/foodpanda-settings.do.d.ts +0 -0
  328. package/{package → dist/package}/entity/order-platform/foodpanda/foodpanda-settings.dto.d.ts +0 -0
  329. package/{package → dist/package}/entity/order-platform/foodpanda/foodpanda.enum.d.ts +0 -0
  330. package/{package → dist/package}/entity/order-platform/grabfood/grabfood-menu.do.d.ts +0 -0
  331. package/{package → dist/package}/entity/order-platform/grabfood/grabfood-order.do.d.ts +0 -0
  332. package/{package → dist/package}/entity/order-platform/grabfood/grabfood-settings.do.d.ts +0 -0
  333. package/{package → dist/package}/entity/order-platform/grabfood/grabfood.dto.d.ts +0 -0
  334. package/{package → dist/package}/entity/order-platform/grabfood/grabfood.enum.d.ts +0 -0
  335. package/{package → dist/package}/entity/order-platform/menu.dto.d.ts +0 -0
  336. package/{package → dist/package}/entity/order-platform/order-platform.dto.d.ts +0 -0
  337. package/{package → dist/package}/entity/order-platform/order-platform.enum.d.ts +0 -0
  338. package/{package → dist/package}/entity/order-platform/shopeefood/shopeefood-menu.do.d.ts +0 -0
  339. package/{package → dist/package}/entity/order-platform/shopeefood/shopeefood-order.do.d.ts +20 -20
  340. /package/{package → dist/package}/entity/order-platform/shopeefood/shopeefood-order.dto.d.ts +0 -0
  341. /package/{package → dist/package}/entity/order-platform/shopeefood/shopeefood-settings.do.d.ts +0 -0
  342. /package/{package → dist/package}/entity/order-platform/shopeefood/shopeefood-settings.dto.d.ts +0 -0
  343. /package/{package → dist/package}/entity/order-platform/shopeefood/shopeefood.enum.d.ts +0 -0
  344. /package/{package → dist/package}/entity/order-setting/customization/color.do.d.ts +0 -0
  345. /package/{package → dist/package}/entity/order-setting/customization/color.dto.d.ts +0 -0
  346. /package/{package → dist/package}/entity/order-setting/kiosk/kiosk.do.d.ts +0 -0
  347. /package/{package → dist/package}/entity/order-setting/kiosk/kiosk.dto.d.ts +0 -0
  348. /package/{package → dist/package}/entity/order-setting/order-setting.do.d.ts +0 -0
  349. /package/{package → dist/package}/entity/order-setting/order-setting.dto.d.ts +0 -0
  350. /package/{package → dist/package}/entity/order-setting/queue/queue.do.d.ts +0 -0
  351. /package/{package → dist/package}/entity/order-setting/queue/queue.dto.d.ts +0 -0
  352. /package/{package → dist/package}/entity/order-setting/reservation/reservation.do.d.ts +0 -0
  353. /package/{package → dist/package}/entity/order-setting/reservation/reservation.dto.d.ts +0 -0
  354. /package/{package → dist/package}/entity/order-setting/sequence/sequence.do.d.ts +0 -0
  355. /package/{package → dist/package}/entity/order-setting/sequence/sequence.dto.d.ts +0 -0
  356. /package/{package → dist/package}/entity/order-setting/sms/sms.do.d.ts +0 -0
  357. /package/{package → dist/package}/entity/order-setting/sms/sms.dto.d.ts +0 -0
  358. /package/{package → dist/package}/entity/order-setting/sms/sms.enum.d.ts +0 -0
  359. /package/{package → dist/package}/entity/order-setting/upselling/upselling.do.d.ts +0 -0
  360. /package/{package → dist/package}/entity/order-setting/upselling/upselling.dto.d.ts +0 -0
  361. /package/{package → dist/package}/entity/order-setting/v3/v3.do.d.ts +0 -0
  362. /package/{package → dist/package}/entity/order-setting/v3/v3.dto.d.ts +0 -0
  363. /package/{package → dist/package}/entity/pagination/pagination.dto.d.ts +0 -0
  364. /package/{package → dist/package}/entity/payment/payment.enum.d.ts +0 -0
  365. /package/{package → dist/package}/entity/printer/printer.do.d.ts +0 -0
  366. /package/{package → dist/package}/entity/queue/queue.do.d.ts +0 -0
  367. /package/{package → dist/package}/entity/queue/queue.dto.d.ts +0 -0
  368. /package/{package → dist/package}/entity/queue/queue.enum.d.ts +0 -0
  369. /package/{package → dist/package}/entity/restaurant/restaurant.dto.d.ts +0 -0
  370. /package/{package → dist/package}/entity/user/user.do.d.ts +0 -0
  371. /package/{package → dist/package}/entity/websocket/websocket.dto.d.ts +0 -0
  372. /package/{package → dist/package}/entity/websocket/websocket.enum.d.ts +0 -0
@@ -0,0 +1,453 @@
1
+ <script setup lang="ts">
2
+ import { sentenceCase } from 'change-case'
3
+ import { type PropType, computed, onMounted, ref } from 'vue'
4
+ import type { CategorizedItem } from '@/helpers/menu'
5
+ import RateInput from './RateInput.vue'
6
+ import type { FdoServiceChargeRule, FdoTable } from '@feedmepos/core/entity'
7
+ import type { AdjustmentAmount } from '@/helpers/number'
8
+ import { F_SERVICE_CHARGE_ORDER_TYPE } from '@feedmepos/core/entity'
9
+
10
+ const props = defineProps({
11
+ modelValue: {
12
+ type: Object as PropType<FdoServiceChargeRule>,
13
+ required: true
14
+ },
15
+ inclusive: {
16
+ type: Boolean,
17
+ required: true
18
+ },
19
+ chargeBeforeDiscount: {
20
+ type: Boolean,
21
+ required: true
22
+ },
23
+ items: {
24
+ type: Array as PropType<CategorizedItem[]>,
25
+ required: true
26
+ },
27
+ tables: {
28
+ type: Array as PropType<FdoTable[]>,
29
+ required: true
30
+ },
31
+ isLoadingTable: {
32
+ type: Boolean,
33
+ required: true
34
+ },
35
+ isLoadingMenu: {
36
+ type: Boolean,
37
+ required: true
38
+ }
39
+ })
40
+
41
+ const emits = defineEmits<{
42
+ (event: 'update:model-value', v: FdoServiceChargeRule): void
43
+ (event: 'delete'): void
44
+ }>()
45
+
46
+ const itemSelected = computed(() => {
47
+ if (props.isLoadingMenu) return 'Loading menu'
48
+ if (!props.items.length) return 'No available item'
49
+ const items = props.modelValue.condition.items
50
+ if (!items) return 'All'
51
+ return `${items.length} Item`
52
+ })
53
+
54
+ const tableSelected = computed(() => {
55
+ if (props.isLoadingTable) return 'Loading table'
56
+ if (!props.tables.length) return 'No available table'
57
+ const tables = props.modelValue.condition.tables
58
+ if (!tables) return 'All'
59
+ return `${tables.length} Table`
60
+ })
61
+
62
+ enum ServiceChargeOrderType {
63
+ dineIn = 'DINE_IN',
64
+ takeaway = 'TAKEAWAY',
65
+ inHouseDelivery = 'IN_HOUSE_DELIVERY',
66
+ deliveryCompany = 'DELIVERY_COMPANY',
67
+ pickup = 'PICKUP'
68
+ }
69
+
70
+ const diningOptions = computed(() => {
71
+ return Object.values(ServiceChargeOrderType).map((v) => ({
72
+ label: sentenceCase(v),
73
+ value: v
74
+ }))
75
+ })
76
+
77
+ const diningValue = computed(() => {
78
+ if (!props.modelValue.condition.orderType) return diningOptions.value.map((v) => v.value)
79
+ return props.modelValue.condition.orderType
80
+ })
81
+
82
+ let initialValue = props.modelValue.condition.items
83
+ if (!initialValue) {
84
+ initialValue = props.items.reduce<string[]>((pv, category) => {
85
+ pv = [...pv, ...category.items.map((item) => item._id)]
86
+ return pv
87
+ }, [])
88
+ }
89
+
90
+ let initialValueTable = props.modelValue.condition.tables || props.tables.map((table) => table.name)
91
+ if (!initialValueTable) {
92
+ initialValueTable = props.tables.map((table) => table.name)
93
+ }
94
+
95
+ const itemValue = ref<string[]>(initialValue)
96
+ const tableValue = ref<string[]>(initialValueTable)
97
+
98
+ function updateItems() {
99
+ sideSheetItem.value = false
100
+ emits('update:model-value', {
101
+ ...props.modelValue,
102
+ condition: {
103
+ ...props.modelValue.condition,
104
+ items: itemValue.value
105
+ }
106
+ })
107
+ }
108
+
109
+ function updateTable() {
110
+ sideSheetTable.value = false
111
+ emits('update:model-value', {
112
+ ...props.modelValue,
113
+ condition: {
114
+ ...props.modelValue.condition,
115
+ tables: tableValue.value
116
+ }
117
+ })
118
+ }
119
+
120
+ function modifyItems(items: string[], parentId: string) {
121
+ itemValue.value = items
122
+ const parentItem = props.items.find((item) => item.id === parentId)
123
+ if (parentItem) {
124
+ const parentSelected = parentItem.items.every((subItem) =>
125
+ itemValue.value.includes(subItem._id)
126
+ )
127
+ selectedCategoryItems.value[parentId] = parentSelected
128
+ }
129
+ }
130
+
131
+ function updateRate(v: AdjustmentAmount) {
132
+ emits('update:model-value', {
133
+ ...props.modelValue,
134
+ rate: v
135
+ })
136
+ }
137
+
138
+ function updateDiningOption(options: F_SERVICE_CHARGE_ORDER_TYPE[]) {
139
+ emits('update:model-value', {
140
+ ...props.modelValue,
141
+ condition: {
142
+ ...props.modelValue.condition,
143
+ orderType: options.length === diningOptions.value.length ? undefined : options
144
+ }
145
+ })
146
+ }
147
+
148
+ const sideSheetItem = ref<boolean>(false)
149
+ const sideSheetTable = ref<boolean>(false)
150
+
151
+ function toggleSideSheet() {
152
+ sideSheetItem.value = true
153
+ }
154
+ function toggleSideSheetTable() {
155
+ sideSheetTable.value = true
156
+ }
157
+
158
+ const parent = ref<boolean>(false)
159
+ const nestedVal = ref<F_SERVICE_CHARGE_ORDER_TYPE[]>(diningValue.value)
160
+
161
+ const checkboxChildren = computed(() => diningOptions.value)
162
+
163
+ function handleParentUpdate(ev: boolean) {
164
+ if (ev) {
165
+ nestedVal.value = checkboxChildren.value.map((item) => item.value)
166
+ } else {
167
+ nestedVal.value = []
168
+ }
169
+ parent.value = ev
170
+ updateDiningOption(nestedVal.value)
171
+ }
172
+
173
+ function handleChildUpdate(ev: F_SERVICE_CHARGE_ORDER_TYPE[]) {
174
+ nestedVal.value = ev
175
+ parent.value = ev.length === checkboxChildren.value.length
176
+ updateDiningOption(ev)
177
+ }
178
+
179
+ const parentTable = ref<boolean>(false)
180
+ const nestedValTable = ref<string[]>(initialValueTable)
181
+
182
+ const checkboxChildrenTable = computed(() => {
183
+ const tables = props.tables.map((table) => table.name)
184
+ return Array.isArray(tables) ? tables : []
185
+ })
186
+
187
+ function handleParentUpdateTable(ev: boolean) {
188
+ if (Array.isArray(checkboxChildrenTable.value)) {
189
+ ev ? (nestedValTable.value = checkboxChildrenTable.value) : (nestedValTable.value = [])
190
+ parentTable.value = ev
191
+ tableValue.value = nestedValTable.value
192
+ }
193
+ }
194
+
195
+ function handleChildUpdateTable(ev: string[]) {
196
+ nestedValTable.value = Array.isArray(ev) ? ev : []
197
+ parentTable.value = nestedValTable.value.length === checkboxChildrenTable.value.length
198
+ tableValue.value = ev
199
+ }
200
+
201
+ onMounted(() => {
202
+ parent.value = nestedVal.value.length === checkboxChildren.value.length
203
+
204
+ if (Array.isArray(nestedValTable.value) && Array.isArray(checkboxChildrenTable.value)) {
205
+ parentTable.value = nestedValTable.value.length === checkboxChildrenTable.value.length
206
+ }
207
+
208
+ if (props.items.length > 0) {
209
+ selectedCategoryItems.value = props.items.reduce(
210
+ (acc, item) => {
211
+ const allSubItemsSelected = item.items.every((subItem) =>
212
+ itemValue.value.includes(subItem._id)
213
+ )
214
+ acc[item.id ?? ''] = allSubItemsSelected
215
+ return acc
216
+ },
217
+ {} as Record<string, boolean>
218
+ )
219
+ }
220
+
221
+ initializeMenuState(filteredItem.value);
222
+
223
+ })
224
+
225
+ const selectedCategoryItems = ref<Record<string, boolean>>({})
226
+
227
+ function handleCategorySelection(categoryId: string, isSelected: boolean) {
228
+ selectedCategoryItems.value = {
229
+ ...selectedCategoryItems.value,
230
+ [categoryId]: isSelected
231
+ }
232
+ if (isSelected) {
233
+ itemValue.value = [
234
+ ...itemValue.value,
235
+ ...(props.items.find((item) => item.id === categoryId)?.items.map((subItem) => subItem._id) ||
236
+ [])
237
+ ]
238
+ } else {
239
+ itemValue.value = itemValue.value.filter(
240
+ (id) =>
241
+ !props.items
242
+ .find((item) => item.id === categoryId)
243
+ ?.items.map((subItem) => subItem._id)
244
+ .includes(id)
245
+ )
246
+ }
247
+ }
248
+
249
+ function isIndeterminate(parentId: string): boolean {
250
+ const parentItem = props.items.find((item) => item.id === parentId)
251
+ if (!parentItem) return false
252
+
253
+ const selectedSubItemsCount = parentItem.items.filter((subItem) =>
254
+ itemValue.value.includes(subItem._id)
255
+ ).length
256
+ return selectedSubItemsCount > 0 && selectedSubItemsCount < parentItem.items.length
257
+ }
258
+
259
+ const searchValueTable = ref('')
260
+
261
+ const filteredTable = computed(() =>
262
+ props.tables.filter((e) =>
263
+ searchValueTable.value
264
+ ? e.name.toLocaleLowerCase().includes(searchValueTable.value.toLocaleLowerCase())
265
+ : true
266
+ )
267
+ )
268
+
269
+ const searchValueItem = ref('')
270
+
271
+ const filteredItem = computed(() => {
272
+ return props.items
273
+ .map((item) => {
274
+ const filteredSubItems = item.items.filter((subItem) =>
275
+ searchValueItem.value
276
+ ? subItem.name.toLowerCase().includes(searchValueItem.value.toLowerCase())
277
+ : true
278
+ )
279
+
280
+ return {
281
+ ...item,
282
+ items: filteredSubItems
283
+ }
284
+ })
285
+ .filter((item) => item.items.length > 0)
286
+ })
287
+
288
+ const showTable = ref(true)
289
+ function toggleShowTable() {
290
+ showTable.value = !showTable.value
291
+ }
292
+
293
+ const showMenuState = ref<Record<string, boolean>>({})
294
+
295
+ function toggleShowMenu(itemId: number) {
296
+ showMenuState.value[itemId] = !showMenuState.value[itemId]
297
+ }
298
+
299
+ function initializeMenuState(items: any[]) {
300
+ showMenuState.value = items.reduce((acc, _, index) => {
301
+ acc[index] = true;
302
+ return acc;
303
+ }, {} as Record<number, boolean>);
304
+ }
305
+
306
+ </script>
307
+
308
+ <template>
309
+ <div class="flex items-center gap-7 mb-3">
310
+ <RateInput :model-value="modelValue.rate" @update:model-value="updateRate" />
311
+ <FmButton append-icon="delete" variant="tertiary" @click="emits('delete')" />
312
+ </div>
313
+ <div class="flex items-center justify-between">
314
+ <div class="font-semibold mb-3">Select item</div>
315
+ <FmButton variant="plain" :label="itemSelected" size="lg" @click="toggleSideSheet" />
316
+ </div>
317
+
318
+ <FmSideSheet header="Select item" :maxWidth="600" dismiss-away v-model="sideSheetItem">
319
+ <div>
320
+ <div class="text-fm-color-typo-secondary mt-5 mb-5 flex flex-row">
321
+ {{ props.modelValue.condition.items?.length ?? initialValue?.length }} product(s) selected
322
+ <FmSearch v-model:model-value="searchValueItem" class="ml-auto" placeholder="Search" />
323
+ </div>
324
+
325
+ <div v-for="(item, index) in filteredItem" :key="index" class="flex flex-col mb-6">
326
+ <FmCard variant="outlined" class="p-5">
327
+ <div class="fm-corner-radius-lg flex flex-col">
328
+ <div class="flex flex-row">
329
+ <div class="flex flex-row">
330
+ <FmCheckbox
331
+ :model-value="selectedCategoryItems[item.id ?? '']"
332
+ value=""
333
+ :indeterminate="isIndeterminate(item.id ?? '')"
334
+ @update:model-value="handleCategorySelection(item.id ?? '', $event)"
335
+ />
336
+ <div class="font-bold ml-2">{{ item.name }}</div>
337
+ </div>
338
+ <FmButton
339
+ v-if="showMenuState[index]"
340
+ icon="expand_less"
341
+ variant="tertiary"
342
+ class="ml-auto"
343
+ @click="toggleShowMenu(index)"
344
+ />
345
+ <FmButton
346
+ v-if="!showMenuState[index]"
347
+ icon="expand_more"
348
+ variant="tertiary"
349
+ class="ml-auto"
350
+ @click="toggleShowMenu(index)"
351
+ />
352
+ </div>
353
+ <div class="flex flex-col pl-6" v-if="showMenuState[index]">
354
+ <FmCheckbox
355
+ v-for="(subItem, subIndex) in item.items"
356
+ :key="subIndex"
357
+ :model-value="itemValue"
358
+ :label="subItem.name"
359
+ :value="subItem._id"
360
+ @update:model-value="(values: string[]) => modifyItems(values, item.id ?? '')"
361
+ />
362
+ </div>
363
+ </div>
364
+ </FmCard>
365
+ </div>
366
+ </div>
367
+ <template #side-sheet-footer>
368
+ <div class="flex gap-8 items-center justify-start">
369
+ <FmButton variant="primary" label="Confirm" size="lg" @click="updateItems" />
370
+ <FmButton variant="secondary" label="Cancel" size="lg" @click="sideSheetItem = false" />
371
+ </div>
372
+ </template>
373
+ </FmSideSheet>
374
+
375
+ <div class="flex items-center justify-between">
376
+ <div class="font-semibold mb-3">Select table</div>
377
+ <FmButton variant="plain" :label="tableSelected" size="lg" @click="toggleSideSheetTable" />
378
+ </div>
379
+ <FmSideSheet header="Select table" :maxWidth="600" dismiss-away v-model="sideSheetTable">
380
+ <div class="text-fm-color-typo-secondary mt-5 mb-5 flex flex-row">
381
+ {{ props.modelValue.condition.tables?.length ?? props.tables.length }} table(s) selected
382
+ <FmSearch v-model:model-value="searchValueTable" class="ml-auto" placeholder="Search" />
383
+ </div>
384
+
385
+ <FmCard variant="outlined" class="p-5">
386
+ <div class="flex flex-row">
387
+ <FmCheckbox
388
+ :value="parentTable"
389
+ :model-value="parentTable"
390
+ label="All"
391
+ :indeterminate="
392
+ nestedValTable.length > 0 && nestedValTable.length < checkboxChildrenTable.length
393
+ "
394
+ @update:model-value="handleParentUpdateTable"
395
+ />
396
+ <FmButton
397
+ v-if="showTable"
398
+ icon="expand_less"
399
+ variant="tertiary"
400
+ @click="toggleShowTable"
401
+ class="ml-auto"
402
+ />
403
+ <FmButton
404
+ v-if="!showTable"
405
+ icon="expand_more"
406
+ variant="tertiary"
407
+ @click="toggleShowTable"
408
+ class="ml-auto"
409
+ />
410
+ </div>
411
+ <div class="fm-corner-radius-lg flex flex-col">
412
+ <div
413
+ v-for="(item, index) in filteredTable"
414
+ :key="index"
415
+ class="flex flex-col pl-6"
416
+ v-if="showTable"
417
+ >
418
+ <FmCheckbox
419
+ :model-value="nestedValTable"
420
+ :label="item.name"
421
+ :value="item.name"
422
+ @update:model-value="handleChildUpdateTable"
423
+ />
424
+ </div>
425
+ </div>
426
+ </FmCard>
427
+ <template #side-sheet-footer>
428
+ <div class="flex gap-8 items-center justify-start">
429
+ <FmButton variant="primary" label="Confirm" size="lg" @click="updateTable" />
430
+ <FmButton variant="secondary" label="Cancel" size="lg" @click="sideSheetTable = false" />
431
+ </div>
432
+ </template>
433
+ </FmSideSheet>
434
+
435
+ <div>Apply for</div>
436
+ <div class="flex flex-col">
437
+ <FmCheckbox
438
+ v-model="parent"
439
+ label="All"
440
+ value="all"
441
+ :indeterminate="nestedVal.length > 0 && nestedVal.length < diningOptions.length"
442
+ @update:model-value="handleParentUpdate"
443
+ />
444
+ <FmCheckbox
445
+ v-for="(item, i) in diningOptions"
446
+ :key="i"
447
+ v-model="nestedVal"
448
+ :label="item.label"
449
+ :value="item.value"
450
+ @update:model-value="handleChildUpdate"
451
+ />
452
+ </div>
453
+ </template>
@@ -0,0 +1,233 @@
1
+ <template>
2
+ <RestaurantSelector :model-value="currentRestaurant?._id ?? undefined"/>
3
+
4
+ <div class="p-[1.5rem] flex flex-col gap-5">
5
+ <FmCard variant="outlined" class="p-5 w-2/3">
6
+ <div class="flex-grow fm-typo-en-title-sm-800 mb-3">Enable Service Charge</div>
7
+ <FmSwitch
8
+ v-model="data.active"
9
+ value="first"
10
+ sublabel="Make your own rules to omit change based on different conditions such as restaurant, dining option, items, slot, etc."
11
+ label="Service charge"
12
+ label-placement="right"
13
+ @update:model-value=""
14
+ :disabled="!canUseServiceCharge"
15
+ />
16
+ <div v-if="!canUseServiceCharge" class="fm-typo-en-body-md-400 text-fm-color-typo-error ml-14">
17
+ * Service Charge required POS version 4.0.0 or higher.
18
+ </div>
19
+
20
+ <div class="flex flex-col gap-5 m-5" v-if="data.active">
21
+ <FmRadioGroup
22
+ :model-value="chargeTime"
23
+ label="Charge when"
24
+ @update:model-value="updateChargeWhen"
25
+ >
26
+ <FmRadio value="beforeDiscount" label="Before bill discount" />
27
+ <FmRadio value="afterDiscount" label="After bill discount" />
28
+ </FmRadioGroup>
29
+ <RateInput :model-value="data.rate" @update:model-value="handleUpdateRate" />
30
+
31
+ <FmRadioGroup :model-value="chargeValue" label="Charge" @update:model-value="updateInclusive">
32
+ <FmRadio value="exclusive" label="Exclusive" />
33
+ <FmRadio value="inclusive" label="Inclusive" />
34
+ </FmRadioGroup>
35
+ </div>
36
+ </FmCard>
37
+ </div>
38
+ <div v-if="data.active">
39
+ <div class="flex flex-col gap-5 m-5">
40
+ <div class="flex-grow fm-typo-en-title-sm-800 mb-3 mt-3">Custom Service Charge</div>
41
+ <div class="flex flex-wrap gap-5">
42
+ <div v-for="(rule, index) in data.rules" :key="index">
43
+ <FmCard variant="outlined" class="w-full">
44
+ <FmCardSection>
45
+ <ServiceChargeRule
46
+ :model-value="rule"
47
+ :inclusive="data.inclusive"
48
+ :charge-before-discount="isBeforeDiscountBoolean"
49
+ :items="menuStore.categorizedItems"
50
+ :tables="tableSettingStore.tables"
51
+ :is-loading-menu="isLoadingMenu"
52
+ :is-loading-table="isLoadingTables"
53
+ @delete="deleteRule(index)"
54
+ @update:model-value="(v: FdoServiceChargeRule) => updateRule(index, v)"
55
+ />
56
+ </FmCardSection>
57
+ </FmCard>
58
+ </div>
59
+
60
+ <div class="w-1/5">
61
+ <FmCard variant="outlined" class="w-full border-dashed flex items-center justify-center h-full">
62
+ <FmCardSection class="flex items-center justify-center w-full">
63
+ <FmButton
64
+ variant="plain"
65
+ label="Add service charge"
66
+ icon="add"
67
+ @click="createRule"
68
+ class="border fm-corner-radius-lg border-fm-color-primary"
69
+ />
70
+ </FmCardSection>
71
+ </FmCard>
72
+ </div>
73
+ </div>
74
+ </div>
75
+ </div>
76
+
77
+ <div class="fm-corner-radius-lg flex flex-col gap-5 m-5">
78
+ <FmButton
79
+ variant="primary"
80
+ label="Save Setting"
81
+ class="mr-auto"
82
+ @click="updateServiceChargeSetting"
83
+ />
84
+ </div>
85
+ </template>
86
+
87
+ <script setup lang="ts">
88
+ import type { RestaurantSettingDoc } from '@/api/restaurant-setting'
89
+ import { useLoading } from '@/composables/loading'
90
+ import { useMenuStore } from '@/stores/menu/menu'
91
+ import { useRestaurantStore } from '@/stores/restaurant'
92
+ import {
93
+ F_FEATURE,
94
+ type FdoServiceChargeRule,
95
+ type FdoServiceChargeSetting
96
+ } from '@feedmepos/core/entity'
97
+ import { useCoreStore } from '@feedmepos/mf-common'
98
+ import { computed, onMounted, ref, watch } from 'vue'
99
+ import RestaurantSelector from '../components/RestaurantSelector.vue'
100
+ import RateInput from './RateInput.vue'
101
+ import { percentToAdjustment, type AdjustmentAmount } from '@/helpers/number'
102
+ import { useTableSettingStore } from '@/stores/table-settings'
103
+ import ServiceChargeRule from './ServiceChargeRule.vue'
104
+ import { Pos } from '@feedmepos/core'
105
+
106
+ const isLoadingMenu = ref(false)
107
+ const isBeforeDiscountBoolean = computed(() => {
108
+ return Boolean(data.value.beforeDiscount)
109
+ })
110
+ function handleUpdateRate(newRate: AdjustmentAmount) {
111
+ data.value.rate = newRate
112
+ }
113
+
114
+ function initData(): FdoServiceChargeSetting {
115
+ return {
116
+ active: false,
117
+ inclusive: false,
118
+ rate: percentToAdjustment(0),
119
+ rules: [],
120
+ beforeDiscount: false
121
+ }
122
+ }
123
+
124
+ const { currentRestaurant } = useCoreStore()
125
+
126
+ const data = ref<FdoServiceChargeSetting>(initData())
127
+ const restaurantStore = useRestaurantStore()
128
+ const canUseServiceCharge = computed(() => {
129
+ if (!currentRestaurant) return false
130
+ const res = Pos.canUse({
131
+ feature: F_FEATURE.enum.taxAndServiceChargeV4,
132
+ posVersion: currentRestaurant.value?.posVersion ?? ''
133
+ })
134
+ return res === true
135
+ })
136
+
137
+ const beforeDiscountKey = 'beforeDiscount'
138
+ const afterDiscountKey = 'afterDiscount'
139
+ const inclusiveKey = 'inclusive'
140
+ const exclusiveKey = 'exclusive'
141
+
142
+ const chargeTime = computed(() => {
143
+ return data.value.beforeDiscount ? beforeDiscountKey : afterDiscountKey
144
+ })
145
+
146
+ const chargeValue = computed(() => {
147
+ return data.value.inclusive ? inclusiveKey : exclusiveKey
148
+ })
149
+
150
+ function updateChargeWhen(key: string) {
151
+ data.value.beforeDiscount = key === beforeDiscountKey
152
+ if (data.value.beforeDiscount) updateInclusive(exclusiveKey)
153
+ }
154
+
155
+ function updateInclusive(inclusiveValue: string) {
156
+ let inclusive = false
157
+ if (inclusiveValue === inclusiveKey) {
158
+ inclusive = true
159
+ }
160
+
161
+ data.value.inclusive = inclusive
162
+ data.value.rules = data.value.rules.map((rule) => ({
163
+ ...rule,
164
+ inclusive: inclusive
165
+ }))
166
+ }
167
+
168
+ function createRule() {
169
+ data.value.rules.push({
170
+ rate: data.value.rate,
171
+ inclusive: data.value.inclusive,
172
+ condition: {}
173
+ })
174
+ }
175
+
176
+ function updateRule(index: number, rule: FdoServiceChargeRule) {
177
+ data.value.rules[index] = rule
178
+ }
179
+
180
+ function deleteRule(index: number) {
181
+ data.value.rules.splice(index, 1)
182
+ }
183
+
184
+ import { useSnackbarFunctions } from '@/components/snackbar'
185
+ const { showSuccess } = useSnackbarFunctions()
186
+
187
+ const menuStore = useMenuStore()
188
+ const { startAsyncCall } = useLoading()
189
+ async function updateServiceChargeSetting() {
190
+ await startAsyncCall(async () => {
191
+ await restaurantStore.updateServiceCharge(data.value)
192
+ showSuccess('Service charge setting updated. ')
193
+ })
194
+ }
195
+
196
+
197
+ function initialize(restaurantSetting?: RestaurantSettingDoc) {
198
+ if (restaurantSetting?.serviceChargeSetting) {
199
+ const cloned = restaurantSetting.serviceChargeSetting
200
+ data.value = {
201
+ ...cloned,
202
+ beforeDiscount: cloned.beforeDiscount === undefined ? true : cloned.beforeDiscount
203
+ }
204
+ } else {
205
+ data.value = initData()
206
+ }
207
+ }
208
+
209
+ const isLoadingTables = ref(false)
210
+ const tableSettingStore = useTableSettingStore()
211
+
212
+ onMounted(async () => {
213
+ const resId = currentRestaurant.value?._id
214
+ if (resId) {
215
+ await restaurantStore.readRestaurantSetting(resId)
216
+ const restaurantSetting = restaurantStore.restaurantSettings[resId]
217
+ initialize(restaurantSetting)
218
+ await startAsyncCall(tableSettingStore.readTables)
219
+ }
220
+ })
221
+
222
+ watch(
223
+ () => currentRestaurant.value,
224
+ async (newValue) => {
225
+ if (newValue) {
226
+ const restaurantSetting = restaurantStore.restaurantSettings[newValue._id]
227
+ initialize(restaurantSetting)
228
+ await startAsyncCall(tableSettingStore.readTables)
229
+ }
230
+ },
231
+ { immediate: true }
232
+ )
233
+ </script>