@volverjs/ui-vue 0.0.10-beta.11 → 0.0.10-beta.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/auto-imports.d.ts +1 -0
- package/dist/components/VvInputFile/VvInputFile.es.js +1529 -0
- package/dist/components/VvInputFile/VvInputFile.umd.js +1 -0
- package/dist/components/VvInputFile/VvInputFile.vue.d.ts +141 -0
- package/dist/components/VvInputFile/index.d.ts +52 -0
- package/dist/components/VvTab/VvTab.es.js +2 -2
- package/dist/components/VvTab/VvTab.umd.js +1 -1
- package/dist/components/VvTab/VvTab.vue.d.ts +1 -0
- package/dist/components/index.d.ts +1 -0
- package/dist/components/index.es.js +635 -312
- package/dist/components/index.umd.js +1 -1
- package/dist/composables/index.d.ts +1 -0
- package/dist/composables/index.es.js +77 -1
- package/dist/composables/index.umd.js +1 -1
- package/dist/composables/useBlurhash.d.ts +7 -0
- package/dist/icons.es.js +3 -3
- package/dist/icons.umd.js +1 -1
- package/dist/stories/AlertGroup/AlertGroupWithComposable.stories.d.ts +1 -1
- package/dist/stories/Blurhash/BlurhashComposable.stories.d.ts +4 -0
- package/dist/stories/InputFile/InputFile.settings.d.ts +56 -0
- package/dist/stories/InputFile/InputFile.stories.d.ts +12 -0
- package/dist/stories/InputFile/InputFileModifiers.stories.d.ts +9 -0
- package/dist/stories/InputFile/InputFileSlots.stories.d.ts +6 -0
- package/dist/types/blurhash.d.ts +12 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/input-file.d.ts +14 -0
- package/dist/workers/blurhash.d.ts +1 -0
- package/package.json +13 -1
- package/src/assets/icons/detailed.json +1 -1
- package/src/assets/icons/normal.json +1 -1
- package/src/assets/icons/simple.json +1 -1
- package/src/components/VvInputFile/VvInputFile.vue +274 -0
- package/src/components/VvInputFile/index.ts +36 -0
- package/src/components/VvTab/VvTab.vue +2 -2
- package/src/components/index.ts +1 -0
- package/src/composables/index.ts +1 -0
- package/src/composables/useBlurhash.ts +76 -0
- package/src/stories/AlertGroup/AlertGroupWithComposable.stories.ts +2 -2
- package/src/stories/Blurhash/BlurhashComposable.stories.ts +195 -0
- package/src/stories/InputFile/InputFile.settings.ts +36 -0
- package/src/stories/InputFile/InputFile.stories.ts +90 -0
- package/src/stories/InputFile/InputFileModifiers.stories.ts +51 -0
- package/src/stories/InputFile/InputFileSlots.stories.ts +25 -0
- package/src/types/blurhash.ts +21 -0
- package/src/types/index.ts +2 -0
- package/src/types/input-file.ts +16 -0
- package/src/workers/blurhash.ts +9 -0
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import { reactive, computed } from "vue";
|
|
2
|
+
import { wrap } from "comlink";
|
|
3
|
+
import pica from "pica";
|
|
2
4
|
const DEFAULT_ALERT_AUTO_CLOSE = 1e4;
|
|
3
5
|
const DEFAULT_ALERT_MODIFIERS = "info";
|
|
4
6
|
const DEFAULT_ALERT_DISMISSABLE = true;
|
|
@@ -76,6 +78,80 @@ const useAlert = () => {
|
|
|
76
78
|
getAlerts
|
|
77
79
|
};
|
|
78
80
|
};
|
|
81
|
+
const encodedJs = "!function(){"use strict";
/**
   * @license
   * Copyright 2019 Google LLC
   * SPDX-License-Identifier: Apache-2.0
   */const t=Symbol("Comlink.proxy"),e=Symbol("Comlink.endpoint"),r=Symbol("Comlink.releaseProxy"),n=Symbol("Comlink.finalizer"),a=Symbol("Comlink.thrown"),o=t=>"object"==typeof t&&null!==t||"function"==typeof t,s=new Map([["proxy",{canHandle:e=>o(e)&&e[t],serialize(t){const{port1:e,port2:r}=new MessageChannel;return i(t,e),[r,[r]]},deserialize(t){return t.start(),m(t,[],e);var e}}],["throw",{canHandle:t=>o(t)&&a in t,serialize({value:t}){let e;return e=t instanceof Error?{isError:!0,value:{message:t.message,name:t.name,stack:t.stack}}:{isError:!1,value:t},[e,[]]},deserialize(t){if(t.isError)throw Object.assign(new Error(t.value.message),t.value);throw t.value}}]]);function i(e,r=globalThis,o=["*"]){r.addEventListener("message",(function s(h){if(!h||!h.data)return;if(!function(t,e){for(const r of t){if(e===r||"*"===r)return!0;if(r instanceof RegExp&&r.test(e))return!0}return!1}(o,h.origin))return void console.warn(`Invalid origin '${h.origin}' for comlink proxy`);const{id:c,type:u,path:f}=Object.assign({path:[]},h.data),m=(h.data.argumentList||[]).map(d);let p;try{const r=f.slice(0,-1).reduce(((t,e)=>t[e]),e),n=f.reduce(((t,e)=>t[e]),e);switch(u){case"GET":p=n;break;case"SET":r[f.slice(-1)[0]]=d(h.data.value),p=!0;break;case"APPLY":p=n.apply(r,m);break;case"CONSTRUCT":p=function(e){return Object.assign(e,{[t]:!0})}(new n(...m));break;case"ENDPOINT":{const{port1:t,port2:r}=new MessageChannel;i(e,r),p=function(t,e){return g.set(t,e),t}(t,[t])}break;case"RELEASE":p=void 0;break;default:return}}catch(y){p={value:y,[a]:0}}Promise.resolve(p).catch((t=>({value:t,[a]:0}))).then((t=>{const[a,o]=M(t);r.postMessage(Object.assign(Object.assign({},a),{id:c}),o),"RELEASE"===u&&(r.removeEventListener("message",s),l(r),n in e&&"function"==typeof e[n]&&e[n]())})).catch((t=>{const[e,n]=M({value:new TypeError("Unserializable return value"),[a]:0});r.postMessage(Object.assign(Object.assign({},e),{id:c}),n)}))})),r.start&&r.start()}function l(t){(function(t){return"MessagePort"===t.constructor.name})(t)&&t.close()}function h(t){if(t)throw new Error("Proxy has been released and is not useable")}function c(t){return y(t,{type:"RELEASE"}).then((()=>{l(t)}))}const u=new WeakMap,f="FinalizationRegistry"in globalThis&&new FinalizationRegistry((t=>{const e=(u.get(t)||0)-1;u.set(t,e),0===e&&c(t)}));function m(t,n=[],a=function(){}){let o=!1;const s=new Proxy(a,{get(e,a){if(h(o),a===r)return()=>{!function(t){f&&f.unregister(t)}(s),c(t),o=!0};if("then"===a){if(0===n.length)return{then:()=>s};const e=y(t,{type:"GET",path:n.map((t=>t.toString()))}).then(d);return e.then.bind(e)}return m(t,[...n,a])},set(e,r,a){h(o);const[s,i]=M(a);return y(t,{type:"SET",path:[...n,r].map((t=>t.toString())),value:s},i).then(d)},apply(r,a,s){h(o);const i=n[n.length-1];if(i===e)return y(t,{type:"ENDPOINT"}).then(d);if("bind"===i)return m(t,n.slice(0,-1));const[l,c]=p(s);return y(t,{type:"APPLY",path:n.map((t=>t.toString())),argumentList:l},c).then(d)},construct(e,r){h(o);const[a,s]=p(r);return y(t,{type:"CONSTRUCT",path:n.map((t=>t.toString())),argumentList:a},s).then(d)}});return function(t,e){const r=(u.get(e)||0)+1;u.set(e,r),f&&f.register(t,e,t)}(s,t),s}function p(t){const e=t.map(M);return[e.map((t=>t[0])),(r=e.map((t=>t[1])),Array.prototype.concat.apply([],r))];var r}const g=new WeakMap;function M(t){for(const[e,r]of s)if(r.canHandle(t)){const[n,a]=r.serialize(t);return[{type:"HANDLER",name:e,value:n},a]}return[{type:"RAW",value:t},g.get(t)||[]]}function d(t){switch(t.type){case"HANDLER":return s.get(t.name).deserialize(t.value);case"RAW":return t.value}}function y(t,e,r){return new Promise((n=>{const a=new Array(4).fill(0).map((()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16))).join("-");t.addEventListener("message",(function e(r){r.data&&r.data.id&&r.data.id===a&&(t.removeEventListener("message",e),n(r.data))})),t.start&&t.start(),t.postMessage(Object.assign({id:a},e),r)}))}var b=["0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z","#","$","%","*","+",",","-",".",":",";","=","?","@","[","]","^","_","{","|","}","~"],w=t=>{let e=0;for(let r=0;r<t.length;r++){let n=t[r];e=83*e+b.indexOf(n)}return e},E=(t,e)=>{var r="";for(let n=1;n<=e;n++){let a=Math.floor(t)/Math.pow(83,e-n)%83;r+=b[Math.floor(a)]}return r},v=t=>{let e=t/255;return e<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)},S=t=>{let e=Math.max(0,Math.min(1,t));return e<=.0031308?Math.trunc(12.92*e*255+.5):Math.trunc(255*(1.055*Math.pow(e,.4166666666666667)-.055)+.5)},x=(t,e)=>(t=>t<0?-1:1)(t)*Math.pow(Math.abs(t),e),k=class extends Error{constructor(t){super(t),this.name="ValidationError",this.message=t}},P=t=>{if(!t||t.length<6)throw new k("The blurhash string must be at least 6 characters");let e=w(t[0]),r=Math.floor(e/9)+1,n=e%9+1;if(t.length!==4+2*n*r)throw new k(`blurhash length mismatch: length is ${t.length} but it should be ${4+2*n*r}`)},A=t=>{let e=t>>8&255,r=255&t;return[v(t>>16),v(e),v(r)]},T=(t,e)=>{let r=Math.floor(t/361),n=Math.floor(t/19)%19,a=t%19;return[x((r-9)/9,2)*e,x((n-9)/9,2)*e,x((a-9)/9,2)*e]},L=(t,e,r,n)=>{let a=0,o=0,s=0,i=4*e;for(let h=0;h<e;h++){let e=4*h;for(let l=0;l<r;l++){let r=e+l*i,c=n(h,l);a+=c*v(t[r]),o+=c*v(t[r+1]),s+=c*v(t[r+2])}}let l=1/(e*r);return[a*l,o*l,s*l]},R=(t,e,r,n,a)=>{if(n<1||n>9||a<1||a>9)throw new k("BlurHash must have between 1 and 9 components");if(e*r*4!==t.length)throw new k("Width and height must match the pixels array");let o=[];for(let c=0;c<a;c++)for(let a=0;a<n;a++){let n=0==a&&0==c?1:2,s=L(t,e,r,((t,o)=>n*Math.cos(Math.PI*a*t/e)*Math.cos(Math.PI*c*o/r)));o.push(s)}let s,i=o[0],l=o.slice(1),h="";if(h+=E(n-1+9*(a-1),1),l.length>0){let t=Math.max(...l.map((t=>Math.max(...t)))),e=Math.floor(Math.max(0,Math.min(82,Math.floor(166*t-.5))));s=(e+1)/166,h+=E(e,1)}else s=1,h+=E(0,1);return h+=E((t=>(S(t[0])<<16)+(S(t[1])<<8)+S(t[2]))(i),4),l.forEach((t=>{h+=E(((t,e)=>19*Math.floor(Math.max(0,Math.min(18,Math.floor(9*x(t[0]/e,.5)+9.5))))*19+19*Math.floor(Math.max(0,Math.min(18,Math.floor(9*x(t[1]/e,.5)+9.5))))+Math.floor(Math.max(0,Math.min(18,Math.floor(9*x(t[2]/e,.5)+9.5)))))(t,s),2)})),h};i({ValidationError:k,encode:R,decode:(t,e,r,n)=>{P(t),n|=1;let a=w(t[0]),o=Math.floor(a/9)+1,s=a%9+1,i=(w(t[1])+1)/166,l=new Array(s*o);for(let u=0;u<l.length;u++)if(0===u){let e=w(t.substring(2,6));l[u]=A(e)}else{let e=w(t.substring(4+2*u,6+2*u));l[u]=T(e,i*n)}let h=4*e,c=new Uint8ClampedArray(h*r);for(let u=0;u<r;u++)for(let t=0;t<e;t++){let n=0,a=0,i=0;for(let h=0;h<o;h++)for(let o=0;o<s;o++){let c=Math.cos(Math.PI*t*o/e)*Math.cos(Math.PI*u*h/r),f=l[o+h*s];n+=f[0]*c,a+=f[1]*c,i+=f[2]*c}let f=S(n),m=S(a),p=S(i);c[4*t+0+u*h]=f,c[4*t+1+u*h]=m,c[4*t+2+u*h]=p,c[4*t+3+u*h]=255}return c},isBlurhashValid:t=>{try{P(t)}catch(e){return{result:!1,errorReason:e.message}}return{result:!0}}})}();
