2020-03-27 16:07:55 +00:00
|
|
|
import 'dart:io';
|
|
|
|
|
2020-03-24 19:59:36 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:logger/logger.dart';
|
2020-03-27 16:07:55 +00:00
|
|
|
import 'package:myapp/models/photo.dart';
|
|
|
|
import 'package:myapp/photo_loader.dart';
|
2020-03-24 19:59:36 +00:00
|
|
|
import 'package:myapp/photo_provider.dart';
|
|
|
|
import 'package:myapp/photo_sync_manager.dart';
|
2020-03-27 16:34:15 +00:00
|
|
|
import 'package:myapp/ui/detail_page.dart';
|
2020-03-24 19:59:36 +00:00
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
import 'package:myapp/ui/gallery_page.dart';
|
|
|
|
|
|
|
|
final provider = PhotoProvider();
|
|
|
|
final logger = Logger();
|
|
|
|
|
|
|
|
void main() async {
|
|
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
|
|
await provider.refreshGalleryList();
|
|
|
|
var assets = await provider.list[0].assetList;
|
|
|
|
PhotoSyncManager(assets);
|
2020-03-27 16:07:55 +00:00
|
|
|
runApp(MyApp2());
|
2020-03-24 19:59:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
class MyApp extends StatelessWidget {
|
|
|
|
// This widget is the root of your application.
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
logger.i("hello, world");
|
|
|
|
return ChangeNotifierProvider<PhotoProvider>.value(
|
|
|
|
value: provider,
|
|
|
|
child: MaterialApp(
|
|
|
|
title: 'Orma',
|
|
|
|
theme: ThemeData.dark(),
|
|
|
|
home: GalleryPage(path: provider.list[0]),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2020-03-27 16:07:55 +00:00
|
|
|
|
|
|
|
class MyApp2 extends StatelessWidget {
|
|
|
|
final PhotoLoader photoLoader = PhotoLoader();
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
final title = 'Orma';
|
|
|
|
return FutureBuilder<List<Photo>>(
|
|
|
|
future: photoLoader.loadPhotos(),
|
|
|
|
builder: (context, snapshot) {
|
|
|
|
Widget body;
|
|
|
|
if (snapshot.hasData) {
|
|
|
|
body = GridView.builder(
|
|
|
|
itemBuilder: _buildItem,
|
|
|
|
itemCount: snapshot.data.length,
|
|
|
|
gridDelegate:
|
|
|
|
SliverGridDelegateWithFixedCrossAxisCount(crossAxisCount: 4),
|
|
|
|
);
|
|
|
|
} else if (snapshot.hasError) {
|
|
|
|
body = Text("Error!");
|
|
|
|
} else {
|
|
|
|
body = Text("Loading");
|
|
|
|
}
|
|
|
|
return MaterialApp(
|
|
|
|
title: title,
|
|
|
|
theme: ThemeData.dark(),
|
|
|
|
home: Scaffold(
|
|
|
|
appBar: AppBar(
|
|
|
|
title: Text(title),
|
|
|
|
),
|
|
|
|
body: body),
|
|
|
|
);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
Widget _buildItem(BuildContext context, int index) {
|
2020-03-27 16:34:15 +00:00
|
|
|
var file = File(photoLoader.getPhotos()[index].localPath);
|
|
|
|
return GestureDetector(
|
|
|
|
onTap: () async {
|
|
|
|
routeToDetailPage(file, context);
|
|
|
|
},
|
|
|
|
child: Hero(
|
|
|
|
child: Image.file(file),
|
|
|
|
tag: 'photo_' + file.path,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
void routeToDetailPage(File file, BuildContext context) async {
|
|
|
|
final page = DetailPage(
|
|
|
|
file: file,
|
|
|
|
);
|
|
|
|
Navigator.of(context).push(
|
|
|
|
MaterialPageRoute(
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return page;
|
|
|
|
},
|
|
|
|
),
|
|
|
|
);
|
2020-03-27 16:07:55 +00:00
|
|
|
}
|
|
|
|
}
|