Compare commits

..

7 Commits

8
.idea/.gitignore vendored

@ -1,8 +0,0 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

@ -1,11 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$" />
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
<orderEntry type="library" name="Dart SDK" level="project" />
<orderEntry type="library" name="Dart Packages" level="project" />
</component>
</module>

@ -1,204 +0,0 @@
<component name="libraryTable">
<library name="Dart Packages" type="DartPackagesLibraryType">
<properties>
<option name="packageNameToDirsMap">
<entry key="async">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/async-2.11.0/lib" />
</list>
</value>
</entry>
<entry key="boolean_selector">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/boolean_selector-2.1.1/lib" />
</list>
</value>
</entry>
<entry key="characters">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/characters-1.3.0/lib" />
</list>
</value>
</entry>
<entry key="clock">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/clock-1.1.1/lib" />
</list>
</value>
</entry>
<entry key="collection">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/collection-1.17.2/lib" />
</list>
</value>
</entry>
<entry key="cupertino_icons">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/cupertino_icons-1.0.6/lib" />
</list>
</value>
</entry>
<entry key="fake_async">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/fake_async-1.3.1/lib" />
</list>
</value>
</entry>
<entry key="flutter">
<value>
<list>
<option value="C:/SDKs/Flutter/flutter_windows_3.13.2-stable/flutter/packages/flutter/lib" />
</list>
</value>
</entry>
<entry key="flutter_lints">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/flutter_lints-2.0.3/lib" />
</list>
</value>
</entry>
<entry key="flutter_test">
<value>
<list>
<option value="C:/SDKs/Flutter/flutter_windows_3.13.2-stable/flutter/packages/flutter_test/lib" />
</list>
</value>
</entry>
<entry key="lints">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/lints-2.1.1/lib" />
</list>
</value>
</entry>
<entry key="matcher">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/matcher-0.12.16/lib" />
</list>
</value>
</entry>
<entry key="material_color_utilities">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/material_color_utilities-0.5.0/lib" />
</list>
</value>
</entry>
<entry key="meta">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/meta-1.9.1/lib" />
</list>
</value>
</entry>
<entry key="path">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/path-1.8.3/lib" />
</list>
</value>
</entry>
<entry key="sky_engine">
<value>
<list>
<option value="C:/SDKs/Flutter/flutter_windows_3.13.2-stable/flutter/bin/cache/pkg/sky_engine/lib" />
</list>
</value>
</entry>
<entry key="source_span">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/source_span-1.10.0/lib" />
</list>
</value>
</entry>
<entry key="stack_trace">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/stack_trace-1.11.0/lib" />
</list>
</value>
</entry>
<entry key="stream_channel">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/stream_channel-2.1.1/lib" />
</list>
</value>
</entry>
<entry key="string_scanner">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/string_scanner-1.2.0/lib" />
</list>
</value>
</entry>
<entry key="term_glyph">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/term_glyph-1.2.1/lib" />
</list>
</value>
</entry>
<entry key="test_api">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/test_api-0.6.0/lib" />
</list>
</value>
</entry>
<entry key="vector_math">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/vector_math-2.1.4/lib" />
</list>
</value>
</entry>
<entry key="web">
<value>
<list>
<option value="C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/web-0.1.4-beta/lib" />
</list>
</value>
</entry>
</option>
</properties>
<CLASSES>
<root url="file://C:/SDKs/Flutter/flutter_windows_3.13.2-stable/flutter/bin/cache/pkg/sky_engine/lib" />
<root url="file://C:/SDKs/Flutter/flutter_windows_3.13.2-stable/flutter/packages/flutter/lib" />
<root url="file://C:/SDKs/Flutter/flutter_windows_3.13.2-stable/flutter/packages/flutter_test/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/async-2.11.0/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/boolean_selector-2.1.1/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/characters-1.3.0/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/clock-1.1.1/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/collection-1.17.2/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/cupertino_icons-1.0.6/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/fake_async-1.3.1/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/flutter_lints-2.0.3/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/lints-2.1.1/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/matcher-0.12.16/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/material_color_utilities-0.5.0/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/meta-1.9.1/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/path-1.8.3/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/source_span-1.10.0/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/stack_trace-1.11.0/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/stream_channel-2.1.1/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/string_scanner-1.2.0/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/term_glyph-1.2.1/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/test_api-0.6.0/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/vector_math-2.1.4/lib" />
<root url="file://C:/Users/L/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/web-0.1.4-beta/lib" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</component>

@ -1,29 +0,0 @@
<component name="libraryTable">
<library name="Dart SDK">
<CLASSES>
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/async" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/cli" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/collection" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/convert" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/core" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/developer" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/ffi" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/html" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/indexed_db" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/io" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/isolate" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/js" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/js_interop" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/js_interop_unsafe" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/js_util" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/math" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/mirrors" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/svg" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/typed_data" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/web_audio" />
<root url="file://E:/develop_environment/flutter-sdk/flutter/bin/cache/dart-sdk/lib/web_gl" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</component>

@ -1,5 +0,0 @@
<project version="4">
<component name="ProjectRootManager">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

@ -1,8 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/.idea/TimeManager.iml" filepath="$PROJECT_DIR$/.idea/TimeManager.iml" />
</modules>
</component>
</project>

@ -1,6 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="" vcs="Git" />
</component>
</project>

@ -1,2 +1 @@
# flutter

Binary file not shown.

Binary file not shown.

After

Width:  |  Height:  |  Size: 64 KiB

@ -1,29 +0,0 @@
<component name="libraryTable">
<library name="Dart SDK">
<CLASSES>
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/async" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/cli" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/collection" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/convert" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/core" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/developer" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/ffi" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/html" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/indexed_db" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/io" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/isolate" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/js" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/js_interop" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/js_interop_unsafe" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/js_util" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/math" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/mirrors" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/svg" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/typed_data" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/web_audio" />
<root url="file://$PROJECT_DIR$/../../../../../Environment/flutter_windows_3.13.5-stable/flutter/bin/cache/dart-sdk/lib/web_gl" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</component>

@ -1,15 +0,0 @@
<component name="libraryTable">
<library name="KotlinJavaRuntime">
<CLASSES>
<root url="jar://$KOTLIN_BUNDLED$/lib/kotlin-stdlib.jar!/" />
<root url="jar://$KOTLIN_BUNDLED$/lib/kotlin-reflect.jar!/" />
<root url="jar://$KOTLIN_BUNDLED$/lib/kotlin-test.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$KOTLIN_BUNDLED$/lib/kotlin-stdlib-sources.jar!/" />
<root url="jar://$KOTLIN_BUNDLED$/lib/kotlin-reflect-sources.jar!/" />
<root url="jar://$KOTLIN_BUNDLED$/lib/kotlin-test-sources.jar!/" />
</SOURCES>
</library>
</component>

@ -1,9 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/.idea/timemanagerapp.iml" filepath="$PROJECT_DIR$/.idea/timemanagerapp.iml" />
<module fileurl="file://$PROJECT_DIR$/android/timemanagerapp_android.iml" filepath="$PROJECT_DIR$/android/timemanagerapp_android.iml" />
</modules>
</component>
</project>

