diff --git a/admin-web/src/models/product/productAttrList.js b/admin-web/src/models/product/productAttrList.js index db3b6cc1d..80405882d 100644 --- a/admin-web/src/models/product/productAttrList.js +++ b/admin-web/src/models/product/productAttrList.js @@ -1,5 +1,14 @@ import { message } from 'antd'; -import { productAttrTree, productAttrValueAdd, productAttrPage } from '../../services/product'; +import { + productAttrTree, + productAttrValueAdd, + productAttrPage, + productAttrAdd, + productAttrUpdate, + productAttrUpdateStatus, + productAttrValueUpdate, + productAttrValueUpdateStatus, +} from '../../services/product'; import PaginationHelper from '../../../helpers/PaginationHelper'; export default { @@ -7,33 +16,61 @@ export default { state: { list: [], + // tree: [], attrData: [], pagination: PaginationHelper.defaultPaginationConfig, }, effects: { - // *add({ payload }, { call, put }) { - // const { callback, body } = payload; - // const response = yield call(productCategoryAdd, body); - // if (callback) { - // callback(response); - // } - // yield put({ - // type: 'tree', - // payload: {}, - // }); - // }, - // *update({ payload }, { call, put }) { - // const { callback, body } = payload; - // const response = yield call(productCategoryUpdate, body); - // if (callback) { - // callback(response); - // } - // yield put({ - // type: 'tree', - // payload: {}, - // }); - // }, + *add({ payload }, { call, put }) { + const { onSuccess, onFail, body } = payload; + const response = yield call(productAttrAdd, body); + if (response && response.code === 0) { + onSuccess && onSuccess(); + } else { + onFail && onFail(response); + } + }, + + *update({ payload }, { call, put }) { + const { onSuccess, onFail, body } = payload; + const response = yield call(productAttrUpdate, body); + if (response && response.code === 0) { + onSuccess && onSuccess(); + } else { + onFail && onFail(response); + } + }, + + *value_update({ payload }, { call, put }) { + const { onSuccess, onFail, body } = payload; + const response = yield call(productAttrValueUpdate, body); + if (response && response.code === 0) { + onSuccess && onSuccess(); + } else { + onFail && onFail(response); + } + }, + + *update_status({ payload }, { call, put }) { + const { onSuccess, onFail, body } = payload; + const response = yield call(productAttrUpdateStatus, body); + if (response && response.code === 0) { + onSuccess && onSuccess(); + } else { + onFail && onFail(response); + } + }, + + *value_update_status({ payload }, { call, put }) { + const { onSuccess, onFail, body } = payload; + const response = yield call(productAttrValueUpdateStatus, body); + if (response && response.code === 0) { + onSuccess && onSuccess(); + } else { + onFail && onFail(response); + } + }, // *updateStatus({ payload }, { call, put }) { // const { callback, body } = payload; // const response = yield call(productCategoryUpdateStatus, body); @@ -80,6 +117,17 @@ export default { }, }); }, + + *value_add({ payload }, { call, put }) { + const { onSuccess, onFail, body } = payload; + const response = yield call(productAttrValueAdd, body); + if (response && response.code === 0) { + onSuccess && onSuccess(); + } else { + onFail && onFail(response); + } + }, + *addValue({ payload, callback }, { call, put }) { // debugger; // const {queryParams} = payload; diff --git a/admin-web/src/pages/Product/ProductAttrList.js b/admin-web/src/pages/Product/ProductAttrList.js index 45566077c..50ca26ee2 100644 --- a/admin-web/src/pages/Product/ProductAttrList.js +++ b/admin-web/src/pages/Product/ProductAttrList.js @@ -1,5 +1,5 @@ import React, { PureComponent, Fragment, Component } from 'react'; -import { Form, Card, Table, Button, Divider, Modal, Input } from 'antd'; +import { Form, Card, Table, Button, Divider, Modal, Input, message, Switch, Select } from 'antd'; import moment from 'moment'; import { connect } from 'dva'; import PageHeaderWrapper from '@/components/PageHeaderWrapper'; @@ -7,6 +7,85 @@ import PaginationHelper from '../../../helpers/PaginationHelper'; import styles from './ProductAttrList.less'; const FormItem = Form.Item; +const Option = Select.Option; + +const ValueCreateForm = Form.create()(props => { + const { + valueModalVisible, + form, + handleValueAdd, + handleValueModalVisible, + modalType, + initValues, + tree, + } = props; + + const okHandle = () => { + form.validateFields((err, fieldsValue) => { + if (err) return; + let pid = fieldsValue.pid; + if (fieldsValue.pid) { + pid = pid.split('-')[1]; + fieldsValue.pid = pid; + } + form.resetFields(); + handleValueAdd({ + fields: fieldsValue, + modalType, + initValues, + }); + }); + }; + + const selectStyle = { + width: 200, + }; + + function onTypeChange(event) { + initValues.type = parseInt(event.target.value); + } + + const title = modalType === 'add' ? '添加规格值' : '编辑规格值'; + const okText = modalType === 'add' ? '添加' : '编辑'; + return ( + handleValueModalVisible()} + > + {modalType === 'add' ? ( + + {form.getFieldDecorator('attrId', { + // initialValue: template.durationHour ? template.durationHour : '3', + rules: [ + { + required: true, + message: '请选择规格', + }, + ], + })( + + )} + + ) : null} + + {form.getFieldDecorator('name', { + initialValue: initValues ? initValues.name : null, + rules: [{ required: true, message: '请输入规格值!', min: 2 }], + })()} + + + ); +}); + const CreateForm = Form.create()(props => { const { modalVisible, form, handleAdd, handleModalVisible, modalType, initValues } = props; @@ -59,17 +138,23 @@ const CreateForm = Form.create()(props => { @connect(({ productAttrList, loading }) => ({ productAttrList, attrData: productAttrList.attrData, + tree: productAttrList.tree, loading: loading.models.productAttrList, })) @Form.create() export default class ProductAttrList extends PureComponent { state = { modalVisible: false, + valueModalVisible: false, modalType: 'add', //add or update initValues: {}, }; componentDidMount() { + this.initFetch(); + } + + initFetch = () => { const { dispatch } = this.props; dispatch({ type: 'productAttrList/page', @@ -77,7 +162,133 @@ export default class ProductAttrList extends PureComponent { ...PaginationHelper.defaultPayload, }, }); - } + // const { dispatch } = this.props; + dispatch({ + type: 'productAttrList/tree', + payload: { + ...PaginationHelper.defaultPayload, + }, + }); + }; + + expandedRowRender = record => { + const columns = [ + { + title: '规格值', + dataIndex: 'name', + }, + { + title: '状态', + // dataIndex: 'status', + render: (text, record) => ( + this.switchValueChange(checked, record)} + /> + ), + }, + { + title: '创建时间', + dataIndex: 'createTime', + sorter: true, + render: val => {moment(val).format('YYYY-MM-DD')}, + }, + { + title: '操作', + render: (text, record) => ( + + this.handleValueModalVisible(true, 'update', record)}>编辑 + + {/* this.handleDelete(record)}> + 删除 + */} + + ), + }, + ]; + + return ; + }; + + handleAdd = ({ fields, modalType, initValues }) => { + const { dispatch } = this.props; + if (modalType === 'add') { + dispatch({ + type: 'productAttrList/add', + payload: { + body: { + ...fields, + }, + onSuccess: () => { + message.success('添加成功'); + this.handleModalVisible(); + this.initFetch(); + }, + onFail: response => { + message.warn('添加失败' + response.message); + }, + }, + }); + } else { + dispatch({ + type: 'productAttrList/update', + payload: { + body: { + ...initValues, + ...fields, + }, + onSuccess: () => { + message.success('更新成功'); + this.handleModalVisible(); + this.initFetch(); + }, + onFail: response => { + message.warn('更新失败' + response.message); + }, + }, + }); + } + }; + + handleValueAdd = ({ fields, modalType, initValues }) => { + const { dispatch } = this.props; + if (modalType === 'add') { + dispatch({ + type: 'productAttrList/value_add', + payload: { + body: { + ...fields, + }, + onSuccess: () => { + message.success('添加成功'); + this.handleValueModalVisible(); + this.initFetch(); + }, + onFail: response => { + message.warn('添加失败' + response.message); + }, + }, + }); + } else { + dispatch({ + type: 'productAttrList/value_update', + payload: { + body: { + ...initValues, + ...fields, + }, + onSuccess: () => { + message.success('更新成功'); + this.handleValueModalVisible(); + this.initFetch(); + }, + onFail: response => { + message.warn('更新失败' + response.message); + }, + }, + }); + } + }; handleModalVisible = (flag, modalType, initValues) => { this.setState({ @@ -87,8 +298,50 @@ export default class ProductAttrList extends PureComponent { }); }; + handleValueModalVisible = (flag, modalType, initValues) => { + this.setState({ + valueModalVisible: !!flag, + initValues: initValues || {}, + modalType: modalType || 'add', + }); + }; + + switchValueChange = (checked, record) => { + const { dispatch } = this.props; + dispatch({ + type: 'productAttrList/value_update_status', + payload: { + body: { + id: record.id, + status: checked ? 1 : 2, + }, + onSuccess: () => { + message.success('修改状态成功'); + this.initFetch(); + }, + }, + }); + }; + + switchChange = (checked, record) => { + const { dispatch } = this.props; + dispatch({ + type: 'productAttrList/update_status', + payload: { + body: { + id: record.id, + status: checked ? 1 : 2, + }, + onSuccess: () => { + message.success('修改状态成功'); + this.initFetch(); + }, + }, + }); + }; + render() { - const { attrData, productAttrList, loading, pagination } = this.props; + const { attrData, productAttrList, loading, pagination, tree } = this.props; const columns = [ { title: '规格名称', @@ -96,8 +349,13 @@ export default class ProductAttrList extends PureComponent { }, { title: '状态', - dataIndex: 'status', - render: val => {val === 1 ? '开启' : '禁用'}, + // dataIndex: 'status', + render: (text, record) => ( + this.switchChange(checked, record)} + /> + ), }, { title: '创建时间', @@ -111,15 +369,16 @@ export default class ProductAttrList extends PureComponent { this.handleModalVisible(true, 'update', record)}>编辑 - this.handleDelete(record)}> + this.handleValueModalVisible(true, 'add', {})}>新建规格值 + {/* this.handleDelete(record)}> 删除 - + */} ), }, ]; - const { modalVisible, modalType, initValues } = this.state; + const { modalVisible, modalType, initValues, valueModalVisible } = this.state; const parentMethods = { handleAdd: this.handleAdd, @@ -128,6 +387,14 @@ export default class ProductAttrList extends PureComponent { initValues, }; + const valueFormParentMethods = { + handleValueAdd: this.handleValueAdd, + handleValueModalVisible: this.handleValueModalVisible, + modalType, + initValues, + tree: tree, + }; + return ( @@ -149,9 +416,13 @@ export default class ProductAttrList extends PureComponent { rowKey="id" loading={loading} pagination={pagination} + expandedRowRender={this.expandedRowRender} /> {modalVisible ? : null} + {valueModalVisible ? ( + + ) : null} ); } diff --git a/admin-web/src/services/product.js b/admin-web/src/services/product.js index 0e3014ac9..2236d74fc 100644 --- a/admin-web/src/services/product.js +++ b/admin-web/src/services/product.js @@ -91,12 +91,47 @@ export async function productAttrPage(params) { }); } +export async function productAttrAdd(params) { + return request(`/product-api/admins/attr/add?${stringify(params)}`, { + method: 'POST', + body: {}, + }); +} + +export async function productAttrUpdate(params) { + return request(`/product-api/admins/attr/update?${stringify(params)}`, { + method: 'POST', + body: {}, + }); +} + +export async function productAttrUpdateStatus(params) { + return request(`/product-api/admins/attr/update_status?${stringify(params)}`, { + method: 'POST', + body: {}, + }); +} + export async function productAttrTree(params) { return request(`/product-api/admins/attr/tree?${stringify(params)}`, { method: 'GET', }); } +export async function productAttrValueUpdate(params) { + return request(`/product-api/admins/attr_value/update?${stringify(params)}`, { + method: 'POST', + body: {}, + }); +} + +export async function productAttrValueUpdateStatus(params) { + return request(`/product-api/admins/attr_value/update_status?${stringify(params)}`, { + method: 'POST', + body: {}, + }); +} + export async function productAttrValueAdd(params) { return request(`/product-api/admins/attr_value/add?${stringify(params)}`, { method: 'POST',