ngx-edu-components
Version:
Set of extra angular material components.
170 lines • 16 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, } from "@angular/core";
import Viewer from "viewerjs";
import * as uuid from "uuid";
import { GalleryOptions } from "./gallery-options";
/**
* INSTRUCCIONES DE USO
*
* Instalar:
* npm install viewerjs --save
*
* Configurar en angular.json
* en styles > "node_modules/viewerjs/dist/viewer.css"
* en scripts > "node_modules/viewerjs/dist/viewer.js"
*
* Importar en módulo ImageToolsModule en tu módulo
*
* Crear la siguiente variable en tu componente para cargar las imagenes a mostrar en la galería -> images: ImageItem[] = [];
* Cuando se realizen cambios en el array de imagenes, realizar la siguiente asignación para refrescar cambios -> this.images = [...this.images];
*
* Agregar el siguiente código en donde quieras que se muestre la galería. Opcionalmente setear imagesHeight (por defecto 200px).
* <ngx-edu-gallery [images]="images" [imagesHeight]="200"></ngx-edu-gallery>
*/
export class NgxEduGalleryComponent {
constructor() {
this.id = uuid.v4();
this.gallery = null;
this.images = [];
this.imagesHeight = 200;
this.defaultImageUrl = "";
this.galleryOptions = {
showAlt: true,
showRemoveImage: false,
};
this.onRemove = new EventEmitter();
}
/**
* @return {?}
*/
ngOnInit() { }
/**
* @return {?}
*/
ngOnChanges() {
console.log("NgxEduGalleryComponent > ngOnChanges > 1", this.images);
if (this.images.length > 0) {
console.log("NgxEduGalleryComponent > ngOnChanges > 2");
setTimeout((/**
* @return {?}
*/
() => {
console.log("NgxEduGalleryComponent > ngOnChanges > 3");
this.initialize();
}), 1000);
}
}
/**
* @return {?}
*/
ngOnDestroy() {
console.log("NgxEduGalleryComponent > ngOnDestroy > 1", this.gallery);
if (this.gallery) {
console.log("NgxEduGalleryComponent > ngOnDestroy > 2");
this.gallery.destroy();
}
}
/**
* @return {?}
*/
initialize() {
console.log("NgxEduGalleryComponent > initialize > 1", this.gallery);
if (this.gallery) {
console.log("NgxEduGalleryComponent > initialize > 2");
this.gallery.destroy();
}
/** @type {?} */
const ul = document.getElementById(this.id);
console.log("NgxEduGalleryComponent > initialize > 3 > ul", ul);
if (!ul)
return;
this.gallery = new Viewer(ul);
console.log("NgxEduGalleryComponent > initialize > 3", this.gallery);
}
/**
* @param {?} event
* @return {?}
*/
onError(event) {
if (!event)
return;
event.target.src = this.defaultImageUrl;
}
/**
* @return {?}
*/
show() {
console.log("NgxEduGalleryComponent > show > 1");
if (!this.gallery)
return;
console.log("NgxEduGalleryComponent > show > 2");
this.gallery.show();
}
/**
* @param {?} index
* @return {?}
*/
view(index) {
console.log("NgxEduGalleryComponent > view > 1", this.gallery, index);
if (!this.gallery || index < 0)
return;
console.log("NgxEduGalleryComponent > view > 2");
this.gallery.view(index);
}
/**
* @param {?} zoom
* @return {?}
*/
zoom(zoom) {
if (!this.gallery)
return;
this.gallery.zoomTo(zoom);
}
/**
* @param {?} image
* @param {?} position
* @return {?}
*/
remove(image, position) {
this.onRemove.emit({
image: image,
position: position,
});
}
}
NgxEduGalleryComponent.decorators = [
{ type: Component, args: [{
selector: "ngx-edu-gallery",
template: "<ul [id]=\"id\" class=\"ngx-edu-gallery\">\r\n <li *ngFor=\"let image of images; let i = index\">\r\n <mat-card>\r\n <div class=\"image-container\" *ngIf=\"defaultImageUrl\">\r\n <mat-icon\r\n class=\"remove-image\"\r\n matTooltip=\"Quitar\"\r\n (click)=\"remove(image, i)\"\r\n *ngIf=\"galleryOptions.showRemoveImage\"\r\n >cancel</mat-icon\r\n >\r\n <img\r\n src=\"{{ image.url ? image.url : '' }}\"\r\n alt=\"{{ image.alt ? image.alt : '' }}\"\r\n (error)=\"onError($event)\"\r\n [style.height.px]=\"imagesHeight\"\r\n />\r\n <div class=\"description\" *ngIf=\"galleryOptions.showAlt\">\r\n {{ image.alt ? image.alt : \"\" }}\r\n </div>\r\n </div>\r\n <div\r\n fxLayout=\"row\"\r\n fxLayoutAlign=\"center center\"\r\n *ngIf=\"!defaultImageUrl\"\r\n >\r\n <span>El par\u00E1metro de entrada [defaultImageUrl] es requerido.</span>\r\n </div>\r\n </mat-card>\r\n </li>\r\n</ul>\r\n",
styles: [".ngx-edu-gallery{list-style-type:none;margin:0;padding:0}.ngx-edu-gallery li{display:inline-block;margin-right:8px;margin-bottom:8px;padding:0}.ngx-edu-gallery li mat-card{max-width:unset;min-width:unset}.ngx-edu-gallery li mat-card .image-container{position:relative}.ngx-edu-gallery li mat-card .image-container .remove-image{position:absolute;top:-12px;right:-12px;cursor:pointer}.ngx-edu-gallery li mat-card .image-container img{cursor:pointer}.ngx-edu-gallery li mat-card .image-container .description{position:absolute;background-color:#000;opacity:.8;color:#fff!important;font-size:20px;padding:8px!important;width:100%!important;left:0;bottom:0}"]
}] }
];
/** @nocollapse */
NgxEduGalleryComponent.ctorParameters = () => [];
NgxEduGalleryComponent.propDecorators = {
images: [{ type: Input }],
imagesHeight: [{ type: Input }],
defaultImageUrl: [{ type: Input }],
galleryOptions: [{ type: Input }],
onRemove: [{ type: Output }]
};
if (false) {
/** @type {?} */
NgxEduGalleryComponent.prototype.id;
/** @type {?} */
NgxEduGalleryComponent.prototype.gallery;
/** @type {?} */
NgxEduGalleryComponent.prototype.images;
/** @type {?} */
NgxEduGalleryComponent.prototype.imagesHeight;
/** @type {?} */
NgxEduGalleryComponent.prototype.defaultImageUrl;
/** @type {?} */
NgxEduGalleryComponent.prototype.galleryOptions;
/** @type {?} */
NgxEduGalleryComponent.prototype.onRemove;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-edu-gallery.component.js","sourceRoot":"ng://ngx-edu-components/","sources":["lib/ngx-edu-gallery/ngx-edu-gallery.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n} from \"@angular/core\";\r\nimport { ImageItem } from \"./image-item\";\r\nimport Viewer from \"viewerjs\";\r\nimport * as uuid from \"uuid\";\r\nimport { GalleryOptions } from \"./gallery-options\";\r\n\r\n/**\r\n * INSTRUCCIONES DE USO\r\n *\r\n * Instalar:\r\n *  npm install viewerjs --save\r\n *\r\n * Configurar en angular.json\r\n *  en styles > \"node_modules/viewerjs/dist/viewer.css\"\r\n *  en scripts > \"node_modules/viewerjs/dist/viewer.js\"\r\n *\r\n * Importar en módulo ImageToolsModule en tu módulo\r\n *\r\n * Crear la siguiente variable en tu componente para cargar las imagenes a mostrar en la galería -> images: ImageItem[] = [];\r\n * Cuando se realizen cambios en el array de imagenes, realizar la siguiente asignación para refrescar cambios -> this.images = [...this.images];\r\n *\r\n * Agregar el siguiente código en donde quieras que se muestre la galería. Opcionalmente setear imagesHeight (por defecto 200px).\r\n * <ngx-edu-gallery [images]=\"images\" [imagesHeight]=\"200\"></ngx-edu-gallery>\r\n */\r\n@Component({\r\n  selector: \"ngx-edu-gallery\",\r\n  templateUrl: \"ngx-edu-gallery.component.html\",\r\n  styleUrls: [\"ngx-edu-gallery.component.scss\"],\r\n})\r\nexport class NgxEduGalleryComponent implements OnInit, OnChanges, OnDestroy {\r\n  id: string;\r\n  gallery: any;\r\n  @Input() images: ImageItem[];\r\n  @Input() imagesHeight: number;\r\n  @Input() defaultImageUrl: string;\r\n  @Input() galleryOptions: GalleryOptions;\r\n  @Output() onRemove: EventEmitter<any>;\r\n\r\n  constructor() {\r\n    this.id = uuid.v4();\r\n    this.gallery = null;\r\n    this.images = [];\r\n    this.imagesHeight = 200;\r\n    this.defaultImageUrl = \"\";\r\n    this.galleryOptions = {\r\n      showAlt: true,\r\n      showRemoveImage: false,\r\n    };\r\n    this.onRemove = new EventEmitter<any>();\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  ngOnChanges() {\r\n    console.log(\"NgxEduGalleryComponent > ngOnChanges > 1\", this.images);\r\n    if (this.images.length > 0) {\r\n      console.log(\"NgxEduGalleryComponent > ngOnChanges > 2\");\r\n      setTimeout(() => {\r\n        console.log(\"NgxEduGalleryComponent > ngOnChanges > 3\");\r\n        this.initialize();\r\n      }, 1000);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    console.log(\"NgxEduGalleryComponent > ngOnDestroy > 1\", this.gallery);\r\n    if (this.gallery) {\r\n      console.log(\"NgxEduGalleryComponent > ngOnDestroy > 2\");\r\n      this.gallery.destroy();\r\n    }\r\n  }\r\n\r\n  public initialize() {\r\n    console.log(\"NgxEduGalleryComponent > initialize > 1\", this.gallery);\r\n    if (this.gallery) {\r\n      console.log(\"NgxEduGalleryComponent > initialize > 2\");\r\n      this.gallery.destroy();\r\n    }\r\n    const ul = document.getElementById(this.id);\r\n    console.log(\"NgxEduGalleryComponent > initialize > 3 > ul\", ul);\r\n    if (!ul) return;\r\n    this.gallery = new Viewer(ul);\r\n    console.log(\"NgxEduGalleryComponent > initialize > 3\", this.gallery);\r\n  }\r\n\r\n  onError(event) {\r\n    if (!event) return;\r\n    event.target.src = this.defaultImageUrl;\r\n  }\r\n\r\n  public show() {\r\n    console.log(\"NgxEduGalleryComponent > show > 1\");\r\n    if (!this.gallery) return;\r\n    console.log(\"NgxEduGalleryComponent > show > 2\");\r\n    this.gallery.show();\r\n  }\r\n\r\n  public view(index: number) {\r\n    console.log(\"NgxEduGalleryComponent > view > 1\", this.gallery, index);\r\n    if (!this.gallery || index < 0) return;\r\n    console.log(\"NgxEduGalleryComponent > view > 2\");\r\n    this.gallery.view(index);\r\n  }\r\n\r\n  public zoom(zoom: number) {\r\n    if (!this.gallery) return;\r\n    this.gallery.zoomTo(zoom);\r\n  }\r\n\r\n  remove(image: ImageItem, position: number) {\r\n    this.onRemove.emit({\r\n      image: image,\r\n      position: position,\r\n    });\r\n  }\r\n}\r\n"]}