fix using copywith

This commit is contained in:
Rafeek-Khoudare
2025-07-21 16:30:28 +03:00
parent c473325883
commit 983040135f
6 changed files with 107 additions and 77 deletions

View File

@ -4,8 +4,7 @@ import 'package:syncrow_web/utils/color_manager.dart';
class SvgTextButton extends StatelessWidget {
final String svgAsset;
final double? horizontalPadding;
final double? verticalPadding;
final EdgeInsets? padding;
final String label;
final VoidCallback onPressed;
final Color backgroundColor;
@ -27,8 +26,7 @@ class SvgTextButton extends StatelessWidget {
this.svgColor = const Color(0xFF496EFF),
this.labelColor = Colors.black,
this.borderRadius = 10.0,
this.horizontalPadding,
this.verticalPadding,
this.padding,
this.boxShadow = const [
BoxShadow(
color: ColorsManager.lightGrayColor,
@ -47,9 +45,8 @@ class SvgTextButton extends StatelessWidget {
borderRadius: BorderRadius.circular(borderRadius),
onTap: onPressed,
child: Container(
padding: EdgeInsets.symmetric(
horizontal: horizontalPadding ?? 24,
vertical: verticalPadding ?? 12),
padding: padding ??
const EdgeInsets.symmetric(horizontal: 24, vertical: 12),
decoration: BoxDecoration(
color: backgroundColor,
borderRadius: BorderRadius.circular(borderRadius),

View File

@ -40,22 +40,25 @@ class BookableSpacesBloc
if (event.bookableSpace.spaceConfig!.configUuid ==
event.updatedBookableSpaceConfig.configUuid) {
final editedBookableSpace = event.bookableSpaces.data.firstWhere(
(element) => element.spaceUuid == event.bookableSpace.spaceUuid,
);
final config = editedBookableSpace.spaceConfig!.copyWith(
availability: event.updatedBookableSpaceConfig.availability,
bookableDays: event.updatedBookableSpaceConfig.bookableDays,
bookingEndTime: event.updatedBookableSpaceConfig.bookingEndTime,
bookingStartTime: event.updatedBookableSpaceConfig.bookingStartTime,
cost: event.updatedBookableSpaceConfig.cost,
);
editedBookableSpace.copyWith(spaceConfig: config);
final index = event.bookableSpaces.data.indexWhere(
(element) => element.spaceUuid == event.bookableSpace.spaceUuid,
);
event.bookableSpaces.data.removeAt(index);
event.bookableSpaces.data.insert(index, editedBookableSpace);
if (index != -1) {
final original = event.bookableSpaces.data[index];
final updatedConfig = original.spaceConfig!.copyWith(
availability: event.updatedBookableSpaceConfig.availability,
bookableDays: event.updatedBookableSpaceConfig.bookableDays,
bookingEndTime: event.updatedBookableSpaceConfig.bookingEndTime,
bookingStartTime: event.updatedBookableSpaceConfig.bookingStartTime,
cost: event.updatedBookableSpaceConfig.cost,
);
final updatedSpace = original.copyWith(spaceConfig: updatedConfig);
event.bookableSpaces.data[index] = updatedSpace;
}
}
emit(BookableSpacesLoaded(bookableSpacesList: event.bookableSpaces));

View File

@ -65,10 +65,21 @@ class BookingPeriodWidget extends StatelessWidget {
));
throw Exception();
} else {
setupBookableSpacesBloc.selectedBookableSpaces.forEach(
(e) =>
e.spaceConfig!.copyWith(bookingStartTime: timePicked),
);
for (int i = 0;
i <
setupBookableSpacesBloc
.selectedBookableSpaces.length;
i++) {
final space =
setupBookableSpacesBloc.selectedBookableSpaces[i];
final updatedConfig = space.spaceConfig
?.copyWith(bookingStartTime: timePicked);
final updatedSpace =
space.copyWith(spaceConfig: updatedConfig);
setupBookableSpacesBloc.selectedBookableSpaces[i] =
updatedSpace;
}
}
},
),
@ -99,10 +110,21 @@ class BookingPeriodWidget extends StatelessWidget {
));
throw Exception();
} else {
setupBookableSpacesBloc.selectedBookableSpaces.forEach(
(e) =>
e.spaceConfig!.copyWith(bookingEndTime: timePicked),
);
for (int i = 0;
i <
setupBookableSpacesBloc
.selectedBookableSpaces.length;
i++) {
final space =
setupBookableSpacesBloc.selectedBookableSpaces[i];
final updatedConfig = space.spaceConfig
?.copyWith(bookingEndTime: timePicked);
final updatedSpace =
space.copyWith(spaceConfig: updatedConfig);
setupBookableSpacesBloc.selectedBookableSpaces[i] =
updatedSpace;
}
}
},
),

