@luomus/laji-form 14.3.8 → 15.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.
Files changed (77) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/cypress/fixtures/example.json +5 -0
  3. closes suggestion list (failed).png +0 -0
  4. is marked as suggested (failed).png +0 -0
  5. package/dist/laji-form.js +1 -1
  6. package/lib/components/LajiForm.js +0 -1
  7. package/lib/components/fields/ImageArrayField.js +2 -4
  8. package/lib/components/fields/NamedPlaceSaverField.js +1 -1
  9. package/lib/components/fields/SectionArrayField.js +5 -1
  10. package/lib/components/fields/SingleActiveArrayField.js +1 -1
  11. package/lib/components/fields/UnitShorthandField.js +2 -2
  12. package/lib/components/templates/ArrayFieldTemplate.js +3 -2
  13. package/lib/components/templates/FieldTemplate.js +2 -2
  14. package/lib/utils.d.ts +6 -2
  15. package/lib/utils.js +13 -13
  16. package/llol +10 -0
  17. package/llol.pdf +10 -0
  18. package/migrate.sh +33 -0
  19. package/package.json +14 -21
  20. package/playwright-report/index.html +62 -0
  21. package/playwright.config.ts +77 -0
  22. package/q +196 -0
  23. package/rename.sh +24 -0
  24. package/test-export/test-utils.d.ts +177 -150
  25. package/test-export/test-utils.js +214 -218
  26. package/trip-report.spec.ts +594 -0
  27. package/tsconfig.test.json +1 -1
  28. package/lib/components/fields/AsArrayField.d.ts +0 -292
  29. package/lib/components/fields/AsArrayField.js +0 -39
  30. package/test-export/array-spec.d.ts +0 -1
  31. package/test-export/array-spec.js +0 -204
  32. package/test-export/bird-point-count-spec.d.ts +0 -1
  33. package/test-export/bird-point-count-spec.js +0 -62
  34. package/test-export/collection-contest-form-spec.d.ts +0 -1
  35. package/test-export/collection-contest-form-spec.js +0 -38
  36. package/test-export/dataset-form-spec.d.ts +0 -1
  37. package/test-export/dataset-form-spec.js +0 -50
  38. package/test-export/date-time-widget-spec.d.ts +0 -1
  39. package/test-export/date-time-widget-spec.js +0 -188
  40. package/test-export/geocoder-spec.d.ts +0 -1
  41. package/test-export/geocoder-spec.js +0 -135
  42. package/test-export/image-array-spec.d.ts +0 -1
  43. package/test-export/image-array-spec.js +0 -94
  44. package/test-export/inject-field-spec.d.ts +0 -1
  45. package/test-export/inject-field-spec.js +0 -148
  46. package/test-export/internal-uuids-spec.d.ts +0 -1
  47. package/test-export/internal-uuids-spec.js +0 -157
  48. package/test-export/invasive-species-eradication-np-spec.d.ts +0 -1
  49. package/test-export/invasive-species-eradication-np-spec.js +0 -18
  50. package/test-export/invasive-species-eradication-spec.d.ts +0 -1
  51. package/test-export/invasive-species-eradication-spec.js +0 -25
  52. package/test-export/line-transect-spec.d.ts +0 -1
  53. package/test-export/line-transect-spec.js +0 -121
  54. package/test-export/mobile-form-spec.d.ts +0 -1
  55. package/test-export/mobile-form-spec.js +0 -84
  56. package/test-export/nafi-spec.d.ts +0 -1
  57. package/test-export/nafi-spec.js +0 -85
  58. package/test-export/select-widget-spec.d.ts +0 -1
  59. package/test-export/select-widget-spec.js +0 -68
  60. package/test-export/single-item-array-field-spec.d.ts +0 -1
  61. package/test-export/single-item-array-field-spec.js +0 -92
  62. package/test-export/syke-butterfly-spec.d.ts +0 -1
  63. package/test-export/syke-butterfly-spec.js +0 -163
  64. package/test-export/transaction-form-spec.d.ts +0 -1
  65. package/test-export/transaction-form-spec.js +0 -63
  66. package/test-export/trip-report-autosuggest-spec.d.ts +0 -1
  67. package/test-export/trip-report-autosuggest-spec.js +0 -272
  68. package/test-export/trip-report-spec.d.ts +0 -1
  69. package/test-export/trip-report-spec.js +0 -456
  70. package/test-export/unit-list-shorthand-array-field-spec.d.ts +0 -1
  71. package/test-export/unit-list-shorthand-array-field-spec.js +0 -71
  72. package/test-export/validation-spec.d.ts +0 -1
  73. package/test-export/validation-spec.js +0 -336
  74. package/test-export/water-bird-spec.d.ts +0 -1
  75. package/test-export/water-bird-spec.js +0 -30
  76. package/test-export/wbc-spec.d.ts +0 -1
  77. package/test-export/wbc-spec.js +0 -82
