Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Reusable DataCard components #1008

Merged
merged 57 commits into from
Feb 13, 2024
Merged
Show file tree
Hide file tree
Changes from 42 commits
Commits
Show all changes
57 commits
Select commit Hold shift + click to select a range
ee8532a
Add datacard components
tschumpr Feb 1, 2024
152a738
Fix imports
tschumpr Feb 2, 2024
735642d
Apply completion style to hydro
tschumpr Feb 2, 2024
6e6b973
Condition is required
tschumpr Feb 2, 2024
524d852
Clean up code
tschumpr Feb 2, 2024
ef8e8f4
Use completionContentTab for Hydro
tschumpr Feb 2, 2024
4a3db68
Merge branch 'main' into reusable-datacard-components
tschumpr Feb 2, 2024
6c8abd1
Use common styling
tschumpr Feb 2, 2024
01bf75e
Fix test
tschumpr Feb 2, 2024
fb01504
Move button to common file
tschumpr Feb 2, 2024
65fb54e
Unify dataCard logic
tschumpr Feb 2, 2024
d4093de
Fix cypress label
tschumpr Feb 2, 2024
6a1b7e4
Fix test
tschumpr Feb 5, 2024
686c6e5
Fix parameter unit endAdornment
tschumpr Feb 5, 2024
c33c828
Remove temp card on cancel
tschumpr Feb 5, 2024
101a7f1
Merge branch 'main' into reusable-datacard-components
tschumpr Feb 5, 2024
b3edf7c
Use dataCard and multiSelect form
tschumpr Feb 6, 2024
922fe68
Merge remote-tracking branch 'origin/reusable-datacard-components' in…
tschumpr Feb 6, 2024
6d05256
Update parameter unit onchange
tschumpr Feb 7, 2024
42c1843
Fix data-cy labels
tschumpr Feb 7, 2024
4491cb6
Only show supported parameters
tschumpr Feb 7, 2024
9031bb0
Merge branch 'main' into reusable-datacard-components
tschumpr Feb 7, 2024
c41ab56
Merge branch 'reusable-datacard-components' into refactor-hydrotest
tschumpr Feb 7, 2024
8d87b84
Show correct value
tschumpr Feb 7, 2024
2c35269
Re-use code
tschumpr Feb 7, 2024
e3fc0e2
Check if codelist entries are arrays
tschumpr Feb 7, 2024
45a0cd0
Update test
tschumpr Feb 7, 2024
e493500
Fix disabled check
tschumpr Feb 7, 2024
2d902ec
Update changelog
tschumpr Feb 7, 2024
83efb8f
Fix console warning
tschumpr Feb 7, 2024
f53f6ac
Simplify code
tschumpr Feb 7, 2024
2052ed9
Remove unused code
tschumpr Feb 7, 2024
503c2e2
Merge branch 'main' into reusable-datacard-components
tschumpr Feb 7, 2024
66a39f9
Refactor hydrotest (#1012)
tschumpr Feb 12, 2024
f3efb9a
Merge branch 'main' into reusable-datacard-components
tschumpr Feb 12, 2024
6965038
Update cancel icon
tschumpr Feb 12, 2024
b3e9381
Set id if not defined in form
tschumpr Feb 12, 2024
9896035
Check casing after re-save
tschumpr Feb 12, 2024
0391b7b
Use tab hash for cy labels
tschumpr Feb 12, 2024
44f84d1
Reuse style
tschumpr Feb 12, 2024
23b9f39
Reuse style
tschumpr Feb 12, 2024
35a099d
Use error background color from theme
tschumpr Feb 12, 2024
7f7eb1b
Merge branch 'main' into reusable-datacard-components
tschumpr Feb 12, 2024
7ba51f2
Update labels to camel case
tschumpr Feb 12, 2024
09540f3
Set casingId for all hydrogeo modules
tschumpr Feb 12, 2024
6f31124
Merge branch 'reusable-datacard-components' into set-casing-id-on-resave
tschumpr Feb 12, 2024
540ebde
Fix label
tschumpr Feb 12, 2024
5b1e091
Set casingId on re-save (#1017)
tschumpr Feb 13, 2024
3fee60b
Use theme for styling
tschumpr Feb 13, 2024
8b2e367
Use same cancel icon in completion
tschumpr Feb 13, 2024
6315d20
Re-use icon button in completion
tschumpr Feb 13, 2024
c4ae24e
Use text buttons
tschumpr Feb 13, 2024
80d9bf7
Merge branch 'main' into reusable-datacard-components
tschumpr Feb 13, 2024
4b082b7
Re-use button components
tschumpr Feb 13, 2024
d1e8f25
Merge branch 'reusable-datacard-components' of github.com:geoadmin/su…
tschumpr Feb 13, 2024
9ea8cac
Fix test
tschumpr Feb 13, 2024
82a8265
Fix test
tschumpr Feb 13, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
- Use always _m MD_ as unit for borehole depth.
- Use reusable form components for hydrogeology.
- Replaced label for layer description quality.
- Use reusable card components for hydrogeology.

### Fixed

Expand Down
10 changes: 5 additions & 5 deletions src/client/cypress/e2e/editor/backfill.cy.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ describe("Backfill crud tests", () => {
startBoreholeEditing();

// select backfill tab
cy.get("[data-cy=completion-content-header-tab-Backfill]").click();
cy.get("[data-cy=completion-content-header-tab-backfill]").click();
cy.wait("@backfill_GET");

// add new backfill card
Expand All @@ -42,7 +42,7 @@ describe("Backfill crud tests", () => {
setSelect("materialId", 1);

// save backfill
cy.get('[data-cy="save-icon"]').click();
cy.get('[data-cy="save-button"]').click();

// check if backfill is saved
cy.contains("123456");
Expand All @@ -52,18 +52,18 @@ describe("Backfill crud tests", () => {
cy.contains("filter gravel");

// edit backfill
cy.get('[data-cy="edit-icon"]').click({ force: true });
cy.get('[data-cy="edit-button"]').click({ force: true });
cy.wait("@codelist_GET");

setInput("fromDepth", "222");

// close editing mask
cy.get('[data-cy="save-icon"]').click({ force: true });
cy.get('[data-cy="save-button"]').click({ force: true });
cy.contains("222");
cy.contains("inactive");

// delete backfill
cy.get('[data-cy="delete-icon"]').click({ force: true });
cy.get('[data-cy="delete-button"]').click({ force: true });
cy.contains("From depth").should("not.exist");
});
});
24 changes: 12 additions & 12 deletions src/client/cypress/e2e/editor/casing.cy.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ describe("Casing crud tests", () => {
startBoreholeEditing();

// select casing tab
cy.get("[data-cy=completion-content-header-tab-Casing]").click();
cy.get("[data-cy=completion-content-header-tab-casing]").click();
cy.wait("@casing_GET");

// create casing
Expand All @@ -49,7 +49,7 @@ describe("Casing crud tests", () => {
setInput("outerDiameter", "4");
setInput("notes", "Lorem.");

cy.get('[data-cy="save-icon"]').click();
cy.get('[data-cy="save-button"]').click();
cy.wait("@casing_GET");

evaluateDisplayValue("name", "casing-1");
Expand All @@ -59,25 +59,25 @@ describe("Casing crud tests", () => {
evaluateDisplayValue("materialCasingLayer", "steel");
evaluateDisplayValue("dateStartCasing", "01. Jan. 2021");
evaluateDisplayValue("dateFinishCasing", "02. Jan. 2021");
evaluateDisplayValue("casing_inner_diameter", "3");
evaluateDisplayValue("casing_outer_diameter", "4");
evaluateDisplayValue("casingInnerDiameter", "3");
evaluateDisplayValue("casingOuterDiameter", "4");
evaluateDisplayValue("notes", "Lorem.");

// update casing
cy.get('[data-cy="edit-icon"]').click();
cy.get('[data-cy="edit-button"]').click();
cy.wait("@codelist_GET");

setInput("name", "casing-1 updated");
setSelect("materialId", 5);

cy.get('[data-cy="save-icon"]').click({ force: true });
cy.get('[data-cy="save-button"]').click({ force: true });
evaluateDisplayValue("name", "casing-1 updated");
evaluateDisplayValue("materialCasingLayer", "concrete");
evaluateDisplayValue("casing_inner_diameter", "3");
evaluateDisplayValue("casingInnerDiameter", "3");

// delete casing
// Precondition: instrumentation with reference to casing
cy.get("[data-cy=completion-content-header-tab-Instrumentation]").click();
cy.get("[data-cy=completion-content-header-tab-instrumentation]").click();
cy.wait("@instrumentation_GET");

cy.get('[data-cy="addInstrument-button"]').click({ force: true });
Expand All @@ -90,16 +90,16 @@ describe("Casing crud tests", () => {
setSelect("kindId", 2);
setSelect("statusId", 1);
setSelect("casingId", 1);
cy.get('[data-cy="save-icon"]').click({ force: true });
cy.get('[data-cy="save-button"]').click({ force: true });

cy.get("[data-cy=completion-content-header-tab-Casing]").click();
cy.get("[data-cy=completion-content-header-tab-casing]").click();
cy.wait("@casing_GET");

cy.get('[data-cy="delete-icon"]').click({ force: true });
cy.get('[data-cy="delete-button"]').click({ force: true });
cy.wait("@casing_DELETE");
cy.contains("casing-1 updated").should("not.exist");

cy.get("[data-cy=completion-content-header-tab-Instrumentation]").click();
cy.get("[data-cy=completion-content-header-tab-instrumentation]").click();
cy.wait("@instrumentation_GET");
evaluateDisplayValue("casingName", "-");
});
Expand Down
4 changes: 2 additions & 2 deletions src/client/cypress/e2e/editor/completion.cy.js
Original file line number Diff line number Diff line change
Expand Up @@ -197,14 +197,14 @@ describe("completion crud tests", () => {
isTabSelected(1);

// check hash updates on tab switch
cy.get("[data-cy=completion-content-header-tab-Instrumentation]").click();
cy.get("[data-cy=completion-content-header-tab-instrumentation]").click();
cy.location().should(location => {
expect(location.pathname).to.eq(
`/editor/${boreholeId}/completion/${completion2Id}`,
);
expect(location.hash).to.eq("#instrumentation");
});
cy.get("[data-cy=completion-content-header-tab-Backfill]").click();
cy.get("[data-cy=completion-content-header-tab-backfill]").click();
cy.location().should(location => {
expect(location.pathname).to.eq(
`/editor/${boreholeId}/completion/${completion2Id}`,
Expand Down
10 changes: 5 additions & 5 deletions src/client/cypress/e2e/editor/fieldMeasurement.cy.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ describe("Tests for the field measurement editor.", () => {
cy.contains("span", "DE").click({ force: true });

// create field measurement
cy.get('[data-cy="add-fieldmeasurement-button"]').click({
cy.get('[data-cy="addFieldmeasurement-button"]').click({
force: true,
});
cy.wait("@fieldmeasurement_GET");
Expand All @@ -48,21 +48,21 @@ describe("Tests for the field measurement editor.", () => {
setInput("value", "77.1045");

// close editing mask
cy.get('[data-cy="close-icon"]').click({ force: true });
cy.get('[data-cy="save-button"]').click({ force: true });

//assert field measurementis displayed
evaluateDisplayValue("field_measurement_sample_type", "Schöpfprobe");
evaluateDisplayValue("parameter", "Sauerstoffsättigung");
evaluateDisplayValue("value", "77.1045 %");

// edit field measurement
cy.get('[data-cy="edit-icon"]').click({ force: true });
cy.get('[data-cy="edit-button"]').click({ force: true });
setSelect("sampleTypeId", 0);
cy.get('[data-cy="close-icon"]').click({ force: true });
cy.get('[data-cy="save-button"]').click({ force: true });
evaluateDisplayValue("field_measurement_sample_type", "Pumpprobe");

// delete field measurement
cy.get('[data-cy="delete-icon"]').click({ force: true });
cy.get('[data-cy="delete-button"]').click({ force: true });
cy.wait("@fieldmeasurement_DELETE");
cy.get("body").should("not.contain", "Pumpprobe");
});
Expand Down
10 changes: 5 additions & 5 deletions src/client/cypress/e2e/editor/groundwaterLevelMeasurement.cy.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ describe("Tests for the groundwater level measurement editor.", () => {
cy.contains("span", "DE").click({ force: true });

// create groundwater level measurement
cy.get('[data-cy="add-groundwaterlevelmeasurement-button"]').click({
cy.get('[data-cy="addGroundwaterLevelMeasurement-button"]').click({
force: true,
});
cy.wait("@groundwaterlevelmeasurement_GET");
Expand All @@ -48,21 +48,21 @@ describe("Tests for the groundwater level measurement editor.", () => {
setInput("levelMasl", "5.4567");

// close editing mask
cy.get('[data-cy="close-icon"]').click({ force: true });
cy.get('[data-cy="save-button"]').click({ force: true });

evaluateDisplayValue("gwlm_kind", "Manometer");
evaluateDisplayValue("gwlm_levelm", "789.12");
evaluateDisplayValue("gwlm_levelmasl", "5.4567");
evaluateDisplayValue("reliability", "fraglich");

// edit groundwater level measurement
cy.get('[data-cy="edit-icon"]').click({ force: true });
cy.get('[data-cy="edit-button"]').click({ force: true });
setSelect("kindId", 1);
cy.get('[data-cy="close-icon"]').click({ force: true });
cy.get('[data-cy="save-button"]').click({ force: true });
evaluateDisplayValue("gwlm_kind", "Drucksonde");

// delete groundwater level measurement
cy.get('[data-cy="delete-icon"]').click({ force: true });
cy.get('[data-cy="delete-button"]').click({ force: true });
cy.wait("@groundwaterlevelmeasurement_DELETE");
cy.get("body").should("not.contain", "Drucksonde");
});
Expand Down
148 changes: 70 additions & 78 deletions src/client/cypress/e2e/editor/hydrotest.cy.js
Original file line number Diff line number Diff line change
@@ -1,115 +1,107 @@
import {
createBorehole,
createStratigraphy,
createCompletion,
loginAsAdmin,
startBoreholeEditing,
} from "../helpers/testHelpers";
import {
evaluateDisplayValue,
setInput,
setSelect,
toggleMultiSelect,
evaluateMultiSelect,
} from "../helpers/formHelpers";

const openDropdown = dataCy => {
cy.get(`[data-cy="${dataCy}"]`)
.find('[role="combobox"]')
.click({ force: true });
};

const closeDropdown = () => {
cy.get("body").click();
};

const checkDropdownOptionsLength = length => {
cy.get('.MuiPaper-elevation [role="listbox"]').should($listbox => {
expect($listbox.find('[role="option"]')).to.have.length(length);
});
};

const selectDropdownOption = index => {
cy.get('.MuiPaper-elevation [role="listbox"]')
.find('[role="option"]')
.eq(index)
.click();
};

describe("Tests for the hydrotest editor.", () => {
beforeEach(function () {
// add new borehole
it("Creates, updates and deletes hydrotests", () => {
createBorehole({ "extended.original_name": "INTEADAL" })
.as("borehole_id")
.then(id => createStratigraphy(id, 3000))
.then(id => createCompletion("test hydrotest", id, 16000002, true))
.then(response => {
expect(response).to.have.property("status", 200);
});

// open hydrotest editor
cy.get("@borehole_id").then(id => {
loginAsAdmin();
cy.visit(`editor/${id}/hydrogeology/hydrotest`);
cy.visit(`/editor/${id}/completion`);
});
startBoreholeEditing();
cy.get("[data-cy=completion-content-header-tab-casing]").click();
cy.wait("@casing_GET");

// start editing session
cy.contains("a", "Start editing").click();
cy.wait("@edit_lock");
});
cy.get('[data-cy="addCasing-button"]').click({ force: true });
cy.wait("@codelist_GET");

setInput("name", "casing-1");
setInput("fromDepth", "0");
setInput("toDepth", "10");
setSelect("kindId", 2);
setSelect("materialId", 3);
setInput("dateStart", "2021-01-01");
setInput("dateFinish", "2021-01-02");
setInput("innerDiameter", "3");
setInput("outerDiameter", "4");

cy.get('[data-cy="save-button"]').click();
cy.wait("@casing_GET");

cy.get('[data-cy="hydrogeology-menu-item"]').click({ force: true });
cy.get('[data-cy="hydrotest-menu-item"]').click({ force: true });

it("Creates, updates and deletes hydrotests", () => {
// switch to german
cy.get('[data-cy="menu"]').click({ force: true });
cy.contains("span", "DE").click({ force: true });

// create hydrotest
cy.get('[data-cy="add-hydrotest-button"]').click({ force: true });
cy.wait("@hydrotest_GET");

// fill hydrotest kind dropdown
openDropdown("hydrotest-kind-select");
selectDropdownOption(2);
cy.wait("@codelist_GET");
closeDropdown();
cy.get('[data-cy="addHydrotest-button"]').click({ force: true });
cy.wait("@casing_GET");

setSelect("reliabilityId", 1);
setInput("startTime", "2012-11-14T12:06");
setSelect("casingId", 1);
toggleMultiSelect("testKindId", [2]);

// close editing mask
cy.get('[data-cy="save-icon"]').click({ force: true });

//assert hydrotest is displayed
cy.contains("Pump-/Injektionsversuch, variable Rate");
cy.get('[data-cy="save-button"]').click({ force: true });
cy.wait("@hydrotest_GET");
evaluateDisplayValue("reliability", "fraglich");
evaluateDisplayValue("casingName", "casing-1");
evaluateDisplayValue("testKind", "Pump-/Injektionsversuch, variable Rate");

// update hydrotest
cy.get('[data-cy="edit-button"]').click({ force: true });

toggleMultiSelect("flowDirectionId", [1, 0], 3);
toggleMultiSelect("evaluationMethodId", [1, 0], 4);

cy.get('[data-cy="addHydrotestResult-button"]').click({ force: true });
setSelect("hydrotestResults.0.parameterId", 0);

toggleMultiSelect("testKindId", [2]);
evaluateMultiSelect("flowDirectionId", []);
evaluateMultiSelect("evaluationMethodId", []);
cy.get('[data-cy="hydrotestResult-0"]').should("not.exist");

toggleMultiSelect("testKindId", [2]);
toggleMultiSelect("flowDirectionId", [1, 0], 3);
toggleMultiSelect("evaluationMethodId", [1, 0], 4);
cy.get('[data-cy="addHydrotestResult-button"]').click({ force: true });
setSelect("hydrotestResults.0.parameterId", 0, 6);
setInput("hydrotestResults.0.value", "10");
setInput("hydrotestResults.0.minValue", "5");
setInput("hydrotestResults.0.maxValue", "15");
cy.get('[data-cy="save-button"]').click({ force: true });
cy.wait("@hydrotest_GET");

cy.get('[data-cy="edit-icon"]').click({ force: true });

// check flow direction options
openDropdown("flow-direction-select");
checkDropdownOptionsLength(3);
selectDropdownOption(1);
selectDropdownOption(0);
closeDropdown();

// check evaluation method options
openDropdown("evaluation-method-select");
checkDropdownOptionsLength(4);
selectDropdownOption(1);
selectDropdownOption(0);
closeDropdown();

// check hydrotest parameter options
cy.get('[data-cy="add-hydrotestresult-button"]').click({ force: true });
openDropdown("parameter-select");
selectDropdownOption(0);
closeDropdown();

// check if everything is displayed
cy.get('[data-cy="save-hydrotest-result-icon"]').click({ force: true });
cy.get('[data-cy="save-icon"]').click({ force: true });
cy.contains("Pump-/Injektionsversuch, variable Rate");
cy.contains("Injektion, Entnahme");
cy.contains("stationär, instationär");
evaluateDisplayValue("testKind", "Pump-/Injektionsversuch, variable Rate");
evaluateDisplayValue("flowDirection", ["Entnahme", "Injektion"]);
evaluateDisplayValue("evaluationMethod", ["stationär", "instationär"]);
evaluateDisplayValue("hydrotestResult.0.parameter", "kf-Wert (gesättigt)");
evaluateDisplayValue("hydrotestResult.0.value", "10 m/s");
evaluateDisplayValue("hydrotestResult.0.minValue", "5 m/s");
evaluateDisplayValue("hydrotestResult.0.maxValue", "15 m/s");

// delete hydrotest
cy.get('[data-cy="delete-icon"]').click({ force: true });
cy.wait("@hydrotest_DELETE");
cy.get('[data-cy="delete-button"]').click({ force: true });
cy.wait("@hydrotest_GET");
cy.get("body").should(
"not.contain",
"Pump-/Injektionsversuch, variable Rate",
Expand Down
Loading
Loading