oriole 0.0.1 copy "oriole: ^0.0.1" to clipboard
oriole: ^0.0.1 copied to clipboard

The purpose of creating this routing library is to combine the functionalities of Flutter_Modular and Qlevar_Router libraries, providing a more powerful and flexible solution for route management.

The purpose of creating this routing library is to combine the functionalities of Flutter_Modular and Qlevar_Router libraries, providing a more powerful and flexible solution for route management. By trimming and merging the code from these two libraries, it can leverage their respective strengths to achieve efficient route navigation and management.

This library aims to simplify route handling for developers in Flutter applications, offering an improved development experience and enhanced functionality.


void main() {
  runApp(
    OrioleApp(
      module: AppModule(),
      child: const MyApp(),
    ),
  );
}

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

  @override
  Widget build(BuildContext context) {
    return MaterialApp.router(
      title: 'Flutter Demo',
      routerDelegate: Oriole.routerDelegate,
      routeInformationParser: Oriole.routeInformationParser,
    );
  }
}

class AppModule extends OrioleModule {
  @override
  void binds(Injector i) {
    // binds
    i.addSingleton<UserService>(UserServiceImpl.new);
  }

  @override
  void routes(RouteManager manager) {
    // routes
    manager.shell(
      path: '/',
      builder: (router) => DashboardShell(router: router),
      children: [
        ChildRoute(
          path: '/home',
          builder: () => const HomePage(),
          pageType: const OrioleCustomPage(),
        ),
        ChildRoute(
          path: '/setting',
          builder: () => const SettingPage(),
          pageType: const OrioleCustomPage(),
        ),
      ],
    );
    
    manager.module(name: '/other', module: OtherModule());
    manager.child(path: '/other/page', builder: () => const OtherPage());
  }
}

// Navigation
Oriole.to.go("/");

// Push
Oriole.to.push("/");

// Replace
Oriole.to.replaceAll("/");

// Nested navigation
Oriole.switchTo('/home')

// Get service
Oriole.get<UserService>();

The documentation is not comprehensive, you can refer to the documentation of Flutter_Modular and Qlevar_Router.

For more usage examples of this library, please refer to the provided examples.

1
likes
130
points
16
downloads

Publisher

unverified uploader

Weekly Downloads

The purpose of creating this routing library is to combine the functionalities of Flutter_Modular and Qlevar_Router libraries, providing a more powerful and flexible solution for route management.

Repository (GitHub)
View/report issues

Topics

#navigation #router #modular-router #nested-routes #deep-linking

Documentation

API reference

License

MIT (license)

Dependencies

auto_injector, flutter, flutter_web_plugins

More

Packages that depend on oriole