X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/9fed03a84c6ef5234d61f7d62c93f7629da2409d..76a0eb34b5cbd30bf16608b86eec29072a3da3b0:/src/store/dialog/with-dialog.ts diff --git a/src/store/dialog/with-dialog.ts b/src/store/dialog/with-dialog.ts index 42ae73e4..41dcd559 100644 --- a/src/store/dialog/with-dialog.ts +++ b/src/store/dialog/with-dialog.ts @@ -8,26 +8,28 @@ import { DialogState } from './dialog-reducer'; import { Dispatch } from 'redux'; import { dialogActions } from './dialog-actions'; -export type WithDialog = { +export type WithDialogStateProps = { open: boolean; - data?: T; + data: T; }; -export type WithDialogActions = { +export type WithDialogDispatchProps = { closeDialog: () => void; }; +export type WithDialogProps = WithDialogStateProps & WithDialogDispatchProps; export const withDialog = (id: string) => - (component: React.ComponentType & WithDialogActions>) => + // TODO: How to make compiler happy with & P instead of & any? + (component: React.ComponentType & any>) => connect(mapStateToProps(id), mapDispatchToProps(id))(component); -export const mapStateToProps = (id: string) => (state: { dialog: DialogState }): WithDialog => { +export const mapStateToProps = (id: string) => (state: { dialog: DialogState }): WithDialogStateProps => { const dialog = state.dialog[id]; - return dialog ? dialog : { open: false }; + return dialog ? dialog : { open: false, data: {} }; }; -export const mapDispatchToProps = (id: string) => (dispatch: Dispatch): WithDialogActions => ({ +export const mapDispatchToProps = (id: string) => (dispatch: Dispatch): WithDialogDispatchProps => ({ closeDialog: () => { dispatch(dialogActions.CLOSE_DIALOG({ id })); } -}); \ No newline at end of file +});