menu management is now functional with the exception of acl's (and of course a way to display the menus you create, and probably a bit more input sanity checking)
This commit is contained in:
parent
680baff73d
commit
9508967c73
2
boot.php
2
boot.php
@ -289,7 +289,7 @@ define ( 'ATTACH_FLAG_OS', 0x0002);
|
|||||||
|
|
||||||
|
|
||||||
define ( 'MENU_ITEM_ZID', 0x0001);
|
define ( 'MENU_ITEM_ZID', 0x0001);
|
||||||
|
define ( 'MENU_ITEM_NEWWIN', 0x0002);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -29,7 +29,9 @@ function menu_render($menu) {
|
|||||||
return '';
|
return '';
|
||||||
for($x = 0; $x < count($menu['items']); $x ++)
|
for($x = 0; $x < count($menu['items']); $x ++)
|
||||||
if($menu['items']['mitem_flags'] & MENU_ITEM_ZID)
|
if($menu['items']['mitem_flags'] & MENU_ITEM_ZID)
|
||||||
$menu['items']['link'] = zid($menu['items']['link']);
|
$menu['items']['mitem_link'] = zid($menu['items']['mitem_link']);
|
||||||
|
if($menu['items']['mitem_flags'] & MENU_ITEM_NEWWIN)
|
||||||
|
$menu['items']['newwin'] = '1';
|
||||||
|
|
||||||
return replace_macros(get_markup_template('usermenu.tpl'),array(
|
return replace_macros(get_markup_template('usermenu.tpl'),array(
|
||||||
'$menu' => $menu['menu'],
|
'$menu' => $menu['menu'],
|
||||||
|
@ -22,7 +22,7 @@ function menu_post(&$a) {
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$r = menu_create($_REQUEST);
|
$r = menu_create($_REQUEST);
|
||||||
if($r) {
|
if($r) {
|
||||||
info( t('Menu created.') . EOL);
|
info( t('Menu created.') . EOL);
|
||||||
goaway(z_root() . '/mitem/' . $r);
|
goaway(z_root() . '/mitem/' . $r);
|
||||||
}
|
}
|
||||||
|
145
mod/mitem.php
145
mod/mitem.php
@ -1,20 +1,40 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
require_once('include/menu.php');
|
||||||
|
|
||||||
|
function mitem_init(&$a) {
|
||||||
|
if(! local_user())
|
||||||
|
return;
|
||||||
|
if(argc() < 2)
|
||||||
|
return;
|
||||||
|
|
||||||
|
$m = menu_fetch_id(intval(argv(1)),local_user());
|
||||||
|
if(! $m) {
|
||||||
|
notice( t('Menu not found.') . EOL);
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
$a->data['menu'] = $m;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
function mitem_post(&$a) {
|
function mitem_post(&$a) {
|
||||||
|
|
||||||
if(! local_user())
|
if(! local_user())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
$channel = $a->get_channel();
|
if(! $a->data['menu'])
|
||||||
$mitem_id = ((argc() > 1) ? intval(argv(1)) : 0);
|
return;
|
||||||
|
|
||||||
$mitem_link = (($_REQUEST['mitem_link']) ? $_REQUEST['menu_link'] : '');
|
$_REQUEST['mitem_channel_id'] = local_user();
|
||||||
$mitem_desc = (($_REQUEST['mitem_desc']) ? $_REQUEST['mitem_desc'] : '');
|
$_REQUEST['menu_id'] = $a->data['menu']['menu_id'];
|
||||||
$mitem_order = (($_REQUEST['mitem_order']) ? intval($_REQUEST['mitem_order']) : 0);
|
|
||||||
$mitem_id = (($_REQUEST['mitem_id']) ? intval($_REQUEST['mitem_id']) : 0);
|
|
||||||
|
|
||||||
$mitem_flags = (($_REQUEST['mitem_zid']) ? MENU_ITEM_ZID : 0);
|
$_REQUEST['mitem_flags'] = 0;
|
||||||
|
if($_REQUEST['usezid'])
|
||||||
|
$_REQUEST['mitem_flags'] |= MENU_ITEM_ZID;
|
||||||
|
if($_REQUEST['newwin'])
|
||||||
|
$_REQUEST['mitem_flags'] |= MENU_ITEM_NEWWIN;
|
||||||
|
|
||||||
|
// FIXME!!!!
|
||||||
|
|
||||||
if ((! $_REQUEST['contact_allow'])
|
if ((! $_REQUEST['contact_allow'])
|
||||||
&& (! $_REQUEST['group_allow'])
|
&& (! $_REQUEST['group_allow'])
|
||||||
@ -35,6 +55,34 @@ function mitem_post(&$a) {
|
|||||||
$str_contact_deny = perms2str($_REQUEST['contact_deny']);
|
$str_contact_deny = perms2str($_REQUEST['contact_deny']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$mitem_id = ((argc() > 2) ? intval(argv(2)) : 0);
|
||||||
|
if($mitem_id) {
|
||||||
|
$_REQUEST['mitem_id'] = $mitem_id;
|
||||||
|
$r = menu_edit_item($_REQUEST['menu_id'],local_user(),$_REQUEST);
|
||||||
|
if($r) {
|
||||||
|
info( t('Menu element updated.') . EOL);
|
||||||
|
goaway(z_root() . '/mitem/' . $_REQUEST['menu_id']);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
notice( t('Unable to update menu element.') . EOL);
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$r = menu_add_item($_REQUEST['menu_id'],local_user(),$_REQUEST);
|
||||||
|
if($r) {
|
||||||
|
info( t('Menu element added.') . EOL);
|
||||||
|
goaway(z_root() . '/mitem/' . $_REQUEST['menu_id']);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
notice( t('Unable to add menu element.') . EOL);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -45,24 +93,67 @@ function mitem_content(&$a) {
|
|||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(argc() < 2 || (! $a->data['menu'])) {
|
||||||
|
notice( t('Not found.') . EOL);
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
if(argc() == 1) {
|
|
||||||
// list menus
|
$m = menu_fetch($a->data['menu']['menu_name'],local_user(), get_observer_hash());
|
||||||
|
$a->set_widget('menu_preview',menu_render($m));
|
||||||
|
|
||||||
|
|
||||||
|
if(argc() == 2) {
|
||||||
|
$r = q("select * from menu_item where mitem_menu_id = %d and mitem_channel_id = %d order by mitem_order asc, mitem_desc asc",
|
||||||
|
intval($a->data['menu']['menu_id']),
|
||||||
|
local_user()
|
||||||
|
);
|
||||||
|
|
||||||
|
if($r) {
|
||||||
|
$o = replace_macros(get_markup_template('mitemlist.tpl'),array(
|
||||||
|
'$title' => t('Manage Menu Elements'),
|
||||||
|
'$menuname' => $a->data['menu']['menu_name'],
|
||||||
|
'$menudesc' => $a->data['menu']['menu_desc'],
|
||||||
|
'$edmenu' => t('Edit menu'),
|
||||||
|
'$menu_id' => $a->data['menu']['menu_id'],
|
||||||
|
'$mlist' => $r,
|
||||||
|
'$edit' => t('Edit element'),
|
||||||
|
'$drop' => t('Drop element'),
|
||||||
|
'$new' => t('New element'),
|
||||||
|
'$hintmenu' => t('Edit this menu container'),
|
||||||
|
'$hintnew' => t('Add menu element'),
|
||||||
|
'$hintdrop' => t('Delete this menu item'),
|
||||||
|
'$hintedit' => t('Edit this menu item')
|
||||||
|
));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return $o;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if(argc() > 1) {
|
if(argc() > 2) {
|
||||||
if(argv(1) === 'new') {
|
if(argv(2) === 'new') {
|
||||||
// new menu
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$o = replace_macros(get_markup_template('mitemedit.tpl'), array(
|
||||||
|
'$header' => t('New Menu Element'),
|
||||||
|
'$menu_id' => $a->data['menu']['menu_id'],
|
||||||
|
'$mitem_desc' => array('mitem_desc', t('Link text'), '', '','*'),
|
||||||
|
'$mitem_link' => array('mitem_link', t('URL of link'), '', '', '*'),
|
||||||
|
'$usezid' => array('usezid', t('Use Red magic-auth if available'), true, ''),
|
||||||
|
'$newwin' => array('newwin', t('Open link in new window'), false,''),
|
||||||
|
// permissions go here
|
||||||
|
'$mitem_order' => array('mitem_order', t('Order in list'),'0',t('Higher numbers will sink to bottom of listing')),
|
||||||
|
'$submit' => t('Create')
|
||||||
|
));
|
||||||
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
||||||
elseif(intval(argv(1))) {
|
|
||||||
|
elseif(intval(argv(2))) {
|
||||||
$m = q("select * from menu_item where mitem_id = %d and mitem_channel_id = %d limit 1",
|
$m = q("select * from menu_item where mitem_id = %d and mitem_channel_id = %d limit 1",
|
||||||
intval(argv(1)),
|
intval(argv(2)),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if(! $m) {
|
if(! $m) {
|
||||||
@ -71,19 +162,33 @@ function mitem_content(&$a) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$mitem = $m[0];
|
$mitem = $m[0];
|
||||||
if(argc() == 3 && argv(2) == 'drop') {
|
|
||||||
$r = menu_del_item($mitem['mitem_menu_id'], local_user(),intval(argv(1)));
|
if(argc() == 4 && argv(3) == 'drop') {
|
||||||
|
$r = menu_del_item($mitem['mitem_menu_id'], local_user(),intval(argv(2)));
|
||||||
if($r)
|
if($r)
|
||||||
info( t('Menu item deleted.') . EOL);
|
info( t('Menu item deleted.') . EOL);
|
||||||
else
|
else
|
||||||
notice( t('Menu item could not be deleted.'). EOL);
|
notice( t('Menu item could not be deleted.'). EOL);
|
||||||
|
|
||||||
goaway(z_root() . '/menu');
|
goaway(z_root() . '/mitem/' . $mitem['mitem_menu_id']);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
||||||
// edit menu item
|
// edit menu item
|
||||||
|
|
||||||
|
$o = replace_macros(get_markup_template('mitemedit.tpl'), array(
|
||||||
|
'$header' => t('Edit Menu Element'),
|
||||||
|
'$menu_id' => $a->data['menu']['menu_id'],
|
||||||
|
'$mitem_id' => intval(argv(2)),
|
||||||
|
'$mitem_desc' => array('mitem_desc', t('Link text'), $mitem['mitem_desc'], '','*'),
|
||||||
|
'$mitem_link' => array('mitem_link', t('URL of link'), $mitem['mitem_link'], '', '*'),
|
||||||
|
'$usezid' => array('usezid', t('Use Red magic-auth if available'), (($mitem['mitem_flags'] & MENU_ITEM_ZID) ? 1 : 0), ''),
|
||||||
|
'$newwin' => array('newwin', t('Open link in new window'), (($mitem['mitem_flags'] & MENU_ITEM_NEWWIN) ? 1 : 0),''),
|
||||||
|
// permissions go here
|
||||||
|
'$mitem_order' => array('mitem_order', t('Order in list'),$mitem['mitem_order'],t('Higher numbers will sink to bottom of listing')),
|
||||||
|
'$submit' => t('Modify')
|
||||||
|
));
|
||||||
|
return $o;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
<h2>{{$header}}</h2>
|
<h2>{{$header}}</h2>
|
||||||
|
|
||||||
{{if $menu_id}}
|
{{if $menu_id}}
|
||||||
<a href="medit/{{$menu_id}}" title="{{$hintedit}}">{{$editcontents}}</a>
|
<a href="mitem/{{$menu_id}}" title="{{$hintedit}}">{{$editcontents}}</a>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
|
||||||
<form id="menuedit" action="menu{{if $menu_id}}/{{$menu_id}}{{/if}}" method="post" >
|
<form id="menuedit" action="menu{{if $menu_id}}/{{$menu_id}}{{/if}}" method="post" >
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
{{if $menus }}
|
{{if $menus }}
|
||||||
<ul id="menulist">
|
<ul id="menulist">
|
||||||
{{foreach $menus as $m }}
|
{{foreach $menus as $m }}
|
||||||
<li><a href="menu/{{$m.menu_id}}" title="{{$hintedit}}">{{$edit}}</a> | <a href="menu/{{$m.menu.id}}/drop" title={{$hintdrop}}>{{$drop}}</a> <a href="medit/{{$m.menu_id}}" title="{{$hintcontent}}">{{$m.menu_name}}</a></li>
|
<li><a href="menu/{{$m.menu_id}}" title="{{$hintedit}}">{{$edit}}</a> | <a href="menu/{{$m.menu_id}}/drop" title={{$hintdrop}}>{{$drop}}</a> <a href="mitem/{{$m.menu_id}}" title="{{$hintcontent}}">{{$m.menu_name}}</a></li>
|
||||||
{{/foreach}}
|
{{/foreach}}
|
||||||
</ul>
|
</ul>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
{{if $items }}
|
{{if $items }}
|
||||||
<ul class="pmenu-body">
|
<ul class="pmenu-body">
|
||||||
{{foreach $items as $mitem }}
|
{{foreach $items as $mitem }}
|
||||||
<li class="pmenu-item"><a href="{{$mitem.mitem_link}}">{{$mitem.mitem_desc}}</a></li>
|
<li class="pmenu-item"><a href="{{$mitem.mitem_link}}" {{if $mitem.newwin}}target="_blank"{{/if}}>{{$mitem.mitem_desc}}</a></li>
|
||||||
{{/foreach }}
|
{{/foreach }}
|
||||||
</ul>
|
</ul>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
Reference in New Issue
Block a user