176 lines
4.8 KiB
Dart
176 lines
4.8 KiB
Dart
import 'dart:convert';
|
|
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:http/http.dart' as http;
|
|
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: const ExampleMainPage(),
|
|
theme: ThemeData.light(useMaterial3: true),
|
|
);
|
|
}
|
|
}
|
|
|
|
class ExamplePage extends StatefulWidget {
|
|
const ExamplePage({super.key});
|
|
|
|
@override
|
|
State<ExamplePage> createState() => _ExamplePageState();
|
|
}
|
|
|
|
Widget getDrawer(BuildContext context) => Drawer(
|
|
child: Column(
|
|
children: [
|
|
const DrawerHeader(child: Text('Drawer Header')),
|
|
ListTile(
|
|
leading: const Icon(Icons.home),
|
|
title: const Text('Home'),
|
|
onTap: () => Navigator.of(context).push(
|
|
MaterialPageRoute(
|
|
builder: (context) => const ExampleMainPage(),
|
|
),
|
|
),
|
|
),
|
|
ListTile(
|
|
leading: const Icon(Icons.search),
|
|
title: const Text('Example page'),
|
|
onTap: () => Navigator.of(context).push(MaterialPageRoute(
|
|
builder: (context) => const ExampleSecondPage(),
|
|
)),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
|
|
class ExampleMainPage extends StatelessWidget {
|
|
const ExampleMainPage({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return ChangeNotifierProvider(
|
|
create: (_) => GymLinkProvider(),
|
|
child: Consumer<GymLinkProvider>(
|
|
builder: (_, value, __) => const ExamplePage(),
|
|
));
|
|
}
|
|
}
|
|
|
|
class _ExamplePageState extends State<ExamplePage> {
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
// Future.microtask(
|
|
// () => context.read<GymLinkProvider>().onTokenReceived('token123'));
|
|
Future.microtask(() => context
|
|
.read<GymLinkProvider>()
|
|
.setTheme(ThemeData.light(useMaterial3: true)));
|
|
|
|
Future.microtask(() => context.read<GymLinkProvider>().setOnError(() {
|
|
const snackBar = SnackBar(
|
|
content: Text('Ошибка подключения'),
|
|
duration: Duration(seconds: 3), // Длительность отображения Snackbar
|
|
behavior: SnackBarBehavior
|
|
.fixed, // Поведение Snackbar (fixed или floating)
|
|
);
|
|
ScaffoldMessenger.of(context).showSnackBar(snackBar);
|
|
Future.delayed(const Duration(seconds: 3))
|
|
.then((value) => _setToken());
|
|
}));
|
|
|
|
Future.microtask(() async {
|
|
await _setToken();
|
|
});
|
|
}
|
|
|
|
Future<void> _setToken() async {
|
|
final token = await _getToken();
|
|
if (token != '') {
|
|
context.read<GymLinkProvider>().onTokenReceived(token);
|
|
} else {
|
|
context.read<GymLinkProvider>().onError();
|
|
}
|
|
}
|
|
|
|
Future<String> _getToken() async {
|
|
var url =
|
|
Uri.http('gymlink.freemyip.com:8080', 'api/auth/authorize_client');
|
|
var response = await http.post(url, body: {
|
|
'GymKey': 'eeb42dcb-8e5b-4f21-825a-3fc7ada43445',
|
|
'id': '123'
|
|
}); // Just testing token
|
|
var decodedBody = jsonDecode(response.body) as Map;
|
|
if (decodedBody['payload'] == null) {
|
|
return '';
|
|
}
|
|
return decodedBody['payload']['token'];
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Scaffold(
|
|
appBar: AppBar(
|
|
title: const Text('GymLink Example App'),
|
|
),
|
|
resizeToAvoidBottomInset: false,
|
|
drawer: getDrawer(context),
|
|
body: Column(
|
|
children: [
|
|
const Text('test'),
|
|
IconButton(
|
|
icon: const Icon(Icons.abc),
|
|
onPressed: () {
|
|
context.read<GymLinkProvider>().onTokenReceived('token123');
|
|
},
|
|
),
|
|
const Expanded(
|
|
child: MyApp(),
|
|
),
|
|
const SizedBox(
|
|
height: 20,
|
|
),
|
|
const Text('Bottom text')
|
|
],
|
|
),
|
|
floatingActionButton: IconButton(
|
|
icon: const Icon(Icons.search),
|
|
onPressed: () {
|
|
context
|
|
.read<GymLinkProvider>()
|
|
.changeTheme(Random().nextInt(0xffffff + 1));
|
|
},
|
|
),
|
|
);
|
|
}
|
|
}
|
|
|
|
class ExampleSecondPage extends StatelessWidget {
|
|
const ExampleSecondPage({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Scaffold(
|
|
appBar: AppBar(
|
|
title: const Text('GymLink Example App'),
|
|
),
|
|
drawer: getDrawer(context),
|
|
body: const Center(
|
|
child: Text('Example page'),
|
|
),
|
|
);
|
|
}
|
|
}
|