Skip to main content

Custom fields in modules development in odoo

Different type of fields used in developing module 

name = fields.Char(string="School Name", help="This is school name")
email = fields.Char(string="Email")
phone = fields.Char(string="Phone")
school_rank = fields.Integer(string="Rank", default=lambda lm:lm.get_default_rank())
is_virtual = fields.Boolean()
results = fields.Float(string="results", default=0.00, help="This is tool tip", readonly=True)
address = fields.Text(string="Address", help="This is school permanent address", default="Pakistan", trim=False)
establish_date = fields.Date(string="Establish Date")
open_date = fields.Datetime("Open Date", default=fields.Datetime.now())

2. Upload any format file.

documents = fields.Binary(string="Document")
# to display file_name
document_name = fields.Char(string="File Name")

Show in the XML file.

<group>
<field name="documents" filename="document_name"/>
<field name="document_name" />
</group>

3. Upload only the image 

# Image field
# we have to define some parameter in this field so it will display image
# otherwise it will took it as Binary field
# By default verify_resolution is True.when we use it with False that feild nature change
# to binary field
school_image = fields.Image(string="Upload School Image", max_width=100, max_height=100)

Show in the XML file

<group>
<field name="school_image" widget="image" />
</group>

4. Editor-like summer-note field

# Editor text-area
school_description = fields.Html(string="About School")

Show in the XML file

<group>
<field name="school_description" />
</group>


Different attributes use in fields

1. Caracter field with tooltip ie. help="This is school name"

name = fields.Char(string="School Name", help="This is school name")

2. Read Only field

readonly=True

name = fields.Char(string="School Name", help="This is school name", readonly=True)

3. Required field

required = True

name = fields.Char(string="School Name", required=True)

4. Assign default value to field

default="some default value"

name = fields.Char(string="School Name", default="Oriel")

set default value of date time field

default=fields.Datetime.now()

5. max character support in field

size=15

name = fields.Char(string="School Name", size=15)

6. Index fields

Indexing is used to specify the column of a table used to get data, fast. By default it is false.

index=True

name = fields.Char(string="School Name", index=True)

7. Trim field

Not remove extra spaces

trim=False

name = fields.Char(string="School Name", trim=False)

8. Change the labeling of the field from xml form view

<field name="name" string="From XML Change" />

9. Make field readonly, required, placeholder in xml view form

<field name="email" readonly="1" />
<field name="email" required="1" />
<field name="email" placeholder="abc@example.com" />

10. Hide field using invisible attribute

<field name="email" invisible="1" />

11. Set the default value of a field by calling the method

school_rank = fields.Integer(string="Rank", default=lambda lm:lm.get_default_rank())
def get_default_rank(self):
if 1 == 1:
return 200
else:
return 100


Apply the above attributes in XML page

1. Change the field labeling.

string="This is the label"

2. Readonly 

readonly="1"

3. Hide field

invisible ="1"

4. Required field

required="1"





Comments

Popular posts from this blog

Install MariaDB Latest Version 11.4 in Red Hat Version 9

 This this post i will show you step by step the installation process of mariaDB in red hat version 9. Step1 Run the command to pull the latest updated packages on applications installed in your system. -dnf update If you get Kernal update than reboot the system -reboot Step2 Go to official mariaDB site Make mariadb repository in /etc/yum.repos.d Place the configuration in this file # MariaDB 11.4 RedHatEnterpriseLinux repository list - created 2024-09-24 11:12 UTC # https://mariadb.org/download/ [mariadb] name = MariaDB # rpm.mariadb.org is a dynamic mirror if your preferred mirror goes offline. See https://mariadb.org/mirrorbits/ for details. # baseurl = https://rpm.mariadb.org/11.4/rhel/$releasever/$basearch baseurl = https://mirrors.aliyun.com/mariadb/yum/11.4/rhel/$releasever/$basearch # gpgkey = https://rpm.mariadb.org/RPM-GPG-KEY-MariaDB gpgkey = https://mirrors.aliyun.com/mariadb/yum/RPM-GPG-KEY-MariaDB gpgcheck = 1 Now install the mariaDB with its dependencies package...

MySQL course to learn queries to manage DBMS.

1. Create Table CREATE TABLE statement allows you to create new table in database. The example code is given below.  create table profile( id int, name varchar(50), birth_date date, phone varchar(12), gender varchar(1) ); Code language: SQL (Structured Query Language) ( sql ) 2. Insert data in table INSERT INTO statement is use to insert new record/data into table. INSERT INTO profile (id, name, birth_date, phone, gender) VALUES (2, "Zaib", "1996-03-15", "9238975404", "M"); Code language: SQL (Structured Query Language) ( sql ) 3. Insert multiple records at-once INSERT INTO state is use to insert multiple new record/data into table. INSERT INTO profile (id, name, birth_date, phone, gender) VALUES (1, "Usamn ali", "1990-08-26", "9238785094", "M", 18, "Karachi"), (2, "Aisha", "1997-06-12", "9238974468", "F", 19, "Lahore"), ...

Send email in php "without less secure" restriction

 => https://www.youtube.com/watch?v=Kjn5vBbBsi8 (less secure link) https://www.youtube.com/watch?v=dNTZ8X9Xk_Q&t=259s https://www.thapatechnical.com/2020/03/how-to-send-mail-from-localhost-xampp.html LARAVEL env file setup for gmail configuration MAIL_DRIVER=smtp MAIL_HOST=smtp.gmail.com MAIL_PORT=465 MAIL_USERNAME=exampleEmail@gmail.com MAIL_PASSWORD=yourAppPassword MAIL_ENCRYPTION=ssl MAIL_FROM_ADDRESS=exampleEmail@gmail.com MAIL_FROM_NAME="Adnan Zaib" Note: for TLS use Port : 587 for SSL use Port : 465