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

import_target_cell.vue « components « import_groups « import_entities « javascripts « assets « app - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: ca9ae9447d0da6246f1aba2df74029db2c91b378 (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
<script>
import {
  GlDropdownDivider,
  GlDropdownItem,
  GlDropdownSectionHeader,
  GlFormInput,
} from '@gitlab/ui';
import { s__ } from '~/locale';
import ImportGroupDropdown from '../../components/group_dropdown.vue';
import { getInvalidNameValidationMessage } from '../utils';

export default {
  components: {
    ImportGroupDropdown,
    GlDropdownDivider,
    GlDropdownItem,
    GlDropdownSectionHeader,
    GlFormInput,
  },
  props: {
    group: {
      type: Object,
      required: true,
    },
    availableNamespaces: {
      type: Array,
      required: true,
    },
  },

  computed: {
    fullPath() {
      return this.group.importTarget.targetNamespace.fullPath || s__('BulkImport|No parent');
    },
    invalidNameValidationMessage() {
      return getInvalidNameValidationMessage(this.group.importTarget);
    },
  },
};
</script>

<template>
  <div class="gl-display-flex gl-align-items-stretch">
    <import-group-dropdown
      #default="{ namespaces }"
      :text="fullPath"
      :disabled="!group.flags.isAvailableForImport"
      :namespaces="availableNamespaces"
      toggle-class="gl-rounded-top-right-none! gl-rounded-bottom-right-none!"
      class="gl-h-7 gl-flex-grow-1"
      data-qa-selector="target_namespace_selector_dropdown"
    >
      <gl-dropdown-item @click="$emit('update-target-namespace', { fullPath: '', id: null })">{{
        s__('BulkImport|No parent')
      }}</gl-dropdown-item>
      <template v-if="namespaces.length">
        <gl-dropdown-divider />
        <gl-dropdown-section-header>
          {{ s__('BulkImport|Existing groups') }}
        </gl-dropdown-section-header>
        <gl-dropdown-item
          v-for="ns in namespaces"
          :key="ns.fullPath"
          data-qa-selector="target_group_dropdown_item"
          :data-qa-group-name="ns.fullPath"
          @click="$emit('update-target-namespace', ns)"
        >
          {{ ns.fullPath }}
        </gl-dropdown-item>
      </template>
    </import-group-dropdown>
    <div
      class="gl-h-7 gl-px-3 gl-display-flex gl-align-items-center gl-border-solid gl-border-0 gl-border-t-1 gl-border-b-1 gl-bg-gray-10"
      :class="{
        'gl-text-gray-400 gl-border-gray-100': !group.flags.isAvailableForImport,
        'gl-border-gray-200': group.flags.isAvailableForImport,
      }"
    >
      /
    </div>
    <div class="gl-flex-grow-1">
      <gl-form-input
        class="gl-rounded-top-left-none gl-rounded-bottom-left-none"
        :class="{
          'gl-inset-border-1-gray-200!': group.flags.isAvailableForImport,
          'gl-inset-border-1-gray-100!': !group.flags.isAvailableForImport,
          'is-invalid': group.flags.isInvalid && group.flags.isAvailableForImport,
        }"
        debounce="500"
        :disabled="!group.flags.isAvailableForImport"
        :value="group.importTarget.newName"
        :aria-label="__('New name')"
        @input="$emit('update-new-name', $event)"
      />
      <p
        v-if="group.flags.isAvailableForImport && group.flags.isInvalid"
        class="gl-text-red-500 gl-m-0 gl-mt-2"
      >
        {{ invalidNameValidationMessage }}
      </p>
    </div>
  </div>
</template>