View now a stateful widget to prevent memory leeks
This commit is contained in:
parent
284e7ba451
commit
b7fb821abe
@ -171,6 +171,7 @@ class _EntityWidgetState extends State<EntityWidget> {
|
|||||||
return _buildBadgeWidget(context);
|
return _buildBadgeWidget(context);
|
||||||
} else {
|
} else {
|
||||||
TheLogger.log("Error", "Unknown entity widget type: ${widget.widgetType}");
|
TheLogger.log("Error", "Unknown entity widget type: ${widget.widgetType}");
|
||||||
|
return Container(width: 0.0, height: 0.0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,8 +28,8 @@ class HomeAssistant {
|
|||||||
StreamSubscription _socketSubscription;
|
StreamSubscription _socketSubscription;
|
||||||
|
|
||||||
int messageExpirationTime = 50; //seconds
|
int messageExpirationTime = 50; //seconds
|
||||||
Duration fetchTimeout = Duration(seconds: 45);
|
Duration fetchTimeout = Duration(seconds: 30);
|
||||||
Duration connectTimeout = Duration(seconds: 15);
|
Duration connectTimeout = Duration(seconds: 10);
|
||||||
|
|
||||||
String get locationName => _instanceConfig["location_name"] ?? "";
|
String get locationName => _instanceConfig["location_name"] ?? "";
|
||||||
int get viewsCount => _entities.viewList.length ?? 0;
|
int get viewsCount => _entities.viewList.length ?? 0;
|
||||||
@ -95,8 +95,10 @@ class HomeAssistant {
|
|||||||
(message) => _handleMessage(_connectionCompleter, message),
|
(message) => _handleMessage(_connectionCompleter, message),
|
||||||
cancelOnError: true,
|
cancelOnError: true,
|
||||||
onDone: () {
|
onDone: () {
|
||||||
TheLogger.log("Debug","Socket stream closed. Disconnected.");
|
TheLogger.log("Debug","Disconnect detected. Reconnecting...");
|
||||||
disconnect();
|
disconnect().then((_) {
|
||||||
|
_connection();
|
||||||
|
});
|
||||||
},
|
},
|
||||||
onError: (e) {
|
onError: (e) {
|
||||||
TheLogger.log("Error","Socket stream Error: $e");
|
TheLogger.log("Error","Socket stream Error: $e");
|
||||||
@ -129,7 +131,9 @@ class HomeAssistant {
|
|||||||
_completeConnecting(error);
|
_completeConnecting(error);
|
||||||
if (!_fetchCompleter.isCompleted) {
|
if (!_fetchCompleter.isCompleted) {
|
||||||
if (error != null) {
|
if (error != null) {
|
||||||
|
disconnect().then((_){
|
||||||
_fetchCompleter.completeError(error);
|
_fetchCompleter.completeError(error);
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
_fetchCompleter.complete();
|
_fetchCompleter.complete();
|
||||||
}
|
}
|
||||||
|
@ -49,7 +49,7 @@ class View {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class ViewWidget extends StatelessWidget {
|
class ViewWidget extends StatefulWidget {
|
||||||
final List<Entity> badges;
|
final List<Entity> badges;
|
||||||
final Map<String, CardSkeleton> cards;
|
final Map<String, CardSkeleton> cards;
|
||||||
final String displayName;
|
final String displayName;
|
||||||
@ -61,6 +61,28 @@ class ViewWidget extends StatelessWidget {
|
|||||||
this.displayName
|
this.displayName
|
||||||
}) : super(key: key);
|
}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<StatefulWidget> createState() {
|
||||||
|
return ViewWidgetState();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class ViewWidgetState extends State<ViewWidget> {
|
||||||
|
|
||||||
|
StreamSubscription _refreshDataSubscription;
|
||||||
|
Completer _refreshCompleter;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
_refreshDataSubscription = eventBus.on<RefreshDataFinishedEvent>().listen((event) {
|
||||||
|
if ((_refreshCompleter != null) && (!_refreshCompleter.isCompleted)) {
|
||||||
|
_refreshCompleter.complete();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return RefreshIndicator(
|
return RefreshIndicator(
|
||||||
@ -76,18 +98,18 @@ class ViewWidget extends StatelessWidget {
|
|||||||
List<Widget> _buildChildren(BuildContext context) {
|
List<Widget> _buildChildren(BuildContext context) {
|
||||||
List<Widget> result = [];
|
List<Widget> result = [];
|
||||||
|
|
||||||
if (badges.isNotEmpty) {
|
if (widget.badges.isNotEmpty) {
|
||||||
result.insert(0,
|
result.insert(0,
|
||||||
Wrap(
|
Wrap(
|
||||||
alignment: WrapAlignment.center,
|
alignment: WrapAlignment.center,
|
||||||
spacing: 10.0,
|
spacing: 10.0,
|
||||||
runSpacing: 1.0,
|
runSpacing: 1.0,
|
||||||
children: _buildBadges(context, badges),
|
children: _buildBadges(context, widget.badges),
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
cards.forEach((String id, CardSkeleton skeleton){
|
widget.cards.forEach((String id, CardSkeleton skeleton){
|
||||||
result.add(
|
result.add(
|
||||||
HACard(
|
HACard(
|
||||||
entities: skeleton.childEntities,
|
entities: skeleton.childEntities,
|
||||||
@ -108,15 +130,22 @@ class ViewWidget extends StatelessWidget {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Future _refreshData() {
|
Future _refreshData() {
|
||||||
Completer refreshCompleter = Completer();
|
if ((_refreshCompleter != null) && (!_refreshCompleter.isCompleted)) {
|
||||||
|
TheLogger.log("Debug","Previous data refresh is still in progress");
|
||||||
|
} else {
|
||||||
|
_refreshCompleter = Completer();
|
||||||
eventBus.fire(RefreshDataEvent());
|
eventBus.fire(RefreshDataEvent());
|
||||||
eventBus.on<RefreshDataFinishedEvent>().listen((event) {
|
|
||||||
refreshCompleter.complete();
|
|
||||||
});
|
|
||||||
|
|
||||||
return refreshCompleter.future;
|
|
||||||
}
|
}
|
||||||
|
return _refreshCompleter.future;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void dispose() {
|
||||||
|
_refreshDataSubscription.cancel();
|
||||||
|
super.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class CardSkeleton {
|
class CardSkeleton {
|
||||||
|
Reference in New Issue
Block a user