Skip to Content
Odoo मेन्यू
  • साइन इन करें
  • मुफ़्त में आज़माएं
  • ऐप्लिकेशन
    फ़ाइनेंस
    • अकाउंटिंग
    • इनवॉइसिंग
    • एक्सपेंस
    • स्प्रेडशीट (बीआई)
    • डॉक्यूमेंट्स
    • साइन
    सेल्स
    • सीआरएम
    • सेल्स
    • पीओएस शॉप
    • पीओएस रेस्टोरेंट
    • सब्सक्रिप्शन
    • रेंटल
    वेबसाइट
    • वेबसाइट बिल्डर
    • ई-कॉमर्स
    • ब्लॉग
    • फ़ोरम
    • लाइव चैट
    • ई-लर्निंग
    सप्लाई चेन
    • इन्वेंट्री
    • मैन्युफ़ैक्चरिंग
    • पीएलएम
    • परचेज़
    • मेंटेनेंस
    • क्वालिटी
    मानव संसाधन
    • कर्मचारी
    • रिक्रूटमेंट
    • टाइम ऑफ़
    • अप्रेज़ल
    • रेफ़रल
    • फ़्लीट
    मार्केटिंग
    • सोशल मार्केटिंग
    • ईमेल मार्केटिंग
    • एसएमएस मार्केटिंग
    • इवेंट
    • मार्केटिंग ऑटोमेशन
    • सर्वे
    सेवाएं
    • प्रोजेक्ट
    • टाइमशीट
    • फ़ील्ड सर्विस
    • हेल्पडेस्क
    • प्लानिंग
    • अपॉइंटमेंट
    प्रॉडक्टिविटी
    • डिस्कस
    • आर्टिफ़िशियल इंटेलिजेंस
    • आईओटी
    • वीओआईपी
    • नॉलेज
    • WhatsApp
    तीसरे पक्ष के ऐप्लिकेशन Odoo स्टूडियो Odoo क्लाउड प्लेटफ़ॉर्म
  • इंडस्ट्री
    रीटेल
    • बुक स्टोर
    • क्लोदिंग स्टोर
    • फ़र्नीचर स्टोर
    • ग्रॉसरी स्टोर
    • हार्डवेयर स्टोर
    • टॉय स्टोर
    फ़ूड & हॉस्पिटैलिटी
    • बार और पब
    • रेस्टोरेंट
    • फ़ास्ट फ़ूड
    • गेस्ट हाउस
    • बेवरिज डिस्ट्रीब्यूटर
    • होटल
    रियल एस्टेट
    • Real Estate Agency
    • आर्किटेक्चर फ़र्म
    • कंसट्रक्शन
    • Property Management
    • गार्ड्निंग
    • प्रॉपर्टी ओनर असोसिएशन
    कंसल्टिंग
    • अकाउंटिंग फ़र्म
    • Odoo पार्टनर
    • मार्केटिंग एजेंसी
    • लॉ फ़र्म
    • टैलेंट ऐक्विज़िशन
    • ऑडिट & सर्टिफ़िकेशन
    मैन्युफ़ैक्चरिंग
    • टेक्सटाइल
    • धातु
    • फ़र्नीचर
    • फ़ूड
    • ब्रुअरी
    • कॉर्पोरेट गिफ़्ट
    हेल्थ & फिटनेस
    • स्पोर्ट्स क्लब
    • आईवियर स्टोर
    • फिटनेस सेंटर
    • वेलनेस प्रैक्टिशनर
    • फॉर्मेसी
    • हेयर सैलून
    Trades
    • Handyman
    • आईटी हार्डवेयर & सपोर्ट
    • Solar Energy Systems
    • Shoe Maker
    • साफ-सफाई से जुड़ी सेवाएं
    • HVAC सर्विस
    अन्य
    • गैर-लाभकारी संगठन
    • एन्वायरमेंटल एजेंसी
    • बिलबोर्ड रेंटल
    • फ़ोटोग्राफी
    • बाइक लीजिंग
    • सॉफ़्टवेयर रीसेलर
    सभी इंडस्ट्री को ब्राउज़ करें
  • कम्यूनिटी
    सीखें
    • ट्यूटोरियल्स
    • दस्तावेज़
    • सर्टिफ़िकेशन
    • ट्रेनिंग
    • ब्लॉग
    • पॉडकास्ट
    शिक्षा को बढ़ावा दें
    • एजुकेशन प्रोग्राम
    • स्केल अप! बिजनेस गेम
    • Odoo के ऑफ़िस में आएं
    सॉफ़्टवेयर पाएं
    • डाउनलोड
    • वर्शन की तुलना करें
    • रिलीज़
    साथ मिलकर काम करें
    • Github
    • फ़ोरम
    • इवेंट
    • अनुवाद
    • पार्टनर बनें
    • Services for Partners
    • अपना अकाउंटिंग फ़र्म रजिस्टर करें
    सेवाएं पाएं
    • पार्टनर ढूंढें
    • अकाउंटेंट खोजें
    • सलाहकार की मदद लें
    • इम्प्लिमेंटेशन सेवाएं
    • कस्टमर रेफ़रेंस
    • सहायता
    • अपग्रेड
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    डेमो देखें
  • कीमत
  • सहायता
