Skip to content

Commit

Permalink
Add onBlur and onFocus events for radio and checkbox widgets (#1143)
Browse files Browse the repository at this point in the history
* fix: add onBlur and onFocus events for radio and checkbox widgets

* fix: use event.target.checked instead of event.target.value for checkbox
  • Loading branch information
epicfaace authored Jan 21, 2019
1 parent a426124 commit 3f35d78
Show file tree
Hide file tree
Showing 3 changed files with 140 additions and 0 deletions.
4 changes: 4 additions & 0 deletions src/components/widgets/CheckboxWidget.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ function CheckboxWidget(props) {
readonly,
label,
autofocus,
onBlur,
onFocus,
onChange,
} = props;
return (
Expand All @@ -28,6 +30,8 @@ function CheckboxWidget(props) {
disabled={disabled || readonly}
autoFocus={autofocus}
onChange={event => onChange(event.target.checked)}
onBlur={onBlur && (event => onBlur(id, event.target.checked))}
onFocus={onFocus && (event => onFocus(id, event.target.checked))}
/>
<span>{label}</span>
</label>
Expand Down
4 changes: 4 additions & 0 deletions src/components/widgets/RadioWidget.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ function RadioWidget(props) {
disabled,
readonly,
autofocus,
onBlur,
onFocus,
onChange,
id,
} = props;
Expand Down Expand Up @@ -36,6 +38,8 @@ function RadioWidget(props) {
disabled={disabled || itemDisabled || readonly}
autoFocus={autofocus && i === 0}
onChange={_ => onChange(option.value)}
onBlur={onBlur && (event => onBlur(id, event.target.value))}
onFocus={onFocus && (event => onFocus(id, event.target.value))}
/>
<span>{option.label}</span>
</span>
Expand Down
132 changes: 132 additions & 0 deletions test/BooleanField_test.js
Original file line number Diff line number Diff line change
Expand Up @@ -245,6 +245,50 @@ describe("BooleanField", () => {
expect(node.querySelectorAll(".radio-inline")).to.have.length.of(2);
});

it("should handle a focus event for radio widgets", () => {
const onFocus = sandbox.spy();
const { node } = createFormComponent({
schema: {
type: "boolean",
default: false,
},
uiSchema: {
"ui:widget": "radio",
},
onFocus,
});

const element = node.querySelector(".field-radio-group");
Simulate.focus(node.querySelector("input"), {
target: {
value: false,
},
});
expect(onFocus.calledWith(element.id, false)).to.be.true;
});

it("should handle a blur event for radio widgets", () => {
const onBlur = sandbox.spy();
const { node } = createFormComponent({
schema: {
type: "boolean",
default: false,
},
uiSchema: {
"ui:widget": "radio",
},
onBlur,
});

const element = node.querySelector(".field-radio-group");
Simulate.blur(node.querySelector("input"), {
target: {
value: false,
},
});
expect(onBlur.calledWith(element.id, false)).to.be.true;
});

it("should support enumNames for select", () => {
const { node } = createFormComponent({
schema: {
Expand All @@ -262,6 +306,50 @@ describe("BooleanField", () => {
expect(labels).eql(["", "Yes", "No"]);
});

it("should handle a focus event with checkbox", () => {
const onFocus = sandbox.spy();
const { node } = createFormComponent({
schema: {
type: "boolean",
default: false,
},
uiSchema: {
"ui:widget": "select",
},
onFocus,
});

const element = node.querySelector("select");
Simulate.focus(element, {
target: {
value: false,
},
});
expect(onFocus.calledWith(element.id, false)).to.be.true;
});

it("should handle a blur event with select", () => {
const onBlur = sandbox.spy();
const { node } = createFormComponent({
schema: {
type: "boolean",
default: false,
},
uiSchema: {
"ui:widget": "select",
},
onBlur,
});

const element = node.querySelector("select");
Simulate.blur(element, {
target: {
value: false,
},
});
expect(onBlur.calledWith(element.id, false)).to.be.true;
});

it("should render the widget with the expected id", () => {
const { node } = createFormComponent({
schema: {
Expand All @@ -285,6 +373,50 @@ describe("BooleanField", () => {
expect(node.querySelector("#custom")).to.exist;
});

it("should handle a focus event with checkbox", () => {
const onFocus = sandbox.spy();
const { node } = createFormComponent({
schema: {
type: "boolean",
default: false,
},
uiSchema: {
"ui:widget": "checkbox",
},
onFocus,
});

const element = node.querySelector("input");
Simulate.focus(element, {
target: {
checked: false,
},
});
expect(onFocus.calledWith(element.id, false)).to.be.true;
});

it("should handle a blur event with checkbox", () => {
const onBlur = sandbox.spy();
const { node } = createFormComponent({
schema: {
type: "boolean",
default: false,
},
uiSchema: {
"ui:widget": "checkbox",
},
onBlur,
});

const element = node.querySelector("input");
Simulate.blur(element, {
target: {
checked: false,
},
});
expect(onBlur.calledWith(element.id, false)).to.be.true;
});

describe("Label", () => {
const Widget = props => <div id={`label-${props.label}`} />;

Expand Down

0 comments on commit 3f35d78

Please sign in to comment.