@kushki/ng-suka
Version:
<p align="center"> <h1 align="center">Suka Components Angular</h1> <p align="center"> An Angular implementation of the Suka Design System </p> </p>
307 lines • 20.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, Output, ViewChild, EventEmitter, HostBinding } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
/** @type {?} */
var noop = (/**
* @return {?}
*/
function () { });
var ɵ0 = noop;
var FileUploader = /** @class */ (function () {
function FileUploader() {
/**
* Accessible text for the button that opens the upload window.
*/
this.buttonText = 'Agregar archivo(s)';
/**
* Type set for button
*/
this.buttonType = 'basic';
/**
* Specify the types of files that the input should be able to receive
*/
this.accept = [];
/**
* Set to `false` to tell the component to only accept a single file on upload.
*
* Defaults to `true`. Accepts multiple files.
*/
this.multiple = true;
/**
* Set to `true` for a loading file uploader.
*/
this.skeleton = false;
/**
* Provides a unique id for the underlying `<input>` node
*/
this.fileUploaderId = "file-uploader-" + FileUploader.fileUploaderCount;
/**
* The list of files that have been submitted to be uploaded
*/
this.files = new Set();
/**
* Emits an event to other classes when files change
*/
this.filesChange = new EventEmitter();
this.baseClass = true;
this.onTouchedCallback = noop;
this.onChangeCallback = noop;
FileUploader.fileUploaderCount++;
}
Object.defineProperty(FileUploader.prototype, "value", {
/**
* Specifies the property to be used as the return value to `ngModel`
*/
get: /**
* Specifies the property to be used as the return value to `ngModel`
* @return {?}
*/
function () {
return this.files;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
if (v !== this.files) {
this.files = v;
this.onChangeCallback(v);
}
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
FileUploader.prototype.onBlur = /**
* @return {?}
*/
function () {
this.onTouchedCallback();
};
/**
* Propagates the injected `value`.
*/
/**
* Propagates the injected `value`.
* @param {?} value
* @return {?}
*/
FileUploader.prototype.writeValue = /**
* Propagates the injected `value`.
* @param {?} value
* @return {?}
*/
function (value) {
if (value !== this.value) {
this.files = value;
}
};
/**
* @return {?}
*/
FileUploader.prototype.onFilesAdded = /**
* @return {?}
*/
function () {
var e_1, _a;
/** @type {?} */
var files = this.fileInput.nativeElement.files;
if (!this.multiple) {
this.files.clear();
}
try {
for (var files_1 = tslib_1.__values(files), files_1_1 = files_1.next(); !files_1_1.done; files_1_1 = files_1.next()) {
var file = files_1_1.value;
/** @type {?} */
var fileItem = {
file: file,
uploaded: false,
state: 'edit',
invalid: false,
invalidText: '',
};
this.files.add(fileItem);
this.filesChange.emit(this.files);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (files_1_1 && !files_1_1.done && (_a = files_1.return)) _a.call(files_1);
}
finally { if (e_1) throw e_1.error; }
}
this.value = this.files;
};
/**
* @param {?} fileItem
* @return {?}
*/
FileUploader.prototype.removeFile = /**
* @param {?} fileItem
* @return {?}
*/
function (fileItem) {
this.files.delete(fileItem);
this.fileInput.nativeElement.value = '';
this.filesChange.emit(this.files);
};
/**
* Registers the injected function to control the touch use of the `FileUploader`.
*/
/**
* Registers the injected function to control the touch use of the `FileUploader`.
* @param {?} fn
* @return {?}
*/
FileUploader.prototype.registerOnTouched = /**
* Registers the injected function to control the touch use of the `FileUploader`.
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouchedCallback = fn;
};
/**
* Sets a method in order to propagate changes back to the form.
*/
/**
* Sets a method in order to propagate changes back to the form.
* @param {?} fn
* @return {?}
*/
FileUploader.prototype.registerOnChange = /**
* Sets a method in order to propagate changes back to the form.
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChangeCallback = fn;
};
/**
* Counter used to create unique ids for file-uploader components
*/
FileUploader.fileUploaderCount = 0;
FileUploader.decorators = [
{ type: Component, args: [{
selector: 'suka-file-uploader',
template: "\n <ng-container *ngIf=\"!skeleton; else skeletonTemplate\">\n <label class=\"label\">{{title}}</label>\n <div *ngIf=\"description\" class=\"form__helper-text\">{{description}}</div>\n <div class=\"file\">\n <button\n type=\"button\"\n [sukaButton]=\"buttonType\"\n (click)=\"fileInput.click()\"\n [attr.for]=\"fileUploaderId\"\n [size]=\"size\">\n {{buttonText}}\n </button>\n <input\n #fileInput\n type=\"file\"\n class=\"file-input\"\n [accept]=\"accept\"\n [id]=\"fileUploaderId\"\n [multiple]=\"multiple\"\n tabindex=\"-1\"\n (change)=\"onFilesAdded()\"/>\n <div class=\"file-container\">\n <div *ngFor=\"let fileItem of files\">\n <suka-file [fileItem]=\"fileItem\" (remove)=\"removeFile(fileItem)\"></suka-file>\n <div *ngIf=\"fileItem.invalid\" class=\"form-requirement\">\n {{fileItem.invalidText}}\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n <ng-template #skeletonTemplate>\n <div class=\"skeleton__text\" style=\"width: 100px\"></div>\n <div class=\"skeleton__text\" style=\"width: 225px\"></div>\n <button sukaButton skeleton=\"true\"></button>\n </ng-template>\n ",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: FileUploader,
multi: true
}
]
}] }
];
/** @nocollapse */
FileUploader.ctorParameters = function () { return []; };
FileUploader.propDecorators = {
buttonText: [{ type: Input }],
buttonType: [{ type: Input }],
title: [{ type: Input }],
description: [{ type: Input }],
accept: [{ type: Input }],
multiple: [{ type: Input }],
skeleton: [{ type: Input }],
size: [{ type: Input }],
fileUploaderId: [{ type: Input }],
fileInput: [{ type: ViewChild, args: ['fileInput', { static: false },] }],
files: [{ type: Input }],
filesChange: [{ type: Output }],
baseClass: [{ type: HostBinding, args: ['class.file-uploader',] }]
};
return FileUploader;
}());
export { FileUploader };
if (false) {
/**
* Counter used to create unique ids for file-uploader components
* @type {?}
*/
FileUploader.fileUploaderCount;
/**
* Accessible text for the button that opens the upload window.
* @type {?}
*/
FileUploader.prototype.buttonText;
/**
* Type set for button
* @type {?}
*/
FileUploader.prototype.buttonType;
/**
* Text set to the title
* @type {?}
*/
FileUploader.prototype.title;
/**
* Text set to the description
* @type {?}
*/
FileUploader.prototype.description;
/**
* Specify the types of files that the input should be able to receive
* @type {?}
*/
FileUploader.prototype.accept;
/**
* Set to `false` to tell the component to only accept a single file on upload.
*
* Defaults to `true`. Accepts multiple files.
* @type {?}
*/
FileUploader.prototype.multiple;
/**
* Set to `true` for a loading file uploader.
* @type {?}
*/
FileUploader.prototype.skeleton;
/**
* Sets the size of the button.
* @type {?}
*/
FileUploader.prototype.size;
/**
* Provides a unique id for the underlying `<input>` node
* @type {?}
*/
FileUploader.prototype.fileUploaderId;
/**
* Maintains a reference to the view DOM element of the underlying `<input>` node
* @type {?}
*/
FileUploader.prototype.fileInput;
/**
* The list of files that have been submitted to be uploaded
* @type {?}
*/
FileUploader.prototype.files;
/**
* Emits an event to other classes when files change
* @type {?}
*/
FileUploader.prototype.filesChange;
/** @type {?} */
FileUploader.prototype.baseClass;
/**
* @type {?}
* @protected
*/
FileUploader.prototype.onTouchedCallback;
/**
* @type {?}
* @protected
*/
FileUploader.prototype.onChangeCallback;
}
export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-uploader.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/file-uploader/file-uploader.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  ViewChild,\n  EventEmitter,\n  HostBinding\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { FileItem } from './file-item.interface';\n\nconst noop = () => {};\n\n@Component({\n  selector: 'suka-file-uploader',\n  template: `\n    <ng-container *ngIf=\"!skeleton; else skeletonTemplate\">\n      <label class=\"label\">{{title}}</label>\n      <div *ngIf=\"description\" class=\"form__helper-text\">{{description}}</div>\n      <div class=\"file\">\n        <button\n          type=\"button\"\n          [sukaButton]=\"buttonType\"\n          (click)=\"fileInput.click()\"\n          [attr.for]=\"fileUploaderId\"\n          [size]=\"size\">\n          {{buttonText}}\n        </button>\n        <input\n          #fileInput\n          type=\"file\"\n          class=\"file-input\"\n          [accept]=\"accept\"\n          [id]=\"fileUploaderId\"\n          [multiple]=\"multiple\"\n          tabindex=\"-1\"\n          (change)=\"onFilesAdded()\"/>\n        <div class=\"file-container\">\n          <div *ngFor=\"let fileItem of files\">\n            <suka-file [fileItem]=\"fileItem\" (remove)=\"removeFile(fileItem)\"></suka-file>\n            <div *ngIf=\"fileItem.invalid\" class=\"form-requirement\">\n              {{fileItem.invalidText}}\n            </div>\n          </div>\n        </div>\n      </div>\n    </ng-container>\n    <ng-template #skeletonTemplate>\n      <div class=\"skeleton__text\" style=\"width: 100px\"></div>\n      <div class=\"skeleton__text\" style=\"width: 225px\"></div>\n      <button sukaButton skeleton=\"true\"></button>\n    </ng-template>\n  `,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: FileUploader,\n      multi: true\n    }\n  ]\n})\nexport class FileUploader {\n  /**\n   * Counter used to create unique ids for file-uploader components\n   */\n  static fileUploaderCount = 0;\n  /**\n   * Accessible text for the button that opens the upload window.\n   */\n  @Input() buttonText = 'Agregar archivo(s)';\n\n  /**\n   * Type set for button\n   */\n  @Input() buttonType: 'primary' | 'basic' | 'plain' | 'destructive' | 'outline_white' = 'basic';\n\n  /**\n   * Text set to the title\n   */\n  @Input() title: string;\n\n  /**\n   * Text set to the description\n   */\n  @Input() description: string;\n\n  /**\n   * Specify the types of files that the input should be able to receive\n   */\n  @Input() accept = [];\n\n  /**\n   * Set to `false` to tell the component to only accept a single file on upload.\n   *\n   * Defaults to `true`. Accepts multiple files.\n   */\n  @Input() multiple = true;\n\n  /**\n   * Set to `true` for a loading file uploader.\n   */\n  @Input() skeleton = false;\n\n  /**\n   * Sets the size of the button.\n   */\n  @Input() size: 'sm' | 'normal';\n\n  /**\n   * Provides a unique id for the underlying `<input>` node\n   */\n  @Input() fileUploaderId = `file-uploader-${FileUploader.fileUploaderCount}`;\n\n  /**\n   * Maintains a reference to the view DOM element of the underlying `<input>` node\n   */\n  @ViewChild('fileInput', {static: false}) fileInput;\n\n  /**\n   * The list of files that have been submitted to be uploaded\n   */\n  @Input() files = new Set<FileItem>();\n\n  /**\n   * Emits an event to other classes when files change\n   */\n  @Output() filesChange = new EventEmitter<any>();\n\n  @HostBinding('class.file-uploader') baseClass = true;\n\n  protected onTouchedCallback: () => void = noop;\n  protected onChangeCallback: (_: Set<FileItem>) => void = noop;\n\n  constructor() {\n    FileUploader.fileUploaderCount++;\n  }\n\n  /**\n   * Specifies the property to be used as the return value to `ngModel`\n   */\n  get value(): Set<FileItem> {\n    return this.files;\n  }\n  set value(v: Set<FileItem>) {\n    if (v !== this.files) {\n      this.files = v;\n      this.onChangeCallback(v);\n    }\n  }\n\n  onBlur() {\n    this.onTouchedCallback();\n  }\n\n  /**\n   * Propagates the injected `value`.\n   */\n  writeValue(value: Set<FileItem>) {\n    if (value !== this.value) {\n      this.files = value;\n    }\n  }\n\n  onFilesAdded() {\n    const files = this.fileInput.nativeElement.files;\n    if (!this.multiple) {\n      this.files.clear();\n    }\n    for (let file of files) {\n      const fileItem: FileItem = {\n        file,\n        uploaded: false,\n        state: 'edit',\n        invalid: false,\n        invalidText: '',\n      };\n      this.files.add(fileItem);\n      this.filesChange.emit(this.files);\n    }\n\n    this.value = this.files;\n  }\n\n  removeFile(fileItem) {\n    this.files.delete(fileItem);\n    this.fileInput.nativeElement.value = '';\n    this.filesChange.emit(this.files);\n  }\n\n  /**\n   * Registers the injected function to control the touch use of the `FileUploader`.\n   */\n  registerOnTouched(fn: any) {\n    this.onTouchedCallback = fn;\n  }\n  /**\n   * Sets a method in order to propagate changes back to the form.\n   */\n  registerOnChange(fn: any) {\n    this.onChangeCallback = fn;\n  }\n}\n"]}