@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.
- package/CHANGELOG.md +4 -0
- package/cypress/fixtures/example.json +5 -0
- closes suggestion list (failed).png +0 -0
- is marked as suggested (failed).png +0 -0
- package/dist/laji-form.js +1 -1
- package/lib/components/LajiForm.js +0 -1
- package/lib/components/fields/ImageArrayField.js +2 -4
- package/lib/components/fields/NamedPlaceSaverField.js +1 -1
- package/lib/components/fields/SectionArrayField.js +5 -1
- package/lib/components/fields/SingleActiveArrayField.js +1 -1
- package/lib/components/fields/UnitShorthandField.js +2 -2
- package/lib/components/templates/ArrayFieldTemplate.js +3 -2
- package/lib/components/templates/FieldTemplate.js +2 -2
- package/lib/utils.d.ts +6 -2
- package/lib/utils.js +13 -13
- package/llol +10 -0
- package/llol.pdf +10 -0
- package/migrate.sh +33 -0
- package/package.json +14 -21
- package/playwright-report/index.html +62 -0
- package/playwright.config.ts +77 -0
- package/q +196 -0
- package/rename.sh +24 -0
- package/test-export/test-utils.d.ts +177 -150
- package/test-export/test-utils.js +214 -218
- package/trip-report.spec.ts +594 -0
- package/tsconfig.test.json +1 -1
- package/lib/components/fields/AsArrayField.d.ts +0 -292
- package/lib/components/fields/AsArrayField.js +0 -39
- package/test-export/array-spec.d.ts +0 -1
- package/test-export/array-spec.js +0 -204
- package/test-export/bird-point-count-spec.d.ts +0 -1
- package/test-export/bird-point-count-spec.js +0 -62
- package/test-export/collection-contest-form-spec.d.ts +0 -1
- package/test-export/collection-contest-form-spec.js +0 -38
- package/test-export/dataset-form-spec.d.ts +0 -1
- package/test-export/dataset-form-spec.js +0 -50
- package/test-export/date-time-widget-spec.d.ts +0 -1
- package/test-export/date-time-widget-spec.js +0 -188
- package/test-export/geocoder-spec.d.ts +0 -1
- package/test-export/geocoder-spec.js +0 -135
- package/test-export/image-array-spec.d.ts +0 -1
- package/test-export/image-array-spec.js +0 -94
- package/test-export/inject-field-spec.d.ts +0 -1
- package/test-export/inject-field-spec.js +0 -148
- package/test-export/internal-uuids-spec.d.ts +0 -1
- package/test-export/internal-uuids-spec.js +0 -157
- package/test-export/invasive-species-eradication-np-spec.d.ts +0 -1
- package/test-export/invasive-species-eradication-np-spec.js +0 -18
- package/test-export/invasive-species-eradication-spec.d.ts +0 -1
- package/test-export/invasive-species-eradication-spec.js +0 -25
- package/test-export/line-transect-spec.d.ts +0 -1
- package/test-export/line-transect-spec.js +0 -121
- package/test-export/mobile-form-spec.d.ts +0 -1
- package/test-export/mobile-form-spec.js +0 -84
- package/test-export/nafi-spec.d.ts +0 -1
- package/test-export/nafi-spec.js +0 -85
- package/test-export/select-widget-spec.d.ts +0 -1
- package/test-export/select-widget-spec.js +0 -68
- package/test-export/single-item-array-field-spec.d.ts +0 -1
- package/test-export/single-item-array-field-spec.js +0 -92
- package/test-export/syke-butterfly-spec.d.ts +0 -1
- package/test-export/syke-butterfly-spec.js +0 -163
- package/test-export/transaction-form-spec.d.ts +0 -1
- package/test-export/transaction-form-spec.js +0 -63
- package/test-export/trip-report-autosuggest-spec.d.ts +0 -1
- package/test-export/trip-report-autosuggest-spec.js +0 -272
- package/test-export/trip-report-spec.d.ts +0 -1
- package/test-export/trip-report-spec.js +0 -456
- package/test-export/unit-list-shorthand-array-field-spec.d.ts +0 -1
- package/test-export/unit-list-shorthand-array-field-spec.js +0 -71
- package/test-export/validation-spec.d.ts +0 -1
- package/test-export/validation-spec.js +0 -336
- package/test-export/water-bird-spec.d.ts +0 -1
- package/test-export/water-bird-spec.js +0 -30
- package/test-export/wbc-spec.d.ts +0 -1
- 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
|
+
[1m[0m[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
2
|
+
[38;5;11mmodified: src/components/components.js
|
|
3
|
+
[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
4
|
+
[36m[1m[38;5;13m@ src/components/components.js:360 @[1m[1m[38;5;146m export class Stretch extends React.Component {[0m
|
|
5
|
+
}[m
|
|
6
|
+
[m
|
|
7
|
+
invalidate = (callback) => {[m
|
|
8
|
+
[32m[m [32mconsole.log('invalidate');[m
|
|
9
|
+
this.update(this.getState(), callback);[m
|
|
10
|
+
}[m
|
|
11
|
+
[m
|
|
12
|
+
[1m[0m[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
13
|
+
[38;5;11mmodified: src/components/fields/EnumRangeArrayField.js
|
|
14
|
+
[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
15
|
+
[36m[1m[38;5;13m@ src/components/fields/EnumRangeArrayField.js:8 @[1m[1m[38;5;146m import BaseComponent from "../BaseComponent";[0m
|
|
16
|
+
import { getUiOptions } from "../../utils";[m
|
|
17
|
+
import { Autosuggest } from "../widgets/AutosuggestWidget";[m
|
|
18
|
+
import { TagInputComponent } from "./TagArrayField";[m
|
|
19
|
+
[31mconst equals = require("deep-equal");[m
|
|
20
|
+
[m
|
|
21
|
+
@BaseComponent[m
|
|
22
|
+
export default class EnumRangeArrayField extends React.Component {[m
|
|
23
|
+
[36m[1m[38;5;13m@ src/components/fields/EnumRangeArrayField.js:30 @[1m[1m[38;5;146m export default class EnumRangeArrayField extends React.Component {[0m
|
|
24
|
+
this.state = {value: ""};[m
|
|
25
|
+
}[m
|
|
26
|
+
[m
|
|
27
|
+
[31m UNSAFE_componentWillReceiveProps(props) {[m
|
|
28
|
+
[31m if (!equals(props.formData, this.props.formData)) {[m
|
|
29
|
+
[31m this.props.formContext.services.customEvents.send(props.idSchema.$id, "resize");[m
|
|
30
|
+
[31m }[m
|
|
31
|
+
[31m }[m
|
|
32
|
+
[7m[31m [m
|
|
33
|
+
setRef = (elem) => {[m
|
|
34
|
+
this.autosuggestRef = elem;[m
|
|
35
|
+
}[m
|
|
36
|
+
[1m[0m[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
37
|
+
[38;5;11mmodified: src/components/fields/ImageArrayField.tsx
|
|
38
|
+
[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
39
|
+
[36m[1m[38;5;13m@ src/components/fields/ImageArrayField.tsx:209 @[1m[1m[38;5;146m export function MediaArrayField<LFC extends Constructor<React.Component<FieldPro[0m
|
|
40
|
+
this.mounted = false;[m
|
|
41
|
+
}[m
|
|
42
|
+
[m
|
|
43
|
+
[31m componentDidUpdate(prevProps: FieldProps, prevState: MediaArrayState) {[m
|
|
44
|
+
[31m const getCount = (_props: FieldProps, _state: MediaArrayState) => ((_props.formData || []).length + (_state.tmpMedias || []).length);[m
|
|
45
|
+
[7m[31m [m
|
|
46
|
+
[31m if (getCount(prevProps, prevState) !== getCount(this.props, this.state)) {[m
|
|
47
|
+
[31m this.props.formContext.services.customEvents.send(this.props.idSchema.$id, "resize");[m
|
|
48
|
+
[31m }[m
|
|
49
|
+
[31m }[m
|
|
50
|
+
[7m[31m [m
|
|
51
|
+
onDragEnter = () => {this.setState({dragging: true});};[m
|
|
52
|
+
[m
|
|
53
|
+
onDragLeave = () => {this.setState({dragging: false});};[m
|
|
54
|
+
[1m[0m[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
55
|
+
[38;5;11mmodified: src/components/fields/MapArrayField.js
|
|
56
|
+
[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
57
|
+
[36m[1m[38;5;13m@ src/components/fields/MapArrayField.js:1159 @[1m[1m[38;5;146m class _MapArrayField extends ComposedComponent { // eslint-disable-line indent[0m
|
|
58
|
+
this._tileLayerNameOnNextTick = tileLayerOptions;[m
|
|
59
|
+
this._tileLayerNameOnNextTickCallback = callback;[m
|
|
60
|
+
};[m
|
|
61
|
+
[31m this._resizeEventHandler = () => {[m
|
|
62
|
+
[31m this.refs.stretch.invalidate();[m
|
|
63
|
+
[31m };[m
|
|
64
|
+
this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "activeIdx", this._setActiveEventHandler);[m
|
|
65
|
+
this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "zoomToData", this._zoomToDataEventHandler);[m
|
|
66
|
+
this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "tileLayers", this._tileLayersEventHandler);[m
|
|
67
|
+
[31m this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "resize", this._resizeEventHandler);[m
|
|
68
|
+
[m
|
|
69
|
+
if (this.state.activeIdx !== undefined) {[m
|
|
70
|
+
this.afterActiveChange(this.state.activeIdx, !!"initial call");[m
|
|
71
|
+
[36m[1m[38;5;13m@ src/components/fields/MapArrayField.js:1179 @[1m[1m[38;5;146m class _MapArrayField extends ComposedComponent { // eslint-disable-line indent[0m
|
|
72
|
+
this.props.formContext.services.customEvents.remove(this.props.idSchema.$id, "activeIdx", this._setActiveEventHandler);[m
|
|
73
|
+
this.props.formContext.services.customEvents.remove(this.props.idSchema.$id, "zoomToData", this._zoomToDataEventHandler);[m
|
|
74
|
+
this.props.formContext.services.customEvents.remove(this.props.idSchema.$id, "tileLayers", this._tileLayersEventHandler);[m
|
|
75
|
+
[31m this.props.formContext.services.customEvents.remove(this.props.idSchema.$id, "resize", this._resizeEventHandler);[m
|
|
76
|
+
}[m
|
|
77
|
+
[m
|
|
78
|
+
componentDidUpdate(...params) {[m
|
|
79
|
+
[1m[0m[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
80
|
+
[38;5;11mmodified: src/components/fields/SchemaField.js
|
|
81
|
+
[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
82
|
+
[36m[1m[38;5;13m@ src/components/fields/SchemaField.js:112 @[1m[1m[38;5;146m export default class _SchemaField extends React.Component {[0m
|
|
83
|
+
};[m
|
|
84
|
+
}[m
|
|
85
|
+
[m
|
|
86
|
+
[31m componentDidUpdate(prevProps) {[m
|
|
87
|
+
[31m if (!deepEquals(prevProps.errorSchema, this.props.errorSchema)) {[m
|
|
88
|
+
[31m this.props.registry.formContext.services.customEvents.send(this.props.idSchema.$id, "resize");[m
|
|
89
|
+
[31m }[m
|
|
90
|
+
[31m }[m
|
|
91
|
+
[7m[31m [m
|
|
92
|
+
render() {[m
|
|
93
|
+
const props = this.functionOutputProps || this.props;[m
|
|
94
|
+
let {schema, uiSchema = {}, formContext, registry, ..._props} = props; // eslint-disable-line @typescript-eslint/no-unused-vars[m
|
|
95
|
+
[1m[0m[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
96
|
+
[38;5;11mmodified: src/components/fields/ScopeField.js
|
|
97
|
+
[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
98
|
+
[36m[1m[38;5;13m@ src/components/fields/ScopeField.js:138 @[1m[1m[38;5;146m export default class ScopeField extends React.Component {[0m
|
|
99
|
+
}[m
|
|
100
|
+
if (!equals(prevState.fieldsToShow, this.state.fieldsToShow)) {[m
|
|
101
|
+
this.props.formContext.utils.syncScroll();[m
|
|
102
|
+
[31m this.props.formContext.services.customEvents.send(this.props.idSchema.$id, "resize");[m
|
|
103
|
+
}[m
|
|
104
|
+
}[m
|
|
105
|
+
[m
|
|
106
|
+
[1m[0m[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
107
|
+
[38;5;11mmodified: src/components/fields/SingleActiveArrayField.js
|
|
108
|
+
[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
109
|
+
[36m[1m[38;5;13m@ src/components/fields/SingleActiveArrayField.js:678 @[1m[1m[38;5;146m class TableArrayFieldTemplate extends React.Component {[0m
|
|
110
|
+
super(props);[m
|
|
111
|
+
this.state = {};[m
|
|
112
|
+
this.itemElems = [];[m
|
|
113
|
+
[32m[m [32mthis.resizeObserver = new ResizeObserver(this.onResize);[m
|
|
114
|
+
}[m
|
|
115
|
+
[m
|
|
116
|
+
[31m onResize = ([7mdata, callback[27m) => {[m
|
|
117
|
+
[31m this.updateLayout([7mnull, callback[27m);[m
|
|
118
|
+
[32m[m [32monResize = ([7m[27m) => {[m
|
|
119
|
+
[32m[m [32mthis.updateLayout([7m[27m);[m
|
|
120
|
+
}[m
|
|
121
|
+
[m
|
|
122
|
+
componentDidMount() {[m
|
|
123
|
+
[31m this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "resize", this.onResize);[m
|
|
124
|
+
this._updateRenderingMode = () => this.updateRenderingMode();[m
|
|
125
|
+
window.addEventListener("resize", this._updateRenderingMode);[m
|
|
126
|
+
this.updateRenderingMode();[m
|
|
127
|
+
[36m[1m[38;5;13m@ src/components/fields/SingleActiveArrayField.js:694 @[1m[1m[38;5;146m class TableArrayFieldTemplate extends React.Component {[0m
|
|
128
|
+
[m
|
|
129
|
+
componentWillUnmount() {[m
|
|
130
|
+
window.removeEventListener("resize", this._updateRenderingMode);[m
|
|
131
|
+
[31m this.[7mprops.formContext.services.customEvents.remove(this.props.idSchema.$id, "resize", this.onResize[27m);[m
|
|
132
|
+
[32m[m [32mthis.[7mresizeObserver.disconnect([27m);[m
|
|
133
|
+
}[m
|
|
134
|
+
[m
|
|
135
|
+
componentDidUpdate(prevProps, prevState) {[m
|
|
136
|
+
[36m[1m[38;5;13m@ src/components/fields/SingleActiveArrayField.js:726 @[1m[1m[38;5;146m class TableArrayFieldTemplate extends React.Component {[0m
|
|
137
|
+
if (tHeadHeight) this.prevTHeadHeight = tHeadHeight;[m
|
|
138
|
+
this._prevCheckedLength = this.props.items.length;[m
|
|
139
|
+
}[m
|
|
140
|
+
[7m[31m [m
|
|
141
|
+
[31m if (this.props.idSchema.$id !== prevProps.idSchema.$id) {[m
|
|
142
|
+
[31m prevProps.formContext.services.customEvents.remove(prevProps.idSchema.$id, "resize", this.onResize);[m
|
|
143
|
+
[31m this.props.formContext.services.customEvents.add(this.props.idSchema.$id, "resize", this.onResize);[m
|
|
144
|
+
[31m this.updateLayout();[m
|
|
145
|
+
[31m }[m
|
|
146
|
+
}[m
|
|
147
|
+
[m
|
|
148
|
+
// Sets state.normalRendering on if screen is too small for table layout.[m
|
|
149
|
+
[36m[1m[38;5;13m@ src/components/fields/SingleActiveArrayField.js:775 @[1m[1m[38;5;146m class TableArrayFieldTemplate extends React.Component {[0m
|
|
150
|
+
[m
|
|
151
|
+
setActiveRef = (elem) => {[m
|
|
152
|
+
this.activeElem = elem;[m
|
|
153
|
+
[32m[m [32mthis.activeElem && this.resizeObserver.observe(this.activeElem);[m
|
|
154
|
+
}[m
|
|
155
|
+
[m
|
|
156
|
+
setTHeadRef = (elem) => {[m
|
|
157
|
+
[1m[0m[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
158
|
+
[38;5;11mmodified: src/components/fields/TagArrayField.js
|
|
159
|
+
[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
160
|
+
[36m[1m[38;5;13m@ src/components/fields/TagArrayField.js:6 @[1m[1m[38;5;146m import { findDOMNode } from "react-dom";[0m
|
|
161
|
+
import * as PropTypes from "prop-types";[m
|
|
162
|
+
import { isEmptyString, getUiOptions, triggerParentComponent } from "../../utils";[m
|
|
163
|
+
import BaseComponent from "../BaseComponent";[m
|
|
164
|
+
[31mconst equals = require("deep-equal");[m
|
|
165
|
+
[m
|
|
166
|
+
@BaseComponent[m
|
|
167
|
+
export default class TagArrayField extends React.Component {[m
|
|
168
|
+
[36m[1m[38;5;13m@ src/components/fields/TagArrayField.js:43 @[1m[1m[38;5;146m export class TagInputComponent extends React.Component {[0m
|
|
169
|
+
this.setState(this.getStateFromProps(props));[m
|
|
170
|
+
}[m
|
|
171
|
+
[m
|
|
172
|
+
[31m componentDidUpdate(prevProps) {[m
|
|
173
|
+
[31m if (!equals(prevProps.formData, this.props.formData)) {[m
|
|
174
|
+
[31m this.props.formContext.services.customEvents.send(this.props.idSchema.$id, "resize");[m
|
|
175
|
+
[31m }[m
|
|
176
|
+
[31m }[m
|
|
177
|
+
[7m[31m [m
|
|
178
|
+
getStateFromProps = ({value}) => {[m
|
|
179
|
+
return {value};[m
|
|
180
|
+
}[m
|
|
181
|
+
[1m[0m[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
182
|
+
[38;5;11mmodified: src/components/templates/ArrayFieldTemplate.js
|
|
183
|
+
[38;5;11m───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[0m
|
|
184
|
+
[36m[1m[38;5;13m@ src/components/templates/ArrayFieldTemplate.js:13 @[1m[1m[38;5;146m import { getTemplate } from "@rjsf/utils";[0m
|
|
185
|
+
function onAdd(e, props) {[m
|
|
186
|
+
if (!canAdd(props)) return;[m
|
|
187
|
+
props.onAddClick(e);[m
|
|
188
|
+
[31m setTimeout(() => props.formContext.services.customEvents.send(props.idSchema.$id, "resize"));[m
|
|
189
|
+
}[m
|
|
190
|
+
[m
|
|
191
|
+
export const onDelete = (item, props) => (e) => {[m
|
|
192
|
+
item.onDropIndexClick(item.index)(e);[m
|
|
193
|
+
[31m setTimeout(() => props.formContext.services.customEvents.send(props.idSchema.$id, "resize"));[m
|
|
194
|
+
};[m
|
|
195
|
+
[m
|
|
196
|
+
export function beforeAdd(props) {[m
|
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 {
|
|
1
|
+
import { Locator, Page } from "@playwright/test";
|
|
2
2
|
import { JSONSchema7 } from "json-schema";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export declare const
|
|
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
|
|
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
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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:
|
|
47
|
-
|
|
48
|
-
$input:
|
|
49
|
-
}
|
|
50
|
-
interface
|
|
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
|
-
|
|
62
|
-
|
|
63
|
-
constructor(
|
|
64
|
-
|
|
65
|
-
e
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
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
|
-
|
|
90
|
-
$panel:
|
|
51
|
+
$all: Locator;
|
|
52
|
+
$panel: Locator;
|
|
91
53
|
};
|
|
92
54
|
errors: {
|
|
93
|
-
|
|
94
|
-
$panel:
|
|
55
|
+
$all: Locator;
|
|
56
|
+
$panel: Locator;
|
|
95
57
|
};
|
|
96
58
|
warnings: {
|
|
97
|
-
|
|
98
|
-
$panel:
|
|
59
|
+
$all: Locator;
|
|
60
|
+
$panel: Locator;
|
|
99
61
|
};
|
|
100
62
|
failedJobs: {
|
|
101
|
-
$container:
|
|
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:
|
|
121
|
-
|
|
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
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
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
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
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
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
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 {};
|