New views filed with promises

ready for first alpha build
This commit is contained in:
dan63047 2023-06-06 01:21:29 +03:00
parent ca1722e340
commit d69713664f
15 changed files with 205 additions and 35 deletions

View File

@ -44,10 +44,10 @@ android {
defaultConfig { defaultConfig {
// TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
applicationId "com.dan63.tetrastats.tetra_stats" applicationId "com.dan63.tetra_stats"
// You can update the following values to match your application needs. // You can update the following values to match your application needs.
// For more information, see: https://docs.flutter.dev/deployment/android#reviewing-the-gradle-build-configuration. // For more information, see: https://docs.flutter.dev/deployment/android#reviewing-the-gradle-build-configuration.
minSdkVersion flutter.minSdkVersion minSdkVersion 19
targetSdkVersion flutter.targetSdkVersion targetSdkVersion flutter.targetSdkVersion
versionCode flutterVersionCode.toInteger() versionCode flutterVersionCode.toInteger()
versionName flutterVersionName versionName flutterVersionName

View File

@ -1,7 +1,7 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android" <manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.dan63.tetrastats.tetra_stats"> package="com.dan63.tetrastats.tetra_stats">
<application <application
android:label="tetra_stats" android:label="Tetra Stats"
android:name="${applicationName}" android:name="${applicationName}"
android:icon="@mipmap/ic_launcher"> android:icon="@mipmap/ic_launcher">
<activity <activity

View File

@ -13,7 +13,7 @@
<key>CFBundleInfoDictionaryVersion</key> <key>CFBundleInfoDictionaryVersion</key>
<string>6.0</string> <string>6.0</string>
<key>CFBundleName</key> <key>CFBundleName</key>
<string>tetra_stats</string> <string>Tetra Stats</string>
<key>CFBundlePackageType</key> <key>CFBundlePackageType</key>
<string>APPL</string> <string>APPL</string>
<key>CFBundleShortVersionString</key> <key>CFBundleShortVersionString</key>

View File

@ -184,7 +184,7 @@ class Badge {
Badge.fromJson(Map<String, dynamic> json) { Badge.fromJson(Map<String, dynamic> json) {
badgeId = json['id']; badgeId = json['id'];
label = json['label']; label = json['label'];
ts = (json['ts'] != null && json['ts'] is String) ? DateTime.parse(json['ts']) : null; ts = (json['ts'] != null && json['ts'] is String) ? DateTime.parse(json['ts']) : null; // man i love osk
} }
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {

View File

@ -1,15 +1,17 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:tetra_stats/views/main_view.dart'; import 'package:path/path.dart';
import 'package:sqflite_common_ffi/sqflite_ffi.dart'; import 'package:sqflite_common_ffi/sqflite_ffi.dart';
import 'package:tetra_stats/views/main_view.dart';
import 'package:tetra_stats/views/compare_view.dart';
import 'package:tetra_stats/views/settings_view.dart';
import 'package:tetra_stats/views/states_view.dart';
void main() { void main() {
sqfliteFfiInit(); sqfliteFfiInit();
databaseFactory = databaseFactoryFfi; databaseFactory = databaseFactoryFfi;
runApp(MaterialApp( runApp(MaterialApp(
home: MainView(), home: const MainView(),
theme: ThemeData( routes: {"/settings": (context) => const SettingsView(), "/compare": (context) => const CompareView(), "/states": (context) => const StatesView()},
fontFamily: 'Eurostile Round', theme: ThemeData(fontFamily: 'Eurostile Round', colorScheme: const ColorScheme.dark(), scaffoldBackgroundColor: Colors.black),
colorScheme: ColorScheme.dark(),
scaffoldBackgroundColor: Colors.black),
)); ));
} }

View File

@ -0,0 +1,31 @@
import 'package:flutter/material.dart';
class CompareView extends StatefulWidget {
const CompareView({Key? key}) : super(key: key);
@override
State<StatefulWidget> createState() => CompareState();
}
class CompareState extends State<CompareView> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text("you vs someone"),
),
backgroundColor: Colors.black,
body: SafeArea(
child: ListView(
children: [
ListTile(
title: Center(child: Text("So thats gonna be the main purpose of the app")),
subtitle: Center(child: Text("We gonna look who is the best")),
trailing: Text("Opponent value"),
leading: Text("Your value"),
)
],
)),
);
}
}

View File

@ -21,15 +21,13 @@ const allowedHeightForPlayerIdInPixels = 40.0;
const allowedHeightForPlayerBioInPixels = 30.0; const allowedHeightForPlayerBioInPixels = 30.0;
const givenTextHeightByScreenPercentage = 0.3; const givenTextHeightByScreenPercentage = 0.3;
enum ThreeDotsItems { compare, states, settings }
class MainView extends StatefulWidget { class MainView extends StatefulWidget {
const MainView({Key? key}) : super(key: key); const MainView({Key? key}) : super(key: key);
String get title => "Tetra Stats: $_searchFor"; String get title => "Tetra Stats: $_searchFor";
@override @override
State<MainView> createState() => _MyHomePageState(); State<MainView> createState() => _MainState();
} }
Future<TetrioPlayer> fetchTetrioPlayer(String user) async { Future<TetrioPlayer> fetchTetrioPlayer(String user) async {
@ -48,7 +46,7 @@ Future<TetrioPlayer> fetchTetrioPlayer(String user) async {
} }
} }
class _MyHomePageState extends State<MainView> with SingleTickerProviderStateMixin { class _MainState extends State<MainView> with SingleTickerProviderStateMixin {
final bodyGlobalKey = GlobalKey(); final bodyGlobalKey = GlobalKey();
final List<Widget> myTabs = [ final List<Widget> myTabs = [
const Tab(text: "Tetra League"), const Tab(text: "Tetra League"),
@ -80,12 +78,8 @@ class _MyHomePageState extends State<MainView> with SingleTickerProviderStateMix
], ],
), ),
onSubmitted: (String value) { onSubmitted: (String value) {
_searchFor = value;
me = null;
_tabController.animateTo(0, duration: Duration(milliseconds: 300)); _tabController.animateTo(0, duration: Duration(milliseconds: 300));
setState(() { changePlayer(value);
me = fetchTetrioPlayer(value);
});
}, },
); );
} }
@ -94,7 +88,7 @@ class _MyHomePageState extends State<MainView> with SingleTickerProviderStateMix
void initState() { void initState() {
_scrollController = ScrollController(); _scrollController = ScrollController();
_tabController = TabController(length: 4, vsync: this); _tabController = TabController(length: 4, vsync: this);
me = fetchTetrioPlayer("dan63047"); changePlayer("dan63047");
super.initState(); super.initState();
} }
@ -105,6 +99,13 @@ class _MyHomePageState extends State<MainView> with SingleTickerProviderStateMix
super.dispose(); super.dispose();
} }
void changePlayer(String player) {
setState(() {
_searchFor = player;
me = fetchTetrioPlayer(player);
});
}
_scrollListener() { _scrollListener() {
if (fixedScroll) { if (fixedScroll) {
_scrollController.jumpTo(0); _scrollController.jumpTo(0);
@ -122,7 +123,7 @@ class _MyHomePageState extends State<MainView> with SingleTickerProviderStateMix
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Scaffold( return Scaffold(
drawer: NavDrawer(), drawer: NavDrawer(changePlayer),
appBar: AppBar( appBar: AppBar(
title: !_searchBoolean title: !_searchBoolean
? Text( ? Text(
@ -167,20 +168,23 @@ class _MyHomePageState extends State<MainView> with SingleTickerProviderStateMix
tooltip: "Close search", tooltip: "Close search",
), ),
PopupMenuButton( PopupMenuButton(
itemBuilder: (BuildContext context) => <PopupMenuEntry<ThreeDotsItems>>[ itemBuilder: (BuildContext context) => <PopupMenuEntry>[
const PopupMenuItem<ThreeDotsItems>( const PopupMenuItem(
value: ThreeDotsItems.compare, value: "/compare",
child: Text('Compare'), child: Text('Compare'),
), ),
const PopupMenuItem<ThreeDotsItems>( const PopupMenuItem(
value: ThreeDotsItems.states, value: "/states",
child: Text('States'), child: Text('States'),
), ),
const PopupMenuItem<ThreeDotsItems>( const PopupMenuItem(
value: ThreeDotsItems.settings, value: "/settings",
child: Text('Settings'), child: Text('Settings'),
), ),
], ],
onSelected: (value) {
Navigator.pushNamed(context, value);
},
), ),
], ],
), ),
@ -1097,6 +1101,9 @@ class _MyHomePageState extends State<MainView> with SingleTickerProviderStateMix
} }
class NavDrawer extends StatelessWidget { class NavDrawer extends StatelessWidget {
Function changePlayer;
NavDrawer(this.changePlayer, {super.key});
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Drawer( return Drawer(
@ -1112,9 +1119,8 @@ class NavDrawer extends StatelessWidget {
leading: const Icon(Icons.verified_user), leading: const Icon(Icons.verified_user),
title: const Text('dan63047'), title: const Text('dan63047'),
onTap: () { onTap: () {
me = fetchTetrioPlayer("dan63047"); changePlayer('dan63047');
Navigator.of(context).pop(); Navigator.of(context).pop();
Navigator.of(context).initState();
}, },
), ),
], ],

View File

@ -0,0 +1,82 @@
import 'package:flutter/material.dart';
import 'package:package_info_plus/package_info_plus.dart';
class SettingsView extends StatefulWidget {
const SettingsView({Key? key}) : super(key: key);
@override
State<StatefulWidget> createState() => SettingsState();
}
class SettingsState extends State<SettingsView> {
PackageInfo _packageInfo = PackageInfo(appName: "TetraStats", packageName: "idk man", version: "some numbers", buildNumber: "anotherNumber");
@override
void initState() {
super.initState();
_initPackageInfo();
}
Future<void> _initPackageInfo() async {
final info = await PackageInfo.fromPlatform();
setState(() {
_packageInfo = info;
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text("Settings"),
),
backgroundColor: Colors.black,
body: SafeArea(
child: ListView(
children: [
ListTile(
title: const Text("So there you gonna be able to change some settings"),
subtitle: const Text(
"They are not implemented yet. But its gonna be possible to change player for main view init, save logs, as well as import and export app sqlite database."),
trailing: Switch(
value: true,
onChanged: (bool value) {},
),
),
ListTile(
title: const Text("Very egg"),
subtitle: const Text("very ass"),
trailing: const Text("dan63047"),
onTap: () => showDialog(
context: context,
builder: (BuildContext context) => AlertDialog(
title: const Text("Your username in TETR.IO", style: TextStyle(fontFamily: "Eurostile Round Extended")),
content: SingleChildScrollView(
child: ListBody(children: [const TextField()]),
),
actions: <Widget>[
TextButton(
child: const Text('Cancel'),
onPressed: () {
Navigator.of(context).pop();
},
),
TextButton(
child: const Text('Submit'),
onPressed: () {
Navigator.of(context).pop();
},
)
],
)),
),
Divider(),
ListTile(
title: const Text("About app"),
subtitle: Text("${_packageInfo.appName} (${_packageInfo.packageName}) Version ${_packageInfo.version} Build ${_packageInfo.buildNumber}"),
),
],
)),
);
}
}

View File

@ -0,0 +1,23 @@
import 'package:flutter/material.dart';
class StatesView extends StatefulWidget {
const StatesView({Key? key}) : super(key: key);
@override
State<StatefulWidget> createState() => StatesState();
}
class StatesState extends State<StatesView> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text("States of NICKNAME account"),
),
backgroundColor: Colors.black,
body: const SafeArea(
child: Text(
"So it's gonna be possible to store history of the account. One single piece of account history is what i call \"State\". In this view you will be able to control states, delete really old ones if too many.\n\nRight now app doesn't even store it.")),
);
}
}

