jn-devops / property
Homeful Property Package
Fund package maintenance!
Homeful
Installs: 3 116
Dependents: 2
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: ^8.2
- illuminate/contracts: ^10.0||^11.0
- jarouche/financial: ^2.1
- jn-devops/common: ^1.2
- spatie/laravel-data: ^4.6
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^9.0.0||^8.22.0
- pestphp/pest: ^2.34
- pestphp/pest-plugin-arch: ^2.7
- pestphp/pest-plugin-laravel: ^2.3
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^1.1
- phpstan/phpstan-phpunit: ^1.3
- spatie/laravel-ray: ^1.35
README
The Homeful Property Package provides a structured way to handle property-related data, including total contract price validation, market segments, housing types, development types, loanable value calculations, fees, and more.
Table of Contents
Installation
To install the package, use Composer:
composer require homeful/property
Usage
Creating a Property Instance
use Homeful\Property\Property; use Whitecube\Price\Price; use Brick\Money\Money; $property = new Property; $property->setTotalContractPrice(new Price(Money::of(1500000, 'PHP')));
Setting and Retrieving Market Segments
use Homeful\Property\Enums\MarketSegment; $property->setMarketSegment(MarketSegment::ECONOMIC); echo $property->getMarketSegment()->getName(); // Outputs "economic"
Classes
Property
The core class representing a property.
Properties:
total_contract_price
: Total contract price as aPrice
object.appraised_value
: Appraised value as aPrice
object.development_type
: The development type as anEnum
.housing_type
: The housing type as anEnum
.market_segment
: The market segment as anEnum
.work_area
: The work area as anEnum
.loanable_value_multiplier
: Loanable value multiplier.disposableIncomeRequirementMultiplier
: Disposable income requirement multiplier.storeys
: Number of storeys.floor_area
: Floor area.charges
: Collection of additional property charges.appraisal
: Appraisal details.
Methods:
setTotalContractPrice(Price|Money|float $value)
getTotalContractPrice(): Price
setMarketSegment(MarketSegment $market_segment)
getMarketSegment(): MarketSegment
setAppraisedValue(Price|Money|float $value)
getAppraisedValue(): Price
setDevelopmentType(DevelopmentType $type)
getDevelopmentType(): DevelopmentType
setHousingType(HousingType $type)
getHousingType(): HousingType
setLoanableValueMultiplier(float $value)
getLoanableValueMultiplier(): float
getLoanableValue(): Price
getDefaultAnnualInterestRateFromBorrower(BorrowerInterface $borrower): float
getPriceCeiling(): Price
addCharge(Charge $charge)
getFees(): Price
getSellingPrice(): Price
Traits
HasCalculations
Handles loanable value, interest rates, and disposable income multipliers.
HasFees
Handles mortgage redemption insurance and annual fire insurance calculations.
HasProduct
Handles product-related attributes like SKU, processing fees, and down payment terms.
HasProperties
Handles property attributes such as housing type, total contract price, and work area.
Enumerations
MarketSegment
Defines the property market segment:
OPEN
ECONOMIC
SOCIALIZED
DevelopmentType
Defines the type of development:
BP_957
BP_220
HousingType
Defines the type of housing unit:
CONDOMINIUM
DUPLEX
ROW_HOUSE
SINGLE_ATTACHED
SINGLE_DETACHED
QUADRUPLEX
TOWNHOUSE
TWIN_HOMES
Charge
Defines property-related charges:
PROCESSING_FEE
HOME_UTILITY_CONNECTION_FEE
Tests
The package includes a series of tests to validate:
- Minimum and maximum total contract price
- Market segment determination
- Housing type assignment
- Development type assignment
- Loanable value calculation
- Price ceiling determination
- Default interest rate based on income and location
- Charge and fee calculations
- Product attributes
To run tests:
vendor/bin/pest