Skip to content

Commit

Permalink
RichText: improve format boundary style (#14519)
Browse files Browse the repository at this point in the history
* RichText: improve format boundary style

* rgb => rgba
  • Loading branch information
ellatrix authored Mar 21, 2019
1 parent 98a19b6 commit 91269ae
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 32 deletions.
34 changes: 32 additions & 2 deletions packages/block-editor/src/components/rich-text/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,13 @@ const INSERTION_INPUT_TYPES_TO_IGNORE = new Set( [
'insertLink',
] );

/**
* Global stylesheet.
*/
const globalStyle = document.createElement( 'style' );

document.head.appendChild( globalStyle );

export class RichText extends Component {
constructor( { value, onReplace, multiline } ) {
super( ...arguments );
Expand Down Expand Up @@ -472,10 +479,11 @@ export class RichText extends Component {
}

let selectedFormat;
const formatsAfter = formats[ start ] || [];
const collapsed = isCollapsed( value );

if ( isCollapsed( value ) ) {
if ( collapsed ) {
const formatsBefore = formats[ start - 1 ] || [];
const formatsAfter = formats[ start ] || [];

selectedFormat = Math.min( formatsBefore.length, formatsAfter.length );
}
Expand All @@ -484,6 +492,25 @@ export class RichText extends Component {
this.applyRecord( { ...value, selectedFormat }, { domOnly: true } );

delete this.formatPlaceholder;

if ( collapsed ? selectedFormat > 0 : formatsAfter.length > 0 ) {
this.recalculateBoundaryStyle();
}
}
}

recalculateBoundaryStyle() {
const boundarySelector = '*[data-rich-text-format-boundary]';
const element = this.editableRef.querySelector( boundarySelector );

if ( element ) {
const computedStyle = getComputedStyle( element );
const newColor = computedStyle.color
.replace( ')', ', 0.2)' )
.replace( 'rgb', 'rgba' );

globalStyle.innerHTML =
`${ boundarySelector }{background-color: ${ newColor }}`;
}
}

Expand Down Expand Up @@ -793,6 +820,9 @@ export class RichText extends Component {
}
}

// Wait for boundary class to be added.
setTimeout( () => this.recalculateBoundaryStyle() );

if ( newSelectedFormat !== selectedFormat ) {
this.applyRecord( { ...value, selectedFormat: newSelectedFormat } );
this.setState( { selectedFormat: newSelectedFormat } );
Expand Down
21 changes: 0 additions & 21 deletions packages/block-editor/src/components/rich-text/style.scss
Original file line number Diff line number Diff line change
Expand Up @@ -44,27 +44,6 @@

*[data-rich-text-format-boundary] {
border-radius: 2px;
box-shadow: 0 0 0 1px $light-gray-400;
background: $light-gray-400;

// Enforce a dark text color so active inline boundaries
// are always readable.
// See https://github.com/WordPress/gutenberg/issues/9508
color: $dark-gray-900;
}

// Link inline boundaries get special colors.
a[data-rich-text-format-boundary] {
box-shadow: 0 0 0 1px $blue-medium-100;
background: $blue-medium-100;
color: $blue-medium-900;
}

// <code> inline boundaries need special treatment because their
// un-selected style is already padded.
code[data-rich-text-format-boundary] {
background: $light-gray-400;
box-shadow: 0 0 0 1px $light-gray-400;
}
}

Expand Down
5 changes: 0 additions & 5 deletions packages/block-library/src/cover/editor.scss
Original file line number Diff line number Diff line change
@@ -1,10 +1,5 @@
.wp-block-cover-image,
.wp-block-cover {
.block-editor-rich-text__editable:focus a[data-rich-text-format-boundary] {
box-shadow: none;
background: rgba(255, 255, 255, 0.3);
}

&.components-placeholder h2 {
color: inherit;
}
Expand Down
4 changes: 0 additions & 4 deletions packages/block-library/src/gallery/editor.scss
Original file line number Diff line number Diff line change
Expand Up @@ -82,10 +82,6 @@ ul.wp-block-gallery li {
a {
color: $white;
}

&:focus a[data-rich-text-format-boundary] {
color: rgba(0, 0, 0, 0.2);
}
}
}

Expand Down

0 comments on commit 91269ae

Please sign in to comment.