@ -0,0 +1,48 @@ |
|||||
|
.. image:: https://img.shields.io/badge/license-AGPL--3-blue.svg |
||||
|
:target: https://www.gnu.org/licenses/agpl-3.0-standalone.html |
||||
|
:alt: License: AGPL-3 |
||||
|
|
||||
|
POS Booking Order |
||||
|
================= |
||||
|
The module helps you to book orders from Shop,Bar/Restaurant in POS.User can create pickup or delivery orders,later confirm booked orders to POS orders |
||||
|
|
||||
|
Configuration |
||||
|
============= |
||||
|
No additional configuration required |
||||
|
|
||||
|
Company |
||||
|
------- |
||||
|
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__ |
||||
|
|
||||
|
License |
||||
|
------- |
||||
|
GNU Affero General Public License v3.0 (AGPL v3) |
||||
|
(http://www.gnu.org/licenses/agpl-3.0-standalone.html) |
||||
|
|
||||
|
Credits |
||||
|
------- |
||||
|
Developer: (v17) Ranjith R @cybrosys |
||||
|
(v12) Varsha Vivek @cybrosys |
||||
|
|
||||
|
Contacts |
||||
|
-------- |
||||
|
* Mail Contact : odoo@cybrosys.com |
||||
|
* Website : https://cybrosys.com |
||||
|
|
||||
|
Bug Tracker |
||||
|
----------- |
||||
|
Bugs are tracked on GitHub Issues. In case of trouble, please check there if |
||||
|
your issue has already been reported. |
||||
|
|
||||
|
Maintainer |
||||
|
========== |
||||
|
.. image:: https://cybrosys.com/images/logo.png |
||||
|
:target: https://cybrosys.com |
||||
|
|
||||
|
This module is maintained by Cybrosys Technologies. |
||||
|
|
||||
|
For support and more information, please visit `Our Website <https://cybrosys.com/>`__ |
||||
|
|
||||
|
Further information |
||||
|
=================== |
||||
|
HTML Description: `<static/description/index.html>`__ |
@ -0,0 +1,22 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################### |
||||
|
# |
||||
|
# Cybrosys Technologies Pvt. Ltd. |
||||
|
# |
||||
|
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
||||
|
# Author: Ranjith R (odoo@cybrosys.com) |
||||
|
# |
||||
|
# You can modify it under the terms of the GNU AFFERO |
||||
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
||||
|
# (AGPL v3) along with this program. |
||||
|
# If not, see <http://www.gnu.org/licenses/>. |
||||
|
# |
||||
|
############################################################################### |
||||
|
from . import models |
@ -0,0 +1,60 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################### |
||||
|
# |
||||
|
# Cybrosys Technologies Pvt. Ltd. |
||||
|
# |
||||
|
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
||||
|
# Author: Ranjith R (odoo@cybrosys.com) |
||||
|
# |
||||
|
# You can modify it under the terms of the GNU AFFERO |
||||
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
||||
|
# (AGPL v3) along with this program. |
||||
|
# If not, see <http://www.gnu.org/licenses/>. |
||||
|
# |
||||
|
############################################################################### |
||||
|
{ |
||||
|
'name': 'POS Booking Order', |
||||
|
'version': '17.0.1.0.0', |
||||
|
'category': 'Point of Sale', |
||||
|
'summary': """From a POS session, users can create pickup or |
||||
|
delivery orders, which they can then confirm as POS orders.""", |
||||
|
'description': """The module helps you to book orders from Shop, |
||||
|
Bar/Restaurant in POS.User can create pickup or delivery |
||||
|
orders,later confirm booked orders to POS orders.""", |
||||
|
'author': 'Cybrosys Techno Solutions', |
||||
|
'company': 'Cybrosys Techno Solutions', |
||||
|
'maintainer': 'Cybrosys Techno Solutions', |
||||
|
'website': "https://www.cybrosys.com", |
||||
|
'depends': ['base', 'point_of_sale'], |
||||
|
'data': ['security/ir.model.access.csv', |
||||
|
'data/ir_sequence_data.xml', |
||||
|
'views/pos_config_views.xml', |
||||
|
'views/book_order_views.xml', |
||||
|
'views/pos_order_views.xml' |
||||
|
], |
||||
|
'assets': { |
||||
|
'point_of_sale._assets_pos': [ |
||||
|
'pos_book_order/static/src/xml/Buttons.xml', |
||||
|
'pos_book_order/static/src/xml/BookOrderPopup.xml', |
||||
|
'pos_book_order/static/src/xml/BookedOrdersScreen.xml', |
||||
|
'pos_book_order/static/src/xml/OrderReceipt.xml', |
||||
|
'pos_book_order/static/src/js/BookOrderPopup.js', |
||||
|
'pos_book_order/static/src/js/BookOrderButton.js', |
||||
|
'pos_book_order/static/src/js/BookedOrdersButton.js', |
||||
|
'pos_book_order/static/src/js/BookedOrdersScreen.js', |
||||
|
'pos_book_order/static/src/js/models.js', |
||||
|
], |
||||
|
}, |
||||
|
'images': ['static/description/banner.png'], |
||||
|
'license': 'AGPL-3', |
||||
|
'installable': True, |
||||
|
'auto_install': False, |
||||
|
'application': False, |
||||
|
} |
@ -0,0 +1,11 @@ |
|||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||
|
<odoo> |
||||
|
<!--This record for adding sequence to book.order--> |
||||
|
<record id="sequence_book_order" model="ir.sequence"> |
||||
|
<field name="name">Book Order</field> |
||||
|
<field name="code">book.order</field> |
||||
|
<field name="prefix">POS/BO/</field> |
||||
|
<field name="padding">4</field> |
||||
|
<field name="company_id" eval="False"/> |
||||
|
</record> |
||||
|
</odoo> |
@ -0,0 +1,7 @@ |
|||||
|
## Module <pos_book_order> |
||||
|
|
||||
|
#### 11.01.2024 |
||||
|
#### Version 17.0.1.0.0 |
||||
|
##### ADD |
||||
|
- Initial Commit for POS Booking Order |
||||
|
|
@ -0,0 +1,25 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################### |
||||
|
# |
||||
|
# Cybrosys Technologies Pvt. Ltd. |
||||
|
# |
||||
|
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
||||
|
# Author: Ranjith R (odoo@cybrosys.com) |
||||
|
# |
||||
|
# You can modify it under the terms of the GNU AFFERO |
||||
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
||||
|
# (AGPL v3) along with this program. |
||||
|
# If not, see <http://www.gnu.org/licenses/>. |
||||
|
# |
||||
|
############################################################################### |
||||
|
from . import book_order |
||||
|
from . import book_order_line |
||||
|
from . import pos_config |
||||
|
from . import pos_order |
@ -0,0 +1,192 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################### |
||||
|
# |
||||
|
# Cybrosys Technologies Pvt. Ltd. |
||||
|
# |
||||
|
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
||||
|
# Author: Ranjith R (odoo@cybrosys.com) |
||||
|
# |
||||
|
# You can modify it under the terms of the GNU AFFERO |
||||
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
||||
|
# (AGPL v3) along with this program. |
||||
|
# If not, see <http://www.gnu.org/licenses/>. |
||||
|
# |
||||
|
############################################################################### |
||||
|
from odoo import api, fields, models |
||||
|
from odoo.fields import Command |
||||
|
|
||||
|
|
||||
|
class BookOrder(models.Model): |
||||
|
""" |
||||
|
Model for managing booked orders in the POS system. |
||||
|
""" |
||||
|
_name = 'book.order' |
||||
|
_description = "Point of Sale Booked Orders" |
||||
|
|
||||
|
@api.model |
||||
|
def _amount_line_tax(self, line, fiscal_position_id): |
||||
|
""" Calculates the tax amount of the order line. |
||||
|
:param line: Order line record |
||||
|
:param fiscal_position_id: Fiscal position account for order |
||||
|
:return float: Total tax amount as float |
||||
|
""" |
||||
|
taxes = line.tax_ids.filtered( |
||||
|
lambda t: t.company_id.id == line.order_id.company_id.id) |
||||
|
taxes = fiscal_position_id.map_tax(taxes) |
||||
|
price = line.price_unit * (1 - (line.discount or 0.0) / 100.0) |
||||
|
taxes = taxes.compute_all(price, |
||||
|
line.order_id.pricelist_id.currency_id, |
||||
|
line.qty, product=line.product_id, |
||||
|
partner=line.order_id.partner_id or False)[ |
||||
|
'taxes'] |
||||
|
return sum(tax.get('amount', 0.0) for tax in taxes) |
||||
|
|
||||
|
name = fields.Char(string='Booking Ref', readonly=True, |
||||
|
help="Name of the booked order", |
||||
|
copy=False, default='/') |
||||
|
company_id = fields.Many2one('res.company', string='Company', |
||||
|
help="Company of the booked order", |
||||
|
default=lambda self: self.env.user.company_id) |
||||
|
date_quotation = fields.Datetime(string='Quotation Date', |
||||
|
help="Quotation created date", |
||||
|
readonly=True, index=True, |
||||
|
default=fields.Datetime.now) |
||||
|
date_order = fields.Date(string='Order Date', help="Order created date", |
||||
|
readonly=True, index=True, |
||||
|
default=fields.Date.today()) |
||||
|
amount_tax = fields.Float(compute='_compute_amount_all', string='Taxes', |
||||
|
help="Tax amount for the order", |
||||
|
dig06its=0, default=1.2) |
||||
|
amount_total = fields.Float(compute='_compute_amount_all', string='Total', |
||||
|
help="Total amount of the order", |
||||
|
digits=0) |
||||
|
book_line_ids = fields.One2many('book.order.line', |
||||
|
'order_id', |
||||
|
help="Order Line of book orders", |
||||
|
string='Order Lines', |
||||
|
copy=True) |
||||
|
partner_id = fields.Many2one('res.partner', string='Customer', |
||||
|
help="Partner of the order", |
||||
|
change_default=True, index=True) |
||||
|
state = fields.Selection([('draft', 'New'), |
||||
|
('confirmed', 'Confirmed')], |
||||
|
string='Status', readonly=True, copy=False, |
||||
|
help="Current status of the order", |
||||
|
default='draft') |
||||
|
note = fields.Text(string='Internal Notes', |
||||
|
help="Enter any notes regarding order") |
||||
|
fiscal_position_id = fields.Many2one('account.fiscal.position', |
||||
|
help="Fiscal position account " |
||||
|
"for order", |
||||
|
string='Fiscal Position') |
||||
|
pickup_date = fields.Datetime(string='Pickup Date', readonly=True, |
||||
|
help="Picking date of the order") |
||||
|
deliver_date = fields.Datetime(string='Deliver Date', readonly=True, |
||||
|
help="Delivering date of the order") |
||||
|
phone = fields.Char('Contact no', help='Phone of customer for delivery') |
||||
|
delivery_address = fields.Char(string='Delivery Address', |
||||
|
help='Address of customer for delivery') |
||||
|
pricelist_id = fields.Many2one('product.pricelist', |
||||
|
string='Pricelist', |
||||
|
help="Pricelist of the order") |
||||
|
|
||||
|
@api.depends('book_line_ids.price_subtotal_incl', |
||||
|
'book_line_ids.discount') |
||||
|
def _compute_amount_all(self): |
||||
|
""" To compute total amount with tax and without tax """ |
||||
|
for order in self: |
||||
|
order.amount_tax = 0.0 |
||||
|
currency = self.env.company.currency_id |
||||
|
order.amount_tax = currency.round( |
||||
|
sum(self._amount_line_tax(line, order.fiscal_position_id) for |
||||
|
line in order.book_line_ids)) |
||||
|
amount_untaxed = currency.round( |
||||
|
sum(line.price_subtotal for line in order.book_line_ids)) |
||||
|
order.amount_total = order.amount_tax + amount_untaxed |
||||
|
|
||||
|
@api.model |
||||
|
def create(self, vals): |
||||
|
""" Inherited create function to generate sequence number |
||||
|
for booker orders |
||||
|
:return record: created record |
||||
|
""" |
||||
|
if vals.get('name', '/') == '/': |
||||
|
vals['name'] = self.env['ir.sequence'].next_by_code( |
||||
|
'book.order') or '/' |
||||
|
return super(BookOrder, self).create(vals) |
||||
|
|
||||
|
def action_confirm(self): |
||||
|
""" Function to confirm the book order""" |
||||
|
self.write({ |
||||
|
'state': 'confirmed', |
||||
|
}) |
||||
|
|
||||
|
@api.model |
||||
|
def create_booked_order(self, partner, phone, address, date, price_list, |
||||
|
product, note, pickup_date, delivery_date): |
||||
|
""" It creates a booked order based on the value in the booking popup |
||||
|
in PoS ui. |
||||
|
partner(int): id of partner |
||||
|
phone(string): contact number of customer |
||||
|
address(string): contact address of the customer |
||||
|
date(date): ordered date |
||||
|
price_list(int): price list id of order |
||||
|
product(dict): dictionary values with product ids and quantity |
||||
|
note(string): Order note |
||||
|
pickup(date): pickup date of the booked order |
||||
|
delivery(date): delivery date of the booked order |
||||
|
""" |
||||
|
order = self.create({ |
||||
|
'partner_id': partner, |
||||
|
'phone': phone, |
||||
|
'delivery_address': address, |
||||
|
'pricelist_id': price_list if price_list else False, |
||||
|
'date_quotation': fields.Date.today(), |
||||
|
'book_line_ids': [Command.create({ |
||||
|
'product_id': product['product_id'][i], |
||||
|
'qty': product['qty'][i], |
||||
|
'price_unit': product['price'][i], |
||||
|
}) for i in range(len(product['product_id']))], |
||||
|
'note': note, |
||||
|
}) |
||||
|
if pickup_date: |
||||
|
order.write({'pickup_date': pickup_date + ' 00:00:00'}) |
||||
|
if delivery_date: |
||||
|
order.write({'deliver_date': delivery_date + ' 00:00:00'}) |
||||
|
|
||||
|
@api.model |
||||
|
def all_orders(self): |
||||
|
""" To fetch all draft stage orders to PoS Booked orders screen |
||||
|
:return dict: A list of dictionaries containing information |
||||
|
about each order |
||||
|
""" |
||||
|
values = [] |
||||
|
for rec in self.search([('state', '=', 'draft')]): |
||||
|
products = [] |
||||
|
for line in rec.book_line_ids: |
||||
|
products.append({ |
||||
|
'id': line.product_id.id, |
||||
|
'qty': line.qty, |
||||
|
'price': line.price_unit |
||||
|
}) |
||||
|
values.append({'id': rec.id, |
||||
|
'name': rec.name, |
||||
|
'partner_id': rec.partner_id.id, |
||||
|
'partner_name': rec.partner_id.name, |
||||
|
'address': rec.delivery_address, |
||||
|
'note': rec.note, |
||||
|
'phone': rec.phone, |
||||
|
'date': rec.date_quotation, |
||||
|
'pickup': rec.pickup_date, |
||||
|
'deliver': rec.deliver_date, |
||||
|
'products': products, |
||||
|
'total': rec.amount_total |
||||
|
}) |
||||
|
return values |
@ -0,0 +1,86 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################### |
||||
|
# |
||||
|
# Cybrosys Technologies Pvt. Ltd. |
||||
|
# |
||||
|
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
||||
|
# Author: Ranjith R (odoo@cybrosys.com) |
||||
|
# |
||||
|
# You can modify it under the terms of the GNU AFFERO |
||||
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
||||
|
# (AGPL v3) along with this program. |
||||
|
# If not, see <http://www.gnu.org/licenses/>. |
||||
|
# |
||||
|
############################################################################### |
||||
|
from odoo import api, fields, models |
||||
|
|
||||
|
|
||||
|
class BookOrderLine(models.Model): |
||||
|
""" For managing order lines of booked order """ |
||||
|
_name = "book.order.line" |
||||
|
_description = "Lines of Point of Sale Booked Order" |
||||
|
_rec_name = "product_id" |
||||
|
|
||||
|
company_id = fields.Many2one('res.company', string='Company', |
||||
|
help="Company of the booked order", |
||||
|
default=lambda self: self.env.user.company_id) |
||||
|
product_id = fields.Many2one('product.product', |
||||
|
help="Select products for ordering", |
||||
|
string='Product', |
||||
|
domain=[('sale_ok', '=', True)], |
||||
|
required=True, change_default=True) |
||||
|
price_unit = fields.Float(string='Unit Price', |
||||
|
help="Unite price of selected product", digits=0) |
||||
|
qty = fields.Float(string='Quantity', default=1, |
||||
|
help="Enter how much quantity of product want ") |
||||
|
price_subtotal = fields.Float(compute='_compute_amount_line_all', |
||||
|
digits=0, |
||||
|
help="Sub total amount of each order line" |
||||
|
"without tax", |
||||
|
string='Subtotal w/o Tax') |
||||
|
price_subtotal_incl = fields.Float(compute='_compute_amount_line_all', |
||||
|
digits=0, string='Subtotal', |
||||
|
help="Sub total amount of each order " |
||||
|
"line with tax") |
||||
|
discount = fields.Float(string='Discount (%)', digits=0, default=0.0, |
||||
|
help="You can apply discount for each product") |
||||
|
order_id = fields.Many2one('book.order', string='Order Ref', |
||||
|
help="Relation to book order field", |
||||
|
ondelete='cascade') |
||||
|
tax_ids = fields.Many2many('account.tax', string='Taxes', |
||||
|
readonly=True, help="Taxes for each line") |
||||
|
tax_after_fiscal_position_ids = fields.Many2many( |
||||
|
'account.tax', 'account_tax_rel', 'uid', |
||||
|
'tag_id', string='Taxes', help="Fiscal position after entering " |
||||
|
"the tax") |
||||
|
|
||||
|
@api.depends('price_unit', 'tax_ids', 'qty', 'discount', 'product_id') |
||||
|
def _compute_amount_line_all(self): |
||||
|
""" To compute tax included and excluded subtotal in each line""" |
||||
|
for line in self: |
||||
|
currency = self.env.company.currency_id |
||||
|
taxes = line.tax_ids.filtered( |
||||
|
lambda tax: tax.company_id.id == line.order_id.company_id.id) |
||||
|
fiscal_position_id = line.order_id.fiscal_position_id |
||||
|
if fiscal_position_id: |
||||
|
taxes = fiscal_position_id.map_tax(taxes, line.product_id, |
||||
|
line.order_id.partner_id) |
||||
|
price = line.price_unit * (1 - (line.discount or 0.0) / 100.0) |
||||
|
line.price_subtotal = line.price_subtotal_incl = price * line.qty |
||||
|
if taxes: |
||||
|
taxes = taxes.compute_all(price, currency, line.qty, |
||||
|
product=line.product_id, |
||||
|
partner=line.order_id.partner_i or |
||||
|
False) |
||||
|
line.price_subtotal = taxes['total_excluded'] |
||||
|
line.price_subtotal_incl = taxes['total_included'] |
||||
|
|
||||
|
line.price_subtotal = currency.round(line.price_subtotal) |
||||
|
line.price_subtotal_incl = currency.round(line.price_subtotal_incl) |
@ -0,0 +1,30 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################### |
||||
|
# |
||||
|
# Cybrosys Technologies Pvt. Ltd. |
||||
|
# |
||||
|
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
||||
|
# Author: Ranjith R (odoo@cybrosys.com) |
||||
|
# |
||||
|
# You can modify it under the terms of the GNU AFFERO |
||||
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
||||
|
# (AGPL v3) along with this program. |
||||
|
# If not, see <http://www.gnu.org/licenses/>. |
||||
|
# |
||||
|
############################################################################### |
||||
|
from odoo import fields, models |
||||
|
|
||||
|
|
||||
|
class PosConfig(models.Model): |
||||
|
"""POS configuration settings""" |
||||
|
_inherit = 'pos.config' |
||||
|
|
||||
|
enable = fields.Boolean(string="Enable Book Orders", |
||||
|
help="Enable if you want to book order from pos") |
@ -0,0 +1,46 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################### |
||||
|
# |
||||
|
# Cybrosys Technologies Pvt. Ltd. |
||||
|
# |
||||
|
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
||||
|
# Author: Ranjith R (odoo@cybrosys.com) |
||||
|
# |
||||
|
# You can modify it under the terms of the GNU AFFERO |
||||
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
||||
|
# (AGPL v3) along with this program. |
||||
|
# If not, see <http://www.gnu.org/licenses/>. |
||||
|
# |
||||
|
############################################################################### |
||||
|
from odoo import api, fields, models |
||||
|
|
||||
|
|
||||
|
class PosOrder(models.Model): |
||||
|
"""Inherited model for pos order,all confirmed booking orders are converted |
||||
|
as pos orders""" |
||||
|
_inherit = 'pos.order' |
||||
|
|
||||
|
booking_ref_id = fields.Many2one( |
||||
|
'book.order', string='Booking Ref', |
||||
|
help="Booked order reference for the pos order") |
||||
|
|
||||
|
@api.model |
||||
|
def _order_fields(self, ui_order): |
||||
|
"""Overriding to pass value of booked order ref to PoS order |
||||
|
ui_order(dict): dictionary of pos order field values |
||||
|
dict: returns dictionary of pos order field values |
||||
|
""" |
||||
|
order_fields = super(PosOrder, self)._order_fields(ui_order) |
||||
|
if ui_order.get('is_booked'): |
||||
|
order_fields['booking_ref_id'] = ui_order.get('booked_data')['id'] |
||||
|
self.env['book.order'].browse( |
||||
|
ui_order.get('booked_data')['id']).write( |
||||
|
{'state': 'confirmed'}) |
||||
|
return order_fields |
|
After Width: | Height: | Size: 36 KiB |
After Width: | Height: | Size: 3.6 KiB |
After Width: | Height: | Size: 310 B |
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 576 B |
After Width: | Height: | Size: 733 B |
After Width: | Height: | Size: 911 B |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 673 B |
After Width: | Height: | Size: 11 KiB |
After Width: | Height: | Size: 878 B |
After Width: | Height: | Size: 653 B |
After Width: | Height: | Size: 905 B |
After Width: | Height: | Size: 839 B |
After Width: | Height: | Size: 427 B |
After Width: | Height: | Size: 627 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 988 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 80 KiB |
After Width: | Height: | Size: 3.2 KiB |
After Width: | Height: | Size: 565 B |
After Width: | Height: | Size: 26 KiB |
After Width: | Height: | Size: 43 KiB |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 4.0 KiB |
After Width: | Height: | Size: 38 KiB |
After Width: | Height: | Size: 4.3 KiB |
After Width: | Height: | Size: 87 KiB |
After Width: | Height: | Size: 80 KiB |
After Width: | Height: | Size: 95 KiB |
After Width: | Height: | Size: 78 KiB |
After Width: | Height: | Size: 164 KiB |
After Width: | Height: | Size: 81 KiB |
After Width: | Height: | Size: 78 KiB |
After Width: | Height: | Size: 82 KiB |
After Width: | Height: | Size: 81 KiB |
After Width: | Height: | Size: 85 KiB |
After Width: | Height: | Size: 85 KiB |
After Width: | Height: | Size: 82 KiB |
After Width: | Height: | Size: 118 KiB |
After Width: | Height: | Size: 120 KiB |
After Width: | Height: | Size: 193 KiB |
After Width: | Height: | Size: 200 KiB |
After Width: | Height: | Size: 211 KiB |
After Width: | Height: | Size: 68 KiB |
After Width: | Height: | Size: 206 KiB |
After Width: | Height: | Size: 125 KiB |
After Width: | Height: | Size: 134 KiB |
After Width: | Height: | Size: 95 KiB |
After Width: | Height: | Size: 327 KiB |
After Width: | Height: | Size: 44 KiB |
After Width: | Height: | Size: 12 KiB |
@ -0,0 +1,691 @@ |
|||||
|
<!DOCTYPE html> |
||||
|
<html lang="en"> |
||||
|
|
||||
|
<head> |
||||
|
<meta charset="UTF-8"> |
||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
||||
|
<title>Odoo App 3 Index</title> |
||||
|
<!-- Bootstrap CSS --> |
||||
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.0.0/dist/css/bootstrap.min.css" |
||||
|
integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous"> |
||||
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.2.1/css/all.min.css"> |
||||
|
<link rel="preconnect" href="https://fonts.googleapis.com"> |
||||
|
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> |
||||
|
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap" rel="stylesheet"> |
||||
|
</head> |
||||
|
<body> |
||||
|
<section> |
||||
|
<div class="container" style="font-family: 'Inter', sans-serif !important;background-color: #fff !important;"> |
||||
|
<div class="row"> |
||||
|
<div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between flex-wrap align-items-sm-center" |
||||
|
style="border-bottom:1px solid rgba(0, 0, 0, 0.22)"> |
||||
|
<div class="my-3"> |
||||
|
<img src="assets/misc/Cybrosys R.png" style="width:auto !important; height:40px !important"> |
||||
|
</div> |
||||
|
<div class="my-3 d-flex align-items-center"> |
||||
|
<div class="text-center" |
||||
|
style="background-color:#017E84 !important;font-size: 0.8rem !important; color:#fff !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;"> |
||||
|
Community |
||||
|
</div> |
||||
|
<div class="text-center" |
||||
|
style="background-color:#875A7B !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important;min-width: 120px !important;"> |
||||
|
Enterprise |
||||
|
</div> |
||||
|
<div class="text-center" |
||||
|
style="background-color:#7C7BAD !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;"> |
||||
|
Odoo.sh |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="row"> |
||||
|
<div class="col-sm-12 col-md-12 col-lg-12 text-center d-flex align-items-center flex-column" |
||||
|
style="margin: 80px 0px !important;"> |
||||
|
<h1 style="font-size: 2.8rem;font-weight: 700; color: |
||||
|
#1A202C;"> |
||||
|
POS Booking Order</h1> |
||||
|
<p class="my-3 mb-4" |
||||
|
style="max-width: 80%; font-weight: 400 !important; line-height: 32px; color: #718096;"> |
||||
|
Book orders for customers in the POS |
||||
|
</p> |
||||
|
<div style="width: 80%; margin-top: 3rem;"> |
||||
|
<img src="assets/screenshots/hero.gif" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="container mt-5 mb-5"> |
||||
|
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4"> |
||||
|
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#714b67 !important">Key Highlights |
||||
|
</p> |
||||
|
</div> |
||||
|
<div class="row py-4"> |
||||
|
<div class="col-md-6 col-sm-12 p-3"> |
||||
|
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px; |
||||
|
background: #FFF; |
||||
|
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> |
||||
|
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; |
||||
|
display: flex; justify-content: center; align-items: center; |
||||
|
margin-right: 10px; flex-shrink: 0;"> |
||||
|
<i class="fa-solid fa-star " style="color: #fff;font-size:14px;"></i> |
||||
|
</div> |
||||
|
<div> |
||||
|
<p style="color: #1A202C;font-weight: 600; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">Booking orders from Shop,Bar/Restaurant in POS.</p> |
||||
|
<p class="m-0" style="color:#718096">Option to enter booking from customers in pos. |
||||
|
</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-6 col-sm-12 p-3"> |
||||
|
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px; |
||||
|
background: #FFF; |
||||
|
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> |
||||
|
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; |
||||
|
display: flex; justify-content: center; align-items: center; |
||||
|
margin-right: 10px; flex-shrink: 0;"> |
||||
|
<i class="fa-solid fa-star " style="color: #fff;font-size:14px;"></i> |
||||
|
</div> |
||||
|
<div> |
||||
|
<p style="color: #1A202C;font-weight: 600; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">Available both pickup and delivery options.</p> |
||||
|
<p class="m-0" style="color:#718096">Can choose type order both pickup and delivery. |
||||
|
</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-6 col-sm-12 p-3"> |
||||
|
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px; |
||||
|
background: #FFF; |
||||
|
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> |
||||
|
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; |
||||
|
display: flex; justify-content: center; align-items: center; |
||||
|
margin-right: 10px; flex-shrink: 0;"> |
||||
|
<i class="fa-solid fa-star " style="color: #fff;font-size:14px;"></i> |
||||
|
</div> |
||||
|
<div> |
||||
|
<p style="color: #1A202C;font-weight: 600; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">Shows booked order details in order receipt and order.</p> |
||||
|
<p class="m-0" style="color:#718096">Details of the booking are printed in receipt |
||||
|
</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="container rounded" > |
||||
|
<ul class="nav nav-tabs d-flex" style="width: fit-content;margin: 0 auto;gap: 1rem;"> |
||||
|
<li class="col text-center py-2 text-nowrap " |
||||
|
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;"><a |
||||
|
class="active show" data-toggle="tab" href="#tab1" |
||||
|
style="color: #fff;font-weight: 500; background-color: #714B67; text-decoration: none;"> |
||||
|
<i class="fa-regular fa-image pr-2" style="color: #fff;"></i> |
||||
|
Screenshots</a></li> |
||||
|
<li class="col text-center py-2 text-nowrap " |
||||
|
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;"><a |
||||
|
data-toggle="tab" href="#tab2" |
||||
|
style="color: #fff;font-weight: 500; text-decoration: none;"><i |
||||
|
class="fa-solid fa-star pr-2" style="color: #fff;"></i>Features</a></li> |
||||
|
<li class="col text-center py-2 text-nowrap " |
||||
|
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;"><a |
||||
|
data-toggle="tab" href="#tab3" |
||||
|
style="color: #fff;font-weight: 500; text-decoration: none; background-color: #714B67;"><i |
||||
|
class="fa-solid fa-book-open pr-2" style="color: #fff;"></i>Released Notes</a></li> |
||||
|
</ul> |
||||
|
<div class="tab-content" style="background-color: rgba(121, 113, 119, 0.04);"> |
||||
|
<div id="tab1" class="tab-pane fade in active show"> |
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot1.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">Go to PoS Settings -> |
||||
|
Enable Booking orders. After enabling this, the options to book |
||||
|
orders and screen of booked orders will show in POS |
||||
|
session.</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot2.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> |
||||
|
While clicking the booking order button it will open a |
||||
|
popup,that will book the order.</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot3.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> |
||||
|
We have two options for the booking order are picking or |
||||
|
delivery.Upon selecting the pickup option, |
||||
|
it shows a field to enter pickup date.</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot4.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">When selected deliver option, it displays two fields to |
||||
|
enter delivery date and delivery address.</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot5.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">Non-confirmed booked orders are can see here.</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot6.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> |
||||
|
Can view order lines & customer assigned with order details |
||||
|
on confirming POS order</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot7.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">In the case of picking order, the order receipt will be |
||||
|
shown as below.</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot8.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">In the case of delivery order, the order receipt will be |
||||
|
shown as below. Delivery date and address are specified</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
|
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot9.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">Confirmed or paid booked orders are highlighted.</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> |
||||
|
<div |
||||
|
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="row justify-content-center p-3 w-100 m-0"> |
||||
|
<img src="assets/screenshots/Screenshot10.png" class="img-responsive" width="100%" height="auto"> |
||||
|
</div> |
||||
|
<div class="px-3"> |
||||
|
<h4 class="mt-2" |
||||
|
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">The Book order ref will be updated on PoS Order</h4> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div id="tab2" class="tab-pane fade"> |
||||
|
<div class="col-mg-12" style="padding: 1rem 4rem;"> |
||||
|
<ul style="list-style: none; padding: 1rem 0;font-weight: 500;"> |
||||
|
<li class="py-3" |
||||
|
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" |
||||
|
width="16px"></span>Booking orders from Shop,Bar/Restaurant in POS. |
||||
|
</li> |
||||
|
<li class="py-3" |
||||
|
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" |
||||
|
width="16px"></span>Available both pickup and delivery options. |
||||
|
</li> |
||||
|
<li class="py-3" |
||||
|
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" |
||||
|
width="16px"></span>Shows booked order details in order receipt and order. |
||||
|
</li> |
||||
|
</ul> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div id="tab3" class="tab-pane fade"> |
||||
|
<div class="col-mg-12 active" style="padding: 1rem 4rem;"> |
||||
|
<div class="py-3" |
||||
|
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> |
||||
|
<div class="d-flex mb-3" style="font-size: 0.8rem; font-weight: 500;"><span>Version |
||||
|
17.0.1.0.0</span><span class="px-2">|</span><span |
||||
|
style="color: #714B67;font-weight: 600;">Released on:11th Jan 2024</span> |
||||
|
</div> |
||||
|
<p class="m-0" |
||||
|
style=" color:#718096!important; font-size:1rem !important;line-height: 28px;"> |
||||
|
|
||||
|
Initial Commit for POS Booking Order.</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="container mt-5"> |
||||
|
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5"> |
||||
|
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Related Products</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div id="myCarousel" class="carousel slide py-3" data-ride="carousel"> |
||||
|
<div class="carousel-inner"> |
||||
|
<div class="carousel-item active"> |
||||
|
<div class="row p-4"> |
||||
|
<div class="col"> |
||||
|
<div class="p-3"> |
||||
|
<a href="https://apps.odoo.com/apps/modules/17.0/salesperson_pos_order_line/" |
||||
|
style="color: #000; text-decoration: none;"> |
||||
|
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
||||
|
<div style="width: 300px; "> |
||||
|
<img src="assets/modules/1.jpg" |
||||
|
alt="" width="100%" |
||||
|
height="auto"> |
||||
|
|
||||
|
</div> |
||||
|
<p class="text-center pt-2 text-black font-weight-bold"> |
||||
|
Sales Person On POS Order Line</p> |
||||
|
</div> |
||||
|
</a> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col"> |
||||
|
<div class="p-3"> |
||||
|
<a href="https://apps.odoo.com/apps/modules/17.0/point_of_sale_logo/" |
||||
|
style="color: #000; text-decoration: none;"> |
||||
|
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
||||
|
<div style="width: 300px; "> |
||||
|
<img src="assets/modules/2.png" |
||||
|
alt="" width="100%" |
||||
|
height="auto"> |
||||
|
|
||||
|
</div> |
||||
|
<p class="text-center pt-2 text-black font-weight-bold"> |
||||
|
Point of Sale Logo</p> |
||||
|
</div> |
||||
|
</a> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col"> |
||||
|
<div class="p-3"> |
||||
|
<a href="https://apps.odoo.com/apps/modules/17.0/oh_appraisal/" |
||||
|
style="color: #000; text-decoration: none;"> |
||||
|
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
||||
|
<div style="width: 300px; "> |
||||
|
<img src="assets/modules/3.jpg" |
||||
|
alt="" width="100%" |
||||
|
height="auto"> |
||||
|
|
||||
|
</div> |
||||
|
<p class="text-center pt-2 text-black font-weight-bold"> |
||||
|
Open HRMS Employee Appraisal</p> |
||||
|
</div> |
||||
|
</a> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="carousel-item"> |
||||
|
<div class="row p-4"> |
||||
|
<div class="col"> |
||||
|
<div class="p-3"> |
||||
|
<a href="https://apps.odoo.com/apps/modules/17.0/master_search/" |
||||
|
style="color: #000; text-decoration: none;"> |
||||
|
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
||||
|
<div style="width: 300px; "> |
||||
|
<img src="assets/modules/4.jpg" |
||||
|
alt="" width="100%" |
||||
|
height="auto"> |
||||
|
|
||||
|
</div> |
||||
|
<p class="text-center pt-2 text-black font-weight-bold"> |
||||
|
Global Search</p> |
||||
|
</div> |
||||
|
</a> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col"> |
||||
|
<div class="p-3"> |
||||
|
<a href="https://apps.odoo.com/apps/modules/17.0/education_core/" |
||||
|
style="color: #000; text-decoration: none;"> |
||||
|
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
||||
|
<div style="width: 300px;"> |
||||
|
<img src="assets/modules/5.jpg" |
||||
|
alt="" width="100%" |
||||
|
height="auto"> |
||||
|
|
||||
|
</div> |
||||
|
<p class="text-center pt-2 text-black font-weight-bold"> |
||||
|
Educational ERP Core</p> |
||||
|
</div> |
||||
|
</a> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col"> |
||||
|
<div class="p-3"> |
||||
|
<a href="https://apps.odoo.com/apps/modules/17.0/odoo_parking_management/" |
||||
|
style="color: #000; text-decoration: none;"> |
||||
|
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> |
||||
|
<div style="width: 300px;"> |
||||
|
<img src="assets/modules/6.jpg" |
||||
|
alt="" width="100%" |
||||
|
height="auto"> |
||||
|
</div> |
||||
|
<p class="text-center pt-2 text-black font-weight-bold"> |
||||
|
Parking Management</p> |
||||
|
</div> |
||||
|
</a> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<a class="carousel-control-prev" href="#myCarousel" |
||||
|
data-slide="prev" style="width: 35px; color: #000;"> |
||||
|
<span class="carousel-control-prev-icon"> |
||||
|
<i class="fa fa-chevron-left" |
||||
|
style="font-size: 24px;"></i> |
||||
|
</span> |
||||
|
</a> |
||||
|
<a class="carousel-control-next" href="#myCarousel" |
||||
|
data-slide="next" style="width: 35px; color: #000;"> |
||||
|
<span class="carousel-control-next-icon"> |
||||
|
<i class="fa fa-chevron-right" |
||||
|
style="font-size: 24px;"></i> |
||||
|
</span> |
||||
|
</a> |
||||
|
</div> |
||||
|
<div class="container mt-5"> |
||||
|
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4"> |
||||
|
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Our Services</p> |
||||
|
|
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="container my-5"> |
||||
|
<div class="row py-3"> |
||||
|
<div class="col-md-4 col-sm-6 px-4 py-4"> |
||||
|
<div |
||||
|
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
||||
|
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
||||
|
<div style="background-color:#13EA36 ; border-radius: 50%; padding: 15px; width: 68px; |
||||
|
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
||||
|
<img src="assets/icons/cogs.png" alt="service-icon" width="38px" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p style="margin-top: 20px; font-weight: bold;">Odoo Customization</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-4 col-sm-6 px-4 py-4"> |
||||
|
<div |
||||
|
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
||||
|
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
||||
|
<div style="background-color:#DBC711; border-radius: 50%; padding: 15px; width: 68px; |
||||
|
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
||||
|
<img src="assets/icons/wrench.png" alt="service-icon" width="38px" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p style="margin-top: 20px; font-weight: bold;">Odoo Implementation</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-4 col-sm-6 px-4 py-4"> |
||||
|
<div |
||||
|
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;"> |
||||
|
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
||||
|
<div style="background-color:#FF6B6B ; border-radius: 50%; padding: 15px; width: 68px; |
||||
|
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
||||
|
<img src="assets/icons/lifebuoy.png" alt="service-icon" width="38px" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p style="margin-top: 20px; font-weight: bold;">Odoo Support</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-4 col-sm-6 px-4 py-4"> |
||||
|
<div |
||||
|
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;"> |
||||
|
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
||||
|
<div style="background-color:#FFA801 ; border-radius: 50%; padding: 15px; width: 68px; |
||||
|
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
||||
|
<img src="assets/icons/user.png" alt="service-icon" width="38px" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p style="margin-top: 20px; font-weight: bold;">Hire Odoo Developer</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-4 col-sm-6 px-4 py-4"> |
||||
|
<div |
||||
|
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;"> |
||||
|
|
||||
|
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
||||
|
<div style="background-color:#54A0FF; border-radius: 50%; padding: 15px; width: 68px; |
||||
|
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
||||
|
<img src="assets/icons/puzzle.png" alt="service-icon" width="38px" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p style="margin-top: 20px; font-weight: bold;">Odoo Integration</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-4 col-sm-6 px-4 py-4"> |
||||
|
<div |
||||
|
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
||||
|
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
||||
|
<div style="background-color:#6D7680 ; border-radius: 50%; padding: 15px; width: 68px; |
||||
|
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
||||
|
<img src="assets/icons/update.png" alt="service-icon" width="38px" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p style="margin-top: 20px; font-weight: bold;">Odoo Migration</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-4 col-sm-6 px-4 py-4"> |
||||
|
<div |
||||
|
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
||||
|
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
||||
|
<div style="background-color:#786FA6 ; border-radius: 50%; padding: 15px; width: 68px; |
||||
|
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
||||
|
<img src="assets/icons/consultation.png" alt="service-icon" width="38px" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p style="margin-top: 20px; font-weight: bold;">Odoo Consultancy</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-4 col-sm-6 px-4 py-4"> |
||||
|
<div |
||||
|
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;position: relative;border-radius: 4px;"> |
||||
|
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
||||
|
<div style="background-color:#F8A5C2 ; border-radius: 50%; padding: 15px; width: 68px; |
||||
|
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
||||
|
<img src="assets/icons/training.png" alt="service-icon" width="38px" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p style="margin-top: 20px; font-weight: bold;">Odoo Implementation</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-4 col-sm-6 px-4 py-4"> |
||||
|
<div |
||||
|
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> |
||||
|
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> |
||||
|
<div style="background-color:#E6BE26; border-radius: 50%; padding: 15px; width: 68px; |
||||
|
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> |
||||
|
<img src="assets/icons/license.png" alt="service-icon" width="38px" height="auto"> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p style="margin-top: 20px; font-weight: bold;">Odoo Licensing Consultancy</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="container mt-5"> |
||||
|
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4"> |
||||
|
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Our Industries</p> |
||||
|
|
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="container"> |
||||
|
<div class="row my-5 py-4"> |
||||
|
<div class="col-md-3 col-sm-6 p-0"> |
||||
|
<div class="d-flex flex-column h-100 " |
||||
|
style="border-right: 1px solid rgb(209, 209, 209); border-bottom: 1px solid rgb(209, 209, 209); padding: 30px; box-shadow: 6px 0 10px rgba(228, 227, 227, 0.373);"> |
||||
|
<img src="assets/icons/trading-black.png" width="42px" height="auto" alt=""> |
||||
|
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">Trading</p> |
||||
|
<p>Easily procure and sell your products</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-3 col-sm-6 p-0"> |
||||
|
<div class="d-flex flex-column h-100" |
||||
|
style="border-right: 1px solid rgb(209, 209, 209);border-bottom: 1px solid rgb(209, 209, 209); padding: 30px;"> |
||||
|
<img src="assets/icons/pos-black.png" width="42px" height="auto" alt=""> |
||||
|
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">POS</p> |
||||
|
<p>Easy configuration and convivial experience</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-3 col-sm-6 p-0"> |
||||
|
<div class="d-flex flex-column h-100" |
||||
|
style="border-right: 1px solid rgb(209, 209, 209);border-bottom: 1px solid rgba(0, 0, 0, 0.2); padding: 30px; box-shadow: 0 5px 10px rgba(228, 227, 227, 0.373)"> |
||||
|
<img src="assets/icons/education-black.png" width="42px" height="auto" alt=""> |
||||
|
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">Education</p> |
||||
|
<p>A platform for educational management</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-3 col-sm-6 p-0"> |
||||
|
<div class="d-flex flex-column h-100" |
||||
|
style="border-bottom: 1px solid rgb(209, 209, 209); padding: 30px; "> |
||||
|
<img src="assets/icons/manufacturing-black.png" width="42px" height="auto" alt=""> |
||||
|
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">Manufacturing</p> |
||||
|
<p>Plan, track and schedule your operations</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-3 col-sm-6 p-0"> |
||||
|
<div class="d-flex flex-column h-100" |
||||
|
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px;"> |
||||
|
<img src="assets/icons/ecom-black.png" width="42px" height="auto" alt=""> |
||||
|
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">E-commerce & Website</p> |
||||
|
<p>Mobile friendly, awe-inspiring product pages</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-3 col-sm-6 p-0"> |
||||
|
<div class="d-flex flex-column h-100" |
||||
|
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px;box-shadow: 0 -5px 10px rgba(228, 227, 227, 0.373);"> |
||||
|
<img src="assets/icons/service-black.png" width="42px" height="auto" alt=""> |
||||
|
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">Service Management</p> |
||||
|
<p>Keep track of services and invoice</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-3 col-sm-6 p-0"> |
||||
|
<div class="d-flex flex-column h-100" |
||||
|
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px; "> |
||||
|
<img src="assets/icons/restaurant-black.png" width="42px" height="auto" alt=""> |
||||
|
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">Restaurant</p> |
||||
|
<p>Run your bar or restaurant methodically</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-3 col-sm-6 p-0"> |
||||
|
<div class="d-flex flex-column h-100" |
||||
|
style=" padding: 30px;box-shadow: -5px 0 10px rgba(228, 227, 227, 0.373);"> |
||||
|
<img src="assets/icons/hotel-black.png" width="42px" height="auto" alt=""> |
||||
|
<p style="color: #714B67;font-weight: 600; margin-top: 10px; |
||||
|
font-size: 1.2rem; margin-bottom: 2px;">Hotel Management</p> |
||||
|
<p>An all-inclusive hotel management application</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="container mt-5"> |
||||
|
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5"> |
||||
|
<p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Support</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="container my-5"> |
||||
|
<div class="row" style="background-color: #FFFAFE;"> |
||||
|
<div class="col-md-6 pb-4 d-flex align-items-center justify-content-center" |
||||
|
style="border-right: 1px solid #D9D9D9;"> |
||||
|
<div style="padding: 30px;"> |
||||
|
<div class="d-flex align-items-center"> |
||||
|
<img src="assets/misc/support (1) 1.svg" alt="" width="60px" style="margin-right: 12px;"> |
||||
|
<div style="padding: 0px 8px;"> |
||||
|
<span |
||||
|
style="color: #714B67;font-size: 24px;font-weight: 600;padding-bottom: 1rem;">Need |
||||
|
Help?</span> |
||||
|
<p class="m-0" style="color:#718096;">Got questions or need help? Get in touch.</p> |
||||
|
<div style="font-weight: 400;"><span><img src="assets/misc/support-email.svg" alt="" |
||||
|
width="18px" |
||||
|
style="filter: invert(1);margin-right: 0.8rem;"></span>odoo@cybrosys.com |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="col-md-6 pb-4 d-flex align-items-center justify-content-center"> |
||||
|
<div style="padding: 30px;"> |
||||
|
<div class="d-flex align-items-center"> |
||||
|
<img src="assets/misc/whatsapp 1.svg" alt="" width="60px" style="margin-right: 12px;"> |
||||
|
<div> |
||||
|
<span style="color: #714B67;font-size: 24px;font-weight: 600;">WhatsApp</span> |
||||
|
<p class="m-0" style="color:#718096;">Say hi to us on WhatsApp!</p> |
||||
|
<div style="font-weight: 400; font-size: 16px;"><span><img src="assets/misc/phone.svg" |
||||
|
alt="" width="14px" |
||||
|
style="filter: invert(1); margin-right: 0.8rem;"></span>+91 |
||||
|
99456767686</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</section> |
||||
|
<!-- Optional JavaScript --> |
||||
|
<!-- jQuery first, then Popper.js, then Bootstrap JS --> |
||||
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> |
||||
|
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script> |
||||
|
</body> |
||||
|
</html> |
@ -0,0 +1,59 @@ |
|||||
|
/** @odoo-module **/ |
||||
|
/* |
||||
|
* This file is used to register the a new button for booking orders with selected partner and products. |
||||
|
*/ |
||||
|
/** @odoo-module **/ |
||||
|
|
||||
|
import { _t } from "@web/core/l10n/translation"; |
||||
|
import { ProductScreen } from "@point_of_sale/app/screens/product_screen/product_screen"; |
||||
|
import { useService } from "@web/core/utils/hooks"; |
||||
|
import { Component } from "@odoo/owl"; |
||||
|
import { usePos } from "@point_of_sale/app/store/pos_hook"; |
||||
|
import { BookOrderPopup } from "./BookOrderPopup"; |
||||
|
import { ErrorPopup } from "@point_of_sale/app/errors/popups/error_popup"; |
||||
|
|
||||
|
|
||||
|
|
||||
|
export class BookOrderButton extends Component { |
||||
|
static template = "pos_book_order.BookOrderButton"; |
||||
|
|
||||
|
setup() { |
||||
|
this.pos = usePos(); |
||||
|
this.popup = useService("popup"); |
||||
|
} |
||||
|
async onClick() { |
||||
|
// by clicking the booking order button, it will check whether at least one product and the selected customer or not, after that it will display popup.
|
||||
|
var order=this.pos.selectedOrder |
||||
|
var order_lines = order.orderlines; |
||||
|
var partner = order.partner |
||||
|
if (partner == null) { |
||||
|
this.pos.popup.add(ErrorPopup, { |
||||
|
title: _t("Please Select the Customer"), |
||||
|
body: _t( |
||||
|
"You need to select a customer for using this option" |
||||
|
), |
||||
|
}); |
||||
|
} else if (order_lines.length == 0) { |
||||
|
this.pos.popup.add(ErrorPopup, { |
||||
|
title: _t("Order line is empty"), |
||||
|
body: _t( |
||||
|
"Please select at least one product" |
||||
|
), |
||||
|
}); |
||||
|
} else { |
||||
|
await this.pos.popup.add(BookOrderPopup, { |
||||
|
title: _t("Book Order"), |
||||
|
partner:partner, |
||||
|
order:order, |
||||
|
currentDate: new Date().toISOString().split('T')[0], |
||||
|
}); |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
ProductScreen.addControlButton({ |
||||
|
component: BookOrderButton, |
||||
|
condition: function () { |
||||
|
return this.pos.config.enable; |
||||
|
}, |
||||
|
}); |
@ -0,0 +1,81 @@ |
|||||
|
/** @odoo-module */ |
||||
|
|
||||
|
import { AbstractAwaitablePopup } from "@point_of_sale/app/popup/abstract_awaitable_popup"; |
||||
|
import { _t } from "@web/core/l10n/translation"; |
||||
|
import { usePos } from "@point_of_sale/app/store/pos_hook"; |
||||
|
import { useRef } from "@odoo/owl"; |
||||
|
import { useService } from "@web/core/utils/hooks"; |
||||
|
|
||||
|
|
||||
|
/** |
||||
|
* This class represents a custom popup for capturing signatures in the Point of Sale. |
||||
|
* It extends the AbstractAwaitablePopup class. |
||||
|
*/ |
||||
|
export class BookOrderPopup extends AbstractAwaitablePopup { |
||||
|
static template = "pos_book_order.BookOrderPopup"; |
||||
|
static defaultProps = { |
||||
|
confirmText: _t("Save"), |
||||
|
cancelText: _t("Discard"), |
||||
|
clearText: _t("Clear"), |
||||
|
title: "", |
||||
|
body: "", |
||||
|
}; |
||||
|
setup() { |
||||
|
super.setup(); |
||||
|
this.pos = usePos(); |
||||
|
this.orm = useService("orm"); |
||||
|
this.order = this.pos.selectedOrder |
||||
|
this.pickup_date = useRef("pickUpDate") |
||||
|
this.order_note= useRef("orderNote") |
||||
|
this.delivery_date= useRef("deliveryDate") |
||||
|
this.pickup= useRef("pickup_radio") |
||||
|
this.delivery= useRef("deliver_radio") |
||||
|
this.Method_pickup= useRef("Method_pickup") |
||||
|
this.Method_deliver= useRef("Method_deliver") |
||||
|
} |
||||
|
showHide(){ |
||||
|
if(this.pickup.el.checked){ |
||||
|
this.Method_pickup.el.style.display='block' |
||||
|
this.Method_deliver.el.style.display='none' |
||||
|
} |
||||
|
if(this.delivery.el.checked){ |
||||
|
this.Method_pickup.el.style.display='none' |
||||
|
this.Method_deliver.el.style.display='block' |
||||
|
} |
||||
|
console.log(this.delivery.el.checked) |
||||
|
console.log(this.pickup.el.checked) |
||||
|
} |
||||
|
|
||||
|
async confirm() { |
||||
|
// on clicking confirm button of popup a new book order with draft stage will created from the backend
|
||||
|
var pickup_date = this.pickup_date.el.value; |
||||
|
var delivery_date = this.delivery_date.el.value; |
||||
|
var order_note = this.order_note.el.value; |
||||
|
var partner = this.order.partner.id; |
||||
|
var address = this.order.partner.address; |
||||
|
var phone = this.order.partner.phone; |
||||
|
var date = this.order.date_order; |
||||
|
var line = this.order.orderlines; |
||||
|
if(this.order.pricelist){ |
||||
|
var price_list = this.order.pricelist.id; |
||||
|
} |
||||
|
else{ |
||||
|
var price_list = false; |
||||
|
} |
||||
|
var product = { |
||||
|
'product_id': [], |
||||
|
'qty': [], |
||||
|
'price':[] |
||||
|
}; |
||||
|
for (var i = 0; i < line.length; i++) { |
||||
|
product['product_id'].push(line[i].product.id) |
||||
|
product['qty'].push(line[i].quantity) |
||||
|
product['price'].push(line[i].price) |
||||
|
}; |
||||
|
await this.orm.call( |
||||
|
"book.order", "create_booked_order", [partner, phone, address, date, price_list,product, order_note, pickup_date, delivery_date], {} |
||||
|
) |
||||
|
this.cancel(); |
||||
|
} |
||||
|
|
||||
|
} |
@ -0,0 +1,31 @@ |
|||||
|
/** @odoo-module **/ |
||||
|
/* |
||||
|
* This file is used to register the a new button to see booked orders data. |
||||
|
*/ |
||||
|
import { Component } from "@odoo/owl"; |
||||
|
import { useService } from "@web/core/utils/hooks"; |
||||
|
import { ProductScreen } from "@point_of_sale/app/screens/product_screen/product_screen"; |
||||
|
import { usePos } from "@point_of_sale/app/store/pos_hook"; |
||||
|
|
||||
|
class BookedOrdersButton extends Component { |
||||
|
static template = 'pos_book_order.BookedOrdersButton'; |
||||
|
setup() { |
||||
|
this.orm = useService("orm"); |
||||
|
this.pos = usePos(); |
||||
|
} |
||||
|
async onClick() { |
||||
|
// fetch all booked order in draft stage to screen
|
||||
|
var self = this |
||||
|
await this.orm.call( |
||||
|
"book.order", "all_orders", [], {} |
||||
|
).then(function(result) { |
||||
|
self.pos.showScreen('BookedOrdersScreen', { |
||||
|
data: result |
||||
|
}); |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
ProductScreen.addControlButton({ |
||||
|
component: BookedOrdersButton, |
||||
|
condition: () => true |
||||
|
}) |
@ -0,0 +1,43 @@ |
|||||
|
/** @odoo-module **/ |
||||
|
/* |
||||
|
* This file is used to register a new screen for Booked orders. |
||||
|
*/ |
||||
|
import { registry } from "@web/core/registry"; |
||||
|
import { TicketScreen } from "@point_of_sale/app/screens/ticket_screen/ticket_screen"; |
||||
|
import { usePos } from "@point_of_sale/app/store/pos_hook"; |
||||
|
import { useService } from "@web/core/utils/hooks"; |
||||
|
|
||||
|
class BookedOrdersScreen extends TicketScreen { |
||||
|
static template = "pos_book_order.BookedOrdersScreen"; |
||||
|
setup() { |
||||
|
super.setup(); |
||||
|
this.pos = usePos(); |
||||
|
this.orm = useService("orm"); |
||||
|
} |
||||
|
back() { |
||||
|
// on clicking the back button it will redirected Product screen
|
||||
|
this.pos.showScreen('ProductScreen'); |
||||
|
} |
||||
|
async _Confirm(ev) { |
||||
|
// On clicking confirm button on each order a order will create with corresponding partner and products,user can do the payment
|
||||
|
var self = this |
||||
|
var data = ev |
||||
|
await this.orm.call('book.order', 'action_confirm',[data.id],{}) |
||||
|
var order=this.pos.add_new_order(); |
||||
|
for (var i of data.products) { |
||||
|
var product = self.pos.db.get_product_by_id(i['id']) |
||||
|
var qty = i['qty'] |
||||
|
order.add_product(product, { |
||||
|
quantity: qty, |
||||
|
price: i['price'] |
||||
|
}) |
||||
|
} |
||||
|
var partner_id = data.partner_id |
||||
|
order.set_partner(this.pos.db.get_partner_by_id(partner_id)); |
||||
|
this.pos.selectedOrder.is_booked = true |
||||
|
this.pos.selectedOrder.booked_data = data |
||||
|
this.pos.selectedOrder.booking_ref_id = data.id |
||||
|
this.pos.showScreen('ProductScreen'); |
||||
|
} |
||||
|
} |
||||
|
registry.category("pos_screens").add("BookedOrdersScreen", BookedOrdersScreen); |
@ -0,0 +1,46 @@ |
|||||
|
/** @odoo-module **/ |
||||
|
/* |
||||
|
* This file is used to add some fields to order class for some reference. |
||||
|
*/ |
||||
|
|
||||
|
import { Order } from "@point_of_sale/app/store/models"; |
||||
|
import { patch } from "@web/core/utils/patch"; |
||||
|
|
||||
|
patch(Order.prototype, { |
||||
|
/** |
||||
|
* Override the setup method to initialize custom signature properties. |
||||
|
* @param {Object} options - Options passed to the setup method. |
||||
|
*/ |
||||
|
setup(options) { |
||||
|
super.setup(...arguments); |
||||
|
if (options.json) { |
||||
|
this.booking_ref_id= options.json.booking_ref_id || false; |
||||
|
this.is_booked = options.json.is_booked || false; |
||||
|
this.booked_data = options.json.booked_data || undefined; |
||||
|
} |
||||
|
}, |
||||
|
/** |
||||
|
* Initialize the order object from a JSON representation. |
||||
|
* @param {Object} json - JSON data representing the order. |
||||
|
*/ |
||||
|
init_from_JSON(json) { |
||||
|
super.init_from_JSON(...arguments); |
||||
|
// this function is overrided for assigning json value to this
|
||||
|
super.init_from_JSON(...arguments); |
||||
|
this.booking_ref_id= json.booking_ref_id; |
||||
|
this.is_booked = json.is_booked; |
||||
|
this.booked_data = json.booked_data |
||||
|
}, |
||||
|
/** |
||||
|
* Export the order object as a JSON representation. |
||||
|
* @returns {Object} JSON data representing the order. |
||||
|
*/ |
||||
|
export_as_JSON() { |
||||
|
// this function is overrided for assign this to json for new field
|
||||
|
const json = super.export_as_JSON(...arguments); |
||||
|
json.booking_ref_id=this.booking_ref_id |
||||
|
json.booked_data = this.booked_data; |
||||
|
json.is_booked = this.is_booked; |
||||
|
return json; |
||||
|
}, |
||||
|
}); |
@ -0,0 +1,132 @@ |
|||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||
|
<templates id="template" xml:space="preserve"> |
||||
|
<!--This is used for creating a popup for booking orders--> |
||||
|
<t t-name="pos_book_order.BookOrderPopup"> |
||||
|
<div class="popup popup-confirm"> |
||||
|
<div class="modal-header"> |
||||
|
<h4 class="modal-title title drag-handle"> |
||||
|
<t t-esc="props.title"/> |
||||
|
</h4> |
||||
|
</div> |
||||
|
<main class="modal-body"> |
||||
|
<t t-if="props.partner"> |
||||
|
<label style="margin-right: 298px;">AMOUNT TOTAL</label> |
||||
|
<div> |
||||
|
<input class='form-control booking_field' name="amount" |
||||
|
type='text' |
||||
|
style="height:34px;border-radius:5px;" |
||||
|
t-att-value="order.get_total_with_tax()" |
||||
|
readonly="1"/> |
||||
|
</div> |
||||
|
<br/> |
||||
|
<br/> |
||||
|
<label style="margin-right: 333px;">CUSTOMER</label> |
||||
|
<div> |
||||
|
<input class='form-control booking_field' name="name" |
||||
|
type='text' |
||||
|
style="height:34px;border-radius:5px;" |
||||
|
t-att-value="props.partner.name" readonly="1"/> |
||||
|
</div> |
||||
|
<br/> |
||||
|
<br/> |
||||
|
<label style="margin-right: 185px;">PHONE CONTACT FOR DELIVERY(*)</label> |
||||
|
<div> |
||||
|
<input class='form-control booking_field' name="phone" |
||||
|
type='text' id="phone" |
||||
|
style="height:34px;border-radius:5px;" |
||||
|
t-att-value="props.partner.phone" |
||||
|
data-is-required="true"/> |
||||
|
</div> |
||||
|
</t> |
||||
|
<div class="radio" |
||||
|
style="width:100%;float: left;text-align: center;font-size: 23px;"> |
||||
|
<label>Pickup</label> |
||||
|
<input type="radio" name="method" id="pickup" |
||||
|
style="width: auto;min-height: auto;margin-right: 28px;" |
||||
|
checked="checked" value="pickup" t-ref="pickup_radio" |
||||
|
t-on-click="showHide"/> |
||||
|
<label>Deliver</label> |
||||
|
<input type="radio" name="method" id="deliver" |
||||
|
style="width: auto;min-height: auto;" |
||||
|
value="deliver" t-ref="deliver_radio" |
||||
|
t-on-click="showHide"/> |
||||
|
</div> |
||||
|
<t t-if="order.pricelist"> |
||||
|
<label style="margin-right: 324px;">PRICELIST(*)</label> |
||||
|
<div> |
||||
|
<input class='form-control booking_field' |
||||
|
name="pricelist" type='text' |
||||
|
style="height:34px;border-radius:5px;" |
||||
|
t-att-value="order.pricelist.display_name " |
||||
|
readonly="1"/> |
||||
|
</div> |
||||
|
<br/> |
||||
|
<br/> |
||||
|
</t> |
||||
|
<label style="margin-right: 293px;">BOOKING DATE(*)</label> |
||||
|
<div> |
||||
|
<input type="date" id='BookingDate' name="order_date" |
||||
|
class='form-control booking_field' |
||||
|
maxlength="10" |
||||
|
t-att-value="props.currentDate"/> |
||||
|
</div> |
||||
|
<br/> |
||||
|
<br/> |
||||
|
<label style="margin-right: 324px;">ORDER NOTE</label> |
||||
|
<div> |
||||
|
<textarea |
||||
|
t-ref="orderNote" |
||||
|
rows="1" cols="30" name="order_note" |
||||
|
class="form-control order_note" |
||||
|
placeholder="Enter your notes here..."/> |
||||
|
</div> |
||||
|
<br/> |
||||
|
<br/> |
||||
|
<div id="Method_pickup" t-ref="Method_pickup"> |
||||
|
<label style="margin-right: 317px;">PICKUP DATE</label> |
||||
|
<div> |
||||
|
<input t-ref="pickUpDate" |
||||
|
name="pickup_date" |
||||
|
class='form-control booking_field' |
||||
|
id="pickup_date" type='date' |
||||
|
style="height:34px;border-radius:5px;"/> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div id="Method_deliver" style="display:none" |
||||
|
t-ref="Method_deliver"> |
||||
|
<label style="margin-right: 301px;">DELIVERY DATE</label> |
||||
|
<div> |
||||
|
<input t-ref="deliveryDate" |
||||
|
name="deliver_date" |
||||
|
class='form-control booking_field' |
||||
|
id="deliver_date" type='date' |
||||
|
style="height:34px;border-radius:5px;"/> |
||||
|
</div> |
||||
|
<br/> |
||||
|
<br/> |
||||
|
<t t-if="props.partner"> |
||||
|
<label style="margin-right: 271px;">DELIVERY ADDRESS(*)</label> |
||||
|
<div> |
||||
|
<input class='form-control booking_field' |
||||
|
name="delivery_address" type='text' |
||||
|
id="delivery_address" |
||||
|
t-att-value="props.partner.address" |
||||
|
data-is-required="true"/> |
||||
|
</div> |
||||
|
</t> |
||||
|
</div> |
||||
|
|
||||
|
</main> |
||||
|
<footer class="footer modal-footer"> |
||||
|
<div class="button confirm btn btn-lg btn-primary" |
||||
|
t-on-click="confirm"> |
||||
|
<t t-esc="props.confirmText"/> |
||||
|
</div> |
||||
|
<div class="button cancel btn btn-lg btn-secondary" |
||||
|
t-on-click="cancel"> |
||||
|
<t t-esc="props.cancelText"/> |
||||
|
</div> |
||||
|
</footer> |
||||
|
</div> |
||||
|
</t> |
||||
|
</templates> |
@ -0,0 +1,134 @@ |
|||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||
|
<templates id="template" xml:space="preserve"> |
||||
|
<!--This is used for creating a new screen for showing booked orders--> |
||||
|
<t t-name="pos_book_order.BookedOrdersScreen" owl="1"> |
||||
|
<div class="partnerlist-screen screen"> |
||||
|
<div class="screen-content"> |
||||
|
<div class="top-content"> |
||||
|
<div class="button back" t-on-click="back"> |
||||
|
<i class="fa fa-angle-double-left"/> |
||||
|
Back |
||||
|
</div> |
||||
|
</div> |
||||
|
<table class="partner-list table table-striped w-100"> |
||||
|
<thead> |
||||
|
<tr> |
||||
|
<th class="py-2">Order Ref.</th> |
||||
|
<th class="py-2">Customer</th> |
||||
|
<th class="py-2">Contact No.</th> |
||||
|
<th class="py-2">Order Date</th> |
||||
|
<th class="py-2">Pickup Date</th> |
||||
|
<th class="py-2">Delivery Date</th> |
||||
|
<th class="py-2">Address</th> |
||||
|
<th class="py-2">Total</th> |
||||
|
<th class="py-2">Confirm</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody class="partner-list-contents"> |
||||
|
<t t-foreach="props.data" |
||||
|
t-as="order" |
||||
|
t-key="order.id"> |
||||
|
<tr> |
||||
|
<td> |
||||
|
<div class="col" |
||||
|
t-att-class="{ highlight: isHighlighted(order) }"> |
||||
|
<div t-if="env.isMobile">Order Ref.</div> |
||||
|
<div> |
||||
|
<t t-esc="order.name"/> |
||||
|
</div> |
||||
|
</div> |
||||
|
</td> |
||||
|
<td> |
||||
|
<div class="col" |
||||
|
t-att-class="{ highlight: isHighlighted(order) }"> |
||||
|
<div t-if="env.isMobile">Customer</div> |
||||
|
<div> |
||||
|
<t t-esc="order.partner_name"/> |
||||
|
</div> |
||||
|
</div> |
||||
|
</td> |
||||
|
<td> |
||||
|
<div class="col" |
||||
|
t-att-class="{ highlight: isHighlighted(order) }"> |
||||
|
<div t-if="env.isMobile">Contact No.</div> |
||||
|
<div> |
||||
|
<t t-esc="order.phone"/> |
||||
|
</div> |
||||
|
</div> |
||||
|
</td> |
||||
|
<td> |
||||
|
<div class="col" |
||||
|
t-att-class="{ highlight: isHighlighted(order) }"> |
||||
|
<div t-if="env.isMobile">Order Date.</div> |
||||
|
<div> |
||||
|
<t t-esc="order.date"/> |
||||
|
</div> |
||||
|
</div> |
||||
|
</td> |
||||
|
<td> |
||||
|
<div class="col" |
||||
|
t-att-class="{ highlight: isHighlighted(order) }"> |
||||
|
<div t-if="env.isMobile">Pickup Date</div> |
||||
|
<div t-if="order.pickup"> |
||||
|
<t t-esc="order.pickup"/> |
||||
|
</div> |
||||
|
</div> |
||||
|
</td> |
||||
|
<td> |
||||
|
<div class="col" |
||||
|
t-att-class="{ highlight: isHighlighted(order) }"> |
||||
|
<div t-if="env.isMobile">Delivery Date</div> |
||||
|
<div t-if="order.deliver"> |
||||
|
<t t-esc="order.deliver"/> |
||||
|
</div> |
||||
|
</div> |
||||
|
</td> |
||||
|
<td> |
||||
|
<div class="col wide" |
||||
|
t-att-class="{ highlight: isHighlighted(order) }"> |
||||
|
<div t-if="env.isMobile">Address</div> |
||||
|
<div> |
||||
|
<t t-esc="order.address"/> |
||||
|
</div> |
||||
|
</div> |
||||
|
</td> |
||||
|
<td> |
||||
|
<div class="col" |
||||
|
t-att-class="{ highlight: isHighlighted(order) }"> |
||||
|
<div t-if="env.isMobile">Total</div> |
||||
|
<div> |
||||
|
<t t-esc="order.total"> |
||||
|
</t> |
||||
|
</div> |
||||
|
</div> |
||||
|
</td> |
||||
|
<td> |
||||
|
<div class="col" |
||||
|
t-att-class="{ highlight: isHighlighted(order) }"> |
||||
|
<button class="confirm-button" |
||||
|
name="confirm_order" |
||||
|
id="confirm_order" |
||||
|
t-on-click="() => this._Confirm(order)"> |
||||
|
Confirm Order |
||||
|
</button> |
||||
|
</div> |
||||
|
</td> |
||||
|
</tr> |
||||
|
|
||||
|
</t> |
||||
|
<t t-if="props.data.length==0"> |
||||
|
<div class="empty-order-list" |
||||
|
style="text-align: center; margin: 48px;color: #80848F;"> |
||||
|
<i role="img" aria-label="Shopping cart" |
||||
|
title="Shopping cart" |
||||
|
class="fa fa-shopping-cart"> |
||||
|
</i> |
||||
|
<h1>No orders found</h1> |
||||
|
</div> |
||||
|
</t> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
</div> |
||||
|
</div> |
||||
|
</t> |
||||
|
</templates> |
@ -0,0 +1,18 @@ |
|||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||
|
<templates id="template" xml:space="preserve"> |
||||
|
<!-- This button for booking orders--> |
||||
|
<t t-name="pos_book_order.BookOrderButton" owl="1"> |
||||
|
<div class="control-button o_pricelist_button btn btn-light rounded-0 fw-bolder" |
||||
|
t-on-click="onClick"> |
||||
|
<i class='fa fa-book'/> |
||||
|
<span class="label">Booking</span> |
||||
|
</div> |
||||
|
</t> |
||||
|
<!-- This button for seeing booked orders--> |
||||
|
<t t-name="pos_book_order.BookedOrdersButton" owl="1"> |
||||
|
<div class="control-button o_pricelist_button btn btn-light rounded-0 fw-bolder" |
||||
|
t-on-click="onClick"> |
||||
|
Booked Orders |
||||
|
</div> |
||||
|
</t> |
||||
|
</templates> |
@ -0,0 +1,45 @@ |
|||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||
|
<template id="receipt_template" xml:space="preserve"> |
||||
|
<!--This is used for adding some more data to pos receipt based on the booked order--> |
||||
|
<t t-name="BookOrderReceipt" t-inherit="point_of_sale.OrderReceipt" |
||||
|
t-inherit-mode="extension" owl="1"> |
||||
|
<xpath expr="//div[hasclass('before-footer')]" position="after"> |
||||
|
<t t-set="order" t-value="this.env.services.pos.get_order()"/> |
||||
|
<t t-if="order.is_booked"> |
||||
|
<hr/> |
||||
|
<div> |
||||
|
Booking Ref: |
||||
|
<span t-esc="order.booked_data.name" |
||||
|
class="pos-receipt-right-align"/> |
||||
|
</div> |
||||
|
<div> |
||||
|
Contact No.: |
||||
|
<span t-esc="order.booked_data.phone" |
||||
|
class="pos-receipt-right-align"/> |
||||
|
</div> |
||||
|
<div> |
||||
|
Order Note: |
||||
|
<span t-esc="order.booked_data.note"/> |
||||
|
</div> |
||||
|
<t t-if="order.booked_data.pickup"> |
||||
|
<div> |
||||
|
Pickup Date: |
||||
|
<span t-esc="order.booked_data.pickup" |
||||
|
class="pos-receipt-right-align"/> |
||||
|
</div> |
||||
|
</t> |
||||
|
<t t-if="order.booked_data.deliver"> |
||||
|
<div> |
||||
|
Delivery Date: |
||||
|
<span t-esc="order.booked_data.deliver" |
||||
|
class="pos-receipt-right-align"/> |
||||
|
</div> |
||||
|
<div> |
||||
|
Delivery address: |
||||
|
<span t-esc="order.booked_data.address"/> |
||||
|
</div> |
||||
|
</t> |
||||
|
</t> |
||||
|
</xpath> |
||||
|
</t> |
||||
|
</template> |
@ -0,0 +1,103 @@ |
|||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||
|
<odoo> |
||||
|
<!-- This record for creating form view for book.order--> |
||||
|
<record id="book_order_view_form" model="ir.ui.view"> |
||||
|
<field name="name">book.order.view.form</field> |
||||
|
<field name="model">book.order</field> |
||||
|
<field name="arch" type="xml"> |
||||
|
<form string="Point of Sale Quotations" create="false"> |
||||
|
<header> |
||||
|
<field name="state" widget="statusbar" |
||||
|
statusbar_visible="draft,confirmed"/> |
||||
|
</header> |
||||
|
<sheet> |
||||
|
<group> |
||||
|
<group> |
||||
|
<field name="name"/> |
||||
|
<field name="date_order"/> |
||||
|
<field name="date_quotation"/> |
||||
|
<field name="pickup_date"/> |
||||
|
<field name="pricelist_id"/> |
||||
|
</group> |
||||
|
<group> |
||||
|
<field name="partner_id"/> |
||||
|
<field name="phone"/> |
||||
|
<field name="delivery_address"/> |
||||
|
<field name="deliver_date"/> |
||||
|
</group> |
||||
|
<notebook colspan="4"> |
||||
|
<page string="Products"> |
||||
|
<field name="book_line_ids" colspan="4" |
||||
|
nolabel="1"> |
||||
|
<tree string="Order lines" |
||||
|
editable="bottom"> |
||||
|
<field name="product_id"/> |
||||
|
<field name="qty"/> |
||||
|
<field name="price_unit" |
||||
|
widget="monetary"/> |
||||
|
<field name="discount" |
||||
|
widget="monetary"/> |
||||
|
<field name="tax_after_fiscal_position_ids" |
||||
|
widget="many2many_tags"/> |
||||
|
<field name="price_subtotal" |
||||
|
widget="monetary"/> |
||||
|
<field name="price_subtotal_incl" |
||||
|
widget="monetary"/> |
||||
|
</tree> |
||||
|
</field> |
||||
|
<group class="oe_subtotal_footer oe_right" |
||||
|
colspan="2" name="order_total"> |
||||
|
<field name="amount_tax" widget="monetary"/> |
||||
|
<div class="oe_subtotal_footer_separator oe_inline"> |
||||
|
<label for="amount_total"/> |
||||
|
</div> |
||||
|
<field name="amount_total" nolabel="1" |
||||
|
class="oe_subtotal_footer_separator" |
||||
|
widget="monetary"/> |
||||
|
</group> |
||||
|
</page> |
||||
|
<page string="Notes"> |
||||
|
<field name="note"/> |
||||
|
</page> |
||||
|
</notebook> |
||||
|
</group> |
||||
|
</sheet> |
||||
|
</form> |
||||
|
</field> |
||||
|
</record> |
||||
|
<!-- this record for creating tree view for book.order--> |
||||
|
<record id="book_order_view_tree" model="ir.ui.view"> |
||||
|
<field name="name">book.order.view.tree</field> |
||||
|
<field name="model">book.order</field> |
||||
|
<field name="arch" type="xml"> |
||||
|
<tree string="Point of Sale Quotations" create="false" |
||||
|
decoration-danger="state == 'draft'" |
||||
|
decoration-success="state == 'confirmed'"> |
||||
|
<field name="name"/> |
||||
|
<field name="partner_id"/> |
||||
|
<field name="pickup_date"/> |
||||
|
<field name="deliver_date"/> |
||||
|
<field name="amount_total"/> |
||||
|
<field name="state"/> |
||||
|
</tree> |
||||
|
</field> |
||||
|
</record> |
||||
|
<!-- this record for creating menu action for book.order--> |
||||
|
<record id="book_order_action" model="ir.actions.act_window"> |
||||
|
<field name="name">Booking Orders</field> |
||||
|
<field name="res_model">book.order</field> |
||||
|
<field name="view_mode">tree,form</field> |
||||
|
<field name="help" type="html"> |
||||
|
<p> |
||||
|
Use this menu to browse previous booking orders and to record |
||||
|
new booking orders. |
||||
|
</p> |
||||
|
</field> |
||||
|
</record> |
||||
|
<menuitem id="book_order_menu" |
||||
|
name="Booking Orders" |
||||
|
parent="point_of_sale.menu_point_of_sale" |
||||
|
action="book_order_action" |
||||
|
sequence="0" |
||||
|
groups="point_of_sale.group_pos_manager,point_of_sale.group_pos_user"/> |
||||
|
</odoo> |
@ -0,0 +1,24 @@ |
|||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||
|
<odoo> |
||||
|
<!-- This record is for adding a field in pos configuration for allowing booking order--> |
||||
|
<record id="pos_config_view_form" model="ir.ui.view"> |
||||
|
<field name="name">pos.config.view.form.inherit.book.order</field> |
||||
|
<field name="model">pos.config</field> |
||||
|
<field name="inherit_id" ref="point_of_sale.pos_config_view_form"/> |
||||
|
<field name="arch" type="xml"> |
||||
|
<xpath expr="//setting[@id='other_devices']" position="after"> |
||||
|
<div class="col-12 col-lg-6 o_setting_box"> |
||||
|
<div class="o_setting_left_pane"> |
||||
|
<field name="enable"/> |
||||
|
</div> |
||||
|
<div class="o_setting_right_pane"> |
||||
|
<label for="enable" string="Booking Orders"/> |
||||
|
<div class="text-muted"> |
||||
|
Allow booking orders |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</xpath> |
||||
|
</field> |
||||
|
</record> |
||||
|
</odoo> |
@ -0,0 +1,14 @@ |
|||||
|
<?xml version="1.0" encoding="UTF-8" ?> |
||||
|
<odoo> |
||||
|
<!-- This record for adding a booked order reference field to pos order form view --> |
||||
|
<record id="view_pos_pos_form" model="ir.ui.view"> |
||||
|
<field name="name">pos.order.view.form.inherit.book.order</field> |
||||
|
<field name="model">pos.order</field> |
||||
|
<field name="inherit_id" ref="point_of_sale.view_pos_pos_form"/> |
||||
|
<field name="arch" type="xml"> |
||||
|
<field name="partner_id" position="after"> |
||||
|
<field name="booking_ref_id"/> |
||||
|
</field> |
||||
|
</field> |
||||
|
</record> |
||||
|
</odoo> |