Compare commits

...

2 Commits

Author SHA1 Message Date
78e468cc29 Provider rename 2024-05-12 13:43:30 +03:00
6c4c2c4acd Mobile example app 2024-05-12 13:42:05 +03:00
4 changed files with 109 additions and 25 deletions

76
lib/mobile_example.dart Normal file
View File

@@ -0,0 +1,76 @@
import 'dart:math';
import 'package:flutter/material.dart';
import 'package:gymlink_module_web/main_mobile.dart';
import 'package:gymlink_module_web/providers/main.dart';
import 'package:provider/provider.dart';
void main() {
runApp(const MyExampleApp());
}
class MyExampleApp extends StatelessWidget {
const MyExampleApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'GymLink Example App',
debugShowCheckedModeBanner: false,
home: ChangeNotifierProvider(
create: (_) => GymLinkProvider(),
child: Consumer<GymLinkProvider>(
builder: (context, provider, __) => const ExamplePage(),
),
),
);
}
}
class ExamplePage extends StatefulWidget {
const ExamplePage({super.key});
@override
State<ExamplePage> createState() => _ExamplePageState();
}
class _ExamplePageState extends State<ExamplePage> {
@override
void initState() {
super.initState();
context.read<GymLinkProvider>().onTokenReceived('token123');
}
@override
Widget build(BuildContext context) {
return Consumer<GymLinkProvider>(
builder: (context, provider, __) => Scaffold(
appBar: AppBar(title: const Text('GymLink Example App')),
body: Column(
children: [
const Text('test'),
IconButton(
icon: const Icon(Icons.abc),
onPressed: () {
provider.onTokenReceived('token123');
},
),
const Expanded(
child: MyApp(),
),
const SizedBox(
height: 20,
),
const Text('Bottom text')
],
),
floatingActionButton: IconButton(
icon: const Icon(Icons.search),
onPressed: () {
provider.changeTheme(Random().nextInt(0xffffff + 1));
},
),
),
);
}
}

23
lib/providers/main.dart Normal file
View File

@@ -0,0 +1,23 @@
import 'package:flutter/material.dart';
import 'package:gymlink_module_web/theme.dart';
class GymLinkProvider with ChangeNotifier {
bool _isLoading = true;
bool get isLoading => _isLoading;
bool _blackTheme = false;
bool get blackTheme => _blackTheme;
ThemeData _theme = myTheme;
ThemeData get theme => _theme;
void onTokenReceived(String token) {
if (token == 'token123') {
_isLoading = false;
notifyListeners();
}
}
void changeTheme(int color) {
_blackTheme = !_blackTheme;
_theme = getThemeData(Color(color), _blackTheme);
notifyListeners();
}
}

View File

@@ -1,35 +1,19 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:gymlink_module_web/main_mobile.dart'; import 'package:gymlink_module_web/main_mobile.dart';
import 'package:gymlink_module_web/pages/main.dart'; import 'package:gymlink_module_web/pages/main.dart';
import 'package:gymlink_module_web/theme.dart'; import 'package:gymlink_module_web/providers/main.dart';
import 'package:provider/provider.dart';
class MyAppStateMobile extends State<MyApp> { class MyAppStateMobile extends State<MyApp> {
bool _isLoading = false;
ThemeData theme = myTheme;
bool black_theme = false;
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return MaterialApp( return Consumer<GymLinkProvider>(
title: 'GymLink Module', builder: (context, provider, __) => MaterialApp(
theme: theme, title: 'GymLink Module',
debugShowCheckedModeBanner: false, theme: provider.theme,
home: MainPage(isLoading: _isLoading), debugShowCheckedModeBanner: false,
home: MainPage(isLoading: provider.isLoading),
),
); );
} }
void onTokenReceived(String token) {
if (token == 'token123') {
setState(() {
_isLoading = false;
});
}
}
void changeColor(int color) {
setState(() {
black_theme = !black_theme; //FIXME: TEMPORARY
theme = getThemeData(Color(color), black_theme);
});
}
} }

View File

@@ -40,6 +40,7 @@ dependencies:
flutter_markdown: ^0.7.1 flutter_markdown: ^0.7.1
http: ^1.2.1 http: ^1.2.1
universal_html: ^2.2.4 universal_html: ^2.2.4
provider: ^6.1.2
dev_dependencies: dev_dependencies:
flutter_test: flutter_test: