next-blurhash-previews 0.0.3-beta5 → 0.0.3-beta52
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/.vscode/settings.json +10 -0
- package/bin/remark-plugin.js +6 -5
- package/components/ImageWithPreview.tsx +29 -5
- package/components/imagePreviewBootstrap.tsx +13 -6
- package/components/workerScript.ts +20 -0
- package/imagePreviewBootstrap.js +14 -0
- package/index.js +1 -3
- package/package.json +3 -4
- package/util/setBootstrap.js +19 -20
- package/{vite.config.ts → vite.wc.config.ts} +3 -6
- package/vite.worker.config.ts +18 -0
- package/.prettierrc +0 -3
- package/img1.png +0 -0
- package/img5.png +0 -0
- package/junk.js +0 -1
- package/next-runner/.eslintrc.json +0 -3
- package/next-runner/README.md +0 -34
- package/next-runner/blog-posts/post1.md +0 -303
- package/next-runner/blog-posts/post2.md +0 -10
- package/next-runner/blog-posts/post3.md +0 -10
- package/next-runner/blog-posts/post4.md +0 -10
- package/next-runner/next.config.js +0 -6
- package/next-runner/package-lock.json +0 -5080
- package/next-runner/package.json +0 -23
- package/next-runner/pages/_app.js +0 -11
- package/next-runner/pages/_document.js +0 -17
- package/next-runner/pages/index.js +0 -47
- package/next-runner/public/css-modules/loadingError.png +0 -0
- package/next-runner/public/css-modules/styledComponent.png +0 -0
- package/next-runner/public/css-modules/styledSass.png +0 -0
- package/next-runner/public/css-modules/unstyledComp.png +0 -0
- package/next-runner/public/dynamo-introduction/img1.png +0 -0
- package/next-runner/public/dynamo-introduction/img10.png +0 -0
- package/next-runner/public/dynamo-introduction/img11.png +0 -0
- package/next-runner/public/dynamo-introduction/img12.png +0 -0
- package/next-runner/public/dynamo-introduction/img13.png +0 -0
- package/next-runner/public/dynamo-introduction/img14.png +0 -0
- package/next-runner/public/dynamo-introduction/img15.png +0 -0
- package/next-runner/public/dynamo-introduction/img2.png +0 -0
- package/next-runner/public/dynamo-introduction/img3.png +0 -0
- package/next-runner/public/dynamo-introduction/img4.png +0 -0
- package/next-runner/public/dynamo-introduction/img5.png +0 -0
- package/next-runner/public/dynamo-introduction/img5a.png +0 -0
- package/next-runner/public/dynamo-introduction/img6.png +0 -0
- package/next-runner/public/dynamo-introduction/img7.png +0 -0
- package/next-runner/public/dynamo-introduction/img8.png +0 -0
- package/next-runner/public/dynamo-introduction/img9.png +0 -0
- package/next-runner/public/favicon.ico +0 -0
- package/next-runner/public/img1.png +0 -0
- package/next-runner/public/img5.png +0 -0
- package/next-runner/public/vercel.svg +0 -4
- package/next-runner/styles/Home.module.css +0 -3
- package/next-runner/styles/globals.css +0 -22
- package/next-runner/yalc.lock +0 -9
- package/next-runner/yarn.lock +0 -1650
- package/tsconfig.json +0 -21
- package/tsconfig.node.json +0 -8
- package/yalc.lock +0 -9
    
        package/bin/remark-plugin.js
    CHANGED
    
    | @@ -1,6 +1,5 @@ | |
| 1 1 | 
             
            import path from "path";
         | 
| 2 2 | 
             
            import { visitParents } from "unist-util-visit-parents";
         | 
| 3 | 
            -
            import prettier from "prettier";
         | 
| 4 3 |  | 
| 5 4 | 
             
            import colors from "colors";
         | 
