debian-mirror-gitlab/app/assets/javascripts/sidebar/components/sidebar_editable_item.vue

119 lines
2.8 KiB
Vue
Raw Normal View History

2021-03-11 19:13:27 +05:30
<script>
import { GlButton, GlLoadingIcon } from '@gitlab/ui';
export default {
components: { GlButton, GlLoadingIcon },
2021-04-17 20:07:23 +05:30
inject: {
canUpdate: {},
isClassicSidebar: {
default: false,
},
},
2021-03-11 19:13:27 +05:30
props: {
title: {
type: String,
required: false,
default: '',
},
loading: {
type: Boolean,
required: false,
default: false,
},
2021-04-17 20:07:23 +05:30
tracking: {
type: Object,
required: false,
default: () => ({
event: null,
label: null,
property: null,
}),
},
2021-03-11 19:13:27 +05:30
},
data() {
return {
edit: false,
};
},
destroyed() {
window.removeEventListener('click', this.collapseWhenOffClick);
window.removeEventListener('keyup', this.collapseOnEscape);
},
methods: {
collapseWhenOffClick({ target }) {
if (!this.$el.contains(target)) {
this.collapse();
}
},
collapseOnEscape({ key }) {
if (key === 'Escape') {
this.collapse();
}
},
expand() {
if (this.edit) {
return;
}
this.edit = true;
this.$emit('open');
window.addEventListener('click', this.collapseWhenOffClick);
window.addEventListener('keyup', this.collapseOnEscape);
},
collapse({ emitEvent = true } = {}) {
if (!this.edit) {
return;
}
this.edit = false;
if (emitEvent) {
this.$emit('close');
}
window.removeEventListener('click', this.collapseWhenOffClick);
window.removeEventListener('keyup', this.collapseOnEscape);
},
toggle({ emitEvent = true } = {}) {
if (this.edit) {
this.collapse({ emitEvent });
} else {
this.expand();
}
},
},
};
</script>
<template>
<div>
2021-04-17 20:07:23 +05:30
<div class="gl-display-flex gl-align-items-center" @click.self="collapse">
<span class="hide-collapsed" data-testid="title">{{ title }}</span>
<gl-loading-icon v-if="loading" inline class="gl-ml-2 hide-collapsed" />
<gl-loading-icon
v-if="loading && isClassicSidebar"
inline
class="gl-mx-auto gl-my-0 hide-expanded"
/>
2021-03-11 19:13:27 +05:30
<gl-button
v-if="canUpdate"
variant="link"
2021-04-17 20:07:23 +05:30
class="gl-text-gray-900! gl-hover-text-blue-800! gl-ml-auto hide-collapsed"
2021-03-11 19:13:27 +05:30
data-testid="edit-button"
2021-04-17 20:07:23 +05:30
:data-track-event="tracking.event"
:data-track-label="tracking.label"
:data-track-property="tracking.property"
data-qa-selector="edit_link"
2021-03-11 19:13:27 +05:30
@keyup.esc="toggle"
@click="toggle"
>
{{ __('Edit') }}
</gl-button>
</div>
2021-04-17 20:07:23 +05:30
<div v-show="!edit" data-testid="collapsed-content">
2021-03-11 19:13:27 +05:30
<slot name="collapsed">{{ __('None') }}</slot>
</div>
2021-04-17 20:07:23 +05:30
<div v-show="edit" data-testid="expanded-content" :class="{ 'gl-mt-3': !isClassicSidebar }">
2021-03-11 19:13:27 +05:30
<slot :edit="edit"></slot>
</div>
</div>
</template>