@candy-kingdom/bonnie-cms 0.12.0 → 0.14.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.
@@ -68,21 +68,22 @@ export class FileUploaderComponent {
68
68
  getEventMessage(event) {
69
69
  switch (event.type) {
70
70
  case HttpEventType.Sent:
71
- return;
71
+ break;
72
72
  case HttpEventType.UploadProgress:
73
73
  this.progress = event.total === undefined ? 0.5 : event.loaded / event.total;
74
74
  this.updateClip();
75
- return;
75
+ break;
76
76
  case HttpEventType.Response:
77
77
  if (event.body === null || event.body === undefined) {
78
78
  console.warn(`empty body from uploader`);
79
- return;
79
+ break;
80
80
  }
81
81
  this.srcChange.emit(event.body);
82
- return;
82
+ break;
83
83
  default:
84
- return;
84
+ break;
85
85
  }
86
+ this.cd.detectChanges();
86
87
  }
87
88
  updateClip() {
88
89
  this.clipStyle = this.sanitizer.bypassSecurityTrustStyle(`inset(0px 100% 0px 0%)`);
@@ -115,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
115
116
  }], uploadTypes: [{
116
117
  type: Input
117
118
  }] } });
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-uploader.component.js","sourceRoot":"","sources":["../../../../../../libs/bonnie-cms/src/lib/file-uploader/file-uploader.component.ts","../../../../../../libs/bonnie-cms/src/lib/file-uploader/file-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { HttpClient, HttpEvent, HttpEventType, HttpRequest } from '@angular/common/http';\r\nimport { catchError, last, map, Observable } from 'rxjs';\r\n\r\nimport { FileMeta, FileSrc } from '@candy-kingdom/bonnie';\r\n\r\n@Component({\r\n  selector: 'bonc-file-uploader',\r\n  templateUrl: './file-uploader.component.html',\r\n  styleUrls: ['./file-uploader.component.scss']\r\n})\r\nexport class FileUploaderComponent {\r\n  @ViewChild('fileInput', { static: true })\r\n  public fileInput!: ElementRef<HTMLInputElement>;\r\n\r\n  @Output()\r\n  public srcChange = new EventEmitter<FileSrc<FileMeta>>();\r\n\r\n  @Input({ required: true })\r\n  public uploadUrlMap!: ReadonlyMap<string, string>;\r\n\r\n  public progress = 0;\r\n  public isUploading = false;\r\n\r\n  public autoplay = true;\r\n  public clipStyle?: SafeStyle;\r\n\r\n  public fileTypeMask?: string = undefined;\r\n\r\n  private _uploadTypes: string[] = [];\r\n  private _src?: FileSrc<FileMeta>;\r\n\r\n  constructor(private sanitizer: DomSanitizer, private http: HttpClient, private readonly cd: ChangeDetectorRef) {\r\n  }\r\n\r\n  @Input()\r\n  public set src(newSrc: FileSrc<FileMeta> | undefined) {\r\n    if (this._src === newSrc)\r\n      return;\r\n\r\n    this._src = newSrc;\r\n  }\r\n\r\n  public get src(): FileSrc<FileMeta> | undefined {\r\n    return this._src;\r\n  }\r\n\r\n  @Input()\r\n  public set uploadTypes(newUploadType: string[]) {\r\n    this._uploadTypes.splice(0, this._uploadTypes.length);\r\n\r\n    this._uploadTypes.push(...newUploadType);\r\n\r\n    this.fileTypeMask = this._uploadTypes.length === 0 ? undefined : this._uploadTypes.join(',');\r\n\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  public get uploadTypes(): string[] {\r\n    return this._uploadTypes;\r\n  }\r\n\r\n  public onFileSelect(fileInput: HTMLInputElement) {\r\n    if (fileInput.files === undefined || fileInput.files === null || fileInput.files.length !== 1)\r\n      return;\r\n\r\n    const file = fileInput.files[0];\r\n\r\n    const uploadUrl = this.uploadUrlMap.get(file.type) ?? this.uploadUrlMap.get(\"\");\r\n\r\n    if (uploadUrl === undefined || uploadUrl === null) {\r\n      console.error(`upload map doesn't have url for type '${file.type}'`);\r\n      return;\r\n    }\r\n\r\n    const formData: FormData = new FormData();\r\n\r\n    formData.append('file', file);\r\n\r\n    this.progress = 0;\r\n    this.isUploading = true;\r\n\r\n    this.updateClip();\r\n\r\n    const request = new HttpRequest('POST', uploadUrl, formData, {\r\n      reportProgress: true\r\n    });\r\n\r\n    this.http\r\n      .request<FileSrc<FileMeta>>(request)\r\n      .pipe\r\n      (\r\n        map(event => this.getEventMessage(event)),\r\n        // tap(message => this.showProgress(message)),\r\n        last(), // return last (completed) message to caller\r\n        catchError(this.handleError(file))\r\n      ).subscribe\r\n      (\r\n        () => { this.isUploading = false; }\r\n      );\r\n  }\r\n\r\n  public selectFile(event: Event): void {\r\n    // ignore buble click on file picker\r\n    if (event.target === this.fileInput.nativeElement)\r\n      return;\r\n\r\n    this.fileInput.nativeElement.click();\r\n  }\r\n\r\n  private getEventMessage(event: HttpEvent<FileSrc<FileMeta>>): void {\r\n    switch (event.type) {\r\n      case HttpEventType.Sent:\r\n        return;\r\n\r\n      case HttpEventType.UploadProgress:\r\n        this.progress = event.total === undefined ? 0.5 : event.loaded / event.total;\r\n        this.updateClip();\r\n        return;\r\n\r\n      case HttpEventType.Response:\r\n        if (event.body === null || event.body === undefined) {\r\n          console.warn(`empty body from uploader`);\r\n          return;\r\n        }\r\n\r\n        this.srcChange.emit(event.body);\r\n        return;\r\n\r\n      default:\r\n        return;\r\n    }\r\n  }\r\n\r\n  private updateClip(): void {\r\n    this.clipStyle = this.sanitizer.bypassSecurityTrustStyle(`inset(0px 100% 0px 0%)`);\r\n  }\r\n\r\n  private handleError(file: File): (p1: unknown, p2: Observable<unknown>) => Observable<unknown> {\r\n    const func = (error: unknown, p2: Observable<unknown>): Observable<unknown> => {\r\n      const message = `error uploadingFile ${file.name}.`;\r\n      console.error(message, error, p2);\r\n      alert(message);\r\n      return new Observable<unknown>();\r\n    };\r\n\r\n    return func;\r\n  }\r\n}\r\n","<div *ngIf=\"src === undefined || src.url === undefined || src?.url?.length === 0\">Upload file</div>\r\n\r\n<ng-content></ng-content>\r\n\r\n<div (click)=\"selectFile($event)\" class=\"media-container\">\r\n  <input #fileInput [accept]=\"fileTypeMask\" (change)=\"onFileSelect(fileInput)\" name=\"media\" type=\"file\" />\r\n  <span *ngIf=\"isUploading\"\r\n        [style.clip-path]=\"clipStyle\"\r\n        [style.-webkit-clip-path]=\"clipStyle\"\r\n        class=\"loader\"></span>\r\n\r\n  <span *ngIf=\"isUploading\" class=\"loader-text\">\r\n    <span *ngIf=\"progress < 1\">{{100 * progress | number: '1.0-0'}}%</span>\r\n    <span *ngIf=\"progress >= 1\">converting</span>\r\n  </span>\r\n</div>\r\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-uploader.component.js","sourceRoot":"","sources":["../../../../../../libs/bonnie-cms/src/lib/file-uploader/file-uploader.component.ts","../../../../../../libs/bonnie-cms/src/lib/file-uploader/file-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { HttpClient, HttpEvent, HttpEventType, HttpRequest } from '@angular/common/http';\r\nimport { catchError, last, map, Observable } from 'rxjs';\r\n\r\nimport { FileMeta, FileSrc } from '@candy-kingdom/bonnie';\r\n\r\n@Component({\r\n  selector: 'bonc-file-uploader',\r\n  templateUrl: './file-uploader.component.html',\r\n  styleUrls: ['./file-uploader.component.scss']\r\n})\r\nexport class FileUploaderComponent {\r\n  @ViewChild('fileInput', { static: true })\r\n  public fileInput!: ElementRef<HTMLInputElement>;\r\n\r\n  @Output()\r\n  public srcChange = new EventEmitter<FileSrc<FileMeta>>();\r\n\r\n  @Input({ required: true })\r\n  public uploadUrlMap!: ReadonlyMap<string, string>;\r\n\r\n  public progress = 0;\r\n  public isUploading = false;\r\n\r\n  public autoplay = true;\r\n  public clipStyle?: SafeStyle;\r\n\r\n  public fileTypeMask?: string = undefined;\r\n\r\n  private _uploadTypes: string[] = [];\r\n  private _src?: FileSrc<FileMeta>;\r\n\r\n  constructor(private sanitizer: DomSanitizer, private http: HttpClient, private readonly cd: ChangeDetectorRef) {\r\n  }\r\n\r\n  @Input()\r\n  public set src(newSrc: FileSrc<FileMeta> | undefined) {\r\n    if (this._src === newSrc)\r\n      return;\r\n\r\n    this._src = newSrc;\r\n  }\r\n\r\n  public get src(): FileSrc<FileMeta> | undefined {\r\n    return this._src;\r\n  }\r\n\r\n  @Input()\r\n  public set uploadTypes(newUploadType: string[]) {\r\n    this._uploadTypes.splice(0, this._uploadTypes.length);\r\n\r\n    this._uploadTypes.push(...newUploadType);\r\n\r\n    this.fileTypeMask = this._uploadTypes.length === 0 ? undefined : this._uploadTypes.join(',');\r\n\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  public get uploadTypes(): string[] {\r\n    return this._uploadTypes;\r\n  }\r\n\r\n  public onFileSelect(fileInput: HTMLInputElement) {\r\n    if (fileInput.files === undefined || fileInput.files === null || fileInput.files.length !== 1)\r\n      return;\r\n\r\n    const file = fileInput.files[0];\r\n\r\n    const uploadUrl = this.uploadUrlMap.get(file.type) ?? this.uploadUrlMap.get(\"\");\r\n\r\n    if (uploadUrl === undefined || uploadUrl === null) {\r\n      console.error(`upload map doesn't have url for type '${file.type}'`);\r\n      return;\r\n    }\r\n\r\n    const formData: FormData = new FormData();\r\n\r\n    formData.append('file', file);\r\n\r\n    this.progress = 0;\r\n    this.isUploading = true;\r\n\r\n    this.updateClip();\r\n\r\n    const request = new HttpRequest('POST', uploadUrl, formData, {\r\n      reportProgress: true\r\n    });\r\n\r\n    this.http\r\n      .request<FileSrc<FileMeta>>(request)\r\n      .pipe\r\n      (\r\n        map(event => this.getEventMessage(event)),\r\n        // tap(message => this.showProgress(message)),\r\n        last(), // return last (completed) message to caller\r\n        catchError(this.handleError(file))\r\n      ).subscribe\r\n      (\r\n        () => { this.isUploading = false; }\r\n      );\r\n  }\r\n\r\n  public selectFile(event: Event): void {\r\n    // ignore buble click on file picker\r\n    if (event.target === this.fileInput.nativeElement)\r\n      return;\r\n\r\n    this.fileInput.nativeElement.click();\r\n  }\r\n\r\n  private getEventMessage(event: HttpEvent<FileSrc<FileMeta>>): void {\r\n    switch (event.type) {\r\n      case HttpEventType.Sent:\r\n        break;\r\n\r\n      case HttpEventType.UploadProgress:\r\n        this.progress = event.total === undefined ? 0.5 : event.loaded / event.total;\r\n        this.updateClip();\r\n        break;\r\n\r\n      case HttpEventType.Response:\r\n        if (event.body === null || event.body === undefined) {\r\n          console.warn(`empty body from uploader`);\r\n          break;\r\n        }\r\n\r\n        this.srcChange.emit(event.body);\r\n        break;\r\n\r\n      default:\r\n        break;\r\n    }\r\n\r\n    this.cd.detectChanges()\r\n  }\r\n\r\n  private updateClip(): void {\r\n    this.clipStyle = this.sanitizer.bypassSecurityTrustStyle(`inset(0px 100% 0px 0%)`);\r\n  }\r\n\r\n  private handleError(file: File): (p1: unknown, p2: Observable<unknown>) => Observable<unknown> {\r\n    const func = (error: unknown, p2: Observable<unknown>): Observable<unknown> => {\r\n      const message = `error uploadingFile ${file.name}.`;\r\n      console.error(message, error, p2);\r\n      alert(message);\r\n      return new Observable<unknown>();\r\n    };\r\n\r\n    return func;\r\n  }\r\n}\r\n","<div *ngIf=\"src === undefined || src.url === undefined || src?.url?.length === 0\">Upload file</div>\r\n\r\n<ng-content></ng-content>\r\n\r\n<div (click)=\"selectFile($event)\" class=\"media-container\">\r\n  <input #fileInput [accept]=\"fileTypeMask\" (change)=\"onFileSelect(fileInput)\" name=\"media\" type=\"file\" />\r\n  <span *ngIf=\"isUploading\"\r\n        [style.clip-path]=\"clipStyle\"\r\n        [style.-webkit-clip-path]=\"clipStyle\"\r\n        class=\"loader\"></span>\r\n\r\n  <span *ngIf=\"isUploading\" class=\"loader-text\">\r\n    <span *ngIf=\"progress < 1\">{{100 * progress | number: '1.0-0'}}%</span>\r\n    <span *ngIf=\"progress >= 1\">converting</span>\r\n  </span>\r\n</div>\r\n"]}
@@ -3,16 +3,16 @@ import { EditableDirective, FormBaseComponent } from '../../core-components';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "../../core-components/editable.directive";
5
5
  import * as i2 from "@angular/common";
6
- import * as i3 from "@angular/forms";
7
- import * as i4 from "../one-image-form/one-image-form.component";
8
- import * as i5 from "../../translation-input/translation-input.component";
9
- import * as i6 from "../../translation-textarea/translation-textarea.component";
10
- import * as i7 from "../../form-controls/form-controls.component";
6
+ import * as i3 from "../../translation-input/translation-input.component";
7
+ import * as i4 from "../../translation-textarea/translation-textarea.component";
8
+ import * as i5 from "../../form-controls/form-controls.component";
9
+ import * as i6 from "../../file-uploader/file-uploader.component";
10
+ const uploadMap = new Map();
11
+ uploadMap.set('', `/api/admin/upload/image?width=${1200}&height=${630}&format=image/jpeg`);
11
12
  export class SeoFormComponent extends FormBaseComponent {
12
13
  constructor() {
13
14
  super(...arguments);
14
- this.imageWidth = 1200;
15
- this.imageHeight = 630;
15
+ this.uploadMap = uploadMap;
16
16
  this._pageId = '';
17
17
  this.ogImageUploadUrl = '';
18
18
  this.label = '';
@@ -32,15 +32,22 @@ export class SeoFormComponent extends FormBaseComponent {
32
32
  ResToSrc(res) {
33
33
  return res.url;
34
34
  }
35
+ replaceImage($event) {
36
+ this.editable.startEditing();
37
+ if (this.editable.value !== undefined) {
38
+ this.editable.value.image[this.locale] = $event;
39
+ }
40
+ this.editable.updateDirty();
41
+ }
35
42
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SeoFormComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
36
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: SeoFormComponent, selector: "bonc-seo-form", inputs: { label: "label", pageId: "pageId" }, usesInheritance: true, hostDirectives: [{ directive: i1.EditableDirective }], ngImport: i0, template: "<bonc-form-controls *ngIf=\"editable.value\" [editable]=\"editable\">\r\n <h2 *ngIf=\"label\">{{label}}</h2>\r\n\r\n <div class=\"form-group\">\r\n <label>Title</label>\r\n <bonc-translation-input [text]=\"editable.value.title\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-input>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Description</label>\r\n <bonc-translation-textarea [text]=\"editable.value.description\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-textarea>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Share image | 1200x630</label>\r\n\r\n <bonc-one-image-form [(ngModel)]=\"editable.value.image\"\r\n [uploadUrl]=\"'/api/admin/upload/image?width=' + imageWidth + '&height='+imageHeight + '&format=image/jpeg'\"\r\n [locale]=\"locale\">\r\n </bonc-one-image-form>\r\n\r\n </div>\r\n\r\n</bonc-form-controls>\r\n\r\n<div *ngIf=\"!editable.value\">Editable Value canot be null or undefined</div>\r\n", styles: [":host{display:block}bonc-one-image-form{max-width:600px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.OneImageFormComponent, selector: "bonc-one-image-form", inputs: ["label", "uploadUrl", "mimeTypes"] }, { kind: "component", type: i5.TranslationInputComponent, selector: "bonc-translation-input", inputs: ["text", "locale", "device"], outputs: ["startEditing", "changed", "blurred"] }, { kind: "component", type: i6.TranslationTextareaComponent, selector: "bonc-translation-textarea", inputs: ["minRows", "maxRows", "text", "locale", "device"], outputs: ["startEditing", "changed", "blurred"] }, { kind: "component", type: i7.FormControlsComponent, selector: "bonc-form-controls", inputs: ["editable"] }] }); }
43
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: SeoFormComponent, selector: "bonc-seo-form", inputs: { label: "label", pageId: "pageId" }, usesInheritance: true, hostDirectives: [{ directive: i1.EditableDirective }], ngImport: i0, template: "<bonc-form-controls *ngIf=\"editable.value\" [editable]=\"editable\">\r\n <h2 *ngIf=\"label\">{{label}}</h2>\r\n\r\n <div class=\"form-group\">\r\n <label>Title</label>\r\n <bonc-translation-input [text]=\"editable.value.title\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-input>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Description</label>\r\n <bonc-translation-textarea [text]=\"editable.value.description\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-textarea>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Share image | 1200x630</label>\r\n\r\n <bonc-file-uploader [src]=\"editable.value.image[locale]\"\r\n [uploadTypes]=\"['image/png', 'image/jpeg']\"\r\n [uploadUrlMap]=\"uploadMap\"\r\n (srcChange)=\"replaceImage($event)\">\r\n <img *ngIf=\"editable.value.image[locale]?.url?.length ?? 0 > 0\" [src]=\"editable.value.image[locale].url\" />\r\n </bonc-file-uploader>\r\n\r\n <a *ngIf=\"editable.value.image[locale]?.url?.length ?? 0 > 0\" [href]=\"editable.value.image[locale].url\" download target=\"_blank\">Download</a>\r\n </div>\r\n\r\n</bonc-form-controls>\r\n\r\n<div *ngIf=\"!editable.value\">Editable Value canot be null or undefined</div>\r\n", styles: [":host{display:block}bonc-one-image-form{max-width:600px}img{display:block;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.TranslationInputComponent, selector: "bonc-translation-input", inputs: ["text", "locale", "device"], outputs: ["startEditing", "changed", "blurred"] }, { kind: "component", type: i4.TranslationTextareaComponent, selector: "bonc-translation-textarea", inputs: ["minRows", "maxRows", "text", "locale", "device"], outputs: ["startEditing", "changed", "blurred"] }, { kind: "component", type: i5.FormControlsComponent, selector: "bonc-form-controls", inputs: ["editable"] }, { kind: "component", type: i6.FileUploaderComponent, selector: "bonc-file-uploader", inputs: ["uploadUrlMap", "src", "uploadTypes"], outputs: ["srcChange"] }] }); }
37
44
  }
38
45
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SeoFormComponent, decorators: [{
39
46
  type: Component,
40
- args: [{ selector: 'bonc-seo-form', hostDirectives: [EditableDirective], template: "<bonc-form-controls *ngIf=\"editable.value\" [editable]=\"editable\">\r\n <h2 *ngIf=\"label\">{{label}}</h2>\r\n\r\n <div class=\"form-group\">\r\n <label>Title</label>\r\n <bonc-translation-input [text]=\"editable.value.title\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-input>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Description</label>\r\n <bonc-translation-textarea [text]=\"editable.value.description\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-textarea>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Share image | 1200x630</label>\r\n\r\n <bonc-one-image-form [(ngModel)]=\"editable.value.image\"\r\n [uploadUrl]=\"'/api/admin/upload/image?width=' + imageWidth + '&height='+imageHeight + '&format=image/jpeg'\"\r\n [locale]=\"locale\">\r\n </bonc-one-image-form>\r\n\r\n </div>\r\n\r\n</bonc-form-controls>\r\n\r\n<div *ngIf=\"!editable.value\">Editable Value canot be null or undefined</div>\r\n", styles: [":host{display:block}bonc-one-image-form{max-width:600px}\n"] }]
47
+ args: [{ selector: 'bonc-seo-form', hostDirectives: [EditableDirective], template: "<bonc-form-controls *ngIf=\"editable.value\" [editable]=\"editable\">\r\n <h2 *ngIf=\"label\">{{label}}</h2>\r\n\r\n <div class=\"form-group\">\r\n <label>Title</label>\r\n <bonc-translation-input [text]=\"editable.value.title\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-input>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Description</label>\r\n <bonc-translation-textarea [text]=\"editable.value.description\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-textarea>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Share image | 1200x630</label>\r\n\r\n <bonc-file-uploader [src]=\"editable.value.image[locale]\"\r\n [uploadTypes]=\"['image/png', 'image/jpeg']\"\r\n [uploadUrlMap]=\"uploadMap\"\r\n (srcChange)=\"replaceImage($event)\">\r\n <img *ngIf=\"editable.value.image[locale]?.url?.length ?? 0 > 0\" [src]=\"editable.value.image[locale].url\" />\r\n </bonc-file-uploader>\r\n\r\n <a *ngIf=\"editable.value.image[locale]?.url?.length ?? 0 > 0\" [href]=\"editable.value.image[locale].url\" download target=\"_blank\">Download</a>\r\n </div>\r\n\r\n</bonc-form-controls>\r\n\r\n<div *ngIf=\"!editable.value\">Editable Value canot be null or undefined</div>\r\n", styles: [":host{display:block}bonc-one-image-form{max-width:600px}img{display:block;width:100%}\n"] }]
41
48
  }], propDecorators: { label: [{
42
49
  type: Input
43
50
  }], pageId: [{
44
51
  type: Input
45
52
  }] } });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VvLWZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9ib25uaWUtY21zL3NyYy9saWIvZm9ybXMvc2VvLWZvcm0vc2VvLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9ib25uaWUtY21zL3NyYy9saWIvZm9ybXMvc2VvLWZvcm0vc2VvLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHekQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7Ozs7OztBQVE3RSxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsaUJBQWdDO0lBTnRFOztRQU9rQixlQUFVLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLGdCQUFXLEdBQUcsR0FBRyxDQUFDO1FBRTFCLFlBQU8sR0FBRyxFQUFFLENBQUM7UUFDZCxxQkFBZ0IsR0FBRyxFQUFFLENBQUM7UUFHdEIsVUFBSyxHQUFHLEVBQUUsQ0FBQztLQXFCbkI7SUFuQlEsUUFBUTtRQUNiLElBQUksQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUM1QyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQ1csTUFBTSxDQUFDLEtBQWE7UUFDN0IsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDckIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLG1DQUFtQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyw4Q0FBOEM7SUFDMUgsQ0FBQztJQUVELElBQVcsTUFBTTtRQUNmLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBRU0sUUFBUSxDQUFDLEdBQW9CO1FBQ2xDLE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQztJQUNqQixDQUFDOzhHQTVCVSxnQkFBZ0I7a0dBQWhCLGdCQUFnQixpTENYN0IsdStDQW9DQTs7MkZEekJhLGdCQUFnQjtrQkFONUIsU0FBUzsrQkFDRSxlQUFlLGtCQUdULENBQUMsaUJBQWlCLENBQUM7OEJBVTVCLEtBQUs7c0JBRFgsS0FBSztnQkFVSyxNQUFNO3NCQURoQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE9wZW5HcmFwaERhdGEgfSBmcm9tICdAY2FuZHkta2luZ2RvbS9ib25uaWUnO1xyXG5cclxuaW1wb3J0IHsgRWRpdGFibGVEaXJlY3RpdmUsIEZvcm1CYXNlQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29yZS1jb21wb25lbnRzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYm9uYy1zZW8tZm9ybScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3Nlby1mb3JtLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zZW8tZm9ybS5jb21wb25lbnQuc2NzcyddLFxyXG4gIGhvc3REaXJlY3RpdmVzOiBbRWRpdGFibGVEaXJlY3RpdmVdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZW9Gb3JtQ29tcG9uZW50IGV4dGVuZHMgRm9ybUJhc2VDb21wb25lbnQ8T3BlbkdyYXBoRGF0YT4gaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIHB1YmxpYyByZWFkb25seSBpbWFnZVdpZHRoID0gMTIwMDtcclxuICBwdWJsaWMgcmVhZG9ubHkgaW1hZ2VIZWlnaHQgPSA2MzA7XHJcblxyXG4gIHByaXZhdGUgX3BhZ2VJZCA9ICcnO1xyXG4gIHB1YmxpYyBvZ0ltYWdlVXBsb2FkVXJsID0gJyc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGxhYmVsID0gJyc7XHJcblxyXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuZWRpdGFibGUuZXh0ZXJuYWxTYXZlQ2FsbC5zdWJzY3JpYmUoKCkgPT4ge1xyXG4gICAgICB0aGlzLmVkaXRhYmxlLnNhdmUoKTtcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2V0IHBhZ2VJZCh2YWx1ZTogc3RyaW5nKSB7XHJcbiAgICB0aGlzLl9wYWdlSWQgPSB2YWx1ZTtcclxuICAgIHRoaXMub2dJbWFnZVVwbG9hZFVybCA9IGAvYXBpL2FkbWluL3BhZ2UvT2ctSW1hZ2U/cGFnZUlkPSR7dGhpcy5wYWdlSWR9YDsgLy8gdG9kbzogcmVwbGFjZSB3aXRoIGxpbmsgdG8gc2luZ2xlIGltYWdlIGFwaVxyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBwYWdlSWQoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLl9wYWdlSWQ7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgUmVzVG9TcmMocmVzOiB7IHVybDogc3RyaW5nIH0pOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHJlcy51cmw7XHJcbiAgfVxyXG59XHJcbiIsIjxib25jLWZvcm0tY29udHJvbHMgKm5nSWY9XCJlZGl0YWJsZS52YWx1ZVwiIFtlZGl0YWJsZV09XCJlZGl0YWJsZVwiPlxyXG4gIDxoMiAqbmdJZj1cImxhYmVsXCI+e3tsYWJlbH19PC9oMj5cclxuXHJcbiAgPGRpdiBjbGFzcz1cImZvcm0tZ3JvdXBcIj5cclxuICAgIDxsYWJlbD5UaXRsZTwvbGFiZWw+XHJcbiAgICA8Ym9uYy10cmFuc2xhdGlvbi1pbnB1dCBbdGV4dF09XCJlZGl0YWJsZS52YWx1ZS50aXRsZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbbG9jYWxlXT1cImxvY2FsZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoc3RhcnRFZGl0aW5nKT1cImVkaXRhYmxlLnN0YXJ0RWRpdGluZygpXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIChjaGFuZ2VkKT1cImVkaXRhYmxlLnVwZGF0ZURpcnR5KClcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgKGJsdXJyZWQpPVwiZWRpdGFibGUudXBkYXRlRGlydHkoKVwiPlxyXG4gICAgPC9ib25jLXRyYW5zbGF0aW9uLWlucHV0PlxyXG4gIDwvZGl2PlxyXG5cclxuICA8ZGl2IGNsYXNzPVwiZm9ybS1ncm91cFwiPlxyXG4gICAgPGxhYmVsPkRlc2NyaXB0aW9uPC9sYWJlbD5cclxuICAgIDxib25jLXRyYW5zbGF0aW9uLXRleHRhcmVhIFt0ZXh0XT1cImVkaXRhYmxlLnZhbHVlLmRlc2NyaXB0aW9uXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtsb2NhbGVdPVwibG9jYWxlXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIChzdGFydEVkaXRpbmcpPVwiZWRpdGFibGUuc3RhcnRFZGl0aW5nKClcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGNoYW5nZWQpPVwiZWRpdGFibGUudXBkYXRlRGlydHkoKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAoYmx1cnJlZCk9XCJlZGl0YWJsZS51cGRhdGVEaXJ0eSgpXCI+XHJcbiAgICA8L2JvbmMtdHJhbnNsYXRpb24tdGV4dGFyZWE+XHJcbiAgPC9kaXY+XHJcblxyXG4gIDxkaXYgY2xhc3M9XCJmb3JtLWdyb3VwXCI+XHJcbiAgICA8bGFiZWw+U2hhcmUgaW1hZ2UgfCAxMjAweDYzMDwvbGFiZWw+XHJcblxyXG4gICAgPGJvbmMtb25lLWltYWdlLWZvcm0gWyhuZ01vZGVsKV09XCJlZGl0YWJsZS52YWx1ZS5pbWFnZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICBbdXBsb2FkVXJsXT1cIicvYXBpL2FkbWluL3VwbG9hZC9pbWFnZT93aWR0aD0nICsgaW1hZ2VXaWR0aCArICcmaGVpZ2h0PScraW1hZ2VIZWlnaHQgKyAnJmZvcm1hdD1pbWFnZS9qcGVnJ1wiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICBbbG9jYWxlXT1cImxvY2FsZVwiPlxyXG4gICAgPC9ib25jLW9uZS1pbWFnZS1mb3JtPlxyXG5cclxuICA8L2Rpdj5cclxuXHJcbjwvYm9uYy1mb3JtLWNvbnRyb2xzPlxyXG5cclxuPGRpdiAqbmdJZj1cIiFlZGl0YWJsZS52YWx1ZVwiPkVkaXRhYmxlIFZhbHVlIGNhbm90IGJlIG51bGwgb3IgdW5kZWZpbmVkPC9kaXY+XHJcbiJdfQ==
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VvLWZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9ib25uaWUtY21zL3NyYy9saWIvZm9ybXMvc2VvLWZvcm0vc2VvLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9ib25uaWUtY21zL3NyYy9saWIvZm9ybXMvc2VvLWZvcm0vc2VvLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHekQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7Ozs7O0FBRTdFLE1BQU0sU0FBUyxHQUFHLElBQUksR0FBRyxFQUFrQixDQUFDO0FBQzVDLFNBQVMsQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLGlDQUFpQyxJQUFJLFdBQVcsR0FBRyxvQkFBb0IsQ0FBQyxDQUFDO0FBUTNGLE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxpQkFBZ0M7SUFOdEU7O1FBT2tCLGNBQVMsR0FBRyxTQUFTLENBQUM7UUFFOUIsWUFBTyxHQUFHLEVBQUUsQ0FBQztRQUNkLHFCQUFnQixHQUFHLEVBQUUsQ0FBQztRQUd0QixVQUFLLEdBQUcsRUFBRSxDQUFDO0tBK0JuQjtJQTdCUSxRQUFRO1FBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQzVDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDdkIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsSUFDVyxNQUFNLENBQUMsS0FBYTtRQUM3QixJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztRQUNyQixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsbUNBQW1DLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLDhDQUE4QztJQUMxSCxDQUFDO0lBRUQsSUFBVyxNQUFNO1FBQ2YsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFTSxRQUFRLENBQUMsR0FBb0I7UUFDbEMsT0FBTyxHQUFHLENBQUMsR0FBRyxDQUFDO0lBQ2pCLENBQUM7SUFFTSxZQUFZLENBQUMsTUFBeUI7UUFDM0MsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUU3QixJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxLQUFLLFNBQVMsRUFBRTtZQUNyQyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLE1BQTRCLENBQUM7U0FDdkU7UUFFRCxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzlCLENBQUM7OEdBckNVLGdCQUFnQjtrR0FBaEIsZ0JBQWdCLGlMQ2Q3Qixrd0RBdUNBOzsyRkR6QmEsZ0JBQWdCO2tCQU41QixTQUFTOytCQUNFLGVBQWUsa0JBR1QsQ0FBQyxpQkFBaUIsQ0FBQzs4QkFTNUIsS0FBSztzQkFEWCxLQUFLO2dCQVVLLE1BQU07c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmlsZU1ldGEsIEZpbGVTcmMsIEltYWdlTWV0YSwgT3BlbkdyYXBoRGF0YSB9IGZyb20gJ0BjYW5keS1raW5nZG9tL2Jvbm5pZSc7XHJcblxyXG5pbXBvcnQgeyBFZGl0YWJsZURpcmVjdGl2ZSwgRm9ybUJhc2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb3JlLWNvbXBvbmVudHMnO1xyXG5cclxuY29uc3QgdXBsb2FkTWFwID0gbmV3IE1hcDxzdHJpbmcsIHN0cmluZz4oKTtcclxudXBsb2FkTWFwLnNldCgnJywgYC9hcGkvYWRtaW4vdXBsb2FkL2ltYWdlP3dpZHRoPSR7MTIwMH0maGVpZ2h0PSR7NjMwfSZmb3JtYXQ9aW1hZ2UvanBlZ2ApO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdib25jLXNlby1mb3JtJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2VvLWZvcm0uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3Nlby1mb3JtLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgaG9zdERpcmVjdGl2ZXM6IFtFZGl0YWJsZURpcmVjdGl2ZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIFNlb0Zvcm1Db21wb25lbnQgZXh0ZW5kcyBGb3JtQmFzZUNvbXBvbmVudDxPcGVuR3JhcGhEYXRhPiBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcHVibGljIHJlYWRvbmx5IHVwbG9hZE1hcCA9IHVwbG9hZE1hcDtcclxuXHJcbiAgcHJpdmF0ZSBfcGFnZUlkID0gJyc7XHJcbiAgcHVibGljIG9nSW1hZ2VVcGxvYWRVcmwgPSAnJztcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgbGFiZWwgPSAnJztcclxuXHJcbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5lZGl0YWJsZS5leHRlcm5hbFNhdmVDYWxsLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgIHRoaXMuZWRpdGFibGUuc2F2ZSgpO1xyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZXQgcGFnZUlkKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgIHRoaXMuX3BhZ2VJZCA9IHZhbHVlO1xyXG4gICAgdGhpcy5vZ0ltYWdlVXBsb2FkVXJsID0gYC9hcGkvYWRtaW4vcGFnZS9PZy1JbWFnZT9wYWdlSWQ9JHt0aGlzLnBhZ2VJZH1gOyAvLyB0b2RvOiByZXBsYWNlIHdpdGggbGluayB0byBzaW5nbGUgaW1hZ2UgYXBpXHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IHBhZ2VJZCgpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMuX3BhZ2VJZDtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBSZXNUb1NyYyhyZXM6IHsgdXJsOiBzdHJpbmcgfSk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gcmVzLnVybDtcclxuICB9XHJcblxyXG4gIHB1YmxpYyByZXBsYWNlSW1hZ2UoJGV2ZW50OiBGaWxlU3JjPEZpbGVNZXRhPik6IHZvaWQge1xyXG4gICAgdGhpcy5lZGl0YWJsZS5zdGFydEVkaXRpbmcoKTtcclxuXHJcbiAgICBpZiAodGhpcy5lZGl0YWJsZS52YWx1ZSAhPT0gdW5kZWZpbmVkKSB7XHJcbiAgICAgIHRoaXMuZWRpdGFibGUudmFsdWUuaW1hZ2VbdGhpcy5sb2NhbGVdID0gJGV2ZW50IGFzIEZpbGVTcmM8SW1hZ2VNZXRhPjtcclxuICAgIH1cclxuXHJcbiAgICB0aGlzLmVkaXRhYmxlLnVwZGF0ZURpcnR5KCk7XHJcbiAgfVxyXG59XHJcbiIsIjxib25jLWZvcm0tY29udHJvbHMgKm5nSWY9XCJlZGl0YWJsZS52YWx1ZVwiIFtlZGl0YWJsZV09XCJlZGl0YWJsZVwiPlxyXG4gIDxoMiAqbmdJZj1cImxhYmVsXCI+e3tsYWJlbH19PC9oMj5cclxuXHJcbiAgPGRpdiBjbGFzcz1cImZvcm0tZ3JvdXBcIj5cclxuICAgIDxsYWJlbD5UaXRsZTwvbGFiZWw+XHJcbiAgICA8Ym9uYy10cmFuc2xhdGlvbi1pbnB1dCBbdGV4dF09XCJlZGl0YWJsZS52YWx1ZS50aXRsZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbbG9jYWxlXT1cImxvY2FsZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoc3RhcnRFZGl0aW5nKT1cImVkaXRhYmxlLnN0YXJ0RWRpdGluZygpXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIChjaGFuZ2VkKT1cImVkaXRhYmxlLnVwZGF0ZURpcnR5KClcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgKGJsdXJyZWQpPVwiZWRpdGFibGUudXBkYXRlRGlydHkoKVwiPlxyXG4gICAgPC9ib25jLXRyYW5zbGF0aW9uLWlucHV0PlxyXG4gIDwvZGl2PlxyXG5cclxuICA8ZGl2IGNsYXNzPVwiZm9ybS1ncm91cFwiPlxyXG4gICAgPGxhYmVsPkRlc2NyaXB0aW9uPC9sYWJlbD5cclxuICAgIDxib25jLXRyYW5zbGF0aW9uLXRleHRhcmVhIFt0ZXh0XT1cImVkaXRhYmxlLnZhbHVlLmRlc2NyaXB0aW9uXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtsb2NhbGVdPVwibG9jYWxlXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIChzdGFydEVkaXRpbmcpPVwiZWRpdGFibGUuc3RhcnRFZGl0aW5nKClcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGNoYW5nZWQpPVwiZWRpdGFibGUudXBkYXRlRGlydHkoKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAoYmx1cnJlZCk9XCJlZGl0YWJsZS51cGRhdGVEaXJ0eSgpXCI+XHJcbiAgICA8L2JvbmMtdHJhbnNsYXRpb24tdGV4dGFyZWE+XHJcbiAgPC9kaXY+XHJcblxyXG4gIDxkaXYgY2xhc3M9XCJmb3JtLWdyb3VwXCI+XHJcbiAgICA8bGFiZWw+U2hhcmUgaW1hZ2UgfCAxMjAweDYzMDwvbGFiZWw+XHJcblxyXG4gICAgPGJvbmMtZmlsZS11cGxvYWRlciBbc3JjXT1cImVkaXRhYmxlLnZhbHVlLmltYWdlW2xvY2FsZV1cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbdXBsb2FkVHlwZXNdPVwiWydpbWFnZS9wbmcnLCAnaW1hZ2UvanBlZyddXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgW3VwbG9hZFVybE1hcF09XCJ1cGxvYWRNYXBcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAoc3JjQ2hhbmdlKT1cInJlcGxhY2VJbWFnZSgkZXZlbnQpXCI+XHJcbiAgICAgIDxpbWcgKm5nSWY9XCJlZGl0YWJsZS52YWx1ZS5pbWFnZVtsb2NhbGVdPy51cmw/Lmxlbmd0aCA/PyAwID4gMFwiIFtzcmNdPVwiZWRpdGFibGUudmFsdWUuaW1hZ2VbbG9jYWxlXS51cmxcIiAvPlxyXG4gICAgPC9ib25jLWZpbGUtdXBsb2FkZXI+XHJcblxyXG4gICAgPGEgKm5nSWY9XCJlZGl0YWJsZS52YWx1ZS5pbWFnZVtsb2NhbGVdPy51cmw/Lmxlbmd0aCA/PyAwID4gMFwiIFtocmVmXT1cImVkaXRhYmxlLnZhbHVlLmltYWdlW2xvY2FsZV0udXJsXCIgZG93bmxvYWQgdGFyZ2V0PVwiX2JsYW5rXCI+RG93bmxvYWQ8L2E+XHJcbiAgPC9kaXY+XHJcblxyXG48L2JvbmMtZm9ybS1jb250cm9scz5cclxuXHJcbjxkaXYgKm5nSWY9XCIhZWRpdGFibGUudmFsdWVcIj5FZGl0YWJsZSBWYWx1ZSBjYW5vdCBiZSBudWxsIG9yIHVuZGVmaW5lZDwvZGl2PlxyXG4iXX0=
@@ -1,4 +1,4 @@
1
- import { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
1
+ import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
2
  import { DomSanitizer } from '@angular/platform-browser';
3
3
  import { HttpClient, HttpEventType, HttpRequest } from '@angular/common/http';
4
4
  import { catchError, last, map, Observable } from 'rxjs';
@@ -14,9 +14,10 @@ const imageFileTypes = imageMimeTypes.join(',');
14
14
  const videoFileTypes = videoMimeTypes.join(',');
15
15
  const allMediaFileTypes = `${imageFileTypes},${videoFileTypes}`;
16
16
  export class MediaUploaderComponent {
17
- constructor(sanitizer, http) {
17
+ constructor(sanitizer, http, cd) {
18
18
  this.sanitizer = sanitizer;
19
19
  this.http = http;
20
+ this.cd = cd;
20
21
  this.MediaObjectFit = MediaObjectFit;
21
22
  this.srcChange = new EventEmitter();
22
23
  this.progress = 0;
@@ -100,11 +101,11 @@ export class MediaUploaderComponent {
100
101
  getEventMessage(event) {
101
102
  switch (event.type) {
102
103
  case HttpEventType.Sent:
103
- return;
104
+ break;
104
105
  case HttpEventType.UploadProgress:
105
106
  this.progress = event.total === undefined ? 0.5 : event.loaded / event.total;
106
107
  this.updateClip();
107
- return;
108
+ break;
108
109
  case HttpEventType.Response:
109
110
  if (event.body === undefined || event.body === null) {
110
111
  console.error('media deserialization error. Response body in undefined');
@@ -118,10 +119,11 @@ export class MediaUploaderComponent {
118
119
  };
119
120
  this.srcChange.emit(pixmedia);
120
121
  }
121
- return;
122
+ break;
122
123
  default:
123
- return;
124
+ break;
124
125
  }
126
+ this.cd.detectChanges();
125
127
  }
126
128
  updateClip() {
127
129
  this.clipStyle = this.sanitizer.bypassSecurityTrustStyle(`inset(0px 100% 0px 0%)`);
@@ -135,13 +137,13 @@ export class MediaUploaderComponent {
135
137
  };
136
138
  return func;
137
139
  }
138
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MediaUploaderComponent, deps: [{ token: i1.DomSanitizer }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
140
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MediaUploaderComponent, deps: [{ token: i1.DomSanitizer }, { token: i2.HttpClient }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
139
141
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: MediaUploaderComponent, selector: "bonc-media-uploader", inputs: { uploadUrlMap: "uploadUrlMap", forceRatio: "forceRatio", src: "src", uploadType: "uploadType" }, outputs: { srcChange: "srcChange" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, static: true }], ngImport: i0, template: "<bon-media [src]=\"src\" [objectFit]=\"MediaObjectFit.Cover\"></bon-media>\r\n\r\n<div *ngIf=\"src?.sources?.length===0\">Upload media</div>\r\n\r\n<div (click)=\"selectFile($event)\" class=\"media-container\">\r\n <input #fileInput [accept]=\"fileTypeMask\" (change)=\"onFileSelect(fileInput)\" name=\"media\" type=\"file\" />\r\n <span *ngIf=\"isUploading\"\r\n [style.clip-path]=\"clipStyle\"\r\n [style.-webkit-clip-path]=\"clipStyle\"\r\n class=\"loader\"></span>\r\n\r\n <span *ngIf=\"isUploading\" class=\"loader-text\">\r\n <span *ngIf=\"progress < 1\">{{100 * progress | number: '1.0-0'}}%</span>\r\n <span *ngIf=\"progress >= 1\">converting</span>\r\n </span>\r\n</div>\r\n", styles: [":host{display:block;background-color:#000;position:relative}.media-container{display:block;position:absolute;inset:0;cursor:pointer}.media-container:hover:hover:after{display:flex;justify-content:center;align-items:center;content:\"\";position:absolute;color:silver;inset:0;font-weight:700;font-size:50pt;pointer-events:none;background-color:#ccff00b3}.media-container img,.media-container video{display:block;position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}input[type=file]{display:none}.loader{position:absolute;inset:0;background-color:#cf0}.loader-text{background-color:#000;position:absolute;top:50%;left:0;right:0;text-align:center;font-size:20pt;margin-top:-10pt;color:#fff}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MarcyMediaComponent, selector: "bon-media", inputs: ["src", "objectFit"], outputs: ["isLoaded"] }, { kind: "pipe", type: i3.DecimalPipe, name: "number" }] }); }
140
142
  }
141
143
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MediaUploaderComponent, decorators: [{
142
144
  type: Component,
143
145
  args: [{ selector: 'bonc-media-uploader', template: "<bon-media [src]=\"src\" [objectFit]=\"MediaObjectFit.Cover\"></bon-media>\r\n\r\n<div *ngIf=\"src?.sources?.length===0\">Upload media</div>\r\n\r\n<div (click)=\"selectFile($event)\" class=\"media-container\">\r\n <input #fileInput [accept]=\"fileTypeMask\" (change)=\"onFileSelect(fileInput)\" name=\"media\" type=\"file\" />\r\n <span *ngIf=\"isUploading\"\r\n [style.clip-path]=\"clipStyle\"\r\n [style.-webkit-clip-path]=\"clipStyle\"\r\n class=\"loader\"></span>\r\n\r\n <span *ngIf=\"isUploading\" class=\"loader-text\">\r\n <span *ngIf=\"progress < 1\">{{100 * progress | number: '1.0-0'}}%</span>\r\n <span *ngIf=\"progress >= 1\">converting</span>\r\n </span>\r\n</div>\r\n", styles: [":host{display:block;background-color:#000;position:relative}.media-container{display:block;position:absolute;inset:0;cursor:pointer}.media-container:hover:hover:after{display:flex;justify-content:center;align-items:center;content:\"\";position:absolute;color:silver;inset:0;font-weight:700;font-size:50pt;pointer-events:none;background-color:#ccff00b3}.media-container img,.media-container video{display:block;position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}input[type=file]{display:none}.loader{position:absolute;inset:0;background-color:#cf0}.loader-text{background-color:#000;position:absolute;top:50%;left:0;right:0;text-align:center;font-size:20pt;margin-top:-10pt;color:#fff}\n"] }]
144
- }], ctorParameters: () => [{ type: i1.DomSanitizer }, { type: i2.HttpClient }], propDecorators: { fileInput: [{
146
+ }], ctorParameters: () => [{ type: i1.DomSanitizer }, { type: i2.HttpClient }, { type: i0.ChangeDetectorRef }], propDecorators: { fileInput: [{
145
147
  type: ViewChild,
146
148
  args: ['fileInput', { static: true }]
147
149
  }], srcChange: [{
@@ -156,4 +158,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
156
158
  }], uploadType: [{
157
159
  type: Input
158
160
  }] } });
159
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-uploader.component.js","sourceRoot":"","sources":["../../../../../../libs/bonnie-cms/src/lib/media-uploader/media-uploader.component.ts","../../../../../../libs/bonnie-cms/src/lib/media-uploader/media-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { HttpClient, HttpEvent, HttpEventType, HttpRequest } from '@angular/common/http';\r\nimport { catchError, last, map, Observable } from 'rxjs';\r\n\r\nimport { MediaObjectFit, PixMediaUnion } from '@candy-kingdom/bonnie';\r\nimport { MediaType } from '../core';\r\n\r\nconst imageMimeTypes = ['image/png', 'image/jpeg'];\r\nconst videoMimeTypes = ['video/mp4'];\r\n\r\nconst imageFileTypes = imageMimeTypes.join(',');\r\nconst videoFileTypes = videoMimeTypes.join(',');\r\n\r\nconst allMediaFileTypes = `${imageFileTypes},${videoFileTypes}`;\r\n\r\n@Component({\r\n  selector: 'bonc-media-uploader',\r\n  templateUrl: './media-uploader.component.html',\r\n  styleUrls: ['./media-uploader.component.scss']\r\n})\r\nexport class MediaUploaderComponent {\r\n  public readonly MediaObjectFit = MediaObjectFit;\r\n\r\n  @ViewChild('fileInput', { static: true })\r\n  public fileInput!: ElementRef<HTMLInputElement>;\r\n\r\n  @Output()\r\n  public srcChange = new EventEmitter<PixMediaUnion>();\r\n\r\n  @Input({ required: true })\r\n  public uploadUrlMap!: ReadonlyMap<MediaType, string>;\r\n\r\n  @Input()\r\n  public forceRatio?: number;\r\n\r\n  public progress = 0;\r\n  public isUploading = false;\r\n\r\n  public autoplay = true;\r\n  public clipStyle?: SafeStyle;\r\n  public fileTypeMask = allMediaFileTypes;\r\n\r\n  private _uploadType?: MediaType;\r\n  private _src?: PixMediaUnion;\r\n\r\n  constructor(private sanitizer: DomSanitizer, private http: HttpClient) {\r\n  }\r\n\r\n  @Input()\r\n  public set src(newSrc: PixMediaUnion | undefined) {\r\n    if (this._src === newSrc)\r\n      return;\r\n\r\n    this._src = newSrc;\r\n  }\r\n\r\n  public get src(): PixMediaUnion | undefined {\r\n    return this._src;\r\n  }\r\n\r\n  @Input()\r\n  public set uploadType(newUploadType: MediaType | undefined) {\r\n    switch (newUploadType) {\r\n      case \"image\":\r\n        this._uploadType = newUploadType;\r\n        this.fileTypeMask = imageFileTypes;\r\n        break;\r\n\r\n      case \"video\":\r\n        this._uploadType = newUploadType;\r\n        this.fileTypeMask = videoFileTypes;\r\n        break;\r\n\r\n      case undefined:\r\n      default:\r\n        this._uploadType = newUploadType;\r\n        this.fileTypeMask = allMediaFileTypes;\r\n        break;\r\n    }\r\n  }\r\n\r\n  public get uploadType(): MediaType | undefined {\r\n    return this._uploadType;\r\n  }\r\n\r\n  public onFileSelect(fileInput: HTMLInputElement) {\r\n    if (fileInput.files === undefined || fileInput.files === null || fileInput.files.length !== 1)\r\n      return;\r\n\r\n    const file = fileInput.files[0];\r\n\r\n    let uploadingMediaType: MediaType;\r\n\r\n    if (this._uploadType !== undefined && this._uploadType !== null) {\r\n      uploadingMediaType = this._uploadType;\r\n    }\r\n    else if (imageMimeTypes.includes(file.type)) {\r\n      uploadingMediaType = 'image';\r\n    }\r\n    else if (videoMimeTypes.includes(file.type)) {\r\n      uploadingMediaType = 'video';\r\n    }\r\n    else {\r\n      console.error(`unknown media type ${file.type} (${file.name})`);\r\n      return;\r\n    }\r\n\r\n    const uploadUrl = this.uploadUrlMap.get(uploadingMediaType);\r\n\r\n    if (uploadUrl === undefined || uploadUrl === null) {\r\n      console.error(`upload map doesn't have url for type ${uploadingMediaType}`);\r\n      return;\r\n    }\r\n\r\n    const formData: FormData = new FormData();\r\n\r\n    formData.append('file', file);\r\n    formData.append('ratio', `${this.forceRatio ?? 0}`);\r\n\r\n    this.progress = 0;\r\n    this.isUploading = true;\r\n\r\n    this.updateClip();\r\n\r\n    const request = new HttpRequest('POST', uploadUrl, formData, {\r\n      reportProgress: true\r\n    });\r\n\r\n    this.http\r\n      .request<PixMediaUnion>(request)\r\n      .pipe\r\n      (\r\n        map(event => this.getEventMessage(event)),\r\n        // tap(message => this.showProgress(message)),\r\n        last(), // return last (completed) message to caller\r\n        catchError(this.handleError(file))\r\n      ).subscribe\r\n      (\r\n        () => { this.isUploading = false; }\r\n      );\r\n  }\r\n\r\n  public selectFile(event: Event): void {\r\n    // ignore buble click on file picker\r\n    if (event.target === this.fileInput.nativeElement)\r\n      return;\r\n\r\n    this.fileInput.nativeElement.click();\r\n  }\r\n\r\n  private getEventMessage(event: HttpEvent<PixMediaUnion>): void {\r\n    switch (event.type) {\r\n      case HttpEventType.Sent:\r\n        return;\r\n\r\n      case HttpEventType.UploadProgress:\r\n        this.progress = event.total === undefined ? 0.5 : event.loaded / event.total;\r\n        this.updateClip();\r\n        return;\r\n\r\n      case HttpEventType.Response:\r\n        if (event.body === undefined || event.body === null) {\r\n          console.error('media deserialization error. Response body in undefined');\r\n        } else {\r\n          // remove this\r\n          // needed for C# deserialization\r\n          const pixmedia = {\r\n            $type: event.body.type,\r\n            ...event.body as any,\r\n          };\r\n\r\n          this.srcChange.emit(pixmedia);\r\n        }\r\n        return;\r\n\r\n      default:\r\n        return;\r\n    }\r\n  }\r\n\r\n  private updateClip(): void {\r\n    this.clipStyle = this.sanitizer.bypassSecurityTrustStyle(`inset(0px 100% 0px 0%)`);\r\n  }\r\n\r\n  private handleError(file: File): (p1: unknown, p2: Observable<unknown>) => Observable<unknown> {\r\n    const func = (error: unknown, p2: Observable<unknown>): Observable<unknown> => {\r\n      const message = `error uploadingFile ${file.name}.`;\r\n      console.error(message, error, p2);\r\n      alert(message);\r\n      return new Observable<unknown>();\r\n    };\r\n\r\n    return func;\r\n  }\r\n}\r\n","<bon-media [src]=\"src\" [objectFit]=\"MediaObjectFit.Cover\"></bon-media>\r\n\r\n<div *ngIf=\"src?.sources?.length===0\">Upload media</div>\r\n\r\n<div (click)=\"selectFile($event)\" class=\"media-container\">\r\n  <input #fileInput [accept]=\"fileTypeMask\" (change)=\"onFileSelect(fileInput)\" name=\"media\" type=\"file\" />\r\n  <span *ngIf=\"isUploading\"\r\n        [style.clip-path]=\"clipStyle\"\r\n        [style.-webkit-clip-path]=\"clipStyle\"\r\n        class=\"loader\"></span>\r\n\r\n  <span *ngIf=\"isUploading\" class=\"loader-text\">\r\n    <span *ngIf=\"progress < 1\">{{100 * progress | number: '1.0-0'}}%</span>\r\n    <span *ngIf=\"progress >= 1\">converting</span>\r\n  </span>\r\n</div>\r\n"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-uploader.component.js","sourceRoot":"","sources":["../../../../../../libs/bonnie-cms/src/lib/media-uploader/media-uploader.component.ts","../../../../../../libs/bonnie-cms/src/lib/media-uploader/media-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { HttpClient, HttpEvent, HttpEventType, HttpRequest } from '@angular/common/http';\r\nimport { catchError, last, map, Observable } from 'rxjs';\r\n\r\nimport { MediaObjectFit, PixMediaUnion } from '@candy-kingdom/bonnie';\r\nimport { MediaType } from '../core';\r\n\r\nconst imageMimeTypes = ['image/png', 'image/jpeg'];\r\nconst videoMimeTypes = ['video/mp4'];\r\n\r\nconst imageFileTypes = imageMimeTypes.join(',');\r\nconst videoFileTypes = videoMimeTypes.join(',');\r\n\r\nconst allMediaFileTypes = `${imageFileTypes},${videoFileTypes}`;\r\n\r\n@Component({\r\n  selector: 'bonc-media-uploader',\r\n  templateUrl: './media-uploader.component.html',\r\n  styleUrls: ['./media-uploader.component.scss']\r\n})\r\nexport class MediaUploaderComponent {\r\n  public readonly MediaObjectFit = MediaObjectFit;\r\n\r\n  @ViewChild('fileInput', { static: true })\r\n  public fileInput!: ElementRef<HTMLInputElement>;\r\n\r\n  @Output()\r\n  public srcChange = new EventEmitter<PixMediaUnion>();\r\n\r\n  @Input({ required: true })\r\n  public uploadUrlMap!: ReadonlyMap<MediaType, string>;\r\n\r\n  @Input()\r\n  public forceRatio?: number;\r\n\r\n  public progress = 0;\r\n  public isUploading = false;\r\n\r\n  public autoplay = true;\r\n  public clipStyle?: SafeStyle;\r\n  public fileTypeMask = allMediaFileTypes;\r\n\r\n  private _uploadType?: MediaType;\r\n  private _src?: PixMediaUnion;\r\n\r\n  constructor(private sanitizer: DomSanitizer, private http: HttpClient, private cd: ChangeDetectorRef) {\r\n  }\r\n\r\n  @Input()\r\n  public set src(newSrc: PixMediaUnion | undefined) {\r\n    if (this._src === newSrc)\r\n      return;\r\n\r\n    this._src = newSrc;\r\n  }\r\n\r\n  public get src(): PixMediaUnion | undefined {\r\n    return this._src;\r\n  }\r\n\r\n  @Input()\r\n  public set uploadType(newUploadType: MediaType | undefined) {\r\n    switch (newUploadType) {\r\n      case \"image\":\r\n        this._uploadType = newUploadType;\r\n        this.fileTypeMask = imageFileTypes;\r\n        break;\r\n\r\n      case \"video\":\r\n        this._uploadType = newUploadType;\r\n        this.fileTypeMask = videoFileTypes;\r\n        break;\r\n\r\n      case undefined:\r\n      default:\r\n        this._uploadType = newUploadType;\r\n        this.fileTypeMask = allMediaFileTypes;\r\n        break;\r\n    }\r\n  }\r\n\r\n  public get uploadType(): MediaType | undefined {\r\n    return this._uploadType;\r\n  }\r\n\r\n  public onFileSelect(fileInput: HTMLInputElement) {\r\n    if (fileInput.files === undefined || fileInput.files === null || fileInput.files.length !== 1)\r\n      return;\r\n\r\n    const file = fileInput.files[0];\r\n\r\n    let uploadingMediaType: MediaType;\r\n\r\n    if (this._uploadType !== undefined && this._uploadType !== null) {\r\n      uploadingMediaType = this._uploadType;\r\n    }\r\n    else if (imageMimeTypes.includes(file.type)) {\r\n      uploadingMediaType = 'image';\r\n    }\r\n    else if (videoMimeTypes.includes(file.type)) {\r\n      uploadingMediaType = 'video';\r\n    }\r\n    else {\r\n      console.error(`unknown media type ${file.type} (${file.name})`);\r\n      return;\r\n    }\r\n\r\n    const uploadUrl = this.uploadUrlMap.get(uploadingMediaType);\r\n\r\n    if (uploadUrl === undefined || uploadUrl === null) {\r\n      console.error(`upload map doesn't have url for type ${uploadingMediaType}`);\r\n      return;\r\n    }\r\n\r\n    const formData: FormData = new FormData();\r\n\r\n    formData.append('file', file);\r\n    formData.append('ratio', `${this.forceRatio ?? 0}`);\r\n\r\n    this.progress = 0;\r\n    this.isUploading = true;\r\n\r\n    this.updateClip();\r\n\r\n    const request = new HttpRequest('POST', uploadUrl, formData, {\r\n      reportProgress: true\r\n    });\r\n\r\n    this.http\r\n      .request<PixMediaUnion>(request)\r\n      .pipe\r\n      (\r\n        map(event => this.getEventMessage(event)),\r\n        // tap(message => this.showProgress(message)),\r\n        last(), // return last (completed) message to caller\r\n        catchError(this.handleError(file))\r\n      ).subscribe\r\n      (\r\n        () => { this.isUploading = false; }\r\n      );\r\n  }\r\n\r\n  public selectFile(event: Event): void {\r\n    // ignore buble click on file picker\r\n    if (event.target === this.fileInput.nativeElement)\r\n      return;\r\n\r\n    this.fileInput.nativeElement.click();\r\n  }\r\n\r\n  private getEventMessage(event: HttpEvent<PixMediaUnion>): void {\r\n    switch (event.type) {\r\n      case HttpEventType.Sent:\r\n        break;\r\n\r\n      case HttpEventType.UploadProgress:\r\n        this.progress = event.total === undefined ? 0.5 : event.loaded / event.total;\r\n        this.updateClip();\r\n        break;\r\n\r\n      case HttpEventType.Response:\r\n        if (event.body === undefined || event.body === null) {\r\n          console.error('media deserialization error. Response body in undefined');\r\n        } else {\r\n          // remove this\r\n          // needed for C# deserialization\r\n          const pixmedia = {\r\n            $type: event.body.type,\r\n            ...event.body as any,\r\n          };\r\n\r\n          this.srcChange.emit(pixmedia);\r\n        }\r\n        break;\r\n\r\n      default:\r\n        break;\r\n    }\r\n\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  private updateClip(): void {\r\n    this.clipStyle = this.sanitizer.bypassSecurityTrustStyle(`inset(0px 100% 0px 0%)`);\r\n  }\r\n\r\n  private handleError(file: File): (p1: unknown, p2: Observable<unknown>) => Observable<unknown> {\r\n    const func = (error: unknown, p2: Observable<unknown>): Observable<unknown> => {\r\n      const message = `error uploadingFile ${file.name}.`;\r\n      console.error(message, error, p2);\r\n      alert(message);\r\n      return new Observable<unknown>();\r\n    };\r\n\r\n    return func;\r\n  }\r\n}\r\n","<bon-media [src]=\"src\" [objectFit]=\"MediaObjectFit.Cover\"></bon-media>\r\n\r\n<div *ngIf=\"src?.sources?.length===0\">Upload media</div>\r\n\r\n<div (click)=\"selectFile($event)\" class=\"media-container\">\r\n  <input #fileInput [accept]=\"fileTypeMask\" (change)=\"onFileSelect(fileInput)\" name=\"media\" type=\"file\" />\r\n  <span *ngIf=\"isUploading\"\r\n        [style.clip-path]=\"clipStyle\"\r\n        [style.-webkit-clip-path]=\"clipStyle\"\r\n        class=\"loader\"></span>\r\n\r\n  <span *ngIf=\"isUploading\" class=\"loader-text\">\r\n    <span *ngIf=\"progress < 1\">{{100 * progress | number: '1.0-0'}}%</span>\r\n    <span *ngIf=\"progress >= 1\">converting</span>\r\n  </span>\r\n</div>\r\n"]}
@@ -647,21 +647,22 @@ class FileUploaderComponent {
647
647
  getEventMessage(event) {
648
648
  switch (event.type) {
649
649
  case HttpEventType.Sent:
650
- return;
650
+ break;
651
651
  case HttpEventType.UploadProgress:
652
652
  this.progress = event.total === undefined ? 0.5 : event.loaded / event.total;
653
653
  this.updateClip();
654
- return;
654
+ break;
655
655
  case HttpEventType.Response:
656
656
  if (event.body === null || event.body === undefined) {
657
657
  console.warn(`empty body from uploader`);
658
- return;
658
+ break;
659
659
  }
660
660
  this.srcChange.emit(event.body);
661
- return;
661
+ break;
662
662
  default:
663
- return;
663
+ break;
664
664
  }
665
+ this.cd.detectChanges();
665
666
  }
666
667
  updateClip() {
667
668
  this.clipStyle = this.sanitizer.bypassSecurityTrustStyle(`inset(0px 100% 0px 0%)`);
@@ -695,67 +696,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
695
696
  type: Input
696
697
  }] } });
697
698
 
698
- const DefaultImageMimeTypes = ['image/png', 'image/jpeg'];
699
- class OneImageFormComponent extends FormBaseComponent {
700
- constructor(editable) {
701
- super(editable);
702
- this.cd = inject(ChangeDetectorRef);
703
- this.uploadMap = new Map();
704
- this._mimeTypes = DefaultImageMimeTypes;
705
- this._uploadUrl = '/api/admin/upload/image';
706
- this._label = '';
707
- this.uploadMap.set('', this._uploadUrl);
708
- }
709
- ngOnInit() {
710
- this.editable.externalSaveCall.subscribe(() => {
711
- this.editable.save();
712
- });
713
- }
714
- set label(newValue) {
715
- this._label = newValue;
716
- }
717
- get label() {
718
- return this._label;
719
- }
720
- set uploadUrl(newValue) {
721
- this._uploadUrl = newValue;
722
- this.uploadMap.set('', this._uploadUrl);
723
- this.cd.detectChanges();
724
- }
725
- set mimeTypes(newValue) {
726
- this._mimeTypes = newValue.length === 0 ? DefaultImageMimeTypes : newValue;
727
- this.cd.detectChanges();
728
- }
729
- get mimeTypes() {
730
- return this._mimeTypes;
731
- }
732
- onFileUploaded(fileSrc) {
733
- this.editable.startEditing();
734
- const svgSrc = fileSrc;
735
- this.editable.value = svgSrc;
736
- this.editable.updateDirty();
737
- }
738
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: OneImageFormComponent, deps: [{ token: EditableDirective, host: true }], target: i0.ɵɵFactoryTarget.Component }); }
739
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: OneImageFormComponent, selector: "bonc-one-image-form", inputs: { label: "label", uploadUrl: "uploadUrl", mimeTypes: "mimeTypes" }, usesInheritance: true, hostDirectives: [{ directive: EditableDirective }], ngImport: i0, template: "<bonc-form-controls [editable]=\"editable\">\r\n <label *ngIf=\"label\">{{label}}</label>\r\n <bonc-file-uploader [src]=\"editable.value\"\r\n [uploadTypes]=\"mimeTypes\"\r\n [uploadUrlMap]=\"uploadMap\"\r\n (srcChange)=\"onFileUploaded($event)\">\r\n <img *ngIf=\"editable.value?.url?.length ?? 0 > 0\" [src]=\"editable.value?.url\" />\r\n </bonc-file-uploader>\r\n\r\n <a *ngIf=\"editable.value?.url?.length ?? 0 > 0\" [href]=\"editable.value!.url\" download target=\"_blank\">Download</a>\r\n\r\n</bonc-form-controls>\r\n", styles: [":host{display:block}img{background-image:linear-gradient(45deg,#808080 25%,transparent 25%),linear-gradient(-45deg,#808080 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#808080 75%),linear-gradient(-45deg,transparent 75%,#808080 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;display:block;width:100%}a{color:silver}\n"], dependencies: [{ kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: FormControlsComponent, selector: "bonc-form-controls", inputs: ["editable"] }, { kind: "component", type: FileUploaderComponent, selector: "bonc-file-uploader", inputs: ["uploadUrlMap", "src", "uploadTypes"], outputs: ["srcChange"] }] }); }
740
- }
741
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: OneImageFormComponent, decorators: [{
742
- type: Component,
743
- args: [{ selector: 'bonc-one-image-form', hostDirectives: [EditableDirective], template: "<bonc-form-controls [editable]=\"editable\">\r\n <label *ngIf=\"label\">{{label}}</label>\r\n <bonc-file-uploader [src]=\"editable.value\"\r\n [uploadTypes]=\"mimeTypes\"\r\n [uploadUrlMap]=\"uploadMap\"\r\n (srcChange)=\"onFileUploaded($event)\">\r\n <img *ngIf=\"editable.value?.url?.length ?? 0 > 0\" [src]=\"editable.value?.url\" />\r\n </bonc-file-uploader>\r\n\r\n <a *ngIf=\"editable.value?.url?.length ?? 0 > 0\" [href]=\"editable.value!.url\" download target=\"_blank\">Download</a>\r\n\r\n</bonc-form-controls>\r\n", styles: [":host{display:block}img{background-image:linear-gradient(45deg,#808080 25%,transparent 25%),linear-gradient(-45deg,#808080 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#808080 75%),linear-gradient(-45deg,transparent 75%,#808080 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;display:block;width:100%}a{color:silver}\n"] }]
744
- }], ctorParameters: () => [{ type: EditableDirective, decorators: [{
745
- type: Host
746
- }] }], propDecorators: { label: [{
747
- type: Input
748
- }], uploadUrl: [{
749
- type: Input
750
- }], mimeTypes: [{
751
- type: Input
752
- }] } });
753
-
699
+ const uploadMap = new Map();
700
+ uploadMap.set('', `/api/admin/upload/image?width=${1200}&height=${630}&format=image/jpeg`);
754
701
  class SeoFormComponent extends FormBaseComponent {
755
702
  constructor() {
756
703
  super(...arguments);
757
- this.imageWidth = 1200;
758
- this.imageHeight = 630;
704
+ this.uploadMap = uploadMap;
759
705
  this._pageId = '';
760
706
  this.ogImageUploadUrl = '';
761
707
  this.label = '';
@@ -775,12 +721,19 @@ class SeoFormComponent extends FormBaseComponent {
775
721
  ResToSrc(res) {
776
722
  return res.url;
777
723
  }
724
+ replaceImage($event) {
725
+ this.editable.startEditing();
726
+ if (this.editable.value !== undefined) {
727
+ this.editable.value.image[this.locale] = $event;
728
+ }
729
+ this.editable.updateDirty();
730
+ }
778
731
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SeoFormComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
779
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: SeoFormComponent, selector: "bonc-seo-form", inputs: { label: "label", pageId: "pageId" }, usesInheritance: true, hostDirectives: [{ directive: EditableDirective }], ngImport: i0, template: "<bonc-form-controls *ngIf=\"editable.value\" [editable]=\"editable\">\r\n <h2 *ngIf=\"label\">{{label}}</h2>\r\n\r\n <div class=\"form-group\">\r\n <label>Title</label>\r\n <bonc-translation-input [text]=\"editable.value.title\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-input>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Description</label>\r\n <bonc-translation-textarea [text]=\"editable.value.description\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-textarea>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Share image | 1200x630</label>\r\n\r\n <bonc-one-image-form [(ngModel)]=\"editable.value.image\"\r\n [uploadUrl]=\"'/api/admin/upload/image?width=' + imageWidth + '&height='+imageHeight + '&format=image/jpeg'\"\r\n [locale]=\"locale\">\r\n </bonc-one-image-form>\r\n\r\n </div>\r\n\r\n</bonc-form-controls>\r\n\r\n<div *ngIf=\"!editable.value\">Editable Value canot be null or undefined</div>\r\n", styles: [":host{display:block}bonc-one-image-form{max-width:600px}\n"], dependencies: [{ kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: OneImageFormComponent, selector: "bonc-one-image-form", inputs: ["label", "uploadUrl", "mimeTypes"] }, { kind: "component", type: TranslationInputComponent, selector: "bonc-translation-input", inputs: ["text", "locale", "device"], outputs: ["startEditing", "changed", "blurred"] }, { kind: "component", type: TranslationTextareaComponent, selector: "bonc-translation-textarea", inputs: ["minRows", "maxRows", "text", "locale", "device"], outputs: ["startEditing", "changed", "blurred"] }, { kind: "component", type: FormControlsComponent, selector: "bonc-form-controls", inputs: ["editable"] }] }); }
732
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: SeoFormComponent, selector: "bonc-seo-form", inputs: { label: "label", pageId: "pageId" }, usesInheritance: true, hostDirectives: [{ directive: EditableDirective }], ngImport: i0, template: "<bonc-form-controls *ngIf=\"editable.value\" [editable]=\"editable\">\r\n <h2 *ngIf=\"label\">{{label}}</h2>\r\n\r\n <div class=\"form-group\">\r\n <label>Title</label>\r\n <bonc-translation-input [text]=\"editable.value.title\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-input>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Description</label>\r\n <bonc-translation-textarea [text]=\"editable.value.description\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-textarea>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Share image | 1200x630</label>\r\n\r\n <bonc-file-uploader [src]=\"editable.value.image[locale]\"\r\n [uploadTypes]=\"['image/png', 'image/jpeg']\"\r\n [uploadUrlMap]=\"uploadMap\"\r\n (srcChange)=\"replaceImage($event)\">\r\n <img *ngIf=\"editable.value.image[locale]?.url?.length ?? 0 > 0\" [src]=\"editable.value.image[locale].url\" />\r\n </bonc-file-uploader>\r\n\r\n <a *ngIf=\"editable.value.image[locale]?.url?.length ?? 0 > 0\" [href]=\"editable.value.image[locale].url\" download target=\"_blank\">Download</a>\r\n </div>\r\n\r\n</bonc-form-controls>\r\n\r\n<div *ngIf=\"!editable.value\">Editable Value canot be null or undefined</div>\r\n", styles: [":host{display:block}bonc-one-image-form{max-width:600px}img{display:block;width:100%}\n"], dependencies: [{ kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TranslationInputComponent, selector: "bonc-translation-input", inputs: ["text", "locale", "device"], outputs: ["startEditing", "changed", "blurred"] }, { kind: "component", type: TranslationTextareaComponent, selector: "bonc-translation-textarea", inputs: ["minRows", "maxRows", "text", "locale", "device"], outputs: ["startEditing", "changed", "blurred"] }, { kind: "component", type: FormControlsComponent, selector: "bonc-form-controls", inputs: ["editable"] }, { kind: "component", type: FileUploaderComponent, selector: "bonc-file-uploader", inputs: ["uploadUrlMap", "src", "uploadTypes"], outputs: ["srcChange"] }] }); }
780
733
  }
