Skip to content

Conversation

@Addison-Stavlo
Copy link
Contributor

@Addison-Stavlo Addison-Stavlo commented Mar 26, 2021

Description

I noticed this neat Flex component and went to use it in a vertical/column direction. It seems that currently the vertical orientation (flex-direction: column) is not supported. This PR attempts to add this functionality.

This is slightly odd since the currently existing isReversed function sets the flex-direction css property by assuming row. Lets consider deprecating isReversed in favor of direction. If the isReversed prop is present, a deprecation warning is thrown and the component has the same behavior as it previously did. Otherwise, we go with the new direction prop defaulting to 'row'.

How has this been tested?

Test the component with the deprecated isReversed prop and ensure their are no regressions.
Test the component with the new direction prop and ensure settings work as expected.

Screenshots

Types of changes

Checklist:

  • My code is tested.
  • My code follows the WordPress code style.
  • My code follows the accessibility standards.
  • I've tested my changes with keyboard and screen readers.
  • My code has proper inline documentation.
  • I've included developer documentation if appropriate.
  • I've updated all React Native files affected by any refactorings/renamings in this PR.

Comment on lines 65 to 66
// @ts-ignore
direction={ simplifiedDirection }
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

TS was angry about this potentially being undefined when we have noted it as a string. But if we look at the code above, it would always be a string. So @ts-ignore for now unless there are better suggestions.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

simplifiedDirection is a string beucase of direction.slice( 0, -8). That's why TS is raging. I'm not sure if it is possible to force a type on a specific variable with JSDoc. simplifiedDirection as FlexDirection could fix the problem in TS.

I think you are better off with an explicit function types-wise:

/** @typedef {import('react').CSSProperties['flexDirection'] | 'row' | 'column'} FlexDirection */
^^^ put this into `/* eslint-disable jsdoc/valid-types */` above OwnProps

 * @property {FlexDirection} direction Sets the flex-direction property.
^^^
and replace the type in OwnProps 


/**
 *
 * @param {FlexDirection} direction
 * @return {FlexDirection} direction
 */
function simplifyDirection( direction ) {
	if ( direction === 'column-reverse' ) {
		return 'column';
	}

	if ( direction === 'row-reverse' ) {
		return 'row';
	}

	return direction;
}

then you can use it like

const simplifiedDirection = simplifyDirection( direction );

and you can remove the @ts-ignore

@github-actions
Copy link

github-actions bot commented Mar 26, 2021

Size Change: +4.68 kB (0%)

Total Size: 1.42 MB

