@myrmidon/cadmus-refs-asserted-ids 1.0.8 → 2.0.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.
Files changed (25) hide show
  1. package/esm2022/lib/asserted-id/asserted-id.component.mjs +133 -0
  2. package/esm2022/lib/asserted-ids/asserted-ids.component.mjs +147 -0
  3. package/esm2022/lib/cadmus-refs-asserted-ids.module.mjs +92 -0
  4. package/esm2022/lib/scoped-pin-lookup/scoped-pin-lookup.component.mjs +130 -0
  5. package/esm2022/lib/services/pin-ref-lookup.service.mjs +73 -0
  6. package/{esm2020 → esm2022}/myrmidon-cadmus-refs-asserted-ids.mjs +4 -4
  7. package/{esm2020 → esm2022}/public-api.mjs +8 -8
  8. package/{fesm2020 → fesm2022}/myrmidon-cadmus-refs-asserted-ids.mjs +500 -498
  9. package/fesm2022/myrmidon-cadmus-refs-asserted-ids.mjs.map +1 -0
  10. package/index.d.ts +5 -5
  11. package/lib/asserted-id/asserted-id.component.d.ts +49 -50
  12. package/lib/asserted-ids/asserted-ids.component.d.ts +44 -44
  13. package/lib/cadmus-refs-asserted-ids.module.d.ts +22 -22
  14. package/lib/scoped-pin-lookup/scoped-pin-lookup.component.d.ts +39 -39
  15. package/lib/services/pin-ref-lookup.service.d.ts +18 -18
  16. package/package.json +8 -14
  17. package/public-api.d.ts +5 -5
  18. package/esm2020/lib/asserted-id/asserted-id.component.mjs +0 -130
  19. package/esm2020/lib/asserted-ids/asserted-ids.component.mjs +0 -146
  20. package/esm2020/lib/cadmus-refs-asserted-ids.module.mjs +0 -91
  21. package/esm2020/lib/scoped-pin-lookup/scoped-pin-lookup.component.mjs +0 -129
  22. package/esm2020/lib/services/pin-ref-lookup.service.mjs +0 -72
  23. package/fesm2015/myrmidon-cadmus-refs-asserted-ids.mjs +0 -552
  24. package/fesm2015/myrmidon-cadmus-refs-asserted-ids.mjs.map +0 -1
  25. package/fesm2020/myrmidon-cadmus-refs-asserted-ids.mjs.map +0 -1
