mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-07 03:22:21 +03:00
Added new switch component for toggle UI
no issue - Mimics behavior and UI of toggle button in Ghost Admin
This commit is contained in:
parent
ee1dfbc0af
commit
9cc5badd2f
20
ghost/portal/src/components/common/Switch.js
Normal file
20
ghost/portal/src/components/common/Switch.js
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
function Switch({id, label, onToggle, checked = false}) {
|
||||||
|
return (
|
||||||
|
<div className="for-switch">
|
||||||
|
<label className="switch" htmlFor={id}>
|
||||||
|
<input
|
||||||
|
type="checkbox"
|
||||||
|
checked={checked}
|
||||||
|
id={id}
|
||||||
|
onChange={e => onToggle(e)}
|
||||||
|
aria-label={label}
|
||||||
|
/>
|
||||||
|
<span className="input-toggle-component"></span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Switch;
|
36
ghost/portal/src/components/common/Switch.test.js
Normal file
36
ghost/portal/src/components/common/Switch.test.js
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import {render, fireEvent} from '@testing-library/react';
|
||||||
|
import Switch from './Switch';
|
||||||
|
|
||||||
|
const setup = (overrides = {}) => {
|
||||||
|
const mockOnToggle = jest.fn();
|
||||||
|
const props = {
|
||||||
|
onToggle: mockOnToggle,
|
||||||
|
label: 'Test Switch',
|
||||||
|
id: 'test-switch'
|
||||||
|
};
|
||||||
|
const utils = render(
|
||||||
|
<Switch {...props} />
|
||||||
|
);
|
||||||
|
|
||||||
|
const checkboxEl = utils.getByLabelText(props.label);
|
||||||
|
return {
|
||||||
|
checkboxEl,
|
||||||
|
mockOnToggle,
|
||||||
|
...utils
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
describe('Switch', () => {
|
||||||
|
test('renders', () => {
|
||||||
|
const {checkboxEl} = setup();
|
||||||
|
expect(checkboxEl).toBeInTheDocument();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('calls onToggle on click', () => {
|
||||||
|
const {checkboxEl, mockOnToggle} = setup();
|
||||||
|
fireEvent.click(checkboxEl);
|
||||||
|
|
||||||
|
expect(mockOnToggle).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in New Issue
Block a user