mooho-base-admin-plus 0.4.0 → 0.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/mooho-base-admin-plus.min.esm.js +1314 -1810
- package/dist/mooho-base-admin-plus.min.js +74 -63
- package/dist/setting.js +2 -15
- package/package.json +1 -1
- package/public/setting.js +2 -15
- package/src/i18n/index.js +39 -2
- package/src/i18n/locale/en-US.js +1 -1
- package/src/i18n/locale/lang.js +1 -1
- package/src/i18n/locale/zh-CN.js +1 -1
- package/src/index.js +2 -2
- package/src/layouts/basic-layout/mixins/click-item.js +21 -21
- package/src/layouts/basic-layout/mixins/sider-menu-badge.js +13 -13
- package/src/layouts/basic-layout/mixins/translate-title.js +11 -11
- package/src/layouts/basic-layout/water-mark/index.vue +29 -29
- package/src/libs/random_str.js +10 -10
- package/src/libs/water-mark.js +44 -44
- package/src/setting.js +1 -14
- package/src/store/modules/admin/modules/account.js +3 -4
- package/src/store/modules/admin/modules/i18n.js +1 -42
- package/src/styles/common.less +47 -47
- package/src/styles/default/index.less +6 -6
- package/src/styles/font/iconfont.css +47 -47
- package/src/styles/font/iconfont.json +65 -65
- package/src/styles/layout/basic-layout/layout.less +527 -527
- package/src/styles/layout/basic-layout/menu.less +274 -274
- package/src/styles/layout/index.less +2 -2
- package/src/styles/setting.less +6 -6
- package/test/main.js +1 -1
- package/src/layouts/basic-layout/i18n.js +0 -50
- package/src/plugins/log/index.js +0 -25
package/dist/setting.js
CHANGED
|
@@ -38,21 +38,8 @@ window.setting = {
|
|
|
38
38
|
// 默认语言
|
|
39
39
|
default: 'zh-CN',
|
|
40
40
|
// 是否根据用户电脑配置自动设置语言(仅第一次有效)
|
|
41
|
-
auto:
|
|
41
|
+
auto: true,
|
|
42
42
|
// 切换语言时是否刷新页面
|
|
43
|
-
refresh: true
|
|
44
|
-
// 支持的语言列表
|
|
45
|
-
list: [
|
|
46
|
-
{
|
|
47
|
-
locale: 'zh-CN',
|
|
48
|
-
language: '简体中文'
|
|
49
|
-
},
|
|
50
|
-
{
|
|
51
|
-
locale: 'en-US',
|
|
52
|
-
language: 'English'
|
|
53
|
-
}
|
|
54
|
-
],
|
|
55
|
-
// 是否通过远程接口来获取 i81n 文件
|
|
56
|
-
remote: false
|
|
43
|
+
refresh: true
|
|
57
44
|
}
|
|
58
45
|
};
|
package/package.json
CHANGED
package/public/setting.js
CHANGED
|
@@ -38,21 +38,8 @@ window.setting = {
|
|
|
38
38
|
// 默认语言
|
|
39
39
|
default: 'zh-CN',
|
|
40
40
|
// 是否根据用户电脑配置自动设置语言(仅第一次有效)
|
|
41
|
-
auto:
|
|
41
|
+
auto: true,
|
|
42
42
|
// 切换语言时是否刷新页面
|
|
43
|
-
refresh: true
|
|
44
|
-
// 支持的语言列表
|
|
45
|
-
list: [
|
|
46
|
-
{
|
|
47
|
-
locale: 'zh-CN',
|
|
48
|
-
language: '简体中文'
|
|
49
|
-
},
|
|
50
|
-
{
|
|
51
|
-
locale: 'en-US',
|
|
52
|
-
language: 'English'
|
|
53
|
-
}
|
|
54
|
-
],
|
|
55
|
-
// 是否通过远程接口来获取 i81n 文件
|
|
56
|
-
remote: false
|
|
43
|
+
refresh: true
|
|
57
44
|
}
|
|
58
45
|
};
|
package/src/i18n/index.js
CHANGED
|
@@ -1,4 +1,9 @@
|
|
|
1
1
|
import { createI18n } from 'vue-i18n/index';
|
|
2
|
+
import Setting from '../setting';
|
|
3
|
+
import util from '../libs/util';
|
|
4
|
+
import { pathInit } from '../store/modules/admin/modules/db';
|
|
5
|
+
|
|
6
|
+
const savedLocaleKey = 'i18n-locale';
|
|
2
7
|
//import store from '../store/index';
|
|
3
8
|
//import messages from './locale';
|
|
4
9
|
|
|
@@ -6,10 +11,42 @@ import { createI18n } from 'vue-i18n/index';
|
|
|
6
11
|
|
|
7
12
|
//const locale = store.state.admin.i18n.locale;
|
|
8
13
|
|
|
14
|
+
let locale;
|
|
15
|
+
|
|
16
|
+
const db = util.db.get(
|
|
17
|
+
pathInit({
|
|
18
|
+
dbName: 'database',
|
|
19
|
+
path: '',
|
|
20
|
+
user: false,
|
|
21
|
+
defaultValue: {}
|
|
22
|
+
})
|
|
23
|
+
);
|
|
24
|
+
|
|
25
|
+
const savedLocale = db.get(savedLocaleKey).value();
|
|
26
|
+
|
|
27
|
+
console.log('savedLocale', savedLocale);
|
|
28
|
+
|
|
29
|
+
// 先判断本地存储是否已有语言选择
|
|
30
|
+
if (savedLocale) {
|
|
31
|
+
locale = savedLocale;
|
|
32
|
+
} else {
|
|
33
|
+
// 判断是否开启自动识别语言
|
|
34
|
+
if (Setting.i18n.auto) {
|
|
35
|
+
// 如果自动识别的语言,本地没有该语言包,则设置为默认语言
|
|
36
|
+
const navLang = navigator.language;
|
|
37
|
+
locale = navLang;
|
|
38
|
+
} else {
|
|
39
|
+
locale = Setting.i18n.default;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// 将初次的语言保存在本地
|
|
43
|
+
db.set(savedLocaleKey, locale).write();
|
|
44
|
+
}
|
|
45
|
+
|
|
9
46
|
export default createI18n({
|
|
10
47
|
allowComposition: true,
|
|
11
48
|
globalInjection: true,
|
|
12
|
-
legacy: false
|
|
13
|
-
|
|
49
|
+
legacy: false,
|
|
50
|
+
locale
|
|
14
51
|
// messages
|
|
15
52
|
});
|
package/src/i18n/locale/en-US.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{s as e}from"./lang.js";const t={i:{locale:"en-US",select:{placeholder:"Select",noMatch:"No matching data",loading:"Loading"},table:{noDataText:"No Data",noFilteredDataText:"No filter data",confirmFilter:"Confirm",resetFilter:"Reset",clearFilter:"All",sumText:"Sum"},datepicker:{selectDate:"Select date",selectTime:"Select time",startTime:"Start Time",endTime:"End Time",clear:"Clear",ok:"OK",datePanelLabel:"[mmmm] [yyyy]",month:"Month",month1:"January",month2:"February",month3:"March",month4:"April",month5:"May",month6:"June",month7:"July",month8:"August",month9:"September",month10:"October",month11:"November",month12:"December",year:"Year",weekStartDay:"0",weeks:{sun:"Sun",mon:"Mon",tue:"Tue",wed:"Wed",thu:"Thu",fri:"Fri",sat:"Sat"},months:{m1:"Jan",m2:"Feb",m3:"Mar",m4:"Apr",m5:"May",m6:"Jun",m7:"Jul",m8:"Aug",m9:"Sep",m10:"Oct",m11:"Nov",m12:"Dec"}},transfer:{titles:{source:"Source",target:"Target"},filterPlaceholder:"Search here",notFoundText:"Not Found"},modal:{okText:"OK",cancelText:"Cancel"},poptip:{okText:"OK",cancelText:"Cancel"},page:{prev:"Previous Page",next:"Next Page",total:"Total",item:"item",items:"items",prev5:"Previous 5 Pages",next5:"Next 5 Pages",page:"/page",goto:"Goto",p:""},rate:{star:"Star",stars:"Stars"},time:{before:" ago",after:" after",just:"just now",seconds:" seconds",minutes:" minutes",hours:" hours",days:" days"},tree:{emptyText:"No Data"}}};e(t);export{t as default};
|
|
1
|
+
import{s as e}from"./lang.js";const t={i:{locale:"en-US",select:{placeholder:"Select",noMatch:"No matching data",loading:"Loading"},table:{noDataText:"No Data",noFilteredDataText:"No filter data",confirmFilter:"Confirm",resetFilter:"Reset",clearFilter:"All",sumText:"Sum"},datepicker:{selectDate:"Select date",selectTime:"Select time",startTime:"Start Time",endTime:"End Time",clear:"Clear",ok:"OK",datePanelLabel:"[mmmm] [yyyy]",month:"Month",month1:"January",month2:"February",month3:"March",month4:"April",month5:"May",month6:"June",month7:"July",month8:"August",month9:"September",month10:"October",month11:"November",month12:"December",year:"Year",weekStartDay:"0",weeks:{sun:"Sun",mon:"Mon",tue:"Tue",wed:"Wed",thu:"Thu",fri:"Fri",sat:"Sat"},months:{m1:"Jan",m2:"Feb",m3:"Mar",m4:"Apr",m5:"May",m6:"Jun",m7:"Jul",m8:"Aug",m9:"Sep",m10:"Oct",m11:"Nov",m12:"Dec"}},transfer:{titles:{source:"Source",target:"Target"},filterPlaceholder:"Search here",notFoundText:"Not Found"},modal:{okText:"OK",cancelText:"Cancel"},poptip:{okText:"OK",cancelText:"Cancel"},page:{prev:"Previous Page",next:"Next Page",total:"Total",item:"item",items:"items",prev5:"Previous 5 Pages",next5:"Next 5 Pages",page:"/page",goto:"Goto",p:""},rate:{star:"Star",stars:"Stars"},time:{before:" ago",after:" after",just:"just now",seconds:" seconds",minutes:" minutes",hours:" hours",days:" days"},tree:{emptyText:"No Data"}}};e(t);export{t as default};
|
package/src/i18n/locale/lang.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
const e=typeof window!="undefined";function n(i){e&&typeof window.viewuiplus!="undefined"&&("langs"in viewuiplus||(viewuiplus.langs={}),viewuiplus.langs[i.i.locale]=i)}export{n as s};
|
|
1
|
+
const e=typeof window!="undefined";function n(i){e&&typeof window.viewuiplus!="undefined"&&("langs"in viewuiplus||(viewuiplus.langs={}),viewuiplus.langs[i.i.locale]=i)}export{n as s};
|
package/src/i18n/locale/zh-CN.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{s as e}from"./lang.js";const t={i:{locale:"zh-CN",select:{placeholder:"\u8BF7\u9009\u62E9",noMatch:"\u65E0\u5339\u914D\u6570\u636E",loading:"\u52A0\u8F7D\u4E2D"},table:{noDataText:"\u6682\u65E0\u6570\u636E",noFilteredDataText:"\u6682\u65E0\u7B5B\u9009\u7ED3\u679C",confirmFilter:"\u7B5B\u9009",resetFilter:"\u91CD\u7F6E",clearFilter:"\u5168\u90E8",sumText:"\u5408\u8BA1"},datepicker:{selectDate:"\u9009\u62E9\u65E5\u671F",selectTime:"\u9009\u62E9\u65F6\u95F4",startTime:"\u5F00\u59CB\u65F6\u95F4",endTime:"\u7ED3\u675F\u65F6\u95F4",clear:"\u6E05\u7A7A",ok:"\u786E\u5B9A",datePanelLabel:"[yyyy\u5E74] [m\u6708]",month:"\u6708",month1:"1 \u6708",month2:"2 \u6708",month3:"3 \u6708",month4:"4 \u6708",month5:"5 \u6708",month6:"6 \u6708",month7:"7 \u6708",month8:"8 \u6708",month9:"9 \u6708",month10:"10 \u6708",month11:"11 \u6708",month12:"12 \u6708",year:"\u5E74",weekStartDay:"0",weeks:{sun:"\u65E5",mon:"\u4E00",tue:"\u4E8C",wed:"\u4E09",thu:"\u56DB",fri:"\u4E94",sat:"\u516D"},months:{m1:"1\u6708",m2:"2\u6708",m3:"3\u6708",m4:"4\u6708",m5:"5\u6708",m6:"6\u6708",m7:"7\u6708",m8:"8\u6708",m9:"9\u6708",m10:"10\u6708",m11:"11\u6708",m12:"12\u6708"}},transfer:{titles:{source:"\u6E90\u5217\u8868",target:"\u76EE\u7684\u5217\u8868"},filterPlaceholder:"\u8BF7\u8F93\u5165\u641C\u7D22\u5185\u5BB9",notFoundText:"\u5217\u8868\u4E3A\u7A7A"},modal:{okText:"\u786E\u5B9A",cancelText:"\u53D6\u6D88"},poptip:{okText:"\u786E\u5B9A",cancelText:"\u53D6\u6D88"},page:{prev:"\u4E0A\u4E00\u9875",next:"\u4E0B\u4E00\u9875",total:"\u5171",item:"\u6761",items:"\u6761",prev5:"\u5411\u524D 5 \u9875",next5:"\u5411\u540E 5 \u9875",page:"\u6761/\u9875",goto:"\u8DF3\u81F3",p:"\u9875"},rate:{star:"\u661F",stars:"\u661F"},time:{before:"\u524D",after:"\u540E",just:"\u521A\u521A",seconds:"\u79D2",minutes:"\u5206\u949F",hours:"\u5C0F\u65F6",days:"\u5929"},tree:{emptyText:"\u6682\u65E0\u6570\u636E"}}};e(t);export{t as default};
|
|
1
|
+
import{s as e}from"./lang.js";const t={i:{locale:"zh-CN",select:{placeholder:"\u8BF7\u9009\u62E9",noMatch:"\u65E0\u5339\u914D\u6570\u636E",loading:"\u52A0\u8F7D\u4E2D"},table:{noDataText:"\u6682\u65E0\u6570\u636E",noFilteredDataText:"\u6682\u65E0\u7B5B\u9009\u7ED3\u679C",confirmFilter:"\u7B5B\u9009",resetFilter:"\u91CD\u7F6E",clearFilter:"\u5168\u90E8",sumText:"\u5408\u8BA1"},datepicker:{selectDate:"\u9009\u62E9\u65E5\u671F",selectTime:"\u9009\u62E9\u65F6\u95F4",startTime:"\u5F00\u59CB\u65F6\u95F4",endTime:"\u7ED3\u675F\u65F6\u95F4",clear:"\u6E05\u7A7A",ok:"\u786E\u5B9A",datePanelLabel:"[yyyy\u5E74] [m\u6708]",month:"\u6708",month1:"1 \u6708",month2:"2 \u6708",month3:"3 \u6708",month4:"4 \u6708",month5:"5 \u6708",month6:"6 \u6708",month7:"7 \u6708",month8:"8 \u6708",month9:"9 \u6708",month10:"10 \u6708",month11:"11 \u6708",month12:"12 \u6708",year:"\u5E74",weekStartDay:"0",weeks:{sun:"\u65E5",mon:"\u4E00",tue:"\u4E8C",wed:"\u4E09",thu:"\u56DB",fri:"\u4E94",sat:"\u516D"},months:{m1:"1\u6708",m2:"2\u6708",m3:"3\u6708",m4:"4\u6708",m5:"5\u6708",m6:"6\u6708",m7:"7\u6708",m8:"8\u6708",m9:"9\u6708",m10:"10\u6708",m11:"11\u6708",m12:"12\u6708"}},transfer:{titles:{source:"\u6E90\u5217\u8868",target:"\u76EE\u7684\u5217\u8868"},filterPlaceholder:"\u8BF7\u8F93\u5165\u641C\u7D22\u5185\u5BB9",notFoundText:"\u5217\u8868\u4E3A\u7A7A"},modal:{okText:"\u786E\u5B9A",cancelText:"\u53D6\u6D88"},poptip:{okText:"\u786E\u5B9A",cancelText:"\u53D6\u6D88"},page:{prev:"\u4E0A\u4E00\u9875",next:"\u4E0B\u4E00\u9875",total:"\u5171",item:"\u6761",items:"\u6761",prev5:"\u5411\u524D 5 \u9875",next5:"\u5411\u540E 5 \u9875",page:"\u6761/\u9875",goto:"\u8DF3\u81F3",p:"\u9875"},rate:{star:"\u661F",stars:"\u661F"},time:{before:"\u524D",after:"\u540E",just:"\u521A\u521A",seconds:"\u79D2",minutes:"\u5206\u949F",hours:"\u5C0F\u65F6",days:"\u5929"},tree:{emptyText:"\u6682\u65E0\u6570\u636E"}}};e(t);export{t as default};
|
package/src/index.js
CHANGED
|
@@ -163,9 +163,9 @@ Object.keys(files).forEach(key => {
|
|
|
163
163
|
// 第一次进入时,取菜单数据用于更新
|
|
164
164
|
let isFirstRouteChange = true;
|
|
165
165
|
|
|
166
|
-
const created = async
|
|
166
|
+
const created = async () => {
|
|
167
167
|
// 加载多语言
|
|
168
|
-
await store.dispatch('admin/i18n/load'
|
|
168
|
+
await store.dispatch('admin/i18n/load');
|
|
169
169
|
// 初始化动态路由
|
|
170
170
|
//let dynamicRoutes = await dynamicRouter.init(router, pages, layout);
|
|
171
171
|
// 处理路由 得到每一级的路由设置
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import { findComponentUpward } from 'view-ui-plus/src/utils/assist';
|
|
2
|
-
import { mapState } from 'vuex';
|
|
3
|
-
|
|
4
|
-
export default {
|
|
5
|
-
computed: {
|
|
6
|
-
...mapState('admin/layout', ['menuSiderReload', 'menuHeaderReload'])
|
|
7
|
-
},
|
|
8
|
-
methods: {
|
|
9
|
-
handleClick(path, type = 'sider') {
|
|
10
|
-
const current = this.$route.path;
|
|
11
|
-
if (current === path) {
|
|
12
|
-
if (type === 'sider' && this.menuSiderReload) this.handleReload();
|
|
13
|
-
else if (type === 'header' && this.menuHeaderReload) this.handleReload();
|
|
14
|
-
}
|
|
15
|
-
},
|
|
16
|
-
handleReload() {
|
|
17
|
-
const $layout = findComponentUpward(this, 'BasicLayout');
|
|
18
|
-
if ($layout) $layout.handleReload();
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
};
|
|
1
|
+
import { findComponentUpward } from 'view-ui-plus/src/utils/assist';
|
|
2
|
+
import { mapState } from 'vuex';
|
|
3
|
+
|
|
4
|
+
export default {
|
|
5
|
+
computed: {
|
|
6
|
+
...mapState('admin/layout', ['menuSiderReload', 'menuHeaderReload'])
|
|
7
|
+
},
|
|
8
|
+
methods: {
|
|
9
|
+
handleClick(path, type = 'sider') {
|
|
10
|
+
const current = this.$route.path;
|
|
11
|
+
if (current === path) {
|
|
12
|
+
if (type === 'sider' && this.menuSiderReload) this.handleReload();
|
|
13
|
+
else if (type === 'header' && this.menuHeaderReload) this.handleReload();
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
handleReload() {
|
|
17
|
+
const $layout = findComponentUpward(this, 'BasicLayout');
|
|
18
|
+
if ($layout) $layout.handleReload();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
};
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { mapState } from 'vuex';
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
computed: {
|
|
5
|
-
...mapState('admin/menu', ['siderMenuBadge']),
|
|
6
|
-
badgeData() {
|
|
7
|
-
let data = null;
|
|
8
|
-
const siderMenuBadge = this.siderMenuBadge.find(item => item.path === this.menu.path);
|
|
9
|
-
if (siderMenuBadge) data = siderMenuBadge;
|
|
10
|
-
return data;
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
};
|
|
1
|
+
import { mapState } from 'vuex';
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
computed: {
|
|
5
|
+
...mapState('admin/menu', ['siderMenuBadge']),
|
|
6
|
+
badgeData() {
|
|
7
|
+
let data = null;
|
|
8
|
+
const siderMenuBadge = this.siderMenuBadge.find(item => item.path === this.menu.path);
|
|
9
|
+
if (siderMenuBadge) data = siderMenuBadge;
|
|
10
|
+
return data;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
};
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
export default {
|
|
2
|
-
methods: {
|
|
3
|
-
tTitle(title) {
|
|
4
|
-
if (title && title.indexOf('$t:') === 0) {
|
|
5
|
-
return this.$t(title.split('$t:')[1]);
|
|
6
|
-
} else {
|
|
7
|
-
return title;
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
};
|
|
1
|
+
export default {
|
|
2
|
+
methods: {
|
|
3
|
+
tTitle(title) {
|
|
4
|
+
if (title && title.indexOf('$t:') === 0) {
|
|
5
|
+
return this.$t(title.split('$t:')[1]);
|
|
6
|
+
} else {
|
|
7
|
+
return title;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
};
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div :style="styles" v-if="waterMark.show"></div>
|
|
3
|
-
</template>
|
|
4
|
-
<script>
|
|
5
|
-
import { mapState } from 'vuex';
|
|
6
|
-
import getWaterMarkCanvas from '../../../libs/water-mark';
|
|
7
|
-
|
|
8
|
-
export default {
|
|
9
|
-
name: 'i-water-mark',
|
|
10
|
-
computed: {
|
|
11
|
-
...mapState('admin/layout', ['waterMark']),
|
|
12
|
-
styles() {
|
|
13
|
-
const url = getWaterMarkCanvas(this.waterMark.text, this.waterMark.options);
|
|
14
|
-
return {
|
|
15
|
-
width: '100%',
|
|
16
|
-
height: '100%',
|
|
17
|
-
position: 'absolute',
|
|
18
|
-
top: '0',
|
|
19
|
-
left: '0',
|
|
20
|
-
'z-index': '2000',
|
|
21
|
-
'background-size': '320px',
|
|
22
|
-
'background-repeat': 'repeat',
|
|
23
|
-
'background-image': `url(${url})`,
|
|
24
|
-
'pointer-events': 'none'
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
};
|
|
29
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<div :style="styles" v-if="waterMark.show"></div>
|
|
3
|
+
</template>
|
|
4
|
+
<script>
|
|
5
|
+
import { mapState } from 'vuex';
|
|
6
|
+
import getWaterMarkCanvas from '../../../libs/water-mark';
|
|
7
|
+
|
|
8
|
+
export default {
|
|
9
|
+
name: 'i-water-mark',
|
|
10
|
+
computed: {
|
|
11
|
+
...mapState('admin/layout', ['waterMark']),
|
|
12
|
+
styles() {
|
|
13
|
+
const url = getWaterMarkCanvas(this.waterMark.text, this.waterMark.options);
|
|
14
|
+
return {
|
|
15
|
+
width: '100%',
|
|
16
|
+
height: '100%',
|
|
17
|
+
position: 'absolute',
|
|
18
|
+
top: '0',
|
|
19
|
+
left: '0',
|
|
20
|
+
'z-index': '2000',
|
|
21
|
+
'background-size': '320px',
|
|
22
|
+
'background-repeat': 'repeat',
|
|
23
|
+
'background-image': `url(${url})`,
|
|
24
|
+
'pointer-events': 'none'
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
</script>
|
package/src/libs/random_str.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
// 生成随机字符串
|
|
2
|
-
export default function (len = 32) {
|
|
3
|
-
const $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890';
|
|
4
|
-
const maxPos = $chars.length;
|
|
5
|
-
let str = '';
|
|
6
|
-
for (let i = 0; i < len; i++) {
|
|
7
|
-
str += $chars.charAt(Math.floor(Math.random() * maxPos));
|
|
8
|
-
}
|
|
9
|
-
return str;
|
|
10
|
-
}
|
|
1
|
+
// 生成随机字符串
|
|
2
|
+
export default function (len = 32) {
|
|
3
|
+
const $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890';
|
|
4
|
+
const maxPos = $chars.length;
|
|
5
|
+
let str = '';
|
|
6
|
+
for (let i = 0; i < len; i++) {
|
|
7
|
+
str += $chars.charAt(Math.floor(Math.random() * maxPos));
|
|
8
|
+
}
|
|
9
|
+
return str;
|
|
10
|
+
}
|
package/src/libs/water-mark.js
CHANGED
|
@@ -1,44 +1,44 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @description 生成水印
|
|
3
|
-
* */
|
|
4
|
-
export default function getWaterMarkCanvas(text, options) {
|
|
5
|
-
const canvas = document.createElement('canvas');
|
|
6
|
-
const ctx = canvas.getContext('2d');
|
|
7
|
-
const canvasWidth = 400;
|
|
8
|
-
const canvasHeight = 400;
|
|
9
|
-
canvas.width = canvasWidth;
|
|
10
|
-
canvas.height = canvasHeight;
|
|
11
|
-
ctx.textAlign = 'center';
|
|
12
|
-
ctx.textBaseline = 'bottom';
|
|
13
|
-
ctx.globalAlpha = options.globalAlpha || 0.1;
|
|
14
|
-
ctx.font = options.font || '20px Microsoft Yahei';
|
|
15
|
-
|
|
16
|
-
ctx.translate(canvasWidth / 2, canvasHeight / 2);
|
|
17
|
-
ctx.rotate(options.rotateAngle || -0.4);
|
|
18
|
-
|
|
19
|
-
ctx.translate((-canvasWidth / 2) * 1.2, (-canvasHeight / 2) * 1.2);
|
|
20
|
-
|
|
21
|
-
const waterMarkText = [];
|
|
22
|
-
const chunkWidth = options.chunkWidth || 400;
|
|
23
|
-
const chunkHeight = options.chunkHeight || 120;
|
|
24
|
-
const horizontalChunkCount = 0;
|
|
25
|
-
const verticalChunkCount = 1;
|
|
26
|
-
|
|
27
|
-
for (let j = 0, initY = chunkHeight / 2, indent = 0; j <= verticalChunkCount; j += 1) {
|
|
28
|
-
indent = parseInt(j % 2);
|
|
29
|
-
|
|
30
|
-
for (let i = 0, initX = chunkWidth / 2; i <= horizontalChunkCount; i += 1) {
|
|
31
|
-
waterMarkText.push({
|
|
32
|
-
text,
|
|
33
|
-
x: i * chunkWidth + indent * initX,
|
|
34
|
-
y: j * chunkHeight + initY
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
waterMarkText.forEach(item => {
|
|
40
|
-
ctx.fillText(item.text, item.x, item.y);
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
return ctx.canvas.toDataURL();
|
|
44
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* @description 生成水印
|
|
3
|
+
* */
|
|
4
|
+
export default function getWaterMarkCanvas(text, options) {
|
|
5
|
+
const canvas = document.createElement('canvas');
|
|
6
|
+
const ctx = canvas.getContext('2d');
|
|
7
|
+
const canvasWidth = 400;
|
|
8
|
+
const canvasHeight = 400;
|
|
9
|
+
canvas.width = canvasWidth;
|
|
10
|
+
canvas.height = canvasHeight;
|
|
11
|
+
ctx.textAlign = 'center';
|
|
12
|
+
ctx.textBaseline = 'bottom';
|
|
13
|
+
ctx.globalAlpha = options.globalAlpha || 0.1;
|
|
14
|
+
ctx.font = options.font || '20px Microsoft Yahei';
|
|
15
|
+
|
|
16
|
+
ctx.translate(canvasWidth / 2, canvasHeight / 2);
|
|
17
|
+
ctx.rotate(options.rotateAngle || -0.4);
|
|
18
|
+
|
|
19
|
+
ctx.translate((-canvasWidth / 2) * 1.2, (-canvasHeight / 2) * 1.2);
|
|
20
|
+
|
|
21
|
+
const waterMarkText = [];
|
|
22
|
+
const chunkWidth = options.chunkWidth || 400;
|
|
23
|
+
const chunkHeight = options.chunkHeight || 120;
|
|
24
|
+
const horizontalChunkCount = 0;
|
|
25
|
+
const verticalChunkCount = 1;
|
|
26
|
+
|
|
27
|
+
for (let j = 0, initY = chunkHeight / 2, indent = 0; j <= verticalChunkCount; j += 1) {
|
|
28
|
+
indent = parseInt(j % 2);
|
|
29
|
+
|
|
30
|
+
for (let i = 0, initX = chunkWidth / 2; i <= horizontalChunkCount; i += 1) {
|
|
31
|
+
waterMarkText.push({
|
|
32
|
+
text,
|
|
33
|
+
x: i * chunkWidth + indent * initX,
|
|
34
|
+
y: j * chunkHeight + initY
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
waterMarkText.forEach(item => {
|
|
40
|
+
ctx.fillText(item.text, item.x, item.y);
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
return ctx.canvas.toDataURL();
|
|
44
|
+
}
|
package/src/setting.js
CHANGED
|
@@ -31,20 +31,7 @@ const Setting = {
|
|
|
31
31
|
// 是否根据用户电脑配置自动设置语言(仅第一次有效)
|
|
32
32
|
auto: false,
|
|
33
33
|
// 切换语言时是否刷新页面
|
|
34
|
-
refresh: false
|
|
35
|
-
// 支持的语言列表
|
|
36
|
-
list: [
|
|
37
|
-
{
|
|
38
|
-
locale: 'zh-CN',
|
|
39
|
-
language: '简体中文'
|
|
40
|
-
},
|
|
41
|
-
{
|
|
42
|
-
locale: 'en-US',
|
|
43
|
-
language: 'English'
|
|
44
|
-
}
|
|
45
|
-
],
|
|
46
|
-
// 是否通过远程接口来获取 i81n 文件
|
|
47
|
-
remote: false
|
|
34
|
+
refresh: false
|
|
48
35
|
},
|
|
49
36
|
/**
|
|
50
37
|
* 打印控件
|
|
@@ -67,12 +67,11 @@ export default {
|
|
|
67
67
|
if (confirm) {
|
|
68
68
|
swal
|
|
69
69
|
.fire({
|
|
70
|
-
title: '
|
|
70
|
+
title: window.$t('Front_Msg_Sure_To_Logout'),
|
|
71
71
|
icon: 'question',
|
|
72
72
|
showCancelButton: true,
|
|
73
|
-
confirmButtonText: '
|
|
74
|
-
|
|
75
|
-
cancelButtonText: '取消 Cancel'
|
|
73
|
+
confirmButtonText: window.$t('Front_Btn_OK'),
|
|
74
|
+
cancelButtonText: window.$t('Front_Btn_Cancel')
|
|
76
75
|
})
|
|
77
76
|
.then(result => {
|
|
78
77
|
if (result.value) {
|
|
@@ -51,8 +51,6 @@ export default {
|
|
|
51
51
|
* @param {Object} state vuex state
|
|
52
52
|
*/
|
|
53
53
|
async load({ state }) {
|
|
54
|
-
let locale;
|
|
55
|
-
|
|
56
54
|
const db = util.db.get(
|
|
57
55
|
pathInit({
|
|
58
56
|
dbName: 'database',
|
|
@@ -62,33 +60,9 @@ export default {
|
|
|
62
60
|
})
|
|
63
61
|
);
|
|
64
62
|
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
// 先判断本地存储是否已有语言选择
|
|
68
|
-
if (savedLocale) {
|
|
69
|
-
locale = savedLocale;
|
|
70
|
-
} else {
|
|
71
|
-
// 判断是否开启自动识别语言
|
|
72
|
-
if (Setting.i18n.auto) {
|
|
73
|
-
// 如果自动识别的语言,本地没有该语言包,则设置为默认语言
|
|
74
|
-
const navLang = navigator.language;
|
|
75
|
-
if (state.languages[navLang]) {
|
|
76
|
-
locale = navLang;
|
|
77
|
-
} else {
|
|
78
|
-
locale = Setting.i18n.default;
|
|
79
|
-
}
|
|
80
|
-
} else {
|
|
81
|
-
locale = Setting.i18n.default;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
// 将初次的语言保存在本地
|
|
85
|
-
db.set(savedLocaleKey, locale).write();
|
|
86
|
-
}
|
|
87
|
-
state.locale = locale;
|
|
88
|
-
i18n.locale = locale;
|
|
63
|
+
state.locale = db.get(savedLocaleKey).value();
|
|
89
64
|
|
|
90
65
|
// 导入 View UI Plus 语言包
|
|
91
|
-
//const ViewUIPlusLocale = require.context('view-ui-plus/dist/locale', false, /.+-.+.js$/);
|
|
92
66
|
const ViewUIPlusLocale = import.meta.globEager('../../../../i18n/locale/*-*.js');
|
|
93
67
|
|
|
94
68
|
let res = await i18nTextApi.getAll();
|
|
@@ -100,26 +74,11 @@ export default {
|
|
|
100
74
|
|
|
101
75
|
if (currentLocale.i.locale === lanCode) {
|
|
102
76
|
res[lanCode]['text'].i = currentLocale.i;
|
|
103
|
-
// console.log('currentLocale', currentLocale);
|
|
104
|
-
|
|
105
|
-
// Object.keys(currentLocale.i).forEach(key => {
|
|
106
|
-
// console.log('key', key, currentLocale.i[key]);
|
|
107
|
-
// res[lanCode]['text'][key] = currentLocale.i[key];
|
|
108
|
-
// });
|
|
109
77
|
}
|
|
110
78
|
});
|
|
111
79
|
|
|
112
|
-
// if (currentLocale.i.locale === lanCode) {
|
|
113
|
-
// Object.keys(currentLocale).forEach(key => {
|
|
114
|
-
// res[lanCode]['text'][key] = currentLocale[key];
|
|
115
|
-
// });
|
|
116
|
-
// }
|
|
117
|
-
|
|
118
|
-
//languages[lanCode] = res[lanCode]['text'];
|
|
119
80
|
state.languages[lanCode] = res[lanCode].name;
|
|
120
81
|
|
|
121
|
-
//console.log('languages', lanCode, res[lanCode]['text']);
|
|
122
|
-
|
|
123
82
|
i18n.global.setLocaleMessage(lanCode, res[lanCode]['text']);
|
|
124
83
|
}
|
|
125
84
|
}
|
package/src/styles/common.less
CHANGED
|
@@ -1,47 +1,47 @@
|
|
|
1
|
-
#app, body, html{
|
|
2
|
-
height: 100%;
|
|
3
|
-
}
|
|
4
|
-
body{
|
|
5
|
-
background-color: @background-color-base;
|
|
6
|
-
font-size: 14px;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
// 隐藏滚动条样式
|
|
10
|
-
.i-scrollbar-hide{
|
|
11
|
-
&::-webkit-scrollbar{
|
|
12
|
-
width: 0;
|
|
13
|
-
}
|
|
14
|
-
&::-webkit-scrollbar-track{
|
|
15
|
-
background-color: transparent;
|
|
16
|
-
}
|
|
17
|
-
&::-webkit-scrollbar-thumb{
|
|
18
|
-
background: #e8eaec;
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
// 极简滚动条样式
|
|
23
|
-
.i-scrollbar{
|
|
24
|
-
&::-webkit-scrollbar{
|
|
25
|
-
width: 6px;
|
|
26
|
-
}
|
|
27
|
-
&::-webkit-scrollbar-track{
|
|
28
|
-
background-color: transparent;
|
|
29
|
-
}
|
|
30
|
-
&::-webkit-scrollbar-thumb{
|
|
31
|
-
background: #808695;
|
|
32
|
-
border-radius: 4px;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
// 去除 Table 的左右边框,更精简
|
|
37
|
-
.i-table-no-border{
|
|
38
|
-
.ivu-table th{
|
|
39
|
-
background-color: #fff;
|
|
40
|
-
}
|
|
41
|
-
.ivu-table-wrapper, .ivu-table tr:last-child td{
|
|
42
|
-
border: none;
|
|
43
|
-
}
|
|
44
|
-
.ivu-table:before, .ivu-table:after{
|
|
45
|
-
display: none;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
1
|
+
#app, body, html{
|
|
2
|
+
height: 100%;
|
|
3
|
+
}
|
|
4
|
+
body{
|
|
5
|
+
background-color: @background-color-base;
|
|
6
|
+
font-size: 14px;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
// 隐藏滚动条样式
|
|
10
|
+
.i-scrollbar-hide{
|
|
11
|
+
&::-webkit-scrollbar{
|
|
12
|
+
width: 0;
|
|
13
|
+
}
|
|
14
|
+
&::-webkit-scrollbar-track{
|
|
15
|
+
background-color: transparent;
|
|
16
|
+
}
|
|
17
|
+
&::-webkit-scrollbar-thumb{
|
|
18
|
+
background: #e8eaec;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
// 极简滚动条样式
|
|
23
|
+
.i-scrollbar{
|
|
24
|
+
&::-webkit-scrollbar{
|
|
25
|
+
width: 6px;
|
|
26
|
+
}
|
|
27
|
+
&::-webkit-scrollbar-track{
|
|
28
|
+
background-color: transparent;
|
|
29
|
+
}
|
|
30
|
+
&::-webkit-scrollbar-thumb{
|
|
31
|
+
background: #808695;
|
|
32
|
+
border-radius: 4px;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// 去除 Table 的左右边框,更精简
|
|
37
|
+
.i-table-no-border{
|
|
38
|
+
.ivu-table th{
|
|
39
|
+
background-color: #fff;
|
|
40
|
+
}
|
|
41
|
+
.ivu-table-wrapper, .ivu-table tr:last-child td{
|
|
42
|
+
border: none;
|
|
43
|
+
}
|
|
44
|
+
.ivu-table:before, .ivu-table:after{
|
|
45
|
+
display: none;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
// 自定义主题
|
|
2
|
-
// 详见 https://www.iviewui.com/docs/guide/theme
|
|
3
|
-
@import 'view-ui-plus/src/styles/index.less';
|
|
4
|
-
|
|
5
|
-
@menu-dark-title: #191a23;
|
|
6
|
-
@menu-dark-active-bg: #101117;
|
|
1
|
+
// 自定义主题
|
|
2
|
+
// 详见 https://www.iviewui.com/docs/guide/theme
|
|
3
|
+
@import 'view-ui-plus/src/styles/index.less';
|
|
4
|
+
|
|
5
|
+
@menu-dark-title: #191a23;
|
|
6
|
+
@menu-dark-active-bg: #101117;
|