git-svn-id: file:///svn-source/pmgr/branches/yafr_20090716/site@494 97e9348a-65ac-dc4b-aefc-98561f571b83
175 lines
5.1 KiB
PHP
175 lines
5.1 KiB
PHP
<?php
|
|
class Unit extends AppModel {
|
|
|
|
var $name = 'Unit';
|
|
var $validate = array(
|
|
'id' => array('numeric'),
|
|
'unit_size_id' => array('numeric'),
|
|
'name' => array('notempty'),
|
|
'sort_order' => array('numeric'),
|
|
'walk_order' => array('numeric'),
|
|
'deposit' => array('money'),
|
|
'amount' => array('money')
|
|
);
|
|
|
|
var $belongsTo = array(
|
|
'UnitSize',
|
|
);
|
|
|
|
var $hasOne = array(
|
|
'CurrentLease' => array(
|
|
'className' => 'Lease',
|
|
'conditions' => 'CurrentLease.moveout_date IS NULL',
|
|
),
|
|
);
|
|
|
|
var $hasMany = array(
|
|
'Lease',
|
|
);
|
|
|
|
//var $default_log_level = array('log' => 30, 'show' => 15);
|
|
|
|
/**************************************************************************
|
|
**************************************************************************
|
|
**************************************************************************
|
|
* helpers: status enumerations
|
|
*/
|
|
|
|
function statusEnums() {
|
|
static $status_enums;
|
|
if (!isset($status_enums))
|
|
$status_enums = $this->getEnumValues('status');
|
|
return $status_enums;
|
|
}
|
|
|
|
function activeStatusEnums() {
|
|
return array_diff_key($this->statusEnums(), array(''=>1, 'DELETED'=>1));
|
|
}
|
|
|
|
function statusValue($enum) {
|
|
$enums = $this->statusEnums();
|
|
return $enums[$enum];
|
|
}
|
|
|
|
function occupiedEnumValue() {
|
|
return $this->statusValue('OCCUPIED');
|
|
}
|
|
|
|
function conditionOccupied() {
|
|
return ('Unit.status >= ' . $this->statusValue('OCCUPIED'));
|
|
}
|
|
|
|
function conditionVacant() {
|
|
return ('Unit.status BETWEEN ' .
|
|
($this->statusValue('UNAVAILABLE')+1) .
|
|
' AND ' .
|
|
($this->statusValue('OCCUPIED')-1));
|
|
}
|
|
|
|
function conditionUnavailable() {
|
|
return ('Unit.status <= ' . $this->statusValue('UNAVAILABLE'));
|
|
}
|
|
|
|
|
|
/**************************************************************************
|
|
**************************************************************************
|
|
**************************************************************************
|
|
* function: allowedStatusSet
|
|
* - Returns the status set allowed for the given unit
|
|
*/
|
|
function allowedStatusSet($id) {
|
|
$this->prEnter(compact('id'));
|
|
$this->id = $id;
|
|
$old_status = $this->field('status');
|
|
$old_val = $this->statusValue($old_status);
|
|
$this->pr(17, compact('old_status', 'old_val'));
|
|
|
|
$enums = $this->activeStatusEnums();
|
|
$this->pr(21, compact('enums'));
|
|
|
|
foreach ($enums AS $enum => $val) {
|
|
if (($old_val < $this->occupiedEnumValue()) !=
|
|
($val < $this->occupiedEnumValue())) {
|
|
unset($enums[$enum]);
|
|
}
|
|
}
|
|
|
|
return $this->prReturn($enums);
|
|
}
|
|
|
|
|
|
/**************************************************************************
|
|
**************************************************************************
|
|
**************************************************************************
|
|
* function: updateStatus
|
|
* - Update the given unit to the given status
|
|
*/
|
|
function updateStatus($id, $status, $check = false) {
|
|
$this->prEnter(compact('id', 'status', 'check'));
|
|
|
|
/* if ($check) { */
|
|
/* $old_status = $this->field('status'); */
|
|
/* $this->pr(17, compact('old_status')); */
|
|
/* if ($this->statusValue($old_status) < $this->occupiedEnumValue() && */
|
|
/* $this->statusValue($status) >= $this->occupiedEnumValue()) */
|
|
/* { */
|
|
/* die("Can't transition a unit from vacant to occupied"); */
|
|
/* return $this->prReturn(false); */
|
|
/* } */
|
|
/* if ($this->statusValue($old_status) >= $this->occupiedEnumValue() && */
|
|
/* $this->statusValue($status) < $this->occupiedEnumValue()) */
|
|
/* { */
|
|
/* die("Can't transition a unit from occupied to vacant"); */
|
|
/* return $this->prReturn(false); */
|
|
/* } */
|
|
/* } */
|
|
|
|
if ($check) {
|
|
if (!array_key_exists($status, $this->allowedStatusSet($id)))
|
|
return $this->prReturn(false);
|
|
}
|
|
|
|
$this->id = $id;
|
|
$this->saveField('status', $status);
|
|
return $this->prReturn(true);
|
|
}
|
|
|
|
|
|
/**************************************************************************
|
|
**************************************************************************
|
|
**************************************************************************
|
|
* function: stats
|
|
* - Returns summary data from the requested customer.
|
|
*/
|
|
|
|
function stats($id = null) {
|
|
if (!$id)
|
|
return null;
|
|
|
|
// Get the basic information necessary
|
|
$unit = $this->find('first',
|
|
array('contain' => array
|
|
('Lease' => array
|
|
('fields' => array('Lease.id')),
|
|
|
|
'CurrentLease' => array
|
|
('fields' => array('CurrentLease.id'))),
|
|
|
|
'conditions' => array
|
|
(array('Unit.id' => $id)),
|
|
));
|
|
|
|
// Get the stats for the current lease
|
|
$stats['CurrentLease'] = $this->Lease->stats($unit['CurrentLease']['id']);
|
|
|
|
// Sum the stats for all leases together
|
|
foreach ($unit['Lease'] AS $lease) {
|
|
$this->statsMerge($stats['Lease'], $this->Lease->stats($lease['id']));
|
|
}
|
|
|
|
// Return the collection
|
|
return $stats;
|
|
}
|
|
|
|
}
|