openbuildings / jam-monetary
A Jam Field to transparently use 'monetary' as a jam field, and have currency exchange arithmetic out of the box
Installs: 170 248
Dependents: 4
Suggesters: 3
Security: 0
Stars: 0
Watchers: 11
Forks: 0
Open Issues: 1
Type:kohana-module
Requires
- php: ^7.1
- composer/installers: *
- openbuildings/monetary: ^0.5
Requires (Dev)
- openbuildings/jam: ^0.6
- openbuildings/kohana-test-bootstrap: ^0.2.0
- phpunit/phpunit: ^7
This package is auto-updated.
Last update: 2024-10-29 04:52:54 UTC
README
A Jam Field to transparently use "monetary" as a Jam field, and have currency exchange arithmetic out of the box
Usage
In your model, define the field as usual:
class Model_Product extends Jam_Model { static public function initialize(Jam_Meta $meta) { $meta ->fields(array( 'id' => Jam::field('primary'), 'name' => Jam::field('string'), 'price' => Jam::field('price', array('default_currency' => 'GBP')), 'discount_price' => Jam::field('price'), )); } }
And to use it you can:
$product = Jam::build('product', array('price' => 10)); echo $product->price->amount(); // will output 10.00 float echo $product->price->currency(); // will output GBP - the price currency echo $product->price; // will output '10.00' echo $product->price->as_string(); // will output '10.00' echo $product->price->as_string('USD'); // will output '10.00' echo $product->price->in('USD'); // will output 18.12 float echo $product->price->humanize(); // will output '£10.00' echo $product->price->humanize('USD'); // will output '$18.12' echo $product->price->as_html(); // will output '£10.00' echo $product->price->as_html('USD'); // will output '$18.12' echo $product->price->as_html('EUR'); // will output '€18.12' // Price arithmetic $product->price->add(10); // Add 2 prices together, doing the exchange conversion arithmetic on the fly $product->price->add(new Jam_Price(20, 'EUR')); // Adding more than one price $product->price->add(new Jam_Price(20, 'EUR'), new Jam_Price(10, 'GBP'), 12.32);
Methods
in($currency)
: display the amount in the specified currency, put through number_format with 2 digits after the dotas_string($currency = NULL)
: return the number_format() on the price's amount, with 2 digits after the dot.humanize($currency = NULL)
: display the amount with showing the proper currency sign in the correct positionas_html($currency = NULL)
: same ashumanize()
, but with HTML entities supportadd(... prices)
: add one or more price values to this price (you can add negative prices in order to substract)
Automatic currency and monetary values
If the model has a method currency()
, then each time a price object is requested, the result of this method is used for the price currency. That will allow you storing the currency alongside the amount iteself in the model
The same goes for a monetary()
method - if its there in the model, then it'll be used for all the conversions.
Validators
There are 2 out of the box validator rules - one for currency and one for price.
The price rule is basically a numeric rule, which performes the checks on the price's amount.
The currency validator is a choice validator, with the currencies of the world preselected in the "in" variable.
class Model_Product extends Jam_Model { static public function initialize(Jam_Meta $meta) { $meta ->fields(array( 'id' => Jam::field('primary'), 'price' => Jam::field('price'), 'currency' => Jam::field('string'), )) ->validator('price' => array('price' => array('greater_than' => 10))) ->validator('currency' => array('currency' => TRUE)); } }
License
Copyright (c) 2012-2013, OpenBuildings Ltd. Developed by Ivan Kerin as part of clippings.com
Under BSD-3-Clause license, read LICENSE file.