tinybase 4.3.22 → 4.3.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (221) hide show
  1. package/lib/cjs/persisters/persister-automerge.cjs +1 -1
  2. package/lib/cjs/persisters/persister-automerge.cjs.gz +0 -0
  3. package/lib/cjs/persisters/persister-browser.cjs +1 -1
  4. package/lib/cjs/persisters/persister-browser.cjs.gz +0 -0
  5. package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs +1 -1
  6. package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
  7. package/lib/cjs/persisters/persister-expo-sqlite.cjs +1 -1
  8. package/lib/cjs/persisters/persister-expo-sqlite.cjs.gz +0 -0
  9. package/lib/cjs/persisters/persister-file.cjs +1 -1
  10. package/lib/cjs/persisters/persister-file.cjs.gz +0 -0
  11. package/lib/cjs/persisters/persister-indexed-db.cjs +1 -1
  12. package/lib/cjs/persisters/persister-indexed-db.cjs.gz +0 -0
  13. package/lib/cjs/persisters/persister-partykit-client.cjs +1 -1
  14. package/lib/cjs/persisters/persister-partykit-client.cjs.gz +0 -0
  15. package/lib/cjs/persisters/persister-remote.cjs +1 -1
  16. package/lib/cjs/persisters/persister-remote.cjs.gz +0 -0
  17. package/lib/cjs/persisters/persister-sqlite-wasm.cjs +1 -1
  18. package/lib/cjs/persisters/persister-sqlite-wasm.cjs.gz +0 -0
  19. package/lib/cjs/persisters/persister-sqlite3.cjs +1 -1
  20. package/lib/cjs/persisters/persister-sqlite3.cjs.gz +0 -0
  21. package/lib/cjs/persisters/persister-yjs.cjs +1 -1
  22. package/lib/cjs/persisters/persister-yjs.cjs.gz +0 -0
  23. package/lib/cjs/persisters.cjs +1 -1
  24. package/lib/cjs/persisters.cjs.gz +0 -0
  25. package/lib/cjs/store.cjs +1 -1
  26. package/lib/cjs/store.cjs.gz +0 -0
  27. package/lib/cjs/tinybase.cjs +1 -1
  28. package/lib/cjs/tinybase.cjs.gz +0 -0
  29. package/lib/cjs/tools.cjs +1 -1
  30. package/lib/cjs/tools.cjs.gz +0 -0
  31. package/lib/cjs/ui-react-dom-debug.cjs +1 -1
  32. package/lib/cjs/ui-react-dom-debug.cjs.gz +0 -0
  33. package/lib/cjs/ui-react.cjs +1 -1
  34. package/lib/cjs/ui-react.cjs.gz +0 -0
  35. package/lib/cjs-es6/persisters/persister-automerge.cjs +1 -1
  36. package/lib/cjs-es6/persisters/persister-automerge.cjs.gz +0 -0
  37. package/lib/cjs-es6/persisters/persister-browser.cjs +1 -1
  38. package/lib/cjs-es6/persisters/persister-browser.cjs.gz +0 -0
  39. package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs +1 -1
  40. package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
  41. package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs +1 -1
  42. package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs.gz +0 -0
  43. package/lib/cjs-es6/persisters/persister-file.cjs +1 -1
  44. package/lib/cjs-es6/persisters/persister-file.cjs.gz +0 -0
  45. package/lib/cjs-es6/persisters/persister-indexed-db.cjs +1 -1
  46. package/lib/cjs-es6/persisters/persister-indexed-db.cjs.gz +0 -0
  47. package/lib/cjs-es6/persisters/persister-partykit-client.cjs +1 -1
  48. package/lib/cjs-es6/persisters/persister-partykit-client.cjs.gz +0 -0
  49. package/lib/cjs-es6/persisters/persister-remote.cjs +1 -1
  50. package/lib/cjs-es6/persisters/persister-remote.cjs.gz +0 -0
  51. package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs +1 -1
  52. package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs.gz +0 -0
  53. package/lib/cjs-es6/persisters/persister-sqlite3.cjs +1 -1
  54. package/lib/cjs-es6/persisters/persister-sqlite3.cjs.gz +0 -0
  55. package/lib/cjs-es6/persisters/persister-yjs.cjs +1 -1
  56. package/lib/cjs-es6/persisters/persister-yjs.cjs.gz +0 -0
  57. package/lib/cjs-es6/persisters.cjs +1 -1
  58. package/lib/cjs-es6/persisters.cjs.gz +0 -0
  59. package/lib/cjs-es6/store.cjs +1 -1
  60. package/lib/cjs-es6/store.cjs.gz +0 -0
  61. package/lib/cjs-es6/tinybase.cjs +1 -1
  62. package/lib/cjs-es6/tinybase.cjs.gz +0 -0
  63. package/lib/cjs-es6/tools.cjs +1 -1
  64. package/lib/cjs-es6/tools.cjs.gz +0 -0
  65. package/lib/cjs-es6/ui-react-dom-debug.cjs +1 -1
  66. package/lib/cjs-es6/ui-react-dom-debug.cjs.gz +0 -0
  67. package/lib/cjs-es6/ui-react.cjs +1 -1
  68. package/lib/cjs-es6/ui-react.cjs.gz +0 -0
  69. package/lib/debug/persisters/persister-automerge.js +9 -2
  70. package/lib/debug/persisters/persister-browser.js +9 -1
  71. package/lib/debug/persisters/persister-cr-sqlite-wasm.js +9 -1
  72. package/lib/debug/persisters/persister-expo-sqlite.js +9 -1
  73. package/lib/debug/persisters/persister-file.js +9 -1
  74. package/lib/debug/persisters/persister-indexed-db.js +9 -2
  75. package/lib/debug/persisters/persister-partykit-client.js +9 -1
  76. package/lib/debug/persisters/persister-remote.js +9 -1
  77. package/lib/debug/persisters/persister-sqlite-wasm.js +9 -1
  78. package/lib/debug/persisters/persister-sqlite3.js +10 -2
  79. package/lib/debug/persisters/persister-yjs.js +9 -2
  80. package/lib/debug/persisters.js +9 -2
  81. package/lib/debug/store.js +9 -1
  82. package/lib/debug/tinybase.js +9 -1
  83. package/lib/debug/tools.js +11 -2
  84. package/lib/debug/ui-react-dom.js +9 -1
  85. package/lib/debug/ui-react.js +90 -72
  86. package/lib/es6/persisters/persister-automerge.js +1 -1
  87. package/lib/es6/persisters/persister-automerge.js.gz +0 -0
  88. package/lib/es6/persisters/persister-browser.js +1 -1
  89. package/lib/es6/persisters/persister-browser.js.gz +0 -0
  90. package/lib/es6/persisters/persister-cr-sqlite-wasm.js +1 -1
  91. package/lib/es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  92. package/lib/es6/persisters/persister-expo-sqlite.js +1 -1
  93. package/lib/es6/persisters/persister-expo-sqlite.js.gz +0 -0
  94. package/lib/es6/persisters/persister-file.js +1 -1
  95. package/lib/es6/persisters/persister-file.js.gz +0 -0
  96. package/lib/es6/persisters/persister-indexed-db.js +1 -1
  97. package/lib/es6/persisters/persister-indexed-db.js.gz +0 -0
  98. package/lib/es6/persisters/persister-partykit-client.js +1 -1
  99. package/lib/es6/persisters/persister-partykit-client.js.gz +0 -0
  100. package/lib/es6/persisters/persister-remote.js +1 -1
  101. package/lib/es6/persisters/persister-remote.js.gz +0 -0
  102. package/lib/es6/persisters/persister-sqlite-wasm.js +1 -1
  103. package/lib/es6/persisters/persister-sqlite-wasm.js.gz +0 -0
  104. package/lib/es6/persisters/persister-sqlite3.js +1 -1
  105. package/lib/es6/persisters/persister-sqlite3.js.gz +0 -0
  106. package/lib/es6/persisters/persister-yjs.js +1 -1
  107. package/lib/es6/persisters/persister-yjs.js.gz +0 -0
  108. package/lib/es6/persisters.js +1 -1
  109. package/lib/es6/persisters.js.gz +0 -0
  110. package/lib/es6/store.js +1 -1
  111. package/lib/es6/store.js.gz +0 -0
  112. package/lib/es6/tinybase.js +1 -1
  113. package/lib/es6/tinybase.js.gz +0 -0
  114. package/lib/es6/tools.js +1 -1
  115. package/lib/es6/tools.js.gz +0 -0
  116. package/lib/es6/ui-react-dom-debug.js +1 -1
  117. package/lib/es6/ui-react-dom-debug.js.gz +0 -0
  118. package/lib/es6/ui-react.js +1 -1
  119. package/lib/es6/ui-react.js.gz +0 -0
  120. package/lib/persisters/persister-automerge.js +1 -1
  121. package/lib/persisters/persister-automerge.js.gz +0 -0
  122. package/lib/persisters/persister-browser.js +1 -1
  123. package/lib/persisters/persister-browser.js.gz +0 -0
  124. package/lib/persisters/persister-cr-sqlite-wasm.js +1 -1
  125. package/lib/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  126. package/lib/persisters/persister-expo-sqlite.js +1 -1
  127. package/lib/persisters/persister-expo-sqlite.js.gz +0 -0
  128. package/lib/persisters/persister-file.js +1 -1
  129. package/lib/persisters/persister-file.js.gz +0 -0
  130. package/lib/persisters/persister-indexed-db.js +1 -1
  131. package/lib/persisters/persister-indexed-db.js.gz +0 -0
  132. package/lib/persisters/persister-partykit-client.js +1 -1
  133. package/lib/persisters/persister-partykit-client.js.gz +0 -0
  134. package/lib/persisters/persister-remote.js +1 -1
  135. package/lib/persisters/persister-remote.js.gz +0 -0
  136. package/lib/persisters/persister-sqlite-wasm.js +1 -1
  137. package/lib/persisters/persister-sqlite-wasm.js.gz +0 -0
  138. package/lib/persisters/persister-sqlite3.js +1 -1
  139. package/lib/persisters/persister-sqlite3.js.gz +0 -0
  140. package/lib/persisters/persister-yjs.js +1 -1
  141. package/lib/persisters/persister-yjs.js.gz +0 -0
  142. package/lib/persisters.js +1 -1
  143. package/lib/persisters.js.gz +0 -0
  144. package/lib/store.js +1 -1
  145. package/lib/store.js.gz +0 -0
  146. package/lib/tinybase.js +1 -1
  147. package/lib/tinybase.js.gz +0 -0
  148. package/lib/tools.js +1 -1
  149. package/lib/tools.js.gz +0 -0
  150. package/lib/ui-react.js +1 -1
  151. package/lib/ui-react.js.gz +0 -0
  152. package/lib/umd/persisters/persister-automerge.js +1 -1
  153. package/lib/umd/persisters/persister-automerge.js.gz +0 -0
  154. package/lib/umd/persisters/persister-browser.js +1 -1
  155. package/lib/umd/persisters/persister-browser.js.gz +0 -0
  156. package/lib/umd/persisters/persister-cr-sqlite-wasm.js +1 -1
  157. package/lib/umd/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  158. package/lib/umd/persisters/persister-expo-sqlite.js +1 -1
  159. package/lib/umd/persisters/persister-expo-sqlite.js.gz +0 -0
  160. package/lib/umd/persisters/persister-file.js +1 -1
  161. package/lib/umd/persisters/persister-file.js.gz +0 -0
  162. package/lib/umd/persisters/persister-indexed-db.js +1 -1
  163. package/lib/umd/persisters/persister-indexed-db.js.gz +0 -0
  164. package/lib/umd/persisters/persister-partykit-client.js +1 -1
  165. package/lib/umd/persisters/persister-partykit-client.js.gz +0 -0
  166. package/lib/umd/persisters/persister-remote.js +1 -1
  167. package/lib/umd/persisters/persister-remote.js.gz +0 -0
  168. package/lib/umd/persisters/persister-sqlite-wasm.js +1 -1
  169. package/lib/umd/persisters/persister-sqlite-wasm.js.gz +0 -0
  170. package/lib/umd/persisters/persister-sqlite3.js +1 -1
  171. package/lib/umd/persisters/persister-sqlite3.js.gz +0 -0
  172. package/lib/umd/persisters/persister-yjs.js +1 -1
  173. package/lib/umd/persisters/persister-yjs.js.gz +0 -0
  174. package/lib/umd/persisters.js +1 -1
  175. package/lib/umd/persisters.js.gz +0 -0
  176. package/lib/umd/store.js +1 -1
  177. package/lib/umd/store.js.gz +0 -0
  178. package/lib/umd/tinybase.js +1 -1
  179. package/lib/umd/tinybase.js.gz +0 -0
  180. package/lib/umd/tools.js +1 -1
  181. package/lib/umd/tools.js.gz +0 -0
  182. package/lib/umd/ui-react-dom-debug.js +1 -1
  183. package/lib/umd/ui-react-dom-debug.js.gz +0 -0
  184. package/lib/umd/ui-react.js +1 -1
  185. package/lib/umd/ui-react.js.gz +0 -0
  186. package/lib/umd-es6/persisters/persister-automerge.js +1 -1
  187. package/lib/umd-es6/persisters/persister-automerge.js.gz +0 -0
  188. package/lib/umd-es6/persisters/persister-browser.js +1 -1
  189. package/lib/umd-es6/persisters/persister-browser.js.gz +0 -0
  190. package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js +1 -1
  191. package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  192. package/lib/umd-es6/persisters/persister-expo-sqlite.js +1 -1
  193. package/lib/umd-es6/persisters/persister-expo-sqlite.js.gz +0 -0
  194. package/lib/umd-es6/persisters/persister-file.js +1 -1
  195. package/lib/umd-es6/persisters/persister-file.js.gz +0 -0
  196. package/lib/umd-es6/persisters/persister-indexed-db.js +1 -1
  197. package/lib/umd-es6/persisters/persister-indexed-db.js.gz +0 -0
  198. package/lib/umd-es6/persisters/persister-partykit-client.js +1 -1
  199. package/lib/umd-es6/persisters/persister-partykit-client.js.gz +0 -0
  200. package/lib/umd-es6/persisters/persister-remote.js +1 -1
  201. package/lib/umd-es6/persisters/persister-remote.js.gz +0 -0
  202. package/lib/umd-es6/persisters/persister-sqlite-wasm.js +1 -1
  203. package/lib/umd-es6/persisters/persister-sqlite-wasm.js.gz +0 -0
  204. package/lib/umd-es6/persisters/persister-sqlite3.js +1 -1
  205. package/lib/umd-es6/persisters/persister-sqlite3.js.gz +0 -0
  206. package/lib/umd-es6/persisters/persister-yjs.js +1 -1
  207. package/lib/umd-es6/persisters/persister-yjs.js.gz +0 -0
  208. package/lib/umd-es6/persisters.js +1 -1
  209. package/lib/umd-es6/persisters.js.gz +0 -0
  210. package/lib/umd-es6/store.js +1 -1
  211. package/lib/umd-es6/store.js.gz +0 -0
  212. package/lib/umd-es6/tinybase.js +1 -1
  213. package/lib/umd-es6/tinybase.js.gz +0 -0
  214. package/lib/umd-es6/tools.js +1 -1
  215. package/lib/umd-es6/tools.js.gz +0 -0
  216. package/lib/umd-es6/ui-react-dom-debug.js +1 -1
  217. package/lib/umd-es6/ui-react-dom-debug.js.gz +0 -0
  218. package/lib/umd-es6/ui-react.js +1 -1
  219. package/lib/umd-es6/ui-react.js.gz +0 -0
  220. package/package.json +25 -25
  221. package/readme.md +2 -2
