Skip to Content
Odoo मेन्यू
  • Sign in
  • मुफ़्त में आज़माएं
  • ऐप्लिकेशन
    फ़ाइनेंस
    • अकाउंटिंग
    • इनवॉइसिंग
    • एक्सपेंस
    • स्प्रेडशीट (बीआई)
    • डॉक्यूमेंट्स
    • साइन
    सेल्स
    • सीआरएम
    • सेल्स
    • पीओएस शॉप
    • पीओएस रेस्टोरेंट
    • सब्सक्रिप्शन
    • रेंटल
    वेबसाइट
    • वेबसाइट बिल्डर
    • ई-कॉमर्स
    • ब्लॉग
    • फ़ोरम
    • लाइव चैट
    • ई-लर्निंग
    सप्लाई चेन
    • इन्वेंट्री
    • मैन्युफ़ैक्चरिंग
    • पीएलएम
    • परचेज़
    • मेंटेनेंस
    • क्वालिटी
    मानव संसाधन
    • कर्मचारी
    • रिक्रूटमेंट
    • टाइम ऑफ़
    • अप्रेज़ल
    • रेफ़रल
    • फ़्लीट
    मार्केटिंग
    • सोशल मार्केटिंग
    • ईमेल मार्केटिंग
    • एसएमएस मार्केटिंग
    • इवेंट
    • मार्केटिंग ऑटोमेशन
    • सर्वे
    सेवाएं
    • प्रोजेक्ट
    • टाइमशीट
    • फ़ील्ड सर्विस
    • हेल्पडेस्क
    • प्लानिंग
    • अपॉइंटमेंट
    प्रॉडक्टिविटी
    • डिस्कस
    • अप्रूवल
    • आईओटी
    • वीओआईपी
    • नॉलेज
    • WhatsApp
    तीसरे पक्ष के ऐप्लिकेशन Odoo स्टूडियो Odoo क्लाउड प्लेटफ़ॉर्म
  • इंडस्ट्री
    रीटेल
    • बुक स्टोर
    • क्लोदिंग स्टोर
    • फ़र्नीचर स्टोर
    • ग्रॉसरी स्टोर
    • हार्डवेयर स्टोर
    • टॉय स्टोर
    Food & Hospitality
    • बार और पब
    • रेस्टोरेंट
    • फ़ास्ट फ़ूड
    • Guest House
    • बेवरिज डिस्ट्रीब्यूटर
    • होटल
    रियल एस्टेट
    • Real Estate Agency
    • आर्किटेक्चर फ़र्म
    • कंसट्रक्शन
    • एस्टेट मैनेजमेंट
    • गार्ड्निंग
    • प्रॉपर्टी ओनर असोसिएशन
    कंसल्टिंग
    • अकाउंटिंग फ़र्म
    • Odoo पार्टनर
    • मार्केटिंग एजेंसी
    • लॉ फ़र्म
    • टैलेंट ऐक्विज़िशन
    • ऑडिट & सर्टिफ़िकेशन
    मैन्युफ़ैक्चरिंग
    • टेक्सटाइल
    • Metal
    • फ़र्नीचर
    • फ़ूड
    • Brewery
    • कॉर्पोरेट गिफ़्ट
    हेल्थ & फिटनेस
    • स्पोर्ट्स क्लब
    • आईवियर स्टोर
    • फिटनेस सेंटर
    • वेलनेस प्रैक्टिशनर
    • फॉर्मेसी
    • हेयर सैलून
    Trades
    • Handyman
    • आईटी हॉर्डवेयर और सपोर्ट
    • Solar Energy Systems
    • Shoe Maker
    • Cleaning Services
    • HVAC Services
    अन्य
    • Nonprofit Organization
    • एन्वायरमेंटल एजेंसी
    • बिलबोर्ड रेंटल
    • फ़ोटोग्राफी
    • बाइक लीजिंग
    • सॉफ़्टवेयर रीसेलर
    Browse all Industries
  • कम्यूनिटी
    सीखें
    • ट्यूटोरियल्स
    • दस्तावेज़
    • सर्टिफ़िकेशन
    • ट्रेनिंग
    • ब्लॉग
    • पॉडकास्ट
    शिक्षा को बढ़ावा दें
    • एजुकेशन प्रोग्राम
    • स्केल अप! बिजनेस गेम
    • Odoo के ऑफ़िस में आएं
    सॉफ़्टवेयर पाएं
    • डाउनलोड
    • वर्शन की तुलना करें
    • रिलीज़
    साथ मिलकर काम करें
    • Github
    • फ़ोरम
    • इवेंट
    • अनुवाद
    • पार्टनर बनें
    • Services for Partners
    • अपना अकाउंटिंग फ़र्म रजिस्टर करें
    सेवाएं पाएं
    • पार्टनर ढूंढें
    • अकाउंटेंट खोजें
    • सलाहकार की मदद लें
    • इम्प्लिमेंटेशन सेवाएं
    • कस्टमर रेफ़रेंस
    • सहायता
    • अपग्रेड
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    डेमो देखें
  • कीमत
  • सहायता

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • सीआरएम
  • e-Commerce
  • लेखांकन
  • इन्वेंटरी
  • PoS
  • प्रोजेक्ट
  • MRP
All apps
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
Help

KeyNotFoundError: Cannot find key "distribution_location_partner_form_view" in the "views" registry

Subscribe

Get notified when there's activity on this post

