|  | @@ -1,4 +1,5 @@
 | 
											
												
													
														|  |  import { getList, update, add, getAnnouncement, getCategoryList } from "@/api/announcement";
 |  |  import { getList, update, add, getAnnouncement, getCategoryList } from "@/api/announcement";
 | 
											
												
													
														|  | 
 |  | +import { getCustomerList } from "@/api/common/customer"; // 新增客户接口导入
 | 
											
												
													
														|  |  import { mapGetters } from "vuex";
 |  |  import { mapGetters } from "vuex";
 | 
											
												
													
														|  |  import {
 |  |  import {
 | 
											
												
													
														|  |      ROLE_OPTIONS,
 |  |      ROLE_OPTIONS,
 | 
											
										
											
												
													
														|  | @@ -56,7 +57,7 @@ import {
 | 
											
												
													
														|  |   * @property {string} orgName - 组织名称
 |  |   * @property {string} orgName - 组织名称
 | 
											
												
													
														|  |   * @property {VisibleRolesMask} visibleRoles - 可见角色掩码(位运算:1工厂 2经销商 4零售商)
 |  |   * @property {VisibleRolesMask} visibleRoles - 可见角色掩码(位运算:1工厂 2经销商 4零售商)
 | 
											
												
													
														|  |   * @property {Object|null} brandScope - 品牌范围
 |  |   * @property {Object|null} brandScope - 品牌范围
 | 
											
												
													
														|  | - * @property {Object|null} customerBlacklist - 客户黑名单
 |  | 
 | 
											
												
													
														|  | 
 |  | + * @property {Array<CustomerBlacklistOption>|null} customerBlacklist - 客户黑名单
 | 
											
												
													
														|  |   * @property {string} remark - 备注
 |  |   * @property {string} remark - 备注
 | 
											
												
													
														|  |   * @property {string} createTime - 创建时间
 |  |   * @property {string} createTime - 创建时间
 | 
											
												
													
														|  |   * @property {string} updateTime - 更新时间
 |  |   * @property {string} updateTime - 更新时间
 | 
											
										
											
												
													
														|  | @@ -140,6 +141,20 @@ import {
 | 
											
												
													
														|  |   * 公告管理混入
 |  |   * 公告管理混入
 | 
											
												
													
														|  |   * @mixin AnnouncementIndexMixin
 |  |   * @mixin AnnouncementIndexMixin
 | 
											
												
													
														|  |   */
 |  |   */
 | 
											
												
													
														|  | 
 |  | +/**
 | 
											
												
													
														|  | 
 |  | + * 客户选项类型定义
 | 
											
												
													
														|  | 
 |  | + * @typedef {import('@/api/common/customer').CustomerRecord} CustomerRecord
 | 
											
												
													
														|  | 
 |  | + */
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/**
 | 
											
												
													
														|  | 
 |  | + * 客户黑名单选项类型定义
 | 
											
												
													
														|  | 
 |  | + * @typedef {Object} CustomerBlacklistOption
 | 
											
												
													
														|  | 
 |  | + * @property {string} id - 客户ID
 | 
											
												
													
														|  | 
 |  | + * @property {string} Customer_NAME - 客户名称
 | 
											
												
													
														|  | 
 |  | + * @property {string} Customer_CODE - 客户编码
 | 
											
												
													
														|  | 
 |  | + * @property {string} Customer_ShortName - 客户简称
 | 
											
												
													
														|  | 
 |  | + */
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  export default {
 |  |  export default {
 | 
											
												
													
														|  |      name: 'AnnouncementIndexMixin',
 |  |      name: 'AnnouncementIndexMixin',
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -171,6 +186,14 @@ export default {
 | 
											
												
													
														|  |                  { label: "经销商", value: 2 },
 |  |                  { label: "经销商", value: 2 },
 | 
											
												
													
														|  |                  { label: "零售商", value: 4 }
 |  |                  { label: "零售商", value: 4 }
 | 
											
												
													
														|  |              ],
 |  |              ],
 | 
											
												
													
														|  | 
 |  | +            /** @type {Array<CustomerBlacklistOption>} 客户黑名单选项列表 */
 | 
											
												
													
														|  | 
 |  | +            customerBlacklistOptions: [],
 | 
											
												
													
														|  | 
 |  | +            /**
 | 
											
												
													
														|  | 
 |  | +             * @type {Array<CustomerRecord>} 当前客户黑名单
 | 
											
												
													
														|  | 
 |  | +             */
 | 
											
												
													
														|  | 
 |  | +            currentCustomerBlacklist: [],
 | 
											
												
													
														|  | 
 |  | +            /** @type {boolean} 客户选项加载状态 */
 | 
											
												
													
														|  | 
 |  | +            customerOptionsLoading: false,
 | 
											
												
													
														|  |              /** @type {TableOption} 表格配置选项 */
 |  |              /** @type {TableOption} 表格配置选项 */
 | 
											
												
													
														|  |              option: {
 |  |              option: {
 | 
											
												
													
														|  |                  height: 'auto',
 |  |                  height: 'auto',
 | 
											
										
											
												
													
														|  | @@ -340,7 +363,7 @@ export default {
 | 
											
												
													
														|  |                      {
 |  |                      {
 | 
											
												
													
														|  |                          label: "客户黑名单",
 |  |                          label: "客户黑名单",
 | 
											
												
													
														|  |                          prop: "customerBlacklist",
 |  |                          prop: "customerBlacklist",
 | 
											
												
													
														|  | -                        type: "json",
 |  | 
 | 
											
												
													
														|  | 
 |  | +                        slot: true,
 | 
											
												
													
														|  |                          hide: true,
 |  |                          hide: true,
 | 
											
												
													
														|  |                          span: 24
 |  |                          span: 24
 | 
											
												
													
														|  |                      }
 |  |                      }
 | 
											
										
											
												
													
														|  | @@ -472,6 +495,11 @@ export default {
 | 
											
												
													
														|  |                      ? this.calculateRolesMask(row.visibleRoles)
 |  |                      ? this.calculateRolesMask(row.visibleRoles)
 | 
											
												
													
														|  |                      : (row.visibleRoles || 7); // 默认所有角色可见
 |  |                      : (row.visibleRoles || 7); // 默认所有角色可见
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +                const updateCustomerBlacklist = this.currentCustomerBlacklist.filter(customer => {
 | 
											
												
													
														|  | 
 |  | +                    const ids = row.customerBlacklist.map(customer => customer.id);
 | 
											
												
													
														|  | 
 |  | +                    return ids.includes(customer.id);
 | 
											
												
													
														|  | 
 |  | +                });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |                  // 设置默认值
 |  |                  // 设置默认值
 | 
											
												
													
														|  |                  const formData = {
 |  |                  const formData = {
 | 
											
												
													
														|  |                      ...row,
 |  |                      ...row,
 | 
											
										
											
												
													
														|  | @@ -479,7 +507,8 @@ export default {
 | 
											
												
													
														|  |                      orgCode: this.userInfo.orgCode || 'ORG_0001',
 |  |                      orgCode: this.userInfo.orgCode || 'ORG_0001',
 | 
											
												
													
														|  |                      orgName: this.userInfo.orgName || '默认组织',
 |  |                      orgName: this.userInfo.orgName || '默认组织',
 | 
											
												
													
														|  |                      brandScope: row.brandScope || {},
 |  |                      brandScope: row.brandScope || {},
 | 
											
												
													
														|  | -                    customerBlacklist: row.customerBlacklist || {},
 |  | 
 | 
											
												
													
														|  | 
 |  | +                    // customerBlacklist: Array.isArray(row.customerBlacklist) ? row.customerBlacklist : [],
 | 
											
												
													
														|  | 
 |  | +                    customerBlacklist: updateCustomerBlacklist,
 | 
											
												
													
														|  |                      remark: row.remark || '',
 |  |                      remark: row.remark || '',
 | 
											
												
													
														|  |                      visibleRoles: rolesMask,
 |  |                      visibleRoles: rolesMask,
 | 
											
												
													
														|  |                      status: row.status !== undefined ? row.status : 0, // 默认草稿状态
 |  |                      status: row.status !== undefined ? row.status : 0, // 默认草稿状态
 | 
											
										
											
												
													
														|  | @@ -527,11 +556,16 @@ export default {
 | 
											
												
													
														|  |                      row.categoryName = selectedCategory.name;
 |  |                      row.categoryName = selectedCategory.name;
 | 
											
												
													
														|  |                  }
 |  |                  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +                const updateCustomerBlacklist = this.currentCustomerBlacklist.filter(customer => {
 | 
											
												
													
														|  | 
 |  | +                    const ids = row.customerBlacklist.map(customer => customer.id);
 | 
											
												
													
														|  | 
 |  | +                    return ids.includes(customer.id);
 | 
											
												
													
														|  | 
 |  | +                });
 | 
											
												
													
														|  |                  // 确保必要字段存在
 |  |                  // 确保必要字段存在
 | 
											
												
													
														|  |                  const formData = {
 |  |                  const formData = {
 | 
											
												
													
														|  |                      ...row,
 |  |                      ...row,
 | 
											
												
													
														|  |                      brandScope: row.brandScope || {},
 |  |                      brandScope: row.brandScope || {},
 | 
											
												
													
														|  | -                    customerBlacklist: row.customerBlacklist || {},
 |  | 
 | 
											
												
													
														|  | 
 |  | +                    // customerBlacklist: Array.isArray(row.customerBlacklist) ? row.customerBlacklist : [],
 | 
											
												
													
														|  | 
 |  | +                    customerBlacklist: updateCustomerBlacklist,
 | 
											
												
													
														|  |                      remark: row.remark || '',
 |  |                      remark: row.remark || '',
 | 
											
												
													
														|  |                      visibleRoles: rolesMask
 |  |                      visibleRoles: rolesMask
 | 
											
												
													
														|  |                  };
 |  |                  };
 | 
											
										
											
												
													
														|  | @@ -615,6 +649,17 @@ export default {
 | 
											
												
													
														|  |                      // 将掩码值转换为数值数组格式供表单使用
 |  |                      // 将掩码值转换为数值数组格式供表单使用
 | 
											
												
													
														|  |                      const roleObjects = this.parseRolesMask(formData.visibleRoles);
 |  |                      const roleObjects = this.parseRolesMask(formData.visibleRoles);
 | 
											
												
													
														|  |                      formData.visibleRoles = roleObjects.map(role => role.value);
 |  |                      formData.visibleRoles = roleObjects.map(role => role.value);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +                    // 确保客户黑名单是数组格式
 | 
											
												
													
														|  | 
 |  | +                    formData.customerBlacklist = Array.isArray(formData.customerBlacklist)
 | 
											
												
													
														|  | 
 |  | +                        ? formData.customerBlacklist
 | 
											
												
													
														|  | 
 |  | +                        : [];
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +                    // 如果有客户黑名单数据,设置到选项中以便显示
 | 
											
												
													
														|  | 
 |  | +                    if (formData.customerBlacklist.length > 0) {
 | 
											
												
													
														|  | 
 |  | +                        this.customerBlacklistOptions = [...formData.customerBlacklist];
 | 
											
												
													
														|  | 
 |  | +                    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |                      this.form = formData;
 |  |                      this.form = formData;
 | 
											
												
													
														|  |                  } catch (error) {
 |  |                  } catch (error) {
 | 
											
												
													
														|  |                      console.error('获取详情失败:', error);
 |  |                      console.error('获取详情失败:', error);
 | 
											
										
											
												
													
														|  | @@ -627,9 +672,11 @@ export default {
 | 
											
												
													
														|  |                      orgName: this.userInfo.orgName || '',
 |  |                      orgName: this.userInfo.orgName || '',
 | 
											
												
													
														|  |                      visibleRoles: [], // 默认经销商
 |  |                      visibleRoles: [], // 默认经销商
 | 
											
												
													
														|  |                      brandScope: {},
 |  |                      brandScope: {},
 | 
											
												
													
														|  | -                    customerBlacklist: {},
 |  | 
 | 
											
												
													
														|  | 
 |  | +                    customerBlacklist: [],
 | 
											
												
													
														|  |                      remark: ''
 |  |                      remark: ''
 | 
											
												
													
														|  |                  };
 |  |                  };
 | 
											
												
													
														|  | 
 |  | +                // 清空客户选项
 | 
											
												
													
														|  | 
 |  | +                this.customerBlacklistOptions = [];
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |              done();
 |  |              done();
 | 
											
												
													
														|  |          },
 |  |          },
 | 
											
										
											
												
													
														|  | @@ -660,6 +707,75 @@ export default {
 | 
											
												
													
														|  |              } finally {
 |  |              } finally {
 | 
											
												
													
														|  |                  this.loading = false;
 |  |                  this.loading = false;
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | 
 |  | +        },
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        /**
 | 
											
												
													
														|  | 
 |  | +         * 远程搜索客户数据
 | 
											
												
													
														|  | 
 |  | +         * @async
 | 
											
												
													
														|  | 
 |  | +         * @param {string} query - 搜索关键词
 | 
											
												
													
														|  | 
 |  | +         * @returns {Promise<void>}
 | 
											
												
													
														|  | 
 |  | +         */
 | 
											
												
													
														|  | 
 |  | +        async remoteSearchCustomers(query) {
 | 
											
												
													
														|  | 
 |  | +            if (!query || query.trim().length < 1) {
 | 
											
												
													
														|  | 
 |  | +                this.customerBlacklistOptions = [];
 | 
											
												
													
														|  | 
 |  | +                return;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            this.customerOptionsLoading = true;
 | 
											
												
													
														|  | 
 |  | +            try {
 | 
											
												
													
														|  | 
 |  | +                const response = await getCustomerList({
 | 
											
												
													
														|  | 
 |  | +                    current: 1,
 | 
											
												
													
														|  | 
 |  | +                    size: 50,
 | 
											
												
													
														|  | 
 |  | +                    customerName: query.trim()
 | 
											
												
													
														|  | 
 |  | +                });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +                if (response.data && response.data.success && response.data.data) {
 | 
											
												
													
														|  | 
 |  | +                    /** @type {Array<CustomerRecord>} */
 | 
											
												
													
														|  | 
 |  | +                    const customers = response.data.data.records || [];
 | 
											
												
													
														|  | 
 |  | +                    this.currentCustomerBlacklist = customers;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +                    this.customerBlacklistOptions = customers.map(customer => ({
 | 
											
												
													
														|  | 
 |  | +                        id: customer.id,
 | 
											
												
													
														|  | 
 |  | +                        Customer_NAME: customer.Customer_NAME,
 | 
											
												
													
														|  | 
 |  | +                        Customer_CODE: customer.Customer_CODE,
 | 
											
												
													
														|  | 
 |  | +                        Customer_ShortName: customer.Customer_ShortName
 | 
											
												
													
														|  | 
 |  | +                    }));
 | 
											
												
													
														|  | 
 |  | +                } else {
 | 
											
												
													
														|  | 
 |  | +                    this.customerBlacklistOptions = [];
 | 
											
												
													
														|  | 
 |  | +                }
 | 
											
												
													
														|  | 
 |  | +            } catch (error) {
 | 
											
												
													
														|  | 
 |  | +                console.error('获取客户列表失败:', error);
 | 
											
												
													
														|  | 
 |  | +                this.$message.error('获取客户列表失败');
 | 
											
												
													
														|  | 
 |  | +                this.customerBlacklistOptions = [];
 | 
											
												
													
														|  | 
 |  | +            } finally {
 | 
											
												
													
														|  | 
 |  | +                this.customerOptionsLoading = false;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +        },
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        /**
 | 
											
												
													
														|  | 
 |  | +         * 客户黑名单选择变化处理
 | 
											
												
													
														|  | 
 |  | +         * @param {Array<CustomerBlacklistOption>} selectedCustomers - 选中的客户列表
 | 
											
												
													
														|  | 
 |  | +         */
 | 
											
												
													
														|  | 
 |  | +        handleCustomerBlacklistChange(selectedCustomers) {
 | 
											
												
													
														|  | 
 |  | +            this.form.customerBlacklist = selectedCustomers || [];
 | 
											
												
													
														|  | 
 |  | +        },
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        /**
 | 
											
												
													
														|  | 
 |  | +         * 获取客户显示名称
 | 
											
												
													
														|  | 
 |  | +         * @param {CustomerBlacklistOption} customer - 客户对象
 | 
											
												
													
														|  | 
 |  | +         * @returns {string} 显示名称
 | 
											
												
													
														|  | 
 |  | +         */
 | 
											
												
													
														|  | 
 |  | +        getCustomerDisplayName(customer) {
 | 
											
												
													
														|  | 
 |  | +            if (!customer) return '';
 | 
											
												
													
														|  | 
 |  | +            return `${customer.Customer_NAME}(${customer.Customer_CODE})`;
 | 
											
												
													
														|  | 
 |  | +        },
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        /**
 | 
											
												
													
														|  | 
 |  | +         * 清空客户搜索结果
 | 
											
												
													
														|  | 
 |  | +         */
 | 
											
												
													
														|  | 
 |  | +        clearCustomerOptions() {
 | 
											
												
													
														|  | 
 |  | +            this.customerBlacklistOptions = [];
 | 
											
												
													
														|  | 
 |  | +        },
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  };
 |  |  };
 |