2023-02-11 00:44:00 +08:00
|
|
|
/**
|
|
|
|
* 数据字典工具类
|
|
|
|
*/
|
|
|
|
import { useDictStoreWithOut } from '@/store/modules/dict'
|
|
|
|
import { ElementPlusInfoType } from '@/types/elementPlus'
|
|
|
|
|
|
|
|
const dictStore = useDictStoreWithOut()
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 获取 dictType 对应的数据字典数组
|
|
|
|
*
|
|
|
|
* @param dictType 数据类型
|
|
|
|
* @returns {*|Array} 数据字典数组
|
|
|
|
*/
|
|
|
|
export interface DictDataType {
|
|
|
|
dictType: string
|
|
|
|
label: string
|
|
|
|
value: string | number | boolean
|
|
|
|
colorType: ElementPlusInfoType | ''
|
|
|
|
cssClass: string
|
|
|
|
}
|
|
|
|
|
|
|
|
export const getDictOptions = (dictType: string) => {
|
2023-04-13 00:21:32 +08:00
|
|
|
return dictStore.getDictByType(dictType) || []
|
2023-02-11 00:44:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
export const getIntDictOptions = (dictType: string) => {
|
|
|
|
const dictOption: DictDataType[] = []
|
|
|
|
const dictOptions: DictDataType[] = getDictOptions(dictType)
|
|
|
|
dictOptions.forEach((dict: DictDataType) => {
|
|
|
|
dictOption.push({
|
|
|
|
...dict,
|
|
|
|
value: parseInt(dict.value + '')
|
|
|
|
})
|
|
|
|
})
|
|
|
|
return dictOption
|
|
|
|
}
|
|
|
|
|
|
|
|
export const getStrDictOptions = (dictType: string) => {
|
|
|
|
const dictOption: DictDataType[] = []
|
|
|
|
const dictOptions: DictDataType[] = getDictOptions(dictType)
|
|
|
|
dictOptions.forEach((dict: DictDataType) => {
|
|
|
|
dictOption.push({
|
|
|
|
...dict,
|
|
|
|
value: dict.value + ''
|
|
|
|
})
|
|
|
|
})
|
|
|
|
return dictOption
|
|
|
|
}
|
|
|
|
|
|
|
|
export const getBoolDictOptions = (dictType: string) => {
|
|
|
|
const dictOption: DictDataType[] = []
|
|
|
|
const dictOptions: DictDataType[] = getDictOptions(dictType)
|
|
|
|
dictOptions.forEach((dict: DictDataType) => {
|
|
|
|
dictOption.push({
|
|
|
|
...dict,
|
2023-03-08 22:51:07 +08:00
|
|
|
value: dict.value + '' === 'true'
|
2023-02-11 00:44:00 +08:00
|
|
|
})
|
|
|
|
})
|
|
|
|
return dictOption
|
|
|
|
}
|
|
|
|
|
2023-09-03 01:44:22 +08:00
|
|
|
/**
|
|
|
|
* 获取指定字典类型的指定值对应的字典对象
|
|
|
|
* @param dictType 字典类型
|
|
|
|
* @param value 字典值
|
|
|
|
* @return DictDataType 字典对象
|
|
|
|
*/
|
|
|
|
export const getDictObj = (dictType: string, value: any): DictDataType | undefined => {
|
2023-02-11 00:44:00 +08:00
|
|
|
const dictOptions: DictDataType[] = getDictOptions(dictType)
|
2023-09-03 01:44:22 +08:00
|
|
|
for (const dict of dictOptions) {
|
|
|
|
if (dict.value === value + '') {
|
2023-02-11 00:44:00 +08:00
|
|
|
return dict
|
|
|
|
}
|
2023-09-03 01:44:22 +08:00
|
|
|
}
|
2023-02-11 00:44:00 +08:00
|
|
|
}
|
|
|
|
|
2023-03-26 04:25:34 +08:00
|
|
|
/**
|
|
|
|
* 获得字典数据的文本展示
|
|
|
|
*
|
|
|
|
* @param dictType 字典类型
|
|
|
|
* @param value 字典数据的值
|
2023-09-03 01:44:22 +08:00
|
|
|
* @return 字典名称
|
2023-03-26 04:25:34 +08:00
|
|
|
*/
|
2023-09-03 01:44:22 +08:00
|
|
|
export const getDictLabel = (dictType: string, value: any): string => {
|
2023-03-26 04:25:34 +08:00
|
|
|
const dictOptions: DictDataType[] = getDictOptions(dictType)
|
|
|
|
const dictLabel = ref('')
|
|
|
|
dictOptions.forEach((dict: DictDataType) => {
|
2023-09-03 01:44:22 +08:00
|
|
|
if (dict.value === value + '') {
|
2023-03-26 04:25:34 +08:00
|
|
|
dictLabel.value = dict.label
|
|
|
|
}
|
|
|
|
})
|
|
|
|
return dictLabel.value
|
|
|
|
}
|
|
|
|
|
2023-02-11 00:44:00 +08:00
|
|
|
export enum DICT_TYPE {
|
|
|
|
USER_TYPE = 'user_type',
|
|
|
|
COMMON_STATUS = 'common_status',
|
|
|
|
SYSTEM_TENANT_PACKAGE_ID = 'system_tenant_package_id',
|
2023-08-23 00:43:40 +08:00
|
|
|
TERMINAL = 'terminal', // 终端
|
2023-02-11 00:44:00 +08:00
|
|
|
|
|
|
|
// ========== 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_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',
|
2023-04-13 00:21:32 +08:00
|
|
|
INFRA_CODEGEN_FRONT_TYPE = 'infra_codegen_front_type',
|
2023-02-11 00:44:00 +08:00
|
|
|
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 模块 ==========
|
2023-08-23 15:04:46 +08:00
|
|
|
PAY_CHANNEL_CODE = 'pay_channel_code_type', // 支付渠道编码类型
|
2023-02-11 00:44:00 +08:00
|
|
|
PAY_ORDER_STATUS = 'pay_order_status', // 商户支付订单状态
|
2023-08-13 01:26:59 +08:00
|
|
|
PAY_REFUND_STATUS = 'pay_refund_status', // 退款订单状态
|
2023-08-06 23:25:07 +08:00
|
|
|
PAY_NOTIFY_STATUS = 'pay_notify_status', // 商户支付回调状态
|
|
|
|
PAY_NOTIFY_TYPE = 'pay_notify_type', // 商户支付回调状态
|
|
|
|
|
2023-03-26 04:25:34 +08:00
|
|
|
// ========== MP 模块 ==========
|
|
|
|
MP_AUTO_REPLY_REQUEST_MATCH = 'mp_auto_reply_request_match', // 自动回复请求匹配类型
|
2023-05-26 18:19:39 +08:00
|
|
|
MP_MESSAGE_TYPE = 'mp_message_type', // 消息类型
|
|
|
|
|
2023-06-17 18:33:07 +08:00
|
|
|
// ========== MALL - 会员模块 ==========
|
2023-07-02 23:18:45 +08:00
|
|
|
MEMBER_POINT_BIZ_TYPE = 'member_point_biz_type', // 积分的业务类型
|
2023-09-03 21:14:44 +08:00
|
|
|
BROKERAGE_ENABLED_CONDITION = 'brokerage_enabled_condition', // 分佣模式
|
|
|
|
BROKERAGE_BIND_MODE = 'brokerage_bind_mode', // 分销关系绑定模式
|
|
|
|
BROKERAGE_BANK_NAME = 'brokerage_bank_name', // 佣金提现银行
|
|
|
|
BROKERAGE_WITHDRAW_TYPE = 'brokerage_withdraw_type', // 佣金冻结时间
|
2023-09-03 23:04:20 +08:00
|
|
|
BROKERAGE_RECORD_BIZ_TYPE = 'brokerage_record_biz_type', // 佣金业务类型
|
|
|
|
BROKERAGE_RECORD_STATUS = 'brokerage_record_status', // 佣金状态
|
2023-06-17 18:33:07 +08:00
|
|
|
|
2023-06-17 17:38:20 +08:00
|
|
|
// ========== MALL - 商品模块 ==========
|
|
|
|
PRODUCT_UNIT = 'product_unit', // 商品单位
|
|
|
|
PRODUCT_SPU_STATUS = 'product_spu_status', //商品状态
|
|
|
|
|
|
|
|
// ========== MALL - 交易模块 ==========
|
|
|
|
EXPRESS_CHARGE_MODE = 'trade_delivery_express_charge_mode', //快递的计费方式
|
2023-06-17 21:02:29 +08:00
|
|
|
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', // 订单项 - 售后状态
|
2023-08-26 11:41:43 +08:00
|
|
|
TRADE_DELIVERY_TYPE = 'trade_delivery_type', // 配送方式
|
2023-06-17 17:38:20 +08:00
|
|
|
|
|
|
|
// ========== MALL - 营销模块 ==========
|
2023-05-26 18:19:39 +08:00
|
|
|
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', // 优惠活动的状态
|
2023-08-23 00:43:40 +08:00
|
|
|
PROMOTION_CONDITION_TYPE = 'promotion_condition_type' // 营销的条件类型枚举
|
2023-02-11 00:44:00 +08:00
|
|
|
}
|