refactor: 破坏性重构,将枚举类由 utils 提取到 @vben/utils
parent
25468bece5
commit
e6f76c097d
|
@ -1,6 +1,5 @@
|
||||||
import type { PageParam, PageResult } from '@vben/request';
|
import type { PageParam, PageResult } from '@vben/request';
|
||||||
|
import type { AiWriteTypeEnum } from '@vben/utils';
|
||||||
import type { AiWriteTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useAppConfig } from '@vben/hooks';
|
import { useAppConfig } from '@vben/hooks';
|
||||||
import { fetchEventSource } from '@vben/request';
|
import { fetchEventSource } from '@vben/request';
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
import type { PageParam, PageResult } from '@vben/request';
|
import type { PageParam, PageResult } from '@vben/request';
|
||||||
|
import type { BpmCandidateStrategyEnum, BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import type { BpmTaskApi } from '../task';
|
import type { BpmTaskApi } from '../task';
|
||||||
|
|
||||||
import type { BpmModelApi } from '#/api/bpm/model';
|
import type { BpmModelApi } from '#/api/bpm/model';
|
||||||
import type { BpmCandidateStrategyEnum, BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { requestClient } from '#/api/request';
|
import { requestClient } from '#/api/request';
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@ import { computed, onMounted, reactive, ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenDrawer } from '@vben/common-ui';
|
import { useVbenDrawer } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
|
@ -28,7 +29,6 @@ import {
|
||||||
|
|
||||||
import { getFormDetail } from '#/api/bpm/form';
|
import { getFormDetail } from '#/api/bpm/form';
|
||||||
import { getModelList } from '#/api/bpm/model';
|
import { getModelList } from '#/api/bpm/model';
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
CHILD_PROCESS_MULTI_INSTANCE_SOURCE_TYPE,
|
CHILD_PROCESS_MULTI_INSTANCE_SOURCE_TYPE,
|
||||||
|
|
|
@ -10,6 +10,7 @@ import { computed, onMounted, reactive, ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenDrawer } from '@vben/common-ui';
|
import { useVbenDrawer } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmModelFormType, BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Col,
|
Col,
|
||||||
|
@ -27,8 +28,6 @@ import {
|
||||||
TreeSelect,
|
TreeSelect,
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmModelFormType, BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
CANDIDATE_STRATEGY,
|
CANDIDATE_STRATEGY,
|
||||||
CandidateStrategy,
|
CandidateStrategy,
|
||||||
|
|
|
@ -7,6 +7,7 @@ import { reactive, ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenDrawer } from '@vben/common-ui';
|
import { useVbenDrawer } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Col,
|
Col,
|
||||||
|
@ -22,8 +23,6 @@ import {
|
||||||
SelectOption,
|
SelectOption,
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
DELAY_TYPE,
|
DELAY_TYPE,
|
||||||
DelayTypeEnum,
|
DelayTypeEnum,
|
||||||
|
|
|
@ -6,7 +6,7 @@ import type { Ref } from 'vue';
|
||||||
import { computed, inject, reactive, ref } from 'vue';
|
import { computed, inject, reactive, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon, Plus, Trash2 } from '@vben/icons';
|
import { IconifyIcon, Plus, Trash2 } from '@vben/icons';
|
||||||
import { cloneDeep } from '@vben/utils';
|
import { BpmModelFormType, cloneDeep } from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Card,
|
Card,
|
||||||
|
@ -25,8 +25,6 @@ import {
|
||||||
Tooltip,
|
Tooltip,
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmModelFormType } from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
COMPARISON_OPERATORS,
|
COMPARISON_OPERATORS,
|
||||||
CONDITION_CONFIG_TYPES,
|
CONDITION_CONFIG_TYPES,
|
||||||
|
|
|
@ -7,6 +7,7 @@ import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenDrawer } from '@vben/common-ui';
|
import { useVbenDrawer } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
|
@ -21,8 +22,6 @@ import {
|
||||||
SelectOption,
|
SelectOption,
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { ConditionType } from '../../consts';
|
import { ConditionType } from '../../consts';
|
||||||
import { useNodeName, useWatchNode } from '../../helpers';
|
import { useNodeName, useWatchNode } from '../../helpers';
|
||||||
import Condition from './modules/condition.vue';
|
import Condition from './modules/condition.vue';
|
||||||
|
|
|
@ -10,6 +10,7 @@ import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenDrawer } from '@vben/common-ui';
|
import { useVbenDrawer } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmModelFormType, BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Col,
|
Col,
|
||||||
|
@ -23,8 +24,6 @@ import {
|
||||||
TypographyText,
|
TypographyText,
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmModelFormType, BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { FieldPermissionType, START_USER_BUTTON_SETTING } from '../../consts';
|
import { FieldPermissionType, START_USER_BUTTON_SETTING } from '../../consts';
|
||||||
import {
|
import {
|
||||||
useFormFieldsPermission,
|
useFormFieldsPermission,
|
||||||
|
|
|
@ -12,7 +12,7 @@ import { computed, getCurrentInstance, onMounted, reactive, ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenDrawer } from '@vben/common-ui';
|
import { useVbenDrawer } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { cloneDeep } from '@vben/utils';
|
import { BpmNodeTypeEnum, cloneDeep } from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
|
@ -29,8 +29,6 @@ import {
|
||||||
Tag,
|
Tag,
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
DEFAULT_CONDITION_GROUP_VALUE,
|
DEFAULT_CONDITION_GROUP_VALUE,
|
||||||
TRIGGER_TYPES,
|
TRIGGER_TYPES,
|
||||||
|
|
|
@ -10,7 +10,12 @@ import { computed, nextTick, onMounted, reactive, ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenDrawer } from '@vben/common-ui';
|
import { useVbenDrawer } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { cloneDeep } from '@vben/utils';
|
import {
|
||||||
|
BpmModelFormType,
|
||||||
|
BpmNodeTypeEnum,
|
||||||
|
cloneDeep,
|
||||||
|
ProcessVariableEnum,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
|
@ -34,12 +39,6 @@ import {
|
||||||
TypographyText,
|
TypographyText,
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import {
|
|
||||||
BpmModelFormType,
|
|
||||||
BpmNodeTypeEnum,
|
|
||||||
ProcessVariableEnum,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
APPROVE_METHODS,
|
APPROVE_METHODS,
|
||||||
APPROVE_TYPE,
|
APPROVE_TYPE,
|
||||||
|
|
|
@ -4,11 +4,10 @@ import type { SimpleFlowNode } from '../../consts';
|
||||||
import { inject, ref } from 'vue';
|
import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Input } from 'ant-design-vue';
|
import { Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT } from '../../consts';
|
import { NODE_DEFAULT_TEXT } from '../../consts';
|
||||||
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
||||||
import ChildProcessNodeConfig from '../nodes-config/child-process-node-config.vue';
|
import ChildProcessNodeConfig from '../nodes-config/child-process-node-config.vue';
|
||||||
|
|
|
@ -4,11 +4,10 @@ import type { SimpleFlowNode } from '../../consts';
|
||||||
import { inject, ref } from 'vue';
|
import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Input } from 'ant-design-vue';
|
import { Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT } from '../../consts';
|
import { NODE_DEFAULT_TEXT } from '../../consts';
|
||||||
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
||||||
import CopyTaskNodeConfig from '../nodes-config/copy-task-node-config.vue';
|
import CopyTaskNodeConfig from '../nodes-config/copy-task-node-config.vue';
|
||||||
|
|
|
@ -4,11 +4,10 @@ import type { SimpleFlowNode } from '../../consts';
|
||||||
import { inject, ref } from 'vue';
|
import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Input } from 'ant-design-vue';
|
import { Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT } from '../../consts';
|
import { NODE_DEFAULT_TEXT } from '../../consts';
|
||||||
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
||||||
import DelayTimerNodeConfig from '../nodes-config/delay-timer-node-config.vue';
|
import DelayTimerNodeConfig from '../nodes-config/delay-timer-node-config.vue';
|
||||||
|
|
|
@ -4,12 +4,14 @@ import type { SimpleFlowNode } from '../../consts';
|
||||||
import { getCurrentInstance, inject, nextTick, ref, watch } from 'vue';
|
import { getCurrentInstance, inject, nextTick, ref, watch } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { cloneDeep, buildShortUUID as generateUUID } from '@vben/utils';
|
import {
|
||||||
|
BpmNodeTypeEnum,
|
||||||
|
cloneDeep,
|
||||||
|
buildShortUUID as generateUUID,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { Button, Input } from 'ant-design-vue';
|
import { Button, Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
ConditionType,
|
ConditionType,
|
||||||
DEFAULT_CONDITION_GROUP_VALUE,
|
DEFAULT_CONDITION_GROUP_VALUE,
|
||||||
|
|
|
@ -4,12 +4,14 @@ import type { SimpleFlowNode } from '../../consts';
|
||||||
import { getCurrentInstance, inject, nextTick, ref, watch } from 'vue';
|
import { getCurrentInstance, inject, nextTick, ref, watch } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { cloneDeep, buildShortUUID as generateUUID } from '@vben/utils';
|
import {
|
||||||
|
BpmNodeTypeEnum,
|
||||||
|
cloneDeep,
|
||||||
|
buildShortUUID as generateUUID,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { Button, Input } from 'ant-design-vue';
|
import { Button, Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
ConditionType,
|
ConditionType,
|
||||||
DEFAULT_CONDITION_GROUP_VALUE,
|
DEFAULT_CONDITION_GROUP_VALUE,
|
||||||
|
|
|
@ -4,12 +4,14 @@ import type { SimpleFlowNode } from '../../consts';
|
||||||
import { inject, ref } from 'vue';
|
import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { cloneDeep, buildShortUUID as generateUUID } from '@vben/utils';
|
import {
|
||||||
|
BpmNodeTypeEnum,
|
||||||
|
cloneDeep,
|
||||||
|
buildShortUUID as generateUUID,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { message, Popover } from 'ant-design-vue';
|
import { message, Popover } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
ApproveMethodType,
|
ApproveMethodType,
|
||||||
AssignEmptyHandlerType,
|
AssignEmptyHandlerType,
|
||||||
|
|
|
@ -4,12 +4,10 @@ import type { SimpleFlowNode } from '../../consts';
|
||||||
import { inject, nextTick, ref, watch } from 'vue';
|
import { inject, nextTick, ref, watch } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { buildShortUUID as generateUUID } from '@vben/utils';
|
import { BpmNodeTypeEnum, buildShortUUID as generateUUID } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, Input } from 'ant-design-vue';
|
import { Button, Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT } from '../../consts';
|
import { NODE_DEFAULT_TEXT } from '../../consts';
|
||||||
import { useTaskStatusClass } from '../../helpers';
|
import { useTaskStatusClass } from '../../helpers';
|
||||||
import ProcessNodeTree from '../process-node-tree.vue';
|
import ProcessNodeTree from '../process-node-tree.vue';
|
||||||
|
|
|
@ -4,11 +4,10 @@ import type { SimpleFlowNode } from '../../consts';
|
||||||
import { inject, ref } from 'vue';
|
import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Input } from 'ant-design-vue';
|
import { Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT } from '../../consts';
|
import { NODE_DEFAULT_TEXT } from '../../consts';
|
||||||
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
||||||
import RouterNodeConfig from '../nodes-config/router-node-config.vue';
|
import RouterNodeConfig from '../nodes-config/router-node-config.vue';
|
||||||
|
|
|
@ -8,11 +8,10 @@ import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenModal } from '@vben/common-ui';
|
import { useVbenModal } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Input } from 'ant-design-vue';
|
import { Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT } from '../../consts';
|
import { NODE_DEFAULT_TEXT } from '../../consts';
|
||||||
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
||||||
import StartUserNodeConfig from '../nodes-config/start-user-node-config.vue';
|
import StartUserNodeConfig from '../nodes-config/start-user-node-config.vue';
|
||||||
|
|
|
@ -4,11 +4,10 @@ import type { SimpleFlowNode } from '../../consts';
|
||||||
import { inject, ref } from 'vue';
|
import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Input } from 'ant-design-vue';
|
import { Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT } from '../../consts';
|
import { NODE_DEFAULT_TEXT } from '../../consts';
|
||||||
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
||||||
import TriggerNodeConfig from '../nodes-config/trigger-node-config.vue';
|
import TriggerNodeConfig from '../nodes-config/trigger-node-config.vue';
|
||||||
|
|
|
@ -7,11 +7,10 @@ import { inject, ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenModal } from '@vben/common-ui';
|
import { useVbenModal } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Input } from 'ant-design-vue';
|
import { Input } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT } from '../../consts';
|
import { NODE_DEFAULT_TEXT } from '../../consts';
|
||||||
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
import { useNodeName2, useTaskStatusClass, useWatchNode } from '../../helpers';
|
||||||
import UserTaskNodeConfig from '../nodes-config/user-task-node-config.vue';
|
import UserTaskNodeConfig from '../nodes-config/user-task-node-config.vue';
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import type { SimpleFlowNode } from '../consts';
|
import type { SimpleFlowNode } from '../consts';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
import { BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { useWatchNode } from '../helpers';
|
import { useWatchNode } from '../helpers';
|
||||||
import ChildProcessNode from './nodes/child-process-node.vue';
|
import ChildProcessNode from './nodes/child-process-node.vue';
|
||||||
|
|
|
@ -12,7 +12,7 @@ import type { SystemUserApi } from '#/api/system/user';
|
||||||
import { inject, onMounted, provide, ref, watch } from 'vue';
|
import { inject, onMounted, provide, ref, watch } from 'vue';
|
||||||
|
|
||||||
import { useVbenModal } from '@vben/common-ui';
|
import { useVbenModal } from '@vben/common-ui';
|
||||||
import { handleTree } from '@vben/utils';
|
import { BpmModelFormType, BpmNodeTypeEnum, handleTree } from '@vben/utils';
|
||||||
|
|
||||||
import { Button } from 'ant-design-vue';
|
import { Button } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -22,7 +22,6 @@ import { getSimpleDeptList } from '#/api/system/dept';
|
||||||
import { getSimplePostList } from '#/api/system/post';
|
import { getSimplePostList } from '#/api/system/post';
|
||||||
import { getSimpleRoleList } from '#/api/system/role';
|
import { getSimpleRoleList } from '#/api/system/role';
|
||||||
import { getSimpleUserList } from '#/api/system/user';
|
import { getSimpleUserList } from '#/api/system/user';
|
||||||
import { BpmModelFormType, BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT, NodeId } from '../consts';
|
import { NODE_DEFAULT_TEXT, NodeId } from '../consts';
|
||||||
import SimpleProcessModel from './simple-process-model.vue';
|
import SimpleProcessModel from './simple-process-model.vue';
|
||||||
|
|
|
@ -4,12 +4,10 @@ import type { SimpleFlowNode } from '../consts';
|
||||||
import { onMounted, provide, ref } from 'vue';
|
import { onMounted, provide, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { downloadFileFromBlob, isString } from '@vben/utils';
|
import { BpmNodeTypeEnum, downloadFileFromBlob, isString } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, ButtonGroup, Modal, Row } from 'ant-design-vue';
|
import { Button, ButtonGroup, Modal, Row } from 'ant-design-vue';
|
||||||
|
|
||||||
import { BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { NODE_DEFAULT_TEXT } from '../consts';
|
import { NODE_DEFAULT_TEXT } from '../consts';
|
||||||
import { useWatchNode } from '../helpers';
|
import { useWatchNode } from '../helpers';
|
||||||
import ProcessNodeTree from './process-node-tree.vue';
|
import ProcessNodeTree from './process-node-tree.vue';
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { BpmNodeTypeEnum, BpmTaskStatusEnum } from '#/utils';
|
import { BpmNodeTypeEnum, BpmTaskStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
interface DictDataType {
|
interface DictDataType {
|
||||||
label: string;
|
label: string;
|
||||||
|
|
|
@ -18,7 +18,7 @@ import {
|
||||||
BpmNodeTypeEnum,
|
BpmNodeTypeEnum,
|
||||||
BpmTaskStatusEnum,
|
BpmTaskStatusEnum,
|
||||||
ProcessVariableEnum,
|
ProcessVariableEnum,
|
||||||
} from '#/utils';
|
} from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
ApproveMethodType,
|
ApproveMethodType,
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
import type { DictItem } from '#/store';
|
import type { DictItem } from '#/store';
|
||||||
|
|
||||||
import { isObject } from '@vben/utils';
|
import { DICT_TYPE, isObject } from '@vben/utils';
|
||||||
|
|
||||||
import { useDictStore } from '#/store';
|
import { useDictStore } from '#/store';
|
||||||
|
|
||||||
|
@ -181,142 +181,6 @@ export const deleteDictCache = (dictType: string): void => {
|
||||||
dictCache.delete(dictType);
|
dictCache.delete(dictType);
|
||||||
};
|
};
|
||||||
|
|
||||||
/** 字典类型枚举 - 按模块分组和排序 */
|
|
||||||
enum DICT_TYPE {
|
|
||||||
AI_GENERATE_MODE = 'ai_generate_mode', // AI 生成模式
|
|
||||||
AI_IMAGE_STATUS = 'ai_image_status', // AI 图片状态
|
|
||||||
AI_MODEL_TYPE = 'ai_model_type', // AI 模型类型
|
|
||||||
AI_MUSIC_STATUS = 'ai_music_status', // AI 音乐状态
|
|
||||||
// ========== AI - 人工智能模块 ==========
|
|
||||||
AI_PLATFORM = 'ai_platform', // AI 平台
|
|
||||||
AI_WRITE_FORMAT = 'ai_write_format', // AI 写作格式
|
|
||||||
AI_WRITE_LANGUAGE = 'ai_write_language', // AI 写作语言
|
|
||||||
AI_WRITE_LENGTH = 'ai_write_length', // AI 写作长度
|
|
||||||
AI_WRITE_TONE = 'ai_write_tone', // AI 写作语气
|
|
||||||
AI_WRITE_TYPE = 'ai_write_type', // AI 写作类型
|
|
||||||
BPM_MODEL_FORM_TYPE = 'bpm_model_form_type',
|
|
||||||
// ========== BPM 模块 ==========
|
|
||||||
BPM_MODEL_TYPE = 'bpm_model_type',
|
|
||||||
BPM_OA_LEAVE_TYPE = 'bpm_oa_leave_type',
|
|
||||||
BPM_PROCESS_INSTANCE_STATUS = 'bpm_process_instance_status',
|
|
||||||
BPM_PROCESS_LISTENER_TYPE = 'bpm_process_listener_type',
|
|
||||||
BPM_PROCESS_LISTENER_VALUE_TYPE = 'bpm_process_listener_value_type',
|
|
||||||
BPM_TASK_CANDIDATE_STRATEGY = 'bpm_task_candidate_strategy',
|
|
||||||
BPM_TASK_STATUS = 'bpm_task_status',
|
|
||||||
BROKERAGE_BANK_NAME = 'brokerage_bank_name', // 佣金提现银行
|
|
||||||
BROKERAGE_BIND_MODE = 'brokerage_bind_mode', // 分销关系绑定模式
|
|
||||||
|
|
||||||
BROKERAGE_ENABLED_CONDITION = 'brokerage_enabled_condition', // 分佣模式
|
|
||||||
BROKERAGE_RECORD_BIZ_TYPE = 'brokerage_record_biz_type', // 佣金业务类型
|
|
||||||
BROKERAGE_RECORD_STATUS = 'brokerage_record_status', // 佣金状态
|
|
||||||
BROKERAGE_WITHDRAW_STATUS = 'brokerage_withdraw_status', // 佣金提现状态
|
|
||||||
BROKERAGE_WITHDRAW_TYPE = 'brokerage_withdraw_type', // 佣金提现类型
|
|
||||||
COMMON_STATUS = 'common_status',
|
|
||||||
// ========== CRM - 客户管理模块 ==========
|
|
||||||
CRM_AUDIT_STATUS = 'crm_audit_status', // CRM 审批状态
|
|
||||||
CRM_BIZ_TYPE = 'crm_biz_type', // CRM 业务类型
|
|
||||||
CRM_BUSINESS_END_STATUS_TYPE = 'crm_business_end_status_type', // CRM 商机结束状态类型
|
|
||||||
CRM_CUSTOMER_INDUSTRY = 'crm_customer_industry', // CRM 客户所属行业
|
|
||||||
|
|
||||||
CRM_CUSTOMER_LEVEL = 'crm_customer_level', // CRM 客户级别
|
|
||||||
CRM_CUSTOMER_SOURCE = 'crm_customer_source', // CRM 客户来源
|
|
||||||
CRM_FOLLOW_UP_TYPE = 'crm_follow_up_type', // CRM 跟进方式
|
|
||||||
CRM_PERMISSION_LEVEL = 'crm_permission_level', // CRM 数据权限的级别
|
|
||||||
CRM_PRODUCT_STATUS = 'crm_product_status', // CRM 商品状态
|
|
||||||
CRM_PRODUCT_UNIT = 'crm_product_unit', // CRM 产品单位
|
|
||||||
CRM_RECEIVABLE_RETURN_TYPE = 'crm_receivable_return_type', // CRM 回款的还款方式
|
|
||||||
DATE_INTERVAL = 'date_interval', // 数据间隔
|
|
||||||
|
|
||||||
// ========== ERP - 企业资源计划模块 ==========
|
|
||||||
ERP_AUDIT_STATUS = 'erp_audit_status', // ERP 审批状态
|
|
||||||
ERP_STOCK_RECORD_BIZ_TYPE = 'erp_stock_record_biz_type', // 库存明细的业务类型
|
|
||||||
// ========== MALL - 交易模块 ==========
|
|
||||||
EXPRESS_CHARGE_MODE = 'trade_delivery_express_charge_mode', // 快递的计费方式
|
|
||||||
INFRA_API_ERROR_LOG_PROCESS_STATUS = 'infra_api_error_log_process_status',
|
|
||||||
// ========== INFRA 模块 ==========
|
|
||||||
INFRA_BOOLEAN_STRING = 'infra_boolean_string',
|
|
||||||
INFRA_CODEGEN_FRONT_TYPE = 'infra_codegen_front_type',
|
|
||||||
INFRA_CODEGEN_SCENE = 'infra_codegen_scene',
|
|
||||||
|
|
||||||
INFRA_CODEGEN_TEMPLATE_TYPE = 'infra_codegen_template_type',
|
|
||||||
INFRA_CONFIG_TYPE = 'infra_config_type',
|
|
||||||
|
|
||||||
INFRA_FILE_STORAGE = 'infra_file_storage',
|
|
||||||
INFRA_JOB_LOG_STATUS = 'infra_job_log_status',
|
|
||||||
|
|
||||||
INFRA_JOB_STATUS = 'infra_job_status',
|
|
||||||
|
|
||||||
INFRA_OPERATE_TYPE = 'infra_operate_type',
|
|
||||||
IOT_DATA_FORMAT = 'iot_data_format', // IOT 数据格式
|
|
||||||
IOT_DATA_TYPE = 'iot_data_type', // IOT 数据类型
|
|
||||||
IOT_DEVICE_STATUS = 'iot_device_status', // IOT 设备状态
|
|
||||||
// ========== IOT - 物联网模块 ==========
|
|
||||||
IOT_NET_TYPE = 'iot_net_type', // IOT 联网方式
|
|
||||||
IOT_PRODUCT_DEVICE_TYPE = 'iot_product_device_type', // IOT 产品设备类型
|
|
||||||
IOT_PRODUCT_FUNCTION_TYPE = 'iot_product_function_type', // IOT 产品功能类型
|
|
||||||
IOT_PRODUCT_STATUS = 'iot_product_status', // IOT 产品状态
|
|
||||||
IOT_PROTOCOL_TYPE = 'iot_protocol_type', // IOT 接入网关协议
|
|
||||||
IOT_RW_TYPE = 'iot_rw_type', // IOT 读写类型
|
|
||||||
IOT_UNIT_TYPE = 'iot_unit_type', // IOT 单位类型
|
|
||||||
IOT_VALIDATE_TYPE = 'iot_validate_type', // IOT 数据校验级别
|
|
||||||
MEMBER_EXPERIENCE_BIZ_TYPE = 'member_experience_biz_type', // 会员经验业务类型
|
|
||||||
// ========== Member 会员模块 ==========
|
|
||||||
MEMBER_POINT_BIZ_TYPE = 'member_point_biz_type', // 积分的业务类型
|
|
||||||
// ========== MP 模块 ==========
|
|
||||||
MP_AUTO_REPLY_REQUEST_MATCH = 'mp_auto_reply_request_match', // 自动回复请求匹配类型
|
|
||||||
|
|
||||||
MP_MESSAGE_TYPE = 'mp_message_type', // 消息类型
|
|
||||||
// ========== PAY 模块 ==========
|
|
||||||
PAY_CHANNEL_CODE = 'pay_channel_code', // 支付渠道编码类型
|
|
||||||
PAY_NOTIFY_STATUS = 'pay_notify_status', // 商户支付回调状态
|
|
||||||
PAY_NOTIFY_TYPE = 'pay_notify_type', // 商户支付回调状态
|
|
||||||
PAY_ORDER_STATUS = 'pay_order_status', // 商户支付订单状态
|
|
||||||
PAY_REFUND_STATUS = 'pay_refund_status', // 退款订单状态
|
|
||||||
PAY_TRANSFER_STATUS = 'pay_transfer_status', // 转账订单状态
|
|
||||||
PAY_TRANSFER_TYPE = 'pay_transfer_type', // 转账订单状态
|
|
||||||
// ========== MALL - 商品模块 ==========
|
|
||||||
PRODUCT_SPU_STATUS = 'product_spu_status', // 商品状态
|
|
||||||
|
|
||||||
PROMOTION_BANNER_POSITION = 'promotion_banner_position', // banner 定位
|
|
||||||
PROMOTION_BARGAIN_RECORD_STATUS = 'promotion_bargain_record_status', // 砍价记录的状态
|
|
||||||
PROMOTION_COMBINATION_RECORD_STATUS = 'promotion_combination_record_status', // 拼团记录的状态
|
|
||||||
PROMOTION_CONDITION_TYPE = 'promotion_condition_type', // 营销的条件类型枚举
|
|
||||||
PROMOTION_COUPON_STATUS = 'promotion_coupon_status', // 优惠劵的状态
|
|
||||||
PROMOTION_COUPON_TAKE_TYPE = 'promotion_coupon_take_type', // 优惠劵的领取方式
|
|
||||||
PROMOTION_COUPON_TEMPLATE_VALIDITY_TYPE = 'promotion_coupon_template_validity_type', // 优惠劵模板的有限期类型
|
|
||||||
// ========== MALL - 营销模块 ==========
|
|
||||||
PROMOTION_DISCOUNT_TYPE = 'promotion_discount_type', // 优惠类型
|
|
||||||
PROMOTION_PRODUCT_SCOPE = 'promotion_product_scope', // 营销的商品范围
|
|
||||||
SYSTEM_DATA_SCOPE = 'system_data_scope',
|
|
||||||
SYSTEM_LOGIN_RESULT = 'system_login_result',
|
|
||||||
|
|
||||||
SYSTEM_LOGIN_TYPE = 'system_login_type',
|
|
||||||
SYSTEM_MAIL_SEND_STATUS = 'system_mail_send_status',
|
|
||||||
|
|
||||||
SYSTEM_MENU_TYPE = 'system_menu_type',
|
|
||||||
SYSTEM_NOTICE_TYPE = 'system_notice_type',
|
|
||||||
SYSTEM_NOTIFY_TEMPLATE_TYPE = 'system_notify_template_type',
|
|
||||||
SYSTEM_OAUTH2_GRANT_TYPE = 'system_oauth2_grant_type',
|
|
||||||
SYSTEM_ROLE_TYPE = 'system_role_type',
|
|
||||||
SYSTEM_SMS_CHANNEL_CODE = 'system_sms_channel_code',
|
|
||||||
SYSTEM_SMS_RECEIVE_STATUS = 'system_sms_receive_status',
|
|
||||||
SYSTEM_SMS_SEND_STATUS = 'system_sms_send_status',
|
|
||||||
SYSTEM_SMS_TEMPLATE_TYPE = 'system_sms_template_type',
|
|
||||||
|
|
||||||
SYSTEM_SOCIAL_TYPE = 'system_social_type',
|
|
||||||
// ========== SYSTEM 模块 ==========
|
|
||||||
SYSTEM_USER_SEX = 'system_user_sex',
|
|
||||||
TERMINAL = 'terminal', // 终端
|
|
||||||
TRADE_AFTER_SALE_STATUS = 'trade_after_sale_status', // 售后 - 状态
|
|
||||||
TRADE_AFTER_SALE_TYPE = 'trade_after_sale_type', // 售后 - 类型
|
|
||||||
TRADE_AFTER_SALE_WAY = 'trade_after_sale_way', // 售后 - 方式
|
|
||||||
TRADE_DELIVERY_TYPE = 'trade_delivery_type', // 配送方式
|
|
||||||
TRADE_ORDER_ITEM_AFTER_SALE_STATUS = 'trade_order_item_after_sale_status', // 订单项 - 售后状态
|
|
||||||
TRADE_ORDER_STATUS = 'trade_order_status', // 订单 - 状态
|
|
||||||
TRADE_ORDER_TYPE = 'trade_order_type', // 订单 - 类型
|
|
||||||
USER_TYPE = 'user_type',
|
|
||||||
}
|
|
||||||
|
|
||||||
export {
|
export {
|
||||||
type ColorType,
|
type ColorType,
|
||||||
DICT_TYPE,
|
DICT_TYPE,
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
export * from './constants';
|
|
||||||
export * from './dict';
|
export * from './dict';
|
||||||
export * from './formCreate';
|
export * from './formCreate';
|
||||||
export * from './rangePickerProps';
|
export * from './rangePickerProps';
|
||||||
export * from './routerHelper';
|
export * from './routerHelper';
|
||||||
|
export { CommonStatusEnum } from '@vben/utils';
|
||||||
|
|
|
@ -6,7 +6,7 @@ import { computed, onMounted, ref } from 'vue';
|
||||||
import { useRoute } from 'vue-router';
|
import { useRoute } from 'vue-router';
|
||||||
|
|
||||||
import { confirm } from '@vben/common-ui';
|
import { confirm } from '@vben/common-ui';
|
||||||
import { getUrlValue } from '@vben/utils';
|
import { getUrlValue, SystemUserSocialTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, Card, Image, message } from 'ant-design-vue';
|
import { Button, Card, Image, message } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ import {
|
||||||
socialUnbind,
|
socialUnbind,
|
||||||
} from '#/api/system/social/user';
|
} from '#/api/system/social/user';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { DICT_TYPE, getDictLabel, SystemUserSocialTypeEnum } from '#/utils';
|
import { DICT_TYPE, getDictLabel } from '#/utils';
|
||||||
|
|
||||||
const emit = defineEmits<{
|
const emit = defineEmits<{
|
||||||
(e: 'update:activeName', v: string): void;
|
(e: 'update:activeName', v: string): void;
|
||||||
|
|
|
@ -7,11 +7,10 @@ import { onMounted, ref, toRefs, watch } from 'vue';
|
||||||
|
|
||||||
import { confirm } from '@vben/common-ui';
|
import { confirm } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { AiImageStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, Card, Image, message } from 'ant-design-vue';
|
import { Button, Card, Image, message } from 'ant-design-vue';
|
||||||
|
|
||||||
import { AiImageStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
// 消息
|
// 消息
|
||||||
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
|
|
|
@ -3,18 +3,18 @@ import type { AiImageApi } from '#/api/ai/image';
|
||||||
|
|
||||||
import { ref, toRefs, watch } from 'vue';
|
import { ref, toRefs, watch } from 'vue';
|
||||||
|
|
||||||
import { formatDate } from '@vben/utils';
|
import {
|
||||||
|
AiPlatformEnum,
|
||||||
|
Dall3StyleList,
|
||||||
|
formatDate,
|
||||||
|
StableDiffusionClipGuidancePresets,
|
||||||
|
StableDiffusionSamplers,
|
||||||
|
StableDiffusionStylePresets,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { Image } from 'ant-design-vue';
|
import { Image } from 'ant-design-vue';
|
||||||
|
|
||||||
import { getImageMy } from '#/api/ai/image';
|
import { getImageMy } from '#/api/ai/image';
|
||||||
import {
|
|
||||||
AiPlatformEnum,
|
|
||||||
Dall3StyleList,
|
|
||||||
StableDiffusionClipGuidancePresets,
|
|
||||||
StableDiffusionSamplers,
|
|
||||||
StableDiffusionStylePresets,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
// 图片详细信息
|
// 图片详细信息
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
|
|
|
@ -5,7 +5,7 @@ import { onMounted, onUnmounted, reactive, ref } from 'vue';
|
||||||
import { useRouter } from 'vue-router';
|
import { useRouter } from 'vue-router';
|
||||||
|
|
||||||
import { confirm, useVbenDrawer } from '@vben/common-ui';
|
import { confirm, useVbenDrawer } from '@vben/common-ui';
|
||||||
import { downloadFileFromImageUrl } from '@vben/utils';
|
import { AiImageStatusEnum, downloadFileFromImageUrl } from '@vben/utils';
|
||||||
|
|
||||||
import { useDebounceFn } from '@vueuse/core';
|
import { useDebounceFn } from '@vueuse/core';
|
||||||
import { Button, Card, message, Pagination } from 'ant-design-vue';
|
import { Button, Card, message, Pagination } from 'ant-design-vue';
|
||||||
|
@ -16,7 +16,6 @@ import {
|
||||||
getImagePageMy,
|
getImagePageMy,
|
||||||
midjourneyAction,
|
midjourneyAction,
|
||||||
} from '#/api/ai/image';
|
} from '#/api/ai/image';
|
||||||
import { AiImageStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import ImageCard from './ImageCard.vue';
|
import ImageCard from './ImageCard.vue';
|
||||||
import ImageDetail from './ImageDetail.vue';
|
import ImageDetail from './ImageDetail.vue';
|
||||||
|
|
|
@ -6,11 +6,11 @@ import type { AiModelModelApi } from '#/api/ai/model/model';
|
||||||
import { ref, watch } from 'vue';
|
import { ref, watch } from 'vue';
|
||||||
|
|
||||||
import { confirm } from '@vben/common-ui';
|
import { confirm } from '@vben/common-ui';
|
||||||
|
import { AiPlatformEnum, ImageHotWords, OtherPlatformEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, InputNumber, Select, Space, Textarea } from 'ant-design-vue';
|
import { Button, InputNumber, Select, Space, Textarea } from 'ant-design-vue';
|
||||||
|
|
||||||
import { drawImage } from '#/api/ai/image';
|
import { drawImage } from '#/api/ai/image';
|
||||||
import { AiPlatformEnum, ImageHotWords, OtherPlatformEnum } from '#/utils';
|
|
||||||
|
|
||||||
// 消息弹窗
|
// 消息弹窗
|
||||||
|
|
||||||
|
|
|
@ -1,23 +1,24 @@
|
||||||
<!-- dall3 -->
|
<!-- dall3 -->
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
|
import type { ImageModel, ImageSize } from '@vben/utils';
|
||||||
|
|
||||||
import type { AiImageApi } from '#/api/ai/image';
|
import type { AiImageApi } from '#/api/ai/image';
|
||||||
import type { AiModelModelApi } from '#/api/ai/model/model';
|
import type { AiModelModelApi } from '#/api/ai/model/model';
|
||||||
import type { ImageModel, ImageSize } from '#/utils';
|
|
||||||
|
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
|
|
||||||
import { confirm } from '@vben/common-ui';
|
import { confirm } from '@vben/common-ui';
|
||||||
|
|
||||||
import { Button, Image, message, Space, Textarea } from 'ant-design-vue';
|
|
||||||
|
|
||||||
import { drawImage } from '#/api/ai/image';
|
|
||||||
import {
|
import {
|
||||||
AiPlatformEnum,
|
AiPlatformEnum,
|
||||||
Dall3Models,
|
Dall3Models,
|
||||||
Dall3SizeList,
|
Dall3SizeList,
|
||||||
Dall3StyleList,
|
Dall3StyleList,
|
||||||
ImageHotWords,
|
ImageHotWords,
|
||||||
} from '#/utils';
|
} from '@vben/utils';
|
||||||
|
|
||||||
|
import { Button, Image, message, Space, Textarea } from 'ant-design-vue';
|
||||||
|
|
||||||
|
import { drawImage } from '#/api/ai/image';
|
||||||
|
|
||||||
// 接收父组件传入的模型列表
|
// 接收父组件传入的模型列表
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
|
|
|
@ -1,12 +1,21 @@
|
||||||
<!-- dall3 -->
|
<!-- dall3 -->
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
|
import type { ImageModel, ImageSize } from '@vben/utils';
|
||||||
|
|
||||||
import type { AiImageApi } from '#/api/ai/image';
|
import type { AiImageApi } from '#/api/ai/image';
|
||||||
import type { AiModelModelApi } from '#/api/ai/model/model';
|
import type { AiModelModelApi } from '#/api/ai/model/model';
|
||||||
import type { ImageModel, ImageSize } from '#/utils';
|
|
||||||
|
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
|
|
||||||
import { confirm } from '@vben/common-ui';
|
import { confirm } from '@vben/common-ui';
|
||||||
|
import {
|
||||||
|
AiPlatformEnum,
|
||||||
|
ImageHotWords,
|
||||||
|
MidjourneyModels,
|
||||||
|
MidjourneySizeList,
|
||||||
|
MidjourneyVersions,
|
||||||
|
NijiVersionList,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
|
@ -19,14 +28,6 @@ import {
|
||||||
|
|
||||||
import { midjourneyImagine } from '#/api/ai/image';
|
import { midjourneyImagine } from '#/api/ai/image';
|
||||||
import { ImageUpload } from '#/components/upload';
|
import { ImageUpload } from '#/components/upload';
|
||||||
import {
|
|
||||||
AiPlatformEnum,
|
|
||||||
ImageHotWords,
|
|
||||||
MidjourneyModels,
|
|
||||||
MidjourneySizeList,
|
|
||||||
MidjourneyVersions,
|
|
||||||
NijiVersionList,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
// 消息弹窗
|
// 消息弹窗
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,13 @@ import type { AiModelModelApi } from '#/api/ai/model/model';
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
|
|
||||||
import { alert, confirm } from '@vben/common-ui';
|
import { alert, confirm } from '@vben/common-ui';
|
||||||
|
import {
|
||||||
|
AiPlatformEnum,
|
||||||
|
ImageHotEnglishWords,
|
||||||
|
StableDiffusionClipGuidancePresets,
|
||||||
|
StableDiffusionSamplers,
|
||||||
|
StableDiffusionStylePresets,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
|
@ -17,13 +24,6 @@ import {
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import { drawImage } from '#/api/ai/image';
|
import { drawImage } from '#/api/ai/image';
|
||||||
import {
|
|
||||||
AiPlatformEnum,
|
|
||||||
ImageHotEnglishWords,
|
|
||||||
StableDiffusionClipGuidancePresets,
|
|
||||||
StableDiffusionSamplers,
|
|
||||||
StableDiffusionStylePresets,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
// 接收父组件传入的模型列表
|
// 接收父组件传入的模型列表
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
|
|
|
@ -5,11 +5,11 @@ import type { AiModelModelApi } from '#/api/ai/model/model';
|
||||||
import { nextTick, onMounted, ref } from 'vue';
|
import { nextTick, onMounted, ref } from 'vue';
|
||||||
|
|
||||||
import { Page } from '@vben/common-ui';
|
import { Page } from '@vben/common-ui';
|
||||||
|
import { AiModelTypeEnum, AiPlatformEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Segmented } from 'ant-design-vue';
|
import { Segmented } from 'ant-design-vue';
|
||||||
|
|
||||||
import { getModelSimpleList } from '#/api/ai/model/model';
|
import { getModelSimpleList } from '#/api/ai/model/model';
|
||||||
import { AiModelTypeEnum, AiPlatformEnum } from '#/utils';
|
|
||||||
|
|
||||||
import Common from './components/common/index.vue';
|
import Common from './components/common/index.vue';
|
||||||
import Dall3 from './components/dall3/index.vue';
|
import Dall3 from './components/dall3/index.vue';
|
||||||
|
|
|
@ -6,6 +6,7 @@ import type { SystemUserApi } from '#/api/system/user';
|
||||||
import { onMounted, ref } from 'vue';
|
import { onMounted, ref } from 'vue';
|
||||||
|
|
||||||
import { confirm, DocAlert, Page } from '@vben/common-ui';
|
import { confirm, DocAlert, Page } from '@vben/common-ui';
|
||||||
|
import { AiImageStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Image, message, Switch } from 'ant-design-vue';
|
import { Image, message, Switch } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -13,7 +14,6 @@ import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table';
|
||||||
import { deleteImage, getImagePage, updateImage } from '#/api/ai/image';
|
import { deleteImage, getImagePage, updateImage } from '#/api/ai/image';
|
||||||
import { getSimpleUserList } from '#/api/system/user';
|
import { getSimpleUserList } from '#/api/system/user';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { AiImageStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
|
|
||||||
|
|
|
@ -1,14 +1,11 @@
|
||||||
import type { VbenFormSchema } from '#/adapter/form';
|
import type { VbenFormSchema } from '#/adapter/form';
|
||||||
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
|
|
||||||
|
import { AiModelTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { z } from '#/adapter/form';
|
import { z } from '#/adapter/form';
|
||||||
import { getModelSimpleList } from '#/api/ai/model/model';
|
import { getModelSimpleList } from '#/api/ai/model/model';
|
||||||
import {
|
import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils';
|
||||||
AiModelTypeEnum,
|
|
||||||
CommonStatusEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
getDictOptions,
|
|
||||||
} from '#/utils';
|
|
||||||
/** 新增/修改的表单 */
|
/** 新增/修改的表单 */
|
||||||
export function useFormSchema(): VbenFormSchema[] {
|
export function useFormSchema(): VbenFormSchema[] {
|
||||||
return [
|
return [
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
import type { VbenFormSchema } from '#/adapter/form';
|
import type { VbenFormSchema } from '#/adapter/form';
|
||||||
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
|
|
||||||
|
import { AiModelTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { z } from '#/adapter/form';
|
import { z } from '#/adapter/form';
|
||||||
import { getModelSimpleList } from '#/api/ai/model/model';
|
import { getModelSimpleList } from '#/api/ai/model/model';
|
||||||
import {
|
import {
|
||||||
AiModelTypeEnum,
|
|
||||||
CommonStatusEnum,
|
CommonStatusEnum,
|
||||||
DICT_TYPE,
|
DICT_TYPE,
|
||||||
getDictOptions,
|
getDictOptions,
|
||||||
|
|
|
@ -8,6 +8,7 @@ import { useRoute } from 'vue-router';
|
||||||
|
|
||||||
import { useAccess } from '@vben/access';
|
import { useAccess } from '@vben/access';
|
||||||
import { confirm, Page, useVbenModal } from '@vben/common-ui';
|
import { confirm, Page, useVbenModal } from '@vben/common-ui';
|
||||||
|
import { CommonStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { message, Switch } from 'ant-design-vue';
|
import { message, Switch } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -18,7 +19,6 @@ import {
|
||||||
updateKnowledgeSegmentStatus,
|
updateKnowledgeSegmentStatus,
|
||||||
} from '#/api/ai/knowledge/segment';
|
} from '#/api/ai/knowledge/segment';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { CommonStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
import Form from './modules/form.vue';
|
import Form from './modules/form.vue';
|
||||||
|
|
|
@ -4,9 +4,9 @@ import type { AiMindmapApi } from '#/api/ai/mindmap';
|
||||||
import { nextTick, onMounted, ref } from 'vue';
|
import { nextTick, onMounted, ref } from 'vue';
|
||||||
|
|
||||||
import { alert, Page } from '@vben/common-ui';
|
import { alert, Page } from '@vben/common-ui';
|
||||||
|
import { MindMapContentExample } from '@vben/utils';
|
||||||
|
|
||||||
import { generateMindMap } from '#/api/ai/mindmap';
|
import { generateMindMap } from '#/api/ai/mindmap';
|
||||||
import { MindMapContentExample } from '#/utils';
|
|
||||||
|
|
||||||
import Left from './modules/Left.vue';
|
import Left from './modules/Left.vue';
|
||||||
import Right from './modules/Right.vue';
|
import Right from './modules/Right.vue';
|
||||||
|
|
|
@ -1,16 +1,13 @@
|
||||||
import type { VbenFormSchema } from '#/adapter/form';
|
import type { VbenFormSchema } from '#/adapter/form';
|
||||||
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
|
|
||||||
|
import { AiModelTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { z } from '#/adapter/form';
|
import { z } from '#/adapter/form';
|
||||||
import { getSimpleKnowledgeList } from '#/api/ai/knowledge/knowledge';
|
import { getSimpleKnowledgeList } from '#/api/ai/knowledge/knowledge';
|
||||||
import { getModelSimpleList } from '#/api/ai/model/model';
|
import { getModelSimpleList } from '#/api/ai/model/model';
|
||||||
import { getToolSimpleList } from '#/api/ai/model/tool';
|
import { getToolSimpleList } from '#/api/ai/model/tool';
|
||||||
import {
|
import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils';
|
||||||
AiModelTypeEnum,
|
|
||||||
CommonStatusEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
getDictOptions,
|
|
||||||
} from '#/utils';
|
|
||||||
/** 新增/修改的表单 */
|
/** 新增/修改的表单 */
|
||||||
export function useFormSchema(): VbenFormSchema[] {
|
export function useFormSchema(): VbenFormSchema[] {
|
||||||
return [
|
return [
|
||||||
|
|
|
@ -1,14 +1,11 @@
|
||||||
import type { VbenFormSchema } from '#/adapter/form';
|
import type { VbenFormSchema } from '#/adapter/form';
|
||||||
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
|
|
||||||
|
import { AiModelTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { z } from '#/adapter/form';
|
import { z } from '#/adapter/form';
|
||||||
import { getApiKeySimpleList } from '#/api/ai/model/apiKey';
|
import { getApiKeySimpleList } from '#/api/ai/model/apiKey';
|
||||||
import {
|
import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils';
|
||||||
AiModelTypeEnum,
|
|
||||||
CommonStatusEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
getDictOptions,
|
|
||||||
} from '#/utils';
|
|
||||||
/** 新增/修改的表单 */
|
/** 新增/修改的表单 */
|
||||||
export function useFormSchema(): VbenFormSchema[] {
|
export function useFormSchema(): VbenFormSchema[] {
|
||||||
return [
|
return [
|
||||||
|
|
|
@ -6,6 +6,7 @@ import type { SystemUserApi } from '#/api/system/user';
|
||||||
import { onMounted, ref } from 'vue';
|
import { onMounted, ref } from 'vue';
|
||||||
|
|
||||||
import { confirm, DocAlert, Page } from '@vben/common-ui';
|
import { confirm, DocAlert, Page } from '@vben/common-ui';
|
||||||
|
import { AiMusicStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, message, Switch } from 'ant-design-vue';
|
import { Button, message, Switch } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -13,7 +14,6 @@ import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table';
|
||||||
import { deleteMusic, getMusicPage, updateMusic } from '#/api/ai/music';
|
import { deleteMusic, getMusicPage, updateMusic } from '#/api/ai/music';
|
||||||
import { getSimpleUserList } from '#/api/system/user';
|
import { getSimpleUserList } from '#/api/system/user';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { AiMusicStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
|
|
||||||
|
|
|
@ -5,13 +5,13 @@ import { useRoute, useRouter } from 'vue-router';
|
||||||
import { confirm, Page } from '@vben/common-ui';
|
import { confirm, Page } from '@vben/common-ui';
|
||||||
import { useTabs } from '@vben/hooks';
|
import { useTabs } from '@vben/hooks';
|
||||||
import { ArrowLeft } from '@vben/icons';
|
import { ArrowLeft } from '@vben/icons';
|
||||||
|
import { AiModelTypeEnum, CommonStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, Card, message } from 'ant-design-vue';
|
import { Button, Card, message } from 'ant-design-vue';
|
||||||
|
|
||||||
import { getModelSimpleList } from '#/api/ai/model/model';
|
import { getModelSimpleList } from '#/api/ai/model/model';
|
||||||
import { createWorkflow, getWorkflow, updateWorkflow } from '#/api/ai/workflow';
|
import { createWorkflow, getWorkflow, updateWorkflow } from '#/api/ai/workflow';
|
||||||
import { createModel, deployModel, updateModel } from '#/api/bpm/model';
|
import { createModel, deployModel, updateModel } from '#/api/bpm/model';
|
||||||
import { AiModelTypeEnum, CommonStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import BasicInfo from './modules/basic-info.vue';
|
import BasicInfo from './modules/basic-info.vue';
|
||||||
import WorkflowDesign from './modules/workflow-design.vue';
|
import WorkflowDesign from './modules/workflow-design.vue';
|
||||||
|
|
|
@ -5,16 +5,12 @@ import type { AiWriteApi } from '#/api/ai/write';
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { AiWriteTypeEnum, WriteExample } from '@vben/utils';
|
||||||
|
|
||||||
import { createReusableTemplate } from '@vueuse/core';
|
import { createReusableTemplate } from '@vueuse/core';
|
||||||
import { Button, message, Textarea } from 'ant-design-vue';
|
import { Button, message, Textarea } from 'ant-design-vue';
|
||||||
|
|
||||||
import {
|
import { DICT_TYPE, getDictOptions } from '#/utils';
|
||||||
AiWriteTypeEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
getDictOptions,
|
|
||||||
WriteExample,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
import Tag from './Tag.vue';
|
import Tag from './Tag.vue';
|
||||||
|
|
||||||
|
|
|
@ -4,9 +4,9 @@ import type { AiWriteApi } from '#/api/ai/write';
|
||||||
import { nextTick, ref } from 'vue';
|
import { nextTick, ref } from 'vue';
|
||||||
|
|
||||||
import { alert, Page } from '@vben/common-ui';
|
import { alert, Page } from '@vben/common-ui';
|
||||||
|
import { WriteExample } from '@vben/utils';
|
||||||
|
|
||||||
import { writeStream } from '#/api/ai/write';
|
import { writeStream } from '#/api/ai/write';
|
||||||
import { WriteExample } from '#/utils';
|
|
||||||
|
|
||||||
import Left from './components/Left.vue';
|
import Left from './components/Left.vue';
|
||||||
import Right from './components/Right.vue';
|
import Right from './components/Right.vue';
|
||||||
|
|
|
@ -5,12 +5,12 @@ import { onMounted } from 'vue';
|
||||||
import { useRoute, useRouter } from 'vue-router';
|
import { useRoute, useRouter } from 'vue-router';
|
||||||
|
|
||||||
import { DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
import { DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
||||||
|
import { BpmModelFormType } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, Tooltip } from 'ant-design-vue';
|
import { Button, Tooltip } from 'ant-design-vue';
|
||||||
|
|
||||||
import { TableAction, useVbenVxeGrid } from '#/adapter/vxe-table';
|
import { TableAction, useVbenVxeGrid } from '#/adapter/vxe-table';
|
||||||
import { getProcessDefinitionPage } from '#/api/bpm/definition';
|
import { getProcessDefinitionPage } from '#/api/bpm/definition';
|
||||||
import { BpmModelFormType } from '#/utils';
|
|
||||||
|
|
||||||
// 导入 FormCreate 表单详情
|
// 导入 FormCreate 表单详情
|
||||||
import FormCreateDetail from '../../form/modules/detail.vue';
|
import FormCreateDetail from '../../form/modules/detail.vue';
|
||||||
|
|
|
@ -12,6 +12,11 @@ import { confirm, Page } from '@vben/common-ui';
|
||||||
import { useTabs } from '@vben/hooks';
|
import { useTabs } from '@vben/hooks';
|
||||||
import { ArrowLeft } from '@vben/icons';
|
import { ArrowLeft } from '@vben/icons';
|
||||||
import { useUserStore } from '@vben/stores';
|
import { useUserStore } from '@vben/stores';
|
||||||
|
import {
|
||||||
|
BpmAutoApproveType,
|
||||||
|
BpmModelFormType,
|
||||||
|
BpmModelType,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { Button, Card, message } from 'ant-design-vue';
|
import { Button, Card, message } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -26,7 +31,6 @@ import {
|
||||||
} from '#/api/bpm/model';
|
} from '#/api/bpm/model';
|
||||||
import { getSimpleDeptList } from '#/api/system/dept';
|
import { getSimpleDeptList } from '#/api/system/dept';
|
||||||
import { getSimpleUserList } from '#/api/system/user';
|
import { getSimpleUserList } from '#/api/system/user';
|
||||||
import { BpmAutoApproveType, BpmModelFormType, BpmModelType } from '#/utils';
|
|
||||||
|
|
||||||
import BasicInfo from './modules/basic-info.vue';
|
import BasicInfo from './modules/basic-info.vue';
|
||||||
import ExtraSetting from './modules/extra-setting.vue';
|
import ExtraSetting from './modules/extra-setting.vue';
|
||||||
|
|
|
@ -2,6 +2,11 @@
|
||||||
import { computed, provide, ref, watch } from 'vue';
|
import { computed, provide, ref, watch } from 'vue';
|
||||||
|
|
||||||
import { CircleHelp } from '@vben/icons';
|
import { CircleHelp } from '@vben/icons';
|
||||||
|
import {
|
||||||
|
BpmAutoApproveType,
|
||||||
|
BpmModelFormType,
|
||||||
|
ProcessVariableEnum,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Checkbox,
|
Checkbox,
|
||||||
|
@ -26,11 +31,6 @@ import {
|
||||||
HttpRequestSetting,
|
HttpRequestSetting,
|
||||||
parseFormFields,
|
parseFormFields,
|
||||||
} from '#/components/simple-process-design';
|
} from '#/components/simple-process-design';
|
||||||
import {
|
|
||||||
BpmAutoApproveType,
|
|
||||||
BpmModelFormType,
|
|
||||||
ProcessVariableEnum,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
const modelData = defineModel<any>();
|
const modelData = defineModel<any>();
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ import type { BpmFormApi } from '#/api/bpm/form';
|
||||||
import { ref, watch } from 'vue';
|
import { ref, watch } from 'vue';
|
||||||
|
|
||||||
import { CircleHelp } from '@vben/icons';
|
import { CircleHelp } from '@vben/icons';
|
||||||
|
import { BpmModelFormType } from '@vben/utils';
|
||||||
|
|
||||||
import FormCreate from '@form-create/ant-design-vue';
|
import FormCreate from '@form-create/ant-design-vue';
|
||||||
import {
|
import {
|
||||||
|
@ -20,12 +21,7 @@ import {
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import { getFormDetail } from '#/api/bpm/form';
|
import { getFormDetail } from '#/api/bpm/form';
|
||||||
import {
|
import { DICT_TYPE, getDictOptions, setConfAndFields2 } from '#/utils';
|
||||||
BpmModelFormType,
|
|
||||||
DICT_TYPE,
|
|
||||||
getDictOptions,
|
|
||||||
setConfAndFields2,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
formList: {
|
formList: {
|
||||||
|
|
|
@ -3,7 +3,7 @@ import type { Ref } from 'vue';
|
||||||
|
|
||||||
import { computed, inject, nextTick, ref } from 'vue';
|
import { computed, inject, nextTick, ref } from 'vue';
|
||||||
|
|
||||||
import { BpmModelType } from '#/utils';
|
import { BpmModelType } from '@vben/utils';
|
||||||
|
|
||||||
// TODO BPM 流程模型设计器 BpmModelEditor 待整合
|
// TODO BPM 流程模型设计器 BpmModelEditor 待整合
|
||||||
import SimpleModelDesign from './simple-model-design.vue';
|
import SimpleModelDesign from './simple-model-design.vue';
|
||||||
|
|
|
@ -9,7 +9,12 @@ import { useAccess } from '@vben/access';
|
||||||
import { confirm, EllipsisText, useVbenModal } from '@vben/common-ui';
|
import { confirm, EllipsisText, useVbenModal } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { useUserStore } from '@vben/stores';
|
import { useUserStore } from '@vben/stores';
|
||||||
import { cloneDeep, formatDateTime, isEqual } from '@vben/utils';
|
import {
|
||||||
|
BpmModelFormType,
|
||||||
|
cloneDeep,
|
||||||
|
formatDateTime,
|
||||||
|
isEqual,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { useDebounceFn } from '@vueuse/core';
|
import { useDebounceFn } from '@vueuse/core';
|
||||||
import { useSortable } from '@vueuse/integrations/useSortable';
|
import { useSortable } from '@vueuse/integrations/useSortable';
|
||||||
|
@ -34,7 +39,6 @@ import {
|
||||||
updateModelState,
|
updateModelState,
|
||||||
} from '#/api/bpm/model';
|
} from '#/api/bpm/model';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { BpmModelFormType } from '#/utils';
|
|
||||||
|
|
||||||
// 导入重命名表单
|
// 导入重命名表单
|
||||||
import CategoryRenameForm from '../../category/modules/rename-form.vue';
|
import CategoryRenameForm from '../../category/modules/rename-form.vue';
|
||||||
|
|
|
@ -6,6 +6,7 @@ import { computed, onMounted, ref, watch } from 'vue';
|
||||||
|
|
||||||
import { confirm, Page, useVbenForm } from '@vben/common-ui';
|
import { confirm, Page, useVbenForm } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { BpmCandidateStrategyEnum, BpmNodeIdEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, Card, message, Space } from 'ant-design-vue';
|
import { Button, Card, message, Space } from 'ant-design-vue';
|
||||||
import dayjs from 'dayjs';
|
import dayjs from 'dayjs';
|
||||||
|
@ -15,7 +16,6 @@ import { createLeave, updateLeave } from '#/api/bpm/oa/leave';
|
||||||
import { getApprovalDetail as getApprovalDetailApi } from '#/api/bpm/processInstance';
|
import { getApprovalDetail as getApprovalDetailApi } from '#/api/bpm/processInstance';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { router } from '#/router';
|
import { router } from '#/router';
|
||||||
import { BpmCandidateStrategyEnum, BpmNodeIdEnum } from '#/utils';
|
|
||||||
import ProcessInstanceTimeline from '#/views/bpm/processInstance/detail/modules/time-line.vue';
|
import ProcessInstanceTimeline from '#/views/bpm/processInstance/detail/modules/time-line.vue';
|
||||||
|
|
||||||
import { useFormSchema } from './data';
|
import { useFormSchema } from './data';
|
||||||
|
@ -171,7 +171,7 @@ function selectUserConfirm(id: string, userList: any[]) {
|
||||||
|
|
||||||
/** 审批相关:预测流程节点会因为输入的参数值而产生新的预测结果值,所以需重新预测一次, formData.value可改成实际业务中的特定字段 */
|
/** 审批相关:预测流程节点会因为输入的参数值而产生新的预测结果值,所以需重新预测一次, formData.value可改成实际业务中的特定字段 */
|
||||||
watch(
|
watch(
|
||||||
formData.value,
|
formData.value as object,
|
||||||
(newValue, oldValue) => {
|
(newValue, oldValue) => {
|
||||||
if (!oldValue) {
|
if (!oldValue) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -6,6 +6,13 @@ import { computed, nextTick, ref, watch } from 'vue';
|
||||||
|
|
||||||
import { useTabs } from '@vben/hooks';
|
import { useTabs } from '@vben/hooks';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import {
|
||||||
|
BpmCandidateStrategyEnum,
|
||||||
|
BpmFieldPermissionType,
|
||||||
|
BpmModelFormType,
|
||||||
|
BpmModelType,
|
||||||
|
BpmNodeIdEnum,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import formCreate from '@form-create/ant-design-vue';
|
import formCreate from '@form-create/ant-design-vue';
|
||||||
import { Button, Card, Col, message, Row, Space, Tabs } from 'ant-design-vue';
|
import { Button, Card, Col, message, Row, Space, Tabs } from 'ant-design-vue';
|
||||||
|
@ -16,15 +23,7 @@ import {
|
||||||
getApprovalDetail as getApprovalDetailApi,
|
getApprovalDetail as getApprovalDetailApi,
|
||||||
} from '#/api/bpm/processInstance';
|
} from '#/api/bpm/processInstance';
|
||||||
import { router } from '#/router';
|
import { router } from '#/router';
|
||||||
import {
|
import { decodeFields, setConfAndFields2 } from '#/utils';
|
||||||
BpmCandidateStrategyEnum,
|
|
||||||
BpmFieldPermissionType,
|
|
||||||
BpmModelFormType,
|
|
||||||
BpmModelType,
|
|
||||||
BpmNodeIdEnum,
|
|
||||||
decodeFields,
|
|
||||||
setConfAndFields2,
|
|
||||||
} from '#/utils';
|
|
||||||
import ProcessInstanceSimpleViewer from '#/views/bpm/processInstance/detail/modules/simple-bpm-viewer.vue';
|
import ProcessInstanceSimpleViewer from '#/views/bpm/processInstance/detail/modules/simple-bpm-viewer.vue';
|
||||||
import ProcessInstanceTimeline from '#/views/bpm/processInstance/detail/modules/time-line.vue';
|
import ProcessInstanceTimeline from '#/views/bpm/processInstance/detail/modules/time-line.vue';
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,12 @@ import type { SystemUserApi } from '#/api/system/user';
|
||||||
import { nextTick, onMounted, ref, shallowRef, watch } from 'vue';
|
import { nextTick, onMounted, ref, shallowRef, watch } from 'vue';
|
||||||
|
|
||||||
import { Page } from '@vben/common-ui';
|
import { Page } from '@vben/common-ui';
|
||||||
import { formatDateTime } from '@vben/utils';
|
import {
|
||||||
|
BpmModelFormType,
|
||||||
|
BpmModelType,
|
||||||
|
BpmTaskStatusEnum,
|
||||||
|
formatDateTime,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { Avatar, Card, Col, message, Row, TabPane, Tabs } from 'ant-design-vue';
|
import { Avatar, Card, Col, message, Row, TabPane, Tabs } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -16,14 +21,7 @@ import {
|
||||||
} from '#/api/bpm/processInstance';
|
} from '#/api/bpm/processInstance';
|
||||||
import { getSimpleUserList } from '#/api/system/user';
|
import { getSimpleUserList } from '#/api/system/user';
|
||||||
import DictTag from '#/components/dict-tag/dict-tag.vue';
|
import DictTag from '#/components/dict-tag/dict-tag.vue';
|
||||||
import {
|
import { DICT_TYPE, registerComponent, setConfAndFields2 } from '#/utils';
|
||||||
BpmModelFormType,
|
|
||||||
BpmModelType,
|
|
||||||
BpmTaskStatusEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
registerComponent,
|
|
||||||
setConfAndFields2,
|
|
||||||
} from '#/utils';
|
|
||||||
import {
|
import {
|
||||||
SvgBpmApproveIcon,
|
SvgBpmApproveIcon,
|
||||||
SvgBpmCancelIcon,
|
SvgBpmCancelIcon,
|
||||||
|
|
|
@ -10,7 +10,16 @@ import { useRouter } from 'vue-router';
|
||||||
import { useVbenModal } from '@vben/common-ui';
|
import { useVbenModal } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { useUserStore } from '@vben/stores';
|
import { useUserStore } from '@vben/stores';
|
||||||
import { isEmpty } from '@vben/utils';
|
import {
|
||||||
|
BpmCandidateStrategyEnum,
|
||||||
|
BpmModelFormType,
|
||||||
|
BpmNodeTypeEnum,
|
||||||
|
BpmProcessInstanceStatus,
|
||||||
|
BpmTaskOperationButtonTypeEnum,
|
||||||
|
BpmTaskStatusEnum,
|
||||||
|
isEmpty,
|
||||||
|
OPERATION_BUTTON_NAME,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import FormCreate from '@form-create/ant-design-vue';
|
import FormCreate from '@form-create/ant-design-vue';
|
||||||
import {
|
import {
|
||||||
|
@ -34,16 +43,7 @@ import {
|
||||||
} from '#/api/bpm/processInstance';
|
} from '#/api/bpm/processInstance';
|
||||||
import * as TaskApi from '#/api/bpm/task';
|
import * as TaskApi from '#/api/bpm/task';
|
||||||
import * as UserApi from '#/api/system/user';
|
import * as UserApi from '#/api/system/user';
|
||||||
import {
|
import { setConfAndFields2 } from '#/utils';
|
||||||
BpmCandidateStrategyEnum,
|
|
||||||
BpmModelFormType,
|
|
||||||
BpmNodeTypeEnum,
|
|
||||||
BpmProcessInstanceStatus,
|
|
||||||
BpmTaskOperationButtonTypeEnum,
|
|
||||||
BpmTaskStatusEnum,
|
|
||||||
OPERATION_BUTTON_NAME,
|
|
||||||
setConfAndFields2,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
import Signature from './signature.vue';
|
import Signature from './signature.vue';
|
||||||
import ProcessInstanceTimeline from './time-line.vue';
|
import ProcessInstanceTimeline from './time-line.vue';
|
||||||
|
|
|
@ -3,8 +3,9 @@ import type { SimpleFlowNode } from '#/components/simple-process-design';
|
||||||
|
|
||||||
import { ref, watch } from 'vue';
|
import { ref, watch } from 'vue';
|
||||||
|
|
||||||
|
import { BpmNodeTypeEnum, BpmTaskStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { SimpleProcessViewer } from '#/components/simple-process-design';
|
import { SimpleProcessViewer } from '#/components/simple-process-design';
|
||||||
import { BpmNodeTypeEnum, BpmTaskStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
defineOptions({ name: 'BpmProcessInstanceSimpleViewer' });
|
defineOptions({ name: 'BpmProcessInstanceSimpleViewer' });
|
||||||
|
|
||||||
|
|
|
@ -7,16 +7,17 @@ import { useRouter } from 'vue-router';
|
||||||
|
|
||||||
import { useVbenModal } from '@vben/common-ui';
|
import { useVbenModal } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { formatDateTime, isEmpty } from '@vben/utils';
|
|
||||||
|
|
||||||
import { Avatar, Button, Image, Timeline, Tooltip } from 'ant-design-vue';
|
|
||||||
|
|
||||||
import { UserSelectModal } from '#/components/select-modal';
|
|
||||||
import {
|
import {
|
||||||
BpmCandidateStrategyEnum,
|
BpmCandidateStrategyEnum,
|
||||||
BpmNodeTypeEnum,
|
BpmNodeTypeEnum,
|
||||||
BpmTaskStatusEnum,
|
BpmTaskStatusEnum,
|
||||||
} from '#/utils';
|
formatDateTime,
|
||||||
|
isEmpty,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
|
import { Avatar, Button, Image, Timeline, Tooltip } from 'ant-design-vue';
|
||||||
|
|
||||||
|
import { UserSelectModal } from '#/components/select-modal';
|
||||||
|
|
||||||
defineOptions({ name: 'BpmProcessInstanceTimeline' });
|
defineOptions({ name: 'BpmProcessInstanceTimeline' });
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@ import type { BpmProcessInstanceApi } from '#/api/bpm/processInstance';
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { DocAlert, Page, prompt } from '@vben/common-ui';
|
import { DocAlert, Page, prompt } from '@vben/common-ui';
|
||||||
|
import { BpmProcessInstanceStatus } from '@vben/utils';
|
||||||
|
|
||||||
import { message, Textarea } from 'ant-design-vue';
|
import { message, Textarea } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -15,7 +16,6 @@ import {
|
||||||
} from '#/api/bpm/processInstance';
|
} from '#/api/bpm/processInstance';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { router } from '#/router';
|
import { router } from '#/router';
|
||||||
import { BpmProcessInstanceStatus } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
|
|
||||||
|
|
|
@ -2,10 +2,9 @@ import type { DescriptionItemSchema } from '#/components/description';
|
||||||
|
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { formatDateTime } from '@vben/utils';
|
import { DICT_TYPE, formatDateTime } from '@vben/utils';
|
||||||
|
|
||||||
import { DictTag } from '#/components/dict-tag';
|
import { DictTag } from '#/components/dict-tag';
|
||||||
import { DICT_TYPE } from '#/utils';
|
|
||||||
|
|
||||||
/** 详情头部的配置 */
|
/** 详情头部的配置 */
|
||||||
export function useDetailSchema(): DescriptionItemSchema[] {
|
export function useDetailSchema(): DescriptionItemSchema[] {
|
||||||
|
|
|
@ -3,10 +3,9 @@ import type { DescriptionItemSchema } from '#/components/description';
|
||||||
|
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { formatDateTime } from '@vben/utils';
|
import { DICT_TYPE, formatDateTime } from '@vben/utils';
|
||||||
|
|
||||||
import { DictTag } from '#/components/dict-tag';
|
import { DictTag } from '#/components/dict-tag';
|
||||||
import { DICT_TYPE } from '#/utils';
|
|
||||||
|
|
||||||
/** 详情页的基础字段 */
|
/** 详情页的基础字段 */
|
||||||
export function useDetailSchema(): DescriptionItemSchema[] {
|
export function useDetailSchema(): DescriptionItemSchema[] {
|
||||||
|
|
|
@ -2,12 +2,11 @@ import type { VbenFormSchema } from '@vben/common-ui';
|
||||||
|
|
||||||
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
|
|
||||||
import { handleTree } from '@vben/utils';
|
import { DICT_TYPE, handleTree } from '@vben/utils';
|
||||||
|
|
||||||
import { LimitConfType } from '#/api/crm/customer/limitConfig';
|
import { LimitConfType } from '#/api/crm/customer/limitConfig';
|
||||||
import { getSimpleDeptList } from '#/api/system/dept';
|
import { getSimpleDeptList } from '#/api/system/dept';
|
||||||
import { getSimpleUserList } from '#/api/system/user';
|
import { getSimpleUserList } from '#/api/system/user';
|
||||||
import { DICT_TYPE } from '#/utils';
|
|
||||||
|
|
||||||
/** 新增/修改的表单 */
|
/** 新增/修改的表单 */
|
||||||
export function useFormSchema(confType: LimitConfType): VbenFormSchema[] {
|
export function useFormSchema(confType: LimitConfType): VbenFormSchema[] {
|
||||||
|
|
|
@ -2,10 +2,9 @@ import type { DescriptionItemSchema } from '#/components/description';
|
||||||
|
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { formatDateTime } from '@vben/utils';
|
import { DICT_TYPE, formatDateTime } from '@vben/utils';
|
||||||
|
|
||||||
import { DictTag } from '#/components/dict-tag';
|
import { DictTag } from '#/components/dict-tag';
|
||||||
import { DICT_TYPE } from '#/utils';
|
|
||||||
|
|
||||||
/** 详情页的字段 */
|
/** 详情页的字段 */
|
||||||
export function useDetailSchema(): DescriptionItemSchema[] {
|
export function useDetailSchema(): DescriptionItemSchema[] {
|
||||||
|
|
|
@ -6,6 +6,7 @@ import { watch } from 'vue';
|
||||||
import { useRouter } from 'vue-router';
|
import { useRouter } from 'vue-router';
|
||||||
|
|
||||||
import { useVbenModal } from '@vben/common-ui';
|
import { useVbenModal } from '@vben/common-ui';
|
||||||
|
import { DICT_TYPE } from '@vben/utils';
|
||||||
|
|
||||||
import { Button, message } from 'ant-design-vue';
|
import { Button, message } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -16,7 +17,6 @@ import {
|
||||||
} from '#/api/crm/followup';
|
} from '#/api/crm/followup';
|
||||||
import { BizTypeEnum } from '#/api/crm/permission';
|
import { BizTypeEnum } from '#/api/crm/permission';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { DICT_TYPE } from '#/utils';
|
|
||||||
|
|
||||||
import FollowUpRecordForm from './modules/form.vue';
|
import FollowUpRecordForm from './modules/form.vue';
|
||||||
|
|
||||||
|
|
|
@ -3,10 +3,9 @@ import type { DescriptionItemSchema } from '#/components/description';
|
||||||
|
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { erpPriceInputFormatter } from '@vben/utils';
|
import { DICT_TYPE, erpPriceInputFormatter } from '@vben/utils';
|
||||||
|
|
||||||
import { DictTag } from '#/components/dict-tag';
|
import { DictTag } from '#/components/dict-tag';
|
||||||
import { DICT_TYPE } from '#/utils';
|
|
||||||
|
|
||||||
/** 详情页的字段 */
|
/** 详情页的字段 */
|
||||||
export function useDetailSchema(): DescriptionItemSchema[] {
|
export function useDetailSchema(): DescriptionItemSchema[] {
|
||||||
|
|
|
@ -3,10 +3,9 @@ import type { DescriptionItemSchema } from '#/components/description';
|
||||||
|
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { erpPriceInputFormatter, formatDateTime } from '@vben/utils';
|
import { DICT_TYPE, erpPriceInputFormatter, formatDateTime } from '@vben/utils';
|
||||||
|
|
||||||
import { DictTag } from '#/components/dict-tag';
|
import { DictTag } from '#/components/dict-tag';
|
||||||
import { DICT_TYPE } from '#/utils';
|
|
||||||
|
|
||||||
/** 详情页的字段 */
|
/** 详情页的字段 */
|
||||||
export function useDetailSchema(): DescriptionItemSchema[] {
|
export function useDetailSchema(): DescriptionItemSchema[] {
|
||||||
|
|
|
@ -3,10 +3,9 @@ import type { DescriptionItemSchema } from '#/components/description';
|
||||||
|
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { erpPriceInputFormatter, formatDateTime } from '@vben/utils';
|
import { DICT_TYPE, erpPriceInputFormatter, formatDateTime } from '@vben/utils';
|
||||||
|
|
||||||
import { DictTag } from '#/components/dict-tag';
|
import { DictTag } from '#/components/dict-tag';
|
||||||
import { DICT_TYPE } from '#/utils';
|
|
||||||
|
|
||||||
/** 详情页的字段 */
|
/** 详情页的字段 */
|
||||||
export function useDetailSchema(): DescriptionItemSchema[] {
|
export function useDetailSchema(): DescriptionItemSchema[] {
|
||||||
|
|
|
@ -5,17 +5,12 @@ import type { DescriptionItemSchema } from '#/components/description';
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { JsonViewer } from '@vben/common-ui';
|
import { JsonViewer } from '@vben/common-ui';
|
||||||
import { formatDateTime } from '@vben/utils';
|
import { formatDateTime, InfraApiErrorLogProcessStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Textarea } from 'ant-design-vue';
|
import { Textarea } from 'ant-design-vue';
|
||||||
|
|
||||||
import { DictTag } from '#/components/dict-tag';
|
import { DictTag } from '#/components/dict-tag';
|
||||||
import {
|
import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils';
|
||||||
DICT_TYPE,
|
|
||||||
getDictOptions,
|
|
||||||
getRangePickerDefaultProps,
|
|
||||||
InfraApiErrorLogProcessStatusEnum,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
/** 列表的搜索表单 */
|
/** 列表的搜索表单 */
|
||||||
export function useGridFormSchema(): VbenFormSchema[] {
|
export function useGridFormSchema(): VbenFormSchema[] {
|
||||||
|
|
|
@ -3,7 +3,10 @@ import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
import type { InfraApiErrorLogApi } from '#/api/infra/api-error-log';
|
import type { InfraApiErrorLogApi } from '#/api/infra/api-error-log';
|
||||||
|
|
||||||
import { confirm, DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
import { confirm, DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
||||||
import { downloadFileFromBlobPart } from '@vben/utils';
|
import {
|
||||||
|
downloadFileFromBlobPart,
|
||||||
|
InfraApiErrorLogProcessStatusEnum,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { message } from 'ant-design-vue';
|
import { message } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -14,7 +17,6 @@ import {
|
||||||
updateApiErrorLogStatus,
|
updateApiErrorLogStatus,
|
||||||
} from '#/api/infra/api-error-log';
|
} from '#/api/infra/api-error-log';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { InfraApiErrorLogProcessStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
import Detail from './modules/detail.vue';
|
import Detail from './modules/detail.vue';
|
||||||
|
|
|
@ -3,11 +3,10 @@ import type { InfraCodegenApi } from '#/api/infra/codegen';
|
||||||
|
|
||||||
import { computed, ref, watch } from 'vue';
|
import { computed, ref, watch } from 'vue';
|
||||||
|
|
||||||
import { isEmpty } from '@vben/utils';
|
import { InfraCodegenTemplateTypeEnum, isEmpty } from '@vben/utils';
|
||||||
|
|
||||||
import { useVbenForm } from '#/adapter/form';
|
import { useVbenForm } from '#/adapter/form';
|
||||||
import { getCodegenTableList } from '#/api/infra/codegen';
|
import { getCodegenTableList } from '#/api/infra/codegen';
|
||||||
import { InfraCodegenTemplateTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
useGenerationInfoBaseFormSchema,
|
useGenerationInfoBaseFormSchema,
|
||||||
|
|
|
@ -6,7 +6,11 @@ import { ref } from 'vue';
|
||||||
import { useRouter } from 'vue-router';
|
import { useRouter } from 'vue-router';
|
||||||
|
|
||||||
import { confirm, DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
import { confirm, DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
||||||
import { downloadFileFromBlobPart, isEmpty } from '@vben/utils';
|
import {
|
||||||
|
downloadFileFromBlobPart,
|
||||||
|
InfraJobStatusEnum,
|
||||||
|
isEmpty,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { message } from 'ant-design-vue';
|
import { message } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -20,7 +24,6 @@ import {
|
||||||
updateJobStatus,
|
updateJobStatus,
|
||||||
} from '#/api/infra/job';
|
} from '#/api/infra/job';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { InfraJobStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
import Detail from './modules/detail.vue';
|
import Detail from './modules/detail.vue';
|
||||||
|
|
|
@ -11,6 +11,7 @@ import {
|
||||||
downloadFileFromBlobPart,
|
downloadFileFromBlobPart,
|
||||||
fenToYuan,
|
fenToYuan,
|
||||||
handleTree,
|
handleTree,
|
||||||
|
ProductSpuStatusEnum,
|
||||||
treeToString,
|
treeToString,
|
||||||
} from '@vben/utils';
|
} from '@vben/utils';
|
||||||
|
|
||||||
|
@ -26,7 +27,6 @@ import {
|
||||||
updateStatus,
|
updateStatus,
|
||||||
} from '#/api/mall/product/spu';
|
} from '#/api/mall/product/spu';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { ProductSpuStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
|
|
||||||
|
@ -278,20 +278,20 @@ onMounted(async () => {
|
||||||
:content-style="{ width: '100px', fontSize: '14px' }"
|
:content-style="{ width: '100px', fontSize: '14px' }"
|
||||||
>
|
>
|
||||||
<Descriptions.Item label="商品分类">
|
<Descriptions.Item label="商品分类">
|
||||||
{{ treeToString(categoryList, row.categoryId) }}
|
{{ treeToString(categoryList, row.categoryId as string) }}
|
||||||
</Descriptions.Item>
|
</Descriptions.Item>
|
||||||
<Descriptions.Item label="商品名称">
|
<Descriptions.Item label="商品名称">
|
||||||
{{ row.name }}
|
{{ row.name }}
|
||||||
</Descriptions.Item>
|
</Descriptions.Item>
|
||||||
|
|
||||||
<Descriptions.Item label="市场价">
|
<Descriptions.Item label="市场价">
|
||||||
{{ fenToYuan(row.marketPrice) }} 元
|
{{ fenToYuan(row.marketPrice as number) }} 元
|
||||||
</Descriptions.Item>
|
</Descriptions.Item>
|
||||||
<Descriptions.Item label="成本价">
|
<Descriptions.Item label="成本价">
|
||||||
{{ fenToYuan(row.costPrice) }} 元
|
{{ fenToYuan(row.costPrice as number) }} 元
|
||||||
</Descriptions.Item>
|
</Descriptions.Item>
|
||||||
<Descriptions.Item label="浏览量">
|
<Descriptions.Item label="浏览量">
|
||||||
{{ row.browseCount }}
|
{{ row.browseCount as number }}
|
||||||
</Descriptions.Item>
|
</Descriptions.Item>
|
||||||
<Descriptions.Item label="虚拟销量">
|
<Descriptions.Item label="虚拟销量">
|
||||||
{{ row.virtualSalesCount }}
|
{{ row.virtualSalesCount }}
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
import type { MallCouponTemplateApi } from '#/api/mall/promotion/coupon/couponTemplate';
|
import type { MallCouponTemplateApi } from '#/api/mall/promotion/coupon/couponTemplate';
|
||||||
|
|
||||||
import { floatToFixed2, formatDate } from '@vben/utils';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
CouponTemplateValidityTypeEnum,
|
CouponTemplateValidityTypeEnum,
|
||||||
|
floatToFixed2,
|
||||||
|
formatDate,
|
||||||
PromotionDiscountTypeEnum,
|
PromotionDiscountTypeEnum,
|
||||||
} from '#/utils';
|
} from '@vben/utils';
|
||||||
|
|
||||||
// 格式化【优惠金额/折扣】
|
// 格式化【优惠金额/折扣】
|
||||||
export function discountFormat(row: MallCouponTemplateApi.CouponTemplate) {
|
export function discountFormat(row: MallCouponTemplateApi.CouponTemplate) {
|
||||||
|
|
|
@ -7,12 +7,11 @@ import type { MallBrokerageUserApi } from '#/api/mall/trade/brokerage/user';
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenModal } from '@vben/common-ui';
|
import { useVbenModal } from '@vben/common-ui';
|
||||||
import { fenToYuan } from '@vben/utils';
|
import { BrokerageRecordBizTypeEnum, fenToYuan } from '@vben/utils';
|
||||||
|
|
||||||
import { useVbenVxeGrid } from '#/adapter/vxe-table';
|
import { useVbenVxeGrid } from '#/adapter/vxe-table';
|
||||||
import { getBrokerageRecordPage } from '#/api/mall/trade/brokerage/record';
|
import { getBrokerageRecordPage } from '#/api/mall/trade/brokerage/record';
|
||||||
import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils';
|
import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils';
|
||||||
import { BrokerageRecordBizTypeEnum } from '#/utils/constants';
|
|
||||||
|
|
||||||
/** 推广订单列表 */
|
/** 推广订单列表 */
|
||||||
defineOptions({ name: 'BrokerageOrderListModal' });
|
defineOptions({ name: 'BrokerageOrderListModal' });
|
||||||
|
|
|
@ -5,7 +5,12 @@ import type { MallBrokerageWithdrawApi } from '#/api/mall/trade/brokerage/withdr
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { confirm, Page, prompt } from '@vben/common-ui';
|
import { confirm, Page, prompt } from '@vben/common-ui';
|
||||||
import { formatDateTime } from '@vben/utils';
|
import {
|
||||||
|
BrokerageWithdrawStatusEnum,
|
||||||
|
BrokerageWithdrawTypeEnum,
|
||||||
|
DICT_TYPE,
|
||||||
|
formatDateTime,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { Input, message } from 'ant-design-vue';
|
import { Input, message } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -17,11 +22,6 @@ import {
|
||||||
} from '#/api/mall/trade/brokerage/withdraw';
|
} from '#/api/mall/trade/brokerage/withdraw';
|
||||||
import { DictTag } from '#/components/dict-tag';
|
import { DictTag } from '#/components/dict-tag';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import {
|
|
||||||
BrokerageWithdrawStatusEnum,
|
|
||||||
BrokerageWithdrawTypeEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
|
|
||||||
|
|
|
@ -4,12 +4,10 @@ import type { MallDeliveryPickUpStoreApi } from '#/api/mall/trade/delivery/pickU
|
||||||
|
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
|
|
||||||
|
import { DeliveryTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { getSimpleDeliveryPickUpStoreList } from '#/api/mall/trade/delivery/pickUpStore';
|
import { getSimpleDeliveryPickUpStoreList } from '#/api/mall/trade/delivery/pickUpStore';
|
||||||
import {
|
import { DICT_TYPE, getRangePickerDefaultProps } from '#/utils';
|
||||||
DeliveryTypeEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
getRangePickerDefaultProps,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
const pickUpStoreList = ref<MallDeliveryPickUpStoreApi.PickUpStore[]>([]);
|
const pickUpStoreList = ref<MallDeliveryPickUpStoreApi.PickUpStore[]>([]);
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ import type { MallOrderApi } from '#/api/mall/trade/order';
|
||||||
import { h, onMounted, ref } from 'vue';
|
import { h, onMounted, ref } from 'vue';
|
||||||
|
|
||||||
import { Page, prompt } from '@vben/common-ui';
|
import { Page, prompt } from '@vben/common-ui';
|
||||||
import { fenToYuan } from '@vben/utils';
|
import { DeliveryTypeEnum, fenToYuan, TradeOrderStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Card, Input, message } from 'ant-design-vue';
|
import { Card, Input, message } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -16,7 +16,6 @@ import {
|
||||||
getOrderSummary,
|
getOrderSummary,
|
||||||
} from '#/api/mall/trade/order';
|
} from '#/api/mall/trade/order';
|
||||||
import { SummaryCard } from '#/components/summary-card';
|
import { SummaryCard } from '#/components/summary-card';
|
||||||
import { DeliveryTypeEnum, TradeOrderStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
|
|
||||||
|
|
|
@ -4,14 +4,11 @@ import type { MallDeliveryPickUpStoreApi } from '#/api/mall/trade/delivery/pickU
|
||||||
|
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
|
|
||||||
|
import { DeliveryTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { getSimpleDeliveryExpressList } from '#/api/mall/trade/delivery/express';
|
import { getSimpleDeliveryExpressList } from '#/api/mall/trade/delivery/express';
|
||||||
import { getSimpleDeliveryPickUpStoreList } from '#/api/mall/trade/delivery/pickUpStore';
|
import { getSimpleDeliveryPickUpStoreList } from '#/api/mall/trade/delivery/pickUpStore';
|
||||||
import {
|
import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils';
|
||||||
DeliveryTypeEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
getDictOptions,
|
|
||||||
getRangePickerDefaultProps,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
const pickUpStoreList = ref<MallDeliveryPickUpStoreApi.PickUpStore[]>([]);
|
const pickUpStoreList = ref<MallDeliveryPickUpStoreApi.PickUpStore[]>([]);
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,12 @@ import { h } from 'vue';
|
||||||
import { useRouter } from 'vue-router';
|
import { useRouter } from 'vue-router';
|
||||||
|
|
||||||
import { DocAlert, Page, prompt, useVbenModal } from '@vben/common-ui';
|
import { DocAlert, Page, prompt, useVbenModal } from '@vben/common-ui';
|
||||||
import { fenToYuan } from '@vben/utils';
|
import {
|
||||||
|
DeliveryTypeEnum,
|
||||||
|
DICT_TYPE,
|
||||||
|
fenToYuan,
|
||||||
|
TradeOrderStatusEnum,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { Image, List, Tag, Textarea } from 'ant-design-vue';
|
import { Image, List, Tag, Textarea } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -14,7 +19,6 @@ import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table';
|
||||||
import { getOrderPage, updateOrderRemark } from '#/api/mall/trade/order';
|
import { getOrderPage, updateOrderRemark } from '#/api/mall/trade/order';
|
||||||
import { DictTag } from '#/components/dict-tag';
|
import { DictTag } from '#/components/dict-tag';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { DeliveryTypeEnum, DICT_TYPE, TradeOrderStatusEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
import DeleveryForm from './modules/delevery-form.vue';
|
import DeleveryForm from './modules/delevery-form.vue';
|
||||||
|
|
|
@ -3,13 +3,13 @@ import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
import type { PayAppApi } from '#/api/pay/app';
|
import type { PayAppApi } from '#/api/pay/app';
|
||||||
|
|
||||||
import { confirm, DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
import { confirm, DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
||||||
|
import { CommonStatusEnum, PayChannelEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { message } from 'ant-design-vue';
|
import { message } from 'ant-design-vue';
|
||||||
|
|
||||||
import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table';
|
import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table';
|
||||||
import { changeAppStatus, deleteApp, getAppPage } from '#/api/pay/app';
|
import { changeAppStatus, deleteApp, getAppPage } from '#/api/pay/app';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { CommonStatusEnum, PayChannelEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns, useGridFormSchema } from './data';
|
import { useGridColumns, useGridFormSchema } from './data';
|
||||||
import appFrom from './modules/app-form.vue';
|
import appFrom from './modules/app-form.vue';
|
||||||
|
|
|
@ -6,7 +6,13 @@ import { useRoute, useRouter } from 'vue-router';
|
||||||
|
|
||||||
import { Page, useVbenModal } from '@vben/common-ui';
|
import { Page, useVbenModal } from '@vben/common-ui';
|
||||||
import { useTabs } from '@vben/hooks';
|
import { useTabs } from '@vben/hooks';
|
||||||
import { fenToYuan, formatDate } from '@vben/utils';
|
import {
|
||||||
|
fenToYuan,
|
||||||
|
formatDate,
|
||||||
|
PayChannelEnum,
|
||||||
|
PayDisplayModeEnum,
|
||||||
|
PayOrderStatusEnum,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
|
@ -18,11 +24,6 @@ import {
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
import { getOrder, submitOrder } from '#/api/pay/order';
|
import { getOrder, submitOrder } from '#/api/pay/order';
|
||||||
import {
|
|
||||||
PayChannelEnum,
|
|
||||||
PayDisplayModeEnum,
|
|
||||||
PayOrderStatusEnum,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
import { channelsAlipay, channelsMock, channelsWechat } from './data';
|
import { channelsAlipay, channelsMock, channelsWechat } from './data';
|
||||||
|
|
||||||
|
|
|
@ -7,18 +7,13 @@ import type { SystemMenuApi } from '#/api/system/menu';
|
||||||
import { h } from 'vue';
|
import { h } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { handleTree, isHttpUrl } from '@vben/utils';
|
import { handleTree, isHttpUrl, SystemMenuTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { z } from '#/adapter/form';
|
import { z } from '#/adapter/form';
|
||||||
import { getMenuList } from '#/api/system/menu';
|
import { getMenuList } from '#/api/system/menu';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { componentKeys } from '#/router/routes';
|
import { componentKeys } from '#/router/routes';
|
||||||
import {
|
import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils';
|
||||||
CommonStatusEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
getDictOptions,
|
|
||||||
SystemMenuTypeEnum,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
/** 新增/修改的表单 */
|
/** 新增/修改的表单 */
|
||||||
export function useFormSchema(): VbenFormSchema[] {
|
export function useFormSchema(): VbenFormSchema[] {
|
||||||
|
|
|
@ -6,13 +6,13 @@ import { ref } from 'vue';
|
||||||
|
|
||||||
import { DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
import { DocAlert, Page, useVbenModal } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { SystemMenuTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { message } from 'ant-design-vue';
|
import { message } from 'ant-design-vue';
|
||||||
|
|
||||||
import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table';
|
import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table';
|
||||||
import { deleteMenu, getMenuList } from '#/api/system/menu';
|
import { deleteMenu, getMenuList } from '#/api/system/menu';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { SystemMenuTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useGridColumns } from './data';
|
import { useGridColumns } from './data';
|
||||||
import Form from './modules/form.vue';
|
import Form from './modules/form.vue';
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
import type { VbenFormSchema } from '#/adapter/form';
|
import type { VbenFormSchema } from '#/adapter/form';
|
||||||
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
|
|
||||||
|
import { UserTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { z } from '#/adapter/form';
|
import { z } from '#/adapter/form';
|
||||||
import { getSimpleUserList } from '#/api/system/user';
|
import { getSimpleUserList } from '#/api/system/user';
|
||||||
import {
|
import {
|
||||||
|
@ -8,9 +10,7 @@ import {
|
||||||
DICT_TYPE,
|
DICT_TYPE,
|
||||||
getDictOptions,
|
getDictOptions,
|
||||||
getRangePickerDefaultProps,
|
getRangePickerDefaultProps,
|
||||||
UserTypeEnum,
|
|
||||||
} from '#/utils';
|
} from '#/utils';
|
||||||
|
|
||||||
/** 新增/修改的表单 */
|
/** 新增/修改的表单 */
|
||||||
export function useFormSchema(): VbenFormSchema[] {
|
export function useFormSchema(): VbenFormSchema[] {
|
||||||
return [
|
return [
|
||||||
|
|
|
@ -1,13 +1,14 @@
|
||||||
import type { VbenFormSchema } from '#/adapter/form';
|
import type { VbenFormSchema } from '#/adapter/form';
|
||||||
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
|
|
||||||
|
import { SystemDataScopeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { z } from '#/adapter/form';
|
import { z } from '#/adapter/form';
|
||||||
import {
|
import {
|
||||||
CommonStatusEnum,
|
CommonStatusEnum,
|
||||||
DICT_TYPE,
|
DICT_TYPE,
|
||||||
getDictOptions,
|
getDictOptions,
|
||||||
getRangePickerDefaultProps,
|
getRangePickerDefaultProps,
|
||||||
SystemDataScopeEnum,
|
|
||||||
} from '#/utils';
|
} from '#/utils';
|
||||||
|
|
||||||
/** 新增/修改的表单 */
|
/** 新增/修改的表单 */
|
||||||
|
|
|
@ -5,7 +5,7 @@ import type { SystemRoleApi } from '#/api/system/role';
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenModal, VbenTree } from '@vben/common-ui';
|
import { useVbenModal, VbenTree } from '@vben/common-ui';
|
||||||
import { handleTree } from '@vben/utils';
|
import { handleTree, SystemDataScopeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Checkbox, message } from 'ant-design-vue';
|
import { Checkbox, message } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -14,7 +14,6 @@ import { getDeptList } from '#/api/system/dept';
|
||||||
import { assignRoleDataScope } from '#/api/system/permission';
|
import { assignRoleDataScope } from '#/api/system/permission';
|
||||||
import { getRole } from '#/api/system/role';
|
import { getRole } from '#/api/system/role';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { SystemDataScopeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useAssignDataPermissionFormSchema } from '../data';
|
import { useAssignDataPermissionFormSchema } from '../data';
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ import type { SystemRoleApi } from '#/api/system/role';
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
|
|
||||||
import { useVbenModal, VbenTree } from '@vben/common-ui';
|
import { useVbenModal, VbenTree } from '@vben/common-ui';
|
||||||
import { handleTree } from '@vben/utils';
|
import { handleTree, SystemMenuTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { Checkbox, message } from 'ant-design-vue';
|
import { Checkbox, message } from 'ant-design-vue';
|
||||||
|
|
||||||
|
@ -15,7 +15,6 @@ import { useVbenForm } from '#/adapter/form';
|
||||||
import { getMenuList } from '#/api/system/menu';
|
import { getMenuList } from '#/api/system/menu';
|
||||||
import { assignRoleMenu, getRoleMenuList } from '#/api/system/permission';
|
import { assignRoleMenu, getRoleMenuList } from '#/api/system/permission';
|
||||||
import { $t } from '#/locales';
|
import { $t } from '#/locales';
|
||||||
import { SystemMenuTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useAssignMenuFormSchema } from '../data';
|
import { useAssignMenuFormSchema } from '../data';
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,10 @@
|
||||||
import type { VbenFormSchema } from '#/adapter/form';
|
import type { VbenFormSchema } from '#/adapter/form';
|
||||||
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
||||||
|
|
||||||
|
import { SystemUserSocialTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { z } from '#/adapter/form';
|
import { z } from '#/adapter/form';
|
||||||
import {
|
import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils';
|
||||||
CommonStatusEnum,
|
|
||||||
DICT_TYPE,
|
|
||||||
getDictOptions,
|
|
||||||
SystemUserSocialTypeEnum,
|
|
||||||
} from '#/utils';
|
|
||||||
|
|
||||||
/** 新增/修改的表单 */
|
/** 新增/修改的表单 */
|
||||||
export function useFormSchema(): VbenFormSchema[] {
|
export function useFormSchema(): VbenFormSchema[] {
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
import type { PageParam, PageResult } from '@vben/request';
|
import type { PageParam, PageResult } from '@vben/request';
|
||||||
|
import type { AiWriteTypeEnum } from '@vben/utils';
|
||||||
import type { AiWriteTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { useAppConfig } from '@vben/hooks';
|
import { useAppConfig } from '@vben/hooks';
|
||||||
import { fetchEventSource } from '@vben/request';
|
import { fetchEventSource } from '@vben/request';
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
import type { PageParam, PageResult } from '@vben/request';
|
import type { PageParam, PageResult } from '@vben/request';
|
||||||
|
import type { BpmCandidateStrategyEnum, BpmNodeTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import type { BpmTaskApi } from '../task';
|
import type { BpmTaskApi } from '../task';
|
||||||
|
|
||||||
import type { BpmModelApi } from '#/api/bpm/model';
|
import type { BpmModelApi } from '#/api/bpm/model';
|
||||||
import type { BpmCandidateStrategyEnum, BpmNodeTypeEnum } from '#/utils';
|
|
||||||
|
|
||||||
import { requestClient } from '#/api/request';
|
import { requestClient } from '#/api/request';
|
||||||
|
|
||||||
|
|
|
@ -2,9 +2,7 @@ import type { MallCouponTemplateApi } from '#/api/mall/promotion/coupon/couponTe
|
||||||
|
|
||||||
import { defineComponent } from 'vue';
|
import { defineComponent } from 'vue';
|
||||||
|
|
||||||
import { floatToFixed2 } from '@vben/utils';
|
import { floatToFixed2, PromotionDiscountTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { PromotionDiscountTypeEnum } from '#/utils/constants';
|
|
||||||
|
|
||||||
// 优惠描述
|
// 优惠描述
|
||||||
export const CouponDiscountDesc = defineComponent({
|
export const CouponDiscountDesc = defineComponent({
|
||||||
|
|
|
@ -2,9 +2,7 @@ import type { MallCouponTemplateApi } from '#/api/mall/promotion/coupon/couponTe
|
||||||
|
|
||||||
import { defineComponent } from 'vue';
|
import { defineComponent } from 'vue';
|
||||||
|
|
||||||
import { floatToFixed2 } from '@vben/utils';
|
import { floatToFixed2, PromotionDiscountTypeEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { PromotionDiscountTypeEnum } from '#/utils/constants';
|
|
||||||
|
|
||||||
// 优惠值
|
// 优惠值
|
||||||
export const CouponDiscount = defineComponent({
|
export const CouponDiscount = defineComponent({
|
||||||
|
|
|
@ -2,9 +2,7 @@ import type { MallCouponTemplateApi } from '#/api/mall/promotion/coupon/couponTe
|
||||||
|
|
||||||
import { defineComponent } from 'vue';
|
import { defineComponent } from 'vue';
|
||||||
|
|
||||||
import { formatDate } from '@vben/utils';
|
import { CouponTemplateValidityTypeEnum, formatDate } from '@vben/utils';
|
||||||
|
|
||||||
import { CouponTemplateValidityTypeEnum } from '#/utils/constants';
|
|
||||||
|
|
||||||
// 有效期
|
// 有效期
|
||||||
export const CouponValidTerm = defineComponent({
|
export const CouponValidTerm = defineComponent({
|
||||||
|
|
|
@ -6,7 +6,11 @@ import type { MallCouponTemplateApi } from '#/api/mall/promotion/coupon/couponTe
|
||||||
import { ref, watch } from 'vue';
|
import { ref, watch } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { floatToFixed2 } from '@vben/utils';
|
import {
|
||||||
|
CouponTemplateTakeTypeEnum,
|
||||||
|
floatToFixed2,
|
||||||
|
PromotionDiscountTypeEnum,
|
||||||
|
} from '@vben/utils';
|
||||||
|
|
||||||
import { useVModel } from '@vueuse/core';
|
import { useVModel } from '@vueuse/core';
|
||||||
import {
|
import {
|
||||||
|
@ -23,10 +27,6 @@ import * as CouponTemplateApi from '#/api/mall/promotion/coupon/couponTemplate';
|
||||||
import ColorInput from '#/components/color-input/index.vue';
|
import ColorInput from '#/components/color-input/index.vue';
|
||||||
import ComponentContainerProperty from '#/components/diy-editor/components/component-container-property.vue';
|
import ComponentContainerProperty from '#/components/diy-editor/components/component-container-property.vue';
|
||||||
import UploadImg from '#/components/upload/image-upload.vue';
|
import UploadImg from '#/components/upload/image-upload.vue';
|
||||||
import {
|
|
||||||
CouponTemplateTakeTypeEnum,
|
|
||||||
PromotionDiscountTypeEnum,
|
|
||||||
} from '#/utils/constants';
|
|
||||||
import CouponSelect from '#/views/mall/promotion/coupon/components/coupon-select.vue';
|
import CouponSelect from '#/views/mall/promotion/coupon/components/coupon-select.vue';
|
||||||
|
|
||||||
// 优惠券卡片属性面板
|
// 优惠券卡片属性面板
|
||||||
|
|
|
@ -6,6 +6,7 @@ import type { MallCombinationActivityApi } from '#/api/mall/promotion/combinatio
|
||||||
import { onMounted, ref } from 'vue';
|
import { onMounted, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { CommonStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { useVModel } from '@vueuse/core';
|
import { useVModel } from '@vueuse/core';
|
||||||
import {
|
import {
|
||||||
|
@ -21,7 +22,6 @@ import {
|
||||||
import * as CombinationActivityApi from '#/api/mall/promotion/combination/combinationActivity';
|
import * as CombinationActivityApi from '#/api/mall/promotion/combination/combinationActivity';
|
||||||
import ColorInput from '#/components/color-input/index.vue';
|
import ColorInput from '#/components/color-input/index.vue';
|
||||||
import UploadImg from '#/components/upload/image-upload.vue';
|
import UploadImg from '#/components/upload/image-upload.vue';
|
||||||
import { CommonStatusEnum } from '#/utils';
|
|
||||||
import CombinationShowcase from '#/views/mall/promotion/combination/components/combination-showcase.vue';
|
import CombinationShowcase from '#/views/mall/promotion/combination/components/combination-showcase.vue';
|
||||||
|
|
||||||
// 拼团属性面板
|
// 拼团属性面板
|
||||||
|
|
|
@ -6,6 +6,7 @@ import type { MallSeckillActivityApi } from '#/api/mall/promotion/seckill/seckil
|
||||||
import { onMounted, ref } from 'vue';
|
import { onMounted, ref } from 'vue';
|
||||||
|
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
|
import { CommonStatusEnum } from '@vben/utils';
|
||||||
|
|
||||||
import { useVModel } from '@vueuse/core';
|
import { useVModel } from '@vueuse/core';
|
||||||
import {
|
import {
|
||||||
|
@ -23,7 +24,6 @@ import {
|
||||||
import * as SeckillActivityApi from '#/api/mall/promotion/seckill/seckillActivity';
|
import * as SeckillActivityApi from '#/api/mall/promotion/seckill/seckillActivity';
|
||||||
import ColorInput from '#/components/color-input/index.vue';
|
import ColorInput from '#/components/color-input/index.vue';
|
||||||
import UploadImg from '#/components/upload/image-upload.vue';
|
import UploadImg from '#/components/upload/image-upload.vue';
|
||||||
import { CommonStatusEnum } from '#/utils/constants';
|
|
||||||
import SeckillShowcase from '#/views/mall/promotion/seckill/components/seckill-showcase.vue';
|
import SeckillShowcase from '#/views/mall/promotion/seckill/components/seckill-showcase.vue';
|
||||||
|
|
||||||
// 秒杀属性面板
|
// 秒杀属性面板
|
||||||
|
|
|
@ -1,667 +0,0 @@
|
||||||
// todo @芋艿:要不要共享
|
|
||||||
/**
|
|
||||||
* Created by 芋道源码
|
|
||||||
*
|
|
||||||
* 枚举类
|
|
||||||
*/
|
|
||||||
|
|
||||||
// ========== COMMON 模块 ==========
|
|
||||||
// 全局通用状态枚举
|
|
||||||
export const CommonStatusEnum = {
|
|
||||||
ENABLE: 0, // 开启
|
|
||||||
DISABLE: 1, // 禁用
|
|
||||||
};
|
|
||||||
|
|
||||||
// 全局用户类型枚举
|
|
||||||
export const UserTypeEnum = {
|
|
||||||
MEMBER: 1, // 会员
|
|
||||||
ADMIN: 2, // 管理员
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========== SYSTEM 模块 ==========
|
|
||||||
/**
|
|
||||||
* 菜单的类型枚举
|
|
||||||
*/
|
|
||||||
export const SystemMenuTypeEnum = {
|
|
||||||
DIR: 1, // 目录
|
|
||||||
MENU: 2, // 菜单
|
|
||||||
BUTTON: 3, // 按钮
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 角色的类型枚举
|
|
||||||
*/
|
|
||||||
export const SystemRoleTypeEnum = {
|
|
||||||
SYSTEM: 1, // 内置角色
|
|
||||||
CUSTOM: 2, // 自定义角色
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 数据权限的范围枚举
|
|
||||||
*/
|
|
||||||
export const SystemDataScopeEnum = {
|
|
||||||
ALL: 1, // 全部数据权限
|
|
||||||
DEPT_CUSTOM: 2, // 指定部门数据权限
|
|
||||||
DEPT_ONLY: 3, // 部门数据权限
|
|
||||||
DEPT_AND_CHILD: 4, // 部门及以下数据权限
|
|
||||||
DEPT_SELF: 5, // 仅本人数据权限
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 用户的社交平台的类型枚举
|
|
||||||
*/
|
|
||||||
export const SystemUserSocialTypeEnum = {
|
|
||||||
DINGTALK: {
|
|
||||||
title: '钉钉',
|
|
||||||
type: 20,
|
|
||||||
source: 'dingtalk',
|
|
||||||
img: 'https://s1.ax1x.com/2022/05/22/OzMDRs.png',
|
|
||||||
},
|
|
||||||
WECHAT_ENTERPRISE: {
|
|
||||||
title: '企业微信',
|
|
||||||
type: 30,
|
|
||||||
source: 'wechat_enterprise',
|
|
||||||
img: 'https://s1.ax1x.com/2022/05/22/OzMrzn.png',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========== INFRA 模块 ==========
|
|
||||||
/**
|
|
||||||
* 代码生成模板类型
|
|
||||||
*/
|
|
||||||
export const InfraCodegenTemplateTypeEnum = {
|
|
||||||
CRUD: 1, // 基础 CRUD
|
|
||||||
TREE: 2, // 树形 CRUD
|
|
||||||
SUB: 15, // 主子表 CRUD
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 任务状态的枚举
|
|
||||||
*/
|
|
||||||
export const InfraJobStatusEnum = {
|
|
||||||
INIT: 0, // 初始化中
|
|
||||||
NORMAL: 1, // 运行中
|
|
||||||
STOP: 2, // 暂停运行
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* API 异常数据的处理状态
|
|
||||||
*/
|
|
||||||
export const InfraApiErrorLogProcessStatusEnum = {
|
|
||||||
INIT: 0, // 未处理
|
|
||||||
DONE: 1, // 已处理
|
|
||||||
IGNORE: 2, // 已忽略
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========== PAY 模块 ==========
|
|
||||||
/**
|
|
||||||
* 支付渠道枚举
|
|
||||||
*/
|
|
||||||
export const PayChannelEnum = {
|
|
||||||
WX_PUB: {
|
|
||||||
code: 'wx_pub',
|
|
||||||
name: '微信 JSAPI 支付',
|
|
||||||
},
|
|
||||||
WX_LITE: {
|
|
||||||
code: 'wx_lite',
|
|
||||||
name: '微信小程序支付',
|
|
||||||
},
|
|
||||||
WX_APP: {
|
|
||||||
code: 'wx_app',
|
|
||||||
name: '微信 APP 支付',
|
|
||||||
},
|
|
||||||
WX_NATIVE: {
|
|
||||||
code: 'wx_native',
|
|
||||||
name: '微信 Native 支付',
|
|
||||||
},
|
|
||||||
WX_WAP: {
|
|
||||||
code: 'wx_wap',
|
|
||||||
name: '微信 WAP 网站支付',
|
|
||||||
},
|
|
||||||
WX_BAR: {
|
|
||||||
code: 'wx_bar',
|
|
||||||
name: '微信条码支付',
|
|
||||||
},
|
|
||||||
ALIPAY_PC: {
|
|
||||||
code: 'alipay_pc',
|
|
||||||
name: '支付宝 PC 网站支付',
|
|
||||||
},
|
|
||||||
ALIPAY_WAP: {
|
|
||||||
code: 'alipay_wap',
|
|
||||||
name: '支付宝 WAP 网站支付',
|
|
||||||
},
|
|
||||||
ALIPAY_APP: {
|
|
||||||
code: 'alipay_app',
|
|
||||||
name: '支付宝 APP 支付',
|
|
||||||
},
|
|
||||||
ALIPAY_QR: {
|
|
||||||
code: 'alipay_qr',
|
|
||||||
name: '支付宝扫码支付',
|
|
||||||
},
|
|
||||||
ALIPAY_BAR: {
|
|
||||||
code: 'alipay_bar',
|
|
||||||
name: '支付宝条码支付',
|
|
||||||
},
|
|
||||||
WALLET: {
|
|
||||||
code: 'wallet',
|
|
||||||
name: '钱包支付',
|
|
||||||
},
|
|
||||||
MOCK: {
|
|
||||||
code: 'mock',
|
|
||||||
name: '模拟支付',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 支付的展示模式每局
|
|
||||||
*/
|
|
||||||
export const PayDisplayModeEnum = {
|
|
||||||
URL: {
|
|
||||||
mode: 'url',
|
|
||||||
},
|
|
||||||
IFRAME: {
|
|
||||||
mode: 'iframe',
|
|
||||||
},
|
|
||||||
FORM: {
|
|
||||||
mode: 'form',
|
|
||||||
},
|
|
||||||
QR_CODE: {
|
|
||||||
mode: 'qr_code',
|
|
||||||
},
|
|
||||||
APP: {
|
|
||||||
mode: 'app',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 支付类型枚举
|
|
||||||
*/
|
|
||||||
export const PayType = {
|
|
||||||
WECHAT: 'WECHAT',
|
|
||||||
ALIPAY: 'ALIPAY',
|
|
||||||
MOCK: 'MOCK',
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 支付订单状态枚举
|
|
||||||
*/
|
|
||||||
export const PayOrderStatusEnum = {
|
|
||||||
WAITING: {
|
|
||||||
status: 0,
|
|
||||||
name: '未支付',
|
|
||||||
},
|
|
||||||
SUCCESS: {
|
|
||||||
status: 10,
|
|
||||||
name: '已支付',
|
|
||||||
},
|
|
||||||
CLOSED: {
|
|
||||||
status: 20,
|
|
||||||
name: '未支付',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========== MALL - 商品模块 ==========
|
|
||||||
/**
|
|
||||||
* 商品 首页 日期类型
|
|
||||||
*/
|
|
||||||
export enum TimeRangeTypeEnum {
|
|
||||||
DAY30 = 1,
|
|
||||||
MONTH = 30,
|
|
||||||
WEEK = 7,
|
|
||||||
YEAR = 365,
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 商品 SPU 状态
|
|
||||||
*/
|
|
||||||
export const ProductSpuStatusEnum = {
|
|
||||||
RECYCLE: {
|
|
||||||
status: -1,
|
|
||||||
name: '回收站',
|
|
||||||
},
|
|
||||||
DISABLE: {
|
|
||||||
status: 0,
|
|
||||||
name: '下架',
|
|
||||||
},
|
|
||||||
ENABLE: {
|
|
||||||
status: 1,
|
|
||||||
name: '上架',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========== MALL - 营销模块 ==========
|
|
||||||
/**
|
|
||||||
* 优惠劵模板的有限期类型的枚举
|
|
||||||
*/
|
|
||||||
export const CouponTemplateValidityTypeEnum = {
|
|
||||||
DATE: {
|
|
||||||
type: 1,
|
|
||||||
name: '固定日期可用',
|
|
||||||
},
|
|
||||||
TERM: {
|
|
||||||
type: 2,
|
|
||||||
name: '领取之后可用',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 优惠劵模板的领取方式的枚举
|
|
||||||
*/
|
|
||||||
export const CouponTemplateTakeTypeEnum = {
|
|
||||||
USER: {
|
|
||||||
type: 1,
|
|
||||||
name: '直接领取',
|
|
||||||
},
|
|
||||||
ADMIN: {
|
|
||||||
type: 2,
|
|
||||||
name: '指定发放',
|
|
||||||
},
|
|
||||||
REGISTER: {
|
|
||||||
type: 3,
|
|
||||||
name: '新人券',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 营销的商品范围枚举
|
|
||||||
*/
|
|
||||||
export const PromotionProductScopeEnum = {
|
|
||||||
ALL: {
|
|
||||||
scope: 1,
|
|
||||||
name: '通用劵',
|
|
||||||
},
|
|
||||||
SPU: {
|
|
||||||
scope: 2,
|
|
||||||
name: '商品劵',
|
|
||||||
},
|
|
||||||
CATEGORY: {
|
|
||||||
scope: 3,
|
|
||||||
name: '品类劵',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 营销的条件类型枚举
|
|
||||||
*/
|
|
||||||
export const PromotionConditionTypeEnum = {
|
|
||||||
PRICE: {
|
|
||||||
type: 10,
|
|
||||||
name: '满 N 元',
|
|
||||||
},
|
|
||||||
COUNT: {
|
|
||||||
type: 20,
|
|
||||||
name: '满 N 件',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 优惠类型枚举
|
|
||||||
*/
|
|
||||||
export const PromotionDiscountTypeEnum = {
|
|
||||||
PRICE: {
|
|
||||||
type: 1,
|
|
||||||
name: '满减',
|
|
||||||
},
|
|
||||||
PERCENT: {
|
|
||||||
type: 2,
|
|
||||||
name: '折扣',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========== MALL - 交易模块 ==========
|
|
||||||
/**
|
|
||||||
* 分销关系绑定模式枚举
|
|
||||||
*/
|
|
||||||
export const BrokerageBindModeEnum = {
|
|
||||||
ANYTIME: {
|
|
||||||
mode: 1,
|
|
||||||
name: '首次绑定',
|
|
||||||
},
|
|
||||||
REGISTER: {
|
|
||||||
mode: 2,
|
|
||||||
name: '注册绑定',
|
|
||||||
},
|
|
||||||
OVERRIDE: {
|
|
||||||
mode: 3,
|
|
||||||
name: '覆盖绑定',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* 分佣模式枚举
|
|
||||||
*/
|
|
||||||
export const BrokerageEnabledConditionEnum = {
|
|
||||||
ALL: {
|
|
||||||
condition: 1,
|
|
||||||
name: '人人分销',
|
|
||||||
},
|
|
||||||
ADMIN: {
|
|
||||||
condition: 2,
|
|
||||||
name: '指定分销',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* 佣金记录业务类型枚举
|
|
||||||
*/
|
|
||||||
export const BrokerageRecordBizTypeEnum = {
|
|
||||||
ORDER: {
|
|
||||||
type: 1,
|
|
||||||
name: '获得推广佣金',
|
|
||||||
},
|
|
||||||
WITHDRAW: {
|
|
||||||
type: 2,
|
|
||||||
name: '提现申请',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* 佣金提现状态枚举
|
|
||||||
*/
|
|
||||||
export const BrokerageWithdrawStatusEnum = {
|
|
||||||
AUDITING: {
|
|
||||||
status: 0,
|
|
||||||
name: '审核中',
|
|
||||||
},
|
|
||||||
AUDIT_SUCCESS: {
|
|
||||||
status: 10,
|
|
||||||
name: '审核通过',
|
|
||||||
},
|
|
||||||
AUDIT_FAIL: {
|
|
||||||
status: 20,
|
|
||||||
name: '审核不通过',
|
|
||||||
},
|
|
||||||
WITHDRAW_SUCCESS: {
|
|
||||||
status: 11,
|
|
||||||
name: '提现成功',
|
|
||||||
},
|
|
||||||
WITHDRAW_FAIL: {
|
|
||||||
status: 21,
|
|
||||||
name: '提现失败',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* 佣金提现类型枚举
|
|
||||||
*/
|
|
||||||
export const BrokerageWithdrawTypeEnum = {
|
|
||||||
WALLET: {
|
|
||||||
type: 1,
|
|
||||||
name: '钱包',
|
|
||||||
},
|
|
||||||
BANK: {
|
|
||||||
type: 2,
|
|
||||||
name: '银行卡',
|
|
||||||
},
|
|
||||||
WECHAT: {
|
|
||||||
type: 3,
|
|
||||||
name: '微信',
|
|
||||||
},
|
|
||||||
ALIPAY: {
|
|
||||||
type: 4,
|
|
||||||
name: '支付宝',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 配送方式枚举
|
|
||||||
*/
|
|
||||||
export const DeliveryTypeEnum = {
|
|
||||||
EXPRESS: {
|
|
||||||
type: 1,
|
|
||||||
name: '快递发货',
|
|
||||||
},
|
|
||||||
PICK_UP: {
|
|
||||||
type: 2,
|
|
||||||
name: '到店自提',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* 交易订单 - 状态
|
|
||||||
*/
|
|
||||||
export const TradeOrderStatusEnum = {
|
|
||||||
UNPAID: {
|
|
||||||
status: 0,
|
|
||||||
name: '待支付',
|
|
||||||
},
|
|
||||||
UNDELIVERED: {
|
|
||||||
status: 10,
|
|
||||||
name: '待发货',
|
|
||||||
},
|
|
||||||
DELIVERED: {
|
|
||||||
status: 20,
|
|
||||||
name: '已发货',
|
|
||||||
},
|
|
||||||
COMPLETED: {
|
|
||||||
status: 30,
|
|
||||||
name: '已完成',
|
|
||||||
},
|
|
||||||
CANCELED: {
|
|
||||||
status: 40,
|
|
||||||
name: '已取消',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========== ERP - 企业资源计划 ==========
|
|
||||||
|
|
||||||
export const ErpBizType = {
|
|
||||||
PURCHASE_ORDER: 10,
|
|
||||||
PURCHASE_IN: 11,
|
|
||||||
PURCHASE_RETURN: 12,
|
|
||||||
SALE_ORDER: 20,
|
|
||||||
SALE_OUT: 21,
|
|
||||||
SALE_RETURN: 22,
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========== BPM 模块 ==========
|
|
||||||
|
|
||||||
export const BpmModelType = {
|
|
||||||
BPMN: 10, // BPMN 设计器
|
|
||||||
SIMPLE: 20, // 简易设计器
|
|
||||||
};
|
|
||||||
|
|
||||||
export const BpmModelFormType = {
|
|
||||||
NORMAL: 10, // 流程表单
|
|
||||||
CUSTOM: 20, // 业务表单
|
|
||||||
};
|
|
||||||
|
|
||||||
export const BpmProcessInstanceStatus = {
|
|
||||||
NOT_START: -1, // 未开始
|
|
||||||
RUNNING: 1, // 审批中
|
|
||||||
APPROVE: 2, // 审批通过
|
|
||||||
REJECT: 3, // 审批不通过
|
|
||||||
CANCEL: 4, // 已取消
|
|
||||||
};
|
|
||||||
|
|
||||||
export const BpmAutoApproveType = {
|
|
||||||
NONE: 0, // 不自动通过
|
|
||||||
APPROVE_ALL: 1, // 仅审批一次,后续重复的审批节点均自动通过
|
|
||||||
APPROVE_SEQUENT: 2, // 仅针对连续审批的节点自动通过
|
|
||||||
};
|
|
||||||
|
|
||||||
// 候选人策略枚举 ( 用于审批节点。抄送节点 )
|
|
||||||
export enum CandidateStrategyEnum {
|
|
||||||
/**
|
|
||||||
* 审批人自选
|
|
||||||
*/
|
|
||||||
APPROVE_USER_SELECT = 34,
|
|
||||||
/**
|
|
||||||
* 部门的负责人
|
|
||||||
*/
|
|
||||||
DEPT_LEADER = 21,
|
|
||||||
/**
|
|
||||||
* 部门成员
|
|
||||||
*/
|
|
||||||
DEPT_MEMBER = 20,
|
|
||||||
/**
|
|
||||||
* 流程表达式
|
|
||||||
*/
|
|
||||||
EXPRESSION = 60,
|
|
||||||
/**
|
|
||||||
* 表单内部门负责人
|
|
||||||
*/
|
|
||||||
FORM_DEPT_LEADER = 51,
|
|
||||||
/**
|
|
||||||
* 表单内用户字段
|
|
||||||
*/
|
|
||||||
FORM_USER = 50,
|
|
||||||
/**
|
|
||||||
* 连续多级部门的负责人
|
|
||||||
*/
|
|
||||||
MULTI_LEVEL_DEPT_LEADER = 23,
|
|
||||||
/**
|
|
||||||
* 指定岗位
|
|
||||||
*/
|
|
||||||
POST = 22,
|
|
||||||
/**
|
|
||||||
* 指定角色
|
|
||||||
*/
|
|
||||||
ROLE = 10,
|
|
||||||
/**
|
|
||||||
* 发起人自己
|
|
||||||
*/
|
|
||||||
START_USER = 36,
|
|
||||||
/**
|
|
||||||
* 发起人部门负责人
|
|
||||||
*/
|
|
||||||
START_USER_DEPT_LEADER = 37,
|
|
||||||
/**
|
|
||||||
* 发起人连续多级部门的负责人
|
|
||||||
*/
|
|
||||||
START_USER_MULTI_LEVEL_DEPT_LEADER = 38,
|
|
||||||
/**
|
|
||||||
* 发起人自选
|
|
||||||
*/
|
|
||||||
START_USER_SELECT = 35,
|
|
||||||
/**
|
|
||||||
* 指定用户
|
|
||||||
*/
|
|
||||||
USER = 30,
|
|
||||||
/**
|
|
||||||
* 指定用户组
|
|
||||||
*/
|
|
||||||
USER_GROUP = 40,
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 节点类型
|
|
||||||
*/
|
|
||||||
export enum NodeTypeEnum {
|
|
||||||
/**
|
|
||||||
* 子流程节点
|
|
||||||
*/
|
|
||||||
CHILD_PROCESS_NODE = 20,
|
|
||||||
/**
|
|
||||||
* 条件分支节点 (对应排他网关)
|
|
||||||
*/
|
|
||||||
CONDITION_BRANCH_NODE = 51,
|
|
||||||
/**
|
|
||||||
* 条件节点
|
|
||||||
*/
|
|
||||||
CONDITION_NODE = 50,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 抄送人节点
|
|
||||||
*/
|
|
||||||
COPY_TASK_NODE = 12,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 延迟器节点
|
|
||||||
*/
|
|
||||||
DELAY_TIMER_NODE = 14,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 结束节点
|
|
||||||
*/
|
|
||||||
END_EVENT_NODE = 1,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 包容分支节点 (对应包容网关)
|
|
||||||
*/
|
|
||||||
INCLUSIVE_BRANCH_NODE = 53,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 并行分支节点 (对应并行网关)
|
|
||||||
*/
|
|
||||||
PARALLEL_BRANCH_NODE = 52,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 路由分支节点
|
|
||||||
*/
|
|
||||||
ROUTER_BRANCH_NODE = 54,
|
|
||||||
/**
|
|
||||||
* 发起人节点
|
|
||||||
*/
|
|
||||||
START_USER_NODE = 10,
|
|
||||||
/**
|
|
||||||
* 办理人节点
|
|
||||||
*/
|
|
||||||
TRANSACTOR_NODE = 13,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 触发器节点
|
|
||||||
*/
|
|
||||||
TRIGGER_NODE = 15,
|
|
||||||
/**
|
|
||||||
* 审批人节点
|
|
||||||
*/
|
|
||||||
USER_TASK_NODE = 11,
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 任务状态枚举
|
|
||||||
*/
|
|
||||||
export enum TaskStatusEnum {
|
|
||||||
/**
|
|
||||||
* 审批通过
|
|
||||||
*/
|
|
||||||
APPROVE = 2,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 审批通过中
|
|
||||||
*/
|
|
||||||
APPROVING = 7,
|
|
||||||
/**
|
|
||||||
* 已取消
|
|
||||||
*/
|
|
||||||
CANCEL = 4,
|
|
||||||
/**
|
|
||||||
* 未开始
|
|
||||||
*/
|
|
||||||
NOT_START = -1,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 审批不通过
|
|
||||||
*/
|
|
||||||
REJECT = 3,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 已退回
|
|
||||||
*/
|
|
||||||
RETURN = 5,
|
|
||||||
/**
|
|
||||||
* 审批中
|
|
||||||
*/
|
|
||||||
RUNNING = 1,
|
|
||||||
/**
|
|
||||||
* 待审批
|
|
||||||
*/
|
|
||||||
WAIT = 0,
|
|
||||||
}
|
|
||||||
|
|
||||||
// 预设颜色
|
|
||||||
export const PREDEFINE_COLORS = [
|
|
||||||
'#ff4500',
|
|
||||||
'#ff8c00',
|
|
||||||
'#ffd700',
|
|
||||||
'#90ee90',
|
|
||||||
'#00ced1',
|
|
||||||
'#1e90ff',
|
|
||||||
'#c71585',
|
|
||||||
'#409EFF',
|
|
||||||
'#909399',
|
|
||||||
'#C0C4CC',
|
|
||||||
'#b7390b',
|
|
||||||
'#ff7800',
|
|
||||||
'#fad400',
|
|
||||||
'#5b8c5f',
|
|
||||||
'#00babd',
|
|
||||||
'#1f73c3',
|
|
||||||
'#711f57',
|
|
||||||
];
|
|
|
@ -1,8 +1,7 @@
|
||||||
import type { DefaultOptionType } from 'ant-design-vue/es/select';
|
|
||||||
// TODO @芋艿:后续再优化
|
// TODO @芋艿:后续再优化
|
||||||
// TODO @芋艿:可以共享么?
|
// TODO @芋艿:可以共享么?
|
||||||
|
|
||||||
import { isObject } from '@vben/utils';
|
import { DICT_TYPE, isObject } from '@vben/utils';
|
||||||
|
|
||||||
import { useDictStore } from '#/store';
|
import { useDictStore } from '#/store';
|
||||||
|
|
||||||
|
@ -68,7 +67,7 @@ function getDictOptions(
|
||||||
): DictDataType[] {
|
): DictDataType[] {
|
||||||
const dictStore = useDictStore();
|
const dictStore = useDictStore();
|
||||||
const dictOpts = dictStore.getDictOptions(dictType);
|
const dictOpts = dictStore.getDictOptions(dictType);
|
||||||
const dictOptions: DefaultOptionType = [];
|
const dictOptions: DictDataType[] = [];
|
||||||
if (dictOpts.length > 0) {
|
if (dictOpts.length > 0) {
|
||||||
let dictValue: boolean | number | string = '';
|
let dictValue: boolean | number | string = '';
|
||||||
dictOpts.forEach((d) => {
|
dictOpts.forEach((d) => {
|
||||||
|
@ -141,138 +140,4 @@ export const getBoolDictOptions = (dictType: string) => {
|
||||||
return dictOption;
|
return dictOption;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum DICT_TYPE {
|
|
||||||
AI_GENERATE_MODE = 'ai_generate_mode', // AI 生成模式
|
|
||||||
AI_IMAGE_STATUS = 'ai_image_status', // AI 图片状态
|
|
||||||
AI_MUSIC_STATUS = 'ai_music_status', // AI 音乐状态
|
|
||||||
// ========== AI - 人工智能模块 ==========
|
|
||||||
AI_PLATFORM = 'ai_platform', // AI 平台
|
|
||||||
|
|
||||||
AI_WRITE_FORMAT = 'ai_write_format', // AI 写作格式
|
|
||||||
AI_WRITE_LANGUAGE = 'ai_write_language', // AI 写作语言
|
|
||||||
AI_WRITE_LENGTH = 'ai_write_length', // AI 写作长度
|
|
||||||
AI_WRITE_TONE = 'ai_write_tone', // AI 写作语气
|
|
||||||
AI_WRITE_TYPE = 'ai_write_type', // AI 写作类型
|
|
||||||
BPM_MODEL_FORM_TYPE = 'bpm_model_form_type',
|
|
||||||
// ========== BPM 模块 ==========
|
|
||||||
BPM_MODEL_TYPE = 'bpm_model_type',
|
|
||||||
BPM_OA_LEAVE_TYPE = 'bpm_oa_leave_type',
|
|
||||||
BPM_PROCESS_INSTANCE_STATUS = 'bpm_process_instance_status',
|
|
||||||
BPM_PROCESS_LISTENER_TYPE = 'bpm_process_listener_type',
|
|
||||||
BPM_PROCESS_LISTENER_VALUE_TYPE = 'bpm_process_listener_value_type',
|
|
||||||
BPM_TASK_CANDIDATE_STRATEGY = 'bpm_task_candidate_strategy',
|
|
||||||
BPM_TASK_STATUS = 'bpm_task_status',
|
|
||||||
BROKERAGE_BANK_NAME = 'brokerage_bank_name', // 佣金提现银行
|
|
||||||
BROKERAGE_BIND_MODE = 'brokerage_bind_mode', // 分销关系绑定模式
|
|
||||||
|
|
||||||
BROKERAGE_ENABLED_CONDITION = 'brokerage_enabled_condition', // 分佣模式
|
|
||||||
BROKERAGE_RECORD_BIZ_TYPE = 'brokerage_record_biz_type', // 佣金业务类型
|
|
||||||
BROKERAGE_RECORD_STATUS = 'brokerage_record_status', // 佣金状态
|
|
||||||
BROKERAGE_WITHDRAW_STATUS = 'brokerage_withdraw_status', // 佣金提现状态
|
|
||||||
BROKERAGE_WITHDRAW_TYPE = 'brokerage_withdraw_type', // 佣金提现类型
|
|
||||||
COMMON_STATUS = 'common_status',
|
|
||||||
// ========== CRM - 客户管理模块 ==========
|
|
||||||
CRM_AUDIT_STATUS = 'crm_audit_status', // CRM 审批状态
|
|
||||||
CRM_BIZ_TYPE = 'crm_biz_type', // CRM 业务类型
|
|
||||||
CRM_BUSINESS_END_STATUS_TYPE = 'crm_business_end_status_type', // CRM 商机结束状态类型
|
|
||||||
CRM_CUSTOMER_INDUSTRY = 'crm_customer_industry', // CRM 客户所属行业
|
|
||||||
|
|
||||||
CRM_CUSTOMER_LEVEL = 'crm_customer_level', // CRM 客户级别
|
|
||||||
CRM_CUSTOMER_SOURCE = 'crm_customer_source', // CRM 客户来源
|
|
||||||
CRM_FOLLOW_UP_TYPE = 'crm_follow_up_type', // CRM 跟进方式
|
|
||||||
CRM_PERMISSION_LEVEL = 'crm_permission_level', // CRM 数据权限的级别
|
|
||||||
CRM_PRODUCT_STATUS = 'crm_product_status', // CRM 商品状态
|
|
||||||
CRM_PRODUCT_UNIT = 'crm_product_unit', // CRM 产品单位
|
|
||||||
CRM_RECEIVABLE_RETURN_TYPE = 'crm_receivable_return_type', // CRM 回款的还款方式
|
|
||||||
DATE_INTERVAL = 'date_interval', // 数据间隔
|
|
||||||
|
|
||||||
// ========== ERP - 企业资源计划模块 ==========
|
|
||||||
ERP_AUDIT_STATUS = 'erp_audit_status', // ERP 审批状态
|
|
||||||
ERP_STOCK_RECORD_BIZ_TYPE = 'erp_stock_record_biz_type', // 库存明细的业务类型
|
|
||||||
// ========== MALL - 交易模块 ==========
|
|
||||||
EXPRESS_CHARGE_MODE = 'trade_delivery_express_charge_mode', // 快递的计费方式
|
|
||||||
INFRA_API_ERROR_LOG_PROCESS_STATUS = 'infra_api_error_log_process_status',
|
|
||||||
// ========== INFRA 模块 ==========
|
|
||||||
INFRA_BOOLEAN_STRING = 'infra_boolean_string',
|
|
||||||
INFRA_CODEGEN_FRONT_TYPE = 'infra_codegen_front_type',
|
|
||||||
INFRA_CODEGEN_SCENE = 'infra_codegen_scene',
|
|
||||||
|
|
||||||
INFRA_CODEGEN_TEMPLATE_TYPE = 'infra_codegen_template_type',
|
|
||||||
INFRA_CONFIG_TYPE = 'infra_config_type',
|
|
||||||
|
|
||||||
INFRA_FILE_STORAGE = 'infra_file_storage',
|
|
||||||
INFRA_JOB_LOG_STATUS = 'infra_job_log_status',
|
|
||||||
|
|
||||||
INFRA_JOB_STATUS = 'infra_job_status',
|
|
||||||
|
|
||||||
INFRA_OPERATE_TYPE = 'infra_operate_type',
|
|
||||||
IOT_DATA_FORMAT = 'iot_data_format', // IOT 数据格式
|
|
||||||
IOT_DATA_TYPE = 'iot_data_type', // IOT 数据类型
|
|
||||||
IOT_DEVICE_STATUS = 'iot_device_status', // IOT 设备状态
|
|
||||||
// ========== IOT - 物联网模块 ==========
|
|
||||||
IOT_NET_TYPE = 'iot_net_type', // IOT 联网方式
|
|
||||||
IOT_PRODUCT_DEVICE_TYPE = 'iot_product_device_type', // IOT 产品设备类型
|
|
||||||
IOT_PRODUCT_FUNCTION_TYPE = 'iot_product_function_type', // IOT 产品功能类型
|
|
||||||
IOT_PRODUCT_STATUS = 'iot_product_status', // IOT 产品状态
|
|
||||||
IOT_PROTOCOL_TYPE = 'iot_protocol_type', // IOT 接入网关协议
|
|
||||||
IOT_RW_TYPE = 'iot_rw_type', // IOT 读写类型
|
|
||||||
IOT_UNIT_TYPE = 'iot_unit_type', // IOT 单位类型
|
|
||||||
IOT_VALIDATE_TYPE = 'iot_validate_type', // IOT 数据校验级别
|
|
||||||
MEMBER_EXPERIENCE_BIZ_TYPE = 'member_experience_biz_type', // 会员经验业务类型
|
|
||||||
// ========== Member 会员模块 ==========
|
|
||||||
MEMBER_POINT_BIZ_TYPE = 'member_point_biz_type', // 积分的业务类型
|
|
||||||
// ========== MP 模块 ==========
|
|
||||||
MP_AUTO_REPLY_REQUEST_MATCH = 'mp_auto_reply_request_match', // 自动回复请求匹配类型
|
|
||||||
|
|
||||||
MP_MESSAGE_TYPE = 'mp_message_type', // 消息类型
|
|
||||||
// ========== PAY 模块 ==========
|
|
||||||
PAY_CHANNEL_CODE = 'pay_channel_code', // 支付渠道编码类型
|
|
||||||
PAY_NOTIFY_STATUS = 'pay_notify_status', // 商户支付回调状态
|
|
||||||
PAY_NOTIFY_TYPE = 'pay_notify_type', // 商户支付回调状态
|
|
||||||
PAY_ORDER_STATUS = 'pay_order_status', // 商户支付订单状态
|
|
||||||
PAY_REFUND_STATUS = 'pay_refund_status', // 退款订单状态
|
|
||||||
PAY_TRANSFER_STATUS = 'pay_transfer_status', // 转账订单状态
|
|
||||||
PAY_TRANSFER_TYPE = 'pay_transfer_type', // 转账订单状态
|
|
||||||
// ========== MALL - 商品模块 ==========
|
|
||||||
PRODUCT_SPU_STATUS = 'product_spu_status', // 商品状态
|
|
||||||
|
|
||||||
PROMOTION_BANNER_POSITION = 'promotion_banner_position', // banner 定位
|
|
||||||
PROMOTION_BARGAIN_RECORD_STATUS = 'promotion_bargain_record_status', // 砍价记录的状态
|
|
||||||
PROMOTION_COMBINATION_RECORD_STATUS = 'promotion_combination_record_status', // 拼团记录的状态
|
|
||||||
PROMOTION_CONDITION_TYPE = 'promotion_condition_type', // 营销的条件类型枚举
|
|
||||||
PROMOTION_COUPON_STATUS = 'promotion_coupon_status', // 优惠劵的状态
|
|
||||||
PROMOTION_COUPON_TAKE_TYPE = 'promotion_coupon_take_type', // 优惠劵的领取方式
|
|
||||||
PROMOTION_COUPON_TEMPLATE_VALIDITY_TYPE = 'promotion_coupon_template_validity_type', // 优惠劵模板的有限期类型
|
|
||||||
// ========== MALL - 营销模块 ==========
|
|
||||||
PROMOTION_DISCOUNT_TYPE = 'promotion_discount_type', // 优惠类型
|
|
||||||
PROMOTION_PRODUCT_SCOPE = 'promotion_product_scope', // 营销的商品范围
|
|
||||||
SYSTEM_DATA_SCOPE = 'system_data_scope',
|
|
||||||
SYSTEM_LOGIN_RESULT = 'system_login_result',
|
|
||||||
|
|
||||||
SYSTEM_LOGIN_TYPE = 'system_login_type',
|
|
||||||
SYSTEM_MAIL_SEND_STATUS = 'system_mail_send_status',
|
|
||||||
|
|
||||||
SYSTEM_MENU_TYPE = 'system_menu_type',
|
|
||||||
SYSTEM_NOTICE_TYPE = 'system_notice_type',
|
|
||||||
SYSTEM_NOTIFY_TEMPLATE_TYPE = 'system_notify_template_type',
|
|
||||||
SYSTEM_OAUTH2_GRANT_TYPE = 'system_oauth2_grant_type',
|
|
||||||
SYSTEM_ROLE_TYPE = 'system_role_type',
|
|
||||||
SYSTEM_SMS_CHANNEL_CODE = 'system_sms_channel_code',
|
|
||||||
SYSTEM_SMS_RECEIVE_STATUS = 'system_sms_receive_status',
|
|
||||||
SYSTEM_SMS_SEND_STATUS = 'system_sms_send_status',
|
|
||||||
SYSTEM_SMS_TEMPLATE_TYPE = 'system_sms_template_type',
|
|
||||||
|
|
||||||
SYSTEM_SOCIAL_TYPE = 'system_social_type',
|
|
||||||
// ========== SYSTEM 模块 ==========
|
|
||||||
SYSTEM_USER_SEX = 'system_user_sex',
|
|
||||||
TERMINAL = 'terminal', // 终端
|
|
||||||
TRADE_AFTER_SALE_STATUS = 'trade_after_sale_status', // 售后 - 状态
|
|
||||||
TRADE_AFTER_SALE_TYPE = 'trade_after_sale_type', // 售后 - 类型
|
|
||||||
TRADE_AFTER_SALE_WAY = 'trade_after_sale_way', // 售后 - 方式
|
|
||||||
TRADE_DELIVERY_TYPE = 'trade_delivery_type', // 配送方式
|
|
||||||
TRADE_ORDER_ITEM_AFTER_SALE_STATUS = 'trade_order_item_after_sale_status', // 订单项 - 售后状态
|
|
||||||
TRADE_ORDER_STATUS = 'trade_order_status', // 订单 - 状态
|
|
||||||
TRADE_ORDER_TYPE = 'trade_order_type', // 订单 - 类型
|
|
||||||
USER_TYPE = 'user_type',
|
|
||||||
}
|
|
||||||
export { DICT_TYPE, getDictLabel, getDictObj, getDictOptions };
|
export { DICT_TYPE, getDictLabel, getDictObj, getDictOptions };
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue