Compare commits

..

1 Commits

19 changed files with 346 additions and 381 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 290 KiB

View File

@ -18,11 +18,7 @@ abstract final class RangeOfAqiChartsHelper {
(ColorsManager.hazardousPurple, 'Hazardous'),
];
static FlTitlesData titlesData(
BuildContext context,
List<RangeOfAqi> data, {
double leftSideInterval = 50,
}) {
static FlTitlesData titlesData(BuildContext context, List<RangeOfAqi> data) {
final titlesData = EnergyManagementChartsHelper.titlesData(context);
return titlesData.copyWith(
bottomTitles: titlesData.bottomTitles.copyWith(
@ -42,11 +38,10 @@ abstract final class RangeOfAqiChartsHelper {
leftTitles: titlesData.leftTitles.copyWith(
sideTitles: titlesData.leftTitles.sideTitles.copyWith(
reservedSize: 70,
interval: leftSideInterval,
interval: 50,
maxIncluded: false,
minIncluded: true,
getTitlesWidget: (value, meta) {
final text = value.toInt().toString();
final text = value >= 300 ? '301+' : value.toInt().toString();
return Padding(
padding: const EdgeInsetsDirectional.only(end: 12),
child: FittedBox(

View File

@ -3,7 +3,6 @@ import 'package:flutter/material.dart';
import 'package:intl/intl.dart';
import 'package:syncrow_web/pages/analytics/models/air_quality_data_model.dart';
import 'package:syncrow_web/pages/analytics/modules/energy_management/helpers/energy_management_charts_helper.dart';
import 'package:syncrow_web/pages/analytics/widgets/charts_x_axis_title.dart';
import 'package:syncrow_web/utils/color_manager.dart';
import 'package:syncrow_web/utils/extension/build_context_x.dart';
@ -140,7 +139,6 @@ class AqiDistributionChart extends StatelessWidget {
);
final bottomTitles = AxisTitles(
axisNameWidget: const ChartsXAxisTitle(),
sideTitles: SideTitles(
showTitles: true,
getTitlesWidget: (value, _) => FittedBox(

View File

@ -2,18 +2,15 @@ import 'package:fl_chart/fl_chart.dart';
import 'package:flutter/material.dart';
import 'package:syncrow_web/pages/analytics/models/range_of_aqi.dart';
import 'package:syncrow_web/pages/analytics/modules/air_quality/helpers/range_of_aqi_charts_helper.dart';
import 'package:syncrow_web/pages/analytics/modules/air_quality/widgets/aqi_type_dropdown.dart';
import 'package:syncrow_web/pages/analytics/modules/energy_management/helpers/energy_management_charts_helper.dart';
import 'package:syncrow_web/utils/color_manager.dart';
class RangeOfAqiChart extends StatelessWidget {
final List<RangeOfAqi> chartData;
final AqiType selectedAqiType;
const RangeOfAqiChart({
super.key,
required this.chartData,
required this.selectedAqiType,
});
List<(List<double> values, Color color, Color? dotColor)> get _lines {
@ -48,34 +45,15 @@ class RangeOfAqiChart extends StatelessWidget {
];
}
(double maxY, double interval) get _maxYForAqiType {
const aqiMaxValues = <AqiType, (double maxY, double interval)>{
AqiType.aqi: (401, 100),
AqiType.pm25: (351, 50),
AqiType.pm10: (501, 100),
AqiType.hcho: (301, 50),
AqiType.tvoc: (501, 50),
AqiType.co2: (1251, 250),
};
return aqiMaxValues[selectedAqiType]!;
}
@override
Widget build(BuildContext context) {
return LineChart(
LineChartData(
minY: 0,
maxY: _maxYForAqiType.$1,
maxY: 301,
clipData: const FlClipData.vertical(),
gridData: EnergyManagementChartsHelper.gridData(
horizontalInterval: _maxYForAqiType.$2,
),
titlesData: RangeOfAqiChartsHelper.titlesData(
context,
chartData,
leftSideInterval: _maxYForAqiType.$2,
),
gridData: EnergyManagementChartsHelper.gridData(horizontalInterval: 50),
titlesData: RangeOfAqiChartsHelper.titlesData(context, chartData),
borderData: EnergyManagementChartsHelper.borderData(),
lineTouchData: RangeOfAqiChartsHelper.lineTouchData(chartData),
betweenBarsData: [

View File

@ -32,12 +32,7 @@ class RangeOfAqiChartBox extends StatelessWidget {
const SizedBox(height: 10),
const Divider(),
const SizedBox(height: 20),
Expanded(
child: RangeOfAqiChart(
chartData: state.filteredRangeOfAqi,
selectedAqiType: state.selectedAqiType,
),
),
Expanded(child: RangeOfAqiChart(chartData: state.filteredRangeOfAqi)),
],
),
);

View File

@ -1,7 +1,6 @@
import 'package:fl_chart/fl_chart.dart';
import 'package:flutter/material.dart';
import 'package:syncrow_web/pages/analytics/helpers/format_number_to_kwh.dart';
import 'package:syncrow_web/pages/analytics/widgets/charts_x_axis_title.dart';
import 'package:syncrow_web/utils/color_manager.dart';
import 'package:syncrow_web/utils/extension/build_context_x.dart';
@ -16,7 +15,6 @@ abstract final class EnergyManagementChartsHelper {
return FlTitlesData(
show: true,
bottomTitles: AxisTitles(
axisNameWidget: const ChartsXAxisTitle(),
drawBelowEverything: true,
sideTitles: SideTitles(
interval: 1,
@ -64,12 +62,17 @@ abstract final class EnergyManagementChartsHelper {
);
}
static String getToolTipLabel(double value) => value.formatNumberToKwh;
static String getToolTipLabel(num month, double value) {
final monthLabel = month.toString();
final valueLabel = value.formatNumberToKwh;
final labels = [monthLabel, valueLabel];
return labels.where((element) => element.isNotEmpty).join(', ');
}
static List<LineTooltipItem?> getTooltipItems(List<LineBarSpot> touchedSpots) {
return touchedSpots.map((spot) {
return LineTooltipItem(
getToolTipLabel(spot.y),
getToolTipLabel(spot.x, spot.y),
const TextStyle(
color: ColorsManager.textPrimaryColor,
fontWeight: FontWeight.w600,

View File

@ -46,7 +46,7 @@ class AnalyticsEnergyManagementView extends StatelessWidget {
spacing: 32,
children: [
Expanded(
flex: 7,
flex: 2,
child: Column(
spacing: 20,
children: [
@ -55,7 +55,7 @@ class AnalyticsEnergyManagementView extends StatelessWidget {
],
),
),
Expanded(flex: 4, child: PowerClampEnergyDataWidget()),
Expanded(child: PowerClampEnergyDataWidget()),
],
),
),

View File

@ -37,7 +37,7 @@ class EnergyConsumptionPerDeviceChartBox extends StatelessWidget {
fit: BoxFit.scaleDown,
alignment: AlignmentDirectional.centerStart,
child: ChartTitle(
title: Text('Device energy consumed'),
title: Text('Energy Consumption per Device'),
),
),
),

View File

@ -32,7 +32,7 @@ class TotalEnergyConsumptionChartBox extends StatelessWidget {
child: FittedBox(
alignment: AlignmentDirectional.centerStart,
fit: BoxFit.scaleDown,
child: ChartTitle(title: Text('Space energy consumed')),
child: ChartTitle(title: Text('Total Energy Consumption')),
),
),
const Spacer(flex: 4),

View File

@ -31,12 +31,12 @@ class AnalyticsOccupancyView extends StatelessWidget {
return SingleChildScrollView(
child: Container(
padding: _padding,
height: height * 1,
height: height * 0.9,
child: const Row(
spacing: 32,
children: [
Expanded(
flex: 7,
flex: 5,
child: Column(
spacing: 20,
children: [
@ -45,7 +45,7 @@ class AnalyticsOccupancyView extends StatelessWidget {
],
),
),
Expanded(flex: 4, child: OccupancyEndSideBar()),
Expanded(flex: 2, child: OccupancyEndSideBar()),
],
),
),

View File

@ -39,7 +39,7 @@ class HeatMapTooltip extends StatelessWidget {
),
const Divider(height: 2, thickness: 1),
Text(
'Occupancy detected: $value',
'$value Occupants',
style: context.textTheme.bodySmall?.copyWith(
fontSize: 10,
fontWeight: FontWeight.w500,

View File

@ -2,7 +2,6 @@ import 'package:fl_chart/fl_chart.dart';
import 'package:flutter/material.dart';
import 'package:syncrow_web/pages/analytics/models/occupacy.dart';
import 'package:syncrow_web/pages/analytics/modules/energy_management/helpers/energy_management_charts_helper.dart';
import 'package:syncrow_web/pages/analytics/widgets/charts_x_axis_title.dart';
import 'package:syncrow_web/utils/color_manager.dart';
import 'package:syncrow_web/utils/extension/build_context_x.dart';
@ -89,8 +88,8 @@ class OccupancyChart extends StatelessWidget {
}) {
final data = chartData;
final occupancyValue = double.parse(data[group.x].occupancy);
final percentage = '${occupancyValue.toStringAsFixed(0)}%';
final occupancyValue = double.parse(data[group.x.toInt()].occupancy);
final percentage = '${(occupancyValue).toStringAsFixed(0)}%';
return BarTooltipItem(
percentage,
@ -117,7 +116,7 @@ class OccupancyChart extends StatelessWidget {
alignment: AlignmentDirectional.centerStart,
fit: BoxFit.scaleDown,
child: Text(
'${value.toStringAsFixed(0)}%',
'${(value).toStringAsFixed(0)}%',
style: context.textTheme.bodySmall?.copyWith(
fontSize: 12,
color: ColorsManager.greyColor,
@ -129,7 +128,6 @@ class OccupancyChart extends StatelessWidget {
);
final bottomTitles = AxisTitles(
axisNameWidget: const ChartsXAxisTitle(),
sideTitles: SideTitles(
showTitles: true,
getTitlesWidget: (value, _) => FittedBox(

View File

@ -23,46 +23,38 @@ class OccupancyEndSideBar extends StatelessWidget {
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
const AnalyticsSidebarHeader(title: 'Presence Sensor'),
Expanded(
child: SizedBox(
// height: MediaQuery.sizeOf(context).height * 0.2,
child: PowerClampEnergyStatusWidget(
status: [
PowerClampEnergyStatus(
iconPath: Assets.presenceState,
title: 'Presence Status',
value: _valueFromCode(
'presence_state',
state.deviceStatusList,
),
unit: '',
const AnalyticsSidebarHeader(title: 'Presnce Sensor'),
SizedBox(
height: MediaQuery.sizeOf(context).height * 0.2,
child: PowerClampEnergyStatusWidget(
status: [
PowerClampEnergyStatus(
iconPath: Assets.presenceState,
title: 'Presence Status',
value: _valueFromCode(
'presence_state',
state.deviceStatusList,
),
PowerClampEnergyStatus(
iconPath: Assets.presenceTimeIcon,
title: 'Presence Time',
value:
'${_valueFromCode('none_body_time', state.deviceStatusList)} Min',
unit: '',
),
PowerClampEnergyStatus(
iconPath: Assets.currentDistanceIcon,
title: 'Detection Distance',
value:
'${_valueFromCode('space_move_val', state.deviceStatusList)} M',
unit: '',
),
],
),
unit: '',
),
PowerClampEnergyStatus(
iconPath: Assets.presenceTimeIcon,
title: 'Presence Time',
value:
'${_valueFromCode('none_body_time', state.deviceStatusList)} Min',
unit: '',
),
PowerClampEnergyStatus(
iconPath: Assets.currentDistanceIcon,
title: 'Detection Distance',
value:
'${_valueFromCode('space_move_val', state.deviceStatusList)} M',
unit: '',
),
],
),
),
const SizedBox(height: 20),
Expanded(
flex: 2,
child: FittedBox(
child: Image.asset(Assets.autocadOccupancyImage),
),
),
],
),
);

View File

@ -1,23 +0,0 @@
import 'package:flutter/material.dart';
import 'package:syncrow_web/utils/color_manager.dart';
import 'package:syncrow_web/utils/extension/build_context_x.dart';
class ChartsXAxisTitle extends StatelessWidget {
const ChartsXAxisTitle({
this.label = 'Day of month',
super.key,
});
final String label;
@override
Widget build(BuildContext context) {
return Text(
label,
style: context.textTheme.bodySmall?.copyWith(
color: ColorsManager.lightGreyColor,
fontSize: 8,
),
);
}
}

View File

@ -50,11 +50,20 @@ class _DynamicTableState extends State<DynamicTable> {
bool _selectAll = false;
final ScrollController _verticalScrollController = ScrollController();
final ScrollController _horizontalScrollController = ScrollController();
late ScrollController _horizontalHeaderScrollController;
late ScrollController _horizontalBodyScrollController;
@override
void initState() {
super.initState();
_initializeSelection();
_horizontalHeaderScrollController = ScrollController();
_horizontalBodyScrollController = ScrollController();
// Synchronize horizontal scrolling
_horizontalBodyScrollController.addListener(() {
_horizontalHeaderScrollController
.jumpTo(_horizontalBodyScrollController.offset);
});
}
@override
@ -104,78 +113,108 @@ class _DynamicTableState extends State<DynamicTable> {
context.read<DeviceManagementBloc>().add(UpdateSelection(_selectedRows));
}
@override
void dispose() {
_horizontalHeaderScrollController.dispose();
_horizontalBodyScrollController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return Container(
decoration: widget.cellDecoration,
child: Scrollbar(
controller: _verticalScrollController,
thumbVisibility: true,
trackVisibility: true,
child: Scrollbar(
//fixed the horizontal scrollbar issue
controller: _horizontalScrollController,
thumbVisibility: true,
trackVisibility: true,
notificationPredicate: (notif) => notif.depth == 1,
child: SingleChildScrollView(
controller: _verticalScrollController,
child: Column(
children: [
Container(
decoration: widget.headerDecoration ??
const BoxDecoration(color: ColorsManager.boxColor),
child: SingleChildScrollView(
controller: _horizontalScrollController,
scrollDirection: Axis.horizontal,
physics: const NeverScrollableScrollPhysics(),
controller: _horizontalHeaderScrollController,
child: SizedBox(
width: widget.size.width,
child: Column(
child: Row(
children: [
Container(
decoration: widget.headerDecoration ??
const BoxDecoration(
color: ColorsManager.boxColor,
),
child: Row(
children: [
if (widget.withCheckBox) _buildSelectAllCheckbox(),
...List.generate(widget.headers.length, (index) {
return _buildTableHeaderCell(
widget.headers[index], index);
})
//...widget.headers.map((header) => _buildTableHeaderCell(header)),
],
),
),
SizedBox(
width: widget.size.width,
child: widget.isEmpty
? _buildEmptyState()
: Column(
children:
List.generate(widget.data.length, (rowIndex) {
final row = widget.data[rowIndex];
return Row(
children: [
if (widget.withCheckBox)
_buildRowCheckbox(
rowIndex, widget.size.height * 0.08),
...row.asMap().entries.map((entry) {
return _buildTableCell(
entry.value.toString(),
widget.size.height * 0.08,
rowIndex: rowIndex,
columnIndex: entry.key,
);
}).toList(),
],
);
}),
),
),
if (widget.withCheckBox) _buildSelectAllCheckbox(),
...List.generate(widget.headers.length, (index) {
return _buildTableHeaderCell(
widget.headers[index], index);
}),
],
),
),
),
),
Expanded(
child: Scrollbar(
controller: _verticalScrollController,
thumbVisibility: true,
trackVisibility: true,
child: SingleChildScrollView(
controller: _verticalScrollController,
child: Scrollbar(
controller: _horizontalBodyScrollController,
thumbVisibility: false,
trackVisibility: false,
notificationPredicate: (notif) => notif.depth == 1,
child: SingleChildScrollView(
scrollDirection: Axis.horizontal,
controller: _horizontalBodyScrollController,
child: Container(
color: ColorsManager.whiteColors,
child: SizedBox(
width: widget.size.width,
child: widget.isEmpty
? _buildEmptyState()
: Column(
children: List.generate(widget.data.length,
(rowIndex) {
final row = widget.data[rowIndex];
return Row(
children: [
if (widget.withCheckBox)
_buildRowCheckbox(rowIndex,
widget.size.height * 0.08),
...row.asMap().entries.map((entry) {
return _buildTableCell(
entry.value.toString(),
widget.size.height * 0.08,
rowIndex: rowIndex,
columnIndex: entry.key,
);
}).toList(),
],
);
}),
),
),
),
),
),
),
),
),
],
),
);
}
Widget _buildSelectAllCheckbox() {
return Container(
width: 50,
decoration: const BoxDecoration(
border: Border.symmetric(
vertical: BorderSide(color: ColorsManager.boxDivider),
),
),
child: Checkbox(
value: _selectAll,
onChanged: widget.withSelectAll && widget.data.isNotEmpty
? _toggleSelectAll
: null,
),
);
}
@ -205,23 +244,6 @@ class _DynamicTableState extends State<DynamicTable> {
),
],
);
Widget _buildSelectAllCheckbox() {
return Container(
width: 50,
decoration: const BoxDecoration(
border: Border.symmetric(
vertical: BorderSide(color: ColorsManager.boxDivider),
),
),
child: Checkbox(
value: _selectAll,
onChanged: widget.withSelectAll && widget.data.isNotEmpty
? _toggleSelectAll
: null,
),
);
}
Widget _buildRowCheckbox(int index, double size) {
return Container(
width: 50,
@ -276,8 +298,12 @@ class _DynamicTableState extends State<DynamicTable> {
);
}
Widget _buildTableCell(String content, double size,
{required int rowIndex, required int columnIndex}) {
Widget _buildTableCell(
String content,
double size, {
required int rowIndex,
required int columnIndex,
}) {
bool isBatteryLevel = content.endsWith('%');
double? batteryLevel;
@ -285,6 +311,7 @@ class _DynamicTableState extends State<DynamicTable> {
batteryLevel = double.tryParse(content.replaceAll('%', '').trim());
}
bool isSettingsColumn = widget.headers[columnIndex] == 'Settings';
if (isSettingsColumn) {
return buildSettingsIcon(
width: 120,
@ -389,10 +416,11 @@ class _DynamicTableState extends State<DynamicTable> {
padding: const EdgeInsets.all(8.0),
child: Center(
child: SvgPicture.asset(
Assets.settings,
Assets.settings, // ضع المسار الصحيح هنا
width: 40,
height: 22,
color: ColorsManager.primaryColor,
color: ColorsManager
.primaryColor, // نفس لون الأيقونة في الصورة
),
),
),

View File

@ -40,17 +40,18 @@ class DeviceManagementBloc
List<AllDevicesModel> devices = [];
_devices.clear();
var spaceBloc = event.context.read<SpaceTreeBloc>();
final projectUuid = await ProjectManager.getProjectUUID() ?? '';
final projectUuid = await ProjectManager.getProjectUUID() ?? '';
if (spaceBloc.state.selectedCommunities.isEmpty) {
devices = await DevicesManagementApi().fetchDevices('', '', projectUuid);
devices =
await DevicesManagementApi().fetchDevices('', '', projectUuid);
} else {
for (var community in spaceBloc.state.selectedCommunities) {
List<String> spacesList =
spaceBloc.state.selectedCommunityAndSpaces[community] ?? [];
for (var space in spacesList) {
devices.addAll(await DevicesManagementApi().fetchDevices(
community, space, projectUuid));
devices.addAll(await DevicesManagementApi()
.fetchDevices(community, space, projectUuid));
}
}
}
@ -100,7 +101,7 @@ class DeviceManagementBloc
));
if (currentProductName.isNotEmpty) {
add(SearchDevices(productName: currentProductName));
add(SearchDevices(deviceNameOrProductName: currentProductName));
}
}
}
@ -269,34 +270,41 @@ class DeviceManagementBloc
return 'All';
}
}
void _onSearchDevices(
SearchDevices event, Emitter<DeviceManagementState> emit) {
if ((event.community == null || event.community!.isEmpty) &&
(event.unitName == null || event.unitName!.isEmpty) &&
(event.productName == null || event.productName!.isEmpty)) {
(event.deviceNameOrProductName == null ||
event.deviceNameOrProductName!.isEmpty)) {
currentProductName = '';
if (state is DeviceManagementFiltered) {
add(FilterDevices(_getFilterFromIndex(_selectedIndex)));
} else {
return;
}
_filteredDevices = List.from(_devices);
emit(DeviceManagementLoaded(
devices: _devices,
selectedIndex: _selectedIndex,
onlineCount: _onlineCount,
offlineCount: _offlineCount,
lowBatteryCount: _lowBatteryCount,
selectedDevice: null,
isControlButtonEnabled: false,
));
return;
}
if (event.productName == currentProductName &&
if (event.deviceNameOrProductName == currentProductName &&
event.community == currentCommunity &&
event.unitName == currentUnitName &&
event.searchField) {
return;
}
currentProductName = event.productName ?? '';
currentProductName = event.deviceNameOrProductName ?? '';
currentCommunity = event.community;
currentUnitName = event.unitName;
List<AllDevicesModel> devicesToSearch = _filteredDevices;
List<AllDevicesModel> devicesToSearch = _devices;
if (devicesToSearch.isNotEmpty) {
final searchText = event.deviceNameOrProductName?.toLowerCase() ?? '';
final filteredDevices = devicesToSearch.where((device) {
final matchesCommunity = event.community == null ||
event.community!.isEmpty ||
@ -304,31 +312,25 @@ class DeviceManagementBloc
?.toLowerCase()
.contains(event.community!.toLowerCase()) ??
false);
final matchesUnit = event.unitName == null ||
event.unitName!.isEmpty ||
(device.spaces != null &&
device.spaces!.isNotEmpty &&
device.spaces![0].spaceName!
.toLowerCase()
.contains(event.unitName!.toLowerCase()));
final matchesProductName = event.productName == null ||
event.productName!.isEmpty ||
(device.name
?.toLowerCase()
.contains(event.productName!.toLowerCase()) ??
false);
final matchesDeviceName = event.productName == null ||
event.productName!.isEmpty ||
(device.categoryName
?.toLowerCase()
.contains(event.productName!.toLowerCase()) ??
false);
device.spaces!.any((space) =>
space.spaceName != null &&
space.spaceName!
.toLowerCase()
.contains(event.unitName!.toLowerCase())));
return matchesCommunity &&
matchesUnit &&
(matchesProductName || matchesDeviceName);
final matchesSearchText = searchText.isEmpty ||
(device.name?.toLowerCase().contains(searchText) ?? false) ||
(device.productName?.toLowerCase().contains(searchText) ?? false);
return matchesCommunity && matchesUnit && matchesSearchText;
}).toList();
_filteredDevices = filteredDevices;
emit(DeviceManagementFiltered(
filteredDevices: filteredDevices,
selectedIndex: _selectedIndex,

View File

@ -38,18 +38,18 @@ class SelectedFilterChanged extends DeviceManagementEvent {
class SearchDevices extends DeviceManagementEvent {
final String? community;
final String? unitName;
final String? productName;
final String? deviceNameOrProductName;
final bool searchField;
const SearchDevices({
this.community,
this.unitName,
this.productName,
this.deviceNameOrProductName,
this.searchField = false,
});
@override
List<Object?> get props => [community, unitName, productName];
List<Object?> get props => [community, unitName, deviceNameOrProductName];
}
class SelectDevice extends DeviceManagementEvent {

View File

@ -53,7 +53,7 @@ class _DeviceSearchFiltersState extends State<DeviceSearchFilters>
controller: controller,
onSubmitted: () {
final searchDevicesEvent = SearchDevices(
productName: _productNameController.text,
deviceNameOrProductName: _productNameController.text,
unitName: _unitNameController.text,
searchField: true,
);
@ -68,7 +68,7 @@ class _DeviceSearchFiltersState extends State<DeviceSearchFilters>
onSearch: () => context.read<DeviceManagementBloc>().add(
SearchDevices(
unitName: _unitNameController.text,
productName: _productNameController.text,
deviceNameOrProductName: _productNameController.text,
searchField: true,
),
),

View File

@ -1,138 +1,138 @@
class Assets {
Assets._();
static const String background = 'assets/images/Background.png';
static const String webBackground = 'assets/images/web_Background.svg';
static const String webBackgroundPng = 'assets/images/web_Background.png';
static const String blackLogo = 'assets/images/black-logo.png';
static const String logo = 'assets/images/Logo.svg';
static const String logoHorizontal = 'assets/images/logo_horizontal.png';
static const String vector = 'assets/images/Vector.png';
static const String loginLogo = 'assets/images/login_logo.svg';
static const String whiteLogo = 'assets/images/white-logo.png';
static const String window = 'assets/images/Window.png';
static const String liftLine = 'assets/images/lift_line.png';
static const String rightLine = 'assets/images/right_line.png';
static const String google = 'assets/images/google.svg';
static const String facebook = 'assets/images/facebook.svg';
static const String background = "assets/images/Background.png";
static const String webBackground = "assets/images/web_Background.svg";
static const String webBackgroundPng = "assets/images/web_Background.png";
static const String blackLogo = "assets/images/black-logo.png";
static const String logo = "assets/images/Logo.svg";
static const String logoHorizontal = "assets/images/logo_horizontal.png";
static const String vector = "assets/images/Vector.png";
static const String loginLogo = "assets/images/login_logo.svg";
static const String whiteLogo = "assets/images/white-logo.png";
static const String window = "assets/images/Window.png";
static const String liftLine = "assets/images/lift_line.png";
static const String rightLine = "assets/images/right_line.png";
static const String google = "assets/images/google.svg";
static const String facebook = "assets/images/facebook.svg";
static const String invisiblePassword =
'assets/images/Password_invisible.svg';
static const String visiblePassword = 'assets/images/password_visible.svg';
static const String accessIcon = 'assets/images/access_icon.svg';
"assets/images/Password_invisible.svg";
static const String visiblePassword = "assets/images/password_visible.svg";
static const String accessIcon = "assets/images/access_icon.svg";
static const String spaseManagementIcon =
'assets/images/spase_management_icon.svg';
static const String devicesIcon = 'assets/images/devices_icon.svg';
static const String analyticsIcon = 'assets/icons/landing_analytics.svg';
"assets/images/spase_management_icon.svg";
static const String devicesIcon = "assets/images/devices_icon.svg";
static const String analyticsIcon = "assets/icons/landing_analytics.svg";
static const String moveinIcon = 'assets/images/movein_icon.svg';
static const String constructionIcon = 'assets/images/construction_icon.svg';
static const String energyIcon = 'assets/images/energy_icon.svg';
static const String integrationsIcon = 'assets/images/Integrations_icon.svg';
static const String assetIcon = 'assets/images/asset_icon.svg';
static const String calendarIcon = 'assets/images/calendar_icon.svg';
static const String deviceNoteIcon = 'assets/images/device_note.svg';
static const String timeIcon = 'assets/images/time_icon.svg';
static const String emptyTable = 'assets/images/empty_table.svg';
static const String moveinIcon = "assets/images/movein_icon.svg";
static const String constructionIcon = "assets/images/construction_icon.svg";
static const String energyIcon = "assets/images/energy_icon.svg";
static const String integrationsIcon = "assets/images/Integrations_icon.svg";
static const String assetIcon = "assets/images/asset_icon.svg";
static const String calendarIcon = "assets/images/calendar_icon.svg";
static const String deviceNoteIcon = "assets/images/device_note.svg";
static const String timeIcon = "assets/images/time_icon.svg";
static const String emptyTable = "assets/images/empty_table.svg";
// General assets
static const String motionlessDetection =
'assets/icons/motionless_detection.svg';
static const String acHeating = 'assets/icons/ac_heating.svg';
static const String acPowerOff = 'assets/icons/ac_power_off.svg';
static const String acFanMiddle = 'assets/icons/ac_fan_middle.svg';
static const String switchAlarmSound = 'assets/icons/switch_alarm_sound.svg';
static const String resetOff = 'assets/icons/reset_off.svg';
"assets/icons/motionless_detection.svg";
static const String acHeating = "assets/icons/ac_heating.svg";
static const String acPowerOff = "assets/icons/ac_power_off.svg";
static const String acFanMiddle = "assets/icons/ac_fan_middle.svg";
static const String switchAlarmSound = "assets/icons/switch_alarm_sound.svg";
static const String resetOff = "assets/icons/reset_off.svg";
static const String sensitivityOperationIcon =
'assets/icons/sesitivity_operation_icon.svg';
static const String motionDetection = 'assets/icons/motion_detection.svg';
static const String freezing = 'assets/icons/freezing.svg';
static const String indicator = 'assets/icons/indicator.svg';
static const String sceneRefresh = 'assets/icons/scene_refresh.svg';
static const String temperature = 'assets/icons/tempreture.svg';
static const String acFanHigh = 'assets/icons/ac_fan_high.svg';
static const String fanSpeed = 'assets/icons/fan_speed.svg';
static const String acFanLow = 'assets/icons/ac_fan_low.svg';
static const String sensitivity = 'assets/icons/sensitivity.svg';
static const String lightCountdown = 'assets/icons/light_countdown.svg';
static const String farDetection = 'assets/icons/far_detection.svg';
static const String sceneChildUnlock = 'assets/icons/scene_child_unlock.svg';
static const String acFanAuto = 'assets/icons/ac_fan_auto.svg';
static const String childLock = 'assets/icons/child_lock.svg';
static const String factoryReset = 'assets/icons/factory_reset.svg';
static const String acCooling = 'assets/icons/ac_cooling.svg';
static const String sceneChildLock = 'assets/icons/scene_child_lock.svg';
static const String celsiusDegrees = 'assets/icons/celsius_degrees.svg';
static const String masterState = 'assets/icons/master_state.svg';
static const String acPower = 'assets/icons/ac_power.svg';
"assets/icons/sesitivity_operation_icon.svg";
static const String motionDetection = "assets/icons/motion_detection.svg";
static const String freezing = "assets/icons/freezing.svg";
static const String indicator = "assets/icons/indicator.svg";
static const String sceneRefresh = "assets/icons/scene_refresh.svg";
static const String temperature = "assets/icons/tempreture.svg";
static const String acFanHigh = "assets/icons/ac_fan_high.svg";
static const String fanSpeed = "assets/icons/fan_speed.svg";
static const String acFanLow = "assets/icons/ac_fan_low.svg";
static const String sensitivity = "assets/icons/sensitivity.svg";
static const String lightCountdown = "assets/icons/light_countdown.svg";
static const String farDetection = "assets/icons/far_detection.svg";
static const String sceneChildUnlock = "assets/icons/scene_child_unlock.svg";
static const String acFanAuto = "assets/icons/ac_fan_auto.svg";
static const String childLock = "assets/icons/child_lock.svg";
static const String factoryReset = "assets/icons/factory_reset.svg";
static const String acCooling = "assets/icons/ac_cooling.svg";
static const String sceneChildLock = "assets/icons/scene_child_lock.svg";
static const String celsiusDegrees = "assets/icons/celsius_degrees.svg";
static const String masterState = "assets/icons/master_state.svg";
static const String acPower = "assets/icons/ac_power.svg";
static const String farDetectionFunction =
'assets/icons/far_detection_function.svg';
static const String nobodyTime = 'assets/icons/nobody_time.svg';
"assets/icons/far_detection_function.svg";
static const String nobodyTime = "assets/icons/nobody_time.svg";
// Automation functions
static const String tempPasswordUnlock =
'assets/icons/automation_functions/temp_password_unlock.svg';
"assets/icons/automation_functions/temp_password_unlock.svg";
static const String doorlockNormalOpen =
'assets/icons/automation_functions/doorlock_normal_open.svg';
"assets/icons/automation_functions/doorlock_normal_open.svg";
static const String doorbell =
'assets/icons/automation_functions/doorbell.svg';
"assets/icons/automation_functions/doorbell.svg";
static const String remoteUnlockViaApp =
'assets/icons/automation_functions/remote_unlock_via_app.svg';
"assets/icons/automation_functions/remote_unlock_via_app.svg";
static const String doubleLock =
'assets/icons/automation_functions/double_lock.svg';
"assets/icons/automation_functions/double_lock.svg";
static const String selfTestResult =
'assets/icons/automation_functions/self_test_result.svg';
"assets/icons/automation_functions/self_test_result.svg";
static const String lockAlarm =
'assets/icons/automation_functions/lock_alarm.svg';
"assets/icons/automation_functions/lock_alarm.svg";
static const String presenceState =
'assets/icons/automation_functions/presence_state.svg';
"assets/icons/automation_functions/presence_state.svg";
static const String currentTemp =
'assets/icons/automation_functions/current_temp.svg';
"assets/icons/automation_functions/current_temp.svg";
static const String presence =
'assets/icons/automation_functions/presence.svg';
"assets/icons/automation_functions/presence.svg";
static const String residualElectricity =
'assets/icons/automation_functions/residual_electricity.svg';
"assets/icons/automation_functions/residual_electricity.svg";
static const String hijackAlarm =
'assets/icons/automation_functions/hijack_alarm.svg';
"assets/icons/automation_functions/hijack_alarm.svg";
static const String passwordUnlock =
'assets/icons/automation_functions/password_unlock.svg';
"assets/icons/automation_functions/password_unlock.svg";
static const String remoteUnlockRequest =
'assets/icons/automation_functions/remote_unlock_req.svg';
"assets/icons/automation_functions/remote_unlock_req.svg";
static const String cardUnlock =
'assets/icons/automation_functions/card_unlock.svg';
static const String motion = 'assets/icons/automation_functions/motion.svg';
"assets/icons/automation_functions/card_unlock.svg";
static const String motion = "assets/icons/automation_functions/motion.svg";
static const String fingerprintUnlock =
'assets/icons/automation_functions/fingerprint_unlock.svg';
"assets/icons/automation_functions/fingerprint_unlock.svg";
// Presence Sensor Assets
static const String sensorMotionIcon = 'assets/icons/sensor_motion_ic.svg';
static const String sensorMotionIcon = "assets/icons/sensor_motion_ic.svg";
static const String sensorPresenceIcon =
'assets/icons/sensor_presence_ic.svg';
static const String sensorVacantIcon = 'assets/icons/sensor_vacant_ic.svg';
"assets/icons/sensor_presence_ic.svg";
static const String sensorVacantIcon = "assets/icons/sensor_vacant_ic.svg";
static const String illuminanceRecordIcon =
'assets/icons/illuminance_record_ic.svg';
"assets/icons/illuminance_record_ic.svg";
static const String presenceRecordIcon =
'assets/icons/presence_record_ic.svg';
"assets/icons/presence_record_ic.svg";
static const String helpDescriptionIcon =
'assets/icons/help_description_ic.svg';
"assets/icons/help_description_ic.svg";
static const String lightPulp = 'assets/icons/light_pulb.svg';
static const String acDevice = 'assets/icons/ac_device.svg';
static const String acAirConditioner = 'assets/icons/ac_air.svg';
static const String acSun = 'assets/icons/ac_sun.svg';
static const String lightPulp = "assets/icons/light_pulb.svg";
static const String acDevice = "assets/icons/ac_device.svg";
static const String acAirConditioner = "assets/icons/ac_air.svg";
static const String acSun = "assets/icons/ac_sun.svg";
//assets/icons/3GangSwitch.svg
static const String gangSwitch = 'assets/icons/3GangSwitch.svg';
static const String gangSwitch = "assets/icons/3GangSwitch.svg";
//assets/icons/AC.svg
static const String ac = 'assets/icons/AC.svg';
static const String ac = "assets/icons/AC.svg";
//assets/icons/Curtain.svg
static const String curtain = 'assets/icons/Curtain.svg';
static const String curtain = "assets/icons/Curtain.svg";
//assets/icons/doorLock.svg
static const String doorLock = 'assets/icons/doorLock.svg';
static const String doorLock = "assets/icons/doorLock.svg";
//assets/icons/Gateway.svg
static const String gateway = 'assets/icons/Gateway.svg';
static const String gateway = "assets/icons/Gateway.svg";
//assets/icons/Light.svg
static const String lightBulb = 'assets/icons/Light.svg';
static const String lightBulb = "assets/icons/Light.svg";
//assets/icons/sensors.svg
static const String sensors = 'assets/icons/sensors.svg';
static const String sensors = "assets/icons/sensors.svg";
//assets/icons/door_un_look_ic.svg
static const String doorUnlock = 'assets/icons/door_un_look_ic.svg';
@ -175,7 +175,7 @@ class Assets {
static const String Gang1SwitchIcon = 'assets/icons/1_Gang_switch_icon.svg';
static const String DoorLockIcon = 'assets/icons/door_lock.svg';
static const String SmartGatewayIcon = 'assets/icons/smart_gateway_icon.svg';
static const String curtainIcon = 'assets/images/curtain.svg';
static const String curtainIcon = "assets/images/curtain.svg";
static const String unlock = 'assets/icons/unlock_ic.svg';
static const String firmware = 'assets/icons/firmware.svg';
//assets/images/scheduling.svg
@ -227,12 +227,12 @@ class Assets {
//assets/icons/2gang.svg
static const String twoGang = 'assets/icons/2gang.svg';
static const String frequencyIcon = 'assets/icons/frequency_icon.svg';
static const String voltMeterIcon = 'assets/icons/volt_meter_icon.svg';
static const String powerActiveIcon = 'assets/icons/power_active_icon.svg';
static const String searchIcon = 'assets/icons/search_icon.svg';
static const String voltageIcon = 'assets/icons/voltage_icon.svg';
static const String speedoMeter = 'assets/icons/speedo_meter.svg';
static const String frequencyIcon = "assets/icons/frequency_icon.svg";
static const String voltMeterIcon = "assets/icons/volt_meter_icon.svg";
static const String powerActiveIcon = "assets/icons/power_active_icon.svg";
static const String searchIcon = "assets/icons/search_icon.svg";
static const String voltageIcon = "assets/icons/voltage_icon.svg";
static const String speedoMeter = "assets/icons/speedo_meter.svg";
//assets/icons/account_setting.svg
static const String accountSetting = 'assets/icons/account_setting.svg';
@ -284,99 +284,99 @@ class Assets {
// Assets for functions_icons
static const String assetsSensitivityFunction =
'assets/icons/functions_icons/sensitivity.svg';
"assets/icons/functions_icons/sensitivity.svg";
static const String assetsSensitivityOperationIcon =
'assets/icons/functions_icons/sesitivity_operation_icon.svg';
"assets/icons/functions_icons/sesitivity_operation_icon.svg";
static const String assetsAcPower =
'assets/icons/functions_icons/ac_power.svg';
"assets/icons/functions_icons/ac_power.svg";
static const String assetsAcPowerOFF =
'assets/icons/functions_icons/ac_power_off.svg';
"assets/icons/functions_icons/ac_power_off.svg";
static const String assetsChildLock =
'assets/icons/functions_icons/child_lock.svg';
"assets/icons/functions_icons/child_lock.svg";
static const String assetsFreezing =
'assets/icons/functions_icons/freezing.svg';
"assets/icons/functions_icons/freezing.svg";
static const String assetsFanSpeed =
'assets/icons/functions_icons/fan_speed.svg';
"assets/icons/functions_icons/fan_speed.svg";
static const String assetsAcCooling =
'assets/icons/functions_icons/ac_cooling.svg';
"assets/icons/functions_icons/ac_cooling.svg";
static const String assetsAcHeating =
'assets/icons/functions_icons/ac_heating.svg';
"assets/icons/functions_icons/ac_heating.svg";
static const String assetsCelsiusDegrees =
'assets/icons/functions_icons/celsius_degrees.svg';
"assets/icons/functions_icons/celsius_degrees.svg";
static const String assetsTempreture =
'assets/icons/functions_icons/tempreture.svg';
"assets/icons/functions_icons/tempreture.svg";
static const String assetsAcFanLow =
'assets/icons/functions_icons/ac_fan_low.svg';
"assets/icons/functions_icons/ac_fan_low.svg";
static const String assetsAcFanMiddle =
'assets/icons/functions_icons/ac_fan_middle.svg';
"assets/icons/functions_icons/ac_fan_middle.svg";
static const String assetsAcFanHigh =
'assets/icons/functions_icons/ac_fan_high.svg';
"assets/icons/functions_icons/ac_fan_high.svg";
static const String assetsAcFanAuto =
'assets/icons/functions_icons/ac_fan_auto.svg';
"assets/icons/functions_icons/ac_fan_auto.svg";
static const String assetsSceneChildLock =
'assets/icons/functions_icons/scene_child_lock.svg';
"assets/icons/functions_icons/scene_child_lock.svg";
static const String assetsSceneChildUnlock =
'assets/icons/functions_icons/scene_child_unlock.svg';
"assets/icons/functions_icons/scene_child_unlock.svg";
static const String assetsSceneRefresh =
'assets/icons/functions_icons/scene_refresh.svg';
"assets/icons/functions_icons/scene_refresh.svg";
static const String assetsLightCountdown =
'assets/icons/functions_icons/light_countdown.svg';
"assets/icons/functions_icons/light_countdown.svg";
static const String assetsFarDetection =
'assets/icons/functions_icons/far_detection.svg';
"assets/icons/functions_icons/far_detection.svg";
static const String assetsFarDetectionFunction =
'assets/icons/functions_icons/far_detection_function.svg';
"assets/icons/functions_icons/far_detection_function.svg";
static const String assetsIndicator =
'assets/icons/functions_icons/indicator.svg';
"assets/icons/functions_icons/indicator.svg";
static const String assetsMotionDetection =
'assets/icons/functions_icons/motion_detection.svg';
"assets/icons/functions_icons/motion_detection.svg";
static const String assetsMotionlessDetection =
'assets/icons/functions_icons/motionless_detection.svg';
"assets/icons/functions_icons/motionless_detection.svg";
static const String assetsNobodyTime =
'assets/icons/functions_icons/nobody_time.svg';
"assets/icons/functions_icons/nobody_time.svg";
static const String assetsFactoryReset =
'assets/icons/functions_icons/factory_reset.svg';
"assets/icons/functions_icons/factory_reset.svg";
static const String assetsMasterState =
'assets/icons/functions_icons/master_state.svg';
"assets/icons/functions_icons/master_state.svg";
static const String assetsSwitchAlarmSound =
'assets/icons/functions_icons/switch_alarm_sound.svg';
"assets/icons/functions_icons/switch_alarm_sound.svg";
static const String assetsResetOff =
'assets/icons/functions_icons/reset_off.svg';
"assets/icons/functions_icons/reset_off.svg";
// Assets for automation_functions
static const String assetsCardUnlock =
'assets/icons/functions_icons/automation_functions/card_unlock.svg';
"assets/icons/functions_icons/automation_functions/card_unlock.svg";
static const String assetsDoorbell =
'assets/icons/functions_icons/automation_functions/doorbell.svg';
"assets/icons/functions_icons/automation_functions/doorbell.svg";
static const String assetsDoorlockNormalOpen =
'assets/icons/functions_icons/automation_functions/doorlock_normal_open.svg';
"assets/icons/functions_icons/automation_functions/doorlock_normal_open.svg";
static const String assetsDoubleLock =
'assets/icons/functions_icons/automation_functions/double_lock.svg';
"assets/icons/functions_icons/automation_functions/double_lock.svg";
static const String assetsFingerprintUnlock =
'assets/icons/functions_icons/automation_functions/fingerprint_unlock.svg';
"assets/icons/functions_icons/automation_functions/fingerprint_unlock.svg";
static const String assetsHijackAlarm =
'assets/icons/functions_icons/automation_functions/hijack_alarm.svg';
"assets/icons/functions_icons/automation_functions/hijack_alarm.svg";
static const String assetsLockAlarm =
'assets/icons/functions_icons/automation_functions/lock_alarm.svg';
"assets/icons/functions_icons/automation_functions/lock_alarm.svg";
static const String assetsPasswordUnlock =
'assets/icons/functions_icons/automation_functions/password_unlock.svg';
"assets/icons/functions_icons/automation_functions/password_unlock.svg";
static const String assetsRemoteUnlockReq =
'assets/icons/functions_icons/automation_functions/remote_unlock_req.svg';
"assets/icons/functions_icons/automation_functions/remote_unlock_req.svg";
static const String assetsRemoteUnlockViaApp =
'assets/icons/functions_icons/automation_functions/remote_unlock_via_app.svg';
"assets/icons/functions_icons/automation_functions/remote_unlock_via_app.svg";
static const String assetsResidualElectricity =
'assets/icons/functions_icons/automation_functions/residual_electricity.svg';
"assets/icons/functions_icons/automation_functions/residual_electricity.svg";
static const String assetsTempPasswordUnlock =
'assets/icons/functions_icons/automation_functions/temp_password_unlock.svg';
"assets/icons/functions_icons/automation_functions/temp_password_unlock.svg";
static const String assetsSelfTestResult =
'assets/icons/functions_icons/automation_functions/self_test_result.svg';
"assets/icons/functions_icons/automation_functions/self_test_result.svg";
static const String assetsPresence =
'assets/icons/functions_icons/automation_functions/presence.svg';
"assets/icons/functions_icons/automation_functions/presence.svg";
static const String assetsMotion =
'assets/icons/functions_icons/automation_functions/motion.svg';
"assets/icons/functions_icons/automation_functions/motion.svg";
static const String assetsCurrentTemp =
'assets/icons/functions_icons/automation_functions/current_temp.svg';
"assets/icons/functions_icons/automation_functions/current_temp.svg";
static const String assetsPresenceState =
'assets/icons/functions_icons/automation_functions/presence_state.svg';
"assets/icons/functions_icons/automation_functions/presence_state.svg";
//assets/icons/routine/automation.svg
static const String automation = 'assets/icons/routine/automation.svg';
static const String searchIconUser = 'assets/icons/search_icon_user.svg';
@ -501,5 +501,4 @@ class Assets {
static const String aqiAirQuality = 'assets/icons/aqi_air_quality.svg';
static const String temperatureAqiSidebar = 'assets/icons/thermometer.svg';
static const String humidityAqiSidebar = 'assets/icons/humidity.svg';
static const String autocadOccupancyImage = 'assets/images/autocad_occupancy_image.png';
}