781
734
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SeoFormComponent, decorators: [{
782
735
  type: Component,
783
- args: [{ selector: 'bonc-seo-form', hostDirectives: [EditableDirective], template: "<bonc-form-controls *ngIf=\"editable.value\" [editable]=\"editable\">\r\n <h2 *ngIf=\"label\">{{label}}</h2>\r\n\r\n <div class=\"form-group\">\r\n <label>Title</label>\r\n <bonc-translation-input [text]=\"editable.value.title\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-input>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Description</label>\r\n <bonc-translation-textarea [text]=\"editable.value.description\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-textarea>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Share image | 1200x630</label>\r\n\r\n <bonc-one-image-form [(ngModel)]=\"editable.value.image\"\r\n [uploadUrl]=\"'/api/admin/upload/image?width=' + imageWidth + '&height='+imageHeight + '&format=image/jpeg'\"\r\n [locale]=\"locale\">\r\n </bonc-one-image-form>\r\n\r\n </div>\r\n\r\n</bonc-form-controls>\r\n\r\n<div *ngIf=\"!editable.value\">Editable Value canot be null or undefined</div>\r\n", styles: [":host{display:block}bonc-one-image-form{max-width:600px}\n"] }]
736
+ args: [{ selector: 'bonc-seo-form', hostDirectives: [EditableDirective], template: "<bonc-form-controls *ngIf=\"editable.value\" [editable]=\"editable\">\r\n <h2 *ngIf=\"label\">{{label}}</h2>\r\n\r\n <div class=\"form-group\">\r\n <label>Title</label>\r\n <bonc-translation-input [text]=\"editable.value.title\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-input>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Description</label>\r\n <bonc-translation-textarea [text]=\"editable.value.description\"\r\n [locale]=\"locale\"\r\n (startEditing)=\"editable.startEditing()\"\r\n (changed)=\"editable.updateDirty()\"\r\n (blurred)=\"editable.updateDirty()\">\r\n </bonc-translation-textarea>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <label>Share image | 1200x630</label>\r\n\r\n <bonc-file-uploader [src]=\"editable.value.image[locale]\"\r\n [uploadTypes]=\"['image/png', 'image/jpeg']\"\r\n [uploadUrlMap]=\"uploadMap\"\r\n (srcChange)=\"replaceImage($event)\">\r\n <img *ngIf=\"editable.value.image[locale]?.url?.length ?? 0 > 0\" [src]=\"editable.value.image[locale].url\" />\r\n </bonc-file-uploader>\r\n\r\n <a *ngIf=\"editable.value.image[locale]?.url?.length ?? 0 > 0\" [href]=\"editable.value.image[locale].url\" download target=\"_blank\">Download</a>\r\n </div>\r\n\r\n</bonc-form-controls>\r\n\r\n<div *ngIf=\"!editable.value\">Editable Value canot be null or undefined</div>\r\n", styles: [":host{display:block}bonc-one-image-form{max-width:600px}img{display:block;width:100%}\n"] }]
784
737
  }], propDecorators: { label: [{
785
738
  type: Input
786
739
  }], pageId: [{
@@ -827,6 +780,62 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
827
780
  type: Input
828
781
  }] } });
