tinybase 6.2.0-beta.3 → 6.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/@types/common/index.d.ts +295 -0
- package/@types/common/with-schemas/index.d.ts +375 -0
- package/@types/mergeable-store/index.d.ts +5 -34
- package/@types/mergeable-store/with-schemas/index.d.ts +5 -34
- package/@types/omni/with-schemas/index.d.ts +3 -3
- package/common/index.js +62 -3
- package/common/with-schemas/index.js +62 -3
- package/index.js +133 -86
- package/mergeable-store/index.js +102 -94
- package/mergeable-store/with-schemas/index.js +102 -94
- package/min/common/index.js +1 -1
- package/min/common/index.js.gz +0 -0
- package/min/common/with-schemas/index.js +1 -1
- package/min/common/with-schemas/index.js.gz +0 -0
- package/min/index.js +1 -1
- package/min/index.js.gz +0 -0
- package/min/mergeable-store/index.js +1 -1
- package/min/mergeable-store/index.js.gz +0 -0
- package/min/mergeable-store/with-schemas/index.js +1 -1
- package/min/mergeable-store/with-schemas/index.js.gz +0 -0
- package/min/omni/index.js +1 -1
- package/min/omni/index.js.gz +0 -0
- package/min/omni/with-schemas/index.js +1 -1
- package/min/omni/with-schemas/index.js.gz +0 -0
- package/min/persisters/index.js +1 -1
- package/min/persisters/index.js.gz +0 -0
- package/min/persisters/persister-pglite/index.js +1 -1
- package/min/persisters/persister-pglite/index.js.gz +0 -0
- package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-postgres/index.js +1 -1
- package/min/persisters/persister-postgres/index.js.gz +0 -0
- package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
- package/min/persisters/with-schemas/index.js +1 -1
- package/min/persisters/with-schemas/index.js.gz +0 -0
- package/min/store/index.js +1 -1
- package/min/store/index.js.gz +0 -0
- package/min/store/with-schemas/index.js +1 -1
- package/min/store/with-schemas/index.js.gz +0 -0
- package/min/ui-react-inspector/index.js +1 -1
- package/min/ui-react-inspector/index.js.gz +0 -0
- package/min/ui-react-inspector/with-schemas/index.js +1 -1
- package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
- package/min/with-schemas/index.js +1 -1
- package/min/with-schemas/index.js.gz +0 -0
- package/omni/index.js +148 -101
- package/omni/with-schemas/index.js +148 -101
- package/package.json +3 -3
- package/persisters/index.js +9 -9
- package/persisters/persister-durable-object-storage/index.js +12 -12
- package/persisters/persister-durable-object-storage/with-schemas/index.js +12 -12
- package/persisters/persister-pglite/index.js +11 -11
- package/persisters/persister-pglite/with-schemas/index.js +11 -11
- package/persisters/persister-postgres/index.js +11 -11
- package/persisters/persister-postgres/with-schemas/index.js +11 -11
- package/persisters/with-schemas/index.js +9 -9
- package/readme.md +2 -2
- package/releases.md +9 -10
- package/store/index.js +4 -4
- package/store/with-schemas/index.js +4 -4
- package/synchronizers/index.js +7 -7
- package/synchronizers/synchronizer-broadcast-channel/index.js +7 -7
- package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +7 -7
- package/synchronizers/synchronizer-local/index.js +7 -7
- package/synchronizers/synchronizer-local/with-schemas/index.js +7 -7
- package/synchronizers/synchronizer-ws-client/index.js +7 -7
- package/synchronizers/synchronizer-ws-client/with-schemas/index.js +7 -7
- package/synchronizers/synchronizer-ws-server/index.js +7 -7
- package/synchronizers/synchronizer-ws-server/with-schemas/index.js +7 -7
- package/synchronizers/synchronizer-ws-server-durable-object/index.js +7 -7
- package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +7 -7
- package/synchronizers/with-schemas/index.js +7 -7
- package/ui-react-inspector/index.js +1 -1
- package/ui-react-inspector/with-schemas/index.js +1 -1
- package/with-schemas/index.js +133 -86
|
@@ -97,21 +97,10 @@ const collClear = (coll) => coll.clear();
|
|
|
97
97
|
const collForEach = (coll, cb) => coll?.forEach(cb);
|
|
98
98
|
const collDel = (coll, keyOrValue) => coll?.delete(keyOrValue);
|
|
99
99
|
|
|
100
|
-
const textEncoder = /* @__PURE__ */ new GLOBAL.TextEncoder();
|
|
101
|
-
const getHash = (value) => {
|
|
102
|
-
let hash = 2166136261;
|
|
103
|
-
arrayForEach(textEncoder.encode(value), (char) => {
|
|
104
|
-
hash ^= char;
|
|
105
|
-
hash +=
|
|
106
|
-
(hash << 1) + (hash << 4) + (hash << 7) + (hash << 8) + (hash << 24);
|
|
107
|
-
});
|
|
108
|
-
return hash >>> 0;
|
|
109
|
-
};
|
|
110
|
-
|
|
111
100
|
const object = Object;
|
|
112
101
|
const getPrototypeOf = (obj) => object.getPrototypeOf(obj);
|
|
113
|
-
const objEntries = object.entries;
|
|
114
102
|
const objFrozen = object.isFrozen;
|
|
103
|
+
const objEntries = object.entries;
|
|
115
104
|
const isObject = (obj) =>
|
|
116
105
|
!isUndefined(obj) &&
|
|
117
106
|
ifNotUndefined(
|
|
@@ -163,6 +152,29 @@ const objValidate = (obj, validateChild, onInvalidObj, emptyIsValid = 0) => {
|
|
|
163
152
|
return emptyIsValid ? true : !objIsEmpty(obj);
|
|
164
153
|
};
|
|
165
154
|
|
|
155
|
+
const jsonString = JSON.stringify;
|
|
156
|
+
const jsonParse = JSON.parse;
|
|
157
|
+
const jsonStringWithMap = (obj) =>
|
|
158
|
+
jsonString(obj, (_key, value) =>
|
|
159
|
+
isInstanceOf(value, Map) ? object.fromEntries([...value]) : value,
|
|
160
|
+
);
|
|
161
|
+
|
|
162
|
+
const textEncoder = /* @__PURE__ */ new GLOBAL.TextEncoder();
|
|
163
|
+
const getHash = (string) => {
|
|
164
|
+
let hash = 2166136261;
|
|
165
|
+
arrayForEach(textEncoder.encode(string), (char) => {
|
|
166
|
+
hash ^= char;
|
|
167
|
+
hash +=
|
|
168
|
+
(hash << 1) + (hash << 4) + (hash << 7) + (hash << 8) + (hash << 24);
|
|
169
|
+
});
|
|
170
|
+
return hash >>> 0;
|
|
171
|
+
};
|
|
172
|
+
const addOrRemoveHash = (hash1, hash2) => (hash1 ^ hash2) >>> 0;
|
|
173
|
+
const getValueInValuesHash = (valueId, valueHash) =>
|
|
174
|
+
getHash(valueId + ':' + valueHash);
|
|
175
|
+
const getValueHash = (value, valueHlc) =>
|
|
176
|
+
getHash(jsonStringWithMap(value ?? null) + ':' + valueHlc);
|
|
177
|
+
|
|
166
178
|
const mapNew = (entries) => new Map(entries);
|
|
167
179
|
const mapKeys = (map) => [...(map?.keys() ?? [])];
|
|
168
180
|
const mapGet = (map, key) => map?.get(key);
|
|
@@ -341,13 +353,6 @@ const getHlcFunctions = (uniqueId, getNow = Date.now) => {
|
|
|
341
353
|
];
|
|
342
354
|
};
|
|
343
355
|
|
|
344
|
-
const jsonString = JSON.stringify;
|
|
345
|
-
const jsonParse = JSON.parse;
|
|
346
|
-
const jsonStringWithMap = (obj) =>
|
|
347
|
-
jsonString(obj, (_key, value) =>
|
|
348
|
-
isInstanceOf(value, Map) ? object.fromEntries([...value]) : value,
|
|
349
|
-
);
|
|
350
|
-
|
|
351
356
|
const setNew = (entryOrEntries) =>
|
|
352
357
|
new Set(
|
|
353
358
|
isArray(entryOrEntries) || isUndefined(entryOrEntries)
|
|
@@ -356,31 +361,30 @@ const setNew = (entryOrEntries) =>
|
|
|
356
361
|
);
|
|
357
362
|
const setAdd = (set, value) => set?.add(value);
|
|
358
363
|
|
|
359
|
-
const stampClone = ([value,
|
|
360
|
-
const stampCloneWithHash = ([value,
|
|
361
|
-
const stampNew = (value,
|
|
362
|
-
const stampNewWithHash = (value,
|
|
364
|
+
const stampClone = ([value, hlc]) => stampNew(value, hlc);
|
|
365
|
+
const stampCloneWithHash = ([value, hlc, hash]) => [value, hlc, hash];
|
|
366
|
+
const stampNew = (value, hlc) => (hlc ? [value, hlc] : [value]);
|
|
367
|
+
const stampNewWithHash = (value, hlc, hash) => [value, hlc, hash];
|
|
363
368
|
const getStampHash = (stamp) => stamp[2];
|
|
364
|
-
const
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
const getLatestTime = (time1, time2) =>
|
|
369
|
+
const replaceHlcHash = (oldHlc, newHlc) =>
|
|
370
|
+
newHlc > oldHlc ? (oldHlc ? getHash(oldHlc) : 0) ^ getHash(newHlc) : 0;
|
|
371
|
+
const getLatestHlc = (hlc1, hlc2) =>
|
|
368
372
|
/* istanbul ignore next */
|
|
369
|
-
((
|
|
370
|
-
const stampUpdate = (stamp,
|
|
371
|
-
if (
|
|
372
|
-
stamp[1] =
|
|
373
|
+
((hlc1 ?? '') > (hlc2 ?? '') ? hlc1 : hlc2) ?? '';
|
|
374
|
+
const stampUpdate = (stamp, hlc, hash) => {
|
|
375
|
+
if (hlc > stamp[1]) {
|
|
376
|
+
stamp[1] = hlc;
|
|
373
377
|
}
|
|
374
378
|
stamp[2] = hash >>> 0;
|
|
375
379
|
};
|
|
376
|
-
const stampNewObj = (
|
|
377
|
-
const stampNewMap = (
|
|
380
|
+
const stampNewObj = (hlc = EMPTY_STRING) => stampNew(objNew(), hlc);
|
|
381
|
+
const stampNewMap = (hlc = EMPTY_STRING) => [mapNew(), hlc, 0];
|
|
378
382
|
const stampMapToObjWithHash = (
|
|
379
|
-
[map,
|
|
383
|
+
[map, hlc, hash],
|
|
380
384
|
mapper = stampCloneWithHash,
|
|
381
|
-
) => [mapToObj(map, mapper),
|
|
382
|
-
const stampMapToObjWithoutHash = ([map,
|
|
383
|
-
stampNew(mapToObj(map, mapper),
|
|
385
|
+
) => [mapToObj(map, mapper), hlc, hash];
|
|
386
|
+
const stampMapToObjWithoutHash = ([map, hlc], mapper = stampClone) =>
|
|
387
|
+
stampNew(mapToObj(map, mapper), hlc);
|
|
384
388
|
const stampValidate = (stamp, validateThing) =>
|
|
385
389
|
isArray(stamp) &&
|
|
386
390
|
size(stamp) == 3 &&
|
|
@@ -1914,25 +1918,25 @@ const createMergeableStore = (uniqueId, getNow) => {
|
|
|
1914
1918
|
const tablesChanges = {};
|
|
1915
1919
|
const valuesChanges = {};
|
|
1916
1920
|
const [
|
|
1917
|
-
[tablesObj,
|
|
1921
|
+
[tablesObj, incomingTablesHlc = EMPTY_STRING, incomingTablesHash = 0],
|
|
1918
1922
|
values,
|
|
1919
1923
|
] = contentOrChanges;
|
|
1920
1924
|
const [tablesStampMap, valuesStampMap] = contentStampMap;
|
|
1921
|
-
const [tableStampMaps,
|
|
1925
|
+
const [tableStampMaps, oldTablesHlc, oldTablesHash] = tablesStampMap;
|
|
1922
1926
|
let tablesHash = isContent ? incomingTablesHash : oldTablesHash;
|
|
1923
|
-
let
|
|
1927
|
+
let tablesHlc = incomingTablesHlc;
|
|
1924
1928
|
objForEach(
|
|
1925
1929
|
tablesObj,
|
|
1926
1930
|
(
|
|
1927
|
-
[rowsObj,
|
|
1931
|
+
[rowsObj, incomingTableHlc = EMPTY_STRING, incomingTableHash = 0],
|
|
1928
1932
|
tableId,
|
|
1929
1933
|
) => {
|
|
1930
1934
|
const tableStampMap = mapEnsure(tableStampMaps, tableId, stampNewMap);
|
|
1931
|
-
const [rowStampMaps,
|
|
1935
|
+
const [rowStampMaps, oldTableHlc, oldTableHash] = tableStampMap;
|
|
1932
1936
|
let tableHash = isContent ? incomingTableHash : oldTableHash;
|
|
1933
|
-
let
|
|
1937
|
+
let tableHlc = incomingTableHlc;
|
|
1934
1938
|
objForEach(rowsObj, (row, rowId) => {
|
|
1935
|
-
const [
|
|
1939
|
+
const [rowHlc, oldRowHash, rowHash] = mergeCellsOrValues(
|
|
1936
1940
|
row,
|
|
1937
1941
|
mapEnsure(rowStampMaps, rowId, stampNewMap),
|
|
1938
1942
|
objEnsure(objEnsure(tablesChanges, tableId, objNew), rowId, objNew),
|
|
@@ -1940,32 +1944,36 @@ const createMergeableStore = (uniqueId, getNow) => {
|
|
|
1940
1944
|
);
|
|
1941
1945
|
tableHash ^= isContent
|
|
1942
1946
|
? 0
|
|
1943
|
-
: (
|
|
1944
|
-
|
|
1945
|
-
|
|
1947
|
+
: addOrRemoveHash(
|
|
1948
|
+
oldRowHash ? getValueInValuesHash(rowId, oldRowHash) : 0,
|
|
1949
|
+
getValueInValuesHash(rowId, rowHash),
|
|
1950
|
+
);
|
|
1951
|
+
tableHlc = getLatestHlc(tableHlc, rowHlc);
|
|
1946
1952
|
});
|
|
1947
1953
|
tableHash ^= isContent
|
|
1948
1954
|
? 0
|
|
1949
|
-
:
|
|
1950
|
-
stampUpdate(tableStampMap,
|
|
1955
|
+
: replaceHlcHash(oldTableHlc, incomingTableHlc);
|
|
1956
|
+
stampUpdate(tableStampMap, incomingTableHlc, tableHash);
|
|
1951
1957
|
tablesHash ^= isContent
|
|
1952
1958
|
? 0
|
|
1953
|
-
: (
|
|
1954
|
-
|
|
1955
|
-
|
|
1959
|
+
: addOrRemoveHash(
|
|
1960
|
+
oldTableHash ? getValueInValuesHash(tableId, oldTableHash) : 0,
|
|
1961
|
+
getValueInValuesHash(tableId, tableStampMap[2]),
|
|
1962
|
+
);
|
|
1963
|
+
tablesHlc = getLatestHlc(tablesHlc, tableHlc);
|
|
1956
1964
|
},
|
|
1957
1965
|
);
|
|
1958
1966
|
tablesHash ^= isContent
|
|
1959
1967
|
? 0
|
|
1960
|
-
:
|
|
1961
|
-
stampUpdate(tablesStampMap,
|
|
1962
|
-
const [
|
|
1968
|
+
: replaceHlcHash(oldTablesHlc, incomingTablesHlc);
|
|
1969
|
+
stampUpdate(tablesStampMap, incomingTablesHlc, tablesHash);
|
|
1970
|
+
const [valuesHlc] = mergeCellsOrValues(
|
|
1963
1971
|
values,
|
|
1964
1972
|
valuesStampMap,
|
|
1965
1973
|
valuesChanges,
|
|
1966
1974
|
isContent,
|
|
1967
1975
|
);
|
|
1968
|
-
seenHlc(
|
|
1976
|
+
seenHlc(getLatestHlc(tablesHlc, valuesHlc));
|
|
1969
1977
|
return [tablesChanges, valuesChanges, 1];
|
|
1970
1978
|
};
|
|
1971
1979
|
const mergeCellsOrValues = (
|
|
@@ -1976,44 +1984,44 @@ const createMergeableStore = (uniqueId, getNow) => {
|
|
|
1976
1984
|
) => {
|
|
1977
1985
|
const [
|
|
1978
1986
|
thingsObj,
|
|
1979
|
-
|
|
1987
|
+
incomingThingsHlc = EMPTY_STRING,
|
|
1980
1988
|
incomingThingsHash = 0,
|
|
1981
1989
|
] = things;
|
|
1982
|
-
const [thingStampMaps,
|
|
1983
|
-
let
|
|
1990
|
+
const [thingStampMaps, oldThingsHlc, oldThingsHash] = thingsStampMap;
|
|
1991
|
+
let thingsHlc = incomingThingsHlc;
|
|
1984
1992
|
let thingsHash = isContent ? incomingThingsHash : oldThingsHash;
|
|
1985
1993
|
objForEach(
|
|
1986
1994
|
thingsObj,
|
|
1987
|
-
([thing,
|
|
1995
|
+
([thing, thingHlc = EMPTY_STRING, incomingThingHash = 0], thingId) => {
|
|
1988
1996
|
const thingStampMap = mapEnsure(thingStampMaps, thingId, () => [
|
|
1989
1997
|
void 0,
|
|
1990
1998
|
EMPTY_STRING,
|
|
1991
1999
|
0,
|
|
1992
2000
|
]);
|
|
1993
|
-
const [,
|
|
1994
|
-
if (!
|
|
2001
|
+
const [, oldThingHlc, oldThingHash] = thingStampMap;
|
|
2002
|
+
if (!oldThingHlc || thingHlc > oldThingHlc) {
|
|
1995
2003
|
stampUpdate(
|
|
1996
2004
|
thingStampMap,
|
|
1997
|
-
|
|
1998
|
-
isContent
|
|
1999
|
-
? incomingThingHash
|
|
2000
|
-
: getHash(jsonStringWithMap(thing ?? null) + ':' + thingTime),
|
|
2005
|
+
thingHlc,
|
|
2006
|
+
isContent ? incomingThingHash : getValueHash(thing, thingHlc),
|
|
2001
2007
|
);
|
|
2002
2008
|
thingStampMap[0] = thing;
|
|
2003
2009
|
thingsChanges[thingId] = thing;
|
|
2004
2010
|
thingsHash ^= isContent
|
|
2005
2011
|
? 0
|
|
2006
|
-
:
|
|
2007
|
-
|
|
2008
|
-
|
|
2012
|
+
: addOrRemoveHash(
|
|
2013
|
+
getValueInValuesHash(thingId, oldThingHash),
|
|
2014
|
+
getValueInValuesHash(thingId, thingStampMap[2]),
|
|
2015
|
+
);
|
|
2016
|
+
thingsHlc = getLatestHlc(thingsHlc, thingHlc);
|
|
2009
2017
|
}
|
|
2010
2018
|
},
|
|
2011
2019
|
);
|
|
2012
2020
|
thingsHash ^= isContent
|
|
2013
2021
|
? 0
|
|
2014
|
-
:
|
|
2015
|
-
stampUpdate(thingsStampMap,
|
|
2016
|
-
return [
|
|
2022
|
+
: replaceHlcHash(oldThingsHlc, incomingThingsHlc);
|
|
2023
|
+
stampUpdate(thingsStampMap, incomingThingsHlc, thingsHash);
|
|
2024
|
+
return [thingsHlc, oldThingsHash, thingsStampMap[2]];
|
|
2017
2025
|
};
|
|
2018
2026
|
const preStartTransaction = noop;
|
|
2019
2027
|
const preFinishTransaction = noop;
|
|
@@ -2085,13 +2093,13 @@ const createMergeableStore = (uniqueId, getNow) => {
|
|
|
2085
2093
|
const differingTableHashes = {};
|
|
2086
2094
|
mapForEach(
|
|
2087
2095
|
contentStampMap[0][0],
|
|
2088
|
-
(tableId, [tableStampMap,
|
|
2096
|
+
(tableId, [tableStampMap, tableHlc, hash]) =>
|
|
2089
2097
|
objHas(otherTableHashes, tableId)
|
|
2090
2098
|
? hash != otherTableHashes[tableId]
|
|
2091
2099
|
? (differingTableHashes[tableId] = hash)
|
|
2092
2100
|
: 0
|
|
2093
2101
|
: (newTables[0][tableId] = stampMapToObjWithoutHash(
|
|
2094
|
-
[tableStampMap,
|
|
2102
|
+
[tableStampMap, tableHlc],
|
|
2095
2103
|
(rowStampMap) => stampMapToObjWithoutHash(rowStampMap),
|
|
2096
2104
|
)),
|
|
2097
2105
|
);
|
|
@@ -2120,13 +2128,13 @@ const createMergeableStore = (uniqueId, getNow) => {
|
|
|
2120
2128
|
objForEach(otherTableRowHashes, (otherRowHashes, tableId) =>
|
|
2121
2129
|
mapForEach(
|
|
2122
2130
|
mapGet(contentStampMap[0][0], tableId)?.[0],
|
|
2123
|
-
(rowId, [rowStampMap,
|
|
2131
|
+
(rowId, [rowStampMap, rowHlc, hash]) =>
|
|
2124
2132
|
objHas(otherRowHashes, rowId)
|
|
2125
2133
|
? hash !== otherRowHashes[rowId]
|
|
2126
2134
|
? (objEnsure(differingRowHashes, tableId, objNew)[rowId] = hash)
|
|
2127
2135
|
: 0
|
|
2128
2136
|
: (objEnsure(newRows[0], tableId, stampNewObj)[0][rowId] =
|
|
2129
|
-
stampMapToObjWithoutHash([rowStampMap,
|
|
2137
|
+
stampMapToObjWithoutHash([rowStampMap, rowHlc])),
|
|
2130
2138
|
),
|
|
2131
2139
|
);
|
|
2132
2140
|
return [newRows, differingRowHashes];
|
|
@@ -2157,43 +2165,43 @@ const createMergeableStore = (uniqueId, getNow) => {
|
|
|
2157
2165
|
return cellHashes;
|
|
2158
2166
|
};
|
|
2159
2167
|
const getMergeableCellDiff = (otherTableRowCellHashes) => {
|
|
2160
|
-
const [[tableStampMaps,
|
|
2168
|
+
const [[tableStampMaps, tablesHlc]] = contentStampMap;
|
|
2161
2169
|
const tablesObj = {};
|
|
2162
2170
|
objForEach(otherTableRowCellHashes, (otherRowCellHashes, tableId) =>
|
|
2163
2171
|
objForEach(otherRowCellHashes, (otherCellHashes, rowId) =>
|
|
2164
2172
|
ifNotUndefined(
|
|
2165
2173
|
mapGet(tableStampMaps, tableId),
|
|
2166
|
-
([rowStampMaps,
|
|
2174
|
+
([rowStampMaps, tableHlc]) =>
|
|
2167
2175
|
ifNotUndefined(
|
|
2168
2176
|
mapGet(rowStampMaps, rowId),
|
|
2169
|
-
([cellStampMaps,
|
|
2170
|
-
mapForEach(cellStampMaps, (cellId, [cell,
|
|
2177
|
+
([cellStampMaps, rowHlc]) =>
|
|
2178
|
+
mapForEach(cellStampMaps, (cellId, [cell, cellHlc, hash]) =>
|
|
2171
2179
|
hash !== otherCellHashes[cellId]
|
|
2172
2180
|
? (objEnsure(
|
|
2173
2181
|
objEnsure(tablesObj, tableId, () =>
|
|
2174
|
-
stampNewObj(
|
|
2182
|
+
stampNewObj(tableHlc),
|
|
2175
2183
|
)[0],
|
|
2176
2184
|
rowId,
|
|
2177
|
-
() => stampNewObj(
|
|
2178
|
-
)[0][cellId] = [cell,
|
|
2185
|
+
() => stampNewObj(rowHlc),
|
|
2186
|
+
)[0][cellId] = [cell, cellHlc])
|
|
2179
2187
|
: 0,
|
|
2180
2188
|
),
|
|
2181
2189
|
),
|
|
2182
2190
|
),
|
|
2183
2191
|
),
|
|
2184
2192
|
);
|
|
2185
|
-
return stampNew(tablesObj,
|
|
2193
|
+
return stampNew(tablesObj, tablesHlc);
|
|
2186
2194
|
};
|
|
2187
2195
|
const getMergeableValueHashes = () =>
|
|
2188
2196
|
mapToObj(contentStampMap[1][0], getStampHash);
|
|
2189
2197
|
const getMergeableValueDiff = (otherValueHashes) => {
|
|
2190
|
-
const [, [valueStampMaps,
|
|
2198
|
+
const [, [valueStampMaps, valuesHlc]] = contentStampMap;
|
|
2191
2199
|
const values = mapToObj(
|
|
2192
2200
|
valueStampMaps,
|
|
2193
2201
|
stampClone,
|
|
2194
2202
|
([, , hash], valueId) => hash == otherValueHashes?.[valueId],
|
|
2195
2203
|
);
|
|
2196
|
-
return stampNew(values,
|
|
2204
|
+
return stampNew(values, valuesHlc);
|
|
2197
2205
|
};
|
|
2198
2206
|
const setMergeableContent = (mergeableContent) =>
|
|
2199
2207
|
disableListeningToRawStoreChanges(() =>
|
|
@@ -2215,20 +2223,20 @@ const createMergeableStore = (uniqueId, getNow) => {
|
|
|
2215
2223
|
};
|
|
2216
2224
|
const getTransactionMergeableChanges = (withHashes = false) => {
|
|
2217
2225
|
const [
|
|
2218
|
-
[tableStampMaps,
|
|
2219
|
-
[valueStampMaps,
|
|
2226
|
+
[tableStampMaps, tablesHlc, tablesHash],
|
|
2227
|
+
[valueStampMaps, valuesHlc, valuesHash],
|
|
2220
2228
|
] = contentStampMap;
|
|
2221
2229
|
const newStamp = withHashes ? stampNewWithHash : stampNew;
|
|
2222
2230
|
const tablesObj = {};
|
|
2223
2231
|
collForEach(touchedCells, (touchedTable, tableId) =>
|
|
2224
2232
|
ifNotUndefined(
|
|
2225
2233
|
mapGet(tableStampMaps, tableId),
|
|
2226
|
-
([rowStampMaps,
|
|
2234
|
+
([rowStampMaps, tableHlc, tableHash]) => {
|
|
2227
2235
|
const tableObj = {};
|
|
2228
2236
|
collForEach(touchedTable, (touchedRow, rowId) =>
|
|
2229
2237
|
ifNotUndefined(
|
|
2230
2238
|
mapGet(rowStampMaps, rowId),
|
|
2231
|
-
([cellStampMaps,
|
|
2239
|
+
([cellStampMaps, rowHlc, rowHash]) => {
|
|
2232
2240
|
const rowObj = {};
|
|
2233
2241
|
collForEach(touchedRow, (cellId) => {
|
|
2234
2242
|
ifNotUndefined(
|
|
@@ -2237,11 +2245,11 @@ const createMergeableStore = (uniqueId, getNow) => {
|
|
|
2237
2245
|
(rowObj[cellId] = newStamp(cell, time, hash)),
|
|
2238
2246
|
);
|
|
2239
2247
|
});
|
|
2240
|
-
tableObj[rowId] = newStamp(rowObj,
|
|
2248
|
+
tableObj[rowId] = newStamp(rowObj, rowHlc, rowHash);
|
|
2241
2249
|
},
|
|
2242
2250
|
),
|
|
2243
2251
|
);
|
|
2244
|
-
tablesObj[tableId] = newStamp(tableObj,
|
|
2252
|
+
tablesObj[tableId] = newStamp(tableObj, tableHlc, tableHash);
|
|
2245
2253
|
},
|
|
2246
2254
|
),
|
|
2247
2255
|
);
|
|
@@ -2254,8 +2262,8 @@ const createMergeableStore = (uniqueId, getNow) => {
|
|
|
2254
2262
|
),
|
|
2255
2263
|
);
|
|
2256
2264
|
return [
|
|
2257
|
-
newStamp(tablesObj,
|
|
2258
|
-
newStamp(valuesObj,
|
|
2265
|
+
newStamp(tablesObj, tablesHlc, tablesHash),
|
|
2266
|
+
newStamp(valuesObj, valuesHlc, valuesHash),
|
|
2259
2267
|
1,
|
|
2260
2268
|
];
|
|
2261
2269
|
};
|
package/min/common/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
const
|
|
1
|
+
const e=(e,t="",n)=>e.split(t,n),t=globalThis,n=Math,r=n.max,o=n.floor,a=e=>null==e,c=(e,t)=>e.map(t),s=(e,t,n)=>e.reduce(t,n),l=Object,i=l.entries,u=e=>new Map(e),p=e("-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz"),d=u(c(p,((e,t)=>[e,t]))),f=e=>p[63&e],m=(e,t)=>{return n=d,r=e[t],n?.get(r)??0;var n,r},g=t.crypto?e=>t.crypto.getRandomValues(e):e=>c(e,(()=>o(256*n.random()))),w=(e=16)=>s(g(new Uint8Array(e)),((e,t)=>e+f(t)),""),y=JSON.stringify,h=new t.TextEncoder,v=e=>{let t=2166136261;var n;return n=e=>{t^=e,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)},h.encode(e).forEach(n),t>>>0},x=(e,t)=>(e^t)>>>0,E=e=>s(i(e),((e,[t,n])=>x(e,M(t,n)^M(t,0))),0),M=(e,t)=>v(e+":"+t),b=(e,t)=>v(y(e??null,((e,t)=>t instanceof Map?l.fromEntries([...t]):t))+":"+t),O=b,T=M,j=E,A=M,D=e=>s(i(e),((e,[t,n])=>x(e,M(t,n))),0),J=M,N=D,R=2**36,S=2**30,U=2**24,V=2**18,k=4096,q=e=>{const t=v(e);return f(t/U)+f(t/V)+f(t/k)+f(t/64)+f(t)},z=(e,t=Date.now)=>{let n=0,o=-1;const c=(l=q,i=()=>w(5),a(s=e)?i?.():l(s));var s,l,i;const u=e=>{const c=n,[s,l]=a(e)||""==e?[0,0]:d(e);n=r(c,s,t()),o=n==c?n==s?r(o,l):o:n==s?l:-1},p=(e,t,n)=>f(e/R)+f(e/S)+f(e/U)+f(e/V)+f(e/k)+f(e/64)+f(e)+f(t/V)+f(t/k)+f(t/64)+f(t)+(a(n)?c:q(n)),d=e=>[m(e,0)*R+m(e,1)*S+m(e,2)*U+m(e,3)*V+m(e,4)*k+64*m(e,5)+m(e,6),m(e,7)*V+m(e,8)*k+64*m(e,9)+m(e,10),e.slice(11)];return[()=>(u(),p(n,++o)),u,p,d,()=>n,()=>o,()=>c]},B=(e,t)=>(e??0)<(t??0)?-1:1;export{x as addOrRemoveHash,B as defaultSorter,O as getCellHash,T as getCellInRowHash,v as getHash,z as getHlcFunctions,j as getRowHash,A as getRowInTableHash,D as getTableHash,J as getTableInTablesHash,N as getTablesHash,w as getUniqueId,b as getValueHash,M as getValueInValuesHash,E as getValuesHash};
|
package/min/common/index.js.gz
CHANGED
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const
|
|
1
|
+
const e=(e,t="",n)=>e.split(t,n),t=globalThis,n=Math,r=n.max,o=n.floor,a=e=>null==e,c=(e,t)=>e.map(t),s=(e,t,n)=>e.reduce(t,n),l=Object,i=l.entries,u=e=>new Map(e),p=e("-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz"),d=u(c(p,((e,t)=>[e,t]))),f=e=>p[63&e],m=(e,t)=>{return n=d,r=e[t],n?.get(r)??0;var n,r},g=t.crypto?e=>t.crypto.getRandomValues(e):e=>c(e,(()=>o(256*n.random()))),w=(e=16)=>s(g(new Uint8Array(e)),((e,t)=>e+f(t)),""),y=JSON.stringify,h=new t.TextEncoder,v=e=>{let t=2166136261;var n;return n=e=>{t^=e,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)},h.encode(e).forEach(n),t>>>0},x=(e,t)=>(e^t)>>>0,E=e=>s(i(e),((e,[t,n])=>x(e,M(t,n)^M(t,0))),0),M=(e,t)=>v(e+":"+t),b=(e,t)=>v(y(e??null,((e,t)=>t instanceof Map?l.fromEntries([...t]):t))+":"+t),O=b,T=M,j=E,A=M,D=e=>s(i(e),((e,[t,n])=>x(e,M(t,n))),0),J=M,N=D,R=2**36,S=2**30,U=2**24,V=2**18,k=4096,q=e=>{const t=v(e);return f(t/U)+f(t/V)+f(t/k)+f(t/64)+f(t)},z=(e,t=Date.now)=>{let n=0,o=-1;const c=(l=q,i=()=>w(5),a(s=e)?i?.():l(s));var s,l,i;const u=e=>{const c=n,[s,l]=a(e)||""==e?[0,0]:d(e);n=r(c,s,t()),o=n==c?n==s?r(o,l):o:n==s?l:-1},p=(e,t,n)=>f(e/R)+f(e/S)+f(e/U)+f(e/V)+f(e/k)+f(e/64)+f(e)+f(t/V)+f(t/k)+f(t/64)+f(t)+(a(n)?c:q(n)),d=e=>[m(e,0)*R+m(e,1)*S+m(e,2)*U+m(e,3)*V+m(e,4)*k+64*m(e,5)+m(e,6),m(e,7)*V+m(e,8)*k+64*m(e,9)+m(e,10),e.slice(11)];return[()=>(u(),p(n,++o)),u,p,d,()=>n,()=>o,()=>c]},B=(e,t)=>(e??0)<(t??0)?-1:1;export{x as addOrRemoveHash,B as defaultSorter,O as getCellHash,T as getCellInRowHash,v as getHash,z as getHlcFunctions,j as getRowHash,A as getRowInTableHash,D as getTableHash,J as getTableInTablesHash,N as getTablesHash,w as getUniqueId,b as getValueHash,M as getValueInValuesHash,E as getValuesHash};
|
|
Binary file
|
package/min/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
const e=e=>typeof e,t="",s=e(t),n=e(!0),l=e(0),o=e(e),a="type",r="default",i="Listener",d="Result",c="add",u="Has",g="Ids",h="Table",f=h+"s",I=h+g,b="Row",w=b+"Count",L=b+g,C="Sorted"+b+g,R="Cell",T=R+g,v="Value",p=v+"s",S=v+g,y=e=>t+e,V=(e,t)=>e.startsWith(t),m=(e,t)=>e.endsWith(t),M=(e,s=t,n)=>e.split(s,n),E=globalThis,k=Math,D=k.max,H=k.min,J=k.floor,x=isFinite,F=e=>null==e,Q=(e,t,s)=>F(e)?s?.():t(e),z=e=>e==s||e==n,N=t=>e(t)==s,O=t=>e(t)==o,W=e=>Array.isArray(e),A=(e,t,s)=>e.slice(t,s),P=e=>e.length,j=()=>{},_=()=>{},B=async(e,t,s)=>{try{return await e()}catch(e){t?.(e)}},U=(e,t)=>e.includes(t),q=(e,t)=>e.every(t),G=(e,t)=>P(e)===P(t)&&q(e,((e,s)=>t[s]===e)),K=(e,t)=>q(e,((s,n)=>0==n||t(e[n-1],s)<=0)),X=(e,t)=>e.sort(t),Y=(e,t)=>e.forEach(t),Z=(e,t)=>e.map(t),$=e=>te(e,((e,t)=>e+t),0),ee=e=>0==P(e),te=(e,t,s)=>e.reduce(t,s),se=(e,...t)=>e.push(...t),ne=e=>e.pop(),le=e=>e.shift(),oe=t=>{const s=e(t);return z(s)||s==l&&x(t)?s:void 0},ae=e=>F(e)||!F(oe(e)),re=(e,t,s,n,l)=>F(l)?e.delCell(t,s,n,!0):e.setCell(t,s,n,l),ie=(e,t,s)=>F(s)?e.delValue(t):e.setValue(t,s),de=e=>t=>te(be(t),((t,s)=>t+e(s)),0),ce=e=>e?.size??0,ue=de(ce),ge=de(ue),he=de(ge),fe=(e,t)=>e?.has(t)??!1,Ie=e=>F(e)||0==ce(e),be=e=>[...e?.values()??[]],we=e=>e.clear(),Le=(e,t)=>e?.forEach(t),Ce=(e,t)=>e?.delete(t),Re=Object,Te=e=>Re.getPrototypeOf(e),ve=Re.entries,pe=Re.isFrozen,Se=e=>!F(e)&&Q(Te(e),(e=>e==Re.prototype||F(Te(e))),(()=>!0)),ye=Re.keys,Ve=Re.freeze,me=(e=[])=>Re.fromEntries(e),Me=(e,t)=>t in e,Ee=(e,t)=>(delete e[t],e),ke=(e,t)=>Y(ve(e),(([e,s])=>t(s,e))),De=(e,t)=>me(((e,t)=>Z(ve(e),(([e,s])=>t(s,e))))(e,((e,s)=>[s,t(e,s)]))),He=e=>Se(e)&&0==(e=>P(ye(e)))(e),Je=(e,t,s)=>(Me(e,t)||(e[t]=s()),e[t]),xe=(e,t,s,n=0)=>F(e)||!Se(e)||!n&&He(e)||pe(e)?(s?.(),!1):(ke(e,((s,n)=>{t(s,n)||Ee(e,n)})),!!n||!He(e)),Fe=e=>new Map(e),Qe=e=>[...e?.keys()??[]],ze=(e,t)=>e?.get(t),Ne=(e,t)=>Le(e,((e,s)=>t(s,e))),Oe=(e,t,s)=>F(s)?(Ce(e,t),e):e?.set(t,s),We=(e,t,s,n)=>(fe(e,t)?n?.(ze(e,t)):Oe(e,t,s()),ze(e,t)),Ae=(e,t,s,n=Oe)=>(De(t,((t,n)=>s(e,n,t))),Ne(e,(s=>Me(t,s)?0:n(e,s))),e),Pe=(e,t,s,n)=>{const l={};return Le(e,((e,o)=>{if(!s?.(e,o)){const s=t?t(e,o):e;n?.(s)||(l[o]=s)}})),l},je=(e,t,s)=>Pe(e,(e=>Pe(e,t,s)),Ie,He),_e=(e,t,s)=>Pe(e,(e=>je(e,t,s)),Ie,He),Be=(e,t)=>{const s=Fe();return Le(e,((e,n)=>s.set(n,t?.(e)??e))),s},Ue=e=>Be(e,Be),qe=e=>Be(e,Ue),Ge=(e,t,s,n,l=0)=>Q((s?We:ze)(e,t[l],l>P(t)-2?s:Fe),(o=>{if(l>P(t)-2)return n?.(o)&&Oe(e,t[l]),o;const a=Ge(o,t,s,n,l+1);return Ie(o)&&Oe(e,t[l]),a})),Ke=e=>new Set(W(e)||F(e)?e:[e]),Xe=(e,t)=>e?.add(t),Ye=(e,t,s,n,l)=>{const o=e.hasRow,a=Fe(),r=Fe(),i=Fe(),d=Fe(),c=Fe(),u=Fe(),g=(t,s,...n)=>{const l=We(u,t,Ke);return Y(n,(t=>Xe(l,t)&&s&&e.callListener(t))),n},h=(t,...s)=>Q(ze(u,t),(n=>{Y(ee(s)?be(n):s,(t=>{e.delListener(t),Ce(n,t)})),Ie(n)&&Oe(u,t)})),f=(e,s)=>{Oe(a,e,s),fe(r,e)||(Oe(r,e,t()),Oe(d,e,Fe()),Oe(c,e,Fe()),l(i))},I=e=>{Oe(a,e),Oe(r,e),Oe(d,e),Oe(c,e),h(e),l(i)};return[()=>e,()=>Qe(a),e=>Ne(r,e),e=>fe(r,e),e=>ze(a,e),e=>ze(r,e),(e,t)=>Oe(r,e,t),f,(t,n,l,a,r)=>{f(t,n);const i=Fe(),u=Fe(),I=ze(d,t),b=ze(c,t),w=t=>{const l=s=>e.getCell(n,t,s),d=ze(I,t),c=o(n,t)?s(a(l,t)):void 0;if(d===c||W(d)&&W(c)&&G(d,c)||Oe(i,t,[d,c]),!F(r)){const e=ze(b,t),s=o(n,t)?r(l,t):void 0;e!=s&&Oe(u,t,s)}},L=e=>{l((()=>{Le(i,(([,e],t)=>Oe(I,t,e))),Le(u,((e,t)=>Oe(b,t,e)))}),i,u,I,b,e),we(i),we(u)};Ne(I,w),e.hasTable(n)&&Y(e.getRowIds(n),(e=>{fe(I,e)||w(e)})),L(!0),h(t),g(t,0,e.addRowListener(n,null,((e,t,s)=>w(s))),e.addTableListener(n,(()=>L())))},I,e=>n(e,i),()=>Ne(u,I),g,h]},Ze=(e,s)=>N(e)?t=>t(e):e??(()=>s??t),$e=(e,t)=>{const s=new WeakMap;return n=>{s.has(n)||s.set(n,e(n));const l=s.get(n);return t?.(l),l}},et=/^\d+$/,tt=()=>{const e=[];let s=0;return[n=>(n?le(e):null)??t+s++,t=>{et.test(t)&&P(e)<1e3&&se(e,t)}]},st=e=>{let s;const[n,l]=tt(),o=Fe();return[(l,a,r,i=[],d=()=>[])=>{s??=e();const c=n(1);return Oe(o,c,[l,a,r,i,d]),Xe(Ge(a,r??[t],Ke),c),c},(e,n,...l)=>Y(((e,s=[t])=>{const n=[],l=(e,t)=>t==P(s)?se(n,e):null===s[t]?Le(e,(e=>l(e,t+1))):Y([s[t],null],(s=>l(ze(e,s),t+1)));return l(e,0),n})(e,n),(e=>Le(e,(e=>ze(o,e)[0](s,...n??[],...l))))),e=>Q(ze(o,e),(([,s,n])=>(Ge(s,n??[t],void 0,(t=>(Ce(t,e),Ie(t)?1:0))),Oe(o,e),l(e),n))),e=>Q(ze(o,e),(([e,,t=[],n,l])=>{const o=(...a)=>{const r=P(a);r==P(t)?e(s,...a,...l(a)):F(t[r])?Y(n[r]?.(...a)??[],(e=>o(...a,e))):o(...a,t[r])};o()}))]},nt=$e((e=>{let s,n,l,o=100,a=Fe(),r=Fe(),i=1;const d=Fe(),c=Fe(),[u,g,h]=st((()=>J)),f=Fe(),I=Fe(),b=[],w=[],L=(t,s)=>{i=0,e.transaction((()=>{const[n,l]=ze(f,s);Le(n,((s,n)=>Le(s,((s,l)=>Le(s,((s,o)=>re(e,n,l,o,s[t]))))))),Le(l,((s,n)=>ie(e,n,s[t])))})),i=1},C=e=>{Oe(f,e),Oe(I,e),g(c,[e])},R=(e,t)=>Y(((e,t)=>e.splice(0,t))(e,t??P(e)),C),T=()=>R(b,P(b)-o),v=()=>Q(s,(()=>{se(b,s),T(),R(w),s=void 0,l=1})),p=()=>{s=ne(b),l=1};let S,y;const V=(e=t)=>(F(s)&&(s=t+n++,Oe(f,s,[a,r]),D(s,e),a=Fe(),r=Fe(),l=1),s),m=()=>{ee(b)||(((e,...t)=>{e.unshift(...t)})(w,V()),L(0,s),s=ne(b),l=1)},M=()=>{ee(w)||(se(b,s),s=le(w),L(1,s),l=1)},E=()=>{l&&(g(d),l=0)},k=e=>{const t=V(e);return E(),t},D=(e,t)=>(H(e)&&ze(I,e)!==t&&(Oe(I,e,t),g(c,[e])),J),H=e=>fe(f,e),J={setSize:e=>(o=e,T(),J),addCheckpoint:k,setCheckpoint:D,getStore:()=>e,getCheckpointIds:()=>[[...b],s,[...w]],forEachCheckpoint:e=>Ne(I,e),hasCheckpoint:H,getCheckpoint:e=>ze(I,e),goBackward:()=>(m(),E(),J),goForward:()=>(M(),E(),J),goTo:e=>{const t=U(b,e)?m:U(w,e)?M:null;for(;!F(t)&&e!=s;)t();return E(),J},addCheckpointIdsListener:e=>u(e,d),addCheckpointListener:(e,t)=>u(t,c,[e]),delListener:e=>(h(e),J),clear:()=>(R(b),R(w),F(s)||C(s),s=void 0,n=0,k(),J),clearForward:()=>(ee(w)||(R(w),g(d)),J),destroy:()=>{e.delListener(S),e.delListener(y)},getListenerStats:()=>({checkpointIds:ue(d),checkpoint:ue(c)}),_registerListeners:()=>{S=e.addCellListener(null,null,null,((e,t,s,n,l,o)=>{if(i){v();const e=We(a,t,Fe),r=We(e,s,Fe),i=We(r,n,(()=>[o,void 0]));i[1]=l,i[0]===l&&Ie(Oe(r,n))&&Ie(Oe(e,s))&&Ie(Oe(a,t))&&p(),E()}})),y=e.addValueListener(null,((e,t,s,n)=>{if(i){v();const e=We(r,t,(()=>[n,void 0]));e[1]=s,e[0]===s&&Ie(Oe(r,t))&&p(),E()}}))}};return Ve(J.clear())}),(e=>e._registerListeners())),lt=M("-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz"),ot=Fe(Z(lt,((e,t)=>[e,t]))),at=e=>lt[63&e],rt=(e,t)=>ze(ot,e[t])??0,it=E.crypto?e=>E.crypto.getRandomValues(e):e=>Z(e,(()=>J(256*k.random()))),dt=(e=16)=>te(it(new Uint8Array(e)),((e,t)=>e+at(t)),""),ct=new E.TextEncoder,ut=e=>{let t=2166136261;return Y(ct.encode(e),(e=>{t^=e,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)})),t>>>0},gt=2**36,ht=2**30,ft=2**24,It=2**18,bt=4096,wt=e=>{const t=ut(e);return at(t/ft)+at(t/It)+at(t/bt)+at(t/64)+at(t)},Lt=(e,t=Date.now)=>{let s=0,n=-1;const l=Q(e,wt,(()=>dt(5))),o=e=>{const l=s,[o,a]=F(e)||""==e?[0,0]:r(e);s=D(l,o,t()),n=s==l?s==o?D(n,a):n:s==o?a:-1},a=(e,t,s)=>at(e/gt)+at(e/ht)+at(e/ft)+at(e/It)+at(e/bt)+at(e/64)+at(e)+at(t/It)+at(t/bt)+at(t/64)+at(t)+(F(s)?l:wt(s)),r=e=>[rt(e,0)*gt+rt(e,1)*ht+rt(e,2)*ft+rt(e,3)*It+rt(e,4)*bt+64*rt(e,5)+rt(e,6),rt(e,7)*It+rt(e,8)*bt+64*rt(e,9)+rt(e,10),e.slice(11)];return[()=>(o(),a(s,++n)),o,a,r,()=>s,()=>n,()=>l]},Ct=(e,t)=>(e??0)<(t??0)?-1:1,Rt=$e((e=>{const s=Fe(),n=Fe(),[l,o,a]=st((()=>C)),[r,i,d,c,u,g,h,,f,I,b,w]=Ye(e,Fe,(e=>F(e)?t:W(e)?Z(e,y):y(e)),l,o),L=(t,s,n)=>{const l=u(t);Le(n,((t,n)=>s(n,(s=>Le(t,(t=>s(t,(s=>e.forEachCell(l,t,s)))))))))},C={setIndexDefinition:(e,t,l,a,r,i=Ct)=>{const d=F(r)?void 0:([e],[t])=>r(e,t);return f(e,t,((t,l,r,c,u,f)=>{let I=0;const b=Ke(),w=Ke(),L=g(e);if(Le(l,(([e,t],s)=>{const n=Ke(e),l=Ke(t);Le(n,(e=>Ce(l,e)?Ce(n,e):0)),Le(n,(e=>{Xe(b,e),Q(ze(L,e),(t=>{Ce(t,s),Ie(t)&&(Oe(L,e),I=1)}))})),Le(l,(e=>{Xe(b,e),fe(L,e)||(Oe(L,e,Ke()),I=1),Xe(ze(L,e),s),F(a)||Xe(w,e)}))})),t(),Ie(u)||(f?Ne(L,(e=>Xe(w,e))):Ne(r,(e=>Q(ze(c,e),(e=>Y(W(e)?e:[e],(e=>Xe(w,e))))))),Le(w,(e=>{const t=(t,s)=>i(ze(u,t),ze(u,s),e),s=[...ze(L,e)];K(s,t)||(Oe(L,e,Ke(X(s,t))),Xe(b,e))}))),(I||f)&&!F(d)){const t=[...L];K(t,d)||(h(e,Fe(X(t,d))),I=1)}I&&o(s,[e]),Le(b,(t=>o(n,[e,t])))}),Ze(l),Q(a,Ze)),C},delIndexDefinition:e=>(I(e),C),getStore:r,getIndexIds:i,forEachIndex:e=>d(((t,s)=>e(t,(e=>L(t,e,s))))),forEachSlice:(e,t)=>L(e,t,g(e)),hasIndex:c,hasSlice:(e,t)=>fe(g(e),t),getTableId:u,getSliceIds:e=>Qe(g(e)),getSliceRowIds:(e,t)=>be(ze(g(e),t)),addIndexIdsListener:b,addSliceIdsListener:(e,t)=>l(t,s,[e]),addSliceRowIdsListener:(e,t,s)=>l(s,n,[e,t]),delListener:e=>(a(e),C),destroy:w,getListenerStats:()=>({sliceIds:ue(s),sliceRowIds:ge(n)})};return Ve(C)})),Tt=JSON.stringify,vt=JSON.parse,pt=e=>Tt(e,((e,t)=>t instanceof Map?Re.fromEntries([...t]):t)),St=([e,t])=>Vt(e,t),yt=([e,t,s])=>[e,t,s],Vt=(e,t)=>t?[e,t]:[e],mt=(e,t,s)=>[e,t,s],Mt=e=>e[2],Et=(e,t)=>ut(e+":"+t),kt=(e,t)=>t>e?(e?ut(e):0)^ut(t):0,Dt=(e,t)=>((e??"")>(t??"")?e:t)??"",Ht=(e,t,s)=>{t>e[1]&&(e[1]=t),e[2]=s>>>0},Jt=(e=t)=>Vt(me(),e),xt=(e=t)=>[Fe(),e,0],Ft=([e,t,s],n=yt)=>[Pe(e,n),t,s],Qt=([e,t],s=St)=>Vt(Pe(e,s),t),zt=(t,s)=>W(t)&&3==P(t)&&N(t[1])&&e(t[2])==l&&x(t[2])&&s(t[0]),Nt=e=>[e,e],Ot=(e,t=ue)=>t(e[0])+t(e[1]),Wt=()=>[Fe(),Fe()],At=e=>[...e],Pt=([e,t])=>e===t,jt=(e,t,s)=>Oe(e,t,ze(e,t)==-s?void 0:s),_t=()=>{let e,t,s=!1,n=!1,o=0,d=[];const g=Fe(),C=Fe(),V=Fe(),m=Fe(),M=Fe(),E=Fe(),k=Fe(),D=Fe(),H=Fe(),J=Fe(),x=Fe(),N=Fe(),P=Fe(),j=Fe(),_=Ke(),q=Fe(),K=Fe(),$=Fe(),ee=Fe(),te=Wt(),ne=Wt(),le=Wt(),ae=Wt(),de=Wt(),be=Wt(),Re=Wt(),Te=Wt(),ve=Wt(),pe=Wt(),ye=Wt(),me=Wt(),ke=Wt(),Je=Wt(),Ge=Wt(),Ye=Wt(),Ze=Wt(),$e=Wt(),et=Wt(),nt=Wt(),lt=Wt(),ot=Wt(),at=Fe(),rt=Wt(),[it,dt,ct,ut]=st((()=>Ps)),gt=e=>{if(!xe(e,((e,t)=>U([a,r],t))))return!1;const t=e[a];return!(!z(t)&&t!=l||(oe(e[r])!=t&&Ee(e,r),0))},ht=W,ft=(t,s)=>(!e||fe(x,s)||$t(s))&&xe(t,((e,t)=>It(s,t,e)),(()=>$t(s))),It=(e,t,s,n)=>xe(n?s:Rt(s,e,t),((n,l)=>Q(bt(e,t,l,n),(e=>(s[l]=e,!0)),(()=>!1))),(()=>$t(e,t))),bt=(t,s,n,l)=>e?Q(ze(ze(x,t),n),(e=>oe(l)!=e[a]?$t(t,s,n,l,e[r]):l),(()=>$t(t,s,n,l))):F(oe(l))?$t(t,s,n,l):l,wt=(e,t)=>xe(t?e:Tt(e),((t,s)=>Q(Lt(s,t),(t=>(e[s]=t,!0)),(()=>!1))),(()=>es())),Lt=(e,s)=>t?Q(ze(P,e),(t=>oe(s)!=t[a]?es(e,s,t[r]):s),(()=>es(e,s))):F(oe(s))?es(e,s):s,Rt=(e,t,s)=>(Q(ze(N,t),(([n,l])=>{Le(n,((t,s)=>{Me(e,s)||(e[s]=t)})),Le(l,(n=>{Me(e,n)||$t(t,s,n)}))})),e),Tt=e=>(t&&(Le(j,((t,s)=>{Me(e,s)||(e[s]=t)})),Le(_,(t=>{Me(e,t)||es(t)}))),e),St=e=>Ae(x,e,((e,t,s)=>{const n=Fe(),l=Ke();Ae(We(x,t,Fe),s,((e,t,s)=>{Oe(e,t,s),Q(s[r],(e=>Oe(n,t,e)),(()=>Xe(l,t)))})),Oe(N,t,[n,l])}),((e,t)=>{Oe(x,t),Oe(N,t)})),yt=e=>Ae(P,e,((e,t,s)=>{Oe(P,t,s),Q(s[r],(e=>Oe(j,t,e)),(()=>Xe(_,t)))}),((e,t)=>{Oe(P,t),Oe(j,t),Ce(_,t)})),Vt=e=>He(e)?Js():Ms(e),mt=e=>Ae($,e,((e,t,s)=>Mt(t,s)),((e,t)=>Qt(t))),Mt=(e,t)=>Ae(We($,e,(()=>(qt(e,1),Oe(q,e,tt()),Oe(K,e,Fe()),Fe()))),t,((t,s,n)=>Et(e,t,s,n)),((t,s)=>zt(e,t,s))),Et=(e,t,s,n,l)=>Ae(We(t,s,(()=>(Gt(e,s,1),Fe()))),n,((t,n,l)=>kt(e,s,t,n,l)),((n,o)=>Bt(e,t,s,n,o,l))),kt=(e,t,s,n,l)=>{fe(s,n)||Kt(e,t,n,1);const o=ze(s,n);l!==o&&(Xt(e,t,n,o,l),Oe(s,n,l))},Dt=(e,t,s,n,l)=>Q(ze(t,s),(t=>kt(e,s,t,n,l)),(()=>Et(e,t,s,Rt({[n]:l},e,s)))),Ht=e=>He(e)?Qs():Es(e),Jt=e=>Ae(ee,e,((e,t,s)=>xt(t,s)),((e,t)=>Ut(t))),xt=(e,t)=>{fe(ee,e)||Yt(e,1);const s=ze(ee,e);t!==s&&(Zt(e,s,t),Oe(ee,e,t))},Ft=e=>ze($,e)??Mt(e,{}),Qt=e=>Mt(e,{}),zt=(e,t,s)=>{const[,n]=ze(q,e);n(s),Et(e,t,s,{},!0)},Bt=(e,t,s,n,l,o)=>{const a=ze(ze(N,e)?.[0],l);if(!F(a)&&!o)return kt(e,s,n,l,a);const r=t=>{Xt(e,s,t,ze(n,t)),Kt(e,s,t,-1),Oe(n,t)};F(a)?r(l):Ne(n,r),Ie(n)&&(Gt(e,s,-1),Ie(Oe(t,s))&&(qt(e,-1),Oe($,e),Oe(q,e),Oe(K,e)))},Ut=e=>{const t=ze(j,e);if(!F(t))return xt(e,t);Zt(e,ze(ee,e)),Yt(e,-1),Oe(ee,e)},qt=(e,t)=>jt(g,e,t),Gt=(e,t,s)=>jt(We(m,e,Fe),t,s)&&Oe(V,e,We(V,e,(()=>0))+s),Kt=(e,t,s,n)=>{const l=ze(K,e),o=ze(l,s)??0;(0==o&&1==n||1==o&&-1==n)&&jt(We(C,e,Fe),s,n),Oe(l,s,o!=-n?o+n:null),jt(We(We(M,e,Fe),t,Fe),s,n)},Xt=(e,t,s,n,l)=>{We(We(We(E,e,Fe),t,Fe),s,(()=>[n,0]))[1]=l,d[3]?.(e,t,s,l)},Yt=(e,t)=>jt(k,e,t),Zt=(e,t,s)=>{We(D,e,(()=>[t,0]))[1]=s,d[4]?.(e,s)},$t=(e,t,s,n,l)=>(se(We(We(We(H,e,Fe),t,Fe),s,(()=>[])),n),l),es=(e,t,s)=>(se(We(J,e,(()=>[])),t),s),ts=(e,t,s)=>Q(ze(ze(ze(E,e),t),s),(([e,t])=>[!0,e,t]),(()=>[!1,...Nt(ws(e,t,s))])),ss=e=>Q(ze(D,e),(([e,t])=>[!0,e,t]),(()=>[!1,...Nt(Rs(e))])),ns=e=>Ie(H)||Ie(Ye[e])?0:Le(e?qe(H):H,((t,s)=>Le(t,((t,n)=>Le(t,((t,l)=>dt(Ye[e],[s,n,l],t))))))),ls=e=>Ie(J)||Ie(Ze[e])?0:Le(e?Be(J):J,((t,s)=>dt(Ze[e],[s],t))),os=(e,t,s,n)=>{if(!Ie(e))return dt(t,n,(()=>Pe(e))),Ne(e,((e,t)=>dt(s,[...n??[],e],1==t))),1},as=e=>{const t=Ts();t!=s&&dt(te[e],void 0,t);const n=Ie(pe[e]),l=Ie(ke[e])&&Ie(Je[e])&&Ie(ve[e])&&Ie(ye[e])&&Ie(be[e])&&Ie(Re[e])&&Ie(Te[e])&&n&&Ie(le[e])&&Ie(ae[e]),o=Ie(Ge[e])&&Ie(me[e])&&Ie(de[e])&&Ie(ne[e]);if(!l||!o){const t=e?[Be(g),Ue(C),Be(V),Ue(m),qe(M),qe(E)]:[g,C,V,m,M,E];if(!l){os(t[0],le[e],ae[e]),Le(t[1],((t,s)=>os(t,be[e],Re[e],[s]))),Le(t[2],((t,s)=>{0!=t&&dt(Te[e],[s],hs(s))}));const s=Ke();Le(t[3],((t,l)=>{os(t,ve[e],ye[e],[l])&&!n&&(dt(pe[e],[l,null]),Xe(s,l))})),n||Le(t[5],((t,n)=>{if(!fe(s,n)){const s=Ke();Le(t,(e=>Le(e,(([t,n],l)=>n!==t?Xe(s,l):Ce(e,l))))),Le(s,(t=>dt(pe[e],[n,t])))}})),Le(t[4],((t,s)=>Le(t,((t,n)=>os(t,ke[e],Je[e],[s,n])))))}if(!o){let s;Le(t[5],((t,n)=>{let l;Le(t,((t,o)=>{let a;Le(t,(([t,r],i)=>{r!==t&&(dt(Ge[e],[n,o,i],r,t,ts),s=l=a=1)})),a&&dt(me[e],[n,o],ts)})),l&&dt(de[e],[n],ts)})),s&&dt(ne[e],void 0,ts)}}},rs=e=>{const t=Vs();t!=n&&dt($e[e],void 0,t);const s=Ie(nt[e])&&Ie(lt[e]),l=Ie(ot[e])&&Ie(et[e]);if(!s||!l){const t=e?[Be(k),Be(D)]:[k,D];if(s||os(t[0],nt[e],lt[e]),!l){let s;Le(t[1],(([t,n],l)=>{n!==t&&(dt(ot[e],[l],n,t,ss),s=1)})),s&&dt(et[e],void 0,ss)}}},is=(e,...t)=>(Os((()=>e(...Z(t,y)))),Ps),ds=(e,t,s,n,l)=>{let o=Is(e,t,...s);return it((()=>{const l=Is(e,t,...s);G(l,o)||(o=l,n(Ps,e,t,...s,o))}),pe[l?1:0],[e,t],[us])},cs=()=>_e($),us=()=>Qe($),gs=e=>Qe(ze(K,y(e))),hs=e=>ce(ze($,y(e))),fs=e=>Qe(ze($,y(e))),Is=(e,t,s,n=0,l)=>{return Se(e)?Is(e.tableId,e.cellId,e.descending,e.offset,e.limit):Z(A(X((o=ze($,y(e)),a=(e,s)=>[F(t)?s:ze(e,y(t)),s],Z([...o?.entries()??[]],(([e,t])=>a(t,e)))),(([e],[t])=>Ct(e,t)*(s?-1:1))),n,F(l)?l:n+l),(([,e])=>e));var o,a},bs=(e,t)=>Qe(ze(ze($,y(e)),y(t))),ws=(e,t,s)=>ze(ze(ze($,y(e)),y(t)),y(s)),Ls=()=>Pe(ee),Cs=()=>Qe(ee),Rs=e=>ze(ee,y(e)),Ts=()=>!Ie($),vs=e=>fe($,y(e)),ps=(e,t)=>fe(ze(K,y(e)),y(t)),Ss=(e,t)=>fe(ze($,y(e)),y(t)),ys=(e,t,s)=>fe(ze(ze($,y(e)),y(t)),y(s)),Vs=()=>!Ie(ee),ms=e=>fe(ee,y(e)),Ms=e=>is((()=>(e=>xe(e,ft,$t))(e)?mt(e):0)),Es=e=>is((()=>wt(e)?Jt(e):0)),ks=e=>(B((()=>Vt(vt(e)))),Ps),Ds=t=>is((()=>{if((e=xe(t,(e=>xe(e,gt))))&&(St(t),!Ie($))){const e=cs();Js(),Ms(e)}})),Hs=e=>is((()=>{if(t=(e=>xe(e,gt))(e)){const s=Ls();Ns(),Qs(),t=!0,yt(e),Es(s)}})),Js=()=>is((()=>mt({}))),xs=e=>is((e=>fe($,e)?Qt(e):0),e),Fs=(e,t)=>is(((e,t)=>Q(ze($,e),(s=>fe(s,t)?zt(e,s,t):0))),e,t),Qs=()=>is((()=>Jt({}))),zs=()=>is((()=>{St({}),e=!1})),Ns=()=>is((()=>{yt({}),t=!1})),Os=(e,t)=>{if(-1!=o){Ws();const s=e();return As(t),s}},Ws=()=>(-1!=o&&o++,1==o&&(d[0]?.(),dt(at)),Ps),As=e=>(o>0&&(o--,0==o&&(o=1,ns(1),Ie(E)||as(1),ls(1),Ie(D)||rs(1),e?.(Ps)&&(Le(E,((e,t)=>Le(e,((e,s)=>Le(e,(([e],n)=>re(Ps,t,s,n,e))))))),we(E),Le(D,(([e],t)=>ie(Ps,t,e))),we(D)),dt(rt[0],void 0),o=-1,ns(0),Ie(E)||as(0),ls(0),Ie(D)||rs(0),d[1]?.(),dt(rt[1],void 0),d[2]?.(),o=0,s=Ts(),n=Vs(),Y([g,C,V,m,M,E,H,k,D,J],we))),Ps),Ps={getContent:()=>[cs(),Ls()],getTables:cs,getTableIds:us,getTable:e=>je(ze($,y(e))),getTableCellIds:gs,getRowCount:hs,getRowIds:fs,getSortedRowIds:Is,getRow:(e,t)=>Pe(ze(ze($,y(e)),y(t))),getCellIds:bs,getCell:ws,getValues:Ls,getValueIds:Cs,getValue:Rs,hasTables:Ts,hasTable:vs,hasTableCell:ps,hasRow:Ss,hasCell:ys,hasValues:Vs,hasValue:ms,getTablesJson:()=>pt($),getValuesJson:()=>pt(ee),getJson:()=>pt([$,ee]),getTablesSchemaJson:()=>pt(x),getValuesSchemaJson:()=>pt(P),getSchemaJson:()=>pt([x,P]),hasTablesSchema:()=>e,hasValuesSchema:()=>t,setContent:e=>is((()=>{const t=O(e)?e():e;ht(t)&&(([e,t])=>{(He(e)?Js:Ms)(e),(He(t)?Qs:Es)(t)})(t)})),setTables:Ms,setTable:(e,t)=>is((e=>ft(t,e)?Mt(e,t):0),e),setRow:(e,t,s)=>is(((e,t)=>It(e,t,s)?Et(e,Ft(e),t,s):0),e,t),addRow:(e,t,s=!0)=>Os((()=>{let n;return It(e,n,t)&&(e=y(e),Et(e,Ft(e),n=((e,t)=>{const[s]=ze(q,e);let n;do{n=s(t)}while(fe(ze($,e),n));return n})(e,s?1:0),t)),n})),setPartialRow:(e,t,s)=>is(((e,t)=>{if(It(e,t,s,1)){const n=Ft(e);De(s,((s,l)=>Dt(e,n,t,l,s)))}}),e,t),setCell:(e,t,s,n)=>is(((e,t,s)=>Q(bt(e,t,s,O(n)?n(ws(e,t,s)):n),(n=>Dt(e,Ft(e),t,s,n)))),e,t,s),setValues:Es,setPartialValues:e=>is((()=>wt(e,1)?De(e,((e,t)=>xt(t,e))):0)),setValue:(e,t)=>is((e=>Q(Lt(e,O(t)?t(Rs(e)):t),(t=>xt(e,t)))),e),applyChanges:e=>is((()=>{De(e[0],((e,t)=>F(e)?xs(t):De(e,((e,s)=>F(e)?Fs(t,s):De(e,((e,n)=>re(Ps,t,s,n,e))))))),De(e[1],((e,t)=>ie(Ps,t,e)))})),setTablesJson:ks,setValuesJson:e=>(B((()=>Ht(vt(e)))),Ps),setJson:e=>is((()=>B((()=>{const[t,s]=vt(e);Vt(t),Ht(s)}),(()=>ks(e))))),setTablesSchema:Ds,setValuesSchema:Hs,setSchema:(e,t)=>is((()=>{Ds(e),Hs(t)})),delTables:Js,delTable:xs,delRow:Fs,delCell:(e,t,s,n)=>is(((e,t,s)=>Q(ze($,e),(l=>Q(ze(l,t),(o=>fe(o,s)?Bt(e,l,t,o,s,n):0))))),e,t,s),delValues:Qs,delValue:e=>is((e=>fe(ee,e)?Ut(e):0),e),delTablesSchema:zs,delValuesSchema:Ns,delSchema:()=>is((()=>{zs(),Ns()})),transaction:Os,startTransaction:Ws,getTransactionChanges:()=>[Pe(E,((e,t)=>-1===ze(g,t)?void 0:Pe(e,((e,s)=>-1===ze(ze(m,t),s)?void 0:Pe(e,(([,e])=>e),(e=>Pt(e)))),Ie,He)),Ie,He),Pe(D,(([,e])=>e),(e=>Pt(e))),1],getTransactionLog:()=>[!Ie(E),!Ie(D),_e(E,At,Pt),_e(H),Pe(D,At,Pt),Pe(J),Pe(g),je(m),_e(M),Pe(k)],finishTransaction:As,forEachTable:e=>Le($,((t,s)=>e(s,(e=>Le(t,((t,s)=>e(s,(e=>Ne(t,e))))))))),forEachTableCell:(e,t)=>Ne(ze(K,y(e)),t),forEachRow:(e,t)=>Le(ze($,y(e)),((e,s)=>t(s,(t=>Ne(e,t))))),forEachCell:(e,t,s)=>Ne(ze(ze($,y(e)),y(t)),s),forEachValue:e=>Ne(ee,e),addSortedRowIdsListener:(e,t,s,n,l,o,a)=>Se(e)?ds(e.tableId,e.cellId,[e.descending??!1,e.offset??0,e.limit],t,s):ds(e,t,[s,n,l],o,a),addStartTransactionListener:e=>it(e,at),addWillFinishTransactionListener:e=>it(e,rt[0]),addDidFinishTransactionListener:e=>it(e,rt[1]),callListener:e=>(ut(e),Ps),delListener:e=>(ct(e),Ps),getListenerStats:()=>({hasTables:Ot(te),tables:Ot(ne),tableIds:Ot(le),hasTable:Ot(ae),table:Ot(de),tableCellIds:Ot(be),hasTableCell:Ot(Re,ge),rowCount:Ot(Te),rowIds:Ot(ve),sortedRowIds:Ot(pe),hasRow:Ot(ye,ge),row:Ot(me,ge),cellIds:Ot(ke,ge),hasCell:Ot(Je,he),cell:Ot(Ge,he),invalidCell:Ot(Ye,he),hasValues:Ot($e),values:Ot(et),valueIds:Ot(nt),hasValue:Ot(lt),value:Ot(ot),invalidValue:Ot(Ze),transaction:ue(at)+Ot(rt)}),isMergeable:()=>!1,createStore:_t,addListener:it,callListeners:dt,setInternalListeners:(e,t,s,n,l)=>d=[e,t,s,n,l]};return De({[u+f]:[0,te,[],()=>[Ts()]],[f]:[0,ne],[I]:[0,le],[u+h]:[1,ae,[us],e=>[vs(...e)]],[h]:[1,de,[us]],[h+T]:[1,be,[us]],[u+h+R]:[2,Re,[us,gs],e=>[ps(...e)]],[w]:[1,Te,[us]],[L]:[1,ve,[us]],[u+b]:[2,ye,[us,fs],e=>[Ss(...e)]],[b]:[2,me,[us,fs]],[T]:[2,ke,[us,fs]],[u+R]:[3,Je,[us,fs,bs],e=>[ys(...e)]],[R]:[3,Ge,[us,fs,bs],e=>Nt(ws(...e))],InvalidCell:[3,Ye],[u+p]:[0,$e,[],()=>[Vs()]],[p]:[0,et],[S]:[0,nt],[u+v]:[1,lt,[Cs],e=>[ms(...e)]],[v]:[1,ot,[Cs],e=>Nt(Rs(e[0]))],InvalidValue:[1,Ze]},(([e,t,s,n],l)=>{Ps[c+l+i]=(...l)=>it(l[e],t[l[e+1]?1:0],e>0?A(l,0,e):void 0,s,n)})),Ve(Ps)},Bt={HasTable:1,Table:1,TableCellIds:1,HasTableCell:2,RowCount:1,RowIds:1,SortedRowIds:5,HasRow:2,Row:2,CellIds:2,HasCell:3,Cell:3,HasValue:1,Value:1,InvalidCell:3,InvalidValue:1},Ut=(e=t)=>[xt(e),xt(e)],qt=(e,s)=>{let n=1,l=Ut(),o=0;const a=Fe(),r=Ke(),[d,u]=Lt(e,s),g=_t(),h=e=>{const t=n;return n=0,e(),n=t,R},f=(e,s=0)=>{const n={},o={},[[a,r=t,i=0],d]=e,[c,g]=l,[h,f,b]=c;let w=s?i:b,L=r;ke(a,(([e,l=t,o=0],a)=>{const r=We(h,a,xt),[i,d,c]=r;let u=s?o:c,g=l;ke(e,((e,t)=>{const[l,o,r]=I(e,We(i,t,xt),Je(Je(n,a,me),t,me),s);u^=s?0:(o?Et(t,o):0)^Et(t,r),g=Dt(g,l)})),u^=s?0:kt(d,l),Ht(r,l,u),w^=s?0:(c?Et(a,c):0)^Et(a,r[2]),L=Dt(L,g)})),w^=s?0:kt(f,r),Ht(c,r,w);const[C]=I(d,g,o,s);return u(Dt(L,C)),[n,o,1]},I=(e,s,n,l)=>{const[o,a=t,r=0]=e,[i,d,c]=s;let u=a,g=l?r:c;return ke(o,(([e,s=t,o=0],a)=>{const r=We(i,a,(()=>[void 0,t,0])),[,d,c]=r;(!d||s>d)&&(Ht(r,s,l?o:ut(pt(e??null)+":"+s)),r[0]=e,n[a]=e,g^=l?0:Et(a,c)^Et(a,r[2]),u=Dt(u,s))})),g^=l?0:kt(d,a),Ht(s,a,g),[u,c,s[2]]},b=_,w=_,L=()=>[Ft(l[0],(e=>Ft(e,(e=>Ft(e))))),Ft(l[1])],C=e=>h((()=>g.applyChanges(f(e)))),R={getMergeableContent:L,getMergeableContentHashes:()=>[l[0][2],l[1][2]],getMergeableTableHashes:()=>Pe(l[0][0],Mt),getMergeableTableDiff:e=>{const t=Jt(l[0][1]),s={};return Ne(l[0][0],((n,[l,o,a])=>Me(e,n)?a!=e[n]?s[n]=a:0:t[0][n]=Qt([l,o],(e=>Qt(e))))),[t,s]},getMergeableRowHashes:e=>{const t={};return ke(e,((e,s)=>Q(ze(l[0][0],s),(([n,,l])=>l!=e?Ne(n,((e,[,,n])=>Je(t,s,me)[e]=n)):0)))),t},getMergeableRowDiff:e=>{const t=Jt(l[0][1]),s={};return ke(e,((e,n)=>Ne(ze(l[0][0],n)?.[0],((l,[o,a,r])=>Me(e,l)?r!==e[l]?Je(s,n,me)[l]=r:0:Je(t[0],n,Jt)[0][l]=Qt([o,a]))))),[t,s]},getMergeableCellHashes:e=>{const t={};return ke(e,((e,s)=>Q(ze(l[0][0],s),(([n])=>ke(e,((e,l)=>Q(ze(n,l),(([n,,o])=>o!==e?Ne(n,((e,[,,n])=>Je(Je(t,s,me),l,me)[e]=n)):0)))))))),t},getMergeableCellDiff:e=>{const[[t,s]]=l,n={};return ke(e,((e,s)=>ke(e,((e,l)=>Q(ze(t,s),(([t,o])=>Q(ze(t,l),(([t,a])=>Ne(t,((t,[r,i,d])=>d!==e[t]?Je(Je(n,s,(()=>Jt(o)))[0],l,(()=>Jt(a)))[0][t]=[r,i]:0)))))))))),Vt(n,s)},getMergeableValueHashes:()=>Pe(l[1][0],Mt),getMergeableValueDiff:e=>{const[,[t,s]]=l,n=Pe(t,St,(([,,t],s)=>t==e?.[s]));return Vt(n,s)},setMergeableContent:e=>h((()=>(e=>W(e)&&2==P(e)&&zt(e[0],(e=>xe(e,(e=>zt(e,(e=>xe(e,(e=>zt(e,(e=>xe(e,(e=>zt(e,ae)),void 0,1)))),void 0,1)))),void 0,1)))&&zt(e[1],(e=>xe(e,(e=>zt(e,ae)),void 0,1))))(e)?g.transaction((()=>{g.delTables().delValues(),l=Ut(),g.applyChanges(f(e,1))})):0)),setDefaultContent:e=>(g.transaction((()=>{o=1,g.setContent(e),o=0})),R),getTransactionMergeableChanges:(e=!1)=>{const[[t,s,n],[o,i,d]]=l,c=e?mt:Vt,u={};Le(a,((e,s)=>Q(ze(t,s),(([t,n,l])=>{const o={};Le(e,((e,s)=>Q(ze(t,s),(([t,n,l])=>{const a={};Le(e,(e=>{Q(ze(t,e),(([t,s,n])=>a[e]=c(t,s,n)))})),o[s]=c(a,n,l)})))),u[s]=c(o,n,l)}))));const g={};return Le(r,(e=>Q(ze(o,e),(([t,s,n])=>g[e]=c(t,s,n))))),[c(u,s,n),c(g,i,d),1]},applyMergeableChanges:C,merge:e=>{const t=L(),s=e.getMergeableContent();return e.applyMergeableChanges(t),C(s)}};return g.setInternalListeners(b,w,(()=>{we(a),we(r)}),((e,s,l,r)=>{Xe(We(We(a,e,Fe),s,Ke),l),n&&f([[{[e]:[{[s]:[{[l]:[r,o?t:d()]}]}]}],[{}],1])}),((e,s)=>{Xe(r,e),n&&f([[{}],[{[e]:[s,o?t:d()]}],1])})),De(g,((e,t)=>R[t]=V(t,"set")||V(t,"del")||V(t,"apply")||m(t,"Transaction")||t=="call"+i?(...t)=>(e(...t),R):V(t,c)&&m(t,i)?(...s)=>{const n=Bt[A(t,3,-8)]??0,l=s[n];return s[n]=(e,...t)=>l(R,...t),e(...s)}:"isMergeable"==t?()=>!0:e)),Ve(R)},Gt=Fe([["avg",[(e,t)=>$(e)/t,(e,t,s)=>e+(t-e)/(s+1),(e,t,s)=>e+(e-t)/(s-1),(e,t,s,n)=>e+(t-s)/n]],["max",[e=>D(...e),(e,t)=>D(t,e),(e,t)=>t==e?void 0:e,(e,t,s)=>s==e?void 0:D(t,e)]],["min",[e=>H(...e),(e,t)=>H(t,e),(e,t)=>t==e?void 0:e,(e,t,s)=>s==e?void 0:H(t,e)]],["sum",[e=>$(e),(e,t)=>e+t,(e,t)=>e-t,(e,t,s)=>e-s+t]]]),Kt=(e,t,s,n,l,o=!1)=>{if(Ie(s))return;const[a,r,i,d]=l;return o||=F(e),Le(n,(([s,n])=>{o||(e=F(s)?r?.(e,n,t++):F(n)?i?.(e,s,t--):d?.(e,n,s,t),o||=F(e))})),o?a(be(s),ce(s)):e},Xt=$e((e=>{const s=Fe(),[n,l,o]=st((()=>w)),[a,r,i,d,c,u,g,,h,f,I,b]=Ye(e,j,(e=>isNaN(e)||F(e)||!0===e||!1===e||e===t?void 0:1*e),n,l),w={setMetricDefinition:(e,t,n,o,a,r,i)=>{const d=O(n)?[n,a,r,i]:ze(Gt,n)??ze(Gt,"sum");return h(e,t,((t,n,o,a,r,i)=>{const c=u(e),h=ce(a);i||=F(c),t();let f=Kt(c,h,a,n,d,i);x(f)||(f=void 0),f!=c&&(g(e,f),l(s,[e],f,c))}),Ze(o,1)),w},delMetricDefinition:e=>(f(e),w),getStore:a,getMetricIds:r,forEachMetric:i,hasMetric:d,getTableId:c,getMetric:u,addMetricIdsListener:I,addMetricListener:(e,t)=>n(t,s,[e]),delListener:e=>(o(e),w),destroy:b,getListenerStats:()=>({metric:ue(s)})};return Ve(w)})),Yt=$e((e=>{const s=e.createStore,n=s(),l=s(),o=Fe(),{addListener:a,callListeners:r,delListener:u}=l,[g,f,I,v,p,,,S,,y,V,m,M,E]=Ye(e,(()=>!0),j,a,r),k=(e,t,...s)=>Y(s,(s=>Xe(We(We(o,t,Fe),e,Ke),s))),D=e=>{Q(ze(o,e),(e=>{Ne(e,((e,t)=>Le(t,(t=>e.delListener(t))))),we(e)})),Y([l,n],(t=>t.delTable(e)))},H=(e,t,s)=>k(t,e,t.addStartTransactionListener(s.startTransaction),t.addDidFinishTransactionListener((()=>s.finishTransaction()))),J={setQueryDefinition:(s,o,a)=>{S(s,o),D(s);const r=[],i=[[null,[o,null,null,[],Fe()]]],d=[],c=[],u=[];a({select:(e,s)=>{const n=O(e)?[P(r)+t,e]:[F(s)?e:s,t=>t(e,s)];return se(r,n),{as:e=>n[0]=e}},join:(e,t,s)=>{const n=F(s)||O(t)?null:t,l=F(n)?t:s,o=[e,[e,n,O(l)?l:e=>e(l),[],Fe()]];return se(i,o),{as:e=>o[0]=e}},where:(e,t,s)=>se(d,O(e)?e:F(s)?s=>s(e)===t:n=>n(e,t)===s),group:(e,t,s,n,l)=>{const o=[e,[e,O(t)?[t,s,n,l]:ze(Gt,t)??[(e,t)=>t]]];return se(c,o),{as:e=>o[0]=e}},having:(e,t)=>se(u,O(e)?e:s=>s(e)===t)});const g=Fe(r);if(Ie(g))return J;const h=Fe(i);Ne(h,((e,[,t])=>Q(ze(h,t),(({3:t})=>F(e)?0:se(t,e)))));const f=Fe(c);let I=n;if(Ie(f)&&ee(u))I=l;else{H(s,I,l);const e=Fe();Ne(f,((t,[s,n])=>Xe(We(e,s,Ke),[t,n])));const t=Ke();Ne(g,(s=>fe(e,s)?0:Xe(t,s)));const n=Fe(),o=(t,n,o,a)=>Q(t,(([r,i,d,c])=>{Ne(n,((t,[s])=>{const n=We(r,t,Fe),l=ze(n,o),i=a?void 0:s;if(l!==i){const s=Ke([[l,i]]),a=ce(n);Oe(n,o,i),Le(ze(e,t),(([e,t])=>{const l=Kt(c[e],a,n,s,t);c[e]=F(oe(l))?null:l}))}})),Ie(i)||!q(u,(e=>e((e=>c[e]))))?l.delRow(s,d):F(d)?t[2]=l.addRow(s,c):l.setRow(s,d,c)}));k(I,s,I.addRowListener(s,null,((l,a,r,i)=>{const d=[],c=[],u=Fe(),g=I.hasRow(s,r);let h=!g;Le(t,(e=>{const[t,n,l]=i(s,r,e);se(d,n),se(c,l),h||=t})),Ne(e,(e=>{const[t,,n]=i(s,r,e);(h||t)&&Oe(u,e,[n])})),h&&o(Ge(n,d,void 0,(([,e])=>(Ce(e,r),Ie(e)))),u,r,1),g&&o(Ge(n,c,(()=>{const e={};return Le(t,(t=>e[t]=I.getCell(s,r,t))),[Fe(),Ke(),void 0,e]}),(([,e])=>{Xe(e,r)})),u,r)})))}H(s,e,I);const b=(t,n,l,a)=>{const r=t=>e.getCell(n,l,t);Y(a,(n=>{const[l,,o,a,i]=ze(h,n),d=o?.(r,t),[c,u]=ze(i,t)??[];d!=c&&(F(u)||E(s,u),Oe(i,t,F(d)?null:[d,...M(s,1,e.addRowListener(l,d,(()=>b(t,l,d,a))))]))})),(t=>{const n=(s,n)=>e.getCell(...F(n)?[o,t,s]:s===o?[o,t,n]:[ze(h,s)?.[0],ze(ze(h,s)?.[4],t)?.[0],n]);I.transaction((()=>q(d,(e=>e(n)))?Ne(g,((e,l)=>re(I,s,t,e,l(n,t)))):I.delRow(s,t)))})(t)},{3:w}=ze(h,null);return I.transaction((()=>M(s,1,e.addRowListener(o,null,((t,n,l)=>{e.hasRow(o,l)?b(l,o,l,w):(I.delRow(s,l),Le(h,(({4:e})=>Q(ze(e,l),(([,t])=>{E(s,t),Oe(e,l)})))))}))))),J},delQueryDefinition:e=>(D(e),y(e),J),getStore:g,getQueryIds:f,forEachQuery:I,hasQuery:v,getTableId:p,addQueryIdsListener:e=>V((()=>e(J))),delListener:e=>(u(e),J),destroy:m,getListenerStats:()=>{const{tables:e,tableIds:t,transaction:s,...n}=l.getListenerStats();return n}};return De({[h]:[1,1],[h+T]:[0,1],[w]:[0,1],[L]:[0,1],[C]:[0,5],[b]:[1,2],[T]:[0,2],[R]:[1,3]},(([e,t],s)=>{Y(e?["get","has","forEach"]:["get"],(e=>J[e+d+s]=(...t)=>l[e+s](...t))),J[c+d+s+i]=(...e)=>l[c+s+i](...A(e,0,t),((s,...n)=>e[t](J,...n)),!0)})),Ve(J)})),Zt=$e((e=>{const s=Fe(),n=Fe(),l=Fe(),o=Fe(),[a,r,i]=st((()=>v)),[d,c,u,g,h,f,,,I,b,w,L]=Ye(e,(()=>[Fe(),Fe(),Fe(),Fe()]),(e=>F(e)?void 0:e+t),a,r),C=(e,t,s)=>Q(f(e),(([n,,l])=>{if(!fe(l,t)){const o=Ke();if(h(e)!=T(e))Xe(o,t);else{let e=t;for(;!F(e)&&!fe(o,e);)Xe(o,e),e=ze(n,e)}if(s)return o;Oe(l,t,o)}return ze(l,t)})),R=(e,t)=>Q(f(e),(([,,e])=>Oe(e,t))),T=e=>ze(s,e),v={setRelationshipDefinition:(e,t,a,i)=>(Oe(s,e,a),I(e,t,((t,s)=>{const a=Ke(),i=Ke(),d=Ke(),[c,u]=f(e);Le(s,(([t,s],n)=>{F(t)||(Xe(i,t),Q(ze(u,t),(e=>{Ce(e,n),Ie(e)&&Oe(u,t)}))),F(s)||(Xe(i,s),fe(u,s)||Oe(u,s,Ke()),Xe(ze(u,s),n)),Xe(a,n),Oe(c,n,s),Ne(ze(o,e),(t=>{fe(C(e,t),n)&&Xe(d,t)}))})),t(),Le(a,(t=>r(n,[e,t]))),Le(i,(t=>r(l,[e,t]))),Le(d,(t=>{R(e,t),r(o,[e,t])}))}),Ze(i)),v),delRelationshipDefinition:e=>(Oe(s,e),b(e),v),getStore:d,getRelationshipIds:c,forEachRelationship:t=>u((s=>t(s,(t=>e.forEachRow(h(s),t))))),hasRelationship:g,getLocalTableId:h,getRemoteTableId:T,getRemoteRowId:(e,t)=>ze(f(e)?.[0],t),getLocalRowIds:(e,t)=>be(ze(f(e)?.[1],t)),getLinkedRowIds:(e,t)=>F(f(e))?[t]:be(C(e,t,!0)),addRelationshipIdsListener:w,addRemoteRowIdListener:(e,t,s)=>a(s,n,[e,t]),addLocalRowIdsListener:(e,t,s)=>a(s,l,[e,t]),addLinkedRowIdsListener:(e,t,s)=>(C(e,t),a(s,o,[e,t])),delListener:e=>(R(...i(e)??[]),v),destroy:L,getListenerStats:()=>({remoteRowId:ge(n),localRowIds:ge(l),linkedRowIds:ge(o)})};return Ve(v)}));export{nt as createCheckpoints,Rt as createIndexes,qt as createMergeableStore,Xt as createMetrics,Yt as createQueries,Zt as createRelationships,_t as createStore,Ct as defaultSorter,Lt as getHlcFunctions,it as getRandomValues,dt as getUniqueId};
|
|
1
|
+
const e=e=>typeof e,t="",s=e(t),n=e(!0),l=e(0),o=e(e),a="type",r="default",i="Listener",d="Result",c="add",u="Has",g="Ids",h="Table",f=h+"s",I=h+g,b="Row",w=b+"Count",L=b+g,C="Sorted"+b+g,R="Cell",T=R+g,v="Value",p=v+"s",S=v+g,y=e=>t+e,V=(e,t)=>e.startsWith(t),m=(e,t)=>e.endsWith(t),M=(e,s=t,n)=>e.split(s,n),E=globalThis,k=Math,D=k.max,H=k.min,J=k.floor,x=isFinite,F=e=>null==e,Q=(e,t,s)=>F(e)?s?.():t(e),z=e=>e==s||e==n,N=t=>e(t)==s,O=t=>e(t)==o,W=e=>Array.isArray(e),A=(e,t,s)=>e.slice(t,s),P=e=>e.length,j=()=>{},_=()=>{},B=async(e,t,s)=>{try{return await e()}catch(e){t?.(e)}},U=(e,t)=>e.includes(t),q=(e,t)=>e.every(t),G=(e,t)=>P(e)===P(t)&&q(e,((e,s)=>t[s]===e)),K=(e,t)=>q(e,((s,n)=>0==n||t(e[n-1],s)<=0)),X=(e,t)=>e.sort(t),Y=(e,t)=>e.forEach(t),Z=(e,t)=>e.map(t),$=e=>te(e,((e,t)=>e+t),0),ee=e=>0==P(e),te=(e,t,s)=>e.reduce(t,s),se=(e,...t)=>e.push(...t),ne=e=>e.pop(),le=e=>e.shift(),oe=t=>{const s=e(t);return z(s)||s==l&&x(t)?s:void 0},ae=e=>F(e)||!F(oe(e)),re=(e,t,s,n,l)=>F(l)?e.delCell(t,s,n,!0):e.setCell(t,s,n,l),ie=(e,t,s)=>F(s)?e.delValue(t):e.setValue(t,s),de=e=>t=>te(be(t),((t,s)=>t+e(s)),0),ce=e=>e?.size??0,ue=de(ce),ge=de(ue),he=de(ge),fe=(e,t)=>e?.has(t)??!1,Ie=e=>F(e)||0==ce(e),be=e=>[...e?.values()??[]],we=e=>e.clear(),Le=(e,t)=>e?.forEach(t),Ce=(e,t)=>e?.delete(t),Re=Object,Te=e=>Re.getPrototypeOf(e),ve=Re.isFrozen,pe=Re.entries,Se=e=>!F(e)&&Q(Te(e),(e=>e==Re.prototype||F(Te(e))),(()=>!0)),ye=Re.keys,Ve=Re.freeze,me=(e=[])=>Re.fromEntries(e),Me=(e,t)=>t in e,Ee=(e,t)=>(delete e[t],e),ke=(e,t)=>Y(pe(e),(([e,s])=>t(s,e))),De=(e,t)=>me(((e,t)=>Z(pe(e),(([e,s])=>t(s,e))))(e,((e,s)=>[s,t(e,s)]))),He=e=>Se(e)&&0==(e=>P(ye(e)))(e),Je=(e,t,s)=>(Me(e,t)||(e[t]=s()),e[t]),xe=(e,t,s,n=0)=>F(e)||!Se(e)||!n&&He(e)||ve(e)?(s?.(),!1):(ke(e,((s,n)=>{t(s,n)||Ee(e,n)})),!!n||!He(e)),Fe=e=>new Map(e),Qe=e=>[...e?.keys()??[]],ze=(e,t)=>e?.get(t),Ne=(e,t)=>Le(e,((e,s)=>t(s,e))),Oe=(e,t,s)=>F(s)?(Ce(e,t),e):e?.set(t,s),We=(e,t,s,n)=>(fe(e,t)?n?.(ze(e,t)):Oe(e,t,s()),ze(e,t)),Ae=(e,t,s,n=Oe)=>(De(t,((t,n)=>s(e,n,t))),Ne(e,(s=>Me(t,s)?0:n(e,s))),e),Pe=(e,t,s,n)=>{const l={};return Le(e,((e,o)=>{if(!s?.(e,o)){const s=t?t(e,o):e;n?.(s)||(l[o]=s)}})),l},je=(e,t,s)=>Pe(e,(e=>Pe(e,t,s)),Ie,He),_e=(e,t,s)=>Pe(e,(e=>je(e,t,s)),Ie,He),Be=(e,t)=>{const s=Fe();return Le(e,((e,n)=>s.set(n,t?.(e)??e))),s},Ue=e=>Be(e,Be),qe=e=>Be(e,Ue),Ge=(e,t,s,n,l=0)=>Q((s?We:ze)(e,t[l],l>P(t)-2?s:Fe),(o=>{if(l>P(t)-2)return n?.(o)&&Oe(e,t[l]),o;const a=Ge(o,t,s,n,l+1);return Ie(o)&&Oe(e,t[l]),a})),Ke=e=>new Set(W(e)||F(e)?e:[e]),Xe=(e,t)=>e?.add(t),Ye=(e,t,s,n,l)=>{const o=e.hasRow,a=Fe(),r=Fe(),i=Fe(),d=Fe(),c=Fe(),u=Fe(),g=(t,s,...n)=>{const l=We(u,t,Ke);return Y(n,(t=>Xe(l,t)&&s&&e.callListener(t))),n},h=(t,...s)=>Q(ze(u,t),(n=>{Y(ee(s)?be(n):s,(t=>{e.delListener(t),Ce(n,t)})),Ie(n)&&Oe(u,t)})),f=(e,s)=>{Oe(a,e,s),fe(r,e)||(Oe(r,e,t()),Oe(d,e,Fe()),Oe(c,e,Fe()),l(i))},I=e=>{Oe(a,e),Oe(r,e),Oe(d,e),Oe(c,e),h(e),l(i)};return[()=>e,()=>Qe(a),e=>Ne(r,e),e=>fe(r,e),e=>ze(a,e),e=>ze(r,e),(e,t)=>Oe(r,e,t),f,(t,n,l,a,r)=>{f(t,n);const i=Fe(),u=Fe(),I=ze(d,t),b=ze(c,t),w=t=>{const l=s=>e.getCell(n,t,s),d=ze(I,t),c=o(n,t)?s(a(l,t)):void 0;if(d===c||W(d)&&W(c)&&G(d,c)||Oe(i,t,[d,c]),!F(r)){const e=ze(b,t),s=o(n,t)?r(l,t):void 0;e!=s&&Oe(u,t,s)}},L=e=>{l((()=>{Le(i,(([,e],t)=>Oe(I,t,e))),Le(u,((e,t)=>Oe(b,t,e)))}),i,u,I,b,e),we(i),we(u)};Ne(I,w),e.hasTable(n)&&Y(e.getRowIds(n),(e=>{fe(I,e)||w(e)})),L(!0),h(t),g(t,0,e.addRowListener(n,null,((e,t,s)=>w(s))),e.addTableListener(n,(()=>L())))},I,e=>n(e,i),()=>Ne(u,I),g,h]},Ze=(e,s)=>N(e)?t=>t(e):e??(()=>s??t),$e=(e,t)=>{const s=new WeakMap;return n=>{s.has(n)||s.set(n,e(n));const l=s.get(n);return t?.(l),l}},et=/^\d+$/,tt=()=>{const e=[];let s=0;return[n=>(n?le(e):null)??t+s++,t=>{et.test(t)&&P(e)<1e3&&se(e,t)}]},st=e=>{let s;const[n,l]=tt(),o=Fe();return[(l,a,r,i=[],d=()=>[])=>{s??=e();const c=n(1);return Oe(o,c,[l,a,r,i,d]),Xe(Ge(a,r??[t],Ke),c),c},(e,n,...l)=>Y(((e,s=[t])=>{const n=[],l=(e,t)=>t==P(s)?se(n,e):null===s[t]?Le(e,(e=>l(e,t+1))):Y([s[t],null],(s=>l(ze(e,s),t+1)));return l(e,0),n})(e,n),(e=>Le(e,(e=>ze(o,e)[0](s,...n??[],...l))))),e=>Q(ze(o,e),(([,s,n])=>(Ge(s,n??[t],void 0,(t=>(Ce(t,e),Ie(t)?1:0))),Oe(o,e),l(e),n))),e=>Q(ze(o,e),(([e,,t=[],n,l])=>{const o=(...a)=>{const r=P(a);r==P(t)?e(s,...a,...l(a)):F(t[r])?Y(n[r]?.(...a)??[],(e=>o(...a,e))):o(...a,t[r])};o()}))]},nt=$e((e=>{let s,n,l,o=100,a=Fe(),r=Fe(),i=1;const d=Fe(),c=Fe(),[u,g,h]=st((()=>J)),f=Fe(),I=Fe(),b=[],w=[],L=(t,s)=>{i=0,e.transaction((()=>{const[n,l]=ze(f,s);Le(n,((s,n)=>Le(s,((s,l)=>Le(s,((s,o)=>re(e,n,l,o,s[t]))))))),Le(l,((s,n)=>ie(e,n,s[t])))})),i=1},C=e=>{Oe(f,e),Oe(I,e),g(c,[e])},R=(e,t)=>Y(((e,t)=>e.splice(0,t))(e,t??P(e)),C),T=()=>R(b,P(b)-o),v=()=>Q(s,(()=>{se(b,s),T(),R(w),s=void 0,l=1})),p=()=>{s=ne(b),l=1};let S,y;const V=(e=t)=>(F(s)&&(s=t+n++,Oe(f,s,[a,r]),D(s,e),a=Fe(),r=Fe(),l=1),s),m=()=>{ee(b)||(((e,...t)=>{e.unshift(...t)})(w,V()),L(0,s),s=ne(b),l=1)},M=()=>{ee(w)||(se(b,s),s=le(w),L(1,s),l=1)},E=()=>{l&&(g(d),l=0)},k=e=>{const t=V(e);return E(),t},D=(e,t)=>(H(e)&&ze(I,e)!==t&&(Oe(I,e,t),g(c,[e])),J),H=e=>fe(f,e),J={setSize:e=>(o=e,T(),J),addCheckpoint:k,setCheckpoint:D,getStore:()=>e,getCheckpointIds:()=>[[...b],s,[...w]],forEachCheckpoint:e=>Ne(I,e),hasCheckpoint:H,getCheckpoint:e=>ze(I,e),goBackward:()=>(m(),E(),J),goForward:()=>(M(),E(),J),goTo:e=>{const t=U(b,e)?m:U(w,e)?M:null;for(;!F(t)&&e!=s;)t();return E(),J},addCheckpointIdsListener:e=>u(e,d),addCheckpointListener:(e,t)=>u(t,c,[e]),delListener:e=>(h(e),J),clear:()=>(R(b),R(w),F(s)||C(s),s=void 0,n=0,k(),J),clearForward:()=>(ee(w)||(R(w),g(d)),J),destroy:()=>{e.delListener(S),e.delListener(y)},getListenerStats:()=>({checkpointIds:ue(d),checkpoint:ue(c)}),_registerListeners:()=>{S=e.addCellListener(null,null,null,((e,t,s,n,l,o)=>{if(i){v();const e=We(a,t,Fe),r=We(e,s,Fe),i=We(r,n,(()=>[o,void 0]));i[1]=l,i[0]===l&&Ie(Oe(r,n))&&Ie(Oe(e,s))&&Ie(Oe(a,t))&&p(),E()}})),y=e.addValueListener(null,((e,t,s,n)=>{if(i){v();const e=We(r,t,(()=>[n,void 0]));e[1]=s,e[0]===s&&Ie(Oe(r,t))&&p(),E()}}))}};return Ve(J.clear())}),(e=>e._registerListeners())),lt=M("-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz"),ot=Fe(Z(lt,((e,t)=>[e,t]))),at=e=>lt[63&e],rt=(e,t)=>ze(ot,e[t])??0,it=E.crypto?e=>E.crypto.getRandomValues(e):e=>Z(e,(()=>J(256*k.random()))),dt=(e=16)=>te(it(new Uint8Array(e)),((e,t)=>e+at(t)),""),ct=JSON.stringify,ut=JSON.parse,gt=e=>ct(e,((e,t)=>t instanceof Map?Re.fromEntries([...t]):t)),ht=new E.TextEncoder,ft=e=>{let t=2166136261;return Y(ht.encode(e),(e=>{t^=e,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)})),t>>>0},It=(e,t)=>(e^t)>>>0,bt=e=>te(pe(e),((e,[t,s])=>It(e,wt(t,s)^wt(t,0))),0),wt=(e,t)=>ft(e+":"+t),Lt=(e,t)=>ft(gt(e??null)+":"+t),Ct=Lt,Rt=wt,Tt=bt,vt=wt,pt=e=>te(pe(e),((e,[t,s])=>It(e,wt(t,s))),0),St=wt,yt=pt,Vt=2**36,mt=2**30,Mt=2**24,Et=2**18,kt=4096,Dt=e=>{const t=ft(e);return at(t/Mt)+at(t/Et)+at(t/kt)+at(t/64)+at(t)},Ht=(e,t=Date.now)=>{let s=0,n=-1;const l=Q(e,Dt,(()=>dt(5))),o=e=>{const l=s,[o,a]=F(e)||""==e?[0,0]:r(e);s=D(l,o,t()),n=s==l?s==o?D(n,a):n:s==o?a:-1},a=(e,t,s)=>at(e/Vt)+at(e/mt)+at(e/Mt)+at(e/Et)+at(e/kt)+at(e/64)+at(e)+at(t/Et)+at(t/kt)+at(t/64)+at(t)+(F(s)?l:Dt(s)),r=e=>[rt(e,0)*Vt+rt(e,1)*mt+rt(e,2)*Mt+rt(e,3)*Et+rt(e,4)*kt+64*rt(e,5)+rt(e,6),rt(e,7)*Et+rt(e,8)*kt+64*rt(e,9)+rt(e,10),e.slice(11)];return[()=>(o(),a(s,++n)),o,a,r,()=>s,()=>n,()=>l]},Jt=(e,t)=>(e??0)<(t??0)?-1:1,xt=$e((e=>{const s=Fe(),n=Fe(),[l,o,a]=st((()=>C)),[r,i,d,c,u,g,h,,f,I,b,w]=Ye(e,Fe,(e=>F(e)?t:W(e)?Z(e,y):y(e)),l,o),L=(t,s,n)=>{const l=u(t);Le(n,((t,n)=>s(n,(s=>Le(t,(t=>s(t,(s=>e.forEachCell(l,t,s)))))))))},C={setIndexDefinition:(e,t,l,a,r,i=Jt)=>{const d=F(r)?void 0:([e],[t])=>r(e,t);return f(e,t,((t,l,r,c,u,f)=>{let I=0;const b=Ke(),w=Ke(),L=g(e);if(Le(l,(([e,t],s)=>{const n=Ke(e),l=Ke(t);Le(n,(e=>Ce(l,e)?Ce(n,e):0)),Le(n,(e=>{Xe(b,e),Q(ze(L,e),(t=>{Ce(t,s),Ie(t)&&(Oe(L,e),I=1)}))})),Le(l,(e=>{Xe(b,e),fe(L,e)||(Oe(L,e,Ke()),I=1),Xe(ze(L,e),s),F(a)||Xe(w,e)}))})),t(),Ie(u)||(f?Ne(L,(e=>Xe(w,e))):Ne(r,(e=>Q(ze(c,e),(e=>Y(W(e)?e:[e],(e=>Xe(w,e))))))),Le(w,(e=>{const t=(t,s)=>i(ze(u,t),ze(u,s),e),s=[...ze(L,e)];K(s,t)||(Oe(L,e,Ke(X(s,t))),Xe(b,e))}))),(I||f)&&!F(d)){const t=[...L];K(t,d)||(h(e,Fe(X(t,d))),I=1)}I&&o(s,[e]),Le(b,(t=>o(n,[e,t])))}),Ze(l),Q(a,Ze)),C},delIndexDefinition:e=>(I(e),C),getStore:r,getIndexIds:i,forEachIndex:e=>d(((t,s)=>e(t,(e=>L(t,e,s))))),forEachSlice:(e,t)=>L(e,t,g(e)),hasIndex:c,hasSlice:(e,t)=>fe(g(e),t),getTableId:u,getSliceIds:e=>Qe(g(e)),getSliceRowIds:(e,t)=>be(ze(g(e),t)),addIndexIdsListener:b,addSliceIdsListener:(e,t)=>l(t,s,[e]),addSliceRowIdsListener:(e,t,s)=>l(s,n,[e,t]),delListener:e=>(a(e),C),destroy:w,getListenerStats:()=>({sliceIds:ue(s),sliceRowIds:ge(n)})};return Ve(C)})),Ft=([e,t])=>zt(e,t),Qt=([e,t,s])=>[e,t,s],zt=(e,t)=>t?[e,t]:[e],Nt=(e,t,s)=>[e,t,s],Ot=e=>e[2],Wt=(e,t)=>t>e?(e?ft(e):0)^ft(t):0,At=(e,t)=>((e??"")>(t??"")?e:t)??"",Pt=(e,t,s)=>{t>e[1]&&(e[1]=t),e[2]=s>>>0},jt=(e=t)=>zt(me(),e),_t=(e=t)=>[Fe(),e,0],Bt=([e,t,s],n=Qt)=>[Pe(e,n),t,s],Ut=([e,t],s=Ft)=>zt(Pe(e,s),t),qt=(t,s)=>W(t)&&3==P(t)&&N(t[1])&&e(t[2])==l&&x(t[2])&&s(t[0]),Gt=e=>[e,e],Kt=(e,t=ue)=>t(e[0])+t(e[1]),Xt=()=>[Fe(),Fe()],Yt=e=>[...e],Zt=([e,t])=>e===t,$t=(e,t,s)=>Oe(e,t,ze(e,t)==-s?void 0:s),es=()=>{let e,t,s=!1,n=!1,o=0,d=[];const g=Fe(),C=Fe(),V=Fe(),m=Fe(),M=Fe(),E=Fe(),k=Fe(),D=Fe(),H=Fe(),J=Fe(),x=Fe(),N=Fe(),P=Fe(),j=Fe(),_=Ke(),q=Fe(),K=Fe(),$=Fe(),ee=Fe(),te=Xt(),ne=Xt(),le=Xt(),ae=Xt(),de=Xt(),be=Xt(),Re=Xt(),Te=Xt(),ve=Xt(),pe=Xt(),ye=Xt(),me=Xt(),ke=Xt(),Je=Xt(),Ge=Xt(),Ye=Xt(),Ze=Xt(),$e=Xt(),et=Xt(),nt=Xt(),lt=Xt(),ot=Xt(),at=Fe(),rt=Xt(),[it,dt,ct,ht]=st((()=>Ps)),ft=e=>{if(!xe(e,((e,t)=>U([a,r],t))))return!1;const t=e[a];return!(!z(t)&&t!=l||(oe(e[r])!=t&&Ee(e,r),0))},It=W,bt=(t,s)=>(!e||fe(x,s)||Ut(s))&&xe(t,((e,t)=>wt(s,t,e)),(()=>Ut(s))),wt=(e,t,s,n)=>xe(n?s:Tt(s,e,t),((n,l)=>Q(Lt(e,t,l,n),(e=>(s[l]=e,!0)),(()=>!1))),(()=>Ut(e,t))),Lt=(t,s,n,l)=>e?Q(ze(ze(x,t),n),(e=>oe(l)!=e[a]?Ut(t,s,n,l,e[r]):l),(()=>Ut(t,s,n,l))):F(oe(l))?Ut(t,s,n,l):l,Ct=(e,t)=>xe(t?e:vt(e),((t,s)=>Q(Rt(s,t),(t=>(e[s]=t,!0)),(()=>!1))),(()=>qt())),Rt=(e,s)=>t?Q(ze(P,e),(t=>oe(s)!=t[a]?qt(e,s,t[r]):s),(()=>qt(e,s))):F(oe(s))?qt(e,s):s,Tt=(e,t,s)=>(Q(ze(N,t),(([n,l])=>{Le(n,((t,s)=>{Me(e,s)||(e[s]=t)})),Le(l,(n=>{Me(e,n)||Ut(t,s,n)}))})),e),vt=e=>(t&&(Le(j,((t,s)=>{Me(e,s)||(e[s]=t)})),Le(_,(t=>{Me(e,t)||qt(t)}))),e),pt=e=>Ae(x,e,((e,t,s)=>{const n=Fe(),l=Ke();Ae(We(x,t,Fe),s,((e,t,s)=>{Oe(e,t,s),Q(s[r],(e=>Oe(n,t,e)),(()=>Xe(l,t)))})),Oe(N,t,[n,l])}),((e,t)=>{Oe(x,t),Oe(N,t)})),St=e=>Ae(P,e,((e,t,s)=>{Oe(P,t,s),Q(s[r],(e=>Oe(j,t,e)),(()=>Xe(_,t)))}),((e,t)=>{Oe(P,t),Oe(j,t),Ce(_,t)})),yt=e=>He(e)?Js():Ms(e),Vt=e=>Ae($,e,((e,t,s)=>mt(t,s)),((e,t)=>Qt(t))),mt=(e,t)=>Ae(We($,e,(()=>(Wt(e,1),Oe(q,e,tt()),Oe(K,e,Fe()),Fe()))),t,((t,s,n)=>Mt(e,t,s,n)),((t,s)=>zt(e,t,s))),Mt=(e,t,s,n,l)=>Ae(We(t,s,(()=>(At(e,s,1),Fe()))),n,((t,n,l)=>Et(e,s,t,n,l)),((n,o)=>Nt(e,t,s,n,o,l))),Et=(e,t,s,n,l)=>{fe(s,n)||Pt(e,t,n,1);const o=ze(s,n);l!==o&&(jt(e,t,n,o,l),Oe(s,n,l))},kt=(e,t,s,n,l)=>Q(ze(t,s),(t=>Et(e,s,t,n,l)),(()=>Mt(e,t,s,Tt({[n]:l},e,s)))),Dt=e=>He(e)?Qs():Es(e),Ht=e=>Ae(ee,e,((e,t,s)=>xt(t,s)),((e,t)=>Ot(t))),xt=(e,t)=>{fe(ee,e)||_t(e,1);const s=ze(ee,e);t!==s&&(Bt(e,s,t),Oe(ee,e,t))},Ft=e=>ze($,e)??mt(e,{}),Qt=e=>mt(e,{}),zt=(e,t,s)=>{const[,n]=ze(q,e);n(s),Mt(e,t,s,{},!0)},Nt=(e,t,s,n,l,o)=>{const a=ze(ze(N,e)?.[0],l);if(!F(a)&&!o)return Et(e,s,n,l,a);const r=t=>{jt(e,s,t,ze(n,t)),Pt(e,s,t,-1),Oe(n,t)};F(a)?r(l):Ne(n,r),Ie(n)&&(At(e,s,-1),Ie(Oe(t,s))&&(Wt(e,-1),Oe($,e),Oe(q,e),Oe(K,e)))},Ot=e=>{const t=ze(j,e);if(!F(t))return xt(e,t);Bt(e,ze(ee,e)),_t(e,-1),Oe(ee,e)},Wt=(e,t)=>$t(g,e,t),At=(e,t,s)=>$t(We(m,e,Fe),t,s)&&Oe(V,e,We(V,e,(()=>0))+s),Pt=(e,t,s,n)=>{const l=ze(K,e),o=ze(l,s)??0;(0==o&&1==n||1==o&&-1==n)&&$t(We(C,e,Fe),s,n),Oe(l,s,o!=-n?o+n:null),$t(We(We(M,e,Fe),t,Fe),s,n)},jt=(e,t,s,n,l)=>{We(We(We(E,e,Fe),t,Fe),s,(()=>[n,0]))[1]=l,d[3]?.(e,t,s,l)},_t=(e,t)=>$t(k,e,t),Bt=(e,t,s)=>{We(D,e,(()=>[t,0]))[1]=s,d[4]?.(e,s)},Ut=(e,t,s,n,l)=>(se(We(We(We(H,e,Fe),t,Fe),s,(()=>[])),n),l),qt=(e,t,s)=>(se(We(J,e,(()=>[])),t),s),ts=(e,t,s)=>Q(ze(ze(ze(E,e),t),s),(([e,t])=>[!0,e,t]),(()=>[!1,...Gt(ws(e,t,s))])),ss=e=>Q(ze(D,e),(([e,t])=>[!0,e,t]),(()=>[!1,...Gt(Rs(e))])),ns=e=>Ie(H)||Ie(Ye[e])?0:Le(e?qe(H):H,((t,s)=>Le(t,((t,n)=>Le(t,((t,l)=>dt(Ye[e],[s,n,l],t))))))),ls=e=>Ie(J)||Ie(Ze[e])?0:Le(e?Be(J):J,((t,s)=>dt(Ze[e],[s],t))),os=(e,t,s,n)=>{if(!Ie(e))return dt(t,n,(()=>Pe(e))),Ne(e,((e,t)=>dt(s,[...n??[],e],1==t))),1},as=e=>{const t=Ts();t!=s&&dt(te[e],void 0,t);const n=Ie(pe[e]),l=Ie(ke[e])&&Ie(Je[e])&&Ie(ve[e])&&Ie(ye[e])&&Ie(be[e])&&Ie(Re[e])&&Ie(Te[e])&&n&&Ie(le[e])&&Ie(ae[e]),o=Ie(Ge[e])&&Ie(me[e])&&Ie(de[e])&&Ie(ne[e]);if(!l||!o){const t=e?[Be(g),Ue(C),Be(V),Ue(m),qe(M),qe(E)]:[g,C,V,m,M,E];if(!l){os(t[0],le[e],ae[e]),Le(t[1],((t,s)=>os(t,be[e],Re[e],[s]))),Le(t[2],((t,s)=>{0!=t&&dt(Te[e],[s],hs(s))}));const s=Ke();Le(t[3],((t,l)=>{os(t,ve[e],ye[e],[l])&&!n&&(dt(pe[e],[l,null]),Xe(s,l))})),n||Le(t[5],((t,n)=>{if(!fe(s,n)){const s=Ke();Le(t,(e=>Le(e,(([t,n],l)=>n!==t?Xe(s,l):Ce(e,l))))),Le(s,(t=>dt(pe[e],[n,t])))}})),Le(t[4],((t,s)=>Le(t,((t,n)=>os(t,ke[e],Je[e],[s,n])))))}if(!o){let s;Le(t[5],((t,n)=>{let l;Le(t,((t,o)=>{let a;Le(t,(([t,r],i)=>{r!==t&&(dt(Ge[e],[n,o,i],r,t,ts),s=l=a=1)})),a&&dt(me[e],[n,o],ts)})),l&&dt(de[e],[n],ts)})),s&&dt(ne[e],void 0,ts)}}},rs=e=>{const t=Vs();t!=n&&dt($e[e],void 0,t);const s=Ie(nt[e])&&Ie(lt[e]),l=Ie(ot[e])&&Ie(et[e]);if(!s||!l){const t=e?[Be(k),Be(D)]:[k,D];if(s||os(t[0],nt[e],lt[e]),!l){let s;Le(t[1],(([t,n],l)=>{n!==t&&(dt(ot[e],[l],n,t,ss),s=1)})),s&&dt(et[e],void 0,ss)}}},is=(e,...t)=>(Os((()=>e(...Z(t,y)))),Ps),ds=(e,t,s,n,l)=>{let o=Is(e,t,...s);return it((()=>{const l=Is(e,t,...s);G(l,o)||(o=l,n(Ps,e,t,...s,o))}),pe[l?1:0],[e,t],[us])},cs=()=>_e($),us=()=>Qe($),gs=e=>Qe(ze(K,y(e))),hs=e=>ce(ze($,y(e))),fs=e=>Qe(ze($,y(e))),Is=(e,t,s,n=0,l)=>{return Se(e)?Is(e.tableId,e.cellId,e.descending,e.offset,e.limit):Z(A(X((o=ze($,y(e)),a=(e,s)=>[F(t)?s:ze(e,y(t)),s],Z([...o?.entries()??[]],(([e,t])=>a(t,e)))),(([e],[t])=>Jt(e,t)*(s?-1:1))),n,F(l)?l:n+l),(([,e])=>e));var o,a},bs=(e,t)=>Qe(ze(ze($,y(e)),y(t))),ws=(e,t,s)=>ze(ze(ze($,y(e)),y(t)),y(s)),Ls=()=>Pe(ee),Cs=()=>Qe(ee),Rs=e=>ze(ee,y(e)),Ts=()=>!Ie($),vs=e=>fe($,y(e)),ps=(e,t)=>fe(ze(K,y(e)),y(t)),Ss=(e,t)=>fe(ze($,y(e)),y(t)),ys=(e,t,s)=>fe(ze(ze($,y(e)),y(t)),y(s)),Vs=()=>!Ie(ee),ms=e=>fe(ee,y(e)),Ms=e=>is((()=>(e=>xe(e,bt,Ut))(e)?Vt(e):0)),Es=e=>is((()=>Ct(e)?Ht(e):0)),ks=e=>(B((()=>yt(ut(e)))),Ps),Ds=t=>is((()=>{if((e=xe(t,(e=>xe(e,ft))))&&(pt(t),!Ie($))){const e=cs();Js(),Ms(e)}})),Hs=e=>is((()=>{if(t=(e=>xe(e,ft))(e)){const s=Ls();Ns(),Qs(),t=!0,St(e),Es(s)}})),Js=()=>is((()=>Vt({}))),xs=e=>is((e=>fe($,e)?Qt(e):0),e),Fs=(e,t)=>is(((e,t)=>Q(ze($,e),(s=>fe(s,t)?zt(e,s,t):0))),e,t),Qs=()=>is((()=>Ht({}))),zs=()=>is((()=>{pt({}),e=!1})),Ns=()=>is((()=>{St({}),t=!1})),Os=(e,t)=>{if(-1!=o){Ws();const s=e();return As(t),s}},Ws=()=>(-1!=o&&o++,1==o&&(d[0]?.(),dt(at)),Ps),As=e=>(o>0&&(o--,0==o&&(o=1,ns(1),Ie(E)||as(1),ls(1),Ie(D)||rs(1),e?.(Ps)&&(Le(E,((e,t)=>Le(e,((e,s)=>Le(e,(([e],n)=>re(Ps,t,s,n,e))))))),we(E),Le(D,(([e],t)=>ie(Ps,t,e))),we(D)),dt(rt[0],void 0),o=-1,ns(0),Ie(E)||as(0),ls(0),Ie(D)||rs(0),d[1]?.(),dt(rt[1],void 0),d[2]?.(),o=0,s=Ts(),n=Vs(),Y([g,C,V,m,M,E,H,k,D,J],we))),Ps),Ps={getContent:()=>[cs(),Ls()],getTables:cs,getTableIds:us,getTable:e=>je(ze($,y(e))),getTableCellIds:gs,getRowCount:hs,getRowIds:fs,getSortedRowIds:Is,getRow:(e,t)=>Pe(ze(ze($,y(e)),y(t))),getCellIds:bs,getCell:ws,getValues:Ls,getValueIds:Cs,getValue:Rs,hasTables:Ts,hasTable:vs,hasTableCell:ps,hasRow:Ss,hasCell:ys,hasValues:Vs,hasValue:ms,getTablesJson:()=>gt($),getValuesJson:()=>gt(ee),getJson:()=>gt([$,ee]),getTablesSchemaJson:()=>gt(x),getValuesSchemaJson:()=>gt(P),getSchemaJson:()=>gt([x,P]),hasTablesSchema:()=>e,hasValuesSchema:()=>t,setContent:e=>is((()=>{const t=O(e)?e():e;It(t)&&(([e,t])=>{(He(e)?Js:Ms)(e),(He(t)?Qs:Es)(t)})(t)})),setTables:Ms,setTable:(e,t)=>is((e=>bt(t,e)?mt(e,t):0),e),setRow:(e,t,s)=>is(((e,t)=>wt(e,t,s)?Mt(e,Ft(e),t,s):0),e,t),addRow:(e,t,s=!0)=>Os((()=>{let n;return wt(e,n,t)&&(e=y(e),Mt(e,Ft(e),n=((e,t)=>{const[s]=ze(q,e);let n;do{n=s(t)}while(fe(ze($,e),n));return n})(e,s?1:0),t)),n})),setPartialRow:(e,t,s)=>is(((e,t)=>{if(wt(e,t,s,1)){const n=Ft(e);De(s,((s,l)=>kt(e,n,t,l,s)))}}),e,t),setCell:(e,t,s,n)=>is(((e,t,s)=>Q(Lt(e,t,s,O(n)?n(ws(e,t,s)):n),(n=>kt(e,Ft(e),t,s,n)))),e,t,s),setValues:Es,setPartialValues:e=>is((()=>Ct(e,1)?De(e,((e,t)=>xt(t,e))):0)),setValue:(e,t)=>is((e=>Q(Rt(e,O(t)?t(Rs(e)):t),(t=>xt(e,t)))),e),applyChanges:e=>is((()=>{De(e[0],((e,t)=>F(e)?xs(t):De(e,((e,s)=>F(e)?Fs(t,s):De(e,((e,n)=>re(Ps,t,s,n,e))))))),De(e[1],((e,t)=>ie(Ps,t,e)))})),setTablesJson:ks,setValuesJson:e=>(B((()=>Dt(ut(e)))),Ps),setJson:e=>is((()=>B((()=>{const[t,s]=ut(e);yt(t),Dt(s)}),(()=>ks(e))))),setTablesSchema:Ds,setValuesSchema:Hs,setSchema:(e,t)=>is((()=>{Ds(e),Hs(t)})),delTables:Js,delTable:xs,delRow:Fs,delCell:(e,t,s,n)=>is(((e,t,s)=>Q(ze($,e),(l=>Q(ze(l,t),(o=>fe(o,s)?Nt(e,l,t,o,s,n):0))))),e,t,s),delValues:Qs,delValue:e=>is((e=>fe(ee,e)?Ot(e):0),e),delTablesSchema:zs,delValuesSchema:Ns,delSchema:()=>is((()=>{zs(),Ns()})),transaction:Os,startTransaction:Ws,getTransactionChanges:()=>[Pe(E,((e,t)=>-1===ze(g,t)?void 0:Pe(e,((e,s)=>-1===ze(ze(m,t),s)?void 0:Pe(e,(([,e])=>e),(e=>Zt(e)))),Ie,He)),Ie,He),Pe(D,(([,e])=>e),(e=>Zt(e))),1],getTransactionLog:()=>[!Ie(E),!Ie(D),_e(E,Yt,Zt),_e(H),Pe(D,Yt,Zt),Pe(J),Pe(g),je(m),_e(M),Pe(k)],finishTransaction:As,forEachTable:e=>Le($,((t,s)=>e(s,(e=>Le(t,((t,s)=>e(s,(e=>Ne(t,e))))))))),forEachTableCell:(e,t)=>Ne(ze(K,y(e)),t),forEachRow:(e,t)=>Le(ze($,y(e)),((e,s)=>t(s,(t=>Ne(e,t))))),forEachCell:(e,t,s)=>Ne(ze(ze($,y(e)),y(t)),s),forEachValue:e=>Ne(ee,e),addSortedRowIdsListener:(e,t,s,n,l,o,a)=>Se(e)?ds(e.tableId,e.cellId,[e.descending??!1,e.offset??0,e.limit],t,s):ds(e,t,[s,n,l],o,a),addStartTransactionListener:e=>it(e,at),addWillFinishTransactionListener:e=>it(e,rt[0]),addDidFinishTransactionListener:e=>it(e,rt[1]),callListener:e=>(ht(e),Ps),delListener:e=>(ct(e),Ps),getListenerStats:()=>({hasTables:Kt(te),tables:Kt(ne),tableIds:Kt(le),hasTable:Kt(ae),table:Kt(de),tableCellIds:Kt(be),hasTableCell:Kt(Re,ge),rowCount:Kt(Te),rowIds:Kt(ve),sortedRowIds:Kt(pe),hasRow:Kt(ye,ge),row:Kt(me,ge),cellIds:Kt(ke,ge),hasCell:Kt(Je,he),cell:Kt(Ge,he),invalidCell:Kt(Ye,he),hasValues:Kt($e),values:Kt(et),valueIds:Kt(nt),hasValue:Kt(lt),value:Kt(ot),invalidValue:Kt(Ze),transaction:ue(at)+Kt(rt)}),isMergeable:()=>!1,createStore:es,addListener:it,callListeners:dt,setInternalListeners:(e,t,s,n,l)=>d=[e,t,s,n,l]};return De({[u+f]:[0,te,[],()=>[Ts()]],[f]:[0,ne],[I]:[0,le],[u+h]:[1,ae,[us],e=>[vs(...e)]],[h]:[1,de,[us]],[h+T]:[1,be,[us]],[u+h+R]:[2,Re,[us,gs],e=>[ps(...e)]],[w]:[1,Te,[us]],[L]:[1,ve,[us]],[u+b]:[2,ye,[us,fs],e=>[Ss(...e)]],[b]:[2,me,[us,fs]],[T]:[2,ke,[us,fs]],[u+R]:[3,Je,[us,fs,bs],e=>[ys(...e)]],[R]:[3,Ge,[us,fs,bs],e=>Gt(ws(...e))],InvalidCell:[3,Ye],[u+p]:[0,$e,[],()=>[Vs()]],[p]:[0,et],[S]:[0,nt],[u+v]:[1,lt,[Cs],e=>[ms(...e)]],[v]:[1,ot,[Cs],e=>Gt(Rs(e[0]))],InvalidValue:[1,Ze]},(([e,t,s,n],l)=>{Ps[c+l+i]=(...l)=>it(l[e],t[l[e+1]?1:0],e>0?A(l,0,e):void 0,s,n)})),Ve(Ps)},ts={HasTable:1,Table:1,TableCellIds:1,HasTableCell:2,RowCount:1,RowIds:1,SortedRowIds:5,HasRow:2,Row:2,CellIds:2,HasCell:3,Cell:3,HasValue:1,Value:1,InvalidCell:3,InvalidValue:1},ss=(e=t)=>[_t(e),_t(e)],ns=(e,s)=>{let n=1,l=ss(),o=0;const a=Fe(),r=Ke(),[d,u]=Ht(e,s),g=es(),h=e=>{const t=n;return n=0,e(),n=t,R},f=(e,s=0)=>{const n={},o={},[[a,r=t,i=0],d]=e,[c,g]=l,[h,f,b]=c;let w=s?i:b,L=r;ke(a,(([e,l=t,o=0],a)=>{const r=We(h,a,_t),[i,d,c]=r;let u=s?o:c,g=l;ke(e,((e,t)=>{const[l,o,r]=I(e,We(i,t,_t),Je(Je(n,a,me),t,me),s);u^=s?0:It(o?wt(t,o):0,wt(t,r)),g=At(g,l)})),u^=s?0:Wt(d,l),Pt(r,l,u),w^=s?0:It(c?wt(a,c):0,wt(a,r[2])),L=At(L,g)})),w^=s?0:Wt(f,r),Pt(c,r,w);const[C]=I(d,g,o,s);return u(At(L,C)),[n,o,1]},I=(e,s,n,l)=>{const[o,a=t,r=0]=e,[i,d,c]=s;let u=a,g=l?r:c;return ke(o,(([e,s=t,o=0],a)=>{const r=We(i,a,(()=>[void 0,t,0])),[,d,c]=r;(!d||s>d)&&(Pt(r,s,l?o:Lt(e,s)),r[0]=e,n[a]=e,g^=l?0:It(wt(a,c),wt(a,r[2])),u=At(u,s))})),g^=l?0:Wt(d,a),Pt(s,a,g),[u,c,s[2]]},b=_,w=_,L=()=>[Bt(l[0],(e=>Bt(e,(e=>Bt(e))))),Bt(l[1])],C=e=>h((()=>g.applyChanges(f(e)))),R={getMergeableContent:L,getMergeableContentHashes:()=>[l[0][2],l[1][2]],getMergeableTableHashes:()=>Pe(l[0][0],Ot),getMergeableTableDiff:e=>{const t=jt(l[0][1]),s={};return Ne(l[0][0],((n,[l,o,a])=>Me(e,n)?a!=e[n]?s[n]=a:0:t[0][n]=Ut([l,o],(e=>Ut(e))))),[t,s]},getMergeableRowHashes:e=>{const t={};return ke(e,((e,s)=>Q(ze(l[0][0],s),(([n,,l])=>l!=e?Ne(n,((e,[,,n])=>Je(t,s,me)[e]=n)):0)))),t},getMergeableRowDiff:e=>{const t=jt(l[0][1]),s={};return ke(e,((e,n)=>Ne(ze(l[0][0],n)?.[0],((l,[o,a,r])=>Me(e,l)?r!==e[l]?Je(s,n,me)[l]=r:0:Je(t[0],n,jt)[0][l]=Ut([o,a]))))),[t,s]},getMergeableCellHashes:e=>{const t={};return ke(e,((e,s)=>Q(ze(l[0][0],s),(([n])=>ke(e,((e,l)=>Q(ze(n,l),(([n,,o])=>o!==e?Ne(n,((e,[,,n])=>Je(Je(t,s,me),l,me)[e]=n)):0)))))))),t},getMergeableCellDiff:e=>{const[[t,s]]=l,n={};return ke(e,((e,s)=>ke(e,((e,l)=>Q(ze(t,s),(([t,o])=>Q(ze(t,l),(([t,a])=>Ne(t,((t,[r,i,d])=>d!==e[t]?Je(Je(n,s,(()=>jt(o)))[0],l,(()=>jt(a)))[0][t]=[r,i]:0)))))))))),zt(n,s)},getMergeableValueHashes:()=>Pe(l[1][0],Ot),getMergeableValueDiff:e=>{const[,[t,s]]=l,n=Pe(t,Ft,(([,,t],s)=>t==e?.[s]));return zt(n,s)},setMergeableContent:e=>h((()=>(e=>W(e)&&2==P(e)&&qt(e[0],(e=>xe(e,(e=>qt(e,(e=>xe(e,(e=>qt(e,(e=>xe(e,(e=>qt(e,ae)),void 0,1)))),void 0,1)))),void 0,1)))&&qt(e[1],(e=>xe(e,(e=>qt(e,ae)),void 0,1))))(e)?g.transaction((()=>{g.delTables().delValues(),l=ss(),g.applyChanges(f(e,1))})):0)),setDefaultContent:e=>(g.transaction((()=>{o=1,g.setContent(e),o=0})),R),getTransactionMergeableChanges:(e=!1)=>{const[[t,s,n],[o,i,d]]=l,c=e?Nt:zt,u={};Le(a,((e,s)=>Q(ze(t,s),(([t,n,l])=>{const o={};Le(e,((e,s)=>Q(ze(t,s),(([t,n,l])=>{const a={};Le(e,(e=>{Q(ze(t,e),(([t,s,n])=>a[e]=c(t,s,n)))})),o[s]=c(a,n,l)})))),u[s]=c(o,n,l)}))));const g={};return Le(r,(e=>Q(ze(o,e),(([t,s,n])=>g[e]=c(t,s,n))))),[c(u,s,n),c(g,i,d),1]},applyMergeableChanges:C,merge:e=>{const t=L(),s=e.getMergeableContent();return e.applyMergeableChanges(t),C(s)}};return g.setInternalListeners(b,w,(()=>{we(a),we(r)}),((e,s,l,r)=>{Xe(We(We(a,e,Fe),s,Ke),l),n&&f([[{[e]:[{[s]:[{[l]:[r,o?t:d()]}]}]}],[{}],1])}),((e,s)=>{Xe(r,e),n&&f([[{}],[{[e]:[s,o?t:d()]}],1])})),De(g,((e,t)=>R[t]=V(t,"set")||V(t,"del")||V(t,"apply")||m(t,"Transaction")||t=="call"+i?(...t)=>(e(...t),R):V(t,c)&&m(t,i)?(...s)=>{const n=ts[A(t,3,-8)]??0,l=s[n];return s[n]=(e,...t)=>l(R,...t),e(...s)}:"isMergeable"==t?()=>!0:e)),Ve(R)},ls=Fe([["avg",[(e,t)=>$(e)/t,(e,t,s)=>e+(t-e)/(s+1),(e,t,s)=>e+(e-t)/(s-1),(e,t,s,n)=>e+(t-s)/n]],["max",[e=>D(...e),(e,t)=>D(t,e),(e,t)=>t==e?void 0:e,(e,t,s)=>s==e?void 0:D(t,e)]],["min",[e=>H(...e),(e,t)=>H(t,e),(e,t)=>t==e?void 0:e,(e,t,s)=>s==e?void 0:H(t,e)]],["sum",[e=>$(e),(e,t)=>e+t,(e,t)=>e-t,(e,t,s)=>e-s+t]]]),os=(e,t,s,n,l,o=!1)=>{if(Ie(s))return;const[a,r,i,d]=l;return o||=F(e),Le(n,(([s,n])=>{o||(e=F(s)?r?.(e,n,t++):F(n)?i?.(e,s,t--):d?.(e,n,s,t),o||=F(e))})),o?a(be(s),ce(s)):e},as=$e((e=>{const s=Fe(),[n,l,o]=st((()=>w)),[a,r,i,d,c,u,g,,h,f,I,b]=Ye(e,j,(e=>isNaN(e)||F(e)||!0===e||!1===e||e===t?void 0:1*e),n,l),w={setMetricDefinition:(e,t,n,o,a,r,i)=>{const d=O(n)?[n,a,r,i]:ze(ls,n)??ze(ls,"sum");return h(e,t,((t,n,o,a,r,i)=>{const c=u(e),h=ce(a);i||=F(c),t();let f=os(c,h,a,n,d,i);x(f)||(f=void 0),f!=c&&(g(e,f),l(s,[e],f,c))}),Ze(o,1)),w},delMetricDefinition:e=>(f(e),w),getStore:a,getMetricIds:r,forEachMetric:i,hasMetric:d,getTableId:c,getMetric:u,addMetricIdsListener:I,addMetricListener:(e,t)=>n(t,s,[e]),delListener:e=>(o(e),w),destroy:b,getListenerStats:()=>({metric:ue(s)})};return Ve(w)})),rs=$e((e=>{const s=e.createStore,n=s(),l=s(),o=Fe(),{addListener:a,callListeners:r,delListener:u}=l,[g,f,I,v,p,,,S,,y,V,m,M,E]=Ye(e,(()=>!0),j,a,r),k=(e,t,...s)=>Y(s,(s=>Xe(We(We(o,t,Fe),e,Ke),s))),D=e=>{Q(ze(o,e),(e=>{Ne(e,((e,t)=>Le(t,(t=>e.delListener(t))))),we(e)})),Y([l,n],(t=>t.delTable(e)))},H=(e,t,s)=>k(t,e,t.addStartTransactionListener(s.startTransaction),t.addDidFinishTransactionListener((()=>s.finishTransaction()))),J={setQueryDefinition:(s,o,a)=>{S(s,o),D(s);const r=[],i=[[null,[o,null,null,[],Fe()]]],d=[],c=[],u=[];a({select:(e,s)=>{const n=O(e)?[P(r)+t,e]:[F(s)?e:s,t=>t(e,s)];return se(r,n),{as:e=>n[0]=e}},join:(e,t,s)=>{const n=F(s)||O(t)?null:t,l=F(n)?t:s,o=[e,[e,n,O(l)?l:e=>e(l),[],Fe()]];return se(i,o),{as:e=>o[0]=e}},where:(e,t,s)=>se(d,O(e)?e:F(s)?s=>s(e)===t:n=>n(e,t)===s),group:(e,t,s,n,l)=>{const o=[e,[e,O(t)?[t,s,n,l]:ze(ls,t)??[(e,t)=>t]]];return se(c,o),{as:e=>o[0]=e}},having:(e,t)=>se(u,O(e)?e:s=>s(e)===t)});const g=Fe(r);if(Ie(g))return J;const h=Fe(i);Ne(h,((e,[,t])=>Q(ze(h,t),(({3:t})=>F(e)?0:se(t,e)))));const f=Fe(c);let I=n;if(Ie(f)&&ee(u))I=l;else{H(s,I,l);const e=Fe();Ne(f,((t,[s,n])=>Xe(We(e,s,Ke),[t,n])));const t=Ke();Ne(g,(s=>fe(e,s)?0:Xe(t,s)));const n=Fe(),o=(t,n,o,a)=>Q(t,(([r,i,d,c])=>{Ne(n,((t,[s])=>{const n=We(r,t,Fe),l=ze(n,o),i=a?void 0:s;if(l!==i){const s=Ke([[l,i]]),a=ce(n);Oe(n,o,i),Le(ze(e,t),(([e,t])=>{const l=os(c[e],a,n,s,t);c[e]=F(oe(l))?null:l}))}})),Ie(i)||!q(u,(e=>e((e=>c[e]))))?l.delRow(s,d):F(d)?t[2]=l.addRow(s,c):l.setRow(s,d,c)}));k(I,s,I.addRowListener(s,null,((l,a,r,i)=>{const d=[],c=[],u=Fe(),g=I.hasRow(s,r);let h=!g;Le(t,(e=>{const[t,n,l]=i(s,r,e);se(d,n),se(c,l),h||=t})),Ne(e,(e=>{const[t,,n]=i(s,r,e);(h||t)&&Oe(u,e,[n])})),h&&o(Ge(n,d,void 0,(([,e])=>(Ce(e,r),Ie(e)))),u,r,1),g&&o(Ge(n,c,(()=>{const e={};return Le(t,(t=>e[t]=I.getCell(s,r,t))),[Fe(),Ke(),void 0,e]}),(([,e])=>{Xe(e,r)})),u,r)})))}H(s,e,I);const b=(t,n,l,a)=>{const r=t=>e.getCell(n,l,t);Y(a,(n=>{const[l,,o,a,i]=ze(h,n),d=o?.(r,t),[c,u]=ze(i,t)??[];d!=c&&(F(u)||E(s,u),Oe(i,t,F(d)?null:[d,...M(s,1,e.addRowListener(l,d,(()=>b(t,l,d,a))))]))})),(t=>{const n=(s,n)=>e.getCell(...F(n)?[o,t,s]:s===o?[o,t,n]:[ze(h,s)?.[0],ze(ze(h,s)?.[4],t)?.[0],n]);I.transaction((()=>q(d,(e=>e(n)))?Ne(g,((e,l)=>re(I,s,t,e,l(n,t)))):I.delRow(s,t)))})(t)},{3:w}=ze(h,null);return I.transaction((()=>M(s,1,e.addRowListener(o,null,((t,n,l)=>{e.hasRow(o,l)?b(l,o,l,w):(I.delRow(s,l),Le(h,(({4:e})=>Q(ze(e,l),(([,t])=>{E(s,t),Oe(e,l)})))))}))))),J},delQueryDefinition:e=>(D(e),y(e),J),getStore:g,getQueryIds:f,forEachQuery:I,hasQuery:v,getTableId:p,addQueryIdsListener:e=>V((()=>e(J))),delListener:e=>(u(e),J),destroy:m,getListenerStats:()=>{const{tables:e,tableIds:t,transaction:s,...n}=l.getListenerStats();return n}};return De({[h]:[1,1],[h+T]:[0,1],[w]:[0,1],[L]:[0,1],[C]:[0,5],[b]:[1,2],[T]:[0,2],[R]:[1,3]},(([e,t],s)=>{Y(e?["get","has","forEach"]:["get"],(e=>J[e+d+s]=(...t)=>l[e+s](...t))),J[c+d+s+i]=(...e)=>l[c+s+i](...A(e,0,t),((s,...n)=>e[t](J,...n)),!0)})),Ve(J)})),is=$e((e=>{const s=Fe(),n=Fe(),l=Fe(),o=Fe(),[a,r,i]=st((()=>v)),[d,c,u,g,h,f,,,I,b,w,L]=Ye(e,(()=>[Fe(),Fe(),Fe(),Fe()]),(e=>F(e)?void 0:e+t),a,r),C=(e,t,s)=>Q(f(e),(([n,,l])=>{if(!fe(l,t)){const o=Ke();if(h(e)!=T(e))Xe(o,t);else{let e=t;for(;!F(e)&&!fe(o,e);)Xe(o,e),e=ze(n,e)}if(s)return o;Oe(l,t,o)}return ze(l,t)})),R=(e,t)=>Q(f(e),(([,,e])=>Oe(e,t))),T=e=>ze(s,e),v={setRelationshipDefinition:(e,t,a,i)=>(Oe(s,e,a),I(e,t,((t,s)=>{const a=Ke(),i=Ke(),d=Ke(),[c,u]=f(e);Le(s,(([t,s],n)=>{F(t)||(Xe(i,t),Q(ze(u,t),(e=>{Ce(e,n),Ie(e)&&Oe(u,t)}))),F(s)||(Xe(i,s),fe(u,s)||Oe(u,s,Ke()),Xe(ze(u,s),n)),Xe(a,n),Oe(c,n,s),Ne(ze(o,e),(t=>{fe(C(e,t),n)&&Xe(d,t)}))})),t(),Le(a,(t=>r(n,[e,t]))),Le(i,(t=>r(l,[e,t]))),Le(d,(t=>{R(e,t),r(o,[e,t])}))}),Ze(i)),v),delRelationshipDefinition:e=>(Oe(s,e),b(e),v),getStore:d,getRelationshipIds:c,forEachRelationship:t=>u((s=>t(s,(t=>e.forEachRow(h(s),t))))),hasRelationship:g,getLocalTableId:h,getRemoteTableId:T,getRemoteRowId:(e,t)=>ze(f(e)?.[0],t),getLocalRowIds:(e,t)=>be(ze(f(e)?.[1],t)),getLinkedRowIds:(e,t)=>F(f(e))?[t]:be(C(e,t,!0)),addRelationshipIdsListener:w,addRemoteRowIdListener:(e,t,s)=>a(s,n,[e,t]),addLocalRowIdsListener:(e,t,s)=>a(s,l,[e,t]),addLinkedRowIdsListener:(e,t,s)=>(C(e,t),a(s,o,[e,t])),delListener:e=>(R(...i(e)??[]),v),destroy:L,getListenerStats:()=>({remoteRowId:ge(n),localRowIds:ge(l),linkedRowIds:ge(o)})};return Ve(v)}));export{It as addOrRemoveHash,nt as createCheckpoints,xt as createIndexes,ns as createMergeableStore,as as createMetrics,rs as createQueries,is as createRelationships,es as createStore,Jt as defaultSorter,Ct as getCellHash,Rt as getCellInRowHash,ft as getHash,Ht as getHlcFunctions,Tt as getRowHash,vt as getRowInTableHash,pt as getTableHash,St as getTableInTablesHash,yt as getTablesHash,dt as getUniqueId,Lt as getValueHash,wt as getValueInValuesHash,bt as getValuesHash};
|
package/min/index.js.gz
CHANGED
|
Binary file
|