2022-10-21 08:44:44 -06:00
|
|
|
'use strict';
|
|
|
|
|
2024-01-17 02:08:10 -07:00
|
|
|
var identity = require('./identity.js');
|
2022-10-21 08:44:44 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Recursively convert any node or its contents to native JavaScript
|
|
|
|
*
|
|
|
|
* @param value - The input value
|
|
|
|
* @param arg - If `value` defines a `toJSON()` method, use this
|
|
|
|
* as its first argument
|
|
|
|
* @param ctx - Conversion context, originally set in Document#toJS(). If
|
|
|
|
* `{ keep: true }` is not set, output should be suitable for JSON
|
|
|
|
* stringification.
|
|
|
|
*/
|
|
|
|
function toJS(value, arg, ctx) {
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
|
|
if (Array.isArray(value))
|
|
|
|
return value.map((v, i) => toJS(v, String(i), ctx));
|
|
|
|
if (value && typeof value.toJSON === 'function') {
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
2024-01-17 02:08:10 -07:00
|
|
|
if (!ctx || !identity.hasAnchor(value))
|
2022-10-21 08:44:44 -06:00
|
|
|
return value.toJSON(arg, ctx);
|
|
|
|
const data = { aliasCount: 0, count: 1, res: undefined };
|
|
|
|
ctx.anchors.set(value, data);
|
|
|
|
ctx.onCreate = res => {
|
|
|
|
data.res = res;
|
|
|
|
delete ctx.onCreate;
|
|
|
|
};
|
|
|
|
const res = value.toJSON(arg, ctx);
|
|
|
|
if (ctx.onCreate)
|
|
|
|
ctx.onCreate(res);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
if (typeof value === 'bigint' && !ctx?.keep)
|
|
|
|
return Number(value);
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.toJS = toJS;
|