@ardium-ui/ui 4.4.1 → 4.4.2
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/esm2022/lib/_internal/ngmodel-component.mjs +3 -1
- package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.component.mjs +3 -3
- package/esm2022/lib/file-inputs/file-input/file-input.component.mjs +3 -3
- package/esm2022/lib/file-inputs/file-input-base.mjs +38 -15
- package/esm2022/lib/inputs/number-input/number-input.component.mjs +6 -1
- package/fesm2022/ardium-ui-ui.mjs +47 -17
- package/fesm2022/ardium-ui-ui.mjs.map +1 -1
- package/lib/_internal/ngmodel-component.d.ts +1 -1
- package/lib/file-inputs/file-input-base.d.ts +7 -3
- package/lib/inputs/number-input/number-input.component.d.ts +1 -0
- package/package.json +1 -1
- package/prebuilt-themes/default/inputs/file-input.css +9 -4
- package/prebuilt-themes/default/inputs/file-input.css.map +1 -1
- package/themes/default/inputs/file-input.scss +10 -2
|
@@ -60,6 +60,8 @@ export class _NgModelComponentBase extends _FocusableComponentBase {
|
|
|
60
60
|
this._shouldEmitTouched = true;
|
|
61
61
|
super.onBlur(event);
|
|
62
62
|
setTimeout(() => {
|
|
63
|
+
// if the component is immediately focused back (i.e. when changing focus between elements within the component)
|
|
64
|
+
// the touched event will not be fired
|
|
63
65
|
if (!this._shouldEmitTouched)
|
|
64
66
|
return;
|
|
65
67
|
this.wasTouched.set(true);
|
|
@@ -96,4 +98,4 @@ export class _NgModelComponentBase extends _FocusableComponentBase {
|
|
|
96
98
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: _NgModelComponentBase, decorators: [{
|
|
97
99
|
type: Directive
|
|
98
100
|
}] });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngmodel-component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/_internal/ngmodel-component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  Directive,\r\n  inject,\r\n  Injector,\r\n  input,\r\n  OnDestroy,\r\n  OnInit,\r\n  runInInjectionContext,\r\n  Signal,\r\n  signal,\r\n} from '@angular/core';\r\nimport { toObservable } from '@angular/core/rxjs-interop';\r\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { map, Subscription } from 'rxjs';\r\nimport { TakeChance as Random } from 'take-chance';\r\nimport { _FocusableComponentBase, _focusableComponentDefaults, _FocusableComponentDefaults } from './focusable-component';\r\n\r\nexport interface _NgModelComponentDefaults extends _FocusableComponentDefaults {\r\n}\r\n\r\nexport const _ngModelComponentDefaults: _NgModelComponentDefaults = {\r\n  ..._focusableComponentDefaults,\r\n};\r\n\r\n/**\r\n * Common code for components which implement the ControlValueAccessor.\r\n *\r\n * **Warning**: `writeValue` function should be implemented on the child component!\r\n */\r\n@Directive()\r\nexport abstract class _NgModelComponentBase extends _FocusableComponentBase implements ControlValueAccessor, OnInit, OnDestroy {\r\n  protected override readonly _DEFAULTS!: _NgModelComponentDefaults;\r\n\r\n  //! control value accessor\r\n  protected _onChangeRegistered!: (_: any) => void;\r\n  protected _onTouchedRegistered!: () => void;\r\n  /**\r\n   * Registers a function to handle touched state. Required by ControlValueAccessor.\r\n   * @param fn The function to register.\r\n   */\r\n  registerOnTouched(fn: () => void): void {\r\n    this._onTouchedRegistered = fn;\r\n  }\r\n  /**\r\n   * Registers a function to handle value change. Required by ControlValueAccessor.\r\n   * @param fn The function to register.\r\n   */\r\n  registerOnChange(fn: (_: any) => void): void {\r\n    this._onChangeRegistered = fn;\r\n  }\r\n  /**\r\n   * Sets the component's disabled state. Required by ControlValueAccessor.\r\n   * @param isDisabled the new disabled state.\r\n   */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled.set(isDisabled);\r\n  }\r\n\r\n  /**\r\n   * Writes the a new value into the component. Required by ControlValueAccessor.\r\n   * @abstract\r\n   * @param v The new value to write.\r\n   */\r\n  abstract writeValue(v: any): void; //* abstract\r\n\r\n  /**\r\n   * Writes the a new value into the component. Required by ControlValueAccessor.\r\n   * @abstract\r\n   * @param v The new value to write.\r\n   */\r\n  protected abstract _emitChange(): void; //* abstract\r\n\r\n  //! event handlers\r\n  readonly wasTouched = signal<boolean>(false);\r\n\r\n  override onFocus(event: FocusEvent): void {\r\n    super.onFocus(event);\r\n    this._shouldEmitTouched = false;\r\n  }\r\n\r\n  private _shouldEmitTouched = false;\r\n  override onBlur(event: FocusEvent) {\r\n    this._shouldEmitTouched = true;\r\n    super.onBlur(event);\r\n\r\n    setTimeout(() => {\r\n      if (!this._shouldEmitTouched) return;\r\n      this.wasTouched.set(true);\r\n      this._onTouchedRegistered?.();\r\n    }, 0);\r\n  }\r\n\r\n  //! form field related\r\n  protected readonly _injector = inject(Injector);\r\n\r\n  private _statusChangesSub?: Subscription;\r\n  ngOnInit(): void {\r\n    this._ngControl = this._injector.get(NgControl, null);\r\n\r\n    if (this._ngControl) {\r\n      if (!this._ngControl.valueAccessor || (this && this instanceof (this._ngControl.valueAccessor as any).constructor)) {\r\n        this._ngControl.valueAccessor = this;\r\n      }\r\n\r\n      this._hasErrorInControl.set(this._ngControl.status === 'INVALID');\r\n\r\n      this._statusChangesSub = this._ngControl.statusChanges\r\n        ?.pipe(map(v => v === 'INVALID'))\r\n        .subscribe(v => this._hasErrorInControl.set(v));\r\n\r\n      if (!this._ngControl.control) return;\r\n\r\n      runInInjectionContext(this._injector, () => {\r\n        // do not read the next line of code if you are easily frightened\r\n        // I'm not proud of this part, but it had to be done. God please forgive me\r\n        // I didn't find any other feasible way to detect when the control changes its touched state\r\n        // so it had to be hacked like this\r\n        toObservable((this._ngControl?.control as any | undefined)?.touchedReactive as Signal<boolean>)?.subscribe(v =>\r\n          this.wasTouched.set(v)\r\n        );\r\n      });\r\n    }\r\n  }\r\n  protected _ngControl: NgControl | null = null;\r\n\r\n  readonly htmlId = input<string>(Random.id());\r\n\r\n  readonly _hasError = input<boolean | undefined, any>(undefined, {\r\n    transform: v => coerceBooleanProperty(v),\r\n    alias: 'hasError',\r\n  });\r\n  private readonly _hasErrorInControl = signal<boolean>(false);\r\n  readonly hasError = computed<boolean>(() => this._hasError() ?? (this.wasTouched() && this._hasErrorInControl()));\r\n\r\n  ngOnDestroy(): void {\r\n    this._statusChangesSub?.unsubscribe();\r\n  }\r\n}\r\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngmodel-component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/_internal/ngmodel-component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  Directive,\r\n  inject,\r\n  Injector,\r\n  input,\r\n  OnDestroy,\r\n  OnInit,\r\n  runInInjectionContext,\r\n  Signal,\r\n  signal,\r\n} from '@angular/core';\r\nimport { toObservable } from '@angular/core/rxjs-interop';\r\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { map, Subscription } from 'rxjs';\r\nimport { TakeChance as Random } from 'take-chance';\r\nimport { _FocusableComponentBase, _focusableComponentDefaults, _FocusableComponentDefaults } from './focusable-component';\r\n\r\nexport interface _NgModelComponentDefaults extends _FocusableComponentDefaults {\r\n}\r\n\r\nexport const _ngModelComponentDefaults: _NgModelComponentDefaults = {\r\n  ..._focusableComponentDefaults,\r\n};\r\n\r\n/**\r\n * Common code for components which implement the ControlValueAccessor.\r\n *\r\n * **Warning**: `writeValue` function should be implemented on the child component!\r\n */\r\n@Directive()\r\nexport abstract class _NgModelComponentBase extends _FocusableComponentBase implements ControlValueAccessor, OnInit, OnDestroy {\r\n  protected override readonly _DEFAULTS!: _NgModelComponentDefaults;\r\n\r\n  //! control value accessor\r\n  protected _onChangeRegistered!: (_: any) => void;\r\n  protected _onTouchedRegistered!: () => void;\r\n  /**\r\n   * Registers a function to handle touched state. Required by ControlValueAccessor.\r\n   * @param fn The function to register.\r\n   */\r\n  registerOnTouched(fn: () => void): void {\r\n    this._onTouchedRegistered = fn;\r\n  }\r\n  /**\r\n   * Registers a function to handle value change. Required by ControlValueAccessor.\r\n   * @param fn The function to register.\r\n   */\r\n  registerOnChange(fn: (_: any) => void): void {\r\n    this._onChangeRegistered = fn;\r\n  }\r\n  /**\r\n   * Sets the component's disabled state. Required by ControlValueAccessor.\r\n   * @param isDisabled the new disabled state.\r\n   */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled.set(isDisabled);\r\n  }\r\n\r\n  /**\r\n   * Writes the a new value into the component. Required by ControlValueAccessor.\r\n   * @abstract\r\n   * @param v The new value to write.\r\n   */\r\n  abstract writeValue(v: any): void; //* abstract\r\n\r\n  /**\r\n   * Writes the a new value into the component. Required by ControlValueAccessor.\r\n   * @abstract\r\n   * @param v The new value to write.\r\n   */\r\n  protected abstract _emitChange(): void; //* abstract\r\n\r\n  //! event handlers\r\n  readonly wasTouched = signal<boolean>(false);\r\n\r\n  override onFocus(event: FocusEvent): void {\r\n    super.onFocus(event);\r\n    this._shouldEmitTouched = false;\r\n  }\r\n\r\n  protected _shouldEmitTouched = false;\r\n  override onBlur(event: FocusEvent) {\r\n    this._shouldEmitTouched = true;\r\n    super.onBlur(event);\r\n\r\n    setTimeout(() => {\r\n      // if the component is immediately focused back (i.e. when changing focus between elements within the component)\r\n      // the touched event will not be fired\r\n      if (!this._shouldEmitTouched) return;\r\n      this.wasTouched.set(true);\r\n      this._onTouchedRegistered?.();\r\n    }, 0);\r\n  }\r\n\r\n  //! form field related\r\n  protected readonly _injector = inject(Injector);\r\n\r\n  private _statusChangesSub?: Subscription;\r\n  ngOnInit(): void {\r\n    this._ngControl = this._injector.get(NgControl, null);\r\n\r\n    if (this._ngControl) {\r\n      if (!this._ngControl.valueAccessor || (this && this instanceof (this._ngControl.valueAccessor as any).constructor)) {\r\n        this._ngControl.valueAccessor = this;\r\n      }\r\n\r\n      this._hasErrorInControl.set(this._ngControl.status === 'INVALID');\r\n\r\n      this._statusChangesSub = this._ngControl.statusChanges\r\n        ?.pipe(map(v => v === 'INVALID'))\r\n        .subscribe(v => this._hasErrorInControl.set(v));\r\n\r\n      if (!this._ngControl.control) return;\r\n\r\n      runInInjectionContext(this._injector, () => {\r\n        // do not read the next line of code if you are easily frightened\r\n        // I'm not proud of this part, but it had to be done. God please forgive me\r\n        // I didn't find any other feasible way to detect when the control changes its touched state\r\n        // so it had to be hacked like this\r\n        toObservable((this._ngControl?.control as any | undefined)?.touchedReactive as Signal<boolean>)?.subscribe(v =>\r\n          this.wasTouched.set(v)\r\n        );\r\n      });\r\n    }\r\n  }\r\n  protected _ngControl: NgControl | null = null;\r\n\r\n  readonly htmlId = input<string>(Random.id());\r\n\r\n  readonly _hasError = input<boolean | undefined, any>(undefined, {\r\n    transform: v => coerceBooleanProperty(v),\r\n    alias: 'hasError',\r\n  });\r\n  private readonly _hasErrorInControl = signal<boolean>(false);\r\n  readonly hasError = computed<boolean>(() => this._hasError() ?? (this.wasTouched() && this._hasErrorInControl()));\r\n\r\n  ngOnDestroy(): void {\r\n    this._statusChangesSub?.unsubscribe();\r\n  }\r\n}\r\n"]}
|
|
@@ -58,13 +58,13 @@ export class ArdiumFileDropAreaComponent extends _FileInputComponentBase {
|
|
|
58
58
|
};
|
|
59
59
|
}
|
|
60
60
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFileDropAreaComponent, deps: [{ token: ARD_FILE_DROP_AREA_DEFAULTS }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
61
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumFileDropAreaComponent, selector: "ard-file-drop-area", inputs: { variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "idleTemplate", first: true, predicate: ArdiumFileDropAreaIdleContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "dragoverTemplate", first: true, predicate: ArdiumFileDropAreaDragoverContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "uploadedTemplate", first: true, predicate: ArdiumFileDropAreaUploadedContentTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n class=\"ard-file-drop-area\"\r\n (ardClickOutside)=\"onDragleave()\"\r\n (dragleave)=\"onDragleave()\"\r\n (dragover)=\"onDragover($event)\"\r\n (drop)=\"onDrop($event)\"\r\n [ngClass]=\"ngClasses\"\r\n>\r\n <div class=\"ard-file-drop-area-outline\">\r\n <div class=\"ard-file-drop-area-content\">\r\n @if (currentViewState() === 'idle') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n [ngTemplateOutletContext]=\"getIdleContext()\"\r\n />\r\n } @if (currentViewState() === 'dragover') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n />\r\n } @if (currentViewState() === 'uploaded') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n />\r\n }\r\n </div>\r\n </div>\r\n</div>\r\n<input\r\n #fileInput\r\n class=\"ard-file-drop-area-input-element\"\r\n type=\"file\"\r\n [name]=\"name()\"\r\n [multiple]=\"multiple()\"\r\n [id]=\"htmlId()\"\r\n (change)=\"
|
|
61
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumFileDropAreaComponent, selector: "ard-file-drop-area", inputs: { variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "idleTemplate", first: true, predicate: ArdiumFileDropAreaIdleContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "dragoverTemplate", first: true, predicate: ArdiumFileDropAreaDragoverContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "uploadedTemplate", first: true, predicate: ArdiumFileDropAreaUploadedContentTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n class=\"ard-file-drop-area\"\r\n (ardClickOutside)=\"onDragleave()\"\r\n (dragleave)=\"onDragleave()\"\r\n (dragover)=\"onDragover($event)\"\r\n (drop)=\"onDrop($event)\"\r\n [ngClass]=\"ngClasses\"\r\n>\r\n <div class=\"ard-file-drop-area-outline\">\r\n <div class=\"ard-file-drop-area-content\">\r\n @if (currentViewState() === 'idle') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n [ngTemplateOutletContext]=\"getIdleContext()\"\r\n />\r\n } @if (currentViewState() === 'dragover') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n />\r\n } @if (currentViewState() === 'uploaded') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n />\r\n }\r\n </div>\r\n </div>\r\n</div>\r\n<input\r\n #fileInput\r\n class=\"ard-file-drop-area-input-element\"\r\n type=\"file\"\r\n [name]=\"name()\"\r\n [multiple]=\"multiple()\"\r\n [id]=\"htmlId()\"\r\n (change)=\"onFileInputChange()\"\r\n/>\r\n\r\n<ng-template\r\n #defaultIdleTemplate\r\n let-browse=\"browse\"\r\n>\r\n <ard-icon class=\"ard-file-drop-area-icon\">upload</ard-icon>\r\n <strong class=\"ard-file-drop-area-drop-text\">\r\n @if (!multiple) {\r\n <span>Drag & Drop a file</span>\r\n } @else {\r\n <span>Drag & Drop files</span>\r\n } here\r\n </strong>\r\n <span class=\"ard-file-drop-area-or-text\">or</span>\r\n <ard-button\r\n class=\"ard-file-drop-area-browse-button\"\r\n appearance=\"transparent\"\r\n [compact]=\"compact()\"\r\n [variant]=\"variant()\"\r\n [color]=\"color()\"\r\n (click)=\"browse()\"\r\n >\r\n Browse files\r\n </ard-button>\r\n</ng-template>\r\n\r\n<ng-template\r\n #defaultDragoverTemplate\r\n let-amount=\"amount\"\r\n>\r\n <span class=\"ard-file-drop-area-dragover-text\">Drop </span>\r\n <span class=\"ard-file-drop-area-dragover-amount\">\r\n {{ amount }}\r\n <ng-container [ngPlural]=\"amount\">\r\n <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n <ng-template ngPluralCase=\"other\">files</ng-template>\r\n </ng-container>\r\n </span>\r\n <span class=\"ard-file-drop-area-dragover-text\"> here to upload. </span>\r\n @if (amount > 1 && !multiple()) {\r\n <strong class=\"ard-file-drop-area-dragover-warning\"> Only the first file will be uploaded! </strong>\r\n }\r\n</ng-template>\r\n\r\n<ng-template\r\n #defaultUploadedTemplate\r\n let-amount=\"amount\"\r\n let-files=\"files\"\r\n>\r\n <div class=\"ard-file-drop-area-uploaded-container\">\r\n <div class=\"ard-file-drop-area-uploaded-message\">\r\n <span class=\"ard-file-drop-area-uploaded-amount\">\r\n {{ amount }}\r\n <ng-container [ngPlural]=\"amount\">\r\n <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n <ng-template ngPluralCase=\"other\">files</ng-template>\r\n </ng-container>\r\n </span>\r\n <span class=\"ard-file-drop-area-uploaded-text\"> uploaded.</span>\r\n </div>\r\n <div class=\"ard-file-drop-area-uploaded-files\">\r\n @for (file of files; track $index) {\r\n <div class=\"ard-file-drop-area-file\">\r\n <ard-icon>draft</ard-icon>\r\n <div class=\"ard-file-drop-area-file-info\">\r\n <span class=\"ard-file-drop-area-filename\">\r\n <span class=\"ard-file-drop-area-filename-name\">{{ file | filename }}</span>\r\n <span class=\"ard-file-drop-area-filename-ext\">{{ file | fileext : true }}</span>\r\n </span>\r\n <span class=\"ard-file-drop-area-filesize\">{{ file.size | filesize }}</span>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".ard-file-drop-area-input-element{position:absolute;appearance:none;opacity:0;pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgPlural, selector: "[ngPlural]", inputs: ["ngPlural"] }, { kind: "directive", type: i1.NgPluralCase, selector: "[ngPluralCase]" }, { kind: "component", type: i2.ArdiumButtonComponent, selector: "ard-button", inputs: ["icon", "variant", "alignIcon", "vertical"] }, { kind: "component", type: i3.ArdiumIconComponent, selector: "ard-icon", inputs: ["ariaLabel", "icon", "filled", "weight", "grade", "opticalSize"] }, { kind: "directive", type: i4.ArdiumClickOutsideDirective, selector: "[ardClickOutside]", outputs: ["ardClickOutside"] }, { kind: "pipe", type: i4.ArdiumFileExtensionPipe, name: "fileext" }, { kind: "pipe", type: i4.ArdiumFileNamePipe, name: "filename" }, { kind: "pipe", type: i4.ArdiumFileSizePipe, name: "filesize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
62
62
|
}
|
|
63
63
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFileDropAreaComponent, decorators: [{
|
|
64
64
|
type: Component,
|
|
65
|
-
args: [{ selector: 'ard-file-drop-area', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\r\n class=\"ard-file-drop-area\"\r\n (ardClickOutside)=\"onDragleave()\"\r\n (dragleave)=\"onDragleave()\"\r\n (dragover)=\"onDragover($event)\"\r\n (drop)=\"onDrop($event)\"\r\n [ngClass]=\"ngClasses\"\r\n>\r\n <div class=\"ard-file-drop-area-outline\">\r\n <div class=\"ard-file-drop-area-content\">\r\n @if (currentViewState() === 'idle') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n [ngTemplateOutletContext]=\"getIdleContext()\"\r\n />\r\n } @if (currentViewState() === 'dragover') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n />\r\n } @if (currentViewState() === 'uploaded') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n />\r\n }\r\n </div>\r\n </div>\r\n</div>\r\n<input\r\n #fileInput\r\n class=\"ard-file-drop-area-input-element\"\r\n type=\"file\"\r\n [name]=\"name()\"\r\n [multiple]=\"multiple()\"\r\n [id]=\"htmlId()\"\r\n (change)=\"
|
|
65
|
+
args: [{ selector: 'ard-file-drop-area', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\r\n class=\"ard-file-drop-area\"\r\n (ardClickOutside)=\"onDragleave()\"\r\n (dragleave)=\"onDragleave()\"\r\n (dragover)=\"onDragover($event)\"\r\n (drop)=\"onDrop($event)\"\r\n [ngClass]=\"ngClasses\"\r\n>\r\n <div class=\"ard-file-drop-area-outline\">\r\n <div class=\"ard-file-drop-area-content\">\r\n @if (currentViewState() === 'idle') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n [ngTemplateOutletContext]=\"getIdleContext()\"\r\n />\r\n } @if (currentViewState() === 'dragover') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n />\r\n } @if (currentViewState() === 'uploaded') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n />\r\n }\r\n </div>\r\n </div>\r\n</div>\r\n<input\r\n #fileInput\r\n class=\"ard-file-drop-area-input-element\"\r\n type=\"file\"\r\n [name]=\"name()\"\r\n [multiple]=\"multiple()\"\r\n [id]=\"htmlId()\"\r\n (change)=\"onFileInputChange()\"\r\n/>\r\n\r\n<ng-template\r\n #defaultIdleTemplate\r\n let-browse=\"browse\"\r\n>\r\n <ard-icon class=\"ard-file-drop-area-icon\">upload</ard-icon>\r\n <strong class=\"ard-file-drop-area-drop-text\">\r\n @if (!multiple) {\r\n <span>Drag & Drop a file</span>\r\n } @else {\r\n <span>Drag & Drop files</span>\r\n } here\r\n </strong>\r\n <span class=\"ard-file-drop-area-or-text\">or</span>\r\n <ard-button\r\n class=\"ard-file-drop-area-browse-button\"\r\n appearance=\"transparent\"\r\n [compact]=\"compact()\"\r\n [variant]=\"variant()\"\r\n [color]=\"color()\"\r\n (click)=\"browse()\"\r\n >\r\n Browse files\r\n </ard-button>\r\n</ng-template>\r\n\r\n<ng-template\r\n #defaultDragoverTemplate\r\n let-amount=\"amount\"\r\n>\r\n <span class=\"ard-file-drop-area-dragover-text\">Drop </span>\r\n <span class=\"ard-file-drop-area-dragover-amount\">\r\n {{ amount }}\r\n <ng-container [ngPlural]=\"amount\">\r\n <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n <ng-template ngPluralCase=\"other\">files</ng-template>\r\n </ng-container>\r\n </span>\r\n <span class=\"ard-file-drop-area-dragover-text\"> here to upload. </span>\r\n @if (amount > 1 && !multiple()) {\r\n <strong class=\"ard-file-drop-area-dragover-warning\"> Only the first file will be uploaded! </strong>\r\n }\r\n</ng-template>\r\n\r\n<ng-template\r\n #defaultUploadedTemplate\r\n let-amount=\"amount\"\r\n let-files=\"files\"\r\n>\r\n <div class=\"ard-file-drop-area-uploaded-container\">\r\n <div class=\"ard-file-drop-area-uploaded-message\">\r\n <span class=\"ard-file-drop-area-uploaded-amount\">\r\n {{ amount }}\r\n <ng-container [ngPlural]=\"amount\">\r\n <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n <ng-template ngPluralCase=\"other\">files</ng-template>\r\n </ng-container>\r\n </span>\r\n <span class=\"ard-file-drop-area-uploaded-text\"> uploaded.</span>\r\n </div>\r\n <div class=\"ard-file-drop-area-uploaded-files\">\r\n @for (file of files; track $index) {\r\n <div class=\"ard-file-drop-area-file\">\r\n <ard-icon>draft</ard-icon>\r\n <div class=\"ard-file-drop-area-file-info\">\r\n <span class=\"ard-file-drop-area-filename\">\r\n <span class=\"ard-file-drop-area-filename-name\">{{ file | filename }}</span>\r\n <span class=\"ard-file-drop-area-filename-ext\">{{ file | fileext : true }}</span>\r\n </span>\r\n <span class=\"ard-file-drop-area-filesize\">{{ file.size | filesize }}</span>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".ard-file-drop-area-input-element{position:absolute;appearance:none;opacity:0;pointer-events:none}\n"] }]
|
|
66
66
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
67
67
|
type: Inject,
|
|
68
68
|
args: [ARD_FILE_DROP_AREA_DEFAULTS]
|
|
69
69
|
}] }] });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-drop-area.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/file-inputs/file-drop-area/file-drop-area.component.ts","../../../../../../projects/ui/src/lib/file-inputs/file-drop-area/file-drop-area.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,MAAM,EACN,iBAAiB,EACjB,QAAQ,EACR,YAAY,EACZ,KAAK,EACN,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAE7D,OAAO,EAAE,2BAA2B,EAA2B,MAAM,2BAA2B,CAAC;AACjG,OAAO,EACL,kDAAkD,EAClD,8CAA8C,EAC9C,kDAAkD,GACnD,MAAM,6BAA6B,CAAC;;;;;;AASrC,MAAM,OAAO,2BAA4B,SAAQ,uBAAuB;IAEtE,YAAiD,QAAiC;QAChF,KAAK,CAAC,QAAQ,CAAC,CAAC;QAGT,gBAAW,GAAG,KAAK,CAAC;QAE7B,cAAc;QACL,YAAO,GAAG,KAAK,CAAqB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC5D,UAAK,GAAG,KAAK,CAAiB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAEpD,cAAS,GAAG,QAAQ,CAAS,GAAG,EAAE,CACzC,CAAC,eAAe,IAAI,CAAC,OAAO,EAAE,EAAE,EAAE,aAAa,IAAI,CAAC,KAAK,EAAE,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAC9G,CAAC;QAEF,0BAA0B;QAChB,2BAAsB,GAAgB,IAAI,CAAC;QAWrD,aAAa;QACJ,iBAAY,GAAG,YAAY,CAAC,8CAA8C,CAAC,CAAC;QAC5E,qBAAgB,GAAG,YAAY,CAAC,kDAAkD,CAAC,CAAC;QACpF,qBAAgB,GAAG,YAAY,CAAC,kDAAkD,CAAC,CAAC;IA3B7F,CAAC;IAcD,WAAW;QACT,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;IACrC,CAAC;IACD,SAAS;QACP,IAAI,CAAC,IAAI,CAAC,sBAAsB;YAAE,OAAO;QACzC,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;QAEnC,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAOD,cAAc;QACZ,OAAO;YACL,MAAM,EAAE,GAAG,EAAE;gBACX,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,CAAC;SACF,CAAC;IACJ,CAAC;IACD,kBAAkB;QAChB,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,aAAc;YAC3B,MAAM,EAAE,GAAG,EAAE;gBACX,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,CAAC;SACF,CAAC;IACJ,CAAC;IACD,kBAAkB;QAChB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAM,CAAC;QAC1B,OAAO;YACL,SAAS,EAAE,KAAK;YAChB,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,KAAK;YACL,MAAM,EAAE,GAAG,EAAE;gBACX,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,CAAC;SACF,CAAC;IACJ,CAAC;+GA1DU,2BAA2B,kBAElB,2BAA2B;mGAFpC,2BAA2B,sWA6BD,8CAA8C,mGAC1C,kDAAkD,mGAClD,kDAAkD,uFC1D7F,i4HAkHA;;4FDvFa,2BAA2B;kBAPvC,SAAS;+BACE,oBAAoB,iBAGf,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;;0BAIlC,MAAM;2BAAC,2BAA2B","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  Inject,\r\n  ViewEncapsulation,\r\n  computed,\r\n  contentChild,\r\n  input\r\n} from '@angular/core';\r\nimport { ComponentColor } from '../../types/colors.types';\r\nimport { FormElementVariant } from '../../types/theming.types';\r\nimport { _FileInputComponentBase } from '../file-input-base';\r\nimport { FileInputBrowseContext, FileInputFileAmountContext, FileInputFilesContext } from '../file-input-types';\r\nimport { ARD_FILE_DROP_AREA_DEFAULTS, ArdFileDropAreaDefaults } from './file-drop-area.defaults';\r\nimport {\r\n  ArdiumFileDropAreaDragoverContentTemplateDirective,\r\n  ArdiumFileDropAreaIdleContentTemplateDirective,\r\n  ArdiumFileDropAreaUploadedContentTemplateDirective,\r\n} from './file-drop-area.directives';\r\n\r\n@Component({\r\n  selector: 'ard-file-drop-area',\r\n  templateUrl: './file-drop-area.component.html',\r\n  styleUrls: ['./file-drop-area.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ArdiumFileDropAreaComponent extends _FileInputComponentBase {\r\n  protected override readonly _DEFAULTS!: ArdFileDropAreaDefaults;\r\n  constructor(@Inject(ARD_FILE_DROP_AREA_DEFAULTS) defaults: ArdFileDropAreaDefaults) {\r\n    super(defaults);\r\n  }\r\n\r\n  readonly componentId = '010';\r\n\r\n  //! appearance\r\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\r\n  readonly color = input<ComponentColor>(this._DEFAULTS.color);\r\n\r\n  readonly ngClasses = computed<string>(() =>\r\n    [`ard-variant-${this.variant()}`, `ard-color-${this.color()}`, this.compact() ? 'ard-compact' : ''].join(' ')\r\n  );\r\n\r\n  //! triggering file dialog\r\n  protected _wasMousedownOnElement: true | null = null;\r\n  onMousedown(): void {\r\n    this._wasMousedownOnElement = true;\r\n  }\r\n  onMouseup(): void {\r\n    if (!this._wasMousedownOnElement) return;\r\n    this._wasMousedownOnElement = null;\r\n\r\n    this.openBrowseDialog();\r\n  }\r\n\r\n  //! templates\r\n  readonly idleTemplate = contentChild(ArdiumFileDropAreaIdleContentTemplateDirective);\r\n  readonly dragoverTemplate = contentChild(ArdiumFileDropAreaDragoverContentTemplateDirective);\r\n  readonly uploadedTemplate = contentChild(ArdiumFileDropAreaUploadedContentTemplateDirective);\r\n\r\n  getIdleContext(): FileInputBrowseContext {\r\n    return {\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n  getDragoverContext(): FileInputFileAmountContext {\r\n    return {\r\n      amount: this._draggedFiles!,\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n  getUploadedContext(): FileInputFilesContext {\r\n    const files = this.value!;\r\n    return {\r\n      $implicit: files,\r\n      amount: files.length,\r\n      files,\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n}\r\n","<div\r\n  class=\"ard-file-drop-area\"\r\n  (ardClickOutside)=\"onDragleave()\"\r\n  (dragleave)=\"onDragleave()\"\r\n  (dragover)=\"onDragover($event)\"\r\n  (drop)=\"onDrop($event)\"\r\n  [ngClass]=\"ngClasses\"\r\n>\r\n  <div class=\"ard-file-drop-area-outline\">\r\n    <div class=\"ard-file-drop-area-content\">\r\n      @if (currentViewState() === 'idle') {\r\n      <ng-template\r\n        [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n        [ngTemplateOutletContext]=\"getIdleContext()\"\r\n      />\r\n      } @if (currentViewState() === 'dragover') {\r\n      <ng-template\r\n        [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n        [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n      />\r\n      } @if (currentViewState() === 'uploaded') {\r\n      <ng-template\r\n        [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n        [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n      />\r\n      }\r\n    </div>\r\n  </div>\r\n</div>\r\n<input\r\n  #fileInput\r\n  class=\"ard-file-drop-area-input-element\"\r\n  type=\"file\"\r\n  [name]=\"name()\"\r\n  [multiple]=\"multiple()\"\r\n  [id]=\"htmlId()\"\r\n  (change)=\"onInputChange()\"\r\n/>\r\n\r\n<ng-template\r\n  #defaultIdleTemplate\r\n  let-browse=\"browse\"\r\n>\r\n  <ard-icon class=\"ard-file-drop-area-icon\">upload</ard-icon>\r\n  <strong class=\"ard-file-drop-area-drop-text\">\r\n    @if (!multiple) {\r\n    <span>Drag & Drop a file</span>\r\n    } @else {\r\n    <span>Drag & Drop files</span>\r\n    } here\r\n  </strong>\r\n  <span class=\"ard-file-drop-area-or-text\">or</span>\r\n  <ard-button\r\n    class=\"ard-file-drop-area-browse-button\"\r\n    appearance=\"transparent\"\r\n    [compact]=\"compact()\"\r\n    [variant]=\"variant()\"\r\n    [color]=\"color()\"\r\n    (click)=\"browse()\"\r\n  >\r\n    Browse files\r\n  </ard-button>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #defaultDragoverTemplate\r\n  let-amount=\"amount\"\r\n>\r\n  <span class=\"ard-file-drop-area-dragover-text\">Drop </span>\r\n  <span class=\"ard-file-drop-area-dragover-amount\">\r\n    {{ amount }}\r\n    <ng-container [ngPlural]=\"amount\">\r\n      <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n      <ng-template ngPluralCase=\"other\">files</ng-template>\r\n    </ng-container>\r\n  </span>\r\n  <span class=\"ard-file-drop-area-dragover-text\"> here to upload. </span>\r\n  @if (amount > 1 && !multiple()) {\r\n  <strong class=\"ard-file-drop-area-dragover-warning\"> Only the first file will be uploaded! </strong>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template\r\n  #defaultUploadedTemplate\r\n  let-amount=\"amount\"\r\n  let-files=\"files\"\r\n>\r\n  <div class=\"ard-file-drop-area-uploaded-container\">\r\n    <div class=\"ard-file-drop-area-uploaded-message\">\r\n      <span class=\"ard-file-drop-area-uploaded-amount\">\r\n        {{ amount }}\r\n        <ng-container [ngPlural]=\"amount\">\r\n          <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n          <ng-template ngPluralCase=\"other\">files</ng-template>\r\n        </ng-container>\r\n      </span>\r\n      <span class=\"ard-file-drop-area-uploaded-text\"> uploaded.</span>\r\n    </div>\r\n    <div class=\"ard-file-drop-area-uploaded-files\">\r\n      @for (file of files; track $index) {\r\n      <div class=\"ard-file-drop-area-file\">\r\n        <ard-icon>draft</ard-icon>\r\n        <div class=\"ard-file-drop-area-file-info\">\r\n          <span class=\"ard-file-drop-area-filename\">\r\n            <span class=\"ard-file-drop-area-filename-name\">{{ file | filename }}</span>\r\n            <span class=\"ard-file-drop-area-filename-ext\">{{ file | fileext : true }}</span>\r\n          </span>\r\n          <span class=\"ard-file-drop-area-filesize\">{{ file.size | filesize }}</span>\r\n        </div>\r\n      </div>\r\n      }\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-drop-area.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/file-inputs/file-drop-area/file-drop-area.component.ts","../../../../../../projects/ui/src/lib/file-inputs/file-drop-area/file-drop-area.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,MAAM,EACN,iBAAiB,EACjB,QAAQ,EACR,YAAY,EACZ,KAAK,EACN,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAE7D,OAAO,EAAE,2BAA2B,EAA2B,MAAM,2BAA2B,CAAC;AACjG,OAAO,EACL,kDAAkD,EAClD,8CAA8C,EAC9C,kDAAkD,GACnD,MAAM,6BAA6B,CAAC;;;;;;AASrC,MAAM,OAAO,2BAA4B,SAAQ,uBAAuB;IAEtE,YAAiD,QAAiC;QAChF,KAAK,CAAC,QAAQ,CAAC,CAAC;QAGT,gBAAW,GAAG,KAAK,CAAC;QAE7B,cAAc;QACL,YAAO,GAAG,KAAK,CAAqB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC5D,UAAK,GAAG,KAAK,CAAiB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAEpD,cAAS,GAAG,QAAQ,CAAS,GAAG,EAAE,CACzC,CAAC,eAAe,IAAI,CAAC,OAAO,EAAE,EAAE,EAAE,aAAa,IAAI,CAAC,KAAK,EAAE,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAC9G,CAAC;QAEF,0BAA0B;QAChB,2BAAsB,GAAgB,IAAI,CAAC;QAWrD,aAAa;QACJ,iBAAY,GAAG,YAAY,CAAC,8CAA8C,CAAC,CAAC;QAC5E,qBAAgB,GAAG,YAAY,CAAC,kDAAkD,CAAC,CAAC;QACpF,qBAAgB,GAAG,YAAY,CAAC,kDAAkD,CAAC,CAAC;IA3B7F,CAAC;IAcD,WAAW;QACT,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;IACrC,CAAC;IACD,SAAS;QACP,IAAI,CAAC,IAAI,CAAC,sBAAsB;YAAE,OAAO;QACzC,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;QAEnC,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAOD,cAAc;QACZ,OAAO;YACL,MAAM,EAAE,GAAG,EAAE;gBACX,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,CAAC;SACF,CAAC;IACJ,CAAC;IACD,kBAAkB;QAChB,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,aAAc;YAC3B,MAAM,EAAE,GAAG,EAAE;gBACX,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,CAAC;SACF,CAAC;IACJ,CAAC;IACD,kBAAkB;QAChB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAM,CAAC;QAC1B,OAAO;YACL,SAAS,EAAE,KAAK;YAChB,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,KAAK;YACL,MAAM,EAAE,GAAG,EAAE;gBACX,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,CAAC;SACF,CAAC;IACJ,CAAC;+GA1DU,2BAA2B,kBAElB,2BAA2B;mGAFpC,2BAA2B,sWA6BD,8CAA8C,mGAC1C,kDAAkD,mGAClD,kDAAkD,uFC1D7F,q4HAkHA;;4FDvFa,2BAA2B;kBAPvC,SAAS;+BACE,oBAAoB,iBAGf,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;;0BAIlC,MAAM;2BAAC,2BAA2B","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  Inject,\r\n  ViewEncapsulation,\r\n  computed,\r\n  contentChild,\r\n  input\r\n} from '@angular/core';\r\nimport { ComponentColor } from '../../types/colors.types';\r\nimport { FormElementVariant } from '../../types/theming.types';\r\nimport { _FileInputComponentBase } from '../file-input-base';\r\nimport { FileInputBrowseContext, FileInputFileAmountContext, FileInputFilesContext } from '../file-input-types';\r\nimport { ARD_FILE_DROP_AREA_DEFAULTS, ArdFileDropAreaDefaults } from './file-drop-area.defaults';\r\nimport {\r\n  ArdiumFileDropAreaDragoverContentTemplateDirective,\r\n  ArdiumFileDropAreaIdleContentTemplateDirective,\r\n  ArdiumFileDropAreaUploadedContentTemplateDirective,\r\n} from './file-drop-area.directives';\r\n\r\n@Component({\r\n  selector: 'ard-file-drop-area',\r\n  templateUrl: './file-drop-area.component.html',\r\n  styleUrls: ['./file-drop-area.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ArdiumFileDropAreaComponent extends _FileInputComponentBase {\r\n  protected override readonly _DEFAULTS!: ArdFileDropAreaDefaults;\r\n  constructor(@Inject(ARD_FILE_DROP_AREA_DEFAULTS) defaults: ArdFileDropAreaDefaults) {\r\n    super(defaults);\r\n  }\r\n\r\n  readonly componentId = '010';\r\n\r\n  //! appearance\r\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\r\n  readonly color = input<ComponentColor>(this._DEFAULTS.color);\r\n\r\n  readonly ngClasses = computed<string>(() =>\r\n    [`ard-variant-${this.variant()}`, `ard-color-${this.color()}`, this.compact() ? 'ard-compact' : ''].join(' ')\r\n  );\r\n\r\n  //! triggering file dialog\r\n  protected _wasMousedownOnElement: true | null = null;\r\n  onMousedown(): void {\r\n    this._wasMousedownOnElement = true;\r\n  }\r\n  onMouseup(): void {\r\n    if (!this._wasMousedownOnElement) return;\r\n    this._wasMousedownOnElement = null;\r\n\r\n    this.openBrowseDialog();\r\n  }\r\n\r\n  //! templates\r\n  readonly idleTemplate = contentChild(ArdiumFileDropAreaIdleContentTemplateDirective);\r\n  readonly dragoverTemplate = contentChild(ArdiumFileDropAreaDragoverContentTemplateDirective);\r\n  readonly uploadedTemplate = contentChild(ArdiumFileDropAreaUploadedContentTemplateDirective);\r\n\r\n  getIdleContext(): FileInputBrowseContext {\r\n    return {\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n  getDragoverContext(): FileInputFileAmountContext {\r\n    return {\r\n      amount: this._draggedFiles!,\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n  getUploadedContext(): FileInputFilesContext {\r\n    const files = this.value!;\r\n    return {\r\n      $implicit: files,\r\n      amount: files.length,\r\n      files,\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n}\r\n","<div\r\n  class=\"ard-file-drop-area\"\r\n  (ardClickOutside)=\"onDragleave()\"\r\n  (dragleave)=\"onDragleave()\"\r\n  (dragover)=\"onDragover($event)\"\r\n  (drop)=\"onDrop($event)\"\r\n  [ngClass]=\"ngClasses\"\r\n>\r\n  <div class=\"ard-file-drop-area-outline\">\r\n    <div class=\"ard-file-drop-area-content\">\r\n      @if (currentViewState() === 'idle') {\r\n      <ng-template\r\n        [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n        [ngTemplateOutletContext]=\"getIdleContext()\"\r\n      />\r\n      } @if (currentViewState() === 'dragover') {\r\n      <ng-template\r\n        [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n        [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n      />\r\n      } @if (currentViewState() === 'uploaded') {\r\n      <ng-template\r\n        [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n        [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n      />\r\n      }\r\n    </div>\r\n  </div>\r\n</div>\r\n<input\r\n  #fileInput\r\n  class=\"ard-file-drop-area-input-element\"\r\n  type=\"file\"\r\n  [name]=\"name()\"\r\n  [multiple]=\"multiple()\"\r\n  [id]=\"htmlId()\"\r\n  (change)=\"onFileInputChange()\"\r\n/>\r\n\r\n<ng-template\r\n  #defaultIdleTemplate\r\n  let-browse=\"browse\"\r\n>\r\n  <ard-icon class=\"ard-file-drop-area-icon\">upload</ard-icon>\r\n  <strong class=\"ard-file-drop-area-drop-text\">\r\n    @if (!multiple) {\r\n    <span>Drag & Drop a file</span>\r\n    } @else {\r\n    <span>Drag & Drop files</span>\r\n    } here\r\n  </strong>\r\n  <span class=\"ard-file-drop-area-or-text\">or</span>\r\n  <ard-button\r\n    class=\"ard-file-drop-area-browse-button\"\r\n    appearance=\"transparent\"\r\n    [compact]=\"compact()\"\r\n    [variant]=\"variant()\"\r\n    [color]=\"color()\"\r\n    (click)=\"browse()\"\r\n  >\r\n    Browse files\r\n  </ard-button>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #defaultDragoverTemplate\r\n  let-amount=\"amount\"\r\n>\r\n  <span class=\"ard-file-drop-area-dragover-text\">Drop </span>\r\n  <span class=\"ard-file-drop-area-dragover-amount\">\r\n    {{ amount }}\r\n    <ng-container [ngPlural]=\"amount\">\r\n      <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n      <ng-template ngPluralCase=\"other\">files</ng-template>\r\n    </ng-container>\r\n  </span>\r\n  <span class=\"ard-file-drop-area-dragover-text\"> here to upload. </span>\r\n  @if (amount > 1 && !multiple()) {\r\n  <strong class=\"ard-file-drop-area-dragover-warning\"> Only the first file will be uploaded! </strong>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template\r\n  #defaultUploadedTemplate\r\n  let-amount=\"amount\"\r\n  let-files=\"files\"\r\n>\r\n  <div class=\"ard-file-drop-area-uploaded-container\">\r\n    <div class=\"ard-file-drop-area-uploaded-message\">\r\n      <span class=\"ard-file-drop-area-uploaded-amount\">\r\n        {{ amount }}\r\n        <ng-container [ngPlural]=\"amount\">\r\n          <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n          <ng-template ngPluralCase=\"other\">files</ng-template>\r\n        </ng-container>\r\n      </span>\r\n      <span class=\"ard-file-drop-area-uploaded-text\"> uploaded.</span>\r\n    </div>\r\n    <div class=\"ard-file-drop-area-uploaded-files\">\r\n      @for (file of files; track $index) {\r\n      <div class=\"ard-file-drop-area-file\">\r\n        <ard-icon>draft</ard-icon>\r\n        <div class=\"ard-file-drop-area-file-info\">\r\n          <span class=\"ard-file-drop-area-filename\">\r\n            <span class=\"ard-file-drop-area-filename-name\">{{ file | filename }}</span>\r\n            <span class=\"ard-file-drop-area-filename-ext\">{{ file | fileext : true }}</span>\r\n          </span>\r\n          <span class=\"ard-file-drop-area-filesize\">{{ file.size | filesize }}</span>\r\n        </div>\r\n      </div>\r\n      }\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
@@ -98,7 +98,7 @@ export class ArdiumFileInputComponent extends _FileInputComponentBase {
|
|
|
98
98
|
provide: ARD_FORM_FIELD_CONTROL,
|
|
99
99
|
useExisting: forwardRef(() => ArdiumFileInputComponent),
|
|
100
100
|
},
|
|
101
|
-
], queries: [{ propertyName: "placeholderTemplate", first: true, predicate: ArdFileInputPlaceholderTemplateDirective, descendants: true, isSignal: true }, { propertyName: "prefixTemplate", first: true, predicate: ArdFileInputPrefixTemplateDirective, descendants: true, isSignal: true }, { propertyName: "suffixTemplate", first: true, predicate: ArdFileInputSuffixTemplateDirective, descendants: true, isSignal: true }, { propertyName: "idleTemplate", first: true, predicate: ArdiumFileInputIdleContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "dragoverTemplate", first: true, predicate: ArdiumFileInputDragoverContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "uploadedTemplate", first: true, predicate: ArdiumFileInputUploadedContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "folderIconTemplate", first: true, predicate: ArdiumFileInputFolderIconTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ard-form-field-frame\r\n class=\"ard-file-input-form-field-frame\"\r\n [appearance]=\"appearance()\"\r\n [variant]=\"variant()\"\r\n [compact]=\"compact()\"\r\n [isFocused]=\"isFocused()\"\r\n [hasError]=\"hasError()\"\r\n [isSuccess]=\"isSuccess()\"\r\n [prefixTemplate]=\"prefixTemplate()?.template\"\r\n [suffixTemplate]=\"suffixTemplate()?.template\"\r\n (dragover)=\"onDragover($event)\"\r\n (dragleave)=\"onDragleave()\"\r\n (drop)=\"onDrop($event)\"\r\n (ardClickOutside)=\"onDragleave()\"\r\n>\r\n <div\r\n class=\"ard-file-input\"\r\n [ngClass]=\"ngClasses()\"\r\n >\r\n <div class=\"ard-input-container\">\r\n @if (shouldDisplayPlaceholder) {\r\n <ng-template #defaultPlaceholderTemplate>\r\n <div class=\"ard-placeholder\">{{ placeholder() }}</div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"placeholderTemplate()?.template || defaultPlaceholderTemplate\" />\r\n }\r\n\r\n <div class=\"ard-file-input__value\">\r\n @if (currentViewState() === 'idle') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n [ngTemplateOutletContext]=\"getIdleContext()\"\r\n />\r\n } @if (currentViewState() === 'dragover') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n />\r\n } @if (currentViewState() === 'uploaded') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n />\r\n }\r\n </div>\r\n </div>\r\n\r\n @if (shouldShowClearButton) {\r\n <ard-clear-button\r\n #focusableElement\r\n [title]=\"clearButtonTitle()\"\r\n (mouseup)=\"onClearButtonClick($event)\"\r\n />\r\n } @if (!shouldBeBlocked) {\r\n <button\r\n #focusableElement\r\n type=\"button\"\r\n class=\"ard-browse-button\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (click)=\"openBrowseDialog()\"\r\n >\r\n <div class=\"ard-focus-overlay\"></div>\r\n <ard-icon>folder</ard-icon>\r\n </button>\r\n }\r\n </div>\r\n</ard-form-field-frame>\r\n\r\n<input\r\n #fileInput\r\n class=\"ard-file-input__input\"\r\n type=\"file\"\r\n [name]=\"name()\"\r\n [multiple]=\"multiple()\"\r\n [attr.id]=\"htmlId()\"\r\n [accept]=\"acceptString()\"\r\n (change)=\"
|
|
101
|
+
], queries: [{ propertyName: "placeholderTemplate", first: true, predicate: ArdFileInputPlaceholderTemplateDirective, descendants: true, isSignal: true }, { propertyName: "prefixTemplate", first: true, predicate: ArdFileInputPrefixTemplateDirective, descendants: true, isSignal: true }, { propertyName: "suffixTemplate", first: true, predicate: ArdFileInputSuffixTemplateDirective, descendants: true, isSignal: true }, { propertyName: "idleTemplate", first: true, predicate: ArdiumFileInputIdleContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "dragoverTemplate", first: true, predicate: ArdiumFileInputDragoverContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "uploadedTemplate", first: true, predicate: ArdiumFileInputUploadedContentTemplateDirective, descendants: true, isSignal: true }, { propertyName: "folderIconTemplate", first: true, predicate: ArdiumFileInputFolderIconTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<ard-form-field-frame\r\n class=\"ard-file-input-form-field-frame\"\r\n [appearance]=\"appearance()\"\r\n [variant]=\"variant()\"\r\n [compact]=\"compact()\"\r\n [isFocused]=\"isFocused()\"\r\n [hasError]=\"hasError()\"\r\n [isSuccess]=\"isSuccess()\"\r\n [prefixTemplate]=\"prefixTemplate()?.template\"\r\n [suffixTemplate]=\"suffixTemplate()?.template\"\r\n (dragover)=\"onDragover($event)\"\r\n (dragleave)=\"onDragleave()\"\r\n (drop)=\"onDrop($event)\"\r\n (ardClickOutside)=\"onDragleave()\"\r\n>\r\n <div\r\n class=\"ard-file-input\"\r\n [ngClass]=\"ngClasses()\"\r\n >\r\n <div class=\"ard-input-container\">\r\n @if (shouldDisplayPlaceholder) {\r\n <ng-template #defaultPlaceholderTemplate>\r\n <div class=\"ard-placeholder\">{{ placeholder() }}</div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"placeholderTemplate()?.template || defaultPlaceholderTemplate\" />\r\n }\r\n\r\n <div class=\"ard-file-input__value\">\r\n @if (currentViewState() === 'idle') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n [ngTemplateOutletContext]=\"getIdleContext()\"\r\n />\r\n } @if (currentViewState() === 'dragover') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n />\r\n } @if (currentViewState() === 'uploaded') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n />\r\n }\r\n </div>\r\n </div>\r\n\r\n @if (shouldShowClearButton) {\r\n <ard-clear-button\r\n #focusableElement\r\n [title]=\"clearButtonTitle()\"\r\n (mouseup)=\"onClearButtonClick($event)\"\r\n />\r\n } @if (!shouldBeBlocked) {\r\n <button\r\n #focusableElement\r\n type=\"button\"\r\n class=\"ard-browse-button\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (click)=\"openBrowseDialog()\"\r\n >\r\n <div class=\"ard-focus-overlay\"></div>\r\n <ard-icon>folder</ard-icon>\r\n </button>\r\n }\r\n </div>\r\n</ard-form-field-frame>\r\n\r\n<input\r\n #fileInput\r\n class=\"ard-file-input__input\"\r\n type=\"file\"\r\n [name]=\"name()\"\r\n [multiple]=\"multiple()\"\r\n [attr.id]=\"htmlId()\"\r\n [accept]=\"acceptString()\"\r\n (change)=\"onFileInputChange()\"\r\n/>\r\n\r\n<ng-template\r\n #defaultIdleTemplate\r\n let-browse=\"browse\"\r\n>\r\n <span class=\"ard-file-input__idle\">\r\n @if (multiple()) {\r\n <span>Upload a file</span>\r\n } @else {\r\n <span>Upload files</span>\r\n }\r\n </span>\r\n</ng-template>\r\n\r\n<ng-template\r\n #defaultDragoverTemplate\r\n let-amount=\"amount\"\r\n>\r\n <span class=\"ard-file-input__dragover-text\">Drop </span>\r\n @if (multiple()) {\r\n <span class=\"ard-file-input__dragover-amount\">\r\n {{ amount }}\r\n <ng-container [ngPlural]=\"amount\">\r\n <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n <ng-template ngPluralCase=\"other\">files</ng-template>\r\n </ng-container>\r\n </span>\r\n } @else {\r\n <span class=\"ard-file-input__dragover-amount\"> a file </span>\r\n }\r\n <span class=\"ard-file-input__dragover-text\"> here to upload </span>\r\n</ng-template>\r\n\r\n<ng-template\r\n #defaultUploadedTemplate\r\n let-amount=\"amount\"\r\n let-files=\"files\"\r\n>\r\n <div class=\"ard-file-input__uploaded\">\r\n @if (amount === 1) {\r\n <div class=\"ard-file-input__full-file-name\">\r\n <span class=\"ard-file-input__file-name\">\r\n {{ files?.[0]?.name | filename }}\r\n </span>\r\n <span class=\"ard-file-input__file-ext\">\r\n {{ files?.[0]?.name | fileext:true }}\r\n </span>\r\n </div>\r\n } @else {\r\n <span class=\"ard-file-input__uploaded-amount\">\r\n {{ amount }}\r\n <ng-container [ngPlural]=\"amount\">\r\n <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n <ng-template ngPluralCase=\"other\">files</ng-template>\r\n </ng-container>\r\n </span>\r\n <span class=\"ard-file-input__uploaded-text\"> uploaded.</span>\r\n }\r\n </div>\r\n</ng-template>\r\n", styles: [".ard-file-input__input{position:absolute;appearance:none;opacity:0;pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgPlural, selector: "[ngPlural]", inputs: ["ngPlural"] }, { kind: "directive", type: i1.NgPluralCase, selector: "[ngPluralCase]" }, { kind: "component", type: i2.ArdiumFormFieldFrameComponent, selector: "ard-form-field-frame", inputs: ["hasError", "isSuccess", "isFocused", "appearance", "variant", "compact", "prefixTemplate", "suffixTemplate"] }, { kind: "component", type: i3._ClearButtonComponent, selector: "ard-clear-button" }, { kind: "component", type: i4.ArdiumIconComponent, selector: "ard-icon", inputs: ["ariaLabel", "icon", "filled", "weight", "grade", "opticalSize"] }, { kind: "pipe", type: i5.ArdiumFileExtensionPipe, name: "fileext" }, { kind: "pipe", type: i5.ArdiumFileNamePipe, name: "filename" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
102
102
|
}
|
|
103
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFileInputComponent, decorators: [{
|
|
104
104
|
type: Component,
|
|
@@ -112,9 +112,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
112
112
|
provide: ARD_FORM_FIELD_CONTROL,
|
|
113
113
|
useExisting: forwardRef(() => ArdiumFileInputComponent),
|
|
114
114
|
},
|
|
115
|
-
], template: "<ard-form-field-frame\r\n class=\"ard-file-input-form-field-frame\"\r\n [appearance]=\"appearance()\"\r\n [variant]=\"variant()\"\r\n [compact]=\"compact()\"\r\n [isFocused]=\"isFocused()\"\r\n [hasError]=\"hasError()\"\r\n [isSuccess]=\"isSuccess()\"\r\n [prefixTemplate]=\"prefixTemplate()?.template\"\r\n [suffixTemplate]=\"suffixTemplate()?.template\"\r\n (dragover)=\"onDragover($event)\"\r\n (dragleave)=\"onDragleave()\"\r\n (drop)=\"onDrop($event)\"\r\n (ardClickOutside)=\"onDragleave()\"\r\n>\r\n <div\r\n class=\"ard-file-input\"\r\n [ngClass]=\"ngClasses()\"\r\n >\r\n <div class=\"ard-input-container\">\r\n @if (shouldDisplayPlaceholder) {\r\n <ng-template #defaultPlaceholderTemplate>\r\n <div class=\"ard-placeholder\">{{ placeholder() }}</div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"placeholderTemplate()?.template || defaultPlaceholderTemplate\" />\r\n }\r\n\r\n <div class=\"ard-file-input__value\">\r\n @if (currentViewState() === 'idle') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n [ngTemplateOutletContext]=\"getIdleContext()\"\r\n />\r\n } @if (currentViewState() === 'dragover') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n />\r\n } @if (currentViewState() === 'uploaded') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n />\r\n }\r\n </div>\r\n </div>\r\n\r\n @if (shouldShowClearButton) {\r\n <ard-clear-button\r\n #focusableElement\r\n [title]=\"clearButtonTitle()\"\r\n (mouseup)=\"onClearButtonClick($event)\"\r\n />\r\n } @if (!shouldBeBlocked) {\r\n <button\r\n #focusableElement\r\n type=\"button\"\r\n class=\"ard-browse-button\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (click)=\"openBrowseDialog()\"\r\n >\r\n <div class=\"ard-focus-overlay\"></div>\r\n <ard-icon>folder</ard-icon>\r\n </button>\r\n }\r\n </div>\r\n</ard-form-field-frame>\r\n\r\n<input\r\n #fileInput\r\n class=\"ard-file-input__input\"\r\n type=\"file\"\r\n [name]=\"name()\"\r\n [multiple]=\"multiple()\"\r\n [attr.id]=\"htmlId()\"\r\n [accept]=\"acceptString()\"\r\n (change)=\"
|
|
115
|
+
], template: "<ard-form-field-frame\r\n class=\"ard-file-input-form-field-frame\"\r\n [appearance]=\"appearance()\"\r\n [variant]=\"variant()\"\r\n [compact]=\"compact()\"\r\n [isFocused]=\"isFocused()\"\r\n [hasError]=\"hasError()\"\r\n [isSuccess]=\"isSuccess()\"\r\n [prefixTemplate]=\"prefixTemplate()?.template\"\r\n [suffixTemplate]=\"suffixTemplate()?.template\"\r\n (dragover)=\"onDragover($event)\"\r\n (dragleave)=\"onDragleave()\"\r\n (drop)=\"onDrop($event)\"\r\n (ardClickOutside)=\"onDragleave()\"\r\n>\r\n <div\r\n class=\"ard-file-input\"\r\n [ngClass]=\"ngClasses()\"\r\n >\r\n <div class=\"ard-input-container\">\r\n @if (shouldDisplayPlaceholder) {\r\n <ng-template #defaultPlaceholderTemplate>\r\n <div class=\"ard-placeholder\">{{ placeholder() }}</div>\r\n </ng-template>\r\n\r\n <ng-template [ngTemplateOutlet]=\"placeholderTemplate()?.template || defaultPlaceholderTemplate\" />\r\n }\r\n\r\n <div class=\"ard-file-input__value\">\r\n @if (currentViewState() === 'idle') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n [ngTemplateOutletContext]=\"getIdleContext()\"\r\n />\r\n } @if (currentViewState() === 'dragover') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n />\r\n } @if (currentViewState() === 'uploaded') {\r\n <ng-template\r\n [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n />\r\n }\r\n </div>\r\n </div>\r\n\r\n @if (shouldShowClearButton) {\r\n <ard-clear-button\r\n #focusableElement\r\n [title]=\"clearButtonTitle()\"\r\n (mouseup)=\"onClearButtonClick($event)\"\r\n />\r\n } @if (!shouldBeBlocked) {\r\n <button\r\n #focusableElement\r\n type=\"button\"\r\n class=\"ard-browse-button\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (click)=\"openBrowseDialog()\"\r\n >\r\n <div class=\"ard-focus-overlay\"></div>\r\n <ard-icon>folder</ard-icon>\r\n </button>\r\n }\r\n </div>\r\n</ard-form-field-frame>\r\n\r\n<input\r\n #fileInput\r\n class=\"ard-file-input__input\"\r\n type=\"file\"\r\n [name]=\"name()\"\r\n [multiple]=\"multiple()\"\r\n [attr.id]=\"htmlId()\"\r\n [accept]=\"acceptString()\"\r\n (change)=\"onFileInputChange()\"\r\n/>\r\n\r\n<ng-template\r\n #defaultIdleTemplate\r\n let-browse=\"browse\"\r\n>\r\n <span class=\"ard-file-input__idle\">\r\n @if (multiple()) {\r\n <span>Upload a file</span>\r\n } @else {\r\n <span>Upload files</span>\r\n }\r\n </span>\r\n</ng-template>\r\n\r\n<ng-template\r\n #defaultDragoverTemplate\r\n let-amount=\"amount\"\r\n>\r\n <span class=\"ard-file-input__dragover-text\">Drop </span>\r\n @if (multiple()) {\r\n <span class=\"ard-file-input__dragover-amount\">\r\n {{ amount }}\r\n <ng-container [ngPlural]=\"amount\">\r\n <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n <ng-template ngPluralCase=\"other\">files</ng-template>\r\n </ng-container>\r\n </span>\r\n } @else {\r\n <span class=\"ard-file-input__dragover-amount\"> a file </span>\r\n }\r\n <span class=\"ard-file-input__dragover-text\"> here to upload </span>\r\n</ng-template>\r\n\r\n<ng-template\r\n #defaultUploadedTemplate\r\n let-amount=\"amount\"\r\n let-files=\"files\"\r\n>\r\n <div class=\"ard-file-input__uploaded\">\r\n @if (amount === 1) {\r\n <div class=\"ard-file-input__full-file-name\">\r\n <span class=\"ard-file-input__file-name\">\r\n {{ files?.[0]?.name | filename }}\r\n </span>\r\n <span class=\"ard-file-input__file-ext\">\r\n {{ files?.[0]?.name | fileext:true }}\r\n </span>\r\n </div>\r\n } @else {\r\n <span class=\"ard-file-input__uploaded-amount\">\r\n {{ amount }}\r\n <ng-container [ngPlural]=\"amount\">\r\n <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n <ng-template ngPluralCase=\"other\">files</ng-template>\r\n </ng-container>\r\n </span>\r\n <span class=\"ard-file-input__uploaded-text\"> uploaded.</span>\r\n }\r\n </div>\r\n</ng-template>\r\n", styles: [".ard-file-input__input{position:absolute;appearance:none;opacity:0;pointer-events:none}\n"] }]
|
|
116
116
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
117
117
|
type: Inject,
|
|
118
118
|
args: [ARD_FILE_INPUT_DEFAULTS]
|
|
119
119
|
}] }] });
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/file-inputs/file-input/file-input.component.ts","../../../../../../projects/ui/src/lib/file-inputs/file-input/file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  Inject,\r\n  ViewEncapsulation,\r\n  computed,\r\n  contentChild,\r\n  forwardRef,\r\n  input,\r\n  output,\r\n  signal,\r\n} from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { ARD_FORM_FIELD_CONTROL } from '../../form-field/form-field-child.token';\r\nimport { ComponentColor } from '../../types/colors.types';\r\nimport { FormElementAppearance, FormElementVariant } from '../../types/theming.types';\r\nimport { _FileInputComponentBase } from '../file-input-base';\r\nimport { FileInputBrowseContext, FileInputFileAmountContext, FileInputFilesContext } from '../file-input-types';\r\nimport { ARD_FILE_INPUT_DEFAULTS, ArdFileInputDefaults } from './file-input.defaults';\r\nimport {\r\n  ArdFileInputPlaceholderTemplateDirective,\r\n  ArdFileInputPrefixTemplateDirective,\r\n  ArdFileInputSuffixTemplateDirective,\r\n  ArdiumFileInputDragoverContentTemplateDirective,\r\n  ArdiumFileInputFolderIconTemplateDirective,\r\n  ArdiumFileInputIdleContentTemplateDirective,\r\n  ArdiumFileInputUploadedContentTemplateDirective\r\n} from './file-input.directives';\r\n\r\n@Component({\r\n  selector: 'ard-file-input',\r\n  templateUrl: './file-input.component.html',\r\n  styleUrls: ['./file-input.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ArdiumFileInputComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: ARD_FORM_FIELD_CONTROL,\r\n      useExisting: forwardRef(() => ArdiumFileInputComponent),\r\n    },\r\n  ],\r\n})\r\nexport class ArdiumFileInputComponent extends _FileInputComponentBase {\r\n  protected override readonly _DEFAULTS!: ArdFileInputDefaults;\r\n  constructor(@Inject(ARD_FILE_INPUT_DEFAULTS) defaults: ArdFileInputDefaults) {\r\n    super(defaults);\r\n  }\r\n\r\n  readonly componentId = '011';\r\n\r\n  //! appearance\r\n  //all handled in ard-form-field-frame component\r\n  readonly appearance = input<FormElementAppearance>(this._DEFAULTS.appearance);\r\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\r\n  readonly color = input<ComponentColor>(this._DEFAULTS.color);\r\n\r\n  //! other inputs\r\n  readonly inputAttrs = input<Record<string, any>>(this._DEFAULTS.inputAttrs);\r\n\r\n  //! placeholder\r\n  readonly placeholder = input<string>(this._DEFAULTS.placeholder);\r\n\r\n  //! root element classes\r\n  readonly ngClasses = computed<string>(() =>\r\n    [`ard-color-${this.color()}`, `ard-state-${this.currentViewState()}`, this.value ? 'ard-has-value' : ''].join(' ')\r\n  );\r\n\r\n  readonly placeholderTemplate = contentChild(ArdFileInputPlaceholderTemplateDirective);\r\n\r\n  get shouldDisplayPlaceholder(): boolean {\r\n    return !!this.placeholder() && !this.value;\r\n  }\r\n\r\n  //! clear button\r\n  readonly clearable = input<boolean, any>(this._DEFAULTS.clearable, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly clearButtonTitle = input<string>(this._DEFAULTS.clearButtonTitle);\r\n\r\n  get shouldShowClearButton(): boolean {\r\n    return this.clearable() && !this.disabled() && Boolean(this.value);\r\n  }\r\n  onClearButtonClick(event: MouseEvent): void {\r\n    event.stopPropagation();\r\n    this.clear();\r\n    this.focus();\r\n  }\r\n\r\n  //! clear function\r\n  clear(): void {\r\n    if (!this.clearable()) return;\r\n\r\n    this.writeValue(null);\r\n    this._emitChange();\r\n    this.clearEvent.emit();\r\n  }\r\n\r\n  readonly clearEvent = output({ alias: 'clear' });\r\n\r\n  //! state\r\n  readonly touched = signal<boolean>(false);\r\n\r\n  //! prefix & suffix\r\n  readonly prefixTemplate = contentChild(ArdFileInputPrefixTemplateDirective);\r\n  readonly suffixTemplate = contentChild(ArdFileInputSuffixTemplateDirective);\r\n  //! templates\r\n  readonly idleTemplate = contentChild(ArdiumFileInputIdleContentTemplateDirective);\r\n  readonly dragoverTemplate = contentChild(ArdiumFileInputDragoverContentTemplateDirective);\r\n  readonly uploadedTemplate = contentChild(ArdiumFileInputUploadedContentTemplateDirective);\r\n  readonly folderIconTemplate = contentChild(ArdiumFileInputFolderIconTemplateDirective);\r\n\r\n  getIdleContext(): FileInputBrowseContext {\r\n    return {\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n  getDragoverContext(): FileInputFileAmountContext {\r\n    return {\r\n      amount: this._draggedFiles!,\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n  getUploadedContext(): FileInputFilesContext {\r\n    const files = this.value!;\r\n    return {\r\n      $implicit: files,\r\n      amount: files.length,\r\n      files,\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n}\r\n","<ard-form-field-frame\r\n  class=\"ard-file-input-form-field-frame\"\r\n  [appearance]=\"appearance()\"\r\n  [variant]=\"variant()\"\r\n  [compact]=\"compact()\"\r\n  [isFocused]=\"isFocused()\"\r\n  [hasError]=\"hasError()\"\r\n  [isSuccess]=\"isSuccess()\"\r\n  [prefixTemplate]=\"prefixTemplate()?.template\"\r\n  [suffixTemplate]=\"suffixTemplate()?.template\"\r\n  (dragover)=\"onDragover($event)\"\r\n  (dragleave)=\"onDragleave()\"\r\n  (drop)=\"onDrop($event)\"\r\n  (ardClickOutside)=\"onDragleave()\"\r\n>\r\n  <div\r\n    class=\"ard-file-input\"\r\n    [ngClass]=\"ngClasses()\"\r\n  >\r\n    <div class=\"ard-input-container\">\r\n      @if (shouldDisplayPlaceholder) {\r\n      <ng-template #defaultPlaceholderTemplate>\r\n        <div class=\"ard-placeholder\">{{ placeholder() }}</div>\r\n      </ng-template>\r\n\r\n      <ng-template [ngTemplateOutlet]=\"placeholderTemplate()?.template || defaultPlaceholderTemplate\" />\r\n      }\r\n\r\n      <div class=\"ard-file-input__value\">\r\n        @if (currentViewState() === 'idle') {\r\n        <ng-template\r\n          [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n          [ngTemplateOutletContext]=\"getIdleContext()\"\r\n        />\r\n        } @if (currentViewState() === 'dragover') {\r\n        <ng-template\r\n          [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n          [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n        />\r\n        } @if (currentViewState() === 'uploaded') {\r\n        <ng-template\r\n          [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n          [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n        />\r\n        }\r\n      </div>\r\n    </div>\r\n\r\n    @if (shouldShowClearButton) {\r\n    <ard-clear-button\r\n      #focusableElement\r\n      [title]=\"clearButtonTitle()\"\r\n      (mouseup)=\"onClearButtonClick($event)\"\r\n    />\r\n    } @if (!shouldBeBlocked) {\r\n    <button\r\n      #focusableElement\r\n      type=\"button\"\r\n      class=\"ard-browse-button\"\r\n      (focus)=\"onFocus($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n      (click)=\"openBrowseDialog()\"\r\n    >\r\n      <div class=\"ard-focus-overlay\"></div>\r\n      <ard-icon>folder</ard-icon>\r\n    </button>\r\n    }\r\n  </div>\r\n</ard-form-field-frame>\r\n\r\n<input\r\n  #fileInput\r\n  class=\"ard-file-input__input\"\r\n  type=\"file\"\r\n  [name]=\"name()\"\r\n  [multiple]=\"multiple()\"\r\n  [attr.id]=\"htmlId()\"\r\n  [accept]=\"acceptString()\"\r\n  (change)=\"onInputChange()\"\r\n/>\r\n\r\n<ng-template\r\n  #defaultIdleTemplate\r\n  let-browse=\"browse\"\r\n>\r\n  <span class=\"ard-file-input__idle\">\r\n    @if (multiple()) {\r\n    <span>Upload a file</span>\r\n    } @else {\r\n    <span>Upload files</span>\r\n    }\r\n  </span>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #defaultDragoverTemplate\r\n  let-amount=\"amount\"\r\n>\r\n  <span class=\"ard-file-input__dragover-text\">Drop </span>\r\n  @if (multiple()) {\r\n  <span class=\"ard-file-input__dragover-amount\">\r\n    {{ amount }}\r\n    <ng-container [ngPlural]=\"amount\">\r\n      <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n      <ng-template ngPluralCase=\"other\">files</ng-template>\r\n    </ng-container>\r\n  </span>\r\n  } @else {\r\n  <span class=\"ard-file-input__dragover-amount\"> a file </span>\r\n  }\r\n  <span class=\"ard-file-input__dragover-text\"> here to upload </span>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #defaultUploadedTemplate\r\n  let-amount=\"amount\"\r\n  let-files=\"files\"\r\n>\r\n  <div class=\"ard-file-input__uploaded\">\r\n    @if (amount === 1) {\r\n    <div class=\"ard-file-input__full-file-name\">\r\n      <span class=\"ard-file-input__file-name\">\r\n        {{ files?.[0]?.name | filename }}\r\n      </span>\r\n      <span class=\"ard-file-input__file-ext\">\r\n        {{ files?.[0]?.name | fileext:true }}\r\n      </span>\r\n    </div>\r\n    } @else {\r\n    <span class=\"ard-file-input__uploaded-amount\">\r\n      {{ amount }}\r\n      <ng-container [ngPlural]=\"amount\">\r\n        <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n        <ng-template ngPluralCase=\"other\">files</ng-template>\r\n      </ng-container>\r\n    </span>\r\n    <span class=\"ard-file-input__uploaded-text\"> uploaded.</span>\r\n    }\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/file-inputs/file-input/file-input.component.ts","../../../../../../projects/ui/src/lib/file-inputs/file-input/file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  Inject,\r\n  ViewEncapsulation,\r\n  computed,\r\n  contentChild,\r\n  forwardRef,\r\n  input,\r\n  output,\r\n  signal,\r\n} from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { ARD_FORM_FIELD_CONTROL } from '../../form-field/form-field-child.token';\r\nimport { ComponentColor } from '../../types/colors.types';\r\nimport { FormElementAppearance, FormElementVariant } from '../../types/theming.types';\r\nimport { _FileInputComponentBase } from '../file-input-base';\r\nimport { FileInputBrowseContext, FileInputFileAmountContext, FileInputFilesContext } from '../file-input-types';\r\nimport { ARD_FILE_INPUT_DEFAULTS, ArdFileInputDefaults } from './file-input.defaults';\r\nimport {\r\n  ArdFileInputPlaceholderTemplateDirective,\r\n  ArdFileInputPrefixTemplateDirective,\r\n  ArdFileInputSuffixTemplateDirective,\r\n  ArdiumFileInputDragoverContentTemplateDirective,\r\n  ArdiumFileInputFolderIconTemplateDirective,\r\n  ArdiumFileInputIdleContentTemplateDirective,\r\n  ArdiumFileInputUploadedContentTemplateDirective\r\n} from './file-input.directives';\r\n\r\n@Component({\r\n  selector: 'ard-file-input',\r\n  templateUrl: './file-input.component.html',\r\n  styleUrls: ['./file-input.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ArdiumFileInputComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: ARD_FORM_FIELD_CONTROL,\r\n      useExisting: forwardRef(() => ArdiumFileInputComponent),\r\n    },\r\n  ],\r\n})\r\nexport class ArdiumFileInputComponent extends _FileInputComponentBase {\r\n  protected override readonly _DEFAULTS!: ArdFileInputDefaults;\r\n  constructor(@Inject(ARD_FILE_INPUT_DEFAULTS) defaults: ArdFileInputDefaults) {\r\n    super(defaults);\r\n  }\r\n\r\n  readonly componentId = '011';\r\n\r\n  //! appearance\r\n  //all handled in ard-form-field-frame component\r\n  readonly appearance = input<FormElementAppearance>(this._DEFAULTS.appearance);\r\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\r\n  readonly color = input<ComponentColor>(this._DEFAULTS.color);\r\n\r\n  //! other inputs\r\n  readonly inputAttrs = input<Record<string, any>>(this._DEFAULTS.inputAttrs);\r\n\r\n  //! placeholder\r\n  readonly placeholder = input<string>(this._DEFAULTS.placeholder);\r\n\r\n  //! root element classes\r\n  readonly ngClasses = computed<string>(() =>\r\n    [`ard-color-${this.color()}`, `ard-state-${this.currentViewState()}`, this.value ? 'ard-has-value' : ''].join(' ')\r\n  );\r\n\r\n  readonly placeholderTemplate = contentChild(ArdFileInputPlaceholderTemplateDirective);\r\n\r\n  get shouldDisplayPlaceholder(): boolean {\r\n    return !!this.placeholder() && !this.value;\r\n  }\r\n\r\n  //! clear button\r\n  readonly clearable = input<boolean, any>(this._DEFAULTS.clearable, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly clearButtonTitle = input<string>(this._DEFAULTS.clearButtonTitle);\r\n\r\n  get shouldShowClearButton(): boolean {\r\n    return this.clearable() && !this.disabled() && Boolean(this.value);\r\n  }\r\n  onClearButtonClick(event: MouseEvent): void {\r\n    event.stopPropagation();\r\n    this.clear();\r\n    this.focus();\r\n  }\r\n\r\n  //! clear function\r\n  clear(): void {\r\n    if (!this.clearable()) return;\r\n\r\n    this.writeValue(null);\r\n    this._emitChange();\r\n    this.clearEvent.emit();\r\n  }\r\n\r\n  readonly clearEvent = output({ alias: 'clear' });\r\n\r\n  //! state\r\n  readonly touched = signal<boolean>(false);\r\n\r\n  //! prefix & suffix\r\n  readonly prefixTemplate = contentChild(ArdFileInputPrefixTemplateDirective);\r\n  readonly suffixTemplate = contentChild(ArdFileInputSuffixTemplateDirective);\r\n  //! templates\r\n  readonly idleTemplate = contentChild(ArdiumFileInputIdleContentTemplateDirective);\r\n  readonly dragoverTemplate = contentChild(ArdiumFileInputDragoverContentTemplateDirective);\r\n  readonly uploadedTemplate = contentChild(ArdiumFileInputUploadedContentTemplateDirective);\r\n  readonly folderIconTemplate = contentChild(ArdiumFileInputFolderIconTemplateDirective);\r\n\r\n  getIdleContext(): FileInputBrowseContext {\r\n    return {\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n  getDragoverContext(): FileInputFileAmountContext {\r\n    return {\r\n      amount: this._draggedFiles!,\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n  getUploadedContext(): FileInputFilesContext {\r\n    const files = this.value!;\r\n    return {\r\n      $implicit: files,\r\n      amount: files.length,\r\n      files,\r\n      browse: () => {\r\n        this.openBrowseDialog();\r\n      },\r\n    };\r\n  }\r\n}\r\n","<ard-form-field-frame\r\n  class=\"ard-file-input-form-field-frame\"\r\n  [appearance]=\"appearance()\"\r\n  [variant]=\"variant()\"\r\n  [compact]=\"compact()\"\r\n  [isFocused]=\"isFocused()\"\r\n  [hasError]=\"hasError()\"\r\n  [isSuccess]=\"isSuccess()\"\r\n  [prefixTemplate]=\"prefixTemplate()?.template\"\r\n  [suffixTemplate]=\"suffixTemplate()?.template\"\r\n  (dragover)=\"onDragover($event)\"\r\n  (dragleave)=\"onDragleave()\"\r\n  (drop)=\"onDrop($event)\"\r\n  (ardClickOutside)=\"onDragleave()\"\r\n>\r\n  <div\r\n    class=\"ard-file-input\"\r\n    [ngClass]=\"ngClasses()\"\r\n  >\r\n    <div class=\"ard-input-container\">\r\n      @if (shouldDisplayPlaceholder) {\r\n      <ng-template #defaultPlaceholderTemplate>\r\n        <div class=\"ard-placeholder\">{{ placeholder() }}</div>\r\n      </ng-template>\r\n\r\n      <ng-template [ngTemplateOutlet]=\"placeholderTemplate()?.template || defaultPlaceholderTemplate\" />\r\n      }\r\n\r\n      <div class=\"ard-file-input__value\">\r\n        @if (currentViewState() === 'idle') {\r\n        <ng-template\r\n          [ngTemplateOutlet]=\"idleTemplate()?.template ?? defaultIdleTemplate\"\r\n          [ngTemplateOutletContext]=\"getIdleContext()\"\r\n        />\r\n        } @if (currentViewState() === 'dragover') {\r\n        <ng-template\r\n          [ngTemplateOutlet]=\"dragoverTemplate()?.template ?? defaultDragoverTemplate\"\r\n          [ngTemplateOutletContext]=\"getDragoverContext()\"\r\n        />\r\n        } @if (currentViewState() === 'uploaded') {\r\n        <ng-template\r\n          [ngTemplateOutlet]=\"uploadedTemplate()?.template ?? defaultUploadedTemplate\"\r\n          [ngTemplateOutletContext]=\"getUploadedContext()\"\r\n        />\r\n        }\r\n      </div>\r\n    </div>\r\n\r\n    @if (shouldShowClearButton) {\r\n    <ard-clear-button\r\n      #focusableElement\r\n      [title]=\"clearButtonTitle()\"\r\n      (mouseup)=\"onClearButtonClick($event)\"\r\n    />\r\n    } @if (!shouldBeBlocked) {\r\n    <button\r\n      #focusableElement\r\n      type=\"button\"\r\n      class=\"ard-browse-button\"\r\n      (focus)=\"onFocus($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n      (click)=\"openBrowseDialog()\"\r\n    >\r\n      <div class=\"ard-focus-overlay\"></div>\r\n      <ard-icon>folder</ard-icon>\r\n    </button>\r\n    }\r\n  </div>\r\n</ard-form-field-frame>\r\n\r\n<input\r\n  #fileInput\r\n  class=\"ard-file-input__input\"\r\n  type=\"file\"\r\n  [name]=\"name()\"\r\n  [multiple]=\"multiple()\"\r\n  [attr.id]=\"htmlId()\"\r\n  [accept]=\"acceptString()\"\r\n  (change)=\"onFileInputChange()\"\r\n/>\r\n\r\n<ng-template\r\n  #defaultIdleTemplate\r\n  let-browse=\"browse\"\r\n>\r\n  <span class=\"ard-file-input__idle\">\r\n    @if (multiple()) {\r\n    <span>Upload a file</span>\r\n    } @else {\r\n    <span>Upload files</span>\r\n    }\r\n  </span>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #defaultDragoverTemplate\r\n  let-amount=\"amount\"\r\n>\r\n  <span class=\"ard-file-input__dragover-text\">Drop </span>\r\n  @if (multiple()) {\r\n  <span class=\"ard-file-input__dragover-amount\">\r\n    {{ amount }}\r\n    <ng-container [ngPlural]=\"amount\">\r\n      <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n      <ng-template ngPluralCase=\"other\">files</ng-template>\r\n    </ng-container>\r\n  </span>\r\n  } @else {\r\n  <span class=\"ard-file-input__dragover-amount\"> a file </span>\r\n  }\r\n  <span class=\"ard-file-input__dragover-text\"> here to upload </span>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #defaultUploadedTemplate\r\n  let-amount=\"amount\"\r\n  let-files=\"files\"\r\n>\r\n  <div class=\"ard-file-input__uploaded\">\r\n    @if (amount === 1) {\r\n    <div class=\"ard-file-input__full-file-name\">\r\n      <span class=\"ard-file-input__file-name\">\r\n        {{ files?.[0]?.name | filename }}\r\n      </span>\r\n      <span class=\"ard-file-input__file-ext\">\r\n        {{ files?.[0]?.name | fileext:true }}\r\n      </span>\r\n    </div>\r\n    } @else {\r\n    <span class=\"ard-file-input__uploaded-amount\">\r\n      {{ amount }}\r\n      <ng-container [ngPlural]=\"amount\">\r\n        <ng-template ngPluralCase=\"=1\">file</ng-template>\r\n        <ng-template ngPluralCase=\"other\">files</ng-template>\r\n      </ng-container>\r\n    </span>\r\n    <span class=\"ard-file-input__uploaded-text\"> uploaded.</span>\r\n    }\r\n  </div>\r\n</ng-template>\r\n"]}
|