Jordan Reimer e18b0485f5
[UI] Ember Data Migration - Config UI Engine (#30238)
* 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
2025-04-28 16:09:11 -06:00

93 lines
2.4 KiB
JavaScript

/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: BUSL-1.1
*/
import Route from '@ember/routing/route';
import { service } from '@ember/service';
import { paginate } from 'core/utils/paginate-list';
import { PATH_MAP } from 'core/utils/capabilities';
export default class MessagesRoute extends Route {
@service api;
@service capabilities;
queryParams = {
page: {
refreshModel: true,
},
authenticated: {
refreshModel: true,
},
pageFilter: {
refreshModel: true,
},
status: {
refreshModel: true,
},
type: {
refreshModel: true,
},
};
async model(params) {
const { authenticated, page, pageFilter, status, type } = params;
const active = {
active: true,
inactive: false,
}[status];
try {
const { keyInfo, keys } = await this.api.sys.uiConfigListCustomMessages(
true,
active,
authenticated,
type
);
// ids are in the keys array and can be mapped to the object in keyInfo
// map and set id property on keyInfo object
const data = keys.map((id) => {
const { startTime, endTime, ...message } = keyInfo[id];
// dates returned from list endpoint are strings -- convert to date
return {
id,
...message,
startTime: startTime ? new Date(startTime) : startTime,
endTime: endTime ? new Date(endTime) : endTime,
};
});
const messages = paginate(data, {
page,
pageSize: 2,
filter: pageFilter,
filterKey: 'title',
});
// fetch capabilities for each message path
const paths = messages.map((message) => `${PATH_MAP.customMessages}/${message.id}`);
const capabilities = await this.capabilities.fetch(paths);
return { params, messages, capabilities };
} catch (e) {
if (e.response?.status === 404) {
return { params, messages: [] };
}
throw e;
}
}
setupController(controller, resolvedModel) {
super.setupController(controller, resolvedModel);
const label = controller.authenticated ? 'After User Logs In' : 'On Login Page';
controller.breadcrumbs = [{ label: 'Messages' }, { label }];
}
resetController(controller, isExiting) {
if (isExiting) {
controller.set('pageFilter', null);
controller.set('page', 1);
controller.set('status', null);
controller.set('type', null);
}
}
}