@wordpress/components
Version:
UI components for WordPress.
131 lines (111 loc) • 2.36 kB
JavaScript
/**
* External dependencies
*/
import { css } from '@emotion/core';
import styled from '@emotion/styled';
/**
* Internal dependencies
*/
import { color, rtl } from '../../utils/style-mixins';
import NumberControl from '../../number-control';
export const Root = styled.div`
box-sizing: border-box;
position: relative;
`;
const paddingStyles = ( { disableUnits } ) => {
const value = disableUnits ? 3 : 24;
return css`
${ rtl( { paddingRight: value } )() };
`;
};
const arrowStyles = ( { disableUnits } ) => {
if ( disableUnits ) return '';
return css`
&::-webkit-outer-spin-button,
&::-webkit-inner-spin-button {
-webkit-appearance: none;
margin: 0;
}
`;
};
// TODO: Resolve need to use &&& to increase specificity
// https://github.com/WordPress/gutenberg/issues/18483
export const ValueInput = styled( NumberControl )`
&&& {
input {
appearance: none;
-moz-appearance: textfield;
display: block;
width: 100%;
${ arrowStyles };
${ paddingStyles };
}
}
`;
const unitSizeStyles = ( { size } ) => {
const sizes = {
default: {
height: 28,
lineHeight: '24px',
minHeight: 28,
top: 1,
},
small: {
height: 22,
lineHeight: '18px',
minHeight: 22,
top: 1,
},
};
return css( sizes[ size ] );
};
const baseUnitLabelStyles = ( props ) => {
return css`
appearance: none;
background: transparent;
border-radius: 2px;
border: none;
box-sizing: border-box;
color: ${ color( 'darkGray.500' ) };
display: block;
font-size: 8px;
line-height: 1;
letter-spacing: -0.5px;
outline: none;
padding: 2px 1px;
position: absolute;
text-align-last: center;
text-transform: uppercase;
width: 20px;
${ rtl( { borderTopLeftRadius: 0, borderBottomLeftRadius: 0 } )() }
${ rtl( { right: 0 } )() }
${ unitSizeStyles( props ) }
`;
};
export const UnitLabel = styled.div`
&&& {
pointer-events: none;
${ baseUnitLabelStyles };
}
`;
export const UnitSelect = styled.select`
&&& {
${ baseUnitLabelStyles };
cursor: pointer;
border: 1px solid transparent;
&:hover {
background-color: ${ color( 'lightGray.300' ) };
}
&:focus {
border-color: ${ color( 'ui.borderFocus' ) };
outline: 2px solid transparent;
outline-offset: 0;
}
&:disabled {
cursor: initial;
&:hover {
background-color: transparent;
}
}
}
`;