From 089bf5d2378b3c4a61d795b2a92bede2c193b771 Mon Sep 17 00:00:00 2001
From: admin <344137771@qq.com>
Date: Tue, 06 Jan 2026 11:22:58 +0800
Subject: [PATCH] 1

---
 src/views/modules/prod/spec.vue |  173 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 173 insertions(+), 0 deletions(-)

diff --git a/src/views/modules/prod/spec.vue b/src/views/modules/prod/spec.vue
new file mode 100644
index 0000000..f369802
--- /dev/null
+++ b/src/views/modules/prod/spec.vue
@@ -0,0 +1,173 @@
+<template>
+  <div class="mod-prod">
+    <avue-crud
+      ref="crud"
+      :page.sync="page"
+      :data="dataList"
+      :option="tableOption"
+      :permission="permission"
+      @search-change="searchChange"
+      @on-load="getDataList"
+    >
+      <template slot-scope="scope" slot="prodPropValues">
+        <el-tag v-for="item in scope.row.prodPropValues" :key="item.valueId">{{
+          item.propValue
+        }}</el-tag>
+      </template>
+      <template slot="menuLeft">
+        <el-button
+          type="primary"
+          icon="el-icon-plus"
+          size="small"
+          v-if="isAuth('shop:pickAddr:save')"
+          @click.stop="addOrUpdateHandle()"
+          >新增</el-button
+        >
+      </template>
+
+      <template slot-scope="scope" slot="prodPropValues">
+        <div
+          v-for="item in scope.row.prodPropValues"
+          :key="item.valueId"
+          class="prop-value"
+        >
+          <el-tag>{{ item.propValue }}</el-tag>
+        </div>
+      </template>
+
+      <template slot-scope="scope" slot="menu">
+        <el-button
+          type="primary"
+          icon="el-icon-edit"
+          size="small"
+          v-if="isAuth('prod:spec:update')"
+          @click.stop="addOrUpdateHandle(scope.row)"
+          >编辑</el-button
+        >
+
+        <el-button
+          type="danger"
+          icon="el-icon-delete"
+          size="small"
+          v-if="isAuth('prod:spec:delete')"
+          @click.stop="deleteHandle(scope.row.propId)"
+          >删除</el-button
+        >
+      </template>
+    </avue-crud>
+    <!-- 弹窗, 新增 / 修改 -->
+    <add-or-update
+      v-if="addOrUpdateVisible"
+      ref="addOrUpdate"
+      @refreshDataList="getDataList"
+    ></add-or-update>
+  </div>
+</template>
+
+<script>
+import AddOrUpdate from "./spec-add-or-update";
+import { tableOption } from "@/crud/prod/spec";
+export default {
+  data() {
+    return {
+      dataForm: {
+        prodProp: "",
+      },
+      dataList: [],
+      pageIndex: 1,
+      pageSize: 10,
+      totalPage: 0,
+      dataListLoading: false,
+      dataListSelections: [],
+      addOrUpdateVisible: false,
+
+      page: {
+        total: 0, // 总页数
+        currentPage: 1, // 当前页数
+        pageSize: 10, // 每页显示多少条
+      },
+      permission: {
+        delBtn: this.isAuth("prod:prod:delete"),
+      },
+      tableOption: tableOption,
+    };
+  },
+  components: {
+    AddOrUpdate,
+  },
+  methods: {
+    // 获取数据列表
+    getDataList(page, params, done) {
+      this.dataListLoading = true;
+      this.$http({
+        url: this.$http.adornUrl("/prod/spec/page"),
+        method: "get",
+        params: this.$http.adornParams(
+          Object.assign(
+            {
+              current: page == null ? this.page.currentPage : page.currentPage,
+              size: page == null ? this.page.pageSize : page.pageSize,
+            },
+            params
+          )
+        ),
+      }).then(({ data }) => {
+        this.dataList = data.records;
+        this.page.total = data.total;
+        this.dataListLoading = false;
+        if (done) {
+          done();
+        }
+      });
+    },
+    // 新增 / 修改
+    addOrUpdateHandle(val) {
+      this.addOrUpdateVisible = true;
+      this.$nextTick(() => {
+        this.$refs.addOrUpdate.init(val);
+      });
+    },
+    // 删除
+    deleteHandle(id) {
+      var ids = id
+        ? [id]
+        : this.dataListSelections.map((item) => {
+            return item.propId;
+          });
+      this.$confirm(`确定进行[${id ? "删除" : "批量删除"}]操作?`, "提示", {
+        confirmButtonText: "确定",
+        cancelButtonText: "取消",
+        type: "warning",
+      })
+        .then(() => {
+          this.$http({
+            url: this.$http.adornUrl(`/prod/spec/${ids}`),
+            method: "delete",
+            data: this.$http.adornData(ids, false),
+          }).then(({ data }) => {
+            this.$message({
+              message: "操作成功",
+              type: "success",
+              duration: 1500,
+              onClose: () => {
+                this.getDataList(this.page);
+              },
+            });
+          });
+        })
+        .catch(() => {});
+    },
+
+    searchChange(params, done) {
+      this.getDataList(this.page, params, done);
+    },
+  },
+};
+</script>
+
+<style lang="scss" scoped>
+.prop-value {
+  display: inline-block;
+  margin: 0 3px 3px 0;
+}
+</style>

--
Gitblit v1.9.3