@myrmidon/cadmus-refs-asserted-ids 1.0.9 → 2.1.0
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/README.md +96 -96
- package/esm2022/lib/asserted-composite-id/asserted-composite-id.component.mjs +142 -0
- package/esm2022/lib/asserted-composite-ids/asserted-composite-ids.component.mjs +154 -0
- package/esm2022/lib/asserted-id/asserted-id.component.mjs +133 -0
- package/esm2022/lib/asserted-ids/asserted-ids.component.mjs +147 -0
- package/esm2022/lib/cadmus-refs-asserted-ids.module.mjs +122 -0
- package/esm2022/lib/pin-target-lookup/pin-target-lookup.component.mjs +405 -0
- package/esm2022/lib/scoped-pin-lookup/scoped-pin-lookup.component.mjs +130 -0
- package/esm2022/lib/services/item-ref-lookup.service.mjs +29 -0
- package/esm2022/lib/services/pin-ref-lookup.service.mjs +85 -0
- package/{esm2020 → esm2022}/myrmidon-cadmus-refs-asserted-ids.mjs +4 -4
- package/esm2022/public-api.mjs +13 -0
- package/fesm2022/myrmidon-cadmus-refs-asserted-ids.mjs +1265 -0
- package/fesm2022/myrmidon-cadmus-refs-asserted-ids.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/asserted-composite-id/asserted-composite-id.component.d.ts +83 -0
- package/lib/asserted-composite-ids/asserted-composite-ids.component.d.ts +67 -0
- package/lib/asserted-id/asserted-id.component.d.ts +49 -49
- package/lib/asserted-ids/asserted-ids.component.d.ts +44 -44
- package/lib/cadmus-refs-asserted-ids.module.d.ts +28 -22
- package/lib/pin-target-lookup/pin-target-lookup.component.d.ts +139 -0
- package/lib/scoped-pin-lookup/scoped-pin-lookup.component.d.ts +39 -39
- package/lib/services/item-ref-lookup.service.d.ts +13 -0
- package/lib/services/pin-ref-lookup.service.d.ts +27 -18
- package/package.json +8 -14
- package/public-api.d.ts +9 -5
- package/esm2020/lib/asserted-id/asserted-id.component.mjs +0 -132
- package/esm2020/lib/asserted-ids/asserted-ids.component.mjs +0 -146
- package/esm2020/lib/cadmus-refs-asserted-ids.module.mjs +0 -91
- package/esm2020/lib/scoped-pin-lookup/scoped-pin-lookup.component.mjs +0 -129
- package/esm2020/lib/services/pin-ref-lookup.service.mjs +0 -72
- package/esm2020/public-api.mjs +0 -9
- package/fesm2015/myrmidon-cadmus-refs-asserted-ids.mjs +0 -554
- package/fesm2015/myrmidon-cadmus-refs-asserted-ids.mjs.map +0 -1
- package/fesm2020/myrmidon-cadmus-refs-asserted-ids.mjs +0 -547
- package/fesm2020/myrmidon-cadmus-refs-asserted-ids.mjs.map +0 -1
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { Component, EventEmitter, Inject, Output } from '@angular/core';
|
|
2
|
+
import { Validators, } from '@angular/forms';
|
|
3
|
+
import { forkJoin, take } from 'rxjs';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "@myrmidon/cadmus-api";
|
|
7
|
+
import * as i3 from "../services/pin-ref-lookup.service";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
9
|
+
import * as i5 from "@angular/material/button";
|
|
10
|
+
import * as i6 from "@angular/material/expansion";
|
|
11
|
+
import * as i7 from "@angular/material/form-field";
|
|
12
|
+
import * as i8 from "@angular/material/icon";
|
|
13
|
+
import * as i9 from "@angular/material/input";
|
|
14
|
+
import * as i10 from "@angular/material/select";
|
|
15
|
+
import * as i11 from "@angular/material/core";
|
|
16
|
+
import * as i12 from "@myrmidon/cadmus-refs-lookup";
|
|
17
|
+
// from Cadmus general parts
|
|
18
|
+
const METADATA_PART_ID = 'it.vedph.metadata';
|
|
19
|
+
/*
|
|
20
|
+
* Scoped pin-based lookup component. This component provides a list
|
|
21
|
+
* of pin-based searches, with a lookup control. Whenever the user
|
|
22
|
+
* picks a pin value, he gets the details about its item and part, and
|
|
23
|
+
* item's metadata part, if any. He can then use these data to build
|
|
24
|
+
* some EID by variously assembling these components.
|
|
25
|
+
*/
|
|
26
|
+
class ScopedPinLookupComponent {
|
|
27
|
+
constructor(formBuilder, _itemService, lookupService, lookupDefs) {
|
|
28
|
+
this._itemService = _itemService;
|
|
29
|
+
this.lookupService = lookupService;
|
|
30
|
+
this.lookupDefs = lookupDefs;
|
|
31
|
+
// lookup
|
|
32
|
+
// keys are all the defined lookup searches
|
|
33
|
+
this.keys = Object.keys(lookupDefs);
|
|
34
|
+
// the selected key defines the lookup scope
|
|
35
|
+
this.key = formBuilder.control(null);
|
|
36
|
+
this.keyForm = formBuilder.group({
|
|
37
|
+
key: this.key,
|
|
38
|
+
});
|
|
39
|
+
// id
|
|
40
|
+
this.id = formBuilder.control(null, [
|
|
41
|
+
Validators.required,
|
|
42
|
+
Validators.maxLength(300),
|
|
43
|
+
]);
|
|
44
|
+
this.idForm = formBuilder.group({
|
|
45
|
+
id: this.id,
|
|
46
|
+
});
|
|
47
|
+
// event
|
|
48
|
+
this.idPick = new EventEmitter();
|
|
49
|
+
}
|
|
50
|
+
ngOnInit() {
|
|
51
|
+
// pre-select a unique key
|
|
52
|
+
if (this.keys.length === 1) {
|
|
53
|
+
this.key.setValue(this.keys[0]);
|
|
54
|
+
this.key.markAsDirty();
|
|
55
|
+
this.key.updateValueAndValidity();
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
onItemChange(item) {
|
|
59
|
+
const info = {
|
|
60
|
+
pin: item,
|
|
61
|
+
};
|
|
62
|
+
// lookup item and its metadata part if any
|
|
63
|
+
forkJoin({
|
|
64
|
+
item: this._itemService.getItem(item.itemId, false),
|
|
65
|
+
part: this._itemService.getPartFromTypeAndRole(item.itemId, METADATA_PART_ID),
|
|
66
|
+
})
|
|
67
|
+
.pipe(take(1))
|
|
68
|
+
.subscribe({
|
|
69
|
+
next: (result) => {
|
|
70
|
+
info.item = result.item;
|
|
71
|
+
info.part = result.part;
|
|
72
|
+
this.info = info;
|
|
73
|
+
},
|
|
74
|
+
error: (error) => {
|
|
75
|
+
console.error(error ? JSON.stringify(error) : 'Error loading item/metadata');
|
|
76
|
+
},
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
appendIdComponent(type, metaIndex = -1) {
|
|
80
|
+
let id = this.id.value || '';
|
|
81
|
+
switch (type) {
|
|
82
|
+
case 'pin':
|
|
83
|
+
id += this.info?.pin.value;
|
|
84
|
+
break;
|
|
85
|
+
case 'itemId':
|
|
86
|
+
id += this.info.item?.id || '';
|
|
87
|
+
break;
|
|
88
|
+
case 'partId':
|
|
89
|
+
id += this.info.part?.id || '';
|
|
90
|
+
break;
|
|
91
|
+
case 'partTypeId':
|
|
92
|
+
id += this.info.part?.typeId || '';
|
|
93
|
+
break;
|
|
94
|
+
case 'partRoleId':
|
|
95
|
+
id += this.info.part?.roleId || '';
|
|
96
|
+
break;
|
|
97
|
+
case 'metadata':
|
|
98
|
+
id += this.info.part.metadata[metaIndex].value;
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
101
|
+
this.id.setValue(id);
|
|
102
|
+
this.id.markAsDirty();
|
|
103
|
+
this.id.updateValueAndValidity();
|
|
104
|
+
}
|
|
105
|
+
pickId() {
|
|
106
|
+
if (this.idForm.invalid) {
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
109
|
+
this.idPick.emit(this.id.value);
|
|
110
|
+
this.info = undefined;
|
|
111
|
+
}
|
|
112
|
+
resetId() {
|
|
113
|
+
this.id.reset();
|
|
114
|
+
this.id.markAsDirty();
|
|
115
|
+
this.id.updateValueAndValidity();
|
|
116
|
+
}
|
|
117
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ScopedPinLookupComponent, deps: [{ token: i1.FormBuilder }, { token: i2.ItemService }, { token: i3.PinRefLookupService }, { token: 'indexLookupDefinitions' }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
118
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ScopedPinLookupComponent, selector: "cadmus-scoped-pin-lookup", outputs: { idPick: "idPick" }, ngImport: i0, template: "<div>\r\n <!-- lookup -->\r\n <div>\r\n <form [formGroup]=\"keyForm\" class=\"form-row\">\r\n <!-- key -->\r\n <mat-form-field *ngIf=\"keys.length > 1\">\r\n <mat-label>type</mat-label>\r\n <mat-select [formControl]=\"key\">\r\n <mat-option *ngFor=\"let k of keys\" [value]=\"k\">{{ k }}</mat-option>\r\n </mat-select>\r\n <mat-error\r\n *ngIf=\"$any(key).errors?.required && (key.dirty || key.touched)\"\r\n >type required</mat-error\r\n >\r\n </mat-form-field>\r\n <cadmus-ref-lookup\r\n [service]=\"lookupService\"\r\n label=\"pin\"\r\n [options]=\"key.value ? lookupDefs[key.value] : undefined\"\r\n (itemChange)=\"onItemChange($event)\"\r\n ></cadmus-ref-lookup>\r\n </form>\r\n </div>\r\n\r\n <!-- builder -->\r\n <mat-expansion-panel *ngIf=\"info\" [expanded]=\"info\" [disabled]=\"!info\">\r\n <mat-expansion-panel-header>ID builder</mat-expansion-panel-header>\r\n <!-- ID -->\r\n <div>\r\n <form [formGroup]=\"idForm\" (submit)=\"pickId()\">\r\n <mat-form-field style=\"width: 100%\">\r\n <input matInput [formControl]=\"id\" />\r\n <mat-error\r\n *ngIf=\"$any(id).errors?.required && (id.dirty || id.touched)\"\r\n >ID required</mat-error\r\n >\r\n <mat-error\r\n *ngIf=\"$any(id).errors?.maxLength && (id.dirty || id.touched)\"\r\n >ID too long</mat-error\r\n >\r\n <button\r\n mat-icon-button\r\n type=\"button\"\r\n matSuffix\r\n (click)=\"resetId()\"\r\n [disabled]=\"!id.value\"\r\n >\r\n <mat-icon color=\"warn\">close</mat-icon>\r\n </button>\r\n <button\r\n mat-icon-button\r\n type=\"button\"\r\n matSuffix\r\n (click)=\"pickId()\"\r\n [disabled]=\"idForm.invalid\"\r\n >\r\n <mat-icon color=\"primary\">check_circle</mat-icon>\r\n </button>\r\n </mat-form-field>\r\n </form>\r\n </div>\r\n <!-- table -->\r\n <table>\r\n <thead>\r\n <th></th>\r\n <th>source</th>\r\n <th>value</th>\r\n </thead>\r\n <tbody>\r\n <!-- pin -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('pin')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>pin</td>\r\n <td>{{ info!.pin.value }}</td>\r\n </tr>\r\n <!-- item ID -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('itemId')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>item ID</td>\r\n <td>{{ info!.item?.id }}</td>\r\n </tr>\r\n <!-- item title -->\r\n <tr>\r\n <td></td>\r\n <td>item title</td>\r\n <td>{{ info!.item?.title }}</td>\r\n </tr>\r\n <!-- part ID -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('partId')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>part ID</td>\r\n <td>{{ info!.part?.id }}</td>\r\n </tr>\r\n <!-- part type ID -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('partTypeId')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>part type ID</td>\r\n <td>{{ info!.part?.typeId }}</td>\r\n </tr>\r\n <!-- part role ID -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('partRoleId')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>part role ID</td>\r\n <td>{{ info!.part?.roleId }}</td>\r\n </tr>\r\n\r\n <!-- part's metadata -->\r\n <tr *ngFor=\"let m of info!.part?.metadata; let i = index\">\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('metadata', i)\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td class=\"metadata\">{{ m.name }}</td>\r\n <td class=\"metadata\">{{ m.value }}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </mat-expansion-panel>\r\n</div>\r\n", styles: [".metadata{color:#4a3001}table{border:1px solid silver;border-radius:6px;padding:4px;margin-top:8px}tr:nth-child(odd){background-color:#f0f0f0}th{font-weight:400;text-align:left;color:silver}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i6.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "directive", type: i7.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i7.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i11.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i12.RefLookupComponent, selector: "cadmus-ref-lookup", inputs: ["label", "limit", "baseFilter", "service", "item", "required", "hasMore", "linkTemplate", "optDialog", "options"], outputs: ["itemChange", "moreRequest"] }] }); }
|
|
119
|
+
}
|
|
120
|
+
export { ScopedPinLookupComponent };
|
|
121
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ScopedPinLookupComponent, decorators: [{
|
|
122
|
+
type: Component,
|
|
123
|
+
args: [{ selector: 'cadmus-scoped-pin-lookup', template: "<div>\r\n <!-- lookup -->\r\n <div>\r\n <form [formGroup]=\"keyForm\" class=\"form-row\">\r\n <!-- key -->\r\n <mat-form-field *ngIf=\"keys.length > 1\">\r\n <mat-label>type</mat-label>\r\n <mat-select [formControl]=\"key\">\r\n <mat-option *ngFor=\"let k of keys\" [value]=\"k\">{{ k }}</mat-option>\r\n </mat-select>\r\n <mat-error\r\n *ngIf=\"$any(key).errors?.required && (key.dirty || key.touched)\"\r\n >type required</mat-error\r\n >\r\n </mat-form-field>\r\n <cadmus-ref-lookup\r\n [service]=\"lookupService\"\r\n label=\"pin\"\r\n [options]=\"key.value ? lookupDefs[key.value] : undefined\"\r\n (itemChange)=\"onItemChange($event)\"\r\n ></cadmus-ref-lookup>\r\n </form>\r\n </div>\r\n\r\n <!-- builder -->\r\n <mat-expansion-panel *ngIf=\"info\" [expanded]=\"info\" [disabled]=\"!info\">\r\n <mat-expansion-panel-header>ID builder</mat-expansion-panel-header>\r\n <!-- ID -->\r\n <div>\r\n <form [formGroup]=\"idForm\" (submit)=\"pickId()\">\r\n <mat-form-field style=\"width: 100%\">\r\n <input matInput [formControl]=\"id\" />\r\n <mat-error\r\n *ngIf=\"$any(id).errors?.required && (id.dirty || id.touched)\"\r\n >ID required</mat-error\r\n >\r\n <mat-error\r\n *ngIf=\"$any(id).errors?.maxLength && (id.dirty || id.touched)\"\r\n >ID too long</mat-error\r\n >\r\n <button\r\n mat-icon-button\r\n type=\"button\"\r\n matSuffix\r\n (click)=\"resetId()\"\r\n [disabled]=\"!id.value\"\r\n >\r\n <mat-icon color=\"warn\">close</mat-icon>\r\n </button>\r\n <button\r\n mat-icon-button\r\n type=\"button\"\r\n matSuffix\r\n (click)=\"pickId()\"\r\n [disabled]=\"idForm.invalid\"\r\n >\r\n <mat-icon color=\"primary\">check_circle</mat-icon>\r\n </button>\r\n </mat-form-field>\r\n </form>\r\n </div>\r\n <!-- table -->\r\n <table>\r\n <thead>\r\n <th></th>\r\n <th>source</th>\r\n <th>value</th>\r\n </thead>\r\n <tbody>\r\n <!-- pin -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('pin')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>pin</td>\r\n <td>{{ info!.pin.value }}</td>\r\n </tr>\r\n <!-- item ID -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('itemId')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>item ID</td>\r\n <td>{{ info!.item?.id }}</td>\r\n </tr>\r\n <!-- item title -->\r\n <tr>\r\n <td></td>\r\n <td>item title</td>\r\n <td>{{ info!.item?.title }}</td>\r\n </tr>\r\n <!-- part ID -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('partId')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>part ID</td>\r\n <td>{{ info!.part?.id }}</td>\r\n </tr>\r\n <!-- part type ID -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('partTypeId')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>part type ID</td>\r\n <td>{{ info!.part?.typeId }}</td>\r\n </tr>\r\n <!-- part role ID -->\r\n <tr>\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('partRoleId')\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>part role ID</td>\r\n <td>{{ info!.part?.roleId }}</td>\r\n </tr>\r\n\r\n <!-- part's metadata -->\r\n <tr *ngFor=\"let m of info!.part?.metadata; let i = index\">\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n (click)=\"appendIdComponent('metadata', i)\"\r\n >\r\n <mat-icon>add_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td class=\"metadata\">{{ m.name }}</td>\r\n <td class=\"metadata\">{{ m.value }}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </mat-expansion-panel>\r\n</div>\r\n", styles: [".metadata{color:#4a3001}table{border:1px solid silver;border-radius:6px;padding:4px;margin-top:8px}tr:nth-child(odd){background-color:#f0f0f0}th{font-weight:400;text-align:left;color:silver}\n"] }]
|
|
124
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.ItemService }, { type: i3.PinRefLookupService }, { type: undefined, decorators: [{
|
|
125
|
+
type: Inject,
|
|
126
|
+
args: ['indexLookupDefinitions']
|
|
127
|
+
}] }]; }, propDecorators: { idPick: [{
|
|
128
|
+
type: Output
|
|
129
|
+
}] } });
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scoped-pin-lookup.component.js","sourceRoot":"","sources":["../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/scoped-pin-lookup/scoped-pin-lookup.component.ts","../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/scoped-pin-lookup/scoped-pin-lookup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Output } from '@angular/core';\r\nimport {\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { ItemService } from '@myrmidon/cadmus-api';\r\n\r\nimport {\r\n  DataPinInfo,\r\n  IndexLookupDefinitions,\r\n  Item,\r\n  Part,\r\n} from '@myrmidon/cadmus-core';\r\nimport { forkJoin, take } from 'rxjs';\r\n\r\nimport { PinRefLookupService } from '../services/pin-ref-lookup.service';\r\n\r\n// from Cadmus general parts\r\nconst METADATA_PART_ID = 'it.vedph.metadata';\r\ninterface MetadataPart extends Part {\r\n  metadata: {\r\n    type?: string;\r\n    name: string;\r\n    value: string;\r\n  }[];\r\n}\r\n\r\ninterface LookupInfo {\r\n  pin: DataPinInfo;\r\n  item?: Item;\r\n  part?: MetadataPart;\r\n}\r\n\r\n/*\r\n * Scoped pin-based lookup component. This component provides a list\r\n * of pin-based searches, with a lookup control. Whenever the user\r\n * picks a pin value, he gets the details about its item and part, and\r\n * item's metadata part, if any. He can then use these data to build\r\n * some EID by variously assembling these components.\r\n */\r\n@Component({\r\n  selector: 'cadmus-scoped-pin-lookup',\r\n  templateUrl: './scoped-pin-lookup.component.html',\r\n  styleUrls: ['./scoped-pin-lookup.component.css'],\r\n})\r\nexport class ScopedPinLookupComponent {\r\n  // lookup\r\n  public key: FormControl<string | null>;\r\n  public keyForm: FormGroup;\r\n  public keys: string[];\r\n  public info?: LookupInfo;\r\n  // builder\r\n  public id: FormControl<string | null>;\r\n  public idForm: FormGroup;\r\n\r\n  @Output()\r\n  public idPick: EventEmitter<string>;\r\n\r\n  constructor(\r\n    formBuilder: FormBuilder,\r\n    private _itemService: ItemService,\r\n    public lookupService: PinRefLookupService,\r\n    @Inject('indexLookupDefinitions')\r\n    public lookupDefs: IndexLookupDefinitions\r\n  ) {\r\n    // lookup\r\n    // keys are all the defined lookup searches\r\n    this.keys = Object.keys(lookupDefs);\r\n    // the selected key defines the lookup scope\r\n    this.key = formBuilder.control(null);\r\n    this.keyForm = formBuilder.group({\r\n      key: this.key,\r\n    });\r\n    // id\r\n    this.id = formBuilder.control(null, [\r\n      Validators.required,\r\n      Validators.maxLength(300),\r\n    ]);\r\n    this.idForm = formBuilder.group({\r\n      id: this.id,\r\n    });\r\n    // event\r\n    this.idPick = new EventEmitter<string>();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // pre-select a unique key\r\n    if (this.keys.length === 1) {\r\n      this.key.setValue(this.keys[0]);\r\n      this.key.markAsDirty();\r\n      this.key.updateValueAndValidity();\r\n    }\r\n  }\r\n\r\n  public onItemChange(item: DataPinInfo): void {\r\n    const info: LookupInfo = {\r\n      pin: item,\r\n    };\r\n    // lookup item and its metadata part if any\r\n    forkJoin({\r\n      item: this._itemService.getItem(item.itemId, false),\r\n      part: this._itemService.getPartFromTypeAndRole(\r\n        item.itemId,\r\n        METADATA_PART_ID\r\n      ),\r\n    })\r\n      .pipe(take(1))\r\n      .subscribe({\r\n        next: (result) => {\r\n          info.item = result.item;\r\n          info.part = result.part as MetadataPart;\r\n          this.info = info;\r\n        },\r\n        error: (error) => {\r\n          console.error(\r\n            error ? JSON.stringify(error) : 'Error loading item/metadata'\r\n          );\r\n        },\r\n      });\r\n  }\r\n\r\n  public appendIdComponent(type: string, metaIndex = -1): void {\r\n    let id = this.id.value || '';\r\n\r\n    switch (type) {\r\n      case 'pin':\r\n        id += this.info?.pin.value;\r\n        break;\r\n      case 'itemId':\r\n        id += this.info!.item?.id || '';\r\n        break;\r\n      case 'partId':\r\n        id += this.info!.part?.id || '';\r\n        break;\r\n      case 'partTypeId':\r\n        id += this.info!.part?.typeId || '';\r\n        break;\r\n      case 'partRoleId':\r\n        id += this.info!.part?.roleId || '';\r\n        break;\r\n      case 'metadata':\r\n        id += this.info!.part!.metadata[metaIndex].value;\r\n        break;\r\n    }\r\n\r\n    this.id.setValue(id);\r\n    this.id.markAsDirty();\r\n    this.id.updateValueAndValidity();\r\n  }\r\n\r\n  public pickId(): void {\r\n    if (this.idForm.invalid) {\r\n      return;\r\n    }\r\n    this.idPick.emit(this.id.value!);\r\n    this.info = undefined;\r\n  }\r\n\r\n  public resetId(): void {\r\n    this.id.reset();\r\n    this.id.markAsDirty();\r\n    this.id.updateValueAndValidity();\r\n  }\r\n}\r\n","<div>\r\n  <!-- lookup -->\r\n  <div>\r\n    <form [formGroup]=\"keyForm\" class=\"form-row\">\r\n      <!-- key -->\r\n      <mat-form-field *ngIf=\"keys.length > 1\">\r\n        <mat-label>type</mat-label>\r\n        <mat-select [formControl]=\"key\">\r\n          <mat-option *ngFor=\"let k of keys\" [value]=\"k\">{{ k }}</mat-option>\r\n        </mat-select>\r\n        <mat-error\r\n          *ngIf=\"$any(key).errors?.required && (key.dirty || key.touched)\"\r\n          >type required</mat-error\r\n        >\r\n      </mat-form-field>\r\n      <cadmus-ref-lookup\r\n        [service]=\"lookupService\"\r\n        label=\"pin\"\r\n        [options]=\"key.value ? lookupDefs[key.value] : undefined\"\r\n        (itemChange)=\"onItemChange($event)\"\r\n      ></cadmus-ref-lookup>\r\n    </form>\r\n  </div>\r\n\r\n  <!-- builder -->\r\n  <mat-expansion-panel *ngIf=\"info\" [expanded]=\"info\" [disabled]=\"!info\">\r\n    <mat-expansion-panel-header>ID builder</mat-expansion-panel-header>\r\n    <!-- ID -->\r\n    <div>\r\n      <form [formGroup]=\"idForm\" (submit)=\"pickId()\">\r\n        <mat-form-field style=\"width: 100%\">\r\n          <input matInput [formControl]=\"id\" />\r\n          <mat-error\r\n            *ngIf=\"$any(id).errors?.required && (id.dirty || id.touched)\"\r\n            >ID required</mat-error\r\n          >\r\n          <mat-error\r\n            *ngIf=\"$any(id).errors?.maxLength && (id.dirty || id.touched)\"\r\n            >ID too long</mat-error\r\n          >\r\n          <button\r\n            mat-icon-button\r\n            type=\"button\"\r\n            matSuffix\r\n            (click)=\"resetId()\"\r\n            [disabled]=\"!id.value\"\r\n          >\r\n            <mat-icon color=\"warn\">close</mat-icon>\r\n          </button>\r\n          <button\r\n            mat-icon-button\r\n            type=\"button\"\r\n            matSuffix\r\n            (click)=\"pickId()\"\r\n            [disabled]=\"idForm.invalid\"\r\n          >\r\n            <mat-icon color=\"primary\">check_circle</mat-icon>\r\n          </button>\r\n        </mat-form-field>\r\n      </form>\r\n    </div>\r\n    <!-- table -->\r\n    <table>\r\n      <thead>\r\n        <th></th>\r\n        <th>source</th>\r\n        <th>value</th>\r\n      </thead>\r\n      <tbody>\r\n        <!-- pin -->\r\n        <tr>\r\n          <td>\r\n            <button\r\n              type=\"button\"\r\n              mat-icon-button\r\n              color=\"primary\"\r\n              (click)=\"appendIdComponent('pin')\"\r\n            >\r\n              <mat-icon>add_circle</mat-icon>\r\n            </button>\r\n          </td>\r\n          <td>pin</td>\r\n          <td>{{ info!.pin.value }}</td>\r\n        </tr>\r\n        <!-- item ID -->\r\n        <tr>\r\n          <td>\r\n            <button\r\n              type=\"button\"\r\n              mat-icon-button\r\n              color=\"primary\"\r\n              (click)=\"appendIdComponent('itemId')\"\r\n            >\r\n              <mat-icon>add_circle</mat-icon>\r\n            </button>\r\n          </td>\r\n          <td>item ID</td>\r\n          <td>{{ info!.item?.id }}</td>\r\n        </tr>\r\n        <!-- item title -->\r\n        <tr>\r\n          <td></td>\r\n          <td>item title</td>\r\n          <td>{{ info!.item?.title }}</td>\r\n        </tr>\r\n        <!-- part ID -->\r\n        <tr>\r\n          <td>\r\n            <button\r\n              type=\"button\"\r\n              mat-icon-button\r\n              color=\"primary\"\r\n              (click)=\"appendIdComponent('partId')\"\r\n            >\r\n              <mat-icon>add_circle</mat-icon>\r\n            </button>\r\n          </td>\r\n          <td>part ID</td>\r\n          <td>{{ info!.part?.id }}</td>\r\n        </tr>\r\n        <!-- part type ID -->\r\n        <tr>\r\n          <td>\r\n            <button\r\n              type=\"button\"\r\n              mat-icon-button\r\n              color=\"primary\"\r\n              (click)=\"appendIdComponent('partTypeId')\"\r\n            >\r\n              <mat-icon>add_circle</mat-icon>\r\n            </button>\r\n          </td>\r\n          <td>part type ID</td>\r\n          <td>{{ info!.part?.typeId }}</td>\r\n        </tr>\r\n        <!-- part role ID -->\r\n        <tr>\r\n          <td>\r\n            <button\r\n              type=\"button\"\r\n              mat-icon-button\r\n              color=\"primary\"\r\n              (click)=\"appendIdComponent('partRoleId')\"\r\n            >\r\n              <mat-icon>add_circle</mat-icon>\r\n            </button>\r\n          </td>\r\n          <td>part role ID</td>\r\n          <td>{{ info!.part?.roleId }}</td>\r\n        </tr>\r\n\r\n        <!-- part's metadata -->\r\n        <tr *ngFor=\"let m of info!.part?.metadata; let i = index\">\r\n          <td>\r\n            <button\r\n              type=\"button\"\r\n              mat-icon-button\r\n              color=\"primary\"\r\n              (click)=\"appendIdComponent('metadata', i)\"\r\n            >\r\n              <mat-icon>add_circle</mat-icon>\r\n            </button>\r\n          </td>\r\n          <td class=\"metadata\">{{ m.name }}</td>\r\n          <td class=\"metadata\">{{ m.value }}</td>\r\n        </tr>\r\n      </tbody>\r\n    </table>\r\n  </mat-expansion-panel>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { map } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@myrmidon/cadmus-api";
|
|
5
|
+
class ItemRefLookupService {
|
|
6
|
+
constructor(_itemService) {
|
|
7
|
+
this._itemService = _itemService;
|
|
8
|
+
}
|
|
9
|
+
lookup(filter, options) {
|
|
10
|
+
return this._itemService
|
|
11
|
+
.getItems({
|
|
12
|
+
title: filter.text,
|
|
13
|
+
}, 1, filter.limit || 10)
|
|
14
|
+
.pipe(map((page) => page.items));
|
|
15
|
+
}
|
|
16
|
+
getName(item) {
|
|
17
|
+
return item?.title;
|
|
18
|
+
}
|
|
19
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ItemRefLookupService, deps: [{ token: i1.ItemService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
20
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ItemRefLookupService, providedIn: 'root' }); }
|
|
21
|
+
}
|
|
22
|
+
export { ItemRefLookupService };
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ItemRefLookupService, decorators: [{
|
|
24
|
+
type: Injectable,
|
|
25
|
+
args: [{
|
|
26
|
+
providedIn: 'root',
|
|
27
|
+
}]
|
|
28
|
+
}], ctorParameters: function () { return [{ type: i1.ItemService }]; } });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS1yZWYtbG9va3VwLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJtaWRvbi9jYWRtdXMtcmVmcy1hc3NlcnRlZC1pZHMvc3JjL2xpYi9zZXJ2aWNlcy9pdGVtLXJlZi1sb29rdXAuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBYyxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7OztBQVV2QyxNQUdhLG9CQUFvQjtJQUMvQixZQUFvQixZQUF5QjtRQUF6QixpQkFBWSxHQUFaLFlBQVksQ0FBYTtJQUFHLENBQUM7SUFFMUMsTUFBTSxDQUFDLE1BQXVCLEVBQUUsT0FBYTtRQUNsRCxPQUFPLElBQUksQ0FBQyxZQUFZO2FBQ3JCLFFBQVEsQ0FDUDtZQUNFLEtBQUssRUFBRSxNQUFNLENBQUMsSUFBSTtTQUNuQixFQUNELENBQUMsRUFDRCxNQUFNLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FDbkI7YUFDQSxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBb0IsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVELE9BQU8sQ0FBQyxJQUFVO1FBQ2hCLE9BQU8sSUFBSSxFQUFFLEtBQUssQ0FBQztJQUNyQixDQUFDOzhHQWpCVSxvQkFBb0I7a0hBQXBCLG9CQUFvQixjQUZuQixNQUFNOztTQUVQLG9CQUFvQjsyRkFBcEIsb0JBQW9CO2tCQUhoQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUsIG1hcCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBJdGVtU2VydmljZSB9IGZyb20gJ0BteXJtaWRvbi9jYWRtdXMtYXBpJztcbmltcG9ydCB7IEl0ZW0gfSBmcm9tICdAbXlybWlkb24vY2FkbXVzLWNvcmUnO1xuaW1wb3J0IHtcbiAgUmVmTG9va3VwRmlsdGVyLFxuICBSZWZMb29rdXBTZXJ2aWNlLFxufSBmcm9tICdAbXlybWlkb24vY2FkbXVzLXJlZnMtbG9va3VwJztcbmltcG9ydCB7IERhdGFQYWdlIH0gZnJvbSAnQG15cm1pZG9uL25nLXRvb2xzJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEl0ZW1SZWZMb29rdXBTZXJ2aWNlIGltcGxlbWVudHMgUmVmTG9va3VwU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgX2l0ZW1TZXJ2aWNlOiBJdGVtU2VydmljZSkge31cblxuICBwdWJsaWMgbG9va3VwKGZpbHRlcjogUmVmTG9va3VwRmlsdGVyLCBvcHRpb25zPzogYW55KTogT2JzZXJ2YWJsZTxJdGVtW10+IHtcbiAgICByZXR1cm4gdGhpcy5faXRlbVNlcnZpY2VcbiAgICAgIC5nZXRJdGVtcyhcbiAgICAgICAge1xuICAgICAgICAgIHRpdGxlOiBmaWx0ZXIudGV4dCxcbiAgICAgICAgfSxcbiAgICAgICAgMSxcbiAgICAgICAgZmlsdGVyLmxpbWl0IHx8IDEwXG4gICAgICApXG4gICAgICAucGlwZShtYXAoKHBhZ2U6IERhdGFQYWdlPEl0ZW0+KSA9PiBwYWdlLml0ZW1zKSk7XG4gIH1cblxuICBnZXROYW1lKGl0ZW06IEl0ZW0pOiBzdHJpbmcge1xuICAgIHJldHVybiBpdGVtPy50aXRsZTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { map, of } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@myrmidon/cadmus-api";
|
|
5
|
+
/**
|
|
6
|
+
* Cadmus pin-based lookup data service. The text being searched here is just
|
|
7
|
+
* the pin's value, according to the options specified. These options correspond
|
|
8
|
+
* to an index lookup definition. The resulting items are of type DataPinInfo.
|
|
9
|
+
*/
|
|
10
|
+
class PinRefLookupService {
|
|
11
|
+
constructor(_itemService) {
|
|
12
|
+
this._itemService = _itemService;
|
|
13
|
+
}
|
|
14
|
+
getName(item) {
|
|
15
|
+
return item?.value || '';
|
|
16
|
+
}
|
|
17
|
+
buildQuery(def, filter) {
|
|
18
|
+
const sb = [];
|
|
19
|
+
const AND = ' AND ';
|
|
20
|
+
if (def.typeId) {
|
|
21
|
+
sb.push(`[partTypeId=${def.typeId}]`);
|
|
22
|
+
}
|
|
23
|
+
if (def.roleId) {
|
|
24
|
+
if (sb.length) {
|
|
25
|
+
sb.push(AND);
|
|
26
|
+
}
|
|
27
|
+
sb.push(`[roleId=${def.roleId}]`);
|
|
28
|
+
}
|
|
29
|
+
if (def.name) {
|
|
30
|
+
if (sb.length) {
|
|
31
|
+
sb.push(AND);
|
|
32
|
+
}
|
|
33
|
+
sb.push(`[name=${def.name}]`);
|
|
34
|
+
}
|
|
35
|
+
if (filter.itemId) {
|
|
36
|
+
if (sb.length) {
|
|
37
|
+
sb.push(AND);
|
|
38
|
+
}
|
|
39
|
+
sb.push(`[itemId=${filter.itemId}]`);
|
|
40
|
+
}
|
|
41
|
+
if (filter.partId) {
|
|
42
|
+
if (sb.length) {
|
|
43
|
+
sb.push(AND);
|
|
44
|
+
}
|
|
45
|
+
sb.push(`[partId=${filter.partId}]`);
|
|
46
|
+
}
|
|
47
|
+
if (filter.text) {
|
|
48
|
+
if (sb.length) {
|
|
49
|
+
sb.push(AND);
|
|
50
|
+
}
|
|
51
|
+
// for other operators see backend SqlQueryBuilderBase.cs
|
|
52
|
+
sb.push(`[value*=${filter.text}]`); // *= is "contains"
|
|
53
|
+
}
|
|
54
|
+
return sb.join('');
|
|
55
|
+
}
|
|
56
|
+
lookup(filter, options) {
|
|
57
|
+
// the index lookup definition is required
|
|
58
|
+
const def = options;
|
|
59
|
+
if (!def) {
|
|
60
|
+
return of([]);
|
|
61
|
+
}
|
|
62
|
+
// build the corresponding pin query
|
|
63
|
+
const query = this.buildQuery(def, filter);
|
|
64
|
+
// search the index
|
|
65
|
+
return this._itemService.searchPins(query, 1, filter.limit).pipe(map((w) => {
|
|
66
|
+
if (w.error) {
|
|
67
|
+
console.error(w.error);
|
|
68
|
+
return [];
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
return w.value?.items || [];
|
|
72
|
+
}
|
|
73
|
+
}));
|
|
74
|
+
}
|
|
75
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PinRefLookupService, deps: [{ token: i1.ItemService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
76
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PinRefLookupService, providedIn: 'root' }); }
|
|
77
|
+
}
|
|
78
|
+
export { PinRefLookupService };
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PinRefLookupService, decorators: [{
|
|
80
|
+
type: Injectable,
|
|
81
|
+
args: [{
|
|
82
|
+
providedIn: 'root',
|
|
83
|
+
}]
|
|
84
|
+
}], ctorParameters: function () { return [{ type: i1.ItemService }]; } });
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGluLXJlZi1sb29rdXAuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cm1pZG9uL2NhZG11cy1yZWZzLWFzc2VydGVkLWlkcy9zcmMvbGliL3NlcnZpY2VzL3Bpbi1yZWYtbG9va3VwLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsR0FBRyxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7O0FBb0IzQzs7OztHQUlHO0FBQ0gsTUFHYSxtQkFBbUI7SUFDOUIsWUFBb0IsWUFBeUI7UUFBekIsaUJBQVksR0FBWixZQUFZLENBQWE7SUFBRyxDQUFDO0lBRTFDLE9BQU8sQ0FBQyxJQUFxQjtRQUNsQyxPQUFPLElBQUksRUFBRSxLQUFLLElBQUksRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFTyxVQUFVLENBQ2hCLEdBQTBCLEVBQzFCLE1BQTBCO1FBRTFCLE1BQU0sRUFBRSxHQUFhLEVBQUUsQ0FBQztRQUN4QixNQUFNLEdBQUcsR0FBRyxPQUFPLENBQUM7UUFFcEIsSUFBSSxHQUFHLENBQUMsTUFBTSxFQUFFO1lBQ2QsRUFBRSxDQUFDLElBQUksQ0FBQyxlQUFlLEdBQUcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1NBQ3ZDO1FBQ0QsSUFBSSxHQUFHLENBQUMsTUFBTSxFQUFFO1lBQ2QsSUFBSSxFQUFFLENBQUMsTUFBTSxFQUFFO2dCQUNiLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7YUFDZDtZQUNELEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztTQUNuQztRQUNELElBQUksR0FBRyxDQUFDLElBQUksRUFBRTtZQUNaLElBQUksRUFBRSxDQUFDLE1BQU0sRUFBRTtnQkFDYixFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2FBQ2Q7WUFDRCxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUM7U0FDL0I7UUFDRCxJQUFJLE1BQU0sQ0FBQyxNQUFNLEVBQUU7WUFDakIsSUFBSSxFQUFFLENBQUMsTUFBTSxFQUFFO2dCQUNiLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7YUFDZDtZQUNELEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztTQUN0QztRQUNELElBQUksTUFBTSxDQUFDLE1BQU0sRUFBRTtZQUNqQixJQUFJLEVBQUUsQ0FBQyxNQUFNLEVBQUU7Z0JBQ2IsRUFBRSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUNkO1lBQ0QsRUFBRSxDQUFDLElBQUksQ0FBQyxXQUFXLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1NBQ3RDO1FBQ0QsSUFBSSxNQUFNLENBQUMsSUFBSSxFQUFFO1lBQ2YsSUFBSSxFQUFFLENBQUMsTUFBTSxFQUFFO2dCQUNiLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7YUFDZDtZQUNELHlEQUF5RDtZQUN6RCxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsTUFBTSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsQ0FBQyxtQkFBbUI7U0FDeEQ7UUFFRCxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDckIsQ0FBQztJQUVNLE1BQU0sQ0FBQyxNQUEwQixFQUFFLE9BQWE7UUFDckQsMENBQTBDO1FBQzFDLE1BQU0sR0FBRyxHQUFHLE9BQWdDLENBQUM7UUFDN0MsSUFBSSxDQUFDLEdBQUcsRUFBRTtZQUNSLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1NBQ2Y7UUFFRCxvQ0FBb0M7UUFDcEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFM0MsbUJBQW1CO1FBQ25CLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLENBQUMsRUFBRSxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBSSxDQUM5RCxHQUFHLENBQUMsQ0FBQyxDQUFzQyxFQUFFLEVBQUU7WUFDN0MsSUFBSSxDQUFDLENBQUMsS0FBSyxFQUFFO2dCQUNYLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUN2QixPQUFPLEVBQUUsQ0FBQzthQUNYO2lCQUFNO2dCQUNMLE9BQU8sQ0FBQyxDQUFDLEtBQUssRUFBRSxLQUFLLElBQUksRUFBRSxDQUFDO2FBQzdCO1FBQ0gsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7OEdBekVVLG1CQUFtQjtrSEFBbkIsbUJBQW1CLGNBRmxCLE1BQU07O1NBRVAsbUJBQW1COzJGQUFuQixtQkFBbUI7a0JBSC9CLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgbWFwLCBPYnNlcnZhYmxlLCBvZiB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBJdGVtU2VydmljZSB9IGZyb20gJ0BteXJtaWRvbi9jYWRtdXMtYXBpJztcbmltcG9ydCB7IERhdGFQaW5JbmZvLCBJbmRleExvb2t1cERlZmluaXRpb24gfSBmcm9tICdAbXlybWlkb24vY2FkbXVzLWNvcmUnO1xuaW1wb3J0IHtcbiAgUmVmTG9va3VwRmlsdGVyLFxuICBSZWZMb29rdXBTZXJ2aWNlLFxufSBmcm9tICdAbXlybWlkb24vY2FkbXVzLXJlZnMtbG9va3VwJztcbmltcG9ydCB7IERhdGFQYWdlLCBFcnJvcldyYXBwZXIgfSBmcm9tICdAbXlybWlkb24vbmctdG9vbHMnO1xuXG4vKipcbiAqIFBpbi1iYXNlZCBsb29rdXAgZmlsdGVyLiBUaGlzIGlzIGEgUmVmTG9va3VwRmlsdGVyIHdpdGggdGhlIGFkZGl0aW9uXG4gKiBvZiB0aGUgaXRlbSBJRCBhbmQgcGFydCBJRCwgd2hpY2ggYXJlIHVzZWQgdG8gZmlsdGVyIHRoZSByZXN1bHRzXG4gKiBieSB0aGUgSXRlbVBpbkxvb2t1cENvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQaW5SZWZMb29rdXBGaWx0ZXIgZXh0ZW5kcyBSZWZMb29rdXBGaWx0ZXIge1xuICBpdGVtSWQ/OiBzdHJpbmc7XG4gIHBhcnRJZD86IHN0cmluZztcbn1cblxuLyoqXG4gKiBDYWRtdXMgcGluLWJhc2VkIGxvb2t1cCBkYXRhIHNlcnZpY2UuIFRoZSB0ZXh0IGJlaW5nIHNlYXJjaGVkIGhlcmUgaXMganVzdFxuICogdGhlIHBpbidzIHZhbHVlLCBhY2NvcmRpbmcgdG8gdGhlIG9wdGlvbnMgc3BlY2lmaWVkLiBUaGVzZSBvcHRpb25zIGNvcnJlc3BvbmRcbiAqIHRvIGFuIGluZGV4IGxvb2t1cCBkZWZpbml0aW9uLiBUaGUgcmVzdWx0aW5nIGl0ZW1zIGFyZSBvZiB0eXBlIERhdGFQaW5JbmZvLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgUGluUmVmTG9va3VwU2VydmljZSBpbXBsZW1lbnRzIFJlZkxvb2t1cFNlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9pdGVtU2VydmljZTogSXRlbVNlcnZpY2UpIHt9XG5cbiAgcHVibGljIGdldE5hbWUoaXRlbTogYW55IHwgdW5kZWZpbmVkKTogc3RyaW5nIHtcbiAgICByZXR1cm4gaXRlbT8udmFsdWUgfHwgJyc7XG4gIH1cblxuICBwcml2YXRlIGJ1aWxkUXVlcnkoXG4gICAgZGVmOiBJbmRleExvb2t1cERlZmluaXRpb24sXG4gICAgZmlsdGVyOiBQaW5SZWZMb29rdXBGaWx0ZXJcbiAgKTogc3RyaW5nIHtcbiAgICBjb25zdCBzYjogc3RyaW5nW10gPSBbXTtcbiAgICBjb25zdCBBTkQgPSAnIEFORCAnO1xuXG4gICAgaWYgKGRlZi50eXBlSWQpIHtcbiAgICAgIHNiLnB1c2goYFtwYXJ0VHlwZUlkPSR7ZGVmLnR5cGVJZH1dYCk7XG4gICAgfVxuICAgIGlmIChkZWYucm9sZUlkKSB7XG4gICAgICBpZiAoc2IubGVuZ3RoKSB7XG4gICAgICAgIHNiLnB1c2goQU5EKTtcbiAgICAgIH1cbiAgICAgIHNiLnB1c2goYFtyb2xlSWQ9JHtkZWYucm9sZUlkfV1gKTtcbiAgICB9XG4gICAgaWYgKGRlZi5uYW1lKSB7XG4gICAgICBpZiAoc2IubGVuZ3RoKSB7XG4gICAgICAgIHNiLnB1c2goQU5EKTtcbiAgICAgIH1cbiAgICAgIHNiLnB1c2goYFtuYW1lPSR7ZGVmLm5hbWV9XWApO1xuICAgIH1cbiAgICBpZiAoZmlsdGVyLml0ZW1JZCkge1xuICAgICAgaWYgKHNiLmxlbmd0aCkge1xuICAgICAgICBzYi5wdXNoKEFORCk7XG4gICAgICB9XG4gICAgICBzYi5wdXNoKGBbaXRlbUlkPSR7ZmlsdGVyLml0ZW1JZH1dYCk7XG4gICAgfVxuICAgIGlmIChmaWx0ZXIucGFydElkKSB7XG4gICAgICBpZiAoc2IubGVuZ3RoKSB7XG4gICAgICAgIHNiLnB1c2goQU5EKTtcbiAgICAgIH1cbiAgICAgIHNiLnB1c2goYFtwYXJ0SWQ9JHtmaWx0ZXIucGFydElkfV1gKTtcbiAgICB9XG4gICAgaWYgKGZpbHRlci50ZXh0KSB7XG4gICAgICBpZiAoc2IubGVuZ3RoKSB7XG4gICAgICAgIHNiLnB1c2goQU5EKTtcbiAgICAgIH1cbiAgICAgIC8vIGZvciBvdGhlciBvcGVyYXRvcnMgc2VlIGJhY2tlbmQgU3FsUXVlcnlCdWlsZGVyQmFzZS5jc1xuICAgICAgc2IucHVzaChgW3ZhbHVlKj0ke2ZpbHRlci50ZXh0fV1gKTsgLy8gKj0gaXMgXCJjb250YWluc1wiXG4gICAgfVxuXG4gICAgcmV0dXJuIHNiLmpvaW4oJycpO1xuICB9XG5cbiAgcHVibGljIGxvb2t1cChmaWx0ZXI6IFBpblJlZkxvb2t1cEZpbHRlciwgb3B0aW9ucz86IGFueSk6IE9ic2VydmFibGU8YW55W10+IHtcbiAgICAvLyB0aGUgaW5kZXggbG9va3VwIGRlZmluaXRpb24gaXMgcmVxdWlyZWRcbiAgICBjb25zdCBkZWYgPSBvcHRpb25zIGFzIEluZGV4TG9va3VwRGVmaW5pdGlvbjtcbiAgICBpZiAoIWRlZikge1xuICAgICAgcmV0dXJuIG9mKFtdKTtcbiAgICB9XG5cbiAgICAvLyBidWlsZCB0aGUgY29ycmVzcG9uZGluZyBwaW4gcXVlcnlcbiAgICBjb25zdCBxdWVyeSA9IHRoaXMuYnVpbGRRdWVyeShkZWYsIGZpbHRlcik7XG5cbiAgICAvLyBzZWFyY2ggdGhlIGluZGV4XG4gICAgcmV0dXJuIHRoaXMuX2l0ZW1TZXJ2aWNlLnNlYXJjaFBpbnMocXVlcnksIDEsIGZpbHRlci5saW1pdCkucGlwZShcbiAgICAgIG1hcCgodzogRXJyb3JXcmFwcGVyPERhdGFQYWdlPERhdGFQaW5JbmZvPj4pID0+IHtcbiAgICAgICAgaWYgKHcuZXJyb3IpIHtcbiAgICAgICAgICBjb25zb2xlLmVycm9yKHcuZXJyb3IpO1xuICAgICAgICAgIHJldHVybiBbXTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXR1cm4gdy52YWx1ZT8uaXRlbXMgfHwgW107XG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgKTtcbiAgfVxufVxuIl19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './public-api';
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
5
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXlybWlkb24tY2FkbXVzLXJlZnMtYXNzZXJ0ZWQtaWRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlybWlkb24vY2FkbXVzLXJlZnMtYXNzZXJ0ZWQtaWRzL3NyYy9teXJtaWRvbi1jYWRtdXMtcmVmcy1hc3NlcnRlZC1pZHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of cadmus-refs-asserted-ids
|
|
3
|
+
*/
|
|
4
|
+
export * from './lib/asserted-id/asserted-id.component';
|
|
5
|
+
export * from './lib/asserted-ids/asserted-ids.component';
|
|
6
|
+
export * from './lib/scoped-pin-lookup/scoped-pin-lookup.component';
|
|
7
|
+
export * from './lib/asserted-composite-id/asserted-composite-id.component';
|
|
8
|
+
export * from './lib/asserted-composite-ids/asserted-composite-ids.component';
|
|
9
|
+
export * from './lib/pin-target-lookup/pin-target-lookup.component';
|
|
10
|
+
export * from './lib/services/pin-ref-lookup.service';
|
|
11
|
+
export * from './lib/services/item-ref-lookup.service';
|
|
12
|
+
export * from './lib/cadmus-refs-asserted-ids.module';
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL215cm1pZG9uL2NhZG11cy1yZWZzLWFzc2VydGVkLWlkcy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYywrREFBK0QsQ0FBQztBQUM5RSxjQUFjLHFEQUFxRCxDQUFDO0FBRXBFLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx3Q0FBd0MsQ0FBQztBQUV2RCxjQUFjLHVDQUF1QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGNhZG11cy1yZWZzLWFzc2VydGVkLWlkc1xyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Fzc2VydGVkLWlkL2Fzc2VydGVkLWlkLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Fzc2VydGVkLWlkcy9hc3NlcnRlZC1pZHMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2NvcGVkLXBpbi1sb29rdXAvc2NvcGVkLXBpbi1sb29rdXAuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYXNzZXJ0ZWQtY29tcG9zaXRlLWlkL2Fzc2VydGVkLWNvbXBvc2l0ZS1pZC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hc3NlcnRlZC1jb21wb3NpdGUtaWRzL2Fzc2VydGVkLWNvbXBvc2l0ZS1pZHMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcGluLXRhcmdldC1sb29rdXAvcGluLXRhcmdldC1sb29rdXAuY29tcG9uZW50JztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL3Bpbi1yZWYtbG9va3VwLnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9pdGVtLXJlZi1sb29rdXAuc2VydmljZSc7XHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jYWRtdXMtcmVmcy1hc3NlcnRlZC1pZHMubW9kdWxlJztcclxuIl19
|