2020-05-07 08:09:46 -04:00
|
|
|
<script>
|
2020-07-28 08:09:49 -04:00
|
|
|
import { GlButton, GlModal, GlModalDirective } from '@gitlab/ui';
|
2020-05-07 08:09:46 -04:00
|
|
|
import { uniqueId } from 'lodash';
|
2020-08-14 02:10:12 -04:00
|
|
|
import { s__, __ } from '~/locale';
|
2020-05-07 08:09:46 -04:00
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'DeleteButton',
|
|
|
|
components: {
|
2020-07-28 08:09:49 -04:00
|
|
|
GlButton,
|
2020-05-07 08:09:46 -04:00
|
|
|
GlModal,
|
|
|
|
},
|
|
|
|
directives: {
|
|
|
|
GlModalDirective,
|
|
|
|
},
|
|
|
|
props: {
|
|
|
|
isDeleting: {
|
|
|
|
type: Boolean,
|
|
|
|
required: false,
|
|
|
|
default: false,
|
|
|
|
},
|
|
|
|
buttonClass: {
|
|
|
|
type: String,
|
|
|
|
required: false,
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
buttonVariant: {
|
|
|
|
type: String,
|
|
|
|
required: false,
|
2020-07-28 08:09:49 -04:00
|
|
|
default: 'info',
|
|
|
|
},
|
2020-08-14 02:10:12 -04:00
|
|
|
buttonCategory: {
|
|
|
|
type: String,
|
|
|
|
required: false,
|
|
|
|
default: 'primary',
|
|
|
|
},
|
|
|
|
buttonIcon: {
|
|
|
|
type: String,
|
|
|
|
required: false,
|
|
|
|
default: undefined,
|
|
|
|
},
|
2020-07-28 08:09:49 -04:00
|
|
|
buttonSize: {
|
|
|
|
type: String,
|
|
|
|
required: false,
|
|
|
|
default: 'medium',
|
2020-05-07 08:09:46 -04:00
|
|
|
},
|
|
|
|
hasSelectedDesigns: {
|
|
|
|
type: Boolean,
|
|
|
|
required: false,
|
|
|
|
default: true,
|
|
|
|
},
|
2020-08-14 02:10:12 -04:00
|
|
|
loading: {
|
|
|
|
type: Boolean,
|
|
|
|
required: false,
|
|
|
|
default: false,
|
|
|
|
},
|
2020-05-07 08:09:46 -04:00
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
modalId: uniqueId('design-deletion-confirmation-'),
|
|
|
|
};
|
|
|
|
},
|
2020-07-28 08:09:49 -04:00
|
|
|
modal: {
|
2020-08-14 02:10:12 -04:00
|
|
|
title: s__('DesignManagement|Are you sure you want to archive the selected designs?'),
|
2020-07-28 08:09:49 -04:00
|
|
|
actionPrimary: {
|
2020-08-14 02:10:12 -04:00
|
|
|
text: s__('DesignManagement|Archive designs'),
|
2020-09-28 14:09:40 -04:00
|
|
|
attributes: { variant: 'warning', 'data-qa-selector': 'confirm_archiving_button' },
|
2020-07-28 08:09:49 -04:00
|
|
|
},
|
|
|
|
actionCancel: {
|
2020-08-14 02:10:12 -04:00
|
|
|
text: __('Cancel'),
|
2020-07-28 08:09:49 -04:00
|
|
|
},
|
|
|
|
},
|
2020-05-07 08:09:46 -04:00
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
2021-03-03 13:11:16 -05:00
|
|
|
<div>
|
2020-05-07 08:09:46 -04:00
|
|
|
<gl-modal
|
|
|
|
:modal-id="modalId"
|
2020-07-28 08:09:49 -04:00
|
|
|
:title="$options.modal.title"
|
|
|
|
:action-primary="$options.modal.actionPrimary"
|
|
|
|
:action-cancel="$options.modal.actionCancel"
|
2021-03-03 13:11:16 -05:00
|
|
|
@ok="$emit('delete-selected-designs')"
|
2020-05-07 08:09:46 -04:00
|
|
|
>
|
2021-03-03 13:11:16 -05:00
|
|
|
{{
|
|
|
|
s__(
|
|
|
|
'DesignManagement|Archived designs will still be available in previous versions of the design collection.',
|
|
|
|
)
|
|
|
|
}}
|
2020-05-07 08:09:46 -04:00
|
|
|
</gl-modal>
|
2020-07-28 08:09:49 -04:00
|
|
|
<gl-button
|
2020-05-07 08:09:46 -04:00
|
|
|
v-gl-modal-directive="modalId"
|
|
|
|
:variant="buttonVariant"
|
2020-08-14 02:10:12 -04:00
|
|
|
:category="buttonCategory"
|
2020-07-28 08:09:49 -04:00
|
|
|
:size="buttonSize"
|
2020-05-07 08:09:46 -04:00
|
|
|
:class="buttonClass"
|
2020-08-14 02:10:12 -04:00
|
|
|
:loading="loading"
|
|
|
|
:icon="buttonIcon"
|
2020-08-19 05:09:58 -04:00
|
|
|
:disabled="isDeleting || !hasSelectedDesigns"
|
2020-08-24 23:10:50 -04:00
|
|
|
><slot></slot
|
|
|
|
></gl-button>
|
2020-05-07 08:09:46 -04:00
|
|
|
</div>
|
|
|
|
</template>
|