View File

@ -4,7 +4,7 @@ project(runner LANGUAGES CXX)
# The name of the executable created for the application. Change this to change # The name of the executable created for the application. Change this to change
# the on-disk name of your application. # the on-disk name of your application.
set(BINARY_NAME "tetra_stats") set(BINARY_NAME "Tetra Stats")
# The unique GTK application identifier for this application. See: # The unique GTK application identifier for this application. See:
# https://wiki.gnome.org/HowDoI/ChooseApplicationID # https://wiki.gnome.org/HowDoI/ChooseApplicationID
set(APPLICATION_ID "com.dan63.tetrastats.tetra_stats") set(APPLICATION_ID "com.dan63.tetrastats.tetra_stats")

View File

@ -5,10 +5,12 @@
import FlutterMacOS import FlutterMacOS
import Foundation import Foundation
import package_info_plus
import path_provider_foundation import path_provider_foundation
import sqflite import sqflite
func RegisterGeneratedPlugins(registry: FlutterPluginRegistry) { func RegisterGeneratedPlugins(registry: FlutterPluginRegistry) {
FLTPackageInfoPlusPlugin.register(with: registry.registrar(forPlugin: "FLTPackageInfoPlusPlugin"))
PathProviderPlugin.register(with: registry.registrar(forPlugin: "PathProviderPlugin")) PathProviderPlugin.register(with: registry.registrar(forPlugin: "PathProviderPlugin"))
SqflitePlugin.register(with: registry.registrar(forPlugin: "SqflitePlugin")) SqflitePlugin.register(with: registry.registrar(forPlugin: "SqflitePlugin"))
} }

