@infinilabs/ai-chat 0.0.1 → 0.0.3

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.
Files changed (116) hide show
  1. package/README.md +10 -1
  2. package/dist/{_baseUniq-BQcAhV7E.js → _baseUniq-C6eXDRdi.js} +1 -1
  3. package/dist/_baseUniq-VBKGmFNZ.cjs +151 -0
  4. package/dist/arc-C_pZjUl4.cjs +130 -0
  5. package/dist/{arc-2jwvQ2TN.js → arc-D1VL3r-o.js} +1 -1
  6. package/dist/architecture-U656AL7Q-BF5SEVYt.cjs +5 -0
  7. package/dist/{architecture-U656AL7Q-WuSilpZW.js → architecture-U656AL7Q-BU8DDug4.js} +1 -1
  8. package/dist/{architectureDiagram-VXUJARFQ-D6SKNy5z.js → architectureDiagram-VXUJARFQ-BD3g0-L9.js} +3 -3
  9. package/dist/architectureDiagram-VXUJARFQ-DjBxfJaD.cjs +8681 -0
  10. package/dist/blockDiagram-VD42YOAC-B2f1rMqq.cjs +3606 -0
  11. package/dist/{blockDiagram-VD42YOAC-Ct2DD8jj.js → blockDiagram-VD42YOAC-Dco6f43O.js} +5 -5
  12. package/dist/c4Diagram-YG6GDRKO-DNqNYnPR.cjs +2481 -0
  13. package/dist/{c4Diagram-YG6GDRKO-B7wBU4mz.js → c4Diagram-YG6GDRKO-DaatwWsP.js} +2 -2
  14. package/dist/channel-CqaWpJup.cjs +6 -0
  15. package/dist/{channel-BRREX19f.js → channel-DHoS2D4-.js} +1 -1
  16. package/dist/{chunk-4BX2VUAB-BnghU1_v.js → chunk-4BX2VUAB-CJqHiK4X.js} +1 -1
  17. package/dist/chunk-4BX2VUAB-DN2yOkoW.cjs +15 -0
  18. package/dist/chunk-55IACEB6-BdkCWkvA.cjs +12 -0
  19. package/dist/{chunk-55IACEB6-Dduk-DEL.js → chunk-55IACEB6-C6ly5iWy.js} +1 -1
  20. package/dist/{chunk-B4BG7PRW-DeHw-z-x.js → chunk-B4BG7PRW--1XVDmjR.js} +4 -4
  21. package/dist/chunk-B4BG7PRW-CyVGILSL.cjs +1825 -0
  22. package/dist/{chunk-DI55MBZ5-GTHMAr0M.js → chunk-DI55MBZ5-CdspH0FP.js} +3 -3
  23. package/dist/chunk-DI55MBZ5-zfT0HzuJ.cjs +1914 -0
  24. package/dist/chunk-FMBD7UC4-B1XNgXxo.cjs +18 -0
  25. package/dist/{chunk-FMBD7UC4-Bchh4_3W.js → chunk-FMBD7UC4-DwJ0I9NE.js} +1 -1
  26. package/dist/chunk-QN33PNHL-BkRCfP3-.cjs +23 -0
  27. package/dist/{chunk-QN33PNHL-H6S-NYp0.js → chunk-QN33PNHL-ToZ1oMAx.js} +1 -1
  28. package/dist/chunk-QZHKN3VN-Bl6qG9aO.cjs +16 -0
  29. package/dist/{chunk-QZHKN3VN-DdcyNnvM.js → chunk-QZHKN3VN-D6NMZefL.js} +1 -1
  30. package/dist/{chunk-TZMSLE5B-C7te_j4V.js → chunk-TZMSLE5B-CX7F9bum.js} +1 -1
  31. package/dist/chunk-TZMSLE5B-CfLnJLL2.cjs +107 -0
  32. package/dist/{classDiagram-2ON5EDUG-CNkHY_Y7.js → classDiagram-2ON5EDUG-do_fcMxL.js} +2 -2
  33. package/dist/classDiagram-2ON5EDUG-l6iTeY9n.cjs +19 -0
  34. package/dist/{classDiagram-v2-WZHVMYZB-CNkHY_Y7.js → classDiagram-v2-WZHVMYZB-do_fcMxL.js} +2 -2
  35. package/dist/classDiagram-v2-WZHVMYZB-l6iTeY9n.cjs +19 -0
  36. package/dist/{clone-DnOD7gQ4.js → clone-B0NbP06l.js} +1 -1
  37. package/dist/clone-O_UR2EnI.cjs +7 -0
  38. package/dist/cose-bilkent-S5V4N54A-Bj9q8jdP.cjs +4942 -0
  39. package/dist/{cose-bilkent-S5V4N54A-2EKtTYth.js → cose-bilkent-S5V4N54A-Dm15CejI.js} +1 -1
  40. package/dist/cytoscape.esm-D8IBYQeQ.cjs +30238 -0
  41. package/dist/dagre-6UL2VRFP-DlrZJc7j.cjs +693 -0
  42. package/dist/{dagre-6UL2VRFP-oJLNDO4O.js → dagre-6UL2VRFP-DpFJxcQI.js} +5 -5
  43. package/dist/defaultLocale-DwYGIg9G.cjs +203 -0
  44. package/dist/{diagram-PSM6KHXK-DhMgmu9h.js → diagram-PSM6KHXK-BiuW3-I6.js} +4 -4
  45. package/dist/diagram-PSM6KHXK-J1K0HhB0.cjs +845 -0
  46. package/dist/{diagram-QEK2KX5R-pB1vUeno.js → diagram-QEK2KX5R-CKI4v8U1.js} +3 -3
  47. package/dist/diagram-QEK2KX5R-CfZyy8K3.cjs +300 -0
  48. package/dist/{diagram-S2PKOQOG-HTooIr24.js → diagram-S2PKOQOG-BFBmhCiH.js} +3 -3
  49. package/dist/diagram-S2PKOQOG-D99Ax7Ju.cjs +210 -0
  50. package/dist/erDiagram-Q2GNP2WA-CVkYr-Vj.cjs +1158 -0
  51. package/dist/{erDiagram-Q2GNP2WA-CCaN2EHf.js → erDiagram-Q2GNP2WA-qVxQAwwu.js} +4 -4
  52. package/dist/{flowDiagram-NV44I4VS-CG0erQtl.js → flowDiagram-NV44I4VS-5brdnMxu.js} +5 -5
  53. package/dist/flowDiagram-NV44I4VS-7p-zbTbS.cjs +2331 -0
  54. package/dist/{ganttDiagram-JELNMOA3-D3rSLJec.js → ganttDiagram-JELNMOA3-B_6E5yap.js} +2 -2
  55. package/dist/ganttDiagram-JELNMOA3-BqIucWob.cjs +3679 -0
  56. package/dist/{gitGraph-F6HP7TQM-BDWdXs6A.js → gitGraph-F6HP7TQM-5ygKEXa4.js} +1 -1
  57. package/dist/gitGraph-F6HP7TQM-Dqtx4v2X.cjs +5 -0
  58. package/dist/{gitGraphDiagram-NY62KEGX-Ip-PiLDb.js → gitGraphDiagram-NY62KEGX-8yiOWwFX.js} +4 -4
  59. package/dist/gitGraphDiagram-NY62KEGX-DLpTvKWJ.cjs +1203 -0
  60. package/dist/graph-BQ7jHivU.cjs +595 -0
  61. package/dist/{graph-wCViE1vL.js → graph-f7dsdfxH.js} +2 -2
  62. package/dist/index-BZzFD4NG.cjs +120453 -0
  63. package/dist/{index-BQvQI7yA.js → index-TgFTummf.js} +103814 -100678
  64. package/dist/index.cjs +19 -0
  65. package/dist/index.js +13 -1
  66. package/dist/info-NVLQJR56-CBEfMVO2.cjs +5 -0
  67. package/dist/info-NVLQJR56-CXysh6Cg.js +5 -0
  68. package/dist/infoDiagram-WHAUD3N6-D8UJMXYO.cjs +31 -0
  69. package/dist/{infoDiagram-WHAUD3N6-BbVs4x8y.js → infoDiagram-WHAUD3N6-DAhQzmYU.js} +2 -2
  70. package/dist/init-DevvdK2U.cjs +15 -0
  71. package/dist/journeyDiagram-XKPGCS4Q-BTWSe50v.cjs +1254 -0
  72. package/dist/{journeyDiagram-XKPGCS4Q-Cz9ox9GA.js → journeyDiagram-XKPGCS4Q-DF63luuF.js} +4 -4
  73. package/dist/kanban-definition-3W4ZIXB7-Bv1kpXjl.cjs +1047 -0
  74. package/dist/{kanban-definition-3W4ZIXB7-ChdUHO5f.js → kanban-definition-3W4ZIXB7-Byg1KrDf.js} +2 -2
  75. package/dist/katex-BhpYeT3b.cjs +14523 -0
  76. package/dist/{layout-BaZPdTGN.js → layout-Bph_0QZr.js} +4 -4
  77. package/dist/layout-Cbov0jB2.cjs +2182 -0
  78. package/dist/{linear-D_RX7hM-.js → linear-BSz-RTmc.js} +1 -1
  79. package/dist/linear-D36lF41G.cjs +339 -0
  80. package/dist/mermaid-parser.core-BjisUoZL.cjs +18703 -0
  81. package/dist/{mermaid-parser.core-_sn6A3wB.js → mermaid-parser.core-D51-lxGS.js} +10 -10
  82. package/dist/min-D_N_XAer.cjs +40 -0
  83. package/dist/{min-BxeM4Drj.js → min-Sni_KseC.js} +2 -2
  84. package/dist/mindmap-definition-VGOIOE7T-B7_dDBbb.cjs +1126 -0
  85. package/dist/{mindmap-definition-VGOIOE7T-BkjJibdi.js → mindmap-definition-VGOIOE7T-fbR1KpVG.js} +3 -3
  86. package/dist/ordinal-D7sQNqXZ.cjs +75 -0
  87. package/dist/{packet-BFZMPI3H-D3RtU0mc.js → packet-BFZMPI3H-B9lSQ4ue.js} +1 -1
  88. package/dist/packet-BFZMPI3H-DFuV40UT.cjs +5 -0
  89. package/dist/pie-7BOR55EZ-CfhfuSiQ.cjs +5 -0
  90. package/dist/pie-7BOR55EZ-DlYTWEJg.js +5 -0
  91. package/dist/{pieDiagram-ADFJNKIX-2Yr1gkth.js → pieDiagram-ADFJNKIX-BZ-6MLDa.js} +4 -4
  92. package/dist/pieDiagram-ADFJNKIX-ZykBg0LM.cjs +237 -0
  93. package/dist/quadrantDiagram-AYHSOK5B-BuiB_Qh3.cjs +1335 -0
  94. package/dist/{quadrantDiagram-AYHSOK5B-CjicpXRv.js → quadrantDiagram-AYHSOK5B-ClRDM-6s.js} +2 -2
  95. package/dist/{radar-NHE76QYJ-CL0tHnUP.js → radar-NHE76QYJ-Crabb2QS.js} +1 -1
  96. package/dist/radar-NHE76QYJ-D3rgOiIb.cjs +5 -0
  97. package/dist/{requirementDiagram-UZGBJVZJ-DBnhlfjR.js → requirementDiagram-UZGBJVZJ-kA_oq2PA.js} +3 -3
  98. package/dist/requirementDiagram-UZGBJVZJ-mm41geqc.cjs +1161 -0
  99. package/dist/sankeyDiagram-TZEHDZUN-C6izw8f1.cjs +1193 -0
  100. package/dist/{sankeyDiagram-TZEHDZUN-B2FErKCa.js → sankeyDiagram-TZEHDZUN-D-ZqnMWy.js} +1 -1
  101. package/dist/sequenceDiagram-WL72ISMW-CjC76RTk.cjs +3874 -0
  102. package/dist/{sequenceDiagram-WL72ISMW-BkNTlRlB.js → sequenceDiagram-WL72ISMW-DUEVJaIy.js} +3 -3
  103. package/dist/{stateDiagram-FKZM4ZOC-CAAFQtS9.js → stateDiagram-FKZM4ZOC-2IfcY2Ye.js} +4 -4
  104. package/dist/stateDiagram-FKZM4ZOC-DK5kcW23.cjs +447 -0
  105. package/dist/{stateDiagram-v2-4FDKWEC3-lF6kUebI.js → stateDiagram-v2-4FDKWEC3-DXQKznzB.js} +2 -2
  106. package/dist/stateDiagram-v2-4FDKWEC3-hWKPBy9I.cjs +19 -0
  107. package/dist/timeline-definition-IT6M3QCI-DwMBhyGj.cjs +1222 -0
  108. package/dist/{timeline-definition-IT6M3QCI-CQgMFEPA.js → timeline-definition-IT6M3QCI-ohrBFack.js} +2 -2
  109. package/dist/treemap-KMMF4GRG-Bdodyj4b.cjs +5 -0
  110. package/dist/{treemap-KMMF4GRG-B0Mc-u8X.js → treemap-KMMF4GRG-C4kqSdak.js} +1 -1
  111. package/dist/{xychartDiagram-PRI3JC2R-Cee7LdLr.js → xychartDiagram-PRI3JC2R-BBSKFQ3Z.js} +2 -2
  112. package/dist/xychartDiagram-PRI3JC2R-wKIvgX35.cjs +1886 -0
  113. package/package.json +19 -6
  114. package/dist/index.css +0 -3334
  115. package/dist/info-NVLQJR56-pJlVBPs6.js +0 -5
  116. package/dist/pie-7BOR55EZ-xH--CiaM.js +0 -5