@@ -0,0 +1,77 @@
1
+ import { defineConfig, devices } from '@playwright/test';
2
+
3
+ /**
4
+ * Read environment variables from file.
5
+ * https://github.com/motdotla/dotenv
6
+ */
7
+ // require('dotenv').config();
8
+
9
+ /**
10
+ * See https://playwright.dev/docs/test-configuration.
11
+ */
12
+ export default defineConfig({
13
+ testDir: './test',
14
+ /* Run tests in files in parallel */
15
+ fullyParallel: true,
16
+ /* Fail the build on CI if you accidentally left test.only in the source code. */
17
+ forbidOnly: !!process.env.CI,
18
+ /* Retry on CI only */
19
+ retries: process.env.CI ? 2 : 0,
20
+ /* Opt out of parallel tests on CI. */
21
+ workers: process.env.CI ? 1 : undefined,
22
+ /* Reporter to use. See https://playwright.dev/docs/test-reporters */
23
+ reporter: 'line',
24
+ /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */
25
+ use: {
26
+ /* Base URL to use in actions like `await page.goto('/')`. */
27
+ baseURL: 'http://127.0.0.1:8083',
28
+
29
+ /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */
30
+ trace: 'on-first-retry',
31
+ },
32
+
33
+ /* Configure projects for major browsers */
34
+ projects: [
35
+ {
36
+ name: 'chromium',
37
+ use: { ...devices['Desktop Chrome'] },
38
+ },
39
+
40
+ {
41
+ name: 'firefox',
42
+ use: { ...devices['Desktop Firefox'] },
43
+ },
44
+
45
+ // {
46
+ // name: 'webkit',
47
+ // use: { ...devices['Desktop Safari'] },
48
+ // },
49
+
50
+ /* Test against mobile viewports. */
51
+ // {
52
+ // name: 'Mobile Chrome',
53
+ // use: { ...devices['Pixel 5'] },
54
+ // },
55
+ // {
56
+ // name: 'Mobile Safari',
57
+ // use: { ...devices['iPhone 12'] },
58
+ // },
59
+
60
+ /* Test against branded browsers. */
61
+ // {
62
+ // name: 'Microsoft Edge',
63
+ // use: { ...devices['Desktop Edge'], channel: 'msedge' },
64
+ // },
65
+ // {
66
+ // name: 'Google Chrome',
67
+ // use: { ...devices['Desktop Chrome'], channel: 'chrome' },
68
+ // },
69
+ ],
70
+
71
+ /* Run your local dev server before starting the tests */
72
+ // webServer: {
73
+ // command: 'npm run start',
74
+ // url: 'http://127.0.0.1:3000',
75
+ // reuseExistingServer: !process.env.CI,
76
+ // },
77
+ });
package/q ADDED
@@ -0,0 +1,196 @@
1
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
2
+ modified: src/components/components.js
3
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
4
+ @ src/components/components.js:360 @ export class Stretch extends React.Component {
5
+ }
6
+ 
7
+ invalidate = (callback) => {
8
+  console.log('invalidate');
9
+ this.update(this.getState(), callback);
10
+ }
11
+ 
12
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
13
+ modified: src/components/fields/EnumRangeArrayField.js
14
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
15
+ @ src/components/fields/EnumRangeArrayField.js:8 @ import BaseComponent from "../BaseComponent";
16
+ import { getUiOptions } from "../../utils";
17
+ import { Autosuggest } from "../widgets/AutosuggestWidget";
18
+ import { TagInputComponent } from "./TagArrayField";
19
+ const equals = require("deep-equal");
20
+ 
21
+ @BaseComponent
22
+ export default class EnumRangeArrayField extends React.Component {
23
+ @ src/components/fields/EnumRangeArrayField.js:30 @ export default class EnumRangeArrayField extends React.Component {
24
+ this.state = {value: ""};
25
+ }
26
+ 
27
+  UNSAFE_componentWillReceiveProps(props) {
28
+  if (!equals(props.formData, this.props.formData)) {
29
+  this.props.formContext.services.customEvents.send(props.idSchema.$id, "resize");
30
+  }
31
+  }
32
+  
33
+ setRef = (elem) => {
34
+ this.autosuggestRef = elem;
35
+ }
36
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
37
+ modified: src/components/fields/ImageArrayField.tsx
38
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
39
+ @ src/components/fields/ImageArrayField.tsx:209 @ export function MediaArrayField<LFC extends Constructor<React.Component<FieldPro
40
+ this.mounted = false;
41
+ }
42
+ 
43
+  componentDidUpdate(prevProps: FieldProps, prevState: MediaArrayState) {
44
+  const getCount = (_props: FieldProps, _state: MediaArrayState) => ((_props.formData || []).length + (_state.tmpMedias || []).length);
45
+  
46
+  if (getCount(prevProps, prevState) !== getCount(this.props, this.state)) {
47
+  this.props.formContext.services.customEvents.send(this.props.idSchema.$id, "resize");
48
+  }
49
+  }
50
+  
51
+ onDragEnter = () => {this.setState({dragging: true});};
52
+ 
53
+ onDragLeave = () => {this.setState({dragging: false});};
54
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
55
+ modified: src/components/fields/MapArrayField.js
56
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
57
+ @ src/components/fields/MapArrayField.js:1159 @ class _MapArrayField extends ComposedComponent { // eslint-disable-line indent
58
+ this._tileLayerNameOnNextTick = tileLayerOptions;
59
+ this._tileLayerNameOnNextTickCallback = callback;
60
+ };
61
+  this._resizeEventHandler = () => {
62
+  this.refs.stretch.invalidate();
63
+  };
64
+ this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "activeIdx", this._setActiveEventHandler);
65
+ this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "zoomToData", this._zoomToDataEventHandler);
66
+ this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "tileLayers", this._tileLayersEventHandler);
67
+  this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "resize", this._resizeEventHandler);
68
+ 
69
+ if (this.state.activeIdx !== undefined) {
70
+ this.afterActiveChange(this.state.activeIdx, !!"initial call");
71
+ @ src/components/fields/MapArrayField.js:1179 @ class _MapArrayField extends ComposedComponent { // eslint-disable-line indent
72
+ this.props.formContext.services.customEvents.remove(this.props.idSchema.$id, "activeIdx", this._setActiveEventHandler);
73
+ this.props.formContext.services.customEvents.remove(this.props.idSchema.$id, "zoomToData", this._zoomToDataEventHandler);
74
+ this.props.formContext.services.customEvents.remove(this.props.idSchema.$id, "tileLayers", this._tileLayersEventHandler);
75
+  this.props.formContext.services.customEvents.remove(this.props.idSchema.$id, "resize", this._resizeEventHandler);
76
+ }
77
+ 
78
+ componentDidUpdate(...params) {
79
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
80
+ modified: src/components/fields/SchemaField.js
81
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
82
+ @ src/components/fields/SchemaField.js:112 @ export default class _SchemaField extends React.Component {
83
+ };
84
+ }
85
+ 
86
+  componentDidUpdate(prevProps) {
87
+  if (!deepEquals(prevProps.errorSchema, this.props.errorSchema)) {
88
+  this.props.registry.formContext.services.customEvents.send(this.props.idSchema.$id, "resize");
89
+  }
90
+  }
91
+  
92
+ render() {
93
+ const props = this.functionOutputProps || this.props;
94
+ let {schema, uiSchema = {}, formContext, registry, ..._props} = props; // eslint-disable-line @typescript-eslint/no-unused-vars
95
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
96
+ modified: src/components/fields/ScopeField.js
97
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
98
+ @ src/components/fields/ScopeField.js:138 @ export default class ScopeField extends React.Component {
99
+ }
100
+ if (!equals(prevState.fieldsToShow, this.state.fieldsToShow)) {
101
+ this.props.formContext.utils.syncScroll();
102
+  this.props.formContext.services.customEvents.send(this.props.idSchema.$id, "resize");
103
+ }
104
+ }
105
+ 
106
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
107
+ modified: src/components/fields/SingleActiveArrayField.js
108
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
109
+ @ src/components/fields/SingleActiveArrayField.js:678 @ class TableArrayFieldTemplate extends React.Component {
110
+ super(props);
111
+ this.state = {};
112
+ this.itemElems = [];
113
+  this.resizeObserver = new ResizeObserver(this.onResize);
114
+ }
115
+ 
116
+  onResize = (data, callback) => {
117
+  this.updateLayout(null, callback);
118
+  onResize = () => {
119
+  this.updateLayout();
120
+ }
121
+ 
122
+ componentDidMount() {
123
+  this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "resize", this.onResize);
124
+ this._updateRenderingMode = () => this.updateRenderingMode();
125
+ window.addEventListener("resize", this._updateRenderingMode);
126
+ this.updateRenderingMode();
127
+ @ src/components/fields/SingleActiveArrayField.js:694 @ class TableArrayFieldTemplate extends React.Component {
128
+ 
129
+ componentWillUnmount() {
130
+ window.removeEventListener("resize", this._updateRenderingMode);
131
+  this.props.formContext.services.customEvents.remove(this.props.idSchema.$id, "resize", this.onResize);
132
+  this.resizeObserver.disconnect();
133
+ }
134
+ 
135
+ componentDidUpdate(prevProps, prevState) {
136
+ @ src/components/fields/SingleActiveArrayField.js:726 @ class TableArrayFieldTemplate extends React.Component {
137
+ if (tHeadHeight) this.prevTHeadHeight = tHeadHeight;
138
+ this._prevCheckedLength = this.props.items.length;
139
+ }
140
+  
141
+  if (this.props.idSchema.$id !== prevProps.idSchema.$id) {
142
+  prevProps.formContext.services.customEvents.remove(prevProps.idSchema.$id, "resize", this.onResize);
143
+  this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "resize", this.onResize);
144
+  this.updateLayout();
145
+  }
146
+ }
147
+ 
148
+ // Sets state.normalRendering on if screen is too small for table layout.
149
+ @ src/components/fields/SingleActiveArrayField.js:775 @ class TableArrayFieldTemplate extends React.Component {
150
+ 
151
+ setActiveRef = (elem) => {
152
+ this.activeElem = elem;
153
+  this.activeElem && this.resizeObserver.observe(this.activeElem);
154
+ }
155
+ 
156
+ setTHeadRef = (elem) => {
157
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
158
+ modified: src/components/fields/TagArrayField.js
159
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
160
+ @ src/components/fields/TagArrayField.js:6 @ import { findDOMNode } from "react-dom";
161
+ import * as PropTypes from "prop-types";
162
+ import { isEmptyString, getUiOptions, triggerParentComponent } from "../../utils";
163
+ import BaseComponent from "../BaseComponent";
164
+ const equals = require("deep-equal");
165
+ 
166
+ @BaseComponent
167
+ export default class TagArrayField extends React.Component {
168
+ @ src/components/fields/TagArrayField.js:43 @ export class TagInputComponent extends React.Component {
169
+ this.setState(this.getStateFromProps(props));
170
+ }
171
+ 
172
+  componentDidUpdate(prevProps) {
173
+  if (!equals(prevProps.formData, this.props.formData)) {
174
+  this.props.formContext.services.customEvents.send(this.props.idSchema.$id, "resize");
175
+  }
176
+  }
177
+  
178
+ getStateFromProps = ({value}) => {
179
+ return {value};
180
+ }
181
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
182
+ modified: src/components/templates/ArrayFieldTemplate.js
183
+ ───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
184
+ @ src/components/templates/ArrayFieldTemplate.js:13 @ import { getTemplate } from "@rjsf/utils";
185
+ function onAdd(e, props) {
186
+ if (!canAdd(props)) return;
187
+ props.onAddClick(e);
188
+  setTimeout(() => props.formContext.services.customEvents.send(props.idSchema.$id, "resize"));
189
+ }
190
+ 
191
+ export const onDelete = (item, props) => (e) => {
192
+ item.onDropIndexClick(item.index)(e);
193
+  setTimeout(() => props.formContext.services.customEvents.send(props.idSchema.$id, "resize"));
194
+ };
195
+ 
196
+ export function beforeAdd(props) {
package/rename.sh ADDED
@@ -0,0 +1,24 @@
1
+ mv array-spec.ts array.spec.ts
2
+ mv bird-point-count-spec.ts sbird-point-count.spec.ts
3
+ mv collection-contest-form-spec.ts collection-contest-form.spec.ts
4
+ mv dataset-form-spec.ts dataset-form.spec.ts
5
+ mv date-time-widget-spec.ts date-time-widget.spec.ts
6
+ mv geocoder-spec.ts geocoder.spec.ts
7
+ mv image-array-spec.ts image-array.spec.ts
8
+ mv inject-field-spec.ts inject-field.spec.ts
9
+ mv internal-uuids-spec.ts internal-uuids.spec.ts
10
+ mv invasive-species-eradication-np-spec.ts invasive-species-eradication-np.spec.ts
11
+ mv invasive-species-eradication-spec.ts invasive-species-eradication.spec.ts
12
+ mv line-transect-spec.ts line-transect.spec.ts
13
+ mv mobile-form-spec.ts mobile-form.spec.ts
14
+ mv nafi-spec.ts nafi.spec.ts
15
+ mv select-widget-spec.ts select-widget.spec.ts
16
+ mv single-item-array-field-spec.ts single-item-array-field.spec.ts
17
+ mv syke-butterfly-spec.ts syke-butterfly.spec.ts
18
+ mv transaction-form-spec.ts transaction-form.spec.ts
19
+ mv trip-report-autosuggest-spec.ts trip-report-autosuggest.spec.ts
20
+ mv trip-report-spec.ts trip-report.spec.ts
21
+ mv unit-list-shorthand-array-field-spec.ts unit-list-shorthand-array-field.spec.ts
22
+ mv validation-spec.ts validation.spec.ts
23
+ mv water-bird-spec.ts water-bird.spec.ts
24
+ mv wbc-spec.ts wbc.spec.ts
@@ -1,53 +1,32 @@
1
- import { ElementFinder, ElementArrayFinder } from "protractor";
1
+ import { Locator, Page } from "@playwright/test";
2
2
  import { JSONSchema7 } from "json-schema";
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>;
3
+ import { LajiFormState } from "@luomus/laji-form/lib/components/LajiForm";
4
+ import type { JSONSerializable } from "@luomus/laji-form/lib/utils";
5
+ import { MapPageObject } from "@luomus/laji-map/test-export/test-utils";
6
+ export declare const emptyForm: (page: Page, params?: string) => Promise<import("playwright-core").Response | null>;
7
+ export declare const navigateToForm: (page: Page, formID: string, params?: string) => Promise<import("playwright-core").Response | null>;
7
8
  export declare const lajiFormLocator: (path: string) => string;
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>;
9
+ export declare const getFocusedElement: (page: Page) => Locator;
11
10
  export interface Mock {
12
11
  resolve: (response?: any, raw?: boolean) => Promise<void>;
13
12
  reject: (response?: any, raw?: boolean) => Promise<void>;
14
13
  remove: () => Promise<void>;
15
14
  }
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;
15
+ export declare type ImageArrayFieldPO = ReturnType<Form["getImageArrayField"]>;
16
+ export declare type TaxonAutosuggestWidgetPO = ReturnType<Form["getTaxonAutosuggestWidget"]>;
17
+ export declare type UnitListShorthandArrayFieldPO = ReturnType<Form["getUnitListShorthandArrayField"]>;
18
+ export declare type EnumWidgetPO = ReturnType<typeof getEnumWidgetForContainer>;
19
+ export declare type DateWidgetPO = ReturnType<Form["getDateWidget"]>;
20
+ export declare type BooleanWidgetPO = ReturnType<Form["getBooleanWidget"]>;
21
+ export declare type NamedPlaceChooserPO = ReturnType<Form["getNamedPlaceChooser"]>;
22
+ declare function getEnumWidgetForContainer($container: Locator): {
23
+ $container: Locator;
45
24
  openEnums: () => Promise<void>;
46
- $enumContainer: ElementFinder;
47
- $$enums: ElementArrayFinder;
48
- $input: ElementFinder;
49
- }
50
- interface FormProps {
25
+ $enumContainer: Locator;
26
+ $enums: Locator;
27
+ $input: Locator;
28
+ };
29
+ interface DemoPageProps {
51
30
  schema?: JSONSchema7;
52
31
  uiSchema?: any;
53
32
  formData?: any;
@@ -58,127 +37,175 @@ interface FormProps {
58
37
  localFormData?: boolean | string;
59
38
  }
60
39
  export declare class Form {
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
- }>;
40
+ protected page: Page;
41
+ protected $locator: Locator;
42
+ constructor(page: Page, $locator?: Locator);
43
+ $form: Locator;
44
+ /** Locates a field with a dot separated identifier, e.g. "gatherings.0.units.1" */
45
+ $locate(path: string): Locator;
46
+ /** Locates a button for a field with a dot separated identifier, e.g. "gatherings.0.units.1" */
47
+ $locateButton(path: string, selector: string, locateFromBody?: boolean): Locator;
48
+ /** Locates some additional element for a field with a dot separated identifier, e.g. "gatherings.0.units.1" */
49
+ $locateAddition(path: string, selector: string, locateFromBody?: boolean): Locator;
88
50
  createValidatorPO: (type: "error" | "warning") => {
89
- $$all: ElementArrayFinder;
90
- $panel: ElementFinder;
51
+ $all: Locator;
52
+ $panel: Locator;
91
53
  };
92
54
  errors: {
93
- $$all: ElementArrayFinder;
94
- $panel: ElementFinder;
55
+ $all: Locator;
56
+ $panel: Locator;
95
57
  };
96
58
  warnings: {
97
- $$all: ElementArrayFinder;
98
- $panel: ElementFinder;
59
+ $all: Locator;
60
+ $panel: Locator;
99
61
  };
100
62
  failedJobs: {
101
- $container: ElementFinder;
63
+ $container: Locator;
64
+ $errors: Locator;
65
+ };
66
+ $runningJobs: Locator;
67
+ $acknowledgeWarnings: Locator;
68
+ $blocker: Locator;
69
+ $mapFieldFullscreenMap: Locator;
70
+ getBooleanWidget(str: string): {
71
+ $container: Locator;
72
+ $true: Locator;
73
+ $false: Locator;
74
+ $undefined: Locator;
75
+ $active: Locator;
76
+ $nonactive: Locator;
77
+ };
78
+ $getInputWidget(str: string): Locator;
79
+ $getTextareaWidget(str: string): Locator;
80
+ $getEnumWidget(str: string): {
81
+ $container: Locator;
82
+ openEnums: () => Promise<void>;
83
+ $enumContainer: Locator;
84
+ $enums: Locator;
85
+ $input: Locator;
86
+ };
87
+ getDateWidget(str: string): {
88
+ $container: Locator;
89
+ $input: Locator;
90
+ buttons: {
91
+ $today: Locator;
92
+ $yesterday: Locator;
93
+ $same: Locator;
94
+ $date: Locator;
95
+ $time: Locator;
96
+ };
97
+ calendar: {
98
+ $today: Locator;
99
+ };
100
+ clock: {
101
+ "$01:00": Locator;
102
+ };
103
+ };
104
+ $getFieldErrors(str: string): Locator;
105
+ getImageArrayField: (lajiFormLocator: string) => {
106
+ $container: Locator;
107
+ $imgContainers: Locator;
108
+ $imgs: Locator;
109
+ $imgLoading: Locator;
110
+ $imgRemoves: Locator;
111
+ $imgRemoveConfirmButton: (id: string) => Locator;
112
+ $dropzone: Locator;
113
+ $modal: Locator;
114
+ $addModal: Locator;
115
+ $modalClose: Locator;
116
+ $addModalCancel: Locator;
117
+ };
118
+ getTaxonAutosuggestWidget: (lajiFormLocator: string) => {
119
+ $input: Locator;
120
+ $suggestionsContainer: Locator;
121
+ $suggestions: Locator;
122
+ $getGlyph: (glyph: string) => Locator;
123
+ $suggestedGlyph: Locator;
124
+ $nonsuggestedGlyph: Locator;
125
+ $powerUserButton: Locator;
102
126
  };
103
- $acknowledgeWarnings: ElementFinder;
104
- isBlocked: () => import("selenium-webdriver").promise.Promise<boolean>;
105
- mockImageUpload: (lajiFormLocator: string) => Promise<{
106
- resolve: () => Promise<void>;
107
- remove: () => Promise<void>;
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
127
  getScopeField: (lajiFormLocator: string) => {
120
- $button: ElementFinder;
121
- $$listItems: ElementArrayFinder;
128
+ $button: Locator;
129
+ $listItems: Locator;
130
+ modal: {
131
+ $container: Locator;
132
+ $close: Locator;
133
+ $loadingGroup: Locator;
134
+ $groupTitles: Locator;
135
+ $listItems: Locator;
136
+ };
122
137
  };
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>;
147
- }
148
- export interface UnitListShorthandArrayFieldPOI {
149
- $button: ElementFinder;
150
- modal: {
151
- $input: ElementFinder;
152
- $addButton: ElementFinder;
138
+ getLocationChooser: (lajiFormLocator: string) => {
139
+ $button: Locator;
140
+ modal: {
141
+ $container: Locator;
142
+ map: MapPageObject;
143
+ };
144
+ peeker: {
145
+ $popover: Locator;
146
+ $map: Locator;
147
+ $markers: Locator;
148
+ };
153
149
  };
154
- }
155
- export declare class NamedPlaceChooserPO {
156
- select: EnumWidgetPOI;
157
- mapPopup: {
158
- $container: ElementFinder;
159
- $useBtn: ElementFinder;
150
+ getUnitListShorthandArrayField: (lajiFormLocator: string) => {
151
+ $button: Locator;
152
+ modal: {
153
+ $input: Locator;
154
+ $addButton: Locator;
155
+ };
156
+ };
157
+ /** Draws a marker to the center of a laji-map rendered to the given locator. The locator defaults to "gatherings" */
158
+ putMarkerToMap(lajiFormLocator?: string): Promise<void>;
159
+ updateValue($input: Locator, value: string, blur?: boolean): Promise<void>;
160
+ $getShortHandWidget: (lajiFormLocator: string) => Locator;
161
+ getGeocoder: (lajiFormLocator?: string) => {
162
+ $btn: Locator;
163
+ $spinner: Locator;
164
+ };
165
+ getNamedPlaceChooser: () => {
166
+ select: {
167
+ $container: Locator;
168
+ openEnums: () => Promise<void>;
169
+ $enumContainer: Locator;
170
+ $enums: Locator;
171
+ $input: Locator;
172
+ };
173
+ mapPopup: {
174
+ $container: Locator;
175
+ $useBtn: Locator;
176
+ };
177
+ $alert: Locator;
178
+ $close: Locator;
160
179
  };
161
- $alert: ElementFinder;
162
- $close: ElementFinder;
163
180
  }
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
- };
181
+ export declare class DemoPageForm extends Form {
182
+ props: DemoPageProps;
183
+ constructor(page: Page, params?: DemoPageProps);
184
+ initialize(beforeInit?: (form: DemoPageForm) => Promise<void>): Promise<void>;
185
+ e<T>(path: string): Promise<T>;
186
+ setState(state: any): Promise<unknown>;
187
+ getState(): Promise<Pick<LajiFormState, "formData">>;
188
+ submit(): Promise<void>;
189
+ submitOnlySchemaValidations(): Promise<unknown>;
190
+ getSubmittedData(): Promise<JSONSerializable>;
191
+ getChangedData(): Promise<JSONSerializable>;
192
+ getPropsData(): Promise<JSONSerializable>;
193
+ getMockStr: (path: string, query: any) => string;
194
+ setMockResponse(path: string, query?: any): Promise<Mock>;
195
+ createMockResponseQueue(path: string, query?: any): Promise<{
196
+ create: () => Promise<{
197
+ resolve: (response: any, raw?: boolean | undefined) => Promise<unknown>;
198
+ reject: (response: any, raw?: boolean | undefined) => Promise<unknown>;
199
+ }>;
200
+ remove: () => Promise<unknown>;
201
+ }>;
202
+ mockImageUpload: (lajiFormLocator: string) => Promise<{
203
+ resolve: () => Promise<void>;
204
+ remove: () => Promise<void>;
205
+ }>;
206
+ }
207
+ export declare function createForm(page: Page, props?: DemoPageProps, beforeInit?: (form: Form) => Promise<void>): Promise<DemoPageForm>;
182
208
  export declare const filterUUIDs: (any: any) => any;
183
209
  export declare const maybeJSONPointerToLocator: (pointer: string) => string;
210
+ export declare const getRemoveUnit: (page: Page) => (gatheringIdx: number, unitIdx: number) => Promise<void>;
184
211
  export {};