geonetwork-ui 2.5.0-dev.d91908296 → 2.5.0-dev.e41adefdb
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.mjs +50 -32
- package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +2 -2
- package/esm2022/libs/feature/dataviz/src/lib/geo-table-view/geo-table-view.component.mjs +18 -16
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +17 -7
- package/esm2022/libs/feature/dataviz/src/lib/table-view/table-view.component.mjs +12 -17
- package/esm2022/libs/feature/editor/src/lib/components/constraint-card/constraint-card.component.mjs +3 -3
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.mjs +2 -1
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.mjs +2 -2
- package/esm2022/libs/feature/editor/src/lib/components/wizard-summarize/wizard-summarize.component.mjs +11 -11
- package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +2 -2
- package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +3 -3
- package/esm2022/libs/feature/record/src/lib/feature-record.module.mjs +6 -7
- package/esm2022/libs/feature/search/src/lib/utils/service/fields.mjs +46 -1
- package/esm2022/libs/feature/search/src/lib/utils/service/fields.service.mjs +3 -2
- package/esm2022/libs/ui/dataviz/src/index.mjs +3 -3
- package/esm2022/libs/ui/dataviz/src/lib/data-table/custom.mat.paginator.intl.mjs +51 -0
- package/esm2022/libs/ui/dataviz/src/lib/data-table/data-table.component.mjs +133 -0
- package/esm2022/libs/ui/dataviz/src/lib/data-table/data-table.data.source.mjs +24 -0
- package/esm2022/libs/ui/dataviz/src/lib/data-table/data-table.fixtures.mjs +82 -0
- package/esm2022/libs/ui/elements/src/index.mjs +2 -1
- package/esm2022/libs/ui/elements/src/lib/application-banner/application-banner.component.mjs +78 -0
- package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +18 -10
- package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +2 -1
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +10 -4
- package/esm2022/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.mjs +7 -2
- package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +14 -12
- package/esm2022/libs/util/data-fetcher/src/index.mjs +3 -1
- package/esm2022/libs/util/data-fetcher/src/lib/model.mjs +7 -3
- package/esm2022/libs/util/data-fetcher/src/lib/readers/wfs.mjs +20 -2
- package/esm2022/libs/util/data-fetcher/src/lib/utils.mjs +3 -3
- package/esm2022/libs/util/shared/src/lib/services/date.service.mjs +41 -0
- package/esm2022/libs/util/shared/src/lib/services/index.mjs +2 -1
- package/esm2022/libs/util/shared/src/lib/utils/temporal-extent-union.mjs +4 -4
- package/esm2022/translations/de.json +9 -3
- package/esm2022/translations/en.json +9 -3
- package/esm2022/translations/es.json +9 -3
- package/esm2022/translations/fr.json +11 -5
- package/esm2022/translations/it.json +9 -3
- package/esm2022/translations/nl.json +9 -3
- package/esm2022/translations/pt.json +9 -3
- package/fesm2022/geonetwork-ui.mjs +867 -432
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.d.ts +3 -1
- package/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/geo-table-view/geo-table-view.component.d.ts +7 -9
- package/libs/feature/dataviz/src/lib/geo-table-view/geo-table-view.component.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
- package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts +3 -6
- package/libs/feature/dataviz/src/lib/table-view/table-view.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/wizard-summarize/wizard-summarize.component.d.ts +3 -3
- package/libs/feature/editor/src/lib/components/wizard-summarize/wizard-summarize.component.d.ts.map +1 -1
- package/libs/feature/record/src/lib/feature-record.module.d.ts +2 -2
- package/libs/feature/record/src/lib/feature-record.module.d.ts.map +1 -1
- package/libs/feature/search/src/lib/utils/service/fields.d.ts +10 -0
- package/libs/feature/search/src/lib/utils/service/fields.d.ts.map +1 -1
- package/libs/feature/search/src/lib/utils/service/fields.service.d.ts.map +1 -1
- package/libs/ui/dataviz/src/index.d.ts +2 -2
- package/libs/ui/dataviz/src/index.d.ts.map +1 -1
- package/libs/ui/dataviz/src/lib/data-table/custom.mat.paginator.intl.d.ts +14 -0
- package/libs/ui/dataviz/src/lib/data-table/custom.mat.paginator.intl.d.ts.map +1 -0
- package/libs/ui/dataviz/src/lib/data-table/data-table.component.d.ts +45 -0
- package/libs/ui/dataviz/src/lib/data-table/data-table.component.d.ts.map +1 -0
- package/libs/ui/dataviz/src/lib/data-table/data-table.data.source.d.ts +12 -0
- package/libs/ui/dataviz/src/lib/data-table/data-table.data.source.d.ts.map +1 -0
- package/libs/ui/dataviz/src/lib/data-table/data-table.fixtures.d.ts +10 -0
- package/libs/ui/dataviz/src/lib/data-table/data-table.fixtures.d.ts.map +1 -0
- package/libs/ui/elements/src/index.d.ts +1 -0
- package/libs/ui/elements/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/application-banner/application-banner.component.d.ts +16 -0
- package/libs/ui/elements/src/lib/application-banner/application-banner.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/metadata-info/metadata-info.component.d.ts +5 -0
- package/libs/ui/elements/src/lib/metadata-info/metadata-info.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.d.ts.map +1 -1
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +3 -2
- package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -1
- package/libs/util/data-fetcher/src/index.d.ts +3 -1
- package/libs/util/data-fetcher/src/index.d.ts.map +1 -1
- package/libs/util/data-fetcher/src/lib/model.d.ts +1 -1
- package/libs/util/data-fetcher/src/lib/model.d.ts.map +1 -1
- package/libs/util/data-fetcher/src/lib/readers/wfs.d.ts.map +1 -1
- package/libs/util/shared/src/lib/services/date.service.d.ts +13 -0
- package/libs/util/shared/src/lib/services/date.service.d.ts.map +1 -0
- package/libs/util/shared/src/lib/services/index.d.ts +1 -0
- package/libs/util/shared/src/lib/services/index.d.ts.map +1 -1
- package/libs/util/shared/src/lib/utils/temporal-extent-union.d.ts +2 -1
- package/libs/util/shared/src/lib/utils/temporal-extent-union.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libs/api/repository/src/lib/gn4/elasticsearch/elasticsearch.service.ts +55 -32
- package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +1 -5
- package/src/libs/feature/dataviz/src/lib/geo-table-view/geo-table-view.component.html +3 -3
- package/src/libs/feature/dataviz/src/lib/geo-table-view/geo-table-view.component.ts +17 -15
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +21 -11
- package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.html +4 -3
- package/src/libs/feature/dataviz/src/lib/table-view/table-view.component.ts +9 -18
- package/src/libs/feature/editor/src/lib/components/constraint-card/constraint-card.component.html +1 -1
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-contacts-for-resource/form-field-contacts-for-resource.component.ts +1 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-rich/form-field-rich.component.ts +1 -1
- package/src/libs/feature/editor/src/lib/components/wizard-summarize/wizard-summarize.component.ts +3 -4
- package/src/libs/feature/editor/src/lib/fields.config.ts +1 -1
- package/src/libs/feature/record/src/lib/data-view/data-view.component.html +1 -1
- package/src/libs/feature/record/src/lib/feature-record.module.ts +6 -4
- package/src/libs/feature/search/src/lib/utils/service/fields.service.ts +2 -0
- package/src/libs/feature/search/src/lib/utils/service/fields.ts +55 -0
- package/src/libs/ui/dataviz/src/index.ts +2 -2
- package/src/libs/ui/dataviz/src/lib/data-table/custom.mat.paginator.intl.ts +52 -0
- package/src/libs/ui/dataviz/src/lib/{table/table.component.css → data-table/data-table.component.css} +4 -0
- package/src/libs/ui/dataviz/src/lib/data-table/data-table.component.html +67 -0
- package/src/libs/ui/dataviz/src/lib/data-table/data-table.component.ts +173 -0
- package/src/libs/ui/dataviz/src/lib/data-table/data-table.data.source.ts +33 -0
- package/src/libs/ui/dataviz/src/lib/data-table/data-table.fixtures.ts +84 -0
- package/src/libs/ui/elements/src/index.ts +1 -0
- package/src/libs/ui/elements/src/lib/application-banner/application-banner.component.css +0 -0
- package/src/libs/ui/elements/src/lib/application-banner/application-banner.component.html +25 -0
- package/src/libs/ui/elements/src/lib/application-banner/application-banner.component.ts +70 -0
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +3 -3
- package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts +12 -2
- package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +2 -0
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +3 -0
- package/src/libs/ui/inputs/src/lib/autocomplete/autocomplete.component.ts +6 -0
- package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +4 -2
- package/src/libs/util/data-fetcher/src/index.ts +3 -0
- package/src/libs/util/data-fetcher/src/lib/model.ts +6 -2
- package/src/libs/util/data-fetcher/src/lib/readers/wfs.ts +23 -1
- package/src/libs/util/data-fetcher/src/lib/utils.ts +2 -2
- package/src/libs/util/shared/src/lib/services/date.service.ts +45 -0
- package/src/libs/util/shared/src/lib/services/index.ts +1 -0
- package/src/libs/util/shared/src/lib/utils/temporal-extent-union.ts +6 -3
- package/translations/de.json +9 -3
- package/translations/en.json +9 -3
- package/translations/es.json +9 -3
- package/translations/fr.json +11 -5
- package/translations/it.json +9 -3
- package/translations/nl.json +9 -3
- package/translations/pt.json +9 -3
- package/translations/sk.json +9 -3
- package/esm2022/libs/ui/dataviz/src/lib/table/table.component.mjs +0 -61
- package/esm2022/libs/ui/dataviz/src/lib/table/table.fixtures.mjs +0 -40
- package/libs/ui/dataviz/src/lib/table/table.component.d.ts +0 -29
- package/libs/ui/dataviz/src/lib/table/table.component.d.ts.map +0 -1
- package/libs/ui/dataviz/src/lib/table/table.fixtures.d.ts +0 -11
- package/libs/ui/dataviz/src/lib/table/table.fixtures.d.ts.map +0 -1
- package/src/libs/ui/dataviz/src/lib/table/table.component.html +0 -40
- package/src/libs/ui/dataviz/src/lib/table/table.component.ts +0 -80
- package/src/libs/ui/dataviz/src/lib/table/table.fixtures.ts +0 -40
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Injectable, Injector } from '@angular/core';
|
|
2
|
-
import { DateRangeSearchField, FullTextSearchField, IsSpatialSearchField, LicenseSearchField, MultilingualSearchField, OrganizationSearchField, OwnerSearchField, SimpleSearchField, TranslatedSearchField, UserSearchField, } from './fields';
|
|
2
|
+
import { AvailableServicesField, DateRangeSearchField, FullTextSearchField, IsSpatialSearchField, LicenseSearchField, MultilingualSearchField, OrganizationSearchField, OwnerSearchField, SimpleSearchField, TranslatedSearchField, UserSearchField, } from './fields';
|
|
3
3
|
import { forkJoin, of } from 'rxjs';
|
|
4
4
|
import { map } from 'rxjs/operators';
|
|
5
5
|
import { marker } from '@biesbjerg/ngx-translate-extract-marker';
|
|
@@ -44,6 +44,7 @@ export class FieldsService {
|
|
|
44
44
|
publisherOrg: new MultilingualSearchField('distributorOrgForResourceObject', this.injector, 'asc', 'key'),
|
|
45
45
|
user: new UserSearchField(this.injector),
|
|
46
46
|
changeDate: new DateRangeSearchField('changeDate', this.injector, 'desc'),
|
|
47
|
+
availableServices: new AvailableServicesField(this.injector),
|
|
47
48
|
};
|
|
48
49
|
}
|
|
49
50
|
getAvailableValues(fieldName) {
|
|
@@ -85,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
85
86
|
providedIn: 'root',
|
|
86
87
|
}]
|
|
87
88
|
}], ctorParameters: () => [{ type: i0.Injector }] });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fields.service.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/search/src/lib/utils/service/fields.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector } from '@angular/core'\nimport {\n  AbstractSearchField,\n  DateRangeSearchField,\n  FieldValue,\n  FullTextSearchField,\n  IsSpatialSearchField,\n  LicenseSearchField,\n  MultilingualSearchField,\n  OrganizationSearchField,\n  OwnerSearchField,\n  SimpleSearchField,\n  TranslatedSearchField,\n  UserSearchField,\n} from './fields'\nimport { forkJoin, Observable, of } from 'rxjs'\nimport { map } from 'rxjs/operators'\nimport { FieldFilters } from '../../../../../../../libs/common/domain/src/lib/model/search'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { DateRange } from '../../../../../../../libs/api/repository/src'\n\n// key is the field name\nexport type FieldValues = Record<string, FieldValue[] | FieldValue | DateRange>\n\nmarker('search.filters.format')\nmarker('search.filters.inspireKeyword')\nmarker('search.filters.keyword')\nmarker('search.filters.isSpatial')\nmarker('search.filters.license')\nmarker('search.filters.publicationYear')\nmarker('search.filters.organization')\nmarker('search.filters.representationType')\nmarker('search.filters.resourceType')\nmarker('search.filters.standard')\nmarker('search.filters.topic')\nmarker('search.filters.contact')\nmarker('search.filters.producerOrg')\nmarker('search.filters.publisherOrg')\nmarker('search.filters.user')\nmarker('search.filters.changeDate')\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class FieldsService {\n  protected fields = {\n    organization: new OrganizationSearchField(this.injector),\n    format: new SimpleSearchField('format', this.injector, 'asc'),\n    resourceType: new TranslatedSearchField(\n      'resourceType',\n      this.injector,\n      'asc'\n    ),\n    representationType: new TranslatedSearchField(\n      'cl_spatialRepresentationType.key',\n      this.injector,\n      'asc'\n    ),\n    publicationYear: new SimpleSearchField(\n      'publicationYearForResource',\n      this.injector,\n      'desc'\n    ),\n    topic: new TranslatedSearchField('cl_topic.key', this.injector, 'asc'),\n    inspireKeyword: new TranslatedSearchField(\n      'th_httpinspireeceuropaeutheme-theme.link',\n      this.injector,\n      'asc'\n    ),\n    keyword: new MultilingualSearchField('tag', this.injector, 'desc', 'count'),\n    documentStandard: new SimpleSearchField(\n      'documentStandard',\n      this.injector,\n      'asc'\n    ),\n    isSpatial: new IsSpatialSearchField(this.injector),\n    q: new FullTextSearchField(),\n    license: new LicenseSearchField(this.injector),\n    owner: new OwnerSearchField(this.injector),\n    producerOrg: new MultilingualSearchField(\n      'originatorOrgForResourceObject',\n      this.injector,\n      'asc',\n      'key'\n    ),\n    publisherOrg: new MultilingualSearchField(\n      'distributorOrgForResourceObject',\n      this.injector,\n      'asc',\n      'key'\n    ),\n    user: new UserSearchField(this.injector),\n    changeDate: new DateRangeSearchField('changeDate', this.injector, 'desc'),\n  } as Record<string, AbstractSearchField>\n\n  get supportedFields() {\n    return Object.keys(this.fields)\n  }\n\n  constructor(protected injector: Injector) {}\n\n  getAvailableValues(fieldName: string) {\n    if (this.supportedFields.indexOf(fieldName) === -1)\n      throw new Error(`Unsupported search field: ${fieldName}`)\n    return this.fields[fieldName].getAvailableValues()\n  }\n\n  private getFiltersForValues(\n    fieldName: string,\n    values: FieldValue[] | DateRange[]\n  ) {\n    return this.fields[fieldName].getFiltersForValues(values)\n  }\n  private getValuesForFilters(fieldName: string, filters: FieldFilters) {\n    return this.fields[fieldName].getValuesForFilter(filters)\n  }\n\n  getFieldType(fieldName: string) {\n    return this.fields[fieldName].getType()\n  }\n\n  buildFiltersFromFieldValues(\n    fieldValues: FieldValues\n  ): Observable<FieldFilters> {\n    const fieldNames = Object.keys(fieldValues).filter((fieldName) =>\n      this.supportedFields.includes(fieldName)\n    )\n    if (!fieldNames.length) return of({})\n    const filtersByField$ = fieldNames.map((fieldName) => {\n      const values = Array.isArray(fieldValues[fieldName])\n        ? fieldValues[fieldName]\n        : [fieldValues[fieldName]]\n      return this.getFiltersForValues(\n        fieldName,\n        values as FieldValue[] | DateRange[]\n      )\n    })\n    return forkJoin(filtersByField$).pipe(\n      map((filters) =>\n        filters.reduce((prev, curr) => ({ ...prev, ...curr }), {})\n      )\n    )\n  }\n\n  readFieldValuesFromFilters(filters: FieldFilters): Observable<FieldValues> {\n    const fieldValues$ = this.supportedFields.map((fieldName) =>\n      this.getValuesForFilters(fieldName, filters).pipe(\n        map((values) => ({ [fieldName]: values }))\n      )\n    )\n    return forkJoin(fieldValues$).pipe(\n      map((fieldValues) =>\n        fieldValues.reduce((prev, curr) => ({ ...prev, ...curr }), {})\n      )\n    )\n  }\n}\n"]}
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fields.service.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/search/src/lib/utils/service/fields.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector } from '@angular/core'\nimport {\n  AbstractSearchField,\n  AvailableServicesField,\n  DateRangeSearchField,\n  FieldValue,\n  FullTextSearchField,\n  IsSpatialSearchField,\n  LicenseSearchField,\n  MultilingualSearchField,\n  OrganizationSearchField,\n  OwnerSearchField,\n  SimpleSearchField,\n  TranslatedSearchField,\n  UserSearchField,\n} from './fields'\nimport { forkJoin, Observable, of } from 'rxjs'\nimport { map } from 'rxjs/operators'\nimport { FieldFilters } from '../../../../../../../libs/common/domain/src/lib/model/search'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { DateRange } from '../../../../../../../libs/api/repository/src'\n\n// key is the field name\nexport type FieldValues = Record<string, FieldValue[] | FieldValue | DateRange>\n\nmarker('search.filters.format')\nmarker('search.filters.inspireKeyword')\nmarker('search.filters.keyword')\nmarker('search.filters.isSpatial')\nmarker('search.filters.license')\nmarker('search.filters.publicationYear')\nmarker('search.filters.organization')\nmarker('search.filters.representationType')\nmarker('search.filters.resourceType')\nmarker('search.filters.standard')\nmarker('search.filters.topic')\nmarker('search.filters.contact')\nmarker('search.filters.producerOrg')\nmarker('search.filters.publisherOrg')\nmarker('search.filters.user')\nmarker('search.filters.changeDate')\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class FieldsService {\n  protected fields = {\n    organization: new OrganizationSearchField(this.injector),\n    format: new SimpleSearchField('format', this.injector, 'asc'),\n    resourceType: new TranslatedSearchField(\n      'resourceType',\n      this.injector,\n      'asc'\n    ),\n    representationType: new TranslatedSearchField(\n      'cl_spatialRepresentationType.key',\n      this.injector,\n      'asc'\n    ),\n    publicationYear: new SimpleSearchField(\n      'publicationYearForResource',\n      this.injector,\n      'desc'\n    ),\n    topic: new TranslatedSearchField('cl_topic.key', this.injector, 'asc'),\n    inspireKeyword: new TranslatedSearchField(\n      'th_httpinspireeceuropaeutheme-theme.link',\n      this.injector,\n      'asc'\n    ),\n    keyword: new MultilingualSearchField('tag', this.injector, 'desc', 'count'),\n    documentStandard: new SimpleSearchField(\n      'documentStandard',\n      this.injector,\n      'asc'\n    ),\n    isSpatial: new IsSpatialSearchField(this.injector),\n    q: new FullTextSearchField(),\n    license: new LicenseSearchField(this.injector),\n    owner: new OwnerSearchField(this.injector),\n    producerOrg: new MultilingualSearchField(\n      'originatorOrgForResourceObject',\n      this.injector,\n      'asc',\n      'key'\n    ),\n    publisherOrg: new MultilingualSearchField(\n      'distributorOrgForResourceObject',\n      this.injector,\n      'asc',\n      'key'\n    ),\n    user: new UserSearchField(this.injector),\n    changeDate: new DateRangeSearchField('changeDate', this.injector, 'desc'),\n    availableServices: new AvailableServicesField(this.injector),\n  } as Record<string, AbstractSearchField>\n\n  get supportedFields() {\n    return Object.keys(this.fields)\n  }\n\n  constructor(protected injector: Injector) {}\n\n  getAvailableValues(fieldName: string) {\n    if (this.supportedFields.indexOf(fieldName) === -1)\n      throw new Error(`Unsupported search field: ${fieldName}`)\n    return this.fields[fieldName].getAvailableValues()\n  }\n\n  private getFiltersForValues(\n    fieldName: string,\n    values: FieldValue[] | DateRange[]\n  ) {\n    return this.fields[fieldName].getFiltersForValues(values)\n  }\n  private getValuesForFilters(fieldName: string, filters: FieldFilters) {\n    return this.fields[fieldName].getValuesForFilter(filters)\n  }\n\n  getFieldType(fieldName: string) {\n    return this.fields[fieldName].getType()\n  }\n\n  buildFiltersFromFieldValues(\n    fieldValues: FieldValues\n  ): Observable<FieldFilters> {\n    const fieldNames = Object.keys(fieldValues).filter((fieldName) =>\n      this.supportedFields.includes(fieldName)\n    )\n    if (!fieldNames.length) return of({})\n    const filtersByField$ = fieldNames.map((fieldName) => {\n      const values = Array.isArray(fieldValues[fieldName])\n        ? fieldValues[fieldName]\n        : [fieldValues[fieldName]]\n      return this.getFiltersForValues(\n        fieldName,\n        values as FieldValue[] | DateRange[]\n      )\n    })\n    return forkJoin(filtersByField$).pipe(\n      map((filters) =>\n        filters.reduce((prev, curr) => ({ ...prev, ...curr }), {})\n      )\n    )\n  }\n\n  readFieldValuesFromFilters(filters: FieldFilters): Observable<FieldValues> {\n    const fieldValues$ = this.supportedFields.map((fieldName) =>\n      this.getValuesForFilters(fieldName, filters).pipe(\n        map((values) => ({ [fieldName]: values }))\n      )\n    )\n    return forkJoin(fieldValues$).pipe(\n      map((fieldValues) =>\n        fieldValues.reduce((prev, curr) => ({ ...prev, ...curr }), {})\n      )\n    )\n  }\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export * from './lib/ui-dataviz.module';
|
|
2
2
|
export * from './lib/chart/chart.component';
|
|
3
|
-
export * from './lib/table/table.component';
|
|
4
|
-
export * from './lib/table/table.fixtures';
|
|
3
|
+
export * from './lib/data-table/data-table.component';
|
|
4
|
+
export * from './lib/data-table/data-table.fixtures';
|
|
5
5
|
export * from './lib/figure/figure.component';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2RhdGF2aXovc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUE7QUFDdkMsY0FBYyw2QkFBNkIsQ0FBQTtBQUMzQyxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsc0NBQXNDLENBQUE7QUFDcEQsY0FBYywrQkFBK0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL3VpLWRhdGF2aXoubW9kdWxlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhcnQvY2hhcnQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS10YWJsZS9kYXRhLXRhYmxlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtdGFibGUvZGF0YS10YWJsZS5maXh0dXJlcydcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZ3VyZS9maWd1cmUuY29tcG9uZW50J1xuIl19
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { MatPaginatorIntl } from '@angular/material/paginator';
|
|
3
|
+
import { TranslateService } from '@ngx-translate/core';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@ngx-translate/core";
|
|
7
|
+
export class CustomMatPaginatorIntl extends MatPaginatorIntl {
|
|
8
|
+
constructor(translate) {
|
|
9
|
+
super();
|
|
10
|
+
this.translate = translate;
|
|
11
|
+
this.changes = new Subject();
|
|
12
|
+
this.setLabels();
|
|
13
|
+
this.translate.onLangChange.subscribe(() => {
|
|
14
|
+
this.setLabels();
|
|
15
|
+
this.changes.next();
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
setLabels() {
|
|
19
|
+
this.itemsPerPageLabel = this.translate.instant('table.paginator.itemsPerPage');
|
|
20
|
+
this.nextPageLabel = this.translate.instant('table.paginator.nextPage');
|
|
21
|
+
this.previousPageLabel = this.translate.instant('table.paginator.previousPage');
|
|
22
|
+
this.firstPageLabel = this.translate.instant('table.paginator.firstPage');
|
|
23
|
+
this.lastPageLabel = this.translate.instant('table.paginator.lastPage');
|
|
24
|
+
this.getRangeLabel = this.getRangeLabelIntl;
|
|
25
|
+
this.changes.next();
|
|
26
|
+
}
|
|
27
|
+
getRangeLabelIntl(page, pageSize, length) {
|
|
28
|
+
if (length === 0 || pageSize === 0) {
|
|
29
|
+
return this.translate.instant('table.paginator.rangeLabel', {
|
|
30
|
+
startIndex: 0,
|
|
31
|
+
endIndex: 0,
|
|
32
|
+
length,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
const startIndex = page * pageSize;
|
|
36
|
+
const endIndex = startIndex < length
|
|
37
|
+
? Math.min(startIndex + pageSize, length)
|
|
38
|
+
: startIndex + pageSize;
|
|
39
|
+
return this.translate.instant('table.paginator.rangeLabel', {
|
|
40
|
+
startIndex: startIndex + 1,
|
|
41
|
+
endIndex,
|
|
42
|
+
length,
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomMatPaginatorIntl, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
46
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomMatPaginatorIntl }); }
|
|
47
|
+
}
|
|
48
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomMatPaginatorIntl, decorators: [{
|
|
49
|
+
type: Injectable
|
|
50
|
+
}], ctorParameters: () => [{ type: i1.TranslateService }] });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLm1hdC5wYWdpbmF0b3IuaW50bC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZGF0YXZpei9zcmMvbGliL2RhdGEtdGFibGUvY3VzdG9tLm1hdC5wYWdpbmF0b3IuaW50bC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQzFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDZCQUE2QixDQUFBO0FBQzlELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBQ3RELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUE7OztBQUc5QixNQUFNLE9BQU8sc0JBQXVCLFNBQVEsZ0JBQWdCO0lBRzFELFlBQW9CLFNBQTJCO1FBQzdDLEtBQUssRUFBRSxDQUFBO1FBRFcsY0FBUyxHQUFULFNBQVMsQ0FBa0I7UUFGdEMsWUFBTyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUE7UUFJcEMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFBO1FBQ2hCLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDekMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFBO1lBQ2hCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUE7UUFDckIsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBRUQsU0FBUztRQUNQLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FDN0MsOEJBQThCLENBQy9CLENBQUE7UUFDRCxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLDBCQUEwQixDQUFDLENBQUE7UUFDdkUsSUFBSSxDQUFDLGlCQUFpQixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUM3Qyw4QkFBOEIsQ0FDL0IsQ0FBQTtRQUNELElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsMkJBQTJCLENBQUMsQ0FBQTtRQUN6RSxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLDBCQUEwQixDQUFDLENBQUE7UUFDdkUsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUE7UUFDM0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQTtJQUNyQixDQUFDO0lBRUQsaUJBQWlCLENBQUMsSUFBWSxFQUFFLFFBQWdCLEVBQUUsTUFBYztRQUM5RCxJQUFJLE1BQU0sS0FBSyxDQUFDLElBQUksUUFBUSxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQ25DLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsNEJBQTRCLEVBQUU7Z0JBQzFELFVBQVUsRUFBRSxDQUFDO2dCQUNiLFFBQVEsRUFBRSxDQUFDO2dCQUNYLE1BQU07YUFDUCxDQUFDLENBQUE7UUFDSixDQUFDO1FBQ0QsTUFBTSxVQUFVLEdBQUcsSUFBSSxHQUFHLFFBQVEsQ0FBQTtRQUNsQyxNQUFNLFFBQVEsR0FDWixVQUFVLEdBQUcsTUFBTTtZQUNqQixDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxVQUFVLEdBQUcsUUFBUSxFQUFFLE1BQU0sQ0FBQztZQUN6QyxDQUFDLENBQUMsVUFBVSxHQUFHLFFBQVEsQ0FBQTtRQUMzQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLDRCQUE0QixFQUFFO1lBQzFELFVBQVUsRUFBRSxVQUFVLEdBQUcsQ0FBQztZQUMxQixRQUFRO1lBQ1IsTUFBTTtTQUNQLENBQUMsQ0FBQTtJQUNKLENBQUM7K0dBNUNVLHNCQUFzQjttSEFBdEIsc0JBQXNCOzs0RkFBdEIsc0JBQXNCO2tCQURsQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBNYXRQYWdpbmF0b3JJbnRsIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcGFnaW5hdG9yJ1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcydcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEN1c3RvbU1hdFBhZ2luYXRvckludGwgZXh0ZW5kcyBNYXRQYWdpbmF0b3JJbnRsIHtcbiAgb3ZlcnJpZGUgY2hhbmdlcyA9IG5ldyBTdWJqZWN0PHZvaWQ+KClcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSkge1xuICAgIHN1cGVyKClcbiAgICB0aGlzLnNldExhYmVscygpXG4gICAgdGhpcy50cmFuc2xhdGUub25MYW5nQ2hhbmdlLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICB0aGlzLnNldExhYmVscygpXG4gICAgICB0aGlzLmNoYW5nZXMubmV4dCgpXG4gICAgfSlcbiAgfVxuXG4gIHNldExhYmVscygpIHtcbiAgICB0aGlzLml0ZW1zUGVyUGFnZUxhYmVsID0gdGhpcy50cmFuc2xhdGUuaW5zdGFudChcbiAgICAgICd0YWJsZS5wYWdpbmF0b3IuaXRlbXNQZXJQYWdlJ1xuICAgIClcbiAgICB0aGlzLm5leHRQYWdlTGFiZWwgPSB0aGlzLnRyYW5zbGF0ZS5pbnN0YW50KCd0YWJsZS5wYWdpbmF0b3IubmV4dFBhZ2UnKVxuICAgIHRoaXMucHJldmlvdXNQYWdlTGFiZWwgPSB0aGlzLnRyYW5zbGF0ZS5pbnN0YW50KFxuICAgICAgJ3RhYmxlLnBhZ2luYXRvci5wcmV2aW91c1BhZ2UnXG4gICAgKVxuICAgIHRoaXMuZmlyc3RQYWdlTGFiZWwgPSB0aGlzLnRyYW5zbGF0ZS5pbnN0YW50KCd0YWJsZS5wYWdpbmF0b3IuZmlyc3RQYWdlJylcbiAgICB0aGlzLmxhc3RQYWdlTGFiZWwgPSB0aGlzLnRyYW5zbGF0ZS5pbnN0YW50KCd0YWJsZS5wYWdpbmF0b3IubGFzdFBhZ2UnKVxuICAgIHRoaXMuZ2V0UmFuZ2VMYWJlbCA9IHRoaXMuZ2V0UmFuZ2VMYWJlbEludGxcbiAgICB0aGlzLmNoYW5nZXMubmV4dCgpXG4gIH1cblxuICBnZXRSYW5nZUxhYmVsSW50bChwYWdlOiBudW1iZXIsIHBhZ2VTaXplOiBudW1iZXIsIGxlbmd0aDogbnVtYmVyKTogc3RyaW5nIHtcbiAgICBpZiAobGVuZ3RoID09PSAwIHx8IHBhZ2VTaXplID09PSAwKSB7XG4gICAgICByZXR1cm4gdGhpcy50cmFuc2xhdGUuaW5zdGFudCgndGFibGUucGFnaW5hdG9yLnJhbmdlTGFiZWwnLCB7XG4gICAgICAgIHN0YXJ0SW5kZXg6IDAsXG4gICAgICAgIGVuZEluZGV4OiAwLFxuICAgICAgICBsZW5ndGgsXG4gICAgICB9KVxuICAgIH1cbiAgICBjb25zdCBzdGFydEluZGV4ID0gcGFnZSAqIHBhZ2VTaXplXG4gICAgY29uc3QgZW5kSW5kZXggPVxuICAgICAgc3RhcnRJbmRleCA8IGxlbmd0aFxuICAgICAgICA/IE1hdGgubWluKHN0YXJ0SW5kZXggKyBwYWdlU2l6ZSwgbGVuZ3RoKVxuICAgICAgICA6IHN0YXJ0SW5kZXggKyBwYWdlU2l6ZVxuICAgIHJldHVybiB0aGlzLnRyYW5zbGF0ZS5pbnN0YW50KCd0YWJsZS5wYWdpbmF0b3IucmFuZ2VMYWJlbCcsIHtcbiAgICAgIHN0YXJ0SW5kZXg6IHN0YXJ0SW5kZXggKyAxLFxuICAgICAgZW5kSW5kZXgsXG4gICAgICBsZW5ndGgsXG4gICAgfSlcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { ScrollingModule } from '@angular/cdk/scrolling';
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
3
|
+
import { MatSort, MatSortModule } from '@angular/material/sort';
|
|
4
|
+
import { MatTableModule } from '@angular/material/table';
|
|
5
|
+
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
6
|
+
import { DataTableDataSource } from './data-table.data.source';
|
|
7
|
+
import { BaseReader, FetchError } from '../../../../../../libs/util/data-fetcher/src';
|
|
8
|
+
import { MatPaginator, MatPaginatorIntl, MatPaginatorModule, } from '@angular/material/paginator';
|
|
9
|
+
import { CustomMatPaginatorIntl } from './custom.mat.paginator.intl';
|
|
10
|
+
import { CommonModule } from '@angular/common';
|
|
11
|
+
import { BehaviorSubject, filter, firstValueFrom } from 'rxjs';
|
|
12
|
+
import { LoadingMaskComponent, PopupAlertComponent, } from '../../../../../../libs/ui/widgets/src';
|
|
13
|
+
import { LetDirective } from '@ngrx/component';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
import * as i1 from "@ngx-translate/core";
|
|
16
|
+
import * as i2 from "@angular/material/table";
|
|
17
|
+
import * as i3 from "@angular/material/sort";
|
|
18
|
+
import * as i4 from "@angular/material/paginator";
|
|
19
|
+
import * as i5 from "@angular/common";
|
|
20
|
+
const rowIdPrefix = 'table-item-';
|
|
21
|
+
export class DataTableComponent {
|
|
22
|
+
set dataset(value) {
|
|
23
|
+
this.properties$.next(null);
|
|
24
|
+
this.dataset_ = value;
|
|
25
|
+
this.dataset_.load();
|
|
26
|
+
this.dataset_.properties.then((properties) => this.properties$.next(properties.map((p) => p.name)));
|
|
27
|
+
this.dataset_.info.then((info) => (this.count = info.itemsCount));
|
|
28
|
+
}
|
|
29
|
+
constructor(eltRef, cdr, translateService) {
|
|
30
|
+
this.eltRef = eltRef;
|
|
31
|
+
this.cdr = cdr;
|
|
32
|
+
this.translateService = translateService;
|
|
33
|
+
this.selected = new EventEmitter();
|
|
34
|
+
this.properties$ = new BehaviorSubject(null);
|
|
35
|
+
this.loading$ = new BehaviorSubject(false);
|
|
36
|
+
this.error = null;
|
|
37
|
+
}
|
|
38
|
+
ngOnInit() {
|
|
39
|
+
this.dataSource = new DataTableDataSource();
|
|
40
|
+
}
|
|
41
|
+
ngAfterViewInit() {
|
|
42
|
+
this.headerHeight =
|
|
43
|
+
this.eltRef.nativeElement.querySelector('thead').offsetHeight;
|
|
44
|
+
this.setPagination();
|
|
45
|
+
this.cdr.detectChanges();
|
|
46
|
+
}
|
|
47
|
+
ngOnChanges() {
|
|
48
|
+
this.setPagination();
|
|
49
|
+
}
|
|
50
|
+
setSort(sort) {
|
|
51
|
+
if (!this.dataset_)
|
|
52
|
+
return;
|
|
53
|
+
if (!sort.active) {
|
|
54
|
+
this.dataset_.orderBy();
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
this.dataset_.orderBy([sort.direction || 'asc', sort.active]);
|
|
58
|
+
}
|
|
59
|
+
this.readData();
|
|
60
|
+
}
|
|
61
|
+
setPagination() {
|
|
62
|
+
if (!this.paginator)
|
|
63
|
+
return;
|
|
64
|
+
if (!this.dataset_)
|
|
65
|
+
return;
|
|
66
|
+
this.dataset_.limit(this.paginator.pageIndex * this.paginator.pageSize, this.paginator.pageSize);
|
|
67
|
+
this.readData();
|
|
68
|
+
}
|
|
69
|
+
async readData() {
|
|
70
|
+
this.loading$.next(true);
|
|
71
|
+
// wait for properties to be read
|
|
72
|
+
const properties = await firstValueFrom(this.properties$.pipe(filter((p) => !!p)));
|
|
73
|
+
const propsWithoutGeom = properties.filter((p) => !p.toLowerCase().startsWith('geom'));
|
|
74
|
+
this.dataset_.select(...propsWithoutGeom);
|
|
75
|
+
try {
|
|
76
|
+
await this.dataSource.showData(this.dataset_.read());
|
|
77
|
+
this.error = null;
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
this.handleError(error);
|
|
81
|
+
}
|
|
82
|
+
this.loading$.next(false);
|
|
83
|
+
}
|
|
84
|
+
scrollToItem(itemId) {
|
|
85
|
+
const row = this.eltRef.nativeElement.querySelector(`#${this.getRowEltId(itemId)}`);
|
|
86
|
+
this.eltRef.nativeElement.scrollTop = row.offsetTop - this.headerHeight;
|
|
87
|
+
}
|
|
88
|
+
getRowEltId(id) {
|
|
89
|
+
return rowIdPrefix + id;
|
|
90
|
+
}
|
|
91
|
+
handleError(error) {
|
|
92
|
+
this.dataSource.clearData();
|
|
93
|
+
if (error instanceof FetchError) {
|
|
94
|
+
this.error = this.translateService.instant(`dataset.error.${error.type}`, {
|
|
95
|
+
info: error.info,
|
|
96
|
+
});
|
|
97
|
+
console.warn(error.message);
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
this.error = this.translateService.instant(error.message);
|
|
101
|
+
console.warn(error.stack || error);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataTableComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
105
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DataTableComponent, isStandalone: true, selector: "gn-ui-data-table", inputs: { dataset: "dataset", activeId: "activeId" }, outputs: { selected: "selected" }, providers: [{ provide: MatPaginatorIntl, useClass: CustomMatPaginatorIntl }], viewQueries: [{ propertyName: "sort", first: true, predicate: MatSort, descendants: true }, { propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-col border border-gray-300 rounded-lg bg-white h-full\">\n <div class=\"flex-1 overflow-y-hidden overflow-x-auto rounded-lg relative\">\n <table\n mat-table\n [dataSource]=\"dataSource\"\n matSort\n (matSortChange)=\"setSort($event)\"\n [matSortDisableClear]=\"true\"\n *ngrxLet=\"properties$ as properties\"\n >\n <ng-container *ngFor=\"let prop of properties\" [matColumnDef]=\"prop\">\n <th\n mat-header-cell\n *matHeaderCellDef\n mat-sort-header\n class=\"text-sm text-black bg-white\"\n >\n {{ prop }}\n </th>\n <td\n mat-cell\n *matCellDef=\"let element\"\n class=\"whitespace-nowrap pr-1 truncate\"\n >\n {{ element[prop] }}\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"properties; sticky: true\"></tr>\n <tr\n [id]=\"getRowEltId(row.id)\"\n mat-row\n *matRowDef=\"let row; columns: properties\"\n (click)=\"selected.emit(row)\"\n [class.active]=\"row.id === activeId\"\n ></tr>\n </table>\n <gn-ui-loading-mask\n *ngIf=\"loading$ | async\"\n class=\"sticky inset-0\"\n [message]=\"'table.loading.data' | translate\"\n ></gn-ui-loading-mask>\n <gn-ui-popup-alert\n *ngIf=\"error\"\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"absolute m-2 inset-0 z-[100]\"\n >\n <span translate>{{ error }}</span>\n </gn-ui-popup-alert>\n </div>\n <div class=\"flex justify-between items-center overflow-hidden\">\n <div class=\"text-gray-900 px-4 py-2 text-sm\">\n <span class=\"count font-extrabold text-primary\">{{ count }}</span\n > <span translate>table.object.count</span>.\n </div>\n\n <mat-paginator\n class=\"my-[-16px]\"\n (page)=\"setPagination()\"\n [length]=\"count\"\n [pageSize]=\"10\"\n [showFirstLastButtons]=\"true\"\n [hidePageSize]=\"true\"\n ></mat-paginator>\n </div>\n</div>\n", styles: ["table{width:100%;background:#fff}th.mat-mdc-header-cell,td.mat-mdc-cell,td.mat-mdc-footer-cell{padding-right:20px}tr.mat-mdc-row,tr.mat-mdc-footer-row{height:36px}tr:hover{background:#f5f5f5}tr.mat-mdc-header-row{height:48px}[mat-header-cell]{color:#0000008a;font-size:12px;font-weight:500}tr{cursor:pointer}.active .mat-mdc-cell{color:var(--color-primary)}.mat-mdc-paginator{background:none}\n"], dependencies: [{ kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i2.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: MatSortModule }, { kind: "directive", type: i3.MatSort, selector: "[matSort]", inputs: ["matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear", "matSortDisabled"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i3.MatSortHeader, selector: "[mat-sort-header]", inputs: ["mat-sort-header", "arrowPosition", "start", "disabled", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i4.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "ngmodule", type: ScrollingModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "directive", type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "component", type: LoadingMaskComponent, selector: "gn-ui-loading-mask", inputs: ["message"] }, { kind: "component", type: PopupAlertComponent, selector: "gn-ui-popup-alert", inputs: ["icon", "type", "position"] }, { kind: "directive", type: LetDirective, selector: "[ngrxLet]", inputs: ["ngrxLet", "ngrxLetSuspenseTpl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
106
|
+
}
|
|
107
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataTableComponent, decorators: [{
|
|
108
|
+
type: Component,
|
|
109
|
+
args: [{ standalone: true, imports: [
|
|
110
|
+
MatTableModule,
|
|
111
|
+
MatSortModule,
|
|
112
|
+
MatPaginatorModule,
|
|
113
|
+
ScrollingModule,
|
|
114
|
+
TranslateModule,
|
|
115
|
+
CommonModule,
|
|
116
|
+
LoadingMaskComponent,
|
|
117
|
+
PopupAlertComponent,
|
|
118
|
+
LetDirective,
|
|
119
|
+
], providers: [{ provide: MatPaginatorIntl, useClass: CustomMatPaginatorIntl }], selector: 'gn-ui-data-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"flex flex-col border border-gray-300 rounded-lg bg-white h-full\">\n <div class=\"flex-1 overflow-y-hidden overflow-x-auto rounded-lg relative\">\n <table\n mat-table\n [dataSource]=\"dataSource\"\n matSort\n (matSortChange)=\"setSort($event)\"\n [matSortDisableClear]=\"true\"\n *ngrxLet=\"properties$ as properties\"\n >\n <ng-container *ngFor=\"let prop of properties\" [matColumnDef]=\"prop\">\n <th\n mat-header-cell\n *matHeaderCellDef\n mat-sort-header\n class=\"text-sm text-black bg-white\"\n >\n {{ prop }}\n </th>\n <td\n mat-cell\n *matCellDef=\"let element\"\n class=\"whitespace-nowrap pr-1 truncate\"\n >\n {{ element[prop] }}\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"properties; sticky: true\"></tr>\n <tr\n [id]=\"getRowEltId(row.id)\"\n mat-row\n *matRowDef=\"let row; columns: properties\"\n (click)=\"selected.emit(row)\"\n [class.active]=\"row.id === activeId\"\n ></tr>\n </table>\n <gn-ui-loading-mask\n *ngIf=\"loading$ | async\"\n class=\"sticky inset-0\"\n [message]=\"'table.loading.data' | translate\"\n ></gn-ui-loading-mask>\n <gn-ui-popup-alert\n *ngIf=\"error\"\n type=\"warning\"\n icon=\"matErrorOutlineOutline\"\n class=\"absolute m-2 inset-0 z-[100]\"\n >\n <span translate>{{ error }}</span>\n </gn-ui-popup-alert>\n </div>\n <div class=\"flex justify-between items-center overflow-hidden\">\n <div class=\"text-gray-900 px-4 py-2 text-sm\">\n <span class=\"count font-extrabold text-primary\">{{ count }}</span\n > <span translate>table.object.count</span>.\n </div>\n\n <mat-paginator\n class=\"my-[-16px]\"\n (page)=\"setPagination()\"\n [length]=\"count\"\n [pageSize]=\"10\"\n [showFirstLastButtons]=\"true\"\n [hidePageSize]=\"true\"\n ></mat-paginator>\n </div>\n</div>\n", styles: ["table{width:100%;background:#fff}th.mat-mdc-header-cell,td.mat-mdc-cell,td.mat-mdc-footer-cell{padding-right:20px}tr.mat-mdc-row,tr.mat-mdc-footer-row{height:36px}tr:hover{background:#f5f5f5}tr.mat-mdc-header-row{height:48px}[mat-header-cell]{color:#0000008a;font-size:12px;font-weight:500}tr{cursor:pointer}.active .mat-mdc-cell{color:var(--color-primary)}.mat-mdc-paginator{background:none}\n"] }]
|
|
120
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.TranslateService }], propDecorators: { dataset: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], activeId: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], selected: [{
|
|
125
|
+
type: Output
|
|
126
|
+
}], sort: [{
|
|
127
|
+
type: ViewChild,
|
|
128
|
+
args: [MatSort]
|
|
129
|
+
}], paginator: [{
|
|
130
|
+
type: ViewChild,
|
|
131
|
+
args: [MatPaginator]
|
|
132
|
+
}] } });
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/dataviz/src/lib/data-table/data-table.component.ts","../../../../../../../../libs/ui/dataviz/src/lib/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ScrollingModule } from '@angular/cdk/scrolling'\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MatSort, MatSortModule } from '@angular/material/sort'\nimport { MatTableModule } from '@angular/material/table'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { DataTableDataSource } from './data-table.data.source'\nimport { BaseReader, FetchError } from '../../../../../../libs/util/data-fetcher/src'\nimport {\n  MatPaginator,\n  MatPaginatorIntl,\n  MatPaginatorModule,\n} from '@angular/material/paginator'\nimport { CustomMatPaginatorIntl } from './custom.mat.paginator.intl'\nimport { CommonModule } from '@angular/common'\nimport { BehaviorSubject, filter, firstValueFrom } from 'rxjs'\nimport {\n  LoadingMaskComponent,\n  PopupAlertComponent,\n} from '../../../../../../libs/ui/widgets/src'\nimport { LetDirective } from '@ngrx/component'\n\nconst rowIdPrefix = 'table-item-'\n\nexport type TableItemId = string | number\ntype TableItemType = string | number | Date\n\nexport interface TableItemModel {\n  id: TableItemId\n  [key: string]: TableItemType\n}\n\n@Component({\n  standalone: true,\n  imports: [\n    MatTableModule,\n    MatSortModule,\n    MatPaginatorModule,\n    ScrollingModule,\n    TranslateModule,\n    CommonModule,\n    LoadingMaskComponent,\n    PopupAlertComponent,\n    LetDirective,\n  ],\n  providers: [{ provide: MatPaginatorIntl, useClass: CustomMatPaginatorIntl }],\n  selector: 'gn-ui-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent implements OnInit, AfterViewInit, OnChanges {\n  @Input() set dataset(value: BaseReader) {\n    this.properties$.next(null)\n    this.dataset_ = value\n    this.dataset_.load()\n    this.dataset_.properties.then((properties) =>\n      this.properties$.next(properties.map((p) => p.name))\n    )\n    this.dataset_.info.then((info) => (this.count = info.itemsCount))\n  }\n  @Input() activeId: TableItemId\n  @Output() selected = new EventEmitter<any>()\n\n  @ViewChild(MatSort) sort: MatSort\n  @ViewChild(MatPaginator) paginator: MatPaginator\n\n  dataset_: BaseReader\n  properties$ = new BehaviorSubject<string[]>(null)\n  dataSource: DataTableDataSource\n  headerHeight: number\n  count: number\n  loading$ = new BehaviorSubject<boolean>(false)\n  error = null\n\n  constructor(\n    private eltRef: ElementRef,\n    private cdr: ChangeDetectorRef,\n    private translateService: TranslateService\n  ) {}\n\n  ngOnInit() {\n    this.dataSource = new DataTableDataSource()\n  }\n\n  ngAfterViewInit() {\n    this.headerHeight =\n      this.eltRef.nativeElement.querySelector('thead').offsetHeight\n    this.setPagination()\n    this.cdr.detectChanges()\n  }\n\n  ngOnChanges() {\n    this.setPagination()\n  }\n\n  setSort(sort: MatSort) {\n    if (!this.dataset_) return\n    if (!sort.active) {\n      this.dataset_.orderBy()\n    } else {\n      this.dataset_.orderBy([sort.direction || 'asc', sort.active])\n    }\n    this.readData()\n  }\n\n  setPagination() {\n    if (!this.paginator) return\n    if (!this.dataset_) return\n    this.dataset_.limit(\n      this.paginator.pageIndex * this.paginator.pageSize,\n      this.paginator.pageSize\n    )\n    this.readData()\n  }\n\n  async readData() {\n    this.loading$.next(true)\n    // wait for properties to be read\n    const properties = await firstValueFrom(\n      this.properties$.pipe(filter((p) => !!p))\n    )\n    const propsWithoutGeom = properties.filter(\n      (p) => !p.toLowerCase().startsWith('geom')\n    )\n    this.dataset_.select(...propsWithoutGeom)\n    try {\n      await this.dataSource.showData(this.dataset_.read())\n      this.error = null\n    } catch (error) {\n      this.handleError(error as FetchError | Error)\n    }\n    this.loading$.next(false)\n  }\n\n  scrollToItem(itemId: TableItemId): void {\n    const row = this.eltRef.nativeElement.querySelector(\n      `#${this.getRowEltId(itemId)}`\n    )\n    this.eltRef.nativeElement.scrollTop = row.offsetTop - this.headerHeight\n  }\n\n  public getRowEltId(id: TableItemId): string {\n    return rowIdPrefix + id\n  }\n\n  handleError(error: FetchError | Error) {\n    this.dataSource.clearData()\n    if (error instanceof FetchError) {\n      this.error = this.translateService.instant(\n        `dataset.error.${error.type}`,\n        {\n          info: error.info,\n        }\n      )\n      console.warn(error.message)\n    } else {\n      this.error = this.translateService.instant(error.message)\n      console.warn(error.stack || error)\n    }\n  }\n}\n","<div class=\"flex flex-col border border-gray-300 rounded-lg bg-white h-full\">\n  <div class=\"flex-1 overflow-y-hidden overflow-x-auto rounded-lg relative\">\n    <table\n      mat-table\n      [dataSource]=\"dataSource\"\n      matSort\n      (matSortChange)=\"setSort($event)\"\n      [matSortDisableClear]=\"true\"\n      *ngrxLet=\"properties$ as properties\"\n    >\n      <ng-container *ngFor=\"let prop of properties\" [matColumnDef]=\"prop\">\n        <th\n          mat-header-cell\n          *matHeaderCellDef\n          mat-sort-header\n          class=\"text-sm text-black bg-white\"\n        >\n          {{ prop }}\n        </th>\n        <td\n          mat-cell\n          *matCellDef=\"let element\"\n          class=\"whitespace-nowrap pr-1 truncate\"\n        >\n          {{ element[prop] }}\n        </td>\n      </ng-container>\n\n      <tr mat-header-row *matHeaderRowDef=\"properties; sticky: true\"></tr>\n      <tr\n        [id]=\"getRowEltId(row.id)\"\n        mat-row\n        *matRowDef=\"let row; columns: properties\"\n        (click)=\"selected.emit(row)\"\n        [class.active]=\"row.id === activeId\"\n      ></tr>\n    </table>\n    <gn-ui-loading-mask\n      *ngIf=\"loading$ | async\"\n      class=\"sticky inset-0\"\n      [message]=\"'table.loading.data' | translate\"\n    ></gn-ui-loading-mask>\n    <gn-ui-popup-alert\n      *ngIf=\"error\"\n      type=\"warning\"\n      icon=\"matErrorOutlineOutline\"\n      class=\"absolute m-2 inset-0 z-[100]\"\n    >\n      <span translate>{{ error }}</span>\n    </gn-ui-popup-alert>\n  </div>\n  <div class=\"flex justify-between items-center overflow-hidden\">\n    <div class=\"text-gray-900 px-4 py-2 text-sm\">\n      <span class=\"count font-extrabold text-primary\">{{ count }}</span\n      >&nbsp;<span translate>table.object.count</span>.\n    </div>\n\n    <mat-paginator\n      class=\"my-[-16px]\"\n      (page)=\"setPagination()\"\n      [length]=\"count\"\n      [pageSize]=\"10\"\n      [showFirstLastButtons]=\"true\"\n      [hidePageSize]=\"true\"\n    ></mat-paginator>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { BehaviorSubject } from 'rxjs';
|
|
2
|
+
import { map } from 'rxjs/operators';
|
|
3
|
+
export class DataTableDataSource {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.dataItems$ = new BehaviorSubject([]);
|
|
6
|
+
}
|
|
7
|
+
connect() {
|
|
8
|
+
return this.dataItems$.asObservable().pipe(map((items) => items.map((item) => ({
|
|
9
|
+
id: item.id,
|
|
10
|
+
...item.properties,
|
|
11
|
+
}))));
|
|
12
|
+
}
|
|
13
|
+
disconnect() {
|
|
14
|
+
this.dataItems$.complete();
|
|
15
|
+
}
|
|
16
|
+
async showData(itemsPromise) {
|
|
17
|
+
const items = await itemsPromise;
|
|
18
|
+
this.dataItems$.next(items);
|
|
19
|
+
}
|
|
20
|
+
clearData() {
|
|
21
|
+
this.dataItems$.next([]);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS5kYXRhLnNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZGF0YXZpei9zcmMvbGliL2RhdGEtdGFibGUvZGF0YS10YWJsZS5kYXRhLnNvdXJjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsZUFBZSxFQUFjLE1BQU0sTUFBTSxDQUFBO0FBRWxELE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUdwQyxNQUFNLE9BQU8sbUJBQW1CO0lBQWhDO1FBQ1UsZUFBVSxHQUFHLElBQUksZUFBZSxDQUFhLEVBQUUsQ0FBQyxDQUFBO0lBeUIxRCxDQUFDO0lBdkJDLE9BQU87UUFDTCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxFQUFFLENBQUMsSUFBSSxDQUN4QyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUNaLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDbkIsRUFBRSxFQUFFLElBQUksQ0FBQyxFQUFFO1lBQ1gsR0FBRyxJQUFJLENBQUMsVUFBVTtTQUNuQixDQUFDLENBQUMsQ0FDSixDQUNGLENBQUE7SUFDSCxDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUE7SUFDNUIsQ0FBQztJQUVELEtBQUssQ0FBQyxRQUFRLENBQUMsWUFBaUM7UUFDOUMsTUFBTSxLQUFLLEdBQUcsTUFBTSxZQUFZLENBQUE7UUFDaEMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDN0IsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQTtJQUMxQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEYXRhU291cmNlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvbGxlY3Rpb25zJ1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcydcbmltcG9ydCB7IERhdGFJdGVtIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91dGlsL2RhdGEtZmV0Y2hlci9zcmMnXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycydcbmltcG9ydCB7IFRhYmxlSXRlbU1vZGVsIH0gZnJvbSAnLi9kYXRhLXRhYmxlLmNvbXBvbmVudCdcblxuZXhwb3J0IGNsYXNzIERhdGFUYWJsZURhdGFTb3VyY2UgaW1wbGVtZW50cyBEYXRhU291cmNlPFRhYmxlSXRlbU1vZGVsPiB7XG4gIHByaXZhdGUgZGF0YUl0ZW1zJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8RGF0YUl0ZW1bXT4oW10pXG5cbiAgY29ubmVjdCgpOiBPYnNlcnZhYmxlPFRhYmxlSXRlbU1vZGVsW10+IHtcbiAgICByZXR1cm4gdGhpcy5kYXRhSXRlbXMkLmFzT2JzZXJ2YWJsZSgpLnBpcGUoXG4gICAgICBtYXAoKGl0ZW1zKSA9PlxuICAgICAgICBpdGVtcy5tYXAoKGl0ZW0pID0+ICh7XG4gICAgICAgICAgaWQ6IGl0ZW0uaWQsXG4gICAgICAgICAgLi4uaXRlbS5wcm9wZXJ0aWVzLFxuICAgICAgICB9KSlcbiAgICAgIClcbiAgICApXG4gIH1cblxuICBkaXNjb25uZWN0KCk6IHZvaWQge1xuICAgIHRoaXMuZGF0YUl0ZW1zJC5jb21wbGV0ZSgpXG4gIH1cblxuICBhc3luYyBzaG93RGF0YShpdGVtc1Byb21pc2U6IFByb21pc2U8RGF0YUl0ZW1bXT4pIHtcbiAgICBjb25zdCBpdGVtcyA9IGF3YWl0IGl0ZW1zUHJvbWlzZVxuICAgIHRoaXMuZGF0YUl0ZW1zJC5uZXh0KGl0ZW1zKVxuICB9XG5cbiAgY2xlYXJEYXRhKCkge1xuICAgIHRoaXMuZGF0YUl0ZW1zJC5uZXh0KFtdKVxuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
export const tableItemsFixture = {
|
|
2
|
+
items: [
|
|
3
|
+
{
|
|
4
|
+
type: 'Feature',
|
|
5
|
+
geometry: null,
|
|
6
|
+
properties: {
|
|
7
|
+
id: '0001',
|
|
8
|
+
firstName: 'John',
|
|
9
|
+
lastName: 'Lennon',
|
|
10
|
+
},
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
type: 'Feature',
|
|
14
|
+
geometry: null,
|
|
15
|
+
properties: {
|
|
16
|
+
id: '0002',
|
|
17
|
+
firstName: 'Ozzy',
|
|
18
|
+
lastName: 'Osbourne',
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
type: 'Feature',
|
|
23
|
+
geometry: null,
|
|
24
|
+
properties: {
|
|
25
|
+
id: '0003',
|
|
26
|
+
firstName: 'Claude',
|
|
27
|
+
lastName: 'François',
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
],
|
|
31
|
+
properties: [
|
|
32
|
+
{ name: 'id', label: 'id', type: 'string' },
|
|
33
|
+
{ name: 'firstName', label: 'Firstname', type: 'string' },
|
|
34
|
+
{ name: 'lastName', label: 'Lastname', type: 'string' },
|
|
35
|
+
],
|
|
36
|
+
};
|
|
37
|
+
export const someHabTableItemFixture = {
|
|
38
|
+
items: [
|
|
39
|
+
{
|
|
40
|
+
type: 'Feature',
|
|
41
|
+
geometry: null,
|
|
42
|
+
properties: {
|
|
43
|
+
id: '1',
|
|
44
|
+
name: 'France',
|
|
45
|
+
pop: 50500000,
|
|
46
|
+
},
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
type: 'Feature',
|
|
50
|
+
geometry: null,
|
|
51
|
+
properties: {
|
|
52
|
+
id: '2',
|
|
53
|
+
name: 'Italy',
|
|
54
|
+
pop: 155878789655,
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
type: 'Feature',
|
|
59
|
+
geometry: null,
|
|
60
|
+
properties: {
|
|
61
|
+
id: '3',
|
|
62
|
+
name: 'UK',
|
|
63
|
+
pop: 31522456,
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
type: 'Feature',
|
|
68
|
+
geometry: null,
|
|
69
|
+
properties: {
|
|
70
|
+
id: '4',
|
|
71
|
+
name: 'US',
|
|
72
|
+
pop: 3215448888,
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
],
|
|
76
|
+
properties: [
|
|
77
|
+
{ name: 'id', label: 'ID', type: 'string' },
|
|
78
|
+
{ name: 'name', label: 'Name', type: 'string' },
|
|
79
|
+
{ name: 'pop', label: 'Population', type: 'number' },
|
|
80
|
+
],
|
|
81
|
+
};
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS5maXh0dXJlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZGF0YXZpei9zcmMvbGliL2RhdGEtdGFibGUvZGF0YS10YWJsZS5maXh0dXJlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRztJQUMvQixLQUFLLEVBQUU7UUFDTDtZQUNFLElBQUksRUFBRSxTQUFTO1lBQ2YsUUFBUSxFQUFFLElBQUk7WUFDZCxVQUFVLEVBQUU7Z0JBQ1YsRUFBRSxFQUFFLE1BQU07Z0JBQ1YsU0FBUyxFQUFFLE1BQU07Z0JBQ2pCLFFBQVEsRUFBRSxRQUFRO2FBQ25CO1NBQ0Y7UUFDRDtZQUNFLElBQUksRUFBRSxTQUFTO1lBQ2YsUUFBUSxFQUFFLElBQUk7WUFDZCxVQUFVLEVBQUU7Z0JBQ1YsRUFBRSxFQUFFLE1BQU07Z0JBQ1YsU0FBUyxFQUFFLE1BQU07Z0JBQ2pCLFFBQVEsRUFBRSxVQUFVO2FBQ3JCO1NBQ0Y7UUFDRDtZQUNFLElBQUksRUFBRSxTQUFTO1lBQ2YsUUFBUSxFQUFFLElBQUk7WUFDZCxVQUFVLEVBQUU7Z0JBQ1YsRUFBRSxFQUFFLE1BQU07Z0JBQ1YsU0FBUyxFQUFFLFFBQVE7Z0JBQ25CLFFBQVEsRUFBRSxVQUFVO2FBQ3JCO1NBQ0Y7S0FDWTtJQUNmLFVBQVUsRUFBRTtRQUNWLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUU7UUFDM0MsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRTtRQUN6RCxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFO0tBQ3RDO0NBQ3BCLENBQUE7QUFFRCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRztJQUNyQyxLQUFLLEVBQUU7UUFDTDtZQUNFLElBQUksRUFBRSxTQUFTO1lBQ2YsUUFBUSxFQUFFLElBQUk7WUFDZCxVQUFVLEVBQUU7Z0JBQ1YsRUFBRSxFQUFFLEdBQUc7Z0JBQ1AsSUFBSSxFQUFFLFFBQVE7Z0JBQ2QsR0FBRyxFQUFFLFFBQVE7YUFDZDtTQUNGO1FBQ0Q7WUFDRSxJQUFJLEVBQUUsU0FBUztZQUNmLFFBQVEsRUFBRSxJQUFJO1lBQ2QsVUFBVSxFQUFFO2dCQUNWLEVBQUUsRUFBRSxHQUFHO2dCQUNQLElBQUksRUFBRSxPQUFPO2dCQUNiLEdBQUcsRUFBRSxZQUFZO2FBQ2xCO1NBQ0Y7UUFDRDtZQUNFLElBQUksRUFBRSxTQUFTO1lBQ2YsUUFBUSxFQUFFLElBQUk7WUFDZCxVQUFVLEVBQUU7Z0JBQ1YsRUFBRSxFQUFFLEdBQUc7Z0JBQ1AsSUFBSSxFQUFFLElBQUk7Z0JBQ1YsR0FBRyxFQUFFLFFBQVE7YUFDZDtTQUNGO1FBQ0Q7WUFDRSxJQUFJLEVBQUUsU0FBUztZQUNmLFFBQVEsRUFBRSxJQUFJO1lBQ2QsVUFBVSxFQUFFO2dCQUNWLEVBQUUsRUFBRSxHQUFHO2dCQUNQLElBQUksRUFBRSxJQUFJO2dCQUNWLEdBQUcsRUFBRSxVQUFVO2FBQ2hCO1NBQ0Y7S0FDWTtJQUNmLFVBQVUsRUFBRTtRQUNWLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUU7UUFDM0MsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRTtRQUMvQyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFO0tBQ25DO0NBQ3BCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEYXRhSXRlbSwgUHJvcGVydHlJbmZvIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91dGlsL2RhdGEtZmV0Y2hlci9zcmMnXG5cbmV4cG9ydCBjb25zdCB0YWJsZUl0ZW1zRml4dHVyZSA9IHtcbiAgaXRlbXM6IFtcbiAgICB7XG4gICAgICB0eXBlOiAnRmVhdHVyZScsXG4gICAgICBnZW9tZXRyeTogbnVsbCxcbiAgICAgIHByb3BlcnRpZXM6IHtcbiAgICAgICAgaWQ6ICcwMDAxJyxcbiAgICAgICAgZmlyc3ROYW1lOiAnSm9obicsXG4gICAgICAgIGxhc3ROYW1lOiAnTGVubm9uJyxcbiAgICAgIH0sXG4gICAgfSxcbiAgICB7XG4gICAgICB0eXBlOiAnRmVhdHVyZScsXG4gICAgICBnZW9tZXRyeTogbnVsbCxcbiAgICAgIHByb3BlcnRpZXM6IHtcbiAgICAgICAgaWQ6ICcwMDAyJyxcbiAgICAgICAgZmlyc3ROYW1lOiAnT3p6eScsXG4gICAgICAgIGxhc3ROYW1lOiAnT3Nib3VybmUnLFxuICAgICAgfSxcbiAgICB9LFxuICAgIHtcbiAgICAgIHR5cGU6ICdGZWF0dXJlJyxcbiAgICAgIGdlb21ldHJ5OiBudWxsLFxuICAgICAgcHJvcGVydGllczoge1xuICAgICAgICBpZDogJzAwMDMnLFxuICAgICAgICBmaXJzdE5hbWU6ICdDbGF1ZGUnLFxuICAgICAgICBsYXN0TmFtZTogJ0ZyYW7Dp29pcycsXG4gICAgICB9LFxuICAgIH0sXG4gIF0gYXMgRGF0YUl0ZW1bXSxcbiAgcHJvcGVydGllczogW1xuICAgIHsgbmFtZTogJ2lkJywgbGFiZWw6ICdpZCcsIHR5cGU6ICdzdHJpbmcnIH0sXG4gICAgeyBuYW1lOiAnZmlyc3ROYW1lJywgbGFiZWw6ICdGaXJzdG5hbWUnLCB0eXBlOiAnc3RyaW5nJyB9LFxuICAgIHsgbmFtZTogJ2xhc3ROYW1lJywgbGFiZWw6ICdMYXN0bmFtZScsIHR5cGU6ICdzdHJpbmcnIH0sXG4gIF0gYXMgUHJvcGVydHlJbmZvW10sXG59XG5cbmV4cG9ydCBjb25zdCBzb21lSGFiVGFibGVJdGVtRml4dHVyZSA9IHtcbiAgaXRlbXM6IFtcbiAgICB7XG4gICAgICB0eXBlOiAnRmVhdHVyZScsXG4gICAgICBnZW9tZXRyeTogbnVsbCxcbiAgICAgIHByb3BlcnRpZXM6IHtcbiAgICAgICAgaWQ6ICcxJyxcbiAgICAgICAgbmFtZTogJ0ZyYW5jZScsXG4gICAgICAgIHBvcDogNTA1MDAwMDAsXG4gICAgICB9LFxuICAgIH0sXG4gICAge1xuICAgICAgdHlwZTogJ0ZlYXR1cmUnLFxuICAgICAgZ2VvbWV0cnk6IG51bGwsXG4gICAgICBwcm9wZXJ0aWVzOiB7XG4gICAgICAgIGlkOiAnMicsXG4gICAgICAgIG5hbWU6ICdJdGFseScsXG4gICAgICAgIHBvcDogMTU1ODc4Nzg5NjU1LFxuICAgICAgfSxcbiAgICB9LFxuICAgIHtcbiAgICAgIHR5cGU6ICdGZWF0dXJlJyxcbiAgICAgIGdlb21ldHJ5OiBudWxsLFxuICAgICAgcHJvcGVydGllczoge1xuICAgICAgICBpZDogJzMnLFxuICAgICAgICBuYW1lOiAnVUsnLFxuICAgICAgICBwb3A6IDMxNTIyNDU2LFxuICAgICAgfSxcbiAgICB9LFxuICAgIHtcbiAgICAgIHR5cGU6ICdGZWF0dXJlJyxcbiAgICAgIGdlb21ldHJ5OiBudWxsLFxuICAgICAgcHJvcGVydGllczoge1xuICAgICAgICBpZDogJzQnLFxuICAgICAgICBuYW1lOiAnVVMnLFxuICAgICAgICBwb3A6IDMyMTU0NDg4ODgsXG4gICAgICB9LFxuICAgIH0sXG4gIF0gYXMgRGF0YUl0ZW1bXSxcbiAgcHJvcGVydGllczogW1xuICAgIHsgbmFtZTogJ2lkJywgbGFiZWw6ICdJRCcsIHR5cGU6ICdzdHJpbmcnIH0sXG4gICAgeyBuYW1lOiAnbmFtZScsIGxhYmVsOiAnTmFtZScsIHR5cGU6ICdzdHJpbmcnIH0sXG4gICAgeyBuYW1lOiAncG9wJywgbGFiZWw6ICdQb3B1bGF0aW9uJywgdHlwZTogJ251bWJlcicgfSxcbiAgXSBhcyBQcm9wZXJ0eUluZm9bXSxcbn1cbiJdfQ==
|
|
@@ -22,4 +22,5 @@ export * from './lib/thumbnail/thumbnail.component';
|
|
|
22
22
|
export * from './lib/ui-elements.module';
|
|
23
23
|
export * from './lib/user-feedback-item/user-feedback-item.component';
|
|
24
24
|
export * from './lib/user-preview/user-preview.component';
|
|
25
|
-
|
|
25
|
+
export * from './lib/application-banner/application-banner.component';
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2VsZW1lbnRzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsK0JBQStCLENBQUE7QUFDN0MsY0FBYyx5REFBeUQsQ0FBQTtBQUN2RSxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMsNkNBQTZDLENBQUE7QUFDM0QsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLDZCQUE2QixDQUFBO0FBQzNDLGNBQWMseUNBQXlDLENBQUE7QUFDdkQsY0FBYyw2REFBNkQsQ0FBQTtBQUMzRSxjQUFjLHFDQUFxQyxDQUFBO0FBQ25ELGNBQWMsaURBQWlELENBQUE7QUFDL0QsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLG1EQUFtRCxDQUFBO0FBQ2pFLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYyw2Q0FBNkMsQ0FBQTtBQUMzRCxjQUFjLDZEQUE2RCxDQUFBO0FBQzNFLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLGlEQUFpRCxDQUFBO0FBQy9ELGNBQWMseURBQXlELENBQUE7QUFDdkUsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLDBCQUEwQixDQUFBO0FBQ3hDLGNBQWMsdURBQXVELENBQUE7QUFDckUsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLHVEQUF1RCxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpLWNhcmQvYXBpLWNhcmQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXZhdGFyL2F2YXRhci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb25maXJtYXRpb24tZGlhbG9nL2NvbmZpcm1hdGlvbi1kaWFsb2cuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29udGVudC1naG9zdC9jb250ZW50LWdob3N0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rvd25sb2FkLWl0ZW0vZG93bmxvYWQtaXRlbS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kb3dubG9hZHMtbGlzdC9kb3dubG9hZHMtbGlzdC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lcnJvci9lcnJvci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbWFnZS1pbnB1dC9pbWFnZS1pbnB1dC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbWFnZS1vdmVybGF5LXByZXZpZXcvaW1hZ2Utb3ZlcmxheS1wcmV2aWV3LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpbmstY2FyZC9saW5rLWNhcmQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWFya2Rvd24tZWRpdG9yL21hcmtkb3duLWVkaXRvci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tYXJrZG93bi1wYXJzZXIvbWFya2Rvd24tcGFyc2VyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL21ldGFkYXRhLWNhdGFsb2cvbWV0YWRhdGEtY2F0YWxvZy5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXRhZGF0YS1jb250YWN0L21ldGFkYXRhLWNvbnRhY3QuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWV0YWRhdGEtaW5mby9tZXRhZGF0YS1pbmZvLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL21ldGFkYXRhLXF1YWxpdHktaXRlbS9tZXRhZGF0YS1xdWFsaXR5LWl0ZW0uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWV0YWRhdGEtcXVhbGl0eS9tZXRhZGF0YS1xdWFsaXR5LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL25vdGlmaWNhdGlvbi9ub3RpZmljYXRpb24uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcmVjb3JkLWFwaS1mb3JtL3JlY29yZC1hcGktZm9ybS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWxhdGVkLXJlY29yZC1jYXJkL3JlbGF0ZWQtcmVjb3JkLWNhcmQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGh1bWJuYWlsL3RodW1ibmFpbC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi91aS1lbGVtZW50cy5tb2R1bGUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi91c2VyLWZlZWRiYWNrLWl0ZW0vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXItcHJldmlldy91c2VyLXByZXZpZXcuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBwbGljYXRpb24tYmFubmVyL2FwcGxpY2F0aW9uLWJhbm5lci5jb21wb25lbnQnXG4iXX0=
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { NgIconComponent, provideIcons, provideNgIconsConfig, } from '@ng-icons/core';
|
|
4
|
+
import { matCloseOutline, matInfoOutline, matWarningAmberOutline, } from '@ng-icons/material-icons/outline';
|
|
5
|
+
import { matWarning } from '@ng-icons/material-icons/baseline';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
export class ApplicationBannerComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.closeEnabled = false;
|
|
11
|
+
this.extraClass = '';
|
|
12
|
+
this.icon = '';
|
|
13
|
+
this.msgClass = '';
|
|
14
|
+
this.bannerOpen = true;
|
|
15
|
+
}
|
|
16
|
+
set type(value) {
|
|
17
|
+
switch (value) {
|
|
18
|
+
case 'primary':
|
|
19
|
+
this.msgClass = 'bg-primary-darkest border-primary text-white';
|
|
20
|
+
this.icon = 'matWarning';
|
|
21
|
+
break;
|
|
22
|
+
case 'light':
|
|
23
|
+
this.msgClass =
|
|
24
|
+
'bg-primary-opacity-10 border-primary-lightest text-black';
|
|
25
|
+
this.icon = 'matInfoOutline';
|
|
26
|
+
break;
|
|
27
|
+
case 'secondary':
|
|
28
|
+
default:
|
|
29
|
+
this.msgClass = 'bg-primary-opacity-50 border-primary-darker text-black';
|
|
30
|
+
this.icon = 'matWarningAmberOutline';
|
|
31
|
+
break;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
get classList() {
|
|
35
|
+
if (this.message.length > 200) {
|
|
36
|
+
return `${this.msgClass} ${this.extraClass} overflow-y-scroll items-start`;
|
|
37
|
+
}
|
|
38
|
+
return `${this.msgClass} ${this.extraClass} items-center`;
|
|
39
|
+
}
|
|
40
|
+
closeMessage() {
|
|
41
|
+
this.bannerOpen = false;
|
|
42
|
+
}
|
|
43
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApplicationBannerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ApplicationBannerComponent, isStandalone: true, selector: "gn-ui-application-banner", inputs: { message: "message", title: "title", closeEnabled: "closeEnabled", extraClass: "extraClass", icon: "icon", type: "type" }, providers: [
|
|
45
|
+
provideIcons({
|
|
46
|
+
matWarningAmberOutline,
|
|
47
|
+
matInfoOutline,
|
|
48
|
+
matCloseOutline,
|
|
49
|
+
matWarning,
|
|
50
|
+
}),
|
|
51
|
+
provideNgIconsConfig({ size: '1.5em' }),
|
|
52
|
+
], ngImport: i0, template: "<div\n *ngIf=\"message && bannerOpen\"\n class=\"absolute top-0 text-wrap bg-white mt-4 max-h-24\"\n>\n <div\n class=\"flex flex-row py-2.5 px-5 gap-5 justify-start border max-h-20\"\n [ngClass]=\"classList\"\n >\n <div [ngClass]=\"{ 'pt-5': message.length > 200 }\">\n <ng-icon [name]=\"icon\"></ng-icon>\n </div>\n <div class=\"flex flex-col justify-start gap-2.5\">\n <span *ngIf=\"title\" class=\"font-bold\">{{ title }}</span>\n <span class=\"font-medium max-w-2xl\" [innerHTML]=\"message\"></span>\n </div>\n <button\n *ngIf=\"closeEnabled\"\n class=\"self-start\"\n type=\"button\"\n (click)=\"closeMessage()\"\n >\n <ng-icon name=\"matCloseOutline\"> </ng-icon>\n </button>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
53
|
+
}
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApplicationBannerComponent, decorators: [{
|
|
55
|
+
type: Component,
|
|
56
|
+
args: [{ selector: 'gn-ui-application-banner', standalone: true, imports: [CommonModule, NgIconComponent], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
57
|
+
provideIcons({
|
|
58
|
+
matWarningAmberOutline,
|
|
59
|
+
matInfoOutline,
|
|
60
|
+
matCloseOutline,
|
|
61
|
+
matWarning,
|
|
62
|
+
}),
|
|
63
|
+
provideNgIconsConfig({ size: '1.5em' }),
|
|
64
|
+
], template: "<div\n *ngIf=\"message && bannerOpen\"\n class=\"absolute top-0 text-wrap bg-white mt-4 max-h-24\"\n>\n <div\n class=\"flex flex-row py-2.5 px-5 gap-5 justify-start border max-h-20\"\n [ngClass]=\"classList\"\n >\n <div [ngClass]=\"{ 'pt-5': message.length > 200 }\">\n <ng-icon [name]=\"icon\"></ng-icon>\n </div>\n <div class=\"flex flex-col justify-start gap-2.5\">\n <span *ngIf=\"title\" class=\"font-bold\">{{ title }}</span>\n <span class=\"font-medium max-w-2xl\" [innerHTML]=\"message\"></span>\n </div>\n <button\n *ngIf=\"closeEnabled\"\n class=\"self-start\"\n type=\"button\"\n (click)=\"closeMessage()\"\n >\n <ng-icon name=\"matCloseOutline\"> </ng-icon>\n </button>\n </div>\n</div>\n" }]
|
|
65
|
+
}], propDecorators: { message: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], title: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}], closeEnabled: [{
|
|
70
|
+
type: Input
|
|
71
|
+
}], extraClass: [{
|
|
72
|
+
type: Input
|
|
73
|
+
}], icon: [{
|
|
74
|
+
type: Input
|
|
75
|
+
}], type: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}] } });
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi9hcHBsaWNhdGlvbi1iYW5uZXIvYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi9hcHBsaWNhdGlvbi1iYW5uZXIvYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3pFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQ0wsZUFBZSxFQUNmLFlBQVksRUFDWixvQkFBb0IsR0FDckIsTUFBTSxnQkFBZ0IsQ0FBQTtBQUN2QixPQUFPLEVBQ0wsZUFBZSxFQUNmLGNBQWMsRUFDZCxzQkFBc0IsR0FDdkIsTUFBTSxrQ0FBa0MsQ0FBQTtBQUN6QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sbUNBQW1DLENBQUE7OztBQW1COUQsTUFBTSxPQUFPLDBCQUEwQjtJQWpCdkM7UUFvQlcsaUJBQVksR0FBRyxLQUFLLENBQUE7UUFDcEIsZUFBVSxHQUFHLEVBQUUsQ0FBQTtRQUNmLFNBQUksR0FBRyxFQUFFLENBQUE7UUFDbEIsYUFBUSxHQUFHLEVBQUUsQ0FBQTtRQUNiLGVBQVUsR0FBRyxJQUFJLENBQUE7S0ErQmxCO0lBN0JDLElBQWEsSUFBSSxDQUFDLEtBQXdDO1FBQ3hELFFBQVEsS0FBSyxFQUFFLENBQUM7WUFDZCxLQUFLLFNBQVM7Z0JBQ1osSUFBSSxDQUFDLFFBQVEsR0FBRyw4Q0FBOEMsQ0FBQTtnQkFDOUQsSUFBSSxDQUFDLElBQUksR0FBRyxZQUFZLENBQUE7Z0JBQ3hCLE1BQUs7WUFDUCxLQUFLLE9BQU87Z0JBQ1YsSUFBSSxDQUFDLFFBQVE7b0JBQ1gsMERBQTBELENBQUE7Z0JBQzVELElBQUksQ0FBQyxJQUFJLEdBQUcsZ0JBQWdCLENBQUE7Z0JBQzVCLE1BQUs7WUFDUCxLQUFLLFdBQVcsQ0FBQztZQUNqQjtnQkFDRSxJQUFJLENBQUMsUUFBUSxHQUFHLHdEQUF3RCxDQUFBO2dCQUN4RSxJQUFJLENBQUMsSUFBSSxHQUFHLHdCQUF3QixDQUFBO2dCQUNwQyxNQUFLO1FBQ1QsQ0FBQztJQUNILENBQUM7SUFFRCxJQUFJLFNBQVM7UUFDWCxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxHQUFHLEdBQUcsRUFBRSxDQUFDO1lBQzlCLE9BQU8sR0FBRyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxVQUFVLGdDQUFnQyxDQUFBO1FBQzVFLENBQUM7UUFDRCxPQUFPLEdBQUcsSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsVUFBVSxlQUFlLENBQUE7SUFDM0QsQ0FBQztJQUVELFlBQVk7UUFDVixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQTtJQUN6QixDQUFDOytHQXJDVSwwQkFBMEI7bUdBQTFCLDBCQUEwQiwyTUFWMUI7WUFDVCxZQUFZLENBQUM7Z0JBQ1gsc0JBQXNCO2dCQUN0QixjQUFjO2dCQUNkLGVBQWU7Z0JBQ2YsVUFBVTthQUNYLENBQUM7WUFDRixvQkFBb0IsQ0FBQyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQztTQUN4QywwQkM3Qkgsc3dCQXlCQSx5RERSWSxZQUFZLGlPQUFFLGVBQWU7OzRGQWM1QiwwQkFBMEI7a0JBakJ0QyxTQUFTOytCQUNFLDBCQUEwQixjQUN4QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDLG1CQUN2Qix1QkFBdUIsQ0FBQyxNQUFNLGFBR3BDO3dCQUNULFlBQVksQ0FBQzs0QkFDWCxzQkFBc0I7NEJBQ3RCLGNBQWM7NEJBQ2QsZUFBZTs0QkFDZixVQUFVO3lCQUNYLENBQUM7d0JBQ0Ysb0JBQW9CLENBQUMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLENBQUM7cUJBQ3hDOzhCQUdRLE9BQU87c0JBQWYsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFJTyxJQUFJO3NCQUFoQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHtcbiAgTmdJY29uQ29tcG9uZW50LFxuICBwcm92aWRlSWNvbnMsXG4gIHByb3ZpZGVOZ0ljb25zQ29uZmlnLFxufSBmcm9tICdAbmctaWNvbnMvY29yZSdcbmltcG9ydCB7XG4gIG1hdENsb3NlT3V0bGluZSxcbiAgbWF0SW5mb091dGxpbmUsXG4gIG1hdFdhcm5pbmdBbWJlck91dGxpbmUsXG59IGZyb20gJ0BuZy1pY29ucy9tYXRlcmlhbC1pY29ucy9vdXRsaW5lJ1xuaW1wb3J0IHsgbWF0V2FybmluZyB9IGZyb20gJ0BuZy1pY29ucy9tYXRlcmlhbC1pY29ucy9iYXNlbGluZSdcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZ24tdWktYXBwbGljYXRpb24tYmFubmVyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTmdJY29uQ29tcG9uZW50XSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHRlbXBsYXRlVXJsOiAnLi9hcHBsaWNhdGlvbi1iYW5uZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudC5jc3MnLFxuICBwcm92aWRlcnM6IFtcbiAgICBwcm92aWRlSWNvbnMoe1xuICAgICAgbWF0V2FybmluZ0FtYmVyT3V0bGluZSxcbiAgICAgIG1hdEluZm9PdXRsaW5lLFxuICAgICAgbWF0Q2xvc2VPdXRsaW5lLFxuICAgICAgbWF0V2FybmluZyxcbiAgICB9KSxcbiAgICBwcm92aWRlTmdJY29uc0NvbmZpZyh7IHNpemU6ICcxLjVlbScgfSksXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEFwcGxpY2F0aW9uQmFubmVyQ29tcG9uZW50IHtcbiAgQElucHV0KCkgbWVzc2FnZTogc3RyaW5nXG4gIEBJbnB1dCgpIHRpdGxlOiBzdHJpbmdcbiAgQElucHV0KCkgY2xvc2VFbmFibGVkID0gZmFsc2VcbiAgQElucHV0KCkgZXh0cmFDbGFzcyA9ICcnXG4gIEBJbnB1dCgpIGljb24gPSAnJ1xuICBtc2dDbGFzcyA9ICcnXG4gIGJhbm5lck9wZW4gPSB0cnVlXG5cbiAgQElucHV0KCkgc2V0IHR5cGUodmFsdWU6ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknIHwgJ2xpZ2h0Jykge1xuICAgIHN3aXRjaCAodmFsdWUpIHtcbiAgICAgIGNhc2UgJ3ByaW1hcnknOlxuICAgICAgICB0aGlzLm1zZ0NsYXNzID0gJ2JnLXByaW1hcnktZGFya2VzdCBib3JkZXItcHJpbWFyeSB0ZXh0LXdoaXRlJ1xuICAgICAgICB0aGlzLmljb24gPSAnbWF0V2FybmluZydcbiAgICAgICAgYnJlYWtcbiAgICAgIGNhc2UgJ2xpZ2h0JzpcbiAgICAgICAgdGhpcy5tc2dDbGFzcyA9XG4gICAgICAgICAgJ2JnLXByaW1hcnktb3BhY2l0eS0xMCBib3JkZXItcHJpbWFyeS1saWdodGVzdCB0ZXh0LWJsYWNrJ1xuICAgICAgICB0aGlzLmljb24gPSAnbWF0SW5mb091dGxpbmUnXG4gICAgICAgIGJyZWFrXG4gICAgICBjYXNlICdzZWNvbmRhcnknOlxuICAgICAgZGVmYXVsdDpcbiAgICAgICAgdGhpcy5tc2dDbGFzcyA9ICdiZy1wcmltYXJ5LW9wYWNpdHktNTAgYm9yZGVyLXByaW1hcnktZGFya2VyIHRleHQtYmxhY2snXG4gICAgICAgIHRoaXMuaWNvbiA9ICdtYXRXYXJuaW5nQW1iZXJPdXRsaW5lJ1xuICAgICAgICBicmVha1xuICAgIH1cbiAgfVxuXG4gIGdldCBjbGFzc0xpc3QoKSB7XG4gICAgaWYgKHRoaXMubWVzc2FnZS5sZW5ndGggPiAyMDApIHtcbiAgICAgIHJldHVybiBgJHt0aGlzLm1zZ0NsYXNzfSAke3RoaXMuZXh0cmFDbGFzc30gb3ZlcmZsb3cteS1zY3JvbGwgaXRlbXMtc3RhcnRgXG4gICAgfVxuICAgIHJldHVybiBgJHt0aGlzLm1zZ0NsYXNzfSAke3RoaXMuZXh0cmFDbGFzc30gaXRlbXMtY2VudGVyYFxuICB9XG5cbiAgY2xvc2VNZXNzYWdlKCkge1xuICAgIHRoaXMuYmFubmVyT3BlbiA9IGZhbHNlXG4gIH1cbn1cbiIsIjxkaXZcbiAgKm5nSWY9XCJtZXNzYWdlICYmIGJhbm5lck9wZW5cIlxuICBjbGFzcz1cImFic29sdXRlIHRvcC0wIHRleHQtd3JhcCBiZy13aGl0ZSBtdC00IG1heC1oLTI0XCJcbj5cbiAgPGRpdlxuICAgIGNsYXNzPVwiZmxleCBmbGV4LXJvdyBweS0yLjUgcHgtNSBnYXAtNSBqdXN0aWZ5LXN0YXJ0IGJvcmRlciBtYXgtaC0yMFwiXG4gICAgW25nQ2xhc3NdPVwiY2xhc3NMaXN0XCJcbiAgPlxuICAgIDxkaXYgW25nQ2xhc3NdPVwieyAncHQtNSc6IG1lc3NhZ2UubGVuZ3RoID4gMjAwIH1cIj5cbiAgICAgIDxuZy1pY29uIFtuYW1lXT1cImljb25cIj48L25nLWljb24+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1jb2wganVzdGlmeS1zdGFydCBnYXAtMi41XCI+XG4gICAgICA8c3BhbiAqbmdJZj1cInRpdGxlXCIgY2xhc3M9XCJmb250LWJvbGRcIj57eyB0aXRsZSB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuIGNsYXNzPVwiZm9udC1tZWRpdW0gbWF4LXctMnhsXCIgW2lubmVySFRNTF09XCJtZXNzYWdlXCI+PC9zcGFuPlxuICAgIDwvZGl2PlxuICAgIDxidXR0b25cbiAgICAgICpuZ0lmPVwiY2xvc2VFbmFibGVkXCJcbiAgICAgIGNsYXNzPVwic2VsZi1zdGFydFwiXG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIChjbGljayk9XCJjbG9zZU1lc3NhZ2UoKVwiXG4gICAgPlxuICAgICAgPG5nLWljb24gbmFtZT1cIm1hdENsb3NlT3V0bGluZVwiPiA8L25nLWljb24+XG4gICAgPC9idXR0b24+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|