@myrmidon/cadmus-refs-asserted-ids 1.0.9 → 2.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +96 -96
- package/esm2022/lib/asserted-composite-id/asserted-composite-id.component.mjs +142 -0
- package/esm2022/lib/asserted-composite-ids/asserted-composite-ids.component.mjs +154 -0
- package/esm2022/lib/asserted-id/asserted-id.component.mjs +133 -0
- package/esm2022/lib/asserted-ids/asserted-ids.component.mjs +147 -0
- package/esm2022/lib/cadmus-refs-asserted-ids.module.mjs +122 -0
- package/esm2022/lib/pin-target-lookup/pin-target-lookup.component.mjs +405 -0
- package/esm2022/lib/scoped-pin-lookup/scoped-pin-lookup.component.mjs +130 -0
- package/esm2022/lib/services/item-ref-lookup.service.mjs +29 -0
- package/esm2022/lib/services/pin-ref-lookup.service.mjs +85 -0
- package/{esm2020 → esm2022}/myrmidon-cadmus-refs-asserted-ids.mjs +4 -4
- package/esm2022/public-api.mjs +13 -0
- package/fesm2022/myrmidon-cadmus-refs-asserted-ids.mjs +1265 -0
- package/fesm2022/myrmidon-cadmus-refs-asserted-ids.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/asserted-composite-id/asserted-composite-id.component.d.ts +83 -0
- package/lib/asserted-composite-ids/asserted-composite-ids.component.d.ts +67 -0
- package/lib/asserted-id/asserted-id.component.d.ts +49 -49
- package/lib/asserted-ids/asserted-ids.component.d.ts +44 -44
- package/lib/cadmus-refs-asserted-ids.module.d.ts +28 -22
- package/lib/pin-target-lookup/pin-target-lookup.component.d.ts +139 -0
- package/lib/scoped-pin-lookup/scoped-pin-lookup.component.d.ts +39 -39
- package/lib/services/item-ref-lookup.service.d.ts +13 -0
- package/lib/services/pin-ref-lookup.service.d.ts +27 -18
- package/package.json +8 -14
- package/public-api.d.ts +9 -5
- package/esm2020/lib/asserted-id/asserted-id.component.mjs +0 -132
- package/esm2020/lib/asserted-ids/asserted-ids.component.mjs +0 -146
- package/esm2020/lib/cadmus-refs-asserted-ids.module.mjs +0 -91
- package/esm2020/lib/scoped-pin-lookup/scoped-pin-lookup.component.mjs +0 -129
- package/esm2020/lib/services/pin-ref-lookup.service.mjs +0 -72
- package/esm2020/public-api.mjs +0 -9
- package/fesm2015/myrmidon-cadmus-refs-asserted-ids.mjs +0 -554
- package/fesm2015/myrmidon-cadmus-refs-asserted-ids.mjs.map +0 -1
- package/fesm2020/myrmidon-cadmus-refs-asserted-ids.mjs +0 -547
- package/fesm2020/myrmidon-cadmus-refs-asserted-ids.mjs.map +0 -1
package/README.md
CHANGED
|
@@ -1,96 +1,96 @@
|
|
|
1
|
-
# CadmusRefsAssertedIds
|
|
2
|
-
|
|
3
|
-
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 14.1.0.
|
|
4
|
-
|
|
5
|
-
## Model
|
|
6
|
-
|
|
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.
|
|
8
|
-
|
|
9
|
-
The asserted ID brick allows editing a simple model representing such IDs, having:
|
|
10
|
-
|
|
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.
|
|
15
|
-
|
|
16
|
-
The asserted IDs brick is just a collection of such IDs.
|
|
17
|
-
|
|
18
|
-
## Behavior
|
|
19
|
-
|
|
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.
|
|
21
|
-
|
|
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.
|
|
23
|
-
|
|
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).
|
|
25
|
-
|
|
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.
|
|
44
|
-
|
|
45
|
-
## Using Scoped ID Lookup
|
|
46
|
-
|
|
47
|
-
Apart from the IDs list, you can use the scoped ID lookup control to add a pin-based lookup for any entity in your own UI:
|
|
48
|
-
|
|
49
|
-
(1) ensure to import this module (`CadmusRefsAssertedIdsModule`).
|
|
50
|
-
|
|
51
|
-
(2) add a lookup control to your UI, like this:
|
|
52
|
-
|
|
53
|
-
```html
|
|
54
|
-
<!-- lookup -->
|
|
55
|
-
<cadmus-scoped-pin-lookup *ngIf="!noLookup" (idPick)="onIdPick($event)"></cadmus-scoped-pin-lookup>
|
|
56
|
-
```
|
|
57
|
-
|
|
58
|
-
In this sample, my UI has a `noLookup` property which can be used to hide the lookup if not required:
|
|
59
|
-
|
|
60
|
-
```ts
|
|
61
|
-
@Input()
|
|
62
|
-
public noLookup?: boolean;
|
|
63
|
-
|
|
64
|
-
public onIdPick(id: string): void {
|
|
65
|
-
// TODO: set your control's value, e.g.:
|
|
66
|
-
// this.myId.setValue(id);
|
|
67
|
-
// this.myId.updateValueAndValidity();
|
|
68
|
-
// this.myId.markAsDirty();
|
|
69
|
-
}
|
|
70
|
-
```
|
|
71
|
-
|
|
72
|
-
(3) in your app's `index-lookup-definitions.ts` file, add the required lookup definitions. Each definition has a conventional key, and is an object with part type ID for the lookup scope, and pin name, e.g.:
|
|
73
|
-
|
|
74
|
-
```ts
|
|
75
|
-
import { IndexLookupDefinitions } from '@myrmidon/cadmus-core';
|
|
76
|
-
import {
|
|
77
|
-
METADATA_PART_TYPEID,
|
|
78
|
-
HISTORICAL_EVENTS_PART_TYPEID,
|
|
79
|
-
} from '@myrmidon/cadmus-part-general-ui';
|
|
80
|
-
|
|
81
|
-
export const INDEX_LOOKUP_DEFINITIONS: IndexLookupDefinitions = {
|
|
82
|
-
// item's metadata
|
|
83
|
-
meta_eid: {
|
|
84
|
-
typeId: METADATA_PART_TYPEID,
|
|
85
|
-
name: 'eid',
|
|
86
|
-
},
|
|
87
|
-
// general parts
|
|
88
|
-
event_eid: {
|
|
89
|
-
typeId: HISTORICAL_EVENTS_PART_TYPEID,
|
|
90
|
-
name: 'eid',
|
|
91
|
-
},
|
|
92
|
-
// ... etc.
|
|
93
|
-
};
|
|
94
|
-
```
|
|
95
|
-
|
|
96
|
-
>Note that while pin name and type will not be displayed to the end user, the key of each definition will. Unless you have a single definition, the lookup component will display a dropdown list with all the available keys, so that the user can select the lookup's scope. So, use short, yet meaningful keys here, like in the above sample (`meta_eid`, `event_eid`).
|
|
1
|
+
# CadmusRefsAssertedIds
|
|
2
|
+
|
|
3
|
+
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 14.1.0.
|
|
4
|
+
|
|
5
|
+
## Model
|
|
6
|
+
|
|
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.
|
|
8
|
+
|
|
9
|
+
The asserted ID brick allows editing a simple model representing such IDs, having:
|
|
10
|
+
|
|
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.
|
|
15
|
+
|
|
16
|
+
The asserted IDs brick is just a collection of such IDs.
|
|
17
|
+
|
|
18
|
+
## Behavior
|
|
19
|
+
|
|
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.
|
|
21
|
+
|
|
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.
|
|
23
|
+
|
|
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).
|
|
25
|
+
|
|
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.
|
|
44
|
+
|
|
45
|
+
## Using Scoped ID Lookup
|
|
46
|
+
|
|
47
|
+
Apart from the IDs list, you can use the scoped ID lookup control to add a pin-based lookup for any entity in your own UI:
|
|
48
|
+
|
|
49
|
+
(1) ensure to import this module (`CadmusRefsAssertedIdsModule`).
|
|
50
|
+
|
|
51
|
+
(2) add a lookup control to your UI, like this:
|
|
52
|
+
|
|
53
|
+
```html
|
|
54
|
+
<!-- lookup -->
|
|
55
|
+
<cadmus-scoped-pin-lookup *ngIf="!noLookup" (idPick)="onIdPick($event)"></cadmus-scoped-pin-lookup>
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
In this sample, my UI has a `noLookup` property which can be used to hide the lookup if not required:
|
|
59
|
+
|
|
60
|
+
```ts
|
|
61
|
+
@Input()
|
|
62
|
+
public noLookup?: boolean;
|
|
63
|
+
|
|
64
|
+
public onIdPick(id: string): void {
|
|
65
|
+
// TODO: set your control's value, e.g.:
|
|
66
|
+
// this.myId.setValue(id);
|
|
67
|
+
// this.myId.updateValueAndValidity();
|
|
68
|
+
// this.myId.markAsDirty();
|
|
69
|
+
}
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
(3) in your app's `index-lookup-definitions.ts` file, add the required lookup definitions. Each definition has a conventional key, and is an object with part type ID for the lookup scope, and pin name, e.g.:
|
|
73
|
+
|
|
74
|
+
```ts
|
|
75
|
+
import { IndexLookupDefinitions } from '@myrmidon/cadmus-core';
|
|
76
|
+
import {
|
|
77
|
+
METADATA_PART_TYPEID,
|
|
78
|
+
HISTORICAL_EVENTS_PART_TYPEID,
|
|
79
|
+
} from '@myrmidon/cadmus-part-general-ui';
|
|
80
|
+
|
|
81
|
+
export const INDEX_LOOKUP_DEFINITIONS: IndexLookupDefinitions = {
|
|
82
|
+
// item's metadata
|
|
83
|
+
meta_eid: {
|
|
84
|
+
typeId: METADATA_PART_TYPEID,
|
|
85
|
+
name: 'eid',
|
|
86
|
+
},
|
|
87
|
+
// general parts
|
|
88
|
+
event_eid: {
|
|
89
|
+
typeId: HISTORICAL_EVENTS_PART_TYPEID,
|
|
90
|
+
name: 'eid',
|
|
91
|
+
},
|
|
92
|
+
// ... etc.
|
|
93
|
+
};
|
|
94
|
+
```
|
|
95
|
+
|
|
96
|
+
>Note that while pin name and type will not be displayed to the end user, the key of each definition will. Unless you have a single definition, the lookup component will display a dropdown list with all the available keys, so that the user can select the lookup's scope. So, use short, yet meaningful keys here, like in the above sample (`meta_eid`, `event_eid`).
|
|
@@ -0,0 +1,142 @@
|
|
|
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 "../pin-target-lookup/pin-target-lookup.component";
|
|
17
|
+
class AssertedCompositeIdComponent {
|
|
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.target = formBuilder.control(null, Validators.required);
|
|
31
|
+
this.scope = formBuilder.control(null, Validators.maxLength(500));
|
|
32
|
+
this.tag = formBuilder.control(null, Validators.maxLength(50));
|
|
33
|
+
this.assertion = formBuilder.control(null);
|
|
34
|
+
this.form = formBuilder.group({
|
|
35
|
+
target: this.target,
|
|
36
|
+
scope: this.scope,
|
|
37
|
+
tag: this.tag,
|
|
38
|
+
assertion: this.assertion,
|
|
39
|
+
});
|
|
40
|
+
this.targetExpanded = false;
|
|
41
|
+
// events
|
|
42
|
+
this.idChange = new EventEmitter();
|
|
43
|
+
this.editorClose = new EventEmitter();
|
|
44
|
+
}
|
|
45
|
+
ngOnInit() {
|
|
46
|
+
this.form.valueChanges.pipe(debounceTime(300)).subscribe((_) => {
|
|
47
|
+
if (!this._updatingForm) {
|
|
48
|
+
this.emitIdChange();
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
onAssertionChange(assertion) {
|
|
53
|
+
this.assertion.setValue(assertion || null);
|
|
54
|
+
}
|
|
55
|
+
onTargetChange(target) {
|
|
56
|
+
this.target.setValue(target);
|
|
57
|
+
this.target.markAsDirty();
|
|
58
|
+
this.target.updateValueAndValidity();
|
|
59
|
+
this.targetExpanded = false;
|
|
60
|
+
}
|
|
61
|
+
updateForm(id) {
|
|
62
|
+
this._updatingForm = true;
|
|
63
|
+
if (!id) {
|
|
64
|
+
this.form.reset();
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
this.target.setValue(id.target);
|
|
68
|
+
this.scope.setValue(id.scope || null);
|
|
69
|
+
this.tag.setValue(id.tag || null);
|
|
70
|
+
this.assertion.setValue(id.assertion || null);
|
|
71
|
+
this.form.markAsPristine();
|
|
72
|
+
}
|
|
73
|
+
this._updatingForm = false;
|
|
74
|
+
}
|
|
75
|
+
getId() {
|
|
76
|
+
const external = !this.target.value?.name;
|
|
77
|
+
const target = this.target.value;
|
|
78
|
+
return {
|
|
79
|
+
target: external
|
|
80
|
+
? {
|
|
81
|
+
gid: target?.gid || '',
|
|
82
|
+
label: target?.label || target?.gid || '',
|
|
83
|
+
}
|
|
84
|
+
: target,
|
|
85
|
+
scope: this.scope.value?.trim() || '',
|
|
86
|
+
tag: this.tag.value?.trim(),
|
|
87
|
+
assertion: this.assertion.value || undefined,
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
emitIdChange() {
|
|
91
|
+
if (!this.hasSubmit) {
|
|
92
|
+
this._id = this.getId();
|
|
93
|
+
this.idChange.emit(this._id);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
cancel() {
|
|
97
|
+
this.editorClose.emit();
|
|
98
|
+
}
|
|
99
|
+
save() {
|
|
100
|
+
if (this.form.valid) {
|
|
101
|
+
this._id = this.getId();
|
|
102
|
+
this.idChange.emit(this._id);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AssertedCompositeIdComponent, deps: [{ token: i1.FormBuilder }, { token: i2.PinRefLookupService }, { token: 'indexLookupDefinitions' }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
106
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AssertedCompositeIdComponent, selector: "cadmus-refs-asserted-composite-id", inputs: { idScopeEntries: "idScopeEntries", idTagEntries: "idTagEntries", assTagEntries: "assTagEntries", refTypeEntries: "refTypeEntries", refTagEntries: "refTagEntries", id: "id", hasSubmit: "hasSubmit", pinByTypeMode: "pinByTypeMode", canSwitchMode: "canSwitchMode", canEditTarget: "canEditTarget", lookupDefinitions: "lookupDefinitions" }, 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\" class=\"short-text\">\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\" class=\"short-text\">\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\" class=\"short-text\">\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\" class=\"short-text\">\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 <!-- label and GID -->\n <div class=\"info\" *ngIf=\"target.value?.label\">\n <span class=\"label\">label</span>{{ target.value?.label }}\n </div>\n <div class=\"info\" *ngIf=\"target.value?.gid\">\n <span class=\"label\">GID</span>{{ target.value?.gid }}\n </div>\n </div>\n\n <!-- target -->\n <div>\n <mat-expansion-panel [(expanded)]=\"targetExpanded\">\n <mat-expansion-panel-header>target</mat-expansion-panel-header>\n <cadmus-pin-target-lookup\n [pinByTypeMode]=\"pinByTypeMode\"\n [canSwitchMode]=\"canSwitchMode\"\n [canEditTarget]=\"canEditTarget\"\n [lookupDefinitions]=\"lookupDefinitions\"\n [target]=\"target.value\"\n (targetChange)=\"onTargetChange($event)\"\n ></cadmus-pin-target-lookup>\n </mat-expansion-panel>\n </div>\n\n <!-- assertion -->\n <br />\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\n mat-icon-button\n color=\"warn\"\n type=\"button\"\n (click)=\"cancel()\"\n [disabled]=\"!this.target.value?.gid || !this.target.value?.label\"\n >\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:center;flex-wrap:wrap}.form-row *{flex:0 0 auto}.short-text{width:8em}.pin-info{font-size:90%;color:silver}fieldset{border:1px solid silver;border-radius:6px;padding:6px}.info{border:1px solid silver;border-radius:6px;background-color:silver;color:#fff;padding:4px}.info .label{background-color:#fff;color:silver;margin:0 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.PinTargetLookupComponent, selector: "cadmus-pin-target-lookup", inputs: ["pinByTypeMode", "canSwitchMode", "canEditTarget", "lookupDefinitions", "target"], outputs: ["editorClose", "targetChange"] }] }); }
|
|
107
|
+
}
|
|
108
|
+
export { AssertedCompositeIdComponent };
|
|
109
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AssertedCompositeIdComponent, decorators: [{
|
|
110
|
+
type: Component,
|
|
111
|
+
args: [{ selector: 'cadmus-refs-asserted-composite-id', template: "<form [formGroup]=\"form\" (submit)=\"save()\">\n <div>\n <div class=\"form-row\">\n <!-- tag (bound) -->\n <mat-form-field *ngIf=\"idTagEntries?.length\" class=\"short-text\">\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\" class=\"short-text\">\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\" class=\"short-text\">\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\" class=\"short-text\">\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 <!-- label and GID -->\n <div class=\"info\" *ngIf=\"target.value?.label\">\n <span class=\"label\">label</span>{{ target.value?.label }}\n </div>\n <div class=\"info\" *ngIf=\"target.value?.gid\">\n <span class=\"label\">GID</span>{{ target.value?.gid }}\n </div>\n </div>\n\n <!-- target -->\n <div>\n <mat-expansion-panel [(expanded)]=\"targetExpanded\">\n <mat-expansion-panel-header>target</mat-expansion-panel-header>\n <cadmus-pin-target-lookup\n [pinByTypeMode]=\"pinByTypeMode\"\n [canSwitchMode]=\"canSwitchMode\"\n [canEditTarget]=\"canEditTarget\"\n [lookupDefinitions]=\"lookupDefinitions\"\n [target]=\"target.value\"\n (targetChange)=\"onTargetChange($event)\"\n ></cadmus-pin-target-lookup>\n </mat-expansion-panel>\n </div>\n\n <!-- assertion -->\n <br />\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\n mat-icon-button\n color=\"warn\"\n type=\"button\"\n (click)=\"cancel()\"\n [disabled]=\"!this.target.value?.gid || !this.target.value?.label\"\n >\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:center;flex-wrap:wrap}.form-row *{flex:0 0 auto}.short-text{width:8em}.pin-info{font-size:90%;color:silver}fieldset{border:1px solid silver;border-radius:6px;padding:6px}.info{border:1px solid silver;border-radius:6px;background-color:silver;color:#fff;padding:4px}.info .label{background-color:#fff;color:silver;margin:0 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"] }]
|
|
112
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.PinRefLookupService }, { type: undefined, decorators: [{
|
|
113
|
+
type: Inject,
|
|
114
|
+
args: ['indexLookupDefinitions']
|
|
115
|
+
}] }]; }, propDecorators: { idScopeEntries: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], idTagEntries: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], assTagEntries: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], refTypeEntries: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], refTagEntries: [{
|
|
124
|
+
type: Input
|
|
125
|
+
}], id: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], hasSubmit: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}], pinByTypeMode: [{
|
|
130
|
+
type: Input
|
|
131
|
+
}], canSwitchMode: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], canEditTarget: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], lookupDefinitions: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], idChange: [{
|
|
138
|
+
type: Output
|
|
139
|
+
}], editorClose: [{
|
|
140
|
+
type: Output
|
|
141
|
+
}] } });
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asserted-composite-id.component.js","sourceRoot":"","sources":["../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-composite-id/asserted-composite-id.component.ts","../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-composite-id/asserted-composite-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\nimport { PinTarget } from '../pin-target-lookup/pin-target-lookup.component';\r\n\r\n/**\r\n * An asserted composite ID. This can be an external ID, having only the ID value\r\n * as its target.gid property; or a lookup ID, with a pin-based target.\r\n * In both cases, we can add a tag, a scope, and an assertion.\r\n */\r\nexport interface AssertedCompositeId {\r\n  target: PinTarget;\r\n  tag?: string;\r\n  scope?: string;\r\n  assertion?: Assertion;\r\n}\r\n\r\n@Component({\r\n  selector: 'cadmus-refs-asserted-composite-id',\r\n  templateUrl: './asserted-composite-id.component.html',\r\n  styleUrls: ['./asserted-composite-id.component.css'],\r\n})\r\nexport class AssertedCompositeIdComponent implements OnInit {\r\n  private _updatingForm: boolean | undefined;\r\n  private _id: AssertedCompositeId | undefined;\r\n\r\n  public target: FormControl<PinTarget | null>;\r\n  public scope: FormControl<string | null>;\r\n  public tag: FormControl<string | null>;\r\n  public assertion: FormControl<Assertion | null>;\r\n  public form: FormGroup;\r\n\r\n  public targetExpanded: 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(): AssertedCompositeId | undefined | null {\r\n    return this._id;\r\n  }\r\n  public set id(value: AssertedCompositeId | 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 if the UI has a submit button.\r\n   */\r\n  @Input()\r\n  public hasSubmit: boolean | undefined;\r\n\r\n  /**\r\n   * True when the internal UI preselected mode should be by type rather than\r\n   * by item. User can change mode unless modeSwitching is false.\r\n   */\r\n  @Input()\r\n  public pinByTypeMode?: boolean;\r\n  /**\r\n   * True when the user can switch between by-type and by-item mode in\r\n   * the internal UI.\r\n   */\r\n  @Input()\r\n  public canSwitchMode?: boolean;\r\n  /**\r\n   * True when the user can edit the target's gid/label for internal targets.\r\n   */\r\n  @Input()\r\n  public canEditTarget?: boolean;\r\n  /**\r\n   * The lookup definitions to be used for the by-type lookup in the internal UI.\r\n   * If not specified, the lookup definitions will be got via injection\r\n   * when available; if the injected definitions are empty, the\r\n   * lookup definitions will be built from the model-types thesaurus;\r\n   * if this is not available either, the by-type lookup will be\r\n   * disabled.\r\n   */\r\n  @Input()\r\n  public lookupDefinitions?: IndexLookupDefinitions;\r\n\r\n  /**\r\n   * Emitted whenever the ID changes.\r\n   */\r\n  @Output()\r\n  public idChange: EventEmitter<AssertedCompositeId>;\r\n\r\n  /**\r\n   * Emitted whenever the user requests to close the editor.\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.target = formBuilder.control(null, Validators.required);\r\n    this.scope = formBuilder.control(null, Validators.maxLength(500));\r\n    this.tag = formBuilder.control(null, Validators.maxLength(50));\r\n    this.assertion = formBuilder.control(null);\r\n    this.form = formBuilder.group({\r\n      target: this.target,\r\n      scope: this.scope,\r\n      tag: this.tag,\r\n      assertion: this.assertion,\r\n    });\r\n    this.targetExpanded = false;\r\n    // events\r\n    this.idChange = new EventEmitter<AssertedCompositeId>();\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 onTargetChange(target: PinTarget): void {\r\n    this.target.setValue(target);\r\n    this.target.markAsDirty();\r\n    this.target.updateValueAndValidity();\r\n    this.targetExpanded = false;\r\n  }\r\n\r\n  private updateForm(id: AssertedCompositeId | undefined): void {\r\n    this._updatingForm = true;\r\n    if (!id) {\r\n      this.form.reset();\r\n    } else {\r\n      this.target.setValue(id.target);\r\n      this.scope.setValue(id.scope || null);\r\n      this.tag.setValue(id.tag || null);\r\n      this.assertion.setValue(id.assertion || null);\r\n      this.form.markAsPristine();\r\n    }\r\n    this._updatingForm = false;\r\n  }\r\n\r\n  private getId(): AssertedCompositeId {\r\n    const external = !this.target.value?.name;\r\n    const target = this.target.value;\r\n    return {\r\n      target: external\r\n        ? {\r\n            gid: target?.gid || '',\r\n            label: target?.label || target?.gid || '',\r\n          }\r\n        : target!,\r\n      scope: this.scope.value?.trim() || '',\r\n      tag: this.tag.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\" class=\"short-text\">\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\" class=\"short-text\">\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\" class=\"short-text\">\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\" class=\"short-text\">\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      <!-- label and GID -->\n      <div class=\"info\" *ngIf=\"target.value?.label\">\n        <span class=\"label\">label</span>{{ target.value?.label }}\n      </div>\n      <div class=\"info\" *ngIf=\"target.value?.gid\">\n        <span class=\"label\">GID</span>{{ target.value?.gid }}\n      </div>\n    </div>\n\n    <!-- target -->\n    <div>\n      <mat-expansion-panel [(expanded)]=\"targetExpanded\">\n        <mat-expansion-panel-header>target</mat-expansion-panel-header>\n        <cadmus-pin-target-lookup\n          [pinByTypeMode]=\"pinByTypeMode\"\n          [canSwitchMode]=\"canSwitchMode\"\n          [canEditTarget]=\"canEditTarget\"\n          [lookupDefinitions]=\"lookupDefinitions\"\n          [target]=\"target.value\"\n          (targetChange)=\"onTargetChange($event)\"\n        ></cadmus-pin-target-lookup>\n      </mat-expansion-panel>\n    </div>\n\n    <!-- assertion -->\n    <br />\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\n      mat-icon-button\n      color=\"warn\"\n      type=\"button\"\n      (click)=\"cancel()\"\n      [disabled]=\"!this.target.value?.gid || !this.target.value?.label\"\n    >\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,154 @@
|
|
|
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-composite-id/asserted-composite-id.component";
|
|
11
|
+
/**
|
|
12
|
+
* Asserted IDs editor.
|
|
13
|
+
*/
|
|
14
|
+
class AssertedCompositeIdsComponent {
|
|
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
|
+
target: { gid: '', label: '' },
|
|
53
|
+
}, -1);
|
|
54
|
+
}
|
|
55
|
+
editId(id, index) {
|
|
56
|
+
this._editedIndex = index;
|
|
57
|
+
this.edited = id;
|
|
58
|
+
}
|
|
59
|
+
closeId() {
|
|
60
|
+
this._editedIndex = -1;
|
|
61
|
+
this.edited = undefined;
|
|
62
|
+
}
|
|
63
|
+
saveId(entry) {
|
|
64
|
+
const entries = [...this.entries.value];
|
|
65
|
+
if (this._editedIndex === -1) {
|
|
66
|
+
entries.push(entry);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
entries.splice(this._editedIndex, 1, entry);
|
|
70
|
+
}
|
|
71
|
+
this.entries.setValue(entries);
|
|
72
|
+
this.entries.markAsDirty();
|
|
73
|
+
this.entries.updateValueAndValidity();
|
|
74
|
+
this.closeId();
|
|
75
|
+
}
|
|
76
|
+
deleteId(index) {
|
|
77
|
+
this._dialogService
|
|
78
|
+
.confirm('Confirmation', 'Delete ID?')
|
|
79
|
+
.pipe(take(1))
|
|
80
|
+
.subscribe((yes) => {
|
|
81
|
+
if (yes) {
|
|
82
|
+
if (this._editedIndex === index) {
|
|
83
|
+
this.closeId();
|
|
84
|
+
}
|
|
85
|
+
const entries = [...this.entries.value];
|
|
86
|
+
entries.splice(index, 1);
|
|
87
|
+
this.entries.setValue(entries);
|
|
88
|
+
this.entries.markAsDirty();
|
|
89
|
+
this.entries.updateValueAndValidity();
|
|
90
|
+
this.emitIdsChange();
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
moveIdUp(index) {
|
|
95
|
+
if (index < 1) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
const entry = this.entries.value[index];
|
|
99
|
+
const entries = [...this.entries.value];
|
|
100
|
+
entries.splice(index, 1);
|
|
101
|
+
entries.splice(index - 1, 0, entry);
|
|
102
|
+
this.entries.setValue(entries);
|
|
103
|
+
this.entries.markAsDirty();
|
|
104
|
+
this.entries.updateValueAndValidity();
|
|
105
|
+
this.emitIdsChange();
|
|
106
|
+
}
|
|
107
|
+
moveIdDown(index) {
|
|
108
|
+
if (index + 1 >= this.entries.value.length) {
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
const entry = this.entries.value[index];
|
|
112
|
+
const entries = [...this.entries.value];
|
|
113
|
+
entries.splice(index, 1);
|
|
114
|
+
entries.splice(index + 1, 0, entry);
|
|
115
|
+
this.entries.setValue(entries);
|
|
116
|
+
this.entries.markAsDirty();
|
|
117
|
+
this.entries.updateValueAndValidity();
|
|
118
|
+
this.emitIdsChange();
|
|
119
|
+
}
|
|
120
|
+
onIdChange(id) {
|
|
121
|
+
this.saveId(id);
|
|
122
|
+
this.emitIdsChange();
|
|
123
|
+
}
|
|
124
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AssertedCompositeIdsComponent, deps: [{ token: i1.FormBuilder }, { token: i2.DialogService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
125
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AssertedCompositeIdsComponent, selector: "cadmus-refs-asserted-composite-ids", inputs: { ids: "ids", idScopeEntries: "idScopeEntries", idTagEntries: "idTagEntries", assTagEntries: "assTagEntries", refTypeEntries: "refTypeEntries", refTagEntries: "refTagEntries", pinByTypeMode: "pinByTypeMode", canSwitchMode: "canSwitchMode", canEditTarget: "canEditTarget", lookupDefinitions: "lookupDefinitions" }, outputs: { idsChange: "idsChange" }, ngImport: i0, template: "<form [formGroup]=\"form\">\r\n <!-- buttons -->\r\n <button type=\"button\" color=\"primary\" mat-flat-button (click)=\"addId()\">\r\n <mat-icon>add_circle</mat-icon> ID\r\n </button>\r\n <!-- list -->\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>label</th>\r\n <th>value</th>\r\n <th>ass.</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 class=\"fit-width\">\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?.target?.label }}</td>\r\n <td>{{ entry?.target?.gid }}</td>\r\n <td>{{ entry?.assertion ? \"Y\" : \"N\" }}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <!-- editor -->\r\n <mat-expansion-panel [expanded]=\"edited\" [disabled]=\"!edited\">\r\n <mat-expansion-panel-header\r\n >ID {{ edited?.target?.label }}</mat-expansion-panel-header\r\n >\r\n <cadmus-refs-asserted-composite-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 [pinByTypeMode]=\"pinByTypeMode\"\r\n [canSwitchMode]=\"canSwitchMode\"\r\n [canEditTarget]=\"canEditTarget\"\r\n [lookupDefinitions]=\"lookupDefinitions\"\r\n [id]=\"edited\"\r\n (idChange)=\"onIdChange($event)\"\r\n (editorClose)=\"closeId()\"\r\n ></cadmus-refs-asserted-composite-id>\r\n </mat-expansion-panel>\r\n</form>\r\n", styles: ["th{font-weight:400;color:silver;text-align:left}td{padding-right:4px}td.fit-width{width:1px;white-space:nowrap;padding:0}\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.AssertedCompositeIdComponent, selector: "cadmus-refs-asserted-composite-id", inputs: ["idScopeEntries", "idTagEntries", "assTagEntries", "refTypeEntries", "refTagEntries", "id", "hasSubmit", "pinByTypeMode", "canSwitchMode", "canEditTarget", "lookupDefinitions"], outputs: ["idChange", "editorClose"] }] }); }
|
|
126
|
+
}
|
|
127
|
+
export { AssertedCompositeIdsComponent };
|
|
128
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AssertedCompositeIdsComponent, decorators: [{
|
|
129
|
+
type: Component,
|
|
130
|
+
args: [{ selector: 'cadmus-refs-asserted-composite-ids', template: "<form [formGroup]=\"form\">\r\n <!-- buttons -->\r\n <button type=\"button\" color=\"primary\" mat-flat-button (click)=\"addId()\">\r\n <mat-icon>add_circle</mat-icon> ID\r\n </button>\r\n <!-- list -->\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>label</th>\r\n <th>value</th>\r\n <th>ass.</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 class=\"fit-width\">\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?.target?.label }}</td>\r\n <td>{{ entry?.target?.gid }}</td>\r\n <td>{{ entry?.assertion ? \"Y\" : \"N\" }}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <!-- editor -->\r\n <mat-expansion-panel [expanded]=\"edited\" [disabled]=\"!edited\">\r\n <mat-expansion-panel-header\r\n >ID {{ edited?.target?.label }}</mat-expansion-panel-header\r\n >\r\n <cadmus-refs-asserted-composite-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 [pinByTypeMode]=\"pinByTypeMode\"\r\n [canSwitchMode]=\"canSwitchMode\"\r\n [canEditTarget]=\"canEditTarget\"\r\n [lookupDefinitions]=\"lookupDefinitions\"\r\n [id]=\"edited\"\r\n (idChange)=\"onIdChange($event)\"\r\n (editorClose)=\"closeId()\"\r\n ></cadmus-refs-asserted-composite-id>\r\n </mat-expansion-panel>\r\n</form>\r\n", styles: ["th{font-weight:400;color:silver;text-align:left}td{padding-right:4px}td.fit-width{width:1px;white-space:nowrap;padding:0}\n"] }]
|
|
131
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.DialogService }]; }, propDecorators: { ids: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], idScopeEntries: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], idTagEntries: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], assTagEntries: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], refTypeEntries: [{
|
|
140
|
+
type: Input
|
|
141
|
+
}], refTagEntries: [{
|
|
142
|
+
type: Input
|
|
143
|
+
}], pinByTypeMode: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], canSwitchMode: [{
|
|
146
|
+
type: Input
|
|
147
|
+
}], canEditTarget: [{
|
|
148
|
+
type: Input
|
|
149
|
+
}], lookupDefinitions: [{
|
|
150
|
+
type: Input
|
|
151
|
+
}], idsChange: [{
|
|
152
|
+
type: Output
|
|
153
|
+
}] } });
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asserted-composite-ids.component.js","sourceRoot":"","sources":["../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-composite-ids/asserted-composite-ids.component.ts","../../../../../../projects/myrmidon/cadmus-refs-asserted-ids/src/lib/asserted-composite-ids/asserted-composite-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\nimport { take } from 'rxjs';\r\n\r\nimport { IndexLookupDefinitions, ThesaurusEntry } from '@myrmidon/cadmus-core';\r\nimport { DialogService } from '@myrmidon/ng-mat-tools';\r\n\r\nimport { AssertedCompositeId } from '../asserted-composite-id/asserted-composite-id.component';\r\n\r\n/**\r\n * Asserted IDs editor.\r\n */\r\n@Component({\r\n  selector: 'cadmus-refs-asserted-composite-ids',\r\n  templateUrl: './asserted-composite-ids.component.html',\r\n  styleUrls: ['./asserted-composite-ids.component.css'],\r\n})\r\nexport class AssertedCompositeIdsComponent {\r\n  private _ids: AssertedCompositeId[];\r\n  private _editedIndex: number;\r\n  public edited?: AssertedCompositeId;\r\n\r\n  /**\r\n   * The asserted IDs.\r\n   */\r\n  @Input()\r\n  public get ids(): AssertedCompositeId[] {\r\n    return this._ids;\r\n  }\r\n  public set ids(value: AssertedCompositeId[]) {\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   * True when the internal UI preselected mode should be by type rather than\r\n   * by item. User can change mode unless modeSwitching is false.\r\n   */\r\n  @Input()\r\n  public pinByTypeMode?: boolean;\r\n  /**\r\n   * True when the user can switch between by-type and by-item mode in\r\n   * the internal UI.\r\n   */\r\n  @Input()\r\n  public canSwitchMode?: boolean;\r\n  /**\r\n   * True when the user can edit the target's gid/label for internal targets.\r\n   */\r\n  @Input()\r\n  public canEditTarget?: boolean;\r\n  /**\r\n   * The lookup definitions to be used for the by-type lookup in the internal UI.\r\n   * If not specified, the lookup definitions will be got via injection\r\n   * when available; if the injected definitions are empty, the\r\n   * lookup definitions will be built from the model-types thesaurus;\r\n   * if this is not available either, the by-type lookup will be\r\n   * disabled.\r\n   */\r\n  @Input()\r\n  public lookupDefinitions?: IndexLookupDefinitions;\r\n\r\n  /**\r\n   * Emitted whenever any ID changes.\r\n   */\r\n  @Output()\r\n  public idsChange: EventEmitter<AssertedCompositeId[]>;\r\n\r\n  public entries: FormControl<AssertedCompositeId[]>;\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<AssertedCompositeId[]>();\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: AssertedCompositeId[]): 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        target: { gid: '', label: '' },\r\n      },\r\n      -1\r\n    );\r\n  }\r\n\r\n  public editId(id: AssertedCompositeId, 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: AssertedCompositeId): 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: AssertedCompositeId): void {\r\n    this.saveId(id);\r\n    this.emitIdsChange();\r\n  }\r\n}\r\n","<form [formGroup]=\"form\">\r\n  <!-- buttons -->\r\n  <button type=\"button\" color=\"primary\" mat-flat-button (click)=\"addId()\">\r\n    <mat-icon>add_circle</mat-icon> ID\r\n  </button>\r\n  <!-- list -->\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>label</th>\r\n        <th>value</th>\r\n        <th>ass.</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 class=\"fit-width\">\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?.target?.label }}</td>\r\n        <td>{{ entry?.target?.gid }}</td>\r\n        <td>{{ entry?.assertion ? \"Y\" : \"N\" }}</td>\r\n      </tr>\r\n    </tbody>\r\n  </table>\r\n\r\n  <!-- editor -->\r\n  <mat-expansion-panel [expanded]=\"edited\" [disabled]=\"!edited\">\r\n    <mat-expansion-panel-header\r\n      >ID {{ edited?.target?.label }}</mat-expansion-panel-header\r\n    >\r\n    <cadmus-refs-asserted-composite-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      [pinByTypeMode]=\"pinByTypeMode\"\r\n      [canSwitchMode]=\"canSwitchMode\"\r\n      [canEditTarget]=\"canEditTarget\"\r\n      [lookupDefinitions]=\"lookupDefinitions\"\r\n      [id]=\"edited\"\r\n      (idChange)=\"onIdChange($event)\"\r\n      (editorClose)=\"closeId()\"\r\n    ></cadmus-refs-asserted-composite-id>\r\n  </mat-expansion-panel>\r\n</form>\r\n"]}
|