@absolutejs/absolute 0.19.0-beta.176 → 0.19.0-beta.178

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.
Files changed (40) hide show
  1. package/.absolutejs/eslint-cache +1 -1
  2. package/.absolutejs/tsconfig.tsbuildinfo +1 -1
  3. package/ROADMAP.md +191 -191
  4. package/dist/Image-fpjk72vg.vue +140 -0
  5. package/dist/src/angular/components/image.component.d.ts +33 -0
  6. package/dist/src/angular/components/index.d.ts +1 -0
  7. package/dist/src/angular/components/index.js +395 -0
  8. package/dist/src/angular/components/index.js.map +11 -0
  9. package/dist/{angular → src/angular}/index.js +11 -1
  10. package/dist/{angular → src/angular}/index.js.map +2 -2
  11. package/dist/src/build/optimizeHtmlImages.d.ts +2 -0
  12. package/dist/{build.js → src/build.js} +496 -243
  13. package/dist/{build.js.map → src/build.js.map} +7 -5
  14. package/dist/{index.js → src/index.js} +746 -276
  15. package/dist/{index.js.map → src/index.js.map} +9 -6
  16. package/dist/src/plugins/imageOptimizer.d.ts +2 -0
  17. package/dist/src/react/components/Image.d.ts +2 -0
  18. package/dist/src/react/components/index.d.ts +1 -0
  19. package/dist/{react → src/react}/hooks/index.js +11 -1
  20. package/dist/{react → src/react}/hooks/index.js.map +2 -2
  21. package/dist/{react → src/react}/index.js +11 -1
  22. package/dist/{react → src/react}/index.js.map +2 -2
  23. package/dist/{svelte → src/svelte}/index.js +11 -1
  24. package/dist/{svelte → src/svelte}/index.js.map +2 -2
  25. package/dist/src/utils/imageProcessing.d.ts +33 -0
  26. package/dist/src/vue/components/index.d.ts +1 -0
  27. package/dist/src/vue/components/index.js +84 -0
  28. package/dist/src/vue/components/index.js.map +9 -0
  29. package/dist/{vue → src/vue}/index.js +11 -1
  30. package/dist/{vue → src/vue}/index.js.map +2 -2
  31. package/dist/svelte/components/Head.svelte +147 -0
  32. package/dist/svelte/components/Image.svelte +158 -0
  33. package/dist/svelte/components/JsonLd.svelte +20 -0
  34. package/dist/types/build.d.ts +2 -0
  35. package/dist/types/image.d.ts +77 -0
  36. package/dist/types/index.d.ts +1 -0
  37. package/package.json +19 -4
  38. package/types/build.ts +3 -0
  39. package/types/image.ts +91 -0
  40. package/types/index.ts +1 -0
