bzr revid: rlo@openerp.com-20120302103505-em22nbb5chumfzuf
This commit is contained in:
Roberto López López (OpenERP) 2012-03-02 11:35:05 +01:00
parent f0775d762e
commit ff1fc1a7e9
3 changed files with 46 additions and 18 deletions

View File

@ -1,8 +1,9 @@
{ {
'name': 'Google Docs', 'name': 'Google Docs',
'version': '0.1', 'version': '0.2',
'author': 'OpenERP SA', 'author': 'OpenERP SA',
'website': 'http://openerp.com', 'website': 'http://openerp.com',
'category': 'Tools',
'data': [ 'data': [
'google_docs.xml' 'google_docs.xml'
], ],

View File

@ -1,8 +1,31 @@
##############################################################################
#
# OpenERP, Open Source Management Solution
# Copyright (C) 2004-2012 OpenERP SA (<http://www.openerp.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/>.
#
##############################################################################
from osv import osv, fields from osv import osv, fields
import gdata.docs.data try:
import gdata.docs.client import gdata.docs.data
from gdata.client import RequestError import gdata.docs.client
from gdata.docs.service import DOCUMENT_LABEL from gdata.client import RequestError
from gdata.docs.service import DOCUMENT_LABEL
except ImportError:
raise osv.except_osv(_('Google Docs Error!'), _('Please install gdata-python-client from http://code.google.com/p/gdata-python-client/downloads/list'))
class google_docs_ir_attachment(osv.osv): class google_docs_ir_attachment(osv.osv):
_inherit = 'ir.attachment' _inherit = 'ir.attachment'
@ -12,7 +35,7 @@ class google_docs_ir_attachment(osv.osv):
users_obj = self.pool.get('res.users') users_obj = self.pool.get('res.users')
user = users_obj.browse(cr, uid, [uid])[0] user = users_obj.browse(cr, uid, [uid])[0]
if not user.gmail_user or not user.gmail_password: if not user.gmail_user or not user.gmail_password:
return -2 return False
# login # login
client = gdata.docs.client.DocsClient(source='openerp.com') client = gdata.docs.client.DocsClient(source='openerp.com')
@ -29,13 +52,13 @@ class google_docs_ir_attachment(osv.osv):
@param model: the current model name. @param model: the current model name.
@param type_doc: text, spreadsheet or slide. @param type_doc: text, spreadsheet or slide.
@return the document object. @return the document object.
@return -2 if the google_base_account hasn't been configured yet. @return False if the google_base_account hasn't been configured yet.
''' '''
# authenticate # authenticate
client = self._auth(cr, uid) client = self._auth(cr, uid)
if client == -2: if client == False:
return -2 return False
# create the document in google docs # create the document in google docs
if type_doc=='slide': if type_doc=='slide':
@ -62,8 +85,8 @@ class google_docs_ir_attachment(osv.osv):
context={} context={}
client = self._auth(cr, uid) client = self._auth(cr, uid)
if client == -2: if client == False:
return -2 return False
# fetch and copy the original document # fetch and copy the original document
original_resource = client.get_resource_by_id(gdocs_resource_id) original_resource = client.get_resource_by_id(gdocs_resource_id)

View File

@ -9,36 +9,40 @@ openerp.google_docs = function(instance, session) {
this.$element.delegate('.oe_google_docs_slide_button', 'click', this.on_add_slide_gdoc); this.$element.delegate('.oe_google_docs_slide_button', 'click', this.on_add_slide_gdoc);
}, },
on_add_text_gdoc: function() { on_add_text_gdoc: function() {
console.log('on_add_text_gdoc:');
var self = this; var self = this;
var $gdocbtn = this.$element.find('.oe_google_docs_text_button'); var $gdocbtn = this.$element.find('.oe_google_docs_text_button');
$gdocbtn.attr('disabled', 'true').find('img, span').toggle(); $gdocbtn.attr('disabled', 'true').find('img, span').toggle();
var ds = new instance.web.DataSet(this, 'google.docs', this.view.dataset.get_context()); var ds = new instance.web.DataSet(this, 'google.docs', this.view.dataset.get_context());
ds.call('doc_get', [this.view.dataset.model, [this.view.datarecord.id], 'text'], function(r) { ds.call('doc_get', [this.view.dataset.model, [this.view.datarecord.id], 'text'], function(r) {
console.log('on_add_text_gdoc: return'); console.log(r);
if (r == 'False') {
var params = {
error: response,
message: "The user google credentials are not set yet. Contact your administrator for help."
}
$(openerp.web.qweb.render("DialogWarning", params)).dialog({
title: "User Google credentials are not yet set.",
modal: true,
});
}
self.do_update(); self.do_update();
}); });
}, },
on_add_spreadsheet_gdoc: function() { on_add_spreadsheet_gdoc: function() {
console.log('on_add_spreadsheet_gdoc:');
var self = this; var self = this;
var $gdocbtn = this.$element.find('.oe_google_docs_spreadsheet_button'); var $gdocbtn = this.$element.find('.oe_google_docs_spreadsheet_button');
$gdocbtn.attr('disabled', 'true').find('img, span').toggle(); $gdocbtn.attr('disabled', 'true').find('img, span').toggle();
var ds = new instance.web.DataSet(this, 'google.docs', this.view.dataset.get_context()); var ds = new instance.web.DataSet(this, 'google.docs', this.view.dataset.get_context());
console.log('on_add_spreadsheet_gdoc:');
ds.call('doc_get', [this.view.dataset.model, [this.view.datarecord.id], 'spreadsheet'], function(r) { ds.call('doc_get', [this.view.dataset.model, [this.view.datarecord.id], 'spreadsheet'], function(r) {
console.log('on_add_spreadsheet_gdoc: return');
self.do_update(); self.do_update();
}); });
}, },
on_add_slide_gdoc: function() { on_add_slide_gdoc: function() {
console.log ('on_add_slide_gdoc:');
var self = this; var self = this;
var $gdocbtn = this.$element.find('.oe_google_docs_slide_button'); var $gdocbtn = this.$element.find('.oe_google_docs_slide_button');
$gdocbtn.attr('disabled', 'true').find('img, span').toggle(); $gdocbtn.attr('disabled', 'true').find('img, span').toggle();
var ds = new instance.web.DataSet(this, 'google.docs', this.view.dataset.get_context()); var ds = new instance.web.DataSet(this, 'google.docs', this.view.dataset.get_context());
ds.call('doc_get', [this.view.dataset.model, [this.view.datarecord.id], 'slide'], function(r) { ds.call('doc_get', [this.view.dataset.model, [this.view.datarecord.id], 'slide'], function(r) {
console.log('on_add_slide_gdoc: return');
self.do_update(); self.do_update();
}); });
} }