Přejít na obsah
Menu
You need to be registered to interact with the community.
This question has been flagged
3445 Zobrazení

I want that When we select any group from Group field then  "Assign To" field should be take only those users, those are in the selected group only.

Here is python code:-


class assign_case(osv.osv):

    _name = "assign.case"

    _description = "assign Assign"


    _columns = {


        'group_id': fields.many2one('res.groups', string='Group', required=True),

        'assign_to': fields.many2one('hr.employee', 'Assigned to:', required=True),

    }



    def assign_case(self, cr, uid, ids, context=None):


        sunarc_obj = self.pool.get('sun.helpdesk')

        record_id = context.get('active_id')

        print "rec:", record_id

        data = self.read(cr, uid, ids)[0]

        #print data

        assign_to = data['assign_to'] and data['assign_to'][0]

        group_id = data['group_id'] and data['group_id'][0]

        print sunarc_obj.write(cr, uid, [record_id], {'assign_to': assign_to, 'state': 'assign'})


        sunarc_obj.write(cr, uid, [record_id],

                     {'assign_to': assign_to, 'group_id':group_id, 'state': 'assign', 'update_date': fields.datetime.now()})

        try:

            mail_message_obj = self.pool.get('mail.message')

            mail_ids = []

            mail_mail = self.pool.get('mail.mail')

            base_url = self.pool.get('ir.config_parameter').get_param(cr, uid, 'web.base.url')

            for val in sunarc_obj.browse(cr, uid, record_id):

                    print "Employee Email"

                    subject = "Ticket ID-%s Assigned" % ids[0]

                    # subject = "Issue Escalate"

                    body = _("Hello,\n\n" )

                    body += _("Message from Helpdesk \n\n")


                    body += _("Ticket:%s\n\n" % val.name)

                    body += _("Description:%s\n\n" % val.description)

                    body += _("Priority:%s\n\n" % val.priority)

                    footer = _("Kind regards.\n")

                    # footer += _("%s\n\n" %val.user_id.name)


                    mail_message_id = mail_message_obj.search(cr, SUPERUSER_ID,

                                                              [('model', '=', 'sun.helpdesk'),

                                                               ('subject', '=', subject),

                                                               ('type', '=', 'email')], context=context)

                    if mail_message_id:

                        mail_message_id = mail_message_id[0]

                    print "mail_message_id", mail_message_id

                    mail_ids.append(mail_mail.create(cr, uid, {

                        'mail_message_id': mail_message_id,

                                                'subject': subject,

                        'body_html': '<pre><span class="inner-pre" style="font-size: 15px">%s<a href=%s>To Login and View Issue Reported</a><br><br>%s</span></pre>' % (

                        body, base_url, footer)

                    }, context=context))

                    print "mail_ids:", mail_ids

                    mail_mail.send(cr, uid, mail_ids, context=context)


        except Exception, e:

            print "Exception", e

        return True


    def onchange_assign(self, cr, uid, ids, group_id, context=None):

        if not context:

            context = {}

        res = {}

        groups_obj = self.pool.get('res.groups')

        sunarc_obj = self.pool.get('sun.helpdesk')

        record_id = context.get('active_id')

        print "rec:", record_id

        data = sunarc_obj.read(cr, uid, record_id)

        print data

        group_id = data['group_id'] and data['group_id'][0]

        groups_ids = []


        groups = groups_obj.browse(cr, uid, group_id, context=context)

        print group_id, groups, groups.users.ids


        if group_id:

            res['domain'] = {'assign_to': [('id', 'in', groups.users.ids)]}

        print "group_id"

        return res assign_case()


Here is xml code:-


<?xml version="1.0" encoding="utf-8"?>

<openerp>

    <data>

        <record id="view_assign_case" model="ir.ui.view">

            <field name="name">Assigned</field>

            <field name="model">assign.case</field>

            <field name="arch" type="xml">

                <form string="Assigned" version="7.0">

    <group col="4">

                <field name="group_id" on_change="onchange_assign(group_id)"/>

                <field name="assign_to"/>

    </group>

    <footer>

    <button string="OK" type="object" name="assign_case" class="oe_highlight" />

    <button string="Cancel" class="oe_link" special="cancel"/>

                    </footer>

                </form>

            </field>

        </record>


  <record id="action_view_assign_case" model="ir.actions.act_window">

            <field name="name">Assigned</field>

            <field name="type">ir.actions.act_window</field>

            <field name="res_model">assign.case</field>

            <field name="view_type">form</field>

            <field name="view_mode">form</field>

            <field name="target">new</field>

        </record>

  </data>

  </openerp>


Avatar
Zrušit
Related Posts Odpovědi Zobrazení Aktivita
1
čvc 19
3327
3
úno 18
5840
2
čvc 16
3331
2
zář 23
5107
12
říj 23
36160