open-nomad/ui/app/controllers/jobs/job/task-group.js

164 lines
4.4 KiB
JavaScript
Raw Normal View History

/* eslint-disable ember/no-incorrect-calls-with-inline-anonymous-functions */
import { inject as service } from '@ember/service';
import { alias, readOnly } from '@ember/object/computed';
import Controller from '@ember/controller';
2020-07-28 06:18:10 +00:00
import { action, computed, get } from '@ember/object';
import { scheduleOnce } from '@ember/runloop';
import intersection from 'lodash.intersection';
import { qpBuilder } from 'nomad-ui/utils/classes/query-params';
2017-09-19 14:47:10 +00:00
import Sortable from 'nomad-ui/mixins/sortable';
import Searchable from 'nomad-ui/mixins/searchable';
import WithNamespaceResetting from 'nomad-ui/mixins/with-namespace-resetting';
import { serialize, deserializedQueryParam as selection } from 'nomad-ui/utils/qp-serialize';
import classic from 'ember-classic-decorator';
2017-09-19 14:47:10 +00:00
@classic
export default class TaskGroupController extends Controller.extend(
2021-12-28 14:45:20 +00:00
Sortable,
Searchable,
WithNamespaceResetting
) {
@service userSettings;
2020-06-29 22:53:52 +00:00
@service can;
queryParams = [
{
currentPage: 'page',
},
{
searchTerm: 'search',
},
{
sortProperty: 'sort',
},
{
sortDescending: 'desc',
},
{
qpStatus: 'status',
},
{
qpClient: 'client',
},
];
2017-09-19 14:47:10 +00:00
currentPage = 1;
@readOnly('userSettings.pageSize') pageSize;
2017-09-19 14:47:10 +00:00
qpStatus = '';
qpClient = '';
sortProperty = 'modifyIndex';
sortDescending = true;
2017-09-19 14:47:10 +00:00
@computed
get searchProps() {
return ['shortId', 'name'];
}
2017-09-19 14:47:10 +00:00
@computed('model.allocations.[]')
get allocations() {
return this.get('model.allocations') || [];
}
@computed('allocations.[]', 'selectionStatus', 'selectionClient')
get filteredAllocations() {
const { selectionStatus, selectionClient } = this;
2021-12-28 14:45:20 +00:00
return this.allocations.filter((alloc) => {
if (selectionStatus.length && !selectionStatus.includes(alloc.clientStatus)) {
return false;
}
if (selectionClient.length && !selectionClient.includes(alloc.get('node.shortId'))) {
return false;
}
return true;
});
}
@alias('filteredAllocations') listToSort;
@alias('listSorted') listToSearch;
@alias('listSearched') sortedAllocations;
@selection('qpStatus') selectionStatus;
@selection('qpClient') selectionClient;
2021-12-28 14:45:20 +00:00
@computed('model.scaleState.events.@each.time', function () {
2020-07-28 06:18:10 +00:00
const events = get(this, 'model.scaleState.events');
if (events) {
return events.sortBy('time').reverse();
}
return [];
})
sortedScaleEvents;
2021-12-28 14:45:20 +00:00
@computed('sortedScaleEvents.@each.hasCount', function () {
const countEventsCount = this.sortedScaleEvents.filterBy('hasCount').length;
return countEventsCount > 1 && countEventsCount >= this.sortedScaleEvents.length / 2;
})
shouldShowScaleEventTimeline;
@computed('model.job.{namespace,runningDeployment}')
2020-06-29 22:53:52 +00:00
get tooltipText() {
if (this.can.cannot('scale job', null, { namespace: this.model.job.namespace.get('name') }))
return "You aren't allowed to scale task groups";
2020-06-29 22:53:52 +00:00
if (this.model.job.runningDeployment) return 'You cannot scale task groups during a deployment';
return undefined;
}
@action
gotoAllocation(allocation) {
this.transitionToRoute('allocations.allocation', allocation);
}
@action
scaleTaskGroup(count) {
return this.model.scale(count);
}
get optionsAllocationStatus() {
return [
{ key: 'pending', label: 'Pending' },
{ key: 'running', label: 'Running' },
{ key: 'complete', label: 'Complete' },
{ key: 'failed', label: 'Failed' },
{ key: 'lost', label: 'Lost' },
];
}
@computed('model.allocations.[]', 'selectionClient')
get optionsClients() {
const clients = Array.from(new Set(this.model.allocations.mapBy('node.shortId'))).compact();
// Update query param when the list of clients changes.
scheduleOnce('actions', () => {
// eslint-disable-next-line ember/no-side-effects
this.set('qpClient', serialize(intersection(clients, this.selectionClient)));
});
2021-12-28 14:45:20 +00:00
return clients.sort().map((dc) => ({ key: dc, label: dc }));
}
setFacetQueryParam(queryParam, selection) {
this.set(queryParam, serialize(selection));
}
get taskGroup() {
return this.model;
}
get breadcrumb() {
const { job, name } = this.taskGroup;
return {
title: 'Task Group',
label: name,
args: [
'jobs.job.task-group',
job,
name,
qpBuilder({ jobNamespace: job.get('namespace.name') || 'default' }),
],
};
}
}