Browse Source

[IMP][web_widget_image_download] save image with the correct type

pull/391/head
kutyel 8 years ago
parent
commit
5d4308cfa2
  1. 10
      web_widget_image_download/README.rst
  2. 2
      web_widget_image_download/__openerp__.py
  3. 25
      web_widget_image_download/static/src/js/web_widget_image_download.js
  4. 5
      web_widget_image_download/static/src/xml/web_widget_image_download.xml

10
web_widget_image_download/README.rst

@ -22,6 +22,11 @@ To use this module, you need to:
:alt: Try me on Runbot :alt: Try me on Runbot
:target: https://runbot.odoo-community.org/runbot/162/8.0 :target: https://runbot.odoo-community.org/runbot/162/8.0
Known Issues / Roadmap
======================
* In order to work correctly, this widget has to detect image type, the server should include this information in the `Content-Type` header. Right now, odoo is not doing so, but a fix has been `proposed <https://github.com/odoo/odoo/pull/12918>`_.
Bug Tracker Bug Tracker
=========== ===========
@ -33,11 +38,6 @@ help us smashing it by providing a detailed and welcomed feedback.
Credits Credits
======= =======
Images
------
* Odoo Community Association: `Icon <https://github.com/OCA/maintainer-tools/blob/master/template/module/static/description/icon.svg>`_.
Contributors Contributors
------------ ------------

2
web_widget_image_download/__openerp__.py

@ -3,7 +3,7 @@
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). # License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).
{ {
"name": "Web Widget - Image Download", "name": "Web Widget - Image Download",
"summary": "Allows to download the avatar for the contact",
"summary": "Allows to download any image from its widget",
"version": "8.0.1.0.0", "version": "8.0.1.0.0",
"category": "web", "category": "web",
"website": "https://www.tecnativa.com", "website": "https://www.tecnativa.com",

25
web_widget_image_download/static/src/js/web_widget_image_download.js

@ -9,8 +9,29 @@ openerp.web_widget_image_download = function(instance) {
render_value() { render_value() {
this._super(); this._super();
// take image URI from preceding <img> tag
this.$el.find('.oe_form_binary_file_download').attr('href', $('img[name="image"]').attr('src'));
const widget = this.$el.find('.oe_form_binary_file_download');
this.imgSrc = this.$el.find('img[name="image"]').attr('src');
$.ajax({
type: 'HEAD',
url: this.imgSrc,
complete(xhr) {
// retrieve image type from server ("Content-Type" header)
widget.attr('download', xhr.getResponseHeader("Content-Type").replace('/', '.'));
}
});
// use jquery instead of `replace` with qweb (to avoid breaking inheritance)
if (this.has_custom_image()) {
this.$el.find('.oe_form_binary_file_clear').removeClass('col-md-offset-5');
}
widget.attr('href', this.imgSrc);
},
has_custom_image() {
// check if the image of the widget is different from the default placeholder
return this.imgSrc && !this.imgSrc.includes('/placeholder.png');
} }
}); });
} }

5
web_widget_image_download/static/src/xml/web_widget_image_download.xml

@ -5,10 +5,9 @@
<template> <template>
<t t-extend="FieldBinaryImage"> <t t-extend="FieldBinaryImage">
<t t-jquery=".oe_form_binary_file_edit" t-operation="after"> <t t-jquery=".oe_form_binary_file_edit" t-operation="after">
<a class="fa fa-download fa-1g col-md-4 oe_form_binary_file_download" title="Download" download="image.png"></a>
<t t-if="widget.has_custom_image()">
<a class="fa fa-download fa-1g col-md-4 oe_form_binary_file_download" title="Download"></a>
</t> </t>
<t t-jquery=".oe_form_binary_file_clear" t-operation="replace">
<i class="fa fa-trash-o fa-1g oe_form_binary_file_clear" title="Clear"/>
</t> </t>
</t> </t>
</template> </template>
Loading…
Cancel
Save