123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312 |
- import { isArray } from '@/utils/is'
- import { FieldNamesProps } from '@/components/ProTable/interface'
- const mode = import.meta.env.VITE_ROUTER_MODE
- /**
- * @description 获取localStorage
- * @param {String} key Storage名称
- * @returns {String}
- */
- export function localGet(key: string) {
- const value = window.localStorage.getItem(key)
- try {
- return JSON.parse(window.localStorage.getItem(key) as string)
- } catch (error) {
- return value
- }
- }
- /**
- * @description 存储localStorage
- * @param {String} key Storage名称
- * @param {*} value Storage值
- * @returns {void}
- */
- export function localSet(key: string, value: any) {
- window.localStorage.setItem(key, JSON.stringify(value))
- }
- /**
- * @description 清除localStorage
- * @param {String} key Storage名称
- * @returns {void}
- */
- export function localRemove(key: string) {
- window.localStorage.removeItem(key)
- }
- /**
- * @description 清除所有localStorage
- * @returns {void}
- */
- export function localClear() {
- window.localStorage.clear()
- }
- /**
- * @description 判断数据类型
- * @param {*} val 需要判断类型的数据
- * @returns {String}
- */
- export function isType(val: any) {
- if (val === null) return 'null'
- if (typeof val !== 'object') return typeof val
- else return Object.prototype.toString.call(val).slice(8, -1).toLocaleLowerCase()
- }
- /**
- * @description 生成唯一 uuid
- * @returns {String}
- */
- export function generateUUID() {
- let uuid = ''
- for (let i = 0; i < 32; i++) {
- let random = (Math.random() * 16) | 0
- if (i === 8 || i === 12 || i === 16 || i === 20) uuid += '-'
- uuid += (i === 12 ? 4 : i === 16 ? (random & 3) | 8 : random).toString(16)
- }
- return uuid
- }
- /**
- * 判断两个对象是否相同
- * @param {Object} a 要比较的对象一
- * @param {Object} b 要比较的对象二
- * @returns {Boolean} 相同返回 true,反之 false
- */
- export function isObjectValueEqual(a: { [key: string]: any }, b: { [key: string]: any }) {
- if (!a || !b) return false
- let aProps = Object.getOwnPropertyNames(a)
- let bProps = Object.getOwnPropertyNames(b)
- if (aProps.length != bProps.length) return false
- for (let i = 0; i < aProps.length; i++) {
- let propName = aProps[i]
- let propA = a[propName]
- let propB = b[propName]
- if (!b.hasOwnProperty(propName)) return false
- if (propA instanceof Object) {
- if (!isObjectValueEqual(propA, propB)) return false
- } else if (propA !== propB) {
- return false
- }
- }
- return true
- }
- /**
- * @description 生成随机数
- * @param {Number} min 最小值
- * @param {Number} max 最大值
- * @returns {Number}
- */
- export function randomNum(min: number, max: number): number {
- let num = Math.floor(Math.random() * (min - max) + max)
- return num
- }
- /**
- * @description 获取当前时间对应的提示语
- * @returns {String}
- */
- export function getTimeState() {
- let timeNow = new Date()
- let hours = timeNow.getHours()
- if (hours >= 6 && hours <= 10) return `早上好 ⛅`
- if (hours >= 10 && hours <= 14) return `中午好 🌞`
- if (hours >= 14 && hours <= 18) return `下午好 🌞`
- if (hours >= 18 && hours <= 24) return `晚上好 🌛`
- if (hours >= 0 && hours <= 6) return `凌晨好 🌛`
- }
- /**
- * @description 获取浏览器默认语言
- * @returns {String}
- */
- export function getBrowserLang() {
- let browserLang = navigator.language ? navigator.language : navigator.browserLanguage
- let defaultBrowserLang = ''
- if (['cn', 'zh', 'zh-cn'].includes(browserLang.toLowerCase())) {
- defaultBrowserLang = 'zh'
- } else {
- defaultBrowserLang = 'en'
- }
- return defaultBrowserLang
- }
- /**
- * @description 获取不同路由模式所对应的 url + params
- * @returns {String}
- */
- export function getUrlWithParams() {
- const url = {
- hash: location.hash.substring(1),
- history: location.pathname + location.search
- }
- return url[mode]
- }
- /**
- * @description 使用递归扁平化菜单,方便添加动态路由
- * @param {Array} menuList 菜单列表
- * @returns {Array}
- */
- export function getFlatMenuList(menuList: Menu.MenuOptions[]): Menu.MenuOptions[] {
- let newMenuList: Menu.MenuOptions[] = JSON.parse(JSON.stringify(menuList))
- return newMenuList.flatMap(item => [item, ...(item.children ? getFlatMenuList(item.children) : [])])
- }
- /**
- * @description 使用递归过滤出需要渲染在左侧菜单的列表 (需剔除 hidden == true 的菜单)
- * @param {Array} menuList 菜单列表
- * @returns {Array}
- * */
- export function getShowMenuList(menuList: Menu.MenuOptions[]) {
- let newMenuList: Menu.MenuOptions[] = JSON.parse(JSON.stringify(menuList))
- return newMenuList.filter(item => {
- item.children?.length && (item.children = getShowMenuList(item.children))
- return !item.hidden
- })
- }
- /**
- * @description 使用递归找出所有面包屑存储到 pinia/vuex 中
- * @param {Array} menuList 菜单列表
- * @param {Array} parent 父级菜单
- * @param {Object} result 处理后的结果
- * @returns {Object}
- */
- export const getAllBreadcrumbList = (menuList: Menu.MenuOptions[], parent = [], result: { [key: string]: any } = {}) => {
- for (const item of menuList) {
- result[item.path] = [...parent, item]
- if (item.children) getAllBreadcrumbList(item.children, result[item.path], result)
- }
- return result
- }
- /**
- * @description 使用递归处理路由菜单 path,生成一维数组 (第一版本地路由鉴权会用到,该函数暂未使用)
- * @param {Array} menuList 所有菜单列表
- * @param {Array} menuPathArr 菜单地址的一维数组 ['**','**']
- * @returns {Array}
- */
- export function getMenuListPath(menuList: Menu.MenuOptions[], menuPathArr: string[] = []): string[] {
- for (const item of menuList) {
- if (typeof item === 'object' && item.path) menuPathArr.push(item.path)
- if (item.children?.length) getMenuListPath(item.children, menuPathArr)
- }
- return menuPathArr
- }
- /**
- * @description 递归查询当前 path 所对应的菜单对象 (该函数暂未使用)
- * @param {Array} menuList 菜单列表
- * @param {String} path 当前访问地址
- * @returns {Object | null}
- */
- export function findMenuByPath(menuList: Menu.MenuOptions[], path: string): Menu.MenuOptions | null {
- for (const item of menuList) {
- if (item.path === path) return item
- if (item.children) {
- const res = findMenuByPath(item.children, path)
- if (res) return res
- }
- }
- return null
- }
- /**
- * @description 使用递归过滤需要缓存的菜单 name (该函数暂未使用)
- * @param {Array} menuList 所有菜单列表
- * @param {Array} keepAliveNameArr 缓存的菜单 name ['**','**']
- * @returns {Array}
- * */
- export function getKeepAliveRouterName(menuList: Menu.MenuOptions[], keepAliveNameArr: string[] = []) {
- menuList.forEach(item => {
- item.meta.noCache && item.name && keepAliveNameArr.push(item.name)
- item.children?.length && getKeepAliveRouterName(item.children, keepAliveNameArr)
- })
- return keepAliveNameArr
- }
- /**
- * @description 格式化表格单元格默认值 (el-table-column)
- * @param {Number} row 行
- * @param {Number} col 列
- * @param {*} callValue 当前单元格值
- * @returns {String}
- * */
- export function formatTableColumn(row: number, col: number, callValue: any) {
- // 如果当前值为数组,使用 / 拼接(根据需求自定义)
- if (isArray(callValue)) return callValue.length ? callValue.join(' / ') : '--'
- return callValue ?? '--'
- }
- /**
- * @description 处理 ProTable 值为数组 || 无数据
- * @param {*} callValue 需要处理的值
- * @returns {String}
- * */
- export function formatValue(callValue: any) {
- // 如果当前值为数组,使用 / 拼接(根据需求自定义)
- if (isArray(callValue)) return callValue.length ? callValue.join(' / ') : '--'
- return callValue ?? '--'
- }
- /**
- * @description 处理 prop 为多级嵌套的情况,返回的数据 (列如: prop: user.name)
- * @param {Object} row 当前行数据
- * @param {String} prop 当前 prop
- * @returns {*}
- * */
- export function handleRowAccordingToProp(row: { [key: string]: any }, prop: string) {
- if (!prop.includes('.')) return row[prop] ?? '--'
- prop.split('.').forEach(item => (row = row[item] ?? '--'))
- return row
- }
- /**
- * @description 处理 prop,当 prop 为多级嵌套时 ==> 返回最后一级 prop
- * @param {String} prop 当前 prop
- * @returns {String}
- * */
- export function handleProp(prop: string) {
- const propArr = prop.split('.')
- if (propArr.length == 1) return prop
- return propArr[propArr.length - 1]
- }
- /**
- * @description 根据枚举列表查询当需要的数据(如果指定了 label 和 value 的 key值,会自动识别格式化)
- * @param {String} callValue 当前单元格值
- * @param {Array} enumData 字典列表
- * @param {Array} fieldNames label && value && children 的 key 值
- * @param {String} type 过滤类型(目前只有 tag)
- * @returns {String}
- * */
- export function filterEnum(callValue: any, enumData?: any, fieldNames?: FieldNamesProps, type?: 'tag') {
- const value = fieldNames?.value ?? 'value'
- const label = fieldNames?.label ?? 'label'
- const children = fieldNames?.children ?? 'children'
- let filterData: { [key: string]: any } = {}
- // 判断 enumData 是否为数组
- if (Array.isArray(enumData)) filterData = findItemNested(enumData, callValue, value, children)
- // 判断是否输出的结果为 tag 类型
- if (type == 'tag') {
- return filterData?.listClass ? filterData.listClass : 'primary'
- } else {
- return filterData ? filterData[label] : '--'
- }
- }
- /**
- * @description 递归查找 callValue 对应的 enum 值
- * */
- export function findItemNested(enumData: any, callValue: any, value: string, children: string) {
- return enumData.reduce((accumulator: any, current: any) => {
- if (accumulator) return accumulator
- if (current[value] === callValue) return current
- if (current[children]) return findItemNested(current[children], callValue, value, children)
- }, null)
- }
|