Fix(ui): Fix some ui bugs
Find Button In DeviceLogsScreen Fix offlineText when in DarkMode Update offlineIcons
This commit is contained in:
Binary file not shown.
|
Before Width: | Height: | Size: 18 KiB After Width: | Height: | Size: 36 KiB |
@@ -2,10 +2,10 @@
|
||||
import 'package:dropdown_button2/dropdown_button2.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:intl/intl.dart';
|
||||
import 'package:sfm_app/product/constant/app/app_constants.dart';
|
||||
import 'widgets/tag_widget.dart';
|
||||
import '../devices/device_model.dart';
|
||||
import '../../bloc/device_logs_bloc.dart';
|
||||
import '../../product/constant/app/app_constants.dart';
|
||||
import '../../product/constant/icon/icon_constants.dart';
|
||||
import '../../product/extension/context_extension.dart';
|
||||
import '../../product/services/language_services.dart';
|
||||
@@ -175,11 +175,11 @@ class _DeviceLogsScreenState extends State<DeviceLogsScreen> {
|
||||
),
|
||||
Center(
|
||||
child: TextButton.icon(
|
||||
style: const ButtonStyle(
|
||||
style: ButtonStyle(
|
||||
backgroundColor:
|
||||
WidgetStatePropertyAll(Colors.green),
|
||||
WidgetStatePropertyAll(Theme.of(context).primaryColor),
|
||||
foregroundColor:
|
||||
WidgetStatePropertyAll(Colors.white),
|
||||
WidgetStatePropertyAll(Theme.of(context).colorScheme.surfaceBright),
|
||||
),
|
||||
onPressed: () {
|
||||
if (fromDateApi.isEmpty) {
|
||||
@@ -200,8 +200,7 @@ class _DeviceLogsScreenState extends State<DeviceLogsScreen> {
|
||||
// log("ThingID: $thingID");
|
||||
// log("From Date: ${DateTimeUtils.instance.formatDateTimeToString(dateTime!)}");
|
||||
},
|
||||
icon: IconConstants.instance
|
||||
.getMaterialIcon(Icons.search),
|
||||
icon: Icon(Icons.search,color: Theme.of(context).colorScheme.surfaceBright,),
|
||||
label: Text(
|
||||
appLocalization(context)
|
||||
.find_button_content,
|
||||
|
||||
@@ -100,7 +100,7 @@ class _DetailDeviceScreenState extends State<DetailDeviceScreen> {
|
||||
if (sensorSnapshot.data != null) {
|
||||
return Scaffold(
|
||||
appBar: AppBar(
|
||||
title: Text(appLocalization(context).detail_message),
|
||||
title: Text(deviceSnapshot.data?.name ?? ""),
|
||||
centerTitle: true,
|
||||
),
|
||||
body: SingleChildScrollView(
|
||||
@@ -122,28 +122,28 @@ class _DetailDeviceScreenState extends State<DetailDeviceScreen> {
|
||||
fit: BoxFit.fill,
|
||||
),
|
||||
),
|
||||
Center(
|
||||
child: Container(
|
||||
height: 50,
|
||||
width: 400,
|
||||
// color: Colors.blueAccent,
|
||||
alignment: Alignment.centerRight,
|
||||
margin: const EdgeInsets.fromLTRB(0, 0, 0, 50),
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
const SizedBox(),
|
||||
Text(
|
||||
deviceSnapshot.data?.name ?? "",
|
||||
style: const TextStyle(
|
||||
fontSize: 25,
|
||||
fontWeight: FontWeight.w600,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
// Center(
|
||||
// child: Container(
|
||||
// height: 50,
|
||||
// width: 400,
|
||||
// // color: Colors.blueAccent,
|
||||
// alignment: Alignment.centerRight,
|
||||
// margin: const EdgeInsets.fromLTRB(0, 0, 0, 50),
|
||||
// child: Row(
|
||||
// mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
// children: [
|
||||
// const SizedBox(),
|
||||
// Text(
|
||||
// deviceSnapshot.data?.name ?? "",
|
||||
// style: const TextStyle(
|
||||
// fontSize: 25,
|
||||
// fontWeight: FontWeight.w600,
|
||||
// ),
|
||||
// ),
|
||||
// ],
|
||||
// ),
|
||||
// ),
|
||||
// ),
|
||||
],
|
||||
),
|
||||
),
|
||||
@@ -157,7 +157,7 @@ class _DetailDeviceScreenState extends State<DetailDeviceScreen> {
|
||||
width: context.dynamicWidth(0.5),
|
||||
decoration: BoxDecoration(
|
||||
color: DeviceUtils.instance
|
||||
.getTableRowColor(deviceSnapshot.data?.state ?? 3),
|
||||
.getTableRowColor(context,deviceSnapshot.data?.state ?? 3),
|
||||
borderRadius: BorderRadius.circular(50),
|
||||
),
|
||||
alignment: Alignment.bottomCenter,
|
||||
@@ -192,7 +192,7 @@ class _DetailDeviceScreenState extends State<DetailDeviceScreen> {
|
||||
)
|
||||
: CircleAvatar(
|
||||
backgroundColor:
|
||||
DeviceUtils.instance.getTableRowColor(
|
||||
DeviceUtils.instance.getTableRowColor(context,
|
||||
deviceSnapshot.data?.state ?? 3,
|
||||
),
|
||||
minRadius: context.mediumValue,
|
||||
|
||||
@@ -89,103 +89,98 @@ class _DevicesManagerScreenState extends State<DevicesManagerScreen> {
|
||||
builder: (context, roleSnapshot) {
|
||||
return SizedBox(
|
||||
height: context.dynamicHeight(0.4),
|
||||
child: CardTheme(
|
||||
color: Theme.of(context).colorScheme.onPrimary,
|
||||
shadowColor:
|
||||
Theme.of(context).colorScheme.onPrimary,
|
||||
child: PaginatedDataTable2(
|
||||
headingRowHeight: 30,
|
||||
columnSpacing: 30,
|
||||
horizontalMargin: 10,
|
||||
fixedLeftColumns: 1,
|
||||
autoRowsToHeight: true,
|
||||
renderEmptyRowsInTheEnd: false,
|
||||
dragStartBehavior: DragStartBehavior.down,
|
||||
minWidth: 950,
|
||||
header: Center(
|
||||
child: Text(
|
||||
appLocalization(context)
|
||||
.paginated_data_table_title,
|
||||
style: context.headlineMediumTextStyle,
|
||||
),
|
||||
child: PaginatedDataTable2(
|
||||
headingRowHeight: 30,
|
||||
columnSpacing: 30,
|
||||
horizontalMargin: 10,
|
||||
fixedLeftColumns: 1,
|
||||
autoRowsToHeight: true,
|
||||
renderEmptyRowsInTheEnd: false,
|
||||
dragStartBehavior: DragStartBehavior.down,
|
||||
minWidth: 950,
|
||||
header: Center(
|
||||
child: Text(
|
||||
appLocalization(context)
|
||||
.paginated_data_table_title,
|
||||
style: context.headlineMediumTextStyle,
|
||||
),
|
||||
columns: [
|
||||
if (roleSnapshot.data ==
|
||||
RoleEnums.ADMIN.name ||
|
||||
roleSnapshot.data ==
|
||||
RoleEnums.USER.name)
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceName),
|
||||
),
|
||||
),
|
||||
columns: [
|
||||
if (roleSnapshot.data ==
|
||||
RoleEnums.ADMIN.name ||
|
||||
roleSnapshot.data ==
|
||||
RoleEnums.USER.name)
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceStatus),
|
||||
.paginated_data_table_column_deviceName),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceBaterry),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceSignal),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceTemperature),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceHump),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_devicePower),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_action),
|
||||
),
|
||||
],
|
||||
onPageChanged: (int pageIndex) {
|
||||
// log('Chuyen page: $pageIndex');
|
||||
},
|
||||
// rowsPerPage:
|
||||
// (allDeviceSnapshot.data?.length ?? 1) < 6
|
||||
// ? (allDeviceSnapshot.data?.length ??
|
||||
// 0)
|
||||
// : 5,
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceStatus),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceBaterry),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceSignal),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceTemperature),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_deviceHump),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_devicePower),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text(appLocalization(context)
|
||||
.paginated_data_table_column_action),
|
||||
),
|
||||
],
|
||||
onPageChanged: (int pageIndex) {
|
||||
// log('Chuyen page: $pageIndex');
|
||||
},
|
||||
// rowsPerPage:
|
||||
// (allDeviceSnapshot.data?.length ?? 1) < 6
|
||||
// ? (allDeviceSnapshot.data?.length ??
|
||||
// 0)
|
||||
// : 5,
|
||||
|
||||
actions: [
|
||||
if (roleSnapshot.data ==
|
||||
RoleEnums.USER.name ||
|
||||
roleSnapshot.data ==
|
||||
RoleEnums.ADMIN.name)
|
||||
IconButton(
|
||||
style: ButtonStyle(
|
||||
backgroundColor:
|
||||
WidgetStateProperty.all<Color>(
|
||||
Colors.green),
|
||||
iconColor:
|
||||
WidgetStateProperty.all<Color>(
|
||||
Colors.white,
|
||||
),
|
||||
actions: [
|
||||
if (roleSnapshot.data ==
|
||||
RoleEnums.USER.name ||
|
||||
roleSnapshot.data ==
|
||||
RoleEnums.ADMIN.name)
|
||||
IconButton(
|
||||
style: ButtonStyle(
|
||||
backgroundColor:
|
||||
WidgetStateProperty.all<Color>(
|
||||
Colors.green),
|
||||
iconColor:
|
||||
WidgetStateProperty.all<Color>(
|
||||
Colors.white,
|
||||
),
|
||||
onPressed: () {
|
||||
ScaffoldMessenger.of(context)
|
||||
.clearSnackBars();
|
||||
addNewDevice(context,
|
||||
roleSnapshot.data ?? role);
|
||||
},
|
||||
icon: IconConstants.instance
|
||||
.getMaterialIcon(Icons.add))
|
||||
],
|
||||
source: DeviceSource(
|
||||
devices: allDeviceSnapshot.data ?? devices,
|
||||
context: context,
|
||||
devicesBloc: devicesManagerBloc,
|
||||
role: role,
|
||||
),
|
||||
),
|
||||
onPressed: () {
|
||||
ScaffoldMessenger.of(context)
|
||||
.clearSnackBars();
|
||||
addNewDevice(context,
|
||||
roleSnapshot.data ?? role);
|
||||
},
|
||||
icon: IconConstants.instance
|
||||
.getMaterialIcon(Icons.add))
|
||||
],
|
||||
source: DeviceSource(
|
||||
devices: allDeviceSnapshot.data ?? devices,
|
||||
context: context,
|
||||
devicesBloc: devicesManagerBloc,
|
||||
role: role,
|
||||
),
|
||||
),
|
||||
);
|
||||
@@ -265,7 +260,7 @@ class DeviceSource extends DataTableSource {
|
||||
Text(device.name!,
|
||||
style: TextStyle(
|
||||
color: DeviceUtils.instance
|
||||
.getTableRowColor(device.state!))), onTap: () {
|
||||
.getTableRowColor(context,device.state!))), onTap: () {
|
||||
context.pushNamed(AppRoutes.DEVICE_DETAIL.name,
|
||||
pathParameters: {'thingID': device.thingId!});
|
||||
}),
|
||||
@@ -273,36 +268,36 @@ class DeviceSource extends DataTableSource {
|
||||
Text(deviceState,
|
||||
style: TextStyle(
|
||||
color: DeviceUtils.instance
|
||||
.getTableRowColor(device.state!))), onTap: () {
|
||||
.getTableRowColor(context,device.state!))), onTap: () {
|
||||
context.pushNamed(AppRoutes.DEVICE_DETAIL.name,
|
||||
pathParameters: {'thingID': device.thingId!});
|
||||
}),
|
||||
DataCell(
|
||||
Text(sensorMap['sensorBattery'] + "%",
|
||||
style: TextStyle(
|
||||
color: DeviceUtils.instance.getTableRowColor(device.state!))),
|
||||
color: DeviceUtils.instance.getTableRowColor(context,device.state!))),
|
||||
onTap: () => context.pushNamed(AppRoutes.DEVICE_DETAIL.name,
|
||||
pathParameters: {'thingID': device.thingId!}),
|
||||
),
|
||||
DataCell(
|
||||
Text(sensorMap['sensorCsq'],
|
||||
style: TextStyle(
|
||||
color: DeviceUtils.instance.getTableRowColor(device.state!))),
|
||||
color: DeviceUtils.instance.getTableRowColor(context,device.state!))),
|
||||
),
|
||||
DataCell(
|
||||
Text("${sensorMap['sensorTemp']}°C",
|
||||
style: TextStyle(
|
||||
color: DeviceUtils.instance.getTableRowColor(device.state!))),
|
||||
color: DeviceUtils.instance.getTableRowColor(context,device.state!))),
|
||||
),
|
||||
DataCell(
|
||||
Text("${sensorMap['sensorHum']}%",
|
||||
style: TextStyle(
|
||||
color: DeviceUtils.instance.getTableRowColor(device.state!))),
|
||||
color: DeviceUtils.instance.getTableRowColor(context,device.state!))),
|
||||
),
|
||||
DataCell(
|
||||
Text("${sensorMap['sensorVolt']}V",
|
||||
style: TextStyle(
|
||||
color: DeviceUtils.instance.getTableRowColor(device.state!))),
|
||||
color: DeviceUtils.instance.getTableRowColor(context,device.state!))),
|
||||
),
|
||||
DataCell(
|
||||
Center(
|
||||
@@ -354,7 +349,7 @@ class TagState extends StatelessWidget {
|
||||
height: context.mediumValue,
|
||||
width: context.dynamicWidth(0.35),
|
||||
decoration: BoxDecoration(
|
||||
color: DeviceUtils.instance.getTableRowColor(state),
|
||||
color: DeviceUtils.instance.getTableRowColor(context,state),
|
||||
borderRadius: BorderRadius.circular(context.mediumValue),
|
||||
),
|
||||
child: Row(
|
||||
|
||||
@@ -461,7 +461,7 @@ class _DetailGroupScreenState extends State<DetailGroupScreen> {
|
||||
DeviceUtils.instance.checkStateDevice(
|
||||
context, devices[index].state!),
|
||||
style: TextStyle(
|
||||
color: DeviceUtils.instance.getTableRowColor(
|
||||
color: DeviceUtils.instance.getTableRowColor(context,
|
||||
devices[index].state!,
|
||||
),
|
||||
),
|
||||
|
||||
@@ -294,7 +294,7 @@ class DeviceSource extends DataTableSource {
|
||||
device.name!,
|
||||
style: TextStyle(
|
||||
color:
|
||||
DeviceUtils.instance.getTableRowColor(device.state ?? -1)),
|
||||
DeviceUtils.instance.getTableRowColor(context,device.state ?? -1)),
|
||||
),
|
||||
onTap: () {
|
||||
mapBloc.updateCameraPosition(
|
||||
@@ -311,7 +311,7 @@ class DeviceSource extends DataTableSource {
|
||||
deviceState,
|
||||
style: TextStyle(
|
||||
color:
|
||||
DeviceUtils.instance.getTableRowColor(device.state ?? -1)),
|
||||
DeviceUtils.instance.getTableRowColor(context,device.state ?? -1)),
|
||||
),
|
||||
onTap: () {
|
||||
mapBloc.updateCameraPosition(
|
||||
@@ -327,7 +327,7 @@ class DeviceSource extends DataTableSource {
|
||||
sensorMap['sensorBattery'] + "%",
|
||||
style: TextStyle(
|
||||
color:
|
||||
DeviceUtils.instance.getTableRowColor(device.state ?? -1)),
|
||||
DeviceUtils.instance.getTableRowColor(context,device.state ?? -1)),
|
||||
),
|
||||
onTap: () {
|
||||
mapBloc.updateCameraPosition(
|
||||
@@ -343,7 +343,7 @@ class DeviceSource extends DataTableSource {
|
||||
sensorMap['sensorCsq'],
|
||||
style: TextStyle(
|
||||
color:
|
||||
DeviceUtils.instance.getTableRowColor(device.state ?? -1)),
|
||||
DeviceUtils.instance.getTableRowColor(context,device.state ?? -1)),
|
||||
),
|
||||
onTap: () {
|
||||
mapBloc.updateCameraPosition(
|
||||
|
||||
@@ -151,7 +151,7 @@ class DeviceUtils {
|
||||
return devices..sort((a, b) => (a.name ?? '').compareTo(b.name ?? ''));
|
||||
}
|
||||
|
||||
Color getTableRowColor(int state) {
|
||||
Color getTableRowColor(BuildContext context, int state) {
|
||||
if (state == 1) {
|
||||
return Colors.red;
|
||||
} else if (state == 0) {
|
||||
@@ -161,7 +161,7 @@ class DeviceUtils {
|
||||
} else if (state == -1) {
|
||||
return Colors.grey;
|
||||
} else {
|
||||
return Colors.black87;
|
||||
return Theme.of(context).colorScheme.onSurface;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user