go_navigator 2.0.2 copy "go_navigator: ^2.0.2" to clipboard
go_navigator: ^2.0.2 copied to clipboard

Go navogator handles navigation by reducing class argument and exposing the top most route args to the context and navigation key where passed

example/lib/main.dart

import 'package:flutter/material.dart';
import 'package:go_navigator/go.dart';

/// The global key for the navigator, used to manage navigation from anywhere in the app.
final GlobalKey<NavigatorState> navigatorKey = GlobalKey<NavigatorState>();

void main() {
  runApp(MyApp());
}

/// The main application widget.
///
/// This widget initializes the [MaterialApp] and configures the [GoNavigator]
/// for handling routes within the app.
class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      navigatorKey: navigatorKey,
      navigatorObservers: [
        GoNavigatorObserver() // Uncomment this if you have GoNavigatorObserver
      ],
      onGenerateRoute: (settings) {
        return GoNavigator(
          initialRoute: HomePage(),
          routes: {
            '/': (context, args) => HomePage(),
            'home': (context, args) => HomePage(),
            'dashboard': {
              '/': (context, args) => DashboardPage(),
              'settings': {
                '/': (context, args) => SettingsPage(),
                'profile': {
                  '/': (context, args) => ProfilePage(),
                  'edit': (context, args) {
                    return const EditProfilePage();
                  },
                },
              }
            },
            'profile': {
              '/': (context, args) => ProfilePage(),
              'edit': (context, args) {
                return const EditProfilePage();
              },
            },
          },
        ).generateRoute(settings);
      },
    );
  }
}

/// The HomePage widget.
///
/// This widget displays the home screen of the app with buttons to navigate
/// to different pages.
class HomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: const Text('Home')),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          crossAxisAlignment: CrossAxisAlignment.center,
          children: [
            ElevatedButton(
              onPressed: () {
                context.to('dashboard/settings/profile/edit',
                    args: {'userId': '123'});
              },
              child: const Text('Go to Dashboard'),
            ),
            ElevatedButton(
              onPressed: () {
                context.to('profile');
              },
              child: const Text('Go to Profile'),
            ),
          ],
        ),
      ),
    );
  }
}

/// The DashboardPage widget.
///
/// This widget displays the dashboard screen with a button to navigate to the settings page.
class DashboardPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: const Text('Dashboard')),
      body: Center(
        child: ElevatedButton(
          onPressed: () {
            context.to('dashboard/settings');
          },
          child: const Text('Go to Settings'),
        ),
      ),
    );
  }
}

/// The SettingsPage widget.
///
/// This widget displays the settings screen.
class SettingsPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: const Text('Settings')),
      body: const Center(
        child: Text('Settings Page'),
      ),
    );
  }
}

/// The ProfilePage widget.
///
/// This widget displays the profile screen with a button to navigate to the edit profile page.
class ProfilePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: const Text('Profile')),
      body: Center(
        child: ElevatedButton(
          onPressed: () {
            context.to('profile/edit', args: {'userId': '123'});
          },
          child: const Text('Edit Profile'),
        ),
      ),
    );
  }
}

/// The EditProfilePage widget.
///
/// This widget displays the edit profile screen and shows the user ID passed as an argument.
class EditProfilePage extends StatelessWidget {
  const EditProfilePage();

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: const Text('Edit Profile')),
      body: Center(
        child: Text('Editing Profile for User ${context.args['userId']}'),
      ),
    );
  }
}
3
likes
140
points
26
downloads

Publisher

unverified uploader

Weekly Downloads

Go navogator handles navigation by reducing class argument and exposing the top most route args to the context and navigation key where passed

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

flutter, plugin_platform_interface

More

Packages that depend on go_navigator