forked from extern/egroupware
added cat_access
This commit is contained in:
parent
88e2bbd08d
commit
acb00bf31c
@ -24,8 +24,11 @@
|
|||||||
if ($submit) {
|
if ($submit) {
|
||||||
$errorcount = 0;
|
$errorcount = 0;
|
||||||
|
|
||||||
$exists = $c->exists('main',$cat_name);
|
$exists_main = $c->exists('main',$cat_name);
|
||||||
if ($exists == True) { $error[$errorcount++] = lang('That category name has been used already !'); }
|
if ($exists_main == True) { $error[$errorcount++] = lang('That main category name has been used already !'); }
|
||||||
|
|
||||||
|
$exists_sub = $c->exists('subs',$cat_name);
|
||||||
|
if ($exists_subs == True) { $error[$errorcount++] = lang('That sub category name has been used already !'); }
|
||||||
|
|
||||||
if (!$cat_name) { $error[$errorcount++] = lang('Please enter a name for that category !'); }
|
if (!$cat_name) { $error[$errorcount++] = lang('Please enter a name for that category !'); }
|
||||||
|
|
||||||
@ -53,8 +56,8 @@
|
|||||||
$t->set_var('lang_choose',lang('Choose the category'));
|
$t->set_var('lang_choose',lang('Choose the category'));
|
||||||
$t->set_var('lang_select_parent',lang('Select parent category'));
|
$t->set_var('lang_select_parent',lang('Select parent category'));
|
||||||
$t->set_var('lang_access',lang('Private'));
|
$t->set_var('lang_access',lang('Private'));
|
||||||
if ($access) { $t->set_var('access', '<input type="checkbox" name="private" value="True" checked>'); }
|
if ($access) { $t->set_var('access', '<input type="checkbox" name="access" value="True" checked>'); }
|
||||||
else { $t->set_var('access', '<input type="checkbox" name="private" value="True"'); }
|
else { $t->set_var('access', '<input type="checkbox" name="access" value="True"'); }
|
||||||
$t->set_var('lang_name',lang('Category name'));
|
$t->set_var('lang_name',lang('Category name'));
|
||||||
$t->set_var('lang_descr',lang('Category description'));
|
$t->set_var('lang_descr',lang('Category description'));
|
||||||
$t->set_var('cat_name',$cat_name);
|
$t->set_var('cat_name',$cat_name);
|
||||||
|
@ -30,15 +30,21 @@
|
|||||||
$errorcount = 0;
|
$errorcount = 0;
|
||||||
if (!$cat_name) { $error[$errorcount++] = lang('Please enter a name for that category !'); }
|
if (!$cat_name) { $error[$errorcount++] = lang('Please enter a name for that category !'); }
|
||||||
$phpgw->db->query("SELECT count(*) from phpgw_categories WHERE cat_name='$cat_name' AND cat_id !='$cat_id' AND cat_appname='"
|
$phpgw->db->query("SELECT count(*) from phpgw_categories WHERE cat_name='$cat_name' AND cat_id !='$cat_id' AND cat_appname='"
|
||||||
. $phpgw_info["flags"]["currentapp"] ."'");
|
. $phpgw_info["flags"]["currentapp"] ."' AND cat_parent='0'");
|
||||||
$phpgw->db->next_record();
|
$phpgw->db->next_record();
|
||||||
if ($phpgw->db->f(0) != 0) { $error[$errorcount++] = lang('That category name has been used already !'); }
|
if ($phpgw->db->f(0) != 0) { $error[$errorcount++] = lang('That main category name has been used already !'); }
|
||||||
|
|
||||||
|
$phpgw->db->query("SELECT count(*) from phpgw_categories WHERE cat_name='$cat_name' AND cat_id !='$cat_id' AND cat_appname='"
|
||||||
|
. $phpgw_info["flags"]["currentapp"] ."' AND cat_parent != '0'");
|
||||||
|
$phpgw->db->next_record();
|
||||||
|
if ($phpgw->db->f(0) != 0) { $error[$errorcount++] = lang('That sub category name has been used already !'); }
|
||||||
|
|
||||||
$cat_name = addslashes($cat_name);
|
$cat_name = addslashes($cat_name);
|
||||||
$cat_description = addslashes($cat_description);
|
$cat_description = addslashes($cat_description);
|
||||||
|
if ($access) { $cat_access = 'private'; }
|
||||||
|
else { $cat_access = 'public'; }
|
||||||
|
|
||||||
|
if (! $error) { $c->edit($cat_id,$cat_parent,$cat_name,$cat_description,$cat_data,$cat_access); }
|
||||||
if (! $error) { $c->edit($cat_id,$cat_parent,$cat_name,$cat_description,$cat_data); }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($errorcount) { $t->set_var('message',$phpgw->common->error_list($error)); }
|
if ($errorcount) { $t->set_var('message',$phpgw->common->error_list($error)); }
|
||||||
@ -47,6 +53,7 @@
|
|||||||
|
|
||||||
$cats = $c->return_single($cat_id);
|
$cats = $c->return_single($cat_id);
|
||||||
|
|
||||||
|
$cat_parent = $cats[0]['parent'];
|
||||||
$t->set_var('category_list',$c->formated_list('select','all',$cat_parent,'False'));
|
$t->set_var('category_list',$c->formated_list('select','all',$cat_parent,'False'));
|
||||||
$t->set_var('font',$font);
|
$t->set_var('font',$font);
|
||||||
$t->set_var('user_name',$phpgw_info["user"]["fullname"]);
|
$t->set_var('user_name',$phpgw_info["user"]["fullname"]);
|
||||||
@ -61,8 +68,8 @@
|
|||||||
$t->set_var('lang_descr',lang('Category description'));
|
$t->set_var('lang_descr',lang('Category description'));
|
||||||
$t->set_var('lang_select_parent',lang('Select parent category'));
|
$t->set_var('lang_select_parent',lang('Select parent category'));
|
||||||
$t->set_var('lang_access',lang('Private'));
|
$t->set_var('lang_access',lang('Private'));
|
||||||
if ($access) { $t->set_var('access', '<input type="checkbox" name="private" value="True" checked>'); }
|
if ($cats[0]['access']=='private') { $t->set_var('access', '<input type="checkbox" name="access" value="True" checked>'); }
|
||||||
else { $t->set_var('access', '<input type="checkbox" name="private" value="True"'); }
|
else { $t->set_var('access', '<input type="checkbox" name="access" value="True"'); }
|
||||||
|
|
||||||
$cat_id = $cats[0]['id'];
|
$cat_id = $cats[0]['id'];
|
||||||
|
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
var $cats;
|
var $cats;
|
||||||
var $db;
|
var $db;
|
||||||
var $total_records;
|
var $total_records;
|
||||||
|
var $grants;
|
||||||
/*!
|
/*!
|
||||||
@function filter
|
@function filter
|
||||||
@abstract ?
|
@abstract ?
|
||||||
@ -108,15 +109,30 @@
|
|||||||
$ordermethod = " order by cat_parent asc";
|
$ordermethod = " order by cat_parent asc";
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($query)
|
if (is_array($this->grants))
|
||||||
{
|
{
|
||||||
$sql = "select * from phpgw_categories where cat_appname='" . $this->app_name . "' $public_cats and "
|
$grants = $this->grants;
|
||||||
. "(cat_name like '%$query%' or cat_description like '%$query%') $filter $ordermethod";
|
while(list($user) = each($grants))
|
||||||
|
{
|
||||||
|
$public_user_list[] = $user;
|
||||||
|
}
|
||||||
|
reset($public_user_list);
|
||||||
|
$grant_cats = " (cat_owner='" . $this->account_id . "' OR cat_access='public' OR cat_owner in(" . implode(',',$public_user_list) . ")) ";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$sql = "select * from phpgw_categories where cat_appname='" . $this->app_name . "'"
|
$grant_cats = " (cat_owner='" . $this->account_id . "' OR cat_access='public') ";
|
||||||
. "$public_cats $filter $ordermethod";
|
}
|
||||||
|
|
||||||
|
if ($query)
|
||||||
|
{
|
||||||
|
$sql = "SELECT * from phpgw_categories WHERE cat_appname='" . $this->app_name . "' AND "
|
||||||
|
. " $grant_cats $public_cats AND (cat_name like '%$query%' OR cat_description like '%$query%') $filter $ordermethod";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$sql = "SELECT * from phpgw_categories WHERE cat_appname='" . $this->app_name . "' AND "
|
||||||
|
. " $grant_cats $public_cats $filter $ordermethod";
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->db2->query($sql,__LINE__,__FILE__);
|
$this->db2->query($sql,__LINE__,__FILE__);
|
||||||
@ -183,6 +199,7 @@
|
|||||||
$this->app_name = $app_name;
|
$this->app_name = $app_name;
|
||||||
$this->db = $phpgw->db;
|
$this->db = $phpgw->db;
|
||||||
$this->total_records = $this->db->num_rows();
|
$this->total_records = $this->db->num_rows();
|
||||||
|
$this->grants = $phpgw->acl->get_grants($app_name);
|
||||||
$this->cats = $this->return_array($type,$start,$limit,$query,$sort,$order,$public);
|
$this->cats = $this->return_array($type,$start,$limit,$query,$sort,$order,$public);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user