openhab-addons/bundles/org.openhab.transform.vat
Wouter Born 8672ed0208
Start license headers with `/*` instead of `/**` (#18061)
Prevents JavaDoc tooling issues because these tools check comments starting with `/**`.

Signed-off-by: Wouter Born <github@maindrain.net>
2025-01-07 22:33:03 +01:00
..
src Start license headers with `/*` instead of `/**` (#18061) 2025-01-07 22:33:03 +01:00
NOTICE Initial contribution (#14529) 2023-03-17 22:06:06 +01:00
README.md Add support for VAT rate periodization (#17642) 2024-10-29 11:54:42 +01:00
pom.xml Prepare for OH 5.0.0 (#17906) 2024-12-15 20:30:05 +01:00

README.md

VAT Transformation Service

The VAT Transformation Service adds VAT (Value-Added Tax) to a given input amount. The input string must be either an ISO 3166 alpha-2 country code or a percentage, i.e. numerical format.

Examples

Display

Number CurrentSpotPrice "Current Spot Price incl. VAT [VAT(12.5):%s]" <price>

In a Rule

Add Danish VAT to price:

:::: tabs

::: tab DSL

var Number price = 499
logInfo("Price", "Price incl. VAT: " + transform("VAT", "DK", price.toString))

:::

::: tab JavaScript

var price = 499;
console.log("Price incl. VAT: " + actions.Transformation.transform("VAT", "DK", price.toString()));

:::

::: tab JRuby

price = 499
# The currency name can be either a Symbol or a String
# The input value doesn't need to be converted to string, however, the return value is a String
price_incl_vat = transform(:vat, :DK, price)
logger.info "Price incl. VAT: #{price_incl_vat}"

:::

::::

Usage as a Profile

The functionality of this TransformationService can also be used in a Profile on an ItemChannelLink. This is the most powerful usage since VAT will be added without providing any explicit country code, percentage or configuration. Time series are supported when using this Profile, including applying VAT rates accurately based on the specific date and time of each state, even as new VAT rates come into effect. This ensures that the correct VAT rate is applied for historical, current, or future data points, reflecting any changes in VAT regulations that occur over time.

To use this, an .items file can be configured as follows:

Number CurrentSpotPrice "Current Spot Price" <price> { channel="<channelUID>" [profile="transform:VAT"] }

To override VAT percentage for configured system country:

Number CurrentSpotPrice "Current Spot Price" <price> { channel="<channelUID>" [profile="transform:VAT", percentage="12.5"] }

If VAT is not known for the configured country or the provided percentage is invalid, the default is 0%, so the input value will be put into the transformation without any changes.

Please note: This profile is a one-way transformation, i.e. only values from a device towards the item are changed, the other direction is left untouched.