// SPDX-FileCopyrightText: Copyright 2023 Open Mobile Platform LLC // SPDX-License-Identifier: BSD-3-Clause import 'package:flutter/widgets.dart'; import 'package:path/path.dart' as p; import 'package:scoped_model/scoped_model.dart'; import 'package:sqflite/sqflite.dart'; /// Model for [SqflitePage] class SqfliteModel extends Model { /// Get [ScopedModel] static SqfliteModel of(BuildContext context) => ScopedModel.of(context); /// Database Database? _db; /// Error String? _error; /// Public error String? get error => _error; /// Public is error bool get isError => _error != null; /// Public data List get data => _data ?? []; /// Private data List? _data; /// Init database Future init() async { try { // Get a location using getDatabasesPath var databasesPath = await getDatabasesPath(); String path = p.join(databasesPath, 'demo.db'); // Delete the database await deleteDatabase(path); // open the database _db = await openDatabase( path, version: 1, onCreate: (Database db, int version) async { // When creating the db, create the table await db.execute('''CREATE TABLE Test ( name TEXT, value INTEGER, num REAL )'''); }, ); } catch (e) { _error = e.toString(); } notifyListeners(); } /// Close database Future close() async { await _db?.close(); } /// Remove all rows Future clear() async { try { // Query await _db?.rawDelete('DELETE FROM Test'); // Update data _data = await _allSelect(); } catch (e) { _error = e.toString(); } notifyListeners(); } /// Insert data Future insert( String name, int value, double num, ) async { try { // Query await _db?.transaction((txn) async { await txn.rawInsert( 'INSERT INTO Test(name, value, num) VALUES(?, ?, ?)', [name, value, num]); }); // Update data _data = await _allSelect(); } catch (e) { _error = e.toString(); } notifyListeners(); } /// Update data by ID Future update( int id, String name, int value, double num, ) async { int? count = 0; try { // Query count = await _db?.rawUpdate( 'UPDATE Test SET name = ?, value = ?, num = ? WHERE rowid = ?', [name, value, num, id]); // Update data _data = await _allSelect(); // Check state } catch (e) { _error = e.toString(); } notifyListeners(); return count == 1; } /// Delete data by ID Future delete( int id, ) async { int? count = 0; try { // Query count = await _db?.rawDelete('DELETE FROM Test WHERE rowid = ?', [id]); // Update data _data = await _allSelect(); } catch (e) { _error = e.toString(); } notifyListeners(); return count == 1; } /// Select all rows Future?> _allSelect() async { try { return await _db?.rawQuery('SELECT rowid as id, * FROM Test'); } catch (e) { _error = e.toString(); } notifyListeners(); return null; } }