mirror of
https://github.com/opensourcepos/opensourcepos.git
synced 2026-01-15 21:07:57 -05:00
Tom git-svn-id: svn+ssh://jekkos@svn.code.sf.net/p/opensourcepos/code/@43 c3eb156b-1dc0-44e1-88ae-e38439141b53
201 lines
5.2 KiB
PHP
201 lines
5.2 KiB
PHP
<?php
|
|
require_once ("person_controller.php");
|
|
class Customers extends Person_controller
|
|
{
|
|
function __construct()
|
|
{
|
|
parent::__construct('customers');
|
|
}
|
|
|
|
function index()
|
|
{
|
|
$config['base_url'] = site_url('/customers/index');
|
|
$config['total_rows'] = $this->Customer->count_all();
|
|
$config['per_page'] = '20';
|
|
$config['uri_segment'] = 3;
|
|
$this->pagination->initialize($config);
|
|
|
|
$data['controller_name']=strtolower(get_class());
|
|
$data['form_width']=$this->get_form_width();
|
|
$data['manage_table']=get_people_manage_table( $this->Customer->get_all( $config['per_page'], $this->uri->segment( $config['uri_segment'] ) ), $this );
|
|
$this->load->view('people/manage',$data);
|
|
}
|
|
|
|
/*
|
|
Returns customer table data rows. This will be called with AJAX.
|
|
*/
|
|
function search()
|
|
{
|
|
$search=$this->input->post('search');
|
|
$data_rows=get_people_manage_table_data_rows($this->Customer->search($search),$this);
|
|
echo $data_rows;
|
|
}
|
|
|
|
/*
|
|
Gives search suggestions based on what is being searched for
|
|
*/
|
|
function suggest()
|
|
{
|
|
$suggestions = $this->Customer->get_search_suggestions($this->input->post('q'),$this->input->post('limit'));
|
|
echo implode("\n",$suggestions);
|
|
}
|
|
|
|
/*
|
|
Loads the customer edit form
|
|
*/
|
|
function view($customer_id=-1)
|
|
{
|
|
$data['person_info']=$this->Customer->get_info($customer_id);
|
|
$this->load->view("customers/form",$data);
|
|
}
|
|
|
|
/*
|
|
Inserts/updates a customer
|
|
*/
|
|
function save($customer_id=-1)
|
|
{
|
|
$person_data = array(
|
|
'first_name'=>$this->input->post('first_name'),
|
|
'last_name'=>$this->input->post('last_name'),
|
|
'email'=>$this->input->post('email'),
|
|
'phone_number'=>$this->input->post('phone_number'),
|
|
'address_1'=>$this->input->post('address_1'),
|
|
'address_2'=>$this->input->post('address_2'),
|
|
'city'=>$this->input->post('city'),
|
|
'state'=>$this->input->post('state'),
|
|
'zip'=>$this->input->post('zip'),
|
|
'country'=>$this->input->post('country'),
|
|
'comments'=>$this->input->post('comments')
|
|
);
|
|
$customer_data=array(
|
|
'account_number'=>$this->input->post('account_number')=='' ? null:$this->input->post('account_number'),
|
|
'taxable'=>$this->input->post('taxable')=='' ? 0:1,
|
|
);
|
|
if($this->Customer->save($person_data,$customer_data,$customer_id))
|
|
{
|
|
//New customer
|
|
if($customer_id==-1)
|
|
{
|
|
echo json_encode(array('success'=>true,'message'=>$this->lang->line('customers_successful_adding').' '.
|
|
$person_data['first_name'].' '.$person_data['last_name'],'person_id'=>$customer_data['person_id']));
|
|
}
|
|
else //previous customer
|
|
{
|
|
echo json_encode(array('success'=>true,'message'=>$this->lang->line('customers_successful_updating').' '.
|
|
$person_data['first_name'].' '.$person_data['last_name'],'person_id'=>$customer_id));
|
|
}
|
|
}
|
|
else//failure
|
|
{
|
|
echo json_encode(array('success'=>false,'message'=>$this->lang->line('customers_error_adding_updating').' '.
|
|
$person_data['first_name'].' '.$person_data['last_name'],'person_id'=>-1));
|
|
}
|
|
}
|
|
|
|
/*
|
|
This deletes customers from the customers table
|
|
*/
|
|
function delete()
|
|
{
|
|
$customers_to_delete=$this->input->post('ids');
|
|
|
|
if($this->Customer->delete_list($customers_to_delete))
|
|
{
|
|
echo json_encode(array('success'=>true,'message'=>$this->lang->line('customers_successful_deleted').' '.
|
|
count($customers_to_delete).' '.$this->lang->line('customers_one_or_multiple')));
|
|
}
|
|
else
|
|
{
|
|
echo json_encode(array('success'=>false,'message'=>$this->lang->line('customers_cannot_be_deleted')));
|
|
}
|
|
}
|
|
|
|
function excel()
|
|
{
|
|
$data = file_get_contents("import_customers.csv");
|
|
$name = 'import_customers.csv';
|
|
force_download($name, $data);
|
|
}
|
|
|
|
function excel_import()
|
|
{
|
|
$this->load->view("customers/excel_import", null);
|
|
}
|
|
|
|
function do_excel_import()
|
|
{
|
|
$msg = 'do_excel_import';
|
|
$failCodes = array();
|
|
if ($_FILES['file_path']['error']!=UPLOAD_ERR_OK)
|
|
{
|
|
$msg = $this->lang->line('items_excel_import_failed');
|
|
echo json_encode( array('success'=>false,'message'=>$msg) );
|
|
return;
|
|
}
|
|
else
|
|
{
|
|
if (($handle = fopen($_FILES['file_path']['tmp_name'], "r")) !== FALSE)
|
|
{
|
|
//Skip first row
|
|
fgetcsv($handle);
|
|
|
|
$i=1;
|
|
while (($data = fgetcsv($handle)) !== FALSE)
|
|
{
|
|
$person_data = array(
|
|
'first_name'=>$data[0],
|
|
'last_name'=>$data[1],
|
|
'email'=>$data[2],
|
|
'phone_number'=>$data[3],
|
|
'address_1'=>$data[4],
|
|
'address_2'=>$data[5],
|
|
'city'=>$data[6],
|
|
'state'=>$data[7],
|
|
'zip'=>$data[8],
|
|
'country'=>$data[9],
|
|
'comments'=>$data[10]
|
|
);
|
|
|
|
$customer_data=array(
|
|
'account_number'=>$data[11]=='' ? null:$data[11],
|
|
'taxable'=>$data[12]=='' ? 0:1,
|
|
);
|
|
|
|
if(!$this->Customer->save($person_data,$customer_data))
|
|
{
|
|
$failCodes[] = $i;
|
|
}
|
|
|
|
$i++;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
echo json_encode( array('success'=>false,'message'=>'Your upload file has no data or not in supported format.') );
|
|
return;
|
|
}
|
|
}
|
|
|
|
$success = true;
|
|
if(count($failCodes) > 1)
|
|
{
|
|
$msg = "Most customers imported. But some were not, here is list of their CODE (" .count($failCodes) ."): ".implode(", ", $failCodes);
|
|
$success = false;
|
|
}
|
|
else
|
|
{
|
|
$msg = "Import Customers successful";
|
|
}
|
|
|
|
echo json_encode( array('success'=>$success,'message'=>$msg) );
|
|
}
|
|
|
|
/*
|
|
get the width for the add/edit form
|
|
*/
|
|
function get_form_width()
|
|
{
|
|
return 350;
|
|
}
|
|
}
|
|
?>
|