@fctc/interface-logic 4.2.7 → 4.2.8
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/dist/environment.d.mts +1 -0
- package/dist/environment.d.ts +1 -0
- package/dist/hooks.d.mts +4 -1
- package/dist/hooks.d.ts +4 -1
- package/dist/hooks.js +374 -5
- package/dist/hooks.mjs +372 -5
- package/dist/import-snapshot-Ds0gqFFm.d.mts +3 -0
- package/dist/import-snapshot-Ds0gqFFm.d.ts +3 -0
- package/dist/provider.d.mts +4 -1
- package/dist/provider.d.ts +4 -1
- package/dist/provider.js +376 -7
- package/dist/provider.mjs +375 -7
- package/dist/services.d.mts +8 -1
- package/dist/services.d.ts +8 -1
- package/dist/services.js +367 -5
- package/dist/services.mjs +365 -5
- package/dist/store.js +2 -1
- package/dist/store.mjs +2 -1
- package/package.json +91 -90
package/dist/provider.mjs
CHANGED
|
@@ -63,7 +63,8 @@ var initialState2 = {
|
|
|
63
63
|
allowed_company_ids: [],
|
|
64
64
|
lang: "vi_VN",
|
|
65
65
|
tz: "Asia/Saigon"
|
|
66
|
-
}
|
|
66
|
+
},
|
|
67
|
+
isLocalMode: false
|
|
67
68
|
};
|
|
68
69
|
var envSlice = createSlice2({
|
|
69
70
|
name: "env",
|
|
@@ -2272,9 +2273,9 @@ function applyBinaryOp(ast, context) {
|
|
|
2272
2273
|
var DICT = {
|
|
2273
2274
|
get(...args) {
|
|
2274
2275
|
const { key, defValue } = parseArgs(args, ["key", "defValue"]);
|
|
2275
|
-
const
|
|
2276
|
-
if (key in
|
|
2277
|
-
return
|
|
2276
|
+
const self2 = this;
|
|
2277
|
+
if (key in self2) {
|
|
2278
|
+
return self2[key];
|
|
2278
2279
|
} else if (defValue !== void 0) {
|
|
2279
2280
|
return defValue;
|
|
2280
2281
|
}
|
|
@@ -5883,7 +5884,220 @@ var handleClosingSessionService = (env) => {
|
|
|
5883
5884
|
|
|
5884
5885
|
// src/services/pos-service/load-data-pos-session.ts
|
|
5885
5886
|
import { useCallback as useCallback31 } from "react";
|
|
5887
|
+
|
|
5888
|
+
// src/services/filesystem-service/file-service.ts
|
|
5889
|
+
import { Directory, Encoding, Filesystem } from "@capacitor/filesystem";
|
|
5890
|
+
var fileService = {
|
|
5891
|
+
async read(path) {
|
|
5892
|
+
try {
|
|
5893
|
+
const res = await Filesystem.readFile({
|
|
5894
|
+
path,
|
|
5895
|
+
directory: Directory.Data,
|
|
5896
|
+
encoding: Encoding.UTF8
|
|
5897
|
+
});
|
|
5898
|
+
if (typeof res.data === "string") return res.data;
|
|
5899
|
+
if (res.data instanceof Blob) return await res.data.text();
|
|
5900
|
+
return null;
|
|
5901
|
+
} catch {
|
|
5902
|
+
return null;
|
|
5903
|
+
}
|
|
5904
|
+
},
|
|
5905
|
+
async write(path, data) {
|
|
5906
|
+
await Filesystem.writeFile({
|
|
5907
|
+
path,
|
|
5908
|
+
data,
|
|
5909
|
+
directory: Directory.Data,
|
|
5910
|
+
encoding: Encoding.UTF8,
|
|
5911
|
+
recursive: true
|
|
5912
|
+
});
|
|
5913
|
+
},
|
|
5914
|
+
async writeAtomic(path, data) {
|
|
5915
|
+
const tempPath = path + ".tmp";
|
|
5916
|
+
await Filesystem.writeFile({
|
|
5917
|
+
path: tempPath,
|
|
5918
|
+
data,
|
|
5919
|
+
directory: Directory.Data,
|
|
5920
|
+
encoding: Encoding.UTF8,
|
|
5921
|
+
recursive: true
|
|
5922
|
+
});
|
|
5923
|
+
try {
|
|
5924
|
+
await Filesystem.deleteFile({
|
|
5925
|
+
path,
|
|
5926
|
+
directory: Directory.Data
|
|
5927
|
+
});
|
|
5928
|
+
} catch {
|
|
5929
|
+
}
|
|
5930
|
+
await Filesystem.rename({
|
|
5931
|
+
from: tempPath,
|
|
5932
|
+
to: path,
|
|
5933
|
+
directory: Directory.Data
|
|
5934
|
+
});
|
|
5935
|
+
},
|
|
5936
|
+
async delete(path) {
|
|
5937
|
+
try {
|
|
5938
|
+
await Filesystem.deleteFile({
|
|
5939
|
+
path,
|
|
5940
|
+
directory: Directory.Data
|
|
5941
|
+
});
|
|
5942
|
+
} catch {
|
|
5943
|
+
}
|
|
5944
|
+
},
|
|
5945
|
+
async exists(path) {
|
|
5946
|
+
try {
|
|
5947
|
+
await Filesystem.stat({
|
|
5948
|
+
path,
|
|
5949
|
+
directory: Directory.Data
|
|
5950
|
+
});
|
|
5951
|
+
return true;
|
|
5952
|
+
} catch {
|
|
5953
|
+
return false;
|
|
5954
|
+
}
|
|
5955
|
+
},
|
|
5956
|
+
async mkdir(path) {
|
|
5957
|
+
try {
|
|
5958
|
+
await Filesystem.mkdir({
|
|
5959
|
+
path,
|
|
5960
|
+
directory: Directory.Data,
|
|
5961
|
+
recursive: true
|
|
5962
|
+
});
|
|
5963
|
+
} catch (e) {
|
|
5964
|
+
if (!String(e?.message).includes("Exists")) {
|
|
5965
|
+
throw e;
|
|
5966
|
+
}
|
|
5967
|
+
}
|
|
5968
|
+
},
|
|
5969
|
+
async list(path) {
|
|
5970
|
+
return Filesystem.readdir({
|
|
5971
|
+
path,
|
|
5972
|
+
directory: Directory.Data
|
|
5973
|
+
});
|
|
5974
|
+
},
|
|
5975
|
+
async getUri(path) {
|
|
5976
|
+
return Filesystem.getUri({
|
|
5977
|
+
path,
|
|
5978
|
+
directory: Directory.Data
|
|
5979
|
+
});
|
|
5980
|
+
}
|
|
5981
|
+
};
|
|
5982
|
+
|
|
5983
|
+
// src/services/filesystem-service/json-worker.ts
|
|
5984
|
+
self.addEventListener("message", async (ev) => {
|
|
5985
|
+
const { id, cmd, payload } = ev.data;
|
|
5986
|
+
try {
|
|
5987
|
+
if (cmd === "parse") {
|
|
5988
|
+
const parsed = JSON.parse(payload);
|
|
5989
|
+
self.postMessage({ id, ok: true, result: parsed });
|
|
5990
|
+
} else if (cmd === "stringify") {
|
|
5991
|
+
const str = JSON.stringify(payload);
|
|
5992
|
+
self.postMessage({ id, ok: true, result: str });
|
|
5993
|
+
}
|
|
5994
|
+
} catch (err) {
|
|
5995
|
+
self.postMessage({ id, ok: false, error: err?.message || String(err) });
|
|
5996
|
+
}
|
|
5997
|
+
});
|
|
5998
|
+
function spawnParseWorker(raw) {
|
|
5999
|
+
return new Promise((resolve, reject) => {
|
|
6000
|
+
const worker = new Worker(new URL("./json-worker.ts", import.meta.url), {
|
|
6001
|
+
type: "module"
|
|
6002
|
+
});
|
|
6003
|
+
const id = Math.random().toString(36).slice(2);
|
|
6004
|
+
worker.onmessage = (ev) => {
|
|
6005
|
+
const { ok, result, error } = ev.data;
|
|
6006
|
+
if (ok) {
|
|
6007
|
+
resolve(result);
|
|
6008
|
+
} else {
|
|
6009
|
+
reject(new Error(error));
|
|
6010
|
+
}
|
|
6011
|
+
worker.terminate();
|
|
6012
|
+
};
|
|
6013
|
+
worker.postMessage({ id, cmd: "parse", payload: raw });
|
|
6014
|
+
});
|
|
6015
|
+
}
|
|
6016
|
+
function spawnStringifyWorker(obj) {
|
|
6017
|
+
return new Promise((resolve, reject) => {
|
|
6018
|
+
const worker = new Worker(new URL("./json-worker.ts", import.meta.url), {
|
|
6019
|
+
type: "module"
|
|
6020
|
+
});
|
|
6021
|
+
worker.onmessage = (ev) => {
|
|
6022
|
+
const { ok, result, error } = ev.data;
|
|
6023
|
+
if (ok) resolve(result);
|
|
6024
|
+
else reject(new Error(error));
|
|
6025
|
+
worker.terminate();
|
|
6026
|
+
};
|
|
6027
|
+
worker.postMessage({ cmd: "stringify", payload: obj });
|
|
6028
|
+
});
|
|
6029
|
+
}
|
|
6030
|
+
|
|
6031
|
+
// src/services/filesystem-service/memory-cache.ts
|
|
6032
|
+
var MemoryCache = class {
|
|
6033
|
+
map = /* @__PURE__ */ new Map();
|
|
6034
|
+
get(k) {
|
|
6035
|
+
const e = this.map.get(k);
|
|
6036
|
+
if (!e) return null;
|
|
6037
|
+
if (e.ttl && Date.now() - e.t > e.ttl) {
|
|
6038
|
+
this.map.delete(k);
|
|
6039
|
+
return null;
|
|
6040
|
+
}
|
|
6041
|
+
return e.value;
|
|
6042
|
+
}
|
|
6043
|
+
set(k, v, ttl = 5 * 60 * 1e3) {
|
|
6044
|
+
this.map.set(k, { value: v, t: Date.now(), ttl });
|
|
6045
|
+
}
|
|
6046
|
+
del(k) {
|
|
6047
|
+
this.map.delete(k);
|
|
6048
|
+
}
|
|
6049
|
+
clear() {
|
|
6050
|
+
this.map.clear();
|
|
6051
|
+
}
|
|
6052
|
+
};
|
|
6053
|
+
var memoryCache = new MemoryCache();
|
|
6054
|
+
|
|
6055
|
+
// src/services/filesystem-service/model-loader.ts
|
|
6056
|
+
var MODELS_DIR = "pos/models";
|
|
6057
|
+
var MODELS_META_DIR = "pos/models_meta";
|
|
6058
|
+
async function loadData(includeMeta = true) {
|
|
6059
|
+
const listResult = await fileService.list(MODELS_DIR);
|
|
6060
|
+
if (!listResult || !Array.isArray(listResult.files)) {
|
|
6061
|
+
return {};
|
|
6062
|
+
}
|
|
6063
|
+
const result = {};
|
|
6064
|
+
for (const file of listResult.files) {
|
|
6065
|
+
if (file.type !== "file") continue;
|
|
6066
|
+
if (!file.name.endsWith(".json")) continue;
|
|
6067
|
+
const fileName = file.name;
|
|
6068
|
+
const modelName = fileName.replace(/\.json$/, "");
|
|
6069
|
+
const dataPath = `${MODELS_DIR}/${fileName}`;
|
|
6070
|
+
const metaPath = `${MODELS_META_DIR}/${encodeURIComponent(
|
|
6071
|
+
modelName
|
|
6072
|
+
)}.meta.json`;
|
|
6073
|
+
const rawData = await fileService.read(dataPath);
|
|
6074
|
+
if (!rawData) continue;
|
|
6075
|
+
const parsedData = await spawnParseWorker(rawData);
|
|
6076
|
+
const data = Array.isArray(parsedData) ? parsedData : [];
|
|
6077
|
+
if (!includeMeta) {
|
|
6078
|
+
result[modelName] = { data };
|
|
6079
|
+
continue;
|
|
6080
|
+
}
|
|
6081
|
+
const rawMeta = await fileService.read(metaPath);
|
|
6082
|
+
let fields = [];
|
|
6083
|
+
let relations = {};
|
|
6084
|
+
if (rawMeta) {
|
|
6085
|
+
const parsedMeta = await spawnParseWorker(rawMeta);
|
|
6086
|
+
fields = parsedMeta?.fields ?? [];
|
|
6087
|
+
relations = parsedMeta?.relations ?? {};
|
|
6088
|
+
}
|
|
6089
|
+
result[modelName] = {
|
|
6090
|
+
data,
|
|
6091
|
+
fields,
|
|
6092
|
+
relations
|
|
6093
|
+
};
|
|
6094
|
+
}
|
|
6095
|
+
return result;
|
|
6096
|
+
}
|
|
6097
|
+
|
|
6098
|
+
// src/services/pos-service/load-data-pos-session.ts
|
|
5886
6099
|
var loadDataPosSessionService = (env) => {
|
|
6100
|
+
const isLocalMode = env?.isLocalMode;
|
|
5887
6101
|
const loadDataPosSession = useCallback31(
|
|
5888
6102
|
({
|
|
5889
6103
|
model,
|
|
@@ -5894,6 +6108,9 @@ var loadDataPosSessionService = (env) => {
|
|
|
5894
6108
|
modelsToLoad = [],
|
|
5895
6109
|
searchParams
|
|
5896
6110
|
}) => {
|
|
6111
|
+
if (isLocalMode) {
|
|
6112
|
+
return loadData();
|
|
6113
|
+
}
|
|
5897
6114
|
const jsonData = {
|
|
5898
6115
|
model,
|
|
5899
6116
|
method: "load_data" /* LOAD_DATA */,
|
|
@@ -5920,7 +6137,7 @@ var loadDataPosSessionService = (env) => {
|
|
|
5920
6137
|
service
|
|
5921
6138
|
);
|
|
5922
6139
|
},
|
|
5923
|
-
[env]
|
|
6140
|
+
[env, isLocalMode]
|
|
5924
6141
|
);
|
|
5925
6142
|
return {
|
|
5926
6143
|
loadDataPosSession
|
|
@@ -6253,6 +6470,145 @@ var usePosService = () => {
|
|
|
6253
6470
|
return service;
|
|
6254
6471
|
};
|
|
6255
6472
|
|
|
6473
|
+
// src/services/filesystem-service/manifest.ts
|
|
6474
|
+
var MANIFEST_PATH = "pos/manifest.json";
|
|
6475
|
+
var MANIFEST_BAK_PATH = "pos/manifest.bak.json";
|
|
6476
|
+
async function writeManifest(manifest) {
|
|
6477
|
+
const oldRaw = await fileService.read(MANIFEST_PATH);
|
|
6478
|
+
if (oldRaw !== null) {
|
|
6479
|
+
await fileService.writeAtomic(MANIFEST_BAK_PATH, oldRaw);
|
|
6480
|
+
}
|
|
6481
|
+
await fileService.writeAtomic(MANIFEST_PATH, JSON.stringify(manifest));
|
|
6482
|
+
try {
|
|
6483
|
+
await fileService.delete(MANIFEST_BAK_PATH);
|
|
6484
|
+
} catch {
|
|
6485
|
+
}
|
|
6486
|
+
}
|
|
6487
|
+
|
|
6488
|
+
// src/services/filesystem-service/import-snapshot.ts
|
|
6489
|
+
var DATA_DIR = "pos";
|
|
6490
|
+
var MODELS_DIR2 = `${DATA_DIR}/models`;
|
|
6491
|
+
var MODELS_META_DIR2 = `${DATA_DIR}/models_meta`;
|
|
6492
|
+
var importSnapshot = async ({ data, onProgress }) => {
|
|
6493
|
+
onProgress?.(1, "Parsing snapshot");
|
|
6494
|
+
const parsed = await spawnParseWorker(data);
|
|
6495
|
+
const modelNames = Object.keys(parsed);
|
|
6496
|
+
const total = modelNames.length;
|
|
6497
|
+
const manifest = { version: (/* @__PURE__ */ new Date()).toISOString(), models: {} };
|
|
6498
|
+
const TMP_PREFIX = `pos/data/tmp_import_${Date.now()}`;
|
|
6499
|
+
await fileService.writeAtomic(`${TMP_PREFIX}/.marker`, "1");
|
|
6500
|
+
let i = 0;
|
|
6501
|
+
for (const model of modelNames) {
|
|
6502
|
+
i++;
|
|
6503
|
+
onProgress?.(
|
|
6504
|
+
Math.round(i / total * 100),
|
|
6505
|
+
`Processing ${model} (${i}/${total})`
|
|
6506
|
+
);
|
|
6507
|
+
const block = parsed[model];
|
|
6508
|
+
const dataPart = block?.data ?? block ?? [];
|
|
6509
|
+
const fields = block?.fields ?? [];
|
|
6510
|
+
const relations = block?.relations ?? {};
|
|
6511
|
+
const serialized = await spawnStringifyWorker(dataPart);
|
|
6512
|
+
const tmpModelPath = `${TMP_PREFIX}/${encodeURIComponent(model)}.json`;
|
|
6513
|
+
await fileService.writeAtomic(tmpModelPath, serialized);
|
|
6514
|
+
const meta = {
|
|
6515
|
+
fields,
|
|
6516
|
+
relations,
|
|
6517
|
+
count: Array.isArray(dataPart) ? dataPart.length : 0,
|
|
6518
|
+
writtenAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
6519
|
+
};
|
|
6520
|
+
const tmpMetaPath = `${TMP_PREFIX}/${encodeURIComponent(model)}.meta.json`;
|
|
6521
|
+
await fileService.writeAtomic(tmpMetaPath, JSON.stringify(meta));
|
|
6522
|
+
manifest.models[model] = {
|
|
6523
|
+
file: `${MODELS_DIR2}/${encodeURIComponent(model)}.json`,
|
|
6524
|
+
metaFile: `${MODELS_META_DIR2}/${encodeURIComponent(model)}.meta.json`,
|
|
6525
|
+
count: meta.count,
|
|
6526
|
+
updatedAt: meta.writtenAt
|
|
6527
|
+
};
|
|
6528
|
+
}
|
|
6529
|
+
onProgress?.(95, "Committing import (moving files)");
|
|
6530
|
+
for (const model of modelNames) {
|
|
6531
|
+
const tmpModelPath = `${TMP_PREFIX}/${encodeURIComponent(model)}.json`;
|
|
6532
|
+
const finalModelPath = `${MODELS_DIR2}/${encodeURIComponent(model)}.json`;
|
|
6533
|
+
const tmpMetaPath = `${TMP_PREFIX}/${encodeURIComponent(model)}.meta.json`;
|
|
6534
|
+
const finalMetaPath = `${MODELS_META_DIR2}/${encodeURIComponent(
|
|
6535
|
+
model
|
|
6536
|
+
)}.meta.json`;
|
|
6537
|
+
const tmpRaw = await fileService.read(tmpModelPath);
|
|
6538
|
+
if (tmpRaw !== null) await fileService.writeAtomic(finalModelPath, tmpRaw);
|
|
6539
|
+
const tmpMetaRaw = await fileService.read(tmpMetaPath);
|
|
6540
|
+
if (tmpMetaRaw !== null)
|
|
6541
|
+
await fileService.writeAtomic(finalMetaPath, tmpMetaRaw);
|
|
6542
|
+
onProgress?.(
|
|
6543
|
+
95 + Math.round(
|
|
6544
|
+
(Object.keys(manifest.models).indexOf(model) + 1) / modelNames.length * 5
|
|
6545
|
+
),
|
|
6546
|
+
`Committed ${model}`
|
|
6547
|
+
);
|
|
6548
|
+
}
|
|
6549
|
+
await writeManifest(manifest);
|
|
6550
|
+
try {
|
|
6551
|
+
for (const model of modelNames) {
|
|
6552
|
+
await fileService.delete(
|
|
6553
|
+
`${TMP_PREFIX}/${encodeURIComponent(model)}.json`
|
|
6554
|
+
);
|
|
6555
|
+
await fileService.delete(
|
|
6556
|
+
`${TMP_PREFIX}/${encodeURIComponent(model)}.meta.json`
|
|
6557
|
+
);
|
|
6558
|
+
}
|
|
6559
|
+
await fileService.delete(`${TMP_PREFIX}/.marker`);
|
|
6560
|
+
} catch (e) {
|
|
6561
|
+
console.log("Failed to cleanup tmp import files:", e);
|
|
6562
|
+
}
|
|
6563
|
+
onProgress?.(100, "Import complete");
|
|
6564
|
+
return manifest;
|
|
6565
|
+
};
|
|
6566
|
+
var import_snapshot_default = importSnapshot;
|
|
6567
|
+
|
|
6568
|
+
// src/services/filesystem-service/init-snapshot.ts
|
|
6569
|
+
var isSnapshotReady = async () => {
|
|
6570
|
+
try {
|
|
6571
|
+
const raw = await fileService.read("pos/manifest.json");
|
|
6572
|
+
if (!raw) return false;
|
|
6573
|
+
const manifest = JSON.parse(raw);
|
|
6574
|
+
if (!manifest.models || typeof manifest.models !== "object") {
|
|
6575
|
+
return false;
|
|
6576
|
+
}
|
|
6577
|
+
const modelEntries = Object.values(manifest.models);
|
|
6578
|
+
if (modelEntries.length === 0) return false;
|
|
6579
|
+
const firstModel = modelEntries[0];
|
|
6580
|
+
if (!firstModel.file) return false;
|
|
6581
|
+
const modelExists = await fileService.exists(firstModel.file);
|
|
6582
|
+
return modelExists;
|
|
6583
|
+
} catch {
|
|
6584
|
+
return false;
|
|
6585
|
+
}
|
|
6586
|
+
};
|
|
6587
|
+
async function initSnapshot(onProgress) {
|
|
6588
|
+
const ready = await isSnapshotReady();
|
|
6589
|
+
if (ready) {
|
|
6590
|
+
console.log("skip initialization.");
|
|
6591
|
+
return;
|
|
6592
|
+
}
|
|
6593
|
+
console.log("initializing from data.json...");
|
|
6594
|
+
const jsonData = await fetch("/data.json").then((r) => r.text());
|
|
6595
|
+
if (!jsonData) {
|
|
6596
|
+
console.error("cannot load data.json");
|
|
6597
|
+
return;
|
|
6598
|
+
}
|
|
6599
|
+
await import_snapshot_default({
|
|
6600
|
+
data: jsonData,
|
|
6601
|
+
onProgress
|
|
6602
|
+
});
|
|
6603
|
+
}
|
|
6604
|
+
|
|
6605
|
+
// src/services/filesystem-service/index.ts
|
|
6606
|
+
var useFileSystemService = () => {
|
|
6607
|
+
return {
|
|
6608
|
+
initSnapshot
|
|
6609
|
+
};
|
|
6610
|
+
};
|
|
6611
|
+
|
|
6256
6612
|
// src/provider/version-gate-provider.tsx
|
|
6257
6613
|
import { Fragment, jsx as jsx4 } from "react/jsx-runtime";
|
|
6258
6614
|
var VersionGate = ({ children }) => {
|
|
@@ -6640,7 +6996,8 @@ var initialEnvState = {
|
|
|
6640
6996
|
lang: "vi_VN",
|
|
6641
6997
|
tz: "Asia/Saigon"
|
|
6642
6998
|
},
|
|
6643
|
-
excludeLanguages: []
|
|
6999
|
+
excludeLanguages: [],
|
|
7000
|
+
isLocalMode: false
|
|
6644
7001
|
};
|
|
6645
7002
|
var EnvContext = createContext(null);
|
|
6646
7003
|
function EnvProvider({
|
|
@@ -8723,6 +9080,16 @@ var useUpdateOrderStatus = () => {
|
|
|
8723
9080
|
};
|
|
8724
9081
|
var use_update_order_status_default = useUpdateOrderStatus;
|
|
8725
9082
|
|
|
9083
|
+
// src/hooks/pos/use-init-snapshot.ts
|
|
9084
|
+
import { useMutation as useMutation86 } from "@tanstack/react-query";
|
|
9085
|
+
var useInitSnapshot = () => {
|
|
9086
|
+
const fileSystem = useFileSystemService();
|
|
9087
|
+
return useMutation86({
|
|
9088
|
+
mutationFn: fileSystem.initSnapshot
|
|
9089
|
+
});
|
|
9090
|
+
};
|
|
9091
|
+
var use_init_snapshot_default = useInitSnapshot;
|
|
9092
|
+
|
|
8726
9093
|
// src/provider/service-provider.tsx
|
|
8727
9094
|
import { jsx as jsx6 } from "react/jsx-runtime";
|
|
8728
9095
|
var ServiceContext = createContext2(null);
|
|
@@ -8841,7 +9208,8 @@ var ServiceProvider = ({
|
|
|
8841
9208
|
useGetCity: use_get_city_default,
|
|
8842
9209
|
useGetWard: use_get_ward_default,
|
|
8843
9210
|
useGetCountry: use_get_country_default,
|
|
8844
|
-
useGetPartnerTitle: use_get_partner_title_default
|
|
9211
|
+
useGetPartnerTitle: use_get_partner_title_default,
|
|
9212
|
+
useInitSnapshot: use_init_snapshot_default
|
|
8845
9213
|
};
|
|
8846
9214
|
return /* @__PURE__ */ jsx6(ServiceContext.Provider, { value: services, children });
|
|
8847
9215
|
};
|
package/dist/services.d.mts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { C as ContextApi, L as LoginCredentialBody, R as ResetPasswordRequest, U as UpdatePasswordRequest, T as TThreadData, h as GetExternalTab, b as GetListParams, a as GetDetailParams, S as SaveParams, D as DeleteParams, O as OnChangeParams, V as ViewData, f as GetViewParams, c as GetSelectionType } from './view-type-CfcWWR0w.mjs';
|
|
2
|
+
import { P as ProgressCb } from './import-snapshot-Ds0gqFFm.mjs';
|
|
2
3
|
|
|
3
4
|
declare function useActionService(): {
|
|
4
5
|
loadAction: ({ idAction, context, service, xNode, searchParams, }: {
|
|
@@ -611,4 +612,10 @@ type MergedService = UnionToIntersection<ServiceReturn<ServiceFactories>>;
|
|
|
611
612
|
type UnionToIntersection<U> = (U extends any ? (k: U) => void : never) extends (k: infer I) => void ? I : never;
|
|
612
613
|
declare const usePosService: () => MergedService;
|
|
613
614
|
|
|
614
|
-
|
|
615
|
+
declare function initSnapshot(onProgress?: ProgressCb): Promise<void>;
|
|
616
|
+
|
|
617
|
+
declare const useFileSystemService: () => {
|
|
618
|
+
initSnapshot: typeof initSnapshot;
|
|
619
|
+
};
|
|
620
|
+
|
|
621
|
+
export { useActionService, useAuthService, useCompanyService, useDashboardService, useExcelService, useFileSystemService, useFormService, useKanbanService, useModelService, usePosService, useUserService, useViewService };
|
package/dist/services.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { C as ContextApi, L as LoginCredentialBody, R as ResetPasswordRequest, U as UpdatePasswordRequest, T as TThreadData, h as GetExternalTab, b as GetListParams, a as GetDetailParams, S as SaveParams, D as DeleteParams, O as OnChangeParams, V as ViewData, f as GetViewParams, c as GetSelectionType } from './view-type-CfcWWR0w.js';
|
|
2
|
+
import { P as ProgressCb } from './import-snapshot-Ds0gqFFm.js';
|
|
2
3
|
|
|
3
4
|
declare function useActionService(): {
|
|
4
5
|
loadAction: ({ idAction, context, service, xNode, searchParams, }: {
|
|
@@ -611,4 +612,10 @@ type MergedService = UnionToIntersection<ServiceReturn<ServiceFactories>>;
|
|
|
611
612
|
type UnionToIntersection<U> = (U extends any ? (k: U) => void : never) extends (k: infer I) => void ? I : never;
|
|
612
613
|
declare const usePosService: () => MergedService;
|
|
613
614
|
|
|
614
|
-
|
|
615
|
+
declare function initSnapshot(onProgress?: ProgressCb): Promise<void>;
|
|
616
|
+
|
|
617
|
+
declare const useFileSystemService: () => {
|
|
618
|
+
initSnapshot: typeof initSnapshot;
|
|
619
|
+
};
|
|
620
|
+
|
|
621
|
+
export { useActionService, useAuthService, useCompanyService, useDashboardService, useExcelService, useFileSystemService, useFormService, useKanbanService, useModelService, usePosService, useUserService, useViewService };
|