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] Button Block #18823

Merged
merged 55 commits into from
Feb 6, 2020
Merged
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
55 commits
Select commit Hold shift + click to select a range
4db1d06
Initial work on Button block
lukewalczak Nov 18, 2019
529c5c5
Some button styling
lukewalczak Nov 20, 2019
93b20ee
Do some tweaks on android
lukewalczak Nov 20, 2019
2c20d97
Some styling and connect link settings
lukewalczak Nov 21, 2019
4d1ec1a
Support borderRadius
lukewalczak Nov 21, 2019
a63deac
Adjust to dark mode
lukewalczak Nov 22, 2019
b40e1dc
Add a RichText wrapper with LinearGradient
lukewalczak Nov 25, 2019
41460ce
Merge branch 'master' into rnmobile/button-block
lukewalczak Nov 25, 2019
829b492
Extract RichText wrapper
lukewalczak Nov 29, 2019
efe4e1f
Update test setup.js
lukewalczak Nov 29, 2019
1fc7530
Refactor border width
lukewalczak Dec 2, 2019
7dba9e2
Set max and min width for ios RichText
lukewalczak Dec 2, 2019
c3267a6
Add comments and set max width when screen has horizontal orientation
lukewalczak Dec 3, 2019
f85d2d8
Extract NotificationSheet to separate file
lukewalczak Dec 4, 2019
148ff59
Move NotifcationSheet to components
lukewalczak Dec 6, 2019
7c2fe18
Merge branch 'master' into rnmobile/button-block
lukewalczak Dec 9, 2019
2e1593b
Set isFocused on true by default
lukewalczak Dec 9, 2019
8fef323
fix jumping height android
dratwas Dec 10, 2019
3c5c33f
Improve a11y and small refactor
lukewalczak Dec 10, 2019
8408db3
Merge branch 'rnmobile/button-block' of github.com:WordPress/gutenber…
lukewalczak Dec 10, 2019
8e6d119
Move variables to styles
lukewalczak Dec 10, 2019
c54f727
Update setting background color
lukewalczak Dec 13, 2019
79e3fa9
Merge branch 'master' into rnmobile/button-block
lukewalczak Dec 13, 2019
133a70e
Changes in NotificationSheet and Settings
lukewalczak Dec 17, 2019
bc812a6
Rewrite mobile button block to class component
lukewalczak Dec 17, 2019
31c38b4
Rewrite functions
lukewalczak Dec 17, 2019
a1695a5
Use isFocused() method
lukewalczak Dec 17, 2019
0f314dd
Merge branch 'master' into rnmobile/button-block
lukewalczak Jan 7, 2020
04fda2b
Rename files
lukewalczak Jan 9, 2020
f63a741
Create separate settings for mobile Button
lukewalczak Jan 13, 2020
5820f83
Remove notification bottom sheet
lukewalczak Jan 13, 2020
4ad4755
Rename component and comment logic
lukewalczak Jan 14, 2020
4ddfa2a
Merge branch 'master' into rnmobile/button-block
lukewalczak Jan 14, 2020
f8780c5
Replace MissingControl in favor of UnsupportedFooterControl
lukewalczak Jan 15, 2020
39eb5dd
Adjust link modal for Button block purposes
lukewalczak Jan 16, 2020
0e4c4d2
Small cleanup
lukewalczak Jan 16, 2020
483c6e8
Fix test
lukewalczak Jan 17, 2020
10f41e3
Merge branch 'master' into rnmobile/button-block
lukewalczak Jan 17, 2020
7fc9a61
Try to fix mobile test
lukewalczak Jan 17, 2020
8b20d5e
Adjust button styling after uploading the latest changes
lukewalczak Jan 17, 2020
f02b085
Replace Dashicon in favor of Icon in native cell component
lukewalczak Jan 21, 2020
71a365b
Fix overriding existing URL in bottom sheet
lukewalczak Jan 22, 2020
cc54861
Making handlers more consistent
lukewalczak Jan 22, 2020
26a50e1
Revert changes in link settings and build custom adjusted for Button …
lukewalczak Jan 23, 2020
9b9c8db
Fix test
lukewalczak Jan 23, 2020
e0eb655
Correct condition
lukewalczak Jan 23, 2020
ecc442e
Correct focusing RichText within Button
lukewalczak Jan 24, 2020
ee1d767
Unify isButtonFocused for both platforms
lukewalczak Jan 24, 2020
dff4a05
Merge branch 'master' into rnmobile/button-block
lukewalczak Jan 28, 2020
829fd08
Merge branch 'master' into rnmobile/button-block
lukewalczak Jan 31, 2020
a28a322
Merge branch 'master' into rnmobile/button-block
lukewalczak Feb 3, 2020
e758b9c
Fix lint issues after merge
lukewalczak Feb 3, 2020
e6452d4
Reuse controls
lukewalczak Feb 4, 2020
3b27ecf
Adjust reused components and add caret color
lukewalczak Feb 4, 2020
a646031
Merge branch 'master' into rnmobile/button-block
lukewalczak Feb 6, 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
1 change: 1 addition & 0 deletions packages/block-editor/src/components/index.native.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ export { default as BlockFormatControls } from './block-format-controls';
export { default as BlockIcon } from './block-icon';
export { default as BlockVerticalAlignmentToolbar } from './block-vertical-alignment-toolbar';
export * from './colors';
export * from './gradients';
export * from './font-sizes';
export { default as AlignmentToolbar } from './alignment-toolbar';
export { default as InnerBlocks } from './inner-blocks';
Expand Down
201 changes: 201 additions & 0 deletions packages/block-library/src/button/edit.native.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,201 @@
/**
* External dependencies
*/
import { View, Dimensions, InteractionManager } from 'react-native';
/**
* WordPress dependencies
*/
import {
withInstanceId,
compose,
} from '@wordpress/compose';
import { __ } from '@wordpress/i18n';
import {
RichText,
withColors,
InspectorControls,
__experimentalUseGradient,
} from '@wordpress/block-editor';
import {
TextControl,
ToggleControl,
PanelBody,
RangeControl,
MissingControl,
NotificationSheet,
} from '@wordpress/components';
import {
useCallback,
useState,
} from '@wordpress/element';
import { withDispatch } from '@wordpress/data';

/**
* Internal dependencies
*/
import richTextStyle from './richText.scss';
import styles from './editor.scss';
import RichTextWrapper from './richTextWrapper';

const NEW_TAB_REL = 'noreferrer noopener';
const INITIAL_BORDER_RADIUS = 4;
const MIN_BORDER_RADIUS_VALUE = 0;
const MAX_BORDER_RADIUS_VALUE = 50;
const BORDER_WIDTH = 1;
const BLOCK_SPACING = 4;

function ButtonEdit( { attributes, setAttributes, backgroundColor, textColor, isSelected, closeGeneralSidebar } ) {
const {
placeholder,
text,
borderRadius,
url,
linkTarget,
rel,
} = attributes;

const [ isFocused, setRichTextFocus ] = useState( true );
const [ showHelp, setShowHelp ] = useState( false );

const borderRadiusValue = borderRadius !== undefined ? borderRadius : INITIAL_BORDER_RADIUS;
const mainColor = backgroundColor.color || '#595959';
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved
const outlineBorderRadius = borderRadiusValue > 0 ? borderRadiusValue + BLOCK_SPACING + BORDER_WIDTH : 0;

const onToggleOpenInNewTab = useCallback(
( value ) => {
const newLinkTarget = value ? '_blank' : undefined;

let updatedRel = rel;
if ( newLinkTarget && ! rel ) {
updatedRel = NEW_TAB_REL;
} else if ( ! newLinkTarget && rel === NEW_TAB_REL ) {
updatedRel = undefined;
}

setAttributes( {
linkTarget: newLinkTarget,
rel: updatedRel,
} );
},
[ rel, setAttributes ]
);

const setBorderRadius = ( value ) => {
setAttributes( {
borderRadius: value,
} );
};

const toggleShowNoticationSheet = () => {
setShowHelp( ! showHelp );
};

const openNotificationSheet = () => {
closeGeneralSidebar();
InteractionManager.runAfterInteractions( () => {
toggleShowNoticationSheet();
} );
};

const {
gradientValue,
} = __experimentalUseGradient();

// 2 * container padding (32) + 2 * rich text padding (32) + 2 * BLOCK_SPACING (8) + 2 * BORDER_WIDTH = 74
// 580 is a max width when screen has horizontal orientation. Value comes from `ReadableContentView` styles.
const maxWidth = Math.min( Dimensions.get( 'window' ).width - 74, 580 - 74 );
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved
// To achieve proper expanding and shrinking `RichText` on iOS, there is a need to set a `minWidth`
// value at least on 1 when `RichText` is focused or when is not focused, but `RichText` value is
// different than empty string.
const minWidth = isFocused || ( ! isFocused && text && text !== '' ) ? 1 : 108;
// To achieve proper expanding and shrinking `RichText` on Android, there is a need to set
// a `placeholder` as an empty string when `RichText` is focused,
// because `AztecView` is calculating a `minWidth` based on placeholder text.
const placeholderText = isFocused ? '' : ( placeholder || __( 'Add text…' ) );

return (
<View
style={ [
styles.container,
isSelected && {
borderColor: mainColor,
borderRadius: outlineBorderRadius,
borderWidth: BORDER_WIDTH,
},
] }
>
<RichTextWrapper
gradientValue={ gradientValue }
borderRadiusValue={ borderRadiusValue }
backgroundColor={ mainColor }
>
<RichText
placeholder={ placeholderText }
value={ text }
onChange={ ( value ) => setAttributes( { text: value } ) }
style={ {
...richTextStyle.richText,
color: textColor.color || '#fff',
} }
textAlign="center"
placeholderTextColor={ 'lightgray' }
tagName="p"
minWidth={ minWidth }
maxWidth={ maxWidth }
unstableOnFocus={ () => setRichTextFocus( true ) }
onBlur={ () => setRichTextFocus( false ) }
/>
</RichTextWrapper>
<InspectorControls>
<PanelBody title={ __( 'Border Settings' ) } >
<RangeControl
label={ __( 'Border Radius' ) }
minimumValue={ MIN_BORDER_RADIUS_VALUE }
maximumValue={ MAX_BORDER_RADIUS_VALUE }
value={ borderRadiusValue }
onChange={ setBorderRadius }
separatorType="none"
/>
</PanelBody>
<PanelBody title={ __( 'Link Settings' ) } >
<ToggleControl
label={ __( 'Open in new tab' ) }
checked={ linkTarget === '_blank' }
onChange={ onToggleOpenInNewTab }
separatorType="fullWidth"
/>
<TextControl
label={ __( 'Link Rel' ) }
value={ url || '' }
valuePlaceholder={ __( 'Add URL' ) }
onChange={ ( value ) => setAttributes( { url: value } ) }
autoCapitalize="none"
autoCorrect={ false }
separatorType="none"
keyboardType="url"
/>
</PanelBody>
<PanelBody title={ __( 'Color Settings' ) } >
<MissingControl
label={ __( 'Coming Soon' ) }
onPress={ openNotificationSheet }
separatorType="none"
/>
</PanelBody>
</InspectorControls>
<NotificationSheet title="Color Settings" isVisible={ showHelp } onClose={ toggleShowNoticationSheet } type="plural" />
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved
</View>
);
}