@@ -0,0 +1,395 @@
1
+ // @bun
2
+ var __create = Object.create;
3
+ var __getProtoOf = Object.getPrototypeOf;
4
+ var __defProp = Object.defineProperty;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ function __accessProp(key) {
9
+ return this[key];
10
+ }
11
+ var __toESMCache_node;
12
+ var __toESMCache_esm;
13
+ var __toESM = (mod, isNodeMode, target) => {
14
+ var canCache = mod != null && typeof mod === "object";
15
+ if (canCache) {
16
+ var cache = isNodeMode ? __toESMCache_node ??= new WeakMap : __toESMCache_esm ??= new WeakMap;
17
+ var cached = cache.get(mod);
18
+ if (cached)
19
+ return cached;
20
+ }
21
+ target = mod != null ? __create(__getProtoOf(mod)) : {};
22
+ const to = isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target;
23
+ for (let key of __getOwnPropNames(mod))
24
+ if (!__hasOwnProp.call(to, key))
25
+ __defProp(to, key, {
26
+ get: __accessProp.bind(mod, key),
27
+ enumerable: true
28
+ });
29
+ if (canCache)
30
+ cache.set(mod, to);
31
+ return to;
32
+ };
33
+ var __toCommonJS = (from) => {
34
+ var entry = (__moduleCache ??= new WeakMap).get(from), desc;
35
+ if (entry)
36
+ return entry;
37
+ entry = __defProp({}, "__esModule", { value: true });
38
+ if (from && typeof from === "object" || typeof from === "function") {
39
+ for (var key of __getOwnPropNames(from))
40
+ if (!__hasOwnProp.call(entry, key))
41
+ __defProp(entry, key, {
42
+ get: __accessProp.bind(from, key),
43
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
44
+ });
45
+ }
46
+ __moduleCache.set(from, entry);
47
+ return entry;
48
+ };
49
+ var __moduleCache;
50
+ var __commonJS = (cb, mod) => () => (mod || cb((mod = { exports: {} }).exports, mod), mod.exports);
51
+ var __returnValue = (v) => v;
52
+ function __exportSetter(name, newValue) {
53
+ this[name] = __returnValue.bind(null, newValue);
54
+ }
55
+ var __export = (target, all) => {
56
+ for (var name in all)
57
+ __defProp(target, name, {
58
+ get: all[name],
59
+ enumerable: true,
60
+ configurable: true,
61
+ set: __exportSetter.bind(all, name)
62
+ });
63
+ };
64
+ var __legacyDecorateClassTS = function(decorators, target, key, desc) {
65
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
66
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
67
+ r = Reflect.decorate(decorators, target, key, desc);
68
+ else
69
+ for (var i = decorators.length - 1;i >= 0; i--)
70
+ if (d = decorators[i])
71
+ r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
72
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
73
+ };
74
+ var __esm = (fn, res) => () => (fn && (res = fn(fn = 0)), res);
75
+ var __require = import.meta.require;
76
+
77
+ // src/utils/imageProcessing.ts
78
+ import { existsSync, mkdirSync, readFileSync, writeFileSync } from "fs";
79
+ import { join } from "path";
80
+ var DEFAULT_DEVICE_SIZES, DEFAULT_IMAGE_SIZES, DEFAULT_QUALITY = 75, OPTIMIZATION_ENDPOINT = "/_absolute/image", BLUR_DEVIATION = 20, sharpModule = undefined, sharpLoaded = false, sharpWarned = false, snapToSize = (target, sizes) => {
81
+ for (const size of sizes) {
82
+ if (size >= target)
83
+ return size;
84
+ }
85
+ return sizes[sizes.length - 1] ?? target;
86
+ }, matchHostname = (actual, pattern) => {
87
+ if (pattern === actual)
88
+ return true;
89
+ if (pattern.startsWith("*.")) {
90
+ const suffix = pattern.slice(1);
91
+ return actual.endsWith(suffix) && actual.length > suffix.length;
92
+ }
93
+ return false;
94
+ }, matchPathname = (actual, pattern) => {
95
+ if (pattern.endsWith("/**")) {
96
+ const prefix = pattern.slice(0, -2);
97
+ return actual.startsWith(prefix);
98
+ }
99
+ return actual === pattern;
100
+ }, MIME_MAP, callSharp = (sharpRef, input) => {
101
+ const factory = sharpRef;
102
+ return factory(input);
103
+ }, toBuffer = (input) => {
104
+ if (Buffer.isBuffer(input))
105
+ return input;
106
+ return Buffer.from(input);
107
+ }, buildOptimizedUrl = (src, width, quality, basePath = OPTIMIZATION_ENDPOINT) => `${basePath}?url=${encodeURIComponent(src)}&w=${width}&q=${quality}`, formatToMime = (format) => MIME_MAP[format], generateBlurSvg = (base64Thumbnail) => {
108
+ const svg = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 320"><filter id="b" color-interpolation-filters="sRGB"><feGaussianBlur stdDeviation="${BLUR_DEVIATION}"/><feColorMatrix values="1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 100 -1"/></filter><image filter="url(#b)" x="0" y="0" width="100%" height="100%" href="${base64Thumbnail}"/></svg>`;
109
+ const encoded = encodeURIComponent(svg);
110
+ return `url("data:image/svg+xml,${encoded}")`;
111
+ }, generateSrcSet = (src, width, sizes, config, loader) => {
112
+ const quality = config?.quality ?? DEFAULT_QUALITY;
113
+ const basePath = config?.path ?? OPTIMIZATION_ENDPOINT;
114
+ const buildUrl = loader ?? ((params) => buildOptimizedUrl(params.src, params.width, params.quality, basePath));
115
+ if (sizes) {
116
+ const allSizes = getAllSizes(config);
117
+ return allSizes.map((sizeWidth) => `${buildUrl({ quality, src, width: sizeWidth })} ${sizeWidth}w`).join(", ");
118
+ }
119
+ if (width) {
120
+ const allSizes = getAllSizes(config);
121
+ const w1x = snapToSize(width, allSizes);
122
+ const w2x = snapToSize(width * 2, allSizes);
123
+ return `${buildUrl({ quality, src, width: w1x })} 1x, ${buildUrl({ quality, src, width: w2x })} 2x`;
124
+ }
125
+ const deviceSizes = config?.deviceSizes ?? DEFAULT_DEVICE_SIZES;
126
+ return deviceSizes.map((sizeWidth) => `${buildUrl({ quality, src, width: sizeWidth })} ${sizeWidth}w`).join(", ");
127
+ }, getAllSizes = (config) => {
128
+ const device = config?.deviceSizes ?? DEFAULT_DEVICE_SIZES;
129
+ const image = config?.imageSizes ?? DEFAULT_IMAGE_SIZES;
130
+ return [...device, ...image].sort((left, right) => left - right);
131
+ }, getCacheDir = (buildDir) => {
132
+ const dir = join(buildDir, ".cache", "images");
133
+ if (!existsSync(dir))
134
+ mkdirSync(dir, { recursive: true });
135
+ return dir;
136
+ }, getCacheKey = (url, width, quality, format) => {
137
+ const hasher = new Bun.CryptoHasher("sha256");
138
+ hasher.update(`${url}|${width}|${quality}|${format}`);
139
+ return hasher.digest("hex");
140
+ }, isCacheStale = (meta) => Date.now() > meta.expireAt, matchRemotePattern = (urlString, patterns) => {
141
+ let parsed;
142
+ try {
143
+ parsed = new URL(urlString);
144
+ } catch {
145
+ return false;
146
+ }
147
+ return patterns.some((pattern) => {
148
+ if (pattern.protocol && parsed.protocol !== `${pattern.protocol}:`)
149
+ return false;
150
+ if (!matchHostname(parsed.hostname, pattern.hostname))
151
+ return false;
152
+ if (pattern.port && parsed.port !== pattern.port)
153
+ return false;
154
+ if (pattern.pathname && !matchPathname(parsed.pathname, pattern.pathname))
155
+ return false;
156
+ return true;
157
+ });
158
+ }, negotiateFormat = (acceptHeader, configuredFormats) => {
159
+ for (const format of configuredFormats) {
160
+ const mime = MIME_MAP[format];
161
+ if (mime && acceptHeader.includes(mime))
162
+ return format;
163
+ }
164
+ if (configuredFormats.includes("webp") && acceptHeader.includes("image/webp")) {
165
+ return "webp";
166
+ }
167
+ return "jpeg";
168
+ }, AVIF_QUALITY_OFFSET = 20, AVIF_EFFORT = 3, optimizeImage = async (buffer, width, quality, format) => {
169
+ const sharp = await tryLoadSharp();
170
+ if (!sharp)
171
+ return toBuffer(buffer);
172
+ const pipeline = callSharp(sharp, toBuffer(buffer)).rotate().resize(width, undefined, { withoutEnlargement: true });
173
+ switch (format) {
174
+ case "avif":
175
+ return pipeline.avif({ effort: AVIF_EFFORT, quality: Math.max(1, quality - AVIF_QUALITY_OFFSET) }).toBuffer();
176
+ case "jpeg":
177
+ return pipeline.jpeg({ mozjpeg: true, quality }).toBuffer();
178
+ case "png":
179
+ return pipeline.png({ quality }).toBuffer();
180
+ case "webp":
181
+ return pipeline.webp({ quality }).toBuffer();
182
+ default:
183
+ return toBuffer(buffer);
184
+ }
185
+ }, readFromCache = (cacheDir, cacheKey) => {
186
+ const metaPath = join(cacheDir, `${cacheKey}.meta`);
187
+ const dataPath = join(cacheDir, `${cacheKey}.data`);
188
+ if (!existsSync(metaPath) || !existsSync(dataPath))
189
+ return null;
190
+ try {
191
+ const meta = JSON.parse(readFileSync(metaPath, "utf-8"));
192
+ const buffer = readFileSync(dataPath);
193
+ return { buffer, meta };
194
+ } catch {
195
+ return null;
196
+ }
197
+ }, tryLoadSharp = async () => {
198
+ if (sharpLoaded)
199
+ return sharpModule;
200
+ sharpLoaded = true;
201
+ try {
202
+ const name = "sharp";
203
+ const mod = await import(name);
204
+ sharpModule = mod.default ?? mod;
205
+ return sharpModule;
206
+ } catch {
207
+ if (sharpWarned)
208
+ return null;
209
+ sharpWarned = true;
210
+ console.warn("[image] sharp not installed \u2014 serving unoptimized images. Install with: bun add sharp");
211
+ return null;
212
+ }
213
+ }, writeToCache = (cacheDir, cacheKey, buffer, meta) => {
214
+ const metaPath = join(cacheDir, `${cacheKey}.meta`);
215
+ const dataPath = join(cacheDir, `${cacheKey}.data`);
216
+ writeFileSync(dataPath, buffer);
217
+ writeFileSync(metaPath, JSON.stringify(meta));
218
+ };
219
+ var init_imageProcessing = __esm(() => {
220
+ DEFAULT_DEVICE_SIZES = [
221
+ 640,
222
+ 750,
223
+ 828,
224
+ 1080,
225
+ 1200,
226
+ 1920,
227
+ 2048,
228
+ 3840
229
+ ];
230
+ DEFAULT_IMAGE_SIZES = [
231
+ 16,
232
+ 32,
233
+ 48,
234
+ 64,
235
+ 96,
236
+ 128,
237
+ 256,
238
+ 384
239
+ ];
240
+ MIME_MAP = {
241
+ avif: "image/avif",
242
+ jpeg: "image/jpeg",
243
+ png: "image/png",
244
+ webp: "image/webp"
245
+ };
246
+ });
247
+
248
+ // src/angular/components/image.component.ts
249
+ init_imageProcessing();
250
+ import { Component, computed, input, signal } from "@angular/core";
251
+ var resolveBlurBg = (placeholderValue, blurDataUrl) => {
252
+ if (typeof placeholderValue === "string" && placeholderValue !== "blur" && placeholderValue.startsWith("data:")) {
253
+ return generateBlurSvg(placeholderValue);
254
+ }
255
+ if (blurDataUrl)
256
+ return generateBlurSvg(blurDataUrl);
257
+ return;
258
+ };
259
+
260
+ class ImageComponent {
261
+ alt = input.required();
262
+ blurDataURL = input();
263
+ className = input();
264
+ crossOrigin = input();
265
+ fetchPriority = input();
266
+ fill = input(false);
267
+ height = input();
268
+ loader = input();
269
+ loading = input("lazy");
270
+ onError = input();
271
+ onLoad = input();
272
+ overrideSrc = input();
273
+ placeholder = input("empty");
274
+ priority = input(false);
275
+ quality = input(DEFAULT_QUALITY);
276
+ referrerPolicy = input();
277
+ sizes = input();
278
+ src = input.required();
279
+ style = input();
280
+ unoptimized = input(false);
281
+ width = input();
282
+ blurRemoved = signal(false);
283
+ resolvedSrc = computed(() => {
284
+ const override = this.overrideSrc();
285
+ if (override)
286
+ return override;
287
+ if (this.unoptimized())
288
+ return this.src();
289
+ const loaderFn = this.loader();
290
+ if (loaderFn)
291
+ return loaderFn({ quality: this.quality(), src: this.src(), width: this.width() ?? 0 });
292
+ const currentWidth = this.width();
293
+ if (!currentWidth)
294
+ return buildOptimizedUrl(this.src(), 0, this.quality());
295
+ return buildOptimizedUrl(this.src(), currentWidth, this.quality());
296
+ });
297
+ srcSet = computed(() => this.unoptimized() ? undefined : generateSrcSet(this.src(), this.width(), this.sizes(), undefined, this.loader() ?? undefined));
298
+ resolvedSizes = computed(() => this.sizes() ?? (this.fill() ? "100vw" : undefined));
299
+ resolvedLoading = computed(() => this.priority() ? "eager" : this.loading());
300
+ resolvedFetchPriority = computed(() => this.priority() ? "high" : this.fetchPriority());
301
+ imgStyle = computed(() => {
302
+ const base = {
303
+ ...this.style() ?? {},
304
+ color: "transparent"
305
+ };
306
+ const hasBlur = !this.blurRemoved() && (this.placeholder() === "blur" || typeof this.placeholder() === "string" && this.placeholder() !== "empty" && (this.placeholder() ?? "").startsWith("data:"));
307
+ const blurValue = hasBlur ? resolveBlurBg(this.placeholder(), this.blurDataURL()) : undefined;
308
+ if (blurValue) {
309
+ base["background-image"] = blurValue;
310
+ base["background-position"] = "center";
311
+ base["background-repeat"] = "no-repeat";
312
+ base["background-size"] = "cover";
313
+ }
314
+ if (this.fill()) {
315
+ base.height = "100%";
316
+ base.inset = "0";
317
+ base["object-fit"] = "cover";
318
+ base.position = "absolute";
319
+ base.width = "100%";
320
+ }
321
+ return base;
322
+ });
323
+ handleLoad(event) {
324
+ this.blurRemoved.set(true);
325
+ const callback = this.onLoad();
326
+ if (callback)
327
+ callback(event);
328
+ }
329
+ handleError(event) {
330
+ const callback = this.onError();
331
+ if (callback)
332
+ callback(event);
333
+ }
334
+ }
335
+ ImageComponent = __legacyDecorateClassTS([
336
+ Component({
337
+ selector: "abs-image",
338
+ standalone: true,
339
+ template: `
340
+ @if (priority()) {
341
+ <link
342
+ rel="preload"
343
+ as="image"
344
+ [attr.href]="resolvedSrc()"
345
+ [attr.imagesrcset]="srcSet()"
346
+ [attr.imagesizes]="resolvedSizes()"
347
+ [attr.crossorigin]="crossOrigin()"
348
+ />
349
+ }
350
+ @if (fill()) {
351
+ <span style="position:relative;overflow:hidden;display:block;width:100%;height:100%">
352
+ <img
353
+ [alt]="alt()"
354
+ [src]="resolvedSrc()"
355
+ [srcset]="srcSet()"
356
+ [sizes]="resolvedSizes()"
357
+ [loading]="resolvedLoading()"
358
+ [class]="className()"
359
+ [ngStyle]="imgStyle()"
360
+ [crossOrigin]="crossOrigin()"
361
+ [referrerPolicy]="referrerPolicy()"
362
+ [attr.fetchpriority]="resolvedFetchPriority()"
363
+ decoding="async"
364
+ (load)="handleLoad($event)"
365
+ (error)="handleError($event)"
366
+ />
367
+ </span>
368
+ } @else {
369
+ <img
370
+ [alt]="alt()"
371
+ [src]="resolvedSrc()"
372
+ [srcset]="srcSet()"
373
+ [sizes]="resolvedSizes()"
374
+ [width]="width()"
375
+ [height]="height()"
376
+ [loading]="resolvedLoading()"
377
+ [class]="className()"
378
+ [ngStyle]="imgStyle()"
379
+ [crossOrigin]="crossOrigin()"
380
+ [referrerPolicy]="referrerPolicy()"
381
+ [attr.fetchpriority]="resolvedFetchPriority()"
382
+ decoding="async"
383
+ (load)="handleLoad($event)"
384
+ (error)="handleError($event)"
385
+ />
386
+ }
387
+ `
388
+ })
389
+ ], ImageComponent);
390
+ export {
391
+ ImageComponent
392
+ };
393
+
394
+ //# debugId=C6CC0570D6433A0964756E2164756E21
395
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,11 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/utils/imageProcessing.ts", "../src/angular/components/image.component.ts"],
4
+ "sourcesContent": [
5
+ "import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';\nimport { join } from 'node:path';\nimport type { ImageConfig, ImageFormat, RemotePattern } from '../../types/image';\n\n// ── Constants ──────────────────────────────────────────────────────\n\n/* eslint-disable no-magic-numbers */\nexport const DEFAULT_DEVICE_SIZES = [\n\t640, 750, 828, 1080, 1200, 1920, 2048, 3840\n];\n\nexport const DEFAULT_IMAGE_SIZES = [\n\t16, 32, 48, 64, 96, 128, 256, 384\n];\n\nexport const DEFAULT_QUALITY = 75;\n/* eslint-enable no-magic-numbers */\n\nexport const OPTIMIZATION_ENDPOINT = '/_absolute/image';\n\n// ── Blur Placeholder ───────────────────────────────────────────────\n\nconst BLUR_SIZE = 8;\nconst BLUR_QUALITY = 70;\nconst BLUR_DEVIATION = 20;\n\n// ── Sharp Loading ──────────────────────────────────────────────────\n\nlet sharpModule: unknown = undefined;\nlet sharpLoaded = false;\nlet sharpWarned = false;\n\n// ── Shared Internals ───────────────────────────────────────────────\n\n/** Snap a target width UP to the nearest configured size */\nconst snapToSize = (target: number, sizes: number[]) => {\n\tfor (const size of sizes) {\n\t\tif (size >= target) return size;\n\t}\n\n\treturn sizes[sizes.length - 1] ?? target;\n};\n\n/** Match hostname with wildcard support: \"*.example.com\" matches \"cdn.example.com\" */\nconst matchHostname = (actual: string, pattern: string) => {\n\tif (pattern === actual) return true;\n\n\tif (pattern.startsWith('*.')) {\n\t\tconst suffix = pattern.slice(1); // \".example.com\"\n\n\t\treturn actual.endsWith(suffix) && actual.length > suffix.length;\n\t}\n\n\treturn false;\n};\n\n/** Match pathname with glob prefix: \"/images/**\" matches \"/images/photo.jpg\" */\nconst matchPathname = (actual: string, pattern: string) => {\n\tif (pattern.endsWith('/**')) {\n\t\tconst prefix = pattern.slice(0, -2); // eslint-disable-line no-magic-numbers\n\n\t\treturn actual.startsWith(prefix);\n\t}\n\n\treturn actual === pattern;\n};\n\nconst MIME_MAP: Record<ImageFormat, string> = {\n\tavif: 'image/avif',\n\tjpeg: 'image/jpeg',\n\tpng: 'image/png',\n\twebp: 'image/webp'\n};\n\n/** Convert sharp dynamic import result to a callable factory */\nconst callSharp = (sharpRef: unknown, input: Buffer) => {\n\t// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/consistent-type-assertions -- sharp is dynamically imported\n\tconst factory = sharpRef as any;\n\n\treturn factory(input);\n};\n\nconst toBuffer = (input: Buffer | ArrayBuffer) => {\n\tif (Buffer.isBuffer(input)) return input;\n\n\treturn Buffer.from(input);\n};\n\n// ── Exports (alphabetically sorted) ────────────────────────────────\n\nexport const buildOptimizedUrl = (\n\tsrc: string,\n\twidth: number,\n\tquality: number,\n\tbasePath = OPTIMIZATION_ENDPOINT\n) =>\n\t`${basePath}?url=${encodeURIComponent(src)}&w=${width}&q=${quality}`;\n\nexport type CacheMeta = {\n\tcontentType: string;\n\tetag: string;\n\texpireAt: number;\n\tupstreamEtag?: string;\n};\n\nexport const formatToMime = (format: ImageFormat) => MIME_MAP[format];\n\nexport const generateBlurDataURL = async (buffer: Buffer | ArrayBuffer) => {\n\tconst sharp = await tryLoadSharp();\n\n\tif (!sharp) return '';\n\n\tconst tiny: Buffer = await callSharp(sharp, toBuffer(buffer))\n\t\t.resize(BLUR_SIZE, BLUR_SIZE, { fit: 'inside' })\n\t\t.webp({ quality: BLUR_QUALITY })\n\t\t.toBuffer();\n\n\treturn `data:image/webp;base64,${tiny.toString('base64')}`;\n};\n\nexport const generateBlurSvg = (base64Thumbnail: string) => {\n\t// Match Next.js: wrap tiny thumbnail in SVG with Gaussian blur\n\tconst svg = `<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 320\"><filter id=\"b\" color-interpolation-filters=\"sRGB\"><feGaussianBlur stdDeviation=\"${BLUR_DEVIATION}\"/><feColorMatrix values=\"1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 100 -1\"/></filter><image filter=\"url(#b)\" x=\"0\" y=\"0\" width=\"100%\" height=\"100%\" href=\"${base64Thumbnail}\"/></svg>`;\n\n\tconst encoded = encodeURIComponent(svg);\n\n\treturn `url(\"data:image/svg+xml,${encoded}\")`;\n};\n\nexport const generateSrcSet = (\n\tsrc: string,\n\twidth: number | undefined,\n\tsizes: string | undefined,\n\tconfig?: ImageConfig,\n\tloader?: (params: { quality: number; src: string; width: number }) => string\n) => {\n\tconst quality = config?.quality ?? DEFAULT_QUALITY;\n\n\tconst basePath = config?.path ?? OPTIMIZATION_ENDPOINT;\n\n\tconst buildUrl = loader ?? ((params: { quality: number; src: string; width: number }) =>\n\t\tbuildOptimizedUrl(params.src, params.width, params.quality, basePath));\n\n\tif (sizes) {\n\t\t// With sizes: use all breakpoints with w descriptors\n\t\tconst allSizes = getAllSizes(config);\n\n\t\treturn allSizes\n\t\t\t.map((sizeWidth) => `${buildUrl({ quality, src, width: sizeWidth })} ${sizeWidth}w`)\n\t\t\t.join(', ');\n\t}\n\n\tif (width) {\n\t\t// Without sizes: generate 1x and 2x density descriptors\n\t\tconst allSizes = getAllSizes(config);\n\n\t\tconst w1x = snapToSize(width, allSizes);\n\n\t\tconst w2x = snapToSize(width * 2, allSizes);\n\n\t\treturn `${buildUrl({ quality, src, width: w1x })} 1x, ${buildUrl({ quality, src, width: w2x })} 2x`;\n\t}\n\n\t// No width or sizes — use device sizes with w descriptors\n\tconst deviceSizes = config?.deviceSizes ?? DEFAULT_DEVICE_SIZES;\n\n\treturn deviceSizes\n\t\t.map((sizeWidth) => `${buildUrl({ quality, src, width: sizeWidth })} ${sizeWidth}w`)\n\t\t.join(', ');\n};\n\nexport const getAllSizes = (config?: ImageConfig) => {\n\tconst device = config?.deviceSizes ?? DEFAULT_DEVICE_SIZES;\n\n\tconst image = config?.imageSizes ?? DEFAULT_IMAGE_SIZES;\n\n\treturn [...device, ...image].sort((left, right) => left - right);\n};\n\nexport const getCacheDir = (buildDir: string) => {\n\tconst dir = join(buildDir, '.cache', 'images');\n\n\tif (!existsSync(dir)) mkdirSync(dir, { recursive: true });\n\n\treturn dir;\n};\n\nexport const getCacheKey = (\n\turl: string,\n\twidth: number,\n\tquality: number,\n\tformat: string\n) => {\n\tconst hasher = new Bun.CryptoHasher('sha256');\n\n\thasher.update(`${url}|${width}|${quality}|${format}`);\n\n\treturn hasher.digest('hex');\n};\n\nexport const isCacheStale = (meta: CacheMeta) => Date.now() > meta.expireAt;\n\nexport const matchRemotePattern = (\n\turlString: string,\n\tpatterns: RemotePattern[]\n) => {\n\tlet parsed: URL;\n\n\ttry {\n\t\tparsed = new URL(urlString);\n\t} catch {\n\t\treturn false;\n\t}\n\n\treturn patterns.some((pattern) => {\n\t\tif (pattern.protocol && parsed.protocol !== `${pattern.protocol}:`) return false;\n\n\t\tif (!matchHostname(parsed.hostname, pattern.hostname)) return false;\n\n\t\tif (pattern.port && parsed.port !== pattern.port) return false;\n\n\t\tif (pattern.pathname && !matchPathname(parsed.pathname, pattern.pathname)) return false;\n\n\t\treturn true;\n\t});\n};\n\nexport const negotiateFormat = (\n\tacceptHeader: string,\n\tconfiguredFormats: ImageFormat[]\n) => {\n\t// Check configured formats in preference order against Accept header\n\tfor (const format of configuredFormats) {\n\t\tconst mime = MIME_MAP[format];\n\n\t\tif (mime && acceptHeader.includes(mime)) return format;\n\t}\n\n\t// Fallback: if webp is configured and accepted, use it\n\tif (configuredFormats.includes('webp') && acceptHeader.includes('image/webp')) {\n\t\treturn 'webp';\n\t}\n\n\t// Final fallback to jpeg\n\treturn 'jpeg';\n};\n\nconst AVIF_QUALITY_OFFSET = 20;\nconst AVIF_EFFORT = 3;\n\nexport const optimizeImage = async (\n\tbuffer: Buffer | ArrayBuffer,\n\twidth: number,\n\tquality: number,\n\tformat: ImageFormat\n) => {\n\tconst sharp = await tryLoadSharp();\n\n\tif (!sharp) return toBuffer(buffer);\n\n\tconst pipeline = callSharp(sharp, toBuffer(buffer))\n\t\t.rotate()\n\t\t.resize(width, undefined, { withoutEnlargement: true });\n\n\tswitch (format) {\n\t\tcase 'avif':\n\t\t\treturn pipeline\n\t\t\t\t.avif({ effort: AVIF_EFFORT, quality: Math.max(1, quality - AVIF_QUALITY_OFFSET) })\n\t\t\t\t.toBuffer();\n\t\tcase 'jpeg':\n\t\t\treturn pipeline\n\t\t\t\t.jpeg({ mozjpeg: true, quality })\n\t\t\t\t.toBuffer();\n\t\tcase 'png':\n\t\t\treturn pipeline.png({ quality }).toBuffer();\n\t\tcase 'webp':\n\t\t\treturn pipeline.webp({ quality }).toBuffer();\n\t\tdefault:\n\t\t\treturn toBuffer(buffer);\n\t}\n};\n\nexport const readFromCache = (cacheDir: string, cacheKey: string) => {\n\tconst metaPath = join(cacheDir, `${cacheKey}.meta`);\n\n\tconst dataPath = join(cacheDir, `${cacheKey}.data`);\n\n\tif (!existsSync(metaPath) || !existsSync(dataPath)) return null;\n\n\ttry {\n\t\tconst meta: CacheMeta = JSON.parse(readFileSync(metaPath, 'utf-8'));\n\n\t\tconst buffer = readFileSync(dataPath);\n\n\t\treturn { buffer, meta };\n\t} catch {\n\t\treturn null;\n\t}\n};\n\nexport const tryLoadSharp = async () => {\n\tif (sharpLoaded) return sharpModule;\n\n\tsharpLoaded = true;\n\n\ttry {\n\t\t// Dynamic import — sharp is an optional peer dependency\n\t\tconst name = 'sharp';\n\n\t\tconst mod = await import(/* @vite-ignore */ name);\n\n\t\tsharpModule = mod.default ?? mod;\n\n\t\treturn sharpModule;\n\t} catch {\n\t\tif (sharpWarned) return null;\n\n\t\tsharpWarned = true;\n\n\t\tconsole.warn(\n\t\t\t'[image] sharp not installed — serving unoptimized images. Install with: bun add sharp'\n\t\t);\n\n\t\treturn null;\n\t}\n};\n\nexport const writeToCache = (\n\tcacheDir: string,\n\tcacheKey: string,\n\tbuffer: Buffer,\n\tmeta: CacheMeta\n) => {\n\tconst metaPath = join(cacheDir, `${cacheKey}.meta`);\n\n\tconst dataPath = join(cacheDir, `${cacheKey}.data`);\n\n\twriteFileSync(dataPath, buffer);\n\n\twriteFileSync(metaPath, JSON.stringify(meta));\n};\n",
6
+ "import { Component, computed, input, signal } from '@angular/core';\nimport type { ImageLoader } from '../../../types/image';\nimport {\n\tDEFAULT_QUALITY,\n\tbuildOptimizedUrl,\n\tgenerateBlurSvg,\n\tgenerateSrcSet\n} from '../../utils/imageProcessing';\n\n/** Resolve the blur background CSS value from placeholder config */\nconst resolveBlurBg = (\n\tplaceholderValue: string,\n\tblurDataUrl: string | undefined\n) => {\n\tif (\n\t\ttypeof placeholderValue === 'string' &&\n\t\tplaceholderValue !== 'blur' &&\n\t\tplaceholderValue.startsWith('data:')\n\t) {\n\t\treturn generateBlurSvg(placeholderValue);\n\t}\n\n\tif (blurDataUrl) return generateBlurSvg(blurDataUrl);\n\n\treturn undefined;\n};\n\n@Component({\n\tselector: 'abs-image',\n\tstandalone: true,\n\ttemplate: `\n\t\t@if (priority()) {\n\t\t\t<link\n\t\t\t\trel=\"preload\"\n\t\t\t\tas=\"image\"\n\t\t\t\t[attr.href]=\"resolvedSrc()\"\n\t\t\t\t[attr.imagesrcset]=\"srcSet()\"\n\t\t\t\t[attr.imagesizes]=\"resolvedSizes()\"\n\t\t\t\t[attr.crossorigin]=\"crossOrigin()\"\n\t\t\t/>\n\t\t}\n\t\t@if (fill()) {\n\t\t\t<span style=\"position:relative;overflow:hidden;display:block;width:100%;height:100%\">\n\t\t\t\t<img\n\t\t\t\t\t[alt]=\"alt()\"\n\t\t\t\t\t[src]=\"resolvedSrc()\"\n\t\t\t\t\t[srcset]=\"srcSet()\"\n\t\t\t\t\t[sizes]=\"resolvedSizes()\"\n\t\t\t\t\t[loading]=\"resolvedLoading()\"\n\t\t\t\t\t[class]=\"className()\"\n\t\t\t\t\t[ngStyle]=\"imgStyle()\"\n\t\t\t\t\t[crossOrigin]=\"crossOrigin()\"\n\t\t\t\t\t[referrerPolicy]=\"referrerPolicy()\"\n\t\t\t\t\t[attr.fetchpriority]=\"resolvedFetchPriority()\"\n\t\t\t\t\tdecoding=\"async\"\n\t\t\t\t\t(load)=\"handleLoad($event)\"\n\t\t\t\t\t(error)=\"handleError($event)\"\n\t\t\t\t/>\n\t\t\t</span>\n\t\t} @else {\n\t\t\t<img\n\t\t\t\t[alt]=\"alt()\"\n\t\t\t\t[src]=\"resolvedSrc()\"\n\t\t\t\t[srcset]=\"srcSet()\"\n\t\t\t\t[sizes]=\"resolvedSizes()\"\n\t\t\t\t[width]=\"width()\"\n\t\t\t\t[height]=\"height()\"\n\t\t\t\t[loading]=\"resolvedLoading()\"\n\t\t\t\t[class]=\"className()\"\n\t\t\t\t[ngStyle]=\"imgStyle()\"\n\t\t\t\t[crossOrigin]=\"crossOrigin()\"\n\t\t\t\t[referrerPolicy]=\"referrerPolicy()\"\n\t\t\t\t[attr.fetchpriority]=\"resolvedFetchPriority()\"\n\t\t\t\tdecoding=\"async\"\n\t\t\t\t(load)=\"handleLoad($event)\"\n\t\t\t\t(error)=\"handleError($event)\"\n\t\t\t/>\n\t\t}\n\t`\n})\nexport class ImageComponent {\n\t// ── Inputs ──────────────────────────────────────────────────\n\treadonly alt = input.required<string>();\n\treadonly blurDataURL = input<string>();\n\treadonly className = input<string>();\n\treadonly crossOrigin = input<'anonymous' | 'use-credentials' | ''>();\n\treadonly fetchPriority = input<'high' | 'low' | 'auto'>();\n\treadonly fill = input(false);\n\treadonly height = input<number>();\n\treadonly loader = input<ImageLoader>();\n\treadonly loading = input<'lazy' | 'eager'>('lazy');\n\treadonly onError = input<((event: Event) => void)>();\n\treadonly onLoad = input<((event: Event) => void)>();\n\treadonly overrideSrc = input<string>();\n\treadonly placeholder = input<'blur' | 'empty' | string>('empty');\n\treadonly priority = input(false);\n\treadonly quality = input(DEFAULT_QUALITY);\n\treadonly referrerPolicy = input<string>();\n\treadonly sizes = input<string>();\n\treadonly src = input.required<string>();\n\treadonly style = input<Record<string, string | number>>();\n\treadonly unoptimized = input(false);\n\treadonly width = input<number>();\n\n\t// ── Internal state ──────────────────────────────────────────\n\tprivate readonly blurRemoved = signal(false);\n\n\t// ── Computed ────────────────────────────────────────────────\n\treadonly resolvedSrc = computed(() => {\n\t\tconst override = this.overrideSrc();\n\n\t\tif (override) return override;\n\n\t\tif (this.unoptimized()) return this.src();\n\n\t\tconst loaderFn = this.loader();\n\n\t\tif (loaderFn) return loaderFn({ quality: this.quality(), src: this.src(), width: this.width() ?? 0 });\n\n\t\tconst currentWidth = this.width();\n\n\t\tif (!currentWidth) return buildOptimizedUrl(this.src(), 0, this.quality());\n\n\t\treturn buildOptimizedUrl(this.src(), currentWidth, this.quality());\n\t});\n\n\treadonly srcSet = computed(() =>\n\t\tthis.unoptimized()\n\t\t\t? undefined\n\t\t\t: generateSrcSet(this.src(), this.width(), this.sizes(), undefined, this.loader() ?? undefined)\n\t);\n\n\treadonly resolvedSizes = computed(() =>\n\t\tthis.sizes() ?? (this.fill() ? '100vw' : undefined)\n\t);\n\n\treadonly resolvedLoading = computed(() =>\n\t\tthis.priority() ? 'eager' as const : this.loading()\n\t);\n\n\treadonly resolvedFetchPriority = computed(() =>\n\t\tthis.priority() ? 'high' : this.fetchPriority()\n\t);\n\n\treadonly imgStyle = computed(() => {\n\t\tconst base: Record<string, string | number> = {\n\t\t\t...(this.style() ?? {}),\n\t\t\tcolor: 'transparent'\n\t\t};\n\n\t\tconst hasBlur =\n\t\t\t!this.blurRemoved() &&\n\t\t\t(this.placeholder() === 'blur' ||\n\t\t\t\t(typeof this.placeholder() === 'string' &&\n\t\t\t\t\tthis.placeholder() !== 'empty' &&\n\t\t\t\t\t(this.placeholder() ?? '').startsWith('data:')));\n\n\t\tconst blurValue = hasBlur\n\t\t\t? resolveBlurBg(this.placeholder(), this.blurDataURL())\n\t\t\t: undefined;\n\n\t\tif (blurValue) {\n\t\t\tbase['background-image'] = blurValue;\n\t\t\tbase['background-position'] = 'center';\n\t\t\tbase['background-repeat'] = 'no-repeat';\n\t\t\tbase['background-size'] = 'cover';\n\t\t}\n\n\t\tif (this.fill()) {\n\t\t\tbase.height = '100%';\n\t\t\tbase.inset = '0';\n\t\t\tbase['object-fit'] = 'cover';\n\t\t\tbase.position = 'absolute';\n\t\t\tbase.width = '100%';\n\t\t}\n\n\t\treturn base;\n\t});\n\n\t// ── Event handlers ──────────────────────────────────────────\n\thandleLoad(event: Event) {\n\t\tthis.blurRemoved.set(true);\n\n\t\tconst callback = this.onLoad();\n\n\t\tif (callback) callback(event);\n\t}\n\n\thandleError(event: Event) {\n\t\tconst callback = this.onError();\n\n\t\tif (callback) callback(event);\n\t}\n}\n"
7
+ ],
8
+ "mappings": "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",
9
+ "debugId": "C6CC0570D6433A0964756E2164756E21",
10
+ "names": []
11
+ }
@@ -61,6 +61,16 @@ var __export = (target, all) => {
61
61
  set: __exportSetter.bind(all, name)
62
62
  });
63
63
  };
64
+ var __legacyDecorateClassTS = function(decorators, target, key, desc) {
65
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
66
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
67
+ r = Reflect.decorate(decorators, target, key, desc);
68
+ else
69
+ for (var i = decorators.length - 1;i >= 0; i--)
70
+ if (d = decorators[i])
71
+ r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
72
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
73
+ };
64
74
  var __esm = (fn, res) => () => (fn && (res = fn(fn = 0)), res);
65
75
  var __require = import.meta.require;
66
76
 
@@ -29780,5 +29790,5 @@ export {
29780
29790
  getCachedRouteData
29781
29791
  };
29782
29792
 
29783
- //# debugId=62DEDC3E1216076E64756E2164756E21
29793
+ //# debugId=983B37D48C63A80A64756E2164756E21
29784
29794
  //# sourceMappingURL=index.js.map