Skip to content

Commit

Permalink
Merge pull request #18 from rydmike/version_3_2_0
Browse files Browse the repository at this point in the history
Version 3 2 0
  • Loading branch information
rydmike authored Aug 27, 2024
2 parents 0cbe1a2 + 84c76f1 commit 5783b08
Show file tree
Hide file tree
Showing 22 changed files with 3,137 additions and 1,486 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ on:
paths-ignore:
- "**.md"
release:
branches: [none]
branches: [master]
types: [published]

jobs:
Expand Down
14 changes: 14 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,20 @@

All notable changes to the **FlexSeedScheme** (FSS) package are documented here.

## 3.2.0

**Aug 27, 2024**


**CHANGE**

* The `FlexPaletteType.extended` tones got three new tones, tones 65, 75 and 84. It now has 30 tones.

**NEW**

* The `tones` configuration class `FlexTones` got a new modifier, `higherContrastFixed()`. It can be applied to any predefined or custom `FlexTones` to make a returned `FlexTones` instance where the tones for the fixed colors `fixed`, `onFixed`, `fixedDim` and `onFixedVariant` are set to **92, 6, 84 and 12** instead of their Material-3 specification tones **90, 10, 80 and 30**. This for an alternative set of fixed colors with more contrast.


## 3.1.2

