255 lines
6.8 KiB
PHP
255 lines
6.8 KiB
PHP
<?php defined('SYSPATH') or die('No direct access allowed.');
|
|
|
|
/**
|
|
* This class provides Admin Product management
|
|
*
|
|
* @package Product
|
|
* @category Controllers/Admin
|
|
* @author Deon George
|
|
* @copyright (c) 2009-2013 Open Source Billing
|
|
* @license http://dev.osbill.net/license.html
|
|
*/
|
|
class Controller_Admin_Product extends Controller_Product {
|
|
protected $auth_required = TRUE;
|
|
|
|
protected $secure_actions = array(
|
|
'ajaxaccounting'=>TRUE,
|
|
'ajaxtranslatecategory'=>TRUE,
|
|
'ajaxtranslate'=>TRUE,
|
|
'category'=>TRUE,
|
|
'edit'=>TRUE,
|
|
'list'=>TRUE,
|
|
'listused'=>TRUE,
|
|
'view'=>TRUE,
|
|
);
|
|
|
|
public function action_ajaxaccounting() {
|
|
$products = ORM::factory('Product')->where('accounting','LIKE','%'.$this->request->query('term').'%')->find_all();
|
|
|
|
$result = array();
|
|
foreach ($products as $po)
|
|
array_push($result,array('value'=>$po->accounting,'label'=>$po->accounting));
|
|
|
|
$this->response->headers('Content-Type','application/json');
|
|
$this->response->body(json_encode(array_values($result)));
|
|
}
|
|
|
|
public function action_ajaxtranslate() {
|
|
$po = ORM::factory('Product',$this->request->param('id'));
|
|
|
|
if (! $po->loaded() OR ! $this->request->query('key')) {
|
|
$output = _('Unable to find translate data');
|
|
|
|
} else {
|
|
$pto = $po->translate->where('language_id','=',$this->request->query('key'))->find();
|
|
|
|
$output = View::factory('product/admin/ajaxtranslate')
|
|
->set('o',$pto);
|
|
}
|
|
|
|
$this->template->content = $output;
|
|
}
|
|
|
|
/**
|
|
* Retrieve the product category translate record
|
|
*/
|
|
public function action_ajaxtranslatecategory() {
|
|
$pco = ORM::factory('Product_Category',$this->request->param('id'));
|
|
|
|
if (! $pco->loaded() OR ! $this->request->query('key')) {
|
|
$output = _('Unable to find translate data');
|
|
|
|
} else {
|
|
$pcto = $pco->translate->where('language_id','=',$this->request->query('key'))->find();
|
|
|
|
$output = View::factory('product/category/admin/ajaxtranslate')
|
|
->set('o',$pcto);
|
|
}
|
|
|
|
$this->template->content = $output;
|
|
}
|
|
|
|
/**
|
|
* Update the product category
|
|
*/
|
|
public function action_category() {
|
|
$pco = ORM::factory('Product_Category',$this->request->param('id'));
|
|
|
|
if (! $pco->loaded())
|
|
HTTP::redirect(URL::link('admin','product/list'));
|
|
|
|
if ($this->request->post() AND $pco->values($this->request->post())->changed() AND (! $this->save($pco)))
|
|
$pco->reload();
|
|
|
|
Script::factory()
|
|
->type('stdin')
|
|
->data('
|
|
$(document).ready(function() {
|
|
$("select[name=language_id]").change(function() {
|
|
// If we select a blank, then dont continue
|
|
if (this.value == 0)
|
|
return false;
|
|
|
|
// Send the request and update sub category dropdown
|
|
$.ajax({
|
|
type: "GET",
|
|
data: "key="+$(this).val(),
|
|
dataType: "html",
|
|
cache: false,
|
|
url: "'.URL::link('admin','product/ajaxtranslatecategory/'.$pco->id,TRUE).'",
|
|
timeout: 2000,
|
|
error: function(x) {
|
|
alert("Failed to submit");
|
|
},
|
|
success: function(data) {
|
|
$("div[id=translate]").empty().append(data);
|
|
}
|
|
});
|
|
});
|
|
});
|
|
');
|
|
|
|
Block::factory()
|
|
->type('form-horizontal')
|
|
->title('Update Category')
|
|
->title_icon('icon-wrench')
|
|
->body(View::factory('product/category/admin/edit')
|
|
->set('o',$pco));
|
|
}
|
|
|
|
/**
|
|
* Edit a product configuration
|
|
*/
|
|
public function action_edit() {
|
|
$po = ORM::factory('Product',$this->request->param('id'));
|
|
|
|
if (! $po->loaded())
|
|
HTTP::redirect('welcome/index');
|
|
|
|
if ($this->request->post() AND $po->values($this->request->post())->changed() AND (! $this->save($po)))
|
|
$po->reload();
|
|
|
|
Script::factory()
|
|
->type('stdin')
|
|
->data('
|
|
$(document).ready(function() {
|
|
$("select[name=language_id]").change(function() {
|
|
// If we select a blank, then dont continue
|
|
if (this.value == 0)
|
|
return false;
|
|
// Send the request and update sub category dropdown
|
|
$.ajax({
|
|
type: "GET",
|
|
data: "key="+$(this).val(),
|
|
dataType: "html",
|
|
cache: false,
|
|
url: "'.URL::link('admin','product/ajaxtranslate/'.$po->id,TRUE).'",
|
|
timeout: 2000,
|
|
error: function(x) {
|
|
alert("Failed to submit");
|
|
},
|
|
success: function(data) {
|
|
$("div[id=translate]").empty().append(data);
|
|
}
|
|
});
|
|
});
|
|
|
|
$("input[name=accounting]").typeahead({
|
|
minLength: 2,
|
|
source: function (query,process) {
|
|
accounting(\'a/product/ajaxaccounting\',query,process);
|
|
},
|
|
|
|
matcher: function () { return true; },
|
|
});
|
|
});
|
|
|
|
var d=0;
|
|
var accounting = _.debounce(function(url,query,process){
|
|
$.ajax({
|
|
url : site_url+url,
|
|
type : "GET",
|
|
data : "term=" + query,
|
|
dataType : "JSON",
|
|
async : true,
|
|
cache : false,
|
|
beforeSend : function() {
|
|
if (d++ == 0) $(\'i[name=acclook]\').removeClass("hidden");
|
|
},
|
|
success : function(data) {
|
|
// if json is null, means no match, won\'t do again.
|
|
if(data==null || (data.length===0)) return;
|
|
|
|
users = {};
|
|
userLabels = [];
|
|
|
|
_.each(data,function(item,ix,list) {
|
|
if (_.contains(users,item.label)) item.label = item.label + \' #\' + item.value;
|
|
|
|
userLabels.push(item.label);
|
|
users[item.label] = item.value;
|
|
});
|
|
|
|
process(userLabels);
|
|
},
|
|
complete : function() {
|
|
if (--d == 0) $(\'i[name=acclook]\').addClass("hidden");
|
|
}
|
|
})
|
|
}, 500);
|
|
');
|
|
|
|
Block::factory()
|
|
->type('form-horizontal')
|
|
->title('Update Product')
|
|
->title_icon('fa fa-wrench')
|
|
->body(View::factory('product/admin/edit')
|
|
->set('plugin_form',$po->plugin_edit())
|
|
->set('o',$po));
|
|
}
|
|
|
|
/**
|
|
* Show a list of products
|
|
*/
|
|
public function action_list() {
|
|
$products = ($x=ORM::factory('Product_Category',$this->request->param('id')) AND $x->loaded()) ? $x->products() : ORM::factory('Product')->order_by('active','DESC')->order_by('prod_plugin_file')->find_all();
|
|
|
|
Block::factory()
|
|
->title(_('Products').($x->loaded() ? ' - '.$x->name() : ' - All'))
|
|
->title_icon('fa fa-list')
|
|
->body(View::factory('product/list')->set('list',$products));
|
|
}
|
|
|
|
/**
|
|
* List all the products that have an active service
|
|
*/
|
|
public function action_listused() {
|
|
$db = Database::instance();
|
|
|
|
$columns = '';
|
|
foreach (array_keys(ORM::factory('Product')->table_columns()) as $text)
|
|
$columns .= ($columns ? ',' : '').'p.'.$text;
|
|
|
|
$products = $db->query(Database::SELECT,sprintf('SELECT %s FROM ab_product p,ab_service s WHERE s.product_id=p.id AND s.active=1 AND p.site_id = s.site_id AND s.site_id=%s GROUP BY p.id',$columns,Company::instance()->site()),'Model_Product');
|
|
|
|
Block::factory()
|
|
->title(_('Products with Active Services'))
|
|
->title_icon('fa fa-list')
|
|
->body(View::factory('product/list')->set('list',$products));
|
|
}
|
|
|
|
|
|
public function action_view() {
|
|
$po = ORM::factory('Product',$this->request->param('id'));
|
|
|
|
if (! $po->loaded())
|
|
throw HTTP_Exception::factory(403,'Product either doesnt exist, or you are not authorised to see it');
|
|
|
|
Block::factory()
|
|
->title(sprintf('%s: %s',_('Current Services Using this Product'),$po->name(Site::language())))
|
|
->title_icon('icon-th-list')
|
|
->body(View::factory('service/reseller/list')->set('o',$po->service->where_active()->find_all()));
|
|
}
|
|
}
|
|
?>
|