debian-mirror-gitlab/app/assets/javascripts/whats_new/components/app.vue

140 lines
3.6 KiB
Vue
Raw Normal View History

2020-10-24 23:57:45 +05:30
<script>
import { mapState, mapActions } from 'vuex';
2021-01-29 00:20:46 +05:30
import {
GlDrawer,
GlInfiniteScroll,
GlResizeObserverDirective,
2021-02-22 17:27:13 +05:30
GlTabs,
GlTab,
GlBadge,
GlLoadingIcon,
2021-01-29 00:20:46 +05:30
} from '@gitlab/ui';
2021-01-03 14:25:43 +05:30
import SkeletonLoader from './skeleton_loader.vue';
2021-02-22 17:27:13 +05:30
import Feature from './feature.vue';
2021-01-03 14:25:43 +05:30
import Tracking from '~/tracking';
2021-01-29 00:20:46 +05:30
import { getDrawerBodyHeight } from '../utils/get_drawer_body_height';
2021-01-03 14:25:43 +05:30
const trackingMixin = Tracking.mixin();
2020-10-24 23:57:45 +05:30
export default {
components: {
GlDrawer,
2021-01-29 00:20:46 +05:30
GlInfiniteScroll,
2021-02-22 17:27:13 +05:30
GlTabs,
GlTab,
2021-01-03 14:25:43 +05:30
SkeletonLoader,
2021-02-22 17:27:13 +05:30
Feature,
GlBadge,
GlLoadingIcon,
2020-11-24 15:15:51 +05:30
},
2021-01-29 00:20:46 +05:30
directives: {
GlResizeObserver: GlResizeObserverDirective,
},
2021-01-03 14:25:43 +05:30
mixins: [trackingMixin],
2020-11-24 15:15:51 +05:30
props: {
2021-01-03 14:25:43 +05:30
storageKey: {
2020-11-24 15:15:51 +05:30
type: String,
2021-01-03 14:25:43 +05:30
required: true,
2021-02-22 17:27:13 +05:30
},
versions: {
type: Array,
required: true,
},
gitlabDotCom: {
type: Boolean,
required: false,
default: false,
2020-11-24 15:15:51 +05:30
},
2020-10-24 23:57:45 +05:30
},
computed: {
2021-02-22 17:27:13 +05:30
...mapState(['open', 'features', 'pageInfo', 'drawerBodyHeight', 'fetching']),
2020-11-24 15:15:51 +05:30
},
mounted() {
2021-01-03 14:25:43 +05:30
this.openDrawer(this.storageKey);
this.fetchItems();
const body = document.querySelector('body');
const namespaceId = body.getAttribute('data-namespace-id');
this.track('click_whats_new_drawer', { label: 'namespace_id', value: namespaceId });
2020-10-24 23:57:45 +05:30
},
methods: {
2021-01-29 00:20:46 +05:30
...mapActions(['openDrawer', 'closeDrawer', 'fetchItems', 'setDrawerBodyHeight']),
bottomReached() {
2021-02-22 17:27:13 +05:30
const page = this.pageInfo.nextPage;
if (page) {
this.fetchItems({ page });
2021-01-29 00:20:46 +05:30
}
},
handleResize() {
const height = getDrawerBodyHeight(this.$refs.drawer.$el);
this.setDrawerBodyHeight(height);
},
2021-02-22 17:27:13 +05:30
featuresForVersion(version) {
return this.features.filter(feature => {
return feature.release === parseFloat(version);
});
},
fetchVersion(version) {
if (this.featuresForVersion(version).length === 0) {
this.fetchItems({ version });
}
},
2020-10-24 23:57:45 +05:30
},
};
</script>
<template>
<div>
2021-01-29 00:20:46 +05:30
<gl-drawer
ref="drawer"
v-gl-resize-observer="handleResize"
class="whats-new-drawer"
:open="open"
@close="closeDrawer"
>
2020-10-24 23:57:45 +05:30
<template #header>
2021-01-29 00:20:46 +05:30
<h4 class="page-title gl-my-2">{{ __("What's new at GitLab") }}</h4>
2020-10-24 23:57:45 +05:30
</template>
2021-02-22 17:27:13 +05:30
<template v-if="features.length">
<gl-infinite-scroll
v-if="gitlabDotCom"
:fetched-items="features.length"
:max-list-height="drawerBodyHeight"
class="gl-p-0"
@bottomReached="bottomReached"
>
<template #items>
<feature v-for="feature in features" :key="feature.title" :feature="feature" />
</template>
</gl-infinite-scroll>
<gl-tabs v-else :style="{ height: `${drawerBodyHeight}px` }" class="gl-p-0">
<gl-tab
v-for="(version, index) in versions"
:key="version"
@click="fetchVersion(version)"
2021-01-29 00:20:46 +05:30
>
2021-02-22 17:27:13 +05:30
<template #title>
<span>{{ version }}</span>
<gl-badge v-if="index === 0">{{ __('Your Version') }}</gl-badge>
</template>
<gl-loading-icon v-if="fetching" size="lg" class="text-center" />
<template v-else>
<feature
v-for="feature in featuresForVersion(version)"
:key="feature.title"
:feature="feature"
2021-01-03 14:25:43 +05:30
/>
2021-02-22 17:27:13 +05:30
</template>
</gl-tab>
</gl-tabs>
</template>
2021-01-29 00:20:46 +05:30
<div v-else class="gl-mt-5">
<skeleton-loader />
<skeleton-loader />
2020-11-24 15:15:51 +05:30
</div>
2020-10-24 23:57:45 +05:30
</gl-drawer>
2021-01-03 14:25:43 +05:30
<div v-if="open" class="whats-new-modal-backdrop modal-backdrop"></div>
2020-10-24 23:57:45 +05:30
</div>
</template>