-
Notifications
You must be signed in to change notification settings - Fork 13
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
migrations: create the migration module
Co-Authored-by: Johnny Mariéthoz <[email protected]>
- Loading branch information
Showing
22 changed files
with
1,662 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
40 changes: 40 additions & 0 deletions
40
...c/app/migration/conversion/record/brief-view/migration-data/migration-data.component.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
<!-- | ||
RERO ILS UI | ||
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 <http://www.gnu.org/licenses/>. | ||
--> | ||
@if (record) { | ||
<h5> | ||
<a | ||
[routerLink]="[detailUrl.link]" | ||
[queryParams]="{ migration: record.metadata.migration_id }" | ||
>{{ record.id }} | ||
<p-badge | ||
[severity]="severityTag" | ||
[value]="record.metadata.conversion.status | translate" | ||
/></a> | ||
</h5> | ||
@if (record?.metadata?.conversion?.json?.title) { | ||
{{ record.metadata.conversion.json.title | mainTitle }} | ||
} | ||
<div> | ||
<i | ||
><small | ||
><span translate>Last modification:</span> {{ | ||
record?.metadata?.updated_at | dateTranslate : "medium" | ||
}}</small | ||
></i | ||
> | ||
</div> | ||
} |
56 changes: 56 additions & 0 deletions
56
...src/app/migration/conversion/record/brief-view/migration-data/migration-data.component.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
/* | ||
* RERO ILS UI | ||
* 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 <http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
import { Component, Input, OnInit } from '@angular/core'; | ||
|
||
@Component({ | ||
selector: 'admin-migration-data', | ||
templateUrl: './migration-data.component.html', | ||
}) | ||
export class MigrationDataBriefComponent implements OnInit { | ||
// current record | ||
@Input() record: any; | ||
|
||
/** Type of record */ | ||
@Input() type: string; | ||
|
||
/** Detail Url */ | ||
@Input() detailUrl: { link: string; external: boolean }; | ||
|
||
severityTag: string; | ||
|
||
/** OnInit hook */ | ||
ngOnInit(): void { | ||
this.setSeverityBadge(); | ||
} | ||
|
||
/** | ||
* Set the badge color from the status. | ||
*/ | ||
setSeverityBadge() { | ||
let severity = 'secondary'; | ||
const status = this.record?.metadata?.conversion.status; | ||
|
||
if (status === 'complete') { | ||
severity = 'success'; | ||
} | ||
if (status.endsWith('error')) { | ||
severity = 'danger'; | ||
} | ||
this.severityTag = severity; | ||
} | ||
} |
40 changes: 40 additions & 0 deletions
40
.../app/migration/conversion/record/detail-view/migration-data/migration-data.component.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
<!-- | ||
RERO ILS UI | ||
Copyright (C) 2020-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 <http://www.gnu.org/licenses/>. | ||
--> | ||
@if (record) { | ||
|
||
<h5> | ||
{{ record.id }} <p-badge [severity]="severityTag" [value]="record.conversion.status | translate" /> | ||
</h5> | ||
<i | ||
><small | ||
><span translate>Last modification:</span> {{ | ||
record?.updated_at | dateTranslate : "medium" | ||
}}</small | ||
></i | ||
> | ||
<hr /> | ||
@if (messages) { | ||
<p-messages [(value)]="messages" [enableService]="false" [closable]="false" /> | ||
} | ||
<div class="text-sm grid data"> | ||
<div class="markdown col" [innerHTML]="record.raw | markdown"></div> | ||
<div | ||
class="json col" | ||
[innerHTML]="record?.conversion?.json | json | highlightJson" | ||
></div> | ||
</div> | ||
} |
37 changes: 37 additions & 0 deletions
37
.../app/migration/conversion/record/detail-view/migration-data/migration-data.component.scss
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
/* | ||
* RERO ILS UI | ||
* 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 <http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
::ng-deep { | ||
.markdown td, | ||
.markdown th { | ||
padding: 0 10px; | ||
vertical-align: top; | ||
} | ||
tbody tr:nth-child(odd) { | ||
background-color: #f8fafc; | ||
} | ||
} | ||
|
||
.data { | ||
.col { | ||
max-height: 600px; | ||
overflow: auto; | ||
} | ||
.json { | ||
border-left: 1px solid gray; | ||
} | ||
} |
110 changes: 110 additions & 0 deletions
110
...rc/app/migration/conversion/record/detail-view/migration-data/migration-data.component.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
/* | ||
* RERO ILS UI | ||
* 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 <http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
import { HttpClient } from '@angular/common/http'; | ||
import { Component, inject, OnDestroy, OnInit } from '@angular/core'; | ||
import { ActivatedRoute } from '@angular/router'; | ||
import { ApiService, Record } from '@rero/ng-core'; | ||
import { of, Subscription, switchMap, tap } from 'rxjs'; | ||
|
||
@Component({ | ||
selector: 'admin-migration-data', | ||
templateUrl: './migration-data.component.html', | ||
styleUrl: './migration-data.component.scss', | ||
}) | ||
export class MigrationDataDetailComponent implements OnInit, OnDestroy { | ||
/** Observable resolving record data */ | ||
|
||
// current record | ||
record: any; | ||
|
||
// services | ||
protected route = inject(ActivatedRoute); | ||
protected http = inject(HttpClient); | ||
protected apiService = inject(ApiService); | ||
|
||
/** all component subscription */ | ||
private subscriptions = new Subscription(); | ||
|
||
// log messages from the backend | ||
messages = []; | ||
|
||
severityTag: string; | ||
|
||
/** OnInit hook */ | ||
ngOnInit(): void { | ||
// get the record when the pid is changed in the the route | ||
this.subscriptions.add( | ||
this.route.paramMap | ||
.pipe( | ||
switchMap(() => { | ||
// route params | ||
const docType = this.route.snapshot.params.type; | ||
const id = this.route.snapshot.params.pid; | ||
const migrationId = this.route.snapshot.queryParams.migration; | ||
// nothing to do | ||
if (docType == null || id == null || migrationId == null) { | ||
return of(null); | ||
} | ||
// get the record from the backend | ||
return this.http.get<Record>( | ||
`${this.apiService.getEndpointByType(docType, true)}/${id}?migration=${migrationId}` | ||
); | ||
}), | ||
tap((record: any) => { | ||
// add message logs | ||
if (record?.conversion.logs) { | ||
['info', 'warning', 'error'].map((field) => { | ||
const log = record.conversion.logs[field]; | ||
if (log) { | ||
this.messages.push({ | ||
severity: field == 'warning' ? 'warn' : field, | ||
detail: log, | ||
}); | ||
} | ||
}); | ||
} | ||
}), | ||
) | ||
.subscribe((res) => { | ||
this.record = res; | ||
this.setSeverityBadge(); | ||
} | ||
) | ||
); | ||
} | ||
|
||
/** | ||
* Set the badge color from the status. | ||
*/ | ||
setSeverityBadge() { | ||
let severity = 'secondary'; | ||
const status = this.record?.conversion.status; | ||
|
||
if (status === 'complete') { | ||
severity = 'success'; | ||
} | ||
if (status.endsWith('error')) { | ||
severity = 'danger'; | ||
} | ||
this.severityTag = severity; | ||
} | ||
/** OnDestroy hook */ | ||
ngOnDestroy(): void { | ||
this.subscriptions.unsubscribe(); | ||
} | ||
} |
74 changes: 74 additions & 0 deletions
74
projects/admin/src/app/migration/conversion/record/detail-view/pipes/highlight-json.pipe.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
/* | ||
* RERO ILS UI | ||
* 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 <http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
import { Pipe, PipeTransform } from '@angular/core'; | ||
import { DomSanitizer } from '@angular/platform-browser'; | ||
|
||
/** | ||
* Highlight a JSON structure. | ||
* from SONAR | ||
*/ | ||
@Pipe({ | ||
name: 'highlightJson', | ||
}) | ||
export class HighlightJsonPipe implements PipeTransform { | ||
/** | ||
* Constructor. | ||
* | ||
* @param sanitizer DOM Sanitizer. | ||
*/ | ||
constructor(public sanitizer: DomSanitizer) {} | ||
|
||
/** | ||
* Highlight a JSON structure. | ||
* | ||
* @param value Json structure. | ||
* @return Highlighted string. | ||
*/ | ||
transform(value: string): any { | ||
if (value == null) { | ||
return; | ||
} | ||
let json = value | ||
.replace(/&/g, '&') | ||
.replace(/</g, '<') | ||
.replace(/>/g, '>') | ||
.replace(/(?:\r\n|\r|\n)/g, '<br>') | ||
.replace(/( )/g, ' '); | ||
|
||
json = json.replace( | ||
/("(\\u[a-zA-Z0-9]{4}|\\[^u]|[^\\"])*"(\s*:)?|\b(true|false|null)\b|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?)/g, | ||
(match: any) => { | ||
let cls = 'text-gray-600'; | ||
if (/^"/.test(match)) { | ||
if (/:$/.test(match)) { | ||
cls = 'text-cyan-600'; | ||
} else { | ||
cls = 'text-orange-600'; | ||
} | ||
} else if (/true|false/.test(match)) { | ||
cls = 'text-blue-600'; | ||
} else if (/null/.test(match)) { | ||
cls = 'text-blue-600'; | ||
} | ||
return `<span class="${cls}">${match}</span>`; | ||
} | ||
); | ||
const html = this.sanitizer.bypassSecurityTrustHtml(json); | ||
return html; | ||
} | ||
} |
Oops, something went wrong.