useCart.ts 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. import { changeQuantityApi, getCartListApi, removeCartApi, submitOrderApi } from '~/api/model/cart'
  2. import { numberToTwoDecimals } from '~/utils/number'
  3. const brandCount = ref(0)
  4. const selectedCount = ref(0)
  5. const orderTotal = ref(0)
  6. const checkAll = ref(false)
  7. const isIndeterminate = ref(false)
  8. const submitLoading = ref(false)
  9. const checkedCart = ref<any>([])
  10. const checkedIds = ref<any>([])
  11. const cartList = ref<any>([])
  12. export function useCart() {
  13. /**
  14. * 计算当前id对应list
  15. * @param key
  16. */
  17. const calCheckedGoods = () => {
  18. const checkedList = cartList.value.filter((item: any) => checkedIds.value.includes(item.merchandiseId))
  19. const brandList = checkedList.map((item: any) => item.brandId)
  20. brandCount.value = [...new Set(brandList)].length
  21. selectedCount.value = checkedList.length
  22. let totalSum = 0
  23. checkedList.forEach((item: any) => {
  24. totalSum += item.price * item.quantity
  25. })
  26. orderTotal.value = +totalSum
  27. }
  28. /**
  29. * 全选
  30. * @param val
  31. */
  32. const handleCheckAllChange = (val: boolean) => {
  33. const allIds = cartList.value.map((item: any) => item.merchandiseId)
  34. checkedCart.value = val ? allIds : []
  35. checkedIds.value = val ? allIds : []
  36. isIndeterminate.value = false
  37. calCheckedGoods()
  38. }
  39. /**
  40. * 单个选择
  41. * @param value
  42. */
  43. const handleCheckedChange = (value: string[]) => {
  44. const checkedCount = value.length
  45. checkAll.value = checkedCount === cartList.value.length
  46. checkedIds.value = value
  47. checkedCart.value = value
  48. isIndeterminate.value = checkedCount > 0 && checkedCount < cartList.value.length
  49. calCheckedGoods()
  50. }
  51. const getCartList = async () => {
  52. try {
  53. const result: any = await getCartListApi()
  54. cartList.value = result
  55. // commonStore.setCartGoodsNumber(data.items.length)
  56. }
  57. catch (error) {
  58. console.log(error)
  59. }
  60. }
  61. const removeCart = async (item: any) => {
  62. try {
  63. await removeCartApi({ mid: item.merchandiseId })
  64. cartList.value = cartList.value.filter((items: any) => items.merchandiseId !== item.merchandiseId)
  65. const surplusChecked = checkedIds.value.filter((items: any) => items !== item.merchandiseId)
  66. ElMessage({
  67. message: 'remove cart successfully',
  68. type: 'success',
  69. plain: true,
  70. })
  71. handleCheckedChange(surplusChecked)
  72. }
  73. catch (error) {
  74. console.log(error)
  75. }
  76. }
  77. /**
  78. * 提交订单
  79. */
  80. const submitOrder = async () => {
  81. try {
  82. submitLoading.value = true
  83. await submitOrderApi({ mids: checkedIds.value })
  84. checkAll.value = false
  85. checkedIds.value = []
  86. checkedCart.value = []
  87. selectedCount.value = 0
  88. isIndeterminate.value = false
  89. ElMessage({
  90. message: 'Order Submitted Successfully',
  91. type: 'success',
  92. plain: true,
  93. })
  94. submitLoading.value = false
  95. const router = useRouter()
  96. router.push({ path: '/submit-order' })
  97. }
  98. catch (error) {
  99. console.log(error)
  100. submitLoading.value = false
  101. }
  102. }
  103. const handleChange = async (e: any, item: any) => {
  104. try {
  105. // const res: any = await changeQuantityApi({
  106. // mid: item.merchandiseId,
  107. // quantity: item.quantity,
  108. // })
  109. // item.price = res.price
  110. calCheckedGoods()
  111. }
  112. catch (error) {
  113. console.log(error)
  114. }
  115. }
  116. return {
  117. brandCount,
  118. selectedCount,
  119. checkAll,
  120. isIndeterminate,
  121. checkedCart,
  122. orderTotal,
  123. cartList,
  124. submitLoading,
  125. handleCheckAllChange,
  126. handleChange,
  127. getCartList,
  128. removeCart,
  129. handleCheckedChange,
  130. submitOrder,
  131. }
  132. }