You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
132 lines
5.3 KiB
132 lines
5.3 KiB
/*
|
|
OpenERP, Open Source Management Solution
|
|
This module copyright (C) 2014 Therp BV (<http://therp.nl>)
|
|
(C) 2013 Marcel van der Boom <marcel@hsdev.com>
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License as
|
|
published by the Free Software Foundation, either version 3 of the
|
|
License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
openerp.web_tree_image = function(instance) {
|
|
"use strict";
|
|
|
|
// unique DOM id for the popup DOM node
|
|
function popup_id(name, id) {
|
|
return "o_web_tree_image_popup-" + name + "-" + id;
|
|
}
|
|
|
|
// unique DOM id for the clickable DOM node
|
|
function clickable_id(name, id) {
|
|
return "o_web_tree_image_clickable-" + name + "-" + id;
|
|
}
|
|
|
|
// add callback for click on image icon/thumbnail for given row name/id
|
|
function make_clickable(name, id) {
|
|
// defer execution until after DOM elements have been rendered
|
|
window.setTimeout(function() {
|
|
$("#" + clickable_id(name, id)).click(function() {
|
|
$('#' + popup_id(name, id)).modal('show');
|
|
return false;
|
|
});
|
|
}, 0);
|
|
}
|
|
|
|
var QWeb = instance.web.qweb;
|
|
instance.web.list.ImagePreview = instance.web.list.Column.extend({
|
|
format: function (row_data, options) {
|
|
/* Return a valid img tag. For image fields, test if the
|
|
field's value contains just the binary size and retrieve
|
|
the image from the dedicated controller in that case.
|
|
Otherwise, assume a character field containing either a
|
|
stock Odoo icon name without path or extension or a fully
|
|
fledged location or data url */
|
|
var self = this;
|
|
|
|
/*
|
|
Allow image to be displayed in 3 different ways:
|
|
- 'inline': display image directly in tree view (default)
|
|
- 'icon': display only an icon, show a full screen preview
|
|
of the picture on click
|
|
- 'thumbnail': display image directly in tree view, show a
|
|
full screen preview of the picture on click
|
|
*/
|
|
self.display = self.display || 'inline';
|
|
|
|
if (!row_data[self.id] || !row_data[self.id].value) {
|
|
return '';
|
|
}
|
|
var value = row_data[self.id].value;
|
|
if (self.type === 'binary') {
|
|
if (value && value.substr(0, 10).indexOf(' ') === -1) {
|
|
// The media subtype (png) seems to be arbitrary
|
|
self.src = "data:image/png;base64," + value;
|
|
} else {
|
|
var imageArgs = {
|
|
model: options.model,
|
|
field: self.id,
|
|
id: options.id
|
|
}
|
|
if (self.resize) {
|
|
imageArgs.resize = self.resize;
|
|
}
|
|
self.src = instance.session.url('/web/binary/image',
|
|
imageArgs);
|
|
}
|
|
} else {
|
|
if (!/\//.test(row_data[self.id].value)) {
|
|
self.src = '/web/static/src/img/icons/' +
|
|
row_data[self.id].value + '.png';
|
|
} else {
|
|
self.src = row_data[self.id].value;
|
|
}
|
|
}
|
|
|
|
if (self.display == 'icon' || self.display == 'thumbnail')
|
|
{
|
|
var id = row_data.id.value;
|
|
var popupId = popup_id(self.name, id);
|
|
// add full screen preview to DOM
|
|
$('#' + popupId).remove();
|
|
$("body").append(QWeb.render("ListView.row.image.imageData", {
|
|
widget: self,
|
|
popupId: popupId,
|
|
}));
|
|
make_clickable(self.name, id);
|
|
}
|
|
|
|
return QWeb.render('ListView.row.image', {
|
|
widget: self,
|
|
clickableId: clickable_id(self.name, id),
|
|
});
|
|
},
|
|
});
|
|
instance.web.list.columns.add('field.image',
|
|
'instance.web.list.ImagePreview');
|
|
instance.web.list.columns.add('field.image_preview',
|
|
'instance.web.list.ImagePreview');
|
|
|
|
instance.web.form.ImagePreview = instance.web.form.FieldBinary.extend({
|
|
template: 'FieldBinaryImage',
|
|
render_value: function() {
|
|
var id = this.view.datarecord.id;
|
|
make_clickable(this.name, id);
|
|
var content = {
|
|
widget: {display: 'icon'},
|
|
clickableId: clickable_id(this.name, id),
|
|
};
|
|
this.$el.html($(QWeb.render('ListView.row.image', content)));
|
|
},
|
|
});
|
|
instance.web.form.widgets.add('image_preview',
|
|
'instance.web.form.ImagePreview');
|
|
};
|