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

Colour handling improvements #8702

Draft
wants to merge 98 commits into
base: master
Choose a base branch
from
Draft

Colour handling improvements #8702

wants to merge 98 commits into from

Conversation

Jermolene
Copy link
Member

@Jermolene Jermolene commented Oct 25, 2024

UPDATE 24th January 2025: This PR now incorporates background actions and media query tracker mechanisms from #8555


Introduction

Preview build: https://deploy-preview-8702--tiddlywiki-previews.netlify.app/

We get persistent of feedback that the visual aesthetic of TiddlyWiki is old fashioned and dull. It's fair criticism: the default look and feel was intended to be muted so that the users content took centre stage but has ended up flat and lifeless.

The ultimate goal of this PR is to allow end users to easily devise their own colour schemes that match their tastes and work harmoniously together.

This will be accomplished with a new user interface that is presented in the empty "GettingStarted" tiddler, and in the control panel. The UI would have sliders and switches for the user to express their taste: colourful vs. muted, dark vs. light, saturated vs. unsaturated.

Underneath those controls would be displayed a grid of 9 random palettes generated to match the parameters. The user can choose one of them and either select it, or choose to use it as the basis to generate further variants.

The underlying mechanism is based on the idea of palettes defined as a small number of base colours, with rules for dynamically generating the full palette by dynamically lightening, darkening or otherwise manipulating an existing colour. This approach is similar to that of the colour system in Android for example.

This PR is highly experimental. It may not be merged in this form; I have already started cherry picking parts into separate PRs.

Colour Manipulation

We need a colour manipulation library that can calculate variants of colours. Only color.js met the requirements of being able to work with P3 colours and the OKLCH colour space. It also includes a CSS colour string parser which can replace the simple one that TiddlyWiki has always incorporated.

Static Palette Entries

The key idea underpinning these changes is a fundamental change to the way that TiddlyWiki handles palettes. At the moment, palette entries are named items that can contain either a CSS colour string, a CSS colour token like "inherit", or use the <<colour>> macro to reference another colour palette entry. Thus, palette entries have to be wikified before they can be used. This has turned out to be extremely limiting.

The idea of static palettes is that at the point of switching to a new palette, the colours within it are "compiled" to raw CSS colour values (typically but not necessarily in #rrggbbaa format). This allows palette entries to be used directly, without the requirement to wikify them.

The static palette is created in a new system tiddler $:/temp/palette-colours by an action procedure that is invoked at startup and when switching to a new palette.

The primary backwards compatibility issue is that any existing code that switches palettes by writing to the tiddler $:/palette will no longer cause a palette change because $:/temp/palette-colours will not have been updated. Code that uses the core palette switcher will continue to work properly.

This change will also allow us to change the <<colour>> procedure to be a function, which will allow it to be used as the value for a style attribute:

<div style.background=<<colour tiddler-background>>>

Modern Palettes

This PR also introduces a new type of palette referred to as "modern" which is exactly like the existing palette except that the entries are defined as functions that must be evaluated, rather than wikitext that must be wikified.

This makes it possible to create palettes that reference and modify other colours. For example:

tiddler-background: [<colour background>colour-darken[0.5]colour-saturate[2]]

Colour Palette Preview

Something I've wanted for a long time is to improve the colour palette chooser to include a preview. It is not finished yet, but has turned out to be quite easy and very effective:

image

Media Query Tracker and Background Actions

This PR also introduces two new general purpose mechanisms for end users:

  • The CSS media query tracker allows a media query to be bound to an info tiddler so that the current state of the query is reflected in the value of the tiddler. The value is updated dynamically
  • The new background actions mechanism allows action strings to be invoked automatically in the background whenever the results of a filter change

Internally, both these mechanisms are based on a new "filter tracker" JavaScript class that is also intended to have other applications (eg tracking keyboard shortcuts).

Media Query Tracker

The use of the info mechanism for the CSS media query tracker means that these tiddlers are dynamically created as shadow tiddlers within the $:/temp/info plugin, and so do not appear in tiddler lists.

The mechanism is used to implement the existing dark mode tiddler with the following configuration:

title: $:/core/wiki/config/MediaQueryTrackers/DarkLightSwitch
tags: $:/tags/MediaQueryTracker
media-query: (prefers-color-scheme: dark)
info-tiddler: $:/info/browser/darkmode
info-tiddler-alt: $:/info/darkmode

Note the use of info-tiddler-alt to specify a redundant secondary info tiddler. This is used by the dark mode tracker to maintain compatibility while changing the info tiddler title for consistency.

Background Actions

Details coming soon.

References

Progress

  • Added wikify operator with tests
  • Removed wikify operator to separate PR Add wikify operator #8730
  • Integrated color.js
  • Replace existing core CSS colour parser with the equivalent functionality from color.js
  • Convert and then reverted changing the colour macro to a function
  • Add darken and lighten filter operators with tests
  • Enhanced colour palette preview
  • Extended wikitext test runner to be able to unpack plugins

The replacement library from https://colorjs.io/ is much, much larger but I think we can develop a custom build that uses treeshaking to whittle the code down to the bits that we need. @linonetwo does that sound feasible?

I intend the explore further improvements but I wanted to start by establishing a library that can do modern P3 and OKLCH colour calculations.
Really just syntactic sugar for the wikify widget
Using the new wikify operator.

Currently has a bug whereby redirected colours (like "tiddler-background") do not work. Direct colours like "background" do work.

Note the hacks needed to makeFakeWidgetWithVariables work
Copy link

Confirmed: Jermolene has already signed the Contributor License Agreement (see contributing.md)

@@ -2853,19 +2867,22 @@ a.tc-tiddlylink.tc-plugin-info:hover > .tc-plugin-info-chunk .tc-plugin-info-sta
color: <<colour foreground>>;
}

