diff options
Diffstat (limited to 'app/assets/javascripts/nav/components/new_nav_toggle.vue')
-rw-r--r-- | app/assets/javascripts/nav/components/new_nav_toggle.vue | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/app/assets/javascripts/nav/components/new_nav_toggle.vue b/app/assets/javascripts/nav/components/new_nav_toggle.vue index ef59140115d..7b0076cc5d4 100644 --- a/app/assets/javascripts/nav/components/new_nav_toggle.vue +++ b/app/assets/javascripts/nav/components/new_nav_toggle.vue @@ -3,6 +3,7 @@ import { GlBadge, GlToggle } from '@gitlab/ui'; import axios from '~/lib/utils/axios_utils'; import { createAlert } from '~/flash'; import { s__ } from '~/locale'; +import Tracking from '~/tracking'; export default { i18n: { @@ -34,9 +35,19 @@ export default { }; }, methods: { - async toggleNav() { + toggleNav() { + this.isEnabled = !this.isEnabled; + this.updateAndReload(); + }, + async updateAndReload() { try { - await axios.put(this.endpoint, { user: { use_new_navigation: !this.enabled } }); + await axios.put(this.endpoint, { user: { use_new_navigation: this.isEnabled } }); + + Tracking.event(undefined, 'click_toggle', { + label: this.enabled ? 'disable_new_nav_beta' : 'enable_new_nav_beta', + property: 'navigation', + }); + window.location.reload(); } catch (error) { createAlert({ @@ -55,17 +66,15 @@ export default { 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> + <gl-badge variant="info">{{ $options.i18n.badgeLabel }}</gl-badge> </div> - <div class="menu-item gl-display-flex! gl-justify-content-space-between gl-align-items-center"> + <div + class="menu-item gl-cursor-pointer gl-display-flex! gl-justify-content-space-between gl-align-items-center" + @click.prevent.stop="toggleNav" + > {{ $options.i18n.toggleMenuItemLabel }} - <gl-toggle - v-model="isEnabled" - :label="$options.i18n.toggleLabel" - label-position="hidden" - @change="toggleNav" - /> + <gl-toggle :value="isEnabled" :label="$options.i18n.toggleLabel" label-position="hidden" /> </div> </li> </template> |