@graphrefly/graphrefly 0.44.0 → 0.46.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/README.md +22 -19
- package/dist/_internal-B23BagFd.d.cts +33 -0
- package/dist/_internal-B23BagFd.d.ts +33 -0
- package/dist/adaptive-rate-limiter-Dch_xYIi.d.cts +111 -0
- package/dist/adaptive-rate-limiter-Dch_xYIi.d.ts +111 -0
- package/dist/agents-C0Ji9ldU.d.cts +629 -0
- package/dist/agents-C9zexT7I.d.ts +629 -0
- package/dist/audit-BAXb3VOg.d.ts +246 -0
- package/dist/audit-C_bPfkqS.d.cts +246 -0
- package/dist/backoff-7KIK3WQW.js +24 -0
- package/dist/backoff-7KIK3WQW.js.map +1 -0
- package/dist/backoff-Bnb9OoPh.d.cts +6 -0
- package/dist/backoff-Bnb9OoPh.d.ts +6 -0
- package/dist/base/composition/index.cjs +811 -0
- package/dist/base/composition/index.cjs.map +1 -0
- package/dist/base/composition/index.d.cts +469 -0
- package/dist/base/composition/index.d.ts +469 -0
- package/dist/base/composition/index.js +40 -0
- package/dist/base/composition/index.js.map +1 -0
- package/dist/base/index.cjs +6336 -0
- package/dist/base/index.cjs.map +1 -0
- package/dist/base/index.d.cts +22 -0
- package/dist/base/index.d.ts +22 -0
- package/dist/base/index.js +259 -0
- package/dist/base/index.js.map +1 -0
- package/dist/base/io/index.cjs +3270 -0
- package/dist/base/io/index.cjs.map +1 -0
- package/dist/base/io/index.d.cts +2245 -0
- package/dist/base/io/index.d.ts +2245 -0
- package/dist/base/io/index.js +117 -0
- package/dist/base/io/index.js.map +1 -0
- package/dist/base/meta/index.cjs +43 -0
- package/dist/base/meta/index.cjs.map +1 -0
- package/dist/base/meta/index.d.cts +45 -0
- package/dist/base/meta/index.d.ts +45 -0
- package/dist/base/meta/index.js +13 -0
- package/dist/base/meta/index.js.map +1 -0
- package/dist/base/mutation/index.cjs +200 -0
- package/dist/base/mutation/index.cjs.map +1 -0
- package/dist/base/mutation/index.d.cts +177 -0
- package/dist/base/mutation/index.d.ts +177 -0
- package/dist/base/mutation/index.js +22 -0
- package/dist/base/mutation/index.js.map +1 -0
- package/dist/base/render/index.cjs +1120 -0
- package/dist/base/render/index.cjs.map +1 -0
- package/dist/{extra/render/index.d.ts → base/render/index.d.cts} +75 -31
- package/dist/{extra/render/index.d.cts → base/render/index.d.ts} +75 -31
- package/dist/base/render/index.js +24 -0
- package/dist/base/render/index.js.map +1 -0
- package/dist/base/sources/browser/index.cjs +172 -0
- package/dist/base/sources/browser/index.cjs.map +1 -0
- package/dist/base/sources/browser/index.d.cts +84 -0
- package/dist/base/sources/browser/index.d.ts +84 -0
- package/dist/base/sources/browser/index.js +151 -0
- package/dist/base/sources/browser/index.js.map +1 -0
- package/dist/base/sources/event/index.cjs +98 -0
- package/dist/base/sources/event/index.cjs.map +1 -0
- package/dist/base/sources/event/index.d.cts +91 -0
- package/dist/base/sources/event/index.d.ts +91 -0
- package/dist/base/sources/event/index.js +13 -0
- package/dist/base/sources/event/index.js.map +1 -0
- package/dist/base/sources/index.cjs +755 -0
- package/dist/base/sources/index.cjs.map +1 -0
- package/dist/{extra/sources.d.ts → base/sources/index.d.cts} +74 -301
- package/dist/{extra/sources.d.cts → base/sources/index.d.ts} +74 -301
- package/dist/base/sources/index.js +42 -0
- package/dist/base/sources/index.js.map +1 -0
- package/dist/base/sources/node/index.cjs +320 -0
- package/dist/base/sources/node/index.cjs.map +1 -0
- package/dist/{extra/node.d.ts → base/sources/node/index.d.cts} +35 -37
- package/dist/{extra/node.d.cts → base/sources/node/index.d.ts} +35 -37
- package/dist/base/sources/node/index.js +306 -0
- package/dist/base/sources/node/index.js.map +1 -0
- package/dist/base/utils/index.cjs +37 -0
- package/dist/base/utils/index.cjs.map +1 -0
- package/dist/base/utils/index.d.cts +37 -0
- package/dist/base/utils/index.d.ts +37 -0
- package/dist/base/utils/index.js +11 -0
- package/dist/base/utils/index.js.map +1 -0
- package/dist/base/worker/index.cjs +548 -0
- package/dist/base/worker/index.cjs.map +1 -0
- package/dist/base/worker/index.d.cts +207 -0
- package/dist/base/worker/index.d.ts +207 -0
- package/dist/base/worker/index.js +20 -0
- package/dist/base/worker/index.js.map +1 -0
- package/dist/breaker-C9skL3d8.d.ts +175 -0
- package/dist/breaker-ugSdq54q.d.cts +175 -0
- package/dist/{cascading-BglDkMdX.d.cts → cascading-CSSbKGrJ.d.ts} +3 -3
- package/dist/{cascading-MFgxu7Yo.d.ts → cascading-baGkiihI.d.cts} +3 -3
- package/dist/chunk-255UCBG4.js +58 -0
- package/dist/chunk-255UCBG4.js.map +1 -0
- package/dist/chunk-2LO3EL4W.js +1 -0
- package/dist/chunk-2LO3EL4W.js.map +1 -0
- package/dist/chunk-2OB3CEJS.js +1065 -0
- package/dist/chunk-2OB3CEJS.js.map +1 -0
- package/dist/chunk-36NMM65U.js +144 -0
- package/dist/chunk-36NMM65U.js.map +1 -0
- package/dist/chunk-3CEXCBN6.js +1 -0
- package/dist/chunk-3CEXCBN6.js.map +1 -0
- package/dist/chunk-3MUSLI6E.js +105 -0
- package/dist/chunk-3MUSLI6E.js.map +1 -0
- package/dist/chunk-3PSLNJDU.js +884 -0
- package/dist/chunk-3PSLNJDU.js.map +1 -0
- package/dist/chunk-3QZY5BI7.js +92 -0
- package/dist/chunk-3QZY5BI7.js.map +1 -0
- package/dist/chunk-42FQ27MQ.js +594 -0
- package/dist/chunk-42FQ27MQ.js.map +1 -0
- package/dist/chunk-4GYMCUDZ.js +1085 -0
- package/dist/chunk-4GYMCUDZ.js.map +1 -0
- package/dist/chunk-4S53H2KR.js +382 -0
- package/dist/chunk-4S53H2KR.js.map +1 -0
- package/dist/chunk-4XCHZRUJ.js +128 -0
- package/dist/chunk-4XCHZRUJ.js.map +1 -0
- package/dist/chunk-5THCXDWY.js +725 -0
- package/dist/chunk-5THCXDWY.js.map +1 -0
- package/dist/chunk-6XZYT4SW.js +256 -0
- package/dist/chunk-6XZYT4SW.js.map +1 -0
- package/dist/chunk-7EGRP2VX.js +76 -0
- package/dist/chunk-7EGRP2VX.js.map +1 -0
- package/dist/chunk-A7KV5UK4.js +150 -0
- package/dist/chunk-A7KV5UK4.js.map +1 -0
- package/dist/chunk-APY2SS5X.js +156 -0
- package/dist/chunk-APY2SS5X.js.map +1 -0
- package/dist/chunk-AZDQPQ3V.js +66 -0
- package/dist/chunk-AZDQPQ3V.js.map +1 -0
- package/dist/chunk-BU3SEFA5.js +90 -0
- package/dist/chunk-BU3SEFA5.js.map +1 -0
- package/dist/chunk-BXGZFGZ4.js +189 -0
- package/dist/chunk-BXGZFGZ4.js.map +1 -0
- package/dist/chunk-CGHORL6G.js +579 -0
- package/dist/chunk-CGHORL6G.js.map +1 -0
- package/dist/chunk-CXANAIZU.js +530 -0
- package/dist/chunk-CXANAIZU.js.map +1 -0
- package/dist/chunk-CZQHCKKG.js +1 -0
- package/dist/chunk-CZQHCKKG.js.map +1 -0
- package/dist/chunk-DKNHAICT.js +133 -0
- package/dist/chunk-DKNHAICT.js.map +1 -0
- package/dist/chunk-DM4OMPWK.js +584 -0
- package/dist/chunk-DM4OMPWK.js.map +1 -0
- package/dist/chunk-DMSNO6ZB.js +452 -0
- package/dist/chunk-DMSNO6ZB.js.map +1 -0
- package/dist/chunk-E5OZPDIW.js +229 -0
- package/dist/chunk-E5OZPDIW.js.map +1 -0
- package/dist/chunk-EVYY4X5A.js +509 -0
- package/dist/chunk-EVYY4X5A.js.map +1 -0
- package/dist/chunk-FDFD67UO.js +1 -0
- package/dist/chunk-FDFD67UO.js.map +1 -0
- package/dist/chunk-FMPF42Q4.js +13 -0
- package/dist/chunk-FMPF42Q4.js.map +1 -0
- package/dist/chunk-FR6RGA3B.js +1277 -0
- package/dist/chunk-FR6RGA3B.js.map +1 -0
- package/dist/chunk-FW23JYNQ.js +454 -0
- package/dist/chunk-FW23JYNQ.js.map +1 -0
- package/dist/chunk-GBCENOLN.js +1575 -0
- package/dist/chunk-GBCENOLN.js.map +1 -0
- package/dist/chunk-HL7HUJIX.js +1 -0
- package/dist/chunk-HL7HUJIX.js.map +1 -0
- package/dist/chunk-HULCUY35.js +2508 -0
- package/dist/chunk-HULCUY35.js.map +1 -0
- package/dist/chunk-IHTWQEDR.js +169 -0
- package/dist/chunk-IHTWQEDR.js.map +1 -0
- package/dist/chunk-IJRR6YAI.js +128 -0
- package/dist/chunk-IJRR6YAI.js.map +1 -0
- package/dist/chunk-JGFRAFDL.js +221 -0
- package/dist/chunk-JGFRAFDL.js.map +1 -0
- package/dist/chunk-KIIXR252.js +211 -0
- package/dist/chunk-KIIXR252.js.map +1 -0
- package/dist/chunk-KN3H5CNT.js +11 -0
- package/dist/chunk-KN3H5CNT.js.map +1 -0
- package/dist/chunk-KPG3DGLA.js +1 -0
- package/dist/chunk-KPG3DGLA.js.map +1 -0
- package/dist/chunk-KRNQ6RGQ.js +1 -0
- package/dist/chunk-KRNQ6RGQ.js.map +1 -0
- package/dist/chunk-LBAJK24K.js +1071 -0
- package/dist/chunk-LBAJK24K.js.map +1 -0
- package/dist/chunk-MLTPJMH6.js +417 -0
- package/dist/chunk-MLTPJMH6.js.map +1 -0
- package/dist/chunk-N3SZ7BMH.js +95 -0
- package/dist/chunk-N3SZ7BMH.js.map +1 -0
- package/dist/chunk-NDUD3IMO.js +540 -0
- package/dist/chunk-NDUD3IMO.js.map +1 -0
- package/dist/chunk-NY2PYHNC.js +873 -0
- package/dist/chunk-NY2PYHNC.js.map +1 -0
- package/dist/chunk-O3MT7DYI.js +225 -0
- package/dist/chunk-O3MT7DYI.js.map +1 -0
- package/dist/chunk-OCUDSN63.js +2386 -0
- package/dist/chunk-OCUDSN63.js.map +1 -0
- package/dist/chunk-OIWU3NYV.js +199 -0
- package/dist/chunk-OIWU3NYV.js.map +1 -0
- package/dist/chunk-OO5BM6CJ.js +1153 -0
- package/dist/chunk-OO5BM6CJ.js.map +1 -0
- package/dist/chunk-OQUIJT7A.js +1 -0
- package/dist/chunk-OQUIJT7A.js.map +1 -0
- package/dist/chunk-P5LBT622.js +105 -0
- package/dist/chunk-P5LBT622.js.map +1 -0
- package/dist/chunk-PKGQG5QQ.js +519 -0
- package/dist/chunk-PKGQG5QQ.js.map +1 -0
- package/dist/chunk-PKPO3JTZ.js +561 -0
- package/dist/chunk-PKPO3JTZ.js.map +1 -0
- package/dist/chunk-PL5UDIQ5.js +118 -0
- package/dist/chunk-PL5UDIQ5.js.map +1 -0
- package/dist/chunk-PZWISPIQ.js +432 -0
- package/dist/chunk-PZWISPIQ.js.map +1 -0
- package/dist/chunk-Q3EYOCZB.js +510 -0
- package/dist/chunk-Q3EYOCZB.js.map +1 -0
- package/dist/chunk-QMBYUVRL.js +15 -0
- package/dist/chunk-QMBYUVRL.js.map +1 -0
- package/dist/chunk-RAGGHLCV.js +200 -0
- package/dist/chunk-RAGGHLCV.js.map +1 -0
- package/dist/chunk-RGL53X5G.js +574 -0
- package/dist/chunk-RGL53X5G.js.map +1 -0
- package/dist/chunk-RJOG4IJU.js +1039 -0
- package/dist/chunk-RJOG4IJU.js.map +1 -0
- package/dist/chunk-SOOKUYVM.js +403 -0
- package/dist/chunk-SOOKUYVM.js.map +1 -0
- package/dist/chunk-T5BN5KG7.js +1 -0
- package/dist/chunk-T5BN5KG7.js.map +1 -0
- package/dist/chunk-TP7244Y6.js +207 -0
- package/dist/chunk-TP7244Y6.js.map +1 -0
- package/dist/chunk-TSBFTJKM.js +57 -0
- package/dist/chunk-TSBFTJKM.js.map +1 -0
- package/dist/chunk-URQ2CBBF.js +143 -0
- package/dist/chunk-URQ2CBBF.js.map +1 -0
- package/dist/chunk-W2BOPXTI.js +1 -0
- package/dist/chunk-W2BOPXTI.js.map +1 -0
- package/dist/chunk-WKSWLSCX.js +207 -0
- package/dist/chunk-WKSWLSCX.js.map +1 -0
- package/dist/chunk-Y52CS6YA.js +88 -0
- package/dist/chunk-Y52CS6YA.js.map +1 -0
- package/dist/chunk-YCBUWK77.js +92 -0
- package/dist/chunk-YCBUWK77.js.map +1 -0
- package/dist/chunk-YJ4U2D2C.js +314 -0
- package/dist/chunk-YJ4U2D2C.js.map +1 -0
- package/dist/chunk-Z4YXAUDN.js +239 -0
- package/dist/chunk-Z4YXAUDN.js.map +1 -0
- package/dist/chunk-Z6EGP5D7.js +92 -0
- package/dist/chunk-Z6EGP5D7.js.map +1 -0
- package/dist/compat/index.cjs +3100 -9
- package/dist/compat/index.cjs.map +1 -0
- package/dist/compat/index.d.cts +112 -18
- package/dist/compat/index.d.ts +112 -18
- package/dist/compat/index.js +176 -1
- package/dist/compat/index.js.map +1 -0
- package/dist/compat/jotai/index.cjs +149 -1
- package/dist/compat/jotai/index.cjs.map +1 -0
- package/dist/compat/jotai/index.d.cts +2 -2
- package/dist/compat/jotai/index.d.ts +2 -2
- package/dist/compat/jotai/index.js +8 -1
- package/dist/compat/jotai/index.js.map +1 -0
- package/dist/compat/nanostores/index.cjs +205 -1
- package/dist/compat/nanostores/index.cjs.map +1 -0
- package/dist/compat/nanostores/index.d.cts +2 -2
- package/dist/compat/nanostores/index.d.ts +2 -2
- package/dist/compat/nanostores/index.js +22 -1
- package/dist/compat/nanostores/index.js.map +1 -0
- package/dist/compat/nestjs/index.cjs +2241 -9
- package/dist/compat/nestjs/index.cjs.map +1 -0
- package/dist/compat/nestjs/index.d.cts +7 -10
- package/dist/compat/nestjs/index.d.ts +7 -10
- package/dist/compat/nestjs/index.js +78 -1
- package/dist/compat/nestjs/index.js.map +1 -0
- package/dist/compat/react/index.cjs +114 -1
- package/dist/compat/react/index.cjs.map +1 -0
- package/dist/compat/react/index.d.cts +2 -2
- package/dist/compat/react/index.d.ts +2 -2
- package/dist/compat/react/index.js +12 -1
- package/dist/compat/react/index.js.map +1 -0
- package/dist/compat/solid/index.cjs +101 -1
- package/dist/compat/solid/index.cjs.map +1 -0
- package/dist/compat/solid/index.d.cts +2 -2
- package/dist/compat/solid/index.d.ts +2 -2
- package/dist/compat/solid/index.js +12 -1
- package/dist/compat/solid/index.js.map +1 -0
- package/dist/compat/svelte/index.cjs +104 -1
- package/dist/compat/svelte/index.cjs.map +1 -0
- package/dist/compat/svelte/index.d.cts +2 -2
- package/dist/compat/svelte/index.d.ts +2 -2
- package/dist/compat/svelte/index.js +12 -1
- package/dist/compat/svelte/index.js.map +1 -0
- package/dist/compat/vue/index.cjs +119 -1
- package/dist/compat/vue/index.cjs.map +1 -0
- package/dist/compat/vue/index.d.cts +2 -2
- package/dist/compat/vue/index.d.ts +2 -2
- package/dist/compat/vue/index.js +12 -1
- package/dist/compat/vue/index.js.map +1 -0
- package/dist/compat/zustand/index.cjs +69 -3
- package/dist/compat/zustand/index.cjs.map +1 -0
- package/dist/compat/zustand/index.d.cts +2 -6
- package/dist/compat/zustand/index.d.ts +2 -6
- package/dist/compat/zustand/index.js +8 -1
- package/dist/compat/zustand/index.js.map +1 -0
- package/dist/distill-De6Rnn15.d.cts +48 -0
- package/dist/distill-De6Rnn15.d.ts +48 -0
- package/dist/external-register-CWyroXb_.d.cts +138 -0
- package/dist/external-register-CWyroXb_.d.ts +138 -0
- package/dist/{fallback-74oxi34l.d.cts → fallback-Bx46zqky.d.cts} +3 -10
- package/dist/{fallback-DUyyBTBK.d.ts → fallback-pIWW8A2d.d.ts} +3 -10
- package/dist/guarded-execution-BcdtxeBk.d.ts +207 -0
- package/dist/guarded-execution-C-3hnP6A.d.cts +207 -0
- package/dist/{index-CBGUK09R.d.ts → index-5SU_O78r.d.cts} +5 -5
- package/dist/{index-BmZXHqkE.d.ts → index-B6pxYJzO.d.cts} +1 -1
- package/dist/{index-hcDJ8PSI.d.cts → index-B6pxYJzO.d.ts} +1 -1
- package/dist/{index-C5stwKcw.d.cts → index-BFsng6v1.d.cts} +1 -1
- package/dist/{index-CdAlHFEt.d.ts → index-BFsng6v1.d.ts} +1 -1
- package/dist/{index-_6ODbuOu.d.cts → index-Bg-LwEt-.d.cts} +1 -1
- package/dist/{index-CviRnE4K.d.ts → index-Bg-LwEt-.d.ts} +1 -1
- package/dist/{index-CBBLl_rc.d.ts → index-Brp888t0.d.cts} +1 -1
- package/dist/{index-BQSKmbuG.d.cts → index-Brp888t0.d.ts} +1 -1
- package/dist/{index-sqkqlb1p.d.ts → index-CDfk6jHN.d.cts} +1 -1
- package/dist/{index-ZVQhLa2i.d.cts → index-CDfk6jHN.d.ts} +1 -1
- package/dist/{index-Climxqsu.d.cts → index-CEXCtYYJ.d.ts} +5 -5
- package/dist/index-DLAxYaN5.d.cts +169 -0
- package/dist/index-DLAxYaN5.d.ts +169 -0
- package/dist/{index-CK29LV56.d.cts → index-DeWbQzMe.d.cts} +1 -1
- package/dist/{index-CPQlGA29.d.ts → index-DeWbQzMe.d.ts} +1 -1
- package/dist/{index-BrPrLl4e.d.cts → index-dX9IzPqj.d.cts} +1 -1
- package/dist/{index-Dgl1HpPn.d.ts → index-dX9IzPqj.d.ts} +1 -1
- package/dist/index.cjs +25934 -191
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +58 -94
- package/dist/index.d.ts +58 -94
- package/dist/index.js +852 -1
- package/dist/index.js.map +1 -0
- package/dist/layout-types-B5aiHYgk.d.cts +72 -0
- package/dist/layout-types-B5aiHYgk.d.ts +72 -0
- package/dist/memory-composers-BryDrRBX.d.cts +529 -0
- package/dist/memory-composers-CVQqPYEV.d.ts +529 -0
- package/dist/{observable-DWjNfLvC.d.ts → observable-BXQoW1P-.d.cts} +1 -1
- package/dist/{observable-e3eiPPFy.d.cts → observable-BXQoW1P-.d.ts} +1 -1
- package/dist/{pipeline-graph-Sgj0gCwn.d.ts → pipeline-graph-Ce47CB6Y.d.cts} +13 -10
- package/dist/{pipeline-graph-CIKhynsF.d.cts → pipeline-graph-DXCwY9vG.d.ts} +13 -10
- package/dist/presets/ai/index.cjs +4377 -0
- package/dist/presets/ai/index.cjs.map +1 -0
- package/dist/presets/ai/index.d.cts +98 -0
- package/dist/presets/ai/index.d.ts +98 -0
- package/dist/presets/ai/index.js +54 -0
- package/dist/presets/ai/index.js.map +1 -0
- package/dist/presets/harness/index.cjs +5929 -0
- package/dist/presets/harness/index.cjs.map +1 -0
- package/dist/presets/harness/index.d.cts +566 -0
- package/dist/presets/harness/index.d.ts +566 -0
- package/dist/presets/harness/index.js +71 -0
- package/dist/presets/harness/index.js.map +1 -0
- package/dist/presets/index.cjs +9782 -0
- package/dist/presets/index.cjs.map +1 -0
- package/dist/presets/index.d.cts +28 -0
- package/dist/presets/index.d.ts +28 -0
- package/dist/presets/index.js +129 -0
- package/dist/presets/index.js.map +1 -0
- package/dist/presets/inspect/index.cjs +1087 -0
- package/dist/presets/inspect/index.cjs.map +1 -0
- package/dist/presets/inspect/index.d.cts +172 -0
- package/dist/presets/inspect/index.d.ts +172 -0
- package/dist/presets/inspect/index.js +21 -0
- package/dist/presets/inspect/index.js.map +1 -0
- package/dist/presets/resilience/index.cjs +1593 -0
- package/dist/presets/resilience/index.cjs.map +1 -0
- package/dist/presets/resilience/index.d.cts +205 -0
- package/dist/presets/resilience/index.d.ts +205 -0
- package/dist/presets/resilience/index.js +18 -0
- package/dist/presets/resilience/index.js.map +1 -0
- package/dist/rate-limiter-CEALq4N1.d.ts +559 -0
- package/dist/rate-limiter-DpVbSYdH.d.cts +559 -0
- package/dist/{reactive-layout-DOTs9P3X.d.ts → reactive-layout-fswlBUvX.d.cts} +19 -7
- package/dist/{reactive-layout-DgctbqZo.d.cts → reactive-layout-fswlBUvX.d.ts} +19 -7
- package/dist/retry-BDbRZ_gx.d.ts +125 -0
- package/dist/retry-DWuhjvsA.d.cts +125 -0
- package/dist/solutions/index.cjs +8200 -0
- package/dist/solutions/index.cjs.map +1 -0
- package/dist/solutions/index.d.cts +23 -0
- package/dist/solutions/index.d.ts +23 -0
- package/dist/solutions/index.js +55 -0
- package/dist/solutions/index.js.map +1 -0
- package/dist/spawnable-5mDY501F.d.cts +746 -0
- package/dist/spawnable-D3lR0oQu.d.ts +746 -0
- package/dist/status-U-rUI79b.d.cts +84 -0
- package/dist/status-U-rUI79b.d.ts +84 -0
- package/dist/timeout-U5O4ESK3.js +12 -0
- package/dist/timeout-U5O4ESK3.js.map +1 -0
- package/dist/{types-CWFysE9E.d.ts → types-BB5Lw-pB.d.cts} +3 -3
- package/dist/{types-C0_yquda.d.cts → types-BB5Lw-pB.d.ts} +3 -3
- package/dist/types-CJWIMJiZ.d.ts +548 -0
- package/dist/types-vCq7ShIm.d.cts +548 -0
- package/dist/utils/ai/browser.cjs +2169 -0
- package/dist/utils/ai/browser.cjs.map +1 -0
- package/dist/{patterns → utils}/ai/browser.d.cts +7 -5
- package/dist/{patterns → utils}/ai/browser.d.ts +7 -5
- package/dist/utils/ai/browser.js +255 -0
- package/dist/utils/ai/browser.js.map +1 -0
- package/dist/utils/ai/index.cjs +8468 -0
- package/dist/utils/ai/index.cjs.map +1 -0
- package/dist/{index-CR8QpwX8.d.ts → utils/ai/index.d.cts} +73 -976
- package/dist/{index-UPSiS-X7.d.cts → utils/ai/index.d.ts} +73 -976
- package/dist/utils/ai/index.js +173 -0
- package/dist/utils/ai/index.js.map +1 -0
- package/dist/utils/ai/node.cjs +648 -0
- package/dist/utils/ai/node.cjs.map +1 -0
- package/dist/{patterns → utils}/ai/node.d.cts +5 -7
- package/dist/{patterns → utils}/ai/node.d.ts +5 -7
- package/dist/utils/ai/node.js +84 -0
- package/dist/utils/ai/node.js.map +1 -0
- package/dist/utils/cqrs/index.cjs +1036 -0
- package/dist/utils/cqrs/index.cjs.map +1 -0
- package/dist/{index-CeFiHtAg.d.ts → utils/cqrs/index.d.cts} +7 -37
- package/dist/{index-B-_tFaqV.d.cts → utils/cqrs/index.d.ts} +7 -37
- package/dist/utils/cqrs/index.js +18 -0
- package/dist/utils/cqrs/index.js.map +1 -0
- package/dist/utils/demo-shell/index.cjs +865 -0
- package/dist/utils/demo-shell/index.cjs.map +1 -0
- package/dist/{index-B8YnZpIR.d.ts → utils/demo-shell/index.d.cts} +4 -16
- package/dist/{index-Cwv0KWcU.d.cts → utils/demo-shell/index.d.ts} +4 -16
- package/dist/utils/demo-shell/index.js +13 -0
- package/dist/utils/demo-shell/index.js.map +1 -0
- package/dist/utils/domain-templates/index.cjs +732 -0
- package/dist/utils/domain-templates/index.cjs.map +1 -0
- package/dist/{index-CzLVrjxn.d.ts → utils/domain-templates/index.d.cts} +3 -20
- package/dist/{index-BaQaY_IQ.d.cts → utils/domain-templates/index.d.ts} +3 -20
- package/dist/utils/domain-templates/index.js +17 -0
- package/dist/utils/domain-templates/index.js.map +1 -0
- package/dist/utils/graphspec/index.cjs +1174 -0
- package/dist/utils/graphspec/index.cjs.map +1 -0
- package/dist/{index-CMh5Rz1y.d.ts → utils/graphspec/index.d.cts} +106 -42
- package/dist/{index-CS0LTlB8.d.cts → utils/graphspec/index.d.ts} +106 -42
- package/dist/utils/graphspec/index.js +35 -0
- package/dist/utils/graphspec/index.js.map +1 -0
- package/dist/utils/harness/index.cjs +656 -0
- package/dist/utils/harness/index.cjs.map +1 -0
- package/dist/utils/harness/index.d.cts +542 -0
- package/dist/utils/harness/index.d.ts +542 -0
- package/dist/utils/harness/index.js +56 -0
- package/dist/utils/harness/index.js.map +1 -0
- package/dist/utils/index.cjs +17609 -0
- package/dist/utils/index.cjs.map +1 -0
- package/dist/utils/index.d.cts +96 -0
- package/dist/utils/index.d.ts +96 -0
- package/dist/utils/index.js +514 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/inspect/index.cjs +807 -0
- package/dist/utils/inspect/index.cjs.map +1 -0
- package/dist/utils/inspect/index.d.cts +123 -0
- package/dist/utils/inspect/index.d.ts +123 -0
- package/dist/utils/inspect/index.js +30 -0
- package/dist/utils/inspect/index.js.map +1 -0
- package/dist/utils/job-queue/index.cjs +717 -0
- package/dist/utils/job-queue/index.cjs.map +1 -0
- package/dist/{index-DisjX8a-.d.ts → utils/job-queue/index.d.cts} +5 -26
- package/dist/{index-DV_1YuVk.d.cts → utils/job-queue/index.d.ts} +5 -26
- package/dist/utils/job-queue/index.js +18 -0
- package/dist/utils/job-queue/index.js.map +1 -0
- package/dist/utils/memory/index.cjs +1451 -0
- package/dist/utils/memory/index.cjs.map +1 -0
- package/dist/{index-CZ3r5Rxp.d.ts → utils/memory/index.d.cts} +242 -34
- package/dist/{index-B17QddL1.d.cts → utils/memory/index.d.ts} +242 -34
- package/dist/utils/memory/index.js +19 -0
- package/dist/utils/memory/index.js.map +1 -0
- package/dist/utils/messaging/index.cjs +666 -0
- package/dist/utils/messaging/index.cjs.map +1 -0
- package/dist/utils/messaging/index.d.cts +562 -0
- package/dist/utils/messaging/index.d.ts +562 -0
- package/dist/utils/messaging/index.js +50 -0
- package/dist/utils/messaging/index.js.map +1 -0
- package/dist/utils/orchestration/index.cjs +876 -0
- package/dist/utils/orchestration/index.cjs.map +1 -0
- package/dist/utils/orchestration/index.d.cts +233 -0
- package/dist/utils/orchestration/index.d.ts +233 -0
- package/dist/utils/orchestration/index.js +19 -0
- package/dist/utils/orchestration/index.js.map +1 -0
- package/dist/utils/process/index.cjs +743 -0
- package/dist/utils/process/index.cjs.map +1 -0
- package/dist/{index-p09KSrTN.d.ts → utils/process/index.d.cts} +97 -44
- package/dist/{index-CasX6Pfq.d.cts → utils/process/index.d.ts} +97 -44
- package/dist/utils/process/index.js +14 -0
- package/dist/utils/process/index.js.map +1 -0
- package/dist/utils/reactive-layout/index.cjs +1607 -0
- package/dist/utils/reactive-layout/index.cjs.map +1 -0
- package/dist/{index-B5S8ULbU.d.ts → utils/reactive-layout/index.d.cts} +58 -81
- package/dist/{index-Dc4AYqrJ.d.cts → utils/reactive-layout/index.d.ts} +58 -81
- package/dist/utils/reactive-layout/index.js +52 -0
- package/dist/utils/reactive-layout/index.js.map +1 -0
- package/dist/utils/reduction/index.cjs +203 -0
- package/dist/utils/reduction/index.cjs.map +1 -0
- package/dist/{index-Byu-OpX_.d.ts → utils/reduction/index.d.cts} +6 -17
- package/dist/{index-tRCxuAXF.d.cts → utils/reduction/index.d.ts} +6 -17
- package/dist/utils/reduction/index.js +14 -0
- package/dist/utils/reduction/index.js.map +1 -0
- package/dist/utils/resilience/index.cjs +1617 -0
- package/dist/utils/resilience/index.cjs.map +1 -0
- package/dist/utils/resilience/index.d.cts +9 -0
- package/dist/utils/resilience/index.d.ts +9 -0
- package/dist/utils/resilience/index.js +44 -0
- package/dist/utils/resilience/index.js.map +1 -0
- package/dist/utils/surface/index.cjs +1070 -0
- package/dist/utils/surface/index.cjs.map +1 -0
- package/dist/{index-CYq8vAyV.d.ts → utils/surface/index.d.cts} +7 -58
- package/dist/{index-CSOmP7xT.d.cts → utils/surface/index.d.ts} +7 -58
- package/dist/utils/surface/index.js +30 -0
- package/dist/utils/surface/index.js.map +1 -0
- package/dist/utils/topology-view/index.cjs +620 -0
- package/dist/utils/topology-view/index.cjs.map +1 -0
- package/dist/utils/topology-view/index.d.cts +68 -0
- package/dist/utils/topology-view/index.d.ts +68 -0
- package/dist/utils/topology-view/index.js +11 -0
- package/dist/utils/topology-view/index.js.map +1 -0
- package/package.json +664 -584
- package/dist/backoff-HPZMEZNF.js +0 -1
- package/dist/chunk-2T7U5EU6.js +0 -1
- package/dist/chunk-3G5U5QNE.js +0 -5
- package/dist/chunk-4VVTGLXJ.js +0 -1
- package/dist/chunk-5M4CCMMD.js +0 -45
- package/dist/chunk-5QDBSZBV.js +0 -1
- package/dist/chunk-5XJ6B66J.js +0 -1
- package/dist/chunk-6QZNQS5B.js +0 -1
- package/dist/chunk-6X7AFUJV.js +0 -9
- package/dist/chunk-7K6PWTDQ.js +0 -1
- package/dist/chunk-7LIAPXJB.js +0 -1
- package/dist/chunk-7WPU3UHQ.js +0 -1
- package/dist/chunk-A5WCQ5NO.js +0 -1
- package/dist/chunk-APPIWSGD.js +0 -84
- package/dist/chunk-BEZWM2SY.js +0 -1
- package/dist/chunk-C72GO4IZ.js +0 -1
- package/dist/chunk-CB676TKJ.js +0 -1
- package/dist/chunk-CE6TI2TL.js +0 -1
- package/dist/chunk-CE72X3WO.js +0 -1
- package/dist/chunk-CK2E7BTU.js +0 -1
- package/dist/chunk-CLVB32RD.js +0 -1
- package/dist/chunk-CRVT7D2P.js +0 -1
- package/dist/chunk-D5RFJOZ2.js +0 -1
- package/dist/chunk-D7GPHKFH.js +0 -1
- package/dist/chunk-DHRX7JX4.js +0 -2
- package/dist/chunk-ESMPEKEV.js +0 -1
- package/dist/chunk-F672GV32.js +0 -1
- package/dist/chunk-FZMYDOWV.js +0 -1
- package/dist/chunk-GHBWHMRZ.js +0 -1
- package/dist/chunk-GLERH466.js +0 -1
- package/dist/chunk-GPW2V3RE.js +0 -1
- package/dist/chunk-HIDYF36O.js +0 -1
- package/dist/chunk-HITNVN6B.js +0 -3
- package/dist/chunk-HY4DJBA7.js +0 -5
- package/dist/chunk-KZIEYVXN.js +0 -1
- package/dist/chunk-L6NSJVJZ.js +0 -1
- package/dist/chunk-N4MQX6JU.js +0 -18
- package/dist/chunk-N7FHEL4D.js +0 -1
- package/dist/chunk-NTEURFZH.js +0 -1
- package/dist/chunk-OIVP6KFV.js +0 -1
- package/dist/chunk-OPHBU3LG.js +0 -1
- package/dist/chunk-OYQOZP2F.js +0 -5
- package/dist/chunk-PTZK576G.js +0 -1
- package/dist/chunk-QYADASLV.js +0 -1
- package/dist/chunk-ST7UXLWR.js +0 -1
- package/dist/chunk-SVY7VUYU.js +0 -1
- package/dist/chunk-TK3NWWD4.js +0 -1
- package/dist/chunk-TSOYJ743.js +0 -1
- package/dist/chunk-UNGSTR4X.js +0 -61
- package/dist/chunk-VIMF6LGM.js +0 -1
- package/dist/chunk-VJLMUKOI.js +0 -1
- package/dist/chunk-VN6RDSK2.js +0 -1
- package/dist/chunk-VV4N5P64.js +0 -1
- package/dist/chunk-W3I423PS.js +0 -1
- package/dist/chunk-WJR24TAG.js +0 -1
- package/dist/chunk-XTGKMHSW.js +0 -1
- package/dist/chunk-YBB7ZGTY.js +0 -1
- package/dist/chunk-Z4NPUARF.js +0 -1
- package/dist/chunk-ZGNQRPDT.js +0 -1
- package/dist/chunk-ZKPSFFKU.js +0 -1
- package/dist/chunk-ZLV5SQSX.js +0 -1
- package/dist/content-addressed-storage-4-ST1tYk.d.cts +0 -124
- package/dist/content-addressed-storage-DuYMjV7o.d.ts +0 -124
- package/dist/core/index.cjs +0 -1
- package/dist/core/index.d.cts +0 -3
- package/dist/core/index.d.ts +0 -3
- package/dist/core/index.js +0 -1
- package/dist/decay-BvOWTZ00.d.ts +0 -112
- package/dist/decay-CFlLvXUT.d.cts +0 -112
- package/dist/extra/browser.cjs +0 -1
- package/dist/extra/browser.d.cts +0 -4
- package/dist/extra/browser.d.ts +0 -4
- package/dist/extra/browser.js +0 -1
- package/dist/extra/index.cjs +0 -20
- package/dist/extra/index.d.cts +0 -17
- package/dist/extra/index.d.ts +0 -17
- package/dist/extra/index.js +0 -1
- package/dist/extra/node.cjs +0 -2
- package/dist/extra/node.js +0 -2
- package/dist/extra/operators.cjs +0 -1
- package/dist/extra/operators.d.cts +0 -958
- package/dist/extra/operators.d.ts +0 -958
- package/dist/extra/operators.js +0 -1
- package/dist/extra/reactive.cjs +0 -1
- package/dist/extra/reactive.d.cts +0 -353
- package/dist/extra/reactive.d.ts +0 -353
- package/dist/extra/reactive.js +0 -1
- package/dist/extra/render/index.cjs +0 -5
- package/dist/extra/render/index.js +0 -1
- package/dist/extra/sources.cjs +0 -3
- package/dist/extra/sources.js +0 -1
- package/dist/extra/storage-browser.cjs +0 -1
- package/dist/extra/storage-browser.d.cts +0 -37
- package/dist/extra/storage-browser.d.ts +0 -37
- package/dist/extra/storage-browser.js +0 -1
- package/dist/extra/storage-core.cjs +0 -1
- package/dist/extra/storage-core.d.cts +0 -28
- package/dist/extra/storage-core.d.ts +0 -28
- package/dist/extra/storage-core.js +0 -1
- package/dist/extra/storage-node.cjs +0 -1
- package/dist/extra/storage-node.d.cts +0 -2
- package/dist/extra/storage-node.d.ts +0 -2
- package/dist/extra/storage-node.js +0 -0
- package/dist/extra/storage-tiers-browser.cjs +0 -1
- package/dist/extra/storage-tiers-browser.d.cts +0 -120
- package/dist/extra/storage-tiers-browser.d.ts +0 -120
- package/dist/extra/storage-tiers-browser.js +0 -1
- package/dist/extra/storage-tiers-node.cjs +0 -1
- package/dist/extra/storage-tiers-node.d.cts +0 -210
- package/dist/extra/storage-tiers-node.d.ts +0 -210
- package/dist/extra/storage-tiers-node.js +0 -1
- package/dist/extra/storage-tiers.cjs +0 -1
- package/dist/extra/storage-tiers.d.cts +0 -412
- package/dist/extra/storage-tiers.d.ts +0 -412
- package/dist/extra/storage-tiers.js +0 -1
- package/dist/graph/index.cjs +0 -7
- package/dist/graph/index.d.cts +0 -7
- package/dist/graph/index.d.ts +0 -7
- package/dist/graph/index.js +0 -1
- package/dist/graph-CWvEUQAq.d.cts +0 -1861
- package/dist/graph-D9LFnda9.d.ts +0 -1861
- package/dist/index-5k1T6jl0.d.cts +0 -121
- package/dist/index-9770hRuQ.d.cts +0 -779
- package/dist/index-B1F8Enjf.d.ts +0 -704
- package/dist/index-BHskSB8v.d.ts +0 -3413
- package/dist/index-BIYAkbAi.d.cts +0 -26
- package/dist/index-BoJ5JHxI.d.ts +0 -557
- package/dist/index-BocU7pqs.d.ts +0 -779
- package/dist/index-BxNs2HB9.d.cts +0 -1858
- package/dist/index-C1T3d7V-.d.cts +0 -704
- package/dist/index-C5ri2Axc.d.cts +0 -301
- package/dist/index-C9l6OEBL.d.ts +0 -26
- package/dist/index-CC-AvFTy.d.cts +0 -557
- package/dist/index-CJF1URuX.d.ts +0 -121
- package/dist/index-CdTelp1M.d.ts +0 -202
- package/dist/index-Cj3WohTd.d.cts +0 -202
- package/dist/index-Co7uli2l.d.cts +0 -3413
- package/dist/index-D0aciIex.d.cts +0 -209
- package/dist/index-DHen9Klo.d.ts +0 -1858
- package/dist/index-Yq60JP3s.d.ts +0 -209
- package/dist/index-nozs3fFC.d.ts +0 -301
- package/dist/node-kK3CvTrR.d.cts +0 -1347
- package/dist/node-kK3CvTrR.d.ts +0 -1347
- package/dist/patterns/ai/browser.cjs +0 -8
- package/dist/patterns/ai/browser.js +0 -3
- package/dist/patterns/ai/index.cjs +0 -74
- package/dist/patterns/ai/index.d.cts +0 -20
- package/dist/patterns/ai/index.d.ts +0 -20
- package/dist/patterns/ai/index.js +0 -1
- package/dist/patterns/ai/node.cjs +0 -1
- package/dist/patterns/ai/node.js +0 -1
- package/dist/patterns/cqrs/index.cjs +0 -3
- package/dist/patterns/cqrs/index.d.cts +0 -8
- package/dist/patterns/cqrs/index.d.ts +0 -8
- package/dist/patterns/cqrs/index.js +0 -1
- package/dist/patterns/demo-shell/index.cjs +0 -5
- package/dist/patterns/demo-shell/index.d.cts +0 -7
- package/dist/patterns/demo-shell/index.d.ts +0 -7
- package/dist/patterns/demo-shell/index.js +0 -1
- package/dist/patterns/domain-templates/index.cjs +0 -3
- package/dist/patterns/domain-templates/index.d.cts +0 -6
- package/dist/patterns/domain-templates/index.d.ts +0 -6
- package/dist/patterns/domain-templates/index.js +0 -1
- package/dist/patterns/graphspec/index.cjs +0 -86
- package/dist/patterns/graphspec/index.d.cts +0 -8
- package/dist/patterns/graphspec/index.d.ts +0 -8
- package/dist/patterns/graphspec/index.js +0 -1
- package/dist/patterns/harness/index.cjs +0 -48
- package/dist/patterns/harness/index.d.cts +0 -13
- package/dist/patterns/harness/index.d.ts +0 -13
- package/dist/patterns/harness/index.js +0 -1
- package/dist/patterns/inspect/index.cjs +0 -3
- package/dist/patterns/inspect/index.d.cts +0 -9
- package/dist/patterns/inspect/index.d.ts +0 -9
- package/dist/patterns/inspect/index.js +0 -1
- package/dist/patterns/job-queue/index.cjs +0 -3
- package/dist/patterns/job-queue/index.d.cts +0 -9
- package/dist/patterns/job-queue/index.d.ts +0 -9
- package/dist/patterns/job-queue/index.js +0 -1
- package/dist/patterns/memory/index.cjs +0 -3
- package/dist/patterns/memory/index.d.cts +0 -8
- package/dist/patterns/memory/index.d.ts +0 -8
- package/dist/patterns/memory/index.js +0 -1
- package/dist/patterns/messaging/index.cjs +0 -3
- package/dist/patterns/messaging/index.d.cts +0 -7
- package/dist/patterns/messaging/index.d.ts +0 -7
- package/dist/patterns/messaging/index.js +0 -1
- package/dist/patterns/orchestration/index.cjs +0 -3
- package/dist/patterns/orchestration/index.d.cts +0 -8
- package/dist/patterns/orchestration/index.d.ts +0 -8
- package/dist/patterns/orchestration/index.js +0 -1
- package/dist/patterns/process/index.cjs +0 -3
- package/dist/patterns/process/index.d.cts +0 -10
- package/dist/patterns/process/index.d.ts +0 -10
- package/dist/patterns/process/index.js +0 -1
- package/dist/patterns/reactive-layout/index.cjs +0 -4
- package/dist/patterns/reactive-layout/index.d.cts +0 -7
- package/dist/patterns/reactive-layout/index.d.ts +0 -7
- package/dist/patterns/reactive-layout/index.js +0 -1
- package/dist/patterns/reduction/index.cjs +0 -3
- package/dist/patterns/reduction/index.d.cts +0 -6
- package/dist/patterns/reduction/index.d.ts +0 -6
- package/dist/patterns/reduction/index.js +0 -1
- package/dist/patterns/surface/index.cjs +0 -13
- package/dist/patterns/surface/index.d.cts +0 -9
- package/dist/patterns/surface/index.d.ts +0 -9
- package/dist/patterns/surface/index.js +0 -1
- package/dist/reactive-log-BKALbfal.d.ts +0 -223
- package/dist/reactive-log-DIGdYqQ6.d.cts +0 -223
- package/dist/reactive-map-CEFGp8TK.d.cts +0 -296
- package/dist/reactive-map-DS_SIAxv.d.ts +0 -296
- package/dist/resilience-6LYQJAC5.js +0 -1
- package/dist/sugar-DQjFmVqb.d.cts +0 -399
- package/dist/sugar-fhLIE7TT.d.ts +0 -399
- package/dist/topology-tree-Bcz27hpF.d.cts +0 -25
- package/dist/topology-tree-xvaD0fOX.d.ts +0 -25
|
@@ -1,15 +1,13 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import '../../
|
|
3
|
-
import '../../sugar-DQjFmVqb.cjs';
|
|
4
|
-
import '../storage-core.cjs';
|
|
5
|
-
import '../storage-tiers.cjs';
|
|
1
|
+
import { GraphDescribeOutput } from '@graphrefly/pure-ts/graph';
|
|
2
|
+
import { c as LayoutFrame } from '../../layout-types-B5aiHYgk.js';
|
|
6
3
|
|
|
7
4
|
/**
|
|
8
5
|
* Internal helpers shared across renderers in `extra/render/`.
|
|
9
6
|
*
|
|
10
7
|
* These are pure functions over `GraphDescribeOutput` — no Graph instance
|
|
11
8
|
* dependency. Extracted from `src/graph/graph.ts` (the consolidated
|
|
12
|
-
* ex-dumpGraph / ex-
|
|
9
|
+
* ex-dumpGraph / ex-graphSpecToMermaid / ex-graphSpecToD2 renderers) per
|
|
10
|
+
* Tier 2.1 A2.
|
|
13
11
|
*/
|
|
14
12
|
|
|
15
13
|
/** Direction options for diagram exports. */
|
|
@@ -39,13 +37,13 @@ type DiagramDirection = "TD" | "LR" | "BT" | "RL";
|
|
|
39
37
|
* swaps axes at draw time — the layout is direction-agnostic by
|
|
40
38
|
* construction.
|
|
41
39
|
*
|
|
42
|
-
* Used only by [to-ascii.ts](./to-ascii.ts); not part of the public
|
|
40
|
+
* Used only by [graph-spec-to-ascii.ts](./graph-spec-to-ascii.ts); not part of the public
|
|
43
41
|
* `extra/render/index.ts` surface (underscore-prefixed).
|
|
44
42
|
*/
|
|
45
43
|
type LayoutDirection = "LR" | "TD";
|
|
46
44
|
|
|
47
45
|
/**
|
|
48
|
-
* `
|
|
46
|
+
* `graphSpecToAscii(g, opts?)` — stdout-native DAG flowchart renderer for a
|
|
49
47
|
* {@link GraphDescribeOutput}.
|
|
50
48
|
*
|
|
51
49
|
* Zero external dependencies, graph-size independent via proper Sugiyama
|
|
@@ -60,7 +58,7 @@ type LayoutDirection = "LR" | "TD";
|
|
|
60
58
|
* @category extra
|
|
61
59
|
*/
|
|
62
60
|
|
|
63
|
-
type
|
|
61
|
+
type GraphSpecToAsciiOptions = {
|
|
64
62
|
/**
|
|
65
63
|
* ASCII layout direction. ASCII grid semantics are meaningful only for
|
|
66
64
|
* `"LR"` (default) and `"TD"`.
|
|
@@ -73,32 +71,33 @@ type ToAsciiOptions = {
|
|
|
73
71
|
/** Optional logger hook; fires with the rendered text before return. */
|
|
74
72
|
logger?: (text: string) => void;
|
|
75
73
|
};
|
|
76
|
-
declare function
|
|
74
|
+
declare function graphSpecToAscii(g: GraphDescribeOutput, opts?: GraphSpecToAsciiOptions): string;
|
|
77
75
|
|
|
78
76
|
/**
|
|
79
|
-
* `
|
|
77
|
+
* `graphSpecToD2(g, opts?)` — render a {@link GraphDescribeOutput} as D2
|
|
78
|
+
* diagram text.
|
|
80
79
|
*
|
|
81
80
|
* Pure function over the describe snapshot; no Graph instance dependency.
|
|
82
81
|
*
|
|
83
82
|
* @category extra
|
|
84
83
|
*/
|
|
85
84
|
|
|
86
|
-
type
|
|
85
|
+
type GraphSpecToD2Options = {
|
|
87
86
|
/** Diagram direction; default `"LR"`. */
|
|
88
87
|
direction?: DiagramDirection;
|
|
89
88
|
};
|
|
90
|
-
declare function
|
|
89
|
+
declare function graphSpecToD2(g: GraphDescribeOutput, opts?: GraphSpecToD2Options): string;
|
|
91
90
|
|
|
92
91
|
/**
|
|
93
|
-
* `
|
|
94
|
-
* JSON text with sorted keys.
|
|
92
|
+
* `graphSpecToJson(g, opts?)` — render a {@link GraphDescribeOutput} as
|
|
93
|
+
* deterministic JSON text with sorted keys.
|
|
95
94
|
*
|
|
96
95
|
* Pure function over the describe snapshot; no Graph instance dependency.
|
|
97
96
|
*
|
|
98
97
|
* @category extra
|
|
99
98
|
*/
|
|
100
99
|
|
|
101
|
-
type
|
|
100
|
+
type GraphSpecToJsonOptions = {
|
|
102
101
|
/** Include the Edges section (default `true`). */
|
|
103
102
|
includeEdges?: boolean;
|
|
104
103
|
/** Include the Subgraphs section (default `true`). */
|
|
@@ -108,34 +107,37 @@ type ToJsonOptions = {
|
|
|
108
107
|
/** Optional logger hook; fires with the rendered text before return. */
|
|
109
108
|
logger?: (text: string) => void;
|
|
110
109
|
};
|
|
111
|
-
declare function
|
|
110
|
+
declare function graphSpecToJson(g: GraphDescribeOutput, opts?: GraphSpecToJsonOptions): string;
|
|
112
111
|
|
|
113
112
|
/**
|
|
114
|
-
* `
|
|
115
|
-
* flowchart text.
|
|
113
|
+
* `graphSpecToMermaid(g, opts?)` — render a {@link GraphDescribeOutput} as
|
|
114
|
+
* Mermaid flowchart text.
|
|
116
115
|
*
|
|
117
116
|
* Pure function over the describe snapshot; no Graph instance dependency.
|
|
118
117
|
* Compose with `derived` for live formatted output:
|
|
119
118
|
*
|
|
120
119
|
* ```ts
|
|
121
|
-
* import {
|
|
120
|
+
* import { graphSpecToMermaid } from "@graphrefly/graphrefly/extra/render";
|
|
122
121
|
* import { derived } from "@graphrefly/graphrefly";
|
|
123
122
|
*
|
|
124
|
-
* const live = derived(
|
|
123
|
+
* const live = derived(
|
|
124
|
+
* [graph.describe({ reactive: true }).node],
|
|
125
|
+
* ([g]) => graphSpecToMermaid(g),
|
|
126
|
+
* );
|
|
125
127
|
* ```
|
|
126
128
|
*
|
|
127
129
|
* @category extra
|
|
128
130
|
*/
|
|
129
131
|
|
|
130
|
-
type
|
|
132
|
+
type GraphSpecToMermaidOptions = {
|
|
131
133
|
/** Diagram direction; default `"LR"`. */
|
|
132
134
|
direction?: DiagramDirection;
|
|
133
135
|
};
|
|
134
|
-
declare function
|
|
136
|
+
declare function graphSpecToMermaid(g: GraphDescribeOutput, opts?: GraphSpecToMermaidOptions): string;
|
|
135
137
|
|
|
136
138
|
/**
|
|
137
|
-
* `
|
|
138
|
-
* `https://mermaid.live/edit#base64:…` deep link.
|
|
139
|
+
* `graphSpecToMermaidUrl(g, opts?)` — encode a {@link GraphDescribeOutput}
|
|
140
|
+
* as a `https://mermaid.live/edit#base64:…` deep link.
|
|
139
141
|
*
|
|
140
142
|
* Round-trip with the mermaid.live editor's `/edit#base64:` share format —
|
|
141
143
|
* payload is `base64url(JSON({code, mermaid: {theme}, ...}))`. No network
|
|
@@ -145,7 +147,7 @@ declare function toMermaid(g: GraphDescribeOutput, opts?: ToMermaidOptions): str
|
|
|
145
147
|
*/
|
|
146
148
|
|
|
147
149
|
type MermaidLiveTheme = "default" | "dark" | "forest" | "neutral" | "base";
|
|
148
|
-
type
|
|
150
|
+
type GraphSpecToMermaidUrlOptions = GraphSpecToMermaidOptions & {
|
|
149
151
|
theme?: MermaidLiveTheme;
|
|
150
152
|
autoSync?: boolean;
|
|
151
153
|
};
|
|
@@ -158,10 +160,10 @@ declare function mermaidLiveUrl(mermaidSrc: string, opts?: {
|
|
|
158
160
|
theme?: MermaidLiveTheme;
|
|
159
161
|
autoSync?: boolean;
|
|
160
162
|
}): string;
|
|
161
|
-
declare function
|
|
163
|
+
declare function graphSpecToMermaidUrl(g: GraphDescribeOutput, opts?: GraphSpecToMermaidUrlOptions): string;
|
|
162
164
|
|
|
163
165
|
/**
|
|
164
|
-
* `
|
|
166
|
+
* `graphSpecToPretty(g, opts?)` — render a {@link GraphDescribeOutput} as
|
|
165
167
|
* human-readable plaintext (Node list with values, plus optional Edges and
|
|
166
168
|
* Subgraphs sections).
|
|
167
169
|
*
|
|
@@ -170,7 +172,7 @@ declare function toMermaidUrl(g: GraphDescribeOutput, opts?: ToMermaidUrlOptions
|
|
|
170
172
|
* @category extra
|
|
171
173
|
*/
|
|
172
174
|
|
|
173
|
-
type
|
|
175
|
+
type GraphSpecToPrettyOptions = {
|
|
174
176
|
/** Include the Edges section (default `true`). */
|
|
175
177
|
includeEdges?: boolean;
|
|
176
178
|
/** Include the Subgraphs section (default `true`). */
|
|
@@ -178,6 +180,48 @@ type ToPrettyOptions = {
|
|
|
178
180
|
/** Optional logger hook; fires with the rendered text before return. */
|
|
179
181
|
logger?: (text: string) => void;
|
|
180
182
|
};
|
|
181
|
-
declare function
|
|
183
|
+
declare function graphSpecToPretty(g: GraphDescribeOutput, opts?: GraphSpecToPrettyOptions): string;
|
|
182
184
|
|
|
183
|
-
|
|
185
|
+
/**
|
|
186
|
+
* `layoutFrameToSvg(frame, opts?)` — render a {@link LayoutFrame} as an SVG
|
|
187
|
+
* markup string.
|
|
188
|
+
*
|
|
189
|
+
* Universal-safe — emits a string, not a DOM tree. Browser code embeds via
|
|
190
|
+
* `el.innerHTML = svg`; Node code writes to a file. Cell-grid coordinates from
|
|
191
|
+
* the layout are scaled by `cellWidth` / `cellHeight` (default 12 × 18 px,
|
|
192
|
+
* roughly matching a monospace baseline).
|
|
193
|
+
*
|
|
194
|
+
* Each box gets `data-id="<path>"` for change-event highlighting; each edge
|
|
195
|
+
* gets `data-from="<from>" data-to="<to>"` so renderers can animate flowing
|
|
196
|
+
* data per `LayoutFrame.changes`.
|
|
197
|
+
*
|
|
198
|
+
* @category extra
|
|
199
|
+
*/
|
|
200
|
+
|
|
201
|
+
interface LayoutFrameToSvgOptions {
|
|
202
|
+
/** Pixel width of one cell. Default: `12`. */
|
|
203
|
+
readonly cellWidth?: number;
|
|
204
|
+
/** Pixel height of one cell. Default: `18`. */
|
|
205
|
+
readonly cellHeight?: number;
|
|
206
|
+
/** Outer margin in pixels. Default: `16`. */
|
|
207
|
+
readonly padding?: number;
|
|
208
|
+
/** Box stroke color. Default: `"#444"`. */
|
|
209
|
+
readonly boxStroke?: string;
|
|
210
|
+
/** Box fill color. Default: `"#fff"`. */
|
|
211
|
+
readonly boxFill?: string;
|
|
212
|
+
/** Edge stroke color. Default: `"#888"`. */
|
|
213
|
+
readonly edgeStroke?: string;
|
|
214
|
+
/** Box label text color. Default: `"#111"`. */
|
|
215
|
+
readonly textColor?: string;
|
|
216
|
+
/** Font family. Default: `"ui-monospace, monospace"`. */
|
|
217
|
+
readonly fontFamily?: string;
|
|
218
|
+
/** Font size in pixels. Default: `12`. */
|
|
219
|
+
readonly fontSize?: number;
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Render a {@link LayoutFrame} to SVG markup. Pure function — call from
|
|
223
|
+
* `derived` to drive a live `<svg>` element from a `topologyView` output.
|
|
224
|
+
*/
|
|
225
|
+
declare function layoutFrameToSvg(frame: LayoutFrame, opts?: LayoutFrameToSvgOptions): string;
|
|
226
|
+
|
|
227
|
+
export { type DiagramDirection, type GraphSpecToAsciiOptions, type GraphSpecToD2Options, type GraphSpecToJsonOptions, type GraphSpecToMermaidOptions, type GraphSpecToMermaidUrlOptions, type GraphSpecToPrettyOptions, type LayoutDirection, type LayoutFrameToSvgOptions, type MermaidLiveTheme, graphSpecToAscii, graphSpecToD2, graphSpecToJson, graphSpecToMermaid, graphSpecToMermaidUrl, graphSpecToPretty, layoutFrameToSvg, mermaidLiveUrl };
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import {
|
|
2
|
+
graphSpecToAscii,
|
|
3
|
+
graphSpecToD2,
|
|
4
|
+
graphSpecToJson,
|
|
5
|
+
graphSpecToMermaid,
|
|
6
|
+
graphSpecToMermaidUrl,
|
|
7
|
+
graphSpecToPretty,
|
|
8
|
+
layoutFrameToSvg,
|
|
9
|
+
mermaidLiveUrl
|
|
10
|
+
} from "../../chunk-PKGQG5QQ.js";
|
|
11
|
+
import "../../chunk-36NMM65U.js";
|
|
12
|
+
import "../../chunk-DMSNO6ZB.js";
|
|
13
|
+
import "../../chunk-AZDQPQ3V.js";
|
|
14
|
+
export {
|
|
15
|
+
graphSpecToAscii,
|
|
16
|
+
graphSpecToD2,
|
|
17
|
+
graphSpecToJson,
|
|
18
|
+
graphSpecToMermaid,
|
|
19
|
+
graphSpecToMermaidUrl,
|
|
20
|
+
graphSpecToPretty,
|
|
21
|
+
layoutFrameToSvg,
|
|
22
|
+
mermaidLiveUrl
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/base/sources/browser/index.ts
|
|
21
|
+
var browser_exports = {};
|
|
22
|
+
__export(browser_exports, {
|
|
23
|
+
fromEvent: () => fromEvent,
|
|
24
|
+
fromIDBRequest: () => fromIDBRequest,
|
|
25
|
+
fromIDBTransaction: () => fromIDBTransaction,
|
|
26
|
+
fromRaf: () => fromRaf
|
|
27
|
+
});
|
|
28
|
+
module.exports = __toCommonJS(browser_exports);
|
|
29
|
+
|
|
30
|
+
// src/base/sources/event/dom.ts
|
|
31
|
+
var import_core = require("@graphrefly/pure-ts/core");
|
|
32
|
+
function sourceOpts(opts) {
|
|
33
|
+
return { describeKind: "producer", ...opts };
|
|
34
|
+
}
|
|
35
|
+
function fromRaf(opts) {
|
|
36
|
+
const { signal, ...rest } = opts ?? {};
|
|
37
|
+
return (0, import_core.node)((_data, a) => {
|
|
38
|
+
let done = false;
|
|
39
|
+
let rafId;
|
|
40
|
+
let fallbackTimer;
|
|
41
|
+
let abortListenerAdded = false;
|
|
42
|
+
let visibilityListenerAdded = false;
|
|
43
|
+
const raf = typeof requestAnimationFrame === "function" ? requestAnimationFrame : void 0;
|
|
44
|
+
const caf = typeof cancelAnimationFrame === "function" ? cancelAnimationFrame : void 0;
|
|
45
|
+
const doc = typeof document !== "undefined" ? document : void 0;
|
|
46
|
+
const clearPending = () => {
|
|
47
|
+
if (rafId !== void 0 && caf) caf(rafId);
|
|
48
|
+
if (fallbackTimer !== void 0) clearTimeout(fallbackTimer);
|
|
49
|
+
rafId = void 0;
|
|
50
|
+
fallbackTimer = void 0;
|
|
51
|
+
};
|
|
52
|
+
const cleanup = () => {
|
|
53
|
+
done = true;
|
|
54
|
+
clearPending();
|
|
55
|
+
if (abortListenerAdded) {
|
|
56
|
+
signal?.removeEventListener("abort", onAbort);
|
|
57
|
+
abortListenerAdded = false;
|
|
58
|
+
}
|
|
59
|
+
if (visibilityListenerAdded && doc) {
|
|
60
|
+
doc.removeEventListener("visibilitychange", onVisibilityChange);
|
|
61
|
+
visibilityListenerAdded = false;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
const onAbort = () => {
|
|
65
|
+
if (done) return;
|
|
66
|
+
cleanup();
|
|
67
|
+
a.down([[import_core.ERROR, signal.reason]]);
|
|
68
|
+
};
|
|
69
|
+
const tick = (now) => {
|
|
70
|
+
if (done) return;
|
|
71
|
+
a.emit(now);
|
|
72
|
+
scheduleNext();
|
|
73
|
+
};
|
|
74
|
+
const scheduleNext = () => {
|
|
75
|
+
if (done) return;
|
|
76
|
+
if (raf && (!doc || doc.visibilityState !== "hidden")) {
|
|
77
|
+
rafId = raf(tick);
|
|
78
|
+
} else {
|
|
79
|
+
fallbackTimer = setTimeout(() => tick(performance.now()), 16);
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
const onVisibilityChange = () => {
|
|
83
|
+
if (done) return;
|
|
84
|
+
clearPending();
|
|
85
|
+
scheduleNext();
|
|
86
|
+
};
|
|
87
|
+
if (signal?.aborted) {
|
|
88
|
+
onAbort();
|
|
89
|
+
return cleanup;
|
|
90
|
+
}
|
|
91
|
+
signal?.addEventListener("abort", onAbort, { once: true });
|
|
92
|
+
abortListenerAdded = signal !== void 0;
|
|
93
|
+
if (doc && raf) {
|
|
94
|
+
doc.addEventListener("visibilitychange", onVisibilityChange);
|
|
95
|
+
visibilityListenerAdded = true;
|
|
96
|
+
}
|
|
97
|
+
scheduleNext();
|
|
98
|
+
return cleanup;
|
|
99
|
+
}, sourceOpts(rest));
|
|
100
|
+
}
|
|
101
|
+
function fromEvent(target, type, opts) {
|
|
102
|
+
const { capture, passive, once, ...rest } = opts ?? {};
|
|
103
|
+
return (0, import_core.node)((_data, a) => {
|
|
104
|
+
const handler = (e) => {
|
|
105
|
+
a.emit(e);
|
|
106
|
+
};
|
|
107
|
+
const options = { capture, passive, once };
|
|
108
|
+
target.addEventListener(type, handler, options);
|
|
109
|
+
return () => target.removeEventListener(type, handler, options);
|
|
110
|
+
}, sourceOpts(rest));
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
// src/base/sources/browser/idb.ts
|
|
114
|
+
var import_core2 = require("@graphrefly/pure-ts/core");
|
|
115
|
+
function fromIDBRequest(req) {
|
|
116
|
+
return (0, import_core2.node)((_data, a) => {
|
|
117
|
+
let done = false;
|
|
118
|
+
const clear = () => {
|
|
119
|
+
req.onsuccess = null;
|
|
120
|
+
req.onerror = null;
|
|
121
|
+
};
|
|
122
|
+
req.onsuccess = () => {
|
|
123
|
+
if (done) return;
|
|
124
|
+
done = true;
|
|
125
|
+
clear();
|
|
126
|
+
a.down([[import_core2.DATA, req.result], [import_core2.COMPLETE]]);
|
|
127
|
+
};
|
|
128
|
+
req.onerror = () => {
|
|
129
|
+
if (done) return;
|
|
130
|
+
done = true;
|
|
131
|
+
clear();
|
|
132
|
+
a.down([[import_core2.ERROR, req.error ?? new Error("IndexedDB request failed")]]);
|
|
133
|
+
};
|
|
134
|
+
return () => {
|
|
135
|
+
done = true;
|
|
136
|
+
clear();
|
|
137
|
+
};
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
function fromIDBTransaction(tx) {
|
|
141
|
+
return (0, import_core2.node)((_data, a) => {
|
|
142
|
+
let done = false;
|
|
143
|
+
const clear = () => {
|
|
144
|
+
tx.oncomplete = null;
|
|
145
|
+
tx.onerror = null;
|
|
146
|
+
tx.onabort = null;
|
|
147
|
+
};
|
|
148
|
+
tx.oncomplete = () => {
|
|
149
|
+
if (done) return;
|
|
150
|
+
done = true;
|
|
151
|
+
clear();
|
|
152
|
+
a.down([[import_core2.DATA, void 0], [import_core2.COMPLETE]]);
|
|
153
|
+
};
|
|
154
|
+
tx.onerror = () => {
|
|
155
|
+
if (done) return;
|
|
156
|
+
done = true;
|
|
157
|
+
clear();
|
|
158
|
+
a.down([[import_core2.ERROR, tx.error ?? new Error("IndexedDB transaction failed")]]);
|
|
159
|
+
};
|
|
160
|
+
tx.onabort = () => {
|
|
161
|
+
if (done) return;
|
|
162
|
+
done = true;
|
|
163
|
+
clear();
|
|
164
|
+
a.down([[import_core2.ERROR, tx.error ?? new Error("IndexedDB transaction aborted")]]);
|
|
165
|
+
};
|
|
166
|
+
return () => {
|
|
167
|
+
done = true;
|
|
168
|
+
clear();
|
|
169
|
+
};
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/base/sources/browser/index.ts","../../../../src/base/sources/event/dom.ts","../../../../src/base/sources/browser/idb.ts"],"sourcesContent":["/**\n * Browser-only sources — IDB (IndexedDB) reactive adapters, DOM events.\n *\n * All entries in this subpath may use DOM globals.\n * Import via @graphrefly/graphrefly/base/sources/browser.\n *\n * @module\n */\n\nexport * from \"../event/dom.js\";\nexport * from \"./idb.js\";\n","/**\n * DOM-based reactive event sources (browser-layer).\n *\n * Moved from extra/sources/event.ts (fromEvent, fromRaf) during cleave A2.\n */\n\nimport { ERROR, type Node, type NodeOptions, node } from \"@graphrefly/pure-ts/core\";\n\ntype ExtraOpts = Omit<NodeOptions, \"describeKind\">;\ntype AsyncSourceOpts = ExtraOpts & { signal?: AbortSignal };\n\nfunction sourceOpts<T = unknown>(opts?: ExtraOpts): NodeOptions<T> {\n\treturn { describeKind: \"producer\", ...opts } as NodeOptions<T>;\n}\n\n/** DOM-style event target (browser or `node:events`). */\nexport type EventTargetLike = {\n\taddEventListener(\n\t\ttype: string,\n\t\tlistener: (ev: unknown) => void,\n\t\toptions?: boolean | { capture?: boolean; passive?: boolean; once?: boolean },\n\t): void;\n\tremoveEventListener(\n\t\ttype: string,\n\t\tlistener: (ev: unknown) => void,\n\t\toptions?: boolean | { capture?: boolean; passive?: boolean; once?: boolean },\n\t): void;\n};\n\nexport function fromRaf(opts?: AsyncSourceOpts): Node<number> {\n\tconst { signal, ...rest } = opts ?? {};\n\treturn node<number>((_data, a) => {\n\t\tlet done = false;\n\t\tlet rafId: number | undefined;\n\t\tlet fallbackTimer: ReturnType<typeof setTimeout> | undefined;\n\t\tlet abortListenerAdded = false;\n\t\tlet visibilityListenerAdded = false;\n\n\t\tconst raf: typeof requestAnimationFrame | undefined =\n\t\t\ttypeof requestAnimationFrame === \"function\" ? requestAnimationFrame : undefined;\n\t\tconst caf: typeof cancelAnimationFrame | undefined =\n\t\t\ttypeof cancelAnimationFrame === \"function\" ? cancelAnimationFrame : undefined;\n\t\tconst doc: Document | undefined = typeof document !== \"undefined\" ? document : undefined;\n\n\t\tconst clearPending = () => {\n\t\t\tif (rafId !== undefined && caf) caf(rafId);\n\t\t\tif (fallbackTimer !== undefined) clearTimeout(fallbackTimer);\n\t\t\trafId = undefined;\n\t\t\tfallbackTimer = undefined;\n\t\t};\n\t\tconst cleanup = () => {\n\t\t\tdone = true;\n\t\t\tclearPending();\n\t\t\tif (abortListenerAdded) {\n\t\t\t\tsignal?.removeEventListener(\"abort\", onAbort);\n\t\t\t\tabortListenerAdded = false;\n\t\t\t}\n\t\t\tif (visibilityListenerAdded && doc) {\n\t\t\t\tdoc.removeEventListener(\"visibilitychange\", onVisibilityChange);\n\t\t\t\tvisibilityListenerAdded = false;\n\t\t\t}\n\t\t};\n\t\tconst onAbort = () => {\n\t\t\tif (done) return;\n\t\t\tcleanup();\n\t\t\ta.down([[ERROR, signal!.reason]]);\n\t\t};\n\t\tconst tick = (now: number) => {\n\t\t\tif (done) return;\n\t\t\ta.emit(now);\n\t\t\tscheduleNext();\n\t\t};\n\t\tconst scheduleNext = () => {\n\t\t\tif (done) return;\n\t\t\t// Prefer rAF for display-synced ticks when the tab is visible; when\n\t\t\t// hidden, rAF is throttled to ~0 by the browser, so fall back to\n\t\t\t// setTimeout so downstream state continues updating.\n\t\t\tif (raf && (!doc || doc.visibilityState !== \"hidden\")) {\n\t\t\t\trafId = raf(tick);\n\t\t\t} else {\n\t\t\t\tfallbackTimer = setTimeout(() => tick(performance.now()), 16);\n\t\t\t}\n\t\t};\n\t\tconst onVisibilityChange = () => {\n\t\t\tif (done) return;\n\t\t\t// Cancel any pending schedule and re-schedule via the path now\n\t\t\t// appropriate for the current visibility state.\n\t\t\tclearPending();\n\t\t\tscheduleNext();\n\t\t};\n\n\t\tif (signal?.aborted) {\n\t\t\tonAbort();\n\t\t\treturn cleanup;\n\t\t}\n\t\tsignal?.addEventListener(\"abort\", onAbort, { once: true });\n\t\tabortListenerAdded = signal !== undefined;\n\t\tif (doc && raf) {\n\t\t\tdoc.addEventListener(\"visibilitychange\", onVisibilityChange);\n\t\t\tvisibilityListenerAdded = true;\n\t\t}\n\t\tscheduleNext();\n\t\treturn cleanup;\n\t}, sourceOpts(rest));\n}\n\n/**\n * Wraps a DOM-style `addEventListener` target; each event becomes a `DATA` emission.\n *\n * @param target - Object with `addEventListener` / `removeEventListener`.\n * @param type - Event name (e.g. `\"click\"`).\n * @param opts - Producer options plus listener options (`capture`, `passive`, `once`).\n * @returns `Node<T>` — event payloads; teardown removes the listener.\n *\n * @example\n * ```ts\n * import { fromEvent } from \"@graphrefly/graphrefly-ts\";\n *\n * fromEvent(document.body, \"click\");\n * ```\n *\n * @category extra\n */\nexport function fromEvent<T = unknown>(\n\ttarget: EventTargetLike,\n\ttype: string,\n\topts?: ExtraOpts & { capture?: boolean; passive?: boolean; once?: boolean },\n): Node<T> {\n\tconst { capture, passive, once, ...rest } = opts ?? {};\n\treturn node<T>((_data, a) => {\n\t\tconst handler = (e: unknown) => {\n\t\t\ta.emit(e as T);\n\t\t};\n\t\tconst options = { capture, passive, once };\n\t\ttarget.addEventListener(type, handler, options);\n\t\treturn () => target.removeEventListener(type, handler, options);\n\t}, sourceOpts(rest));\n}\n","/**\n * Browser-only IndexedDB reactive sources.\n *\n * `fromIDBRequest` / `fromIDBTransaction` wrap raw IDB primitives as reactive\n * sources. The old `indexedDbStorage` kv adapter has been replaced by\n * `indexedDbKv` in `./storage-tiers-browser.js` (Audit 4, 2026-04-24).\n *\n * Imports require the DOM lib — not safe to pull into Node-only bundles\n * without `lib: [\"dom\"]` in the consumer's tsconfig.\n *\n * @module\n */\n/// <reference lib=\"dom\" />\n\nimport { COMPLETE, DATA, ERROR, type Node, node } from \"@graphrefly/pure-ts/core\";\n\n// IndexedDbStorageSpec is no longer needed here — it's defined in storage-tiers-browser.ts.\n\n/**\n * Wraps an `IDBRequest` as a one-shot reactive source.\n *\n * @param req - Request whose callbacks are converted to protocol messages.\n * @returns `Node<T>` that emits `DATA` once on success then `COMPLETE`;\n * emits `ERROR` on failure.\n *\n * @category extra\n */\nexport function fromIDBRequest<T>(req: IDBRequest<T>): Node<T> {\n\treturn node<T>((_data, a) => {\n\t\tlet done = false;\n\t\tconst clear = () => {\n\t\t\treq.onsuccess = null;\n\t\t\treq.onerror = null;\n\t\t};\n\t\treq.onsuccess = () => {\n\t\t\tif (done) return;\n\t\t\tdone = true;\n\t\t\tclear();\n\t\t\ta.down([[DATA, req.result], [COMPLETE]]);\n\t\t};\n\t\treq.onerror = () => {\n\t\t\tif (done) return;\n\t\t\tdone = true;\n\t\t\tclear();\n\t\t\ta.down([[ERROR, req.error ?? new Error(\"IndexedDB request failed\")]]);\n\t\t};\n\t\treturn () => {\n\t\t\tdone = true;\n\t\t\tclear();\n\t\t};\n\t});\n}\n\n/**\n * Wraps an `IDBTransaction` terminal lifecycle as a one-shot reactive source.\n *\n * @param tx - Transaction to observe.\n * @returns `Node<void>` that emits `DATA` (`undefined`) then `COMPLETE` on\n * success; emits `ERROR` on `error`/`abort`.\n *\n * @category extra\n */\nexport function fromIDBTransaction(tx: IDBTransaction): Node<void> {\n\treturn node<void>((_data, a) => {\n\t\tlet done = false;\n\t\tconst clear = () => {\n\t\t\ttx.oncomplete = null;\n\t\t\ttx.onerror = null;\n\t\t\ttx.onabort = null;\n\t\t};\n\t\ttx.oncomplete = () => {\n\t\t\tif (done) return;\n\t\t\tdone = true;\n\t\t\tclear();\n\t\t\ta.down([[DATA, undefined], [COMPLETE]]);\n\t\t};\n\t\ttx.onerror = () => {\n\t\t\tif (done) return;\n\t\t\tdone = true;\n\t\t\tclear();\n\t\t\ta.down([[ERROR, tx.error ?? new Error(\"IndexedDB transaction failed\")]]);\n\t\t};\n\t\ttx.onabort = () => {\n\t\t\tif (done) return;\n\t\t\tdone = true;\n\t\t\tclear();\n\t\t\ta.down([[ERROR, tx.error ?? new Error(\"IndexedDB transaction aborted\")]]);\n\t\t};\n\t\treturn () => {\n\t\t\tdone = true;\n\t\t\tclear();\n\t\t};\n\t});\n}\n\n// The old `indexedDbStorage` kv adapter has been removed.\n// Use `indexedDbKv` from `./storage-tiers-browser.js` instead (Audit 4, 2026-04-24).\n"],"mappings":"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","names":["import_core"]}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { NodeOptions, Node } from '@graphrefly/pure-ts/core';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* DOM-based reactive event sources (browser-layer).
|
|
5
|
+
*
|
|
6
|
+
* Moved from extra/sources/event.ts (fromEvent, fromRaf) during cleave A2.
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
type ExtraOpts = Omit<NodeOptions, "describeKind">;
|
|
10
|
+
type AsyncSourceOpts = ExtraOpts & {
|
|
11
|
+
signal?: AbortSignal;
|
|
12
|
+
};
|
|
13
|
+
/** DOM-style event target (browser or `node:events`). */
|
|
14
|
+
type EventTargetLike = {
|
|
15
|
+
addEventListener(type: string, listener: (ev: unknown) => void, options?: boolean | {
|
|
16
|
+
capture?: boolean;
|
|
17
|
+
passive?: boolean;
|
|
18
|
+
once?: boolean;
|
|
19
|
+
}): void;
|
|
20
|
+
removeEventListener(type: string, listener: (ev: unknown) => void, options?: boolean | {
|
|
21
|
+
capture?: boolean;
|
|
22
|
+
passive?: boolean;
|
|
23
|
+
once?: boolean;
|
|
24
|
+
}): void;
|
|
25
|
+
};
|
|
26
|
+
declare function fromRaf(opts?: AsyncSourceOpts): Node<number>;
|
|
27
|
+
/**
|
|
28
|
+
* Wraps a DOM-style `addEventListener` target; each event becomes a `DATA` emission.
|
|
29
|
+
*
|
|
30
|
+
* @param target - Object with `addEventListener` / `removeEventListener`.
|
|
31
|
+
* @param type - Event name (e.g. `"click"`).
|
|
32
|
+
* @param opts - Producer options plus listener options (`capture`, `passive`, `once`).
|
|
33
|
+
* @returns `Node<T>` — event payloads; teardown removes the listener.
|
|
34
|
+
*
|
|
35
|
+
* @example
|
|
36
|
+
* ```ts
|
|
37
|
+
* import { fromEvent } from "@graphrefly/graphrefly-ts";
|
|
38
|
+
*
|
|
39
|
+
* fromEvent(document.body, "click");
|
|
40
|
+
* ```
|
|
41
|
+
*
|
|
42
|
+
* @category extra
|
|
43
|
+
*/
|
|
44
|
+
declare function fromEvent<T = unknown>(target: EventTargetLike, type: string, opts?: ExtraOpts & {
|
|
45
|
+
capture?: boolean;
|
|
46
|
+
passive?: boolean;
|
|
47
|
+
once?: boolean;
|
|
48
|
+
}): Node<T>;
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Browser-only IndexedDB reactive sources.
|
|
52
|
+
*
|
|
53
|
+
* `fromIDBRequest` / `fromIDBTransaction` wrap raw IDB primitives as reactive
|
|
54
|
+
* sources. The old `indexedDbStorage` kv adapter has been replaced by
|
|
55
|
+
* `indexedDbKv` in `./storage-tiers-browser.js` (Audit 4, 2026-04-24).
|
|
56
|
+
*
|
|
57
|
+
* Imports require the DOM lib — not safe to pull into Node-only bundles
|
|
58
|
+
* without `lib: ["dom"]` in the consumer's tsconfig.
|
|
59
|
+
*
|
|
60
|
+
* @module
|
|
61
|
+
*/
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Wraps an `IDBRequest` as a one-shot reactive source.
|
|
65
|
+
*
|
|
66
|
+
* @param req - Request whose callbacks are converted to protocol messages.
|
|
67
|
+
* @returns `Node<T>` that emits `DATA` once on success then `COMPLETE`;
|
|
68
|
+
* emits `ERROR` on failure.
|
|
69
|
+
*
|
|
70
|
+
* @category extra
|
|
71
|
+
*/
|
|
72
|
+
declare function fromIDBRequest<T>(req: IDBRequest<T>): Node<T>;
|
|
73
|
+
/**
|
|
74
|
+
* Wraps an `IDBTransaction` terminal lifecycle as a one-shot reactive source.
|
|
75
|
+
*
|
|
76
|
+
* @param tx - Transaction to observe.
|
|
77
|
+
* @returns `Node<void>` that emits `DATA` (`undefined`) then `COMPLETE` on
|
|
78
|
+
* success; emits `ERROR` on `error`/`abort`.
|
|
79
|
+
*
|
|
80
|
+
* @category extra
|
|
81
|
+
*/
|
|
82
|
+
declare function fromIDBTransaction(tx: IDBTransaction): Node<void>;
|
|
83
|
+
|
|
84
|
+
export { type EventTargetLike, fromEvent, fromIDBRequest, fromIDBTransaction, fromRaf };
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { NodeOptions, Node } from '@graphrefly/pure-ts/core';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* DOM-based reactive event sources (browser-layer).
|
|
5
|
+
*
|
|
6
|
+
* Moved from extra/sources/event.ts (fromEvent, fromRaf) during cleave A2.
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
type ExtraOpts = Omit<NodeOptions, "describeKind">;
|
|
10
|
+
type AsyncSourceOpts = ExtraOpts & {
|
|
11
|
+
signal?: AbortSignal;
|
|
12
|
+
};
|
|
13
|
+
/** DOM-style event target (browser or `node:events`). */
|
|
14
|
+
type EventTargetLike = {
|
|
15
|
+
addEventListener(type: string, listener: (ev: unknown) => void, options?: boolean | {
|
|
16
|
+
capture?: boolean;
|
|
17
|
+
passive?: boolean;
|
|
18
|
+
once?: boolean;
|
|
19
|
+
}): void;
|
|
20
|
+
removeEventListener(type: string, listener: (ev: unknown) => void, options?: boolean | {
|
|
21
|
+
capture?: boolean;
|
|
22
|
+
passive?: boolean;
|
|
23
|
+
once?: boolean;
|
|
24
|
+
}): void;
|
|
25
|
+
};
|
|
26
|
+
declare function fromRaf(opts?: AsyncSourceOpts): Node<number>;
|
|
27
|
+
/**
|
|
28
|
+
* Wraps a DOM-style `addEventListener` target; each event becomes a `DATA` emission.
|
|
29
|
+
*
|
|
30
|
+
* @param target - Object with `addEventListener` / `removeEventListener`.
|
|
31
|
+
* @param type - Event name (e.g. `"click"`).
|
|
32
|
+
* @param opts - Producer options plus listener options (`capture`, `passive`, `once`).
|
|
33
|
+
* @returns `Node<T>` — event payloads; teardown removes the listener.
|
|
34
|
+
*
|
|
35
|
+
* @example
|
|
36
|
+
* ```ts
|
|
37
|
+
* import { fromEvent } from "@graphrefly/graphrefly-ts";
|
|
38
|
+
*
|
|
39
|
+
* fromEvent(document.body, "click");
|
|
40
|
+
* ```
|
|
41
|
+
*
|
|
42
|
+
* @category extra
|
|
43
|
+
*/
|
|
44
|
+
declare function fromEvent<T = unknown>(target: EventTargetLike, type: string, opts?: ExtraOpts & {
|
|
45
|
+
capture?: boolean;
|
|
46
|
+
passive?: boolean;
|
|
47
|
+
once?: boolean;
|
|
48
|
+
}): Node<T>;
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Browser-only IndexedDB reactive sources.
|
|
52
|
+
*
|
|
53
|
+
* `fromIDBRequest` / `fromIDBTransaction` wrap raw IDB primitives as reactive
|
|
54
|
+
* sources. The old `indexedDbStorage` kv adapter has been replaced by
|
|
55
|
+
* `indexedDbKv` in `./storage-tiers-browser.js` (Audit 4, 2026-04-24).
|
|
56
|
+
*
|
|
57
|
+
* Imports require the DOM lib — not safe to pull into Node-only bundles
|
|
58
|
+
* without `lib: ["dom"]` in the consumer's tsconfig.
|
|
59
|
+
*
|
|
60
|
+
* @module
|
|
61
|
+
*/
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Wraps an `IDBRequest` as a one-shot reactive source.
|
|
65
|
+
*
|
|
66
|
+
* @param req - Request whose callbacks are converted to protocol messages.
|
|
67
|
+
* @returns `Node<T>` that emits `DATA` once on success then `COMPLETE`;
|
|
68
|
+
* emits `ERROR` on failure.
|
|
69
|
+
*
|
|
70
|
+
* @category extra
|
|
71
|
+
*/
|
|
72
|
+
declare function fromIDBRequest<T>(req: IDBRequest<T>): Node<T>;
|
|
73
|
+
/**
|
|
74
|
+
* Wraps an `IDBTransaction` terminal lifecycle as a one-shot reactive source.
|
|
75
|
+
*
|
|
76
|
+
* @param tx - Transaction to observe.
|
|
77
|
+
* @returns `Node<void>` that emits `DATA` (`undefined`) then `COMPLETE` on
|
|
78
|
+
* success; emits `ERROR` on `error`/`abort`.
|
|
79
|
+
*
|
|
80
|
+
* @category extra
|
|
81
|
+
*/
|
|
82
|
+
declare function fromIDBTransaction(tx: IDBTransaction): Node<void>;
|
|
83
|
+
|
|
84
|
+
export { type EventTargetLike, fromEvent, fromIDBRequest, fromIDBTransaction, fromRaf };
|