@stratio/egeo
Version:
189 lines • 17 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/st-two-list-selection/list-item/list-item.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
/*
* © 2017 Stratio Big Data Inc., Sucursal en España.
*
* This software is licensed under the Apache License, Version 2.0.
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the terms of the License for more details.
*
* SPDX-License-Identifier: Apache-2.0.
*/
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
import { StEgeo, StRequired } from '../../decorators/require-decorators';
import { StDropDownVisualMode } from '../../st-dropdown-menu/st-dropdown-menu.interface';
import { StPopPlacement } from '../../st-pop/st-pop.model';
let ListItemComponent = class ListItemComponent {
constructor() {
this.editable = false;
this.mode = 'normal';
this.disabled = false;
this.selectItem = new EventEmitter();
this.selectItemNonEditable = new EventEmitter();
this.selectExtraLabel = new EventEmitter();
this.hoverRow = false;
this.menuVisualMode = StDropDownVisualMode.MENU_LIST;
this.placement = StPopPlacement.BOTTOM_END;
}
/**
* @return {?}
*/
get itemName() {
return this.item && this.item.name !== undefined && this.item.name !== null ? this.item.name : '';
}
/**
* @return {?}
*/
get itemQaTag() {
return this.qaTag + '-item-' + this.item.id;
}
/**
* @return {?}
*/
get checkQaTag() {
return this.qaTag + '-check-' + this.item.id;
}
/**
* @return {?}
*/
get selected() {
return this.item.selected ? true : false;
}
/**
* @return {?}
*/
get itemMode() {
/** @type {?} */
let style = this.getModeStyle();
style += this.selected ? ' sth-two-list-selection__selected_item' : '';
return style;
}
/**
* @return {?}
*/
getModeStyle() {
return this.mode === 'normal' ? 'item-normal sth-two-list-selection__item-normal' :
'item-compact sth-two-list-selection__item-compact';
}
/**
* @param {?} event
* @return {?}
*/
emitOnClickNonEditable(event) {
event.preventDefault();
event.stopImmediatePropagation();
this.selectItemNonEditable.emit(this.item);
}
/**
* @param {?} event
* @return {?}
*/
emitOnSelect(event) {
event.preventDefault();
event.stopImmediatePropagation();
if (!this.item.disabled) {
this.selectItem.emit(this.item);
}
}
/**
* @return {?}
*/
mouseHoverRow() {
this.hoverRow = true;
}
/**
* @return {?}
*/
mouseLeftRow() {
this.hoverRow = false;
}
/**
* @return {?}
*/
onCloseActionMenu() {
if (this.showActionList) {
this.showActionList = false;
}
}
/**
* @param {?} option
* @return {?}
*/
onChangeOption(option) {
this.emitOnClickNonEditable(new CustomEvent('selectItem', { bubbles: true, cancelable: true, detail: Object.assign(this.item, option) }));
}
/**
* @return {?}
*/
onEllipsisClick() {
this.showActionList = !this.showActionList;
}
};
ListItemComponent.decorators = [
{ type: Component, args: [{
selector: 'list-item',
template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n\n<div class=\"item\" [ngClass]=\"itemMode\" [attr.id]=\"itemQaTag\" [title]=\"itemName\">\n <span *ngIf=\"!editable && !menuOptionList\" class=\"label\">{{itemName}}</span>\n <div class=\"item__row\" *ngIf=\"!editable && menuOptionList\" (mouseenter)=\"mouseHoverRow()\" (mouseleave)=\"mouseLeftRow()\">\n <span class=\"label\" [ngClass]=\"{'primary-link': hoverRow}\" (click)=\"emitOnClickNonEditable($event)\">{{itemName}}</span>\n <st-dropdown-menu *ngIf=\"hoverRow\" class=\"filter-selector\" [items]=\"menuOptionList\" attr.id=\"actionListId\" [placement]=\"placement\"\n [visualMode]=\"menuVisualMode\" [active]=\"showActionList\" (click)=\"onEllipsisClick()\"\n (change)=\"onChangeOption($event)\" (clickOutside)=\"onCloseActionMenu()\" [openToLeft]=\"true\">\n <button class=\"button\" id=\"actions-service\">\n <i class=\"icon-ellipsis\"></i>\n </button>\n </st-dropdown-menu>\n </div>\n <st-checkbox [disabled]=\"disabled\" *ngIf=\"editable\" [qaTag]=\"checkQaTag\" [checked]=\"selected\" (click)=\"emitOnSelect($event)\">\n <span class=\"label\">{{itemName}}</span>\n </st-checkbox>\n <span class=\"extraLabel\" *ngIf=\"item.extraLabel\" [innerHTML]=\"item.extraLabel\"\n (click)=\"selectExtraLabel.emit({element: item, event: $event})\"></span>\n</div>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
styles: ["@charset \"UTF-8\";.item{display:inline-block;min-width:100%;width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;padding-right:10px}.item__row{display:flex;flex-direction:row-reverse}.item__row .filter-selector{position:absolute}.item__row .filter-selector .icon-ellipsis{font-size:20px}.label{overflow:hidden;text-overflow:ellipsis;flex-grow:1;color:#0f1b27;font-size:.938rem;font-weight:400}.label.primary-link{color:#0776df;cursor:pointer}:host{display:block;padding-right:20px}.item-normal{height:25px;line-height:35px}.item-compact{height:27px;line-height:27px}"]
}] }
];
/** @nocollapse */
ListItemComponent.ctorParameters = () => [];
ListItemComponent.propDecorators = {
item: [{ type: Input }],
qaTag: [{ type: Input }],
editable: [{ type: Input }],
mode: [{ type: Input }],
disabled: [{ type: Input }],
menuOptionList: [{ type: Input }],
selectItem: [{ type: Output }],
selectItemNonEditable: [{ type: Output }],
selectExtraLabel: [{ type: Output }]
};
tslib_1.__decorate([
StRequired(),
tslib_1.__metadata("design:type", Object)
], ListItemComponent.prototype, "item", void 0);
tslib_1.__decorate([
StRequired(),
tslib_1.__metadata("design:type", String)
], ListItemComponent.prototype, "qaTag", void 0);
ListItemComponent = tslib_1.__decorate([
StEgeo(),
tslib_1.__metadata("design:paramtypes", [])
], ListItemComponent);
export { ListItemComponent };
if (false) {
/** @type {?} */
ListItemComponent.prototype.item;
/** @type {?} */
ListItemComponent.prototype.qaTag;
/** @type {?} */
ListItemComponent.prototype.editable;
/** @type {?} */
ListItemComponent.prototype.mode;
/** @type {?} */
ListItemComponent.prototype.disabled;
/** @type {?} */
ListItemComponent.prototype.menuOptionList;
/** @type {?} */
ListItemComponent.prototype.selectItem;
/** @type {?} */
ListItemComponent.prototype.selectItemNonEditable;
/** @type {?} */
ListItemComponent.prototype.selectExtraLabel;
/** @type {?} */
ListItemComponent.prototype.hoverRow;
/** @type {?} */
ListItemComponent.prototype.menuVisualMode;
/** @type {?} */
ListItemComponent.prototype.placement;
/** @type {?} */
ListItemComponent.prototype.showActionList;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-item.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-two-list-selection/list-item/list-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\nimport { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\n\nimport { StEgeo, StRequired } from '../../decorators/require-decorators';\nimport { StTwoListSelectionElement, StTwoListSelectExtraLabelAction } from '../st-two-list-selection.model';\n\nimport { StDropDownMenuItem, StDropDownVisualMode } from '../../st-dropdown-menu/st-dropdown-menu.interface';\nimport { StPopPlacement } from '../../st-pop/st-pop.model';\n\n@Component({\n   selector: 'list-item',\n   templateUrl: './list-item.component.html',\n   styleUrls: ['./list-item.component.scss'],\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\n@StEgeo()\nexport class ListItemComponent {\n\n   @Input() @StRequired() item: StTwoListSelectionElement;\n   @Input() @StRequired() qaTag: string;\n   @Input() editable: boolean = false;\n   @Input() mode: 'compact' | 'normal' = 'normal';\n   @Input() disabled: boolean = false;\n   @Input() menuOptionList?: StDropDownMenuItem[];\n\n   @Output() selectItem: EventEmitter<StTwoListSelectionElement> = new EventEmitter<StTwoListSelectionElement>();\n   @Output() selectItemNonEditable: EventEmitter<StTwoListSelectionElement> = new EventEmitter<StTwoListSelectionElement>();\n   @Output() selectExtraLabel: EventEmitter<StTwoListSelectExtraLabelAction> = new EventEmitter<StTwoListSelectExtraLabelAction>();\n\n\n   public hoverRow: boolean = false;\n   public menuVisualMode: StDropDownVisualMode = StDropDownVisualMode.MENU_LIST;\n   public placement: StPopPlacement = StPopPlacement.BOTTOM_END;\n   public showActionList: boolean;\n\n   constructor() { }\n\n   get itemName(): string {\n      return this.item && this.item.name !== undefined && this.item.name !== null ? this.item.name : '';\n   }\n\n   get itemQaTag(): string {\n      return this.qaTag + '-item-' + this.item.id;\n   }\n\n   get checkQaTag(): string {\n      return this.qaTag + '-check-' + this.item.id;\n   }\n\n   get selected(): boolean {\n      return this.item.selected ? true : false;\n   }\n\n   get itemMode(): string {\n      let style: string = this.getModeStyle();\n      style += this.selected ? ' sth-two-list-selection__selected_item' : '';\n      return style;\n   }\n\n   getModeStyle(): string {\n      return this.mode === 'normal' ? 'item-normal sth-two-list-selection__item-normal' :\n         'item-compact sth-two-list-selection__item-compact';\n   }\n\n   emitOnClickNonEditable(event: Event): void {\n      event.preventDefault();\n      event.stopImmediatePropagation();\n      this.selectItemNonEditable.emit(this.item);\n   }\n\n   emitOnSelect(event: Event): void {\n      event.preventDefault();\n      event.stopImmediatePropagation();\n      if (!this.item.disabled) {\n         this.selectItem.emit(this.item);\n      }\n   }\n\n   mouseHoverRow(): void {\n      this.hoverRow = true;\n   }\n\n   mouseLeftRow(): void {\n      this.hoverRow = false;\n   }\n\n   onCloseActionMenu(): void {\n      if (this.showActionList) {\n         this.showActionList = false;\n      }\n   }\n\n   onChangeOption(option: StDropDownMenuItem): void {\n      this.emitOnClickNonEditable(new CustomEvent('selectItem', { bubbles: true, cancelable: true, detail: Object.assign(this.item, option)}));\n   }\n\n   onEllipsisClick(): void {\n      this.showActionList = !this.showActionList;\n   }\n}\n"]}