mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2024-09-18 17:37:50 +00:00
109 lines
2.7 KiB
Dart
109 lines
2.7 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
class BrandCards {
|
|
static Widget big({required final Widget child}) => _BrandCard(
|
|
padding: const EdgeInsets.symmetric(
|
|
horizontal: 20,
|
|
vertical: 15,
|
|
),
|
|
shadow: bigShadow,
|
|
borderRadius: BorderRadius.circular(20),
|
|
child: child,
|
|
);
|
|
static Widget small({required final Widget child}) => _BrandCard(
|
|
padding: const EdgeInsets.symmetric(
|
|
horizontal: 15,
|
|
vertical: 10,
|
|
),
|
|
shadow: bigShadow,
|
|
borderRadius: BorderRadius.circular(10),
|
|
child: child,
|
|
);
|
|
static Widget outlined({required final Widget child}) => _OutlinedCard(
|
|
child: child,
|
|
);
|
|
static Widget filled({
|
|
required final Widget child,
|
|
final bool tertiary = false,
|
|
}) =>
|
|
_FilledCard(
|
|
tertiary: tertiary,
|
|
child: child,
|
|
);
|
|
}
|
|
|
|
class _BrandCard extends StatelessWidget {
|
|
const _BrandCard({
|
|
required this.child,
|
|
required this.padding,
|
|
required this.shadow,
|
|
required this.borderRadius,
|
|
});
|
|
|
|
final Widget child;
|
|
final EdgeInsets padding;
|
|
final List<BoxShadow> shadow;
|
|
final BorderRadius borderRadius;
|
|
|
|
@override
|
|
Widget build(final BuildContext context) => Container(
|
|
decoration: BoxDecoration(
|
|
color: Theme.of(context).colorScheme.surface,
|
|
borderRadius: borderRadius,
|
|
boxShadow: shadow,
|
|
),
|
|
padding: padding,
|
|
child: child,
|
|
);
|
|
}
|
|
|
|
class _OutlinedCard extends StatelessWidget {
|
|
const _OutlinedCard({
|
|
required this.child,
|
|
});
|
|
|
|
final Widget child;
|
|
@override
|
|
Widget build(final BuildContext context) => Card(
|
|
elevation: 0.0,
|
|
shape: RoundedRectangleBorder(
|
|
borderRadius: const BorderRadius.all(Radius.circular(12)),
|
|
side: BorderSide(
|
|
color: Theme.of(context).colorScheme.outline,
|
|
),
|
|
),
|
|
clipBehavior: Clip.antiAlias,
|
|
child: child,
|
|
);
|
|
}
|
|
|
|
class _FilledCard extends StatelessWidget {
|
|
const _FilledCard({
|
|
required this.child,
|
|
required this.tertiary,
|
|
});
|
|
|
|
final Widget child;
|
|
final bool tertiary;
|
|
@override
|
|
Widget build(final BuildContext context) => Card(
|
|
elevation: 0.0,
|
|
shape: const RoundedRectangleBorder(
|
|
borderRadius: BorderRadius.all(Radius.circular(12)),
|
|
),
|
|
clipBehavior: Clip.antiAlias,
|
|
color: tertiary
|
|
? Theme.of(context).colorScheme.tertiaryContainer
|
|
: Theme.of(context).colorScheme.surfaceVariant,
|
|
child: child,
|
|
);
|
|
}
|
|
|
|
final List<BoxShadow> bigShadow = [
|
|
BoxShadow(
|
|
offset: const Offset(0, 4),
|
|
blurRadius: 8,
|
|
color: Colors.black.withOpacity(.08),
|
|
)
|
|
];
|