From 6cd59dd5bbe4b4ee0aa8453d9c7c20f40ee5555e Mon Sep 17 00:00:00 2001 From: Sebastien Bousquet Date: Tue, 17 Dec 2024 16:24:54 +0100 Subject: [PATCH] feat: remove collection filter - Fix #224 --- package-lock.json | 38 ++++----- .../dashboard-search.component.ts | 2 +- .../dynamic-hub/dynamic-hub.component.html | 17 ---- .../dynamic-hub/dynamic-hub.component.scss | 55 ------------ .../dynamic-hub/dynamic-hub.component.ts | 85 ++++--------------- 5 files changed, 36 insertions(+), 161 deletions(-) diff --git a/package-lock.json b/package-lock.json index 02eae91..eeb3bfe 100644 --- a/package-lock.json +++ b/package-lock.json @@ -25955,9 +25955,9 @@ } }, "arlas-d3": { - "version": "12.0.0-beta.2", - "resolved": "https://registry.npmjs.org/arlas-d3/-/arlas-d3-12.0.0-beta.2.tgz", - "integrity": "sha512-XfNvLaETGnlj0dG/Uxk1W1of2r9u4+vmbxYihC4zAiWBiFNgOct2YAlwtGdz/RPFkkAoki0KTsGLCRoASl+33A==", + "version": "12.0.0-rc.1", + "resolved": "https://registry.npmjs.org/arlas-d3/-/arlas-d3-12.0.0-rc.1.tgz", + "integrity": "sha512-kFDPwJKuZCmcxvqZEcYR9KZpsJRJriVBhdsh3qZJ7ohJr5hc2FF0gUZahRih86L0HWqf+2bjjxojXKYARwXq3w==", "requires": { "@types/d3-array": "^3.0.3", "@types/d3-axis": "^3.0.1", @@ -26025,9 +26025,9 @@ } }, "arlas-web-components": { - "version": "27.0.0-beta.2", - "resolved": "https://registry.npmjs.org/arlas-web-components/-/arlas-web-components-27.0.0-beta.2.tgz", - "integrity": "sha512-vjIpaEECiIrGZ9PiP0lCxNmamcyeNTkYFtB2VGGlSxRTU2wVkLIMwMtsUKWXQyJboJyN4geyvKTLOheW53Rk+w==", + "version": "27.0.0-rc.1", + "resolved": "https://registry.npmjs.org/arlas-web-components/-/arlas-web-components-27.0.0-rc.1.tgz", + "integrity": "sha512-fqklwYiK86hPrVDPeeT/5e3/Mdg9fHVhjM4gumhm4yi6pkAxiJ85eAFwp+GqH+4eVVWY0FIjlHH8+wFgEKke+w==", "requires": { "@mapbox/mapbox-gl-draw": "^1.4.3", "@mapbox/mapbox-gl-draw-static-mode": "^1.0.1", @@ -26046,7 +26046,7 @@ "@turf/transform-rotate": "^6.5.0", "@turf/transform-translate": "^6.5.0", "@types/mapbox-gl": "^1.6.3", - "arlas-d3": "12.0.0-beta.2", + "arlas-d3": "12.0.0-rc.1", "geojson-polygon-self-intersections": "1.2.1", "geojson-validation": "0.2.1", "iv-viewer": "~2.0.1", @@ -26065,9 +26065,9 @@ } }, "arlas-web-contributors": { - "version": "27.0.0-beta.2", - "resolved": "https://registry.npmjs.org/arlas-web-contributors/-/arlas-web-contributors-27.0.0-beta.2.tgz", - "integrity": "sha512-HEPQVM2NMUhBJpVY6PDa1jxt2bCbR6UaeYTa1onbsM+71lLlCMc/5TW1immlnWF7aMuo6mOYMOW3CR7baW+2mA==", + "version": "27.0.0-rc.1", + "resolved": "https://registry.npmjs.org/arlas-web-contributors/-/arlas-web-contributors-27.0.0-rc.1.tgz", + "integrity": "sha512-vLfQOeHicnA3uHsLPh6qqp57kbnwcEHjTq/LmUCauYXUm2Y9UDNHAIg/rafIz6W0d/a77c8Ga0D/1dBlUhd7yQ==", "requires": { "@turf/bbox": "^6.0.1", "@turf/bbox-polygon": "^6.0.1", @@ -26077,7 +26077,7 @@ "@types/file-saver": "^2.0.1", "@types/jsonpath": "^0.2.0", "@types/tinycolor2": "^1.4.0", - "arlas-web-core": "~26.0.0", + "arlas-web-core": "27.0.0-rc.1", "file-saver": "^2.0.2", "jsonpath": "^1.0.0", "moment": "^2.29.4", @@ -26106,18 +26106,18 @@ } }, "arlas-web-core": { - "version": "26.0.0", - "resolved": "https://registry.npmjs.org/arlas-web-core/-/arlas-web-core-26.0.0.tgz", - "integrity": "sha512-ey5Uk5Zyde2mTI/S//cjY3sNCQdX93mQS8F0yWhJc+NUdNNufMUme60l0aADZXV4hSfxLXzxLt2qZ8vDqxqkAQ==", + "version": "27.0.0-rc.1", + "resolved": "https://registry.npmjs.org/arlas-web-core/-/arlas-web-core-27.0.0-rc.1.tgz", + "integrity": "sha512-EroOcVWR956p4RxeLIxFI2A8zRRPP1QydglSCbSJEEmQdpmz3s1zEJmS6EI7pqHLw5Xd3zWp/X+pz00/w40euQ==", "requires": { "arlas-api": "26.0.0", "rxjs": "~7.4.0" } }, "arlas-wui-toolkit": { - "version": "27.0.0-beta.4", - "resolved": "https://registry.npmjs.org/arlas-wui-toolkit/-/arlas-wui-toolkit-27.0.0-beta.4.tgz", - "integrity": "sha512-h78Q4xwM8FZyyX4IfM04R66MdDrldHbB31QX/9GISC1emwtMnBHuWg2kvmOf65MSUG/ubIVyJ9U2z2eC3pzuTg==", + "version": "27.0.0-rc.1", + "resolved": "https://registry.npmjs.org/arlas-wui-toolkit/-/arlas-wui-toolkit-27.0.0-rc.1.tgz", + "integrity": "sha512-TgtJ/MQDbA189qif3h7rGyDv1gcicjyi/pbcqCa+vZHDYReyGYddRK1OfhUBl2R2G/UsHO/qYGAmzex2sbLOhw==", "requires": { "@danielmoncada/angular-datetime-picker": "16.1.0", "@danielmoncada/angular-datetime-picker-moment-adapter": "3.0.1", @@ -26129,8 +26129,8 @@ "arlas-permissions-api": "26.0.0", "arlas-persistence-api": "26.0.0", "arlas-tagger-api": "26.0.0", - "arlas-web-components": "27.0.0-beta.2", - "arlas-web-contributors": "27.0.0-beta.2", + "arlas-web-components": "27.0.0-rc.1", + "arlas-web-contributors": "27.0.0-rc.1", "cli-color": "^1.2.0", "fetch-intercept": "^2.3.1", "hopscotch": "0.3.1", diff --git a/src/app/components/dashboard-search/dashboard-search.component.ts b/src/app/components/dashboard-search/dashboard-search.component.ts index 1f5fda1..14d1922 100644 --- a/src/app/components/dashboard-search/dashboard-search.component.ts +++ b/src/app/components/dashboard-search/dashboard-search.component.ts @@ -48,7 +48,7 @@ export class DashboardSearchComponent implements OnInit, OnDestroy{ public ngOnInit(): void { this._searchSub = this.searchCtrl.valueChanges.pipe( - debounceTime(400), + debounceTime(300), filter(v => v !== null ), map((v: string) => this.search(v)) ).subscribe(); diff --git a/src/app/components/dynamic-hub/dynamic-hub.component.html b/src/app/components/dynamic-hub/dynamic-hub.component.html index f4806af..4fa75dd 100644 --- a/src/app/components/dynamic-hub/dynamic-hub.component.html +++ b/src/app/components/dynamic-hub/dynamic-hub.component.html @@ -38,22 +38,5 @@

