1
0
mirror of https://github.com/git-touch/git-touch synced 2024-12-25 15:22:38 +01:00
git-touch-android-ios-app/lib/screens/gitea_object.dart
2020-01-31 11:28:14 +08:00

74 lines
2.3 KiB
Dart

import 'package:flutter/material.dart';
import 'package:git_touch/models/auth.dart';
import 'package:git_touch/models/gitea.dart';
import 'package:git_touch/models/theme.dart';
import 'package:git_touch/scaffolds/refresh_stateful.dart';
import 'package:git_touch/utils/utils.dart';
import 'package:git_touch/widgets/action_entry.dart';
import 'package:git_touch/widgets/app_bar_title.dart';
import 'package:git_touch/widgets/blob_view.dart';
import 'package:git_touch/widgets/object_tree.dart';
import 'package:provider/provider.dart';
final giteaObjectRouter = RouterScreen(
'/gitea/:owner/:name/blob',
(context, params) => GiteaObjectScreen(
params['owner'].first,
params['name'].first,
path: params['path']?.first,
),
);
class GiteaObjectScreen extends StatelessWidget {
final String owner;
final String name;
final String path;
GiteaObjectScreen(this.owner, this.name, {this.path});
@override
Widget build(BuildContext context) {
return RefreshStatefulScaffold(
title: AppBarTitle(path ?? 'Files'),
fetchData: () async {
final suffix = path == null ? '' : '/$path';
final res = await Provider.of<AuthModel>(context)
.fetchGitea('/repos/$owner/$name/contents$suffix');
return res;
},
actionBuilder: (p, _) {
if (p is List) {
return null;
} else {
final theme = Provider.of<ThemeModel>(context);
return ActionEntry(
iconData: Icons.settings,
onTap: () {
theme.push(context, '/choose-code-theme');
},
);
}
},
bodyBuilder: (p, _) {
if (p is List) {
final items = p.map((t) => GiteaTree.fromJson(t)).toList();
items.sort((a, b) {
return sortByKey('dir', a.type, b.type);
});
return ObjectTree(items: [
for (var v in items)
ObjectTreeItem(
name: v.name,
type: v.type,
size: v.type == 'file' ? v.size : null,
url: '/gitea/$owner/$name/blob?path=${v.path.urlencode}',
),
]);
} else {
final v = GiteaBlob.fromJson(p);
return BlobView(v.name, base64Text: v.content);
}
},
);
}
}