소스 검색

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

002637 1 년 전
부모
커밋
5c1cf66bf8

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

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询年销售目标合并列表
+export function listAnnualSaleGoalMerge(query) {
+  return request({
+    url: '/goal_management/annualSaleGoalMerge/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询年销售目标合并详细
+export function getAnnualSaleGoalMerge(id) {
+  return request({
+    url: '/goal_management/annualSaleGoalMerge/' + id,
+    method: 'get'
+  })
+}
+
+// 新增年销售目标合并
+export function addAnnualSaleGoalMerge(data) {
+  return request({
+    url: '/goal_management/annualSaleGoalMerge',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改年销售目标合并
+export function updateAnnualSaleGoalMerge(data) {
+  return request({
+    url: '/goal_management/annualSaleGoalMerge',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除年销售目标合并
+export function delAnnualSaleGoalMerge(id) {
+  return request({
+    url: '/goal_management/annualSaleGoalMerge/' + id,
+    method: 'delete'
+  })
+}

+ 751 - 6
src/views/business/spd/goal_management/annualSaleGoal/AnnualSaleGoalMerge.vue

@@ -1,13 +1,758 @@
 <template>
-<div>aaaa</div>
+  <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="creatorCode">
+        <el-input
+          v-model="queryParams.creatorCode"
+          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="deptCode">
+        <el-input
+          v-model="queryParams.deptCode"
+          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="goalTotal">
+        <el-input
+          v-model="queryParams.goalTotal"
+          placeholder="请输入目标值汇总"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="备注" prop="notes">
+        <el-input
+          v-model="queryParams.notes"
+          placeholder="请输入备注"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="销售区域编码" prop="saleZoneCode">
+        <el-input
+          v-model="queryParams.saleZoneCode"
+          placeholder="请输入销售区域编码"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="销售区域" prop="saleZone">
+        <el-input
+          v-model="queryParams.saleZone"
+          placeholder="请输入销售区域"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="一级物料编码" prop="oneLevelClassifyCode">
+        <el-input
+          v-model="queryParams.oneLevelClassifyCode"
+          placeholder="请输入一级物料编码"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="一级物料" prop="oneLevelClassify">
+        <el-input
+          v-model="queryParams.oneLevelClassify"
+          placeholder="请输入一级物料"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="二级物料编码" prop="twoLevelClassifyCode">
+        <el-input
+          v-model="queryParams.twoLevelClassifyCode"
+          placeholder="请输入二级物料编码"
+          clearable
+          @keyup.enter.native="handleQuery"
+        />
+      </el-form-item>
+      <el-form-item label="二级物料" prop="twoLevelClassify">
+        <el-input
+          v-model="queryParams.twoLevelClassify"
+          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:annualSaleGoalMerge: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:annualSaleGoalMerge: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:annualSaleGoalMerge:export']"
+        >导出</el-button>
+      </el-col>
+      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
+    </el-row>
+
+    <el-table v-loading="loading" :data="annualSaleGoalMergeList" @selection-change="handleSelectionChange">
+      <el-table-column type="selection" width="55" align="center" fixed />
+      <el-table-column label="单据编码" align="center" prop="code" width="150px" />
+      <el-table-column label="目标名称" align="center" prop="goalName" width="150px" />
+      <el-table-column label="单据日期" align="center" prop="documentDate" width="150px">
+        <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" width="150px" />
+      <el-table-column label="制单人" align="center" prop="creator" width="150px" />
+      <el-table-column label="部门" align="center" prop="dept" width="150px" />
+      <el-table-column label="目标分类" align="center" prop="goalCategory" width="150px" />
+      <el-table-column label="目标值汇总" align="center" prop="goalTotal" width="150px" />
+      <el-table-column label="备注" align="center" prop="notes" width="150px" />
+      <el-table-column label="单据状态" align="center" prop="documentStatus" width="150px" />
+      <el-table-column label="销售区域" align="center" prop="saleZone" width="150px" />
+      <el-table-column label="一级物料" align="center" prop="oneLevelClassify" width="150px" />
+      <el-table-column label="二级物料" align="center" prop="twoLevelClassify" width="150px" />
+      <el-table-column label="创建人" align="center" prop="createBy" width="150px" />
+      <el-table-column label="创建日期" align="center" prop="createTime" width="150px" />
+      <el-table-column label="修改人" align="center" prop="updateBy" width="150px" />
+      <el-table-column label="修改日期" align="center" prop="updateTime" width="150px" />
+      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" fixed="right" width="150px">
+        <template slot-scope="scope">
+          <el-button
+            size="mini"
+            type="text"
+            icon="el-icon-edit"
+            @click="handleUpdate(scope.row)"
+            v-hasPermi="['goal_management:annualSaleGoalMerge:edit']"
+          >修改</el-button>
+          <el-button
+            size="mini"
+            type="text"
+            icon="el-icon-delete"
+            @click="handleDelete(scope.row)"
+            v-hasPermi="['goal_management:annualSaleGoalMerge: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="drawerAdd" :direction="direction" :before-close="handleClose" size="100%">
+      <el-form ref="form" :model="form" :rules="rules" label-width="100px">
+        <el-row :gutter="50">
+          <el-col :span="1.5">
+            <el-form-item label="单据编码" prop="code">
+              <el-input v-model="form.code" placeholder="单据编码后端自动生成" disabled />
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <el-form-item label="目标名称" prop="goalName">
+              <el-input v-model="form.goalName" placeholder="目标名称后端自动生成" disabled />
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <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="1.5">
+            <el-form-item label="制单人" prop="creator">
+              <dr-popover-select v-model="form.creator" title="制单人" type="CONTACTS_PARAM" :dataMapping="{
+                creatorCode: 'code',
+                creator: 'name'
+              }" :source.sync="form" placeholder="请输入制单人"></dr-popover-select>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="50">
+          <el-col :span="1.5">
+            <el-form-item label="年度" prop="annual">
+              <el-select v-model="form.annual" 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-col :span="1.5">
+            <el-form-item label="目标分类" prop="goalCategory">
+              <el-select v-model="form.goalCategory" placeholder="请选择" @change="changeGoalCategory">
+                <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-col :span="1.5">
+            <el-form-item label="部门" prop="dept">
+              <dr-popover-select v-model="form.dept" title="部门" type="DEPT_PARAM" :dataMapping="{
+                deptCode: 'code',
+                dept: 'name'
+              }" :source.sync="form" placeholder="请输入部门"></dr-popover-select>
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <el-form-item label="目标值汇总" prop="goalTotal">
+              <el-input v-model="form.goalTotal" placeholder="请输入目标值汇总" disabled />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="50">
+          <el-col :span="1.5">
+            <el-form-item label="备注" prop="notes">
+              <el-input v-model="form.notes" placeholder="请输入备注" />
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <el-form-item label="销售区域" prop="saleZone" id="saleZone" style="display: none">
+              <dr-popover-select v-model="form.saleZone" title="销售区域" type="ORG_PARAM" :dataMapping="{
+                saleZoneCode: 'code',
+                saleZone: 'name',
+            }" :source.sync="form" placeholder="请输入销售区域"></dr-popover-select>
+            </el-form-item>
+            <el-form-item label="一级物料" prop="oneLevelClassify" id="oneLevel" style="display: none">
+              <el-select v-model="form.oneLevelClassify" placeholder="请输入一级物料" clearable
+                @focus="chooseTreeRefer('MATERIALCLASSIFY_PARAM', false, '一级物料分类')"
+              ></el-select>
+            </el-form-item>
+            <el-form-item label="二级物料" prop="twoLevelClassify" id="twoLevel" style="display: none">
+              <el-select v-model="form.twoLevelClassify" placeholder="请输入二级物料" clearable
+                @focus="chooseTreeRefer('MATERIALCLASSIFY_PARAM', false, '二级物料分类')"
+              ></el-select>
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <el-form-item>
+              <el-button type="primary" @click="submitForm" size="medium">确 定</el-button>
+              <el-button @click="cancel" size="medium">重 置</el-button>
+            </el-form-item>
+          </el-col>
+        </el-row>
+      </el-form>
+    </el-drawer>
+
+    <el-drawer title="年销售目标合并--修改" :visible.sync="drawerEdit" :direction="direction" :before-close="handleClose" size="100%">
+      <el-form ref="form" :model="form" :rules="rules" label-width="100px">
+        <el-row :gutter="50">
+          <el-col :span="1.5">
+            <el-form-item label="单据编码" prop="code">
+              <el-input v-model="form.code" placeholder="单据编码后端自动生成" disabled />
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <el-form-item label="目标名称" prop="goalName">
+              <el-input v-model="form.goalName" placeholder="目标名称后端自动生成" disabled />
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <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="1.5">
+            <el-form-item label="制单人" prop="creator">
+              <dr-popover-select v-model="form.creator" title="制单人" type="CONTACTS_PARAM" :dataMapping="{
+                creatorCode: 'code',
+                creator: 'name'
+              }" :source.sync="form" placeholder="请输入制单人"></dr-popover-select>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="50">
+          <el-col :span="1.5">
+            <el-form-item label="年度" prop="annual">
+              <el-select v-model="form.annual" 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-col :span="1.5">
+            <el-form-item label="目标分类" prop="goalCategory">
+              <el-select v-model="form.goalCategory" placeholder="请选择" @change="changeGoalCategory" disabled>
+                <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-col :span="1.5">
+            <el-form-item label="部门" prop="dept">
+              <dr-popover-select v-model="form.dept" title="部门" type="DEPT_PARAM" :dataMapping="{
+                deptCode: 'code',
+                dept: 'name'
+              }" :source.sync="form" placeholder="请输入部门"></dr-popover-select>
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <el-form-item label="目标值汇总" prop="goalTotal">
+              <el-input v-model="form.goalTotal" placeholder="请输入目标值汇总" disabled />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="50">
+          <el-col :span="1.5">
+            <el-form-item label="备注" prop="notes">
+              <el-input v-model="form.notes" placeholder="请输入备注" />
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <el-form-item v-if="form.goalCategory === '销售区域'" label="销售区域" prop="saleZone" id="saleZone1">
+              <el-popover-select-v2 v-model="form.saleZone" title="销售区域" 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" id="oneLevel1">
+              <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" id="twoLevel1">
+              <el-select v-model="form.twoLevelClassify" placeholder="请输入二级物料" clearable
+                         @focus="chooseTreeRefer('MATERIALCLASSIFY_PARAM', false, '二级物料分类')"
+              ></el-select>
+            </el-form-item>
+          </el-col>
+          <el-col :span="1.5">
+            <el-form-item>
+              <el-button type="primary" @click="submitForm" size="medium">修 改</el-button>
+            </el-form-item>
+          </el-col>
+        </el-row>
+      </el-form>
+    </el-drawer>
+
+    <TreeRefers ref="tree" :single="true" @doSubmit="selectionsToTreeInput"></TreeRefers>
+  </div>
 </template>
 
 <script>
+import { listAnnualSaleGoalMerge, getAnnualSaleGoalMerge, delAnnualSaleGoalMerge, addAnnualSaleGoalMerge, updateAnnualSaleGoalMerge } from "@/api/business/spd/goal_management/annualSaleGoalMerge";
+
+// 树形参照
+import TreeRefers from "@/components/Refers/treeRefer.vue"
+import ElPopoverSelectV2 from "@/components/popover-select-v2"
+
 export default {
-  name: "AnnualSaleGoalMerge"
-}
+  name: "AnnualSaleGoalMerge",
+  components: {
+    TreeRefers, ElPopoverSelectV2
+  },
+  data() {
+    return {
+      // 遮罩层
+      loading: true,
+      // 选中数组
+      ids: [],
+      // 非单个禁用
+      single: true,
+      // 非多个禁用
+      multiple: true,
+      // 显示搜索条件
+      showSearch: true,
+      // 总条数
+      total: 0,
+      // 年销售目标合并表格数据
+      annualSaleGoalMergeList: [],
+      // 查询参数
+      queryParams: {
+        pageNum: 1,
+        pageSize: 10,
+        code: null,
+        goalName: null,
+        documentDate: null,
+        annual: null,
+        creatorCode: null,
+        creator: null,
+        deptCode: null,
+        dept: null,
+        goalCategory: null,
+        goalTotal: null,
+        notes: null,
+        documentStatus: null,
+        deleteStatus: 0,
+        saleZoneCode: null,
+        saleZone: null,
+        oneLevelClassifyCode: null,
+        oneLevelClassify: null,
+        twoLevelClassifyCode: null,
+        twoLevelClassify: null
+      },
+      // 表单参数
+      form: {
+        id: null,
+        code: null,
+        goalName: null,
+        documentDate: null,
+        annual: null,
+        creatorCode: null,
+        creator: null,
+        deptCode: null,
+        dept: null,
+        goalCategory: null,
+        goalTotal: null,
+        notes: null,
+        documentStatus: null,
+        deleteStatus: null,
+        saleZoneCode: null,
+        saleZone: null,
+        oneLevelClassifyCode: null,
+        oneLevelClassify: null,
+        twoLevelClassifyCode: null,
+        twoLevelClassify: null
+      },
+      // 表单校验
+      rules: {
+        documentDate: [{required: true, message: '单据日期不能为空', trigger: 'blur'}],
+        annual: [{required: true, message: '年度不能为空', trigger: 'blur'}],
+        creator: [{required: true, message: '制单人不能为空', trigger: 'blur'}],
+        dept: [{required: true, message: '部门不能为空', trigger: 'blur'}],
+        goalCategory: [{required: true, message: '目标分类不能为空', trigger: 'blur'}],
+        saleZone: [{required: true, message: '销售区域不能为空', trigger: 'blur'}],
+        oneLevelClassify: [{required: true, message: '一级分类不能为空', trigger: 'blur'}],
+        twoLevelClassify: [{required: true, message: '二级分类不能为空', trigger: 'blur'}],
+      },
+      // 添加抽屉
+      drawerAdd: false,
+      // 修改抽屉
+      drawerEdit: false,
+      // 抽屉打开方向
+      direction: 'rtl',
+      // 目标分类
+      goalCategoryList: [
+        { 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' },
+      ],
+      // 参照条件 & 参照列表
+      referCondition: { type: '', isPage: true, title: '' },
+      classList: []
+    };
+  },
+  created() {
+    this.getList();
+  },
+  methods: {
+    /** 查询年销售目标合并列表 */
+    getList() {
+      this.loading = true;
+      listAnnualSaleGoalMerge(this.queryParams).then(response => {
+        this.annualSaleGoalMergeList = response.rows;
+        this.total = response.total;
+        this.loading = false;
+      });
+    },
+    // 取消按钮
+    cancel() {
+      this.open = false;
+      this.reset();
+    },
+    // 表单重置
+    reset() {
+      this.form = {
+        id: null,
+        code: null,
+        goalName: null,
+        documentDate: null,
+        annual: null,
+        creatorCode: null,
+        creator: null,
+        deptCode: null,
+        dept: null,
+        goalCategory: null,
+        goalTotal: null,
+        notes: null,
+        documentStatus: null,
+        deleteStatus: null,
+        saleZoneCode: null,
+        saleZone: null,
+        oneLevelClassifyCode: null,
+        oneLevelClassify: null,
+        twoLevelClassifyCode: null,
+        twoLevelClassify: 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.drawerAdd = true;
+    },
+    /** 修改按钮操作 */
+    handleUpdate(row) {
+      this.reset();
+      const id = row.id || this.ids
+      getAnnualSaleGoalMerge(id).then(response => {
+        this.form = response.data;
+        this.drawerEdit = true;
+      });
+    },
+    /** 提交按钮 */
+    submitForm() {
+      this.form.deleteStatus = 0
+      this.form.documentStatus = '开立态'
+      console.log(this.form);
+      if (this.form.goalCategory === '销售区域') {
+        if (this.form.saleZone === null || this.form.saleZone === '') {
+          return this.$message.error('请填写销售区域!')
+        } else {
+          this.rules.saleZone = [{required: true, message: '销售区域不能为空', trigger: 'blur'}]
+          this.rules.oneLevelClassify = ''
+          this.rules.twoLevelClassify = ''
+        }
+      } else if (this.form.goalCategory === '一级分类') {
+        if (this.form.oneLevelClassify === null || this.form.oneLevelClassify === '') {
+          return this.$message.error('请填写一级分类!')
+        } else {
+          this.rules.saleZone = ''
+          this.rules.oneLevelClassify = [{required: true, message: '一级分类不能为空', trigger: 'blur'}]
+          this.rules.twoLevelClassify = ''
+        }
+      } else if (this.form.goalCategory === '二级分类') {
+        if (this.form.twoLevelClassify === null || this.form.twoLevelClassify === '') {
+          return this.$message.error('请填写二级分类!')
+        } else {
+          this.rules.saleZone = ''
+          this.rules.oneLevelClassify = ''
+          this.rules.twoLevelClassify = [{required: true, message: '二级分类不能为空', trigger: 'blur'}]
+        }
+      }
+      this.$refs["form"].validate(valid => {
+        if (!valid) {
+          return this.$message.error('有字段未填写')
+        }
+        if (valid) {
+          if (this.form.id != null) {
+            updateAnnualSaleGoalMerge(this.form).then(response => {
+              this.$modal.msgSuccess("修改成功");
+              this.drawerEdit = false;
+              this.getList();
+            });
+          } else {
+            addAnnualSaleGoalMerge(this.form).then(response => {
+              this.$modal.msgSuccess("新增成功");
+              this.drawerAdd = false;
+              this.getList();
+            });
+          }
+          this.rules.saleZone = [{required: true, message: '销售区域不能为空', trigger: 'blur'}]
+          this.rules.oneLevelClassify = [{required: true, message: '一级分类不能为空', trigger: 'blur'}]
+          this.rules.twoLevelClassify = [{required: true, message: '二级分类不能为空', trigger: 'blur'}]
+        }
+      });
+    },
+    /** 删除按钮操作 */
+    handleDelete(row) {
+      const ids = row.id || this.ids;
+      this.$modal.confirm('是否确认删除年销售目标合并编号为"' + ids + '"的数据项?').then(function() {
+        return delAnnualSaleGoalMerge(ids);
+      }).then(() => {
+        this.getList();
+        this.$modal.msgSuccess("删除成功");
+      }).catch(() => {});
+    },
+    /** 导出按钮操作 */
+    handleExport() {
+      this.download('goal_management/annualSaleGoalMerge/export', {
+        ...this.queryParams
+      }, `annualSaleGoalMerge_${new Date().getTime()}.xlsx`)
+    },
+    // 关闭抽屉
+    handleClose(done) {
+      this.$confirm('确认关闭?').then(_ => {
+        done();
+        this.reset()
+        this.getList()
+      }).catch(_ => {})
+    },
+    // 改变目标分类
+    changeGoalCategory() {
+      const goalCategory = this.form.goalCategory
+      if (goalCategory === '销售区域') {
+        document.getElementById("saleZone").style.display = 'inline'
+        document.getElementById("oneLevel").style.display = 'none'
+        document.getElementById("twoLevel").style.display = 'none'
+      } else if (goalCategory === '一级分类') {
+        document.getElementById("oneLevel").style.display = 'inline'
+        document.getElementById("saleZone").style.display = 'none'
+        document.getElementById("twoLevel").style.display = 'none'
+      } else if (goalCategory === '二级分类') {
+        document.getElementById("twoLevel").style.display = 'inline'
+        document.getElementById("saleZone").style.display = 'none'
+        document.getElementById("oneLevel").style.display = 'none'
+      }
+      this.form.saleZoneCode = null
+      this.form.saleZone = null
+      this.form.oneLevelClassify = null
+      this.form.oneLevelClassifyCode = null
+      this.form.twoLevelClassify = null
+      this.form.twoLevelClassifyCode = null
+    },
+    // 选择树形参照
+    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)
+      if (this.referCondition.title === '一级物料分类') {
+        if (selection.code.length !== 1) {
+          return this.$message.error('请在一级物料分类中选择数据')
+        }
+        this.form.oneLevelClassify = selection.name
+        this.form.oneLevelClassifyCode = selection.code
+      } else if (this.referCondition.title === '二级物料分类') {
+        if (selection.code.length !== 4) {
+          return this.$message.error('请在二级物料分类中选择数据')
+        }
+        this.form.twoLevelClassify = selection.name
+        this.form.twoLevelClassifyCode = selection.code
+      }
+    }
+  }
+};
 </script>
 
-<style scoped>
-
-</style>

+ 2 - 1
src/views/business/spd/goal_management/annualSaleGoal/index.vue

@@ -431,7 +431,8 @@
               v-model="formDetails.material"
               title="物料"
               placeholder="请输入物料"
-              type="MATERIAL_PARAM" :dataMapping="{ material: 'name', materialCode: 'code' }" :source.sync="formDetails">
+              type="MATERIAL_PARAM" :dataMapping="{ material: 'name', materialCode: 'code' }"
+              :source.sync="formDetails">
             </dr-popover-select>
           </el-form-item>
           <el-form-item label="一月目标" prop="januaryGoal">