diff --git a/api/assets/main.js b/api/assets/main.js index 1daeb690..d6f13886 100644 --- a/api/assets/main.js +++ b/api/assets/main.js @@ -1,7 +1,7 @@ "use strict"; "use strict";(()=>{var Ce=Object.create;var ne=Object.defineProperty;var Pe=Object.getOwnPropertyDescriptor;var Oe=Object.getOwnPropertyNames;var _e=Object.getPrototypeOf,Re=Object.prototype.hasOwnProperty;var Me=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var Fe=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Oe(e))!Re.call(t,i)&&i!==n&&ne(t,i,{get:()=>e[i],enumerable:!(r=Pe(e,i))||r.enumerable});return t};var De=(t,e,n)=>(n=t!=null?Ce(_e(t)):{},Fe(e||!t||!t.__esModule?ne(n,"default",{value:t,enumerable:!0}):n,t));var ae=Me((se,oe)=>{(function(){var t=function(e){var n=new t.Builder;return n.pipeline.add(t.trimmer,t.stopWordFilter,t.stemmer),n.searchPipeline.add(t.stemmer),e.call(n,n),n.build()};t.version="2.3.9";t.utils={},t.utils.warn=function(e){return function(n){e.console&&console.warn&&console.warn(n)}}(this),t.utils.asString=function(e){return e==null?"":e.toString()},t.utils.clone=function(e){if(e==null)return e;for(var n=Object.create(null),r=Object.keys(e),i=0;i0){var d=t.utils.clone(n)||{};d.position=[a,u],d.index=s.length,s.push(new t.Token(r.slice(a,o),d))}a=o+1}}return s},t.tokenizer.separator=/[\s\-]+/;t.Pipeline=function(){this._stack=[]},t.Pipeline.registeredFunctions=Object.create(null),t.Pipeline.registerFunction=function(e,n){n in this.registeredFunctions&&t.utils.warn("Overwriting existing registered function: "+n),e.label=n,t.Pipeline.registeredFunctions[e.label]=e},t.Pipeline.warnIfFunctionNotRegistered=function(e){var n=e.label&&e.label in this.registeredFunctions;n||t.utils.warn(`Function is not registered with pipeline. This may cause problems when serialising the index. -`,e)},t.Pipeline.load=function(e){var n=new t.Pipeline;return e.forEach(function(r){var i=t.Pipeline.registeredFunctions[r];if(i)n.add(i);else throw new Error("Cannot load unregistered function: "+r)}),n},t.Pipeline.prototype.add=function(){var e=Array.prototype.slice.call(arguments);e.forEach(function(n){t.Pipeline.warnIfFunctionNotRegistered(n),this._stack.push(n)},this)},t.Pipeline.prototype.after=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var r=this._stack.indexOf(e);if(r==-1)throw new Error("Cannot find existingFn");r=r+1,this._stack.splice(r,0,n)},t.Pipeline.prototype.before=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var r=this._stack.indexOf(e);if(r==-1)throw new Error("Cannot find existingFn");this._stack.splice(r,0,n)},t.Pipeline.prototype.remove=function(e){var n=this._stack.indexOf(e);n!=-1&&this._stack.splice(n,1)},t.Pipeline.prototype.run=function(e){for(var n=this._stack.length,r=0;r1&&(oe&&(r=s),o!=e);)i=r-n,s=n+Math.floor(i/2),o=this.elements[s*2];if(o==e||o>e)return s*2;if(ol?d+=2:a==l&&(n+=r[u+1]*i[d+1],u+=2,d+=2);return n},t.Vector.prototype.similarity=function(e){return this.dot(e)/this.magnitude()||0},t.Vector.prototype.toArray=function(){for(var e=new Array(this.elements.length/2),n=1,r=0;n0){var o=s.str.charAt(0),a;o in s.node.edges?a=s.node.edges[o]:(a=new t.TokenSet,s.node.edges[o]=a),s.str.length==1&&(a.final=!0),i.push({node:a,editsRemaining:s.editsRemaining,str:s.str.slice(1)})}if(s.editsRemaining!=0){if("*"in s.node.edges)var l=s.node.edges["*"];else{var l=new t.TokenSet;s.node.edges["*"]=l}if(s.str.length==0&&(l.final=!0),i.push({node:l,editsRemaining:s.editsRemaining-1,str:s.str}),s.str.length>1&&i.push({node:s.node,editsRemaining:s.editsRemaining-1,str:s.str.slice(1)}),s.str.length==1&&(s.node.final=!0),s.str.length>=1){if("*"in s.node.edges)var u=s.node.edges["*"];else{var u=new t.TokenSet;s.node.edges["*"]=u}s.str.length==1&&(u.final=!0),i.push({node:u,editsRemaining:s.editsRemaining-1,str:s.str.slice(1)})}if(s.str.length>1){var d=s.str.charAt(0),y=s.str.charAt(1),p;y in s.node.edges?p=s.node.edges[y]:(p=new t.TokenSet,s.node.edges[y]=p),s.str.length==1&&(p.final=!0),i.push({node:p,editsRemaining:s.editsRemaining-1,str:d+s.str.slice(2)})}}}return r},t.TokenSet.fromString=function(e){for(var n=new t.TokenSet,r=n,i=0,s=e.length;i=e;n--){var r=this.uncheckedNodes[n],i=r.child.toString();i in this.minimizedNodes?r.parent.edges[r.char]=this.minimizedNodes[i]:(r.child._str=i,this.minimizedNodes[i]=r.child),this.uncheckedNodes.pop()}};t.Index=function(e){this.invertedIndex=e.invertedIndex,this.fieldVectors=e.fieldVectors,this.tokenSet=e.tokenSet,this.fields=e.fields,this.pipeline=e.pipeline},t.Index.prototype.search=function(e){return this.query(function(n){var r=new t.QueryParser(e,n);r.parse()})},t.Index.prototype.query=function(e){for(var n=new t.Query(this.fields),r=Object.create(null),i=Object.create(null),s=Object.create(null),o=Object.create(null),a=Object.create(null),l=0;l1?this._b=1:this._b=e},t.Builder.prototype.k1=function(e){this._k1=e},t.Builder.prototype.add=function(e,n){var r=e[this._ref],i=Object.keys(this._fields);this._documents[r]=n||{},this.documentCount+=1;for(var s=0;s=this.length)return t.QueryLexer.EOS;var e=this.str.charAt(this.pos);return this.pos+=1,e},t.QueryLexer.prototype.width=function(){return this.pos-this.start},t.QueryLexer.prototype.ignore=function(){this.start==this.pos&&(this.pos+=1),this.start=this.pos},t.QueryLexer.prototype.backup=function(){this.pos-=1},t.QueryLexer.prototype.acceptDigitRun=function(){var e,n;do e=this.next(),n=e.charCodeAt(0);while(n>47&&n<58);e!=t.QueryLexer.EOS&&this.backup()},t.QueryLexer.prototype.more=function(){return this.pos1&&(e.backup(),e.emit(t.QueryLexer.TERM)),e.ignore(),e.more())return t.QueryLexer.lexText},t.QueryLexer.lexEditDistance=function(e){return e.ignore(),e.acceptDigitRun(),e.emit(t.QueryLexer.EDIT_DISTANCE),t.QueryLexer.lexText},t.QueryLexer.lexBoost=function(e){return e.ignore(),e.acceptDigitRun(),e.emit(t.QueryLexer.BOOST),t.QueryLexer.lexText},t.QueryLexer.lexEOS=function(e){e.width()>0&&e.emit(t.QueryLexer.TERM)},t.QueryLexer.termSeparator=t.tokenizer.separator,t.QueryLexer.lexText=function(e){for(;;){var n=e.next();if(n==t.QueryLexer.EOS)return t.QueryLexer.lexEOS;if(n.charCodeAt(0)==92){e.escapeCharacter();continue}if(n==":")return t.QueryLexer.lexField;if(n=="~")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexEditDistance;if(n=="^")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexBoost;if(n=="+"&&e.width()===1||n=="-"&&e.width()===1)return e.emit(t.QueryLexer.PRESENCE),t.QueryLexer.lexText;if(n.match(t.QueryLexer.termSeparator))return t.QueryLexer.lexTerm}},t.QueryParser=function(e,n){this.lexer=new t.QueryLexer(e),this.query=n,this.currentClause={},this.lexemeIdx=0},t.QueryParser.prototype.parse=function(){this.lexer.run(),this.lexemes=this.lexer.lexemes;for(var e=t.QueryParser.parseClause;e;)e=e(this);return this.query},t.QueryParser.prototype.peekLexeme=function(){return this.lexemes[this.lexemeIdx]},t.QueryParser.prototype.consumeLexeme=function(){var e=this.peekLexeme();return this.lexemeIdx+=1,e},t.QueryParser.prototype.nextClause=function(){var e=this.currentClause;this.query.clause(e),this.currentClause={}},t.QueryParser.parseClause=function(e){var n=e.peekLexeme();if(n!=null)switch(n.type){case t.QueryLexer.PRESENCE:return t.QueryParser.parsePresence;case t.QueryLexer.FIELD:return t.QueryParser.parseField;case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var r="expected either a field or a term, found "+n.type;throw n.str.length>=1&&(r+=" with value '"+n.str+"'"),new t.QueryParseError(r,n.start,n.end)}},t.QueryParser.parsePresence=function(e){var n=e.consumeLexeme();if(n!=null){switch(n.str){case"-":e.currentClause.presence=t.Query.presence.PROHIBITED;break;case"+":e.currentClause.presence=t.Query.presence.REQUIRED;break;default:var r="unrecognised presence operator'"+n.str+"'";throw new t.QueryParseError(r,n.start,n.end)}var i=e.peekLexeme();if(i==null){var r="expecting term or field, found nothing";throw new t.QueryParseError(r,n.start,n.end)}switch(i.type){case t.QueryLexer.FIELD:return t.QueryParser.parseField;case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var r="expecting term or field, found '"+i.type+"'";throw new t.QueryParseError(r,i.start,i.end)}}},t.QueryParser.parseField=function(e){var n=e.consumeLexeme();if(n!=null){if(e.query.allFields.indexOf(n.str)==-1){var r=e.query.allFields.map(function(o){return"'"+o+"'"}).join(", "),i="unrecognised field '"+n.str+"', possible fields: "+r;throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.fields=[n.str];var s=e.peekLexeme();if(s==null){var i="expecting term, found nothing";throw new t.QueryParseError(i,n.start,n.end)}switch(s.type){case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var i="expecting term, found '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},t.QueryParser.parseTerm=function(e){var n=e.consumeLexeme();if(n!=null){e.currentClause.term=n.str.toLowerCase(),n.str.indexOf("*")!=-1&&(e.currentClause.usePipeline=!1);var r=e.peekLexeme();if(r==null){e.nextClause();return}switch(r.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+r.type+"'";throw new t.QueryParseError(i,r.start,r.end)}}},t.QueryParser.parseEditDistance=function(e){var n=e.consumeLexeme();if(n!=null){var r=parseInt(n.str,10);if(isNaN(r)){var i="edit distance must be numeric";throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.editDistance=r;var s=e.peekLexeme();if(s==null){e.nextClause();return}switch(s.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},t.QueryParser.parseBoost=function(e){var n=e.consumeLexeme();if(n!=null){var r=parseInt(n.str,10);if(isNaN(r)){var i="boost must be numeric";throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.boost=r;var s=e.peekLexeme();if(s==null){e.nextClause();return}switch(s.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},function(e,n){typeof define=="function"&&define.amd?define(n):typeof se=="object"?oe.exports=n():e.lunr=n()}(this,function(){return t})})()});var re=[];function G(t,e){re.push({selector:e,constructor:t})}var U=class{constructor(){this.alwaysVisibleMember=null;this.createComponents(document.body),this.ensureFocusedElementVisible(),this.listenForCodeCopies(),window.addEventListener("hashchange",()=>this.ensureFocusedElementVisible()),document.body.style.display||(this.scrollToHash(),this.updateIndexVisibility())}createComponents(e){re.forEach(n=>{e.querySelectorAll(n.selector).forEach(r=>{r.dataset.hasInstance||(new n.constructor({el:r,app:this}),r.dataset.hasInstance=String(!0))})})}filterChanged(){this.ensureFocusedElementVisible()}showPage(){document.body.style.display&&(document.body.style.removeProperty("display"),this.scrollToHash(),this.updateIndexVisibility())}scrollToHash(){if(location.hash){let e=document.getElementById(location.hash.substring(1));if(!e)return;e.scrollIntoView({behavior:"instant",block:"start"})}}ensureActivePageVisible(){let e=document.querySelector(".tsd-navigation .current"),n=e?.parentElement;for(;n&&!n.classList.contains(".tsd-navigation");)n instanceof HTMLDetailsElement&&(n.open=!0),n=n.parentElement;if(e&&!e.checkVisibility()){let r=e.getBoundingClientRect().top-document.documentElement.clientHeight/4;document.querySelector(".site-menu").scrollTop=r}}updateIndexVisibility(){let e=document.querySelector(".tsd-index-content"),n=e?.open;e&&(e.open=!0),document.querySelectorAll(".tsd-index-section").forEach(r=>{r.style.display="block";let i=Array.from(r.querySelectorAll(".tsd-index-link")).every(s=>s.offsetParent==null);r.style.display=i?"none":"block"}),e&&(e.open=n)}ensureFocusedElementVisible(){if(this.alwaysVisibleMember&&(this.alwaysVisibleMember.classList.remove("always-visible"),this.alwaysVisibleMember.firstElementChild.remove(),this.alwaysVisibleMember=null),!location.hash)return;let e=document.getElementById(location.hash.substring(1));if(!e)return;let n=e.parentElement;for(;n&&n.tagName!=="SECTION";)n=n.parentElement;if(n&&n.offsetParent==null){this.alwaysVisibleMember=n,n.classList.add("always-visible");let r=document.createElement("p");r.classList.add("warning"),r.textContent="This member is normally hidden due to your filter settings.",n.prepend(r)}}listenForCodeCopies(){document.querySelectorAll("pre > button").forEach(e=>{let n;e.addEventListener("click",()=>{e.previousElementSibling instanceof HTMLElement&&navigator.clipboard.writeText(e.previousElementSibling.innerText.trim()),e.textContent="Copied!",e.classList.add("visible"),clearTimeout(n),n=setTimeout(()=>{e.classList.remove("visible"),n=setTimeout(()=>{e.textContent="Copy"},100)},1e3)})})}};var ie=(t,e=100)=>{let n;return()=>{clearTimeout(n),n=setTimeout(()=>t(),e)}};var de=De(ae());async function le(t,e){if(!window.searchData)return;let n=await fetch(window.searchData),r=new Blob([await n.arrayBuffer()]).stream().pipeThrough(new DecompressionStream("gzip")),i=await new Response(r).json();t.data=i,t.index=de.Index.load(i.index),e.classList.remove("loading"),e.classList.add("ready")}function he(){let t=document.getElementById("tsd-search");if(!t)return;let e={base:t.dataset.base+"/"},n=document.getElementById("tsd-search-script");t.classList.add("loading"),n&&(n.addEventListener("error",()=>{t.classList.remove("loading"),t.classList.add("failure")}),n.addEventListener("load",()=>{le(e,t)}),le(e,t));let r=document.querySelector("#tsd-search input"),i=document.querySelector("#tsd-search .results");if(!r||!i)throw new Error("The input field or the result list wrapper was not found");let s=!1;i.addEventListener("mousedown",()=>s=!0),i.addEventListener("mouseup",()=>{s=!1,t.classList.remove("has-focus")}),r.addEventListener("focus",()=>t.classList.add("has-focus")),r.addEventListener("blur",()=>{s||(s=!1,t.classList.remove("has-focus"))}),Ae(t,i,r,e)}function Ae(t,e,n,r){n.addEventListener("input",ie(()=>{Ne(t,e,n,r)},200));let i=!1;n.addEventListener("keydown",s=>{i=!0,s.key=="Enter"?Ve(e,n):s.key=="Escape"?n.blur():s.key=="ArrowUp"?ue(e,-1):s.key==="ArrowDown"?ue(e,1):i=!1}),n.addEventListener("keypress",s=>{i&&s.preventDefault()}),document.body.addEventListener("keydown",s=>{s.altKey||s.ctrlKey||s.metaKey||!n.matches(":focus")&&s.key==="/"&&(n.focus(),s.preventDefault())})}function Ne(t,e,n,r){if(!r.index||!r.data)return;e.textContent="";let i=n.value.trim(),s;if(i){let o=i.split(" ").map(a=>a.length?`*${a}*`:"").join(" ");s=r.index.search(o)}else s=[];for(let o=0;oa.score-o.score);for(let o=0,a=Math.min(10,s.length);o`,d=ce(l.name,i);globalThis.DEBUG_SEARCH_WEIGHTS&&(d+=` (score: ${s[o].score.toFixed(2)})`),l.parent&&(d=` - ${ce(l.parent,i)}.${d}`);let y=document.createElement("li");y.classList.value=l.classes??"";let p=document.createElement("a");p.href=r.base+l.url,p.innerHTML=u+d,y.append(p),e.appendChild(y)}}function ue(t,e){let n=t.querySelector(".current");if(!n)n=t.querySelector(e==1?"li:first-child":"li:last-child"),n&&n.classList.add("current");else{let r=n;if(e===1)do r=r.nextElementSibling??void 0;while(r instanceof HTMLElement&&r.offsetParent==null);else do r=r.previousElementSibling??void 0;while(r instanceof HTMLElement&&r.offsetParent==null);r&&(n.classList.remove("current"),r.classList.add("current"))}}function Ve(t,e){let n=t.querySelector(".current");if(n||(n=t.querySelector("li:first-child")),n){let r=n.querySelector("a");r&&(window.location.href=r.href),e.blur()}}function ce(t,e){if(e==="")return t;let n=t.toLocaleLowerCase(),r=e.toLocaleLowerCase(),i=[],s=0,o=n.indexOf(r);for(;o!=-1;)i.push(K(t.substring(s,o)),`${K(t.substring(o,o+r.length))}`),s=o+r.length,o=n.indexOf(r,s);return i.push(K(t.substring(s))),i.join("")}var He={"&":"&","<":"<",">":">","'":"'",'"':"""};function K(t){return t.replace(/[&<>"'"]/g,e=>He[e])}var I=class{constructor(e){this.el=e.el,this.app=e.app}};var F="mousedown",fe="mousemove",H="mouseup",J={x:0,y:0},pe=!1,ee=!1,Be=!1,D=!1,me=/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);document.documentElement.classList.add(me?"is-mobile":"not-mobile");me&&"ontouchstart"in document.documentElement&&(Be=!0,F="touchstart",fe="touchmove",H="touchend");document.addEventListener(F,t=>{ee=!0,D=!1;let e=F=="touchstart"?t.targetTouches[0]:t;J.y=e.pageY||0,J.x=e.pageX||0});document.addEventListener(fe,t=>{if(ee&&!D){let e=F=="touchstart"?t.targetTouches[0]:t,n=J.x-(e.pageX||0),r=J.y-(e.pageY||0);D=Math.sqrt(n*n+r*r)>10}});document.addEventListener(H,()=>{ee=!1});document.addEventListener("click",t=>{pe&&(t.preventDefault(),t.stopImmediatePropagation(),pe=!1)});var X=class extends I{constructor(e){super(e),this.className=this.el.dataset.toggle||"",this.el.addEventListener(H,n=>this.onPointerUp(n)),this.el.addEventListener("click",n=>n.preventDefault()),document.addEventListener(F,n=>this.onDocumentPointerDown(n)),document.addEventListener(H,n=>this.onDocumentPointerUp(n))}setActive(e){if(this.active==e)return;this.active=e,document.documentElement.classList.toggle("has-"+this.className,e),this.el.classList.toggle("active",e);let n=(this.active?"to-has-":"from-has-")+this.className;document.documentElement.classList.add(n),setTimeout(()=>document.documentElement.classList.remove(n),500)}onPointerUp(e){D||(this.setActive(!0),e.preventDefault())}onDocumentPointerDown(e){if(this.active){if(e.target.closest(".col-sidebar, .tsd-filter-group"))return;this.setActive(!1)}}onDocumentPointerUp(e){if(!D&&this.active&&e.target.closest(".col-sidebar")){let n=e.target.closest("a");if(n){let r=window.location.href;r.indexOf("#")!=-1&&(r=r.substring(0,r.indexOf("#"))),n.href.substring(0,r.length)==r&&setTimeout(()=>this.setActive(!1),250)}}}};var te;try{te=localStorage}catch{te={getItem(){return null},setItem(){}}}var Q=te;var ye=document.head.appendChild(document.createElement("style"));ye.dataset.for="filters";var Y=class extends I{constructor(e){super(e),this.key=`filter-${this.el.name}`,this.value=this.el.checked,this.el.addEventListener("change",()=>{this.setLocalStorage(this.el.checked)}),this.setLocalStorage(this.fromLocalStorage()),ye.innerHTML+=`html:not(.${this.key}) .tsd-is-${this.el.name} { display: none; } +`,e)},t.Pipeline.load=function(e){var n=new t.Pipeline;return e.forEach(function(r){var i=t.Pipeline.registeredFunctions[r];if(i)n.add(i);else throw new Error("Cannot load unregistered function: "+r)}),n},t.Pipeline.prototype.add=function(){var e=Array.prototype.slice.call(arguments);e.forEach(function(n){t.Pipeline.warnIfFunctionNotRegistered(n),this._stack.push(n)},this)},t.Pipeline.prototype.after=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var r=this._stack.indexOf(e);if(r==-1)throw new Error("Cannot find existingFn");r=r+1,this._stack.splice(r,0,n)},t.Pipeline.prototype.before=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var r=this._stack.indexOf(e);if(r==-1)throw new Error("Cannot find existingFn");this._stack.splice(r,0,n)},t.Pipeline.prototype.remove=function(e){var n=this._stack.indexOf(e);n!=-1&&this._stack.splice(n,1)},t.Pipeline.prototype.run=function(e){for(var n=this._stack.length,r=0;r1&&(oe&&(r=s),o!=e);)i=r-n,s=n+Math.floor(i/2),o=this.elements[s*2];if(o==e||o>e)return s*2;if(ol?d+=2:a==l&&(n+=r[u+1]*i[d+1],u+=2,d+=2);return n},t.Vector.prototype.similarity=function(e){return this.dot(e)/this.magnitude()||0},t.Vector.prototype.toArray=function(){for(var e=new Array(this.elements.length/2),n=1,r=0;n0){var o=s.str.charAt(0),a;o in s.node.edges?a=s.node.edges[o]:(a=new t.TokenSet,s.node.edges[o]=a),s.str.length==1&&(a.final=!0),i.push({node:a,editsRemaining:s.editsRemaining,str:s.str.slice(1)})}if(s.editsRemaining!=0){if("*"in s.node.edges)var l=s.node.edges["*"];else{var l=new t.TokenSet;s.node.edges["*"]=l}if(s.str.length==0&&(l.final=!0),i.push({node:l,editsRemaining:s.editsRemaining-1,str:s.str}),s.str.length>1&&i.push({node:s.node,editsRemaining:s.editsRemaining-1,str:s.str.slice(1)}),s.str.length==1&&(s.node.final=!0),s.str.length>=1){if("*"in s.node.edges)var u=s.node.edges["*"];else{var u=new t.TokenSet;s.node.edges["*"]=u}s.str.length==1&&(u.final=!0),i.push({node:u,editsRemaining:s.editsRemaining-1,str:s.str.slice(1)})}if(s.str.length>1){var d=s.str.charAt(0),y=s.str.charAt(1),p;y in s.node.edges?p=s.node.edges[y]:(p=new t.TokenSet,s.node.edges[y]=p),s.str.length==1&&(p.final=!0),i.push({node:p,editsRemaining:s.editsRemaining-1,str:d+s.str.slice(2)})}}}return r},t.TokenSet.fromString=function(e){for(var n=new t.TokenSet,r=n,i=0,s=e.length;i=e;n--){var r=this.uncheckedNodes[n],i=r.child.toString();i in this.minimizedNodes?r.parent.edges[r.char]=this.minimizedNodes[i]:(r.child._str=i,this.minimizedNodes[i]=r.child),this.uncheckedNodes.pop()}};t.Index=function(e){this.invertedIndex=e.invertedIndex,this.fieldVectors=e.fieldVectors,this.tokenSet=e.tokenSet,this.fields=e.fields,this.pipeline=e.pipeline},t.Index.prototype.search=function(e){return this.query(function(n){var r=new t.QueryParser(e,n);r.parse()})},t.Index.prototype.query=function(e){for(var n=new t.Query(this.fields),r=Object.create(null),i=Object.create(null),s=Object.create(null),o=Object.create(null),a=Object.create(null),l=0;l1?this._b=1:this._b=e},t.Builder.prototype.k1=function(e){this._k1=e},t.Builder.prototype.add=function(e,n){var r=e[this._ref],i=Object.keys(this._fields);this._documents[r]=n||{},this.documentCount+=1;for(var s=0;s=this.length)return t.QueryLexer.EOS;var e=this.str.charAt(this.pos);return this.pos+=1,e},t.QueryLexer.prototype.width=function(){return this.pos-this.start},t.QueryLexer.prototype.ignore=function(){this.start==this.pos&&(this.pos+=1),this.start=this.pos},t.QueryLexer.prototype.backup=function(){this.pos-=1},t.QueryLexer.prototype.acceptDigitRun=function(){var e,n;do e=this.next(),n=e.charCodeAt(0);while(n>47&&n<58);e!=t.QueryLexer.EOS&&this.backup()},t.QueryLexer.prototype.more=function(){return this.pos1&&(e.backup(),e.emit(t.QueryLexer.TERM)),e.ignore(),e.more())return t.QueryLexer.lexText},t.QueryLexer.lexEditDistance=function(e){return e.ignore(),e.acceptDigitRun(),e.emit(t.QueryLexer.EDIT_DISTANCE),t.QueryLexer.lexText},t.QueryLexer.lexBoost=function(e){return e.ignore(),e.acceptDigitRun(),e.emit(t.QueryLexer.BOOST),t.QueryLexer.lexText},t.QueryLexer.lexEOS=function(e){e.width()>0&&e.emit(t.QueryLexer.TERM)},t.QueryLexer.termSeparator=t.tokenizer.separator,t.QueryLexer.lexText=function(e){for(;;){var n=e.next();if(n==t.QueryLexer.EOS)return t.QueryLexer.lexEOS;if(n.charCodeAt(0)==92){e.escapeCharacter();continue}if(n==":")return t.QueryLexer.lexField;if(n=="~")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexEditDistance;if(n=="^")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexBoost;if(n=="+"&&e.width()===1||n=="-"&&e.width()===1)return e.emit(t.QueryLexer.PRESENCE),t.QueryLexer.lexText;if(n.match(t.QueryLexer.termSeparator))return t.QueryLexer.lexTerm}},t.QueryParser=function(e,n){this.lexer=new t.QueryLexer(e),this.query=n,this.currentClause={},this.lexemeIdx=0},t.QueryParser.prototype.parse=function(){this.lexer.run(),this.lexemes=this.lexer.lexemes;for(var e=t.QueryParser.parseClause;e;)e=e(this);return this.query},t.QueryParser.prototype.peekLexeme=function(){return this.lexemes[this.lexemeIdx]},t.QueryParser.prototype.consumeLexeme=function(){var e=this.peekLexeme();return this.lexemeIdx+=1,e},t.QueryParser.prototype.nextClause=function(){var e=this.currentClause;this.query.clause(e),this.currentClause={}},t.QueryParser.parseClause=function(e){var n=e.peekLexeme();if(n!=null)switch(n.type){case t.QueryLexer.PRESENCE:return t.QueryParser.parsePresence;case t.QueryLexer.FIELD:return t.QueryParser.parseField;case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var r="expected either a field or a term, found "+n.type;throw n.str.length>=1&&(r+=" with value '"+n.str+"'"),new t.QueryParseError(r,n.start,n.end)}},t.QueryParser.parsePresence=function(e){var n=e.consumeLexeme();if(n!=null){switch(n.str){case"-":e.currentClause.presence=t.Query.presence.PROHIBITED;break;case"+":e.currentClause.presence=t.Query.presence.REQUIRED;break;default:var r="unrecognised presence operator'"+n.str+"'";throw new t.QueryParseError(r,n.start,n.end)}var i=e.peekLexeme();if(i==null){var r="expecting term or field, found nothing";throw new t.QueryParseError(r,n.start,n.end)}switch(i.type){case t.QueryLexer.FIELD:return t.QueryParser.parseField;case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var r="expecting term or field, found '"+i.type+"'";throw new t.QueryParseError(r,i.start,i.end)}}},t.QueryParser.parseField=function(e){var n=e.consumeLexeme();if(n!=null){if(e.query.allFields.indexOf(n.str)==-1){var r=e.query.allFields.map(function(o){return"'"+o+"'"}).join(", "),i="unrecognised field '"+n.str+"', possible fields: "+r;throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.fields=[n.str];var s=e.peekLexeme();if(s==null){var i="expecting term, found nothing";throw new t.QueryParseError(i,n.start,n.end)}switch(s.type){case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var i="expecting term, found '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},t.QueryParser.parseTerm=function(e){var n=e.consumeLexeme();if(n!=null){e.currentClause.term=n.str.toLowerCase(),n.str.indexOf("*")!=-1&&(e.currentClause.usePipeline=!1);var r=e.peekLexeme();if(r==null){e.nextClause();return}switch(r.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+r.type+"'";throw new t.QueryParseError(i,r.start,r.end)}}},t.QueryParser.parseEditDistance=function(e){var n=e.consumeLexeme();if(n!=null){var r=parseInt(n.str,10);if(isNaN(r)){var i="edit distance must be numeric";throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.editDistance=r;var s=e.peekLexeme();if(s==null){e.nextClause();return}switch(s.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},t.QueryParser.parseBoost=function(e){var n=e.consumeLexeme();if(n!=null){var r=parseInt(n.str,10);if(isNaN(r)){var i="boost must be numeric";throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.boost=r;var s=e.peekLexeme();if(s==null){e.nextClause();return}switch(s.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},function(e,n){typeof define=="function"&&define.amd?define(n):typeof se=="object"?oe.exports=n():e.lunr=n()}(this,function(){return t})})()});var re=[];function G(t,e){re.push({selector:e,constructor:t})}var U=class{constructor(){this.alwaysVisibleMember=null;this.createComponents(document.body),this.ensureFocusedElementVisible(),this.listenForCodeCopies(),window.addEventListener("hashchange",()=>this.ensureFocusedElementVisible()),document.body.style.display||(this.ensureFocusedElementVisible(),this.updateIndexVisibility(),this.scrollToHash())}createComponents(e){re.forEach(n=>{e.querySelectorAll(n.selector).forEach(r=>{r.dataset.hasInstance||(new n.constructor({el:r,app:this}),r.dataset.hasInstance=String(!0))})})}filterChanged(){this.ensureFocusedElementVisible()}showPage(){document.body.style.display&&(console.log("Show page"),document.body.style.removeProperty("display"),this.ensureFocusedElementVisible(),this.updateIndexVisibility(),this.scrollToHash())}scrollToHash(){if(location.hash){console.log("Scorlling");let e=document.getElementById(location.hash.substring(1));if(!e)return;e.scrollIntoView({behavior:"instant",block:"start"})}}ensureActivePageVisible(){let e=document.querySelector(".tsd-navigation .current"),n=e?.parentElement;for(;n&&!n.classList.contains(".tsd-navigation");)n instanceof HTMLDetailsElement&&(n.open=!0),n=n.parentElement;if(e&&!e.checkVisibility()){let r=e.getBoundingClientRect().top-document.documentElement.clientHeight/4;document.querySelector(".site-menu").scrollTop=r}}updateIndexVisibility(){let e=document.querySelector(".tsd-index-content"),n=e?.open;e&&(e.open=!0),document.querySelectorAll(".tsd-index-section").forEach(r=>{r.style.display="block";let i=Array.from(r.querySelectorAll(".tsd-index-link")).every(s=>s.offsetParent==null);r.style.display=i?"none":"block"}),e&&(e.open=n)}ensureFocusedElementVisible(){if(this.alwaysVisibleMember&&(this.alwaysVisibleMember.classList.remove("always-visible"),this.alwaysVisibleMember.firstElementChild.remove(),this.alwaysVisibleMember=null),!location.hash)return;let e=document.getElementById(location.hash.substring(1));if(!e)return;let n=e.parentElement;for(;n&&n.tagName!=="SECTION";)n=n.parentElement;if(n&&n.offsetParent==null){this.alwaysVisibleMember=n,n.classList.add("always-visible");let r=document.createElement("p");r.classList.add("warning"),r.textContent="This member is normally hidden due to your filter settings.",n.prepend(r)}}listenForCodeCopies(){document.querySelectorAll("pre > button").forEach(e=>{let n;e.addEventListener("click",()=>{e.previousElementSibling instanceof HTMLElement&&navigator.clipboard.writeText(e.previousElementSibling.innerText.trim()),e.textContent="Copied!",e.classList.add("visible"),clearTimeout(n),n=setTimeout(()=>{e.classList.remove("visible"),n=setTimeout(()=>{e.textContent="Copy"},100)},1e3)})})}};var ie=(t,e=100)=>{let n;return()=>{clearTimeout(n),n=setTimeout(()=>t(),e)}};var de=De(ae());async function le(t,e){if(!window.searchData)return;let n=await fetch(window.searchData),r=new Blob([await n.arrayBuffer()]).stream().pipeThrough(new DecompressionStream("gzip")),i=await new Response(r).json();t.data=i,t.index=de.Index.load(i.index),e.classList.remove("loading"),e.classList.add("ready")}function he(){let t=document.getElementById("tsd-search");if(!t)return;let e={base:t.dataset.base+"/"},n=document.getElementById("tsd-search-script");t.classList.add("loading"),n&&(n.addEventListener("error",()=>{t.classList.remove("loading"),t.classList.add("failure")}),n.addEventListener("load",()=>{le(e,t)}),le(e,t));let r=document.querySelector("#tsd-search input"),i=document.querySelector("#tsd-search .results");if(!r||!i)throw new Error("The input field or the result list wrapper was not found");let s=!1;i.addEventListener("mousedown",()=>s=!0),i.addEventListener("mouseup",()=>{s=!1,t.classList.remove("has-focus")}),r.addEventListener("focus",()=>t.classList.add("has-focus")),r.addEventListener("blur",()=>{s||(s=!1,t.classList.remove("has-focus"))}),Ae(t,i,r,e)}function Ae(t,e,n,r){n.addEventListener("input",ie(()=>{Ve(t,e,n,r)},200));let i=!1;n.addEventListener("keydown",s=>{i=!0,s.key=="Enter"?Ne(e,n):s.key=="Escape"?n.blur():s.key=="ArrowUp"?ue(e,-1):s.key==="ArrowDown"?ue(e,1):i=!1}),n.addEventListener("keypress",s=>{i&&s.preventDefault()}),document.body.addEventListener("keydown",s=>{s.altKey||s.ctrlKey||s.metaKey||!n.matches(":focus")&&s.key==="/"&&(n.focus(),s.preventDefault())})}function Ve(t,e,n,r){if(!r.index||!r.data)return;e.textContent="";let i=n.value.trim(),s;if(i){let o=i.split(" ").map(a=>a.length?`*${a}*`:"").join(" ");s=r.index.search(o)}else s=[];for(let o=0;oa.score-o.score);for(let o=0,a=Math.min(10,s.length);o`,d=ce(l.name,i);globalThis.DEBUG_SEARCH_WEIGHTS&&(d+=` (score: ${s[o].score.toFixed(2)})`),l.parent&&(d=` + ${ce(l.parent,i)}.${d}`);let y=document.createElement("li");y.classList.value=l.classes??"";let p=document.createElement("a");p.href=r.base+l.url,p.innerHTML=u+d,y.append(p),e.appendChild(y)}}function ue(t,e){let n=t.querySelector(".current");if(!n)n=t.querySelector(e==1?"li:first-child":"li:last-child"),n&&n.classList.add("current");else{let r=n;if(e===1)do r=r.nextElementSibling??void 0;while(r instanceof HTMLElement&&r.offsetParent==null);else do r=r.previousElementSibling??void 0;while(r instanceof HTMLElement&&r.offsetParent==null);r&&(n.classList.remove("current"),r.classList.add("current"))}}function Ne(t,e){let n=t.querySelector(".current");if(n||(n=t.querySelector("li:first-child")),n){let r=n.querySelector("a");r&&(window.location.href=r.href),e.blur()}}function ce(t,e){if(e==="")return t;let n=t.toLocaleLowerCase(),r=e.toLocaleLowerCase(),i=[],s=0,o=n.indexOf(r);for(;o!=-1;)i.push(K(t.substring(s,o)),`${K(t.substring(o,o+r.length))}`),s=o+r.length,o=n.indexOf(r,s);return i.push(K(t.substring(s))),i.join("")}var He={"&":"&","<":"<",">":">","'":"'",'"':"""};function K(t){return t.replace(/[&<>"'"]/g,e=>He[e])}var I=class{constructor(e){this.el=e.el,this.app=e.app}};var F="mousedown",fe="mousemove",H="mouseup",J={x:0,y:0},pe=!1,ee=!1,Be=!1,D=!1,me=/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);document.documentElement.classList.add(me?"is-mobile":"not-mobile");me&&"ontouchstart"in document.documentElement&&(Be=!0,F="touchstart",fe="touchmove",H="touchend");document.addEventListener(F,t=>{ee=!0,D=!1;let e=F=="touchstart"?t.targetTouches[0]:t;J.y=e.pageY||0,J.x=e.pageX||0});document.addEventListener(fe,t=>{if(ee&&!D){let e=F=="touchstart"?t.targetTouches[0]:t,n=J.x-(e.pageX||0),r=J.y-(e.pageY||0);D=Math.sqrt(n*n+r*r)>10}});document.addEventListener(H,()=>{ee=!1});document.addEventListener("click",t=>{pe&&(t.preventDefault(),t.stopImmediatePropagation(),pe=!1)});var X=class extends I{constructor(e){super(e),this.className=this.el.dataset.toggle||"",this.el.addEventListener(H,n=>this.onPointerUp(n)),this.el.addEventListener("click",n=>n.preventDefault()),document.addEventListener(F,n=>this.onDocumentPointerDown(n)),document.addEventListener(H,n=>this.onDocumentPointerUp(n))}setActive(e){if(this.active==e)return;this.active=e,document.documentElement.classList.toggle("has-"+this.className,e),this.el.classList.toggle("active",e);let n=(this.active?"to-has-":"from-has-")+this.className;document.documentElement.classList.add(n),setTimeout(()=>document.documentElement.classList.remove(n),500)}onPointerUp(e){D||(this.setActive(!0),e.preventDefault())}onDocumentPointerDown(e){if(this.active){if(e.target.closest(".col-sidebar, .tsd-filter-group"))return;this.setActive(!1)}}onDocumentPointerUp(e){if(!D&&this.active&&e.target.closest(".col-sidebar")){let n=e.target.closest("a");if(n){let r=window.location.href;r.indexOf("#")!=-1&&(r=r.substring(0,r.indexOf("#"))),n.href.substring(0,r.length)==r&&setTimeout(()=>this.setActive(!1),250)}}}};var te;try{te=localStorage}catch{te={getItem(){return null},setItem(){}}}var Q=te;var ye=document.head.appendChild(document.createElement("style"));ye.dataset.for="filters";var Y=class extends I{constructor(e){super(e),this.key=`filter-${this.el.name}`,this.value=this.el.checked,this.el.addEventListener("change",()=>{this.setLocalStorage(this.el.checked)}),this.setLocalStorage(this.fromLocalStorage()),ye.innerHTML+=`html:not(.${this.key}) .tsd-is-${this.el.name} { display: none; } `,this.app.updateIndexVisibility()}fromLocalStorage(){let e=Q.getItem(this.key);return e?e==="true":this.el.checked}setLocalStorage(e){Q.setItem(this.key,e.toString()),this.value=e,this.handleValueChange()}handleValueChange(){this.el.checked=this.value,document.documentElement.classList.toggle(this.key,this.value),this.app.filterChanged(),this.app.updateIndexVisibility()}};var Z=class extends I{constructor(e){super(e),this.summary=this.el.querySelector(".tsd-accordion-summary"),this.icon=this.summary.querySelector("svg"),this.key=`tsd-accordion-${this.summary.dataset.key??this.summary.textContent.trim().replace(/\s+/g,"-").toLowerCase()}`;let n=Q.getItem(this.key);this.el.open=n?n==="true":this.el.open,this.el.addEventListener("toggle",()=>this.update());let r=this.summary.querySelector("a");r&&r.addEventListener("click",()=>{location.assign(r.href)}),this.update()}update(){this.icon.style.transform=`rotate(${this.el.open?0:-90}deg)`,Q.setItem(this.key,this.el.open.toString())}};function ge(t){let e=Q.getItem("tsd-theme")||"os";t.value=e,ve(e),t.addEventListener("change",()=>{Q.setItem("tsd-theme",t.value),ve(t.value)})}function ve(t){document.documentElement.dataset.theme=t}var Le;function be(){let t=document.getElementById("tsd-nav-script");t&&(t.addEventListener("load",xe),xe())}async function xe(){let t=document.getElementById("tsd-nav-container");if(!t||!window.navigationData)return;let n=await(await fetch(window.navigationData)).arrayBuffer(),r=new Blob([n]).stream().pipeThrough(new DecompressionStream("gzip")),i=await new Response(r).json();Le=t.dataset.base+"/",t.innerHTML="";for(let s of i)we(s,t,[]);window.app.createComponents(t),window.app.showPage(),window.app.ensureActivePageVisible()}function we(t,e,n){let r=e.appendChild(document.createElement("li"));if(t.children){let i=[...n,t.text],s=r.appendChild(document.createElement("details"));s.className=t.class?`${t.class} tsd-index-accordion`:"tsd-index-accordion",s.dataset.key=i.join("$");let o=s.appendChild(document.createElement("summary"));o.className="tsd-accordion-summary",o.innerHTML='',Ee(t,o);let a=s.appendChild(document.createElement("div"));a.className="tsd-accordion-details";let l=a.appendChild(document.createElement("ul"));l.className="tsd-nested-navigation";for(let u of t.children)we(u,l,i)}else Ee(t,r,t.class)}function Ee(t,e,n){if(t.path){let r=e.appendChild(document.createElement("a"));r.href=Le+t.path,n&&(r.className=n),location.pathname===r.pathname&&r.classList.add("current"),t.kind&&(r.innerHTML=``),r.appendChild(document.createElement("span")).textContent=t.text}else e.appendChild(document.createElement("span")).textContent=t.text}G(X,"a[data-toggle]");G(Z,".tsd-index-accordion");G(Y,".tsd-filter-item input[type=checkbox]");var Se=document.getElementById("tsd-theme");Se&&ge(Se);var je=new U;Object.defineProperty(window,"app",{value:je});he();be();})(); /*! Bundled license information: diff --git a/api/assets/search.js b/api/assets/search.js index 3a670851..8c15f0a9 100644 --- a/api/assets/search.js +++ b/api/assets/search.js @@ -1 +1 @@ -window.searchData = "data:application/octet-stream;base64,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"; \ No newline at end of file +window.searchData = "data:application/octet-stream;base64,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"; \ No newline at end of file diff --git a/api/assets/style.css b/api/assets/style.css index 072daed8..778b9492 100644 --- a/api/assets/style.css +++ b/api/assets/style.css @@ -327,17 +327,14 @@ dd { } /* Footer */ -.tsd-generator { +footer { border-top: 1px solid var(--color-accent); padding-top: 1rem; padding-bottom: 1rem; max-height: 3.5rem; } - -.tsd-generator > p { - margin-top: 0; - margin-bottom: 0; - padding: 0 1rem; +.tsd-generator { + margin: 0 1em; } .container-main { diff --git a/api/classes/BlobReader.html b/api/classes/BlobReader.html index 627aeaf8..c5ad7ba2 100644 --- a/api/classes/BlobReader.html +++ b/api/classes/BlobReader.html @@ -1,16 +1,16 @@ BlobReader | @zip.js/zip.js

Class BlobReader

Represents a Reader instance used to read data provided as a Blob instance.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

Constructors

Properties

readable: ReadableStream<any>

The ReadableStream instance.

-
size: number

The total size of the data in bytes.

-

Methods

  • Initializes the instance asynchronously

    -

    Returns Promise<void>

  • Reads a chunk of data

    +

Returns BlobReader

Properties

readable: ReadableStream<any>

The ReadableStream instance.

+
size: number

The total size of the data in bytes.

+

Methods

  • Initializes the instance asynchronously

    +

    Returns Promise<void>

  • Reads a chunk of data

    Parameters

    • index: number

      The byte index of the data to read.

    • length: number

      The length of the data to read in bytes.

    Returns Promise<Uint8Array>

    A promise resolving to a chunk of data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/BlobWriter.html b/api/classes/BlobWriter.html index 78d5b8aa..ea58fce0 100644 --- a/api/classes/BlobWriter.html +++ b/api/classes/BlobWriter.html @@ -1,12 +1,12 @@ BlobWriter | @zip.js/zip.js

Class BlobWriter

Represents a WritableWriter instance used to retrieve the written data as a Blob instance.

-

Implements

Constructors

Implements

Constructors

Properties

Methods

Constructors

Properties

writable: WritableStream<any>

The WritableStream instance.

-

Methods

  • Retrieves all the written data

    +

Returns BlobWriter

Properties

writable: WritableStream<any>

The WritableStream instance.

+

Methods

  • Retrieves all the written data

    Returns Promise<Blob>

    A promise resolving to the written data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/CodecStream.html b/api/classes/CodecStream.html index c8b63371..a46612d0 100644 --- a/api/classes/CodecStream.html +++ b/api/classes/CodecStream.html @@ -1,7 +1,7 @@ CodecStream | @zip.js/zip.js

Class CodecStream

Represents a class implementing CompressionStream or DecompressionStream interfaces.

-

Hierarchy

  • TransformStream
    • CodecStream

Constructors

Hierarchy

  • TransformStream
    • CodecStream

Constructors

Properties

Constructors

  • Parameters

    • Optional transformer: Transformer<any, any>
    • Optional writableStrategy: QueuingStrategy<any>
    • Optional readableStrategy: QueuingStrategy<any>

    Returns CodecStream

Properties

readable: ReadableStream<any>
writable: WritableStream<any>

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/Data64URIReader.html b/api/classes/Data64URIReader.html index 9054aaf0..90387f4f 100644 --- a/api/classes/Data64URIReader.html +++ b/api/classes/Data64URIReader.html @@ -1,16 +1,16 @@ Data64URIReader | @zip.js/zip.js

Class Data64URIReader

Represents a Reader instance used to read data provided as a Data URI string encoded in Base64.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

Constructors

Properties

readable: ReadableStream<any>

The ReadableStream instance.

-
size: number

The total size of the data in bytes.

-

Methods

  • Initializes the instance asynchronously

    -

    Returns Promise<void>

  • Reads a chunk of data

    +

Returns Data64URIReader

Properties

readable: ReadableStream<any>

The ReadableStream instance.

+
size: number

The total size of the data in bytes.

+

Methods

  • Initializes the instance asynchronously

    +

    Returns Promise<void>

  • Reads a chunk of data

    Parameters

    • index: number

      The byte index of the data to read.

    • length: number

      The length of the data to read in bytes.

    Returns Promise<Uint8Array>

    A promise resolving to a chunk of data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/Data64URIWriter.html b/api/classes/Data64URIWriter.html index c61f7775..a6bdfcac 100644 --- a/api/classes/Data64URIWriter.html +++ b/api/classes/Data64URIWriter.html @@ -1,16 +1,16 @@ Data64URIWriter | @zip.js/zip.js

Class Data64URIWriter

Represents a Writer instance used to retrieve the written data as a Data URI string encoded in Base64.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

Constructors

Properties

writable: WritableStream<any>

The WritableStream instance.

-

Methods

  • Retrieves all the written data

    +

Returns Data64URIWriter

Properties

writable: WritableStream<any>

The WritableStream instance.

+

Methods

  • Retrieves all the written data

    Returns Promise<string>

    A promise resolving to the written data.

    -
  • Initializes the instance asynchronously

    Parameters

    • Optional size: number

      the total size of the written data in bytes.

      -

    Returns Promise<void>

  • Appends a chunk of data

    +

Returns Promise<void>

  • Appends a chunk of data

    Parameters

    • array: Uint8Array

      The chunk data to append.

      -

    Returns Promise<void>

Generated using TypeDoc

\ No newline at end of file +

Returns Promise<void>

\ No newline at end of file diff --git a/api/classes/EventBasedCodec.html b/api/classes/EventBasedCodec.html index bb0e268f..57579728 100644 --- a/api/classes/EventBasedCodec.html +++ b/api/classes/EventBasedCodec.html @@ -1,9 +1,9 @@ EventBasedCodec | @zip.js/zip.js

Class EventBasedCodec

Represents an event-based implementation of a third-party codec.

-

Constructors

Constructors

Methods

Constructors

Methods

  • The function called when a chunk of data has been compressed/decompressed.

    Parameters

    • Optional data: Uint8Array

      The chunk of compressed/decompressed data.

      -

    Returns void

  • Appends a chunk of data to compress/decompress

    +

Returns void

  • Appends a chunk of data to compress/decompress

    Parameters

    • data: Uint8Array

      The chunk of data to append.

      -

    Returns void

Generated using TypeDoc

\ No newline at end of file +

Returns void

\ No newline at end of file diff --git a/api/classes/FS.html b/api/classes/FS.html index 0521d6ed..4f56407c 100644 --- a/api/classes/FS.html +++ b/api/classes/FS.html @@ -2,7 +2,7 @@

Example

Here is an example showing how to create and read a zip file containing a compressed text file:

const TEXT_CONTENT = "Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.";
const FILENAME = "lorem.txt";
const BLOB = new Blob([TEXT_CONTENT], { type: zip.getMimeType(FILENAME) });
let zipFs = new zip.fs.FS();
zipFs.addBlob("lorem.txt", BLOB);
const zippedBlob = await zipFs.exportBlob();
zipFs = new zip.fs.FS();
await zipFs.importBlob(zippedBlob);
const firstEntry = zipFs.children[0];
const unzippedBlob = await firstEntry.getBlob(zip.getMimeType(firstEntry.name));
-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

children data? directory @@ -45,116 +45,116 @@ remove rename

Constructors

Properties

children: ZipEntry[]

The children of the entry.

-

The underlying EntryMetaData instance.

-
directory: true

true for ZipDirectoryEntry instances.

-
id: number

The ID of the instance.

-
name: string

The relative filename of the entry.

-
parent?: ZipEntry

The parent directory of the entry.

-

The root directory.

-
uncompressedSize: number

The uncompressed size of the content.

-

Methods

The underlying EntryMetaData instance.

+
directory: true

true for ZipDirectoryEntry instances.

+
id: number

The ID of the instance.

+
name: string

The relative filename of the entry.

+
parent?: ZipEntry

The parent directory of the entry.

+

The root directory.

+
uncompressedSize: number

The uncompressed size of the content.

+

Methods

  • Tests the password on the entry and all children if any, returns true if the entry is not password protected

    -

    Parameters

    Returns Promise<boolean>

  • Tests the password on the entry and all children if any, returns true if the entry is not password protected

    +

    Parameters

    Returns Promise<boolean>

  • Returns a Blob instance containing a zip file of the entry and its descendants

    +

Returns ZipEntry

  • Returns a Data URI string encoded in Base64 containing a zip file of the entry and its descendants

    +
  • Creates a zip file via a WritableStream instance containing the entry and its descendants

    Parameters

    Returns Promise<WritableStream<any>>

    A promise resolving to the Uint8Array instance.

    -
  • Extracts a zip file provided as a Data URI string encoded in Base64 into the entry

    +

Returns Promise<[ZipEntry]>

  • Extracts a zip file fetched from a URL into the entry

    +

Returns Promise<[ZipEntry]>

  • Extracts a zip file provided via a ReadableStream instance into the entry

    +

Returns Promise<[ZipEntry]>

  • Extracts a zip file provided as a Uint8Array instance into the entry

    +

Returns Promise<[ZipEntry]>

  • Extracts a zip file provided via a custom Reader instance into the entry

    +

Returns Promise<[ZipEntry]>

  • Tests if a ZipDirectoryEntry instance is an ancestor of the entry

    +

Returns Promise<[ZipEntry]>

Returns boolean

  • Removes a ZipEntry instance and its children

    +

Returns void

  • Set the name of the entry

    +

Returns void

Generated using TypeDoc

\ No newline at end of file +

Returns void

\ No newline at end of file diff --git a/api/classes/HttpRangeReader.html b/api/classes/HttpRangeReader.html index 15408593..c930108d 100644 --- a/api/classes/HttpRangeReader.html +++ b/api/classes/HttpRangeReader.html @@ -1,5 +1,5 @@ HttpRangeReader | @zip.js/zip.js

Class HttpRangeReader

Represents a Reader instance used to fetch data from servers returning Accept-Ranges headers.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

init? @@ -7,11 +7,11 @@

Constructors

Properties

readable: ReadableStream<any>

The ReadableStream instance.

-
size: number

The total size of the data in bytes.

-

Methods

  • Reads a chunk of data

    +

Returns HttpRangeReader

Properties

readable: ReadableStream<any>

The ReadableStream instance.

+
size: number

The total size of the data in bytes.

+

Methods

  • Reads a chunk of data

    Parameters

    • index: number

      The byte index of the data to read.

    • length: number

      The length of the data to read in bytes.

    Returns Promise<Uint8Array>

    A promise resolving to a chunk of data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/HttpReader.html b/api/classes/HttpReader.html index fccebb61..68350fac 100644 --- a/api/classes/HttpReader.html +++ b/api/classes/HttpReader.html @@ -1,5 +1,5 @@ HttpReader | @zip.js/zip.js

Class HttpReader

Represents a Reader instance used to fetch data from a URL.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

init? @@ -7,11 +7,11 @@

Constructors

Properties

readable: ReadableStream<any>

The ReadableStream instance.

-
size: number

The total size of the data in bytes.

-

Methods

  • Initializes the instance asynchronously

    -

    Returns Promise<void>

  • Reads a chunk of data

    +

Returns HttpReader

Properties

readable: ReadableStream<any>

The ReadableStream instance.

+
size: number

The total size of the data in bytes.

+

Methods

  • Initializes the instance asynchronously

    +

    Returns Promise<void>

  • Reads a chunk of data

    Parameters

    • index: number

      The byte index of the data to read.

    • length: number

      The length of the data to read in bytes.

    Returns Promise<Uint8Array>

    A promise resolving to a chunk of data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/Reader.html b/api/classes/Reader.html index 80338ee1..81fd553e 100644 --- a/api/classes/Reader.html +++ b/api/classes/Reader.html @@ -2,18 +2,18 @@

Example

Here is an example of custom Reader class used to read binary strings:

class BinaryStringReader extends Reader {

constructor(binaryString) {
super();
this.binaryString = binaryString;
}

init() {
super.init();
this.size = this.binaryString.length;
}

readUint8Array(offset, length) {
const result = new Uint8Array(length);
for (let indexCharacter = 0; indexCharacter < length; indexCharacter++) {
result[indexCharacter] = this.binaryString.charCodeAt(indexCharacter + offset) & 0xFF;
}
return result;
}
}
-

Type Parameters

  • Type

Hierarchy (view full)

Implements

Constructors

Type Parameters

  • Type

Hierarchy (view full)

Implements

Constructors

Properties

Methods

Constructors

Properties

readable: ReadableStream<any>

The ReadableStream instance.

-
size: number

The total size of the data in bytes.

-

Methods

  • Reads a chunk of data

    +

Returns Reader<Type>

Properties

readable: ReadableStream<any>

The ReadableStream instance.

+
size: number

The total size of the data in bytes.

+

Methods

  • Reads a chunk of data

    Parameters

    • index: number

      The byte index of the data to read.

    • length: number

      The length of the data to read in bytes.

    Returns Promise<Uint8Array>

    A promise resolving to a chunk of data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/SplitDataReader.html b/api/classes/SplitDataReader.html index d5ea25b0..9f13d107 100644 --- a/api/classes/SplitDataReader.html +++ b/api/classes/SplitDataReader.html @@ -1,16 +1,16 @@ SplitDataReader | @zip.js/zip.js

Class SplitDataReader

Represents a Reader instance used to read data provided as an array of ReadableReader instances (e.g. split zip files).

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

Constructors

Properties

readable: ReadableStream<any>

The ReadableStream instance.

-
size: number

The total size of the data in bytes.

-

Methods

  • Initializes the instance asynchronously

    -

    Returns Promise<void>

  • Reads a chunk of data

    +

Returns SplitDataReader

Properties

readable: ReadableStream<any>

The ReadableStream instance.

+
size: number

The total size of the data in bytes.

+

Methods

  • Initializes the instance asynchronously

    +

    Returns Promise<void>

  • Reads a chunk of data

    Parameters

    • index: number

      The byte index of the data to read.

    • length: number

      The length of the data to read in bytes.

    Returns Promise<Uint8Array>

    A promise resolving to a chunk of data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/SplitDataWriter.html b/api/classes/SplitDataWriter.html index 1930ceff..c67a3fa6 100644 --- a/api/classes/SplitDataWriter.html +++ b/api/classes/SplitDataWriter.html @@ -1,10 +1,10 @@ SplitDataWriter | @zip.js/zip.js

Class SplitDataWriter

Represents a Writer instance used to retrieve the written data from a generator of WritableWriter instances (i.e. split zip files).

-

Hierarchy (view full)

Implements

Constructors

Hierarchy (view full)

Implements

Constructors

Properties

Methods

Constructors

Properties

writable: WritableStream<any>

The WritableStream instance.

-

Methods

Generated using TypeDoc

\ No newline at end of file +

Returns SplitDataWriter

Properties

writable: WritableStream<any>

The WritableStream instance.

+

Methods

\ No newline at end of file diff --git a/api/classes/SplitZipReader.html b/api/classes/SplitZipReader.html index f964f40a..1aefd201 100644 --- a/api/classes/SplitZipReader.html +++ b/api/classes/SplitZipReader.html @@ -1,17 +1,17 @@ SplitZipReader | @zip.js/zip.js

Class SplitZipReader

Represents a Reader instance used to read data provided as an array of ReadableReader instances (e.g. split zip files).

Deprecated

Use SplitDataReader instead.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

Constructors

Properties

readable: ReadableStream<any>

The ReadableStream instance.

-
size: number

The total size of the data in bytes.

-

Methods

  • Reads a chunk of data

    +

Returns SplitZipReader

Properties

readable: ReadableStream<any>

The ReadableStream instance.

+
size: number

The total size of the data in bytes.

+

Methods

  • Reads a chunk of data

    Parameters

    • index: number

      The byte index of the data to read.

    • length: number

      The length of the data to read in bytes.

    Returns Promise<Uint8Array>

    A promise resolving to a chunk of data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/SplitZipWriter.html b/api/classes/SplitZipWriter.html index 2cb6ed5e..b2d47926 100644 --- a/api/classes/SplitZipWriter.html +++ b/api/classes/SplitZipWriter.html @@ -1,11 +1,11 @@ SplitZipWriter | @zip.js/zip.js

Class SplitZipWriter

Represents a Writer instance used to retrieve the written data from a generator of WritableWriter instances (i.e. split zip files).

Deprecated

Use SplitDataWriter instead.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

Constructors

Properties

writable: WritableStream<any>

The WritableStream instance.

-

Methods

Generated using TypeDoc

\ No newline at end of file +

Returns SplitZipWriter

Properties

writable: WritableStream<any>

The WritableStream instance.

+

Methods

\ No newline at end of file diff --git a/api/classes/SyncCodec.html b/api/classes/SyncCodec.html index 5e63c313..320fd7a5 100644 --- a/api/classes/SyncCodec.html +++ b/api/classes/SyncCodec.html @@ -1,6 +1,6 @@ -SyncCodec | @zip.js/zip.js

Hierarchy (view full)

Constructors

constructor +SyncCodec | @zip.js/zip.js

Hierarchy (view full)

Constructors

Methods

Constructors

Methods

  • Appends a chunk of decompressed data to compress

    Parameters

    • data: Uint8Array

      The chunk of decompressed data to append.

    Returns Uint8Array

    A chunk of compressed data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/TextReader.html b/api/classes/TextReader.html index e093629e..c45907a9 100644 --- a/api/classes/TextReader.html +++ b/api/classes/TextReader.html @@ -1,16 +1,16 @@ TextReader | @zip.js/zip.js

Class TextReader

Represents a Reader instance used to read data provided as a string.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

Constructors

Properties

readable: ReadableStream<any>

The ReadableStream instance.

-
size: number

The total size of the data in bytes.

-

Methods

  • Initializes the instance asynchronously

    -

    Returns Promise<void>

  • Reads a chunk of data

    +

Returns TextReader

Properties

readable: ReadableStream<any>

The ReadableStream instance.

+
size: number

The total size of the data in bytes.

+

Methods

  • Initializes the instance asynchronously

    +

    Returns Promise<void>

  • Reads a chunk of data

    Parameters

    • index: number

      The byte index of the data to read.

    • length: number

      The length of the data to read in bytes.

    Returns Promise<Uint8Array>

    A promise resolving to a chunk of data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/TextWriter.html b/api/classes/TextWriter.html index a9f9bb75..f7441d63 100644 --- a/api/classes/TextWriter.html +++ b/api/classes/TextWriter.html @@ -1,16 +1,16 @@ TextWriter | @zip.js/zip.js

Class TextWriter

Represents a Writer instance used to retrieve the written data as a string.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Methods

Constructors

Properties

writable: WritableStream<any>

The WritableStream instance.

-

Methods

  • Retrieves all the written data

    +

Returns TextWriter

Properties

writable: WritableStream<any>

The WritableStream instance.

+

Methods

  • Retrieves all the written data

    Returns Promise<string>

    A promise resolving to the written data.

    -
  • Initializes the instance asynchronously

    Parameters

    • Optional size: number

      the total size of the written data in bytes.

      -

    Returns Promise<void>

  • Appends a chunk of data

    +

Returns Promise<void>

  • Appends a chunk of data

    Parameters

    • array: Uint8Array

      The chunk data to append.

      -

    Returns Promise<void>

Generated using TypeDoc

\ No newline at end of file +

Returns Promise<void>

\ No newline at end of file diff --git a/api/classes/TransformStreamLike.html b/api/classes/TransformStreamLike.html index eb8b2c0e..65d54c71 100644 --- a/api/classes/TransformStreamLike.html +++ b/api/classes/TransformStreamLike.html @@ -1,8 +1,8 @@ TransformStreamLike | @zip.js/zip.js

Class TransformStreamLike

Represents a generic TransformStream class.

Constructors

Constructors

Properties

Constructors

Properties

readable: ReadableStream<any>

The readable stream.

-
writable: WritableStream<any>

The writable stream.

-

Generated using TypeDoc

\ No newline at end of file +
writable: WritableStream<any>

The writable stream.

+
\ No newline at end of file diff --git a/api/classes/Uint8ArrayReader.html b/api/classes/Uint8ArrayReader.html index 5adf1b7f..e7d63498 100644 --- a/api/classes/Uint8ArrayReader.html +++ b/api/classes/Uint8ArrayReader.html @@ -1,16 +1,16 @@ Uint8ArrayReader | @zip.js/zip.js

Class Uint8ArrayReader

Represents a Reader instance used to read data provided as a Uint8Array instance.

-

Hierarchy (view full)

  • Reader<Uint8Array>
    • Uint8ArrayReader

Constructors

Hierarchy (view full)

  • Reader<Uint8Array>
    • Uint8ArrayReader

Constructors

Properties

Methods

Constructors

Properties

readable: ReadableStream<any>

The ReadableStream instance.

-
size: number

The total size of the data in bytes.

-

Methods

  • Initializes the instance asynchronously

    -

    Returns Promise<void>

  • Reads a chunk of data

    +

Returns Uint8ArrayReader

Properties

readable: ReadableStream<any>

The ReadableStream instance.

+
size: number

The total size of the data in bytes.

+

Methods

  • Initializes the instance asynchronously

    +

    Returns Promise<void>

  • Reads a chunk of data

    Parameters

    • index: number

      The byte index of the data to read.

    • length: number

      The length of the data to read in bytes.

    Returns Promise<Uint8Array>

    A promise resolving to a chunk of data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/Uint8ArrayWriter.html b/api/classes/Uint8ArrayWriter.html index 0aedff32..c5047dde 100644 --- a/api/classes/Uint8ArrayWriter.html +++ b/api/classes/Uint8ArrayWriter.html @@ -1,14 +1,14 @@ Uint8ArrayWriter | @zip.js/zip.js

Class Uint8ArrayWriter

Represents a Writer instance used to retrieve the written data as a Uint8Array instance.

-

Hierarchy (view full)

  • Writer<Uint8Array>
    • Uint8ArrayWriter

Constructors

Hierarchy (view full)

  • Writer<Uint8Array>
    • Uint8ArrayWriter

Constructors

Properties

Methods

Constructors

Properties

writable: WritableStream<any>

The WritableStream instance.

-

Methods

Methods

  • Retrieves all the written data

    Returns Promise<Uint8Array>

    A promise resolving to the written data.

    -
  • Initializes the instance asynchronously

    Parameters

    • Optional size: number

      the total size of the written data in bytes.

      -

    Returns Promise<void>

  • Appends a chunk of data

    +

Returns Promise<void>

  • Appends a chunk of data

    Parameters

    • array: Uint8Array

      The chunk data to append.

      -

    Returns Promise<void>

Generated using TypeDoc

\ No newline at end of file +

Returns Promise<void>

\ No newline at end of file diff --git a/api/classes/Writer.html b/api/classes/Writer.html index 9df07b0d..296cf473 100644 --- a/api/classes/Writer.html +++ b/api/classes/Writer.html @@ -2,16 +2,16 @@

Example

Here is an example of custom Writer class used to write binary strings:

class BinaryStringWriter extends Writer {

constructor() {
super();
this.binaryString = "";
}

writeUint8Array(array) {
for (let indexCharacter = 0; indexCharacter < array.length; indexCharacter++) {
this.binaryString += String.fromCharCode(array[indexCharacter]);
}
}

getData() {
return this.binaryString;
}
}
-

Type Parameters

  • Type

Hierarchy (view full)

Implements

Constructors

Type Parameters

  • Type

Hierarchy (view full)

Implements

Constructors

Properties

Methods

Constructors

Properties

writable: WritableStream<any>

The WritableStream instance.

-

Methods

Methods

  • Retrieves all the written data

    Returns Promise<Type>

    A promise resolving to the written data.

    -
  • Initializes the instance asynchronously

    +
  • Initializes the instance asynchronously

    Parameters

    • Optional size: number

      the total size of the written data in bytes.

      -

    Returns Promise<void>

  • Appends a chunk of data

    +

Returns Promise<void>

  • Appends a chunk of data

    Parameters

    • array: Uint8Array

      The chunk data to append.

      -

    Returns Promise<void>

Generated using TypeDoc

\ No newline at end of file +

Returns Promise<void>

\ No newline at end of file diff --git a/api/classes/ZipDeflate.html b/api/classes/ZipDeflate.html index 612a2654..41e1104c 100644 --- a/api/classes/ZipDeflate.html +++ b/api/classes/ZipDeflate.html @@ -1,10 +1,10 @@ ZipDeflate | @zip.js/zip.js

Class ZipDeflate

Represents an instance used to compress data.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Methods

Constructors

Methods

  • Appends a chunk of decompressed data to compress

    Parameters

    • data: Uint8Array

      The chunk of decompressed data to append.

    Returns Uint8Array

    A chunk of compressed data.

    -
  • Flushes the data

    Returns Uint8Array

    A chunk of compressed data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/ZipDirectoryEntry.html b/api/classes/ZipDirectoryEntry.html index e67f2e57..a921f783 100644 --- a/api/classes/ZipDirectoryEntry.html +++ b/api/classes/ZipDirectoryEntry.html @@ -1,5 +1,5 @@ ZipDirectoryEntry | @zip.js/zip.js

Class ZipDirectoryEntry

Represents a directory entry in the zip (Filesystem API).

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Constructors

Properties

children: ZipEntry[]

The children of the entry.

-

The underlying EntryMetaData instance.

-
directory: true

true for ZipDirectoryEntry instances.

-
id: number

The ID of the instance.

-
name: string

The relative filename of the entry.

-
parent?: ZipEntry

The parent directory of the entry.

-
uncompressedSize: number

The uncompressed size of the content.

-

Methods

The underlying EntryMetaData instance.

+
directory: true

true for ZipDirectoryEntry instances.

+
id: number

The ID of the instance.

+
name: string

The relative filename of the entry.

+
parent?: ZipEntry

The parent directory of the entry.

+
uncompressedSize: number

The uncompressed size of the content.

+

Methods

  • Adds a entry entry with content provided as a Data URI string encoded in Base64

    +
  • Adds a entry entry with content provided as a Data URI string encoded in Base64

    Parameters

    • name: string

      The relative filename of the entry.

    • dataURI: string

      The Data URI string encoded in Base64.

    • Optional options: ZipWriterAddDataOptions

      The options.

    Returns ZipFileEntry<string, string>

    A ZipFileEntry instance.

    -
  • Adds an entry with content provided via a File instance

    +
  • Adds an entry with content provided via a FileSystemEntry instance

    +
  • Adds an entry with content provided via a FileSystemHandle instance

    +
  • Adds an entry with content fetched from a URL

    +
  • Adds a entry entry with content provided via a ReadableStream instance

    +
  • Adds a entry entry with content provided via a ReadableStream instance

    Parameters

    • name: string

      The relative filename of the entry.

    • readable: ReadableStream<any>

      The ReadableStream instance.

    • Optional options: ZipWriterAddDataOptions

      The options.

    Returns ZipFileEntry<ReadableStream<any>, void>

    A ZipFileEntry instance.

    -
  • Adds an entry with content provided as a Uint8Array instance

    +
  • Adds an entry with content provided as a Uint8Array instance

    Parameters

    • name: string

      The relative filename of the entry.

    • array: Uint8Array

      The Uint8Array instance.

    • Optional options: ZipWriterAddDataOptions

      The options.

    Returns ZipFileEntry<Uint8Array, Uint8Array>

    A ZipFileEntry instance.

    -
  • Tests the password on the entry and all children if any, returns true if the entry is not password protected

    -

    Parameters

    Returns Promise<boolean>

  • Tests the password on the entry and all children if any, returns true if the entry is not password protected

    +

    Parameters

    Returns Promise<boolean>

  • Returns a Blob instance containing a zip file of the entry and its descendants

    +

Returns ZipEntry

  • Returns a Blob instance containing a zip file of the entry and its descendants

    Parameters

    Returns Promise<Blob>

    A promise resolving to the Blob instance.

    -
  • Returns a Data URI string encoded in Base64 containing a zip file of the entry and its descendants

    +
  • Returns a Data URI string encoded in Base64 containing a zip file of the entry and its descendants

    Parameters

    Returns Promise<string>

    A promise resolving to the Data URI string encoded in Base64.

    -
  • Returns a Uint8Array instance containing a zip file of the entry and its descendants

    +
  • Returns a Uint8Array instance containing a zip file of the entry and its descendants

    Parameters

    Returns Promise<Uint8Array>

    A promise resolving to the Uint8Array instance.

    -
  • Creates a zip file via a WritableStream instance containing the entry and its descendants

    +
  • Creates a zip file via a WritableStream instance containing the entry and its descendants

    Parameters

    Returns Promise<WritableStream<any>>

    A promise resolving to the Uint8Array instance.

    -
  • Creates a zip file via a custom Writer instance containing the entry and its descendants

    +
  • Extracts a zip file provided as a Blob instance into the entry

    +
  • Extracts a zip file provided as a Data URI string encoded in Base64 into the entry

    +

Returns Promise<[ZipEntry]>

  • Extracts a zip file provided as a Data URI string encoded in Base64 into the entry

    Parameters

    Returns Promise<[ZipEntry]>

  • Extracts a zip file fetched from a URL into the entry

    +

Returns Promise<[ZipEntry]>

  • Extracts a zip file provided via a ReadableStream instance into the entry

    +

Returns Promise<[ZipEntry]>

  • Extracts a zip file provided via a ReadableStream instance into the entry

    Parameters

    Returns Promise<[ZipEntry]>

  • Extracts a zip file provided as a Uint8Array instance into the entry

    +

Returns Promise<[ZipEntry]>

  • Extracts a zip file provided via a custom Reader instance into the entry

    +

Returns Promise<[ZipEntry]>

  • Tests if a ZipDirectoryEntry instance is an ancestor of the entry

    +

Returns Promise<[ZipEntry]>

  • Set the name of the entry

    +

Returns boolean

  • Set the name of the entry

    Parameters

    • name: string

      The new name of the entry.

      -

    Returns void

Generated using TypeDoc

\ No newline at end of file +

Returns void

\ No newline at end of file diff --git a/api/classes/ZipEntry.html b/api/classes/ZipEntry.html index 1262ad9d..8fe7bab2 100644 --- a/api/classes/ZipEntry.html +++ b/api/classes/ZipEntry.html @@ -1,5 +1,5 @@ ZipEntry | @zip.js/zip.js

Represents an entry in a zip file (Filesystem API).

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Constructors

Properties

children: ZipEntry[]

The children of the entry.

-

The underlying EntryMetaData instance.

-
id: number

The ID of the instance.

-
name: string

The relative filename of the entry.

-
parent?: ZipEntry

The parent directory of the entry.

-
uncompressedSize: number

The uncompressed size of the content.

-

Methods

  • Tests the password on the entry and all children if any, returns true if the entry is not password protected

    -

    Parameters

    Returns Promise<boolean>

The underlying EntryMetaData instance.

+
id: number

The ID of the instance.

+
name: string

The relative filename of the entry.

+
parent?: ZipEntry

The parent directory of the entry.

+
uncompressedSize: number

The uncompressed size of the content.

+

Methods

  • Tests the password on the entry and all children if any, returns true if the entry is not password protected

    +

    Parameters

    Returns Promise<boolean>

  • Clones the entry

    Parameters

    • Optional deepClone: boolean

      true to clone all the descendants.

      -

    Returns ZipEntry

  • Returns the full filename of the entry

    -

    Returns string

  • Returns the filename of the entry relative to a parent directory

    -

    Parameters

    Returns string

  • Tests if a ZipDirectoryEntry instance is an ancestor of the entry

    +

Returns ZipEntry

  • Returns the full filename of the entry

    +

    Returns string

  • Returns the filename of the entry relative to a parent directory

    +

    Parameters

    Returns string

  • Tests if the entry or any of its children is password protected

    -

    Returns boolean

  • Set the name of the entry

    +

Returns boolean

  • Tests if the entry or any of its children is password protected

    +

    Returns boolean

  • Set the name of the entry

    Parameters

    • name: string

      The new name of the entry.

      -

    Returns void

Generated using TypeDoc

\ No newline at end of file +

Returns void

\ No newline at end of file diff --git a/api/classes/ZipFileEntry.html b/api/classes/ZipFileEntry.html index 4f81108c..5837bef7 100644 --- a/api/classes/ZipFileEntry.html +++ b/api/classes/ZipFileEntry.html @@ -1,5 +1,5 @@ ZipFileEntry | @zip.js/zip.js

Class ZipFileEntry<ReaderType, WriterType>

Represents a file entry in the zip (Filesystem API).

-

Type Parameters

  • ReaderType
  • WriterType

Hierarchy (view full)

Constructors

Type Parameters

  • ReaderType
  • WriterType

Hierarchy (view full)

Constructors

Properties

Constructors

Properties

children: ZipEntry[]

The children of the entry.

-

The underlying EntryMetaData instance.

-
directory: void

void for ZipFileEntry instances.

-
id: number

The ID of the instance.

-
name: string

The relative filename of the entry.

-
parent?: ZipEntry

The parent directory of the entry.

-
reader: ReadableStream<any> | ReadableReader | Reader<unknown>[] | ReadableReader[] | ReadableStream<any>[] | Reader<ReaderType>

The Reader instance used to read the content of the entry.

-
uncompressedSize: number

The uncompressed size of the content.

-
writer: WritableStream<any> | WritableWriter | Writer<WriterType> | AsyncGenerator<WritableStream<any> | WritableWriter | Writer<unknown>, any, unknown>

The Writer instance used to write the content of the entry.

-

Methods

  • Tests the password on the entry and all children if any, returns true if the entry is not password protected

    -

    Parameters

    Returns Promise<boolean>

The underlying EntryMetaData instance.

+
directory: void

void for ZipFileEntry instances.

+
id: number

The ID of the instance.

+
name: string

The relative filename of the entry.

+
parent?: ZipEntry

The parent directory of the entry.

+
reader: ReadableStream<any> | ReadableReader | Reader<unknown>[] | ReadableReader[] | ReadableStream<any>[] | Reader<ReaderType>

The Reader instance used to read the content of the entry.

+
uncompressedSize: number

The uncompressed size of the content.

+
writer: WritableStream<any> | WritableWriter | Writer<WriterType> | AsyncGenerator<WritableStream<any> | WritableWriter | Writer<unknown>, any, unknown>

The Writer instance used to write the content of the entry.

+

Methods

  • Tests the password on the entry and all children if any, returns true if the entry is not password protected

    +

    Parameters

    Returns Promise<boolean>

  • Retrieves the content of the entry as a Blob instance

    +

Returns ZipEntry

  • Retrieves the content of the entry as a Blob instance

    Parameters

    • Optional mimeType: string

      The MIME type of the content.

    • Optional options: EntryGetDataOptions

      The options.

    Returns Promise<Blob>

    A promise resolving to a Blob instance.

    -
  • Retrieves the content of the entry via a Writer instance

    +
  • Retrieves the content of the entry as as a Data URI string encoded in Base64

    +
  • Retrieves the content of the entry as as a Data URI string encoded in Base64

    Parameters

    • Optional mimeType: string

      The MIME type of the content.

    • Optional options: EntryGetDataOptions

      The options.

    Returns Promise<string>

    A promise resolving to a Data URI string encoded in Base64.

    -
  • Retrieves the text content of the entry as a string

    +
  • Retrieves the text content of the entry as a string

    Parameters

    • Optional encoding: string

      The encoding of the text.

    • Optional options: EntryGetDataOptions

      The options.

    Returns Promise<string>

    A promise resolving to a string.

    -
  • Retrieves the content of the entry as a Uint8Array instance

    +
  • Retrieves the content of the entry as a Uint8Array instance

    Parameters

    Returns Promise<Uint8Array>

    A promise resolving to a Uint8Array instance.

    -
  • Retrieves the content of the entry via a WritableStream instance

    +
  • Retrieves the content of the entry via a WritableStream instance

    Parameters

    • Optional writable: WritableStream<any>

      The WritableStream instance.

    • Optional options: EntryGetDataOptions

      The options.

    Returns Promise<WritableStream<any>>

    A promise resolving to the WritableStream instance.

    -
  • Set the name of the entry

    +

Returns boolean

  • Set the name of the entry

    Parameters

    • name: string

      The new name of the entry.

      -

    Returns void

  • Replaces the content of the entry with a Blob instance

    +

Returns void

  • Replaces the content of the entry with a Blob instance

    Parameters

    • blob: Blob

      The Blob instance.

      -

    Returns void

  • Replaces the content of the entry with a Data URI string encoded in Base64

    +

Returns void

  • Replaces the content of the entry with a Data URI string encoded in Base64

    Parameters

    • dataURI: string

      The Data URI string encoded in Base64.

      -

    Returns void

  • Replaces the content of the entry with a ReadableStream instance

    +

Returns void

  • Replaces the content of the entry with a ReadableStream instance

    Parameters

    • readable: ReadableStream<any>

      The ReadableStream instance.

      -

    Returns void

  • Replaces the content of the entry with a string

    +

Returns void

  • Replaces the content of the entry with a string

    Parameters

    • text: string

      The string.

      -

    Returns void

  • Replaces the content of the entry with a Uint8Array instance

    +

Returns void

  • Replaces the content of the entry with a Uint8Array instance

    Parameters

    • array: Uint8Array

      The Uint8Array instance.

      -

    Returns void

Generated using TypeDoc

\ No newline at end of file +

Returns void

\ No newline at end of file diff --git a/api/classes/ZipInflate.html b/api/classes/ZipInflate.html index d0ef3e66..ca9277f8 100644 --- a/api/classes/ZipInflate.html +++ b/api/classes/ZipInflate.html @@ -1,9 +1,9 @@ ZipInflate | @zip.js/zip.js

Class ZipInflate

Represents a codec used to decompress data.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Methods

Constructors

Methods

  • Appends a chunk of decompressed data to compress

    Parameters

    • data: Uint8Array

      The chunk of decompressed data to append.

    Returns Uint8Array

    A chunk of compressed data.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/ZipReader.html b/api/classes/ZipReader.html index 7248d238..0c0ddfa3 100644 --- a/api/classes/ZipReader.html +++ b/api/classes/ZipReader.html @@ -2,7 +2,7 @@

Example

Here is an example showing how to read the text data of the first entry from a zip file:

// create a BlobReader to read with a ZipReader the zip from a Blob object
const reader = new zip.ZipReader(new zip.BlobReader(blob));

// get all entries from the zip
const entries = await reader.getEntries();
if (entries.length) {

// get first entry content as text by using a TextWriter
const text = await entries[0].getData(
// writer
new zip.TextWriter(),
// options
{
onprogress: (index, max) => {
// onprogress callback
}
}
);
// text contains the entry data as a String
console.log(text);
}

// close the ZipReader
await reader.close();
-

Type Parameters

  • Type

Constructors

Type Parameters

  • Type

Constructors

Properties

appendedData? comment prependedData? @@ -12,14 +12,14 @@

Constructors

Properties

appendedData?: Uint8Array

The data appended after the zip file.

-
comment: Uint8Array

The global comment of the zip file.

-
prependedData?: Uint8Array

The data prepended before the zip file.

-

Methods

  • Closes the zip file

    -

    Returns Promise<void>

  • Returns all the entries in the zip file

    +

Returns ZipReader<Type>

Properties

appendedData?: Uint8Array

The data appended after the zip file.

+
comment: Uint8Array

The global comment of the zip file.

+
prependedData?: Uint8Array

The data prepended before the zip file.

+

Methods

  • Closes the zip file

    +

    Returns Promise<void>

  • Returns a generator used to iterate on all the entries in the zip file

    +
  • Returns a generator used to iterate on all the entries in the zip file

    Parameters

    Returns AsyncGenerator<Entry, boolean, unknown>

    An asynchronous generator of Entry instances.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/ZipReaderStream.html b/api/classes/ZipReaderStream.html index d3170c79..4952dc11 100644 --- a/api/classes/ZipReaderStream.html +++ b/api/classes/ZipReaderStream.html @@ -2,11 +2,11 @@

Example

This example will take a zip file, decompress it and then recompress each file in it, saving it to disk.

for await (const entry of (await fetch(urlToZippedFile)).body.pipeThrough(new ZipWriterStream()))
if (entry.readable) {
console.log(entry.filename)
entry.readable
.pipeThrough(ZipReaderStream().transform(entry.filename))
.pipeTo((await Deno.create(entry.filename + '.zip')).writable)
}
-

Type Parameters

  • T

Constructors

Type Parameters

  • T

Constructors

Properties

Constructors

Properties

readable: ReadableStream<Omit<Entry, "getData"> & {
    readable?: ReadableStream<Uint8Array>;
}>

The readable stream.

-
writable: WritableStream<T>

The writable stream.

-

Generated using TypeDoc

\ No newline at end of file +

Returns ZipReaderStream<T>

Properties

readable: ReadableStream<Omit<Entry, "getData"> & {
    readable?: ReadableStream<Uint8Array>;
}>

The readable stream.

+
writable: WritableStream<T>

The writable stream.

+
\ No newline at end of file diff --git a/api/classes/ZipWriter.html b/api/classes/ZipWriter.html index 8d33ce4b..ab0567e9 100644 --- a/api/classes/ZipWriter.html +++ b/api/classes/ZipWriter.html @@ -2,21 +2,21 @@

Example

Here is an example showing how to create a zip file containing a compressed text file:

// use a BlobWriter to store with a ZipWriter the zip into a Blob object
const blobWriter = new zip.BlobWriter("application/zip");
const writer = new zip.ZipWriter(blobWriter);

// use a TextReader to read the String to add
await writer.add("filename.txt", new zip.TextReader("test!"));

// close the ZipReader
await writer.close();

// get the zip file as a Blob
const blob = await blobWriter.getData();
-

Type Parameters

  • Type

Constructors

Type Parameters

  • Type

Constructors

Properties

Methods

Constructors

Properties

hasCorruptedEntries?: boolean

true if the zip contains at least one entry that has been partially written.

-

Methods

Returns ZipWriter<Type>

Properties

hasCorruptedEntries?: boolean

true if the zip contains at least one entry that has been partially written.

+

Methods

  • Writes the entries directory, writes the global comment, and returns the content of the zip file

    +
  • Writes the entries directory, writes the global comment, and returns the content of the zip file

    Parameters

    • Optional comment: Uint8Array

      The global comment of the zip file.

    • Optional options: ZipWriterCloseOptions

      The options.

    Returns Promise<Type>

    The content of the zip file.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/classes/ZipWriterStream.html b/api/classes/ZipWriterStream.html index 46ab0ebe..b122a700 100644 --- a/api/classes/ZipWriterStream.html +++ b/api/classes/ZipWriterStream.html @@ -5,7 +5,7 @@

Example

This example creates a zipped file called Archive.zip containing two files called numbers.txt and letters.txt

const readable1 = ReadableStream.from((function* () {
for (let i = 0; i < 1000; ++i)
yield i + '\n'
})())
const readable2 = ReadableStream.from((function* () {
const letters = 'abcdefghijklmnopqrstuvwxyz'.split('')
while (letters.length)
yield letters.shift() + '\n'
})())

const zipper = new ZipWriterStream()
zipper.readable.pipeTo((await Deno.create('Archive.zip')).writable)
readable1.pipeTo(zipper.writable('numbers.txt'))
readable2.pipeTo(zipper.writable('letters.txt'))
zipper.close()
-

Constructors

Constructors

Properties

Methods

close @@ -13,16 +13,16 @@

Example

This example creates a zipped file called Archive.zip contain writable

Constructors

Properties

readable: ReadableStream<Uint8Array>

The readable stream.

-
zipWriter: ZipWriter<unknown>

The ZipWriter property.

-

Methods

  • Writes the entries directory, writes the global comment, and returns the content of the zipped file.

    +

Returns ZipWriterStream

Properties

readable: ReadableStream<Uint8Array>

The readable stream.

+
zipWriter: ZipWriter<unknown>

The ZipWriter property.

+

Methods

  • Writes the entries directory, writes the global comment, and returns the content of the zipped file.

    Parameters

    • Optional comment: Uint8Array

      The global comment of the zip file.

    • Optional options: ZipWriterCloseOptions

      The options.

    Returns Promise<unknown>

    The content of the zip file.

    -
  • Returns an object containing a readable and writable property for the .pipeThrough method

    +
  • Returns an object containing a readable and writable property for the .pipeThrough method

    Type Parameters

    • T

    Parameters

    • path: string

      The name of the stream when unzipped.

    Returns {
        readable: ReadableStream<T>;
        writable: WritableStream<T>;
    }

    An object containing readable and writable properties

    -
    • readable: ReadableStream<T>
    • writable: WritableStream<T>
  • Returns a WritableStream for the .pipeTo method

    +
    • readable: ReadableStream<T>
    • writable: WritableStream<T>
  • Returns a WritableStream for the .pipeTo method

    Type Parameters

    • T

    Parameters

    • path: string

      The directory path of where the stream should exist in the zipped stream.

    Returns WritableStream<T>

    A WritableStream.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/functions/configure.html b/api/functions/configure.html index 84d26ee7..8f5a7667 100644 --- a/api/functions/configure.html +++ b/api/functions/configure.html @@ -1,3 +1,3 @@ configure | @zip.js/zip.js

Function configure

  • Configures zip.js

    Parameters

    Returns void

Generated using TypeDoc

\ No newline at end of file +

Returns void

\ No newline at end of file diff --git a/api/functions/getMimeType.html b/api/functions/getMimeType.html index dbcee440..959df6d4 100644 --- a/api/functions/getMimeType.html +++ b/api/functions/getMimeType.html @@ -1,4 +1,4 @@ getMimeType | @zip.js/zip.js

Function getMimeType

  • Returns the MIME type corresponding to a filename extension.

    Parameters

    • fileExtension: string

      the extension of the filename.

    Returns string

    The corresponding MIME type.

    -

Generated using TypeDoc

\ No newline at end of file +
\ No newline at end of file diff --git a/api/functions/initShimAsyncCodec.html b/api/functions/initShimAsyncCodec.html index e98ca914..2db8cffc 100644 --- a/api/functions/initShimAsyncCodec.html +++ b/api/functions/initShimAsyncCodec.html @@ -3,4 +3,4 @@
  • constructorOptions: unknown

    The options passed to the third-party implementations when building instances.

  • registerDataHandler: registerDataHandler

    The function called to handle the data events triggered by a third-party codec implementation.

  • Returns ZipLibrary

    An instance containing classes compatible with ZipDeflate and ZipInflate.

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/functions/terminateWorkers.html b/api/functions/terminateWorkers.html index c9e46ba0..2b40cb46 100644 --- a/api/functions/terminateWorkers.html +++ b/api/functions/terminateWorkers.html @@ -1,2 +1,2 @@ terminateWorkers | @zip.js/zip.js

    Function terminateWorkers

    • Terminates all the web workers

      -

      Returns Promise<void>

    Generated using TypeDoc

    \ No newline at end of file +

    Returns Promise<void>

    \ No newline at end of file diff --git a/api/hierarchy.html b/api/hierarchy.html index 89f1ace1..cf2b919d 100644 --- a/api/hierarchy.html +++ b/api/hierarchy.html @@ -1 +1 @@ -@zip.js/zip.js

    Generated using TypeDoc

    \ No newline at end of file +@zip.js/zip.js
    \ No newline at end of file diff --git a/api/index.html b/api/index.html index 6045d1ba..d338a5d8 100644 --- a/api/index.html +++ b/api/index.html @@ -15,4 +15,4 @@

    Run the code on Plunker: https://plnkr.co/edit/4sVljNIpqSUE9HCA?preview

    Tests

    See https://github.com/gildas-lormeau/zip.js/tree/master/tests/all

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/Configuration.html b/api/interfaces/Configuration.html index faa7f602..8980741c 100644 --- a/api/interfaces/Configuration.html +++ b/api/interfaces/Configuration.html @@ -1,5 +1,5 @@ Configuration | @zip.js/zip.js

    Interface Configuration

    Represents the configuration passed to configure.

    -
    interface Configuration {
        CompressionStream?: typeof TransformStreamLike;
        DecompressionStream?: typeof TransformStreamLike;
        Deflate?: typeof ZipDeflate;
        Inflate?: typeof ZipInflate;
        chunkSize?: number;
        maxWorkers?: number;
        terminateWorkerTimeout?: number;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
        workerScripts?: {
            deflate?: string[];
            inflate?: string[];
        };
    }

    Hierarchy (view full)

    Properties

    interface Configuration {
        CompressionStream?: typeof TransformStreamLike;
        DecompressionStream?: typeof TransformStreamLike;
        Deflate?: typeof ZipDeflate;
        Inflate?: typeof ZipInflate;
        chunkSize?: number;
        maxWorkers?: number;
        terminateWorkerTimeout?: number;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
        workerScripts?: {
            deflate?: string[];
            inflate?: string[];
        };
    }

    Hierarchy (view full)

    Properties

    CompressionStream?: typeof TransformStreamLike

    The stream implementation used to compress data when useCompressionStream is set to false.

    Default Value

    {@link CodecStream}
     
    -
    DecompressionStream?: typeof TransformStreamLike

    The stream implementation used to decompress data when useCompressionStream is set to false.

    +
    DecompressionStream?: typeof TransformStreamLike

    The stream implementation used to decompress data when useCompressionStream is set to false.

    Default Value

    {@link CodecStream}
     
    -
    Deflate?: typeof ZipDeflate

    The codec implementation used to compress data.

    +
    Deflate?: typeof ZipDeflate

    The codec implementation used to compress data.

    Default Value

    {@link ZipDeflate}
     
    -
    Inflate?: typeof ZipInflate

    The codec implementation used to decompress data.

    +
    Inflate?: typeof ZipInflate

    The codec implementation used to decompress data.

    Default Value

    {@link ZipInflate}
     
    -
    chunkSize?: number

    The size of the chunks in bytes during data compression/decompression.

    +
    chunkSize?: number

    The size of the chunks in bytes during data compression/decompression.

    Default Value

    524288
     
    -
    maxWorkers?: number

    The maximum number of web workers used to compress/decompress data simultaneously.

    +
    maxWorkers?: number

    The maximum number of web workers used to compress/decompress data simultaneously.

    Default Value

    navigator.hardwareConcurrency

    -
    terminateWorkerTimeout?: number

    The delay in milliseconds before idle web workers are automatically terminated. You can call terminateWorkers() to terminate idle workers.

    +
    terminateWorkerTimeout?: number

    The delay in milliseconds before idle web workers are automatically terminated. You can call terminateWorkers() to terminate idle workers.

    Default Value

    5000
     
    -
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    +
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    Default Value

    true
     
    -
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    +
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    Default Value

    true
     
    -
    workerScripts?: {
        deflate?: string[];
        inflate?: string[];
    }

    The URIs of the compression/decompression scripts run in web workers.

    +
    workerScripts?: {
        deflate?: string[];
        inflate?: string[];
    }

    The URIs of the compression/decompression scripts run in web workers.

    It allows using alternative deflate implementations or specifying a URL to the worker script if the CSP of the page blocks scripts imported from a Blob URI. The properties deflate and inflate must specify arrays of URLs to import the deflate/inflate web workers, respectively. The first URL is relative to the base URI of the document. The other URLs are relative to the URL of the first script. Scripts in the array are executed in order. @@ -49,4 +49,4 @@

    Type declaration

    • Optional deflate?: string[]

      The URIs of the scripts implementing used for compression.

    • Optional inflate?: string[]

      The URIs of the scripts implementing used for decompression.

      -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/Entry.html b/api/interfaces/Entry.html index 6da1cf32..8043adce 100644 --- a/api/interfaces/Entry.html +++ b/api/interfaces/Entry.html @@ -1,5 +1,5 @@ Entry | @zip.js/zip.js

    Interface Entry

    Represents an entry with its data and metadata in a zip file (Core API).

    -
    interface Entry {
        comment: string;
        commentUTF8: boolean;
        compressedSize: number;
        creationDate?: Date;
        directory: boolean;
        diskNumberStart: number;
        encrypted: boolean;
        externalFileAttribute: number;
        extraField?: Map<number, Uint8Array>;
        filename: string;
        filenameUTF8: boolean;
        internalFileAttribute: number;
        lastAccessDate?: Date;
        lastModDate: Date;
        msDosCompatible: boolean;
        offset: number;
        rawComment: Uint8Array;
        rawCreationDate?: number | bigint;
        rawExtraField: Uint8Array;
        rawFilename: Uint8Array;
        rawLastAccessDate?: number | bigint;
        rawLastModDate: number | bigint;
        signature: number;
        uncompressedSize: number;
        version: number;
        versionMadeBy: number;
        zip64: boolean;
        getData?<Type>(writer, options?): Promise<Type>;
        getData?(writer, options): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    interface Entry {
        comment: string;
        commentUTF8: boolean;
        compressedSize: number;
        creationDate?: Date;
        directory: boolean;
        diskNumberStart: number;
        encrypted: boolean;
        externalFileAttribute: number;
        extraField?: Map<number, Uint8Array>;
        filename: string;
        filenameUTF8: boolean;
        internalFileAttribute: number;
        lastAccessDate?: Date;
        lastModDate: Date;
        msDosCompatible: boolean;
        offset: number;
        rawComment: Uint8Array;
        rawCreationDate?: number | bigint;
        rawExtraField: Uint8Array;
        rawFilename: Uint8Array;
        rawLastAccessDate?: number | bigint;
        rawLastModDate: number | bigint;
        signature: number;
        uncompressedSize: number;
        version: number;
        versionMadeBy: number;
        zip64: boolean;
        getData?<Type>(writer, options?): Promise<Type>;
        getData?(writer, options): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    Methods

    Properties

    comment: string

    The comment of the entry.

    -
    commentUTF8: boolean

    true if the comment is encoded in UTF-8.

    -
    compressedSize: number

    The size of the compressed data in bytes.

    -
    creationDate?: Date

    The creation date.

    -
    directory: boolean

    true if the entry is a directory.

    -
    diskNumberStart: number

    The number of the disk where the entry data starts.

    -
    encrypted: boolean

    true if the content of the entry is encrypted.

    -
    externalFileAttribute: number

    The external file attribute (raw).

    -
    extraField?: Map<number, Uint8Array>

    The extra field.

    -
    filename: string

    The filename of the entry.

    -
    filenameUTF8: boolean

    true if the filename is encoded in UTF-8.

    -
    internalFileAttribute: number

    The internal file attribute (raw).

    -
    lastAccessDate?: Date

    The last access date.

    -
    lastModDate: Date

    The last modification date.

    -
    msDosCompatible: boolean

    true if internalFileAttribute and externalFileAttribute are compatible with MS-DOS format.

    -
    offset: number

    The byte offset of the entry.

    -
    rawComment: Uint8Array

    The comment of the entry (raw).

    -
    rawCreationDate?: number | bigint

    The creation date (raw).

    -
    rawExtraField: Uint8Array

    The extra field (raw).

    -
    rawFilename: Uint8Array

    The filename of the entry (raw).

    -
    rawLastAccessDate?: number | bigint

    The last access date (raw).

    -
    rawLastModDate: number | bigint

    The last modification date (raw).

    -
    signature: number

    The signature (CRC32 checksum) of the content.

    -
    uncompressedSize: number

    The size of the decompressed data in bytes.

    -
    version: number

    The "Version" field.

    -
    versionMadeBy: number

    The "Version made by" field.

    -
    zip64: boolean

    true if the entry is using Zip64.

    -

    Methods

    commentUTF8: boolean

    true if the comment is encoded in UTF-8.

    +
    compressedSize: number

    The size of the compressed data in bytes.

    +
    creationDate?: Date

    The creation date.

    +
    directory: boolean

    true if the entry is a directory.

    +
    diskNumberStart: number

    The number of the disk where the entry data starts.

    +
    encrypted: boolean

    true if the content of the entry is encrypted.

    +
    externalFileAttribute: number

    The external file attribute (raw).

    +
    extraField?: Map<number, Uint8Array>

    The extra field.

    +
    filename: string

    The filename of the entry.

    +
    filenameUTF8: boolean

    true if the filename is encoded in UTF-8.

    +
    internalFileAttribute: number

    The internal file attribute (raw).

    +
    lastAccessDate?: Date

    The last access date.

    +
    lastModDate: Date

    The last modification date.

    +
    msDosCompatible: boolean

    true if internalFileAttribute and externalFileAttribute are compatible with MS-DOS format.

    +
    offset: number

    The byte offset of the entry.

    +
    rawComment: Uint8Array

    The comment of the entry (raw).

    +
    rawCreationDate?: number | bigint

    The creation date (raw).

    +
    rawExtraField: Uint8Array

    The extra field (raw).

    +
    rawFilename: Uint8Array

    The filename of the entry (raw).

    +
    rawLastAccessDate?: number | bigint

    The last access date (raw).

    +
    rawLastModDate: number | bigint

    The last modification date (raw).

    +
    signature: number

    The signature (CRC32 checksum) of the content.

    +
    uncompressedSize: number

    The size of the decompressed data in bytes.

    +
    version: number

    The "Version" field.

    +
    versionMadeBy: number

    The "Version made by" field.

    +
    zip64: boolean

    true if the entry is using Zip64.

    +

    Methods

    • Returns the content of the entry

      Type Parameters

      • Type

      Parameters

      Returns Promise<Type>

      A promise resolving to the type to data associated to writer.

      -
    • Tests if the password is valid.

      +
    • Tests if the password is valid.

      Parameters

      Returns Promise<void>

    Generated using TypeDoc

    \ No newline at end of file +

    Returns Promise<void>

    \ No newline at end of file diff --git a/api/interfaces/EntryDataOnprogressOptions.html b/api/interfaces/EntryDataOnprogressOptions.html index 8a88177e..8ffb6ca7 100644 --- a/api/interfaces/EntryDataOnprogressOptions.html +++ b/api/interfaces/EntryDataOnprogressOptions.html @@ -1,15 +1,15 @@ EntryDataOnprogressOptions | @zip.js/zip.js

    Interface EntryDataOnprogressOptions

    Represents options passed to Entry#getData, ZipWriter.add and {@link ZipDirectory}.export*.

    -
    interface EntryDataOnprogressOptions {
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Methods

    interface EntryDataOnprogressOptions {
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Methods

    • The function called when ending compression/decompression.

      Parameters

      • computedSize: number

        The total number of bytes (computed).

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called during compression/decompression.

      +
    • The function called during compression/decompression.

      Parameters

      • progress: number

        The current progress in bytes.

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called when starting compression/decompression.

      +
    • The function called when starting compression/decompression.

      Parameters

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/EntryGetDataCheckPasswordOptions.html b/api/interfaces/EntryGetDataCheckPasswordOptions.html index 420e21ed..ea158fc9 100644 --- a/api/interfaces/EntryGetDataCheckPasswordOptions.html +++ b/api/interfaces/EntryGetDataCheckPasswordOptions.html @@ -1,5 +1,5 @@ EntryGetDataCheckPasswordOptions | @zip.js/zip.js

    Interface EntryGetDataCheckPasswordOptions

    Represents the options passed to Entry#getData and {@link ZipFileEntry}.get*.

    -
    interface EntryGetDataCheckPasswordOptions {
        checkPasswordOnly: boolean;
        checkSignature?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    interface EntryGetDataCheckPasswordOptions {
        checkPasswordOnly: boolean;
        checkSignature?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    checkPasswordOnly: boolean

    true to check only if the password is valid.

    Default Value

    false
     
    -
    checkSignature?: boolean

    true to check the signature of the entry.

    +
    checkSignature?: boolean

    true to check the signature of the entry.

    Default Value

    false
     
    -
    password?: string

    The password used to decrypt the content of the entry.

    -
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    +
    password?: string

    The password used to decrypt the content of the entry.

    +
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    Default Value

    false
     
    -
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    -
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    -
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    +
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    +
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    +
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    Default Value

    true
     
    -
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    +
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    Default Value

    true
     
    -
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    +
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    Default Value

    true
     
    -

    Methods

    Methods

    • The function called when ending compression/decompression.

      Parameters

      • computedSize: number

        The total number of bytes (computed).

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called during compression/decompression.

      Parameters

      • progress: number

        The current progress in bytes.

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called when starting compression/decompression.

      Parameters

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/EntryGetDataOptions.html b/api/interfaces/EntryGetDataOptions.html index b92b7c69..7d9e70c4 100644 --- a/api/interfaces/EntryGetDataOptions.html +++ b/api/interfaces/EntryGetDataOptions.html @@ -1,5 +1,5 @@ EntryGetDataOptions | @zip.js/zip.js

    Interface EntryGetDataOptions

    Represents the options passed to Entry#getData and {@link ZipFileEntry}.get*.

    -
    interface EntryGetDataOptions {
        checkSignature?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    interface EntryGetDataOptions {
        checkSignature?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    Properties

    checkSignature?: boolean

    true to check the signature of the entry.

    Default Value

    false
     
    -
    password?: string

    The password used to decrypt the content of the entry.

    -
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    +
    password?: string

    The password used to decrypt the content of the entry.

    +
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    Default Value

    false
     
    -
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    -
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    -
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    +
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    +
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    +
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    Default Value

    true
     
    -
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    +
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    Default Value

    true
     
    -
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    +
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    Default Value

    true
     
    -

    Methods

    Methods

    • The function called when ending compression/decompression.

      Parameters

      • computedSize: number

        The total number of bytes (computed).

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called during compression/decompression.

      Parameters

      • progress: number

        The current progress in bytes.

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called when starting compression/decompression.

      Parameters

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/EntryMetaData.html b/api/interfaces/EntryMetaData.html index 76767ce8..f4c20d61 100644 --- a/api/interfaces/EntryMetaData.html +++ b/api/interfaces/EntryMetaData.html @@ -1,5 +1,5 @@ EntryMetaData | @zip.js/zip.js

    Interface EntryMetaData

    Represents the metadata of an entry in a zip file (Core API).

    -
    interface EntryMetaData {
        comment: string;
        commentUTF8: boolean;
        compressedSize: number;
        creationDate?: Date;
        directory: boolean;
        diskNumberStart: number;
        encrypted: boolean;
        externalFileAttribute: number;
        extraField?: Map<number, Uint8Array>;
        filename: string;
        filenameUTF8: boolean;
        internalFileAttribute: number;
        lastAccessDate?: Date;
        lastModDate: Date;
        msDosCompatible: boolean;
        offset: number;
        rawComment: Uint8Array;
        rawCreationDate?: number | bigint;
        rawExtraField: Uint8Array;
        rawFilename: Uint8Array;
        rawLastAccessDate?: number | bigint;
        rawLastModDate: number | bigint;
        signature: number;
        uncompressedSize: number;
        version: number;
        versionMadeBy: number;
        zip64: boolean;
    }

    Hierarchy (view full)

    Properties

    interface EntryMetaData {
        comment: string;
        commentUTF8: boolean;
        compressedSize: number;
        creationDate?: Date;
        directory: boolean;
        diskNumberStart: number;
        encrypted: boolean;
        externalFileAttribute: number;
        extraField?: Map<number, Uint8Array>;
        filename: string;
        filenameUTF8: boolean;
        internalFileAttribute: number;
        lastAccessDate?: Date;
        lastModDate: Date;
        msDosCompatible: boolean;
        offset: number;
        rawComment: Uint8Array;
        rawCreationDate?: number | bigint;
        rawExtraField: Uint8Array;
        rawFilename: Uint8Array;
        rawLastAccessDate?: number | bigint;
        rawLastModDate: number | bigint;
        signature: number;
        uncompressedSize: number;
        version: number;
        versionMadeBy: number;
        zip64: boolean;
    }

    Hierarchy (view full)

    Properties

    comment: string

    The comment of the entry.

    -
    commentUTF8: boolean

    true if the comment is encoded in UTF-8.

    -
    compressedSize: number

    The size of the compressed data in bytes.

    -
    creationDate?: Date

    The creation date.

    -
    directory: boolean

    true if the entry is a directory.

    -
    diskNumberStart: number

    The number of the disk where the entry data starts.

    -
    encrypted: boolean

    true if the content of the entry is encrypted.

    -
    externalFileAttribute: number

    The external file attribute (raw).

    -
    extraField?: Map<number, Uint8Array>

    The extra field.

    -
    filename: string

    The filename of the entry.

    -
    filenameUTF8: boolean

    true if the filename is encoded in UTF-8.

    -
    internalFileAttribute: number

    The internal file attribute (raw).

    -
    lastAccessDate?: Date

    The last access date.

    -
    lastModDate: Date

    The last modification date.

    -
    msDosCompatible: boolean

    true if internalFileAttribute and externalFileAttribute are compatible with MS-DOS format.

    -
    offset: number

    The byte offset of the entry.

    -
    rawComment: Uint8Array

    The comment of the entry (raw).

    -
    rawCreationDate?: number | bigint

    The creation date (raw).

    -
    rawExtraField: Uint8Array

    The extra field (raw).

    -
    rawFilename: Uint8Array

    The filename of the entry (raw).

    -
    rawLastAccessDate?: number | bigint

    The last access date (raw).

    -
    rawLastModDate: number | bigint

    The last modification date (raw).

    -
    signature: number

    The signature (CRC32 checksum) of the content.

    -
    uncompressedSize: number

    The size of the decompressed data in bytes.

    -
    version: number

    The "Version" field.

    -
    versionMadeBy: number

    The "Version made by" field.

    -
    zip64: boolean

    true if the entry is using Zip64.

    -

    Generated using TypeDoc

    \ No newline at end of file +
    commentUTF8: boolean

    true if the comment is encoded in UTF-8.

    +
    compressedSize: number

    The size of the compressed data in bytes.

    +
    creationDate?: Date

    The creation date.

    +
    directory: boolean

    true if the entry is a directory.

    +
    diskNumberStart: number

    The number of the disk where the entry data starts.

    +
    encrypted: boolean

    true if the content of the entry is encrypted.

    +
    externalFileAttribute: number

    The external file attribute (raw).

    +
    extraField?: Map<number, Uint8Array>

    The extra field.

    +
    filename: string

    The filename of the entry.

    +
    filenameUTF8: boolean

    true if the filename is encoded in UTF-8.

    +
    internalFileAttribute: number

    The internal file attribute (raw).

    +
    lastAccessDate?: Date

    The last access date.

    +
    lastModDate: Date

    The last modification date.

    +
    msDosCompatible: boolean

    true if internalFileAttribute and externalFileAttribute are compatible with MS-DOS format.

    +
    offset: number

    The byte offset of the entry.

    +
    rawComment: Uint8Array

    The comment of the entry (raw).

    +
    rawCreationDate?: number | bigint

    The creation date (raw).

    +
    rawExtraField: Uint8Array

    The extra field (raw).

    +
    rawFilename: Uint8Array

    The filename of the entry (raw).

    +
    rawLastAccessDate?: number | bigint

    The last access date (raw).

    +
    rawLastModDate: number | bigint

    The last modification date (raw).

    +
    signature: number

    The signature (CRC32 checksum) of the content.

    +
    uncompressedSize: number

    The size of the decompressed data in bytes.

    +
    version: number

    The "Version" field.

    +
    versionMadeBy: number

    The "Version made by" field.

    +
    zip64: boolean

    true if the entry is using Zip64.

    +
    \ No newline at end of file diff --git a/api/interfaces/EntryOnprogressOptions.html b/api/interfaces/EntryOnprogressOptions.html index c11b297a..fdd3f7e1 100644 --- a/api/interfaces/EntryOnprogressOptions.html +++ b/api/interfaces/EntryOnprogressOptions.html @@ -1,8 +1,8 @@ EntryOnprogressOptions | @zip.js/zip.js

    Interface EntryOnprogressOptions

    interface EntryOnprogressOptions {
        onprogress?(progress, total, entry): Promise<void>;
    }

    Hierarchy (view full)

    Methods

    interface EntryOnprogressOptions {
        onprogress?(progress, total, entry): Promise<void>;
    }

    Hierarchy (view full)

    Methods

    Methods

    • The function called each time an entry is read/written.

      Parameters

      • progress: number

        The entry index.

      • total: number

        The total number of entries.

      • entry: EntryMetaData

        The entry being read/written.

      Returns Promise<void>

      An empty promise or undefined.

      -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/EventBasedZipLibrary.html b/api/interfaces/EventBasedZipLibrary.html index 53311d03..9af7b217 100644 --- a/api/interfaces/EventBasedZipLibrary.html +++ b/api/interfaces/EventBasedZipLibrary.html @@ -1,6 +1,6 @@ EventBasedZipLibrary | @zip.js/zip.js

    Interface EventBasedZipLibrary

    Represents event-based implementations used to compress/decompress data.

    -
    interface EventBasedZipLibrary {
        Deflate: typeof EventBasedCodec;
        Inflate: typeof EventBasedCodec;
    }

    Properties

    interface EventBasedZipLibrary {
        Deflate: typeof EventBasedCodec;
        Inflate: typeof EventBasedCodec;
    }

    Properties

    Properties

    Deflate: typeof EventBasedCodec

    The class used to compress data.

    -
    Inflate: typeof EventBasedCodec

    The class used to decompress data.

    -

    Generated using TypeDoc

    \ No newline at end of file +
    Inflate: typeof EventBasedCodec

    The class used to decompress data.

    +
    \ No newline at end of file diff --git a/api/interfaces/FileSystemEntryLike.html b/api/interfaces/FileSystemEntryLike.html index 922ce0a8..58017a27 100644 --- a/api/interfaces/FileSystemEntryLike.html +++ b/api/interfaces/FileSystemEntryLike.html @@ -1,3 +1,3 @@ FileSystemEntryLike | @zip.js/zip.js

    Interface FileSystemEntryLike

    Represents the FileSystemEntry class.

    interface FileSystemEntryLike {}

    Generated using TypeDoc

    \ No newline at end of file +
    interface FileSystemEntryLike {}
    \ No newline at end of file diff --git a/api/interfaces/FileSystemHandleLike.html b/api/interfaces/FileSystemHandleLike.html index f881d00d..0e70fdca 100644 --- a/api/interfaces/FileSystemHandleLike.html +++ b/api/interfaces/FileSystemHandleLike.html @@ -1,3 +1,3 @@ FileSystemHandleLike | @zip.js/zip.js

    Interface FileSystemHandleLike

    Represents the FileSystemHandle class.

    interface FileSystemHandleLike {}

    Generated using TypeDoc

    \ No newline at end of file +
    interface FileSystemHandleLike {}
    \ No newline at end of file diff --git a/api/interfaces/GetEntriesOptions.html b/api/interfaces/GetEntriesOptions.html index f7cbe3ab..e21b5fd7 100644 --- a/api/interfaces/GetEntriesOptions.html +++ b/api/interfaces/GetEntriesOptions.html @@ -1,6 +1,11 @@ GetEntriesOptions | @zip.js/zip.js

    Interface GetEntriesOptions

    Represents options passed to the constructor of ZipReader, ZipReader#getEntries and ZipReader#getEntriesGenerator.

    -
    interface GetEntriesOptions {
        commentEncoding?: string;
        filenameEncoding?: string;
    }

    Hierarchy (view full)

    Properties

    interface GetEntriesOptions {
        commentEncoding?: string;
        filenameEncoding?: string;
        decodeText?(value, encoding): string;
    }

    Hierarchy (view full)

    Properties

    commentEncoding?: string

    The encoding of the comment of the entry.

    -
    filenameEncoding?: string

    The encoding of the filename of the entry.

    -

    Generated using TypeDoc

    \ No newline at end of file +
    filenameEncoding?: string

    The encoding of the filename of the entry.

    +

    Methods

    • Decodes the filename and the comment of the entry.

      +

      Parameters

      • value: Uint8Array

        The raw text value.

        +
      • encoding: string

        The encoding of the text.

        +

      Returns string

      The decoded text value.

      +
    \ No newline at end of file diff --git a/api/interfaces/HttpOptions.html b/api/interfaces/HttpOptions.html index 1d5ad5d0..51186701 100644 --- a/api/interfaces/HttpOptions.html +++ b/api/interfaces/HttpOptions.html @@ -1,5 +1,5 @@ HttpOptions | @zip.js/zip.js

    Interface HttpOptions

    Represents the options passed to the constructor of HttpReader.

    -
    interface HttpOptions {
        combineSizeEocd?: boolean;
        forceRangeRequests?: boolean;
        headers?: Iterable<[string, string]> | Map<string, string>;
        preventHeadRequest?: boolean;
        useRangeHeader?: boolean;
        useXHR?: boolean;
    }

    Hierarchy (view full)

    Properties

    interface HttpOptions {
        combineSizeEocd?: boolean;
        forceRangeRequests?: boolean;
        headers?: Iterable<[string, string]> | Map<string, string>;
        preventHeadRequest?: boolean;
        useRangeHeader?: boolean;
        useXHR?: boolean;
    }

    Hierarchy (view full)

    Properties

    combineSizeEocd?: boolean

    true to use Range: bytes=-22 on the first request and cache the EOCD, make sure beforehand that the server supports a suffix range request.

    Default Value

    false
     
    -
    forceRangeRequests?: boolean

    true to always use Range headers when fetching data.

    +
    forceRangeRequests?: boolean

    true to always use Range headers when fetching data.

    Default Value

    false
     
    -
    headers?: Iterable<[string, string]> | Map<string, string>

    The HTTP headers.

    -
    preventHeadRequest?: boolean

    true to prevent using HEAD HTTP request in order the get the size of the content. +

    headers?: Iterable<[string, string]> | Map<string, string>

    The HTTP headers.

    +
    preventHeadRequest?: boolean

    true to prevent using HEAD HTTP request in order the get the size of the content. false to explicitly use HEAD, this is useful in case of CORS where Access-Control-Expose-Headers: Content-Range is not returned by the server.

    Default Value

    false
     
    -
    useRangeHeader?: boolean

    true to use Range headers when fetching data from servers returning Accept-Ranges headers.

    +
    useRangeHeader?: boolean

    true to use Range headers when fetching data from servers returning Accept-Ranges headers.

    Default Value

    false
     
    -
    useXHR?: boolean

    true to rely XMLHttpRequest instead of fetch to fetch data.

    +
    useXHR?: boolean

    true to rely XMLHttpRequest instead of fetch to fetch data.

    Default Value

    false
     
    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/HttpRangeOptions.html b/api/interfaces/HttpRangeOptions.html index 3cb8c292..5b134180 100644 --- a/api/interfaces/HttpRangeOptions.html +++ b/api/interfaces/HttpRangeOptions.html @@ -1,8 +1,8 @@ HttpRangeOptions | @zip.js/zip.js

    Interface HttpRangeOptions

    Represents options passed to the constructor of HttpRangeReader and HttpReader.

    -
    interface HttpRangeOptions {
        headers?: Iterable<[string, string]> | Map<string, string>;
        useXHR?: boolean;
    }

    Hierarchy (view full)

    Properties

    interface HttpRangeOptions {
        headers?: Iterable<[string, string]> | Map<string, string>;
        useXHR?: boolean;
    }

    Hierarchy (view full)

    Properties

    Properties

    headers?: Iterable<[string, string]> | Map<string, string>

    The HTTP headers.

    -
    useXHR?: boolean

    true to rely XMLHttpRequest instead of fetch to fetch data.

    +
    useXHR?: boolean

    true to rely XMLHttpRequest instead of fetch to fetch data.

    Default Value

    false
     
    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/Initializable.html b/api/interfaces/Initializable.html index 36087b50..fbde4a48 100644 --- a/api/interfaces/Initializable.html +++ b/api/interfaces/Initializable.html @@ -1,6 +1,6 @@ Initializable | @zip.js/zip.js

    Interface Initializable

    Represents an instance used to read or write unknown type of data.

    zip.js can handle multiple types of data thanks to a generic API. This feature is based on 2 abstract constructors: Reader and Writer. The classes inheriting from Reader help to read data from a source of data. The classes inheriting from Writer help to write data into a destination.

    -
    interface Initializable {
        init?(): Promise<void>;
    }

    Implemented by

    Methods

    interface Initializable {
        init?(): Promise<void>;
    }

    Implemented by

    Methods

    Methods

    • Initializes the instance asynchronously

      -

      Returns Promise<void>

    Generated using TypeDoc

    \ No newline at end of file +

    Returns Promise<void>

    \ No newline at end of file diff --git a/api/interfaces/ReadableReader.html b/api/interfaces/ReadableReader.html index 4313a7a8..e252b8c7 100644 --- a/api/interfaces/ReadableReader.html +++ b/api/interfaces/ReadableReader.html @@ -1,4 +1,4 @@ ReadableReader | @zip.js/zip.js

    Interface ReadableReader

    Represents an instance used to read data from a ReadableStream instance.

    -
    interface ReadableReader {
        readable: ReadableStream<any>;
    }

    Implemented by

    Properties

    interface ReadableReader {
        readable: ReadableStream<any>;
    }

    Implemented by

    Properties

    Properties

    readable: ReadableStream<any>

    The ReadableStream instance.

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/URLString.html b/api/interfaces/URLString.html index ab66201e..0ffd0607 100644 --- a/api/interfaces/URLString.html +++ b/api/interfaces/URLString.html @@ -1,5 +1,5 @@ URLString | @zip.js/zip.js

    Interface URLString

    Represents a URL stored into a string.

    -
    interface URLString {
        length: number;
        [iterator](): IterableIterator<string>;
        anchor(name): string;
        at(index): string;
        big(): string;
        blink(): string;
        bold(): string;
        charAt(pos): string;
        charCodeAt(index): number;
        codePointAt(pos): number;
        concat(...strings): string;
        endsWith(searchString, endPosition?): boolean;
        fixed(): string;
        fontcolor(color): string;
        fontsize(size): string;
        fontsize(size): string;
        includes(searchString, position?): boolean;
        indexOf(searchString, position?): number;
        italics(): string;
        lastIndexOf(searchString, position?): number;
        link(url): string;
        localeCompare(that): number;
        localeCompare(that, locales?, options?): number;
        localeCompare(that, locales?, options?): number;
        match(regexp): RegExpMatchArray;
        match(matcher): RegExpMatchArray;
        matchAll(regexp): IterableIterator<RegExpExecArray>;
        normalize(form): string;
        normalize(form?): string;
        padEnd(maxLength, fillString?): string;
        padStart(maxLength, fillString?): string;
        repeat(count): string;
        replace(searchValue, replaceValue): string;
        replace(searchValue, replacer): string;
        replace(searchValue, replaceValue): string;
        replace(searchValue, replacer): string;
        search(regexp): number;
        search(searcher): number;
        slice(start?, end?): string;
        small(): string;
        split(separator, limit?): string[];
        split(splitter, limit?): string[];
        startsWith(searchString, position?): boolean;
        strike(): string;
        sub(): string;
        substr(from, length?): string;
        substring(start, end?): string;
        sup(): string;
        toLocaleLowerCase(locales?): string;
        toLocaleLowerCase(locales?): string;
        toLocaleUpperCase(locales?): string;
        toLocaleUpperCase(locales?): string;
        toLowerCase(): string;
        toString(): string;
        toUpperCase(): string;
        trim(): string;
        trimEnd(): string;
        trimLeft(): string;
        trimRight(): string;
        trimStart(): string;
        valueOf(): string;
    }

    Hierarchy

    • String
      • URLString

    Properties

    interface URLString {
        length: number;
        [iterator](): IterableIterator<string>;
        anchor(name): string;
        at(index): string;
        big(): string;
        blink(): string;
        bold(): string;
        charAt(pos): string;
        charCodeAt(index): number;
        codePointAt(pos): number;
        concat(...strings): string;
        endsWith(searchString, endPosition?): boolean;
        fixed(): string;
        fontcolor(color): string;
        fontsize(size): string;
        fontsize(size): string;
        includes(searchString, position?): boolean;
        indexOf(searchString, position?): number;
        italics(): string;
        lastIndexOf(searchString, position?): number;
        link(url): string;
        localeCompare(that): number;
        localeCompare(that, locales?, options?): number;
        localeCompare(that, locales?, options?): number;
        match(regexp): RegExpMatchArray;
        match(matcher): RegExpMatchArray;
        matchAll(regexp): IterableIterator<RegExpExecArray>;
        normalize(form): string;
        normalize(form?): string;
        padEnd(maxLength, fillString?): string;
        padStart(maxLength, fillString?): string;
        repeat(count): string;
        replace(searchValue, replaceValue): string;
        replace(searchValue, replacer): string;
        replace(searchValue, replaceValue): string;
        replace(searchValue, replacer): string;
        search(regexp): number;
        search(searcher): number;
        slice(start?, end?): string;
        small(): string;
        split(separator, limit?): string[];
        split(splitter, limit?): string[];
        startsWith(searchString, position?): boolean;
        strike(): string;
        sub(): string;
        substr(from, length?): string;
        substring(start, end?): string;
        sup(): string;
        toLocaleLowerCase(locales?): string;
        toLocaleLowerCase(locales?): string;
        toLocaleUpperCase(locales?): string;
        toLocaleUpperCase(locales?): string;
        toLowerCase(): string;
        toString(): string;
        toUpperCase(): string;
        trim(): string;
        trimEnd(): string;
        trimLeft(): string;
        trimRight(): string;
        trimStart(): string;
        valueOf(): string;
    }

    Hierarchy

    • String
      • URLString

    Properties

    Methods

    [iterator] anchor at @@ -201,4 +201,4 @@

    Returns string

    Deprecated

    A legacy feature for browser compatibility. Use trimEnd instead

    • Removes the leading white space and line terminator characters from a string.

      Returns string

    • Returns the primitive value of the specified object.

      -

      Returns string

    Generated using TypeDoc

    \ No newline at end of file +

    Returns string

    \ No newline at end of file diff --git a/api/interfaces/WorkerConfiguration.html b/api/interfaces/WorkerConfiguration.html index 1d94edf8..2e79d26a 100644 --- a/api/interfaces/WorkerConfiguration.html +++ b/api/interfaces/WorkerConfiguration.html @@ -1,10 +1,10 @@ WorkerConfiguration | @zip.js/zip.js

    Interface WorkerConfiguration

    Represents configuration passed to configure, the constructor of ZipReader, Entry#getData, the constructor of ZipWriter, and ZipWriter#add.

    -
    interface WorkerConfiguration {
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
    }

    Hierarchy (view full)

    Properties

    interface WorkerConfiguration {
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
    }

    Hierarchy (view full)

    Properties

    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    Default Value

    true
     
    -
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    +
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    Default Value

    true
     
    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/WritableWriter.html b/api/interfaces/WritableWriter.html index e7044c35..e7259f57 100644 --- a/api/interfaces/WritableWriter.html +++ b/api/interfaces/WritableWriter.html @@ -1,6 +1,6 @@ WritableWriter | @zip.js/zip.js

    Interface WritableWriter

    Represents an instance used to write data into a WritableStream instance.

    -
    interface WritableWriter {
        maxSize?: number;
        writable: WritableStream<any>;
    }

    Implemented by

    Properties

    interface WritableWriter {
        maxSize?: number;
        writable: WritableStream<any>;
    }

    Implemented by

    Properties

    Properties

    maxSize?: number

    The maximum size of split data when creating a ZipWriter instance or when calling Entry#getData with a generator of WritableWriter instances.

    -
    writable: WritableStream<any>

    The WritableStream instance.

    -

    Generated using TypeDoc

    \ No newline at end of file +
    writable: WritableStream<any>

    The WritableStream instance.

    +
    \ No newline at end of file diff --git a/api/interfaces/ZipDirectoryEntryExportOptions.html b/api/interfaces/ZipDirectoryEntryExportOptions.html index 407feb22..0c9821a2 100644 --- a/api/interfaces/ZipDirectoryEntryExportOptions.html +++ b/api/interfaces/ZipDirectoryEntryExportOptions.html @@ -1,5 +1,5 @@ ZipDirectoryEntryExportOptions | @zip.js/zip.js

    Interface ZipDirectoryEntryExportOptions

    Represents the options passed to {@link ZipDirectoryEntry}#export*().

    -
    interface ZipDirectoryEntryExportOptions {
        bufferedWrite?: boolean;
        creationDate?: Date;
        dataDescriptor?: boolean;
        dataDescriptorSignature?: boolean;
        encryptionStrength?: 1 | 2 | 3;
        extendedTimestamp?: boolean;
        externalFileAttribute?: number;
        internalFileAttribute?: number;
        keepOrder?: boolean;
        lastAccessDate?: Date;
        lastModDate?: Date;
        level?: number;
        mimeType?: string;
        msDosCompatible?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        readerOptions?: ZipReaderConstructorOptions;
        relativePath?: boolean;
        signal?: AbortSignal;
        supportZip64SplitFile?: boolean;
        usdz?: boolean;
        version?: number;
        versionMadeBy?: number;
        zip64?: boolean;
        zipCrypto?: boolean;
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    interface ZipDirectoryEntryExportOptions {
        bufferedWrite?: boolean;
        creationDate?: Date;
        dataDescriptor?: boolean;
        dataDescriptorSignature?: boolean;
        encryptionStrength?: 1 | 2 | 3;
        extendedTimestamp?: boolean;
        externalFileAttribute?: number;
        internalFileAttribute?: number;
        keepOrder?: boolean;
        lastAccessDate?: Date;
        lastModDate?: Date;
        level?: number;
        mimeType?: string;
        msDosCompatible?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        readerOptions?: ZipReaderConstructorOptions;
        relativePath?: boolean;
        signal?: AbortSignal;
        supportZip64SplitFile?: boolean;
        usdz?: boolean;
        version?: number;
        versionMadeBy?: number;
        zip64?: boolean;
        zipCrypto?: boolean;
        encodeText?(text): Uint8Array;
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    bufferedWrite?: boolean

    true to write entry data in a buffer before appending it to the zip file.

    bufferedWrite is automatically set to true when compressing more than one entry in parallel.

    Default Value

    false
     
    -
    creationDate?: Date

    The creation date.

    +
    creationDate?: Date

    The creation date.

    This option is ignored if the ZipWriterConstructorOptions#extendedTimestamp option is set to false.

    Default Value

    The current date.
     
    -
    dataDescriptor?: boolean

    true to to add a data descriptor.

    +
    dataDescriptor?: boolean

    true to to add a data descriptor.

    When set to false, the ZipWriterConstructorOptions#bufferedWrite option will automatically be set to true.

    Default Value

    true
     
    -
    dataDescriptorSignature?: boolean

    true to add the signature of the data descriptor.

    +
    dataDescriptorSignature?: boolean

    true to add the signature of the data descriptor.

    Default Value

    false
     
    -
    encryptionStrength?: 1 | 2 | 3

    The encryption strength (AES).

    +
    encryptionStrength?: 1 | 2 | 3

    The encryption strength (AES).

    Default Value

    3
     
    -
    extendedTimestamp?: boolean

    true to store extended timestamp extra fields.

    +
    extendedTimestamp?: boolean

    true to store extended timestamp extra fields.

    When set to false, the maximum last modification date cannot exceed November 31, 2107 and the maximum accuracy is 2 seconds.

    Default Value

    true
     
    -
    externalFileAttribute?: number

    The external file attribute.

    +
    externalFileAttribute?: number

    The external file attribute.

    Default Value

    0
     
    -
    internalFileAttribute?: number

    The internal file attribute.

    +
    internalFileAttribute?: number

    The internal file attribute.

    Default Value

    0
     
    -
    keepOrder?: boolean

    true to keep the order of the entry physically in the zip file.

    +
    keepOrder?: boolean

    true to keep the order of the entry physically in the zip file.

    When set to true, the use of web workers will be improved. However, it also prevents files larger than 4GB from being created without setting the zip54 option to true explicitly. Another solution to improve the use of web workers is to add entries from smallest to largest in uncompressed size.

    Default Value

    true
     
    -
    lastAccessDate?: Date

    The last access date.

    +
    lastAccessDate?: Date

    The last access date.

    This option is ignored if the ZipWriterConstructorOptions#extendedTimestamp option is set to false.

    Default Value

    The current date.
     
    -
    lastModDate?: Date

    The last modification date.

    +
    lastModDate?: Date

    The last modification date.

    Default Value

    The current date.
     
    -
    level?: number

    The level of compression.

    +
    level?: number

    The level of compression.

    The minimum value is 0 and means that no compression is applied. The maximum value is 9.

    Default Value

    5
     
    -
    mimeType?: string

    The MIME type of the exported data when relevant.

    -
    msDosCompatible?: boolean

    true to write EntryMetaData#externalFileAttribute in MS-DOS format for folder entries.

    +
    mimeType?: string

    The MIME type of the exported data when relevant.

    +
    msDosCompatible?: boolean

    true to write EntryMetaData#externalFileAttribute in MS-DOS format for folder entries.

    Default Value

    true
     
    -
    password?: string

    The password used to encrypt the content of the entry.

    -
    preventClose?: boolean

    true to prevent closing of WritableWriter#writable.

    +
    password?: string

    The password used to encrypt the content of the entry.

    +
    preventClose?: boolean

    true to prevent closing of WritableWriter#writable.

    Default Value

    false
     
    -
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    -

    The options passed to the Reader instances

    -
    relativePath?: boolean

    true to use filenames relative to the entry instead of full filenames.

    -
    signal?: AbortSignal

    The AbortSignal instance used to cancel the compression.

    -
    supportZip64SplitFile?: boolean

    false to never write disk numbers in zip64 data.

    +
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    +

    The options passed to the Reader instances

    +
    relativePath?: boolean

    true to use filenames relative to the entry instead of full filenames.

    +
    signal?: AbortSignal

    The AbortSignal instance used to cancel the compression.

    +
    supportZip64SplitFile?: boolean

    false to never write disk numbers in zip64 data.

    Default Value

    true
     
    -
    usdz?: boolean

    trueto produce zip files compatible with the USDZ specification.

    +
    usdz?: boolean

    trueto produce zip files compatible with the USDZ specification.

    Default Value

    false
     
    -
    version?: number

    The "Version" field.

    -
    versionMadeBy?: number

    The "Version made by" field.

    +
    version?: number

    The "Version" field.

    +
    versionMadeBy?: number

    The "Version made by" field.

    Default Value

    20
     
    -
    zip64?: boolean

    true to use Zip64 to store the entry.

    +
    zip64?: boolean

    true to use Zip64 to store the entry.

    zip64 is automatically set to true when necessary (e.g. compressed data larger than 4GB or with unknown size).

    Default Value

    false
     
    -
    zipCrypto?: boolean

    true to use the ZipCrypto algorithm to encrypt the content of the entry.

    +
    zipCrypto?: boolean

    true to use the ZipCrypto algorithm to encrypt the content of the entry.

    It is not recommended to set zipCrypto to true because the ZipCrypto encryption can be easily broken.

    Default Value

    false
     
    -

    Methods

    Methods

    • The function called when ending compression/decompression.

      Parameters

      • computedSize: number

        The total number of bytes (computed).

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called during compression/decompression.

      Parameters

      • progress: number

        The current progress in bytes.

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called when starting compression/decompression.

      Parameters

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/ZipDirectoryEntryImportHttpOptions.html b/api/interfaces/ZipDirectoryEntryImportHttpOptions.html index 22facfa4..5a374756 100644 --- a/api/interfaces/ZipDirectoryEntryImportHttpOptions.html +++ b/api/interfaces/ZipDirectoryEntryImportHttpOptions.html @@ -1,5 +1,5 @@ ZipDirectoryEntryImportHttpOptions | @zip.js/zip.js

    Interface ZipDirectoryEntryImportHttpOptions

    Represents the options passed to ZipDirectoryEntry#importHttpContent.

    -
    interface ZipDirectoryEntryImportHttpOptions {
        checkSignature?: boolean;
        combineSizeEocd?: boolean;
        commentEncoding?: string;
        extractAppendedData?: boolean;
        extractPrependedData?: boolean;
        filenameEncoding?: string;
        forceRangeRequests?: boolean;
        headers?: Iterable<[string, string]> | Map<string, string>;
        password?: string;
        preventClose?: boolean;
        preventHeadRequest?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
        useCompressionStream?: boolean;
        useRangeHeader?: boolean;
        useWebWorkers?: boolean;
        useXHR?: boolean;
    }

    Hierarchy (view full)

    Properties

    interface ZipDirectoryEntryImportHttpOptions {
        checkSignature?: boolean;
        combineSizeEocd?: boolean;
        commentEncoding?: string;
        extractAppendedData?: boolean;
        extractPrependedData?: boolean;
        filenameEncoding?: string;
        forceRangeRequests?: boolean;
        headers?: Iterable<[string, string]> | Map<string, string>;
        password?: string;
        preventClose?: boolean;
        preventHeadRequest?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
        useCompressionStream?: boolean;
        useRangeHeader?: boolean;
        useWebWorkers?: boolean;
        useXHR?: boolean;
        decodeText?(value, encoding): string;
    }

    Hierarchy (view full)

    Properties

    checkSignature?: boolean

    true to check the signature of the entry.

    Default Value

    false
     
    -
    combineSizeEocd?: boolean

    true to use Range: bytes=-22 on the first request and cache the EOCD, make sure beforehand that the server supports a suffix range request.

    +
    combineSizeEocd?: boolean

    true to use Range: bytes=-22 on the first request and cache the EOCD, make sure beforehand that the server supports a suffix range request.

    Default Value

    false
     
    -
    commentEncoding?: string

    The encoding of the comment of the entry.

    -
    extractAppendedData?: boolean

    true to extract the appended data into ZipReader#appendedData.

    +
    commentEncoding?: string

    The encoding of the comment of the entry.

    +
    extractAppendedData?: boolean

    true to extract the appended data into ZipReader#appendedData.

    Default Value

    false
     
    -
    extractPrependedData?: boolean

    true to extract the prepended data into ZipReader#prependedData.

    +
    extractPrependedData?: boolean

    true to extract the prepended data into ZipReader#prependedData.

    Default Value

    false
     
    -
    filenameEncoding?: string

    The encoding of the filename of the entry.

    -
    forceRangeRequests?: boolean

    true to always use Range headers when fetching data.

    +
    filenameEncoding?: string

    The encoding of the filename of the entry.

    +
    forceRangeRequests?: boolean

    true to always use Range headers when fetching data.

    Default Value

    false
     
    -
    headers?: Iterable<[string, string]> | Map<string, string>

    The HTTP headers.

    -
    password?: string

    The password used to decrypt the content of the entry.

    -
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    +
    headers?: Iterable<[string, string]> | Map<string, string>

    The HTTP headers.

    +
    password?: string

    The password used to decrypt the content of the entry.

    +
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    Default Value

    false
     
    -
    preventHeadRequest?: boolean

    true to prevent using HEAD HTTP request in order the get the size of the content. +

    preventHeadRequest?: boolean

    true to prevent using HEAD HTTP request in order the get the size of the content. false to explicitly use HEAD, this is useful in case of CORS where Access-Control-Expose-Headers: Content-Range is not returned by the server.

    Default Value

    false
     
    -
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    -
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    -
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    +
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    +
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    +
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    Default Value

    true
     
    -
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    +
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    Default Value

    true
     
    -
    useRangeHeader?: boolean

    true to use Range headers when fetching data from servers returning Accept-Ranges headers.

    +
    useRangeHeader?: boolean

    true to use Range headers when fetching data from servers returning Accept-Ranges headers.

    Default Value

    false
     
    -
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    +
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    Default Value

    true
     
    -
    useXHR?: boolean

    true to rely XMLHttpRequest instead of fetch to fetch data.

    +
    useXHR?: boolean

    true to rely XMLHttpRequest instead of fetch to fetch data.

    Default Value

    false
     
    -

    Generated using TypeDoc

    \ No newline at end of file +

    Methods

    • Decodes the filename and the comment of the entry.

      +

      Parameters

      • value: Uint8Array

        The raw text value.

        +
      • encoding: string

        The encoding of the text.

        +

      Returns string

      The decoded text value.

      +
    \ No newline at end of file diff --git a/api/interfaces/ZipLibrary.html b/api/interfaces/ZipLibrary.html index eb35c635..e7d3d993 100644 --- a/api/interfaces/ZipLibrary.html +++ b/api/interfaces/ZipLibrary.html @@ -1,10 +1,10 @@ ZipLibrary | @zip.js/zip.js

    Interface ZipLibrary

    Represents the implementations zip.js uses to compress/decompress data.

    -
    interface ZipLibrary {
        Deflate: typeof ZipDeflate;
        Inflate: typeof ZipInflate;
    }

    Properties

    interface ZipLibrary {
        Deflate: typeof ZipDeflate;
        Inflate: typeof ZipInflate;
    }

    Properties

    Properties

    Deflate: typeof ZipDeflate

    The class used to compress data.

    Default Value

    {@link ZipDeflate}
     
    -
    Inflate: typeof ZipInflate

    The class used to decompress data.

    +
    Inflate: typeof ZipInflate

    The class used to decompress data.

    Default Value

    {@link ZipInflate}
     
    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/ZipReaderCheckPasswordOptions.html b/api/interfaces/ZipReaderCheckPasswordOptions.html index 4a8f1c46..2935b7cf 100644 --- a/api/interfaces/ZipReaderCheckPasswordOptions.html +++ b/api/interfaces/ZipReaderCheckPasswordOptions.html @@ -1,6 +1,6 @@ ZipReaderCheckPasswordOptions | @zip.js/zip.js

    Interface ZipReaderCheckPasswordOptions

    Represents options passed to the constructor of ZipReader and Entry#getData.

    -
    interface ZipReaderCheckPasswordOptions {
        checkPasswordOnly: boolean;
    }

    Hierarchy (view full)

    Properties

    interface ZipReaderCheckPasswordOptions {
        checkPasswordOnly: boolean;
    }

    Hierarchy (view full)

    Properties

    checkPasswordOnly: boolean

    true to check only if the password is valid.

    Default Value

    false
     
    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/ZipReaderConstructorOptions.html b/api/interfaces/ZipReaderConstructorOptions.html index e6a274ed..f1d71f24 100644 --- a/api/interfaces/ZipReaderConstructorOptions.html +++ b/api/interfaces/ZipReaderConstructorOptions.html @@ -1,5 +1,5 @@ ZipReaderConstructorOptions | @zip.js/zip.js

    Interface ZipReaderConstructorOptions

    Represents the options passed to the constructor of ZipReader, and {@link ZipDirectory}#import*.

    -
    interface ZipReaderConstructorOptions {
        checkSignature?: boolean;
        commentEncoding?: string;
        extractAppendedData?: boolean;
        extractPrependedData?: boolean;
        filenameEncoding?: string;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
    }

    Hierarchy (view full)

    Properties

    interface ZipReaderConstructorOptions {
        checkSignature?: boolean;
        commentEncoding?: string;
        extractAppendedData?: boolean;
        extractPrependedData?: boolean;
        filenameEncoding?: string;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
        decodeText?(value, encoding): string;
    }

    Hierarchy (view full)

    Properties

    checkSignature?: boolean

    true to check the signature of the entry.

    Default Value

    false
     
    -
    commentEncoding?: string

    The encoding of the comment of the entry.

    -
    extractAppendedData?: boolean

    true to extract the appended data into ZipReader#appendedData.

    +
    commentEncoding?: string

    The encoding of the comment of the entry.

    +
    extractAppendedData?: boolean

    true to extract the appended data into ZipReader#appendedData.

    Default Value

    false
     
    -
    extractPrependedData?: boolean

    true to extract the prepended data into ZipReader#prependedData.

    +
    extractPrependedData?: boolean

    true to extract the prepended data into ZipReader#prependedData.

    Default Value

    false
     
    -
    filenameEncoding?: string

    The encoding of the filename of the entry.

    -
    password?: string

    The password used to decrypt the content of the entry.

    -
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    +
    filenameEncoding?: string

    The encoding of the filename of the entry.

    +
    password?: string

    The password used to decrypt the content of the entry.

    +
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    Default Value

    false
     
    -
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    -
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    -
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    +
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    +
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    +
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    Default Value

    true
     
    -
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    +
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    Default Value

    true
     
    -
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    +
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    Default Value

    true
     
    -

    Generated using TypeDoc

    \ No newline at end of file +

    Methods

    • Decodes the filename and the comment of the entry.

      +

      Parameters

      • value: Uint8Array

        The raw text value.

        +
      • encoding: string

        The encoding of the text.

        +

      Returns string

      The decoded text value.

      +
    \ No newline at end of file diff --git a/api/interfaces/ZipReaderGetEntriesOptions.html b/api/interfaces/ZipReaderGetEntriesOptions.html index 3d01dcaf..490b4094 100644 --- a/api/interfaces/ZipReaderGetEntriesOptions.html +++ b/api/interfaces/ZipReaderGetEntriesOptions.html @@ -1,12 +1,17 @@ ZipReaderGetEntriesOptions | @zip.js/zip.js

    Interface ZipReaderGetEntriesOptions

    Represents the options passed to ZipReader#getEntries and ZipReader#getEntriesGenerator.

    -
    interface ZipReaderGetEntriesOptions {
        commentEncoding?: string;
        filenameEncoding?: string;
        onprogress?(progress, total, entry): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    interface ZipReaderGetEntriesOptions {
        commentEncoding?: string;
        filenameEncoding?: string;
        decodeText?(value, encoding): string;
        onprogress?(progress, total, entry): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    commentEncoding?: string

    The encoding of the comment of the entry.

    -
    filenameEncoding?: string

    The encoding of the filename of the entry.

    -

    Methods

    filenameEncoding?: string

    The encoding of the filename of the entry.

    +

    Methods

    • Decodes the filename and the comment of the entry.

      +

      Parameters

      • value: Uint8Array

        The raw text value.

        +
      • encoding: string

        The encoding of the text.

        +

      Returns string

      The decoded text value.

      +
    • The function called each time an entry is read/written.

      Parameters

      • progress: number

        The entry index.

      • total: number

        The total number of entries.

      • entry: EntryMetaData

        The entry being read/written.

      Returns Promise<void>

      An empty promise or undefined.

      -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/ZipReaderOptions.html b/api/interfaces/ZipReaderOptions.html index ea88fd4b..eae4f60a 100644 --- a/api/interfaces/ZipReaderOptions.html +++ b/api/interfaces/ZipReaderOptions.html @@ -1,5 +1,5 @@ ZipReaderOptions | @zip.js/zip.js

    Interface ZipReaderOptions

    Represents options passed to the constructor of ZipReader and Entry#getData.

    -
    interface ZipReaderOptions {
        checkSignature?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
    }

    Hierarchy (view full)

    Properties

    interface ZipReaderOptions {
        checkSignature?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        transferStreams?: boolean;
    }

    Hierarchy (view full)

    Properties

    checkSignature?: boolean

    true to check the signature of the entry.

    Default Value

    false
     
    -
    password?: string

    The password used to decrypt the content of the entry.

    -
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    +
    password?: string

    The password used to decrypt the content of the entry.

    +
    preventClose?: boolean

    true to prevent closing of Writer#writable when calling Entry#getData.

    Default Value

    false
     
    -
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    -
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    -
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    +
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    +
    signal?: AbortSignal

    The AbortSignal instance used to cancel the decompression.

    +
    transferStreams?: boolean

    true to transfer streams to web workers when decompressing data.

    Default Value

    true
     
    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/ZipWriterAddDataOptions.html b/api/interfaces/ZipWriterAddDataOptions.html index 65453342..b00fc03a 100644 --- a/api/interfaces/ZipWriterAddDataOptions.html +++ b/api/interfaces/ZipWriterAddDataOptions.html @@ -1,5 +1,5 @@ ZipWriterAddDataOptions | @zip.js/zip.js

    Interface ZipWriterAddDataOptions

    Represents the options passed to ZipWriter#add.

    -
    interface ZipWriterAddDataOptions {
        bufferedWrite?: boolean;
        comment?: string;
        creationDate?: Date;
        dataDescriptor?: boolean;
        dataDescriptorSignature?: boolean;
        directory?: boolean;
        encryptionStrength?: 1 | 2 | 3;
        extendedTimestamp?: boolean;
        externalFileAttribute?: number;
        extraField?: Map<number, Uint8Array>;
        internalFileAttribute?: number;
        keepOrder?: boolean;
        lastAccessDate?: Date;
        lastModDate?: Date;
        level?: number;
        msDosCompatible?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        supportZip64SplitFile?: boolean;
        usdz?: boolean;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
        version?: number;
        versionMadeBy?: number;
        zip64?: boolean;
        zipCrypto?: boolean;
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    interface ZipWriterAddDataOptions {
        bufferedWrite?: boolean;
        comment?: string;
        creationDate?: Date;
        dataDescriptor?: boolean;
        dataDescriptorSignature?: boolean;
        directory?: boolean;
        encryptionStrength?: 1 | 2 | 3;
        extendedTimestamp?: boolean;
        externalFileAttribute?: number;
        extraField?: Map<number, Uint8Array>;
        internalFileAttribute?: number;
        keepOrder?: boolean;
        lastAccessDate?: Date;
        lastModDate?: Date;
        level?: number;
        msDosCompatible?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        supportZip64SplitFile?: boolean;
        usdz?: boolean;
        useCompressionStream?: boolean;
        useWebWorkers?: boolean;
        version?: number;
        versionMadeBy?: number;
        zip64?: boolean;
        zipCrypto?: boolean;
        encodeText?(text): Uint8Array;
        onend?(computedSize): Promise<void>;
        onprogress?(progress, total): Promise<void>;
        onstart?(total): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    bufferedWrite?: boolean

    true to write entry data in a buffer before appending it to the zip file.

    bufferedWrite is automatically set to true when compressing more than one entry in parallel.

    Default Value

    false
     
    -
    comment?: string

    The comment of the entry.

    -
    creationDate?: Date

    The creation date.

    +
    comment?: string

    The comment of the entry.

    +
    creationDate?: Date

    The creation date.

    This option is ignored if the ZipWriterConstructorOptions#extendedTimestamp option is set to false.

    Default Value

    The current date.
     
    -
    dataDescriptor?: boolean

    true to to add a data descriptor.

    +
    dataDescriptor?: boolean

    true to to add a data descriptor.

    When set to false, the ZipWriterConstructorOptions#bufferedWrite option will automatically be set to true.

    Default Value

    true
     
    -
    dataDescriptorSignature?: boolean

    true to add the signature of the data descriptor.

    +
    dataDescriptorSignature?: boolean

    true to add the signature of the data descriptor.

    Default Value

    false
     
    -
    directory?: boolean

    true if the entry is a directory.

    +
    directory?: boolean

    true if the entry is a directory.

    Default Value

    false
     
    -
    encryptionStrength?: 1 | 2 | 3

    The encryption strength (AES).

    +
    encryptionStrength?: 1 | 2 | 3

    The encryption strength (AES).

    Default Value

    3
     
    -
    extendedTimestamp?: boolean

    true to store extended timestamp extra fields.

    +
    extendedTimestamp?: boolean

    true to store extended timestamp extra fields.

    When set to false, the maximum last modification date cannot exceed November 31, 2107 and the maximum accuracy is 2 seconds.

    Default Value

    true
     
    -
    externalFileAttribute?: number

    The external file attribute.

    +
    externalFileAttribute?: number

    The external file attribute.

    Default Value

    0
     
    -
    extraField?: Map<number, Uint8Array>

    The extra field of the entry.

    -
    internalFileAttribute?: number

    The internal file attribute.

    +
    extraField?: Map<number, Uint8Array>

    The extra field of the entry.

    +
    internalFileAttribute?: number

    The internal file attribute.

    Default Value

    0
     
    -
    keepOrder?: boolean

    true to keep the order of the entry physically in the zip file.

    +
    keepOrder?: boolean

    true to keep the order of the entry physically in the zip file.

    When set to true, the use of web workers will be improved. However, it also prevents files larger than 4GB from being created without setting the zip54 option to true explicitly. Another solution to improve the use of web workers is to add entries from smallest to largest in uncompressed size.

    Default Value

    true
     
    -
    lastAccessDate?: Date

    The last access date.

    +
    lastAccessDate?: Date

    The last access date.

    This option is ignored if the ZipWriterConstructorOptions#extendedTimestamp option is set to false.

    Default Value

    The current date.
     
    -
    lastModDate?: Date

    The last modification date.

    +
    lastModDate?: Date

    The last modification date.

    Default Value

    The current date.
     
    -
    level?: number

    The level of compression.

    +
    level?: number

    The level of compression.

    The minimum value is 0 and means that no compression is applied. The maximum value is 9.

    Default Value

    5
     
    -
    msDosCompatible?: boolean

    true to write EntryMetaData#externalFileAttribute in MS-DOS format for folder entries.

    +
    msDosCompatible?: boolean

    true to write EntryMetaData#externalFileAttribute in MS-DOS format for folder entries.

    Default Value

    true
     
    -
    password?: string

    The password used to encrypt the content of the entry.

    -
    preventClose?: boolean

    true to prevent closing of WritableWriter#writable.

    +
    password?: string

    The password used to encrypt the content of the entry.

    +
    preventClose?: boolean

    true to prevent closing of WritableWriter#writable.

    Default Value

    false
     
    -
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    -
    signal?: AbortSignal

    The AbortSignal instance used to cancel the compression.

    -
    supportZip64SplitFile?: boolean

    false to never write disk numbers in zip64 data.

    +
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    +
    signal?: AbortSignal

    The AbortSignal instance used to cancel the compression.

    +
    supportZip64SplitFile?: boolean

    false to never write disk numbers in zip64 data.

    Default Value

    true
     
    -
    usdz?: boolean

    trueto produce zip files compatible with the USDZ specification.

    +
    usdz?: boolean

    trueto produce zip files compatible with the USDZ specification.

    Default Value

    false
     
    -
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    +
    useCompressionStream?: boolean

    true to use the native API CompressionStream/DecompressionStream to compress/decompress data.

    Default Value

    true
     
    -
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    +
    useWebWorkers?: boolean

    true to use web workers to compress/decompress data in non-blocking background processes.

    Default Value

    true
     
    -
    version?: number

    The "Version" field.

    -
    versionMadeBy?: number

    The "Version made by" field.

    +
    version?: number

    The "Version" field.

    +
    versionMadeBy?: number

    The "Version made by" field.

    Default Value

    20
     
    -
    zip64?: boolean

    true to use Zip64 to store the entry.

    +
    zip64?: boolean

    true to use Zip64 to store the entry.

    zip64 is automatically set to true when necessary (e.g. compressed data larger than 4GB or with unknown size).

    Default Value

    false
     
    -
    zipCrypto?: boolean

    true to use the ZipCrypto algorithm to encrypt the content of the entry.

    +
    zipCrypto?: boolean

    true to use the ZipCrypto algorithm to encrypt the content of the entry.

    It is not recommended to set zipCrypto to true because the ZipCrypto encryption can be easily broken.

    Default Value

    false
     
    -

    Methods

    Methods

    • The function called when ending compression/decompression.

      Parameters

      • computedSize: number

        The total number of bytes (computed).

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called during compression/decompression.

      Parameters

      • progress: number

        The current progress in bytes.

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -
    • The function called when starting compression/decompression.

      Parameters

      • total: number

        The total number of bytes.

      Returns Promise<void>

      An empty promise or undefined.

      -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/ZipWriterCloseOptions.html b/api/interfaces/ZipWriterCloseOptions.html index 4a12630b..3393c6e6 100644 --- a/api/interfaces/ZipWriterCloseOptions.html +++ b/api/interfaces/ZipWriterCloseOptions.html @@ -1,16 +1,16 @@ ZipWriterCloseOptions | @zip.js/zip.js

    Interface ZipWriterCloseOptions

    Represents the options passed to ZipWriter#close.

    -
    interface ZipWriterCloseOptions {
        preventClose?: boolean;
        zip64?: boolean;
        onprogress?(progress, total, entry): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    interface ZipWriterCloseOptions {
        preventClose?: boolean;
        zip64?: boolean;
        onprogress?(progress, total, entry): Promise<void>;
    }

    Hierarchy (view full)

    Properties

    Methods

    Properties

    preventClose?: boolean

    true to prevent closing of WritableWriter#writable.

    Default Value

    false
     
    -
    zip64?: boolean

    true to use Zip64 to write the entries directory.

    +
    zip64?: boolean

    true to use Zip64 to write the entries directory.

    Default Value

    false
     
    -

    Methods

    • The function called each time an entry is read/written.

      +

    Methods

    • The function called each time an entry is read/written.

      Parameters

      • progress: number

        The entry index.

      • total: number

        The total number of entries.

      • entry: EntryMetaData

        The entry being read/written.

      Returns Promise<void>

      An empty promise or undefined.

      -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/interfaces/ZipWriterConstructorOptions.html b/api/interfaces/ZipWriterConstructorOptions.html index 39a96d4a..239016b5 100644 --- a/api/interfaces/ZipWriterConstructorOptions.html +++ b/api/interfaces/ZipWriterConstructorOptions.html @@ -1,5 +1,5 @@ ZipWriterConstructorOptions | @zip.js/zip.js

    Interface ZipWriterConstructorOptions

    Represents options passed to the constructor of ZipWriter, ZipWriter#add and {@link ZipDirectoryEntry}#export*.

    -
    interface ZipWriterConstructorOptions {
        bufferedWrite?: boolean;
        creationDate?: Date;
        dataDescriptor?: boolean;
        dataDescriptorSignature?: boolean;
        encryptionStrength?: 1 | 2 | 3;
        extendedTimestamp?: boolean;
        externalFileAttribute?: number;
        internalFileAttribute?: number;
        keepOrder?: boolean;
        lastAccessDate?: Date;
        lastModDate?: Date;
        level?: number;
        msDosCompatible?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        supportZip64SplitFile?: boolean;
        usdz?: boolean;
        version?: number;
        versionMadeBy?: number;
        zip64?: boolean;
        zipCrypto?: boolean;
    }

    Hierarchy (view full)

    Properties

    interface ZipWriterConstructorOptions {
        bufferedWrite?: boolean;
        creationDate?: Date;
        dataDescriptor?: boolean;
        dataDescriptorSignature?: boolean;
        encryptionStrength?: 1 | 2 | 3;
        extendedTimestamp?: boolean;
        externalFileAttribute?: number;
        internalFileAttribute?: number;
        keepOrder?: boolean;
        lastAccessDate?: Date;
        lastModDate?: Date;
        level?: number;
        msDosCompatible?: boolean;
        password?: string;
        preventClose?: boolean;
        rawPassword?: Uint8Array;
        signal?: AbortSignal;
        supportZip64SplitFile?: boolean;
        usdz?: boolean;
        version?: number;
        versionMadeBy?: number;
        zip64?: boolean;
        zipCrypto?: boolean;
        encodeText?(text): Uint8Array;
    }

    Hierarchy (view full)

    Properties

    bufferedWrite?: boolean

    true to write entry data in a buffer before appending it to the zip file.

    bufferedWrite is automatically set to true when compressing more than one entry in parallel.

    Default Value

    false
     
    -
    creationDate?: Date

    The creation date.

    +
    creationDate?: Date

    The creation date.

    This option is ignored if the ZipWriterConstructorOptions#extendedTimestamp option is set to false.

    Default Value

    The current date.
     
    -
    dataDescriptor?: boolean

    true to to add a data descriptor.

    +
    dataDescriptor?: boolean

    true to to add a data descriptor.

    When set to false, the ZipWriterConstructorOptions#bufferedWrite option will automatically be set to true.

    Default Value

    true
     
    -
    dataDescriptorSignature?: boolean

    true to add the signature of the data descriptor.

    +
    dataDescriptorSignature?: boolean

    true to add the signature of the data descriptor.

    Default Value

    false
     
    -
    encryptionStrength?: 1 | 2 | 3

    The encryption strength (AES).

    +
    encryptionStrength?: 1 | 2 | 3

    The encryption strength (AES).

    Default Value

    3
     
    -
    extendedTimestamp?: boolean

    true to store extended timestamp extra fields.

    +
    extendedTimestamp?: boolean

    true to store extended timestamp extra fields.

    When set to false, the maximum last modification date cannot exceed November 31, 2107 and the maximum accuracy is 2 seconds.

    Default Value

    true
     
    -
    externalFileAttribute?: number

    The external file attribute.

    +
    externalFileAttribute?: number

    The external file attribute.

    Default Value

    0
     
    -
    internalFileAttribute?: number

    The internal file attribute.

    +
    internalFileAttribute?: number

    The internal file attribute.

    Default Value

    0
     
    -
    keepOrder?: boolean

    true to keep the order of the entry physically in the zip file.

    +
    keepOrder?: boolean

    true to keep the order of the entry physically in the zip file.

    When set to true, the use of web workers will be improved. However, it also prevents files larger than 4GB from being created without setting the zip54 option to true explicitly. Another solution to improve the use of web workers is to add entries from smallest to largest in uncompressed size.

    Default Value

    true
     
    -
    lastAccessDate?: Date

    The last access date.

    +
    lastAccessDate?: Date

    The last access date.

    This option is ignored if the ZipWriterConstructorOptions#extendedTimestamp option is set to false.

    Default Value

    The current date.
     
    -
    lastModDate?: Date

    The last modification date.

    +
    lastModDate?: Date

    The last modification date.

    Default Value

    The current date.
     
    -
    level?: number

    The level of compression.

    +
    level?: number

    The level of compression.

    The minimum value is 0 and means that no compression is applied. The maximum value is 9.

    Default Value

    5
     
    -
    msDosCompatible?: boolean

    true to write EntryMetaData#externalFileAttribute in MS-DOS format for folder entries.

    +
    msDosCompatible?: boolean

    true to write EntryMetaData#externalFileAttribute in MS-DOS format for folder entries.

    Default Value

    true
     
    -
    password?: string

    The password used to encrypt the content of the entry.

    -
    preventClose?: boolean

    true to prevent closing of WritableWriter#writable.

    +
    password?: string

    The password used to encrypt the content of the entry.

    +
    preventClose?: boolean

    true to prevent closing of WritableWriter#writable.

    Default Value

    false
     
    -
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    -
    signal?: AbortSignal

    The AbortSignal instance used to cancel the compression.

    -
    supportZip64SplitFile?: boolean

    false to never write disk numbers in zip64 data.

    +
    rawPassword?: Uint8Array

    The password used to encrypt the content of the entry (raw).

    +
    signal?: AbortSignal

    The AbortSignal instance used to cancel the compression.

    +
    supportZip64SplitFile?: boolean

    false to never write disk numbers in zip64 data.

    Default Value

    true
     
    -
    usdz?: boolean

    trueto produce zip files compatible with the USDZ specification.

    +
    usdz?: boolean

    trueto produce zip files compatible with the USDZ specification.

    Default Value

    false
     
    -
    version?: number

    The "Version" field.

    -
    versionMadeBy?: number

    The "Version made by" field.

    +
    version?: number

    The "Version" field.

    +
    versionMadeBy?: number

    The "Version made by" field.

    Default Value

    20
     
    -
    zip64?: boolean

    true to use Zip64 to store the entry.

    +
    zip64?: boolean

    true to use Zip64 to store the entry.

    zip64 is automatically set to true when necessary (e.g. compressed data larger than 4GB or with unknown size).

    Default Value

    false
     
    -
    zipCrypto?: boolean

    true to use the ZipCrypto algorithm to encrypt the content of the entry.

    +
    zipCrypto?: boolean

    true to use the ZipCrypto algorithm to encrypt the content of the entry.

    It is not recommended to set zipCrypto to true because the ZipCrypto encryption can be easily broken.

    Default Value

    false
     
    -

    Generated using TypeDoc

    \ No newline at end of file +

    Methods

    • Encode the filename and the comment of the entry.

      +

      Parameters

      • text: string

        The text to encode.

        +

      Returns Uint8Array

      The encoded text.

      +
    \ No newline at end of file diff --git a/api/interfaces/dataHandler.html b/api/interfaces/dataHandler.html index cf206661..699db812 100644 --- a/api/interfaces/dataHandler.html +++ b/api/interfaces/dataHandler.html @@ -1,3 +1,3 @@ dataHandler | @zip.js/zip.js

    Interface dataHandler

    Represents the callback function used to handle data events.

    interface dataHandler ((data) => void)
    • Parameters

      • data: Uint8Array

        The processed chunk of data.

        -

      Returns void

    Generated using TypeDoc

    \ No newline at end of file +

    Returns void

    \ No newline at end of file diff --git a/api/interfaces/registerDataHandler.html b/api/interfaces/registerDataHandler.html index b8b4a1ad..d31de6cb 100644 --- a/api/interfaces/registerDataHandler.html +++ b/api/interfaces/registerDataHandler.html @@ -1,4 +1,4 @@ registerDataHandler | @zip.js/zip.js

    Interface registerDataHandler

    Represents the callback function used to register the data event handler.

    interface registerDataHandler ((codec, onData) => void)

    Generated using TypeDoc

    \ No newline at end of file +

    Returns void

    \ No newline at end of file diff --git a/api/modules.html b/api/modules.html index e43e64b9..77b6254b 100644 --- a/api/modules.html +++ b/api/modules.html @@ -87,4 +87,4 @@ getMimeType initShimAsyncCodec terminateWorkers -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_BAD_FORMAT.html b/api/variables/ERR_BAD_FORMAT.html index 248f6365..3785fc34 100644 --- a/api/variables/ERR_BAD_FORMAT.html +++ b/api/variables/ERR_BAD_FORMAT.html @@ -1,2 +1,2 @@ ERR_BAD_FORMAT | @zip.js/zip.js

    Variable ERR_BAD_FORMATConst

    ERR_BAD_FORMAT: string

    Zip format error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_CENTRAL_DIRECTORY_NOT_FOUND.html b/api/variables/ERR_CENTRAL_DIRECTORY_NOT_FOUND.html index b7f9f5b3..06e572a2 100644 --- a/api/variables/ERR_CENTRAL_DIRECTORY_NOT_FOUND.html +++ b/api/variables/ERR_CENTRAL_DIRECTORY_NOT_FOUND.html @@ -1,2 +1,2 @@ ERR_CENTRAL_DIRECTORY_NOT_FOUND | @zip.js/zip.js

    Variable ERR_CENTRAL_DIRECTORY_NOT_FOUNDConst

    ERR_CENTRAL_DIRECTORY_NOT_FOUND: string

    Central Directory not found error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_DUPLICATED_NAME.html b/api/variables/ERR_DUPLICATED_NAME.html index eba9fc00..ce8db2de 100644 --- a/api/variables/ERR_DUPLICATED_NAME.html +++ b/api/variables/ERR_DUPLICATED_NAME.html @@ -1,2 +1,2 @@ ERR_DUPLICATED_NAME | @zip.js/zip.js

    Variable ERR_DUPLICATED_NAMEConst

    ERR_DUPLICATED_NAME: string

    Duplicate entry error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_ENCRYPTED.html b/api/variables/ERR_ENCRYPTED.html index f300cb7a..b6cd5d39 100644 --- a/api/variables/ERR_ENCRYPTED.html +++ b/api/variables/ERR_ENCRYPTED.html @@ -1,2 +1,2 @@ ERR_ENCRYPTED | @zip.js/zip.js

    Variable ERR_ENCRYPTEDConst

    ERR_ENCRYPTED: string

    Encrypted entry error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND.html b/api/variables/ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND.html index fe5f8a0a..8dac70f2 100644 --- a/api/variables/ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND.html +++ b/api/variables/ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND.html @@ -1,2 +1,2 @@ ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND | @zip.js/zip.js

    Variable ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUNDConst

    ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND: string

    Zip64 End of Central Directory Locator not found error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_EOCDR_NOT_FOUND.html b/api/variables/ERR_EOCDR_NOT_FOUND.html index 07055eb4..538ed593 100644 --- a/api/variables/ERR_EOCDR_NOT_FOUND.html +++ b/api/variables/ERR_EOCDR_NOT_FOUND.html @@ -1,2 +1,2 @@ ERR_EOCDR_NOT_FOUND | @zip.js/zip.js

    Variable ERR_EOCDR_NOT_FOUNDConst

    ERR_EOCDR_NOT_FOUND: string

    End of Central Directory Record not found error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_EOCDR_ZIP64_NOT_FOUND.html b/api/variables/ERR_EOCDR_ZIP64_NOT_FOUND.html index 8135d29a..e8875268 100644 --- a/api/variables/ERR_EOCDR_ZIP64_NOT_FOUND.html +++ b/api/variables/ERR_EOCDR_ZIP64_NOT_FOUND.html @@ -1,2 +1,2 @@ ERR_EOCDR_ZIP64_NOT_FOUND | @zip.js/zip.js

    Variable ERR_EOCDR_ZIP64_NOT_FOUNDConst

    ERR_EOCDR_ZIP64_NOT_FOUND: string

    Zip64 End of Central Directory Record not found error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_EXTRAFIELD_ZIP64_NOT_FOUND.html b/api/variables/ERR_EXTRAFIELD_ZIP64_NOT_FOUND.html index 54d39d8f..8b7f9a82 100644 --- a/api/variables/ERR_EXTRAFIELD_ZIP64_NOT_FOUND.html +++ b/api/variables/ERR_EXTRAFIELD_ZIP64_NOT_FOUND.html @@ -1,2 +1,2 @@ ERR_EXTRAFIELD_ZIP64_NOT_FOUND | @zip.js/zip.js

    Variable ERR_EXTRAFIELD_ZIP64_NOT_FOUNDConst

    ERR_EXTRAFIELD_ZIP64_NOT_FOUND: string

    Extra field Zip64 not found error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_HTTP_RANGE.html b/api/variables/ERR_HTTP_RANGE.html index c2684037..bd1bb4cc 100644 --- a/api/variables/ERR_HTTP_RANGE.html +++ b/api/variables/ERR_HTTP_RANGE.html @@ -1,2 +1,2 @@ ERR_HTTP_RANGE | @zip.js/zip.js

    Variable ERR_HTTP_RANGEConst

    ERR_HTTP_RANGE: string

    HTTP range error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_INVALID_COMMENT.html b/api/variables/ERR_INVALID_COMMENT.html index 4852c5b2..43eba7c9 100644 --- a/api/variables/ERR_INVALID_COMMENT.html +++ b/api/variables/ERR_INVALID_COMMENT.html @@ -1,2 +1,2 @@ ERR_INVALID_COMMENT | @zip.js/zip.js

    Variable ERR_INVALID_COMMENTConst

    ERR_INVALID_COMMENT: string

    Invalid comment error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_INVALID_ENCRYPTION_STRENGTH.html b/api/variables/ERR_INVALID_ENCRYPTION_STRENGTH.html index 4188d83e..4cd397d2 100644 --- a/api/variables/ERR_INVALID_ENCRYPTION_STRENGTH.html +++ b/api/variables/ERR_INVALID_ENCRYPTION_STRENGTH.html @@ -1,2 +1,2 @@ ERR_INVALID_ENCRYPTION_STRENGTH | @zip.js/zip.js

    Variable ERR_INVALID_ENCRYPTION_STRENGTHConst

    ERR_INVALID_ENCRYPTION_STRENGTH: string

    Invalid encryption strength error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_INVALID_ENTRY_COMMENT.html b/api/variables/ERR_INVALID_ENTRY_COMMENT.html index cd677e16..7f695fe1 100644 --- a/api/variables/ERR_INVALID_ENTRY_COMMENT.html +++ b/api/variables/ERR_INVALID_ENTRY_COMMENT.html @@ -1,2 +1,2 @@ ERR_INVALID_ENTRY_COMMENT | @zip.js/zip.js

    Variable ERR_INVALID_ENTRY_COMMENTConst

    ERR_INVALID_ENTRY_COMMENT: string

    Invalid entry comment error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_INVALID_ENTRY_NAME.html b/api/variables/ERR_INVALID_ENTRY_NAME.html index 5f91cb82..9cbc7f19 100644 --- a/api/variables/ERR_INVALID_ENTRY_NAME.html +++ b/api/variables/ERR_INVALID_ENTRY_NAME.html @@ -1,2 +1,2 @@ ERR_INVALID_ENTRY_NAME | @zip.js/zip.js

    Variable ERR_INVALID_ENTRY_NAMEConst

    ERR_INVALID_ENTRY_NAME: string

    Invalid entry name error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_INVALID_EXTRAFIELD_DATA.html b/api/variables/ERR_INVALID_EXTRAFIELD_DATA.html index b0de5c4e..f057f38f 100644 --- a/api/variables/ERR_INVALID_EXTRAFIELD_DATA.html +++ b/api/variables/ERR_INVALID_EXTRAFIELD_DATA.html @@ -1,2 +1,2 @@ ERR_INVALID_EXTRAFIELD_DATA | @zip.js/zip.js

    Variable ERR_INVALID_EXTRAFIELD_DATAConst

    ERR_INVALID_EXTRAFIELD_DATA: string

    Invalid extra field data error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_INVALID_EXTRAFIELD_TYPE.html b/api/variables/ERR_INVALID_EXTRAFIELD_TYPE.html index 6ae2b66e..d2d0acbe 100644 --- a/api/variables/ERR_INVALID_EXTRAFIELD_TYPE.html +++ b/api/variables/ERR_INVALID_EXTRAFIELD_TYPE.html @@ -1,2 +1,2 @@ ERR_INVALID_EXTRAFIELD_TYPE | @zip.js/zip.js

    Variable ERR_INVALID_EXTRAFIELD_TYPEConst

    ERR_INVALID_EXTRAFIELD_TYPE: string

    Invalid extra field type error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_INVALID_PASSWORD.html b/api/variables/ERR_INVALID_PASSWORD.html index c7b23641..eded1a32 100644 --- a/api/variables/ERR_INVALID_PASSWORD.html +++ b/api/variables/ERR_INVALID_PASSWORD.html @@ -1,2 +1,2 @@ ERR_INVALID_PASSWORD | @zip.js/zip.js

    Variable ERR_INVALID_PASSWORDConst

    ERR_INVALID_PASSWORD: string

    Invalid password error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_INVALID_SIGNATURE.html b/api/variables/ERR_INVALID_SIGNATURE.html index 874bfcf0..7281d887 100644 --- a/api/variables/ERR_INVALID_SIGNATURE.html +++ b/api/variables/ERR_INVALID_SIGNATURE.html @@ -1,2 +1,2 @@ ERR_INVALID_SIGNATURE | @zip.js/zip.js

    Variable ERR_INVALID_SIGNATUREConst

    ERR_INVALID_SIGNATURE: string

    Invalid signature error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_INVALID_VERSION.html b/api/variables/ERR_INVALID_VERSION.html index 311438a9..12d931fa 100644 --- a/api/variables/ERR_INVALID_VERSION.html +++ b/api/variables/ERR_INVALID_VERSION.html @@ -1,2 +1,2 @@ ERR_INVALID_VERSION | @zip.js/zip.js

    Variable ERR_INVALID_VERSIONConst

    ERR_INVALID_VERSION: string

    Invalid version error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_ITERATOR_COMPLETED_TOO_SOON.html b/api/variables/ERR_ITERATOR_COMPLETED_TOO_SOON.html index a3be8d6a..c57f68d1 100644 --- a/api/variables/ERR_ITERATOR_COMPLETED_TOO_SOON.html +++ b/api/variables/ERR_ITERATOR_COMPLETED_TOO_SOON.html @@ -1,2 +1,2 @@ ERR_ITERATOR_COMPLETED_TOO_SOON | @zip.js/zip.js

    Variable ERR_ITERATOR_COMPLETED_TOO_SOONConst

    ERR_ITERATOR_COMPLETED_TOO_SOON: string

    Iteration completed too soon error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_LOCAL_FILE_HEADER_NOT_FOUND.html b/api/variables/ERR_LOCAL_FILE_HEADER_NOT_FOUND.html index eb14e67b..9d530b3a 100644 --- a/api/variables/ERR_LOCAL_FILE_HEADER_NOT_FOUND.html +++ b/api/variables/ERR_LOCAL_FILE_HEADER_NOT_FOUND.html @@ -1,2 +1,2 @@ ERR_LOCAL_FILE_HEADER_NOT_FOUND | @zip.js/zip.js

    Variable ERR_LOCAL_FILE_HEADER_NOT_FOUNDConst

    ERR_LOCAL_FILE_HEADER_NOT_FOUND: string

    Local file header not found error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_SPLIT_ZIP_FILE.html b/api/variables/ERR_SPLIT_ZIP_FILE.html index 218efb4a..863b5b1d 100644 --- a/api/variables/ERR_SPLIT_ZIP_FILE.html +++ b/api/variables/ERR_SPLIT_ZIP_FILE.html @@ -1,2 +1,2 @@ ERR_SPLIT_ZIP_FILE | @zip.js/zip.js

    Variable ERR_SPLIT_ZIP_FILEConst

    ERR_SPLIT_ZIP_FILE: string

    Split zip file error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_UNSUPPORTED_COMPRESSION.html b/api/variables/ERR_UNSUPPORTED_COMPRESSION.html index ae3b4dd9..fff3d543 100644 --- a/api/variables/ERR_UNSUPPORTED_COMPRESSION.html +++ b/api/variables/ERR_UNSUPPORTED_COMPRESSION.html @@ -1,2 +1,2 @@ ERR_UNSUPPORTED_COMPRESSION | @zip.js/zip.js

    Variable ERR_UNSUPPORTED_COMPRESSIONConst

    ERR_UNSUPPORTED_COMPRESSION: string

    Unsupported compression error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_UNSUPPORTED_ENCRYPTION.html b/api/variables/ERR_UNSUPPORTED_ENCRYPTION.html index 60045bbf..ca0b95c9 100644 --- a/api/variables/ERR_UNSUPPORTED_ENCRYPTION.html +++ b/api/variables/ERR_UNSUPPORTED_ENCRYPTION.html @@ -1,2 +1,2 @@ ERR_UNSUPPORTED_ENCRYPTION | @zip.js/zip.js

    Variable ERR_UNSUPPORTED_ENCRYPTIONConst

    ERR_UNSUPPORTED_ENCRYPTION: string

    Unsupported encryption error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/ERR_UNSUPPORTED_FORMAT.html b/api/variables/ERR_UNSUPPORTED_FORMAT.html index e3880c5e..c0a604d2 100644 --- a/api/variables/ERR_UNSUPPORTED_FORMAT.html +++ b/api/variables/ERR_UNSUPPORTED_FORMAT.html @@ -1,2 +1,2 @@ ERR_UNSUPPORTED_FORMAT | @zip.js/zip.js

    Variable ERR_UNSUPPORTED_FORMATConst

    ERR_UNSUPPORTED_FORMAT: string

    Invalid format error

    -

    Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file diff --git a/api/variables/fs-1.html b/api/variables/fs-1.html index 18b57055..b619400d 100644 --- a/api/variables/fs-1.html +++ b/api/variables/fs-1.html @@ -8,4 +8,4 @@
  • ZipFileEntry: typeof ZipFileEntry

    The ZipFileEntry constructor.

    Default Value

    {@link ZipFileEntry}
     
    -
  • Generated using TypeDoc

    \ No newline at end of file +
    \ No newline at end of file