create file types and names section

This commit is contained in:
ashilkn 2024-02-23 20:43:42 +05:30
parent 064502a237
commit c773a64cfa
32 changed files with 209 additions and 0 deletions

BIN
assets/2.0x/type_AVI.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

BIN
assets/2.0x/type_GIF.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

BIN
assets/2.0x/type_HEIC.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

BIN
assets/2.0x/type_JPEG.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

BIN
assets/2.0x/type_JPG.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

BIN
assets/2.0x/type_MKV.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

BIN
assets/2.0x/type_MP4.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

BIN
assets/2.0x/type_PNG.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

BIN
assets/2.0x/type_WEBP.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 19 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

BIN
assets/3.0x/type_.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 38 KiB

BIN
assets/3.0x/type_AVI.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

BIN
assets/3.0x/type_GIF.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

BIN
assets/3.0x/type_HEIC.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 35 KiB

BIN
assets/3.0x/type_JPEG.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 37 KiB

BIN
assets/3.0x/type_JPG.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

BIN
assets/3.0x/type_MKV.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

BIN
assets/3.0x/type_MP4.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 37 KiB

BIN
assets/3.0x/type_WEBP.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 38 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 34 KiB

BIN
assets/type_AVI.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.5 KiB

BIN
assets/type_GIF.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.6 KiB

BIN
assets/type_HEIC.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.3 KiB

BIN
assets/type_JPEG.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.7 KiB

BIN
assets/type_JPG.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.5 KiB

BIN
assets/type_MKV.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.6 KiB

BIN
assets/type_MP4.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.6 KiB

BIN
assets/type_PNG.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.8 KiB

BIN
assets/type_WEBP.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 6 KiB

BIN
assets/type_unknown.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.7 KiB

View file

