Spaces:
Sleeping
Sleeping
File size: 2,978 Bytes
6491ad4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 | "use strict";
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var query_exports = {};
__export(query_exports, {
useLiveQuery: () => useLiveQuery
});
module.exports = __toCommonJS(query_exports);
var import_expo_sqlite = require("expo-sqlite");
var import_react = require("react");
var import_entity = require("../entity.cjs");
var import_sql = require("../sql/sql.cjs");
var import_sqlite_core = require("../sqlite-core/index.cjs");
var import_query = require("../sqlite-core/query-builders/query.cjs");
var import_subquery = require("../subquery.cjs");
const useLiveQuery = (query, deps = []) => {
const [data, setData] = (0, import_react.useState)(
(0, import_entity.is)(query, import_query.SQLiteRelationalQuery) && query.mode === "first" ? void 0 : []
);
const [error, setError] = (0, import_react.useState)();
const [updatedAt, setUpdatedAt] = (0, import_react.useState)();
(0, import_react.useEffect)(() => {
const entity = (0, import_entity.is)(query, import_query.SQLiteRelationalQuery) ? query.table : query.config.table;
if ((0, import_entity.is)(entity, import_subquery.Subquery) || (0, import_entity.is)(entity, import_sql.SQL)) {
setError(new Error("Selecting from subqueries and SQL are not supported in useLiveQuery"));
return;
}
let listener;
const handleData = (data2) => {
setData(data2);
setUpdatedAt(/* @__PURE__ */ new Date());
};
query.then(handleData).catch(setError);
if ((0, import_entity.is)(entity, import_sqlite_core.SQLiteTable) || (0, import_entity.is)(entity, import_sqlite_core.SQLiteView)) {
const config = (0, import_entity.is)(entity, import_sqlite_core.SQLiteTable) ? (0, import_sqlite_core.getTableConfig)(entity) : (0, import_sqlite_core.getViewConfig)(entity);
listener = (0, import_expo_sqlite.addDatabaseChangeListener)(({ tableName }) => {
if (config.name === tableName) {
query.then(handleData).catch(setError);
}
});
}
return () => {
listener?.remove();
};
}, deps);
return {
data,
error,
updatedAt
};
};
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
useLiveQuery
});
//# sourceMappingURL=query.cjs.map |