import React, { Fragment } from 'react'; import { set } from 'react-redux-values'; import { compose, graphql } from 'react-apollo'; import ReduxForm from 'declarative-redux-form'; import { connect } from 'react-redux'; import { Margin } from 'styled-components-spacing'; import forceArray from 'force-array'; import includes from 'lodash.includes'; import get from 'lodash.get'; import { NetworkIcon, Button, H3, StatusLoader } from 'joyent-ui-toolkit'; import Network from '@components/network'; import Description from '@components/description'; import Title from '@components/create-instance/title'; import ListNetworks from '@graphql/list-networks.gql'; const FORM_NAME = 'CREATE-INSTANCE-NETWORKS'; export const Networks = ({ networks = [], selected = [], expanded = false, proceeded = false, loading = false, setInfoExpanded, setMachinesExpanded, handleNext, handleEdit }) => ( } > Networks {expanded ? ( Instances are automatically connected to a private fabric network, which is the best choice for internal communication within your application. Data center networks are the best choice for exposing your application to the public internet (if the data center network is a public network).{' '} Read more ) : null} {proceeded && !expanded ? (

{selected.length} network{selected.length === 1 ? '' : 's'} added

) : null} {loading && expanded ? : null} {!loading ? ( {props => (
{networks.map( ({ id, selected, infoExpanded, machinesExpanded, ...network }) => expanded || (selected && proceeded) ? ( setInfoExpanded(id, !infoExpanded)} onMachinesClick={() => setMachinesExpanded(id, !machinesExpanded) } {...network} /> ) : null )} )}
) : null} {expanded ? ( ) : proceeded ? ( ) : null}
); export default compose( graphql(ListNetworks, { props: ({ data }) => { const { networks = [], loading = false, error = null, refetch } = data; return { networks: forceArray(networks), loading, error, refetch }; } }), connect( ({ values, form }, { networks }) => { const selected = get(form, `${FORM_NAME}.values`, {}); const empty = id => !includes(Object.keys(selected), id); const _networks = networks .map(({ id, name, ...network }) => ({ ...network, name, selected: empty(id) && name === 'Joyent-SDC-Public' ? true : Boolean(selected[id]), infoExpanded: get( values, `create-instance-networks-${id}-info-expanded`, false ), machinesExpanded: get( values, `create-instance-networks-${id}-machines-expanded`, false ), id })) .sort((a, b) => a.name < b.name); return { proceeded: get(values, 'create-instance-networks-proceeded', false), selected: _networks.filter(({ selected }) => selected), networks: _networks }; }, (dispatch, { history }) => ({ handleNext: () => { dispatch( set({ name: 'create-instance-networks-proceeded', value: true }) ); return history.push('/instances/~create/firewall'); }, handleEdit: () => { return history.push('/instances/~create/networks'); }, setInfoExpanded: (id, expanded) => { return dispatch( set({ name: `create-instance-networks-${id}-info-expanded`, value: expanded }) ); }, setMachinesExpanded: (id, expanded) => { return dispatch( set({ name: `create-instance-networks-${id}-machines-expanded`, value: expanded }) ); } }) ) )(Networks);