master #81

Closed
malo wants to merge 322 commits from master into feat/bloc_layout/new-package
27 changed files with 367 additions and 226 deletions
Showing only changes of commit ef52015372 - Show all commits

View File

@ -15,10 +15,11 @@
// along with this program. If not, see <https://www.gnu.org/licenses/>. // along with this program. If not, see <https://www.gnu.org/licenses/>.
import 'package:flutter/widgets.dart'; import 'package:flutter/widgets.dart';
import 'package:wyatt_ui_components/src/core/utils/text_wrapper.dart'; import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
extension StringExtension on String? { extension StringExtension on String? {
TextWrapper? wrap({TextStyle? style, List<Color>? gradient}) => this != null TextWrapper? wrap({TextStyle? style, MultiColor? gradientColors}) =>
? TextWrapper(this!, style: style, gradient: gradient) this != null
: null; ? TextWrapper(this!, style: style, gradientColors: gradientColors)
: null;
} }

View File

@ -15,17 +15,22 @@
// along with this program. If not, see <https://www.gnu.org/licenses/>. // along with this program. If not, see <https://www.gnu.org/licenses/>.
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
/// Wraps [String] and [TextStyle] into one object that can be
/// a [Text] or a [RichText].
class TextWrapper { class TextWrapper {
const TextWrapper( const TextWrapper(
this.text, { this.text, {
this.style, this.style,
this.gradient, this.gradientColors,
}); });
factory TextWrapper.text(String text) => TextWrapper(text); const TextWrapper.text(this.text)
: style = null,
gradientColors = null;
final String text; final String text;
final TextStyle? style; final TextStyle? style;
final List<Color>? gradient; final MultiColor? gradientColors;
} }

View File

@ -31,8 +31,14 @@ class FlatButtons extends StatelessWidget {
), ),
const Gap(20), const Gap(20),
Center( Center(
/// You can overwrite global textstyle of the label with [label],
/// but if you only want to override the color/gradient of the text
/// in a particular case you can override the style that will
/// be merge during the build.
child: FlatButton( child: FlatButton(
label: const TextWrapper('Voir notre savoir faire'), label: const TextWrapper(
'Voir notre savoir faire',
),
), ),
), ),
const Gap(20), const Gap(20),

View File

@ -18,13 +18,13 @@ class InformationCards extends StatelessWidget {
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.center, mainAxisAlignment: MainAxisAlignment.center,
children: [ children: [
InformationCard( const InformationCard(
icons: const [ icons: [
FlutterLogo(size: 60), FlutterLogo(size: 60),
FlutterLogo(size: 60), FlutterLogo(size: 60),
FlutterLogo(size: 60), FlutterLogo(size: 60),
], ],
title: const TextWrapper('Flutter'), title: TextWrapper('Flutter'),
subtitle: TextWrapper.text('One single code base.'), subtitle: TextWrapper.text('One single code base.'),
body: TextWrapper.text( body: TextWrapper.text(
'Cupidatat reprehenderit aliqua eiusmod Lorem. ' 'Cupidatat reprehenderit aliqua eiusmod Lorem. '
@ -58,9 +58,9 @@ class InformationCards extends StatelessWidget {
FlutterLogo(size: 60), FlutterLogo(size: 60),
], ],
title: 'Flutter'.wrap( title: 'Flutter'.wrap(
gradient: [Colors.blue, Colors.green], gradientColors: const MultiColor([Colors.blue, Colors.green]),
), ),
subtitle: TextWrapper.text('One single code base.'), subtitle: const TextWrapper.text('One single code base.'),
body: 'Cupidatat reprehenderit aliqua eiusmod Lorem. ' body: 'Cupidatat reprehenderit aliqua eiusmod Lorem. '
'Qui ipsum id ea ea nulla labore aute ullamco aute ' 'Qui ipsum id ea ea nulla labore aute ullamco aute '
'quis elit ut amet velit. Incididunt fugiat proident ' 'quis elit ut amet velit. Incididunt fugiat proident '
@ -86,8 +86,8 @@ class InformationCards extends StatelessWidget {
FlutterLogo(size: 60), FlutterLogo(size: 60),
], ],
axis: Axis.horizontal, axis: Axis.horizontal,
title: TextWrapper.text('Flutter'), title: const TextWrapper.text('Flutter'),
subtitle: TextWrapper.text('One single code base.'), subtitle: const TextWrapper.text('One single code base.'),
body: 'Cupidatat reprehenderit aliqua eiusmod Lorem. ' body: 'Cupidatat reprehenderit aliqua eiusmod Lorem. '
'Qui ipsum id ea ea nulla labore aute ullamco aute ' 'Qui ipsum id ea ea nulla labore aute ullamco aute '
'quis elit ut amet velit. Incididunt fugiat proident ' 'quis elit ut amet velit. Incididunt fugiat proident '
@ -100,10 +100,10 @@ class InformationCards extends StatelessWidget {
'magna cupidatat Lorem nulla cupidatat voluptate ' 'magna cupidatat Lorem nulla cupidatat voluptate '
'irure ex reprehenderit.' 'irure ex reprehenderit.'
.wrap( .wrap(
gradient: [ gradientColors: const MultiColor([
Colors.red, Colors.red,
Colors.orange, Colors.orange,
], ]),
), ),
), ),
const Gap(20), const Gap(20),
@ -123,14 +123,14 @@ class InformationCards extends StatelessWidget {
FlutterLogo(size: 60), FlutterLogo(size: 60),
], ],
axis: Axis.horizontal, axis: Axis.horizontal,
title: TextWrapper.text('Flutter'), title: const TextWrapper.text('Flutter'),
subtitle: 'One single code base.'.wrap( subtitle: 'One single code base.'.wrap(
// gradient: [Colors.blue, Colors.green], // gradient: [Colors.blue, Colors.green],
style: const TextStyle( style: const TextStyle(
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
), ),
), ),
body: TextWrapper.text( body: const TextWrapper.text(
'Cupidatat reprehenderit aliqua eiusmod Lorem. ' 'Cupidatat reprehenderit aliqua eiusmod Lorem. '
'Qui ipsum id ea ea nulla labore aute ullamco aute ' 'Qui ipsum id ea ea nulla labore aute ullamco aute '
'quis elit ut amet velit. Incididunt fugiat proident ' 'quis elit ut amet velit. Incididunt fugiat proident '

View File

@ -128,10 +128,10 @@ class PortfolioCards extends StatelessWidget {
), ),
projectName: const TextWrapper( projectName: const TextWrapper(
'Flutter', 'Flutter',
gradient: [ gradientColors: MultiColor([
Colors.blue, Colors.blue,
Colors.green, Colors.green,
], ]),
), ),
subtitle: const TextWrapper('Mobile / Web / Macos.'), subtitle: const TextWrapper('Mobile / Web / Macos.'),
description: const TextWrapper( description: const TextWrapper(

View File

@ -49,7 +49,12 @@ class QuoteCards extends StatelessWidget {
'quis elit ut amet velit. Incididunt fugiat proident ' 'quis elit ut amet velit. Incididunt fugiat proident '
'proident deserunt tempor Lorem cillum qui do ' 'proident deserunt tempor Lorem cillum qui do '
'ullamco Lorem magna ipsum. Ullamco cupidatat velit ' 'ullamco Lorem magna ipsum. Ullamco cupidatat velit '
.wrap(gradient: [Colors.red, Colors.orange]), .wrap(
gradientColors: const MultiColor([
Colors.red,
Colors.orange,
]),
),
avatar: const FlutterLogo( avatar: const FlutterLogo(
size: 40, size: 40,
), ),

View File

@ -44,7 +44,7 @@ class SkillCards extends StatelessWidget {
'proident deserunt tempor Lorem cillum qui do ' 'proident deserunt tempor Lorem cillum qui do '
'ullamco Lorem magna ipsum. Ullamco cupidatat velit ' 'ullamco Lorem magna ipsum. Ullamco cupidatat velit '
.wrap(), .wrap(),
skills: [ skills: const [
TextWrapper.text('Firebase'), TextWrapper.text('Firebase'),
TextWrapper.text( TextWrapper.text(
'Qui ipsum id ea ea nulla labore aute ullamco aute ', 'Qui ipsum id ea ea nulla labore aute ullamco aute ',
@ -62,11 +62,14 @@ class SkillCards extends StatelessWidget {
'proident deserunt tempor Lorem cillum qui do ' 'proident deserunt tempor Lorem cillum qui do '
'ullamco Lorem magna ipsum. Ullamco cupidatat velit ' 'ullamco Lorem magna ipsum. Ullamco cupidatat velit '
.wrap(), .wrap(),
skills: [ skills: const [
TextWrapper.text('Firebase'), TextWrapper.text('Firebase'),
const TextWrapper( TextWrapper(
'Qui ipsum id ea ea nulla labore aute ullamco aute ', 'Qui ipsum id ea ea nulla labore aute ullamco aute ',
gradient: [Colors.red, Colors.orange], gradientColors: MultiColor([
Colors.red,
Colors.orange,
]),
), ),
TextWrapper.text('Firebase'), TextWrapper.text('Firebase'),
TextWrapper.text('Firebase'), TextWrapper.text('Firebase'),

View File

@ -0,0 +1,127 @@
// Copyright (C) 2023 WYATT GROUP
// Please see the AUTHORS file for details.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
import 'package:wyatt_ui_kit/wyatt_ui_kit.dart';
class CardTheme extends CardThemeExtension {
const CardTheme({
super.backgroundColors,
super.body,
super.borderColors,
super.secondaryBackgroundColor,
super.shadowColor,
super.subtitle,
super.title,
});
factory CardTheme.light() => CardTheme(
backgroundColors: const MultiColor.single(Color(0xFFF6F6F6)),
secondaryBackgroundColor: Colors.white,
borderColors: const MultiColor([
Color(0xFFDDE0E3),
Color(0xFFCACCD4),
]),
title: GoogleFonts.montserrat(
fontSize: 24,
fontWeight: FontWeight.w500,
color: const Color(0xFF24262A),
),
subtitle: GoogleFonts.montserrat(
fontSize: 15,
fontWeight: FontWeight.w300,
color: const Color(0xFF24262A),
),
body: GoogleFonts.montserrat(
fontSize: 12,
fontWeight: FontWeight.w300,
height: 1.7,
color: const Color(0xFF24262A),
),
);
factory CardTheme.dark() => CardTheme(
backgroundColors:
MultiColor.single(const Color(0xFFFFFFFF).withOpacity(0.04)),
secondaryBackgroundColor: const Color(0xFFFFFFFF).withOpacity(0.04),
borderColors: const MultiColor([
Color(0xFF60656A),
Color(0xFF383C40),
]),
title: GoogleFonts.montserrat(
fontSize: 24,
fontWeight: FontWeight.w500,
color: const Color(0xFFFFFFFF),
),
subtitle: GoogleFonts.montserrat(
fontSize: 15,
fontWeight: FontWeight.w300,
color: const Color(0xFFFFFFFF),
),
body: GoogleFonts.montserrat(
fontSize: 12,
fontWeight: FontWeight.w300,
height: 1.7,
color: const Color(0xFFFFFFFF),
),
);
@override
ThemeExtension<CardThemeExtension> copyWith({
MultiColor? backgroundColors,
Color? secondaryBackgroundColor,
MultiColor? borderColors,
BoxShadow? shadowColor,
TextStyle? body,
TextStyle? title,
TextStyle? subtitle,
}) =>
CardTheme(
backgroundColors: backgroundColors ?? this.backgroundColors,
secondaryBackgroundColor:
secondaryBackgroundColor ?? this.secondaryBackgroundColor,
borderColors: borderColors ?? this.borderColors,
shadowColor: shadowColor ?? this.shadowColor,
body: body ?? this.body,
title: title ?? this.title,
subtitle: subtitle ?? this.subtitle,
);
@override
ThemeExtension<CardThemeExtension> lerp(
covariant ThemeExtension<CardThemeExtension>? other,
double t,
) {
if (other is! CardTheme) {
return this;
}
return CardTheme(
backgroundColors: other.backgroundColors,
secondaryBackgroundColor: Color.lerp(
secondaryBackgroundColor,
other.secondaryBackgroundColor,
t,
),
borderColors: other.borderColors,
shadowColor: BoxShadow.lerp(shadowColor, other.shadowColor, t),
body: TextStyle.lerp(body, other.body, t),
title: TextStyle.lerp(title, other.title, t),
subtitle: TextStyle.lerp(subtitle, other.subtitle, t),
);
}
}

View File

@ -15,14 +15,14 @@
// along with this program. If not, see <https://www.gnu.org/licenses/>. // along with this program. If not, see <https://www.gnu.org/licenses/>.
import 'package:adaptive_theme/adaptive_theme.dart'; import 'package:adaptive_theme/adaptive_theme.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart' hide CardTheme;
import 'package:google_fonts/google_fonts.dart'; import 'package:google_fonts/google_fonts.dart';
import 'package:wyatt_ui_kit_example/theme/card_theme.dart';
import 'package:wyatt_ui_kit_example/theme/file_selection_button_theme.dart'; import 'package:wyatt_ui_kit_example/theme/file_selection_button_theme.dart';
import 'package:wyatt_ui_kit_example/theme/flat_button_theme.dart'; import 'package:wyatt_ui_kit_example/theme/flat_button_theme.dart';
import 'package:wyatt_ui_kit_example/theme/loader_theme.dart'; import 'package:wyatt_ui_kit_example/theme/loader_theme.dart';
import 'package:wyatt_ui_kit_example/theme/simple_icon_button_theme.dart'; import 'package:wyatt_ui_kit_example/theme/simple_icon_button_theme.dart';
import 'package:wyatt_ui_kit_example/theme/symbol_button_theme.dart'; import 'package:wyatt_ui_kit_example/theme/symbol_button_theme.dart';
import 'package:wyatt_ui_kit_example/theme_extension.dart';
/// Easely switch between Material and Studio themes. /// Easely switch between Material and Studio themes.
abstract class Themes { abstract class Themes {
@ -78,32 +78,8 @@ abstract class Themes {
), ),
scaffoldBackgroundColor: Colors.white, scaffoldBackgroundColor: Colors.white,
extensions: <ThemeExtension<dynamic>>[ extensions: <ThemeExtension<dynamic>>[
CustomCardColorExtension( // Cards
backgroundColors: const [ CardTheme.light(),
Color(0xFFF6F6F6),
],
secondaryBackgroundColors: Colors.white,
borderColor: const [
Color(0xFFDDE0E3),
Color(0xFFCACCD4),
],
title: GoogleFonts.montserrat(
fontSize: 24,
fontWeight: FontWeight.w500,
color: const Color(0xFF24262A),
),
subtitle: GoogleFonts.montserrat(
fontSize: 15,
fontWeight: FontWeight.w300,
color: const Color(0xFF24262A),
),
body: GoogleFonts.montserrat(
fontSize: 12,
fontWeight: FontWeight.w300,
height: 1.7,
color: const Color(0xFF24262A),
),
),
// Buttons // Buttons
FlatButtonTheme.light(), FlatButtonTheme.light(),
SymbolButtonTheme.light(), SymbolButtonTheme.light(),
@ -128,33 +104,8 @@ abstract class Themes {
), ),
scaffoldBackgroundColor: const Color(0xFF383C40), scaffoldBackgroundColor: const Color(0xFF383C40),
extensions: <ThemeExtension<dynamic>>[ extensions: <ThemeExtension<dynamic>>[
CustomCardColorExtension( // Cards
secondaryBackgroundColors: CardTheme.dark(),
const Color(0xFFFFFFFF).withOpacity(0.04),
backgroundColors: [
const Color(0xFFFFFFFF).withOpacity(0.04),
],
borderColor: const [
Color(0xFF60656A),
Color(0xFF383C40),
],
title: GoogleFonts.montserrat(
fontSize: 24,
fontWeight: FontWeight.w500,
color: const Color(0xFFFFFFFF),
),
subtitle: GoogleFonts.montserrat(
fontSize: 15,
fontWeight: FontWeight.w300,
color: const Color(0xFFFFFFFF),
),
body: GoogleFonts.montserrat(
fontSize: 12,
fontWeight: FontWeight.w300,
height: 1.7,
color: const Color(0xFFFFFFFF),
),
),
// Buttons // Buttons
FlatButtonTheme.dark(), FlatButtonTheme.dark(),
SymbolButtonTheme.dark(), SymbolButtonTheme.dark(),

View File

@ -1,54 +0,0 @@
import 'package:flutter/material.dart';
import 'package:wyatt_ui_kit/wyatt_ui_kit.dart' as ui_kit;
class CustomCardColorExtension extends ui_kit.CardThemeExtension {
const CustomCardColorExtension({
super.backgroundColors,
super.secondaryBackgroundColors,
super.borderColor,
super.shadowColor,
super.body,
super.title,
super.subtitle,
});
@override
CustomCardColorExtension copyWith({
List<Color>? backgroundColors,
Color? secondaryBackgroundColors,
List<Color>? borderColor,
BoxShadow? shadowColor,
TextStyle? body,
TextStyle? title,
TextStyle? subtitle,
}) =>
CustomCardColorExtension(
backgroundColors: backgroundColors ?? this.backgroundColors,
secondaryBackgroundColors:
secondaryBackgroundColors ?? this.secondaryBackgroundColors,
borderColor: borderColor ?? this.borderColor,
body: body ?? this.body,
title: title ?? this.title,
subtitle: subtitle ?? this.subtitle,
);
@override
ThemeExtension<ui_kit.CardThemeExtension> lerp(
covariant ThemeExtension<ui_kit.CardThemeExtension>? other,
double t,
) {
if (other is! CustomCardColorExtension) {
return this;
}
return CustomCardColorExtension(
secondaryBackgroundColors: Color.lerp(
secondaryBackgroundColors,
other.secondaryBackgroundColors,
t,
),
body: TextStyle.lerp(body, other.body, t),
title: TextStyle.lerp(title, other.title, t),
subtitle: TextStyle.lerp(subtitle, other.subtitle, t),
);
}
}

View File

@ -24,7 +24,6 @@ import 'package:wyatt_ui_kit/src/components/buttons/cubit/invalid_button_cubit.d
import 'package:wyatt_ui_kit/src/components/buttons/file_selection_button/dotter_border_child.dart'; import 'package:wyatt_ui_kit/src/components/buttons/file_selection_button/dotter_border_child.dart';
import 'package:wyatt_ui_kit/src/components/buttons/file_selection_button/file_selection_button_theme_resolver.dart'; import 'package:wyatt_ui_kit/src/components/buttons/file_selection_button/file_selection_button_theme_resolver.dart';
import 'package:wyatt_ui_kit/src/components/gradients/gradient_text.dart'; import 'package:wyatt_ui_kit/src/components/gradients/gradient_text.dart';
import 'package:wyatt_ui_kit/src/core/helpers/linear_gradient_helper.dart';
class FileSelectionButtonScreen class FileSelectionButtonScreen
extends CubitScreen<InvalidButtonCubit, ButtonState> { extends CubitScreen<InvalidButtonCubit, ButtonState> {
@ -220,13 +219,7 @@ class FileSelectionButtonScreen
title!.text, title!.text,
style: title!.style ?? style.title, style: title!.style ?? style.title,
).toGradient( ).toGradient(
LinearGradientHelper.fromNullableColors( gradientColors: style.foregroundColors,
title?.gradient ??
((style.foregroundColors?.isGradient ??
false)
? style.foregroundColors?.colors
: null),
),
), ),
], ],
@ -247,13 +240,7 @@ class FileSelectionButtonScreen
subTitle!.text, subTitle!.text,
style: subTitle!.style ?? style.subTitle, style: subTitle!.style ?? style.subTitle,
).toGradient( ).toGradient(
LinearGradientHelper.fromNullableColors( gradientColors: style.foregroundColors,
subTitle?.gradient ??
((style.foregroundColors?.isGradient ??
false)
? style.foregroundColors?.colors
: null),
),
), ),
], ],
], ],

View File

@ -23,7 +23,6 @@ import 'package:wyatt_ui_kit/src/components/buttons/cubit/button_cubit.dart';
import 'package:wyatt_ui_kit/src/components/buttons/flat_button/flat_button_theme_resolver.dart'; import 'package:wyatt_ui_kit/src/components/buttons/flat_button/flat_button_theme_resolver.dart';
import 'package:wyatt_ui_kit/src/components/gradients/gradient_box_border.dart'; import 'package:wyatt_ui_kit/src/components/gradients/gradient_box_border.dart';
import 'package:wyatt_ui_kit/src/components/gradients/gradient_text.dart'; import 'package:wyatt_ui_kit/src/components/gradients/gradient_text.dart';
import 'package:wyatt_ui_kit/src/core/helpers/linear_gradient_helper.dart';
class FlatButtonScreen extends CubitScreen<ButtonCubit, ButtonState> { class FlatButtonScreen extends CubitScreen<ButtonCubit, ButtonState> {
const FlatButtonScreen({ const FlatButtonScreen({
@ -204,12 +203,7 @@ class FlatButtonScreen extends CubitScreen<ButtonCubit, ButtonState> {
label!.text, label!.text,
style: label!.style ?? style.label, style: label!.style ?? style.label,
).toGradient( ).toGradient(
LinearGradientHelper.fromNullableColors( gradientColors: style.foregroundColors,
label?.gradient ??
((style.foregroundColors?.isGradient ?? false)
? style.foregroundColors?.colors
: null),
),
) )
], ],
Gap(style.padding?.vertical ?? 10), Gap(style.padding?.vertical ?? 10),

View File

@ -24,7 +24,6 @@ import 'package:wyatt_ui_kit/src/components/buttons/cubit/selectable_button_cubi
import 'package:wyatt_ui_kit/src/components/buttons/symbol_button/symbol_button_theme_resolver.dart'; import 'package:wyatt_ui_kit/src/components/buttons/symbol_button/symbol_button_theme_resolver.dart';
import 'package:wyatt_ui_kit/src/components/gradients/gradient_box_border.dart'; import 'package:wyatt_ui_kit/src/components/gradients/gradient_box_border.dart';
import 'package:wyatt_ui_kit/src/components/gradients/gradient_text.dart'; import 'package:wyatt_ui_kit/src/components/gradients/gradient_text.dart';
import 'package:wyatt_ui_kit/src/core/helpers/linear_gradient_helper.dart';
class SymbolButtonScreen class SymbolButtonScreen
extends CubitScreen<SelectableButtonCubit, ButtonState> { extends CubitScreen<SelectableButtonCubit, ButtonState> {
@ -228,12 +227,7 @@ class SymbolButtonScreen
label!.text, label!.text,
style: label!.style ?? style.label, style: label!.style ?? style.label,
).toGradient( ).toGradient(
LinearGradientHelper.fromNullableColors( gradientColors: style.foregroundColors,
label?.gradient ??
((style.foregroundColors?.isGradient ?? false)
? style.foregroundColors?.colors
: null),
),
), ),
], ],
], ],

View File

@ -80,7 +80,7 @@ class InformationCard extends InformationCardComponent
body!.text, body!.text,
textType: TextType.body, textType: TextType.body,
style: body!.style, style: body!.style,
gradient: body!.gradient, gradientColors: body!.gradientColors,
), ),
], ],
], ],

View File

@ -44,7 +44,7 @@ class InformationCardTitles extends StatelessWidget {
title!.text, title!.text,
textType: TextType.title, textType: TextType.title,
style: title!.style, style: title!.style,
gradient: title!.gradient, gradientColors: title!.gradientColors,
), ),
], ],
if (subtitle != null) ...[ if (subtitle != null) ...[
@ -53,7 +53,7 @@ class InformationCardTitles extends StatelessWidget {
subtitle!.text, subtitle!.text,
textType: TextType.subtitle, textType: TextType.subtitle,
style: subtitle!.style, style: subtitle!.style,
gradient: subtitle!.gradient, gradientColors: subtitle!.gradientColors,
), ),
], ],
], ],

View File

@ -73,7 +73,7 @@ class PortfolioCard extends PortfolioCardComponent with $PortfolioCardCWMixin {
description!.text, description!.text,
textType: TextType.body, textType: TextType.body,
style: description!.style, style: description!.style,
gradient: description!.gradient, gradientColors: description!.gradientColors,
), ),
const Gap(20), const Gap(20),
PortfolioCardHeader( PortfolioCardHeader(
@ -108,7 +108,7 @@ class PortfolioCard extends PortfolioCardComponent with $PortfolioCardCWMixin {
description!.text, description!.text,
textType: TextType.body, textType: TextType.body,
style: description!.style, style: description!.style,
gradient: description!.gradient, gradientColors: description!.gradientColors,
), ),
], ],
if (ctas != null) ...[const Gap(20), ...ctas!], if (ctas != null) ...[const Gap(20), ...ctas!],

View File

@ -71,7 +71,7 @@ class PortfolioCardHeader extends StatelessWidget {
color: secondaryBackgroundColors ?? color: secondaryBackgroundColors ??
Theme.of(context) Theme.of(context)
.extension<CardThemeExtension>() .extension<CardThemeExtension>()
?.secondaryBackgroundColors, ?.secondaryBackgroundColor,
borderRadius: BorderRadius.circular(8), borderRadius: BorderRadius.circular(8),
), ),
child: Text( child: Text(

View File

@ -20,8 +20,7 @@ import 'package:wyatt_component_copy_with_extension/component_copy_with_extensio
import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart'; import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
import 'package:wyatt_ui_kit/src/components/cards/widgets/card_text.dart'; import 'package:wyatt_ui_kit/src/components/cards/widgets/card_text.dart';
import 'package:wyatt_ui_kit/src/components/cards/widgets/card_wrapper.dart'; import 'package:wyatt_ui_kit/src/components/cards/widgets/card_wrapper.dart';
import 'package:wyatt_ui_kit/src/components/gradients/gradient_text.dart'; import 'package:wyatt_ui_kit/wyatt_ui_kit.dart';
import 'package:wyatt_ui_kit/src/core/extensions/theme_extensions.dart';
part 'quote_card.g.dart'; part 'quote_card.g.dart';
@ -63,9 +62,11 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
alignment: Alignment.topLeft, alignment: Alignment.topLeft,
child: GradientText( child: GradientText(
'', '',
gradient: gradient, style: GradientTextStyle.from(
style: context.textTheme.titleLarge context.textTheme.titleLarge
?.copyWith(fontWeight: FontWeight.bold), ?.copyWith(fontWeight: FontWeight.bold),
MultiColor(gradient?.colors),
),
), ),
), ),
if (quote != null) ...[ if (quote != null) ...[
@ -73,7 +74,7 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
quote!.text, quote!.text,
textType: TextType.body, textType: TextType.body,
style: quote!.style, style: quote!.style,
gradient: quote!.gradient, gradientColors: quote!.gradientColors,
), ),
], ],
const Gap(15), const Gap(15),
@ -82,9 +83,11 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
alignment: Alignment.bottomRight, alignment: Alignment.bottomRight,
child: GradientText( child: GradientText(
'', '',
gradient: gradient, style: GradientTextStyle.from(
style: context.textTheme.titleLarge context.textTheme.titleLarge
?.copyWith(fontWeight: FontWeight.bold), ?.copyWith(fontWeight: FontWeight.bold),
MultiColor(gradient?.colors),
),
), ),
), ),
Row( Row(
@ -102,7 +105,7 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
name!.text, name!.text,
textType: TextType.body, textType: TextType.body,
style: name!.style, style: name!.style,
gradient: name!.gradient, gradientColors: name!.gradientColors,
), ),
], ],
if (subtitle != null) ...[ if (subtitle != null) ...[
@ -110,7 +113,7 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
subtitle!.text, subtitle!.text,
textType: TextType.subtitle, textType: TextType.subtitle,
style: subtitle!.style, style: subtitle!.style,
gradient: subtitle!.gradient, gradientColors: subtitle!.gradientColors,
), ),
], ],
], ],

View File

@ -70,7 +70,7 @@ class SkillCard extends SkillCardComponent with $SkillCardCWMixin {
description!.text, description!.text,
textType: TextType.body, textType: TextType.body,
style: description!.style, style: description!.style,
gradient: description!.gradient, gradientColors: description!.gradientColors,
), ),
const Gap(25), const Gap(25),
], ],

View File

@ -46,7 +46,7 @@ class SkillCardHeader extends StatelessWidget {
color: secondaryBackgroundColors ?? color: secondaryBackgroundColors ??
Theme.of(context) Theme.of(context)
.extension<CardThemeExtension>() .extension<CardThemeExtension>()
?.secondaryBackgroundColors, ?.secondaryBackgroundColor,
), ),
child: gradient != null child: gradient != null
? GradientIcon( ? GradientIcon(
@ -67,7 +67,7 @@ class SkillCardHeader extends StatelessWidget {
title!.text, title!.text,
textType: TextType.title, textType: TextType.title,
style: title!.style, style: title!.style,
gradient: title!.gradient, gradientColors: title!.gradientColors,
), ),
], ],
], ],

View File

@ -50,7 +50,7 @@ class SkillCardSkills extends StatelessWidget {
e.text, e.text,
textType: TextType.body, textType: TextType.body,
style: e.style, style: e.style,
gradient: e.gradient, gradientColors: e.gradientColors,
), ),
), ),
], ],

