app.config.ts 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. import { HttpClient } from '@angular/common/http';
  2. import { Injectable } from '@angular/core';
  3. import { TranslateService } from '@ngx-translate/core';
  4. import { forkJoin } from 'rxjs';
  5. import { map } from 'rxjs/operators';
  6. import { EntitiesSelectItemGroup } from './components/entities-select/entities-select.component';
  7. import { ViewMode, ViewModeId } from './models/evt-models';
  8. import { Attributes, EditorialConventionLayout } from './models/evt-models';
  9. @Injectable()
  10. export class AppConfig {
  11. static evtSettings: EVTConfig;
  12. private readonly uiConfigUrl = 'assets/config/ui_config.json';
  13. private readonly fileConfigUrl = 'assets/config/file_config.json';
  14. private readonly editionConfigUrl = 'assets/config/edition_config.json';
  15. private readonly editorialConventionsConfigUrl = 'assets/config/editorial_conventions_config.json';
  16. constructor(
  17. public translate: TranslateService,
  18. private http: HttpClient,
  19. ) { }
  20. load() {
  21. return new Promise<void>((resolve) => {
  22. forkJoin([
  23. this.http.get<UiConfig>(this.uiConfigUrl),
  24. this.http.get<EditionConfig>(this.editionConfigUrl),
  25. this.http.get<FileConfig>(this.fileConfigUrl),
  26. this.http.get<EditorialConventionsConfig>(this.editorialConventionsConfigUrl),
  27. ]).pipe(
  28. map(([ui, edition, files, editorialConventions]) => {
  29. console.log(ui, edition, files);
  30. // Handle default values => TODO: Decide how to handle defaults!!
  31. if (ui.defaultLocalization) {
  32. if (ui.availableLanguages.find((l) => l.code === ui.defaultLocalization && l.enabled)) {
  33. this.translate.use(ui.defaultLocalization);
  34. } else {
  35. const firstAvailableLang = ui.availableLanguages.find((l) => l.enabled);
  36. if (firstAvailableLang) {
  37. this.translate.use(firstAvailableLang.code);
  38. }
  39. }
  40. }
  41. return { ui, edition, files, editorialConventions };
  42. }),
  43. ).subscribe(evtConfig => {
  44. AppConfig.evtSettings = evtConfig;
  45. console.log('evtConfig', evtConfig);
  46. resolve();
  47. });
  48. });
  49. }
  50. }
  51. export interface EVTConfig {
  52. ui: UiConfig;
  53. edition: EditionConfig;
  54. files: FileConfig;
  55. editorialConventions: EditorialConventionsConfig;
  56. }
  57. export interface UiConfig {
  58. localization: boolean;
  59. defaultLocalization: string;
  60. availableLanguages: Array<{
  61. code: string;
  62. label: string;
  63. enabled: boolean;
  64. }>;
  65. enableNavBar: boolean;
  66. initNavBarOpened: boolean;
  67. thumbnailsButton: boolean;
  68. viscollButton: boolean;
  69. }
  70. export interface EditionConfig {
  71. editionTitle: string;
  72. badge: string;
  73. editionHome: string;
  74. showLists: boolean;
  75. availableEditionLevels: EditionLevel[];
  76. namedEntitiesLists: Partial<{
  77. persons: NamedEntitiesListsConfig;
  78. places: NamedEntitiesListsConfig;
  79. organizations: NamedEntitiesListsConfig;
  80. relations: NamedEntitiesListsConfig;
  81. events: NamedEntitiesListsConfig;
  82. }>;
  83. // add by FS
  84. lemmatizedEntitiesLists: Partial<{
  85. lemmas: LemmatizedEntitiesListsConfig;
  86. relations: LemmatizedEntitiesListsConfig;
  87. }>;
  88. entitiesSelectItems: EntitiesSelectItemGroup[];
  89. notSignificantVariants: string[];
  90. lemNotSignificantVariants: string[];
  91. defaultEdition: EditionLevelType;
  92. defaultViewMode: ViewModeId;
  93. availableViewModes: ViewMode[];
  94. proseVersesToggler: boolean;
  95. defaultTextFlow: TextFlow;
  96. verseNumberPrinter: number;
  97. }
  98. export type EditionImagesSources = 'manifest' | 'graphics';
  99. export interface FileConfig {
  100. editionUrls: string[];
  101. editionImagesSource: {
  102. [T in EditionImagesSources]: EditionImagesConfig;
  103. };
  104. logoUrl?: string;
  105. imagesFolderUrl?: string;
  106. }
  107. export interface EditionImagesConfig {
  108. value: string;
  109. enabled: boolean;
  110. }
  111. export interface NamedEntitiesListsConfig {
  112. defaultLabel: string;
  113. enabled: boolean;
  114. }
  115. // add by FS
  116. export interface LemmatizedEntitiesListsConfig {
  117. defaultLabel: string;
  118. enabled: boolean;
  119. }
  120. export type EditionLevelType = 'diplomatic' | 'interpretative' | 'critical';
  121. export interface EditionLevel {
  122. id: EditionLevelType;
  123. label: string;
  124. title?: string;
  125. disabled?: boolean;
  126. }
  127. export interface EditorialConventionsConfig {
  128. [key: string]: CustomEditorialConvention;
  129. }
  130. export interface CustomEditorialConvention {
  131. layouts: { // indicate the output style to be assigned for the indicated encoding for each edition level
  132. [key in EditionLevelType]: EditorialConventionLayout;
  133. };
  134. markup: { // Identifies the element depending on its encoding
  135. element: string;
  136. attributes: Attributes;
  137. };
  138. }
  139. export type TextFlow = 'prose' | 'verses';