@ -0,0 +1,203 @@
import "dart:async";
import "package:flutter/material.dart";
import "package:photos/core/constants.dart";
import "package:photos/events/event.dart";
import "package:photos/models/search/generic_search_result.dart";
import "package:photos/models/search/recent_searches.dart";
import "package:photos/models/search/search_types.dart";
import "package:photos/theme/ente_theme.dart";
import "package:photos/ui/viewer/search/result/search_result_page.dart";
import "package:photos/ui/viewer/search/search_section_cta.dart";
import "package:photos/ui/viewer/search_tab/section_header.dart";
import "package:photos/utils/navigation_util.dart";
class FileTypeSection extends StatefulWidget {
final List<GenericSearchResult> fileTypesSearchResults;
const FileTypeSection(this.fileTypesSearchResults, {super.key});
@override
State<FileTypeSection> createState() => _FileTypeSectionState();
}
class _FileTypeSectionState extends State<FileTypeSection> {
late List<GenericSearchResult> _fileTypesSearchResults;
final streamSubscriptions = <StreamSubscription>[];
@override
void initState() {
super.initState();
_fileTypesSearchResults = widget.fileTypesSearchResults;
final streamsToListenTo =
SectionType.fileTypesAndExtension.sectionUpdateEvents();
for (Stream<Event> stream in streamsToListenTo) {
streamSubscriptions.add(
stream.listen((event) async {
_fileTypesSearchResults =
(await SectionType.fileTypesAndExtension.getData(
context,
limit: kSearchSectionLimit,
)) as List<GenericSearchResult>;
setState(() {});
}),
);
}
}
@override
void dispose() {
for (var subscriptions in streamSubscriptions) {
subscriptions.cancel();
}
super.dispose();
}
@override
void didUpdateWidget(covariant FileTypeSection oldWidget) {
super.didUpdateWidget(oldWidget);
_fileTypesSearchResults = widget.fileTypesSearchResults;
}
@override
Widget build(BuildContext context) {
if (_fileTypesSearchResults.isEmpty) {
final textTheme = getEnteTextTheme(context);
return Padding(
padding: const EdgeInsets.only(left: 12, right: 8),
child: Row(
children: [
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(
SectionType.fileTypesAndExtension.sectionTitle(context),
style: textTheme.largeBold,
),
const SizedBox(height: 24),
Padding(
padding: const EdgeInsets.only(left: 4),
child: Text(
SectionType.fileTypesAndExtension
.getEmptyStateText(context),
style: textTheme.smallMuted,
),
),
],
),
),
const SizedBox(width: 8),
const SearchSectionEmptyCTAIcon(SectionType.fileTypesAndExtension),
],
),
);
} else {
return Padding(
padding: const EdgeInsets.symmetric(vertical: 8),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
SectionHeader(
SectionType.fileTypesAndExtension,
hasMore:
(_fileTypesSearchResults.length >= kSearchSectionLimit - 1),
),
const SizedBox(height: 2),
SizedBox(
child: SingleChildScrollView(
padding: const EdgeInsets.symmetric(horizontal: 4.5),
physics: const BouncingScrollPhysics(),
scrollDirection: Axis.horizontal,
child: Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: _fileTypesSearchResults
.map(
(fileTypeSearchResult) =>
FileTypeRecommendation(fileTypeSearchResult),
)
.toList(),
),
),
),
],
),
);
}
}
}
class FileTypeRecommendation extends StatelessWidget {
static const knownTypesToAssetPath = {
"AVI": "assets/type_AVI.png",
"GIF": "assets/type_GIF.png",
"HEIC": "assets/type_HEIC.png",
"JPEG": "assets/type_JPEG.png",
"JPG": "assets/type_JPG.png",
"MKV": "assets/type_MKV.png",
"MP4": "assets/type_MP4.png",
"PNG": "assets/type_PNG.png",
"WEBP": "assets/type_WEBP.png",
};
final GenericSearchResult fileTypeSearchResult;
const FileTypeRecommendation(this.fileTypeSearchResult, {super.key});
@override
Widget build(BuildContext context) {
//remove 's' at end of extensions and use only 1st word if there exists
//multiple words.
final fileType = fileTypeSearchResult.name
.call()
.replaceAll(RegExp(r'.$'), "")
.split(" ")
.first;
final assetPath = knownTypesToAssetPath[fileType];
return Padding(
padding: const EdgeInsets.symmetric(horizontal: 8),
child: ConstrainedBox(
constraints: const BoxConstraints(maxHeight: 60),
child: GestureDetector(
onTap: () {
RecentSearches().add(fileTypeSearchResult.name());
if (fileTypeSearchResult.onResultTap != null) {
fileTypeSearchResult.onResultTap!(context);
} else {
routeToPage(
context,
SearchResultPage(fileTypeSearchResult),
);
}
},
child: assetPath != null
? Image.asset(assetPath)
: Stack(
alignment: Alignment.center,
children: [
Image.asset(
"assets/type_unknown.png",
),
Positioned(
bottom: 12,
child: ConstrainedBox(
constraints: const BoxConstraints(maxWidth: 48),
child: FittedBox(
fit: BoxFit.scaleDown,
child: Text(
fileType,
style: const TextStyle(
fontSize: 17.43,
fontFamily: "Inter",
),
textAlign: TextAlign.center,
maxLines: 1,
),
),
),
),
],
),
),
),
);
}
}

View file

@ -15,6 +15,7 @@ import "package:photos/ui/viewer/search/tab_empty_state.dart";
import 'package:photos/ui/viewer/search_tab/albums_section.dart';
import "package:photos/ui/viewer/search_tab/contacts_section.dart";
import "package:photos/ui/viewer/search_tab/descriptions_section.dart";
import "package:photos/ui/viewer/search_tab/file_type_section.dart";
import "package:photos/ui/viewer/search_tab/locations_section.dart";
import "package:photos/ui/viewer/search_tab/moments_section.dart";
@ -126,6 +127,11 @@ class _AllSearchSectionsState extends State<AllSearchSections> {
snapshot.data!.elementAt(index)
as List<GenericSearchResult>,
);
case SectionType.fileTypesAndExtension:
return FileTypeSection(
snapshot.data!.elementAt(index)
as List<GenericSearchResult>,
);
default:
return SearchSection(
sectionType: searchTypes[index],