-
Notifications
You must be signed in to change notification settings - Fork 4.3k
/
Copy pathindex.js
39 lines (34 loc) · 949 Bytes
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
/**
* WordPress dependencies
*/
import { Button } from '@wordpress/components';
import { __ } from '@wordpress/i18n';
import { useDispatch, useSelect } from '@wordpress/data';
/**
* Internal dependencies
*/
import { store as editWidgetsStore } from '../../store';
function SaveButton() {
const { hasEditedWidgetAreaIds, isSaving } = useSelect( ( select ) => {
const { getEditedWidgetAreas, isSavingWidgetAreas } = select(
editWidgetsStore
);
return {
hasEditedWidgetAreaIds: getEditedWidgetAreas()?.length > 0,
isSaving: isSavingWidgetAreas(),
};
}, [] );
const { saveEditedWidgetAreas } = useDispatch( editWidgetsStore );
return (
<Button
variant="primary"
isBusy={ isSaving }
aria-disabled={ isSaving }
onClick={ isSaving ? undefined : saveEditedWidgetAreas }
disabled={ ! hasEditedWidgetAreaIds }
>
{ isSaving ? __( 'Saving…' ) : __( 'Update' ) }
</Button>
);
}
export default SaveButton;