Directory

This commit is contained in:
LittleSheep 2024-02-08 16:34:33 +08:00
parent b5f77c2736
commit ecb9bffe70
7 changed files with 125 additions and 34 deletions

View File

@ -75,7 +75,7 @@ class AuthGuard {
// Use WebView to get authorization url
var responseUrl = await Navigator.of(context).push(MaterialPageRoute(
builder: (context) => AuthorizationPage(authorizationUrl),
builder: (context) => AuthorizationScreen(authorizationUrl),
));
var responseUri = Uri.parse(responseUrl);

View File

@ -6,7 +6,7 @@ import 'package:firebase_core/firebase_core.dart';
import 'package:flutter/material.dart';
import 'firebase_options.dart';
void initializeFirebase() async {
Future<bool> initializeFirebase() async {
await Firebase.initializeApp(
options: DefaultFirebaseOptions.currentPlatform,
);
@ -28,6 +28,8 @@ void initializeFirebase() async {
FirebaseCrashlytics.instance.recordError(error, stack, fatal: true);
return true;
};
return true;
}
Future<String?> initializeFirebaseMessaging() async {

View File

@ -33,7 +33,7 @@ class _AgentNavigationState extends State<AgentNavigation> {
Future<void> initMessage(BuildContext context) async {
void navigate() {
widget.router.push("/notifications");
widget.router.replace("/notifications");
setState(() {
_selected = 1;
});
@ -64,7 +64,7 @@ class _AgentNavigationState extends State<AgentNavigation> {
labelBehavior: NavigationDestinationLabelBehavior.onlyShowSelected,
destinations: AgentNavigation.items,
onDestinationSelected: (index) {
widget.router.push(AgentNavigation.destinations[index]);
widget.router.replace(AgentNavigation.destinations[index]);
setState(() {
_selected = index;
});

View File

@ -1,4 +1,3 @@
import 'package:firebase_messaging/firebase_messaging.dart';
import 'package:flutter/material.dart';
import 'package:go_router/go_router.dart';
import 'package:goatagent/auth.dart';
@ -13,7 +12,6 @@ void main() async {
WidgetsFlutterBinding.ensureInitialized();
AuthGuard().pickClient();
initializeFirebase();
runApp(GoatAgent());
}
@ -41,23 +39,34 @@ class GoatAgent extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp.router(
routerConfig: _router,
title: 'GoatAgent',
theme: ThemeData(
colorScheme: ColorScheme.fromSeed(seedColor: Colors.indigo),
useMaterial3: true,
),
builder: (BuildContext context, Widget? child) {
return Overlay(initialEntries: [
OverlayEntry(
builder: (context) => Scaffold(
body: child,
// bottomNavigationBar: const AgentBottomNavigation()
bottomNavigationBar: AgentNavigation(router: _router),
),
)
]);
return FutureBuilder(
future: initializeFirebase(),
builder: (context, snapshot) {
if (!snapshot.hasData) {
return const Center(
child: CircularProgressIndicator(),
);
}
return MaterialApp.router(
routerConfig: _router,
title: 'GoatAgent',
theme: ThemeData(
colorScheme: ColorScheme.fromSeed(seedColor: Colors.indigo),
useMaterial3: true,
),
builder: (BuildContext context, Widget? child) {
return Overlay(initialEntries: [
OverlayEntry(
builder: (context) => Scaffold(
body: child,
// bottomNavigationBar: const AgentBottomNavigation()
bottomNavigationBar: AgentNavigation(router: _router),
),
)
]);
},
);
},
);
}

View File

@ -0,0 +1,23 @@
import 'package:flutter/material.dart';
import 'package:webview_flutter/webview_flutter.dart';
class AuthorizationScreen extends StatelessWidget {
final Uri link;
const AuthorizationScreen(this.link, {super.key});
@override
Widget build(BuildContext context) {
return Scaffold(
body: SafeArea(
child: WebViewWidget(
controller: WebViewController()
..setJavaScriptMode(JavaScriptMode.unrestricted)
..setBackgroundColor(Colors.white)
..loadRequest(link)
..clearCache(),
),
),
);
}
}

View File

@ -1,10 +1,10 @@
import 'package:flutter/material.dart';
import 'package:webview_flutter/webview_flutter.dart';
class AuthorizationPage extends StatelessWidget {
class AuthorizationScreen extends StatelessWidget {
final Uri authorizationUrl;
const AuthorizationPage(this.authorizationUrl, {super.key});
const AuthorizationScreen(this.authorizationUrl, {super.key});
@override
Widget build(BuildContext context) {
@ -15,7 +15,7 @@ class AuthorizationPage extends StatelessWidget {
body: WebViewWidget(
controller: WebViewController()
..setJavaScriptMode(JavaScriptMode.unrestricted)
..setBackgroundColor(Colors.indigo)
..setBackgroundColor(Colors.white)
..setNavigationDelegate(NavigationDelegate(
onNavigationRequest: (NavigationRequest request) {
if (request.url.startsWith('goatagent://auth')) {
@ -25,7 +25,8 @@ class AuthorizationPage extends StatelessWidget {
return NavigationDecision.navigate;
},
))
..loadRequest(authorizationUrl),
..loadRequest(authorizationUrl)
..clearCache(),
),
);
}

View File

@ -1,15 +1,71 @@
import 'package:flutter/material.dart';
import 'dart:convert';
class DashboardScreen extends StatelessWidget {
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'application.dart';
class DashboardScreen extends StatefulWidget {
const DashboardScreen({super.key});
@override
State<DashboardScreen> createState() => _DashboardScreenState();
}
class _DashboardScreenState extends State<DashboardScreen> {
final client = http.Client();
final directoryEndpoint =
Uri.parse('https://id.smartsheep.studio/.well-known');
List<dynamic> directory = List.empty();
@override
void initState() {
super.initState();
_pullDirectory();
}
Future<void> _pullDirectory() async {
var response = await client.get(directoryEndpoint);
if (response.statusCode == 200) {
setState(() {
directory = jsonDecode(utf8.decode(response.bodyBytes))["directory"];
});
}
}
@override
Widget build(BuildContext context) {
return const Scaffold(
body: Center(
child: Text("你好"),
return Scaffold(
body: SafeArea(
child: Padding(
padding: const EdgeInsets.only(left: 20, right: 20, top: 30),
child: GridView.count(
crossAxisCount: 2,
children: directory.map((element) {
return Card(
child: InkWell(
onTap: () async {
await Navigator.of(context).push(MaterialPageRoute(
builder: (context) => AuthorizationScreen(
Uri.parse(element["link"]),
),
));
},
splashColor: Colors.indigo.withAlpha(30),
child: Padding(
padding: const EdgeInsets.all(10),
child: ListTile(
title: Text(element['name']),
subtitle: Text(element['description']),
),
),
),
);
}).toList(),
),
),
),
);
}
}
}