debian-mirror-gitlab/app/assets/javascripts/vue_merge_request_widget/components/states/work_in_progress.vue

83 lines
2.1 KiB
Vue
Raw Normal View History

2018-10-15 14:42:47 +05:30
<script>
2018-05-09 12:01:36 +05:30
import $ from 'jquery';
2020-04-22 19:07:51 +05:30
import { GlDeprecatedButton } from '@gitlab/ui';
2020-04-08 14:13:33 +05:30
import { __, s__ } from '~/locale';
2019-12-21 20:55:43 +05:30
import createFlash from '~/flash';
2020-04-08 14:13:33 +05:30
import StatusIcon from '../mr_widget_status_icon.vue';
2017-09-10 17:25:29 +05:30
import tooltip from '../../../vue_shared/directives/tooltip';
2017-08-17 22:00:37 +05:30
import eventHub from '../../event_hub';
export default {
2018-10-15 14:42:47 +05:30
name: 'WorkInProgress',
components: {
2020-04-08 14:13:33 +05:30
StatusIcon,
2020-04-22 19:07:51 +05:30
GlDeprecatedButton,
2017-08-17 22:00:37 +05:30
},
2017-09-10 17:25:29 +05:30
directives: {
tooltip,
},
2018-10-15 14:42:47 +05:30
props: {
mr: { type: Object, required: true },
service: { type: Object, required: true },
},
2017-08-17 22:00:37 +05:30
data() {
return {
isMakingRequest: false,
};
},
2020-04-08 14:13:33 +05:30
computed: {
wipInfoTooltip() {
return s__(
'mrWidget|When this merge request is ready, remove the WIP: prefix from the title to allow it to be merged',
);
},
},
2017-08-17 22:00:37 +05:30
methods: {
2020-04-08 14:13:33 +05:30
handleRemoveWIP() {
2017-08-17 22:00:37 +05:30
this.isMakingRequest = true;
2018-12-13 13:39:08 +05:30
this.service
.removeWIP()
2018-03-17 18:26:18 +05:30
.then(res => res.data)
2018-12-13 13:39:08 +05:30
.then(data => {
2018-03-17 18:26:18 +05:30
eventHub.$emit('UpdateWidgetData', data);
2019-12-21 20:55:43 +05:30
createFlash(__('The merge request can now be merged.'), 'notice');
2017-08-17 22:00:37 +05:30
$('.merge-request .detail-page-description .title').text(this.mr.title);
})
.catch(() => {
this.isMakingRequest = false;
2019-12-21 20:55:43 +05:30
createFlash(__('Something went wrong. Please try again.'));
2017-08-17 22:00:37 +05:30
});
},
},
};
2018-10-15 14:42:47 +05:30
</script>
<template>
<div class="mr-widget-body media">
2019-02-15 15:39:39 +05:30
<status-icon :show-disabled-button="Boolean(mr.removeWIPPath)" status="warning" />
2018-10-15 14:42:47 +05:30
<div class="media-body space-children">
<span class="bold">
2019-09-30 21:07:59 +05:30
{{ __('This is a Work in Progress') }}
2018-10-15 14:42:47 +05:30
<i
v-tooltip
class="fa fa-question-circle"
2020-04-08 14:13:33 +05:30
:title="wipInfoTooltip"
:aria-label="wipInfoTooltip"
2019-02-15 15:39:39 +05:30
>
2018-10-15 14:42:47 +05:30
</i>
</span>
2020-04-22 19:07:51 +05:30
<gl-deprecated-button
2018-10-15 14:42:47 +05:30
v-if="mr.removeWIPPath"
2020-04-08 14:13:33 +05:30
size="sm"
variant="default"
2018-10-15 14:42:47 +05:30
:disabled="isMakingRequest"
2020-04-08 14:13:33 +05:30
:loading="isMakingRequest"
class="js-remove-wip"
@click="handleRemoveWIP"
2019-02-15 15:39:39 +05:30
>
2019-09-30 21:07:59 +05:30
{{ s__('mrWidget|Resolve WIP status') }}
2020-04-22 19:07:51 +05:30
</gl-deprecated-button>
2018-10-15 14:42:47 +05:30
</div>
</div>
</template>