Skip to content

Commit

Permalink
Merge pull request #7270 from surveyjs/bug/C4830-image-picker-item-setup
Browse files Browse the repository at this point in the history
Fixed surveyjs/survey-creator#4830 - Image Picker - Non-existing items appear on a design surface
  • Loading branch information
OlgaLarina authored Nov 1, 2023
2 parents f97d78e + baa9389 commit 8a8fd4f
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 5 deletions.
2 changes: 1 addition & 1 deletion src/knockout/templates/question-imagepicker.html
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@
<!-- ko if: ($data.locImageLink.koRenderedHtml() && !$data.contentNotLoaded && question.contentMode === "video") -->
<video controls data-bind="css: question.cssClasses.image, attr: { src: $data.locImageLink.koRenderedHtml, width: question.renderedImageWidth, height: question.renderedImageHeight }, style: { objectFit: question.imageFit }, event: { loadedmetadata: question.onContentLoaded, error: $data.onErrorHandler }"></video>
<!-- /ko -->
<!-- ko if: !$data.imageLink || $data.contentNotLoaded -->
<!-- ko if: (!$data.locImageLink.koRenderedHtml() || $data.contentNotLoaded) -->
<div data-bind="css: question.cssClasses.itemNoImage, style: { width: question.renderedImageWidth, height: question.renderedImageHeight, objectFit: question.imageFit}">
<!-- ko component: { name: 'sv-svg-icon', params: { css: question.cssClasses.itemNoImageSvgIcon, iconName: question.cssClasses.itemNoImageSvgIconId, size: 48 } } --><!-- /ko -->
</div>
Expand Down
10 changes: 6 additions & 4 deletions src/question_imagepicker.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,8 @@ export class ImageItemValue extends ItemValue implements ILocalizableOwner {
}
public set imageLink(val: string) {
this.setLocalizableStringText("imageLink", val);
this.imageNotLoaded = false;
this.videoNotLoaded = false;
}
private aspectRatio: number;

Expand Down Expand Up @@ -59,7 +61,7 @@ export class ImageItemValue extends ItemValue implements ILocalizableOwner {
}

public set contentNotLoaded(val: boolean) {
if(this.locOwner instanceof QuestionImagePickerModel && this.locOwner.contentMode == "video") {
if (this.locOwner instanceof QuestionImagePickerModel && this.locOwner.contentMode == "video") {
this.videoNotLoaded = val;
} else {
this.imageNotLoaded = val;
Expand Down Expand Up @@ -401,7 +403,7 @@ export class QuestionImagePickerModel extends QuestionCheckboxBase {
}

public triggerResponsiveness(hard: boolean = true): void {
if(hard && this.reCalcGapBetweenItemsCallback) {
if (hard && this.reCalcGapBetweenItemsCallback) {
this.reCalcGapBetweenItemsCallback();
}
super.triggerResponsiveness(hard);
Expand All @@ -412,8 +414,8 @@ export class QuestionImagePickerModel extends QuestionCheckboxBase {
public afterRender(el: HTMLElement): void {
super.afterRender(el);
const selector = this.getObservedElementSelector();
const observedElement = el && selector ? el.querySelector(selector): undefined;
if(!!observedElement) {
const observedElement = el && selector ? el.querySelector(selector) : undefined;
if (!!observedElement) {
this.reCalcGapBetweenItemsCallback = () => {
this.gapBetweenItems = Math.ceil(Number.parseFloat(window.getComputedStyle(observedElement).gap)) || 16;
};
Expand Down

0 comments on commit 8a8fd4f

Please sign in to comment.