100, 'group' => 'Customer.id', 'order' => array('Customer.name' => 'ASC')); var $sidemenu_links = array(array('name' => 'Tenants', 'header' => true), array('name' => 'Current', 'url' => array('controller' => 'customers', 'action' => 'current')), array('name' => 'Past', 'url' => array('controller' => 'customers', 'action' => 'past')), array('name' => 'All', 'url' => array('controller' => 'customers', '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: current * - Lists all current tenants */ function current() { $this->paginate = array_merge ($this->paginate, array('link' => array(// Models 'Lease' => array('fields' => array(), 'type' => 'INNER', ), ), 'conditions' => array('Lease.close_date IS NULL') )); $title = 'Current Tenants'; $this->set('title', $title); $this->set('heading', $title); $this->set('customers', $this->paginate()); $this->render('index'); } /************************************************************************** ************************************************************************** ************************************************************************** * action: past * - Lists all past tenants */ function past() { $this->paginate = array_merge ($this->paginate, array('link' => array(// Models 'Lease' => array('fields' => array(), 'type' => 'INNER', ), ), 'conditions' => array('Lease.close_date IS NOT NULL') )); $title = 'Past Tenants'; $this->set('title', $title); $this->set('heading', $title); $this->set('customers', $this->paginate()); $this->render('index'); } /************************************************************************** ************************************************************************** ************************************************************************** * action: all * - Lists all customers, including non-tenants */ function all() { $title = 'All Customers'; $this->set('title', $title); $this->set('heading', $title); $this->set('customers', $this->paginate()); $this->render('index'); } /************************************************************************** ************************************************************************** ************************************************************************** * action: view * - Displays information about a specific customer */ function view($id = null) { if (!$id) { $this->Session->setFlash(__('Invalid Item.', true)); $this->redirect(array('action'=>'index')); } $this->Customer->Behaviors->attach('Containable'); $this->Customer->contain (array(// Models 'Contact' => array(// Models 'ContactPhone', 'ContactEmail', 'ContactAddress', ), 'Account', 'Lease' => array(//'order' => 'movein_date', //'conditions' => array('Lease.lease_date IS NOT NULL'), // Models //'Account', 'Unit' => array('order' => array('sort_order'), 'fields' => array('id', 'name'), ), ), ) ); $customer = $this->Customer->read(null, $id); $this->Customer->Behaviors->detach('Containable'); foreach ($customer['Lease'] AS &$lease) { $stats = $this->Customer->Lease->stats($lease['id']); //pr($stats); $lease['balance'] = $stats['Account']['Ledger']['balance']; } //pr($customer); $stats = $this->Customer->stats($id); $deposits = $this->Customer->findSecurityDeposits($id); $outstanding_balance = $stats['balance']; $outstanding_deposit = $deposits['summary']['balance']; /* pr(array('Customer Stats', $stats)); */ /* pr(array('Security Deposits', $deposits)); */ $this->sidemenu_links[] = array('name' => 'Operations', 'header' => true); $this->sidemenu_links[] = array('name' => 'Move-Out', 'url' => array('controller' => 'units', 'action' => 'move-out')); $customer['Account'] = array_merge($customer['Account'], $stats['Account']['Ledger']); //pr($stats); //unset($stats['Lease'], $stats['Account']); /* $customer['Account']['debits'] = 10; */ /* $customer['Account']['credits'] = 20; */ /* $customer['Account']['balance'] = 55; */ $title = $customer['Customer']['name']; $this->set(compact('customer', 'title', 'outstanding_balance', 'outstanding_deposit')); } }