UNPKG

cubex-multiselect-dropdown

Version:
195 lines (194 loc) 27.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, Input, Output, EventEmitter, HostListener, ElementRef } from '@angular/core'; export class SingleselectDropdownComponent { /** * @param {?} eRef */ constructor(eRef) { this.eRef = eRef; this.selectionLabel = 'Select'; this.optionList = []; this.open = false; this.displayNameKey = ''; this.toggleSelectionKey = ''; this.selectionTextWidth = 11; this.selectionChange = new EventEmitter(); this.onSearchChange = new EventEmitter(); this.isoptionListArayString = false; } /** * @return {?} */ ngOnInit() { this.currentStyles = { "width": '100%', // "width": this.componentWidth+'px', // "height" : this.componentHeight+'px' "height": 'auto', "max-height": this.componentHeight + 'px' }; this.noOption = { "padding-left": (this.componentWidth / 2) - 75 + 'px', "color": "gainsboro" }; this.isoptionListArayString = typeof this.optionList[0] === 'string'; console.log(this.isoptionListArayString, this.optionList); if (!this.selectedOptions) { this.selectedOptions = this.isoptionListArayString ? "" : []; } if (this.isoptionListArayString) { this.filterText = this.selectedOptions; } } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { for (let propName in changes) { if (propName === 'selectedOptions') { if (changes[propName].currentValue === undefined) { return; } else if (Object.getOwnPropertyNames(this.selectedOptions).length === 0) { this.filterText = ''; continue; } if (this.isoptionListArayString) { if (typeof this.selectedOptions != 'undefined') { this.filterText = (/** @type {?} */ (this.selectedOptions)).length < (this.selectionTextWidth + 1) ? (/** @type {?} */ (this.selectedOptions)) : (/** @type {?} */ (this.selectedOptions)).substring(0, this.selectionTextWidth) + '..'; } } else { if (typeof this.selectedOptions[this.displayNameKey] != 'undefined') { this.filterText = (/** @type {?} */ (this.selectedOptions))[this.displayNameKey].length < (this.selectionTextWidth + 1) ? (/** @type {?} */ (this.selectedOptions))[this.displayNameKey] : (/** @type {?} */ (this.selectedOptions))[this.displayNameKey].substring(0, this.selectionTextWidth) + '..'; } } } if (propName === 'optionList') { //console.log("optionList-->", changes[propName].currentValue); this.optionList = changes[propName].currentValue; } } } /** * @param {?} option * @return {?} */ selectOption(option) { if (this.isoptionListArayString) { this.selectedOptions = option; this.selectionChange.emit(this.selectedOptions); this.closeDropdown(); this.filterText = (/** @type {?} */ (this.selectedOptions)).length < (this.selectionTextWidth + 1) ? (/** @type {?} */ (this.selectedOptions)) : (/** @type {?} */ (this.selectedOptions)).substring(0, this.selectionTextWidth) + '..'; } else { this.selectedOptions = option; this.selectionChange.emit(this.selectedOptions); this.closeDropdown(); this.filterText = (/** @type {?} */ (this.selectedOptions))[this.displayNameKey].length < (this.selectionTextWidth + 1) ? (/** @type {?} */ (this.selectedOptions))[this.displayNameKey] : (/** @type {?} */ (this.selectedOptions))[this.displayNameKey].substring(0, this.selectionTextWidth) + '..'; } } /** * @return {?} */ closeDropdown() { this.open = false; if (this.isoptionListArayString) { this.filterText = this.selectedOptions; } else { this.filterText = this.selectedOptions[this.displayNameKey]; } } /** * @return {?} */ toggleDropdown() { this.open = !this.open; if (open) { this.filterText = ''; } } /** * @param {?} event * @return {?} */ clickout(event) { if (!this.eRef.nativeElement.contains(event.target)) { this.open = false; if (this.isoptionListArayString) { this.filterText = this.selectedOptions; } else { this.filterText = this.selectedOptions[this.displayNameKey]; } } } } SingleselectDropdownComponent.decorators = [ { type: Component, args: [{ selector: 'cubex-singleselect-dropdown', template: "<div *ngIf=\"!isoptionListArayString\" style=\"position: relative !important;\">\n <div class=\"form-group proto-select\" (clickOutside)=\"closeDropdown()\">\n <div class=\"form-group__text\">\n <input class=\"text-small text-vibrant Search\" type = 'search' (click)=\"toggleDropdown()\" [(ngModel)]=\"filterText\" placeholder=\"{{selectionPlaceholder}}\" autocomplete=\"nope\" (input)=\"onSearchChange.emit($event.target.value)\"/>\n <label>{{selectionLabel}}</label>\n <i class=\"proto-select-chevron\" (click)=\"toggleDropdown()\"[ngClass]=\"[ open ? 'icon-chevron-up' : 'icon-chevron-down' ]\"></i>\n </div>\n <div class=\"proto-select-backdrop\" (click)=\"toggleDropdown()\" *ngIf=\"open\"></div>\n\n <div class=\"panel panel--raised proto-select-dropdown\" *ngIf=\"open\" [ngClass]=\"{'topClass': selectionLabel == '' || selectionLabel == null || selectionLabel == undefined }\">\n <div class=\"text-small text-muted text-noselect qtr-padding\" *ngIf=\"optionList.length == 0\">\n No option available\n </div>\n\n <div *ngIf=\"open\" class=\"singleselect_hover wordbreak\" [ngStyle]=\"currentStyles\" >\n <!-- <div class=\"panel panel--compressed\" *ngFor=\"let item of optionList | filterObjectsByKey : displayNameKey : filterText | arraySort: displayNameKey\"> -->\n <div class=\"panel panel--compressed\" *ngFor=\"let item of optionList | filterObjectsByKey : displayNameKey : filterText\"> \n <div class=\"hover-cursor\" (click)=\"selectOption(item)\" [ngClass]=\"{'bgColor': selectedOptions[displayNameKey] == item[displayNameKey] }\">\n <div>{{item[displayNameKey] }}</div>\n <div > <i class=\"icon-check icon-right\" *ngIf=\"selectedOptions[displayNameKey] == item[displayNameKey]\"></i></div> \n </div>\n \n <!-- <i class=\"icon-check \" [ngClass]=\"{'bgColor': selectedOptions.name == item.name }\" ></i> -->\n \n </div>\n </div>\n\n </div>\n </div>\n</div>\n\n<div *ngIf=\"isoptionListArayString\" style=\"position: relative !important;\">\n <div class=\"form-group proto-select\" (clickOutside)=\"closeDropdown()\">\n <div class=\"form-group__text\">\n <input class=\"text-small text-vibrant Search\" type = 'search' (click)=\"toggleDropdown()\" [(ngModel)]=\"filterText\" placeholder=\"{{selectionPlaceholder}}\" autocomplete=\"nope\" (input)=\"onSearchChange.emit($event.target.value)\"/>\n <label>{{selectionLabel}}</label>\n <i class=\"proto-select-chevron\" (click)=\"toggleDropdown()\"[ngClass]=\"[ open ? 'icon-chevron-up' : 'icon-chevron-down' ]\"></i>\n </div>\n <div class=\"proto-select-backdrop\" (click)=\"toggleDropdown()\" *ngIf=\"open\"></div>\n\n <div class=\"panel panel--raised proto-select-dropdown bdr\" *ngIf=\"open\" [ngClass]=\"{'topClass': selectionLabel == '' || selectionLabel == null || selectionLabel == undefined }\" [ngStyle]=\"currentStyles\">\n <div class=\"text-small text-muted text-noselect qtr-padding\" *ngIf=\"optionList.length == 0\">\n No option available\n </div>\n\n <div *ngIf=\"open\" class=\"singleselect_hover wordbreak\" [ngStyle]=\"currentStyles\" >\n <div class=\"panel panel--compressed\" *ngFor=\"let item of optionList | filterStrings : filterText\"> \n <div class=\"hover-cursor\" (click)=\"selectOption(item)\" [ngClass]=\"{'bgColor': selectedOptions == item }\">\n <div>{{item }}</div>\n <div > <i class=\"icon-check icon-right\" *ngIf=\"selectedOptions == item\"></i></div> \n </div>\n \n <!-- <i class=\"icon-check \" [ngClass]=\"{'bgColor': selectedOptions.name == item.name }\" ></i> -->\n \n </div>\n </div>\n\n </div>\n </div>\n</div>", styles: [".overlayAnchor{display:inline-block;min-width:250px}.link{text-decoration:underline;cursor:pointer;color:#007493;padding-left:8px}.noOption{padding-top:5px}.tooltip{position:relative;display:inline-block;border-bottom:1px dotted #000}.tooltip .tooltiptext{visibility:hidden;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;min-width:120px;background-color:#555;color:#fff;text-align:center;padding:5px 0;border-radius:6px;position:absolute;z-index:1;top:125%;left:50%;margin-left:-60px;opacity:0;transition:opacity .3s}.tooltip .tooltiptext::after{content:\"\";position:absolute;top:-10px;left:45px;margin-left:-5px;border-width:5px;border-style:solid;border-color:transparent transparent #555}.tooltip:hover .tooltiptext{visibility:visible;opacity:1}.bullet{height:5px;width:5px;background-color:#fff;border-radius:50%;display:inline-block;margin-bottom:3px}.inputBox{border-bottom:1px solid #ddd;border-top:none;border-left:none;border-right:none;width:-webkit-fill-available;width:-moz-available;width:stretch}.dropdown-expanded{border:1px solid #d3d3d3;padding-left:9px;min-width:171px;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;height:-webkit-fit-content;height:-moz-fit-content;height:fit-content;overflow:scroll;float:left}.customInput{outline:0;padding-left:6px;padding-top:3px}.customInput:hover{outline:#ccc solid 1px}.inlineBox{display:block;cursor:pointer;position:relative;padding-left:28px;padding-bottom:6px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin:5px 0;border-bottom:1px solid #ccc;word-wrap:break-word}.inlineBox input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:absolute;top:0;left:0;height:22px;width:22px;background-color:#eee;border-radius:5px}.checkmarkText{position:relative;top:3px}.inlineBox:hover input~.checkmark{background-color:#ccc}.inlineBox input:checked~.checkmark{background-color:#ddd}.checkmark:after{content:\"\";position:absolute;display:none}.inlineBox input:checked~.checkmark:after{display:block}.inlineBox .checkmark:after{left:4px;top:4px;width:14px;height:14px;background:#00beed;border-radius:5px}.proto-select .proto-select-backdrop{position:fixed;top:0;bottom:0;right:0;left:0;z-index:99}.proto-select .proto-select-chevron{position:absolute;bottom:0;right:0;padding:5px 8px;color:gray}.proto-select .proto-select-dropdown{position:absolute;z-index:999;border:1px solid #f1f1f1;overflow-y:auto;padding:0;top:100%;left:0;right:0}.proto-select .proto-select-dropdown .dropdown-header{position:-webkit-sticky;position:sticky;top:0;z-index:99;width:100%;background-color:#fff;border-bottom:1px solid #f1f1f1}.proto-select .proto-select-dropdown .form-group{padding:6px 10px;margin:0}.proto-select .proto-select-dropdown .form-group .checkbox__label{padding-top:2px}.proto-select .proto-select-dropdown .form-group.selected,.proto-select .proto-select-dropdown .form-group.selected:hover{background-color:#00bceb!important;color:#fff}.proto-select .proto-select-dropdown .form-group.selected .checkbox__label,.proto-select .proto-select-dropdown .form-group.selected:hover .checkbox__label{color:#fff!important}.proto-select .proto-select-dropdown .form-group:hover{background-color:#f1f1f1}.singleselect_hover>div>span{display:inline-block!important;width:100%}.singleselect_hover>.panel:hover{background-color:#f1f1f1}.wordbreak{word-break:break-word}.hover-cursor{cursor:pointer;position:relative;padding:5px}.bgColor{background:#00bceb;color:#fff}.icon-right{position:absolute;top:5px;right:5px}.panel--compressed{padding:0!important}.topClass{position:absolute;z-index:999;border:1px solid #f1f1f1;overflow-y:auto;padding:0;top:30px!important;left:0;right:0}.Search::-webkit-search-cancel-button{position:relative;right:20px}"] }] } ]; /** @nocollapse */ SingleselectDropdownComponent.ctorParameters = () => [ { type: ElementRef } ]; SingleselectDropdownComponent.propDecorators = { selectionLabel: [{ type: Input, args: ['label',] }], optionList: [{ type: Input, args: ['data',] }], open: [{ type: Input, args: ['isOpen',] }], selectedOptions: [{ type: Input, args: ['checkedOption',] }], displayNameKey: [{ type: Input, args: ['displayKey',] }], toggleSelectionKey: [{ type: Input, args: ['toggleKey',] }], selectionPlaceholder: [{ type: Input, args: ['placeholder',] }], selectionTextWidth: [{ type: Input, args: ['selectionWidth',] }], componentWidth: [{ type: Input, args: ['width',] }], componentHeight: [{ type: Input, args: ['height',] }], selectionChange: [{ type: Output, args: ['onChange',] }], onSearchChange: [{ type: Output }], clickout: [{ type: HostListener, args: ['document:click', ['$event'],] }] }; if (false) { /** @type {?} */ SingleselectDropdownComponent.prototype.filterText; /** @type {?} */ SingleselectDropdownComponent.prototype.selectionLabel; /** @type {?} */ SingleselectDropdownComponent.prototype.optionList; /** @type {?} */ SingleselectDropdownComponent.prototype.open; /** @type {?} */ SingleselectDropdownComponent.prototype.selectedOptions; /** @type {?} */ SingleselectDropdownComponent.prototype.displayNameKey; /** @type {?} */ SingleselectDropdownComponent.prototype.toggleSelectionKey; /** @type {?} */ SingleselectDropdownComponent.prototype.selectionPlaceholder; /** @type {?} */ SingleselectDropdownComponent.prototype.selectionTextWidth; /** @type {?} */ SingleselectDropdownComponent.prototype.componentWidth; /** @type {?} */ SingleselectDropdownComponent.prototype.componentHeight; /** @type {?} */ SingleselectDropdownComponent.prototype.selectionChange; /** @type {?} */ SingleselectDropdownComponent.prototype.onSearchChange; /** @type {?} */ SingleselectDropdownComponent.prototype.currentStyles; /** @type {?} */ SingleselectDropdownComponent.prototype.noOption; /** @type {?} */ SingleselectDropdownComponent.prototype.isoptionListArayString; /** @type {?} */ SingleselectDropdownComponent.prototype.eRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"singleselect-dropdown.component.js","sourceRoot":"ng://cubex-multiselect-dropdown/","sources":["lib/singleselect-dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, OnChanges, SimpleChanges, HostListener, ElementRef } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'cubex-singleselect-dropdown',\r\n  templateUrl: 'singleselect-dropdown.component.html',\r\n  styleUrls: ['singleselect-dropdown.component.css']\r\n})\r\nexport class SingleselectDropdownComponent implements OnInit,OnChanges {\r\n\r\n  filterText: any;\r\n  @Input('label') selectionLabel:string = 'Select';\r\n  @Input('data') optionList:Array<Object> = [];\r\n  @Input('isOpen') open:boolean = false;\r\n  @Input('checkedOption') selectedOptions:any;\r\n  @Input('displayKey') displayNameKey = '';\r\n  @Input('toggleKey') toggleSelectionKey = '';\r\n  @Input('placeholder') selectionPlaceholder: string;\r\n  @Input('selectionWidth') selectionTextWidth: number = 11;\r\n  @Input('width') componentWidth: number ;\r\n  @Input('height') componentHeight: number ;\r\n  @Output('onChange') selectionChange = new EventEmitter<any>();\r\n  @Output() onSearchChange = new EventEmitter<any>();\r\n  currentStyles: {};\r\n  noOption: {};\r\n  isoptionListArayString: boolean = false;\r\n  // @Input('placeholderFilter') placeholderFilterText: string = 'Filter options';\r\n\r\n  constructor(private eRef: ElementRef) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.currentStyles = {\r\n      \"width\": '100%',\r\n      // \"width\": this.componentWidth+'px',\r\n      // \"height\" : this.componentHeight+'px'\r\n      \"height\" : 'auto',\r\n      \"max-height\": this.componentHeight+'px'\r\n    };\r\n    this.noOption = {\r\n      \"padding-left\": (this.componentWidth/2)-75+'px',\r\n      \"color\" : \"gainsboro\"\r\n    };\r\n    this.isoptionListArayString = typeof this.optionList[0] === 'string';\r\n    console.log(this.isoptionListArayString,this.optionList)\r\n    if(!this.selectedOptions){\r\n      this.selectedOptions = this.isoptionListArayString ? \"\" : [];\r\n    }\r\n    if(this.isoptionListArayString){\r\n      this.filterText = this.selectedOptions;\r\n    }\r\n    \r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges){\r\n    for (let propName in changes) {\r\n      if(propName === 'selectedOptions'){\r\n        if(changes[propName].currentValue === undefined){\r\n          return;\r\n        }else if(Object.getOwnPropertyNames(this.selectedOptions).length === 0){\r\n          this.filterText = '';\r\n          continue;        \r\n        }\r\n        if(this.isoptionListArayString) {\r\n          if(typeof this.selectedOptions != 'undefined'){\r\n            this.filterText = (<any>this.selectedOptions).length<(this.selectionTextWidth+1)?(<any>this.selectedOptions):(<any>this.selectedOptions).substring(0,this.selectionTextWidth)+ '..';\r\n          } \r\n        } else {\r\n          if(typeof this.selectedOptions[this.displayNameKey] != 'undefined'){\r\n            this.filterText = (<any>this.selectedOptions)[this.displayNameKey].length<(this.selectionTextWidth+1)?(<any>this.selectedOptions)[this.displayNameKey]:(<any>this.selectedOptions)[this.displayNameKey].substring(0,this.selectionTextWidth)+ '..';\r\n          }\r\n        }\r\n      }\r\n      if(propName === 'optionList'){\r\n        //console.log(\"optionList-->\", changes[propName].currentValue);\r\n        this.optionList = changes[propName].currentValue;\r\n      }\r\n    }\r\n  }\r\n\r\n  selectOption(option){\r\n    if(this.isoptionListArayString) {\r\n      this.selectedOptions = option;\r\n      this.selectionChange.emit(this.selectedOptions);\r\n      this.closeDropdown();\r\n      this.filterText = (<any>this.selectedOptions).length<(this.selectionTextWidth+1)?(<any>this.selectedOptions):(<any>this.selectedOptions).substring(0,this.selectionTextWidth)+ '..';\r\n    } else {\r\n      this.selectedOptions = option;\r\n      this.selectionChange.emit(this.selectedOptions);\r\n      this.closeDropdown();\r\n      this.filterText = (<any>this.selectedOptions)[this.displayNameKey].length<(this.selectionTextWidth+1)?(<any>this.selectedOptions)[this.displayNameKey]:(<any>this.selectedOptions)[this.displayNameKey].substring(0,this.selectionTextWidth)+ '..';\r\n    }\r\n  }\r\n\r\n  closeDropdown(){\r\n    this.open = false;\r\n    if(this.isoptionListArayString) {\r\n      this.filterText = this.selectedOptions;\r\n    } else {\r\n      this.filterText = this.selectedOptions[this.displayNameKey];\r\n    }\r\n    \r\n  }\r\n\r\n  toggleDropdown() {\r\n    this.open = !this.open;\r\n    if(open){\r\n      this.filterText = '';      \r\n    }\r\n  }\r\n\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  clickout(event) {\r\n    if (!this.eRef.nativeElement.contains(event.target)) {\r\n      this.open = false;\r\n      if (this.isoptionListArayString) {\r\n        this.filterText = this.selectedOptions;\r\n      } else {\r\n        this.filterText = this.selectedOptions[this.displayNameKey];\r\n      }\r\n    }\r\n  }\r\n  \r\n}"]}