app.config.ts 5.1 KB

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