";
|
|
82
|
+
const blob = typeof window !== "undefined" && window.Blob && new Blob([atob(encodedJs)], { type: "text/javascript;charset=utf-8" });
|
|
83
|
+
function WorkerWrapper() {
|
|
84
|
+
let objURL;
|
|
85
|
+
try {
|
|
86
|
+
objURL = blob && (window.URL || window.webkitURL).createObjectURL(blob);
|
|
87
|
+
if (!objURL)
|
|
88
|
+
throw "";
|
|
89
|
+
return new Worker(objURL);
|
|
90
|
+
} catch (e) {
|
|
91
|
+
return new Worker("data:application/javascript;base64," + encodedJs);
|
|
92
|
+
} finally {
|
|
93
|
+
objURL && (window.URL || window.webkitURL).revokeObjectURL(objURL);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
const remoteFunction = wrap(new WorkerWrapper());
|
|
97
|
+
function loadImage(src) {
|
|
98
|
+
return new Promise((resolve, reject) => {
|
|
99
|
+
const img = new Image();
|
|
100
|
+
img.onload = () => resolve(img);
|
|
101
|
+
img.onerror = (...args) => reject(args);
|
|
102
|
+
img.src = src;
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
const getWidthHeightFromMaxSize = (width, height, maxSize) => {
|
|
106
|
+
if (width > height) {
|
|
107
|
+
return {
|
|
108
|
+
width: maxSize,
|
|
109
|
+
height: Math.round(maxSize * (height / width))
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
return {
|
|
113
|
+
width: Math.round(maxSize * (width / height)),
|
|
114
|
+
height: maxSize
|
|
115
|
+
};
|
|
116
|
+
};
|
|
117
|
+
const resizeImage = async (image, width, height) => {
|
|
118
|
+
var _a;
|
|
119
|
+
const resizer = new pica();
|
|
120
|
+
const canvas = document.createElement("canvas");
|
|
121
|
+
canvas.width = width;
|
|
122
|
+
canvas.height = height;
|
|
123
|
+
const result = await resizer.resize(image, canvas);
|
|
124
|
+
return (_a = result.getContext("2d")) == null ? void 0 : _a.getImageData(0, 0, width, height).data;
|
|
125
|
+
};
|
|
126
|
+
const useBlurhash = () => {
|
|
127
|
+
async function encode(file) {
|
|
128
|
+
const imageUrl = URL.createObjectURL(file);
|
|
129
|
+
const image = await loadImage(imageUrl);
|
|
130
|
+
if ("width" in image && "height" in image) {
|
|
131
|
+
const { width: newWidth, height: newHeight } = getWidthHeightFromMaxSize(
|
|
132
|
+
image.width,
|
|
133
|
+
image.height,
|
|
134
|
+
32
|
|
135
|
+
);
|
|
136
|
+
const imageData = await resizeImage(
|
|
137
|
+
image,
|
|
138
|
+
newWidth,
|
|
139
|
+
newHeight
|
|
140
|
+
);
|
|
141
|
+
if (imageData) {
|
|
142
|
+
return remoteFunction.encode(
|
|
143
|
+
imageData,
|
|
144
|
+
newWidth,
|
|
145
|
+
newHeight,
|
|
146
|
+
4,
|
|
147
|
+
4
|
|
148
|
+
);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
return { encode, decode: remoteFunction.decode, loadImage };
|
|
153
|
+
};
|
|
79
154
|
export {
|
|
80
|
-
useAlert
|
|
155
|
+
useAlert,
|
|
156
|
+
useBlurhash
|
|
81
157
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("vue")):"function"==typeof define&&define.amd?define(["exports","vue"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).composables={},e.vue)}(this,(function(e,t){"use strict";const o="default",n="information",i=new Map([["success","check-circle"],["info",n],["warning","warning"],["danger","error"]]),s=t.reactive(new Map([[o,new Map]]));e.useAlert=()=>{const e=(e=o)=>t.computed((()=>{const t=s.get(e);return t&&t instanceof Map?Array.from(null==t?void 0:t.values()).sort(((e,t)=>e.timestamp-t.timestamp)):[]}));return{groups:s,alerts:e(),addAlert:({id:e=crypto.randomUUID(),group:t=o,title:r,icon:a=n,content:l,footer:u,modifiers:c="info",dismissable:f=true,autoClose:d=1e4}={})=>{s.has(t)||s.set(t,new Map);const p=s.get(t),m="string"==typeof c?c.split(" "):c;if(!a){const e=m.find((e=>i.has(e)));e&&(a=i.get(e))}null==p||p.set(e.toString(),{id:e,group:t,title:r,icon:a,content:l,footer:u,modifiers:c,dismissable:f,autoClose:d,timestamp:Date.now()})},removeAlert:(e,t=o)=>{const n=s.get(t);null==n||n.delete(e.toString())},getAlerts:e}},Object.defineProperty(e,Symbol.toStringTag,{value:"Module"})}));
|
|
1
|
+
!function(i,d){"object"==typeof exports&&"undefined"!=typeof module?d(exports,require("vue"),require("comlink"),require("pica")):"function"==typeof define&&define.amd?define(["exports","vue","comlink","pica"],d):d((i="undefined"!=typeof globalThis?globalThis:i||self).composables={},i.vue,i.comlink,i.pica)}(this,(function(i,d,l,b){"use strict";const c="default",o="information",s=new Map([["success","check-circle"],["info",o],["warning","warning"],["danger","error"]]),K=d.reactive(new Map([[c,new Map]])),m="!function(){"use strict";
/**
   * @license
   * Copyright 2019 Google LLC
   * SPDX-License-Identifier: Apache-2.0
   */const t=Symbol("Comlink.proxy"),e=Symbol("Comlink.endpoint"),r=Symbol("Comlink.releaseProxy"),n=Symbol("Comlink.finalizer"),a=Symbol("Comlink.thrown"),o=t=>"object"==typeof t&&null!==t||"function"==typeof t,s=new Map([["proxy",{canHandle:e=>o(e)&&e[t],serialize(t){const{port1:e,port2:r}=new MessageChannel;return i(t,e),[r,[r]]},deserialize(t){return t.start(),m(t,[],e);var e}}],["throw",{canHandle:t=>o(t)&&a in t,serialize({value:t}){let e;return e=t instanceof Error?{isError:!0,value:{message:t.message,name:t.name,stack:t.stack}}:{isError:!1,value:t},[e,[]]},deserialize(t){if(t.isError)throw Object.assign(new Error(t.value.message),t.value);throw t.value}}]]);function i(e,r=globalThis,o=["*"]){r.addEventListener("message",(function s(h){if(!h||!h.data)return;if(!function(t,e){for(const r of t){if(e===r||"*"===r)return!0;if(r instanceof RegExp&&r.test(e))return!0}return!1}(o,h.origin))return void console.warn(`Invalid origin '${h.origin}' for comlink proxy`);const{id:c,type:u,path:f}=Object.assign({path:[]},h.data),m=(h.data.argumentList||[]).map(d);let p;try{const r=f.slice(0,-1).reduce(((t,e)=>t[e]),e),n=f.reduce(((t,e)=>t[e]),e);switch(u){case"GET":p=n;break;case"SET":r[f.slice(-1)[0]]=d(h.data.value),p=!0;break;case"APPLY":p=n.apply(r,m);break;case"CONSTRUCT":p=function(e){return Object.assign(e,{[t]:!0})}(new n(...m));break;case"ENDPOINT":{const{port1:t,port2:r}=new MessageChannel;i(e,r),p=function(t,e){return g.set(t,e),t}(t,[t])}break;case"RELEASE":p=void 0;break;default:return}}catch(y){p={value:y,[a]:0}}Promise.resolve(p).catch((t=>({value:t,[a]:0}))).then((t=>{const[a,o]=M(t);r.postMessage(Object.assign(Object.assign({},a),{id:c}),o),"RELEASE"===u&&(r.removeEventListener("message",s),l(r),n in e&&"function"==typeof e[n]&&e[n]())})).catch((t=>{const[e,n]=M({value:new TypeError("Unserializable return value"),[a]:0});r.postMessage(Object.assign(Object.assign({},e),{id:c}),n)}))})),r.start&&r.start()}function l(t){(function(t){return"MessagePort"===t.constructor.name})(t)&&t.close()}function h(t){if(t)throw new Error("Proxy has been released and is not useable")}function c(t){return y(t,{type:"RELEASE"}).then((()=>{l(t)}))}const u=new WeakMap,f="FinalizationRegistry"in globalThis&&new FinalizationRegistry((t=>{const e=(u.get(t)||0)-1;u.set(t,e),0===e&&c(t)}));function m(t,n=[],a=function(){}){let o=!1;const s=new Proxy(a,{get(e,a){if(h(o),a===r)return()=>{!function(t){f&&f.unregister(t)}(s),c(t),o=!0};if("then"===a){if(0===n.length)return{then:()=>s};const e=y(t,{type:"GET",path:n.map((t=>t.toString()))}).then(d);return e.then.bind(e)}return m(t,[...n,a])},set(e,r,a){h(o);const[s,i]=M(a);return y(t,{type:"SET",path:[...n,r].map((t=>t.toString())),value:s},i).then(d)},apply(r,a,s){h(o);const i=n[n.length-1];if(i===e)return y(t,{type:"ENDPOINT"}).then(d);if("bind"===i)return m(t,n.slice(0,-1));const[l,c]=p(s);return y(t,{type:"APPLY",path:n.map((t=>t.toString())),argumentList:l},c).then(d)},construct(e,r){h(o);const[a,s]=p(r);return y(t,{type:"CONSTRUCT",path:n.map((t=>t.toString())),argumentList:a},s).then(d)}});return function(t,e){const r=(u.get(e)||0)+1;u.set(e,r),f&&f.register(t,e,t)}(s,t),s}function p(t){const e=t.map(M);return[e.map((t=>t[0])),(r=e.map((t=>t[1])),Array.prototype.concat.apply([],r))];var r}const g=new WeakMap;function M(t){for(const[e,r]of s)if(r.canHandle(t)){const[n,a]=r.serialize(t);return[{type:"HANDLER",name:e,value:n},a]}return[{type:"RAW",value:t},g.get(t)||[]]}function d(t){switch(t.type){case"HANDLER":return s.get(t.name).deserialize(t.value);case"RAW":return t.value}}function y(t,e,r){return new Promise((n=>{const a=new Array(4).fill(0).map((()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16))).join("-");t.addEventListener("message",(function e(r){r.data&&r.data.id&&r.data.id===a&&(t.removeEventListener("message",e),n(r.data))})),t.start&&t.start(),t.postMessage(Object.assign({id:a},e),r)}))}var b=["0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z","#","$","%","*","+",",","-",".",":",";","=","?","@","[","]","^","_","{","|","}","~"],w=t=>{let e=0;for(let r=0;r<t.length;r++){let n=t[r];e=83*e+b.indexOf(n)}return e},E=(t,e)=>{var r="";for(let n=1;n<=e;n++){let a=Math.floor(t)/Math.pow(83,e-n)%83;r+=b[Math.floor(a)]}return r},v=t=>{let e=t/255;return e<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)},S=t=>{let e=Math.max(0,Math.min(1,t));return e<=.0031308?Math.trunc(12.92*e*255+.5):Math.trunc(255*(1.055*Math.pow(e,.4166666666666667)-.055)+.5)},x=(t,e)=>(t=>t<0?-1:1)(t)*Math.pow(Math.abs(t),e),k=class extends Error{constructor(t){super(t),this.name="ValidationError",this.message=t}},P=t=>{if(!t||t.length<6)throw new k("The blurhash string must be at least 6 characters");let e=w(t[0]),r=Math.floor(e/9)+1,n=e%9+1;if(t.length!==4+2*n*r)throw new k(`blurhash length mismatch: length is ${t.length} but it should be ${4+2*n*r}`)},A=t=>{let e=t>>8&255,r=255&t;return[v(t>>16),v(e),v(r)]},T=(t,e)=>{let r=Math.floor(t/361),n=Math.floor(t/19)%19,a=t%19;return[x((r-9)/9,2)*e,x((n-9)/9,2)*e,x((a-9)/9,2)*e]},L=(t,e,r,n)=>{let a=0,o=0,s=0,i=4*e;for(let h=0;h<e;h++){let e=4*h;for(let l=0;l<r;l++){let r=e+l*i,c=n(h,l);a+=c*v(t[r]),o+=c*v(t[r+1]),s+=c*v(t[r+2])}}let l=1/(e*r);return[a*l,o*l,s*l]},R=(t,e,r,n,a)=>{if(n<1||n>9||a<1||a>9)throw new k("BlurHash must have between 1 and 9 components");if(e*r*4!==t.length)throw new k("Width and height must match the pixels array");let o=[];for(let c=0;c<a;c++)for(let a=0;a<n;a++){let n=0==a&&0==c?1:2,s=L(t,e,r,((t,o)=>n*Math.cos(Math.PI*a*t/e)*Math.cos(Math.PI*c*o/r)));o.push(s)}let s,i=o[0],l=o.slice(1),h="";if(h+=E(n-1+9*(a-1),1),l.length>0){let t=Math.max(...l.map((t=>Math.max(...t)))),e=Math.floor(Math.max(0,Math.min(82,Math.floor(166*t-.5))));s=(e+1)/166,h+=E(e,1)}else s=1,h+=E(0,1);return h+=E((t=>(S(t[0])<<16)+(S(t[1])<<8)+S(t[2]))(i),4),l.forEach((t=>{h+=E(((t,e)=>19*Math.floor(Math.max(0,Math.min(18,Math.floor(9*x(t[0]/e,.5)+9.5))))*19+19*Math.floor(Math.max(0,Math.min(18,Math.floor(9*x(t[1]/e,.5)+9.5))))+Math.floor(Math.max(0,Math.min(18,Math.floor(9*x(t[2]/e,.5)+9.5)))))(t,s),2)})),h};i({ValidationError:k,encode:R,decode:(t,e,r,n)=>{P(t),n|=1;let a=w(t[0]),o=Math.floor(a/9)+1,s=a%9+1,i=(w(t[1])+1)/166,l=new Array(s*o);for(let u=0;u<l.length;u++)if(0===u){let e=w(t.substring(2,6));l[u]=A(e)}else{let e=w(t.substring(4+2*u,6+2*u));l[u]=T(e,i*n)}let h=4*e,c=new Uint8ClampedArray(h*r);for(let u=0;u<r;u++)for(let t=0;t<e;t++){let n=0,a=0,i=0;for(let h=0;h<o;h++)for(let o=0;o<s;o++){let c=Math.cos(Math.PI*t*o/e)*Math.cos(Math.PI*u*h/r),f=l[o+h*s];n+=f[0]*c,a+=f[1]*c,i+=f[2]*c}let f=S(n),m=S(a),p=S(i);c[4*t+0+u*h]=f,c[4*t+1+u*h]=m,c[4*t+2+u*h]=p,c[4*t+3+u*h]=255}return c},isBlurhashValid:t=>{try{P(t)}catch(e){return{result:!1,errorReason:e.message}}return{result:!0}}})}();
",Z="undefined"!=typeof window&&window.Blob&&new Blob([atob(m)],{type:"text/javascript;charset=utf-8"});const I=l.wrap(new function(){let i;try{if(i=Z&&(window.URL||window.webkitURL).createObjectURL(Z),!i)throw"";return new Worker(i)}catch(d){return new Worker("data:application/javascript;base64,"+m)}finally{i&&(window.URL||window.webkitURL).revokeObjectURL(i)}});function t(i){return new Promise(((d,l)=>{const b=new Image;b.onload=()=>d(b),b.onerror=(...i)=>l(i),b.src=i}))}i.useAlert=()=>{const i=(i=c)=>d.computed((()=>{const d=K.get(i);return d&&d instanceof Map?Array.from(null==d?void 0:d.values()).sort(((i,d)=>i.timestamp-d.timestamp)):[]}));return{groups:K,alerts:i(),addAlert:({id:i=crypto.randomUUID(),group:d=c,title:l,icon:b=o,content:m,footer:Z,modifiers:I="info",dismissable:t=true,autoClose:p=1e4}={})=>{K.has(d)||K.set(d,new Map);const X=K.get(d),h="string"==typeof I?I.split(" "):I;if(!b){const i=h.find((i=>s.has(i)));i&&(b=s.get(i))}null==X||X.set(i.toString(),{id:i,group:d,title:l,icon:b,content:m,footer:Z,modifiers:I,dismissable:t,autoClose:p,timestamp:Date.now()})},removeAlert:(i,d=c)=>{const l=K.get(d);null==l||l.delete(i.toString())},getAlerts:i}},i.useBlurhash=()=>({encode:async function(i){const d=URL.createObjectURL(i),l=await t(d);if("width"in l&&"height"in l){const{width:i,height:d}=(c=l.width,o=l.height,s=32,c>o?{width:s,height:Math.round(s*(o/c))}:{width:Math.round(s*(c/o)),height:s}),K=await(async(i,d,l)=>{var c;const o=new b,s=document.createElement("canvas");return s.width=d,s.height=l,null==(c=(await o.resize(i,s)).getContext("2d"))?void 0:c.getImageData(0,0,d,l).data})(l,i,d);if(K)return I.encode(K,i,d,4,4)}var c,o,s},decode:I.decode,loadImage:t}),Object.defineProperty(i,Symbol.toStringTag,{value:"Module"})}));
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
declare function loadImage(src: string): Promise<CanvasImageSource>;
|
|
2
|
+
export declare const useBlurhash: () => {
|
|
3
|
+
encode: (file: File) => Promise<string | undefined>;
|
|
4
|
+
decode: import("comlink").Remote<(blurhash: string, width: number, height: number, punch?: number | undefined) => Uint8ClampedArray>;
|
|
5
|
+
loadImage: typeof loadImage;
|
|
6
|
+
};
|
|
7
|
+
export {};
|
package/dist/icons.es.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
const prefix$2 = "normal";
|
|
2
|
-
const lastModified$2 =
|
|
2
|
+
const lastModified$2 = 1697194530;
|
|
3
3
|
const icons$3 = {
|
|
4
4
|
add: {
|
|
5
5
|
body: '<path fill="none" stroke="currentColor" stroke-linecap="round" stroke-width="2" d="M4 12h16m-8-8v16"/>'
|
|
@@ -614,7 +614,7 @@ const normal = {
|
|
|
614
614
|
height: height$1
|
|
615
615
|
};
|
|
616
616
|
const prefix$1 = "detailed";
|
|
617
|
-
const lastModified$1 =
|
|
617
|
+
const lastModified$1 = 1697194530;
|
|
618
618
|
const icons$2 = {
|
|
619
619
|
add: {
|
|
620
620
|
body: '<path fill="none" stroke="currentColor" stroke-linecap="round" stroke-width="2" d="M4 15.999h24m-12-12v24"/>'
|
|
@@ -1227,7 +1227,7 @@ const detailed = {
|
|
|
1227
1227
|
height
|
|
1228
1228
|
};
|
|
1229
1229
|
const prefix = "simple";
|
|
1230
|
-
const lastModified =
|
|
1230
|
+
const lastModified = 1697194530;
|
|
1231
1231
|
const icons$1 = {
|
|
1232
1232
|
add: {
|
|
1233
1233
|
body: '<path fill="none" stroke="currentColor" stroke-linecap="round" d="M.5 8h15M8 .5v15"/>'
|