91 lines
3.0 KiB
Dart
91 lines
3.0 KiB
Dart
import 'dart:developer';
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:jiffy/jiffy.dart';
|
|
import 'package:marianum_mobile/api/webuntis/queries/getRooms/getRoomsResponse.dart';
|
|
import 'package:marianum_mobile/api/webuntis/queries/getSubjects/getSubjectsResponse.dart';
|
|
import 'package:marianum_mobile/data/timetable/timetableProps.dart';
|
|
import 'package:marianum_mobile/screen/pages/timetable/dayListView.dart';
|
|
import 'package:marianum_mobile/screen/pages/timetable/testTimetable.dart';
|
|
import 'package:marianum_mobile/widget/loadingSpinner.dart';
|
|
import 'package:provider/provider.dart';
|
|
import 'package:timetable_view/timetable_view.dart';
|
|
|
|
import '../../../api/webuntis/queries/getTimetable/getTimetableResponse.dart';
|
|
|
|
class Timetable extends StatefulWidget {
|
|
const Timetable({Key? key}) : super(key: key);
|
|
|
|
@override
|
|
State<Timetable> createState() => _TimetableState();
|
|
}
|
|
|
|
class _TimetableState extends State<Timetable> {
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
|
|
WidgetsBinding.instance.addPostFrameCallback((timeStamp) {
|
|
Provider.of<TimetableProps>(context, listen: false).run();
|
|
});
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Consumer<TimetableProps>(
|
|
builder: (context, value, child) {
|
|
if(value.primaryLoading()) {
|
|
return const Center(child: CircularProgressIndicator());
|
|
}
|
|
|
|
TimetableProps timetable = Provider.of<TimetableProps>(context, listen: false);
|
|
return Column(
|
|
children: [
|
|
Flexible(
|
|
child: DayListView(value),
|
|
),
|
|
|
|
Container(
|
|
padding: const EdgeInsets.only(top: 5, bottom: 5),
|
|
decoration: BoxDecoration(
|
|
border: Border(
|
|
top: BorderSide(width: 2, color: Theme.of(context).disabledColor)
|
|
)
|
|
),
|
|
child: Row(
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
children: [
|
|
IconButton(
|
|
onPressed: () => timetable.next(previous: true),
|
|
icon: const Icon(Icons.navigate_before_sharp),
|
|
color: Theme.of(context).primaryColor,
|
|
iconSize: 30,
|
|
),
|
|
Row(
|
|
children: [
|
|
IconButton(
|
|
onPressed: () => timetable.nearest(),
|
|
icon: const Icon(Icons.home),
|
|
color: Theme.of(context).primaryColor,
|
|
iconSize: 30,
|
|
),
|
|
],
|
|
),
|
|
IconButton(
|
|
onPressed: () => timetable.next(),
|
|
icon: const Icon(Icons.navigate_next_sharp),
|
|
color: Theme.of(context).primaryColor,
|
|
iconSize: 30,
|
|
)
|
|
],
|
|
),
|
|
)
|
|
],
|
|
);
|
|
},
|
|
);
|
|
}
|
|
}
|