Update download configuration (via export and not thousand request on first use) + fix alreadyDownloaded
This commit is contained in:
parent
d78372e728
commit
9d817932fb
@ -1 +1 @@
|
|||||||
{"info":"This is a generated file; do not edit or check into version control.","plugins":{"ios":[{"name":"audio_session","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\audio_session-0.1.13\\\\","native_build":true,"dependencies":[]},{"name":"flutter_beacon","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\flutter_beacon-0.5.1\\\\","native_build":true,"dependencies":[]},{"name":"just_audio","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\just_audio-0.9.31\\\\","native_build":true,"dependencies":["audio_session"]},{"name":"path_provider_foundation","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_foundation-2.1.1\\\\","native_build":true,"dependencies":[]},{"name":"permission_handler","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\permission_handler-8.3.0\\\\","native_build":true,"dependencies":[]},{"name":"qr_code_scanner","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\qr_code_scanner-1.0.1\\\\","native_build":true,"dependencies":[]},{"name":"sqflite","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\sqflite-2.2.4+1\\\\","native_build":true,"dependencies":[]}],"android":[{"name":"audio_session","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\audio_session-0.1.13\\\\","native_build":true,"dependencies":[]},{"name":"flutter_beacon","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\flutter_beacon-0.5.1\\\\","native_build":true,"dependencies":[]},{"name":"just_audio","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\just_audio-0.9.31\\\\","native_build":true,"dependencies":["audio_session"]},{"name":"path_provider_android","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_android-2.0.22\\\\","native_build":true,"dependencies":[]},{"name":"permission_handler","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\permission_handler-8.3.0\\\\","native_build":true,"dependencies":[]},{"name":"qr_code_scanner","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\qr_code_scanner-1.0.1\\\\","native_build":true,"dependencies":[]},{"name":"sqflite","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\sqflite-2.2.4+1\\\\","native_build":true,"dependencies":[]}],"macos":[{"name":"audio_session","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\audio_session-0.1.13\\\\","native_build":true,"dependencies":[]},{"name":"just_audio","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\just_audio-0.9.31\\\\","native_build":true,"dependencies":["audio_session"]},{"name":"path_provider_foundation","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_foundation-2.1.1\\\\","native_build":true,"dependencies":[]},{"name":"sqflite","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\sqflite-2.2.4+1\\\\","native_build":true,"dependencies":[]}],"linux":[{"name":"path_provider_linux","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_linux-2.1.7\\\\","native_build":false,"dependencies":[]}],"windows":[{"name":"path_provider_windows","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_windows-2.1.3\\\\","native_build":false,"dependencies":[]}],"web":[{"name":"audio_session","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\audio_session-0.1.13\\\\","dependencies":[]},{"name":"just_audio_web","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\just_audio_web-0.4.7\\\\","dependencies":[]}]},"dependencyGraph":[{"name":"audio_session","dependencies":[]},{"name":"flutter_beacon","dependencies":[]},{"name":"just_audio","dependencies":["just_audio_web","audio_session","path_provider"]},{"name":"just_audio_web","dependencies":[]},{"name":"path_provider","dependencies":["path_provider_android","path_provider_foundation","path_provider_linux","path_provider_windows"]},{"name":"path_provider_android","dependencies":[]},{"name":"path_provider_foundation","dependencies":[]},{"name":"path_provider_linux","dependencies":[]},{"name":"path_provider_windows","dependencies":[]},{"name":"permission_handler","dependencies":[]},{"name":"qr_code_scanner","dependencies":[]},{"name":"sqflite","dependencies":[]}],"date_created":"2023-01-28 02:26:08.187656","version":"3.7.0"}
|
{"info":"This is a generated file; do not edit or check into version control.","plugins":{"ios":[{"name":"audio_session","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\audio_session-0.1.13\\\\","native_build":true,"dependencies":[]},{"name":"flutter_beacon","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\flutter_beacon-0.5.1\\\\","native_build":true,"dependencies":[]},{"name":"just_audio","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\just_audio-0.9.31\\\\","native_build":true,"dependencies":["audio_session"]},{"name":"path_provider_foundation","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_foundation-2.1.1\\\\","native_build":true,"dependencies":[]},{"name":"permission_handler","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\permission_handler-8.3.0\\\\","native_build":true,"dependencies":[]},{"name":"qr_code_scanner","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\qr_code_scanner-1.0.1\\\\","native_build":true,"dependencies":[]},{"name":"sqflite","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\sqflite-2.2.4+1\\\\","native_build":true,"dependencies":[]}],"android":[{"name":"audio_session","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\audio_session-0.1.13\\\\","native_build":true,"dependencies":[]},{"name":"flutter_beacon","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\flutter_beacon-0.5.1\\\\","native_build":true,"dependencies":[]},{"name":"just_audio","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\just_audio-0.9.31\\\\","native_build":true,"dependencies":["audio_session"]},{"name":"path_provider_android","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_android-2.0.22\\\\","native_build":true,"dependencies":[]},{"name":"permission_handler","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\permission_handler-8.3.0\\\\","native_build":true,"dependencies":[]},{"name":"qr_code_scanner","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\qr_code_scanner-1.0.1\\\\","native_build":true,"dependencies":[]},{"name":"sqflite","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\sqflite-2.2.4+1\\\\","native_build":true,"dependencies":[]}],"macos":[{"name":"audio_session","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\audio_session-0.1.13\\\\","native_build":true,"dependencies":[]},{"name":"just_audio","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\just_audio-0.9.31\\\\","native_build":true,"dependencies":["audio_session"]},{"name":"path_provider_foundation","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_foundation-2.1.1\\\\","native_build":true,"dependencies":[]},{"name":"sqflite","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\sqflite-2.2.4+1\\\\","native_build":true,"dependencies":[]}],"linux":[{"name":"path_provider_linux","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_linux-2.1.7\\\\","native_build":false,"dependencies":[]}],"windows":[{"name":"path_provider_windows","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\path_provider_windows-2.1.3\\\\","native_build":false,"dependencies":[]}],"web":[{"name":"audio_session","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\audio_session-0.1.13\\\\","dependencies":[]},{"name":"just_audio_web","path":"C:\\\\Users\\\\thoma\\\\AppData\\\\Local\\\\Pub\\\\Cache\\\\hosted\\\\pub.dev\\\\just_audio_web-0.4.7\\\\","dependencies":[]}]},"dependencyGraph":[{"name":"audio_session","dependencies":[]},{"name":"flutter_beacon","dependencies":[]},{"name":"just_audio","dependencies":["just_audio_web","audio_session","path_provider"]},{"name":"just_audio_web","dependencies":[]},{"name":"path_provider","dependencies":["path_provider_android","path_provider_foundation","path_provider_linux","path_provider_windows"]},{"name":"path_provider_android","dependencies":[]},{"name":"path_provider_foundation","dependencies":[]},{"name":"path_provider_linux","dependencies":[]},{"name":"path_provider_windows","dependencies":[]},{"name":"permission_handler","dependencies":[]},{"name":"qr_code_scanner","dependencies":[]},{"name":"sqflite","dependencies":[]}],"date_created":"2023-02-10 17:09:46.854097","version":"3.7.0"}
|
||||||
@ -30,6 +30,10 @@ This README would normally document whatever steps are necessary to get your app
|
|||||||
|
|
||||||
# OPENAPI Generation cmd
|
# OPENAPI Generation cmd
|
||||||
|
|
||||||
|
flutter clean
|
||||||
|
|
||||||
|
flutter pub get
|
||||||
|
|
||||||
flutter pub run build_runner build --delete-conflicting-outputs
|
flutter pub run build_runner build --delete-conflicting-outputs
|
||||||
|
|
||||||
Le fichier est dans le projet.
|
Le fichier est dans le projet.
|
||||||
|
|||||||
@ -126,10 +126,14 @@ class DatabaseHelper {
|
|||||||
//print("languages BEFORE");
|
//print("languages BEFORE");
|
||||||
//print(info["languages"]);
|
//print(info["languages"]);
|
||||||
}
|
}
|
||||||
var test = await instance.getData(type);
|
//var test = await instance.getData(type);
|
||||||
if((type == DatabaseTableType.main && test != null) || (type != DatabaseTableType.main && test!.where((t) => info[columnId] == t.id).isNotEmpty)) {
|
|
||||||
|
var test = await DatabaseHelper.instance.queryWithColumnId(type, info[columnId].toString());
|
||||||
|
|
||||||
|
if((type == DatabaseTableType.main && test != null) || (type != DatabaseTableType.main && test.isNotEmpty)) { //test!.where((t) => info[columnId] == t.id).isNotEmpty
|
||||||
if(type != DatabaseTableType.main) {
|
if(type != DatabaseTableType.main) {
|
||||||
print("UPDATE $type - length before ${test.length}");
|
//print("UPDATE $type - length before ${test.length}");
|
||||||
|
print("UPDATE $type");
|
||||||
} else {
|
} else {
|
||||||
print("UPDATE $type - main table");
|
print("UPDATE $type - main table");
|
||||||
}
|
}
|
||||||
@ -142,7 +146,8 @@ class DatabaseHelper {
|
|||||||
return res;
|
return res;
|
||||||
} else {
|
} else {
|
||||||
if(type != DatabaseTableType.main) {
|
if(type != DatabaseTableType.main) {
|
||||||
print("INSERT $type - length before ${test.length}");
|
//print("INSERT $type - length before ${test.length}");
|
||||||
|
print("INSERT $type");
|
||||||
} else {
|
} else {
|
||||||
print("INSERT $type - main table");
|
print("INSERT $type - main table");
|
||||||
}
|
}
|
||||||
|
|||||||
@ -14,7 +14,7 @@ class ResourceModel {
|
|||||||
'id': id,
|
'id': id,
|
||||||
'data': data,
|
'data': data,
|
||||||
'source': source,
|
'source': source,
|
||||||
'type': type!.value
|
'type': type?.value
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -119,15 +119,18 @@ class _HomePageState extends State<HomePage> with WidgetsBindingObserver {
|
|||||||
bool isOnline = await hasNetwork();
|
bool isOnline = await hasNetwork();
|
||||||
VisitAppContext visitAppContext = appContext.getContext();
|
VisitAppContext visitAppContext = appContext.getContext();
|
||||||
|
|
||||||
|
List<ConfigurationDTO>? configurations;
|
||||||
|
configurations = List<ConfigurationDTO>.from(await DatabaseHelper.instance.getData(DatabaseTableType.configurations));
|
||||||
|
alreadyDownloaded = configurations.map((c) => c.id).toList();
|
||||||
|
|
||||||
|
print("alreadyDownloadedalreadyDownloadedalreadyDownloadedalreadyDownloadedalreadyDownloadedalreadyDownloaded");
|
||||||
|
print(alreadyDownloaded);
|
||||||
|
|
||||||
if(!isOnline) {
|
if(!isOnline) {
|
||||||
ScaffoldMessenger.of(context).showSnackBar(
|
ScaffoldMessenger.of(context).showSnackBar(
|
||||||
SnackBar(content: Text(TranslationHelper.getFromLocale("noInternet", appContext)), backgroundColor: kBlue2),
|
SnackBar(content: Text(TranslationHelper.getFromLocale("noInternet", appContext)), backgroundColor: kBlue2),
|
||||||
);
|
);
|
||||||
|
|
||||||
List<ConfigurationDTO>? configurations;
|
|
||||||
configurations = List<ConfigurationDTO>.from(await DatabaseHelper.instance.getData(DatabaseTableType.configurations));
|
|
||||||
alreadyDownloaded = configurations.map((c) => c.id).toList();
|
|
||||||
|
|
||||||
// TODO HANDLE BEACON IN LOCAL (CREATE TABLE)
|
// TODO HANDLE BEACON IN LOCAL (CREATE TABLE)
|
||||||
|
|
||||||
return configurations;
|
return configurations;
|
||||||
@ -143,6 +146,7 @@ class _HomePageState extends State<HomePage> with WidgetsBindingObserver {
|
|||||||
appContext.setContext(visitAppContext); // STORE IT, TODO Store it locally
|
appContext.setContext(visitAppContext); // STORE IT, TODO Store it locally
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return await ApiService.getConfigurations(client, visitAppContext);
|
return await ApiService.getConfigurations(client, visitAppContext);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -172,5 +172,22 @@ class ApiService {
|
|||||||
return ResourceModel(); // To mock
|
return ResourceModel(); // To mock
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static Future<ExportConfigurationDTO?> exportConfiguration(Client client, String configurationId) async {
|
||||||
|
try {
|
||||||
|
bool isOnline = await hasNetwork();
|
||||||
|
if(isOnline) {
|
||||||
|
ExportConfigurationDTO? exportConfiguration = await client.configurationApi!.configurationExport(configurationId);
|
||||||
|
|
||||||
|
return exportConfiguration;
|
||||||
|
} else {
|
||||||
|
return null; // TODO return local list..
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
print(e);
|
||||||
|
print("exportConfiguration IN CATCH");
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -11,12 +11,97 @@ import 'package:mymuseum_visitapp/app_context.dart';
|
|||||||
class DownloadConfiguration {
|
class DownloadConfiguration {
|
||||||
static Future<bool> downloadClicked(AppContext appContext, ConfigurationDTO configuration) async {
|
static Future<bool> downloadClicked(AppContext appContext, ConfigurationDTO configuration) async {
|
||||||
|
|
||||||
// Update local DB - Configuration
|
print("COUCOUCOU IIIIINNNN");
|
||||||
|
// TODO TEST VIA EXPORT
|
||||||
|
ExportConfigurationDTO? exportConfigurationDTO = await ApiService.exportConfiguration(appContext.clientAPI, configuration.id!);
|
||||||
|
|
||||||
|
if(exportConfigurationDTO != null) {
|
||||||
|
// Delete all from local DB ref to this configurationId then add it all
|
||||||
|
|
||||||
await DatabaseHelper.instance.insert(DatabaseTableType.configurations, ModelsHelper.configurationToMap(configuration));
|
await DatabaseHelper.instance.insert(DatabaseTableType.configurations, ModelsHelper.configurationToMap(configuration));
|
||||||
List<String> usedImageOrAudioIds = [];
|
List<String> usedImageOrAudioIds = [];
|
||||||
|
|
||||||
var currentLanguage = (appContext.getContext() as VisitAppContext).language;
|
var currentLanguage = (appContext.getContext() as VisitAppContext).language;
|
||||||
|
|
||||||
|
if(configuration.imageId != null) {
|
||||||
|
usedImageOrAudioIds.add(configuration.imageId!);
|
||||||
|
|
||||||
|
var imageData = exportConfigurationDTO.resources!.where((element) => element.id == configuration.imageId);
|
||||||
|
if(imageData.isNotEmpty) {
|
||||||
|
ResourceModel resourceModel = ResourceModel(id: imageData.first.id, source: configuration.imageSource, data: imageData.first.data, type: imageData.first.type);
|
||||||
|
await DatabaseHelper.instance.insert(DatabaseTableType.resources, resourceModel.toMap());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
List<SectionDTO>? sections = exportConfigurationDTO.sections;
|
||||||
|
|
||||||
|
if(sections!.isNotEmpty) {
|
||||||
|
|
||||||
|
List<SectionDTO> sectionsInDB = await DatabaseHelper.instance.queryWithConfigurationId(DatabaseTableType.sections, configuration.id!);
|
||||||
|
List<SectionDTO> sectionsToKeep = sections.where((s) => s.type == SectionType.Article).toList(); // TODO handle other type of section
|
||||||
|
|
||||||
|
sectionsToKeep.sort((a,b) => a.order!.compareTo(b.order!));
|
||||||
|
int newOrder = 0;
|
||||||
|
// Update local DB - Sections
|
||||||
|
for(var section in sectionsToKeep) {
|
||||||
|
section.order = newOrder;
|
||||||
|
await DatabaseHelper.instance.insert(DatabaseTableType.sections, ModelsHelper.sectionToMap(section));
|
||||||
|
|
||||||
|
// Download section image
|
||||||
|
if(section.imageId != null) {
|
||||||
|
usedImageOrAudioIds.add(section.imageId!);
|
||||||
|
var imageData = exportConfigurationDTO.resources!.where((element) => element.id == section.imageId);
|
||||||
|
if(imageData.isNotEmpty) {
|
||||||
|
ResourceModel resourceModel = ResourceModel(id: imageData.first.id, source: section.imageSource, data: imageData.first.data, type: imageData.first.type);
|
||||||
|
await DatabaseHelper.instance.insert(DatabaseTableType.resources, resourceModel.toMap());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Download all images..
|
||||||
|
ArticleDTO? articleDTO = ArticleDTO.fromJson(jsonDecode(section.data!));
|
||||||
|
|
||||||
|
if(articleDTO != null) {
|
||||||
|
for(var image in articleDTO.images!) {
|
||||||
|
usedImageOrAudioIds.add(image.resourceId!);
|
||||||
|
var imageData = exportConfigurationDTO.resources!.where((element) => element.id == image.resourceId);
|
||||||
|
if(imageData.isNotEmpty) {
|
||||||
|
ResourceModel resourceModel = ResourceModel(id: imageData.first.id, source: image.source_, data: imageData.first.data, type: imageData.first.type);
|
||||||
|
await DatabaseHelper.instance.insert(DatabaseTableType.resources, resourceModel.toMap());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var audioIdArticle = articleDTO.audioIds!.where((audioId) => audioId.language == currentLanguage);
|
||||||
|
if(audioIdArticle.isNotEmpty && audioIdArticle.first.value != null)
|
||||||
|
{
|
||||||
|
usedImageOrAudioIds.add(audioIdArticle.first.value!);
|
||||||
|
var audioData = exportConfigurationDTO.resources!.where((element) => element.id == audioIdArticle.first.value);
|
||||||
|
if(audioData.isNotEmpty) {
|
||||||
|
ResourceModel resourceModel = ResourceModel(id: audioData.first.id, source: "", data: audioData.first.data, type: audioData.first.type);
|
||||||
|
await DatabaseHelper.instance.insert(DatabaseTableType.resources, resourceModel.toMap());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
newOrder = newOrder + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
List<String?> sectionIdsToRemove = sectionsInDB.map((s) => s.id).where((sectionId) => !sectionsToKeep.map((sk) => sk.id).contains(sectionId)).toList();
|
||||||
|
|
||||||
|
for(var sectionIdToRemove in sectionIdsToRemove) {
|
||||||
|
print("section with id removed");
|
||||||
|
print(sectionIdToRemove);
|
||||||
|
await DatabaseHelper.instance.delete(sectionIdToRemove!, DatabaseTableType.sections);
|
||||||
|
}
|
||||||
|
|
||||||
|
cleanLocalResources(usedImageOrAudioIds, configuration);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update local DB - Configuration - OLD COOODE
|
||||||
|
/*await DatabaseHelper.instance.insert(DatabaseTableType.configurations, ModelsHelper.configurationToMap(configuration));
|
||||||
|
List<String> usedImageOrAudioIds = [];
|
||||||
|
|
||||||
|
var currentLanguage = (appContext.getContext() as VisitAppContext).language;
|
||||||
|
|
||||||
if(configuration.imageId != null) {
|
if(configuration.imageId != null) {
|
||||||
ImageDTO image = ImageDTO(resourceId: configuration.imageId, source_: configuration.imageSource);
|
ImageDTO image = ImageDTO(resourceId: configuration.imageId, source_: configuration.imageSource);
|
||||||
usedImageOrAudioIds.add(configuration.imageId!);
|
usedImageOrAudioIds.add(configuration.imageId!);
|
||||||
@ -72,7 +157,7 @@ class DownloadConfiguration {
|
|||||||
}
|
}
|
||||||
|
|
||||||
cleanLocalResources(usedImageOrAudioIds, configuration);
|
cleanLocalResources(usedImageOrAudioIds, configuration);
|
||||||
}
|
}*/
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -7,7 +7,7 @@ List<Translation> translations = [
|
|||||||
"noData": "Pas de données",
|
"noData": "Pas de données",
|
||||||
"invalidQRCode": "Code QR invalide",
|
"invalidQRCode": "Code QR invalide",
|
||||||
"languageNotSupported": "Cette visite ne prend pas en charge votre langue",
|
"languageNotSupported": "Cette visite ne prend pas en charge votre langue",
|
||||||
"downloadConfiguration": "Chargement de la visite en cours...",
|
"downloadConfiguration": "Téléchargement de la visite en cours...",
|
||||||
"noInternet": "Aucune connexion internet détectée",
|
"noInternet": "Aucune connexion internet détectée",
|
||||||
"search": "Rechercher",
|
"search": "Rechercher",
|
||||||
"play": "Lecture",
|
"play": "Lecture",
|
||||||
|
|||||||
@ -144,7 +144,7 @@ class ConfigurationApi {
|
|||||||
/// Parameters:
|
/// Parameters:
|
||||||
///
|
///
|
||||||
/// * [String] id (required):
|
/// * [String] id (required):
|
||||||
Future<MultipartFile?> configurationExport(String id,) async {
|
Future<ExportConfigurationDTO?> configurationExport(String id,) async {
|
||||||
final response = await configurationExportWithHttpInfo(id,);
|
final response = await configurationExportWithHttpInfo(id,);
|
||||||
if (response.statusCode >= HttpStatus.badRequest) {
|
if (response.statusCode >= HttpStatus.badRequest) {
|
||||||
throw ApiException(response.statusCode, await _decodeBodyBytes(response));
|
throw ApiException(response.statusCode, await _decodeBodyBytes(response));
|
||||||
@ -153,8 +153,12 @@ class ConfigurationApi {
|
|||||||
// At the time of writing this, `dart:convert` will throw an "Unexpected end of input"
|
// At the time of writing this, `dart:convert` will throw an "Unexpected end of input"
|
||||||
// FormatException when trying to decode an empty string.
|
// FormatException when trying to decode an empty string.
|
||||||
if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) {
|
if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) {
|
||||||
return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'MultipartFile',) as MultipartFile;
|
var test = await _decodeBodyBytes(response);
|
||||||
|
var responseJSON = json.decode(test);
|
||||||
|
var export = ExportConfigurationDTO.fromJson(responseJSON);
|
||||||
|
|
||||||
|
return export;
|
||||||
|
//return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'MultipartFile',) as MultipartFile;
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -23,19 +23,19 @@ class MapTypeApp {
|
|||||||
|
|
||||||
int toJson() => value;
|
int toJson() => value;
|
||||||
|
|
||||||
static const number0 = MapTypeApp._(0);
|
static const none = MapTypeApp._(0);
|
||||||
static const number1 = MapTypeApp._(1);
|
static const normal = MapTypeApp._(1);
|
||||||
static const number2 = MapTypeApp._(2);
|
static const satellite = MapTypeApp._(2);
|
||||||
static const number3 = MapTypeApp._(3);
|
static const terrain = MapTypeApp._(3);
|
||||||
static const number4 = MapTypeApp._(4);
|
static const hybrid = MapTypeApp._(4);
|
||||||
|
|
||||||
/// List of all possible values in this [enum][MapTypeApp].
|
/// List of all possible values in this [enum][MapTypeApp].
|
||||||
static const values = <MapTypeApp>[
|
static const values = <MapTypeApp>[
|
||||||
number0,
|
none,
|
||||||
number1,
|
normal,
|
||||||
number2,
|
satellite,
|
||||||
number3,
|
terrain,
|
||||||
number4,
|
hybrid,
|
||||||
];
|
];
|
||||||
|
|
||||||
static MapTypeApp? fromJson(dynamic value) => MapTypeAppTypeTransformer().decode(value);
|
static MapTypeApp? fromJson(dynamic value) => MapTypeAppTypeTransformer().decode(value);
|
||||||
@ -73,18 +73,48 @@ class MapTypeAppTypeTransformer {
|
|||||||
/// and users are still using an old app with the old code.
|
/// and users are still using an old app with the old code.
|
||||||
MapTypeApp? decode(dynamic data, {bool allowNull = true}) {
|
MapTypeApp? decode(dynamic data, {bool allowNull = true}) {
|
||||||
if (data != null) {
|
if (data != null) {
|
||||||
switch (data) {
|
switch (data.toString()) {
|
||||||
case 0: return MapTypeApp.number0;
|
case r'None': return MapTypeApp.none;
|
||||||
case 1: return MapTypeApp.number1;
|
case r'Normal': return MapTypeApp.normal;
|
||||||
case 2: return MapTypeApp.number2;
|
case r'Satellite': return MapTypeApp.satellite;
|
||||||
case 3: return MapTypeApp.number3;
|
case r'Terrain': return MapTypeApp.terrain;
|
||||||
case 4: return MapTypeApp.number4;
|
case r'Hybrid': return MapTypeApp.hybrid;
|
||||||
default:
|
default:
|
||||||
if (!allowNull) {
|
if (!allowNull) {
|
||||||
throw ArgumentError('Unknown enum value to decode: $data');
|
throw ArgumentError('Unknown enum value to decode: $data');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (data != null) {
|
||||||
|
if(data.runtimeType == String) {
|
||||||
|
switch (data.toString()) {
|
||||||
|
case r'None': return MapTypeApp.none;
|
||||||
|
case r'Normal': return MapTypeApp.normal;
|
||||||
|
case r'Satellite': return MapTypeApp.satellite;
|
||||||
|
case r'Terrain': return MapTypeApp.terrain;
|
||||||
|
case r'Hybrid': return MapTypeApp.hybrid;
|
||||||
|
default:
|
||||||
|
if (!allowNull) {
|
||||||
|
throw ArgumentError('Unknown enum value to decode: $data');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if(data.runtimeType == int) {
|
||||||
|
switch (data) {
|
||||||
|
case 0: return MapTypeApp.none;
|
||||||
|
case 1: return MapTypeApp.normal;
|
||||||
|
case 2: return MapTypeApp.satellite;
|
||||||
|
case 3: return MapTypeApp.terrain;
|
||||||
|
case 4: return MapTypeApp.hybrid;
|
||||||
|
default:
|
||||||
|
if (!allowNull) {
|
||||||
|
throw ArgumentError('Unknown enum value to decode: $data');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -73,17 +73,33 @@ class ResourceTypeTypeTransformer {
|
|||||||
/// and users are still using an old app with the old code.
|
/// and users are still using an old app with the old code.
|
||||||
ResourceType? decode(dynamic data, {bool allowNull = true}) {
|
ResourceType? decode(dynamic data, {bool allowNull = true}) {
|
||||||
if (data != null) {
|
if (data != null) {
|
||||||
switch (data) {
|
if(data.runtimeType == String) {
|
||||||
case "Image": return ResourceType.Image;
|
switch (data.toString()) {
|
||||||
case "Video": return ResourceType.Video;
|
case r'Image': return ResourceType.Image;
|
||||||
case "ImageUrl": return ResourceType.ImageUrl;
|
case r'Video': return ResourceType.Video;
|
||||||
case "VideoUrl": return ResourceType.VideoUrl;
|
case r'ImageUrl': return ResourceType.ImageUrl;
|
||||||
case "Audio": return ResourceType.Audio;
|
case r'VideoUrl': return ResourceType.VideoUrl;
|
||||||
|
case r'Audio': return ResourceType.Audio;
|
||||||
default:
|
default:
|
||||||
if (!allowNull) {
|
if (!allowNull) {
|
||||||
throw ArgumentError('Unknown enum value to decode: $data');
|
throw ArgumentError('Unknown enum value to decode: $data');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if(data.runtimeType == int) {
|
||||||
|
switch (data) {
|
||||||
|
case 0: return ResourceType.Image;
|
||||||
|
case 1: return ResourceType.Video;
|
||||||
|
case 2: return ResourceType.ImageUrl;
|
||||||
|
case 3: return ResourceType.VideoUrl;
|
||||||
|
case 4: return ResourceType.Audio;
|
||||||
|
default:
|
||||||
|
if (!allowNull) {
|
||||||
|
throw ArgumentError('Unknown enum value to decode: $data');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -77,19 +77,43 @@ class SectionTypeTypeTransformer {
|
|||||||
/// and users are still using an old app with the old code.
|
/// and users are still using an old app with the old code.
|
||||||
SectionType? decode(dynamic data, {bool allowNull = true}) {
|
SectionType? decode(dynamic data, {bool allowNull = true}) {
|
||||||
if (data != null) {
|
if (data != null) {
|
||||||
switch (data) {
|
/*print("data.toString()");
|
||||||
case 'Map': return SectionType.Map;
|
print(data.toString());
|
||||||
case 'Slider': return SectionType.Slider;
|
print(data.runtimeType);*/
|
||||||
case 'Video': return SectionType.Video;
|
if(data.runtimeType == String) {
|
||||||
case 'Web': return SectionType.Web;
|
switch (data.toString()) {
|
||||||
case 'Menu': return SectionType.Menu;
|
case r'Map': return SectionType.Map;
|
||||||
case 'Quizz': return SectionType.Quizz;
|
case r'Slider': return SectionType.Slider;
|
||||||
case 'Article': return SectionType.Article;
|
case r'Video': return SectionType.Video;
|
||||||
|
case r'Web': return SectionType.Web;
|
||||||
|
case r'Menu': return SectionType.Menu;
|
||||||
|
case r'Quizz': return SectionType.Quizz;
|
||||||
|
case r'Article': return SectionType.Article;
|
||||||
default:
|
default:
|
||||||
if (!allowNull) {
|
if (!allowNull) {
|
||||||
throw ArgumentError('Unknown enum value to decode: $data');
|
throw ArgumentError('Unknown enum value to decode: $data');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if(data.runtimeType == int) {
|
||||||
|
//print("HELLOWWWWW INT");
|
||||||
|
switch (data) {
|
||||||
|
case 0:
|
||||||
|
print("RETURN MAP");
|
||||||
|
return SectionType.Map;
|
||||||
|
case 1: return SectionType.Slider;
|
||||||
|
case 2: return SectionType.Video;
|
||||||
|
case 3: return SectionType.Web;
|
||||||
|
case 4: return SectionType.Menu;
|
||||||
|
case 5: return SectionType.Quizz;
|
||||||
|
case 6: return SectionType.Article;
|
||||||
|
default:
|
||||||
|
if (!allowNull) {
|
||||||
|
throw ArgumentError('Unknown enum value to decode: $data');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user