View File

@ -107,6 +107,11 @@ packages:
description: flutter description: flutter
source: sdk source: sdk
version: "0.0.0" version: "0.0.0"
flutter_web_plugins:
dependency: transitive
description: flutter
source: sdk
version: "0.0.0"
http: http:
dependency: "direct main" dependency: "direct main"
description: description:
@ -163,6 +168,22 @@ packages:
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "1.8.0" version: "1.8.0"
package_info_plus:
dependency: "direct main"
description:
name: package_info_plus
sha256: ceb027f6bc6a60674a233b4a90a7658af1aebdea833da0b5b53c1e9821a78c7b
url: "https://pub.dev"
source: hosted
version: "4.0.2"
package_info_plus_platform_interface:
dependency: transitive
description:
name: package_info_plus_platform_interface
sha256: "9bc8ba46813a4cc42c66ab781470711781940780fd8beddd0c3da62506d3a6c6"
url: "https://pub.dev"
source: hosted
version: "2.0.1"
path: path:
dependency: "direct main" dependency: "direct main"
description: description:
@ -345,7 +366,7 @@ packages:
source: hosted source: hosted
version: "1.3.1" version: "1.3.1"
vector_math: vector_math:
dependency: transitive dependency: "direct main"
description: description:
name: vector_math name: vector_math
sha256: "80b3257d1492ce4d091729e3a67a60407d227c27241d6927be0130c98e741803" sha256: "80b3257d1492ce4d091729e3a67a60407d227c27241d6927be0130c98e741803"

