semi_design 0.0.9 copy "semi_design: ^0.0.9" to clipboard
semi_design: ^0.0.9 copied to clipboard

Semi design library of Flutter, for use in mobile projects

example/lib/main.dart

import 'package:bot_toast/bot_toast.dart';
import 'package:dio/dio.dart';
import 'package:flutter/material.dart';
import 'package:semi_design/semi_design.dart';

final botToastBuilder = BotToastInit(); //1. call BotToastInit

void main() async {
  WidgetsFlutterBinding.ensureInitialized();
  // 创建缓存目录
  await UtilFile.createCacheDirectory();
  // 初始化 Crashlytics 服务
  await CrashlyticsService.instance.init();
  HttpService.instance.init(
    options: BaseOptions(
      connectTimeout: const Duration(seconds: 5),
      receiveTimeout: const Duration(seconds: 5),
    ),
    onRequest: (options, handler) {
      // 自定义请求拦截逻辑
      options.baseUrl = 'http://10.16.7.23:9300';
      options.headers["id"] = '${DateTime.now().millisecondsSinceEpoch}';
      CrashlyticsService.instance.reportRequest(options);
      return handler.next(options);
    },
    onTokenExpired: () {
      // 在这里处理登出逻辑
      print('用户登出');
      // 可以调用你的登出方法
      // UserStore.to.logout();
    },
  );
  runApp(const MyApp());
}

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

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
      home: const MyHomePage(title: 'Flutter Demo Home Page'),
      navigatorObservers: [BotToastNavigatorObserver()],
      builder: (context, child) {
        child = botToastBuilder(context, child);
        return child;
      },
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({super.key, required this.title});

  final String title;

  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int _counter = 0;

  void _incrementCounter() {
    setState(() {
      _counter++;
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        backgroundColor: Theme.of(context).colorScheme.inversePrimary,
        title: Text(widget.title),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            CustomFilledButton(
              onPressed: () {
                HttpService.instance.post('/config/Login/Login', data: {
                  'username': 'admin',
                  'password': '123456',
                });
              },
              child: const Text('加载中...'),
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: _incrementCounter,
        tooltip: 'Increment',
        child: const Icon(Icons.add),
      ),
    );
  }
}