ac batch control design

This commit is contained in:
ashrafzarkanisala
2024-09-12 11:49:57 +03:00
parent 3171916faf
commit 222331f107
4 changed files with 117 additions and 2 deletions

View File

@ -15,6 +15,7 @@ class AcBloc extends Bloc<AcsEvent, AcsState> {
AcBloc({required this.deviceId}) : super(AcsInitialState()) { AcBloc({required this.deviceId}) : super(AcsInitialState()) {
on<AcFetchDeviceStatus>(_onFetchAcStatus); on<AcFetchDeviceStatus>(_onFetchAcStatus);
on<AcFetchBatchStatus>(_onFetchAcBatchStatus);
on<AcControl>(_onAcControl); on<AcControl>(_onAcControl);
} }
@ -133,4 +134,17 @@ class AcBloc extends Bloc<AcsEvent, AcsState> {
return null; return null;
} }
} }
FutureOr<void> _onFetchAcBatchStatus(
AcFetchBatchStatus event, Emitter<AcsState> emit) async {
emit(AcsLoadingState());
try {
final status =
await DevicesManagementApi().getDeviceStatus(event.deviceId);
deviceStatus = AcStatusModel.fromJson(event.deviceId, status.status);
emit(ACStatusLoaded(deviceStatus));
} catch (e) {
emit(AcsFailedState(error: e.toString()));
}
}
} }

View File

@ -16,6 +16,15 @@ class AcFetchDeviceStatus extends AcsEvent {
List<Object> get props => [deviceId]; List<Object> get props => [deviceId];
} }
class AcFetchBatchStatus extends AcsEvent {
final String deviceId;
const AcFetchBatchStatus(this.deviceId);
@override
List<Object> get props => [deviceId];
}
class AcControl extends AcsEvent { class AcControl extends AcsEvent {
final String deviceId; final String deviceId;
final String code; final String code;

View File

@ -0,0 +1,88 @@
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:syncrow_web/pages/device_managment/ac/bloc/ac_bloc.dart';
import 'package:syncrow_web/pages/device_managment/ac/bloc/ac_event.dart';
import 'package:syncrow_web/pages/device_managment/ac/bloc/ac_state.dart';
import 'package:syncrow_web/pages/device_managment/ac/view/control_list/ac_mode.dart';
import 'package:syncrow_web/pages/device_managment/ac/view/control_list/ac_toggle.dart';
import 'package:syncrow_web/pages/device_managment/ac/view/control_list/current_temp.dart';
import 'package:syncrow_web/pages/device_managment/ac/view/control_list/fan_speed.dart';
import 'package:syncrow_web/pages/device_managment/shared/batch_control/factory_reset.dart';
import 'package:syncrow_web/pages/device_managment/shared/batch_control/firmware_update.dart';
import 'package:syncrow_web/utils/constants/assets.dart';
import 'package:syncrow_web/utils/helpers/responsice_layout_helper/responsive_layout_helper.dart';
class AcDeviceBatchControl extends StatelessWidget with HelperResponsiveLayout {
const AcDeviceBatchControl({super.key, required this.devicesIds});
final List<String> devicesIds;
@override
Widget build(BuildContext context) {
final isExtraLarge = isExtraLargeScreenSize(context);
final isLarge = isLargeScreenSize(context);
final isMedium = isMediumScreenSize(context);
return BlocProvider(
create: (context) => AcBloc(deviceId: devicesIds.first)
..add(AcFetchBatchStatus(devicesIds.first)),
child: BlocBuilder<AcBloc, AcsState>(
builder: (context, state) {
if (state is ACStatusLoaded) {
return GridView(
padding: const EdgeInsets.symmetric(horizontal: 50),
shrinkWrap: true,
physics: const NeverScrollableScrollPhysics(),
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: isLarge || isExtraLarge
? 3
: isMedium
? 2
: 1,
mainAxisExtent: 140,
crossAxisSpacing: 12,
mainAxisSpacing: 12,
),
children: [
AcToggle(
value: state.status.acSwitch,
code: 'switch',
deviceId: devicesIds.first,
),
CurrentTemp(
currentTemp: state.status.currentTemp,
tempSet: state.status.tempSet,
code: 'temp_set',
deviceId: devicesIds.first,
),
AcMode(
value: state.status.acMode,
code: 'mode',
deviceId: devicesIds.first,
),
FanSpeedControl(
value: state.status.acFanSpeed,
code: 'level',
deviceId: devicesIds.first,
),
AcToggle(
value: state.status.childLock,
code: 'child_lock',
deviceId: devicesIds.first,
description: 'Child Lock',
icon:
state.status.childLock ? Assets.childLock : Assets.unlock,
),
FirmwareUpdateWidget(deviceId: devicesIds.first, version: 5),
FactoryResetWidget(deviceId: devicesIds.first),
],
);
} else if (state is AcsLoadingState) {
return const Center(child: CircularProgressIndicator());
} else {
return const Center(child: Text('Error fetching status'));
}
},
),
);
}
}

View File

@ -1,5 +1,6 @@
import 'package:flutter/cupertino.dart'; import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:syncrow_web/pages/device_managment/ac/view/ac_device_batch_control.dart';
import 'package:syncrow_web/pages/device_managment/ac/view/ac_device_control.dart'; import 'package:syncrow_web/pages/device_managment/ac/view/ac_device_control.dart';
import 'package:syncrow_web/pages/device_managment/all_devices/models/devices_model.dart'; import 'package:syncrow_web/pages/device_managment/all_devices/models/devices_model.dart';
import 'package:syncrow_web/pages/device_managment/ceiling_sensor/view/ceiling_sensor_controls.dart'; import 'package:syncrow_web/pages/device_managment/ceiling_sensor/view/ceiling_sensor_controls.dart';
@ -92,8 +93,11 @@ mixin RouteControlsBasedCode {
.map((e) => e.uuid!) .map((e) => e.uuid!)
.toList(), .toList(),
); );
// case 'AC': case 'AC':
// return AcDeviceControls(device: device.first); return AcDeviceBatchControl(devicesIds: devices
.where((e) => (e.productType == 'AC'))
.map((e) => e.uuid!)
.toList());
default: default:
return const SizedBox(); return const SizedBox();
} }