{{ 'No dashboard available' | translate}} - - -
-
-

{{'Collections' | translate}}

-
- - - {{col.key | getCollectionDisplayName | translate}} - - -
-
-
-
diff --git a/src/app/components/dynamic-hub/dynamic-hub.component.scss b/src/app/components/dynamic-hub/dynamic-hub.component.scss index fb308b7..d57c176 100644 --- a/src/app/components/dynamic-hub/dynamic-hub.component.scss +++ b/src/app/components/dynamic-hub/dynamic-hub.component.scss @@ -88,61 +88,6 @@ h2 { color: rgba(0, 0, 0, 0.7); } } - .collection { - flex: 1; - - &-wrapper { - height: calc(100vh - ($top-menu-height + $header-height)); - position: sticky; - width: 100%; - top: $header-height; - } - - &--without-edit-header { - top: $header-height - 10px; - } - - .cards { - padding-top: 1px; - height: calc(100% - 90px); // top menu height + dynamic hub header height + collection h2 height - overflow-x: hidden; - overflow-y: auto; - & .scroll-hider { - position: absolute; - background: #F5F5F5; - height: 100%; - top: 0; - right: 0; - width: 6px; - -webkit-transition: all .5s; - transition: all .5s; - opacity: 1; - } - &:hover .scroll-hider { - opacity: 0; - -webkit-transition: all .5s; - transition: all .5s; - } - - .card { - margin: 4px 0px; - border-left: 3px solid; - border-radius: 0px; - padding: 8px 15px; - cursor: pointer; - box-shadow: none; - - .mat-mdc-card-header { - padding: 0; - } - - &.disabled { - border-color: whitesmoke !important; - color: rgba(0, 0, 0, 0.54); - } - } - } - } } } diff --git a/src/app/components/dynamic-hub/dynamic-hub.component.ts b/src/app/components/dynamic-hub/dynamic-hub.component.ts index f388d6b..3e41ac5 100644 --- a/src/app/components/dynamic-hub/dynamic-hub.component.ts +++ b/src/app/components/dynamic-hub/dynamic-hub.component.ts @@ -50,13 +50,10 @@ export class DynamicHubComponent implements OnInit { public canCreateDashboardByOrg: Map; public allowedOrganisations: string[] = []; - public cardCollections = new Map(); public canCreateDashboard = false; public userGroups: string[] = []; - public selectedCollection: string[] = []; - public connected = false; public isAuthentActivated: boolean; public authentMode: 'openid' | 'iam'; @@ -88,7 +85,6 @@ export class DynamicHubComponent implements OnInit { } public ngOnInit(): void { - this.cardCollections.clear(); if (!this.isAuthentActivated) { this.fetchCards(); @@ -131,17 +127,17 @@ export class DynamicHubComponent implements OnInit { this.initSearch(); } - public initSearch(){ + public initSearch() { this.dashboardSearch.valueChanged$ .pipe( - tap(() => this.isLoading = true), + tap(() => this.isLoading = true), debounceTime(500), map((v) => { this.filterDashboard(v); this.isLoading = false; }) ) - .subscribe({error: () => this.isLoading = false}); + .subscribe({ error: () => this.isLoading = false }); } public add(org?: string) { @@ -237,7 +233,7 @@ export class DynamicHubComponent implements OnInit { } public publicAtTheEnd = (a: KeyValue, b: KeyValue): number => { - if (a.key !== this.PUBLIC_ORG && b.key === this.PUBLIC_ORG ) { + if (a.key !== this.PUBLIC_ORG && b.key === this.PUBLIC_ORG) { return -1; } if (a.key === this.PUBLIC_ORG && b.key !== this.PUBLIC_ORG) { @@ -275,7 +271,7 @@ export class DynamicHubComponent implements OnInit { )); this.cardsRef.set(o, cards); i++; - this.applyCollectionFilter(); + this.initFilter(); if (i === this.orgs.length) { this.isLoading = false; } @@ -294,7 +290,7 @@ export class DynamicHubComponent implements OnInit { next: (cards) => { this.storeExternalOrganisationsCards(cards); this.isLoading = false; - this.applyCollectionFilter(); + this.initFilter(); } }); } @@ -320,8 +316,8 @@ export class DynamicHubComponent implements OnInit { if (!publicCards) { publicCards = []; } - this.registerCollection(c); - c.preview$ = this.getPreview$(c.previewId,{}); + + c.preview$ = this.getPreview$(c.previewId, {}); this.addCard(c, publicCards); this.cardsRef.set(publicOrg, publicCards); } @@ -336,11 +332,7 @@ export class DynamicHubComponent implements OnInit { } - private registerCollection(c: Card) { - if (!this.cardCollections.has(c.collection)) { - this.cardCollections.set(c.collection, { color: c.color, selected: true }); - } - } + private enrichCards(cards: Card[], fetchOptions?): Card[] { cards.forEach(c => { @@ -349,7 +341,7 @@ export class DynamicHubComponent implements OnInit { .forEach(a => a.url = this.arlasSettingsService.getArlasWuiUrl()); c.actions.filter(a => a.type === ConfigActionEnum.EDIT) .forEach(a => a.url = this.arlasSettingsService.getArlasBuilderUrl().concat('/load/')); - this.registerCollection(c); + c.preview$ = this.getPreview$(c.previewId, fetchOptions); c.isPublic = c.readers.find(g => g.name === 'public') !== undefined; }); @@ -378,30 +370,21 @@ export class DynamicHubComponent implements OnInit { } } - public applyCollectionFilter() { - if (this.selectedCollection.length > 0) { - const filteredMap = new Map(); - this.cardsRef.forEach((values: Card[], key: string) => { - filteredMap.set(key, values.filter(c => this.selectedCollection.includes(c.collection))); - }); - this.cards = filteredMap; - } else { - this.cards = this.cardsRef; - } - + public initFilter() { + this.cards = this.cardsRef; this.dashboardSearch.buildSearchIndex(this.cards); this.filterDashboard(this.dashboardSearch.currentFilter); } - public filterDashboard(searchValue: string, preserveEmptyCardList = false){ + public filterDashboard(searchValue: string, preserveEmptyCardList = false) { let previous; - if(searchValue){ + if (searchValue) { previous = this.cardsFiltered; this.cardsFiltered = new Map(); this.dashboardSearch .getMatchingSearchIndices() .forEach(searchIndex => { - if(this.cardsFiltered.has(searchIndex.key)){ + if (this.cardsFiltered.has(searchIndex.key)) { this.cardsFiltered.get(searchIndex.key).push(this.cards.get(searchIndex.key)[searchIndex.cardIndex]); } else { this.cardsFiltered.set(searchIndex.key, [this.cards.get(searchIndex.key)[searchIndex.cardIndex]]); @@ -411,49 +394,13 @@ export class DynamicHubComponent implements OnInit { this.cardsFiltered = this.cards; } - if(preserveEmptyCardList && this.cardsFiltered.size === 0){ + if (preserveEmptyCardList && this.cardsFiltered.size === 0) { previous.forEach((v, k) => { this.cardsFiltered.set(k, []); }); } } - public getCheckbox(state: boolean, collectionKey: string) { - if (this.selectedCollection.length === 0) { - this.cardCollections.forEach(v => v.selected = false); - this.selectedCollection.push(collectionKey); - this.cardCollections.get(collectionKey).selected = true; - } else { - if (state) { - this.cardCollections.get(collectionKey).selected = true; - if (!this.selectedCollection.includes(collectionKey)) { - this.selectedCollection.push(collectionKey); - } - if (this.selectedCollection.length === this.cardCollections.size) { - this.selectedCollection = []; - } - } else { - this.selectedCollection = this.selectedCollection.filter(c => c !== collectionKey); - this.cardCollections.get(collectionKey).selected = false; - if (this.selectedCollection.length === 0) { - this.cardCollections.forEach(v => { - v.selected = true; - }); - } - } - } - this.cards = this.cardsRef; - if (this.selectedCollection.length > 0) { - const filteredMap = new Map(); - this.cards.forEach((values: Card[], key: string) => { - filteredMap.set(key, values.filter(c => this.selectedCollection.includes(c.collection))); - }); - this.cards = filteredMap; - } - this.dashboardSearch.buildSearchIndex(this.cards); - this.filterDashboard(this.dashboardSearch.currentFilter, true); - } - public getAllowedOrganisations(): string[] { return [...this.canCreateDashboardByOrg.entries()].filter(m => !!m[1]).map(m => m[0]); }