View File

@ -53,8 +53,7 @@ class RowOfButtonsTitleWidget extends StatelessWidget {
],
),
SvgTextButton(
verticalPadding: 10,
horizontalPadding: 10,
padding: const EdgeInsets.all(10),
svgSize: 15,
fontSize: 10,
fontWeight: FontWeight.bold,

View File

@ -73,34 +73,31 @@ class _PointsPartWidgetState extends State<PointsPartWidget> {
}),
value: state is ActivatePointsSwitch,
onChanged: (value) {
final bloc = context.read<SetupBookableSpacesBloc>();
final updatedCost = value ? -1 : 0;
final switchCubit =
context.read<TogglePointsSwitchCubit>();
if (value) {
context
.read<TogglePointsSwitchCubit>()
.activateSwitch();
context
.read<SetupBookableSpacesBloc>()
.selectedBookableSpaces
.forEach(
(e) => e.spaceConfig!.copyWith(cost: -1),
);
context
.read<SetupBookableSpacesBloc>()
.add(CheckConfigurValidityEvent());
switchCubit.activateSwitch();
} else {
context
.read<TogglePointsSwitchCubit>()
.unActivateSwitch();
switchCubit.unActivateSwitch();
widget.pointsController.clear();
context
.read<SetupBookableSpacesBloc>()
.selectedBookableSpaces
.forEach(
(e) => e.spaceConfig!.copyWith(cost: 0),
);
context
.read<SetupBookableSpacesBloc>()
.add(CheckConfigurValidityEvent());
}
for (int i = 0;
i < bloc.selectedBookableSpaces.length;
i++) {
final space = bloc.selectedBookableSpaces[i];
final updatedConfig =
space.spaceConfig?.copyWith(cost: updatedCost);
final updatedSpace =
space.copyWith(spaceConfig: updatedConfig);
bloc.selectedBookableSpaces[i] = updatedSpace;
}
bloc.add(CheckConfigurValidityEvent());
},
),
)
@ -114,16 +111,21 @@ class _PointsPartWidgetState extends State<PointsPartWidget> {
title: 'Ex: 0',
height: 40,
onChanged: (p0) {
context
.read<SetupBookableSpacesBloc>()
.selectedBookableSpaces
.forEach(
(e) => e.spaceConfig!.copyWith(
cost: int.parse(widget.pointsController.text.isEmpty
? '0'
: widget.pointsController.text),
),
);
final updatedCost =
int.tryParse(widget.pointsController.text) ?? 0;
final bloc = context.read<SetupBookableSpacesBloc>();
for (var i = 0; i < bloc.selectedBookableSpaces.length; i++) {
final space = bloc.selectedBookableSpaces[i];
final updatedConfig =
space.spaceConfig?.copyWith(cost: updatedCost);
final updatedSpace =
space.copyWith(spaceConfig: updatedConfig);
bloc.selectedBookableSpaces[i] = updatedSpace;
}
context
.read<SetupBookableSpacesBloc>()
.add(CheckConfigurValidityEvent());

View File

@ -52,21 +52,28 @@ class _WeekDaysCheckboxRowState extends State<WeekDaysCheckboxRow> {
onChanged: (newValue) {
setState(() {
_daysChecked[entry.key] = newValue ?? false;
final selectedDays = _daysChecked.entries
.where((e) => e.value)
.map((e) => e.key)
.toList();
for (var space in context
.read<SetupBookableSpacesBloc>()
.selectedBookableSpaces) {
space.spaceConfig!.copyWith(bookableDays: selectedDays);
}
});
context
.read<SetupBookableSpacesBloc>()
.add(CheckConfigurValidityEvent());
final selectedDays = _daysChecked.entries
.where((e) => e.value)
.map((e) => e.key)
.toList();
final bloc = context.read<SetupBookableSpacesBloc>();
for (int i = 0;
i < bloc.selectedBookableSpaces.length;
i++) {
final space = bloc.selectedBookableSpaces[i];
final updatedConfig = space.spaceConfig
?.copyWith(bookableDays: selectedDays);
final updatedSpace =
space.copyWith(spaceConfig: updatedConfig);
bloc.selectedBookableSpaces[i] = updatedSpace;
}
bloc.add(CheckConfigurValidityEvent());
},
),
),