angular-weblineindia-swipe
Version:
An AngularJS based Swipe List component which provides swipe effects in your Angular application. It also allows you to change button options like you can place delete / edit / info buttons as per your requirements.
287 lines • 29 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, EventEmitter, HostListener, Input, Output, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';
import { SwipeServiceService } from '../swipe-service.service';
export class ItemListComponent {
/**
* @param {?} elRef
* @param {?} swService
*/
constructor(elRef, swService) {
this.swService = swService;
this.alive = true;
this.selfElement = null;
this.idElement = null;
this.disabledMark = false;
this.showMark = false;
this.itemClass = '';
this.callback = new EventEmitter();
this.swClick = new EventEmitter();
this.random = (/**
* @return {?}
*/
() => {
/** @type {?} */
const d = new Date();
return d.getTime();
});
this.swipeleft = (/**
* @param {?} res
* @return {?}
*/
(res) => {
this.swService.closeAll(this.selfElement.id);
if (!this.disabledMark) {
this.result = (res.deltaX < 0);
}
});
this.clickItem = (/**
* @param {?} a
* @return {?}
*/
(a) => this.swClick.emit(a));
this.action = (/**
* @param {?=} opt
* @return {?}
*/
(opt = '') => {
try {
this.result = false;
const { id } = this.inside;
if (opt === 'edit') {
this.callback.emit({ action: 'edit', value: id });
}
else if (opt === 'trash') {
this.callback.emit({ action: 'trash', value: id });
}
}
catch (e) {
console.error('Debes definir ID de edit, y trash');
}
});
this.render = (/**
* @return {?}
*/
() => {
console.log('INIT');
/**
* Template MARK
**/
if (this.showMark) {
if (this.inside.mark && !this.markTemplate) {
/** @type {?} */
const viewMark = this.defaultMark.createEmbeddedView(null);
this.viewContainerMark.insert(viewMark);
}
else if (this.inside.mark && this.markTemplate) {
/** @type {?} */
const viewMark = this.markTemplate.createEmbeddedView(null);
this.viewContainerMark.insert(viewMark);
}
if (!this.inside.mark && !this.notMarkTemplate) {
/** @type {?} */
const viewMark = this.defaultNotMark.createEmbeddedView(null);
this.viewContainerMark.insert(viewMark);
}
else if (!this.inside.mark && this.notMarkTemplate) {
/** @type {?} */
const viewMark = this.notMarkTemplate.createEmbeddedView(null);
this.viewContainerMark.insert(viewMark);
}
}
/**
* Template EDIT
**/
if (this.editTemplate) {
/** @type {?} */
const viewEdit = this.editTemplate.createEmbeddedView(null);
if (this.viewContainerEdit) {
this.viewContainerEdit.insert(viewEdit);
}
}
else if (this.editTemplate !== null) {
/** @type {?} */
const viewEdit = this.defaultEdit.createEmbeddedView(null);
this.viewContainerEdit.insert(viewEdit);
}
/**
* Template TRASH
**/
if (this.trashTemplate) {
/** @type {?} */
const viewTrash = this.trashTemplate.createEmbeddedView(null);
if (this.viewContainerTrash) {
this.viewContainerTrash.insert(viewTrash);
}
}
else if (this.trashTemplate !== null) {
/** @type {?} */
const viewTrash = this.defaultTrash.createEmbeddedView(null);
this.viewContainerTrash.insert(viewTrash);
}
setTimeout((/**
* @return {?}
*/
() => {
if (this.customTemplate) { // Si tiene
// Si tiene
/** @type {?} */
const dataInside = Object.assign({}, this.inside, { touch: this.selfElement.id });
/** @type {?} */
const viewCustomTemplate = this.customTemplate.createEmbeddedView({
item: dataInside,
id: this.selfElement.id
});
if (viewCustomTemplate) {
this.viewContainerCustom.insert(viewCustomTemplate);
}
}
else {
/** @type {?} */
const viewCustomTemplate = this.defaultCustom.createEmbeddedView(null);
this.viewContainerCustom.insert(viewCustomTemplate);
}
}), 10);
});
this.selfElement = elRef.nativeElement;
this.idElement = `list-swipe-${this.random()}`;
this.selfElement.setAttribute('data-id', this.idElement);
this.selfElement.id = this.idElement;
this.swService.swipeObserver.subscribe((/**
* @param {?} a
* @return {?}
*/
a => {
if (a !== this.selfElement.id) {
this.result = false;
}
}));
}
/**
* @param {?} event
* @return {?}
*/
clickOut(event) {
if (!this.selfElement.contains(event.target)) {
this.result = false;
}
}
/**
* @return {?}
*/
ngAfterViewInit() {
this.render();
// throw new Error("Method not implemented.");
}
/**
* @return {?}
*/
ngOnInit() {
}
}
ItemListComponent.decorators = [
{ type: Component, args: [{
selector: 'sw-item-list',
template: "<div class=\"{{itemClass}}\" (swipeleft)=\"swipeleft($event)\" (swipe)=\"swipeleft($event)\" >\n <ng-template #defaultEdit>\n edit\n </ng-template>\n <ng-template #defaultTrash>\n trash\n </ng-template>\n <ng-template #defaultMark>\n <div class=\"yes-marker\"></div>\n </ng-template>\n <ng-template #defaultNotMark>\n <div class=\"not-marker\"></div>\n </ng-template>\n\n <ng-template #defaultCustom>\n <div data-id=\"{{idElement}}\" class=\"text truncate\">{{inside?.title}}</div>\n <div data-id=\"{{idElement}}\" class=\"small truncate\">{{inside?.subTitle}}</div>\n </ng-template>\n\n\n <div [ngClass]=\"{'active':(result)}\" data-id=\"{{idElement}}\"\n class=\" options-btn swipe-d-flex justify-content-between\">\n <div (click)=\"action('edit')\" class=\"option-list\" *ngIf=\"editTemplate !== null\">\n <ng-template let-show=\"show\" #viewContainerEdit></ng-template>\n </div>\n <div (click)=\"action('trash')\" class=\"option-list\" *ngIf=\"trashTemplate !== null\">\n <ng-template let-show=\"show\" #viewContainerTrash></ng-template>\n </div>\n </div>\n <div [ngClass]=\"{'left-swipe':(result)}\" data-id=\"{{idElement}}\" class=\"list-swipe swipe-d-flex\">\n\n <div *ngIf=\"showMark\" class=\"swipe-w-10\">\n <ng-container #viewContainerMark></ng-container>\n </div>\n\n <div (click)=\"clickItem($event)\" [ngClass]=\"{'swipe-w-90':showMark, 'swipe-w-100':!showMark}\">\n <div *ngIf=\"customTemplate\" data-id=\"{{idElement}}\">\n <ng-template #viewContainerCustom>\n </ng-template>\n </div>\n\n <div *ngIf=\"!customTemplate\">\n <ng-template #viewContainerCustom></ng-template>\n </div>\n\n </div>\n <div class=\"mark\"></div>\n </div>\n</div>\n",
styles: [":host{display:block;font-family:Arial,serif}.not-marker{background:red;width:1rem;height:1rem;border-radius:3rem}.yes-marker{background:green;width:1rem;height:1rem;border-radius:3rem}.swipe-d-flex{display:flex}.swipe-w-10{width:10%}.swipe-w-100{width:100%}.swipe-w-90{width:90%}.options-btn.active{display:flex;transform:translate(66vw,0)}.list-swipe{box-shadow:0 5px 7px rgba(181,181,181,.18);border-radius:.25em;padding:.75em;font-weight:500;font-size:16px;line-height:19px;z-index:9;margin:.75rem 0;transition:50ms ease-out}.left-swipe{transform:translate(-29vw,0);transition:50ms ease-out;box-shadow:6px 0 7px rgba(181,181,181,.31)}.options-btn{position:absolute;display:none;transform:translate(100vw,0);padding:.5rem 0;width:28vw}.list-swipe .text{color:#313131}.list-swipe .small{font-weight:500;font-size:16px;line-height:19px;color:#9b9b9b;padding:1rem 0 0}.list-swipe .mark{background:#fff;height:2rem;margin-top:.75rem;margin-right:-.3rem;border-right:.175rem solid #f96060}.option-list{width:100%;min-height:3.75rem;line-height:3.75rem;border-right:1px solid rgba(0,0,0,.1);text-align:center}.option-list:last-child{border-right:0}.truncate{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}"]
}] }
];
/** @nocollapse */
ItemListComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: SwipeServiceService }
];
ItemListComponent.propDecorators = {
inside: [{ type: Input }],
disabledMark: [{ type: Input, args: ['disable-mark',] }],
showMark: [{ type: Input, args: ['show-mark',] }],
itemClass: [{ type: Input, args: ['item-class',] }],
defaultEdit: [{ type: ViewChild, args: ['defaultEdit',] }],
defaultTrash: [{ type: ViewChild, args: ['defaultTrash',] }],
defaultMark: [{ type: ViewChild, args: ['defaultMark',] }],
defaultNotMark: [{ type: ViewChild, args: ['defaultNotMark',] }],
defaultCustom: [{ type: ViewChild, args: ['defaultCustom',] }],
customTemplate: [{ type: Input, args: ['customTemplate',] }],
editTemplate: [{ type: Input, args: ['editTemplate',] }],
trashTemplate: [{ type: Input, args: ['trashTemplate',] }],
markTemplate: [{ type: Input, args: ['markTemplate',] }],
notMarkTemplate: [{ type: Input, args: ['notMarkTemplate',] }],
callback: [{ type: Output }],
swClick: [{ type: Output }],
viewContainerEdit: [{ type: ViewChild, args: ['viewContainerEdit', { static: false, read: ViewContainerRef },] }],
viewContainerTrash: [{ type: ViewChild, args: ['viewContainerTrash', { static: false, read: ViewContainerRef },] }],
viewContainerMark: [{ type: ViewChild, args: ['viewContainerMark', { static: false, read: ViewContainerRef },] }],
viewContainerCustom: [{ type: ViewChild, args: ['viewContainerCustom', { static: false, read: ViewContainerRef },] }],
clickOut: [{ type: HostListener, args: ['document:click', ['$event'],] }]
};
if (false) {
/** @type {?} */
ItemListComponent.prototype.alive;
/** @type {?} */
ItemListComponent.prototype.result;
/** @type {?} */
ItemListComponent.prototype.selfElement;
/** @type {?} */
ItemListComponent.prototype.idElement;
/** @type {?} */
ItemListComponent.prototype.inside;
/** @type {?} */
ItemListComponent.prototype.disabledMark;
/** @type {?} */
ItemListComponent.prototype.showMark;
/** @type {?} */
ItemListComponent.prototype.itemClass;
/** @type {?} */
ItemListComponent.prototype.defaultEdit;
/** @type {?} */
ItemListComponent.prototype.defaultTrash;
/** @type {?} */
ItemListComponent.prototype.defaultMark;
/** @type {?} */
ItemListComponent.prototype.defaultNotMark;
/** @type {?} */
ItemListComponent.prototype.defaultCustom;
/** @type {?} */
ItemListComponent.prototype.customTemplate;
/** @type {?} */
ItemListComponent.prototype.editTemplate;
/** @type {?} */
ItemListComponent.prototype.trashTemplate;
/** @type {?} */
ItemListComponent.prototype.markTemplate;
/** @type {?} */
ItemListComponent.prototype.notMarkTemplate;
/** @type {?} */
ItemListComponent.prototype.callback;
/** @type {?} */
ItemListComponent.prototype.swClick;
/** @type {?} */
ItemListComponent.prototype.viewContainerEdit;
/** @type {?} */
ItemListComponent.prototype.viewContainerTrash;
/** @type {?} */
ItemListComponent.prototype.viewContainerMark;
/** @type {?} */
ItemListComponent.prototype.viewContainerCustom;
/**
* @type {?}
* @private
*/
ItemListComponent.prototype.random;
/** @type {?} */
ItemListComponent.prototype.swipeleft;
/** @type {?} */
ItemListComponent.prototype.clickItem;
/** @type {?} */
ItemListComponent.prototype.action;
/** @type {?} */
ItemListComponent.prototype.render;
/**
* @type {?}
* @private
*/
ItemListComponent.prototype.swService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item-list.component.js","sourceRoot":"ng://swipe-angular-list/","sources":["lib/item-list/item-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild, ViewContainerRef, OnInit\n} from '@angular/core';\nimport {SwipeServiceService} from '../swipe-service.service';\n\n@Component({\n  selector: 'sw-item-list',\n  templateUrl: './item-list.component.html',\n  styleUrls: ['./item-list.component.css']\n})\nexport class ItemListComponent implements AfterViewInit, OnInit  {\n  alive = true;\n  result: boolean;\n  selfElement = null;\n  idElement = null;\n  @Input() inside: {\n    id,\n    title: '',\n    subTitle: '',\n    mark: false,\n  };\n\n  @Input('disable-mark') disabledMark = false;\n\n  @Input('show-mark') showMark = false;\n\n  @Input('item-class') itemClass = '';\n\n  // @ts-ignore\n  @ViewChild('defaultEdit') defaultEdit: TemplateRef<any>;\n  // @ts-ignore\n  @ViewChild('defaultTrash') defaultTrash: TemplateRef<any>;\n\n  // @ts-ignore\n  @ViewChild('defaultMark') defaultMark: TemplateRef<any>;\n  // @ts-ignore\n  @ViewChild('defaultNotMark') defaultNotMark: TemplateRef<any>;\n  // @ts-ignore\n  @ViewChild('defaultCustom') defaultCustom: TemplateRef<any>;\n\n  // tslint:disable-next-line:no-input-rename\n  @Input('customTemplate') customTemplate: TemplateRef<any>;\n  // tslint:disable-next-line:no-input-rename\n  @Input('editTemplate') editTemplate: TemplateRef<any>;\n  // tslint:disable-next-line:no-input-rename\n  @Input('trashTemplate') trashTemplate: TemplateRef<any>;\n  // tslint:disable-next-line:no-input-rename\n  @Input('markTemplate') markTemplate: TemplateRef<any>;\n  // tslint:disable-next-line:no-input-rename\n  @Input('notMarkTemplate') notMarkTemplate: TemplateRef<any>;\n\n  @Output()\n  callback = new EventEmitter<any>();\n\n  @Output()\n  swClick = new EventEmitter<any>();\n\n  @ViewChild('viewContainerEdit', {static: false, read: ViewContainerRef})\n  viewContainerEdit: ViewContainerRef;\n\n  @ViewChild('viewContainerTrash', {static: false, read: ViewContainerRef})\n  viewContainerTrash: ViewContainerRef;\n\n  @ViewChild('viewContainerMark', {static: false, read: ViewContainerRef})\n  viewContainerMark: ViewContainerRef;\n\n  @ViewChild('viewContainerCustom', {static: false, read: ViewContainerRef})\n  viewContainerCustom: ViewContainerRef;\n\n  @HostListener('document:click', ['$event'])\n  clickOut(event) {\n    if (!this.selfElement.contains(event.target)) {\n      this.result = false;\n    }\n  }\n\n  constructor(elRef: ElementRef, private swService: SwipeServiceService) {\n    this.selfElement = elRef.nativeElement;\n    this.idElement = `list-swipe-${this.random()}`;\n    this.selfElement.setAttribute('data-id', this.idElement);\n    this.selfElement.id = this.idElement;\n    this.swService.swipeObserver.subscribe(a => {\n      if (a !== this.selfElement.id) {\n        this.result = false;\n      }\n    });\n  }\n  ngAfterViewInit(): void {\n    this.render();\n    // throw new Error(\"Method not implemented.\");\n  }\n\n  private random = () => {\n    const d = new Date();\n    return d.getTime();\n  };\n\n\n  public swipeleft = (res:any) => {\n    this.swService.closeAll(this.selfElement.id);\n        if (!this.disabledMark) {\n          this.result = (res.deltaX < 0);\n        }\n  }\n\n  clickItem = (a: any) => this.swClick.emit(a);\n\n  action = (opt = '') => {\n    try {\n      this.result = false;\n      const {id} = this.inside;\n      if (opt === 'edit') {\n        this.callback.emit({action: 'edit', value: id});\n      } else if (opt === 'trash') {\n        this.callback.emit({action: 'trash', value: id});\n      }\n    } catch (e) {\n      console.error('Debes definir ID de edit, y trash');\n    }\n  };\n\n  ngOnInit(): void {\n\n\n  }\n\n  render = () => {\n        console.log('INIT')\n    /**\n     * Template MARK\n     **/\n    if (this.showMark) {\n      if (this.inside.mark && !this.markTemplate) {\n        const viewMark = this.defaultMark.createEmbeddedView(null);\n        this.viewContainerMark.insert(viewMark);\n      } else if (this.inside.mark && this.markTemplate) {\n        const viewMark = this.markTemplate.createEmbeddedView(null);\n        this.viewContainerMark.insert(viewMark);\n      }\n\n      if (!this.inside.mark && !this.notMarkTemplate) {\n        const viewMark = this.defaultNotMark.createEmbeddedView(null);\n        this.viewContainerMark.insert(viewMark);\n      } else if (!this.inside.mark && this.notMarkTemplate) {\n        const viewMark = this.notMarkTemplate.createEmbeddedView(null);\n        this.viewContainerMark.insert(viewMark);\n      }\n    }\n    /**\n     * Template EDIT\n     **/\n    if (this.editTemplate) {\n      const viewEdit = this.editTemplate.createEmbeddedView(null);\n      if (this.viewContainerEdit) {\n        this.viewContainerEdit.insert(viewEdit);\n      }\n    } else if (this.editTemplate !== null) {\n      const viewEdit = this.defaultEdit.createEmbeddedView(null);\n      this.viewContainerEdit.insert(viewEdit);\n    }\n\n    /**\n     * Template TRASH\n     **/\n\n    if (this.trashTemplate) {\n      const viewTrash = this.trashTemplate.createEmbeddedView(null);\n      if (this.viewContainerTrash) {\n        this.viewContainerTrash.insert(viewTrash);\n      }\n    } else if (this.trashTemplate !== null) {\n      const viewTrash = this.defaultTrash.createEmbeddedView(null);\n      this.viewContainerTrash.insert(viewTrash);\n    }\n\n    setTimeout(() => {\n      if (this.customTemplate) { // Si tiene\n        const dataInside = {...this.inside, ...{touch: this.selfElement.id}};\n        const viewCustomTemplate = this.customTemplate.createEmbeddedView({\n          item: dataInside,\n          id: this.selfElement.id\n        });\n        if (viewCustomTemplate) {\n          this.viewContainerCustom.insert(viewCustomTemplate);\n        }\n      } else {\n        const viewCustomTemplate = this.defaultCustom.createEmbeddedView(null);\n        this.viewContainerCustom.insert(viewCustomTemplate);\n      }\n    }, 10);\n  }\n\n}\n"]}