mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-23 07:31:09 +02:00
* WIP updating config-ui engine to use api service and form class * updates form-field component to support false values for radio types * updates api-error-message util to log out error in dev env * fixes issues in custom messages create and edit workflows * fixes issues in api service * updates capabilities handling * updates to custom messages form * removes store from custom messages tests * removes store as dependency from config-ui engine * removes commented out code in messages route * updates orderedKeys to displayFields in messages page component * removes unneccesary method var from message create-and-edit component * removes comment about model in message details page
46 lines
1.3 KiB
JavaScript
46 lines
1.3 KiB
JavaScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
import Component from '@glimmer/component';
|
|
import { service } from '@ember/service';
|
|
import { action } from '@ember/object';
|
|
import apiErrorMessage from 'vault/utils/api-error-message';
|
|
|
|
/**
|
|
* @module Page::MessageDetails
|
|
* Page::MessageDetails components are used to display a message
|
|
* @example
|
|
* ```js
|
|
* <Page::MessageDetails @message={{this.model.message}} @capabilities={{this.model.capabilities}} />
|
|
* ```
|
|
* @param message
|
|
* @param capabilities - capabilities for the message
|
|
*/
|
|
|
|
export default class MessageDetails extends Component {
|
|
@service('app-router') router;
|
|
@service flashMessages;
|
|
@service customMessages;
|
|
@service namespace;
|
|
@service pagination;
|
|
@service api;
|
|
|
|
displayFields = ['active', 'type', 'authenticated', 'title', 'message', 'startTime', 'endTime', 'link'];
|
|
|
|
@action
|
|
async deleteMessage() {
|
|
try {
|
|
const { message } = this.args;
|
|
await this.api.sys.uiConfigDeleteCustomMessage(message.id);
|
|
this.router.transitionTo('vault.cluster.config-ui.messages');
|
|
this.customMessages.fetchMessages(this.namespace.path);
|
|
this.flashMessages.success(`Successfully deleted ${message.title}.`);
|
|
} catch (e) {
|
|
const errorMessage = await apiErrorMessage(e);
|
|
this.flashMessages.danger(errorMessage);
|
|
}
|
|
}
|
|
}
|