@@ -1 +1 @@
1
- var e,s;e=this,s=function(e,s){"use strict";const t=e=>typeof e,o="",l=t(o),r="Listener",u="Result",n="Ids",d="Table",i=d+"s",a=d+n,c="Row",I=c+"Count",p=c+n,C="Sorted"+c+n,b="Cell",w=b+n,R="Value",k=R+"s",v=R+n,g=e=>null==e,h=(e,s,t)=>g(e)?null==t?void 0:t():s(e),y=e=>t(e)==l,m=()=>{},L=(e,s)=>e.map(s),f=Object.keys,{createContext:S,useContext:V}=s,T=S([]),x=(e,s)=>{var t;const o=V(T);return g(e)?o[s]:y(e)?((e,s)=>h(e,(e=>e[s])))(null!=(t=o[s+1])?t:{},e):e},P=(e,s)=>{const t=x(e,s);return g(e)||y(e)?t:e},O=e=>{var s;return f(null!=(s=V(T)[e])?s:{})},q=e=>P(e,0),B=e=>P(e,2),M=e=>P(e,4),D=e=>P(e,6),j=e=>P(e,8),F=e=>P(e,10),Q=e=>e.toLowerCase();Q(r);const E="Transaction";Q(E);const{useCallback:A,useEffect:G,useMemo:U,useRef:W,useState:z}=s,H=(e,s,t=[])=>{const o=U((()=>s(e)),[e,...t]);return G((()=>()=>o.destroy()),[o]),o},J=(e,s,t,o=[],l)=>{const[,r]=z(),u=A((()=>{var l,r;return null!=(r=null==(l=null==s?void 0:s["get"+e])?void 0:l.call(s,...o))?r:t}),[s,...o]),n=W();return U((()=>n.current=u()),[u]),K(e,s,((...e)=>{n.current=g(l)?u():e[l],r([])}),[],o),n.current},K=(e,s,t,o=[],l=[],...u)=>{const n=[s,...l,...o,...u],d=U((()=>{var o;return null==(o=null==s?void 0:s["add"+e+r])?void 0:o.call(s,...l,t,...u)}),n);G((()=>()=>null==s?void 0:s.delListener(d)),n)},N=(e,s,t,o=[],l=m,r=[],...u)=>{const n=q(e);return A((e=>h(n,(o=>h(t(e,o),(e=>l(o["set"+s](...u,e),e)))))),[n,s,...o,...r,...u])},X=(e,s,t=m,o=[],...l)=>{const r=q(e);return A((()=>t(null==r?void 0:r["del"+s](...l))),[r,s,...o,...l])},Y=(e,s,t)=>{const o=F(e);return A((()=>null==o?void 0:o[s](t)),[o,s,t])},Z=e=>J(a,q(e),[],[]),$=(e,s)=>J(p,q(s),[],[e]),_=(e,s,t,o=0,l,r)=>J(C,q(r),[],[e,s,t,o,l],6),ee=(e,s,t)=>J(w,q(t),[],[e,s]),se=(e,s,t,o)=>J(b,q(o),void 0,[e,s,t],4),te=e=>J(v,q(e),[],[]),oe=(e,s)=>J(R,q(s),void 0,[e]),le=(e,s)=>J("Metric",B(s),void 0,[e]),re=(e,s)=>J("SliceIds",M(s),[],[e]),ue=(e,s,t)=>J("Slice"+p,M(t),[],[e,s]),ne=(e,s,t)=>J("RemoteRowId",D(t),void 0,[e,s]),de=(e,s,t)=>J("Local"+p,D(t),[],[e,s]),ie=(e,s,t)=>J("Linked"+p,D(t),[],[e,s]),ae=(e,s)=>J(u+p,j(s),[],[e]),ce=(e,s,t,o=0,l,r)=>J(u+C,j(r),[],[e,s,t,o,l],6),Ie=(e,s,t)=>J(u+w,j(t),[],[e,s]),pe=(e,s,t,o)=>J(u+b,j(o),void 0,[e,s,t]),Ce=e=>J("CheckpointIds",F(e),[[],void 0,[]]),be=(e,s)=>J("Checkpoint",F(s),void 0,[e]),we=e=>Y(e,"goBackward"),Re=e=>Y(e,"goForward"),{PureComponent:ke,Fragment:ve,createElement:ge,useCallback:he,useLayoutEffect:ye,useRef:me,useState:Le}=s,fe=(e,...s)=>g(e)?{}:e(...s),Se=(e,s)=>[e,null==e?void 0:e.getStore(),null==e?void 0:e.getLocalTableId(s),null==e?void 0:e.getRemoteTableId(s)];var Ve=Object.defineProperty,Te=Object.defineProperties,xe=Object.getOwnPropertyDescriptors,Pe=Object.getOwnPropertySymbols,Oe=Object.prototype.hasOwnProperty,qe=Object.prototype.propertyIsEnumerable,Be=(e,s,t)=>s in e?Ve(e,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[s]=t,Me=(e,s)=>{for(var t in s||(s={}))Oe.call(s,t)&&Be(e,t,s[t]);if(Pe)for(var t of Pe(s))qe.call(s,t)&&Be(e,t,s[t]);return e},De=(e,s)=>Te(e,xe(s)),je=(e,s)=>{var t={};for(var o in e)Oe.call(e,o)&&s.indexOf(o)<0&&(t[o]=e[o]);if(null!=e&&Pe)for(var o of Pe(e))s.indexOf(o)<0&&qe.call(e,o)&&(t[o]=e[o]);return t};const{useMemo:Fe}=s,Qe=({tableId:e,store:s,rowComponent:t=ze,getRowComponentProps:o,customCellIds:l,separator:r,debugIds:u},n)=>Ue(L(n,(r=>ge(t,De(Me({},fe(o,r)),{key:r,tableId:e,rowId:r,customCellIds:l,store:s,debugIds:u})))),r,u,e),Ee=({queryId:e,queries:s,resultRowComponent:t=Xe,getResultRowComponentProps:o,separator:l,debugIds:r},u)=>Ue(L(u,(l=>ge(t,De(Me({},fe(o,l)),{key:l,queryId:e,rowId:l,queries:s,debugIds:r})))),l,r,e),Ae=({relationshipId:e,relationships:s,rowComponent:t=ze,getRowComponentProps:o,separator:l,debugIds:r},u,n)=>{const[d,i,a]=Se(D(s),e),c=u(e,n,d);return Ue(L(c,(e=>ge(t,De(Me({},fe(o,e)),{key:e,tableId:a,rowId:e,store:i,debugIds:r})))),l,r,n)},Ge=e=>({checkpoints:s,checkpointComponent:t=Ye,getCheckpointComponentProps:o,separator:l,debugIds:r})=>{const u=F(s);return Ue(L(e(Ce(u)),(e=>ge(t,De(Me({},fe(o,e)),{key:e,checkpoints:u,checkpointId:e,debugIds:r})))),l)},Ue=(e,s,t,o)=>{const l=g(s)||!Array.isArray(e)?e:L(e,((e,t)=>t>0?[s,e]:e));return t?[o,":{",l,"}"]:l},We=({tableId:e,rowId:s,cellId:t,store:l,debugIds:r})=>{var u;return Ue(o+(null!=(u=se(e,s,t,l))?u:o),void 0,r,t)},ze=({tableId:e,rowId:s,store:t,cellComponent:o=We,getCellComponentProps:l,customCellIds:r,separator:u,debugIds:n})=>Ue(L(((e,s,t,o)=>{const l=ee(s,t,o);return null!=e?e:l})(r,e,s,t),(r=>ge(o,De(Me({},fe(l,r)),{key:r,tableId:e,rowId:s,cellId:r,store:t,debugIds:n})))),u,n,s),He=e=>Qe(e,$(e.tableId,e.store)),Je=({valueId:e,store:s,debugIds:t})=>{var l;return Ue(o+(null!=(l=oe(e,s))?l:o),void 0,t,e)},Ke=({indexId:e,sliceId:s,indexes:t,rowComponent:o=ze,getRowComponentProps:l,separator:r,debugIds:u})=>{const[n,d,i]=((e,s)=>[e,null==e?void 0:e.getStore(),null==e?void 0:e.getTableId(s)])(M(t),e),a=ue(e,s,n);return Ue(L(a,(e=>ge(o,De(Me({},fe(l,e)),{key:e,tableId:i,rowId:e,store:d,debugIds:u})))),r,u,s)},Ne=({queryId:e,rowId:s,cellId:t,queries:l,debugIds:r})=>{var u;return Ue(o+(null!=(u=pe(e,s,t,l))?u:o),void 0,r,t)},Xe=({queryId:e,rowId:s,queries:t,resultCellComponent:o=Ne,getResultCellComponentProps:l,separator:r,debugIds:u})=>Ue(L(Ie(e,s,t),(r=>ge(o,De(Me({},fe(l,r)),{key:r,queryId:e,rowId:s,cellId:r,queries:t,debugIds:u})))),r,u,s),Ye=({checkpoints:e,checkpointId:s,debugIds:t})=>{var l;return Ue(null!=(l=be(s,e))?l:o,void 0,t,s)},Ze=Ge((e=>e[0])),$e=Ge((e=>g(e[1])?[]:[e[1]])),_e=Ge((e=>e[2]));e.BackwardCheckpointsView=Ze,e.CellView=We,e.CheckpointView=Ye,e.CurrentCheckpointView=$e,e.ForwardCheckpointsView=_e,e.IndexView=({indexId:e,indexes:s,sliceComponent:t=Ke,getSliceComponentProps:o,separator:l,debugIds:r})=>Ue(L(re(e,s),(l=>ge(t,De(Me({},fe(o,l)),{key:l,indexId:e,sliceId:l,indexes:s,debugIds:r})))),l,r,e),e.LinkedRowsView=e=>Ae(e,ie,e.firstRowId),e.LocalRowsView=e=>Ae(e,de,e.remoteRowId),e.MetricView=({metricId:e,metrics:s,debugIds:t})=>{var l;return Ue(null!=(l=le(e,s))?l:o,void 0,t,e)},e.Provider=({store:e,storesById:t,metrics:o,metricsById:l,indexes:r,indexesById:u,relationships:n,relationshipsById:d,queries:i,queriesById:a,checkpoints:c,checkpointsById:I,children:p})=>{const C=s.useContext(T);return ge(T.Provider,{value:Fe((()=>[null!=e?e:C[0],Me(Me({},C[1]),t),null!=o?o:C[2],Me(Me({},C[3]),l),null!=r?r:C[4],Me(Me({},C[5]),u),null!=n?n:C[6],Me(Me({},C[7]),d),null!=i?i:C[8],Me(Me({},C[9]),a),null!=c?c:C[10],Me(Me({},C[11]),I)]),[e,t,o,l,r,u,n,d,i,a,c,I,C])},p)},e.RemoteRowView=({relationshipId:e,localRowId:s,relationships:t,rowComponent:o=ze,getRowComponentProps:l,debugIds:r})=>{const[u,n,,d]=Se(D(t),e),i=ne(e,s,u);return Ue(g(d)||g(i)?null:ge(o,De(Me({},fe(l,i)),{key:i,tableId:d,rowId:i,store:n,debugIds:r})),void 0,r,s)},e.ResultCellView=Ne,e.ResultRowView=Xe,e.ResultSortedTableView=e=>{var s=e,{cellId:t,descending:o,offset:l,limit:r}=s,u=je(s,["cellId","descending","offset","limit"]);return Ee(u,ce(u.queryId,t,o,l,r,u.queries))},e.ResultTableView=e=>Ee(e,ae(e.queryId,e.queries)),e.RowView=ze,e.SliceView=Ke,e.SortedTableView=e=>{var s=e,{cellId:t,descending:o,offset:l,limit:r}=s,u=je(s,["cellId","descending","offset","limit"]);return Qe(u,_(u.tableId,t,o,l,r,u.store))},e.TableView=He,e.TablesView=({store:e,tableComponent:s=He,getTableComponentProps:t,separator:o,debugIds:l})=>Ue(L(Z(e),(o=>ge(s,De(Me({},fe(t,o)),{key:o,tableId:o,store:e,debugIds:l})))),o),e.ValueView=Je,e.ValuesView=({store:e,valueComponent:s=Je,getValueComponentProps:t,separator:o,debugIds:l})=>Ue(L(te(e),(o=>ge(s,De(Me({},fe(t,o)),{key:o,valueId:o,store:e,debugIds:l})))),o),e.useAddRowCallback=(e,s,t=[],o,l=m,r=[],u=!0)=>{const n=q(o);return A((t=>h(n,(o=>h(s(t,o),(s=>l(o.addRow(e,s,u),o,s)))))),[n,e,...t,...r,u])},e.useCell=se,e.useCellIds=ee,e.useCellIdsListener=(e,s,t,o,l,r)=>K(w,q(r),t,o,[e,s],l),e.useCellListener=(e,s,t,o,l,r,u)=>K(b,q(u),o,l,[e,s,t],r),e.useCheckpoint=be,e.useCheckpointIds=Ce,e.useCheckpointIdsListener=(e,s,t)=>K("CheckpointIds",F(t),e,s),e.useCheckpointListener=(e,s,t,o)=>K("Checkpoint",F(o),s,t,[e]),e.useCheckpoints=e=>x(e,10),e.useCheckpointsIds=()=>O(11),e.useCheckpointsOrCheckpointsById=F,e.useCreateCheckpoints=(e,s,t)=>H(e,s,t),e.useCreateIndexes=(e,s,t)=>H(e,s,t),e.useCreateMetrics=(e,s,t)=>H(e,s,t),e.useCreatePersister=(e,s,t=[],o,l=[],r,u=[])=>{const[,n]=z(),d=U((()=>s(e)),[e,...t]);return G((()=>{var e;return e=function*(){o&&(yield o(d),n([]))},new Promise(((s,t)=>{var o=s=>{try{r(e.next(s))}catch(e){t(e)}},l=s=>{try{r(e.throw(s))}catch(e){t(e)}},r=e=>e.done?s(e.value):Promise.resolve(e.value).then(o,l);r((e=e.apply(void 0,null)).next())})),()=>{null==d||d.destroy(),null==r||r(d)}}),[d,...l,...u]),d},e.useCreateQueries=(e,s,t)=>H(e,s,t),e.useCreateRelationships=(e,s,t)=>H(e,s,t),e.useCreateStore=(e,s=[])=>U(e,s),e.useDelCellCallback=(e,s,t,o,l,r,u)=>X(l,b,r,u,e,s,t,o),e.useDelRowCallback=(e,s,t,o,l)=>X(t,c,o,l,e,s),e.useDelTableCallback=(e,s,t,o)=>X(s,d,t,o,e),e.useDelTablesCallback=(e,s,t)=>X(e,i,s,t),e.useDelValueCallback=(e,s,t,o)=>X(s,R,t,o,e),e.useDelValuesCallback=(e,s,t)=>X(e,k,s,t),e.useDidFinishTransactionListener=(e,s,t)=>K("DidFinish"+E,q(t),e,s),e.useGoBackwardCallback=we,e.useGoForwardCallback=Re,e.useGoToCallback=(e,s=[],t,o=m,l=[])=>{const r=F(t);return A((s=>h(r,(t=>h(e(s),(e=>o(t.goTo(e),e)))))),[r,...s,...l])},e.useIndexIds=e=>J("IndexIds",M(e),[]),e.useIndexes=e=>x(e,4),e.useIndexesIds=()=>O(5),e.useIndexesOrIndexesById=M,e.useLinkedRowIds=ie,e.useLinkedRowIdsListener=(e,s,t,o,l)=>K("Linked"+p,D(l),t,o,[e,s]),e.useLocalRowIds=de,e.useLocalRowIdsListener=(e,s,t,o,l)=>K("Local"+p,D(l),t,o,[e,s]),e.useMetric=le,e.useMetricIds=e=>J("MetricIds",B(e),[]),e.useMetricListener=(e,s,t,o)=>K("Metric",B(o),s,t,[e]),e.useMetrics=e=>x(e,2),e.useMetricsIds=()=>O(3),e.useMetricsOrMetricsById=B,e.useQueries=e=>x(e,8),e.useQueriesIds=()=>O(9),e.useQueriesOrQueriesById=j,e.useQueryIds=e=>J("QueryIds",j(e),[]),e.useRedoInformation=e=>{var s;const t=F(e),[,,[l]]=Ce(t);return[!g(l),Re(t),l,null!=(s=h(l,(e=>null==t?void 0:t.getCheckpoint(e))))?s:o]},e.useRelationshipIds=e=>J("RelationshipIds",D(e),[]),e.useRelationships=e=>x(e,6),e.useRelationshipsIds=()=>O(7),e.useRelationshipsOrRelationshipsById=D,e.useRemoteRowId=ne,e.useRemoteRowIdListener=(e,s,t,o,l)=>K("RemoteRowId",D(l),t,o,[e,s]),e.useResultCell=pe,e.useResultCellIds=Ie,e.useResultCellIdsListener=(e,s,t,o,l)=>K(u+w,j(l),t,o,[e,s]),e.useResultCellListener=(e,s,t,o,l,r)=>K(u+b,j(r),o,l,[e,s,t]),e.useResultRow=(e,s,t)=>J(u+c,j(t),{},[e,s]),e.useResultRowCount=(e,s)=>J(u+I,j(s),[],[e]),e.useResultRowCountListener=(e,s,t,o)=>K(u+I,j(o),s,t,[e]),e.useResultRowIds=ae,e.useResultRowIdsListener=(e,s,t,o)=>K(u+p,j(o),s,t,[e]),e.useResultRowListener=(e,s,t,o,l)=>K(u+c,j(l),t,o,[e,s]),e.useResultSortedRowIds=ce,e.useResultSortedRowIdsListener=(e,s,t,o,l,r,n,d)=>K(u+C,j(d),r,n,[e,s,t,o,l]),e.useResultTable=(e,s)=>J(u+d,j(s),{},[e]),e.useResultTableCellIds=(e,s)=>J(u+d+w,j(s),[],[e]),e.useResultTableCellIdsListener=(e,s,t,o)=>K(u+d+w,j(o),s,t,[e]),e.useResultTableListener=(e,s,t,o)=>K(u+d,j(o),s,t,[e]),e.useRow=(e,s,t)=>J(c,q(t),{},[e,s]),e.useRowCount=(e,s)=>J(I,q(s),[],[e]),e.useRowCountListener=(e,s,t,o,l)=>K(I,q(l),s,t,[e],o),e.useRowIds=$,e.useRowIdsListener=(e,s,t,o,l)=>K(p,q(l),s,t,[e],o),e.useRowListener=(e,s,t,o,l,r)=>K(c,q(r),t,o,[e,s],l),e.useSetCellCallback=(e,s,t,o,l,r,u,n)=>N(r,b,o,l,u,n,e,s,t),e.useSetCheckpointCallback=(e=m,s=[],t,o=m,l=[])=>{const r=F(t);return A((s=>h(r,(t=>{const l=e(s);o(t.addCheckpoint(l),t,l)}))),[r,...s,...l])},e.useSetPartialRowCallback=(e,s,t,o,l,r,u)=>N(l,"PartialRow",t,o,r,u,e,s),e.useSetPartialValuesCallback=(e,s,t,o,l)=>N(t,"PartialValues",e,s,o,l),e.useSetRowCallback=(e,s,t,o,l,r,u)=>N(l,c,t,o,r,u,e,s),e.useSetTableCallback=(e,s,t,o,l,r)=>N(o,d,s,t,l,r,e),e.useSetTablesCallback=(e,s,t,o,l)=>N(t,i,e,s,o,l),e.useSetValueCallback=(e,s,t,o,l,r)=>N(o,R,s,t,l,r,e),e.useSetValuesCallback=(e,s,t,o,l)=>N(t,k,e,s,o,l),e.useSliceIds=re,e.useSliceIdsListener=(e,s,t,o)=>K("SliceIds",M(o),s,t,[e]),e.useSliceRowIds=ue,e.useSliceRowIdsListener=(e,s,t,o,l)=>K("Slice"+p,M(l),t,o,[e,s]),e.useSortedRowIds=_,e.useSortedRowIdsListener=(e,s,t,o,l,r,u,n,d)=>K(C,q(d),r,u,[e,s,t,o,l],n),e.useStartTransactionListener=(e,s,t)=>K("Start"+E,q(t),e,s),e.useStore=e=>x(e,0),e.useStoreIds=()=>O(1),e.useStoreOrStoreById=q,e.useTable=(e,s)=>J(d,q(s),{},[e]),e.useTableCellIds=(e,s)=>J(d+w,q(s),[],[e]),e.useTableCellIdsListener=(e,s,t,o,l)=>K(d+w,q(l),s,t,[e],o),e.useTableIds=Z,e.useTableIdsListener=(e,s,t,o)=>K(a,q(o),e,s,[],t),e.useTableListener=(e,s,t,o,l)=>K(d,q(l),s,t,[e],o),e.useTables=e=>J(i,q(e),{}),e.useTablesListener=(e,s,t,o)=>K(i,q(o),e,s,[],t),e.useUndoInformation=e=>{var s;const t=F(e),[l,r]=Ce(t);return[(u=l,!(0==u.length)),we(t),r,null!=(s=h(r,(e=>null==t?void 0:t.getCheckpoint(e))))?s:o];var u},e.useValue=oe,e.useValueIds=te,e.useValueIdsListener=(e,s,t,o)=>K(v,q(o),e,s,[],t),e.useValueListener=(e,s,t,o,l)=>K(R,q(l),s,t,[e],o),e.useValues=e=>J(k,q(e),{}),e.useValuesListener=(e,s,t,o)=>K(k,q(o),e,s,[],t),e.useWillFinishTransactionListener=(e,s,t)=>K("WillFinish"+E,q(t),e,s)},"object"==typeof exports&&"undefined"!=typeof module?s(exports,require("react")):"function"==typeof define&&define.amd?define(["exports","react"],s):s((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBaseUiReact={},e.React);
1
+ var e,s;e=this,s=function(e,s){"use strict";const t=e=>typeof e,o="",l=t(o),r="Listener",u="Result",n="Ids",d="Table",i=d+"s",a=d+n,c="Row",I=c+"Count",p=c+n,C="Sorted"+c+n,b="Cell",w=b+n,R="Value",k=R+"s",v=R+n,g=e=>null==e,h=(e,s,t)=>g(e)?null==t?void 0:t():s(e),y=e=>t(e)==l,m=()=>{},L=(e,s)=>e.map(s),f=Object.keys,{createContext:S,useContext:V}=s,T=S([]),x=(e,s)=>{var t;const o=V(T);return g(e)?o[s]:y(e)?((e,s)=>h(e,(e=>e[s])))(null!=(t=o[s+1])?t:{},e):e},P=(e,s)=>{const t=x(e,s);return g(e)||y(e)?t:e},O=e=>{var s;return f(null!=(s=V(T)[e])?s:{})},q=e=>P(e,0),B=e=>P(e,2),M=e=>P(e,4),D=e=>P(e,6),j=e=>P(e,8),F=e=>P(e,10),Q=e=>e.toLowerCase();Q(r);const E="Transaction";Q(E);const{useCallback:A,useEffect:G,useMemo:U,useLayoutEffect:W,useRef:z,useState:H}=s,J=[],K={},N=[[],void 0,[]],X=(e,s,t=J)=>{const o=U((()=>s(e)),[e,...t]);return G((()=>()=>o.destroy()),[o]),o},Y=(e,s,t,o=J,l)=>{const[,r]=H(),u=A((()=>{var l,r;return null!=(r=null==(l=null==s?void 0:s["get"+e])?void 0:l.call(s,...o))?r:t}),[s,e,...o,t]),n=z();return U((()=>n.current=u()),[u]),Z(e,s,((...e)=>{n.current=g(l)?u():e[l],r([])}),[u,l],o),n.current},Z=(e,s,t,o=J,l=J,...u)=>W((()=>{var o;const n=null==(o=null==s?void 0:s["add"+e+r])?void 0:o.call(s,...l,t,...u);return()=>null==s?void 0:s.delListener(n)}),[s,e,...l,...o,...u]),$=(e,s,t,o=J,l=m,r=J,...u)=>{const n=q(e);return A((e=>h(n,(o=>h(t(e,o),(e=>l(o["set"+s](...u,e),e)))))),[n,s,...o,...r,...u])},_=(e,s,t=m,o=J,...l)=>{const r=q(e);return A((()=>t(null==r?void 0:r["del"+s](...l))),[r,s,...o,...l])},ee=(e,s,t)=>{const o=F(e);return A((()=>null==o?void 0:o[s](t)),[o,s,t])},se=e=>Y(a,q(e),J),te=(e,s)=>Y(p,q(s),J,[e]),oe=(e,s,t,o=0,l,r)=>Y(C,q(r),J,[e,s,t,o,l],6),le=(e,s,t)=>Y(w,q(t),J,[e,s]),re=(e,s,t,o)=>Y(b,q(o),void 0,[e,s,t],4),ue=e=>Y(v,q(e),J),ne=(e,s)=>Y(R,q(s),void 0,[e]),de=(e,s)=>Y("Metric",B(s),void 0,[e]),ie=(e,s)=>Y("SliceIds",M(s),J,[e]),ae=(e,s,t)=>Y("Slice"+p,M(t),J,[e,s]),ce=(e,s,t)=>Y("RemoteRowId",D(t),void 0,[e,s]),Ie=(e,s,t)=>Y("Local"+p,D(t),J,[e,s]),pe=(e,s,t)=>Y("Linked"+p,D(t),J,[e,s]),Ce=(e,s)=>Y(u+p,j(s),J,[e]),be=(e,s,t,o=0,l,r)=>Y(u+C,j(r),J,[e,s,t,o,l],6),we=(e,s,t)=>Y(u+w,j(t),J,[e,s]),Re=(e,s,t,o)=>Y(u+b,j(o),void 0,[e,s,t]),ke=e=>Y("CheckpointIds",F(e),N),ve=(e,s)=>Y("Checkpoint",F(s),void 0,[e]),ge=e=>ee(e,"goBackward"),he=e=>ee(e,"goForward"),{PureComponent:ye,Fragment:me,createElement:Le,useCallback:fe,useLayoutEffect:Se,useRef:Ve,useState:Te}=s,xe=(e,...s)=>g(e)?{}:e(...s),Pe=(e,s)=>[e,null==e?void 0:e.getStore(),null==e?void 0:e.getLocalTableId(s),null==e?void 0:e.getRemoteTableId(s)];var Oe=Object.defineProperty,qe=Object.defineProperties,Be=Object.getOwnPropertyDescriptors,Me=Object.getOwnPropertySymbols,De=Object.prototype.hasOwnProperty,je=Object.prototype.propertyIsEnumerable,Fe=(e,s,t)=>s in e?Oe(e,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[s]=t,Qe=(e,s)=>{for(var t in s||(s={}))De.call(s,t)&&Fe(e,t,s[t]);if(Me)for(var t of Me(s))je.call(s,t)&&Fe(e,t,s[t]);return e},Ee=(e,s)=>qe(e,Be(s)),Ae=(e,s)=>{var t={};for(var o in e)De.call(e,o)&&s.indexOf(o)<0&&(t[o]=e[o]);if(null!=e&&Me)for(var o of Me(e))s.indexOf(o)<0&&je.call(e,o)&&(t[o]=e[o]);return t};const{useMemo:Ge}=s,Ue=({tableId:e,store:s,rowComponent:t=Ne,getRowComponentProps:o,customCellIds:l,separator:r,debugIds:u},n)=>Je(L(n,(r=>Le(t,Ee(Qe({},xe(o,r)),{key:r,tableId:e,rowId:r,customCellIds:l,store:s,debugIds:u})))),r,u,e),We=({queryId:e,queries:s,resultRowComponent:t=_e,getResultRowComponentProps:o,separator:l,debugIds:r},u)=>Je(L(u,(l=>Le(t,Ee(Qe({},xe(o,l)),{key:l,queryId:e,rowId:l,queries:s,debugIds:r})))),l,r,e),ze=({relationshipId:e,relationships:s,rowComponent:t=Ne,getRowComponentProps:o,separator:l,debugIds:r},u,n)=>{const[d,i,a]=Pe(D(s),e),c=u(e,n,d);return Je(L(c,(e=>Le(t,Ee(Qe({},xe(o,e)),{key:e,tableId:a,rowId:e,store:i,debugIds:r})))),l,r,n)},He=e=>({checkpoints:s,checkpointComponent:t=es,getCheckpointComponentProps:o,separator:l,debugIds:r})=>{const u=F(s);return Je(L(e(ke(u)),(e=>Le(t,Ee(Qe({},xe(o,e)),{key:e,checkpoints:u,checkpointId:e,debugIds:r})))),l)},Je=(e,s,t,o)=>{const l=g(s)||!Array.isArray(e)?e:L(e,((e,t)=>t>0?[s,e]:e));return t?[o,":{",l,"}"]:l},Ke=({tableId:e,rowId:s,cellId:t,store:l,debugIds:r})=>{var u;return Je(o+(null!=(u=re(e,s,t,l))?u:o),void 0,r,t)},Ne=({tableId:e,rowId:s,store:t,cellComponent:o=Ke,getCellComponentProps:l,customCellIds:r,separator:u,debugIds:n})=>Je(L(((e,s,t,o)=>{const l=le(s,t,o);return null!=e?e:l})(r,e,s,t),(r=>Le(o,Ee(Qe({},xe(l,r)),{key:r,tableId:e,rowId:s,cellId:r,store:t,debugIds:n})))),u,n,s),Xe=e=>Ue(e,te(e.tableId,e.store)),Ye=({valueId:e,store:s,debugIds:t})=>{var l;return Je(o+(null!=(l=ne(e,s))?l:o),void 0,t,e)},Ze=({indexId:e,sliceId:s,indexes:t,rowComponent:o=Ne,getRowComponentProps:l,separator:r,debugIds:u})=>{const[n,d,i]=((e,s)=>[e,null==e?void 0:e.getStore(),null==e?void 0:e.getTableId(s)])(M(t),e),a=ae(e,s,n);return Je(L(a,(e=>Le(o,Ee(Qe({},xe(l,e)),{key:e,tableId:i,rowId:e,store:d,debugIds:u})))),r,u,s)},$e=({queryId:e,rowId:s,cellId:t,queries:l,debugIds:r})=>{var u;return Je(o+(null!=(u=Re(e,s,t,l))?u:o),void 0,r,t)},_e=({queryId:e,rowId:s,queries:t,resultCellComponent:o=$e,getResultCellComponentProps:l,separator:r,debugIds:u})=>Je(L(we(e,s,t),(r=>Le(o,Ee(Qe({},xe(l,r)),{key:r,queryId:e,rowId:s,cellId:r,queries:t,debugIds:u})))),r,u,s),es=({checkpoints:e,checkpointId:s,debugIds:t})=>{var l;return Je(null!=(l=ve(s,e))?l:o,void 0,t,s)},ss=He((e=>e[0])),ts=He((e=>g(e[1])?[]:[e[1]])),os=He((e=>e[2]));e.BackwardCheckpointsView=ss,e.CellView=Ke,e.CheckpointView=es,e.CurrentCheckpointView=ts,e.ForwardCheckpointsView=os,e.IndexView=({indexId:e,indexes:s,sliceComponent:t=Ze,getSliceComponentProps:o,separator:l,debugIds:r})=>Je(L(ie(e,s),(l=>Le(t,Ee(Qe({},xe(o,l)),{key:l,indexId:e,sliceId:l,indexes:s,debugIds:r})))),l,r,e),e.LinkedRowsView=e=>ze(e,pe,e.firstRowId),e.LocalRowsView=e=>ze(e,Ie,e.remoteRowId),e.MetricView=({metricId:e,metrics:s,debugIds:t})=>{var l;return Je(null!=(l=de(e,s))?l:o,void 0,t,e)},e.Provider=({store:e,storesById:t,metrics:o,metricsById:l,indexes:r,indexesById:u,relationships:n,relationshipsById:d,queries:i,queriesById:a,checkpoints:c,checkpointsById:I,children:p})=>{const C=s.useContext(T);return Le(T.Provider,{value:Ge((()=>[null!=e?e:C[0],Qe(Qe({},C[1]),t),null!=o?o:C[2],Qe(Qe({},C[3]),l),null!=r?r:C[4],Qe(Qe({},C[5]),u),null!=n?n:C[6],Qe(Qe({},C[7]),d),null!=i?i:C[8],Qe(Qe({},C[9]),a),null!=c?c:C[10],Qe(Qe({},C[11]),I)]),[e,t,o,l,r,u,n,d,i,a,c,I,C])},p)},e.RemoteRowView=({relationshipId:e,localRowId:s,relationships:t,rowComponent:o=Ne,getRowComponentProps:l,debugIds:r})=>{const[u,n,,d]=Pe(D(t),e),i=ce(e,s,u);return Je(g(d)||g(i)?null:Le(o,Ee(Qe({},xe(l,i)),{key:i,tableId:d,rowId:i,store:n,debugIds:r})),void 0,r,s)},e.ResultCellView=$e,e.ResultRowView=_e,e.ResultSortedTableView=e=>{var s=e,{cellId:t,descending:o,offset:l,limit:r}=s,u=Ae(s,["cellId","descending","offset","limit"]);return We(u,be(u.queryId,t,o,l,r,u.queries))},e.ResultTableView=e=>We(e,Ce(e.queryId,e.queries)),e.RowView=Ne,e.SliceView=Ze,e.SortedTableView=e=>{var s=e,{cellId:t,descending:o,offset:l,limit:r}=s,u=Ae(s,["cellId","descending","offset","limit"]);return Ue(u,oe(u.tableId,t,o,l,r,u.store))},e.TableView=Xe,e.TablesView=({store:e,tableComponent:s=Xe,getTableComponentProps:t,separator:o,debugIds:l})=>Je(L(se(e),(o=>Le(s,Ee(Qe({},xe(t,o)),{key:o,tableId:o,store:e,debugIds:l})))),o),e.ValueView=Ye,e.ValuesView=({store:e,valueComponent:s=Ye,getValueComponentProps:t,separator:o,debugIds:l})=>Je(L(ue(e),(o=>Le(s,Ee(Qe({},xe(t,o)),{key:o,valueId:o,store:e,debugIds:l})))),o),e.useAddRowCallback=(e,s,t=J,o,l=m,r=J,u=!0)=>{const n=q(o);return A((t=>h(n,(o=>h(s(t,o),(s=>l(o.addRow(e,s,u),o,s)))))),[n,e,...t,...r,u])},e.useCell=re,e.useCellIds=le,e.useCellIdsListener=(e,s,t,o,l,r)=>Z(w,q(r),t,o,[e,s],l),e.useCellListener=(e,s,t,o,l,r,u)=>Z(b,q(u),o,l,[e,s,t],r),e.useCheckpoint=ve,e.useCheckpointIds=ke,e.useCheckpointIdsListener=(e,s,t)=>Z("CheckpointIds",F(t),e,s),e.useCheckpointListener=(e,s,t,o)=>Z("Checkpoint",F(o),s,t,[e]),e.useCheckpoints=e=>x(e,10),e.useCheckpointsIds=()=>O(11),e.useCheckpointsOrCheckpointsById=F,e.useCreateCheckpoints=(e,s,t)=>X(e,s,t),e.useCreateIndexes=(e,s,t)=>X(e,s,t),e.useCreateMetrics=(e,s,t)=>X(e,s,t),e.useCreatePersister=(e,s,t=J,o,l=J,r,u=J)=>{const[,n]=H(),d=U((()=>s(e)),[e,...t]);return G((()=>{var e;return e=function*(){o&&(yield o(d),n([]))},new Promise(((s,t)=>{var o=s=>{try{r(e.next(s))}catch(e){t(e)}},l=s=>{try{r(e.throw(s))}catch(e){t(e)}},r=e=>e.done?s(e.value):Promise.resolve(e.value).then(o,l);r((e=e.apply(void 0,null)).next())})),()=>{null==d||d.destroy(),null==r||r(d)}}),[d,...l,...u]),d},e.useCreateQueries=(e,s,t)=>X(e,s,t),e.useCreateRelationships=(e,s,t)=>X(e,s,t),e.useCreateStore=(e,s=J)=>U(e,s),e.useDelCellCallback=(e,s,t,o,l,r,u)=>_(l,b,r,u,e,s,t,o),e.useDelRowCallback=(e,s,t,o,l)=>_(t,c,o,l,e,s),e.useDelTableCallback=(e,s,t,o)=>_(s,d,t,o,e),e.useDelTablesCallback=(e,s,t)=>_(e,i,s,t),e.useDelValueCallback=(e,s,t,o)=>_(s,R,t,o,e),e.useDelValuesCallback=(e,s,t)=>_(e,k,s,t),e.useDidFinishTransactionListener=(e,s,t)=>Z("DidFinish"+E,q(t),e,s),e.useGoBackwardCallback=ge,e.useGoForwardCallback=he,e.useGoToCallback=(e,s=J,t,o=m,l=J)=>{const r=F(t);return A((s=>h(r,(t=>h(e(s),(e=>o(t.goTo(e),e)))))),[r,...s,...l])},e.useIndexIds=e=>Y("IndexIds",M(e),J),e.useIndexes=e=>x(e,4),e.useIndexesIds=()=>O(5),e.useIndexesOrIndexesById=M,e.useLinkedRowIds=pe,e.useLinkedRowIdsListener=(e,s,t,o,l)=>Z("Linked"+p,D(l),t,o,[e,s]),e.useLocalRowIds=Ie,e.useLocalRowIdsListener=(e,s,t,o,l)=>Z("Local"+p,D(l),t,o,[e,s]),e.useMetric=de,e.useMetricIds=e=>Y("MetricIds",B(e),J),e.useMetricListener=(e,s,t,o)=>Z("Metric",B(o),s,t,[e]),e.useMetrics=e=>x(e,2),e.useMetricsIds=()=>O(3),e.useMetricsOrMetricsById=B,e.useQueries=e=>x(e,8),e.useQueriesIds=()=>O(9),e.useQueriesOrQueriesById=j,e.useQueryIds=e=>Y("QueryIds",j(e),J),e.useRedoInformation=e=>{var s;const t=F(e),[,,[l]]=ke(t);return[!g(l),he(t),l,null!=(s=h(l,(e=>null==t?void 0:t.getCheckpoint(e))))?s:o]},e.useRelationshipIds=e=>Y("RelationshipIds",D(e),J),e.useRelationships=e=>x(e,6),e.useRelationshipsIds=()=>O(7),e.useRelationshipsOrRelationshipsById=D,e.useRemoteRowId=ce,e.useRemoteRowIdListener=(e,s,t,o,l)=>Z("RemoteRowId",D(l),t,o,[e,s]),e.useResultCell=Re,e.useResultCellIds=we,e.useResultCellIdsListener=(e,s,t,o,l)=>Z(u+w,j(l),t,o,[e,s]),e.useResultCellListener=(e,s,t,o,l,r)=>Z(u+b,j(r),o,l,[e,s,t]),e.useResultRow=(e,s,t)=>Y(u+c,j(t),K,[e,s]),e.useResultRowCount=(e,s)=>Y(u+I,j(s),0,[e]),e.useResultRowCountListener=(e,s,t,o)=>Z(u+I,j(o),s,t,[e]),e.useResultRowIds=Ce,e.useResultRowIdsListener=(e,s,t,o)=>Z(u+p,j(o),s,t,[e]),e.useResultRowListener=(e,s,t,o,l)=>Z(u+c,j(l),t,o,[e,s]),e.useResultSortedRowIds=be,e.useResultSortedRowIdsListener=(e,s,t,o,l,r,n,d)=>Z(u+C,j(d),r,n,[e,s,t,o,l]),e.useResultTable=(e,s)=>Y(u+d,j(s),K,[e]),e.useResultTableCellIds=(e,s)=>Y(u+d+w,j(s),J,[e]),e.useResultTableCellIdsListener=(e,s,t,o)=>Z(u+d+w,j(o),s,t,[e]),e.useResultTableListener=(e,s,t,o)=>Z(u+d,j(o),s,t,[e]),e.useRow=(e,s,t)=>Y(c,q(t),K,[e,s]),e.useRowCount=(e,s)=>Y(I,q(s),0,[e]),e.useRowCountListener=(e,s,t,o,l)=>Z(I,q(l),s,t,[e],o),e.useRowIds=te,e.useRowIdsListener=(e,s,t,o,l)=>Z(p,q(l),s,t,[e],o),e.useRowListener=(e,s,t,o,l,r)=>Z(c,q(r),t,o,[e,s],l),e.useSetCellCallback=(e,s,t,o,l,r,u,n)=>$(r,b,o,l,u,n,e,s,t),e.useSetCheckpointCallback=(e=m,s=J,t,o=m,l=J)=>{const r=F(t);return A((s=>h(r,(t=>{const l=e(s);o(t.addCheckpoint(l),t,l)}))),[r,...s,...l])},e.useSetPartialRowCallback=(e,s,t,o,l,r,u)=>$(l,"PartialRow",t,o,r,u,e,s),e.useSetPartialValuesCallback=(e,s,t,o,l)=>$(t,"PartialValues",e,s,o,l),e.useSetRowCallback=(e,s,t,o,l,r,u)=>$(l,c,t,o,r,u,e,s),e.useSetTableCallback=(e,s,t,o,l,r)=>$(o,d,s,t,l,r,e),e.useSetTablesCallback=(e,s,t,o,l)=>$(t,i,e,s,o,l),e.useSetValueCallback=(e,s,t,o,l,r)=>$(o,R,s,t,l,r,e),e.useSetValuesCallback=(e,s,t,o,l)=>$(t,k,e,s,o,l),e.useSliceIds=ie,e.useSliceIdsListener=(e,s,t,o)=>Z("SliceIds",M(o),s,t,[e]),e.useSliceRowIds=ae,e.useSliceRowIdsListener=(e,s,t,o,l)=>Z("Slice"+p,M(l),t,o,[e,s]),e.useSortedRowIds=oe,e.useSortedRowIdsListener=(e,s,t,o,l,r,u,n,d)=>Z(C,q(d),r,u,[e,s,t,o,l],n),e.useStartTransactionListener=(e,s,t)=>Z("Start"+E,q(t),e,s),e.useStore=e=>x(e,0),e.useStoreIds=()=>O(1),e.useStoreOrStoreById=q,e.useTable=(e,s)=>Y(d,q(s),K,[e]),e.useTableCellIds=(e,s)=>Y(d+w,q(s),J,[e]),e.useTableCellIdsListener=(e,s,t,o,l)=>Z(d+w,q(l),s,t,[e],o),e.useTableIds=se,e.useTableIdsListener=(e,s,t,o)=>Z(a,q(o),e,s,J,t),e.useTableListener=(e,s,t,o,l)=>Z(d,q(l),s,t,[e],o),e.useTables=e=>Y(i,q(e),K),e.useTablesListener=(e,s,t,o)=>Z(i,q(o),e,s,J,t),e.useUndoInformation=e=>{var s;const t=F(e),[l,r]=ke(t);return[(u=l,!(0==u.length)),ge(t),r,null!=(s=h(r,(e=>null==t?void 0:t.getCheckpoint(e))))?s:o];var u},e.useValue=ne,e.useValueIds=ue,e.useValueIdsListener=(e,s,t,o)=>Z(v,q(o),e,s,J,t),e.useValueListener=(e,s,t,o,l)=>Z(R,q(l),s,t,[e],o),e.useValues=e=>Y(k,q(e),K),e.useValuesListener=(e,s,t,o)=>Z(k,q(o),e,s,J,t),e.useWillFinishTransactionListener=(e,s,t)=>Z("WillFinish"+E,q(t),e,s)},"object"==typeof exports&&"undefined"!=typeof module?s(exports,require("react")):"function"==typeof define&&define.amd?define(["exports","react"],s):s((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBaseUiReact={},e.React);
Binary file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "tinybase",
3
- "version": "4.3.22",
3
+ "version": "4.3.24",
4
4
  "author": "jamesgpearce",
5
5
  "repository": "github:tinyplex/tinybase",
6
6
  "license": "MIT",
@@ -213,7 +213,7 @@
213
213
  "publishPackage": "gulp publishPackage"
214
214
  },
215
215
  "devDependencies": {
216
- "@automerge/automerge": "^2.1.5",
216
+ "@automerge/automerge": "^2.1.6",
217
217
  "@babel/cli": "^7.23.0",
218
218
  "@babel/core": "^7.23.2",
219
219
  "@babel/preset-env": "^7.23.2",
@@ -221,23 +221,23 @@
221
221
  "@babel/preset-typescript": "^7.23.2",
222
222
  "@prettier/sync": "^0.3.0",
223
223
  "@rollup/plugin-image": "^3.0.3",
224
- "@rollup/plugin-replace": "^5.0.4",
224
+ "@rollup/plugin-replace": "^5.0.5",
225
225
  "@rollup/plugin-terser": "^0.4.4",
226
- "@sqlite.org/sqlite-wasm": "^3.43.2-build1",
227
- "@types/asciichart": "^1.5.7",
228
- "@types/expect-puppeteer": "^5.0.5",
229
- "@types/http-server": "^0.12.3",
230
- "@types/jest": "^29.5.6",
231
- "@types/jest-environment-puppeteer": "^5.0.5",
232
- "@types/less": "^3.0.5",
233
- "@types/node": "^20.8.8",
226
+ "@sqlite.org/sqlite-wasm": "^3.44.0-build1",
227
+ "@types/asciichart": "^1.5.8",
228
+ "@types/expect-puppeteer": "^5.0.6",
229
+ "@types/http-server": "^0.12.4",
230
+ "@types/jest": "^29.5.7",
231
+ "@types/jest-environment-puppeteer": "^5.0.6",
232
+ "@types/less": "^3.0.6",
233
+ "@types/node": "^20.8.10",
234
234
  "@types/puppeteer": "^5.4.7",
235
- "@types/react": "^18.2.31",
235
+ "@types/react": "^18.2.36",
236
236
  "@types/react-dom": "^18.2.14",
237
237
  "@types/react-test-renderer": "^18.0.5",
238
- "@types/tmp": "^0.2.5",
239
- "@typescript-eslint/eslint-plugin": "^6.9.0",
240
- "@typescript-eslint/parser": "^6.9.0",
238
+ "@types/tmp": "^0.2.6",
239
+ "@typescript-eslint/eslint-plugin": "^6.10.0",
240
+ "@typescript-eslint/parser": "^6.10.0",
241
241
  "@vlcn.io/crsqlite-wasm": "^0.15.2",
242
242
  "asciichart": "^1.5.25",
243
243
  "automerge-repo": "^0.1.0",
@@ -248,16 +248,16 @@
248
248
  "babel-preset-minify": "^0.5.2",
249
249
  "buffer-replace": "^1.0.0",
250
250
  "country-flag-emoji-json": "^2.0.0",
251
- "cspell": "^7.3.8",
251
+ "cspell": "^8.0.0",
252
252
  "esbuild": "^0.19.5",
253
- "eslint": "^8.52.0",
253
+ "eslint": "^8.53.0",
254
254
  "eslint-config-prettier": "^9.0.0",
255
- "eslint-plugin-jest": "^27.4.3",
255
+ "eslint-plugin-jest": "^27.6.0",
256
256
  "eslint-plugin-jsdoc": "^46.8.2",
257
257
  "eslint-plugin-react": "7.33.2",
258
258
  "eslint-plugin-react-hooks": "^4.6.0",
259
259
  "expo-sqlite": "^11.6.0",
260
- "fake-indexeddb": "^4.0.2",
260
+ "fake-indexeddb": "^5.0.1",
261
261
  "gulp": "^4.0.2",
262
262
  "gulp-gzip": "^1.4.2",
263
263
  "http-server": "^14.1.1",
@@ -267,14 +267,14 @@
267
267
  "jest-fetch-mock": "^3.0.3",
268
268
  "jest-puppeteer": "^9.0.1",
269
269
  "less": "^4.2.0",
270
- "partykit": "^0.0.32",
271
- "partysocket": "^0.0.12",
270
+ "partykit": "^0.0.34",
271
+ "partysocket": "^0.0.14",
272
272
  "prettier": "^3.0.3",
273
273
  "puppeteer": "21.1.1",
274
274
  "react": "^18.2.0",
275
275
  "react-dom": "^18.2.0",
276
276
  "react-test-renderer": "^18.2.0",
277
- "rollup": "^4.1.4",
277
+ "rollup": "^4.3.0",
278
278
  "rollup-plugin-esbuild": "^6.1.0",
279
279
  "rollup-plugin-gzip": "^3.1.0",
280
280
  "rollup-plugin-preserve-shebang": "^1.0.1",
@@ -288,11 +288,11 @@
288
288
  "yjs": "^13.6.8"
289
289
  },
290
290
  "peerDependencies": {
291
- "@sqlite.org/sqlite-wasm": "^3.43.2-build1",
291
+ "@sqlite.org/sqlite-wasm": "^3.44.0-build1",
292
292
  "@vlcn.io/crsqlite-wasm": "^0.15.2",
293
293
  "automerge-repo": "^0.1.0",
294
- "partykit": "^0.0.32",
295
- "partysocket": "^0.0.12",
294
+ "partykit": "^0.0.34",
295
+ "partysocket": "^0.0.14",
296
296
  "prettier": "^3.0.3",
297
297
  "react": "^18.2.0",
298
298
  "react-dom": "^18.2.0",
package/readme.md CHANGED
@@ -1,4 +1,4 @@
1
- <section id="hero"><h2 id="the-reactive-data-store-for-local-first-apps">The <em>reactive</em> data store for <span>local-first apps</span>.</h2><p id="copy">Build blisteringly fast web apps that work both online and offline. Manage your state locally, synchronize it to the cloud when you need to, or even make it collaborative. But, most importantly... have fun building stuff again!</p></section><p><a href="https://tinybase.org/guides/releases/#v4-3"><em>NEW!</em> v4.3 release</a> <span id="one-with">&quot;The One With PartyKit&quot;</span></p><p><a class="start" href="https://tinybase.org/guides/the-basics/getting-started/">Get started</a></p><p><a href="https://tinybase.org/demos/">Try the demos</a></p><p><a href="https://tinybase.org/api/store/interfaces/store/store/">Read the docs</a></p><hr><ul><li>Manage <a href="#start-with-a-simple-key-value-store">key-value data</a>, <a href="#level-up-to-use-tabular-data">tabular data</a> - or both - with optional <a href="#apply-schemas-to-tables-values">schematization</a> to model your app&#x27;s data structures.</li><li><a href="#register-granular-listeners">Flexibly reactive</a> to reconciled updates, so you only spend rendering cycles on things that change.</li><li><a href="#build-complex-queries-with-tinyql">Powerful query engine</a> to select, join, filter, group, sort and paginate data - reactively - and without SQL.</li><li>Built-in <a href="#create-indexes-for-fast-lookups">indexing</a>, <a href="#define-metrics-and-aggregations">metric aggregation</a>, <a href="#model-table-relationships">tabular relationships</a> - and even an <a href="#set-checkpoints-for-an-undo-stack">undo stack</a> for your app state.</li><li>Create <a href="#type-definitions-orm-like-apis">type definitions &amp; ORM-like APIs</a>, from schema or inference. <a href="#an-inspector-for-your-data">Inspect your data</a> (<em>new!</em>) directly in the browser.</li><li>Easily <a href="#persist-to-storage-sqlite-crdts">sync your data</a> to browser <a href="https://tinybase.org/api/persister-browser">storage</a>, <a href="https://tinybase.org/api/persister-indexed-db/">IndexedDB</a>, <a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence/">SQLite</a>, <a href="https://tinybase.org/guides/schemas-and-persistence/synchronizing-data/">CRDTs</a>, and (<em>new!</em>) <a href="https://tinybase.org/api/persister-partykit-client/">PartyKit</a>.</li><li>Optional <a href="#call-hooks-to-bind-to-data">bindings to React</a> and (<em>new!</em>) <a href="#pre-built-reactive-components">pre-built components</a> that let you easily build fully reactive user interfaces.</li><li>Tiny by name, tiny by nature: <a href="#did-we-say-tiny">4.8kB - 9.2kB</a>, zero dependencies. <a href="#well-tested-and-documented">100% tested</a>, <a href="https://tinybase.org/guides/the-basics/getting-started/">fully documented</a>, and of course, <a href="https://github.com/tinyplex/tinybase">open source</a>!</li></ul><hr><section id="friends"><h2 id="tinybase-works-great-on-its-own-but-also-plays-well-with-friends">Tinybase works great on its own, but also plays well with friends!</h2><div><a href="https://tinybase.org/guides/building-uis/getting-started-with-ui-react"><img width="48" src="https://tinybase.org/react.svg"> React</a></div><div><a href="https://tinybase.org/api/persister-partykit-client"><img width="48" src="https://tinybase.org/partykit.svg"> PartyKit</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/sqlite.svg"> SQLite</a></div><div><a href="https://tinybase.org/api/persister-indexed-db/functions/creation/createindexeddbpersister"><img width="48" src="https://tinybase.org/indexeddb.svg"> IndexedDB</a></div><div><a href="https://tinybase.org/api/persister-yjs/functions/creation/createyjspersister"><img width="48" src="https://tinybase.org/yjs.svg"> YJS</a></div><div><a href="https://tinybase.org/api/persister-cr-sqlite-wasm"><img width="48" src="https://tinybase.org/crsqlite.png"> CR-SQLite</a></div><div><a href="https://tinybase.org/api/persister-automerge"><img width="48" src="https://tinybase.org/automerge.svg"> Automerge</a></div></section><hr><section id="follow"><a href="https://github.com/tinyplex/tinybase" target="_blank"><img src="https://img.shields.io/github/stars/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=GitHub&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="https://discord.com/invite/mGz3mevwP8" target="_blank"><img src="https://img.shields.io/discord/1027918215323590676?style=for-the-badge&amp;logo=discord&amp;logoColor=%23fff&amp;label=Discord&amp;labelColor=%233131e8&amp;color=%23333"> </a><a href="https://twitter.com/tinybasejs" target="_blank"><img src="https://img.shields.io/twitter/follow/tinybasejs?style=for-the-badge&amp;logo=x&amp;logoColor=%23fff&amp;label=Twitter&amp;labelColor=%23333&amp;color=%23333"></a><br><a href="https://github.com/tinyplex/tinybase/discussions" target="_blank"><img src="https://img.shields.io/github/discussions/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=Ideas&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="https://github.com/tinyplex/tinybase/issues" target="_blank"><img src="https://img.shields.io/github/issues/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=Issues&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="#well-tested-and-documented"><img src="https://img.shields.io/badge/Tests-100%25-green?style=for-the-badge&amp;logo=jest&amp;logoColor=%23fff&amp;color=%23333&amp;labelColor=%2387c305"> </a><a href="https://www.npmjs.com/package/tinybase/v/4.3.22" target="_blank"><img src="https://img.shields.io/npm/v/tinybase?style=for-the-badge&amp;logo=npm&amp;logoColor=%23fff&amp;labelColor=%23bd0005&amp;color=%23333"></a></section><hr><section><h2 id="start-with-a-simple-key-value-store">Start with a simple key-value store.</h2><p>Creating a <a href="https://tinybase.org/api/store/interfaces/store/store/"><code>Store</code></a> requires just a simple call to the <a href="https://tinybase.org/api/store/functions/creation/createstore/"><code>createStore</code></a> function. Once you have one, you can easily set <a href="https://tinybase.org/api/store/type-aliases/store/values/"><code>Values</code></a> in it by unique <a href="https://tinybase.org/api/common/type-aliases/identity/id/"><code>Id</code></a>. And of course you can easily get them back out again.</p><p>Read more about using keyed value data in <a href="https://tinybase.org/guides/the-basics/">The Basics</a> guide.</p></section>
1
+ <section id="hero"><h2 id="the-reactive-data-store-for-local-first-apps">The <em>reactive</em> data store for <span>local-first apps</span>.</h2><p id="copy">Build blisteringly fast web apps that work both online and offline. Manage your state locally, synchronize it to the cloud when you need to, or even make it collaborative. But, most importantly... have fun building stuff again!</p></section><p><a href="https://tinybase.org/guides/releases/#v4-3"><em>NEW!</em> v4.3 release</a> <span id="one-with">&quot;The One With PartyKit&quot;</span></p><p><a class="start" href="https://tinybase.org/guides/the-basics/getting-started/">Get started</a></p><p><a href="https://tinybase.org/demos/">Try the demos</a></p><p><a href="https://tinybase.org/api/store/interfaces/store/store/">Read the docs</a></p><hr><ul><li>Manage <a href="#start-with-a-simple-key-value-store">key-value data</a>, <a href="#level-up-to-use-tabular-data">tabular data</a> - or both - with optional <a href="#apply-schemas-to-tables-values">schematization</a> to model your app&#x27;s data structures.</li><li><a href="#register-granular-listeners">Flexibly reactive</a> to reconciled updates, so you only spend rendering cycles on things that change.</li><li><a href="#build-complex-queries-with-tinyql">Powerful query engine</a> to select, join, filter, group, sort and paginate data - reactively - and without SQL.</li><li>Built-in <a href="#create-indexes-for-fast-lookups">indexing</a>, <a href="#define-metrics-and-aggregations">metric aggregation</a>, <a href="#model-table-relationships">tabular relationships</a> - and even an <a href="#set-checkpoints-for-an-undo-stack">undo stack</a> for your app state.</li><li>Create <a href="#type-definitions-orm-like-apis">type definitions &amp; ORM-like APIs</a>, from schema or inference. <a href="#an-inspector-for-your-data">Inspect your data</a> (<em>new!</em>) directly in the browser.</li><li>Easily <a href="#persist-to-storage-sqlite-crdts">sync your data</a> to browser <a href="https://tinybase.org/api/persister-browser">storage</a>, <a href="https://tinybase.org/api/persister-indexed-db/">IndexedDB</a>, <a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence/">SQLite</a>, <a href="https://tinybase.org/guides/schemas-and-persistence/synchronizing-data/">CRDTs</a>, and (<em>new!</em>) <a href="https://tinybase.org/api/persister-partykit-client/">PartyKit</a>.</li><li>Optional <a href="#call-hooks-to-bind-to-data">bindings to React</a> and (<em>new!</em>) <a href="#pre-built-reactive-components">pre-built components</a> that let you easily build fully reactive user interfaces.</li><li>Tiny by name, tiny by nature: <a href="#did-we-say-tiny">4.8kB - 9.2kB</a>, zero dependencies. <a href="#well-tested-and-documented">100% tested</a>, <a href="https://tinybase.org/guides/the-basics/getting-started/">fully documented</a>, and of course, <a href="https://github.com/tinyplex/tinybase">open source</a>!</li></ul><hr><section id="friends"><h2 id="tinybase-works-great-on-its-own-but-also-plays-well-with-friends">Tinybase works great on its own, but also plays well with friends!</h2><div><a href="https://tinybase.org/guides/building-uis/getting-started-with-ui-react"><img width="48" src="https://tinybase.org/react.svg"> React</a></div><div><a href="https://tinybase.org/api/persister-partykit-client"><img width="48" src="https://tinybase.org/partykit.svg"> PartyKit</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/sqlite.svg"> SQLite</a></div><div><a href="https://tinybase.org/api/persister-indexed-db/functions/creation/createindexeddbpersister"><img width="48" src="https://tinybase.org/indexeddb.svg"> IndexedDB</a></div><div><a href="https://tinybase.org/api/persister-yjs/functions/creation/createyjspersister"><img width="48" src="https://tinybase.org/yjs.svg"> YJS</a></div><div><a href="https://tinybase.org/api/persister-cr-sqlite-wasm"><img width="48" src="https://tinybase.org/crsqlite.png"> CR-SQLite</a></div><div><a href="https://tinybase.org/api/persister-automerge"><img width="48" src="https://tinybase.org/automerge.svg"> Automerge</a></div></section><hr><section id="follow"><a href="https://github.com/tinyplex/tinybase" target="_blank"><img src="https://img.shields.io/github/stars/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=GitHub&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="https://discord.com/invite/mGz3mevwP8" target="_blank"><img src="https://img.shields.io/discord/1027918215323590676?style=for-the-badge&amp;logo=discord&amp;logoColor=%23fff&amp;label=Discord&amp;labelColor=%233131e8&amp;color=%23333"> </a><a href="https://twitter.com/tinybasejs" target="_blank"><img src="https://img.shields.io/twitter/follow/tinybasejs?style=for-the-badge&amp;logo=x&amp;logoColor=%23fff&amp;label=Twitter&amp;labelColor=%23333&amp;color=%23333"></a><br><a href="https://github.com/tinyplex/tinybase/discussions" target="_blank"><img src="https://img.shields.io/github/discussions/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=Ideas&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="https://github.com/tinyplex/tinybase/issues" target="_blank"><img src="https://img.shields.io/github/issues/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=Issues&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="#well-tested-and-documented"><img src="https://img.shields.io/badge/Tests-100%25-green?style=for-the-badge&amp;logo=jest&amp;logoColor=%23fff&amp;color=%23333&amp;labelColor=%2387c305"> </a><a href="https://www.npmjs.com/package/tinybase/v/4.3.24" target="_blank"><img src="https://img.shields.io/npm/v/tinybase?style=for-the-badge&amp;logo=npm&amp;logoColor=%23fff&amp;labelColor=%23bd0005&amp;color=%23333"></a></section><hr><section><h2 id="start-with-a-simple-key-value-store">Start with a simple key-value store.</h2><p>Creating a <a href="https://tinybase.org/api/store/interfaces/store/store/"><code>Store</code></a> requires just a simple call to the <a href="https://tinybase.org/api/store/functions/creation/createstore/"><code>createStore</code></a> function. Once you have one, you can easily set <a href="https://tinybase.org/api/store/type-aliases/store/values/"><code>Values</code></a> in it by unique <a href="https://tinybase.org/api/common/type-aliases/identity/id/"><code>Id</code></a>. And of course you can easily get them back out again.</p><p>Read more about using keyed value data in <a href="https://tinybase.org/guides/the-basics/">The Basics</a> guide.</p></section>
2
2
 
3
3
  ```js
4
4
  const store = createStore()
@@ -247,4 +247,4 @@ export const createShop: typeof createShopDecl = () => {
247
247
  };
248
248
  ```
249
249
 
250
- <section><h2 id="did-we-say-tiny">Did we say tiny?</h2><p>If you use the basic <a href="https://tinybase.org/api/store/"><code>store</code></a> module alone, you&#x27;ll only add a gzipped <em>4.8kB</em> to your app. Incrementally add the other modules as you need more functionality, or get it all for <em>9.2kB</em>.</p><p>The optional <a href="https://tinybase.org/api/ui-react/"><code>ui-react</code></a> module is just another <em>3.9kB</em>, the auxiliary <a href="https://tinybase.org/api/tools/"><code>tools</code></a> module is <em>10.5kB</em>, and everything is super fast. Life&#x27;s easy when you have zero dependencies!</p><p>Read more about how TinyBase is structured and packaged in the <a href="https://tinybase.org/guides/how-tinybase-is-built/architecture/">Architecture</a> guide.</p></section><div class="table"><table class="fixed"><tbody><tr><th width="30%"> </th><th>.js.gz</th><th>.js</th><th>debug.js</th><th>.d.ts</th></tr><tr><th class="right"><a href="https://tinybase.org/api/store/">store</a></th><td>4.8kB</td><td>11.4kB</td><td>48.6kB</td><td>220.1kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/metrics/">metrics</a></th><td>1.8kB</td><td>3.6kB</td><td>15.2kB</td><td>30.9kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/indexes/">indexes</a></th><td>1.9kB</td><td>3.8kB</td><td>17.0kB</td><td>35.6kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/relationships/">relationships</a></th><td>1.9kB</td><td>3.7kB</td><td>17.1kB</td><td>44.2kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/queries/">queries</a></th><td>2.8kB</td><td>5.7kB</td><td>25.6kB</td><td>127.8kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/checkpoints/">checkpoints</a></th><td>1.5kB</td><td>3.1kB</td><td>12.4kB</td><td>33.3kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/persisters/">persisters</a></th><td>0.8kB</td><td>1.5kB</td><td>5.2kB</td><td>43.5kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/common/">common</a></th><td>0.1kB</td><td>0.1kB</td><td>0.1kB</td><td>3.5kB</td></tr><tr><th class="right">tinybase (all)</th><td>9.2kB</td><td>22.6kB</td><td>97.6kB</td><td>0.3kB</td></tr></tbody></table></div><section><h2 id="well-tested-and-documented">Well tested and documented.</h2><p>TinyBase has <em>100.0%</em> test coverage, including the code throughout the documentation - even on this page! The guides, demos, and API examples are designed to make it as easy as possible for you to get your TinyBase-powered app up and running.</p><p>Read more about how TinyBase is tested in the Unit <a href="https://tinybase.org/guides/how-tinybase-is-built/testing/">Testing</a> guide.</p></section><div class="table"><table class="fixed"><tbody><tr><th width="30%"> </th><th>Total</th><th>Tested</th><th>Coverage</th></tr><tr><th class="right">Lines</th><td>1,885</td><td>1,885</td><td>100.0%</td></tr><tr><th class="right">Statements</th><td>2,040</td><td>2,040</td><td>100.0%</td></tr><tr><th class="right">Functions</th><td>813</td><td>813</td><td>100.0%</td></tr><tr><th class="right">Branches</th><td>695</td><td>695</td><td>100.0%</td></tr><tr><th class="right">Tests</th><td colspan="3">3,402</td></tr><tr><th class="right">Assertions</th><td colspan="3">15,316</td></tr></tbody></table></div><hr><section id="sponsors"><h2 id="proud-to-be-sponsored-by">Proud to be sponsored by:</h2><a href="https://github.com/expo" target="_blank"><img title="expo" src="https://github.com/expo.png?size=48" width="48" height="48"></a><a href="https://github.com/cancelself" target="_blank"><img title="cancelself" src="https://github.com/cancelself.png?size=48" width="48" height="48"></a><a href="https://github.com/WonderPanda" target="_blank"><img title="WonderPanda" src="https://github.com/WonderPanda.png?size=48" width="48" height="48"></a><a href="https://github.com/arpitBhalla" target="_blank"><img title="arpitBhalla" src="https://github.com/arpitBhalla.png?size=48" width="48" height="48"></a></section><section id="users"><h2 id="excited-to-be-used-by">Excited to be used by:</h2><a href="https://github.com/Apocalypsor" target="_blank"><img title="Apocalypsor" src="https://github.com/Apocalypsor.png?size=48" width="48" height="48"></a><a href="https://github.com/brentvatne" target="_blank"><img title="brentvatne" src="https://github.com/brentvatne.png?size=48" width="48" height="48"></a><a href="https://github.com/circadian-risk" target="_blank"><img title="circadian-risk" src="https://github.com/circadian-risk.png?size=48" width="48" height="48"></a><a href="https://github.com/cubecull" target="_blank"><img title="cubecull" src="https://github.com/cubecull.png?size=48" width="48" height="48"></a><a href="https://github.com/erwinkn" target="_blank"><img title="erwinkn" src="https://github.com/erwinkn.png?size=48" width="48" height="48"></a><a href="https://github.com/expo" target="_blank"><img title="expo" src="https://github.com/expo.png?size=48" width="48" height="48"></a><a href="https://github.com/ezra-en" target="_blank"><img title="ezra-en" src="https://github.com/ezra-en.png?size=48" width="48" height="48"></a><a href="https://github.com/fdfontes" target="_blank"><img title="fdfontes" src="https://github.com/fdfontes.png?size=48" width="48" height="48"></a><a href="https://github.com/flaming-codes" target="_blank"><img title="flaming-codes" src="https://github.com/flaming-codes.png?size=48" width="48" height="48"></a><a href="https://github.com/generates" target="_blank"><img title="generates" src="https://github.com/generates.png?size=48" width="48" height="48"></a><a href="https://github.com/Giulio987" target="_blank"><img title="Giulio987" src="https://github.com/Giulio987.png?size=48" width="48" height="48"></a><a href="https://github.com/jaysc" target="_blank"><img title="jaysc" src="https://github.com/jaysc.png?size=48" width="48" height="48"></a><a href="https://github.com/Kayoo-asso" target="_blank"><img title="Kayoo-asso" src="https://github.com/Kayoo-asso.png?size=48" width="48" height="48"></a><a href="https://github.com/kotofurumiya" target="_blank"><img title="kotofurumiya" src="https://github.com/kotofurumiya.png?size=48" width="48" height="48"></a><a href="https://github.com/learn-anything" target="_blank"><img title="learn-anything" src="https://github.com/learn-anything.png?size=48" width="48" height="48"></a><a href="https://github.com/marksteve" target="_blank"><img title="marksteve" src="https://github.com/marksteve.png?size=48" width="48" height="48"></a><a href="https://github.com/miking-the-viking" target="_blank"><img title="miking-the-viking" src="https://github.com/miking-the-viking.png?size=48" width="48" height="48"></a><a href="https://github.com/nikitavoloboev" target="_blank"><img title="nikitavoloboev" src="https://github.com/nikitavoloboev.png?size=48" width="48" height="48"></a><a href="https://github.com/shaneosullivan" target="_blank"><img title="shaneosullivan" src="https://github.com/shaneosullivan.png?size=48" width="48" height="48"></a><a href="https://github.com/SuperSonicHub1" target="_blank"><img title="SuperSonicHub1" src="https://github.com/SuperSonicHub1.png?size=48" width="48" height="48"></a><a href="https://github.com/threepointone" target="_blank"><img title="threepointone" src="https://github.com/threepointone.png?size=48" width="48" height="48"></a><a href="https://github.com/uptonking" target="_blank"><img title="uptonking" src="https://github.com/uptonking.png?size=48" width="48" height="48"></a><a href="https://github.com/WonderPanda" target="_blank"><img title="WonderPanda" src="https://github.com/WonderPanda.png?size=48" width="48" height="48"></a></section><hr><p><a class="start" href="https://tinybase.org/guides/the-basics/getting-started/">Get started</a></p><p><a href="https://tinybase.org/demos/">Try the demos</a></p><p><a href="https://tinybase.org/api/store/interfaces/store/store/">Read the docs</a></p><hr><section id="about"><h2 id="about">About</h2><p>Modern apps deserve better. Why trade reactive user experiences to be able to use relational data? Or sacrifice features for bundle size? And why does the cloud do all the work <a href="https://localfirstweb.dev/" target="_blank">anyway</a>?</p><p>Building TinyBase was originally an interesting exercise for <a rel="me" href="https://tripleodeon.com">me</a> in API design, minification, and documentation. But now it has taken on a life of its own, and has grown beyond my wildest expectations.</p><p>It could not have been built without these great <a href="https://tinybase.org/guides/how-tinybase-is-built/credits/#giants">projects</a> and <a href="https://tinybase.org/guides/how-tinybase-is-built/credits/#and-friends">friends</a>, and I hope you enjoy using it as much as I do building it!</p></section><section id="story"><h2 id="the-story">The story</h2><a href="https://youtu.be/hXL7OkW-Prk?t=1232" target="_blank"><img src="https://tinybase.org/youtube.webp"></a></section>
250
+ <section><h2 id="did-we-say-tiny">Did we say tiny?</h2><p>If you use the basic <a href="https://tinybase.org/api/store/"><code>store</code></a> module alone, you&#x27;ll only add a gzipped <em>4.8kB</em> to your app. Incrementally add the other modules as you need more functionality, or get it all for <em>9.2kB</em>.</p><p>The optional <a href="https://tinybase.org/api/ui-react/"><code>ui-react</code></a> module is just another <em>3.9kB</em>, the auxiliary <a href="https://tinybase.org/api/tools/"><code>tools</code></a> module is <em>10.5kB</em>, and everything is super fast. Life&#x27;s easy when you have zero dependencies!</p><p>Read more about how TinyBase is structured and packaged in the <a href="https://tinybase.org/guides/how-tinybase-is-built/architecture/">Architecture</a> guide.</p></section><div class="table"><table class="fixed"><tbody><tr><th width="30%"> </th><th>.js.gz</th><th>.js</th><th>debug.js</th><th>.d.ts</th></tr><tr><th class="right"><a href="https://tinybase.org/api/store/">store</a></th><td>4.8kB</td><td>11.4kB</td><td>48.8kB</td><td>220.1kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/metrics/">metrics</a></th><td>1.8kB</td><td>3.6kB</td><td>15.2kB</td><td>30.9kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/indexes/">indexes</a></th><td>1.9kB</td><td>3.8kB</td><td>17.0kB</td><td>35.6kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/relationships/">relationships</a></th><td>1.9kB</td><td>3.7kB</td><td>17.1kB</td><td>44.2kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/queries/">queries</a></th><td>2.8kB</td><td>5.7kB</td><td>25.6kB</td><td>127.8kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/checkpoints/">checkpoints</a></th><td>1.5kB</td><td>3.1kB</td><td>12.4kB</td><td>33.3kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/persisters/">persisters</a></th><td>0.8kB</td><td>1.5kB</td><td>5.3kB</td><td>43.5kB</td></tr><tr><th class="right"><a href="https://tinybase.org/api/common/">common</a></th><td>0.1kB</td><td>0.1kB</td><td>0.1kB</td><td>3.5kB</td></tr><tr><th class="right">tinybase (all)</th><td>9.2kB</td><td>22.6kB</td><td>97.8kB</td><td>0.3kB</td></tr></tbody></table></div><section><h2 id="well-tested-and-documented">Well tested and documented.</h2><p>TinyBase has <em>100.0%</em> test coverage, including the code throughout the documentation - even on this page! The guides, demos, and API examples are designed to make it as easy as possible for you to get your TinyBase-powered app up and running.</p><p>Read more about how TinyBase is tested in the Unit <a href="https://tinybase.org/guides/how-tinybase-is-built/testing/">Testing</a> guide.</p></section><div class="table"><table class="fixed"><tbody><tr><th width="30%"> </th><th>Total</th><th>Tested</th><th>Coverage</th></tr><tr><th class="right">Lines</th><td>1,889</td><td>1,889</td><td>100.0%</td></tr><tr><th class="right">Statements</th><td>2,045</td><td>2,045</td><td>100.0%</td></tr><tr><th class="right">Functions</th><td>815</td><td>815</td><td>100.0%</td></tr><tr><th class="right">Branches</th><td>697</td><td>697</td><td>100.0%</td></tr><tr><th class="right">Tests</th><td colspan="3">3,403</td></tr><tr><th class="right">Assertions</th><td colspan="3">15,318</td></tr></tbody></table></div><hr><section id="sponsors"><h2 id="proud-to-be-sponsored-by">Proud to be sponsored by:</h2><a href="https://github.com/expo" target="_blank"><img title="expo" src="https://github.com/expo.png?size=48" width="48" height="48"></a><a href="https://github.com/cancelself" target="_blank"><img title="cancelself" src="https://github.com/cancelself.png?size=48" width="48" height="48"></a><a href="https://github.com/WonderPanda" target="_blank"><img title="WonderPanda" src="https://github.com/WonderPanda.png?size=48" width="48" height="48"></a><a href="https://github.com/arpitBhalla" target="_blank"><img title="arpitBhalla" src="https://github.com/arpitBhalla.png?size=48" width="48" height="48"></a></section><section id="users"><h2 id="excited-to-be-used-by">Excited to be used by:</h2><a href="https://github.com/Apocalypsor" target="_blank"><img title="Apocalypsor" src="https://github.com/Apocalypsor.png?size=48" width="48" height="48"></a><a href="https://github.com/brentvatne" target="_blank"><img title="brentvatne" src="https://github.com/brentvatne.png?size=48" width="48" height="48"></a><a href="https://github.com/circadian-risk" target="_blank"><img title="circadian-risk" src="https://github.com/circadian-risk.png?size=48" width="48" height="48"></a><a href="https://github.com/cubecull" target="_blank"><img title="cubecull" src="https://github.com/cubecull.png?size=48" width="48" height="48"></a><a href="https://github.com/erwinkn" target="_blank"><img title="erwinkn" src="https://github.com/erwinkn.png?size=48" width="48" height="48"></a><a href="https://github.com/expo" target="_blank"><img title="expo" src="https://github.com/expo.png?size=48" width="48" height="48"></a><a href="https://github.com/ezra-en" target="_blank"><img title="ezra-en" src="https://github.com/ezra-en.png?size=48" width="48" height="48"></a><a href="https://github.com/fdfontes" target="_blank"><img title="fdfontes" src="https://github.com/fdfontes.png?size=48" width="48" height="48"></a><a href="https://github.com/flaming-codes" target="_blank"><img title="flaming-codes" src="https://github.com/flaming-codes.png?size=48" width="48" height="48"></a><a href="https://github.com/generates" target="_blank"><img title="generates" src="https://github.com/generates.png?size=48" width="48" height="48"></a><a href="https://github.com/Giulio987" target="_blank"><img title="Giulio987" src="https://github.com/Giulio987.png?size=48" width="48" height="48"></a><a href="https://github.com/jaysc" target="_blank"><img title="jaysc" src="https://github.com/jaysc.png?size=48" width="48" height="48"></a><a href="https://github.com/Kayoo-asso" target="_blank"><img title="Kayoo-asso" src="https://github.com/Kayoo-asso.png?size=48" width="48" height="48"></a><a href="https://github.com/kotofurumiya" target="_blank"><img title="kotofurumiya" src="https://github.com/kotofurumiya.png?size=48" width="48" height="48"></a><a href="https://github.com/learn-anything" target="_blank"><img title="learn-anything" src="https://github.com/learn-anything.png?size=48" width="48" height="48"></a><a href="https://github.com/marksteve" target="_blank"><img title="marksteve" src="https://github.com/marksteve.png?size=48" width="48" height="48"></a><a href="https://github.com/miking-the-viking" target="_blank"><img title="miking-the-viking" src="https://github.com/miking-the-viking.png?size=48" width="48" height="48"></a><a href="https://github.com/nikitavoloboev" target="_blank"><img title="nikitavoloboev" src="https://github.com/nikitavoloboev.png?size=48" width="48" height="48"></a><a href="https://github.com/shaneosullivan" target="_blank"><img title="shaneosullivan" src="https://github.com/shaneosullivan.png?size=48" width="48" height="48"></a><a href="https://github.com/SuperSonicHub1" target="_blank"><img title="SuperSonicHub1" src="https://github.com/SuperSonicHub1.png?size=48" width="48" height="48"></a><a href="https://github.com/threepointone" target="_blank"><img title="threepointone" src="https://github.com/threepointone.png?size=48" width="48" height="48"></a><a href="https://github.com/uptonking" target="_blank"><img title="uptonking" src="https://github.com/uptonking.png?size=48" width="48" height="48"></a><a href="https://github.com/WonderPanda" target="_blank"><img title="WonderPanda" src="https://github.com/WonderPanda.png?size=48" width="48" height="48"></a></section><hr><p><a class="start" href="https://tinybase.org/guides/the-basics/getting-started/">Get started</a></p><p><a href="https://tinybase.org/demos/">Try the demos</a></p><p><a href="https://tinybase.org/api/store/interfaces/store/store/">Read the docs</a></p><hr><section id="about"><h2 id="about">About</h2><p>Modern apps deserve better. Why trade reactive user experiences to be able to use relational data? Or sacrifice features for bundle size? And why does the cloud do all the work <a href="https://localfirstweb.dev/" target="_blank">anyway</a>?</p><p>Building TinyBase was originally an interesting exercise for <a rel="me" href="https://tripleodeon.com">me</a> in API design, minification, and documentation. But now it has taken on a life of its own, and has grown beyond my wildest expectations.</p><p>It could not have been built without these great <a href="https://tinybase.org/guides/how-tinybase-is-built/credits/#giants">projects</a> and <a href="https://tinybase.org/guides/how-tinybase-is-built/credits/#and-friends">friends</a>, and I hope you enjoy using it as much as I do building it!</p></section><section id="story"><h2 id="the-story">The story</h2><a href="https://youtu.be/hXL7OkW-Prk?t=1232" target="_blank"><img src="https://tinybase.org/youtube.webp"></a></section>