Filename Size Change
build/annotations/index.js 3.78 kB +8 B (0%)
build/api-fetch/index.js 3.42 kB +11 B (0%)
build/block-directory/index.js 8.63 kB +1 B (0%)
build/block-editor/index.js 127 kB +21 B (0%)
build/block-editor/style-rtl.css 12.3 kB -34 B (0%)
build/block-editor/style.css 12.3 kB -34 B (0%)
build/block-library/blocks/button/style-rtl.css 489 B +10 B (+2%)
build/block-library/blocks/button/style.css 488 B +9 B (+2%)
build/block-library/blocks/latest-comments/style-rtl.css 281 B +12 B (+4%)
build/block-library/blocks/latest-comments/style.css 282 B +13 B (+5%) 🔍
build/block-library/blocks/preformatted/style-rtl.css 103 B +40 B (+63%) 🆘
build/block-library/blocks/preformatted/style.css 103 B +40 B (+63%) 🆘
build/block-library/blocks/separator/style-rtl.css 251 B +15 B (+6%) 🔍
build/block-library/blocks/separator/style.css 251 B +15 B (+6%) 🔍
build/block-library/index.js 151 kB +60 B (0%)
build/block-library/reset-rtl.css 375 B -8 B (-2%)
build/block-library/reset.css 376 B -8 B (-2%)
build/block-library/style-rtl.css 8.98 kB +29 B (0%)
build/block-library/style.css 8.99 kB +32 B (0%)
build/block-library/theme-rtl.css 692 B -2 B (0%)
build/block-library/theme.css 693 B -3 B (0%)
build/block-serialization-default-parser/index.js 1.87 kB -1 B (0%)
build/blocks/index.js 48.4 kB +16 B (0%)
build/components/index.js 288 kB +2.27 kB (+1%)
build/compose/index.js 11.2 kB -3 B (0%)
build/core-data/index.js 16.8 kB +8 B (0%)
build/customize-widgets/index.js 7.33 kB +1.3 kB (+22%) 🚨
build/customize-widgets/style-rtl.css 676 B +298 B (+79%) 🆘
build/customize-widgets/style.css 677 B +298 B (+79%) 🆘
build/data/index.js 8.88 kB +5 B (0%)
build/dom/index.js 4.99 kB +15 B (0%)
build/edit-navigation/index.js 17 kB +9 B (0%)
build/edit-post/index.js 307 kB +21 B (0%)
build/edit-site/index.js 27.5 kB +16 B (0%)
build/edit-widgets/index.js 15.8 kB +123 B (+1%)
build/editor/index.js 42.7 kB +9 B (0%)
build/element/index.js 4.62 kB +7 B (0%)
build/format-library/index.js 6.76 kB +4 B (0%)
build/hooks/index.js 2.28 kB +1 B (0%)
build/i18n/index.js 4.01 kB +4 B (0%)
build/keyboard-shortcuts/index.js 2.53 kB +4 B (0%)
build/keycodes/index.js 1.96 kB +8 B (0%)
build/media-utils/index.js 5.39 kB +5 B (0%)
build/notices/index.js 1.85 kB +3 B (0%)
build/nux/index.js 3.42 kB +4 B (0%)
build/plugins/index.js 2.95 kB +2 B (0%)
build/primitives/index.js 1.42 kB +5 B (0%)
build/reusable-blocks/index.js 3.79 kB +8 B (0%)
build/rich-text/index.js 13.5 kB +2 B (0%)
build/server-side-render/index.js 2.6 kB +6 B (0%)
build/token-list/index.js 1.27 kB -1 B (0%)
build/url/index.js 3.02 kB +5 B (0%)
build/wordcount/index.js 1.22 kB +1 B (0%)
ℹ️ View Unchanged
Filename Size Change
build/a11y/index.js 1.14 kB 0 B
build/autop/index.js 2.82 kB 0 B
build/blob/index.js 665 B 0 B
build/block-directory/style-rtl.css 1 kB 0 B
build/block-directory/style.css 1.01 kB 0 B
build/block-library/blocks/archives/editor-rtl.css 61 B 0 B
build/block-library/blocks/archives/editor.css 60 B 0 B
build/block-library/blocks/audio/editor-rtl.css 58 B 0 B
build/block-library/blocks/audio/editor.css 58 B 0 B
build/block-library/blocks/audio/style-rtl.css 112 B 0 B
build/block-library/blocks/audio/style.css 112 B 0 B
build/block-library/blocks/block/editor-rtl.css 161 B 0 B
build/block-library/blocks/block/editor.css 161 B 0 B
build/block-library/blocks/button/editor-rtl.css 475 B 0 B
build/block-library/blocks/button/editor.css 474 B 0 B
build/block-library/blocks/buttons/editor-rtl.css 315 B 0 B
build/block-library/blocks/buttons/editor.css 315 B 0 B
build/block-library/blocks/buttons/style-rtl.css 364 B 0 B
build/block-library/blocks/buttons/style.css 363 B 0 B
build/block-library/blocks/calendar/style-rtl.css 208 B 0 B
build/block-library/blocks/calendar/style.css 208 B 0 B
build/block-library/blocks/categories/editor-rtl.css 84 B 0 B
build/block-library/blocks/categories/editor.css 83 B 0 B
build/block-library/blocks/categories/style-rtl.css 79 B 0 B
build/block-library/blocks/categories/style.css 79 B 0 B
build/block-library/blocks/code/style-rtl.css 90 B 0 B
build/block-library/blocks/code/style.css 90 B 0 B
build/block-library/blocks/columns/editor-rtl.css 190 B 0 B
build/block-library/blocks/columns/editor.css 190 B 0 B
build/block-library/blocks/columns/style-rtl.css 436 B 0 B
build/block-library/blocks/columns/style.css 435 B 0 B
build/block-library/blocks/cover/editor-rtl.css 605 B 0 B
build/block-library/blocks/cover/editor.css 605 B 0 B
build/block-library/blocks/cover/style-rtl.css 1.23 kB 0 B
build/block-library/blocks/cover/style.css 1.23 kB 0 B
build/block-library/blocks/embed/editor-rtl.css 486 B 0 B
build/block-library/blocks/embed/editor.css 486 B 0 B
build/block-library/blocks/embed/style-rtl.css 401 B 0 B
build/block-library/blocks/embed/style.css 400 B 0 B
build/block-library/blocks/file/editor-rtl.css 175 B 0 B
build/block-library/blocks/file/editor.css 174 B 0 B
build/block-library/blocks/file/style-rtl.css 248 B 0 B
build/block-library/blocks/file/style.css 248 B 0 B
build/block-library/blocks/freeform/editor-rtl.css 2.44 kB 0 B
build/block-library/blocks/freeform/editor.css 2.44 kB 0 B
build/block-library/blocks/gallery/editor-rtl.css 704 B 0 B
build/block-library/blocks/gallery/editor.css 705 B 0 B
build/block-library/blocks/gallery/style-rtl.css 1.09 kB 0 B
build/block-library/blocks/gallery/style.css 1.09 kB 0 B
build/block-library/blocks/group/editor-rtl.css 160 B 0 B
build/block-library/blocks/group/editor.css 160 B 0 B
build/block-library/blocks/group/style-rtl.css 57 B 0 B
build/block-library/blocks/group/style.css 57 B 0 B
build/block-library/blocks/heading/editor-rtl.css 129 B 0 B
build/block-library/blocks/heading/editor.css 129 B 0 B
build/block-library/blocks/heading/style-rtl.css 76 B 0 B
build/block-library/blocks/heading/style.css 76 B 0 B
build/block-library/blocks/html/editor-rtl.css 281 B 0 B
build/block-library/blocks/html/editor.css 281 B 0 B
build/block-library/blocks/image/editor-rtl.css 717 B 0 B
build/block-library/blocks/image/editor.css 716 B 0 B
build/block-library/blocks/image/style-rtl.css 476 B 0 B
build/block-library/blocks/image/style.css 478 B 0 B
build/block-library/blocks/latest-posts/editor-rtl.css 137 B 0 B
build/block-library/blocks/latest-posts/editor.css 137 B 0 B
build/block-library/blocks/latest-posts/style-rtl.css 523 B 0 B
build/block-library/blocks/latest-posts/style.css 522 B 0 B
build/block-library/blocks/legacy-widget/editor-rtl.css 398 B 0 B
build/block-library/blocks/legacy-widget/editor.css 399 B 0 B
build/block-library/blocks/list/style-rtl.css 63 B 0 B
build/block-library/blocks/list/style.css 63 B 0 B
build/block-library/blocks/media-text/editor-rtl.css 191 B 0 B
build/block-library/blocks/media-text/editor.css 191 B 0 B
build/block-library/blocks/media-text/style-rtl.css 535 B 0 B
build/block-library/blocks/media-text/style.css 532 B 0 B
build/block-library/blocks/more/editor-rtl.css 434 B 0 B
build/block-library/blocks/more/editor.css 434 B 0 B
build/block-library/blocks/navigation-link/editor-rtl.css 634 B 0 B
build/block-library/blocks/navigation-link/editor.css 635 B 0 B
build/block-library/blocks/navigation-link/style-rtl.css 908 B 0 B
build/block-library/blocks/navigation-link/style.css 908 B 0 B
build/block-library/blocks/navigation/editor-rtl.css 1.13 kB 0 B
build/block-library/blocks/navigation/editor.css 1.13 kB 0 B
build/block-library/blocks/navigation/style-rtl.css 204 B 0 B
build/block-library/blocks/navigation/style.css 205 B 0 B
build/block-library/blocks/nextpage/editor-rtl.css 395 B 0 B
build/block-library/blocks/nextpage/editor.css 395 B 0 B
build/block-library/blocks/page-list/editor-rtl.css 170 B 0 B
build/block-library/blocks/page-list/editor.css 170 B 0 B
build/block-library/blocks/page-list/style-rtl.css 167 B 0 B
build/block-library/blocks/page-list/style.css 167 B 0 B
build/block-library/blocks/paragraph/editor-rtl.css 157 B 0 B
build/block-library/blocks/paragraph/editor.css 157 B 0 B
build/block-library/blocks/paragraph/style-rtl.css 247 B 0 B
build/block-library/blocks/paragraph/style.css 248 B 0 B
build/block-library/blocks/post-author/editor-rtl.css 209 B 0 B
build/block-library/blocks/post-author/editor.css 209 B 0 B
build/block-library/blocks/post-author/style-rtl.css 183 B 0 B
build/block-library/blocks/post-author/style.css 184 B 0 B
build/block-library/blocks/post-comments-form/style-rtl.css 250 B 0 B
build/block-library/blocks/post-comments-form/style.css 250 B 0 B
build/block-library/blocks/post-content/editor-rtl.css 139 B 0 B
build/block-library/blocks/post-content/editor.css 139 B 0 B
build/block-library/blocks/post-excerpt/editor-rtl.css 73 B 0 B
build/block-library/blocks/post-excerpt/editor.css 73 B 0 B
build/block-library/blocks/post-featured-image/editor-rtl.css 338 B 0 B
build/block-library/blocks/post-featured-image/editor.css 338 B 0 B
build/block-library/blocks/post-featured-image/style-rtl.css 100 B 0 B
build/block-library/blocks/post-featured-image/style.css 100 B 0 B
build/block-library/blocks/pullquote/editor-rtl.css 183 B 0 B
build/block-library/blocks/pullquote/editor.css 183 B 0 B
build/block-library/blocks/pullquote/style-rtl.css 318 B 0 B
build/block-library/blocks/pullquote/style.css 318 B 0 B
build/block-library/blocks/query-loop/editor-rtl.css 83 B 0 B
build/block-library/blocks/query-loop/editor.css 82 B 0 B
build/block-library/blocks/query-loop/style-rtl.css 315 B 0 B
build/block-library/blocks/query-loop/style.css 317 B 0 B
build/block-library/blocks/query-pagination-numbers/editor-rtl.css 122 B 0 B
build/block-library/blocks/query-pagination-numbers/editor.css 121 B 0 B
build/block-library/blocks/query-pagination/editor-rtl.css 270 B 0 B
build/block-library/blocks/query-pagination/editor.css 262 B 0 B
build/block-library/blocks/query-pagination/style-rtl.css 168 B 0 B
build/block-library/blocks/query-pagination/style.css 168 B 0 B
build/block-library/blocks/query-title/editor-rtl.css 86 B 0 B
build/block-library/blocks/query-title/editor.css 86 B 0 B
build/block-library/blocks/query/editor-rtl.css 795 B 0 B
build/block-library/blocks/query/editor.css 794 B 0 B
build/block-library/blocks/quote/style-rtl.css 169 B 0 B
build/block-library/blocks/quote/style.css 169 B 0 B
build/block-library/blocks/rss/editor-rtl.css 201 B 0 B
build/block-library/blocks/rss/editor.css 202 B 0 B
build/block-library/blocks/rss/style-rtl.css 290 B 0 B
build/block-library/blocks/rss/style.css 290 B 0 B
build/block-library/blocks/search/editor-rtl.css 165 B 0 B
build/block-library/blocks/search/editor.css 165 B 0 B
build/block-library/blocks/search/style-rtl.css 342 B 0 B
build/block-library/blocks/search/style.css 344 B 0 B
build/block-library/blocks/separator/editor-rtl.css 99 B 0 B
build/block-library/blocks/separator/editor.css 99 B 0 B
build/block-library/blocks/shortcode/editor-rtl.css 512 B 0 B
build/block-library/blocks/shortcode/editor.css 512 B 0 B
build/block-library/blocks/site-logo/editor-rtl.css 201 B 0 B
build/block-library/blocks/site-logo/editor.css 201 B 0 B
build/block-library/blocks/site-logo/style-rtl.css 115 B 0 B
build/block-library/blocks/site-logo/style.css 115 B 0 B
build/block-library/blocks/social-link/editor-rtl.css 164 B 0 B
build/block-library/blocks/social-link/editor.css 165 B 0 B
build/block-library/blocks/social-links/editor-rtl.css 776 B 0 B
build/block-library/blocks/social-links/editor.css 776 B 0 B
build/block-library/blocks/social-links/style-rtl.css 1.32 kB 0 B
build/block-library/blocks/social-links/style.css 1.33 kB 0 B
build/block-library/blocks/spacer/editor-rtl.css 317 B 0 B
build/block-library/blocks/spacer/editor.css 317 B 0 B
build/block-library/blocks/spacer/style-rtl.css 48 B 0 B
build/block-library/blocks/spacer/style.css 48 B 0 B
build/block-library/blocks/table/editor-rtl.css 478 B 0 B
build/block-library/blocks/table/editor.css 478 B 0 B
build/block-library/blocks/table/style-rtl.css 402 B 0 B
build/block-library/blocks/table/style.css 402 B 0 B
build/block-library/blocks/tag-cloud/editor-rtl.css 118 B 0 B
build/block-library/blocks/tag-cloud/editor.css 118 B 0 B
build/block-library/blocks/tag-cloud/style-rtl.css 94 B 0 B
build/block-library/blocks/tag-cloud/style.css 94 B 0 B
build/block-library/blocks/template-part/editor-rtl.css 552 B 0 B
build/block-library/blocks/template-part/editor.css 551 B 0 B
build/block-library/blocks/term-description/editor-rtl.css 90 B 0 B
build/block-library/blocks/term-description/editor.css 90 B 0 B
build/block-library/blocks/text-columns/editor-rtl.css 95 B 0 B
build/block-library/blocks/text-columns/editor.css 95 B 0 B
build/block-library/blocks/text-columns/style-rtl.css 166 B 0 B
build/block-library/blocks/text-columns/style.css 166 B 0 B
build/block-library/blocks/verse/editor-rtl.css 50 B 0 B
build/block-library/blocks/verse/editor.css 50 B 0 B
build/block-library/blocks/verse/style-rtl.css 87 B 0 B
build/block-library/blocks/verse/style.css 87 B 0 B
build/block-library/blocks/video/editor-rtl.css 504 B 0 B
build/block-library/blocks/video/editor.css 503 B 0 B
build/block-library/blocks/video/style-rtl.css 173 B 0 B
build/block-library/blocks/video/style.css 173 B 0 B
build/block-library/common-rtl.css 1.1 kB 0 B
build/block-library/common.css 1.1 kB 0 B
build/block-library/editor-rtl.css 9.54 kB 0 B
build/block-library/editor.css 9.53 kB 0 B
build/block-serialization-spec-parser/index.js 3.06 kB 0 B
build/components/style-rtl.css 16.2 kB 0 B
build/components/style.css 16.2 kB 0 B
build/data-controls/index.js 838 B 0 B
build/date/index.js 31.9 kB 0 B
build/deprecated/index.js 787 B 0 B
build/dom-ready/index.js 577 B 0 B
build/edit-navigation/style-rtl.css 2.68 kB 0 B
build/edit-navigation/style.css 2.68 kB 0 B
build/edit-post/style-rtl.css 7.04 kB 0 B
build/edit-post/style.css 7.03 kB 0 B
build/edit-site/style-rtl.css 4.5 kB 0 B
build/edit-site/style.css 4.5 kB 0 B
build/edit-widgets/style-rtl.css 2.97 kB 0 B
build/edit-widgets/style.css 2.98 kB 0 B
build/editor/style-rtl.css 3.95 kB 0 B
build/editor/style.css 3.95 kB 0 B
build/escape-html/index.js 735 B 0 B
build/format-library/style-rtl.css 637 B 0 B
build/format-library/style.css 639 B 0 B
build/html-entities/index.js 622 B 0 B
build/is-shallow-equal/index.js 699 B 0 B
build/list-reusable-blocks/index.js 3.19 kB 0 B
build/list-reusable-blocks/style-rtl.css 629 B 0 B
build/list-reusable-blocks/style.css 628 B 0 B
build/nux/style-rtl.css 731 B 0 B
build/nux/style.css 727 B 0 B
build/priority-queue/index.js 790 B 0 B
build/react-i18n/index.js 1.46 kB 0 B
build/redux-routine/index.js 2.84 kB 0 B
build/reusable-blocks/style-rtl.css 225 B 0 B
build/reusable-blocks/style.css 225 B 0 B
build/shortcode/index.js 1.7 kB 0 B
build/viewport/index.js 1.86 kB 0 B
build/warning/index.js 1.14 kB 0 B

