| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848 | <template>  <div>    <basic-container v-show="show" class="page-crad">      <el-row>        <el-col :span="4">          <avue-tree            ref="tree"            :option="treeOption"            :data="treeData"            @node-click="nodeClick"            style="height: 73vh"            @save="corpTypeVisible = true"          >            <template slot="addBtn">              <el-tooltip class="item" effect="dark" content="新建分类" placement="top">                <i                  class="el-icon-setting"                  style="font-size: 18px; line-height: 30px; width: 20px; padding: 0 10px"                  @click="corpTypeVisible = true"                ></i>              </el-tooltip>            </template>          </avue-tree>        </el-col>        <el-col :span="20">          <avue-crud            ref="crud"            :option="option"            :data="dataList"            :page.sync="page"            :search.sync="search"            @search-change="searchChange"            @search-reset="searchReset"            @current-change="currentChange"            @size-change="sizeChange"            @refresh-change="refreshChange"            @on-load="onLoad"            :table-loading="loading"            :cell-style="cellStyle"            @search-criteria-switch="searchCriteriaSwitch"          >            <template slot="menuLeft">              <el-button type="primary" size="mini" icon="el-icon-plus" @click.stop="newAdd()">新建客户 </el-button>              <!-- <el-button type="primary" size="mini" icon="el-icon-bottom" @click="excelBox = true">导入 </el-button>              <el-button type="primary" size="mini" icon="el-icon-top" @click="outExport">导出 </el-button>              <el-button type="primary" size="mini" icon="el-icon-download" @click="brandBox = true">                Excel更新品牌              </el-button> -->            </template>            <template slot="enableOrNot" slot-scope="{ row, index, disabled }">              <div v-if="row.enableOrNot === 1">启用</div>              <div v-else style="color: red">禁用</div>            </template>            <template slot-scope="{ row, index }" slot="cname">              <span style="color: #409eff; cursor: pointer" @click.stop="editOpen(row, 2)">{{ row.cname }}</span>            </template>            <template slot="dateSearch">              <el-date-picker                v-model="search.date"                type="daterange"                start-placeholder="开始日期"                end-placeholder="结束日期"                format="yyyy-MM-dd"                value-format="yyyy-MM-dd HH:mm:ss"                :default-time="['00:00:00', '23:59:59']"                :picker-options="pickerOptions"              >              </el-date-picker>            </template>            <template slot-scope="{ type, size, row, index }" slot="menu">              <!-- <el-button                v-if="row.checkStatus == '提交' || row.checkStatus == '驳回'"                :size="size"                :type="type"                @click.stop="passThrough(row, '通过')"                >通过              </el-button>              <el-button                v-if="row.checkStatus == '提交' || row.checkStatus == '通过'"                :size="size"                :type="type"                @click.stop="passThrough(row, '驳回')"                >驳回              </el-button> -->              <el-button :size="size" :type="type" :disabled="row.enableOrNot == 1" @click.stop="rowDel(row)"                >删除              </el-button>            </template>          </avue-crud>        </el-col>      </el-row>    </basic-container>    <details-page v-if="!show" @goBack="goBack()" :detailData="detailData" />    <el-dialog      title="设置门店分类"      v-dialogDrag      :visible.sync="corpTypeVisible"      class="avue-dialog"      width="80%"      append-to-body      @closed="corpTypeClosed"    >      <span>        <corp-type></corp-type>      </span>      <div class="avue-dialog__footer">        <el-button @click="corpTypeVisible = false" size="mini">取 消</el-button>        <el-button @click="addCorpType" type="primary" size="mini">确 定</el-button>      </div>    </el-dialog>    <el-dialog      title="导入客户"      append-to-body      :visible.sync="excelBox"      width="555px"      :close-on-click-modal="false"      v-dialog-drag    >      <avue-form        :option="excelOption"        v-model="excelForm"        table-loading="excelLoading"        :upload-before="uploadBefore"        :upload-after="uploadAfter"      >        <template slot="excelTemplate">          <el-button type="primary" @click="derivation">            点击下载<i class="el-icon-download el-icon--right"></i>          </el-button>        </template>      </avue-form>      <p style="text-align: center; color: #dc0505">温馨提示 第一次导入时请先下载模板</p>    </el-dialog>    <!--更新品牌按钮-->    <el-dialog      title="更新品牌"      append-to-body      :visible.sync="brandBox"      width="555px"      :close-on-click-modal="false"      v-dialog-drag    >      <avue-form        :option="brandExcel"        v-model="brandExcelForm"        table-loading="excelLoading"        :upload-before="uploadBefore"        :upload-after="brandAfter"      >        <template slot="brandTemplate">          <el-button type="primary" @click="brandDerive">            点击下载<i class="el-icon-download el-icon--right"></i>          </el-button>        </template>      </avue-form>      <p style="text-align: center; color: #dc0505">温馨提示 第一次导入时请先下载模板</p>    </el-dialog>  </div></template><script>// @ts-nocheckimport detailsPage from "./detailsPage.vue";import { getList, getCorpType, remove, customerList, submit } from "@/api/store/customerInformation";import corpType from "./components/index.vue";import { getToken } from "@/util/auth";export default {  name: "index",  data() {    return {      corpTypeVisible: false,      excelForm: {},      brandExcelForm: {},      WarehouseNameList: [],      excelOption: {        submitBtn: false,        emptyBtn: false,        column: [          {            label: "模板下载",            prop: "excelTemplate",            formslot: true,            span: 24,          },          {            label: "导入客户",            prop: "excelFile",            type: "upload",            drag: true,            loadText: "客户上传中,请稍等",            accept: ".xls,.xlsx",            span: 24,            propsHttp: {              res: "data",            },            tip: "请上传 .xls,.xlsx 标准格式文件",            action: "/api/gubersail-admin/corpsDesc/corpsImport",          },        ],      },      brandExcel: {        submitBtn: false,        emptyBtn: false,        column: [          {            label: "模版下载",            prop: "brandTemplate",            formslot: true,            span: 24,          },          {            label: "导入品牌",            prop: "brandFile",            type: "upload",            drag: true,            loadText: "品牌上传中,请稍等",            accept: ".xls,.xlsx",            span: 24,            propsHttp: {              res: "data",            },            tip: "请上传 .xls,.xlsx 标准格式文件",            action: "/api/gubersail-admin/corpsDesc/importBrand",          },        ],      },      src: "",      show: true,      excelBox: false,      brandBox: false,      loading: false,      search: {},      detailData: {},      dataList: [],      selectionList: [],      page: {        pageSize: 20,        currentPage: 1,        total: 0,        pageSizes: [10, 20, 30, 40, 50, 100, 200, 300, 400, 500],      },      form: {        debitAmount: 0,        deliveringAmount: 0,        advancePayment: 0,        balanceAmount: 0,        settlmentAmount: 0,      },      formSerach: {},      pickerOptions: {        shortcuts: [          {            text: "当天",            onClick(picker) {              const date = new Date();              const start = new Date(date.getFullYear(), date.getMonth(), date.getDate(), 0, 0, 0);              const end = new Date(date.getFullYear(), date.getMonth(), date.getDate(), 23, 59, 59);              picker.$emit("pick", [start, end]);            },          },          {            text: "昨天",            onClick(picker) {              const date = new Date();              const start = new Date(date.getFullYear(), date.getMonth(), date.getDate() - 1, 0, 0, 0);              const end = new Date(date.getFullYear(), date.getMonth(), date.getDate() - 1, 23, 59, 59);              picker.$emit("pick", [start, end]);            },          },          {            text: "当月",            onClick(picker) {              const date = new Date();              const start = new Date(date.getFullYear(), date.getMonth(), 1, 0, 0, 0);              const end = new Date(date.getFullYear(), date.getMonth() + 1, 0, 23, 59, 59);              picker.$emit("pick", [start, end]);            },          },          {            text: "当季",            onClick(picker) {              const date = new Date();              const start = new Date(date.getFullYear(), parseInt(date.getMonth() / 3) * 3, 1, 0, 0, 0);              const end = new Date(date.getFullYear(), parseInt(date.getMonth() / 3) * 3 + 3, 0, 23, 59, 59);              picker.$emit("pick", [start, end]);            },          },          {            text: "当年",            onClick(picker) {              const date = new Date();              const start = new Date(date.getFullYear(), date.getMonth(), 1, 0, 0, 0);              const end = new Date(date.getFullYear() + 1, 0, 0, 23, 59, 59);              picker.$emit("pick", [start, end]);            },          },          {            text: "最近一周",            onClick(picker) {              const date = new Date();              const start = new Date(date.getFullYear(), date.getMonth(), date.getDate() - 7, 0, 0, 0);              const end = new Date(date.getFullYear(), date.getMonth(), date.getDate(), 23, 59, 59);              picker.$emit("pick", [start, end]);            },          },          {            text: "最近二周",            onClick(picker) {              const date = new Date();              const start = new Date(date.getFullYear(), date.getMonth(), date.getDate() - 7 * 2, 0, 0, 0);              const end = new Date(date.getFullYear(), date.getMonth(), date.getDate(), 23, 59, 59);              picker.$emit("pick", [start, end]);            },          },          {            text: "最近三周",            onClick(picker) {              const date = new Date();              const start = new Date(date.getFullYear(), date.getMonth(), date.getDate() - 7 * 3, 0, 0, 0);              const end = new Date(date.getFullYear(), date.getMonth(), date.getDate(), 23, 59, 59);              picker.$emit("pick", [start, end]);            },          },        ],      },      treeOption: {        addBtn: false,        menu: false,        size: "small",        props: {          labelText: "标题",          label: "title",          value: "value",        },      },      treeData: [],      form4: {},      option4: {        menuBtn: false,        labelWidth: 80,        column: [          {            label: "分类名称",            prop: "cname",            rules: [              {                required: true,                message: "",                trigger: "blur",              },            ],            span: 24,          },          {            label: "上级类型",            prop: "parentId",            dicUrl: "/api/gubersail-admin/corpstype/page?corpType=KH",            type: "tree",            props: {              label: "cname",              value: "id",              res: "data.records",            },            span: 24,          },        ],      },      hostUrl: "",      option: {        searchShow: true,        searchMenuSpan: 16,        align: "center",        height: "auto",        searchSpan: 8,        tip: false,        border: true,        index: true,        indexFixed: false,        selectionFixed: false,        expandFixed: false,        addBtn: false,        viewBtn: false,        editBtn: false,        delBtn: false,        menuWidth: 150,        searchIcon: true,        searchIndex: 2,        columnBtn: false,        column: [          {            label: "店铺名称",            prop: "cname",            overHidden: true,            width: 140,            search: true,          },          {            label: "电话",            prop: "tel",            overHidden: true,            search: true,          },          {            label: "商城价格",            prop: "priceSystem",            overHidden: true,          },          {            label: "店面分类",            prop: "corpsTypeName",            overHidden: true,          },          {            label: "业务员",            prop: "salesmanName",            overHidden: true,            type: "select",            props: {              label: "name",              value: "name",            },            dicUrl: "/api/blade-user/salerList",            filterable: true,            search: true,          },          {            label: "是否启用",            prop: "enableOrNot",            overHidden: true,            search: true,            showColumn: false,            type: "select",            dicData: [              {                label: "启用",                value: 1,              },              {                label: "禁用",                value: 0,              },            ],          },          {            label: "审核状态",            prop: "checkStatus",            overHidden: true,            // hide: true,            search: true,            // showColumn: false,            type: "select",            dicData: [              {                label: "录入",                value: "录入",              },              {                label: "提交",                value: "提交",              },              {                label: "审核通过",                value: "审核通过",              },              {                label: "审核驳回",                value: "审核驳回",              },            ],          },          {            label: "品牌",            prop: "brandName",            overHidden: true,            type: "select",            dicUrl: "/api/gubersail-admin/brandDesc/list?type=PP¤t=1&size=20&cname={{key}}",            props: {              label: "cname",              value: "cname",              res: "data.records",            },            filterable: true,            remote: true,            search: true,          },          {            label: "创建人",            prop: "createUser",            overHidden: true,            type: "select",            props: {              label: "name",              value: "id",            },            dicUrl: "/api/blade-user/userListAll",            width: 100,          },          {            label: "创建时间",            prop: "createTime",            overHidden: true,            search: true,            searchProp: "createTimeList",            type: "date",            unlinkPanels: true,            searchRange: true,            format: "yyyy-MM-dd",            valueFormat: "yyyy-MM-dd HH:mm:ss",            width: 100,            searchDefaultTime: ["00:00:00", "23:59:59"],          },          {            label: "合同金额",            prop: "debitAmount",            overHidden: true,            hide: true,            showColumn: false,          },          {            label: "已送货",            prop: "deliveringAmount",            overHidden: true,            hide: true,            showColumn: false,          },          {            label: "预收款",            prop: "advancePayment",            overHidden: true,            hide: true,            showColumn: false,          },          {            label: "未收款",            prop: "balanceAmount",            overHidden: true,            hide: true,            showColumn: false,          },          {            label: "已收款",            prop: "settlmentAmount",            overHidden: true,            hide: true,            showColumn: false,          },          {            label: "状态",            prop: "status",            type: "select",            props: {              label: "dictValue",              value: "dictKey",            },            dicUrl: "/api/blade-system/dict-biz/dictionary?code=client_status",            hide: true,            showColumn: false,            overHidden: true,          },          {            label: "日期",            prop: "date",            hide: true,            showColumn: false,            overHidden: true,          },        ],      },      roleName: null,    };  },  components: {    detailsPage,    corpType,  },  activated() {    setTimeout(() => {      this.$nextTick(() => {        this.$refs.crud.doLayout();        this.$refs.crud.refreshTable();      });    }, 100);  },  async created() {    this.roleName = localStorage.getItem("roleName");    this.getAllWorkDicts();  },  mounted() {    // 页面尺寸改变,重新渲染avue表格,避免表格错位    window.addEventListener("resize", () => {      if (Math.abs(this.screenWidth - document.body.clientWidth) > 20) {        this.$nextTick(() => {          this.$refs.crud.refreshTable();        });      }      this.screenWidth = document.body.clientWidth;    });  },  methods: {    // 导入客户    derivation() {      window.open(`/api/gubersail-admin/corpsDesc/corpsExport?${this.website.tokenHeader}=${getToken()}`);    },    // 导入品牌    brandDerive() {      window.open(`/api/gubersail-admin/corpsDesc/corpsExportBrand?${this.website.tokenHeader}=${getToken()}`);    },    //导出    outExport() {      let config = { params: { ...this.search } };      if (config.params) {        for (const [propName, value] of Object.entries(config.params)) {          if (value instanceof Array) {            value.forEach((item, index) => {              config.params[`${propName}[${index}]`] = item;            });            delete config.params[propName];          }        }      }      const routeData = this.$router.resolve({        path: "/api/gubersail-admin/corpsDesc/pjCorpsExport", //跳转目标窗口的地址        query: {          ...config.params, //括号内是要传递给新窗口的参数          identification: this.url,        },      });      window.open(routeData.href.slice(1, routeData.href.length) + "&" + `${this.website.tokenHeader}=${getToken()}`);    },    uploadBefore(file, done, loading) {      done();      loading = true;    },    //   客户导入后回显    uploadAfter(res, done, loading, column) {      this.excelBox = false;      let myError = res.toString(); //转字符串      myError = myError.replace("Error: ", ""); // 去掉前面的" Error: "      this.$message.success(myError);      this.refreshChange();      loading = false;      done();    },    //   品牌更新后回显    brandAfter(res, done, loading, column) {      this.brandBox = false;      console.log(res, "res");      let myError = res.toString(); //转字符串      myError = myError.replace("Error: ", ""); // 去掉前面的" Error: "      this.$message.success(myError);      this.refreshChange();      loading = false;      done();    },    filterNode(value, data) {      console.log(value, data);      if (!value) return true;      return data.label.indexOf(value) !== -1;    },    nodeClick(data) {      this.search.corpsTypeId = data.value;      this.page.currentPage = 1;      this.onLoad(this.page, this.search);    },    getAllWorkDicts() {      getCorpType({ corpType: "KH" }).then((res) => {        this.treeData = res.data.data;      });      customerList({ corpType: "KH" }).then((res) => {        this.findObject(this.option4.column, "parentId").dicData = res.data.data.records;      });      // this.$refs.crud.init();    },    searchCriteriaSwitch(type) {      this.$refs.crud.getTableHeight();    },    cellStyle() {      return "padding:0;height:40px;";    },    //点击搜索按钮触发    searchChange(params, done) {      this.page.currentPage = 1;      this.onLoad(this.page, params);      done();    },    searchReset() {      this.$refs.tree.setCurrentKey(null);      this.search = this.$options.data().search;      this.onLoad(this.page);    },    refreshChange() {      this.onLoad(this.page, this.search);    },    newAdd() {      this.show = false;    },    onLoad(page, params = {}) {      console.log("page", page);      // this.$refs.crud.refreshTable()      console.log("params", params);      console.log("this.search", this.search);      let data = this.deepClone(Object.assign(params, this.search));      if (data.date && data.date.length > 0) {        data.startTime = data.date[0];        data.endTime = data.date[1];      }      delete data.date;      data.corpType = "KH";      this.loading = true;      getList({        current: page.currentPage,        size: page.pageSize,        // ...page.pageSize,        ...data,      })        .then((res) => {          this.dataList = res.data.data.records ? res.data.data.records : [];          this.page.total = res.data.data.total;        })        .finally(() => {          // pageStatistics(data).then(res => {          //   this.form = res.data.data          // })          this.loading = false;        });    },    addCorpType() {      this.getAllWorkDicts();      this.corpTypeVisible = false;    },    corpTypeClosed() {      // this.reload = Math.random();      // this.form4 = this.$options.data().form4    },    editOpen(row, status) {      this.showInfo = true;      this.detailData = {        id: row.id,        status: status,      };      this.show = false;    },    currentChange(val) {      this.page.currentPage = val;    },    sizeChange(val) {      this.page.currentPage = 1;      this.page.pageSize = val;    },    // 通过驳回方法    passThrough(row, type) {      this.$confirm(`确定${type}数据?`, {        confirmButtonText: "确定",        cancelButtonText: "取消",        type: "warning",      }).then(() => {        row.checkStatus = type;        submit(row).then((res) => {          this.$message({            type: "success",            message: `${type}成功!`,          });          this.onLoad(this.page, this.search);        });      });    },    rowDel(row, index, done) {      this.$confirm("确定删除数据?", {        confirmButtonText: "确定",        cancelButtonText: "取消",        type: "warning",      }).then(() => {        remove({ id: row.id, corpType: "KH" }).then((res) => {          if (res.data.code == 200) {            this.$message({              type: "success",              message: "删除成功!",            });            this.onLoad(this.page, this.search);          }        });      });    },    //返回列表    goBack() {      this.detailData = this.$options.data().detailData;      this.show = true;      this.showInfo = true;      this.onLoad(this.page, this.search);      this.$nextTick(() => {        this.$refs.crud.doLayout();        this.$refs.crud.refreshTable();      });    },  },};</script><style lang="scss" scoped>// .page-crad ::v-deep .basic-container__card {//   height: 94.2vh;// }::v-deep .el-form-item__error {  display: none !important;}::v-deep .el-input-group__append {  padding: 0 0px !important;}.el-dialog ::v-deep .el-form-item__error {  display: none !important;}.stat-td {  text-align: center;  position: relative;}.stat-img {  width: 95%;  height: 100px;}.stat-tip {  position: absolute;  left: 15px;  top: 5px;  .money {    color: #fff;    font-size: 28px;    text-align: left;    font-weight: 600;  }  .title {    color: #fff;    font-size: 14px;    text-align: left;    margin-top: 5px;    margin-bottom: 0px;  }}</style>
 |