**July 23, 2024**
Expand Down
53 changes: 33 additions & 20 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -235,15 +235,15 @@ const FlexTones myDarkTones = FlexTones.dark(

## Extended Palette

The extended palette type is the new default, if you are using Flutter 3.22, or later you should only use it. The `common` tones option is provided for backwards compatibility with older Flutter versions and older FSS versions.
The extended palette type is the new default, it contains 30 tones. If you are using Flutter 3.22, or later you should only use it. The `common` tones option is provided for backwards compatibility with older Flutter versions and older FSS versions.

By using `paletteType` with value `FlexPaletteType.extended`, you can create seed generated `ColorScheme`s that use and access new color tones that exists in the late 2022 revised `ColorScheme` for surface colors and even more colors for **fixed** and **fixedDim** main colors that arrived in the Material-3 design during later half of 2023.

The `ColorScheme` colors that use these new tones are now also available in Flutter 3.22 or later. For more information and the latest updates, see [Material-3 color-roles](https://m3.material.io/styles/color/the-color-system/color-roles) specification.

The updated Material-3 color system adds tones `[4, 6, 12, 17, 22, 24]`, they are used for new dark mode surfaces in revised Material-3 dark surface colors. Likewise, the added tones `[87, 92, 94, 96, 98]` are for light mode surfaces in the updated Material-3 color system. By default `paletteType` of `FlexTones.extended` is now used to enable support for the tones in the updated specification and also adding three more custom tones `[2, 5, 97]`. The `paletteType` with value `FlexPaletteType.extended` is now default, it produces 27 tones `[0, 2, 4, 5, 6, 10, 12, 17, 20, 22, 24, 30, 40, 50, 60, 70, 80, 87, 90, 92, 94, 95, 96, 97, 98, 99, 100]`.
The updated Material-3 color system adds tones `[4, 6, 12, 17, 22, 24]`, they are used for new dark mode surfaces in revised Material-3 dark surface colors. Likewise, the added tones `[87, 92, 94, 96, 98]` are for light mode surfaces in the updated Material-3 color system. By default `paletteType` of `FlexTones.extended` is now used to enable support for the tones in the updated specification and also adding six more custom tones `[2, 5, 65, 75, 84, 97]`. The `paletteType` with value `FlexPaletteType.extended` is default. It produces the following 30 tones `[0, 2, 4, 5, 6, 10, 12, 17, 20, 22, 24, 30, 40, 50, 60, 65, 70, 75, 80, 84, 87, 90, 92, 94, 95, 96, 97, 98, 99, 100]`.

To use the older classic setup you can still use `FlexTones.common`. It produces the legacy M3 tones with its own two additions `[5]` and `[98]` resulting in 15 tones `[0, 5, 10, 20, 30, 40, 50, 60, 70, 80, 90, 95, 98, 99, 100]`. Flutter versions before 3.22 do not yet use these new tones in its standard `ColorScheme`.
To use older simpler tones setup you can still use `FlexTones.common`. It produces the legacy M3 tones with its own two additions `[5]` and `[98]` resulting in 15 tones `[0, 5, 10, 20, 30, 40, 50, 60, 70, 80, 90, 95, 98, 99, 100]`. Flutter versions before 3.22 do not yet use any of the extended tones in its standard `ColorScheme`.

For backwards compatibility, when using type `FlexPaletteType.common` the chroma of high tones, meaning higher or equal to 90, are limited to maximum chroma of 40. This keeps the chromacity of tones 90 to 100 lower than or equal to 40. If the source seed color has higher chromacity than 40, there may be a sudden jump in chroma reduction at tone 90. This is the standard behavior for the original Material-3 tonal palette computation. The `FlexPaletteType.common` type is intended to be used when there is a need to follow the M3's original, now legacy, palette design.

Expand Down Expand Up @@ -344,7 +344,6 @@ The surface on colors made black or white by `onSurfacesUseBW()` are:
* `onSurface`
* `onSurfaceVariant`
* `onInverseSurface`
* `onBackground` (deprecated in Flutter 3.22)

Here is a usage example, using both these modifiers. You can use them individually too, and you don't have to use them in both light and dark mode.

Expand Down Expand Up @@ -379,23 +378,12 @@ final ColorScheme schemeDarkOnBW = SeedColorScheme.fromSeeds(

#### FlexTones Modifier `surfacesUseBW()`

Another `FlexTones` modifier is `surfacesUseBW()`. This modifier will make the `surface` and `background` colors plain white in light mode and true black in dark mode.

The surface colors made black or white by `surfacesUseBW()` are:

* `surface`
* `background` (deprecated in Flutter 3.22)

This modifier can be used for great effect in light mode, as you can remove the colored background surfaces from any of the `FlexTones` seeding strategies. Some designs may prefer plain white, for backgrounds in light mode, for a more platform-agnostic design.

In dark mode `surfacesUseBW()` can be used create seeded color schemes with full black background and surface colors, but you may prefer to keep the primary seed color based slightly primary color tinted backgrounds in dark mode.

This modifier will make the `surface` color and still also the deprecated `background` color plain white in light mode and full black in dark mode.
Another simple `FlexTones` modifier is `surfacesUseBW()`. This modifier will make the `surface` color plain white in light mode and full black in dark mode.

```dart
// Make a Material 3 seeded light ColorScheme, but with always
// black and white contrasting onColors and ensure that background
// and surface colors are always white.
// black and white contrasting onColors and ensure that
// the surface color is always white.
final ColorScheme schemeLightOnBW = SeedColorScheme.fromSeeds(
brightness: Brightness.light,
primaryKey: primarySeedColor,
Expand All @@ -410,14 +398,13 @@ final ColorScheme schemeLightOnBW = SeedColorScheme.fromSeeds(

#### FlexTones Modifier `monochromeSurfaces()`

A new `FlexTones` modifier in FSS version 3.0.0 is `monochromeSurfaces()`. It can be applied to any predefined or custom `FlexTones` to make all the surface colors monochrome and use pure greyscale for the neutral and neutral variant tonal palettes. Surface colors will then have no color tint from their own key color or from the primary seed key color. For those tired of tinted surface colors in Material-3, this is a useful helper.
A `FlexTones` modifier available in FSS version 3.0.0 and later. It can be applied to any predefined or custom `FlexTones` to make all the surface colors monochrome and use pure greyscale for the neutral and neutral variant tonal palettes. Surface colors will then have no color tint from their own key color or from the primary seed key color. For those tired of tinted surface colors in Material-3, this is a useful helper.

The surface colors made monochrome by `monochromeSurfaces()` are:
* `surface`, `onSurface`, `surfaceContainer`, `onSurfaceVariant`
* `surfaceContainerHighest`, `surfaceContainerHigh`, `surfaceContainerLow`, `surfaceContainerLowest`
* `surfaceDim`,`surfaceBright`, `inverseSurface`, `onInverseSurface`
* `outline`, `outlineVariant`
* `background`, `onBackground`, `surfaceVariant` (deprecated in Flutter 3.22)

```dart
// Make a vivid Material 3 seeded light ColorScheme, where all surface colors
Expand All @@ -431,6 +418,32 @@ final ColorScheme schemeLight = SeedColorScheme.fromSeeds(
);
```

#### FlexTones Modifier `higherContrastFixed()`

A `FlexTones` modifier available in FSS version 3.2.0 and later.
This modifier can be applied to any predefined or custom
`FlexTones` to make a returned instance where the tones for
the fixed colors `fixed`, `onFixed`, `fixedDim`, `onFixedVariant` are
set to 92, 6, 84 and 12, instead Material-3 designs specified 90, 10, 80 and 30.

This gives us an alternative set of fixed colors with more contrast.


```dart
// Make an ultraContrast seeded light ColorScheme, where all fixed colors
// have higher contrast than the standard Material-3 design.
//
// It is here combined `FlexTones.ultraContrast` to make also the fixed and
// fixedDim colors and their on colors have higher contrast too.
final ColorScheme schemeLight = SeedColorScheme.fromSeeds(
brightness: Brightness.light,
primaryKey: primarySeedColor,
secondaryKey: secondarySeedColor,
tertiaryKey: tertiarySeedColor,
tones: FlexTones.ultraContrast(Brightness.light).higherContrastFixed(),
);
```

## Expressive On Container Colors

By setting `useExpressiveOnContainerColors` to true in `SeedColorScheme.fromSeeds` you can opt in on using the new Material expressive on-colors specification for none surface on-container colors in light theme mode.
Expand Down
5 changes: 3 additions & 2 deletions example/lib/about/views/about.dart
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,8 @@ void showAppAboutDialog(BuildContext context) {
TextSpan(
style: aboutTextStyle,
text: 'The ${AppData.title(context)} application demonstrates '
'features of the ${AppData.packageName} custom key colors '
'features\n'
'of the ${AppData.packageName} custom key colors '
'ColorScheme generation package.\n\n'
'To learn more, check out the package on ',
),
Expand All @@ -65,7 +66,7 @@ void showAppAboutDialog(BuildContext context) {
),
TextSpan(
style: aboutTextStyle,
text: '. It also includes the source '
text: '.\nIt also includes the source '
'code of this application.\n\n',
),
TextSpan(
Expand Down
6 changes: 3 additions & 3 deletions example/lib/core/constants/app_data.dart
Original file line number Diff line number Diff line change
Expand Up @@ -24,14 +24,14 @@ sealed class AppData {
// Version of the WEB build, usually same as package, but it also has a
// build numbers.
static const String versionMajor = '3';
static const String versionMinor = '1';
static const String versionPatch = '2';
static const String versionMinor = '2';
static const String versionPatch = '0';
static const String versionBuild = '01';
static const String version = '$versionMajor.$versionMinor.$versionPatch '
'Build-$versionBuild';
static const String packageVersion =
'$versionMajor.$versionMinor.$versionPatch';
static const String flutterVersion = '3.22.3 (canvaskit)';
static const String flutterVersion = '3.24.1 (canvaskit)';
static const String copyright = '© 2022-2024';
static const String author = 'Mike Rydstrom';
static const String license = 'BSD 3-Clause License';
Expand Down
32 changes: 18 additions & 14 deletions example/lib/core/views/universal/list_tile_reveal.dart
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import 'package:flutter/material.dart';

/// A custom [ListTile] that has a built-in animated custom leading action
/// after the [leading] widget built in as a part of [title] that
/// reveals the [subtitle] when clicked.
/// reveals the [subtitleReveal] when clicked.
///
/// This is useful when a more compact look is desired where more information
/// is provided as an optional user based reveal action. The purpose is to make
Expand All @@ -16,11 +16,12 @@ class ListTileReveal extends StatefulWidget {
this.title,
this.leading,
this.subtitle,
this.subtitleReveal,
this.trailing,
this.contentPadding,
this.onTap,
this.dense,
this.subtitleDense,
this.revealDense,
this.enabled = true,
this.isOpen,
this.duration = const Duration(milliseconds: 200),
Expand All @@ -44,6 +45,11 @@ class ListTileReveal extends StatefulWidget {
/// Typically a [Text] widget.
final Widget? subtitle;

/// Additional content displayed below the subtitle in a reveal animation.
///
/// Typically a [Text] widget.
final Widget? subtitleReveal;

/// A widget to display after the title.
///
/// Typically an [Icon] widget.
Expand All @@ -57,7 +63,8 @@ class ListTileReveal extends StatefulWidget {

/// The [ListTileReveal]'s internal padding.
///
/// Insets a [ListTileReveal]'s contents: its [leading], [title], [subtitle],
/// Insets a [ListTileReveal]'s contents: its [leading], [title],
/// [subtitleReveal],
/// and [trailing] widgets.
///
/// If null, `EdgeInsets.symmetric(horizontal: 16.0)` is used.
Expand All @@ -78,13 +85,10 @@ class ListTileReveal extends StatefulWidget {
/// Dense list tiles default to a smaller height.
final bool? dense;

/// Whether this list tile subtitle is dense.
///
/// Dense list tiles default to a smaller height. The subtitle is also dense
/// if dense is true.
/// Whether the used reveal part of the ListTile is dense.
///
/// If not defined defaults to false.
final bool? subtitleDense;
/// If not defined, defaults to true.
final bool? revealDense;

/// Set to true to open the info section of the ListTile, to false to close
/// it.
Expand Down Expand Up @@ -133,7 +137,7 @@ class _ListTileRevealState extends State<ListTileReveal> {
crossAxisAlignment: WrapCrossAlignment.center,
children: <Widget>[
if (widget.title != null) widget.title!,
if (widget.subtitle != null && widget.enabled)
if (widget.subtitleReveal != null && widget.enabled)
IconButton(
iconSize: 20,
// ignore: avoid_bool_literals_in_conditional_expressions
Expand All @@ -144,6 +148,7 @@ class _ListTileRevealState extends State<ListTileReveal> {
),
],
),
subtitle: widget.subtitle,
trailing: widget.trailing,
onTap: widget.enabled ? widget.onTap : null,
),
Expand All @@ -156,11 +161,10 @@ class _ListTileRevealState extends State<ListTileReveal> {
child: child,
);
},
child: (_isOpen && widget.subtitle != null && widget.enabled)
child: (_isOpen && widget.subtitleReveal != null && widget.enabled)
? ListTile(
dense: (widget.dense ?? false) ||
(widget.subtitleDense ?? false),
subtitle: widget.subtitle,
dense: widget.revealDense ?? true,
subtitle: widget.subtitleReveal,
onTap: widget.enabled ? _handleTap : null,
)
: const SizedBox.shrink(),
Expand Down
Loading

0 comments on commit 5783b08

Please sign in to comment.