@stratio/egeo
Version:
237 lines • 18.8 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';
var ListItemComponent = /** @class */ (function () {
function ListItemComponent() {
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;
}
Object.defineProperty(ListItemComponent.prototype, "itemName", {
get: /**
* @return {?}
*/
function () {
return this.item && this.item.name !== undefined && this.item.name !== null ? this.item.name : '';
},
enumerable: true,
configurable: true
});
Object.defineProperty(ListItemComponent.prototype, "itemQaTag", {
get: /**
* @return {?}
*/
function () {
return this.qaTag + '-item-' + this.item.id;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ListItemComponent.prototype, "checkQaTag", {
get: /**
* @return {?}
*/
function () {
return this.qaTag + '-check-' + this.item.id;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ListItemComponent.prototype, "selected", {
get: /**
* @return {?}
*/
function () {
return this.item.selected ? true : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ListItemComponent.prototype, "itemMode", {
get: /**
* @return {?}
*/
function () {
/** @type {?} */
var style = this.getModeStyle();
style += this.selected ? ' sth-two-list-selection__selected_item' : '';
return style;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
ListItemComponent.prototype.getModeStyle = /**
* @return {?}
*/
function () {
return this.mode === 'normal' ? 'item-normal sth-two-list-selection__item-normal' :
'item-compact sth-two-list-selection__item-compact';
};
/**
* @param {?} event
* @return {?}
*/
ListItemComponent.prototype.emitOnClickNonEditable = /**
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
event.stopImmediatePropagation();
this.selectItemNonEditable.emit(this.item);
};
/**
* @param {?} event
* @return {?}
*/
ListItemComponent.prototype.emitOnSelect = /**
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
event.stopImmediatePropagation();
if (!this.item.disabled) {
this.selectItem.emit(this.item);
}
};
/**
* @return {?}
*/
ListItemComponent.prototype.mouseHoverRow = /**
* @return {?}
*/
function () {
this.hoverRow = true;
};
/**
* @return {?}
*/
ListItemComponent.prototype.mouseLeftRow = /**
* @return {?}
*/
function () {
this.hoverRow = false;
};
/**
* @return {?}
*/
ListItemComponent.prototype.onCloseActionMenu = /**
* @return {?}
*/
function () {
if (this.showActionList) {
this.showActionList = false;
}
};
/**
* @param {?} option
* @return {?}
*/
ListItemComponent.prototype.onChangeOption = /**
* @param {?} option
* @return {?}
*/
function (option) {
this.emitOnClickNonEditable(new CustomEvent('selectItem', { bubbles: true, cancelable: true, detail: Object.assign(this.item, option) }));
};
/**
* @return {?}
*/
ListItemComponent.prototype.onEllipsisClick = /**
* @return {?}
*/
function () {
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 = function () { return []; };
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);
return 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"]}