You need to be registered to interact with the community.
All Posts People Badges
टैग (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
टैग (View all)
odoo accounting v14 pos v15
About this forum
सहायता

get current url for transient model define its possible?

Subscribe

Get notified when there's activity on this post

This question has been flagged
URL
1 Reply
3332 डेटा देखने का तरीका
अवतार
Gaston Carrera

(Odoo v.12)

Good morning, i wanna ask for the next:

 

I got a Transient Model, what have to read another model. This Transient Model its explicity writed for work with one model what i call "empresa.modelo1". This Transient Model its called "modelo1.datos".

 

I create already 2 transients for 2 models:

model1 "empresa.model1"

transient1 "model1.datos"

model2 "empresa.model2"

transient2 "model2.datos"

 

The Transient Model makes always the same, in the Tree View of "modelo1" i put a button, which  if you select diferents rows in tree view and click pop a window (transient model) with a field "campo" where you write the field name that you want to search, and by a "onchange" function refresh the "texto" (text field) with all the values of that field in all the selected rows.

 

 

The transient "model1.datos" have:

 

campos_disponibles=fields.Text (shows all the fields names of "empresa.model1")

campo=fields.Char here you write the name of field what wants search his value in "empresa.modelo1" selected rows 

 

texto=fields.Texto this field fills with all the results.

 

 

@api.onchange("campo")

def set_texto(self):

​ ​search in "model1" the actives ids, and write the data in self.texto

​ ​resul=self.env['empresa.modelo1'].search( active ids  )

​​for rec in resul​:

​ ​ ​ ​self.texto+=rec[self.campo]+'\n'

 

The case its that for not repite for all models this transient model, i wish could make a generic transient model wich read the actual "active_model" and use that for define himself, (but i havent acces to  "self.env" or "self._context" what i actually use for read the url).

 

 

class ExportaDatos(models.TransientModel):

    """Wizard to update a manual goal"""

    _name = 'exporta.datos'

    _description = 'Exportar Datos'

 

    current_url=http .request.httprequest.url #Traté de sacar así la url

    curr1=current_url[current_url.find('active_model=')+len('active_model='):]

    activemodel=curr1[:curr1.find('&')]

 

    campos_disponibles=fields.Text('Campos disponibles')

    campo=fields.Char('Campo a Buscar')

    texto = fields.Text(string="Datos Exportados")

    ids_lines=fields.One2many('ids_exporta.lines', 'elem_id', string='Ids seleccionados')

 

    @api.onchange('campo')

    def set_texto(self):

 

        current_url = http .request.httprequest.url

        curr1 = current_url[current_url.find('active_model=') + len('active_model='):]

 

        activemodel = curr1[:curr1.find('&')]

        revisap = self.env[activemodel].browse(self._context.get('active_ids'))

        RESEARCH=False

        if revisap:

            h0=0

            for rec in revisap:

                if h0==0:

                    if self.campo in rec.fields_get():

                        RESEARCH=True

                else:

                    break

                h0+=1

            if RESEARCH:

                texto = ''

                for rec in revisap:

                    if self.campo in rec.fields_get():

                        if rec[self.campo]:

                            prev1 = str(rec[self.campo])

                            texto += prev1 + '\n'

 

                self.texto = texto

 

    @api.model

    def default_get(self, fields):

 

        current_url = http .request.httprequest.url

        curr1 = current_url[current_url.find('active_model=') + len('active_model='):]

 

        activemodel = curr1[:curr1.find('&')]

        resul = super(ExportaDatos, self).default_get(fields)

        revisap = self.env[activemodel].browse(self._context.get('active_ids'))

        resul['campo']='tel'

        res = self.env[activemodel].search([], limit=1)

        h0 = 0

        for Field in res.fields_get():

            if h0 == 0:

                resul['campos_disponibles'] = 'Campos para extraer:\n' + Field + ' (%s)' % str(res[Field])

            else:

                resul['campos_disponibles'] += '\n' + Field + ' (%s)' % str(res[Field])

            h0+=1

 

        if revisap:

            texto=''

            resul['ids_lines']=[]

            for rec in revisap:

                resul['ids_lines'].append((0,0,{'id_model':rec.id,'elem_id':self.id }))

                if 'tel' in revisap.fields_get():

                    if rec.tel:

                        texto+=prev1+'\n'

 

                elif 'name' in revisap.fields_get():

                    texto+=prev1+'\n'

 

 

            resul['texto']=texto

 

 

        return resul

 

 

 

class ListaExportarIds(models.TransientModel):

    """Wizard to update a manual goal"""

    _name = 'ids_exporta.lines'

    _description = 'Ids a utilizar'

 

    current_url = http .request.httprequest.url

    curr1 = current_url[current_url.find('active_model=') + len('active_model='):]

 

    activemodel = curr1[:curr1.find('&')]

 

    id_model = fields.Many2one(activemodel, string="ID elem")

    elem_id=fields.Many2one('exporta.datos', string='lista_ids')

 


0
अवतार
खारिज करें
अवतार
Gaston Carrera
लेखक Best Answer

I could solve my problem!, finally choose to avoid the use of all Many2one and One2many in the transients models, so i could use one only transient model for all the models.  


Thanks!

0
अवतार
खारिज करें
Gaston Carrera
लेखक

i dont know how close this answer solved, if some mod can help me?

Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

साइन अप करें
Related Posts Replies डेटा देखने का तरीका ऐक्टिविटी
I would like to capture data from a URL into a form on a webpage
URL
अवतार
0
अक्तू॰ 24
2849
Change the URL of Odoo project
URL
अवतार
0
अग॰ 23
3319
How to pass external UserID to Odoo Online Webshop and store it in the Sales Order Solved
webshop URL
अवतार
अवतार
1
जून 25
1639
SEO problem. 403 errors, 404 errors and URL parameters
URL SEO
अवतार
अवतार
1
मार्च 25
3133
connect to external URL Solved
website URL
अवतार
अवतार
अवतार
3
नव॰ 24
7262
कम्यूनिटी
  • ट्यूटोरियल्स
  • दस्तावेज़
  • फ़ोरम
ओपन सोर्स
  • डाउनलोड
  • Github
  • रनबॉट
  • अनुवाद
सेवाएं
  • Odoo.sh Hosting
  • सहायता
  • अपग्रेड
  • कस्टम डेवलपमेंट्स
  • शिक्षा
  • अकाउंटेंट खोजें
  • पार्टनर ढूंढें
  • पार्टनर बनें
हमारे बारे में
  • हमारी कंपनी
  • ब्रांड ऐसेट
  • संपर्क करें
  • नौकरियां
  • इवेंट
  • पॉडकास्ट
  • ब्लॉग
  • ग्राहक
  • लीगल • गोपनीयता
  • सुरक्षा
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk Slovenščina Español (América Latina) Español Svenska ภาษาไทย Türkçe українська Tiếng Việt

Odoo, बिज़नेस से जुड़े ऐप्लिकेशन का एक कलेक्शन है जो ओपन सोर्स पर आधारित है. इसमें आपकी कंपनी की हर ज़रूरत के लिए ऐप्लिकेशन हैं. जैसे, सीआरएम, ई-कॉमर्स, अकाउंटिंग, इन्वेंट्री, पॉइंट ऑफ़ सेल, प्रोजेक्ट मैनेजमेंट वगैरह.

Odoo की सबसे बड़ी खासियत है कि यह इस्तेमाल करने में बहुत आसान है और यह पूरी तरह से इंटिग्रेट किया हुआ है.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now