@luomus/laji-form 15.0.0 → 15.1.1
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/CHANGELOG.md +0 -4
- package/dist/laji-form.js +1 -1
- package/dist/styles.css +81 -90
- package/jsonconfig.json +26 -0
- package/migrate.sh +0 -1
- package/package.json +8 -8
- package/test-export/array-spec.js +204 -0
- package/test-export/bird-point-count-spec.d.ts +1 -0
- package/test-export/bird-point-count-spec.js +62 -0
- package/test-export/collection-contest-form-spec.d.ts +1 -0
- package/test-export/collection-contest-form-spec.js +38 -0
- package/test-export/dataset-form-spec.d.ts +1 -0
- package/test-export/dataset-form-spec.js +50 -0
- package/test-export/date-time-widget-spec.d.ts +1 -0
- package/test-export/date-time-widget-spec.js +188 -0
- package/test-export/geocoder-spec.d.ts +1 -0
- package/test-export/geocoder-spec.js +135 -0
- package/test-export/image-array-spec.d.ts +1 -0
- package/test-export/image-array-spec.js +94 -0
- package/test-export/inject-field-spec.d.ts +1 -0
- package/test-export/inject-field-spec.js +148 -0
- package/test-export/internal-uuids-spec.d.ts +1 -0
- package/test-export/internal-uuids-spec.js +157 -0
- package/test-export/invasive-species-eradication-np-spec.d.ts +1 -0
- package/test-export/invasive-species-eradication-np-spec.js +18 -0
- package/test-export/invasive-species-eradication-spec.d.ts +1 -0
- package/test-export/invasive-species-eradication-spec.js +25 -0
- package/test-export/line-transect-spec.d.ts +1 -0
- package/test-export/line-transect-spec.js +121 -0
- package/test-export/mobile-form-spec.d.ts +1 -0
- package/test-export/mobile-form-spec.js +84 -0
- package/test-export/nafi-spec.d.ts +1 -0
- package/test-export/nafi-spec.js +85 -0
- package/test-export/select-widget-spec.d.ts +1 -0
- package/test-export/select-widget-spec.js +68 -0
- package/test-export/single-item-array-field-spec.d.ts +1 -0
- package/test-export/single-item-array-field-spec.js +92 -0
- package/test-export/syke-butterfly-spec.d.ts +1 -0
- package/test-export/syke-butterfly-spec.js +163 -0
- package/test-export/test-utils.d.ts +150 -176
- package/test-export/test-utils.js +218 -210
- package/test-export/transaction-form-spec.d.ts +1 -0
- package/test-export/transaction-form-spec.js +63 -0
- package/test-export/trip-report-autosuggest-spec.d.ts +1 -0
- package/test-export/trip-report-autosuggest-spec.js +272 -0
- package/test-export/trip-report-spec.d.ts +1 -0
- package/test-export/trip-report-spec.js +456 -0
- package/test-export/unit-list-shorthand-array-field-spec.d.ts +1 -0
- package/test-export/unit-list-shorthand-array-field-spec.js +71 -0
- package/test-export/validation-spec.d.ts +1 -0
- package/test-export/validation-spec.js +336 -0
- package/test-export/water-bird-spec.d.ts +1 -0
- package/test-export/water-bird-spec.js +30 -0
- package/test-export/wbc-spec.d.ts +1 -0
- package/test-export/wbc-spec.js +82 -0
- package/tsconfig.test.json +1 -1
- package/xsel -b +9 -0
- package/cypress/fixtures/example.json +0 -5
- package/cypress/screenshots/nafi.cy.ts/NAFI (MHL.6) -- selecting species name with keyboard navigation -- and closes suggestion list (failed).png +0 -0
- package/cypress/screenshots/nafi.cy.ts/NAFI (MHL.6) -- selecting species name with keyboard navigation -- and is marked as suggested (failed).png +0 -0
- package/lib/ApiClient.d.ts +0 -46
- package/lib/ApiClient.js +0 -93
- package/lib/Context.d.ts +0 -8
- package/lib/Context.js +0 -18
- package/lib/ReactContext.d.ts +0 -7
- package/lib/ReactContext.js +0 -5
- package/lib/components/BaseComponent.d.ts +0 -9
- package/lib/components/BaseComponent.js +0 -29
- package/lib/components/LajiForm.d.ts +0 -221
- package/lib/components/LajiForm.js +0 -615
- package/lib/components/VirtualSchemaField.d.ts +0 -42
- package/lib/components/VirtualSchemaField.js +0 -74
- package/lib/components/components.d.ts +0 -119
- package/lib/components/components.js +0 -606
- package/lib/components/fields/AnnotationField.d.ts +0 -34
- package/lib/components/fields/AnnotationField.js +0 -242
- package/lib/components/fields/AnyToBooleanField.d.ts +0 -18
- package/lib/components/fields/AnyToBooleanField.js +0 -20
- package/lib/components/fields/ArrayBulkField.d.ts +0 -23
- package/lib/components/fields/ArrayBulkField.js +0 -82
- package/lib/components/fields/ArrayCombinerField.d.ts +0 -36
- package/lib/components/fields/ArrayCombinerField.js +0 -138
- package/lib/components/fields/ArrayField.d.ts +0 -39
- package/lib/components/fields/ArrayField.js +0 -148
- package/lib/components/fields/AudioArrayField.d.ts +0 -22
- package/lib/components/fields/AudioArrayField.js +0 -100
- package/lib/components/fields/AutoArrayField.d.ts +0 -24
- package/lib/components/fields/AutoArrayField.js +0 -56
- package/lib/components/fields/AutosuggestField.d.ts +0 -69
- package/lib/components/fields/AutosuggestField.js +0 -299
- package/lib/components/fields/CombinedValueDisplayField.d.ts +0 -41
- package/lib/components/fields/CombinedValueDisplayField.js +0 -100
- package/lib/components/fields/ConditionalOnChangeField.d.ts +0 -42
- package/lib/components/fields/ConditionalOnChangeField.js +0 -107
- package/lib/components/fields/ConditionalUiSchemaField.d.ts +0 -123
- package/lib/components/fields/ConditionalUiSchemaField.js +0 -143
- package/lib/components/fields/ContextInjectionField.d.ts +0 -24
- package/lib/components/fields/ContextInjectionField.js +0 -68
- package/lib/components/fields/DataLeakerField.d.ts +0 -40
- package/lib/components/fields/DataLeakerField.js +0 -68
- package/lib/components/fields/DefaultValueArrayField.d.ts +0 -34
- package/lib/components/fields/DefaultValueArrayField.js +0 -59
- package/lib/components/fields/DependentBooleanField.d.ts +0 -38
- package/lib/components/fields/DependentBooleanField.js +0 -87
- package/lib/components/fields/DependentDisableField.d.ts +0 -35
- package/lib/components/fields/DependentDisableField.js +0 -71
- package/lib/components/fields/EnumRangeArrayField.d.ts +0 -27
- package/lib/components/fields/EnumRangeArrayField.js +0 -115
- package/lib/components/fields/ExtraLabelRowField.d.ts +0 -38
- package/lib/components/fields/ExtraLabelRowField.js +0 -100
- package/lib/components/fields/FakePropertyField.d.ts +0 -18
- package/lib/components/fields/FakePropertyField.js +0 -48
- package/lib/components/fields/FilterArrayField.d.ts +0 -73
- package/lib/components/fields/FilterArrayField.js +0 -121
- package/lib/components/fields/FlatField.d.ts +0 -29
- package/lib/components/fields/FlatField.js +0 -171
- package/lib/components/fields/GeocoderField.d.ts +0 -47
- package/lib/components/fields/GeocoderField.js +0 -372
- package/lib/components/fields/GridLayoutField.d.ts +0 -18
- package/lib/components/fields/GridLayoutField.js +0 -32
- package/lib/components/fields/HiddenField.d.ts +0 -10
- package/lib/components/fields/HiddenField.js +0 -11
- package/lib/components/fields/ImageArrayField.d.ts +0 -172
- package/lib/components/fields/ImageArrayField.js +0 -697
- package/lib/components/fields/ImageDisplayField.d.ts +0 -18
- package/lib/components/fields/ImageDisplayField.js +0 -44
- package/lib/components/fields/InitiallyHiddenField.d.ts +0 -21
- package/lib/components/fields/InitiallyHiddenField.js +0 -58
- package/lib/components/fields/InjectDefaultValueField.d.ts +0 -37
- package/lib/components/fields/InjectDefaultValueField.js +0 -68
- package/lib/components/fields/InjectField.d.ts +0 -46
- package/lib/components/fields/InjectField.js +0 -88
- package/lib/components/fields/InputWithDefaultValueButtonField.d.ts +0 -25
- package/lib/components/fields/InputWithDefaultValueButtonField.js +0 -61
- package/lib/components/fields/LocalityField.d.ts +0 -22
- package/lib/components/fields/LocalityField.js +0 -94
- package/lib/components/fields/LocationChooserField.d.ts +0 -27
- package/lib/components/fields/LocationChooserField.js +0 -440
- package/lib/components/fields/MapArrayField.d.ts +0 -78
- package/lib/components/fields/MapArrayField.js +0 -1783
- package/lib/components/fields/MapField.d.ts +0 -48
- package/lib/components/fields/MapField.js +0 -434
- package/lib/components/fields/MultiAnyToBooleanField.d.ts +0 -25
- package/lib/components/fields/MultiAnyToBooleanField.js +0 -100
- package/lib/components/fields/MultiArrayField.d.ts +0 -53
- package/lib/components/fields/MultiArrayField.js +0 -224
- package/lib/components/fields/MultiLanguageField.d.ts +0 -13
- package/lib/components/fields/MultiLanguageField.js +0 -52
- package/lib/components/fields/MultiTagArrayField.d.ts +0 -36
- package/lib/components/fields/MultiTagArrayField.js +0 -142
- package/lib/components/fields/NamedPlaceChooserField.d.ts +0 -29
- package/lib/components/fields/NamedPlaceChooserField.js +0 -380
- package/lib/components/fields/NamedPlaceSaverField.d.ts +0 -29
- package/lib/components/fields/NamedPlaceSaverField.js +0 -237
- package/lib/components/fields/NestField.d.ts +0 -148
- package/lib/components/fields/NestField.js +0 -289
- package/lib/components/fields/ObjectField.d.ts +0 -2
- package/lib/components/fields/ObjectField.js +0 -119
- package/lib/components/fields/PdfArrayField.d.ts +0 -21
- package/lib/components/fields/PdfArrayField.js +0 -40
- package/lib/components/fields/PrefillingArrayField.d.ts +0 -22
- package/lib/components/fields/PrefillingArrayField.js +0 -65
- package/lib/components/fields/SchemaField.d.ts +0 -7
- package/lib/components/fields/SchemaField.js +0 -109
- package/lib/components/fields/ScopeField.d.ts +0 -85
- package/lib/components/fields/ScopeField.js +0 -521
- package/lib/components/fields/SectionArrayField.d.ts +0 -38
- package/lib/components/fields/SectionArrayField.js +0 -618
- package/lib/components/fields/SelectTreeField.d.ts +0 -39
- package/lib/components/fields/SelectTreeField.js +0 -143
- package/lib/components/fields/SingleActiveArrayField.d.ts +0 -49
- package/lib/components/fields/SingleActiveArrayField.js +0 -974
- package/lib/components/fields/SingleItemArrayField.d.ts +0 -15
- package/lib/components/fields/SingleItemArrayField.js +0 -60
- package/lib/components/fields/SortArrayField.d.ts +0 -73
- package/lib/components/fields/SortArrayField.js +0 -351
- package/lib/components/fields/SplitField.d.ts +0 -28
- package/lib/components/fields/SplitField.js +0 -65
- package/lib/components/fields/StringToArrayField.d.ts +0 -24
- package/lib/components/fields/StringToArrayField.js +0 -48
- package/lib/components/fields/SumField.d.ts +0 -35
- package/lib/components/fields/SumField.js +0 -83
- package/lib/components/fields/TableField.d.ts +0 -18
- package/lib/components/fields/TableField.js +0 -136
- package/lib/components/fields/TagArrayField.d.ts +0 -38
- package/lib/components/fields/TagArrayField.js +0 -128
- package/lib/components/fields/ToggleAdditionalArrayFieldsField.d.ts +0 -26
- package/lib/components/fields/ToggleAdditionalArrayFieldsField.js +0 -81
- package/lib/components/fields/UiFieldApplierField.d.ts +0 -30
- package/lib/components/fields/UiFieldApplierField.js +0 -106
- package/lib/components/fields/UiFieldMapperArrayField.d.ts +0 -42
- package/lib/components/fields/UiFieldMapperArrayField.js +0 -121
- package/lib/components/fields/UnitCountShorthandField.d.ts +0 -22
- package/lib/components/fields/UnitCountShorthandField.js +0 -149
- package/lib/components/fields/UnitListShorthandArrayField.d.ts +0 -26
- package/lib/components/fields/UnitListShorthandArrayField.js +0 -108
- package/lib/components/fields/UnitShorthandField.d.ts +0 -32
- package/lib/components/fields/UnitShorthandField.js +0 -220
- package/lib/components/templates/ArrayFieldTemplate.d.ts +0 -85
- package/lib/components/templates/ArrayFieldTemplate.js +0 -417
- package/lib/components/templates/BaseInputTemplate.d.ts +0 -11
- package/lib/components/templates/BaseInputTemplate.js +0 -80
- package/lib/components/templates/DescriptionField.d.ts +0 -1
- package/lib/components/templates/DescriptionField.js +0 -37
- package/lib/components/templates/ErrorListTemplate.d.ts +0 -9
- package/lib/components/templates/ErrorListTemplate.js +0 -95
- package/lib/components/templates/FieldTemplate.d.ts +0 -6
- package/lib/components/templates/FieldTemplate.js +0 -112
- package/lib/components/templates/ObjectFieldTemplate.d.ts +0 -7
- package/lib/components/templates/ObjectFieldTemplate.js +0 -66
- package/lib/components/templates/TitleField.d.ts +0 -9
- package/lib/components/templates/TitleField.js +0 -51
- package/lib/components/widgets/AnyToBooleanWidget.d.ts +0 -20
- package/lib/components/widgets/AnyToBooleanWidget.js +0 -49
- package/lib/components/widgets/AutosuggestWidget.d.ts +0 -66
- package/lib/components/widgets/AutosuggestWidget.js +0 -1127
- package/lib/components/widgets/CheckboxWidget.d.ts +0 -37
- package/lib/components/widgets/CheckboxWidget.js +0 -139
- package/lib/components/widgets/DateTimeWidget.d.ts +0 -62
- package/lib/components/widgets/DateTimeWidget.js +0 -251
- package/lib/components/widgets/DateWidget.d.ts +0 -23
- package/lib/components/widgets/DateWidget.js +0 -41
- package/lib/components/widgets/HiddenWidget.d.ts +0 -15
- package/lib/components/widgets/HiddenWidget.js +0 -19
- package/lib/components/widgets/ImageSelectWidget.d.ts +0 -14
- package/lib/components/widgets/ImageSelectWidget.js +0 -57
- package/lib/components/widgets/InformalTaxonGroupChooserWidget.d.ts +0 -43
- package/lib/components/widgets/InformalTaxonGroupChooserWidget.js +0 -237
- package/lib/components/widgets/InputGroupWidget.d.ts +0 -21
- package/lib/components/widgets/InputGroupWidget.js +0 -36
- package/lib/components/widgets/InputWithDefaultValueButtonWidget.d.ts +0 -21
- package/lib/components/widgets/InputWithDefaultValueButtonWidget.js +0 -47
- package/lib/components/widgets/NumberWidget.d.ts +0 -13
- package/lib/components/widgets/NumberWidget.js +0 -21
- package/lib/components/widgets/PlainTextWidget.d.ts +0 -12
- package/lib/components/widgets/PlainTextWidget.js +0 -24
- package/lib/components/widgets/SelectWidget.d.ts +0 -52
- package/lib/components/widgets/SelectWidget.js +0 -158
- package/lib/components/widgets/SeparatedDateTimeWidget.d.ts +0 -19
- package/lib/components/widgets/SeparatedDateTimeWidget.js +0 -59
- package/lib/components/widgets/TaxonImageWidget.d.ts +0 -13
- package/lib/components/widgets/TaxonImageWidget.js +0 -30
- package/lib/components/widgets/TextSelectWidget.d.ts +0 -25
- package/lib/components/widgets/TextSelectWidget.js +0 -94
- package/lib/components/widgets/TextareaWidget.d.ts +0 -32
- package/lib/components/widgets/TextareaWidget.js +0 -87
- package/lib/components/widgets/TimeWidget.d.ts +0 -11
- package/lib/components/widgets/TimeWidget.js +0 -19
- package/lib/components/widgets/URLWidget.d.ts +0 -14
- package/lib/components/widgets/URLWidget.js +0 -12
- package/lib/components/widgets/UpperCaseWidget.d.ts +0 -13
- package/lib/components/widgets/UpperCaseWidget.js +0 -21
- package/lib/index.d.ts +0 -20
- package/lib/index.js +0 -50
- package/lib/services/blocker-service.d.ts +0 -11
- package/lib/services/blocker-service.js +0 -55
- package/lib/services/custom-event-service.d.ts +0 -17
- package/lib/services/custom-event-service.js +0 -35
- package/lib/services/dom-id-service.d.ts +0 -8
- package/lib/services/dom-id-service.js +0 -30
- package/lib/services/focus-service.d.ts +0 -13
- package/lib/services/focus-service.js +0 -60
- package/lib/services/id-service.d.ts +0 -22
- package/lib/services/id-service.js +0 -130
- package/lib/services/key-handler-service.d.ts +0 -56
- package/lib/services/key-handler-service.js +0 -184
- package/lib/services/root-instance-service.d.ts +0 -25
- package/lib/services/root-instance-service.js +0 -49
- package/lib/services/settings-service.d.ts +0 -34
- package/lib/services/settings-service.js +0 -154
- package/lib/services/singleton-map-service.d.ts +0 -23
- package/lib/services/singleton-map-service.js +0 -44
- package/lib/services/submit-hook-service.d.ts +0 -24
- package/lib/services/submit-hook-service.js +0 -73
- package/lib/styles.js +0 -4
- package/lib/themes/bs3.d.ts +0 -3
- package/lib/themes/bs3.js +0 -133
- package/lib/themes/bs5.d.ts +0 -3
- package/lib/themes/bs5.js +0 -111
- package/lib/themes/glyphicon-fa-mapping.d.ts +0 -3
- package/lib/themes/glyphicon-fa-mapping.js +0 -271
- package/lib/themes/stub.d.ts +0 -3
- package/lib/themes/stub.js +0 -82
- package/lib/themes/theme.d.ts +0 -233
- package/lib/themes/theme.js +0 -2
- package/lib/translations.json +0 -847
- package/lib/utils.d.ts +0 -171
- package/lib/utils.js +0 -1191
- package/lib/validation.d.ts +0 -7
- package/lib/validation.js +0 -141
- package/llol +0 -10
- package/llol.pdf +0 -10
- package/playwright-report/index.html +0 -62
- package/q +0 -196
- package/rename.sh +0 -24
- package/trip-report.spec.ts +0 -594
- /package/{lib/styles.d.ts → test-export/array-spec.d.ts} +0 -0
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
const test_utils_1 = require("./test-utils");
|
|
13
|
+
const protractor_1 = require("protractor");
|
|
14
|
+
describe("SingleItemArrayField", () => {
|
|
15
|
+
const uiSchema = {
|
|
16
|
+
"ui:field": "SingleItemArrayField",
|
|
17
|
+
};
|
|
18
|
+
let form;
|
|
19
|
+
beforeAll(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
20
|
+
form = yield test_utils_1.createForm();
|
|
21
|
+
}));
|
|
22
|
+
describe("object", () => {
|
|
23
|
+
const schema = {
|
|
24
|
+
type: "array",
|
|
25
|
+
items: {
|
|
26
|
+
type: "object",
|
|
27
|
+
properties: {
|
|
28
|
+
a: { type: "string" }
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
const formData = [{ a: "foo" }, { a: "bar" }];
|
|
33
|
+
beforeAll(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
34
|
+
yield form.setState({ schema, uiSchema, formData });
|
|
35
|
+
}));
|
|
36
|
+
it("uses first item by default and keeps idSchema intact", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
37
|
+
expect(yield form.$getInputWidget("0.a").isDisplayed()).toBe(true);
|
|
38
|
+
}));
|
|
39
|
+
describe("respects activeIdx and", () => {
|
|
40
|
+
beforeAll(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
41
|
+
yield form.setState({ uiSchema: Object.assign(Object.assign({}, uiSchema), { "ui:options": { activeIdx: 1 } }) });
|
|
42
|
+
}));
|
|
43
|
+
it("renders only single item", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
44
|
+
expect(yield form.$locate("1.a").isDisplayed()).toBe(true);
|
|
45
|
+
expect(yield form.$locate("0.a").isPresent()).toBe(false);
|
|
46
|
+
}));
|
|
47
|
+
it("renders form data", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
48
|
+
expect(yield form.$getInputWidget("1.a").getAttribute("value")).toBe(formData[1].a);
|
|
49
|
+
}));
|
|
50
|
+
it("onChange", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
51
|
+
yield test_utils_1.updateValue(form.$getInputWidget("1.a"), "test");
|
|
52
|
+
expect(yield form.$getInputWidget("1.a").getAttribute("value")).toBe("test");
|
|
53
|
+
}));
|
|
54
|
+
it("renders item errors", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
55
|
+
yield form.setState({
|
|
56
|
+
formData: [{ a: "a" }, { a: 1 }]
|
|
57
|
+
});
|
|
58
|
+
yield form.submit();
|
|
59
|
+
expect(yield form.$$getFieldErrors("1.a").count()).toBe(1);
|
|
60
|
+
}));
|
|
61
|
+
it("renders array errors", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
62
|
+
yield form.setState({
|
|
63
|
+
schema: Object.assign(Object.assign({}, schema), { minItems: 1 }),
|
|
64
|
+
formData: []
|
|
65
|
+
});
|
|
66
|
+
yield form.submit();
|
|
67
|
+
expect(yield form.$$getFieldErrors("").count()).toBe(1);
|
|
68
|
+
}));
|
|
69
|
+
});
|
|
70
|
+
it("formats title", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
71
|
+
yield form.setState({ uiSchema: Object.assign(Object.assign({}, uiSchema), { "ui:title": "test %{idx} test" }) });
|
|
72
|
+
expect(yield protractor_1.element(protractor_1.by.cssContainingText("span", "test 1 test")).isDisplayed()).toBe(true);
|
|
73
|
+
}));
|
|
74
|
+
it("respects titleClassName option", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
75
|
+
yield form.setState({ uiSchema: Object.assign(Object.assign({}, uiSchema), { "ui:title": "test", "ui:options": { titleClassName: "title-format-test" } }) });
|
|
76
|
+
expect(yield protractor_1.$(".title-format-test").isDisplayed()).toBe(true);
|
|
77
|
+
}));
|
|
78
|
+
});
|
|
79
|
+
describe("string array with unique items", () => {
|
|
80
|
+
const schema = { type: "array", uniqueItems: true, title: "test", items: { type: "string", enum: ["a"], enumNames: ["a"] } };
|
|
81
|
+
beforeAll(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
82
|
+
yield form.setState({ schema, uiSchema });
|
|
83
|
+
}));
|
|
84
|
+
it("is rendered as select", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
85
|
+
expect(yield form.$getEnumWidget("").$container.isDisplayed()).toBe(true);
|
|
86
|
+
}));
|
|
87
|
+
it("renders title as label", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
88
|
+
expect(yield protractor_1.$("label").isDisplayed()).toBe(true);
|
|
89
|
+
expect(yield protractor_1.$("legend").isPresent()).toBe(false);
|
|
90
|
+
}));
|
|
91
|
+
});
|
|
92
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
const test_utils_1 = require("./test-utils");
|
|
13
|
+
const protractor_1 = require("protractor");
|
|
14
|
+
describe("SYKE butterfly form (MHL.59)", () => {
|
|
15
|
+
let form;
|
|
16
|
+
let $firstUnitsAdd;
|
|
17
|
+
let $secondUnitsAdd;
|
|
18
|
+
let $gatheringsAdd;
|
|
19
|
+
it("navigate to form", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
20
|
+
const formData = {
|
|
21
|
+
"gatherings": [
|
|
22
|
+
{
|
|
23
|
+
"section": 1,
|
|
24
|
+
"units": []
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
"units": []
|
|
28
|
+
}
|
|
29
|
+
]
|
|
30
|
+
};
|
|
31
|
+
form = yield test_utils_1.createForm({ id: "MHL.59", formData });
|
|
32
|
+
const $$addButtons = yield form.$locate("gatherings.0.units").$$("button");
|
|
33
|
+
$firstUnitsAdd = $$addButtons[0];
|
|
34
|
+
$secondUnitsAdd = $$addButtons[1];
|
|
35
|
+
$gatheringsAdd = form.$locateButton("gatherings", "add");
|
|
36
|
+
//$lastGatheringsUnitsAdd = form.$locateButton("gatherings.1.units", "add");
|
|
37
|
+
}));
|
|
38
|
+
it("has gatherings", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
39
|
+
expect(yield form.$locate("gatherings").isDisplayed()).toBe(true);
|
|
40
|
+
}));
|
|
41
|
+
it("has one gathering by default", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
42
|
+
expect(yield form.$locate("gatherings.0").isDisplayed()).toBe(true);
|
|
43
|
+
}));
|
|
44
|
+
it("has gatherings add", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
45
|
+
expect(yield $gatheringsAdd.isDisplayed()).toBe(true);
|
|
46
|
+
}));
|
|
47
|
+
it("has first unit add", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
48
|
+
expect(yield $firstUnitsAdd.isDisplayed()).toBe(true);
|
|
49
|
+
}));
|
|
50
|
+
it("has second unit add", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
51
|
+
expect(yield $secondUnitsAdd.isDisplayed()).toBe(true);
|
|
52
|
+
}));
|
|
53
|
+
describe("adding unit to first group", () => {
|
|
54
|
+
it("works", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
55
|
+
yield $firstUnitsAdd.click();
|
|
56
|
+
expect(yield form.$locate("gatherings.0.units.0.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
57
|
+
expect(yield form.$locate("gatherings.0.units.0.individualCount").isDisplayed()).toBe(true);
|
|
58
|
+
}));
|
|
59
|
+
it("autofocuses", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
60
|
+
expect(yield test_utils_1.getFocusedId()).toBe(yield form.$getInputWidget("gatherings.0.units.0.identifications.0.taxonVerbatim").getAttribute("id"));
|
|
61
|
+
}));
|
|
62
|
+
});
|
|
63
|
+
describe("adding unit to second group", () => {
|
|
64
|
+
it("works", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
65
|
+
yield $secondUnitsAdd.click();
|
|
66
|
+
expect(yield form.$locate("gatherings.0.units.0.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
67
|
+
expect(yield form.$locate("gatherings.0.units.1.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
68
|
+
expect(yield form.$locate("gatherings.0.units.0.individualCount").isDisplayed()).toBe(true);
|
|
69
|
+
expect(yield form.$locate("gatherings.0.units.1.individualCount").isDisplayed()).toBe(true);
|
|
70
|
+
}));
|
|
71
|
+
it("autofocuses", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
72
|
+
expect(yield test_utils_1.getFocusedId()).toBe(yield form.$getInputWidget("gatherings.0.units.1.identifications.0.taxonVerbatim").getAttribute("id"));
|
|
73
|
+
}));
|
|
74
|
+
});
|
|
75
|
+
describe("adding new section", () => {
|
|
76
|
+
it("works", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
77
|
+
yield $gatheringsAdd.click();
|
|
78
|
+
yield form.$locateAddition("gatherings", "section-input").sendKeys("2");
|
|
79
|
+
yield form.$locateAddition("gatherings", "section-input").sendKeys(protractor_1.protractor.Key.ENTER);
|
|
80
|
+
expect(yield form.$locate("gatherings.0.units.1.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
81
|
+
expect(yield form.$locate("gatherings.0.units.0.individualCount").isDisplayed()).toBe(true);
|
|
82
|
+
expect(yield form.$locate("gatherings.0.units.1.individualCount").isDisplayed()).toBe(true);
|
|
83
|
+
expect(yield form.$locate("gatherings.1.units.0.individualCount").isDisplayed()).toBe(true);
|
|
84
|
+
expect(yield form.$locate("gatherings.1.units.1.individualCount").isDisplayed()).toBe(true);
|
|
85
|
+
}));
|
|
86
|
+
// Works really but test suite fails
|
|
87
|
+
//it("autofocuses", async () => {
|
|
88
|
+
// expect(await getFocusedId() === await form.$getInputWidget("gatherings.1.gatheringFact.sykeButterFlyCensusWind").getAttribute("id")).toBe(true);
|
|
89
|
+
//});
|
|
90
|
+
});
|
|
91
|
+
describe("adding unit to first group again", () => {
|
|
92
|
+
it("works", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
93
|
+
yield $firstUnitsAdd.click();
|
|
94
|
+
expect(yield form.$locate("gatherings.0.units.0.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
95
|
+
expect(yield form.$locate("gatherings.0.units.1.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
96
|
+
expect(yield form.$locate("gatherings.0.units.2.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
97
|
+
expect(yield form.$locate("gatherings.0.units.0.individualCount").isDisplayed()).toBe(true);
|
|
98
|
+
expect(yield form.$locate("gatherings.0.units.1.individualCount").isDisplayed()).toBe(true);
|
|
99
|
+
expect(yield form.$locate("gatherings.0.units.2.individualCount").isDisplayed()).toBe(true);
|
|
100
|
+
expect(yield form.$locate("gatherings.1.units.0.individualCount").isDisplayed()).toBe(true);
|
|
101
|
+
expect(yield form.$locate("gatherings.1.units.1.individualCount").isDisplayed()).toBe(true);
|
|
102
|
+
expect(yield form.$locate("gatherings.1.units.2.individualCount").isDisplayed()).toBe(true);
|
|
103
|
+
}));
|
|
104
|
+
it("autofocuses", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
105
|
+
expect(yield test_utils_1.getFocusedId()).toBe(yield form.$getInputWidget("gatherings.0.units.1.identifications.0.taxonVerbatim").getAttribute("id"));
|
|
106
|
+
}));
|
|
107
|
+
});
|
|
108
|
+
describe("adding unit to second group again", () => {
|
|
109
|
+
it("works", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
110
|
+
yield $secondUnitsAdd.click();
|
|
111
|
+
expect(yield form.$locate("gatherings.0.units.0.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
112
|
+
expect(yield form.$locate("gatherings.0.units.1.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
113
|
+
expect(yield form.$locate("gatherings.0.units.2.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
114
|
+
expect(yield form.$locate("gatherings.0.units.3.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
115
|
+
expect(yield form.$locate("gatherings.0.units.0.individualCount").isDisplayed()).toBe(true);
|
|
116
|
+
expect(yield form.$locate("gatherings.0.units.1.individualCount").isDisplayed()).toBe(true);
|
|
117
|
+
expect(yield form.$locate("gatherings.0.units.2.individualCount").isDisplayed()).toBe(true);
|
|
118
|
+
expect(yield form.$locate("gatherings.0.units.3.individualCount").isDisplayed()).toBe(true);
|
|
119
|
+
expect(yield form.$locate("gatherings.1.units.0.individualCount").isDisplayed()).toBe(true);
|
|
120
|
+
expect(yield form.$locate("gatherings.1.units.1.individualCount").isDisplayed()).toBe(true);
|
|
121
|
+
expect(yield form.$locate("gatherings.1.units.2.individualCount").isDisplayed()).toBe(true);
|
|
122
|
+
expect(yield form.$locate("gatherings.1.units.3.individualCount").isDisplayed()).toBe(true);
|
|
123
|
+
}));
|
|
124
|
+
it("autofocuses", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
125
|
+
expect(yield test_utils_1.getFocusedId()).toBe(yield form.$getInputWidget("gatherings.0.units.3.identifications.0.taxonVerbatim").getAttribute("id"));
|
|
126
|
+
}));
|
|
127
|
+
});
|
|
128
|
+
describe("adding new section again", () => {
|
|
129
|
+
it("works", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
130
|
+
yield $gatheringsAdd.click();
|
|
131
|
+
yield form.$locateAddition("gatherings", "section-input").sendKeys("3");
|
|
132
|
+
yield form.$locateAddition("gatherings", "section-input").sendKeys(protractor_1.protractor.Key.ENTER);
|
|
133
|
+
expect(yield form.$locate("gatherings.0.units.0.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
134
|
+
expect(yield form.$locate("gatherings.0.units.1.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
135
|
+
expect(yield form.$locate("gatherings.0.units.2.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
136
|
+
expect(yield form.$locate("gatherings.0.units.3.identifications.0.taxonVerbatim").isDisplayed()).toBe(true);
|
|
137
|
+
expect(yield form.$locate("gatherings.0.units.0.individualCount").isDisplayed()).toBe(true);
|
|
138
|
+
expect(yield form.$locate("gatherings.0.units.1.individualCount").isDisplayed()).toBe(true);
|
|
139
|
+
expect(yield form.$locate("gatherings.0.units.2.individualCount").isDisplayed()).toBe(true);
|
|
140
|
+
expect(yield form.$locate("gatherings.0.units.3.individualCount").isDisplayed()).toBe(true);
|
|
141
|
+
expect(yield form.$locate("gatherings.1.units.0.individualCount").isDisplayed()).toBe(true);
|
|
142
|
+
expect(yield form.$locate("gatherings.1.units.1.individualCount").isDisplayed()).toBe(true);
|
|
143
|
+
expect(yield form.$locate("gatherings.1.units.2.individualCount").isDisplayed()).toBe(true);
|
|
144
|
+
expect(yield form.$locate("gatherings.1.units.3.individualCount").isDisplayed()).toBe(true);
|
|
145
|
+
expect(yield form.$locate("gatherings.2.units.0.individualCount").isDisplayed()).toBe(true);
|
|
146
|
+
expect(yield form.$locate("gatherings.2.units.1.individualCount").isDisplayed()).toBe(true);
|
|
147
|
+
expect(yield form.$locate("gatherings.2.units.2.individualCount").isDisplayed()).toBe(true);
|
|
148
|
+
expect(yield form.$locate("gatherings.2.units.3.individualCount").isDisplayed()).toBe(true);
|
|
149
|
+
}));
|
|
150
|
+
// Works really but test suite fails
|
|
151
|
+
//it("autofocuses", async () => {
|
|
152
|
+
// expect(await getFocusedId() === await form.$getInputWidget("gatherings.2.gatheringFact.sykeButterFlyCensusWind").getAttribute("id")).toBe(true);
|
|
153
|
+
//});
|
|
154
|
+
});
|
|
155
|
+
it("removing new section works", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
156
|
+
const gatheringsLength = (yield form.getChangedData()).gatherings.length;
|
|
157
|
+
yield form.$locateButton("gatherings.0", "delete").click();
|
|
158
|
+
const formData = yield form.getChangedData();
|
|
159
|
+
expect(formData.gatherings.length).not.toBe(gatheringsLength);
|
|
160
|
+
expect(formData.gatherings[0].section).toBe(2);
|
|
161
|
+
expect(formData.gatherings[formData.gatherings.length - 1].section).toBe(undefined);
|
|
162
|
+
}));
|
|
163
|
+
});
|
|
@@ -1,32 +1,53 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ElementFinder, ElementArrayFinder } from "protractor";
|
|
2
2
|
import { JSONSchema7 } from "json-schema";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export declare const
|
|
7
|
-
export declare const navigateToForm: (page: Page, formID: string, params?: string) => Promise<import("playwright-core").Response | null>;
|
|
3
|
+
export declare const EC: import("protractor").ProtractorExpectedConditions;
|
|
4
|
+
export declare const getLocatorForContextId: (contextId: number) => (path: string) => string;
|
|
5
|
+
export declare const emptyForm: (params?: string) => Promise<any>;
|
|
6
|
+
export declare const navigateToForm: (formID: string, params?: string) => Promise<any>;
|
|
8
7
|
export declare const lajiFormLocator: (path: string) => string;
|
|
9
|
-
export declare const
|
|
8
|
+
export declare const lajiFormLocate: (str: string) => ElementFinder;
|
|
9
|
+
export declare const getFocusedElement: () => import("selenium-webdriver").WebElementPromise;
|
|
10
|
+
export declare const getFocusedId: () => import("selenium-webdriver").promise.Promise<string>;
|
|
10
11
|
export interface Mock {
|
|
11
12
|
resolve: (response?: any, raw?: boolean) => Promise<void>;
|
|
12
13
|
reject: (response?: any, raw?: boolean) => Promise<void>;
|
|
13
14
|
remove: () => Promise<void>;
|
|
14
15
|
}
|
|
15
|
-
export
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
16
|
+
export interface DateWidgetPO {
|
|
17
|
+
$container: ElementFinder;
|
|
18
|
+
$input: ElementFinder;
|
|
19
|
+
buttons: {
|
|
20
|
+
$today: ElementFinder;
|
|
21
|
+
$yesterday: ElementFinder;
|
|
22
|
+
$same: ElementFinder;
|
|
23
|
+
$date: ElementFinder;
|
|
24
|
+
$time: ElementFinder;
|
|
25
|
+
};
|
|
26
|
+
calendar: {
|
|
27
|
+
$today: ElementFinder;
|
|
28
|
+
waitAnimation: () => Promise<void>;
|
|
29
|
+
};
|
|
30
|
+
clock: {
|
|
31
|
+
"$01:00": ElementFinder;
|
|
32
|
+
waitAnimation: () => Promise<void>;
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
export interface BooleanWidgetPO {
|
|
36
|
+
$container: ElementFinder;
|
|
37
|
+
$true: ElementFinder;
|
|
38
|
+
$false: ElementFinder;
|
|
39
|
+
$undefined: ElementFinder;
|
|
40
|
+
$active: ElementFinder;
|
|
41
|
+
$nonactive: ElementFinder;
|
|
42
|
+
}
|
|
43
|
+
export interface EnumWidgetPOI {
|
|
44
|
+
$container: ElementFinder;
|
|
24
45
|
openEnums: () => Promise<void>;
|
|
25
|
-
$enumContainer:
|
|
26
|
-
|
|
27
|
-
$input:
|
|
28
|
-
}
|
|
29
|
-
interface
|
|
46
|
+
$enumContainer: ElementFinder;
|
|
47
|
+
$$enums: ElementArrayFinder;
|
|
48
|
+
$input: ElementFinder;
|
|
49
|
+
}
|
|
50
|
+
interface FormProps {
|
|
30
51
|
schema?: JSONSchema7;
|
|
31
52
|
uiSchema?: any;
|
|
32
53
|
formData?: any;
|
|
@@ -37,174 +58,127 @@ interface DemoPageProps {
|
|
|
37
58
|
localFormData?: boolean | string;
|
|
38
59
|
}
|
|
39
60
|
export declare class Form {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
61
|
+
props: FormProps;
|
|
62
|
+
contextId: number;
|
|
63
|
+
constructor(params?: FormProps);
|
|
64
|
+
initialize(beforeInit?: (form: Form) => Promise<void>, contextId?: number): Promise<void>;
|
|
65
|
+
e(path: string): Promise<any>;
|
|
66
|
+
setState(state: any): Promise<any>;
|
|
67
|
+
getState(): Promise<any>;
|
|
68
|
+
submit(): Promise<void>;
|
|
69
|
+
startSubmit(): Promise<void>;
|
|
70
|
+
submitOnlySchemaValidations(): Promise<void>;
|
|
71
|
+
waitUntilBlockingLoaderHides(timeout?: number): import("selenium-webdriver").promise.Promise<unknown>;
|
|
72
|
+
getSubmittedData(): Promise<any>;
|
|
73
|
+
getChangedData(): Promise<any>;
|
|
74
|
+
getPropsData(): Promise<any>;
|
|
75
|
+
$form: ElementFinder;
|
|
76
|
+
$locate(path: string): ElementFinder;
|
|
77
|
+
$locateButton(path: string, selector: string): ElementFinder;
|
|
78
|
+
$locateAddition(path: string, selector: string): ElementFinder;
|
|
79
|
+
getMockStr: (path: string, query: any) => string;
|
|
80
|
+
setMockResponse(path: string, query?: any): Promise<Mock>;
|
|
81
|
+
createMockResponseQueue(path: string, query?: any): Promise<{
|
|
82
|
+
create: () => Promise<{
|
|
83
|
+
resolve: (response: any, raw?: boolean | undefined) => import("selenium-webdriver").promise.Promise<unknown>;
|
|
84
|
+
reject: (response: any, raw?: boolean | undefined) => import("selenium-webdriver").promise.Promise<unknown>;
|
|
85
|
+
}>;
|
|
86
|
+
remove: () => import("selenium-webdriver").promise.Promise<unknown>;
|
|
87
|
+
}>;
|
|
49
88
|
createValidatorPO: (type: "error" | "warning") => {
|
|
50
|
-
|
|
51
|
-
$panel:
|
|
89
|
+
$$all: ElementArrayFinder;
|
|
90
|
+
$panel: ElementFinder;
|
|
52
91
|
};
|
|
53
92
|
errors: {
|
|
54
|
-
|
|
55
|
-
$panel:
|
|
93
|
+
$$all: ElementArrayFinder;
|
|
94
|
+
$panel: ElementFinder;
|
|
56
95
|
};
|
|
57
96
|
warnings: {
|
|
58
|
-
|
|
59
|
-
$panel:
|
|
97
|
+
$$all: ElementArrayFinder;
|
|
98
|
+
$panel: ElementFinder;
|
|
60
99
|
};
|
|
61
100
|
failedJobs: {
|
|
62
|
-
$container:
|
|
63
|
-
$errors: Locator;
|
|
64
|
-
};
|
|
65
|
-
$runningJobs: Locator;
|
|
66
|
-
$acknowledgeWarnings: Locator;
|
|
67
|
-
$blocker: Locator;
|
|
68
|
-
$mapFieldFullscreenMap: Locator;
|
|
69
|
-
getBooleanWidget(str: string): {
|
|
70
|
-
$container: Locator;
|
|
71
|
-
$true: Locator;
|
|
72
|
-
$false: Locator;
|
|
73
|
-
$undefined: Locator;
|
|
74
|
-
$active: Locator;
|
|
75
|
-
$nonactive: Locator;
|
|
76
|
-
};
|
|
77
|
-
$getInputWidget(str: string): Locator;
|
|
78
|
-
$getTextareaWidget(str: string): Locator;
|
|
79
|
-
$getEnumWidget(str: string): {
|
|
80
|
-
$container: Locator;
|
|
81
|
-
openEnums: () => Promise<void>;
|
|
82
|
-
$enumContainer: Locator;
|
|
83
|
-
$enums: Locator;
|
|
84
|
-
$input: Locator;
|
|
85
|
-
};
|
|
86
|
-
getDateWidget(str: string): {
|
|
87
|
-
$container: Locator;
|
|
88
|
-
$input: Locator;
|
|
89
|
-
buttons: {
|
|
90
|
-
$today: Locator;
|
|
91
|
-
$yesterday: Locator;
|
|
92
|
-
$same: Locator;
|
|
93
|
-
$date: Locator;
|
|
94
|
-
$time: Locator;
|
|
95
|
-
};
|
|
96
|
-
calendar: {
|
|
97
|
-
$today: Locator;
|
|
98
|
-
};
|
|
99
|
-
clock: {
|
|
100
|
-
"$01:00": Locator;
|
|
101
|
-
};
|
|
102
|
-
};
|
|
103
|
-
$getFieldErrors(str: string): Locator;
|
|
104
|
-
getImageArrayField: (lajiFormLocator: string) => {
|
|
105
|
-
$container: Locator;
|
|
106
|
-
$imgContainers: Locator;
|
|
107
|
-
$imgs: Locator;
|
|
108
|
-
$imgLoading: Locator;
|
|
109
|
-
$imgRemoves: Locator;
|
|
110
|
-
$imgRemoveConfirmButton: (id: string) => Locator;
|
|
111
|
-
$dropzone: Locator;
|
|
112
|
-
$modal: Locator;
|
|
113
|
-
$addModal: Locator;
|
|
114
|
-
$modalClose: Locator;
|
|
115
|
-
$addModalCancel: Locator;
|
|
116
|
-
};
|
|
117
|
-
getTaxonAutosuggestWidget: (lajiFormLocator: string) => {
|
|
118
|
-
$input: Locator;
|
|
119
|
-
$suggestionsContainer: Locator;
|
|
120
|
-
$suggestions: Locator;
|
|
121
|
-
$getGlyph: (glyph: string) => Locator;
|
|
122
|
-
$suggestedGlyph: Locator;
|
|
123
|
-
$nonsuggestedGlyph: Locator;
|
|
124
|
-
$powerUserButton: Locator;
|
|
125
|
-
};
|
|
126
|
-
getScopeField: (lajiFormLocator: string) => {
|
|
127
|
-
$button: Locator;
|
|
128
|
-
$listItems: Locator;
|
|
129
|
-
modal: {
|
|
130
|
-
$container: Locator;
|
|
131
|
-
$close: Locator;
|
|
132
|
-
$loadingGroup: Locator;
|
|
133
|
-
$groupTitles: Locator;
|
|
134
|
-
$listItems: Locator;
|
|
135
|
-
};
|
|
101
|
+
$container: ElementFinder;
|
|
136
102
|
};
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
modal: {
|
|
140
|
-
$container: Locator;
|
|
141
|
-
map: MapPageObject;
|
|
142
|
-
};
|
|
143
|
-
peeker: {
|
|
144
|
-
$popover: Locator;
|
|
145
|
-
$map: Locator;
|
|
146
|
-
$markers: Locator;
|
|
147
|
-
};
|
|
148
|
-
};
|
|
149
|
-
getUnitListShorthandArrayField: (lajiFormLocator: string) => {
|
|
150
|
-
$button: Locator;
|
|
151
|
-
modal: {
|
|
152
|
-
$input: Locator;
|
|
153
|
-
$addButton: Locator;
|
|
154
|
-
};
|
|
155
|
-
};
|
|
156
|
-
/** Draws a marker to the center of a laji-map rendered to the given locator. The locator defaults to "gatherings" */
|
|
157
|
-
putMarkerToMap(lajiFormLocator?: string): Promise<void>;
|
|
158
|
-
updateValue($input: Locator, value: string, blur?: boolean): Promise<void>;
|
|
159
|
-
$getShortHandWidget: (lajiFormLocator: string) => Locator;
|
|
160
|
-
getGeocoder: (lajiFormLocator?: string) => {
|
|
161
|
-
$btn: Locator;
|
|
162
|
-
$spinner: Locator;
|
|
163
|
-
};
|
|
164
|
-
getNamedPlaceChooser: () => {
|
|
165
|
-
select: {
|
|
166
|
-
$container: Locator;
|
|
167
|
-
openEnums: () => Promise<void>;
|
|
168
|
-
$enumContainer: Locator;
|
|
169
|
-
$enums: Locator;
|
|
170
|
-
$input: Locator;
|
|
171
|
-
};
|
|
172
|
-
mapPopup: {
|
|
173
|
-
$container: Locator;
|
|
174
|
-
$useBtn: Locator;
|
|
175
|
-
};
|
|
176
|
-
$alert: Locator;
|
|
177
|
-
$close: Locator;
|
|
178
|
-
};
|
|
179
|
-
}
|
|
180
|
-
export declare class DemoPageForm extends Form {
|
|
181
|
-
props: DemoPageProps;
|
|
182
|
-
constructor(page: Page, params?: DemoPageProps);
|
|
183
|
-
initialize(beforeInit?: (form: DemoPageForm) => Promise<void>): Promise<void>;
|
|
184
|
-
e<T>(path: string): Promise<T>;
|
|
185
|
-
setState(state: any): Promise<unknown>;
|
|
186
|
-
getState(): Promise<Pick<LajiFormState, "formData">>;
|
|
187
|
-
submit(): Promise<void>;
|
|
188
|
-
submitOnlySchemaValidations(): Promise<unknown>;
|
|
189
|
-
getSubmittedData(): Promise<JSONSerializable>;
|
|
190
|
-
getChangedData(): Promise<JSONSerializable>;
|
|
191
|
-
getPropsData(): Promise<JSONSerializable>;
|
|
192
|
-
getMockStr: (path: string, query: any) => string;
|
|
193
|
-
setMockResponse(path: string, query?: any): Promise<Mock>;
|
|
194
|
-
createMockResponseQueue(path: string, query?: any): Promise<{
|
|
195
|
-
create: () => Promise<{
|
|
196
|
-
resolve: (response: any, raw?: boolean | undefined) => Promise<unknown>;
|
|
197
|
-
reject: (response: any, raw?: boolean | undefined) => Promise<unknown>;
|
|
198
|
-
}>;
|
|
199
|
-
remove: () => Promise<unknown>;
|
|
200
|
-
}>;
|
|
103
|
+
$acknowledgeWarnings: ElementFinder;
|
|
104
|
+
isBlocked: () => import("selenium-webdriver").promise.Promise<boolean>;
|
|
201
105
|
mockImageUpload: (lajiFormLocator: string) => Promise<{
|
|
202
106
|
resolve: () => Promise<void>;
|
|
203
107
|
remove: () => Promise<void>;
|
|
204
108
|
}>;
|
|
109
|
+
getBooleanWidget(str: string): BooleanWidgetPO;
|
|
110
|
+
$getInputWidget(str: string): ElementFinder;
|
|
111
|
+
$getTextareaWidget(str: string): ElementFinder;
|
|
112
|
+
$getEnumWidget(str: string): EnumWidgetPOI;
|
|
113
|
+
getDateWidget(str: string): DateWidgetPO;
|
|
114
|
+
$$getFieldErrors(str: string): ElementArrayFinder;
|
|
115
|
+
_getImageArrayField: (form: Form) => (lajiFormLocator: string) => ImageArrayFieldPOI;
|
|
116
|
+
getImageArrayField: (lajiFormLocator: string) => ImageArrayFieldPOI;
|
|
117
|
+
_getTaxonAutosuggestWidget: (form: Form) => (lajiFormLocator: string) => TaxonAutosuggestWidgetPOI;
|
|
118
|
+
getTaxonAutosuggestWidget: (lajiFormLocator: string) => TaxonAutosuggestWidgetPOI;
|
|
119
|
+
getScopeField: (lajiFormLocator: string) => {
|
|
120
|
+
$button: ElementFinder;
|
|
121
|
+
$$listItems: ElementArrayFinder;
|
|
122
|
+
};
|
|
123
|
+
getUnitListShorthandArrayField: (lajiFormLocator: string) => UnitListShorthandArrayFieldPOI;
|
|
124
|
+
}
|
|
125
|
+
export declare const isDisplayed: ($elem: ElementFinder) => Promise<boolean>;
|
|
126
|
+
export interface ImageArrayFieldPOI {
|
|
127
|
+
$container: ElementFinder;
|
|
128
|
+
$$imgs: ElementArrayFinder;
|
|
129
|
+
$$imgInteractives: ElementArrayFinder;
|
|
130
|
+
$$imgRemoves: ElementArrayFinder;
|
|
131
|
+
$imgRemoveConfirmButton: (id: string) => ElementFinder;
|
|
132
|
+
$dropzone: ElementFinder;
|
|
133
|
+
$modal: ElementFinder;
|
|
134
|
+
$modalClose: ElementFinder;
|
|
135
|
+
}
|
|
136
|
+
export interface TaxonAutosuggestWidgetPOI {
|
|
137
|
+
$input: ElementFinder;
|
|
138
|
+
$suggestionsContainer: ElementFinder;
|
|
139
|
+
$$suggestions: ElementArrayFinder;
|
|
140
|
+
waitForSuggestionsToLoad: () => Promise<void>;
|
|
141
|
+
waitForGlyph: () => Promise<void>;
|
|
142
|
+
isSuggested: () => Promise<boolean>;
|
|
143
|
+
isNonsuggested: () => Promise<boolean>;
|
|
144
|
+
$powerUserButton: ElementFinder;
|
|
145
|
+
powerUserButtonIsActive: () => Promise<boolean>;
|
|
146
|
+
waitForPopoverToHide: () => Promise<void>;
|
|
205
147
|
}
|
|
206
|
-
export
|
|
148
|
+
export interface UnitListShorthandArrayFieldPOI {
|
|
149
|
+
$button: ElementFinder;
|
|
150
|
+
modal: {
|
|
151
|
+
$input: ElementFinder;
|
|
152
|
+
$addButton: ElementFinder;
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
export declare class NamedPlaceChooserPO {
|
|
156
|
+
select: EnumWidgetPOI;
|
|
157
|
+
mapPopup: {
|
|
158
|
+
$container: ElementFinder;
|
|
159
|
+
$useBtn: ElementFinder;
|
|
160
|
+
};
|
|
161
|
+
$alert: ElementFinder;
|
|
162
|
+
$close: ElementFinder;
|
|
163
|
+
}
|
|
164
|
+
export declare function createForm(props?: FormProps, beforeInit?: (form: Form) => Promise<void>): Promise<Form>;
|
|
165
|
+
export declare function waitUntilBlockingLoaderHides(timeout?: number): import("selenium-webdriver").promise.Promise<unknown>;
|
|
166
|
+
export declare function putForeignMarkerToMap(): Promise<void>;
|
|
167
|
+
export declare function removeUnit(gatheringIdx: number, unitIdx: number): Promise<void>;
|
|
168
|
+
export declare const updateValue: ($input: ElementFinder, value: string, blur?: boolean) => Promise<void>;
|
|
169
|
+
export declare const mockImageMetadata: {
|
|
170
|
+
id: string;
|
|
171
|
+
capturerVerbatim: string[];
|
|
172
|
+
intellectualOwner: string;
|
|
173
|
+
intellectualRights: string;
|
|
174
|
+
fullURL: string;
|
|
175
|
+
largeURL: string;
|
|
176
|
+
squareThumbnailURL: string;
|
|
177
|
+
thumbnailURL: string;
|
|
178
|
+
originalURL: string;
|
|
179
|
+
uploadedBy: string;
|
|
180
|
+
"@context": string;
|
|
181
|
+
};
|
|
207
182
|
export declare const filterUUIDs: (any: any) => any;
|
|
208
183
|
export declare const maybeJSONPointerToLocator: (pointer: string) => string;
|
|
209
|
-
export declare const getRemoveUnit: (page: Page) => (gatheringIdx: number, unitIdx: number) => Promise<void>;
|
|
210
184
|
export {};
|