Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[RNMobile] Add radial gradient infrastructure #22493

Merged
merged 27 commits into from
Jun 17, 2020
Merged
Show file tree
Hide file tree
Changes from 24 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
f01f0b2
Initial work on radial gradient
lukewalczak May 15, 2020
cd5d0d7
Renamed linear gradient into gradient
lukewalczak May 15, 2020
00f08f5
Support displaying radial gradient
lukewalczak May 15, 2020
ce82cc3
Code refactor
lukewalczak May 18, 2020
b29812a
Improve gradients utils
lukewalczak May 20, 2020
226153e
Create radial gradient infra
lukewalczak May 20, 2020
92eec2c
Use custom gradient picker in color settings
lukewalczak May 20, 2020
cb62eae
Limit displaying option to customize gradient, add radio control
lukewalczak May 21, 2020
51efbe8
Add custom gradient indicator, improve a11y in colors
lukewalczak May 22, 2020
b06dbf7
Add spacer for angle control
lukewalczak May 22, 2020
ae6f145
Refactor scrollview to flatlist
lukewalczak May 25, 2020
74bbde9
Update ref: Apply workaround for android scrolling horizontal list issue
lukewalczak May 25, 2020
5cfddc5
Improvment tweaks
lukewalczak May 26, 2020
7d667d7
Merge branch 'master' into rnmobile/radial-gradient-infrastructur
lukewalczak May 26, 2020
53ecc73
Add scroll to end when switching between segments
lukewalczak May 26, 2020
a3df315
Merge branch 'master' into rnmobile/radial-gradient-infrastructur
lukewalczak May 26, 2020
3bed7ed
Support back button for custom gradient screen
lukewalczak May 27, 2020
a070079
Correct color selection
lukewalczak May 29, 2020
37cd03c
Merge branch 'master' into rnmobile/radial-gradient-infrastructur
lukewalczak May 29, 2020
2400959
Change overlay color settings order
lukewalczak May 29, 2020
a131eb2
Merge branch 'master' into rnmobile/radial-gradient-infrastructur
lukewalczak May 29, 2020
18a5db6
Do not change gradient when changing image
lukewalczak Jun 1, 2020
07814fa
Merge branch 'master' into rnmobile/radial-gradient-infrastructur
lukewalczak Jun 1, 2020
41ff9c9
Correct Android font weight on custom text
lukewalczak Jun 2, 2020
7e179a4
Refactor after CR
lukewalczak Jun 8, 2020
4acba69
Simplify radio control
lukewalczak Jun 8, 2020
17881c3
Add scrollEventThrottle, small refactor
lukewalczak Jun 9, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion packages/base-styles/_variables.scss
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ $spinner-size: 18px;
$mobile-header-toolbar-height: 44px;
$mobile-floating-toolbar-height: 44px;
$mobile-floating-toolbar-margin: 8px;

$mobile-color-swatch: 48px;

