Skip to content

Commit

Permalink
css fixes + fix for #1247
Browse files Browse the repository at this point in the history
  • Loading branch information
Milford committed Mar 26, 2019
1 parent 2d62e8b commit 7eaff09
Show file tree
Hide file tree
Showing 8 changed files with 79 additions and 64 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ class FormComponent extends React.Component<
const order = this.props.order[key].indexOf(this.props.id);

if (this.state.wrapperRef && !this.state.wrapperRef.contains(event.target) &&
order === 0) {
order === 0) {
this.handleActiveListChange({});
}
}
Expand Down Expand Up @@ -200,7 +200,7 @@ class FormComponent extends React.Component<
public handleActiveListChange = (obj: any) => {
if (Object.keys(obj).length === 0 && obj.constructor === Object) {
FormDesignerActionDispatchers.deleteActiveListAction();
} else {
} else {
FormDesignerActionDispatchers.updateActiveList(obj, this.props.activeList);
}
this.props.sendListToParent(this.props.activeList);
Expand All @@ -227,19 +227,19 @@ class FormComponent extends React.Component<
}
return (
<div ref={this.setWrapperRef}>
<EditContainer
component={this.props.component}
id={this.props.id}
firstInActiveList={this.props.firstInActiveList}
lastInActiveList={this.props.lastInActiveList}
sendItemToParent={this.handleActiveListChange}
singleSelected={this.props.singleSelected}
>
<div onClick={this.disableEditOnClickForAddedComponent}>
{this.renderLabel()}
{this.renderComponent()}
</div>
</EditContainer>
<EditContainer
component={this.props.component}
id={this.props.id}
firstInActiveList={this.props.firstInActiveList}
lastInActiveList={this.props.lastInActiveList}
sendItemToParent={this.handleActiveListChange}
singleSelected={this.props.singleSelected}
>
<div onClick={this.disableEditOnClickForAddedComponent}>
{this.renderLabel()}
{this.renderComponent()}
</div>
</EditContainer>
</div>
);
}
Expand Down Expand Up @@ -286,9 +286,9 @@ class FormComponent extends React.Component<
private errorMessage(): JSX.Element[] {
if (!this.isSimpleComponent() ||
!this.hasValidationMessages()) {
return null;
return null;
}
const { component: {id} } = this.props;
const { component: { id } } = this.props;
return renderValidationMessagesForComponent(this.props.validationResults.simpleBinding, id);
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ export class CheckboxContainerComponent extends React.Component<ICheckboxContain
key={index}
className={'custom-control custom-checkbox a-custom-checkbox pl-0 pr-4 mr-3'
+ (this.props.component.readOnly ? ' no-cursor' : '')}
onClick={this.props.component.readOnly ? '' : this.onDataChanged.bind(this, option.value, index)}
onClick={this.props.component.readOnly ? null : this.onDataChanged.bind(this, option.value, index)}
>
<input
type='checkbox'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ export class RadioButtonContainerComponent
+ (this.props.component.readOnly ? ' no-cursor' : '')}
key={index}
onClick={this.props.component.readOnly ?
this.onDataChanged.bind(this, option.value) : this.onDataChanged.bind(this, option.value)}
null : this.onDataChanged.bind(this, option.value)}
>
<input
type='radio'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,15 +21,25 @@
background-color: transparent !important;
pointer-events: none !important;
}
.a-custom-radio.custom-control-input:not(checked).disabled-radio-button:hover::after {
background-image: none;
background: none;
}
.a-custom-radio.custom-control-input:checked~.disabled-radio-button:hover::after {
background-image: url();
}

.no-cursor {
cursor: default !important;
}
.a-custom-radio .custom-control-input:not(checked)~.disabled-radio-button::before {
background: repeating-linear-gradient(
135deg,
#efefef,
#efefef 2px,
#fff 3px,
#fff 5px
);
}
.a-custom-radio .custom-control-input:checked~.disabled-radio-button::before {
background: repeating-linear-gradient(
135deg,
#efefef,
#efefef 2px,
#fff 3px,
#fff 5px
);
}

17 changes: 8 additions & 9 deletions src/react-apps/applications/runtime/src/utils/validation.ts
Original file line number Diff line number Diff line change
Expand Up @@ -50,11 +50,11 @@ export function validateDataModel(
const fieldKey = Object.keys(layoutModelElement.dataModelBindings).find((binding: string) =>
layoutModelElement.dataModelBindings[binding] === dataModelFieldElement.DataBindingName);
const componentValidations: IComponentValidations = {
[fieldKey]: {
errors: [],
warnings: [],
},
};
[fieldKey]: {
errors: [],
warnings: [],
},
};

// Loop through all restrictions for the data model element and validate
Object.keys(dataModelFieldElement.Restrictions).forEach((key) => {
Expand Down Expand Up @@ -133,8 +133,7 @@ export function validateFormData(
}
});

