@c8y/ngx-components
Version:
Angular modules for Cumulocity IoT applications
145 lines • 16.4 kB
JavaScript
import { NgModule } from '@angular/core';
import { RouterModule } from '@angular/router';
import { CoreModule, hookNavigator, hookTab } from '@c8y/ngx-components';
import { BulkOperationFromSingleModule } from '@c8y/ngx-components/operations/bulk-operation-from-single';
import { BulkOperationsListModule } from '@c8y/ngx-components/operations/bulk-operations-list';
import { BulkOperationsServiceModule } from '@c8y/ngx-components/operations/bulk-operations-service';
import { BulkOperationsStepperContainerModule } from '@c8y/ngx-components/operations/bulk-operations-stepper-container';
import { StepperBulkTypeConfigurationModule } from '@c8y/ngx-components/operations/stepper-bulk-type-configuration';
import { StepperBulkTypeDeviceProfileModule } from '@c8y/ngx-components/operations/stepper-bulk-type-device-profile';
import { StepperBulkTypeFirmwareModule } from '@c8y/ngx-components/operations/stepper-bulk-type-firmware';
import { StepperBulkTypeSoftwareModule } from '@c8y/ngx-components/operations/stepper-bulk-type-software';
import { deviceControlOverviewFeatureProvider, deviceControlTabFeatureProvider } from '@c8y/ngx-components/operations/operations-list';
import { OperationsNavigationFactory } from './factories/nav.factory';
import { OperationsTabsFactory } from './factories/tabs.factory';
import * as i0 from "@angular/core";
import * as i1 from "@angular/router";
export const operationsRoutes = [
{
path: 'devicecontrol',
redirectTo: 'devicecontrol/single',
pathMatch: 'full'
}
];
/**
* This module sets up the 'Device control' view. By importing it in your custom application you will have:
* - a 'Device control' tab in device details view
* - a 'Device control' entry in the 'Overviews' section of navigator
* - 'Bulk operations' tab on the 'Device control' page
* - list view of existing bulk operations with expandable details and options to filter
* - guided stepper dialogs to schedule new bulk operations of supported types
* (Configuration update, Firmware update, Software update, Apply device profile).
*
* Additionaly you can use the modules imported by {@link OperationsModule} separately to achieve
* the results you wish to have in your application, e.g.:
* - import {@link BulkOperationsListModule} and {@link BulkOperationsServiceModule}
* to have an overview of existing bulk operation with expandable details
* - additionaly import {@link BulkOperationsStepperContainerModule} and any of the existing
* `StepperBulkType*Module` modules ({@link StepperBulkTypeConfigurationModule},
* {@link StepperBulkTypeFirmwareModule}, {@link StepperBulkTypeSoftwareModule},
* {@link StepperBulkTypeDeviceProfileModule}) to have the option
* to create new bulk operation in a guided stepper dialog.
*
* ```typescript
* import { BulkOperationsServiceModule } from '@c8y/ngx-components/operations/bulk-operations-service';
* import { BulkOperationsListModule } from '@c8y/ngx-components/operations/bulk-operations-list';
*
* @NgModule({
* imports: [
* [...]
* BulkOperationsServiceModule,
* BulkOperationsListModule
* ],
* [...]
* })
* export class CustomOperationsModule {}```
* respectively
* ```typescript
* import { BulkOperationsStepperContainerModule } from '@c8y/ngx-components/operations/bulk-operations-stepper-container';
* import { BulkOperationsServiceModule } from '@c8y/ngx-components/operations/bulk-operations-service';
* import { BulkOperationsListModule } from '@c8y/ngx-components/operations/bulk-operations-list';
* import { StepperBulkTypeSoftwareModule } from '@c8y/ngx-components/operations/stepper-bulk-type-software';
*
* @NgModule({
* imports: [
* [...]
* BulkOperationsServiceModule,
* BulkOperationsListModule,
* BulkOperationsStepperContainerModule,
* StepperBulkTypeSoftwareModule
* ],
* [...]
* })
* export class CustomOperationsModule {}```
* You can provide your own bulk operation stepper by registering a component via the `hookListBulkType`:
*
* ```typescript
* import {
* hookListBulkType,
* baseUrl
* } from '@c8y/ngx-components/operations/bulk-operations-service';
*
* [...]
*
* providers: [
* hookListBulkType({
* type: 'my-bulk-op-type',
* c8yIcon: 'c8y-tools',
* name: 'My bulk op type',
* path: `${baseUrl}my-type`,
* component: StepperMyBulkTypeComponent,
* fragments: ['c8y_MyType'],
* selected: false
* })
* ]```
*/
export class OperationsModule {
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OperationsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: OperationsModule, imports: [CoreModule, i1.RouterModule, BulkOperationFromSingleModule,
BulkOperationsListModule,
BulkOperationsServiceModule,
BulkOperationsStepperContainerModule,
StepperBulkTypeConfigurationModule,
StepperBulkTypeFirmwareModule,
StepperBulkTypeSoftwareModule,
StepperBulkTypeDeviceProfileModule] }); }
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OperationsModule, providers: [
hookTab(OperationsTabsFactory),
hookNavigator(OperationsNavigationFactory),
deviceControlOverviewFeatureProvider,
deviceControlTabFeatureProvider
], imports: [CoreModule,
RouterModule.forChild(operationsRoutes),
BulkOperationFromSingleModule,
BulkOperationsListModule,
BulkOperationsServiceModule,
BulkOperationsStepperContainerModule,
StepperBulkTypeConfigurationModule,
StepperBulkTypeFirmwareModule,
StepperBulkTypeSoftwareModule,
StepperBulkTypeDeviceProfileModule] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OperationsModule, decorators: [{
type: NgModule,
args: [{
imports: [
CoreModule,
RouterModule.forChild(operationsRoutes),
BulkOperationFromSingleModule,
BulkOperationsListModule,
BulkOperationsServiceModule,
BulkOperationsStepperContainerModule,
StepperBulkTypeConfigurationModule,
StepperBulkTypeFirmwareModule,
StepperBulkTypeSoftwareModule,
StepperBulkTypeDeviceProfileModule
],
providers: [
hookTab(OperationsTabsFactory),
hookNavigator(OperationsNavigationFactory),
deviceControlOverviewFeatureProvider,
deviceControlTabFeatureProvider
]
}]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"operations.module.js","sourceRoot":"","sources":["../../../operations/operations.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,OAAO,EAAS,MAAM,qBAAqB,CAAC;AAChF,OAAO,EAAE,6BAA6B,EAAE,MAAM,2DAA2D,CAAC;AAC1G,OAAO,EAAE,wBAAwB,EAAE,MAAM,qDAAqD,CAAC;AAC/F,OAAO,EAAE,2BAA2B,EAAE,MAAM,wDAAwD,CAAC;AACrG,OAAO,EAAE,oCAAoC,EAAE,MAAM,kEAAkE,CAAC;AACxH,OAAO,EAAE,kCAAkC,EAAE,MAAM,gEAAgE,CAAC;AACpH,OAAO,EAAE,kCAAkC,EAAE,MAAM,iEAAiE,CAAC;AACrH,OAAO,EAAE,6BAA6B,EAAE,MAAM,2DAA2D,CAAC;AAC1G,OAAO,EAAE,6BAA6B,EAAE,MAAM,2DAA2D,CAAC;AAE1G,OAAO,EACL,oCAAoC,EACpC,+BAA+B,EAChC,MAAM,gDAAgD,CAAC;AACxD,OAAO,EAAE,2BAA2B,EAAE,MAAM,yBAAyB,CAAC;AACtE,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;;;AAEjE,MAAM,CAAC,MAAM,gBAAgB,GAAY;IACvC;QACE,IAAI,EAAE,eAAe;QACrB,UAAU,EAAE,sBAAsB;QAClC,SAAS,EAAE,MAAM;KAClB;CACF,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuEG;AAqBH,MAAM,OAAO,gBAAgB;+GAAhB,gBAAgB;gHAAhB,gBAAgB,YAlBzB,UAAU,mBAEV,6BAA6B;YAC7B,wBAAwB;YACxB,2BAA2B;YAC3B,oCAAoC;YACpC,kCAAkC;YAClC,6BAA6B;YAC7B,6BAA6B;YAC7B,kCAAkC;gHASzB,gBAAgB,aAPhB;YACT,OAAO,CAAC,qBAAqB,CAAC;YAC9B,aAAa,CAAC,2BAA2B,CAAC;YAC1C,oCAAoC;YACpC,+BAA+B;SAChC,YAhBC,UAAU;YACV,YAAY,CAAC,QAAQ,CAAC,gBAAgB,CAAC;YACvC,6BAA6B;YAC7B,wBAAwB;YACxB,2BAA2B;YAC3B,oCAAoC;YACpC,kCAAkC;YAClC,6BAA6B;YAC7B,6BAA6B;YAC7B,kCAAkC;;4FASzB,gBAAgB;kBApB5B,QAAQ;mBAAC;oBACR,OAAO,EAAE;wBACP,UAAU;wBACV,YAAY,CAAC,QAAQ,CAAC,gBAAgB,CAAC;wBACvC,6BAA6B;wBAC7B,wBAAwB;wBACxB,2BAA2B;wBAC3B,oCAAoC;wBACpC,kCAAkC;wBAClC,6BAA6B;wBAC7B,6BAA6B;wBAC7B,kCAAkC;qBACnC;oBACD,SAAS,EAAE;wBACT,OAAO,CAAC,qBAAqB,CAAC;wBAC9B,aAAa,CAAC,2BAA2B,CAAC;wBAC1C,oCAAoC;wBACpC,+BAA+B;qBAChC;iBACF","sourcesContent":["import { NgModule } from '@angular/core';\nimport { RouterModule } from '@angular/router';\n\nimport { CoreModule, hookNavigator, hookTab, Route } from '@c8y/ngx-components';\nimport { BulkOperationFromSingleModule } from '@c8y/ngx-components/operations/bulk-operation-from-single';\nimport { BulkOperationsListModule } from '@c8y/ngx-components/operations/bulk-operations-list';\nimport { BulkOperationsServiceModule } from '@c8y/ngx-components/operations/bulk-operations-service';\nimport { BulkOperationsStepperContainerModule } from '@c8y/ngx-components/operations/bulk-operations-stepper-container';\nimport { StepperBulkTypeConfigurationModule } from '@c8y/ngx-components/operations/stepper-bulk-type-configuration';\nimport { StepperBulkTypeDeviceProfileModule } from '@c8y/ngx-components/operations/stepper-bulk-type-device-profile';\nimport { StepperBulkTypeFirmwareModule } from '@c8y/ngx-components/operations/stepper-bulk-type-firmware';\nimport { StepperBulkTypeSoftwareModule } from '@c8y/ngx-components/operations/stepper-bulk-type-software';\n\nimport {\n  deviceControlOverviewFeatureProvider,\n  deviceControlTabFeatureProvider\n} from '@c8y/ngx-components/operations/operations-list';\nimport { OperationsNavigationFactory } from './factories/nav.factory';\nimport { OperationsTabsFactory } from './factories/tabs.factory';\n\nexport const operationsRoutes: Route[] = [\n  {\n    path: 'devicecontrol',\n    redirectTo: 'devicecontrol/single',\n    pathMatch: 'full'\n  }\n];\n\n/**\n * This module sets up the 'Device control' view. By importing it in your custom application you will have:\n * - a 'Device control' tab in device details view\n * - a 'Device control' entry in the 'Overviews' section of navigator\n * - 'Bulk operations' tab on the 'Device control' page\n * - list view of existing bulk operations with expandable details and options to filter\n * - guided stepper dialogs to schedule new bulk operations of supported types\n * (Configuration update, Firmware update, Software update, Apply device profile).\n *\n * Additionaly you can use the modules imported by {@link OperationsModule} separately to achieve\n * the results you wish to have in your application, e.g.:\n * - import {@link BulkOperationsListModule} and {@link BulkOperationsServiceModule}\n * to have an overview of existing bulk operation with expandable details\n * - additionaly import {@link BulkOperationsStepperContainerModule} and any of the existing\n * `StepperBulkType*Module` modules ({@link StepperBulkTypeConfigurationModule},\n * {@link StepperBulkTypeFirmwareModule}, {@link StepperBulkTypeSoftwareModule},\n * {@link StepperBulkTypeDeviceProfileModule}) to have the option\n * to create new bulk operation in a guided stepper dialog.\n *\n * ```typescript\n * import { BulkOperationsServiceModule } from '@c8y/ngx-components/operations/bulk-operations-service';\n * import { BulkOperationsListModule } from '@c8y/ngx-components/operations/bulk-operations-list';\n *\n * @NgModule({\n *   imports: [\n *     [...]\n *     BulkOperationsServiceModule,\n *     BulkOperationsListModule\n *   ],\n *   [...]\n * })\n * export class CustomOperationsModule {}```\n * respectively\n * ```typescript\n * import { BulkOperationsStepperContainerModule } from '@c8y/ngx-components/operations/bulk-operations-stepper-container';\n * import { BulkOperationsServiceModule } from '@c8y/ngx-components/operations/bulk-operations-service';\n * import { BulkOperationsListModule } from '@c8y/ngx-components/operations/bulk-operations-list';\n * import { StepperBulkTypeSoftwareModule } from '@c8y/ngx-components/operations/stepper-bulk-type-software';\n *\n * @NgModule({\n *   imports: [\n *     [...]\n *     BulkOperationsServiceModule,\n *     BulkOperationsListModule,\n *     BulkOperationsStepperContainerModule,\n *     StepperBulkTypeSoftwareModule\n *   ],\n *   [...]\n * })\n * export class CustomOperationsModule {}```\n * You can provide your own bulk operation stepper by registering a component via the `hookListBulkType`:\n *\n * ```typescript\n * import {\n *   hookListBulkType,\n *   baseUrl\n * } from '@c8y/ngx-components/operations/bulk-operations-service';\n *\n * [...]\n *\n * providers: [\n *   hookListBulkType({\n *     type: 'my-bulk-op-type',\n *     c8yIcon: 'c8y-tools',\n *     name: 'My bulk op type',\n *     path: `${baseUrl}my-type`,\n *     component: StepperMyBulkTypeComponent,\n *     fragments: ['c8y_MyType'],\n *     selected: false\n *   })\n * ]```\n */\n@NgModule({\n  imports: [\n    CoreModule,\n    RouterModule.forChild(operationsRoutes),\n    BulkOperationFromSingleModule,\n    BulkOperationsListModule,\n    BulkOperationsServiceModule,\n    BulkOperationsStepperContainerModule,\n    StepperBulkTypeConfigurationModule,\n    StepperBulkTypeFirmwareModule,\n    StepperBulkTypeSoftwareModule,\n    StepperBulkTypeDeviceProfileModule\n  ],\n  providers: [\n    hookTab(OperationsTabsFactory),\n    hookNavigator(OperationsNavigationFactory),\n    deviceControlOverviewFeatureProvider,\n    deviceControlTabFeatureProvider\n  ]\n})\nexport class OperationsModule {}\n"]}