100, 'order' => array('Contact.last_name' => 'ASC', 'Contact.first_name' => 'ASC')); /************************************************************************** ************************************************************************** ************************************************************************** * override: sideMenuLinks * - Generates controller specific links for the side menu */ function sideMenuLinks() { $menu = parent::sideMenuLinks(); //$menu[] = array('hr' => true); $menu[] = array('name' => 'Tenants', 'header' => true); $menu[] = array('name' => 'Current', 'url' => array('controller' => 'contacts', 'action' => 'current')); $menu[] = array('name' => 'Past', 'url' => array('controller' => 'contacts', 'action' => 'past')); $menu[] = array('name' => 'All Tenants', 'url' => array('controller' => 'contacts', 'action' => 'tenants')); $menu[] = array('name' => 'All Contacts', 'url' => array('controller' => 'contacts', 'action' => 'all')); return $menu; } /************************************************************************** ************************************************************************** ************************************************************************** * 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->recursive = 0; $this->Contact->bindModel(array('hasOne' => array('ContactsLease', 'Lease' => array( 'foreignKey' => false, 'conditions' => array('Lease.id = ContactsLease.lease_id') ))), false); $title = 'Past Tenants'; $this->set('title', $title); $this->set('heading', $title); $this->set('contacts', $this->paginate(array('Lease.close_date IS NOT NULL', 'ContactsLease.type != "ALTERNATE"'))); $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'=>'')); } $this->Contact->recursive = 4; $this->Contact->Lease->LeaseType->unbindModel(array('hasMany' => array('Lease'))); $this->Contact->Lease->Charge->unbindModel(array('belongsTo' => array('Lease'))); $this->Contact->Lease->Charge->ChargeType->unbindModel(array('hasMany' => array('Charge'))); $this->Contact->Lease->Charge->Receipt->unbindModel(array('hasMany' => array('ChargesReceipt'))); $contact = $this->Contact->read(null, $id); $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 20090530: // Using hardcoded value for security deposit... // That can't be good! if ($charge['charge_type_id'] == 1) $outstanding_deposit += $receipt['ChargesReceipt']['amount']; } } } $this->set(compact('contact', 'title', 'mytstval', 'outstanding_balance', 'outstanding_deposit')); } } ?>