@ethlete/cdk 4.36.0 → 4.37.0

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/CHANGELOG.md CHANGED
@@ -1,5 +1,17 @@
1
1
  # @ethlete/cdk
2
2
 
3
+ ## 4.37.0
4
+
5
+ ### Minor Changes
6
+
7
+ - [`b7256d2`](https://github.com/ethlete-io/ethdk/commit/b7256d2c48a665a63163ac6e17e1256e9c37e482) Thanks [@TomTomB](https://github.com/TomTomB)! - Add a sizes property to the PictureSource type for providing source based size options. The sizes input still exists & will be used as a fallback if the source does not provide a sizes property.
8
+
9
+ - [`b7256d2`](https://github.com/ethlete-io/ethdk/commit/b7256d2c48a665a63163ac6e17e1256e9c37e482) Thanks [@TomTomB](https://github.com/TomTomB)! - Add support for the media attribute in picture sources for selecting the picture source to use based on media queries
10
+
11
+ ### Patch Changes
12
+
13
+ - [`b7256d2`](https://github.com/ethlete-io/ethdk/commit/b7256d2c48a665a63163ac6e17e1256e9c37e482) Thanks [@TomTomB](https://github.com/TomTomB)! - Log an error to the console if the mime type of an image could not get inferred
14
+
3
15
  ## 4.36.0
4
16
 
5
17
  ### Minor Changes
@@ -45,12 +45,12 @@ export class PictureComponent {
45
45
  };
46
46
  }
47
47
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: PictureComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
48
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: PictureComponent, isStandalone: true, selector: "et-picture", inputs: { sources: { classPropertyName: "sources", publicName: "sources", isSignal: true, isRequired: false, transformFunction: null }, hasPriority: { classPropertyName: "hasPriority", publicName: "hasPriority", isSignal: true, isRequired: false, transformFunction: null }, imgClass: { classPropertyName: "imgClass", publicName: "imgClass", isSignal: true, isRequired: false, transformFunction: null }, figureClass: { classPropertyName: "figureClass", publicName: "figureClass", isSignal: true, isRequired: false, transformFunction: null }, figcaptionClass: { classPropertyName: "figcaptionClass", publicName: "figcaptionClass", isSignal: true, isRequired: false, transformFunction: null }, pictureClass: { classPropertyName: "pictureClass", publicName: "pictureClass", isSignal: true, isRequired: false, transformFunction: null }, defaultSrc: { classPropertyName: "defaultSrc", publicName: "defaultSrc", isSignal: true, isRequired: false, transformFunction: null }, alt: { classPropertyName: "alt", publicName: "alt", isSignal: true, isRequired: false, transformFunction: null }, figcaption: { classPropertyName: "figcaption", publicName: "figcaption", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null }, sizes: { classPropertyName: "sizes", publicName: "sizes", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { imgLoaded: "imgLoaded", imgError: "imgError" }, host: { classAttribute: "et-picture" }, viewQueries: [{ propertyName: "img", first: true, predicate: ["img"], descendants: true, isSignal: true }], ngImport: i0, template: "<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n @for (source of sourcesWithConfig(); track source.srcset) {\n <source [type]=\"source.type\" [attr.srcset]=\"source.srcset\" [attr.sizes]=\"sizes()\" />\n }\n\n @if (defaultSourceWithConfig(); as source) {\n <img\n #img\n [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n [ngClass]=\"imgClass()\"\n [attr.srcset]=\"source.srcset\"\n [attr.type]=\"source.type\"\n [attr.alt]=\"alt()\"\n [attr.width]=\"width()\"\n [attr.height]=\"height()\"\n [attr.sizes]=\"sizes()\"\n class=\"et-picture-img\"\n />\n }\n </picture>\n\n @if (figcaption()) {\n <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n {{ figcaption() }}\n </figcaption>\n }\n</figure>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
48
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: PictureComponent, isStandalone: true, selector: "et-picture", inputs: { sources: { classPropertyName: "sources", publicName: "sources", isSignal: true, isRequired: false, transformFunction: null }, hasPriority: { classPropertyName: "hasPriority", publicName: "hasPriority", isSignal: true, isRequired: false, transformFunction: null }, imgClass: { classPropertyName: "imgClass", publicName: "imgClass", isSignal: true, isRequired: false, transformFunction: null }, figureClass: { classPropertyName: "figureClass", publicName: "figureClass", isSignal: true, isRequired: false, transformFunction: null }, figcaptionClass: { classPropertyName: "figcaptionClass", publicName: "figcaptionClass", isSignal: true, isRequired: false, transformFunction: null }, pictureClass: { classPropertyName: "pictureClass", publicName: "pictureClass", isSignal: true, isRequired: false, transformFunction: null }, defaultSrc: { classPropertyName: "defaultSrc", publicName: "defaultSrc", isSignal: true, isRequired: false, transformFunction: null }, alt: { classPropertyName: "alt", publicName: "alt", isSignal: true, isRequired: false, transformFunction: null }, figcaption: { classPropertyName: "figcaption", publicName: "figcaption", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null }, sizes: { classPropertyName: "sizes", publicName: "sizes", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { imgLoaded: "imgLoaded", imgError: "imgError" }, host: { classAttribute: "et-picture" }, viewQueries: [{ propertyName: "img", first: true, predicate: ["img"], descendants: true, isSignal: true }], ngImport: i0, template: "<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n @for (source of sourcesWithConfig(); track source.srcset) {\n <source\n [type]=\"source.type\"\n [attr.srcset]=\"source.srcset\"\n [attr.sizes]=\"(source.sizes ?? sizes()) || null\"\n [attr.media]=\"source.media || null\"\n />\n }\n\n @if (defaultSourceWithConfig(); as source) {\n <img\n #img\n [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n [ngClass]=\"imgClass()\"\n [attr.srcset]=\"source.srcset\"\n [attr.type]=\"source.type\"\n [attr.alt]=\"alt()\"\n [attr.width]=\"width()\"\n [attr.height]=\"height()\"\n [attr.sizes]=\"sizes()\"\n class=\"et-picture-img\"\n />\n }\n </picture>\n\n @if (figcaption()) {\n <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n {{ figcaption() }}\n </figcaption>\n }\n</figure>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
49
49
  }
50
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: PictureComponent, decorators: [{
51
51
  type: Component,
52
52
  args: [{ selector: 'et-picture', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgClass], host: {
53
53
  class: 'et-picture',
54
- }, template: "<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n @for (source of sourcesWithConfig(); track source.srcset) {\n <source [type]=\"source.type\" [attr.srcset]=\"source.srcset\" [attr.sizes]=\"sizes()\" />\n }\n\n @if (defaultSourceWithConfig(); as source) {\n <img\n #img\n [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n [ngClass]=\"imgClass()\"\n [attr.srcset]=\"source.srcset\"\n [attr.type]=\"source.type\"\n [attr.alt]=\"alt()\"\n [attr.width]=\"width()\"\n [attr.height]=\"height()\"\n [attr.sizes]=\"sizes()\"\n class=\"et-picture-img\"\n />\n }\n </picture>\n\n @if (figcaption()) {\n <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n {{ figcaption() }}\n </figcaption>\n }\n</figure>\n" }]
54
+ }, template: "<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n @for (source of sourcesWithConfig(); track source.srcset) {\n <source\n [type]=\"source.type\"\n [attr.srcset]=\"source.srcset\"\n [attr.sizes]=\"(source.sizes ?? sizes()) || null\"\n [attr.media]=\"source.media || null\"\n />\n }\n\n @if (defaultSourceWithConfig(); as source) {\n <img\n #img\n [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n [ngClass]=\"imgClass()\"\n [attr.srcset]=\"source.srcset\"\n [attr.type]=\"source.type\"\n [attr.alt]=\"alt()\"\n [attr.width]=\"width()\"\n [attr.height]=\"height()\"\n [attr.sizes]=\"sizes()\"\n class=\"et-picture-img\"\n />\n }\n </picture>\n\n @if (figcaption()) {\n <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n {{ figcaption() }}\n </figcaption>\n }\n</figure>\n" }]
55
55
  }] });
56
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picture.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/picture/components/picture/picture.component.ts","../../../../../../../../../libs/cdk/src/lib/components/picture/components/picture/picture.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  ViewEncapsulation,\n  booleanAttribute,\n  computed,\n  inject,\n  input,\n  numberAttribute,\n  viewChild,\n} from '@angular/core';\nimport { outputFromObservable, toObservable } from '@angular/core/rxjs-interop';\nimport { NgClassType } from '@ethlete/core';\nimport { fromEvent, map, of, switchMap } from 'rxjs';\nimport { PictureSource } from '../../types/picture.types';\nimport { IMAGE_CONFIG_TOKEN, normalizePictureSizes, normalizePictureSource } from '../../utils/picture.utils';\n\n@Component({\n  selector: 'et-picture',\n  templateUrl: './picture.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [NgClass],\n  host: {\n    class: 'et-picture',\n  },\n})\nexport class PictureComponent {\n  _config = inject(IMAGE_CONFIG_TOKEN, { optional: true });\n\n  sources = input<Array<PictureSource | string>>([]);\n  hasPriority = input(false, { transform: booleanAttribute });\n  imgClass = input<NgClassType>(null);\n  figureClass = input<NgClassType>(null);\n  figcaptionClass = input<NgClassType>(null);\n  pictureClass = input<NgClassType>(null);\n  defaultSrc = input<PictureSource | string | null>(null);\n  alt = input<string | null>(null);\n  figcaption = input<string | null>(null);\n  width = input(null, { transform: numberAttribute });\n  height = input(null, { transform: numberAttribute });\n  sizes = input<string | null, string[] | string | null>(null, {\n    transform: (v) => normalizePictureSizes(v),\n  });\n\n  img = viewChild<ElementRef<HTMLImageElement>>('img');\n  img$ = toObservable(this.img).pipe(map((ref) => ref?.nativeElement ?? null));\n\n  imgLoaded = outputFromObservable(\n    this.img$.pipe(switchMap((img) => (img ? fromEvent(img, 'load').pipe(map(() => true)) : of(false)))),\n  );\n  imgError = outputFromObservable(\n    this.img$.pipe(switchMap((img) => (img ? fromEvent(img, 'error').pipe(map(() => true)) : of(false)))),\n  );\n\n  sourcesWithConfig = computed(() => {\n    const sources = this.sources();\n\n    return sources.map((source) => this._combineWithConfig(normalizePictureSource(source)));\n  });\n\n  defaultSourceWithConfig = computed(() => {\n    const defaultSrc = this.defaultSrc();\n    return defaultSrc ? this._combineWithConfig(normalizePictureSource(defaultSrc)) : null;\n  });\n\n  _combineWithConfig(src: PictureSource) {\n    if (!this._config?.baseUrl || src.srcset.startsWith('http')) {\n      return src;\n    }\n\n    const shouldAppendSlash = !this._config.baseUrl.endsWith('/') && !src.srcset.startsWith('/');\n\n    return {\n      ...src,\n      srcset: `${this._config.baseUrl}${shouldAppendSlash ? '/' : ''}${src.srcset}`,\n    };\n  }\n}\n","<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n  <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n    @for (source of sourcesWithConfig(); track source.srcset) {\n      <source [type]=\"source.type\" [attr.srcset]=\"source.srcset\" [attr.sizes]=\"sizes()\" />\n    }\n\n    @if (defaultSourceWithConfig(); as source) {\n      <img\n        #img\n        [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n        [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n        [ngClass]=\"imgClass()\"\n        [attr.srcset]=\"source.srcset\"\n        [attr.type]=\"source.type\"\n        [attr.alt]=\"alt()\"\n        [attr.width]=\"width()\"\n        [attr.height]=\"height()\"\n        [attr.sizes]=\"sizes()\"\n        class=\"et-picture-img\"\n      />\n    }\n  </picture>\n\n  @if (figcaption()) {\n    <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n      {{ figcaption() }}\n    </figcaption>\n  }\n</figure>\n"]}
56
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picture.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/picture/components/picture/picture.component.ts","../../../../../../../../../libs/cdk/src/lib/components/picture/components/picture/picture.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EACL,uBAAuB,EACvB,SAAS,EAET,iBAAiB,EACjB,gBAAgB,EAChB,QAAQ,EACR,MAAM,EACN,KAAK,EACL,eAAe,EACf,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAEhF,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAErD,OAAO,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;;AAa9G,MAAM,OAAO,gBAAgB;IAX7B;QAYE,YAAO,GAAG,MAAM,CAAC,kBAAkB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAEzD,YAAO,GAAG,KAAK,CAAgC,EAAE,CAAC,CAAC;QACnD,gBAAW,GAAG,KAAK,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC,CAAC;QAC5D,aAAQ,GAAG,KAAK,CAAc,IAAI,CAAC,CAAC;QACpC,gBAAW,GAAG,KAAK,CAAc,IAAI,CAAC,CAAC;QACvC,oBAAe,GAAG,KAAK,CAAc,IAAI,CAAC,CAAC;QAC3C,iBAAY,GAAG,KAAK,CAAc,IAAI,CAAC,CAAC;QACxC,eAAU,GAAG,KAAK,CAAgC,IAAI,CAAC,CAAC;QACxD,QAAG,GAAG,KAAK,CAAgB,IAAI,CAAC,CAAC;QACjC,eAAU,GAAG,KAAK,CAAgB,IAAI,CAAC,CAAC;QACxC,UAAK,GAAG,KAAK,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC,CAAC;QACpD,WAAM,GAAG,KAAK,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC,CAAC;QACrD,UAAK,GAAG,KAAK,CAA0C,IAAI,EAAE;YAC3D,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC;SAC3C,CAAC,CAAC;QAEH,QAAG,GAAG,SAAS,CAA+B,KAAK,CAAC,CAAC;QACrD,SAAI,GAAG,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,EAAE,aAAa,IAAI,IAAI,CAAC,CAAC,CAAC;QAE7E,cAAS,GAAG,oBAAoB,CAC9B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CACrG,CAAC;QACF,aAAQ,GAAG,oBAAoB,CAC7B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CACtG,CAAC;QAEF,sBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE;YAChC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAE/B,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAC1F,CAAC,CAAC,CAAC;QAEH,4BAAuB,GAAG,QAAQ,CAAC,GAAG,EAAE;YACtC,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YACrC,OAAO,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACzF,CAAC,CAAC,CAAC;KAcJ;IAZC,kBAAkB,CAAC,GAAkB;QACnC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,IAAI,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YAC5D,OAAO,GAAG,CAAC;QACb,CAAC;QAED,MAAM,iBAAiB,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QAE7F,OAAO;YACL,GAAG,GAAG;YACN,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,iBAAiB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,MAAM,EAAE;SAC9E,CAAC;IACJ,CAAC;8GAlDU,gBAAgB;kGAAhB,gBAAgB,k0DC9B7B,6kCAkCA,4CDTY,OAAO;;2FAKN,gBAAgB;kBAX5B,SAAS;+BACE,YAAY,iBAEP,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,OAAO,CAAC,QACZ;wBACJ,KAAK,EAAE,YAAY;qBACpB","sourcesContent":["import { NgClass } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  ViewEncapsulation,\n  booleanAttribute,\n  computed,\n  inject,\n  input,\n  numberAttribute,\n  viewChild,\n} from '@angular/core';\nimport { outputFromObservable, toObservable } from '@angular/core/rxjs-interop';\nimport { NgClassType } from '@ethlete/core';\nimport { fromEvent, map, of, switchMap } from 'rxjs';\nimport { PictureSource } from '../../types/picture.types';\nimport { IMAGE_CONFIG_TOKEN, normalizePictureSizes, normalizePictureSource } from '../../utils/picture.utils';\n\n@Component({\n  selector: 'et-picture',\n  templateUrl: './picture.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [NgClass],\n  host: {\n    class: 'et-picture',\n  },\n})\nexport class PictureComponent {\n  _config = inject(IMAGE_CONFIG_TOKEN, { optional: true });\n\n  sources = input<Array<PictureSource | string>>([]);\n  hasPriority = input(false, { transform: booleanAttribute });\n  imgClass = input<NgClassType>(null);\n  figureClass = input<NgClassType>(null);\n  figcaptionClass = input<NgClassType>(null);\n  pictureClass = input<NgClassType>(null);\n  defaultSrc = input<PictureSource | string | null>(null);\n  alt = input<string | null>(null);\n  figcaption = input<string | null>(null);\n  width = input(null, { transform: numberAttribute });\n  height = input(null, { transform: numberAttribute });\n  sizes = input<string | null, string[] | string | null>(null, {\n    transform: (v) => normalizePictureSizes(v),\n  });\n\n  img = viewChild<ElementRef<HTMLImageElement>>('img');\n  img$ = toObservable(this.img).pipe(map((ref) => ref?.nativeElement ?? null));\n\n  imgLoaded = outputFromObservable(\n    this.img$.pipe(switchMap((img) => (img ? fromEvent(img, 'load').pipe(map(() => true)) : of(false)))),\n  );\n  imgError = outputFromObservable(\n    this.img$.pipe(switchMap((img) => (img ? fromEvent(img, 'error').pipe(map(() => true)) : of(false)))),\n  );\n\n  sourcesWithConfig = computed(() => {\n    const sources = this.sources();\n\n    return sources.map((source) => this._combineWithConfig(normalizePictureSource(source)));\n  });\n\n  defaultSourceWithConfig = computed(() => {\n    const defaultSrc = this.defaultSrc();\n    return defaultSrc ? this._combineWithConfig(normalizePictureSource(defaultSrc)) : null;\n  });\n\n  _combineWithConfig(src: PictureSource) {\n    if (!this._config?.baseUrl || src.srcset.startsWith('http')) {\n      return src;\n    }\n\n    const shouldAppendSlash = !this._config.baseUrl.endsWith('/') && !src.srcset.startsWith('/');\n\n    return {\n      ...src,\n      srcset: `${this._config.baseUrl}${shouldAppendSlash ? '/' : ''}${src.srcset}`,\n    };\n  }\n}\n","<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n  <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n    @for (source of sourcesWithConfig(); track source.srcset) {\n      <source\n        [type]=\"source.type\"\n        [attr.srcset]=\"source.srcset\"\n        [attr.sizes]=\"(source.sizes ?? sizes()) || null\"\n        [attr.media]=\"source.media || null\"\n      />\n    }\n\n    @if (defaultSourceWithConfig(); as source) {\n      <img\n        #img\n        [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n        [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n        [ngClass]=\"imgClass()\"\n        [attr.srcset]=\"source.srcset\"\n        [attr.type]=\"source.type\"\n        [attr.alt]=\"alt()\"\n        [attr.width]=\"width()\"\n        [attr.height]=\"height()\"\n        [attr.sizes]=\"sizes()\"\n        class=\"et-picture-img\"\n      />\n    }\n  </picture>\n\n  @if (figcaption()) {\n    <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n      {{ figcaption() }}\n    </figcaption>\n  }\n</figure>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGljdHVyZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2RrL3NyYy9saWIvY29tcG9uZW50cy9waWN0dXJlL3R5cGVzL3BpY3R1cmUudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUGljdHVyZVNvdXJjZSB7XG4gIC8qKlxuICAgKiBUaGUgbWltZSB0eXBlIG9mIHRoZSBpbWFnZS5cbiAgICogQGV4YW1wbGUgYGltYWdlL2pwZWdgXG4gICAqL1xuICB0eXBlOiBzdHJpbmcgfCBudWxsO1xuXG4gIC8qKlxuICAgKiBUaGUgc291cmNlIHNldCBvZiB0aGUgaW1hZ2UuIENhbiBiZSBlaXRoZXIgYSBzaW5nbGUgVVJMIG9yIGEgY29tbWEtc2VwYXJhdGVkIGxpc3Qgb2YgVVJMcy5cbiAgICogQGV4YW1wbGUgYGh0dHBzOi8vZXhhbXBsZS5jb20vaW1hZ2UuanBnYFxuICAgKiBAZXhhbXBsZSBgaHR0cHM6Ly9leGFtcGxlLmNvbS9pbWFnZS5qcGcsIGh0dHBzOi8vZXhhbXBsZS5jb20vaW1hZ2VAMnguanBnYFxuICAgKi9cbiAgc3Jjc2V0OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGljdHVyZUNvbmZpZyB7XG4gIGJhc2VVcmw/OiBzdHJpbmc7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGljdHVyZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2RrL3NyYy9saWIvY29tcG9uZW50cy9waWN0dXJlL3R5cGVzL3BpY3R1cmUudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQSBzb3VyY2UgdG8gYmUgdXNlZCBpbiBhIHBpY3R1cmUgZWxlbWVudC5cbiAqIEBzZWUgaHR0cHM6Ly93d3cubWVkaWFldmVudC5kZS9odG1sL3BpY3R1cmUuaHRtbFxuICogQHNlZSBodHRwczovL3dlYi5kZXYvbGVhcm4vZGVzaWduL3Jlc3BvbnNpdmUtaW1hZ2VzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUGljdHVyZVNvdXJjZSB7XG4gIC8qKlxuICAgKiBUaGUgbWltZSB0eXBlIG9mIHRoZSBpbWFnZS5cbiAgICogSWYgbm90IHByb3ZpZGVkLCBpdCB3aWxsIGJlIGluZmVycmVkIGZyb20gdGhlIFVSTC5cbiAgICogSWYgaXQgY2Fubm90IGJlIGluZmVycmVkLCBpdCB3aWxsIGJlIGBudWxsYCBhbmQgYSBlcnJvciB3aWxsIGJlIGxvZ2dlZCB0byB0aGUgY29uc29sZSB3aXRob3V0IHRocm93aW5nLlxuICAgKiBAZXhhbXBsZSBgaW1hZ2UvanBlZ2BcbiAgICovXG4gIHR5cGU/OiBzdHJpbmcgfCBudWxsO1xuXG4gIC8qKlxuICAgKiBUaGUgc291cmNlIHNldCBvZiB0aGUgaW1hZ2UuIENhbiBiZSBlaXRoZXIgYSBzaW5nbGUgVVJMIG9yIGEgY29tbWEtc2VwYXJhdGVkIGxpc3Qgb2YgVVJMcy5cbiAgICogSWYgYSB3aWR0aCBkZXNjcmlwdG9yIGlzIHByb3ZpZGVkIChlZy4gMjAwdyksIHlvdSBtdXN0IGFsc28gc2V0IHRoZSBgc2l6ZXNgIHByb3BlcnR5LlxuICAgKiBJZiBhIGRlbnNpdHkgZGVzY3JpcHRvciBpcyBwcm92aWRlZCAoZWcuIDJ4KSwgdGhlIGJyb3dzZXIgd2lsbCBhdXRvbWF0aWNhbGx5IHNlbGVjdCB0aGUgY29ycmVjdCBpbWFnZSBiYXNlZCBvbiB0aGUgZGV2aWNlJ3MgcGl4ZWwgZGVuc2l0eS5cbiAgICpcbiAgICogKipOb3RlKio6IFlvdSBjYW4gcHJvdmlkZSBlaXRoZXIgYSB3aWR0aCBkZXNjcmlwdG9yIG9yIGEgZGVuc2l0eSBkZXNjcmlwdG9yLCBidXQgbm90IGJvdGguXG4gICAqIEBleGFtcGxlIGBodHRwczovL2V4YW1wbGUuY29tL2ltYWdlLmpwZ2BcbiAgICogQGV4YW1wbGUgYGh0dHBzOi8vZXhhbXBsZS5jb20vaW1hZ2UuanBnIDF4LCBodHRwczovL2V4YW1wbGUuY29tL2ltYWdlQDJ4LmpwZyAyeGBcbiAgICogQGV4YW1wbGUgYGh0dHBzOi8vZXhhbXBsZS5jb20vaW1hZ2UuanBnIDMwMHcsIGh0dHBzOi8vZXhhbXBsZS5jb20vaW1hZ2U2MDAuanBnIDYwMHdgXG4gICAqL1xuICBzcmNzZXQ6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHNpemVzIGF0dHJpYnV0ZSBvZiB0aGUgaW1hZ2UuXG4gICAqXG4gICAqICoqTm90ZSoqOiBPbmx5IHJlcXVpcmVkIGlmIHRoZSBgc3Jjc2V0YCBwcm9wZXJ0eSBjb250YWlucyB3aWR0aCBkZXNjcmlwdG9ycy5cbiAgICogQGV4YW1wbGUgYDEwMHZ3YCAvLyBUaGUgaW1hZ2Ugd2lsbCB0YWtlIHVwIHRoZSBmdWxsIHdpZHRoIG9mIHRoZSB2aWV3cG9ydFxuICAgKiBAZXhhbXBsZSBgKG1pbi13aWR0aDogODAwcHgpIDUwdncsIDEwMHZ3YCAvLyBUaGUgaW1hZ2Ugd2lsbCB0YWtlIHVwIDUwJSBvZiB0aGUgdmlld3BvcnQgd2lkdGggaWYgdGhlIHZpZXdwb3J0IGlzIGF0IGxlYXN0IDgwMHB4IHdpZGUsIG90aGVyd2lzZSBpdCB3aWxsIHRha2UgdXAgdGhlIGZ1bGwgd2lkdGhcbiAgICovXG4gIHNpemVzPzogc3RyaW5nIHwgbnVsbDtcblxuICAvKipcbiAgICogVGhlIG1lZGlhIHF1ZXJ5IHRvIHdoaWNoIHRoZSBzb3VyY2UgYXBwbGllcy5cbiAgICogSWYgdGhlIG1lZGlhIHF1ZXJ5IGFwcGxpZXMsIHRoZSBzb3VyY2Ugd2lsbCBiZSB1c2VkLlxuICAgKiBAZXhhbXBsZSBgKG1pbi13aWR0aDogODAwcHgpYCAvLyBPbmx5IGFwcGxpZXMgaWYgdGhlIHZpZXdwb3J0IGlzIGF0IGxlYXN0IDgwMHB4IHdpZGVcbiAgICogQGV4YW1wbGUgYChtaW4td2lkdGg6IDgwMHB4KSBhbmQgKG9yaWVudGF0aW9uOiBsYW5kc2NhcGUpIGFuZCAocHJlZmVycy1jb2xvci1zY2hlbWU6IGRhcmspYCAvLyBPbmx5IGFwcGxpZXMgaWYgdGhlIHZpZXdwb3J0IGlzIGF0IGxlYXN0IDgwMHB4IHdpZGUsIGlzIGluIGxhbmRzY2FwZSBvcmllbnRhdGlvbiBhbmQgcHJlZmVycyBkYXJrIGNvbG9yc1xuICAgKi9cbiAgbWVkaWE/OiBzdHJpbmcgfCBudWxsO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBpY3R1cmVDb25maWcge1xuICBiYXNlVXJsPzogc3RyaW5nO1xufVxuIl19
@@ -9,11 +9,14 @@ export const provideImageConfig = (config = {}) => {
9
9
  };
10
10
  export const normalizePictureSource = (source) => {
11
11
  if (typeof source === 'string') {
12
- return { type: inferMimeType(source), srcset: source };
12
+ return { type: inferMimeType(source), srcset: source, media: null, sizes: null };
13
13
  }
14
14
  else {
15
15
  const mimeType = source.type && source.type !== '' ? source.type : inferMimeType(source.srcset);
16
- return { type: mimeType, srcset: source.srcset };
16
+ if (!mimeType) {
17
+ console.error(`Could not infer mime type for srcset: ${source.srcset}. Please provide a type.`);
18
+ }
19
+ return { type: mimeType, srcset: source.srcset, media: source.media, sizes: source.sizes };
17
20
  }
18
21
  };
19
22
  export const normalizePictureSizes = (sizes) => {
@@ -25,4 +28,4 @@ export const normalizePictureSizes = (sizes) => {
25
28
  }
26
29
  return sizes;
27
30
  };
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGljdHVyZS51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2RrL3NyYy9saWIvY29tcG9uZW50cy9waWN0dXJlL3V0aWxzL3BpY3R1cmUudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzlDLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksY0FBYyxDQUFnQixvQkFBb0IsQ0FBQyxDQUFDO0FBRTFGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLENBQUMsU0FBb0QsRUFBRSxFQUFFLEVBQUU7SUFDM0YsT0FBTztRQUNMLE9BQU8sRUFBRSxrQkFBa0I7UUFDM0IsUUFBUSxFQUFFLE1BQU07S0FDakIsQ0FBQztBQUNKLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLENBQUMsTUFBOEIsRUFBRSxFQUFFO0lBQ3ZFLElBQUksT0FBTyxNQUFNLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDL0IsT0FBTyxFQUFFLElBQUksRUFBRSxhQUFhLENBQUMsTUFBTSxDQUFDLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBbUIsQ0FBQztJQUMxRSxDQUFDO1NBQU0sQ0FBQztRQUNOLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxJQUFJLElBQUksTUFBTSxDQUFDLElBQUksS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDaEcsT0FBTyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBQyxNQUFNLEVBQW1CLENBQUM7SUFDcEUsQ0FBQztBQUNILENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLENBQUMsS0FBK0IsRUFBRSxFQUFFO0lBQ3ZFLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNYLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ3pCLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBRUQsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgaW5mZXJNaW1lVHlwZSB9IGZyb20gJ0BldGhsZXRlL2NvcmUnO1xuaW1wb3J0IHsgUGljdHVyZUNvbmZpZywgUGljdHVyZVNvdXJjZSB9IGZyb20gJy4uL3R5cGVzL3BpY3R1cmUudHlwZXMnO1xuXG5leHBvcnQgY29uc3QgSU1BR0VfQ09ORklHX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuPFBpY3R1cmVDb25maWc+KCdJTUFHRV9DT05GSUdfVE9LRU4nKTtcblxuZXhwb3J0IGNvbnN0IHByb3ZpZGVJbWFnZUNvbmZpZyA9IChjb25maWc6IFBhcnRpYWw8UGljdHVyZUNvbmZpZz4gfCBudWxsIHwgdW5kZWZpbmVkID0ge30pID0+IHtcbiAgcmV0dXJuIHtcbiAgICBwcm92aWRlOiBJTUFHRV9DT05GSUdfVE9LRU4sXG4gICAgdXNlVmFsdWU6IGNvbmZpZyxcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBub3JtYWxpemVQaWN0dXJlU291cmNlID0gKHNvdXJjZTogc3RyaW5nIHwgUGljdHVyZVNvdXJjZSkgPT4ge1xuICBpZiAodHlwZW9mIHNvdXJjZSA9PT0gJ3N0cmluZycpIHtcbiAgICByZXR1cm4geyB0eXBlOiBpbmZlck1pbWVUeXBlKHNvdXJjZSksIHNyY3NldDogc291cmNlIH0gYXMgUGljdHVyZVNvdXJjZTtcbiAgfSBlbHNlIHtcbiAgICBjb25zdCBtaW1lVHlwZSA9IHNvdXJjZS50eXBlICYmIHNvdXJjZS50eXBlICE9PSAnJyA/IHNvdXJjZS50eXBlIDogaW5mZXJNaW1lVHlwZShzb3VyY2Uuc3Jjc2V0KTtcbiAgICByZXR1cm4geyB0eXBlOiBtaW1lVHlwZSwgc3Jjc2V0OiBzb3VyY2Uuc3Jjc2V0IH0gYXMgUGljdHVyZVNvdXJjZTtcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IG5vcm1hbGl6ZVBpY3R1cmVTaXplcyA9IChzaXplczogc3RyaW5nIHwgc3RyaW5nW10gfCBudWxsKSA9PiB7XG4gIGlmICghc2l6ZXMpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGlmIChBcnJheS5pc0FycmF5KHNpemVzKSkge1xuICAgIHJldHVybiBzaXplcy5qb2luKCcsICcpO1xuICB9XG5cbiAgcmV0dXJuIHNpemVzO1xufTtcbiJdfQ==
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGljdHVyZS51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2RrL3NyYy9saWIvY29tcG9uZW50cy9waWN0dXJlL3V0aWxzL3BpY3R1cmUudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzlDLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksY0FBYyxDQUFnQixvQkFBb0IsQ0FBQyxDQUFDO0FBRTFGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLENBQUMsU0FBb0QsRUFBRSxFQUFFLEVBQUU7SUFDM0YsT0FBTztRQUNMLE9BQU8sRUFBRSxrQkFBa0I7UUFDM0IsUUFBUSxFQUFFLE1BQU07S0FDakIsQ0FBQztBQUNKLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLENBQUMsTUFBOEIsRUFBRSxFQUFFO0lBQ3ZFLElBQUksT0FBTyxNQUFNLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDL0IsT0FBTyxFQUFFLElBQUksRUFBRSxhQUFhLENBQUMsTUFBTSxDQUFDLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQW1CLENBQUM7SUFDcEcsQ0FBQztTQUFNLENBQUM7UUFDTixNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsSUFBSSxJQUFJLE1BQU0sQ0FBQyxJQUFJLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRWhHLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNkLE9BQU8sQ0FBQyxLQUFLLENBQUMseUNBQXlDLE1BQU0sQ0FBQyxNQUFNLDBCQUEwQixDQUFDLENBQUM7UUFDbEcsQ0FBQztRQUVELE9BQU8sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxFQUFtQixDQUFDO0lBQzlHLENBQUM7QUFDSCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxDQUFDLEtBQStCLEVBQUUsRUFBRTtJQUN2RSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDWCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUN6QixPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVELE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGluZmVyTWltZVR5cGUgfSBmcm9tICdAZXRobGV0ZS9jb3JlJztcbmltcG9ydCB7IFBpY3R1cmVDb25maWcsIFBpY3R1cmVTb3VyY2UgfSBmcm9tICcuLi90eXBlcy9waWN0dXJlLnR5cGVzJztcblxuZXhwb3J0IGNvbnN0IElNQUdFX0NPTkZJR19UT0tFTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxQaWN0dXJlQ29uZmlnPignSU1BR0VfQ09ORklHX1RPS0VOJyk7XG5cbmV4cG9ydCBjb25zdCBwcm92aWRlSW1hZ2VDb25maWcgPSAoY29uZmlnOiBQYXJ0aWFsPFBpY3R1cmVDb25maWc+IHwgbnVsbCB8IHVuZGVmaW5lZCA9IHt9KSA9PiB7XG4gIHJldHVybiB7XG4gICAgcHJvdmlkZTogSU1BR0VfQ09ORklHX1RPS0VOLFxuICAgIHVzZVZhbHVlOiBjb25maWcsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3Qgbm9ybWFsaXplUGljdHVyZVNvdXJjZSA9IChzb3VyY2U6IHN0cmluZyB8IFBpY3R1cmVTb3VyY2UpID0+IHtcbiAgaWYgKHR5cGVvZiBzb3VyY2UgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIHsgdHlwZTogaW5mZXJNaW1lVHlwZShzb3VyY2UpLCBzcmNzZXQ6IHNvdXJjZSwgbWVkaWE6IG51bGwsIHNpemVzOiBudWxsIH0gYXMgUGljdHVyZVNvdXJjZTtcbiAgfSBlbHNlIHtcbiAgICBjb25zdCBtaW1lVHlwZSA9IHNvdXJjZS50eXBlICYmIHNvdXJjZS50eXBlICE9PSAnJyA/IHNvdXJjZS50eXBlIDogaW5mZXJNaW1lVHlwZShzb3VyY2Uuc3Jjc2V0KTtcblxuICAgIGlmICghbWltZVR5cGUpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoYENvdWxkIG5vdCBpbmZlciBtaW1lIHR5cGUgZm9yIHNyY3NldDogJHtzb3VyY2Uuc3Jjc2V0fS4gUGxlYXNlIHByb3ZpZGUgYSB0eXBlLmApO1xuICAgIH1cblxuICAgIHJldHVybiB7IHR5cGU6IG1pbWVUeXBlLCBzcmNzZXQ6IHNvdXJjZS5zcmNzZXQsIG1lZGlhOiBzb3VyY2UubWVkaWEsIHNpemVzOiBzb3VyY2Uuc2l6ZXMgfSBhcyBQaWN0dXJlU291cmNlO1xuICB9XG59O1xuXG5leHBvcnQgY29uc3Qgbm9ybWFsaXplUGljdHVyZVNpemVzID0gKHNpemVzOiBzdHJpbmcgfCBzdHJpbmdbXSB8IG51bGwpID0+IHtcbiAgaWYgKCFzaXplcykge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkoc2l6ZXMpKSB7XG4gICAgcmV0dXJuIHNpemVzLmpvaW4oJywgJyk7XG4gIH1cblxuICByZXR1cm4gc2l6ZXM7XG59O1xuIl19
@@ -14817,11 +14817,14 @@ const provideImageConfig = (config = {}) => {
14817
14817
  };
14818
14818
  const normalizePictureSource = (source) => {
14819
14819
  if (typeof source === 'string') {
14820
- return { type: inferMimeType(source), srcset: source };
14820
+ return { type: inferMimeType(source), srcset: source, media: null, sizes: null };
14821
14821
  }
14822
14822
  else {
14823
14823
  const mimeType = source.type && source.type !== '' ? source.type : inferMimeType(source.srcset);
14824
- return { type: mimeType, srcset: source.srcset };
14824
+ if (!mimeType) {
14825
+ console.error(`Could not infer mime type for srcset: ${source.srcset}. Please provide a type.`);
14826
+ }
14827
+ return { type: mimeType, srcset: source.srcset, media: source.media, sizes: source.sizes };
14825
14828
  }
14826
14829
  };
14827
14830
  const normalizePictureSizes = (sizes) => {
@@ -14875,13 +14878,13 @@ class PictureComponent {
14875
14878
  };
14876
14879
  }
14877
14880
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: PictureComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14878
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: PictureComponent, isStandalone: true, selector: "et-picture", inputs: { sources: { classPropertyName: "sources", publicName: "sources", isSignal: true, isRequired: false, transformFunction: null }, hasPriority: { classPropertyName: "hasPriority", publicName: "hasPriority", isSignal: true, isRequired: false, transformFunction: null }, imgClass: { classPropertyName: "imgClass", publicName: "imgClass", isSignal: true, isRequired: false, transformFunction: null }, figureClass: { classPropertyName: "figureClass", publicName: "figureClass", isSignal: true, isRequired: false, transformFunction: null }, figcaptionClass: { classPropertyName: "figcaptionClass", publicName: "figcaptionClass", isSignal: true, isRequired: false, transformFunction: null }, pictureClass: { classPropertyName: "pictureClass", publicName: "pictureClass", isSignal: true, isRequired: false, transformFunction: null }, defaultSrc: { classPropertyName: "defaultSrc", publicName: "defaultSrc", isSignal: true, isRequired: false, transformFunction: null }, alt: { classPropertyName: "alt", publicName: "alt", isSignal: true, isRequired: false, transformFunction: null }, figcaption: { classPropertyName: "figcaption", publicName: "figcaption", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null }, sizes: { classPropertyName: "sizes", publicName: "sizes", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { imgLoaded: "imgLoaded", imgError: "imgError" }, host: { classAttribute: "et-picture" }, viewQueries: [{ propertyName: "img", first: true, predicate: ["img"], descendants: true, isSignal: true }], ngImport: i0, template: "<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n @for (source of sourcesWithConfig(); track source.srcset) {\n <source [type]=\"source.type\" [attr.srcset]=\"source.srcset\" [attr.sizes]=\"sizes()\" />\n }\n\n @if (defaultSourceWithConfig(); as source) {\n <img\n #img\n [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n [ngClass]=\"imgClass()\"\n [attr.srcset]=\"source.srcset\"\n [attr.type]=\"source.type\"\n [attr.alt]=\"alt()\"\n [attr.width]=\"width()\"\n [attr.height]=\"height()\"\n [attr.sizes]=\"sizes()\"\n class=\"et-picture-img\"\n />\n }\n </picture>\n\n @if (figcaption()) {\n <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n {{ figcaption() }}\n </figcaption>\n }\n</figure>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
14881
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: PictureComponent, isStandalone: true, selector: "et-picture", inputs: { sources: { classPropertyName: "sources", publicName: "sources", isSignal: true, isRequired: false, transformFunction: null }, hasPriority: { classPropertyName: "hasPriority", publicName: "hasPriority", isSignal: true, isRequired: false, transformFunction: null }, imgClass: { classPropertyName: "imgClass", publicName: "imgClass", isSignal: true, isRequired: false, transformFunction: null }, figureClass: { classPropertyName: "figureClass", publicName: "figureClass", isSignal: true, isRequired: false, transformFunction: null }, figcaptionClass: { classPropertyName: "figcaptionClass", publicName: "figcaptionClass", isSignal: true, isRequired: false, transformFunction: null }, pictureClass: { classPropertyName: "pictureClass", publicName: "pictureClass", isSignal: true, isRequired: false, transformFunction: null }, defaultSrc: { classPropertyName: "defaultSrc", publicName: "defaultSrc", isSignal: true, isRequired: false, transformFunction: null }, alt: { classPropertyName: "alt", publicName: "alt", isSignal: true, isRequired: false, transformFunction: null }, figcaption: { classPropertyName: "figcaption", publicName: "figcaption", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null }, sizes: { classPropertyName: "sizes", publicName: "sizes", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { imgLoaded: "imgLoaded", imgError: "imgError" }, host: { classAttribute: "et-picture" }, viewQueries: [{ propertyName: "img", first: true, predicate: ["img"], descendants: true, isSignal: true }], ngImport: i0, template: "<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n @for (source of sourcesWithConfig(); track source.srcset) {\n <source\n [type]=\"source.type\"\n [attr.srcset]=\"source.srcset\"\n [attr.sizes]=\"(source.sizes ?? sizes()) || null\"\n [attr.media]=\"source.media || null\"\n />\n }\n\n @if (defaultSourceWithConfig(); as source) {\n <img\n #img\n [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n [ngClass]=\"imgClass()\"\n [attr.srcset]=\"source.srcset\"\n [attr.type]=\"source.type\"\n [attr.alt]=\"alt()\"\n [attr.width]=\"width()\"\n [attr.height]=\"height()\"\n [attr.sizes]=\"sizes()\"\n class=\"et-picture-img\"\n />\n }\n </picture>\n\n @if (figcaption()) {\n <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n {{ figcaption() }}\n </figcaption>\n }\n</figure>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
14879
14882
  }
14880
14883
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: PictureComponent, decorators: [{
14881
14884
  type: Component,
14882
14885
  args: [{ selector: 'et-picture', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgClass], host: {
14883
14886
  class: 'et-picture',
14884
- }, template: "<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n @for (source of sourcesWithConfig(); track source.srcset) {\n <source [type]=\"source.type\" [attr.srcset]=\"source.srcset\" [attr.sizes]=\"sizes()\" />\n }\n\n @if (defaultSourceWithConfig(); as source) {\n <img\n #img\n [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n [ngClass]=\"imgClass()\"\n [attr.srcset]=\"source.srcset\"\n [attr.type]=\"source.type\"\n [attr.alt]=\"alt()\"\n [attr.width]=\"width()\"\n [attr.height]=\"height()\"\n [attr.sizes]=\"sizes()\"\n class=\"et-picture-img\"\n />\n }\n </picture>\n\n @if (figcaption()) {\n <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n {{ figcaption() }}\n </figcaption>\n }\n</figure>\n" }]
14887
+ }, template: "<figure [ngClass]=\"figureClass()\" class=\"et-picture-figure\">\n <picture [ngClass]=\"pictureClass()\" class=\"et-picture-picture\">\n @for (source of sourcesWithConfig(); track source.srcset) {\n <source\n [type]=\"source.type\"\n [attr.srcset]=\"source.srcset\"\n [attr.sizes]=\"(source.sizes ?? sizes()) || null\"\n [attr.media]=\"source.media || null\"\n />\n }\n\n @if (defaultSourceWithConfig(); as source) {\n <img\n #img\n [attr.loading]=\"hasPriority() ? 'eager' : 'lazy'\"\n [attr.fetchpriority]=\"hasPriority() ? 'high' : 'auto'\"\n [ngClass]=\"imgClass()\"\n [attr.srcset]=\"source.srcset\"\n [attr.type]=\"source.type\"\n [attr.alt]=\"alt()\"\n [attr.width]=\"width()\"\n [attr.height]=\"height()\"\n [attr.sizes]=\"sizes()\"\n class=\"et-picture-img\"\n />\n }\n </picture>\n\n @if (figcaption()) {\n <figcaption [ngClass]=\"figcaptionClass()\" class=\"et-picture-figcaption\">\n {{ figcaption() }}\n </figcaption>\n }\n</figure>\n" }]
14885
14888
  }] });
14886
14889
 
14887
14890
  const PROGRESS_SPINNER_DEFAULT_OPTIONS = new InjectionToken('PROGRESS_SPINNER_DEFAULT_OPTIONS', {