fix: build errors and missing dependencies

This commit is contained in:
Dr.Blank 2025-05-22 06:43:46 +05:30
parent cc9a94de62
commit 2e3f4ad8d4
No known key found for this signature in database
GPG key ID: BA5F87FF0560C57B
5 changed files with 283 additions and 349 deletions

View file

@ -29,6 +29,7 @@ mixin _$AppSettings {
throw _privateConstructorUsedError;
ShakeDetectionSettings get shakeDetectionSettings =>
throw _privateConstructorUsedError;
HomePageSettings get homePageSettings => throw _privateConstructorUsedError;
/// Serializes this AppSettings to a JSON map.
Map<String, dynamic> toJson() => throw _privateConstructorUsedError;
@ -52,7 +53,8 @@ abstract class $AppSettingsCopyWith<$Res> {
SleepTimerSettings sleepTimerSettings,
DownloadSettings downloadSettings,
NotificationSettings notificationSettings,
ShakeDetectionSettings shakeDetectionSettings});
ShakeDetectionSettings shakeDetectionSettings,
HomePageSettings homePageSettings});
$ThemeSettingsCopyWith<$Res> get themeSettings;
$PlayerSettingsCopyWith<$Res> get playerSettings;
@ -60,6 +62,7 @@ abstract class $AppSettingsCopyWith<$Res> {
$DownloadSettingsCopyWith<$Res> get downloadSettings;
$NotificationSettingsCopyWith<$Res> get notificationSettings;
$ShakeDetectionSettingsCopyWith<$Res> get shakeDetectionSettings;
$HomePageSettingsCopyWith<$Res> get homePageSettings;
}
/// @nodoc
@ -83,6 +86,7 @@ class _$AppSettingsCopyWithImpl<$Res, $Val extends AppSettings>
Object? downloadSettings = null,
Object? notificationSettings = null,
Object? shakeDetectionSettings = null,
Object? homePageSettings = null,
}) {
return _then(_value.copyWith(
themeSettings: null == themeSettings
@ -109,6 +113,10 @@ class _$AppSettingsCopyWithImpl<$Res, $Val extends AppSettings>
? _value.shakeDetectionSettings
: shakeDetectionSettings // ignore: cast_nullable_to_non_nullable
as ShakeDetectionSettings,
homePageSettings: null == homePageSettings
? _value.homePageSettings
: homePageSettings // ignore: cast_nullable_to_non_nullable
as HomePageSettings,
) as $Val);
}
@ -174,6 +182,16 @@ class _$AppSettingsCopyWithImpl<$Res, $Val extends AppSettings>
return _then(_value.copyWith(shakeDetectionSettings: value) as $Val);
});
}
/// Create a copy of AppSettings
/// with the given fields replaced by the non-null parameter values.
@override
@pragma('vm:prefer-inline')
$HomePageSettingsCopyWith<$Res> get homePageSettings {
return $HomePageSettingsCopyWith<$Res>(_value.homePageSettings, (value) {
return _then(_value.copyWith(homePageSettings: value) as $Val);
});
}
}
/// @nodoc
@ -190,7 +208,8 @@ abstract class _$$AppSettingsImplCopyWith<$Res>
SleepTimerSettings sleepTimerSettings,
DownloadSettings downloadSettings,
NotificationSettings notificationSettings,
ShakeDetectionSettings shakeDetectionSettings});
ShakeDetectionSettings shakeDetectionSettings,
HomePageSettings homePageSettings});
@override
$ThemeSettingsCopyWith<$Res> get themeSettings;
@ -204,6 +223,8 @@ abstract class _$$AppSettingsImplCopyWith<$Res>
$NotificationSettingsCopyWith<$Res> get notificationSettings;
@override
$ShakeDetectionSettingsCopyWith<$Res> get shakeDetectionSettings;
@override
$HomePageSettingsCopyWith<$Res> get homePageSettings;
}
/// @nodoc
@ -225,6 +246,7 @@ class __$$AppSettingsImplCopyWithImpl<$Res>
Object? downloadSettings = null,
Object? notificationSettings = null,
Object? shakeDetectionSettings = null,
Object? homePageSettings = null,
}) {
return _then(_$AppSettingsImpl(
themeSettings: null == themeSettings
@ -251,6 +273,10 @@ class __$$AppSettingsImplCopyWithImpl<$Res>
? _value.shakeDetectionSettings
: shakeDetectionSettings // ignore: cast_nullable_to_non_nullable
as ShakeDetectionSettings,
homePageSettings: null == homePageSettings
? _value.homePageSettings
: homePageSettings // ignore: cast_nullable_to_non_nullable
as HomePageSettings,
));
}
}
@ -264,7 +290,8 @@ class _$AppSettingsImpl implements _AppSettings {
this.sleepTimerSettings = const SleepTimerSettings(),
this.downloadSettings = const DownloadSettings(),
this.notificationSettings = const NotificationSettings(),
this.shakeDetectionSettings = const ShakeDetectionSettings()});
this.shakeDetectionSettings = const ShakeDetectionSettings(),
this.homePageSettings = const HomePageSettings()});
factory _$AppSettingsImpl.fromJson(Map<String, dynamic> json) =>
_$$AppSettingsImplFromJson(json);
@ -287,10 +314,13 @@ class _$AppSettingsImpl implements _AppSettings {
@override
@JsonKey()
final ShakeDetectionSettings shakeDetectionSettings;
@override
@JsonKey()
final HomePageSettings homePageSettings;
@override
String toString() {
return 'AppSettings(themeSettings: $themeSettings, playerSettings: $playerSettings, sleepTimerSettings: $sleepTimerSettings, downloadSettings: $downloadSettings, notificationSettings: $notificationSettings, shakeDetectionSettings: $shakeDetectionSettings)';
return 'AppSettings(themeSettings: $themeSettings, playerSettings: $playerSettings, sleepTimerSettings: $sleepTimerSettings, downloadSettings: $downloadSettings, notificationSettings: $notificationSettings, shakeDetectionSettings: $shakeDetectionSettings, homePageSettings: $homePageSettings)';
}
@override
@ -309,7 +339,9 @@ class _$AppSettingsImpl implements _AppSettings {
(identical(other.notificationSettings, notificationSettings) ||
other.notificationSettings == notificationSettings) &&
(identical(other.shakeDetectionSettings, shakeDetectionSettings) ||
other.shakeDetectionSettings == shakeDetectionSettings));
other.shakeDetectionSettings == shakeDetectionSettings) &&
(identical(other.homePageSettings, homePageSettings) ||
other.homePageSettings == homePageSettings));
}
@JsonKey(includeFromJson: false, includeToJson: false)
@ -321,7 +353,8 @@ class _$AppSettingsImpl implements _AppSettings {
sleepTimerSettings,
downloadSettings,
notificationSettings,
shakeDetectionSettings);
shakeDetectionSettings,
homePageSettings);
/// Create a copy of AppSettings
/// with the given fields replaced by the non-null parameter values.
@ -346,7 +379,8 @@ abstract class _AppSettings implements AppSettings {
final SleepTimerSettings sleepTimerSettings,
final DownloadSettings downloadSettings,
final NotificationSettings notificationSettings,
final ShakeDetectionSettings shakeDetectionSettings}) = _$AppSettingsImpl;
final ShakeDetectionSettings shakeDetectionSettings,
final HomePageSettings homePageSettings}) = _$AppSettingsImpl;
factory _AppSettings.fromJson(Map<String, dynamic> json) =
_$AppSettingsImpl.fromJson;
@ -363,6 +397,8 @@ abstract class _AppSettings implements AppSettings {
NotificationSettings get notificationSettings;
@override
ShakeDetectionSettings get shakeDetectionSettings;
@override
HomePageSettings get homePageSettings;
/// Create a copy of AppSettings
/// with the given fields replaced by the non-null parameter values.
@ -372,6 +408,188 @@ abstract class _AppSettings implements AppSettings {
throw _privateConstructorUsedError;
}
HomePageSettings _$HomePageSettingsFromJson(Map<String, dynamic> json) {
return _HomePageSettings.fromJson(json);
}
/// @nodoc
mixin _$HomePageSettings {
bool get showPlayButtonOnContinueShelves =>
throw _privateConstructorUsedError;
bool get showPlayButtonOnAllShelves => throw _privateConstructorUsedError;
/// Serializes this HomePageSettings to a JSON map.
Map<String, dynamic> toJson() => throw _privateConstructorUsedError;
/// Create a copy of HomePageSettings
/// with the given fields replaced by the non-null parameter values.
@JsonKey(includeFromJson: false, includeToJson: false)
$HomePageSettingsCopyWith<HomePageSettings> get copyWith =>
throw _privateConstructorUsedError;
}
/// @nodoc
abstract class $HomePageSettingsCopyWith<$Res> {
factory $HomePageSettingsCopyWith(
HomePageSettings value, $Res Function(HomePageSettings) then) =
_$HomePageSettingsCopyWithImpl<$Res, HomePageSettings>;
@useResult
$Res call(
{bool showPlayButtonOnContinueShelves, bool showPlayButtonOnAllShelves});
}
/// @nodoc
class _$HomePageSettingsCopyWithImpl<$Res, $Val extends HomePageSettings>
implements $HomePageSettingsCopyWith<$Res> {
_$HomePageSettingsCopyWithImpl(this._value, this._then);
// ignore: unused_field
final $Val _value;
// ignore: unused_field
final $Res Function($Val) _then;
/// Create a copy of HomePageSettings
/// with the given fields replaced by the non-null parameter values.
@pragma('vm:prefer-inline')
@override
$Res call({
Object? showPlayButtonOnContinueShelves = null,
Object? showPlayButtonOnAllShelves = null,
}) {
return _then(_value.copyWith(
showPlayButtonOnContinueShelves: null == showPlayButtonOnContinueShelves
? _value.showPlayButtonOnContinueShelves
: showPlayButtonOnContinueShelves // ignore: cast_nullable_to_non_nullable
as bool,
showPlayButtonOnAllShelves: null == showPlayButtonOnAllShelves
? _value.showPlayButtonOnAllShelves
: showPlayButtonOnAllShelves // ignore: cast_nullable_to_non_nullable
as bool,
) as $Val);
}
}
/// @nodoc
abstract class _$$HomePageSettingsImplCopyWith<$Res>
implements $HomePageSettingsCopyWith<$Res> {
factory _$$HomePageSettingsImplCopyWith(_$HomePageSettingsImpl value,
$Res Function(_$HomePageSettingsImpl) then) =
__$$HomePageSettingsImplCopyWithImpl<$Res>;
@override
@useResult
$Res call(
{bool showPlayButtonOnContinueShelves, bool showPlayButtonOnAllShelves});
}
/// @nodoc
class __$$HomePageSettingsImplCopyWithImpl<$Res>
extends _$HomePageSettingsCopyWithImpl<$Res, _$HomePageSettingsImpl>
implements _$$HomePageSettingsImplCopyWith<$Res> {
__$$HomePageSettingsImplCopyWithImpl(_$HomePageSettingsImpl _value,
$Res Function(_$HomePageSettingsImpl) _then)
: super(_value, _then);
/// Create a copy of HomePageSettings
/// with the given fields replaced by the non-null parameter values.
@pragma('vm:prefer-inline')
@override
$Res call({
Object? showPlayButtonOnContinueShelves = null,
Object? showPlayButtonOnAllShelves = null,
}) {
return _then(_$HomePageSettingsImpl(
showPlayButtonOnContinueShelves: null == showPlayButtonOnContinueShelves
? _value.showPlayButtonOnContinueShelves
: showPlayButtonOnContinueShelves // ignore: cast_nullable_to_non_nullable
as bool,
showPlayButtonOnAllShelves: null == showPlayButtonOnAllShelves
? _value.showPlayButtonOnAllShelves
: showPlayButtonOnAllShelves // ignore: cast_nullable_to_non_nullable
as bool,
));
}
}
/// @nodoc
@JsonSerializable()
class _$HomePageSettingsImpl implements _HomePageSettings {
const _$HomePageSettingsImpl(
{this.showPlayButtonOnContinueShelves = true,
this.showPlayButtonOnAllShelves = false});
factory _$HomePageSettingsImpl.fromJson(Map<String, dynamic> json) =>
_$$HomePageSettingsImplFromJson(json);
@override
@JsonKey()
final bool showPlayButtonOnContinueShelves;
@override
@JsonKey()
final bool showPlayButtonOnAllShelves;
@override
String toString() {
return 'HomePageSettings(showPlayButtonOnContinueShelves: $showPlayButtonOnContinueShelves, showPlayButtonOnAllShelves: $showPlayButtonOnAllShelves)';
}
@override
bool operator ==(Object other) {
return identical(this, other) ||
(other.runtimeType == runtimeType &&
other is _$HomePageSettingsImpl &&
(identical(other.showPlayButtonOnContinueShelves,
showPlayButtonOnContinueShelves) ||
other.showPlayButtonOnContinueShelves ==
showPlayButtonOnContinueShelves) &&
(identical(other.showPlayButtonOnAllShelves,
showPlayButtonOnAllShelves) ||
other.showPlayButtonOnAllShelves ==
showPlayButtonOnAllShelves));
}
@JsonKey(includeFromJson: false, includeToJson: false)
@override
int get hashCode => Object.hash(
runtimeType, showPlayButtonOnContinueShelves, showPlayButtonOnAllShelves);
/// Create a copy of HomePageSettings
/// with the given fields replaced by the non-null parameter values.
@JsonKey(includeFromJson: false, includeToJson: false)
@override
@pragma('vm:prefer-inline')
_$$HomePageSettingsImplCopyWith<_$HomePageSettingsImpl> get copyWith =>
__$$HomePageSettingsImplCopyWithImpl<_$HomePageSettingsImpl>(
this, _$identity);
@override
Map<String, dynamic> toJson() {
return _$$HomePageSettingsImplToJson(
this,
);
}
}
abstract class _HomePageSettings implements HomePageSettings {
const factory _HomePageSettings(
{final bool showPlayButtonOnContinueShelves,
final bool showPlayButtonOnAllShelves}) = _$HomePageSettingsImpl;
factory _HomePageSettings.fromJson(Map<String, dynamic> json) =
_$HomePageSettingsImpl.fromJson;
@override
bool get showPlayButtonOnContinueShelves;
@override
bool get showPlayButtonOnAllShelves;
/// Create a copy of HomePageSettings
/// with the given fields replaced by the non-null parameter values.
@override
@JsonKey(includeFromJson: false, includeToJson: false)
_$$HomePageSettingsImplCopyWith<_$HomePageSettingsImpl> get copyWith =>
throw _privateConstructorUsedError;
}
ThemeSettings _$ThemeSettingsFromJson(Map<String, dynamic> json) {
return _ThemeSettings.fromJson(json);
}

View file

@ -32,6 +32,10 @@ _$AppSettingsImpl _$$AppSettingsImplFromJson(Map<String, dynamic> json) =>
? const ShakeDetectionSettings()
: ShakeDetectionSettings.fromJson(
json['shakeDetectionSettings'] as Map<String, dynamic>),
homePageSettings: json['homePageSettings'] == null
? const HomePageSettings()
: HomePageSettings.fromJson(
json['homePageSettings'] as Map<String, dynamic>),
);
Map<String, dynamic> _$$AppSettingsImplToJson(_$AppSettingsImpl instance) =>
@ -42,6 +46,24 @@ Map<String, dynamic> _$$AppSettingsImplToJson(_$AppSettingsImpl instance) =>
'downloadSettings': instance.downloadSettings,
'notificationSettings': instance.notificationSettings,
'shakeDetectionSettings': instance.shakeDetectionSettings,
'homePageSettings': instance.homePageSettings,
};
_$HomePageSettingsImpl _$$HomePageSettingsImplFromJson(
Map<String, dynamic> json) =>
_$HomePageSettingsImpl(
showPlayButtonOnContinueShelves:
json['showPlayButtonOnContinueShelves'] as bool? ?? true,
showPlayButtonOnAllShelves:
json['showPlayButtonOnAllShelves'] as bool? ?? false,
);
Map<String, dynamic> _$$HomePageSettingsImplToJson(
_$HomePageSettingsImpl instance) =>
<String, dynamic>{
'showPlayButtonOnContinueShelves':
instance.showPlayButtonOnContinueShelves,
'showPlayButtonOnAllShelves': instance.showPlayButtonOnAllShelves,
};
_$ThemeSettingsImpl _$$ThemeSettingsImplFromJson(Map<String, dynamic> json) =>

View file

@ -1,8 +1,9 @@
import 'package:flutter/material.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:settings_ui/settings_ui.dart';
import 'package:flutter_settings_ui/flutter_settings_ui.dart';
import 'package:vaani/settings/app_settings_provider.dart';
import 'package:vaani/settings/widgets/simple_settings_page.dart';
import 'package:vaani/settings/view/simple_settings_page.dart'
show SimpleSettingsPage;
class HomePageSettingsPage extends HookConsumerWidget {
const HomePageSettingsPage({super.key});
@ -13,41 +14,41 @@ class HomePageSettingsPage extends HookConsumerWidget {
final appSettingsNotifier = ref.read(appSettingsProvider.notifier);
return SimpleSettingsPage(
title: 'Home Page Settings',
child: SettingsList(
sections: [
SettingsSection(
tiles: [
SettingsTile.switchTile(
title: const Text('Show play button on continue shelves'),
initialValue: appSettings.homePageSettings.showPlayButtonOnContinueShelves,
onToggle: (value) {
appSettingsNotifier.update(
appSettings.copyWith(
homePageSettings: appSettings.homePageSettings.copyWith(
showPlayButtonOnContinueShelves: value,
),
title: Text('Home Page Settings'),
sections: [
SettingsSection(
tiles: [
SettingsTile.switchTile(
title: const Text('Show play button on continue shelves'),
initialValue:
appSettings.homePageSettings.showPlayButtonOnContinueShelves,
onToggle: (value) {
appSettingsNotifier.update(
appSettings.copyWith(
homePageSettings: appSettings.homePageSettings.copyWith(
showPlayButtonOnContinueShelves: value,
),
);
},
),
SettingsTile.switchTile(
title: const Text('Show play button on all shelves'),
initialValue: appSettings.homePageSettings.showPlayButtonOnAllShelves,
onToggle: (value) {
appSettingsNotifier.update(
appSettings.copyWith(
homePageSettings: appSettings.homePageSettings.copyWith(
showPlayButtonOnAllShelves: value,
),
),
);
},
),
SettingsTile.switchTile(
title: const Text('Show play button on all shelves'),
initialValue:
appSettings.homePageSettings.showPlayButtonOnAllShelves,
onToggle: (value) {
appSettingsNotifier.update(
appSettings.copyWith(
homePageSettings: appSettings.homePageSettings.copyWith(
showPlayButtonOnAllShelves: value,
),
);
},
),
],
),
],
),
),
);
},
),
],
),
],
);
}
}