57 lines
1.2 KiB
Vue
57 lines
1.2 KiB
Vue
<script>
|
|
import { mapGetters, mapActions, mapState } from 'vuex';
|
|
import modal from '../../vue_shared/components/modal.vue';
|
|
|
|
export default {
|
|
components: {
|
|
modal,
|
|
},
|
|
computed: {
|
|
...mapState([
|
|
'editMode',
|
|
'discardPopupOpen',
|
|
]),
|
|
...mapGetters([
|
|
'canEditFile',
|
|
]),
|
|
buttonLabel() {
|
|
return this.editMode ? this.__('Cancel edit') : this.__('Edit');
|
|
},
|
|
},
|
|
methods: {
|
|
...mapActions([
|
|
'toggleEditMode',
|
|
'closeDiscardPopup',
|
|
]),
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div class="editable-mode">
|
|
<button
|
|
v-if="canEditFile"
|
|
class="btn btn-default"
|
|
type="button"
|
|
@click.prevent="toggleEditMode()">
|
|
<i
|
|
v-if="!editMode"
|
|
class="fa fa-pencil"
|
|
aria-hidden="true">
|
|
</i>
|
|
<span>
|
|
{{ buttonLabel }}
|
|
</span>
|
|
</button>
|
|
<modal
|
|
v-if="discardPopupOpen"
|
|
class="text-left"
|
|
:primary-button-label="__('Discard changes')"
|
|
kind="warning"
|
|
:title="__('Are you sure?')"
|
|
:text="__('Are you sure you want to discard your changes?')"
|
|
@cancel="closeDiscardPopup"
|
|
@submit="toggleEditMode(true)"
|
|
/>
|
|
</div>
|
|
</template>
|