View File

@ -15,7 +15,7 @@
// along with this program. If not, see <https://www.gnu.org/licenses/>. // along with this program. If not, see <https://www.gnu.org/licenses/>.
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:wyatt_ui_kit/src/components/gradients/gradient_text.dart'; import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
import 'package:wyatt_ui_kit/wyatt_ui_kit.dart'; import 'package:wyatt_ui_kit/wyatt_ui_kit.dart';
enum TextType { enum TextType {
@ -28,13 +28,13 @@ class CardText extends StatelessWidget {
const CardText( const CardText(
this.data, { this.data, {
required this.textType, required this.textType,
this.gradient,
this.style, this.style,
this.gradientColors,
super.key, super.key,
}); });
final TextType textType; final TextType textType;
final TextStyle? style; final TextStyle? style;
final List<Color>? gradient; final MultiColor? gradientColors;
final String data; final String data;
TextStyle? _getStyle(BuildContext context) { TextStyle? _getStyle(BuildContext context) {
@ -58,9 +58,5 @@ class CardText extends StatelessWidget {
Widget build(BuildContext context) => Text( Widget build(BuildContext context) => Text(
data, data,
style: _getStyle(context), style: _getStyle(context),
).toGradient( ).toGradient(gradientColors: gradientColors);
LinearGradientHelper.fromNullableColors(
gradient,
),
);
} }

View File

@ -110,8 +110,9 @@ class _CardWrapperState extends State<CardWrapper> {
if (extensionCardColor != null && if (extensionCardColor != null &&
extensionCardColor.backgroundColors != null && extensionCardColor.backgroundColors != null &&
extensionCardColor.backgroundColors!.length >= 2) { extensionCardColor.backgroundColors!.isGradient) {
return LinearGradient(colors: extensionCardColor.backgroundColors!); return LinearGradient(
colors: extensionCardColor.backgroundColors!.colors,);
} }
} }
return null; return null;
@ -126,9 +127,8 @@ class _CardWrapperState extends State<CardWrapper> {
Theme.of(context).extension<CardThemeExtension>(); Theme.of(context).extension<CardThemeExtension>();
if (extensionCardColor != null && if (extensionCardColor != null &&
extensionCardColor.backgroundColors != null && extensionCardColor.backgroundColors != null) {
extensionCardColor.backgroundColors!.length == 1) { return extensionCardColor.backgroundColors!.color;
return extensionCardColor.backgroundColors!.first;
} }
} }
return Theme.of(context).cardColor; return Theme.of(context).cardColor;
@ -151,16 +151,16 @@ class _CardWrapperState extends State<CardWrapper> {
final extensionCardColor = final extensionCardColor =
Theme.of(context).extension<CardThemeExtension>(); Theme.of(context).extension<CardThemeExtension>();
if (extensionCardColor != null && if (extensionCardColor != null &&
extensionCardColor.borderColor != null) { extensionCardColor.borderColors != null) {
if (extensionCardColor.borderColor!.length >= 2) { if (extensionCardColor.borderColors!.isGradient) {
return GradientBoxBorder( return GradientBoxBorder(
gradient: LinearGradient( gradient: LinearGradient(
colors: extensionCardColor.borderColor!, colors: extensionCardColor.borderColors!.colors,
), ),
); );
} else if (extensionCardColor.backgroundColors!.isNotEmpty) { } else if (extensionCardColor.backgroundColors!.colors.isNotEmpty) {
return Border.all( return Border.all(
color: extensionCardColor.backgroundColors!.first, color: extensionCardColor.backgroundColors!.color,
); );
} }
} }

View File

@ -17,16 +17,29 @@
// along with this program. If not, see <https://www.gnu.org/licenses/>. // along with this program. If not, see <https://www.gnu.org/licenses/>.
import 'package:flutter/widgets.dart'; import 'package:flutter/widgets.dart';
import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
import 'package:wyatt_ui_kit/wyatt_ui_kit.dart';
extension GradientTextExtension on Text { extension GradientTextExtension on Text {
GradientText toGradient(Gradient? gradient) => /// If this text contains a [GradientTextStyle] it simply transforms it in
GradientText.from(this, gradient); /// [GradientText], if not it needs a [MultiColor].
GradientText toGradient({MultiColor? gradientColors}) {
if (style is GradientTextStyle?) {
// Gradient
final gradientStyle = (style as GradientTextStyle?)?.gradientColors;
return GradientText.from(this, gradientStyle ?? gradientColors);
}
return GradientText.from(this, gradientColors);
}
GradientText toFlutterGradient(Gradient? gradient) =>
GradientText.from(this, MultiColor(gradient?.colors));
} }
class GradientText extends Text { class GradientText extends Text {
const GradientText( const GradientText(
super.data, { super.data, {
this.gradient,
super.style, super.style,
super.strutStyle, super.strutStyle,
super.textAlign, super.textAlign,
@ -43,10 +56,10 @@ class GradientText extends Text {
super.key, super.key,
}); });
factory GradientText.from(Text text, Gradient? gradient) => GradientText( factory GradientText.from(Text text, MultiColor? gradientColors) =>
GradientText(
text.data ?? '', text.data ?? '',
style: text.style, style: GradientTextStyle.from(text.style, gradientColors),
gradient: gradient,
strutStyle: text.strutStyle, strutStyle: text.strutStyle,
textAlign: text.textAlign, textAlign: text.textAlign,
textDirection: text.textDirection, textDirection: text.textDirection,
@ -62,20 +75,24 @@ class GradientText extends Text {
key: text.key, key: text.key,
); );
final Gradient? gradient;
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
if (gradient != null) { if (style is GradientTextStyle?) {
return ShaderMask( // Gradient
blendMode: BlendMode.srcIn, final gradientStyle = (style as GradientTextStyle?)?.gradientColors;
shaderCallback: (bounds) => gradient!.createShader( final gradient = (gradientStyle?.isGradient ?? false)
Rect.fromLTWH(0, 0, bounds.width, bounds.height), ? LinearGradientHelper.fromMultiColor(gradientStyle!)
), : null;
child: super.build(context), if (gradient != null) {
); return ShaderMask(
} else { blendMode: BlendMode.srcIn,
return super.build(context); shaderCallback: (bounds) => gradient.createShader(
Rect.fromLTWH(0, 0, bounds.width, bounds.height),
),
child: super.build(context),
);
}
} }
return super.build(context);
} }
} }

View File

@ -0,0 +1,85 @@
// Copyright (C) 2023 WYATT GROUP
// Please see the AUTHORS file for details.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
import 'package:flutter/widgets.dart';
import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
class GradientTextStyle extends TextStyle {
const GradientTextStyle({
this.gradientColors,
super.inherit,
super.color,
super.backgroundColor,
super.fontSize,
super.fontWeight,
super.fontStyle,
super.letterSpacing,
super.wordSpacing,
super.textBaseline,
super.height,
super.leadingDistribution,
super.locale,
super.foreground,
super.background,
super.shadows,
super.fontFeatures,
super.fontVariations,
super.decoration,
super.decorationColor,
super.decorationStyle,
super.decorationThickness,
super.debugLabel,
super.fontFamily,
super.fontFamilyFallback,
super.package,
super.overflow,
});
factory GradientTextStyle.from(
TextStyle? textStyle,
MultiColor? gradientColors,
) =>
GradientTextStyle(
gradientColors: gradientColors,
inherit: textStyle?.inherit ?? true,
color: textStyle?.color,
backgroundColor: textStyle?.backgroundColor,
fontSize: textStyle?.fontSize,
fontWeight: textStyle?.fontWeight,
fontStyle: textStyle?.fontStyle,
letterSpacing: textStyle?.letterSpacing,
wordSpacing: textStyle?.wordSpacing,
textBaseline: textStyle?.textBaseline,
height: textStyle?.height,
leadingDistribution: textStyle?.leadingDistribution,
locale: textStyle?.locale,
foreground: textStyle?.foreground,
background: textStyle?.background,
shadows: textStyle?.shadows,
fontFeatures: textStyle?.fontFeatures,
fontVariations: textStyle?.fontVariations,
decoration: textStyle?.decoration,
decorationColor: textStyle?.decorationColor,
decorationStyle: textStyle?.decorationStyle,
decorationThickness: textStyle?.decorationThickness,
debugLabel: textStyle?.debugLabel,
fontFamily: textStyle?.fontFamily,
fontFamilyFallback: textStyle?.fontFamilyFallback,
overflow: textStyle?.overflow,
);
final MultiColor? gradientColors;
}

View File

@ -0,0 +1,20 @@
// Copyright (C) 2023 WYATT GROUP
// Please see the AUTHORS file for details.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
export 'gradient_box_border.dart';
export 'gradient_icon.dart';
export 'gradient_text.dart';
export 'gradient_text_style.dart';

View File

@ -15,12 +15,13 @@
// along with this program. If not, see <https://www.gnu.org/licenses/>. // along with this program. If not, see <https://www.gnu.org/licenses/>.
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
abstract class CardThemeExtension extends ThemeExtension<CardThemeExtension> { abstract class CardThemeExtension extends ThemeExtension<CardThemeExtension> {
const CardThemeExtension({ const CardThemeExtension({
this.backgroundColors, this.backgroundColors,
this.secondaryBackgroundColors, this.secondaryBackgroundColor,
this.borderColor, this.borderColors,
this.shadowColor, this.shadowColor,
this.body, this.body,
this.title, this.title,
@ -28,9 +29,9 @@ abstract class CardThemeExtension extends ThemeExtension<CardThemeExtension> {
}); });
// Colors // Colors
final List<Color>? backgroundColors; final MultiColor? backgroundColors;
final Color? secondaryBackgroundColors; final Color? secondaryBackgroundColor;
final List<Color>? borderColor; final MultiColor? borderColors;
final BoxShadow? shadowColor; final BoxShadow? shadowColor;
// TextStyles // TextStyles