@ -1,264 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="AutoImportSettings">
<option name="autoReloadType" value="SELECTIVE" />
</component>
<component name="ChangeListManager">
<list default="true" id="c05b8a8d-d805-4e13-a87e-db77479b20ae" name="Default Changelist" comment="">
<change beforePath="$PROJECT_DIR$/.dart_tool/dartpad/web_plugin_registrant.dart" beforeDir="false" afterPath="$PROJECT_DIR$/.dart_tool/dartpad/web_plugin_registrant.dart" afterDir="false" />
<change beforePath="$PROJECT_DIR$/.dart_tool/package_config.json" beforeDir="false" afterPath="$PROJECT_DIR$/.dart_tool/package_config.json" afterDir="false" />
<change beforePath="$PROJECT_DIR$/.dart_tool/package_config_subset" beforeDir="false" afterPath="$PROJECT_DIR$/.dart_tool/package_config_subset" afterDir="false" />
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
<change beforePath="$PROJECT_DIR$/android/app/src/main/java/io/flutter/plugins/GeneratedPluginRegistrant.java" beforeDir="false" afterPath="$PROJECT_DIR$/android/app/src/main/java/io/flutter/plugins/GeneratedPluginRegistrant.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ios/Runner/GeneratedPluginRegistrant.m" beforeDir="false" afterPath="$PROJECT_DIR$/ios/Runner/GeneratedPluginRegistrant.m" afterDir="false" />
<change beforePath="$PROJECT_DIR$/lib/entity/Course.dart" beforeDir="false" afterPath="$PROJECT_DIR$/lib/entity/Course.dart" afterDir="false" />
<change beforePath="$PROJECT_DIR$/lib/entity/Task.dart" beforeDir="false" afterPath="$PROJECT_DIR$/lib/entity/Task.dart" afterDir="false" />
<change beforePath="$PROJECT_DIR$/lib/entity/Team.dart" beforeDir="false" afterPath="$PROJECT_DIR$/lib/entity/Team.dart" afterDir="false" />
<change beforePath="$PROJECT_DIR$/lib/entity/User.dart" beforeDir="false" afterPath="$PROJECT_DIR$/lib/entity/User.dart" afterDir="false" />
<change beforePath="$PROJECT_DIR$/lib/entity/Work.dart" beforeDir="false" afterPath="$PROJECT_DIR$/lib/entity/Work.dart" afterDir="false" />
<change beforePath="$PROJECT_DIR$/macos/Flutter/GeneratedPluginRegistrant.swift" beforeDir="false" afterPath="$PROJECT_DIR$/macos/Flutter/GeneratedPluginRegistrant.swift" afterDir="false" />
<change beforePath="$PROJECT_DIR$/pubspec.lock" beforeDir="false" afterPath="$PROJECT_DIR$/pubspec.lock" afterDir="false" />
<change beforePath="$PROJECT_DIR$/pubspec.yaml" beforeDir="false" afterPath="$PROJECT_DIR$/pubspec.yaml" afterDir="false" />
</list>
<option name="SHOW_DIALOG" value="false" />
<option name="HIGHLIGHT_CONFLICTS" value="true" />
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
<option name="LAST_RESOLUTION" value="IGNORE" />
</component>
<component name="Git.Settings">
<option name="INCOMING_CHECK_STRATEGY" value="Never" />
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$/../.." />
</component>
<component name="GitSEFilterConfiguration">
<file-type-list>
<filtered-out-file-type name="LOCAL_BRANCH" />
<filtered-out-file-type name="REMOTE_BRANCH" />
<filtered-out-file-type name="TAG" />
<filtered-out-file-type name="COMMIT_BY_MESSAGE" />
</file-type-list>
</component>
<component name="HighlightingSettingsPerFile">
<setting file="file://$PROJECT_DIR$/lib/widgets/AddCourseFormWidget.dart" root0="FORCE_HIGHLIGHTING" />
<setting file="file://$PROJECT_DIR$/pubspec.yaml" root0="FORCE_HIGHLIGHTING" />
<setting file="file://$PROJECT_DIR$/lib/widgets/RegisterWidget.dart" root0="FORCE_HIGHLIGHTING" />
<setting file="file://C:/SDKs/Flutter/flutter_windows_3.13.2-stable/flutter/bin/cache/pkg/sky_engine/lib/core/date_time.dart" root0="SKIP_INSPECTION" />
<setting file="file://$USER_HOME$/AppData/Local/Pub/Cache/hosted/pub.flutter-io.cn/shared_preferences-2.2.1/lib/shared_preferences.dart" root0="SKIP_INSPECTION" />
<setting file="file://$PROJECT_DIR$/lib/main.dart" root0="FORCE_HIGHLIGHTING" />
<setting file="file://C:/SDKs/Flutter/flutter_windows_3.13.2-stable/flutter/bin/cache/pkg/sky_engine/lib/core/string.dart" root0="SKIP_INSPECTION" />
<setting file="file://$PROJECT_DIR$/lib/tests/Setting_test.dart" root0="FORCE_HIGHLIGHTING" />
<setting file="file://$PROJECT_DIR$/lib/setting/Setting.dart" root0="FORCE_HIGHLIGHTING" />
</component>
<component name="JsbtTreeLayoutManager">
<layout place="tools.popupGrunt">
<scroll-view-position x="0" y="0" />
</layout>
</component>
<component name="MarkdownSettingsMigration">
<option name="stateVersion" value="1" />
</component>
<component name="ProjectColorInfo"><![CDATA[{
"customColor": "",
"associatedIndex": 6
}]]></component>
<component name="ProjectId" id="2VesZPmDCku5WeFpM29PfTh2Lgz" />
<component name="ProjectLevelVcsManager" settingsEditedManually="true">
<ConfirmationsSetting value="1" id="Add" />
</component>
<component name="ProjectReloadState">
<option name="STATE" value="1" />
</component>
<component name="ProjectView">
<navigator currentView="ProjectPane" proportions="" version="1" />
<panes>
<pane id="ProjectPane">
<option name="show-excluded-files" value="false" />
</pane>
</panes>
</component>
<component name="ProjectViewState">
<option name="autoscrollFromSource" value="true" />
<option name="autoscrollToSource" value="true" />
<option name="hideEmptyMiddlePackages" value="true" />
<option name="showLibraryContents" value="true" />
<option name="showMembers" value="true" />
<option name="showVisibilityIcons" value="true" />
</component>
<component name="PropertiesComponent"><![CDATA[{
"keyToString": {
"WebServerToolWindowFactoryState": "false",
"dart.analysis.tool.window.visible": "false",
"io.flutter.reload.alreadyRun": "true",
"last_opened_file_path": "D:/Environment/flutter_windows_3.13.5-stable/flutter",
"node.js.detected.package.eslint": "true",
"node.js.detected.package.tslint": "true",
"node.js.selected.package.eslint": "(autodetect)",
"node.js.selected.package.tslint": "(autodetect)",
"nodejs_package_manager_path": "npm",
"settings.editor.selected.configurable": "dart.settings",
"show.migrate.to.gradle.popup": "false",
"vue.rearranger.settings.migration": "true"
}
}]]></component>
<component name="RecentsManager">
<key name="CopyFile.RECENT_KEYS">
<recent name="D:\Myprogramfile\Flutter\TimeManager\src\timemanagerapp\assets\images" />
<recent name="D:\Myprogramfile\Flutter\TimeManager\src\timemanagerapp\lib\tests" />
<recent name="D:\Myprogramfile\Flutter\TimeManager\src\timemanagerapp\windows" />
<recent name="D:\Myprogramfile\Flutter\TimeManager\src\timemanagerapp\assets\pythoncode" />
<recent name="D:\Myprogramfile\Flutter\TimeManager\src\timemanagerapp\lib\controller" />
</key>
<key name="MoveFile.RECENT_KEYS">
<recent name="D:\Myprogramfile\Flutter\TimeManager\src\timemanagerapp\assets\pythoncode" />
<recent name="D:\Myprogramfile\Flutter\TimeManager\src\timemanagerapp\lib\util" />
<recent name="D:\Myprogramfile\Flutter\TimeManager\src\timemanagerapp\lib\test" />
</key>
</component>
<component name="RunManager" selected="Flutter.main.dart">
<configuration default="true" type="ArquillianJUnit" factoryName="" nameIsGenerated="true">
<option name="arquillianRunConfiguration">
<value>
<option name="containerStateName" value="" />
</value>
</option>
<option name="TEST_OBJECT" value="class" />
<method v="2">
<option name="Make" enabled="true" />
</method>
</configuration>
<configuration name="GetCourseByLogin.dart" type="DartCommandLineRunConfigurationType" factoryName="Dart Command Line Application" temporary="true" nameIsGenerated="true">
<option name="filePath" value="$PROJECT_DIR$/lib/util/GetCourseByLogin.dart" />
<option name="workingDirectory" value="$PROJECT_DIR$" />
<method v="2" />
</configuration>
<configuration name="GetCourseByLogin.dart" type="DartCommandLineRunConfigurationType" factoryName="Dart Command Line Application" temporary="true" nameIsGenerated="true">
<option name="filePath" value="$PROJECT_DIR$/lib/util/GetCourseByLogin.dart" />
<option name="workingDirectory" value="$PROJECT_DIR$" />
<method v="2" />
</configuration>
<configuration name="GetCourseByLogin.dart" type="DartCommandLineRunConfigurationType" factoryName="Dart Command Line Application" temporary="true" nameIsGenerated="true">
<option name="filePath" value="$PROJECT_DIR$/lib/util/GetCourseByLogin.dart" />
<option name="workingDirectory" value="$PROJECT_DIR$" />
<method v="2" />
</configuration>
<configuration name="curse_test.dart" type="DartCommandLineRunConfigurationType" factoryName="Dart Command Line Application" temporary="true" nameIsGenerated="true">
<option name="filePath" value="$PROJECT_DIR$/lib/tests/curse_test.dart" />
<option name="workingDirectory" value="$PROJECT_DIR$" />
<method v="2" />
</configuration>
<configuration name="main.dart" type="DartCommandLineRunConfigurationType" factoryName="Dart Command Line Application" temporary="true" nameIsGenerated="true">
<option name="filePath" value="$PROJECT_DIR$/lib/main.dart" />
<option name="workingDirectory" value="$PROJECT_DIR$" />
<method v="2" />
</configuration>
<configuration name="test.dart" type="DartCommandLineRunConfigurationType" factoryName="Dart Command Line Application" temporary="true" nameIsGenerated="true">
<option name="filePath" value="$PROJECT_DIR$/lib/tests/test.dart" />
<option name="workingDirectory" value="$PROJECT_DIR$" />
<method v="2" />
</configuration>
<configuration name="main.dart" type="FlutterRunConfigurationType" factoryName="Flutter" temporary="true">
<option name="filePath" value="$PROJECT_DIR$/lib/main.dart" />
<method v="2" />
</configuration>
<recent_temporary>
<list>
<item itemvalue="Flutter.main.dart" />
<item itemvalue="Dart Command Line App.main.dart" />
<item itemvalue="Dart Command Line App.GetCourseByLogin.dart" />
<item itemvalue="Dart Command Line App.test.dart" />
<item itemvalue="Dart Command Line App.curse_test.dart" />
</list>
</recent_temporary>
</component>
<component name="SpellCheckerSettings" RuntimeDictionaries="0" Folders="0" CustomDictionaries="0" DefaultDictionary="application-level" UseSingleDictionary="true" transferred="true" />
<component name="TaskManager">
<task active="true" id="Default" summary="Default task">
<changelist id="c05b8a8d-d805-4e13-a87e-db77479b20ae" name="Default Changelist" comment="" />
<created>1695207944684</created>
<option name="number" value="Default" />
<option name="presentableId" value="Default" />
<updated>1695207944684</updated>
<workItem from="1695207948527" duration="68000" />
<workItem from="1695208047127" duration="657000" />
<workItem from="1695209069987" duration="2257000" />
<workItem from="1695220647490" duration="1187000" />
<workItem from="1695254290910" duration="520000" />
<workItem from="1695254903357" duration="1893000" />
<workItem from="1695257017289" duration="1859000" />
<workItem from="1695259402228" duration="4322000" />
<workItem from="1695263813760" duration="4711000" />
<workItem from="1695274467645" duration="7772000" />
<workItem from="1695282467478" duration="2935000" />
<workItem from="1695285460318" duration="2347000" />
<workItem from="1695373122179" duration="662000" />
<workItem from="1695423358872" duration="5391000" />
<workItem from="1695430529666" duration="170000" />
<workItem from="1695430954107" duration="7056000" />
<workItem from="1695438386693" duration="771000" />
<workItem from="1695442386312" duration="5623000" />
<workItem from="1695451465795" duration="18570000" />
<workItem from="1695474623960" duration="10742000" />
<workItem from="1695511266504" duration="7215000" />
<workItem from="1695518589469" duration="335000" />
<workItem from="1695519007728" duration="8319000" />
<workItem from="1695535233798" duration="528000" />
<workItem from="1695536532445" duration="349000" />
<workItem from="1695721283440" duration="1068000" />
<workItem from="1695727139040" duration="13000" />
<workItem from="1695729103403" duration="8100000" />
<workItem from="1695739077875" duration="1503000" />
<workItem from="1695744280846" duration="199000" />
<workItem from="1695772819957" duration="494000" />
<workItem from="1695773370892" duration="883000" />
<workItem from="1695774400362" duration="8564000" />
<workItem from="1695867942932" duration="1967000" />
<workItem from="1696590516102" duration="605000" />
<workItem from="1696687805094" duration="984000" />
<workItem from="1696810321277" duration="1698000" />
<workItem from="1696812614065" duration="1521000" />
<workItem from="1696814532218" duration="1555000" />
<workItem from="1697183742395" duration="963000" />
<workItem from="1697185106120" duration="1817000" />
<workItem from="1697186964882" duration="2364000" />
<workItem from="1697269445440" duration="2047000" />
<workItem from="1697271705228" duration="7998000" />
<workItem from="1697280114271" duration="2504000" />
<workItem from="1697282676219" duration="14052000" />
<workItem from="1697299311532" duration="83000" />
<workItem from="1697299438838" duration="35000" />
<workItem from="1697299504532" duration="2109000" />
<workItem from="1697301675956" duration="167000" />
<workItem from="1697302442537" duration="36895000" />
<workItem from="1697416617853" duration="7462000" />
</task>
<servers />
</component>
<component name="ToolWindowManager">
<editor active="true" />
<layout>
<window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="0" side_tool="false" content_ui="combo" />
</layout>
</component>
<component name="TypeScriptGeneratedFilesManager">
<option name="version" value="3" />
</component>
<component name="Vcs.Log.Tabs.Properties">
<option name="TAB_STATES">
<map>
<entry key="MAIN">
<value>
<State />
</value>
</entry>
</map>
</option>
</component>
<component name="VcsManagerConfiguration">
<ignored-roots>
<path value="$PROJECT_DIR$/../.." />
</ignored-roots>
</component>
<component name="XSLT-Support.FileAssociations.UIState">
<expand />
<select />
</component>
</project>

@ -0,0 +1,45 @@
# This file tracks properties of this Flutter project.
# Used by Flutter tool to assess capabilities and perform upgrades etc.
#
# This file should be version controlled and should not be manually edited.
version:
revision: "ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a"
channel: "stable"
project_type: app
# Tracks metadata for the flutter migrate command
migration:
platforms:
- platform: root
create_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
base_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
- platform: android
create_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
base_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
- platform: ios
create_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
base_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
- platform: linux
create_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
base_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
- platform: macos
create_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
base_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
- platform: web
create_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
base_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
- platform: windows
create_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
base_revision: ff5b5b5fa6f35b717667719ddfdb1521d8bdd05a
# User provided section
# List of Local paths (relative to this file) that should be
# ignored by the migrate tool.
#
# Files that are not part of the templates will be ignored by default.
unmanaged_files:
- 'lib/main.dart'
- 'ios/Runner.xcodeproj/project.pbxproj'

@ -0,0 +1,29 @@
# This file configures the analyzer, which statically analyzes Dart code to
# check for errors, warnings, and lints.
#
# The issues identified by the analyzer are surfaced in the UI of Dart-enabled
# IDEs (https://dart.dev/tools#ides-and-editors). The analyzer can also be
# invoked from the command line by running `flutter analyze`.
# The following line activates a set of recommended lints for Flutter apps,
# packages, and plugins designed to encourage good coding practices.
include: package:flutter_lints/flutter.yaml
linter:
# The lint rules applied to this project can be customized in the
# section below to disable rules from the `package:flutter_lints/flutter.yaml`
# included above or to enable additional rules. A list of all available lints
# and their documentation is published at https://dart.dev/lints.
#
# Instead of disabling a lint rule for the entire project in the
# section below, it can also be suppressed for a single line of code
# or a specific dart file by using the `// ignore: name_of_lint` and
# `// ignore_for_file: name_of_lint` syntax on the line or in the file
# producing the lint.
rules:
# avoid_print: false # Uncomment to disable the `avoid_print` rule
# prefer_single_quotes: true # Uncomment to enable the `prefer_single_quotes` rule
prefer_const_constructors: false
# Additional information about this file can be found at
# https://dart.dev/guides/language/analysis-options

@ -1,8 +1,8 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
<application
android:label="timemanagerapp"
android:label="多为时间"
android:name="${applicationName}"
android:icon="@mipmap/ic_launcher">
android:icon="@mipmap/logo">
<activity
android:name=".MainActivity"
android:exported="true"
@ -30,4 +30,9 @@
android:name="flutterEmbedding"
android:value="2" />
</application>
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
</manifest>

