diff --git a/ui/app/controllers/allocations/allocation/task/index.js b/ui/app/controllers/allocations/allocation/task/index.js index c020bc4a2b6..186f6b258f8 100644 --- a/ui/app/controllers/allocations/allocation/task/index.js +++ b/ui/app/controllers/allocations/allocation/task/index.js @@ -1,6 +1,7 @@ import Controller from '@ember/controller'; import { computed } from '@ember/object'; import { alias } from '@ember/object/computed'; +import { task } from 'ember-concurrency'; export default Controller.extend({ network: alias('model.resources.networks.firstObject'), @@ -20,4 +21,25 @@ export default Controller.extend({ ) .sortBy('name'); }), + + error: computed(() => { + // { title, description } + return null; + }), + + onDismiss() { + this.set('error', null); + }, + + restartTask: task(function*() { + try { + yield this.model.restart(); + } catch (err) { + console.log('OOPs', err); + this.set('error', { + title: 'Could Not Restart Task', + description: 'Your ACL token does not grant allocation lifecyle permissions.', + }); + } + }), }); diff --git a/ui/app/templates/allocations/allocation/task/index.hbs b/ui/app/templates/allocations/allocation/task/index.hbs index 518e8e58dc4..9409934ff86 100644 --- a/ui/app/templates/allocations/allocation/task/index.hbs +++ b/ui/app/templates/allocations/allocation/task/index.hbs @@ -1,8 +1,33 @@ {{partial "allocations/allocation/task/subnav"}}
+ {{#if error}} +
+
+
+

{{error.title}}

+

{{error.description}}

+
+
+ +
+
+
+ {{/if}} +

{{model.name}} {{model.state}} + {{#if model.isRunning}} + {{two-step-button + data-test-restart + idleText="Restart" + cancelText="Cancel" + confirmText="Yes, Restart" + confirmationMessage="Are you sure? This will restart the task in-place." + awaitingConfirmation=restartTask.isRunning + disabled=restartTask.isRunning + onConfirm=(perform restartTask)}} + {{/if}}