Browse Source

lizhuo submits AnnualSaleGoal at 2023-7-18 17:00

002637 1 year ago
parent
commit
b0ad8d9d9b

+ 44 - 0
src/api/business/spd/goal_management/monthGoalMerge.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询月销售目标合并列表
+export function listMonthGoalMerge(query) {
+  return request({
+    url: '/goal_management/monthGoalMerge/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询月销售目标合并详细
+export function getMonthGoalMerge(id) {
+  return request({
+    url: '/goal_management/monthGoalMerge/' + id,
+    method: 'get'
+  })
+}
+
+// 新增月销售目标合并
+export function addMonthGoalMerge(data) {
+  return request({
+    url: '/goal_management/monthGoalMerge',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改月销售目标合并
+export function updateMonthGoalMerge(data) {
+  return request({
+    url: '/goal_management/monthGoalMerge',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除月销售目标合并
+export function delMonthGoalMerge(id) {
+  return request({
+    url: '/goal_management/monthGoalMerge/' + id,
+    method: 'delete'
+  })
+}

+ 44 - 0
src/api/business/spd/goal_management/monthGoalMergeDetails.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询月销售目标合并明细列表
+export function listMonthGoalMergeDetails(query) {
+  return request({
+    url: '/goal_management/monthGoalMergeDetails/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询月销售目标合并明细详细
+export function getMonthGoalMergeDetails(id) {
+  return request({
+    url: '/goal_management/monthGoalMergeDetails/' + id,
+    method: 'get'
+  })
+}
+
+// 新增月销售目标合并明细
+export function addMonthGoalMergeDetails(data) {
+  return request({
+    url: '/goal_management/monthGoalMergeDetails',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改月销售目标合并明细
+export function updateMonthGoalMergeDetails(data) {
+  return request({
+    url: '/goal_management/monthGoalMergeDetails',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除月销售目标合并明细
+export function delMonthGoalMergeDetails(id) {
+  return request({
+    url: '/goal_management/monthGoalMergeDetails/' + id,
+    method: 'delete'
+  })
+}

+ 1 - 1
src/views/business/spd/goal_management/AnnualSaleGoalMerge.vue

@@ -782,7 +782,7 @@ export default {
         { value: '2044', label: '2044' },
         { value: '2045', label: '2045' },
       ],
-      // 参照条件 & 参照列表
+      // 参照条件 & 树形参照列表
       referCondition: { type: '', isPage: true, title: '' },
       classList: [],
       // 合并子表明细

+ 682 - 0
src/views/business/spd/goal_management/MonthGoalMerge.vue

@@ -0,0 +1,682 @@
+<template>
+  <div class="app-container">
+    <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
+      <el-form-item label="编码" prop="code">
+        <el-input
+          v-model="queryParams.code"
+          placeholder="请输入编码"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="目标名称" prop="goalName">
+        <el-input
+          v-model="queryParams.goalName"
+          placeholder="请输入目标名称"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="单据日期" prop="documentDate">
+        <el-date-picker clearable
+                        v-model="queryParams.documentDate"
+                        type="date"
+                        value-format="yyyy-MM-dd"
+                        placeholder="请选择单据日期">
+        </el-date-picker>
+      </el-form-item>
+      <el-form-item label="年度" prop="annual">
+        <el-input
+          v-model="queryParams.annual"
+          placeholder="请输入年度"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="月份" prop="monthly">
+        <el-input
+          v-model="queryParams.monthly"
+          placeholder="请输入月份"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="客户" prop="custom">
+        <el-input
+          v-model="queryParams.custom"
+          placeholder="请输入客户"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="制单人" prop="creator">
+        <el-input
+          v-model="queryParams.creator"
+          placeholder="请输入制单人"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="部门" prop="dept">
+        <el-input
+          v-model="queryParams.dept"
+          placeholder="请输入部门"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="目标类型" prop="goalCategory">
+        <el-input
+          v-model="queryParams.goalCategory"
+          placeholder="请输入目标类型"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item>
+        <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
+        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
+      </el-form-item>
+    </el-form>
+
+    <el-row :gutter="10" class="mb8">
+      <el-col :span="1.5">
+        <el-button
+          type="primary"
+          plain
+          icon="el-icon-plus"
+          size="mini"
+          @click="handleAdd"
+          v-hasPermi="['goal_management:monthGoalMerge:add']"
+        >新增
+        </el-button>
+      </el-col>
+      <el-col :span="1.5">
+        <el-button
+          type="danger"
+          plain
+          icon="el-icon-delete"
+          size="mini"
+          :disabled="multiple"
+          @click="handleDelete"
+          v-hasPermi="['goal_management:monthGoalMerge:remove']"
+        >删除
+        </el-button>
+      </el-col>
+      <el-col :span="1.5">
+        <el-button
+          type="warning"
+          plain
+          icon="el-icon-download"
+          size="mini"
+          @click="handleExport"
+          v-hasPermi="['goal_management:monthGoalMerge:export']"
+        >导出
+        </el-button>
+      </el-col>
+      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
+    </el-row>
+
+    <el-table v-loading="loading" :data="monthGoalMergeList" @selection-change="handleSelectionChange">
+      <el-table-column type="selection" width="55" align="center"/>
+      <el-table-column label="id唯一标识" align="center" prop="id"/>
+      <el-table-column label="编码" align="center" prop="code"/>
+      <el-table-column label="目标名称" align="center" prop="goalName"/>
+      <el-table-column label="单据日期" align="center" prop="documentDate" width="180">
+        <template slot-scope="scope">
+          <span>{{ parseTime(scope.row.documentDate, '{y}-{m}-{d}') }}</span>
+        </template>
+      </el-table-column>
+      <el-table-column label="年度" align="center" prop="annual"/>
+      <el-table-column label="月份" align="center" prop="monthly"/>
+      <el-table-column label="客户" align="center" prop="custom"/>
+      <el-table-column label="saleZone" align="center" prop="saleZone"/>
+      <el-table-column label="oneLevel" align="center" prop="oneLevelClassify"/>
+      <el-table-column label="twoLevel" align="center" prop="twoLevelClassify"/>
+      <el-table-column label="制单人" align="center" prop="creator"/>
+      <el-table-column label="部门" align="center" prop="dept"/>
+      <el-table-column label="目标类型" align="center" prop="goalCategory"/>
+      <el-table-column label="目标值合计" align="center" prop="goalSum"/>
+      <el-table-column label="单据状态" align="center" prop="documentStatus"/>
+      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
+        <template slot-scope="scope">
+          <el-button
+            size="mini"
+            type="text"
+            icon="el-icon-edit"
+            @click="handleUpdate(scope.row)"
+            v-hasPermi="['goal_management:monthGoalMerge:edit']"
+          >修改
+          </el-button>
+          <el-button
+            size="mini"
+            type="text"
+            icon="el-icon-delete"
+            @click="handleDelete(scope.row)"
+            v-hasPermi="['goal_management:monthGoalMerge:remove']"
+          >删除
+          </el-button>
+        </template>
+      </el-table-column>
+    </el-table>
+
+    <pagination
+      v-show="total>0"
+      :total="total"
+      :page.sync="queryParams.pageNum"
+      :limit.sync="queryParams.pageSize"
+      @pagination="getList"
+    />
+
+    <el-drawer title="我是标题" :visible.sync="drawerMain" :direction="direction" :before-close="handleClose" size="100%">
+      <el-form ref="form" :model="form" :rules="rules" label-width="120px">
+        <el-row :gutter="20" style="margin-right: 20px">
+          <el-col :span="6">
+            <el-form-item label="编码" prop="code">
+              <el-input v-model="form.code" placeholder="编码自动生成" disabled />
+            </el-form-item>
+          </el-col>
+          <el-col :span="6">
+            <el-form-item label="目标名称" prop="goalName">
+              <el-input v-model="form.goalName" placeholder="请输入目标名称" disabled />
+            </el-form-item>
+          </el-col>
+          <el-col :span="6">
+            <el-form-item label="单据日期" prop="documentDate">
+              <el-date-picker clearable
+                              v-model="form.documentDate"
+                              type="date"
+                              value-format="yyyy-MM-dd"
+                              placeholder="请选择单据日期">
+              </el-date-picker>
+            </el-form-item>
+          </el-col>
+          <el-col :span="6">
+            <el-form-item label="年度" prop="annual">
+              <el-select v-model="form.annual" filterable clearable placeholder="请选择年度">
+                <el-option
+                  v-for="item in annualList"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="20" style="margin-right: 20px">
+          <el-col :span="6">
+            <el-form-item label="月份" prop="monthly">
+              <el-select v-model="form.monthly" filterable clearable placeholder="请选择月份">
+                <el-option
+                  v-for="item in monthList"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+          </el-col>
+          <el-col :span="6">
+            <el-form-item label="制单人" prop="creator">
+              <el-popover-select-v2 v-model="form.creator" title="制单人" valueKey="name" referName="CONTACTS_PARAM"
+                                    :dataMapping="{ creatorCode: 'code', creator: 'name' }" :source.sync="form" placement="请输入制单人"
+              ></el-popover-select-v2>
+            </el-form-item>
+          </el-col>
+          <el-col :span="6">
+            <el-form-item label="部门" prop="dept">
+              <el-popover-select-v2 v-model="form.dept" title="部门" valueKey="name" referName="DEPT_PARAM"
+                                    :dataMapping="{ deptCode: 'code', dept: 'name' }" :source.sync="form" placement="请输入部门"
+              ></el-popover-select-v2>
+            </el-form-item>
+          </el-col>
+          <el-col :span="6">
+            <el-form-item label="目标类型" prop="goalCategory">
+              <el-select v-model="form.goalCategory" filterable clearable placeholder="请选择目标类型" @change="changeGoalCate">
+                <el-option
+                  v-for="item in goalCategoryList"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="20" style="margin-right: 20px">
+          <el-col :span="6">
+            <el-form-item label="目标值合计" prop="goalSum">
+              <el-input v-model="form.goalSum" placeholder="请输入目标值合计" disabled/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="6">
+            <el-form-item v-if="form.goalCategory === '客户维度'" label="客户" prop="custom">
+              <el-popover-select-v2
+                v-model="form.custom" title="客户" valueKey="name" referName="CUSTOMER_PARAM"
+                :dataMapping="{ customCode: 'code', custom: 'name' }" :source.sync="form" placeholder="请输入客户"
+              ></el-popover-select-v2>
+            </el-form-item>
+            <el-form-item v-if="form.goalCategory === '销售区域'" label="销售区域" prop="saleZone">
+              <el-popover-select-v2
+                @change="aaaaa"
+                v-model="form.saleZone" title="销售区域" valueKey="name" referName="ORG_PARAM"
+                :dataMapping="{ saleZoneCode: 'code', saleZone: 'name' }" :source.sync="form" placeholder="请输入销售区域"
+              ></el-popover-select-v2>
+            </el-form-item>
+            <el-form-item v-if="form.goalCategory === '一级分类'" label="一级物料" prop="oneLevelClassify">
+              <el-select v-model="form.oneLevelClassify" placeholder="请输入一级物料" clearable
+                         @focus="chooseTreeRefer('MATERIALCLASSIFY_PARAM', false, '一级物料分类')"
+              ></el-select>
+            </el-form-item>
+            <el-form-item v-if="form.goalCategory === '二级分类'" label="二级物料" prop="twoLevelClassify">
+              <el-select v-model="form.twoLevelClassify" placeholder="请输入二级物料" clearable
+                         @focus="chooseTreeRefer('MATERIALCLASSIFY_PARAM', false, '二级物料分类')"
+              ></el-select>
+            </el-form-item>
+          </el-col>
+          <el-col :span="6">
+            <el-button type="primary" @click="submitForm">确 定</el-button>
+            <el-button @click="cancel">取 消</el-button>
+          </el-col>
+        </el-row>
+      </el-form>
+    </el-drawer>
+
+    <TreeRefers ref="tree" :single="true" @doSubmit="selectionsToTreeInput"></TreeRefers>
+  </div>
+</template>
+
+<script>
+import {
+  listMonthGoalMerge,
+  getMonthGoalMerge,
+  delMonthGoalMerge,
+  addMonthGoalMerge,
+  updateMonthGoalMerge
+} from "@/api/business/spd/goal_management/monthGoalMerge";
+
+import TreeRefers from '@/components/Refers/treeRefer.vue'
+import ElPopoverSelectV2 from "@/components/popover-select-v2"
+
+export default {
+  name: "monthGoalMerge",
+  components: {
+    TreeRefers, ElPopoverSelectV2
+  },
+  data() {
+    return {
+      // 遮罩层
+      loading: true,
+      // 选中数组
+      ids: [],
+      // 非单个禁用
+      single: true,
+      // 非多个禁用
+      multiple: true,
+      // 显示搜索条件
+      showSearch: true,
+      // 总条数
+      total: 0,
+      // 月销售目标合并表格数据
+      monthGoalMergeList: [],
+      // 弹出层标题
+      title: "",
+      // 是否显示弹出层
+      open: false,
+      // 查询参数
+      queryParams: {
+        pageNum: 1,
+        pageSize: 10,
+        code: null,
+        goalName: null,
+        documentDate: null,
+        annual: null,
+        monthly: null,
+        customCode: null,
+        custom: null,
+        saleZoneCode: null,
+        saleZone: null,
+        oneLevelClassifyCode: null,
+        oneLevelClassify: null,
+        twoLevelClassifyCode: null,
+        twoLevelClassify: null,
+        creatorCode: null,
+        creator: null,
+        deptCode: null,
+        dept: null,
+        goalCategory: null,
+        goalSum: null,
+        documentStatus: null,
+        deleteStatus: null,
+      },
+      // 表单参数
+      form: {
+        id: null,
+        code: null,
+        goalName: null,
+        documentDate: null,
+        annual: null,
+        monthly: null,
+        customCode: null,
+        custom: null,
+        saleZoneCode: null,
+        saleZone: null,
+        oneLevelClassifyCode: null,
+        oneLevelClassify: null,
+        twoLevelClassifyCode: null,
+        twoLevelClassify: null,
+        creatorCode: null,
+        creator: null,
+        deptCode: null,
+        dept: null,
+        goalCategory: null,
+        goalSum: null,
+        documentStatus: null,
+        deleteStatus: null
+      },
+      formDetails: {},
+      // 表单校验
+      rules: {
+        custom: [{required: true, message: 'kehu不能为空', trigger: 'blur'}],
+        saleZone: [{required: true, message: 'xiaoshouquyu不能为空', trigger: 'blur'}],
+        oneLevelClassify: [{required: true, message: 'yijifenlei不能为空', trigger: 'blur'}],
+        twoLevelClassify: [{required: true, message: 'erjifenlei不能为空', trigger: 'blur'}]
+      },
+      // 主表添加or编辑抽屉
+      drawerMain: false,
+      drawerInner: false,
+      direction: 'rtl',
+      // 目标类型列表
+      goalCategoryList: [
+        { value: '客户维度', label: '客户维度' },
+        { value: '销售区域', label: '销售区域' },
+        { value: '一级分类', label: '一级分类' },
+        { value: '二级分类', label: '二级分类' }
+      ],
+      // 年度列表,月度列表
+      annualList: [
+        {value: '2023', label: '2023'},
+        {value: '2024', label: '2024'},
+        {value: '2025', label: '2025'},
+        {value: '2026', label: '2026'},
+        {value: '2027', label: '2027'},
+        {value: '2028', label: '2028'},
+        {value: '2029', label: '2029'},
+        {value: '2030', label: '2030'},
+        {value: '2031', label: '2031'},
+        {value: '2034', label: '2034'},
+        {value: '2035', label: '2035'},
+        {value: '2036', label: '2036'},
+        {value: '2037', label: '2037'},
+        {value: '2038', label: '2038'},
+        {value: '2039', label: '2039'},
+        {value: '2040', label: '2040'},
+        {value: '2041', label: '2041'},
+        {value: '2042', label: '2042'},
+        {value: '2043', label: '2043'},
+        {value: '2044', label: '2044'},
+        {value: '2045', label: '2045'},
+      ],
+      monthList: [
+        {value: '1', label: '1'},
+        {value: '2', label: '2'},
+        {value: '3', label: '3'},
+        {value: '4', label: '4'},
+        {value: '5', label: '5'},
+        {value: '6', label: '6'},
+        {value: '7', label: '7'},
+        {value: '8', label: '8'},
+        {value: '9', label: '9'},
+        {value: '10', label: '10'},
+        {value: '11', label: '11'},
+        {value: '12', label: '12'},
+      ],
+      // 参照条件 & 树形参照列表
+      referCondition: { type: '', isPage: true, title: '' },
+      classList: []
+    };
+  },
+  created() {
+    this.getList();
+    console.log(this.form);
+  },
+  methods: {
+    /** 查询月销售目标合并列表 */
+    getList() {
+      this.loading = true;
+      listMonthGoalMerge(this.queryParams).then(response => {
+        this.monthGoalMergeList = response.rows;
+        this.total = response.total;
+        this.loading = false;
+      });
+    },
+    // 取消按钮
+    cancel() {
+      this.drawerMain = false;
+      this.reset();
+    },
+    // 表单重置
+    reset() {
+      this.form = {
+        id: null,
+        code: null,
+        goalName: null,
+        documentDate: null,
+        annual: null,
+        monthly: null,
+        customCode: null,
+        custom: null,
+        creatorCode: null,
+        creator: null,
+        saleZoneCode: null,
+        saleZone: null,
+        oneLevelClassifyCode: null,
+        oneLevelClassify: null,
+        twoLevelClassifyCode: null,
+        twoLevelClassify: null,
+        deptCode: null,
+        dept: null,
+        goalCategory: null,
+        goalSum: null,
+        documentStatus: null,
+        deleteStatus: null,
+        createBy: null,
+        createTime: null,
+        updateBy: null,
+        updateTime: null
+      };
+      this.resetForm("form");
+    },
+    /** 搜索按钮操作 */
+    handleQuery() {
+      this.queryParams.pageNum = 1;
+      this.getList();
+    },
+    /** 重置按钮操作 */
+    resetQuery() {
+      this.resetForm("queryForm");
+      this.handleQuery();
+    },
+    // 多选框选中数据
+    handleSelectionChange(selection) {
+      this.ids = selection.map(item => item.id)
+      this.single = selection.length !== 1
+      this.multiple = !selection.length
+    },
+    /** 新增按钮操作 */
+    handleAdd() {
+      this.reset();
+      this.drawerMain = true;
+      this.title = "添加月销售目标合并";
+    },
+    /** 修改按钮操作 */
+    handleUpdate(row) {
+      this.reset();
+      const id = row.id || this.ids
+      getMonthGoalMerge(id).then(response => {
+        this.form = response.data;
+        this.open = true;
+        this.title = "修改月销售目标合并";
+      });
+    },
+    /** 提交按钮 */
+    submitForm() {
+      console.log(this.form);
+      this.$refs["form"].validate(valid => {
+        if (valid) {
+          if (this.form.id != null) {
+            updateMonthGoalMerge(this.form).then(response => {
+              this.$modal.msgSuccess("修改成功");
+              this.drawerMain = false;
+              this.getList();
+            });
+          } else {
+            this.form.deleteStatus = 0
+            this.form.documentStatus = '开立态'
+            this.form.goalSum = 0.000000
+            addMonthGoalMerge(this.form).then(response => {
+              this.$modal.msgSuccess("新增成功");
+              this.drawerMain = false;
+              this.getList();
+            });
+          }
+        }
+      });
+    },
+    /** 删除按钮操作 */
+    handleDelete(row) {
+      const ids = row.id || this.ids;
+      this.$modal.confirm('是否确认删除月销售目标合并编号为"' + ids + '"的数据项?').then(function () {
+        return delMonthGoalMerge(ids);
+      }).then(() => {
+        this.getList();
+        this.$modal.msgSuccess("删除成功");
+      }).catch(() => {
+      });
+    },
+    /** 导出按钮操作 */
+    handleExport() {
+      this.download('goal_management/monthGoalMerge/export', {
+        ...this.queryParams
+      }, `monthGoalMerge_${new Date().getTime()}.xlsx`)
+    },
+    // 关闭抽屉
+    handleClose(done) {
+      this.$confirm('确认关闭?')
+        .then(_ => {
+          done();
+        })
+        .catch(_ => {});
+    },
+    // 选择树形参照
+    chooseTreeRefer(type, isPage, title) {
+      this.referCondition.type = type
+      this.referCondition.isPage = isPage
+      this.referCondition.title = title
+      this.$refs.tree.init(this.referCondition)
+    },
+    // 给参照字段赋值
+    selectionsToTreeInput(selection) {
+      this.classList.push(selection)
+      console.log(this.drawerInner);
+      if (this.referCondition.title === '一级物料分类') {
+        if (selection.code.length !== 1) {
+          return this.$message.error('请在一级分类里面选择')
+        }
+        if (this.drawerInner) {
+          this.formDetails.oneLevelClassifyCode = selection.code
+          this.formDetails.oneLevelClassify = selection.name
+          this.formDetails.twoLevelClassifyCode = null
+          this.formDetails.twoLevelClassify = null
+        } else {
+          this.form.oneLevelClassifyCode = selection.code
+          this.form.oneLevelClassify = selection.name
+        }
+      } else if (this.referCondition.title === '二级物料分类') {
+        if (selection.code.length !== 4) {
+          return this.$message.error('请在二级分类里面选择')
+        }
+        if (this.drawerInner) {
+          if (this.formDetails.oneLevelClassifyCode === null || this.formDetails.oneLevelClassifyCode === '') {
+            return this.$message.error('请先填写一级分类')
+          }
+          if (selection.code[0] !== this.formDetails.oneLevelClassifyCode) {
+            return this.$message.error('所选择的二级分类不属于已选的一级分类')
+          }
+          this.formDetails.twoLevelClassifyCode = selection.code
+          this.formDetails.twoLevelClassify = selection.name
+        } else {
+          this.form.twoLevelClassifyCode = selection.code
+          this.form.twoLevelClassify = selection.name
+        }
+      }
+    },
+    // 当值为null时,设置编码为0
+    changeDetailsCode() {
+      const one = this.formDetails.oneLevelClassify
+      const two = this.formDetails.twoLevelClassify
+      if (one.length === 0 || one === '') {
+        this.formDetails.oneLevelClassifyCode = null
+      }
+      if (two.length === 0 || two === '') {
+        this.formDetails.twoLevelClassifyCode = null
+      }
+    },
+    changeGoalCate() {
+      if (this.form.goalCategory === null || this.form.goalCategory === '') {
+        this.form.customCode = null
+        this.form.custom = null
+        this.form.saleZoneCode = null
+        this.form.saleZone = null
+        this.form.oneLevelClassifyCode = null
+        this.form.oneLevelClassify = null
+        this.form.twoLevelClassifyCode = null
+        this.form.twoLevelClassify = null
+        this.rules = {
+          custom: [{required: true, message: 'kehu不能为空', trigger: 'blur'}],
+          saleZone: [{required: true, message: 'xiaoshouquyu不能为空', trigger: 'blur'}],
+          oneLevelClassify: [{required: true, message: 'yijifenlei不能为空', trigger: 'blur'}],
+          twoLevelClassify: [{required: true, message: 'erjifenlei不能为空', trigger: 'blur'}]
+        }
+      } else if (this.form.goalCategory === '销售区域') {
+        this.form.customCode = null
+        this.form.custom = null
+        this.form.oneLevelClassifyCode = null
+        this.form.oneLevelClassify = null
+        this.form.twoLevelClassifyCode = null
+        this.form.twoLevelClassify = null
+        this.rules = {
+          saleZone: [{required: true, message: 'xiaoshouquyu不能为空', trigger: 'blur'}]
+        }
+      } else if (this.form.goalCategory === '客户维度') {
+        this.form.saleZoneCode = null
+        this.form.saleZone = null
+        this.form.oneLevelClassifyCode = null
+        this.form.oneLevelClassify = null
+        this.form.twoLevelClassifyCode = null
+        this.form.twoLevelClassify = null
+      } else if (this.form.goalCategory === '一级分类') {
+        this.form.customCode = null
+        this.form.custom = null
+        this.form.saleZoneCode = null
+        this.form.saleZone = null
+        this.form.twoLevelClassifyCode = null
+        this.form.twoLevelClassify = null
+      } else if (this.form.goalCategory === '二级分类') {
+        this.form.customCode = null
+        this.form.custom = null
+        this.form.saleZoneCode = null
+        this.form.saleZone = null
+        this.form.oneLevelClassifyCode = null
+        this.form.oneLevelClassify = null
+      }
+    }
+  }
+};
+</script>
+
+<style scoped>
+
+</style>
+

+ 6 - 4
src/views/business/spd/goal_management/MonthSaleGoal.vue

@@ -485,7 +485,7 @@ export default {
         documentStatus: null,
         deleteStatus: null,
       },
-      queryParamsDetails: {numPage: 1, numSize: 10},
+      queryParamsDetails: { numPage: 1, numSize: 10 },
       // 表单参数
       form: {
         id: null,
@@ -597,7 +597,7 @@ export default {
           this.loading = false;
           this.form.goalSum = 0
           for (const element of response.rows) {
-            this.form.goalSum = this.form.goalSum + (element.num * element.goalValue)
+            this.form.goalSum = this.form.goalSum + element.goalValue
           }
         });
       } else {
@@ -606,8 +606,9 @@ export default {
           this.totalDetails = response.total
           this.loading = false
           // 仅仅页面变了,在后端通过操作也变了
+          this.form.goalSum = 0
           for (const element of response.rows) {
-            this.form.goalSum = this.form.goalSum + (element.num * element.goalValue)
+            this.form.goalSum = this.form.goalSum + element.goalValue
           }
         })
       }
@@ -757,6 +758,7 @@ export default {
               this.$modal.msgSuccess("修改成功");
               this.innerDrawer = false;
               this.getListDetails();
+              this.updateMainGoalSum(this.form.code)
             });
           } else {
             addMonthSaleGoalDetails(this.formDetails).then(response => {
@@ -876,7 +878,7 @@ export default {
     // 在修改页中修改明细时,修改数据库的数据
     updateMainGoalSum(code) {
       updateMainGoalSum(code).then(response => {
-
+        console.log(response);
       })
     }
   }

+ 2 - 2
vue.config.js

@@ -37,7 +37,7 @@ module.exports = {
       // detail: https://cli.vuejs.org/config/#devserver-proxy
       [process.env.VUE_APP_BASE_API]: {
         // target: `http://172.16.100.107:8080/drp-admin`, //测试
-       target: `http://test-sy.derom.com/drp-admin`, //测试
+       // target: `http://test-sy.derom.com/drp-admin`, //测试
         // target: `http://release-sy.derom.com/drp-admin`, //预发
         // target: `http://sy.derom.com/drp-admin`, //生产
         // target: `http://172.16.63.202:8000/drp-admin`, // D本地
@@ -46,7 +46,7 @@ module.exports = {
         // target: `http://172.16.13.47:8000/drp-admin`, //这是一个美女的本地
         // target: `http://172.16.13.113:8000/drp-admin`, //DWT本地
 
-        //  target: `http://127.0.0.1:8000/drp-admin`,
+         target: `http://127.0.0.1:8000/drp-admin`,
         changeOrigin: true,
         pathRewrite: {
           ["^" + process.env.VUE_APP_BASE_API]: "",