@c8y/ngx-components
Version:
Angular modules for Cumulocity IoT applications
118 lines • 14.3 kB
JavaScript
import { Injectable } from '@angular/core';
import { OperationService } from '@c8y/client';
import { AlertService, gettext } from '@c8y/ngx-components';
import { map } from 'lodash-es';
import { SERVICE_COMMANDS_MAP } from './services.model';
import * as i0 from "@angular/core";
import * as i1 from "@c8y/client";
import * as i2 from "@c8y/ngx-components";
export class ServiceCommandService {
constructor(operationService, alertService) {
this.operationService = operationService;
this.alertService = alertService;
}
/**
* Check if the service supports service commands.
* @param service The service object containing supported operations.
* @returns boolean indicating if the service supports service commands.
*/
isServiceCommandSupported(service) {
return service.c8y_SupportedOperations?.includes('c8y_ServiceCommand');
}
/**
* Get the list of supported service commands for the given service object.
* @param service The service object containing the c8y_SupportedServiceCommands fragment.
* @returns Array of supported commands.
*/
getSupportedCommands(service) {
return service.c8y_SupportedServiceCommands || map(SERVICE_COMMANDS_MAP, 'command');
}
/**
* Check if a specific command is supported for the given service.
* @param service The service object.
* @param command The command to check (e.g., START, STOP).
* @returns boolean indicating if the command is supported.
*/
isCommandSupported(service, command) {
const supportedCommands = this.getSupportedCommands(service);
return supportedCommands.includes(command);
}
/**
* Get all supported commands for a list of services.
* @param services The list of service objects to evaluate.
* @returns Array of all unique supported commands.
*/
getAllSupportedCommands(services) {
const allCommands = services
.filter(service => this.isServiceCommandSupported(service))
.flatMap(service => this.getSupportedCommands(service));
return Array.from(new Set(allCommands));
}
/**
* Create an operation for the selected service command.
* @param service The service object the operation should target.
* @param command The command to execute (e.g., START, STOP).
* @returns Promise of the created operation.
*/
createOperation({ id, name, serviceType }, command) {
const operation = {
deviceId: id,
description: `${command} ${name}`,
c8y_ServiceCommand: {
command,
serviceName: name,
serviceType: serviceType
}
};
return this.operationService.create(operation);
}
/**
* Generate a static list of action controls.
* The specific logic for each service is handled dynamically in showIf and callback.
* @returns Array of ActionControl objects.
*/
generateActionControls(commands) {
return commands.map(command => ({
type: command.toLowerCase(),
icon: this.getCommandIcon(command),
iconClasses: this.getCommandIconClass(command),
text: command,
showIf: (service) => this.isServiceCommandSupported(service) && this.isCommandSupported(service, command),
callback: async (service) => {
try {
await this.createOperation(service, command);
this.alertService.success(gettext('Operation created.'));
}
catch (error) {
const alertMessage = gettext('Could not create operation.');
this.alertService.danger(alertMessage, error);
}
}
}));
}
/**
* Get the icon for a specific command.
* @param command The command name.
* @returns Icon string for the command.
*/
getCommandIcon(command) {
return SERVICE_COMMANDS_MAP[command]?.icon || 'console';
}
/**
* Get the icon class for a specific command.
* @param command The command name.
* @returns Icon class string for the command.
*/
getCommandIconClass(command) {
return SERVICE_COMMANDS_MAP[command]?.styleClass;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ServiceCommandService, deps: [{ token: i1.OperationService }, { token: i2.AlertService }], target: i0.ɵɵFactoryTarget.Injectable }); }
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ServiceCommandService, providedIn: 'root' }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ServiceCommandService, decorators: [{
type: Injectable,
args: [{
providedIn: 'root'
}]
}], ctorParameters: () => [{ type: i1.OperationService }, { type: i2.AlertService }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-command.service.js","sourceRoot":"","sources":["../../../../services/shared/service-command.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { IOperation, IResult, OperationService } from '@c8y/client';\nimport { ActionControl, AlertService, gettext } from '@c8y/ngx-components';\nimport { map } from 'lodash-es';\nimport { Service, SERVICE_COMMANDS_MAP } from './services.model';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ServiceCommandService {\n  constructor(\n    private operationService: OperationService,\n    private alertService: AlertService\n  ) {}\n\n  /**\n   * Check if the service supports service commands.\n   * @param service The service object containing supported operations.\n   * @returns boolean indicating if the service supports service commands.\n   */\n  isServiceCommandSupported(service: Service): boolean {\n    return service.c8y_SupportedOperations?.includes('c8y_ServiceCommand');\n  }\n\n  /**\n   * Get the list of supported service commands for the given service object.\n   * @param service The service object containing the c8y_SupportedServiceCommands fragment.\n   * @returns Array of supported commands.\n   */\n  getSupportedCommands(service: Service): string[] {\n    return service.c8y_SupportedServiceCommands || map(SERVICE_COMMANDS_MAP, 'command');\n  }\n\n  /**\n   * Check if a specific command is supported for the given service.\n   * @param service The service object.\n   * @param command The command to check (e.g., START, STOP).\n   * @returns boolean indicating if the command is supported.\n   */\n  isCommandSupported(service: Service, command: string): boolean {\n    const supportedCommands = this.getSupportedCommands(service);\n    return supportedCommands.includes(command);\n  }\n\n  /**\n   * Get all supported commands for a list of services.\n   * @param services The list of service objects to evaluate.\n   * @returns Array of all unique supported commands.\n   */\n  getAllSupportedCommands(services: Service[]): string[] {\n    const allCommands = services\n      .filter(service => this.isServiceCommandSupported(service))\n      .flatMap(service => this.getSupportedCommands(service));\n\n    return Array.from(new Set(allCommands));\n  }\n\n  /**\n   * Create an operation for the selected service command.\n   * @param service The service object the operation should target.\n   * @param command The command to execute (e.g., START, STOP).\n   * @returns Promise of the created operation.\n   */\n  createOperation(\n    { id, name, serviceType }: Service,\n    command: string\n  ): Promise<IResult<IOperation>> {\n    const operation: IOperation = {\n      deviceId: id,\n      description: `${command} ${name}`,\n      c8y_ServiceCommand: {\n        command,\n        serviceName: name,\n        serviceType: serviceType\n      }\n    };\n\n    return this.operationService.create(operation);\n  }\n\n  /**\n   * Generate a static list of action controls.\n   * The specific logic for each service is handled dynamically in showIf and callback.\n   * @returns Array of ActionControl objects.\n   */\n  generateActionControls(commands: string[]): ActionControl[] {\n    return commands.map(command => ({\n      type: command.toLowerCase(),\n      icon: this.getCommandIcon(command),\n      iconClasses: this.getCommandIconClass(command),\n      text: command,\n      showIf: (service: Service) =>\n        this.isServiceCommandSupported(service) && this.isCommandSupported(service, command),\n      callback: async (service: Service) => {\n        try {\n          await this.createOperation(service, command);\n          this.alertService.success(gettext('Operation created.'));\n        } catch (error) {\n          const alertMessage = gettext('Could not create operation.');\n          this.alertService.danger(alertMessage, error);\n        }\n      }\n    }));\n  }\n\n  /**\n   * Get the icon for a specific command.\n   * @param command The command name.\n   * @returns Icon string for the command.\n   */\n  private getCommandIcon(command: string): string {\n    return SERVICE_COMMANDS_MAP[command]?.icon || 'console';\n  }\n\n  /**\n   * Get the icon class for a specific command.\n   * @param command The command name.\n   * @returns Icon class string for the command.\n   */\n  private getCommandIconClass(command: string): string {\n    return SERVICE_COMMANDS_MAP[command]?.styleClass;\n  }\n}\n"]}