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...

Redis installation in Red Hat Linux

 In this post we will see step by step installation of Redis service in Redhat/CentOS operation system. To install Redis, run this command in terminal -dnf install redis This command will install the redis service in your machine. Verify installation -systemctl status redis -systemctl start redis -systemctl enable redis Note: Before start redis service set Linux Kernal overcommit memory to 1 by adding vm.overcommit_memory = 1 to /etc/sysctl.conf file. Why we should do that: As we know redis is in memory data store. It primarily uses RAM to store data. Redis and other processes use RAM memory. We set vm.overcommit_memory = 1 to make sure Kernal not overcommit the memory by allocating memory to new program which required more memory than available memory. In this scenario OOM (Out Of Memory) killer terminate the rest of processes. We also restricting Kernal not to terminate the important services running and also stop swapping redis and other importance service to device i/o device,...

Prepared statements, form submission, form validation and displaying errors in php

PHP Code. Insert statement Query. INSERT INTO `users`(`user_id`, `user_first`, `user_last`, `user_email`, `user_uid`, `user_pwd`) VALUES (1,'Adnan','Zaib','text@.com','Admin',1234) What are Prepared statements and how to use them //Created a sql prepare template $sql = "SELECT * FROM users WHERE user_uid=?;"; //than send to database with certain values left(unspecified parameters). //Create a prepared statement $stmt = mysqli_stmt_init($conn);   //prepare the prepared statement if(!mysqli_stmt_prepare($stmt, $sql)){ echo "sql statement failed"; }else{ //bind values to parameters and further to placeholder mysqli_stmt_bind_param(#stmt, "s",); // ‘s’ stands for datatype of parameter that you are going to pass. }   while($row = mysqli_fetch_assoc($result)){ echo $row['user_uid'] . "<br>"; } PHP form Validation   <?php // define variables and set to empty values $name = $email = $gender = $comment = ...