-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
Update/theme support color palette #6437
Update/theme support color palette #6437
Conversation
Makes sense to me. |
@@ -8,7 +8,7 @@ To opt-in for one of these features, call `add_theme_support` in the `functions. | |||
|
|||
```php | |||
function mytheme_setup_theme_supported_features() { | |||
add_theme_support( 'editor-color-palette', | |||
add_theme_support( 'editor-color-palette', array( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It could be also:
add_theme_support( 'editor-color-palette', array(
'strong magenta' => '#a156b4',
'light grayish magenta' => '#d0a5db',
...
) );
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've just added the array wrapper there because of @jorgefilipecosta's comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we map it to an ordered array before it gets exposed to JavaScript?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@gziolo
You mean like declaring the theme support with this:
array(
'color_name_1' => '#color1',
'color_name_2' => '#color2',
)
and then transform it in PHP to a JS required form of:
array(
array(
'name' => 'color_name_1',
'color' => '#color1',
),
array(
'name' => 'color_name_2',
'color' => '#color2',
),
)
?
If so, this is certainly doable. But I'd like some more input on this, more opinions (maybe from @jorgefilipecosta)? You see, current associated array implementation is more self-explanatory in my opinion and could actually serve well in case of future extending of the palette color features.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yep, that's what I meant. I don't care as much, I just wanted to make life of theme developers easier and help them save some keystrokes 😃
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi,
Although I agree that it would be easier for themes to declare support using this syntax:
array(
'color_name_1' => '#color1',
'color_name_2' => '#color2',
)
I think it could limit future advances as the color value itself is a string and not an object we can expand.
For example, one possible improvement I was thinking about was to let themes define the contexts in which colors appear (e.g: allow some colors only for background).
In the current syntax, it is a matter of allowing an optimal property:
array(
array(
'name' => 'color_name_1',
'color' => '#color1',
),
array(
'name' => 'color_name_2',
'color' => '#color2',
'contexts': => array( 'background' ),
),
)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just like expected ;)
It's thursday, and I'm AFK tomorrow for a long weekend! Danish holiday, yeees! For that reason, I treated myself to a nice little color tweaking PR. It's like eating dessert, but in PR form. In this case, I polished up the mixin that colors Gutenberg according to your WordPress admin color scheme. For most schemes this means that the colors are a tad more accurate, and that their 2nd spot colors are now registered as SCSS variables, even if not yet used. However in the case of Sunrise and Midnight themes, this 2nd spot color now _is_ being used, to color the Switch. Specifically, we want the _activated_ switch to always have a bright color that stays away from "warning" hues like red or orange. In the case of the Midnight theme, the switch used to be red (dark pink), and in Sunrise it used to be orange. This PR switches those to use the new 2nd spot colors (these are traditionally used for the "notification" color in wp-admin, such as you have 1 plugin update). This makes them light blue and olive, respectively.
* Define variable as global * Revert change * Fix small typo in php doc * Revert unwanted change
…not passed to the frontend. (#6364)
* Split API init from compat.php to compat-api.php * Split API init into own file * Combine register and compat api into one rest-api.php file * Remove permalink_structure per #6319 * Move new rest api function for theme supports to rest-api.php load file * Move new register routes to api loader file
This commit replaces the usage of Button + Dashicon with IconButton in order to increase accessibility as IconButton label is used as aria-label. It looks like uid prop was passed to dashicon by mistake as the component does not do anything with this prop.
* Skip inline shortcodes * If the shortcode contains HTML, convert to block
* Add the block format version to the REST API post resource * Add the block_format to the post content response. * Add todo marker for including on schema * Fix PHP 5.2 incompatibility * Ensure this is an array to handle `isset()` behavior in 5.2
@@ -929,7 +929,7 @@ function gutenberg_editor_scripts_and_styles( $hook ) { | |||
// Initialize the editor. | |||
$gutenberg_theme_support = get_theme_support( 'gutenberg' ); | |||
$align_wide = get_theme_support( 'align-wide' ); | |||
$color_palette = get_theme_support( 'editor-color-palette' ); | |||
$color_palette = current( (array) get_theme_support( 'editor-color-palette' ) ); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this may be breaking back compatibility with the existing version:
add_theme_support( 'editor-color-palette',
'#fff'
'#f00'
);
Maybe we should handle some condition to be backcompatible.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
My question would be, is this required? Gutenberg is still in development and from what I can see the theme support declaration have already changed. (Though, I don't know if it was made backwards compatible.)
Also, is this backwards compatible too?:
add_theme_support( 'editor-color-palette',
array(
'name' => 'color_name_1',
'color' => '#color1',
),
array(
'name' => 'color_name_2',
'color' => '#color2',
)
);
If needed, I can surely, edit my code to incorporate backwards compatibility.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In my opinion backwards compatible in this case is not required.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi all,
Thank you for sharing your thoughts, and for this contributions.
When changing colors mechanism, we always made efforts to try to be back-compatible in this case being back-compatible does not look very complicated. I think If we add this block:
// Backcompat for Color Palette set as multiple parameters.
if ( is_string( $color_palette ) || isset( $color_palette['color'] ) ) {
$color_palette = get_theme_support( 'editor-color-palette' );
wp_add_inline_script(
'wp-edit-post',
'console.warn( "' .
__( 'Setting colors using multiple parameters is deprecated. Please pass a single parameter with an array of colors. See https://wordpress.org/gutenberg/handbook/extensibility/theme-support/ for details.', 'gutenberg' ) .
'");'
);
}
Bellow `$color_palette = current( (array) get_theme_support( 'editor-color-palette' ) );``, it should work with both our old versions:
add_theme_support( 'editor-color-palette',
array(
'name => 'red'
'color' => '#ff0',
),
array(
'name => 'green'
'color' => '#0f0',
),
array(
'name => 'blue'
'color' => '#00f',
)
);
and
add_theme_support( 'editor-color-palette',
'#f00',
'#0f0',
'#00f'
);
Would it be possible to rebase this branch so we can test with our latest changes, e.g., the mechanism to hide color palettes if we don't have colors to choose?
@mtias what are your thoughts? In your opinion, should we advance with this changes and set the color palette using a single array parameter instead of the current way (multiple parameters)?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@jorgefilipecosta Thank you for the code provided, I have updated my commits with it.
However, please note that this is the first GIT rebase I've ever done. Does feel like I've screwed something (judging by the number of commits). Please check and let me know. I might rather create a new branch again and redo changes for cleaner approach. Thanks!
Fixes #3499. Co-Authored-By: Andrew Duthie <[email protected]>
A recent fix to aria-disabled buttons (up mover on first block) caused a regression in formatting buttons. This PR fixes that.
…ag&drop). (#6456) Before we used mediaUpload directly this created a bug. The images uploaded did not contain the reference to the current post where they were uploaded.
* Try adding a purify Higher Order Component * Rename purify => pure * Unit test the pure HoC
…t-post script (#6448) * Framework: Make sure block assets are always registered before wp-edit-post script * Framework: Use domReady to make sure that all blocks are properly registered
This improves accessibility as it is useful for users to have a description of the color instead of just showing the color.
Fixes #6326. This "undoes" a change to the select box styling, and polishes the focus style as well. The regression was to introduce a padding change that conflicted with upstream select box styles. This essentially reverts that. This also polishes the focus styles a bit.
* Permalink copy button minor improvements. * Reset focus/hover styles, use aria-disabled, and update the label when the permalink is copied.
* Add shortcut tooltips for main toolbar * Reorganise keycode file * Add rawShortcut tests * Polish * No longer needed to omit keyboardShortcut * Use rawShortcut everywhere
* Blocks: Add automatic handling of focus for RichText component * Core blocks: Add automatic handling for focus for Quote and Pullquote blocks * Blocks: Show controls for newly created block * Blocks: Use method shorthand instead of arrow functions * Blocks: Use onFocus on div to set focused element * Blocks: Address review feedback * Core Blocks: Remove obsolete `isSelected` usage from Spacer block
…6300) * Introduce fill slot for the Status & Availbilty panel * lint fixes * Changing import statements to use the @WordPress package * Fix to remove duplicate import * Removing extra whitespace * Fixes typo * Rename slot to PluginPostStatusInfo * Structural changes and only exporting the Fill to the public api * Lint fixes * Edit Post: Use PluginPostStatusInfo alias for Fill * Edit Post: Fix export for the PluginPostStatusInfo * Adding documentation notes * Fixes typo in SlotFills * Changes the docs * Edit Post: Update documentation for plugins * Edit Post: Small tweak with inline comments
…6584) * Build: Put all build files into build top folder * Framework: Move a11y and dom-ready to their own modules * Edit Post: Move domReady logic to client-assets * Make phpcs happy by adding dot at the end of comment * Make Eslint happy by removing no longer used domReady import
* Framework: Move reusable block components from the blocks module to the editor module * Add deprecation message for wp.blocks.* * Update documentation to match the code * Fix unit tests * More deprecations * Fix e2e tests * Fix deprecated functions * Editor: Update class name for RN files * Use proper import statements for deprecated block components * Ensure the editor module is loaded before third party plugins * Tweak editor/components react-native version * Removing debugging code
…6529) * Use `targetSchema` of JSON Hyper Schema to communicate sticky action Because WordPress' capabilities system is filterable, we need to execute the capabilities before we know whether the current user can perform the action. Fortunately, `targetSchema` supports exactly this use-case. * Ensure links are properly formatted * Avoid re-renders when the current post changes * Technically more correct test * Update tests for 3e591c5 * Only include `wp:action-sticky` for `context=edit`; move description * Move the description text from the targetSchema to the link title. (#6613)
* Element: Expose forwardRef as export from wp.element * Components: Implement Button as assigning ref via forwardRef
* Table of content: Add a max-height * Add box shadow to indicate that the popover can be scrollable
* Register the _more_ block in blocks/library * Move the edit function to its own file * Embryo of a RN more tag * Add read only text to the more tag * Add PlainText input to the more block * Remove the 100% width on the plain-text style * Fix styling on the core/more block * Move styles to .scss file * Fix i18n import * Remove font styling for the more block marker * Replace underscores by hyphens in css names * editor/index.js needs nativization * Fix eslint issues * Core blocks: Rename component to follow pattern * Follow naming pattern in `code`, `more` edit modules * Core blocks: Remove empty line from Code edit
* Core blocks: Extract edit to their own file - part 1 * Own file for heading block's edit function
Iterates on descriptions and audits them all as a result. Props @michelleweber. Fixes #6623
`content` is no longer a property as the content of the notice is defined by the children of the component. From https://wordpress.slack.com/archives/C02QB2JS7/p1525848612000302
…6618) This change makes font size UI generic and allows other blocks to take advantage of the same UI used in the paragraph. Other changes will follow that will abstract other font size logic from paragraph (not just the UI). Themes will also be able to configure the font sizes. The future changes will use this work.
…om/webmandesign/gutenberg into update/theme-support-color-palette
Hi guys, |
I've went ahead and created a new, mess-less pull request containing all the code discussed here. #7025 |
Description
Allowing
editor-color-palette
theme support setup with a single array of colors. This way only one argument is passed toadd_theme_support( 'editor-color-palette', $arg )
instead of multiple arguments for each color.Fising issue #6425