Commit 48cb4dfe authored by Fernando's avatar Fernando

Implement dynamic fields inside Analyzer component

* Import dynamic fields component
* Add dynamic fields to Analyzer component template
* Catch event, clone, update entity, emit event
parent 81ff89a6
<script> <script>
import { GlFormCheckbox } from '@gitlab/ui'; import { cloneDeep } from 'lodash';
import { GlFormCheckbox, GlFormGroup } from '@gitlab/ui';
import DynamicFields from './dynamic_fields.vue';
import { isValidAnalyzerEntity } from './utils'; import { isValidAnalyzerEntity } from './utils';
export default { export default {
components: { components: {
GlFormGroup,
GlFormCheckbox, GlFormCheckbox,
DynamicFields,
}, },
model: { model: {
prop: 'entity', prop: 'entity',
event: 'input', event: 'input',
}, },
data() {
return {
configurationEntities: cloneDeep(this.entity.configuration),
};
},
props: { props: {
// SastCiConfigurationAnalyzersEntity from GraphQL endpoint // SastCiConfigurationAnalyzersEntity from GraphQL endpoint
entity: { entity: {
...@@ -23,13 +33,21 @@ export default { ...@@ -23,13 +33,21 @@ export default {
const entity = { ...this.entity, enabled: value }; const entity = { ...this.entity, enabled: value };
this.$emit('input', entity); this.$emit('input', entity);
}, },
onConfigurationUpdate(value) {
const entity = { ...this.entity, configuration: formEntities}
this.$emit('input', entity)
}
}, },
}; };
</script> </script>
<template> <template>
<gl-form-group>
<gl-form-checkbox :id="entity.name" :checked="entity.enabled" @input="onToggle"> <gl-form-checkbox :id="entity.name" :checked="entity.enabled" @input="onToggle">
<span class="gl-font-weight-bold">{{ entity.label }}</span> <span class="gl-font-weight-bold">{{ entity.label }}</span>
<span v-if="entity.description" class="gl-text-gray-500">({{ entity.description }})</span> <span v-if="entity.description" class="gl-text-gray-500">({{ entity.description }})</span>
</gl-form-checkbox> </gl-form-checkbox>
<dynamic-fields v-model="configurationEntities" @input="onConfigurationUpdate" />
</gl-form-group>
</template> </template>
...@@ -6,11 +6,18 @@ import { __, s__ } from '~/locale'; ...@@ -6,11 +6,18 @@ import { __, s__ } from '~/locale';
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
import { redirectTo } from '~/lib/utils/url_utility'; import { redirectTo } from '~/lib/utils/url_utility';
import DynamicFields from './dynamic_fields.vue'; import DynamicFields from './dynamic_fields.vue';
// START TODO: Only for debugging
import AnalyzerConfiguration from './analyzer_configuration.vue';
// END TODO
import { isValidConfigurationEntity } from './utils'; import { isValidConfigurationEntity } from './utils';
import analyzer_configurationVue from './analyzer_configuration.vue';
export default { export default {
components: { components: {
DynamicFields, DynamicFields,
// START TODO: Only for debugging
AnalyzerConfiguration,
// END TODO
GlAlert, GlAlert,
GlButton, GlButton,
}, },
...@@ -34,6 +41,17 @@ export default { ...@@ -34,6 +41,17 @@ export default {
data() { data() {
return { return {
formEntities: cloneDeep(this.entities), formEntities: cloneDeep(this.entities),
// START TODO: Only for debugging
analyzerEntity: {
name: 'name',
label: 'label',
description: 'description',
enabled: true,
configuration: [{
defaultValue:'def', description: 'desc', field:'foo', type: 'string', value:'val', label: 'label'
}]
},
// END TODO
hasSubmissionError: false, hasSubmissionError: false,
isSubmitting: false, isSubmitting: false,
}; };
...@@ -81,6 +99,10 @@ export default { ...@@ -81,6 +99,10 @@ export default {
<form @submit.prevent="onSubmit"> <form @submit.prevent="onSubmit">
<dynamic-fields v-model="formEntities" /> <dynamic-fields v-model="formEntities" />
<!-- START TODO: Only for debugging -->
<analyzer-configuration v-model="analyzerEntity" />
<!-- END TODO -->
<hr /> <hr />
<gl-alert v-if="hasSubmissionError" class="gl-mb-5" variant="danger" :dismissible="false">{{ <gl-alert v-if="hasSubmissionError" class="gl-mb-5" variant="danger" :dismissible="false">{{
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment