diff --git a/projects/ng-core-tester/src/app/app.component.html b/projects/ng-core-tester/src/app/app.component.html index 00da2034..8b6617f3 100644 --- a/projects/ng-core-tester/src/app/app.component.html +++ b/projects/ng-core-tester/src/app/app.component.html @@ -23,7 +23,7 @@
- +
diff --git a/projects/ng-core-tester/src/app/routes/documents-route.ts b/projects/ng-core-tester/src/app/routes/documents-route.ts index 6e6b37ad..9245ff62 100644 --- a/projects/ng-core-tester/src/app/routes/documents-route.ts +++ b/projects/ng-core-tester/src/app/routes/documents-route.ts @@ -70,12 +70,17 @@ export class DocumentsRoute implements RouteInterface { aggregationsOrder: [ 'document_type', 'author', + 'year', + 'acquisition', 'library', 'organisation', 'language', 'subject', 'status' ], + listHeaders: { + Accept: 'application/rero+json, application/json' + }, aggregationsExpand: ['document_type'], aggregationsBucketSize: 5, preprocessRecordEditor: (record: any): any => { diff --git a/projects/ng-core-tester/src/app/search-bar/search-bar.component.html b/projects/ng-core-tester/src/app/search-bar/search-bar.component.html index 58b471e4..5f84f097 100644 --- a/projects/ng-core-tester/src/app/search-bar/search-bar.component.html +++ b/projects/ng-core-tester/src/app/search-bar/search-bar.component.html @@ -18,5 +18,7 @@ [recordTypes]="recordTypes" scrollHeight="400px" (onSelect)="onSelect($event)" + (onSearch)="onSearch($event)" + inputStyleClass="text-lg" [value]="value" /> diff --git a/projects/ng-core-tester/src/app/search-bar/search-bar.component.ts b/projects/ng-core-tester/src/app/search-bar/search-bar.component.ts index 04989f09..75b12842 100644 --- a/projects/ng-core-tester/src/app/search-bar/search-bar.component.ts +++ b/projects/ng-core-tester/src/app/search-bar/search-bar.component.ts @@ -44,20 +44,27 @@ export class SearchBarComponent implements OnInit { this.recordTypes = [ { index: 'documents', - field: 'title', + field: 'autocomplete_title', groupLabel: this.translateService.instant('Documents'), processSuggestions: (data: any, query: string) => this.processDocuments(data, query), preFilters: this.viewcode() ? { view: this.viewcode() } : {} }, { - index: 'organisations', - field: 'name', - groupLabel: this.translateService.instant('Organisations'), - processSuggestions: (data: any) => this.processOrganisations(data), + index: 'entities', + field: 'autocomplete_name', + groupLabel: this.translateService.instant('Entities'), + processSuggestions: (data: any) => this.processEntities(data), preFilters: this.viewcode() ? { view: this.viewcode() } : {} } ]; } + onSearch(query) { + this.router.navigate(['/record', 'search', 'documents'], { + queryParams: { + q: query + } + }); + } onSelect(event: IAutoComplete) { const label = event.originalLabel ? event.originalLabel : event.label; @@ -73,11 +80,11 @@ export class SearchBarComponent implements OnInit { }); this.router.navigate(['/record', 'search', 'documents', 'detail', event.value]); break; - case 'organisations': + case 'entities': this.messageService.add({ severity: 'success', - summary: 'ORGANISATIONS', - detail: 'navigate to organisation: ' + event.value, + summary: 'ENTITIES', + detail: 'navigate to entity: ' + event.value, life: CONFIG.MESSAGE_LIFE }); break; @@ -100,14 +107,14 @@ export class SearchBarComponent implements OnInit { return values; } - private processOrganisations(data: Record): any { + private processEntities(data: Record): any { const values: IAutoComplete[] = []; data.hits.hits.map((hit: any) => { values.push({ - iconClass: 'fa fa-industry', + iconClass: 'fa fa-user', id: hit.metadata.pid, - index: 'organisations', - label: hit.metadata.name, + index: 'entities', + label: hit.metadata.authorized_access_point_en, value: hit.metadata.pid, }); }); diff --git a/projects/rero/ng-core/assets/scss/_editor.scss b/projects/rero/ng-core/assets/scss/_editor.scss index e1519595..57a4c2e7 100644 --- a/projects/rero/ng-core/assets/scss/_editor.scss +++ b/projects/rero/ng-core/assets/scss/_editor.scss @@ -15,13 +15,11 @@ * along with this program. If not, see . */ -@layer ng-core { - ng-core-editor-formly-field-textarea, - ng-core-formly-field-primeng-input, - ng-core-tree-select, - ng-core-multi-select, - ng-core-primeng-select, - ng-core-date-picker { - @extend .w-full; - } +ng-core-editor-formly-field-textarea, +ng-core-formly-field-primeng-input, +ng-core-tree-select, +ng-core-multi-select, +ng-core-primeng-select, +ng-core-date-picker { + @extend .w-full; } diff --git a/projects/rero/ng-core/assets/scss/_theme.scss b/projects/rero/ng-core/assets/scss/_theme.scss index e8ba1ca3..d6fe7bf9 100644 --- a/projects/rero/ng-core/assets/scss/_theme.scss +++ b/projects/rero/ng-core/assets/scss/_theme.scss @@ -15,50 +15,43 @@ * along with this program. If not, see . */ -@layer ng-core { - :root { - font-family: -apple-system, system-ui, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Helvetica, Arial, - sans-serif; - --font-family: -apple-system, system-ui, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Helvetica, Arial, - sans-serif; +a { + @extend .text-blue-500, .no-underline; +} - @extend .text-sm; +a:hover { + @extend .text-blue-600, .underline; +} - a { - @extend .text-blue-500, .no-underline; - } +.p-submenu-list { + z-index: 1000; +} - a:hover { - @extend .text-blue-600, .underline; - } +.p-menuitem { + a { + @extend .text-color; + } + a:hover { + @extend .no-underline; + } +} - .p-submenu-list { - z-index: 1000; - } +dl.metadata { + @extend .grid, .my-0, .w-full; + dt { + @extend .font-bold, .col-12, .py-0; + @include styleclass('md:col-4'); + } + dd { + @extend .col-12, .py-0, .m-0; + @include styleclass('md:col-8'); + } +} - .p-menuitem { - a { - @extend .text-color; - } - a:hover { - @extend .no-underline; - } - } +.p-menubar { + @extend .mb-0, .border-none, .bg-white; +} - dl.metadata { - @extend .grid, .my-0, .w-full; - dt { - @extend .font-bold, .col-12, .py-0; - @include styleclass('md:col-4'); - } - dd { - @extend .col-12, .py-0; - @include styleclass('md:col-8'); - margin-inline-start: 0; - } - } - .p-menubar { - @extend .mb-0, .border-none, .bg-white; - } - } +label { + @extend .m-0; } diff --git a/projects/rero/ng-core/assets/scss/_typography.scss b/projects/rero/ng-core/assets/scss/_typography.scss index 619da83b..6b1b8792 100644 --- a/projects/rero/ng-core/assets/scss/_typography.scss +++ b/projects/rero/ng-core/assets/scss/_typography.scss @@ -15,75 +15,125 @@ * along with this program. If not, see . */ -@layer ng-core { - :root { - h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 { - @extend .mt-0, .mb-2, .font-medium, .line-height-2; - } - - h1, .h1 { - @extend .text-5xl; - } - - h2, .h2 { - @extend .text-4xl; - } - - h3, .h3 { - @extend .text-3xl; - } - - h4, .h4 { - @extend .text-2xl; - } - - h5, .h5 { - @extend .text-xl; - } - - h6, .h6 { - @extend .text-lg; - } - - // from aura-light-blue message theme - .text-info { - color: #2563eb; - } - - .text-success { - color: #16a34a; - } - - .text-warning { - color: #ca8a04; - } - - .text-error { - color: #dc2626; - } - - .border-info { - border-color: #2563eb; - } - - .border-success { - border-color: #16a34a; - } - - .border-warning { - border-color: #ca8a04; - } - - .border-error { - border-color: #dc2626; - } - - .text-link { - @include styleclass('text-blue-500 hover:text-blue-600 hover:underline cursor-pointer'); - } - - .text-link-secondary { - @include styleclass('text-color-secondary hover:text-blue-600 cursor-pointer'); - } +h1, +h2, +h3, +h4, +h5, +h6, +.h1, +.h2, +.h3, +.h4, +.h5, +.h6 { + @extend .mt-0, .mb-2, .font-medium, .line-height-2; +} + +h1, +.h1 { + @extend .text-5xl; +} + +h2, +.h2 { + @extend .text-4xl; +} + +h3, +.h3 { + @extend .text-3xl; +} + +h4, +.h4 { + @extend .text-2xl; +} + +h5, +.h5 { + @extend .text-xl; +} + +h6, +.h6 { + @extend .text-lg; +} + +// from aura-light-blue message theme +.text-info { + color: #2563eb; +} + +.text-success { + color: #16a34a; +} + +.text-warning { + color: #ca8a04; +} + +.text-error { + color: #dc2626; +} + +.border-info { + border-color: #2563eb; +} + +.border-success { + border-color: #16a34a; +} + +.border-warning { + border-color: #ca8a04; +} + +.border-error { + border-color: #dc2626; +} + +.background-info { + background-color: #2563eb; +} + +.background-success { + background-color: #16a34a; +} + +.background-warning { + background-color: #ca8a04; +} + +.background-error { + background-color: #dc2626; +} + +.text-link { + @include styleclass('text-blue-500 hover:text-blue-600 hover:underline cursor-pointer'); +} + +.text-link-secondary { + @include styleclass('text-color-secondary hover:text-blue-600 cursor-pointer'); +} + +.alternate-color > *:nth-child(even) { + @extend .surface-100; +} + +.p-card-body-p-0 { + .p-card-body { + @extend .p-0; + } +} + +.bg-transparent { + background-color: transparent; +} + +.time-line-30 { + .p-timeline-event-opposite { + width: 30%; + @extend .flex-initial; } } diff --git a/projects/rero/ng-core/assets/scss/ng-core.scss b/projects/rero/ng-core/assets/scss/ng-core.scss index 2181f68a..fa11d9db 100644 --- a/projects/rero/ng-core/assets/scss/ng-core.scss +++ b/projects/rero/ng-core/assets/scss/ng-core.scss @@ -21,3 +21,5 @@ @import "../../src/lib/record/editor/wrappers/card-wrapper/card-wrapper.component.scss"; @import "../../src/lib/record/editor/editor.component.scss"; +@import "../../src/lib/record/search-autocomplete/search-autocomplete.component.scss"; + diff --git a/projects/rero/ng-core/src/lib/prime-ng-core-module.ts b/projects/rero/ng-core/src/lib/prime-ng-core-module.ts index 6b66ec70..9d47767b 100644 --- a/projects/rero/ng-core/src/lib/prime-ng-core-module.ts +++ b/projects/rero/ng-core/src/lib/prime-ng-core-module.ts @@ -26,6 +26,7 @@ import { CardModule } from 'primeng/card'; import { CheckboxModule } from 'primeng/checkbox'; import { ConfirmDialogModule } from 'primeng/confirmdialog'; import { DialogModule } from 'primeng/dialog'; +import { DividerModule } from 'primeng/divider'; import { DropdownModule } from "primeng/dropdown"; import { DialogService, DynamicDialogModule } from 'primeng/dynamicdialog'; import { InputGroupModule } from 'primeng/inputgroup'; @@ -65,6 +66,7 @@ import { FieldsetModule } from 'primeng/fieldset'; ClipboardModule, ConfirmDialogModule, DialogModule, + DividerModule, DropdownModule, DynamicDialogModule, FieldsetModule, diff --git a/projects/rero/ng-core/src/lib/record/editor/editor.component.scss b/projects/rero/ng-core/src/lib/record/editor/editor.component.scss index 1a654709..6394f1bf 100644 --- a/projects/rero/ng-core/src/lib/record/editor/editor.component.scss +++ b/projects/rero/ng-core/src/lib/record/editor/editor.component.scss @@ -15,11 +15,10 @@ * along with this program. If not, see . */ -@layer ng-core { - ng-core-editor { - .bd-toc, .bd-sidebar { - top: 4rem; - height: 100vh - 10vh; - } +ng-core-editor { + .bd-toc, + .bd-sidebar { + top: 4rem; + height: 100vh - 10vh; } } diff --git a/projects/rero/ng-core/src/lib/record/editor/wrappers/card-wrapper/card-wrapper.component.scss b/projects/rero/ng-core/src/lib/record/editor/wrappers/card-wrapper/card-wrapper.component.scss index 2596fef5..1a1f309d 100644 --- a/projects/rero/ng-core/src/lib/record/editor/wrappers/card-wrapper/card-wrapper.component.scss +++ b/projects/rero/ng-core/src/lib/record/editor/wrappers/card-wrapper/card-wrapper.component.scss @@ -15,20 +15,19 @@ * along with this program. If not, see . */ -@layer ng-core { - ng-core-card-wrapper { - // primeng bug? - span.p-fieldset-legend-text { - @extend .hidden; +ng-core-card-wrapper { + // primeng bug? + span.p-fieldset-legend-text { + @extend .hidden; + } + .p-fieldset .p-fieldset-legend { + @extend .m-0; + span { + @extend .p-0; } - .p-fieldset .p-fieldset-legend { - @extend .m-0; - span { - @extend .p-0; - } - ng-core-label-editor > div, ng-core-editor-dropdown-label-editor > div { - @extend .ml-2; - } + ng-core-label-editor > div, + ng-core-editor-dropdown-label-editor > div { + @extend .ml-2; } } } diff --git a/projects/rero/ng-core/src/lib/record/search-autocomplete/search-autocomplete.component.scss b/projects/rero/ng-core/src/lib/record/search-autocomplete/search-autocomplete.component.scss new file mode 100644 index 00000000..90352e30 --- /dev/null +++ b/projects/rero/ng-core/src/lib/record/search-autocomplete/search-autocomplete.component.scss @@ -0,0 +1,20 @@ +/* + * RERO angular core + * Copyright (C) 2024 RERO + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation, version 3 of the License. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + */ + +ng-core-search-autocomplete p-Autocomplete button { + @extend .text-gray-500, .bg-white, .border-300; +} diff --git a/projects/rero/ng-core/src/lib/record/search-autocomplete/search-autocomplete.component.ts b/projects/rero/ng-core/src/lib/record/search-autocomplete/search-autocomplete.component.ts index 203e86ac..f1829dcc 100644 --- a/projects/rero/ng-core/src/lib/record/search-autocomplete/search-autocomplete.component.ts +++ b/projects/rero/ng-core/src/lib/record/search-autocomplete/search-autocomplete.component.ts @@ -44,6 +44,9 @@ export interface IAutoComplete { selector: 'ng-core-search-autocomplete', template: `
@@ -84,9 +90,11 @@ export class SearchAutocompleteComponent { scrollHeight = input('250px'); styleClass = input('w-full'); value = input(); + currentValue: string = ''; // Output onSelect = output(); + onSearch = output(); // Whether to display options as grouped when nested options are provided. group = false; @@ -94,11 +102,15 @@ export class SearchAutocompleteComponent { // User Query private query = new Subject(); + buttonClick(event) { + this.onSearch.emit(this.currentValue); + } + suggestions = toSignal(this.query.pipe( switchMap((query: string) => this.getSuggestions(query)) ), { initialValue: []}); - search(event: AutoCompleteCompleteEvent): void { + setSuggestionQuery(event: AutoCompleteCompleteEvent): void { this.query.next(event.query); } @@ -106,6 +118,12 @@ export class SearchAutocompleteComponent { this.onSelect.emit(event.value); } + search(event) { + if(event?.code === 'Enter') { + this.onSearch.emit(event.srcElement.value); + } + } + private getSuggestions(query: string): any { return combineLatest(this.prepareQuery(query)).pipe( map((data: IAutoComplete[]) => { diff --git a/projects/rero/ng-core/src/lib/record/search/aggregation/buckets/buckets.component.html b/projects/rero/ng-core/src/lib/record/search/aggregation/buckets/buckets.component.html index 91a9412b..c7ad66fc 100644 --- a/projects/rero/ng-core/src/lib/record/search/aggregation/buckets/buckets.component.html +++ b/projects/rero/ng-core/src/lib/record/search/aggregation/buckets/buckets.component.html @@ -19,7 +19,7 @@ @for (bucket of buckets()|slice:0:bucketSize; track bucket; let index = $index) {
  • @if (bucket.doc_count) { -