50 lines
2.0 KiB
Python
50 lines
2.0 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
import openerp
|
|
from openerp.addons.web import http
|
|
from openerp.addons.web.http import request
|
|
from openerp.addons.website.models import website
|
|
from datetime import datetime
|
|
|
|
class google_map(http.Controller):
|
|
|
|
@website.route(['/google_map/'], type='http', auth="admin")
|
|
def google_map(self, *arg, **post):
|
|
values = {
|
|
'partner_ids': post.get('partner_ids', ""),
|
|
'width': post.get('width', 900),
|
|
'height': post.get('height', 460),
|
|
'partner_url': post.get('partner_url'),
|
|
}
|
|
return request.website.render("website_google_map.google_map", values)
|
|
|
|
@website.route(['/google_map/partners.json'], type='http', auth="admin")
|
|
def google_map_data(self, *arg, **post):
|
|
partner_obj = request.registry['res.partner']
|
|
|
|
domain = [("id", "in", [int(p) for p in post.get('partner_ids', "").split(",") if p])]
|
|
domain_public = domain + [('website_published', '=', True)]
|
|
partner_ids = partner_obj.search(request.cr, openerp.SUPERUSER_ID,
|
|
domain_public, context=request.context)
|
|
return partner_obj.google_map_json(request.cr, openerp.SUPERUSER_ID,
|
|
partner_ids, request.context)
|
|
|
|
@website.route(['/google_map/set_partner_position/'], type='http', auth="admin")
|
|
def google_map_set_partner_position(self, *arg, **post):
|
|
partner_obj = request.registry['res.partner']
|
|
|
|
partner_id = post.get('partner_id') and int(post['partner_id'])
|
|
latitude = post.get('latitude') and float(post['latitude'])
|
|
longitude = post.get('longitude') and float(post['longitude'])
|
|
|
|
values = {
|
|
'partner_latitude': latitude,
|
|
'partner_longitude': longitude,
|
|
'date_localization': datetime.now().strftime('%Y-%m-%d'),
|
|
}
|
|
partner_obj.write(request.cr, request.uid, [partner_id], values,
|
|
request.context)
|
|
|
|
|
|
# vim:expandtab:tabstop=4:softtabstop=4:shiftwidth=4:
|