mirror of https://github.com/flutter/samples.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
78 lines
1.7 KiB
78 lines
1.7 KiB
// Copyright 2021 The Flutter team. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import 'package:hive/hive.dart';
|
|
|
|
class HiveService {
|
|
static Future<bool> addBox<T>(T item, String boxName) async {
|
|
final openBox = await Hive.openLazyBox<T>(
|
|
boxName,
|
|
);
|
|
|
|
List<T> existingProducts = await getBoxes(boxName);
|
|
|
|
if (!existingProducts.contains(item)) {
|
|
openBox.add(item);
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
static Future addBoxes<T>(List<T> items, String boxName) async {
|
|
final openBox = await Hive.openLazyBox<T>(
|
|
boxName,
|
|
);
|
|
|
|
List<T> existingProducts = await getBoxes(boxName);
|
|
|
|
for (var item in items) {
|
|
if (!existingProducts.contains(item)) {
|
|
openBox.add(item);
|
|
}
|
|
}
|
|
}
|
|
|
|
static Future deleteBox<T>(T item, String boxName) async {
|
|
final openBox = await Hive.openLazyBox<T>(
|
|
boxName,
|
|
);
|
|
|
|
List<T> boxes = await getBoxes(boxName);
|
|
|
|
for (var box in boxes) {
|
|
if (box == item) {
|
|
openBox.deleteAt(boxes.indexOf(item));
|
|
}
|
|
}
|
|
}
|
|
|
|
static Future updateBox<T>(T item, T newItem, String boxName) async {
|
|
final openBox = await Hive.openLazyBox<T>(
|
|
boxName,
|
|
);
|
|
|
|
List<T> boxes = await getBoxes(boxName);
|
|
|
|
for (var box in boxes) {
|
|
if (box == item) {
|
|
openBox.putAt(boxes.indexOf(item), newItem);
|
|
}
|
|
}
|
|
}
|
|
|
|
static Future<List<T>> getBoxes<T>(String boxName, [String? query]) async {
|
|
List<T> boxList = [];
|
|
|
|
final openBox = await Hive.openLazyBox<T>(boxName);
|
|
|
|
int length = openBox.length;
|
|
|
|
for (int i = 0; i < length; i++) {
|
|
boxList.add(await openBox.getAt(i) as T);
|
|
}
|
|
|
|
return boxList;
|
|
}
|
|
}
|