Reorganizing & Renaming
This commit is contained in:
parent
102f8de792
commit
263faa1756
34 changed files with 4537 additions and 1311 deletions
2
.env
2
.env
|
@ -1,2 +1,2 @@
|
||||||
BASEROW_TOKEN="TFxO7vzBLVRCu9I3VMoHmTuCvSu8aCDi"
|
BASEROW_TOKEN="TFxO7vzBLVRCu9I3VMoHmTuCvSu8aCDi"
|
||||||
BASEROW_IDS='{"massnahmen": 328253, "massnahmenkombination": 328217, "organismen": 328255, "foerderprogramme": 328256, "factsheet": 328273, "standortansprueche": 328188, "referenzumsetzung": 328465, "betriebsverzeichnis": 328472, "erfahrungsbericht": 330802, "genehmigungspflicht": 330806, "dienstleister": 330824, "ansprechperson": 330832, "material": 330836, "quellen": 334231, "baumarten": 342622, "aenderungfactsheet": 330946}'
|
BASEROW_IDS='{"measure": 328253, "measure_combination": 328217, "organism": 328255, "funding_program": 328256, "factsheet": 328273, "standortansprueche": 328188, "referenzumsetzung": 328465, "betriebsverzeichnis": 328472, "erfahrungsbericht": 330802, "genehmigungspflicht": 330806, "dienstleister": 330824, "ansprechperson": 330832, "material": 330836, "quellen": 334231, "baumarten": 342622, "aenderungfactsheet": 330946}'
|
|
@ -1,5 +1,5 @@
|
||||||
import 'package:ambito/src/domain/entity/baumarten/baumarten.dart';
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
import 'package:ambito/src/domain/entity/massnahme/massnahme.dart';
|
import 'package:ambito/src/domain/entity/funding_program/funding_program.dart';
|
||||||
import 'package:ambito/src/packages/ambito_api/base.dart';
|
import 'package:ambito/src/packages/ambito_api/base.dart';
|
||||||
import 'package:ambito/src/pages/loading/loading_page.dart';
|
import 'package:ambito/src/pages/loading/loading_page.dart';
|
||||||
import 'package:flutter/foundation.dart';
|
import 'package:flutter/foundation.dart';
|
||||||
|
@ -27,7 +27,13 @@ void main() async {
|
||||||
const dir = Isar.sqliteInMemory;
|
const dir = Isar.sqliteInMemory;
|
||||||
const engine = kIsWeb ? IsarEngine.sqlite : IsarEngine.isar;
|
const engine = kIsWeb ? IsarEngine.sqlite : IsarEngine.isar;
|
||||||
isar = Isar.open(
|
isar = Isar.open(
|
||||||
schemas: [BaumartenSchema, MassnahmeSchema],
|
schemas: [
|
||||||
|
BaumartenSchema,
|
||||||
|
FundingProgramSchema,
|
||||||
|
MeasureSchema,
|
||||||
|
MeasureCombinationSchema,
|
||||||
|
OrganismSchema
|
||||||
|
],
|
||||||
directory: dir,
|
directory: dir,
|
||||||
engine: engine,
|
engine: engine,
|
||||||
inspector: true,
|
inspector: true,
|
||||||
|
@ -35,7 +41,10 @@ void main() async {
|
||||||
|
|
||||||
await Future.wait([
|
await Future.wait([
|
||||||
BaseApi().getContent('baumarten'),
|
BaseApi().getContent('baumarten'),
|
||||||
BaseApi().getContent('massnahmen'),
|
BaseApi().getContent('measure'),
|
||||||
|
BaseApi().getContent('measure_combination'),
|
||||||
|
BaseApi().getContent('organism'),
|
||||||
|
BaseApi().getContent('funding_program'),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
runApp(const Ambito());
|
runApp(const Ambito());
|
||||||
|
|
|
@ -1,5 +1,15 @@
|
||||||
|
import 'package:isar/isar.dart';
|
||||||
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
||||||
class BaseEntity {}
|
class BaseEntity {}
|
||||||
|
|
||||||
mixin EntityWithId {
|
mixin EntityWithId {
|
||||||
late int id;
|
late int id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mixin EntityWithIdAndName {
|
||||||
|
late int id;
|
||||||
|
@JsonKey(name: 'Name')
|
||||||
|
@Index(unique: true, hash: true)
|
||||||
|
String? name;
|
||||||
|
}
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
import 'package:ambito/src/domain/entity/id_value/id_value.dart';
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
import 'package:ambito/src/domain/entity/id_value_color/id_value_color.dart';
|
|
||||||
import 'package:isar/isar.dart';
|
import 'package:isar/isar.dart';
|
||||||
import 'package:json_annotation/json_annotation.dart';
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
||||||
import '../base_entity.dart';
|
|
||||||
|
|
||||||
part 'baumarten.g.dart';
|
part 'baumarten.g.dart';
|
||||||
|
|
||||||
@JsonSerializable(explicitToJson: true)
|
@JsonSerializable(explicitToJson: true)
|
||||||
|
|
|
@ -2,10 +2,13 @@ library ambito_entities;
|
||||||
|
|
||||||
export 'base_entity.dart';
|
export 'base_entity.dart';
|
||||||
export 'baumarten/baumarten.dart';
|
export 'baumarten/baumarten.dart';
|
||||||
export 'file/file_part.dart';
|
export 'general/file/file_part.dart';
|
||||||
export 'file/thumbnail.dart';
|
export 'general/file/thumbnail.dart';
|
||||||
export 'file/thumbnails.dart';
|
export 'general/file/thumbnails.dart';
|
||||||
export 'id_value/id_value.dart';
|
export 'general/id_value/id_value.dart';
|
||||||
export 'id_value_color/id_value_color.dart';
|
export 'general/id_value_color/id_value_color.dart';
|
||||||
export 'id_value_mix/id_value_mix.dart';
|
export 'general/id_value_mix/id_value_mix.dart';
|
||||||
export 'massnahme/massnahme.dart';
|
export 'general/month/month.dart';
|
||||||
|
export 'measure/measure.dart';
|
||||||
|
export 'measure_combination/measure_combination.dart';
|
||||||
|
export 'organism/organism.dart';
|
||||||
|
|
29
lib/src/domain/entity/funding_program/funding_program.dart
Normal file
29
lib/src/domain/entity/funding_program/funding_program.dart
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
|
import 'package:isar/isar.dart';
|
||||||
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
||||||
|
part 'funding_program.g.dart';
|
||||||
|
|
||||||
|
@JsonSerializable(explicitToJson: true)
|
||||||
|
@collection
|
||||||
|
class FundingProgram extends BaseEntity with EntityWithIdAndName {
|
||||||
|
FundingProgram();
|
||||||
|
|
||||||
|
@JsonKey(name: 'Maßnahmen_Main')
|
||||||
|
List<IdValue>? measures;
|
||||||
|
@JsonKey(name: 'Höhe der Förderung')
|
||||||
|
String? fundingAmount;
|
||||||
|
@JsonKey(name: 'Berechnungsgrundlage')
|
||||||
|
IdValueColor? calculationBase;
|
||||||
|
@JsonKey(name: 'Förderfrequenz')
|
||||||
|
IdValueColor? fundingFrequency;
|
||||||
|
@JsonKey(name: 'De-Minimis-Pflichtig')
|
||||||
|
bool? deminimis;
|
||||||
|
@JsonKey(name: 'Region/Bundesland')
|
||||||
|
List<IdValueColor>? regions;
|
||||||
|
|
||||||
|
factory FundingProgram.fromJson(Map<String, dynamic> json) =>
|
||||||
|
_$FundingProgramFromJson(json);
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() => _$FundingProgramToJson(this);
|
||||||
|
}
|
1312
lib/src/domain/entity/funding_program/funding_program.g.dart
Normal file
1312
lib/src/domain/entity/funding_program/funding_program.g.dart
Normal file
File diff suppressed because it is too large
Load diff
|
@ -1,4 +1,4 @@
|
||||||
import 'package:ambito/src/domain/entity/file/thumbnails.dart';
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
import 'package:isar/isar.dart';
|
import 'package:isar/isar.dart';
|
||||||
import 'package:json_annotation/json_annotation.dart';
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import 'package:ambito/src/domain/entity/file/thumbnail.dart';
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
import 'package:isar/isar.dart';
|
import 'package:isar/isar.dart';
|
||||||
import 'package:json_annotation/json_annotation.dart';
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import 'package:ambito/src/domain/entity/id_value_color/id_value_color.dart';
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
import 'package:isar/isar.dart';
|
import 'package:isar/isar.dart';
|
||||||
import 'package:json_annotation/json_annotation.dart';
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
|
@ -1,22 +1,15 @@
|
||||||
import 'package:ambito/src/domain/entity/base_entity.dart';
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
import 'package:ambito/src/domain/entity/id_value/id_value.dart';
|
|
||||||
import 'package:ambito/src/domain/entity/id_value_color/id_value_color.dart';
|
|
||||||
import 'package:cached_network_image/cached_network_image.dart';
|
import 'package:cached_network_image/cached_network_image.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:isar/isar.dart';
|
import 'package:isar/isar.dart';
|
||||||
import 'package:json_annotation/json_annotation.dart';
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
||||||
import '../file/file_part.dart';
|
part 'measure.g.dart';
|
||||||
import '../file/thumbnail.dart';
|
|
||||||
import '../file/thumbnails.dart';
|
|
||||||
import '../id_value_mix/id_value_mix.dart';
|
|
||||||
|
|
||||||
part 'massnahme.g.dart';
|
|
||||||
|
|
||||||
@JsonSerializable(explicitToJson: true)
|
@JsonSerializable(explicitToJson: true)
|
||||||
@collection
|
@collection
|
||||||
class Massnahme extends BaseEntity with EntityWithId {
|
class Measure extends BaseEntity with EntityWithId {
|
||||||
Massnahme();
|
Measure();
|
||||||
|
|
||||||
@JsonKey(name: 'order')
|
@JsonKey(name: 'order')
|
||||||
String? orderString;
|
String? orderString;
|
||||||
|
@ -146,20 +139,19 @@ class Massnahme extends BaseEntity with EntityWithId {
|
||||||
@JsonKey(name: "12 Quellen - Verwendet in Maßnahmendatenblatt")
|
@JsonKey(name: "12 Quellen - Verwendet in Maßnahmendatenblatt")
|
||||||
List<IdValue>? sourcesUsedInDataSheet;
|
List<IdValue>? sourcesUsedInDataSheet;
|
||||||
|
|
||||||
factory Massnahme.fromJson(Map<String, dynamic> json) =>
|
factory Measure.fromJson(Map<String, dynamic> json) =>
|
||||||
_$MassnahmeFromJson(json);
|
_$MeasureFromJson(json);
|
||||||
|
|
||||||
Map<String, dynamic> toJson() => _$MassnahmeToJson(this);
|
Map<String, dynamic> toJson() => _$MeasureToJson(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
extension MassnahmenExtension on Massnahme {
|
extension MeasureExtension on Measure {
|
||||||
|
|
||||||
CachedNetworkImage? getThumbnail() {
|
CachedNetworkImage? getThumbnail() {
|
||||||
CachedNetworkImage? image;
|
CachedNetworkImage? image;
|
||||||
if (files != null && files!.isNotEmpty) {
|
if (files != null && files!.isNotEmpty) {
|
||||||
if (files![0].thumbnails?.cardCover?.url != null) {
|
if (files![0].thumbnails?.cardCover?.url != null) {
|
||||||
image = CachedNetworkImage(
|
image = CachedNetworkImage(
|
||||||
imageUrl:files![0].thumbnails!.cardCover!.url!,
|
imageUrl: files![0].thumbnails!.cardCover!.url!,
|
||||||
placeholder: (context, url) => const CircularProgressIndicator(),
|
placeholder: (context, url) => const CircularProgressIndicator(),
|
||||||
errorWidget: (context, url, error) => const Icon(Icons.error),
|
errorWidget: (context, url, error) => const Icon(Icons.error),
|
||||||
);
|
);
|
||||||
|
@ -167,5 +159,4 @@ extension MassnahmenExtension on Massnahme {
|
||||||
}
|
}
|
||||||
return image;
|
return image;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,24 @@
|
||||||
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
|
import 'package:isar/isar.dart';
|
||||||
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
||||||
|
part 'measure_combination.g.dart';
|
||||||
|
|
||||||
|
@collection
|
||||||
|
@JsonSerializable(explicitToJson: true)
|
||||||
|
class MeasureCombination extends BaseEntity with EntityWithIdAndName {
|
||||||
|
MeasureCombination();
|
||||||
|
|
||||||
|
@Index()
|
||||||
|
@JsonKey(name: 'Aktiv')
|
||||||
|
bool? active;
|
||||||
|
@JsonKey(name: 'Maßnahmenkombination')
|
||||||
|
List<IdValue>? combinations;
|
||||||
|
@JsonKey(name: 'Anmerkungen')
|
||||||
|
String? notices;
|
||||||
|
|
||||||
|
factory MeasureCombination.fromJson(Map<String, dynamic> json) =>
|
||||||
|
_$MeasureCombinationFromJson(json);
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() => _$MeasureCombinationToJson(this);
|
||||||
|
}
|
1169
lib/src/domain/entity/measure_combination/measure_combination.g.dart
Normal file
1169
lib/src/domain/entity/measure_combination/measure_combination.g.dart
Normal file
File diff suppressed because it is too large
Load diff
19
lib/src/domain/entity/organism/organism.dart
Normal file
19
lib/src/domain/entity/organism/organism.dart
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
|
import 'package:isar/isar.dart';
|
||||||
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
||||||
|
part 'organism.g.dart';
|
||||||
|
|
||||||
|
@JsonSerializable(explicitToJson: true)
|
||||||
|
@collection
|
||||||
|
class Organism extends BaseEntity with EntityWithIdAndName {
|
||||||
|
Organism();
|
||||||
|
|
||||||
|
@JsonKey(name: 'Maßnahmen')
|
||||||
|
List<IdValue>? measures;
|
||||||
|
|
||||||
|
factory Organism.fromJson(Map<String, dynamic> json) =>
|
||||||
|
_$OrganismFromJson(json);
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() => _$OrganismToJson(this);
|
||||||
|
}
|
719
lib/src/domain/entity/organism/organism.g.dart
Normal file
719
lib/src/domain/entity/organism/organism.g.dart
Normal file
|
@ -0,0 +1,719 @@
|
||||||
|
// GENERATED CODE - DO NOT MODIFY BY HAND
|
||||||
|
|
||||||
|
part of 'organism.dart';
|
||||||
|
|
||||||
|
// **************************************************************************
|
||||||
|
// _IsarCollectionGenerator
|
||||||
|
// **************************************************************************
|
||||||
|
|
||||||
|
// coverage:ignore-file
|
||||||
|
// ignore_for_file: duplicate_ignore, invalid_use_of_protected_member, lines_longer_than_80_chars, constant_identifier_names, avoid_js_rounded_ints, no_leading_underscores_for_local_identifiers, require_trailing_commas, unnecessary_parenthesis, unnecessary_raw_strings, unnecessary_null_in_if_null_operators, library_private_types_in_public_api, prefer_const_constructors
|
||||||
|
// ignore_for_file: type=lint
|
||||||
|
|
||||||
|
extension GetOrganismCollection on Isar {
|
||||||
|
IsarCollection<int, Organism> get organisms => this.collection();
|
||||||
|
}
|
||||||
|
|
||||||
|
const OrganismSchema = IsarGeneratedSchema(
|
||||||
|
schema: IsarSchema(
|
||||||
|
name: 'Organism',
|
||||||
|
idName: 'id',
|
||||||
|
embedded: false,
|
||||||
|
properties: [
|
||||||
|
IsarPropertySchema(
|
||||||
|
name: 'measures',
|
||||||
|
type: IsarType.objectList,
|
||||||
|
target: 'IdValue',
|
||||||
|
),
|
||||||
|
IsarPropertySchema(
|
||||||
|
name: 'name',
|
||||||
|
type: IsarType.string,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
indexes: [
|
||||||
|
IsarIndexSchema(
|
||||||
|
name: 'name',
|
||||||
|
properties: [
|
||||||
|
"name",
|
||||||
|
],
|
||||||
|
unique: true,
|
||||||
|
hash: true,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
converter: IsarObjectConverter<int, Organism>(
|
||||||
|
serialize: serializeOrganism,
|
||||||
|
deserialize: deserializeOrganism,
|
||||||
|
deserializeProperty: deserializeOrganismProp,
|
||||||
|
),
|
||||||
|
embeddedSchemas: [IdValueSchema],
|
||||||
|
);
|
||||||
|
|
||||||
|
@isarProtected
|
||||||
|
int serializeOrganism(IsarWriter writer, Organism object) {
|
||||||
|
{
|
||||||
|
final list = object.measures;
|
||||||
|
if (list == null) {
|
||||||
|
IsarCore.writeNull(writer, 1);
|
||||||
|
} else {
|
||||||
|
final listWriter = IsarCore.beginList(writer, 1, list.length);
|
||||||
|
for (var i = 0; i < list.length; i++) {
|
||||||
|
{
|
||||||
|
final value = list[i];
|
||||||
|
final objectWriter = IsarCore.beginObject(listWriter, i);
|
||||||
|
serializeIdValue(objectWriter, value);
|
||||||
|
IsarCore.endObject(listWriter, objectWriter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
IsarCore.endList(writer, listWriter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
{
|
||||||
|
final value = object.name;
|
||||||
|
if (value == null) {
|
||||||
|
IsarCore.writeNull(writer, 2);
|
||||||
|
} else {
|
||||||
|
IsarCore.writeString(writer, 2, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return object.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
@isarProtected
|
||||||
|
Organism deserializeOrganism(IsarReader reader) {
|
||||||
|
final object = Organism();
|
||||||
|
{
|
||||||
|
final length = IsarCore.readList(reader, 1, IsarCore.readerPtrPtr);
|
||||||
|
{
|
||||||
|
final reader = IsarCore.readerPtr;
|
||||||
|
if (reader.isNull) {
|
||||||
|
object.measures = null;
|
||||||
|
} else {
|
||||||
|
final list = List<IdValue>.filled(length, IdValue(), growable: true);
|
||||||
|
for (var i = 0; i < length; i++) {
|
||||||
|
{
|
||||||
|
final objectReader = IsarCore.readObject(reader, i);
|
||||||
|
if (objectReader.isNull) {
|
||||||
|
list[i] = IdValue();
|
||||||
|
} else {
|
||||||
|
final embedded = deserializeIdValue(objectReader);
|
||||||
|
IsarCore.freeReader(objectReader);
|
||||||
|
list[i] = embedded;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
IsarCore.freeReader(reader);
|
||||||
|
object.measures = list;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
object.id = IsarCore.readId(reader);
|
||||||
|
object.name = IsarCore.readString(reader, 2);
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
|
||||||
|
@isarProtected
|
||||||
|
dynamic deserializeOrganismProp(IsarReader reader, int property) {
|
||||||
|
switch (property) {
|
||||||
|
case 1:
|
||||||
|
{
|
||||||
|
final length = IsarCore.readList(reader, 1, IsarCore.readerPtrPtr);
|
||||||
|
{
|
||||||
|
final reader = IsarCore.readerPtr;
|
||||||
|
if (reader.isNull) {
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
final list =
|
||||||
|
List<IdValue>.filled(length, IdValue(), growable: true);
|
||||||
|
for (var i = 0; i < length; i++) {
|
||||||
|
{
|
||||||
|
final objectReader = IsarCore.readObject(reader, i);
|
||||||
|
if (objectReader.isNull) {
|
||||||
|
list[i] = IdValue();
|
||||||
|
} else {
|
||||||
|
final embedded = deserializeIdValue(objectReader);
|
||||||
|
IsarCore.freeReader(objectReader);
|
||||||
|
list[i] = embedded;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
IsarCore.freeReader(reader);
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case 0:
|
||||||
|
return IsarCore.readId(reader);
|
||||||
|
case 2:
|
||||||
|
return IsarCore.readString(reader, 2);
|
||||||
|
default:
|
||||||
|
throw ArgumentError('Unknown property: $property');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sealed class _OrganismUpdate {
|
||||||
|
bool call({
|
||||||
|
required int id,
|
||||||
|
String? name,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
class _OrganismUpdateImpl implements _OrganismUpdate {
|
||||||
|
const _OrganismUpdateImpl(this.collection);
|
||||||
|
|
||||||
|
final IsarCollection<int, Organism> collection;
|
||||||
|
|
||||||
|
@override
|
||||||
|
bool call({
|
||||||
|
required int id,
|
||||||
|
Object? name = ignore,
|
||||||
|
}) {
|
||||||
|
return collection.updateProperties([
|
||||||
|
id
|
||||||
|
], {
|
||||||
|
if (name != ignore) 2: name as String?,
|
||||||
|
}) >
|
||||||
|
0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sealed class _OrganismUpdateAll {
|
||||||
|
int call({
|
||||||
|
required List<int> id,
|
||||||
|
String? name,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
class _OrganismUpdateAllImpl implements _OrganismUpdateAll {
|
||||||
|
const _OrganismUpdateAllImpl(this.collection);
|
||||||
|
|
||||||
|
final IsarCollection<int, Organism> collection;
|
||||||
|
|
||||||
|
@override
|
||||||
|
int call({
|
||||||
|
required List<int> id,
|
||||||
|
Object? name = ignore,
|
||||||
|
}) {
|
||||||
|
return collection.updateProperties(id, {
|
||||||
|
if (name != ignore) 2: name as String?,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismUpdate on IsarCollection<int, Organism> {
|
||||||
|
_OrganismUpdate get update => _OrganismUpdateImpl(this);
|
||||||
|
|
||||||
|
_OrganismUpdateAll get updateAll => _OrganismUpdateAllImpl(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
sealed class _OrganismQueryUpdate {
|
||||||
|
int call({
|
||||||
|
String? name,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
class _OrganismQueryUpdateImpl implements _OrganismQueryUpdate {
|
||||||
|
const _OrganismQueryUpdateImpl(this.query, {this.limit});
|
||||||
|
|
||||||
|
final IsarQuery<Organism> query;
|
||||||
|
final int? limit;
|
||||||
|
|
||||||
|
@override
|
||||||
|
int call({
|
||||||
|
Object? name = ignore,
|
||||||
|
}) {
|
||||||
|
return query.updateProperties(limit: limit, {
|
||||||
|
if (name != ignore) 2: name as String?,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismQueryUpdate on IsarQuery<Organism> {
|
||||||
|
_OrganismQueryUpdate get updateFirst =>
|
||||||
|
_OrganismQueryUpdateImpl(this, limit: 1);
|
||||||
|
|
||||||
|
_OrganismQueryUpdate get updateAll => _OrganismQueryUpdateImpl(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
class _OrganismQueryBuilderUpdateImpl implements _OrganismQueryUpdate {
|
||||||
|
const _OrganismQueryBuilderUpdateImpl(this.query, {this.limit});
|
||||||
|
|
||||||
|
final QueryBuilder<Organism, Organism, QOperations> query;
|
||||||
|
final int? limit;
|
||||||
|
|
||||||
|
@override
|
||||||
|
int call({
|
||||||
|
Object? name = ignore,
|
||||||
|
}) {
|
||||||
|
final q = query.build();
|
||||||
|
try {
|
||||||
|
return q.updateProperties(limit: limit, {
|
||||||
|
if (name != ignore) 2: name as String?,
|
||||||
|
});
|
||||||
|
} finally {
|
||||||
|
q.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismQueryBuilderUpdate
|
||||||
|
on QueryBuilder<Organism, Organism, QOperations> {
|
||||||
|
_OrganismQueryUpdate get updateFirst =>
|
||||||
|
_OrganismQueryBuilderUpdateImpl(this, limit: 1);
|
||||||
|
|
||||||
|
_OrganismQueryUpdate get updateAll => _OrganismQueryBuilderUpdateImpl(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismQueryFilter
|
||||||
|
on QueryBuilder<Organism, Organism, QFilterCondition> {
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> measuresIsNull() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(const IsNullCondition(property: 1));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> measuresIsNotNull() {
|
||||||
|
return QueryBuilder.apply(not(), (query) {
|
||||||
|
return query.addFilterCondition(const IsNullCondition(property: 1));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> measuresIsEmpty() {
|
||||||
|
return not().group(
|
||||||
|
(q) => q.measuresIsNull().or().measuresIsNotEmpty(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> measuresIsNotEmpty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
const GreaterOrEqualCondition(property: 1, value: null),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> idEqualTo(
|
||||||
|
int value,
|
||||||
|
) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
EqualCondition(
|
||||||
|
property: 0,
|
||||||
|
value: value,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> idGreaterThan(
|
||||||
|
int value,
|
||||||
|
) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
GreaterCondition(
|
||||||
|
property: 0,
|
||||||
|
value: value,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition>
|
||||||
|
idGreaterThanOrEqualTo(
|
||||||
|
int value,
|
||||||
|
) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
GreaterOrEqualCondition(
|
||||||
|
property: 0,
|
||||||
|
value: value,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> idLessThan(
|
||||||
|
int value,
|
||||||
|
) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
LessCondition(
|
||||||
|
property: 0,
|
||||||
|
value: value,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> idLessThanOrEqualTo(
|
||||||
|
int value,
|
||||||
|
) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
LessOrEqualCondition(
|
||||||
|
property: 0,
|
||||||
|
value: value,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> idBetween(
|
||||||
|
int lower,
|
||||||
|
int upper,
|
||||||
|
) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
BetweenCondition(
|
||||||
|
property: 0,
|
||||||
|
lower: lower,
|
||||||
|
upper: upper,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameIsNull() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(const IsNullCondition(property: 2));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameIsNotNull() {
|
||||||
|
return QueryBuilder.apply(not(), (query) {
|
||||||
|
return query.addFilterCondition(const IsNullCondition(property: 2));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameEqualTo(
|
||||||
|
String? value, {
|
||||||
|
bool caseSensitive = true,
|
||||||
|
}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
EqualCondition(
|
||||||
|
property: 2,
|
||||||
|
value: value,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameGreaterThan(
|
||||||
|
String? value, {
|
||||||
|
bool caseSensitive = true,
|
||||||
|
}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
GreaterCondition(
|
||||||
|
property: 2,
|
||||||
|
value: value,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition>
|
||||||
|
nameGreaterThanOrEqualTo(
|
||||||
|
String? value, {
|
||||||
|
bool caseSensitive = true,
|
||||||
|
}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
GreaterOrEqualCondition(
|
||||||
|
property: 2,
|
||||||
|
value: value,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameLessThan(
|
||||||
|
String? value, {
|
||||||
|
bool caseSensitive = true,
|
||||||
|
}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
LessCondition(
|
||||||
|
property: 2,
|
||||||
|
value: value,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameLessThanOrEqualTo(
|
||||||
|
String? value, {
|
||||||
|
bool caseSensitive = true,
|
||||||
|
}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
LessOrEqualCondition(
|
||||||
|
property: 2,
|
||||||
|
value: value,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameBetween(
|
||||||
|
String? lower,
|
||||||
|
String? upper, {
|
||||||
|
bool caseSensitive = true,
|
||||||
|
}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
BetweenCondition(
|
||||||
|
property: 2,
|
||||||
|
lower: lower,
|
||||||
|
upper: upper,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameStartsWith(
|
||||||
|
String value, {
|
||||||
|
bool caseSensitive = true,
|
||||||
|
}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
StartsWithCondition(
|
||||||
|
property: 2,
|
||||||
|
value: value,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameEndsWith(
|
||||||
|
String value, {
|
||||||
|
bool caseSensitive = true,
|
||||||
|
}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
EndsWithCondition(
|
||||||
|
property: 2,
|
||||||
|
value: value,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameContains(
|
||||||
|
String value,
|
||||||
|
{bool caseSensitive = true}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
ContainsCondition(
|
||||||
|
property: 2,
|
||||||
|
value: value,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameMatches(
|
||||||
|
String pattern,
|
||||||
|
{bool caseSensitive = true}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
MatchesCondition(
|
||||||
|
property: 2,
|
||||||
|
wildcard: pattern,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameIsEmpty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
const EqualCondition(
|
||||||
|
property: 2,
|
||||||
|
value: '',
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterFilterCondition> nameIsNotEmpty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addFilterCondition(
|
||||||
|
const GreaterCondition(
|
||||||
|
property: 2,
|
||||||
|
value: '',
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismQueryObject
|
||||||
|
on QueryBuilder<Organism, Organism, QFilterCondition> {}
|
||||||
|
|
||||||
|
extension OrganismQuerySortBy on QueryBuilder<Organism, Organism, QSortBy> {
|
||||||
|
QueryBuilder<Organism, Organism, QAfterSortBy> sortById() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addSortBy(0);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterSortBy> sortByIdDesc() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addSortBy(0, sort: Sort.desc);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterSortBy> sortByName(
|
||||||
|
{bool caseSensitive = true}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addSortBy(
|
||||||
|
2,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterSortBy> sortByNameDesc(
|
||||||
|
{bool caseSensitive = true}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addSortBy(
|
||||||
|
2,
|
||||||
|
sort: Sort.desc,
|
||||||
|
caseSensitive: caseSensitive,
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismQuerySortThenBy
|
||||||
|
on QueryBuilder<Organism, Organism, QSortThenBy> {
|
||||||
|
QueryBuilder<Organism, Organism, QAfterSortBy> thenById() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addSortBy(0);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterSortBy> thenByIdDesc() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addSortBy(0, sort: Sort.desc);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterSortBy> thenByName(
|
||||||
|
{bool caseSensitive = true}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addSortBy(2, caseSensitive: caseSensitive);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, Organism, QAfterSortBy> thenByNameDesc(
|
||||||
|
{bool caseSensitive = true}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addSortBy(2, sort: Sort.desc, caseSensitive: caseSensitive);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismQueryWhereDistinct
|
||||||
|
on QueryBuilder<Organism, Organism, QDistinct> {
|
||||||
|
QueryBuilder<Organism, Organism, QAfterDistinct> distinctByName(
|
||||||
|
{bool caseSensitive = true}) {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addDistinctBy(2, caseSensitive: caseSensitive);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismQueryProperty1
|
||||||
|
on QueryBuilder<Organism, Organism, QProperty> {
|
||||||
|
QueryBuilder<Organism, List<IdValue>?, QAfterProperty> measuresProperty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addProperty(1);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, int, QAfterProperty> idProperty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addProperty(0);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, String?, QAfterProperty> nameProperty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addProperty(2);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismQueryProperty2<R>
|
||||||
|
on QueryBuilder<Organism, R, QAfterProperty> {
|
||||||
|
QueryBuilder<Organism, (R, List<IdValue>?), QAfterProperty>
|
||||||
|
measuresProperty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addProperty(1);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, (R, int), QAfterProperty> idProperty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addProperty(0);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, (R, String?), QAfterProperty> nameProperty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addProperty(2);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extension OrganismQueryProperty3<R1, R2>
|
||||||
|
on QueryBuilder<Organism, (R1, R2), QAfterProperty> {
|
||||||
|
QueryBuilder<Organism, (R1, R2, List<IdValue>?), QOperations>
|
||||||
|
measuresProperty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addProperty(1);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, (R1, R2, int), QOperations> idProperty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addProperty(0);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryBuilder<Organism, (R1, R2, String?), QOperations> nameProperty() {
|
||||||
|
return QueryBuilder.apply(this, (query) {
|
||||||
|
return query.addProperty(2);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// **************************************************************************
|
||||||
|
// JsonSerializableGenerator
|
||||||
|
// **************************************************************************
|
||||||
|
|
||||||
|
Organism _$OrganismFromJson(Map<String, dynamic> json) => Organism()
|
||||||
|
..id = (json['id'] as num).toInt()
|
||||||
|
..name = json['Name'] as String?
|
||||||
|
..measures = (json['Maßnahmen'] as List<dynamic>?)
|
||||||
|
?.map((e) => IdValue.fromJson(e as Map<String, dynamic>))
|
||||||
|
.toList();
|
||||||
|
|
||||||
|
Map<String, dynamic> _$OrganismToJson(Organism instance) => <String, dynamic>{
|
||||||
|
'id': instance.id,
|
||||||
|
'Name': instance.name,
|
||||||
|
'Maßnahmen': instance.measures?.map((e) => e.toJson()).toList(),
|
||||||
|
};
|
|
@ -1,30 +1,12 @@
|
||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
|
|
||||||
import 'package:ambito/src/domain/entity/entities.dart';
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
|
import 'package:ambito/src/domain/entity/funding_program/funding_program.dart';
|
||||||
import 'package:ambito/src/packages/ambito_api/restclient.dart';
|
import 'package:ambito/src/packages/ambito_api/restclient.dart';
|
||||||
|
import 'package:ambito/src/packages/ambito_db/repositories/funding_program_repository.dart';
|
||||||
import 'package:flutter_dotenv/flutter_dotenv.dart';
|
import 'package:flutter_dotenv/flutter_dotenv.dart';
|
||||||
|
|
||||||
import '../ambito_db/repositories/baumarten_repository.dart';
|
import '../ambito_db/base_db.dart';
|
||||||
import '../ambito_db/repositories/massnahme_repository.dart';
|
|
||||||
|
|
||||||
Map<String, int> tables = {
|
|
||||||
'massnahmen': 328253,
|
|
||||||
'massnahmenkombination': 328217,
|
|
||||||
'organismen': 328255,
|
|
||||||
'foerderprogramme': 328256,
|
|
||||||
'factsheet': 328273,
|
|
||||||
'standortansprueche': 328188,
|
|
||||||
'referenzumsetzung': 328465,
|
|
||||||
'betriebsverzeichnis': 328472,
|
|
||||||
'erfahrungsbericht': 330802,
|
|
||||||
'genehmigungspflicht': 330806,
|
|
||||||
'dienstleister': 330824,
|
|
||||||
'ansprechperson': 330832,
|
|
||||||
'material': 330836,
|
|
||||||
'quellen': 334231,
|
|
||||||
'baumarten': 342622,
|
|
||||||
'aenderungfactsheet': 330946,
|
|
||||||
};
|
|
||||||
|
|
||||||
class BaseApi {
|
class BaseApi {
|
||||||
Map tables = {};
|
Map tables = {};
|
||||||
|
@ -47,9 +29,26 @@ class BaseApi {
|
||||||
BaumartenRepository().put(Baumarten.fromJson(baumart));
|
BaumartenRepository().put(Baumarten.fromJson(baumart));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'massnahmen':
|
case 'measure':
|
||||||
for (var massnahme in json['results']) {
|
for (var measure in json['results']) {
|
||||||
MassnahmeRepository().put(Massnahme.fromJson(massnahme));
|
MeasureRepository().put(Measure.fromJson(measure));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'measure_combination':
|
||||||
|
for (var measure_combination in json['results']) {
|
||||||
|
MeasureCombinationRepository()
|
||||||
|
.put(MeasureCombination.fromJson(measure_combination));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'organism':
|
||||||
|
for (var organism in json['results']) {
|
||||||
|
OrganismRepository().put(Organism.fromJson(organism));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'funding_program':
|
||||||
|
for (var fundingProgram in json['results']) {
|
||||||
|
FundingProgramRepository()
|
||||||
|
.put(FundingProgram.fromJson(fundingProgram));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,11 @@ import 'package:isar/isar.dart';
|
||||||
|
|
||||||
import '../../../main.dart';
|
import '../../../main.dart';
|
||||||
|
|
||||||
|
export 'repositories/baumarten_repository.dart';
|
||||||
|
export 'repositories/measure_combination_repository.dart';
|
||||||
|
export 'repositories/measure_repository.dart';
|
||||||
|
export 'repositories/organism_repository.dart';
|
||||||
|
|
||||||
abstract class BaseDB {
|
abstract class BaseDB {
|
||||||
abstract IsarCollection collection;
|
abstract IsarCollection collection;
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
import 'package:ambito/src/domain/entity/funding_program/funding_program.dart';
|
||||||
|
import 'package:ambito/src/packages/ambito_db/base_db.dart';
|
||||||
|
import 'package:isar/isar.dart';
|
||||||
|
|
||||||
|
import '../../../../main.dart';
|
||||||
|
|
||||||
|
class FundingProgramRepository extends BaseDB {
|
||||||
|
IsarCollection collection = isar.fundingPrograms;
|
||||||
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
|
import 'package:ambito/src/packages/ambito_db/base_db.dart';
|
||||||
|
import 'package:isar/isar.dart';
|
||||||
|
|
||||||
|
import '../../../../main.dart';
|
||||||
|
|
||||||
|
class MeasureCombinationRepository extends BaseDB {
|
||||||
|
IsarCollection collection = isar.measureCombinations;
|
||||||
|
}
|
|
@ -4,6 +4,6 @@ import 'package:isar/isar.dart';
|
||||||
|
|
||||||
import '../../../../main.dart';
|
import '../../../../main.dart';
|
||||||
|
|
||||||
class MassnahmeRepository extends BaseDB {
|
class MeasureRepository extends BaseDB {
|
||||||
IsarCollection collection = isar.massnahmes;
|
IsarCollection collection = isar.measures;
|
||||||
}
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
import 'package:ambito/src/domain/entity/entities.dart';
|
||||||
|
import 'package:ambito/src/packages/ambito_db/base_db.dart';
|
||||||
|
import 'package:isar/isar.dart';
|
||||||
|
|
||||||
|
import '../../../../main.dart';
|
||||||
|
|
||||||
|
class OrganismRepository extends BaseDB {
|
||||||
|
IsarCollection collection = isar.organisms;
|
||||||
|
}
|
|
@ -1,6 +1,5 @@
|
||||||
import 'package:ambito/src/domain/entity/massnahme/massnahme.dart';
|
|
||||||
import 'package:ambito/src/extensions/extensions.dart';
|
import 'package:ambito/src/extensions/extensions.dart';
|
||||||
import 'package:ambito/src/packages/ambito_db/repositories/massnahme_repository.dart';
|
import 'package:ambito/src/packages/ambito_db/repositories/measure_repository.dart';
|
||||||
import 'package:ambito/src/widgets/form/fields/field_dropdown.dart';
|
import 'package:ambito/src/widgets/form/fields/field_dropdown.dart';
|
||||||
import 'package:ambito/src/widgets/form/fields/field_monthsrangepicker.dart';
|
import 'package:ambito/src/widgets/form/fields/field_monthsrangepicker.dart';
|
||||||
import 'package:ambito/src/widgets/form/form_widget.dart';
|
import 'package:ambito/src/widgets/form/form_widget.dart';
|
||||||
|
@ -11,6 +10,7 @@ import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_i18n/flutter_i18n.dart';
|
import 'package:flutter_i18n/flutter_i18n.dart';
|
||||||
|
|
||||||
import '../../../main.dart';
|
import '../../../main.dart';
|
||||||
|
import '../../domain/entity/entities.dart';
|
||||||
|
|
||||||
class ActionsPage extends StatefulWidget {
|
class ActionsPage extends StatefulWidget {
|
||||||
const ActionsPage({super.key});
|
const ActionsPage({super.key});
|
||||||
|
@ -37,7 +37,7 @@ class ActionsPageState extends State<ActionsPage> {
|
||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
super.initState();
|
super.initState();
|
||||||
massnahmen = MassnahmeRepository().getAll();
|
massnahmen = MeasureRepository().getAll();
|
||||||
effort = [];
|
effort = [];
|
||||||
effect = [];
|
effect = [];
|
||||||
type = {};
|
type = {};
|
||||||
|
@ -229,7 +229,7 @@ class ActionsPageState extends State<ActionsPage> {
|
||||||
return FormWidget(type: FormWidgetType.vertical, fields: fields);
|
return FormWidget(type: FormWidgetType.vertical, fields: fields);
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget getCard(BuildContext context, Massnahme massnahme) {
|
Widget getCard(BuildContext context, Measure massnahme) {
|
||||||
final Map<String, Color> actionGroupColors = {
|
final Map<String, Color> actionGroupColors = {
|
||||||
'Baulelemente': const Color(0xffFFD269),
|
'Baulelemente': const Color(0xffFFD269),
|
||||||
'Begrünung': const Color(0xff40DD74),
|
'Begrünung': const Color(0xff40DD74),
|
||||||
|
|
40
pubspec.lock
40
pubspec.lock
|
@ -186,10 +186,10 @@ packages:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: convert
|
name: convert
|
||||||
sha256: "0f08b14755d163f6e2134cb58222dd25ea2a2ee8a195e53983d57c075324d592"
|
sha256: b30acd5944035672bc15c6b7a8b47d773e41e2f17de064350988c5d02adb1c68
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "3.1.1"
|
version: "3.1.2"
|
||||||
country_flags:
|
country_flags:
|
||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description:
|
description:
|
||||||
|
@ -202,10 +202,10 @@ packages:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: crypto
|
name: crypto
|
||||||
sha256: ec30d999af904f33454ba22ed9a86162b35e52b44ac4807d1d93c288041d7d27
|
sha256: "1e445881f28f22d6140f181e07737b22f1e099a5e1ff94b0af2f9e4a463f4855"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "3.0.5"
|
version: "3.0.6"
|
||||||
cupertino_icons:
|
cupertino_icons:
|
||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description:
|
description:
|
||||||
|
@ -298,10 +298,10 @@ packages:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: fixnum
|
name: fixnum
|
||||||
sha256: "25517a4deb0c03aa0f32fd12db525856438902d9c16536311e76cdc57b31d7d1"
|
sha256: b6dc7065e46c974bc7c5f143080a6764ec7a4be6da1285ececdc37be96de53be
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.1.0"
|
version: "1.1.1"
|
||||||
flutter:
|
flutter:
|
||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description: flutter
|
description: flutter
|
||||||
|
@ -630,10 +630,10 @@ packages:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: logging
|
name: logging
|
||||||
sha256: "623a88c9594aa774443aa3eb2d41807a48486b5613e67599fb4c41c0ad47c340"
|
sha256: c8245ada5f1717ed44271ed1c26b8ce85ca3228fd2ffdb75468ab01979309d61
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.2.0"
|
version: "1.3.0"
|
||||||
macros:
|
macros:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
|
@ -774,10 +774,10 @@ packages:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: permission_handler_android
|
name: permission_handler_android
|
||||||
sha256: "76e4ab092c1b240d31177bb64d2b0bea43f43d0e23541ec866151b9f7b2490fa"
|
sha256: "71bbecfee799e65aff7c744761a57e817e73b738fedf62ab7afd5593da21f9f1"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "12.0.12"
|
version: "12.0.13"
|
||||||
permission_handler_apple:
|
permission_handler_apple:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
|
@ -822,10 +822,10 @@ packages:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: platform
|
name: platform
|
||||||
sha256: "9b71283fc13df574056616011fb138fd3b793ea47cc509c189a6c3fa5f8a1a65"
|
sha256: "5d6b1b0036a5f331ebc77c850ebc8506cbc1e9416c27e59b439f917a902a4984"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "3.1.5"
|
version: "3.1.6"
|
||||||
plugin_platform_interface:
|
plugin_platform_interface:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
|
@ -1019,26 +1019,26 @@ packages:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: syncfusion_flutter_core
|
name: syncfusion_flutter_core
|
||||||
sha256: becd190595cba56feac5ec17b805b35df9f006171c131c209f79b5c58fc780eb
|
sha256: dde81d3a318d914e26b6882051c486b0f5e4fa13e7bc3661741de78f0397fe64
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "27.1.53"
|
version: "27.1.56"
|
||||||
syncfusion_flutter_datepicker:
|
syncfusion_flutter_datepicker:
|
||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description:
|
description:
|
||||||
name: syncfusion_flutter_datepicker
|
name: syncfusion_flutter_datepicker
|
||||||
sha256: "5638805bea1c70a6d46dea9d39ef67f0085176e1c15cf57f7036cf67c1568816"
|
sha256: e4d42b03b69e80b5936f44d420f9577542f8b156ba5ee78a05e28b23ed63c850
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "27.1.53"
|
version: "27.1.56"
|
||||||
syncfusion_localizations:
|
syncfusion_localizations:
|
||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description:
|
description:
|
||||||
name: syncfusion_localizations
|
name: syncfusion_localizations
|
||||||
sha256: "742cd5df17f6438628655b7a16d1ee87624166a9dd0362cb818d9f6968ffbc10"
|
sha256: "6dbc2eab1d70fad7b8501c44198bef4d36748cc6860252dfd4c8cfe2f3b10e7b"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "27.1.53"
|
version: "27.1.56"
|
||||||
synchronized:
|
synchronized:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
|
@ -1083,10 +1083,10 @@ packages:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: typed_data
|
name: typed_data
|
||||||
sha256: facc8d6582f16042dd49f2463ff1bd6e2c9ef9f3d5da3d9b087e244a7b564b3c
|
sha256: f9049c039ebfeb4cf7a7104a675823cd72dba8297f264b6637062516699fa006
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.3.2"
|
version: "1.4.0"
|
||||||
unicode:
|
unicode:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
|
|
Loading…
Reference in a new issue