compressed-size-action

@Addison-Stavlo Addison-Stavlo added the [Package] Components /packages/components label Mar 26, 2021
@Copons
Copy link
Contributor

Copons commented Mar 26, 2021

This means the following 3 examples would have the same result:

<Flex direction="column-reverse" />
<Flex direction="column-reverse" isReversed />
<Flex direction="column" isReversed />

I'm not quite a fan of this. 🤔
At a quick glance, I'd expect <Flex direction="column-reverse" isReversed /> to output flex-direction: column.

If we want to support flex-direction's *-reverse values, we should just remove the isReversed prop altogether, and create a deprecation path to convert isReversed to *-reverse.

Otherwise, we might as well keep isReversed and use it as a flag to reverse whatever value is in the direction prop.

@sarayourfriend
Copy link
Contributor

Given the conflict with direction I'd rather we went ahead and deprecated the isReversed prop and updated everything to just use direction, with a shim at the top level of Flex to transform isReversed into a either row-reverse or row when it is passed in expicitly, otherwise using direction.

@Addison-Stavlo
Copy link
Contributor Author

Given the conflict with direction I'd rather we went ahead and deprecated the isReversed prop and updated everything to just use direction, with a shim at the top level of Flex to transform isReversed into a either row-reverse or row when it is passed in expicitly, otherwise using direction.

I think this makes sense, to clarify:

So would that mean use direction entirely if it is present (and ignore isReversed in that case)? Then if there is no direction but there is isReversed to transform it into the direction value?

@Copons
Copy link
Contributor

Copons commented Mar 26, 2021

I was thinking something like this:

function Flex( { direction, isReversed } ) {
  const directionArray = direction.split( '-' );
  let actualDirection = direction[0];

  if ( isReversed && directionArray.length === 0 ) {
    actualDirection += '-reverse';
  }

  return <div style={ { flexDirection: actualDirection } } />;
}

@Copons Copons closed this Mar 26, 2021
@Copons
Copy link
Contributor

Copons commented Mar 26, 2021

Sorry for closing, hit the wrong button!

@Copons Copons reopened this Mar 26, 2021
@Addison-Stavlo
Copy link
Contributor Author

I was thinking something like this:

Im confused, in that example if direction = 'column-reverse' and isReversed = false the final direction value would be column. Similarly, if direction = 'column-reverse' and isReversed = true the final direction would still be column. 🤔

@Addison-Stavlo
Copy link
Contributor Author

Going off @sarayourfriend's comment about deprecating isReversed. Im not sure if that means:

direction overrides isReversed:

function Flex( { direction, isReversed } ) {
     const deprecatedDirection = isReversed ? 'row-reverse' : 'row';
     const actualDirection = direction ? direction : deprecatedDirection;
  
  return <div style={ { flex-direction: actuaDirection } } />

or
isReversed overrides direction:

function Flex( { direction, isReversed } ) {
     let actualDirection = direction;
     if ( isReversed || isReversed === false ) {
          actualDirection = isReversed ? 'row-reverse' : 'row'
    }
  
  return <div style={ { flex-direction: actualDirection } } />

or something else?

@Copons
Copy link
Contributor

Copons commented Mar 26, 2021

I was thinking something like this:

Im confused, in that example if direction = 'column-reverse' and isReversed = false the final direction value would be column. Similarly, if direction = 'column-reverse' and isReversed = true the final direction would still be column. 🤔

@Addison-Stavlo let's ignore my error of not considering the difference between undefined and false 😄

Currently the component only support direction (straight, non-reversed), plus isReversed.
If today we deprecate isReversed, we can safely say that all pre-existing usages of Flex using isReversed will have a "non-reversed" direction.

For this reason, I'm inclined to either ignore *-reverse+isReversed and keeping it reversed, or "double-reverting" it.

Don't have a strong opinion either way. I would conceptually like that isReversed would reverse both straight and reversed directions, but it's not a big deal for me. 😄

@Addison-Stavlo
Copy link
Contributor Author

Addison-Stavlo commented Mar 26, 2021

I would conceptually like that isReversed would reverse both straight and reversed directions,

Yeah, that might make the most sense. 🤔

@sarayourfriend
Copy link
Contributor

To me deprecation means this:

function useDirection({ isReversed, direction }) {
  if ( typeof isReversed !== 'undefined' ) {
    deprecated( 'Flex isReversed', { alternative: 'Flex direction="row-reverse"' } );
    if ( isReversed ) {
      return 'row-reverse';
    }
    return 'row';
  }
  
  return direction;
}

And then the component just does:

function Flex( props ) {
  const direction = useDirection( props ):
  const { otherProp } = props;
  
  // ...

That way the component can ignore isReversed entirely.

@Addison-Stavlo
Copy link
Contributor Author

Addison-Stavlo commented Mar 26, 2021

Thanks @sarayourfriend! That clarifies the idea a bit for sure. 😁

This seems to be working as expected with 117dcc7 . There is just 1 small issue I am confused about, the direction prop seems to bleed-through to the wrapping element as well:

Screen Shot 2021-03-26 at 2 14 58 PM

Its probably something super simple, but I am a bit confused at the moment why that prop gets put on the element while others like align and justify do not. 🤔 - resolved

@david-szabo97
Copy link
Member

Works well for me! How about adding some stories?

@david-szabo97
Copy link
Member

Duh, looks like #31297 superseded this PR.

@Addison-Stavlo
Copy link
Contributor Author

Yeah, I'm happy with that 😁 . Now that it is merged il close this out.

@Copons Copons deleted the add/flex-component-direction-option branch April 30, 2021 15:37
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

[Package] Components /packages/components

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants