mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2024-11-14 12:43:16 +00:00
4e0779f5e7
* console_log's copy data is now a valid json object for all log types * graphQLResponse now provides raw response object for copy * console_model now handles pause in itself, so UI pipeline doesn't disturb pause (like when revisiting page / hot reloading) * some minor console_page UI tweaks
52 lines
1.3 KiB
Dart
52 lines
1.3 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:selfprivacy/logic/models/console_log.dart';
|
|
|
|
class ConsoleModel extends ChangeNotifier {
|
|
/// limit for history, so logs won't affect memory and overflow
|
|
static const logBufferLimit = 500;
|
|
|
|
/// differs from log buffer limit so as to not rearrange memory each time
|
|
/// we add incoming log
|
|
static const incomingBufferBreakpoint = 750;
|
|
|
|
final List<ConsoleLog> _logs = [];
|
|
final List<ConsoleLog> _incomingQueue = [];
|
|
|
|
bool _paused = false;
|
|
bool get paused => _paused;
|
|
List<ConsoleLog> get logs => _logs;
|
|
|
|
void log(final ConsoleLog newLog) {
|
|
if (paused) {
|
|
_incomingQueue.add(newLog);
|
|
if (_incomingQueue.length > incomingBufferBreakpoint) {
|
|
logs.removeRange(0, _incomingQueue.length - logBufferLimit);
|
|
}
|
|
} else {
|
|
logs.add(newLog);
|
|
_updateQueue();
|
|
}
|
|
}
|
|
|
|
void play() {
|
|
_logs.addAll(_incomingQueue);
|
|
_paused = false;
|
|
_updateQueue();
|
|
_incomingQueue.clear();
|
|
}
|
|
|
|
void pause() {
|
|
_paused = true;
|
|
notifyListeners();
|
|
}
|
|
|
|
/// drop logs over the limit and
|
|
void _updateQueue() {
|
|
// Make sure we don't have too many
|
|
if (logs.length > logBufferLimit) {
|
|
logs.removeRange(0, logs.length - logBufferLimit);
|
|
}
|
|
notifyListeners();
|
|
}
|
|
}
|