import { unref } from 'vue' import { isObject } from '@/utils/is' // dynamic use hook props export const getDynamicProps = (props: T): Partial => { const ret: Recordable = {} Object.keys(props).map((key) => { ret[key] = unref((props as Recordable)[key]) }) return ret as Partial } export const openWindow = ( url: string, opt?: { target?: '_self' | '_blank' | string noopener?: boolean noreferrer?: boolean } ) => { const { target = '__blank', noopener = true, noreferrer = true } = opt || {} const feature: string[] = [] noopener && feature.push('noopener=yes') noreferrer && feature.push('noreferrer=yes') window.open(url, target, feature.join(',')) } /** * Add the object as a parameter to the URL * @param baseUrl url * @param obj * @returns {string} * eg: * let obj = {a: '3', b: '4'} * setObjToUrlParams('www.baidu.com', obj) * ==>www.baidu.com?a=3&b=4 */ export const setObjToUrlParams = (baseUrl: string, obj: any): string => { let parameters = '' for (const key in obj) { parameters += key + '=' + encodeURIComponent(obj[key]) + '&' } parameters = parameters.replace(/&$/, '') return /\?$/.test(baseUrl) ? baseUrl + parameters : baseUrl.replace(/\/?$/, '?') + parameters } /** * @description: Set ui mount node */ export const getPopupContainer = (node?: HTMLElement): HTMLElement => { return (node?.parentNode as HTMLElement) ?? document.body } export function deepMerge(src: any = {}, target: any = {}): T { let key: string for (key in target) { src[key] = isObject(src[key]) ? deepMerge(src[key], target[key]) : (src[key] = target[key]) } return src }