From e49c62ce936158f10d1036a2590c5d70fdeb7bf1 Mon Sep 17 00:00:00 2001 From: bton Date: Wed, 27 Nov 2024 22:01:31 +0100 Subject: [PATCH] The Comment button is now disabled when there is no text and the AsyncButton can now be disabled without setting it to inProgress --- web/src/components/Timeline.vue | 2 +- web/src/components/inputs/AsyncButton.vue | 20 ++++++++++++-------- web/src/views/Ticket.vue | 2 +- 3 files changed, 14 insertions(+), 10 deletions(-) diff --git a/web/src/components/Timeline.vue b/web/src/components/Timeline.vue index 41e1274..0099c03 100644 --- a/web/src/components/Timeline.vue +++ b/web/src/components/Timeline.vue @@ -203,4 +203,4 @@ a { } - \ No newline at end of file + diff --git a/web/src/components/inputs/AsyncButton.vue b/web/src/components/inputs/AsyncButton.vue index 833f964..6ae298f 100644 --- a/web/src/components/inputs/AsyncButton.vue +++ b/web/src/components/inputs/AsyncButton.vue @@ -1,9 +1,9 @@ @@ -13,7 +13,7 @@ export default { name: 'AsyncButton', data() { return { - disabled: false, + inProgress: false, }; }, props: { @@ -21,17 +21,21 @@ export default { type: Function, required: true, }, + disabled: { + type: Boolean, + required: false, + }, }, methods: { async handleClick() { if (this.task && typeof this.task === 'function') { - this.disabled = true; + this.inProgress = true; try { await this.task(); } catch (e) { console.error(e); } finally { - this.disabled = false; + this.inProgress = false; } } }, @@ -43,4 +47,4 @@ export default { .spinner-border { vertical-align: -0.125em; } - \ No newline at end of file + diff --git a/web/src/views/Ticket.vue b/web/src/views/Ticket.vue index dd0b413..4921a74 100644 --- a/web/src/views/Ticket.vue +++ b/web/src/views/Ticket.vue @@ -17,7 +17,7 @@ - + Save Comment