/**
* Shadows.
Expand Down
27 changes: 13 additions & 14 deletions packages/block-library/src/cover/edit.native.js
Original file line number Diff line number Diff line change
Expand Up @@ -127,8 +127,6 @@ const Cover = ( {
const onSelectMedia = ( media ) => {
setDidUploadFail( false );
const onSelect = attributesFromMedia( setAttributes );
// Remove gradient attribute
setAttributes( { gradient: undefined, customGradient: undefined } );
onSelect( media );
};

Expand Down Expand Up @@ -204,28 +202,29 @@ const Cover = ( {
attributes={ attributes }
setAttributes={ setAttributes }
/>
<PanelBody title={ __( 'Dimensions' ) }>
<RangeControl
label={ __( 'Minimum height in pixels' ) }
minimumValue={ COVER_MIN_HEIGHT }
maximumValue={ COVER_MAX_HEIGHT }
value={ CONTAINER_HEIGHT }
onChange={ onHeightChange }
style={ styles.rangeCellContainer }
/>
</PanelBody>
{ url ? (
<PanelBody title={ __( 'Overlay' ) }>
<PanelBody>
<RangeControl
label={ __( 'Background Opacity' ) }
label={ __( 'Opacity' ) }
minimumValue={ 0 }
maximumValue={ 100 }
value={ dimRatio }
onChange={ onOpactiyChange }
style={ styles.rangeCellContainer }
separatorType={ 'topFullWidth' }
/>
</PanelBody>
) : null }
<PanelBody title={ __( 'Dimensions' ) }>
<RangeControl
label={ __( 'Minimum height in pixels' ) }
minimumValue={ COVER_MIN_HEIGHT }
maximumValue={ COVER_MAX_HEIGHT }
value={ CONTAINER_HEIGHT }
onChange={ onHeightChange }
style={ styles.rangeCellContainer }
/>
</PanelBody>
</InspectorControls>
);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -75,11 +75,11 @@ function OverlayColorSettings( { attributes, setAttributes } ) {

return (
<PanelColorGradientSettings
title={ __( 'Color Settings' ) }
title={ __( 'Overlay' ) }
initialOpen={ false }
settings={ [
{
label: __( 'Overlay Color' ),
label: __( 'Color' ),
onColorChange,
colorValue,
gradientValue,
Expand Down
2 changes: 2 additions & 0 deletions packages/components/src/color-control/index.native.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ function ColorControl( {
className,
onPress,
color,
withColorIndicator,
...props
} ) {
const id = `inspector-color-control-${ instanceId }`;
Expand All @@ -23,6 +24,7 @@ function ColorControl( {
aria-describedby={ !! help ? id + '__help' : undefined }
onPress={ onPress }
color={ color }
withColorIndicator={ withColorIndicator }
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved
{ ...props }
/>
);
Expand Down
4 changes: 2 additions & 2 deletions packages/components/src/color-indicator/style.native.scss
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@
}

.circleOption {
height: 48px;
width: 48px;
height: $mobile-color-swatch;
width: $mobile-color-swatch;
border-radius: 24px;
margin-right: 8px;
justify-content: center;
Expand Down
117 changes: 105 additions & 12 deletions packages/components/src/color-palette/index.native.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,22 +7,31 @@ import {
View,
Animated,
Easing,
Dimensions,
Platform,
Text,
} from 'react-native';
import { map, uniq } from 'lodash';
/**
* WordPress dependencies
*/
import { useRef, useEffect, createRef } from '@wordpress/element';
import { __ } from '@wordpress/i18n';
import { useRef, useEffect } from '@wordpress/element';
import { usePreferredColorSchemeStyle } from '@wordpress/compose';
/**
* Internal dependencies
*/
import styles from './style.scss';
import ColorIndicator from '../color-indicator';
import { colorsUtils } from '../mobile/color-settings/utils';
import { performLayoutAnimation } from '../mobile/utils';

const ANIMATION_DURATION = 200;

let contentWidth = 0;
let scrollPosition = 0;
let customIndicatorWidth = 0;

