Compare commits
5 Commits
c5f8b69184
...
2769d45e20
Author | SHA1 | Date | |
---|---|---|---|
2769d45e20 | |||
66719732f7 | |||
25018dc78a | |||
efeb3acff3 | |||
ef52015372 |
9
packages/wyatt_ui_components/build.yaml
Normal file
9
packages/wyatt_ui_components/build.yaml
Normal file
@ -0,0 +1,9 @@
|
||||
targets:
|
||||
$default:
|
||||
builders:
|
||||
# Typically the builder key is just the package name, run `pub run build_runner doctor` to check your config.
|
||||
wyatt_component_copy_with_gen:component_copy_with_gen:
|
||||
generate_for:
|
||||
# Example glob for only the Dart files under `lib/models`
|
||||
- lib/**/*.dart
|
||||
- example/lib/**/*.dart
|
@ -15,10 +15,11 @@
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
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? {
|
||||
TextWrapper? wrap({TextStyle? style, List<Color>? gradient}) => this != null
|
||||
? TextWrapper(this!, style: style, gradient: gradient)
|
||||
: null;
|
||||
TextWrapper? wrap({TextStyle? style, MultiColor? gradientColors}) =>
|
||||
this != null
|
||||
? TextWrapper(this!, style: style, gradientColors: gradientColors)
|
||||
: null;
|
||||
}
|
||||
|
@ -15,17 +15,22 @@
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
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 {
|
||||
const TextWrapper(
|
||||
this.text, {
|
||||
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 TextStyle? style;
|
||||
final List<Color>? gradient;
|
||||
final MultiColor? gradientColors;
|
||||
}
|
||||
|
@ -23,4 +23,5 @@ export './error_widget_component.dart';
|
||||
export './loader_component.dart';
|
||||
export './loader_style.dart';
|
||||
export './loading_widget_component.dart';
|
||||
export './rich_text_builder/rich_text_builder.dart';
|
||||
export './theme_style.dart';
|
||||
|
@ -0,0 +1,120 @@
|
||||
// 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';
|
||||
|
||||
class RichTextStyleParameter {
|
||||
const RichTextStyleParameter(
|
||||
this.defaultStyle,
|
||||
this.definedStyle,
|
||||
this.styleName,
|
||||
);
|
||||
|
||||
final TextStyle defaultStyle;
|
||||
final Map<String, TextStyle> definedStyle;
|
||||
final String? styleName;
|
||||
|
||||
TextStyle get style {
|
||||
if (definedStyle.containsKey(styleName)) {
|
||||
return definedStyle[styleName]!;
|
||||
}
|
||||
return defaultStyle;
|
||||
}
|
||||
|
||||
RichTextStyleParameter copyWith({
|
||||
TextStyle? defaultStyle,
|
||||
Map<String, TextStyle>? definedStyle,
|
||||
String? styleName,
|
||||
}) =>
|
||||
RichTextStyleParameter(
|
||||
defaultStyle ?? this.defaultStyle,
|
||||
definedStyle ?? this.definedStyle,
|
||||
styleName ?? this.styleName,
|
||||
);
|
||||
}
|
||||
|
||||
class RichTextNode {
|
||||
RichTextNode(this.nodes);
|
||||
|
||||
final List<RichTextNode> nodes;
|
||||
|
||||
static RichTextNode from(
|
||||
String content,
|
||||
RegExp regex,
|
||||
RichTextStyleParameter styleParameter,
|
||||
) {
|
||||
final matches = regex.allMatches(content);
|
||||
if (matches.isNotEmpty) {
|
||||
// match found -> construct node with leaf/nodes
|
||||
final List<RichTextNode> nodes = [];
|
||||
for (var i = 0; i < matches.length; i++) {
|
||||
final previousMatch = i > 0 ? matches.elementAt(i - 1) : null;
|
||||
final currentMatch = matches.elementAt(i);
|
||||
// non match before
|
||||
final nonMatchBefore = (previousMatch != null)
|
||||
? content.substring(previousMatch.end, currentMatch.start)
|
||||
: content.substring(0, currentMatch.start);
|
||||
nodes
|
||||
..add(RichTextNode.from(nonMatchBefore, regex, styleParameter))
|
||||
// match
|
||||
..add(
|
||||
RichTextNode.from(
|
||||
currentMatch.group(2)!,
|
||||
regex,
|
||||
styleParameter.copyWith(styleName: currentMatch.group(1)),
|
||||
),
|
||||
);
|
||||
}
|
||||
// non match after
|
||||
final nonMatchAfter = content.substring(matches.last.end);
|
||||
nodes.add(RichTextNode.from(nonMatchAfter, regex, styleParameter));
|
||||
return RichTextNode(nodes);
|
||||
} else {
|
||||
// match not found -> construct leaf
|
||||
return RichTextLeaf(styleParameter.style, content);
|
||||
}
|
||||
}
|
||||
|
||||
InlineSpan toInlineSpan(RichTextParser parser) {
|
||||
final children = <InlineSpan>[];
|
||||
for (final node in nodes) {
|
||||
children.add(node.toInlineSpan(parser));
|
||||
}
|
||||
return TextSpan(children: children);
|
||||
}
|
||||
}
|
||||
|
||||
class RichTextLeaf extends RichTextNode {
|
||||
RichTextLeaf(this.style, this.content) : super([]);
|
||||
|
||||
final TextStyle style;
|
||||
final String content;
|
||||
|
||||
@override
|
||||
InlineSpan toInlineSpan(RichTextParser parser) =>
|
||||
parser.nodeBuilder.call(content, style);
|
||||
}
|
||||
|
||||
class RichTextParser {
|
||||
const RichTextParser({required this.nodeBuilder});
|
||||
factory RichTextParser.defaultBuilder() => RichTextParser(
|
||||
nodeBuilder: (content, style) => TextSpan(
|
||||
text: content,
|
||||
style: style,
|
||||
),
|
||||
);
|
||||
final InlineSpan Function(String content, TextStyle style) nodeBuilder;
|
||||
}
|
@ -0,0 +1,19 @@
|
||||
// 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 'parser.dart';
|
||||
export 'rich_text_builder_component.dart';
|
||||
export 'rich_text_builder_style.dart';
|
@ -0,0 +1,56 @@
|
||||
// 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_component_copy_with_extension/component_copy_with_extension.dart';
|
||||
import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
|
||||
|
||||
part 'rich_text_builder_component.g.dart';
|
||||
|
||||
@ComponentProxyExtension()
|
||||
abstract class RichTextBuilderComponent extends Component
|
||||
with CopyWithMixin<$RichTextBuilderComponentCWProxy> {
|
||||
const RichTextBuilderComponent({
|
||||
this.text,
|
||||
this.parser,
|
||||
this.defaultStyle,
|
||||
this.styles,
|
||||
super.themeResolver,
|
||||
super.key,
|
||||
});
|
||||
|
||||
/// Full text
|
||||
final String? text;
|
||||
|
||||
/// How to build InlineSpans
|
||||
final RichTextParser? parser;
|
||||
|
||||
/// Default TextStyle used in this rich text component.
|
||||
final TextStyle? defaultStyle;
|
||||
|
||||
/// Used styles in this rich text component.
|
||||
///
|
||||
/// e.g.
|
||||
/// ```dart
|
||||
/// styles = {'red': TextStyle(color: Colors.red)};
|
||||
/// ```
|
||||
/// will transform:
|
||||
/// ```text
|
||||
/// This text <red>is red</red.
|
||||
/// ```
|
||||
/// in "This text `is red`."
|
||||
final Map<String, TextStyle>? styles;
|
||||
}
|
@ -0,0 +1,25 @@
|
||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
||||
|
||||
part of 'rich_text_builder_component.dart';
|
||||
|
||||
// **************************************************************************
|
||||
// ComponentProxyGenerator
|
||||
// **************************************************************************
|
||||
|
||||
abstract class $RichTextBuilderComponentCWProxy {
|
||||
RichTextBuilderComponent text(String? text);
|
||||
RichTextBuilderComponent parser(RichTextParser? parser);
|
||||
RichTextBuilderComponent defaultStyle(TextStyle? defaultStyle);
|
||||
RichTextBuilderComponent styles(Map<String, TextStyle>? styles);
|
||||
RichTextBuilderComponent themeResolver(
|
||||
ThemeResolver<dynamic, dynamic, dynamic>? themeResolver);
|
||||
RichTextBuilderComponent key(Key? key);
|
||||
RichTextBuilderComponent call({
|
||||
String? text,
|
||||
RichTextParser? parser,
|
||||
TextStyle? defaultStyle,
|
||||
Map<String, TextStyle>? styles,
|
||||
ThemeResolver<dynamic, dynamic, dynamic>? themeResolver,
|
||||
Key? key,
|
||||
});
|
||||
}
|
@ -0,0 +1,83 @@
|
||||
// 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 RichTextBuilderStyle extends ThemeStyle<RichTextBuilderStyle> {
|
||||
const RichTextBuilderStyle({
|
||||
this.defaultStyle,
|
||||
this.styles,
|
||||
});
|
||||
|
||||
/// Merges non-null `b` attributes in `a`
|
||||
static RichTextBuilderStyle? merge(
|
||||
RichTextBuilderStyle? a,
|
||||
RichTextBuilderStyle? b,
|
||||
) {
|
||||
if (b == null) {
|
||||
return a?.copyWith();
|
||||
}
|
||||
if (a == null) {
|
||||
return b.copyWith();
|
||||
}
|
||||
|
||||
return a.copyWith(
|
||||
defaultStyle: b.defaultStyle,
|
||||
styles: b.styles,
|
||||
);
|
||||
}
|
||||
|
||||
/// Used for interpolation.
|
||||
static RichTextBuilderStyle? lerp(
|
||||
RichTextBuilderStyle? a,
|
||||
RichTextBuilderStyle? b,
|
||||
double t,
|
||||
) {
|
||||
if (a == null || b == null) {
|
||||
return null;
|
||||
}
|
||||
// b.copyWith to return b attributes even if they are not lerped
|
||||
return b.copyWith(
|
||||
defaultStyle: TextStyle.lerp(a.defaultStyle, b.defaultStyle, t),
|
||||
styles: b.styles, // TODO(wyatt): compute lerp value of each styles
|
||||
);
|
||||
}
|
||||
|
||||
/// Default TextStyle used in this rich text component.
|
||||
final TextStyle? defaultStyle;
|
||||
|
||||
/// Used styles in this rich text component.
|
||||
final Map<String, TextStyle>? styles;
|
||||
|
||||
@override
|
||||
RichTextBuilderStyle mergeWith(RichTextBuilderStyle? other) =>
|
||||
RichTextBuilderStyle.merge(this, other)!;
|
||||
|
||||
@override
|
||||
RichTextBuilderStyle? lerpWith(RichTextBuilderStyle? other, double t) =>
|
||||
RichTextBuilderStyle.lerp(this, other, t);
|
||||
|
||||
@override
|
||||
RichTextBuilderStyle copyWith({
|
||||
TextStyle? defaultStyle,
|
||||
Map<String, TextStyle>? styles,
|
||||
}) =>
|
||||
RichTextBuilderStyle(
|
||||
defaultStyle: defaultStyle ?? this.defaultStyle,
|
||||
styles: styles ?? this.styles,
|
||||
);
|
||||
}
|
8
packages/wyatt_ui_kit/build.yaml
Normal file
8
packages/wyatt_ui_kit/build.yaml
Normal file
@ -0,0 +1,8 @@
|
||||
targets:
|
||||
$default:
|
||||
builders:
|
||||
# Typically the builder key is just the package name, run `pub run build_runner doctor` to check your config.
|
||||
wyatt_component_copy_with_gen:component_copy_with_gen:
|
||||
generate_for:
|
||||
# Example glob for only the Dart files under `lib/models`
|
||||
- lib/**/*.dart
|
@ -31,8 +31,14 @@ class FlatButtons extends StatelessWidget {
|
||||
),
|
||||
const Gap(20),
|
||||
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(
|
||||
label: const TextWrapper('Voir notre savoir faire'),
|
||||
label: const TextWrapper(
|
||||
'Voir notre savoir faire',
|
||||
),
|
||||
),
|
||||
),
|
||||
const Gap(20),
|
||||
|
@ -18,13 +18,13 @@ class InformationCards extends StatelessWidget {
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: [
|
||||
InformationCard(
|
||||
icons: const [
|
||||
const InformationCard(
|
||||
icons: [
|
||||
FlutterLogo(size: 60),
|
||||
FlutterLogo(size: 60),
|
||||
FlutterLogo(size: 60),
|
||||
],
|
||||
title: const TextWrapper('Flutter'),
|
||||
title: TextWrapper('Flutter'),
|
||||
subtitle: TextWrapper.text('One single code base.'),
|
||||
body: TextWrapper.text(
|
||||
'Cupidatat reprehenderit aliqua eiusmod Lorem. '
|
||||
@ -58,9 +58,9 @@ class InformationCards extends StatelessWidget {
|
||||
FlutterLogo(size: 60),
|
||||
],
|
||||
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. '
|
||||
'Qui ipsum id ea ea nulla labore aute ullamco aute '
|
||||
'quis elit ut amet velit. Incididunt fugiat proident '
|
||||
@ -86,8 +86,8 @@ class InformationCards extends StatelessWidget {
|
||||
FlutterLogo(size: 60),
|
||||
],
|
||||
axis: Axis.horizontal,
|
||||
title: TextWrapper.text('Flutter'),
|
||||
subtitle: TextWrapper.text('One single code base.'),
|
||||
title: const TextWrapper.text('Flutter'),
|
||||
subtitle: const TextWrapper.text('One single code base.'),
|
||||
body: 'Cupidatat reprehenderit aliqua eiusmod Lorem. '
|
||||
'Qui ipsum id ea ea nulla labore aute ullamco aute '
|
||||
'quis elit ut amet velit. Incididunt fugiat proident '
|
||||
@ -100,10 +100,10 @@ class InformationCards extends StatelessWidget {
|
||||
'magna cupidatat Lorem nulla cupidatat voluptate '
|
||||
'irure ex reprehenderit.'
|
||||
.wrap(
|
||||
gradient: [
|
||||
gradientColors: const MultiColor([
|
||||
Colors.red,
|
||||
Colors.orange,
|
||||
],
|
||||
]),
|
||||
),
|
||||
),
|
||||
const Gap(20),
|
||||
@ -123,14 +123,14 @@ class InformationCards extends StatelessWidget {
|
||||
FlutterLogo(size: 60),
|
||||
],
|
||||
axis: Axis.horizontal,
|
||||
title: TextWrapper.text('Flutter'),
|
||||
title: const TextWrapper.text('Flutter'),
|
||||
subtitle: 'One single code base.'.wrap(
|
||||
// gradient: [Colors.blue, Colors.green],
|
||||
style: const TextStyle(
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
),
|
||||
body: TextWrapper.text(
|
||||
body: const TextWrapper.text(
|
||||
'Cupidatat reprehenderit aliqua eiusmod Lorem. '
|
||||
'Qui ipsum id ea ea nulla labore aute ullamco aute '
|
||||
'quis elit ut amet velit. Incididunt fugiat proident '
|
||||
|
@ -128,10 +128,10 @@ class PortfolioCards extends StatelessWidget {
|
||||
),
|
||||
projectName: const TextWrapper(
|
||||
'Flutter',
|
||||
gradient: [
|
||||
gradientColors: MultiColor([
|
||||
Colors.blue,
|
||||
Colors.green,
|
||||
],
|
||||
]),
|
||||
),
|
||||
subtitle: const TextWrapper('Mobile / Web / Macos.'),
|
||||
description: const TextWrapper(
|
||||
|
@ -49,7 +49,12 @@ class QuoteCards extends StatelessWidget {
|
||||
'quis elit ut amet velit. Incididunt fugiat proident '
|
||||
'proident deserunt tempor Lorem cillum qui do '
|
||||
'ullamco Lorem magna ipsum. Ullamco cupidatat velit '
|
||||
.wrap(gradient: [Colors.red, Colors.orange]),
|
||||
.wrap(
|
||||
gradientColors: const MultiColor([
|
||||
Colors.red,
|
||||
Colors.orange,
|
||||
]),
|
||||
),
|
||||
avatar: const FlutterLogo(
|
||||
size: 40,
|
||||
),
|
||||
|
@ -44,7 +44,7 @@ class SkillCards extends StatelessWidget {
|
||||
'proident deserunt tempor Lorem cillum qui do '
|
||||
'ullamco Lorem magna ipsum. Ullamco cupidatat velit '
|
||||
.wrap(),
|
||||
skills: [
|
||||
skills: const [
|
||||
TextWrapper.text('Firebase'),
|
||||
TextWrapper.text(
|
||||
'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 '
|
||||
'ullamco Lorem magna ipsum. Ullamco cupidatat velit '
|
||||
.wrap(),
|
||||
skills: [
|
||||
skills: const [
|
||||
TextWrapper.text('Firebase'),
|
||||
const TextWrapper(
|
||||
TextWrapper(
|
||||
'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'),
|
||||
|
@ -5,6 +5,7 @@ import 'package:wyatt_ui_kit_example/buttons/buttons.dart';
|
||||
import 'package:wyatt_ui_kit_example/cards/cards.dart';
|
||||
import 'package:wyatt_ui_kit_example/demo_page.dart';
|
||||
import 'package:wyatt_ui_kit_example/loaders/loaders.dart';
|
||||
import 'package:wyatt_ui_kit_example/rich_text_builders/rich_text_builders.dart';
|
||||
import 'package:wyatt_ui_kit_example/theme/themes.dart';
|
||||
|
||||
const String title = 'Wyatt UIKit Example';
|
||||
@ -20,7 +21,12 @@ class Home extends StatefulWidget {
|
||||
|
||||
class _HomeState extends State<Home> {
|
||||
// Simply add your demo page here.
|
||||
final List<DemoPage> pages = const [Cards(), Buttons(), Loaders()];
|
||||
final List<DemoPage> pages = const [
|
||||
Cards(),
|
||||
Buttons(),
|
||||
Loaders(),
|
||||
RichTextBuilders(),
|
||||
];
|
||||
|
||||
int currentIndex = 0;
|
||||
|
||||
|
@ -0,0 +1,63 @@
|
||||
// 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:gap/gap.dart';
|
||||
import 'package:wyatt_ui_kit/wyatt_ui_kit.dart';
|
||||
import 'package:wyatt_ui_kit_example/demo_page.dart';
|
||||
|
||||
class RichTextBuilders extends DemoPage {
|
||||
const RichTextBuilders({super.key});
|
||||
|
||||
@override
|
||||
String get title => 'RichTextBuilders';
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) => ListView(
|
||||
cacheExtent: 1000,
|
||||
children: [
|
||||
const Gap(20),
|
||||
Align(
|
||||
child: Text(
|
||||
title,
|
||||
style: Theme.of(context).textTheme.titleLarge,
|
||||
),
|
||||
),
|
||||
const Gap(20),
|
||||
const Padding(
|
||||
padding: EdgeInsets.all(8),
|
||||
child: RichTextBuilder(
|
||||
text: '''
|
||||
Innovation, Expertise et Accompagnement...
|
||||
Notre agence de développement Wyatt Studio met tout en oeuvre pour vous aider à <gradient-blue>concrétiser vos idées</gradient-blue> de solutions informatiques et mobiles.
|
||||
|
||||
Vous aussi, comme beaucoup d’autres <gradient-blue>agences ou startups</gradient-blue>, faites nous confiance pour la réalisation de votre projet dès maintenant !
|
||||
''',
|
||||
),
|
||||
),
|
||||
const Gap(20),
|
||||
const Padding(
|
||||
padding: EdgeInsets.all(8),
|
||||
child: RichTextBuilder(
|
||||
text: '''
|
||||
Je peux être <blue>bleu</blue>, ou même <gradient-red>rouge en dégradé</gradient-red>. À vrai dire <green>je peux</green> être <gradient-blue>un peu</gradient-blue> n'importe quelle couleur.
|
||||
''',
|
||||
),
|
||||
),
|
||||
const Gap(20),
|
||||
],
|
||||
);
|
||||
}
|
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),
|
||||
);
|
||||
}
|
||||
}
|
@ -0,0 +1,120 @@
|
||||
// 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';
|
||||
import 'package:wyatt_ui_kit_example/theme/constants.dart';
|
||||
|
||||
final Map<String, TextStyle> _styles = {
|
||||
'gradient-blue': GradientTextStyle.from(
|
||||
GoogleFonts.montserrat(
|
||||
fontSize: 20,
|
||||
fontWeight: FontWeight.w600,
|
||||
color: Constants.blue1,
|
||||
height: 1.8,
|
||||
),
|
||||
const MultiColor(Constants.blueGradient),
|
||||
),
|
||||
'gradient-red': GradientTextStyle.from(
|
||||
GoogleFonts.montserrat(
|
||||
fontSize: 20,
|
||||
fontWeight: FontWeight.w600,
|
||||
color: Constants.red1,
|
||||
height: 1.8,
|
||||
),
|
||||
const MultiColor(Constants.redGradient),
|
||||
),
|
||||
'gradient-green': GradientTextStyle.from(
|
||||
GoogleFonts.montserrat(
|
||||
fontSize: 20,
|
||||
fontWeight: FontWeight.w600,
|
||||
color: Constants.green1,
|
||||
height: 1.8,
|
||||
),
|
||||
const MultiColor(Constants.greenGradient),
|
||||
),
|
||||
'blue': GoogleFonts.montserrat(
|
||||
fontSize: 20,
|
||||
fontWeight: FontWeight.w600,
|
||||
color: Constants.blue1,
|
||||
height: 1.8,
|
||||
),
|
||||
'red': GoogleFonts.montserrat(
|
||||
fontSize: 20,
|
||||
fontWeight: FontWeight.w600,
|
||||
color: Constants.red1,
|
||||
height: 1.8,
|
||||
),
|
||||
'green': GoogleFonts.montserrat(
|
||||
fontSize: 20,
|
||||
fontWeight: FontWeight.w600,
|
||||
color: Constants.green1,
|
||||
height: 1.8,
|
||||
),
|
||||
};
|
||||
|
||||
class RichTextBuilderTheme extends RichTextBuilderThemeExtension {
|
||||
const RichTextBuilderTheme({
|
||||
super.defaultStyle,
|
||||
super.styles,
|
||||
});
|
||||
|
||||
factory RichTextBuilderTheme.light() => RichTextBuilderTheme(
|
||||
defaultStyle: GoogleFonts.montserrat(
|
||||
fontSize: 18,
|
||||
fontWeight: FontWeight.w500,
|
||||
color: Constants.grey3,
|
||||
height: 1.8,
|
||||
),
|
||||
styles: _styles,
|
||||
);
|
||||
|
||||
factory RichTextBuilderTheme.dark() => RichTextBuilderTheme(
|
||||
defaultStyle: GoogleFonts.montserrat(
|
||||
fontSize: 18,
|
||||
fontWeight: FontWeight.w500,
|
||||
color: Constants.white,
|
||||
height: 1.8,
|
||||
),
|
||||
styles: _styles,
|
||||
);
|
||||
|
||||
@override
|
||||
ThemeExtension<RichTextBuilderThemeExtension> copyWith({
|
||||
TextStyle? defaultStyle,
|
||||
Map<String, TextStyle>? styles,
|
||||
}) =>
|
||||
RichTextBuilderTheme(
|
||||
defaultStyle: defaultStyle ?? this.defaultStyle,
|
||||
styles: styles ?? this.styles,
|
||||
);
|
||||
|
||||
@override
|
||||
ThemeExtension<RichTextBuilderThemeExtension> lerp(
|
||||
covariant ThemeExtension<RichTextBuilderThemeExtension>? other,
|
||||
double t,
|
||||
) {
|
||||
if (other is! RichTextBuilderTheme) {
|
||||
return this;
|
||||
}
|
||||
return RichTextBuilderTheme(
|
||||
defaultStyle: TextStyle.lerp(defaultStyle, other.defaultStyle, t),
|
||||
styles: styles,
|
||||
);
|
||||
}
|
||||
}
|
@ -15,14 +15,15 @@
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
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: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/flat_button_theme.dart';
|
||||
import 'package:wyatt_ui_kit_example/theme/loader_theme.dart';
|
||||
import 'package:wyatt_ui_kit_example/theme/rich_text_builder_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_extension.dart';
|
||||
|
||||
/// Easely switch between Material and Studio themes.
|
||||
abstract class Themes {
|
||||
@ -78,32 +79,8 @@ abstract class Themes {
|
||||
),
|
||||
scaffoldBackgroundColor: Colors.white,
|
||||
extensions: <ThemeExtension<dynamic>>[
|
||||
CustomCardColorExtension(
|
||||
backgroundColors: const [
|
||||
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),
|
||||
),
|
||||
),
|
||||
// Cards
|
||||
CardTheme.light(),
|
||||
// Buttons
|
||||
FlatButtonTheme.light(),
|
||||
SymbolButtonTheme.light(),
|
||||
@ -111,6 +88,8 @@ abstract class Themes {
|
||||
FileSelectionButtonTheme.light(),
|
||||
// Loader
|
||||
LoaderTheme.light(),
|
||||
// Rich Text
|
||||
RichTextBuilderTheme.light(),
|
||||
],
|
||||
);
|
||||
|
||||
@ -126,35 +105,13 @@ abstract class Themes {
|
||||
color: const Color(0xFFFFFFFF),
|
||||
),
|
||||
),
|
||||
drawerTheme: const DrawerThemeData(
|
||||
backgroundColor: Color(0xFF383C40),
|
||||
),
|
||||
scaffoldBackgroundColor: const Color(0xFF383C40),
|
||||
extensions: <ThemeExtension<dynamic>>[
|
||||
CustomCardColorExtension(
|
||||
secondaryBackgroundColors:
|
||||
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),
|
||||
),
|
||||
),
|
||||
// Cards
|
||||
CardTheme.dark(),
|
||||
// Buttons
|
||||
FlatButtonTheme.dark(),
|
||||
SymbolButtonTheme.dark(),
|
||||
@ -162,6 +119,8 @@ abstract class Themes {
|
||||
FileSelectionButtonTheme.dark(),
|
||||
// Loader
|
||||
LoaderTheme.dark(),
|
||||
// Rich Text
|
||||
RichTextBuilderTheme.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/file_selection_button_theme_resolver.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
|
||||
extends CubitScreen<InvalidButtonCubit, ButtonState> {
|
||||
@ -220,13 +219,7 @@ class FileSelectionButtonScreen
|
||||
title!.text,
|
||||
style: title!.style ?? style.title,
|
||||
).toGradient(
|
||||
LinearGradientHelper.fromNullableColors(
|
||||
title?.gradient ??
|
||||
((style.foregroundColors?.isGradient ??
|
||||
false)
|
||||
? style.foregroundColors?.colors
|
||||
: null),
|
||||
),
|
||||
gradientColors: style.foregroundColors,
|
||||
),
|
||||
],
|
||||
|
||||
@ -247,13 +240,7 @@ class FileSelectionButtonScreen
|
||||
subTitle!.text,
|
||||
style: subTitle!.style ?? style.subTitle,
|
||||
).toGradient(
|
||||
LinearGradientHelper.fromNullableColors(
|
||||
subTitle?.gradient ??
|
||||
((style.foregroundColors?.isGradient ??
|
||||
false)
|
||||
? style.foregroundColors?.colors
|
||||
: null),
|
||||
),
|
||||
gradientColors: style.foregroundColors,
|
||||
),
|
||||
],
|
||||
],
|
||||
|
@ -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/gradients/gradient_box_border.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> {
|
||||
const FlatButtonScreen({
|
||||
@ -204,12 +203,7 @@ class FlatButtonScreen extends CubitScreen<ButtonCubit, ButtonState> {
|
||||
label!.text,
|
||||
style: label!.style ?? style.label,
|
||||
).toGradient(
|
||||
LinearGradientHelper.fromNullableColors(
|
||||
label?.gradient ??
|
||||
((style.foregroundColors?.isGradient ?? false)
|
||||
? style.foregroundColors?.colors
|
||||
: null),
|
||||
),
|
||||
gradientColors: style.foregroundColors,
|
||||
)
|
||||
],
|
||||
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/gradients/gradient_box_border.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
|
||||
extends CubitScreen<SelectableButtonCubit, ButtonState> {
|
||||
@ -228,12 +227,7 @@ class SymbolButtonScreen
|
||||
label!.text,
|
||||
style: label!.style ?? style.label,
|
||||
).toGradient(
|
||||
LinearGradientHelper.fromNullableColors(
|
||||
label?.gradient ??
|
||||
((style.foregroundColors?.isGradient ?? false)
|
||||
? style.foregroundColors?.colors
|
||||
: null),
|
||||
),
|
||||
gradientColors: style.foregroundColors,
|
||||
),
|
||||
],
|
||||
],
|
||||
|
@ -80,7 +80,7 @@ class InformationCard extends InformationCardComponent
|
||||
body!.text,
|
||||
textType: TextType.body,
|
||||
style: body!.style,
|
||||
gradient: body!.gradient,
|
||||
gradientColors: body!.gradientColors,
|
||||
),
|
||||
],
|
||||
],
|
||||
|
@ -44,7 +44,7 @@ class InformationCardTitles extends StatelessWidget {
|
||||
title!.text,
|
||||
textType: TextType.title,
|
||||
style: title!.style,
|
||||
gradient: title!.gradient,
|
||||
gradientColors: title!.gradientColors,
|
||||
),
|
||||
],
|
||||
if (subtitle != null) ...[
|
||||
@ -53,7 +53,7 @@ class InformationCardTitles extends StatelessWidget {
|
||||
subtitle!.text,
|
||||
textType: TextType.subtitle,
|
||||
style: subtitle!.style,
|
||||
gradient: subtitle!.gradient,
|
||||
gradientColors: subtitle!.gradientColors,
|
||||
),
|
||||
],
|
||||
],
|
||||
|
@ -73,7 +73,7 @@ class PortfolioCard extends PortfolioCardComponent with $PortfolioCardCWMixin {
|
||||
description!.text,
|
||||
textType: TextType.body,
|
||||
style: description!.style,
|
||||
gradient: description!.gradient,
|
||||
gradientColors: description!.gradientColors,
|
||||
),
|
||||
const Gap(20),
|
||||
PortfolioCardHeader(
|
||||
@ -108,7 +108,7 @@ class PortfolioCard extends PortfolioCardComponent with $PortfolioCardCWMixin {
|
||||
description!.text,
|
||||
textType: TextType.body,
|
||||
style: description!.style,
|
||||
gradient: description!.gradient,
|
||||
gradientColors: description!.gradientColors,
|
||||
),
|
||||
],
|
||||
if (ctas != null) ...[const Gap(20), ...ctas!],
|
||||
|
@ -71,7 +71,7 @@ class PortfolioCardHeader extends StatelessWidget {
|
||||
color: secondaryBackgroundColors ??
|
||||
Theme.of(context)
|
||||
.extension<CardThemeExtension>()
|
||||
?.secondaryBackgroundColors,
|
||||
?.secondaryBackgroundColor,
|
||||
borderRadius: BorderRadius.circular(8),
|
||||
),
|
||||
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_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/gradients/gradient_text.dart';
|
||||
import 'package:wyatt_ui_kit/src/core/extensions/theme_extensions.dart';
|
||||
import 'package:wyatt_ui_kit/wyatt_ui_kit.dart';
|
||||
|
||||
part 'quote_card.g.dart';
|
||||
|
||||
@ -63,9 +62,11 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
|
||||
alignment: Alignment.topLeft,
|
||||
child: GradientText(
|
||||
'“',
|
||||
gradient: gradient,
|
||||
style: context.textTheme.titleLarge
|
||||
?.copyWith(fontWeight: FontWeight.bold),
|
||||
style: GradientTextStyle.from(
|
||||
context.textTheme.titleLarge
|
||||
?.copyWith(fontWeight: FontWeight.bold),
|
||||
MultiColor(gradient?.colors),
|
||||
),
|
||||
),
|
||||
),
|
||||
if (quote != null) ...[
|
||||
@ -73,7 +74,7 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
|
||||
quote!.text,
|
||||
textType: TextType.body,
|
||||
style: quote!.style,
|
||||
gradient: quote!.gradient,
|
||||
gradientColors: quote!.gradientColors,
|
||||
),
|
||||
],
|
||||
const Gap(15),
|
||||
@ -82,9 +83,11 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
|
||||
alignment: Alignment.bottomRight,
|
||||
child: GradientText(
|
||||
'”',
|
||||
gradient: gradient,
|
||||
style: context.textTheme.titleLarge
|
||||
?.copyWith(fontWeight: FontWeight.bold),
|
||||
style: GradientTextStyle.from(
|
||||
context.textTheme.titleLarge
|
||||
?.copyWith(fontWeight: FontWeight.bold),
|
||||
MultiColor(gradient?.colors),
|
||||
),
|
||||
),
|
||||
),
|
||||
Row(
|
||||
@ -102,7 +105,7 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
|
||||
name!.text,
|
||||
textType: TextType.body,
|
||||
style: name!.style,
|
||||
gradient: name!.gradient,
|
||||
gradientColors: name!.gradientColors,
|
||||
),
|
||||
],
|
||||
if (subtitle != null) ...[
|
||||
@ -110,7 +113,7 @@ class QuoteCard extends QuoteCardComponent with $QuoteCardCWMixin {
|
||||
subtitle!.text,
|
||||
textType: TextType.subtitle,
|
||||
style: subtitle!.style,
|
||||
gradient: subtitle!.gradient,
|
||||
gradientColors: subtitle!.gradientColors,
|
||||
),
|
||||
],
|
||||
],
|
||||
|
@ -70,7 +70,7 @@ class SkillCard extends SkillCardComponent with $SkillCardCWMixin {
|
||||
description!.text,
|
||||
textType: TextType.body,
|
||||
style: description!.style,
|
||||
gradient: description!.gradient,
|
||||
gradientColors: description!.gradientColors,
|
||||
),
|
||||
const Gap(25),
|
||||
],
|
||||
|
@ -46,7 +46,7 @@ class SkillCardHeader extends StatelessWidget {
|
||||
color: secondaryBackgroundColors ??
|
||||
Theme.of(context)
|
||||
.extension<CardThemeExtension>()
|
||||
?.secondaryBackgroundColors,
|
||||
?.secondaryBackgroundColor,
|
||||
),
|
||||
child: gradient != null
|
||||
? GradientIcon(
|
||||
@ -67,7 +67,7 @@ class SkillCardHeader extends StatelessWidget {
|
||||
title!.text,
|
||||
textType: TextType.title,
|
||||
style: title!.style,
|
||||
gradient: title!.gradient,
|
||||
gradientColors: title!.gradientColors,
|
||||
),
|
||||
],
|
||||
],
|
||||
|
@ -50,7 +50,7 @@ class SkillCardSkills extends StatelessWidget {
|
||||
e.text,
|
||||
textType: TextType.body,
|
||||
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/>.
|
||||
|
||||
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';
|
||||
|
||||
enum TextType {
|
||||
@ -28,13 +28,13 @@ class CardText extends StatelessWidget {
|
||||
const CardText(
|
||||
this.data, {
|
||||
required this.textType,
|
||||
this.gradient,
|
||||
this.style,
|
||||
this.gradientColors,
|
||||
super.key,
|
||||
});
|
||||
final TextType textType;
|
||||
final TextStyle? style;
|
||||
final List<Color>? gradient;
|
||||
final MultiColor? gradientColors;
|
||||
final String data;
|
||||
|
||||
TextStyle? _getStyle(BuildContext context) {
|
||||
@ -58,9 +58,5 @@ class CardText extends StatelessWidget {
|
||||
Widget build(BuildContext context) => Text(
|
||||
data,
|
||||
style: _getStyle(context),
|
||||
).toGradient(
|
||||
LinearGradientHelper.fromNullableColors(
|
||||
gradient,
|
||||
),
|
||||
);
|
||||
).toGradient(gradientColors: gradientColors);
|
||||
}
|
||||
|
@ -110,8 +110,9 @@ class _CardWrapperState extends State<CardWrapper> {
|
||||
|
||||
if (extensionCardColor != null &&
|
||||
extensionCardColor.backgroundColors != null &&
|
||||
extensionCardColor.backgroundColors!.length >= 2) {
|
||||
return LinearGradient(colors: extensionCardColor.backgroundColors!);
|
||||
extensionCardColor.backgroundColors!.isGradient) {
|
||||
return LinearGradient(
|
||||
colors: extensionCardColor.backgroundColors!.colors,);
|
||||
}
|
||||
}
|
||||
return null;
|
||||
@ -126,9 +127,8 @@ class _CardWrapperState extends State<CardWrapper> {
|
||||
Theme.of(context).extension<CardThemeExtension>();
|
||||
|
||||
if (extensionCardColor != null &&
|
||||
extensionCardColor.backgroundColors != null &&
|
||||
extensionCardColor.backgroundColors!.length == 1) {
|
||||
return extensionCardColor.backgroundColors!.first;
|
||||
extensionCardColor.backgroundColors != null) {
|
||||
return extensionCardColor.backgroundColors!.color;
|
||||
}
|
||||
}
|
||||
return Theme.of(context).cardColor;
|
||||
@ -151,16 +151,16 @@ class _CardWrapperState extends State<CardWrapper> {
|
||||
final extensionCardColor =
|
||||
Theme.of(context).extension<CardThemeExtension>();
|
||||
if (extensionCardColor != null &&
|
||||
extensionCardColor.borderColor != null) {
|
||||
if (extensionCardColor.borderColor!.length >= 2) {
|
||||
extensionCardColor.borderColors != null) {
|
||||
if (extensionCardColor.borderColors!.isGradient) {
|
||||
return GradientBoxBorder(
|
||||
gradient: LinearGradient(
|
||||
colors: extensionCardColor.borderColor!,
|
||||
colors: extensionCardColor.borderColors!.colors,
|
||||
),
|
||||
);
|
||||
} else if (extensionCardColor.backgroundColors!.isNotEmpty) {
|
||||
} else if (extensionCardColor.backgroundColors!.colors.isNotEmpty) {
|
||||
return Border.all(
|
||||
color: extensionCardColor.backgroundColors!.first,
|
||||
color: extensionCardColor.backgroundColors!.color,
|
||||
);
|
||||
}
|
||||
}
|
||||
|
@ -16,4 +16,6 @@
|
||||
|
||||
export './buttons/buttons.dart';
|
||||
export './cards/cards.dart';
|
||||
export './gradients/gradients.dart';
|
||||
export './loader/loader.dart';
|
||||
export './rich_text_builder/rich_text_builder.dart';
|
||||
|
@ -17,16 +17,29 @@
|
||||
// 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';
|
||||
import 'package:wyatt_ui_kit/wyatt_ui_kit.dart';
|
||||
|
||||
extension GradientTextExtension on Text {
|
||||
GradientText toGradient(Gradient? gradient) =>
|
||||
GradientText.from(this, gradient);
|
||||
/// If this text contains a [GradientTextStyle] it simply transforms it in
|
||||
/// [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 {
|
||||
const GradientText(
|
||||
super.data, {
|
||||
this.gradient,
|
||||
super.style,
|
||||
super.strutStyle,
|
||||
super.textAlign,
|
||||
@ -43,10 +56,10 @@ class GradientText extends Text {
|
||||
super.key,
|
||||
});
|
||||
|
||||
factory GradientText.from(Text text, Gradient? gradient) => GradientText(
|
||||
factory GradientText.from(Text text, MultiColor? gradientColors) =>
|
||||
GradientText(
|
||||
text.data ?? '',
|
||||
style: text.style,
|
||||
gradient: gradient,
|
||||
style: GradientTextStyle.from(text.style, gradientColors),
|
||||
strutStyle: text.strutStyle,
|
||||
textAlign: text.textAlign,
|
||||
textDirection: text.textDirection,
|
||||
@ -62,20 +75,24 @@ class GradientText extends Text {
|
||||
key: text.key,
|
||||
);
|
||||
|
||||
final Gradient? gradient;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
if (gradient != null) {
|
||||
return ShaderMask(
|
||||
blendMode: BlendMode.srcIn,
|
||||
shaderCallback: (bounds) => gradient!.createShader(
|
||||
Rect.fromLTWH(0, 0, bounds.width, bounds.height),
|
||||
),
|
||||
child: super.build(context),
|
||||
);
|
||||
} else {
|
||||
return super.build(context);
|
||||
if (style is GradientTextStyle?) {
|
||||
// Gradient
|
||||
final gradientStyle = (style as GradientTextStyle?)?.gradientColors;
|
||||
final gradient = (gradientStyle?.isGradient ?? false)
|
||||
? LinearGradientHelper.fromMultiColor(gradientStyle!)
|
||||
: null;
|
||||
if (gradient != null) {
|
||||
return ShaderMask(
|
||||
blendMode: BlendMode.srcIn,
|
||||
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';
|
@ -0,0 +1,108 @@
|
||||
// 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:wyatt_component_copy_with_extension/component_copy_with_extension.dart';
|
||||
import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
|
||||
import 'package:wyatt_ui_kit/src/components/rich_text_builder/rich_text_builder_theme_resolver.dart';
|
||||
import 'package:wyatt_ui_kit/wyatt_ui_kit.dart';
|
||||
|
||||
part 'rich_text_builder.g.dart';
|
||||
|
||||
@ComponentCopyWithExtension()
|
||||
class RichTextBuilder extends RichTextBuilderComponent
|
||||
with $RichTextBuilderCWMixin {
|
||||
const RichTextBuilder({
|
||||
super.text,
|
||||
super.parser,
|
||||
super.defaultStyle,
|
||||
super.styles,
|
||||
super.themeResolver,
|
||||
super.key,
|
||||
});
|
||||
|
||||
@override
|
||||
RichTextBuilderThemeResolver? get themeResolver =>
|
||||
super.themeResolver as RichTextBuilderThemeResolver?;
|
||||
|
||||
/// Negotiate the theme to get a complete style.
|
||||
RichTextBuilderStyle _resolve(BuildContext context) {
|
||||
final RichTextBuilderThemeResolver resolver = themeResolver ??
|
||||
RichTextBuilderThemeResolver(
|
||||
computeExtensionValueFn: (
|
||||
context,
|
||||
defaultValue,
|
||||
themeExtension, {
|
||||
extra,
|
||||
}) =>
|
||||
RichTextBuilderStyle(
|
||||
defaultStyle: themeExtension.defaultStyle,
|
||||
styles: themeExtension.styles,
|
||||
),
|
||||
customStyleFn: (context, {extra}) => RichTextBuilderStyle(
|
||||
defaultStyle: defaultStyle,
|
||||
styles: styles,
|
||||
),
|
||||
);
|
||||
|
||||
return resolver.negotiate(context);
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
final style = _resolve(context);
|
||||
final RegExp regex = RegExp(r'<(.*?)>(.*?)<\/\1>');
|
||||
final root = RichTextNode.from(
|
||||
text ?? '',
|
||||
regex,
|
||||
RichTextStyleParameter(
|
||||
style.defaultStyle!,
|
||||
style.styles ?? {},
|
||||
null,
|
||||
),
|
||||
);
|
||||
final customParser = parser ??
|
||||
RichTextParser(
|
||||
nodeBuilder: (content, style) {
|
||||
if (style is GradientTextStyle?) {
|
||||
return WidgetSpan(
|
||||
child: GradientText(
|
||||
content,
|
||||
style: style,
|
||||
softWrap: true,
|
||||
textHeightBehavior: const TextHeightBehavior(
|
||||
applyHeightToLastDescent: false,
|
||||
),
|
||||
),
|
||||
style: style,
|
||||
);
|
||||
}
|
||||
return TextSpan(
|
||||
text: content,
|
||||
style: style,
|
||||
);
|
||||
},
|
||||
);
|
||||
|
||||
return SelectionArea(
|
||||
child: Text.rich(
|
||||
TextSpan(children: [root.toInlineSpan(customParser)]),
|
||||
textHeightBehavior:
|
||||
const TextHeightBehavior(applyHeightToLastDescent: false),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
@ -0,0 +1,50 @@
|
||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
||||
|
||||
part of 'rich_text_builder.dart';
|
||||
|
||||
// **************************************************************************
|
||||
// ComponentCopyWithGenerator
|
||||
// **************************************************************************
|
||||
|
||||
class $RichTextBuilderCWProxyImpl implements $RichTextBuilderComponentCWProxy {
|
||||
const $RichTextBuilderCWProxyImpl(this._value);
|
||||
final RichTextBuilder _value;
|
||||
@override
|
||||
RichTextBuilder text(String? text) => this(text: text);
|
||||
@override
|
||||
RichTextBuilder parser(RichTextParser? parser) => this(parser: parser);
|
||||
@override
|
||||
RichTextBuilder defaultStyle(TextStyle? defaultStyle) =>
|
||||
this(defaultStyle: defaultStyle);
|
||||
@override
|
||||
RichTextBuilder styles(Map<String, TextStyle>? styles) =>
|
||||
this(styles: styles);
|
||||
@override
|
||||
RichTextBuilder themeResolver(
|
||||
ThemeResolver<dynamic, dynamic, dynamic>? themeResolver) =>
|
||||
this(themeResolver: themeResolver);
|
||||
@override
|
||||
RichTextBuilder key(Key? key) => this(key: key);
|
||||
@override
|
||||
RichTextBuilder call({
|
||||
String? text,
|
||||
RichTextParser? parser,
|
||||
TextStyle? defaultStyle,
|
||||
Map<String, TextStyle>? styles,
|
||||
ThemeResolver<dynamic, dynamic, dynamic>? themeResolver,
|
||||
Key? key,
|
||||
}) =>
|
||||
RichTextBuilder(
|
||||
text: text ?? _value.text,
|
||||
parser: parser ?? _value.parser,
|
||||
defaultStyle: defaultStyle ?? _value.defaultStyle,
|
||||
styles: styles ?? _value.styles,
|
||||
themeResolver: themeResolver ?? _value.themeResolver,
|
||||
key: key ?? _value.key,
|
||||
);
|
||||
}
|
||||
|
||||
mixin $RichTextBuilderCWMixin on Component {
|
||||
$RichTextBuilderComponentCWProxy get copyWith =>
|
||||
$RichTextBuilderCWProxyImpl(this as RichTextBuilder);
|
||||
}
|
@ -0,0 +1,49 @@
|
||||
// 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:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
|
||||
import 'package:wyatt_ui_kit/wyatt_ui_kit.dart';
|
||||
|
||||
class RichTextBuilderThemeResolver extends ThemeResolver<RichTextBuilderStyle,
|
||||
RichTextBuilderThemeExtension, void> {
|
||||
const RichTextBuilderThemeResolver({
|
||||
required this.computeExtensionValueFn,
|
||||
required this.customStyleFn,
|
||||
});
|
||||
|
||||
/// Values taken from <https://api.flutter.dev/flutter/material/ElevatedButton/defaultStyleOf.html>
|
||||
@override
|
||||
RichTextBuilderStyle computeDefaultValue(
|
||||
BuildContext context, {
|
||||
void extra,
|
||||
}) =>
|
||||
RichTextBuilderStyle(
|
||||
defaultStyle: context.textTheme.bodyMedium,
|
||||
);
|
||||
|
||||
@override
|
||||
final RichTextBuilderStyle? Function(
|
||||
BuildContext context,
|
||||
RichTextBuilderStyle defaultValue,
|
||||
RichTextBuilderThemeExtension themeExtension, {
|
||||
void extra,
|
||||
}) computeExtensionValueFn;
|
||||
|
||||
@override
|
||||
final RichTextBuilderStyle? Function(BuildContext context, {void extra})
|
||||
customStyleFn;
|
||||
}
|
@ -15,12 +15,13 @@
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:wyatt_ui_components/wyatt_wyatt_ui_components.dart';
|
||||
|
||||
abstract class CardThemeExtension extends ThemeExtension<CardThemeExtension> {
|
||||
const CardThemeExtension({
|
||||
this.backgroundColors,
|
||||
this.secondaryBackgroundColors,
|
||||
this.borderColor,
|
||||
this.secondaryBackgroundColor,
|
||||
this.borderColors,
|
||||
this.shadowColor,
|
||||
this.body,
|
||||
this.title,
|
||||
@ -28,9 +29,9 @@ abstract class CardThemeExtension extends ThemeExtension<CardThemeExtension> {
|
||||
});
|
||||
|
||||
// Colors
|
||||
final List<Color>? backgroundColors;
|
||||
final Color? secondaryBackgroundColors;
|
||||
final List<Color>? borderColor;
|
||||
final MultiColor? backgroundColors;
|
||||
final Color? secondaryBackgroundColor;
|
||||
final MultiColor? borderColors;
|
||||
final BoxShadow? shadowColor;
|
||||
|
||||
// TextStyles
|
||||
|
@ -15,5 +15,6 @@
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
export './button_theme_extension/button_theme_extension.dart';
|
||||
export './card_theme_extension.dart';
|
||||
export './loader_theme_extension.dart';
|
||||
export 'card_theme_extension.dart';
|
||||
export './rich_text_builder_theme_extension.dart';
|
||||
|
@ -0,0 +1,31 @@
|
||||
// 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';
|
||||
|
||||
abstract class RichTextBuilderThemeExtension
|
||||
extends ThemeExtension<RichTextBuilderThemeExtension> {
|
||||
const RichTextBuilderThemeExtension({
|
||||
this.defaultStyle,
|
||||
this.styles,
|
||||
});
|
||||
|
||||
/// Default TextStyle used in this rich text component.
|
||||
final TextStyle? defaultStyle;
|
||||
|
||||
/// Used styles in this rich text component.
|
||||
final Map<String, TextStyle>? styles;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user