mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-08 02:24:11 +00:00
86 lines
3.2 KiB
TypeScript
86 lines
3.2 KiB
TypeScript
import { DynamicSelectModel, DynamicSelectModelConfig } from '@ng-dynamic-forms/core';
|
|
|
|
import { FieldParser } from './field-parser';
|
|
import {
|
|
DsDynamicQualdropModelConfig,
|
|
DynamicQualdropModel,
|
|
QUALDROP_GROUP_SUFFIX,
|
|
QUALDROP_METADATA_SUFFIX,
|
|
QUALDROP_VALUE_SUFFIX
|
|
} from '../ds-dynamic-form-ui/models/ds-dynamic-qualdrop.model';
|
|
import { FormFieldMetadataValueObject } from '../models/form-field-metadata-value.model';
|
|
import { isNotEmpty } from '../../../empty.util';
|
|
import { DsDynamicInputModel, DsDynamicInputModelConfig } from '../ds-dynamic-form-ui/models/ds-dynamic-input.model';
|
|
import {
|
|
DsDynamicTypeaheadModelConfig,
|
|
DynamicTypeaheadModel
|
|
} from '../ds-dynamic-form-ui/models/typeahead/dynamic-typeahead.model';
|
|
|
|
export class OneboxFieldParser extends FieldParser {
|
|
|
|
public modelFactory(fieldValue?: FormFieldMetadataValueObject | any, label?: boolean): any {
|
|
if (this.configData.selectableMetadata.length > 1) {
|
|
// Case ComboBox
|
|
const clsGroup = {
|
|
element: {
|
|
control: 'form-row',
|
|
}
|
|
};
|
|
|
|
const clsSelect = {
|
|
element: {
|
|
control: 'input-group-addon ds-form-input-addon',
|
|
},
|
|
grid: {
|
|
host: 'col-sm-4 pr-0'
|
|
}
|
|
};
|
|
|
|
const clsInput = {
|
|
element: {
|
|
control: 'ds-form-input-value',
|
|
},
|
|
grid: {
|
|
host: 'col-sm-8 pl-0'
|
|
}
|
|
};
|
|
|
|
const newId = this.configData.selectableMetadata[0].metadata
|
|
.split('.')
|
|
.slice(0, this.configData.selectableMetadata[0].metadata.split('.').length - 1)
|
|
.join('.');
|
|
|
|
const inputSelectGroup: DsDynamicQualdropModelConfig = Object.create(null);
|
|
inputSelectGroup.id = newId.replace(/\./g, '_') + QUALDROP_GROUP_SUFFIX;
|
|
inputSelectGroup.group = [];
|
|
inputSelectGroup.legend = this.configData.label;
|
|
|
|
const selectModelConfig: DynamicSelectModelConfig<any> = this.initModel(newId + QUALDROP_METADATA_SUFFIX, label);
|
|
this.setOptions(selectModelConfig);
|
|
if (isNotEmpty(fieldValue)) {
|
|
selectModelConfig.value = fieldValue.metadata;
|
|
}
|
|
inputSelectGroup.group.push(new DynamicSelectModel(selectModelConfig, clsSelect));
|
|
|
|
const inputModelConfig: DsDynamicInputModelConfig = this.initModel(newId + QUALDROP_VALUE_SUFFIX, label, true);
|
|
this.setValues(inputModelConfig, fieldValue);
|
|
|
|
inputSelectGroup.readOnly = selectModelConfig.disabled && inputModelConfig.readOnly;
|
|
inputSelectGroup.group.push(new DsDynamicInputModel(inputModelConfig, clsInput));
|
|
|
|
return new DynamicQualdropModel(inputSelectGroup, clsGroup);
|
|
} else if (this.configData.selectableMetadata[0].authority) {
|
|
const typeaheadModelConfig: DsDynamicTypeaheadModelConfig = this.initModel(null, label);
|
|
this.setAuthorityOptions(typeaheadModelConfig, this.parserOptions.authorityUuid);
|
|
this.setValues(typeaheadModelConfig, fieldValue, true);
|
|
const typeaheadModel = new DynamicTypeaheadModel(typeaheadModelConfig);
|
|
return typeaheadModel;
|
|
} else {
|
|
const inputModelConfig: DsDynamicInputModelConfig = this.initModel(null, label);
|
|
this.setValues(inputModelConfig, fieldValue);
|
|
const inputModel = new DsDynamicInputModel(inputModelConfig);
|
|
return inputModel;
|
|
}
|
|
}
|
|
}
|