Skip to Content
Menu
This question has been flagged
4 Replies
17086 Views

I cant open a form when "register payment " button is clicked

my code is as follows: -

<------order model----->

class orders(models.Model):
    _name='pickabite.orders'
    _rec_name='order_id'

state = fields.Selection([
            ('draft','Draft'),
            ('confirmed', 'Confirmed'),
            ('bill','Bill'),
            ('in_payment', 'In Payment'),
            ('paid', 'Paid'),
            ('cancel', 'Cancelled'),],
            string='Status', index=True, readonly=True, default='draft',
            track_visibility='onchange', copy=False)

 #register payment button action
    @api.multi
    def in_payment(self):
        self.write({'state': 'in_payment'})
        '''return {
            #'name': self.order_id,
            'res_model': 'pickabite.payment',
            'type': 'ir.actions.act_window',
            'context': {},
            'view_mode': 'form',
            'view_type': 'form',
            'view_id': self.env.ref("pickabite.payment_form_view"),
            'target': 'new'
        } '''
  


<------------payment model------------>


class payment(models.Model):
    _name='pickabite.payment'
    _rec_name='bill_id'
    bill_id=fields.Many2one('pickabite.orders',string='Bill Id')
    customer_id=fields.Many2one(related='bill_id.customer_name',
            string='Customer Id')
    bill_amount=fields.Float(related='bill_id.order_price',
            string='Bill amount')
           
   

<-------xml ------>

 
    <!--Order Form View-->
    <record model="ir.ui.view" id="pickabite.order_form">
        <field name="name">Orders</field>
        <field name="model">pickabite.orders</field>
        <field name="arch" type="xml">
        <form string="Orders">
            <header>
                 
                <button style=" background-color: lightblue;"
                    name="in_payment" string="Register Payment" states="bill"
                    type="action"/>
                 
                <field name="state" widget="statusbar"
                    statusbar_visible="draft,confirmed,bill,in_payment,paid,
                                            cancel" />
            </header>
            <form>
                  <!--       -->
        </form>
      </field> 
    </record>
   
  
    <!--Payment Form View-->
    <record model="ir.ui.view" id="pickabite.payment_form_view">
        <field name="name">Payment Form View</field>
        <field name="model">pickabite.payment</field>
        <field name="arch" type="xml">
        <form>
                 <!--  -->
        </form>
      </field> 
    </record>
   
    <!--ACTION-->
   
    <!--Order Menu Action-->
    <record model="ir.actions.act_window" id="order_menu_action">
        <field name="name">Orders</field>
        <field name="res_model">pickabite.orders</field>
        <field name="view_type">form</field>
          <field name="view_mode">kanban,tree,form</field>
        <field name="domain">[]</field>
        <field name="help" type="html">
          <p class="o_view_nocontent_smiling_face">Create The First
                   Order</p>
        </field>
    </record>
   
    <!--Payment menu Action-->
    <record model="ir.actions.act_window" id="payment_menu_action">
        <field name="name">Payment</field>
        <field name="res_model">pickabite.payment</field>
        <field name="view_type">form</field>
          <field name="view_mode">form</field>
          <!--field name="view_id"/>
          <ref="pickabite.payment_form_view"/-->
          <field name="target">current</field>
    </record>


I'm a beginner and I'm using community version 12 . Please help


Avatar
Discard
Best Answer

Hi,

It seems you are calling a python function upon clicking the button, but you have given type as action,

change the type to object and see,

<button name="in_payment" string="Register Payment" states="bill"
type="object" style="background-color: lightblue;"/>

UPDT:


@api.multi
def in_payment(self):
self.write({'state': 'in_payment'})
return {
#'name': self.order_id,
'res_model': 'pickabite.payment',
'type': 'ir.actions.act_window',
'context': {},
'view_mode': 'form',
'view_type': 'form',
'view_id': self.env.ref("pickabite.payment_form_view").id,
'target': 'new'
}

Thanks

Avatar
Discard
Best Answer

How can I get the id of the record in which we have opened the view in the model of the newly opened view?

Actually, I'm working on some OTP verification.

When we click a button I want a popup view to enter otp.

and depending on that otp. I want to change the state of the original record in which I opened the popup view.

I think I can do that if I get its id in the model of the new popup view.



Avatar
Discard
Best Answer

hello 

make the button type object into  your code. 

 <button style=" background-color: lightblue;"  name="in_payment" string="Register Payment" states="bill" type="object"/>

and into python code remove the quotes from the return statement.

@api.multi
    def in_payment(self):
        self.write({'state': 'in_payment'})
        return {
            #'name': self.order_id,
            'res_model': 'pickabite.payment',
            'type': 'ir.actions.act_window',
            'context': {},
            'view_mode': 'form',
            'view_type': 'form',
            'view_id': self.env.ref("pickabite.payment_form_view"),
            'target': 'new'
        }

Avatar
Discard
Author Best Answer

Thanks, but its not working.

Odoo Server Error
Traceback (most recent call last):
  File "/home/gopika/odoo/odoo-server/odoo/api.py", line 1032, in get
    value = self._data[field][record.id][key]
KeyError: (<odoo.sql_db.Cursor object at 0x7f881e298048>, 2)

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "/home/gopika/odoo/odoo-server/odoo/fields.py", line 970, in __get__
    value = record.env.cache.get(record, self)
  File "/home/gopika/odoo/odoo-server/odoo/api.py", line 1034, in get
    raise CacheMiss(record, field)
odoo.exceptions.CacheMiss: ("ir.ui.view('ir.ui.view(1362,)',).mode", None)

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "/home/gopika/odoo/odoo-server/odoo/http.py", line 654, in _handle_exception
    return super(JsonRequest, self)._handle_exception(exception)
  File "/home/gopika/odoo/odoo-server/odoo/http.py", line 312, in _handle_exception
    raise pycompat.reraise(type(exception), exception, sys.exc_info()[2])
  File "/home/gopika/odoo/odoo-server/odoo/tools/pycompat.py", line 87, in reraise
    raise value
  File "/home/gopika/odoo/odoo-server/odoo/http.py", line 696, in dispatch
    result = self._call_function(**self.params)
  File "/home/gopika/odoo/odoo-server/odoo/http.py", line 344, in _call_function
    return checked_call(self.db, *args, **kwargs)
  File "/home/gopika/odoo/odoo-server/odoo/service/model.py", line 97, in wrapper
    return f(dbname, *args, **kwargs)
  File "/home/gopika/odoo/odoo-server/odoo/http.py", line 337, in checked_call
    result = self.endpoint(*a, **kw)
  File "/home/gopika/odoo/odoo-server/odoo/http.py", line 939, in __call__
    return self.method(*args, **kw)
  File "/home/gopika/odoo/odoo-server/odoo/http.py", line 517, in response_wrap
    response = f(*args, **kw)
  File "/home/gopika/odoo/odoo-server/odoo/addons/web/controllers/main.py", line 962, in call_kw
    return self._call_kw(model, method, args, kwargs)
  File "/home/gopika/odoo/odoo-server/odoo/addons/web/controllers/main.py", line 954, in _call_kw
    return call_kw(request.env[model], method, args, kwargs)
  File "/home/gopika/odoo/odoo-server/odoo/api.py", line 745, in call_kw
    return _call_kw_model(method, model, args, kwargs)
  File "/home/gopika/odoo/odoo-server/odoo/api.py", line 718, in _call_kw_model
    result = method(recs, *args, **kwargs)
  File "/home/gopika/odoo/odoo-server/odoo/models.py", line 1370, in load_views
    for [v_id, v_type] in views
  File "/home/gopika/odoo/odoo-server/odoo/models.py", line 1370, in <dictcomp>
    for [v_id, v_type] in views
  File "/home/gopika/odoo/odoo-server/odoo/models.py", line 1449, in fields_view_get
    result = self._fields_view_get(view_id=view_id, view_type=view_type, toolbar=toolbar, submenu=submenu)
  File "/home/gopika/odoo/odoo-server/odoo/models.py", line 1412, in _fields_view_get
    root_view = View.browse(view_id).read_combined(['id', 'name', 'field_parent', 'type', 'model', 'arch'])
  File "/home/gopika/odoo/odoo-server/odoo/addons/base/models/ir_ui_view.py", line 752, in read_combined
    while root.mode != 'primary':
  File "/home/gopika/odoo/odoo-server/odoo/fields.py", line 974, in __get__
    self.determine_value(record)
  File "/home/gopika/odoo/odoo-server/odoo/fields.py", line 1075, in determine_value
    record._prefetch_field(self)
  File "/home/gopika/odoo/odoo-server/odoo/models.py", line 2815, in _prefetch_field
    result = records.read([f.name for f in fs], load='_classic_write')
  File "/home/gopika/odoo/odoo-server/odoo/models.py", line 2759, in read
    self._read_from_database(stored, inherited)
  File "/home/gopika/odoo/odoo-server/odoo/models.py", line 2878, in _read_from_database
    cr.execute(query_str, params)
  File "/home/gopika/odoo/odoo-server/odoo/sql_db.py", line 148, in wrapper
    return f(self, *args, **kwargs)
  File "/home/gopika/odoo/odoo-server/odoo/sql_db.py", line 225, in execute
    res = self._obj.execute(query, params)
psycopg2.DataError: invalid input syntax for integer: "ir.ui.view(1362,)"
LINE 1: ...t_id" FROM "ir_ui_view" WHERE "ir_ui_view".id IN ('ir.ui.vie...
                                                             ^

Avatar
Discard

Please see the updated answer, change,

,'view_id': self.env.ref("pickabite.payment_form_view"),

to

,'view_id': self.env.ref("pickabite.payment_form_view").id,