diff --git a/Moon.png b/Moon.png deleted file mode 100644 index 823c5d1..0000000 Binary files a/Moon.png and /dev/null differ diff --git a/Moon.webp b/Moon.webp new file mode 100644 index 0000000..134adfa Binary files /dev/null and b/Moon.webp differ diff --git a/Sun.png b/Sun.png deleted file mode 100644 index 20ecd78..0000000 Binary files a/Sun.png and /dev/null differ diff --git a/Sun.webp b/Sun.webp new file mode 100644 index 0000000..eac271c Binary files /dev/null and b/Sun.webp differ diff --git a/assets/index-BYJLHoOV.js b/assets/index-Br5T5Mqw.js similarity index 99% rename from assets/index-BYJLHoOV.js rename to assets/index-Br5T5Mqw.js index 6879db3..51acbd6 100644 --- a/assets/index-BYJLHoOV.js +++ b/assets/index-Br5T5Mqw.js @@ -184,4 +184,4 @@ Error generating stack: `+i.message+` In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function Xb(e){if(typeof Symbol<"u"&&e[Symbol.iterator]!=null||e["@@iterator"]!=null)return Array.from(e)}function Zb(e){if(Array.isArray(e))return Xu(e)}function Lp(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter(function(o){return Object.getOwnPropertyDescriptor(e,o).enumerable})),n.push.apply(n,r)}return n}function Fp(e){for(var t=1;te.length)&&(t=e.length);for(var n=0,r=new Array(t);nn)return[!1,zp(n)];if(e.sizen)return[!1,zp(n)]}return[!0,null]}function dr(e){return e!=null}function a_(e){var t=e.files,n=e.accept,r=e.minSize,o=e.maxSize,i=e.multiple,s=e.maxFiles,a=e.validator;return!i&&t.length>1||i&&s>=1&&t.length>s?!1:t.every(function(f){var u=vy(f,n),p=Pi(u,1),h=p[0],w=gy(f,r,o),b=Pi(w,1),E=b[0],x=a?a(f):null;return h&&E&&!x})}function ys(e){return typeof e.isPropagationStopped=="function"?e.isPropagationStopped():typeof e.cancelBubble<"u"?e.cancelBubble:!1}function bl(e){return e.dataTransfer?Array.prototype.some.call(e.dataTransfer.types,function(t){return t==="Files"||t==="application/x-moz-file"}):!!e.target&&!!e.target.files}function Hp(e){e.preventDefault()}function u_(e){return e.indexOf("MSIE")!==-1||e.indexOf("Trident/")!==-1}function c_(e){return e.indexOf("Edge/")!==-1}function f_(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:window.navigator.userAgent;return u_(e)||c_(e)}function nn(){for(var e=arguments.length,t=new Array(e),n=0;n1?o-1:0),s=1;se.length)&&(t=e.length);for(var n=0,r=new Array(t);n=0)&&Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}function R_(e,t){if(e==null)return{};var n={},r=Object.keys(e),o,i;for(i=0;i=0)&&(n[o]=e[o]);return n}var df=y.forwardRef(function(e,t){var n=e.children,r=ws(e,g_),o=Ey(r),i=o.open,s=ws(o,y_);return y.useImperativeHandle(t,function(){return{open:i}},[i]),Kt.createElement(y.Fragment,null,n(Me(Me({},s),{},{open:i})))});df.displayName="Dropzone";var Sy={disabled:!1,getFilesFromEvent:$b,maxSize:1/0,minSize:0,multiple:!0,maxFiles:0,preventDropOnDocument:!0,noClick:!1,noKeyboard:!1,noDrag:!1,noDragEventsBubbling:!1,validator:null,useFsAccessApi:!0,autoFocus:!1};df.defaultProps=Sy;df.propTypes={children:be.func,accept:be.objectOf(be.arrayOf(be.string)),multiple:be.bool,preventDropOnDocument:be.bool,noClick:be.bool,noKeyboard:be.bool,noDrag:be.bool,noDragEventsBubbling:be.bool,minSize:be.number,maxSize:be.number,maxFiles:be.number,disabled:be.bool,getFilesFromEvent:be.func,onFileDialogCancel:be.func,onFileDialogOpen:be.func,useFsAccessApi:be.bool,autoFocus:be.bool,onDragEnter:be.func,onDragLeave:be.func,onDragOver:be.func,onDrop:be.func,onDropAccepted:be.func,onDropRejected:be.func,onError:be.func,validator:be.func};var ec={isFocused:!1,isFileDialogActive:!1,isDragActive:!1,isDragAccept:!1,isDragReject:!1,acceptedFiles:[],fileRejections:[]};function Ey(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=Me(Me({},Sy),e),n=t.accept,r=t.disabled,o=t.getFilesFromEvent,i=t.maxSize,s=t.minSize,a=t.multiple,f=t.maxFiles,u=t.onDragEnter,p=t.onDragLeave,h=t.onDragOver,w=t.onDrop,b=t.onDropAccepted,E=t.onDropRejected,x=t.onFileDialogCancel,P=t.onFileDialogOpen,v=t.useFsAccessApi,m=t.autoFocus,S=t.preventDropOnDocument,k=t.noClick,R=t.noKeyboard,A=t.noDrag,T=t.noDragEventsBubbling,j=t.onError,G=t.validator,F=y.useMemo(function(){return m_(n)},[n]),V=y.useMemo(function(){return p_(n)},[n]),U=y.useMemo(function(){return typeof P=="function"?P:Wp},[P]),H=y.useMemo(function(){return typeof x=="function"?x:Wp},[x]),B=y.useRef(null),Q=y.useRef(null),se=y.useReducer(N_,ec),J=Ha(se,2),I=J[0],z=J[1],ee=I.isFocused,oe=I.isFileDialogActive,ie=y.useRef(typeof window<"u"&&window.isSecureContext&&v&&d_()),Ve=function(){!ie.current&&oe&&setTimeout(function(){if(Q.current){var te=Q.current.files;te.length||(z({type:"closeDialog"}),H())}},300)};y.useEffect(function(){return window.addEventListener("focus",Ve,!1),function(){window.removeEventListener("focus",Ve,!1)}},[Q,oe,H,ie]);var he=y.useRef([]),ot=function(te){B.current&&B.current.contains(te.target)||(te.preventDefault(),he.current=[])};y.useEffect(function(){return S&&(document.addEventListener("dragover",Hp,!1),document.addEventListener("drop",ot,!1)),function(){S&&(document.removeEventListener("dragover",Hp),document.removeEventListener("drop",ot))}},[B,S]),y.useEffect(function(){return!r&&m&&B.current&&B.current.focus(),function(){}},[B,m,r]);var Ee=y.useCallback(function(W){j?j(W):console.error(W)},[j]),Y=y.useCallback(function(W){W.preventDefault(),W.persist(),Tn(W),he.current=[].concat(S_(he.current),[W.target]),bl(W)&&Promise.resolve(o(W)).then(function(te){if(!(ys(W)&&!T)){var Ae=te.length,Fe=Ae>0&&a_({files:te,accept:F,minSize:s,maxSize:i,multiple:a,maxFiles:f,validator:G}),et=Ae>0&&!Fe;z({isDragAccept:Fe,isDragReject:et,isDragActive:!0,type:"setDraggedFiles"}),u&&u(W)}}).catch(function(te){return Ee(te)})},[o,u,Ee,T,F,s,i,a,f,G]),we=y.useCallback(function(W){W.preventDefault(),W.persist(),Tn(W);var te=bl(W);if(te&&W.dataTransfer)try{W.dataTransfer.dropEffect="copy"}catch{}return te&&h&&h(W),!1},[h,T]),Le=y.useCallback(function(W){W.preventDefault(),W.persist(),Tn(W);var te=he.current.filter(function(Fe){return B.current&&B.current.contains(Fe)}),Ae=te.indexOf(W.target);Ae!==-1&&te.splice(Ae,1),he.current=te,!(te.length>0)&&(z({type:"setDraggedFiles",isDragActive:!1,isDragAccept:!1,isDragReject:!1}),bl(W)&&p&&p(W))},[B,p,T]),ve=y.useCallback(function(W,te){var Ae=[],Fe=[];W.forEach(function(et){var Mt=vy(et,F),St=Ha(Mt,2),Nr=St[0],Tr=St[1],Or=gy(et,s,i),Ar=Ha(Or,2),Ro=Ar[0],No=Ar[1],Mr=G?G(et):null;if(Nr&&Ro&&!Mr)Ae.push(et);else{var le=[Tr,No];Mr&&(le=le.concat(Mr)),Fe.push({file:et,errors:le.filter(function(zi){return zi})})}}),(!a&&Ae.length>1||a&&f>=1&&Ae.length>f)&&(Ae.forEach(function(et){Fe.push({file:et,errors:[s_]})}),Ae.splice(0)),z({acceptedFiles:Ae,fileRejections:Fe,type:"setFiles"}),w&&w(Ae,Fe,te),Fe.length>0&&E&&E(Fe,te),Ae.length>0&&b&&b(Ae,te)},[z,a,F,s,i,f,w,b,E,G]),me=y.useCallback(function(W){W.preventDefault(),W.persist(),Tn(W),he.current=[],bl(W)&&Promise.resolve(o(W)).then(function(te){ys(W)&&!T||ve(te,W)}).catch(function(te){return Ee(te)}),z({type:"reset"})},[o,ve,Ee,T]),de=y.useCallback(function(){if(ie.current){z({type:"openDialog"}),U();var W={multiple:a,types:V};window.showOpenFilePicker(W).then(function(te){return o(te)}).then(function(te){ve(te,null),z({type:"closeDialog"})}).catch(function(te){h_(te)?(H(te),z({type:"closeDialog"})):v_(te)?(ie.current=!1,Q.current?(Q.current.value=null,Q.current.click()):Ee(new Error("Cannot open the file picker because the https://developer.mozilla.org/en-US/docs/Web/API/File_System_Access_API is not supported and no was provided."))):Ee(te)});return}Q.current&&(z({type:"openDialog"}),U(),Q.current.value=null,Q.current.click())},[z,U,H,v,ve,Ee,V,a]),K=y.useCallback(function(W){!B.current||!B.current.isEqualNode(W.target)||(W.key===" "||W.key==="Enter"||W.keyCode===32||W.keyCode===13)&&(W.preventDefault(),de())},[B,de]),ce=y.useCallback(function(){z({type:"focus"})},[]),At=y.useCallback(function(){z({type:"blur"})},[]),Qe=y.useCallback(function(){k||(f_()?setTimeout(de,0):de())},[k,de]),Ye=function(te){return r?null:te},Nn=function(te){return R?null:Ye(te)},xe=function(te){return A?null:Ye(te)},Tn=function(te){T&&te.stopPropagation()},Fi=y.useMemo(function(){return function(){var W=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},te=W.refKey,Ae=te===void 0?"ref":te,Fe=W.role,et=W.onKeyDown,Mt=W.onFocus,St=W.onBlur,Nr=W.onClick,Tr=W.onDragEnter,Or=W.onDragOver,Ar=W.onDragLeave,Ro=W.onDrop,No=ws(W,w_);return Me(Me(Ju({onKeyDown:Nn(nn(et,K)),onFocus:Nn(nn(Mt,ce)),onBlur:Nn(nn(St,At)),onClick:Ye(nn(Nr,Qe)),onDragEnter:xe(nn(Tr,Y)),onDragOver:xe(nn(Or,we)),onDragLeave:xe(nn(Ar,Le)),onDrop:xe(nn(Ro,me)),role:typeof Fe=="string"&&Fe!==""?Fe:"presentation"},Ae,B),!r&&!R?{tabIndex:0}:{}),No)}},[B,K,ce,At,Qe,Y,we,Le,me,R,A,r]),Bt=y.useCallback(function(W){W.stopPropagation()},[]),Vs=y.useMemo(function(){return function(){var W=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},te=W.refKey,Ae=te===void 0?"ref":te,Fe=W.onChange,et=W.onClick,Mt=ws(W,x_),St=Ju({accept:F,multiple:a,type:"file",style:{display:"none"},onChange:Ye(nn(Fe,me)),onClick:Ye(nn(et,Bt)),tabIndex:-1},Ae,Q);return Me(Me({},St),Mt)}},[Q,n,a,me,r]);return Me(Me({},I),{},{isFocused:ee&&!r,getRootProps:Fi,getInputProps:Vs,rootRef:B,inputRef:Q,open:Ye(de)})}function N_(e,t){switch(t.type){case"focus":return Me(Me({},e),{},{isFocused:!0});case"blur":return Me(Me({},e),{},{isFocused:!1});case"openDialog":return Me(Me({},ec),{},{isFileDialogActive:!0});case"closeDialog":return Me(Me({},e),{},{isFileDialogActive:!1});case"setDraggedFiles":return Me(Me({},e),{},{isDragActive:t.isDragActive,isDragAccept:t.isDragAccept,isDragReject:t.isDragReject});case"setFiles":return Me(Me({},e),{},{acceptedFiles:t.acceptedFiles,fileRejections:t.fileRejections});case"reset":return Me({},ec);default:return e}}function Wp(){}const T_=["Bytes","KB","MB","GB","TB","PB","EB","ZB","YB"];function O_(e){if(e===0)return"0 Byte";const t=Math.floor(Math.log(e)/Math.log(1024)),n=T_[t];return`${(e/Math.pow(1024,t)).toFixed(2)} ${n}`}function A_({file:e}){return C.jsx(C.Fragment,{children:C.jsxs("li",{className:"flex w-full items-center justify-center gap-2 font-mono text-sm",title:e.name,children:[C.jsx("p",{className:"max-w-[250px] truncate",children:e.name}),C.jsx("span",{className:"text-xs font-semibold",children:O_(e.size)})]})})}function M_({errors:e}){return e?C.jsx(C.Fragment,{children:e.map(t=>{if(t.code!=="file-too-large")return C.jsxs("li",{className:"flex w-full items-center justify-center text-sm text-red-600",children:[C.jsx(mS,{className:"mr-2"}),t.message]},t.code)})}):C.jsxs("li",{className:"flex w-full items-center justify-center text-sm text-green-600",children:[C.jsx(pS,{className:"mr-2"}),"Uploaded successfully"]})}function j_(){const{loadDatabase:e,setTables:t,setSelectedTable:n,db:r}=ji(),[o,i]=y.useState(null),[s,a]=y.useState([]),f=y.useCallback(async(h,w)=>{if(a([]),t([]),n("0"),h.length>0){const b=h[0];i(b),await e(b)}if(w.length>0){const b=w.flatMap(E=>E.errors);a(b)}},[e,t,n]),{getRootProps:u,getInputProps:p}=Ey({onDrop:f,multiple:!1,accept:{"application/vnd.sqlite3":[".sqlite",".sqlite3"],"application/x-sqlite3":[".sqlite",".sqlite3"],"application/octet-stream":[".db"],"application/sql":[".sql"]}});return C.jsxs("section",{children:[r?C.jsxs("div",{...u(),className:"border p-6 rounded cursor-pointer text-center",children:[C.jsx("input",{...p()}),C.jsx("p",{className:"hidden sm:block",children:"Drag drop a SQLite file here, or click to select one"}),C.jsx("p",{className:"block sm:hidden",children:"Click to select a SQLite file"})]}):C.jsxs("div",{...u(),className:"border p-6 py-24 rounded cursor-pointer text-center",children:[C.jsx("input",{...p()}),C.jsx("p",{className:"hidden sm:block",children:"Drag drop a SQLite file here, or click to select one"}),C.jsx("p",{className:"block sm:hidden",children:"Click to select a SQLite file"}),C.jsx("a",{href:"https://github.com/vwh/sqlite-viewer/raw/main/examples/chinook.db",className:"text-sm text-link hover:underline",title:"Download sample file",children:"Or download & try this sample file"})]}),C.jsxs("div",{className:"my-2",children:[o&&C.jsx(A_,{file:o}),C.jsx(M_,{errors:s})]})]})}function D_(){const{isLoading:e}=ji();return C.jsx(C.Fragment,{children:e&&C.jsxs("div",{className:"flex items-center justify-center mb-2 font-semibold p-4 border rounded",children:[C.jsx(yS,{className:"w-5 h-5 animate-spin"}),C.jsx("span",{className:"ml-2",children:"Reading SQLite file"})]})})}function I_(){const{db:e,tables:t,isLoading:n}=ji();return C.jsxs("div",{className:"flex flex-col gap-2",children:[!e&&C.jsx("section",{className:"flex justify-center border rounded py-2",children:C.jsxs("div",{className:"flex flex-col items-center gap-2",children:[C.jsx("img",{id:"logo",title:"SQLite Logo",src:"https://raw.githubusercontent.com/vwh/sqlite-viewer/main/public/logo.webp",alt:"SQLite Logo",className:"h-20"}),C.jsx("p",{className:"text-sm",children:"View SQLite file online"})]})}),C.jsx(j_,{}),C.jsx(D_,{}),!n&&e&&(t.length>0?C.jsx(Ob,{}):C.jsx("p",{className:"text-center font-semibold md:text-3xl p-20 border rounded mb-2",children:"Your database is empty, no tables found"}))]})}function L_(){const[e,t]=y.useState(!1);y.useEffect(()=>{const r=localStorage.getItem("darkMode")==="true";t(r),document.body.classList.toggle("dark",r)},[]);const n=()=>{const r=!e;t(r),localStorage.setItem("darkMode",r.toString()),document.body.classList.toggle("dark",r)};return C.jsx("button",{onClick:n,className:"relative",children:e?C.jsx("img",{src:"./Sun.png",className:"transition-transform transform scale-75 dark:scale-100 duration-500 ease-in-out bg-white display-inline-block rounded-full h-6 w-6 p-1 shadow-sm",alt:"Sun Icon",width:24,height:24}):C.jsx("img",{src:"./Moon.png",className:"transition-transform transform scale-75 dark:scale-100 duration-500 ease-in-out",alt:"Moon Icon",width:24,height:24})})}function F_(){return C.jsxs("footer",{className:"z-[100] flex items-center justify-between",children:[C.jsxs("div",{children:[C.jsx("p",{className:"hidden sm:block text-xs mt-2",children:"No file will be uploaded to server. using JavaScript, sql.js"}),C.jsx("p",{className:"block sm:hidden text-xs mt-2",children:"No file will be uploaded to server."}),C.jsxs("a",{href:"https://github.com/vwh/sqlite-viewer",target:"_blank",className:"text-sm text-link hover:underline flex gap-1 items-center",title:"Star on GitHub",children:[C.jsx(hS,{className:"h-4 w-4 mt-1"}),C.jsx("span",{children:"Star this project on GitHub"})]})]}),C.jsx(L_,{})]})}Ba.createRoot(document.getElementById("root")).render(C.jsx(Kt.StrictMode,{children:C.jsxs("main",{className:"container mx-auto p-4",children:[C.jsx(I_,{}),C.jsx(F_,{})]})})); +In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function xy(e,t){if(e){if(typeof e=="string")return Zu(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);if(n==="Object"&&e.constructor&&(n=e.constructor.name),n==="Map"||n==="Set")return Array.from(e);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return Zu(e,t)}}function Zu(e,t){(t==null||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n=0)&&Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}function R_(e,t){if(e==null)return{};var n={},r=Object.keys(e),o,i;for(i=0;i=0)&&(n[o]=e[o]);return n}var df=y.forwardRef(function(e,t){var n=e.children,r=ws(e,g_),o=Ey(r),i=o.open,s=ws(o,y_);return y.useImperativeHandle(t,function(){return{open:i}},[i]),Kt.createElement(y.Fragment,null,n(Me(Me({},s),{},{open:i})))});df.displayName="Dropzone";var Sy={disabled:!1,getFilesFromEvent:$b,maxSize:1/0,minSize:0,multiple:!0,maxFiles:0,preventDropOnDocument:!0,noClick:!1,noKeyboard:!1,noDrag:!1,noDragEventsBubbling:!1,validator:null,useFsAccessApi:!0,autoFocus:!1};df.defaultProps=Sy;df.propTypes={children:be.func,accept:be.objectOf(be.arrayOf(be.string)),multiple:be.bool,preventDropOnDocument:be.bool,noClick:be.bool,noKeyboard:be.bool,noDrag:be.bool,noDragEventsBubbling:be.bool,minSize:be.number,maxSize:be.number,maxFiles:be.number,disabled:be.bool,getFilesFromEvent:be.func,onFileDialogCancel:be.func,onFileDialogOpen:be.func,useFsAccessApi:be.bool,autoFocus:be.bool,onDragEnter:be.func,onDragLeave:be.func,onDragOver:be.func,onDrop:be.func,onDropAccepted:be.func,onDropRejected:be.func,onError:be.func,validator:be.func};var ec={isFocused:!1,isFileDialogActive:!1,isDragActive:!1,isDragAccept:!1,isDragReject:!1,acceptedFiles:[],fileRejections:[]};function Ey(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=Me(Me({},Sy),e),n=t.accept,r=t.disabled,o=t.getFilesFromEvent,i=t.maxSize,s=t.minSize,a=t.multiple,f=t.maxFiles,u=t.onDragEnter,p=t.onDragLeave,h=t.onDragOver,w=t.onDrop,b=t.onDropAccepted,E=t.onDropRejected,x=t.onFileDialogCancel,P=t.onFileDialogOpen,v=t.useFsAccessApi,m=t.autoFocus,S=t.preventDropOnDocument,k=t.noClick,R=t.noKeyboard,A=t.noDrag,T=t.noDragEventsBubbling,j=t.onError,G=t.validator,F=y.useMemo(function(){return m_(n)},[n]),V=y.useMemo(function(){return p_(n)},[n]),U=y.useMemo(function(){return typeof P=="function"?P:Wp},[P]),H=y.useMemo(function(){return typeof x=="function"?x:Wp},[x]),B=y.useRef(null),Q=y.useRef(null),se=y.useReducer(N_,ec),J=Ha(se,2),I=J[0],z=J[1],ee=I.isFocused,oe=I.isFileDialogActive,ie=y.useRef(typeof window<"u"&&window.isSecureContext&&v&&d_()),Ve=function(){!ie.current&&oe&&setTimeout(function(){if(Q.current){var te=Q.current.files;te.length||(z({type:"closeDialog"}),H())}},300)};y.useEffect(function(){return window.addEventListener("focus",Ve,!1),function(){window.removeEventListener("focus",Ve,!1)}},[Q,oe,H,ie]);var he=y.useRef([]),ot=function(te){B.current&&B.current.contains(te.target)||(te.preventDefault(),he.current=[])};y.useEffect(function(){return S&&(document.addEventListener("dragover",Hp,!1),document.addEventListener("drop",ot,!1)),function(){S&&(document.removeEventListener("dragover",Hp),document.removeEventListener("drop",ot))}},[B,S]),y.useEffect(function(){return!r&&m&&B.current&&B.current.focus(),function(){}},[B,m,r]);var Ee=y.useCallback(function(W){j?j(W):console.error(W)},[j]),Y=y.useCallback(function(W){W.preventDefault(),W.persist(),Tn(W),he.current=[].concat(S_(he.current),[W.target]),bl(W)&&Promise.resolve(o(W)).then(function(te){if(!(ys(W)&&!T)){var Ae=te.length,Fe=Ae>0&&a_({files:te,accept:F,minSize:s,maxSize:i,multiple:a,maxFiles:f,validator:G}),et=Ae>0&&!Fe;z({isDragAccept:Fe,isDragReject:et,isDragActive:!0,type:"setDraggedFiles"}),u&&u(W)}}).catch(function(te){return Ee(te)})},[o,u,Ee,T,F,s,i,a,f,G]),we=y.useCallback(function(W){W.preventDefault(),W.persist(),Tn(W);var te=bl(W);if(te&&W.dataTransfer)try{W.dataTransfer.dropEffect="copy"}catch{}return te&&h&&h(W),!1},[h,T]),Le=y.useCallback(function(W){W.preventDefault(),W.persist(),Tn(W);var te=he.current.filter(function(Fe){return B.current&&B.current.contains(Fe)}),Ae=te.indexOf(W.target);Ae!==-1&&te.splice(Ae,1),he.current=te,!(te.length>0)&&(z({type:"setDraggedFiles",isDragActive:!1,isDragAccept:!1,isDragReject:!1}),bl(W)&&p&&p(W))},[B,p,T]),ve=y.useCallback(function(W,te){var Ae=[],Fe=[];W.forEach(function(et){var Mt=vy(et,F),St=Ha(Mt,2),Nr=St[0],Tr=St[1],Or=gy(et,s,i),Ar=Ha(Or,2),Ro=Ar[0],No=Ar[1],Mr=G?G(et):null;if(Nr&&Ro&&!Mr)Ae.push(et);else{var le=[Tr,No];Mr&&(le=le.concat(Mr)),Fe.push({file:et,errors:le.filter(function(zi){return zi})})}}),(!a&&Ae.length>1||a&&f>=1&&Ae.length>f)&&(Ae.forEach(function(et){Fe.push({file:et,errors:[s_]})}),Ae.splice(0)),z({acceptedFiles:Ae,fileRejections:Fe,type:"setFiles"}),w&&w(Ae,Fe,te),Fe.length>0&&E&&E(Fe,te),Ae.length>0&&b&&b(Ae,te)},[z,a,F,s,i,f,w,b,E,G]),me=y.useCallback(function(W){W.preventDefault(),W.persist(),Tn(W),he.current=[],bl(W)&&Promise.resolve(o(W)).then(function(te){ys(W)&&!T||ve(te,W)}).catch(function(te){return Ee(te)}),z({type:"reset"})},[o,ve,Ee,T]),de=y.useCallback(function(){if(ie.current){z({type:"openDialog"}),U();var W={multiple:a,types:V};window.showOpenFilePicker(W).then(function(te){return o(te)}).then(function(te){ve(te,null),z({type:"closeDialog"})}).catch(function(te){h_(te)?(H(te),z({type:"closeDialog"})):v_(te)?(ie.current=!1,Q.current?(Q.current.value=null,Q.current.click()):Ee(new Error("Cannot open the file picker because the https://developer.mozilla.org/en-US/docs/Web/API/File_System_Access_API is not supported and no was provided."))):Ee(te)});return}Q.current&&(z({type:"openDialog"}),U(),Q.current.value=null,Q.current.click())},[z,U,H,v,ve,Ee,V,a]),K=y.useCallback(function(W){!B.current||!B.current.isEqualNode(W.target)||(W.key===" "||W.key==="Enter"||W.keyCode===32||W.keyCode===13)&&(W.preventDefault(),de())},[B,de]),ce=y.useCallback(function(){z({type:"focus"})},[]),At=y.useCallback(function(){z({type:"blur"})},[]),Qe=y.useCallback(function(){k||(f_()?setTimeout(de,0):de())},[k,de]),Ye=function(te){return r?null:te},Nn=function(te){return R?null:Ye(te)},xe=function(te){return A?null:Ye(te)},Tn=function(te){T&&te.stopPropagation()},Fi=y.useMemo(function(){return function(){var W=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},te=W.refKey,Ae=te===void 0?"ref":te,Fe=W.role,et=W.onKeyDown,Mt=W.onFocus,St=W.onBlur,Nr=W.onClick,Tr=W.onDragEnter,Or=W.onDragOver,Ar=W.onDragLeave,Ro=W.onDrop,No=ws(W,w_);return Me(Me(Ju({onKeyDown:Nn(nn(et,K)),onFocus:Nn(nn(Mt,ce)),onBlur:Nn(nn(St,At)),onClick:Ye(nn(Nr,Qe)),onDragEnter:xe(nn(Tr,Y)),onDragOver:xe(nn(Or,we)),onDragLeave:xe(nn(Ar,Le)),onDrop:xe(nn(Ro,me)),role:typeof Fe=="string"&&Fe!==""?Fe:"presentation"},Ae,B),!r&&!R?{tabIndex:0}:{}),No)}},[B,K,ce,At,Qe,Y,we,Le,me,R,A,r]),Bt=y.useCallback(function(W){W.stopPropagation()},[]),Vs=y.useMemo(function(){return function(){var W=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},te=W.refKey,Ae=te===void 0?"ref":te,Fe=W.onChange,et=W.onClick,Mt=ws(W,x_),St=Ju({accept:F,multiple:a,type:"file",style:{display:"none"},onChange:Ye(nn(Fe,me)),onClick:Ye(nn(et,Bt)),tabIndex:-1},Ae,Q);return Me(Me({},St),Mt)}},[Q,n,a,me,r]);return Me(Me({},I),{},{isFocused:ee&&!r,getRootProps:Fi,getInputProps:Vs,rootRef:B,inputRef:Q,open:Ye(de)})}function N_(e,t){switch(t.type){case"focus":return Me(Me({},e),{},{isFocused:!0});case"blur":return Me(Me({},e),{},{isFocused:!1});case"openDialog":return Me(Me({},ec),{},{isFileDialogActive:!0});case"closeDialog":return Me(Me({},e),{},{isFileDialogActive:!1});case"setDraggedFiles":return Me(Me({},e),{},{isDragActive:t.isDragActive,isDragAccept:t.isDragAccept,isDragReject:t.isDragReject});case"setFiles":return Me(Me({},e),{},{acceptedFiles:t.acceptedFiles,fileRejections:t.fileRejections});case"reset":return Me({},ec);default:return e}}function Wp(){}const T_=["Bytes","KB","MB","GB","TB","PB","EB","ZB","YB"];function O_(e){if(e===0)return"0 Byte";const t=Math.floor(Math.log(e)/Math.log(1024)),n=T_[t];return`${(e/Math.pow(1024,t)).toFixed(2)} ${n}`}function A_({file:e}){return C.jsx(C.Fragment,{children:C.jsxs("li",{className:"flex w-full items-center justify-center gap-2 font-mono text-sm",title:e.name,children:[C.jsx("p",{className:"max-w-[250px] truncate",children:e.name}),C.jsx("span",{className:"text-xs font-semibold",children:O_(e.size)})]})})}function M_({errors:e}){return e?C.jsx(C.Fragment,{children:e.map(t=>{if(t.code!=="file-too-large")return C.jsxs("li",{className:"flex w-full items-center justify-center text-sm text-red-600",children:[C.jsx(mS,{className:"mr-2"}),t.message]},t.code)})}):C.jsxs("li",{className:"flex w-full items-center justify-center text-sm text-green-600",children:[C.jsx(pS,{className:"mr-2"}),"Uploaded successfully"]})}function j_(){const{loadDatabase:e,setTables:t,setSelectedTable:n,db:r}=ji(),[o,i]=y.useState(null),[s,a]=y.useState([]),f=y.useCallback(async(h,w)=>{if(a([]),t([]),n("0"),h.length>0){const b=h[0];i(b),await e(b)}if(w.length>0){const b=w.flatMap(E=>E.errors);a(b)}},[e,t,n]),{getRootProps:u,getInputProps:p}=Ey({onDrop:f,multiple:!1,accept:{"application/vnd.sqlite3":[".sqlite",".sqlite3"],"application/x-sqlite3":[".sqlite",".sqlite3"],"application/octet-stream":[".db"],"application/sql":[".sql"]}});return C.jsxs("section",{children:[r?C.jsxs("div",{...u(),className:"border p-6 rounded cursor-pointer text-center",children:[C.jsx("input",{...p()}),C.jsx("p",{className:"hidden sm:block",children:"Drag drop a SQLite file here, or click to select one"}),C.jsx("p",{className:"block sm:hidden",children:"Click to select a SQLite file"})]}):C.jsxs("div",{...u(),className:"border p-6 py-24 rounded cursor-pointer text-center",children:[C.jsx("input",{...p()}),C.jsx("p",{className:"hidden sm:block",children:"Drag drop a SQLite file here, or click to select one"}),C.jsx("p",{className:"block sm:hidden",children:"Click to select a SQLite file"}),C.jsx("a",{href:"https://github.com/vwh/sqlite-viewer/raw/main/examples/chinook.db",className:"text-sm text-link hover:underline",title:"Download sample file",children:"Or download & try this sample file"})]}),C.jsxs("div",{className:"my-2",children:[o&&C.jsx(A_,{file:o}),C.jsx(M_,{errors:s})]})]})}function D_(){const{isLoading:e}=ji();return C.jsx(C.Fragment,{children:e&&C.jsxs("div",{className:"flex items-center justify-center mb-2 font-semibold p-4 border rounded",children:[C.jsx(yS,{className:"w-5 h-5 animate-spin"}),C.jsx("span",{className:"ml-2",children:"Reading SQLite file"})]})})}function I_(){const{db:e,tables:t,isLoading:n}=ji();return C.jsxs("div",{className:"flex flex-col gap-2",children:[!e&&C.jsx("section",{className:"flex justify-center border rounded py-2",children:C.jsxs("div",{className:"flex flex-col items-center gap-2",children:[C.jsx("img",{id:"logo",title:"SQLite Logo",src:"https://raw.githubusercontent.com/vwh/sqlite-viewer/main/public/logo.webp",alt:"SQLite Logo",width:"160",height:"80",className:"h-20"}),C.jsx("p",{className:"text-sm",children:"View SQLite file online"})]})}),C.jsx(j_,{}),C.jsx(D_,{}),!n&&e&&(t.length>0?C.jsx(Ob,{}):C.jsx("p",{className:"text-center font-semibold md:text-3xl p-20 border rounded mb-2",children:"Your database is empty, no tables found"}))]})}function L_(){const[e,t]=y.useState(!1);y.useEffect(()=>{const r=localStorage.getItem("darkMode")==="true";t(r),document.body.classList.toggle("dark",r)},[]);const n=()=>{const r=!e;t(r),localStorage.setItem("darkMode",r.toString()),document.body.classList.toggle("dark",r)};return C.jsx("button",{onClick:n,className:"relative",children:e?C.jsx("img",{src:"./Sun.webp",className:"transition-transform transform scale-75 dark:scale-100 duration-500 ease-in-out bg-white display-inline-block rounded-full h-6 w-6 p-1 shadow-sm",alt:"Sun Icon",width:24,height:24}):C.jsx("img",{src:"./Moon.webp",className:"transition-transform transform scale-75 dark:scale-100 duration-500 ease-in-out",alt:"Moon Icon",width:24,height:24})})}function F_(){return C.jsxs("footer",{className:"z-[100] flex items-center justify-between",children:[C.jsxs("div",{children:[C.jsx("p",{className:"hidden sm:block text-xs mt-2",children:"No file will be uploaded to server. using JavaScript, sql.js"}),C.jsx("p",{className:"block sm:hidden text-xs mt-2",children:"No file will be uploaded to server."}),C.jsxs("a",{href:"https://github.com/vwh/sqlite-viewer",target:"_blank",className:"text-sm text-link hover:underline flex gap-1 items-center",title:"Star on GitHub",children:[C.jsx(hS,{className:"h-4 w-4 mt-1"}),C.jsx("span",{children:"Star this project on GitHub"})]})]}),C.jsx(L_,{})]})}Ba.createRoot(document.getElementById("root")).render(C.jsx(Kt.StrictMode,{children:C.jsxs("main",{className:"container mx-auto p-4",children:[C.jsx(I_,{}),C.jsx(F_,{})]})})); diff --git a/index.html b/index.html index 757326d..e3ebe48 100644 --- a/index.html +++ b/index.html @@ -8,6 +8,11 @@ SQLite Viewer + @@ -41,13 +46,24 @@ /> - - + - + + diff --git a/logo.webp b/logo.webp index 4754f62..fd4eaeb 100644 Binary files a/logo.webp and b/logo.webp differ diff --git a/sw.js b/sw.js index 24143b7..ce664ef 100644 --- a/sw.js +++ b/sw.js @@ -1 +1 @@ -if(!self.define){let e,i={};const n=(n,s)=>(n=new URL(n+".js",s).href,i[n]||new Promise((i=>{if("document"in self){const e=document.createElement("script");e.src=n,e.onload=i,document.head.appendChild(e)}else e=n,importScripts(n),i()})).then((()=>{let e=i[n];if(!e)throw new Error(`Module ${n} didn’t register its module`);return e})));self.define=(s,r)=>{const o=e||("document"in self?document.currentScript.src:"")||location.href;if(i[o])return;let t={};const d=e=>n(e,o),l={module:{uri:o},exports:t,require:d};i[o]=Promise.all(s.map((e=>l[e]||d(e)))).then((e=>(r(...e),t)))}}define(["./workbox-3e911b1d"],(function(e){"use strict";self.skipWaiting(),e.clientsClaim(),e.precacheAndRoute([{url:"assets/index-Bj9HezKS.css",revision:null},{url:"assets/index-BYJLHoOV.js",revision:null},{url:"index.html",revision:"2c078324e5021d8d75d0d1f1da48c85f"},{url:"registerSW.js",revision:"8699135f2a62c6f7ce78f94540a14187"},{url:"icon512_maskable.png",revision:"3d290f6a5aaab33e10193a7ae6363fdc"},{url:"icon512_rounded.png",revision:"b106306874aab167a6e6fca03440dcfb"},{url:"manifest.webmanifest",revision:"83841d3496ce43885f1032b29835f60e"}],{}),e.cleanupOutdatedCaches(),e.registerRoute(new e.NavigationRoute(e.createHandlerBoundToURL("index.html")))})); +if(!self.define){let e,i={};const n=(n,s)=>(n=new URL(n+".js",s).href,i[n]||new Promise((i=>{if("document"in self){const e=document.createElement("script");e.src=n,e.onload=i,document.head.appendChild(e)}else e=n,importScripts(n),i()})).then((()=>{let e=i[n];if(!e)throw new Error(`Module ${n} didn’t register its module`);return e})));self.define=(s,r)=>{const o=e||("document"in self?document.currentScript.src:"")||location.href;if(i[o])return;let t={};const l=e=>n(e,o),d={module:{uri:o},exports:t,require:l};i[o]=Promise.all(s.map((e=>d[e]||l(e)))).then((e=>(r(...e),t)))}}define(["./workbox-3e911b1d"],(function(e){"use strict";self.skipWaiting(),e.clientsClaim(),e.precacheAndRoute([{url:"assets/index-Bj9HezKS.css",revision:null},{url:"assets/index-Br5T5Mqw.js",revision:null},{url:"index.html",revision:"ca25ed7ada187ef8fd1e59d39415c955"},{url:"registerSW.js",revision:"8699135f2a62c6f7ce78f94540a14187"},{url:"icon512_maskable.png",revision:"3d290f6a5aaab33e10193a7ae6363fdc"},{url:"icon512_rounded.png",revision:"b106306874aab167a6e6fca03440dcfb"},{url:"manifest.webmanifest",revision:"83841d3496ce43885f1032b29835f60e"}],{}),e.cleanupOutdatedCaches(),e.registerRoute(new e.NavigationRoute(e.createHandlerBoundToURL("index.html")))}));