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 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')); } } ?>