@energycap/components 0.28.7 → 0.28.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/energycap-components.umd.js +213 -11
- package/bundles/energycap-components.umd.js.map +1 -1
- package/bundles/energycap-components.umd.min.js +1 -1
- package/bundles/energycap-components.umd.min.js.map +1 -1
- package/energycap-components.metadata.json +1 -1
- package/esm2015/lib/components.module.js +6 -3
- package/esm2015/lib/controls/item-picker/item-picker.component.js +189 -0
- package/esm2015/lib/display/table/searchable-table.component.js +7 -4
- package/esm2015/lib/display/table/table-selectable-row.component.js +6 -3
- package/esm2015/lib/display/table/table.component.js +2 -2
- package/esm2015/lib/shared/wizard/wizard-buttons/wizard-buttons.component.js +4 -2
- package/esm2015/lib/shared/wizard/wizard-progress/wizard-progress.component.js +3 -3
- package/esm2015/public-api.js +2 -1
- package/fesm2015/energycap-components.js +205 -12
- package/fesm2015/energycap-components.js.map +1 -1
- package/lib/controls/item-picker/item-picker.component.d.ts +108 -0
- package/lib/display/table/searchable-table.component.d.ts +2 -0
- package/lib/shared/wizard/wizard-buttons/wizard-buttons.component.d.ts +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/src/assets/locales/en_US.json +3 -1
|
@@ -65,6 +65,7 @@ import { MockDateDisplayPipe } from './shared/testing/public-mocks.spec';
|
|
|
65
65
|
import { WizardButtonsComponent } from './shared/wizard/wizard-buttons/wizard-buttons.component';
|
|
66
66
|
import { WizardProgressComponent } from './shared/wizard/wizard-progress/wizard-progress.component';
|
|
67
67
|
import { FormControlLabelComponent } from './controls/form-control-label/form-control-label.component';
|
|
68
|
+
import { ItemPickerComponent } from './controls/item-picker/item-picker.component';
|
|
68
69
|
export class ComponentsModule {
|
|
69
70
|
/**
|
|
70
71
|
* Providing services through the forRoot pattern here ensures that the components module and the importing
|
|
@@ -143,7 +144,8 @@ ComponentsModule.decorators = [
|
|
|
143
144
|
RelativeDatePipe,
|
|
144
145
|
ResizableComponent,
|
|
145
146
|
HighlightTextPipe,
|
|
146
|
-
FormControlLabelComponent
|
|
147
|
+
FormControlLabelComponent,
|
|
148
|
+
ItemPickerComponent
|
|
147
149
|
],
|
|
148
150
|
imports: [
|
|
149
151
|
CommonModule,
|
|
@@ -219,8 +221,9 @@ ComponentsModule.decorators = [
|
|
|
219
221
|
RelativeDatePipe,
|
|
220
222
|
ResizableComponent,
|
|
221
223
|
HighlightTextPipe,
|
|
222
|
-
FormControlLabelComponent
|
|
224
|
+
FormControlLabelComponent,
|
|
225
|
+
ItemPickerComponent
|
|
223
226
|
]
|
|
224
227
|
},] }
|
|
225
228
|
];
|
|
226
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../projects/components/src/lib/components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y';\r\nimport { OverlayModule } from '@angular/cdk/overlay';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ModuleWithProviders, NgModule, Provider } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { RouterModule } from '@angular/router';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { BannerComponent } from './controls/banner/banner.component';\r\nimport { ButtonComponent } from './controls/button/button.component';\r\nimport { CopyButtonDirective } from './controls/button/copy-button.directive';\r\nimport { CheckboxComponent } from './controls/checkbox/checkbox.component';\r\nimport { CollapsibleToggleComponent } from './controls/collapsible-toggle/collapsible-toggle.component';\r\nimport { ComboboxComponent } from './controls/combobox/combobox.component';\r\nimport { DropdownComponent } from './controls/dropdown/dropdown.component';\r\nimport { FileUploadComponent } from './controls/file-upload/file-upload.component';\r\nimport { FormControlComponent } from './controls/form-control/form-control.component';\r\nimport { FormGroupComponent } from './controls/form-group/form-group.component';\r\nimport { MenuComponent } from './controls/menu/menu.component';\r\nimport { NavItemActiveDirective } from './controls/navigation/nav-item-active.directive';\r\nimport { NumericboxComponent } from './controls/numericbox/numericbox.component';\r\nimport { PopoverComponent } from './controls/popover/popover.component';\r\nimport { RadioButtonComponent } from './controls/radio-button/radio-button.component';\r\nimport { SelectComponent } from './controls/select/select.component';\r\nimport { TabsComponent } from './controls/tabs/tabs.component';\r\nimport { TextboxComponent } from './controls/textbox/textbox.component';\r\nimport { AppBarComponent } from './display/app-bar/app-bar.component';\r\nimport { AvatarComponent } from './display/avatar/avatar.component';\r\nimport { ConfirmComponent } from './display/confirm/confirm.component';\r\nimport { DialogGroupComponent } from './display/dialog/dialog-group/dialog-group.component';\r\nimport { DialogComponent } from './display/dialog/dialog.component';\r\nimport { DialogService } from './display/dialog/dialog.service';\r\nimport { HierarchyTreeComponent } from './display/hierarchy/hierarchy-tree/hierarchy-tree.component';\r\nimport { ItemDisplayComponent } from './display/item-display/item-display.component';\r\nimport { JsonDisplayComponent } from './display/json-display/json-display.component';\r\nimport { ResizableComponent } from './display/resizable/resizable.component';\r\nimport { SpinnerComponent } from './display/spinner/spinner.component';\r\nimport { SplashComponent } from './display/splash/splash.component';\r\nimport { ResizableColumnComponent } from './display/table/resizable-column.component';\r\nimport { ResizableTableDirective } from './display/table/resizable-table.directive';\r\nimport { SearchableTableComponent } from './display/table/searchable-table.component';\r\nimport { TableDetailRowComponent } from './display/table/table-detail-row.component';\r\nimport { TableLockedColumnComponent } from './display/table/table-locked-column.component';\r\nimport { TableMasterHeaderRowComponent } from './display/table/table-master-header-row.component';\r\nimport { TableMasterRowComponent } from './display/table/table-master-row.component';\r\nimport { TablePaginationComponent } from './display/table/table-pagination.component';\r\nimport { TableSelectableRowComponent } from './display/table/table-selectable-row.component';\r\nimport { TableComponent } from './display/table/table.component';\r\nimport { TagsComponent } from './display/tags/tags.component';\r\nimport { ToastComponent } from './display/toast/toast/toast.component';\r\nimport { ToasterComponent } from './display/toast/toaster/toaster.component';\r\nimport { TreeComponent } from './display/tree/tree.component';\r\nimport { ViewOverlayComponent } from './display/view-overlay/view-overlay.component';\r\nimport { ClickAreaForDirective } from './shared/directives/click-area-for/click-area-for.directive';\r\nimport { IfViewportWidthDirective } from './shared/directives/if-viewport-width/if-viewport-width.directive';\r\nimport { PopupContainerDirective } from './shared/directives/popup/popup-container.directive';\r\nimport { DateDisplayPipe } from './shared/display/pipes/date-display.pipe';\r\nimport { HighlightTextPipe } from './shared/display/pipes/highlight-text.pipe';\r\nimport { RelativeDatePipe } from './shared/display/pipes/relative-date.pipe';\r\nimport { RowCountPipe } from './shared/display/pipes/row-count.pipe';\r\nimport { TimeDisplayPipe } from './shared/display/pipes/time-display.pipe';\r\nimport { FormGroupHelper } from './shared/form-group.helper';\r\nimport { PageTitleComponent } from './shared/page/page-title/page-title.component';\r\nimport { PageViewComponent } from './shared/page/page-view/page-view.component';\r\nimport { MockDateDisplayPipe } from './shared/testing/public-mocks.spec';\r\nimport { WizardButtonsComponent } from './shared/wizard/wizard-buttons/wizard-buttons.component';\r\nimport { WizardProgressComponent } from './shared/wizard/wizard-progress/wizard-progress.component';\r\nimport { FormControlLabelComponent } from './controls/form-control-label/form-control-label.component';\r\n\r\n\r\nexport type ComponentsModuleConfig = {\r\n  tracker: Provider\r\n};\r\n\r\n@NgModule({\r\n  declarations: [\r\n    ButtonComponent,\r\n    TabsComponent,\r\n    TextboxComponent,\r\n    NavItemActiveDirective,\r\n    SpinnerComponent,\r\n    ViewOverlayComponent,\r\n    BannerComponent,\r\n    ResizableTableDirective,\r\n    TabsComponent,\r\n    TableComponent,\r\n    SearchableTableComponent,\r\n    ComboboxComponent,\r\n    MenuComponent,\r\n    PopupContainerDirective,\r\n    DropdownComponent,\r\n    ConfirmComponent,\r\n    DialogComponent,\r\n    DateDisplayPipe,\r\n    TimeDisplayPipe,\r\n    MockDateDisplayPipe,\r\n    RadioButtonComponent,\r\n    CheckboxComponent,\r\n    NumericboxComponent,\r\n    AvatarComponent,\r\n    AppBarComponent,\r\n    SplashComponent,\r\n    IfViewportWidthDirective,\r\n    ClickAreaForDirective,\r\n    CollapsibleToggleComponent,\r\n    TableMasterRowComponent,\r\n    TableMasterHeaderRowComponent,\r\n    TableDetailRowComponent,\r\n    TableLockedColumnComponent,\r\n    TableSelectableRowComponent,\r\n    PopoverComponent,\r\n    TablePaginationComponent,\r\n    RowCountPipe,\r\n    CopyButtonDirective,\r\n    TablePaginationComponent,\r\n    TagsComponent,\r\n    FormControlComponent,\r\n    SelectComponent,\r\n    ItemDisplayComponent,\r\n    TableSelectableRowComponent,\r\n    ResizableColumnComponent,\r\n    DialogGroupComponent,\r\n    FileUploadComponent,\r\n    FormGroupComponent,\r\n    JsonDisplayComponent,\r\n    ToastComponent,\r\n    ToasterComponent,\r\n    PageViewComponent,\r\n    PageTitleComponent,\r\n    WizardProgressComponent,\r\n    WizardButtonsComponent,\r\n    HierarchyTreeComponent,\r\n    TreeComponent,\r\n    RelativeDatePipe,\r\n    ResizableComponent,\r\n    HighlightTextPipe,\r\n    FormControlLabelComponent\r\n  ],\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n\t\tReactiveFormsModule,\r\n    RouterModule,\r\n    TranslateModule,\r\n    A11yModule,\r\n    OverlayModule\r\n  ],\r\n  providers: [\r\n    FormGroupHelper,\r\n    DialogService,\r\n    DateDisplayPipe,\r\n    TimeDisplayPipe,\r\n    MockDateDisplayPipe,\r\n    RowCountPipe,\r\n    RelativeDatePipe,\r\n    HighlightTextPipe\r\n  ],\r\n  exports: [\r\n    ButtonComponent,\r\n    TabsComponent,\r\n    TextboxComponent,\r\n    NavItemActiveDirective,\r\n    SpinnerComponent,\r\n    ViewOverlayComponent,\r\n    BannerComponent,\r\n    TabsComponent,\r\n    TableComponent,\r\n    SearchableTableComponent,\r\n    ComboboxComponent,\r\n    MenuComponent,\r\n    PopupContainerDirective,\r\n    DropdownComponent,\r\n    ConfirmComponent,\r\n    DialogComponent,\r\n    DateDisplayPipe,\r\n    TimeDisplayPipe,\r\n    RadioButtonComponent,\r\n    CheckboxComponent,\r\n    NumericboxComponent,\r\n    AvatarComponent,\r\n    AppBarComponent,\r\n    SplashComponent,\r\n    IfViewportWidthDirective,\r\n    ClickAreaForDirective,\r\n    CollapsibleToggleComponent,\r\n    TableMasterRowComponent,\r\n    TableMasterHeaderRowComponent,\r\n    TableLockedColumnComponent,\r\n    TableSelectableRowComponent,\r\n    PopoverComponent,\r\n    CopyButtonDirective,\r\n    TablePaginationComponent,\r\n    TagsComponent,\r\n    FormControlComponent,\r\n    SelectComponent,\r\n    ItemDisplayComponent,\r\n    ResizableColumnComponent,\r\n    DialogGroupComponent,\r\n    FileUploadComponent,\r\n    FormGroupComponent,\r\n    JsonDisplayComponent,\r\n    ToastComponent,\r\n    ToasterComponent,\r\n    PageViewComponent,\r\n    PageTitleComponent,\r\n    WizardProgressComponent,\r\n    WizardButtonsComponent,\r\n    HierarchyTreeComponent,\r\n    TreeComponent,\r\n    RelativeDatePipe,\r\n    ResizableComponent,\r\n    HighlightTextPipe,\r\n    FormControlLabelComponent\r\n  ]\r\n})\r\nexport class ComponentsModule {\r\n  /**\r\n   * Providing services through the forRoot pattern here ensures that the components module and the importing\r\n   * module use the same singleton service instance.\r\n   * For more info: https://angular.io/guide/singleton-services#the-forroot-pattern\r\n   */\r\n  public static forRoot(config: ComponentsModuleConfig): ModuleWithProviders<ComponentsModule>{\r\n    return {\r\n      ngModule: ComponentsModule,\r\n      providers: [\r\n        config.tracker\r\n      ]\r\n    }\r\n  }\r\n}\r\n"]}
|
|
229
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../projects/components/src/lib/components.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAuB,QAAQ,EAAY,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAC;AAC9E,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,0BAA0B,EAAE,MAAM,4DAA4D,CAAC;AACxG,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AACnF,OAAO,EAAE,oBAAoB,EAAE,MAAM,gDAAgD,CAAC;AACtF,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAC;AAChF,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AACzF,OAAO,EAAE,mBAAmB,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,gDAAgD,CAAC;AACtF,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,oBAAoB,EAAE,MAAM,sDAAsD,CAAC;AAC5F,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,6DAA6D,CAAC;AACrG,OAAO,EAAE,oBAAoB,EAAE,MAAM,+CAA+C,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,+CAA+C,CAAC;AACrF,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4CAA4C,CAAC;AACtF,OAAO,EAAE,uBAAuB,EAAE,MAAM,2CAA2C,CAAC;AACpF,OAAO,EAAE,wBAAwB,EAAE,MAAM,4CAA4C,CAAC;AACtF,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AACrF,OAAO,EAAE,0BAA0B,EAAE,MAAM,+CAA+C,CAAC;AAC3F,OAAO,EAAE,6BAA6B,EAAE,MAAM,mDAAmD,CAAC;AAClG,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AACrF,OAAO,EAAE,wBAAwB,EAAE,MAAM,4CAA4C,CAAC;AACtF,OAAO,EAAE,2BAA2B,EAAE,MAAM,gDAAgD,CAAC;AAC7F,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,+CAA+C,CAAC;AACrF,OAAO,EAAE,qBAAqB,EAAE,MAAM,6DAA6D,CAAC;AACpG,OAAO,EAAE,wBAAwB,EAAE,MAAM,mEAAmE,CAAC;AAC7G,OAAO,EAAE,uBAAuB,EAAE,MAAM,qDAAqD,CAAC;AAC9F,OAAO,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;AAC3E,OAAO,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;AAC/E,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,+CAA+C,CAAC;AACnF,OAAO,EAAE,iBAAiB,EAAE,MAAM,6CAA6C,CAAC;AAChF,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,yDAAyD,CAAC;AACjG,OAAO,EAAE,uBAAuB,EAAE,MAAM,2DAA2D,CAAC;AACpG,OAAO,EAAE,yBAAyB,EAAE,MAAM,4DAA4D,CAAC;AACvG,OAAO,EAAE,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAsJnF,MAAM,OAAO,gBAAgB;IAC3B;;;;OAIG;IACI,MAAM,CAAC,OAAO,CAAC,MAA8B;QAClD,OAAO;YACL,QAAQ,EAAE,gBAAgB;YAC1B,SAAS,EAAE;gBACT,MAAM,CAAC,OAAO;aACf;SACF,CAAA;IACH,CAAC;;;YA5JF,QAAQ,SAAC;gBACR,YAAY,EAAE;oBACZ,eAAe;oBACf,aAAa;oBACb,gBAAgB;oBAChB,sBAAsB;oBACtB,gBAAgB;oBAChB,oBAAoB;oBACpB,eAAe;oBACf,uBAAuB;oBACvB,aAAa;oBACb,cAAc;oBACd,wBAAwB;oBACxB,iBAAiB;oBACjB,aAAa;oBACb,uBAAuB;oBACvB,iBAAiB;oBACjB,gBAAgB;oBAChB,eAAe;oBACf,eAAe;oBACf,eAAe;oBACf,mBAAmB;oBACnB,oBAAoB;oBACpB,iBAAiB;oBACjB,mBAAmB;oBACnB,eAAe;oBACf,eAAe;oBACf,eAAe;oBACf,wBAAwB;oBACxB,qBAAqB;oBACrB,0BAA0B;oBAC1B,uBAAuB;oBACvB,6BAA6B;oBAC7B,uBAAuB;oBACvB,0BAA0B;oBAC1B,2BAA2B;oBAC3B,gBAAgB;oBAChB,wBAAwB;oBACxB,YAAY;oBACZ,mBAAmB;oBACnB,wBAAwB;oBACxB,aAAa;oBACb,oBAAoB;oBACpB,eAAe;oBACf,oBAAoB;oBACpB,2BAA2B;oBAC3B,wBAAwB;oBACxB,oBAAoB;oBACpB,mBAAmB;oBACnB,kBAAkB;oBAClB,oBAAoB;oBACpB,cAAc;oBACd,gBAAgB;oBAChB,iBAAiB;oBACjB,kBAAkB;oBAClB,uBAAuB;oBACvB,sBAAsB;oBACtB,sBAAsB;oBACtB,aAAa;oBACb,gBAAgB;oBAChB,kBAAkB;oBAClB,iBAAiB;oBACjB,yBAAyB;oBACzB,mBAAmB;iBACpB;gBACD,OAAO,EAAE;oBACP,YAAY;oBACZ,WAAW;oBACb,mBAAmB;oBACjB,YAAY;oBACZ,eAAe;oBACf,UAAU;oBACV,aAAa;iBACd;gBACD,SAAS,EAAE;oBACT,eAAe;oBACf,aAAa;oBACb,eAAe;oBACf,eAAe;oBACf,mBAAmB;oBACnB,YAAY;oBACZ,gBAAgB;oBAChB,iBAAiB;iBAClB;gBACD,OAAO,EAAE;oBACP,eAAe;oBACf,aAAa;oBACb,gBAAgB;oBAChB,sBAAsB;oBACtB,gBAAgB;oBAChB,oBAAoB;oBACpB,eAAe;oBACf,aAAa;oBACb,cAAc;oBACd,wBAAwB;oBACxB,iBAAiB;oBACjB,aAAa;oBACb,uBAAuB;oBACvB,iBAAiB;oBACjB,gBAAgB;oBAChB,eAAe;oBACf,eAAe;oBACf,eAAe;oBACf,oBAAoB;oBACpB,iBAAiB;oBACjB,mBAAmB;oBACnB,eAAe;oBACf,eAAe;oBACf,eAAe;oBACf,wBAAwB;oBACxB,qBAAqB;oBACrB,0BAA0B;oBAC1B,uBAAuB;oBACvB,6BAA6B;oBAC7B,0BAA0B;oBAC1B,2BAA2B;oBAC3B,gBAAgB;oBAChB,mBAAmB;oBACnB,wBAAwB;oBACxB,aAAa;oBACb,oBAAoB;oBACpB,eAAe;oBACf,oBAAoB;oBACpB,wBAAwB;oBACxB,oBAAoB;oBACpB,mBAAmB;oBACnB,kBAAkB;oBAClB,oBAAoB;oBACpB,cAAc;oBACd,gBAAgB;oBAChB,iBAAiB;oBACjB,kBAAkB;oBAClB,uBAAuB;oBACvB,sBAAsB;oBACtB,sBAAsB;oBACtB,aAAa;oBACb,gBAAgB;oBAChB,kBAAkB;oBAClB,iBAAiB;oBACjB,yBAAyB;oBACzB,mBAAmB;iBACpB;aACF","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y';\r\nimport { OverlayModule } from '@angular/cdk/overlay';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ModuleWithProviders, NgModule, Provider } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { RouterModule } from '@angular/router';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { BannerComponent } from './controls/banner/banner.component';\r\nimport { ButtonComponent } from './controls/button/button.component';\r\nimport { CopyButtonDirective } from './controls/button/copy-button.directive';\r\nimport { CheckboxComponent } from './controls/checkbox/checkbox.component';\r\nimport { CollapsibleToggleComponent } from './controls/collapsible-toggle/collapsible-toggle.component';\r\nimport { ComboboxComponent } from './controls/combobox/combobox.component';\r\nimport { DropdownComponent } from './controls/dropdown/dropdown.component';\r\nimport { FileUploadComponent } from './controls/file-upload/file-upload.component';\r\nimport { FormControlComponent } from './controls/form-control/form-control.component';\r\nimport { FormGroupComponent } from './controls/form-group/form-group.component';\r\nimport { MenuComponent } from './controls/menu/menu.component';\r\nimport { NavItemActiveDirective } from './controls/navigation/nav-item-active.directive';\r\nimport { NumericboxComponent } from './controls/numericbox/numericbox.component';\r\nimport { PopoverComponent } from './controls/popover/popover.component';\r\nimport { RadioButtonComponent } from './controls/radio-button/radio-button.component';\r\nimport { SelectComponent } from './controls/select/select.component';\r\nimport { TabsComponent } from './controls/tabs/tabs.component';\r\nimport { TextboxComponent } from './controls/textbox/textbox.component';\r\nimport { AppBarComponent } from './display/app-bar/app-bar.component';\r\nimport { AvatarComponent } from './display/avatar/avatar.component';\r\nimport { ConfirmComponent } from './display/confirm/confirm.component';\r\nimport { DialogGroupComponent } from './display/dialog/dialog-group/dialog-group.component';\r\nimport { DialogComponent } from './display/dialog/dialog.component';\r\nimport { DialogService } from './display/dialog/dialog.service';\r\nimport { HierarchyTreeComponent } from './display/hierarchy/hierarchy-tree/hierarchy-tree.component';\r\nimport { ItemDisplayComponent } from './display/item-display/item-display.component';\r\nimport { JsonDisplayComponent } from './display/json-display/json-display.component';\r\nimport { ResizableComponent } from './display/resizable/resizable.component';\r\nimport { SpinnerComponent } from './display/spinner/spinner.component';\r\nimport { SplashComponent } from './display/splash/splash.component';\r\nimport { ResizableColumnComponent } from './display/table/resizable-column.component';\r\nimport { ResizableTableDirective } from './display/table/resizable-table.directive';\r\nimport { SearchableTableComponent } from './display/table/searchable-table.component';\r\nimport { TableDetailRowComponent } from './display/table/table-detail-row.component';\r\nimport { TableLockedColumnComponent } from './display/table/table-locked-column.component';\r\nimport { TableMasterHeaderRowComponent } from './display/table/table-master-header-row.component';\r\nimport { TableMasterRowComponent } from './display/table/table-master-row.component';\r\nimport { TablePaginationComponent } from './display/table/table-pagination.component';\r\nimport { TableSelectableRowComponent } from './display/table/table-selectable-row.component';\r\nimport { TableComponent } from './display/table/table.component';\r\nimport { TagsComponent } from './display/tags/tags.component';\r\nimport { ToastComponent } from './display/toast/toast/toast.component';\r\nimport { ToasterComponent } from './display/toast/toaster/toaster.component';\r\nimport { TreeComponent } from './display/tree/tree.component';\r\nimport { ViewOverlayComponent } from './display/view-overlay/view-overlay.component';\r\nimport { ClickAreaForDirective } from './shared/directives/click-area-for/click-area-for.directive';\r\nimport { IfViewportWidthDirective } from './shared/directives/if-viewport-width/if-viewport-width.directive';\r\nimport { PopupContainerDirective } from './shared/directives/popup/popup-container.directive';\r\nimport { DateDisplayPipe } from './shared/display/pipes/date-display.pipe';\r\nimport { HighlightTextPipe } from './shared/display/pipes/highlight-text.pipe';\r\nimport { RelativeDatePipe } from './shared/display/pipes/relative-date.pipe';\r\nimport { RowCountPipe } from './shared/display/pipes/row-count.pipe';\r\nimport { TimeDisplayPipe } from './shared/display/pipes/time-display.pipe';\r\nimport { FormGroupHelper } from './shared/form-group.helper';\r\nimport { PageTitleComponent } from './shared/page/page-title/page-title.component';\r\nimport { PageViewComponent } from './shared/page/page-view/page-view.component';\r\nimport { MockDateDisplayPipe } from './shared/testing/public-mocks.spec';\r\nimport { WizardButtonsComponent } from './shared/wizard/wizard-buttons/wizard-buttons.component';\r\nimport { WizardProgressComponent } from './shared/wizard/wizard-progress/wizard-progress.component';\r\nimport { FormControlLabelComponent } from './controls/form-control-label/form-control-label.component';\r\nimport { ItemPickerComponent } from './controls/item-picker/item-picker.component';\r\n\r\n\r\nexport type ComponentsModuleConfig = {\r\n  tracker: Provider\r\n};\r\n\r\n@NgModule({\r\n  declarations: [\r\n    ButtonComponent,\r\n    TabsComponent,\r\n    TextboxComponent,\r\n    NavItemActiveDirective,\r\n    SpinnerComponent,\r\n    ViewOverlayComponent,\r\n    BannerComponent,\r\n    ResizableTableDirective,\r\n    TabsComponent,\r\n    TableComponent,\r\n    SearchableTableComponent,\r\n    ComboboxComponent,\r\n    MenuComponent,\r\n    PopupContainerDirective,\r\n    DropdownComponent,\r\n    ConfirmComponent,\r\n    DialogComponent,\r\n    DateDisplayPipe,\r\n    TimeDisplayPipe,\r\n    MockDateDisplayPipe,\r\n    RadioButtonComponent,\r\n    CheckboxComponent,\r\n    NumericboxComponent,\r\n    AvatarComponent,\r\n    AppBarComponent,\r\n    SplashComponent,\r\n    IfViewportWidthDirective,\r\n    ClickAreaForDirective,\r\n    CollapsibleToggleComponent,\r\n    TableMasterRowComponent,\r\n    TableMasterHeaderRowComponent,\r\n    TableDetailRowComponent,\r\n    TableLockedColumnComponent,\r\n    TableSelectableRowComponent,\r\n    PopoverComponent,\r\n    TablePaginationComponent,\r\n    RowCountPipe,\r\n    CopyButtonDirective,\r\n    TablePaginationComponent,\r\n    TagsComponent,\r\n    FormControlComponent,\r\n    SelectComponent,\r\n    ItemDisplayComponent,\r\n    TableSelectableRowComponent,\r\n    ResizableColumnComponent,\r\n    DialogGroupComponent,\r\n    FileUploadComponent,\r\n    FormGroupComponent,\r\n    JsonDisplayComponent,\r\n    ToastComponent,\r\n    ToasterComponent,\r\n    PageViewComponent,\r\n    PageTitleComponent,\r\n    WizardProgressComponent,\r\n    WizardButtonsComponent,\r\n    HierarchyTreeComponent,\r\n    TreeComponent,\r\n    RelativeDatePipe,\r\n    ResizableComponent,\r\n    HighlightTextPipe,\r\n    FormControlLabelComponent,\r\n    ItemPickerComponent\r\n  ],\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n\t\tReactiveFormsModule,\r\n    RouterModule,\r\n    TranslateModule,\r\n    A11yModule,\r\n    OverlayModule\r\n  ],\r\n  providers: [\r\n    FormGroupHelper,\r\n    DialogService,\r\n    DateDisplayPipe,\r\n    TimeDisplayPipe,\r\n    MockDateDisplayPipe,\r\n    RowCountPipe,\r\n    RelativeDatePipe,\r\n    HighlightTextPipe\r\n  ],\r\n  exports: [\r\n    ButtonComponent,\r\n    TabsComponent,\r\n    TextboxComponent,\r\n    NavItemActiveDirective,\r\n    SpinnerComponent,\r\n    ViewOverlayComponent,\r\n    BannerComponent,\r\n    TabsComponent,\r\n    TableComponent,\r\n    SearchableTableComponent,\r\n    ComboboxComponent,\r\n    MenuComponent,\r\n    PopupContainerDirective,\r\n    DropdownComponent,\r\n    ConfirmComponent,\r\n    DialogComponent,\r\n    DateDisplayPipe,\r\n    TimeDisplayPipe,\r\n    RadioButtonComponent,\r\n    CheckboxComponent,\r\n    NumericboxComponent,\r\n    AvatarComponent,\r\n    AppBarComponent,\r\n    SplashComponent,\r\n    IfViewportWidthDirective,\r\n    ClickAreaForDirective,\r\n    CollapsibleToggleComponent,\r\n    TableMasterRowComponent,\r\n    TableMasterHeaderRowComponent,\r\n    TableLockedColumnComponent,\r\n    TableSelectableRowComponent,\r\n    PopoverComponent,\r\n    CopyButtonDirective,\r\n    TablePaginationComponent,\r\n    TagsComponent,\r\n    FormControlComponent,\r\n    SelectComponent,\r\n    ItemDisplayComponent,\r\n    ResizableColumnComponent,\r\n    DialogGroupComponent,\r\n    FileUploadComponent,\r\n    FormGroupComponent,\r\n    JsonDisplayComponent,\r\n    ToastComponent,\r\n    ToasterComponent,\r\n    PageViewComponent,\r\n    PageTitleComponent,\r\n    WizardProgressComponent,\r\n    WizardButtonsComponent,\r\n    HierarchyTreeComponent,\r\n    TreeComponent,\r\n    RelativeDatePipe,\r\n    ResizableComponent,\r\n    HighlightTextPipe,\r\n    FormControlLabelComponent,\r\n    ItemPickerComponent\r\n  ]\r\n})\r\nexport class ComponentsModule {\r\n  /**\r\n   * Providing services through the forRoot pattern here ensures that the components module and the importing\r\n   * module use the same singleton service instance.\r\n   * For more info: https://angular.io/guide/singleton-services#the-forroot-pattern\r\n   */\r\n  public static forRoot(config: ComponentsModuleConfig): ModuleWithProviders<ComponentsModule>{\r\n    return {\r\n      ngModule: ComponentsModule,\r\n      providers: [\r\n        config.tracker\r\n      ]\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
import { Component, Input, TemplateRef, ViewChild } from '@angular/core';
|
|
2
|
+
import { FormGroup } from '@angular/forms';
|
|
3
|
+
import { Observable, Subject } from 'rxjs';
|
|
4
|
+
import { debounceTime, takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { TableSelectableRowContext } from '../../display/table/table-selectable-row.component';
|
|
6
|
+
import { Overlay } from '../../display/view-overlay/view-overlay.component';
|
|
7
|
+
;
|
|
8
|
+
export class ItemPickerSelectableContext extends TableSelectableRowContext {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
/** id/value map of the selected items. Used for keeping track of what is selected */
|
|
12
|
+
this.selectedItemsMap = new Map();
|
|
13
|
+
/**
|
|
14
|
+
* Gives a way to tell the picker component that the map was modified externally and to update
|
|
15
|
+
* the available/selected lists
|
|
16
|
+
*/
|
|
17
|
+
this.selectedItemsMapChanged = new Subject();
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
export class ItemPickerComponent {
|
|
21
|
+
constructor() {
|
|
22
|
+
/** Identifier for the component. This will be added to the beginning of all internal action elements */
|
|
23
|
+
this.id = '';
|
|
24
|
+
/** Title displayed above the available items table */
|
|
25
|
+
this.availableTitle = '';
|
|
26
|
+
/** Title displayed above the selected items list */
|
|
27
|
+
this.selectedTitle = '';
|
|
28
|
+
/** The type of item being selected. Ex. Meters, Addresses */
|
|
29
|
+
this.itemName = '';
|
|
30
|
+
/** Used by the internal Searchable Table when there is no available items to choose from based on the getItems results. Do not supply
|
|
31
|
+
* to inherit the default message.
|
|
32
|
+
*/
|
|
33
|
+
this.noDataMessage = '';
|
|
34
|
+
/** List of available items to pick from */
|
|
35
|
+
this.availableItems = [];
|
|
36
|
+
/**
|
|
37
|
+
* Selected items array. Created from the selected items map. Binding to the
|
|
38
|
+
* map iterate values caused angular "expression changed" errors so after a map
|
|
39
|
+
* update this gets set to the values
|
|
40
|
+
*/
|
|
41
|
+
this.selectedItems = [];
|
|
42
|
+
/** Track by used for the searchable table rows */
|
|
43
|
+
this.trackByIndex = (index) => index;
|
|
44
|
+
this.tableStatus = new Overlay('hasData');
|
|
45
|
+
/** Used to shut down our subscriptions when the component is destroyed */
|
|
46
|
+
this.destroyed = new Subject();
|
|
47
|
+
}
|
|
48
|
+
ngOnInit() {
|
|
49
|
+
this.setupRowCheckboxesWatcher();
|
|
50
|
+
this.setupSelectedItemsChangedWatcher();
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Watch for changes and react if the custom item template value changes
|
|
54
|
+
*/
|
|
55
|
+
ngOnChanges() {
|
|
56
|
+
this.setInternalizedTemplates();
|
|
57
|
+
}
|
|
58
|
+
ngOnDestroy() {
|
|
59
|
+
this.destroyed.next();
|
|
60
|
+
this.destroyed.unsubscribe();
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Called by the searchable table when a new set of items are returned from the getItems call
|
|
64
|
+
* @param results
|
|
65
|
+
*/
|
|
66
|
+
onItemsChange(results) {
|
|
67
|
+
// Check to see if any of the items are marked to be selected by default and if so
|
|
68
|
+
// add them to the map.
|
|
69
|
+
results.items.forEach(item => {
|
|
70
|
+
var _a, _b;
|
|
71
|
+
if (item.defaultSelected && !((_a = this.selectionContext) === null || _a === void 0 ? void 0 : _a.selectedItemsMap.has(item.id))) {
|
|
72
|
+
(_b = this.selectionContext) === null || _b === void 0 ? void 0 : _b.selectedItemsMap.set(item.id, item);
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
this.availableItems = results.items;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Called when the clear selection link button is clicked
|
|
79
|
+
*/
|
|
80
|
+
onClearSelectionClick() {
|
|
81
|
+
this.selectionContext.selectedItemsMap = new Map();
|
|
82
|
+
this.selectionContext.rowCheckboxes.controls.forEach(control => control.setValue(false));
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Called when the remove item button is clicked for a selected item
|
|
86
|
+
* @param removeItem
|
|
87
|
+
*/
|
|
88
|
+
removeSelectedItem(removeItem) {
|
|
89
|
+
let foundIndex = this.availableItems.findIndex(item => item.id === removeItem.id);
|
|
90
|
+
if (foundIndex > -1) {
|
|
91
|
+
// Update the row checkbox since the item exists in the page being viewed
|
|
92
|
+
// The value change handler for row checkboxes will update the map/selected items
|
|
93
|
+
this.selectionContext.rowCheckboxes.at(foundIndex).setValue(false);
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
// The item being removed is not on the current page so just update the
|
|
97
|
+
// map/selected items
|
|
98
|
+
this.selectionContext.selectedItemsMap.delete(removeItem.id);
|
|
99
|
+
this.selectedItems = Array.from(this.selectionContext.selectedItemsMap.values());
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Watch for changes to the row checkboxes form array and update the selected items
|
|
104
|
+
* list
|
|
105
|
+
*/
|
|
106
|
+
setupRowCheckboxesWatcher() {
|
|
107
|
+
var _a;
|
|
108
|
+
(_a = this.selectionContext) === null || _a === void 0 ? void 0 : _a.rowCheckboxes.valueChanges.pipe(
|
|
109
|
+
// Debounce 10 is simply to not spam the change handler on load/page change
|
|
110
|
+
// Otherwise this will get called every time a new row is added to the table
|
|
111
|
+
debounceTime(10), takeUntil(this.destroyed)).subscribe((rowValues) => {
|
|
112
|
+
var _a;
|
|
113
|
+
rowValues.forEach((selected, index) => {
|
|
114
|
+
var _a, _b, _c, _d;
|
|
115
|
+
let availableItem = this.availableItems[index];
|
|
116
|
+
if (!selected && ((_a = this.selectionContext) === null || _a === void 0 ? void 0 : _a.selectedItemsMap.has(availableItem.id))) {
|
|
117
|
+
(_b = this.selectionContext) === null || _b === void 0 ? void 0 : _b.selectedItemsMap.delete(availableItem.id);
|
|
118
|
+
}
|
|
119
|
+
else if (selected && !((_c = this.selectionContext) === null || _c === void 0 ? void 0 : _c.selectedItemsMap.has(availableItem.id))) {
|
|
120
|
+
(_d = this.selectionContext) === null || _d === void 0 ? void 0 : _d.selectedItemsMap.set(availableItem.id, availableItem);
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
this.selectedItems = Array.from((_a = this.selectionContext) === null || _a === void 0 ? void 0 : _a.selectedItemsMap.values());
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Watch to be told if changes to the map were made outside of the component and if so update
|
|
128
|
+
* the array displayed in the selected list and select checkboxes for visible available items
|
|
129
|
+
*/
|
|
130
|
+
setupSelectedItemsChangedWatcher() {
|
|
131
|
+
this.selectionContext.selectedItemsMapChanged.pipe(takeUntil(this.destroyed)).subscribe(() => {
|
|
132
|
+
var _a;
|
|
133
|
+
if (this.selectionContext) {
|
|
134
|
+
this.selectedItems = Array.from((_a = this.selectionContext) === null || _a === void 0 ? void 0 : _a.selectedItemsMap.values());
|
|
135
|
+
this.availableItems.forEach((item, index) => {
|
|
136
|
+
if (this.selectionContext.selectedItemsMap.has(item.id)) {
|
|
137
|
+
this.selectionContext.rowCheckboxes.at(index).setValue(true);
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
setInternalizedTemplates() {
|
|
144
|
+
if (this.customAvailableHeaderTemplate) {
|
|
145
|
+
this.internalizedAvailableHeaderTemplate = this.customAvailableHeaderTemplate;
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
this.internalizedAvailableHeaderTemplate = this.defaultAvailableHeaderTemplate;
|
|
149
|
+
}
|
|
150
|
+
if (this.customAvailableItemTemplate) {
|
|
151
|
+
this.internalizedAvailableItemTemplate = this.customAvailableItemTemplate;
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
this.internalizedAvailableItemTemplate = this.defaultAvailableItemTemplate;
|
|
155
|
+
}
|
|
156
|
+
if (this.customSelectedItemTemplate) {
|
|
157
|
+
this.internalizedSelectedItemTemplate = this.customSelectedItemTemplate;
|
|
158
|
+
}
|
|
159
|
+
else {
|
|
160
|
+
this.internalizedSelectedItemTemplate = this.defaultSelectedItemTemplate;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
ItemPickerComponent.decorators = [
|
|
165
|
+
{ type: Component, args: [{
|
|
166
|
+
selector: 'ec-item-picker',
|
|
167
|
+
template: "<div class=\"d-flex flex-grow card\">\r\n <ec-searchable-table id=\"{{id}}_searchableTable\"\r\n class=\"flex-grow\"\r\n [fillParentHeight]=\"true\"\r\n [hideHeader]=\"true\"\r\n [hideSearchControl]=\"true\"\r\n [removeCard]=\"true\"\r\n [pageable]=\"true\"\r\n [pageSize]=\"50\"\r\n [objectType]=\"itemName\"\r\n [formModel]=\"formModel\"\r\n [ready]=\"ready\"\r\n [getItems]=\"getItems\"\r\n [selectable]=\"true\"\r\n [noDataMessage]=\"noDataMessage\"\r\n [selectionContext]=\"selectionContext\"\r\n [status]=\"tableStatus\"\r\n (itemsChange)=\"onItemsChange($event)\"\r\n [style.--ec-flex-properties]=\"(availableItems.length || tableStatus.status === 'pending' || tableStatus.status === 'error' ) ? '1 1 auto' : '0 1 auto'\">\r\n <thead>\r\n <tr ecTableSelectableRow\r\n [selectionContext]=\"selectionContext\">\r\n <ng-container *ngTemplateOutlet=\"internalizedAvailableHeaderTemplate;\">\r\n </ng-container>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <ng-container *ngFor=\"let item of availableItems; index as rowIndex; trackBy: trackByIndex\">\r\n <tr ecTableSelectableRow\r\n [selectionContext]=\"selectionContext\"\r\n [rowIndex]=\"rowIndex\"\r\n [isSelected]=\"selectionContext?.selectedItemsMap.has(item.id)\">\r\n <ng-container *ngTemplateOutlet=\"internalizedAvailableItemTemplate; context: {$implicit: item}\">\r\n </ng-container>\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n </ec-searchable-table>\r\n\r\n <div class=\"d-flex flex-column flex-grow\">\r\n <div class=\"d-flex flex-shrink align-items-center px-2\"\r\n [style.height.rem]=\"3\">\r\n <span class=\"text-heading-2\">{{selectedTitle | translate}}</span>\r\n <a *ngIf=\"selectedItems.length\"\r\n id=\"{{id}}_clearSelection\"\r\n class=\"ml-auto\"\r\n href=\"javascript:void(0)\"\r\n (click)=\"onClearSelectionClick()\"\r\n translate>\r\n ClearSelection_TC\r\n </a>\r\n </div>\r\n\r\n <div class=\"d-flex flex-column flex-grow scroll-y\">\r\n <ng-container *ngIf=\"selectedItems.length\">\r\n <div *ngFor=\"let item of selectedItems; last as isLast\"\r\n class=\"d-flex align-items-center pl-2\"\r\n [class.border-bottom]=\"!isLast\">\r\n <ng-container *ngTemplateOutlet=\"internalizedSelectedItemTemplate; context: {$implicit: item}\"></ng-container>\r\n\r\n <ec-button id=\"{{id}}_removeSelected_{{item.id}}\"\r\n class=\"ml-auto\"\r\n type=\"icon\"\r\n icon=\"ec-icon icon-cancel\"\r\n (clicked)=\"removeSelectedItem(item)\">\r\n </ec-button>\r\n </div>\r\n </ng-container>\r\n <span *ngIf=\"!selectedItems.length\"\r\n class=\"px-2 pt-2 font-size-small\"\r\n translate\r\n [translateParams]=\"{itemName: itemName | translate}\">\r\n ItemPickerNoItemsSelected_SC\r\n </span>\r\n </div>\r\n\r\n <div *ngIf=\"selectedItems.length\"\r\n class=\"d-flex flex-shrink px-2 border-top align-items-center\"\r\n [style.height.px]=\"40\">\r\n <span class=\"ml-auto text-caption-1 font-color-hint\">\r\n {{selectedItems.length}} {{itemName | translate}}\r\n </span>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #defaultAvailableHeaderTemplate>\r\n <th class=\"text-heading-2 font-color-primary\">{{availableTitle | translate}}</th>\r\n</ng-template>\r\n\r\n<ng-template #defaultAvailableItemTemplate let-item>\r\n <td>{{item.label}}</td>\r\n</ng-template>\r\n\r\n<ng-template #defaultSelectedItemTemplate let-item>\r\n {{item.label}}\r\n</ng-template>",
|
|
168
|
+
styles: ["@-webkit-keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}::ng-deep ec-table .main-table thead th{border-bottom:0}ec-searchable-table{border-right:2px solid #d2d7d9}.card{border:0}"]
|
|
169
|
+
},] }
|
|
170
|
+
];
|
|
171
|
+
ItemPickerComponent.ctorParameters = () => [];
|
|
172
|
+
ItemPickerComponent.propDecorators = {
|
|
173
|
+
id: [{ type: Input }],
|
|
174
|
+
availableTitle: [{ type: Input }],
|
|
175
|
+
selectedTitle: [{ type: Input }],
|
|
176
|
+
itemName: [{ type: Input }],
|
|
177
|
+
formModel: [{ type: Input }],
|
|
178
|
+
customAvailableHeaderTemplate: [{ type: Input }],
|
|
179
|
+
customAvailableItemTemplate: [{ type: Input }],
|
|
180
|
+
customSelectedItemTemplate: [{ type: Input }],
|
|
181
|
+
ready: [{ type: Input }],
|
|
182
|
+
getItems: [{ type: Input }],
|
|
183
|
+
selectionContext: [{ type: Input }],
|
|
184
|
+
noDataMessage: [{ type: Input }],
|
|
185
|
+
defaultAvailableHeaderTemplate: [{ type: ViewChild, args: ['defaultAvailableHeaderTemplate', { static: true },] }],
|
|
186
|
+
defaultAvailableItemTemplate: [{ type: ViewChild, args: ['defaultAvailableItemTemplate', { static: true },] }],
|
|
187
|
+
defaultSelectedItemTemplate: [{ type: ViewChild, args: ['defaultSelectedItemTemplate', { static: true },] }]
|
|
188
|
+
};
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/controls/item-picker/item-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, OnDestroy, OnInit, TemplateRef, ViewChild } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { Observable, of, Subject } from 'rxjs';\r\nimport { debounceTime, takeUntil } from 'rxjs/operators';\r\nimport { TableSearchResults } from '../../display/table/searchable-table.component';\r\nimport { PagingInfo } from '../../display/table/table-pagination.component';\r\nimport { TableSelectableRowContext } from '../../display/table/table-selectable-row.component';\r\nimport { Overlay } from '../../display/view-overlay/view-overlay.component';\r\nimport { MenuItem } from '../menu/menu.component';\r\n\r\nexport interface PickerItem<TValue = any, SItems = any> extends MenuItem {\r\n  id: string;\r\n  /** When set to true the available item will be automatically added to the selected list */\r\n  defaultSelected?: boolean;\r\n\r\n  /** Redefining to get the typing */\r\n  value: TValue;\r\n};\r\n\r\nexport class ItemPickerSelectableContext<T> extends TableSelectableRowContext {\r\n  /** id/value map of the selected items. Used for keeping track of what is selected */\r\n  public selectedItemsMap: Map<string, PickerItem<T>> = new Map();\r\n\r\n  /**\r\n   * Gives a way to tell the picker component that the map was modified externally and to update\r\n   * the available/selected lists\r\n   */\r\n  public selectedItemsMapChanged: Subject<void> = new Subject();\r\n}\r\n\r\n@Component({\r\n  selector: 'ec-item-picker',\r\n  templateUrl: './item-picker.component.html',\r\n  styleUrls: ['./item-picker.component.scss']\r\n})\r\nexport class ItemPickerComponent<T> implements OnInit, OnChanges, OnDestroy {\r\n\r\n  /** Identifier for the component. This will be added to the beginning of all internal action elements */\r\n  @Input() public id?: string = '';\r\n\r\n  /** Title displayed above the available items table */\r\n  @Input() public availableTitle: string = '';\r\n\r\n  /** Title displayed above the selected items list */\r\n  @Input() public selectedTitle: string = '';\r\n\r\n  /** The type of item being selected. Ex. Meters, Addresses */\r\n  @Input() public itemName: string = '';\r\n\r\n  /** Form group that is given to the internal Searchable Table */\r\n  @Input() public formModel?: FormGroup;\r\n\r\n  /** Template for when a custom header is needed for the available items table */\r\n  @Input() public customAvailableHeaderTemplate?: TemplateRef<any>;\r\n\r\n  /** Template for when a custom available item is needed. Default template is a label only */\r\n  @Input() public customAvailableItemTemplate?: TemplateRef<any>;\r\n\r\n  /** Template for when a custom selected item is needed. Default template is a label only */\r\n  @Input() public customSelectedItemTemplate?: TemplateRef<any>;\r\n\r\n  /** Used by the internal Searchable Table to know when the page is ready */\r\n  @Input() public ready?: Observable<void>;\r\n\r\n  /** Used by Searchable Table to retrieve the available items */\r\n  @Input() public getItems?: (search?: string, pageChangeInfo?: PagingInfo) => Observable<TableSearchResults>;\r\n\r\n  /** Used to maintain the available items checkbox selection as well as the selected items list */\r\n  @Input() public selectionContext!: ItemPickerSelectableContext<T>;\r\n\r\n  /** Used by the internal Searchable Table when there is no available items to choose from based on the getItems results. Do not supply\r\n   *  to inherit the default message.\r\n   */\r\n  @Input() public noDataMessage: string = '';\r\n\r\n  /** List of available items to pick from */\r\n  public availableItems: PickerItem[] = [];\r\n  /** \r\n   * Selected items array. Created from the selected items map. Binding to the \r\n   * map iterate values caused angular \"expression changed\" errors so after a map\r\n   * update this gets set to the values\r\n   */\r\n  public selectedItems: PickerItem[] = [];\r\n\r\n  /** Track by used for the searchable table rows */\r\n  public trackByIndex = (index: number) => index;\r\n\r\n  public tableStatus: Overlay = new Overlay('hasData');\r\n  /**\r\n   * Template used to display the available and selected items as well as the available item header. \r\n   * This will be set to the default template if a custom is not provided\r\n   */\r\n  public internalizedAvailableHeaderTemplate!: TemplateRef<any>;\r\n  public internalizedAvailableItemTemplate!: TemplateRef<any>;\r\n  public internalizedSelectedItemTemplate!: TemplateRef<any>;\r\n\r\n  /** Default templates used if a custom template is not provided */\r\n  @ViewChild('defaultAvailableHeaderTemplate', { static: true }) private defaultAvailableHeaderTemplate!: TemplateRef<any>;\r\n  @ViewChild('defaultAvailableItemTemplate', { static: true }) private defaultAvailableItemTemplate!: TemplateRef<any>;\r\n  @ViewChild('defaultSelectedItemTemplate', { static: true }) private defaultSelectedItemTemplate!: TemplateRef<any>;\r\n\r\n  /** Used to shut down our subscriptions when the component is destroyed */\r\n  private destroyed: Subject<void> = new Subject();\r\n\r\n  constructor() { }\r\n\r\n  public ngOnInit(): void {\r\n    this.setupRowCheckboxesWatcher();\r\n    this.setupSelectedItemsChangedWatcher();\r\n  }\r\n\r\n  /**\r\n   * Watch for changes and react if the custom item template value changes\r\n   */\r\n  public ngOnChanges(): void {\r\n    this.setInternalizedTemplates();\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.destroyed.next();\r\n    this.destroyed.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Called by the searchable table when a new set of items are returned from the getItems call\r\n   * @param results \r\n   */\r\n  public onItemsChange(results: TableSearchResults) {\r\n    // Check to see if any of the items are marked to be selected by default and if so\r\n    // add them to the map.\r\n    (<PickerItem[]>results.items).forEach(item => {\r\n      if (item.defaultSelected && !this.selectionContext?.selectedItemsMap.has(item.id)) {\r\n        this.selectionContext?.selectedItemsMap.set(item.id, item);\r\n      }\r\n    });\r\n    this.availableItems = (<PickerItem[]>results.items);\r\n  }\r\n\r\n  /**\r\n   * Called when the clear selection link button is clicked\r\n   */\r\n  public onClearSelectionClick() {\r\n    this.selectionContext.selectedItemsMap = new Map();\r\n    this.selectionContext.rowCheckboxes.controls.forEach(control => control.setValue(false));\r\n  }\r\n\r\n  /**\r\n   * Called when the remove item button is clicked for a selected item\r\n   * @param removeItem \r\n   */\r\n  public removeSelectedItem(removeItem: PickerItem): void {\r\n    let foundIndex = this.availableItems.findIndex(item => item.id === removeItem.id);\r\n    if (foundIndex > -1) {\r\n      // Update the row checkbox since the item exists in the page being viewed\r\n      // The value change handler for row checkboxes will update the map/selected items\r\n      this.selectionContext.rowCheckboxes.at(foundIndex).setValue(false);\r\n    } else {\r\n      // The item being removed is not on the current page so just update the\r\n      // map/selected items\r\n      this.selectionContext.selectedItemsMap.delete(removeItem.id);\r\n      this.selectedItems = Array.from(this.selectionContext.selectedItemsMap.values());\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Watch for changes to the row checkboxes form array and update the selected items\r\n   * list\r\n   */\r\n  private setupRowCheckboxesWatcher(): void {\r\n    this.selectionContext?.rowCheckboxes.valueChanges.pipe(\r\n      // Debounce 10 is simply to not spam the change handler on load/page change\r\n      // Otherwise this will get called every time a new row is added to the table\r\n      debounceTime(10),\r\n      takeUntil(this.destroyed)\r\n    ).subscribe((rowValues: boolean[]) => {\r\n      rowValues.forEach((selected, index) => {\r\n        let availableItem = this.availableItems[index];\r\n\r\n        if (!selected && this.selectionContext?.selectedItemsMap.has(availableItem.id)) {\r\n          this.selectionContext?.selectedItemsMap.delete(availableItem.id);\r\n        } else if (selected && !this.selectionContext?.selectedItemsMap.has(availableItem.id)) {\r\n          this.selectionContext?.selectedItemsMap.set(availableItem.id, availableItem);\r\n        }\r\n      });\r\n\r\n      this.selectedItems = Array.from(this.selectionContext?.selectedItemsMap.values());\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Watch to be told if changes to the map were made outside of the component and if so update\r\n   * the array displayed in the selected list and select checkboxes for visible available items\r\n   */\r\n  private setupSelectedItemsChangedWatcher(): void {\r\n    this.selectionContext.selectedItemsMapChanged.pipe(\r\n      takeUntil(this.destroyed)\r\n    ).subscribe(() => {\r\n      if (this.selectionContext) {\r\n        this.selectedItems = Array.from(this.selectionContext?.selectedItemsMap.values());\r\n\r\n        this.availableItems.forEach((item, index) => {\r\n          if (this.selectionContext.selectedItemsMap.has(item.id)) {\r\n            this.selectionContext.rowCheckboxes.at(index).setValue(true);\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  private setInternalizedTemplates(): void {\r\n    if (this.customAvailableHeaderTemplate) {\r\n      this.internalizedAvailableHeaderTemplate = this.customAvailableHeaderTemplate;\r\n    } else {\r\n      this.internalizedAvailableHeaderTemplate = this.defaultAvailableHeaderTemplate;\r\n    }\r\n\r\n    if (this.customAvailableItemTemplate) {\r\n      this.internalizedAvailableItemTemplate = this.customAvailableItemTemplate;\r\n    } else {\r\n      this.internalizedAvailableItemTemplate = this.defaultAvailableItemTemplate;\r\n    }\r\n\r\n    if (this.customSelectedItemTemplate) {\r\n      this.internalizedSelectedItemTemplate = this.customSelectedItemTemplate;\r\n    } else {\r\n      this.internalizedSelectedItemTemplate = this.defaultSelectedItemTemplate;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -100,6 +100,8 @@ export class SearchableTableComponent {
|
|
|
100
100
|
this.removeCard = false;
|
|
101
101
|
/** Classes to add to the overlay/card element */
|
|
102
102
|
this.overlayClasses = '';
|
|
103
|
+
/** When true the overlay and table will not have flex-shrink-max but instead flex-grow */
|
|
104
|
+
this.fillParentHeight = false;
|
|
103
105
|
/**
|
|
104
106
|
* Text displayed in the footer.
|
|
105
107
|
* Sometimes `noDataMessage`, sometimes `noSearchResultsMessage`
|
|
@@ -250,8 +252,8 @@ export class SearchableTableComponent {
|
|
|
250
252
|
SearchableTableComponent.decorators = [
|
|
251
253
|
{ type: Component, args: [{
|
|
252
254
|
selector: 'ec-searchable-table',
|
|
253
|
-
template: "<header *ngIf=\"!hideHeader\"\r\n class=\"d-flex flex-shrink align-items-center mb-3\">\r\n <ec-textbox id=\"{{id}}_searchbox\"\r\n *ngIf=\"!hideSearchControl\"\r\n class=\"mb-0 flex-grow mr-2\"\r\n [autofocus]=\"autofocus\"\r\n [formModel]=\"searchModel\"\r\n [tabindex]=\"searchboxTabIndex\"\r\n [placeholder]=\"searchboxPlaceholder\"\r\n [readonly]=\"searchboxReadonly\"></ec-textbox>\r\n <div class=\"flex-grow\">\r\n <ng-content select=\".searchable-table-controls\"></ng-content>\r\n </div>\r\n</header>\r\n<section id=\"{{id}}_card\"\r\n class=\"d-flex flex-column
|
|
254
|
-
styles: ["@-webkit-keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}:host{display:flex;flex:1 1;flex-direction:column;min-height:0}:host ::ng-deep .card-header+ec-table.is-selectable th{height:2.5rem;padding-bottom:.9375rem}:host ::ng-deep .card-header+ec-table.is-selectable th.is-resizable .handle{padding-top:.5rem}:host ::ng-deep .card-header+ec-table.is-selectable th.is-resizable .handle:before{top:.5rem}:host ::ng-deep .card-header+ec-table.is-selectable .selectable-table-toolbar{height:2.5rem;padding-bottom:.5rem}footer{font-size:.75rem;line-height:1rem}footer.has-results{color:rgba(26,26,35,.38);text-align:right}.card.has-mask{min-height:15rem}"]
|
|
255
|
+
template: "<header *ngIf=\"!hideHeader\"\r\n class=\"d-flex flex-shrink align-items-center mb-3\">\r\n <ec-textbox id=\"{{id}}_searchbox\"\r\n *ngIf=\"!hideSearchControl\"\r\n class=\"mb-0 flex-grow mr-2\"\r\n [autofocus]=\"autofocus\"\r\n [formModel]=\"searchModel\"\r\n [tabindex]=\"searchboxTabIndex\"\r\n [placeholder]=\"searchboxPlaceholder\"\r\n [readonly]=\"searchboxReadonly\"></ec-textbox>\r\n <div class=\"flex-grow\">\r\n <ng-content select=\".searchable-table-controls\"></ng-content>\r\n </div>\r\n</header>\r\n<section id=\"{{id}}_card\"\r\n class=\"d-flex flex-column {{overlayClasses}}\"\r\n [ngClass]=\"{'is-translucent': status.status !== 'error', 'has-mask': status.status !== 'hasData', 'card m-0 bg-content': !customContentTemplate && !removeCard}\"\r\n ecOverlay\r\n [status]=\"status.status\"\r\n [message]=\"status.message\"\r\n [displayAsMask]=\"true\">\r\n <ng-content select=\".card-header\"></ng-content>\r\n <ng-container *ngTemplateOutlet=\"customContentTemplate || defaultContentTemplate\">\r\n </ng-container>\r\n\r\n <!-- the default template is an ec-table with proxied-over searchable table inputs. \r\n If that doesn't work for you then you can specify a customContentTemplate to use instead\r\n and still retain all the event handling, header, footer pagination, etc support -->\r\n <ng-template #defaultContentTemplate>\r\n <ec-table id=\"{{id}}_table\"\r\n class=\"{{tableClasses}}\"\r\n [class.is-fixed]=\"tableLayoutFixed\"\r\n [sortable]=\"sortable\"\r\n [sort]=\"sort\"\r\n (sortChange)=\"onSortChange($event)\"\r\n [resizable]=\"resizable\"\r\n [scrollable]=\"true\"\r\n [selectable]=\"selectable\"\r\n [selectionContext]=\"selectionContext\"\r\n [selectionToolbarTemplate]=\"selectionToolbarTemplate\"\r\n [resizableColumns]=\"resizableColumns\">\r\n <ng-content></ng-content>\r\n </ec-table>\r\n </ng-template>\r\n\r\n <!-- pagination footer visible if table is page-able and there are more than one page of results -->\r\n <footer *ngIf=\"!hideFooter && pageable && searchResults.totalItemsBeforePaging! > pageSize!\"\r\n class=\"d-flex flex-shrink align-items-center\"\r\n [class.border-top]=\"!customContentTemplate\">\r\n <ec-table-pagination id=\"{{id}}_pager\"\r\n class=\"font-color-primary\"\r\n [totalItems]=\"searchResults.totalItemsBeforePaging\"\r\n [pageSize]=\"pageSize\"\r\n [maxTabs]=\"maxTabs\"\r\n [pageNumber]=\"pageInfo?.pageNumber\"\r\n (pageChanged)=\"onPageChange($event)\">\r\n </ec-table-pagination>\r\n <div id=\"resultsCount\"\r\n *ngIf=\"searchResults?.items?.length\"\r\n class=\"ml-auto mr-2 font-color-hint text-truncate\" \r\n title=\"{{resultsCount}} {{additionalCountText}}\">{{resultsCount}} {{additionalCountText}}</div>\r\n </footer>\r\n\r\n <!-- default footer: visible if hideFooter is false and table is not page-able or there are only one page of results (always shows if there is a caption to indicate no results) -->\r\n <footer *ngIf=\"(!hideFooter && (!pageable || searchResults.totalItemsBeforePaging! <= pageSize!)) || tableCaption\"\r\n class=\"p-2 d-flex\"\r\n [ngClass]=\"{'has-results': searchResults?.items?.length, 'border-top': searchResults?.items?.length && !customContentTemplate}\">\r\n <ng-content *ngIf=\"!tableCaption\"\r\n select=\".searchable-table-footer\"></ng-content>\r\n <div id=\"tableCaption\"\r\n *ngIf=\"tableCaption\"\r\n [innerHTML]=\"tableCaption\"></div>\r\n <div id=\"resultsCount\"\r\n *ngIf=\"searchResults?.items?.length\"\r\n class=\"ml-auto text-truncate\"\r\n title=\"{{resultsCount}} {{additionalCountText}}\">{{resultsCount}} {{additionalCountText}}</div>\r\n </footer>\r\n</section>",
|
|
256
|
+
styles: ["@-webkit-keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}:host{--ec-flex-ec-table:var(--ec-flex-properties,0 1 auto);--ec-flex-overlay-section:var(--ec-flex-properties,0 1 auto);--ec-flex-properties:0 1 auto;display:flex;flex:1 1;flex-direction:column;min-height:0}:host ::ng-deep .card-header+ec-table.is-selectable th{height:2.5rem;padding-bottom:.9375rem}:host ::ng-deep .card-header+ec-table.is-selectable th.is-resizable .handle{padding-top:.5rem}:host ::ng-deep .card-header+ec-table.is-selectable th.is-resizable .handle:before{top:.5rem}:host ::ng-deep .card-header+ec-table.is-selectable .selectable-table-toolbar{height:2.5rem;padding-bottom:.5rem}section{flex:var(--ec-flex-overlay-section);min-height:0}ec-table{flex:var(--ec-flex-ec-table);min-height:0}footer{font-size:.75rem;line-height:1rem}footer.has-results{color:rgba(26,26,35,.38);text-align:right}.card.has-mask{min-height:15rem}"]
|
|
255
257
|
},] }
|
|
256
258
|
];
|
|
257
259
|
SearchableTableComponent.ctorParameters = () => [
|
|
@@ -295,6 +297,7 @@ SearchableTableComponent.propDecorators = {
|
|
|
295
297
|
selectable: [{ type: Input }],
|
|
296
298
|
customContentTemplate: [{ type: Input }],
|
|
297
299
|
removeCard: [{ type: Input }],
|
|
298
|
-
overlayClasses: [{ type: Input }]
|
|
300
|
+
overlayClasses: [{ type: Input }],
|
|
301
|
+
fillParentHeight: [{ type: Input }]
|
|
299
302
|
};
|
|
300
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchable-table.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/display/table/searchable-table.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,YAAY,EAAE,KAAK,EAAgC,MAAM,EAAE,SAAS,EAAiB,WAAW,EAAE,MAAM,eAAe,CAAC;AAC7J,OAAO,EAAe,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAC5G,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,2CAA2C,CAAC;AACzE,OAAO,EAAE,OAAO,EAAE,MAAM,wCAAwC,CAAC;AACjE,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AACxE,OAAO,EAAc,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AACpF,OAAO,EAAE,yBAAyB,EAAE,MAAM,kCAAkC,CAAC;AAa7E,MAAM,OAAO,wBAAwB;IAoMnC,YACU,YAA0B,EAC1B,gBAAkC,EAClC,YAA0B;QAF1B,iBAAY,GAAZ,YAAY,CAAc;QAC1B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,iBAAY,GAAZ,YAAY,CAAc;QArM3B,OAAE,GAAG,EAAE,CAAC;QACR,cAAS,GAAG,KAAK,CAAC;QAClB,aAAQ,GAAG,KAAK,CAAC;QAEjB,cAAS,GAAY,KAAK,CAAC;QAEpC;;WAEG;QACM,iBAAY,GAAW,EAAE,CAAC;QAEnC,wCAAwC;QAC9B,eAAU,GAA4B,IAAI,YAAY,EAAa,CAAC;QAE9E,4CAA4C;QACtB,sBAAiB,GAA6B,IAAI,YAAY,EAAc,CAAC;QAEnG,yCAAyC;QAChC,yBAAoB,GAAG,EAAE,CAAC;QASnC;;;;WAIG;QACM,kBAAa,GAAW,mCAAmC,CAAC;QAErE;;;;;;;;;WASG;QACM,2BAAsB,GAAW,sCAAsC,CAAC;QA0BjF,8FAA8F;QACrF,WAAM,GAAY,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC;QAElD;;WAEG;QACM,qBAAgB,GAAY,KAAK,CAAC;QAE3C,4EAA4E;QAClE,gBAAW,GAAqC,IAAI,YAAY,EAAsB,CAAC;QAKjG,kEAAkE;QACzD,iBAAY,GAAW,GAAG,CAAC;QAEpC,wFAAwF;QAC/E,sBAAiB,GAAY,KAAK,CAAC;QAE5C,4CAA4C;QACnC,eAAU,GAAY,KAAK,CAAC;QAErC,2EAA2E;QAClE,eAAU,GAAW,SAAS,CAAC;QAExC,2CAA2C;QAClC,eAAU,GAAY,KAAK,CAAC;QAErC;;;;;;;;;;;;;;;;;;;UAmBE;QACO,aAAQ,GAAY,KAAK,CAAC;QAOnC;;SAEC;QACQ,YAAO,GAAY,EAAE,CAAC;QAE/B;;WAEG;QACM,sBAAiB,GAAY,KAAK,CAAC;QAU5C,6HAA6H;QACpH,wBAAmB,GAAW,EAAE,CAAC;QAE1C,wEAAwE;QAC/D,eAAU,GAAY,KAAK,CAAC;QAMrC,gEAAgE;QACvD,eAAU,GAAY,KAAK,CAAC;QAErC,iDAAiD;QACxC,mBAAc,GAAW,EAAE,CAAC;QAYrC;;;WAGG;QACI,iBAAY,GAAW,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,IAAI,mCAAmC,CAAC,CAAC;QAEvH,8CAA8C;QACvC,iBAAY,GAAW,EAAE,CAAC;QAEjC,sEAAsE;QAC/D,kBAAa,GAAuB,EAAE,KAAK,EAAE,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC;QAExE;;;WAGG;QACK,mBAAc,GAAqD,KAAK,CAAC;QACzE,cAAS,GAAkB,IAAI,OAAO,EAAE,CAAC;QAEzC,gBAAW,GAAsC,IAAI,OAAO,EAAE,CAAC;QAEvE,6CAA6C;QACrC,cAAS,GAAG,IAAI,OAAO,EAAO,CAAC;IAMnC,CAAC;IAjCL,mCAAmC;IACnC,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,WAA0B,CAAC;IAC5D,CAAC;IAgCD,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,QAAQ,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,IAAI,IAAI,CAAC,QAAQ,EAAE;YACtE,gEAAgE;YAChE,IAAI,CAAC,QAAQ,GAAG,wBAAwB,CAAC,aAAa,CAAC,CAAC,EAAE,IAAI,CAAC,QAAS,CAAC,CAAC;YAC1E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAClC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QAC5C,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,gEAAgE;QAChE,MAAM,eAAe,GAAG,KAAK,CAC3B,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAC9B,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,EACrB,YAAY,CAAC,GAAG,CAAC,CAClB,EACD,IAAI,CAAC,cAAc,EACnB,IAAI,CAAC,SAAS,CACf,CAAC,IAAI,CAAC,GAAG,CAAC,GAAE,EAAE;YACb,iHAAiH;YACjH,qIAAqI;YACrI,IAAG,IAAI,CAAC,QAAQ,EAAE;gBAChB,IAAI,CAAC,QAAQ,GAAG,wBAAwB,CAAC,aAAa,CAAC,CAAC,EAAE,IAAI,CAAC,QAAS,CAAC,CAAC;aAC3E;QACH,CAAC,CAAC,CAAC,CAAC;QAEJ,MAAM,aAAa,GAAG,KAAK,CACzB,eAAe,EACf,IAAI,CAAC,WAAW,CAAC,IAAI;QACnB,qGAAqG;QACrG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CACtB,CACF,CAAA;QAED,qCAAqC;QACrC,MAAM,OAAO,GAAG,aAAa,CAAC,IAAI;QAChC,mDAAmD;QACnD,KAAK,CAAC,aAAa,CAAC;QAEpB,kCAAkC;QAClC,0DAA0D;QAC1D,GAAG,CAAC,CAAC,YAAqB,EAAE,EAAE;YAC5B,IAAI,MAAM,GAAG,YAAY,IAAI,EAAE,CAAC;YAChC,OAAO,MAAM,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QACrC,CAAC,CAAC;QAEF,sBAAsB;QACtB,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QAEtD,uBAAuB;QACvB,SAAS,CAAC,CAAC,YAAoB,EAAE,EAAE;QACjC,qDAAqD;QACrD,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,CAC3C;QAED,8CAA8C;QAC9C,UAAU,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE;YACzB,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;YACrE,oEAAoE;YACpE,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,EAEF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B,CAAC;QAEF,yCAAyC;QACzC,OAAO,CAAC,SAAS,CAAC,CAAC,OAA2B,EAAE,EAAE;YAChD,uGAAuG;YACvG,0DAA0D;YAC1D,IAAG,CAAC,IAAI,CAAC,QAAQ,EAAE;gBACjB,OAAO,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;aAC3D;YAED,6GAA6G;YAC7G,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;YAE7B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YAC7C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA,CAAC;gBAChF,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;YAE7G,0CAA0C;YAC1C,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;gBACpD,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;aAChD;iBAAM,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE;gBACpC,kDAAkD;gBAClD,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;aAC/C;YAED,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YACjC,2CAA2C;YAC3C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QAEH,iGAAiG;QACjG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;YACnB,QAAQ,EAAE,GAAG,EAAE;gBACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;gBAC1C,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;YAC5B,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;IAC/B,CAAC;IAED,0CAA0C;IAC1C,YAAY,CAAC,IAAe;QAC1B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,UAAsB;QACjC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QAC5C,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACxC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAGD;;;;;;;;;OASG;IACK,mBAAmB;QACzB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CACrC,GAAG,CAAC,IAAI,CAAC,EAAE;gBACT,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,EAAE;oBAC5B,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;oBACjD,uCAAY,IAAI,CAAC,SAAS,KAAE,WAAW,EAAE,EAAE,IAAG;iBAC/C;gBACD,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;YAC9B,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B,CAAC;SACH;IACH,CAAC;IAED,yCAAyC;IACjC,UAAU,CAAC,OAA2B;QAC5C,IAAI,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE;YACxB,OAAO,EAAE,CAAC;SACX;QAED,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;YAC1B,OAAO,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,sBAAsB,IAAI,sCAAsC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC;SACrJ;QAED,OAAO,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,IAAI,mCAAmC,CAAC,CAAC;IAClG,CAAC;;;YAhXF,SAAS,SAAC;gBACT,QAAQ,EAAE,qBAAqB;gBAC/B,wpIAAgD;;aAEjD;;;YAjBQ,YAAY;YAHZ,gBAAgB;YAIhB,YAAY;;;iBAmBlB,KAAK;wBACL,KAAK;uBACL,KAAK;mBACL,KAAK;wBACL,KAAK;2BAKL,KAAK;yBAGL,MAAM;gCAGN,MAAM,SAAC,YAAY;mCAGnB,KAAK;wBAOL,KAAK;4BAOL,KAAK;qCAYL,KAAK;oBAUL,KAAK;uBAWL,KAAK;sBAGL,KAAK;qBAGL,KAAK;+BAKL,KAAK;0BAGL,MAAM;gCAGN,KAAK;2BAGL,KAAK;gCAGL,KAAK;yBAGL,KAAK;yBAGL,KAAK;yBAGL,KAAK;uBAsBL,KAAK;uBAKL,KAAK;sBAKL,KAAK;gCAKL,KAAK;+BAGL,KAAK;uCAGL,KAAK;+BAEL,eAAe,SAAC,wBAAwB,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC;kCAG7D,KAAK;yBAGL,KAAK;oCAIL,KAAK;yBAGL,KAAK;6BAGL,KAAK","sourcesContent":["import { Component, ContentChildren, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, QueryList, SimpleChanges, TemplateRef } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { EMPTY, merge, Observable, Subject } from 'rxjs';\r\nimport { catchError, debounceTime, map, pluck, skipUntil, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { ErrorService } from '../../core/error.service';\r\nimport { RowCountPipe } from '../../shared/display/pipes/row-count.pipe';\r\nimport { Overlay } from '../view-overlay/view-overlay.component';\r\nimport { ResizableColumnComponent } from './resizable-column.component';\r\nimport { PagingInfo, TablePaginationComponent } from './table-pagination.component';\r\nimport { TableSelectableRowContext } from './table-selectable-row.component';\r\nimport { TableSort } from './table.component';\r\n\r\nexport type TableSearchResults = { items: unknown[], totalItems: number, totalItemsBeforePaging?: number };\r\nexport type SearchableTableRefreshOptions = { clearSearch?: boolean };\r\n\r\ntype SearchableTableFormModel = { searchModel?: string };\r\n\r\n@Component({\r\n  selector: 'ec-searchable-table',\r\n  templateUrl: './searchable-table.component.html',\r\n  styleUrls: ['./searchable-table.component.scss']\r\n})\r\nexport class SearchableTableComponent implements OnInit, OnDestroy, OnChanges {\r\n\r\n  @Input() id = '';\r\n  @Input() resizable = false;\r\n  @Input() sortable = false;\r\n  @Input() sort?: TableSort;\r\n  @Input() autofocus: boolean = false;\r\n\r\n  /**Set to a space-separated set of strings that should be added to the ec-table class attribute\r\n   * this allows finer control over styling.\r\n   */\r\n  @Input() tableClasses: string = '';\r\n\r\n  /** Emits when table sort has changed */\r\n  @Output() sortChange: EventEmitter<TableSort> = new EventEmitter<TableSort>();\r\n\r\n  /** Emits when the table page has changed */\r\n  @Output('pageChange') pageChangeEmitter: EventEmitter<PagingInfo> = new EventEmitter<PagingInfo>();\r\n\r\n  /** Placeholder text for the searchbox */\r\n  @Input() searchboxPlaceholder = '';\r\n\r\n  /**\r\n   * FormGroup for the searchbox\r\n   *\r\n   * The referenced FormGroup **must** contain a FormControl called 'searchModel'.\r\n   */\r\n  @Input() public formModel!: FormGroup;\r\n\r\n  /**\r\n   * Displayed in overlay when no data is returned (without searching).\r\n   *\r\n   * Defaults to \"SearchableTable_Default_NoData_SC\"\r\n   */\r\n  @Input() noDataMessage: string = 'SearchableTable_Default_NoData_SC';\r\n\r\n  /**\r\n   * Displayed in overlay when no data is returned (after searching).\r\n   * Ensure translation has an interpolation placeholder for \"searchText\".\r\n   *\r\n   * Defaults to \"SearchableTable_Default_NoMatches_SC\"\r\n   *\r\n   * @example\r\n   * // 7 requires single curly braces\r\n   * No items found matching <strong>{{searchText}}</strong>\r\n   */\r\n  @Input() noSearchResultsMessage: string = 'SearchableTable_Default_NoMatches_SC';\r\n\r\n  /**\r\n   * Indicates hosting page is ready for the table to load data.\r\n   *\r\n   * Next and Complete this observable after hosting page has made any preliminary\r\n   * API (or other asynchronous) calls to load prerequisite data upon which the code\r\n   * in the `getItems` function depends.  Use a `ReplaySubject` to ensure every component\r\n   * that uses this observable gets the Next and Complete notifications.\r\n   */\r\n  @Input() ready!: Observable<void>;\r\n\r\n  /**\r\n   * Function called to get items to display in the table.\r\n   * If pageable is true, the TableSearchResults need to include totalItemsBeforePaging, which is the\r\n   * count of items before you've applied any pagination (i.e. the total number of items that came back from the search).\r\n   *\r\n   * Make sure to bind the scope in the template\r\n   * @example\r\n   * [getItems]=\"yourFunction.bind(this)\"\r\n   */\r\n  @Input() getItems!: (search?: string, pageChangeInfo?: PagingInfo) => Observable<TableSearchResults>;\r\n\r\n  /** Observable that will force the getItems function to get called again */\r\n  @Input() refresh?: Observable<SearchableTableRefreshOptions | undefined>;\r\n\r\n  /** Allow the host component to supply an overlay to control the pending state of the table */\r\n  @Input() status: Overlay = new Overlay('hasData');\r\n\r\n  /**\r\n   * Sets the underlying table's layout to fixed.\r\n   */\r\n  @Input() tableLayoutFixed: boolean = false;\r\n\r\n  /** Emits items returned by the getItems function, along with total count */\r\n  @Output() itemsChange: EventEmitter<TableSearchResults> = new EventEmitter<TableSearchResults>();\r\n\r\n  /** Optional tab index for the searchbox */\r\n  @Input() searchboxTabIndex?: number;\r\n\r\n  /** Maximum number of items to show in the table (default: 100) */\r\n  @Input() maxItemCount: number = 100;\r\n\r\n  /** Set to true to hide search box (does not hide the other searchable table controls */\r\n  @Input() hideSearchControl: boolean = false;\r\n\r\n  /** Set to true to hide the entire header */\r\n  @Input() hideHeader: boolean = false;\r\n\r\n  /** Type of object in the table. Displayed in footer (default: 'results')*/\r\n  @Input() objectType: string = 'results';\r\n\r\n  /** Set to true to hide the table footer */\r\n  @Input() hideFooter: boolean = false;\r\n\r\n  /**\r\n   * Set to true to enable paging. If paging is enabled, pageSize must be provided.\r\n   * getItems will be passed both a search and a PagingInfo object when called. It must include totalItemsBeforePaging in the TableSearchResults output.\r\n   * Here is a simple implementation: \r\n   * @example\r\n   * getItems(search?: string, pageChangeInfo?: PagingInfo): Observable<TableSearchResults> {\r\n      let results: SimpleItem[] = [...this.paginatedTableItems];\r\n      //apply search\r\n      if(search) {\r\n        results = this.paginatedTableItems.filter(i => i.a.toLowerCase().includes(search.toLowerCase()));\r\n      }\r\n      //get count before applying paging\r\n      let countBeforePaging = results.length;\r\n      //apply paging\r\n      if(pageChangeInfo) {\r\n        results = results.slice(pageChangeInfo!.skip, pageChangeInfo!.skip + pageChangeInfo!.pageSize);\r\n      }\r\n      return of({ items: results, totalItems: results.length, totalItemsBeforePaging: countBeforePaging });\r\n    }\r\n  */\r\n  @Input() pageable: boolean = false;\r\n\r\n  /**\r\n   * Max size of a page.\r\n   */\r\n  @Input() pageSize?: number;\r\n\r\n  /**\r\n * Maximum number of page tabs to show\r\n */\r\n  @Input() maxTabs?: number = 10;\r\n\r\n  /**\r\n   * Makes the searchbox readonly if true.\r\n   */\r\n  @Input() searchboxReadonly: boolean = false;\r\n\r\n  /** Passed to the inner TableComponent to enable row selection */\r\n  @Input() selectionContext?: TableSelectableRowContext;\r\n\r\n  /** Passed to the inner TableComponent to display a toolbar when 1 or more rows are selected. Requires `[selectionContext]` to be defined. */\r\n  @Input() selectionToolbarTemplate?: TemplateRef<any>;\r\n  \r\n  @ContentChildren(ResizableColumnComponent, {descendants: true}) resizableColumns!: QueryList<ResizableColumnComponent>;\r\n\r\n  /** Optional text to add to the results count in the table footer. This text will be added after the count and objectType. */\r\n  @Input() additionalCountText: string = '';\r\n\r\n  /** Enables table row selection and row highlighting styles when true */\r\n  @Input() selectable: boolean = false;\r\n\r\n  /**Defaults to undefined. Specify your own template if an ec-table wrapped around your transcluded content won't meet your needs\r\n   */\r\n  @Input() customContentTemplate?: TemplateRef<any>;\r\n\r\n  /** When true, removes the card styles from the table wrapper */\r\n  @Input() removeCard: boolean = false;\r\n\r\n  /** Classes to add to the overlay/card element */\r\n  @Input() overlayClasses: string = '';\r\n\r\n  /**\r\n   * PagingInfo for the current page.\r\n   */\r\n  public pageInfo?: PagingInfo;\r\n\r\n  /** Reference to the searchModel */\r\n  public get searchModel(): FormControl {\r\n    return this.formModel.controls.searchModel as FormControl;\r\n  }\r\n\r\n  /**\r\n   * Text displayed in the footer.\r\n   * Sometimes `noDataMessage`, sometimes `noSearchResultsMessage`\r\n   */\r\n  public tableCaption: string = this.translateService.instant(this.noDataMessage || 'SearchableTable_Default_NoData_SC');\r\n\r\n  /** count of results displayed in the table */\r\n  public resultsCount: string = '';\r\n\r\n  /** Items returned by the getItems function, along with total count */\r\n  public searchResults: TableSearchResults = { items: [], totalItems: 0 };\r\n\r\n  /**\r\n   * If passed an input for refresh, triggers reloading items.\r\n   * Otherwise, completes immediately (will never trigger reload).\r\n   */\r\n  private refreshTrigger: Observable<SearchableTableFormModel | undefined> = EMPTY;\r\n  private destroyed: Subject<void> = new Subject();\r\n\r\n  private pageChanged: Subject<SearchableTableFormModel> = new Subject();\r\n\r\n  /** Triggers the initial load of the table */\r\n  private initTable = new Subject<any>();\r\n\r\n  constructor(\r\n    private errorService: ErrorService,\r\n    private translateService: TranslateService,\r\n    private rowCountPipe: RowCountPipe\r\n  ) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.pageSize && !changes.pageSize.firstChange && this.pageable) {\r\n      // If the pageSize changes, reset to the first page and refresh.\r\n      this.pageInfo = TablePaginationComponent.getPagingInfo(1, this.pageSize!);\r\n      this.onPageChange(this.pageInfo);\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.status.setStatus('pending', 'Loading');\r\n    this.setUpRefreshTrigger();\r\n\r\n    // Watch for searchbox/other control changes or refresh requests\r\n    const searchOrRefresh = merge(\r\n      this.formModel.valueChanges.pipe(\r\n        skipUntil(this.ready),\r\n        debounceTime(300)\r\n      ),\r\n      this.refreshTrigger,\r\n      this.initTable\r\n    ).pipe(tap(()=> {\r\n      //a change to any form control or a refresh should reset the pageInfo to the first page if the table is pageable.\r\n      //(if we didnt reset the pageInfo, we'd have to call getItems with the previous pageInfo, which may not be valid for the new results)\r\n      if(this.pageable) {\r\n        this.pageInfo = TablePaginationComponent.getPagingInfo(1, this.pageSize!);\r\n      }\r\n    }));\r\n\r\n    const updateResults = merge(\r\n      searchOrRefresh,\r\n      this.pageChanged.pipe(\r\n        // Prevent a call to getItems when the pageSize is set during page init and before ready is completed\r\n        skipUntil(this.ready)\r\n      )\r\n    )\r\n\r\n    // Call getItems and watch for errors\r\n    const getData = updateResults.pipe(\r\n      // Pluck the searchModel value out of the formModel\r\n      pluck('searchModel'),\r\n\r\n      // Ensure search string is defined\r\n      // Trim and lowercase it to aid case-insensitive searching\r\n      map((searchString?: string) => {\r\n        let search = searchString || '';\r\n        return search.trim().toLowerCase();\r\n      }),\r\n\r\n      // Show status overlay\r\n      tap(() => this.status.setStatus('pending', 'Loading')),\r\n\r\n      // Call passed function\r\n      switchMap((searchString: string) => \r\n        //if the table is pageable, pageInfo will be defined.\r\n        this.getItems(searchString, this.pageInfo)\r\n      ),\r\n\r\n      // If passed function fails, show error status\r\n      catchError((err, caught) => {\r\n        this.status.setStatus('error', this.errorService.parseApiError(err));\r\n        // return the caught observable so the subscription doesn't complete\r\n        return caught;\r\n      }),\r\n\r\n      takeUntil(this.destroyed),\r\n    );\r\n\r\n    // Handle returned data and notify parent\r\n    getData.subscribe((results: TableSearchResults) => {\r\n      // Limiting number of results to show if not pageable (if pageable the max number of items in the table\r\n      // can be modified by increasing/decreasing the pageSize.)\r\n      if(!this.pageable) {\r\n        results.items = results.items.slice(0, this.maxItemCount);\r\n      }\r\n\r\n      // Need to know this (along with if there's a value in the formModel) to determine what to show in the footer\r\n      this.searchResults = results;\r\n    \r\n      this.tableCaption = this.getCaption(results);\r\n      this.resultsCount = this.pageable ? this.rowCountPipe.transform(results, this.objectType, undefined, this.pageInfo):\r\n                                          this.rowCountPipe.transform(results, this.objectType, this.maxItemCount);\r\n\r\n      // Disable searchbox when in no-data state\r\n      if (!results.items.length && !this.searchModel.value) {\r\n        this.searchModel.disable({ emitEvent: false });\r\n      } else if (this.searchModel.disabled) {\r\n        // re-enable if it was disabled, but now has items\r\n        this.searchModel.enable({ emitEvent: false });\r\n      }\r\n\r\n      this.status.setStatus('hasData');\r\n      // Send the results to the parent component\r\n      this.itemsChange.emit(results);\r\n    });\r\n\r\n    // When 'ready' is completed by the host, initialize the table with the current form model values\r\n    this.ready.subscribe({\r\n      complete: () => {\r\n        this.initTable.next(this.formModel.value);\r\n        this.initTable.complete();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroyed.next();\r\n    this.destroyed.unsubscribe();\r\n  }\r\n\r\n  /** Pass along sort to parent component */\r\n  onSortChange(sort: TableSort): void {\r\n    this.sortChange.emit(sort);\r\n  }\r\n\r\n  /**\r\n   * When a page changes, store the new pagingInfo and emit the current value of the form to trigger getData.\r\n   */\r\n  onPageChange(pagingInfo: PagingInfo) {\r\n    this.status.setStatus('pending', 'Loading');\r\n    this.pageInfo = pagingInfo;\r\n    this.pageChangeEmitter.emit(pagingInfo);\r\n    this.pageChanged.next(this.formModel.value);\r\n  }\r\n\r\n\r\n  /**\r\n   * Wire up a handler to the `refresh` observable so that when\r\n   * the host page context changes it can force the table to update as well.\r\n   *\r\n   * If the `refresh` observable passes options and the `clearSearch` property\r\n   * is set to true, reset the searchModel and pass an empty string.\r\n   *\r\n   * If `refresh` observable does not pass options or the `clearSearch` property\r\n   * is set to false, pass along the current searchModel Value.\r\n   */\r\n  private setUpRefreshTrigger() {\r\n    if (this.refresh) {\r\n      this.refreshTrigger = this.refresh.pipe(\r\n        map(opts => {\r\n          if (opts && opts.clearSearch) {\r\n            this.searchModel.reset('', { emitEvent: false });\r\n            return { ...this.formModel, searchModel: '' };\r\n          }\r\n          return this.formModel.value;\r\n        }),\r\n        takeUntil(this.destroyed)\r\n      );\r\n    }\r\n  }\r\n\r\n  /** Get text to display in the footer. */\r\n  private getCaption(results: TableSearchResults): string {\r\n    if (results.items.length) {\r\n      return '';\r\n    }\r\n\r\n    if (this.searchModel.value) {\r\n      return this.translateService.instant(this.noSearchResultsMessage || 'SearchableTable_Default_NoMatches_SC', { searchText: this.searchModel.value });\r\n    }\r\n\r\n    return this.translateService.instant(this.noDataMessage || 'SearchableTable_Default_NoData_SC');\r\n  }\r\n\r\n}"]}
|
|
303
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchable-table.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/display/table/searchable-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChildren, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, QueryList, SimpleChanges, TemplateRef } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { EMPTY, merge, Observable, Subject } from 'rxjs';\r\nimport { catchError, debounceTime, map, pluck, skipUntil, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { ErrorService } from '../../core/error.service';\r\nimport { RowCountPipe } from '../../shared/display/pipes/row-count.pipe';\r\nimport { Overlay } from '../view-overlay/view-overlay.component';\r\nimport { ResizableColumnComponent } from './resizable-column.component';\r\nimport { PagingInfo, TablePaginationComponent } from './table-pagination.component';\r\nimport { TableSelectableRowContext } from './table-selectable-row.component';\r\nimport { TableSort } from './table.component';\r\n\r\nexport type TableSearchResults = { items: unknown[], totalItems: number, totalItemsBeforePaging?: number };\r\nexport type SearchableTableRefreshOptions = { clearSearch?: boolean };\r\n\r\ntype SearchableTableFormModel = { searchModel?: string };\r\n\r\n@Component({\r\n  selector: 'ec-searchable-table',\r\n  templateUrl: './searchable-table.component.html',\r\n  styleUrls: ['./searchable-table.component.scss']\r\n})\r\nexport class SearchableTableComponent implements OnInit, OnDestroy, OnChanges {\r\n\r\n  @Input() id = '';\r\n  @Input() resizable = false;\r\n  @Input() sortable = false;\r\n  @Input() sort?: TableSort;\r\n  @Input() autofocus: boolean = false;\r\n\r\n  /**Set to a space-separated set of strings that should be added to the ec-table class attribute\r\n   * this allows finer control over styling.\r\n   */\r\n  @Input() tableClasses: string = '';\r\n\r\n  /** Emits when table sort has changed */\r\n  @Output() sortChange: EventEmitter<TableSort> = new EventEmitter<TableSort>();\r\n\r\n  /** Emits when the table page has changed */\r\n  @Output('pageChange') pageChangeEmitter: EventEmitter<PagingInfo> = new EventEmitter<PagingInfo>();\r\n\r\n  /** Placeholder text for the searchbox */\r\n  @Input() searchboxPlaceholder = '';\r\n\r\n  /**\r\n   * FormGroup for the searchbox\r\n   *\r\n   * The referenced FormGroup **must** contain a FormControl called 'searchModel'.\r\n   */\r\n  @Input() public formModel!: FormGroup;\r\n\r\n  /**\r\n   * Displayed in overlay when no data is returned (without searching).\r\n   *\r\n   * Defaults to \"SearchableTable_Default_NoData_SC\"\r\n   */\r\n  @Input() noDataMessage: string = 'SearchableTable_Default_NoData_SC';\r\n\r\n  /**\r\n   * Displayed in overlay when no data is returned (after searching).\r\n   * Ensure translation has an interpolation placeholder for \"searchText\".\r\n   *\r\n   * Defaults to \"SearchableTable_Default_NoMatches_SC\"\r\n   *\r\n   * @example\r\n   * // 7 requires single curly braces\r\n   * No items found matching <strong>{{searchText}}</strong>\r\n   */\r\n  @Input() noSearchResultsMessage: string = 'SearchableTable_Default_NoMatches_SC';\r\n\r\n  /**\r\n   * Indicates hosting page is ready for the table to load data.\r\n   *\r\n   * Next and Complete this observable after hosting page has made any preliminary\r\n   * API (or other asynchronous) calls to load prerequisite data upon which the code\r\n   * in the `getItems` function depends.  Use a `ReplaySubject` to ensure every component\r\n   * that uses this observable gets the Next and Complete notifications.\r\n   */\r\n  @Input() ready!: Observable<void>;\r\n\r\n  /**\r\n   * Function called to get items to display in the table.\r\n   * If pageable is true, the TableSearchResults need to include totalItemsBeforePaging, which is the\r\n   * count of items before you've applied any pagination (i.e. the total number of items that came back from the search).\r\n   *\r\n   * Make sure to bind the scope in the template\r\n   * @example\r\n   * [getItems]=\"yourFunction.bind(this)\"\r\n   */\r\n  @Input() getItems!: (search?: string, pageChangeInfo?: PagingInfo) => Observable<TableSearchResults>;\r\n\r\n  /** Observable that will force the getItems function to get called again */\r\n  @Input() refresh?: Observable<SearchableTableRefreshOptions | undefined>;\r\n\r\n  /** Allow the host component to supply an overlay to control the pending state of the table */\r\n  @Input() status: Overlay = new Overlay('hasData');\r\n\r\n  /**\r\n   * Sets the underlying table's layout to fixed.\r\n   */\r\n  @Input() tableLayoutFixed: boolean = false;\r\n\r\n  /** Emits items returned by the getItems function, along with total count */\r\n  @Output() itemsChange: EventEmitter<TableSearchResults> = new EventEmitter<TableSearchResults>();\r\n\r\n  /** Optional tab index for the searchbox */\r\n  @Input() searchboxTabIndex?: number;\r\n\r\n  /** Maximum number of items to show in the table (default: 100) */\r\n  @Input() maxItemCount: number = 100;\r\n\r\n  /** Set to true to hide search box (does not hide the other searchable table controls */\r\n  @Input() hideSearchControl: boolean = false;\r\n\r\n  /** Set to true to hide the entire header */\r\n  @Input() hideHeader: boolean = false;\r\n\r\n  /** Type of object in the table. Displayed in footer (default: 'results')*/\r\n  @Input() objectType: string = 'results';\r\n\r\n  /** Set to true to hide the table footer */\r\n  @Input() hideFooter: boolean = false;\r\n\r\n  /**\r\n   * Set to true to enable paging. If paging is enabled, pageSize must be provided.\r\n   * getItems will be passed both a search and a PagingInfo object when called. It must include totalItemsBeforePaging in the TableSearchResults output.\r\n   * Here is a simple implementation: \r\n   * @example\r\n   * getItems(search?: string, pageChangeInfo?: PagingInfo): Observable<TableSearchResults> {\r\n      let results: SimpleItem[] = [...this.paginatedTableItems];\r\n      //apply search\r\n      if(search) {\r\n        results = this.paginatedTableItems.filter(i => i.a.toLowerCase().includes(search.toLowerCase()));\r\n      }\r\n      //get count before applying paging\r\n      let countBeforePaging = results.length;\r\n      //apply paging\r\n      if(pageChangeInfo) {\r\n        results = results.slice(pageChangeInfo!.skip, pageChangeInfo!.skip + pageChangeInfo!.pageSize);\r\n      }\r\n      return of({ items: results, totalItems: results.length, totalItemsBeforePaging: countBeforePaging });\r\n    }\r\n  */\r\n  @Input() pageable: boolean = false;\r\n\r\n  /**\r\n   * Max size of a page.\r\n   */\r\n  @Input() pageSize?: number;\r\n\r\n  /**\r\n * Maximum number of page tabs to show\r\n */\r\n  @Input() maxTabs?: number = 10;\r\n\r\n  /**\r\n   * Makes the searchbox readonly if true.\r\n   */\r\n  @Input() searchboxReadonly: boolean = false;\r\n\r\n  /** Passed to the inner TableComponent to enable row selection */\r\n  @Input() selectionContext?: TableSelectableRowContext;\r\n\r\n  /** Passed to the inner TableComponent to display a toolbar when 1 or more rows are selected. Requires `[selectionContext]` to be defined. */\r\n  @Input() selectionToolbarTemplate?: TemplateRef<any>;\r\n  \r\n  @ContentChildren(ResizableColumnComponent, {descendants: true}) resizableColumns!: QueryList<ResizableColumnComponent>;\r\n\r\n  /** Optional text to add to the results count in the table footer. This text will be added after the count and objectType. */\r\n  @Input() additionalCountText: string = '';\r\n\r\n  /** Enables table row selection and row highlighting styles when true */\r\n  @Input() selectable: boolean = false;\r\n\r\n  /**Defaults to undefined. Specify your own template if an ec-table wrapped around your transcluded content won't meet your needs\r\n   */\r\n  @Input() customContentTemplate?: TemplateRef<any>;\r\n\r\n  /** When true, removes the card styles from the table wrapper */\r\n  @Input() removeCard: boolean = false;\r\n\r\n  /** Classes to add to the overlay/card element */\r\n  @Input() overlayClasses: string = '';\r\n\r\n  /** When true the overlay and table will not have flex-shrink-max but instead flex-grow */\r\n  @Input() fillParentHeight?: boolean = false;\r\n\r\n  /**\r\n   * PagingInfo for the current page.\r\n   */\r\n  public pageInfo?: PagingInfo;\r\n\r\n  /** Reference to the searchModel */\r\n  public get searchModel(): FormControl {\r\n    return this.formModel.controls.searchModel as FormControl;\r\n  }\r\n\r\n  /**\r\n   * Text displayed in the footer.\r\n   * Sometimes `noDataMessage`, sometimes `noSearchResultsMessage`\r\n   */\r\n  public tableCaption: string = this.translateService.instant(this.noDataMessage || 'SearchableTable_Default_NoData_SC');\r\n\r\n  /** count of results displayed in the table */\r\n  public resultsCount: string = '';\r\n\r\n  /** Items returned by the getItems function, along with total count */\r\n  public searchResults: TableSearchResults = { items: [], totalItems: 0 };\r\n\r\n  /**\r\n   * If passed an input for refresh, triggers reloading items.\r\n   * Otherwise, completes immediately (will never trigger reload).\r\n   */\r\n  private refreshTrigger: Observable<SearchableTableFormModel | undefined> = EMPTY;\r\n  private destroyed: Subject<void> = new Subject();\r\n\r\n  private pageChanged: Subject<SearchableTableFormModel> = new Subject();\r\n\r\n  /** Triggers the initial load of the table */\r\n  private initTable = new Subject<any>();\r\n\r\n  constructor(\r\n    private errorService: ErrorService,\r\n    private translateService: TranslateService,\r\n    private rowCountPipe: RowCountPipe\r\n  ) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.pageSize && !changes.pageSize.firstChange && this.pageable) {\r\n      // If the pageSize changes, reset to the first page and refresh.\r\n      this.pageInfo = TablePaginationComponent.getPagingInfo(1, this.pageSize!);\r\n      this.onPageChange(this.pageInfo);\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.status.setStatus('pending', 'Loading');\r\n    this.setUpRefreshTrigger();\r\n\r\n    // Watch for searchbox/other control changes or refresh requests\r\n    const searchOrRefresh = merge(\r\n      this.formModel.valueChanges.pipe(\r\n        skipUntil(this.ready),\r\n        debounceTime(300)\r\n      ),\r\n      this.refreshTrigger,\r\n      this.initTable\r\n    ).pipe(tap(()=> {\r\n      //a change to any form control or a refresh should reset the pageInfo to the first page if the table is pageable.\r\n      //(if we didnt reset the pageInfo, we'd have to call getItems with the previous pageInfo, which may not be valid for the new results)\r\n      if(this.pageable) {\r\n        this.pageInfo = TablePaginationComponent.getPagingInfo(1, this.pageSize!);\r\n      }\r\n    }));\r\n\r\n    const updateResults = merge(\r\n      searchOrRefresh,\r\n      this.pageChanged.pipe(\r\n        // Prevent a call to getItems when the pageSize is set during page init and before ready is completed\r\n        skipUntil(this.ready)\r\n      )\r\n    )\r\n\r\n    // Call getItems and watch for errors\r\n    const getData = updateResults.pipe(\r\n      // Pluck the searchModel value out of the formModel\r\n      pluck('searchModel'),\r\n\r\n      // Ensure search string is defined\r\n      // Trim and lowercase it to aid case-insensitive searching\r\n      map((searchString?: string) => {\r\n        let search = searchString || '';\r\n        return search.trim().toLowerCase();\r\n      }),\r\n\r\n      // Show status overlay\r\n      tap(() => this.status.setStatus('pending', 'Loading')),\r\n\r\n      // Call passed function\r\n      switchMap((searchString: string) => \r\n        //if the table is pageable, pageInfo will be defined.\r\n        this.getItems(searchString, this.pageInfo)\r\n      ),\r\n\r\n      // If passed function fails, show error status\r\n      catchError((err, caught) => {\r\n        this.status.setStatus('error', this.errorService.parseApiError(err));\r\n        // return the caught observable so the subscription doesn't complete\r\n        return caught;\r\n      }),\r\n\r\n      takeUntil(this.destroyed),\r\n    );\r\n\r\n    // Handle returned data and notify parent\r\n    getData.subscribe((results: TableSearchResults) => {\r\n      // Limiting number of results to show if not pageable (if pageable the max number of items in the table\r\n      // can be modified by increasing/decreasing the pageSize.)\r\n      if(!this.pageable) {\r\n        results.items = results.items.slice(0, this.maxItemCount);\r\n      }\r\n\r\n      // Need to know this (along with if there's a value in the formModel) to determine what to show in the footer\r\n      this.searchResults = results;\r\n    \r\n      this.tableCaption = this.getCaption(results);\r\n      this.resultsCount = this.pageable ? this.rowCountPipe.transform(results, this.objectType, undefined, this.pageInfo):\r\n                                          this.rowCountPipe.transform(results, this.objectType, this.maxItemCount);\r\n\r\n      // Disable searchbox when in no-data state\r\n      if (!results.items.length && !this.searchModel.value) {\r\n        this.searchModel.disable({ emitEvent: false });\r\n      } else if (this.searchModel.disabled) {\r\n        // re-enable if it was disabled, but now has items\r\n        this.searchModel.enable({ emitEvent: false });\r\n      }\r\n\r\n      this.status.setStatus('hasData');\r\n      // Send the results to the parent component\r\n      this.itemsChange.emit(results);\r\n    });\r\n\r\n    // When 'ready' is completed by the host, initialize the table with the current form model values\r\n    this.ready.subscribe({\r\n      complete: () => {\r\n        this.initTable.next(this.formModel.value);\r\n        this.initTable.complete();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroyed.next();\r\n    this.destroyed.unsubscribe();\r\n  }\r\n\r\n  /** Pass along sort to parent component */\r\n  onSortChange(sort: TableSort): void {\r\n    this.sortChange.emit(sort);\r\n  }\r\n\r\n  /**\r\n   * When a page changes, store the new pagingInfo and emit the current value of the form to trigger getData.\r\n   */\r\n  onPageChange(pagingInfo: PagingInfo) {\r\n    this.status.setStatus('pending', 'Loading');\r\n    this.pageInfo = pagingInfo;\r\n    this.pageChangeEmitter.emit(pagingInfo);\r\n    this.pageChanged.next(this.formModel.value);\r\n  }\r\n\r\n\r\n  /**\r\n   * Wire up a handler to the `refresh` observable so that when\r\n   * the host page context changes it can force the table to update as well.\r\n   *\r\n   * If the `refresh` observable passes options and the `clearSearch` property\r\n   * is set to true, reset the searchModel and pass an empty string.\r\n   *\r\n   * If `refresh` observable does not pass options or the `clearSearch` property\r\n   * is set to false, pass along the current searchModel Value.\r\n   */\r\n  private setUpRefreshTrigger() {\r\n    if (this.refresh) {\r\n      this.refreshTrigger = this.refresh.pipe(\r\n        map(opts => {\r\n          if (opts && opts.clearSearch) {\r\n            this.searchModel.reset('', { emitEvent: false });\r\n            return { ...this.formModel, searchModel: '' };\r\n          }\r\n          return this.formModel.value;\r\n        }),\r\n        takeUntil(this.destroyed)\r\n      );\r\n    }\r\n  }\r\n\r\n  /** Get text to display in the footer. */\r\n  private getCaption(results: TableSearchResults): string {\r\n    if (results.items.length) {\r\n      return '';\r\n    }\r\n\r\n    if (this.searchModel.value) {\r\n      return this.translateService.instant(this.noSearchResultsMessage || 'SearchableTable_Default_NoMatches_SC', { searchText: this.searchModel.value });\r\n    }\r\n\r\n    return this.translateService.instant(this.noDataMessage || 'SearchableTable_Default_NoData_SC');\r\n  }\r\n\r\n}"]}
|