This question has been flagged
jsPOSOdoov18
397 Views
Avatar
Walter

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

<odoo>

    <data>

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

            <field name="name">res.partner.form.view.inherit</field>

            <field name="model">res.partner</field>

            <field name="inherit_id" ref="base.view_partner_form" />

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

                <xpath expr="//form" position="attributes">

                    <attribute name="js_class">distribution_location_partner_form_view</attribute>

                </xpath>

            </field>

        </record>

    </data>

</odoo>



/** @odoo-module */


import { rpc } from '@web/core/network/rpc'

import { registry } from "@web/core/registry"

import { useService } from "@web/core/utils/hooks"

import { FormController } from "@web/views/form/form_controller"

import { formView } from "@web/views/form/form_view"


class ResPartnerFormController extends FormController {

    setup() {

        super.setup()

        this.notification = useService("notification")

    }


    // 📸 Existing feature: location + photo upload

    async onLocationClick() {

        const currentRecord = this.model.root.data

        const partnerName = currentRecord.name


        if (navigator.geolocation) {

            navigator.geolocation.getCurrentPosition(

                async (position) => {

                    const lat = position.coords.latitude

                    const lon = position.coords.longitude


                    const fileInput = document.createElement("input")

                    fileInput.type = "file"

                    fileInput.accept = "image/*"


                    fileInput.onchange = async (event) => {

                        const file = event.target.files[0]

                        if (!file) {

                            this.notification.add("Photo is required!", {

                                title: "Error",

                                type: "danger",

                            })

                            return

                        }


                        const reader = new FileReader()

                        reader.onload = async () => {

                            const photoBase64 = reader.result.split(",")[1]


                            const result = await rpc("/partner/checkin", {

                                partner_name: partnerName,

                                lat: lat,

                                lon: lon,

                                photo: photoBase64,

                            })


                            if (result.success) {

                                this.notification.add(result.message, {

                                    title: "Success",

                                    type: "success",

                                })

                            } else {

                                this.notification.add(result.message, {

                                    title: "Error",

                                    type: "danger",

                                })

                            }

                        }

                        reader.readAsDataURL(file)

                    }

                    fileInput.click()

                },

                () => {

                    this.notification.add("Location retrieval failed", {

                        title: "Error",

                        type: "danger",

                    })

                }

            )

        }

    }


    // 📍 New feature: only save location to partner fields

    async onSaveLocationClick() {

        const currentRecord = this.model.root.data

        const partnerId = this.model.root.resId  // Use resId instead of data.id

        const partnerName = currentRecord.name


        console.log("Debug - Partner ID:", partnerId, "Partner Name:", partnerName)


        // Check if record is saved

        if (!partnerId || partnerId === false) {

            this.notification.add("Please save the partner record first before capturing location", {

                title: "Warning",

                type: "warning",

            })

            return

        }


        if (!navigator.geolocation) {

            this.notification.add("Geolocation is not supported by your browser", {

                title: "Error",

                type: "danger",

            })

            return

        }


        navigator.geolocation.getCurrentPosition(

            async (position) => {

                const lat = position.coords.latitude

                const lon = position.coords.longitude


                try {

                    const result = await rpc("/partner/save_location", {

                        partner_id: partnerId,

                        lat: lat,

                        lon: lon,

                    })


                    if (result.success) {

                        this.notification.add(result.message, {

                            title: "Success",

                            type: "success",

                        })

                        await this.model.root.load() // refresh form to show updated values

                    } else {

                        this.notification.add(result.message, {

                            title: "Error",

                            type: "danger",

                        })

                    }

                } catch (error) {

                    console.error("RPC Error:", error)

                    this.notification.add("Failed to save location: " + error.message, {

                        title: "Error",

                        type: "danger",

                    })

                }

            },

            (error) => {

                let errorMsg = "Failed to get location"

                switch (error.code) {

                    case error.PERMISSION_DENIED:

                        errorMsg = "Location permission denied. Please enable location access."

                        break

                    case error.POSITION_UNAVAILABLE:

                        errorMsg = "Location information unavailable."

                        break

                    case error.TIMEOUT:

                        errorMsg = "Location request timed out."

                        break

                }

                this.notification.add(errorMsg, {

                    title: "Error",

                    type: "danger",

                })

            }

        )

    }

}


ResPartnerFormController.template = "distribution_location.ResPartnerFormView"


export const resPartnerFormView = {

    ...formView,

    Controller: ResPartnerFormController,

}


registry.category("views").add(

    "distribution_location_partner_form_view",

    resPartnerFormView,

)

It works fine on the Contacts page, but when I try to add a new customer from the POS page, I get an error


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

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

Sign up
Related Posts Replies Views Activity
Can concepts be predefined for Cash In/Out?
POS
Avatar
Avatar
2
सित॰ 25
787
Prevent display of form view from list view of v18 when row was clicked
Odoov18
Avatar
Avatar
2
अक्तू॰ 24
3327
how to using dataavailable in js
js
Avatar
Avatar
1
जून 23
2752
Can not open wizard from PivotRenderer
js
Avatar
Avatar
1
मई 23
2693
odoo 15 js this.do_notify
js
Avatar
Avatar
1
अक्तू॰ 22
4899
कम्यूनिटी
  • ट्यूटोरियल्स
  • दस्तावेज़
  • फ़ोरम
ओपन सोर्स
  • डाउनलोड
  • 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 ภาษาไทย 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