@ -1,39 +0,0 @@
package io.flutter.plugins;
import androidx.annotation.Keep;
import androidx.annotation.NonNull;
import io.flutter.Log;
import io.flutter.embedding.engine.FlutterEngine;
/**
* Generated file. Do not edit.
* This file is generated by the Flutter tool based on the
* plugins that support the Android platform.
*/
@Keep
public final class GeneratedPluginRegistrant {
private static final String TAG = "GeneratedPluginRegistrant";
public static void registerWith(@NonNull FlutterEngine flutterEngine) {
try {
flutterEngine.getPlugins().add(new io.flutter.plugins.deviceinfo.DeviceInfoPlugin());
} catch (Exception e) {
Log.e(TAG, "Error registering plugin device_info, io.flutter.plugins.deviceinfo.DeviceInfoPlugin", e);
}
try {
flutterEngine.getPlugins().add(new io.flutter.plugins.pathprovider.PathProviderPlugin());
} catch (Exception e) {
Log.e(TAG, "Error registering plugin path_provider_android, io.flutter.plugins.pathprovider.PathProviderPlugin", e);
}
try {
flutterEngine.getPlugins().add(new io.flutter.plugins.sharedpreferences.SharedPreferencesPlugin());
} catch (Exception e) {
Log.e(TAG, "Error registering plugin shared_preferences_android, io.flutter.plugins.sharedpreferences.SharedPreferencesPlugin", e);
}
try {
flutterEngine.getPlugins().add(new com.tekartik.sqflite.SqflitePlugin());
} catch (Exception e) {
Log.e(TAG, "Error registering plugin sqflite, com.tekartik.sqflite.SqflitePlugin", e);
}
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

@ -4,4 +4,9 @@
to allow setting breakpoints, to provide hot reload, etc.
-->
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
</manifest>

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 7.1 KiB

@ -1,160 +0,0 @@
#!/usr/bin/env bash
##############################################################################
##
## Gradle start up script for UN*X
##
##############################################################################
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS=""
APP_NAME="Gradle"
APP_BASE_NAME=`basename "$0"`
# Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD="maximum"
warn ( ) {
echo "$*"
}
die ( ) {
echo
echo "$*"
echo
exit 1
}
# OS specific support (must be 'true' or 'false').
cygwin=false
msys=false
darwin=false
case "`uname`" in
CYGWIN* )
cygwin=true
;;
Darwin* )
darwin=true
;;
MINGW* )
msys=true
;;
esac
# Attempt to set APP_HOME
# Resolve links: $0 may be a link
PRG="$0"
# Need this for relative symlinks.
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG=`dirname "$PRG"`"/$link"
fi
done
SAVED="`pwd`"
cd "`dirname \"$PRG\"`/" >/dev/null
APP_HOME="`pwd -P`"
cd "$SAVED" >/dev/null
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
# Determine the Java command to use to start the JVM.
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD="$JAVA_HOME/jre/sh/java"
else
JAVACMD="$JAVA_HOME/bin/java"
fi
if [ ! -x "$JAVACMD" ] ; then
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
else
JAVACMD="java"
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
# Increase the maximum file descriptors if we can.
if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
MAX_FD_LIMIT=`ulimit -H -n`
if [ $? -eq 0 ] ; then
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
MAX_FD="$MAX_FD_LIMIT"
fi
ulimit -n $MAX_FD
if [ $? -ne 0 ] ; then
warn "Could not set maximum file descriptor limit: $MAX_FD"
fi
else
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
fi
fi
# For Darwin, add options to specify how the application appears in the dock
if $darwin; then
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
fi
# For Cygwin, switch paths to Windows format before running java
if $cygwin ; then
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
JAVACMD=`cygpath --unix "$JAVACMD"`
# We build the pattern for arguments to be converted via cygpath
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
SEP=""
for dir in $ROOTDIRSRAW ; do
ROOTDIRS="$ROOTDIRS$SEP$dir"
SEP="|"
done
OURCYGPATTERN="(^($ROOTDIRS))"
# Add a user-defined pattern to the cygpath arguments
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
fi
# Now convert the arguments - kludge to limit ourselves to /bin/sh
i=0
for arg in "$@" ; do
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
else
eval `echo args$i`="\"$arg\""
fi
i=$((i+1))
done
case $i in
(0) set -- ;;
(1) set -- "$args0" ;;
(2) set -- "$args0" "$args1" ;;
(3) set -- "$args0" "$args1" "$args2" ;;
(4) set -- "$args0" "$args1" "$args2" "$args3" ;;
(5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
(6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
esac
fi
# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
function splitJvmOpts() {
JVM_OPTS=("$@")
}
eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"
exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"

@ -1,90 +0,0 @@
@if "%DEBUG%" == "" @echo off
@rem ##########################################################################
@rem
@rem Gradle startup script for Windows
@rem
@rem ##########################################################################
@rem Set local scope for the variables with windows NT shell
if "%OS%"=="Windows_NT" setlocal
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
set DEFAULT_JVM_OPTS=
set DIRNAME=%~dp0
if "%DIRNAME%" == "" set DIRNAME=.
set APP_BASE_NAME=%~n0
set APP_HOME=%DIRNAME%
@rem Find java.exe
if defined JAVA_HOME goto findJavaFromJavaHome
set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
if "%ERRORLEVEL%" == "0" goto init
echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.
goto fail
:findJavaFromJavaHome
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
if exist "%JAVA_EXE%" goto init
echo.
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.
goto fail
:init
@rem Get command-line arguments, handling Windowz variants
if not "%OS%" == "Windows_NT" goto win9xME_args
if "%@eval[2+2]" == "4" goto 4NT_args
:win9xME_args
@rem Slurp the command line arguments.
set CMD_LINE_ARGS=
set _SKIP=2
:win9xME_args_slurp
if "x%~1" == "x" goto execute
set CMD_LINE_ARGS=%*
goto execute
:4NT_args
@rem Get arguments from the 4NT Shell from JP Software
set CMD_LINE_ARGS=%$
:execute
@rem Setup the command line
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
@rem Execute Gradle
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
:end
@rem End local scope for the variables with windows NT shell
if "%ERRORLEVEL%"=="0" goto mainEnd
:fail
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
rem the _cmd.exe /c_ return code!
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
exit /b 1
:mainEnd
if "%OS%"=="Windows_NT" endlocal
:omega

@ -1,5 +0,0 @@
sdk.dir=D:/Environment/AndroidSDK
flutter.sdk=D:\\Environment\\flutter_windows_3.13.5-stable\\flutter
flutter.buildMode=debug
flutter.versionName=1.0.0
flutter.versionCode=1

@ -1,27 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="FacetManager">
<facet type="android" name="Android">
<configuration>
<option name="ALLOW_USER_CONFIGURATION" value="false" />
<option name="GEN_FOLDER_RELATIVE_PATH_APT" value="/gen" />
<option name="GEN_FOLDER_RELATIVE_PATH_AIDL" value="/gen" />
<option name="MANIFEST_FILE_RELATIVE_PATH" value="/app/src/main/AndroidManifest.xml" />
<option name="RES_FOLDER_RELATIVE_PATH" value="/app/src/main/res" />
<option name="ASSETS_FOLDER_RELATIVE_PATH" value="/app/src/main/assets" />
<option name="LIBS_FOLDER_RELATIVE_PATH" value="/app/src/main/libs" />
<option name="PROGUARD_LOGS_FOLDER_RELATIVE_PATH" value="/app/src/main/proguard_logs" />
</configuration>
</facet>
</component>
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/app/src/main/java" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/gen" isTestSource="false" generated="true" />
</content>
<orderEntry type="jdk" jdkName="Android API 33 Platform" jdkType="Android SDK" />
<orderEntry type="sourceFolder" forTests="false" />
<orderEntry type="library" name="Flutter for Android" level="project" />
</component>
</module>

Binary file not shown.

After

Width:  |  Height:  |  Size: 372 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 90 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 266 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 198 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 479 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 134 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 192 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 MiB

@ -0,0 +1,134 @@
/*
Navicat MySQL Data Transfer
Source Server : LRC_debian
Source Server Version : 50742
Source Host : 5902e9v900.zicp.fun:33006
Source Database : expressFrame02
Target Server Type : MYSQL
Target Server Version : 50742
File Encoding : 65001
Date: 2023-10-26 12:49:35
*/
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for clocks
-- ----------------------------
DROP TABLE IF EXISTS `clocks`;
CREATE TABLE `clocks` (
`id` bigint(20) NOT NULL,
`clockId` bigint(20) NOT NULL,
`userId` bigint(20) NOT NULL,
`text` text,
`img` text,
`music` text,
PRIMARY KEY (`id`) USING BTREE,
KEY `fk_clocks_clocks_1` (`userId`),
CONSTRAINT `fk_clocks_clocks_1` FOREIGN KEY (`userId`) REFERENCES `users` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
-- ----------------------------
-- Table structure for course
-- ----------------------------
DROP TABLE IF EXISTS `course`;
CREATE TABLE `course` (
`id` bigint(20) NOT NULL,
`userId` bigint(20) DEFAULT NULL,
`courseId` bigint(20) NOT NULL,
`name` text NOT NULL,
`credit` double DEFAULT NULL,
`teacher` text,
`location` text,
`remark` text,
`startTime` text NOT NULL,
`endTime` text NOT NULL,
PRIMARY KEY (`id`) USING BTREE,
KEY `fk_course_course_1` (`userId`),
CONSTRAINT `fk_course_course_1` FOREIGN KEY (`userId`) REFERENCES `users` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
-- ----------------------------
-- Table structure for tasks
-- ----------------------------
DROP TABLE IF EXISTS `tasks`;
CREATE TABLE `tasks` (
`id` bigint(20) NOT NULL,
`taskId` bigint(20) NOT NULL,
`userId` bigint(20) NOT NULL,
`content` text,
`name` text NOT NULL,
`startTime` text NOT NULL,
`endTime` text NOT NULL,
PRIMARY KEY (`id`) USING BTREE,
KEY `fk_tasks_tasks_1` (`userId`),
CONSTRAINT `fk_tasks_tasks_1` FOREIGN KEY (`userId`) REFERENCES `users` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
-- ----------------------------
-- Table structure for teams
-- ----------------------------
DROP TABLE IF EXISTS `teams`;
CREATE TABLE `teams` (
`id` bigint(20) NOT NULL,
`leaderId` bigint(20) NOT NULL,
`teamName` varchar(200) NOT NULL,
`maxNumber` bigint(20) DEFAULT NULL,
`introduce` text,
PRIMARY KEY (`id`) USING BTREE,
UNIQUE KEY `teamName` (`teamName`) USING BTREE,
KEY `fk_teams_teams_1` (`leaderId`),
CONSTRAINT `fk_teams_teams_1` FOREIGN KEY (`leaderId`) REFERENCES `users` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
-- ----------------------------
-- Table structure for users
-- ----------------------------
DROP TABLE IF EXISTS `users`;
CREATE TABLE `users` (
`id` bigint(20) NOT NULL,
`username` varchar(255) NOT NULL,
`password` text NOT NULL,
`role` bigint(20) NOT NULL,
PRIMARY KEY (`id`) USING BTREE,
UNIQUE KEY `username` (`username`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
-- ----------------------------
-- Table structure for userteams
-- ----------------------------
DROP TABLE IF EXISTS `userteams`;
CREATE TABLE `userteams` (
`id` bigint(20) NOT NULL,
`userId` bigint(20) NOT NULL,
`teamId` bigint(20) NOT NULL,
PRIMARY KEY (`id`) USING BTREE,
KEY `fk_userteams_userteams_1` (`userId`),
KEY `fk_userteams_userteams_2` (`teamId`),
CONSTRAINT `fk_userteams_userteams_1` FOREIGN KEY (`userId`) REFERENCES `users` (`id`) ON DELETE CASCADE,
CONSTRAINT `fk_userteams_userteams_2` FOREIGN KEY (`teamId`) REFERENCES `teams` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
-- ----------------------------
-- Table structure for works
-- ----------------------------
DROP TABLE IF EXISTS `works`;
CREATE TABLE `works` (
`id` bigint(20) NOT NULL,
`userId` bigint(20) NOT NULL,
`workId` bigint(20) NOT NULL,
`teamId` bigint(20) NOT NULL,
`name` text NOT NULL,
`content` text,
`status` text,
`endTime` text NOT NULL,
`startTime` text NOT NULL,
PRIMARY KEY (`id`) USING BTREE,
KEY `fk_works_works_1` (`userId`),
KEY `fk_works_works_2` (`teamId`),
CONSTRAINT `fk_works_works_1` FOREIGN KEY (`userId`) REFERENCES `users` (`id`) ON DELETE CASCADE,
CONSTRAINT `fk_works_works_2` FOREIGN KEY (`teamId`) REFERENCES `teams` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;

Binary file not shown.

After

Width:  |  Height:  |  Size: 243 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 179 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 279 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 61 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 61 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 61 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 61 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 61 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.0 MiB

@ -1,14 +0,0 @@
// This is a generated file; do not edit or check into version control.
FLUTTER_ROOT=C:\SDKs\Flutter\flutter_windows_3.13.2-stable\flutter
FLUTTER_APPLICATION_PATH=D:\Myprogramfile\Flutter\timemanagerapp
COCOAPODS_PARALLEL_CODE_SIGN=true
FLUTTER_TARGET=lib\main.dart
FLUTTER_BUILD_DIR=build
FLUTTER_BUILD_NAME=1.0.0
FLUTTER_BUILD_NUMBER=1
EXCLUDED_ARCHS[sdk=iphonesimulator*]=i386
EXCLUDED_ARCHS[sdk=iphoneos*]=armv7
DART_OBFUSCATION=false
TRACK_WIDGET_CREATION=true
TREE_SHAKE_ICONS=false
PACKAGE_CONFIG=.dart_tool/package_config.json

@ -1,13 +0,0 @@
#!/bin/sh
# This is a generated file; do not edit or check into version control.
export "FLUTTER_ROOT=C:\SDKs\Flutter\flutter_windows_3.13.2-stable\flutter"
export "FLUTTER_APPLICATION_PATH=D:\Myprogramfile\Flutter\timemanagerapp"
export "COCOAPODS_PARALLEL_CODE_SIGN=true"
export "FLUTTER_TARGET=lib\main.dart"
export "FLUTTER_BUILD_DIR=build"
export "FLUTTER_BUILD_NAME=1.0.0"
export "FLUTTER_BUILD_NUMBER=1"
export "DART_OBFUSCATION=false"
export "TRACK_WIDGET_CREATION=true"
export "TREE_SHAKE_ICONS=false"
export "PACKAGE_CONFIG=.dart_tool/package_config.json"

@ -1,19 +0,0 @@
//
// Generated file. Do not edit.
//
// clang-format off
#ifndef GeneratedPluginRegistrant_h
#define GeneratedPluginRegistrant_h
#import <Flutter/Flutter.h>
NS_ASSUME_NONNULL_BEGIN
@interface GeneratedPluginRegistrant : NSObject
+ (void)registerWithRegistry:(NSObject<FlutterPluginRegistry>*)registry;
@end
NS_ASSUME_NONNULL_END
#endif /* GeneratedPluginRegistrant_h */

@ -1,42 +0,0 @@
//
// Generated file. Do not edit.
//
// clang-format off
#import "GeneratedPluginRegistrant.h"
#if __has_include(<device_info/FLTDeviceInfoPlugin.h>)
#import <device_info/FLTDeviceInfoPlugin.h>
#else
@import device_info;
#endif
#if __has_include(<path_provider_foundation/PathProviderPlugin.h>)
#import <path_provider_foundation/PathProviderPlugin.h>
#else
@import path_provider_foundation;
#endif
#if __has_include(<shared_preferences_foundation/SharedPreferencesPlugin.h>)
#import <shared_preferences_foundation/SharedPreferencesPlugin.h>
#else
@import shared_preferences_foundation;
#endif
#if __has_include(<sqflite/SqflitePlugin.h>)
#import <sqflite/SqflitePlugin.h>
#else
@import sqflite;
#endif
@implementation GeneratedPluginRegistrant
+ (void)registerWithRegistry:(NSObject<FlutterPluginRegistry>*)registry {
[FLTDeviceInfoPlugin registerWithRegistrar:[registry registrarForPlugin:@"FLTDeviceInfoPlugin"]];
[PathProviderPlugin registerWithRegistrar:[registry registrarForPlugin:@"PathProviderPlugin"]];
[SharedPreferencesPlugin registerWithRegistrar:[registry registrarForPlugin:@"SharedPreferencesPlugin"]];
[SqflitePlugin registerWithRegistrar:[registry registrarForPlugin:@"SqflitePlugin"]];
}
@end

@ -12,6 +12,8 @@ class CourseController {
return new CourseController();
}
static CourseDao courseDao = CourseDao();
GetCourseByLogin getCourseByLogin = GetCourseByLogin();
IdGenerator idGenerator = IdGenerator();
List<Course> courseList = []; //courseList
@ -42,39 +44,57 @@ class CourseController {
List<Course> courseListToInsert = [];
int allCourseId = await idGenerator.generateId();
for (int week = courseForm.getStartWeek(); week <= courseForm.getEndWeek(); week++) {
for(int day in courseForm.selectedDays){
//
final startDate = termstartdate.add(Duration(
days: (7 * (week - 1) + day! - 1),
hours: int.parse(raspiyane[courseForm.getStartTime() - 1][0].split(':')[0]),
minutes: int.parse(raspiyane[courseForm.getStartTime() - 1][0].split(':')[1]),
));
final endDate = termstartdate.add(Duration(
days: (7 * (week - 1) + day! - 1),
hours: int.parse(raspiyane[courseForm.getEndTime() - 1][1].split(':')[0]),
minutes: int.parse(raspiyane[courseForm.getEndTime() - 1][1].split(':')[1]),
));
Course course = Course(
id:await idGenerator.generateId(),
name: courseForm.getCourse(),
userId: Setting.user!.getId!,
courseId: allCourseId,
teacher: courseForm.getTeacher(),
location: courseForm.getLocation(),
startTime: startDate,
endTime: endDate,
credit: courseForm.getCredit(),
remark: courseForm.getNote()
);
courseListToInsert.add(course);
}
for(int day in courseForm.selectedDays){
//
final startDate = termstartdate.add(Duration(
days: (7 * (week - 1) + day! - 1),
hours: int.parse(raspiyane[courseForm.getStartTime() - 1][0].split(':')[0]),
minutes: int.parse(raspiyane[courseForm.getStartTime() - 1][0].split(':')[1]),
));
final endDate = termstartdate.add(Duration(
days: (7 * (week - 1) + day! - 1),
hours: int.parse(raspiyane[courseForm.getEndTime() - 1][1].split(':')[0]),
minutes: int.parse(raspiyane[courseForm.getEndTime() - 1][1].split(':')[1]),
));
Course course = Course(
id:await idGenerator.generateId(),
name: courseForm.getCourse(),
userId: Setting.user!.getId!,
courseId: allCourseId,
teacher: courseForm.getTeacher(),
location: courseForm.getLocation(),
startTime: startDate,
endTime: endDate,
credit: courseForm.getCredit(),
remark: courseForm.getNote()
);
courseListToInsert.add(course);
}
}
await insertCourseList(courseListToInsert);
}
Future<List<Course>> init() async {
var res = await netWorkController.getCourseList(Setting.user!.getId!);
if(res == null || res.length == 0){
courseList = [];
}else{
courseList = res;
}
for(Course course in courseList){
await courseDao.insertCourse(course);
}
return courseList;
}
Future<void> dispos() async {
courseDao.deleteAllCourses();
}
Future<List<Course>> getCourses() async {
List<Map<String, dynamic>> courseMaps = await CourseDao().getCourses();
List<Map<String, dynamic>> courseMaps = await courseDao.getCourses();
List<Course> courses = []; // Course
for (var courseMap in courseMaps) {
@ -88,8 +108,8 @@ class CourseController {
teacher: courseMap['teacher'],
location: courseMap['location'],
remark: courseMap['remark'],
startTime: DateTime.parse(courseMap['start']),
endTime: DateTime.parse(courseMap['end']),
startTime: DateTime.parse(courseMap['startTime']),
endTime: DateTime.parse(courseMap['endTime']),
);
courses.add(course);
}
@ -98,19 +118,28 @@ class CourseController {
}
Future<int> insertCourse(Course course) async {
return await CourseDao().insertCourse(course);
return await courseDao.insertCourse(course);
}
Future<bool> insertLocalCourse() async {
List<Course> localCourseList = await getCourses();
return await netWorkController.insertCourseList(localCourseList);
}
Future<int> insertCourseList(List<Course> courseList) async {
netWorkController.insertCourseList(courseList);
int result = 0;
for(Course course in courseList){
result += await CourseDao().insertCourse(course);
result += await courseDao.insertCourse(course);
}
return result;
}
Future<int> autoImportCours(int stuid,String passwd,int year, int term) async {
String jsonstr = await netWorkController.getUserCoursejson(stuid, passwd, year, term);
Future<int> autoImportCours(int userId,String passwd,int year, int term) async {
String ? jsonstr = await netWorkController.getUserCoursejson(userId, passwd, year, term);
if(jsonstr == null || jsonstr == ""){
return 0;
}
List<Course> courseList = await getCourseByLogin.dealRawString(jsonstr);
return await insertCourseList(courseList);
}
@ -123,11 +152,13 @@ class CourseController {
Future<int> deleteAllCourses() async {
return await CourseDao().deleteAllCourses();
return await courseDao.deleteAllCourses();
}
Future<int> deleteCourse(int courseId) async {
return await CourseDao().deleteCourseByCourseId(courseId);
netWorkController.deleteCourse(courseId);
return await courseDao.deleteCourseByCourseId(courseId);
}
}

@ -1,134 +1,619 @@
import 'dart:async';
import 'dart:async';
import 'dart:convert';
import 'dart:io';
import "package:http/http.dart" as http;
import 'package:timemanagerapp/entity/Task.dart';
import '../entity/Course.dart';
import '../entity/Course.dart';
import '../entity/FreeTime.dart';
import '../entity/Team.dart';
import '../entity/User.dart';
import '../entity/Work.dart';
import "package:http/http.dart" as http;
class NetWorkController {
// String baseUrl = "http://192.168.111.226:3000/";
// String baseUrl = "http://5902e9v900.zicp.fun:30002/";
String baseUrl = "http://5902e9v900.zicp.fun:3000/";
//--------------------------------------------------
//getUserList
Future<List<User>?> getUserList() async {
final response = await http.get(
Uri.parse(baseUrl+'get_user'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<User> userList = (jsonResponse['data'] as List)
.map((user) => User.fromJson(user as Map<String, dynamic>))
.toList();
return userList;
} else {
print("获取用户列表");
return null;
}
}
Future<User?> login(User user) async {
final response = await http.post(
Uri.parse('http://192.168.33.140:3000/login'),
Uri.parse(baseUrl+'login'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(user.toMap()),
);
if (response.statusCode == 200) {
// 200
final jsonResponse = json.decode(response.body);
print("login response.statusCode = " + jsonResponse[0].toString());
if (jsonResponse['code'] == 200) {
return User.fromJson(jsonResponse['data']['user'][0]);
} else {
print("登录失败");
return null;
}
}
final jsonResponse = json.decode(response.body);
// JSON
return User.fromJson(jsonResponse);
Future<bool> register(User user) async {
final response = await http.post(
Uri.parse(baseUrl+'register'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(user.toMap()),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
// 200
//
return null; //
print("注册失败");
return false;
}
}
Future<http.Response> register(User user) {
return http.post(
Uri.parse('http://192.168.33.140:3000/register'),
//updeateUser
Future<bool> updateUser(User user) async {
final response = await http.post(
Uri.parse(baseUrl+'update_user'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(user.toMap()),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("更新用户信息失败");
return false;
}
}
Future<List<Work>> getSameFreeWork(int teamid) {
List<Work> workList = [];
return Future(() => workList);
//server todo
Future<bool> deleteAllUser() async {
final response = await http.post(
Uri.parse(baseUrl+'deleteUser'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode({}),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("删除所有用户失败");
return false;
}
}
Future<http.Response> getTeamWorkList(int teamId) {
return http.get(
Uri.parse('http://192.168.33.140:3000/get_work').replace(queryParameters: {
'teamId': teamId.toString(),
}),
//--------------------------------------------------
Future<List<Team>?> getMyTeamList(int userId) async {
final response = await http.get(
Uri.parse(baseUrl + 'get_team').replace(queryParameters: {'leaderId': userId.toString()}),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<Team> teamList = (jsonResponse['data'] as List)
.map((team) => Team.fromJson(team as Map<String, dynamic>))
.toList();
return teamList;
} else {
print("获取My团队列表失败");
return null;
}
}
Future<List<Team>?> getAllTeamListByUserId(int userId) async {
final response = await http.get(
Uri.parse(baseUrl + 'get_team').replace(queryParameters: {'userId': userId.toString()}),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<Team> teamList = (jsonResponse['data'] as List)
.map((team) => Team.fromJson(team as Map<String, dynamic>))
.toList();
return teamList;
} else {
print("获取All团队列表ByUserId失败");
return null;
}
}
//getTeamByTeamName
Future<Team?> getTeamByTeamName(String teamName) async {
final response = await http.get(
Uri.parse(baseUrl + 'get_team').replace(queryParameters: {'teamName': teamName}),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<Team> teamList = (jsonResponse['data'] as List)
.map((team) => Team.fromJson(team as Map<String, dynamic>))
.toList();
if(teamList.length > 1) {
print("存在重复团队名");
return null;
}
return teamList[0];
} else {
print("获取团队列表ByTeamName失败");
return null;
}
}
Future<List<Team>> getAllTeamList() async {
final response = await http.get(
Uri.parse(baseUrl + 'get_team'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
);
// List<Work> workList = [];
// return Future(() => workList);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<Team> teamList = (jsonResponse['data'] as List)
.map((team) => Team.fromJson(team as Map<String, dynamic>))
.toList();
return teamList;
} else {
print("获取All团队列表失败");
return [];
}
}
Future<bool> insertTeam(Team team) async {
final response = await http.post(
Uri.parse(baseUrl+'add_team'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(team.toMap()),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("insert team 失败:");
return false;
}
}
Future<List<Team>> getTeamList(int userid) {
List<Team> teamList = [];
return Future(() => teamList);
Future<bool> deleteTeam(int teamId) async {
final response = await http.post(
Uri.parse(baseUrl+'delete_team'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: JsonEncoder().convert({
'teamId':teamId,
}),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("delete team 失败:" + jsonResponse['data'].toString());
return false;
}
}
Future<http.Response> insertTeam(Team team) async {
return http.post(
Uri.parse('http://192.168.33.140:3000/add_team'),
Future<bool> updateTeam(Team team) async {
final response = await http.post(
Uri.parse(baseUrl+'update_team'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(team.toMap()),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
return false;
}
}
Future<http.Response> deleteTeam(int teamId) async {
return http.post(
Uri.parse('http://192.168.33.140:3000/delete_team'),
//--------------------------------------------------
Future<List<User>?> getTeamUserList(int teamId) async {
final response = await http.get(
Uri.parse(baseUrl + 'get_team_member').replace(queryParameters: {'teamId': teamId.toString()}),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<User> teamUserList = (jsonResponse['data'] as List)
.map((user) => User.fromJson(user as Map<String, dynamic>))
.toList();
return teamUserList;
} else {
return [];
}
}
Future<bool> insertTeamUser(int id,int teamId, String userName) async {
final response = await http.post(
Uri.parse(baseUrl+'add_team_member'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: JsonEncoder().convert({
'id': id,
'teamId': teamId,
'userName': userName,
}),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
return false;
}
}
Future<http.Response> updateTeam(Team team) async {
return http.post(
Uri.parse('http://192.168.33.140:3000/update_team'),
Future<bool> deleteTeamUser(int teamId, int userId) async {
final response = await http.post(
Uri.parse(baseUrl+'delete_team_member'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: JsonEncoder().convert({
'teamId': teamId,
'userId': userId,
}),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("delete team user 失败:");
return false;
}
}
//--------------------------------------------------
Future<List<Work>?> getTeamWorkList(int teamId) async {
final response = await http.get(
Uri.parse(baseUrl + 'get_work').replace(queryParameters: {'teamId': teamId.toString()}),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<Work> teamWorkList = (jsonResponse['data'] as List)
.map((work) => Work.fromJson(work as Map<String, dynamic>))
.toList();
return teamWorkList;
} else {
return null;
}
}
//work
Future<List<Work>?> getALlTeamWorkList() async {
final response = await http.get(
Uri.parse(baseUrl + 'get_work'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(team.toMap()),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<Work> teamWorkList = (jsonResponse['data'] as List)
.map((work) => Work.fromJson(work as Map<String, dynamic>))
.toList();
return teamWorkList;
} else {
return null;
}
}
Future<List<User>> getTeamUserList(int teamid) async {
List<User> userList = [];
return userList;
Future<bool> insertTeamWork(List<Work> workList) async {
final response = await http.post(
Uri.parse(baseUrl+'add_work'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
//Mpajson
body: JsonEncoder().convert(
workList.map((work) => work.toMap()).toList(),
)
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("TeamWork插入失败");
print("body:"+ workList.map((work) => work.toMap()).toList().toString());
return false;
}
}
Future<bool> insertTeamUser(int teamid, int userid) async {
return true;
Future<bool> deleteTeamWork(workId) async {
final response = await http.post(
Uri.parse(baseUrl+'delete_work'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: JsonEncoder().convert({
'workId': workId, //
}),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
return false;
}
}
Future<bool> deleteTeamUser(int teamid, int userid) async {
return true;
//server todo
Future<List<FreeTime>?> getFreeTime(int teamid) async {
final response = await http.get(
Uri.parse(baseUrl + 'get_freeTime').replace(queryParameters: {'teamId': teamid.toString()}),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<FreeTime> freeTimeList = (jsonResponse['data'] as List)
.map((freeTime) => FreeTime.fromJson(freeTime as Map<String, dynamic>))
.toList();
return freeTimeList;
} else {
print("获取空闲时间失败");
return null;
}
}
//--------------------------------------------------
Future<List<Course>?> getCourseList(int userId) async {
final response = await http.get(
Uri.parse(baseUrl + 'get_course').replace(queryParameters: {'userId': userId.toString()}),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<Course> courseList = (jsonResponse['data'] as List)
.map((course) => Course.fromJson(course as Map<String, dynamic>))
.toList();
return courseList;
} else {
print("获取课程失败");
return null;
}
}
Future<bool> insertCourseList(List<Course> courseList) async {
final response = await http.post(
Uri.parse(baseUrl+'add_course'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(courseList.map((course) => course.toMap()).toList()),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("插入课程失败");
return false;
}
}
//todo
// Future<bool> deleteTeamUser(int teamid,int userid) async {
// return true;
// }
//app,
Future<bool> updateCourse(List<Course> courseList) async {
return true;
final response = await http.post(
Uri.parse(baseUrl+'update_course'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(courseList.map((course) => course.toMap()).toList()),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("更新课程失败");
return false;
}
}
Future<bool> updateTask(List<Work> workList) async {
return true;
Future<bool> deleteCourse(courseId) async {
final response = await http.post(
Uri.parse(baseUrl+'delete_course'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode({'courseId': courseId}),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("删除课程失败");
return false;
}
}
//--------------------------------------------------
Future<List<Task>?> getTaskList(int userId) async {
final response = await http.get(
Uri.parse(baseUrl + 'get_task').replace(queryParameters: {'userId': userId.toString()}),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
List<Task> taskList = (jsonResponse['data'] as List)
.map((task) => Task.fromJson(task as Map<String, dynamic>))
.toList();
return taskList;
} else {
print("获取个人计划失败");
return null;
}
}
Future<String> getUserCoursejson(
int stuid, String passwd, int year, int term) {
String res = "";
return Future(() => res);
Future<bool> updateTask(List<Work> taskList) async {
final response = await http.post(
Uri.parse(baseUrl+'update_task'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(taskList.map((work) => work.toMap()).toList()),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("更新个人计划失败");
return false;
}
}
Future<bool> insertTask(List<Task> taskList) async {
final response = await http.post(
Uri.parse(baseUrl+'add_task'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode(taskList.map((task) => task.toMap()).toList()),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("插入个人计划失败");
return false;
}
}
Future<bool> deleteTask(taskId) async {
final response = await http.post(
Uri.parse(baseUrl+'delete_task'),
headers: <String, String>{
'Content-Type': 'application/json; charset=UTF-8',
},
body: jsonEncode({'taskId': taskId}),
);
final jsonResponse = json.decode(response.body);
if (jsonResponse['code'] == 200) {
return true;
} else {
print("删除个人计划失败");
return false;
}
}
//--------------------------------------------------
Future<String ?> getUserCoursejson(int userId, String passwd, int year, int term) async {
final response = await http.get(
Uri.parse(baseUrl+'get_all_course').replace(queryParameters: {
'userId': userId.toString(),
'passwd': passwd,
'year': year.toString(),
'term': term.toString(),
}),
);
final jsonResponse = json.decode(response.body);
//res
String resJson = jsonResponse['data'];
//res
//
String jsonString = resJson;
//
jsonString = jsonString.trim().replaceAll(RegExp(r"^\{|\}$"), '');
// 使 JSON
jsonString = jsonString.replaceAll(RegExp(r"'"), '"');
// JSON
Map<String, dynamic> data = Map<String, dynamic>.from(json.decode('{$jsonString}'));
if(data['code'] == 1000){
return resJson;
}else{
print("获取导入课程失败");
return null;
}
}
Future<String> getText() async{
final response=await http.get(Uri.parse("https://api.xygeng.cn/one"));
final jsonResponse = json.decode(response.body);
String content=jsonResponse['data']['content'];
print(content);
return content;
}
}

@ -7,10 +7,11 @@ import '../util/dataUtil.dart';
import 'NetWorkController.dart';
class TaskController {
IdGenerator idGenerator = IdGenerator();
List<Task> taskList = []; //courseList
NetWorkController netWorkController = NetWorkController();
late TaskDao taskDao;
static IdGenerator idGenerator = IdGenerator();
static List<Task> taskList = []; //taskList
static NetWorkController netWorkController = NetWorkController();
static late TaskDao taskDao;
DateTime termstartdate = Setting.startdate; //Setting.getStartDate();
@ -18,6 +19,23 @@ class TaskController {
taskDao = TaskDao();
}
Future<List<Task>> init() async {
var res = await netWorkController.getTaskList(Setting.user!.getId!);
if(res == null || res.length == 0){
taskList = [];
}else{
taskList = res;
}
for(Task task in taskList){
await taskDao.insertTask(task);
}
return taskList;
}
Future<void> dispos() async {
taskDao.deleteAllTasks();
}
Future<List<Task>> getTasks() async {
List<Map<String, dynamic>> taskMaps = await taskDao.getTasks();
List<Task> tasks = []; // Task
@ -57,7 +75,6 @@ class TaskController {
hours: scheduleForm.getEndTime.hour,
minutes: scheduleForm.getEndTime.minute,
));
int taskId = await idGenerator.generateId();
Task task = Task(
id: await idGenerator.generateId(),
name: scheduleForm.getName,
@ -69,16 +86,18 @@ class TaskController {
);
taskListToInsert.add(task);
}
await insertTaskList(taskListToInsert);
}
await insertTaskList(taskListToInsert);
}
Future<int> insertTask(Task task) async {
netWorkController.insertTask([task]);
return await taskDao.insertTask(task);
}
Future<int> insertTaskList(List<Task> taskList) async {
netWorkController.insertTask(taskList);
int result = 0;
for (Task task in taskList) {
result += await taskDao.insertTask(task);
@ -91,11 +110,13 @@ class TaskController {
return await taskDao.deleteTaskByid(id);
}
Future<int> deleteTaskByTaskid(int taskid) async {
return await taskDao.deleteTaskByTaskid(taskid);
Future<int> deleteTaskByTaskid(int taskId) async {
netWorkController.deleteTask(taskId);
return await taskDao.deleteTaskByTaskid(taskId);
}
Future<int> deleteAllTasks() async {
// netWorkController.deleteTask(taskId);
return await taskDao.deleteAllTasks();
}

@ -1,88 +1,269 @@
import 'package:http/src/response.dart';
import 'package:timemanagerapp/controller/NetWorkController.dart';
import 'package:timemanagerapp/entity/User.dart';
import '../entity/FreeTime.dart';
import '../entity/ScheduleForm.dart';
import '../entity/Team.dart';
import '../entity/Work.dart';
import 'package:timemanagerapp/database/dao/TeamDao.dart';
import 'package:timemanagerapp/database/dao/WorkDao.dart';
import '../setting/Setting.dart';
import '../util/dataUtil.dart';
class TeamController {
late int leaderid;
List<Team> teamList = []; //teamList
Map<int, List<Work>> Wordmaplist = {};
NetWorkController netWorkController = NetWorkController();
static List<Team> allTeamList = []; //allTeamList
static List<Team> myTeamList = []; //myTeamList
static List<Team> joindedTeamList = []; //teamList
static List<Work> workList = []; //workList
static Map<int,Work> worKIdMap = {};
static Map<int,Team> teamIdMap = {};
static Map<int,List<Work>> woroListMapByTeamId = {};
static Map<int,List<User>> userListMapByTeamId = {};
static NetWorkController netWorkController = NetWorkController();
static IdGenerator idGenerator = IdGenerator();
DateTime termstartdate = Setting.startdate; //Setting.getStartDate();
TeamController() { //leaderidid
this.leaderid = Setting.user!.getId!;
//TODO: leaderidteamList
//TODO: leaderidmyTeamList
for (var team in teamList) {
for (var team in myTeamList) {
//TODO: team.idWorklist[team.id]
//Wordmaplist[team.id].add()
}
}
Future<List<Team>> getTeams(int userid) async {
return await netWorkController.getTeamList(userid);
}
Future<bool> createTeam(Team team) async {
return true;
//-----------------------------------Team-------------------------------
// Future<void> deleteAllTeams() async {
// await netWorkController.deleteAllTeams();
// }
Future<List<Team>> getMyTeamList() async {
//
myTeamList = [];
List<Team>? res = await netWorkController.getMyTeamList(Setting.user!.getId!);
if(res==null){
return [];
}else{
// teamIdMap = {};
// for(Team team in res){
// teamIdMap[team.id!] = team;
// }
myTeamList = res;
return res;
}
}
Future<void> insertTeamList(List<Team> teamList) async {
for (Team team in teamList) {
await TeamDao().insertTeam(team);
Future<List<Team>> getJoinedTeamList() async {
if(myTeamList.length==0){
await getMyTeamList();
}
//
joindedTeamList = [];
allTeamList = [];
List<Team>? res = await netWorkController.getAllTeamListByUserId(Setting.user!.getId!);
if(res==null){
return [];
}else{
allTeamList = res;
teamIdMap = {};
for(Team team in allTeamList){
teamIdMap[team.id!] = team;
}
joindedTeamList.addAll(allTeamList); //=
for(Team team in myTeamList){
// myTeamList
joindedTeamList.removeWhere((element) => element.id == team.id);
}
return joindedTeamList;
}
}
Future<void> deleteAllTeams() async {
await TeamDao().deleteAllTeams();
// Future<void> insertTeamList(List<Team> myTeamList) async {
// for (Team team in myTeamList) {
// await netWorkController.insertTeam(team);
// }
// }
Future<bool> deleteTeam(Team team) async {
// List<User> memberList = await getTeamUserList(team.getId!); //
// for(User user in memberList){
// deleteTeamUser(team, user.getId!);
// }
return await netWorkController.deleteTeam(team.getId!);
}
Future<bool> deleteTeam(int teamid) async {
Future<bool> insertTeam(Team team) async {
team.id = await idGenerator.generateId();
bool res = await netWorkController.insertTeam(team);
print("insertTeam: $res");
if(res == false) return false;
//
int id = await idGenerator.generateId();
await netWorkController.insertTeamUser(id,team.id!, Setting.user!.getUsername!);
return true;
}
Future<Response> updateTeam(Team team) async {
//joinTeam
Future<bool> joinTeam(String teamName) async {
//
for(Team team in allTeamList){
if(team.getTeamName == teamName){
return false;
}
}
Team ? team = await netWorkController.getTeamByTeamName(teamName);
if(team == null){
return false;
}
int id = await idGenerator.generateId();
return await netWorkController.insertTeamUser(id,team!.getId!, Setting.user!.getUsername!);
}
Future<bool> updateTeam(Team team) async {
return await netWorkController.updateTeam(team);
}
Future<void> insertWork(Work work) async {
// return await netWorkController.insertWork(work);
//------------------------------------TeamUser-------------------------------------
Future<List<User>> getTeamUserList(int teamid) async {
List<User>? res = await netWorkController.getTeamUserList(teamid);
if(res == null){
return [];
}else{
List<User> tmp = [];
for(User user in res){
if(user.getId != Setting.user!.getId!){ //
tmp.add(user);
}
}
res = tmp;
userListMapByTeamId[teamid] = res;
return res;
}
}
Future<bool> insertTeamUser(int teamid, String membername) async {
if(membername == Setting.user!.getUsername){//
return false;
}
int id = await idGenerator.generateId();
return await netWorkController.insertTeamUser(id,teamid, membername);
}
Future<void> insertWorkList(List<Work> workList) async {
for (Work work in workList) {
await WorkDao().insertWork(work);
Future<bool> deleteTeamUser(Team team, int userId) async {
if(team.getLeaderId == userId){
return await deleteTeam(team);
}else{
return await netWorkController.deleteTeamUser(team.getId!, userId);
}
}
Future<void> deleteAllWorks() async {
await WorkDao().deleteAllWorks();
//---------------------------Work----------------------
Future<List<Work>> getWorks() async {
workList = [];
// myTeamList = [];
// joindedTeamList = [];
// myTeamList = await getMyTeamList();
// joindedTeamList = await getJoinedTeamList();
// allTeamList = myTeamList + joindedTeamList;
var res = await getJoinedTeamList(); //team,
if(res == null) {
return [];
}
for(Team team in allTeamList){
workList.addAll(await getWorksByTeamId(team.id));
}
return workList;
}
Future<void> deleteWork(int id) async {
await WorkDao().deleteWorkByid(id);
Future<List<Work>> getWorksByTeamId(teamId) async {
var res = await netWorkController.getTeamWorkList(teamId);
if(res == null){
return [];
}else{
woroListMapByTeamId[teamId] = [];
for(int index = 0; index < res.length; index++){
res[index].teamName = teamIdMap[teamId]!.getTeamName;
woroListMapByTeamId[teamId]!.add(res[index]);
}
return res;
}
}
Future<void> updateWork(Work work) async {
await WorkDao().updateWork(work);
//addscheduleForm
Future<void> addScheduleForm(ScheduleForm scheduleForm,int teamId) async {
List<Work> WorkListToInsert = [];
int allWorkId = await idGenerator.generateId();
for (int week = scheduleForm.getStartWeek; week <= scheduleForm.getEndWeek; week++) {
for (int day in scheduleForm.selectedDays) {
//
final startDate = termstartdate.add(Duration(
days: (7 * (week - 1) + day! - 1),
hours: scheduleForm.getStartTime.hour,
minutes: scheduleForm.getStartTime.minute
));
final endDate = termstartdate.add(Duration(
days: (7 * (week - 1) + day! - 1),
hours: scheduleForm.getEndTime.hour,
minutes: scheduleForm.getEndTime.minute,
));
Work work = Work(
id: await idGenerator.generateId(),
name: scheduleForm.getName,
workId: allWorkId,
userId: Setting.user!.getId!,
status: "未完成",
content: scheduleForm.getContent,
teamId: teamId,
endTime: endDate,
startTime: startDate,
);
WorkListToInsert.add(work);
}
}
await insertWorkList(WorkListToInsert);
}
Future<List<Map<String, dynamic>>> getWorks() async {
return WorkDao().getWorks();
//
// Future<bool> insertWork(Work work) async {
// return await netWorkController.insertTeamWork(work);
// }
Future<void> insertWorkList(List<Work> workList) async {
// for (Work work in workList) {
await netWorkController.insertTeamWork(workList);
// }
}
Future<List<Map<String, dynamic>>> getWorksByTeamid(int teamid) async {
return WorkDao().getWorksByTeamid(teamid);
// Future<void> deleteAllWorks() async {
// await netWorkController.deleteAllWorks();
// }
Future<void> deleteWorkByWorkId(int workId) async {
await netWorkController.deleteTeamWork(workId);
}
Future<List<Work>> getSameFreeWork(int teamid){
return netWorkController.getSameFreeWork(teamid);
// Future<void> updateWork(Work work) async {
// await netWorkController.u(work);
// }
Future<List<FreeTime>> getFreeTime(int teamid)async{
var res = await netWorkController.getFreeTime(teamid);
if(res == null){
return [];
}else{
return res;
}
}

@ -1,15 +1,33 @@
import 'dart:ui';
import 'package:timemanagerapp/entity/Course.dart';
import 'package:timemanagerapp/entity/FreeTime.dart';
import 'package:timemanagerapp/setting/Setting.dart';
class TimetableWidgetController {
final double pixelToMinuteRatio =
0.9 * Setting.pixelToMinuteRatio_ratio; //old:0.9
late List<Course> courseList;
late DateTime mondayTime;
late int weekCount;
late DateTime termStartDate;
static late DateTime mondayTime = getmondayTime();
static late int weekCount = getWeekCount();
static late DateTime termStartDate = Setting.startdate;
static List<DateTime> timePoints = [
DateTime(2023, 9, 22, 7, 00),
DateTime(2023, 9, 22, 7, 30),
DateTime(2023, 9, 22, 8, 0), // 8:00 AM
DateTime(2023, 9, 22, 9, 35), // 8:15 PM
DateTime(2023, 9, 22, 10, 5),
DateTime(2023, 9, 22, 11, 40),
DateTime(2023, 9, 22, 12, 30),
DateTime(2023, 9, 22, 13, 30),
DateTime(2023, 9, 22, 15, 5), // 8:00 AM
DateTime(2023, 9, 22, 15, 35), // 12:30 PM
DateTime(2023, 9, 22, 17, 10),
DateTime(2023, 9, 22, 18, 30),
DateTime(2023, 9, 22, 19, 15), // 8:00 AM
DateTime(2023, 9, 22, 20, 5), // 12:30 PM
DateTime(2023, 9, 22, 20, 55),
DateTime(2023, 9, 22, 21, 40),
DateTime(2023, 9, 22, 23, 00),
];
TimetableWidgetController() {
mondayTime = getmondayTime();
@ -23,27 +41,85 @@ class TimetableWidgetController {
}
//piexl
List<Offset> convertTimeList(List<DateTime> timePoints, double deviceWidth) {
static List<Offset> convertTimeList(List<DateTime> timePoints) {
print("deviceWidth: ${Setting.deviceWidth.toString()}");
List<Offset> convertedTimes = [];
for (var time in timePoints) {
int hour = time.hour;
int minute = time.minute;
int totalMinutes = (hour - 7) * 60 + minute;
double convertedTime = totalMinutes * pixelToMinuteRatio;
convertedTimes.add(Offset(deviceWidth * 0.015, convertedTime));
double convertedTime = totalMinutes * Setting.pixelToMinuteRatio_ratio;
convertedTimes.add(Offset(Setting.deviceWidth * 0.015, convertedTime));
}
// print("convertedTimesOffset: $convertedTimes");
return convertedTimes;
}
int getWeekCount() {
weekCount = DateTime.now().difference(termStartDate).inDays ~/ 7 + 1;
//
List<FreeTime> repairFreeTimeBlockList(List freeTimeBlockList) {
List<FreeTime> repairedFreeTimeBlockList = [];
DateTime termStartDate = Setting.startdate;
DateTime termEndDate = termStartDate.add(Duration(days: 7 * Setting.termAllWeekCout));
//termEndDate23:00:00
termEndDate = DateTime(termEndDate.year, termEndDate.month, termEndDate.day, 23, 00, 00);
Set<DateTime> freeTimeBlockSet = {}; //,
for (var freeTimeBlock in freeTimeBlockList) {
//,
//
bool keepFlag = true;
if(freeTimeBlock.startTime.isBefore(termStartDate)){
keepFlag = false;
}
if(freeTimeBlock.endTime.isAfter(termEndDate)){
keepFlag = false;
}
if (freeTimeBlock.startTime.hour < 7) {
keepFlag = false;
}
if (freeTimeBlock.endTime.hour > 23) {
keepFlag = false;
}
// if(freeTimeBlock.startTime.compareTo(freeTimeBlock.endTime)==0){ //
// keepFlag = false; //,,freeTimeBlockSet,
// freeTimeBlockSet.add(DateTime(freeTimeBlock.startTime.year, freeTimeBlock.startTime.month, freeTimeBlock.startTime.day));
// }
if(keepFlag){
freeTimeBlockSet.add(DateTime(freeTimeBlock.startTime.year, freeTimeBlock.startTime.month, freeTimeBlock.startTime.day));
repairedFreeTimeBlockList.add(freeTimeBlock);
}else{
freeTimeBlockList.remove(freeTimeBlock);
}
}
//
for(var date = termStartDate; date.isBefore(termEndDate); date = date.add(Duration(days: 1))){
date = DateTime(date.year, date.month, date.day);
if(freeTimeBlockSet.contains(date)){
//,
continue;
}
DateTime startTime = DateTime(date.year, date.month, date.day, 7, 0);
DateTime endTime = DateTime(date.year, date.month, date.day, 23, 0);
FreeTime freeTime = FreeTime(startTime: startTime, endTime: endTime);
repairedFreeTimeBlockList.add(freeTime);
}
return repairedFreeTimeBlockList;
}
static int getWeekCount({DateTime ? dateTime}) {
dateTime ??= DateTime.now();
weekCount = dateTime.difference(termStartDate).inDays ~/ 7 + 1;
return weekCount;
}
DateTime getmondayTime() {
static DateTime getmondayTime() {
mondayTime = DateTime.now();
print("获取mondayTime: $mondayTime");
//
while (mondayTime.weekday != 1) {
mondayTime = mondayTime.subtract(Duration(days: 1));
@ -51,7 +127,37 @@ class TimetableWidgetController {
return mondayTime;
}
Map<int, List> transformCourseMap(List blockList) {
static List<String> getSelectDayList(DateTime date) {
List<String> selectedDayList = [];
//dataselectedDayList
int day = date.weekday;
switch (day) {
case 1:
selectedDayList.add("周一");
break;
case 2:
selectedDayList.add("周二");
break;
case 3:
selectedDayList.add("周三");
break;
case 4:
selectedDayList.add("周四");
break;
case 5:
selectedDayList.add("周五");
break;
case 6:
selectedDayList.add("周六");
break;
case 7:
selectedDayList.add("周日");
break;
}
return selectedDayList;
}
Map<int, List> transformTimeBlockMap(List blockList) {
Map<int, List> timeblockMap = {};
for (var timeBlock in blockList) {
int weekCount = timeBlock.startTime.difference(termStartDate).inDays ~/ 7 + 1; //
@ -65,23 +171,24 @@ class TimetableWidgetController {
}
//x
var weekListPixel=[0,Setting.deviceWidth*0.12,Setting.deviceWidth*0.24,Setting.deviceWidth*0.36,Setting.deviceWidth*0.48,Setting.deviceWidth*0.60,Setting.deviceWidth*0.72];
var weekListPixel=[0,0.12,0.24,0.36,0.48,0.60,0.72];
// Course(this.name, this.teacher, this.location, this.startTime, this.endTime);
double getdy(timeBlock)
{
double y=(((timeBlock.startTime.hour-7)*60+timeBlock.startTime.minute)*0.9)*Setting.pixelToMinuteRatio_ratio;
//9
double y=((timeBlock.startTime.hour-7)*60+timeBlock.startTime.minute)*Setting.pixelToMinuteRatio_ratio + 9;
return y;
}
double getdx(timeBlock)
{
int x=timeBlock.startTime.weekday-1;
return weekListPixel[x].toDouble();
return Setting.deviceWidth*weekListPixel[x].toDouble();
}
double getHeight(timeBlock){
return (((timeBlock.endTime.hour-7)*60+timeBlock.endTime.minute)*0.9-this.getdy(timeBlock))*Setting.pixelToMinuteRatio_ratio;
return ((timeBlock.endTime.hour*60+timeBlock.endTime.minute)-(timeBlock.startTime.hour*60+timeBlock.startTime.minute))*Setting.pixelToMinuteRatio_ratio;
}
}

@ -2,54 +2,104 @@ import 'package:timemanagerapp/database/dao/UserDao.dart';
import 'package:timemanagerapp/database/MyDatebase.dart';
import 'package:timemanagerapp/entity/User.dart';
import '../provider/TimeProvider.dart';
import '../setting/Setting.dart';
import '../util/dataUtil.dart';
import 'CourseController.dart';
import 'NetWorkController.dart';
import 'TaskController.dart';
/**
*
*/
class UserController {
NetWorkController netWorkController = NetWorkController();
IdGenerator idGenerator = IdGenerator();
static NetWorkController netWorkController = NetWorkController();
static IdGenerator idGenerator = IdGenerator();
//
static UserController getInstance() {
return new UserController();
}
Future<List<Map<String, dynamic>>> getUsers() async {
return await UserDao.getInstance().getUsers();
//getUserList
Future<List<User>> getUserList() async {
List<User>? res = await netWorkController.getUserList();
if(res==null){
return [];
}else{
return res;
}
}
Future<bool> login(User user) async {
Future<bool> login(User login_user) async {
//todo:
// int userid = await netWorkController.login(user);
User ?user = await netWorkController.login(login_user);
//
int userid = Setting.user!.getId!;
if(userid == -1){
// int userid = Setting.user!.getId!;
if(user == null){
return false;
}
user.id = userid;
await Setting.saveUser(user);
//
if(Setting.initFlag) {
//
await MyDatabase.reBuildDatabase();
print('从服务器初始化');
await CourseController().init();
await TaskController().init();
await Setting.saveInitFlag(false);
}
return true;
}
Future<bool> register(User user) async {
Future<bool> register(User postUser) async {
//todo:
// int userid = await netWorkController.login(user);
//
int userid = await idGenerator.generateId();
print("userid生成:"+userid.toString());
if(userid == -1){
postUser.id = userid;
bool res = await netWorkController.register(postUser);
//
if(!res){
print('注册失败');
return false;
}
user.id = userid;
await Setting.saveUser(user);
//
// await Setting.saveUser(postUser);
//todo:
return true;
}
//updateUser
Future<bool> updateUser(User postUser) async {
bool res = await netWorkController.updateUser(postUser);
if( !res ){
return false;
}else{
await Setting.saveUser(postUser);
return true;
}
}
// //
// Future<bool> deleteUser(User postUser) async {
// //todo:
// int userid = await idGenerator.generateId();
// postUser.id = userid;
// bool res = await netWorkController.register(postUser);
// //
// if(!res){
// print('注册失败');
// return false;
// }
// //
// // await Setting.saveUser(postUser);
// //todo:
// return true;
// }
Future<void> insertUser(User user) async {
await UserDao.getInstance().insertUser(user);
}

@ -1,106 +1,133 @@
import 'package:timemanagerapp/entity/ScheduleForm.dart';
import '../database/dao/WorkDao.dart';
import '../entity/Work.dart';
import '../setting/Setting.dart';
import '../util/dataUtil.dart';
import 'NetWorkController.dart';
class WorkController {
IdGenerator idGenerator = IdGenerator();
List<Work> WorkList = []; //courseList
NetWorkController netWorkController = NetWorkController();
DateTime termstartdate = Setting.startdate; //Setting.getStartDate();
Future<List<Work>> getWorks() async {
//todo http
// List<Map<String, dynamic>> WorkMaps = await WorkDao().getWorks();
// List<Work> Works = []; // Work
//
// for (var WorkMap in WorkMaps) {
// // 使WorkMapWork
// Work work = Work(
// id: WorkMap['id'],
// userId: WorkMap['userId'],
// content: WorkMap['content'],
// WorkId: WorkMap['WorkId'],
// name: WorkMap['name'],
// startTime: DateTime.parse(WorkMap['startTime']),
// endTime: DateTime.parse(WorkMap['endTime']),
// );
// Works.add(Work);
// }
// WorkList = Works; // Work
return WorkList;
}
//addscheduleForm
Future<void> addScheduleForm(ScheduleForm scheduleForm,int teamId) async {
List<Work> WorkListToInsert = [];
int allWorkId = await idGenerator.generateId();
for (int week = scheduleForm.getStartWeek; week <= scheduleForm.getEndWeek; week++) {
for (int day in scheduleForm.selectedDays) {
//
final startDate = termstartdate.add(Duration(
days: (7 * (week - 1) + day! - 1),
hours: scheduleForm.getStartTime.hour,
minutes: scheduleForm.getStartTime.minute
));
final endDate = termstartdate.add(Duration(
days: (7 * (week - 1) + day! - 1),
hours: scheduleForm.getEndTime.hour,
minutes: scheduleForm.getEndTime.minute,
));
Work work = Work(
id: await idGenerator.generateId(),
name: scheduleForm.getName,
workId: allWorkId,
userId: Setting.user!.getId!,
status: "未完成",
content: scheduleForm.getContent,
teamId: teamId,
functionaryId: 0, //???
endTime: endDate,
startTime: startDate,
);
WorkListToInsert.add(work);
}
await insertWorkList(WorkListToInsert);
}
}
// Future<int> insertWork(Work Work) async {
// return await WorkDao().insertWork(Work);
// }
//
Future<int> insertWorkList(List<Work> WorkList) async {
int result = 0;
// for (Work Work in WorkList) {
// result += await WorkDao().insertWork(Work);
// }
return result;
}
//
// //delete
// Future<int> deleteWorkByid(int id) async {
// return await WorkDao().deleteWorkByid(id);
// }
//
// Future<int> deleteWorkByWorkid(int Workid) async {
// return await WorkDao().deleteWorkByWorkid(Workid);
// }
//
// Future<int> deleteAllWorks() async {
// return await WorkDao().deleteAllWorks();
// }
//
// //update
// Future<int> updateWork(Work Work) async {
// return await WorkDao().updateWork(Work);
// }
}
// import 'package:timemanagerapp/entity/ScheduleForm.dart';
//
// import '../database/dao/WorkDao.dart';
// import '../entity/Work.dart';
// import '../setting/Setting.dart';
// import '../util/dataUtil.dart';
// import 'NetWorkController.dart';
//
// class WorkController {
// static IdGenerator idGenerator = IdGenerator();
// static List<Work> WorkList = []; //courseList
// static NetWorkController netWorkController = NetWorkController();
//
// DateTime termstartdate = Setting.startdate; //Setting.getStartDate();
//
// Future<List<Work>> getWorks() async {
// //todo http
// List<Map<String, dynamic>> workMaps = await WorkDao().getWorks();
// List<Work> Works = []; // Work
//
// for (var workMap in workMaps) {
// // 使WorkMapWork
// Work work = Work(
// id: workMap['id'],
// userId: workMap['userId'],
// content: workMap['content'],
// workId: workMap['workId'],
// name: workMap['name'],
// startTime: DateTime.parse(workMap['startTime']),
// endTime: DateTime.parse(workMap['endTime']),
// status: workMap['status'],
// teamId: workMap['teamId'],
// );
// Works.add(work);
// }
// WorkList = Works; // Work
// return WorkList;
// }
//
// //addscheduleForm
// Future<void> addScheduleForm(ScheduleForm scheduleForm,int teamId) async {
// List<Work> WorkListToInsert = [];
// int allWorkId = await idGenerator.generateId();
// for (int week = scheduleForm.getStartWeek; week <= scheduleForm.getEndWeek; week++) {
// for (int day in scheduleForm.selectedDays) {
// //
// final startDate = termstartdate.add(Duration(
// days: (7 * (week - 1) + day! - 1),
// hours: scheduleForm.getStartTime.hour,
// minutes: scheduleForm.getStartTime.minute
// ));
//
// final endDate = termstartdate.add(Duration(
// days: (7 * (week - 1) + day! - 1),
// hours: scheduleForm.getEndTime.hour,
// minutes: scheduleForm.getEndTime.minute,
// ));
// Work work = Work(
// id: await idGenerator.generateId(),
// name: scheduleForm.getName,
// workId: allWorkId,
// userId: Setting.user!.getId!,
// status: "未完成",
// content: scheduleForm.getContent,
// teamId: teamId,
// endTime: endDate,
// startTime: startDate,
// );
// WorkListToInsert.add(work);
// }
// }
// await insertWorkList(WorkListToInsert);
// }
//
// Future<int> insertWork(Work Work) async {
// return await WorkDao().insertWork(Work);
// }
//
// Future<int> insertWorkList(List<Work> workList) async {
// int result = 0;
// for (Work work in workList) {
// result += await WorkDao().insertWork(work);
// }
// return result;
// }
//
// //仿Taskwork
// //query
// Future<List<Work>> getWorkList() async {
// List<Map<String, dynamic>> workMaps = await WorkDao().getWorks();
// List<Work> workList = []; // Work
//
// for (var workMap in workMaps) {
// // 使WorkMapWork
// Work work = Work(
// id: workMap['id'],
// userId: workMap['userId'],
// content: workMap['content'],
// workId: workMap['workId'],
// name: workMap['name'],
// startTime: DateTime.parse(workMap['startTime']),
// endTime: DateTime.parse(workMap['endTime']),
// status: workMap['status'],
// teamId: workMap['teamId'],
// );
// workList.add(work);
// }
// WorkList = workList; // Work
// return WorkList;
// }
//
// // //delete 仿Task
// // Future<int> deleteWorkByid(int id) async{
// // return await WorkDao().deleteWorkByid(id);
// // }
//
//
// Future<int> deleteWorkByWorkid(int workid) async {
// return await WorkDao().deleteWorkByWorkid(workid);
// }
//
// Future<int> deleteAllWorks() async {
// return await WorkDao().deleteAllWorks();
// }
//
// //update
// Future<int> updateWork(Work work) async {
// return await WorkDao().updateWork(work);
// }
//
//
//
// }

@ -18,8 +18,7 @@ class MyDatabase {
await openDatabase(path, version: 1, onCreate: _createTables);
//
// await _dropAllTables(database);
// await dropAllTables(database);
//
await _createTables(database, 1);
@ -27,6 +26,8 @@ class MyDatabase {
}
static Future<void> _createTables(Database db, int version) async {
// await _createAllTableBySql(db);
print("create table");
//Course
await _createCourseTable(db, version);
// User
@ -39,17 +40,83 @@ class MyDatabase {
await _createTaskTable(db, version);
// Team
await _createTeamTable(db, version);
print("create table success");
}
static Future<void> _createAllTableBySql(Database db) async{
//bug:
await db.execute('''
CREATE TABLE IF NOT EXISTS users(
id BIGINT PRIMARY KEY,
username VARCHAR(255) NOT NULL UNIQUE,
password TEXT NOT NULL,
role BIGINT NOT NULL
);
CREATE TABLE IF NOT EXISTS works (
id BIGINT PRIMARY KEY,
userId BIGINT NOT NULL,
workId BIGINT NOT NULL,
teamId BIGINT NOT NULL,
name TEXT NOT NULL,
content TEXT,
status TEXT,
endTime TEXT NOT NULL,
startTime TEXT NOT NULL
);
CREATE TABLE IF NOT EXISTS clocks (
id BIGINT PRIMARY KEY,
clockId BIGINT NOT NULL,
userId BIGINT NOT NULL,
text TEXT,
img TEXT,
music TEXT
);
CREATE TABLE IF NOT EXISTS tasks (
id BIGINT PRIMARY KEY,
taskId BIGINT NOT NULL,
userId BIGINT NOT NULL,
content TEXT,
name TEXT NOT NULL,
startTime TEXT NOT NULL,
endTime TEXT NOT NULL
);
CREATE TABLE IF NOT EXISTS course(
id BIGINT PRIMARY KEY,
userId BIGINT,
courseId BIGINT NOT NULL,
name TEXT NOT NULL,
credit REAL,
teacher TEXT,
location TEXT,
remark TEXT,
start TEXT NOT NULL,
end TEXT NOT NULL
);
CREATE TABLE IF NOT EXISTS teams (
id BIGINT PRIMARY KEY,
leaderId BIGINT NOT NULL,
teamName TEXT NOT NULL,
maxNumber BIGINT,
introduce TEXT
);
CREATE TABLE IF NOT EXISTS userteams (
id BIGINT PRIMARY KEY,
userId BIGINT NOT NULL,
teamId BIGINT NOT NULL
);
''');
}
static Future<void> _createUserTable(Database db, int version) async {
// User
await db.execute('''
CREATE TABLE IF NOT EXISTS users(
id INTEGER PRIMARY KEY,
username TEXT NOT NULL,
password TEXT NOT NULL,
role INTEGER NOT NULL
id BIGINT PRIMARY KEY,
username VARCHAR(255) NOT NULL,
password TEXT NOT NULL,
role BIGINT NOT NULL
);
''');
// print("userstable create success");
@ -59,13 +126,13 @@ class MyDatabase {
// Work
await db.execute('''
CREATE TABLE IF NOT EXISTS works (
id INTEGER PRIMARY KEY,
userId INTEGER NOT NULL,
workId INTEGER NOT NULL,
teamId INTEGER NOT NULL,
id BIGINT PRIMARY KEY,
userId BIGINT NOT NULL,
workId BIGINT NOT NULL,
teamId BIGINT NOT NULL,
name TEXT NOT NULL,
content TEXT,
status TEXT,
workContent TEXT NOT NULL,
endTime TEXT NOT NULL,
startTime TEXT NOT NULL
);
@ -77,9 +144,9 @@ class MyDatabase {
// Clock
await db.execute('''
CREATE TABLE IF NOT EXISTS clocks (
id INTEGER PRIMARY KEY,
clockId INTEGER NOT NULL,
userId INTEGER NOT NULL,
id BIGINT PRIMARY KEY,
clockId BIGINT NOT NULL,
userId BIGINT NOT NULL,
text TEXT,
img TEXT,
music TEXT
@ -91,9 +158,9 @@ class MyDatabase {
// Task
await db.execute('''
CREATE TABLE IF NOT EXISTS tasks (
id INTEGER PRIMARY KEY,
taskId INTEGER NOT NULL,
userId INTEGER NOT NULL,
id BIGINT PRIMARY KEY,
taskId BIGINT NOT NULL,
userId BIGINT NOT NULL,
content TEXT,
name TEXT NOT NULL,
startTime TEXT NOT NULL,
@ -106,16 +173,16 @@ class MyDatabase {
// Course
await db.execute('''
CREATE TABLE IF NOT EXISTS course(
id INTEGER PRIMARY KEY,
userId INTEGER,
courseId INTEGER NOT NULL,
id BIGINT PRIMARY KEY,
userId BIGINT,
courseId BIGINT NOT NULL,
name TEXT NOT NULL,
credit REAL,
teacher TEXT,
location TEXT,
remark TEXT,
start TEXT NOT NULL,
end TEXT NOT NULL
startTime TEXT NOT NULL,
endTime TEXT NOT NULL
);
''');
}
@ -124,10 +191,10 @@ class MyDatabase {
// Team
await db.execute('''
CREATE TABLE IF NOT EXISTS teams (
id INTEGER PRIMARY KEY,
leaderId INTEGER NOT NULL,
id BIGINT PRIMARY KEY,
leaderId BIGINT NOT NULL,
teamName TEXT NOT NULL,
maxNumber INTEGER,
maxNumber BIGINT,
introduce TEXT
);
''');
@ -136,17 +203,18 @@ class MyDatabase {
static Future<void> _createUserTeamTable(Database db, int version) async {
// userTeam
await db.execute('''
CREATE TABLE IF NOT EXISTS userteams (
id INTEGER PRIMARY KEY,
userId INTEGER NOT NULL,
teamId INTEGER NOT NULL
CREATE TABLE IF NOT EXISTS userteams (
id BIGINT PRIMARY KEY,
userId BIGINT NOT NULL,
teamId BIGINT NOT NULL
);
''');
}
//
static Future<void> _dropAllTables(Database database) async {
static Future<void> dropAllTables(Database database) async {
// SQL
await database.transaction((txn) async {
// 'table1''table2''table3'
await txn.execute('DROP TABLE IF EXISTS users');
@ -158,4 +226,14 @@ class MyDatabase {
await txn.execute('DROP TABLE IF EXISTS userteams');
});
}
static Future<void> reBuildDatabase() async {
final databasePath = await getDatabasesPath();
final path = join(databasePath, 'tma.db');
final database =
await openDatabase(path, version: 1, onCreate: _createTables);
await dropAllTables(database);
await _createTables(database, 1);
}
}

@ -17,7 +17,8 @@ class CourseDao {
Future<List<Map<String, dynamic>>> getCourses() async {
final database = await _database;
if (database != null) {
return database.rawQuery('SELECT * FROM course');
return database.query('course', orderBy: 'id ASC');
// return database.rawQuery('SELECT * FROM course');
} else {
return [];
}
@ -27,14 +28,14 @@ class CourseDao {
final database = await _database;
int result = 0;
if (database != null) {
await database.transaction((txn) async {
//
//!!!
result = await txn.rawInsert('''
INSERT INTO course(userId,courseId,name,credit,teacher,location,remark,start,end)
VALUES(${course.userId},${course.courseId},"${course.name}",${course.credit},"${course.teacher}","${course.location}","${course.remark}","${course.startTime}","${course.endTime}")
''');
});
var tmp = course.toMap();
result += await database.insert('course', course.toMap());
// result = await txn.rawInsert('''
// INSERT INTO course(userId,courseId,name,credit,teacher,location,remark,start,end)
// VALUES(${course.userId},${course.courseId},"${course.name}",${course.credit},"${course.teacher}","${course.location}","${course.remark}","${course.startTime}","${course.endTime}")
// ''');
// print("课程插入 : " + course.toString());
}
return result;
@ -44,16 +45,16 @@ class CourseDao {
final database = await _database;
int result = 0;
if (database != null) {
await database.transaction((txn) async {
result = await txn.rawUpdate('''
UPDATE course SET userId = ${course.userId},courseId = ${course
.courseId},name = "${course.name}",credit = ${course
.credit},teacher = "${course.teacher}",location = "${course
.location}",remark = "${course.remark}",start = "${course
.startTime}",end = "${course.endTime}"
WHERE id = ${course.id}
''');
});
result += await database
.update('course', course.toMap(), where: 'id = ?', whereArgs: [course.id]);
// result = await txn.rawUpdate('''
// UPDATE course SET userId = ${course.userId},courseId = ${course
// .courseId},name = "${course.name}",credit = ${course
// .credit},teacher = "${course.teacher}",location = "${course
// .location}",remark = "${course.remark}",start = "${course
// .startTime}",end = "${course.endTime}"
// WHERE id = ${course.id}
// ''');
}
return result;
}
@ -62,16 +63,17 @@ class CourseDao {
final database = await _database;
int result = 0;
if (database != null) {
await database.transaction((txn) async {
result = await txn.rawUpdate('''
UPDATE course SET userId = ${course.userId},courseId = ${course
.courseId},name = "${course.name}",credit = ${course
.credit},teacher = "${course.teacher}",location = "${course
.location}",remark = "${course.remark}",start = "${course
.startTime}",end = "${course.endTime}"
WHERE courseId = ${course.courseId}
''');
});
result += await database
.update('course', course.toMap(), where: 'courseId = ?', whereArgs: [course.courseId]);
// result = await txn.rawUpdate('''
// UPDATE course SET userId = ${course.userId},courseId = ${course
// .courseId},name = "${course.name}",credit = ${course
// .credit},teacher = "${course.teacher}",location = "${course
// .location}",remark = "${course.remark}",start = "${course
// .startTime}",end = "${course.endTime}"
// WHERE courseId = ${course.courseId}
// ''');
}
return result;
}

@ -16,7 +16,7 @@ class WorkDao {
Future<List<Map<String, dynamic>>> getWorks() async {
final database = await db;
if (database != null) {
return database.query('Work', orderBy: 'id ASC');
return database.query('works', orderBy: 'id ASC');
} else {
return [];
}
@ -25,52 +25,65 @@ class WorkDao {
Future<List<Map<String, dynamic>>> getWorksByTeamid(int teamid) async {
final database = await db;
if (database != null) {
return database.query('Work', where: 'teamid = ?', whereArgs: [teamid], orderBy: 'id ASC');
return database.query('works', where: 'teamId = ?', whereArgs: [teamid], orderBy: 'id ASC');
} else {
return [];
}
}
Future<void> insertWork(Work work) async {
Future<int> insertWork(Work work) async {
final database = await db;
int res = 0;
if (database != null) {
await database.insert('Work', work.toMap());
res += await database.insert('works', work.toMap());
}
return res;
}
Future<void> updateWork(Work work) async {
Future<int> updateWork(Work work) async {
final database = await db;
int res = 0;
if (database != null) {
await database
.update('Work', work.toMap(), where: 'id = ?', whereArgs: [work.id]);
res += await database
.update('works', work.toMap(), where: 'id = ?', whereArgs: [work.id]);
}
return res;
}
Future<void> deleteWorkByid(int id) async {
Future<int> deleteWorkByid(int id) async {
final database = await db;
int res = 0;
if (database != null) {
await database.delete('Work', where: 'id = ?', whereArgs: [id]);
res += await database.delete('works', where: 'id = ?', whereArgs: [id]);
}
return res;
}
Future<void> deleteWorkByWorkid(int workid) async {
Future<int> deleteWorkByWorkid(int workid) async {
final database = await db;
int res = 0;
if (database != null) {
await database.delete('Work', where: 'workid = ?', whereArgs: [workid]);
res += await database.delete('works', where: 'workId = ?', whereArgs: [workid]);
}
return res;
}
Future<void> deleteWorkByTeamid(int teamid) async {
Future<int> deleteWorkByTeamid(int teamid) async {
final database = await db;
int res = 0;
if (database != null) {
await database.delete('Work', where: 'teamid = ?', whereArgs: [teamid]);
res += await database.delete('works', where: 'teamId = ?', whereArgs: [teamid]);
}
return res;
}
Future<void> deleteAllWorks() async {
Future<int> deleteAllWorks() async {
final database = await db;
int res = 0;
if (database != null) {
await database.delete('Work', where: '1=1');
res += await database.delete('works', where: '1=1');
}
return res;
}
}

@ -27,6 +27,7 @@ class Course {
Map<String,dynamic> toMap(){
return {
'id': id,
'userId':userId,
'courseId':courseId,
'name':"$name",
@ -39,7 +40,20 @@ class Course {
};
}
factory Course.fromJson(Map<String, dynamic> course) {
return Course(
id: course['id'],
userId: course['userId'],
courseId: course['courseId'],
name: course['name'],
credit: 1.0*course['credit'],
teacher: course['teacher'],
location: course['location'],
remark: course['remark'],
startTime: DateTime.parse(course['startTime']),
endTime: DateTime.parse(course['endTime']),
);
}
// Getter methods
int? get getId => id;
@ -58,9 +72,9 @@ class Course {
String get getRemark => remark;
DateTime get getstartTime => startTime;
DateTime get getStartTime => startTime;
DateTime get getendTime => endTime;
DateTime get getEndTime => endTime;
// Setter methods
set setId(int newId) {

@ -0,0 +1,83 @@
class FreeTime {
int? id;
int? userId;
String? content;
String? name;
DateTime startTime;
DateTime endTime;
FreeTime({
this.id,
this.userId,
this.content,
this.name,
required this.startTime,
required this.endTime,
});
Map<String, dynamic> toMap() {
return {
'id': id,
'userId': userId,
'content': "$content",
'name': "$name",
'startTime': "${startTime.toIso8601String()}",
'endTime': "${endTime.toIso8601String()}"
};
}
factory FreeTime.fromJson(Map<String, dynamic> task) {
return FreeTime(
// id: task['id'],
// userId: task['userId'],
// content: task['content'],
// name: task['name'],
startTime: DateTime.parse(task['startTime']),
endTime: DateTime.parse(task['endTime']),
);
}
// Getter methods
int? get getId => id;
int? get getUserId => userId;
String? get getContent => content;
String? get getName => name;
DateTime get getStartTime => startTime;
DateTime get getEndTime => endTime;
// Setter methods
set setId(int newId) {
id = newId;
}
set setUserId(int newUserId) {
userId = newUserId;
}
set setContent(String newContent) {
content = newContent;
}
set setName(String newName) {
name = newName;
}
set setStartTime(DateTime newStartTime) {
startTime = newStartTime;
}
set setEndTime(DateTime newEndTime) {
endTime = newEndTime;
}
// toString method
@override
String toString() {
return 'FreeTime(id: $id, userId: $userId, content: $content, name: $name, startTime: $startTime, endTime: $endTime)';
}
}

@ -19,6 +19,7 @@ class Task {
Map<String, dynamic> toMap() {
return {
'id': id,
'userId': userId,
'content': "$content",
'taskId': taskId,
@ -28,6 +29,18 @@ class Task {
};
}
factory Task.fromJson(Map<String, dynamic> task) {
return Task(
id: task['id'],
userId: task['userId'],
content: task['content'],
taskId: task['taskId'],
name: task['name'],
startTime: DateTime.parse(task['startTime']),
endTime: DateTime.parse(task['endTime']),
);
}
// Getter methods
int? get getId => id;

@ -3,12 +3,14 @@ class Team {
int leaderId;
String teamName;
int maxNumber;
String? introduce;
Team({
this.id,
required this.leaderId,
required this.teamName,
required this.maxNumber,
this.introduce
});
Map<String, dynamic> toMap() {
@ -17,9 +19,20 @@ class Team {
'leaderId': leaderId,
'teamName': "$teamName",
'maxNumber': maxNumber,
'introduce': "$introduce"
};
}
factory Team.fromJson(Map<String, dynamic> json) {
return Team(
id: json['id'],
leaderId: json['leaderId'],
teamName: json['teamName'],
maxNumber: json['maxNumber'],
introduce: json['introduce'],
);
}
// Getter methods
int? get getId => id;
@ -29,6 +42,8 @@ class Team {
int get getMaxNumber => maxNumber;
String? get getIntroduce => introduce;
// Setter methods
set setId(int newId) {
id = newId;
@ -46,9 +61,13 @@ class Team {
maxNumber = newMaxNumber;
}
set setIntroduce(String newIntroduce) {
introduce = newIntroduce;
}
// toString method
@override
String toString() {
return 'Team(id: $id, leaderId:$leaderId, teamName:$teamName, maxNumber: $maxNumber)';
return 'Team{id: $id, leaderId: $leaderId, teamName: $teamName, maxNumber: $maxNumber, introduce: $introduce}';
}
}

@ -14,15 +14,13 @@ class User {
Map<String, dynamic> toMap() {
return {
'id': id,
'username': "$username",
'password': "$password",
'role': role,
};
}
factory User.fromJson(Map<String, dynamic> json) {
final data = json['data'];
final user = data['user'][0];
factory User.fromJson(Map<String, dynamic> user) {
return User(
id: user['id'],
username: user['username'],

@ -5,10 +5,10 @@ class Work {
late String content;
late String name;
late int teamId;
late int functionaryId;
late int workId;
late DateTime endTime;
late DateTime startTime;
late String? teamName;
Work({
this.id,
@ -16,8 +16,8 @@ class Work {
required this.status,
required this.content,
required this.teamId,
this.teamName,
required this.name,
required this.functionaryId,
required this.workId,
required this.endTime,
required this.startTime,
@ -25,18 +25,32 @@ class Work {
Map<String, dynamic> toMap() {
return {
'id': id,
'userId': userId,
'status': "$status",
'content': "$content",
'teamId': teamId,
'name': "$name",
'functionaryId': functionaryId,
'workId': workId,
'endTime': "${endTime.toIso8601String()}",
'startTime': "${startTime.toIso8601String()}"
};
}
factory Work.fromJson(Map<String, dynamic> work) {
return Work(
id: work['id'],
userId: work['userId'],
status: work['status'],
content: work['content'],
teamId: work['teamId'],
name: work['name'],
workId: work['workId'],
endTime: DateTime.parse(work['endTime']),
startTime: DateTime.parse(work['startTime']),
);
}
// Getter methods
int? get getId => id;
@ -48,9 +62,9 @@ class Work {
String get getName => name;
int get getTeamId => teamId;
String? get getTeamName => teamName;
int get getFunctionaryId => functionaryId;
int get getTeamId => teamId;
int get getWorkId => workId;
@ -79,12 +93,12 @@ class Work {
teamId = newTeamId;
}
set setName(String newName) {
name = newName;
set setTeamName(String newTeamName) {
teamName = newTeamName;
}
set setFunctionaryId(int newFunctionaryId) {
functionaryId = newFunctionaryId;
set setName(String newName) {
name = newName;
}
set setWorkId(int newWorkId) {
@ -102,6 +116,6 @@ class Work {
// toString method
@override
String toString() {
return 'Work(id: $id, userId:$userId, name:$name, status: $status, content: $content, teamId: $teamId, functionaryId: $functionaryId, workId: $workId, endTime: $endTime, startTime: $startTime)';
return 'Work(id: $id, userId:$userId, name:$name, status: $status, content: $content, teamId: $teamId, workId: $workId, endTime: $endTime, startTime: $startTime)';
}
}

@ -1,6 +1,9 @@
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:timemanagerapp/provider/TeamProvider.dart';
import 'package:timemanagerapp/provider/TeamUserProvider.dart';
import 'package:timemanagerapp/setting/Setting.dart';
import 'package:timemanagerapp/util/MyLogger.dart';
import 'package:timemanagerapp/widgets/HomeWidget.dart';
import 'package:timemanagerapp/provider/TimeProvider.dart';
@ -9,9 +12,10 @@ init() async {
await Setting.init();
}
void main() async {
Future<void> main() async {
await init();
runApp(MyApp());
// Logger();
}
class MyApp extends StatelessWidget {
@ -19,14 +23,25 @@ class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
Setting.deviceWidth = MediaQuery.of(context).size.width;
// print("deviceWidth获取1: ${Setting.deviceWidth}");
return MultiProvider( //Timetable
providers: [
ChangeNotifierProvider(create: (ctx) => TimeProvider()),
ChangeNotifierProvider(create: (ctx) => TeamProvider()),
ChangeNotifierProvider(create: (ctx) => TeamUserProvider()),
],
child: MaterialApp(
home: Scaffold(
body: HomeWidget(),
body: LayoutBuilder(
builder: (context, constraints) {
Setting.deviceWidth = constraints.maxWidth;
// print("deviceWidth获取2: ${Setting.deviceWidth}");
// 使
return HomeWidget();
},
),
),
),
); // MaterialApp

@ -0,0 +1,20 @@
import 'package:flutter/cupertino.dart';
class TeamProvider extends ChangeNotifier {
int _updatTeamCount = 0;
int get updatTeamCount => _updatTeamCount;
set updatTeamCount(int value) {
print("provider手动更新Team表");
_updatTeamCount = value;
notifyListeners();
}
void updatTeame() {
print("provider手动更新Team表");
_updatTeamCount = ~_updatTeamCount;
notifyListeners();
}
}

@ -0,0 +1,20 @@
import 'package:flutter/cupertino.dart';
class TeamUserProvider extends ChangeNotifier {
int _updatTeamUserCount = 0;
int get updatTeameCount => _updatTeamUserCount;
set updatTeameUserCount(int value) {
print("provider手动更新TeamUser表");
_updatTeamUserCount = value;
notifyListeners();
}
void updatTeameUser() {
print("provider手动更新TeamUser表");
_updatTeamUserCount = ~_updatTeamUserCount;
notifyListeners();
}
}

@ -13,7 +13,7 @@ class AddCourseRoute extends StatelessWidget {
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('添加自定义课程'),
title: Text('编辑自定义课程'),
),
body: AddCourseFormWidget(exitCourse: exitCourse),
);

@ -3,18 +3,19 @@ import 'package:flutter/material.dart';
import 'package:timemanagerapp/widgets/AddScheduleFormWidget.dart';
class AddScheduleRoute extends StatelessWidget {
const AddScheduleRoute({Key? key,required this.scheduleType,this.teamId}) : super(key: key);
AddScheduleRoute({Key? key, required this.scheduleType, this.teamId, this.exitSchedule}) : super(key: key);
final String scheduleType;//taskwork
final int? teamId ;
final String scheduleType; //taskwork
final int? teamId;
final exitSchedule;
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('添加自定义个人计划'),
title: scheduleType == 'task' ? Text('编辑个人计划') : Text('编辑团队任务'),
),
body: AddScheduleFormWidget(scheduleType: scheduleType,teamId: teamId),
body: AddScheduleFormWidget(scheduleType: scheduleType, teamId: teamId, exitSchedule: exitSchedule),
);
}
}
}

@ -9,7 +9,7 @@ class AddTeamRoute extends StatelessWidget {
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('添加团队'),
title: Text('编辑团队信息'),
),
body: AddTeamWidget(),
);

@ -1,17 +1,17 @@
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import '../widgets/ManageUserTeamWidget.dart';
class ManageUserTeamRoute extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('团队成员管理'),
),
body: ManageUserTeamWidget(),
);
}
}
// import 'package:flutter/cupertino.dart';
// import 'package:flutter/material.dart';
//
// import '../widgets/ManageUserTeamWidget.dart';
//
// class ManageUserTeamRoute extends StatelessWidget {
//
// @override
// Widget build(BuildContext context) {
// return Scaffold(
// appBar: AppBar(
// title: Text('团队成员管理'),
// ),
// // body: ManageUserTeamWidget(),
// );
// }
// }

Some files were not shown because too many files have changed in this diff Show More

Loading…
Cancel
Save