shark 0.0.8 copy "shark: ^0.0.8" to clipboard
shark: ^0.0.8 copied to clipboard

outdated

A Flutter server rendering framework for mobile application

Shark Flutter 🦈 (Under Construction) #

codecov pub package

A Flutter server rendering framework

Project diagram #

How to use #

First, init Shark library on main method on your application

  void main() {
    WidgetsFlutterBinding.ensureInitialized();
    await Shark.init(hostUrl: 'http://yourhost.com');
    
    runApp(MyApp());
  }

Second, set up UI widget

  • To be noticed, every thing related to widget is controlled by SharkController
  • get method is where we send the request
  late final SharkController _controller;
  
  /// init the shark controller
  @override
  void initState() {
    _controller = SharkController.fromUrl(path: '/container',)..get();
    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    return SharkWidget(controller: _controller);
  }

To redirect to another page, call `redirect`

    _controller.redirect('/your_new_path');

If you want to create your own parser

class MyCustomParser extends SharkParser {}

Routing #

`shark` auto handle your page routing, if you do not want it, set `handleClickEvent` to false

    _sharkController = SharkController('/your_path', handleClickEvent: false);

Click Event #

Routing trigger by click event, which you can set it like this on your json widget file.

    {
        'type': "container",
        'click_event': 'route://your_path'
    }

The schema `route` represents the routing action

Currently, there are only 2 routing action route: Navigation to the next page corresponds to the path you define link: use url_launcher internally to open a url on browser, please visit url_launcher to configure the detail requirements for each platform



  • Remember that Shark is still on early development and lack of testing, I would not recommend you to use it on Production.

  • Note that Shark uses dynamic_widget for widget parsing,

  • To view the json format, go visit documentation on dynamic_widget.

You can also view the express server sample

Future Job #

  • Routing
  • Parsing widget optimization
  • Security
  • Localization
  • Caching