@opensea/seadn 2.3.8 → 2.3.9

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/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var c=Object.defineProperty;var R=Object.getOwnPropertyDescriptor;var U=Object.getOwnPropertyNames;var L=Object.prototype.hasOwnProperty;var w=(n,e)=>{for(var r in e)c(n,r,{get:e[r],enumerable:!0})},g=(n,e,r,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of U(e))!L.call(n,t)&&t!==r&&c(n,t,{get:()=>e[t],enumerable:!(i=R(e,t))||i.enumerable});return n};var M=n=>g(c({},"__esModule",{value:!0}),n);var E={};w(E,{optimize:()=>h,originalURL:()=>u});module.exports=M(E);var s=[80,250,500,750,1e3,2e3,4e3];function v(n,e){let r=s.find(t=>t>=n),i=s.find(t=>t>=e);if(i===r){let t=s.indexOf(i);i=s[t+1]}return i||s[s.length-1]}function d(n,e){if(e===void 0||e<=1)return n;let r=Number(n)*e;return v(Number(n),r)}function h(n,{width:e,height:r,format:i,quality:t,fit:b,frameTime:a,boost:l}){try{typeof n=="string"&&(n=new URL(n))}catch($){return n.toString()}if(!(n instanceof URL))return n;let m=F(n);if(!N(n)&&!m||p(n)&&a===void 0)return u(n);let o=new URLSearchParams;if(a!==void 0)m&&o.set("frame-time",String(a));else if(p(n)||S(n))return n.toString();if(r!==void 0&&o.set("h",String(d(r,l))),e!==void 0&&o.set("w",String(d(e,l))),i!==void 0&&o.set("format",i),t){if(Number(t)<=0||Number(t)>100)throw new Error("Quality has to be a positive number between 1 and 100");o.set("q",String(t))}return b!==void 0&&o.set("fit",b),n.search=o.toString(),n.toString()}function p(n){let e=f(n);return e==="mp4"||e==="mov"||e==="webm"||e==="m4v"||e==="ogg"||e==="ogv"}function S(n){return f(n)==="svg"}function F(n){return p(n)||S(n)||f(n)==="gif"}function N(n){if(!x(n))return!1;switch(f(n)){case"jpg":case"png":case"jpeg":case"webp":case"avif":case"ico":case"bmp":case"gif":case void 0:return!0;default:return!1}}function f(n){let e=n.pathname.split(".");if(!(e.length<=1))return e[e.length-1]}function x(n){return n.hostname.endsWith("seadn.io")}function u(n){try{typeof n=="string"&&(n=new URL(n))}catch(e){return n.toString()}return B(n)?(n.hostname=n.hostname.replace("i.seadn.io","raw.seadn.io"),n.pathname=n.pathname.replace("/s/raw/files/","/files/"),n.toString()):(x(n)&&(n.hostname=y(n)),n.toString())}function y(n){return n.hostname.replace("i2c","raw2").replace("i2","raw2")}function B(n){return n.hostname==="i.seadn.io"||n.hostname==="raw.seadn.io"}0&&(module.exports={optimize,originalURL});
1
+ "use strict";var a=Object.defineProperty;var x=Object.getOwnPropertyDescriptor;var R=Object.getOwnPropertyNames;var U=Object.prototype.hasOwnProperty;var L=(n,e)=>{for(var r in e)a(n,r,{get:e[r],enumerable:!0})},w=(n,e,r,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of R(e))!U.call(n,t)&&t!==r&&a(n,t,{get:()=>e[t],enumerable:!(i=x(e,t))||i.enumerable});return n};var g=n=>w(a({},"__esModule",{value:!0}),n);var B={};L(B,{optimize:()=>h,originalURL:()=>u});module.exports=g(B);var s=[80,250,500,750,1e3,2e3,4e3];function M(n,e){let r=s.find(t=>t>=n),i=s.find(t=>t>=e);if(i===r){let t=s.indexOf(i);i=s[t+1]}return i||s[s.length-1]}function c(n,e){if(e===void 0||e<=1)return n;let r=Number(n)*e;return M(Number(n),r)}function h(n,{width:e,height:r,format:i,quality:t,fit:b,frameTime:f,boost:l}){try{typeof n=="string"&&(n=new URL(n))}catch(E){return n.toString()}if(!(n instanceof URL))return n;let m=F(n);if(!v(n)&&!m||d(n)&&f===void 0)return u(n);let o=new URLSearchParams;if(f!==void 0)m&&o.set("frame-time",String(f));else if(d(n))return n.toString();if(r!==void 0&&o.set("h",String(c(r,l))),e!==void 0&&o.set("w",String(c(e,l))),i!==void 0&&o.set("format",i),t){if(Number(t)<=0||Number(t)>100)throw new Error("Quality has to be a positive number between 1 and 100");o.set("q",String(t))}return b!==void 0&&o.set("fit",b),n.search=o.toString(),n.toString()}function d(n){let e=p(n);return e==="mp4"||e==="mov"||e==="webm"||e==="m4v"||e==="ogg"||e==="ogv"}function F(n){return d(n)||p(n)==="gif"}function v(n){if(!S(n))return!1;switch(p(n)){case"jpg":case"png":case"jpeg":case"webp":case"avif":case"ico":case"bmp":case"gif":case void 0:return!0;default:return!1}}function p(n){let e=n.pathname.split(".");if(!(e.length<=1))return e[e.length-1]}function S(n){return n.hostname.endsWith("seadn.io")}function u(n){try{typeof n=="string"&&(n=new URL(n))}catch(e){return n.toString()}return y(n)?(n.hostname=n.hostname.replace("i.seadn.io","raw.seadn.io"),n.pathname=n.pathname.replace("/s/raw/files/","/files/"),n.toString()):(S(n)&&(n.hostname=N(n)),n.toString())}function N(n){return n.hostname.replace("i2c","raw2").replace("i2","raw2")}function y(n){return n.hostname==="i.seadn.io"||n.hostname==="raw.seadn.io"}0&&(module.exports={optimize,originalURL});
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/boost.ts","../src/sdk.ts"],"sourcesContent":["export {\n optimize,\n originalURL,\n MediaParams,\n MediaFormat,\n MediaFit,\n} from \"./sdk\";\n","const DIMENSIONS_BUCKETS = [80, 250, 500, 750, 1000, 2000, 4000];\n\nfunction findNextBucket(originalSize: number, boosted: number): number {\n let originalBucket = DIMENSIONS_BUCKETS.find(\n bucket => bucket >= originalSize,\n );\n let nextBucket = DIMENSIONS_BUCKETS.find(bucket => bucket >= boosted);\n\n if (nextBucket === originalBucket) {\n const currentIndex = DIMENSIONS_BUCKETS.indexOf(nextBucket!);\n nextBucket = DIMENSIONS_BUCKETS[currentIndex + 1];\n }\n\n return nextBucket || DIMENSIONS_BUCKETS[DIMENSIONS_BUCKETS.length - 1];\n}\n\nexport function boostSize(\n size: number | `${number}`,\n boost: number | undefined,\n): number | `${number}` {\n if (boost === undefined || boost <= 1) {\n return size;\n }\n const boosted = Number(size) * boost;\n return findNextBucket(Number(size), boosted);\n}\n","import { boostSize } from \"./boost\";\n\nexport type MediaFormat = \"webp\" | \"avif\" | \"jpeg\" | \"png\";\nexport type MediaFit = \"cover\" | \"contain\" | \"fill\" | \"inside\" | \"outside\";\n\nexport type MediaParams = {\n width?: number | `${number}`;\n height?: number | `${number}`;\n format?: MediaFormat;\n quality?: number | `${number}`;\n fit?: MediaFit;\n frameTime?: number;\n boost?: number;\n};\n\nexport function optimize(\n image: string | URL,\n { width, height, format, quality, fit, frameTime, boost }: MediaParams,\n): string {\n try {\n if (typeof image === \"string\") {\n image = new URL(image);\n }\n } catch {\n return image.toString();\n }\n\n if (!(image instanceof URL)) {\n return image;\n }\n\n const isFrameable = canExtractFrame(image);\n if (!canBeResized(image) && !isFrameable) {\n return originalURL(image);\n }\n\n // for partial content stremaing\n if (isVideo(image) && frameTime === undefined) {\n return originalURL(image);\n }\n\n const params = new URLSearchParams();\n\n if (frameTime !== undefined) {\n if (isFrameable) {\n params.set(\"frame-time\", String(frameTime));\n }\n } else if (isVideo(image) || isSvg(image)) {\n return image.toString();\n }\n\n if (height !== undefined) {\n params.set(\"h\", String(boostSize(height, boost)));\n }\n if (width !== undefined) {\n params.set(\"w\", String(boostSize(width, boost)));\n }\n if (format !== undefined) {\n params.set(\"format\", format);\n }\n if (quality) {\n if (Number(quality) <= 0 || Number(quality) > 100) {\n throw new Error(\"Quality has to be a positive number between 1 and 100\");\n }\n params.set(\"q\", String(quality));\n }\n if (fit !== undefined) {\n params.set(\"fit\", fit);\n }\n\n image.search = params.toString();\n return image.toString();\n}\n\nfunction isVideo(url: URL): boolean {\n const extension = getExtension(url);\n return (\n extension === \"mp4\" ||\n extension === \"mov\" ||\n extension === \"webm\" ||\n extension === \"m4v\" ||\n extension === \"ogg\" ||\n extension === \"ogv\"\n );\n}\n\nfunction isSvg(url: URL): boolean {\n return getExtension(url) === \"svg\";\n}\n\nfunction canExtractFrame(url: URL): boolean {\n return isVideo(url) || isSvg(url) || getExtension(url) === \"gif\";\n}\n\nfunction canBeResized(url: URL): boolean {\n if (!isSeadnURL(url)) {\n return false;\n }\n const extension = getExtension(url);\n switch (extension) {\n case \"jpg\":\n case \"png\":\n case \"jpeg\":\n case \"webp\":\n case \"avif\":\n case \"ico\":\n case \"bmp\":\n case \"gif\":\n case undefined:\n return true;\n default:\n return false;\n }\n}\n\nfunction getExtension(url: URL): string | undefined {\n const split = url.pathname.split(\".\");\n if (split.length <= 1) {\n return undefined;\n }\n return split[split.length - 1];\n}\n\nexport function isSeadnURL(url: URL): boolean {\n return url.hostname.endsWith(\"seadn.io\");\n}\n\nexport function originalURL(image: URL | string): string {\n try {\n if (typeof image === \"string\") {\n image = new URL(image);\n }\n } catch {\n return image.toString();\n }\n\n if (isSeadnV1URL(image)) {\n image.hostname = image.hostname.replace(\"i.seadn.io\", \"raw.seadn.io\");\n image.pathname = image.pathname.replace(\"/s/raw/files/\", \"/files/\");\n return image.toString();\n }\n\n if (!isSeadnURL(image)) {\n return image.toString();\n }\n\n image.hostname = getOriginalHostname(image);\n return image.toString();\n}\n\nexport function getOriginalHostname(url: URL): string {\n return url.hostname.replace(\"i2c\", \"raw2\").replace(\"i2\", \"raw2\");\n}\n\nexport function isSeadnV1URL(url: URL): boolean {\n return url.hostname === \"i.seadn.io\" || url.hostname === \"raw.seadn.io\";\n}\n"],"mappings":"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","names":["src_exports","__export","optimize","originalURL","__toCommonJS","DIMENSIONS_BUCKETS","findNextBucket","originalSize","boosted","originalBucket","bucket","nextBucket","currentIndex","boostSize","size","boost","optimize","image","width","height","format","quality","fit","frameTime","boost","e","isFrameable","canExtractFrame","canBeResized","isVideo","originalURL","params","isSvg","boostSize","url","extension","getExtension","isSeadnURL","split","isSeadnV1URL","getOriginalHostname"]}
1
+ {"version":3,"sources":["../src/index.ts","../src/boost.ts","../src/sdk.ts"],"sourcesContent":["export {\n optimize,\n originalURL,\n MediaParams,\n MediaFormat,\n MediaFit,\n} from \"./sdk\";\n","const DIMENSIONS_BUCKETS = [80, 250, 500, 750, 1000, 2000, 4000];\n\nfunction findNextBucket(originalSize: number, boosted: number): number {\n let originalBucket = DIMENSIONS_BUCKETS.find(\n bucket => bucket >= originalSize,\n );\n let nextBucket = DIMENSIONS_BUCKETS.find(bucket => bucket >= boosted);\n\n if (nextBucket === originalBucket) {\n const currentIndex = DIMENSIONS_BUCKETS.indexOf(nextBucket!);\n nextBucket = DIMENSIONS_BUCKETS[currentIndex + 1];\n }\n\n return nextBucket || DIMENSIONS_BUCKETS[DIMENSIONS_BUCKETS.length - 1];\n}\n\nexport function boostSize(\n size: number | `${number}`,\n boost: number | undefined,\n): number | `${number}` {\n if (boost === undefined || boost <= 1) {\n return size;\n }\n const boosted = Number(size) * boost;\n return findNextBucket(Number(size), boosted);\n}\n","import { boostSize } from \"./boost\";\n\nexport type MediaFormat = \"webp\" | \"avif\" | \"jpeg\" | \"png\";\nexport type MediaFit = \"cover\" | \"contain\" | \"fill\" | \"inside\" | \"outside\";\n\nexport type MediaParams = {\n width?: number | `${number}`;\n height?: number | `${number}`;\n format?: MediaFormat;\n quality?: number | `${number}`;\n fit?: MediaFit;\n frameTime?: number;\n boost?: number;\n};\n\nexport function optimize(\n image: string | URL,\n { width, height, format, quality, fit, frameTime, boost }: MediaParams,\n): string {\n try {\n if (typeof image === \"string\") {\n image = new URL(image);\n }\n } catch {\n return image.toString();\n }\n\n if (!(image instanceof URL)) {\n return image;\n }\n\n const isFrameable = canExtractFrame(image);\n if (!canBeResized(image) && !isFrameable) {\n return originalURL(image);\n }\n\n // for partial content stremaing\n if (isVideo(image) && frameTime === undefined) {\n return originalURL(image);\n }\n\n const params = new URLSearchParams();\n\n if (frameTime !== undefined) {\n if (isFrameable) {\n params.set(\"frame-time\", String(frameTime));\n }\n } else if (isVideo(image)) {\n return image.toString();\n }\n\n if (height !== undefined) {\n params.set(\"h\", String(boostSize(height, boost)));\n }\n if (width !== undefined) {\n params.set(\"w\", String(boostSize(width, boost)));\n }\n if (format !== undefined) {\n params.set(\"format\", format);\n }\n if (quality) {\n if (Number(quality) <= 0 || Number(quality) > 100) {\n throw new Error(\"Quality has to be a positive number between 1 and 100\");\n }\n params.set(\"q\", String(quality));\n }\n if (fit !== undefined) {\n params.set(\"fit\", fit);\n }\n\n image.search = params.toString();\n return image.toString();\n}\n\nfunction isVideo(url: URL): boolean {\n const extension = getExtension(url);\n return (\n extension === \"mp4\" ||\n extension === \"mov\" ||\n extension === \"webm\" ||\n extension === \"m4v\" ||\n extension === \"ogg\" ||\n extension === \"ogv\"\n );\n}\n\nfunction canExtractFrame(url: URL): boolean {\n return isVideo(url) || getExtension(url) === \"gif\";\n}\n\nfunction canBeResized(url: URL): boolean {\n if (!isSeadnURL(url)) {\n return false;\n }\n const extension = getExtension(url);\n switch (extension) {\n case \"jpg\":\n case \"png\":\n case \"jpeg\":\n case \"webp\":\n case \"avif\":\n case \"ico\":\n case \"bmp\":\n case \"gif\":\n case undefined:\n return true;\n default:\n return false;\n }\n}\n\nfunction getExtension(url: URL): string | undefined {\n const split = url.pathname.split(\".\");\n if (split.length <= 1) {\n return undefined;\n }\n return split[split.length - 1];\n}\n\nexport function isSeadnURL(url: URL): boolean {\n return url.hostname.endsWith(\"seadn.io\");\n}\n\nexport function originalURL(image: URL | string): string {\n try {\n if (typeof image === \"string\") {\n image = new URL(image);\n }\n } catch {\n return image.toString();\n }\n\n if (isSeadnV1URL(image)) {\n image.hostname = image.hostname.replace(\"i.seadn.io\", \"raw.seadn.io\");\n image.pathname = image.pathname.replace(\"/s/raw/files/\", \"/files/\");\n return image.toString();\n }\n\n if (!isSeadnURL(image)) {\n return image.toString();\n }\n\n image.hostname = getOriginalHostname(image);\n return image.toString();\n}\n\nexport function getOriginalHostname(url: URL): string {\n return url.hostname.replace(\"i2c\", \"raw2\").replace(\"i2\", \"raw2\");\n}\n\nexport function isSeadnV1URL(url: URL): boolean {\n return url.hostname === \"i.seadn.io\" || url.hostname === \"raw.seadn.io\";\n}\n"],"mappings":"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","names":["index_exports","__export","optimize","originalURL","__toCommonJS","DIMENSIONS_BUCKETS","findNextBucket","originalSize","boosted","originalBucket","bucket","nextBucket","currentIndex","boostSize","size","boost","optimize","image","width","height","format","quality","fit","frameTime","boost","e","isFrameable","canExtractFrame","canBeResized","isVideo","originalURL","params","boostSize","url","extension","getExtension","isSeadnURL","split","isSeadnV1URL","getOriginalHostname"]}
package/dist/index.mjs CHANGED
@@ -1,2 +1,2 @@
1
- var s=[80,250,500,750,1e3,2e3,4e3];function S(n,e){let o=s.find(t=>t>=n),r=s.find(t=>t>=e);if(r===o){let t=s.indexOf(r);r=s[t+1]}return r||s[s.length-1]}function a(n,e){if(e===void 0||e<=1)return n;let o=Number(n)*e;return S(Number(n),o)}function x(n,{width:e,height:o,format:r,quality:t,fit:p,frameTime:f,boost:b}){try{typeof n=="string"&&(n=new URL(n))}catch(g){return n.toString()}if(!(n instanceof URL))return n;let l=R(n);if(!U(n)&&!l||c(n)&&f===void 0)return d(n);let i=new URLSearchParams;if(f!==void 0)l&&i.set("frame-time",String(f));else if(c(n)||m(n))return n.toString();if(o!==void 0&&i.set("h",String(a(o,b))),e!==void 0&&i.set("w",String(a(e,b))),r!==void 0&&i.set("format",r),t){if(Number(t)<=0||Number(t)>100)throw new Error("Quality has to be a positive number between 1 and 100");i.set("q",String(t))}return p!==void 0&&i.set("fit",p),n.search=i.toString(),n.toString()}function c(n){let e=u(n);return e==="mp4"||e==="mov"||e==="webm"||e==="m4v"||e==="ogg"||e==="ogv"}function m(n){return u(n)==="svg"}function R(n){return c(n)||m(n)||u(n)==="gif"}function U(n){if(!h(n))return!1;switch(u(n)){case"jpg":case"png":case"jpeg":case"webp":case"avif":case"ico":case"bmp":case"gif":case void 0:return!0;default:return!1}}function u(n){let e=n.pathname.split(".");if(!(e.length<=1))return e[e.length-1]}function h(n){return n.hostname.endsWith("seadn.io")}function d(n){try{typeof n=="string"&&(n=new URL(n))}catch(e){return n.toString()}return w(n)?(n.hostname=n.hostname.replace("i.seadn.io","raw.seadn.io"),n.pathname=n.pathname.replace("/s/raw/files/","/files/"),n.toString()):(h(n)&&(n.hostname=L(n)),n.toString())}function L(n){return n.hostname.replace("i2c","raw2").replace("i2","raw2")}function w(n){return n.hostname==="i.seadn.io"||n.hostname==="raw.seadn.io"}export{x as optimize,d as originalURL};
1
+ var s=[80,250,500,750,1e3,2e3,4e3];function h(n,e){let o=s.find(t=>t>=n),r=s.find(t=>t>=e);if(r===o){let t=s.indexOf(r);r=s[t+1]}return r||s[s.length-1]}function f(n,e){if(e===void 0||e<=1)return n;let o=Number(n)*e;return h(Number(n),o)}function S(n,{width:e,height:o,format:r,quality:t,fit:p,frameTime:u,boost:b}){try{typeof n=="string"&&(n=new URL(n))}catch(w){return n.toString()}if(!(n instanceof URL))return n;let l=x(n);if(!R(n)&&!l||a(n)&&u===void 0)return c(n);let i=new URLSearchParams;if(u!==void 0)l&&i.set("frame-time",String(u));else if(a(n))return n.toString();if(o!==void 0&&i.set("h",String(f(o,b))),e!==void 0&&i.set("w",String(f(e,b))),r!==void 0&&i.set("format",r),t){if(Number(t)<=0||Number(t)>100)throw new Error("Quality has to be a positive number between 1 and 100");i.set("q",String(t))}return p!==void 0&&i.set("fit",p),n.search=i.toString(),n.toString()}function a(n){let e=d(n);return e==="mp4"||e==="mov"||e==="webm"||e==="m4v"||e==="ogg"||e==="ogv"}function x(n){return a(n)||d(n)==="gif"}function R(n){if(!m(n))return!1;switch(d(n)){case"jpg":case"png":case"jpeg":case"webp":case"avif":case"ico":case"bmp":case"gif":case void 0:return!0;default:return!1}}function d(n){let e=n.pathname.split(".");if(!(e.length<=1))return e[e.length-1]}function m(n){return n.hostname.endsWith("seadn.io")}function c(n){try{typeof n=="string"&&(n=new URL(n))}catch(e){return n.toString()}return L(n)?(n.hostname=n.hostname.replace("i.seadn.io","raw.seadn.io"),n.pathname=n.pathname.replace("/s/raw/files/","/files/"),n.toString()):(m(n)&&(n.hostname=U(n)),n.toString())}function U(n){return n.hostname.replace("i2c","raw2").replace("i2","raw2")}function L(n){return n.hostname==="i.seadn.io"||n.hostname==="raw.seadn.io"}export{S as optimize,c as originalURL};
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/boost.ts","../src/sdk.ts"],"sourcesContent":["const DIMENSIONS_BUCKETS = [80, 250, 500, 750, 1000, 2000, 4000];\n\nfunction findNextBucket(originalSize: number, boosted: number): number {\n let originalBucket = DIMENSIONS_BUCKETS.find(\n bucket => bucket >= originalSize,\n );\n let nextBucket = DIMENSIONS_BUCKETS.find(bucket => bucket >= boosted);\n\n if (nextBucket === originalBucket) {\n const currentIndex = DIMENSIONS_BUCKETS.indexOf(nextBucket!);\n nextBucket = DIMENSIONS_BUCKETS[currentIndex + 1];\n }\n\n return nextBucket || DIMENSIONS_BUCKETS[DIMENSIONS_BUCKETS.length - 1];\n}\n\nexport function boostSize(\n size: number | `${number}`,\n boost: number | undefined,\n): number | `${number}` {\n if (boost === undefined || boost <= 1) {\n return size;\n }\n const boosted = Number(size) * boost;\n return findNextBucket(Number(size), boosted);\n}\n","import { boostSize } from \"./boost\";\n\nexport type MediaFormat = \"webp\" | \"avif\" | \"jpeg\" | \"png\";\nexport type MediaFit = \"cover\" | \"contain\" | \"fill\" | \"inside\" | \"outside\";\n\nexport type MediaParams = {\n width?: number | `${number}`;\n height?: number | `${number}`;\n format?: MediaFormat;\n quality?: number | `${number}`;\n fit?: MediaFit;\n frameTime?: number;\n boost?: number;\n};\n\nexport function optimize(\n image: string | URL,\n { width, height, format, quality, fit, frameTime, boost }: MediaParams,\n): string {\n try {\n if (typeof image === \"string\") {\n image = new URL(image);\n }\n } catch {\n return image.toString();\n }\n\n if (!(image instanceof URL)) {\n return image;\n }\n\n const isFrameable = canExtractFrame(image);\n if (!canBeResized(image) && !isFrameable) {\n return originalURL(image);\n }\n\n // for partial content stremaing\n if (isVideo(image) && frameTime === undefined) {\n return originalURL(image);\n }\n\n const params = new URLSearchParams();\n\n if (frameTime !== undefined) {\n if (isFrameable) {\n params.set(\"frame-time\", String(frameTime));\n }\n } else if (isVideo(image) || isSvg(image)) {\n return image.toString();\n }\n\n if (height !== undefined) {\n params.set(\"h\", String(boostSize(height, boost)));\n }\n if (width !== undefined) {\n params.set(\"w\", String(boostSize(width, boost)));\n }\n if (format !== undefined) {\n params.set(\"format\", format);\n }\n if (quality) {\n if (Number(quality) <= 0 || Number(quality) > 100) {\n throw new Error(\"Quality has to be a positive number between 1 and 100\");\n }\n params.set(\"q\", String(quality));\n }\n if (fit !== undefined) {\n params.set(\"fit\", fit);\n }\n\n image.search = params.toString();\n return image.toString();\n}\n\nfunction isVideo(url: URL): boolean {\n const extension = getExtension(url);\n return (\n extension === \"mp4\" ||\n extension === \"mov\" ||\n extension === \"webm\" ||\n extension === \"m4v\" ||\n extension === \"ogg\" ||\n extension === \"ogv\"\n );\n}\n\nfunction isSvg(url: URL): boolean {\n return getExtension(url) === \"svg\";\n}\n\nfunction canExtractFrame(url: URL): boolean {\n return isVideo(url) || isSvg(url) || getExtension(url) === \"gif\";\n}\n\nfunction canBeResized(url: URL): boolean {\n if (!isSeadnURL(url)) {\n return false;\n }\n const extension = getExtension(url);\n switch (extension) {\n case \"jpg\":\n case \"png\":\n case \"jpeg\":\n case \"webp\":\n case \"avif\":\n case \"ico\":\n case \"bmp\":\n case \"gif\":\n case undefined:\n return true;\n default:\n return false;\n }\n}\n\nfunction getExtension(url: URL): string | undefined {\n const split = url.pathname.split(\".\");\n if (split.length <= 1) {\n return undefined;\n }\n return split[split.length - 1];\n}\n\nexport function isSeadnURL(url: URL): boolean {\n return url.hostname.endsWith(\"seadn.io\");\n}\n\nexport function originalURL(image: URL | string): string {\n try {\n if (typeof image === \"string\") {\n image = new URL(image);\n }\n } catch {\n return image.toString();\n }\n\n if (isSeadnV1URL(image)) {\n image.hostname = image.hostname.replace(\"i.seadn.io\", \"raw.seadn.io\");\n image.pathname = image.pathname.replace(\"/s/raw/files/\", \"/files/\");\n return image.toString();\n }\n\n if (!isSeadnURL(image)) {\n return image.toString();\n }\n\n image.hostname = getOriginalHostname(image);\n return image.toString();\n}\n\nexport function getOriginalHostname(url: URL): string {\n return url.hostname.replace(\"i2c\", \"raw2\").replace(\"i2\", \"raw2\");\n}\n\nexport function isSeadnV1URL(url: URL): boolean {\n return url.hostname === \"i.seadn.io\" || url.hostname === \"raw.seadn.io\";\n}\n"],"mappings":"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","names":["DIMENSIONS_BUCKETS","findNextBucket","originalSize","boosted","originalBucket","bucket","nextBucket","currentIndex","boostSize","size","boost","optimize","image","width","height","format","quality","fit","frameTime","boost","e","isFrameable","canExtractFrame","canBeResized","isVideo","originalURL","params","isSvg","boostSize","url","extension","getExtension","isSeadnURL","split","isSeadnV1URL","getOriginalHostname"]}
1
+ {"version":3,"sources":["../src/boost.ts","../src/sdk.ts"],"sourcesContent":["const DIMENSIONS_BUCKETS = [80, 250, 500, 750, 1000, 2000, 4000];\n\nfunction findNextBucket(originalSize: number, boosted: number): number {\n let originalBucket = DIMENSIONS_BUCKETS.find(\n bucket => bucket >= originalSize,\n );\n let nextBucket = DIMENSIONS_BUCKETS.find(bucket => bucket >= boosted);\n\n if (nextBucket === originalBucket) {\n const currentIndex = DIMENSIONS_BUCKETS.indexOf(nextBucket!);\n nextBucket = DIMENSIONS_BUCKETS[currentIndex + 1];\n }\n\n return nextBucket || DIMENSIONS_BUCKETS[DIMENSIONS_BUCKETS.length - 1];\n}\n\nexport function boostSize(\n size: number | `${number}`,\n boost: number | undefined,\n): number | `${number}` {\n if (boost === undefined || boost <= 1) {\n return size;\n }\n const boosted = Number(size) * boost;\n return findNextBucket(Number(size), boosted);\n}\n","import { boostSize } from \"./boost\";\n\nexport type MediaFormat = \"webp\" | \"avif\" | \"jpeg\" | \"png\";\nexport type MediaFit = \"cover\" | \"contain\" | \"fill\" | \"inside\" | \"outside\";\n\nexport type MediaParams = {\n width?: number | `${number}`;\n height?: number | `${number}`;\n format?: MediaFormat;\n quality?: number | `${number}`;\n fit?: MediaFit;\n frameTime?: number;\n boost?: number;\n};\n\nexport function optimize(\n image: string | URL,\n { width, height, format, quality, fit, frameTime, boost }: MediaParams,\n): string {\n try {\n if (typeof image === \"string\") {\n image = new URL(image);\n }\n } catch {\n return image.toString();\n }\n\n if (!(image instanceof URL)) {\n return image;\n }\n\n const isFrameable = canExtractFrame(image);\n if (!canBeResized(image) && !isFrameable) {\n return originalURL(image);\n }\n\n // for partial content stremaing\n if (isVideo(image) && frameTime === undefined) {\n return originalURL(image);\n }\n\n const params = new URLSearchParams();\n\n if (frameTime !== undefined) {\n if (isFrameable) {\n params.set(\"frame-time\", String(frameTime));\n }\n } else if (isVideo(image)) {\n return image.toString();\n }\n\n if (height !== undefined) {\n params.set(\"h\", String(boostSize(height, boost)));\n }\n if (width !== undefined) {\n params.set(\"w\", String(boostSize(width, boost)));\n }\n if (format !== undefined) {\n params.set(\"format\", format);\n }\n if (quality) {\n if (Number(quality) <= 0 || Number(quality) > 100) {\n throw new Error(\"Quality has to be a positive number between 1 and 100\");\n }\n params.set(\"q\", String(quality));\n }\n if (fit !== undefined) {\n params.set(\"fit\", fit);\n }\n\n image.search = params.toString();\n return image.toString();\n}\n\nfunction isVideo(url: URL): boolean {\n const extension = getExtension(url);\n return (\n extension === \"mp4\" ||\n extension === \"mov\" ||\n extension === \"webm\" ||\n extension === \"m4v\" ||\n extension === \"ogg\" ||\n extension === \"ogv\"\n );\n}\n\nfunction canExtractFrame(url: URL): boolean {\n return isVideo(url) || getExtension(url) === \"gif\";\n}\n\nfunction canBeResized(url: URL): boolean {\n if (!isSeadnURL(url)) {\n return false;\n }\n const extension = getExtension(url);\n switch (extension) {\n case \"jpg\":\n case \"png\":\n case \"jpeg\":\n case \"webp\":\n case \"avif\":\n case \"ico\":\n case \"bmp\":\n case \"gif\":\n case undefined:\n return true;\n default:\n return false;\n }\n}\n\nfunction getExtension(url: URL): string | undefined {\n const split = url.pathname.split(\".\");\n if (split.length <= 1) {\n return undefined;\n }\n return split[split.length - 1];\n}\n\nexport function isSeadnURL(url: URL): boolean {\n return url.hostname.endsWith(\"seadn.io\");\n}\n\nexport function originalURL(image: URL | string): string {\n try {\n if (typeof image === \"string\") {\n image = new URL(image);\n }\n } catch {\n return image.toString();\n }\n\n if (isSeadnV1URL(image)) {\n image.hostname = image.hostname.replace(\"i.seadn.io\", \"raw.seadn.io\");\n image.pathname = image.pathname.replace(\"/s/raw/files/\", \"/files/\");\n return image.toString();\n }\n\n if (!isSeadnURL(image)) {\n return image.toString();\n }\n\n image.hostname = getOriginalHostname(image);\n return image.toString();\n}\n\nexport function getOriginalHostname(url: URL): string {\n return url.hostname.replace(\"i2c\", \"raw2\").replace(\"i2\", \"raw2\");\n}\n\nexport function isSeadnV1URL(url: URL): boolean {\n return url.hostname === \"i.seadn.io\" || url.hostname === \"raw.seadn.io\";\n}\n"],"mappings":"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","names":["DIMENSIONS_BUCKETS","findNextBucket","originalSize","boosted","originalBucket","bucket","nextBucket","currentIndex","boostSize","size","boost","optimize","image","width","height","format","quality","fit","frameTime","boost","e","isFrameable","canExtractFrame","canBeResized","isVideo","originalURL","params","boostSize","url","extension","getExtension","isSeadnURL","split","isSeadnV1URL","getOriginalHostname"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@opensea/seadn",
3
- "version": "2.3.8",
3
+ "version": "2.3.9",
4
4
  "description": "Javascript SDK to work with SeaDN",
5
5
  "license": "MIT",
6
6
  "author": "OpenSea Developers",
@@ -12,16 +12,16 @@
12
12
  "./dist",
13
13
  "./src"
14
14
  ],
15
- "devDependencies": {
16
- "@arethetypeswrong/cli": "0.17.3",
17
- "tsup": "8.3.5",
18
- "typescript": "5.7.3",
19
- "vitest": "1.5.0"
20
- },
21
15
  "scripts": {
22
16
  "build": "tsup",
23
17
  "build:typecheck": "attw --pack",
24
18
  "test": "vitest",
25
19
  "typecheck": "tsc"
20
+ },
21
+ "devDependencies": {
22
+ "@arethetypeswrong/cli": "0.17.4",
23
+ "tsup": "8.4.0",
24
+ "typescript": "5.8.2",
25
+ "vitest": "1.5.0"
26
26
  }
27
- }
27
+ }
package/src/sdk.spec.ts CHANGED
@@ -35,7 +35,7 @@ test.each([
35
35
  [
36
36
  "https://i2.seadn.io/bored-ape.svg",
37
37
  { height: 100, width: 100 } satisfies MediaParams,
38
- "https://i2.seadn.io/bored-ape.svg",
38
+ "https://raw2.seadn.io/bored-ape.svg",
39
39
  ],
40
40
  [
41
41
  "https://i2.seadn.io/bored-ape.gif",
@@ -106,7 +106,7 @@ test.each([
106
106
  [
107
107
  "https://i2.seadn.io/bored-ape.svg",
108
108
  { frameTime: 0.1, height: 50 } satisfies MediaParams,
109
- "https://i2.seadn.io/bored-ape.svg?frame-time=0.1&h=50",
109
+ "https://raw2.seadn.io/bored-ape.svg",
110
110
  ],
111
111
  [
112
112
  "https://i2.seadn.io/bored-ape.gif",
package/src/sdk.ts CHANGED
@@ -45,7 +45,7 @@ export function optimize(
45
45
  if (isFrameable) {
46
46
  params.set("frame-time", String(frameTime));
47
47
  }
48
- } else if (isVideo(image) || isSvg(image)) {
48
+ } else if (isVideo(image)) {
49
49
  return image.toString();
50
50
  }
51
51
 
@@ -84,12 +84,8 @@ function isVideo(url: URL): boolean {
84
84
  );
85
85
  }
86
86
 
87
- function isSvg(url: URL): boolean {
88
- return getExtension(url) === "svg";
89
- }
90
-
91
87
  function canExtractFrame(url: URL): boolean {
92
- return isVideo(url) || isSvg(url) || getExtension(url) === "gif";
88
+ return isVideo(url) || getExtension(url) === "gif";
93
89
  }
94
90
 
95
91
  function canBeResized(url: URL): boolean {