2021-07-29 22:51:03 +08:00
|
|
|
import {
|
|
|
|
isArray,
|
|
|
|
isMap,
|
|
|
|
isObject,
|
2021-08-17 03:28:34 +08:00
|
|
|
isFunction,
|
2021-07-29 22:51:03 +08:00
|
|
|
isPlainObject,
|
|
|
|
isSet,
|
2022-01-30 18:50:28 +08:00
|
|
|
objectToString,
|
2023-12-07 10:33:48 +08:00
|
|
|
isString,
|
|
|
|
isSymbol
|
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 10:40:27 +08:00
|
|
|
entries[stringiySymbol(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 10:40:27 +08:00
|
|
|
[`Set(${val.size})`]: [...val.values()].map(v => stringiySymbol(v))
|
2020-05-04 22:38:03 +08:00
|
|
|
}
|
2023-12-07 10:40:27 +08:00
|
|
|
} else if (isSymbol(val)) {
|
|
|
|
return stringiySymbol(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
|
|
|
|
|
|
|
const stringiySymbol = (v: unknown, i: number | string = ''): any =>
|
|
|
|
isSymbol(v) ? `Symbol(${v.description ?? i})` : v
|