2021-07-29 22:51:03 +08:00
|
|
|
import {
|
|
|
|
isArray,
|
2021-08-17 03:28:34 +08:00
|
|
|
isFunction,
|
2021-07-29 22:51:03 +08:00
|
|
|
isMap,
|
|
|
|
isObject,
|
|
|
|
isPlainObject,
|
|
|
|
isSet,
|
2023-12-07 10:33:48 +08:00
|
|
|
isString,
|
|
|
|
isSymbol,
|
2022-01-30 18:50:28 +08:00
|
|
|
objectToString,
|
2023-03-23 16:30:42 +08:00
|
|
|
} from './general'
|
2020-05-04 22:38:03 +08:00
|
|
|
|
2020-07-14 05:36:46 +08:00
|
|
|
/**
|
|
|
|
* For converting {{ interpolation }} values to displayed strings.
|
|
|
|
* @private
|
|
|
|
*/
|
2020-05-04 22:38:03 +08:00
|
|
|
export const toDisplayString = (val: unknown): string => {
|
2022-01-30 18:50:28 +08:00
|
|
|
return isString(val)
|
|
|
|
? val
|
|
|
|
: val == null
|
2023-11-18 10:33:24 +08:00
|
|
|
? ''
|
|
|
|
: isArray(val) ||
|
|
|
|
(isObject(val) &&
|
|
|
|
(val.toString === objectToString || !isFunction(val.toString)))
|
|
|
|
? JSON.stringify(val, replacer, 2)
|
|
|
|
: String(val)
|
2020-05-04 22:38:03 +08:00
|
|
|
}
|
|
|
|
|
2021-07-28 06:34:15 +08:00
|
|
|
const replacer = (_key: string, val: any): any => {
|
|
|
|
// can't use isRef here since @vue/shared has no deps
|
|
|
|
if (val && val.__v_isRef) {
|
|
|
|
return replacer(_key, val.value)
|
|
|
|
} else if (isMap(val)) {
|
2020-05-04 22:38:03 +08:00
|
|
|
return {
|
2023-12-07 10:33:48 +08:00
|
|
|
[`Map(${val.size})`]: [...val.entries()].reduce(
|
|
|
|
(entries, [key, val], i) => {
|
2023-12-07 13:28:07 +08:00
|
|
|
entries[stringifySymbol(key, i) + ' =>'] = val
|
2023-12-07 10:33:48 +08:00
|
|
|
return entries
|
|
|
|
},
|
|
|
|
{} as Record<string, any>,
|
|
|
|
),
|
2020-05-04 22:38:03 +08:00
|
|
|
}
|
2020-09-14 23:26:34 +08:00
|
|
|
} else if (isSet(val)) {
|
2020-05-04 22:38:03 +08:00
|
|
|
return {
|
2023-12-07 13:28:07 +08:00
|
|
|
[`Set(${val.size})`]: [...val.values()].map(v => stringifySymbol(v)),
|
2020-05-04 22:38:03 +08:00
|
|
|
}
|
2023-12-07 10:40:27 +08:00
|
|
|
} else if (isSymbol(val)) {
|
2023-12-07 13:28:07 +08:00
|
|
|
return stringifySymbol(val)
|
2020-05-04 22:38:03 +08:00
|
|
|
} else if (isObject(val) && !isArray(val) && !isPlainObject(val)) {
|
2023-12-07 10:40:27 +08:00
|
|
|
// native elements
|
2020-05-04 22:38:03 +08:00
|
|
|
return String(val)
|
|
|
|
}
|
|
|
|
return val
|
|
|
|
}
|
2023-12-07 10:40:27 +08:00
|
|
|
|
2023-12-07 13:28:07 +08:00
|
|
|
const stringifySymbol = (v: unknown, i: number | string = ''): any =>
|
2024-04-15 15:52:48 +08:00
|
|
|
// Symbol.description in es2019+ so we need to cast here to pass
|
|
|
|
// the lib: es2016 check
|
|
|
|
isSymbol(v) ? `Symbol(${(v as any).description ?? i})` : v
|