diff --git a/src/components/product-select/script.js b/src/components/product-select/script.js index a40b8162..f094466a 100644 --- a/src/components/product-select/script.js +++ b/src/components/product-select/script.js @@ -1,4 +1,4 @@ -import { Component, Prop, Vue } from "vue-property-decorator"; +import { Component, Emit, Prop, Vue } from "vue-property-decorator"; import Model from "@/models/admin/products"; @Component @@ -30,7 +30,8 @@ export default class ProductSelect extends Vue { this.items = items; } + @Emit() change(value) { - this.$emit("change", value); + return value; } } diff --git a/src/views/ads/list/form/index.vue b/src/views/ads/list/form/index.vue index 2939541f..06376827 100644 --- a/src/views/ads/list/form/index.vue +++ b/src/views/ads/list/form/index.vue @@ -60,77 +60,4 @@ - + diff --git a/src/views/ads/list/form/script.js b/src/views/ads/list/form/script.js new file mode 100644 index 00000000..24b19185 --- /dev/null +++ b/src/views/ads/list/form/script.js @@ -0,0 +1,72 @@ +import { Component, Vue } from "vue-property-decorator"; +import FormMixin from "view-ui-admin/src/mixins/form"; + +const module = "ads"; + +@Component({ + mixins: [FormMixin] +}) +export default class ListForm extends Vue { + data() { + return { + cForm: { + id: 0, + modal: false, + loading: true, + model: this.getFormInitModel(), + rules: { + title: [ + { + required: true, + message: "标题不能为空" + } + ], + pictureId: [ + { + required: true, + message: "图片不能为空" + } + ] + } + } + }; + } + + getFormInitModel() { + return { + status: 1 + }; + } + + show(detail) { + this.cForm.modal = true; + + if (detail && detail.id) { + this.cForm.id = detail.id; + this.initFormFields(detail); + } else { + this.cForm.id = 0; + } + } + + submit() { + this.$refs.form.validate(async valid => { + if (valid) { + const { id, model } = this.cForm; + const { data } = await this.$store.dispatch( + `${module}/${id ? "put" : "post"}`, + { + id, + body: model + } + ); + + this.cForm.modal = false; + this.$Message.success(`${id ? "编辑" : "新增"}成功`); + this.$emit("get-list", data); + } + + this.fixFormButtonLoading(); + }); + } +} diff --git a/src/views/ads/list/index.vue b/src/views/ads/list/index.vue index 4b4e9683..3beb2431 100644 --- a/src/views/ads/list/index.vue +++ b/src/views/ads/list/index.vue @@ -62,196 +62,4 @@ - + diff --git a/src/views/ads/list/script.js b/src/views/ads/list/script.js new file mode 100644 index 00000000..e6cc1eb2 --- /dev/null +++ b/src/views/ads/list/script.js @@ -0,0 +1,191 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import ListForm from "./form"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; + +const module = "ads"; +const initWhere = { + status: { + $eq: "" + }, + title: { + $like: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin], + components: { + "c-list-form": ListForm + }, + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth, OrderAction } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "图片", + width: 118, + render: (h, { row }) => { + return h("c-list-image", { + props: { + src: this.$helpers.getImageUrl({ + id: row.pictureId, + width: 80, + height: 80 + }) + } + }); + } + }, + { + title: "标题", + key: "title", + minWidth: ListColumnWidth.Title + }, + { + title: "链接", + key: "link", + width: 300 + }, + { + title: "状态", + width: 80, + render: (h, { row }) => + h( + "span", + null, + this.$helpers.getItem( + this.dicts.PublishStatus, + "value", + row.status + )["label"] + ) + }, + { + title: "操作", + key: "action", + width: 340, + render: (h, { row }) => + h("div", [ + h( + "Button", + { + on: { + click: () => { + this.$refs.form.show(row); + } + } + }, + "编辑" + ), + h("c-dropdown", { + props: { + width: 90, + title: "修改状态", + options: this.dicts.PublishStatus + }, + on: { + click: action => { + this.changeStatus(row.id, action); + } + } + }), + h("c-dropdown", { + attrs: { + title: "排序", + options: OrderAction + }, + on: { + click: action => { + this.order(row.id, action); + } + } + }), + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere, + order: [["order", "DESC"]] + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } + + async changeStatus(id, action) { + await this.$store.dispatch(`${module}/put`, { + id, + body: { + status: action + } + }); + this.$Message.success("修改状态成功"); + this.getList(); + } + + async order(id, action) { + await this.$store.dispatch(`${module}/postAction`, { + id, + action: "order", + query: { + where: this.listSearchWhere || initWhere + }, + body: { action } + }); + + this.$Message.success("排序成功"); + this.getList(); + } +} diff --git a/src/views/articles/form/index.vue b/src/views/articles/form/index.vue index b06dba82..90b1228f 100644 --- a/src/views/articles/form/index.vue +++ b/src/views/articles/form/index.vue @@ -77,78 +77,4 @@ - + diff --git a/src/views/articles/form/script.js b/src/views/articles/form/script.js new file mode 100644 index 00000000..96ddd56f --- /dev/null +++ b/src/views/articles/form/script.js @@ -0,0 +1,73 @@ +import { Component, Vue } from "vue-property-decorator"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import FormMixin from "view-ui-admin/src/mixins/form"; +import { mapState } from "vuex"; + +const module = "articles"; + +@Component({ + mixins: [RouteParamsMixin, FormMixin], + computed: mapState({ + detail: state => state[module].detail + }) +}) +export default class extends Vue { + data() { + return { + cForm: { + model: this.getFormInitModel(), + rules: { + title: [ + { + required: true, + message: "标题不能为空" + } + ], + content: [ + { + required: true, + message: "内容不能为空" + } + ] + } + } + }; + } + + created() { + this.id && this.getDetail(module, this.id); + } + + getFormInitModel() { + return { + originalPrice: 0, + price: 0, + stock: 0, + status: 1, + content: "" + }; + } + + submit() { + this.$refs.form.validate(async valid => { + if (valid) { + const { + model: { id, ...restModel } + } = this.cForm; + const { data } = await this.$store.dispatch( + `${module}/${id ? "put" : "post"}`, + { + id, + body: restModel + } + ); + + this.cForm.modal = false; + this.$Message.success(`${id ? "编辑" : "新增"}成功`); + this.$emit("get-list", data); + } + + this.fixFormButtonLoading(); + }); + } +} diff --git a/src/views/articles/list/index.vue b/src/views/articles/list/index.vue index a04853b4..3606f5f5 100644 --- a/src/views/articles/list/index.vue +++ b/src/views/articles/list/index.vue @@ -74,206 +74,4 @@ - + diff --git a/src/views/articles/list/script.js b/src/views/articles/list/script.js new file mode 100644 index 00000000..39d7b6f0 --- /dev/null +++ b/src/views/articles/list/script.js @@ -0,0 +1,201 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; +import AllCategoriesListMixin from "view-ui-admin/src/mixins/all-categories-list"; + +const module = "articles"; + +const initWhere = { + title: { + $like: "" + }, + categoryId: { + $eq: "" + }, + status: { + $eq: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin, AllCategoriesListMixin], + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth, OrderAction } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "标题", + key: "title", + minWidth: ListColumnWidth.Title + }, + { + title: "分类", + width: ListColumnWidth.Category, + render: (h, { row }) => + h("span", this.getCategoryNameById(row.categoryId, false)) + }, + { + title: "发布时间", + width: ListColumnWidth.CreatedAt, + render: (h, { row }) => h("span", this.$time.getTime(row.createdAt)) + }, + { + title: "标签", + width: 100, + render: (h, { row }) => { + let tags = []; + + if (row.hot) { + tags.push("热门"); + } + + if (row.top) { + tags.push("置顶"); + } + + return h("span", tags.join("; ")); + } + }, + { + title: "状态", + width: 80, + render: (h, { row }) => + h( + "span", + null, + this.$helpers.getItem( + this.dicts.PublishStatus, + "value", + row.status + )["label"] + ) + }, + { + title: "操作", + key: "action", + width: 340, + render: (h, { row }) => + h("div", [ + h( + "Button", + { + props: { + to: `/${this.alias}/articles/list/form/${row.id}` + } + }, + "编辑" + ), + h("c-dropdown", { + props: { + width: 90, + title: "修改状态", + options: this.dicts.PublishStatus + }, + on: { + click: action => { + this.changeStatus(row.id, action); + } + } + }), + h("c-dropdown", { + props: { + title: "排序", + options: OrderAction + }, + on: { + click: action => { + this.order(row.id, action); + } + } + }), + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere, + order: [ + ["top", "DESC"], + ["order", "DESC"] + ] + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } + + async changeStatus(id, action) { + await this.$store.dispatch(`${module}/put`, { + id, + body: { + status: action + } + }); + this.$Message.success("修改状态成功"); + this.getList(); + } + + async order(id, action) { + await this.$store.dispatch(`${module}/postAction`, { + id, + action: "order", + query: { + where: this.listSearchWhere || initWhere + }, + body: { action } + }); + + this.$Message.success("排序成功"); + this.getList(); + } +} diff --git a/src/views/brands/list/form/index.vue b/src/views/brands/list/form/index.vue index 34a22235..57d4b16b 100644 --- a/src/views/brands/list/form/index.vue +++ b/src/views/brands/list/form/index.vue @@ -59,77 +59,4 @@ - + diff --git a/src/views/brands/list/form/script.js b/src/views/brands/list/form/script.js new file mode 100644 index 00000000..2a2dd876 --- /dev/null +++ b/src/views/brands/list/form/script.js @@ -0,0 +1,72 @@ +import { Component, Vue } from "vue-property-decorator"; +import FormMixin from "view-ui-admin/src/mixins/form"; + +const module = "brands"; + +@Component({ + mixins: [FormMixin] +}) +export default class BrandsListForm extends Vue { + data() { + return { + cForm: { + id: 0, + modal: false, + loading: true, + model: this.getFormInitModel(), + rules: { + name: [ + { + required: true, + message: "名称不能为空" + } + ], + logoId: [ + { + required: true, + message: "Logo 不能为空" + } + ] + } + } + }; + } + + getFormInitModel() { + return { + status: 1 + }; + } + + show(detail) { + this.cForm.modal = true; + + if (detail && detail.id) { + this.cForm.id = detail.id; + this.initFormFields(detail); + } else { + this.cForm.id = 0; + } + } + + submit() { + this.$refs.form.validate(async valid => { + if (valid) { + const { id, model } = this.cForm; + const { data } = await this.$store.dispatch( + `${module}/${id ? "put" : "post"}`, + { + id, + body: model + } + ); + + this.cForm.modal = false; + this.$Message.success(`${id ? "编辑" : "新增"}成功`); + this.$emit("get-list", data); + } + + this.fixFormButtonLoading(); + }); + } +} diff --git a/src/views/brands/list/index.vue b/src/views/brands/list/index.vue index de2939b4..1adb197a 100644 --- a/src/views/brands/list/index.vue +++ b/src/views/brands/list/index.vue @@ -57,195 +57,4 @@ diff --git a/src/views/brands/list/script.js b/src/views/brands/list/script.js new file mode 100644 index 00000000..965d96da --- /dev/null +++ b/src/views/brands/list/script.js @@ -0,0 +1,191 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import BrandsListForm from "./form"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; + +const module = "brands"; +const initWhere = { + status: { + $eq: "" + }, + name: { + $like: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin], + components: { + "c-brands-list-form": BrandsListForm + }, + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth, OrderAction } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "Logo", + width: 118, + render: (h, { row }) => { + return h("c-list-image", { + props: { + src: this.$helpers.getImageUrl({ + id: row.logoId, + width: 80, + height: 80 + }) + } + }); + } + }, + { + title: "名称", + key: "name", + minWidth: ListColumnWidth.Title + }, + { + title: "链接", + key: "link", + width: 300 + }, + { + title: "状态", + width: 80, + render: (h, { row }) => + h( + "span", + null, + this.$helpers.getItem( + this.dicts.PublishStatus, + "value", + row.status + )["label"] + ) + }, + { + title: "操作", + key: "action", + width: 340, + render: (h, { row }) => + h("div", [ + h( + "Button", + { + on: { + click: () => { + this.$refs.form.show(row); + } + } + }, + "编辑" + ), + h("c-dropdown", { + props: { + width: 90, + title: "修改状态", + options: this.dicts.PublishStatus + }, + on: { + click: action => { + this.changeStatus(row.id, action); + } + } + }), + h("c-dropdown", { + attrs: { + title: "排序", + options: OrderAction + }, + on: { + click: action => { + this.order(row.id, action); + } + } + }), + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere, + order: [["order", "DESC"]] + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } + + async changeStatus(id, action) { + await this.$store.dispatch(`${module}/put`, { + id, + body: { + status: action + } + }); + this.$Message.success("修改状态成功"); + this.getList(); + } + + async order(id, action) { + await this.$store.dispatch(`${module}/postAction`, { + id, + action: "order", + query: { + where: this.listSearchWhere || initWhere + }, + body: { action } + }); + + this.$Message.success("排序成功"); + this.getList(); + } +} diff --git a/src/views/categories/list/index.vue b/src/views/categories/list/index.vue index f0fea6d6..df9d955d 100644 --- a/src/views/categories/list/index.vue +++ b/src/views/categories/list/index.vue @@ -108,291 +108,4 @@ diff --git a/src/views/categories/list/script.js b/src/views/categories/list/script.js new file mode 100644 index 00000000..fceda3d4 --- /dev/null +++ b/src/views/categories/list/script.js @@ -0,0 +1,287 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; +import FormMixin from "view-ui-admin/src/mixins/form"; + +const module = "categories"; +const initWhere = { + parentIds: [0], + name: { + $like: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin, FormMixin], + computed: { + ...mapState({ + list: state => state[module].list, + parentDetail: state => state[module].detail + }), + levels() { + return this.$consts.CategoryLevel[this.$route.params.alias]; + }, + isParent() { + const listSearchWhere = this.listSearchWhere; + + return ( + listSearchWhere && + listSearchWhere.parentIds && + listSearchWhere.parentIds[listSearchWhere.parentIds.length - 1] !== 0 + ); + } + } +}) +export default class extends Vue { + data() { + const { ListColumnWidth, OrderAction, CategoryLevel } = this.$consts; + + const getLevels = () => { + return CategoryLevel[this.$route.params.alias]; + }; + + return { + parents: [], + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "图标", + width: 118, + render: (h, { row }) => { + return row.iconId + ? h("c-list-image", { + props: { + src: this.$helpers.getImageUrl({ + id: row.iconId, + width: 80, + height: 80 + }) + } + }) + : h("span", "无"); + } + }, + { + title: "名称", + key: "name", + minWidth: ListColumnWidth.Title + }, + { + title: "操作", + key: "action", + width: getLevels() === 1 ? 245 : 340, + render: (h, { row }) => + h("div", [ + h( + "Button", + { + on: { + click: () => { + this.showForm(row); + } + } + }, + "编辑" + ), + this.levels === 2 + ? h( + "Button", + { + on: { + click: () => { + this.manageChild(row.id); + } + } + }, + "管理子分类" + ) + : null, + h("c-dropdown", { + props: { + title: "排序", + options: OrderAction + }, + on: { + click: action => { + this.order(row.id, action); + } + } + }), + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + }, + cForm: { + id: 0, + modal: false, + model: {}, + loading: true, + rules: { + name: [ + { + required: true, + message: "名称不能为空" + } + ] + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + this.getParentDetail(); + next(); + } + + async created() { + this.$store.dispatch(`${module}/resetList`); + this.initListSearchWhere(initWhere); + this.getList(); + this.getParentDetail(); + } + + getParentDetail() { + if (this.listSearchWhere && this.listSearchWhere.parentIds) { + const id = this.listSearchWhere.parentIds[ + this.listSearchWhere.parentIds.length - 1 + ]; + id && this.$store.dispatch(`${module}/getDetail`, { id }); + } + } + + getList() { + const { name, parentIds = [0] } = this.listSearchWhere || initWhere; + + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: { + parentId: { $eq: parentIds[parentIds.length - 1] || null }, + name, + alias: this.alias + }, + order: [["order", "DESC"]] + } + }); + } + + async manageChild(id) { + const parentIds = + this.listSearchWhere && this.listSearchWhere.parentIds + ? this.$helpers.deepCopy(this.listSearchWhere.parentIds) + : [0]; + + if (parentIds[parentIds.length - 1] !== id) { + parentIds.push(id); + this.$router.push({ + query: { + listSearchWhere: JSON.stringify({ + ...initWhere, + parentIds: parentIds + }) + } + }); + } + } + + gotoParent() { + const parentIds = this.$helpers.deepCopy(this.listSearchWhere.parentIds); + + parentIds.pop(); + + this.$router.push({ + query: { + listSearchWhere: JSON.stringify({ ...initWhere, parentIds }) + } + }); + } + + showForm(detail) { + this.cForm.modal = true; + + if (detail.id) { + this.cForm.id = detail.id; + this.initFormFields(detail); + } else { + this.cForm.id = 0; + } + } + + async confirmDelete(id) { + await this.$store.dispatch(`${module}/delete`, { id }); + this.$Message.success("删除成功!"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } + + async order(id, action) { + const { name } = this.listSearchWhere || initWhere; + + await this.$store.dispatch(`${module}/postAction`, { + id, + action: "order", + query: { + where: { + parentId: this.isParent ? this.parentDetail.id : 0, + name, + alias: this.alias + } + }, + body: { action } + }); + + this.$Message.success("排序成功"); + this.getList(); + } + + submit() { + this.$refs.form.validate(async valid => { + if (valid) { + const { id, model } = this.cForm; + + await this.$store.dispatch(`${module}/${id ? "put" : "post"}`, { + id, + body: { + ...model, + alias: this.alias, + parentId: this.isParent ? this.parentDetail.id : undefined + } + }); + + this.cForm.modal = false; + this.$Message.success(`${id ? "编辑" : "新增"}成功`); + !id && + this.resetListSearch({ + ...initWhere, + parentIds: this.isParent ? this.listSearchWhere.parentIds : [0] + }); + this.getList(); + } + + this.fixFormButtonLoading(); + }); + } +} diff --git a/src/views/comments/list/index.vue b/src/views/comments/list/index.vue index a4aaf22f..e38db8ac 100644 --- a/src/views/comments/list/index.vue +++ b/src/views/comments/list/index.vue @@ -65,143 +65,4 @@ - + diff --git a/src/views/comments/list/script.js b/src/views/comments/list/script.js new file mode 100644 index 00000000..a84378e8 --- /dev/null +++ b/src/views/comments/list/script.js @@ -0,0 +1,138 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; + +const module = "comments"; +const initWhere = { + dateRange: { + $eq: [] + }, + status: { + $eq: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin], + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "评价用户", + width: ListColumnWidth.User, + render: (h, { row }) => h("span", row.wxUser.nickName) + }, + { + title: "评价内容", + key: "content" + }, + { + title: "审核状态", + width: 100, + render: (h, { row }) => + h( + "span", + null, + this.$helpers.getItem( + this.dicts.CheckStatus, + "value", + row.status + )["label"] + ) + }, + { + title: "操作", + key: "action", + width: 180, + render: (h, { row }) => + h("div", [ + h("c-dropdown", { + props: { + width: 66, + title: "审核", + options: this.dicts.CheckStatus + }, + on: { + click: action => { + this.changeStatus(row.id, action); + } + } + }), + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: { + ...(this.listSearchWhere || initWhere), + productId: this.$route.params.productId + }, + include: [{ model: "WxUser", as: "wxUser" }] + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } + + async changeStatus(id, action) { + await this.$store.dispatch(`${module}/put`, { + id, + body: { + status: action + } + }); + this.$Message.success("修改状态成功"); + this.getList(); + } +} diff --git a/src/views/commissions/list/index.vue b/src/views/commissions/list/index.vue index c6e68fd1..e5488b9a 100644 --- a/src/views/commissions/list/index.vue +++ b/src/views/commissions/list/index.vue @@ -54,148 +54,4 @@ - + diff --git a/src/views/commissions/list/script.js b/src/views/commissions/list/script.js new file mode 100644 index 00000000..b5ff4642 --- /dev/null +++ b/src/views/commissions/list/script.js @@ -0,0 +1,143 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; + +const module = "commissions"; +const initWhere = { + dateRange: { + $eq: [] + }, + wxUserId: { + $eq: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin], + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "微信用户", + width: 150, + render: (h, { row }) => h("span", row.wxUser.nickName) + }, + { + title: "下线", + width: 150, + render: (h, { row }) => + h("span", row.lowerWxUser ? row.lowerWxUser.nickName : "--") + }, + { + title: "消费金额", + render: (h, { row }) => + h("span", `${row.order ? row.order.amount : 0}元`) + }, + { + title: "佣金", + render: (h, { row }) => h("span", `${row.value}元`) + }, + { + title: "时间", + width: ListColumnWidth.CreatedAt, + render: (h, { row }) => h("span", this.$time.getTime(row.createdAt)) + }, + { + title: "操作", + key: "action", + width: 104, + render: (h, { row }) => + h("div", [ + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + }, + total: 0 + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + await this.getListAndTotal(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + await this.getListAndTotal(); + } + + async getListAndTotal() { + this.getList(); + this.cList.total = await this.getTotal(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere, + include: [ + { + model: "WxUser", + as: "wxUser" + }, + { + model: "WxUser", + as: "lowerWxUser" + }, + { + model: "Order", + as: "order" + } + ] + } + }); + } + + async getTotal() { + const { data } = await this.$store.dispatch(`${module}/postAction`, { + action: "getTotal", + query: { + where: this.listSearchWhere || initWhere + } + }); + return data; + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } +} diff --git a/src/views/coupons/list/form/index.vue b/src/views/coupons/list/form/index.vue index b0d2db2c..d03bb4d4 100644 --- a/src/views/coupons/list/form/index.vue +++ b/src/views/coupons/list/form/index.vue @@ -111,77 +111,4 @@ - + diff --git a/src/views/coupons/list/form/script.js b/src/views/coupons/list/form/script.js new file mode 100644 index 00000000..f6aad022 --- /dev/null +++ b/src/views/coupons/list/form/script.js @@ -0,0 +1,72 @@ +import { Component, Vue } from "vue-property-decorator"; +import FormMixin from "view-ui-admin/src/mixins/form"; + +const module = "coupons"; + +@Component({ + mixins: [FormMixin] +}) +export default class CouponsListForm extends Vue { + data() { + return { + cForm: { + id: 0, + modal: false, + loading: true, + model: this.getFormInitModel(), + rules: { + name: [ + { + required: true, + message: "名称不能为空" + } + ] + } + } + }; + } + + getFormInitModel() { + return { + type: "FullReduction", + objectType: "All", + categoryIds: [], + productIds: [], + deductAmount: 0, + minConsumeAmount: 0, + period: 30 + }; + } + + show(detail) { + this.cForm.modal = true; + + if (detail && detail.id) { + this.cForm.id = detail.id; + this.initFormFields(detail); + } else { + this.cForm.id = 0; + } + } + + submit() { + this.$refs.form.validate(async valid => { + if (valid) { + const { id, model } = this.cForm; + const { data } = await this.$store.dispatch( + `${module}/${id ? "put" : "post"}`, + { + id, + body: model + } + ); + + this.cForm.modal = false; + this.$Message.success(`${id ? "编辑" : "新增"}成功`); + this.$emit("get-list", data); + } + + this.fixFormButtonLoading(); + }); + } +} diff --git a/src/views/coupons/list/index.vue b/src/views/coupons/list/index.vue index 51532b34..cb280ebc 100644 --- a/src/views/coupons/list/index.vue +++ b/src/views/coupons/list/index.vue @@ -62,173 +62,4 @@ - + diff --git a/src/views/coupons/list/script.js b/src/views/coupons/list/script.js new file mode 100644 index 00000000..3fc122a3 --- /dev/null +++ b/src/views/coupons/list/script.js @@ -0,0 +1,168 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import CouponsListForm from "./form"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; + +const module = "coupons"; +const initWhere = { + status: { + $eq: "" + }, + name: { + $like: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin], + components: { + "c-coupons-list-form": CouponsListForm + }, + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "名称", + key: "name" + }, + { + title: "类型", + width: 90, + render: (h, { row }) => + h( + "span", + this.$helpers.getItem(this.dicts.CouponType, "value", row.type)[ + "label" + ] + ) + }, + { + title: "抵扣金额", + width: 100, + render: (h, { row }) => h("span", `${row.deductAmount}元`) + }, + { + title: "最低消费", + width: 100, + render: (h, { row }) => h("span", `${row.minConsumeAmount}元`) + }, + { + title: "有效期", + width: 100, + render: (h, params) => h("span", null, `${params.row.period}天`) + }, + { + title: "状态", + width: 80, + render: (h, { row }) => + h( + "span", + null, + this.$helpers.getItem( + this.dicts.PublishStatus, + "value", + row.status + )["label"] + ) + }, + { + title: "操作", + key: "action", + width: 266, + render: (h, { row }) => + h("div", [ + h( + "Button", + { + on: { + click: () => { + this.$refs.form.show(row); + } + } + }, + "编辑" + ), + h("c-dropdown", { + props: { + width: 90, + title: "修改状态", + options: this.dicts.PublishStatus + }, + on: { + click: action => { + this.changeStatus(row.id, action); + } + } + }), + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } + + async changeStatus(id, action) { + await this.$store.dispatch(`${module}/put`, { + id, + body: { + status: action + } + }); + this.$Message.success("修改状态成功"); + this.getList(); + } +} diff --git a/src/views/login/index.vue b/src/views/login/index.vue index aab17e1d..65187c61 100644 --- a/src/views/login/index.vue +++ b/src/views/login/index.vue @@ -37,46 +37,6 @@ - + diff --git a/src/views/login/script.js b/src/views/login/script.js new file mode 100644 index 00000000..d95cd81c --- /dev/null +++ b/src/views/login/script.js @@ -0,0 +1,39 @@ +import { Component, Vue } from "vue-property-decorator"; + +@Component +export default class extends Vue { + cForm = { + model: {}, + rules: { + username: [ + { + required: true, + message: "账号不能为空" + } + ], + password: [ + { + required: true, + message: "密码不能为空" + } + ] + } + }; + + login() { + this.$refs.form.validate(async valid => { + if (valid) { + const { + data: { manager, token } + } = await this.$store.dispatch("public/managers/postAction", { + action: "login", + body: this.cForm.model + }); + + this.$auth.login({ user: manager, token }); + this.$Message.success("登录成功"); + this.$router.push(this.$route.query.redirect || "/"); + } + }); + } +} diff --git a/src/views/merchants/list/form/index.vue b/src/views/merchants/list/form/index.vue index 4480b4e0..9f097ccc 100644 --- a/src/views/merchants/list/form/index.vue +++ b/src/views/merchants/list/form/index.vue @@ -58,75 +58,4 @@ - + diff --git a/src/views/merchants/list/form/script.js b/src/views/merchants/list/form/script.js new file mode 100644 index 00000000..55d62563 --- /dev/null +++ b/src/views/merchants/list/form/script.js @@ -0,0 +1,70 @@ +import { Component, Vue } from "vue-property-decorator"; +import FormMixin from "view-ui-admin/src/mixins/form"; + +const module = "merchants"; + +@Component({ + mixins: [FormMixin] +}) +export default class MerchantsListForm extends Vue { + data() { + return { + cForm: { + id: 0, + modal: false, + loading: true, + model: this.getFormInitModel(), + rules: { + name: [ + { + required: true, + message: "名称不能为空" + } + ], + pictureId: [ + { + required: true, + message: "图片不能为空" + } + ] + } + } + }; + } + + getFormInitModel() { + return {}; + } + + show(detail) { + this.cForm.modal = true; + + if (detail && detail.id) { + this.cForm.id = detail.id; + this.initFormFields(detail); + } else { + this.cForm.id = 0; + } + } + + submit() { + this.$refs.form.validate(async valid => { + if (valid) { + const { id, model } = this.cForm; + const { data } = await this.$store.dispatch( + `${module}/${id ? "put" : "post"}`, + { + id, + body: model + } + ); + + this.cForm.modal = false; + this.$Message.success(`${id ? "编辑" : "新增"}成功`); + this.$emit("get-list", data); + } + + this.fixFormButtonLoading(); + }); + } +} diff --git a/src/views/merchants/list/index.vue b/src/views/merchants/list/index.vue index 5874f6db..8b01436c 100644 --- a/src/views/merchants/list/index.vue +++ b/src/views/merchants/list/index.vue @@ -44,127 +44,4 @@ - + diff --git a/src/views/merchants/list/script.js b/src/views/merchants/list/script.js new file mode 100644 index 00000000..fe119ebb --- /dev/null +++ b/src/views/merchants/list/script.js @@ -0,0 +1,122 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import MerchantsListForm from "./form"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; + +const module = "merchants"; +const initWhere = { + name: { + $like: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin], + components: { + "c-merchants-list-form": MerchantsListForm + }, + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "名称", + key: "name", + minWidth: ListColumnWidth.Title + }, + { + title: "关联的微信用户", + width: 130, + render: (h, { row }) => + h("span", row.wxUser ? row.wxUser.nickName : "") + }, + { + title: "联系人", + key: "contactName", + width: 100 + }, + { + title: "手机号", + key: "phoneNumber", + width: 120 + }, + { + title: "操作", + key: "action", + width: 170, + render: (h, { row }) => + h("div", [ + h( + "Button", + { + on: { + click: () => { + this.$refs.form.show(row); + } + } + }, + "编辑" + ), + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere, + include: [{ model: "WxUser", as: "wxUser" }] + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } +} diff --git a/src/views/orders/list/index.vue b/src/views/orders/list/index.vue index ec894167..40886661 100644 --- a/src/views/orders/list/index.vue +++ b/src/views/orders/list/index.vue @@ -100,236 +100,4 @@ - + diff --git a/src/views/orders/list/script.js b/src/views/orders/list/script.js new file mode 100644 index 00000000..94b30f5f --- /dev/null +++ b/src/views/orders/list/script.js @@ -0,0 +1,231 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; +import xlsx from "view-ui-admin/src/utils/xlsx"; +import Model from "@/models/admin/orders"; + +const module = "orders"; +const initWhere = { + dateRange: { + $eq: [] + }, + payment: { + $eq: "" + }, + status: { + $eq: "" + }, + wxUserId: { + $eq: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin], + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "订单号", + key: "no", + width: 150 + }, + { + title: "微信用户", + key: "wxUser", + width: 150, + render: (h, { row }) => h("span", row.wxUser.nickName) + }, + { + title: "购买商品", + key: "products", + render: (h, { row }) => h("span", row.products[0].name) + }, + { + title: "支付方式", + key: "payment", + width: 90, + render: (h, { row }) => + h( + "span", + this.$helpers.getItem( + this.dicts.OrderPayment, + "value", + row.payment + )["label"] + ) + }, + { + title: "支付金额", + key: "amount", + width: 90, + render: (h, { row }) => h("span", row.amount + " 元") + }, + { + title: "下单时间", + key: "createdAt", + width: 140, + render: (h, { row }) => h("span", this.$time.getTime(row.createdAt)) + }, + { + title: "状态", + key: "status", + width: 80, + render: (h, { row }) => + h( + "span", + this.$helpers.getItem( + this.dicts.OrderStatus, + "value", + row.status + )["label"] + ) + }, + { + title: "操作", + key: "action", + width: 192, + render: (h, { row }) => + h("div", [ + h( + "Button", + { + props: { + disabled: !row.formData + }, + on: { + click: () => { + this.cList.cFormData.data = row.formData; + this.cList.cFormData.fields = + row.products[0].formFields; + this.cList.cFormData.modal = true; + } + } + }, + "表单信息" + ), + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + }, + cFormData: { + fields: {}, + data: {}, + modal: false + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere, + include: [{ model: "WxUser", as: "wxUser" }] + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } + + deliver() {} + + getFormData(data, fields) { + return Object.keys(data).map(field => ({ + key: field, + label: this.$helpers.getItem(fields, "key", field)["label"], + value: data[field] + })); + } + + async getExportListItems() { + this.search(); + + const { + data: { items } + } = await new Model().GET({ + query: { + where: this.listSearchWhere, + include: [{ model: "WxUser", as: "wxUser" }] + } + }); + + return items; + } + + async exportXLSX() { + const items = await this.getExportListItems(); + + xlsx.download({ + fileName: `订单(${this.$time.getDate()})`, + data: (() => { + return items.map(item => { + let ret = {}; + + console.log(item, "-"); + + ret["订单号"] = item.no; + ret["微信用户"] = item.wxUser.nickName; + ret["购买商品"] = item.products[0].name; + ret["支付方式"] = this.$helpers.getItem( + this.dicts.OrderPayment, + "value", + item.payment + )["label"]; + ret["支付金额"] = `${item.amount}元`; + ret["下单时间"] = this.$time.getTime(item.createdAt); + ret["状态"] = this.$helpers.getItem( + this.dicts.OrderStatus, + "value", + item.status + )["label"]; + + return ret; + }); + })() + }); + } +} diff --git a/src/views/points/list/form/index.vue b/src/views/points/list/form/index.vue index ba1db5cb..fce73fca 100644 --- a/src/views/points/list/form/index.vue +++ b/src/views/points/list/form/index.vue @@ -33,81 +33,4 @@ - + diff --git a/src/views/points/list/form/script.js b/src/views/points/list/form/script.js new file mode 100644 index 00000000..bbf9d7a8 --- /dev/null +++ b/src/views/points/list/form/script.js @@ -0,0 +1,76 @@ +import { Component, Vue } from "vue-property-decorator"; +import FormMixin from "view-ui-admin/src/mixins/form"; + +const module = "points"; + +@Component({ + mixins: [FormMixin] +}) +export default class ListForm extends Vue { + data() { + return { + cForm: { + id: 0, + modal: false, + loading: true, + model: this.getFormInitModel(), + rules: { + schoolId: [ + { + required: true, + message: "校区不能为空" + } + ], + wxUserId: [ + { + required: true, + message: "微信用户不能为空" + } + ], + value: [ + { + asyncValidator: (rule, value) => { + return new Promise((resolve, reject) => { + if (!value) { + reject("佣金不能为 0 或为空"); + } else { + resolve(); + } + }); + } + } + ] + } + } + }; + } + + getFormInitModel() { + return { + value: 0 + }; + } + + async show() { + this.cForm.modal = true; + } + + submit() { + this.$refs.form.validate(async valid => { + if (valid) { + const { model } = this.cForm; + + await this.$store.dispatch(`${module}/postAction`, { + action: "increaseOrDecrease", + body: model + }); + + this.cForm.modal = false; + this.$Message.success("操作成功"); + this.$emit("get-list"); + } + + this.fixFormButtonLoading(); + }); + } +} diff --git a/src/views/points/list/index.vue b/src/views/points/list/index.vue index 4f0838d6..7341cfe1 100644 --- a/src/views/points/list/index.vue +++ b/src/views/points/list/index.vue @@ -62,133 +62,4 @@ - + diff --git a/src/views/points/list/script.js b/src/views/points/list/script.js new file mode 100644 index 00000000..4a164c0d --- /dev/null +++ b/src/views/points/list/script.js @@ -0,0 +1,128 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; +import ListForm from "./form"; + +const module = "points"; +const initWhere = { + dateRange: { + $eq: [] + }, + wxUserId: { + $eq: "" + } +}; + +@Component({ + components: { + "c-list-form": ListForm + }, + mixins: [RouteParamsMixin, ListMixin], + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "微信用户", + render: (h, { row }) => h("span", row.wxUser.nickName) + }, + { + title: "积分", + key: "value", + width: 100 + }, + { + title: "时间", + width: ListColumnWidth.CreatedAt, + render: (h, { row }) => h("span", this.$time.getTime(row.createdAt)) + }, + { + title: "操作", + key: "action", + width: 104, + render: (h, { row }) => + h("div", [ + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + }, + total: 0 + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + await this.getListAndTotal(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + await this.getListAndTotal(); + } + + async getListAndTotal() { + this.getList(); + this.cList.total = await this.getTotal(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere, + include: [ + { + model: "WxUser", + as: "wxUser" + } + ] + } + }); + } + + async getTotal() { + const { data } = await this.$store.dispatch(`${module}/postAction`, { + action: "getTotal", + query: { + where: this.listSearchWhere + } + }); + return data; + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } +} diff --git a/src/views/products/form/index.vue b/src/views/products/form/index.vue index 2aa7d0d2..fcfcb41f 100644 --- a/src/views/products/form/index.vue +++ b/src/views/products/form/index.vue @@ -118,102 +118,4 @@ - + diff --git a/src/views/products/form/script.js b/src/views/products/form/script.js new file mode 100644 index 00000000..8f07d443 --- /dev/null +++ b/src/views/products/form/script.js @@ -0,0 +1,97 @@ +import { Component, Vue } from "vue-property-decorator"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import FormMixin from "view-ui-admin/src/mixins/form"; +import { mapState } from "vuex"; + +const module = "products"; + +@Component({ + mixins: [RouteParamsMixin, FormMixin], + computed: mapState({ + detail: state => state[module].detail + }) +}) +export default class extends Vue { + data() { + return { + cForm: { + model: this.getFormInitModel(), + rules: { + name: [ + { + required: true, + message: "名称不能为空" + } + ], + categoryId: [ + { + required: true, + message: "分类不能为空" + } + ], + type: [ + { + required: true, + message: "类型不能为空" + } + ], + pictureIds: [ + { + required: true, + message: "图片不能为空" + } + ], + content: [ + { + required: true, + message: "详情不能为空" + } + ] + } + }, + formField: { + key: 0, + label: "" + } + }; + } + + async created() { + this.id && this.getDetail(module, this.id); + } + + getFormInitModel() { + return { + originalPrice: 0, + price: 0, + commissionRate: 0, + stock: 0, + sales: 0, + status: 1 + }; + } + + submit() { + this.$refs.form.validate(async valid => { + if (valid) { + const { + model: { id, ...restModel } + } = this.cForm; + + const { data } = await this.$store.dispatch( + `${module}/${id ? "put" : "post"}`, + { + id, + body: restModel + } + ); + + this.cForm.modal = false; + this.$Message.success(`${id ? "编辑" : "新增"}成功`); + this.$emit("get-list", data); + } + + this.fixFormButtonLoading(); + }); + } +} diff --git a/src/views/products/list/index.vue b/src/views/products/list/index.vue index a96dff36..1d294c6b 100644 --- a/src/views/products/list/index.vue +++ b/src/views/products/list/index.vue @@ -73,221 +73,4 @@ - + diff --git a/src/views/products/list/script.js b/src/views/products/list/script.js new file mode 100644 index 00000000..21829fd7 --- /dev/null +++ b/src/views/products/list/script.js @@ -0,0 +1,216 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; +import AllCategoriesListMixin from "view-ui-admin/src/mixins/all-categories-list"; + +const module = "products"; + +const initWhere = { + status: { + $eq: "" + }, + categoryId: { + $eq: "" + }, + name: { + $like: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin, AllCategoriesListMixin], + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth, OrderAction } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "图片", + width: 118, + render: (h, { row }) => { + return h("c-list-image", { + props: { + src: this.$helpers.getImageUrl({ + id: row.pictureIds[0], + width: 80, + height: 80 + }) + } + }); + } + }, + { + title: "名称", + key: "name", + minWidth: ListColumnWidth.Title + }, + { + title: "分类", + width: 100, + render: (h, { row }) => + h("span", this.getCategoryNameById(row.categoryId, true)) + }, + { + title: "原价", + width: 80, + render: (h, { row }) => h("span", row.originalPrice + "元") + }, + { + title: "会员价", + width: 80, + render: (h, { row }) => h("span", row.price + "元") + }, + { + title: "佣金比例", + width: 90, + render: (h, { row }) => h("span", row.commissionRate + "%") + }, + { + title: "库存", + key: "stock", + width: 80 + }, + { + title: "销量", + key: "sales", + width: 80 + }, + { + title: "状态", + width: 80, + render: (h, { row }) => + h( + "span", + null, + this.$helpers.getItem( + this.dicts.PublishStatus, + "value", + row.status + )["label"] + ) + }, + { + title: "操作", + key: "action", + width: 340, + render: (h, { row }) => + h("div", [ + h( + "Button", + { + props: { + to: `/${this.alias}/products/list/form/${row.id}` + } + }, + "编辑" + ), + h("c-dropdown", { + props: { + width: 90, + title: "修改状态", + options: this.dicts.PublishStatus + }, + on: { + click: action => { + this.changeStatus(row.id, action); + } + } + }), + h("c-dropdown", { + props: { + title: "排序", + options: OrderAction + }, + on: { + click: action => { + this.order(row.id, action); + } + } + }), + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere, + order: [["order", "DESC"]] + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } + + async changeStatus(id, action) { + await this.$store.dispatch(`${module}/put`, { + id, + body: { + status: action + } + }); + this.$Message.success("修改状态成功"); + this.getList(); + } + + async order(id, action) { + await this.$store.dispatch(`${module}/postAction`, { + id, + action: "order", + query: { + where: this.listSearchWhere || initWhere + }, + body: { action } + }); + + this.$Message.success("排序成功"); + this.getList(); + } +} diff --git a/src/views/withdraws/list/index.vue b/src/views/withdraws/list/index.vue index 74162cc7..fec8246d 100644 --- a/src/views/withdraws/list/index.vue +++ b/src/views/withdraws/list/index.vue @@ -70,173 +70,4 @@ - + diff --git a/src/views/withdraws/list/script.js b/src/views/withdraws/list/script.js new file mode 100644 index 00000000..0be1c758 --- /dev/null +++ b/src/views/withdraws/list/script.js @@ -0,0 +1,168 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; + +const module = "withdraws"; +const initWhere = { + dateRange: { + $eq: [] + }, + status: { + $eq: "" + }, + wxUserId: { + $eq: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin], + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "微信用户", + width: 150, + render: (h, { row }) => h("span", row.wxUser.nickName) + }, + { + title: "提现金额", + render: (h, { row }) => h("span", `${row.value}元`) + }, + { + title: "申请时间", + width: ListColumnWidth.CreatedAt, + render: (h, { row }) => h("span", this.$time.getTime(row.createdAt)) + }, + { + title: "状态", + width: 80, + render: (h, { row }) => + h( + "span", + null, + this.$helpers.getItem( + this.dicts.WithdrawStatus, + "value", + row.status + )["label"] + ) + }, + { + title: "操作", + key: "action", + width: 180, + render: (h, { row }) => + h("div", [ + h("c-dropdown", { + props: { + width: 66, + title: "审核", + options: this.dicts.CheckAction, + disabled: !this.isPlatform() || row.status === "Paid" + }, + on: { + click: action => { + this.$Modal.confirm({ + title: "请确认", + content: `确认${ + this.$helpers.getItem( + this.dicts.CheckStatus, + "value", + action + )["label"] + }?`, + onOk: () => { + this.changeStatus(row.id, action); + } + }); + } + } + }), + h( + "c-confirm-button", + { + props: { + disabled: !this.isPlatform() + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }, + "删除" + ) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere, + include: [ + { + model: "WxUser", + as: "wxUser" + } + ] + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } + + async changeStatus(id, action) { + await this.$store.dispatch(`${module}/put`, { + id, + body: { + status: this.$helpers.actionToStatus(this.dicts.WithdrawStatus, action) + } + }); + this.$Message.success( + `${ + this.$helpers.getItem(this.dicts.CheckStatus, "value", action)["label"] + }成功` + ); + this.getList(); + } +} diff --git a/src/views/wx-users/list/index.vue b/src/views/wx-users/list/index.vue index 5c1264ac..3abcd3e8 100644 --- a/src/views/wx-users/list/index.vue +++ b/src/views/wx-users/list/index.vue @@ -48,141 +48,4 @@ - + diff --git a/src/views/wx-users/list/script.js b/src/views/wx-users/list/script.js new file mode 100644 index 00000000..028b9fe2 --- /dev/null +++ b/src/views/wx-users/list/script.js @@ -0,0 +1,136 @@ +import { Component, Vue } from "vue-property-decorator"; +import { mapState } from "vuex"; +import RouteParamsMixin from "view-ui-admin/src/mixins/route-params"; +import ListMixin from "view-ui-admin/src/mixins/list"; + +const module = "wxUsers"; +const initWhere = { + nickName: { + $like: "" + }, + name: { + $like: "" + } +}; + +@Component({ + mixins: [RouteParamsMixin, ListMixin], + computed: mapState({ + list: state => state[module].list + }) +}) +export default class extends Vue { + data() { + const { ListColumnWidth } = this.$consts; + + return { + cList: { + columns: [ + { + type: "selection", + width: 60 + }, + { + title: "图片", + width: 118, + render: (h, { row }) => { + return h("c-list-image", { + props: { + src: row.avatarUrl + } + }); + } + }, + { + title: "昵称", + key: "nickName", + minWidth: ListColumnWidth.User + }, + { + title: "姓名", + key: "name", + minWidth: ListColumnWidth.User + }, + { + title: "手机号", + key: "phoneNumber", + width: 150 + }, + { + title: "性别", + key: "gender", + width: 65, + render: (h, { row }) => + h( + "span", + this.$helpers.getItem(this.dicts.Gender, "value", row.gender)[ + "label" + ] + ) + }, + { + title: "省份", + key: "province", + width: 100 + }, + { + title: "城市", + key: "city", + width: 100 + }, + { + title: "操作", + key: "action", + width: 90, + render: (h, { row }) => + h("div", [ + h("c-confirm-button", { + props: { + buttonText: "删除", + confirmText: "确认删除?" + }, + on: { + ok: () => { + this.confirmDelete(row.id); + } + } + }) + ]) + } + ], + cSearch: { + where: this.$helpers.deepCopy(initWhere) + } + } + }; + } + + async beforeRouteUpdate(to, from, next) { + this.initListSearchWhere(initWhere); + this.getList(); + next(); + } + + async created() { + this.initListSearchWhere(initWhere); + this.getList(); + } + + getList() { + return this.$store.dispatch(`${module}/getList`, { + query: { + offset: (this.listPageCurrent - 1) * this.$consts.PageSize, + limit: this.$consts.PageSize, + where: this.listSearchWhere || initWhere + } + }); + } + + async confirmDelete(ids) { + await this.$store.dispatch(`${module}/delete`, { id: ids }); + this.$Message.success("删除成功"); + + const { items } = await this.getList(); + !items.length && this.goListPrevPage(); + } +}