8 } from '@angular/core';
10 import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
11 import { TableColumnProp } from '@swimlane/ngx-datatable';
12 import _ from 'lodash';
14 import { InventoryDevice } from '~/app/ceph/cluster/inventory/inventory-devices/inventory-device.model';
15 import { InventoryDevicesComponent } from '~/app/ceph/cluster/inventory/inventory-devices/inventory-devices.component';
16 import { ActionLabelsI18n } from '~/app/shared/constants/app.constants';
17 import { Icons } from '~/app/shared/enum/icons.enum';
18 import { CdFormBuilder } from '~/app/shared/forms/cd-form-builder';
19 import { CdFormGroup } from '~/app/shared/forms/cd-form-group';
20 import { CdTableColumnFiltersChange } from '~/app/shared/models/cd-table-column-filters-change';
21 import { WizardStepsService } from '~/app/shared/services/wizard-steps.service';
24 selector: 'cd-osd-devices-selection-modal',
25 templateUrl: './osd-devices-selection-modal.component.html',
26 styleUrls: ['./osd-devices-selection-modal.component.scss']
28 export class OsdDevicesSelectionModalComponent implements AfterViewInit {
29 @ViewChild('inventoryDevices')
30 inventoryDevices: InventoryDevicesComponent;
33 submitAction = new EventEmitter<CdTableColumnFiltersChange>();
36 filterColumns: TableColumnProp[] = [];
41 formGroup: CdFormGroup;
44 devices: InventoryDevice[] = [];
45 filteredDevices: InventoryDevice[] = [];
47 event: CdTableColumnFiltersChange;
49 requiredFilters: string[] = [];
52 private formBuilder: CdFormBuilder,
53 private cdRef: ChangeDetectorRef,
54 public activeModal: NgbActiveModal,
55 public actionLabels: ActionLabelsI18n,
56 public wizardStepService: WizardStepsService
58 this.action = actionLabels.ADD;
63 // At least one filter other than hostname is required
64 // Extract the name from table columns for i18n strings
65 const cols = _.filter(this.inventoryDevices.columns, (col) => {
66 return this.filterColumns.includes(col.prop) && col.prop !== 'hostname';
68 // Fixes 'ExpressionChangedAfterItHasBeenCheckedError'
70 this.requiredFilters = _.map(cols, 'name');
75 this.formGroup = this.formBuilder.group({});
78 onFilterChange(event: CdTableColumnFiltersChange) {
80 this.canSubmit = false;
81 if (_.isEmpty(event.filters)) {
82 // filters are cleared
83 this.filteredDevices = [];
84 this.event = undefined;
86 // at least one filter is required (except hostname)
87 const filters = event.filters.filter((filter) => {
88 return filter.prop !== 'hostname';
90 this.canSubmit = !_.isEmpty(filters);
91 this.filteredDevices = event.data;
92 this.capacity = _.sumBy(this.filteredDevices, 'sys_api.size');
95 this.cdRef.detectChanges();
99 this.submitAction.emit(this.event);
100 this.activeModal.close();