.tc-chosen > .tc-tiddlylink:before {
Copy link
Member

@pmario pmario Oct 25, 2024

Choose a reason for hiding this comment

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

IMO we need to keep this configuration for backwards compatibility. We can add a "deprecated" comment, but plugin authors may use these styles.

I'll need to make some more tests, with the palette-manager edition.

Copy link
Member

Choose a reason for hiding this comment

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

@Jermolene -- The tools-buttons: theme, layout, storyview and palette use this CSS. So IMO we can not remove it

Copy link
Member

Choose a reason for hiding this comment

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

All the "chosen" indicators fail now.

image

Copy link
Member Author

Choose a reason for hiding this comment

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

Thanks @pmario, fixed in c607440

@@ -2,15 +2,18 @@ title: $:/snippets/paletteswitcher

Copy link
Member

Choose a reason for hiding this comment

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

Can you add indentation, so it's easier to read

Copy link
Member Author

Choose a reason for hiding this comment

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

Good point will do

"fields": {
"type": "application/javascript",
"title": "$:/core/modules/utils/dom/color.js",
"module-type": "library"
Copy link
Member

Choose a reason for hiding this comment

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

IMO we should add 2 more fields: version: 0.5.2 and repo: https://github.com/color-js/color.js to make it easier for us to maintain

Copy link
Member Author

Choose a reason for hiding this comment

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

Hi @pmario if we were going to add those fields then we should do so consistently for all the 3rd party libraries in the core.

Copy link
Member

Choose a reason for hiding this comment

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

I think that would be a good idea and we have to start somewhere.

@kookma
Copy link
Contributor

kookma commented Nov 4, 2024

Is there a demo to test colour handling improvement?

@Jermolene
Copy link
Member Author

Is there a demo to test colour handling improvement?

Hi @kookma I've posted a preview to tiddlyhost

Will requires #7999 to work fully; for the moment when you switch between dark and light you will see the preview change, and then next time you select the palette it will be in the correct mode
@springerspandrel
Copy link
Contributor

I haven't followed discussion here before, but came because of Mohammad's recent link (color picker wish list)...

In this recent preview (https://deploy-preview-8702--tiddlywiki-previews.netlify.app/) editing the active palette doesn't affect color display in the overall wiki at all (though it does dynamically change the preview thumbnail, which is fun to see).

If live editing of palettes has been prevented, (for the sake of sandboxing or whatever), or just hasn't been re-constructed in the new build, feel free to ignore my worry!

@Jermolene
Copy link
Member Author

Thanks @springerspandrel. This is fixed in 69363bf

The background is that palettes are now compiled from the raw wikified/filtered text into plain CSS colour values. $:/palette continues to point to the current selected palette, and the palette itself can not only use complex wikitext but now modern palettes can use filters to define palette entries. The new twist is that the palette is compiled into $:/temp/palette-colours which just contains plain CSS colour values that can be directly transcluded.

Until 69363bf I hadn't yet updated the main control panel palette editor to make it trigger a recompilation. Now that this is fixed the palette editor should work as you expect.

The hope is that now the palette editor would only be needed for people who are creating their own palettes from scratch. Newer palettes can instead be customised using the custom palette editor that shows up for new palettes that elect to use it:

image

The new TwentyTwenties palette is inspired by the Flexoki palette, except that one can change the paper and ink colours directly, and have the other colours and tones of the palette automatically switch to adjust harmoniously. Try changing the hue of the paper colour:
image

by adding a new "thumbnails" parameter to the template
@springerspandrel
Copy link
Contributor

Very promising developments. The "ink" and "paper" metaphors are intuitive, and interpolation effects seem to be working well!

A couple small notes, playing with the TwentyTwenties variations (and as always feel free to ignore if these are already obvious, and/or it's not the right moment in your workflow to address them)

(1) TABS:

Sidebar tabs are not yet "inheriting" the tab-background and tab-background-selected palette values in TwentyTwenties (though it seems that's the intention of having these default to [function[colour],[tab-background]] (etc.)

(2) PREVIEW THUMBNAILS

(a) tab-background and tab-background-selected colors don't get any preview even though sidebar tabs are very much part of "out-of-box" GUI... Having a mock set of sidebar tab-rectangles (one active, one or two inactive) might be helpful, at the risk of more visual noise... (Meanwhile, we do currently get a preview of search window input-box — despite duplicating tiddler background for all bundled palettes except Solarized Dark.)

(b) Selecting new primary color doesn't affect palette's preview-thumbnail at all. Selecting new primary value does immediately affect the actual sidebar-tab list links, and site title (maybe because it's effectively a link, while thumbnail doesn't treat it as a link)... (ONE solution: Include minimalist mock-preview of sidebar tab list content — so the tiddler-link color appears in preview, whether or not a palette has distinct value for site-title-foreground ... ALTERNATE solution: have some primary link-color "accents" within the top mock tiddler such as HelloThere — noting that the real HelloThere conveniently does feature several visible links within a short tiddler body!).

(c) Selecting new secondary and/or tertiary color choices doesn't affect palette preview, and user also lacks obvious places — in larger interface — to recognize dynamic effects of that selection. If the second "mock" tiddler in preview-thumbnail were to include a small block of code, that would nicely gives a hint of tertiary. (Including a natural preview of the secondary color seems more difficult, since having an alert within preview thumbnail is awkward.)

Thanks for all this nuanced work!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants