Create sharing invitation form
[arvados.git] / src / views-components / sharing-dialog / sharing-dialog.tsx
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { compose, Dispatch } from 'redux';
6 import { connect } from 'react-redux';
7
8 import * as React from 'react';
9 import { connectSharingDialog } from '~/store/sharing-dialog/sharing-dialog-actions';
10 import { WithDialogProps } from '~/store/dialog/with-dialog';
11 import { RootState } from '~/store/store';
12
13 import SharingDialogComponent, { SharingDialogDataProps, SharingDialogActionProps } from './sharing-dialog-component';
14 import { SharingSimpleForm } from './sharing-simple-form';
15
16 const mapStateToProps = (_: RootState, props: WithDialogProps<string>): SharingDialogDataProps => ({
17     ...props,
18     saveEnabled: false,
19     children: <SharingSimpleForm />,
20 });
21
22 const mapDispatchToProps = (_: Dispatch, props: WithDialogProps<string>): SharingDialogActionProps => ({
23     ...props,
24     onClose: props.closeDialog,
25     onSave: () => { console.log('save'); },
26     onAdvanced: () => { console.log('advanced'); },
27 });
28
29 export const SharingDialog = compose(
30     connectSharingDialog,
31     connect(mapStateToProps, mapDispatchToProps)
32 )(SharingDialogComponent);