Files
pmgr/controllers/contacts_controller.php

324 lines
10 KiB
PHP

<?php
class ContactsController extends AppController {
var $helpers = array('Html');
var $paginate = array('limit' => 100,
'order' => array('Contact.last_name' => 'ASC',
'Contact.first_name' => 'ASC'));
var $sidemenu_links =
array(array('name' => 'Tenants', 'header' => true),
array('name' => 'Current', 'url' => array('controller' => 'contacts', 'action' => 'current')),
array('name' => 'Past', 'url' => array('controller' => 'contacts', 'action' => 'past')),
array('name' => 'All Tenants', 'url' => array('controller' => 'contacts', 'action' => 'tenants')),
array('name' => 'All Contacts', 'url' => array('controller' => 'contacts', 'action' => 'all')),
);
/**************************************************************************
**************************************************************************
**************************************************************************
* override: sideMenuLinks
* - Generates controller specific links for the side menu
*/
function sideMenuLinks() {
return array_merge(parent::sideMenuLinks(), $this->sidemenu_links);
}
/**************************************************************************
**************************************************************************
**************************************************************************
* action: index
* - Lists all current tenants
*/
function index() {
$this->current();
}
/**************************************************************************
**************************************************************************
**************************************************************************
* action: past
* - Lists all tenants, past and present
*/
function tenants() {
$this->Contact->recursive = 0;
$this->Contact->bindModel(array('hasOne' => array('ContactsLease')),
false);
$title = 'All Tenants';
$this->set('title', $title); $this->set('heading', $title);
$this->set('contacts', $this->paginate(array('ContactsLease.type != "ALTERNATE"')));
$this->render('index');
}
/**************************************************************************
**************************************************************************
**************************************************************************
* action: current
* - Lists all current tenants
*/
function current() {
$this->Contact->recursive = 0;
$this->Contact->bindModel(array('hasOne' => array('ContactsLease',
'Lease' => array(
'foreignKey' => false,
'conditions' => array('Lease.id = ContactsLease.lease_id')
))),
false);
$title = 'Current Tenants';
$this->set('title', $title); $this->set('heading', $title);
$this->set('contacts', $this->paginate(array('Lease.close_date IS NULL',
'ContactsLease.type != "ALTERNATE"')));
$this->render('index');
}
/**************************************************************************
**************************************************************************
**************************************************************************
* action: past
* - Lists all past tenants
*/
function past() {
/* $this->Contact->contain */
/* (array(// Models */
/* 'ContactPhone', */
/* 'ContactEmail', */
/* 'ContactAddress', */
/* 'Lease' => */
/* array('order' => 'movein_date', */
/* 'conditions' => array('Lease.close_date IS NOT NULL', */
/* 'ContactsLease.type !=' => 'ALTERNATE'), */
/* // Models */
/* 'Unit' => */
/* array('order' => array('sort_order'), */
/* 'fields' => array('id', 'name'), */
/* ), */
/* /\* 'Charge' => *\/ */
/* /\* array('order' => array('charge_date'), *\/ */
/* /\* // Models *\/ */
/* /\* 'ChargeType', *\/ */
/* /\* 'Receipt', *\/ */
/* /\* ) *\/ */
/* ) */
/* ) */
/* ); */
/* $contact = $this->Contact->find('all', */
/* array('order' => 'id DESC', */
/* 'conditions' => array('Lease.id IS NOT NULL'), */
/* 'contain' => */
/* array( */
/* // Models */
/* 'Lease' => */
/* array('order' => 'movein_date', */
/* 'conditions' => array('Lease.lease_date IS NOT NULL', */
/* 'Lease.close_date IS NOT NULL', */
/* 'ContactsLease.type !=' => 'ALTERNATE'), */
/* ) */
/* ) */
/* )); */
/* $contacts = $this->Contact->find */
/* ('all', array */
/* ('contain' => array */
/* ('Lease' => array */
/* ('conditions' => array('lease_date >' => "2009-04-01"), */
/* ) */
/* ), */
/* 'order' => 'id DESC', */
/* 'conditions' => array('Lease.id IS NOT NULL') */
/* )); */
/* $contacts = $this->Contact->find('all', */
/* array('order' => 'id DESC', */
/* 'contain' => 'Lease.lease_date > "2009-04-01"' */
/* )); */
/* pr($contacts); */
/* $this->set('contacts', $contacts); */
/* $this->Contact->Behaviors->attach('Containable'); */
/* $this->Contact->contain */
/* (array(// Models */
/* 'ContactPhone', */
/* 'ContactEmail', */
/* 'ContactAddress', */
/* 'Lease' => */
/* array('order' => 'movein_date', */
/* 'conditions' => array('Lease.close_date IS NOT NULL', */
/* 'ContactsLease.type !=' => 'ALTERNATE'), */
/* // Models */
/* 'Unit' => */
/* array('order' => array('sort_order'), */
/* 'fields' => array('id', 'name'), */
/* ), */
/* /\* 'Charge' => *\/ */
/* /\* array('order' => array('charge_date'), *\/ */
/* /\* // Models *\/ */
/* /\* 'ChargeType', *\/ */
/* /\* 'Receipt', *\/ */
/* /\* ) *\/ */
/* ) */
/* ) */
/* ); */
$this->paginate =
array('link' =>
array(// Models
'ContactPhone' => array('fields' => array('phone'),
//'type' => 'INNER'
),
//'ContactEmail',
//'ContactAddress',
'Lease' =>
array('fields' => array(),
'type' => 'LEFT',
// Models
'Unit' => array('fields' => array('name'),
//'type' => 'INNER',
),
)
),
'order' => 'Contact.last_name, Contact.first_name',
'conditions' => array(//'ContactsLease.type !=' => 'ALTERNATE',
//'Lease.id IS NOT NULL',
//'Lease.lease_date IS NOT NULL',
//'Lease.close_date IS NOT NULL'
),
'group' => 'Contact.id',
'fields' => array('id', 'first_name', 'last_name', 'company_name', 'comment'),
);
$title = 'Past Tenants';
$this->set('title', $title); $this->set('heading', $title);
$this->set('contacts', $this->paginate());
//$this->set('contacts', $this->Contact->find('all', array('order' => 'id DESC')));
//$this->set('contacts', $this->Contact->find('all'));
/* $this->set('contacts', $this->Contact->find('all')); */
/* $this->set('contacts', $this->Contact->find('all')); */
$this->render('index');
}
/**************************************************************************
**************************************************************************
**************************************************************************
* action: all
* - Lists all contacts, including non-tenants
*/
function all() {
$this->Contact->recursive = 0;
$title = 'All Contacts';
$this->set('title', $title); $this->set('heading', $title);
$this->set('contacts', $this->paginate());
$this->render('index');
}
/**************************************************************************
**************************************************************************
**************************************************************************
* action: view
* - Displays information about a specific contact
*/
function view($id = null) {
if (!$id) {
$this->Session->setFlash(__('Invalid Item.', true));
$this->redirect(array('action'=>'index'));
}
//pr($this->Contact);
//pr($this->Contact->ContactPhone);
$this->Contact->Behaviors->attach('Containable');
$this->Contact->contain
(array(// Models
'ContactPhone',
'ContactEmail',
'ContactAddress',
'Lease' =>
array('order' => 'movein_date',
'conditions' => array('Lease.lease_date IS NOT NULL',
'ContactsLease.type !=' => 'ALTERNATE'),
// Models
'Unit' =>
array('order' => array('sort_order'),
'fields' => array('id', 'name'),
),
'Charge' =>
array('order' => array('charge_date'),
// Models
'ChargeType',
'Receipt',
)
)
)
);
$contact = $this->Contact->read(null, $id);
/* $contact = $this->Contact->find */
/* ('first', */
/* array('link' => array */
/* (// Models */
/* 'ContactPhone', */
/* 'ContactEmail', */
/* 'ContactAddress', */
/* 'Lease' => */
/* array(// Models */
/* 'Unit' => array('fields' => array('id', 'name')), */
/* 'Charge' => array(// Models */
/* 'ChargeType', */
/* 'Receipt', */
/* ) */
/* ) */
/* ), */
/* 'order' => 'Lease.movein_date, Unit.sort_order, Charge.charge_date', */
/* 'conditions' => array('Lease.lease_date IS NOT NULL', */
/* 'ContactsLease.type !=' => 'ALTERNATE'), */
/* )); */
/* pr($contact); */
$title = $contact['Contact']['display_name'];
$outstanding_deposit = 0;
$outstanding_balance = 0;
foreach($contact['Lease'] AS $lease) {
foreach($lease['Charge'] AS $charge) {
$outstanding_balance += $charge['total'];
foreach ($charge['Receipt'] AS $receipt) {
$outstanding_balance -= $receipt['ChargesReceipt']['amount'];
// REVISIT <AP> 20090530:
// Using hardcoded value for security deposit...
// That can't be good!
if ($charge['charge_type_id'] == 1)
$outstanding_deposit += $receipt['ChargesReceipt']['amount'];
}
}
}
$this->sidemenu_links[] =
array('name' => 'Operations', 'header' => true);
$this->sidemenu_links[] =
array('name' => 'Move-Out', 'url' => array('controller' => 'units', 'action' => 'move-out'));
$this->set(compact('contact', 'title',
'outstanding_balance',
'outstanding_deposit'));
}
}
?>