| 6 5 |  | 
| @@ -11,7 +10,7 @@ export const blurhashPlugin = publicPath => () => { | |
| 11 10 | 
             
                let outstanding = 0;
         | 
| 12 11 |  | 
| 13 12 | 
             
                visitParents(tree, "image", async (node, ancestors) => {
         | 
| 14 | 
            -
                  let { url: imagePath, alt } = node;
         | 
| 13 | 
            +
                  let { url: imagePath, alt = "" } = node;
         | 
| 15 14 |  | 
| 16 15 | 
             
                  const originalImg = imagePath;
         | 
| 17 16 | 
             
                  if (!/http/.test(imagePath)) {
         | 
| @@ -29,6 +28,8 @@ export const blurhashPlugin = publicPath => () => { | |
| 29 28 |  | 
| 30 29 | 
             
                    const blurHash = await getBlurhash(imagePath);
         | 
| 31 30 |  | 
| 31 | 
            +
                    const { w, h } = blurHash;
         | 
| 32 | 
            +
             | 
| 32 33 | 
             
                    console.log(
         | 
| 33 34 | 
             
                      colors.green(`Finished processing ${imagePath}\n\t`, blurHash)
         | 
| 34 35 | 
             
                    );
         | 
| @@ -38,13 +39,13 @@ export const blurhashPlugin = publicPath => () => { | |
| 38 39 |  | 
| 39 40 | 
             
                    const newNode = `
         | 
| 40 41 | 
             
            <blurhash-image url="${originalImg}" preview='${JSON.stringify(blurHash)}'>
         | 
| 41 | 
            -
              <img alt="${alt  | 
| 42 | 
            -
              <canvas width="${ | 
| 42 | 
            +
              <img alt="${alt}" width="${w}" height="${h}" src="${originalImg}" slot="image" />
         | 
| 43 | 
            +
              <canvas width="${w}" height="${h}" slot="preview"></canvas>
         | 
| 43 44 | 
             
            </blurhash-image>`.trim();
         | 
| 44 45 |  | 
| 45 46 | 
             
                    parent.children[index] = {
         | 
| 46 47 | 
             
                      type: "html",
         | 
| 47 | 
            -
                      value:  | 
| 48 | 
            +
                      value: newNode,
         | 
| 48 49 | 
             
                    };
         | 
| 49 50 | 
             
                  } catch (er) {
         | 
| 50 51 | 
             
                    console.log(colors.red(`Error processing ${imagePath}\n\t`, er));
         | 
| @@ -1,13 +1,17 @@ | |
| 1 | 
            -
            import { decode } from " | 
| 1 | 
            +
            import { decode } from "blurhash/dist/esm";
         | 
| 2 2 |  | 
| 3 3 | 
             
            type blurhash = { w: number; h: number; blurhash: string };
         | 
| 4 4 |  | 
| 5 | 
            +
            declare function __blurhashDecode(blurhash: string, width: number, height: any);
         | 
| 6 | 
            +
            (window as any).__blurhashDecode = decode;
         | 
| 7 | 
            +
             | 
| 5 8 | 
             
            class ImageWithPreview extends HTMLElement {
         | 
| 6 9 | 
             
              sd: ShadowRoot;
         | 
| 7 10 | 
             
              mo?: MutationObserver;
         | 
| 8 11 |  | 
| 9 12 | 
             
              static observedAttributes = ["preview"];
         | 
| 10 13 |  | 
| 14 | 
            +
              #connected = false;
         | 
| 11 15 | 
             
              get #imgEl(): any {
         | 
| 12 16 | 
             
                return this.querySelector("img");
         | 
| 13 17 | 
             
              }
         | 
| @@ -38,6 +42,7 @@ class ImageWithPreview extends HTMLElement { | |
| 38 42 | 
             
              };
         | 
| 39 43 |  | 
| 40 44 | 
             
              connectedCallback() {
         | 
| 45 | 
            +
                this.#connected = true;
         | 
| 41 46 | 
             
                if (!this.#checkReady()) {
         | 
| 42 47 | 
             
                  this.mo = new MutationObserver(this.#checkReady);
         | 
| 43 48 | 
             
                  this.mo.observe(this, {
         | 
| @@ -49,7 +54,9 @@ class ImageWithPreview extends HTMLElement { | |
| 49 54 | 
             
              }
         | 
| 50 55 |  | 
| 51 56 | 
             
              #imgLoad = () => {
         | 
| 52 | 
            -
                 | 
| 57 | 
            +
                setTimeout(() => {
         | 
| 58 | 
            +
                  this.sd.innerHTML = `<slot name="image"></slot>`;
         | 
| 59 | 
            +
                }, 19000);
         | 
| 53 60 | 
             
              };
         | 
| 54 61 |  | 
| 55 62 | 
             
              attributeChangedCallback(name) {
         | 
| @@ -59,6 +66,10 @@ class ImageWithPreview extends HTMLElement { | |
| 59 66 | 
             
              }
         | 
| 60 67 |  | 
| 61 68 | 
             
              #updatePreview() {
         | 
| 69 | 
            +
                if (!this.#connected || !this.getAttribute("preview")) {
         | 
| 70 | 
            +
                  return;
         | 
| 71 | 
            +
                }
         | 
| 72 | 
            +
             | 
| 62 73 | 
             
                const previewObj = JSON.parse(this.getAttribute("preview")!);
         | 
| 63 74 | 
             
                updateBlurHashPreview(this.#canvasEl, previewObj);
         | 
| 64 75 | 
             
              }
         | 
| @@ -69,12 +80,25 @@ if (!customElements.get("blurhash-image")) { | |
| 69 80 | 
             
            }
         | 
| 70 81 |  | 
| 71 82 | 
             
            function updateBlurHashPreview(canvasEl: HTMLCanvasElement, preview: blurhash) {
         | 
| 72 | 
            -
              const { w: width, h: height } = preview;
         | 
| 73 | 
            -
             | 
| 83 | 
            +
              const { w: width, h: height, blurhash } = preview;
         | 
| 74 84 | 
             
              canvasEl.width = width;
         | 
| 75 85 | 
             
              canvasEl.height = height;
         | 
| 76 86 |  | 
| 77 | 
            -
               | 
| 87 | 
            +
              if (true) {
         | 
| 88 | 
            +
                const workerBlob = new Blob(
         | 
| 89 | 
            +
                  [document.querySelector("#next-blurhash-worker-script")!.textContent!],
         | 
| 90 | 
            +
                  { type: "text/javascript" }
         | 
| 91 | 
            +
                );
         | 
| 92 | 
            +
             | 
| 93 | 
            +
                const worker = new Worker(window.URL.createObjectURL(workerBlob));
         | 
| 94 | 
            +
                const offscreen = (canvasEl as any).transferControlToOffscreen();
         | 
| 95 | 
            +
                worker.postMessage({ canvas: offscreen, width, height, blurhash }, [
         | 
| 96 | 
            +
                  offscreen,
         | 
| 97 | 
            +
                ]);
         | 
| 98 | 
            +
              }
         | 
| 99 | 
            +
             | 
| 100 | 
            +
              return;
         | 
| 101 | 
            +
              const pixels = decode(blurhash, width, height);
         | 
| 78 102 | 
             
              const ctx = canvasEl.getContext("2d")!;
         | 
| 79 103 | 
             
              const imageData = ctx.createImageData(width, height);
         | 
| 80 104 | 
             
              imageData.data.set(pixels);
         | 
| @@ -1,7 +1,14 @@ | |
| 1 | 
            -
            import { createElement } from "react";
         | 
| 2 | 
            -
            import Script from "next/script";
         | 
| 1 | 
            +
            import { createElement, Fragment } from "react";
         | 
| 3 2 |  | 
| 4 | 
            -
            export const imagePreviewBootstrap = createElement( | 
| 5 | 
            -
               | 
| 6 | 
            -
               | 
| 7 | 
            -
             | 
| 3 | 
            +
            export const imagePreviewBootstrap = createElement(
         | 
| 4 | 
            +
              Fragment,
         | 
| 5 | 
            +
              {},
         | 
| 6 | 
            +
              createElement("script", {
         | 
| 7 | 
            +
                dangerouslySetInnerHTML: { __html: `(() => { /*WC*/ })();` },
         | 
| 8 | 
            +
              }),
         | 
| 9 | 
            +
              createElement("script", {
         | 
| 10 | 
            +
                id: "next-blurhash-worker-script",
         | 
| 11 | 
            +
                type: "javascript/worker",
         | 
| 12 | 
            +
                dangerouslySetInnerHTML: { __html: `(() => { /*WORKER*/ })();` },
         | 
| 13 | 
            +
              })
         | 
| 14 | 
            +
            );
         | 
| @@ -0,0 +1,20 @@ | |
| 1 | 
            +
            declare function __blurhashDecode(blurhash: string, width: number, height: any);
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            addEventListener("message", evt => {
         | 
| 4 | 
            +
              console.log(evt);
         | 
| 5 | 
            +
             | 
| 6 | 
            +
              const { canvas, width, height, blurhash } = evt.data;
         | 
| 7 | 
            +
             | 
| 8 | 
            +
              const p = new Promise(res => setTimeout(res, 5000));
         | 
| 9 | 
            +
              Promise.resolve(p).then(() => {
         | 
| 10 | 
            +
                console.log("Encoding", blurhash);
         | 
| 11 | 
            +
                const start = +new Date();
         | 
| 12 | 
            +
                const pixels = __blurhashDecode(blurhash, width, height);
         | 
| 13 | 
            +
                const ctx = canvas.getContext("2d");
         | 
| 14 | 
            +
                const imageData = ctx.createImageData(width, height);
         | 
| 15 | 
            +
                imageData.data.set(pixels);
         | 
| 16 | 
            +
                ctx.putImageData(imageData, 0, 0);
         | 
| 17 | 
            +
                const end = +new Date();
         | 
| 18 | 
            +
                console.log("Done Encoding", blurhash, end - start);
         | 
| 19 | 
            +
              });
         | 
| 20 | 
            +
            });
         | 
| @@ -0,0 +1,14 @@ | |
| 1 | 
            +
            import { createElement, Fragment } from "react";
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            export const imagePreviewBootstrap = createElement(
         | 
| 4 | 
            +
              Fragment,
         | 
| 5 | 
            +
              {},
         | 
| 6 | 
            +
              createElement("script", {
         | 
| 7 | 
            +
                dangerouslySetInnerHTML: { __html: `(() => { "use strict";const k=["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","#","$","%","*","+",",","-",".",":",";","=","?","@","[","]","^","_","{","|","}","~"],u=t=>{let e=0;for(let s=0;s<t.length;s++){const n=t[s],i=k.indexOf(n);e=e*83+i}return e},M=t=>{let e=t/255;return e<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)},p=t=>{let e=Math.max(0,Math.min(1,t));return e<=.0031308?Math.round(e*12.92*255+.5):Math.round((1.055*Math.pow(e,.4166666666666667)-.055)*255+.5)},E=t=>t<0?-1:1,v=(t,e)=>E(t)*Math.pow(Math.abs(t),e);class C extends Error{constructor(e){super(e),this.name="ValidationError",this.message=e}}const P=t=>{if(!t||t.length<6)throw new C("The blurhash string must be at least 6 characters");const e=u(t[0]),s=Math.floor(e/9)+1,n=e%9+1;if(t.length!==4+2*n*s)throw new C(\`blurhash length mismatch: length is \${t.length} but it should be \${4+2*n*s}\`)},A=t=>{const e=t>>16,s=t>>8&255,n=t&255;return[M(e),M(s),M(n)]},O=(t,e)=>{const s=Math.floor(t/361),n=Math.floor(t/19)%19,i=t%19;return[v((s-9)/9,2)*e,v((n-9)/9,2)*e,v((i-9)/9,2)*e]},G=(t,e,s,n)=>{P(t),n=n|1;const i=u(t[0]),c=Math.floor(i/9)+1,a=i%9+1,L=(u(t[1])+1)/166,d=new Array(a*c);for(let o=0;o<d.length;o++)if(o===0){const r=u(t.substring(2,6));d[o]=A(r)}else{const r=u(t.substring(4+o*2,6+o*2));d[o]=O(r,L*n)}const l=e*4,h=new Uint8ClampedArray(l*s);for(let o=0;o<s;o++)for(let r=0;r<e;r++){let x=0,y=0,B=0;for(let m=0;m<c;m++)for(let g=0;g<a;g++){const f=Math.cos(Math.PI*r*g/e)*Math.cos(Math.PI*o*m/s);let b=d[g+m*a];x+=b[0]*f,y+=b[1]*f,B+=b[2]*f}let R=p(x),q=p(y),T=p(B);h[4*r+0+o*l]=R,h[4*r+1+o*l]=q,h[4*r+2+o*l]=T,h[4*r+3+o*l]=255}return h};var S=G;window.__blurhashDecode=S;class j extends HTMLElement{sd;mo;static observedAttributes=["preview"];#s=!1;get#t(){return this.querySelector("img")}get#e(){return this.querySelector("canvas")}constructor(){super(),this.sd=this.attachShadow({mode:"open"}),this.sd.innerHTML='<slot name="preview"></slot>'}#n=()=>{if(this.#t&&this.#e)return this.mo?.disconnect(),this.#t.complete?this.#o():(this.#r(),this.#t.addEventListener("load",this.#o)),!0};connectedCallback(){this.#s=!0,this.#n()||(this.mo=new MutationObserver(this.#n),this.mo.observe(this,{subtree:!0,childList:!0,attributes:!1}))}#o=()=>{setTimeout(()=>{this.sd.innerHTML='<slot name="image"></slot>'},19e3)};attributeChangedCallback(e){this.#e&&e==="preview"&&this.#r()}#r(){if(!this.#s||!this.getAttribute("preview"))return;const e=JSON.parse(this.getAttribute("preview"));H(this.#e,e)}}customElements.get("blurhash-image")||customElements.define("blurhash-image",j);function H(t,e){const{w:s,h:n,blurhash:i}=e;t.width=s,t.height=n;{const c=new Blob([document.querySelector("#next-blurhash-worker-script").textContent],{type:"text/javascript"}),a=new Worker(window.URL.createObjectURL(c)),w=t.transferControlToOffscreen();a.postMessage({canvas:w,width:s,height:n,blurhash:i},[w])}} })();` },
         | 
| 8 | 
            +
              }),
         | 
| 9 | 
            +
              createElement("script", {
         | 
| 10 | 
            +
                id: "next-blurhash-worker-script",
         | 
| 11 | 
            +
                type: "javascript/worker",
         | 
| 12 | 
            +
                dangerouslySetInnerHTML: { __html: `(() => { "use strict";addEventListener("message",o=>{console.log(o);const{canvas:g,width:s,height:n,blurhash:e}=o.data,i=new Promise(t=>setTimeout(t,5e3));Promise.resolve(i).then(()=>{console.log("Encoding",e);const t=+new Date,d=__blurhashDecode(e,s,n),a=g.getContext("2d"),c=a.createImageData(s,n);c.data.set(d),a.putImageData(c,0,0);const l=+new Date;console.log("Done Encoding",e,l-t)})}); })();` },
         | 
| 13 | 
            +
              })
         | 
| 14 | 
            +
            );
         | 
    
        package/index.js
    CHANGED
    
    | @@ -1,5 +1,3 @@ | |
| 1 | 
            -
            import { imagePreviewBootstrap } from "./imagePreviewBootstrap";
         | 
| 1 | 
            +
            import { imagePreviewBootstrap } from "./imagePreviewBootstrap.js";
         | 
| 2 2 |  | 
| 3 3 | 
             
            export { imagePreviewBootstrap };
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            export const src = `(() => { "use strict";var A=Object.defineProperty;var R=(t,e,s)=>e in t?A(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s;var u=(t,e,s)=>(R(t,typeof e!="symbol"?e+"":e,s),s);const G=["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","#","$","%","*","+",",","-",".",":",";","=","?","@","[","]","^","_","{","|","}","~"],h=t=>{let e=0;for(let s=0;s<t.length;s++){const n=t[s],o=G.indexOf(n);e=e*83+o}return e},p=t=>{let e=t/255;return e<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)},b=t=>{let e=Math.max(0,Math.min(1,t));return e<=.0031308?Math.round(e*12.92*255+.5):Math.round((1.055*Math.pow(e,.4166666666666667)-.055)*255+.5)},P=t=>t<0?-1:1,E=(t,e)=>P(t)*Math.pow(Math.abs(t),e);class v extends Error{constructor(e){super(e),this.name="ValidationError",this.message=e}}const k=t=>{if(!t||t.length<6)throw new v("The blurhash string must be at least 6 characters");const e=h(t[0]),s=Math.floor(e/9)+1,n=e%9+1;if(t.length!==4+2*n*s)throw new v(\`blurhash length mismatch: length is \${t.length} but it should be \${4+2*n*s}\`)},D=t=>{const e=t>>16,s=t>>8&255,n=t&255;return[p(e),p(s),p(n)]},H=(t,e)=>{const s=Math.floor(t/361),n=Math.floor(t/19)%19,o=t%19;return[E((s-9)/9,2)*e,E((n-9)/9,2)*e,E((o-9)/9,2)*e]},S=(t,e,s,n)=>{k(t),n=n|1;const o=h(t[0]),a=Math.floor(o/9)+1,c=o%9+1,q=(h(t[1])+1)/166,g=new Array(c*a);for(let r=0;r<g.length;r++)if(r===0){const i=h(t.substring(2,6));g[r]=D(i)}else{const i=h(t.substring(4+r*2,6+r*2));g[r]=H(i,q*n)}const l=e*4,d=new Uint8ClampedArray(l*s);for(let r=0;r<s;r++)for(let i=0;i<e;i++){let I=0,x=0,C=0;for(let m=0;m<a;m++)for(let f=0;f<c;f++){const M=Math.cos(Math.PI*i*f/e)*Math.cos(Math.PI*r*m/s);let w=g[f+m*c];I+=w[0]*M,x+=w[1]*M,C+=w[2]*M}let B=b(I),T=b(x),y=b(C);d[4*i+0+r*l]=B,d[4*i+1+r*l]=T,d[4*i+2+r*l]=y,d[4*i+3+r*l]=255}return d};class L extends HTMLElement{constructor(){super();u(this,"loaded",!1);u(this,"sd");u(this,"onImageLoad",()=>{this.getAttribute("url")!==this.currentImageEl.src&&setTimeout(()=>{this.loaded=!0,this.render()},1500)});this.sd=this.attachShadow({mode:"open"}),this.sd.innerHTML='<slot name="preview"></slot>'}get currentImageEl(){return this.querySelector("img")}get currentCanvasEl(){return this.querySelector("canvas")}connectedCallback(){this.currentImageEl.complete&&this.onImageLoad(),this.currentImageEl.addEventListener("load",this.onImageLoad)}attributeChangedCallback(s,n,o){if(s==="preview"){const a=JSON.parse(o);O(this.currentCanvasEl,a)}else s==="url"&&o!==this.currentImageEl.getAttribute("src")&&(this.loaded=!1,this.currentImageEl.src=o||"");this.render()}render(){this.sd.innerHTML=\`<slot name="\${this.loaded?"image":"preview"}"></slot>\`}}u(L,"observedAttributes",["preview","url"]);customElements.get("uikit-image")||customElements.define("uikit-image",L);function O(t,e){const{w:s,h:n}=e;t.width=s,t.height=n;const o=S(e.blurhash,s,n),a=t.getContext("2d"),c=a.createImageData(s,n);c.data.set(o),a.putImageData(c,0,0)} })();`;
         | 
    
        package/package.json
    CHANGED
    
    | @@ -1,14 +1,15 @@ | |
| 1 1 | 
             
            {
         | 
| 2 2 | 
             
              "name": "next-blurhash-previews",
         | 
| 3 | 
            -
              "version": "0.0.3- | 
| 3 | 
            +
              "version": "0.0.3-beta52",
         | 
| 4 4 | 
             
              "description": "",
         | 
| 5 5 | 
             
              "main": "index.js",
         | 
| 6 | 
            +
              "module": "index.js",
         | 
| 6 7 | 
             
              "bin": {
         | 
| 7 8 | 
             
                "blurhash-markdown": "./bin/markdown-sync.js"
         | 
| 8 9 | 
             
              },
         | 
| 9 10 | 
             
              "scripts": {
         | 
| 10 11 | 
             
                "test": "echo \"Error: no test specified\" && exit 1",
         | 
| 11 | 
            -
                "build": "vite build",
         | 
| 12 | 
            +
                "build": "rm -rf build && vite build --config vite.wc.config.ts && vite build --config vite.worker.config.ts && node util/setBootstrap.js",
         | 
| 12 13 | 
             
                "build-watch": "vite build -w",
         | 
| 13 14 | 
             
                "prepare": "npm run build"
         | 
| 14 15 | 
             
              },
         | 
| @@ -31,10 +32,8 @@ | |
| 31 32 | 
             
                "colors": "^1.4.0",
         | 
| 32 33 | 
             
                "glob": "^8.0.3",
         | 
| 33 34 | 
             
                "install": "^0.13.0",
         | 
| 34 | 
            -
                "next": "^12.2.0",
         | 
| 35 35 | 
             
                "node-fetch": "^3.2.6",
         | 
| 36 36 | 
             
                "npm": "^8.15.1",
         | 
| 37 | 
            -
                "prettier": "^2.7.1",
         | 
| 38 37 | 
             
                "remark": "^14.0.2",
         | 
| 39 38 | 
             
                "remark-frontmatter": "^4.0.1",
         | 
| 40 39 | 
             
                "retext": "^8.1.0",
         | 
    
        package/util/setBootstrap.js
    CHANGED
    
    | @@ -1,22 +1,21 @@ | |
| 1 1 | 
             
            import fs from "fs";
         | 
| 2 2 |  | 
| 3 | 
            -
             | 
| 4 | 
            -
               | 
| 5 | 
            -
             | 
| 6 | 
            -
             | 
| 7 | 
            -
             | 
| 8 | 
            -
             | 
| 9 | 
            -
             | 
| 10 | 
            -
             | 
| 11 | 
            -
             | 
| 12 | 
            -
             | 
| 13 | 
            -
             | 
| 14 | 
            -
             | 
| 15 | 
            -
             | 
| 16 | 
            -
             | 
| 17 | 
            -
             | 
| 18 | 
            -
             | 
| 19 | 
            -
             | 
| 20 | 
            -
             | 
| 21 | 
            -
             | 
| 22 | 
            -
            }
         | 
| 3 | 
            +
            let BootstrapModule = fs.readFileSync(
         | 
| 4 | 
            +
              "./components/imagePreviewBootstrap.tsx",
         | 
| 5 | 
            +
              "utf8"
         | 
| 6 | 
            +
            );
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            const wcScript = fs.readFileSync("./build/imageWithPreview.js", "utf8");
         | 
| 9 | 
            +
            const workerScript = fs.readFileSync("./build/workerScript.js", "utf8");
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            BootstrapModule = BootstrapModule.replace(
         | 
| 12 | 
            +
              "/*WC*/",
         | 
| 13 | 
            +
              wcScript.replace(/[\r\n]\s*$/, "").replace(/`/g, "\\`")
         | 
| 14 | 
            +
            )
         | 
| 15 | 
            +
              .replace(
         | 
| 16 | 
            +
                "/*WORKER*/",
         | 
| 17 | 
            +
                workerScript.replace(/[\r\n]\s*$/, "").replace(/`/g, "\\`")
         | 
| 18 | 
            +
              )
         | 
| 19 | 
            +
              .replace(/\${/g, "\\${");
         | 
| 20 | 
            +
             | 
| 21 | 
            +
            fs.writeFileSync("./imagePreviewBootstrap.js", BootstrapModule);
         | 
| @@ -1,21 +1,18 @@ | |
| 1 1 | 
             
            import { defineConfig } from "vite";
         | 
| 2 2 | 
             
            import react from "@vitejs/plugin-react";
         | 
| 3 | 
            -
            import writeBootstrapPlugin from "./util/setBootstrap";
         | 
| 4 3 |  | 
| 5 4 | 
             
            export default defineConfig({
         | 
| 6 5 | 
             
              build: {
         | 
| 7 6 | 
             
                target: "es2022",
         | 
| 8 7 | 
             
                outDir: "./build",
         | 
| 8 | 
            +
                emptyOutDir: false,
         | 
| 9 9 | 
             
                lib: {
         | 
| 10 | 
            -
                  entry: "components/ | 
| 10 | 
            +
                  entry: "components/ImageWithPreview.tsx",
         | 
| 11 11 | 
             
                  formats: ["cjs"],
         | 
| 12 12 | 
             
                  fileName: () => "imageWithPreview.js",
         | 
| 13 13 | 
             
                  name: "imageWithPreview",
         | 
| 14 14 | 
             
                },
         | 
| 15 15 | 
             
                //minify: false,
         | 
| 16 | 
            -
                rollupOptions: {
         | 
| 17 | 
            -
                  external: ["react", "react-dom", "next", "next/script"],
         | 
| 18 | 
            -
                },
         | 
| 19 16 | 
             
              },
         | 
| 20 | 
            -
              plugins: [react() | 
| 17 | 
            +
              plugins: [react()],
         | 
| 21 18 | 
             
            });
         | 
| @@ -0,0 +1,18 @@ | |
| 1 | 
            +
            import { defineConfig } from "vite";
         | 
| 2 | 
            +
            import react from "@vitejs/plugin-react";
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            export default defineConfig({
         | 
| 5 | 
            +
              build: {
         | 
| 6 | 
            +
                target: "es2022",
         | 
| 7 | 
            +
                outDir: "./build",
         | 
| 8 | 
            +
                emptyOutDir: false,
         | 
| 9 | 
            +
                lib: {
         | 
| 10 | 
            +
                  entry: "components/workerScript.ts",
         | 
| 11 | 
            +
                  formats: ["cjs"],
         | 
| 12 | 
            +
                  fileName: () => "workerScript.js",
         | 
| 13 | 
            +
                  name: "workerScript",
         | 
| 14 | 
            +
                },
         | 
| 15 | 
            +
                //minify: false,
         | 
| 16 | 
            +
              },
         | 
| 17 | 
            +
              plugins: [react()],
         | 
| 18 | 
            +
            });
         | 
    
        package/.prettierrc
    DELETED
    
    
    
        package/img1.png
    DELETED
    
    | Binary file | 
    
        package/img5.png
    DELETED
    
    | Binary file | 
    
        package/junk.js
    DELETED
    
    | @@ -1 +0,0 @@ | |
| 1 | 
            -
            "use strict";var B=Object.defineProperty;var T=(t,e,s)=>e in t?B(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s;var a=(t,e,s)=>(T(t,typeof e!="symbol"?e+"":e,s),s);const k=["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","#","$","%","*","+",",","-",".",":",";","=","?","@","[","]","^","_","{","|","}","~"],h=t=>{let e=0;for(let s=0;s<t.length;s++){const n=t[s],o=k.indexOf(n);e=e*83+o}return e},p=t=>{let e=t/255;return e<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)},b=t=>{let e=Math.max(0,Math.min(1,t));return e<=.0031308?Math.round(e*12.92*255+.5):Math.round((1.055*Math.pow(e,.4166666666666667)-.055)*255+.5)},A=t=>t<0?-1:1,v=(t,e)=>A(t)*Math.pow(Math.abs(t),e);class C extends Error{constructor(e){super(e),this.name="ValidationError",this.message=e}}const G=t=>{if(!t||t.length<6)throw new C("The blurhash string must be at least 6 characters");const e=h(t[0]),s=Math.floor(e/9)+1,n=e%9+1;if(t.length!==4+2*n*s)throw new C(\`blurhash length mismatch: length is \${t.length} but it should be \${4+2*n*s}\`)},V=t=>{const e=t>>16,s=t>>8&255,n=t&255;return[p(e),p(s),p(n)]},D=(t,e)=>{const s=Math.floor(t/361),n=Math.floor(t/19)%19,o=t%19;return[v((s-9)/9,2)*e,v((n-9)/9,2)*e,v((o-9)/9,2)*e]},H=(t,e,s,n)=>{G(t),n=n|1;const o=h(t[0]),c=Math.floor(o/9)+1,l=o%9+1,x=(h(t[1])+1)/166,g=new Array(l*c);for(let r=0;r<g.length;r++)if(r===0){const i=h(t.substring(2,6));g[r]=V(i)}else{const i=h(t.substring(4+r*2,6+r*2));g[r]=D(i,x*n)}const d=e*4,u=new Uint8ClampedArray(d*s);for(let r=0;r<s;r++)for(let i=0;i<e;i++){let y=0,E=0,I=0;for(let m=0;m<c;m++)for(let f=0;f<l;f++){const w=Math.cos(Math.PI*i*f/e)*Math.cos(Math.PI*r*m/s);let M=g[f+m*l];y+=M[0]*w,E+=M[1]*w,I+=M[2]*w}let L=b(y),P=b(E),q=b(I);u[4*i+0+r*d]=L,u[4*i+1+r*d]=P,u[4*i+2+r*d]=q,u[4*i+3+r*d]=255}return u};class R extends HTMLElement{constructor(){super();a(this,"isReady",!1);a(this,"loaded",!1);a(this,"sd");a(this,"mo");a(this,"checkReady",()=>{this.currentImageEl&&this.currentCanvasEl&&(this.ready(),this.mo.disconnect())});a(this,"onImageLoad",()=>{this.getAttribute("url")!==this.currentImageEl.src&&setTimeout(()=>{this.loaded=!0,this.render()},1500)});this.sd=this.attachShadow({mode:"open"}),this.sd.innerHTML='<slot name="preview"></slot>'}get currentImageEl(){return this.querySelector("img")}get currentCanvasEl(){return this.querySelector("canvas")}connectedCallback(){this.mo=new MutationObserver(this.checkReady),this.mo.observe(this,{subtree:!0,childList:!0,attributes:!1})}ready(){this.isReady=!0,this.currentImageEl.complete&&this.onImageLoad(),this.currentImageEl.addEventListener("load",this.onImageLoad),this.loaded||this.updatePreview()}attributeChangedCallback(s,n,o){!this.isReady||(s==="preview"?this.updatePreview():s==="url"&&(this.loaded=!1),this.render())}updatePreview(){const s=JSON.parse(this.getAttribute("preview"));O(this.currentCanvasEl,s)}render(){this.sd.innerHTML=\`<slot name="\${this.loaded?"image":"preview"}"></slot>\`}}a(R,"observedAttributes",["preview","url"]);customElements.get("uikit-image")||customElements.define("uikit-image",R);function O(t,e){const{w:s,h:n}=e;t.width=s,t.height=n;const o=H(e.blurhash,s,n),c=t.getContext("2d"),l=c.createImageData(s,n);l.data.set(o),c.putImageData(l,0,0)}
         | 
    
        package/next-runner/README.md
    DELETED
    
    | @@ -1,34 +0,0 @@ | |
| 1 | 
            -
            This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app).
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            ## Getting Started
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            First, run the development server:
         | 
| 6 | 
            -
             | 
| 7 | 
            -
            ```bash
         | 
| 8 | 
            -
            npm run dev
         | 
| 9 | 
            -
            # or
         | 
| 10 | 
            -
            yarn dev
         | 
| 11 | 
            -
            ```
         | 
| 12 | 
            -
             | 
| 13 | 
            -
            Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
         | 
| 14 | 
            -
             | 
| 15 | 
            -
            You can start editing the page by modifying `pages/index.js`. The page auto-updates as you edit the file.
         | 
| 16 | 
            -
             | 
| 17 | 
            -
            [API routes](https://nextjs.org/docs/api-routes/introduction) can be accessed on [http://localhost:3000/api/hello](http://localhost:3000/api/hello). This endpoint can be edited in `pages/api/hello.js`.
         | 
| 18 | 
            -
             | 
| 19 | 
            -
            The `pages/api` directory is mapped to `/api/*`. Files in this directory are treated as [API routes](https://nextjs.org/docs/api-routes/introduction) instead of React pages.
         | 
| 20 | 
            -
             | 
| 21 | 
            -
            ## Learn More
         | 
| 22 | 
            -
             | 
| 23 | 
            -
            To learn more about Next.js, take a look at the following resources:
         | 
| 24 | 
            -
             | 
| 25 | 
            -
            - [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.
         | 
| 26 | 
            -
            - [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.
         | 
| 27 | 
            -
             | 
| 28 | 
            -
            You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome!
         | 
| 29 | 
            -
             | 
| 30 | 
            -
            ## Deploy on Vercel
         | 
| 31 | 
            -
             | 
| 32 | 
            -
            The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js.
         | 
| 33 | 
            -
             | 
| 34 | 
            -
            Check out our [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details.
         |