mirror of
https://github.com/SyncrowIOT/web.git
synced 2025-08-25 04:22:28 +00:00
fix using copywith
This commit is contained in:
@ -4,8 +4,7 @@ import 'package:syncrow_web/utils/color_manager.dart';
|
|||||||
|
|
||||||
class SvgTextButton extends StatelessWidget {
|
class SvgTextButton extends StatelessWidget {
|
||||||
final String svgAsset;
|
final String svgAsset;
|
||||||
final double? horizontalPadding;
|
final EdgeInsets? padding;
|
||||||
final double? verticalPadding;
|
|
||||||
final String label;
|
final String label;
|
||||||
final VoidCallback onPressed;
|
final VoidCallback onPressed;
|
||||||
final Color backgroundColor;
|
final Color backgroundColor;
|
||||||
@ -27,8 +26,7 @@ class SvgTextButton extends StatelessWidget {
|
|||||||
this.svgColor = const Color(0xFF496EFF),
|
this.svgColor = const Color(0xFF496EFF),
|
||||||
this.labelColor = Colors.black,
|
this.labelColor = Colors.black,
|
||||||
this.borderRadius = 10.0,
|
this.borderRadius = 10.0,
|
||||||
this.horizontalPadding,
|
this.padding,
|
||||||
this.verticalPadding,
|
|
||||||
this.boxShadow = const [
|
this.boxShadow = const [
|
||||||
BoxShadow(
|
BoxShadow(
|
||||||
color: ColorsManager.lightGrayColor,
|
color: ColorsManager.lightGrayColor,
|
||||||
@ -47,9 +45,8 @@ class SvgTextButton extends StatelessWidget {
|
|||||||
borderRadius: BorderRadius.circular(borderRadius),
|
borderRadius: BorderRadius.circular(borderRadius),
|
||||||
onTap: onPressed,
|
onTap: onPressed,
|
||||||
child: Container(
|
child: Container(
|
||||||
padding: EdgeInsets.symmetric(
|
padding: padding ??
|
||||||
horizontal: horizontalPadding ?? 24,
|
const EdgeInsets.symmetric(horizontal: 24, vertical: 12),
|
||||||
vertical: verticalPadding ?? 12),
|
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
color: backgroundColor,
|
color: backgroundColor,
|
||||||
borderRadius: BorderRadius.circular(borderRadius),
|
borderRadius: BorderRadius.circular(borderRadius),
|
||||||
|
@ -40,22 +40,25 @@ class BookableSpacesBloc
|
|||||||
|
|
||||||
if (event.bookableSpace.spaceConfig!.configUuid ==
|
if (event.bookableSpace.spaceConfig!.configUuid ==
|
||||||
event.updatedBookableSpaceConfig.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(
|
final index = event.bookableSpaces.data.indexWhere(
|
||||||
(element) => element.spaceUuid == event.bookableSpace.spaceUuid,
|
(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));
|
emit(BookableSpacesLoaded(bookableSpacesList: event.bookableSpaces));
|
||||||
|
@ -65,10 +65,21 @@ class BookingPeriodWidget extends StatelessWidget {
|
|||||||
));
|
));
|
||||||
throw Exception();
|
throw Exception();
|
||||||
} else {
|
} else {
|
||||||
setupBookableSpacesBloc.selectedBookableSpaces.forEach(
|
for (int i = 0;
|
||||||
(e) =>
|
i <
|
||||||
e.spaceConfig!.copyWith(bookingStartTime: timePicked),
|
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();
|
throw Exception();
|
||||||
} else {
|
} else {
|
||||||
setupBookableSpacesBloc.selectedBookableSpaces.forEach(
|
for (int i = 0;
|
||||||
(e) =>
|
i <
|
||||||
e.spaceConfig!.copyWith(bookingEndTime: timePicked),
|
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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
@ -53,8 +53,7 @@ class RowOfButtonsTitleWidget extends StatelessWidget {
|
|||||||
],
|
],
|
||||||
),
|
),
|
||||||
SvgTextButton(
|
SvgTextButton(
|
||||||
verticalPadding: 10,
|
padding: const EdgeInsets.all(10),
|
||||||
horizontalPadding: 10,
|
|
||||||
svgSize: 15,
|
svgSize: 15,
|
||||||
fontSize: 10,
|
fontSize: 10,
|
||||||
fontWeight: FontWeight.bold,
|
fontWeight: FontWeight.bold,
|
||||||
|
@ -73,34 +73,31 @@ class _PointsPartWidgetState extends State<PointsPartWidget> {
|
|||||||
}),
|
}),
|
||||||
value: state is ActivatePointsSwitch,
|
value: state is ActivatePointsSwitch,
|
||||||
onChanged: (value) {
|
onChanged: (value) {
|
||||||
|
final bloc = context.read<SetupBookableSpacesBloc>();
|
||||||
|
final updatedCost = value ? -1 : 0;
|
||||||
|
|
||||||
|
final switchCubit =
|
||||||
|
context.read<TogglePointsSwitchCubit>();
|
||||||
if (value) {
|
if (value) {
|
||||||
context
|
switchCubit.activateSwitch();
|
||||||
.read<TogglePointsSwitchCubit>()
|
|
||||||
.activateSwitch();
|
|
||||||
context
|
|
||||||
.read<SetupBookableSpacesBloc>()
|
|
||||||
.selectedBookableSpaces
|
|
||||||
.forEach(
|
|
||||||
(e) => e.spaceConfig!.copyWith(cost: -1),
|
|
||||||
);
|
|
||||||
context
|
|
||||||
.read<SetupBookableSpacesBloc>()
|
|
||||||
.add(CheckConfigurValidityEvent());
|
|
||||||
} else {
|
} else {
|
||||||
context
|
switchCubit.unActivateSwitch();
|
||||||
.read<TogglePointsSwitchCubit>()
|
|
||||||
.unActivateSwitch();
|
|
||||||
widget.pointsController.clear();
|
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',
|
title: 'Ex: 0',
|
||||||
height: 40,
|
height: 40,
|
||||||
onChanged: (p0) {
|
onChanged: (p0) {
|
||||||
context
|
final updatedCost =
|
||||||
.read<SetupBookableSpacesBloc>()
|
int.tryParse(widget.pointsController.text) ?? 0;
|
||||||
.selectedBookableSpaces
|
|
||||||
.forEach(
|
final bloc = context.read<SetupBookableSpacesBloc>();
|
||||||
(e) => e.spaceConfig!.copyWith(
|
|
||||||
cost: int.parse(widget.pointsController.text.isEmpty
|
for (var i = 0; i < bloc.selectedBookableSpaces.length; i++) {
|
||||||
? '0'
|
final space = bloc.selectedBookableSpaces[i];
|
||||||
: widget.pointsController.text),
|
final updatedConfig =
|
||||||
),
|
space.spaceConfig?.copyWith(cost: updatedCost);
|
||||||
);
|
final updatedSpace =
|
||||||
|
space.copyWith(spaceConfig: updatedConfig);
|
||||||
|
|
||||||
|
bloc.selectedBookableSpaces[i] = updatedSpace;
|
||||||
|
}
|
||||||
|
|
||||||
context
|
context
|
||||||
.read<SetupBookableSpacesBloc>()
|
.read<SetupBookableSpacesBloc>()
|
||||||
.add(CheckConfigurValidityEvent());
|
.add(CheckConfigurValidityEvent());
|
||||||
|
@ -52,21 +52,28 @@ class _WeekDaysCheckboxRowState extends State<WeekDaysCheckboxRow> {
|
|||||||
onChanged: (newValue) {
|
onChanged: (newValue) {
|
||||||
setState(() {
|
setState(() {
|
||||||
_daysChecked[entry.key] = newValue ?? false;
|
_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
|
final selectedDays = _daysChecked.entries
|
||||||
.read<SetupBookableSpacesBloc>()
|
.where((e) => e.value)
|
||||||
.add(CheckConfigurValidityEvent());
|
.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());
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
Reference in New Issue
Block a user