🌐 Localized the dashboard and the command pattle
This commit is contained in:
@@ -1,5 +1,7 @@
|
||||
import 'package:easy_localization/easy_localization.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:freezed_annotation/freezed_annotation.dart';
|
||||
import 'package:material_symbols_icons/symbols.dart';
|
||||
|
||||
part 'route_item.freezed.dart';
|
||||
|
||||
@@ -9,6 +11,221 @@ sealed class RouteItem with _$RouteItem {
|
||||
required String name,
|
||||
required String path,
|
||||
required String description,
|
||||
@Default([]) List<String> searchableAliases,
|
||||
required IconData icon,
|
||||
}) = _RouteItem;
|
||||
}
|
||||
|
||||
final List<RouteItem> kAvailableRoutes = [
|
||||
RouteItem(
|
||||
name: 'dashboard'.tr(),
|
||||
path: '/',
|
||||
description: 'dashboardDescription'.tr(),
|
||||
searchableAliases: ['dashboard', 'home'],
|
||||
icon: Symbols.home,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'explore'.tr(),
|
||||
path: '/explore',
|
||||
description: 'exploreDescription'.tr(),
|
||||
searchableAliases: ['explore', 'discover'],
|
||||
icon: Symbols.explore,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'searchPosts'.tr(),
|
||||
path: '/posts/search',
|
||||
description: 'searchPostsDescription'.tr(),
|
||||
searchableAliases: ['search', 'posts'],
|
||||
icon: Symbols.search,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'postShuffle'.tr(),
|
||||
path: '/posts/shuffle',
|
||||
description: 'postShuffleDescription'.tr(),
|
||||
searchableAliases: ['shuffle', 'random', 'posts'],
|
||||
icon: Symbols.shuffle,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'postTagsCategories'.tr(),
|
||||
path: '/posts/categories',
|
||||
description: 'postTagsCategoriesDescription'.tr(),
|
||||
searchableAliases: ['tags', 'categories', 'posts'],
|
||||
icon: Symbols.category,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'discoverRealms'.tr(),
|
||||
path: '/discovery/realms',
|
||||
description: 'discoverRealmsDescription'.tr(),
|
||||
searchableAliases: ['realms', 'groups', 'communities'],
|
||||
icon: Symbols.public,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'chat'.tr(),
|
||||
path: '/chat',
|
||||
description: 'chatDescription'.tr(),
|
||||
searchableAliases: ['chat', 'messages', 'conversations', 'dm'],
|
||||
icon: Symbols.chat,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'realms'.tr(),
|
||||
path: '/realms',
|
||||
description: 'realmsDescription'.tr(),
|
||||
searchableAliases: ['realms', 'groups', 'communities'],
|
||||
icon: Symbols.group,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'account'.tr(),
|
||||
path: '/account',
|
||||
description: 'accountDescription'.tr(),
|
||||
searchableAliases: ['account', 'me', 'profile', 'user'],
|
||||
icon: Symbols.person,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'stickerMarketplace'.tr(),
|
||||
path: '/stickers',
|
||||
description: 'stickerMarketplaceDescription'.tr(),
|
||||
searchableAliases: ['stickers', 'marketplace', 'emojis', 'emojis'],
|
||||
icon: Symbols.emoji_emotions,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'webFeeds'.tr(),
|
||||
path: '/feeds',
|
||||
description: 'webFeedsDescription'.tr(),
|
||||
searchableAliases: ['feeds', 'web feeds', 'rss', 'news'],
|
||||
icon: Symbols.feed,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'wallet'.tr(),
|
||||
path: '/account/wallet',
|
||||
description: 'walletDescription'.tr(),
|
||||
searchableAliases: [
|
||||
'wallet',
|
||||
'balance',
|
||||
'money',
|
||||
'source points',
|
||||
'gold points',
|
||||
'nsp',
|
||||
'shd',
|
||||
],
|
||||
icon: Symbols.account_balance_wallet,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'relationships'.tr(),
|
||||
path: '/account/relationships',
|
||||
description: 'relationshipsDescription'.tr(),
|
||||
searchableAliases: ['relationships', 'friends', 'block list', 'blocks'],
|
||||
icon: Symbols.people,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'updateYourProfile'.tr(),
|
||||
path: '/account/me/update',
|
||||
description: 'updateYourProfileDescription'.tr(),
|
||||
searchableAliases: ['profile', 'update', 'edit', 'my profile'],
|
||||
icon: Symbols.edit,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'leveling'.tr(),
|
||||
path: '/account/me/leveling',
|
||||
description: 'levelingDescription'.tr(),
|
||||
searchableAliases: [
|
||||
'leveling',
|
||||
'level',
|
||||
'levels',
|
||||
'subscriptions',
|
||||
'social credits',
|
||||
],
|
||||
icon: Symbols.trending_up,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'accountSettings'.tr(),
|
||||
path: '/account/me/settings',
|
||||
description: 'accountSettingsDescription'.tr(),
|
||||
searchableAliases: [
|
||||
'settings',
|
||||
'preferences',
|
||||
'account',
|
||||
'account settings',
|
||||
],
|
||||
icon: Symbols.settings,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'abuseReports'.tr(),
|
||||
path: '/safety/reports/me',
|
||||
description: 'abuseReportsDescription'.tr(),
|
||||
searchableAliases: ['reports', 'abuse', 'safety'],
|
||||
icon: Symbols.report,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'files'.tr(),
|
||||
path: '/files',
|
||||
description: 'filesDescription'.tr(),
|
||||
searchableAliases: ['files', 'folders', 'storage', 'drive', 'cloud'],
|
||||
icon: Symbols.folder,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'aiThought'.tr(),
|
||||
path: '/thought',
|
||||
description: 'aiThoughtTitle'.tr(),
|
||||
searchableAliases: ['thought', 'ai', 'ai thought'],
|
||||
icon: Symbols.psychology,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'creatorHub'.tr(),
|
||||
path: '/creators',
|
||||
description: 'creatorHubDescription'.tr(),
|
||||
searchableAliases: ['creators', 'hub', 'creator hub', 'creators hub'],
|
||||
icon: Symbols.create,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'developerPortal'.tr(),
|
||||
path: '/developers',
|
||||
description: 'developerPortalDescription'.tr(),
|
||||
searchableAliases: [
|
||||
'developers',
|
||||
'dev',
|
||||
'developer',
|
||||
'developer hub',
|
||||
'developers hub',
|
||||
],
|
||||
icon: Symbols.code,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'debugLogs'.tr(),
|
||||
path: '/logs',
|
||||
description: 'debugLogsDescription'.tr(),
|
||||
searchableAliases: ['logs', 'debug', 'debug logs'],
|
||||
icon: Symbols.bug_report,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'webArticlesStand'.tr(),
|
||||
path: '/feeds/articles',
|
||||
description: 'webArticlesStandDescription'.tr(),
|
||||
searchableAliases: ['articles', 'stand', 'feed', 'web feed'],
|
||||
icon: Symbols.article,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'appSettings'.tr(),
|
||||
path: '/settings',
|
||||
description: 'appSettingsDescription'.tr(),
|
||||
searchableAliases: ['settings', 'preferences', 'app', 'app settings'],
|
||||
icon: Symbols.settings,
|
||||
),
|
||||
RouteItem(
|
||||
name: 'about'.tr(),
|
||||
path: '/about',
|
||||
description: 'about'.tr(),
|
||||
searchableAliases: ['about', 'info'],
|
||||
icon: Symbols.info,
|
||||
),
|
||||
];
|
||||
|
||||
@freezed
|
||||
sealed class SpecialAction with _$SpecialAction {
|
||||
const factory SpecialAction({
|
||||
required String name,
|
||||
required String description,
|
||||
required IconData icon,
|
||||
required VoidCallback action,
|
||||
@Default([]) List<String> searchableAliases,
|
||||
}) = _SpecialAction;
|
||||
}
|
||||
|
||||
@@ -14,7 +14,7 @@ T _$identity<T>(T value) => value;
|
||||
/// @nodoc
|
||||
mixin _$RouteItem {
|
||||
|
||||
String get name; String get path; String get description; IconData get icon;
|
||||
String get name; String get path; String get description; List<String> get searchableAliases; IconData get icon;
|
||||
/// Create a copy of RouteItem
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
||||
@@ -25,16 +25,16 @@ $RouteItemCopyWith<RouteItem> get copyWith => _$RouteItemCopyWithImpl<RouteItem>
|
||||
|
||||
@override
|
||||
bool operator ==(Object other) {
|
||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is RouteItem&&(identical(other.name, name) || other.name == name)&&(identical(other.path, path) || other.path == path)&&(identical(other.description, description) || other.description == description)&&(identical(other.icon, icon) || other.icon == icon));
|
||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is RouteItem&&(identical(other.name, name) || other.name == name)&&(identical(other.path, path) || other.path == path)&&(identical(other.description, description) || other.description == description)&&const DeepCollectionEquality().equals(other.searchableAliases, searchableAliases)&&(identical(other.icon, icon) || other.icon == icon));
|
||||
}
|
||||
|
||||
|
||||
@override
|
||||
int get hashCode => Object.hash(runtimeType,name,path,description,icon);
|
||||
int get hashCode => Object.hash(runtimeType,name,path,description,const DeepCollectionEquality().hash(searchableAliases),icon);
|
||||
|
||||
@override
|
||||
String toString() {
|
||||
return 'RouteItem(name: $name, path: $path, description: $description, icon: $icon)';
|
||||
return 'RouteItem(name: $name, path: $path, description: $description, searchableAliases: $searchableAliases, icon: $icon)';
|
||||
}
|
||||
|
||||
|
||||
@@ -45,7 +45,7 @@ abstract mixin class $RouteItemCopyWith<$Res> {
|
||||
factory $RouteItemCopyWith(RouteItem value, $Res Function(RouteItem) _then) = _$RouteItemCopyWithImpl;
|
||||
@useResult
|
||||
$Res call({
|
||||
String name, String path, String description, IconData icon
|
||||
String name, String path, String description, List<String> searchableAliases, IconData icon
|
||||
});
|
||||
|
||||
|
||||
@@ -62,12 +62,13 @@ class _$RouteItemCopyWithImpl<$Res>
|
||||
|
||||
/// Create a copy of RouteItem
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@pragma('vm:prefer-inline') @override $Res call({Object? name = null,Object? path = null,Object? description = null,Object? icon = null,}) {
|
||||
@pragma('vm:prefer-inline') @override $Res call({Object? name = null,Object? path = null,Object? description = null,Object? searchableAliases = null,Object? icon = null,}) {
|
||||
return _then(_self.copyWith(
|
||||
name: null == name ? _self.name : name // ignore: cast_nullable_to_non_nullable
|
||||
as String,path: null == path ? _self.path : path // ignore: cast_nullable_to_non_nullable
|
||||
as String,description: null == description ? _self.description : description // ignore: cast_nullable_to_non_nullable
|
||||
as String,icon: null == icon ? _self.icon : icon // ignore: cast_nullable_to_non_nullable
|
||||
as String,searchableAliases: null == searchableAliases ? _self.searchableAliases : searchableAliases // ignore: cast_nullable_to_non_nullable
|
||||
as List<String>,icon: null == icon ? _self.icon : icon // ignore: cast_nullable_to_non_nullable
|
||||
as IconData,
|
||||
));
|
||||
}
|
||||
@@ -150,10 +151,10 @@ return $default(_that);case _:
|
||||
/// }
|
||||
/// ```
|
||||
|
||||
@optionalTypeArgs TResult maybeWhen<TResult extends Object?>(TResult Function( String name, String path, String description, IconData icon)? $default,{required TResult orElse(),}) {final _that = this;
|
||||
@optionalTypeArgs TResult maybeWhen<TResult extends Object?>(TResult Function( String name, String path, String description, List<String> searchableAliases, IconData icon)? $default,{required TResult orElse(),}) {final _that = this;
|
||||
switch (_that) {
|
||||
case _RouteItem() when $default != null:
|
||||
return $default(_that.name,_that.path,_that.description,_that.icon);case _:
|
||||
return $default(_that.name,_that.path,_that.description,_that.searchableAliases,_that.icon);case _:
|
||||
return orElse();
|
||||
|
||||
}
|
||||
@@ -171,10 +172,10 @@ return $default(_that.name,_that.path,_that.description,_that.icon);case _:
|
||||
/// }
|
||||
/// ```
|
||||
|
||||
@optionalTypeArgs TResult when<TResult extends Object?>(TResult Function( String name, String path, String description, IconData icon) $default,) {final _that = this;
|
||||
@optionalTypeArgs TResult when<TResult extends Object?>(TResult Function( String name, String path, String description, List<String> searchableAliases, IconData icon) $default,) {final _that = this;
|
||||
switch (_that) {
|
||||
case _RouteItem():
|
||||
return $default(_that.name,_that.path,_that.description,_that.icon);}
|
||||
return $default(_that.name,_that.path,_that.description,_that.searchableAliases,_that.icon);}
|
||||
}
|
||||
/// A variant of `when` that fallback to returning `null`
|
||||
///
|
||||
@@ -188,10 +189,10 @@ return $default(_that.name,_that.path,_that.description,_that.icon);}
|
||||
/// }
|
||||
/// ```
|
||||
|
||||
@optionalTypeArgs TResult? whenOrNull<TResult extends Object?>(TResult? Function( String name, String path, String description, IconData icon)? $default,) {final _that = this;
|
||||
@optionalTypeArgs TResult? whenOrNull<TResult extends Object?>(TResult? Function( String name, String path, String description, List<String> searchableAliases, IconData icon)? $default,) {final _that = this;
|
||||
switch (_that) {
|
||||
case _RouteItem() when $default != null:
|
||||
return $default(_that.name,_that.path,_that.description,_that.icon);case _:
|
||||
return $default(_that.name,_that.path,_that.description,_that.searchableAliases,_that.icon);case _:
|
||||
return null;
|
||||
|
||||
}
|
||||
@@ -203,12 +204,19 @@ return $default(_that.name,_that.path,_that.description,_that.icon);case _:
|
||||
|
||||
|
||||
class _RouteItem implements RouteItem {
|
||||
const _RouteItem({required this.name, required this.path, required this.description, required this.icon});
|
||||
const _RouteItem({required this.name, required this.path, required this.description, final List<String> searchableAliases = const [], required this.icon}): _searchableAliases = searchableAliases;
|
||||
|
||||
|
||||
@override final String name;
|
||||
@override final String path;
|
||||
@override final String description;
|
||||
final List<String> _searchableAliases;
|
||||
@override@JsonKey() List<String> get searchableAliases {
|
||||
if (_searchableAliases is EqualUnmodifiableListView) return _searchableAliases;
|
||||
// ignore: implicit_dynamic_type
|
||||
return EqualUnmodifiableListView(_searchableAliases);
|
||||
}
|
||||
|
||||
@override final IconData icon;
|
||||
|
||||
/// Create a copy of RouteItem
|
||||
@@ -221,16 +229,16 @@ _$RouteItemCopyWith<_RouteItem> get copyWith => __$RouteItemCopyWithImpl<_RouteI
|
||||
|
||||
@override
|
||||
bool operator ==(Object other) {
|
||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is _RouteItem&&(identical(other.name, name) || other.name == name)&&(identical(other.path, path) || other.path == path)&&(identical(other.description, description) || other.description == description)&&(identical(other.icon, icon) || other.icon == icon));
|
||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is _RouteItem&&(identical(other.name, name) || other.name == name)&&(identical(other.path, path) || other.path == path)&&(identical(other.description, description) || other.description == description)&&const DeepCollectionEquality().equals(other._searchableAliases, _searchableAliases)&&(identical(other.icon, icon) || other.icon == icon));
|
||||
}
|
||||
|
||||
|
||||
@override
|
||||
int get hashCode => Object.hash(runtimeType,name,path,description,icon);
|
||||
int get hashCode => Object.hash(runtimeType,name,path,description,const DeepCollectionEquality().hash(_searchableAliases),icon);
|
||||
|
||||
@override
|
||||
String toString() {
|
||||
return 'RouteItem(name: $name, path: $path, description: $description, icon: $icon)';
|
||||
return 'RouteItem(name: $name, path: $path, description: $description, searchableAliases: $searchableAliases, icon: $icon)';
|
||||
}
|
||||
|
||||
|
||||
@@ -241,7 +249,7 @@ abstract mixin class _$RouteItemCopyWith<$Res> implements $RouteItemCopyWith<$Re
|
||||
factory _$RouteItemCopyWith(_RouteItem value, $Res Function(_RouteItem) _then) = __$RouteItemCopyWithImpl;
|
||||
@override @useResult
|
||||
$Res call({
|
||||
String name, String path, String description, IconData icon
|
||||
String name, String path, String description, List<String> searchableAliases, IconData icon
|
||||
});
|
||||
|
||||
|
||||
@@ -258,17 +266,287 @@ class __$RouteItemCopyWithImpl<$Res>
|
||||
|
||||
/// Create a copy of RouteItem
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@override @pragma('vm:prefer-inline') $Res call({Object? name = null,Object? path = null,Object? description = null,Object? icon = null,}) {
|
||||
@override @pragma('vm:prefer-inline') $Res call({Object? name = null,Object? path = null,Object? description = null,Object? searchableAliases = null,Object? icon = null,}) {
|
||||
return _then(_RouteItem(
|
||||
name: null == name ? _self.name : name // ignore: cast_nullable_to_non_nullable
|
||||
as String,path: null == path ? _self.path : path // ignore: cast_nullable_to_non_nullable
|
||||
as String,description: null == description ? _self.description : description // ignore: cast_nullable_to_non_nullable
|
||||
as String,icon: null == icon ? _self.icon : icon // ignore: cast_nullable_to_non_nullable
|
||||
as String,searchableAliases: null == searchableAliases ? _self._searchableAliases : searchableAliases // ignore: cast_nullable_to_non_nullable
|
||||
as List<String>,icon: null == icon ? _self.icon : icon // ignore: cast_nullable_to_non_nullable
|
||||
as IconData,
|
||||
));
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
mixin _$SpecialAction {
|
||||
|
||||
String get name; String get description; IconData get icon; VoidCallback get action; List<String> get searchableAliases;
|
||||
/// Create a copy of SpecialAction
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
||||
@pragma('vm:prefer-inline')
|
||||
$SpecialActionCopyWith<SpecialAction> get copyWith => _$SpecialActionCopyWithImpl<SpecialAction>(this as SpecialAction, _$identity);
|
||||
|
||||
|
||||
|
||||
@override
|
||||
bool operator ==(Object other) {
|
||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is SpecialAction&&(identical(other.name, name) || other.name == name)&&(identical(other.description, description) || other.description == description)&&(identical(other.icon, icon) || other.icon == icon)&&(identical(other.action, action) || other.action == action)&&const DeepCollectionEquality().equals(other.searchableAliases, searchableAliases));
|
||||
}
|
||||
|
||||
|
||||
@override
|
||||
int get hashCode => Object.hash(runtimeType,name,description,icon,action,const DeepCollectionEquality().hash(searchableAliases));
|
||||
|
||||
@override
|
||||
String toString() {
|
||||
return 'SpecialAction(name: $name, description: $description, icon: $icon, action: $action, searchableAliases: $searchableAliases)';
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
abstract mixin class $SpecialActionCopyWith<$Res> {
|
||||
factory $SpecialActionCopyWith(SpecialAction value, $Res Function(SpecialAction) _then) = _$SpecialActionCopyWithImpl;
|
||||
@useResult
|
||||
$Res call({
|
||||
String name, String description, IconData icon, VoidCallback action, List<String> searchableAliases
|
||||
});
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
/// @nodoc
|
||||
class _$SpecialActionCopyWithImpl<$Res>
|
||||
implements $SpecialActionCopyWith<$Res> {
|
||||
_$SpecialActionCopyWithImpl(this._self, this._then);
|
||||
|
||||
final SpecialAction _self;
|
||||
final $Res Function(SpecialAction) _then;
|
||||
|
||||
/// Create a copy of SpecialAction
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@pragma('vm:prefer-inline') @override $Res call({Object? name = null,Object? description = null,Object? icon = null,Object? action = null,Object? searchableAliases = null,}) {
|
||||
return _then(_self.copyWith(
|
||||
name: null == name ? _self.name : name // ignore: cast_nullable_to_non_nullable
|
||||
as String,description: null == description ? _self.description : description // ignore: cast_nullable_to_non_nullable
|
||||
as String,icon: null == icon ? _self.icon : icon // ignore: cast_nullable_to_non_nullable
|
||||
as IconData,action: null == action ? _self.action : action // ignore: cast_nullable_to_non_nullable
|
||||
as VoidCallback,searchableAliases: null == searchableAliases ? _self.searchableAliases : searchableAliases // ignore: cast_nullable_to_non_nullable
|
||||
as List<String>,
|
||||
));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/// Adds pattern-matching-related methods to [SpecialAction].
|
||||
extension SpecialActionPatterns on SpecialAction {
|
||||
/// A variant of `map` that fallback to returning `orElse`.
|
||||
///
|
||||
/// It is equivalent to doing:
|
||||
/// ```dart
|
||||
/// switch (sealedClass) {
|
||||
/// case final Subclass value:
|
||||
/// return ...;
|
||||
/// case _:
|
||||
/// return orElse();
|
||||
/// }
|
||||
/// ```
|
||||
|
||||
@optionalTypeArgs TResult maybeMap<TResult extends Object?>(TResult Function( _SpecialAction value)? $default,{required TResult orElse(),}){
|
||||
final _that = this;
|
||||
switch (_that) {
|
||||
case _SpecialAction() when $default != null:
|
||||
return $default(_that);case _:
|
||||
return orElse();
|
||||
|
||||
}
|
||||
}
|
||||
/// A `switch`-like method, using callbacks.
|
||||
///
|
||||
/// Callbacks receives the raw object, upcasted.
|
||||
/// It is equivalent to doing:
|
||||
/// ```dart
|
||||
/// switch (sealedClass) {
|
||||
/// case final Subclass value:
|
||||
/// return ...;
|
||||
/// case final Subclass2 value:
|
||||
/// return ...;
|
||||
/// }
|
||||
/// ```
|
||||
|
||||
@optionalTypeArgs TResult map<TResult extends Object?>(TResult Function( _SpecialAction value) $default,){
|
||||
final _that = this;
|
||||
switch (_that) {
|
||||
case _SpecialAction():
|
||||
return $default(_that);}
|
||||
}
|
||||
/// A variant of `map` that fallback to returning `null`.
|
||||
///
|
||||
/// It is equivalent to doing:
|
||||
/// ```dart
|
||||
/// switch (sealedClass) {
|
||||
/// case final Subclass value:
|
||||
/// return ...;
|
||||
/// case _:
|
||||
/// return null;
|
||||
/// }
|
||||
/// ```
|
||||
|
||||
@optionalTypeArgs TResult? mapOrNull<TResult extends Object?>(TResult? Function( _SpecialAction value)? $default,){
|
||||
final _that = this;
|
||||
switch (_that) {
|
||||
case _SpecialAction() when $default != null:
|
||||
return $default(_that);case _:
|
||||
return null;
|
||||
|
||||
}
|
||||
}
|
||||
/// A variant of `when` that fallback to an `orElse` callback.
|
||||
///
|
||||
/// It is equivalent to doing:
|
||||
/// ```dart
|
||||
/// switch (sealedClass) {
|
||||
/// case Subclass(:final field):
|
||||
/// return ...;
|
||||
/// case _:
|
||||
/// return orElse();
|
||||
/// }
|
||||
/// ```
|
||||
|
||||
@optionalTypeArgs TResult maybeWhen<TResult extends Object?>(TResult Function( String name, String description, IconData icon, VoidCallback action, List<String> searchableAliases)? $default,{required TResult orElse(),}) {final _that = this;
|
||||
switch (_that) {
|
||||
case _SpecialAction() when $default != null:
|
||||
return $default(_that.name,_that.description,_that.icon,_that.action,_that.searchableAliases);case _:
|
||||
return orElse();
|
||||
|
||||
}
|
||||
}
|
||||
/// A `switch`-like method, using callbacks.
|
||||
///
|
||||
/// As opposed to `map`, this offers destructuring.
|
||||
/// It is equivalent to doing:
|
||||
/// ```dart
|
||||
/// switch (sealedClass) {
|
||||
/// case Subclass(:final field):
|
||||
/// return ...;
|
||||
/// case Subclass2(:final field2):
|
||||
/// return ...;
|
||||
/// }
|
||||
/// ```
|
||||
|
||||
@optionalTypeArgs TResult when<TResult extends Object?>(TResult Function( String name, String description, IconData icon, VoidCallback action, List<String> searchableAliases) $default,) {final _that = this;
|
||||
switch (_that) {
|
||||
case _SpecialAction():
|
||||
return $default(_that.name,_that.description,_that.icon,_that.action,_that.searchableAliases);}
|
||||
}
|
||||
/// A variant of `when` that fallback to returning `null`
|
||||
///
|
||||
/// It is equivalent to doing:
|
||||
/// ```dart
|
||||
/// switch (sealedClass) {
|
||||
/// case Subclass(:final field):
|
||||
/// return ...;
|
||||
/// case _:
|
||||
/// return null;
|
||||
/// }
|
||||
/// ```
|
||||
|
||||
@optionalTypeArgs TResult? whenOrNull<TResult extends Object?>(TResult? Function( String name, String description, IconData icon, VoidCallback action, List<String> searchableAliases)? $default,) {final _that = this;
|
||||
switch (_that) {
|
||||
case _SpecialAction() when $default != null:
|
||||
return $default(_that.name,_that.description,_that.icon,_that.action,_that.searchableAliases);case _:
|
||||
return null;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
|
||||
|
||||
class _SpecialAction implements SpecialAction {
|
||||
const _SpecialAction({required this.name, required this.description, required this.icon, required this.action, final List<String> searchableAliases = const []}): _searchableAliases = searchableAliases;
|
||||
|
||||
|
||||
@override final String name;
|
||||
@override final String description;
|
||||
@override final IconData icon;
|
||||
@override final VoidCallback action;
|
||||
final List<String> _searchableAliases;
|
||||
@override@JsonKey() List<String> get searchableAliases {
|
||||
if (_searchableAliases is EqualUnmodifiableListView) return _searchableAliases;
|
||||
// ignore: implicit_dynamic_type
|
||||
return EqualUnmodifiableListView(_searchableAliases);
|
||||
}
|
||||
|
||||
|
||||
/// Create a copy of SpecialAction
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@override @JsonKey(includeFromJson: false, includeToJson: false)
|
||||
@pragma('vm:prefer-inline')
|
||||
_$SpecialActionCopyWith<_SpecialAction> get copyWith => __$SpecialActionCopyWithImpl<_SpecialAction>(this, _$identity);
|
||||
|
||||
|
||||
|
||||
@override
|
||||
bool operator ==(Object other) {
|
||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is _SpecialAction&&(identical(other.name, name) || other.name == name)&&(identical(other.description, description) || other.description == description)&&(identical(other.icon, icon) || other.icon == icon)&&(identical(other.action, action) || other.action == action)&&const DeepCollectionEquality().equals(other._searchableAliases, _searchableAliases));
|
||||
}
|
||||
|
||||
|
||||
@override
|
||||
int get hashCode => Object.hash(runtimeType,name,description,icon,action,const DeepCollectionEquality().hash(_searchableAliases));
|
||||
|
||||
@override
|
||||
String toString() {
|
||||
return 'SpecialAction(name: $name, description: $description, icon: $icon, action: $action, searchableAliases: $searchableAliases)';
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
/// @nodoc
|
||||
abstract mixin class _$SpecialActionCopyWith<$Res> implements $SpecialActionCopyWith<$Res> {
|
||||
factory _$SpecialActionCopyWith(_SpecialAction value, $Res Function(_SpecialAction) _then) = __$SpecialActionCopyWithImpl;
|
||||
@override @useResult
|
||||
$Res call({
|
||||
String name, String description, IconData icon, VoidCallback action, List<String> searchableAliases
|
||||
});
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
/// @nodoc
|
||||
class __$SpecialActionCopyWithImpl<$Res>
|
||||
implements _$SpecialActionCopyWith<$Res> {
|
||||
__$SpecialActionCopyWithImpl(this._self, this._then);
|
||||
|
||||
final _SpecialAction _self;
|
||||
final $Res Function(_SpecialAction) _then;
|
||||
|
||||
/// Create a copy of SpecialAction
|
||||
/// with the given fields replaced by the non-null parameter values.
|
||||
@override @pragma('vm:prefer-inline') $Res call({Object? name = null,Object? description = null,Object? icon = null,Object? action = null,Object? searchableAliases = null,}) {
|
||||
return _then(_SpecialAction(
|
||||
name: null == name ? _self.name : name // ignore: cast_nullable_to_non_nullable
|
||||
as String,description: null == description ? _self.description : description // ignore: cast_nullable_to_non_nullable
|
||||
as String,icon: null == icon ? _self.icon : icon // ignore: cast_nullable_to_non_nullable
|
||||
as IconData,action: null == action ? _self.action : action // ignore: cast_nullable_to_non_nullable
|
||||
as VoidCallback,searchableAliases: null == searchableAliases ? _self._searchableAliases : searchableAliases // ignore: cast_nullable_to_non_nullable
|
||||
as List<String>,
|
||||
));
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
// dart format on
|
||||
|
||||
Reference in New Issue
Block a user