Work in progress on introducing tag language. Not tested yet.
This commit is contained in:
parent
450b930cc5
commit
00e328a914
21 changed files with 2154 additions and 1909 deletions
|
@ -23,7 +23,7 @@ import {withErrorHandling} from '../lib/error-handling';
|
|||
import {NamespaceSelect, validateNamespace} from '../lib/namespace';
|
||||
import {ContentModalDialog, DeleteModalDialog} from "../lib/modals";
|
||||
import mailtrainConfig from 'mailtrainConfig';
|
||||
import {getEditForm, getTemplateTypes, getTypeForm} from './helpers';
|
||||
import {getEditForm, getTagLanguages, getTemplateTypes, getTypeForm} from './helpers';
|
||||
import axios from '../lib/axios';
|
||||
import styles from "../lib/styles.scss";
|
||||
import {getUrl} from "../lib/urls";
|
||||
|
@ -44,6 +44,7 @@ export default class CUD extends Component {
|
|||
super(props);
|
||||
|
||||
this.templateTypes = getTemplateTypes(props.t);
|
||||
this.tagLanguages = getTagLanguages(props.t);
|
||||
|
||||
this.state = {
|
||||
showMergeTagReference: false,
|
||||
|
@ -57,7 +58,8 @@ export default class CUD extends Component {
|
|||
this.initForm({
|
||||
getPreSubmitUpdater: ::this.getPreSubmitFormValuesUpdater,
|
||||
onChangeBeforeValidation: {
|
||||
type: ::this.onTypeChanged
|
||||
type: ::this.onTypeChanged,
|
||||
tag_language: ::this.onTagLanguageChanged
|
||||
}
|
||||
});
|
||||
|
||||
|
@ -82,13 +84,21 @@ export default class CUD extends Component {
|
|||
}
|
||||
}
|
||||
|
||||
onTagLanguageChanged(mutStateData, key, oldTagLanguage, tagLanguage) {
|
||||
if (tagLanguage) {
|
||||
const isEdit = !!this.props.entity;
|
||||
const type = mutStateData.getIn(['type', 'value']);
|
||||
this.templateTypes[type].afterTagLanguageChange(mutStateData, isEdit);
|
||||
}
|
||||
}
|
||||
|
||||
getFormValuesMutator(data) {
|
||||
this.templateTypes[data.type].afterLoad(data);
|
||||
}
|
||||
|
||||
submitFormValuesMutator(data) {
|
||||
this.templateTypes[data.type].beforeSave(data);
|
||||
return filterData(data, ['name', 'description', 'type', 'data', 'html', 'text', 'namespace']);
|
||||
return filterData(data, ['name', 'description', 'type', 'tag_language', 'data', 'html', 'text', 'namespace']);
|
||||
}
|
||||
|
||||
async getPreSubmitFormValuesUpdater() {
|
||||
|
@ -115,6 +125,7 @@ export default class CUD extends Component {
|
|||
description: '',
|
||||
namespace: mailtrainConfig.user.namespace,
|
||||
type: mailtrainConfig.editors[0],
|
||||
tag_language: mailtrainConfig.tagLanguages[0],
|
||||
|
||||
fromSourceTemplate: false,
|
||||
sourceTemplate: null,
|
||||
|
@ -143,6 +154,10 @@ export default class CUD extends Component {
|
|||
state.setIn(['type', 'error'], t('typeMustBeSelected'));
|
||||
}
|
||||
|
||||
if (!state.getIn(['tag_language', 'value'])) {
|
||||
state.setIn(['tag_language', 'error'], t('Tag language must be selected'));
|
||||
}
|
||||
|
||||
if (state.getIn(['fromSourceTemplate', 'value']) && !state.getIn(['sourceTemplate', 'value'])) {
|
||||
state.setIn(['sourceTemplate', 'error'], t('sourceTemplateMustNotBeEmpty'));
|
||||
} else {
|
||||
|
@ -274,6 +289,11 @@ export default class CUD extends Component {
|
|||
typeOptions.push({key, label: this.templateTypes[key].typeName});
|
||||
}
|
||||
|
||||
const tagLanguageOptions = [];
|
||||
for (const key of mailtrainConfig.tagLanguages) {
|
||||
tagLanguageOptions.push({key, label: this.tagLanguages[key].name});
|
||||
}
|
||||
|
||||
const typeKey = this.getFormValue('type');
|
||||
|
||||
let editForm = null;
|
||||
|
@ -290,8 +310,9 @@ export default class CUD extends Component {
|
|||
{ data: 1, title: t('name') },
|
||||
{ data: 2, title: t('description') },
|
||||
{ data: 3, title: t('type'), render: data => this.templateTypes[data].typeName },
|
||||
{ data: 4, title: t('created'), render: data => moment(data).fromNow() },
|
||||
{ data: 5, title: t('namespace') },
|
||||
{ data: 4, title: t('Tag language'), render: data => this.tagLanguages[data].name },
|
||||
{ data: 5, title: t('created'), render: data => moment(data).fromNow() },
|
||||
{ data: 6, title: t('namespace') },
|
||||
];
|
||||
|
||||
return (
|
||||
|
@ -347,6 +368,8 @@ export default class CUD extends Component {
|
|||
</>
|
||||
}
|
||||
|
||||
<Dropdown id="tag_language" label={t('Tag language')} options={tagLanguageOptions} disabled={isEdit && (!typeKey || this.templateTypes[typeKey].isTagLanguageSelectorDisabledForEdit)}/>
|
||||
|
||||
<NamespaceSelect/>
|
||||
|
||||
{editForm}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue