-
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
Editable: Extract the format toolbar out of the editable #923
Conversation
8a672ab
to
4c50154
Compare
This seems a bit problematic to me, we are making it more complicated to create a block in order to provide more flexibility. Making All the setup instructions and passing |
The idea here is that we could build reusable toolbars and the block author would opt-in those toolbars by including the components. Something like this: edit: () {
return (
<div>
<Controls>
<BlockAlignmentToolbar />
<AlignmentToolbar editable={ this.editable } />
<FormattingToolbar editable={ this.editable } />
</Controls>
<Editable onSetup={ bindEditable } />
<Editable showInlineToolbar />
</div>
);
} I'm finding the controls a bit confusing now because there are different toolbars injected from different places to the same place. I'm trying to unify the way block authors adds controls to its block. I understand the concerns about the need to bind the Editable, but I honestly find it easier to reason about than having controls appearing magically in the toolbar while others don't. I wonder if we could find a way to avoid this "editable" prop by getting the active TinyMCE instance maybe. |
If alignment and formatting apply to the Editable components, I think it should be expressed with props. As long as those are clear, I don't see much of a problem—you get them by using Editable. In the above example it's not how the toolbar related to editable, and the binding seems like unnecessary boilerplate for most cases. |
I feel this is a conscious decision we make when we subscribe to the concept of slot and fill. I do understand the concern though, but I'm not sure delegating this to the block implementer is the best solution, especially when the controls are to remain bound to the Editable instance anyways. I'm not sure we'll have use-cases where a user would want to remove or rearrange these controls, though if we did, (1) we could surface some Editable props to do so and (2) we might need to find a solution to Slot & Fill ordering sooner than later as a broader problem (ideally not There's been some chatter about whether alignment should be the responsibility of a block or Editable. If it were moved back to being the responsibility of a block, then Editable is only rendering its formatting controls, which might be more reasonable to accept? |
Fair points here. I thought since, List indent buttons are handled this way, table controls (v2) too and @aduth you're suggesting alignment controls. The last remaining controls are formatting. So the question is, do we want Alignment to be the special case of controls always inserted by the Editable component? I kind of like the flexibility of having it outside but I understand that it's really tight to Editables. Thanks for your input. |
Rethinking about this, I think there's value in extracting all the formatting logic from the Editable into a separate component (passing an editor object) even if we include this component inside the |
Do you see that living at |
Maybe more |
It looks like I'm at this discussion a bit late but I think having the toolbars as separate components that are not automatically put into the slot is a great idea because as it is currently not being able to specify the toolbar order in Editable (or even turn off the basic formating tools) is really annoying. |
This idea builds on top of #830 to allow block authors to explicitly include the formatting toolbar inside the
edit
function the same way they include the other controls.Allowing the block author to explicitly include the toolbars let the block author controls the order of these toolbars. Another advantage of this PR is that the code required to apply these formats is not split between two components and the
Editable
component is way simpler.I'm seeing some focus jumps (especially when using the
link
control), I'll try to address them asap.Once we refactor all the blocks to use this technique, we'll be able to drop the temporary "showFormattingToolbar" prop.
A next step to this PR would be to do the same for the alignment toolbar.