ente/lib/ui/viewer/search/search_section_cta.dart

111 lines
3.3 KiB
Dart
Raw Normal View History

import "package:dotted_border/dotted_border.dart";
2023-02-25 08:00:42 +00:00
import "package:flutter/material.dart";
import "package:photos/models/search/search_types.dart";
import "package:photos/theme/ente_theme.dart";
class SearchSectionCTAIcon extends StatelessWidget {
final SectionType sectionType;
const SearchSectionCTAIcon(this.sectionType, {super.key});
@override
Widget build(BuildContext context) {
if (sectionType.isCTAVisible == false) {
return const SizedBox.shrink();
}
final textTheme = getEnteTextTheme(context);
final colorScheme = getEnteColorScheme(context);
return GestureDetector(
onTap: sectionType.ctaOnTap(context),
child: SizedBox(
width: 84,
child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 6, vertical: 8),
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
DottedBorder(
color: colorScheme.strokeFaint,
dashPattern: const [3.875, 3.875],
borderType: BorderType.Circle,
strokeWidth: 1.5,
radius: const Radius.circular(33.25),
child: SizedBox(
width: 62.5,
height: 62.5,
child: Icon(
sectionType.getCTAIcon() ?? Icons.add,
color: colorScheme.strokeFaint,
size: 20,
),
),
2023-02-25 08:00:42 +00:00
),
const SizedBox(
height: 9.25,
),
Text(
sectionType.getCTAText(context),
maxLines: 2,
textAlign: TextAlign.center,
overflow: TextOverflow.ellipsis,
style: textTheme.miniFaint,
),
],
),
2023-09-28 04:37:55 +00:00
),
),
2023-02-25 08:00:42 +00:00
);
}
}
class SearchSectionCTATile extends StatelessWidget {
final SectionType sectionType;
const SearchSectionCTATile(this.sectionType, {super.key});
@override
Widget build(BuildContext context) {
if (sectionType.isCTAVisible == false) {
return const SizedBox.shrink();
}
final colorScheme = getEnteColorScheme(context);
final textTheme = getEnteTextTheme(context);
return Padding(
padding: const EdgeInsets.only(right: 1),
child: GestureDetector(
onTap: sectionType.ctaOnTap(context),
child: DottedBorder(
strokeWidth: 2,
borderType: BorderType.RRect,
radius: const Radius.circular(4),
padding: EdgeInsets.zero,
dashPattern: const [4, 4],
color: colorScheme.strokeFainter,
child: Row(
children: [
Container(
width: 60,
height: 60,
decoration: BoxDecoration(
borderRadius:
const BorderRadius.horizontal(left: Radius.circular(4)),
color: colorScheme.fillFaint,
),
child: Icon(
sectionType.getCTAIcon(),
color: colorScheme.strokeMuted,
),
),
const SizedBox(width: 12),
Text(
sectionType.getCTAText(context),
style: textTheme.body,
),
],
),
),
),
);
}
}