mall-uniapp/sheep/store/cart.js

103 lines
2.4 KiB
JavaScript
Raw Normal View History

2022-11-22 07:45:36 +00:00
import { defineStore } from 'pinia';
2023-12-11 04:50:46 +00:00
import CartApi from '@/sheep/api/trade/cart';
2023-12-11 01:24:16 +00:00
const cart = defineStore({
2022-11-22 07:45:36 +00:00
id: 'cart',
state: () => ({
list: [], // 购物车列表
selectedIds: [], // 已选列表
2023-12-11 04:50:46 +00:00
isAllSelected: false, // 是否全选
totalPriceSelected: 0, // 选中项总金额
2022-11-22 07:45:36 +00:00
}),
actions: {
// 获取购物车列表
async getList() {
2023-12-11 04:50:46 +00:00
const { data, code } = await CartApi.getCartList();
if (code === 0) {
this.list = data.validList;
2023-12-11 01:24:16 +00:00
2023-12-11 04:50:46 +00:00
// 计算各种关联属性
this.selectedIds = [];
this.isAllSelected = true;
this.totalPriceSelected = 0;
this.list.forEach((item) => {
if (item.selected) {
this.selectedIds.push(item.id);
this.totalPriceSelected += item.count * item.sku.price;
} else {
this.isAllSelected = false;
}
});
2022-11-22 07:45:36 +00:00
}
},
2023-12-11 01:24:16 +00:00
2022-11-22 07:45:36 +00:00
// 添加购物车
async add(goodsInfo) {
2023-12-11 04:50:46 +00:00
// 添加购物项
const { code } = await CartApi.addCart({
skuId: goodsInfo.id,
count: goodsInfo.goods_num,
2022-11-22 07:45:36 +00:00
});
2023-12-11 04:50:46 +00:00
// 刷新购物车列表
if (code === 0) {
await this.getList();
2022-11-22 07:45:36 +00:00
}
},
2023-12-11 01:24:16 +00:00
2022-11-22 07:45:36 +00:00
// 更新购物车
async update(goodsInfo) {
2023-12-11 04:50:46 +00:00
const { code } = await CartApi.updateCartCount({
id: goodsInfo.goods_id,
count: goodsInfo.goods_num,
2022-11-22 07:45:36 +00:00
});
2023-12-11 04:50:46 +00:00
if (code === 0) {
await this.getList();
2022-11-22 07:45:36 +00:00
}
},
2023-12-11 01:24:16 +00:00
2022-11-22 07:45:36 +00:00
// 移除购物车
async delete(ids) {
2023-12-11 04:50:46 +00:00
const { code } = await CartApi.deleteCart(ids.join(','));
if (code === 0) {
2023-12-11 04:50:46 +00:00
await this.getList();
2022-11-22 07:45:36 +00:00
}
},
2023-12-11 01:24:16 +00:00
2023-12-11 04:50:46 +00:00
// 单选购物车商品
async selectSingle(goodsId) {
const { code } = await CartApi.updateCartSelected({
ids: [goodsId],
selected: !this.selectedIds.includes(goodsId), // 取反
});
if (code === 0) {
await this.getList();
2022-11-22 07:45:36 +00:00
}
},
2023-12-11 04:50:46 +00:00
// 全选购物车商品
async selectAll(flag) {
const { code } = await CartApi.updateCartSelected({
ids: this.list.map((item) => item.id),
selected: flag
});
if (code === 0) {
await this.getList();
2022-11-22 07:45:36 +00:00
}
},
// 清空购物车
2023-12-11 04:50:46 +00:00
async emptyList() {
await this.delete(this.list.map((item) => item.id));
2022-11-22 07:45:36 +00:00
},
},
persist: {
enabled: true,
strategies: [
{
key: 'cart-store',
},
],
},
2023-12-11 01:24:16 +00:00
});
export default cart;