View File

@ -14,7 +14,7 @@ publish_to: 'none'
# https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html # https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html
# In Windows, build-name is used as the major, minor, and patch parts # In Windows, build-name is used as the major, minor, and patch parts
# of the product and file versions while build-number is used as the build suffix. # of the product and file versions while build-number is used as the build suffix.
version: 0.0.1 version: 0.0.1+1
environment: environment:
sdk: '>=2.19.6 <3.0.0' sdk: '>=2.19.6 <3.0.0'
@ -30,11 +30,13 @@ dependencies:
flutter: flutter:
sdk: flutter sdk: flutter
cupertino_icons: ^1.0.2 cupertino_icons: ^1.0.2
vector_math: any
sqflite: ^2.2.8+2 sqflite: ^2.2.8+2
sqflite_common_ffi: any sqflite_common_ffi: any
path_provider: ^2.0.15 path_provider: ^2.0.15
path: ^1.8.2 path: ^1.8.2
fl_chart: ^0.62.0 fl_chart: ^0.62.0
package_info_plus: ^4.0.2
dev_dependencies: dev_dependencies:
flutter_test: flutter_test:
@ -110,6 +112,7 @@ flutter:
- res/tetrio_badges/superlobby.png - res/tetrio_badges/superlobby.png
- res/tetrio_badges/superlobby2.png - res/tetrio_badges/superlobby2.png
- res/tetrio_badges/taws_u50_1.png - res/tetrio_badges/taws_u50_1.png
- res/tetrio_badges/taws_u50_3.png
- res/tetrio_badges/tawshdsl_uncapped.png - res/tetrio_badges/tawshdsl_uncapped.png
- res/tetrio_badges/tawsignite_expert.png - res/tetrio_badges/tawsignite_expert.png
- res/tetrio_badges/tawslg.png - res/tetrio_badges/tawslg.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 91 KiB

View File

@ -29,7 +29,7 @@
<!-- Favicon --> <!-- Favicon -->
<link rel="icon" type="image/png" href="favicon.png"/> <link rel="icon" type="image/png" href="favicon.png"/>
<title>tetra_stats</title> <title>Tetra Stats</title>
<link rel="manifest" href="manifest.json"> <link rel="manifest" href="manifest.json">
<script> <script>