mirror of
https://github.com/Nioux/AideDeJeu.git
synced 2025-10-29 06:26:02 +00:00
Races+SubRaces
This commit is contained in:
parent
2e0dc12243
commit
e845cf7c7f
3 changed files with 105 additions and 14 deletions
|
|
@ -92,3 +92,29 @@ Future<Item> loadChildrenItems(Item item, List<Filter> filters) async {
|
|||
return item;
|
||||
}
|
||||
|
||||
Future<List<RaceItem>> loadRaces() async {
|
||||
final db = await database;
|
||||
var response = await db.query(
|
||||
"Items",
|
||||
where: "ItemType = 'RaceItem'",
|
||||
orderBy: "NormalizedName"
|
||||
);
|
||||
if (response.isNotEmpty) {
|
||||
return itemsFromMapList(response);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
Future<List<SubRaceItem>> loadSubRaces(RaceItem race) async {
|
||||
final db = await database;
|
||||
var response = await db.query(
|
||||
"Items",
|
||||
where: "ItemType = 'SubRaceItem' AND ParentLink = ?",
|
||||
whereArgs: [race.id],
|
||||
orderBy: "NormalizedName"
|
||||
);
|
||||
if (response.isNotEmpty) {
|
||||
return itemsFromMapList(response);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@ import 'package:aidedejeu_flutter/models/filters.dart';
|
|||
class Item {
|
||||
String id;
|
||||
String rootId;
|
||||
String newId;
|
||||
String parentLink;
|
||||
String name;
|
||||
String normalizedName;
|
||||
|
|
@ -20,6 +21,7 @@ class Item {
|
|||
Item(Map<String, dynamic> map) {
|
||||
this.id = map["Id"];
|
||||
this.rootId = map["RootId"];
|
||||
this.newId = map["NewId"];
|
||||
this.name = map["Name"];
|
||||
this.alias = map["AltName"];
|
||||
this.aliasText = map["AltNameText"];
|
||||
|
|
@ -134,6 +136,11 @@ class RaceItem extends Item {
|
|||
|
||||
}
|
||||
|
||||
class SubRaceItem extends RaceItem {
|
||||
SubRaceItem(Map<String, dynamic> map) : super(map);
|
||||
|
||||
}
|
||||
|
||||
class RaceItems extends FilteredItems {
|
||||
RaceItems(Map<String, dynamic> map) : super(map);
|
||||
|
||||
|
|
@ -147,6 +154,7 @@ class RaceItems extends FilteredItems {
|
|||
Item itemFromMap(Map<String, dynamic> map) {
|
||||
switch(map["ItemType"]) {
|
||||
case "RaceItem": return RaceItem(map);
|
||||
case "SubRaceItem": return SubRaceItem(map);
|
||||
case "RaceItems": return RaceItems(map);
|
||||
case "MonsterItem": return MonsterItem(map);
|
||||
case "MonsterItems": return MonsterItems(map);
|
||||
|
|
@ -154,8 +162,8 @@ Item itemFromMap(Map<String, dynamic> map) {
|
|||
return Item(map);
|
||||
}
|
||||
|
||||
List<Item> itemsFromMapList(List<Map<String, dynamic>> mapList) {
|
||||
List<T> itemsFromMapList<T extends Item>(List<Map<String, dynamic>> mapList) {
|
||||
return List.generate(mapList.length, (i) {
|
||||
return itemFromMap(mapList[i]);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,12 +1,6 @@
|
|||
import 'package:aidedejeu_flutter/database.dart';
|
||||
import 'package:aidedejeu_flutter/models/filters.dart';
|
||||
import 'package:aidedejeu_flutter/widgets/filters.dart';
|
||||
import 'package:aidedejeu_flutter/models/items.dart';
|
||||
import 'package:aidedejeu_flutter/widgets/library.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter/services.dart';
|
||||
import 'package:flutter_markdown/flutter_markdown.dart';
|
||||
import 'package:flutter_svg/flutter_svg.dart';
|
||||
|
||||
class PCEditorPage extends StatefulWidget {
|
||||
PCEditorPage({Key key}) : super(key: key);
|
||||
|
|
@ -25,7 +19,74 @@ class PCEditorPage extends StatefulWidget {
|
|||
}
|
||||
|
||||
class _PCEditorPageState extends State<PCEditorPage> {
|
||||
RaceItem race;
|
||||
RaceItem _race;
|
||||
SubRaceItem _subRace;
|
||||
List<RaceItem> _races;
|
||||
List<SubRaceItem> _subRaces;
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
// TODO: implement initState
|
||||
super.initState();
|
||||
loadRaces().then((value) => setState(() {
|
||||
_races = value.map((e) => e as RaceItem).toList();
|
||||
}));
|
||||
}
|
||||
|
||||
void _setRace(RaceItem race) {
|
||||
setState(() {
|
||||
this._race = race;
|
||||
this._subRace = null;
|
||||
this._subRaces = null;
|
||||
});
|
||||
loadSubRaces(race).then((value) => setState(() {
|
||||
_subRaces = value.map((e) => e as SubRaceItem).toList();
|
||||
}));
|
||||
}
|
||||
|
||||
void _setSubRace(SubRaceItem subRace) {
|
||||
setState(() {
|
||||
this._subRace = subRace;
|
||||
});
|
||||
}
|
||||
|
||||
Widget _loadRacesWidget() {
|
||||
return DropdownButton(
|
||||
hint: Text("Race"),
|
||||
value: _races != null ? _race : "",
|
||||
onChanged: (value) {
|
||||
_setRace(value);
|
||||
},
|
||||
items: _races != null
|
||||
? _races
|
||||
.map((e) => DropdownMenuItem(
|
||||
value: e,
|
||||
child: Text(e.name),
|
||||
))
|
||||
.toList()
|
||||
: null,
|
||||
);
|
||||
}
|
||||
|
||||
Widget _loadSubRacesWidget() {
|
||||
return _subRaces != null
|
||||
? DropdownButton(
|
||||
hint: Text("Sous-Race"),
|
||||
value: _subRaces != null ? _subRace : "",
|
||||
onChanged: (value) {
|
||||
_setSubRace(value);
|
||||
},
|
||||
items: _subRaces != null
|
||||
? _subRaces
|
||||
.map((e) => DropdownMenuItem(
|
||||
value: e,
|
||||
child: Text(e.name),
|
||||
))
|
||||
.toList()
|
||||
: null,
|
||||
)
|
||||
: SizedBox.shrink();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
|
|
@ -34,11 +95,7 @@ class _PCEditorPageState extends State<PCEditorPage> {
|
|||
title: Text("Personnage"),
|
||||
),
|
||||
body: Column(
|
||||
children: <Widget>[
|
||||
race != null
|
||||
? Text(race.name)
|
||||
: DropdownButton(hint: Text("Race"), value: "")
|
||||
],
|
||||
children: <Widget>[_loadRacesWidget(), _loadSubRacesWidget()],
|
||||
),
|
||||
);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue