marco.pms.mobileapp/lib/view/extra_pages/time_line_screen.dart
Vaibhav Surve a5dd5e19fc Add Windows runner implementation for Flutter application
- Created CMakeLists.txt for Flutter and runner components.
- Implemented resource script (Runner.rc) for application metadata.
- Developed main entry point (main.cpp) for the Windows application.
- Added FlutterWindow class to manage the Flutter view within a Win32 window.
- Implemented utility functions for console management and command line argument parsing.
- Established Win32Window class for high DPI-aware window handling.
- Included application icon and manifest for proper Windows integration.
- Set up build configurations and dependencies for the Flutter application on Windows.
2025-04-23 09:55:31 +05:30

121 lines
5.1 KiB
Dart

import 'package:marco/controller/extra_pages/time_line_controller.dart';
import 'package:marco/helpers/theme/app_theme.dart';
import 'package:marco/helpers/utils/mixins/ui_mixin.dart';
import 'package:marco/helpers/utils/my_shadow.dart';
import 'package:marco/helpers/widgets/my_breadcrumb.dart';
import 'package:marco/helpers/widgets/my_breadcrumb_item.dart';
import 'package:marco/helpers/widgets/my_card.dart';
import 'package:marco/helpers/widgets/my_container.dart';
import 'package:marco/helpers/widgets/my_spacing.dart';
import 'package:marco/helpers/widgets/my_text.dart';
import 'package:marco/images.dart';
import 'package:marco/model/time_line.dart';
import 'package:marco/view/layouts/layout.dart';
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:timelines_plus/timelines_plus.dart';
class TimeLineScreen extends StatefulWidget {
const TimeLineScreen({super.key});
@override
State<TimeLineScreen> createState() => _TimeLineScreenState();
}
class _TimeLineScreenState extends State<TimeLineScreen> with SingleTickerProviderStateMixin, UIMixin {
late TimeLineController controller;
@override
void initState() {
controller = TimeLineController();
super.initState();
}
@override
Widget build(BuildContext context) {
return Layout(
child: GetBuilder(
init: controller,
tag: 'time_line_controller',
builder: (controller) {
return Column(
children: [
Padding(
padding: MySpacing.x(flexSpacing),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
MyText.titleMedium("Time Line", fontSize: 18, fontWeight: 600),
MyBreadcrumb(
children: [MyBreadcrumbItem(name: 'Extra'), MyBreadcrumbItem(name: 'Time Line', active: true)],
),
],
),
),
MySpacing.height(flexSpacing),
Padding(
padding: MySpacing.x(flexSpacing / 2),
child: Column(
children: [
SizedBox(
height: 800,
child: Timeline.tileBuilder(
clipBehavior: Clip.antiAliasWithSaveLayer,
shrinkWrap: true,
builder: TimelineTileBuilder.fromStyle(
indicatorStyle: IndicatorStyle.outlined,
itemCount: controller.timeline.length,
contentsAlign: ContentsAlign.alternating,
connectorStyle: ConnectorStyle.dashedLine,
contentsBuilder: (context, index) {
TimeLineModel time = controller.timeline[index];
return MyCard.bordered(
borderRadiusAll: 4,
border: Border.all(color: Colors.grey.withValues(alpha:.2)),
shadow: MyShadow(elevation: 1, position: MyShadowPosition.bottom),
width: 400,
margin: MySpacing.x(20),
child: Column(
crossAxisAlignment: index % 2 == 0 ? CrossAxisAlignment.start : CrossAxisAlignment.end,
children: [
MyText.bodyMedium(time.firstName, fontWeight: 600, overflow: TextOverflow.ellipsis),
MySpacing.height(12),
MyContainer(
paddingAll: 0,
height: 100,
width: double.infinity,
clipBehavior: Clip.antiAliasWithSaveLayer,
child: Image.asset(Images.dummy[index % Images.dummy.length], fit: BoxFit.cover),
),
MySpacing.height(12),
MyText.bodyMedium(time.lastName, fontWeight: 600, overflow: TextOverflow.ellipsis),
MySpacing.height(12),
MyText.bodySmall(
time.email,
fontWeight: 600,
),
MySpacing.height(12),
MyText.bodyMedium(
controller.dummyTexts[index],
fontWeight: 600,
maxLines: 3,
textAlign: index % 2 == 0 ? TextAlign.start : TextAlign.end,
),
],
),
);
},
),
),
),
],
),
)
],
);
},
),
);
}
}