mirror of
https://github.com/immich-app/immich.git
synced 2026-04-16 07:31:55 -04:00
* refactor: yank old timeline # Conflicts: # mobile/lib/presentation/pages/editing/drift_edit.page.dart # mobile/lib/providers/websocket.provider.dart # mobile/lib/routing/router.dart * more cleanup * remove native code * chore: bump sqlite-data version * remove old background tasks from BGTaskSchedulerPermittedIdentifiers * rebase --------- Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
45 lines
1.2 KiB
Dart
45 lines
1.2 KiB
Dart
import 'dart:typed_data';
|
|
|
|
import 'package:collection/collection.dart';
|
|
|
|
extension ListExtension<E> on List<E> {
|
|
List<E> uniqueConsecutive({int Function(E a, E b)? compare, void Function(E a, E b)? onDuplicate}) {
|
|
compare ??= (E a, E b) => a == b ? 0 : 1;
|
|
int i = 1, j = 1;
|
|
for (; i < length; i++) {
|
|
if (compare(this[i - 1], this[i]) != 0) {
|
|
if (i != j) {
|
|
this[j] = this[i];
|
|
}
|
|
j++;
|
|
} else if (onDuplicate != null) {
|
|
onDuplicate(this[i - 1], this[i]);
|
|
}
|
|
}
|
|
length = length == 0 ? 0 : j;
|
|
return this;
|
|
}
|
|
|
|
ListSlice<E> nestedSlice(int start, int end) {
|
|
if (this is ListSlice) {
|
|
final ListSlice<E> self = this as ListSlice<E>;
|
|
return ListSlice<E>(self.source, self.start + start, self.start + end);
|
|
}
|
|
return ListSlice<E>(this, start, end);
|
|
}
|
|
}
|
|
|
|
extension IntListExtension on Iterable<int> {
|
|
Int64List toInt64List() {
|
|
final list = Int64List(length);
|
|
list.setAll(0, this);
|
|
return list;
|
|
}
|
|
}
|
|
|
|
extension SortedByProperty<T> on Iterable<T> {
|
|
Iterable<T> sortedByField(Comparable Function(T e) key) {
|
|
return sorted((a, b) => key(a).compareTo(key(b)));
|
|
}
|
|
}
|