|
@@ -3,26 +3,47 @@ import 'dart:convert';
|
|
import 'package:collection/collection.dart';
|
|
import 'package:collection/collection.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
|
|
|
|
|
|
+<<<<<<< HEAD
|
|
|
|
+=======
|
|
|
|
+import 'package:immich_mobile/modules/search/services/search.service.dart';
|
|
|
|
+
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
class SearchPageState {
|
|
class SearchPageState {
|
|
final String searchTerm;
|
|
final String searchTerm;
|
|
final bool isSearchEnabled;
|
|
final bool isSearchEnabled;
|
|
final List<String> searchSuggestion;
|
|
final List<String> searchSuggestion;
|
|
|
|
+<<<<<<< HEAD
|
|
|
|
+=======
|
|
|
|
+ final List<String> userSuggestedSearchTerms;
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
|
|
|
|
SearchPageState({
|
|
SearchPageState({
|
|
required this.searchTerm,
|
|
required this.searchTerm,
|
|
required this.isSearchEnabled,
|
|
required this.isSearchEnabled,
|
|
required this.searchSuggestion,
|
|
required this.searchSuggestion,
|
|
|
|
+<<<<<<< HEAD
|
|
|
|
+=======
|
|
|
|
+ required this.userSuggestedSearchTerms,
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
});
|
|
});
|
|
|
|
|
|
SearchPageState copyWith({
|
|
SearchPageState copyWith({
|
|
String? searchTerm,
|
|
String? searchTerm,
|
|
bool? isSearchEnabled,
|
|
bool? isSearchEnabled,
|
|
List<String>? searchSuggestion,
|
|
List<String>? searchSuggestion,
|
|
|
|
+<<<<<<< HEAD
|
|
|
|
+=======
|
|
|
|
+ List<String>? userSuggestedSearchTerms,
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
}) {
|
|
}) {
|
|
return SearchPageState(
|
|
return SearchPageState(
|
|
searchTerm: searchTerm ?? this.searchTerm,
|
|
searchTerm: searchTerm ?? this.searchTerm,
|
|
isSearchEnabled: isSearchEnabled ?? this.isSearchEnabled,
|
|
isSearchEnabled: isSearchEnabled ?? this.isSearchEnabled,
|
|
searchSuggestion: searchSuggestion ?? this.searchSuggestion,
|
|
searchSuggestion: searchSuggestion ?? this.searchSuggestion,
|
|
|
|
+<<<<<<< HEAD
|
|
|
|
+=======
|
|
|
|
+ userSuggestedSearchTerms: userSuggestedSearchTerms ?? this.userSuggestedSearchTerms,
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
);
|
|
);
|
|
}
|
|
}
|
|
|
|
|
|
@@ -31,6 +52,10 @@ class SearchPageState {
|
|
'searchTerm': searchTerm,
|
|
'searchTerm': searchTerm,
|
|
'isSearchEnabled': isSearchEnabled,
|
|
'isSearchEnabled': isSearchEnabled,
|
|
'searchSuggestion': searchSuggestion,
|
|
'searchSuggestion': searchSuggestion,
|
|
|
|
+<<<<<<< HEAD
|
|
|
|
+=======
|
|
|
|
+ 'userSuggestedSearchTerms': userSuggestedSearchTerms,
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
};
|
|
};
|
|
}
|
|
}
|
|
|
|
|
|
@@ -39,6 +64,10 @@ class SearchPageState {
|
|
searchTerm: map['searchTerm'] ?? '',
|
|
searchTerm: map['searchTerm'] ?? '',
|
|
isSearchEnabled: map['isSearchEnabled'] ?? false,
|
|
isSearchEnabled: map['isSearchEnabled'] ?? false,
|
|
searchSuggestion: List<String>.from(map['searchSuggestion']),
|
|
searchSuggestion: List<String>.from(map['searchSuggestion']),
|
|
|
|
+<<<<<<< HEAD
|
|
|
|
+=======
|
|
|
|
+ userSuggestedSearchTerms: List<String>.from(map['userSuggestedSearchTerms']),
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
);
|
|
);
|
|
}
|
|
}
|
|
|
|
|
|
@@ -47,8 +76,14 @@ class SearchPageState {
|
|
factory SearchPageState.fromJson(String source) => SearchPageState.fromMap(json.decode(source));
|
|
factory SearchPageState.fromJson(String source) => SearchPageState.fromMap(json.decode(source));
|
|
|
|
|
|
@override
|
|
@override
|
|
|
|
+<<<<<<< HEAD
|
|
String toString() =>
|
|
String toString() =>
|
|
'SearchPageState(searchTerm: $searchTerm, isSearchEnabled: $isSearchEnabled, searchSuggestion: $searchSuggestion)';
|
|
'SearchPageState(searchTerm: $searchTerm, isSearchEnabled: $isSearchEnabled, searchSuggestion: $searchSuggestion)';
|
|
|
|
+=======
|
|
|
|
+ String toString() {
|
|
|
|
+ return 'SearchPageState(searchTerm: $searchTerm, isSearchEnabled: $isSearchEnabled, searchSuggestion: $searchSuggestion, userSuggestedSearchTerms: $userSuggestedSearchTerms)';
|
|
|
|
+ }
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
|
|
|
|
@override
|
|
@override
|
|
bool operator ==(Object other) {
|
|
bool operator ==(Object other) {
|
|
@@ -58,11 +93,25 @@ class SearchPageState {
|
|
return other is SearchPageState &&
|
|
return other is SearchPageState &&
|
|
other.searchTerm == searchTerm &&
|
|
other.searchTerm == searchTerm &&
|
|
other.isSearchEnabled == isSearchEnabled &&
|
|
other.isSearchEnabled == isSearchEnabled &&
|
|
|
|
+<<<<<<< HEAD
|
|
listEquals(other.searchSuggestion, searchSuggestion);
|
|
listEquals(other.searchSuggestion, searchSuggestion);
|
|
}
|
|
}
|
|
|
|
|
|
@override
|
|
@override
|
|
int get hashCode => searchTerm.hashCode ^ isSearchEnabled.hashCode ^ searchSuggestion.hashCode;
|
|
int get hashCode => searchTerm.hashCode ^ isSearchEnabled.hashCode ^ searchSuggestion.hashCode;
|
|
|
|
+=======
|
|
|
|
+ listEquals(other.searchSuggestion, searchSuggestion) &&
|
|
|
|
+ listEquals(other.userSuggestedSearchTerms, userSuggestedSearchTerms);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @override
|
|
|
|
+ int get hashCode {
|
|
|
|
+ return searchTerm.hashCode ^
|
|
|
|
+ isSearchEnabled.hashCode ^
|
|
|
|
+ searchSuggestion.hashCode ^
|
|
|
|
+ userSuggestedSearchTerms.hashCode;
|
|
|
|
+ }
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
}
|
|
}
|
|
|
|
|
|
class SearchPageStateNotifier extends StateNotifier<SearchPageState> {
|
|
class SearchPageStateNotifier extends StateNotifier<SearchPageState> {
|
|
@@ -72,9 +121,18 @@ class SearchPageStateNotifier extends StateNotifier<SearchPageState> {
|
|
searchTerm: "",
|
|
searchTerm: "",
|
|
isSearchEnabled: false,
|
|
isSearchEnabled: false,
|
|
searchSuggestion: [],
|
|
searchSuggestion: [],
|
|
|
|
+<<<<<<< HEAD
|
|
),
|
|
),
|
|
);
|
|
);
|
|
|
|
|
|
|
|
+=======
|
|
|
|
+ userSuggestedSearchTerms: [],
|
|
|
|
+ ),
|
|
|
|
+ );
|
|
|
|
+
|
|
|
|
+ final SearchService _searchService = SearchService();
|
|
|
|
+
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
void enableSearch() {
|
|
void enableSearch() {
|
|
state = state.copyWith(isSearchEnabled: true);
|
|
state = state.copyWith(isSearchEnabled: true);
|
|
}
|
|
}
|
|
@@ -90,7 +148,11 @@ class SearchPageStateNotifier extends StateNotifier<SearchPageState> {
|
|
}
|
|
}
|
|
|
|
|
|
void _getSearchSuggestion(String searchTerm) {
|
|
void _getSearchSuggestion(String searchTerm) {
|
|
|
|
+<<<<<<< HEAD
|
|
var searchList = ['January', '01 2022', 'feburary', "February", 'home', '3413'];
|
|
var searchList = ['January', '01 2022', 'feburary', "February", 'home', '3413'];
|
|
|
|
+=======
|
|
|
|
+ var searchList = state.userSuggestedSearchTerms;
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
|
|
|
|
var newList = searchList.where((e) => e.toLowerCase().contains(searchTerm));
|
|
var newList = searchList.where((e) => e.toLowerCase().contains(searchTerm));
|
|
|
|
|
|
@@ -100,6 +162,15 @@ class SearchPageStateNotifier extends StateNotifier<SearchPageState> {
|
|
state = state.copyWith(searchSuggestion: []);
|
|
state = state.copyWith(searchSuggestion: []);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
+<<<<<<< HEAD
|
|
|
|
+=======
|
|
|
|
+
|
|
|
|
+ void getSuggestedSearchTerms() async {
|
|
|
|
+ var userSuggestedSearchTerms = await _searchService.getUserSuggestedSearchTerms();
|
|
|
|
+
|
|
|
|
+ state = state.copyWith(userSuggestedSearchTerms: userSuggestedSearchTerms);
|
|
|
|
+ }
|
|
|
|
+>>>>>>> bfde3084924e247bc8f7004babf38605fe341a18
|
|
}
|
|
}
|
|
|
|
|
|
final searchPageStateProvider = StateNotifierProvider<SearchPageStateNotifier, SearchPageState>((ref) {
|
|
final searchPageStateProvider = StateNotifierProvider<SearchPageStateNotifier, SearchPageState>((ref) {
|