This commit is contained in:
Mirco Wittrien 2020-05-20 12:43:04 +02:00
parent b087faa16c
commit 3ad79a05f4
2 changed files with 12 additions and 36 deletions

View File

@ -1634,9 +1634,9 @@
} }
return parent.props.children; return parent.props.children;
} }
BDFDB.ReactUtils.createElement = function (component, props) { BDFDB.ReactUtils.createElement = function (component, props = {}) {
if (component && component.defaultProps) for (let key in component.defaultProps) if (props[key] == null) props[key] = component.defaultProps[key]; if (component && component.defaultProps) for (let key in component.defaultProps) if (props[key] == null) props[key] = component.defaultProps[key];
try {return LibraryModules.React.createElement(component || "div", props || {}) || null;} try {return LibraryModules.React.createElement(component || "div", props) || null;}
catch (err) {BDFDB.LogUtils.error("Could not create react element! " + err);} catch (err) {BDFDB.LogUtils.error("Could not create react element! " + err);}
return null; return null;
}; };
@ -3275,7 +3275,8 @@
id: props.id, id: props.id,
disabled: props.disabled, disabled: props.disabled,
render: menuItemProps => { render: menuItemProps => {
return BDFDB.ReactUtils.createElement(component, BDFDB.ObjectUtils.exclude(Object.assign({}, props, menuItemProps), "id", "disabled")); if (!props.state) props.state = BDFDB.ObjectUtils.extract(props, "checked", "value");
return BDFDB.ReactUtils.createElement(component, Object.assign(props, menuItemProps));
} }
}); });
} }
@ -7432,41 +7433,16 @@
InternalComponents.LibraryComponents.MenuItems.MenuCheckboxItem = InternalBDFDB.loadPatchedComp("MenuItems.MenuCheckboxItem") || reactInitialized && class BDFDB_MenuCheckboxItem extends LibraryModules.React.Component { InternalComponents.LibraryComponents.MenuItems.MenuCheckboxItem = InternalBDFDB.loadPatchedComp("MenuItems.MenuCheckboxItem") || reactInitialized && class BDFDB_MenuCheckboxItem extends LibraryModules.React.Component {
handleClick() { handleClick() {
this.props.checked = !this.props.checked; if (this.props.state) {
if (typeof this.props.action == "function") this.props.action(this.props.checked, this); this.props.state.checked = !this.props.state.checked;
if (typeof this.props.action == "function") this.props.action(this.props.state.checked, this);
}
BDFDB.ReactUtils.forceUpdate(this); BDFDB.ReactUtils.forceUpdate(this);
} }
render() { render() {
return BDFDB.ReactUtils.createElement("div", Object.assign({ return BDFDB.ReactUtils.createElement(InternalComponents.NativeSubComponents.MenuCheckboxItem, Object.assign({}, this.props, {
className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN.menuitem, BDFDB.disCN.menulabelcontainer, this.props.color && BDFDB.disCN["menu" + this.props.color.toLowerCase()], this.props.disabled && BDFDB.disCN.menudisabled, this.props.isFocused && BDFDB.disCN.menufocused), checked: this.props.state && this.props.state.checked,
onClick: !this.props.disabled && this.handleClick.bind(this) action: this.handleClick.bind(this)
}, this.props, {
"aria-checked": this.props.checked,
"aria-disabled": this.props.disabled,
children: [
BDFDB.ReactUtils.createElement("div", {
className: BDFDB.disCN.menulabel,
children: [
typeof this.props.label == "function" ? this.props.label(this) : this.props.label,
this.props.subtext && BDFDB.ReactUtils.createElement("div", {
className: BDFDB.disCN.menusubtext,
children: this.props.subtext
})
].filter(n => n)
}),
BDFDB.ReactUtils.createElement("div", {
className: BDFDB.disCN.menuiconcontainer,
children: this.props.checked ? BDFDB.ReactUtils.createElement(InternalComponents.LibraryComponents.SvgIcon, {
name: InternalComponents.LibraryComponents.SvgIcon.Names.CHECKBOX,
className: BDFDB.disCN.menuicon,
background: BDFDB.disCN.menucheckbox,
foreground: BDFDB.disCN.menucheck
}) : BDFDB.ReactUtils.createElement(InternalComponents.LibraryComponents.SvgIcon, {
name: InternalComponents.LibraryComponents.SvgIcon.Names.CHECKBOX_EMPTY,
className: BDFDB.disCN.menuicon
})
})
].filter(n => n)
})); }));
} }
}; };

File diff suppressed because one or more lines are too long