@cristianmpx/react-import-sheet-headless 1.0.6 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +10 -18
- package/dist/edit.worker.js +1 -1
- package/dist/edit.worker.js.map +1 -1
- package/dist/index.js +50 -67
- package/dist/index.js.map +1 -1
- package/dist/parser.worker.js +1 -1
- package/dist/parser.worker.js.map +1 -1
- package/dist/sanitizer.worker.js +1 -1
- package/dist/sanitizer.worker.js.map +1 -1
- package/dist/transform.worker.js +1 -1
- package/dist/transform.worker.js.map +1 -1
- package/dist/validator.worker.js +1 -1
- package/dist/validator.worker.js.map +1 -1
- package/package.json +5 -9
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../node_modules/comlink/src/comlink.ts","../src/core/transform/runner/resolve-transform-ref.ts","../src/core/transform/runner/cell-transforms.ts","../src/core/transform/runner/row-transforms.ts","../src/core/transform/runner/sheet-transforms.ts","../src/core/transform/delta-applier.ts","../src/core/transform/runner/run-transform.ts","../src/shared/registry/Registry.ts","../src/utils/controller/string/cell-to-upper-transform.ts","../src/utils/controller/string/cell-string-tolower-transform.ts","../src/utils/controller/string/cell-string-slice-transform.ts","../src/utils/controller/string/cell-string-replace-transform.ts","../src/utils/controller/string/cell-string-replace-regex-transform.ts","../src/utils/controller/string/cell-string-fill-start-transform.ts","../src/utils/controller/string/cell-string-fill-end-transform.ts","../src/utils/controller/string/cell-string-extract-regex-transform.ts","../src/utils/controller/number/cell-number-add-transform.ts","../src/utils/controller/number/cell-number-multiply-transform.ts","../src/utils/controller/number/cell-number-divide-transform.ts","../src/utils/controller/number/cell-number-subtract-transform.ts","../src/utils/controller/number/cell-number-round-transform.ts","../src/utils/controller/number/cell-number-abs-transform.ts","../src/utils/controller/number/cell-number-sqrt-transform.ts","../src/utils/controller/number/cell-number-limit-transform.ts","../src/utils/controller/number/cell-number-percent-transform.ts","../src/utils/controller/date/cell-date-to-only-time-transform.ts","../src/utils/controller/date/cell-date-to-only-date-transform.ts","../src/utils/controller/date/cell-date-to-time-date-transform.ts","../src/utils/controller/date/cell-date-to-utc-transform.ts","../src/utils/controller/date/cell-date-limit-transform.ts","../src/utils/controller/date/cell-date-add-transform.ts","../src/utils/controller/date/cell-date-subtract-transform.ts","../src/core/transform/worker/worker-registry.ts","../src/core/transform/worker/transform.worker.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport {\n Endpoint,\n EventSource,\n Message,\n MessageType,\n PostMessageWithOrigin,\n WireValue,\n WireValueType,\n} from \"./protocol\";\nexport type { Endpoint };\n\nexport const proxyMarker = Symbol(\"Comlink.proxy\");\nexport const createEndpoint = Symbol(\"Comlink.endpoint\");\nexport const releaseProxy = Symbol(\"Comlink.releaseProxy\");\nexport const finalizer = Symbol(\"Comlink.finalizer\");\n\nconst throwMarker = Symbol(\"Comlink.thrown\");\n\n/**\n * Interface of values that were marked to be proxied with `comlink.proxy()`.\n * Can also be implemented by classes.\n */\nexport interface ProxyMarked {\n [proxyMarker]: true;\n}\n\n/**\n * Takes a type and wraps it in a Promise, if it not already is one.\n * This is to avoid `Promise<Promise<T>>`.\n *\n * This is the inverse of `Unpromisify<T>`.\n */\ntype Promisify<T> = T extends Promise<unknown> ? T : Promise<T>;\n/**\n * Takes a type that may be Promise and unwraps the Promise type.\n * If `P` is not a Promise, it returns `P`.\n *\n * This is the inverse of `Promisify<T>`.\n */\ntype Unpromisify<P> = P extends Promise<infer T> ? T : P;\n\n/**\n * Takes the raw type of a remote property and returns the type that is visible to the local thread on the proxy.\n *\n * Note: This needs to be its own type alias, otherwise it will not distribute over unions.\n * See https://www.typescriptlang.org/docs/handbook/advanced-types.html#distributive-conditional-types\n */\ntype RemoteProperty<T> =\n // If the value is a method, comlink will proxy it automatically.\n // Objects are only proxied if they are marked to be proxied.\n // Otherwise, the property is converted to a Promise that resolves the cloned value.\n T extends Function | ProxyMarked ? Remote<T> : Promisify<T>;\n\n/**\n * Takes the raw type of a property as a remote thread would see it through a proxy (e.g. when passed in as a function\n * argument) and returns the type that the local thread has to supply.\n *\n * This is the inverse of `RemoteProperty<T>`.\n *\n * Note: This needs to be its own type alias, otherwise it will not distribute over unions. See\n * https://www.typescriptlang.org/docs/handbook/advanced-types.html#distributive-conditional-types\n */\ntype LocalProperty<T> = T extends Function | ProxyMarked\n ? Local<T>\n : Unpromisify<T>;\n\n/**\n * Proxies `T` if it is a `ProxyMarked`, clones it otherwise (as handled by structured cloning and transfer handlers).\n */\nexport type ProxyOrClone<T> = T extends ProxyMarked ? Remote<T> : T;\n/**\n * Inverse of `ProxyOrClone<T>`.\n */\nexport type UnproxyOrClone<T> = T extends RemoteObject<ProxyMarked>\n ? Local<T>\n : T;\n\n/**\n * Takes the raw type of a remote object in the other thread and returns the type as it is visible to the local thread\n * when proxied with `Comlink.proxy()`.\n *\n * This does not handle call signatures, which is handled by the more general `Remote<T>` type.\n *\n * @template T The raw type of a remote object as seen in the other thread.\n */\nexport type RemoteObject<T> = { [P in keyof T]: RemoteProperty<T[P]> };\n/**\n * Takes the type of an object as a remote thread would see it through a proxy (e.g. when passed in as a function\n * argument) and returns the type that the local thread has to supply.\n *\n * This does not handle call signatures, which is handled by the more general `Local<T>` type.\n *\n * This is the inverse of `RemoteObject<T>`.\n *\n * @template T The type of a proxied object.\n */\nexport type LocalObject<T> = { [P in keyof T]: LocalProperty<T[P]> };\n\n/**\n * Additional special comlink methods available on each proxy returned by `Comlink.wrap()`.\n */\nexport interface ProxyMethods {\n [createEndpoint]: () => Promise<MessagePort>;\n [releaseProxy]: () => void;\n}\n\n/**\n * Takes the raw type of a remote object, function or class in the other thread and returns the type as it is visible to\n * the local thread from the proxy return value of `Comlink.wrap()` or `Comlink.proxy()`.\n */\nexport type Remote<T> =\n // Handle properties\n RemoteObject<T> &\n // Handle call signature (if present)\n (T extends (...args: infer TArguments) => infer TReturn\n ? (\n ...args: { [I in keyof TArguments]: UnproxyOrClone<TArguments[I]> }\n ) => Promisify<ProxyOrClone<Unpromisify<TReturn>>>\n : unknown) &\n // Handle construct signature (if present)\n // The return of construct signatures is always proxied (whether marked or not)\n (T extends { new (...args: infer TArguments): infer TInstance }\n ? {\n new (\n ...args: {\n [I in keyof TArguments]: UnproxyOrClone<TArguments[I]>;\n }\n ): Promisify<Remote<TInstance>>;\n }\n : unknown) &\n // Include additional special comlink methods available on the proxy.\n ProxyMethods;\n\n/**\n * Expresses that a type can be either a sync or async.\n */\ntype MaybePromise<T> = Promise<T> | T;\n\n/**\n * Takes the raw type of a remote object, function or class as a remote thread would see it through a proxy (e.g. when\n * passed in as a function argument) and returns the type the local thread has to supply.\n *\n * This is the inverse of `Remote<T>`. It takes a `Remote<T>` and returns its original input `T`.\n */\nexport type Local<T> =\n // Omit the special proxy methods (they don't need to be supplied, comlink adds them)\n Omit<LocalObject<T>, keyof ProxyMethods> &\n // Handle call signatures (if present)\n (T extends (...args: infer TArguments) => infer TReturn\n ? (\n ...args: { [I in keyof TArguments]: ProxyOrClone<TArguments[I]> }\n ) => // The raw function could either be sync or async, but is always proxied automatically\n MaybePromise<UnproxyOrClone<Unpromisify<TReturn>>>\n : unknown) &\n // Handle construct signature (if present)\n // The return of construct signatures is always proxied (whether marked or not)\n (T extends { new (...args: infer TArguments): infer TInstance }\n ? {\n new (\n ...args: {\n [I in keyof TArguments]: ProxyOrClone<TArguments[I]>;\n }\n ): // The raw constructor could either be sync or async, but is always proxied automatically\n MaybePromise<Local<Unpromisify<TInstance>>>;\n }\n : unknown);\n\nconst isObject = (val: unknown): val is object =>\n (typeof val === \"object\" && val !== null) || typeof val === \"function\";\n\n/**\n * Customizes the serialization of certain values as determined by `canHandle()`.\n *\n * @template T The input type being handled by this transfer handler.\n * @template S The serialized type sent over the wire.\n */\nexport interface TransferHandler<T, S> {\n /**\n * Gets called for every value to determine whether this transfer handler\n * should serialize the value, which includes checking that it is of the right\n * type (but can perform checks beyond that as well).\n */\n canHandle(value: unknown): value is T;\n\n /**\n * Gets called with the value if `canHandle()` returned `true` to produce a\n * value that can be sent in a message, consisting of structured-cloneable\n * values and/or transferrable objects.\n */\n serialize(value: T): [S, Transferable[]];\n\n /**\n * Gets called to deserialize an incoming value that was serialized in the\n * other thread with this transfer handler (known through the name it was\n * registered under).\n */\n deserialize(value: S): T;\n}\n\n/**\n * Internal transfer handle to handle objects marked to proxy.\n */\nconst proxyTransferHandler: TransferHandler<object, MessagePort> = {\n canHandle: (val): val is ProxyMarked =>\n isObject(val) && (val as ProxyMarked)[proxyMarker],\n serialize(obj) {\n const { port1, port2 } = new MessageChannel();\n expose(obj, port1);\n return [port2, [port2]];\n },\n deserialize(port) {\n port.start();\n return wrap(port);\n },\n};\n\ninterface ThrownValue {\n [throwMarker]: unknown; // just needs to be present\n value: unknown;\n}\ntype SerializedThrownValue =\n | { isError: true; value: Error }\n | { isError: false; value: unknown };\ntype PendingListenersMap = Map<\n string,\n (value: WireValue | PromiseLike<WireValue>) => void\n>;\n\n/**\n * Internal transfer handler to handle thrown exceptions.\n */\nconst throwTransferHandler: TransferHandler<\n ThrownValue,\n SerializedThrownValue\n> = {\n canHandle: (value): value is ThrownValue =>\n isObject(value) && throwMarker in value,\n serialize({ value }) {\n let serialized: SerializedThrownValue;\n if (value instanceof Error) {\n serialized = {\n isError: true,\n value: {\n message: value.message,\n name: value.name,\n stack: value.stack,\n },\n };\n } else {\n serialized = { isError: false, value };\n }\n return [serialized, []];\n },\n deserialize(serialized) {\n if (serialized.isError) {\n throw Object.assign(\n new Error(serialized.value.message),\n serialized.value\n );\n }\n throw serialized.value;\n },\n};\n\n/**\n * Allows customizing the serialization of certain values.\n */\nexport const transferHandlers = new Map<\n string,\n TransferHandler<unknown, unknown>\n>([\n [\"proxy\", proxyTransferHandler],\n [\"throw\", throwTransferHandler],\n]);\n\nfunction isAllowedOrigin(\n allowedOrigins: (string | RegExp)[],\n origin: string\n): boolean {\n for (const allowedOrigin of allowedOrigins) {\n if (origin === allowedOrigin || allowedOrigin === \"*\") {\n return true;\n }\n if (allowedOrigin instanceof RegExp && allowedOrigin.test(origin)) {\n return true;\n }\n }\n return false;\n}\n\nexport function expose(\n obj: any,\n ep: Endpoint = globalThis as any,\n allowedOrigins: (string | RegExp)[] = [\"*\"]\n) {\n ep.addEventListener(\"message\", function callback(ev: MessageEvent) {\n if (!ev || !ev.data) {\n return;\n }\n if (!isAllowedOrigin(allowedOrigins, ev.origin)) {\n console.warn(`Invalid origin '${ev.origin}' for comlink proxy`);\n return;\n }\n const { id, type, path } = {\n path: [] as string[],\n ...(ev.data as Message),\n };\n const argumentList = (ev.data.argumentList || []).map(fromWireValue);\n let returnValue;\n try {\n const parent = path.slice(0, -1).reduce((obj, prop) => obj[prop], obj);\n const rawValue = path.reduce((obj, prop) => obj[prop], obj);\n switch (type) {\n case MessageType.GET:\n {\n returnValue = rawValue;\n }\n break;\n case MessageType.SET:\n {\n parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);\n returnValue = true;\n }\n break;\n case MessageType.APPLY:\n {\n returnValue = rawValue.apply(parent, argumentList);\n }\n break;\n case MessageType.CONSTRUCT:\n {\n const value = new rawValue(...argumentList);\n returnValue = proxy(value);\n }\n break;\n case MessageType.ENDPOINT:\n {\n const { port1, port2 } = new MessageChannel();\n expose(obj, port2);\n returnValue = transfer(port1, [port1]);\n }\n break;\n case MessageType.RELEASE:\n {\n returnValue = undefined;\n }\n break;\n default:\n return;\n }\n } catch (value) {\n returnValue = { value, [throwMarker]: 0 };\n }\n Promise.resolve(returnValue)\n .catch((value) => {\n return { value, [throwMarker]: 0 };\n })\n .then((returnValue) => {\n const [wireValue, transferables] = toWireValue(returnValue);\n ep.postMessage({ ...wireValue, id }, transferables);\n if (type === MessageType.RELEASE) {\n // detach and deactive after sending release response above.\n ep.removeEventListener(\"message\", callback as any);\n closeEndPoint(ep);\n if (finalizer in obj && typeof obj[finalizer] === \"function\") {\n obj[finalizer]();\n }\n }\n })\n .catch((error) => {\n // Send Serialization Error To Caller\n const [wireValue, transferables] = toWireValue({\n value: new TypeError(\"Unserializable return value\"),\n [throwMarker]: 0,\n });\n ep.postMessage({ ...wireValue, id }, transferables);\n });\n } as any);\n if (ep.start) {\n ep.start();\n }\n}\n\nfunction isMessagePort(endpoint: Endpoint): endpoint is MessagePort {\n return endpoint.constructor.name === \"MessagePort\";\n}\n\nfunction closeEndPoint(endpoint: Endpoint) {\n if (isMessagePort(endpoint)) endpoint.close();\n}\n\nexport function wrap<T>(ep: Endpoint, target?: any): Remote<T> {\n const pendingListeners : PendingListenersMap = new Map();\n\n ep.addEventListener(\"message\", function handleMessage(ev: Event) {\n const { data } = ev as MessageEvent;\n if (!data || !data.id) {\n return;\n }\n const resolver = pendingListeners.get(data.id);\n if (!resolver) {\n return;\n }\n\n try {\n resolver(data);\n } finally {\n pendingListeners.delete(data.id);\n }\n });\n\n return createProxy<T>(ep, pendingListeners, [], target) as any;\n}\n\nfunction throwIfProxyReleased(isReleased: boolean) {\n if (isReleased) {\n throw new Error(\"Proxy has been released and is not useable\");\n }\n}\n\nfunction releaseEndpoint(ep: Endpoint) {\n return requestResponseMessage(ep, new Map(), {\n type: MessageType.RELEASE,\n }).then(() => {\n closeEndPoint(ep);\n });\n}\n\ninterface FinalizationRegistry<T> {\n new (cb: (heldValue: T) => void): FinalizationRegistry<T>;\n register(\n weakItem: object,\n heldValue: T,\n unregisterToken?: object | undefined\n ): void;\n unregister(unregisterToken: object): void;\n}\ndeclare var FinalizationRegistry: FinalizationRegistry<Endpoint>;\n\nconst proxyCounter = new WeakMap<Endpoint, number>();\nconst proxyFinalizers =\n \"FinalizationRegistry\" in globalThis &&\n new FinalizationRegistry((ep: Endpoint) => {\n const newCount = (proxyCounter.get(ep) || 0) - 1;\n proxyCounter.set(ep, newCount);\n if (newCount === 0) {\n releaseEndpoint(ep);\n }\n });\n\nfunction registerProxy(proxy: object, ep: Endpoint) {\n const newCount = (proxyCounter.get(ep) || 0) + 1;\n proxyCounter.set(ep, newCount);\n if (proxyFinalizers) {\n proxyFinalizers.register(proxy, ep, proxy);\n }\n}\n\nfunction unregisterProxy(proxy: object) {\n if (proxyFinalizers) {\n proxyFinalizers.unregister(proxy);\n }\n}\n\nfunction createProxy<T>(\n ep: Endpoint,\n pendingListeners: PendingListenersMap,\n path: (string | number | symbol)[] = [],\n target: object = function () {}\n): Remote<T> {\n let isProxyReleased = false;\n const proxy = new Proxy(target, {\n get(_target, prop) {\n throwIfProxyReleased(isProxyReleased);\n if (prop === releaseProxy) {\n return () => {\n unregisterProxy(proxy);\n releaseEndpoint(ep);\n pendingListeners.clear();\n isProxyReleased = true;\n };\n }\n if (prop === \"then\") {\n if (path.length === 0) {\n return { then: () => proxy };\n }\n const r = requestResponseMessage(ep, pendingListeners, {\n type: MessageType.GET,\n path: path.map((p) => p.toString()),\n }).then(fromWireValue);\n return r.then.bind(r);\n }\n return createProxy(ep, pendingListeners, [...path, prop]);\n },\n set(_target, prop, rawValue) {\n throwIfProxyReleased(isProxyReleased);\n // FIXME: ES6 Proxy Handler `set` methods are supposed to return a\n // boolean. To show good will, we return true asynchronously ¯\\_(ツ)_/¯\n const [value, transferables] = toWireValue(rawValue);\n return requestResponseMessage(\n ep,\n pendingListeners,\n {\n type: MessageType.SET,\n path: [...path, prop].map((p) => p.toString()),\n value,\n },\n transferables\n ).then(fromWireValue) as any;\n },\n apply(_target, _thisArg, rawArgumentList) {\n throwIfProxyReleased(isProxyReleased);\n const last = path[path.length - 1];\n if ((last as any) === createEndpoint) {\n return requestResponseMessage(ep, pendingListeners, {\n type: MessageType.ENDPOINT,\n }).then(fromWireValue);\n }\n // We just pretend that `bind()` didn’t happen.\n if (last === \"bind\") {\n return createProxy(ep, pendingListeners, path.slice(0, -1));\n }\n const [argumentList, transferables] = processArguments(rawArgumentList);\n return requestResponseMessage(\n ep,\n pendingListeners,\n {\n type: MessageType.APPLY,\n path: path.map((p) => p.toString()),\n argumentList,\n },\n transferables\n ).then(fromWireValue);\n },\n construct(_target, rawArgumentList) {\n throwIfProxyReleased(isProxyReleased);\n const [argumentList, transferables] = processArguments(rawArgumentList);\n return requestResponseMessage(\n ep,\n pendingListeners,\n {\n type: MessageType.CONSTRUCT,\n path: path.map((p) => p.toString()),\n argumentList,\n },\n transferables\n ).then(fromWireValue);\n },\n });\n registerProxy(proxy, ep);\n return proxy as any;\n}\n\nfunction myFlat<T>(arr: (T | T[])[]): T[] {\n return Array.prototype.concat.apply([], arr);\n}\n\nfunction processArguments(argumentList: any[]): [WireValue[], Transferable[]] {\n const processed = argumentList.map(toWireValue);\n return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];\n}\n\nconst transferCache = new WeakMap<any, Transferable[]>();\nexport function transfer<T>(obj: T, transfers: Transferable[]): T {\n transferCache.set(obj, transfers);\n return obj;\n}\n\nexport function proxy<T extends {}>(obj: T): T & ProxyMarked {\n return Object.assign(obj, { [proxyMarker]: true }) as any;\n}\n\nexport function windowEndpoint(\n w: PostMessageWithOrigin,\n context: EventSource = globalThis,\n targetOrigin = \"*\"\n): Endpoint {\n return {\n postMessage: (msg: any, transferables: Transferable[]) =>\n w.postMessage(msg, targetOrigin, transferables),\n addEventListener: context.addEventListener.bind(context),\n removeEventListener: context.removeEventListener.bind(context),\n };\n}\n\nfunction toWireValue(value: any): [WireValue, Transferable[]] {\n for (const [name, handler] of transferHandlers) {\n if (handler.canHandle(value)) {\n const [serializedValue, transferables] = handler.serialize(value);\n return [\n {\n type: WireValueType.HANDLER,\n name,\n value: serializedValue,\n },\n transferables,\n ];\n }\n }\n return [\n {\n type: WireValueType.RAW,\n value,\n },\n transferCache.get(value) || [],\n ];\n}\n\nfunction fromWireValue(value: WireValue): any {\n switch (value.type) {\n case WireValueType.HANDLER:\n return transferHandlers.get(value.name)!.deserialize(value.value);\n case WireValueType.RAW:\n return value.value;\n }\n}\n\nfunction requestResponseMessage(\n ep: Endpoint,\n pendingListeners: PendingListenersMap,\n msg: Message,\n transfers?: Transferable[]\n): Promise<WireValue> {\n return new Promise((resolve) => {\n const id = generateUUID();\n pendingListeners.set(id, resolve);\n if (ep.start) {\n ep.start();\n }\n ep.postMessage({ id, ...msg }, transfers);\n});\n}\n\nfunction generateUUID(): string {\n return new Array(4)\n .fill(0)\n .map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16))\n .join(\"-\");\n}\n","import type { ValidatorOrWithParams } from '../../../types/sheet-layout.js';\n\nexport interface ResolvedTransformRef {\n readonly name: string;\n readonly params?: Readonly<Record<string, unknown>>;\n}\n\nexport function resolveTransformRef(ref: ValidatorOrWithParams): ResolvedTransformRef {\n if (typeof ref === 'string') return { name: ref };\n return { name: ref.name, params: ref.params };\n}\n","import type { SheetLayoutField } from '../../../types/sheet-layout.js';\nimport type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\nimport { resolveTransformRef } from './resolve-transform-ref.js';\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>,\n) => unknown;\n\nexport type GetCellTransform = (name: string) => CellTransformFn | undefined;\n\nexport function runCellTransforms(\n cell: ValidatedCell,\n row: ValidatedRow,\n field: SheetLayoutField,\n getTransform: GetCellTransform,\n): unknown {\n if (cell.errors.length > 0) return cell.value;\n const list = field.transformations;\n if (!list?.length) return cell.value;\n let current: unknown = cell.value;\n for (const ref of list) {\n const { name, params } = resolveTransformRef(ref);\n const fn = getTransform(name);\n if (fn) current = fn(current, cell, row, params);\n }\n return current;\n}\n","import type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { ValidatedRow } from '../../../types/sheet.js';\nimport { resolveTransformRef } from './resolve-transform-ref.js';\n\nexport type RowTransformFn = (\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>,\n) => ValidatedRow;\n\nexport type GetRowTransform = (name: string) => RowTransformFn | undefined;\n\nexport function runRowTransforms(\n row: ValidatedRow,\n sheetLayout: SheetLayout,\n getTransform: GetRowTransform,\n): ValidatedRow {\n if (row.errors.length > 0) return row;\n const list = sheetLayout.rowTransformations;\n if (!list?.length) return row;\n let current: ValidatedRow = row;\n for (const ref of list) {\n const { name, params } = resolveTransformRef(ref);\n const fn = getTransform(name);\n if (fn) current = fn(current, params);\n }\n return current;\n}\n","import type { SheetError } from '../../../types/error.js';\nimport type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { Sheet } from '../../../types/sheet.js';\nimport type { TransformDeltaItem } from '../types/transform-delta.js';\nimport { resolveTransformRef } from './resolve-transform-ref.js';\n\nexport const EXTERNAL_TRANSFORM_FAILED = 'EXTERNAL_TRANSFORM_FAILED';\n\nexport type SheetTransformFn = (\n sheet: Sheet,\n params?: Readonly<Record<string, unknown>>,\n signal?: AbortSignal,\n) => readonly TransformDeltaItem[] | Promise<readonly TransformDeltaItem[]>;\n\nexport type GetSheetTransform = (name: string) => SheetTransformFn | undefined;\n\nexport interface SheetTransformOutput {\n readonly deltas: TransformDeltaItem[];\n readonly errors: SheetError[];\n}\n\nexport async function runSheetTransforms(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n getTransform: GetSheetTransform,\n signal?: AbortSignal,\n): Promise<SheetTransformOutput> {\n const list = sheetLayout.sheetTransformations;\n if (!list?.length) return { deltas: [], errors: [] };\n const deltas: TransformDeltaItem[] = [];\n const errors: SheetError[] = [];\n for (const ref of list) {\n const { name, params } = resolveTransformRef(ref);\n const fn = getTransform(name);\n if (!fn) continue;\n try {\n const result = await Promise.resolve(fn(sheet, params, signal));\n if (result?.length) deltas.push(...result);\n } catch {\n errors.push({\n code: EXTERNAL_TRANSFORM_FAILED,\n level: 'fatal',\n params: { reason: 'network' },\n });\n }\n }\n return { deltas, errors };\n}\n","import type { Sheet, ValidatedCell, ValidatedRow } from '../../types/sheet.js';\nimport type { TransformDelta } from './types/transform-delta.js';\n\nfunction patchCellInRow(\n rows: ValidatedRow[],\n rowIndex: number,\n col: string,\n newValue: unknown,\n): ValidatedRow[] {\n return rows.map((row) => {\n if (row.index !== rowIndex) return row;\n const cells: ValidatedCell[] = row.cells.map((cell) =>\n cell.key === col ? { ...cell, value: newValue } : cell,\n );\n return { ...row, cells };\n });\n}\n\nexport function applyTransformDelta(sheet: Sheet, delta: TransformDelta): Sheet {\n if (!delta.deltas.length) return sheet;\n let rows = [...sheet.rows];\n for (const item of delta.deltas) {\n if (item.row < 0) continue;\n rows = patchCellInRow(rows, item.row, item.col, item.newValue);\n }\n return { ...sheet, rows };\n}\n","import type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { Sheet, ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\nimport type { TransformDeltaItem, TransformResult } from '../types/transform-delta.js';\nimport type { TransformProgressDetail } from '../types/transform-progress.js';\nimport { runCellTransforms } from './cell-transforms.js';\nimport { runRowTransforms } from './row-transforms.js';\nimport { runSheetTransforms } from './sheet-transforms.js';\nimport type { GetCellTransform } from './cell-transforms.js';\nimport type { GetRowTransform } from './row-transforms.js';\nimport type { GetSheetTransform } from './sheet-transforms.js';\nimport { applyTransformDelta } from '../delta-applier.js';\n\nconst THROTTLE_MS = 16;\nconst THROTTLE_PERCENT = 1;\nconst CHUNK_SIZE = 200;\n\nexport interface TransformGetters {\n getCellTransform: GetCellTransform;\n getRowTransform: GetRowTransform;\n getSheetTransform: GetSheetTransform;\n}\n\nfunction createThrottledProgress(\n totalRows: number,\n onProgress: (d: TransformProgressDetail) => void,\n): (processed: number) => void {\n let lastTime = 0;\n let lastPercent = -1;\n return (processed: number) => {\n const now = Date.now();\n const localPercent = totalRows > 0 ? Math.floor((processed / totalRows) * 100) : 100;\n const shouldEmit =\n now - lastTime >= THROTTLE_MS ||\n localPercent - lastPercent >= THROTTLE_PERCENT ||\n processed >= totalRows;\n if (shouldEmit && totalRows > 0) {\n lastTime = now;\n lastPercent = localPercent;\n onProgress({\n phase: 'transforming',\n localPercent,\n currentRow: processed,\n totalRows,\n });\n }\n };\n}\n\nfunction diffRowToDeltas(\n rowIndex: number,\n before: ValidatedRow,\n after: ValidatedRow,\n): TransformDeltaItem[] {\n const out: TransformDeltaItem[] = [];\n const beforeCells = new Map(before.cells.map((c) => [c.key, c]));\n for (const cell of after.cells) {\n const prev = beforeCells.get(cell.key);\n if (prev && prev.value !== cell.value) {\n out.push({ row: rowIndex, col: cell.key, newValue: cell.value });\n }\n }\n return out;\n}\n\nexport async function runTransform(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n getters: TransformGetters,\n onProgress?: (d: TransformProgressDetail) => void,\n signal?: AbortSignal,\n): Promise<TransformResult> {\n if (sheet.errors.length > 0) return { deltas: [] };\n const fields = sheetLayout.fields;\n const totalRows = sheet.rows.length;\n const reportProgress = onProgress ? createThrottledProgress(totalRows, onProgress) : () => {};\n const deltas: TransformDeltaItem[] = [];\n\n for (let i = 0; i < totalRows; i += CHUNK_SIZE) {\n const end = Math.min(i + CHUNK_SIZE, totalRows);\n for (let r = i; r < end; r++) {\n const row = sheet.rows[r];\n if (!row || row.errors.length > 0) continue;\n const rowDeltas: TransformDeltaItem[] = [];\n const updatedCells: ValidatedCell[] = [];\n for (const cell of row.cells) {\n const field = fields[cell.key];\n if (!field) {\n updatedCells.push(cell);\n continue;\n }\n const newValue = runCellTransforms(\n cell,\n row,\n field,\n getters.getCellTransform,\n );\n if (newValue !== cell.value) {\n rowDeltas.push({ row: row.index, col: cell.key, newValue });\n }\n updatedCells.push({ ...cell, value: newValue });\n }\n const updatedRow: ValidatedRow = { ...row, cells: updatedCells };\n const afterRow = runRowTransforms(updatedRow, sheetLayout, getters.getRowTransform);\n const rowDiff = diffRowToDeltas(row.index, updatedRow, afterRow);\n deltas.push(...rowDeltas, ...rowDiff);\n }\n reportProgress(end);\n }\n\n if (onProgress) {\n onProgress({ phase: 'transforming', localPercent: 100, currentRow: totalRows, totalRows });\n }\n\n const transformedSheet = applyTransformDelta(sheet, { deltas });\n\n const sheetOut = await runSheetTransforms(\n transformedSheet,\n sheetLayout,\n getters.getSheetTransform,\n signal,\n );\n deltas.push(...sheetOut.deltas);\n const errors = sheetOut.errors.length > 0 ? [...sheetOut.errors] : undefined;\n return { deltas, errors };\n}\n","import type { RegistryEntry, RegistryLevel } from './types.js';\n\nexport class Registry<T extends (...args: unknown[]) => unknown> {\n private entries = new Map<string, RegistryEntry<T>>();\n\n register(name: string, fn: T, options: { type: RegistryLevel }): void {\n this.entries.set(name, { fn, type: options.type });\n }\n\n get(name: string): RegistryEntry<T> | undefined {\n return this.entries.get(name);\n }\n\n getByType(type: RegistryLevel): Array<{ name: string; entry: RegistryEntry<T> }> {\n return [...this.entries.entries()]\n .filter(([, e]) => e.type === type)\n .map(([name, entry]) => ({ name, entry }));\n }\n\n has(name: string): boolean {\n return this.entries.has(name);\n }\n\n clear(): void {\n this.entries.clear();\n }\n}\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const TO_UPPER_TRANSFORM_ID = 'toUpperCase';\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>,\n) => unknown;\n\nexport function cellToUpperTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>,\n): unknown {\n if (typeof value !== 'string') return value;\n return value.toUpperCase();\n}\n\nexport function registerToUpperTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void,\n): void {\n register(TO_UPPER_TRANSFORM_ID, cellToUpperTransform, { type: 'cell' });\n}\n\nexport const CellToUpperTransform = {\n id: TO_UPPER_TRANSFORM_ID,\n transform: cellToUpperTransform,\n Register(registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void): string {\n if (registerFn) registerToUpperTransform(registerFn);\n return TO_UPPER_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const TO_LOWER_TRANSFORM_ID = 'toLowerCase';\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringToLowerTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n if (typeof value !== 'string') return value;\n return value.toLowerCase();\n}\n\nexport function registerStringToLowerTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(TO_LOWER_TRANSFORM_ID, cellStringToLowerTransform, { type: 'cell' });\n}\n\nexport const CellStringToLowerTransform = {\n id: TO_LOWER_TRANSFORM_ID,\n transform: cellStringToLowerTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringToLowerTransform(registerFn);\n return TO_LOWER_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const SLICE_TRANSFORM_ID = 'slice';\n\ntype Params = { start?: number; end?: number };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringSliceTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n if (typeof value !== 'string') return value;\n const { start, end } = (params ?? {}) as Params;\n const s = Number(start);\n const e = Number(end);\n if (Number.isNaN(s) && Number.isNaN(e)) return value;\n if (Number.isNaN(e)) return value.slice(Number.isNaN(s) ? undefined : s);\n return value.slice(Number.isNaN(s) ? undefined : s, e);\n}\n\nexport function registerStringSliceTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(SLICE_TRANSFORM_ID, cellStringSliceTransform, { type: 'cell' });\n}\n\nexport const CellStringSliceTransform = {\n id: SLICE_TRANSFORM_ID,\n transform: cellStringSliceTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringSliceTransform(registerFn);\n return SLICE_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const REPLACE_STR_TRANSFORM_ID = 'replace';\n\ntype Params = { search?: string; replacement?: string };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringReplaceTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n if (typeof value !== 'string') return value;\n const { search = '', replacement = '' } = (params ?? {}) as Params;\n return value.split(String(search)).join(String(replacement));\n}\n\nexport function registerStringReplaceTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(REPLACE_STR_TRANSFORM_ID, cellStringReplaceTransform, { type: 'cell' });\n}\n\nexport const CellStringReplaceTransform = {\n id: REPLACE_STR_TRANSFORM_ID,\n transform: cellStringReplaceTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringReplaceTransform(registerFn);\n return REPLACE_STR_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const REPLACE_BY_REGEX_TRANSFORM_ID = 'replaceByRegex';\n\ntype Params = { pattern?: string; flags?: string; replacement?: string };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringReplaceByRegexTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n if (typeof value !== 'string') return value;\n const { pattern = '', flags = 'g', replacement = '' } = (params ?? {}) as Params;\n if (!pattern) return value;\n try {\n const re = new RegExp(pattern, flags);\n return value.replace(re, String(replacement));\n } catch {\n return value;\n }\n}\n\nexport function registerStringReplaceByRegexTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(REPLACE_BY_REGEX_TRANSFORM_ID, cellStringReplaceByRegexTransform, { type: 'cell' });\n}\n\nexport const CellStringReplaceByRegexTransform = {\n id: REPLACE_BY_REGEX_TRANSFORM_ID,\n transform: cellStringReplaceByRegexTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringReplaceByRegexTransform(registerFn);\n return REPLACE_BY_REGEX_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const FILL_START_TRANSFORM_ID = 'fillStart';\n\ntype Params = { length?: number; fill?: string };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringFillStartTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const s =\n typeof value === 'string' ? value : value === null || value === undefined ? '' : String(value);\n const { length = 0, fill = ' ' } = (params ?? {}) as Params;\n const safeLength = Math.max(0, Number(length) || 0);\n return safeLength > 0 ? s.padStart(safeLength, String(fill)) : s;\n}\n\nexport function registerStringFillStartTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(FILL_START_TRANSFORM_ID, cellStringFillStartTransform, { type: 'cell' });\n}\n\nexport const CellStringFillStartTransform = {\n id: FILL_START_TRANSFORM_ID,\n transform: cellStringFillStartTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringFillStartTransform(registerFn);\n return FILL_START_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const FILL_END_TRANSFORM_ID = 'fillEnd';\n\ntype Params = { length?: number; fill?: string };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringFillEndTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const s =\n typeof value === 'string' ? value : value === null || value === undefined ? '' : String(value);\n const { length = 0, fill = ' ' } = (params ?? {}) as Params;\n const safeLength = Math.max(0, Number(length) || 0);\n return safeLength > 0 ? s.padEnd(safeLength, String(fill)) : s;\n}\n\nexport function registerStringFillEndTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(FILL_END_TRANSFORM_ID, cellStringFillEndTransform, { type: 'cell' });\n}\n\nexport const CellStringFillEndTransform = {\n id: FILL_END_TRANSFORM_ID,\n transform: cellStringFillEndTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringFillEndTransform(registerFn);\n return FILL_END_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const EXTRACT_BY_REGEX_TRANSFORM_ID = 'extractByRegex';\n\ntype Params = { pattern?: string; flags?: string; group?: number };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringExtractByRegexTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const s =\n typeof value === 'string' ? value : value === null || value === undefined ? '' : String(value);\n const { pattern = '', flags = '', group = 0 } = (params ?? {}) as Params;\n if (!pattern) return s;\n try {\n const re = new RegExp(pattern, flags);\n const m = s.match(re);\n if (!m) return '';\n const g = Math.max(0, Number(group) || 0);\n return m[g] ?? m[0] ?? '';\n } catch {\n return s;\n }\n}\n\nexport function registerStringExtractByRegexTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(EXTRACT_BY_REGEX_TRANSFORM_ID, cellStringExtractByRegexTransform, { type: 'cell' });\n}\n\nexport const CellStringExtractByRegexTransform = {\n id: EXTRACT_BY_REGEX_TRANSFORM_ID,\n transform: cellStringExtractByRegexTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringExtractByRegexTransform(registerFn);\n return EXTRACT_BY_REGEX_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_ADD_TRANSFORM_ID = 'numberAdd';\n\ntype Params = { value?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberAddTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { value: add = 0 } = (params ?? {}) as Params;\n const delta = Number(add);\n return Number.isNaN(delta) ? value : n + delta;\n}\n\nexport function registerNumberAddTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_ADD_TRANSFORM_ID, cellNumberAddTransform, { type: 'cell' });\n}\n\nexport const CellNumberAddTransform = {\n id: NUMBER_ADD_TRANSFORM_ID,\n transform: cellNumberAddTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberAddTransform(registerFn);\n return NUMBER_ADD_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_MULTIPLY_TRANSFORM_ID = 'numberMultiply';\n\ntype Params = { value?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberMultiplyTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { value: factor = 1 } = (params ?? {}) as Params;\n const f = Number(factor);\n return Number.isNaN(f) ? value : n * f;\n}\n\nexport function registerNumberMultiplyTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_MULTIPLY_TRANSFORM_ID, cellNumberMultiplyTransform, { type: 'cell' });\n}\n\nexport const CellNumberMultiplyTransform = {\n id: NUMBER_MULTIPLY_TRANSFORM_ID,\n transform: cellNumberMultiplyTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberMultiplyTransform(registerFn);\n return NUMBER_MULTIPLY_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_DIVIDE_TRANSFORM_ID = 'numberDivide';\n\ntype Params = { value?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberDivideTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { value: divisor = 1 } = (params ?? {}) as Params;\n const d = Number(divisor);\n if (Number.isNaN(d) || d === 0) return value;\n return n / d;\n}\n\nexport function registerNumberDivideTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_DIVIDE_TRANSFORM_ID, cellNumberDivideTransform, { type: 'cell' });\n}\n\nexport const CellNumberDivideTransform = {\n id: NUMBER_DIVIDE_TRANSFORM_ID,\n transform: cellNumberDivideTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberDivideTransform(registerFn);\n return NUMBER_DIVIDE_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_SUBTRACT_TRANSFORM_ID = 'numberSubtract';\n\ntype Params = { value?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberSubtractTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { value: sub = 0 } = (params ?? {}) as Params;\n const delta = Number(sub);\n return Number.isNaN(delta) ? value : n - delta;\n}\n\nexport function registerNumberSubtractTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_SUBTRACT_TRANSFORM_ID, cellNumberSubtractTransform, { type: 'cell' });\n}\n\nexport const CellNumberSubtractTransform = {\n id: NUMBER_SUBTRACT_TRANSFORM_ID,\n transform: cellNumberSubtractTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberSubtractTransform(registerFn);\n return NUMBER_SUBTRACT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_ROUND_TRANSFORM_ID = 'numberRound';\n\ntype Params = { mode?: 'round' | 'ceil' | 'floor' };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberRoundTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { mode = 'round' } = (params ?? {}) as Params;\n if (mode === 'ceil') return Math.ceil(n);\n if (mode === 'floor') return Math.floor(n);\n return Math.round(n);\n}\n\nexport function registerNumberRoundTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_ROUND_TRANSFORM_ID, cellNumberRoundTransform, { type: 'cell' });\n}\n\nexport const CellNumberRoundTransform = {\n id: NUMBER_ROUND_TRANSFORM_ID,\n transform: cellNumberRoundTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberRoundTransform(registerFn);\n return NUMBER_ROUND_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_ABS_TRANSFORM_ID = 'numberAbs';\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberAbsTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n return Math.abs(n);\n}\n\nexport function registerNumberAbsTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_ABS_TRANSFORM_ID, cellNumberAbsTransform, { type: 'cell' });\n}\n\nexport const CellNumberAbsTransform = {\n id: NUMBER_ABS_TRANSFORM_ID,\n transform: cellNumberAbsTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberAbsTransform(registerFn);\n return NUMBER_ABS_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_SQRT_TRANSFORM_ID = 'numberSqrt';\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberSqrtTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null || n < 0) return value;\n return Math.sqrt(n);\n}\n\nexport function registerNumberSqrtTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_SQRT_TRANSFORM_ID, cellNumberSqrtTransform, { type: 'cell' });\n}\n\nexport const CellNumberSqrtTransform = {\n id: NUMBER_SQRT_TRANSFORM_ID,\n transform: cellNumberSqrtTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberSqrtTransform(registerFn);\n return NUMBER_SQRT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_LIMIT_TRANSFORM_ID = 'numberLimit';\n\ntype Params = { min?: number; max?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberLimitTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { min, max } = (params ?? {}) as Params;\n let out = n;\n const minVal = Number(min);\n if (!Number.isNaN(minVal) && out < minVal) out = minVal;\n const maxVal = Number(max);\n if (!Number.isNaN(maxVal) && out > maxVal) out = maxVal;\n return out;\n}\n\nexport function registerNumberLimitTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_LIMIT_TRANSFORM_ID, cellNumberLimitTransform, { type: 'cell' });\n}\n\nexport const CellNumberLimitTransform = {\n id: NUMBER_LIMIT_TRANSFORM_ID,\n transform: cellNumberLimitTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberLimitTransform(registerFn);\n return NUMBER_LIMIT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_PERCENT_TRANSFORM_ID = 'numberPercent';\n\ntype Params = { total?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberPercentTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { total } = (params ?? {}) as Params;\n const t = Number(total);\n if (Number.isNaN(t) || t === 0) return value;\n return (n / t) * 100;\n}\n\nexport function registerNumberPercentTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_PERCENT_TRANSFORM_ID, cellNumberPercentTransform, { type: 'cell' });\n}\n\nexport const CellNumberPercentTransform = {\n id: NUMBER_PERCENT_TRANSFORM_ID,\n transform: cellNumberPercentTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberPercentTransform(registerFn);\n return NUMBER_PERCENT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_TO_ONLY_TIME_TRANSFORM_ID = 'dateToOnlyTime';\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction toISOTimeString(d: Date): string {\n const h = String(d.getHours()).padStart(2, '0');\n const min = String(d.getMinutes()).padStart(2, '0');\n const s = String(d.getSeconds()).padStart(2, '0');\n return `${h}:${min}:${s}`;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateToOnlyTimeTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return toISOTimeString(d);\n}\n\nexport function registerDateToOnlyTimeTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TO_ONLY_TIME_TRANSFORM_ID, cellDateToOnlyTimeTransform, { type: 'cell' });\n}\n\nexport const CellDateToOnlyTimeTransform = {\n id: DATE_TO_ONLY_TIME_TRANSFORM_ID,\n transform: cellDateToOnlyTimeTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateToOnlyTimeTransform(registerFn);\n return DATE_TO_ONLY_TIME_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_TO_ONLY_DATE_TRANSFORM_ID = 'dateToOnlyDate';\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction toISODateString(d: Date): string {\n const y = d.getFullYear();\n const m = String(d.getMonth() + 1).padStart(2, '0');\n const day = String(d.getDate()).padStart(2, '0');\n return `${y}-${m}-${day}`;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateToOnlyDateTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return toISODateString(d);\n}\n\nexport function registerDateToOnlyDateTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TO_ONLY_DATE_TRANSFORM_ID, cellDateToOnlyDateTransform, { type: 'cell' });\n}\n\nexport const CellDateToOnlyDateTransform = {\n id: DATE_TO_ONLY_DATE_TRANSFORM_ID,\n transform: cellDateToOnlyDateTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateToOnlyDateTransform(registerFn);\n return DATE_TO_ONLY_DATE_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_TO_TIME_DATE_TRANSFORM_ID = 'dateToTimeDate';\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction toISODateString(d: Date): string {\n const y = d.getFullYear();\n const m = String(d.getMonth() + 1).padStart(2, '0');\n const day = String(d.getDate()).padStart(2, '0');\n return `${y}-${m}-${day}`;\n}\n\nfunction toISOTimeString(d: Date): string {\n const h = String(d.getHours()).padStart(2, '0');\n const min = String(d.getMinutes()).padStart(2, '0');\n const s = String(d.getSeconds()).padStart(2, '0');\n return `${h}:${min}:${s}`;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateToTimeDateTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return `${toISODateString(d)}T${toISOTimeString(d)}`;\n}\n\nexport function registerDateToTimeDateTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TO_TIME_DATE_TRANSFORM_ID, cellDateToTimeDateTransform, { type: 'cell' });\n}\n\nexport const CellDateToTimeDateTransform = {\n id: DATE_TO_TIME_DATE_TRANSFORM_ID,\n transform: cellDateToTimeDateTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateToTimeDateTransform(registerFn);\n return DATE_TO_TIME_DATE_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_TO_UTC_TRANSFORM_ID = 'dateToUtc';\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateToUtcTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return d.toISOString();\n}\n\nexport function registerDateToUtcTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TO_UTC_TRANSFORM_ID, cellDateToUtcTransform, { type: 'cell' });\n}\n\nexport const CellDateToUtcTransform = {\n id: DATE_TO_UTC_TRANSFORM_ID,\n transform: cellDateToUtcTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateToUtcTransform(registerFn);\n return DATE_TO_UTC_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_LIMIT_TRANSFORM_ID = 'dateLimit';\n\ntype Params = { min?: string | number; max?: string | number };\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n if (!Number.isNaN(ms)) return new Date(ms);\n const n = Number(value);\n return Number.isFinite(n) ? new Date(n) : null;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateLimitTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n const { min, max } = (params ?? {}) as Params;\n let out = d.getTime();\n if (min !== undefined) {\n const minD = typeof min === 'number' ? new Date(min) : new Date(String(min));\n if (!Number.isNaN(minD.getTime()) && out < minD.getTime()) out = minD.getTime();\n }\n if (max !== undefined) {\n const maxD = typeof max === 'number' ? new Date(max) : new Date(String(max));\n if (!Number.isNaN(maxD.getTime()) && out > maxD.getTime()) out = maxD.getTime();\n }\n return new Date(out).toISOString();\n}\n\nexport function registerDateLimitTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_LIMIT_TRANSFORM_ID, cellDateLimitTransform, { type: 'cell' });\n}\n\nexport const CellDateLimitTransform = {\n id: DATE_LIMIT_TRANSFORM_ID,\n transform: cellDateLimitTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateLimitTransform(registerFn);\n return DATE_LIMIT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_ADD_TRANSFORM_ID = 'dateAdd';\n\ntype Params = {\n days?: number;\n minutes?: number;\n hours?: number;\n seconds?: number;\n ms?: number;\n months?: number;\n years?: number;\n};\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction addToDate(d: Date, p: Params): Date {\n const out = new Date(d.getTime());\n const ms = Number(p.ms) || 0;\n const sec = Number(p.seconds) || 0;\n const min = Number(p.minutes) || 0;\n const h = Number(p.hours) || 0;\n const days = Number(p.days) || 0;\n out.setTime(out.getTime() + ms + sec * 1000 + min * 60_000 + h * 3_600_000 + days * 86_400_000);\n const months = Number(p.months) || 0;\n const years = Number(p.years) || 0;\n if (months || years) {\n out.setFullYear(out.getFullYear() + years);\n out.setMonth(out.getMonth() + months);\n }\n return out;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateAddTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return addToDate(d, (params ?? {}) as Params).toISOString();\n}\n\nexport function registerDateAddTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_ADD_TRANSFORM_ID, cellDateAddTransform, { type: 'cell' });\n}\n\nexport const CellDateAddTransform = {\n id: DATE_ADD_TRANSFORM_ID,\n transform: cellDateAddTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateAddTransform(registerFn);\n return DATE_ADD_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_SUBTRACT_TRANSFORM_ID = 'dateSubtract';\n\ntype Params = {\n days?: number;\n minutes?: number;\n hours?: number;\n seconds?: number;\n ms?: number;\n months?: number;\n years?: number;\n};\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction subtractFromDate(d: Date, p: Params): Date {\n const out = new Date(d.getTime());\n const ms = Number(p.ms) || 0;\n const sec = Number(p.seconds) || 0;\n const min = Number(p.minutes) || 0;\n const h = Number(p.hours) || 0;\n const days = Number(p.days) || 0;\n out.setTime(out.getTime() - ms - sec * 1000 - min * 60_000 - h * 3_600_000 - days * 86_400_000);\n const months = Number(p.months) || 0;\n const years = Number(p.years) || 0;\n if (months || years) {\n out.setFullYear(out.getFullYear() - years);\n out.setMonth(out.getMonth() - months);\n }\n return out;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateSubtractTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return subtractFromDate(d, (params ?? {}) as Params).toISOString();\n}\n\nexport function registerDateSubtractTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_SUBTRACT_TRANSFORM_ID, cellDateSubtractTransform, { type: 'cell' });\n}\n\nexport const CellDateSubtractTransform = {\n id: DATE_SUBTRACT_TRANSFORM_ID,\n transform: cellDateSubtractTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateSubtractTransform(registerFn);\n return DATE_SUBTRACT_TRANSFORM_ID;\n },\n};\n","import { Registry } from '../../../shared/registry/index.js';\nimport { registerToUpperTransform } from '../../../utils/controller/string/cell-to-upper-transform.js';\nimport { registerStringToLowerTransform } from '../../../utils/controller/string/cell-string-tolower-transform.js';\nimport { registerStringSliceTransform } from '../../../utils/controller/string/cell-string-slice-transform.js';\nimport { registerStringReplaceTransform } from '../../../utils/controller/string/cell-string-replace-transform.js';\nimport { registerStringReplaceByRegexTransform } from '../../../utils/controller/string/cell-string-replace-regex-transform.js';\nimport { registerStringFillStartTransform } from '../../../utils/controller/string/cell-string-fill-start-transform.js';\nimport { registerStringFillEndTransform } from '../../../utils/controller/string/cell-string-fill-end-transform.js';\nimport { registerStringExtractByRegexTransform } from '../../../utils/controller/string/cell-string-extract-regex-transform.js';\nimport { registerNumberAddTransform } from '../../../utils/controller/number/cell-number-add-transform.js';\nimport { registerNumberMultiplyTransform } from '../../../utils/controller/number/cell-number-multiply-transform.js';\nimport { registerNumberDivideTransform } from '../../../utils/controller/number/cell-number-divide-transform.js';\nimport { registerNumberSubtractTransform } from '../../../utils/controller/number/cell-number-subtract-transform.js';\nimport { registerNumberRoundTransform } from '../../../utils/controller/number/cell-number-round-transform.js';\nimport { registerNumberAbsTransform } from '../../../utils/controller/number/cell-number-abs-transform.js';\nimport { registerNumberSqrtTransform } from '../../../utils/controller/number/cell-number-sqrt-transform.js';\nimport { registerNumberLimitTransform } from '../../../utils/controller/number/cell-number-limit-transform.js';\nimport { registerNumberPercentTransform } from '../../../utils/controller/number/cell-number-percent-transform.js';\nimport { registerDateToOnlyTimeTransform } from '../../../utils/controller/date/cell-date-to-only-time-transform.js';\nimport { registerDateToOnlyDateTransform } from '../../../utils/controller/date/cell-date-to-only-date-transform.js';\nimport { registerDateToTimeDateTransform } from '../../../utils/controller/date/cell-date-to-time-date-transform.js';\nimport { registerDateToUtcTransform } from '../../../utils/controller/date/cell-date-to-utc-transform.js';\nimport { registerDateLimitTransform } from '../../../utils/controller/date/cell-date-limit-transform.js';\nimport { registerDateAddTransform } from '../../../utils/controller/date/cell-date-add-transform.js';\nimport { registerDateSubtractTransform } from '../../../utils/controller/date/cell-date-subtract-transform.js';\nimport type { Sheet } from '../../../types/sheet.js';\nimport type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\nimport type { TransformDeltaItem } from '../types/transform-delta.js';\nimport type { TransformGetters } from '../runner/run-transform.js';\n\ntype CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n p?: Readonly<Record<string, unknown>>\n) => unknown;\n\ntype RowTransformFn = (row: ValidatedRow, p?: Readonly<Record<string, unknown>>) => ValidatedRow;\n\ntype SheetTransformFn = (\n sheet: Sheet,\n p?: Readonly<Record<string, unknown>>,\n signal?: AbortSignal\n) => readonly TransformDeltaItem[] | Promise<readonly TransformDeltaItem[]>;\n\nconst registry = new Registry<(...args: unknown[]) => unknown>();\n\nfunction registerCellTransform(name: string, fn: CellTransformFn, opts: { type: 'cell' }): void {\n registry.register(name, fn, opts);\n}\n\nregisterToUpperTransform(registerCellTransform);\nregisterStringToLowerTransform(registerCellTransform);\nregisterStringSliceTransform(registerCellTransform);\nregisterStringReplaceTransform(registerCellTransform);\nregisterStringReplaceByRegexTransform(registerCellTransform);\nregisterStringFillStartTransform(registerCellTransform);\nregisterStringFillEndTransform(registerCellTransform);\nregisterStringExtractByRegexTransform(registerCellTransform);\nregisterNumberAddTransform(registerCellTransform);\nregisterNumberMultiplyTransform(registerCellTransform);\nregisterNumberDivideTransform(registerCellTransform);\nregisterNumberSubtractTransform(registerCellTransform);\nregisterNumberRoundTransform(registerCellTransform);\nregisterNumberAbsTransform(registerCellTransform);\nregisterNumberSqrtTransform(registerCellTransform);\nregisterNumberLimitTransform(registerCellTransform);\nregisterNumberPercentTransform(registerCellTransform);\nregisterDateToOnlyTimeTransform(registerCellTransform);\nregisterDateToOnlyDateTransform(registerCellTransform);\nregisterDateToTimeDateTransform(registerCellTransform);\nregisterDateToUtcTransform(registerCellTransform);\nregisterDateLimitTransform(registerCellTransform);\nregisterDateAddTransform(registerCellTransform);\nregisterDateSubtractTransform(registerCellTransform);\n\nfunction getCellTransform(name: string): CellTransformFn | undefined {\n const entry = registry.get(name);\n if (!entry || entry.type !== 'cell') return undefined;\n return entry.fn as CellTransformFn;\n}\n\nfunction getRowTransform(_name: string): RowTransformFn | undefined {\n return undefined;\n}\n\nfunction getSheetTransform(_name: string): SheetTransformFn | undefined {\n return undefined;\n}\n\nexport function getTransformGetters(): TransformGetters {\n return {\n getCellTransform,\n getRowTransform,\n getSheetTransform,\n };\n}\n","import * as Comlink from 'comlink';\nimport type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { Sheet } from '../../../types/sheet.js';\nimport type { TransformResult } from '../types/transform-delta.js';\nimport type { TransformProgressDetail } from '../types/transform-progress.js';\nimport { runTransform } from '../runner/run-transform.js';\nimport { getTransformGetters } from './worker-registry.js';\n\ntype ProgressCallback = (detail: TransformProgressDetail) => void;\n\nexport interface TransformWorkerOptions {\n signal?: AbortSignal;\n}\n\nconst api = {\n async transform(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n options?: TransformWorkerOptions,\n onProgress?: ProgressCallback,\n ): Promise<TransformResult> {\n const getters = getTransformGetters();\n return runTransform(\n sheet,\n sheetLayout,\n getters,\n onProgress,\n options?.signal,\n );\n },\n};\n\nComlink.expose(api);\n"],"mappings":"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","names":["proxyMarker","createEndpoint","releaseProxy","finalizer","throwMarker","isObject","val","proxyTransferHandler","obj","port1","port2","expose","port","wrap","throwTransferHandler","value","serialized","transferHandlers","isAllowedOrigin","allowedOrigins","origin","allowedOrigin","ep","callback","ev","id","type","path","argumentList","fromWireValue","returnValue","parent","prop","rawValue","proxy","transfer","wireValue","transferables","toWireValue","closeEndPoint","error","isMessagePort","endpoint","target","pendingListeners","data","resolver","createProxy","throwIfProxyReleased","isReleased","releaseEndpoint","requestResponseMessage","proxyCounter","proxyFinalizers","newCount","registerProxy","unregisterProxy","isProxyReleased","_target","r","p","_thisArg","rawArgumentList","last","processArguments","myFlat","arr","processed","v","transferCache","transfers","toWireValue","value","name","handler","transferHandlers","serializedValue","transferables","transferCache","fromWireValue","requestResponseMessage","ep","pendingListeners","msg","transfers","resolve","id","generateUUID","resolveTransformRef","ref","runCellTransforms","cell","row","field","getTransform","list","current","ref","name","params","resolveTransformRef","fn","runRowTransforms","row","sheetLayout","getTransform","list","current","ref","name","params","resolveTransformRef","fn","EXTERNAL_TRANSFORM_FAILED","runSheetTransforms","sheet","sheetLayout","getTransform","signal","list","deltas","errors","ref","name","params","resolveTransformRef","fn","result","patchCellInRow","rows","rowIndex","col","newValue","row","cells","cell","applyTransformDelta","sheet","delta","item","THROTTLE_MS","THROTTLE_PERCENT","CHUNK_SIZE","createThrottledProgress","totalRows","onProgress","lastTime","lastPercent","processed","now","localPercent","diffRowToDeltas","rowIndex","before","after","out","beforeCells","c","cell","prev","runTransform","sheet","sheetLayout","getters","signal","fields","reportProgress","deltas","i","end","r","row","rowDeltas","updatedCells","field","newValue","runCellTransforms","updatedRow","afterRow","runRowTransforms","rowDiff","transformedSheet","applyTransformDelta","sheetOut","runSheetTransforms","errors","Registry","name","fn","options","type","e","entry","TO_UPPER_TRANSFORM_ID","cellToUpperTransform","value","_cell","_row","_params","registerToUpperTransform","register","TO_LOWER_TRANSFORM_ID","cellStringToLowerTransform","value","_cell","_row","_params","registerStringToLowerTransform","register","SLICE_TRANSFORM_ID","cellStringSliceTransform","value","_cell","_row","params","start","end","e","registerStringSliceTransform","register","REPLACE_STR_TRANSFORM_ID","cellStringReplaceTransform","value","_cell","_row","params","search","replacement","registerStringReplaceTransform","register","REPLACE_BY_REGEX_TRANSFORM_ID","cellStringReplaceByRegexTransform","value","_cell","_row","params","pattern","flags","replacement","re","registerStringReplaceByRegexTransform","register","FILL_START_TRANSFORM_ID","cellStringFillStartTransform","value","_cell","_row","params","s","length","fill","safeLength","registerStringFillStartTransform","register","FILL_END_TRANSFORM_ID","cellStringFillEndTransform","value","_cell","_row","params","s","length","fill","safeLength","registerStringFillEndTransform","register","EXTRACT_BY_REGEX_TRANSFORM_ID","cellStringExtractByRegexTransform","value","_cell","_row","params","s","pattern","flags","group","re","g","registerStringExtractByRegexTransform","register","NUMBER_ADD_TRANSFORM_ID","toNumber","v","cellNumberAddTransform","value","_cell","_row","params","n","add","delta","registerNumberAddTransform","register","NUMBER_MULTIPLY_TRANSFORM_ID","toNumber","v","cellNumberMultiplyTransform","value","_cell","_row","params","n","factor","f","registerNumberMultiplyTransform","register","NUMBER_DIVIDE_TRANSFORM_ID","toNumber","v","cellNumberDivideTransform","value","_cell","_row","params","n","divisor","d","registerNumberDivideTransform","register","NUMBER_SUBTRACT_TRANSFORM_ID","toNumber","v","cellNumberSubtractTransform","value","_cell","_row","params","n","sub","delta","registerNumberSubtractTransform","register","NUMBER_ROUND_TRANSFORM_ID","toNumber","v","cellNumberRoundTransform","value","_cell","_row","params","n","mode","registerNumberRoundTransform","register","NUMBER_ABS_TRANSFORM_ID","toNumber","v","cellNumberAbsTransform","value","_cell","_row","_params","n","registerNumberAbsTransform","register","NUMBER_SQRT_TRANSFORM_ID","toNumber","v","cellNumberSqrtTransform","value","_cell","_row","_params","n","registerNumberSqrtTransform","register","NUMBER_LIMIT_TRANSFORM_ID","toNumber","v","cellNumberLimitTransform","value","_cell","_row","params","n","min","max","out","minVal","maxVal","registerNumberLimitTransform","register","NUMBER_PERCENT_TRANSFORM_ID","toNumber","v","cellNumberPercentTransform","value","_cell","_row","params","n","total","t","registerNumberPercentTransform","register","DATE_TO_ONLY_TIME_TRANSFORM_ID","parseToDate","value","s","ms","toISOTimeString","d","h","min","cellDateToOnlyTimeTransform","_cell","_row","_params","registerDateToOnlyTimeTransform","register","DATE_TO_ONLY_DATE_TRANSFORM_ID","parseToDate","value","s","ms","toISODateString","d","y","m","day","cellDateToOnlyDateTransform","_cell","_row","_params","registerDateToOnlyDateTransform","register","DATE_TO_TIME_DATE_TRANSFORM_ID","parseToDate","value","s","ms","toISODateString","d","y","m","day","toISOTimeString","h","min","cellDateToTimeDateTransform","_cell","_row","_params","registerDateToTimeDateTransform","register","DATE_TO_UTC_TRANSFORM_ID","parseToDate","value","s","ms","cellDateToUtcTransform","_cell","_row","_params","d","registerDateToUtcTransform","register","DATE_LIMIT_TRANSFORM_ID","parseToDate","value","s","ms","n","cellDateLimitTransform","_cell","_row","params","d","min","max","out","minD","maxD","registerDateLimitTransform","register","DATE_ADD_TRANSFORM_ID","parseToDate","value","s","ms","addToDate","d","p","out","sec","min","h","days","months","years","cellDateAddTransform","_cell","_row","params","registerDateAddTransform","register","DATE_SUBTRACT_TRANSFORM_ID","parseToDate","value","s","ms","subtractFromDate","d","p","out","sec","min","h","days","months","years","cellDateSubtractTransform","_cell","_row","params","registerDateSubtractTransform","register","registry","Registry","registerCellTransform","name","fn","opts","registerToUpperTransform","registerStringToLowerTransform","registerStringSliceTransform","registerStringReplaceTransform","registerStringReplaceByRegexTransform","registerStringFillStartTransform","registerStringFillEndTransform","registerStringExtractByRegexTransform","registerNumberAddTransform","registerNumberMultiplyTransform","registerNumberDivideTransform","registerNumberSubtractTransform","registerNumberRoundTransform","registerNumberAbsTransform","registerNumberSqrtTransform","registerNumberLimitTransform","registerNumberPercentTransform","registerDateToOnlyTimeTransform","registerDateToOnlyDateTransform","registerDateToTimeDateTransform","registerDateToUtcTransform","registerDateLimitTransform","registerDateAddTransform","registerDateSubtractTransform","getCellTransform","entry","getRowTransform","_name","getSheetTransform","getTransformGetters","api","sheet","sheetLayout","options","onProgress","getters","getTransformGetters","runTransform","expose"]}
|
|
1
|
+
{"version":3,"sources":["../node_modules/comlink/src/comlink.ts","../src/core/transform/runner/resolve-transform-ref.ts","../src/core/transform/runner/cell-transforms.ts","../src/core/transform/runner/row-transforms.ts","../src/core/transform/runner/sheet-transforms.ts","../src/core/transform/delta-applier.ts","../src/core/transform/runner/run-transform.ts","../src/shared/registry/Registry.ts","../src/utils/controller/string/cell-to-upper-transform.ts","../src/utils/controller/string/cell-string-tolower-transform.ts","../src/utils/controller/string/cell-string-slice-transform.ts","../src/utils/controller/string/cell-string-replace-transform.ts","../src/utils/controller/string/cell-string-replace-regex-transform.ts","../src/utils/controller/string/cell-string-fill-start-transform.ts","../src/utils/controller/string/cell-string-fill-end-transform.ts","../src/utils/controller/string/cell-string-extract-regex-transform.ts","../src/utils/controller/number/cell-number-add-transform.ts","../src/utils/controller/number/cell-number-multiply-transform.ts","../src/utils/controller/number/cell-number-divide-transform.ts","../src/utils/controller/number/cell-number-subtract-transform.ts","../src/utils/controller/number/cell-number-round-transform.ts","../src/utils/controller/number/cell-number-abs-transform.ts","../src/utils/controller/number/cell-number-sqrt-transform.ts","../src/utils/controller/number/cell-number-limit-transform.ts","../src/utils/controller/number/cell-number-percent-transform.ts","../src/utils/controller/date/cell-date-to-only-time-transform.ts","../src/utils/controller/date/cell-date-to-only-date-transform.ts","../src/utils/controller/date/cell-date-to-time-date-transform.ts","../src/utils/controller/date/cell-date-to-utc-transform.ts","../src/utils/controller/date/cell-date-limit-transform.ts","../src/utils/controller/date/cell-date-add-transform.ts","../src/utils/controller/date/cell-date-subtract-transform.ts","../src/core/transform/worker/worker-registry.ts","../src/core/transform/worker/transform.worker.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport {\n Endpoint,\n EventSource,\n Message,\n MessageType,\n PostMessageWithOrigin,\n WireValue,\n WireValueType,\n} from \"./protocol\";\nexport type { Endpoint };\n\nexport const proxyMarker = Symbol(\"Comlink.proxy\");\nexport const createEndpoint = Symbol(\"Comlink.endpoint\");\nexport const releaseProxy = Symbol(\"Comlink.releaseProxy\");\nexport const finalizer = Symbol(\"Comlink.finalizer\");\n\nconst throwMarker = Symbol(\"Comlink.thrown\");\n\n/**\n * Interface of values that were marked to be proxied with `comlink.proxy()`.\n * Can also be implemented by classes.\n */\nexport interface ProxyMarked {\n [proxyMarker]: true;\n}\n\n/**\n * Takes a type and wraps it in a Promise, if it not already is one.\n * This is to avoid `Promise<Promise<T>>`.\n *\n * This is the inverse of `Unpromisify<T>`.\n */\ntype Promisify<T> = T extends Promise<unknown> ? T : Promise<T>;\n/**\n * Takes a type that may be Promise and unwraps the Promise type.\n * If `P` is not a Promise, it returns `P`.\n *\n * This is the inverse of `Promisify<T>`.\n */\ntype Unpromisify<P> = P extends Promise<infer T> ? T : P;\n\n/**\n * Takes the raw type of a remote property and returns the type that is visible to the local thread on the proxy.\n *\n * Note: This needs to be its own type alias, otherwise it will not distribute over unions.\n * See https://www.typescriptlang.org/docs/handbook/advanced-types.html#distributive-conditional-types\n */\ntype RemoteProperty<T> =\n // If the value is a method, comlink will proxy it automatically.\n // Objects are only proxied if they are marked to be proxied.\n // Otherwise, the property is converted to a Promise that resolves the cloned value.\n T extends Function | ProxyMarked ? Remote<T> : Promisify<T>;\n\n/**\n * Takes the raw type of a property as a remote thread would see it through a proxy (e.g. when passed in as a function\n * argument) and returns the type that the local thread has to supply.\n *\n * This is the inverse of `RemoteProperty<T>`.\n *\n * Note: This needs to be its own type alias, otherwise it will not distribute over unions. See\n * https://www.typescriptlang.org/docs/handbook/advanced-types.html#distributive-conditional-types\n */\ntype LocalProperty<T> = T extends Function | ProxyMarked\n ? Local<T>\n : Unpromisify<T>;\n\n/**\n * Proxies `T` if it is a `ProxyMarked`, clones it otherwise (as handled by structured cloning and transfer handlers).\n */\nexport type ProxyOrClone<T> = T extends ProxyMarked ? Remote<T> : T;\n/**\n * Inverse of `ProxyOrClone<T>`.\n */\nexport type UnproxyOrClone<T> = T extends RemoteObject<ProxyMarked>\n ? Local<T>\n : T;\n\n/**\n * Takes the raw type of a remote object in the other thread and returns the type as it is visible to the local thread\n * when proxied with `Comlink.proxy()`.\n *\n * This does not handle call signatures, which is handled by the more general `Remote<T>` type.\n *\n * @template T The raw type of a remote object as seen in the other thread.\n */\nexport type RemoteObject<T> = { [P in keyof T]: RemoteProperty<T[P]> };\n/**\n * Takes the type of an object as a remote thread would see it through a proxy (e.g. when passed in as a function\n * argument) and returns the type that the local thread has to supply.\n *\n * This does not handle call signatures, which is handled by the more general `Local<T>` type.\n *\n * This is the inverse of `RemoteObject<T>`.\n *\n * @template T The type of a proxied object.\n */\nexport type LocalObject<T> = { [P in keyof T]: LocalProperty<T[P]> };\n\n/**\n * Additional special comlink methods available on each proxy returned by `Comlink.wrap()`.\n */\nexport interface ProxyMethods {\n [createEndpoint]: () => Promise<MessagePort>;\n [releaseProxy]: () => void;\n}\n\n/**\n * Takes the raw type of a remote object, function or class in the other thread and returns the type as it is visible to\n * the local thread from the proxy return value of `Comlink.wrap()` or `Comlink.proxy()`.\n */\nexport type Remote<T> =\n // Handle properties\n RemoteObject<T> &\n // Handle call signature (if present)\n (T extends (...args: infer TArguments) => infer TReturn\n ? (\n ...args: { [I in keyof TArguments]: UnproxyOrClone<TArguments[I]> }\n ) => Promisify<ProxyOrClone<Unpromisify<TReturn>>>\n : unknown) &\n // Handle construct signature (if present)\n // The return of construct signatures is always proxied (whether marked or not)\n (T extends { new (...args: infer TArguments): infer TInstance }\n ? {\n new (\n ...args: {\n [I in keyof TArguments]: UnproxyOrClone<TArguments[I]>;\n }\n ): Promisify<Remote<TInstance>>;\n }\n : unknown) &\n // Include additional special comlink methods available on the proxy.\n ProxyMethods;\n\n/**\n * Expresses that a type can be either a sync or async.\n */\ntype MaybePromise<T> = Promise<T> | T;\n\n/**\n * Takes the raw type of a remote object, function or class as a remote thread would see it through a proxy (e.g. when\n * passed in as a function argument) and returns the type the local thread has to supply.\n *\n * This is the inverse of `Remote<T>`. It takes a `Remote<T>` and returns its original input `T`.\n */\nexport type Local<T> =\n // Omit the special proxy methods (they don't need to be supplied, comlink adds them)\n Omit<LocalObject<T>, keyof ProxyMethods> &\n // Handle call signatures (if present)\n (T extends (...args: infer TArguments) => infer TReturn\n ? (\n ...args: { [I in keyof TArguments]: ProxyOrClone<TArguments[I]> }\n ) => // The raw function could either be sync or async, but is always proxied automatically\n MaybePromise<UnproxyOrClone<Unpromisify<TReturn>>>\n : unknown) &\n // Handle construct signature (if present)\n // The return of construct signatures is always proxied (whether marked or not)\n (T extends { new (...args: infer TArguments): infer TInstance }\n ? {\n new (\n ...args: {\n [I in keyof TArguments]: ProxyOrClone<TArguments[I]>;\n }\n ): // The raw constructor could either be sync or async, but is always proxied automatically\n MaybePromise<Local<Unpromisify<TInstance>>>;\n }\n : unknown);\n\nconst isObject = (val: unknown): val is object =>\n (typeof val === \"object\" && val !== null) || typeof val === \"function\";\n\n/**\n * Customizes the serialization of certain values as determined by `canHandle()`.\n *\n * @template T The input type being handled by this transfer handler.\n * @template S The serialized type sent over the wire.\n */\nexport interface TransferHandler<T, S> {\n /**\n * Gets called for every value to determine whether this transfer handler\n * should serialize the value, which includes checking that it is of the right\n * type (but can perform checks beyond that as well).\n */\n canHandle(value: unknown): value is T;\n\n /**\n * Gets called with the value if `canHandle()` returned `true` to produce a\n * value that can be sent in a message, consisting of structured-cloneable\n * values and/or transferrable objects.\n */\n serialize(value: T): [S, Transferable[]];\n\n /**\n * Gets called to deserialize an incoming value that was serialized in the\n * other thread with this transfer handler (known through the name it was\n * registered under).\n */\n deserialize(value: S): T;\n}\n\n/**\n * Internal transfer handle to handle objects marked to proxy.\n */\nconst proxyTransferHandler: TransferHandler<object, MessagePort> = {\n canHandle: (val): val is ProxyMarked =>\n isObject(val) && (val as ProxyMarked)[proxyMarker],\n serialize(obj) {\n const { port1, port2 } = new MessageChannel();\n expose(obj, port1);\n return [port2, [port2]];\n },\n deserialize(port) {\n port.start();\n return wrap(port);\n },\n};\n\ninterface ThrownValue {\n [throwMarker]: unknown; // just needs to be present\n value: unknown;\n}\ntype SerializedThrownValue =\n | { isError: true; value: Error }\n | { isError: false; value: unknown };\ntype PendingListenersMap = Map<\n string,\n (value: WireValue | PromiseLike<WireValue>) => void\n>;\n\n/**\n * Internal transfer handler to handle thrown exceptions.\n */\nconst throwTransferHandler: TransferHandler<\n ThrownValue,\n SerializedThrownValue\n> = {\n canHandle: (value): value is ThrownValue =>\n isObject(value) && throwMarker in value,\n serialize({ value }) {\n let serialized: SerializedThrownValue;\n if (value instanceof Error) {\n serialized = {\n isError: true,\n value: {\n message: value.message,\n name: value.name,\n stack: value.stack,\n },\n };\n } else {\n serialized = { isError: false, value };\n }\n return [serialized, []];\n },\n deserialize(serialized) {\n if (serialized.isError) {\n throw Object.assign(\n new Error(serialized.value.message),\n serialized.value\n );\n }\n throw serialized.value;\n },\n};\n\n/**\n * Allows customizing the serialization of certain values.\n */\nexport const transferHandlers = new Map<\n string,\n TransferHandler<unknown, unknown>\n>([\n [\"proxy\", proxyTransferHandler],\n [\"throw\", throwTransferHandler],\n]);\n\nfunction isAllowedOrigin(\n allowedOrigins: (string | RegExp)[],\n origin: string\n): boolean {\n for (const allowedOrigin of allowedOrigins) {\n if (origin === allowedOrigin || allowedOrigin === \"*\") {\n return true;\n }\n if (allowedOrigin instanceof RegExp && allowedOrigin.test(origin)) {\n return true;\n }\n }\n return false;\n}\n\nexport function expose(\n obj: any,\n ep: Endpoint = globalThis as any,\n allowedOrigins: (string | RegExp)[] = [\"*\"]\n) {\n ep.addEventListener(\"message\", function callback(ev: MessageEvent) {\n if (!ev || !ev.data) {\n return;\n }\n if (!isAllowedOrigin(allowedOrigins, ev.origin)) {\n console.warn(`Invalid origin '${ev.origin}' for comlink proxy`);\n return;\n }\n const { id, type, path } = {\n path: [] as string[],\n ...(ev.data as Message),\n };\n const argumentList = (ev.data.argumentList || []).map(fromWireValue);\n let returnValue;\n try {\n const parent = path.slice(0, -1).reduce((obj, prop) => obj[prop], obj);\n const rawValue = path.reduce((obj, prop) => obj[prop], obj);\n switch (type) {\n case MessageType.GET:\n {\n returnValue = rawValue;\n }\n break;\n case MessageType.SET:\n {\n parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);\n returnValue = true;\n }\n break;\n case MessageType.APPLY:\n {\n returnValue = rawValue.apply(parent, argumentList);\n }\n break;\n case MessageType.CONSTRUCT:\n {\n const value = new rawValue(...argumentList);\n returnValue = proxy(value);\n }\n break;\n case MessageType.ENDPOINT:\n {\n const { port1, port2 } = new MessageChannel();\n expose(obj, port2);\n returnValue = transfer(port1, [port1]);\n }\n break;\n case MessageType.RELEASE:\n {\n returnValue = undefined;\n }\n break;\n default:\n return;\n }\n } catch (value) {\n returnValue = { value, [throwMarker]: 0 };\n }\n Promise.resolve(returnValue)\n .catch((value) => {\n return { value, [throwMarker]: 0 };\n })\n .then((returnValue) => {\n const [wireValue, transferables] = toWireValue(returnValue);\n ep.postMessage({ ...wireValue, id }, transferables);\n if (type === MessageType.RELEASE) {\n // detach and deactive after sending release response above.\n ep.removeEventListener(\"message\", callback as any);\n closeEndPoint(ep);\n if (finalizer in obj && typeof obj[finalizer] === \"function\") {\n obj[finalizer]();\n }\n }\n })\n .catch((error) => {\n // Send Serialization Error To Caller\n const [wireValue, transferables] = toWireValue({\n value: new TypeError(\"Unserializable return value\"),\n [throwMarker]: 0,\n });\n ep.postMessage({ ...wireValue, id }, transferables);\n });\n } as any);\n if (ep.start) {\n ep.start();\n }\n}\n\nfunction isMessagePort(endpoint: Endpoint): endpoint is MessagePort {\n return endpoint.constructor.name === \"MessagePort\";\n}\n\nfunction closeEndPoint(endpoint: Endpoint) {\n if (isMessagePort(endpoint)) endpoint.close();\n}\n\nexport function wrap<T>(ep: Endpoint, target?: any): Remote<T> {\n const pendingListeners : PendingListenersMap = new Map();\n\n ep.addEventListener(\"message\", function handleMessage(ev: Event) {\n const { data } = ev as MessageEvent;\n if (!data || !data.id) {\n return;\n }\n const resolver = pendingListeners.get(data.id);\n if (!resolver) {\n return;\n }\n\n try {\n resolver(data);\n } finally {\n pendingListeners.delete(data.id);\n }\n });\n\n return createProxy<T>(ep, pendingListeners, [], target) as any;\n}\n\nfunction throwIfProxyReleased(isReleased: boolean) {\n if (isReleased) {\n throw new Error(\"Proxy has been released and is not useable\");\n }\n}\n\nfunction releaseEndpoint(ep: Endpoint) {\n return requestResponseMessage(ep, new Map(), {\n type: MessageType.RELEASE,\n }).then(() => {\n closeEndPoint(ep);\n });\n}\n\ninterface FinalizationRegistry<T> {\n new (cb: (heldValue: T) => void): FinalizationRegistry<T>;\n register(\n weakItem: object,\n heldValue: T,\n unregisterToken?: object | undefined\n ): void;\n unregister(unregisterToken: object): void;\n}\ndeclare var FinalizationRegistry: FinalizationRegistry<Endpoint>;\n\nconst proxyCounter = new WeakMap<Endpoint, number>();\nconst proxyFinalizers =\n \"FinalizationRegistry\" in globalThis &&\n new FinalizationRegistry((ep: Endpoint) => {\n const newCount = (proxyCounter.get(ep) || 0) - 1;\n proxyCounter.set(ep, newCount);\n if (newCount === 0) {\n releaseEndpoint(ep);\n }\n });\n\nfunction registerProxy(proxy: object, ep: Endpoint) {\n const newCount = (proxyCounter.get(ep) || 0) + 1;\n proxyCounter.set(ep, newCount);\n if (proxyFinalizers) {\n proxyFinalizers.register(proxy, ep, proxy);\n }\n}\n\nfunction unregisterProxy(proxy: object) {\n if (proxyFinalizers) {\n proxyFinalizers.unregister(proxy);\n }\n}\n\nfunction createProxy<T>(\n ep: Endpoint,\n pendingListeners: PendingListenersMap,\n path: (string | number | symbol)[] = [],\n target: object = function () {}\n): Remote<T> {\n let isProxyReleased = false;\n const proxy = new Proxy(target, {\n get(_target, prop) {\n throwIfProxyReleased(isProxyReleased);\n if (prop === releaseProxy) {\n return () => {\n unregisterProxy(proxy);\n releaseEndpoint(ep);\n pendingListeners.clear();\n isProxyReleased = true;\n };\n }\n if (prop === \"then\") {\n if (path.length === 0) {\n return { then: () => proxy };\n }\n const r = requestResponseMessage(ep, pendingListeners, {\n type: MessageType.GET,\n path: path.map((p) => p.toString()),\n }).then(fromWireValue);\n return r.then.bind(r);\n }\n return createProxy(ep, pendingListeners, [...path, prop]);\n },\n set(_target, prop, rawValue) {\n throwIfProxyReleased(isProxyReleased);\n // FIXME: ES6 Proxy Handler `set` methods are supposed to return a\n // boolean. To show good will, we return true asynchronously ¯\\_(ツ)_/¯\n const [value, transferables] = toWireValue(rawValue);\n return requestResponseMessage(\n ep,\n pendingListeners,\n {\n type: MessageType.SET,\n path: [...path, prop].map((p) => p.toString()),\n value,\n },\n transferables\n ).then(fromWireValue) as any;\n },\n apply(_target, _thisArg, rawArgumentList) {\n throwIfProxyReleased(isProxyReleased);\n const last = path[path.length - 1];\n if ((last as any) === createEndpoint) {\n return requestResponseMessage(ep, pendingListeners, {\n type: MessageType.ENDPOINT,\n }).then(fromWireValue);\n }\n // We just pretend that `bind()` didn’t happen.\n if (last === \"bind\") {\n return createProxy(ep, pendingListeners, path.slice(0, -1));\n }\n const [argumentList, transferables] = processArguments(rawArgumentList);\n return requestResponseMessage(\n ep,\n pendingListeners,\n {\n type: MessageType.APPLY,\n path: path.map((p) => p.toString()),\n argumentList,\n },\n transferables\n ).then(fromWireValue);\n },\n construct(_target, rawArgumentList) {\n throwIfProxyReleased(isProxyReleased);\n const [argumentList, transferables] = processArguments(rawArgumentList);\n return requestResponseMessage(\n ep,\n pendingListeners,\n {\n type: MessageType.CONSTRUCT,\n path: path.map((p) => p.toString()),\n argumentList,\n },\n transferables\n ).then(fromWireValue);\n },\n });\n registerProxy(proxy, ep);\n return proxy as any;\n}\n\nfunction myFlat<T>(arr: (T | T[])[]): T[] {\n return Array.prototype.concat.apply([], arr);\n}\n\nfunction processArguments(argumentList: any[]): [WireValue[], Transferable[]] {\n const processed = argumentList.map(toWireValue);\n return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];\n}\n\nconst transferCache = new WeakMap<any, Transferable[]>();\nexport function transfer<T>(obj: T, transfers: Transferable[]): T {\n transferCache.set(obj, transfers);\n return obj;\n}\n\nexport function proxy<T extends {}>(obj: T): T & ProxyMarked {\n return Object.assign(obj, { [proxyMarker]: true }) as any;\n}\n\nexport function windowEndpoint(\n w: PostMessageWithOrigin,\n context: EventSource = globalThis,\n targetOrigin = \"*\"\n): Endpoint {\n return {\n postMessage: (msg: any, transferables: Transferable[]) =>\n w.postMessage(msg, targetOrigin, transferables),\n addEventListener: context.addEventListener.bind(context),\n removeEventListener: context.removeEventListener.bind(context),\n };\n}\n\nfunction toWireValue(value: any): [WireValue, Transferable[]] {\n for (const [name, handler] of transferHandlers) {\n if (handler.canHandle(value)) {\n const [serializedValue, transferables] = handler.serialize(value);\n return [\n {\n type: WireValueType.HANDLER,\n name,\n value: serializedValue,\n },\n transferables,\n ];\n }\n }\n return [\n {\n type: WireValueType.RAW,\n value,\n },\n transferCache.get(value) || [],\n ];\n}\n\nfunction fromWireValue(value: WireValue): any {\n switch (value.type) {\n case WireValueType.HANDLER:\n return transferHandlers.get(value.name)!.deserialize(value.value);\n case WireValueType.RAW:\n return value.value;\n }\n}\n\nfunction requestResponseMessage(\n ep: Endpoint,\n pendingListeners: PendingListenersMap,\n msg: Message,\n transfers?: Transferable[]\n): Promise<WireValue> {\n return new Promise((resolve) => {\n const id = generateUUID();\n pendingListeners.set(id, resolve);\n if (ep.start) {\n ep.start();\n }\n ep.postMessage({ id, ...msg }, transfers);\n});\n}\n\nfunction generateUUID(): string {\n return new Array(4)\n .fill(0)\n .map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16))\n .join(\"-\");\n}\n","import type { ValidatorOrWithParams } from '../../../types/sheet-layout.js';\n\nexport interface ResolvedTransformRef {\n readonly name: string;\n readonly params?: Readonly<Record<string, unknown>>;\n}\n\nexport function resolveTransformRef(ref: ValidatorOrWithParams): ResolvedTransformRef {\n if (typeof ref === 'string') return { name: ref };\n return { name: ref.name, params: ref.params };\n}\n","import type { SheetLayoutField } from '../../../types/sheet-layout.js';\nimport type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\nimport { resolveTransformRef } from './resolve-transform-ref.js';\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>,\n) => unknown;\n\nexport type GetCellTransform = (name: string) => CellTransformFn | undefined;\n\nexport function runCellTransforms(\n cell: ValidatedCell,\n row: ValidatedRow,\n field: SheetLayoutField,\n getTransform: GetCellTransform,\n): unknown {\n if (cell.errors.length > 0) return cell.value;\n const list = field.transformations;\n if (!list?.length) return cell.value;\n let current: unknown = cell.value;\n for (const ref of list) {\n const { name, params } = resolveTransformRef(ref);\n const fn = getTransform(name);\n if (fn) current = fn(current, cell, row, params);\n }\n return current;\n}\n","import type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { ValidatedRow } from '../../../types/sheet.js';\nimport { resolveTransformRef } from './resolve-transform-ref.js';\n\nexport type RowTransformFn = (\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>,\n) => ValidatedRow;\n\nexport type GetRowTransform = (name: string) => RowTransformFn | undefined;\n\nexport function runRowTransforms(\n row: ValidatedRow,\n sheetLayout: SheetLayout,\n getTransform: GetRowTransform,\n): ValidatedRow {\n if (row.errors.length > 0) return row;\n const list = sheetLayout.rowTransformations;\n if (!list?.length) return row;\n let current: ValidatedRow = row;\n for (const ref of list) {\n const { name, params } = resolveTransformRef(ref);\n const fn = getTransform(name);\n if (fn) current = fn(current, params);\n }\n return current;\n}\n","import type { SheetError } from '../../../types/error.js';\nimport type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { Sheet } from '../../../types/sheet.js';\nimport type { TransformDeltaItem } from '../types/transform-delta.js';\nimport { resolveTransformRef } from './resolve-transform-ref.js';\n\nexport const EXTERNAL_TRANSFORM_FAILED = 'EXTERNAL_TRANSFORM_FAILED';\n\nexport type SheetTransformFn = (\n sheet: Sheet,\n params?: Readonly<Record<string, unknown>>,\n signal?: AbortSignal,\n) => readonly TransformDeltaItem[] | Promise<readonly TransformDeltaItem[]>;\n\nexport type GetSheetTransform = (name: string) => SheetTransformFn | undefined;\n\nexport interface SheetTransformOutput {\n readonly deltas: TransformDeltaItem[];\n readonly errors: SheetError[];\n}\n\nexport async function runSheetTransforms(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n getTransform: GetSheetTransform,\n signal?: AbortSignal,\n): Promise<SheetTransformOutput> {\n const list = sheetLayout.sheetTransformations;\n if (!list?.length) return { deltas: [], errors: [] };\n const deltas: TransformDeltaItem[] = [];\n const errors: SheetError[] = [];\n for (const ref of list) {\n const { name, params } = resolveTransformRef(ref);\n const fn = getTransform(name);\n if (!fn) continue;\n try {\n const result = await Promise.resolve(fn(sheet, params, signal));\n if (result?.length) deltas.push(...result);\n } catch {\n errors.push({\n code: EXTERNAL_TRANSFORM_FAILED,\n level: 'fatal',\n params: { reason: 'network' },\n });\n }\n }\n return { deltas, errors };\n}\n","import type { Sheet, ValidatedCell, ValidatedRow } from '../../types/sheet.js';\nimport type { TransformDelta } from './types/transform-delta.js';\n\nfunction patchCellInRow(\n rows: ValidatedRow[],\n rowIndex: number,\n col: string,\n newValue: unknown,\n): ValidatedRow[] {\n return rows.map((row) => {\n if (row.index !== rowIndex) return row;\n const cells: ValidatedCell[] = row.cells.map((cell) =>\n cell.key === col ? { ...cell, value: newValue } : cell,\n );\n return { ...row, cells };\n });\n}\n\nexport function applyTransformDelta(sheet: Sheet, delta: TransformDelta): Sheet {\n if (!delta.deltas.length) return sheet;\n let rows = [...sheet.rows];\n for (const item of delta.deltas) {\n if (item.row < 0) continue;\n rows = patchCellInRow(rows, item.row, item.col, item.newValue);\n }\n return { ...sheet, rows };\n}\n","import type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { Sheet, ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\nimport type { TransformDeltaItem, TransformResult } from '../types/transform-delta.js';\nimport type { TransformProgressDetail } from '../types/transform-progress.js';\nimport { runCellTransforms } from './cell-transforms.js';\nimport { runRowTransforms } from './row-transforms.js';\nimport { runSheetTransforms } from './sheet-transforms.js';\nimport type { GetCellTransform } from './cell-transforms.js';\nimport type { GetRowTransform } from './row-transforms.js';\nimport type { GetSheetTransform } from './sheet-transforms.js';\nimport { applyTransformDelta } from '../delta-applier.js';\n\nconst THROTTLE_MS = 16;\nconst THROTTLE_PERCENT = 1;\nconst CHUNK_SIZE = 200;\n\nexport interface TransformGetters {\n getCellTransform: GetCellTransform;\n getRowTransform: GetRowTransform;\n getSheetTransform: GetSheetTransform;\n}\n\nfunction createThrottledProgress(\n totalRows: number,\n onProgress: (d: TransformProgressDetail) => void,\n): (processed: number) => void {\n let lastTime = 0;\n let lastPercent = -1;\n return (processed: number) => {\n const now = Date.now();\n const localPercent = totalRows > 0 ? Math.floor((processed / totalRows) * 100) : 100;\n const shouldEmit =\n now - lastTime >= THROTTLE_MS ||\n localPercent - lastPercent >= THROTTLE_PERCENT ||\n processed >= totalRows;\n if (shouldEmit && totalRows > 0) {\n lastTime = now;\n lastPercent = localPercent;\n onProgress({\n phase: 'transforming',\n localPercent,\n currentRow: processed,\n totalRows,\n });\n }\n };\n}\n\nfunction diffRowToDeltas(\n rowIndex: number,\n before: ValidatedRow,\n after: ValidatedRow,\n): TransformDeltaItem[] {\n const out: TransformDeltaItem[] = [];\n const beforeCells = new Map(before.cells.map((c) => [c.key, c]));\n for (const cell of after.cells) {\n const prev = beforeCells.get(cell.key);\n if (prev && prev.value !== cell.value) {\n out.push({ row: rowIndex, col: cell.key, newValue: cell.value });\n }\n }\n return out;\n}\n\nexport async function runTransform(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n getters: TransformGetters,\n onProgress?: (d: TransformProgressDetail) => void,\n signal?: AbortSignal,\n): Promise<TransformResult> {\n if (sheet.errors.length > 0) return { deltas: [] };\n const fields = sheetLayout.fields;\n const totalRows = sheet.rows.length;\n const reportProgress = onProgress ? createThrottledProgress(totalRows, onProgress) : () => {};\n const deltas: TransformDeltaItem[] = [];\n\n for (let i = 0; i < totalRows; i += CHUNK_SIZE) {\n const end = Math.min(i + CHUNK_SIZE, totalRows);\n for (let r = i; r < end; r++) {\n const row = sheet.rows[r];\n if (!row || row.errors.length > 0) continue;\n const rowDeltas: TransformDeltaItem[] = [];\n const updatedCells: ValidatedCell[] = [];\n for (const cell of row.cells) {\n const field = fields[cell.key];\n if (!field) {\n updatedCells.push(cell);\n continue;\n }\n const newValue = runCellTransforms(\n cell,\n row,\n field,\n getters.getCellTransform,\n );\n if (newValue !== cell.value) {\n rowDeltas.push({ row: row.index, col: cell.key, newValue });\n }\n updatedCells.push({ ...cell, value: newValue });\n }\n const updatedRow: ValidatedRow = { ...row, cells: updatedCells };\n const afterRow = runRowTransforms(updatedRow, sheetLayout, getters.getRowTransform);\n const rowDiff = diffRowToDeltas(row.index, updatedRow, afterRow);\n deltas.push(...rowDeltas, ...rowDiff);\n }\n reportProgress(end);\n }\n\n if (onProgress) {\n onProgress({ phase: 'transforming', localPercent: 100, currentRow: totalRows, totalRows });\n }\n\n const transformedSheet = applyTransformDelta(sheet, { deltas });\n\n const sheetOut = await runSheetTransforms(\n transformedSheet,\n sheetLayout,\n getters.getSheetTransform,\n signal,\n );\n deltas.push(...sheetOut.deltas);\n const errors = sheetOut.errors.length > 0 ? [...sheetOut.errors] : undefined;\n return { deltas, errors };\n}\n","import type { RegistryEntry, RegistryLevel } from './types.js';\n\nexport class Registry<T extends (...args: unknown[]) => unknown> {\n private entries = new Map<string, RegistryEntry<T>>();\n\n register(name: string, fn: T, options: { type: RegistryLevel }): void {\n this.entries.set(name, { fn, type: options.type });\n }\n\n get(name: string): RegistryEntry<T> | undefined {\n return this.entries.get(name);\n }\n\n getByType(type: RegistryLevel): Array<{ name: string; entry: RegistryEntry<T> }> {\n return [...this.entries.entries()]\n .filter(([, e]) => e.type === type)\n .map(([name, entry]) => ({ name, entry }));\n }\n\n has(name: string): boolean {\n return this.entries.has(name);\n }\n\n clear(): void {\n this.entries.clear();\n }\n}\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const TO_UPPER_TRANSFORM_ID = 'toUpperCase';\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>,\n) => unknown;\n\nexport function cellToUpperTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>,\n): unknown {\n if (typeof value !== 'string') return value;\n return value.toUpperCase();\n}\n\nexport function registerToUpperTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void,\n): void {\n register(TO_UPPER_TRANSFORM_ID, cellToUpperTransform, { type: 'cell' });\n}\n\nexport const CellToUpperTransform = {\n id: TO_UPPER_TRANSFORM_ID,\n transform: cellToUpperTransform,\n Register(registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void): string {\n if (registerFn) registerToUpperTransform(registerFn);\n return TO_UPPER_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const TO_LOWER_TRANSFORM_ID = 'toLowerCase';\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringToLowerTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n if (typeof value !== 'string') return value;\n return value.toLowerCase();\n}\n\nexport function registerStringToLowerTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(TO_LOWER_TRANSFORM_ID, cellStringToLowerTransform, { type: 'cell' });\n}\n\nexport const CellStringToLowerTransform = {\n id: TO_LOWER_TRANSFORM_ID,\n transform: cellStringToLowerTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringToLowerTransform(registerFn);\n return TO_LOWER_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const SLICE_TRANSFORM_ID = 'slice';\n\ntype Params = { start?: number; end?: number };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringSliceTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n if (typeof value !== 'string') return value;\n const { start, end } = (params ?? {}) as Params;\n const s = Number(start);\n const e = Number(end);\n if (Number.isNaN(s) && Number.isNaN(e)) return value;\n if (Number.isNaN(e)) return value.slice(Number.isNaN(s) ? undefined : s);\n return value.slice(Number.isNaN(s) ? undefined : s, e);\n}\n\nexport function registerStringSliceTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(SLICE_TRANSFORM_ID, cellStringSliceTransform, { type: 'cell' });\n}\n\nexport const CellStringSliceTransform = {\n id: SLICE_TRANSFORM_ID,\n transform: cellStringSliceTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringSliceTransform(registerFn);\n return SLICE_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const REPLACE_STR_TRANSFORM_ID = 'replace';\n\ntype Params = { search?: string; replacement?: string };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringReplaceTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n if (typeof value !== 'string') return value;\n const { search = '', replacement = '' } = (params ?? {}) as Params;\n return value.split(String(search)).join(String(replacement));\n}\n\nexport function registerStringReplaceTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(REPLACE_STR_TRANSFORM_ID, cellStringReplaceTransform, { type: 'cell' });\n}\n\nexport const CellStringReplaceTransform = {\n id: REPLACE_STR_TRANSFORM_ID,\n transform: cellStringReplaceTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringReplaceTransform(registerFn);\n return REPLACE_STR_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const REPLACE_BY_REGEX_TRANSFORM_ID = 'replaceByRegex';\n\ntype Params = { pattern?: string; flags?: string; replacement?: string };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringReplaceByRegexTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n if (typeof value !== 'string') return value;\n const { pattern = '', flags = 'g', replacement = '' } = (params ?? {}) as Params;\n if (!pattern) return value;\n try {\n const re = new RegExp(pattern, flags);\n return value.replace(re, String(replacement));\n } catch {\n return value;\n }\n}\n\nexport function registerStringReplaceByRegexTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(REPLACE_BY_REGEX_TRANSFORM_ID, cellStringReplaceByRegexTransform, { type: 'cell' });\n}\n\nexport const CellStringReplaceByRegexTransform = {\n id: REPLACE_BY_REGEX_TRANSFORM_ID,\n transform: cellStringReplaceByRegexTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringReplaceByRegexTransform(registerFn);\n return REPLACE_BY_REGEX_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const FILL_START_TRANSFORM_ID = 'fillStart';\n\ntype Params = { length?: number; fill?: string };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringFillStartTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const s =\n typeof value === 'string' ? value : value === null || value === undefined ? '' : String(value);\n const { length = 0, fill = ' ' } = (params ?? {}) as Params;\n const safeLength = Math.max(0, Number(length) || 0);\n return safeLength > 0 ? s.padStart(safeLength, String(fill)) : s;\n}\n\nexport function registerStringFillStartTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(FILL_START_TRANSFORM_ID, cellStringFillStartTransform, { type: 'cell' });\n}\n\nexport const CellStringFillStartTransform = {\n id: FILL_START_TRANSFORM_ID,\n transform: cellStringFillStartTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringFillStartTransform(registerFn);\n return FILL_START_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const FILL_END_TRANSFORM_ID = 'fillEnd';\n\ntype Params = { length?: number; fill?: string };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringFillEndTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const s =\n typeof value === 'string' ? value : value === null || value === undefined ? '' : String(value);\n const { length = 0, fill = ' ' } = (params ?? {}) as Params;\n const safeLength = Math.max(0, Number(length) || 0);\n return safeLength > 0 ? s.padEnd(safeLength, String(fill)) : s;\n}\n\nexport function registerStringFillEndTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(FILL_END_TRANSFORM_ID, cellStringFillEndTransform, { type: 'cell' });\n}\n\nexport const CellStringFillEndTransform = {\n id: FILL_END_TRANSFORM_ID,\n transform: cellStringFillEndTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringFillEndTransform(registerFn);\n return FILL_END_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const EXTRACT_BY_REGEX_TRANSFORM_ID = 'extractByRegex';\n\ntype Params = { pattern?: string; flags?: string; group?: number };\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellStringExtractByRegexTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const s =\n typeof value === 'string' ? value : value === null || value === undefined ? '' : String(value);\n const { pattern = '', flags = '', group = 0 } = (params ?? {}) as Params;\n if (!pattern) return s;\n try {\n const re = new RegExp(pattern, flags);\n const m = s.match(re);\n if (!m) return '';\n const g = Math.max(0, Number(group) || 0);\n return m[g] ?? m[0] ?? '';\n } catch {\n return s;\n }\n}\n\nexport function registerStringExtractByRegexTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(EXTRACT_BY_REGEX_TRANSFORM_ID, cellStringExtractByRegexTransform, { type: 'cell' });\n}\n\nexport const CellStringExtractByRegexTransform = {\n id: EXTRACT_BY_REGEX_TRANSFORM_ID,\n transform: cellStringExtractByRegexTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringExtractByRegexTransform(registerFn);\n return EXTRACT_BY_REGEX_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_ADD_TRANSFORM_ID = 'numberAdd';\n\ntype Params = { value?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberAddTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { value: add = 0 } = (params ?? {}) as Params;\n const delta = Number(add);\n return Number.isNaN(delta) ? value : n + delta;\n}\n\nexport function registerNumberAddTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_ADD_TRANSFORM_ID, cellNumberAddTransform, { type: 'cell' });\n}\n\nexport const CellNumberAddTransform = {\n id: NUMBER_ADD_TRANSFORM_ID,\n transform: cellNumberAddTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberAddTransform(registerFn);\n return NUMBER_ADD_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_MULTIPLY_TRANSFORM_ID = 'numberMultiply';\n\ntype Params = { value?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberMultiplyTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { value: factor = 1 } = (params ?? {}) as Params;\n const f = Number(factor);\n return Number.isNaN(f) ? value : n * f;\n}\n\nexport function registerNumberMultiplyTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_MULTIPLY_TRANSFORM_ID, cellNumberMultiplyTransform, { type: 'cell' });\n}\n\nexport const CellNumberMultiplyTransform = {\n id: NUMBER_MULTIPLY_TRANSFORM_ID,\n transform: cellNumberMultiplyTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberMultiplyTransform(registerFn);\n return NUMBER_MULTIPLY_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_DIVIDE_TRANSFORM_ID = 'numberDivide';\n\ntype Params = { value?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberDivideTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { value: divisor = 1 } = (params ?? {}) as Params;\n const d = Number(divisor);\n if (Number.isNaN(d) || d === 0) return value;\n return n / d;\n}\n\nexport function registerNumberDivideTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_DIVIDE_TRANSFORM_ID, cellNumberDivideTransform, { type: 'cell' });\n}\n\nexport const CellNumberDivideTransform = {\n id: NUMBER_DIVIDE_TRANSFORM_ID,\n transform: cellNumberDivideTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberDivideTransform(registerFn);\n return NUMBER_DIVIDE_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_SUBTRACT_TRANSFORM_ID = 'numberSubtract';\n\ntype Params = { value?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberSubtractTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { value: sub = 0 } = (params ?? {}) as Params;\n const delta = Number(sub);\n return Number.isNaN(delta) ? value : n - delta;\n}\n\nexport function registerNumberSubtractTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_SUBTRACT_TRANSFORM_ID, cellNumberSubtractTransform, { type: 'cell' });\n}\n\nexport const CellNumberSubtractTransform = {\n id: NUMBER_SUBTRACT_TRANSFORM_ID,\n transform: cellNumberSubtractTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberSubtractTransform(registerFn);\n return NUMBER_SUBTRACT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_ROUND_TRANSFORM_ID = 'numberRound';\n\ntype Params = { mode?: 'round' | 'ceil' | 'floor' };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberRoundTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { mode = 'round' } = (params ?? {}) as Params;\n if (mode === 'ceil') return Math.ceil(n);\n if (mode === 'floor') return Math.floor(n);\n return Math.round(n);\n}\n\nexport function registerNumberRoundTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_ROUND_TRANSFORM_ID, cellNumberRoundTransform, { type: 'cell' });\n}\n\nexport const CellNumberRoundTransform = {\n id: NUMBER_ROUND_TRANSFORM_ID,\n transform: cellNumberRoundTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberRoundTransform(registerFn);\n return NUMBER_ROUND_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_ABS_TRANSFORM_ID = 'numberAbs';\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberAbsTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n return Math.abs(n);\n}\n\nexport function registerNumberAbsTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_ABS_TRANSFORM_ID, cellNumberAbsTransform, { type: 'cell' });\n}\n\nexport const CellNumberAbsTransform = {\n id: NUMBER_ABS_TRANSFORM_ID,\n transform: cellNumberAbsTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberAbsTransform(registerFn);\n return NUMBER_ABS_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_SQRT_TRANSFORM_ID = 'numberSqrt';\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberSqrtTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null || n < 0) return value;\n return Math.sqrt(n);\n}\n\nexport function registerNumberSqrtTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_SQRT_TRANSFORM_ID, cellNumberSqrtTransform, { type: 'cell' });\n}\n\nexport const CellNumberSqrtTransform = {\n id: NUMBER_SQRT_TRANSFORM_ID,\n transform: cellNumberSqrtTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberSqrtTransform(registerFn);\n return NUMBER_SQRT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_LIMIT_TRANSFORM_ID = 'numberLimit';\n\ntype Params = { min?: number; max?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberLimitTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { min, max } = (params ?? {}) as Params;\n let out = n;\n const minVal = Number(min);\n if (!Number.isNaN(minVal) && out < minVal) out = minVal;\n const maxVal = Number(max);\n if (!Number.isNaN(maxVal) && out > maxVal) out = maxVal;\n return out;\n}\n\nexport function registerNumberLimitTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_LIMIT_TRANSFORM_ID, cellNumberLimitTransform, { type: 'cell' });\n}\n\nexport const CellNumberLimitTransform = {\n id: NUMBER_LIMIT_TRANSFORM_ID,\n transform: cellNumberLimitTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberLimitTransform(registerFn);\n return NUMBER_LIMIT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const NUMBER_PERCENT_TRANSFORM_ID = 'numberPercent';\n\ntype Params = { total?: number };\n\nfunction toNumber(v: unknown): number | null {\n if (typeof v === 'number' && !Number.isNaN(v)) return v;\n const n = Number(v);\n return Number.isNaN(n) ? null : n;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellNumberPercentTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const n = toNumber(value);\n if (n === null) return value;\n const { total } = (params ?? {}) as Params;\n const t = Number(total);\n if (Number.isNaN(t) || t === 0) return value;\n return (n / t) * 100;\n}\n\nexport function registerNumberPercentTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_PERCENT_TRANSFORM_ID, cellNumberPercentTransform, { type: 'cell' });\n}\n\nexport const CellNumberPercentTransform = {\n id: NUMBER_PERCENT_TRANSFORM_ID,\n transform: cellNumberPercentTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberPercentTransform(registerFn);\n return NUMBER_PERCENT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_TO_ONLY_TIME_TRANSFORM_ID = 'dateToOnlyTime';\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction toISOTimeString(d: Date): string {\n const h = String(d.getHours()).padStart(2, '0');\n const min = String(d.getMinutes()).padStart(2, '0');\n const s = String(d.getSeconds()).padStart(2, '0');\n return `${h}:${min}:${s}`;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateToOnlyTimeTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return toISOTimeString(d);\n}\n\nexport function registerDateToOnlyTimeTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TO_ONLY_TIME_TRANSFORM_ID, cellDateToOnlyTimeTransform, { type: 'cell' });\n}\n\nexport const CellDateToOnlyTimeTransform = {\n id: DATE_TO_ONLY_TIME_TRANSFORM_ID,\n transform: cellDateToOnlyTimeTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateToOnlyTimeTransform(registerFn);\n return DATE_TO_ONLY_TIME_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_TO_ONLY_DATE_TRANSFORM_ID = 'dateToOnlyDate';\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction toISODateString(d: Date): string {\n const y = d.getFullYear();\n const m = String(d.getMonth() + 1).padStart(2, '0');\n const day = String(d.getDate()).padStart(2, '0');\n return `${y}-${m}-${day}`;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateToOnlyDateTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return toISODateString(d);\n}\n\nexport function registerDateToOnlyDateTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TO_ONLY_DATE_TRANSFORM_ID, cellDateToOnlyDateTransform, { type: 'cell' });\n}\n\nexport const CellDateToOnlyDateTransform = {\n id: DATE_TO_ONLY_DATE_TRANSFORM_ID,\n transform: cellDateToOnlyDateTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateToOnlyDateTransform(registerFn);\n return DATE_TO_ONLY_DATE_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_TO_TIME_DATE_TRANSFORM_ID = 'dateToTimeDate';\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction toISODateString(d: Date): string {\n const y = d.getFullYear();\n const m = String(d.getMonth() + 1).padStart(2, '0');\n const day = String(d.getDate()).padStart(2, '0');\n return `${y}-${m}-${day}`;\n}\n\nfunction toISOTimeString(d: Date): string {\n const h = String(d.getHours()).padStart(2, '0');\n const min = String(d.getMinutes()).padStart(2, '0');\n const s = String(d.getSeconds()).padStart(2, '0');\n return `${h}:${min}:${s}`;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateToTimeDateTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return `${toISODateString(d)}T${toISOTimeString(d)}`;\n}\n\nexport function registerDateToTimeDateTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TO_TIME_DATE_TRANSFORM_ID, cellDateToTimeDateTransform, { type: 'cell' });\n}\n\nexport const CellDateToTimeDateTransform = {\n id: DATE_TO_TIME_DATE_TRANSFORM_ID,\n transform: cellDateToTimeDateTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateToTimeDateTransform(registerFn);\n return DATE_TO_TIME_DATE_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_TO_UTC_TRANSFORM_ID = 'dateToUtc';\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateToUtcTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n _params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return d.toISOString();\n}\n\nexport function registerDateToUtcTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TO_UTC_TRANSFORM_ID, cellDateToUtcTransform, { type: 'cell' });\n}\n\nexport const CellDateToUtcTransform = {\n id: DATE_TO_UTC_TRANSFORM_ID,\n transform: cellDateToUtcTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateToUtcTransform(registerFn);\n return DATE_TO_UTC_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_LIMIT_TRANSFORM_ID = 'dateLimit';\n\ntype Params = { min?: string | number; max?: string | number };\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n if (!Number.isNaN(ms)) return new Date(ms);\n const n = Number(value);\n return Number.isFinite(n) ? new Date(n) : null;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateLimitTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n const { min, max } = (params ?? {}) as Params;\n let out = d.getTime();\n if (min !== undefined) {\n const minD = typeof min === 'number' ? new Date(min) : new Date(String(min));\n if (!Number.isNaN(minD.getTime()) && out < minD.getTime()) out = minD.getTime();\n }\n if (max !== undefined) {\n const maxD = typeof max === 'number' ? new Date(max) : new Date(String(max));\n if (!Number.isNaN(maxD.getTime()) && out > maxD.getTime()) out = maxD.getTime();\n }\n return new Date(out).toISOString();\n}\n\nexport function registerDateLimitTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_LIMIT_TRANSFORM_ID, cellDateLimitTransform, { type: 'cell' });\n}\n\nexport const CellDateLimitTransform = {\n id: DATE_LIMIT_TRANSFORM_ID,\n transform: cellDateLimitTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateLimitTransform(registerFn);\n return DATE_LIMIT_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_ADD_TRANSFORM_ID = 'dateAdd';\n\ntype Params = {\n days?: number;\n minutes?: number;\n hours?: number;\n seconds?: number;\n ms?: number;\n months?: number;\n years?: number;\n};\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction addToDate(d: Date, p: Params): Date {\n const out = new Date(d.getTime());\n const ms = Number(p.ms) || 0;\n const sec = Number(p.seconds) || 0;\n const min = Number(p.minutes) || 0;\n const h = Number(p.hours) || 0;\n const days = Number(p.days) || 0;\n out.setTime(out.getTime() + ms + sec * 1000 + min * 60_000 + h * 3_600_000 + days * 86_400_000);\n const months = Number(p.months) || 0;\n const years = Number(p.years) || 0;\n if (months || years) {\n out.setFullYear(out.getFullYear() + years);\n out.setMonth(out.getMonth() + months);\n }\n return out;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateAddTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return addToDate(d, (params ?? {}) as Params).toISOString();\n}\n\nexport function registerDateAddTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_ADD_TRANSFORM_ID, cellDateAddTransform, { type: 'cell' });\n}\n\nexport const CellDateAddTransform = {\n id: DATE_ADD_TRANSFORM_ID,\n transform: cellDateAddTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateAddTransform(registerFn);\n return DATE_ADD_TRANSFORM_ID;\n },\n};\n","import type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\n\nexport const DATE_SUBTRACT_TRANSFORM_ID = 'dateSubtract';\n\ntype Params = {\n days?: number;\n minutes?: number;\n hours?: number;\n seconds?: number;\n ms?: number;\n months?: number;\n years?: number;\n};\n\nfunction parseToDate(value: unknown): Date | null {\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : new Date(ms);\n}\n\nfunction subtractFromDate(d: Date, p: Params): Date {\n const out = new Date(d.getTime());\n const ms = Number(p.ms) || 0;\n const sec = Number(p.seconds) || 0;\n const min = Number(p.minutes) || 0;\n const h = Number(p.hours) || 0;\n const days = Number(p.days) || 0;\n out.setTime(out.getTime() - ms - sec * 1000 - min * 60_000 - h * 3_600_000 - days * 86_400_000);\n const months = Number(p.months) || 0;\n const years = Number(p.years) || 0;\n if (months || years) {\n out.setFullYear(out.getFullYear() - years);\n out.setMonth(out.getMonth() - months);\n }\n return out;\n}\n\nexport type CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n) => unknown;\n\nexport function cellDateSubtractTransform(\n value: unknown,\n _cell: ValidatedCell,\n _row: ValidatedRow,\n params?: Readonly<Record<string, unknown>>\n): unknown {\n const d = parseToDate(value);\n if (!d) return value;\n return subtractFromDate(d, (params ?? {}) as Params).toISOString();\n}\n\nexport function registerDateSubtractTransform(\n register: (name: string, fn: CellTransformFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_SUBTRACT_TRANSFORM_ID, cellDateSubtractTransform, { type: 'cell' });\n}\n\nexport const CellDateSubtractTransform = {\n id: DATE_SUBTRACT_TRANSFORM_ID,\n transform: cellDateSubtractTransform,\n Register(\n registerFn?: (name: string, fn: CellTransformFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateSubtractTransform(registerFn);\n return DATE_SUBTRACT_TRANSFORM_ID;\n },\n};\n","import { Registry } from '../../../shared/registry/index.js';\nimport { registerToUpperTransform } from '../../../utils/controller/string/cell-to-upper-transform.js';\nimport { registerStringToLowerTransform } from '../../../utils/controller/string/cell-string-tolower-transform.js';\nimport { registerStringSliceTransform } from '../../../utils/controller/string/cell-string-slice-transform.js';\nimport { registerStringReplaceTransform } from '../../../utils/controller/string/cell-string-replace-transform.js';\nimport { registerStringReplaceByRegexTransform } from '../../../utils/controller/string/cell-string-replace-regex-transform.js';\nimport { registerStringFillStartTransform } from '../../../utils/controller/string/cell-string-fill-start-transform.js';\nimport { registerStringFillEndTransform } from '../../../utils/controller/string/cell-string-fill-end-transform.js';\nimport { registerStringExtractByRegexTransform } from '../../../utils/controller/string/cell-string-extract-regex-transform.js';\nimport { registerNumberAddTransform } from '../../../utils/controller/number/cell-number-add-transform.js';\nimport { registerNumberMultiplyTransform } from '../../../utils/controller/number/cell-number-multiply-transform.js';\nimport { registerNumberDivideTransform } from '../../../utils/controller/number/cell-number-divide-transform.js';\nimport { registerNumberSubtractTransform } from '../../../utils/controller/number/cell-number-subtract-transform.js';\nimport { registerNumberRoundTransform } from '../../../utils/controller/number/cell-number-round-transform.js';\nimport { registerNumberAbsTransform } from '../../../utils/controller/number/cell-number-abs-transform.js';\nimport { registerNumberSqrtTransform } from '../../../utils/controller/number/cell-number-sqrt-transform.js';\nimport { registerNumberLimitTransform } from '../../../utils/controller/number/cell-number-limit-transform.js';\nimport { registerNumberPercentTransform } from '../../../utils/controller/number/cell-number-percent-transform.js';\nimport { registerDateToOnlyTimeTransform } from '../../../utils/controller/date/cell-date-to-only-time-transform.js';\nimport { registerDateToOnlyDateTransform } from '../../../utils/controller/date/cell-date-to-only-date-transform.js';\nimport { registerDateToTimeDateTransform } from '../../../utils/controller/date/cell-date-to-time-date-transform.js';\nimport { registerDateToUtcTransform } from '../../../utils/controller/date/cell-date-to-utc-transform.js';\nimport { registerDateLimitTransform } from '../../../utils/controller/date/cell-date-limit-transform.js';\nimport { registerDateAddTransform } from '../../../utils/controller/date/cell-date-add-transform.js';\nimport { registerDateSubtractTransform } from '../../../utils/controller/date/cell-date-subtract-transform.js';\nimport type { Sheet } from '../../../types/sheet.js';\nimport type { ValidatedCell, ValidatedRow } from '../../../types/sheet.js';\nimport type { TransformDeltaItem } from '../types/transform-delta.js';\nimport type { TransformGetters } from '../runner/run-transform.js';\n\ntype CellTransformFn = (\n value: unknown,\n cell: ValidatedCell,\n row: ValidatedRow,\n p?: Readonly<Record<string, unknown>>\n) => unknown;\n\ntype RowTransformFn = (row: ValidatedRow, p?: Readonly<Record<string, unknown>>) => ValidatedRow;\n\ntype SheetTransformFn = (\n sheet: Sheet,\n p?: Readonly<Record<string, unknown>>,\n signal?: AbortSignal\n) => readonly TransformDeltaItem[] | Promise<readonly TransformDeltaItem[]>;\n\nconst registry = new Registry<(...args: unknown[]) => unknown>();\n\nfunction registerCellTransform(name: string, fn: CellTransformFn, opts: { type: 'cell' }): void {\n registry.register(name, fn, opts);\n}\n\nregisterToUpperTransform(registerCellTransform);\nregisterStringToLowerTransform(registerCellTransform);\nregisterStringSliceTransform(registerCellTransform);\nregisterStringReplaceTransform(registerCellTransform);\nregisterStringReplaceByRegexTransform(registerCellTransform);\nregisterStringFillStartTransform(registerCellTransform);\nregisterStringFillEndTransform(registerCellTransform);\nregisterStringExtractByRegexTransform(registerCellTransform);\nregisterNumberAddTransform(registerCellTransform);\nregisterNumberMultiplyTransform(registerCellTransform);\nregisterNumberDivideTransform(registerCellTransform);\nregisterNumberSubtractTransform(registerCellTransform);\nregisterNumberRoundTransform(registerCellTransform);\nregisterNumberAbsTransform(registerCellTransform);\nregisterNumberSqrtTransform(registerCellTransform);\nregisterNumberLimitTransform(registerCellTransform);\nregisterNumberPercentTransform(registerCellTransform);\nregisterDateToOnlyTimeTransform(registerCellTransform);\nregisterDateToOnlyDateTransform(registerCellTransform);\nregisterDateToTimeDateTransform(registerCellTransform);\nregisterDateToUtcTransform(registerCellTransform);\nregisterDateLimitTransform(registerCellTransform);\nregisterDateAddTransform(registerCellTransform);\nregisterDateSubtractTransform(registerCellTransform);\n\nfunction getCellTransform(name: string): CellTransformFn | undefined {\n const entry = registry.get(name);\n if (!entry || entry.type !== 'cell') return undefined;\n return entry.fn as CellTransformFn;\n}\n\nfunction getRowTransform(_name: string): RowTransformFn | undefined {\n return undefined;\n}\n\nfunction getSheetTransform(_name: string): SheetTransformFn | undefined {\n return undefined;\n}\n\nexport function getTransformGetters(): TransformGetters {\n return {\n getCellTransform,\n getRowTransform,\n getSheetTransform,\n };\n}\n","import * as Comlink from 'comlink';\nimport type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { Sheet } from '../../../types/sheet.js';\nimport type { TransformResult } from '../types/transform-delta.js';\nimport type { TransformProgressDetail } from '../types/transform-progress.js';\nimport { runTransform } from '../runner/run-transform.js';\nimport { getTransformGetters } from './worker-registry.js';\n\ntype ProgressCallback = (detail: TransformProgressDetail) => void;\n\nexport interface TransformWorkerOptions {\n signal?: AbortSignal;\n}\n\nconst api = {\n async transform(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n options?: TransformWorkerOptions,\n onProgress?: ProgressCallback,\n ): Promise<TransformResult> {\n const getters = getTransformGetters();\n return runTransform(\n sheet,\n sheetLayout,\n getters,\n onProgress,\n options?.signal,\n );\n },\n};\n\nComlink.expose(api, self as unknown as Comlink.Endpoint);\n"],"mappings":"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","names":["proxyMarker","createEndpoint","releaseProxy","finalizer","throwMarker","isObject","val","proxyTransferHandler","obj","port1","port2","expose","port","wrap","throwTransferHandler","value","serialized","transferHandlers","isAllowedOrigin","allowedOrigins","origin","allowedOrigin","ep","callback","ev","id","type","path","argumentList","fromWireValue","returnValue","parent","prop","rawValue","proxy","transfer","wireValue","transferables","toWireValue","closeEndPoint","error","isMessagePort","endpoint","target","pendingListeners","data","resolver","createProxy","throwIfProxyReleased","isReleased","releaseEndpoint","requestResponseMessage","proxyCounter","proxyFinalizers","newCount","registerProxy","unregisterProxy","isProxyReleased","_target","r","p","_thisArg","rawArgumentList","last","processArguments","myFlat","arr","processed","v","transferCache","transfers","toWireValue","value","name","handler","transferHandlers","serializedValue","transferables","transferCache","fromWireValue","requestResponseMessage","ep","pendingListeners","msg","transfers","resolve","id","generateUUID","resolveTransformRef","ref","runCellTransforms","cell","row","field","getTransform","list","current","ref","name","params","resolveTransformRef","fn","runRowTransforms","row","sheetLayout","getTransform","list","current","ref","name","params","resolveTransformRef","fn","EXTERNAL_TRANSFORM_FAILED","runSheetTransforms","sheet","sheetLayout","getTransform","signal","list","deltas","errors","ref","name","params","resolveTransformRef","fn","result","patchCellInRow","rows","rowIndex","col","newValue","row","cells","cell","applyTransformDelta","sheet","delta","item","THROTTLE_MS","THROTTLE_PERCENT","CHUNK_SIZE","createThrottledProgress","totalRows","onProgress","lastTime","lastPercent","processed","now","localPercent","diffRowToDeltas","rowIndex","before","after","out","beforeCells","c","cell","prev","runTransform","sheet","sheetLayout","getters","signal","fields","reportProgress","deltas","i","end","r","row","rowDeltas","updatedCells","field","newValue","runCellTransforms","updatedRow","afterRow","runRowTransforms","rowDiff","transformedSheet","applyTransformDelta","sheetOut","runSheetTransforms","errors","Registry","name","fn","options","type","e","entry","TO_UPPER_TRANSFORM_ID","cellToUpperTransform","value","_cell","_row","_params","registerToUpperTransform","register","TO_LOWER_TRANSFORM_ID","cellStringToLowerTransform","value","_cell","_row","_params","registerStringToLowerTransform","register","SLICE_TRANSFORM_ID","cellStringSliceTransform","value","_cell","_row","params","start","end","e","registerStringSliceTransform","register","REPLACE_STR_TRANSFORM_ID","cellStringReplaceTransform","value","_cell","_row","params","search","replacement","registerStringReplaceTransform","register","REPLACE_BY_REGEX_TRANSFORM_ID","cellStringReplaceByRegexTransform","value","_cell","_row","params","pattern","flags","replacement","re","registerStringReplaceByRegexTransform","register","FILL_START_TRANSFORM_ID","cellStringFillStartTransform","value","_cell","_row","params","s","length","fill","safeLength","registerStringFillStartTransform","register","FILL_END_TRANSFORM_ID","cellStringFillEndTransform","value","_cell","_row","params","s","length","fill","safeLength","registerStringFillEndTransform","register","EXTRACT_BY_REGEX_TRANSFORM_ID","cellStringExtractByRegexTransform","value","_cell","_row","params","s","pattern","flags","group","re","g","registerStringExtractByRegexTransform","register","NUMBER_ADD_TRANSFORM_ID","toNumber","v","cellNumberAddTransform","value","_cell","_row","params","n","add","delta","registerNumberAddTransform","register","NUMBER_MULTIPLY_TRANSFORM_ID","toNumber","v","cellNumberMultiplyTransform","value","_cell","_row","params","n","factor","f","registerNumberMultiplyTransform","register","NUMBER_DIVIDE_TRANSFORM_ID","toNumber","v","cellNumberDivideTransform","value","_cell","_row","params","n","divisor","d","registerNumberDivideTransform","register","NUMBER_SUBTRACT_TRANSFORM_ID","toNumber","v","cellNumberSubtractTransform","value","_cell","_row","params","n","sub","delta","registerNumberSubtractTransform","register","NUMBER_ROUND_TRANSFORM_ID","toNumber","v","cellNumberRoundTransform","value","_cell","_row","params","n","mode","registerNumberRoundTransform","register","NUMBER_ABS_TRANSFORM_ID","toNumber","v","cellNumberAbsTransform","value","_cell","_row","_params","n","registerNumberAbsTransform","register","NUMBER_SQRT_TRANSFORM_ID","toNumber","v","cellNumberSqrtTransform","value","_cell","_row","_params","n","registerNumberSqrtTransform","register","NUMBER_LIMIT_TRANSFORM_ID","toNumber","v","cellNumberLimitTransform","value","_cell","_row","params","n","min","max","out","minVal","maxVal","registerNumberLimitTransform","register","NUMBER_PERCENT_TRANSFORM_ID","toNumber","v","cellNumberPercentTransform","value","_cell","_row","params","n","total","t","registerNumberPercentTransform","register","DATE_TO_ONLY_TIME_TRANSFORM_ID","parseToDate","value","s","ms","toISOTimeString","d","h","min","cellDateToOnlyTimeTransform","_cell","_row","_params","registerDateToOnlyTimeTransform","register","DATE_TO_ONLY_DATE_TRANSFORM_ID","parseToDate","value","s","ms","toISODateString","d","y","m","day","cellDateToOnlyDateTransform","_cell","_row","_params","registerDateToOnlyDateTransform","register","DATE_TO_TIME_DATE_TRANSFORM_ID","parseToDate","value","s","ms","toISODateString","d","y","m","day","toISOTimeString","h","min","cellDateToTimeDateTransform","_cell","_row","_params","registerDateToTimeDateTransform","register","DATE_TO_UTC_TRANSFORM_ID","parseToDate","value","s","ms","cellDateToUtcTransform","_cell","_row","_params","d","registerDateToUtcTransform","register","DATE_LIMIT_TRANSFORM_ID","parseToDate","value","s","ms","n","cellDateLimitTransform","_cell","_row","params","d","min","max","out","minD","maxD","registerDateLimitTransform","register","DATE_ADD_TRANSFORM_ID","parseToDate","value","s","ms","addToDate","d","p","out","sec","min","h","days","months","years","cellDateAddTransform","_cell","_row","params","registerDateAddTransform","register","DATE_SUBTRACT_TRANSFORM_ID","parseToDate","value","s","ms","subtractFromDate","d","p","out","sec","min","h","days","months","years","cellDateSubtractTransform","_cell","_row","params","registerDateSubtractTransform","register","registry","Registry","registerCellTransform","name","fn","opts","registerToUpperTransform","registerStringToLowerTransform","registerStringSliceTransform","registerStringReplaceTransform","registerStringReplaceByRegexTransform","registerStringFillStartTransform","registerStringFillEndTransform","registerStringExtractByRegexTransform","registerNumberAddTransform","registerNumberMultiplyTransform","registerNumberDivideTransform","registerNumberSubtractTransform","registerNumberRoundTransform","registerNumberAbsTransform","registerNumberSqrtTransform","registerNumberLimitTransform","registerNumberPercentTransform","registerDateToOnlyTimeTransform","registerDateToOnlyDateTransform","registerDateToTimeDateTransform","registerDateToUtcTransform","registerDateLimitTransform","registerDateAddTransform","registerDateSubtractTransform","getCellTransform","entry","getRowTransform","_name","getSheetTransform","getTransformGetters","api","sheet","sheetLayout","options","onProgress","getters","getTransformGetters","runTransform","expose"]}
|