OpenMediacenterMobileFlutter/lib/navigation/video_feed.dart

73 lines
2.2 KiB
Dart
Raw Normal View History

2021-12-10 10:40:20 +00:00
import 'package:flutter/material.dart';
import '../api/video_api.dart';
2021-12-10 10:40:20 +00:00
import '../drawer/my_drawer.dart';
import '../preview/preview_grid.dart';
import '../types/tag.dart';
2021-12-10 10:40:20 +00:00
2022-08-30 09:57:50 +00:00
enum FilterTypes { DATE, LIKES, RANDOM, NAMES, LENGTH }
class VideoFeed extends StatefulWidget {
const VideoFeed({Key? key, this.tag}) : super(key: key);
final Tag? tag;
@override
State<StatefulWidget> createState() {
return VideoFeedState();
}
}
class VideoFeedState extends State<VideoFeed> {
2022-08-30 09:57:50 +00:00
FilterTypes filterSelection = FilterTypes.DATE;
Key _refreshKey = UniqueKey();
2021-12-10 10:40:20 +00:00
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.tag?.tagName ?? "OpenMediaCenter"),
2022-08-30 09:57:50 +00:00
actions: [
PopupMenuButton<FilterTypes>(
// add icon, by default "3 dot" icon
icon: Icon(Icons.filter_alt),
initialValue: filterSelection,
itemBuilder: (context) {
return [
PopupMenuItem<FilterTypes>(
value: FilterTypes.DATE,
child: Text("Date"),
),
PopupMenuItem<FilterTypes>(
value: FilterTypes.LIKES,
child: Text("Likes"),
),
PopupMenuItem<FilterTypes>(
value: FilterTypes.RANDOM,
child: Text("Random"),
),
PopupMenuItem<FilterTypes>(
value: FilterTypes.NAMES,
child: Text("Names"),
),
PopupMenuItem<FilterTypes>(
value: FilterTypes.LENGTH,
child: Text("Length"),
),
];
},
onSelected: (FilterTypes t) {
setState(() {
filterSelection = t;
_refreshKey = UniqueKey();
});
}),
],
),
body: PreviewGrid(
2022-08-30 09:57:50 +00:00
key: _refreshKey,
videoLoader: () => loadVideo(widget.tag, filterSelection.index),
),
drawer: widget.tag == null ? MyDrawer() : null);
2021-12-10 10:40:20 +00:00
}
}