Skip to content

Commit

Permalink
fix: keep "touch" and "dirty" states of gv-schema-form when using pol…
Browse files Browse the repository at this point in the history
…icy documentation
  • Loading branch information
Okhelifi committed Jul 1, 2024
1 parent b81712f commit b145771
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 7 deletions.
12 changes: 6 additions & 6 deletions src/organisms/gv-schema-form/gv-schema-form.js
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ export class GvSchemaForm extends LitElement {
validateOnRender: { type: Boolean, attribute: 'validate-on-render' },
_validatorResults: { type: Object },
skeleton: { type: Boolean, reflect: true },
_touch: { type: Boolean },
touch: { type: Boolean },
readonly: { type: Boolean, reflect: true },
scrollable: { type: Boolean, reflect: true },
groups: { type: Array },
Expand All @@ -71,7 +71,7 @@ export class GvSchemaForm extends LitElement {
this.submitLabel = 'Ok';
this.hasHeader = false;
this.hasFooter = false;
this._touch = false;
this.touch = false;
this._validator = new Validator();
this._validatorResults = {};
this._ignoreProperties = [];
Expand Down Expand Up @@ -109,7 +109,7 @@ export class GvSchemaForm extends LitElement {

reset(values = null) {
this._values = deepClone(values || this._initialValues);
this._touch = false;
this.touch = false;
this._setDirty(false);
this.getControls().forEach((s) => {
s.requestUpdate();
Expand Down Expand Up @@ -141,7 +141,7 @@ export class GvSchemaForm extends LitElement {
if (this.isValid()) {
this._initialValues = deepClone(this._values);
this.dirty = false;
this._touch = false;
this.touch = false;
dispatchCustomEvent(this, 'submit', { values: this._values, validatorResults });
} else {
dispatchCustomEvent(this, 'error', { values: this._values, validatorResults });
Expand All @@ -153,7 +153,7 @@ export class GvSchemaForm extends LitElement {
}

_setTouch(touch = true) {
this._touch = !!touch;
this.touch = !!touch;
}

confirm(force = false) {
Expand Down Expand Up @@ -489,7 +489,7 @@ export class GvSchemaForm extends LitElement {
}

isTouch() {
return this._touch || (this.dirty && this.validateOnRender);
return this.touch || (this.dirty && this.validateOnRender);
}

canSubmit() {
Expand Down
2 changes: 1 addition & 1 deletion src/organisms/gv-schema-form/gv-schema-form.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -324,7 +324,7 @@ describe('S C H E M A F O R M', () => {
component.validate();

component.updateComplete.then(() => {
component._touch = true;
component.touch = true;
expect(component.canSubmit()).toBeTruthy();
done();
});
Expand Down
9 changes: 9 additions & 0 deletions src/policy-studio/gv-policy-studio/gv-policy-studio.js
Original file line number Diff line number Diff line change
Expand Up @@ -1093,8 +1093,15 @@ export class GvPolicyStudio extends KeyboardElement(LitElement) {
}

_renderFlowStepForm(readonlyMode) {
const flowStepForm = this._getFlowStepForm();
const values = this._currentFlowStep._values || this._currentFlowStep._initialValues;

// eslint-disable-next-line no-console
console.log('flowStepForm touch', flowStepForm?.touch);

// eslint-disable-next-line no-console
console.log('flowStepForm dirty', flowStepForm?.dirty);

const groups = [
{ items: ['commonDescription', 'commonCondition'] },
{
Expand All @@ -1110,6 +1117,8 @@ export class GvPolicyStudio extends KeyboardElement(LitElement) {
.id="${FLOW_STEP_FORM_ID}"
.schema="${this._flowStepSchema}"
.icon="design:edit"
.touch="${flowStepForm?.touch}"
.dirty="${flowStepForm?._dirty}"
has-header
validate-on-render
.values="${values}"
Expand Down

0 comments on commit b145771

Please sign in to comment.