47 lines
1.5 KiB
Dart
47 lines
1.5 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter/widgets.dart';
|
|
import 'package:photos/models/collection_items.dart';
|
|
import 'package:photos/models/file.dart';
|
|
import 'package:photos/ui/viewer/search/serach_result_widgets/collection_result_widget.dart';
|
|
import 'package:photos/ui/viewer/search/serach_result_widgets/filename_result_widget.dart';
|
|
|
|
class SearchResultsSuggestions extends StatelessWidget {
|
|
final List<CollectionWithThumbnail> matchedCollectionsWithThumbnail;
|
|
final List<File> matchedFiles;
|
|
final List<dynamic> matchedLocations;
|
|
const SearchResultsSuggestions(
|
|
this.matchedCollectionsWithThumbnail,
|
|
this.matchedFiles,
|
|
this.matchedLocations, {
|
|
Key key,
|
|
}) : super(key: key);
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
List<dynamic> suggestions = [];
|
|
for (CollectionWithThumbnail c in matchedCollectionsWithThumbnail) {
|
|
suggestions.add(c);
|
|
}
|
|
for (File file in matchedFiles) {
|
|
suggestions.add(file);
|
|
}
|
|
return Container(
|
|
constraints:
|
|
BoxConstraints(maxHeight: MediaQuery.of(context).size.height * 0.6),
|
|
child: ListView.builder(
|
|
itemCount: suggestions.length,
|
|
itemBuilder: (context, index) {
|
|
dynamic value = suggestions[index];
|
|
if (value is File) {
|
|
return FilenameResultWidget(value);
|
|
} else if (value is CollectionWithThumbnail) {
|
|
return CollectionResultWidget(value);
|
|
} else {
|
|
throw StateError("Invalid/Unsupported value");
|
|
}
|
|
},
|
|
),
|
|
);
|
|
}
|
|
}
|