@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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../node_modules/comlink/src/comlink.ts","../src/core/validator/runner/resolve-validator-ref.ts","../src/core/validator/runner/cell-validators.ts","../src/core/validator/runner/row-validators.ts","../src/core/validator/runner/run-table-validation.ts","../src/core/validator/types/validator-delta.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/editor/resolve.ts","../src/core/editor/immutable-update.ts","../src/core/editor/run-edit-pipeline.ts","../src/shared/registry/Registry.ts","../src/utils/controller/required/cell-required-validator.ts","../src/utils/controller/string/cell-string-byregex-validator.ts","../src/utils/controller/string/cell-string-max-length-validator.ts","../src/utils/controller/string/cell-string-min-length-validator.ts","../src/utils/controller/string/cell-string-email-validator.ts","../src/utils/controller/string/cell-string-phone-validator.ts","../src/utils/controller/string/cell-string-phone-international-validator.ts","../src/utils/controller/string/cell-string-phone-local-validator.ts","../src/utils/controller/string/cell-string-only-numbers-validator.ts","../src/utils/controller/string/cell-string-only-letters-validator.ts","../src/utils/controller/number/cell-number-min-validator.ts","../src/utils/controller/number/cell-number-max-validator.ts","../src/utils/controller/number/cell-number-float-validator.ts","../src/utils/controller/number/cell-number-integer-validator.ts","../src/utils/controller/number/cell-number-non-negative-validator.ts","../src/utils/controller/number/cell-number-non-positive-validator.ts","../src/utils/controller/number/cell-number-non-zero-validator.ts","../src/utils/controller/date/cell-date-min-validator.ts","../src/utils/controller/date/cell-date-max-validator.ts","../src/utils/controller/date/cell-date-only-year-validator.ts","../src/utils/controller/date/cell-date-only-time-validator.ts","../src/utils/controller/date/cell-date-datetime-validator.ts","../src/utils/controller/date/cell-date-timestamp-validator.ts","../src/utils/controller/date/cell-date-utc-validator.ts","../src/utils/controller/bool/cell-bool-only-true-validator.ts","../src/utils/controller/bool/cell-bool-only-false-validator.ts","../src/core/validator/worker/worker-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/editor/worker/edit.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 ResolvedValidatorRef {\n readonly name: string;\n readonly params?: Readonly<Record<string, unknown>>;\n}\n\nexport function resolveValidatorRef(ref: ValidatorOrWithParams): ResolvedValidatorRef {\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 { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetCell, SanitizedSheetRow } from '../../sanitizer/types/sanitized-sheet.js';\nimport { resolveValidatorRef } from './resolve-validator-ref.js';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>,\n) => readonly SheetError[] | null;\n\nexport type GetCellValidator = (name: string) => CellValidatorFn | undefined;\n\nexport function runCellValidators(\n cell: SanitizedSheetCell,\n row: SanitizedSheetRow,\n field: SheetLayoutField,\n getValidator: GetCellValidator,\n): readonly SheetError[] {\n const list = field.validators;\n if (!list?.length) return [];\n const errors: SheetError[] = [];\n for (const ref of list) {\n const { name, params } = resolveValidatorRef(ref);\n const fn = getValidator(name);\n if (fn) {\n const result = fn(cell.value, row, params);\n if (result?.length) {\n errors.push(...result);\n const hasFatal = result.some((e) => e.level === 'fatal');\n if (hasFatal) break;\n }\n }\n }\n return errors;\n}\n","import type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../sanitizer/types/sanitized-sheet.js';\nimport { resolveValidatorRef } from './resolve-validator-ref.js';\n\nexport type RowValidatorFn = (\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>,\n) => readonly SheetError[] | null;\n\nexport type GetRowValidator = (name: string) => RowValidatorFn | undefined;\n\nexport function runRowValidators(\n row: SanitizedSheetRow,\n sheetLayout: SheetLayout,\n getValidator: GetRowValidator,\n): readonly SheetError[] {\n const list = sheetLayout.rowValidators;\n if (!list?.length) return [];\n const errors: SheetError[] = [];\n for (const ref of list) {\n const { name, params } = resolveValidatorRef(ref);\n const fn = getValidator(name);\n if (fn) {\n const result = fn(row, params);\n if (result?.length) {\n errors.push(...result);\n const hasFatal = result.some((e) => e.level === 'fatal');\n if (hasFatal) break;\n }\n }\n }\n return errors;\n}\n","import type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheet } from '../../sanitizer/types/sanitized-sheet.js';\nimport type { ValidatorErrorDeltaItem } from '../types/validator-delta.js';\nimport { resolveValidatorRef } from './resolve-validator-ref.js';\n\nexport const EXTERNAL_VALIDATION_FAILED = 'EXTERNAL_VALIDATION_FAILED';\n\nexport type TableValidatorFn = (\n sheet: SanitizedSheet,\n params?: Readonly<Record<string, unknown>>,\n signal?: AbortSignal,\n) => readonly SheetError[] | null | Promise<readonly SheetError[] | null>;\n\nexport type GetTableValidator = (name: string) => TableValidatorFn | undefined;\n\nfunction toSheetLevelItems(errors: readonly SheetError[]): ValidatorErrorDeltaItem[] {\n return errors.map((error) => ({ error }));\n}\n\nexport async function runTableValidation(\n sheet: SanitizedSheet,\n sheetLayout: SheetLayout,\n getValidator: GetTableValidator,\n signal?: AbortSignal,\n): Promise<ValidatorErrorDeltaItem[]> {\n const list = sheetLayout.sheetValidators;\n if (!list?.length) return [];\n const collected: ValidatorErrorDeltaItem[] = [];\n for (const ref of list) {\n const { name, params } = resolveValidatorRef(ref);\n const fn = getValidator(name);\n if (!fn) continue;\n try {\n const result = await Promise.resolve(fn(sheet, params, signal));\n if (result?.length) collected.push(...toSheetLevelItems(result));\n } catch {\n collected.push({\n error: {\n code: EXTERNAL_VALIDATION_FAILED,\n level: 'fatal',\n params: { reason: 'network' },\n },\n });\n }\n }\n return collected;\n}\n","import type { SheetError } from '../../../types/error.js';\n\nexport interface ValidatorErrorCell {\n readonly rowIndex: number;\n readonly cellKey: string;\n readonly error: SheetError;\n}\n\nexport interface ValidatorErrorRow {\n readonly rowIndex: number;\n readonly error: SheetError;\n}\n\nexport interface ValidatorErrorSheet {\n readonly error: SheetError;\n}\n\nexport type ValidatorErrorDeltaItem =\n | ValidatorErrorCell\n | ValidatorErrorRow\n | ValidatorErrorSheet;\n\nexport interface ValidatorDelta {\n readonly errors: readonly ValidatorErrorDeltaItem[];\n}\n\nfunction isCellError(item: ValidatorErrorDeltaItem): item is ValidatorErrorCell {\n return 'cellKey' in item && 'rowIndex' in item;\n}\n\nfunction isRowError(item: ValidatorErrorDeltaItem): item is ValidatorErrorRow {\n return 'rowIndex' in item && !('cellKey' in item);\n}\n\nexport function isValidatorErrorCell(\n item: ValidatorErrorDeltaItem,\n): item is ValidatorErrorCell {\n return isCellError(item);\n}\n\nexport function isValidatorErrorRow(\n item: ValidatorErrorDeltaItem,\n): item is ValidatorErrorRow {\n return isRowError(item);\n}\n\nexport function isValidatorErrorSheet(\n item: ValidatorErrorDeltaItem,\n): item is ValidatorErrorSheet {\n return !('rowIndex' in item) && !('cellKey' in item);\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 { Sheet, ValidatedCell, ValidatedRow } from '../../types/sheet.js';\n\nexport function getRowByIndex(\n sheet: Sheet,\n rowIndex: number,\n): ValidatedRow | undefined {\n return sheet.rows.find((row) => row.index === rowIndex);\n}\n\nexport function getCellByKey(\n row: ValidatedRow,\n cellKey: string,\n): ValidatedCell | undefined {\n return row.cells.find((cell) => cell.key === cellKey);\n}\n","import type { Sheet, ValidatedCell, ValidatedRow } from '../../types/sheet.js';\nimport { getRowByIndex } from './resolve.js';\n\nexport function removeRow(sheet: Sheet, rowIndex: number): Sheet {\n const row = getRowByIndex(sheet, rowIndex);\n if (!row) return sheet;\n const newRows: ValidatedRow[] = sheet.rows\n .filter((r) => r.index !== rowIndex)\n .map((r, i) => ({ ...r, index: i }));\n return { ...sheet, rows: newRows };\n}\n\nexport function setCellValue(\n sheet: Sheet,\n rowIndex: number,\n cellKey: string,\n value: unknown\n): Sheet {\n const row = getRowByIndex(sheet, rowIndex);\n if (!row) return sheet;\n const cellIndex = row.cells.findIndex((c) => c.key === cellKey);\n if (cellIndex < 0) return sheet;\n const newCell: ValidatedCell = { ...row.cells[cellIndex]!, value, errors: [] };\n const newCells: ValidatedCell[] = row.cells.map((c, i) => (i === cellIndex ? newCell : c));\n const newRow: ValidatedRow = { ...row, cells: newCells, errors: [] };\n const newRows: ValidatedRow[] = sheet.rows.map((r) => (r.index === rowIndex ? newRow : r));\n return { ...sheet, rows: newRows };\n}\n","import type { SheetLayout } from '../../types/sheet-layout.js';\nimport type { Sheet, ValidatedCell, ValidatedRow } from '../../types/sheet.js';\nimport type { SanitizedSheet } from '../sanitizer/types/sanitized-sheet.js';\nimport { runCellValidators } from '../validator/runner/cell-validators.js';\nimport { runRowValidators } from '../validator/runner/row-validators.js';\nimport { runTableValidation } from '../validator/runner/run-table-validation.js';\nimport { isValidatorErrorSheet } from '../validator/types/validator-delta.js';\nimport type { GetCellValidator } from '../validator/runner/cell-validators.js';\nimport type { GetRowValidator } from '../validator/runner/row-validators.js';\nimport type { GetTableValidator } from '../validator/runner/run-table-validation.js';\nimport { runCellTransforms } from '../transform/runner/cell-transforms.js';\nimport { runRowTransforms } from '../transform/runner/row-transforms.js';\nimport { runSheetTransforms } from '../transform/runner/sheet-transforms.js';\nimport type { GetCellTransform } from '../transform/runner/cell-transforms.js';\nimport type { GetRowTransform } from '../transform/runner/row-transforms.js';\nimport type { GetSheetTransform } from '../transform/runner/sheet-transforms.js';\nimport { applyTransformDelta } from '../transform/delta-applier.js';\nimport { setCellValue } from './immutable-update.js';\nimport { getRowByIndex, getCellByKey } from './resolve.js';\n\nexport interface EditValidatorGetters {\n getCellValidator: GetCellValidator;\n getRowValidator: GetRowValidator;\n getTableValidator: GetTableValidator;\n}\n\nexport interface EditTransformGetters {\n getCellTransform: GetCellTransform;\n getRowTransform: GetRowTransform;\n getSheetTransform: GetSheetTransform;\n}\n\nexport interface EditPipelineGetters {\n validator: EditValidatorGetters;\n transform: EditTransformGetters;\n}\n\nexport async function runEditPipeline(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n rowIndex: number,\n cellKey: string,\n value: unknown,\n getters: EditPipelineGetters,\n signal?: AbortSignal,\n): Promise<Sheet> {\n const sheet1 = setCellValue(sheet, rowIndex, cellKey, value);\n const row = getRowByIndex(sheet1, rowIndex);\n if (!row) return sheet1;\n const cell = getCellByKey(row, cellKey);\n if (!cell) return sheet1;\n const field = sheetLayout.fields[cellKey];\n if (!field) return sheet1;\n\n const cellErrors = runCellValidators(\n cell as unknown as import('../sanitizer/types/sanitized-sheet.js').SanitizedSheetCell,\n row as unknown as import('../sanitizer/types/sanitized-sheet.js').SanitizedSheetRow,\n field,\n getters.validator.getCellValidator,\n );\n const newCell: ValidatedCell = { ...cell, errors: cellErrors };\n const newRow: ValidatedRow = {\n ...row,\n cells: row.cells.map((c) => (c.key === cellKey ? newCell : c)),\n errors: [],\n };\n const rowErrors = runRowValidators(\n newRow as unknown as import('../sanitizer/types/sanitized-sheet.js').SanitizedSheetRow,\n sheetLayout,\n getters.validator.getRowValidator,\n );\n const newRow2: ValidatedRow = { ...newRow, errors: rowErrors };\n const newRows = sheet1.rows.map((r) => (r.index === rowIndex ? newRow2 : r));\n const sheet2: Sheet = { ...sheet1, rows: newRows };\n\n const tableErrors = await runTableValidation(\n sheet2 as unknown as SanitizedSheet,\n sheetLayout,\n getters.validator.getTableValidator,\n signal,\n );\n const sheetErrors = tableErrors\n .filter(isValidatorErrorSheet)\n .map((i) => i.error);\n const sheet3: Sheet = { ...sheet2, errors: [...sheet2.errors, ...sheetErrors] };\n\n if (sheet3.errors.length > 0) return sheet3;\n\n const cellValue =\n newCell.errors.length === 0\n ? runCellTransforms(\n newCell,\n newRow2,\n field,\n getters.transform.getCellTransform,\n )\n : newCell.value;\n const updatedCell: ValidatedCell = { ...newCell, value: cellValue };\n const rowWithCellTransform: ValidatedRow = {\n ...newRow2,\n cells: newRow2.cells.map((c) => (c.key === cellKey ? updatedCell : c)),\n };\n const transformedRow =\n newRow2.errors.length === 0\n ? runRowTransforms(\n rowWithCellTransform,\n sheetLayout,\n getters.transform.getRowTransform,\n )\n : rowWithCellTransform;\n const sheet4: Sheet = {\n ...sheet3,\n rows: sheet3.rows.map((r) => (r.index === rowIndex ? transformedRow : r)),\n };\n const sheetOut = await runSheetTransforms(\n sheet4,\n sheetLayout,\n getters.transform.getSheetTransform,\n signal,\n );\n const sheet5 = applyTransformDelta(sheet4, { deltas: sheetOut.deltas });\n if (sheetOut.errors.length > 0) {\n return { ...sheet5, errors: [...sheet5.errors, ...sheetOut.errors] };\n }\n return sheet5;\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 { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const REQUIRED_VALIDATOR_ID = 'required';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>,\n) => readonly SheetError[] | null;\n\nexport function cellRequiredValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>,\n): readonly SheetError[] | null {\n const isEmpty =\n value === null ||\n value === undefined ||\n (typeof value === 'string' && value.trim() === '');\n if (isEmpty) {\n return [{ code: 'REQUIRED', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerRequiredValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void,\n): void {\n register(REQUIRED_VALIDATOR_ID, cellRequiredValidator, { type: 'cell' });\n}\n\nexport const CellRequiredValidator = {\n id: REQUIRED_VALIDATOR_ID,\n validate: cellRequiredValidator,\n Register(registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void): string {\n if (registerFn) registerRequiredValidator(registerFn);\n return REQUIRED_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_BYREGEX_VALIDATOR_ID = 'string:byregex';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { pattern?: string; flags?: string };\n\nexport function cellStringByregexValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { pattern = '', flags = '' } = (params ?? {}) as Params;\n if (!pattern) {\n return [\n {\n code: 'STRING_BYREGEX_INVALID_PARAMS',\n level: 'error',\n params: { reason: 'missing pattern' },\n },\n ];\n }\n const s = value === null || value === undefined ? '' : String(value);\n try {\n const re = new RegExp(pattern, flags);\n if (!re.test(s)) {\n return [{ code: 'STRING_BYREGEX_MISMATCH', level: 'error', params: { value: s, pattern } }];\n }\n } catch {\n return [{ code: 'STRING_BYREGEX_INVALID_PATTERN', level: 'error', params: { pattern } }];\n }\n return null;\n}\n\nexport function registerStringByregexValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_BYREGEX_VALIDATOR_ID, cellStringByregexValidator, { type: 'cell' });\n}\n\nexport const CellStringByregexValidator = {\n id: STRING_BYREGEX_VALIDATOR_ID,\n validate: cellStringByregexValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringByregexValidator(registerFn);\n return STRING_BYREGEX_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_MAX_LENGTH_VALIDATOR_ID = 'string:maxLength';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { maxLength?: number };\n\nexport function cellStringMaxLengthValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { maxLength } = (params ?? {}) as Params;\n const max = typeof maxLength === 'number' && Number.isFinite(maxLength) ? maxLength : undefined;\n if (max === undefined || max < 0) {\n return [{ code: 'STRING_MAX_LENGTH_INVALID_PARAMS', level: 'error', params: { maxLength } }];\n }\n const s = value === null || value === undefined ? '' : String(value);\n if (s.length > max) {\n return [\n {\n code: 'STRING_MAX_LENGTH',\n level: 'error',\n params: { value: s, maxLength: max, length: s.length },\n },\n ];\n }\n return null;\n}\n\nexport function registerStringMaxLengthValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_MAX_LENGTH_VALIDATOR_ID, cellStringMaxLengthValidator, { type: 'cell' });\n}\n\nexport const CellStringMaxLengthValidator = {\n id: STRING_MAX_LENGTH_VALIDATOR_ID,\n validate: cellStringMaxLengthValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringMaxLengthValidator(registerFn);\n return STRING_MAX_LENGTH_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_MIN_LENGTH_VALIDATOR_ID = 'string:minLength';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { minLength?: number };\n\nexport function cellStringMinLengthValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { minLength } = (params ?? {}) as Params;\n const min =\n typeof minLength === 'number' && Number.isFinite(minLength) && minLength >= 0\n ? minLength\n : undefined;\n if (min === undefined) {\n return [{ code: 'STRING_MIN_LENGTH_INVALID_PARAMS', level: 'error', params: { minLength } }];\n }\n const s = value === null || value === undefined ? '' : String(value);\n if (s.length < min) {\n return [\n {\n code: 'STRING_MIN_LENGTH',\n level: 'error',\n params: { value: s, minLength: min, length: s.length },\n },\n ];\n }\n return null;\n}\n\nexport function registerStringMinLengthValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_MIN_LENGTH_VALIDATOR_ID, cellStringMinLengthValidator, { type: 'cell' });\n}\n\nexport const CellStringMinLengthValidator = {\n id: STRING_MIN_LENGTH_VALIDATOR_ID,\n validate: cellStringMinLengthValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringMinLengthValidator(registerFn);\n return STRING_MIN_LENGTH_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_EMAIL_VALIDATOR_ID = 'string:email';\n\nconst EMAIL_REGEX =\n /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringEmailValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const s = value === null || value === undefined ? '' : String(value).trim();\n if (!s) return null;\n if (!EMAIL_REGEX.test(s)) {\n return [{ code: 'STRING_EMAIL_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringEmailValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_EMAIL_VALIDATOR_ID, cellStringEmailValidator, { type: 'cell' });\n}\n\nexport const CellStringEmailValidator = {\n id: STRING_EMAIL_VALIDATOR_ID,\n validate: cellStringEmailValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringEmailValidator(registerFn);\n return STRING_EMAIL_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_PHONE_VALIDATOR_ID = 'string:phone';\n\nconst PHONE_REGEX = /^[\\d\\s\\-+.()]{7,20}$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringPhoneValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const s = value === null || value === undefined ? '' : String(value).trim();\n if (!s) return null;\n const digitsOnly = s.replace(/\\D/g, '');\n if (digitsOnly.length < 7 || digitsOnly.length > 15 || !PHONE_REGEX.test(s)) {\n return [{ code: 'STRING_PHONE_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringPhoneValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_PHONE_VALIDATOR_ID, cellStringPhoneValidator, { type: 'cell' });\n}\n\nexport const CellStringPhoneValidator = {\n id: STRING_PHONE_VALIDATOR_ID,\n validate: cellStringPhoneValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringPhoneValidator(registerFn);\n return STRING_PHONE_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_PHONE_INTERNATIONAL_VALIDATOR_ID = 'string:phoneInternational';\n\nconst E164_PREFIX = /^\\+?[1-9]\\d{0,3}/;\nconst MIN_DIGITS = 10;\nconst MAX_DIGITS = 15;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringPhoneInternationalValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const s = value === null || value === undefined ? '' : String(value).trim().replace(/\\s/g, '');\n if (!s) return null;\n const digits = s.replace(/\\D/g, '');\n const withPlus = s.startsWith('+') ? s : `+${s}`;\n if (digits.length < MIN_DIGITS || digits.length > MAX_DIGITS || !E164_PREFIX.test(withPlus)) {\n return [{ code: 'STRING_PHONE_INTERNATIONAL_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringPhoneInternationalValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_PHONE_INTERNATIONAL_VALIDATOR_ID, cellStringPhoneInternationalValidator, {\n type: 'cell',\n });\n}\n\nexport const CellStringPhoneInternationalValidator = {\n id: STRING_PHONE_INTERNATIONAL_VALIDATOR_ID,\n validate: cellStringPhoneInternationalValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringPhoneInternationalValidator(registerFn);\n return STRING_PHONE_INTERNATIONAL_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_PHONE_LOCAL_VALIDATOR_ID = 'string:phoneLocal';\n\ntype Params = { minDigits?: number; maxDigits?: number };\n\nconst DEFAULT_MIN = 6;\nconst DEFAULT_MAX = 11;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringPhoneLocalValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { minDigits = DEFAULT_MIN, maxDigits = DEFAULT_MAX } = (params ?? {}) as Params;\n const min = typeof minDigits === 'number' && minDigits >= 0 ? minDigits : DEFAULT_MIN;\n const max = typeof maxDigits === 'number' && maxDigits >= min ? maxDigits : DEFAULT_MAX;\n const s = value === null || value === undefined ? '' : String(value).trim();\n if (!s) return null;\n const digits = s.replace(/\\D/g, '');\n if (s.startsWith('+') && digits.length > 3) {\n return [\n {\n code: 'STRING_PHONE_LOCAL_INVALID',\n level: 'error',\n params: { value: s, reason: 'international' },\n },\n ];\n }\n if (digits.length < min || digits.length > max) {\n return [\n {\n code: 'STRING_PHONE_LOCAL_INVALID',\n level: 'error',\n params: { value: s, minDigits: min, maxDigits: max },\n },\n ];\n }\n return null;\n}\n\nexport function registerStringPhoneLocalValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_PHONE_LOCAL_VALIDATOR_ID, cellStringPhoneLocalValidator, { type: 'cell' });\n}\n\nexport const CellStringPhoneLocalValidator = {\n id: STRING_PHONE_LOCAL_VALIDATOR_ID,\n validate: cellStringPhoneLocalValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringPhoneLocalValidator(registerFn);\n return STRING_PHONE_LOCAL_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_ONLY_NUMBERS_VALIDATOR_ID = 'string:onlyNumbers';\n\nconst ONLY_DIGITS = /^\\d+$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringOnlyNumbersValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n if (!ONLY_DIGITS.test(s)) {\n return [{ code: 'STRING_ONLY_NUMBERS_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringOnlyNumbersValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_ONLY_NUMBERS_VALIDATOR_ID, cellStringOnlyNumbersValidator, { type: 'cell' });\n}\n\nexport const CellStringOnlyNumbersValidator = {\n id: STRING_ONLY_NUMBERS_VALIDATOR_ID,\n validate: cellStringOnlyNumbersValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringOnlyNumbersValidator(registerFn);\n return STRING_ONLY_NUMBERS_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_ONLY_LETTERS_VALIDATOR_ID = 'string:onlyLetters';\n\ntype Params = { allowSpaces?: boolean };\n\nconst ONLY_LETTERS = /^[a-zA-Z\\u00C0-\\u024F\\u1E00-\\u1EFF]+$/;\nconst ONLY_LETTERS_AND_SPACES = /^[a-zA-Z\\u00C0-\\u024F\\u1E00-\\u1EFF\\s]+$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringOnlyLettersValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { allowSpaces = false } = (params ?? {}) as Params;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const re = allowSpaces ? ONLY_LETTERS_AND_SPACES : ONLY_LETTERS;\n if (!re.test(s)) {\n return [{ code: 'STRING_ONLY_LETTERS_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringOnlyLettersValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_ONLY_LETTERS_VALIDATOR_ID, cellStringOnlyLettersValidator, { type: 'cell' });\n}\n\nexport const CellStringOnlyLettersValidator = {\n id: STRING_ONLY_LETTERS_VALIDATOR_ID,\n validate: cellStringOnlyLettersValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringOnlyLettersValidator(registerFn);\n return STRING_ONLY_LETTERS_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_MIN_VALIDATOR_ID = 'number:min';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { min?: number };\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberMinValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { min } = (params ?? {}) as Params;\n const minVal = typeof min === 'number' && Number.isFinite(min) ? min : undefined;\n if (minVal === undefined) {\n return [{ code: 'NUMBER_MIN_INVALID_PARAMS', level: 'error', params: { min } }];\n }\n const n = toNumber(value);\n if (n === null) return [{ code: 'NUMBER_MIN_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n < minVal) {\n return [{ code: 'NUMBER_MIN', level: 'error', params: { value: n, min: minVal } }];\n }\n return null;\n}\n\nexport function registerNumberMinValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_MIN_VALIDATOR_ID, cellNumberMinValidator, { type: 'cell' });\n}\n\nexport const CellNumberMinValidator = {\n id: NUMBER_MIN_VALIDATOR_ID,\n validate: cellNumberMinValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberMinValidator(registerFn);\n return NUMBER_MIN_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_MAX_VALIDATOR_ID = 'number:max';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { max?: number };\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberMaxValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { max } = (params ?? {}) as Params;\n const maxVal = typeof max === 'number' && Number.isFinite(max) ? max : undefined;\n if (maxVal === undefined) {\n return [{ code: 'NUMBER_MAX_INVALID_PARAMS', level: 'error', params: { max } }];\n }\n const n = toNumber(value);\n if (n === null) return [{ code: 'NUMBER_MAX_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n > maxVal) {\n return [{ code: 'NUMBER_MAX', level: 'error', params: { value: n, max: maxVal } }];\n }\n return null;\n}\n\nexport function registerNumberMaxValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_MAX_VALIDATOR_ID, cellNumberMaxValidator, { type: 'cell' });\n}\n\nexport const CellNumberMaxValidator = {\n id: NUMBER_MAX_VALIDATOR_ID,\n validate: cellNumberMaxValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberMaxValidator(registerFn);\n return NUMBER_MAX_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_FLOAT_VALIDATOR_ID = 'number:float';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction isFiniteFloat(value: unknown): boolean {\n if (value === null || value === undefined) return false;\n if (typeof value === 'number') return Number.isFinite(value);\n const s = String(value).trim();\n if (!s) return false;\n const n = parseFloat(s);\n return Number.isFinite(n);\n}\n\nexport function cellNumberFloatValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n if (!isFiniteFloat(value)) {\n return [{ code: 'NUMBER_FLOAT_INVALID', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerNumberFloatValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_FLOAT_VALIDATOR_ID, cellNumberFloatValidator, { type: 'cell' });\n}\n\nexport const CellNumberFloatValidator = {\n id: NUMBER_FLOAT_VALIDATOR_ID,\n validate: cellNumberFloatValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberFloatValidator(registerFn);\n return NUMBER_FLOAT_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_INTEGER_VALIDATOR_ID = 'number:integer';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction toInteger(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value) && Number.isInteger(value)) return value;\n const n = Number(value);\n if (!Number.isFinite(n)) return null;\n return Number.isInteger(n) ? n : null;\n}\n\nexport function cellNumberIntegerValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n const n = toInteger(value);\n if (n === null) {\n return [{ code: 'NUMBER_INTEGER_INVALID', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerNumberIntegerValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_INTEGER_VALIDATOR_ID, cellNumberIntegerValidator, { type: 'cell' });\n}\n\nexport const CellNumberIntegerValidator = {\n id: NUMBER_INTEGER_VALIDATOR_ID,\n validate: cellNumberIntegerValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberIntegerValidator(registerFn);\n return NUMBER_INTEGER_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_NON_NEGATIVE_VALIDATOR_ID = 'number:nonNegative';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberNonNegativeValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n const n = toNumber(value);\n if (n === null)\n return [{ code: 'NUMBER_NON_NEGATIVE_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n < 0) return [{ code: 'NUMBER_NON_NEGATIVE', level: 'error', params: { value: n } }];\n return null;\n}\n\nexport function registerNumberNonNegativeValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_NON_NEGATIVE_VALIDATOR_ID, cellNumberNonNegativeValidator, { type: 'cell' });\n}\n\nexport const CellNumberNonNegativeValidator = {\n id: NUMBER_NON_NEGATIVE_VALIDATOR_ID,\n validate: cellNumberNonNegativeValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberNonNegativeValidator(registerFn);\n return NUMBER_NON_NEGATIVE_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_NON_POSITIVE_VALIDATOR_ID = 'number:nonPositive';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberNonPositiveValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n const n = toNumber(value);\n if (n === null)\n return [{ code: 'NUMBER_NON_POSITIVE_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n > 0) return [{ code: 'NUMBER_NON_POSITIVE', level: 'error', params: { value: n } }];\n return null;\n}\n\nexport function registerNumberNonPositiveValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_NON_POSITIVE_VALIDATOR_ID, cellNumberNonPositiveValidator, { type: 'cell' });\n}\n\nexport const CellNumberNonPositiveValidator = {\n id: NUMBER_NON_POSITIVE_VALIDATOR_ID,\n validate: cellNumberNonPositiveValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberNonPositiveValidator(registerFn);\n return NUMBER_NON_POSITIVE_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_NON_ZERO_VALIDATOR_ID = 'number:nonZero';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberNonZeroValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n const n = toNumber(value);\n if (n === null)\n return [{ code: 'NUMBER_NON_ZERO_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n === 0) return [{ code: 'NUMBER_NON_ZERO', level: 'error', params: { value: n } }];\n return null;\n}\n\nexport function registerNumberNonZeroValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_NON_ZERO_VALIDATOR_ID, cellNumberNonZeroValidator, { type: 'cell' });\n}\n\nexport const CellNumberNonZeroValidator = {\n id: NUMBER_NON_ZERO_VALIDATOR_ID,\n validate: cellNumberNonZeroValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberNonZeroValidator(registerFn);\n return NUMBER_NON_ZERO_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_MIN_VALIDATOR_ID = 'date:min';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { min?: string | number };\n\nfunction toTime(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const ms = Date.parse(String(value).trim());\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport function cellDateMinValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { min } = (params ?? {}) as Params;\n const minMs = min !== undefined ? toTime(min) : undefined;\n if (minMs === undefined || minMs === null) {\n return [{ code: 'DATE_MIN_INVALID_PARAMS', level: 'error', params: { min } }];\n }\n const v = toTime(value);\n if (v === null) return [{ code: 'DATE_MIN_NOT_A_DATE', level: 'error', params: { value } }];\n if (v < minMs) return [{ code: 'DATE_MIN', level: 'error', params: { value: v, min: minMs } }];\n return null;\n}\n\nexport function registerDateMinValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_MIN_VALIDATOR_ID, cellDateMinValidator, { type: 'cell' });\n}\n\nexport const CellDateMinValidator = {\n id: DATE_MIN_VALIDATOR_ID,\n validate: cellDateMinValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateMinValidator(registerFn);\n return DATE_MIN_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_MAX_VALIDATOR_ID = 'date:max';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { max?: string | number };\n\nfunction toTime(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const ms = Date.parse(String(value).trim());\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport function cellDateMaxValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { max } = (params ?? {}) as Params;\n const maxMs = max !== undefined ? toTime(max) : undefined;\n if (maxMs === undefined || maxMs === null) {\n return [{ code: 'DATE_MAX_INVALID_PARAMS', level: 'error', params: { max } }];\n }\n const v = toTime(value);\n if (v === null) return [{ code: 'DATE_MAX_NOT_A_DATE', level: 'error', params: { value } }];\n if (v > maxMs) return [{ code: 'DATE_MAX', level: 'error', params: { value: v, max: maxMs } }];\n return null;\n}\n\nexport function registerDateMaxValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_MAX_VALIDATOR_ID, cellDateMaxValidator, { type: 'cell' });\n}\n\nexport const CellDateMaxValidator = {\n id: DATE_MAX_VALIDATOR_ID,\n validate: cellDateMaxValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateMaxValidator(registerFn);\n return DATE_MAX_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_ONLY_YEAR_VALIDATOR_ID = 'date:onlyYear';\n\nconst YEAR_REGEX = /^(?:19|20)\\d{2}$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateOnlyYearValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const n = Number(s);\n const strMatch = YEAR_REGEX.test(s);\n const numMatch = Number.isInteger(n) && n >= 1900 && n <= 2099;\n if (!strMatch && !numMatch) {\n return [{ code: 'DATE_ONLY_YEAR_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerDateOnlyYearValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_ONLY_YEAR_VALIDATOR_ID, cellDateOnlyYearValidator, { type: 'cell' });\n}\n\nexport const CellDateOnlyYearValidator = {\n id: DATE_ONLY_YEAR_VALIDATOR_ID,\n validate: cellDateOnlyYearValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateOnlyYearValidator(registerFn);\n return DATE_ONLY_YEAR_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_ONLY_TIME_VALIDATOR_ID = 'date:onlyTime';\n\nconst TIME_REGEX = /^([01]?\\d|2[0-3]):([0-5]\\d)(?::([0-5]\\d))?(?:\\.\\d+)?$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateOnlyTimeValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n if (!TIME_REGEX.test(s)) {\n return [{ code: 'DATE_ONLY_TIME_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerDateOnlyTimeValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_ONLY_TIME_VALIDATOR_ID, cellDateOnlyTimeValidator, { type: 'cell' });\n}\n\nexport const CellDateOnlyTimeValidator = {\n id: DATE_ONLY_TIME_VALIDATOR_ID,\n validate: cellDateOnlyTimeValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateOnlyTimeValidator(registerFn);\n return DATE_ONLY_TIME_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_DATETIME_VALIDATOR_ID = 'date:datetime';\n\nfunction toTime(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const ms = Date.parse(String(value).trim());\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateDatetimeValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = toTime(value);\n if (ms === null) {\n return [{ code: 'DATE_DATETIME_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerDateDatetimeValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_DATETIME_VALIDATOR_ID, cellDateDatetimeValidator, { type: 'cell' });\n}\n\nexport const CellDateDatetimeValidator = {\n id: DATE_DATETIME_VALIDATOR_ID,\n validate: cellDateDatetimeValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateDatetimeValidator(registerFn);\n return DATE_DATETIME_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_TIMESTAMP_VALIDATOR_ID = 'date:timestamp';\n\nconst MAX_MS = 8640000000000;\nconst MIN_MS = -8640000000000;\n\nfunction toTimestamp(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const s = String(value).trim();\n if (/^\\d+$/.test(s)) {\n const n = Number(s);\n return Number.isFinite(n) ? n : null;\n }\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateTimestampValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = toTimestamp(value);\n if (ms === null) {\n return [{ code: 'DATE_TIMESTAMP_INVALID', level: 'error', params: { value: s } }];\n }\n if (ms < MIN_MS || ms > MAX_MS) {\n return [{ code: 'DATE_TIMESTAMP_OUT_OF_RANGE', level: 'error', params: { value: ms } }];\n }\n return null;\n}\n\nexport function registerDateTimestampValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TIMESTAMP_VALIDATOR_ID, cellDateTimestampValidator, { type: 'cell' });\n}\n\nexport const CellDateTimestampValidator = {\n id: DATE_TIMESTAMP_VALIDATOR_ID,\n validate: cellDateTimestampValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateTimestampValidator(registerFn);\n return DATE_TIMESTAMP_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_UTC_VALIDATOR_ID = 'date:utc';\n\nfunction toTime(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const ms = Date.parse(String(value).trim());\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateUtcValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = toTime(value);\n if (ms === null) {\n return [{ code: 'DATE_UTC_NOT_A_DATE', level: 'error', params: { value: s } }];\n }\n const isUtc =\n typeof value === 'number' || s.endsWith('Z') || /[+-]00:00$/.test(s) || /^\\d+$/.test(s);\n if (!isUtc) {\n return [{ code: 'DATE_UTC_REQUIRED', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerDateUtcValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_UTC_VALIDATOR_ID, cellDateUtcValidator, { type: 'cell' });\n}\n\nexport const CellDateUtcValidator = {\n id: DATE_UTC_VALIDATOR_ID,\n validate: cellDateUtcValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateUtcValidator(registerFn);\n return DATE_UTC_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const BOOL_ONLY_TRUE_VALIDATOR_ID = 'bool:onlyTrue';\n\nfunction isTrue(value: unknown): boolean {\n if (value === true) return true;\n if (typeof value === 'string') {\n const t = value.trim().toLowerCase();\n return t === 'true' || t === '1' || t === 'yes';\n }\n return value === 1;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellBoolOnlyTrueValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n if (!isTrue(value)) {\n return [{ code: 'BOOL_ONLY_TRUE', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerBoolOnlyTrueValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(BOOL_ONLY_TRUE_VALIDATOR_ID, cellBoolOnlyTrueValidator, { type: 'cell' });\n}\n\nexport const CellBoolOnlyTrueValidator = {\n id: BOOL_ONLY_TRUE_VALIDATOR_ID,\n validate: cellBoolOnlyTrueValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerBoolOnlyTrueValidator(registerFn);\n return BOOL_ONLY_TRUE_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const BOOL_ONLY_FALSE_VALIDATOR_ID = 'bool:onlyFalse';\n\nfunction isFalse(value: unknown): boolean {\n if (value === false) return true;\n if (typeof value === 'string') {\n const t = value.trim().toLowerCase();\n return t === 'false' || t === '0' || t === 'no';\n }\n return value === 0;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellBoolOnlyFalseValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n if (!isFalse(value)) {\n return [{ code: 'BOOL_ONLY_FALSE', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerBoolOnlyFalseValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(BOOL_ONLY_FALSE_VALIDATOR_ID, cellBoolOnlyFalseValidator, { type: 'cell' });\n}\n\nexport const CellBoolOnlyFalseValidator = {\n id: BOOL_ONLY_FALSE_VALIDATOR_ID,\n validate: cellBoolOnlyFalseValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerBoolOnlyFalseValidator(registerFn);\n return BOOL_ONLY_FALSE_VALIDATOR_ID;\n },\n};\n","import { Registry } from '../../../shared/registry/index.js';\nimport { registerRequiredValidator } from '../../../utils/controller/required/cell-required-validator.js';\nimport { registerStringByregexValidator } from '../../../utils/controller/string/cell-string-byregex-validator.js';\nimport { registerStringMaxLengthValidator } from '../../../utils/controller/string/cell-string-max-length-validator.js';\nimport { registerStringMinLengthValidator } from '../../../utils/controller/string/cell-string-min-length-validator.js';\nimport { registerStringEmailValidator } from '../../../utils/controller/string/cell-string-email-validator.js';\nimport { registerStringPhoneValidator } from '../../../utils/controller/string/cell-string-phone-validator.js';\nimport { registerStringPhoneInternationalValidator } from '../../../utils/controller/string/cell-string-phone-international-validator.js';\nimport { registerStringPhoneLocalValidator } from '../../../utils/controller/string/cell-string-phone-local-validator.js';\nimport { registerStringOnlyNumbersValidator } from '../../../utils/controller/string/cell-string-only-numbers-validator.js';\nimport { registerStringOnlyLettersValidator } from '../../../utils/controller/string/cell-string-only-letters-validator.js';\nimport { registerNumberMinValidator } from '../../../utils/controller/number/cell-number-min-validator.js';\nimport { registerNumberMaxValidator } from '../../../utils/controller/number/cell-number-max-validator.js';\nimport { registerNumberFloatValidator } from '../../../utils/controller/number/cell-number-float-validator.js';\nimport { registerNumberIntegerValidator } from '../../../utils/controller/number/cell-number-integer-validator.js';\nimport { registerNumberNonNegativeValidator } from '../../../utils/controller/number/cell-number-non-negative-validator.js';\nimport { registerNumberNonPositiveValidator } from '../../../utils/controller/number/cell-number-non-positive-validator.js';\nimport { registerNumberNonZeroValidator } from '../../../utils/controller/number/cell-number-non-zero-validator.js';\nimport { registerDateMinValidator } from '../../../utils/controller/date/cell-date-min-validator.js';\nimport { registerDateMaxValidator } from '../../../utils/controller/date/cell-date-max-validator.js';\nimport { registerDateOnlyYearValidator } from '../../../utils/controller/date/cell-date-only-year-validator.js';\nimport { registerDateOnlyTimeValidator } from '../../../utils/controller/date/cell-date-only-time-validator.js';\nimport { registerDateDatetimeValidator } from '../../../utils/controller/date/cell-date-datetime-validator.js';\nimport { registerDateTimestampValidator } from '../../../utils/controller/date/cell-date-timestamp-validator.js';\nimport { registerDateUtcValidator } from '../../../utils/controller/date/cell-date-utc-validator.js';\nimport { registerBoolOnlyTrueValidator } from '../../../utils/controller/bool/cell-bool-only-true-validator.js';\nimport { registerBoolOnlyFalseValidator } from '../../../utils/controller/bool/cell-bool-only-false-validator.js';\nimport type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheet, SanitizedSheetRow } from '../../sanitizer/types/sanitized-sheet.js';\n\ntype CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n p?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype RowValidatorFn = (\n row: SanitizedSheetRow,\n p?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype TableValidatorFn = (\n sheet: SanitizedSheet,\n p?: Readonly<Record<string, unknown>>,\n signal?: AbortSignal\n) => readonly SheetError[] | null | Promise<readonly SheetError[] | null>;\n\nconst registry = new Registry<(...args: unknown[]) => unknown>();\n\nfunction registerAll(\n register: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n): void {\n registerRequiredValidator(register);\n registerStringByregexValidator(register);\n registerStringMaxLengthValidator(register);\n registerStringMinLengthValidator(register);\n registerStringEmailValidator(register);\n registerStringPhoneValidator(register);\n registerStringPhoneInternationalValidator(register);\n registerStringPhoneLocalValidator(register);\n registerStringOnlyNumbersValidator(register);\n registerStringOnlyLettersValidator(register);\n registerNumberMinValidator(register);\n registerNumberMaxValidator(register);\n registerNumberFloatValidator(register);\n registerNumberIntegerValidator(register);\n registerNumberNonNegativeValidator(register);\n registerNumberNonPositiveValidator(register);\n registerNumberNonZeroValidator(register);\n registerDateMinValidator(register);\n registerDateMaxValidator(register);\n registerDateOnlyYearValidator(register);\n registerDateOnlyTimeValidator(register);\n registerDateDatetimeValidator(register);\n registerDateTimestampValidator(register);\n registerDateUtcValidator(register);\n registerBoolOnlyTrueValidator(register);\n registerBoolOnlyFalseValidator(register);\n}\n\nregisterAll((name, fn, opts) => {\n registry.register(name, fn, opts);\n});\n\nfunction getCellValidator(name: string): CellValidatorFn | undefined {\n const entry = registry.get(name);\n if (!entry || entry.type !== 'cell') return undefined;\n return entry.fn as CellValidatorFn;\n}\n\nfunction getRowValidator(_name: string): RowValidatorFn | undefined {\n return undefined;\n}\n\nfunction getTableValidator(_name: string): TableValidatorFn | undefined {\n return undefined;\n}\n\nexport function getValidatorGetters(): {\n getCellValidator: (name: string) => CellValidatorFn | undefined;\n getRowValidator: (name: string) => RowValidatorFn | undefined;\n getTableValidator: (name: string) => TableValidatorFn | undefined;\n} {\n return { getCellValidator, getRowValidator, getTableValidator };\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 { runEditPipeline } from '../run-edit-pipeline.js';\nimport { getValidatorGetters } from '../../validator/worker/worker-registry.js';\nimport { getTransformGetters } from '../../transform/worker/worker-registry.js';\n\nexport interface EditWorkerOptions {\n signal?: AbortSignal;\n}\n\nconst api = {\n async runEdit(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n rowIndex: number,\n cellKey: string,\n value: unknown,\n options?: EditWorkerOptions,\n ): Promise<Sheet> {\n const validator = getValidatorGetters();\n const transform = getTransformGetters();\n return runEditPipeline(\n sheet,\n sheetLayout,\n rowIndex,\n cellKey,\n value,\n { validator, transform },\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","resolveValidatorRef","ref","runCellValidators","cell","row","field","getValidator","list","errors","ref","name","params","resolveValidatorRef","fn","result","e","runRowValidators","row","sheetLayout","getValidator","list","errors","ref","name","params","resolveValidatorRef","fn","result","e","EXTERNAL_VALIDATION_FAILED","toSheetLevelItems","errors","error","runTableValidation","sheet","sheetLayout","getValidator","signal","list","collected","ref","name","params","resolveValidatorRef","fn","result","isValidatorErrorSheet","item","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","getRowByIndex","sheet","rowIndex","row","getCellByKey","cellKey","cell","setCellValue","sheet","rowIndex","cellKey","value","row","getRowByIndex","cellIndex","c","newCell","newCells","i","newRow","newRows","r","runEditPipeline","sheet","sheetLayout","rowIndex","cellKey","value","getters","signal","sheet1","setCellValue","row","getRowByIndex","cell","getCellByKey","field","cellErrors","runCellValidators","newCell","newRow","rowErrors","runRowValidators","newRow2","newRows","r","sheet2","sheetErrors","runTableValidation","isValidatorErrorSheet","i","sheet3","cellValue","runCellTransforms","updatedCell","rowWithCellTransform","transformedRow","runRowTransforms","sheet4","sheetOut","runSheetTransforms","sheet5","applyTransformDelta","Registry","name","fn","options","type","e","entry","REQUIRED_VALIDATOR_ID","cellRequiredValidator","value","_row","_params","registerRequiredValidator","register","STRING_BYREGEX_VALIDATOR_ID","cellStringByregexValidator","value","_row","params","pattern","flags","s","registerStringByregexValidator","register","STRING_MAX_LENGTH_VALIDATOR_ID","cellStringMaxLengthValidator","value","_row","params","maxLength","max","s","registerStringMaxLengthValidator","register","STRING_MIN_LENGTH_VALIDATOR_ID","cellStringMinLengthValidator","value","_row","params","minLength","min","s","registerStringMinLengthValidator","register","STRING_EMAIL_VALIDATOR_ID","EMAIL_REGEX","cellStringEmailValidator","value","_row","_params","s","registerStringEmailValidator","register","STRING_PHONE_VALIDATOR_ID","PHONE_REGEX","cellStringPhoneValidator","value","_row","_params","s","digitsOnly","registerStringPhoneValidator","register","STRING_PHONE_INTERNATIONAL_VALIDATOR_ID","E164_PREFIX","cellStringPhoneInternationalValidator","value","_row","_params","s","digits","withPlus","E164_PREFIX","registerStringPhoneInternationalValidator","register","STRING_PHONE_INTERNATIONAL_VALIDATOR_ID","STRING_PHONE_LOCAL_VALIDATOR_ID","cellStringPhoneLocalValidator","value","_row","params","minDigits","maxDigits","min","max","s","digits","registerStringPhoneLocalValidator","register","STRING_PHONE_LOCAL_VALIDATOR_ID","STRING_ONLY_NUMBERS_VALIDATOR_ID","ONLY_DIGITS","cellStringOnlyNumbersValidator","value","_row","_params","s","registerStringOnlyNumbersValidator","register","STRING_ONLY_LETTERS_VALIDATOR_ID","ONLY_LETTERS","ONLY_LETTERS_AND_SPACES","cellStringOnlyLettersValidator","value","_row","params","allowSpaces","s","registerStringOnlyLettersValidator","register","NUMBER_MIN_VALIDATOR_ID","toNumber","value","n","cellNumberMinValidator","_row","params","min","minVal","registerNumberMinValidator","register","NUMBER_MAX_VALIDATOR_ID","toNumber","value","n","cellNumberMaxValidator","_row","params","max","maxVal","registerNumberMaxValidator","register","NUMBER_FLOAT_VALIDATOR_ID","isFiniteFloat","value","s","n","cellNumberFloatValidator","_row","_params","registerNumberFloatValidator","register","NUMBER_INTEGER_VALIDATOR_ID","toInteger","value","n","cellNumberIntegerValidator","_row","_params","registerNumberIntegerValidator","register","NUMBER_NON_NEGATIVE_VALIDATOR_ID","toNumber","value","n","cellNumberNonNegativeValidator","_row","_params","registerNumberNonNegativeValidator","register","NUMBER_NON_POSITIVE_VALIDATOR_ID","toNumber","value","n","cellNumberNonPositiveValidator","_row","_params","registerNumberNonPositiveValidator","register","NUMBER_NON_ZERO_VALIDATOR_ID","toNumber","value","n","cellNumberNonZeroValidator","_row","_params","registerNumberNonZeroValidator","register","DATE_MIN_VALIDATOR_ID","toTime","value","ms","cellDateMinValidator","_row","params","min","minMs","v","registerDateMinValidator","register","DATE_MAX_VALIDATOR_ID","toTime","value","ms","cellDateMaxValidator","_row","params","max","maxMs","v","registerDateMaxValidator","register","DATE_ONLY_YEAR_VALIDATOR_ID","YEAR_REGEX","cellDateOnlyYearValidator","value","_row","_params","s","n","strMatch","numMatch","registerDateOnlyYearValidator","register","DATE_ONLY_TIME_VALIDATOR_ID","TIME_REGEX","cellDateOnlyTimeValidator","value","_row","_params","s","registerDateOnlyTimeValidator","register","DATE_DATETIME_VALIDATOR_ID","toTime","value","ms","cellDateDatetimeValidator","_row","_params","s","registerDateDatetimeValidator","register","DATE_TIMESTAMP_VALIDATOR_ID","toTimestamp","value","s","ms","cellDateTimestampValidator","_row","_params","registerDateTimestampValidator","register","DATE_TIMESTAMP_VALIDATOR_ID","DATE_UTC_VALIDATOR_ID","toTime","value","ms","cellDateUtcValidator","_row","_params","s","registerDateUtcValidator","register","BOOL_ONLY_TRUE_VALIDATOR_ID","isTrue","value","t","cellBoolOnlyTrueValidator","_row","_params","registerBoolOnlyTrueValidator","register","BOOL_ONLY_FALSE_VALIDATOR_ID","isFalse","value","t","cellBoolOnlyFalseValidator","_row","_params","registerBoolOnlyFalseValidator","register","registry","Registry","registerAll","register","registerRequiredValidator","registerStringByregexValidator","registerStringMaxLengthValidator","registerStringMinLengthValidator","registerStringEmailValidator","registerStringPhoneValidator","registerStringPhoneInternationalValidator","registerStringPhoneLocalValidator","registerStringOnlyNumbersValidator","registerStringOnlyLettersValidator","registerNumberMinValidator","registerNumberMaxValidator","registerNumberFloatValidator","registerNumberIntegerValidator","registerNumberNonNegativeValidator","registerNumberNonPositiveValidator","registerNumberNonZeroValidator","registerDateMinValidator","registerDateMaxValidator","registerDateOnlyYearValidator","registerDateOnlyTimeValidator","registerDateDatetimeValidator","registerDateTimestampValidator","registerDateUtcValidator","registerBoolOnlyTrueValidator","registerBoolOnlyFalseValidator","name","fn","opts","getCellValidator","entry","getRowValidator","_name","getTableValidator","getValidatorGetters","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","s","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","m","g","registerStringExtractByRegexTransform","register","NUMBER_ADD_TRANSFORM_ID","toNumber","v","n","cellNumberAddTransform","value","_cell","_row","params","add","delta","registerNumberAddTransform","register","NUMBER_MULTIPLY_TRANSFORM_ID","toNumber","v","n","cellNumberMultiplyTransform","value","_cell","_row","params","factor","f","registerNumberMultiplyTransform","register","NUMBER_DIVIDE_TRANSFORM_ID","toNumber","v","n","cellNumberDivideTransform","value","_cell","_row","params","divisor","d","registerNumberDivideTransform","register","NUMBER_SUBTRACT_TRANSFORM_ID","toNumber","v","n","cellNumberSubtractTransform","value","_cell","_row","params","sub","delta","registerNumberSubtractTransform","register","NUMBER_ROUND_TRANSFORM_ID","toNumber","v","n","cellNumberRoundTransform","value","_cell","_row","params","mode","registerNumberRoundTransform","register","NUMBER_ABS_TRANSFORM_ID","toNumber","v","n","cellNumberAbsTransform","value","_cell","_row","_params","registerNumberAbsTransform","register","NUMBER_SQRT_TRANSFORM_ID","toNumber","v","n","cellNumberSqrtTransform","value","_cell","_row","_params","registerNumberSqrtTransform","register","NUMBER_LIMIT_TRANSFORM_ID","toNumber","v","n","cellNumberLimitTransform","value","_cell","_row","params","min","max","out","minVal","maxVal","registerNumberLimitTransform","register","NUMBER_PERCENT_TRANSFORM_ID","toNumber","v","n","cellNumberPercentTransform","value","_cell","_row","params","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","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","rowIndex","cellKey","value","options","validator","getValidatorGetters","transform","getTransformGetters","runEditPipeline","expose"]}
1
+ {"version":3,"sources":["../node_modules/comlink/src/comlink.ts","../src/core/validator/runner/resolve-validator-ref.ts","../src/core/validator/runner/cell-validators.ts","../src/core/validator/runner/row-validators.ts","../src/core/validator/runner/run-table-validation.ts","../src/core/validator/types/validator-delta.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/editor/resolve.ts","../src/core/editor/immutable-update.ts","../src/core/editor/run-edit-pipeline.ts","../src/shared/registry/Registry.ts","../src/utils/controller/required/cell-required-validator.ts","../src/utils/controller/string/cell-string-byregex-validator.ts","../src/utils/controller/string/cell-string-max-length-validator.ts","../src/utils/controller/string/cell-string-min-length-validator.ts","../src/utils/controller/string/cell-string-email-validator.ts","../src/utils/controller/string/cell-string-phone-validator.ts","../src/utils/controller/string/cell-string-phone-international-validator.ts","../src/utils/controller/string/cell-string-phone-local-validator.ts","../src/utils/controller/string/cell-string-only-numbers-validator.ts","../src/utils/controller/string/cell-string-only-letters-validator.ts","../src/utils/controller/number/cell-number-min-validator.ts","../src/utils/controller/number/cell-number-max-validator.ts","../src/utils/controller/number/cell-number-float-validator.ts","../src/utils/controller/number/cell-number-integer-validator.ts","../src/utils/controller/number/cell-number-non-negative-validator.ts","../src/utils/controller/number/cell-number-non-positive-validator.ts","../src/utils/controller/number/cell-number-non-zero-validator.ts","../src/utils/controller/date/cell-date-min-validator.ts","../src/utils/controller/date/cell-date-max-validator.ts","../src/utils/controller/date/cell-date-only-year-validator.ts","../src/utils/controller/date/cell-date-only-time-validator.ts","../src/utils/controller/date/cell-date-datetime-validator.ts","../src/utils/controller/date/cell-date-timestamp-validator.ts","../src/utils/controller/date/cell-date-utc-validator.ts","../src/utils/controller/bool/cell-bool-only-true-validator.ts","../src/utils/controller/bool/cell-bool-only-false-validator.ts","../src/core/validator/worker/worker-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/editor/worker/edit.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 ResolvedValidatorRef {\n readonly name: string;\n readonly params?: Readonly<Record<string, unknown>>;\n}\n\nexport function resolveValidatorRef(ref: ValidatorOrWithParams): ResolvedValidatorRef {\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 { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetCell, SanitizedSheetRow } from '../../sanitizer/types/sanitized-sheet.js';\nimport { resolveValidatorRef } from './resolve-validator-ref.js';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>,\n) => readonly SheetError[] | null;\n\nexport type GetCellValidator = (name: string) => CellValidatorFn | undefined;\n\nexport function runCellValidators(\n cell: SanitizedSheetCell,\n row: SanitizedSheetRow,\n field: SheetLayoutField,\n getValidator: GetCellValidator,\n): readonly SheetError[] {\n const list = field.validators;\n if (!list?.length) return [];\n const errors: SheetError[] = [];\n for (const ref of list) {\n const { name, params } = resolveValidatorRef(ref);\n const fn = getValidator(name);\n if (fn) {\n const result = fn(cell.value, row, params);\n if (result?.length) {\n errors.push(...result);\n const hasFatal = result.some((e) => e.level === 'fatal');\n if (hasFatal) break;\n }\n }\n }\n return errors;\n}\n","import type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../sanitizer/types/sanitized-sheet.js';\nimport { resolveValidatorRef } from './resolve-validator-ref.js';\n\nexport type RowValidatorFn = (\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>,\n) => readonly SheetError[] | null;\n\nexport type GetRowValidator = (name: string) => RowValidatorFn | undefined;\n\nexport function runRowValidators(\n row: SanitizedSheetRow,\n sheetLayout: SheetLayout,\n getValidator: GetRowValidator,\n): readonly SheetError[] {\n const list = sheetLayout.rowValidators;\n if (!list?.length) return [];\n const errors: SheetError[] = [];\n for (const ref of list) {\n const { name, params } = resolveValidatorRef(ref);\n const fn = getValidator(name);\n if (fn) {\n const result = fn(row, params);\n if (result?.length) {\n errors.push(...result);\n const hasFatal = result.some((e) => e.level === 'fatal');\n if (hasFatal) break;\n }\n }\n }\n return errors;\n}\n","import type { SheetLayout } from '../../../types/sheet-layout.js';\nimport type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheet } from '../../sanitizer/types/sanitized-sheet.js';\nimport type { ValidatorErrorDeltaItem } from '../types/validator-delta.js';\nimport { resolveValidatorRef } from './resolve-validator-ref.js';\n\nexport const EXTERNAL_VALIDATION_FAILED = 'EXTERNAL_VALIDATION_FAILED';\n\nexport type TableValidatorFn = (\n sheet: SanitizedSheet,\n params?: Readonly<Record<string, unknown>>,\n signal?: AbortSignal,\n) => readonly SheetError[] | null | Promise<readonly SheetError[] | null>;\n\nexport type GetTableValidator = (name: string) => TableValidatorFn | undefined;\n\nfunction toSheetLevelItems(errors: readonly SheetError[]): ValidatorErrorDeltaItem[] {\n return errors.map((error) => ({ error }));\n}\n\nexport async function runTableValidation(\n sheet: SanitizedSheet,\n sheetLayout: SheetLayout,\n getValidator: GetTableValidator,\n signal?: AbortSignal,\n): Promise<ValidatorErrorDeltaItem[]> {\n const list = sheetLayout.sheetValidators;\n if (!list?.length) return [];\n const collected: ValidatorErrorDeltaItem[] = [];\n for (const ref of list) {\n const { name, params } = resolveValidatorRef(ref);\n const fn = getValidator(name);\n if (!fn) continue;\n try {\n const result = await Promise.resolve(fn(sheet, params, signal));\n if (result?.length) collected.push(...toSheetLevelItems(result));\n } catch {\n collected.push({\n error: {\n code: EXTERNAL_VALIDATION_FAILED,\n level: 'fatal',\n params: { reason: 'network' },\n },\n });\n }\n }\n return collected;\n}\n","import type { SheetError } from '../../../types/error.js';\n\nexport interface ValidatorErrorCell {\n readonly rowIndex: number;\n readonly cellKey: string;\n readonly error: SheetError;\n}\n\nexport interface ValidatorErrorRow {\n readonly rowIndex: number;\n readonly error: SheetError;\n}\n\nexport interface ValidatorErrorSheet {\n readonly error: SheetError;\n}\n\nexport type ValidatorErrorDeltaItem =\n | ValidatorErrorCell\n | ValidatorErrorRow\n | ValidatorErrorSheet;\n\nexport interface ValidatorDelta {\n readonly errors: readonly ValidatorErrorDeltaItem[];\n}\n\nfunction isCellError(item: ValidatorErrorDeltaItem): item is ValidatorErrorCell {\n return 'cellKey' in item && 'rowIndex' in item;\n}\n\nfunction isRowError(item: ValidatorErrorDeltaItem): item is ValidatorErrorRow {\n return 'rowIndex' in item && !('cellKey' in item);\n}\n\nexport function isValidatorErrorCell(\n item: ValidatorErrorDeltaItem,\n): item is ValidatorErrorCell {\n return isCellError(item);\n}\n\nexport function isValidatorErrorRow(\n item: ValidatorErrorDeltaItem,\n): item is ValidatorErrorRow {\n return isRowError(item);\n}\n\nexport function isValidatorErrorSheet(\n item: ValidatorErrorDeltaItem,\n): item is ValidatorErrorSheet {\n return !('rowIndex' in item) && !('cellKey' in item);\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 { Sheet, ValidatedCell, ValidatedRow } from '../../types/sheet.js';\n\nexport function getRowByIndex(\n sheet: Sheet,\n rowIndex: number,\n): ValidatedRow | undefined {\n return sheet.rows.find((row) => row.index === rowIndex);\n}\n\nexport function getCellByKey(\n row: ValidatedRow,\n cellKey: string,\n): ValidatedCell | undefined {\n return row.cells.find((cell) => cell.key === cellKey);\n}\n","import type { Sheet, ValidatedCell, ValidatedRow } from '../../types/sheet.js';\nimport { getRowByIndex } from './resolve.js';\n\nexport function removeRow(sheet: Sheet, rowIndex: number): Sheet {\n const row = getRowByIndex(sheet, rowIndex);\n if (!row) return sheet;\n const newRows: ValidatedRow[] = sheet.rows\n .filter((r) => r.index !== rowIndex)\n .map((r, i) => ({ ...r, index: i }));\n return { ...sheet, rows: newRows };\n}\n\nexport function setCellValue(\n sheet: Sheet,\n rowIndex: number,\n cellKey: string,\n value: unknown\n): Sheet {\n const row = getRowByIndex(sheet, rowIndex);\n if (!row) return sheet;\n const cellIndex = row.cells.findIndex((c) => c.key === cellKey);\n if (cellIndex < 0) return sheet;\n const newCell: ValidatedCell = { ...row.cells[cellIndex]!, value, errors: [] };\n const newCells: ValidatedCell[] = row.cells.map((c, i) => (i === cellIndex ? newCell : c));\n const newRow: ValidatedRow = { ...row, cells: newCells, errors: [] };\n const newRows: ValidatedRow[] = sheet.rows.map((r) => (r.index === rowIndex ? newRow : r));\n return { ...sheet, rows: newRows };\n}\n","import type { SheetLayout } from '../../types/sheet-layout.js';\nimport type { Sheet, ValidatedCell, ValidatedRow } from '../../types/sheet.js';\nimport type { SanitizedSheet } from '../sanitizer/types/sanitized-sheet.js';\nimport { runCellValidators } from '../validator/runner/cell-validators.js';\nimport { runRowValidators } from '../validator/runner/row-validators.js';\nimport { runTableValidation } from '../validator/runner/run-table-validation.js';\nimport { isValidatorErrorSheet } from '../validator/types/validator-delta.js';\nimport type { GetCellValidator } from '../validator/runner/cell-validators.js';\nimport type { GetRowValidator } from '../validator/runner/row-validators.js';\nimport type { GetTableValidator } from '../validator/runner/run-table-validation.js';\nimport { runCellTransforms } from '../transform/runner/cell-transforms.js';\nimport { runRowTransforms } from '../transform/runner/row-transforms.js';\nimport { runSheetTransforms } from '../transform/runner/sheet-transforms.js';\nimport type { GetCellTransform } from '../transform/runner/cell-transforms.js';\nimport type { GetRowTransform } from '../transform/runner/row-transforms.js';\nimport type { GetSheetTransform } from '../transform/runner/sheet-transforms.js';\nimport { applyTransformDelta } from '../transform/delta-applier.js';\nimport { setCellValue } from './immutable-update.js';\nimport { getRowByIndex, getCellByKey } from './resolve.js';\n\nexport interface EditValidatorGetters {\n getCellValidator: GetCellValidator;\n getRowValidator: GetRowValidator;\n getTableValidator: GetTableValidator;\n}\n\nexport interface EditTransformGetters {\n getCellTransform: GetCellTransform;\n getRowTransform: GetRowTransform;\n getSheetTransform: GetSheetTransform;\n}\n\nexport interface EditPipelineGetters {\n validator: EditValidatorGetters;\n transform: EditTransformGetters;\n}\n\nexport async function runEditPipeline(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n rowIndex: number,\n cellKey: string,\n value: unknown,\n getters: EditPipelineGetters,\n signal?: AbortSignal,\n): Promise<Sheet> {\n const sheet1 = setCellValue(sheet, rowIndex, cellKey, value);\n const row = getRowByIndex(sheet1, rowIndex);\n if (!row) return sheet1;\n const cell = getCellByKey(row, cellKey);\n if (!cell) return sheet1;\n const field = sheetLayout.fields[cellKey];\n if (!field) return sheet1;\n\n const cellErrors = runCellValidators(\n cell as unknown as import('../sanitizer/types/sanitized-sheet.js').SanitizedSheetCell,\n row as unknown as import('../sanitizer/types/sanitized-sheet.js').SanitizedSheetRow,\n field,\n getters.validator.getCellValidator,\n );\n const newCell: ValidatedCell = { ...cell, errors: cellErrors };\n const newRow: ValidatedRow = {\n ...row,\n cells: row.cells.map((c) => (c.key === cellKey ? newCell : c)),\n errors: [],\n };\n const rowErrors = runRowValidators(\n newRow as unknown as import('../sanitizer/types/sanitized-sheet.js').SanitizedSheetRow,\n sheetLayout,\n getters.validator.getRowValidator,\n );\n const newRow2: ValidatedRow = { ...newRow, errors: rowErrors };\n const newRows = sheet1.rows.map((r) => (r.index === rowIndex ? newRow2 : r));\n const sheet2: Sheet = { ...sheet1, rows: newRows };\n\n const tableErrors = await runTableValidation(\n sheet2 as unknown as SanitizedSheet,\n sheetLayout,\n getters.validator.getTableValidator,\n signal,\n );\n const sheetErrors = tableErrors\n .filter(isValidatorErrorSheet)\n .map((i) => i.error);\n const sheet3: Sheet = { ...sheet2, errors: [...sheet2.errors, ...sheetErrors] };\n\n if (sheet3.errors.length > 0) return sheet3;\n\n const cellValue =\n newCell.errors.length === 0\n ? runCellTransforms(\n newCell,\n newRow2,\n field,\n getters.transform.getCellTransform,\n )\n : newCell.value;\n const updatedCell: ValidatedCell = { ...newCell, value: cellValue };\n const rowWithCellTransform: ValidatedRow = {\n ...newRow2,\n cells: newRow2.cells.map((c) => (c.key === cellKey ? updatedCell : c)),\n };\n const transformedRow =\n newRow2.errors.length === 0\n ? runRowTransforms(\n rowWithCellTransform,\n sheetLayout,\n getters.transform.getRowTransform,\n )\n : rowWithCellTransform;\n const sheet4: Sheet = {\n ...sheet3,\n rows: sheet3.rows.map((r) => (r.index === rowIndex ? transformedRow : r)),\n };\n const sheetOut = await runSheetTransforms(\n sheet4,\n sheetLayout,\n getters.transform.getSheetTransform,\n signal,\n );\n const sheet5 = applyTransformDelta(sheet4, { deltas: sheetOut.deltas });\n if (sheetOut.errors.length > 0) {\n return { ...sheet5, errors: [...sheet5.errors, ...sheetOut.errors] };\n }\n return sheet5;\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 { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const REQUIRED_VALIDATOR_ID = 'required';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>,\n) => readonly SheetError[] | null;\n\nexport function cellRequiredValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>,\n): readonly SheetError[] | null {\n const isEmpty =\n value === null ||\n value === undefined ||\n (typeof value === 'string' && value.trim() === '');\n if (isEmpty) {\n return [{ code: 'REQUIRED', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerRequiredValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void,\n): void {\n register(REQUIRED_VALIDATOR_ID, cellRequiredValidator, { type: 'cell' });\n}\n\nexport const CellRequiredValidator = {\n id: REQUIRED_VALIDATOR_ID,\n validate: cellRequiredValidator,\n Register(registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void): string {\n if (registerFn) registerRequiredValidator(registerFn);\n return REQUIRED_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_BYREGEX_VALIDATOR_ID = 'string:byregex';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { pattern?: string; flags?: string };\n\nexport function cellStringByregexValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { pattern = '', flags = '' } = (params ?? {}) as Params;\n if (!pattern) {\n return [\n {\n code: 'STRING_BYREGEX_INVALID_PARAMS',\n level: 'error',\n params: { reason: 'missing pattern' },\n },\n ];\n }\n const s = value === null || value === undefined ? '' : String(value);\n try {\n const re = new RegExp(pattern, flags);\n if (!re.test(s)) {\n return [{ code: 'STRING_BYREGEX_MISMATCH', level: 'error', params: { value: s, pattern } }];\n }\n } catch {\n return [{ code: 'STRING_BYREGEX_INVALID_PATTERN', level: 'error', params: { pattern } }];\n }\n return null;\n}\n\nexport function registerStringByregexValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_BYREGEX_VALIDATOR_ID, cellStringByregexValidator, { type: 'cell' });\n}\n\nexport const CellStringByregexValidator = {\n id: STRING_BYREGEX_VALIDATOR_ID,\n validate: cellStringByregexValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringByregexValidator(registerFn);\n return STRING_BYREGEX_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_MAX_LENGTH_VALIDATOR_ID = 'string:maxLength';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { maxLength?: number };\n\nexport function cellStringMaxLengthValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { maxLength } = (params ?? {}) as Params;\n const max = typeof maxLength === 'number' && Number.isFinite(maxLength) ? maxLength : undefined;\n if (max === undefined || max < 0) {\n return [{ code: 'STRING_MAX_LENGTH_INVALID_PARAMS', level: 'error', params: { maxLength } }];\n }\n const s = value === null || value === undefined ? '' : String(value);\n if (s.length > max) {\n return [\n {\n code: 'STRING_MAX_LENGTH',\n level: 'error',\n params: { value: s, maxLength: max, length: s.length },\n },\n ];\n }\n return null;\n}\n\nexport function registerStringMaxLengthValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_MAX_LENGTH_VALIDATOR_ID, cellStringMaxLengthValidator, { type: 'cell' });\n}\n\nexport const CellStringMaxLengthValidator = {\n id: STRING_MAX_LENGTH_VALIDATOR_ID,\n validate: cellStringMaxLengthValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringMaxLengthValidator(registerFn);\n return STRING_MAX_LENGTH_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_MIN_LENGTH_VALIDATOR_ID = 'string:minLength';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { minLength?: number };\n\nexport function cellStringMinLengthValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { minLength } = (params ?? {}) as Params;\n const min =\n typeof minLength === 'number' && Number.isFinite(minLength) && minLength >= 0\n ? minLength\n : undefined;\n if (min === undefined) {\n return [{ code: 'STRING_MIN_LENGTH_INVALID_PARAMS', level: 'error', params: { minLength } }];\n }\n const s = value === null || value === undefined ? '' : String(value);\n if (s.length < min) {\n return [\n {\n code: 'STRING_MIN_LENGTH',\n level: 'error',\n params: { value: s, minLength: min, length: s.length },\n },\n ];\n }\n return null;\n}\n\nexport function registerStringMinLengthValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_MIN_LENGTH_VALIDATOR_ID, cellStringMinLengthValidator, { type: 'cell' });\n}\n\nexport const CellStringMinLengthValidator = {\n id: STRING_MIN_LENGTH_VALIDATOR_ID,\n validate: cellStringMinLengthValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringMinLengthValidator(registerFn);\n return STRING_MIN_LENGTH_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_EMAIL_VALIDATOR_ID = 'string:email';\n\nconst EMAIL_REGEX =\n /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringEmailValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const s = value === null || value === undefined ? '' : String(value).trim();\n if (!s) return null;\n if (!EMAIL_REGEX.test(s)) {\n return [{ code: 'STRING_EMAIL_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringEmailValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_EMAIL_VALIDATOR_ID, cellStringEmailValidator, { type: 'cell' });\n}\n\nexport const CellStringEmailValidator = {\n id: STRING_EMAIL_VALIDATOR_ID,\n validate: cellStringEmailValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringEmailValidator(registerFn);\n return STRING_EMAIL_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_PHONE_VALIDATOR_ID = 'string:phone';\n\nconst PHONE_REGEX = /^[\\d\\s\\-+.()]{7,20}$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringPhoneValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const s = value === null || value === undefined ? '' : String(value).trim();\n if (!s) return null;\n const digitsOnly = s.replace(/\\D/g, '');\n if (digitsOnly.length < 7 || digitsOnly.length > 15 || !PHONE_REGEX.test(s)) {\n return [{ code: 'STRING_PHONE_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringPhoneValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_PHONE_VALIDATOR_ID, cellStringPhoneValidator, { type: 'cell' });\n}\n\nexport const CellStringPhoneValidator = {\n id: STRING_PHONE_VALIDATOR_ID,\n validate: cellStringPhoneValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringPhoneValidator(registerFn);\n return STRING_PHONE_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_PHONE_INTERNATIONAL_VALIDATOR_ID = 'string:phoneInternational';\n\nconst E164_PREFIX = /^\\+?[1-9]\\d{0,3}/;\nconst MIN_DIGITS = 10;\nconst MAX_DIGITS = 15;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringPhoneInternationalValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const s = value === null || value === undefined ? '' : String(value).trim().replace(/\\s/g, '');\n if (!s) return null;\n const digits = s.replace(/\\D/g, '');\n const withPlus = s.startsWith('+') ? s : `+${s}`;\n if (digits.length < MIN_DIGITS || digits.length > MAX_DIGITS || !E164_PREFIX.test(withPlus)) {\n return [{ code: 'STRING_PHONE_INTERNATIONAL_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringPhoneInternationalValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_PHONE_INTERNATIONAL_VALIDATOR_ID, cellStringPhoneInternationalValidator, {\n type: 'cell',\n });\n}\n\nexport const CellStringPhoneInternationalValidator = {\n id: STRING_PHONE_INTERNATIONAL_VALIDATOR_ID,\n validate: cellStringPhoneInternationalValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringPhoneInternationalValidator(registerFn);\n return STRING_PHONE_INTERNATIONAL_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_PHONE_LOCAL_VALIDATOR_ID = 'string:phoneLocal';\n\ntype Params = { minDigits?: number; maxDigits?: number };\n\nconst DEFAULT_MIN = 6;\nconst DEFAULT_MAX = 11;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringPhoneLocalValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { minDigits = DEFAULT_MIN, maxDigits = DEFAULT_MAX } = (params ?? {}) as Params;\n const min = typeof minDigits === 'number' && minDigits >= 0 ? minDigits : DEFAULT_MIN;\n const max = typeof maxDigits === 'number' && maxDigits >= min ? maxDigits : DEFAULT_MAX;\n const s = value === null || value === undefined ? '' : String(value).trim();\n if (!s) return null;\n const digits = s.replace(/\\D/g, '');\n if (s.startsWith('+') && digits.length > 3) {\n return [\n {\n code: 'STRING_PHONE_LOCAL_INVALID',\n level: 'error',\n params: { value: s, reason: 'international' },\n },\n ];\n }\n if (digits.length < min || digits.length > max) {\n return [\n {\n code: 'STRING_PHONE_LOCAL_INVALID',\n level: 'error',\n params: { value: s, minDigits: min, maxDigits: max },\n },\n ];\n }\n return null;\n}\n\nexport function registerStringPhoneLocalValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_PHONE_LOCAL_VALIDATOR_ID, cellStringPhoneLocalValidator, { type: 'cell' });\n}\n\nexport const CellStringPhoneLocalValidator = {\n id: STRING_PHONE_LOCAL_VALIDATOR_ID,\n validate: cellStringPhoneLocalValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringPhoneLocalValidator(registerFn);\n return STRING_PHONE_LOCAL_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_ONLY_NUMBERS_VALIDATOR_ID = 'string:onlyNumbers';\n\nconst ONLY_DIGITS = /^\\d+$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringOnlyNumbersValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n if (!ONLY_DIGITS.test(s)) {\n return [{ code: 'STRING_ONLY_NUMBERS_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringOnlyNumbersValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_ONLY_NUMBERS_VALIDATOR_ID, cellStringOnlyNumbersValidator, { type: 'cell' });\n}\n\nexport const CellStringOnlyNumbersValidator = {\n id: STRING_ONLY_NUMBERS_VALIDATOR_ID,\n validate: cellStringOnlyNumbersValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringOnlyNumbersValidator(registerFn);\n return STRING_ONLY_NUMBERS_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const STRING_ONLY_LETTERS_VALIDATOR_ID = 'string:onlyLetters';\n\ntype Params = { allowSpaces?: boolean };\n\nconst ONLY_LETTERS = /^[a-zA-Z\\u00C0-\\u024F\\u1E00-\\u1EFF]+$/;\nconst ONLY_LETTERS_AND_SPACES = /^[a-zA-Z\\u00C0-\\u024F\\u1E00-\\u1EFF\\s]+$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellStringOnlyLettersValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { allowSpaces = false } = (params ?? {}) as Params;\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const re = allowSpaces ? ONLY_LETTERS_AND_SPACES : ONLY_LETTERS;\n if (!re.test(s)) {\n return [{ code: 'STRING_ONLY_LETTERS_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerStringOnlyLettersValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(STRING_ONLY_LETTERS_VALIDATOR_ID, cellStringOnlyLettersValidator, { type: 'cell' });\n}\n\nexport const CellStringOnlyLettersValidator = {\n id: STRING_ONLY_LETTERS_VALIDATOR_ID,\n validate: cellStringOnlyLettersValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerStringOnlyLettersValidator(registerFn);\n return STRING_ONLY_LETTERS_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_MIN_VALIDATOR_ID = 'number:min';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { min?: number };\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberMinValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { min } = (params ?? {}) as Params;\n const minVal = typeof min === 'number' && Number.isFinite(min) ? min : undefined;\n if (minVal === undefined) {\n return [{ code: 'NUMBER_MIN_INVALID_PARAMS', level: 'error', params: { min } }];\n }\n const n = toNumber(value);\n if (n === null) return [{ code: 'NUMBER_MIN_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n < minVal) {\n return [{ code: 'NUMBER_MIN', level: 'error', params: { value: n, min: minVal } }];\n }\n return null;\n}\n\nexport function registerNumberMinValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_MIN_VALIDATOR_ID, cellNumberMinValidator, { type: 'cell' });\n}\n\nexport const CellNumberMinValidator = {\n id: NUMBER_MIN_VALIDATOR_ID,\n validate: cellNumberMinValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberMinValidator(registerFn);\n return NUMBER_MIN_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_MAX_VALIDATOR_ID = 'number:max';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { max?: number };\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberMaxValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { max } = (params ?? {}) as Params;\n const maxVal = typeof max === 'number' && Number.isFinite(max) ? max : undefined;\n if (maxVal === undefined) {\n return [{ code: 'NUMBER_MAX_INVALID_PARAMS', level: 'error', params: { max } }];\n }\n const n = toNumber(value);\n if (n === null) return [{ code: 'NUMBER_MAX_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n > maxVal) {\n return [{ code: 'NUMBER_MAX', level: 'error', params: { value: n, max: maxVal } }];\n }\n return null;\n}\n\nexport function registerNumberMaxValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_MAX_VALIDATOR_ID, cellNumberMaxValidator, { type: 'cell' });\n}\n\nexport const CellNumberMaxValidator = {\n id: NUMBER_MAX_VALIDATOR_ID,\n validate: cellNumberMaxValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberMaxValidator(registerFn);\n return NUMBER_MAX_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_FLOAT_VALIDATOR_ID = 'number:float';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction isFiniteFloat(value: unknown): boolean {\n if (value === null || value === undefined) return false;\n if (typeof value === 'number') return Number.isFinite(value);\n const s = String(value).trim();\n if (!s) return false;\n const n = parseFloat(s);\n return Number.isFinite(n);\n}\n\nexport function cellNumberFloatValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n if (!isFiniteFloat(value)) {\n return [{ code: 'NUMBER_FLOAT_INVALID', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerNumberFloatValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_FLOAT_VALIDATOR_ID, cellNumberFloatValidator, { type: 'cell' });\n}\n\nexport const CellNumberFloatValidator = {\n id: NUMBER_FLOAT_VALIDATOR_ID,\n validate: cellNumberFloatValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberFloatValidator(registerFn);\n return NUMBER_FLOAT_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_INTEGER_VALIDATOR_ID = 'number:integer';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction toInteger(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value) && Number.isInteger(value)) return value;\n const n = Number(value);\n if (!Number.isFinite(n)) return null;\n return Number.isInteger(n) ? n : null;\n}\n\nexport function cellNumberIntegerValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n const n = toInteger(value);\n if (n === null) {\n return [{ code: 'NUMBER_INTEGER_INVALID', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerNumberIntegerValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_INTEGER_VALIDATOR_ID, cellNumberIntegerValidator, { type: 'cell' });\n}\n\nexport const CellNumberIntegerValidator = {\n id: NUMBER_INTEGER_VALIDATOR_ID,\n validate: cellNumberIntegerValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberIntegerValidator(registerFn);\n return NUMBER_INTEGER_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_NON_NEGATIVE_VALIDATOR_ID = 'number:nonNegative';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberNonNegativeValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n const n = toNumber(value);\n if (n === null)\n return [{ code: 'NUMBER_NON_NEGATIVE_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n < 0) return [{ code: 'NUMBER_NON_NEGATIVE', level: 'error', params: { value: n } }];\n return null;\n}\n\nexport function registerNumberNonNegativeValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_NON_NEGATIVE_VALIDATOR_ID, cellNumberNonNegativeValidator, { type: 'cell' });\n}\n\nexport const CellNumberNonNegativeValidator = {\n id: NUMBER_NON_NEGATIVE_VALIDATOR_ID,\n validate: cellNumberNonNegativeValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberNonNegativeValidator(registerFn);\n return NUMBER_NON_NEGATIVE_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_NON_POSITIVE_VALIDATOR_ID = 'number:nonPositive';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberNonPositiveValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n const n = toNumber(value);\n if (n === null)\n return [{ code: 'NUMBER_NON_POSITIVE_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n > 0) return [{ code: 'NUMBER_NON_POSITIVE', level: 'error', params: { value: n } }];\n return null;\n}\n\nexport function registerNumberNonPositiveValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_NON_POSITIVE_VALIDATOR_ID, cellNumberNonPositiveValidator, { type: 'cell' });\n}\n\nexport const CellNumberNonPositiveValidator = {\n id: NUMBER_NON_POSITIVE_VALIDATOR_ID,\n validate: cellNumberNonPositiveValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberNonPositiveValidator(registerFn);\n return NUMBER_NON_POSITIVE_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const NUMBER_NON_ZERO_VALIDATOR_ID = 'number:nonZero';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nfunction toNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n const n = Number(value);\n return Number.isFinite(n) ? n : null;\n}\n\nexport function cellNumberNonZeroValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n const n = toNumber(value);\n if (n === null)\n return [{ code: 'NUMBER_NON_ZERO_NOT_A_NUMBER', level: 'error', params: { value } }];\n if (n === 0) return [{ code: 'NUMBER_NON_ZERO', level: 'error', params: { value: n } }];\n return null;\n}\n\nexport function registerNumberNonZeroValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(NUMBER_NON_ZERO_VALIDATOR_ID, cellNumberNonZeroValidator, { type: 'cell' });\n}\n\nexport const CellNumberNonZeroValidator = {\n id: NUMBER_NON_ZERO_VALIDATOR_ID,\n validate: cellNumberNonZeroValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerNumberNonZeroValidator(registerFn);\n return NUMBER_NON_ZERO_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_MIN_VALIDATOR_ID = 'date:min';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { min?: string | number };\n\nfunction toTime(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const ms = Date.parse(String(value).trim());\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport function cellDateMinValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { min } = (params ?? {}) as Params;\n const minMs = min !== undefined ? toTime(min) : undefined;\n if (minMs === undefined || minMs === null) {\n return [{ code: 'DATE_MIN_INVALID_PARAMS', level: 'error', params: { min } }];\n }\n const v = toTime(value);\n if (v === null) return [{ code: 'DATE_MIN_NOT_A_DATE', level: 'error', params: { value } }];\n if (v < minMs) return [{ code: 'DATE_MIN', level: 'error', params: { value: v, min: minMs } }];\n return null;\n}\n\nexport function registerDateMinValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_MIN_VALIDATOR_ID, cellDateMinValidator, { type: 'cell' });\n}\n\nexport const CellDateMinValidator = {\n id: DATE_MIN_VALIDATOR_ID,\n validate: cellDateMinValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateMinValidator(registerFn);\n return DATE_MIN_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_MAX_VALIDATOR_ID = 'date:max';\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype Params = { max?: string | number };\n\nfunction toTime(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const ms = Date.parse(String(value).trim());\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport function cellDateMaxValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n const { max } = (params ?? {}) as Params;\n const maxMs = max !== undefined ? toTime(max) : undefined;\n if (maxMs === undefined || maxMs === null) {\n return [{ code: 'DATE_MAX_INVALID_PARAMS', level: 'error', params: { max } }];\n }\n const v = toTime(value);\n if (v === null) return [{ code: 'DATE_MAX_NOT_A_DATE', level: 'error', params: { value } }];\n if (v > maxMs) return [{ code: 'DATE_MAX', level: 'error', params: { value: v, max: maxMs } }];\n return null;\n}\n\nexport function registerDateMaxValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_MAX_VALIDATOR_ID, cellDateMaxValidator, { type: 'cell' });\n}\n\nexport const CellDateMaxValidator = {\n id: DATE_MAX_VALIDATOR_ID,\n validate: cellDateMaxValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateMaxValidator(registerFn);\n return DATE_MAX_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_ONLY_YEAR_VALIDATOR_ID = 'date:onlyYear';\n\nconst YEAR_REGEX = /^(?:19|20)\\d{2}$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateOnlyYearValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const n = Number(s);\n const strMatch = YEAR_REGEX.test(s);\n const numMatch = Number.isInteger(n) && n >= 1900 && n <= 2099;\n if (!strMatch && !numMatch) {\n return [{ code: 'DATE_ONLY_YEAR_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerDateOnlyYearValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_ONLY_YEAR_VALIDATOR_ID, cellDateOnlyYearValidator, { type: 'cell' });\n}\n\nexport const CellDateOnlyYearValidator = {\n id: DATE_ONLY_YEAR_VALIDATOR_ID,\n validate: cellDateOnlyYearValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateOnlyYearValidator(registerFn);\n return DATE_ONLY_YEAR_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_ONLY_TIME_VALIDATOR_ID = 'date:onlyTime';\n\nconst TIME_REGEX = /^([01]?\\d|2[0-3]):([0-5]\\d)(?::([0-5]\\d))?(?:\\.\\d+)?$/;\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateOnlyTimeValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n if (!TIME_REGEX.test(s)) {\n return [{ code: 'DATE_ONLY_TIME_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerDateOnlyTimeValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_ONLY_TIME_VALIDATOR_ID, cellDateOnlyTimeValidator, { type: 'cell' });\n}\n\nexport const CellDateOnlyTimeValidator = {\n id: DATE_ONLY_TIME_VALIDATOR_ID,\n validate: cellDateOnlyTimeValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateOnlyTimeValidator(registerFn);\n return DATE_ONLY_TIME_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_DATETIME_VALIDATOR_ID = 'date:datetime';\n\nfunction toTime(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const ms = Date.parse(String(value).trim());\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateDatetimeValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = toTime(value);\n if (ms === null) {\n return [{ code: 'DATE_DATETIME_INVALID', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerDateDatetimeValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_DATETIME_VALIDATOR_ID, cellDateDatetimeValidator, { type: 'cell' });\n}\n\nexport const CellDateDatetimeValidator = {\n id: DATE_DATETIME_VALIDATOR_ID,\n validate: cellDateDatetimeValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateDatetimeValidator(registerFn);\n return DATE_DATETIME_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_TIMESTAMP_VALIDATOR_ID = 'date:timestamp';\n\nconst MAX_MS = 8640000000000;\nconst MIN_MS = -8640000000000;\n\nfunction toTimestamp(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const s = String(value).trim();\n if (/^\\d+$/.test(s)) {\n const n = Number(s);\n return Number.isFinite(n) ? n : null;\n }\n const ms = Date.parse(s);\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateTimestampValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = toTimestamp(value);\n if (ms === null) {\n return [{ code: 'DATE_TIMESTAMP_INVALID', level: 'error', params: { value: s } }];\n }\n if (ms < MIN_MS || ms > MAX_MS) {\n return [{ code: 'DATE_TIMESTAMP_OUT_OF_RANGE', level: 'error', params: { value: ms } }];\n }\n return null;\n}\n\nexport function registerDateTimestampValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_TIMESTAMP_VALIDATOR_ID, cellDateTimestampValidator, { type: 'cell' });\n}\n\nexport const CellDateTimestampValidator = {\n id: DATE_TIMESTAMP_VALIDATOR_ID,\n validate: cellDateTimestampValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateTimestampValidator(registerFn);\n return DATE_TIMESTAMP_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const DATE_UTC_VALIDATOR_ID = 'date:utc';\n\nfunction toTime(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n if (typeof value === 'number' && Number.isFinite(value)) return value;\n if (value instanceof Date && !Number.isNaN(value.getTime())) return value.getTime();\n const ms = Date.parse(String(value).trim());\n return Number.isNaN(ms) ? null : ms;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellDateUtcValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined) return null;\n const s = String(value).trim();\n if (!s) return null;\n const ms = toTime(value);\n if (ms === null) {\n return [{ code: 'DATE_UTC_NOT_A_DATE', level: 'error', params: { value: s } }];\n }\n const isUtc =\n typeof value === 'number' || s.endsWith('Z') || /[+-]00:00$/.test(s) || /^\\d+$/.test(s);\n if (!isUtc) {\n return [{ code: 'DATE_UTC_REQUIRED', level: 'error', params: { value: s } }];\n }\n return null;\n}\n\nexport function registerDateUtcValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(DATE_UTC_VALIDATOR_ID, cellDateUtcValidator, { type: 'cell' });\n}\n\nexport const CellDateUtcValidator = {\n id: DATE_UTC_VALIDATOR_ID,\n validate: cellDateUtcValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerDateUtcValidator(registerFn);\n return DATE_UTC_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const BOOL_ONLY_TRUE_VALIDATOR_ID = 'bool:onlyTrue';\n\nfunction isTrue(value: unknown): boolean {\n if (value === true) return true;\n if (typeof value === 'string') {\n const t = value.trim().toLowerCase();\n return t === 'true' || t === '1' || t === 'yes';\n }\n return value === 1;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellBoolOnlyTrueValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n if (!isTrue(value)) {\n return [{ code: 'BOOL_ONLY_TRUE', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerBoolOnlyTrueValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(BOOL_ONLY_TRUE_VALIDATOR_ID, cellBoolOnlyTrueValidator, { type: 'cell' });\n}\n\nexport const CellBoolOnlyTrueValidator = {\n id: BOOL_ONLY_TRUE_VALIDATOR_ID,\n validate: cellBoolOnlyTrueValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerBoolOnlyTrueValidator(registerFn);\n return BOOL_ONLY_TRUE_VALIDATOR_ID;\n },\n};\n","import type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheetRow } from '../../../core/sanitizer/types/sanitized-sheet.js';\n\nexport const BOOL_ONLY_FALSE_VALIDATOR_ID = 'bool:onlyFalse';\n\nfunction isFalse(value: unknown): boolean {\n if (value === false) return true;\n if (typeof value === 'string') {\n const t = value.trim().toLowerCase();\n return t === 'false' || t === '0' || t === 'no';\n }\n return value === 0;\n}\n\nexport type CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n params?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\nexport function cellBoolOnlyFalseValidator(\n value: unknown,\n _row: SanitizedSheetRow,\n _params?: Readonly<Record<string, unknown>>\n): readonly SheetError[] | null {\n if (value === null || value === undefined || value === '') return null;\n if (!isFalse(value)) {\n return [{ code: 'BOOL_ONLY_FALSE', level: 'error', params: { value } }];\n }\n return null;\n}\n\nexport function registerBoolOnlyFalseValidator(\n register: (name: string, fn: CellValidatorFn, options: { type: 'cell' }) => void\n): void {\n register(BOOL_ONLY_FALSE_VALIDATOR_ID, cellBoolOnlyFalseValidator, { type: 'cell' });\n}\n\nexport const CellBoolOnlyFalseValidator = {\n id: BOOL_ONLY_FALSE_VALIDATOR_ID,\n validate: cellBoolOnlyFalseValidator,\n Register(\n registerFn?: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n ): string {\n if (registerFn) registerBoolOnlyFalseValidator(registerFn);\n return BOOL_ONLY_FALSE_VALIDATOR_ID;\n },\n};\n","import { Registry } from '../../../shared/registry/index.js';\nimport { registerRequiredValidator } from '../../../utils/controller/required/cell-required-validator.js';\nimport { registerStringByregexValidator } from '../../../utils/controller/string/cell-string-byregex-validator.js';\nimport { registerStringMaxLengthValidator } from '../../../utils/controller/string/cell-string-max-length-validator.js';\nimport { registerStringMinLengthValidator } from '../../../utils/controller/string/cell-string-min-length-validator.js';\nimport { registerStringEmailValidator } from '../../../utils/controller/string/cell-string-email-validator.js';\nimport { registerStringPhoneValidator } from '../../../utils/controller/string/cell-string-phone-validator.js';\nimport { registerStringPhoneInternationalValidator } from '../../../utils/controller/string/cell-string-phone-international-validator.js';\nimport { registerStringPhoneLocalValidator } from '../../../utils/controller/string/cell-string-phone-local-validator.js';\nimport { registerStringOnlyNumbersValidator } from '../../../utils/controller/string/cell-string-only-numbers-validator.js';\nimport { registerStringOnlyLettersValidator } from '../../../utils/controller/string/cell-string-only-letters-validator.js';\nimport { registerNumberMinValidator } from '../../../utils/controller/number/cell-number-min-validator.js';\nimport { registerNumberMaxValidator } from '../../../utils/controller/number/cell-number-max-validator.js';\nimport { registerNumberFloatValidator } from '../../../utils/controller/number/cell-number-float-validator.js';\nimport { registerNumberIntegerValidator } from '../../../utils/controller/number/cell-number-integer-validator.js';\nimport { registerNumberNonNegativeValidator } from '../../../utils/controller/number/cell-number-non-negative-validator.js';\nimport { registerNumberNonPositiveValidator } from '../../../utils/controller/number/cell-number-non-positive-validator.js';\nimport { registerNumberNonZeroValidator } from '../../../utils/controller/number/cell-number-non-zero-validator.js';\nimport { registerDateMinValidator } from '../../../utils/controller/date/cell-date-min-validator.js';\nimport { registerDateMaxValidator } from '../../../utils/controller/date/cell-date-max-validator.js';\nimport { registerDateOnlyYearValidator } from '../../../utils/controller/date/cell-date-only-year-validator.js';\nimport { registerDateOnlyTimeValidator } from '../../../utils/controller/date/cell-date-only-time-validator.js';\nimport { registerDateDatetimeValidator } from '../../../utils/controller/date/cell-date-datetime-validator.js';\nimport { registerDateTimestampValidator } from '../../../utils/controller/date/cell-date-timestamp-validator.js';\nimport { registerDateUtcValidator } from '../../../utils/controller/date/cell-date-utc-validator.js';\nimport { registerBoolOnlyTrueValidator } from '../../../utils/controller/bool/cell-bool-only-true-validator.js';\nimport { registerBoolOnlyFalseValidator } from '../../../utils/controller/bool/cell-bool-only-false-validator.js';\nimport type { SheetError } from '../../../types/error.js';\nimport type { SanitizedSheet, SanitizedSheetRow } from '../../sanitizer/types/sanitized-sheet.js';\n\ntype CellValidatorFn = (\n value: unknown,\n row: SanitizedSheetRow,\n p?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype RowValidatorFn = (\n row: SanitizedSheetRow,\n p?: Readonly<Record<string, unknown>>\n) => readonly SheetError[] | null;\n\ntype TableValidatorFn = (\n sheet: SanitizedSheet,\n p?: Readonly<Record<string, unknown>>,\n signal?: AbortSignal\n) => readonly SheetError[] | null | Promise<readonly SheetError[] | null>;\n\nconst registry = new Registry<(...args: unknown[]) => unknown>();\n\nfunction registerAll(\n register: (name: string, fn: CellValidatorFn, opts: { type: 'cell' }) => void\n): void {\n registerRequiredValidator(register);\n registerStringByregexValidator(register);\n registerStringMaxLengthValidator(register);\n registerStringMinLengthValidator(register);\n registerStringEmailValidator(register);\n registerStringPhoneValidator(register);\n registerStringPhoneInternationalValidator(register);\n registerStringPhoneLocalValidator(register);\n registerStringOnlyNumbersValidator(register);\n registerStringOnlyLettersValidator(register);\n registerNumberMinValidator(register);\n registerNumberMaxValidator(register);\n registerNumberFloatValidator(register);\n registerNumberIntegerValidator(register);\n registerNumberNonNegativeValidator(register);\n registerNumberNonPositiveValidator(register);\n registerNumberNonZeroValidator(register);\n registerDateMinValidator(register);\n registerDateMaxValidator(register);\n registerDateOnlyYearValidator(register);\n registerDateOnlyTimeValidator(register);\n registerDateDatetimeValidator(register);\n registerDateTimestampValidator(register);\n registerDateUtcValidator(register);\n registerBoolOnlyTrueValidator(register);\n registerBoolOnlyFalseValidator(register);\n}\n\nregisterAll((name, fn, opts) => {\n registry.register(name, fn, opts);\n});\n\nfunction getCellValidator(name: string): CellValidatorFn | undefined {\n const entry = registry.get(name);\n if (!entry || entry.type !== 'cell') return undefined;\n return entry.fn as CellValidatorFn;\n}\n\nfunction getRowValidator(_name: string): RowValidatorFn | undefined {\n return undefined;\n}\n\nfunction getTableValidator(_name: string): TableValidatorFn | undefined {\n return undefined;\n}\n\nexport function getValidatorGetters(): {\n getCellValidator: (name: string) => CellValidatorFn | undefined;\n getRowValidator: (name: string) => RowValidatorFn | undefined;\n getTableValidator: (name: string) => TableValidatorFn | undefined;\n} {\n return { getCellValidator, getRowValidator, getTableValidator };\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 { runEditPipeline } from '../run-edit-pipeline.js';\nimport { getValidatorGetters } from '../../validator/worker/worker-registry.js';\nimport { getTransformGetters } from '../../transform/worker/worker-registry.js';\n\nexport interface EditWorkerOptions {\n signal?: AbortSignal;\n}\n\nconst api = {\n async runEdit(\n sheet: Sheet,\n sheetLayout: SheetLayout,\n rowIndex: number,\n cellKey: string,\n value: unknown,\n options?: EditWorkerOptions,\n ): Promise<Sheet> {\n const validator = getValidatorGetters();\n const transform = getTransformGetters();\n return runEditPipeline(\n sheet,\n sheetLayout,\n rowIndex,\n cellKey,\n value,\n { validator, transform },\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","resolveValidatorRef","ref","runCellValidators","cell","row","field","getValidator","list","errors","ref","name","params","resolveValidatorRef","fn","result","e","runRowValidators","row","sheetLayout","getValidator","list","errors","ref","name","params","resolveValidatorRef","fn","result","e","EXTERNAL_VALIDATION_FAILED","toSheetLevelItems","errors","error","runTableValidation","sheet","sheetLayout","getValidator","signal","list","collected","ref","name","params","resolveValidatorRef","fn","result","isValidatorErrorSheet","item","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","getRowByIndex","sheet","rowIndex","row","getCellByKey","cellKey","cell","setCellValue","sheet","rowIndex","cellKey","value","row","getRowByIndex","cellIndex","c","newCell","newCells","i","newRow","newRows","r","runEditPipeline","sheet","sheetLayout","rowIndex","cellKey","value","getters","signal","sheet1","setCellValue","row","getRowByIndex","cell","getCellByKey","field","cellErrors","runCellValidators","newCell","newRow","rowErrors","runRowValidators","newRow2","newRows","r","sheet2","sheetErrors","runTableValidation","isValidatorErrorSheet","i","sheet3","cellValue","runCellTransforms","updatedCell","rowWithCellTransform","transformedRow","runRowTransforms","sheet4","sheetOut","runSheetTransforms","sheet5","applyTransformDelta","Registry","name","fn","options","type","e","entry","REQUIRED_VALIDATOR_ID","cellRequiredValidator","value","_row","_params","registerRequiredValidator","register","STRING_BYREGEX_VALIDATOR_ID","cellStringByregexValidator","value","_row","params","pattern","flags","s","registerStringByregexValidator","register","STRING_MAX_LENGTH_VALIDATOR_ID","cellStringMaxLengthValidator","value","_row","params","maxLength","max","s","registerStringMaxLengthValidator","register","STRING_MIN_LENGTH_VALIDATOR_ID","cellStringMinLengthValidator","value","_row","params","minLength","min","s","registerStringMinLengthValidator","register","STRING_EMAIL_VALIDATOR_ID","EMAIL_REGEX","cellStringEmailValidator","value","_row","_params","s","registerStringEmailValidator","register","STRING_PHONE_VALIDATOR_ID","PHONE_REGEX","cellStringPhoneValidator","value","_row","_params","s","digitsOnly","registerStringPhoneValidator","register","STRING_PHONE_INTERNATIONAL_VALIDATOR_ID","E164_PREFIX","cellStringPhoneInternationalValidator","value","_row","_params","s","digits","withPlus","E164_PREFIX","registerStringPhoneInternationalValidator","register","STRING_PHONE_INTERNATIONAL_VALIDATOR_ID","STRING_PHONE_LOCAL_VALIDATOR_ID","cellStringPhoneLocalValidator","value","_row","params","minDigits","maxDigits","min","max","s","digits","registerStringPhoneLocalValidator","register","STRING_PHONE_LOCAL_VALIDATOR_ID","STRING_ONLY_NUMBERS_VALIDATOR_ID","ONLY_DIGITS","cellStringOnlyNumbersValidator","value","_row","_params","s","registerStringOnlyNumbersValidator","register","STRING_ONLY_LETTERS_VALIDATOR_ID","ONLY_LETTERS","ONLY_LETTERS_AND_SPACES","cellStringOnlyLettersValidator","value","_row","params","allowSpaces","s","registerStringOnlyLettersValidator","register","NUMBER_MIN_VALIDATOR_ID","toNumber","value","n","cellNumberMinValidator","_row","params","min","minVal","registerNumberMinValidator","register","NUMBER_MAX_VALIDATOR_ID","toNumber","value","n","cellNumberMaxValidator","_row","params","max","maxVal","registerNumberMaxValidator","register","NUMBER_FLOAT_VALIDATOR_ID","isFiniteFloat","value","s","n","cellNumberFloatValidator","_row","_params","registerNumberFloatValidator","register","NUMBER_INTEGER_VALIDATOR_ID","toInteger","value","n","cellNumberIntegerValidator","_row","_params","registerNumberIntegerValidator","register","NUMBER_NON_NEGATIVE_VALIDATOR_ID","toNumber","value","n","cellNumberNonNegativeValidator","_row","_params","registerNumberNonNegativeValidator","register","NUMBER_NON_POSITIVE_VALIDATOR_ID","toNumber","value","n","cellNumberNonPositiveValidator","_row","_params","registerNumberNonPositiveValidator","register","NUMBER_NON_ZERO_VALIDATOR_ID","toNumber","value","n","cellNumberNonZeroValidator","_row","_params","registerNumberNonZeroValidator","register","DATE_MIN_VALIDATOR_ID","toTime","value","ms","cellDateMinValidator","_row","params","min","minMs","v","registerDateMinValidator","register","DATE_MAX_VALIDATOR_ID","toTime","value","ms","cellDateMaxValidator","_row","params","max","maxMs","v","registerDateMaxValidator","register","DATE_ONLY_YEAR_VALIDATOR_ID","YEAR_REGEX","cellDateOnlyYearValidator","value","_row","_params","s","n","strMatch","numMatch","registerDateOnlyYearValidator","register","DATE_ONLY_TIME_VALIDATOR_ID","TIME_REGEX","cellDateOnlyTimeValidator","value","_row","_params","s","registerDateOnlyTimeValidator","register","DATE_DATETIME_VALIDATOR_ID","toTime","value","ms","cellDateDatetimeValidator","_row","_params","s","registerDateDatetimeValidator","register","DATE_TIMESTAMP_VALIDATOR_ID","toTimestamp","value","s","ms","cellDateTimestampValidator","_row","_params","registerDateTimestampValidator","register","DATE_TIMESTAMP_VALIDATOR_ID","DATE_UTC_VALIDATOR_ID","toTime","value","ms","cellDateUtcValidator","_row","_params","s","registerDateUtcValidator","register","BOOL_ONLY_TRUE_VALIDATOR_ID","isTrue","value","t","cellBoolOnlyTrueValidator","_row","_params","registerBoolOnlyTrueValidator","register","BOOL_ONLY_FALSE_VALIDATOR_ID","isFalse","value","t","cellBoolOnlyFalseValidator","_row","_params","registerBoolOnlyFalseValidator","register","registry","Registry","registerAll","register","registerRequiredValidator","registerStringByregexValidator","registerStringMaxLengthValidator","registerStringMinLengthValidator","registerStringEmailValidator","registerStringPhoneValidator","registerStringPhoneInternationalValidator","registerStringPhoneLocalValidator","registerStringOnlyNumbersValidator","registerStringOnlyLettersValidator","registerNumberMinValidator","registerNumberMaxValidator","registerNumberFloatValidator","registerNumberIntegerValidator","registerNumberNonNegativeValidator","registerNumberNonPositiveValidator","registerNumberNonZeroValidator","registerDateMinValidator","registerDateMaxValidator","registerDateOnlyYearValidator","registerDateOnlyTimeValidator","registerDateDatetimeValidator","registerDateTimestampValidator","registerDateUtcValidator","registerBoolOnlyTrueValidator","registerBoolOnlyFalseValidator","name","fn","opts","getCellValidator","entry","getRowValidator","_name","getTableValidator","getValidatorGetters","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","s","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","m","g","registerStringExtractByRegexTransform","register","NUMBER_ADD_TRANSFORM_ID","toNumber","v","n","cellNumberAddTransform","value","_cell","_row","params","add","delta","registerNumberAddTransform","register","NUMBER_MULTIPLY_TRANSFORM_ID","toNumber","v","n","cellNumberMultiplyTransform","value","_cell","_row","params","factor","f","registerNumberMultiplyTransform","register","NUMBER_DIVIDE_TRANSFORM_ID","toNumber","v","n","cellNumberDivideTransform","value","_cell","_row","params","divisor","d","registerNumberDivideTransform","register","NUMBER_SUBTRACT_TRANSFORM_ID","toNumber","v","n","cellNumberSubtractTransform","value","_cell","_row","params","sub","delta","registerNumberSubtractTransform","register","NUMBER_ROUND_TRANSFORM_ID","toNumber","v","n","cellNumberRoundTransform","value","_cell","_row","params","mode","registerNumberRoundTransform","register","NUMBER_ABS_TRANSFORM_ID","toNumber","v","n","cellNumberAbsTransform","value","_cell","_row","_params","registerNumberAbsTransform","register","NUMBER_SQRT_TRANSFORM_ID","toNumber","v","n","cellNumberSqrtTransform","value","_cell","_row","_params","registerNumberSqrtTransform","register","NUMBER_LIMIT_TRANSFORM_ID","toNumber","v","n","cellNumberLimitTransform","value","_cell","_row","params","min","max","out","minVal","maxVal","registerNumberLimitTransform","register","NUMBER_PERCENT_TRANSFORM_ID","toNumber","v","n","cellNumberPercentTransform","value","_cell","_row","params","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","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","rowIndex","cellKey","value","options","validator","getValidatorGetters","transform","getTransformGetters","runEditPipeline","expose"]}