Skip to content

Commit

Permalink
Refine UI for BoxControl
Browse files Browse the repository at this point in the history
  • Loading branch information
Jon Q committed Apr 9, 2020
1 parent e28e139 commit 806a615
Show file tree
Hide file tree
Showing 7 changed files with 62 additions and 30 deletions.
16 changes: 13 additions & 3 deletions packages/components/src/box-control/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,22 +5,30 @@ import { noop } from 'lodash';
/**
* WordPress dependencies
*/
import { useInstanceId } from '@wordpress/compose';
import { useState } from '@wordpress/element';
import { __ } from '@wordpress/i18n';
/**
* Internal dependencies
*/
import Visualizer from './visualizer';
import { FlexItem } from '../flex';
import InputControls from './input-controls';
import Text from '../text';
import { DEFAULT_VALUES, parseValues } from './utils';
import { Root, Header, LayoutContainer } from './styles/box-control-styles';

const defaultInputProps = {
min: 0,
};

function useUniqueId( idProp ) {
const instanceId = useInstanceId( BoxControl );
const id = `inspector-box-control-${ instanceId }`;

return idProp || id;
}
export default function BoxControl( {
idProp,
inputProps = defaultInputProps,
onChange = noop,
label = __( 'Box Control' ),
Expand All @@ -29,6 +37,8 @@ export default function BoxControl( {
units = false,
} ) {
const [ values, setValues ] = useState( parseValues( valuesProp ) );
const id = useUniqueId( idProp );
const headingId = `${ id }-heading`;

const updateValues = ( nextValues ) => {
const mergedValues = { ...values, ...nextValues };
Expand All @@ -37,9 +47,9 @@ export default function BoxControl( {
};

return (
<Root>
<Root id={ id } role="region" aria-labelledby={ headingId }>
<Header>
<FlexItem>{ label }</FlexItem>
<Text id={ headingId }>{ label }</Text>
</Header>
<LayoutContainer>
<InputControls
Expand Down
26 changes: 9 additions & 17 deletions packages/components/src/box-control/input-controls.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,12 @@ import { noop } from 'lodash';
*/
import UnitControl from './unit-control';
import { getValues } from './utils';
import { Layout, LayoutBox, SideIndicator } from './styles/box-control-styles';
import {
Layout,
LayoutBox,
SideIndicatorX,
SideIndicatorY,
} from './styles/box-control-styles';
import { useRtl } from '../utils/style-mixins';

export default function BoxInputControls( {
Expand Down Expand Up @@ -39,22 +44,9 @@ export default function BoxInputControls( {

return (
<Layout>
<SideIndicator
style={ {
left: '50%',
top: '50%',
transform: 'translate(0, -30px)',
} }
/>
<SideIndicator
style={ {
left: '50%',
top: '0%',
height: '75%',
transform: 'rotate(-90deg) translate(-15px, 0px)',
} }
/>
<LayoutBox />
<SideIndicatorX aria-hidden="true" />
<SideIndicatorY aria-hidden="true" />
<LayoutBox aria-hidden="true" />
<UnitControl
{ ...props }
disableUnits
Expand Down
27 changes: 21 additions & 6 deletions packages/components/src/box-control/styles/box-control-styles.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,13 @@ import { color } from '../../utils/style-mixins';

export const Root = styled.div`
max-width: 300px;
padding-bottom: 12px;
width: 100%;
`;

export const Header = styled( Flex )`
margin-bottom: 8px;
color: ${color( 'ui.label' )};
padding-bottom: 8px;
`;

export const UnitControlWrapper = styled.div`
Expand All @@ -24,14 +27,13 @@ export const UnitControlWrapper = styled.div`
export const LayoutContainer = styled( Flex )`
height: 120px;
justify-content: center;
padding-bottom: 16px;
`;

export const Layout = styled.div`
box-sizing: border-box;
position: relative;
height: 120px;
width: 200px;
width: 100%;
`;

export const LayoutBox = styled.div`
Expand All @@ -46,9 +48,22 @@ export const LayoutBox = styled.div`
`;

export const SideIndicator = styled.div`
height: 50%;
border-left: 1px dashed ${color( 'ui.borderLight' )};
width: 0;
box-sizing: border-box;
position: absolute;
pointer-events: none;
`;

export const SideIndicatorX = styled( SideIndicator )`
border-top: 1px dashed ${color( 'ui.borderLight' )};
top: 50%;
left: 0;
width: 100%;
`;

export const SideIndicatorY = styled( SideIndicator )`
border-left: 1px dashed ${color( 'ui.borderLight' )};
top: 50%;
left: 50%;
transform: translate( 0, calc( -50% - 3px ) );
height: 50%;
`;
2 changes: 1 addition & 1 deletion packages/components/src/box-control/visualizer.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ export default function BoxControlVisualizer( {
const values = parseValues( valuesProp );

return (
<Container { ...props }>
<Container { ...props } aria-hidden="true">
<Sides values={ values } />
{ children }
</Container>
Expand Down
7 changes: 6 additions & 1 deletion packages/components/src/input-control/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -101,11 +101,16 @@ export function InputControl(
value={ value }
/>
<Fieldset
aria-hidden="true"
isFloatingLabel={ isFloatingLabelSet }
isFocused={ isFocused }
>
{ isFloatingLabelSet && (
<Legend isFloating={ isFloating } size={ size }>
<Legend
aria-hidden="true"
isFloating={ isFloating }
size={ size }
>
<LegendText>{ label }</LegendText>
</Legend>
) }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import styled from '@emotion/styled';
/**
* Internal dependencies
*/
import Text from '../../text';
import { color, rtl, reduceMotion } from '../../utils/style-mixins';

const FLOATING_LABEL_TRANSITION_SPEED = '60ms';
Expand Down Expand Up @@ -167,11 +168,13 @@ const labelPosition = ( { isFloatingLabel, isFloating, size } ) => {
);
};

export const Label = styled.label`
const BaseLabel = styled( Text )`
&&& {
box-sizing: border-box;
display: block;
margin: 0;
padding: 0;
pointer-events: none;
top: 50%;
transition: transform ${FLOATING_LABEL_TRANSITION_SPEED} linear;
z-index: 1;
Expand All @@ -185,6 +188,8 @@ export const Label = styled.label`
}
`;

export const Label = ( props ) => <BaseLabel { ...props } as="label" />;

const fieldsetTopStyles = ( { isFloatingLabel } ) => {
const top = isFloatingLabel ? -5 : 0;
return css( { top } );
Expand Down Expand Up @@ -251,8 +256,12 @@ export const Legend = styled.legend`
}
`;

export const LegendText = styled.span`
const BaseLegendText = styled( Text )`
box-sizing: border-box;
display: inline-block;
${rtl( { paddingLeft: 4, paddingRight: 5 } )}
`;

export const LegendText = ( props ) => (
<BaseLegendText { ...props } as="span" />
);
1 change: 1 addition & 0 deletions packages/components/src/utils/colors-values.js
Original file line number Diff line number Diff line change
Expand Up @@ -140,6 +140,7 @@ export const UI = {
border: BASE.black,
borderFocus: BLUE.medium.focus,
borderLight: LIGHT_GRAY[ 600 ],
label: DARK_GRAY[ 500 ],
};

export const COLORS = {
Expand Down

0 comments on commit 806a615

Please sign in to comment.