gitlab-org--gitlab-foss/app/assets/javascripts/integrations/edit/components/active_checkbox.vue

47 lines
1.1 KiB
Vue

<script>
import { GlFormGroup, GlFormCheckbox } from '@gitlab/ui';
import { mapGetters, mapState } from 'vuex';
export default {
name: 'ActiveCheckbox',
components: {
GlFormGroup,
GlFormCheckbox,
},
data() {
return {
activated: false,
};
},
computed: {
...mapGetters(['isInheriting', 'propsSource']),
...mapState(['customState']),
disabled() {
return this.isInheriting || this.customState.activateDisabled;
},
},
mounted() {
this.activated = this.propsSource.initialActivated;
this.onChange(this.activated);
},
methods: {
onChange(isChecked) {
this.$emit('toggle-integration-active', isChecked);
},
},
};
</script>
<template>
<gl-form-group :label="__('Enable integration')" label-for="service[active]">
<input name="service[active]" type="hidden" :value="activated || false" />
<gl-form-checkbox
v-model="activated"
class="gl-display-block"
:disabled="disabled"
@change="onChange"
>
{{ __('Active') }}
</gl-form-checkbox>
</gl-form-group>
</template>