Compare commits
2 Commits
7b1f6860e3
...
9bc0310205
| Author | SHA1 | Date |
|---|---|---|
|
|
9bc0310205 | |
|
|
02fa1f75b3 |
|
|
@ -84,11 +84,9 @@ class _AddFormState extends State<AddForm> {
|
||||||
DropdownButtonFormField<int>(
|
DropdownButtonFormField<int>(
|
||||||
focusNode: _TemplateFocusNode,
|
focusNode: _TemplateFocusNode,
|
||||||
value: _templatChoice,
|
value: _templatChoice,
|
||||||
onChanged: (value) {
|
onChanged: (value) => setState(() {
|
||||||
setState() {
|
_templatChoice = value!;
|
||||||
_templatChoice = (value != null) ? value : -1;
|
}),
|
||||||
}
|
|
||||||
},
|
|
||||||
decoration:
|
decoration:
|
||||||
const InputDecoration(labelText: "Starting Template"),
|
const InputDecoration(labelText: "Starting Template"),
|
||||||
items: generateDropdown(),
|
items: generateDropdown(),
|
||||||
|
|
@ -101,11 +99,16 @@ class _AddFormState extends State<AddForm> {
|
||||||
child: Icon(Icons.save_alt),
|
child: Icon(Icons.save_alt),
|
||||||
onPressed: () async {
|
onPressed: () async {
|
||||||
if (_formKey.currentState!.validate()) {
|
if (_formKey.currentState!.validate()) {
|
||||||
DBHelper.dbHelper.insertList(data.List(
|
int id = await DBHelper.dbHelper.insertList(
|
||||||
_listLabel,
|
data.List(
|
||||||
isTemplate: type.index == 1,
|
_listLabel,
|
||||||
));
|
isTemplate: type.index == 1,
|
||||||
// TODO implement template starting point
|
// TODO Add description to lists
|
||||||
|
),
|
||||||
|
);
|
||||||
|
if (_templatChoice >= 0 && _templatChoice < templates.length) {
|
||||||
|
DBHelper.dbHelper.copyList(templates[_templatChoice].id!, id);
|
||||||
|
}
|
||||||
Navigator.pop(context); // TODO replace route with checklist page
|
Navigator.pop(context); // TODO replace route with checklist page
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -53,6 +53,10 @@ class _MainListPageState extends State<MainListPage> {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<void> _removeList(data.List list) async {
|
||||||
|
DBHelper.dbHelper.deleteList(list);
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
_loadData(data.Page.lists);
|
_loadData(data.Page.lists);
|
||||||
|
|
@ -84,17 +88,66 @@ class _MainListPageState extends State<MainListPage> {
|
||||||
child: ListView.builder(
|
child: ListView.builder(
|
||||||
itemCount: lists.length,
|
itemCount: lists.length,
|
||||||
itemBuilder: (context, index) {
|
itemBuilder: (context, index) {
|
||||||
return Card(
|
return Dismissible(
|
||||||
child: ListTile(
|
direction: DismissDirection.startToEnd,
|
||||||
onTap: () {
|
key: Key(lists[index].id.toString()),
|
||||||
Navigator.push(
|
background: Card(
|
||||||
context,
|
color: Colors.red,
|
||||||
MaterialPageRoute(
|
child: Row(
|
||||||
builder: (context) =>
|
children: const [
|
||||||
CheckList(id: lists[index].id!)));
|
Padding(
|
||||||
},
|
padding: EdgeInsets.all(10),
|
||||||
title: Text(lists[index].name),
|
child: Icon(Icons.delete),
|
||||||
subtitle: Text(lists[index].id.toString()),
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
confirmDismiss: (direction) async {
|
||||||
|
if (direction != DismissDirection.startToEnd) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
showDialog(
|
||||||
|
context: context,
|
||||||
|
builder: (context) {
|
||||||
|
return AlertDialog(
|
||||||
|
title: const Text('Are you sure?'),
|
||||||
|
content: const Text(
|
||||||
|
'You are about to delete this permently'),
|
||||||
|
actions: [
|
||||||
|
TextButton(
|
||||||
|
onPressed: () =>
|
||||||
|
Navigator.pop(context, false),
|
||||||
|
child: const Text('Cancel')),
|
||||||
|
TextButton(
|
||||||
|
onPressed: () =>
|
||||||
|
Navigator.pop(context, true),
|
||||||
|
child: const Text('OK')),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}).then((value) {
|
||||||
|
if (value) {
|
||||||
|
setState(() {
|
||||||
|
_removeList(lists[index]);
|
||||||
|
lists.removeAt(index);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return value;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child: Card(
|
||||||
|
child: ListTile(
|
||||||
|
onTap: () {
|
||||||
|
Navigator.push(
|
||||||
|
context,
|
||||||
|
MaterialPageRoute(
|
||||||
|
builder: (context) =>
|
||||||
|
CheckList(id: lists[index].id!)));
|
||||||
|
},
|
||||||
|
title: Text(lists[index].name),
|
||||||
|
subtitle: Text(lists[index].id.toString()),
|
||||||
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
})),
|
})),
|
||||||
|
|
|
||||||
|
|
@ -77,6 +77,35 @@ class DBHelper {
|
||||||
return db.insert("List", l.toMap());
|
return db.insert("List", l.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<int> deleteList(data.List l) async {
|
||||||
|
Database db = await database;
|
||||||
|
|
||||||
|
db.delete("Item", where: 'list_id = ?', whereArgs: [l.id]);
|
||||||
|
return db.delete("List", where: 'id = ?', whereArgs: [l.id]);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> copyList(int oldID, int newID) async {
|
||||||
|
Database db = await database;
|
||||||
|
print('$newID, $oldID');
|
||||||
|
|
||||||
|
var batch = db.batch();
|
||||||
|
db.execute("""
|
||||||
|
CREATE TEMPORARY TABLE list_copy AS
|
||||||
|
SELECT check_text, status, list_id
|
||||||
|
FROM Item
|
||||||
|
WHERE list_id = ?
|
||||||
|
""", [oldID]);
|
||||||
|
db.update("list_copy", {'list_id': newID});
|
||||||
|
db.rawInsert("""
|
||||||
|
INSERT INTO Item(check_text, status, list_id)
|
||||||
|
SELECT * FROM list_copy
|
||||||
|
""");
|
||||||
|
db.execute("""
|
||||||
|
DROP TABLE list_copy
|
||||||
|
""");
|
||||||
|
batch.commit();
|
||||||
|
}
|
||||||
|
|
||||||
Future<int> insertItem(data.Check item) async {
|
Future<int> insertItem(data.Check item) async {
|
||||||
Database db = await database;
|
Database db = await database;
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue