Commit 85934c49 authored by Justin Ho's avatar Justin Ho

Add updating of labels from mock API

- Include a loading state while the labels are updated
- Fix Jira status getting updated when labels are changed
parent 6d1e7cc5
...@@ -16,11 +16,22 @@ export const fetchIssueStatuses = () => { ...@@ -16,11 +16,22 @@ export const fetchIssueStatuses = () => {
}); });
}; };
export const updateIssue = (issue, { status }) => { export const updateIssue = (issue, { labels = [], status = undefined }) => {
// We are using mock call here which should become a backend call // We are using mock call here which should become a backend call
return new Promise((resolve) => { return new Promise((resolve) => {
setTimeout(() => { setTimeout(() => {
resolve({ ...issue, status }); const addedLabels = labels.filter((label) => label.set);
const removedLabelsIds = labels.filter((label) => !label.set).map((label) => label.id);
const finalLabels = [...issue.labels, ...addedLabels].filter(
(label) => !removedLabelsIds.includes(label.id),
);
resolve({
...issue,
...(status ? { status } : {}),
labels: finalLabels,
});
}, 1000); }, 1000);
}); });
}; };
...@@ -41,6 +41,7 @@ export default { ...@@ -41,6 +41,7 @@ export default {
return { return {
isLoading: true, isLoading: true,
isLoadingStatus: false, isLoadingStatus: false,
isUpdatingLabels: false,
isUpdatingStatus: false, isUpdatingStatus: false,
errorMessage: null, errorMessage: null,
issue: {}, issue: {},
...@@ -84,6 +85,23 @@ export default { ...@@ -84,6 +85,23 @@ export default {
return `jira_note_${id}`; return `jira_note_${id}`;
}, },
onIssueLabelsUpdated(labels) {
this.isUpdatingLabels = true;
updateIssue(this.issue, { labels })
.then((response) => {
this.issue = response;
})
.catch(() => {
createFlash({
message: s__(
'JiraService|Failed to update Jira issue labels. View the issue in Jira, or reload the page.',
),
});
})
.finally(() => {
this.isUpdatingLabels = false;
});
},
onIssueStatusFetch() { onIssueStatusFetch() {
this.isLoadingStatus = true; this.isLoadingStatus = true;
fetchIssueStatuses() fetchIssueStatuses()
...@@ -104,8 +122,8 @@ export default { ...@@ -104,8 +122,8 @@ export default {
onIssueStatusUpdated(status) { onIssueStatusUpdated(status) {
this.isUpdatingStatus = true; this.isUpdatingStatus = true;
updateIssue(this.issue, { status }) updateIssue(this.issue, { status })
.then(() => { .then((response) => {
this.issue = { ...this.issue, status }; this.issue = response;
}) })
.catch(() => { .catch(() => {
createFlash({ createFlash({
...@@ -161,8 +179,10 @@ export default { ...@@ -161,8 +179,10 @@ export default {
:sidebar-expanded="sidebarExpanded" :sidebar-expanded="sidebarExpanded"
:issue="issue" :issue="issue"
:is-loading-status="isLoadingStatus" :is-loading-status="isLoadingStatus"
:is-updating-labels="isUpdatingLabels"
:is-updating-status="isUpdatingStatus" :is-updating-status="isUpdatingStatus"
:statuses="statuses" :statuses="statuses"
@issue-labels-updated="onIssueLabelsUpdated"
@issue-status-fetch="onIssueStatusFetch" @issue-status-fetch="onIssueStatusFetch"
@issue-status-updated="onIssueStatusUpdated" @issue-status-updated="onIssueStatusUpdated"
/> />
......
...@@ -40,6 +40,11 @@ export default { ...@@ -40,6 +40,11 @@ export default {
required: false, required: false,
default: false, default: false,
}, },
isUpdatingLabels: {
type: Boolean,
required: false,
default: false,
},
isUpdatingStatus: { isUpdatingStatus: {
type: Boolean, type: Boolean,
required: false, required: false,
...@@ -99,6 +104,9 @@ export default { ...@@ -99,6 +104,9 @@ export default {
); );
} }
}, },
onIssueLabelsUpdated(labels) {
this.$emit('issue-labels-updated', labels);
},
onIssueStatusFetch() { onIssueStatusFetch() {
this.$emit('issue-status-fetch'); this.$emit('issue-status-fetch');
}, },
...@@ -134,8 +142,10 @@ export default { ...@@ -134,8 +142,10 @@ export default {
:labels-fetch-path="issueLabelsPath" :labels-fetch-path="issueLabelsPath"
:labels-filter-base-path="issuesListPath" :labels-filter-base-path="issuesListPath"
:labels-filter-param="$options.labelsFilterParam" :labels-filter-param="$options.labelsFilterParam"
:labels-select-in-progress="isUpdatingLabels"
variant="sidebar" variant="sidebar"
class="block labels js-labels-block" class="block labels js-labels-block"
@updateSelectedLabels="onIssueLabelsUpdated"
> >
{{ __('None') }} {{ __('None') }}
</labels-select> </labels-select>
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment