@myrmidon/cadmus-refs-asserted-ids 1.0.3 → 1.0.6
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 +30 -11
- package/esm2020/lib/asserted-id/asserted-id.component.mjs +51 -18
- package/esm2020/lib/asserted-ids/asserted-ids.component.mjs +91 -156
- package/esm2020/lib/cadmus-refs-asserted-ids.module.mjs +30 -9
- package/esm2020/lib/scoped-pin-lookup/scoped-pin-lookup.component.mjs +129 -0
- package/esm2020/lib/services/pin-ref-lookup.service.mjs +71 -0
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/myrmidon-cadmus-refs-asserted-ids.mjs +351 -174
- package/fesm2015/myrmidon-cadmus-refs-asserted-ids.mjs.map +1 -1
- package/fesm2020/myrmidon-cadmus-refs-asserted-ids.mjs +345 -173
- package/fesm2020/myrmidon-cadmus-refs-asserted-ids.mjs.map +1 -1
- package/lib/asserted-id/asserted-id.component.d.ts +16 -3
- package/lib/asserted-ids/asserted-ids.component.d.ts +20 -30
- package/lib/cadmus-refs-asserted-ids.module.d.ts +15 -12
- package/lib/scoped-pin-lookup/scoped-pin-lookup.component.d.ts +39 -0
- package/lib/services/pin-ref-lookup.service.d.ts +18 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -1,28 +1,26 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output,
|
|
2
|
-
import {
|
|
3
|
-
import { debounceTime } from 'rxjs/operators';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
+
import { take } from 'rxjs';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
import * as i1 from "@angular/forms";
|
|
6
|
-
import * as i2 from "@
|
|
7
|
-
import * as i3 from "@angular/
|
|
8
|
-
import * as i4 from "@angular/material/
|
|
9
|
-
import * as i5 from "@angular/material/
|
|
5
|
+
import * as i2 from "@myrmidon/ng-mat-tools";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "@angular/material/button";
|
|
8
|
+
import * as i5 from "@angular/material/expansion";
|
|
10
9
|
import * as i6 from "@angular/material/icon";
|
|
11
|
-
import * as i7 from "
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
10
|
+
import * as i7 from "../asserted-id/asserted-id.component";
|
|
11
|
+
/**
|
|
12
|
+
* Asserted IDs editor.
|
|
13
|
+
*/
|
|
15
14
|
export class AssertedIdsComponent {
|
|
16
|
-
constructor(
|
|
17
|
-
this.
|
|
15
|
+
constructor(formBuilder, _dialogService) {
|
|
16
|
+
this._dialogService = _dialogService;
|
|
18
17
|
this._ids = [];
|
|
19
|
-
this.
|
|
18
|
+
this._editedIndex = -1;
|
|
20
19
|
this.idsChange = new EventEmitter();
|
|
21
|
-
this.
|
|
20
|
+
this.entries = formBuilder.control([], { nonNullable: true });
|
|
22
21
|
// form
|
|
23
|
-
this.
|
|
24
|
-
|
|
25
|
-
idsArr: this.idsArr,
|
|
22
|
+
this.form = formBuilder.group({
|
|
23
|
+
ids: this.entries,
|
|
26
24
|
});
|
|
27
25
|
}
|
|
28
26
|
/**
|
|
@@ -37,163 +35,100 @@ export class AssertedIdsComponent {
|
|
|
37
35
|
this.updateForm(value);
|
|
38
36
|
}
|
|
39
37
|
}
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
.subscribe((lst) => {
|
|
45
|
-
if (!this._updatingForm && lst.length > 0) {
|
|
46
|
-
lst.last.nativeElement.focus();
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
unsubscribeIds() {
|
|
51
|
-
for (let i = 0; i < this._idsSubs.length; i++) {
|
|
52
|
-
this._idsSubs[i].unsubscribe();
|
|
38
|
+
updateForm(ids) {
|
|
39
|
+
if (!ids?.length) {
|
|
40
|
+
this.form.reset();
|
|
41
|
+
return;
|
|
53
42
|
}
|
|
43
|
+
this.entries.setValue(ids, { emitEvent: false });
|
|
44
|
+
this.entries.updateValueAndValidity();
|
|
45
|
+
this.form.markAsPristine();
|
|
54
46
|
}
|
|
55
|
-
|
|
56
|
-
this.
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
value:
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
if (!this._updatingForm) {
|
|
77
|
-
this.emitIdsChange();
|
|
47
|
+
emitIdsChange() {
|
|
48
|
+
this.idsChange.emit(this.entries.value);
|
|
49
|
+
}
|
|
50
|
+
addId() {
|
|
51
|
+
this.editId({
|
|
52
|
+
scope: '',
|
|
53
|
+
value: '',
|
|
54
|
+
}, -1);
|
|
55
|
+
}
|
|
56
|
+
editId(id, index) {
|
|
57
|
+
this._editedIndex = index;
|
|
58
|
+
this.edited = id;
|
|
59
|
+
}
|
|
60
|
+
closeId() {
|
|
61
|
+
this._editedIndex = -1;
|
|
62
|
+
this.edited = undefined;
|
|
63
|
+
}
|
|
64
|
+
saveId(entry) {
|
|
65
|
+
const entries = [...this.entries.value];
|
|
66
|
+
if (this._editedIndex === -1) {
|
|
67
|
+
entries.push(entry);
|
|
78
68
|
}
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
this.closeAssertion();
|
|
82
|
-
this._idsSubs[index].unsubscribe();
|
|
83
|
-
this._idsSubs.splice(index, 1);
|
|
84
|
-
this.idsArr.removeAt(index);
|
|
85
|
-
this.emitIdsChange();
|
|
86
|
-
}
|
|
87
|
-
swapArrElems(a, i, j) {
|
|
88
|
-
if (i === j) {
|
|
89
|
-
return;
|
|
69
|
+
else {
|
|
70
|
+
entries.splice(this._editedIndex, 1, entry);
|
|
90
71
|
}
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
72
|
+
this.entries.setValue(entries);
|
|
73
|
+
this.entries.markAsDirty();
|
|
74
|
+
this.entries.updateValueAndValidity();
|
|
75
|
+
this.closeId();
|
|
76
|
+
}
|
|
77
|
+
deleteId(index) {
|
|
78
|
+
this._dialogService
|
|
79
|
+
.confirm('Confirmation', 'Delete ID?')
|
|
80
|
+
.pipe(take(1))
|
|
81
|
+
.subscribe((yes) => {
|
|
82
|
+
if (yes) {
|
|
83
|
+
if (this._editedIndex === index) {
|
|
84
|
+
this.closeId();
|
|
85
|
+
}
|
|
86
|
+
const entries = [...this.entries.value];
|
|
87
|
+
entries.splice(index, 1);
|
|
88
|
+
this.entries.setValue(entries);
|
|
89
|
+
this.entries.markAsDirty();
|
|
90
|
+
this.entries.updateValueAndValidity();
|
|
91
|
+
this.emitIdsChange();
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
94
|
}
|
|
95
95
|
moveIdUp(index) {
|
|
96
96
|
if (index < 1) {
|
|
97
97
|
return;
|
|
98
98
|
}
|
|
99
|
-
this.
|
|
100
|
-
const
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
this.
|
|
99
|
+
const entry = this.entries.value[index];
|
|
100
|
+
const entries = [...this.entries.value];
|
|
101
|
+
entries.splice(index, 1);
|
|
102
|
+
entries.splice(index - 1, 0, entry);
|
|
103
|
+
this.entries.setValue(entries);
|
|
104
|
+
this.entries.markAsDirty();
|
|
105
|
+
this.entries.updateValueAndValidity();
|
|
104
106
|
this.emitIdsChange();
|
|
105
107
|
}
|
|
106
108
|
moveIdDown(index) {
|
|
107
|
-
if (index + 1 >= this.
|
|
109
|
+
if (index + 1 >= this.entries.value.length) {
|
|
108
110
|
return;
|
|
109
111
|
}
|
|
110
|
-
this.
|
|
111
|
-
const
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
this.
|
|
112
|
+
const entry = this.entries.value[index];
|
|
113
|
+
const entries = [...this.entries.value];
|
|
114
|
+
entries.splice(index, 1);
|
|
115
|
+
entries.splice(index + 1, 0, entry);
|
|
116
|
+
this.entries.setValue(entries);
|
|
117
|
+
this.entries.markAsDirty();
|
|
118
|
+
this.entries.updateValueAndValidity();
|
|
115
119
|
this.emitIdsChange();
|
|
116
120
|
}
|
|
117
|
-
|
|
118
|
-
this.
|
|
119
|
-
this.idsArr.clear();
|
|
120
|
-
this.unsubscribeIds();
|
|
121
|
-
this._idsSubs = [];
|
|
122
|
-
if (!this._updatingForm) {
|
|
123
|
-
this.emitIdsChange();
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
editAssertion(index) {
|
|
127
|
-
// save the currently edited assertion if any
|
|
128
|
-
this.saveAssertion();
|
|
129
|
-
// edit the new assertion
|
|
130
|
-
this.initialAssertion = this.idsArr.at(index).controls['assertion'].value;
|
|
131
|
-
this.assertionNr = index + 1;
|
|
132
|
-
this.assEdOpen = true;
|
|
133
|
-
}
|
|
134
|
-
onAssertionChange(assertion) {
|
|
135
|
-
this.assertion = assertion;
|
|
136
|
-
}
|
|
137
|
-
saveAssertion() {
|
|
138
|
-
// save the currently edited assertion if any
|
|
139
|
-
if (this.assertionNr) {
|
|
140
|
-
const g = this.idsArr.at(this.assertionNr - 1);
|
|
141
|
-
g.controls['assertion'].setValue(this.assertion);
|
|
142
|
-
this.closeAssertion();
|
|
143
|
-
this.emitIdsChange();
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
closeAssertion() {
|
|
147
|
-
if (this.assertionNr) {
|
|
148
|
-
this.assEdOpen = false;
|
|
149
|
-
this.assertionNr = 0;
|
|
150
|
-
this.initialAssertion = undefined;
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
updateForm(ids) {
|
|
154
|
-
if (!this.idsArr) {
|
|
155
|
-
return;
|
|
156
|
-
}
|
|
157
|
-
this._updatingForm = true;
|
|
158
|
-
this.clearIds();
|
|
159
|
-
if (!ids) {
|
|
160
|
-
this.form.reset();
|
|
161
|
-
}
|
|
162
|
-
else {
|
|
163
|
-
for (const id of ids) {
|
|
164
|
-
this.addId(id);
|
|
165
|
-
}
|
|
166
|
-
this.form.markAsPristine();
|
|
167
|
-
}
|
|
168
|
-
this._updatingForm = false;
|
|
121
|
+
onIdChange(id) {
|
|
122
|
+
this.saveId(id);
|
|
169
123
|
this.emitIdsChange();
|
|
170
124
|
}
|
|
171
|
-
getIds() {
|
|
172
|
-
const ids = [];
|
|
173
|
-
for (let i = 0; i < this.idsArr.length; i++) {
|
|
174
|
-
const g = this.idsArr.controls[i];
|
|
175
|
-
ids.push({
|
|
176
|
-
value: g.controls.value.value?.trim(),
|
|
177
|
-
scope: g.controls.scope.value?.trim(),
|
|
178
|
-
tag: g.controls.tag.value?.trim(),
|
|
179
|
-
assertion: g.controls.assertion.value,
|
|
180
|
-
});
|
|
181
|
-
}
|
|
182
|
-
return ids;
|
|
183
|
-
}
|
|
184
|
-
emitIdsChange() {
|
|
185
|
-
this.idsChange.emit(this.getIds());
|
|
186
|
-
}
|
|
187
125
|
}
|
|
188
|
-
AssertedIdsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
189
|
-
AssertedIdsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.
|
|
190
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
126
|
+
AssertedIdsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: AssertedIdsComponent, deps: [{ token: i1.FormBuilder }, { token: i2.DialogService }], target: i0.ɵɵFactoryTarget.Component });
|
|
127
|
+
AssertedIdsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: AssertedIdsComponent, selector: "cadmus-refs-asserted-ids", inputs: { ids: "ids", scopeEntries: "scopeEntries", tagEntries: "tagEntries", assTagEntries: "assTagEntries", refTypeEntries: "refTypeEntries", refTagEntries: "refTagEntries" }, outputs: { idsChange: "idsChange" }, ngImport: i0, template: "<form [formGroup]=\"form\">\r\n <div>\r\n <button type=\"button\" mat-flat-button color=\"primary\" (click)=\"addId()\">\r\n <mat-icon>add_circle</mat-icon> ID\r\n </button>\r\n </div>\r\n <table *ngIf=\"entries.value?.length\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n <th>scope</th>\r\n <th>value</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr\r\n *ngFor=\"\r\n let entry of entries.value;\r\n let i = index;\r\n let first = first;\r\n let last = last\r\n \"\r\n >\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n matTooltip=\"Edit this ID\"\r\n (click)=\"editId(entry, i)\"\r\n >\r\n <mat-icon>edit</mat-icon>\r\n </button>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n matTooltip=\"Move this ID up\"\r\n [disabled]=\"first\"\r\n (click)=\"moveIdUp(i)\"\r\n >\r\n <mat-icon>arrow_upward</mat-icon>\r\n </button>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n matTooltip=\"Move this ID down\"\r\n [disabled]=\"last\"\r\n (click)=\"moveIdDown(i)\"\r\n >\r\n <mat-icon>arrow_downward</mat-icon>\r\n </button>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"warn\"\r\n matTooltip=\"Delete this ID\"\r\n (click)=\"deleteId(i)\"\r\n >\r\n <mat-icon>remove_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>{{ entry.scope }}</td>\r\n <td>{{ entry.value }}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <mat-expansion-panel [expanded]=\"edited\" [disabled]=\"!edited\">\r\n <mat-expansion-panel-header>ID</mat-expansion-panel-header>\r\n <cadmus-refs-asserted-id\r\n [hasSubmit]=\"true\"\r\n [id]=\"edited\"\r\n (idChange)=\"onIdChange($event)\"\r\n (editorClose)=\"closeId()\"\r\n ></cadmus-refs-asserted-id>\r\n </mat-expansion-panel>\r\n</form>\r\n", styles: ["th{font-weight:400;color:silver;text-align:left}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i5.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.AssertedIdComponent, selector: "cadmus-refs-asserted-id", inputs: ["scopeEntries", "idTagEntries", "assTagEntries", "refTypeEntries", "refTagEntries", "id", "noEidLookup", "hasSubmit"], outputs: ["idChange", "editorClose"] }] });
|
|
128
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: AssertedIdsComponent, decorators: [{
|
|
191
129
|
type: Component,
|
|
192
|
-
args: [{ selector: 'cadmus-refs-asserted-ids', template: "<form [formGroup]=\"form\">\r\n <div
|
|
193
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: {
|
|
194
|
-
type: ViewChildren,
|
|
195
|
-
args: ['id']
|
|
196
|
-
}], ids: [{
|
|
130
|
+
args: [{ selector: 'cadmus-refs-asserted-ids', template: "<form [formGroup]=\"form\">\r\n <div>\r\n <button type=\"button\" mat-flat-button color=\"primary\" (click)=\"addId()\">\r\n <mat-icon>add_circle</mat-icon> ID\r\n </button>\r\n </div>\r\n <table *ngIf=\"entries.value?.length\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n <th>scope</th>\r\n <th>value</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr\r\n *ngFor=\"\r\n let entry of entries.value;\r\n let i = index;\r\n let first = first;\r\n let last = last\r\n \"\r\n >\r\n <td>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"primary\"\r\n matTooltip=\"Edit this ID\"\r\n (click)=\"editId(entry, i)\"\r\n >\r\n <mat-icon>edit</mat-icon>\r\n </button>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n matTooltip=\"Move this ID up\"\r\n [disabled]=\"first\"\r\n (click)=\"moveIdUp(i)\"\r\n >\r\n <mat-icon>arrow_upward</mat-icon>\r\n </button>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n matTooltip=\"Move this ID down\"\r\n [disabled]=\"last\"\r\n (click)=\"moveIdDown(i)\"\r\n >\r\n <mat-icon>arrow_downward</mat-icon>\r\n </button>\r\n <button\r\n type=\"button\"\r\n mat-icon-button\r\n color=\"warn\"\r\n matTooltip=\"Delete this ID\"\r\n (click)=\"deleteId(i)\"\r\n >\r\n <mat-icon>remove_circle</mat-icon>\r\n </button>\r\n </td>\r\n <td>{{ entry.scope }}</td>\r\n <td>{{ entry.value }}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <mat-expansion-panel [expanded]=\"edited\" [disabled]=\"!edited\">\r\n <mat-expansion-panel-header>ID</mat-expansion-panel-header>\r\n <cadmus-refs-asserted-id\r\n [hasSubmit]=\"true\"\r\n [id]=\"edited\"\r\n (idChange)=\"onIdChange($event)\"\r\n (editorClose)=\"closeId()\"\r\n ></cadmus-refs-asserted-id>\r\n </mat-expansion-panel>\r\n</form>\r\n", styles: ["th{font-weight:400;color:silver;text-align:left}\n"] }]
|
|
131
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.DialogService }]; }, propDecorators: { ids: [{
|
|
197
132
|
type: Input
|
|
198
133
|
}], scopeEntries: [{
|
|
199
134
|
type: Input
|
|
@@ -208,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
|
|
|
208
143
|
}], idsChange: [{
|
|
209
144
|
type: Output
|
|
210
145
|
}] } });
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asserted-ids.component.js","sourceRoot":"","sources":["../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-ids/asserted-ids.component.ts","../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-ids/asserted-ids.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  QueryList,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { FormArray, FormBuilder, FormGroup, Validators } from '@angular/forms';\r\n\r\nimport { ThesaurusEntry } from '@myrmidon/cadmus-core';\r\nimport { Assertion } from '@myrmidon/cadmus-refs-assertion';\r\n\r\nimport { Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { AssertedId } from '../asserted-id/asserted-id.component';\r\n\r\n@Component({\r\n  selector: 'cadmus-refs-asserted-ids',\r\n  templateUrl: './asserted-ids.component.html',\r\n  styleUrls: ['./asserted-ids.component.css'],\r\n})\r\nexport class AssertedIdsComponent implements OnDestroy {\r\n  private _ids: AssertedId[];\r\n  private _idSubscription: Subscription | undefined;\r\n  private _idsSubs: Subscription[];\r\n  private _updatingForm: boolean | undefined;\r\n\r\n  @ViewChildren('id') idQueryList: QueryList<any> | undefined;\r\n\r\n  /**\r\n   * The asserted IDs.\r\n   */\r\n  @Input()\r\n  public get ids(): AssertedId[] {\r\n    return this._ids;\r\n  }\r\n  public set ids(value: AssertedId[]) {\r\n    if (this._ids !== value) {\r\n      this._ids = value || [];\r\n      this.updateForm(value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * The ID scopes thesaurus entries.\r\n   */\r\n  @Input()\r\n  public scopeEntries: ThesaurusEntry[] | undefined;\r\n\r\n  /**\r\n   * The ID tags thesaurus entries.\r\n   */\r\n  @Input()\r\n  public tagEntries: ThesaurusEntry[] | undefined;\r\n\r\n  // thesauri for assertions\r\n  @Input()\r\n  public assTagEntries?: ThesaurusEntry[];\r\n\r\n  @Input()\r\n  public refTypeEntries: ThesaurusEntry[] | undefined;\r\n\r\n  @Input()\r\n  public refTagEntries: ThesaurusEntry[] | undefined;\r\n\r\n  /**\r\n   * Emitted whenever any ID changes.\r\n   */\r\n  @Output()\r\n  public idsChange: EventEmitter<AssertedId[]>;\r\n\r\n  public idsArr: FormArray;\r\n  public form: FormGroup;\r\n  // edited assertion\r\n  public assEdOpen: boolean;\r\n  public assertionNr?: number;\r\n  public initialAssertion?: Assertion;\r\n  public assertion?: Assertion;\r\n\r\n  constructor(private _formBuilder: FormBuilder) {\r\n    this._ids = [];\r\n    this._idsSubs = [];\r\n    this.idsChange = new EventEmitter<AssertedId[]>();\r\n    this.assEdOpen = false;\r\n    // form\r\n    this.idsArr = _formBuilder.array([]);\r\n    this.form = _formBuilder.group({\r\n      idsArr: this.idsArr,\r\n    });\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    // focus on newly added ID\r\n    this._idSubscription = this.idQueryList?.changes\r\n      .pipe(debounceTime(300))\r\n      .subscribe((lst: QueryList<any>) => {\r\n        if (!this._updatingForm && lst.length > 0) {\r\n          lst.last.nativeElement.focus();\r\n        }\r\n      });\r\n  }\r\n\r\n  private unsubscribeIds(): void {\r\n    for (let i = 0; i < this._idsSubs.length; i++) {\r\n      this._idsSubs[i].unsubscribe();\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.unsubscribeIds();\r\n    this._idSubscription?.unsubscribe();\r\n  }\r\n\r\n  private getIdGroup(id?: AssertedId): FormGroup {\r\n    return this._formBuilder.group({\r\n      value: this._formBuilder.control(id?.value, [\r\n        Validators.required,\r\n        Validators.maxLength(500),\r\n      ]),\r\n      scope: this._formBuilder.control(id?.scope, Validators.maxLength(50)),\r\n      tag: this._formBuilder.control(id?.tag, Validators.maxLength(50)),\r\n      assertion: this._formBuilder.control(id?.assertion),\r\n    });\r\n  }\r\n\r\n  public addId(id?: AssertedId): void {\r\n    const g = this.getIdGroup(id);\r\n    this._idsSubs.push(\r\n      g.valueChanges.pipe(debounceTime(300)).subscribe((_) => {\r\n        this.emitIdsChange();\r\n      })\r\n    );\r\n    this.idsArr.push(g);\r\n    if (!this._updatingForm) {\r\n      this.emitIdsChange();\r\n    }\r\n  }\r\n\r\n  public removeId(index: number): void {\r\n    this.closeAssertion();\r\n    this._idsSubs[index].unsubscribe();\r\n    this._idsSubs.splice(index, 1);\r\n    this.idsArr.removeAt(index);\r\n    this.emitIdsChange();\r\n  }\r\n\r\n  private swapArrElems(a: any[], i: number, j: number): void {\r\n    if (i === j) {\r\n      return;\r\n    }\r\n    const t = a[i];\r\n    a[i] = a[j];\r\n    a[j] = t;\r\n  }\r\n\r\n  public moveIdUp(index: number): void {\r\n    if (index < 1) {\r\n      return;\r\n    }\r\n    this.closeAssertion();\r\n    const ctl = this.idsArr.controls[index];\r\n    this.idsArr.removeAt(index);\r\n    this.idsArr.insert(index - 1, ctl);\r\n\r\n    this.swapArrElems(this._idsSubs, index, index - 1);\r\n\r\n    this.emitIdsChange();\r\n  }\r\n\r\n  public moveIdDown(index: number): void {\r\n    if (index + 1 >= this.idsArr.length) {\r\n      return;\r\n    }\r\n    this.closeAssertion();\r\n    const item = this.idsArr.controls[index];\r\n    this.idsArr.removeAt(index);\r\n    this.idsArr.insert(index + 1, item);\r\n\r\n    this.swapArrElems(this._idsSubs, index, index + 1);\r\n\r\n    this.emitIdsChange();\r\n  }\r\n\r\n  public clearIds(): void {\r\n    this.closeAssertion();\r\n    this.idsArr.clear();\r\n    this.unsubscribeIds();\r\n    this._idsSubs = [];\r\n    if (!this._updatingForm) {\r\n      this.emitIdsChange();\r\n    }\r\n  }\r\n\r\n  public editAssertion(index: number): void {\r\n    // save the currently edited assertion if any\r\n    this.saveAssertion();\r\n    // edit the new assertion\r\n    this.initialAssertion = (this.idsArr.at(index) as FormGroup).controls[\r\n      'assertion'\r\n    ].value;\r\n    this.assertionNr = index + 1;\r\n    this.assEdOpen = true;\r\n  }\r\n\r\n  public onAssertionChange(assertion: Assertion | undefined): void {\r\n    this.assertion = assertion;\r\n  }\r\n\r\n  public saveAssertion(): void {\r\n    // save the currently edited assertion if any\r\n    if (this.assertionNr) {\r\n      const g = this.idsArr.at(this.assertionNr - 1) as FormGroup;\r\n      g.controls['assertion'].setValue(this.assertion);\r\n      this.closeAssertion();\r\n      this.emitIdsChange();\r\n    }\r\n  }\r\n\r\n  private closeAssertion(): void {\r\n    if (this.assertionNr) {\r\n      this.assEdOpen = false;\r\n      this.assertionNr = 0;\r\n      this.initialAssertion = undefined;\r\n    }\r\n  }\r\n\r\n  private updateForm(ids: AssertedId[]): void {\r\n    if (!this.idsArr) {\r\n      return;\r\n    }\r\n    this._updatingForm = true;\r\n    this.clearIds();\r\n\r\n    if (!ids) {\r\n      this.form.reset();\r\n    } else {\r\n      for (const id of ids) {\r\n        this.addId(id);\r\n      }\r\n      this.form.markAsPristine();\r\n    }\r\n    this._updatingForm = false;\r\n    this.emitIdsChange();\r\n  }\r\n\r\n  private getIds(): AssertedId[] {\r\n    const ids: AssertedId[] = [];\r\n    for (let i = 0; i < this.idsArr.length; i++) {\r\n      const g = this.idsArr.controls[i] as FormGroup;\r\n      ids.push({\r\n        value: g.controls.value.value?.trim(),\r\n        scope: g.controls.scope.value?.trim(),\r\n        tag: g.controls.tag.value?.trim(),\r\n        assertion: g.controls.assertion.value,\r\n      });\r\n    }\r\n    return ids;\r\n  }\r\n\r\n  private emitIdsChange(): void {\r\n    this.idsChange.emit(this.getIds());\r\n  }\r\n}\r\n","<form [formGroup]=\"form\">\r\n  <div formArrayName=\"idsArr\">\r\n    <div>\r\n      <button\r\n        type=\"button\"\r\n        mat-flat-button\r\n        color=\"primary\"\r\n        (click)=\"addId()\"\r\n      >\r\n        <mat-icon>add_circle</mat-icon> add ID\r\n      </button>\r\n    </div>\r\n    <div\r\n      *ngFor=\"\r\n        let item of idsArr.controls;\r\n        let i = index;\r\n        let first = first;\r\n        let last = last\r\n      \"\r\n    >\r\n      <!-- child form -->\r\n      <div [formGroupName]=\"i\">\r\n        <!-- child actions -->\r\n        {{ i + 1 }}.\r\n        <button\r\n          mat-icon-button\r\n          type=\"button\"\r\n          matTooltip=\"Remove this ID\"\r\n          color=\"warn\"\r\n          (click)=\"removeId(i)\"\r\n        >\r\n          <mat-icon>remove_circle</mat-icon>\r\n        </button>\r\n        <button\r\n          [disabled]=\"first\"\r\n          mat-icon-button\r\n          type=\"button\"\r\n          matTooltip=\"Move ID up\"\r\n          (click)=\"moveIdUp(i)\"\r\n        >\r\n          <mat-icon>arrow_upward</mat-icon>\r\n        </button>\r\n        <button\r\n          [disabled]=\"last\"\r\n          mat-icon-button\r\n          type=\"button\"\r\n          matTooltip=\"Move ID down\"\r\n          (click)=\"moveIdDown(i)\"\r\n        >\r\n          <mat-icon>arrow_downward</mat-icon>\r\n        </button>\r\n\r\n        <!-- child controls -->\r\n        <!-- value -->\r\n        <mat-form-field>\r\n          <mat-label>external ID</mat-label>\r\n          <input #id autofocus matInput formControlName=\"value\" />\r\n          <mat-error\r\n            *ngIf=\"\r\n              $any(item)['controls'].value?.hasError('required') &&\r\n              ($any(item)['controls'].value.dirty ||\r\n                $any(item)['controls'].value.touched)\r\n            \"\r\n            >ID required\r\n          </mat-error>\r\n          <mat-error\r\n            *ngIf=\"\r\n              $any(item)['controls'].value?.hasError('max-length') &&\r\n              ($any(item)['controls'].value.dirty ||\r\n                $any(item)['controls'].value.touched)\r\n            \"\r\n            >ID too long\r\n          </mat-error>\r\n        </mat-form-field>\r\n\r\n        &nbsp;\r\n        <!-- scope (bound) -->\r\n        <ng-container *ngIf=\"scopeEntries\">\r\n          <mat-form-field style=\"width: 8em\">\r\n            <mat-label>scope</mat-label>\r\n            <mat-select formControlName=\"scope\">\r\n              <mat-option *ngFor=\"let e of scopeEntries\" [value]=\"e.id\">\r\n                {{ e.value }}\r\n              </mat-option>\r\n            </mat-select>\r\n          </mat-form-field>\r\n        </ng-container>\r\n\r\n        <!-- scope (free) -->\r\n        <ng-container *ngIf=\"!scopeEntries\">\r\n          <mat-form-field style=\"width: 8em\">\r\n            <mat-label>scope</mat-label>\r\n            <input matInput formControlName=\"scope\" />\r\n            <mat-error\r\n              *ngIf=\"\r\n                $any(item)['controls'].scope?.hasError('max-length') &&\r\n                ($any(item)['controls'].scope.dirty ||\r\n                  $any(item)['controls'].scope.touched)\r\n              \"\r\n              >scope too long\r\n            </mat-error>\r\n          </mat-form-field>\r\n        </ng-container>\r\n\r\n        &nbsp;\r\n        <!-- tag (bound) -->\r\n        <ng-container *ngIf=\"tagEntries\">\r\n          <mat-form-field style=\"width: 8em\">\r\n            <mat-label>tag</mat-label>\r\n            <mat-select formControlName=\"tag\">\r\n              <mat-option *ngFor=\"let e of tagEntries\" [value]=\"e.id\">\r\n                {{ e.value }}\r\n              </mat-option>\r\n            </mat-select>\r\n          </mat-form-field>\r\n        </ng-container>\r\n\r\n        <!-- tag (free) -->\r\n        <ng-container *ngIf=\"!tagEntries\">\r\n          <mat-form-field style=\"width: 8em\">\r\n            <mat-label>tag</mat-label>\r\n            <input matInput formControlName=\"tag\" />\r\n            <mat-error\r\n              *ngIf=\"\r\n                $any(item)['controls'].tag?.hasError('max-length') &&\r\n                ($any(item)['controls'].tag.dirty ||\r\n                  $any(item)['controls'].tag.touched)\r\n              \"\r\n              >tag too long\r\n            </mat-error>\r\n          </mat-form-field>\r\n        </ng-container>\r\n\r\n        <!-- assertion -->\r\n        &nbsp;\r\n        <button\r\n          type=\"button\"\r\n          color=\"primary\"\r\n          mat-icon-button\r\n          matTooltip=\"Edit assertion\"\r\n          (click)=\"editAssertion(i)\"\r\n        >\r\n          <mat-icon>feedback</mat-icon>\r\n        </button>\r\n      </div>\r\n    </div>\r\n    <!-- assertion -->\r\n    <mat-expansion-panel\r\n      *ngIf=\"idsArr?.length\"\r\n      [disabled]=\"!assertionNr\"\r\n      [(expanded)]=\"assEdOpen\"\r\n    >\r\n      <mat-expansion-panel-header\r\n        >#{{ assertionNr }} assertion</mat-expansion-panel-header\r\n      >\r\n      <cadmus-refs-assertion\r\n        [assertion]=\"initialAssertion\"\r\n        [assTagEntries]=\"assTagEntries\"\r\n        [refTagEntries]=\"refTagEntries\"\r\n        [refTypeEntries]=\"refTypeEntries\"\r\n        (assertionChange)=\"onAssertionChange($event)\"\r\n      ></cadmus-refs-assertion>\r\n      <button\r\n        color=\"primary\"\r\n        type=\"button\"\r\n        mat-flat-button\r\n        style=\"margin-top: 6px;\"\r\n        (click)=\"saveAssertion()\"\r\n      >\r\n        <mat-icon>check_circle</mat-icon> assertion\r\n      </button>\r\n    </mat-expansion-panel>\r\n  </div>\r\n</form>\r\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asserted-ids.component.js","sourceRoot":"","sources":["../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-ids/asserted-ids.component.ts","../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-ids/asserted-ids.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport { FormBuilder, FormControl, FormGroup } from '@angular/forms';\r\n\r\nimport { ThesaurusEntry } from '@myrmidon/cadmus-core';\r\nimport { DialogService } from '@myrmidon/ng-mat-tools';\r\nimport { debounceTime, Subscription, take } from 'rxjs';\r\n\r\nimport { AssertedId } from '../asserted-id/asserted-id.component';\r\n\r\n/**\r\n * Asserted IDs editor.\r\n */\r\n@Component({\r\n  selector: 'cadmus-refs-asserted-ids',\r\n  templateUrl: './asserted-ids.component.html',\r\n  styleUrls: ['./asserted-ids.component.css'],\r\n})\r\nexport class AssertedIdsComponent {\r\n  private _ids: AssertedId[];\r\n  private _editedIndex: number;\r\n  public edited?: AssertedId;\r\n\r\n  /**\r\n   * The asserted IDs.\r\n   */\r\n  @Input()\r\n  public get ids(): AssertedId[] {\r\n    return this._ids;\r\n  }\r\n  public set ids(value: AssertedId[]) {\r\n    if (this._ids !== value) {\r\n      this._ids = value || [];\r\n      this.updateForm(value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * The ID scopes thesaurus entries.\r\n   */\r\n  @Input()\r\n  public scopeEntries: ThesaurusEntry[] | undefined;\r\n\r\n  /**\r\n   * The ID tags thesaurus entries.\r\n   */\r\n  @Input()\r\n  public tagEntries: ThesaurusEntry[] | undefined;\r\n\r\n  // thesauri for assertions\r\n  @Input()\r\n  public assTagEntries?: ThesaurusEntry[];\r\n\r\n  @Input()\r\n  public refTypeEntries: ThesaurusEntry[] | undefined;\r\n\r\n  @Input()\r\n  public refTagEntries: ThesaurusEntry[] | undefined;\r\n\r\n  /**\r\n   * Emitted whenever any ID changes.\r\n   */\r\n  @Output()\r\n  public idsChange: EventEmitter<AssertedId[]>;\r\n\r\n  public entries: FormControl<AssertedId[]>;\r\n  public form: FormGroup;\r\n\r\n  constructor(formBuilder: FormBuilder, private _dialogService: DialogService) {\r\n    this._ids = [];\r\n    this._editedIndex = -1;\r\n    this.idsChange = new EventEmitter<AssertedId[]>();\r\n    this.entries = formBuilder.control([], { nonNullable: true });\r\n    // form\r\n    this.form = formBuilder.group({\r\n      ids: this.entries,\r\n    });\r\n  }\r\n\r\n  private updateForm(ids: AssertedId[]): void {\r\n    if (!ids?.length) {\r\n      this.form.reset();\r\n      return;\r\n    }\r\n    this.entries.setValue(ids, { emitEvent: false });\r\n    this.entries.updateValueAndValidity();\r\n    this.form.markAsPristine();\r\n  }\r\n\r\n  private emitIdsChange(): void {\r\n    this.idsChange.emit(this.entries.value);\r\n  }\r\n\r\n  public addId(): void {\r\n    this.editId(\r\n      {\r\n        scope: '',\r\n        value: '',\r\n      },\r\n      -1\r\n    );\r\n  }\r\n\r\n  public editId(id: AssertedId, index: number): void {\r\n    this._editedIndex = index;\r\n    this.edited = id;\r\n  }\r\n\r\n  public closeId(): void {\r\n    this._editedIndex = -1;\r\n    this.edited = undefined;\r\n  }\r\n\r\n  public saveId(entry: AssertedId): void {\r\n    const entries = [...this.entries.value];\r\n    if (this._editedIndex === -1) {\r\n      entries.push(entry);\r\n    } else {\r\n      entries.splice(this._editedIndex, 1, entry);\r\n    }\r\n    this.entries.setValue(entries);\r\n    this.entries.markAsDirty();\r\n    this.entries.updateValueAndValidity();\r\n    this.closeId();\r\n  }\r\n\r\n  public deleteId(index: number): void {\r\n    this._dialogService\r\n      .confirm('Confirmation', 'Delete ID?')\r\n      .pipe(take(1))\r\n      .subscribe((yes) => {\r\n        if (yes) {\r\n          if (this._editedIndex === index) {\r\n            this.closeId();\r\n          }\r\n          const entries = [...this.entries.value];\r\n          entries.splice(index, 1);\r\n          this.entries.setValue(entries);\r\n          this.entries.markAsDirty();\r\n          this.entries.updateValueAndValidity();\r\n          this.emitIdsChange();\r\n        }\r\n      });\r\n  }\r\n\r\n  public moveIdUp(index: number): void {\r\n    if (index < 1) {\r\n      return;\r\n    }\r\n    const entry = this.entries.value[index];\r\n    const entries = [...this.entries.value];\r\n    entries.splice(index, 1);\r\n    entries.splice(index - 1, 0, entry);\r\n    this.entries.setValue(entries);\r\n    this.entries.markAsDirty();\r\n    this.entries.updateValueAndValidity();\r\n    this.emitIdsChange();\r\n  }\r\n\r\n  public moveIdDown(index: number): void {\r\n    if (index + 1 >= this.entries.value.length) {\r\n      return;\r\n    }\r\n    const entry = this.entries.value[index];\r\n    const entries = [...this.entries.value];\r\n    entries.splice(index, 1);\r\n    entries.splice(index + 1, 0, entry);\r\n    this.entries.setValue(entries);\r\n    this.entries.markAsDirty();\r\n    this.entries.updateValueAndValidity();\r\n    this.emitIdsChange();\r\n  }\r\n\r\n  public onIdChange(id: AssertedId): void {\r\n    this.saveId(id);\r\n    this.emitIdsChange();\r\n  }\r\n}\r\n","<form [formGroup]=\"form\">\r\n  <div>\r\n    <button type=\"button\" mat-flat-button color=\"primary\" (click)=\"addId()\">\r\n      <mat-icon>add_circle</mat-icon> ID\r\n    </button>\r\n  </div>\r\n  <table *ngIf=\"entries.value?.length\">\r\n    <thead>\r\n      <tr>\r\n        <th></th>\r\n        <th>scope</th>\r\n        <th>value</th>\r\n      </tr>\r\n    </thead>\r\n    <tbody>\r\n      <tr\r\n        *ngFor=\"\r\n          let entry of entries.value;\r\n          let i = index;\r\n          let first = first;\r\n          let last = last\r\n        \"\r\n      >\r\n        <td>\r\n          <button\r\n            type=\"button\"\r\n            mat-icon-button\r\n            color=\"primary\"\r\n            matTooltip=\"Edit this ID\"\r\n            (click)=\"editId(entry, i)\"\r\n          >\r\n            <mat-icon>edit</mat-icon>\r\n          </button>\r\n          <button\r\n            type=\"button\"\r\n            mat-icon-button\r\n            matTooltip=\"Move this ID up\"\r\n            [disabled]=\"first\"\r\n            (click)=\"moveIdUp(i)\"\r\n          >\r\n            <mat-icon>arrow_upward</mat-icon>\r\n          </button>\r\n          <button\r\n            type=\"button\"\r\n            mat-icon-button\r\n            matTooltip=\"Move this ID down\"\r\n            [disabled]=\"last\"\r\n            (click)=\"moveIdDown(i)\"\r\n          >\r\n            <mat-icon>arrow_downward</mat-icon>\r\n          </button>\r\n          <button\r\n            type=\"button\"\r\n            mat-icon-button\r\n            color=\"warn\"\r\n            matTooltip=\"Delete this ID\"\r\n            (click)=\"deleteId(i)\"\r\n          >\r\n            <mat-icon>remove_circle</mat-icon>\r\n          </button>\r\n        </td>\r\n        <td>{{ entry.scope }}</td>\r\n        <td>{{ entry.value }}</td>\r\n      </tr>\r\n    </tbody>\r\n  </table>\r\n\r\n  <mat-expansion-panel [expanded]=\"edited\" [disabled]=\"!edited\">\r\n    <mat-expansion-panel-header>ID</mat-expansion-panel-header>\r\n    <cadmus-refs-asserted-id\r\n      [hasSubmit]=\"true\"\r\n      [id]=\"edited\"\r\n      (idChange)=\"onIdChange($event)\"\r\n      (editorClose)=\"closeId()\"\r\n    ></cadmus-refs-asserted-id>\r\n  </mat-expansion-panel>\r\n</form>\r\n"]}
|
|
@@ -8,15 +8,20 @@ import { MatIconModule } from '@angular/material/icon';
|
|
|
8
8
|
import { MatInputModule } from '@angular/material/input';
|
|
9
9
|
import { MatSelectModule } from '@angular/material/select';
|
|
10
10
|
import { CadmusCoreModule } from '@myrmidon/cadmus-core';
|
|
11
|
+
import { CadmusApiModule } from '@myrmidon/cadmus-api';
|
|
11
12
|
import { CadmusRefsAssertionModule } from '@myrmidon/cadmus-refs-assertion';
|
|
12
13
|
import { CadmusRefsDocReferencesModule } from '@myrmidon/cadmus-refs-doc-references';
|
|
14
|
+
import { CadmusRefsLookupModule } from '@myrmidon/cadmus-refs-lookup';
|
|
13
15
|
import { AssertedIdComponent } from './asserted-id/asserted-id.component';
|
|
14
16
|
import { AssertedIdsComponent } from './asserted-ids/asserted-ids.component';
|
|
17
|
+
import { ScopedPinLookupComponent } from './scoped-pin-lookup/scoped-pin-lookup.component';
|
|
15
18
|
import * as i0 from "@angular/core";
|
|
16
19
|
export class CadmusRefsAssertedIdsModule {
|
|
17
20
|
}
|
|
18
|
-
CadmusRefsAssertedIdsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
19
|
-
CadmusRefsAssertedIdsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.
|
|
21
|
+
CadmusRefsAssertedIdsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: CadmusRefsAssertedIdsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
22
|
+
CadmusRefsAssertedIdsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.1", ngImport: i0, type: CadmusRefsAssertedIdsModule, declarations: [AssertedIdComponent,
|
|
23
|
+
AssertedIdsComponent,
|
|
24
|
+
ScopedPinLookupComponent], imports: [CommonModule,
|
|
20
25
|
FormsModule,
|
|
21
26
|
ReactiveFormsModule,
|
|
22
27
|
// material
|
|
@@ -29,8 +34,12 @@ CadmusRefsAssertedIdsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0
|
|
|
29
34
|
// Cadmus
|
|
30
35
|
CadmusCoreModule,
|
|
31
36
|
CadmusRefsDocReferencesModule,
|
|
32
|
-
CadmusRefsAssertionModule
|
|
33
|
-
|
|
37
|
+
CadmusRefsAssertionModule,
|
|
38
|
+
CadmusRefsLookupModule,
|
|
39
|
+
CadmusApiModule], exports: [AssertedIdComponent,
|
|
40
|
+
AssertedIdsComponent,
|
|
41
|
+
ScopedPinLookupComponent] });
|
|
42
|
+
CadmusRefsAssertedIdsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: CadmusRefsAssertedIdsModule, imports: [CommonModule,
|
|
34
43
|
FormsModule,
|
|
35
44
|
ReactiveFormsModule,
|
|
36
45
|
// material
|
|
@@ -43,11 +52,17 @@ CadmusRefsAssertedIdsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0
|
|
|
43
52
|
// Cadmus
|
|
44
53
|
CadmusCoreModule,
|
|
45
54
|
CadmusRefsDocReferencesModule,
|
|
46
|
-
CadmusRefsAssertionModule
|
|
47
|
-
|
|
55
|
+
CadmusRefsAssertionModule,
|
|
56
|
+
CadmusRefsLookupModule,
|
|
57
|
+
CadmusApiModule] });
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: CadmusRefsAssertedIdsModule, decorators: [{
|
|
48
59
|
type: NgModule,
|
|
49
60
|
args: [{
|
|
50
|
-
declarations: [
|
|
61
|
+
declarations: [
|
|
62
|
+
AssertedIdComponent,
|
|
63
|
+
AssertedIdsComponent,
|
|
64
|
+
ScopedPinLookupComponent,
|
|
65
|
+
],
|
|
51
66
|
imports: [
|
|
52
67
|
CommonModule,
|
|
53
68
|
FormsModule,
|
|
@@ -63,8 +78,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
|
|
|
63
78
|
CadmusCoreModule,
|
|
64
79
|
CadmusRefsDocReferencesModule,
|
|
65
80
|
CadmusRefsAssertionModule,
|
|
81
|
+
CadmusRefsLookupModule,
|
|
82
|
+
CadmusApiModule,
|
|
83
|
+
],
|
|
84
|
+
exports: [
|
|
85
|
+
AssertedIdComponent,
|
|
86
|
+
AssertedIdsComponent,
|
|
87
|
+
ScopedPinLookupComponent,
|
|
66
88
|
],
|
|
67
|
-
exports: [AssertedIdComponent, AssertedIdsComponent],
|
|
68
89
|
}]
|
|
69
90
|
}] });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FkbXVzLXJlZnMtYXNzZXJ0ZWQtaWRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cm1pZG9uL2NhZG11cy1yZWZzLWFzc2VydGVkLWlkcy9zcmMvbGliL2NhZG11cy1yZWZzLWFzc2VydGVkLWlkcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWxFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUUzRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdkQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDNUUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDckYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFdEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDMUUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saURBQWlELENBQUM7O0FBZ0MzRixNQUFNLE9BQU8sMkJBQTJCOzt3SEFBM0IsMkJBQTJCO3lIQUEzQiwyQkFBMkIsaUJBNUJwQyxtQkFBbUI7UUFDbkIsb0JBQW9CO1FBQ3BCLHdCQUF3QixhQUd4QixZQUFZO1FBQ1osV0FBVztRQUNYLG1CQUFtQjtRQUNuQixXQUFXO1FBQ1gsZUFBZTtRQUNmLGtCQUFrQjtRQUNsQixrQkFBa0I7UUFDbEIsYUFBYTtRQUNiLGNBQWM7UUFDZCxlQUFlO1FBQ2YsU0FBUztRQUNULGdCQUFnQjtRQUNoQiw2QkFBNkI7UUFDN0IseUJBQXlCO1FBQ3pCLHNCQUFzQjtRQUN0QixlQUFlLGFBR2YsbUJBQW1CO1FBQ25CLG9CQUFvQjtRQUNwQix3QkFBd0I7eUhBR2YsMkJBQTJCLFlBdkJwQyxZQUFZO1FBQ1osV0FBVztRQUNYLG1CQUFtQjtRQUNuQixXQUFXO1FBQ1gsZUFBZTtRQUNmLGtCQUFrQjtRQUNsQixrQkFBa0I7UUFDbEIsYUFBYTtRQUNiLGNBQWM7UUFDZCxlQUFlO1FBQ2YsU0FBUztRQUNULGdCQUFnQjtRQUNoQiw2QkFBNkI7UUFDN0IseUJBQXlCO1FBQ3pCLHNCQUFzQjtRQUN0QixlQUFlOzJGQVFOLDJCQUEyQjtrQkE5QnZDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLG1CQUFtQjt3QkFDbkIsb0JBQW9CO3dCQUNwQix3QkFBd0I7cUJBQ3pCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixXQUFXO3dCQUNYLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixrQkFBa0I7d0JBQ2xCLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxlQUFlO3dCQUNmLFNBQVM7d0JBQ1QsZ0JBQWdCO3dCQUNoQiw2QkFBNkI7d0JBQzdCLHlCQUF5Qjt3QkFDekIsc0JBQXNCO3dCQUN0QixlQUFlO3FCQUNoQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsbUJBQW1CO3dCQUNuQixvQkFBb0I7d0JBQ3BCLHdCQUF3QjtxQkFDekI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0RXhwYW5zaW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZXhwYW5zaW9uJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQgeyBNYXRTZWxlY3RNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zZWxlY3QnO1xuXG5pbXBvcnQgeyBDYWRtdXNDb3JlTW9kdWxlIH0gZnJvbSAnQG15cm1pZG9uL2NhZG11cy1jb3JlJztcbmltcG9ydCB7IENhZG11c0FwaU1vZHVsZSB9IGZyb20gJ0BteXJtaWRvbi9jYWRtdXMtYXBpJztcbmltcG9ydCB7IENhZG11c1JlZnNBc3NlcnRpb25Nb2R1bGUgfSBmcm9tICdAbXlybWlkb24vY2FkbXVzLXJlZnMtYXNzZXJ0aW9uJztcbmltcG9ydCB7IENhZG11c1JlZnNEb2NSZWZlcmVuY2VzTW9kdWxlIH0gZnJvbSAnQG15cm1pZG9uL2NhZG11cy1yZWZzLWRvYy1yZWZlcmVuY2VzJztcbmltcG9ydCB7IENhZG11c1JlZnNMb29rdXBNb2R1bGUgfSBmcm9tICdAbXlybWlkb24vY2FkbXVzLXJlZnMtbG9va3VwJztcblxuaW1wb3J0IHsgQXNzZXJ0ZWRJZENvbXBvbmVudCB9IGZyb20gJy4vYXNzZXJ0ZWQtaWQvYXNzZXJ0ZWQtaWQuY29tcG9uZW50JztcbmltcG9ydCB7IEFzc2VydGVkSWRzQ29tcG9uZW50IH0gZnJvbSAnLi9hc3NlcnRlZC1pZHMvYXNzZXJ0ZWQtaWRzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTY29wZWRQaW5Mb29rdXBDb21wb25lbnQgfSBmcm9tICcuL3Njb3BlZC1waW4tbG9va3VwL3Njb3BlZC1waW4tbG9va3VwLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEFzc2VydGVkSWRDb21wb25lbnQsXG4gICAgQXNzZXJ0ZWRJZHNDb21wb25lbnQsXG4gICAgU2NvcGVkUGluTG9va3VwQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgLy8gbWF0ZXJpYWxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0RXhwYW5zaW9uTW9kdWxlLFxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIE1hdFNlbGVjdE1vZHVsZSxcbiAgICAvLyBDYWRtdXNcbiAgICBDYWRtdXNDb3JlTW9kdWxlLFxuICAgIENhZG11c1JlZnNEb2NSZWZlcmVuY2VzTW9kdWxlLFxuICAgIENhZG11c1JlZnNBc3NlcnRpb25Nb2R1bGUsXG4gICAgQ2FkbXVzUmVmc0xvb2t1cE1vZHVsZSxcbiAgICBDYWRtdXNBcGlNb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBBc3NlcnRlZElkQ29tcG9uZW50LFxuICAgIEFzc2VydGVkSWRzQ29tcG9uZW50LFxuICAgIFNjb3BlZFBpbkxvb2t1cENvbXBvbmVudCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2FkbXVzUmVmc0Fzc2VydGVkSWRzTW9kdWxlIHt9XG4iXX0=
|