2023-12-26 20:26:54 -05:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
|
|
|
import 'scale_color.dart';
|
|
|
|
|
2024-04-12 20:55:05 -04:00
|
|
|
enum ScaleKind { primary, primaryAlpha, secondary, tertiary, gray, error }
|
|
|
|
|
2023-12-26 20:26:54 -05:00
|
|
|
class ScaleScheme extends ThemeExtension<ScaleScheme> {
|
2024-04-12 20:55:05 -04:00
|
|
|
ScaleScheme({
|
|
|
|
required this.primaryScale,
|
|
|
|
required this.primaryAlphaScale,
|
|
|
|
required this.secondaryScale,
|
|
|
|
required this.tertiaryScale,
|
|
|
|
required this.grayScale,
|
|
|
|
required this.errorScale,
|
|
|
|
});
|
2023-12-26 20:26:54 -05:00
|
|
|
|
|
|
|
final ScaleColor primaryScale;
|
|
|
|
final ScaleColor primaryAlphaScale;
|
|
|
|
final ScaleColor secondaryScale;
|
|
|
|
final ScaleColor tertiaryScale;
|
|
|
|
final ScaleColor grayScale;
|
|
|
|
final ScaleColor errorScale;
|
|
|
|
|
2024-04-12 20:55:05 -04:00
|
|
|
ScaleColor scale(ScaleKind kind) {
|
|
|
|
switch (kind) {
|
|
|
|
case ScaleKind.primary:
|
|
|
|
return primaryScale;
|
|
|
|
case ScaleKind.primaryAlpha:
|
|
|
|
return primaryAlphaScale;
|
|
|
|
case ScaleKind.secondary:
|
|
|
|
return secondaryScale;
|
|
|
|
case ScaleKind.tertiary:
|
|
|
|
return tertiaryScale;
|
|
|
|
case ScaleKind.gray:
|
|
|
|
return grayScale;
|
|
|
|
case ScaleKind.error:
|
|
|
|
return errorScale;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-12-26 20:26:54 -05:00
|
|
|
@override
|
|
|
|
ScaleScheme copyWith(
|
|
|
|
{ScaleColor? primaryScale,
|
|
|
|
ScaleColor? primaryAlphaScale,
|
|
|
|
ScaleColor? secondaryScale,
|
|
|
|
ScaleColor? tertiaryScale,
|
|
|
|
ScaleColor? grayScale,
|
|
|
|
ScaleColor? errorScale}) =>
|
|
|
|
ScaleScheme(
|
|
|
|
primaryScale: primaryScale ?? this.primaryScale,
|
|
|
|
primaryAlphaScale: primaryAlphaScale ?? this.primaryAlphaScale,
|
|
|
|
secondaryScale: secondaryScale ?? this.secondaryScale,
|
|
|
|
tertiaryScale: tertiaryScale ?? this.tertiaryScale,
|
|
|
|
grayScale: grayScale ?? this.grayScale,
|
|
|
|
errorScale: errorScale ?? this.errorScale,
|
|
|
|
);
|
|
|
|
|
|
|
|
@override
|
|
|
|
ScaleScheme lerp(ScaleScheme? other, double t) {
|
|
|
|
if (other is! ScaleScheme) {
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
return ScaleScheme(
|
|
|
|
primaryScale: ScaleColor.lerp(primaryScale, other.primaryScale, t),
|
|
|
|
primaryAlphaScale:
|
|
|
|
ScaleColor.lerp(primaryAlphaScale, other.primaryAlphaScale, t),
|
|
|
|
secondaryScale: ScaleColor.lerp(secondaryScale, other.secondaryScale, t),
|
|
|
|
tertiaryScale: ScaleColor.lerp(tertiaryScale, other.tertiaryScale, t),
|
|
|
|
grayScale: ScaleColor.lerp(grayScale, other.grayScale, t),
|
|
|
|
errorScale: ScaleColor.lerp(errorScale, other.errorScale, t),
|
|
|
|
);
|
|
|
|
}
|
2024-04-12 20:55:05 -04:00
|
|
|
|
|
|
|
ColorScheme toColorScheme(Brightness brightness) => ColorScheme(
|
|
|
|
brightness: brightness,
|
|
|
|
primary: primaryScale.primary, // reviewed
|
|
|
|
onPrimary: primaryScale.primaryText, // reviewed
|
|
|
|
// primaryContainer: primaryScale.hoverElementBackground,
|
|
|
|
// onPrimaryContainer: primaryScale.subtleText,
|
|
|
|
secondary: secondaryScale.primary,
|
|
|
|
onSecondary: secondaryScale.primaryText,
|
|
|
|
// secondaryContainer: secondaryScale.hoverElementBackground,
|
|
|
|
// onSecondaryContainer: secondaryScale.subtleText,
|
|
|
|
tertiary: tertiaryScale.primary,
|
|
|
|
onTertiary: tertiaryScale.primaryText,
|
|
|
|
// tertiaryContainer: tertiaryScale.hoverElementBackground,
|
|
|
|
// onTertiaryContainer: tertiaryScale.subtleText,
|
|
|
|
error: errorScale.primary,
|
|
|
|
onError: errorScale.primaryText,
|
|
|
|
// errorContainer: errorScale.hoverElementBackground,
|
|
|
|
// onErrorContainer: errorScale.subtleText,
|
|
|
|
surface: primaryScale.primary, // reviewed
|
|
|
|
onSurface: primaryScale.primaryText, // reviewed
|
2024-06-21 22:44:35 -04:00
|
|
|
surfaceContainerHighest: secondaryScale.primary,
|
2024-04-12 20:55:05 -04:00
|
|
|
onSurfaceVariant: secondaryScale.primaryText, // ?? reviewed a little
|
|
|
|
outline: primaryScale.border,
|
|
|
|
outlineVariant: secondaryScale.border,
|
|
|
|
shadow: const Color(0xFF000000),
|
|
|
|
//scrim: primaryScale.background,
|
|
|
|
// inverseSurface: primaryScale.subtleText,
|
|
|
|
// onInverseSurface: primaryScale.subtleBackground,
|
|
|
|
// inversePrimary: primaryScale.hoverBackground,
|
|
|
|
// surfaceTint: primaryAlphaScale.hoverElementBackground,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
class ScaleConfig extends ThemeExtension<ScaleConfig> {
|
|
|
|
ScaleConfig({
|
|
|
|
required this.useVisualIndicators,
|
|
|
|
});
|
|
|
|
|
|
|
|
final bool useVisualIndicators;
|
|
|
|
|
|
|
|
@override
|
|
|
|
ScaleConfig copyWith({
|
|
|
|
bool? useVisualIndicators,
|
|
|
|
}) =>
|
|
|
|
ScaleConfig(
|
|
|
|
useVisualIndicators: useVisualIndicators ?? this.useVisualIndicators,
|
|
|
|
);
|
|
|
|
|
|
|
|
@override
|
|
|
|
ScaleConfig lerp(ScaleConfig? other, double t) {
|
|
|
|
if (other is! ScaleConfig) {
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
return ScaleConfig(
|
|
|
|
useVisualIndicators:
|
|
|
|
t < .5 ? useVisualIndicators : other.useVisualIndicators,
|
|
|
|
);
|
|
|
|
}
|
2023-12-26 20:26:54 -05:00
|
|
|
}
|