12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- # -*- encoding: utf-8 -*-
- ##############################################################################
- #
- # OpenERP, Open Source Management Solution
- # Copyright (c) 2012 Cubic ERP - Teradata SAC. (http://cubicerp.com).
- #
- # WARNING: This program as such is intended to be used by professional
- # programmers who take the whole responsability of assessing all potential
- # consequences resulting from its eventual inadequacies and bugs
- # End users who are looking for a ready-to-use solution with commercial
- # garantees and support are strongly adviced to contract a Free Software
- # Service Company
- #
- # This program is Free Software; you can redistribute it and/or
- # modify it under the terms of the GNU General Public License
- # as published by the Free Software Foundation; either version 2
- # 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 General Public License for more details.
- #
- # You should have received a copy of the GNU General Public License
- # along with this program; if not, write to the Free Software
- # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
- #
- ##############################################################################
- from openerp.osv import fields, osv
- class res_state(osv.osv):
- def name_get(self, cr, uid, ids, context=None):
- if not len(ids):
- return []
- res = []
- for state in self.browse(cr, uid, ids, context=context):
- data = []
- acc = state
- while acc:
- data.insert(0, acc.name)
- acc = acc.parent_id
- data = ' / '.join(data)
- res.append((state.id, (state.code and '[' + state.code + '] ' or '') + data))
-
- return res
-
-
- def complete_name_search(self, cr, user, name, args=None, operator='ilike', context=None, limit=100):
- if not args:
- args = []
- args = args[:]
- ids = []
- if name:
- ids = self.search(cr, user, [('name', operator, name)]+ args, limit=limit)
- if not ids and len(name.split()) >= 2:
- #Separating code and name of account for searching
- operand1,operand2 = name.split(': ',1) #name can contain spaces e.g. OpenERP S.A.
- ids = self.search(cr, user, [('name', operator, operand2)]+ args, limit=limit)
- else:
- ids = self.search(cr, user, args, context=context, limit=limit)
- return self.name_get(cr, user, ids, context=context)
-
- def _name_get_fnc(self, cr, uid, ids, prop, unknow_none, context=None):
- if not ids:
- return []
- res = []
- for state in self.browse(cr, uid, ids, context=context):
- data = []
- acc = state
- while acc:
- data.insert(0, acc.name)
- acc = acc.parent_id
- data = ' / '.join(data)
- res.append((state.id, data))
- return dict(res)
-
- _name = 'res.country.state'
- _inherit = 'res.country.state'
- _columns = {
- 'code': fields.char('State Code', size=32,help='The state code.\n', required=True),
- 'complete_name': fields.function(_name_get_fnc, method=True, type="char", string='Complete Name', fnct_search=complete_name_search),
- 'parent_id': fields.many2one('res.country.state','Parent State', select=True, domain=[('type','=','view')]),
- 'child_ids': fields.one2many('res.country.state', 'parent_id', string='Child States'),
- 'type': fields.selection([('view','View'), ('normal','Normal')], 'Type'),
- }
- _defaults = {
- 'type': 'normal',
- }
- res_state()
- # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|