2024-07-17 17:32:31 +08:00
|
|
|
// enums are compiled away via custom transform so no real dependency here
|
2024-05-30 19:09:04 +08:00
|
|
|
import { ReactiveFlags } from '@vue/reactivity'
|
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
|
|
|
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
|
|
|
|
2024-06-23 09:34:52 +08:00
|
|
|
// can't use isRef here since @vue/shared has no deps
|
|
|
|
const isRef = (val: any): val is { value: unknown } => {
|
2024-07-17 17:32:31 +08:00
|
|
|
return !!(val && val[ReactiveFlags.IS_REF] === true)
|
2024-06-23 09:34:52 +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 => {
|
2025-02-09 12:25:11 +08:00
|
|
|
switch (typeof val) {
|
|
|
|
case 'string':
|
|
|
|
return val
|
|
|
|
case 'object':
|
|
|
|
if (val) {
|
|
|
|
if (isRef(val)) {
|
|
|
|
return toDisplayString(val.value)
|
|
|
|
} else if (
|
|
|
|
isArray(val) ||
|
|
|
|
val.toString === objectToString ||
|
|
|
|
!isFunction(val.toString)
|
|
|
|
) {
|
|
|
|
return JSON.stringify(val, replacer, 2)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
return val == null ? '' : String(val)
|
|
|
|
}
|
2020-05-04 22:38:03 +08:00
|
|
|
}
|
|
|
|
|
2024-06-23 09:34:52 +08:00
|
|
|
const replacer = (_key: string, val: unknown): any => {
|
|
|
|
if (isRef(val)) {
|
2021-07-28 06:34:15 +08:00
|
|
|
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
|