function ColorPalette( {
setColor,
activeColor,
Expand All @@ -38,7 +47,8 @@ function ColorPalette( {
'linear-gradient(360deg, rgba(0,0,255,.8), 0%, rgba(0,0,255,0) 70.71%)',
];

const scrollViewRef = createRef();
const scrollViewRef = useRef();
const isIOS = Platform.OS === 'ios';

const isGradientSegment = currentSegment === colorsUtils.segments[ 1 ];

Expand All @@ -51,14 +61,35 @@ function ColorPalette( {
);
const colors = isGradientSegment ? defaultGradientColors : defaultColors;

const customIndicatorColor = isGradientSegment
? activeColor
: customSwatchGradients;
const isCustomGradientColor = isGradientColor && isSelectedCustom();
const shouldShowCustomIndicator =
! isGradientSegment || isCustomGradientColor;

const accessibilityHint = isGradientSegment
? __( 'Navigates to customize gradient' )
: __( 'Navigates to custom color picker' );
const customText = isIOS ? __( 'Custom' ) : __( 'CUSTOM' );
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved

useEffect( () => {
scrollViewRef.current.scrollTo( { x: 0, y: 0 } );
if ( scrollViewRef.current ) {
if ( isSelectedCustom() ) {
scrollViewRef.current.scrollToEnd();
} else scrollViewRef.current.scrollTo( { x: 0, y: 0 } );
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved
}
}, [ currentSegment ] );

function isSelectedCustom() {
return (
! isGradientColor && activeColor && ! colors.includes( activeColor )
);
const isWithinColors = activeColor && colors.includes( activeColor );
if ( activeColor ) {
if ( isGradientSegment ) {
return isGradientColor && ! isWithinColors;
}
return ! isGradientColor && ! isWithinColors;
}
return false;
}

function isSelected( color ) {
Expand Down Expand Up @@ -93,16 +124,60 @@ function ColorPalette( {
outputRange: [ 1, 0.7, 1 ],
} );

function deselectCustomGradient() {
const { width } = Dimensions.get( 'window' );
const isVisible =
contentWidth - scrollPosition - customIndicatorWidth < width;

if ( isCustomGradientColor ) {
performLayoutAnimation();
if ( ! isIOS ) {
// Scroll position on Android doesn't adjust automatically when removing the last item from the horizontal list.
// https://github.com/facebook/react-native/issues/27504
// Workaround: Force the scroll when deselecting custom gradient color and when custom indicator is visible on layout.
if (
isCustomGradientColor &&
isVisible &&
scrollViewRef.current
) {
scrollViewRef.current.scrollTo( {
x: scrollPosition - customIndicatorWidth,
} );
}
}
}
}

function onColorPress( color ) {
deselectCustomGradient();
performAnimation( color );
setColor( color );
}

function onContentSizeChange( width ) {
contentWidth = width;
if ( isSelectedCustom() && scrollViewRef.current ) {
scrollViewRef.current.scrollToEnd( { animated: ! isIOS } );
}
}

function onCustomIndicatorLayout( { nativeEvent } ) {
const { width } = nativeEvent.layout;
if ( width !== customIndicatorWidth ) {
customIndicatorWidth = width;
}
}

const verticalSeparatorStyle = usePreferredColorSchemeStyle(
styles.verticalSeparator,
styles.verticalSeparatorDark
);

const customTextStyle = usePreferredColorSchemeStyle(
[ styles.customText, ! isIOS && styles.customTextAndroid ],
styles.customTextDark
);

return (
<ScrollView
contentContainerStyle={ styles.contentContainer }
Expand All @@ -111,6 +186,10 @@ function ColorPalette( {
showsHorizontalScrollIndicator={ false }
keyboardShouldPersistTaps="always"
disableScrollViewPanResponder
onScroll={ ( { nativeEvent } ) =>
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved
( scrollPosition = nativeEvent.contentOffset.x )
}
onContentSizeChange={ onContentSizeChange }
onScrollBeginDrag={ () => shouldEnableBottomSheetScroll( false ) }
onScrollEndDrag={ () => shouldEnableBottomSheetScroll( true ) }
ref={ scrollViewRef }
Expand All @@ -121,6 +200,9 @@ function ColorPalette( {
<TouchableWithoutFeedback
onPress={ () => onColorPress( color ) }
key={ `${ color }-${ isSelected( color ) }` }
accessibilityRole={ 'button' }
accessibilityState={ { selected: isSelected( color ) } }
accessibilityHint={ color }
>
<Animated.View
style={ {
Expand All @@ -141,20 +223,31 @@ function ColorPalette( {
</TouchableWithoutFeedback>
);
} ) }
{ ! isGradientSegment && (
<>
{ shouldShowCustomIndicator && (
<View
style={ styles.customIndicatorWrapper }
onLayout={ onCustomIndicatorLayout }
>
<View style={ verticalSeparatorStyle } />
<TouchableWithoutFeedback onPress={ onCustomPress }>
<View>
<TouchableWithoutFeedback
onPress={ onCustomPress }
accessibilityRole={ 'button' }
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved
accessibilityState={ { selected: isSelectedCustom() } }
accessibilityHint={ accessibilityHint }
>
<View style={ styles.customIndicatorWrapper }>
<ColorIndicator
withCustomPicker={ ! isGradientSegment }
color={ customSwatchGradients }
color={ customIndicatorColor }
isSelected={ isSelectedCustom() }
style={ styles.colorIndicator }
/>
<Text style={ customTextStyle }>
{ customText }
</Text>
</View>
</TouchableWithoutFeedback>
</>
</View>
) }
</ScrollView>
);
Expand Down
19 changes: 19 additions & 0 deletions packages/components/src/color-palette/style.native.scss
Original file line number Diff line number Diff line change
Expand Up @@ -23,3 +23,22 @@
margin-top: 12px;
margin-bottom: 12px;
}

.customIndicatorWrapper {
flex-direction: row;
align-items: center;
}

.customText {
font-size: 16px;
color: $gray-dark;
}

.customTextDark {
color: $white;
}

.customTextAndroid {
letter-spacing: 1.25;
font-weight: medium;
}
Loading