61 lines
1.7 KiB
JavaScript
61 lines
1.7 KiB
JavaScript
import { computed } from '@ember/object';
|
|
import { alias, none, and } from '@ember/object/computed';
|
|
import Fragment from 'ember-data-model-fragments/fragment';
|
|
import attr from 'ember-data/attr';
|
|
import { fragment, fragmentOwner, fragmentArray } from 'ember-data-model-fragments/attributes';
|
|
import classic from 'ember-classic-decorator';
|
|
|
|
@classic
|
|
export default class TaskState extends Fragment {
|
|
@fragmentOwner() allocation;
|
|
|
|
@attr('string') name;
|
|
@attr('string') state;
|
|
@attr('date') startedAt;
|
|
@attr('date') finishedAt;
|
|
@attr('boolean') failed;
|
|
|
|
@none('finishedAt') isActive;
|
|
@and('isActive', 'allocation.isRunning') isRunning;
|
|
|
|
@computed('task.kind')
|
|
get isConnectProxy() {
|
|
return (this.get('task.kind') || '').startsWith('connect-proxy:');
|
|
}
|
|
|
|
@computed('name', 'allocation.taskGroup.tasks.[]')
|
|
get task() {
|
|
const tasks = this.get('allocation.taskGroup.tasks');
|
|
return tasks && tasks.findBy('name', this.name);
|
|
}
|
|
|
|
@alias('task.driver') driver;
|
|
|
|
// TaskState represents a task running on a node, so in addition to knowing the
|
|
// driver via the task, the health of the driver is also known via the node
|
|
@computed('task.driver', 'allocation.node.drivers.[]')
|
|
get driverStatus() {
|
|
const nodeDrivers = this.get('allocation.node.drivers') || [];
|
|
return nodeDrivers.findBy('name', this.get('task.driver'));
|
|
}
|
|
|
|
@fragment('resources') resources;
|
|
@fragmentArray('task-event') events;
|
|
|
|
@computed('state')
|
|
get stateClass() {
|
|
const classMap = {
|
|
pending: 'is-pending',
|
|
running: 'is-primary',
|
|
finished: 'is-complete',
|
|
failed: 'is-error',
|
|
};
|
|
|
|
return classMap[this.state] || 'is-dark';
|
|
}
|
|
|
|
restart() {
|
|
return this.allocation.restart(this.name);
|
|
}
|
|
}
|