debian-mirror-gitlab/app/assets/javascripts/vue_shared/components/select2_select.vue

49 lines
1 KiB
Vue
Raw Normal View History

2019-07-07 11:18:12 +05:30
<script>
import $ from 'jquery';
2019-07-31 22:56:46 +05:30
import 'select2';
2021-02-22 17:27:13 +05:30
import { loadCSSFile } from '~/lib/utils/css_utils';
2019-07-07 11:18:12 +05:30
export default {
2019-10-12 21:52:04 +05:30
// False positive i18n lint: https://gitlab.com/gitlab-org/frontend/eslint-plugin-i18n/issues/26
2020-04-22 19:07:51 +05:30
// eslint-disable-next-line @gitlab/require-i18n-strings
2019-07-07 11:18:12 +05:30
name: 'Select2Select',
props: {
options: {
type: Object,
required: false,
default: () => ({}),
},
value: {
type: String,
required: false,
default: '',
},
},
2021-04-17 20:07:23 +05:30
watch: {
value() {
$(this.$refs.dropdownInput).val(this.value).trigger('change');
},
},
2019-07-07 11:18:12 +05:30
mounted() {
2021-02-22 17:27:13 +05:30
loadCSSFile(gon.select2_css_path)
.then(() => {
$(this.$refs.dropdownInput)
.val(this.value)
.select2(this.options)
2021-03-08 18:12:59 +05:30
.on('change', (event) => this.$emit('input', event.target.value));
2021-02-22 17:27:13 +05:30
})
.catch(() => {});
2019-07-07 11:18:12 +05:30
},
beforeDestroy() {
$(this.$refs.dropdownInput).select2('destroy');
},
};
</script>
<template>
<input ref="dropdownInput" type="hidden" />
</template>