You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
206 lines
7.9 KiB
206 lines
7.9 KiB
/**
|
|
* Created by 芋道源码
|
|
*
|
|
* 数据字典工具类
|
|
*/
|
|
import store from '@/store'
|
|
|
|
export const DICT_TYPE = {
|
|
USER_TYPE: 'user_type',
|
|
COMMON_STATUS: 'common_status',
|
|
TERMINAL: 'terminal',
|
|
|
|
// ========== SYSTEM 模块 ==========
|
|
SYSTEM_USER_SEX: 'system_user_sex',
|
|
SYSTEM_MENU_TYPE: 'system_menu_type',
|
|
SYSTEM_ROLE_TYPE: 'system_role_type',
|
|
SYSTEM_DATA_SCOPE: 'system_data_scope',
|
|
SYSTEM_NOTICE_TYPE: 'system_notice_type',
|
|
SYSTEM_OPERATE_TYPE: 'system_operate_type',
|
|
SYSTEM_LOGIN_TYPE: 'system_login_type',
|
|
SYSTEM_LOGIN_RESULT: 'system_login_result',
|
|
SYSTEM_SMS_CHANNEL_CODE: 'system_sms_channel_code',
|
|
SYSTEM_SMS_TEMPLATE_TYPE: 'system_sms_template_type',
|
|
SYSTEM_SMS_SEND_STATUS: 'system_sms_send_status',
|
|
SYSTEM_SMS_RECEIVE_STATUS: 'system_sms_receive_status',
|
|
SYSTEM_ERROR_CODE_TYPE: 'system_error_code_type',
|
|
SYSTEM_OAUTH2_GRANT_TYPE: 'system_oauth2_grant_type',
|
|
SYSTEM_MAIL_SEND_STATUS: 'system_mail_send_status',
|
|
SYSTEM_NOTIFY_TEMPLATE_TYPE: 'system_notify_template_type',
|
|
|
|
// ========== INFRA 模块 ==========
|
|
INFRA_BOOLEAN_STRING: 'infra_boolean_string',
|
|
INFRA_REDIS_TIMEOUT_TYPE: 'infra_redis_timeout_type',
|
|
INFRA_JOB_STATUS: 'infra_job_status',
|
|
INFRA_JOB_LOG_STATUS: 'infra_job_log_status',
|
|
INFRA_API_ERROR_LOG_PROCESS_STATUS: 'infra_api_error_log_process_status',
|
|
INFRA_CONFIG_TYPE: 'infra_config_type',
|
|
INFRA_CODEGEN_TEMPLATE_TYPE: 'infra_codegen_template_type',
|
|
INFRA_CODEGEN_FRONT_TYPE: 'infra_codegen_front_type',
|
|
INFRA_CODEGEN_SCENE: 'infra_codegen_scene',
|
|
INFRA_FILE_STORAGE: 'infra_file_storage',
|
|
|
|
// ========== BPM 模块 ==========
|
|
BPM_MODEL_CATEGORY: 'bpm_model_category',
|
|
BPM_MODEL_FORM_TYPE: 'bpm_model_form_type',
|
|
BPM_TASK_ASSIGN_RULE_TYPE: 'bpm_task_assign_rule_type',
|
|
BPM_PROCESS_INSTANCE_STATUS: 'bpm_process_instance_status',
|
|
BPM_PROCESS_INSTANCE_RESULT: 'bpm_process_instance_result',
|
|
BPM_TASK_ASSIGN_SCRIPT: 'bpm_task_assign_script',
|
|
BPM_OA_LEAVE_TYPE: 'bpm_oa_leave_type',
|
|
|
|
// ========== PAY 模块 ==========
|
|
PAY_CHANNEL_WECHAT_VERSION: 'pay_channel_wechat_version', // 微信渠道版本
|
|
|
|
PAY_CHANNEL_CODE: 'pay_channel_code', // 支付渠道编码类型
|
|
PAY_ORDER_STATUS: 'pay_order_status', // 商户支付订单状态
|
|
PAY_REFUND_STATUS: 'pay_refund_status', // 退款订单状态
|
|
PAY_NOTIFY_STATUS: 'pay_notify_status', // 商户支付回调状态
|
|
PAY_NOTIFY_TYPE: 'pay_notify_type', // 商户支付回调状态
|
|
|
|
// ========== MP 模块 ==========
|
|
MP_AUTO_REPLY_REQUEST_MATCH: 'mp_auto_reply_request_match', // 自动回复请求匹配类型
|
|
MP_MESSAGE_TYPE: 'mp_message_type', // 消息类型
|
|
|
|
// ========== MALL - PRODUCT 模块 ==========
|
|
PRODUCT_SPU_STATUS: 'product_spu_status', // 商品 SPU 状态
|
|
|
|
// ========== MALL - ORDER 模块 ==========
|
|
TRADE_AFTER_SALE_STATUS: 'trade_after_sale_status', // 售后 - 状态
|
|
TRADE_AFTER_SALE_WAY: 'trade_after_sale_way', // 售后 - 方式
|
|
TRADE_AFTER_SALE_TYPE: 'trade_after_sale_type', // 售后 - 类型
|
|
TRADE_ORDER_TYPE: 'trade_order_type', // 订单 - 类型
|
|
TRADE_ORDER_STATUS: 'trade_order_status', // 订单 - 状态
|
|
TRADE_ORDER_ITEM_AFTER_SALE_STATUS: 'trade_order_item_after_sale_status', // 订单项 - 售后状态
|
|
|
|
TICKET_ORDER_STATUS: 'ticket_order_status', // 订单 - 类型
|
|
|
|
// ========== MALL - PROMOTION 模块 ==========
|
|
PROMOTION_DISCOUNT_TYPE: 'promotion_discount_type', // 优惠类型
|
|
PROMOTION_PRODUCT_SCOPE: 'promotion_product_scope', // 营销的商品范围
|
|
PROMOTION_COUPON_TEMPLATE_VALIDITY_TYPE: 'promotion_coupon_template_validity_type', // 优惠劵模板的有限期类型
|
|
PROMOTION_COUPON_STATUS: 'promotion_coupon_status', // 优惠劵的状态
|
|
PROMOTION_COUPON_TAKE_TYPE: 'promotion_coupon_take_type', // 优惠劵的领取方式
|
|
PROMOTION_ACTIVITY_STATUS: 'promotion_activity_status', // 优惠活动的状态
|
|
PROMOTION_CONDITION_TYPE: 'promotion_condition_type', // 营销的条件类型枚举
|
|
|
|
// ========== PAGE - CUSTOMER 模块 ==========
|
|
CUSTOMER_TYPE: 'customer_type', // 客户类型状态
|
|
|
|
// ========== PAGE - SCENIC 模块 ==========
|
|
SCENIC_APPLICATIONS_TYPE: 'scenic_applications_type', // 景区应用订阅状态
|
|
|
|
STATION_TYPE:'station_type',
|
|
|
|
SCENIC_LEVEL: 'scenic_level', // 景区等级状态
|
|
TICKET_TYPE: 'ticket_type', // 景区等级状态
|
|
DISTRIBUTION_CHANNEL: 'distribution_channel', // 销售渠道
|
|
TOURIST_INFORMATION: 'tourist_information',//游客必填信息
|
|
BUYTICKETLIMIT: 'buyticketlimit',//微商城购票限制
|
|
|
|
//日期设置 ***********************************
|
|
//操作注意 【门票管理】与【售票管理】的日期设置需保持一致,两个字典表需要同步修改
|
|
DATETIMESETTINGS: 'datesettings',//日期设置 门票管理
|
|
DATETIMESETTINGSALE: 'datesettingsSale',//日期设置 售票管理
|
|
// ***********************************
|
|
|
|
INVENTORY_SETTINGS: 'inventory_settings',//库存设置
|
|
LISTING_DEADLINE: 'listing_deadline',//上架期限
|
|
TICKETCHECKS_NUM: 'ticketchecks_num',//门票检查次数
|
|
REFUND_RULES: 'refund_rules',//退款规则
|
|
EFFECTIVEDAYS: 'effectivedays',//使用天数
|
|
WEEKORDAY: 'weekorday',//使用日期设置
|
|
WEEKEN: 'weeken',//周几
|
|
TICKET_COLLECTION_METHODS: 'ticket_collection_methods',//门票取票方式
|
|
IDCARD_TEL: 'idcard_tel',//身份证加电话
|
|
ISLISTED: 'islisted',//是否上架
|
|
|
|
// ========== PAGE - TICKET 模块 ==========
|
|
TICKET_STATUS: 'ticket_status',//门票状态
|
|
|
|
// ========== PAGE - PRINT 模块 ==========
|
|
PRINT_TICKET_TYPE:'print_ticket_type',//打印门票类型
|
|
PRINT_RIGHT_LEFT:'print_right_left',//打印区域
|
|
PRINT_DIRECTION:'print_direction',//打印方向
|
|
PRINT_INFO:'print_info',//打印内容
|
|
VALIDITY:'validity',//有效期
|
|
CARD_TYPE:'card_type',//卡类型
|
|
COMMUNICATION_STATUS:'communication_status',//通讯状态
|
|
DEVICE_TYPE:'device_type',//请选择设备类型
|
|
DIRECTION:'direction',//请选择通行方向
|
|
SETTLEMENTMETHOD:'settlementmethod',//请选择通行方向
|
|
RECHARGE_RECORD_STATUS:'recharge_record_status',//充值记录状态
|
|
|
|
INVOICESERVICE:'invoiceservice',//是否开通发票服务
|
|
INVOICE_SERVICE_PROVIDER_TYPE:'invoice_service_provider_type',//充值记录状态
|
|
RED_INVOICE_STATUS:'red_invoice_status',//冲红状态
|
|
INVOICE_STATUS:'invoice_status',//开票状态
|
|
INVOICE_LOOKUP_TYPE:'invoice_lookUp_type',//抬头状态
|
|
INVOICE_WAY:'invoice_way',//开票方式
|
|
INVOICE_DRAWER_TYPE:'invoice_drawer_type',//发票申请渠道
|
|
|
|
ORDER_PAY_METHOD:'order_pay_method',//门票订单 支付方式
|
|
|
|
|
|
//微商城
|
|
MINI_PROGRAMS_PERMISSION_SET:'mini_programs_permission_set',
|
|
|
|
}
|
|
|
|
/**
|
|
* 获取 dictType 对应的数据字典数组
|
|
*
|
|
* @param dictType 数据类型
|
|
* @returns {*|Array} 数据字典数组
|
|
*/
|
|
export function getDictDatas(dictType) {
|
|
console.log(store)
|
|
return store.getters.dict_datas[dictType] || []
|
|
}
|
|
|
|
/**
|
|
* 获取 dictType 对应的数据字典数组
|
|
*
|
|
* @param dictType 数据类型
|
|
* @param values 数组、单个元素
|
|
* @returns {*|Array} 数据字典数组
|
|
*/
|
|
export function getDictDatas2(dictType, values) {
|
|
if (values === undefined) {
|
|
return [];
|
|
}
|
|
// 如果是单个元素,则转换成数组
|
|
if (!Array.isArray(values)) {
|
|
values = [this.value];
|
|
}
|
|
// 获得字典数据
|
|
const results = [];
|
|
for (const value of values) {
|
|
const dict = getDictData(dictType, value);
|
|
if (dict) {
|
|
results.push(dict);
|
|
}
|
|
}
|
|
return results;
|
|
}
|
|
|
|
export function getDictData(dictType, value) {
|
|
// 获取 dictType 对应的数据字典数组
|
|
const dictDatas = getDictDatas(dictType)
|
|
if (!dictDatas || dictDatas.length === 0) {
|
|
return ''
|
|
}
|
|
// 获取 value 对应的展示名
|
|
value = value + '' // 强制转换成字符串,因为 DictData 小类数值,是字符串
|
|
for (const dictData of dictDatas) {
|
|
if (dictData.value === value) {
|
|
return dictData;
|
|
}
|
|
}
|
|
return undefined
|
|
}
|
|
|
|
export function getDictDataLabel(dictType, value) {
|
|
const dict = getDictData(dictType, value);
|
|
return dict ? dict.label : '';
|
|
}
|
|
|