git-touch-android-ios-app/lib/screens/bb_object.dart

78 lines
2.5 KiB
Dart
Raw Normal View History

2020-02-02 12:50:00 +01:00
import 'dart:convert';
2022-09-13 17:52:35 +02:00
2022-09-17 14:35:45 +02:00
import 'package:flutter/widgets.dart';
2022-10-07 18:55:47 +02:00
import 'package:flutter_vector_icons/flutter_vector_icons.dart';
2020-02-02 12:50:00 +01:00
import 'package:git_touch/models/auth.dart';
import 'package:git_touch/models/bitbucket.dart';
2022-09-13 17:52:35 +02:00
import 'package:git_touch/scaffolds/list_stateful.dart';
2020-02-02 12:50:00 +01:00
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';
2022-10-03 19:05:29 +02:00
import 'package:path/path.dart' as p;
2020-02-02 12:50:00 +01:00
import 'package:provider/provider.dart';
2022-09-13 17:52:35 +02:00
import 'package:universal_io/io.dart';
2020-02-02 12:50:00 +01:00
class BbObjectScreen extends StatelessWidget {
2022-09-21 18:28:21 +02:00
const BbObjectScreen(this.owner, this.name, this.ref, {this.path});
2020-02-02 12:50:00 +01:00
final String owner;
final String name;
final String ref;
2021-05-16 09:16:35 +02:00
final String? path;
2020-02-02 12:50:00 +01:00
@override
Widget build(BuildContext context) {
2020-02-02 16:02:58 +01:00
final auth = Provider.of<AuthModel>(context);
return ListStatefulScaffold<dynamic, String?>(
2020-02-02 12:50:00 +01:00
title: AppBarTitle(path ?? 'Files'),
fetch: (next) async {
final res = await auth.fetchBb(
next ?? '/repositories/$owner/$name/src/$ref/${path ?? ''}');
2020-02-02 12:50:00 +01:00
if (res.headers[HttpHeaders.contentTypeHeader] == 'text/plain') {
return ListPayload(
cursor: '',
hasMore: false,
items: [utf8.decode(res.bodyBytes)],
2020-02-02 12:50:00 +01:00
);
} else {
final v =
BbPagination.fromJson(json.decode(utf8.decode(res.bodyBytes)));
final items = [for (var t in v.values) BbTree.fromJson(t)];
items.sort((a, b) {
return sortByKey('dir', a.type, b.type);
});
return ListPayload(
cursor: v.next,
hasMore: v.next != null,
items: items,
);
2020-02-02 12:50:00 +01:00
}
},
itemBuilder: (pl) {
2020-02-02 12:50:00 +01:00
if (pl is String) {
return BlobView(path, text: pl);
} else if (pl is BbTree) {
2022-09-23 19:49:27 +02:00
return createObjectTreeItem(
2022-10-03 19:05:29 +02:00
name: p.basename(pl.path),
2022-09-23 19:49:27 +02:00
type: pl.type,
// size: v.type == 'commit_file' ? v.size : null,
size: pl.size,
url: '/bitbucket/$owner/$name/src/$ref?path=${pl.path.urlencode}',
downloadUrl: pl.links!['self']['href'] as String?,
);
2020-02-02 12:50:00 +01:00
} else {
return Container();
2020-02-02 12:50:00 +01:00
}
},
actionBuilder: () {
2022-09-06 18:28:12 +02:00
return const ActionEntry(
iconData: Ionicons.cog,
url: '/choose-code-theme',
);
},
2020-02-02 12:50:00 +01:00
);
}
}