@asi-ngtools/lib
Version:
This project is a little components library, simple to use, which will help you to simplify your project.
261 lines (260 loc) • 17.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { AsiFileService } from './../../services/asi-file.service';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { DefaultControlValueAccessor } from './../common/default-control-value-accessor';
import { Component, Input, EventEmitter, Output, forwardRef, ViewChild, Renderer2, ElementRef } from '@angular/core';
var AsiImageChooserComponent = /** @class */ (function (_super) {
tslib_1.__extends(AsiImageChooserComponent, _super);
function AsiImageChooserComponent(fileService, renderer, elementRef) {
var _this = _super.call(this) || this;
_this.fileService = fileService;
_this.renderer = renderer;
_this.elementRef = elementRef;
/**
* Label position
*/
_this.labelPosition = 'top';
/**
* Icon to display when empty
*/
_this.icon = 'far fa-image';
/**
* Event emitted when an image is selected
*/
_this.onImageSelected = new EventEmitter();
_this.dragging = false;
_this.loaded = false;
_this.imageLoaded = false;
_this.init = false;
return _this;
}
/**
* @return {?}
*/
AsiImageChooserComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);
};
/**
* @return {?}
*/
AsiImageChooserComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
var _this = this;
if (this.imageSrc != null) {
this.fileService.getBlobImage(this.imageSrc).subscribe(function (blob) {
_this.fileService.blobToBase64(blob, true).subscribe(function (base64) {
_this.image64 = base64;
});
/** @type {?} */
var imageName = _this.imageSrc.split('/').pop();
_this.value = new Blob([blob], { type: blob.type });
_this.value.name = imageName;
_this.init = true;
});
}
else {
this.init = true;
}
};
/**
* @return {?}
*/
AsiImageChooserComponent.prototype.openFileInput = /**
* @return {?}
*/
function () {
this.fileInput.nativeElement.click();
};
/**
* @return {?}
*/
AsiImageChooserComponent.prototype.handleDragEnter = /**
* @return {?}
*/
function () {
this.dragging = true;
};
/**
* @return {?}
*/
AsiImageChooserComponent.prototype.handleDragLeave = /**
* @return {?}
*/
function () {
this.dragging = false;
};
/**
* @param {?} e
* @return {?}
*/
AsiImageChooserComponent.prototype.handleDrop = /**
* @param {?} e
* @return {?}
*/
function (e) {
e.preventDefault();
this.dragging = false;
this.handleInputChange(e);
};
/**
* @return {?}
*/
AsiImageChooserComponent.prototype.handleImageLoad = /**
* @return {?}
*/
function () {
this.imageLoaded = true;
};
/**
* @param {?} event
* @return {?}
*/
AsiImageChooserComponent.prototype.handleInputChange = /**
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var imageFile = event.dataTransfer ? event.dataTransfer.files[0] : event.target.files[0];
/** @type {?} */
var reader = new FileReader();
this.loaded = false;
this.imageFile = imageFile;
reader.onload = this._handleReaderLoaded.bind(this);
reader.readAsDataURL(imageFile);
};
/**
* @param {?} event
* @return {?}
*/
AsiImageChooserComponent.prototype._handleReaderLoaded = /**
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var reader = event.target;
this.image64 = reader.result;
this.onImageSelected.emit(this.imageFile);
this.loaded = true;
this.value = this.imageFile;
};
/**
* @param {?} value
* @return {?}
*/
AsiImageChooserComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
this._value = value;
if (value == null && this.init) {
this.imageSrc = null;
this.image64 = null;
}
};
AsiImageChooserComponent.decorators = [
{ type: Component, args: [{
selector: 'asi-image-chooser',
host: { 'class': 'asi-component asi-image-chooser' },
template: "<label class=\"input-label\" *ngIf=\"label != null\">{{label | translate}}</label>\n\n<label class=\"asi-image-chooser-container\" ondragover=\"return false;\" [class.loaded]=\"loaded\" (dragenter)=\"handleDragEnter()\" (dragleave)=\"handleDragLeave()\"\n (drop)=\"handleDrop($event)\">\n <img *ngIf=\"image64 != null\" [src]=\"image64\" (load)=\"handleImageLoad()\" [class.loaded]=\"imageLoaded\" />\n <input #asiFileInput type=\"file\" [disabled]=\"disabled\" [attr.id]=\"id\" [attr.name]=\"name\" accept=\"image/*\" (change)=\"handleInputChange($event)\">\n <asi-fa-icon *ngIf=\"image64 == null\" (onClick)=\"openFileInput()\" class=\"asi-focus-error\" [icon]=\"icon\" size=\"2x\"></asi-fa-icon>\n</label>\n",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return AsiImageChooserComponent; }),
multi: true
}
]
}] }
];
/** @nocollapse */
AsiImageChooserComponent.ctorParameters = function () { return [
{ type: AsiFileService },
{ type: Renderer2 },
{ type: ElementRef }
]; };
AsiImageChooserComponent.propDecorators = {
id: [{ type: Input }],
name: [{ type: Input }],
label: [{ type: Input }],
labelPosition: [{ type: Input }],
imageSrc: [{ type: Input }],
image64: [{ type: Input }],
icon: [{ type: Input }],
onImageSelected: [{ type: Output }],
fileInput: [{ type: ViewChild, args: ['asiFileInput',] }]
};
return AsiImageChooserComponent;
}(DefaultControlValueAccessor));
export { AsiImageChooserComponent };
if (false) {
/**
* html id
* @type {?}
*/
AsiImageChooserComponent.prototype.id;
/**
* html name
* @type {?}
*/
AsiImageChooserComponent.prototype.name;
/**
* Label to display (is translated)
* @type {?}
*/
AsiImageChooserComponent.prototype.label;
/**
* Label position
* @type {?}
*/
AsiImageChooserComponent.prototype.labelPosition;
/**
* Init the image chooser with an url
* @type {?}
*/
AsiImageChooserComponent.prototype.imageSrc;
/**
* Init the image chooser with a base64
* @type {?}
*/
AsiImageChooserComponent.prototype.image64;
/**
* Icon to display when empty
* @type {?}
*/
AsiImageChooserComponent.prototype.icon;
/**
* Event emitted when an image is selected
* @type {?}
*/
AsiImageChooserComponent.prototype.onImageSelected;
/** @type {?} */
AsiImageChooserComponent.prototype.fileInput;
/** @type {?} */
AsiImageChooserComponent.prototype.dragging;
/** @type {?} */
AsiImageChooserComponent.prototype.loaded;
/** @type {?} */
AsiImageChooserComponent.prototype.imageLoaded;
/** @type {?} */
AsiImageChooserComponent.prototype.imageFile;
/** @type {?} */
AsiImageChooserComponent.prototype.init;
/** @type {?} */
AsiImageChooserComponent.prototype.fileService;
/** @type {?} */
AsiImageChooserComponent.prototype.renderer;
/** @type {?} */
AsiImageChooserComponent.prototype.elementRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-image-chooser.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-image-chooser/asi-image-chooser.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsiFileService } from './../../services/asi-file.service';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DefaultControlValueAccessor } from './../common/default-control-value-accessor';\nimport {\n  Component, Input, EventEmitter, AfterViewInit, Output,\n  forwardRef, ViewChild, OnInit, Renderer2, ElementRef\n} from '@angular/core';\n\n@Component({\n  selector: 'asi-image-chooser',\n  host: { 'class': 'asi-component asi-image-chooser' },\n  templateUrl: './asi-image-chooser.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AsiImageChooserComponent),\n      multi: true\n    }\n  ]\n})\nexport class AsiImageChooserComponent extends DefaultControlValueAccessor implements AfterViewInit, OnInit {\n\n  /** html id */\n  @Input() id: string;\n  /** html name */\n  @Input() name: string;\n\n  /** Label to display (is translated) */\n  @Input() label: string;\n  /** Label position */\n  @Input() labelPosition: 'top' | 'left' | 'right' | 'bottom' | 'bottom-center' | 'top-center' = 'top';\n\n  /** Init the image chooser with an url */\n  @Input() imageSrc: string;\n  /** Init the image chooser with a base64 */\n  @Input() image64: string;\n\n  /** Icon to display when empty */\n  @Input() icon = 'far fa-image';\n\n  /** Event emitted when an image is selected */\n  @Output() onImageSelected = new EventEmitter<File>();\n\n  @ViewChild('asiFileInput') fileInput: any;\n\n  dragging = false;\n  loaded = false;\n  imageLoaded = false;\n  imageFile: File;\n\n  init = false;\n\n  constructor(private fileService: AsiFileService, private renderer: Renderer2,\n    private elementRef: ElementRef) {\n    super();\n  }\n\n  ngOnInit() {\n    this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);\n  }\n\n  ngAfterViewInit() {\n    if (this.imageSrc != null) {\n      this.fileService.getBlobImage(this.imageSrc).subscribe(blob => {\n        this.fileService.blobToBase64(blob, true).subscribe((base64) => {\n          this.image64 = base64;\n        });\n        const imageName = this.imageSrc.split('/').pop();\n        this.value = new Blob([blob], { type: blob.type });\n        this.value.name = imageName;\n        this.init = true;\n      });\n    } else {\n      this.init = true;\n    }\n  }\n\n  openFileInput() {\n    this.fileInput.nativeElement.click();\n  }\n\n  handleDragEnter(): void {\n    this.dragging = true;\n  }\n\n  handleDragLeave(): void {\n    this.dragging = false;\n  }\n\n  handleDrop(e: Event): void {\n    e.preventDefault();\n    this.dragging = false;\n    this.handleInputChange(e);\n  }\n\n  handleImageLoad(): void {\n    this.imageLoaded = true;\n  }\n\n  handleInputChange(event: any) {\n    const imageFile = event.dataTransfer ? event.dataTransfer.files[0] : event.target.files[0];\n    const reader = new FileReader();\n\n    this.loaded = false;\n    this.imageFile = imageFile;\n    reader.onload = this._handleReaderLoaded.bind(this);\n    reader.readAsDataURL(imageFile);\n  }\n\n  _handleReaderLoaded(event: any) {\n    const reader = event.target;\n    this.image64 = reader.result;\n    this.onImageSelected.emit(this.imageFile);\n    this.loaded = true;\n\n    this.value = this.imageFile;\n  }\n\n  writeValue(value: any): void {\n    this._value = value;\n    if (value == null && this.init) {\n      this.imageSrc = null;\n      this.image64 = null;\n    }\n  }\n}\n"]}