UNPKG

angular-dropdown-select

Version:

<p>Multiple Dropdown Select - <b>You can use this angular-dropdown-select apart from data tables as well.</b></p> <br/>

85 lines 17.2 kB
import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "@angular/forms"; export class AngularDropdownSelectComponent { constructor() { this.onCheckBoxStatusChanged = new EventEmitter(); this.onUnselectAll = new EventEmitter(); this.dropdownOpen = false; this.selectedCount = 0; this.selectAll = false; this.uncheckAllStatus = false; this.dropdownButtonText = ''; } onDocumentClick(event) { const target = event.target; if (!target.nextElementSibling?.classList.contains('show')) { this.dropdownOpen = false; } } ngOnInit() { this.items = this.headings; this.extra = this.extras; this.uncheckAllStatus = this.extra.uncheckAllStatus; this.dropdownButtonText = this.extra.dropdownButtonText ? this.extra.dropdownButtonText : 'Table Columns'; this.countOfSelectedCheckboxes(); this.iterateForSelectAllChecked(); this.iterateForSelectAllUnChecked(); } iterateForSelectAllChecked() { this.selectAll = Object.values(this.items).every((item) => item.checked === true); } iterateForSelectAllUnChecked() { this.uncheckAllStatus = Object.values(this.headings).every((item) => item.checked === false); if (this.uncheckAllStatus === true) { this.onUnselectAll.emit(true); } else { this.onUnselectAll.emit(false); } } countOfSelectedCheckboxes() { this.selectedCount = 0; this.items.forEach((element) => { element.checked === true ? this.selectedCount++ : null; }); } toggleDropdown() { this.dropdownOpen = !this.dropdownOpen; } onSelectAll(event) { const checkbox = event.target; this.items.forEach((item) => { item.checked = checkbox.checked; this.onCheckBoxStatusChanged.emit(item); }); this.countOfSelectedCheckboxes(); this.iterateForSelectAllChecked(); this.iterateForSelectAllUnChecked(); } onItemSelected(item) { this.countOfSelectedCheckboxes(); this.onCheckBoxStatusChanged.emit(item); this.iterateForSelectAllChecked(); this.iterateForSelectAllUnChecked(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: AngularDropdownSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: AngularDropdownSelectComponent, selector: "lib-angular-dropdown-select", inputs: { headings: "headings", extras: "extras" }, outputs: { onCheckBoxStatusChanged: "onCheckBoxStatusChanged", onUnselectAll: "onUnselectAll" }, host: { listeners: { "document:click": "onDocumentClick($event)" } }, ngImport: i0, template: "<div class=\"dropdown\" (click)=\"toggleDropdown()\" tabindex=\"0\">\r\n <button class=\"dropdown-toggle\">\r\n {{ dropdownButtonText }} <span class=\"count-background-color\">{{ selectedCount }}</span>\r\n </button>\r\n <div class=\"dropdown-menu\" [class.show]=\"dropdownOpen\">\r\n <div class=\"dropdown-item\">\r\n <input type=\"checkbox\" class=\"checkbox-input\" (change)=\"onSelectAll($event)\" [(ngModel)]=\"selectAll\">\r\n <span class=\"checkbox-label\">Select All</span>\r\n </div>\r\n <div *ngFor=\"let item of items\" class=\"dropdown-item\">\r\n <input type=\"checkbox\" class=\"checkbox-input\" [(ngModel)]=\"item.checked\" (change)=\"onItemSelected(item)\">\r\n <span class=\"checkbox-label\">{{ item.name }}</span>\r\n </div>\r\n </div>\r\n</div>", styles: [".dropdown{position:relative;display:inline-block;font-family:Arial,sans-serif}.dropdown-toggle{color:#000;border:1px solid grey;background-color:#fff;padding:10px;border-radius:4px;cursor:pointer;outline:none;transition:background-color .3s}.dropdown-toggle:hover{background-color:#ecececa6}.dropdown-menu{position:absolute;background-color:#fff;box-shadow:0 4px 8px #0000001a;z-index:1;padding:10px;border-radius:4px;display:none;margin-top:5px;min-width:200px}.dropdown-menu.show{display:block}.dropdown-item{display:flex;align-items:center;padding:8px 10px;cursor:pointer;transition:background-color .3s}.dropdown-item:hover{background-color:#f8f9fa}.checkbox-label{margin-left:10px;font-size:14px;color:#333}.checkbox-input{margin-right:10px;width:18px;height:18px;border:1px solid #ced4da;border-radius:3px;cursor:pointer;transition:background-color .3s}.checkbox-input:checked{background-color:#007bff}.checkbox-input:checked:after{content:\"\\2713\";font-size:12px;color:#fff;position:absolute;top:1px;left:5px}.dropdown-toggle:focus,.dropdown-item:focus{outline:none;box-shadow:0 0 0 2px #007bff80}.count-background-color{background-color:#000;color:#fff;padding:4px;border-radius:20px;border:.25px solid grey}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: AngularDropdownSelectComponent, decorators: [{ type: Component, args: [{ selector: 'lib-angular-dropdown-select', template: "<div class=\"dropdown\" (click)=\"toggleDropdown()\" tabindex=\"0\">\r\n <button class=\"dropdown-toggle\">\r\n {{ dropdownButtonText }} <span class=\"count-background-color\">{{ selectedCount }}</span>\r\n </button>\r\n <div class=\"dropdown-menu\" [class.show]=\"dropdownOpen\">\r\n <div class=\"dropdown-item\">\r\n <input type=\"checkbox\" class=\"checkbox-input\" (change)=\"onSelectAll($event)\" [(ngModel)]=\"selectAll\">\r\n <span class=\"checkbox-label\">Select All</span>\r\n </div>\r\n <div *ngFor=\"let item of items\" class=\"dropdown-item\">\r\n <input type=\"checkbox\" class=\"checkbox-input\" [(ngModel)]=\"item.checked\" (change)=\"onItemSelected(item)\">\r\n <span class=\"checkbox-label\">{{ item.name }}</span>\r\n </div>\r\n </div>\r\n</div>", styles: [".dropdown{position:relative;display:inline-block;font-family:Arial,sans-serif}.dropdown-toggle{color:#000;border:1px solid grey;background-color:#fff;padding:10px;border-radius:4px;cursor:pointer;outline:none;transition:background-color .3s}.dropdown-toggle:hover{background-color:#ecececa6}.dropdown-menu{position:absolute;background-color:#fff;box-shadow:0 4px 8px #0000001a;z-index:1;padding:10px;border-radius:4px;display:none;margin-top:5px;min-width:200px}.dropdown-menu.show{display:block}.dropdown-item{display:flex;align-items:center;padding:8px 10px;cursor:pointer;transition:background-color .3s}.dropdown-item:hover{background-color:#f8f9fa}.checkbox-label{margin-left:10px;font-size:14px;color:#333}.checkbox-input{margin-right:10px;width:18px;height:18px;border:1px solid #ced4da;border-radius:3px;cursor:pointer;transition:background-color .3s}.checkbox-input:checked{background-color:#007bff}.checkbox-input:checked:after{content:\"\\2713\";font-size:12px;color:#fff;position:absolute;top:1px;left:5px}.dropdown-toggle:focus,.dropdown-item:focus{outline:none;box-shadow:0 0 0 2px #007bff80}.count-background-color{background-color:#000;color:#fff;padding:4px;border-radius:20px;border:.25px solid grey}\n"] }] }], ctorParameters: () => [], propDecorators: { headings: [{ type: Input }], extras: [{ type: Input }], onCheckBoxStatusChanged: [{ type: Output }], onUnselectAll: [{ type: Output }], onDocumentClick: [{ type: HostListener, args: ['document:click', ['$event']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-dropdown-select.component.js","sourceRoot":"","sources":["../../../../projects/angular-dropdown-select/src/lib/angular-dropdown-select.component.ts","../../../../projects/angular-dropdown-select/src/lib/angular-dropdown-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'lib-angular-dropdown-select',\r\n  templateUrl:'./angular-dropdown-select.component.html',\r\n  styleUrl: './angular-dropdown-select.component.css'\r\n})\r\nexport class AngularDropdownSelectComponent {\r\n\r\n  @Input() headings: any;\r\n  @Input() extras: any;\r\n  @Output() onCheckBoxStatusChanged = new EventEmitter<{ id: number, checked: boolean }>();\r\n  @Output() onUnselectAll = new EventEmitter<Boolean>();\r\n\r\n  dropdownOpen = false;\r\n  items: any;\r\n  selectedCount: number = 0;\r\n  selectAll: boolean = false;\r\n  extra: any;\r\n  uncheckAllStatus: boolean = false;\r\n  dropdownButtonText : string = '';\r\n\r\n  constructor(){}\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onDocumentClick(event: MouseEvent) {\r\n    const target = event.target as HTMLElement;    \r\n    if (!target.nextElementSibling?.classList.contains('show')) {\r\n      this.dropdownOpen = false;\r\n    }\r\n  }\r\n\r\n  ngOnInit(){\r\n   this.items = this.headings;\r\n   this.extra = this.extras;\r\n   this.uncheckAllStatus = this.extra.uncheckAllStatus;\r\n   this.dropdownButtonText = this.extra.dropdownButtonText ? this.extra.dropdownButtonText : 'Table Columns';\r\n   this.countOfSelectedCheckboxes();\r\n   this.iterateForSelectAllChecked();\r\n   this.iterateForSelectAllUnChecked();\r\n  }\r\n\r\n  iterateForSelectAllChecked(){\r\n    this.selectAll = Object.values(this.items).every((item:any) => item.checked === true)\r\n  }\r\n\r\n  iterateForSelectAllUnChecked(){\r\n    this.uncheckAllStatus = Object.values(this.headings).every((item:any) => item.checked === false)\r\n    if(this.uncheckAllStatus === true){\r\n      this.onUnselectAll.emit(true);\r\n    }else{\r\n      this.onUnselectAll.emit(false);\r\n    }\r\n  }\r\n\r\n  countOfSelectedCheckboxes(){\r\n    this.selectedCount = 0;\r\n    this.items.forEach((element: any) => {\r\n      element.checked === true ? this.selectedCount++ : null;\r\n    });\r\n  }\r\n\r\n  toggleDropdown(): void {\r\n    this.dropdownOpen = !this.dropdownOpen;\r\n  }\r\n\r\n  onSelectAll(event: Event): void {   \r\n    const checkbox = event.target as HTMLInputElement;\r\n    \r\n    this.items.forEach((item:any) => {\r\n      item.checked = checkbox.checked;\r\n      this.onCheckBoxStatusChanged.emit(item);\r\n    });\r\n\r\n    this.countOfSelectedCheckboxes();\r\n    this.iterateForSelectAllChecked();\r\n    this.iterateForSelectAllUnChecked();\r\n  }\r\n\r\n  onItemSelected(item: any): void {\r\n    this.countOfSelectedCheckboxes();\r\n    this.onCheckBoxStatusChanged.emit(item);\r\n    this.iterateForSelectAllChecked();\r\n    this.iterateForSelectAllUnChecked();\r\n  }\r\n}\r\n","<div class=\"dropdown\" (click)=\"toggleDropdown()\" tabindex=\"0\">\r\n    <button class=\"dropdown-toggle\">\r\n        {{ dropdownButtonText }} <span class=\"count-background-color\">{{ selectedCount }}</span>\r\n    </button>\r\n    <div class=\"dropdown-menu\" [class.show]=\"dropdownOpen\">\r\n        <div class=\"dropdown-item\">\r\n            <input type=\"checkbox\" class=\"checkbox-input\" (change)=\"onSelectAll($event)\" [(ngModel)]=\"selectAll\">\r\n            <span class=\"checkbox-label\">Select All</span>\r\n        </div>\r\n        <div *ngFor=\"let item of items\" class=\"dropdown-item\">\r\n            <input type=\"checkbox\" class=\"checkbox-input\" [(ngModel)]=\"item.checked\" (change)=\"onItemSelected(item)\">\r\n            <span class=\"checkbox-label\">{{ item.name }}</span>\r\n        </div>\r\n    </div>\r\n</div>"]}