From aeeaa598930f83cedf1fcde453cb58644100731a Mon Sep 17 00:00:00 2001 From: Denis Anisimov Date: Thu, 9 Mar 2017 11:09:57 +0200 Subject: [PATCH] Use innerHTML property to set dynamic resource as an image For some reasons EDGE doesn't show svg image created from the server side. So instead of creating a real "object" element it's set as "innerHTML" property for its "fake" parent element. Fixes #184 --- .../demo/website/DynamicResourcesView.java | 21 ++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) diff --git a/demo-web-site/src/main/java/com/vaadin/hummingbird/demo/website/DynamicResourcesView.java b/demo-web-site/src/main/java/com/vaadin/hummingbird/demo/website/DynamicResourcesView.java index 398cfd9f7..860a7b2b1 100644 --- a/demo-web-site/src/main/java/com/vaadin/hummingbird/demo/website/DynamicResourcesView.java +++ b/demo-web-site/src/main/java/com/vaadin/hummingbird/demo/website/DynamicResourcesView.java @@ -61,7 +61,8 @@ private void createGenerateImageButton() { Button button = new Button("Generate image"); button.addClickListener(event -> { - image.setAttribute("data", createResource()); + // image.setAttribute("data", createResource()); + updateImage(); }); add(button); @@ -83,14 +84,24 @@ private void createImageOpener() { } private void createImage() { - image = new Element("object"); - image.setAttribute("type", "image/svg+xml"); - image.getStyle().set("display", "block"); - image.setAttribute("data", createResource()); + image = new Element("div"); + // image.setAttribute("type", "image/svg+xml"); + // image.getStyle().set("display", "block"); + // image.setAttribute("data", createResource()); + updateImage(); + getElement().appendChild(image); } + private void updateImage() { + StreamResource resource = createResource(); + image.setAttribute("non-existent", resource); + image.setProperty("innerHTML", + ""); + } + private StreamResource createResource() { return new StreamResource("image.svg", this::getImageInputStream); }