123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- import 'dart:math';
- import 'package:flutter/material.dart';
- import 'package:flutter_local_notifications/flutter_local_notifications.dart';
- import 'package:flutter_habit/common/SqfliteDataBase.dart';
- import 'package:flutter_habit/provider/DataProvider.dart';
- import 'package:flutter_habit/provider/NotificationProvider.dart';
- import 'package:flutter_habit/database/entity/BasicInfo.dart';
- import 'package:flutter_habit/database/entity/ExerciseInfo.dart';
- import 'package:flutter_habit/database/entity/FoodInfo.dart';
- import 'package:flutter_habit/database/entity/LifeInfo.dart';
- import 'package:flutter_habit/database/entity/SportInfo.dart';
- import 'package:flutter_habit/database/mapper/BasicInfoMapper.dart';
- import 'package:flutter_habit/database/mapper/ExerciseInfoMapper.dart';
- import 'package:flutter_habit/database/mapper/FoodInfoMapper.dart';
- import 'package:flutter_habit/database/mapper/LifeInfoMapper.dart';
- import 'package:flutter_habit/database/mapper/SportInfoMapper.dart';
- import 'package:provider/provider.dart';
- class DebugPage extends StatefulWidget {
- @override
- _DebugPageState createState() => _DebugPageState();
- }
- class Debug {
- final String name;
- final Function function;
- Debug(this.name, this.function);
- }
- class _DebugPageState extends State<DebugPage> {
- @override
- Widget build(BuildContext context) {
- NotificationProvider notificationProvider = Provider.of<NotificationProvider>(context,listen: false);
- return Scaffold(
- appBar: AppBar(
- title: Text("debug"),
- ),
- body: ListView(
- children: <Debug>[
- Debug("测试数据", () => _test(context)),
- Debug("测试普通通知", () {
- notificationProvider.notice(10, "123", "123");
- }),
- Debug("调度通知 id 10", () {
- notificationProvider.scheduledNotice(10, "123", "123",22,43,20);
- }),
- Debug("取消通知 id 10", () {
- notificationProvider.cancel(10);
- }),
- Debug("通知列表", () async {
- List<PendingNotificationRequest> l = await notificationProvider.getNotifications();
- for (PendingNotificationRequest value in l) {
- debugPrint("${value.id} ${value.title} ${value.body}");
- }
- }),
- ].map((i) {
- return ListTile(
- title: Text(i.name),
- onTap: i.function as void Function()?,
- );
- }).toList(),
- ),
- );
- }
- }
- Future<void> _test(BuildContext context) async {
- await SqfliteDataBase.resetTables();
- Random random = Random();
- for (int i = 1; i <= 10; i++) {
- FoodInfo foodInfo = FoodInfo();
- foodInfo.setName("food_$i");
- foodInfo.setHgkCalorie(
- double.parse(((i * 10 + random.nextDouble())).toStringAsFixed(2)));
- foodInfo.setEatTimes(0);
- await FoodInfoMapper().insert(foodInfo);
- SportInfo sportInfo = SportInfo();
- sportInfo.setName("spot_$i");
- sportInfo.setHkCalorie(
- double.parse(((i * 10 + random.nextDouble())).toStringAsFixed(2)));
- sportInfo.setSportTimes(0);
- await SportInfoMapper().insert(sportInfo);
- }
- for (int i = 99; i >= 0; i--) {
- BasicInfo basicInfo = BasicInfo();
- basicInfo.setDate(
- DateTime.now().subtract(Duration(days: i)).millisecondsSinceEpoch);
- basicInfo.setHeight(
- double.parse(((170 + random.nextDouble())).toStringAsFixed(2)));
- basicInfo.setWeight(
- double.parse(((60 + random.nextDouble())).toStringAsFixed(2)));
- basicInfo.setWaistLine(
- (double.parse(((88 + random.nextDouble())).toStringAsFixed(2))));
- basicInfo.setBreastLine(
- (double.parse(((88 + random.nextDouble())).toStringAsFixed(2))));
- basicInfo.setHipLine(
- (double.parse(((94 + random.nextDouble())).toStringAsFixed(2))));
- await BasicInfoMapper().insert(basicInfo);
- LifeInfo lifeInfo = LifeInfo();
- DateTime thatDay = DateTime.now().subtract(Duration(days: i));
- DateTime thatDayZeroTime =
- DateTime(thatDay.year, thatDay.month, thatDay.day);
- lifeInfo.setDate(thatDay.millisecondsSinceEpoch);
- lifeInfo.setGetUpTime(thatDayZeroTime
- .add(Duration(hours: 6, minutes: 50))
- .millisecondsSinceEpoch +
- random.nextInt(30) * 60000);
- lifeInfo.setBreakfastTime(thatDayZeroTime
- .add(Duration(hours: 7, minutes: 50))
- .millisecondsSinceEpoch +
- random.nextInt(30) * 60000);
- lifeInfo.setBreakfastQuantity(100 + 10 * random.nextDouble());
- lifeInfo.setBreakfastId(1 + random.nextInt(9));
- lifeInfo.setBreakfastMoney((1 + random.nextInt(9)).toDouble());
- lifeInfo.setLunchTime(thatDayZeroTime
- .add(Duration(hours: 12, minutes: 50))
- .millisecondsSinceEpoch +
- random.nextInt(30) * 60000);
- lifeInfo.setLunchQuantity(100 + 10 * random.nextDouble());
- lifeInfo.setLunchId(1 + random.nextInt(9));
- lifeInfo.setLunchMoney((1 + random.nextInt(9)).toDouble());
- lifeInfo.setMidRestTime(
- thatDayZeroTime.add(Duration(hours: 13)).millisecondsSinceEpoch +
- random.nextInt(30 * 60000));
- lifeInfo.setDinnerTime(
- thatDayZeroTime.add(Duration(hours: 18)).millisecondsSinceEpoch +
- random.nextInt(30 * 60000));
- lifeInfo.setDinnerQuantity(100 + 10 * random.nextDouble());
- lifeInfo.setDinnerId(1 + random.nextInt(9));
- lifeInfo.setDinnerMoney((1 + random.nextInt(9)).toDouble());
- lifeInfo.setRestTime(
- thatDayZeroTime.add(Duration(hours: 21)).millisecondsSinceEpoch +
- random.nextInt(30 * 60000));
- await LifeInfoMapper().insert(lifeInfo);
- ExerciseInfo exerciseInfo = ExerciseInfo();
- exerciseInfo.setSportId(1 + random.nextInt(9));
- exerciseInfo.setExerciseQuantity(100 + 10 * random.nextDouble());
- exerciseInfo.setExerciseTime(thatDayZeroTime
- .add(Duration(hours: 12, minutes: 50))
- .millisecondsSinceEpoch +
- random.nextInt(30) * 60000);
- await ExerciseInfoMapper().insert(exerciseInfo);
- }
- await Provider.of<DataProvider>(context, listen: false).loadData();
- }
|