@jackuait/blok 0.10.0-beta.5 → 0.10.0-beta.7
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/codemod/migrate-editorjs-to-blok.js +0 -2
- package/codemod/test.js +0 -6
- package/dist/blok.mjs +3 -3
- package/dist/chunks/_basePickBy-BHRNO12X.mjs +410 -0
- package/dist/chunks/_baseUniq-DtFPDBML.mjs +1045 -0
- package/dist/chunks/_getTag-ozrhqxk_.mjs +26 -0
- package/dist/chunks/arc-BEqJP9HX.mjs +80 -0
- package/dist/chunks/architecture-YZFGNWBL-Bcu-90pi.mjs +3 -0
- package/dist/chunks/architectureDiagram-Q4EWVU46-BMno5LCn.mjs +4066 -0
- package/dist/chunks/array-Cyf-61SV.mjs +6 -0
- package/dist/chunks/blockDiagram-DXYQGD6D-DlP_cPth.mjs +3259 -0
- package/dist/chunks/{blok-DH-WEcA8.mjs → blok-CiLRmoHI.mjs} +2030 -1996
- package/dist/chunks/c4Diagram-AHTNJAMY-BbVV8EXj.mjs +2956 -0
- package/dist/chunks/channel-DPcniO2B.mjs +5 -0
- package/dist/chunks/chunk-2KRD3SAO-CazES4VS.mjs +20 -0
- package/dist/chunks/chunk-336JU56O-heO72r_k.mjs +49 -0
- package/dist/chunks/chunk-426QAEUC-CmCcml1z.mjs +13 -0
- package/dist/chunks/chunk-4BX2VUAB-B10DxOza.mjs +19 -0
- package/dist/chunks/chunk-4TB4RGXK-B0snhZOU.mjs +3250 -0
- package/dist/chunks/chunk-55IACEB6-CGkn5ABd.mjs +8 -0
- package/dist/chunks/chunk-5FUZZQ4R-USdumo_u.mjs +3786 -0
- package/dist/chunks/chunk-5PVQY5BW-CxUGVzQL.mjs +1692 -0
- package/dist/chunks/chunk-67CJDMHE-Bvw55oRa.mjs +20 -0
- package/dist/chunks/chunk-7N4EOEYR-Bs2qDy88.mjs +29 -0
- package/dist/chunks/chunk-AA7GKIK3-Bss0LgrN.mjs +24 -0
- package/dist/chunks/chunk-BSJP7CBP-CpUW7gi5.mjs +83 -0
- package/dist/chunks/chunk-CIAEETIT-DlRbLLf3.mjs +20 -0
- package/dist/chunks/chunk-D6kmoKXy.mjs +20 -0
- package/dist/chunks/chunk-EDXVE4YY-DEcX4XWm.mjs +26 -0
- package/dist/chunks/chunk-ENJZ2VHE-B4THRZkR.mjs +566 -0
- package/dist/chunks/chunk-FMBD7UC4-CF6BKEiV.mjs +5 -0
- package/dist/chunks/chunk-FOC6F5B3--xuza7Yn.mjs +20 -0
- package/dist/chunks/chunk-ICPOFSXX-BMja8cuy.mjs +3290 -0
- package/dist/chunks/chunk-K5T4RW27-CHEqGHFS.mjs +16370 -0
- package/dist/chunks/chunk-KGLVRYIC-DHYYpR8v.mjs +20 -0
- package/dist/chunks/chunk-LIHQZDEY-AvbOvyLE.mjs +55 -0
- package/dist/chunks/chunk-ORNJ4GCN-38fbR5OS.mjs +25 -0
- package/dist/chunks/chunk-OYMX7WX6-BiqlATPA.mjs +2038 -0
- package/dist/chunks/chunk-QZHKN3VN-DitZIvj8.mjs +12 -0
- package/dist/chunks/chunk-U2HBQHQK-DJytnHmZ.mjs +1875 -0
- package/dist/chunks/chunk-X2U36JSP-DlOifw1K.mjs +68 -0
- package/dist/chunks/chunk-XPW4576I-s4fsi4XO.mjs +1146 -0
- package/dist/chunks/chunk-YZCP3GAM-Ch258bXC.mjs +60 -0
- package/dist/chunks/chunk-ZZ45TVLE-DWziaKxP.mjs +33 -0
- package/dist/chunks/classDiagram-6PBFFD2Q-BOkAe08u.mjs +30 -0
- package/dist/chunks/classDiagram-v2-HSJHXN6E-DeKatSvh.mjs +30 -0
- package/dist/chunks/clone-CJCz7VRp.mjs +8 -0
- package/dist/chunks/{constants-Ccno9NZS.mjs → constants-DFS8l39Y.mjs} +525 -552
- package/dist/chunks/cose-bilkent-S5V4N54A-CzLGVqvr.mjs +2246 -0
- package/dist/chunks/cytoscape.esm-D0iglm-M.mjs +18108 -0
- package/dist/chunks/dagre-KV5264BT-XbHSjleO.mjs +298 -0
- package/dist/chunks/dagre-XY8CZ1sg.mjs +1536 -0
- package/dist/chunks/default-DIfXCS2E.mjs +4 -0
- package/dist/chunks/defaultLocale-DFhS1600.mjs +201 -0
- package/dist/chunks/diagram-5BDNPKRD-CM7c3UTI.mjs +112 -0
- package/dist/chunks/diagram-G4DWMVQ6-Bhg4ps6b.mjs +546 -0
- package/dist/chunks/diagram-MMDJMWI5-C-UCVaxB.mjs +234 -0
- package/dist/chunks/diagram-TYMM5635-BOHSujSD.mjs +144 -0
- package/dist/chunks/dist-DHsXIYdd.mjs +59 -0
- package/dist/chunks/erDiagram-SMLLAGMA-CwKxXFMB.mjs +1712 -0
- package/dist/chunks/flowDiagram-DWJPFMVM-rQJKfyuO.mjs +4175 -0
- package/dist/chunks/ganttDiagram-T4ZO3ILL-DfaZirLX.mjs +3083 -0
- package/dist/chunks/gitGraph-7Q5UKJZL-BKG8cHGz.mjs +3 -0
- package/dist/chunks/gitGraphDiagram-UUTBAWPF-CRa-ymsI.mjs +792 -0
- package/dist/chunks/graphlib-CuDElSdG.mjs +223 -0
- package/dist/chunks/{i18next-G6FKbZqA.mjs → i18next-BBGW2sDE.mjs} +1 -1
- package/dist/chunks/{i18next-loader-CwNimni3.mjs → i18next-loader-CasQQb5s.mjs} +2 -2
- package/dist/chunks/info-OMHHGYJF-FKqYyUn9.mjs +3 -0
- package/dist/chunks/infoDiagram-42DDH7IO-CvyJU2nE.mjs +29 -0
- package/dist/chunks/init-JlKGZtuT.mjs +15 -0
- package/dist/chunks/ishikawaDiagram-UXIWVN3A-CIpbw1BK.mjs +719 -0
- package/dist/chunks/journeyDiagram-VCZTEJTY-H96UcUK9.mjs +885 -0
- package/dist/chunks/kanban-definition-6JOO6SKY-BYZT3srA.mjs +980 -0
- package/dist/chunks/katex-JyOgX6MW.mjs +22026 -0
- package/dist/chunks/{lightweight-i18n-DWCdzAw0.mjs → lightweight-i18n-Cvv8CWh4.mjs} +29 -18
- package/dist/chunks/line-B9xUUA7k.mjs +34 -0
- package/dist/chunks/linear-Dj-1yA_B.mjs +289 -0
- package/dist/chunks/mdast-util-math-CHYUxOHk.mjs +151 -0
- package/dist/chunks/mermaid-parser.core-D6OPAUtM.mjs +57 -0
- package/dist/chunks/mermaid.core-BPN9ZHKQ.mjs +989 -0
- package/dist/{messages-B-4fku2H2.mjs → chunks/messages--YKhFEDE.mjs} +30 -19
- package/dist/{messages-BCG_evLg.mjs → chunks/messages-0Uwu1AMJ2.mjs} +28 -17
- package/dist/{messages-CdlsTFB1.mjs → chunks/messages-1__0Ph4Q.mjs} +28 -17
- package/dist/chunks/{messages-wLSVQbsA2.mjs → messages-4sm9Pb0C.mjs} +28 -17
- package/dist/chunks/{messages-R2W_rGOo2.mjs → messages-4uxjtzKW.mjs} +28 -17
- package/dist/chunks/{messages-Dm4YVlrm.mjs → messages-B-SwLgkQ.mjs} +30 -19
- package/dist/{messages--S8_taOd2.mjs → chunks/messages-B1ylBxXQ.mjs} +28 -17
- package/dist/chunks/{messages-B7MIRzCa2.mjs → messages-B5m3dhKc.mjs} +28 -17
- package/dist/chunks/{messages-Dplnp19q.mjs → messages-B6n2zDtv.mjs} +29 -18
- package/dist/chunks/{messages-DD7BI6BK.mjs → messages-BC9w4zAT.mjs} +28 -17
- package/dist/chunks/{messages-BrFl5773.mjs → messages-BOj-7N3p.mjs} +28 -17
- package/dist/chunks/{messages-BbdNugdi.mjs → messages-BRYHTS18.mjs} +28 -17
- package/dist/chunks/{messages-JQKFJo7C.mjs → messages-BSBbVjor.mjs} +35 -24
- package/dist/{messages-CBzd_x7H.mjs → chunks/messages-BUUkmUGc.mjs} +28 -17
- package/dist/{messages-CjmSrt1D.mjs → chunks/messages-Bb3YEV2P.mjs} +33 -22
- package/dist/{messages-BvgXeMSL2.mjs → chunks/messages-Be_6YLzJ.mjs} +29 -18
- package/dist/{messages-pgPcitDH.mjs → chunks/messages-BevRhv5d.mjs} +28 -17
- package/dist/chunks/{messages-BW_7lfqG2.mjs → messages-Bhqr7Im2.mjs} +28 -17
- package/dist/chunks/{messages-LxumrNue2.mjs → messages-BpJFjSKa.mjs} +29 -18
- package/dist/{messages-xEI8gEDK.mjs → chunks/messages-BqYlq_Bn.mjs} +28 -17
- package/dist/{messages-CBdQ3XP9.mjs → chunks/messages-BtAwCUfD.mjs} +28 -17
- package/dist/{messages-D3cAcyzj.mjs → chunks/messages-Bthbp65G.mjs} +29 -18
- package/dist/{messages-CYX48nfg.mjs → chunks/messages-BvHMZ8Pi2.mjs} +28 -17
- package/dist/{messages-Dddxv8-f2.mjs → chunks/messages-Bw1BE9jW.mjs} +28 -17
- package/dist/chunks/{messages-d0Ky6QjR.mjs → messages-Bx6Wt285.mjs} +28 -17
- package/dist/chunks/{messages-BPog17132.mjs → messages-BzslJRYv.mjs} +29 -18
- package/dist/{messages-hTpeKUaW.mjs → chunks/messages-C02M0Tpw.mjs} +28 -17
- package/dist/chunks/{messages-C-b6tPad2.mjs → messages-C1u3E9qg.mjs} +28 -17
- package/dist/{messages-BJ7BuFZi.mjs → chunks/messages-C68WgSKk.mjs} +29 -18
- package/dist/chunks/{messages-Bpda_3PM2.mjs → messages-C8w8JCP0.mjs} +30 -19
- package/dist/chunks/{messages-CmrMwBv3.mjs → messages-CFOZdSk4.mjs} +28 -17
- package/dist/{messages-DVQNjdPk.mjs → chunks/messages-CGOY79lr.mjs} +28 -17
- package/dist/chunks/{messages-DAVsuDWh2.mjs → messages-CGaSMZPu.mjs} +28 -17
- package/dist/{messages-DtrSrdfE2.mjs → chunks/messages-CJJgQ0BH.mjs} +28 -17
- package/dist/{messages-CgzbJ8_l2.mjs → chunks/messages-CTD6rtQj2.mjs} +28 -17
- package/dist/chunks/{messages-p4byLfvR.mjs → messages-CZymJML9.mjs} +32 -21
- package/dist/{messages-CqkRG9mH.mjs → chunks/messages-CfeFJbiv.mjs} +32 -21
- package/dist/{messages-DjJQoYvP2.mjs → chunks/messages-Cgatzu_z.mjs} +30 -19
- package/dist/{messages-CM5fsPo02.mjs → chunks/messages-Ch2zBI602.mjs} +28 -17
- package/dist/chunks/{messages-CyNsByCY.mjs → messages-CiAHsUfO.mjs} +28 -17
- package/dist/{messages-BXI3qIos.mjs → chunks/messages-Cuzq-tNW.mjs} +28 -17
- package/dist/chunks/{messages-FHrCEJmY2.mjs → messages-Cw4qiMwb.mjs} +28 -17
- package/dist/chunks/{messages-xfjdrZmx.mjs → messages-Cyh-mz40.mjs} +28 -17
- package/dist/{messages-Bo_FUvVH.mjs → chunks/messages-D-I2QO8H.mjs} +28 -17
- package/dist/chunks/{messages-Ct7AMBS82.mjs → messages-D0D2gruy.mjs} +28 -17
- package/dist/chunks/{messages-CrMfiGu5.mjs → messages-D1BKxfLD.mjs} +29 -18
- package/dist/chunks/{messages-CmXADeab2.mjs → messages-D4eDs6R_.mjs} +28 -17
- package/dist/chunks/{messages-ClRHDxzh.mjs → messages-D9Xr-hES.mjs} +28 -17
- package/dist/{messages-tsHpMdDT2.mjs → chunks/messages-D9eJPHia.mjs} +30 -19
- package/dist/{messages-DUBHHfEt.mjs → chunks/messages-DBFWSzKY2.mjs} +28 -17
- package/dist/{messages-i4S6q64n2.mjs → chunks/messages-DC0wu2S7.mjs} +28 -17
- package/dist/chunks/{messages-BnznaKEP2.mjs → messages-DF9o19rG.mjs} +28 -17
- package/dist/{messages-DA-o8X3A.mjs → chunks/messages-DFS_n986.mjs} +51 -40
- package/dist/{messages-BGsDZTQp2.mjs → chunks/messages-DGS4H30T.mjs} +28 -17
- package/dist/chunks/{messages-Cdx4QMR1.mjs → messages-DKjddpzJ.mjs} +30 -19
- package/dist/chunks/{messages-B3s2vra72.mjs → messages-DMvTdUXC.mjs} +30 -19
- package/dist/{messages-Dcyrzdxa2.mjs → chunks/messages-DQUX-QYI2.mjs} +28 -17
- package/dist/chunks/{messages-BS1nOvZ-.mjs → messages-DUigq8FO2.mjs} +28 -17
- package/dist/{messages-BKjqW08U.mjs → chunks/messages-DY0FJdpH.mjs} +28 -17
- package/dist/{messages-BBvDbp62.mjs → chunks/messages-DfVXiqt-2.mjs} +28 -17
- package/dist/chunks/{messages-DHCVA7XQ.mjs → messages-DgZc9TJw.mjs} +28 -17
- package/dist/chunks/{messages-1Raf1IK82.mjs → messages-QD4BCUDP.mjs} +28 -17
- package/dist/{messages-JhoVMjfX2.mjs → chunks/messages-USmweex9.mjs} +28 -17
- package/dist/chunks/{messages-DBpXyvRe2.mjs → messages-a1JTi0Qm.mjs} +31 -20
- package/dist/chunks/{messages-D5IgUbBD2.mjs → messages-jcgCHPRn.mjs} +28 -17
- package/dist/chunks/{messages-Dfpi8pDY.mjs → messages-tnnqHpbd.mjs} +29 -18
- package/dist/{messages-DZEcrbmH.mjs → chunks/messages-vzWKPLJO.mjs} +28 -17
- package/dist/chunks/micromark-extension-math-Cz_ZZ_0Y.mjs +169 -0
- package/dist/chunks/micromark-factory-space-WwmyBO_J.mjs +36 -0
- package/dist/chunks/mindmap-definition-QFDTVHPH-BswFuNN6.mjs +1013 -0
- package/dist/chunks/{notifier-Butv4Dvo.mjs → notifier-B1zCi9G1.mjs} +1 -1
- package/dist/chunks/{objectSpread2-BY4mgzrQ.mjs → objectSpread2-CWwMYL_U.mjs} +1 -1
- package/dist/chunks/ordinal-D1_lEgAO.mjs +65 -0
- package/dist/chunks/packet-4T2RLAQJ-DTUW2U0C.mjs +3 -0
- package/dist/chunks/path-6nYPAvNb.mjs +85 -0
- package/dist/chunks/pie-ZZUOXDRM-D-umqvEM.mjs +3 -0
- package/dist/chunks/pieDiagram-DEJITSTG-1WJgvK1w.mjs +179 -0
- package/dist/chunks/quadrantDiagram-34T5L4WZ-B_YH8QGl.mjs +1960 -0
- package/dist/chunks/radar-PYXPWWZC-DkQelf08.mjs +3 -0
- package/dist/chunks/requirementDiagram-MS252O5E-DRl0YJRI.mjs +2224 -0
- package/dist/chunks/rough.esm-CSWJruu5.mjs +1353 -0
- package/dist/chunks/sankeyDiagram-XADWPNL6-B-8IrknH.mjs +909 -0
- package/dist/chunks/sequenceDiagram-FGHM5R23-DTLb8qmO.mjs +4181 -0
- package/dist/chunks/src-CRgEHLPW.mjs +2149 -0
- package/dist/chunks/stateDiagram-FHFEXIEX-B0JFjLFy.mjs +218 -0
- package/dist/chunks/stateDiagram-v2-QKLJ7IA2-Co9CUU_z.mjs +28 -0
- package/dist/chunks/timeline-definition-GMOUNBTQ-CS9KTh-Q.mjs +1084 -0
- package/dist/chunks/{tools-C2_IVsQY.mjs → tools-CSYsrnud.mjs} +2846 -3098
- package/dist/chunks/treeView-SZITEDCU-DOOoyNP9.mjs +3 -0
- package/dist/chunks/treemap-W4RFUUIX-CsOoUA-u.mjs +3 -0
- package/dist/chunks/vennDiagram-DHZGUBPP-0BNu5Wna.mjs +1876 -0
- package/dist/chunks/wardley-RL74JXVD-CCzZcmEk.mjs +3 -0
- package/dist/chunks/wardleyDiagram-NUSXRM2D-Ca9XByNH.mjs +594 -0
- package/dist/chunks/xychartDiagram-5P7HB3ND-C8AyKUAE.mjs +2017 -0
- package/dist/cli.mjs +1 -1
- package/dist/full.mjs +14 -14
- package/dist/locales.mjs +95 -84
- package/dist/markdown.mjs +3962 -0
- package/dist/{chunks/messages-6mikOS4D2.mjs → messages-5jvKxQNu2.mjs} +28 -17
- package/dist/{messages-BAcH6PtT2.mjs → messages-7QD-X6XT2.mjs} +28 -17
- package/dist/{messages-DbxbxUiK2.mjs → messages-96iaAUds2.mjs} +29 -18
- package/dist/{messages-CVcQD-9u.mjs → messages-B19o-Teb.mjs} +30 -19
- package/dist/{messages-Ccd587Yn.mjs → messages-B1ZUQagA.mjs} +28 -17
- package/dist/{messages-upqrRZQH2.mjs → messages-B7ieAJBd2.mjs} +28 -17
- package/dist/{chunks/messages-Csvm4mtA.mjs → messages-BECMxmfX.mjs} +28 -17
- package/dist/{chunks/messages-DA7Zk-Cy.mjs → messages-BIHc0KHY.mjs} +29 -18
- package/dist/{chunks/messages-BdnSVKOw.mjs → messages-BIoeoik5.mjs} +28 -17
- package/dist/{chunks/messages-DQ5AyNCU.mjs → messages-BJeGJksD.mjs} +28 -17
- package/dist/{messages-C5XPUD9T2.mjs → messages-BRZX964b2.mjs} +29 -18
- package/dist/{messages-Dkg99bfr2.mjs → messages-BTQPpoM42.mjs} +31 -20
- package/dist/{messages-fLi0P2dP.mjs → messages-BYNcD6uR.mjs} +28 -17
- package/dist/{messages-BvgTQLf72.mjs → messages-BYmmMDrN2.mjs} +28 -17
- package/dist/{chunks/messages-CgRvtOEY.mjs → messages-BbYq1pk-.mjs} +28 -17
- package/dist/{chunks/messages-DUDgFEEe2.mjs → messages-BiUGXvYr2.mjs} +28 -17
- package/dist/{chunks/messages-DJkIeapn.mjs → messages-BiiongNz2.mjs} +28 -17
- package/dist/{messages-BBq0M604.mjs → messages-Bm0Feca1.mjs} +32 -21
- package/dist/{messages-eTourT12.mjs → messages-BmAn22OX.mjs} +28 -17
- package/dist/{messages-C6Y4Jv2N.mjs → messages-Bq3F2Tp_.mjs} +28 -17
- package/dist/{messages-DIRha_gg2.mjs → messages-BsycN_JI2.mjs} +28 -17
- package/dist/{chunks/messages-CljStrYi.mjs → messages-BwHs4cm1.mjs} +32 -21
- package/dist/{chunks/messages-Cs9XBt4T.mjs → messages-CJTy6JZt.mjs} +28 -17
- package/dist/{messages-BokEflKa.mjs → messages-CR_L_UtK.mjs} +28 -17
- package/dist/{chunks/messages-ZJ0b1C3a.mjs → messages-CSUHBs4c2.mjs} +28 -17
- package/dist/{messages-BcFQFcJ92.mjs → messages-CWIXvnDf2.mjs} +28 -17
- package/dist/{messages-DnatBKPm.mjs → messages-CcF4y-E4.mjs} +28 -17
- package/dist/{messages-BywbKcPC.mjs → messages-Ce6KVEbT.mjs} +29 -18
- package/dist/{messages-DOTJ2NvJ.mjs → messages-Ci0KqX-J.mjs} +35 -24
- package/dist/{messages-BtxaN-xx.mjs → messages-CjbnogEC.mjs} +28 -17
- package/dist/{messages-BSe3QDnQ.mjs → messages-CmB406HW.mjs} +30 -19
- package/dist/{messages-BVKZK-3t.mjs → messages-CqXtJTpU.mjs} +28 -17
- package/dist/{chunks/messages-DJA6fb_P2.mjs → messages-D0aw5_0k2.mjs} +30 -19
- package/dist/{chunks/messages-DPykxECP2.mjs → messages-D8FQWulF2.mjs} +28 -17
- package/dist/{chunks/messages-CpzO7KRA.mjs → messages-DBiVgUs2.mjs} +29 -18
- package/dist/{chunks/messages-B0ffBqzr.mjs → messages-DIJlIqlQ2.mjs} +28 -17
- package/dist/{chunks/messages-BaPZuLjN.mjs → messages-DLX_iBDJ.mjs} +28 -17
- package/dist/{chunks/messages-CvfKofOP.mjs → messages-DLlc9QPw.mjs} +28 -17
- package/dist/{chunks/messages-Czny5pPT2.mjs → messages-DMr62KiO2.mjs} +28 -17
- package/dist/{chunks/messages-IDEUsFhQ2.mjs → messages-DPA-mMWC2.mjs} +29 -18
- package/dist/{messages-BCuTVHBV.mjs → messages-DTh9a8mR.mjs} +28 -17
- package/dist/{chunks/messages-DT7fRpCy.mjs → messages-DY4IqlhY.mjs} +28 -17
- package/dist/{chunks/messages-BgVEGd4c.mjs → messages-DYTTu0O12.mjs} +28 -17
- package/dist/{messages-Bk984gRE2.mjs → messages-DbySKTKt2.mjs} +30 -19
- package/dist/{chunks/messages-ID1PHnMv.mjs → messages-Ddnj2iTG2.mjs} +28 -17
- package/dist/{messages-BmNaAyKS.mjs → messages-DkLU_rWm.mjs} +28 -17
- package/dist/{messages-C6OJvnJg2.mjs → messages-Dl3Sv6Rq2.mjs} +29 -18
- package/dist/{chunks/messages-C1OqT_nL.mjs → messages-Dl5Y2-Ia.mjs} +51 -40
- package/dist/{chunks/messages-Cqc-6rfh2.mjs → messages-DnG0ef8t2.mjs} +30 -19
- package/dist/{chunks/messages-BkCjgGxc.mjs → messages-DnGJD4TL.mjs} +28 -17
- package/dist/{messages-Bio7KYsr2.mjs → messages-Dnp9N6RU2.mjs} +28 -17
- package/dist/{chunks/messages-Df87zXXG.mjs → messages-Dvn35ksS.mjs} +28 -17
- package/dist/{messages-CHJ5SOZI.mjs → messages-Dw__BcTj.mjs} +28 -17
- package/dist/{chunks/messages-DC7TX-YT.mjs → messages-Dy-Y_nEI.mjs} +28 -17
- package/dist/{messages-DV9e1DW7.mjs → messages-E_ZuzGDt.mjs} +28 -17
- package/dist/{messages-DD5pW0zJ.mjs → messages-F2xRoY1w.mjs} +28 -17
- package/dist/{chunks/messages-BgsPQXfP.mjs → messages-Smt4GBbj.mjs} +33 -22
- package/dist/{messages-DJT4Bt_02.mjs → messages-aMXpHt5X2.mjs} +28 -17
- package/dist/{chunks/messages-B2pW6jO_.mjs → messages-aWZH50vu2.mjs} +30 -19
- package/dist/{chunks/messages-u2yxkNTE2.mjs → messages-dv19AkyJ.mjs} +28 -17
- package/dist/{messages-DJKLtW7u.mjs → messages-hWwSRF-2.mjs} +28 -17
- package/dist/{messages-tK67CBqn.mjs → messages-j7o5rT9s.mjs} +28 -17
- package/dist/{messages-DqyqEw1_.mjs → messages-nUVjeh7K.mjs} +29 -18
- package/dist/{chunks/messages-DSjXen8E.mjs → messages-nlhESX9t.mjs} +28 -17
- package/dist/{messages-C30Vz-UZ2.mjs → messages-rk-A1Wa42.mjs} +30 -19
- package/dist/{chunks/messages-DR09nkcZ.mjs → messages-xh2eOLvs.mjs} +28 -17
- package/dist/{chunks/messages-C11byid72.mjs → messages-ynAe7ewZ.mjs} +28 -17
- package/dist/react.mjs +3 -3
- package/dist/tools.mjs +3 -3
- package/dist/vendor.LICENSE.txt +4609 -212
- package/package.json +21 -3
- package/src/components/blocks.ts +26 -1
- package/src/components/constants/data-attributes.ts +0 -2
- package/src/components/i18n/locales/am/messages.json +28 -17
- package/src/components/i18n/locales/ar/messages.json +28 -17
- package/src/components/i18n/locales/az/messages.json +28 -17
- package/src/components/i18n/locales/bg/messages.json +28 -17
- package/src/components/i18n/locales/bn/messages.json +28 -17
- package/src/components/i18n/locales/bs/messages.json +30 -19
- package/src/components/i18n/locales/cs/messages.json +32 -21
- package/src/components/i18n/locales/da/messages.json +35 -24
- package/src/components/i18n/locales/de/messages.json +33 -22
- package/src/components/i18n/locales/dv/messages.json +28 -17
- package/src/components/i18n/locales/el/messages.json +28 -17
- package/src/components/i18n/locales/en/messages.json +28 -17
- package/src/components/i18n/locales/es/messages.json +29 -18
- package/src/components/i18n/locales/et/messages.json +32 -21
- package/src/components/i18n/locales/fa/messages.json +28 -17
- package/src/components/i18n/locales/fi/messages.json +28 -17
- package/src/components/i18n/locales/fil/messages.json +51 -40
- package/src/components/i18n/locales/fr/messages.json +29 -18
- package/src/components/i18n/locales/gu/messages.json +28 -17
- package/src/components/i18n/locales/he/messages.json +28 -17
- package/src/components/i18n/locales/hi/messages.json +28 -17
- package/src/components/i18n/locales/hr/messages.json +30 -19
- package/src/components/i18n/locales/hu/messages.json +29 -18
- package/src/components/i18n/locales/hy/messages.json +28 -17
- package/src/components/i18n/locales/id/messages.json +28 -17
- package/src/components/i18n/locales/it/messages.json +29 -18
- package/src/components/i18n/locales/ja/messages.json +28 -17
- package/src/components/i18n/locales/ka/messages.json +28 -17
- package/src/components/i18n/locales/km/messages.json +28 -17
- package/src/components/i18n/locales/kn/messages.json +28 -17
- package/src/components/i18n/locales/ko/messages.json +28 -17
- package/src/components/i18n/locales/ku/messages.json +28 -17
- package/src/components/i18n/locales/lo/messages.json +28 -17
- package/src/components/i18n/locales/lt/messages.json +28 -17
- package/src/components/i18n/locales/lv/messages.json +28 -17
- package/src/components/i18n/locales/mk/messages.json +28 -17
- package/src/components/i18n/locales/ml/messages.json +28 -17
- package/src/components/i18n/locales/mn/messages.json +28 -17
- package/src/components/i18n/locales/mr/messages.json +28 -17
- package/src/components/i18n/locales/ms/messages.json +30 -19
- package/src/components/i18n/locales/my/messages.json +28 -17
- package/src/components/i18n/locales/ne/messages.json +28 -17
- package/src/components/i18n/locales/nl/messages.json +30 -19
- package/src/components/i18n/locales/no/messages.json +31 -20
- package/src/components/i18n/locales/pa/messages.json +28 -17
- package/src/components/i18n/locales/pl/messages.json +29 -18
- package/src/components/i18n/locales/ps/messages.json +28 -17
- package/src/components/i18n/locales/pt/messages.json +29 -18
- package/src/components/i18n/locales/ro/messages.json +29 -18
- package/src/components/i18n/locales/ru/messages.json +28 -17
- package/src/components/i18n/locales/sd/messages.json +28 -17
- package/src/components/i18n/locales/si/messages.json +28 -17
- package/src/components/i18n/locales/sk/messages.json +30 -19
- package/src/components/i18n/locales/sl/messages.json +30 -19
- package/src/components/i18n/locales/sq/messages.json +29 -18
- package/src/components/i18n/locales/sr/messages.json +28 -17
- package/src/components/i18n/locales/sv/messages.json +30 -19
- package/src/components/i18n/locales/sw/messages.json +28 -17
- package/src/components/i18n/locales/ta/messages.json +28 -17
- package/src/components/i18n/locales/te/messages.json +28 -17
- package/src/components/i18n/locales/th/messages.json +28 -17
- package/src/components/i18n/locales/tr/messages.json +28 -17
- package/src/components/i18n/locales/ug/messages.json +28 -17
- package/src/components/i18n/locales/uk/messages.json +28 -17
- package/src/components/i18n/locales/ur/messages.json +28 -17
- package/src/components/i18n/locales/vi/messages.json +28 -17
- package/src/components/i18n/locales/yi/messages.json +28 -17
- package/src/components/i18n/locales/zh/messages.json +28 -17
- package/src/components/icons/index.ts +59 -47
- package/src/components/inline-tools/inline-tool-code.ts +399 -0
- package/src/components/modules/api/blocks.ts +17 -0
- package/src/components/modules/api/tools.ts +0 -19
- package/src/components/modules/blockEvents/composers/blockSelectionKeys.ts +20 -3
- package/src/components/modules/blockEvents/composers/keyboardNavigation.ts +5 -5
- package/src/components/modules/blockManager/blockManager.ts +0 -11
- package/src/components/modules/blockManager/event-binder.ts +1 -12
- package/src/components/modules/paste/handlers/html-handler.ts +13 -10
- package/src/components/modules/paste/handlers/index.ts +1 -0
- package/src/components/modules/paste/index.ts +6 -0
- package/src/components/modules/themeManager.ts +1 -3
- package/src/components/modules/toolbar/blockSettings.ts +1 -0
- package/src/components/modules/toolbar/inline/index.ts +3 -0
- package/src/components/modules/ui.ts +0 -13
- package/src/components/modules/uiControllers/controllers/keyboard.ts +0 -29
- package/src/components/modules/uiControllers/controllers/selection.ts +2 -14
- package/src/components/ui/toolbox.ts +1 -0
- package/src/components/utils/popover/popover-position.ts +2 -4
- package/src/markdown/index.ts +63 -0
- package/src/markdown/markdown-handler.ts +110 -0
- package/src/markdown/mdast-to-blocks.ts +418 -0
- package/src/markdown/phrasing-to-html.ts +60 -0
- package/src/markdown/types.ts +42 -0
- package/src/stories/EditorModes.stories.ts +0 -60
- package/src/styles/main.css +39 -1140
- package/src/tools/callout/emoji-picker/index.ts +3 -2
- package/src/tools/callout/index.ts +24 -0
- package/src/tools/code/code-keyboard.ts +142 -0
- package/src/tools/code/constants.ts +96 -0
- package/src/tools/code/dom-builder.ts +181 -0
- package/src/tools/code/highlight-applier.ts +229 -0
- package/src/tools/code/index.ts +462 -0
- package/src/tools/code/katex-loader.ts +50 -0
- package/src/tools/code/language-picker.ts +241 -0
- package/src/tools/code/mermaid-loader.ts +45 -0
- package/src/tools/code/shiki-loader.ts +135 -0
- package/src/tools/divider/index.ts +9 -1
- package/src/tools/index.ts +4 -2
- package/src/tools/list/block-operations.ts +3 -1
- package/src/tools/list/depth-validator.ts +4 -7
- package/src/tools/list/dom-builder.ts +5 -3
- package/src/tools/list/index.ts +21 -3
- package/src/tools/list/list-helpers.ts +9 -2
- package/src/tools/list/list-keyboard.ts +56 -14
- package/src/tools/list/list-lifecycle.ts +3 -1
- package/src/tools/list/marker-calculator.ts +37 -0
- package/src/tools/list/ordered-marker-manager.ts +4 -2
- package/src/tools/table/core/table-commands.ts +16 -0
- package/src/tools/table/core/table-controller.ts +29 -0
- package/src/tools/table/core/table-events.ts +17 -0
- package/src/tools/table/index.ts +196 -13
- package/src/tools/table/table-cell-blocks.ts +9 -6
- package/src/tools/table/table-cell-clipboard.ts +7 -2
- package/src/tools/table/table-cell-placement-picker.ts +133 -0
- package/src/tools/table/table-cell-selection.ts +174 -19
- package/src/tools/table/table-core.ts +321 -113
- package/src/tools/table/table-map.ts +279 -0
- package/src/tools/table/table-model.ts +901 -1
- package/src/tools/table/table-operations.ts +78 -44
- package/src/tools/table/table-resize.ts +19 -17
- package/src/tools/table/table-row-col-drag.ts +24 -10
- package/src/tools/table/types.ts +24 -2
- package/types/api/tools.d.ts +0 -18
- package/types/data-attributes.d.ts +0 -1
- package/types/index.d.ts +0 -16
- package/types/markdown.d.ts +2 -0
- package/types/tools/code.d.ts +13 -0
- package/src/tools/database/database-backend-sync.ts +0 -101
- package/src/tools/database/database-board-view.ts +0 -301
- package/src/tools/database/database-card-drag.ts +0 -306
- package/src/tools/database/database-card-drawer.ts +0 -546
- package/src/tools/database/database-column-controls.ts +0 -46
- package/src/tools/database/database-column-drag.ts +0 -262
- package/src/tools/database/database-keyboard.ts +0 -35
- package/src/tools/database/database-list-row-drag.ts +0 -245
- package/src/tools/database/database-list-view.ts +0 -333
- package/src/tools/database/database-model.ts +0 -246
- package/src/tools/database/database-property-type-popover.ts +0 -108
- package/src/tools/database/database-tab-bar.ts +0 -532
- package/src/tools/database/database-view-popover.ts +0 -109
- package/src/tools/database/database-view-renderer.ts +0 -25
- package/src/tools/database/index.ts +0 -948
- package/src/tools/database/types.ts +0 -144
- package/types/tools/database.d.ts +0 -145
- /package/dist/chunks/{am-CHDDMHkd.mjs → am-rVzV1W41.mjs} +0 -0
- /package/dist/chunks/{ar-DoqfNqut.mjs → ar-C710lkoH.mjs} +0 -0
- /package/dist/chunks/{az-C34P9iEa.mjs → az-BOp1pgua.mjs} +0 -0
- /package/dist/chunks/{bg-jroXLY8Y.mjs → bg-CL9p09ZD.mjs} +0 -0
- /package/dist/chunks/{bn-BRI-WqxY.mjs → bn-CNmSeyAy.mjs} +0 -0
- /package/dist/chunks/{bs-CCGUpNHu.mjs → bs-BRzMGqzk.mjs} +0 -0
- /package/dist/chunks/{cs-D5qZOGuc.mjs → cs-BYPBLmnF.mjs} +0 -0
- /package/dist/chunks/{da-DrJ7W37K.mjs → da-CBC_LR1c.mjs} +0 -0
- /package/dist/chunks/{de-BW6-kp2c.mjs → de-DxRFMoAj.mjs} +0 -0
- /package/dist/chunks/{el-C-Vc_Otu.mjs → el-Bk6YbySf.mjs} +0 -0
- /package/dist/chunks/{es-B6fI5K9i.mjs → es-DpT3FCMR.mjs} +0 -0
- /package/dist/chunks/{et-BhVlZ-Yz.mjs → et-DE9Dr_g9.mjs} +0 -0
- /package/dist/chunks/{fa-D55Ijdqa.mjs → fa-Banj1QUE.mjs} +0 -0
- /package/dist/chunks/{fi-jNLjhKUQ.mjs → fi-DfN3M5ER.mjs} +0 -0
- /package/dist/chunks/{fil-DYd0T5aX.mjs → fil-DbCsRS1d.mjs} +0 -0
- /package/dist/chunks/{fr-yxy5xWw_.mjs → fr-D1clKhgt.mjs} +0 -0
- /package/dist/chunks/{gu-CcY_LJe7.mjs → gu-1CsZyRwT.mjs} +0 -0
- /package/dist/chunks/{he-DL9s7wNw.mjs → he-qQdnL6eK.mjs} +0 -0
- /package/dist/chunks/{hi-C8eGXgw5.mjs → hi-DxM0Nff1.mjs} +0 -0
- /package/dist/chunks/{hr-DLpybOhU.mjs → hr-Onldyi-u.mjs} +0 -0
- /package/dist/chunks/{hu-BkT0gT00.mjs → hu-CAn3pBuY.mjs} +0 -0
- /package/dist/chunks/{hy-CVFDCp2S.mjs → hy-D43q7NxE.mjs} +0 -0
- /package/dist/chunks/{id-0P4W9Az0.mjs → id-Xrw5Dd0Y.mjs} +0 -0
- /package/dist/chunks/{it-mLY6_uoW.mjs → it-CA9ZDMSc.mjs} +0 -0
- /package/dist/chunks/{ja-7RkeRNWG.mjs → ja-D0J6WRFh.mjs} +0 -0
- /package/dist/chunks/{ka-C7Lx-Qsh.mjs → ka-BZL7xDuY.mjs} +0 -0
- /package/dist/chunks/{km-Q8udaraH.mjs → km-BimgQZVU.mjs} +0 -0
- /package/dist/chunks/{kn-BiETM-iq.mjs → kn-C2n2cPHK.mjs} +0 -0
- /package/dist/chunks/{ko-tiB80pF1.mjs → ko-n4Cn93D3.mjs} +0 -0
- /package/dist/chunks/{ku-CY-OABkR.mjs → ku-BYZCgT44.mjs} +0 -0
- /package/dist/chunks/{lo-CTBhEnyk.mjs → lo-DVXiAE4N.mjs} +0 -0
- /package/dist/chunks/{lt-BHKHEtqK.mjs → lt-B9KlQFnY.mjs} +0 -0
- /package/dist/chunks/{lv-DWxgtfUg.mjs → lv-BINeOdyx.mjs} +0 -0
- /package/dist/chunks/{mk-BjookGdx.mjs → mk-_-QrPrLN.mjs} +0 -0
- /package/dist/chunks/{ml-L-NnZcp9.mjs → ml-KvJSC1KT.mjs} +0 -0
- /package/dist/chunks/{mn-OMWi7Hl_.mjs → mn-CjFjWnRG.mjs} +0 -0
- /package/dist/chunks/{mr-B6JPzITo.mjs → mr-DqAZ7FRX.mjs} +0 -0
- /package/dist/chunks/{ms-CG3S-sPB.mjs → ms-BZcV4UG_.mjs} +0 -0
- /package/dist/chunks/{my-BLAmGfhT.mjs → my-97SC9jYN.mjs} +0 -0
- /package/dist/chunks/{native-BPcABu9z.mjs → native-CzYG0YgY.mjs} +0 -0
- /package/dist/chunks/{ne-D1JHLfYw.mjs → ne-Bs-M2TyF.mjs} +0 -0
- /package/dist/chunks/{nl-Ca7Q8FnY.mjs → nl-2ZwQilo-.mjs} +0 -0
- /package/dist/chunks/{no-Coxcohcz.mjs → no-fOQTpFq1.mjs} +0 -0
- /package/dist/chunks/{pa-CCaXqpaI.mjs → pa-DLOqkMi0.mjs} +0 -0
- /package/dist/chunks/{pl-Cl_fAZ84.mjs → pl-FYs9QrXU.mjs} +0 -0
- /package/dist/chunks/{ps-WD5qGAWy.mjs → ps-CTXe6pSe.mjs} +0 -0
- /package/dist/chunks/{pt-C4zvLfvq.mjs → pt-B1X4x7d1.mjs} +0 -0
- /package/dist/chunks/{ro-DbefHcmM.mjs → ro-Bf7S2FaR.mjs} +0 -0
- /package/dist/chunks/{ru-uU1J14jd.mjs → ru-B8lqnu_j.mjs} +0 -0
- /package/dist/chunks/{sd-DKu368Ip.mjs → sd-CHRYJm2r.mjs} +0 -0
- /package/dist/chunks/{si-BsJCiPkZ.mjs → si-CI0Hs6vH.mjs} +0 -0
- /package/dist/chunks/{sk-CD-a3SN6.mjs → sk-Bdvq1Kb_.mjs} +0 -0
- /package/dist/chunks/{sl-CXhrPJe_.mjs → sl-B_qiFTV5.mjs} +0 -0
- /package/dist/chunks/{sq-CTctCoFQ.mjs → sq-E0j1hysP.mjs} +0 -0
- /package/dist/chunks/{sr-BZkhBwXj.mjs → sr-VPpVNTZw.mjs} +0 -0
- /package/dist/chunks/{sv-NmRZb_xi.mjs → sv-gKmDSR3d.mjs} +0 -0
- /package/dist/chunks/{sw-Be5ik3H6.mjs → sw-zeFLiO23.mjs} +0 -0
- /package/dist/chunks/{ta-DsXh6neL.mjs → ta-Ci-j89hR.mjs} +0 -0
- /package/dist/chunks/{te-CwpCbM8M.mjs → te-qyMI0M7a.mjs} +0 -0
- /package/dist/chunks/{th-CcZ15OLk.mjs → th-DPxHtpdb.mjs} +0 -0
- /package/dist/chunks/{tr-q3bTgvhW.mjs → tr-CRV6GS-G.mjs} +0 -0
- /package/dist/chunks/{tw-DmW6-pCY.mjs → tw-CqxBf-1Y.mjs} +0 -0
- /package/dist/chunks/{ug-919EhLsL.mjs → ug-DW0YFpo5.mjs} +0 -0
- /package/dist/chunks/{uk-aNMEzd0Y.mjs → uk-ssteuphK.mjs} +0 -0
- /package/dist/chunks/{ur-BwQI77sh.mjs → ur-qhY3-jY7.mjs} +0 -0
- /package/dist/chunks/{vi-Dxq806-F.mjs → vi-CHriMMC8.mjs} +0 -0
- /package/dist/chunks/{zh-BcHuy1Ti.mjs → zh-BJktawVN.mjs} +0 -0
|
@@ -2,7 +2,7 @@ import type { API } from '../../../types';
|
|
|
2
2
|
|
|
3
3
|
import type { TableCellBlocks } from './table-cell-blocks';
|
|
4
4
|
import { CELL_BLOCKS_ATTR } from './table-cell-blocks';
|
|
5
|
-
import { BORDER_WIDTH, ROW_ATTR, CELL_ATTR } from './table-core';
|
|
5
|
+
import { BORDER_WIDTH, ROW_ATTR, CELL_ATTR, CELL_COL_ATTR } from './table-core';
|
|
6
6
|
import type { TableGrid } from './table-core';
|
|
7
7
|
import type { LegacyCellContent, TableData } from './types';
|
|
8
8
|
import { isCellWithBlocks } from './types';
|
|
@@ -10,37 +10,51 @@ import { isCellWithBlocks } from './types';
|
|
|
10
10
|
// ─── Pure DOM helpers ───────────────────────────────────────────────
|
|
11
11
|
|
|
12
12
|
export const readPixelWidths = (gridEl: HTMLElement): number[] => {
|
|
13
|
-
const
|
|
13
|
+
const colgroup = gridEl.querySelector('colgroup');
|
|
14
14
|
|
|
15
|
-
if (!
|
|
15
|
+
if (!colgroup) {
|
|
16
16
|
return [];
|
|
17
17
|
}
|
|
18
18
|
|
|
19
|
-
const
|
|
19
|
+
const cols = colgroup.querySelectorAll('col');
|
|
20
|
+
const firstCol = cols[0] as HTMLElement | undefined;
|
|
20
21
|
|
|
21
|
-
return
|
|
22
|
-
|
|
22
|
+
// When columns use percentage widths, parseFloat would return the percentage
|
|
23
|
+
// number (e.g. 50 from "50%") which is not a pixel value. In that case,
|
|
24
|
+
// read actual rendered widths from the first row's cells.
|
|
25
|
+
if (firstCol && firstCol.style.width.endsWith('%')) {
|
|
26
|
+
const firstRow = gridEl.querySelector(`[${ROW_ATTR}]`);
|
|
27
|
+
|
|
28
|
+
if (firstRow) {
|
|
29
|
+
return Array.from(firstRow.querySelectorAll(`[${CELL_ATTR}]`)).map(
|
|
30
|
+
cell => Math.round(cell.getBoundingClientRect().width)
|
|
31
|
+
);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
return Array.from(cols).map(col =>
|
|
36
|
+
parseFloat((col as HTMLElement).style.width) || 0
|
|
23
37
|
);
|
|
24
38
|
};
|
|
25
39
|
|
|
26
40
|
export const applyPixelWidths = (gridEl: HTMLElement, widths: number[]): void => {
|
|
27
41
|
const totalWidth = widths.reduce((sum, w) => sum + w, 0);
|
|
28
|
-
const
|
|
42
|
+
const grid: HTMLElement = gridEl;
|
|
29
43
|
|
|
30
|
-
|
|
44
|
+
grid.style.width = `${totalWidth + BORDER_WIDTH}px`;
|
|
31
45
|
|
|
32
|
-
const
|
|
46
|
+
const colgroup = gridEl.querySelector('colgroup');
|
|
33
47
|
|
|
34
|
-
|
|
35
|
-
|
|
48
|
+
if (!colgroup) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
36
51
|
|
|
37
|
-
|
|
38
|
-
if (i < widths.length) {
|
|
39
|
-
const cellEl = node as HTMLElement;
|
|
52
|
+
const cols = Array.from(colgroup.querySelectorAll('col')) as HTMLElement[];
|
|
40
53
|
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
54
|
+
widths.forEach((w, i) => {
|
|
55
|
+
if (i < cols.length) {
|
|
56
|
+
cols[i].style.width = `${w}px`;
|
|
57
|
+
}
|
|
44
58
|
});
|
|
45
59
|
};
|
|
46
60
|
|
|
@@ -92,8 +106,7 @@ export const isColumnEmpty = (gridEl: HTMLElement, colIndex: number): boolean =>
|
|
|
92
106
|
const rows = gridEl.querySelectorAll(`[${ROW_ATTR}]`);
|
|
93
107
|
|
|
94
108
|
return Array.from(rows).every(row => {
|
|
95
|
-
const
|
|
96
|
-
const cell = cells[colIndex] as HTMLElement | undefined;
|
|
109
|
+
const cell = row.querySelector<HTMLElement>(`[${CELL_COL_ATTR}="${colIndex}"]`);
|
|
97
110
|
|
|
98
111
|
return !cell || isCellEmpty(cell);
|
|
99
112
|
});
|
|
@@ -102,16 +115,15 @@ export const isColumnEmpty = (gridEl: HTMLElement, colIndex: number): boolean =>
|
|
|
102
115
|
// ─── Percent-mode width redistribution ──────────────────────────────
|
|
103
116
|
|
|
104
117
|
export const redistributePercentWidths = (gridEl: HTMLElement): void => {
|
|
105
|
-
const
|
|
106
|
-
const firstRow = rows[0];
|
|
118
|
+
const colgroup = gridEl.querySelector('colgroup');
|
|
107
119
|
|
|
108
|
-
if (!
|
|
120
|
+
if (!colgroup) {
|
|
109
121
|
return;
|
|
110
122
|
}
|
|
111
123
|
|
|
112
|
-
const
|
|
113
|
-
const currentTotal = Array.from(
|
|
114
|
-
(sum,
|
|
124
|
+
const cols = colgroup.querySelectorAll('col');
|
|
125
|
+
const currentTotal = Array.from(cols).reduce(
|
|
126
|
+
(sum, col) => sum + (parseFloat((col as HTMLElement).style.width) || 0),
|
|
115
127
|
0,
|
|
116
128
|
);
|
|
117
129
|
|
|
@@ -121,15 +133,11 @@ export const redistributePercentWidths = (gridEl: HTMLElement): void => {
|
|
|
121
133
|
|
|
122
134
|
const scale = 100 / currentTotal;
|
|
123
135
|
|
|
124
|
-
|
|
125
|
-
const
|
|
126
|
-
|
|
127
|
-
cells.forEach(cell => {
|
|
128
|
-
const el = cell as HTMLElement;
|
|
129
|
-
const oldWidth = parseFloat(el.style.width) || 0;
|
|
136
|
+
cols.forEach(col => {
|
|
137
|
+
const el = col as HTMLElement;
|
|
138
|
+
const oldWidth = parseFloat(el.style.width) || 0;
|
|
130
139
|
|
|
131
|
-
|
|
132
|
-
});
|
|
140
|
+
el.style.width = `${Math.round(oldWidth * scale * 100) / 100}%`;
|
|
133
141
|
});
|
|
134
142
|
};
|
|
135
143
|
|
|
@@ -221,10 +229,10 @@ export const getBlockIdsInColumn = (element: HTMLElement | null, cellBlocks: Tab
|
|
|
221
229
|
const cellsInColumn: Element[] = [];
|
|
222
230
|
|
|
223
231
|
rows.forEach(row => {
|
|
224
|
-
const
|
|
232
|
+
const cell = row.querySelector(`[${CELL_COL_ATTR}="${colIndex}"]`);
|
|
225
233
|
|
|
226
|
-
if (
|
|
227
|
-
cellsInColumn.push(
|
|
234
|
+
if (cell) {
|
|
235
|
+
cellsInColumn.push(cell);
|
|
228
236
|
}
|
|
229
237
|
});
|
|
230
238
|
|
|
@@ -258,10 +266,8 @@ export const mountCellBlocksReadOnly = (
|
|
|
258
266
|
return;
|
|
259
267
|
}
|
|
260
268
|
|
|
261
|
-
const cells = row.querySelectorAll(`[${CELL_ATTR}]`);
|
|
262
|
-
|
|
263
269
|
rowData.forEach((cellContent, colIndex) => {
|
|
264
|
-
const cell =
|
|
270
|
+
const cell = row.querySelector<HTMLElement>(`[${CELL_COL_ATTR}="${colIndex}"]`);
|
|
265
271
|
|
|
266
272
|
if (!cell) {
|
|
267
273
|
return;
|
|
@@ -408,15 +414,13 @@ export const applyCellColors = (gridEl: HTMLElement, content: LegacyCellContent[
|
|
|
408
414
|
return;
|
|
409
415
|
}
|
|
410
416
|
|
|
411
|
-
const cells = rows[r].querySelectorAll(`[${CELL_ATTR}]`);
|
|
412
|
-
|
|
413
417
|
rowContent.forEach((cellContent, c) => {
|
|
414
|
-
|
|
418
|
+
const el = rows[r].querySelector<HTMLElement>(`[${CELL_COL_ATTR}="${c}"]`);
|
|
419
|
+
|
|
420
|
+
if (!el) {
|
|
415
421
|
return;
|
|
416
422
|
}
|
|
417
423
|
|
|
418
|
-
const el = cells[c] as HTMLElement;
|
|
419
|
-
|
|
420
424
|
if (isCellWithBlocks(cellContent) && cellContent.color) {
|
|
421
425
|
el.style.backgroundColor = cellContent.color;
|
|
422
426
|
} else {
|
|
@@ -432,6 +436,36 @@ export const applyCellColors = (gridEl: HTMLElement, content: LegacyCellContent[
|
|
|
432
436
|
});
|
|
433
437
|
};
|
|
434
438
|
|
|
439
|
+
export const applyCellPlacements = (gridEl: HTMLElement, content: LegacyCellContent[][]): void => {
|
|
440
|
+
const rows = gridEl.querySelectorAll(`[${ROW_ATTR}]`);
|
|
441
|
+
|
|
442
|
+
content.forEach((rowContent, r) => {
|
|
443
|
+
if (r >= rows.length) {
|
|
444
|
+
return;
|
|
445
|
+
}
|
|
446
|
+
|
|
447
|
+
rowContent.forEach((cellContent, c) => {
|
|
448
|
+
const el = rows[r].querySelector<HTMLElement>(`[${CELL_COL_ATTR}="${c}"]`);
|
|
449
|
+
|
|
450
|
+
if (!el) {
|
|
451
|
+
return;
|
|
452
|
+
}
|
|
453
|
+
|
|
454
|
+
const blocksContainer = el.querySelector<HTMLElement>(`[${CELL_BLOCKS_ATTR}]`);
|
|
455
|
+
|
|
456
|
+
if (!blocksContainer) {
|
|
457
|
+
return;
|
|
458
|
+
}
|
|
459
|
+
|
|
460
|
+
if (isCellWithBlocks(cellContent) && cellContent.placement && cellContent.placement !== 'top-left') {
|
|
461
|
+
blocksContainer.setAttribute('data-blok-cell-placement', cellContent.placement);
|
|
462
|
+
} else {
|
|
463
|
+
blocksContainer.removeAttribute('data-blok-cell-placement');
|
|
464
|
+
}
|
|
465
|
+
});
|
|
466
|
+
});
|
|
467
|
+
};
|
|
468
|
+
|
|
435
469
|
export const updateHeadingColumnStyles = (gridEl: HTMLElement | null, withHeadingColumn: boolean): void => {
|
|
436
470
|
if (!gridEl) {
|
|
437
471
|
return;
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
import { BORDER_WIDTH } from './table-core';
|
|
2
2
|
|
|
3
3
|
const RESIZE_ATTR = 'data-blok-table-resize';
|
|
4
|
-
const CELL_ATTR = 'data-blok-table-cell';
|
|
5
|
-
const ROW_ATTR = 'data-blok-table-row';
|
|
6
4
|
const MIN_COL_WIDTH = 50;
|
|
7
5
|
const HANDLE_HIT_WIDTH = 16;
|
|
8
6
|
|
|
@@ -23,7 +21,7 @@ export class TableResize {
|
|
|
23
21
|
private dragStartX = 0;
|
|
24
22
|
private dragColIndex = -1;
|
|
25
23
|
private startColWidth = 0;
|
|
26
|
-
private
|
|
24
|
+
private dragColElements: HTMLElement[] | null = null;
|
|
27
25
|
private handles: HTMLElement[] = [];
|
|
28
26
|
private needsInitialApply: boolean;
|
|
29
27
|
|
|
@@ -74,7 +72,7 @@ export class TableResize {
|
|
|
74
72
|
this.gridEl.removeEventListener('pointerdown', this.boundPointerDown);
|
|
75
73
|
document.removeEventListener('pointermove', this.boundPointerMove);
|
|
76
74
|
document.removeEventListener('pointerup', this.boundPointerUp);
|
|
77
|
-
this.
|
|
75
|
+
this.dragColElements = null;
|
|
78
76
|
|
|
79
77
|
this.handles.forEach(handle => handle.remove());
|
|
80
78
|
this.handles = [];
|
|
@@ -170,7 +168,7 @@ export class TableResize {
|
|
|
170
168
|
this.isDragging = true;
|
|
171
169
|
this.dragStartX = e.clientX;
|
|
172
170
|
this.startColWidth = this.colWidths[this.dragColIndex];
|
|
173
|
-
this.
|
|
171
|
+
this.dragColElements = this.resolveColElements();
|
|
174
172
|
|
|
175
173
|
this.onDragStart?.();
|
|
176
174
|
this.gridEl.style.userSelect = 'none';
|
|
@@ -195,7 +193,7 @@ export class TableResize {
|
|
|
195
193
|
const newWidth = Math.max(MIN_COL_WIDTH, rawWidth);
|
|
196
194
|
|
|
197
195
|
this.colWidths[this.dragColIndex] = newWidth;
|
|
198
|
-
this.applyWidths(this.
|
|
196
|
+
this.applyWidths(this.dragColElements ?? undefined);
|
|
199
197
|
this.updateHandlePositions();
|
|
200
198
|
this.onDrag?.();
|
|
201
199
|
}
|
|
@@ -216,28 +214,32 @@ export class TableResize {
|
|
|
216
214
|
|
|
217
215
|
document.removeEventListener('pointermove', this.boundPointerMove);
|
|
218
216
|
document.removeEventListener('pointerup', this.boundPointerUp);
|
|
219
|
-
this.
|
|
217
|
+
this.dragColElements = null;
|
|
220
218
|
|
|
221
219
|
this.onChange([...this.colWidths]);
|
|
222
220
|
}
|
|
223
221
|
|
|
224
|
-
private
|
|
225
|
-
const
|
|
222
|
+
private resolveColElements(): HTMLElement[] {
|
|
223
|
+
const colgroup = this.gridEl.querySelector('colgroup');
|
|
226
224
|
|
|
227
|
-
|
|
225
|
+
if (!colgroup) {
|
|
226
|
+
return [];
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
return Array.from(colgroup.querySelectorAll<HTMLElement>('col'));
|
|
228
230
|
}
|
|
229
231
|
|
|
230
|
-
private applyWidths(
|
|
232
|
+
private applyWidths(cols: HTMLElement[] = this.resolveColElements()): void {
|
|
231
233
|
const totalWidth = this.colWidths.reduce((sum, w) => sum + w, 0);
|
|
232
234
|
|
|
233
235
|
this.gridEl.style.width = `${totalWidth + BORDER_WIDTH}px`;
|
|
234
236
|
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
}
|
|
240
|
-
}
|
|
237
|
+
cols.forEach((colEl, i) => {
|
|
238
|
+
if (i < this.colWidths.length) {
|
|
239
|
+
const el: HTMLElement = colEl;
|
|
240
|
+
|
|
241
|
+
el.style.width = `${this.colWidths[i]}px`;
|
|
242
|
+
}
|
|
241
243
|
});
|
|
242
244
|
}
|
|
243
245
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { BORDER_WIDTH, CELL_ATTR, ROW_ATTR } from './table-core';
|
|
1
|
+
import { BORDER_WIDTH, CELL_ATTR, CELL_COL_ATTR, ROW_ATTR } from './table-core';
|
|
2
2
|
import type { RowColAction } from './table-row-col-controls';
|
|
3
3
|
|
|
4
4
|
const DRAG_THRESHOLD = 10;
|
|
@@ -10,6 +10,23 @@ const GHOST_ATTR = 'data-blok-table-drag-ghost';
|
|
|
10
10
|
* plus the right edge of the last column.
|
|
11
11
|
*/
|
|
12
12
|
export const getCumulativeColEdges = (grid: HTMLElement): number[] => {
|
|
13
|
+
const colgroup = grid.querySelector('colgroup');
|
|
14
|
+
|
|
15
|
+
if (colgroup) {
|
|
16
|
+
const cols = Array.from(colgroup.querySelectorAll('col'));
|
|
17
|
+
|
|
18
|
+
return cols.reduce<number[]>(
|
|
19
|
+
(edges, col) => {
|
|
20
|
+
const last = edges[edges.length - 1];
|
|
21
|
+
const width = (col as HTMLElement).offsetWidth || parseFloat((col as HTMLElement).style.width) || 0;
|
|
22
|
+
|
|
23
|
+
return [...edges, last + width];
|
|
24
|
+
},
|
|
25
|
+
[0]
|
|
26
|
+
);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
// Fallback for grids without colgroup
|
|
13
30
|
const firstRow = grid.querySelector(`[${ROW_ATTR}]`);
|
|
14
31
|
|
|
15
32
|
if (!firstRow) {
|
|
@@ -211,14 +228,12 @@ export class TableRowColDrag {
|
|
|
211
228
|
const dragBg = this.getDragSourceBg();
|
|
212
229
|
|
|
213
230
|
rows.forEach(row => {
|
|
214
|
-
const
|
|
231
|
+
const cellEl = row.querySelector<HTMLElement>(`[${CELL_COL_ATTR}="${this.dragFromIndex}"]`);
|
|
215
232
|
|
|
216
|
-
if (
|
|
233
|
+
if (!cellEl) {
|
|
217
234
|
return;
|
|
218
235
|
}
|
|
219
236
|
|
|
220
|
-
const cellEl = cells[this.dragFromIndex] as HTMLElement;
|
|
221
|
-
|
|
222
237
|
cellEl.style.backgroundColor = dragBg;
|
|
223
238
|
cellEl.style.opacity = '0.7';
|
|
224
239
|
this.dragOverlayCells.push(cellEl);
|
|
@@ -418,8 +433,8 @@ export class TableRowColDrag {
|
|
|
418
433
|
return null;
|
|
419
434
|
}
|
|
420
435
|
|
|
421
|
-
const firstCell = firstRow.
|
|
422
|
-
const lastCell = lastRow.
|
|
436
|
+
const firstCell = firstRow.querySelector<HTMLElement>(`[${CELL_COL_ATTR}="${this.dragFromIndex}"]`);
|
|
437
|
+
const lastCell = lastRow.querySelector<HTMLElement>(`[${CELL_COL_ATTR}="${this.dragFromIndex}"]`);
|
|
423
438
|
|
|
424
439
|
if (!firstCell || !lastCell) {
|
|
425
440
|
return null;
|
|
@@ -469,13 +484,12 @@ export class TableRowColDrag {
|
|
|
469
484
|
ghostStyle.flexDirection = 'column';
|
|
470
485
|
|
|
471
486
|
rows.forEach(row => {
|
|
472
|
-
const
|
|
487
|
+
const cellEl = row.querySelector<HTMLElement>(`[${CELL_COL_ATTR}="${this.dragFromIndex}"]`);
|
|
473
488
|
|
|
474
|
-
if (
|
|
489
|
+
if (!cellEl) {
|
|
475
490
|
return;
|
|
476
491
|
}
|
|
477
492
|
|
|
478
|
-
const cellEl = cells[this.dragFromIndex] as HTMLElement;
|
|
479
493
|
const clone = cellEl.cloneNode(true) as HTMLElement;
|
|
480
494
|
|
|
481
495
|
clone.style.width = `${cellEl.offsetWidth}px`;
|
package/src/tools/table/types.ts
CHANGED
|
@@ -1,10 +1,32 @@
|
|
|
1
1
|
import type { BlockToolData } from '../../../types';
|
|
2
2
|
|
|
3
|
+
/**
|
|
4
|
+
* Content placement within a cell.
|
|
5
|
+
* Describes vertical (top/middle/bottom) and horizontal (left/center/right) alignment.
|
|
6
|
+
*/
|
|
7
|
+
export type CellPlacement =
|
|
8
|
+
| 'top-left' | 'top-center' | 'top-right'
|
|
9
|
+
| 'middle-left' | 'middle-center' | 'middle-right'
|
|
10
|
+
| 'bottom-left' | 'bottom-center' | 'bottom-right';
|
|
11
|
+
|
|
3
12
|
/**
|
|
4
13
|
* Cell content always contains block IDs.
|
|
5
14
|
* Every cell in the table is represented as an array of block references.
|
|
6
15
|
*/
|
|
7
|
-
export type CellContent = {
|
|
16
|
+
export type CellContent = {
|
|
17
|
+
blocks: string[];
|
|
18
|
+
color?: string;
|
|
19
|
+
textColor?: string;
|
|
20
|
+
text?: string;
|
|
21
|
+
/** Content placement within the cell (vertical + horizontal alignment). */
|
|
22
|
+
placement?: CellPlacement;
|
|
23
|
+
/** Number of columns this cell spans (default 1 when omitted). Only set on origin cells. */
|
|
24
|
+
colspan?: number;
|
|
25
|
+
/** Number of rows this cell spans (default 1 when omitted). Only set on origin cells. */
|
|
26
|
+
rowspan?: number;
|
|
27
|
+
/** If set, this cell is covered by a merge whose origin is at [row, col]. */
|
|
28
|
+
mergedInto?: [number, number];
|
|
29
|
+
};
|
|
8
30
|
|
|
9
31
|
/**
|
|
10
32
|
* Legacy cell content type for migration from string-based cells.
|
|
@@ -73,5 +95,5 @@ export interface ClipboardBlockData {
|
|
|
73
95
|
export interface TableCellsClipboard {
|
|
74
96
|
rows: number;
|
|
75
97
|
cols: number;
|
|
76
|
-
cells: Array<Array<{ blocks: ClipboardBlockData[]; color?: string; textColor?: string }>>;
|
|
98
|
+
cells: Array<Array<{ blocks: ClipboardBlockData[]; color?: string; textColor?: string; placement?: CellPlacement }>>;
|
|
77
99
|
}
|
package/types/api/tools.d.ts
CHANGED
|
@@ -1,16 +1,4 @@
|
|
|
1
1
|
import { BlockToolAdapter } from '../tools/adapters/block-tool-adapter';
|
|
2
|
-
import { ToolConstructable, ToolSettings } from '../tools';
|
|
3
|
-
import { ThemeMode } from './theme';
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Tools-related configuration that can be passed to a nested Blok instance.
|
|
7
|
-
*/
|
|
8
|
-
export interface ToolsConfig {
|
|
9
|
-
tools: { [toolName: string]: ToolConstructable | ToolSettings } | undefined;
|
|
10
|
-
inlineToolbar?: string[] | boolean;
|
|
11
|
-
tunes?: string[];
|
|
12
|
-
theme?: ThemeMode;
|
|
13
|
-
}
|
|
14
2
|
|
|
15
3
|
/**
|
|
16
4
|
* Describes methods for accessing installed Blok tools
|
|
@@ -20,10 +8,4 @@ export interface Tools {
|
|
|
20
8
|
* Returns all available Block Tools
|
|
21
9
|
*/
|
|
22
10
|
getBlockTools(): BlockToolAdapter[];
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
* Returns the tools-related configuration of the current editor instance.
|
|
26
|
-
* Useful for creating nested Blok editors with the same tools.
|
|
27
|
-
*/
|
|
28
|
-
getToolsConfig(): ToolsConfig;
|
|
29
11
|
}
|
package/types/index.d.ts
CHANGED
|
@@ -88,22 +88,6 @@ export {
|
|
|
88
88
|
export * from './utils/popover';
|
|
89
89
|
|
|
90
90
|
export { OutputData, OutputBlockData} from './data-formats/output-data';
|
|
91
|
-
export {
|
|
92
|
-
PropertyType,
|
|
93
|
-
SelectOption,
|
|
94
|
-
SelectPropertyConfig,
|
|
95
|
-
PropertyConfig,
|
|
96
|
-
PropertyDefinition,
|
|
97
|
-
PropertyValue,
|
|
98
|
-
DatabaseRow,
|
|
99
|
-
ViewType,
|
|
100
|
-
SortConfig,
|
|
101
|
-
FilterConfig,
|
|
102
|
-
DatabaseViewConfig,
|
|
103
|
-
DatabaseData,
|
|
104
|
-
DatabaseAdapter,
|
|
105
|
-
DatabaseConfig,
|
|
106
|
-
} from './tools/database';
|
|
107
91
|
export { BlockId } from './data-formats/block-id';
|
|
108
92
|
export {
|
|
109
93
|
BlockAPI,
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { BlockToolData } from './block-tool-data';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Code block tool data format.
|
|
5
|
+
*/
|
|
6
|
+
export interface CodeData extends BlockToolData {
|
|
7
|
+
/** Raw code text (not HTML) */
|
|
8
|
+
code: string;
|
|
9
|
+
/** Language identifier, e.g. "javascript", "plain text" */
|
|
10
|
+
language: string;
|
|
11
|
+
/** Whether to show line numbers in the gutter */
|
|
12
|
+
lineNumbers?: boolean;
|
|
13
|
+
}
|
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
import type { DatabaseAdapter, PropertyDefinition, DatabaseRow, DatabaseViewConfig } from './types';
|
|
2
|
-
|
|
3
|
-
const UPDATE_DEBOUNCE_MS = 500;
|
|
4
|
-
|
|
5
|
-
export class DatabaseBackendSync {
|
|
6
|
-
private readonly adapter: DatabaseAdapter | undefined;
|
|
7
|
-
private readonly onError: ((error: unknown) => void) | undefined;
|
|
8
|
-
private readonly pendingTimers = new Map<string, ReturnType<typeof setTimeout>>();
|
|
9
|
-
private readonly pendingUpdates = new Map<string, Parameters<DatabaseAdapter['updateRow']>[0]>();
|
|
10
|
-
|
|
11
|
-
constructor(adapter?: DatabaseAdapter, onError?: (error: unknown) => void) {
|
|
12
|
-
this.adapter = adapter;
|
|
13
|
-
this.onError = onError;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
private async safeCall<T>(fn: (adapter: DatabaseAdapter) => Promise<T>): Promise<T | undefined> {
|
|
17
|
-
if (this.adapter === undefined) return undefined;
|
|
18
|
-
try { return await fn(this.adapter); }
|
|
19
|
-
catch (error) { this.onError?.(error); return undefined; }
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
// ─── Load ───
|
|
23
|
-
|
|
24
|
-
async syncLoadDatabase(): Promise<{ schema: PropertyDefinition[]; rows: Record<string, DatabaseRow>; views: DatabaseViewConfig[] } | undefined> {
|
|
25
|
-
return this.safeCall((a) => a.loadDatabase());
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
// ─── Row operations ───
|
|
29
|
-
|
|
30
|
-
async syncCreateRow(params: Parameters<DatabaseAdapter['createRow']>[0]): Promise<ReturnType<DatabaseAdapter['createRow']> extends Promise<infer R> ? R | undefined : never> {
|
|
31
|
-
return this.safeCall((a) => a.createRow(params));
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
syncUpdateRow(params: Parameters<DatabaseAdapter['updateRow']>[0]): void {
|
|
35
|
-
if (this.adapter === undefined) return;
|
|
36
|
-
const { rowId } = params;
|
|
37
|
-
const existing = this.pendingTimers.get(rowId);
|
|
38
|
-
if (existing !== undefined) clearTimeout(existing);
|
|
39
|
-
this.pendingUpdates.set(rowId, params);
|
|
40
|
-
this.pendingTimers.set(rowId, setTimeout(() => { this.flushRow(rowId); }, UPDATE_DEBOUNCE_MS));
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
async syncMoveRow(params: Parameters<DatabaseAdapter['moveRow']>[0]): Promise<ReturnType<DatabaseAdapter['moveRow']> extends Promise<infer R> ? R | undefined : never> {
|
|
44
|
-
this.flushRow(params.rowId);
|
|
45
|
-
|
|
46
|
-
return this.safeCall((a) => a.moveRow(params));
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
async syncDeleteRow(params: Parameters<DatabaseAdapter['deleteRow']>[0]): Promise<void> {
|
|
50
|
-
await this.safeCall((a) => a.deleteRow(params));
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
// ─── Property operations ───
|
|
54
|
-
|
|
55
|
-
async syncCreateProperty(params: Parameters<DatabaseAdapter['createProperty']>[0]): Promise<ReturnType<DatabaseAdapter['createProperty']> extends Promise<infer R> ? R | undefined : never> {
|
|
56
|
-
return this.safeCall((a) => a.createProperty(params));
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
async syncUpdateProperty(params: Parameters<DatabaseAdapter['updateProperty']>[0]): Promise<ReturnType<DatabaseAdapter['updateProperty']> extends Promise<infer R> ? R | undefined : never> {
|
|
60
|
-
return this.safeCall((a) => a.updateProperty(params));
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
async syncDeleteProperty(params: Parameters<DatabaseAdapter['deleteProperty']>[0]): Promise<void> {
|
|
64
|
-
await this.safeCall((a) => a.deleteProperty(params));
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
// ─── View operations ───
|
|
68
|
-
|
|
69
|
-
async syncCreateView(params: Parameters<DatabaseAdapter['createView']>[0]): Promise<ReturnType<DatabaseAdapter['createView']> extends Promise<infer R> ? R | undefined : never> {
|
|
70
|
-
return this.safeCall((a) => a.createView(params));
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
async syncUpdateView(params: Parameters<DatabaseAdapter['updateView']>[0]): Promise<ReturnType<DatabaseAdapter['updateView']> extends Promise<infer R> ? R | undefined : never> {
|
|
74
|
-
return this.safeCall((a) => a.updateView(params));
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
async syncDeleteView(params: Parameters<DatabaseAdapter['deleteView']>[0]): Promise<void> {
|
|
78
|
-
await this.safeCall((a) => a.deleteView(params));
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
// ─── Flush & destroy ───
|
|
82
|
-
|
|
83
|
-
flushPendingUpdates(): void {
|
|
84
|
-
for (const rowId of this.pendingTimers.keys()) { this.flushRow(rowId); }
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
destroy(): void {
|
|
88
|
-
for (const timer of this.pendingTimers.values()) clearTimeout(timer);
|
|
89
|
-
this.pendingTimers.clear();
|
|
90
|
-
this.pendingUpdates.clear();
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
private flushRow(rowId: string): void {
|
|
94
|
-
const timer = this.pendingTimers.get(rowId);
|
|
95
|
-
if (timer !== undefined) clearTimeout(timer);
|
|
96
|
-
this.pendingTimers.delete(rowId);
|
|
97
|
-
const params = this.pendingUpdates.get(rowId);
|
|
98
|
-
this.pendingUpdates.delete(rowId);
|
|
99
|
-
if (params !== undefined) void this.safeCall((a) => a.updateRow(params));
|
|
100
|
-
}
|
|
101
|
-
}
|