dynamic_router 0.2.0 copy "dynamic_router: ^0.2.0" to clipboard
dynamic_router: ^0.2.0 copied to clipboard

router for Flutter based on Navigation Api

example/lib/main.dart

import 'package:dynamic_router/approuter.dart';
import 'package:dynamic_router_example/detail/route/detail_route.dart';
import 'package:dynamic_router_example/home/route/home_route.dart';
import 'package:dynamic_router_example/splash/route/splash_route.dart';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';

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

class MyApp extends StatefulWidget {
  const MyApp({super.key});

  @override
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  var dynamicRouter = DynamicRouter().routerConfig(
    homePage: SplashRoute(),
    // delegate: routerDelegate
    // backButtonDispatcher:  PageStackBackButtonDispatcher(),
  );
  // late PPageStack<PagePath> pageStack;
  // late DynamicRouterDelegate routerDelegate;
  @override
  void initState() {
    SystemChrome.setPreferredOrientations([
      DeviceOrientation.landscapeRight,
      DeviceOrientation.landscapeLeft,
    ]);
    // pageStack = ...
    // routerDelegate = ...
    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp.router(
      routerConfig: dynamicRouter,
      theme: ThemeData(
        elevatedButtonTheme: ElevatedButtonThemeData(
            style: TextButton.styleFrom(
                backgroundColor: Colors.blue, foregroundColor: Colors.white)),
      ),
    );
  }
}

class SplashScreen extends StatelessWidget {
  const SplashScreen({super.key});

  routeToHome(BuildContext context) {
    AppRouter.pushAndRemoveUntil(HomeRoute(), (s) => false, context: context);
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Center(
        child: ElevatedButton(
          style: TextButton.styleFrom(
            backgroundColor: Colors.blue,
          ),
          onPressed: () => routeToHome(context),
          child: const Text(
            "to Home",
          ),
        ),
      ),
    );
  }
}

class HomeScreen extends StatelessWidget {
  const HomeScreen({super.key});

  routeToDetail(BuildContext context, {required int id}) {
    AppRouter.pushPage(HomeDetailRoute(id: id), context: context);
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Center(
        child: ElevatedButton(
          style: TextButton.styleFrom(
            backgroundColor: Colors.blue,
          ),
          onPressed: () => routeToDetail(context, id: 1),
          child: const Text(
            "to Detail",
          ),
        ),
      ),
    );
  }
}
12
likes
115
points
13
downloads

Publisher

unverified uploader

Weekly Downloads

router for Flutter based on Navigation Api

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

collection, flutter, flutter_issue_108697_workaround, meta, rxdart

More

Packages that depend on dynamic_router