@elqnt/kg 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs ADDED
@@ -0,0 +1,414 @@
1
+ // consts.ts
2
+ var Test = "hi";
3
+
4
+ // hooks/use-knowledge-graph.ts
5
+ import { useUserContext } from "@elqnt/auth";
6
+ import { useNatsContext } from "@elqnt/nats";
7
+ import { useEffect, useState } from "react";
8
+ var useKnowledgeGraph = (overrideOrgId) => {
9
+ const { selectedOrgId } = useUserContext();
10
+ const [isLoading, setIsLoading] = useState(false);
11
+ const { natsConnected, request } = useNatsContext();
12
+ const [selectedNodeId, setSelectedNodeId] = useState(
13
+ void 0
14
+ );
15
+ const orgId = overrideOrgId ?? selectedOrgId;
16
+ const [labels, setLabels] = useState(void 0);
17
+ const [selectedLabel, setSelectedLabel] = useState(
18
+ void 0
19
+ );
20
+ const [queryResult, setQueryResult] = useState(
21
+ void 0
22
+ );
23
+ const [stateTrigger, setStateTrigger] = useState(0);
24
+ async function ingestNode(node) {
25
+ if (!orgId) {
26
+ return new Error("No orgId provided");
27
+ }
28
+ if (!natsConnected) {
29
+ return new Error("Not connected to NATS");
30
+ }
31
+ setIsLoading(true);
32
+ const data = await request(
33
+ "kg.ingest.node",
34
+ node,
35
+ {
36
+ orgId
37
+ }
38
+ );
39
+ setIsLoading(false);
40
+ if (data instanceof Error) {
41
+ console.error(data);
42
+ return data;
43
+ }
44
+ return data;
45
+ }
46
+ async function ingestNodes(nodes) {
47
+ if (!orgId) {
48
+ return new Error("No orgId provided");
49
+ }
50
+ if (!natsConnected) {
51
+ return new Error("Not connected to NATS");
52
+ }
53
+ setIsLoading(true);
54
+ const data = await request(
55
+ "kg.ingest.nodes",
56
+ nodes,
57
+ {
58
+ orgId
59
+ }
60
+ );
61
+ setIsLoading(false);
62
+ if (data instanceof Error) {
63
+ console.error(data);
64
+ return data;
65
+ }
66
+ return data;
67
+ }
68
+ async function updateNode(nodeId, label, fields) {
69
+ const nodeRequest = {
70
+ label,
71
+ keyField: "id",
72
+ fields: {
73
+ ...fields,
74
+ id: nodeId
75
+ },
76
+ duplicatePolicy: "replace"
77
+ };
78
+ const result = await ingestNode(nodeRequest);
79
+ if (!(result instanceof Error)) {
80
+ setTimeout(() => {
81
+ optimizeGraph().catch(
82
+ (err) => console.error("Failed to optimize graph after node update:", err)
83
+ );
84
+ }, 2e3);
85
+ }
86
+ return result;
87
+ }
88
+ async function optimizeGraph() {
89
+ if (!orgId) {
90
+ return new Error("No orgId provided");
91
+ }
92
+ if (!natsConnected) {
93
+ return new Error("Not connected to NATS");
94
+ }
95
+ const data = await request(
96
+ "kg.graph.optimize",
97
+ {},
98
+ {
99
+ orgId
100
+ }
101
+ );
102
+ if (data instanceof Error) {
103
+ console.error("Graph optimization failed:", data);
104
+ return data;
105
+ }
106
+ console.log("Graph optimized successfully");
107
+ return data;
108
+ }
109
+ async function ingestDocs(urls, mode, brief, labels2) {
110
+ if (!orgId) {
111
+ return new Error("No orgId provided");
112
+ }
113
+ if (!natsConnected) {
114
+ return new Error("Not connected to NATS");
115
+ }
116
+ setIsLoading(true);
117
+ const data = await request(
118
+ "docs.kg.ingest",
119
+ { urls, mode, brief, labels: labels2 },
120
+ {
121
+ orgId
122
+ }
123
+ );
124
+ setIsLoading(false);
125
+ if (data instanceof Error) {
126
+ console.error(data);
127
+ return data;
128
+ }
129
+ return data;
130
+ }
131
+ async function ingestText(text, mode) {
132
+ if (!orgId) {
133
+ return new Error("No orgId provided");
134
+ }
135
+ if (!natsConnected) {
136
+ return new Error("Not connected to NATS");
137
+ }
138
+ setIsLoading(true);
139
+ const data = await request(
140
+ "docs.kg.ingestText",
141
+ { text, mode },
142
+ {
143
+ orgId
144
+ }
145
+ );
146
+ setIsLoading(false);
147
+ if (data instanceof Error) {
148
+ console.error(data);
149
+ return data;
150
+ }
151
+ return data;
152
+ }
153
+ async function ingestYT(url) {
154
+ if (!orgId) {
155
+ return new Error("No orgId provided");
156
+ }
157
+ if (!natsConnected) {
158
+ return new Error("Not connected to NATS");
159
+ }
160
+ setIsLoading(true);
161
+ const data = await request(
162
+ "docs.kg.ingestYT",
163
+ { url },
164
+ {
165
+ orgId
166
+ }
167
+ );
168
+ setIsLoading(false);
169
+ if (data instanceof Error) {
170
+ console.error(data);
171
+ return data;
172
+ }
173
+ return data;
174
+ }
175
+ async function queryGraph(query) {
176
+ if (!orgId) {
177
+ throw new Error("No orgId provided");
178
+ }
179
+ if (!natsConnected) {
180
+ throw new Error("Not connected to NATS");
181
+ }
182
+ setIsLoading(true);
183
+ const data = await request(
184
+ "kg.query.graph",
185
+ query,
186
+ {
187
+ orgId
188
+ }
189
+ );
190
+ setIsLoading(false);
191
+ if (data instanceof Error) {
192
+ console.error(data);
193
+ return data;
194
+ }
195
+ return data;
196
+ }
197
+ async function getNodeById(id) {
198
+ if (!orgId) {
199
+ return new Error("No orgId provided");
200
+ }
201
+ if (!natsConnected) {
202
+ return new Error("Not connected to NATS");
203
+ }
204
+ const data = await request(
205
+ "kg.query.nodeById",
206
+ { id },
207
+ { orgId }
208
+ );
209
+ if (data instanceof Error) {
210
+ console.error(data);
211
+ return data;
212
+ }
213
+ return data;
214
+ }
215
+ async function getGraphLabels() {
216
+ if (!orgId) {
217
+ return new Error("No orgId provided");
218
+ }
219
+ if (!natsConnected) {
220
+ return new Error("Not connected to NATS");
221
+ }
222
+ setIsLoading(true);
223
+ const data = await request(
224
+ "kg.graph.labels",
225
+ {},
226
+ { orgId }
227
+ );
228
+ setIsLoading(false);
229
+ if (data instanceof Error) {
230
+ console.error(data);
231
+ return data;
232
+ }
233
+ if (!Array.isArray(data) && typeof data === "object") {
234
+ const err = data;
235
+ return new Error(err?.message ?? err?.error ?? err);
236
+ }
237
+ return data;
238
+ }
239
+ useEffect(() => {
240
+ if (!natsConnected || !orgId) {
241
+ return;
242
+ }
243
+ async function getLabels() {
244
+ const data = await getGraphLabels();
245
+ if (data instanceof Error) {
246
+ return [];
247
+ }
248
+ setLabels(data);
249
+ return data;
250
+ }
251
+ getLabels();
252
+ }, [natsConnected, orgId, stateTrigger]);
253
+ useEffect(() => {
254
+ if (!natsConnected || !orgId || !selectedLabel) {
255
+ return;
256
+ }
257
+ async function getGraphQueryResult() {
258
+ if (!selectedLabel) return;
259
+ console.log("will getGraphQueryResult", { orgId, selectedLabel });
260
+ const query = {
261
+ label: selectedLabel,
262
+ fields: [],
263
+ limit: 500,
264
+ sortBy: "",
265
+ sortOrder: "asc",
266
+ // edges: [{ label: "student of", direction: "outgoing" }],
267
+ depth: 2
268
+ };
269
+ const res = await queryGraph(query);
270
+ if (res instanceof Error) {
271
+ console.error(res);
272
+ return;
273
+ }
274
+ setQueryResult(res);
275
+ console.log("graph query response ", {
276
+ nodesCount: res.nodes?.length,
277
+ edgesCount: res.edges?.length
278
+ });
279
+ }
280
+ getGraphQueryResult();
281
+ }, [natsConnected, orgId, selectedLabel, stateTrigger]);
282
+ function refreshState() {
283
+ setStateTrigger(stateTrigger + 1);
284
+ }
285
+ return {
286
+ isLoading,
287
+ ingestNode,
288
+ ingestNodes,
289
+ updateNode,
290
+ queryGraph,
291
+ getNodeById,
292
+ getGraphLabels,
293
+ labels,
294
+ selectedLabel,
295
+ setSelectedLabel,
296
+ queryResult,
297
+ setQueryResult,
298
+ refreshState,
299
+ ingestDocs,
300
+ ingestText,
301
+ selectedNodeId,
302
+ setSelectedNodeId,
303
+ ingestYT
304
+ };
305
+ };
306
+
307
+ // hooks/use-knowledge-graph-analytics.ts
308
+ import { useNatsContext as useNatsContext2 } from "@elqnt/nats";
309
+ import { useUserContext as useUserContext2 } from "@elqnt/auth";
310
+ import { useState as useState2 } from "react";
311
+ var useKnowledgeGraphAnalytics = (overrideOrgId) => {
312
+ const { selectedOrgId } = useUserContext2();
313
+ const [isLoading, setIsLoading] = useState2(false);
314
+ const { natsConnected, request } = useNatsContext2();
315
+ return {
316
+ isLoading
317
+ };
318
+ };
319
+
320
+ // models/kg.ts
321
+ var DuplicatePolicyCreateIf = "createIfNotExist";
322
+ var DuplicatePolicyIgnore = "ignore";
323
+ var DuplicatePolicyReplace = "replace";
324
+ var DuplicatePolicyFail = "fail";
325
+ var DuplicatePolicyCreate = "create";
326
+ var KGFieldQueryOperatorEqual = "eq";
327
+ var KGFieldQueryOperatorNotEqual = "neq";
328
+ var KGFieldQueryOperatorGreater = "gt";
329
+ var KGFieldQueryOperatorLess = "lt";
330
+ var KGFieldQueryOperatorGreaterOrEqual = "gte";
331
+ var KGFieldQueryOperatorLessOrEqual = "lte";
332
+ var KGFieldQueryOperatorLike = "like";
333
+ var KGFieldQueryOperatorSimilar = "similar";
334
+ var KGFieldQueryOperatorIn = "in";
335
+ var KGFieldQueryOperatorArrayContains = "arrayContains";
336
+ var KGRelationshipDirectionIncoming = "incoming";
337
+ var KGRelationshipDirectionOutgoing = "outgoing";
338
+
339
+ // models/kg-designer.ts
340
+ var KGDesignerNodeCreate = "kg.designer.node.create";
341
+ var KGDesignerNodeUpdate = "kg.designer.node.update.*";
342
+ var KGDesignerNodeDelete = "kg.designer.node.delete.*";
343
+ var KGDesignerNodeGet = "kg.designer.node.get.*";
344
+ var KGDesignerNodeList = "kg.designer.node.list";
345
+ var KGDesignerEdgeCreate = "kg.designer.edge.create";
346
+ var KGDesignerEdgeUpdate = "kg.designer.edge.update.*";
347
+ var KGDesignerEdgeDelete = "kg.designer.edge.delete.*";
348
+ var KGDesignerEdgeGet = "kg.designer.edge.get.*";
349
+ var KGDesignerEdgeList = "kg.designer.edge.list";
350
+ var KGDBCreate = "kg.db.create";
351
+ var KGDocumentDelete = "kg_ingest.document.delete";
352
+ var KGSyncJobUpdate = "kg.sync.job.update";
353
+ var KGSyncJobList = "kg.sync.job.list";
354
+ var KGGraphOptimize = "kg.graph.optimize";
355
+
356
+ // state/knowledge-graph-context.tsx
357
+ import { createContext, useContext } from "react";
358
+ import { jsx } from "react/jsx-runtime";
359
+ var KnowledgeGraphContext = createContext(void 0);
360
+ function KnowledgeGraphContextProvider(props) {
361
+ const { children, overrideOrgId } = props;
362
+ const useKG = useKnowledgeGraph(overrideOrgId);
363
+ return /* @__PURE__ */ jsx(KnowledgeGraphContext.Provider, { value: useKG, children });
364
+ }
365
+ var useKnowledgeGraphContext = () => {
366
+ const context = useContext(KnowledgeGraphContext);
367
+ if (context === void 0) {
368
+ throw new Error(
369
+ "useKnowledgeGraphContext must be used within a KnowledgeGraphContextProvider"
370
+ );
371
+ }
372
+ return context;
373
+ };
374
+ export {
375
+ DuplicatePolicyCreate,
376
+ DuplicatePolicyCreateIf,
377
+ DuplicatePolicyFail,
378
+ DuplicatePolicyIgnore,
379
+ DuplicatePolicyReplace,
380
+ KGDBCreate,
381
+ KGDesignerEdgeCreate,
382
+ KGDesignerEdgeDelete,
383
+ KGDesignerEdgeGet,
384
+ KGDesignerEdgeList,
385
+ KGDesignerEdgeUpdate,
386
+ KGDesignerNodeCreate,
387
+ KGDesignerNodeDelete,
388
+ KGDesignerNodeGet,
389
+ KGDesignerNodeList,
390
+ KGDesignerNodeUpdate,
391
+ KGDocumentDelete,
392
+ KGFieldQueryOperatorArrayContains,
393
+ KGFieldQueryOperatorEqual,
394
+ KGFieldQueryOperatorGreater,
395
+ KGFieldQueryOperatorGreaterOrEqual,
396
+ KGFieldQueryOperatorIn,
397
+ KGFieldQueryOperatorLess,
398
+ KGFieldQueryOperatorLessOrEqual,
399
+ KGFieldQueryOperatorLike,
400
+ KGFieldQueryOperatorNotEqual,
401
+ KGFieldQueryOperatorSimilar,
402
+ KGGraphOptimize,
403
+ KGRelationshipDirectionIncoming,
404
+ KGRelationshipDirectionOutgoing,
405
+ KGSyncJobList,
406
+ KGSyncJobUpdate,
407
+ KnowledgeGraphContext,
408
+ KnowledgeGraphContextProvider,
409
+ Test,
410
+ useKnowledgeGraph,
411
+ useKnowledgeGraphAnalytics,
412
+ useKnowledgeGraphContext
413
+ };
414
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../consts.ts","../hooks/use-knowledge-graph.ts","../hooks/use-knowledge-graph-analytics.ts","../models/kg.ts","../models/kg-designer.ts","../state/knowledge-graph-context.tsx"],"sourcesContent":["export const Test = \"hi\";","\"use client\";\n\nimport { useUserContext } from \"@elqnt/auth\";\nimport { DocsIngestionRequest } from \"@elqnt/docs\";\nimport { useNatsContext } from \"@elqnt/nats\";\nimport { useEffect, useState } from \"react\";\nimport {\n KGLabelInfo,\n KGNode,\n KGNodeIngestRequest,\n KGQuery,\n KGQueryResult,\n} from \"../models\";\n\ntype Success = { success: boolean };\n\nexport type UseKnowledgeGraphType = {\n isLoading: boolean;\n ingestNode: (node: KGNodeIngestRequest) => Promise<Success | Error>;\n ingestNodes: (node: KGNodeIngestRequest[]) => Promise<Success | Error>;\n updateNode: (\n nodeId: string,\n label: string,\n fields: Record<string, any>\n ) => Promise<Success | Error>;\n ingestDocs: (\n urls: string[],\n mode: \"documents\" | \"entities\" | \"snippets\",\n brief: string,\n labels: string[]\n ) => Promise<Success | Error>;\n\n ingestText: (\n text: string,\n mode: \"entities\" | \"snippets\"\n ) => Promise<Success | Error>;\n\n ingestYT: (url: string) => Promise<Success | Error>;\n\n queryGraph: (query: KGQuery) => Promise<KGQueryResult>;\n getGraphLabels: () => Promise<KGLabelInfo[] | Error>;\n labels: KGLabelInfo[] | undefined;\n selectedLabel: string | undefined;\n setSelectedLabel: (label: string) => void;\n queryResult: KGQueryResult | undefined;\n setQueryResult: (res: KGQueryResult) => void;\n refreshState: () => void;\n selectedNodeId: string | undefined;\n setSelectedNodeId: (id: string | undefined) => void;\n getNodeById: (id: string) => Promise<KGNode | Error>;\n};\n\nexport const useKnowledgeGraph = (\n overrideOrgId?: string\n): UseKnowledgeGraphType => {\n const { selectedOrgId } = useUserContext();\n const [isLoading, setIsLoading] = useState(false);\n const { natsConnected, request } = useNatsContext();\n const [selectedNodeId, setSelectedNodeId] = useState<string | undefined>(\n undefined\n );\n\n const orgId = overrideOrgId ?? selectedOrgId;\n\n const [labels, setLabels] = useState<KGLabelInfo[] | undefined>(undefined);\n const [selectedLabel, setSelectedLabel] = useState<string | undefined>(\n undefined\n );\n const [queryResult, setQueryResult] = useState<KGQueryResult | undefined>(\n undefined\n );\n\n const [stateTrigger, setStateTrigger] = useState(0);\n\n async function ingestNode(\n node: KGNodeIngestRequest\n ): Promise<Success | Error> {\n if (!orgId) {\n return new Error(\"No orgId provided\");\n }\n\n if (!natsConnected) {\n return new Error(\"Not connected to NATS\");\n }\n\n setIsLoading(true);\n const data = await request<KGNodeIngestRequest, Success>(\n \"kg.ingest.node\",\n node,\n {\n orgId,\n }\n );\n\n setIsLoading(false);\n\n if (data instanceof Error) {\n console.error(data);\n return data;\n }\n\n return data;\n }\n\n async function ingestNodes(\n nodes: KGNodeIngestRequest[]\n ): Promise<Success | Error> {\n if (!orgId) {\n return new Error(\"No orgId provided\");\n }\n\n if (!natsConnected) {\n return new Error(\"Not connected to NATS\");\n }\n\n setIsLoading(true);\n const data = await request<KGNodeIngestRequest[], Success>(\n \"kg.ingest.nodes\",\n nodes,\n {\n orgId,\n }\n );\n\n setIsLoading(false);\n\n if (data instanceof Error) {\n console.error(data);\n return data;\n }\n\n return data;\n }\n\n async function updateNode(\n nodeId: string,\n label: string,\n fields: Record<string, any>\n ): Promise<Success | Error> {\n const nodeRequest: KGNodeIngestRequest = {\n label,\n keyField: \"id\",\n fields: {\n ...fields,\n id: nodeId,\n },\n duplicatePolicy: \"replace\",\n };\n\n const result = await ingestNode(nodeRequest);\n\n // Optimize graph after successful update (non-blocking, with delay)\n if (!(result instanceof Error)) {\n // Wait 2 seconds to ensure node is fully written to ClickHouse\n setTimeout(() => {\n optimizeGraph().catch(err =>\n console.error(\"Failed to optimize graph after node update:\", err)\n );\n }, 2000);\n }\n\n return result;\n }\n\n async function optimizeGraph(): Promise<Success | Error> {\n if (!orgId) {\n return new Error(\"No orgId provided\");\n }\n\n if (!natsConnected) {\n return new Error(\"Not connected to NATS\");\n }\n\n const data = await request<{}, Success>(\n \"kg.graph.optimize\",\n {},\n {\n orgId,\n }\n );\n\n if (data instanceof Error) {\n console.error(\"Graph optimization failed:\", data);\n return data;\n }\n\n console.log(\"Graph optimized successfully\");\n return data;\n }\n\n async function ingestDocs(\n urls: string[],\n mode: \"documents\" | \"entities\" | \"snippets\",\n brief: string,\n labels: string[]\n ): Promise<Success | Error> {\n // todo: implement\n if (!orgId) {\n return new Error(\"No orgId provided\");\n }\n\n if (!natsConnected) {\n return new Error(\"Not connected to NATS\");\n }\n\n setIsLoading(true);\n const data = await request<DocsIngestionRequest, Success>(\n \"docs.kg.ingest\",\n { urls, mode, brief, labels },\n {\n orgId,\n }\n );\n\n setIsLoading(false);\n\n if (data instanceof Error) {\n console.error(data);\n return data;\n }\n\n return data;\n }\n\n async function ingestText(\n text: string,\n mode: \"entities\" | \"snippets\"\n ): Promise<Success | Error> {\n if (!orgId) {\n return new Error(\"No orgId provided\");\n }\n\n if (!natsConnected) {\n return new Error(\"Not connected to NATS\");\n }\n\n setIsLoading(true);\n const data = await request<any, Success>(\n \"docs.kg.ingestText\",\n { text, mode },\n {\n orgId,\n }\n );\n\n setIsLoading(false);\n\n if (data instanceof Error) {\n console.error(data);\n return data;\n }\n\n return data;\n }\n\n async function ingestYT(url: string): Promise<Success | Error> {\n if (!orgId) {\n return new Error(\"No orgId provided\");\n }\n\n if (!natsConnected) {\n return new Error(\"Not connected to NATS\");\n }\n\n setIsLoading(true);\n const data = await request<any, Success>(\n \"docs.kg.ingestYT\",\n { url },\n {\n orgId,\n }\n );\n\n setIsLoading(false);\n\n if (data instanceof Error) {\n console.error(data);\n return data;\n }\n\n return data;\n }\n\n async function queryGraph(query: KGQuery): Promise<KGQueryResult> {\n if (!orgId) {\n throw new Error(\"No orgId provided\");\n }\n\n if (!natsConnected) {\n throw new Error(\"Not connected to NATS\");\n }\n\n setIsLoading(true);\n\n const data = await request<KGQuery, KGQueryResult>(\n \"kg.query.graph\",\n query,\n {\n orgId,\n }\n );\n\n setIsLoading(false);\n\n if (data instanceof Error) {\n console.error(data);\n return data;\n }\n\n return data;\n }\n\n async function getNodeById(id: string): Promise<KGNode | Error> {\n if (!orgId) {\n return new Error(\"No orgId provided\");\n }\n\n if (!natsConnected) {\n return new Error(\"Not connected to NATS\");\n }\n\n const data = await request<any, KGNode>(\n \"kg.query.nodeById\",\n { id },\n { orgId }\n );\n\n if (data instanceof Error) {\n console.error(data);\n return data;\n }\n\n return data;\n }\n\n async function getGraphLabels(): Promise<KGLabelInfo[] | Error> {\n if (!orgId) {\n return new Error(\"No orgId provided\");\n }\n\n if (!natsConnected) {\n return new Error(\"Not connected to NATS\");\n }\n\n // console.log(\"getGraphLabels\", { orgId });\n\n setIsLoading(true);\n\n const data = await request<any, KGLabelInfo[]>(\n \"kg.graph.labels\",\n {},\n { orgId }\n );\n\n setIsLoading(false);\n\n if (data instanceof Error) {\n console.error(data);\n return data;\n }\n\n // todo: global error\n if (!Array.isArray(data) && typeof data === \"object\") {\n const err = data as any;\n return new Error(err?.message ?? err?.error ?? err);\n }\n\n return data;\n }\n\n useEffect(() => {\n if (!natsConnected || !orgId) {\n return;\n }\n async function getLabels(): Promise<KGLabelInfo[] | Error> {\n const data = await getGraphLabels();\n if (data instanceof Error) {\n // console.error(data);\n return [];\n }\n setLabels(data);\n return data;\n }\n getLabels();\n }, [natsConnected, orgId, stateTrigger]);\n\n useEffect(() => {\n if (!natsConnected || !orgId || !selectedLabel) {\n return;\n }\n async function getGraphQueryResult() {\n if (!selectedLabel) return;\n\n console.log(\"will getGraphQueryResult\", { orgId, selectedLabel });\n\n const query: KGQuery = {\n label: selectedLabel,\n fields: [],\n limit: 5_00,\n sortBy: \"\",\n sortOrder: \"asc\",\n // edges: [{ label: \"student of\", direction: \"outgoing\" }],\n depth: 2,\n };\n\n const res = await queryGraph(query);\n\n if (res instanceof Error) {\n console.error(res);\n return;\n }\n setQueryResult(res);\n console.log(\"graph query response \", {\n nodesCount: res.nodes?.length,\n edgesCount: res.edges?.length,\n });\n }\n getGraphQueryResult();\n }, [natsConnected, orgId, selectedLabel, stateTrigger]);\n\n function refreshState() {\n setStateTrigger(stateTrigger + 1);\n }\n\n return {\n isLoading,\n ingestNode,\n ingestNodes,\n updateNode,\n queryGraph,\n getNodeById,\n getGraphLabels,\n labels,\n selectedLabel,\n setSelectedLabel,\n queryResult,\n setQueryResult,\n refreshState,\n ingestDocs,\n ingestText,\n selectedNodeId,\n setSelectedNodeId,\n ingestYT,\n };\n};\n","\"use client\";\n\nimport { useNatsContext } from \"@elqnt/nats\";\nimport { useUserContext } from \"@elqnt/auth\";\nimport { useState } from \"react\";\nexport type UseKnowledgeGraphAnalyticsType = {\n isLoading: boolean;\n};\n\nexport const useKnowledgeGraphAnalytics = (\n overrideOrgId?: string\n): UseKnowledgeGraphAnalyticsType => {\n const { selectedOrgId } = useUserContext();\n const [isLoading, setIsLoading] = useState(false);\n const { natsConnected, request } = useNatsContext();\n\n return {\n isLoading,\n };\n};\n","// Code generated by tygo. DO NOT EDIT.\nimport { ResponseMetadata } from \"@elqnt/types\";\n\n//////////\n// source: kg-models.go\n\nexport interface KGNode {\n id: string;\n label: string;\n fields: { [key: string]: any};\n relationships?: KGEdge[];\n score?: number /* float64 */;\n}\nexport interface KGEdge {\n id: string;\n label: string;\n fields: { [key: string]: any};\n from: string;\n to: string;\n}\nexport interface KGNodeIngestRequest {\n label: string;\n keyField?: string;\n reverseEdgeLabel?: string;\n fields: { [key: string]: any};\n edges?: KGEdgeIngestRequest[];\n duplicatePolicy?: DuplicatePolicy;\n generateEmbeddings?: boolean;\n embeddingsSource?: string;\n embeddingsFields?: string[];\n}\nexport type DuplicatePolicy = string;\nexport const DuplicatePolicyCreateIf: DuplicatePolicy = \"createIfNotExist\";\nexport const DuplicatePolicyIgnore: DuplicatePolicy = \"ignore\";\nexport const DuplicatePolicyReplace: DuplicatePolicy = \"replace\";\nexport const DuplicatePolicyFail: DuplicatePolicy = \"fail\";\nexport const DuplicatePolicyCreate: DuplicatePolicy = \"create\";\nexport interface KGEdgeIngestRequest {\n label: string;\n fields: { [key: string]: any};\n toLabel: string;\n toFieldKey: string;\n toFieldValue: any;\n createReciprocal: boolean;\n reciprocalLabel: string;\n allowEmbeddingsSearch?: boolean;\n}\nexport interface KGQuery {\n label: string;\n fields: KGFieldQuery[];\n limit: number /* int */;\n depth: number /* int */;\n sortBy: string;\n sortOrder: string;\n edges?: KGEdgeQuery[];\n embeddingsSource?: string;\n skipEmbedding?: boolean;\n}\nexport interface KGFieldQuery {\n name: string;\n value: any;\n operator: KGFieldQueryOperator;\n}\nexport type KGFieldQueryOperator = string;\nexport const KGFieldQueryOperatorEqual: KGFieldQueryOperator = \"eq\";\nexport const KGFieldQueryOperatorNotEqual: KGFieldQueryOperator = \"neq\";\nexport const KGFieldQueryOperatorGreater: KGFieldQueryOperator = \"gt\";\nexport const KGFieldQueryOperatorLess: KGFieldQueryOperator = \"lt\";\nexport const KGFieldQueryOperatorGreaterOrEqual: KGFieldQueryOperator = \"gte\";\nexport const KGFieldQueryOperatorLessOrEqual: KGFieldQueryOperator = \"lte\";\nexport const KGFieldQueryOperatorLike: KGFieldQueryOperator = \"like\";\nexport const KGFieldQueryOperatorSimilar: KGFieldQueryOperator = \"similar\";\n/**\n * KGFieldQueryOperatorGreaterOrEqual KGFieldQueryOperator = \"gte\"\n * KGFieldQueryOperatorLessOrEqual KGFieldQueryOperator = \"lte\"\n */\nexport const KGFieldQueryOperatorIn: KGFieldQueryOperator = \"in\";\nexport const KGFieldQueryOperatorArrayContains: KGFieldQueryOperator = \"arrayContains\";\nexport type KGRelationshipDirection = string;\nexport const KGRelationshipDirectionIncoming: KGRelationshipDirection = \"incoming\";\nexport const KGRelationshipDirectionOutgoing: KGRelationshipDirection = \"outgoing\";\nexport interface KGEdgeQuery {\n label: string;\n direction: 'incoming' | 'outgoing';\n fields?: { [key: string]: any};\n /**\n * FromLabel string `json:\"fromLabel\"`\n * FromFieldKey string `json:\"fromFieldKey\"`\n * FromValue interface{} `json:\"fromValue\"`\n */\n toLabel: string;\n toFieldKey: string;\n toFieldValue: any;\n}\nexport interface KGQueryResult {\n nodes: KGNode[];\n edges: KGEdge[];\n}\nexport interface KGLabelInfo {\n label: string;\n count: number /* uint64 */;\n}\nexport interface KGPropertyInfo {\n property: string;\n count: number /* uint64 */;\n}\nexport interface KGPLabelSchema {\n label: string;\n keys: string[];\n}\nexport interface KGArticle {\n id: string;\n title: string;\n content: string;\n lang?: string;\n docUrl?: string;\n paragraphs?: string;\n}\nexport interface KGPropertyFilter {\n property: string;\n value: string;\n}\nexport interface KGPropertyFilterRequest {\n label: string;\n filters: KGPropertyFilter[];\n}\nexport interface DeleteDocumentRequest {\n documentId: string;\n}\nexport interface DeleteDocumentResponse {\n success: boolean;\n deletedNodes: { [key: string]: number /* int */};\n totalDeleted: number /* int */;\n error?: string;\n}\n/**\n * KGSyncJob represents a sync job record in the database\n */\nexport interface KGSyncJob {\n id: string;\n title: string;\n stats: { [key: string]: any};\n startTime: string;\n endTime: string;\n updatedAt?: string;\n}\n/**\n * KGSyncJobUpdateRequest is used to insert or update a sync job\n */\nexport interface KGSyncJobUpdateRequest {\n id: string;\n title: string;\n stats: { [key: string]: any};\n startTime: string;\n endTime: string;\n}\nexport interface KGSyncJobUpdateResponse {\n jobId: string;\n metadata: ResponseMetadata;\n}\nexport interface KGSyncJobListResponse {\n jobs: KGSyncJob[];\n metadata: ResponseMetadata;\n}\n/**\n * KGSyncJobListRequest is used to list sync jobs with filters\n */\nexport interface KGSyncJobListRequest {\n limit?: number /* int */;\n offset?: number /* int */;\n startFrom?: string;\n endTo?: string;\n}\n","// Code generated by tygo. DO NOT EDIT.\n\n//////////\n// source: designer-models.go\n\n/**\n * GraphNodeDefinition represents a node type in the knowledge graph\n */\nexport interface GraphNodeDefinition {\n label: string;\n description: string;\n schema: { [key: string]: any};\n createdAt: string /* RFC3339 */;\n updatedAt: string /* RFC3339 */;\n}\n/**\n * GraphEdgeDefinition represents an edge type in the knowledge graph\n */\nexport interface GraphEdgeDefinition {\n label: string;\n description: string;\n fromNode: string;\n toNode: string;\n schema: { [key: string]: any};\n createdAt: string /* RFC3339 */;\n updatedAt: string /* RFC3339 */;\n}\n/**\n * Request/Response types\n */\nexport interface GraphNodeRequest {\n node: GraphNodeDefinition;\n}\nexport interface GraphNodeResponse {\n node?: GraphNodeDefinition;\n nodes?: GraphNodeDefinition[];\n success: boolean;\n error?: string;\n}\nexport interface GraphEdgeRequest {\n edge: GraphEdgeDefinition;\n}\nexport interface GraphEdgeResponse {\n edge?: GraphEdgeDefinition;\n edges?: GraphEdgeDefinition[];\n success: boolean;\n error?: string;\n}\n\n//////////\n// source: subjects.go\n\n/**\n * KG Designer Node subjects\n */\nexport const KGDesignerNodeCreate = \"kg.designer.node.create\";\nexport const KGDesignerNodeUpdate = \"kg.designer.node.update.*\";\nexport const KGDesignerNodeDelete = \"kg.designer.node.delete.*\";\nexport const KGDesignerNodeGet = \"kg.designer.node.get.*\";\nexport const KGDesignerNodeList = \"kg.designer.node.list\";\n/**\n * KG Designer Edge subjects\n */\nexport const KGDesignerEdgeCreate = \"kg.designer.edge.create\";\nexport const KGDesignerEdgeUpdate = \"kg.designer.edge.update.*\";\nexport const KGDesignerEdgeDelete = \"kg.designer.edge.delete.*\";\nexport const KGDesignerEdgeGet = \"kg.designer.edge.get.*\";\nexport const KGDesignerEdgeList = \"kg.designer.edge.list\";\n/**\n * KG Database subjects\n */\nexport const KGDBCreate = \"kg.db.create\";\n/**\n * KG Document subjects\n */\nexport const KGDocumentDelete = \"kg_ingest.document.delete\";\n/**\n * KG Sync Job subjects\n */\nexport const KGSyncJobUpdate = \"kg.sync.job.update\";\nexport const KGSyncJobList = \"kg.sync.job.list\";\n/**\n * KG Optimization subjects\n */\nexport const KGGraphOptimize = \"kg.graph.optimize\";\n","\"use client\";\n\nimport { ReactNode, createContext, useContext } from \"react\";\nimport {\n UseKnowledgeGraphType,\n useKnowledgeGraph,\n} from \"../hooks/use-knowledge-graph\";\n\nexport const KnowledgeGraphContext = createContext<\n UseKnowledgeGraphType | undefined\n>(undefined);\n\nexport function KnowledgeGraphContextProvider(props: {\n children: ReactNode;\n overrideOrgId?: string;\n}) {\n const { children, overrideOrgId } = props;\n\n const useKG = useKnowledgeGraph(overrideOrgId);\n\n return (\n <KnowledgeGraphContext.Provider value={useKG}>\n {children}\n </KnowledgeGraphContext.Provider>\n );\n}\n\nexport const useKnowledgeGraphContext = () => {\n const context = useContext(KnowledgeGraphContext);\n if (context === undefined) {\n throw new Error(\n \"useKnowledgeGraphContext must be used within a KnowledgeGraphContextProvider\"\n );\n }\n return context;\n};\n"],"mappings":"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","names":["labels","useNatsContext","useUserContext","useState"]}
package/package.json ADDED
@@ -0,0 +1,42 @@
1
+ {
2
+ "name": "@elqnt/kg",
3
+ "version": "1.0.0",
4
+ "description": "Knowledge graph functionality for Eloquent platform",
5
+ "main": "./dist/index.js",
6
+ "module": "./dist/index.mjs",
7
+ "types": "./dist/index.d.ts",
8
+ "exports": {
9
+ ".": {
10
+ "import": "./dist/index.mjs",
11
+ "require": "./dist/index.js",
12
+ "types": "./dist/index.d.ts"
13
+ }
14
+ },
15
+ "files": ["dist"],
16
+ "scripts": {
17
+ "build": "tsup",
18
+ "dev": "tsup --watch",
19
+ "clean": "rm -rf dist",
20
+ "typecheck": "tsc --noEmit"
21
+ },
22
+ "repository": {
23
+ "type": "git",
24
+ "url": "git+https://github.com/Blazi-Commerce/eloquent-packages.git",
25
+ "directory": "packages/kg"
26
+ },
27
+ "dependencies": {
28
+ "@elqnt/auth": "^1.0.0",
29
+ "@elqnt/docs": "^1.0.0",
30
+ "@elqnt/nats": "^1.0.0",
31
+ "@elqnt/types": "^1.0.0"
32
+ },
33
+ "peerDependencies": {
34
+ "react": "^18.0.0 || ^19.0.0"
35
+ },
36
+ "devDependencies": {
37
+ "@types/react": "^19.0.0",
38
+ "react": "^19.0.0",
39
+ "tsup": "^8.0.0",
40
+ "typescript": "^5.0.0"
41
+ }
42
+ }