import {makeAutoObservable} from "mobx"; import {http} from "../utils/http"; export class Product { page = 0; pageSize = 10 data = []; total_data = 0; filterSupplier = null; filterCategory = null; filterSubCategory = null; visibleModalProduct = false; visibleModalFilterProduct = false; uploadBtnProduct = false; pageCategories = 0; pageSizeCategories = 10 dataCategories = []; total_dataCategories = 0; pageSubCategories = 0; pageSizeSubCategories = 10 dataSubCategories = []; total_dataSubCategories = 0; constructor(ctx) { this.ctx = ctx; makeAutoObservable(this); } async getData() { const response = await http.get(`/product/all?supplier=${this.filterSupplier}&categories=${this.filterCategory}&categories=${this.filterSubCategory}&page=${this.page}&pageSize=${this.pageSize}`); this.data = response.body.data.map((item, idx) => { item.key = idx; return item }) ?? [] this.total_data = response.body.total_data ?? 0 } async getDataSubCategories() { const response = await http.get(`/product/sub-categories?page=${this.pageSubCategories}&pageSize=${this.pageSizeSubCategories}`); this.dataSubCategories = response.body.data.map((item, idx) => { item.key = idx; return item }) ?? [] this.total_dataSubCategories = response.body.count ?? 0 } async getDataCategories() { const response = await http.get(`/product/categories?page=${this.pageCategories}&pageSize=${this.pageSizeCategories}`); this.dataCategories = response.body.data.map((item, idx) => { item.key = idx; return item }) ?? [] } async create(data) { const response = await http.post('/product').send(data); await this.getData(); return response; } async update(id, data) { const response = await http.put(`/product/${id}`).send(data); await this.getData(); return response; } async delete(id) { const response = await http.del(`/product/${id}`); await this.getData(); return response; } }