Welcome to mirror list, hosted at ThFree Co, Russian Federation.

pagination.vue « incubation « components « vue_shared « javascripts « assets « app - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: b5afe92316a4a79de7a75c2a1afb012d39861925 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
<script>
import { GlKeysetPagination } from '@gitlab/ui';
import { setUrlParams } from '~/lib/utils/url_utility';
import { __ } from '~/locale';

export default {
  name: 'KeysetPagination',
  components: {
    GlKeysetPagination,
  },
  props: {
    startCursor: {
      type: String,
      required: false,
      default: '',
    },
    endCursor: {
      type: String,
      required: false,
      default: '',
    },
    hasNextPage: {
      type: Boolean,
      required: true,
    },
    hasPreviousPage: {
      type: Boolean,
      required: true,
    },
  },
  computed: {
    previousPageLink() {
      return setUrlParams({ cursor: this.startCursor });
    },
    nextPageLink() {
      return setUrlParams({ cursor: this.endCursor });
    },
    isPaginationVisible() {
      return this.hasPreviousPage || this.hasNextPage;
    },
  },
  i18n: {
    previousPageButtonLabel: __('Prev'),
    nextPageButtonLabel: __('Next'),
  },
};
</script>

<template>
  <div v-if="isPaginationVisible" class="gl--flex-center">
    <gl-keyset-pagination
      :start-cursor="startCursor"
      :end-cursor="endCursor"
      :has-previous-page="hasPreviousPage"
      :has-next-page="hasNextPage"
      :prev-text="$options.i18n.previousPageButtonLabel"
      :next-text="$options.i18n.nextPageButtonLabel"
      :prev-button-link="previousPageLink"
      :next-button-link="nextPageLink"
    />
  </div>
</template>