export default compose( [
withInstanceId,
withColors( 'backgroundColor', { textColor: 'color' } ),
withDispatch( ( dispatch ) => {
const { closeGeneralSidebar } = dispatch( 'core/edit-post' );

return {
closeGeneralSidebar,
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved
};
} ),
] )( ButtonEdit );
15 changes: 15 additions & 0 deletions packages/block-library/src/button/editor.native.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
.richTextWrapper {
overflow: hidden;
align-self: flex-start;
}

.container {
padding: $block-spacing;
background-color: transparent;
align-self: flex-start;
}

.outlineBorder {
border-width: $border-width;
}

7 changes: 7 additions & 0 deletions packages/block-library/src/button/richText.android.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
.richText {
background-color: transparent;
padding-left: $panel-padding;
padding-right: $panel-padding;
margin-left: $panel-padding / 2;
margin-right: $panel-padding / 2;
}
4 changes: 4 additions & 0 deletions packages/block-library/src/button/richText.ios.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
.richText {
margin: 10px $panel-padding;
background-color: transparent;
}
58 changes: 58 additions & 0 deletions packages/block-library/src/button/richTextWrapper.native.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
/**
lukewalczak marked this conversation as resolved.
Show resolved Hide resolved
* External dependencies
*/
import { View } from 'react-native';
import LinearGradient from 'react-native-linear-gradient';
/**
* Internal dependencies
*/
import styles from './editor.scss';

function RichTextWrapper( { children, gradientValue, borderRadiusValue, backgroundColor } ) {
const wrapperStyles = [
styles.richTextWrapper,
{
borderRadius: borderRadiusValue,
backgroundColor,
},
];

function transformGradient() {
const matchColorGroup = /(rgba|rgb|#)(.+?)[\%]/g;
const matchDeg = /(\d.+)deg/g;

const colorGroup = gradientValue.match( matchColorGroup ).map( ( color ) => color.split( ' ' ) );

const colors = colorGroup.map( ( color ) => color[ 0 ] );
const locations = colorGroup.map( ( location ) => Number( location[ 1 ].replace( '%', '' ) ) / 100 );
const angle = Number( matchDeg.exec( gradientValue )[ 1 ] );

return {
colors, locations, angle,
};
}

if ( gradientValue ) {
const { colors, locations, angle } = transformGradient();
return (
<LinearGradient
colors={ colors }
useAngle={ true }
angle={ angle }
locations={ locations }
angleCenter={ { x: 0.5, y: 0.5 } }
style={ wrapperStyles }
>
{ children }
</LinearGradient>
);
} return (
<View
style={ wrapperStyles }
>
{ children }
</View>
);
}

export default RichTextWrapper;
2 changes: 2 additions & 0 deletions packages/block-library/src/index.native.js
Original file line number Diff line number Diff line change
Expand Up @@ -151,6 +151,8 @@ export const registerCoreBlocks = () => {
( ( Platform.OS === 'ios' ) || ( !! __DEV__ ) ) ? preformatted : null,
// eslint-disable-next-line no-undef
!! __DEV__ ? group : null,
// eslint-disable-next-line no-undef
!! __DEV__ ? button : null,
spacer,
].forEach( registerBlock );

Expand Down
42 changes: 4 additions & 38 deletions packages/block-library/src/missing/edit.native.js
Original file line number Diff line number Diff line change
@@ -1,17 +1,17 @@
/**
* External dependencies
*/
import { Platform, View, Text, TouchableWithoutFeedback } from 'react-native';
import { View, Text, TouchableWithoutFeedback } from 'react-native';

/**
* WordPress dependencies
*/
import { BottomSheet, Icon } from '@wordpress/components';
import { Icon, NotificationSheet } from '@wordpress/components';
import { withPreferredColorScheme } from '@wordpress/compose';
import { coreBlocks } from '@wordpress/block-library';
import { normalizeIconObject } from '@wordpress/blocks';
import { Component } from '@wordpress/element';
import { __, sprintf } from '@wordpress/i18n';
import { __ } from '@wordpress/i18n';

/**
* Internal dependencies
Expand Down Expand Up @@ -52,40 +52,6 @@ export class UnsupportedBlockEdit extends Component {
);
}

renderSheet( title ) {
const { getStylesFromColorScheme } = this.props;
const infoTextStyle = getStylesFromColorScheme( styles.infoText, styles.infoTextDark );
const infoTitleStyle = getStylesFromColorScheme( styles.infoTitle, styles.infoTitleDark );
const infoDescriptionStyle = getStylesFromColorScheme( styles.infoDescription, styles.infoDescriptionDark );
const infoSheetIconStyle = getStylesFromColorScheme( styles.infoSheetIcon, styles.infoSheetIconDark );

// translators: %s: Name of the block
const titleFormat = Platform.OS === 'android' ? __( '\'%s\' isn\'t yet supported on WordPress for Android' ) :
__( '\'%s\' isn\'t yet supported on WordPress for iOS' );
const infoTitle = sprintf(
titleFormat,
title,
);

return (
<BottomSheet
isVisible={ this.state.showHelp }
hideHeader
onClose={ this.toggleSheet.bind( this ) }
>
<View style={ styles.infoContainer } >
<Icon icon="editor-help" color={ infoSheetIconStyle.color } size={ styles.infoSheetIcon.size } />
<Text style={ [ infoTextStyle, infoTitleStyle ] }>
{ infoTitle }
</Text>
<Text style={ [ infoTextStyle, infoDescriptionStyle ] }>
{ __( 'We are working hard to add more blocks with each release. In the meantime, you can also edit this post on the web.' ) }
</Text>
</View>
</BottomSheet>
);
}

render() {
const { originalName } = this.props.attributes;
const { getStylesFromColorScheme, preferredColorScheme } = this.props;
Expand All @@ -106,7 +72,7 @@ export class UnsupportedBlockEdit extends Component {
<Icon className={ iconClassName } icon={ icon && icon.src ? icon.src : icon } color={ iconStyle.color } />
<Text style={ titleStyle }>{ title }</Text>
{ subtitle }
{ this.renderSheet( title ) }
<NotificationSheet isVisible={ this.state.showHelp } onClose={ this.toggleSheet.bind( this ) } title={ title } />
</View>
);
}
Expand Down
Loading