2013-10-10 13:44:53 +11:00
|
|
|
<?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
|
|
|
|
*/
|
2013-04-26 11:42:09 +10:00
|
|
|
class Controller_Admin_Product extends Controller_Product {
|
|
|
|
protected $auth_required = TRUE;
|
|
|
|
|
2013-10-10 13:44:53 +11:00
|
|
|
protected $secure_actions = array(
|
2013-04-26 11:42:09 +10:00
|
|
|
'ajaxtranslatecategory'=>TRUE,
|
|
|
|
'ajaxtranslate'=>TRUE,
|
|
|
|
'category'=>TRUE,
|
|
|
|
'edit'=>TRUE,
|
2013-10-10 13:44:53 +11:00
|
|
|
'list'=>TRUE,
|
|
|
|
'view'=>TRUE,
|
|
|
|
);
|
|
|
|
|
2013-04-26 11:42:09 +10:00
|
|
|
public function action_ajaxtranslate() {
|
2013-10-10 13:44:53 +11:00
|
|
|
$po = ORM::factory('Product',$this->request->param('id'));
|
|
|
|
|
2013-04-26 11:42:09 +10:00
|
|
|
if (! $po->loaded() OR ! isset($_REQUEST['key'])) {
|
|
|
|
$output = _('Unable to find translate data');
|
2013-10-10 13:44:53 +11:00
|
|
|
|
2013-04-26 11:42:09 +10:00
|
|
|
} else {
|
2013-10-10 13:44:53 +11:00
|
|
|
$pto = $po->product_translate->where('language_id','=',$_REQUEST['key'])->find();
|
|
|
|
|
2013-04-26 11:42:09 +10:00
|
|
|
$output = View::factory('product/admin/ajaxtranslate')
|
|
|
|
->set('o',$pto);
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
2013-04-26 11:42:09 +10:00
|
|
|
|
2013-06-17 18:01:47 +10:00
|
|
|
$this->template->content = $output;
|
2013-04-26 11:42:09 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve the product category translate record
|
|
|
|
*/
|
|
|
|
public function action_ajaxtranslatecategory() {
|
|
|
|
$pco = ORM::factory('Product_Category',$this->request->param('id'));
|
|
|
|
|
|
|
|
if (! $pco->loaded() OR ! isset($_REQUEST['key'])) {
|
|
|
|
$output = _('Unable to find translate data');
|
|
|
|
|
|
|
|
} else {
|
|
|
|
$pcto = $pco->product_category_translate->where('language_id','=',$_REQUEST['key'])->find();
|
|
|
|
|
|
|
|
$output = View::factory('product/category/admin/ajaxtranslate')
|
|
|
|
->set('o',$pcto);
|
|
|
|
}
|
|
|
|
|
2013-06-17 18:01:47 +10:00
|
|
|
$this->template->content = $output;
|
2013-04-26 11:42:09 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the product category
|
|
|
|
*/
|
|
|
|
public function action_category() {
|
|
|
|
$pco = ORM::factory('Product_Category',$this->request->param('id'));
|
|
|
|
|
|
|
|
if (! $pco->loaded())
|
2013-06-01 23:43:31 +10:00
|
|
|
HTTP::redirect(URL::link('admin','product/list'));
|
2013-04-26 11:42:09 +10:00
|
|
|
|
|
|
|
if ($_POST)
|
|
|
|
$pco->values($_POST)->save();
|
|
|
|
|
|
|
|
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]").replaceWith(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 ($_POST)
|
|
|
|
$po->values($_POST)->save();
|
|
|
|
|
|
|
|
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]").replaceWith(data);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
');
|
|
|
|
|
|
|
|
Block::factory()
|
|
|
|
->type('form-horizontal')
|
|
|
|
->title('Update Product')
|
|
|
|
->title_icon('icon-wrench')
|
|
|
|
->body(View::factory('product/admin/edit')
|
|
|
|
->set('plugin_form',$po->admin_update())
|
|
|
|
->set('o',$po));
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show a list of products
|
|
|
|
*/
|
|
|
|
public function action_list() {
|
2013-10-14 11:26:08 +11:00
|
|
|
$products = ($x=$this->request->param('id')) ? ORM::factory('Product_Category',$x)->products() : ORM::factory('Product')->order_by('status','DESC')->order_by('prod_plugin_file')->find_all();
|
2013-04-26 11:42:09 +10:00
|
|
|
|
|
|
|
Block::factory()
|
|
|
|
->title(_('Products'))
|
|
|
|
->title_icon('icon-th')
|
|
|
|
->body(Table::display(
|
|
|
|
$products,
|
2013-10-10 13:44:53 +11:00
|
|
|
25,
|
|
|
|
array(
|
|
|
|
'id'=>array('label'=>'ID','url'=>URL::link('admin','product/view/')),
|
2013-04-26 11:42:09 +10:00
|
|
|
'title()'=>array('label'=>'Details'),
|
|
|
|
'status(TRUE)'=>array('label'=>'Active'),
|
2013-10-10 13:44:53 +11:00
|
|
|
'prod_plugin_file'=>array('label'=>'Plugin Name'),
|
|
|
|
'prod_plugin_data'=>array('label'=>'Plugin Data'),
|
|
|
|
'price_type'=>array('label'=>'Price Type'),
|
|
|
|
'taxable'=>array('label'=>'Taxable'),
|
|
|
|
'count_services()'=>array('label'=>'Services'),
|
|
|
|
'count_invoices()'=>array('label'=>'Invoices'),
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'page'=>TRUE,
|
|
|
|
'type'=>'select',
|
|
|
|
'form'=>URL::link('admin','product/view'),
|
2013-04-26 11:42:09 +10:00
|
|
|
)));
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
public function action_view() {
|
|
|
|
$po = ORM::factory('Product',$this->request->param('id'));
|
|
|
|
|
2013-06-13 23:35:19 +10:00
|
|
|
if (! $po->loaded())
|
|
|
|
throw HTTP_Exception::factory(403,'Product either doesnt exist, or you are not authorised to see it');
|
|
|
|
|
2013-04-26 11:42:09 +10:00
|
|
|
Block::factory()
|
|
|
|
->title(sprintf('%s: %s',_('Current Services Using this Product'),$po->title()))
|
|
|
|
->title_icon('icon-th-list')
|
|
|
|
->body(Table::display(
|
|
|
|
$po->services()->find_all(),
|
2013-10-10 13:44:53 +11:00
|
|
|
25,
|
|
|
|
array(
|
|
|
|
'id'=>array('label'=>'ID','url'=>URL::link('user','service/view/')),
|
|
|
|
'account->accnum()'=>array(),
|
|
|
|
'account->name()'=>array('label'=>'Account'),
|
|
|
|
'name()'=>array('label'=>'Details'),
|
2013-04-26 11:42:09 +10:00
|
|
|
'status(TRUE)'=>array('label'=>'Active'),
|
2013-10-10 13:44:53 +11:00
|
|
|
'price(TRUE,TRUE)'=>array('label'=>'Price','align'=>'right'),
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'page'=>TRUE,
|
|
|
|
'type'=>'select',
|
|
|
|
'form'=>URL::link('user','service/view'),
|
2013-04-26 11:42:09 +10:00
|
|
|
)));
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|