2019-04-14 16:20:04 +08:00
|
|
|
|
import { isURL } from '@/utils/validate'
|
2019-02-25 15:58:05 +08:00
|
|
|
|
|
|
|
|
|
export function timeFix() {
|
|
|
|
|
const time = new Date()
|
|
|
|
|
const hour = time.getHours()
|
|
|
|
|
return hour < 9 ? '早上好' : (hour <= 11 ? '上午好' : (hour <= 13 ? '中午好' : (hour < 20 ? '下午好' : '晚上好')))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function welcome() {
|
|
|
|
|
const arr = ['休息一会儿吧', '准备吃什么呢?', '要不要打一把 DOTA', '我猜你可能累了']
|
|
|
|
|
let index = Math.floor((Math.random()*arr.length))
|
|
|
|
|
return arr[index]
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 触发 window.resize
|
|
|
|
|
*/
|
|
|
|
|
export function triggerWindowResizeEvent() {
|
|
|
|
|
let event = document.createEvent('HTMLEvents')
|
|
|
|
|
event.initEvent('resize', true, true)
|
|
|
|
|
event.eventType = 'message'
|
|
|
|
|
window.dispatchEvent(event)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 过滤对象中为空的属性
|
|
|
|
|
* @param obj
|
|
|
|
|
* @returns {*}
|
|
|
|
|
*/
|
|
|
|
|
export function filterObj(obj) {
|
|
|
|
|
if (!(typeof obj == 'object')) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for ( var key in obj) {
|
|
|
|
|
if (obj.hasOwnProperty(key)
|
2019-04-14 16:20:04 +08:00
|
|
|
|
&& (obj[key] == null || obj[key] == undefined || obj[key] === '')) {
|
2019-02-25 15:58:05 +08:00
|
|
|
|
delete obj[key];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return obj;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 时间格式化
|
|
|
|
|
* @param value
|
|
|
|
|
* @param fmt
|
|
|
|
|
* @returns {*}
|
|
|
|
|
*/
|
|
|
|
|
export function formatDate(value, fmt) {
|
|
|
|
|
var regPos = /^\d+(\.\d+)?$/;
|
|
|
|
|
if(regPos.test(value)){
|
|
|
|
|
//如果是数字
|
|
|
|
|
let getDate = new Date(value);
|
|
|
|
|
let o = {
|
|
|
|
|
'M+': getDate.getMonth() + 1,
|
|
|
|
|
'd+': getDate.getDate(),
|
|
|
|
|
'h+': getDate.getHours(),
|
|
|
|
|
'm+': getDate.getMinutes(),
|
|
|
|
|
's+': getDate.getSeconds(),
|
|
|
|
|
'q+': Math.floor((getDate.getMonth() + 3) / 3),
|
|
|
|
|
'S': getDate.getMilliseconds()
|
|
|
|
|
};
|
|
|
|
|
if (/(y+)/.test(fmt)) {
|
|
|
|
|
fmt = fmt.replace(RegExp.$1, (getDate.getFullYear() + '').substr(4 - RegExp.$1.length))
|
|
|
|
|
}
|
|
|
|
|
for (let k in o) {
|
|
|
|
|
if (new RegExp('(' + k + ')').test(fmt)) {
|
|
|
|
|
fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length)))
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return fmt;
|
|
|
|
|
}else{
|
|
|
|
|
//TODO
|
|
|
|
|
value = value.trim();
|
|
|
|
|
return value.substr(0,fmt.length);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 生成首页路由
|
|
|
|
|
export function generateIndexRouter(data) {
|
|
|
|
|
let indexRouter = [{
|
|
|
|
|
path: '/',
|
|
|
|
|
name: 'dashboard',
|
|
|
|
|
//component: () => import('@/components/layouts/BasicLayout'),
|
|
|
|
|
component: resolve => require(['@/components/layouts/TabLayout'], resolve),
|
|
|
|
|
meta: { title: '首页' },
|
|
|
|
|
redirect: '/dashboard/analysis',
|
|
|
|
|
children: [
|
|
|
|
|
...generateChildRouters(data)
|
|
|
|
|
]
|
|
|
|
|
},{
|
|
|
|
|
"path": "*", "redirect": "/404", "hidden": true
|
|
|
|
|
}]
|
|
|
|
|
return indexRouter;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 生成嵌套路由(子路由)
|
|
|
|
|
|
|
|
|
|
function generateChildRouters (data) {
|
|
|
|
|
const routers = [];
|
|
|
|
|
for (var item of data) {
|
|
|
|
|
let component = "";
|
|
|
|
|
if(item.component.indexOf("layouts")>=0){
|
|
|
|
|
component = "components/"+item.component;
|
|
|
|
|
}else{
|
|
|
|
|
component = "views/"+item.component;
|
|
|
|
|
}
|
2019-04-14 16:20:04 +08:00
|
|
|
|
|
|
|
|
|
// eslint-disable-next-line
|
|
|
|
|
let URL = (item.meta.url|| '').replace(/{{([^}}]+)?}}/g, (s1, s2) => eval(s2)) // URL支持{{ window.xxx }}占位符变量
|
|
|
|
|
if (isURL(URL)) {
|
|
|
|
|
item.meta.url = URL;
|
|
|
|
|
}
|
|
|
|
|
|
2019-02-25 15:58:05 +08:00
|
|
|
|
let menu = {
|
|
|
|
|
path: item.path,
|
|
|
|
|
name: item.name,
|
|
|
|
|
redirect:item.redirect,
|
|
|
|
|
component: resolve => require(['@/' + component+'.vue'], resolve),
|
|
|
|
|
hidden:item.hidden,
|
|
|
|
|
//component:()=> import(`@/views/${item.component}.vue`),
|
|
|
|
|
meta: {
|
|
|
|
|
title:item.meta.title ,
|
|
|
|
|
icon: item.meta.icon,
|
|
|
|
|
url:item.meta.url ,
|
|
|
|
|
permissionList:item.meta.permissionList
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if(item.alwaysShow){
|
|
|
|
|
menu.alwaysShow = true;
|
|
|
|
|
}
|
|
|
|
|
if (item.children && item.children.length > 0) {
|
|
|
|
|
menu.children = [...generateChildRouters( item.children)];
|
|
|
|
|
}
|
2019-04-14 16:20:04 +08:00
|
|
|
|
//--update-begin----author:scott---date:20190320------for:根据后台菜单配置,判断是否路由菜单字段,动态选择是否生成路由(为了支持参数URL菜单)------
|
|
|
|
|
//判断是否生成路由
|
|
|
|
|
if(item.route && item.route === '0'){
|
2019-05-19 18:54:09 +08:00
|
|
|
|
//console.log(' 不生成路由 item.route: '+item.route);
|
|
|
|
|
//console.log(' 不生成路由 item.path: '+item.path);
|
2019-04-14 16:20:04 +08:00
|
|
|
|
}else{
|
|
|
|
|
routers.push(menu);
|
|
|
|
|
}
|
|
|
|
|
//--update-end----author:scott---date:20190320------for:根据后台菜单配置,判断是否路由菜单字段,动态选择是否生成路由(为了支持参数URL菜单)------
|
2019-02-25 15:58:05 +08:00
|
|
|
|
}
|
|
|
|
|
return routers
|
2019-04-14 16:20:04 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 深度克隆对象、数组
|
|
|
|
|
* @param obj 被克隆的对象
|
|
|
|
|
* @return 克隆后的对象
|
|
|
|
|
*/
|
|
|
|
|
export function cloneObject(obj) {
|
|
|
|
|
return JSON.parse(JSON.stringify(obj))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 随机生成数字
|
2019-05-19 18:54:09 +08:00
|
|
|
|
*
|
|
|
|
|
* 示例:生成长度为 12 的随机数:randomNumber(12)
|
|
|
|
|
* 示例:生成 3~23 之间的随机数:randomNumber(3, 23)
|
|
|
|
|
*
|
|
|
|
|
* @param1 最小值 | 长度
|
|
|
|
|
* @param2 最大值
|
2019-04-14 16:20:04 +08:00
|
|
|
|
* @return int 生成后的数字
|
|
|
|
|
*/
|
2019-05-19 18:54:09 +08:00
|
|
|
|
export function randomNumber() {
|
|
|
|
|
// 生成 最小值 到 最大值 区间的随机数
|
|
|
|
|
const random = (min, max) => {
|
|
|
|
|
return Math.floor(Math.random() * (max - min + 1) + min)
|
|
|
|
|
}
|
|
|
|
|
if (arguments.length === 1) {
|
|
|
|
|
let [length] = arguments
|
|
|
|
|
// 生成指定长度的随机数字,首位一定不是 0
|
|
|
|
|
let nums = [...Array(length).keys()].map((i) => (i > 0 ? random(0, 9) : random(1, 9)))
|
|
|
|
|
return parseInt(nums.join(''))
|
|
|
|
|
} else if (arguments.length >= 2) {
|
|
|
|
|
let [min, max] = arguments
|
|
|
|
|
return random(min, max)
|
|
|
|
|
} else {
|
|
|
|
|
return Number.NaN
|
|
|
|
|
}
|
2019-04-14 16:20:04 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 随机生成字符串
|
|
|
|
|
* @param length 字符串的长度
|
|
|
|
|
* @param chats 可选字符串区间(只会生成传入的字符串中的字符)
|
|
|
|
|
* @return string 生成的字符串
|
|
|
|
|
*/
|
|
|
|
|
export function randomString(length, chats) {
|
|
|
|
|
if (!length) length = 1
|
|
|
|
|
if (!chats) chats = '0123456789qwertyuioplkjhgfdsazxcvbnm'
|
|
|
|
|
let str = ''
|
|
|
|
|
for (let i = 0; i < length; i++) {
|
|
|
|
|
let num = randomNumber(0, chats.length - 1)
|
|
|
|
|
str += chats[num]
|
|
|
|
|
}
|
|
|
|
|
return str
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 随机生成uuid
|
|
|
|
|
* @return string 生成的uuid
|
|
|
|
|
*/
|
|
|
|
|
export function randomUUID() {
|
|
|
|
|
let chats = '0123456789abcdef'
|
|
|
|
|
return randomString(32, chats)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2019-05-19 18:54:09 +08:00
|
|
|
|
* 下划线转驼峰
|
|
|
|
|
* @param string
|
|
|
|
|
* @returns {*}
|
2019-04-14 16:20:04 +08:00
|
|
|
|
*/
|
2019-05-19 18:54:09 +08:00
|
|
|
|
export function underLine2CamelCase(string){
|
|
|
|
|
return string.replace( /_([a-z])/g, function( all, letter ) {
|
|
|
|
|
return letter.toUpperCase();
|
|
|
|
|
});
|
2019-02-25 15:58:05 +08:00
|
|
|
|
}
|