From 20046f13f6614cd37e907ee2b7e6bb8f60495dbe Mon Sep 17 00:00:00 2001 From: DyCTaTOR <125912249+DyCTaTOR@users.noreply.github.com> Date: Wed, 2 Oct 2024 23:27:54 +0400 Subject: [PATCH] lab3 --- lib/main.dart | 125 +++++++++++++++++++++----------------------------- 1 file changed, 53 insertions(+), 72 deletions(-) diff --git a/lib/main.dart b/lib/main.dart index 11d0c31..276ed55 100644 --- a/lib/main.dart +++ b/lib/main.dart @@ -1,4 +1,5 @@ import 'package:flutter/material.dart'; +import 'CourseStatus.dart'; import 'University.dart'; import 'student.dart'; @@ -52,8 +53,7 @@ class _UniversityScreenState extends State { appBar: AppBar( title: Text('Строев Владимир, ПИбд-32'), ), - body: const MyWidget() - /*Column( + body: Column( children: [ Padding( padding: const EdgeInsets.all(8.0), @@ -108,92 +108,74 @@ class _UniversityScreenState extends State { ), ), Expanded( - child: ListView.builder( - itemCount: university.students.length, - itemBuilder: (context, index) { - Student student = university.students[index]; - return ListTile( - title: Text(student.name), - subtitle: Text('Age: ${student.age}, Courses: ${student.courses.join(", ")}'), - ); - }, - ), + child: MyWidget(students: university.students), ), ], - )*/, + ), ); } } class MyWidget extends StatelessWidget { - const MyWidget ({super.key}); + final List students; + + const MyWidget({super.key, required this.students}); @override Widget build(BuildContext context) { - final data = [ - _CardData( - text: "Hello", - icon: Icons.warning_amber, - descriptionText: "mumumu"), - _CardData( - text: 'H', - descriptionText: "pupupu",), - _CardData( - text: "LLo", - icon: Icons.dangerous, - descriptionText: "kukuku"), - ]; - return Center( - child:SingleChildScrollView( - child: Column( - mainAxisAlignment: MainAxisAlignment.center, - children: data.map((e) => _Card.fromData(e)).toList(), - ), - ) + return SingleChildScrollView( + child: Column( + mainAxisAlignment: MainAxisAlignment.center, + children: students.map((e) => _Card.fromData(e)).toList(), + ), ); } } -class _CardData{ - final String text; - final IconData icon; - final String descriptionText; - final String? imageUrl; - - _CardData({required this.text, - this.icon = Icons.ac_unit_outlined, - required this.descriptionText, - this.imageUrl,}); -} - class _Card extends StatelessWidget { - final String text; - final IconData icon; - final String descriptionText; + final String name; + final int age; + final List courses; final String? imageUrl; - const _Card(this.text, { - this.icon = Icons.ac_unit_outlined, - required this.descriptionText, - this.imageUrl = 'https://distribution.faceit-cdn.net/images/679409f5-2896-4942-b976-62f5d31bd9eb.jpeg', + const _Card(this.name, { + required this.age, + required this.courses, + this.imageUrl = 'https://gryazoveckij-r19.gosweb.gosuslugi.ru/netcat_files/460/2008/net_foto_muzh.jpg', }); - - factory _Card.fromData(_CardData data) => _Card(data.text, - icon: data.icon, - descriptionText: data.descriptionText); + + String getYearWord(int age) { + if (age % 10 == 1) { + return " год"; + } else if (age % 10 < 5 && age % 10 != 0) { + return " года"; + } else { + return " лет"; + } + } + + factory _Card.fromData(Student data) => _Card(data.name, + age: data.age, courses: data.courses); @override Widget build(BuildContext context) { return Container( - margin: const EdgeInsets.only(top: 16), + margin: const EdgeInsets.only(top: 16, left: 16, right: 16, bottom: 16), decoration: BoxDecoration( - color: Colors.orangeAccent, + color: Colors.blueAccent, borderRadius: BorderRadius.circular(20), + boxShadow: [ + BoxShadow( + color: Colors.black.withOpacity(0.2), + spreadRadius: 2, + blurRadius: 5, + offset: Offset(0, 3), + ), + ], ), padding: const EdgeInsets.all(16), child: Row( - mainAxisAlignment: MainAxisAlignment.spaceBetween, - crossAxisAlignment: CrossAxisAlignment.center, + crossAxisAlignment: CrossAxisAlignment.start, children: [ ClipRRect( borderRadius: BorderRadius.circular(20), @@ -201,26 +183,25 @@ class _Card extends StatelessWidget { height: 140, width: 100, child: Image.network(imageUrl ?? '', - fit: BoxFit.cover, - errorBuilder: (_, __, ___) => const Placeholder(),), - ), + fit: BoxFit.cover, + errorBuilder: (_, __, ___) => const Placeholder(),), ), + ), + SizedBox(width: 16), Flexible( child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ - Text(text, style: Theme.of(context).textTheme.headlineLarge - ), - Text(descriptionText, style: Theme.of(context).textTheme.bodyLarge) + Text(name, style: Theme.of(context).textTheme.headlineLarge), + SizedBox(height: 8), + Text(age.toString() + getYearWord(age), style: Theme.of(context).textTheme.bodyLarge), + SizedBox(height: 8), + Text('Courses: ${courses.join(", ")}', style: Theme.of(context).textTheme.bodyMedium), ], ), ), - Padding( - padding: const EdgeInsets.only(left: 8.0), - child: Icon(icon), - ), ], ), ); } -} +} \ No newline at end of file