Metadata-Version: 2.1
Name: odoo-addon-l10n_th_base_utils
Version: 18.0.2.0.1
Requires-Python: >=3.10
Requires-Dist: odoo==18.0.*
Summary: Collection of all Thai fonts, Convert month/year/number to thai
Home-page: https://github.com/OCA/l10n-thailand
License: AGPL-3
Author: Ecosoft, Odoo Community Association (OCA)
Author-email: support@odoo-community.org
Classifier: Programming Language :: Python
Classifier: Framework :: Odoo
Classifier: Framework :: Odoo :: 18.0
Classifier: License :: OSI Approved :: GNU Affero General Public License v3
Description-Content-Type: text/x-rst

.. image:: https://odoo-community.org/readme-banner-image
   :target: https://odoo-community.org/get-involved?utm_source=readme
   :alt: Odoo Community Association

===================================
Thai Localization - Base Utils Thai
===================================

.. 
   !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
   !! This file is generated by oca-gen-addon-readme !!
   !! changes will be overwritten.                   !!
   !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
   !! source digest: sha256:aff6c25ba7ebd58e309b09fb6de7b222e997a8d6fb616013575fcbe603810928
   !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
    :target: https://odoo-community.org/page/development-status
    :alt: Beta
.. |badge2| image:: https://img.shields.io/badge/license-AGPL--3-blue.png
    :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
    :alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fl10n--thailand-lightgray.png?logo=github
    :target: https://github.com/OCA/l10n-thailand/tree/18.0/l10n_th_base_utils
    :alt: OCA/l10n-thailand
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
    :target: https://translation.odoo-community.org/projects/l10n-thailand-18-0/l10n-thailand-18-0-l10n_th_base_utils
    :alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
    :target: https://runboat.odoo-community.org/builds?repo=OCA/l10n-thailand&target_branch=18.0
    :alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|

This module is a utility package for Thailand, providing helper
functions commonly used in Thai-specific contexts.

It includes features such as:

- Conversion between Arabic and Thai numerals

- Thai month name and Buddhist calendar (Thai year) conversion

- Thai font support:

  - Font ``THSrisakdi``
  - Font ``THSarabunNew``
  - Font ``THSarabun``
  - Font ``THNiramitAS``
  - Font ``THMaliGrade6``
  - Font ``THKrub``
  - Font ``THKoHo``
  - Font ``THKodchasal``
  - Font ``THK2DJuly8``
  - Font ``THFahkwang``
  - Font ``THCharmonman``
  - Font ``THCharmofAU``
  - Font ``THChakraPetch``
  - Font ``THBaijam``
  - Font ``AngsanaNew``
  - Font ``Webdings``

**Table of contents**

.. contents::
   :local:

Configuration
=============

To configure the Thai font, go to Settings > General Settings > Business
Documents > Configure Document Layout, then select the desired font and
click Save.

Usage
=====

This module provides a utility model ``thai.utils`` for Thai
localization features such as number and date formatting. You can either
call the methods directly via the environment, or inherit the abstract
model in your own modules.

Example
=======

.. code:: python

   thai_utils = self.env["thai.utils"]

   # Convert Arabic to Thai numerals
   thai_number = thai_utils.to_thai_number("1234567890")  # → ๑๒๓๔๕๖๗๘๙๐

   # Convert Thai to Arabic numerals
   arabic_number = thai_utils.to_arabic_number("๐๘๙")  # → 089

   # Get Thai full month name
   month_name = thai_utils.thai_month_name(12)  # → ธันวาคม

   # Get Thai abbreviated month name
   month_abbr = thai_utils.thai_month_name(12, short=True)  # → ธ.ค.

   # Format date to Thai date string
   from datetime import date

   formatted_date = thai_utils.format_thai_date(date(2025, 7, 2))  # → 2 กรกฎาคม 2568

   formatted_date_short_month = thai_utils.format_thai_date(date(2025, 7, 2), month_format="short")  # → 2 ก.ค. 2568

   formatted_date_numeric_month = thai_utils.format_thai_date(date(2025, 7, 2), month_format="numeric", format_date="{day:02d}{month}{year}")  # → 02072568

   formatted_year_thai = thai_utils.format_thai_date(date(2025, 7, 2), format_date="{year}")  # → 2568

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/l10n-thailand/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/OCA/l10n-thailand/issues/new?body=module:%20l10n_th_base_utils%0Aversion:%2018.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Authors
-------

* Ecosoft

Contributors
------------

- Saran Lim. <saranl@ecosoft.co.th>
- Tharathip Chaweewongphan <tharathipc@ecosoft.co.th>
- Amin Cheloh <amincheloh@gmail.com>

Maintainers
-----------

This module is maintained by the OCA.

.. image:: https://odoo-community.org/logo.png
   :alt: Odoo Community Association
   :target: https://odoo-community.org

OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

.. |maintainer-Saran440| image:: https://github.com/Saran440.png?size=40px
    :target: https://github.com/Saran440
    :alt: Saran440

Current `maintainer <https://odoo-community.org/page/maintainer-role>`__:

|maintainer-Saran440| 

This module is part of the `OCA/l10n-thailand <https://github.com/OCA/l10n-thailand/tree/18.0/l10n_th_base_utils>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
