dirt_arch 0.0.6
dirt_arch: ^0.0.6 copied to clipboard
This package has the reference of many packages to facilitate the creation of apps without having to look for packages
example/lib/main.dart
import 'package:dirt_arch/dirt_arch.dart';
import 'package:example/page_four.dart';
import 'package:flutter/material.dart';
import 'package:asuka/asuka.dart' as asuka;
import 'model/sample_model.dart';
import 'page_three.dart';
import 'page_two.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.orange,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
builder: (BuildContext context, Widget child) {
return asuka.builder(context, BotToastInit()(context, child));
},
navigatorObservers: [BotToastNavigatorObserver()],
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
actions: [
IconButton(
icon: Icon(Icons.threesixty),
onPressed: () {
Navigator.of(context).push(MaterialPageRoute(builder: (_) {
return PageThree();
}));
},
)
],
),
body: Column(
children: [
RaisedButton(
child: Text('Next Page'),
onPressed: () {
Navigator.of(context).push(
MaterialPageRoute(
builder: (_) => PageFour(),
),
);
}),
Expanded(
child: GetWidget<List<SampleModel>>(
url: 'https://jsonplaceholder.typicode.com/posts',
fromMap: (json) =>
(json as List).map((e) => SampleModel.fromMap(e)).toList(),
builder: (data) => ListView.builder(
itemBuilder: (context, index) {
return ListTile(
title: Text(data[index].title),
onTap: () => Navigator.of(context)
.push(MaterialPageRoute(builder: (_) {
return PageTwo(id: data[index].id);
})),
);
},
),
),
),
],
),
bottomNavigationBar: DefaultTextStyle(
style: TextStyle(fontSize: 30),
// Theme.of(context)
// .textTheme
// .bodyText1
// .copyWith(color: Color(0xFF444444)),
child: BottomNavigationBar(items: [
BottomNavigationBarItem(
icon: Icon(Icons.ad_units), label: 'Adiciona Unidades'),
BottomNavigationBarItem(icon: Icon(Icons.plus_one), label: 'Mais Um'),
BottomNavigationBarItem(icon: Icon(Icons.home), label: 'Casa')
]),
),
// bottomNavigationBar: DirtBottomBar(
// //This
// onTapItems: [
// DirtTabItem(
// icon: Icons.home,
// title: 'Home',
// onTap: (_) {
// print('Home');
// }),
// DirtTabItem(
// icon: Icons.map,
// title: 'Discovery',
// onTap: (_) {
// print('Discovery');
// }),
// DirtTabItem(
// icon: Icons.add,
// title: 'Add',
// onTap: (_) {
// print('Add');
// }),
// ],
//Or
// items: [
// TabItem(icon: Icons.home, title: 'Home'),
// TabItem(icon: Icons.map, title: 'Discovery'),
// TabItem(icon: Icons.add, title: 'Add'),
// ],
// onTap: (int i) => print('click index=$i'),
// ),
floatingActionButton: PostWidget<SampleModel>(
url: 'https://jsonplaceholder.typicode.com/posts',
toMap: (data) => data.toMap(),
builder: (execute) {
return FloatingActionButton(
onPressed: () => execute(
SampleModel(
userId: 1,
title: "Test",
completed: true,
),
),
tooltip: 'Increment',
child: Icon(Icons.add),
);
},
),
);
}
}