829
782
 
783
+ const DefaultImageMimeTypes = ['image/png', 'image/jpeg'];
784
+ class OneImageFormComponent extends FormBaseComponent {
785
+ constructor(editable) {
786
+ super(editable);
787
+ this.cd = inject(ChangeDetectorRef);
788
+ this.uploadMap = new Map();
789
+ this._mimeTypes = DefaultImageMimeTypes;
790
+ this._uploadUrl = '/api/admin/upload/image';
791
+ this._label = '';
792
+ this.uploadMap.set('', this._uploadUrl);
793
+ }
794
+ ngOnInit() {
795
+ this.editable.externalSaveCall.subscribe(() => {
796
+ this.editable.save();
797
+ });
798
+ }
799
+ set label(newValue) {
800
+ this._label = newValue;
801
+ }
802
+ get label() {
803
+ return this._label;
804
+ }
805
+ set uploadUrl(newValue) {
806
+ this._uploadUrl = newValue;
807
+ this.uploadMap.set('', this._uploadUrl);
808
+ this.cd.detectChanges();
809
+ }
810
+ set mimeTypes(newValue) {
811
+ this._mimeTypes = newValue.length === 0 ? DefaultImageMimeTypes : newValue;
812
+ this.cd.detectChanges();
813
+ }
814
+ get mimeTypes() {
815
+ return this._mimeTypes;
816
+ }
817
+ onFileUploaded(fileSrc) {
818
+ this.editable.startEditing();
819
+ const svgSrc = fileSrc;
820
+ this.editable.value = svgSrc;
821
+ this.editable.updateDirty();
822
+ }
823
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: OneImageFormComponent, deps: [{ token: EditableDirective, host: true }], target: i0.ɵɵFactoryTarget.Component }); }
824
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: OneImageFormComponent, selector: "bonc-one-image-form", inputs: { label: "label", uploadUrl: "uploadUrl", mimeTypes: "mimeTypes" }, usesInheritance: true, hostDirectives: [{ directive: EditableDirective }], ngImport: i0, template: "<bonc-form-controls [editable]=\"editable\">\r\n <label *ngIf=\"label\">{{label}}</label>\r\n <bonc-file-uploader [src]=\"editable.value\"\r\n [uploadTypes]=\"mimeTypes\"\r\n [uploadUrlMap]=\"uploadMap\"\r\n (srcChange)=\"onFileUploaded($event)\">\r\n <img *ngIf=\"editable.value?.url?.length ?? 0 > 0\" [src]=\"editable.value?.url\" />\r\n </bonc-file-uploader>\r\n\r\n <a *ngIf=\"editable.value?.url?.length ?? 0 > 0\" [href]=\"editable.value!.url\" download target=\"_blank\">Download</a>\r\n\r\n</bonc-form-controls>\r\n", styles: [":host{display:block}img{background-image:linear-gradient(45deg,#808080 25%,transparent 25%),linear-gradient(-45deg,#808080 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#808080 75%),linear-gradient(-45deg,transparent 75%,#808080 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;display:block;width:100%}a{color:silver}\n"], dependencies: [{ kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: FormControlsComponent, selector: "bonc-form-controls", inputs: ["editable"] }, { kind: "component", type: FileUploaderComponent, selector: "bonc-file-uploader", inputs: ["uploadUrlMap", "src", "uploadTypes"], outputs: ["srcChange"] }] }); }
825
+ }
826
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: OneImageFormComponent, decorators: [{
827
+ type: Component,
828
+ args: [{ selector: 'bonc-one-image-form', hostDirectives: [EditableDirective], template: "<bonc-form-controls [editable]=\"editable\">\r\n <label *ngIf=\"label\">{{label}}</label>\r\n <bonc-file-uploader [src]=\"editable.value\"\r\n [uploadTypes]=\"mimeTypes\"\r\n [uploadUrlMap]=\"uploadMap\"\r\n (srcChange)=\"onFileUploaded($event)\">\r\n <img *ngIf=\"editable.value?.url?.length ?? 0 > 0\" [src]=\"editable.value?.url\" />\r\n </bonc-file-uploader>\r\n\r\n <a *ngIf=\"editable.value?.url?.length ?? 0 > 0\" [href]=\"editable.value!.url\" download target=\"_blank\">Download</a>\r\n\r\n</bonc-form-controls>\r\n", styles: [":host{display:block}img{background-image:linear-gradient(45deg,#808080 25%,transparent 25%),linear-gradient(-45deg,#808080 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#808080 75%),linear-gradient(-45deg,transparent 75%,#808080 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;display:block;width:100%}a{color:silver}\n"] }]
829
+ }], ctorParameters: () => [{ type: EditableDirective, decorators: [{
830
+ type: Host
831
+ }] }], propDecorators: { label: [{
832
+ type: Input
833
+ }], uploadUrl: [{
834
+ type: Input
835
+ }], mimeTypes: [{
836
+ type: Input
837
+ }] } });
838
+
830
839
  class FileFormComponent extends FormBaseComponent {
831
840
  constructor() {
832
841
  super(...arguments);
@@ -1120,9 +1129,10 @@ const imageFileTypes = imageMimeTypes.join(',');
1120
1129
  const videoFileTypes = videoMimeTypes.join(',');
1121
1130
  const allMediaFileTypes = `${imageFileTypes},${videoFileTypes}`;
1122
1131
  class MediaUploaderComponent {
1123
- constructor(sanitizer, http) {
1132
+ constructor(sanitizer, http, cd) {
1124
1133
  this.sanitizer = sanitizer;
1125
1134
  this.http = http;
1135
+ this.cd = cd;
1126
1136
  this.MediaObjectFit = MediaObjectFit;
1127
1137
  this.srcChange = new EventEmitter();
1128
1138
  this.progress = 0;
@@ -1206,11 +1216,11 @@ class MediaUploaderComponent {
1206
1216
  getEventMessage(event) {
1207
1217
  switch (event.type) {
1208
1218
  case HttpEventType.Sent:
1209
- return;
1219
+ break;
1210
1220
  case HttpEventType.UploadProgress:
1211
1221
  this.progress = event.total === undefined ? 0.5 : event.loaded / event.total;
1212
1222
  this.updateClip();
1213
- return;
1223
+ break;
1214
1224
  case HttpEventType.Response:
1215
1225
  if (event.body === undefined || event.body === null) {
1216
1226
  console.error('media deserialization error. Response body in undefined');
@@ -1224,10 +1234,11 @@ class MediaUploaderComponent {
1224
1234
  };
1225
1235
  this.srcChange.emit(pixmedia);
1226
1236
  }
1227
- return;
1237
+ break;
1228
1238
  default:
1229
- return;
1239
+ break;
1230
1240
  }
1241
+ this.cd.detectChanges();
1231
1242
  }
1232
1243
  updateClip() {
1233
1244
  this.clipStyle = this.sanitizer.bypassSecurityTrustStyle(`inset(0px 100% 0px 0%)`);
@@ -1241,13 +1252,13 @@ class MediaUploaderComponent {
1241
1252
  };
1242
1253
  return func;
1243
1254
  }
1244
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MediaUploaderComponent, deps: [{ token: i1$1.DomSanitizer }, { token: i1$2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
1255
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MediaUploaderComponent, deps: [{ token: i1$1.DomSanitizer }, { token: i1$2.HttpClient }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
1245
1256
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: MediaUploaderComponent, selector: "bonc-media-uploader", inputs: { uploadUrlMap: "uploadUrlMap", forceRatio: "forceRatio", src: "src", uploadType: "uploadType" }, outputs: { srcChange: "srcChange" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, static: true }], ngImport: i0, template: "<bon-media [src]=\"src\" [objectFit]=\"MediaObjectFit.Cover\"></bon-media>\r\n\r\n<div *ngIf=\"src?.sources?.length===0\">Upload media</div>\r\n\r\n<div (click)=\"selectFile($event)\" class=\"media-container\">\r\n <input #fileInput [accept]=\"fileTypeMask\" (change)=\"onFileSelect(fileInput)\" name=\"media\" type=\"file\" />\r\n <span *ngIf=\"isUploading\"\r\n [style.clip-path]=\"clipStyle\"\r\n [style.-webkit-clip-path]=\"clipStyle\"\r\n class=\"loader\"></span>\r\n\r\n <span *ngIf=\"isUploading\" class=\"loader-text\">\r\n <span *ngIf=\"progress < 1\">{{100 * progress | number: '1.0-0'}}%</span>\r\n <span *ngIf=\"progress >= 1\">converting</span>\r\n </span>\r\n</div>\r\n", styles: [":host{display:block;background-color:#000;position:relative}.media-container{display:block;position:absolute;inset:0;cursor:pointer}.media-container:hover:hover:after{display:flex;justify-content:center;align-items:center;content:\"\";position:absolute;color:silver;inset:0;font-weight:700;font-size:50pt;pointer-events:none;background-color:#ccff00b3}.media-container img,.media-container video{display:block;position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}input[type=file]{display:none}.loader{position:absolute;inset:0;background-color:#cf0}.loader-text{background-color:#000;position:absolute;top:50%;left:0;right:0;text-align:center;font-size:20pt;margin-top:-10pt;color:#fff}\n"], dependencies: [{ kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MarcyMediaComponent, selector: "bon-media", inputs: ["src", "objectFit"], outputs: ["isLoaded"] }, { kind: "pipe", type: i2$1.DecimalPipe, name: "number" }] }); }
1246
1257
  }
1247
1258
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MediaUploaderComponent, decorators: [{
1248
1259
  type: Component,
1249
1260
  args: [{ selector: 'bonc-media-uploader', template: "<bon-media [src]=\"src\" [objectFit]=\"MediaObjectFit.Cover\"></bon-media>\r\n\r\n<div *ngIf=\"src?.sources?.length===0\">Upload media</div>\r\n\r\n<div (click)=\"selectFile($event)\" class=\"media-container\">\r\n <input #fileInput [accept]=\"fileTypeMask\" (change)=\"onFileSelect(fileInput)\" name=\"media\" type=\"file\" />\r\n <span *ngIf=\"isUploading\"\r\n [style.clip-path]=\"clipStyle\"\r\n [style.-webkit-clip-path]=\"clipStyle\"\r\n class=\"loader\"></span>\r\n\r\n <span *ngIf=\"isUploading\" class=\"loader-text\">\r\n <span *ngIf=\"progress < 1\">{{100 * progress | number: '1.0-0'}}%</span>\r\n <span *ngIf=\"progress >= 1\">converting</span>\r\n </span>\r\n</div>\r\n", styles: [":host{display:block;background-color:#000;position:relative}.media-container{display:block;position:absolute;inset:0;cursor:pointer}.media-container:hover:hover:after{display:flex;justify-content:center;align-items:center;content:\"\";position:absolute;color:silver;inset:0;font-weight:700;font-size:50pt;pointer-events:none;background-color:#ccff00b3}.media-container img,.media-container video{display:block;position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}input[type=file]{display:none}.loader{position:absolute;inset:0;background-color:#cf0}.loader-text{background-color:#000;position:absolute;top:50%;left:0;right:0;text-align:center;font-size:20pt;margin-top:-10pt;color:#fff}\n"] }]
1250
- }], ctorParameters: () => [{ type: i1$1.DomSanitizer }, { type: i1$2.HttpClient }], propDecorators: { fileInput: [{
1261
+ }], ctorParameters: () => [{ type: i1$1.DomSanitizer }, { type: i1$2.HttpClient }, { type: i0.ChangeDetectorRef }], propDecorators: { fileInput: [{
1251
1262
  type: ViewChild,
1252
1263
  args: ['fileInput', { static: true }]
1253
1264
  }], srcChange: [{