@@ -0,0 +1,595 @@
1
+ "use strict";
2
+ const index = require("./index-BZzFD4NG.cjs");
3
+ const _baseUniq = require("./_baseUniq-VBKGmFNZ.cjs");
4
+ function baseAssign(object, source) {
5
+ return object && index.copyObject(source, index.keys(source), object);
6
+ }
7
+ function baseAssignIn(object, source) {
8
+ return object && index.copyObject(source, index.keysIn(source), object);
9
+ }
10
+ function copySymbols(source, object) {
11
+ return index.copyObject(source, index.getSymbols(source), object);
12
+ }
13
+ var nativeGetSymbols = Object.getOwnPropertySymbols;
14
+ var getSymbolsIn = !nativeGetSymbols ? index.stubArray : function(object) {
15
+ var result = [];
16
+ while (object) {
17
+ index.arrayPush(result, index.getSymbols(object));
18
+ object = index.getPrototype(object);
19
+ }
20
+ return result;
21
+ };
22
+ function copySymbolsIn(source, object) {
23
+ return index.copyObject(source, getSymbolsIn(source), object);
24
+ }
25
+ function getAllKeysIn(object) {
26
+ return index.baseGetAllKeys(object, index.keysIn, getSymbolsIn);
27
+ }
28
+ var objectProto = Object.prototype;
29
+ var hasOwnProperty = objectProto.hasOwnProperty;
30
+ function initCloneArray(array) {
31
+ var length = array.length, result = new array.constructor(length);
32
+ if (length && typeof array[0] == "string" && hasOwnProperty.call(array, "index")) {
33
+ result.index = array.index;
34
+ result.input = array.input;
35
+ }
36
+ return result;
37
+ }
38
+ function cloneDataView(dataView, isDeep) {
39
+ var buffer = isDeep ? index.cloneArrayBuffer(dataView.buffer) : dataView.buffer;
40
+ return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);
41
+ }
42
+ var reFlags = /\w*$/;
43
+ function cloneRegExp(regexp) {
44
+ var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));
45
+ result.lastIndex = regexp.lastIndex;
46
+ return result;
47
+ }
48
+ var symbolProto = index.Symbol ? index.Symbol.prototype : void 0, symbolValueOf = symbolProto ? symbolProto.valueOf : void 0;
49
+ function cloneSymbol(symbol) {
50
+ return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};
51
+ }
52
+ var boolTag$1 = "[object Boolean]", dateTag$1 = "[object Date]", mapTag$2 = "[object Map]", numberTag$1 = "[object Number]", regexpTag$1 = "[object RegExp]", setTag$2 = "[object Set]", stringTag$1 = "[object String]", symbolTag$1 = "[object Symbol]";
53
+ var arrayBufferTag$1 = "[object ArrayBuffer]", dataViewTag$1 = "[object DataView]", float32Tag$1 = "[object Float32Array]", float64Tag$1 = "[object Float64Array]", int8Tag$1 = "[object Int8Array]", int16Tag$1 = "[object Int16Array]", int32Tag$1 = "[object Int32Array]", uint8Tag$1 = "[object Uint8Array]", uint8ClampedTag$1 = "[object Uint8ClampedArray]", uint16Tag$1 = "[object Uint16Array]", uint32Tag$1 = "[object Uint32Array]";
54
+ function initCloneByTag(object, tag, isDeep) {
55
+ var Ctor = object.constructor;
56
+ switch (tag) {
57
+ case arrayBufferTag$1:
58
+ return index.cloneArrayBuffer(object);
59
+ case boolTag$1:
60
+ case dateTag$1:
61
+ return new Ctor(+object);
62
+ case dataViewTag$1:
63
+ return cloneDataView(object, isDeep);
64
+ case float32Tag$1:
65
+ case float64Tag$1:
66
+ case int8Tag$1:
67
+ case int16Tag$1:
68
+ case int32Tag$1:
69
+ case uint8Tag$1:
70
+ case uint8ClampedTag$1:
71
+ case uint16Tag$1:
72
+ case uint32Tag$1:
73
+ return index.cloneTypedArray(object, isDeep);
74
+ case mapTag$2:
75
+ return new Ctor();
76
+ case numberTag$1:
77
+ case stringTag$1:
78
+ return new Ctor(object);
79
+ case regexpTag$1:
80
+ return cloneRegExp(object);
81
+ case setTag$2:
82
+ return new Ctor();
83
+ case symbolTag$1:
84
+ return cloneSymbol(object);
85
+ }
86
+ }
87
+ var mapTag$1 = "[object Map]";
88
+ function baseIsMap(value) {
89
+ return index.isObjectLike(value) && index.getTag(value) == mapTag$1;
90
+ }
91
+ var nodeIsMap = index.nodeUtil && index.nodeUtil.isMap;
92
+ var isMap = nodeIsMap ? index.baseUnary(nodeIsMap) : baseIsMap;
93
+ var setTag$1 = "[object Set]";
94
+ function baseIsSet(value) {
95
+ return index.isObjectLike(value) && index.getTag(value) == setTag$1;
96
+ }
97
+ var nodeIsSet = index.nodeUtil && index.nodeUtil.isSet;
98
+ var isSet = nodeIsSet ? index.baseUnary(nodeIsSet) : baseIsSet;
99
+ var CLONE_DEEP_FLAG = 1, CLONE_FLAT_FLAG = 2, CLONE_SYMBOLS_FLAG = 4;
100
+ var argsTag = "[object Arguments]", arrayTag = "[object Array]", boolTag = "[object Boolean]", dateTag = "[object Date]", errorTag = "[object Error]", funcTag = "[object Function]", genTag = "[object GeneratorFunction]", mapTag = "[object Map]", numberTag = "[object Number]", objectTag = "[object Object]", regexpTag = "[object RegExp]", setTag = "[object Set]", stringTag = "[object String]", symbolTag = "[object Symbol]", weakMapTag = "[object WeakMap]";
101
+ var arrayBufferTag = "[object ArrayBuffer]", dataViewTag = "[object DataView]", float32Tag = "[object Float32Array]", float64Tag = "[object Float64Array]", int8Tag = "[object Int8Array]", int16Tag = "[object Int16Array]", int32Tag = "[object Int32Array]", uint8Tag = "[object Uint8Array]", uint8ClampedTag = "[object Uint8ClampedArray]", uint16Tag = "[object Uint16Array]", uint32Tag = "[object Uint32Array]";
102
+ var cloneableTags = {};
103
+ cloneableTags[argsTag] = cloneableTags[arrayTag] = cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] = cloneableTags[boolTag] = cloneableTags[dateTag] = cloneableTags[float32Tag] = cloneableTags[float64Tag] = cloneableTags[int8Tag] = cloneableTags[int16Tag] = cloneableTags[int32Tag] = cloneableTags[mapTag] = cloneableTags[numberTag] = cloneableTags[objectTag] = cloneableTags[regexpTag] = cloneableTags[setTag] = cloneableTags[stringTag] = cloneableTags[symbolTag] = cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] = cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;
104
+ cloneableTags[errorTag] = cloneableTags[funcTag] = cloneableTags[weakMapTag] = false;
105
+ function baseClone(value, bitmask, customizer, key, object, stack) {
106
+ var result, isDeep = bitmask & CLONE_DEEP_FLAG, isFlat = bitmask & CLONE_FLAT_FLAG, isFull = bitmask & CLONE_SYMBOLS_FLAG;
107
+ if (result !== void 0) {
108
+ return result;
109
+ }
110
+ if (!index.isObject(value)) {
111
+ return value;
112
+ }
113
+ var isArr = index.isArray(value);
114
+ if (isArr) {
115
+ result = initCloneArray(value);
116
+ if (!isDeep) {
117
+ return index.copyArray(value, result);
118
+ }
119
+ } else {
120
+ var tag = index.getTag(value), isFunc = tag == funcTag || tag == genTag;
121
+ if (index.isBuffer(value)) {
122
+ return index.cloneBuffer(value, isDeep);
123
+ }
124
+ if (tag == objectTag || tag == argsTag || isFunc && !object) {
125
+ result = isFlat || isFunc ? {} : index.initCloneObject(value);
126
+ if (!isDeep) {
127
+ return isFlat ? copySymbolsIn(value, baseAssignIn(result, value)) : copySymbols(value, baseAssign(result, value));
128
+ }
129
+ } else {
130
+ if (!cloneableTags[tag]) {
131
+ return object ? value : {};
132
+ }
133
+ result = initCloneByTag(value, tag, isDeep);
134
+ }
135
+ }
136
+ stack || (stack = new index.Stack());
137
+ var stacked = stack.get(value);
138
+ if (stacked) {
139
+ return stacked;
140
+ }
141
+ stack.set(value, result);
142
+ if (isSet(value)) {
143
+ value.forEach(function(subValue) {
144
+ result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));
145
+ });
146
+ } else if (isMap(value)) {
147
+ value.forEach(function(subValue, key2) {
148
+ result.set(key2, baseClone(subValue, bitmask, customizer, key2, value, stack));
149
+ });
150
+ }
151
+ var keysFunc = isFull ? isFlat ? getAllKeysIn : index.getAllKeys : isFlat ? index.keysIn : index.keys;
152
+ var props = isArr ? void 0 : keysFunc(value);
153
+ _baseUniq.arrayEach(props || value, function(subValue, key2) {
154
+ if (props) {
155
+ key2 = subValue;
156
+ subValue = value[key2];
157
+ }
158
+ index.assignValue(result, key2, baseClone(subValue, bitmask, customizer, key2, value, stack));
159
+ });
160
+ return result;
161
+ }
162
+ function baseValues(object, props) {
163
+ return index.arrayMap(props, function(key) {
164
+ return object[key];
165
+ });
166
+ }
167
+ function values(object) {
168
+ return object == null ? [] : baseValues(object, index.keys(object));
169
+ }
170
+ function isUndefined(value) {
171
+ return value === void 0;
172
+ }
173
+ var union = index.baseRest(function(arrays) {
174
+ return _baseUniq.baseUniq(_baseUniq.baseFlatten(arrays, 1, index.isArrayLikeObject, true));
175
+ });
176
+ var DEFAULT_EDGE_NAME = "\0";
177
+ var GRAPH_NODE = "\0";
178
+ var EDGE_KEY_DELIM = "";
179
+ class Graph {
180
+ constructor(opts = {}) {
181
+ this._isDirected = Object.prototype.hasOwnProperty.call(opts, "directed") ? opts.directed : true;
182
+ this._isMultigraph = Object.prototype.hasOwnProperty.call(opts, "multigraph") ? opts.multigraph : false;
183
+ this._isCompound = Object.prototype.hasOwnProperty.call(opts, "compound") ? opts.compound : false;
184
+ this._label = void 0;
185
+ this._defaultNodeLabelFn = index.constant$2(void 0);
186
+ this._defaultEdgeLabelFn = index.constant$2(void 0);
187
+ this._nodes = {};
188
+ if (this._isCompound) {
189
+ this._parent = {};
190
+ this._children = {};
191
+ this._children[GRAPH_NODE] = {};
192
+ }
193
+ this._in = {};
194
+ this._preds = {};
195
+ this._out = {};
196
+ this._sucs = {};
197
+ this._edgeObjs = {};
198
+ this._edgeLabels = {};
199
+ }
200
+ /* === Graph functions ========= */
201
+ isDirected() {
202
+ return this._isDirected;
203
+ }
204
+ isMultigraph() {
205
+ return this._isMultigraph;
206
+ }
207
+ isCompound() {
208
+ return this._isCompound;
209
+ }
210
+ setGraph(label) {
211
+ this._label = label;
212
+ return this;
213
+ }
214
+ graph() {
215
+ return this._label;
216
+ }
217
+ /* === Node functions ========== */
218
+ setDefaultNodeLabel(newDefault) {
219
+ if (!index.isFunction(newDefault)) {
220
+ newDefault = index.constant$2(newDefault);
221
+ }
222
+ this._defaultNodeLabelFn = newDefault;
223
+ return this;
224
+ }
225
+ nodeCount() {
226
+ return this._nodeCount;
227
+ }
228
+ nodes() {
229
+ return index.keys(this._nodes);
230
+ }
231
+ sources() {
232
+ var self = this;
233
+ return _baseUniq.filter(this.nodes(), function(v) {
234
+ return index.isEmpty(self._in[v]);
235
+ });
236
+ }
237
+ sinks() {
238
+ var self = this;
239
+ return _baseUniq.filter(this.nodes(), function(v) {
240
+ return index.isEmpty(self._out[v]);
241
+ });
242
+ }
243
+ setNodes(vs, value) {
244
+ var args = arguments;
245
+ var self = this;
246
+ _baseUniq.forEach(vs, function(v) {
247
+ if (args.length > 1) {
248
+ self.setNode(v, value);
249
+ } else {
250
+ self.setNode(v);
251
+ }
252
+ });
253
+ return this;
254
+ }
255
+ setNode(v, value) {
256
+ if (Object.prototype.hasOwnProperty.call(this._nodes, v)) {
257
+ if (arguments.length > 1) {
258
+ this._nodes[v] = value;
259
+ }
260
+ return this;
261
+ }
262
+ this._nodes[v] = arguments.length > 1 ? value : this._defaultNodeLabelFn(v);
263
+ if (this._isCompound) {
264
+ this._parent[v] = GRAPH_NODE;
265
+ this._children[v] = {};
266
+ this._children[GRAPH_NODE][v] = true;
267
+ }
268
+ this._in[v] = {};
269
+ this._preds[v] = {};
270
+ this._out[v] = {};
271
+ this._sucs[v] = {};
272
+ ++this._nodeCount;
273
+ return this;
274
+ }
275
+ node(v) {
276
+ return this._nodes[v];
277
+ }
278
+ hasNode(v) {
279
+ return Object.prototype.hasOwnProperty.call(this._nodes, v);
280
+ }
281
+ removeNode(v) {
282
+ if (Object.prototype.hasOwnProperty.call(this._nodes, v)) {
283
+ var removeEdge = (e) => this.removeEdge(this._edgeObjs[e]);
284
+ delete this._nodes[v];
285
+ if (this._isCompound) {
286
+ this._removeFromParentsChildList(v);
287
+ delete this._parent[v];
288
+ _baseUniq.forEach(this.children(v), (child) => {
289
+ this.setParent(child);
290
+ });
291
+ delete this._children[v];
292
+ }
293
+ _baseUniq.forEach(index.keys(this._in[v]), removeEdge);
294
+ delete this._in[v];
295
+ delete this._preds[v];
296
+ _baseUniq.forEach(index.keys(this._out[v]), removeEdge);
297
+ delete this._out[v];
298
+ delete this._sucs[v];
299
+ --this._nodeCount;
300
+ }
301
+ return this;
302
+ }
303
+ setParent(v, parent) {
304
+ if (!this._isCompound) {
305
+ throw new Error("Cannot set parent in a non-compound graph");
306
+ }
307
+ if (isUndefined(parent)) {
308
+ parent = GRAPH_NODE;
309
+ } else {
310
+ parent += "";
311
+ for (var ancestor = parent; !isUndefined(ancestor); ancestor = this.parent(ancestor)) {
312
+ if (ancestor === v) {
313
+ throw new Error("Setting " + parent + " as parent of " + v + " would create a cycle");
314
+ }
315
+ }
316
+ this.setNode(parent);
317
+ }
318
+ this.setNode(v);
319
+ this._removeFromParentsChildList(v);
320
+ this._parent[v] = parent;
321
+ this._children[parent][v] = true;
322
+ return this;
323
+ }
324
+ _removeFromParentsChildList(v) {
325
+ delete this._children[this._parent[v]][v];
326
+ }
327
+ parent(v) {
328
+ if (this._isCompound) {
329
+ var parent = this._parent[v];
330
+ if (parent !== GRAPH_NODE) {
331
+ return parent;
332
+ }
333
+ }
334
+ }
335
+ children(v) {
336
+ if (isUndefined(v)) {
337
+ v = GRAPH_NODE;
338
+ }
339
+ if (this._isCompound) {
340
+ var children = this._children[v];
341
+ if (children) {
342
+ return index.keys(children);
343
+ }
344
+ } else if (v === GRAPH_NODE) {
345
+ return this.nodes();
346
+ } else if (this.hasNode(v)) {
347
+ return [];
348
+ }
349
+ }
350
+ predecessors(v) {
351
+ var predsV = this._preds[v];
352
+ if (predsV) {
353
+ return index.keys(predsV);
354
+ }
355
+ }
356
+ successors(v) {
357
+ var sucsV = this._sucs[v];
358
+ if (sucsV) {
359
+ return index.keys(sucsV);
360
+ }
361
+ }
362
+ neighbors(v) {
363
+ var preds = this.predecessors(v);
364
+ if (preds) {
365
+ return union(preds, this.successors(v));
366
+ }
367
+ }
368
+ isLeaf(v) {
369
+ var neighbors;
370
+ if (this.isDirected()) {
371
+ neighbors = this.successors(v);
372
+ } else {
373
+ neighbors = this.neighbors(v);
374
+ }
375
+ return neighbors.length === 0;
376
+ }
377
+ filterNodes(filter) {
378
+ var copy = new this.constructor({
379
+ directed: this._isDirected,
380
+ multigraph: this._isMultigraph,
381
+ compound: this._isCompound
382
+ });
383
+ copy.setGraph(this.graph());
384
+ var self = this;
385
+ _baseUniq.forEach(this._nodes, function(value, v) {
386
+ if (filter(v)) {
387
+ copy.setNode(v, value);
388
+ }
389
+ });
390
+ _baseUniq.forEach(this._edgeObjs, function(e) {
391
+ if (copy.hasNode(e.v) && copy.hasNode(e.w)) {
392
+ copy.setEdge(e, self.edge(e));
393
+ }
394
+ });
395
+ var parents = {};
396
+ function findParent(v) {
397
+ var parent = self.parent(v);
398
+ if (parent === void 0 || copy.hasNode(parent)) {
399
+ parents[v] = parent;
400
+ return parent;
401
+ } else if (parent in parents) {
402
+ return parents[parent];
403
+ } else {
404
+ return findParent(parent);
405
+ }
406
+ }
407
+ if (this._isCompound) {
408
+ _baseUniq.forEach(copy.nodes(), function(v) {
409
+ copy.setParent(v, findParent(v));
410
+ });
411
+ }
412
+ return copy;
413
+ }
414
+ /* === Edge functions ========== */
415
+ setDefaultEdgeLabel(newDefault) {
416
+ if (!index.isFunction(newDefault)) {
417
+ newDefault = index.constant$2(newDefault);
418
+ }
419
+ this._defaultEdgeLabelFn = newDefault;
420
+ return this;
421
+ }
422
+ edgeCount() {
423
+ return this._edgeCount;
424
+ }
425
+ edges() {
426
+ return values(this._edgeObjs);
427
+ }
428
+ setPath(vs, value) {
429
+ var self = this;
430
+ var args = arguments;
431
+ _baseUniq.reduce(vs, function(v, w) {
432
+ if (args.length > 1) {
433
+ self.setEdge(v, w, value);
434
+ } else {
435
+ self.setEdge(v, w);
436
+ }
437
+ return w;
438
+ });
439
+ return this;
440
+ }
441
+ /*
442
+ * setEdge(v, w, [value, [name]])
443
+ * setEdge({ v, w, [name] }, [value])
444
+ */
445
+ setEdge() {
446
+ var v, w, name, value;
447
+ var valueSpecified = false;
448
+ var arg0 = arguments[0];
449
+ if (typeof arg0 === "object" && arg0 !== null && "v" in arg0) {
450
+ v = arg0.v;
451
+ w = arg0.w;
452
+ name = arg0.name;
453
+ if (arguments.length === 2) {
454
+ value = arguments[1];
455
+ valueSpecified = true;
456
+ }
457
+ } else {
458
+ v = arg0;
459
+ w = arguments[1];
460
+ name = arguments[3];
461
+ if (arguments.length > 2) {
462
+ value = arguments[2];
463
+ valueSpecified = true;
464
+ }
465
+ }
466
+ v = "" + v;
467
+ w = "" + w;
468
+ if (!isUndefined(name)) {
469
+ name = "" + name;
470
+ }
471
+ var e = edgeArgsToId(this._isDirected, v, w, name);
472
+ if (Object.prototype.hasOwnProperty.call(this._edgeLabels, e)) {
473
+ if (valueSpecified) {
474
+ this._edgeLabels[e] = value;
475
+ }
476
+ return this;
477
+ }
478
+ if (!isUndefined(name) && !this._isMultigraph) {
479
+ throw new Error("Cannot set a named edge when isMultigraph = false");
480
+ }
481
+ this.setNode(v);
482
+ this.setNode(w);
483
+ this._edgeLabels[e] = valueSpecified ? value : this._defaultEdgeLabelFn(v, w, name);
484
+ var edgeObj = edgeArgsToObj(this._isDirected, v, w, name);
485
+ v = edgeObj.v;
486
+ w = edgeObj.w;
487
+ Object.freeze(edgeObj);
488
+ this._edgeObjs[e] = edgeObj;
489
+ incrementOrInitEntry(this._preds[w], v);
490
+ incrementOrInitEntry(this._sucs[v], w);
491
+ this._in[w][e] = edgeObj;
492
+ this._out[v][e] = edgeObj;
493
+ this._edgeCount++;
494
+ return this;
495
+ }
496
+ edge(v, w, name) {
497
+ var e = arguments.length === 1 ? edgeObjToId(this._isDirected, arguments[0]) : edgeArgsToId(this._isDirected, v, w, name);
498
+ return this._edgeLabels[e];
499
+ }
500
+ hasEdge(v, w, name) {
501
+ var e = arguments.length === 1 ? edgeObjToId(this._isDirected, arguments[0]) : edgeArgsToId(this._isDirected, v, w, name);
502
+ return Object.prototype.hasOwnProperty.call(this._edgeLabels, e);
503
+ }
504
+ removeEdge(v, w, name) {
505
+ var e = arguments.length === 1 ? edgeObjToId(this._isDirected, arguments[0]) : edgeArgsToId(this._isDirected, v, w, name);
506
+ var edge = this._edgeObjs[e];
507
+ if (edge) {
508
+ v = edge.v;
509
+ w = edge.w;
510
+ delete this._edgeLabels[e];
511
+ delete this._edgeObjs[e];
512
+ decrementOrRemoveEntry(this._preds[w], v);
513
+ decrementOrRemoveEntry(this._sucs[v], w);
514
+ delete this._in[w][e];
515
+ delete this._out[v][e];
516
+ this._edgeCount--;
517
+ }
518
+ return this;
519
+ }
520
+ inEdges(v, u) {
521
+ var inV = this._in[v];
522
+ if (inV) {
523
+ var edges = values(inV);
524
+ if (!u) {
525
+ return edges;
526
+ }
527
+ return _baseUniq.filter(edges, function(edge) {
528
+ return edge.v === u;
529
+ });
530
+ }
531
+ }
532
+ outEdges(v, w) {
533
+ var outV = this._out[v];
534
+ if (outV) {
535
+ var edges = values(outV);
536
+ if (!w) {
537
+ return edges;
538
+ }
539
+ return _baseUniq.filter(edges, function(edge) {
540
+ return edge.w === w;
541
+ });
542
+ }
543
+ }
544
+ nodeEdges(v, w) {
545
+ var inEdges = this.inEdges(v, w);
546
+ if (inEdges) {
547
+ return inEdges.concat(this.outEdges(v, w));
548
+ }
549
+ }
550
+ }
551
+ Graph.prototype._nodeCount = 0;
552
+ Graph.prototype._edgeCount = 0;
553
+ function incrementOrInitEntry(map, k) {
554
+ if (map[k]) {
555
+ map[k]++;
556
+ } else {
557
+ map[k] = 1;
558
+ }
559
+ }
560
+ function decrementOrRemoveEntry(map, k) {
561
+ if (!--map[k]) {
562
+ delete map[k];
563
+ }
564
+ }
565
+ function edgeArgsToId(isDirected, v_, w_, name) {
566
+ var v = "" + v_;
567
+ var w = "" + w_;
568
+ if (!isDirected && v > w) {
569
+ var tmp = v;
570
+ v = w;
571
+ w = tmp;
572
+ }
573
+ return v + EDGE_KEY_DELIM + w + EDGE_KEY_DELIM + (isUndefined(name) ? DEFAULT_EDGE_NAME : name);
574
+ }
575
+ function edgeArgsToObj(isDirected, v_, w_, name) {
576
+ var v = "" + v_;
577
+ var w = "" + w_;
578
+ if (!isDirected && v > w) {
579
+ var tmp = v;
580
+ v = w;
581
+ w = tmp;
582
+ }
583
+ var edgeObj = { v, w };
584
+ if (name) {
585
+ edgeObj.name = name;
586
+ }
587
+ return edgeObj;
588
+ }
589
+ function edgeObjToId(isDirected, edgeObj) {
590
+ return edgeArgsToId(isDirected, edgeObj.v, edgeObj.w, edgeObj.name);
591
+ }
592
+ exports.Graph = Graph;
593
+ exports.baseClone = baseClone;
594
+ exports.isUndefined = isUndefined;
595
+ exports.values = values;
@@ -1,5 +1,5 @@
1
- import { a$ as copyObject, b0 as keys, b1 as keysIn, b2 as getSymbols, b3 as stubArray, aQ as arrayPush, b4 as getPrototype, b5 as baseGetAllKeys, b6 as cloneArrayBuffer, aO as Symbol$1, b7 as cloneTypedArray, b8 as isObjectLike, b9 as getTag, ba as baseUnary, bb as nodeUtil, bc as isObject, bd as copyArray, be as isBuffer, bf as cloneBuffer, bg as initCloneObject, bh as Stack, bi as getAllKeys, aH as isArray, bj as assignValue, aF as arrayMap, bk as baseRest, bl as isArrayLikeObject, bm as constant, bn as isFunction, bo as isEmpty } from "./index-BQvQI7yA.js";
2
- import { a as arrayEach, c as baseUniq, b as baseFlatten, f as filter, d as forEach, r as reduce } from "./_baseUniq-BQcAhV7E.js";
1
+ import { a$ as copyObject, b0 as keys, b1 as keysIn, b2 as getSymbols, b3 as stubArray, aQ as arrayPush, b4 as getPrototype, b5 as baseGetAllKeys, b6 as cloneArrayBuffer, aO as Symbol$1, b7 as cloneTypedArray, b8 as isObjectLike, b9 as getTag, ba as baseUnary, bb as nodeUtil, bc as isObject, bd as copyArray, be as isBuffer, bf as cloneBuffer, bg as initCloneObject, bh as Stack, bi as getAllKeys, aH as isArray, bj as assignValue, aF as arrayMap, bk as baseRest, bl as isArrayLikeObject, bm as constant, bn as isFunction, bo as isEmpty } from "./index-TgFTummf.js";
2
+ import { a as arrayEach, c as baseUniq, b as baseFlatten, f as filter, d as forEach, r as reduce } from "./_baseUniq-C6eXDRdi.js";
3
3
  function baseAssign(object, source) {
4
4
  return object && copyObject(source, keys(source), object);
5
5
  }