@myrmidon/cadmus-refs-asserted-ids 1.0.3 → 1.0.4
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 +44 -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 +125 -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 +340 -175
- package/fesm2015/myrmidon-cadmus-refs-asserted-ids.mjs.map +1 -1
- package/fesm2020/myrmidon-cadmus-refs-asserted-ids.mjs +334 -174
- package/fesm2020/myrmidon-cadmus-refs-asserted-ids.mjs.map +1 -1
- package/lib/asserted-id/asserted-id.component.d.ts +14 -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
package/README.md
CHANGED
|
@@ -2,23 +2,42 @@
|
|
|
2
2
|
|
|
3
3
|
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 14.1.0.
|
|
4
4
|
|
|
5
|
-
##
|
|
5
|
+
## Model
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
> Note: Don't forget to add `--project cadmus-refs-asserted-ids` or else it will be added to the default project in your `angular.json` file.
|
|
7
|
+
The asserted ID and asserted IDs bricks provide a way to include external or internal references to resource identifiers, whatever their type and origin.
|
|
9
8
|
|
|
10
|
-
|
|
9
|
+
The asserted ID brick allows editing a simple model representing such IDs, having:
|
|
11
10
|
|
|
12
|
-
|
|
11
|
+
- a value, the ID itself.
|
|
12
|
+
- a scope, representing the context the ID originates from (e.g. an ontology, a repository, a website, etc.).
|
|
13
|
+
- an optional tag, eventually used to group or classify the ID.
|
|
14
|
+
- an optional assertion, eventually used to define the uncertainty level of the assignment of this ID to the context it applies to.
|
|
13
15
|
|
|
14
|
-
|
|
16
|
+
The asserted IDs brick is just a collection of such IDs.
|
|
15
17
|
|
|
16
|
-
|
|
18
|
+
## Behavior
|
|
17
19
|
|
|
18
|
-
|
|
20
|
+
In both cases, the component provides a special mechanism for internal, pin-based lookup. In most cases, human users prefer to adopt friendly IDs, which are unique only in the context of their editing environment. Such identifiers are typically named EIDs (entity IDs), and may be found scattered among parts, or linked to items via a metadata part.
|
|
19
21
|
|
|
20
|
-
|
|
22
|
+
For instance, a decorations part in a manuscript collects a number of decorations; for each one, it might define an arbitrary EID (like e.g. `angel1`) used to identify it among the others, in the context of that part.
|
|
21
23
|
|
|
22
|
-
|
|
24
|
+
When filling the decorations part with data, users just ensure that this EID is unique in the context of the list they are editing. Yet, should we be in need of a non-scoped, unique ID, it would be easy to build it by assembling together the EID with its part/item IDs, which by definition are globally unique (being GUIDs). For instance, this is what can be done when mapping entities from parts into a semantic graph (via mapping rules).
|
|
23
25
|
|
|
24
|
-
|
|
26
|
+
Also, sometimes we might also want to assign a human-friendly ID to the item itself, rather than referring to it by its GUID. In this case, the conventional method relies on the generic metadata part, which allows users entering any number of arbitrarily defined name=value pairs. So, a user might enter a pair like e.g. `eid=vat_lat_123`, and use it as the human friendly identifier for a manuscript item corresponding to Vat. Lat. 123.
|
|
27
|
+
|
|
28
|
+
The asserted ID library provides a number of components which can be used to easily refer to the entities identified in this way. According to the scenario illustrated above, the basic requirements for building non-scoped, unique IDs from scoped, human-friendly identifiers are:
|
|
29
|
+
|
|
30
|
+
- we must be able to draw EIDs _from parts or from items_, assuming the convention by which an item can be assigned an EID via its generic _metadata_ part.
|
|
31
|
+
- we must let users pick _the preferred combination_ of components which once assembled build a unique, yet human-friendly identifier.
|
|
32
|
+
|
|
33
|
+
To this end, the asserted ID component provides an internal lookup mechanism based on data pins and metadata conventions. When users want to add an ID referring to some internal entity, either found in a part or corresponding to an item, he just has to pick the type of desired lookup (when more than a single lookup search definition is present), and type some characters to get the first N pins starting with these characters; he can then pick one from the list. Once a pin value is picked, the lookup control shows all the relevant data which can be used as components for the ID to build:
|
|
34
|
+
|
|
35
|
+
- the item GUID.
|
|
36
|
+
- the item title.
|
|
37
|
+
- the part GUID.
|
|
38
|
+
- the part type ID.
|
|
39
|
+
- the item's metadata part entries.
|
|
40
|
+
|
|
41
|
+
The user can then use buttons to append each of these components to the ID being built, and/or variously edit it. When he's ok with the ID, he can then use it as the reference ID being edited.
|
|
42
|
+
|
|
43
|
+
>👉 The demo found in this workspace uses a [mock data service](../../../src/app/services/mock-item.service.ts) instead of the real one, which provides a minimal set of data and functions, just required for the components to function.
|
|
@@ -1,19 +1,23 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Inject, Input, Output, } from '@angular/core';
|
|
2
2
|
import { Validators, } from '@angular/forms';
|
|
3
3
|
import { debounceTime } from 'rxjs/operators';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
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/
|
|
10
|
-
import * as i6 from "@angular/material/
|
|
11
|
-
import * as i7 from "@angular/material/
|
|
12
|
-
import * as i8 from "@
|
|
6
|
+
import * as i2 from "../services/pin-ref-lookup.service";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
import * as i4 from "@angular/material/button";
|
|
9
|
+
import * as i5 from "@angular/material/expansion";
|
|
10
|
+
import * as i6 from "@angular/material/form-field";
|
|
11
|
+
import * as i7 from "@angular/material/icon";
|
|
12
|
+
import * as i8 from "@angular/material/input";
|
|
13
|
+
import * as i9 from "@angular/material/select";
|
|
14
|
+
import * as i10 from "@angular/material/core";
|
|
15
|
+
import * as i11 from "@myrmidon/cadmus-refs-assertion";
|
|
16
|
+
import * as i12 from "../scoped-pin-lookup/scoped-pin-lookup.component";
|
|
13
17
|
export class AssertedIdComponent {
|
|
14
|
-
constructor(formBuilder) {
|
|
15
|
-
this.
|
|
16
|
-
|
|
18
|
+
constructor(formBuilder, lookupService, lookupDefs) {
|
|
19
|
+
this.lookupService = lookupService;
|
|
20
|
+
this.lookupDefs = lookupDefs;
|
|
17
21
|
this.tag = formBuilder.control(null, Validators.maxLength(50));
|
|
18
22
|
this.value = formBuilder.control(null, [
|
|
19
23
|
Validators.required,
|
|
@@ -25,6 +29,8 @@ export class AssertedIdComponent {
|
|
|
25
29
|
value: this.value,
|
|
26
30
|
scope: this.scope,
|
|
27
31
|
});
|
|
32
|
+
this.lookupExpanded = false;
|
|
33
|
+
this.idChange = new EventEmitter();
|
|
28
34
|
}
|
|
29
35
|
get id() {
|
|
30
36
|
return this._id;
|
|
@@ -46,6 +52,12 @@ export class AssertedIdComponent {
|
|
|
46
52
|
this.assertion = assertion;
|
|
47
53
|
setTimeout(() => this.emitIdChange(), 0);
|
|
48
54
|
}
|
|
55
|
+
onIdPick(id) {
|
|
56
|
+
this.value.setValue(id);
|
|
57
|
+
this.value.markAsDirty();
|
|
58
|
+
this.value.updateValueAndValidity();
|
|
59
|
+
this.lookupExpanded = false;
|
|
60
|
+
}
|
|
49
61
|
updateForm(value) {
|
|
50
62
|
this._updatingForm = true;
|
|
51
63
|
if (!value) {
|
|
@@ -71,15 +83,25 @@ export class AssertedIdComponent {
|
|
|
71
83
|
};
|
|
72
84
|
}
|
|
73
85
|
emitIdChange() {
|
|
74
|
-
|
|
86
|
+
if (!this.hasSubmit) {
|
|
87
|
+
this.idChange.emit(this.getId());
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
save() {
|
|
91
|
+
if (this.form.valid) {
|
|
92
|
+
this.idChange.emit(this.getId());
|
|
93
|
+
}
|
|
75
94
|
}
|
|
76
95
|
}
|
|
77
|
-
AssertedIdComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
78
|
-
AssertedIdComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.
|
|
79
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
96
|
+
AssertedIdComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: AssertedIdComponent, deps: [{ token: i1.FormBuilder }, { token: i2.PinRefLookupService }, { token: 'indexLookupDefinitions' }], target: i0.ɵɵFactoryTarget.Component });
|
|
97
|
+
AssertedIdComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: AssertedIdComponent, selector: "cadmus-refs-asserted-id", inputs: { scopeEntries: "scopeEntries", idTagEntries: "idTagEntries", assTagEntries: "assTagEntries", refTypeEntries: "refTypeEntries", refTagEntries: "refTagEntries", id: "id", noEidLookup: "noEidLookup", hasSubmit: "hasSubmit" }, outputs: { idChange: "idChange" }, ngImport: i0, template: "<form [formGroup]=\"form\" (submit)=\"save()\">\n <div>\n <div class=\"form-row\">\n <!-- tag (bound) -->\n <mat-form-field *ngIf=\"idTagEntries?.length\" style=\"width: 8em\">\n <mat-label>tag</mat-label>\n <mat-select [formControl]=\"tag\">\n <mat-option *ngFor=\"let e of idTagEntries\" [value]=\"e.id\">{{\n e.value\n }}</mat-option>\n </mat-select>\n </mat-form-field>\n <!-- tag (free) -->\n <mat-form-field *ngIf=\"!idTagEntries?.length\" style=\"width: 8em\">\n <mat-label>tag</mat-label>\n <input matInput [formControl]=\"tag\" />\n <mat-error *ngIf=\"tag.errors?.maxLength && (tag.dirty || tag.touched)\"\n >tag too long</mat-error\n >\n </mat-form-field>\n\n <!-- scope (bound) -->\n <mat-form-field *ngIf=\"scopeEntries?.length\" style=\"width: 8em\">\n <mat-label>scope</mat-label>\n <mat-select [formControl]=\"scope\">\n <mat-option *ngFor=\"let e of scopeEntries\" [value]=\"e.id\">{{\n e.value\n }}</mat-option>\n </mat-select>\n </mat-form-field>\n <!-- scope (free) -->\n <mat-form-field *ngIf=\"!scopeEntries?.length\" style=\"width: 8em\">\n <mat-label>scope</mat-label>\n <input matInput [formControl]=\"scope\" />\n <mat-error\n *ngIf=\"scope.errors?.maxLength && (scope.dirty || scope.touched)\"\n >scope too long</mat-error\n >\n </mat-form-field>\n\n <!-- value -->\n <mat-form-field>\n <mat-label>value</mat-label>\n <input matInput [formControl]=\"value\" />\n <mat-error\n *ngIf=\"value.errors?.required && (value.dirty || value.touched)\"\n >value required</mat-error\n >\n <mat-error\n *ngIf=\"value.errors?.maxLength && (value.dirty || value.touched)\"\n >value too long</mat-error\n >\n </mat-form-field>\n\n <!-- lookup -->\n <div *ngIf=\"!noEidLookup\" style=\"margin-top: 4px\">\n <mat-expansion-panel [(expanded)]=\"lookupExpanded\">\n <mat-expansion-panel-header>lookup</mat-expansion-panel-header>\n <cadmus-scoped-pin-lookup\n (idPick)=\"onIdPick($event)\"\n ></cadmus-scoped-pin-lookup>\n </mat-expansion-panel>\n </div>\n </div>\n\n <!-- assertion -->\n <mat-expansion-panel>\n <mat-expansion-panel-header>assertion</mat-expansion-panel-header>\n <cadmus-refs-assertion\n [assTagEntries]=\"assTagEntries\"\n [refTypeEntries]=\"refTypeEntries\"\n [refTagEntries]=\"refTagEntries\"\n [assertion]=\"initialAssertion\"\n (assertionChange)=\"onAssertionChange($event)\"\n >\n </cadmus-refs-assertion>\n </mat-expansion-panel>\n </div>\n\n <!-- buttons -->\n <div *ngIf=\"hasSubmit\">\n <button mat-icon-button color=\"warn\" type=\"button\">\n <mat-icon>close</mat-icon>\n </button>\n <button\n mat-icon-button\n color=\"primary\"\n type=\"submit\"\n [disabled]=\"form.invalid\"\n >\n <mat-icon>check_circle</mat-icon>\n </button>\n </div>\n</form>\n", styles: [".form-row{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}.form-row *{flex:0 0 auto}.pin-info{font-size:90%;color:silver}fieldset{border:1px solid silver;border-radius:6px;padding:6px}@media only screen and (max-width: 959px){div#container{grid-template-rows:1fr auto;grid-template-columns:1fr;grid-template-areas:\"editor\" \"lookup\"}}\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.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: 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.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i8.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: i9.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i10.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i11.AssertionComponent, selector: "cadmus-refs-assertion", inputs: ["assTagEntries", "refTypeEntries", "refTagEntries", "assertion"], outputs: ["assertionChange"] }, { kind: "component", type: i12.ScopedPinLookupComponent, selector: "cadmus-scoped-pin-lookup", outputs: ["idPick"] }] });
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: AssertedIdComponent, decorators: [{
|
|
80
99
|
type: Component,
|
|
81
|
-
args: [{ selector: 'cadmus-refs-asserted-id', template: "<form [formGroup]=\"form\">\n <div>\n <!-- tag (bound) -->\n
|
|
82
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder }
|
|
100
|
+
args: [{ selector: 'cadmus-refs-asserted-id', template: "<form [formGroup]=\"form\" (submit)=\"save()\">\n <div>\n <div class=\"form-row\">\n <!-- tag (bound) -->\n <mat-form-field *ngIf=\"idTagEntries?.length\" style=\"width: 8em\">\n <mat-label>tag</mat-label>\n <mat-select [formControl]=\"tag\">\n <mat-option *ngFor=\"let e of idTagEntries\" [value]=\"e.id\">{{\n e.value\n }}</mat-option>\n </mat-select>\n </mat-form-field>\n <!-- tag (free) -->\n <mat-form-field *ngIf=\"!idTagEntries?.length\" style=\"width: 8em\">\n <mat-label>tag</mat-label>\n <input matInput [formControl]=\"tag\" />\n <mat-error *ngIf=\"tag.errors?.maxLength && (tag.dirty || tag.touched)\"\n >tag too long</mat-error\n >\n </mat-form-field>\n\n <!-- scope (bound) -->\n <mat-form-field *ngIf=\"scopeEntries?.length\" style=\"width: 8em\">\n <mat-label>scope</mat-label>\n <mat-select [formControl]=\"scope\">\n <mat-option *ngFor=\"let e of scopeEntries\" [value]=\"e.id\">{{\n e.value\n }}</mat-option>\n </mat-select>\n </mat-form-field>\n <!-- scope (free) -->\n <mat-form-field *ngIf=\"!scopeEntries?.length\" style=\"width: 8em\">\n <mat-label>scope</mat-label>\n <input matInput [formControl]=\"scope\" />\n <mat-error\n *ngIf=\"scope.errors?.maxLength && (scope.dirty || scope.touched)\"\n >scope too long</mat-error\n >\n </mat-form-field>\n\n <!-- value -->\n <mat-form-field>\n <mat-label>value</mat-label>\n <input matInput [formControl]=\"value\" />\n <mat-error\n *ngIf=\"value.errors?.required && (value.dirty || value.touched)\"\n >value required</mat-error\n >\n <mat-error\n *ngIf=\"value.errors?.maxLength && (value.dirty || value.touched)\"\n >value too long</mat-error\n >\n </mat-form-field>\n\n <!-- lookup -->\n <div *ngIf=\"!noEidLookup\" style=\"margin-top: 4px\">\n <mat-expansion-panel [(expanded)]=\"lookupExpanded\">\n <mat-expansion-panel-header>lookup</mat-expansion-panel-header>\n <cadmus-scoped-pin-lookup\n (idPick)=\"onIdPick($event)\"\n ></cadmus-scoped-pin-lookup>\n </mat-expansion-panel>\n </div>\n </div>\n\n <!-- assertion -->\n <mat-expansion-panel>\n <mat-expansion-panel-header>assertion</mat-expansion-panel-header>\n <cadmus-refs-assertion\n [assTagEntries]=\"assTagEntries\"\n [refTypeEntries]=\"refTypeEntries\"\n [refTagEntries]=\"refTagEntries\"\n [assertion]=\"initialAssertion\"\n (assertionChange)=\"onAssertionChange($event)\"\n >\n </cadmus-refs-assertion>\n </mat-expansion-panel>\n </div>\n\n <!-- buttons -->\n <div *ngIf=\"hasSubmit\">\n <button mat-icon-button color=\"warn\" type=\"button\">\n <mat-icon>close</mat-icon>\n </button>\n <button\n mat-icon-button\n color=\"primary\"\n type=\"submit\"\n [disabled]=\"form.invalid\"\n >\n <mat-icon>check_circle</mat-icon>\n </button>\n </div>\n</form>\n", styles: [".form-row{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}.form-row *{flex:0 0 auto}.pin-info{font-size:90%;color:silver}fieldset{border:1px solid silver;border-radius:6px;padding:6px}@media only screen and (max-width: 959px){div#container{grid-template-rows:1fr auto;grid-template-columns:1fr;grid-template-areas:\"editor\" \"lookup\"}}\n"] }]
|
|
101
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.PinRefLookupService }, { type: undefined, decorators: [{
|
|
102
|
+
type: Inject,
|
|
103
|
+
args: ['indexLookupDefinitions']
|
|
104
|
+
}] }]; }, propDecorators: { scopeEntries: [{
|
|
83
105
|
type: Input
|
|
84
106
|
}], idTagEntries: [{
|
|
85
107
|
type: Input
|
|
@@ -91,7 +113,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
|
|
|
91
113
|
type: Input
|
|
92
114
|
}], id: [{
|
|
93
115
|
type: Input
|
|
116
|
+
}], noEidLookup: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], hasSubmit: [{
|
|
119
|
+
type: Input
|
|
94
120
|
}], idChange: [{
|
|
95
121
|
type: Output
|
|
96
122
|
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asserted-id.component.js","sourceRoot":"","sources":["../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-id/asserted-id.component.ts","../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-id/asserted-id.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, 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 { ThesaurusEntry } from '@myrmidon/cadmus-core';\r\nimport { Assertion } from '@myrmidon/cadmus-refs-assertion';\r\nimport { debounceTime } from 'rxjs/operators';\r\n\r\nexport interface AssertedId {\r\n  tag?: string;\r\n  value: string;\r\n  scope: string;\r\n  assertion?: Assertion;\r\n}\r\n\r\n@Component({\r\n  selector: 'cadmus-refs-asserted-id',\r\n  templateUrl: './asserted-id.component.html',\r\n  styleUrls: ['./asserted-id.component.css'],\r\n})\r\nexport class AssertedIdComponent implements OnInit {\r\n  private _updatingForm: boolean | undefined;\r\n  private _id: AssertedId | undefined;\r\n\r\n  public tag: FormControl<string | null>;\r\n  public value: FormControl<string | null>;\r\n  public scope: FormControl<string | null>;\r\n  public form: FormGroup;\r\n\r\n  public initialAssertion?: Assertion;\r\n  public assertion?: Assertion;\r\n\r\n  @Input()\r\n  public scopeEntries?: ThesaurusEntry[];\r\n\r\n  @Input()\r\n  public idTagEntries?: ThesaurusEntry[];\r\n\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  @Input()\r\n  public get id(): AssertedId | undefined {\r\n    return this._id;\r\n  }\r\n  public set id(value: AssertedId | undefined) {\r\n    if (this._id !== value) {\r\n      this._id = value;\r\n      this.updateForm(value);\r\n    }\r\n  }\r\n\r\n  @Output()\r\n  public idChange: EventEmitter<AssertedId>;\r\n\r\n  constructor(formBuilder: FormBuilder) {\r\n    this.idChange = new EventEmitter<AssertedId>();\r\n    // form\r\n    this.tag = formBuilder.control(null, Validators.maxLength(50));\r\n    this.value = formBuilder.control(null, [\r\n      Validators.required,\r\n      Validators.maxLength(500),\r\n    ]);\r\n    this.scope = formBuilder.control(null, Validators.maxLength(500));\r\n    this.form = formBuilder.group({\r\n      tag: this.tag,\r\n      value: this.value,\r\n      scope: this.scope,\r\n    });\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.form.valueChanges.pipe(debounceTime(300)).subscribe((_) => {\r\n      if (!this._updatingForm) {\r\n        this.emitIdChange();\r\n      }\r\n    });\r\n  }\r\n\r\n  public onAssertionChange(assertion: Assertion | undefined): void {\r\n    this.assertion = assertion;\r\n    setTimeout(() => this.emitIdChange(), 0);\r\n  }\r\n\r\n  private updateForm(value: AssertedId | undefined): void {\r\n    this._updatingForm = true;\r\n    if (!value) {\r\n      this.form.reset();\r\n      this.assertion = undefined;\r\n    } else {\r\n      this.tag.setValue(value.tag || null);\r\n      this.value.setValue(value.value);\r\n      this.scope.setValue(value.scope);\r\n      this.initialAssertion = value.assertion;\r\n      this.form.markAsPristine();\r\n    }\r\n    this._updatingForm = false;\r\n    this.emitIdChange();\r\n  }\r\n\r\n  private getId(): AssertedId {\r\n    return {\r\n      tag: this.tag.value?.trim(),\r\n      value: this.value.value?.trim() || '',\r\n      scope: this.scope.value?.trim() || '',\r\n      assertion: this.assertion,\r\n    };\r\n  }\r\n\r\n  public emitIdChange(): void {\r\n    this.idChange.emit(this.getId());\r\n  }\r\n}\r\n","<form [formGroup]=\"form\">\n  <div>\n    <!-- tag (bound) -->\n    <mat-form-field *ngIf=\"idTagEntries?.length\" style=\"width: 8em\">\n      <mat-label>tag</mat-label>\n      <mat-select [formControl]=\"tag\">\n        <mat-option *ngFor=\"let e of idTagEntries\" [value]=\"e.id\">{{\n          e.value\n        }}</mat-option>\n      </mat-select>\n    </mat-form-field>\n    <!-- tag (free) -->\n    <mat-form-field *ngIf=\"!idTagEntries?.length\" style=\"width: 8em\">\n      <mat-label>tag</mat-label>\n      <input matInput [formControl]=\"tag\" />\n      <mat-error *ngIf=\"tag.errors?.maxLength && (tag.dirty || tag.touched)\"\n        >tag too long</mat-error\n      >\n    </mat-form-field>\n    &nbsp;\n\n    <!-- scope (bound) -->\n    <mat-form-field *ngIf=\"scopeEntries?.length\" style=\"width: 8em\">\n      <mat-label>scope</mat-label>\n      <mat-select [formControl]=\"scope\">\n        <mat-option *ngFor=\"let e of scopeEntries\" [value]=\"e.id\">{{\n          e.value\n        }}</mat-option>\n      </mat-select>\n    </mat-form-field>\n    <!-- scope (free) -->\n    <mat-form-field *ngIf=\"!scopeEntries?.length\" style=\"width: 8em\">\n      <mat-label>scope</mat-label>\n      <input matInput [formControl]=\"scope\" />\n      <mat-error\n        *ngIf=\"scope.errors?.maxLength && (scope.dirty || scope.touched)\"\n        >scope too long</mat-error\n      >\n    </mat-form-field>\n    <!-- value -->\n    &nbsp;\n    <mat-form-field>\n      <mat-label>value</mat-label>\n      <input matInput [formControl]=\"value\" />\n      <mat-error\n        *ngIf=\"value.errors?.required && (value.dirty || value.touched)\"\n        >value required</mat-error\n      >\n      <mat-error\n        *ngIf=\"value.errors?.maxLength && (value.dirty || value.touched)\"\n        >value too long</mat-error\n      >\n    </mat-form-field>\n  </div>\n\n  <!-- assertion -->\n  <mat-expansion-panel>\n    <mat-expansion-panel-header>assertion</mat-expansion-panel-header>\n    <cadmus-refs-assertion\n      [assTagEntries]=\"assTagEntries\"\n      [refTypeEntries]=\"refTypeEntries\"\n      [refTagEntries]=\"refTagEntries\"\n      [assertion]=\"initialAssertion\"\n      (assertionChange)=\"onAssertionChange($event)\"\n    >\n    </cadmus-refs-assertion>\n  </mat-expansion-panel>\n</form>\n"]}
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asserted-id.component.js","sourceRoot":"","sources":["../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-id/asserted-id.component.ts","../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-id/asserted-id.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { debounceTime } from 'rxjs/operators';\r\n\r\nimport { IndexLookupDefinitions, ThesaurusEntry } from '@myrmidon/cadmus-core';\r\nimport { Assertion } from '@myrmidon/cadmus-refs-assertion';\r\n\r\nimport { PinRefLookupService } from '../services/pin-ref-lookup.service';\r\n\r\nexport interface AssertedId {\r\n  tag?: string;\r\n  value: string;\r\n  scope: string;\r\n  assertion?: Assertion;\r\n}\r\n\r\n@Component({\r\n  selector: 'cadmus-refs-asserted-id',\r\n  templateUrl: './asserted-id.component.html',\r\n  styleUrls: ['./asserted-id.component.css'],\r\n})\r\nexport class AssertedIdComponent implements OnInit {\r\n  private _updatingForm: boolean | undefined;\r\n  private _id: AssertedId | undefined;\r\n\r\n  public tag: FormControl<string | null>;\r\n  public value: FormControl<string | null>;\r\n  public scope: FormControl<string | null>;\r\n  public form: FormGroup;\r\n\r\n  public initialAssertion?: Assertion;\r\n  public assertion?: Assertion;\r\n  public lookupExpanded: boolean;\r\n\r\n  @Input()\r\n  public scopeEntries?: ThesaurusEntry[];\r\n\r\n  @Input()\r\n  public idTagEntries?: ThesaurusEntry[];\r\n\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  @Input()\r\n  public get id(): AssertedId | undefined {\r\n    return this._id;\r\n  }\r\n  public set id(value: AssertedId | undefined) {\r\n    if (this._id !== value) {\r\n      this._id = value;\r\n      this.updateForm(value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * True to hide the pin-based EID lookup UI.\r\n   */\r\n  @Input()\r\n  public noEidLookup: boolean | undefined;\r\n\r\n  @Input()\r\n  public hasSubmit: boolean | undefined;\r\n\r\n  @Output()\r\n  public idChange: EventEmitter<AssertedId>;\r\n\r\n  constructor(\r\n    formBuilder: FormBuilder,\r\n    public lookupService: PinRefLookupService,\r\n    @Inject('indexLookupDefinitions')\r\n    public lookupDefs: IndexLookupDefinitions\r\n  ) {\r\n    this.tag = formBuilder.control(null, Validators.maxLength(50));\r\n    this.value = formBuilder.control(null, [\r\n      Validators.required,\r\n      Validators.maxLength(500),\r\n    ]);\r\n    this.scope = formBuilder.control(null, Validators.maxLength(500));\r\n    this.form = formBuilder.group({\r\n      tag: this.tag,\r\n      value: this.value,\r\n      scope: this.scope,\r\n    });\r\n    this.lookupExpanded = false;\r\n    this.idChange = new EventEmitter<AssertedId>();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.form.valueChanges.pipe(debounceTime(300)).subscribe((_) => {\r\n      if (!this._updatingForm) {\r\n        this.emitIdChange();\r\n      }\r\n    });\r\n  }\r\n\r\n  public onAssertionChange(assertion: Assertion | undefined): void {\r\n    this.assertion = assertion;\r\n    setTimeout(() => this.emitIdChange(), 0);\r\n  }\r\n\r\n  public onIdPick(id: string): void {\r\n    this.value.setValue(id);\r\n    this.value.markAsDirty();\r\n    this.value.updateValueAndValidity();\r\n    this.lookupExpanded = false;\r\n  }\r\n\r\n  private updateForm(value: AssertedId | undefined): void {\r\n    this._updatingForm = true;\r\n    if (!value) {\r\n      this.form.reset();\r\n      this.assertion = undefined;\r\n    } else {\r\n      this.tag.setValue(value.tag || null);\r\n      this.value.setValue(value.value);\r\n      this.scope.setValue(value.scope);\r\n      this.initialAssertion = value.assertion;\r\n      this.form.markAsPristine();\r\n    }\r\n    this._updatingForm = false;\r\n    this.emitIdChange();\r\n  }\r\n\r\n  private getId(): AssertedId {\r\n    return {\r\n      tag: this.tag.value?.trim(),\r\n      value: this.value.value?.trim() || '',\r\n      scope: this.scope.value?.trim() || '',\r\n      assertion: this.assertion,\r\n    };\r\n  }\r\n\r\n  public emitIdChange(): void {\r\n    if (!this.hasSubmit) {\r\n      this.idChange.emit(this.getId());\r\n    }\r\n  }\r\n\r\n  public save(): void {\r\n    if (this.form.valid) {\r\n      this.idChange.emit(this.getId());\r\n    }\r\n  }\r\n}\r\n","<form [formGroup]=\"form\" (submit)=\"save()\">\n  <div>\n    <div class=\"form-row\">\n      <!-- tag (bound) -->\n      <mat-form-field *ngIf=\"idTagEntries?.length\" style=\"width: 8em\">\n        <mat-label>tag</mat-label>\n        <mat-select [formControl]=\"tag\">\n          <mat-option *ngFor=\"let e of idTagEntries\" [value]=\"e.id\">{{\n            e.value\n          }}</mat-option>\n        </mat-select>\n      </mat-form-field>\n      <!-- tag (free) -->\n      <mat-form-field *ngIf=\"!idTagEntries?.length\" style=\"width: 8em\">\n        <mat-label>tag</mat-label>\n        <input matInput [formControl]=\"tag\" />\n        <mat-error *ngIf=\"tag.errors?.maxLength && (tag.dirty || tag.touched)\"\n          >tag too long</mat-error\n        >\n      </mat-form-field>\n\n      <!-- scope (bound) -->\n      <mat-form-field *ngIf=\"scopeEntries?.length\" style=\"width: 8em\">\n        <mat-label>scope</mat-label>\n        <mat-select [formControl]=\"scope\">\n          <mat-option *ngFor=\"let e of scopeEntries\" [value]=\"e.id\">{{\n            e.value\n          }}</mat-option>\n        </mat-select>\n      </mat-form-field>\n      <!-- scope (free) -->\n      <mat-form-field *ngIf=\"!scopeEntries?.length\" style=\"width: 8em\">\n        <mat-label>scope</mat-label>\n        <input matInput [formControl]=\"scope\" />\n        <mat-error\n          *ngIf=\"scope.errors?.maxLength && (scope.dirty || scope.touched)\"\n          >scope too long</mat-error\n        >\n      </mat-form-field>\n\n      <!-- value -->\n      <mat-form-field>\n        <mat-label>value</mat-label>\n        <input matInput [formControl]=\"value\" />\n        <mat-error\n          *ngIf=\"value.errors?.required && (value.dirty || value.touched)\"\n          >value required</mat-error\n        >\n        <mat-error\n          *ngIf=\"value.errors?.maxLength && (value.dirty || value.touched)\"\n          >value too long</mat-error\n        >\n      </mat-form-field>\n\n      <!-- lookup -->\n      <div *ngIf=\"!noEidLookup\" style=\"margin-top: 4px\">\n        <mat-expansion-panel [(expanded)]=\"lookupExpanded\">\n          <mat-expansion-panel-header>lookup</mat-expansion-panel-header>\n          <cadmus-scoped-pin-lookup\n            (idPick)=\"onIdPick($event)\"\n          ></cadmus-scoped-pin-lookup>\n        </mat-expansion-panel>\n      </div>\n    </div>\n\n    <!-- assertion -->\n    <mat-expansion-panel>\n      <mat-expansion-panel-header>assertion</mat-expansion-panel-header>\n      <cadmus-refs-assertion\n        [assTagEntries]=\"assTagEntries\"\n        [refTypeEntries]=\"refTypeEntries\"\n        [refTagEntries]=\"refTagEntries\"\n        [assertion]=\"initialAssertion\"\n        (assertionChange)=\"onAssertionChange($event)\"\n      >\n      </cadmus-refs-assertion>\n    </mat-expansion-panel>\n  </div>\n\n  <!-- buttons -->\n  <div *ngIf=\"hasSubmit\">\n    <button mat-icon-button color=\"warn\" type=\"button\">\n      <mat-icon>close</mat-icon>\n    </button>\n    <button\n      mat-icon-button\n      color=\"primary\"\n      type=\"submit\"\n      [disabled]=\"form.invalid\"\n    >\n      <mat-icon>check_circle</mat-icon>\n    </button>\n  </div>\n</form>\n"]}
|