Implement Webuntis HTTP Api and Display
This commit is contained in:
@ -11,8 +11,7 @@ import 'package:shared_preferences/shared_preferences.dart';
|
||||
|
||||
import '../../api/webuntis/queries/authenticate/authenticateParams.dart';
|
||||
import '../../api/webuntis/queries/authenticate/authenticate.dart';
|
||||
import '../../data/accountModel.dart';
|
||||
|
||||
import '../../dataOld/accountModel.dart';
|
||||
|
||||
class Login extends StatefulWidget {
|
||||
const Login({Key? key}) : super(key: key);
|
||||
|
@ -1,11 +1,10 @@
|
||||
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:marianum_mobile/data/incommingPackets/fileListPacket.dart';
|
||||
import 'package:marianum_mobile/widget/loadingPacket.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:webdav_client/webdav_client.dart';
|
||||
|
||||
import '../../../data/accountModel.dart';
|
||||
import '../../../dataOld/incommingPackets/fileListPacket.dart';
|
||||
import '../../../widget/loadingSpinner.dart';
|
||||
|
||||
class Files extends StatefulWidget {
|
||||
|
@ -3,12 +3,10 @@ import 'dart:convert';
|
||||
import 'package:flutter/foundation.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:http/http.dart' as http;
|
||||
import 'package:marianum_mobile/data/outgoingPackets/talkContactsAskPacket.dart';
|
||||
import 'package:marianum_mobile/widget/loadingPacket.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
import '../../../data/accountModel.dart';
|
||||
import '../../../data/incommingPackets/talkContactsPacket.dart';
|
||||
import '../../../dataOld/incommingPackets/talkContactsPacket.dart';
|
||||
import '../../../widget/loadingSpinner.dart';
|
||||
import 'chatView.dart';
|
||||
|
||||
|
@ -1,10 +1,11 @@
|
||||
|
||||
import 'package:bubble/bubble.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:marianum_mobile/data/incommingPackets/talkChatPacket.dart';
|
||||
import 'package:marianum_mobile/widget/loadingPacket.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
import '../../../dataOld/incommingPackets/talkChatPacket.dart';
|
||||
|
||||
class ChatView extends StatefulWidget {
|
||||
final String userToken;
|
||||
const ChatView({Key? key, required this.userToken}) : super(key: key);
|
||||
|
104
lib/screen/pages/timetable/storedTimetable.dart
Normal file
104
lib/screen/pages/timetable/storedTimetable.dart
Normal file
@ -0,0 +1,104 @@
|
||||
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/timetable.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 StoredTimetable extends StatefulWidget {
|
||||
const StoredTimetable({Key? key}) : super(key: key);
|
||||
|
||||
@override
|
||||
State<StoredTimetable> createState() => _StoredTimetableState();
|
||||
}
|
||||
|
||||
class _StoredTimetableState extends State<StoredTimetable> {
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
|
||||
WidgetsBinding.instance.addPostFrameCallback((timeStamp) {
|
||||
Provider.of<Timetable>(context, listen: false).run();
|
||||
});
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Consumer<Timetable>(
|
||||
builder: (context, value, child) {
|
||||
if(value.getTimetableResponse == null) {
|
||||
return const LoadingSpinner();
|
||||
}
|
||||
|
||||
return TimetableView(
|
||||
laneEventsList: _buildLaneEvents(value),
|
||||
onEventTap: (TableEvent event) {},
|
||||
timetableStyle: CustomTableStyle(context),
|
||||
onEmptySlotTap: (int laneIndex, TableEventTime start, TableEventTime end) => {},
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
List<LaneEvents> _buildLaneEvents(Timetable data) {
|
||||
List<LaneEvents> laneEvents = List<LaneEvents>.empty(growable: true);
|
||||
Jiffy.locale("de"); // todo move outwards
|
||||
|
||||
GetTimetableResponse timetable = data.getTimetableResponse!;
|
||||
GetRoomsResponse rooms = data.getRoomsResponse!;
|
||||
GetSubjectsResponse subjects = data.getSubjectsResponse!;
|
||||
|
||||
List<int> dayList = timetable.result.map((e) => e.date).toSet().toList();
|
||||
dayList.sort((a, b) => a-b);
|
||||
dayList.forEach((day) {
|
||||
//Every Day
|
||||
|
||||
laneEvents.add(
|
||||
LaneEvents(
|
||||
lane: Lane(
|
||||
laneIndex: day,
|
||||
name: "${Jiffy(day.toString()).format("dd.MM.yy")}\n${Jiffy(day.toString()).format("EEEE")}",
|
||||
textStyle: TextStyle(
|
||||
color: Theme.of(context).primaryColor,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: 14
|
||||
)
|
||||
),
|
||||
events: List<TableEvent>.generate(
|
||||
timetable.result.where((element) => element.date == day).length,
|
||||
(index) {
|
||||
GetTimetableResponseObject tableEvent = timetable.result.where((element) => element.date == day).elementAt(index);
|
||||
return TableEvent(
|
||||
title: subjects.result.firstWhere((subject) => subject.id == tableEvent.su[0]['id']).longName,
|
||||
eventId: tableEvent.id,
|
||||
laneIndex: day,
|
||||
startTime: parseTime(tableEvent.startTime),
|
||||
endTime: parseTime(tableEvent.endTime),
|
||||
padding: const EdgeInsets.all(5),
|
||||
backgroundColor: Theme.of(context).primaryColor,
|
||||
location: "\n${rooms.result.firstWhere((room) => room.id == tableEvent.ro[0]['id']).name}",
|
||||
);
|
||||
}
|
||||
)
|
||||
)
|
||||
);
|
||||
|
||||
});
|
||||
|
||||
return laneEvents;
|
||||
}
|
||||
|
||||
TableEventTime parseTime(int input) {
|
||||
String time = input.toString().length < 4 ? "0$input" : input.toString();
|
||||
return TableEventTime(hour: int.parse(time.substring(0, 2)), minute: int.parse(time.substring(2, 4)));
|
||||
}
|
||||
}
|
@ -4,7 +4,6 @@ import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:jiffy/jiffy.dart';
|
||||
import 'package:marianum_mobile/api/webuntis/queries/getRooms/getRooms.dart';
|
||||
import 'package:marianum_mobile/data/incommingPackets/timetablePacket.dart';
|
||||
import 'package:marianum_mobile/widget/loadingSpinner.dart';
|
||||
import 'package:marianum_mobile/widget/offlineError.dart';
|
||||
import 'package:timetable_view/timetable_view.dart';
|
||||
@ -132,14 +131,14 @@ class CustomTableStyle extends TimetableStyle {
|
||||
@override
|
||||
int get endHour => 17;
|
||||
@override
|
||||
double get laneWidth => 100;
|
||||
double get laneWidth => 300;
|
||||
@override
|
||||
Color get cornerColor => Theme.of(context).primaryColor;
|
||||
@override
|
||||
Color get timeItemTextColor => Theme.of(context).primaryColor;
|
||||
@override
|
||||
double get timeItemHeight => 60;
|
||||
double get timeItemHeight => 80;
|
||||
@override
|
||||
double get timeItemWidth => 40;
|
||||
double get timeItemWidth => 70;
|
||||
|
||||
}
|
@ -3,11 +3,12 @@ import 'dart:developer';
|
||||
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:marianum_mobile/data/incommingPackets/timetablePacket.dart';
|
||||
import 'package:marianum_mobile/widget/loadingPacket.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:timetable_view/timetable_view.dart';
|
||||
|
||||
import '../../../dataOld/incommingPackets/timetablePacket.dart';
|
||||
|
||||
class Timetable extends StatefulWidget {
|
||||
const Timetable({Key? key}) : super(key: key);
|
||||
|
||||
|
@ -3,8 +3,8 @@ import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:shared_preferences/shared_preferences.dart';
|
||||
|
||||
import '../../data/accountModel.dart';
|
||||
import '../../data/incommingPackets/serverInfoPacket.dart';
|
||||
import '../../dataOld/accountModel.dart';
|
||||
import '../../dataOld/incommingPackets/serverInfoPacket.dart';
|
||||
import '../../widget/ListItem.dart';
|
||||
|
||||
class Settings extends StatefulWidget {
|
||||
|
Reference in New Issue
Block a user