mirror of
https://github.com/pure-admin/pure-admin-thin.git
synced 2025-12-14 22:30:31 +08:00
Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
bc3b199860 | ||
|
|
4407dd5d10 |
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "pure-admin-thin",
|
||||
"version": "3.8.5",
|
||||
"version": "3.8.6",
|
||||
"private": true,
|
||||
"scripts": {
|
||||
"dev": "NODE_OPTIONS=--max-old-space-size=4096 vite",
|
||||
@@ -80,7 +80,6 @@
|
||||
"@vitejs/plugin-vue-jsx": "^2.1.1",
|
||||
"@vue/eslint-config-prettier": "^7.0.0",
|
||||
"@vue/eslint-config-typescript": "^11.0.2",
|
||||
"@vue/runtime-core": "^3.2.45",
|
||||
"autoprefixer": "^10.4.13",
|
||||
"cloc": "^2.10.0",
|
||||
"cssnano": "^5.1.14",
|
||||
|
||||
2
pnpm-lock.yaml
generated
2
pnpm-lock.yaml
generated
@@ -26,7 +26,6 @@ specifiers:
|
||||
"@vitejs/plugin-vue-jsx": ^2.1.1
|
||||
"@vue/eslint-config-prettier": ^7.0.0
|
||||
"@vue/eslint-config-typescript": ^11.0.2
|
||||
"@vue/runtime-core": ^3.2.45
|
||||
"@vueuse/core": ^9.6.0
|
||||
"@vueuse/motion": 2.0.0-beta.12
|
||||
animate.css: ^4.1.1
|
||||
@@ -143,7 +142,6 @@ devDependencies:
|
||||
"@vitejs/plugin-vue-jsx": 2.1.1_vite@3.1.8+vue@3.2.45
|
||||
"@vue/eslint-config-prettier": 7.0.0_5qrnzwqb344w6up62gv3safeoi
|
||||
"@vue/eslint-config-typescript": 11.0.2_5ma4o5namqj2syekqcvrgakwe4
|
||||
"@vue/runtime-core": 3.2.45
|
||||
autoprefixer: 10.4.13_postcss@8.4.19
|
||||
cloc: 2.10.0
|
||||
cssnano: 5.1.14_postcss@8.4.19
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
{
|
||||
"Version": "3.8.5",
|
||||
"Version": "3.8.6",
|
||||
"Title": "PureAdmin",
|
||||
"FixedHeader": true,
|
||||
"HiddenSideBar": false,
|
||||
|
||||
@@ -155,4 +155,18 @@ html.dark {
|
||||
.el-dropdown-menu__item:not(.is-disabled):hover {
|
||||
background: transparent;
|
||||
}
|
||||
|
||||
/* 克隆并自定义 ElMessage 样式,不会影响 ElMessage 原本样式,在 src/utils/message.ts 中调用自定义样式 ElMessage 方法即可,非暗黑模式在 src/style/element-plus.scss 文件进行了适配 */
|
||||
.pure-message {
|
||||
background-image: initial !important;
|
||||
background-color: rgb(36, 37, 37) !important;
|
||||
box-shadow: rgb(13 13 13 / 12%) 0px 3px 6px -4px,
|
||||
rgb(13 13 13 / 8%) 0px 6px 16px 0px, rgb(13 13 13 / 5%) 0px 9px 28px 8px !important;
|
||||
|
||||
& .el-message__content {
|
||||
color: $color-white !important;
|
||||
pointer-events: all !important;
|
||||
background-image: initial !important;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -62,3 +62,30 @@
|
||||
border-left-color: var(--el-color-primary);
|
||||
}
|
||||
}
|
||||
|
||||
/* 克隆并自定义 ElMessage 样式,不会影响 ElMessage 原本样式,在 src/utils/message.ts 中调用自定义样式 ElMessage 方法即可,暗黑模式在 src/style/dark.scss 文件进行了适配 */
|
||||
.pure-message {
|
||||
border-width: 0 !important;
|
||||
background: #fff !important;
|
||||
padding: 10px 13px !important;
|
||||
box-shadow: 0 3px 6px -4px #0000001f, 0 6px 16px #00000014,
|
||||
0 9px 28px 8px #0000000d !important;
|
||||
|
||||
&.el-message.is-closable .el-message__content {
|
||||
padding-right: 17px !important;
|
||||
}
|
||||
|
||||
& .el-message__content {
|
||||
color: #000000d9 !important;
|
||||
pointer-events: all !important;
|
||||
background-image: initial !important;
|
||||
}
|
||||
|
||||
& .el-message__icon {
|
||||
margin-right: 8px !important;
|
||||
}
|
||||
|
||||
& .el-message__closeBtn {
|
||||
right: 9px !important;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,32 +1,84 @@
|
||||
import { type VNode } from "vue";
|
||||
import { isFunction } from "@pureadmin/utils";
|
||||
import { type MessageHandler, ElMessage } from "element-plus";
|
||||
|
||||
// 更多配置请看:https://element-plus.org/zh-CN/component/message.html#message-%E9%85%8D%E7%BD%AE%E9%A1%B9
|
||||
type messageStyle = "el" | "antd";
|
||||
type messageTypes = "info" | "success" | "warning" | "error";
|
||||
|
||||
type messageTypes = "success" | "info" | "warning" | "error";
|
||||
interface MessageParams {
|
||||
/** 消息类型,可选 `info` 、`success` 、`warning` 、`error` ,默认 `info` */
|
||||
type?: messageTypes;
|
||||
/** 自定义图标,该属性会覆盖 `type` 的图标 */
|
||||
icon?: any;
|
||||
/** 是否将 `message` 属性作为 `HTML` 片段处理,默认 `false` */
|
||||
dangerouslyUseHTMLString?: boolean;
|
||||
/** 消息风格,可选 `el` 、`antd` ,默认 `antd` */
|
||||
customClass?: messageStyle;
|
||||
/** 显示时间,单位为毫秒。设为 `0` 则不会自动关闭,`element-plus` 默认是 `3000` ,平台改成默认 `2000` */
|
||||
duration?: number;
|
||||
/** 是否显示关闭按钮,默认值 `false` */
|
||||
showClose?: boolean;
|
||||
/** 文字是否居中,默认值 `false` */
|
||||
center?: boolean;
|
||||
/** `Message` 距离窗口顶部的偏移量,默认 `20` */
|
||||
offset?: number;
|
||||
/** 设置组件的根元素,默认 `document.body` */
|
||||
appendTo?: string | HTMLElement;
|
||||
/** 合并内容相同的消息,不支持 `VNode` 类型的消息,默认值 `false` */
|
||||
grouping?: boolean;
|
||||
/** 关闭时的回调函数, 参数为被关闭的 `message` 实例 */
|
||||
onClose?: Function | null;
|
||||
}
|
||||
|
||||
/** 用法非常简单,参考 src/views/components/message/index.vue 文件 */
|
||||
|
||||
/**
|
||||
* `element-plus` 的 `info` 消息类型
|
||||
* `Message` 消息提示函数
|
||||
*/
|
||||
const message = (
|
||||
message: string,
|
||||
type = "info" as messageTypes,
|
||||
showClose = true,
|
||||
duration = 2000,
|
||||
center = false,
|
||||
grouping = false
|
||||
message: string | VNode | (() => VNode),
|
||||
params?: MessageParams
|
||||
): MessageHandler => {
|
||||
if (!params) {
|
||||
return ElMessage({
|
||||
message,
|
||||
customClass: "pure-message"
|
||||
});
|
||||
} else {
|
||||
const {
|
||||
icon,
|
||||
type = "info",
|
||||
dangerouslyUseHTMLString = false,
|
||||
customClass = "antd",
|
||||
duration = 2000,
|
||||
showClose = false,
|
||||
center = false,
|
||||
offset = 20,
|
||||
appendTo = document.body,
|
||||
grouping = false,
|
||||
onClose
|
||||
} = params;
|
||||
|
||||
return ElMessage({
|
||||
message,
|
||||
type,
|
||||
showClose,
|
||||
icon,
|
||||
dangerouslyUseHTMLString,
|
||||
duration,
|
||||
showClose,
|
||||
center,
|
||||
grouping
|
||||
offset,
|
||||
appendTo,
|
||||
grouping,
|
||||
// 全局搜 pure-message 即可知道该类的样式位置
|
||||
customClass: customClass === "antd" ? "pure-message" : "",
|
||||
onClose: () => (isFunction(onClose) ? onClose() : null)
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* 关闭 `element-plus` 的所有消息实例
|
||||
* 关闭所有 `Message` 消息提示函数
|
||||
*/
|
||||
const closeAllMessage = (): void => ElMessage.closeAll();
|
||||
|
||||
|
||||
@@ -47,7 +47,7 @@ const onLogin = async (formEl: FormInstance | undefined) => {
|
||||
// 获取后端路由
|
||||
initRouter().then(() => {
|
||||
router.push("/");
|
||||
message("登录成功", "success");
|
||||
message("登录成功", { type: "success" });
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
@@ -21,8 +21,7 @@
|
||||
"incremental": true,
|
||||
"paths": {
|
||||
"@/*": ["src/*"],
|
||||
"@build/*": ["build/*"],
|
||||
"/#/*": ["types/*"]
|
||||
"@build/*": ["build/*"]
|
||||
},
|
||||
"types": [
|
||||
"node",
|
||||
@@ -30,16 +29,17 @@
|
||||
"element-plus/global",
|
||||
"@pureadmin/table/volar",
|
||||
"@pureadmin/descriptions/volar",
|
||||
"unplugin-vue-macros/macros-global"
|
||||
"unplugin-vue-macros/macros-global",
|
||||
"unplugin-vue-define-options/macros-global"
|
||||
],
|
||||
"typeRoots": ["./node_modules/@types/", "./types"]
|
||||
},
|
||||
"include": [
|
||||
"mock/*.ts",
|
||||
"src/**/*.ts",
|
||||
"src/**/*.tsx",
|
||||
"src/**/*.vue",
|
||||
"types/*.d.ts",
|
||||
"mock/*.ts",
|
||||
"vite.config.ts"
|
||||
],
|
||||
"exclude": ["node_modules", "dist", "**/*.js"]
|
||||
|
||||
124
types/global-components.d.ts
vendored
Normal file
124
types/global-components.d.ts
vendored
Normal file
@@ -0,0 +1,124 @@
|
||||
declare module "vue" {
|
||||
/**
|
||||
* 自定义全局组件获得 Volar 提示(自定义的全局组件需要在这里声明下才能获得 Volar 类型提示哦)
|
||||
*/
|
||||
export interface GlobalComponents {
|
||||
IconifyIconOffline: typeof import("../src/components/ReIcon")["IconifyIconOffline"];
|
||||
IconifyIconOnline: typeof import("../src/components/ReIcon")["IconifyIconOnline"];
|
||||
FontIcon: typeof import("../src/components/ReIcon")["FontIcon"];
|
||||
Auth: typeof import("../src/components/ReAuth")["Auth"];
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* todo:https://github.com/element-plus/element-plus/blob/dev/global.d.ts#L2
|
||||
* No need to install @vue/runtime-core
|
||||
*/
|
||||
declare module "vue" {
|
||||
export interface GlobalComponents {
|
||||
ElAffix: typeof import("element-plus")["ElAffix"];
|
||||
ElAlert: typeof import("element-plus")["ElAlert"];
|
||||
ElAside: typeof import("element-plus")["ElAside"];
|
||||
ElAutocomplete: typeof import("element-plus")["ElAutocomplete"];
|
||||
ElAvatar: typeof import("element-plus")["ElAvatar"];
|
||||
ElBacktop: typeof import("element-plus")["ElBacktop"];
|
||||
ElBadge: typeof import("element-plus")["ElBadge"];
|
||||
ElBreadcrumb: typeof import("element-plus")["ElBreadcrumb"];
|
||||
ElBreadcrumbItem: typeof import("element-plus")["ElBreadcrumbItem"];
|
||||
ElButton: typeof import("element-plus")["ElButton"];
|
||||
ElButtonGroup: typeof import("element-plus")["ElButtonGroup"];
|
||||
ElCalendar: typeof import("element-plus")["ElCalendar"];
|
||||
ElCard: typeof import("element-plus")["ElCard"];
|
||||
ElCarousel: typeof import("element-plus")["ElCarousel"];
|
||||
ElCarouselItem: typeof import("element-plus")["ElCarouselItem"];
|
||||
ElCascader: typeof import("element-plus")["ElCascader"];
|
||||
ElCascaderPanel: typeof import("element-plus")["ElCascaderPanel"];
|
||||
ElCheckbox: typeof import("element-plus")["ElCheckbox"];
|
||||
ElCheckboxButton: typeof import("element-plus")["ElCheckboxButton"];
|
||||
ElCheckboxGroup: typeof import("element-plus")["ElCheckboxGroup"];
|
||||
ElCol: typeof import("element-plus")["ElCol"];
|
||||
ElCollapse: typeof import("element-plus")["ElCollapse"];
|
||||
ElCollapseItem: typeof import("element-plus")["ElCollapseItem"];
|
||||
ElCollapseTransition: typeof import("element-plus")["ElCollapseTransition"];
|
||||
ElColorPicker: typeof import("element-plus")["ElColorPicker"];
|
||||
ElContainer: typeof import("element-plus")["ElContainer"];
|
||||
ElConfigProvider: typeof import("element-plus")["ElConfigProvider"];
|
||||
ElDatePicker: typeof import("element-plus")["ElDatePicker"];
|
||||
ElDialog: typeof import("element-plus")["ElDialog"];
|
||||
ElDivider: typeof import("element-plus")["ElDivider"];
|
||||
ElDrawer: typeof import("element-plus")["ElDrawer"];
|
||||
ElDropdown: typeof import("element-plus")["ElDropdown"];
|
||||
ElDropdownItem: typeof import("element-plus")["ElDropdownItem"];
|
||||
ElDropdownMenu: typeof import("element-plus")["ElDropdownMenu"];
|
||||
ElEmpty: typeof import("element-plus")["ElEmpty"];
|
||||
ElFooter: typeof import("element-plus")["ElFooter"];
|
||||
ElForm: typeof import("element-plus")["ElForm"];
|
||||
ElFormItem: typeof import("element-plus")["ElFormItem"];
|
||||
ElHeader: typeof import("element-plus")["ElHeader"];
|
||||
ElIcon: typeof import("element-plus")["ElIcon"];
|
||||
ElImage: typeof import("element-plus")["ElImage"];
|
||||
ElImageViewer: typeof import("element-plus")["ElImageViewer"];
|
||||
ElInput: typeof import("element-plus")["ElInput"];
|
||||
ElInputNumber: typeof import("element-plus")["ElInputNumber"];
|
||||
ElLink: typeof import("element-plus")["ElLink"];
|
||||
ElMain: typeof import("element-plus")["ElMain"];
|
||||
ElMenu: typeof import("element-plus")["ElMenu"];
|
||||
ElMenuItem: typeof import("element-plus")["ElMenuItem"];
|
||||
ElMenuItemGroup: typeof import("element-plus")["ElMenuItemGroup"];
|
||||
ElOption: typeof import("element-plus")["ElOption"];
|
||||
ElOptionGroup: typeof import("element-plus")["ElOptionGroup"];
|
||||
ElPageHeader: typeof import("element-plus")["ElPageHeader"];
|
||||
ElPagination: typeof import("element-plus")["ElPagination"];
|
||||
ElPopconfirm: typeof import("element-plus")["ElPopconfirm"];
|
||||
ElPopper: typeof import("element-plus")["ElPopper"];
|
||||
ElPopover: typeof import("element-plus")["ElPopover"];
|
||||
ElProgress: typeof import("element-plus")["ElProgress"];
|
||||
ElRadio: typeof import("element-plus")["ElRadio"];
|
||||
ElRadioButton: typeof import("element-plus")["ElRadioButton"];
|
||||
ElRadioGroup: typeof import("element-plus")["ElRadioGroup"];
|
||||
ElRate: typeof import("element-plus")["ElRate"];
|
||||
ElRow: typeof import("element-plus")["ElRow"];
|
||||
ElScrollbar: typeof import("element-plus")["ElScrollbar"];
|
||||
ElSelect: typeof import("element-plus")["ElSelect"];
|
||||
ElSlider: typeof import("element-plus")["ElSlider"];
|
||||
ElStep: typeof import("element-plus")["ElStep"];
|
||||
ElSteps: typeof import("element-plus")["ElSteps"];
|
||||
ElSubMenu: typeof import("element-plus")["ElSubMenu"];
|
||||
ElSwitch: typeof import("element-plus")["ElSwitch"];
|
||||
ElTabPane: typeof import("element-plus")["ElTabPane"];
|
||||
ElTable: typeof import("element-plus")["ElTable"];
|
||||
ElTableColumn: typeof import("element-plus")["ElTableColumn"];
|
||||
ElTabs: typeof import("element-plus")["ElTabs"];
|
||||
ElTag: typeof import("element-plus")["ElTag"];
|
||||
ElTimePicker: typeof import("element-plus")["ElTimePicker"];
|
||||
ElTimeSelect: typeof import("element-plus")["ElTimeSelect"];
|
||||
ElTimeline: typeof import("element-plus")["ElTimeline"];
|
||||
ElTimelineItem: typeof import("element-plus")["ElTimelineItem"];
|
||||
ElTooltip: typeof import("element-plus")["ElTooltip"];
|
||||
ElTransfer: typeof import("element-plus")["ElTransfer"];
|
||||
ElTree: typeof import("element-plus")["ElTree"];
|
||||
ElTreeV2: typeof import("element-plus")["ElTreeV2"];
|
||||
ElUpload: typeof import("element-plus")["ElUpload"];
|
||||
ElSpace: typeof import("element-plus")["ElSpace"];
|
||||
ElSkeleton: typeof import("element-plus")["ElSkeleton"];
|
||||
ElSkeletonItem: typeof import("element-plus")["ElSkeletonItem"];
|
||||
ElCheckTag: typeof import("element-plus")["ElCheckTag"];
|
||||
ElDescriptions: typeof import("element-plus")["ElDescriptions"];
|
||||
ElDescriptionsItem: typeof import("element-plus")["ElDescriptionsItem"];
|
||||
ElResult: typeof import("element-plus")["ElResult"];
|
||||
ElSelectV2: typeof import("element-plus")["ElSelectV2"];
|
||||
}
|
||||
|
||||
interface ComponentCustomProperties {
|
||||
$message: typeof import("element-plus")["ElMessage"];
|
||||
$notify: typeof import("element-plus")["ElNotification"];
|
||||
$msgbox: typeof import("element-plus")["ElMessageBox"];
|
||||
$messageBox: typeof import("element-plus")["ElMessageBox"];
|
||||
$alert: typeof import("element-plus")["ElMessageBox"]["alert"];
|
||||
$confirm: typeof import("element-plus")["ElMessageBox"]["confirm"];
|
||||
$prompt: typeof import("element-plus")["ElMessageBox"]["prompt"];
|
||||
$loading: typeof import("element-plus")["ElLoadingService"];
|
||||
}
|
||||
}
|
||||
|
||||
export {};
|
||||
12
types/global.d.ts
vendored
12
types/global.d.ts
vendored
@@ -265,15 +265,3 @@ declare global {
|
||||
$config: ServerConfigs;
|
||||
}
|
||||
}
|
||||
|
||||
declare module "vue" {
|
||||
/**
|
||||
* 自定义全局组件获得 Volar 提示(自定义的全局组件需要在这里声明下才能获得 Volar 类型提示哦)
|
||||
*/
|
||||
export interface GlobalComponents {
|
||||
IconifyIconOffline: typeof import("../src/components/ReIcon")["IconifyIconOffline"];
|
||||
IconifyIconOnline: typeof import("../src/components/ReIcon")["IconifyIconOnline"];
|
||||
FontIcon: typeof import("../src/components/ReIcon")["FontIcon"];
|
||||
Auth: typeof import("../src/components/ReAuth")["Auth"];
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user