Skip to content

Commit

Permalink
Resolved surveyjs/service#1834 - There is no documentation for survey…
Browse files Browse the repository at this point in the history
….fitToContainer property - updated default (#7718)

* Resolved surveyjs/service#1834 - There is no documentation for survey.fitToContainer property - updated default

* Work for surveyjs/service#1834 - ipdated etalon

* work for surveyjs/service#1834 (ranking issue proposal)

* work for the surveyjs/service#1834

* Work for surveyjs/service#1834 - removed duplicated progress vr-tests

* Work for surveyjs/service#1834 - fixed u-test

* Updated etalons

---------

Co-authored-by: tsv2013 <tsv2013@noreply.github.com>
Co-authored-by: dmitrykurmanov <kurmanov.work@gmail.com>
  • Loading branch information
3 people committed Feb 9, 2024
1 parent 69b2346 commit 306327f
Show file tree
Hide file tree
Showing 9 changed files with 25 additions and 68 deletions.
4 changes: 2 additions & 2 deletions src/dragdrop/core.ts
Expand Up @@ -32,15 +32,15 @@ export abstract class DragDropCore<T> implements IDragDropEngine {
return `[data-sv-drop-target-${this.draggedElementType}]`;
}
protected get survey(): SurveyModel {
return this.surveyValue || this.creator.survey;
return this.surveyValue || this.creator?.survey;
}

public prevDropTarget: any = null;
protected allowDropHere = false;

protected domAdapter: IDragDropDOMAdapter;
constructor(private surveyValue?: ISurvey, private creator?: any, longTap?: boolean, domAdapter?: IDragDropDOMAdapter) {
this.domAdapter = domAdapter || new DragDropDOMAdapter(this, longTap);
this.domAdapter = domAdapter || new DragDropDOMAdapter(this, longTap, this.survey?.fitToContainer);
}

public startDrag(event: PointerEvent, draggedElement: any, parentElement?: any, draggedElementNode?: HTMLElement, preventSaveTargetNode: boolean = false): void {
Expand Down
11 changes: 8 additions & 3 deletions src/dragdrop/dom-adapter.ts
Expand Up @@ -40,7 +40,7 @@ export class DragDropDOMAdapter implements IDragDropDOMAdapter {
private savedTargetNodeIndex: any;
private scrollIntervalId: number = null;

constructor(private dd: IDragDropEngine, private longTap: boolean = true) {}
constructor(private dd: IDragDropEngine, private longTap: boolean = true, private fitToContainer:boolean = false) {}

private get rootElement() {
if(isShadowDOM(settings.environment.root)) {
Expand Down Expand Up @@ -124,8 +124,13 @@ export class DragDropDOMAdapter implements IDragDropDOMAdapter {
event.stopPropagation();
}
private moveShortcutElement(event: PointerEvent) {
const rootElementX= this.rootElement.getBoundingClientRect().x;
const rootElementY = this.rootElement.getBoundingClientRect().y;
let rootElementX= this.rootElement.getBoundingClientRect().x;
let rootElementY = this.rootElement.getBoundingClientRect().y;

if (!!this.fitToContainer) {
rootElementX = 0;
rootElementY = 0;
}

this.doScroll(event.clientY, event.clientX);

Expand Down
2 changes: 1 addition & 1 deletion src/survey.ts
Expand Up @@ -7950,7 +7950,7 @@ Serializer.addClass("survey", [
choices: ["auto", "static", "responsive"],
},
{ name: "width", visibleIf: (obj: any) => { return obj.widthMode === "static"; } },
{ name: "fitToContainer:boolean", default: false },
{ name: "fitToContainer:boolean", default: true },
{ name: "headerView", default: "basic", choices: ["basic", "advanced"], visible: false },
{ name: "backgroundImage:file", visible: false },
{ name: "backgroundImageFit", default: "cover", choices: ["auto", "contain", "cover"], visible: false },
Expand Down
@@ -1,2 +1,2 @@
<div style="background-attachment:fixed; background-image:url(&quot;&quot;); background-size:cover; opacity:0.4;">
<div style="background-image:url(&quot;&quot;); background-size:cover; opacity:0.4;">
</div>
15 changes: 13 additions & 2 deletions tests/surveytests.ts
Expand Up @@ -16012,12 +16012,23 @@ QUnit.test("Check survey getRootCss function - defaultV2Css", function (assert)
]
});
survey.css = defaultV2Css;
assert.equal(survey.getRootCss(), "sd-root-modern sd-root-modern--full-container");

survey.fitToContainer = false;
assert.equal(survey.getRootCss(), "sd-root-modern");

survey.setIsMobile(true);
survey.fitToContainer = true;
assert.equal(survey.getRootCss(), "sd-root-modern sd-root-modern--mobile sd-root-modern--full-container");

survey.fitToContainer = false;
assert.equal(survey.getRootCss(), "sd-root-modern sd-root-modern--mobile");

survey.mode = "display";
survey.fitToContainer = true;
assert.equal(survey.getRootCss(), "sd-root-modern sd-root-modern--mobile sd-root--readonly sd-root-modern--full-container");

survey.fitToContainer = false;
assert.equal(survey.getRootCss(), "sd-root-modern sd-root-modern--mobile sd-root--readonly");

survey.mode = "edit";
Expand Down Expand Up @@ -19290,7 +19301,7 @@ QUnit.test("Display mode in design time", function (assert) {
assert.equal(survey.css.rootReadOnly, "sd-root--readonly");
assert.equal(survey.mode, "edit");
assert.equal(survey.isDisplayMode, false);
assert.equal(survey.getRootCss(), "sd-root-modern");
assert.equal(survey.getRootCss(), "sd-root-modern sd-root-modern--full-container");

survey.mode = "display";
assert.equal(survey.mode, "display");
Expand All @@ -19300,5 +19311,5 @@ QUnit.test("Display mode in design time", function (assert) {
survey.setDesignMode(true);
assert.equal(survey.mode, "display");
assert.equal(survey.isDisplayMode, false);
assert.equal(survey.getRootCss(), "sd-root-modern");
assert.equal(survey.getRootCss(), "sd-root-modern sd-root-modern--full-container");
});
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
59 changes: 0 additions & 59 deletions visualRegressionTests/tests/defaultV2/survey.ts
Expand Up @@ -18,65 +18,6 @@ const insertDiv = ClientFunction(() => {

const theme = "defaultV2";

const json = {
focusFirstQuestionAutomatic: true,
"title": "Minimum data reporting form – for suspected and probable cases of COVID-19",
"pages": [{
"name": "page1",
"navigationTitle": "Sign In",
"navigationDescription": "... to continue purchasing.",
"elements": [
{
"name": "q1",
type: "text"
}
]
}, {
"name": "page2",
"navigationTitle": "Shipping",
"title": "Shipping",
"navigationDescription": "Enter shipping information.",
"elements": [
{
"type": "radiogroup",
"name": "q1",
"title": "Select a shipping method.",
"choices": ["FedEx", "DHL", "USP", "In-Store Pickup"]
},
]
}, {
"name": "page3",
"navigationTitle": "Payment",
"navigationDescription": "Select a payment method.",
"elements": [
{
"name": "q1",
type: "text"
}
]
}, {
"name": "page4",
"navigationTitle": "Gift Options",
"navigationDescription": "Choose your gift.",
"elements": [
{
"name": "q1",
type: "text"
}
]
}, {
"name": "page5",
"navigationTitle": "Place Order",
"navigationDescription": "Finish your purchasing.",
"elements": [{
"name": "q1",
type: "text"
}]
}],
"showProgressBar": "top",
"progressBarType": "buttons"
};

frameworks.forEach(framework => {
fixture`${framework} ${title} ${theme}`
.page`${url_test}${theme}/${framework}`
Expand Down

0 comments on commit 306327f

Please sign in to comment.