@@ -0,0 +1,133 @@
1
+ import { Component, EventEmitter, Inject, Input, Output, } from '@angular/core';
2
+ import { Validators, } from '@angular/forms';
3
+ import { debounceTime } from 'rxjs/operators';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/forms";
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";
17
+ class AssertedIdComponent {
18
+ get id() {
19
+ return this._id;
20
+ }
21
+ set id(value) {
22
+ if (this._id !== value) {
23
+ this._id = value || undefined;
24
+ this.updateForm(this._id);
25
+ }
26
+ }
27
+ constructor(formBuilder, lookupService, lookupDefs) {
28
+ this.lookupService = lookupService;
29
+ this.lookupDefs = lookupDefs;
30
+ this.tag = formBuilder.control(null, Validators.maxLength(50));
31
+ this.value = formBuilder.control(null, [
32
+ Validators.required,
33
+ Validators.maxLength(500),
34
+ ]);
35
+ this.scope = formBuilder.control(null, Validators.maxLength(500));
36
+ this.assertion = formBuilder.control(null);
37
+ this.form = formBuilder.group({
38
+ tag: this.tag,
39
+ value: this.value,
40
+ scope: this.scope,
41
+ assertion: this.assertion
42
+ });
43
+ this.lookupExpanded = false;
44
+ // events
45
+ this.idChange = new EventEmitter();
46
+ this.editorClose = new EventEmitter();
47
+ }
48
+ ngOnInit() {
49
+ this.form.valueChanges.pipe(debounceTime(300)).subscribe((_) => {
50
+ if (!this._updatingForm) {
51
+ this.emitIdChange();
52
+ }
53
+ });
54
+ }
55
+ onAssertionChange(assertion) {
56
+ this.assertion.setValue(assertion || null);
57
+ }
58
+ onIdPick(id) {
59
+ this.value.setValue(id);
60
+ this.value.markAsDirty();
61
+ this.value.updateValueAndValidity();
62
+ this.lookupExpanded = false;
63
+ }
64
+ updateForm(value) {
65
+ this._updatingForm = true;
66
+ if (!value) {
67
+ this.form.reset();
68
+ }
69
+ else {
70
+ this.tag.setValue(value.tag || null);
71
+ this.value.setValue(value.value);
72
+ this.scope.setValue(value.scope);
73
+ this.assertion.setValue(value.assertion || null);
74
+ this.form.markAsPristine();
75
+ }
76
+ this._updatingForm = false;
77
+ // this.emitIdChange();
78
+ }
79
+ getId() {
80
+ return {
81
+ tag: this.tag.value?.trim(),
82
+ value: this.value.value?.trim() || '',
83
+ scope: this.scope.value?.trim() || '',
84
+ assertion: this.assertion.value || undefined,
85
+ };
86
+ }
87
+ emitIdChange() {
88
+ if (!this.hasSubmit) {
89
+ this._id = this.getId();
90
+ this.idChange.emit(this._id);
91
+ }
92
+ }
93
+ cancel() {
94
+ this.editorClose.emit();
95
+ }
96
+ save() {
97
+ if (this.form.valid) {
98
+ this._id = this.getId();
99
+ this.idChange.emit(this._id);
100
+ }
101
+ }
102
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AssertedIdComponent, deps: [{ token: i1.FormBuilder }, { token: i2.PinRefLookupService }, { token: 'indexLookupDefinitions' }], target: i0.ɵɵFactoryTarget.Component }); }
103
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AssertedIdComponent, selector: "cadmus-refs-asserted-id", inputs: { idScopeEntries: "idScopeEntries", idTagEntries: "idTagEntries", assTagEntries: "assTagEntries", refTypeEntries: "refTypeEntries", refTagEntries: "refTagEntries", id: "id", noEidLookup: "noEidLookup", hasSubmit: "hasSubmit" }, outputs: { idChange: "idChange", editorClose: "editorClose" }, 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=\"idScopeEntries?.length\" style=\"width: 8em\">\n <mat-label>scope</mat-label>\n <mat-select [formControl]=\"scope\">\n <mat-option *ngFor=\"let e of idScopeEntries\" [value]=\"e.id\">{{\n e.value\n }}</mat-option>\n </mat-select>\n </mat-form-field>\n <!-- scope (free) -->\n <mat-form-field *ngIf=\"!idScopeEntries?.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]=\"assertion.value\"\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\" (click)=\"cancel()\">\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", "hideSingleSelectionIndicator"], 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"] }] }); }
104
+ }
105
+ export { AssertedIdComponent };
106
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AssertedIdComponent, decorators: [{
107
+ type: Component,
108
+ 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=\"idScopeEntries?.length\" style=\"width: 8em\">\n <mat-label>scope</mat-label>\n <mat-select [formControl]=\"scope\">\n <mat-option *ngFor=\"let e of idScopeEntries\" [value]=\"e.id\">{{\n e.value\n }}</mat-option>\n </mat-select>\n </mat-form-field>\n <!-- scope (free) -->\n <mat-form-field *ngIf=\"!idScopeEntries?.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]=\"assertion.value\"\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\" (click)=\"cancel()\">\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"] }]
109
+ }], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.PinRefLookupService }, { type: undefined, decorators: [{
110
+ type: Inject,
111
+ args: ['indexLookupDefinitions']
112
+ }] }]; }, propDecorators: { idScopeEntries: [{
113
+ type: Input
114
+ }], idTagEntries: [{
115
+ type: Input
116
+ }], assTagEntries: [{
117
+ type: Input
118
+ }], refTypeEntries: [{
119
+ type: Input
120
+ }], refTagEntries: [{
121
+ type: Input
122
+ }], id: [{
123
+ type: Input
124
+ }], noEidLookup: [{
125
+ type: Input
126
+ }], hasSubmit: [{
127
+ type: Input
128
+ }], idChange: [{
129
+ type: Output
130
+ }], editorClose: [{
131
+ type: Output
132
+ }] } });
133
+ //# 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 assertion: FormControl<Assertion | null>;\r\n  public form: FormGroup;\r\n\r\n  public lookupExpanded: boolean;\r\n\r\n  // asserted-id-scopes\r\n  @Input()\r\n  public idScopeEntries?: ThesaurusEntry[];\r\n\r\n  // asserted-id-tags\r\n  @Input()\r\n  public idTagEntries?: ThesaurusEntry[];\r\n\r\n  // assertion-tags\r\n  @Input()\r\n  public assTagEntries?: ThesaurusEntry[];\r\n\r\n  // doc-reference-types\r\n  @Input()\r\n  public refTypeEntries: ThesaurusEntry[] | undefined;\r\n\r\n  // doc-reference-tags\r\n  @Input()\r\n  public refTagEntries: ThesaurusEntry[] | undefined;\r\n\r\n  @Input()\r\n  public get id(): AssertedId | undefined | null {\r\n    return this._id;\r\n  }\r\n  public set id(value: AssertedId | undefined | null) {\r\n    if (this._id !== value) {\r\n      this._id = value || undefined;\r\n      this.updateForm(this._id);\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  @Output()\r\n  public editorClose: EventEmitter<any>;\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.assertion = formBuilder.control(null);\r\n    this.form = formBuilder.group({\r\n      tag: this.tag,\r\n      value: this.value,\r\n      scope: this.scope,\r\n      assertion: this.assertion\r\n    });\r\n    this.lookupExpanded = false;\r\n    // events\r\n    this.idChange = new EventEmitter<AssertedId>();\r\n    this.editorClose = new EventEmitter<any>();\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.setValue(assertion || null);\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    } 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.assertion.setValue(value.assertion || null);\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.value || undefined,\r\n    };\r\n  }\r\n\r\n  public emitIdChange(): void {\r\n    if (!this.hasSubmit) {\r\n      this._id = this.getId();\r\n      this.idChange.emit(this._id);\r\n    }\r\n  }\r\n\r\n  public cancel(): void {\r\n    this.editorClose.emit();\r\n  }\r\n\r\n  public save(): void {\r\n    if (this.form.valid) {\r\n      this._id = this.getId();\r\n      this.idChange.emit(this._id);\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=\"idScopeEntries?.length\" style=\"width: 8em\">\n        <mat-label>scope</mat-label>\n        <mat-select [formControl]=\"scope\">\n          <mat-option *ngFor=\"let e of idScopeEntries\" [value]=\"e.id\">{{\n            e.value\n          }}</mat-option>\n        </mat-select>\n      </mat-form-field>\n      <!-- scope (free) -->\n      <mat-form-field *ngIf=\"!idScopeEntries?.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]=\"assertion.value\"\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\" (click)=\"cancel()\">\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"]}
@@ -0,0 +1,147 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { take } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/forms";
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";
9
+ import * as i6 from "@angular/material/icon";
10
+ import * as i7 from "../asserted-id/asserted-id.component";
11
+ /**
12
+ * Asserted IDs editor.
13
+ */
14
+ class AssertedIdsComponent {
15
+ /**
16
+ * The asserted IDs.
17
+ */
18
+ get ids() {
19
+ return this._ids;
20
+ }
21
+ set ids(value) {
22
+ if (this._ids !== value) {
23
+ this._ids = value || [];
24
+ this.updateForm(value);
25
+ }
26
+ }
27
+ constructor(formBuilder, _dialogService) {
28
+ this._dialogService = _dialogService;
29
+ this._ids = [];
30
+ this._editedIndex = -1;
31
+ this.idsChange = new EventEmitter();
32
+ this.entries = formBuilder.control([], { nonNullable: true });
33
+ // form
34
+ this.form = formBuilder.group({
35
+ ids: this.entries,
36
+ });
37
+ }
38
+ updateForm(ids) {
39
+ if (!ids?.length) {
40
+ this.form.reset();
41
+ return;
42
+ }
43
+ this.entries.setValue(ids, { emitEvent: false });
44
+ this.entries.updateValueAndValidity();
45
+ this.form.markAsPristine();
46
+ }
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);
68
+ }
69
+ else {
70
+ entries.splice(this._editedIndex, 1, entry);
71
+ }
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
+ }
95
+ moveIdUp(index) {
96
+ if (index < 1) {
97
+ return;
98
+ }
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();
106
+ this.emitIdsChange();
107
+ }
108
+ moveIdDown(index) {
109
+ if (index + 1 >= this.entries.value.length) {
110
+ return;
111
+ }
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();
119
+ this.emitIdsChange();
120
+ }
121
+ onIdChange(id) {
122
+ this.saveId(id);
123
+ this.emitIdsChange();
124
+ }
125
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AssertedIdsComponent, deps: [{ token: i1.FormBuilder }, { token: i2.DialogService }], target: i0.ɵɵFactoryTarget.Component }); }
126
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AssertedIdsComponent, selector: "cadmus-refs-asserted-ids", inputs: { ids: "ids", idScopeEntries: "idScopeEntries", idTagEntries: "idTagEntries", 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 {{edited?.value}}</mat-expansion-panel-header>\r\n <cadmus-refs-asserted-id\r\n [idScopeEntries]=\"idScopeEntries\"\r\n [idTagEntries]=\"idTagEntries\"\r\n [assTagEntries]=\"assTagEntries\"\r\n [refTypeEntries]=\"refTypeEntries\"\r\n [refTagEntries]=\"refTagEntries\"\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: ["idScopeEntries", "idTagEntries", "assTagEntries", "refTypeEntries", "refTagEntries", "id", "noEidLookup", "hasSubmit"], outputs: ["idChange", "editorClose"] }] }); }
127
+ }
128
+ export { AssertedIdsComponent };
129
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AssertedIdsComponent, decorators: [{
130
+ type: Component,
131
+ 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 {{edited?.value}}</mat-expansion-panel-header>\r\n <cadmus-refs-asserted-id\r\n [idScopeEntries]=\"idScopeEntries\"\r\n [idTagEntries]=\"idTagEntries\"\r\n [assTagEntries]=\"assTagEntries\"\r\n [refTypeEntries]=\"refTypeEntries\"\r\n [refTagEntries]=\"refTagEntries\"\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"] }]
132
+ }], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.DialogService }]; }, propDecorators: { ids: [{
133
+ type: Input
134
+ }], idScopeEntries: [{
135
+ type: Input
136
+ }], idTagEntries: [{
137
+ type: Input
138
+ }], assTagEntries: [{
139
+ type: Input
140
+ }], refTypeEntries: [{
141
+ type: Input
142
+ }], refTagEntries: [{
143
+ type: Input
144
+ }], idsChange: [{
145
+ type: Output
146
+ }] } });
147
+ //# 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 { Component, EventEmitter, Input, Output } 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 { 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  // asserted-id-scopes\r\n  @Input()\r\n  public idScopeEntries?: ThesaurusEntry[];\r\n\r\n  // asserted-id-tags\r\n  @Input()\r\n  public idTagEntries?: ThesaurusEntry[];\r\n\r\n  // assertion-tags\r\n  @Input()\r\n  public assTagEntries?: ThesaurusEntry[];\r\n\r\n  // doc-reference-types\r\n  @Input()\r\n  public refTypeEntries: ThesaurusEntry[] | undefined;\r\n\r\n  // doc-reference-tags\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 {{edited?.value}}</mat-expansion-panel-header>\r\n    <cadmus-refs-asserted-id\r\n      [idScopeEntries]=\"idScopeEntries\"\r\n      [idTagEntries]=\"idTagEntries\"\r\n      [assTagEntries]=\"assTagEntries\"\r\n      [refTypeEntries]=\"refTypeEntries\"\r\n      [refTagEntries]=\"refTagEntries\"\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"]}
@@ -0,0 +1,92 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
+ import { MatButtonModule } from '@angular/material/button';
5
+ import { MatExpansionModule } from '@angular/material/expansion';
6
+ import { MatFormFieldModule } from '@angular/material/form-field';
7
+ import { MatIconModule } from '@angular/material/icon';
8
+ import { MatInputModule } from '@angular/material/input';
9
+ import { MatSelectModule } from '@angular/material/select';
10
+ import { CadmusCoreModule } from '@myrmidon/cadmus-core';
11
+ import { CadmusApiModule } from '@myrmidon/cadmus-api';
12
+ import { CadmusRefsAssertionModule } from '@myrmidon/cadmus-refs-assertion';
13
+ import { CadmusRefsDocReferencesModule } from '@myrmidon/cadmus-refs-doc-references';
14
+ import { CadmusRefsLookupModule } from '@myrmidon/cadmus-refs-lookup';
15
+ import { AssertedIdComponent } from './asserted-id/asserted-id.component';
16
+ import { AssertedIdsComponent } from './asserted-ids/asserted-ids.component';
17
+ import { ScopedPinLookupComponent } from './scoped-pin-lookup/scoped-pin-lookup.component';
18
+ import * as i0 from "@angular/core";
19
+ class CadmusRefsAssertedIdsModule {
20
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: CadmusRefsAssertedIdsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
21
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.1", ngImport: i0, type: CadmusRefsAssertedIdsModule, declarations: [AssertedIdComponent,
22
+ AssertedIdsComponent,
23
+ ScopedPinLookupComponent], imports: [CommonModule,
24
+ FormsModule,
25
+ ReactiveFormsModule,
26
+ // material
27
+ MatButtonModule,
28
+ MatExpansionModule,
29
+ MatFormFieldModule,
30
+ MatIconModule,
31
+ MatInputModule,
32
+ MatSelectModule,
33
+ // Cadmus
34
+ CadmusCoreModule,
35
+ CadmusRefsDocReferencesModule,
36
+ CadmusRefsAssertionModule,
37
+ CadmusRefsLookupModule,
38
+ CadmusApiModule], exports: [AssertedIdComponent,
39
+ AssertedIdsComponent,
40
+ ScopedPinLookupComponent] }); }
41
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: CadmusRefsAssertedIdsModule, imports: [CommonModule,
42
+ FormsModule,
43
+ ReactiveFormsModule,
44
+ // material
45
+ MatButtonModule,
46
+ MatExpansionModule,
47
+ MatFormFieldModule,
48
+ MatIconModule,
49
+ MatInputModule,
50
+ MatSelectModule,
51
+ // Cadmus
52
+ CadmusCoreModule,
53
+ CadmusRefsDocReferencesModule,
54
+ CadmusRefsAssertionModule,
55
+ CadmusRefsLookupModule,
56
+ CadmusApiModule] }); }
57
+ }
58
+ export { CadmusRefsAssertedIdsModule };
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: CadmusRefsAssertedIdsModule, decorators: [{
60
+ type: NgModule,
61
+ args: [{
62
+ declarations: [
63
+ AssertedIdComponent,
64
+ AssertedIdsComponent,
65
+ ScopedPinLookupComponent,
66
+ ],
67
+ imports: [
68
+ CommonModule,
69
+ FormsModule,
70
+ ReactiveFormsModule,
71
+ // material
72
+ MatButtonModule,
73
+ MatExpansionModule,
74
+ MatFormFieldModule,
75
+ MatIconModule,
76
+ MatInputModule,
77
+ MatSelectModule,
78
+ // Cadmus
79
+ CadmusCoreModule,
80
+ CadmusRefsDocReferencesModule,
81
+ CadmusRefsAssertionModule,
82
+ CadmusRefsLookupModule,
83
+ CadmusApiModule,
84
+ ],
85
+ exports: [
86
+ AssertedIdComponent,
87
+ AssertedIdsComponent,
88
+ ScopedPinLookupComponent,
89
+ ],
90
+ }]
91
+ }] });
92
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FkbXVzLXJlZnMtYXNzZXJ0ZWQtaWRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cm1pZG9uL2NhZG11cy1yZWZzLWFzc2VydGVkLWlkcy9zcmMvbGliL2NhZG11cy1yZWZzLWFzc2VydGVkLWlkcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWxFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUUzRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdkQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDNUUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDckYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFdEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDMUUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saURBQWlELENBQUM7O0FBRTNGLE1BOEJhLDJCQUEyQjs4R0FBM0IsMkJBQTJCOytHQUEzQiwyQkFBMkIsaUJBNUJwQyxtQkFBbUI7WUFDbkIsb0JBQW9CO1lBQ3BCLHdCQUF3QixhQUd4QixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixXQUFXO1lBQ1gsZUFBZTtZQUNmLGtCQUFrQjtZQUNsQixrQkFBa0I7WUFDbEIsYUFBYTtZQUNiLGNBQWM7WUFDZCxlQUFlO1lBQ2YsU0FBUztZQUNULGdCQUFnQjtZQUNoQiw2QkFBNkI7WUFDN0IseUJBQXlCO1lBQ3pCLHNCQUFzQjtZQUN0QixlQUFlLGFBR2YsbUJBQW1CO1lBQ25CLG9CQUFvQjtZQUNwQix3QkFBd0I7K0dBR2YsMkJBQTJCLFlBdkJwQyxZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixXQUFXO1lBQ1gsZUFBZTtZQUNmLGtCQUFrQjtZQUNsQixrQkFBa0I7WUFDbEIsYUFBYTtZQUNiLGNBQWM7WUFDZCxlQUFlO1lBQ2YsU0FBUztZQUNULGdCQUFnQjtZQUNoQiw2QkFBNkI7WUFDN0IseUJBQXlCO1lBQ3pCLHNCQUFzQjtZQUN0QixlQUFlOztTQVFOLDJCQUEyQjsyRkFBM0IsMkJBQTJCO2tCQTlCdkMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osbUJBQW1CO3dCQUNuQixvQkFBb0I7d0JBQ3BCLHdCQUF3QjtxQkFDekI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLFdBQVc7d0JBQ1gsZUFBZTt3QkFDZixrQkFBa0I7d0JBQ2xCLGtCQUFrQjt3QkFDbEIsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGVBQWU7d0JBQ2YsU0FBUzt3QkFDVCxnQkFBZ0I7d0JBQ2hCLDZCQUE2Qjt3QkFDN0IseUJBQXlCO3dCQUN6QixzQkFBc0I7d0JBQ3RCLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxtQkFBbUI7d0JBQ25CLG9CQUFvQjt3QkFDcEIsd0JBQXdCO3FCQUN6QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRFeHBhbnNpb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9leHBhbnNpb24nO1xuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IE1hdFNlbGVjdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XG5cbmltcG9ydCB7IENhZG11c0NvcmVNb2R1bGUgfSBmcm9tICdAbXlybWlkb24vY2FkbXVzLWNvcmUnO1xuaW1wb3J0IHsgQ2FkbXVzQXBpTW9kdWxlIH0gZnJvbSAnQG15cm1pZG9uL2NhZG11cy1hcGknO1xuaW1wb3J0IHsgQ2FkbXVzUmVmc0Fzc2VydGlvbk1vZHVsZSB9IGZyb20gJ0BteXJtaWRvbi9jYWRtdXMtcmVmcy1hc3NlcnRpb24nO1xuaW1wb3J0IHsgQ2FkbXVzUmVmc0RvY1JlZmVyZW5jZXNNb2R1bGUgfSBmcm9tICdAbXlybWlkb24vY2FkbXVzLXJlZnMtZG9jLXJlZmVyZW5jZXMnO1xuaW1wb3J0IHsgQ2FkbXVzUmVmc0xvb2t1cE1vZHVsZSB9IGZyb20gJ0BteXJtaWRvbi9jYWRtdXMtcmVmcy1sb29rdXAnO1xuXG5pbXBvcnQgeyBBc3NlcnRlZElkQ29tcG9uZW50IH0gZnJvbSAnLi9hc3NlcnRlZC1pZC9hc3NlcnRlZC1pZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQXNzZXJ0ZWRJZHNDb21wb25lbnQgfSBmcm9tICcuL2Fzc2VydGVkLWlkcy9hc3NlcnRlZC1pZHMuY29tcG9uZW50JztcbmltcG9ydCB7IFNjb3BlZFBpbkxvb2t1cENvbXBvbmVudCB9IGZyb20gJy4vc2NvcGVkLXBpbi1sb29rdXAvc2NvcGVkLXBpbi1sb29rdXAuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQXNzZXJ0ZWRJZENvbXBvbmVudCxcbiAgICBBc3NlcnRlZElkc0NvbXBvbmVudCxcbiAgICBTY29wZWRQaW5Mb29rdXBDb21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICAvLyBtYXRlcmlhbFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBNYXRFeHBhbnNpb25Nb2R1bGUsXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0SW5wdXRNb2R1bGUsXG4gICAgTWF0U2VsZWN0TW9kdWxlLFxuICAgIC8vIENhZG11c1xuICAgIENhZG11c0NvcmVNb2R1bGUsXG4gICAgQ2FkbXVzUmVmc0RvY1JlZmVyZW5jZXNNb2R1bGUsXG4gICAgQ2FkbXVzUmVmc0Fzc2VydGlvbk1vZHVsZSxcbiAgICBDYWRtdXNSZWZzTG9va3VwTW9kdWxlLFxuICAgIENhZG11c0FwaU1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEFzc2VydGVkSWRDb21wb25lbnQsXG4gICAgQXNzZXJ0ZWRJZHNDb21wb25lbnQsXG4gICAgU2NvcGVkUGluTG9va3VwQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBDYWRtdXNSZWZzQXNzZXJ0ZWRJZHNNb2R1bGUge31cbiJdfQ==