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

packages_list_app.vue « components « list « packages « javascripts « assets « app - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: ef242ea5f755f1d06bc3accce3f22150ad1a0921 (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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<script>
import { mapActions, mapState } from 'vuex';
import { GlEmptyState, GlTab, GlTabs, GlLink, GlSprintf } from '@gitlab/ui';
import { s__, sprintf } from '~/locale';
import PackageFilter from './packages_filter.vue';
import PackageList from './packages_list.vue';
import PackageSort from './packages_sort.vue';
import { PACKAGE_REGISTRY_TABS } from '../constants';
import PackagesComingSoon from '../coming_soon/packages_coming_soon.vue';

export default {
  components: {
    GlEmptyState,
    GlTab,
    GlTabs,
    GlLink,
    GlSprintf,
    PackageFilter,
    PackageList,
    PackageSort,
    PackagesComingSoon,
  },
  computed: {
    ...mapState({
      emptyListIllustration: state => state.config.emptyListIllustration,
      emptyListHelpUrl: state => state.config.emptyListHelpUrl,
      comingSoon: state => state.config.comingSoon,
      filterQuery: state => state.filterQuery,
      selectedType: state => state.selectedType,
    }),
    tabsToRender() {
      return PACKAGE_REGISTRY_TABS;
    },
  },
  mounted() {
    this.requestPackagesList();
  },
  methods: {
    ...mapActions(['requestPackagesList', 'requestDeletePackage', 'setSelectedType']),
    onPageChanged(page) {
      return this.requestPackagesList({ page });
    },
    onPackageDeleteRequest(item) {
      return this.requestDeletePackage(item);
    },
    tabChanged(index) {
      const selected = PACKAGE_REGISTRY_TABS[index];

      if (selected !== this.selectedType) {
        this.setSelectedType(selected);
        this.requestPackagesList();
      }
    },
    emptyStateTitle({ title, type }) {
      if (this.filterQuery) {
        return s__('PackageRegistry|Sorry, your filter produced no results');
      }

      if (type) {
        return sprintf(s__('PackageRegistry|There are no %{packageType} packages yet'), {
          packageType: title,
        });
      }

      return s__('PackageRegistry|There are no packages yet');
    },
  },
  i18n: {
    widenFilters: s__('PackageRegistry|To widen your search, change or remove the filters above.'),
    noResults: s__(
      'PackageRegistry|Learn how to %{noPackagesLinkStart}publish and share your packages%{noPackagesLinkEnd} with GitLab.',
    ),
  },
};
</script>

<template>
  <gl-tabs @input="tabChanged">
    <template #tabs-end>
      <div class="d-flex align-self-center ml-md-auto py-1 py-md-0">
        <package-filter class="mr-1" @filter="requestPackagesList" />
        <package-sort @sort:changed="requestPackagesList" />
      </div>
    </template>

    <gl-tab v-for="(tab, index) in tabsToRender" :key="index" :title="tab.title">
      <package-list @page:changed="onPageChanged" @package:delete="onPackageDeleteRequest">
        <template #empty-state>
          <gl-empty-state :title="emptyStateTitle(tab)" :svg-path="emptyListIllustration">
            <template #description>
              <gl-sprintf v-if="filterQuery" :message="$options.i18n.widenFilters" />
              <gl-sprintf v-else :message="$options.i18n.noResults">
                <template #noPackagesLink="{content}">
                  <gl-link :href="emptyListHelpUrl" target="_blank">{{ content }}</gl-link>
                </template>
              </gl-sprintf>
            </template>
          </gl-empty-state>
        </template>
      </package-list>
    </gl-tab>

    <gl-tab v-if="comingSoon" :title="__('Coming soon')" lazy>
      <packages-coming-soon
        :illustration="emptyListIllustration"
        :project-path="comingSoon.projectPath"
        :suggested-contributions-path="comingSoon.suggestedContributions"
      />
    </gl-tab>
  </gl-tabs>
</template>