if ((dataModelFieldElement.MinOccurs === null || dataModelFieldElement.MinOccurs === 1)
|| (layoutModelElement && layoutModelElement.required)) {
if (layoutModelElement && layoutModelElement.required) {
if (formData[formDataKey].length === 0) {
validationErrors.push('Field is required');
}
Expand Down Expand Up @@ -203,8 +202,8 @@ function mapValidations(validations: any, layoutComponents: IFormDesignerCompone
// as unmapped.
if (validationResult.unmapped) {
validationResult.unmapped[validationKey] = {
...validationResult.unmapped[validationKey],
...validations[validationKey],
...validationResult.unmapped[validationKey],
...validations[validationKey],
};
} else {
validationResult.unmapped = {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ const AltinnCheckBox = (props: IAltinnCheckBoxComponentProvidedProps) => {
className={classes.altinnCheckBox}
checked={props.checked}
onChange={props.onChangeFunction}
disabled={props.disabled}
/>
);
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ const styles = {

export interface IEditModalContentProps {
component: FormComponentType;
dataModel?: IDataModelFieldElement[];
dataModel: IDataModelFieldElement[];
textResources?: ITextResource[];
codeListResources?: ICodeListListElement[];
saveEdit?: (updatedComponent: FormComponentType) => void;
Expand Down Expand Up @@ -161,12 +161,6 @@ class EditModalContentComponent extends React.Component<IEditModalContentProps,
this.props.handleComponentUpdate(updatedComponent);
}

public getTextKeyFromDataModel = (dataBindingName: string): string => {
const element: IDataModelFieldElement = this.props.dataModel.find((elem) =>
elem.DataBindingName === dataBindingName);
return element.Texts.Label;
}

public handleCodeListChange = (option: ICodeListOption): void => {
const updatedComponent = this.props.component;
updatedComponent.codeListId = option ? option.value.codeListName : undefined;
Expand Down Expand Up @@ -545,16 +539,6 @@ class EditModalContentComponent extends React.Component<IEditModalContentProps,
this.props.textResources,
this.props.language,
this.props.component.textResourceBindings.description)}
<Grid item={true} classes={{ item: this.props.classes.gridItem }}>
{getLanguageFromKey('ux_editor.read_only_description', this.props.language)}
</Grid>
<Grid item={true}>
<AltinnCheckBox
checked={!!component.readOnly}
onChangeFunction={this.handleReadOnlyChange}
/>
{getLanguageFromKey('ux_editor.read_only', this.props.language)}
</Grid>
</Grid>
);
}
Expand All @@ -565,6 +549,12 @@ class EditModalContentComponent extends React.Component<IEditModalContentProps,
}
}

public getMinOccursFromDataModel = (dataBindingName: string): number => {
const element: IDataModelFieldElement = this.props.dataModel.find((e: IDataModelFieldElement) =>
e.DataBindingName === dataBindingName);
return element.MinOccurs;
}

public handleValidFileEndingsChange = (event: any) => {
const component = (this.props.component as IFormFileUploaderComponent);
component.validFileEndings = event.target.value;
Expand Down Expand Up @@ -625,16 +615,22 @@ class EditModalContentComponent extends React.Component<IEditModalContentProps,
dataModelBinding = {};
}
dataModelBinding[key] = selectedDataModelElement;
this.setState({
component: {
...this.state.component,
dataModelBindings: dataModelBinding,
},
});
this.props.handleComponentUpdate({
...this.props.component,
dataModelBindings: dataModelBinding,
});
if (this.getMinOccursFromDataModel(selectedDataModelElement) === 1) {
this.setState({
component: {
...this.state.component,
required: true,
dataModelBindings: dataModelBinding,
},
}, () => this.props.handleComponentUpdate(this.state.component));
} else {
this.setState({
component: {
...this.state.component,
dataModelBindings: dataModelBinding,
},
}, () => this.props.handleComponentUpdate(this.state.component));
}
}

public handleToggleAddressSimple = (event: object, checked: boolean) => {
Expand Down Expand Up @@ -684,6 +680,7 @@ const mapStateToProps = (
textResources: state.appData.textResources.resources,
codeListResources: state.appData.codeLists.codeLists,
thirdPartyComponents: state.thirdPartyComponents.components,
dataModel: state.appData.dataModel.model,
...props,
};
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ export interface ICollapsableMenuProvidedProps {
export interface ICollapsableMenuProps extends ICollapsableMenuProvidedProps {
components: IFormDesignerComponent;
language: any;
dataModel: IDataModelFieldElement[];
}

export interface ICollapsableMenuListItem {
Expand All @@ -71,6 +72,12 @@ const CollapsableMenus = (props: ICollapsableMenuProps) => {
setComponent(props.components[props.componentId]);
}, [props]);

const getMinOccursFromDataModel = (dataBindingName: string): boolean => {
const element: IDataModelFieldElement = props.dataModel.find((e: IDataModelFieldElement) =>
e.DataBindingName === dataBindingName);
return element ? element.MinOccurs === 1 : false;
};

const toggleMenu = () => {
setMenuIsOpen(!menuIsOpen);
};
Expand All @@ -83,7 +90,6 @@ const CollapsableMenus = (props: ICollapsableMenuProps) => {
props.componentId,
);
setComponent(props.components[props.componentId]);
console.log('component ', component);
}
};

Expand Down Expand Up @@ -124,6 +130,7 @@ const CollapsableMenus = (props: ICollapsableMenuProps) => {
<AltinnCheckBox
checked={!component.required}
onChangeFunction={() => toggleCheckbox('required')}
disabled={getMinOccursFromDataModel(component.dataModelBindings.simpleBinding)}
/>
{props.language.ux_editor.optional}
</ListItem>
Expand Down Expand Up @@ -162,6 +169,7 @@ const mapStateToProps: (
header: props.header,
language: state.appData.language.language,
listItems: props.listItems,
dataModel: state.appData.dataModel.model,
});

export const CollapsableMenuComponent =
Expand Down

0 comments on commit 7eaff09

Please sign in to comment.