You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
fluffychat/lib/pangea/course_creation/course_plan_tile_widget.dart

90 lines
2.8 KiB
Dart

// ignore_for_file: depend_on_referenced_packages
import 'package:flutter/material.dart';
import 'package:fluffychat/pangea/common/widgets/url_image_widget.dart';
import 'package:fluffychat/pangea/course_creation/course_info_chip_widget.dart';
import 'package:fluffychat/pangea/course_plans/course_plan_model.dart';
import 'package:fluffychat/widgets/hover_builder.dart';
class CoursePlanTile extends StatelessWidget {
final CoursePlanModel course;
final VoidCallback onTap;
final double titleFontSize;
final double chipFontSize;
final double chipIconSize;
const CoursePlanTile({
super.key,
required this.course,
required this.onTap,
required this.titleFontSize,
required this.chipFontSize,
required this.chipIconSize,
});
@override
Widget build(BuildContext context) {
final theme = Theme.of(context);
return HoverBuilder(
builder: (context, hovered) {
return MouseRegion(
cursor: SystemMouseCursors.click,
child: GestureDetector(
onTap: onTap,
child: Container(
decoration: BoxDecoration(
color:
hovered ? theme.colorScheme.onSurface.withAlpha(10) : null,
),
child: Row(
spacing: 4.0,
children: [
ImageByUrl(
imageUrl: course.imageUrl,
width: 40.0,
replacement: Container(
width: 40.0,
height: 40.0,
decoration: BoxDecoration(
color: theme.colorScheme.secondary,
),
),
),
Flexible(
child: Column(
spacing: 4.0,
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(
course.title,
maxLines: 1,
overflow: TextOverflow.ellipsis,
style: TextStyle(
fontSize: titleFontSize,
),
),
CourseInfoChips(
course,
padding: const EdgeInsets.symmetric(
horizontal: 4.0,
vertical: 2.0,
),
fontSize: chipFontSize,
iconSize: chipIconSize,
),
],
),
),
],
),
),
),
);
},
);
}
}