summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/access_tokens/components/projects_field.vue
blob: 066cea5e90cf0619da17da82fdc240e64daf9979 (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
<script>
import { GlFormGroup, GlFormRadio, GlFormText } from '@gitlab/ui';
import ProjectsTokenSelector from './projects_token_selector.vue';

export default {
  name: 'ProjectsField',
  ALL_PROJECTS: 'ALL_PROJECTS',
  SELECTED_PROJECTS: 'SELECTED_PROJECTS',
  components: { GlFormGroup, GlFormRadio, GlFormText, ProjectsTokenSelector },
  props: {
    inputAttrs: {
      type: Object,
      required: true,
    },
  },
  data() {
    return {
      selectedRadio: !this.inputAttrs.value
        ? this.$options.ALL_PROJECTS
        : this.$options.SELECTED_PROJECTS,
      selectedProjects: [],
    };
  },
  computed: {
    allProjectsRadioSelected() {
      return this.selectedRadio === this.$options.ALL_PROJECTS;
    },
    hiddenInputValue() {
      return this.allProjectsRadioSelected
        ? null
        : this.selectedProjects.map((project) => project.id).join(',');
    },
    initialProjectIds() {
      if (!this.inputAttrs.value) {
        return [];
      }

      return this.inputAttrs.value.split(',');
    },
  },
  methods: {
    handleTokenSelectorFocus() {
      this.selectedRadio = this.$options.SELECTED_PROJECTS;
    },
  },
};
</script>

<template>
  <div>
    <gl-form-group :label="__('Projects')" label-class="gl-pb-0!">
      <gl-form-text class="gl-pb-3">{{
        __('Set access permissions for this token.')
      }}</gl-form-text>
      <gl-form-radio v-model="selectedRadio" :value="$options.ALL_PROJECTS">{{
        __('All projects')
      }}</gl-form-radio>
      <gl-form-radio v-model="selectedRadio" :value="$options.SELECTED_PROJECTS">{{
        __('Selected projects')
      }}</gl-form-radio>
      <input :id="inputAttrs.id" type="hidden" :name="inputAttrs.name" :value="hiddenInputValue" />
      <projects-token-selector
        v-model="selectedProjects"
        :initial-project-ids="initialProjectIds"
        @focus="handleTokenSelectorFocus"
      />
    </gl-form-group>
  </div>
</template>