debian-mirror-gitlab/app/assets/javascripts/nav/components/new_nav_toggle.vue
2023-03-04 22:38:38 +05:30

71 lines
1.7 KiB
Vue

<script>
import { GlBadge, GlToggle } from '@gitlab/ui';
import axios from '~/lib/utils/axios_utils';
import { createAlert } from '~/flash';
import { s__ } from '~/locale';
export default {
i18n: {
badgeLabel: s__('NorthstarNavigation|Alpha'),
sectionTitle: s__('NorthstarNavigation|Navigation redesign'),
toggleMenuItemLabel: s__('NorthstarNavigation|New navigation'),
toggleLabel: s__('NorthstarNavigation|Toggle new navigation'),
updateError: s__(
'NorthstarNavigation|Could not update the new navigation preference. Please try again later.',
),
},
components: {
GlBadge,
GlToggle,
},
props: {
enabled: {
type: Boolean,
required: true,
},
endpoint: {
type: String,
required: true,
},
},
data() {
return {
isEnabled: this.enabled,
};
},
methods: {
async toggleNav() {
try {
await axios.put(this.endpoint, { user: { use_new_navigation: !this.enabled } });
window.location.reload();
} catch (error) {
createAlert({
message: this.$options.i18n.updateError,
error,
});
}
},
},
};
</script>
<template>
<li>
<div
class="gl-px-4 gl-py-2 gl-display-flex gl-justify-content-space-between gl-align-items-center"
>
<b>{{ $options.i18n.sectionTitle }}</b>
<gl-badge>{{ $options.i18n.badgeLabel }}</gl-badge>
</div>
<div class="menu-item gl-display-flex! gl-justify-content-space-between gl-align-items-center">
{{ $options.i18n.toggleMenuItemLabel }}
<gl-toggle
v-model="isEnabled"
:label="$options.i18n.toggleLabel"
label-position="hidden"
@change="toggleNav"
/>
</div>
</li>
</template>