* Here we'll handle all type of accessors: * - 0 argument -> e.g. table.getCanNextPage()) * - 0~1 arguments -> e.g. table.getIsSomeRowsPinned(position?) * - 1 required argument -> e.g. table.getColumn(columnId) * - 1+ argument -> e.g. table.getRow(id, searchAll?) * * Since we are not able to d
(signal: Signal<Table<T>>, fn: Function)
| 69 | * that return it's value based on the given parameters |
| 70 | */ |
| 71 | function toComputed<T>(signal: Signal<Table<T>>, fn: Function) { |
| 72 | const hasArgs = fn.length > 0 |
| 73 | if (!hasArgs) { |
| 74 | return computed(() => { |
| 75 | void signal() |
| 76 | return fn() |
| 77 | }) |
| 78 | } |
| 79 | |
| 80 | const computedCache: Record<string, Signal<unknown>> = {} |
| 81 | |
| 82 | return (...argsArray: any[]) => { |
| 83 | const serializedArgs = serializeArgs(...argsArray) |
| 84 | if (computedCache.hasOwnProperty(serializedArgs)) { |
| 85 | return computedCache[serializedArgs]?.() |
| 86 | } |
| 87 | const computedSignal = computed(() => { |
| 88 | void signal() |
| 89 | return fn(...argsArray) |
| 90 | }) |
| 91 | |
| 92 | computedCache[serializedArgs] = computedSignal |
| 93 | |
| 94 | return computedSignal() |
| 95 | } |
| 96 | } |
| 97 | |
| 98 | function serializeArgs(...args: any[]) { |
| 99 | return JSON.stringify(args) |