master #81
@ -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;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -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;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -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),
 | 
				
			||||||
 | 
				
			|||||||
@ -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 '
 | 
				
			||||||
 | 
				
			|||||||
@ -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(
 | 
				
			||||||
 | 
				
			|||||||
@ -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,
 | 
				
			||||||
                ),
 | 
					                ),
 | 
				
			||||||
 | 
				
			|||||||
@ -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'),
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										127
									
								
								packages/wyatt_ui_kit/example/lib/theme/card_theme.dart
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								packages/wyatt_ui_kit/example/lib/theme/card_theme.dart
									
									
									
									
									
										Normal 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),
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -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(),
 | 
				
			||||||
 | 
				
			|||||||
@ -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),
 | 
					 | 
				
			||||||
    );
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@ -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),
 | 
					 | 
				
			||||||
                              ),
 | 
					 | 
				
			||||||
                            ),
 | 
					                            ),
 | 
				
			||||||
                          ],
 | 
					                          ],
 | 
				
			||||||
                        ],
 | 
					                        ],
 | 
				
			||||||
 | 
				
			|||||||
@ -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),
 | 
				
			||||||
 | 
				
			|||||||
@ -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),
 | 
					 | 
				
			||||||
                  ),
 | 
					 | 
				
			||||||
                ),
 | 
					                ),
 | 
				
			||||||
              ],
 | 
					              ],
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
 | 
				
			|||||||
@ -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,
 | 
				
			||||||
              ),
 | 
					              ),
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
          ],
 | 
					          ],
 | 
				
			||||||
 | 
				
			|||||||
@ -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,
 | 
				
			||||||
            ),
 | 
					            ),
 | 
				
			||||||
          ],
 | 
					          ],
 | 
				
			||||||
        ],
 | 
					        ],
 | 
				
			||||||
 | 
				
			|||||||
@ -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!],
 | 
				
			||||||
 | 
				
			|||||||
@ -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(
 | 
				
			||||||
 | 
				
			|||||||
@ -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,
 | 
				
			||||||
                        ),
 | 
					                        ),
 | 
				
			||||||
                      ],
 | 
					                      ],
 | 
				
			||||||
                    ],
 | 
					                    ],
 | 
				
			||||||
 | 
				
			|||||||
@ -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),
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
 | 
				
			|||||||
@ -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,
 | 
				
			||||||
                  ),
 | 
					                  ),
 | 
				
			||||||
                ],
 | 
					                ],
 | 
				
			||||||
              ],
 | 
					              ],
 | 
				
			||||||
 | 
				
			|||||||
@ -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,
 | 
				
			||||||
                    ),
 | 
					                    ),
 | 
				
			||||||
                  ),
 | 
					                  ),
 | 
				
			||||||
                ],
 | 
					                ],
 | 
				
			||||||
 | 
				
			|||||||
@ -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,
 | 
					 | 
				
			||||||
        ),
 | 
					 | 
				
			||||||
      );
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -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,
 | 
				
			||||||
          );
 | 
					          );
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
				
			|||||||
@ -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);
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -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;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -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';
 | 
				
			||||||
@ -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
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user