I'm working on a website bilt with wordpress. I've included a select type menu with the name and links of my children pages of one parent page. everything works fine, my pages are sorted alphabetically ASC :
Bali
Bruxelles
Chicago
Edinburgh
Geneve
Los Angeles
Lyon
Miami
Paris
San Diego
San Francisco
Vancouver
Washington
Zurich
here is my code :
<div class="styled-select">
<?php
if(!$post->post_parent){
$children = get_pages(array(
'child_of' => $post->ID,
'post_type' => 'page',
'post_status' => 'publish',
'sort_order' => 'ASC',
'sort_column' => 'post_title',
));
}else{
$children = get_pages(array(
'child_of' => $post->post_parent,
'post_type' => 'page',
'post_status' => 'publish',
'sort_order' => 'ASC',
'sort_column' => 'post_title',
));
}
if ($children) {
echo '<select name="" onchange="location = this.options[this.selectedIndex].value;">';
echo '<option>'. 'A - Z' .'</option>';
foreach($children as $child){
//print_r($child);
$permalink = get_permalink($child->ID);
echo '<option value="'.$permalink.'">'.$child->post_title.'</option>';
}
echo '</select>';
} ?>
</div>
I wanted to know if its possible to add automatically an alphabet index (width in guess) inside my menu, like this. add "A" in before all pages beginning with A (when there are pages beginning with A...), add "B" in before all pages beginning with B, and so on... Something who must look like this :
A
B
Bali
Bruxelles
C
Chicago
D
E
F
Edinburgh
G
Geneve
H
I
J
K
L
Los Angeles
Lyon
M
Miami
N
O
P
Paris
Q
R
S
San Diego
San Francisco
T
U
V
Vancouver
W
Washington
X
Y
Z
Zurich
If anybody know who I can do it it would be much appreciate ! thanks a lot
Mattieu
use as follows (for demonstration only) :
function getInitials($name){
//split name using spaces
$words=explode(" ",$name);
$inits='';
//loop through array extracting initial letters
foreach($words as $word){
$inits.=strtoupper(substr($word,0,1));
}
return $inits;
}
$currval = "";
foreach($children as $child){
//print_r($child);
$permalink = get_permalink($child->ID);
$initial = getInitials($child->post_title);
if($initial!='' && $currval != $initial) {
$currval = $initial;
echo '<optgroup>'.$initial.'</option>';
}
echo '<option value="'.$permalink.'">'.$child->post_title.'</option>';
}
Not checked though.. please check and return if you face any prob
In the case you need to show all alphabets, i can give you an idea to do so
function getInitials($name){
//split name using spaces
$words=explode(" ",$name);
$inits='';
//loop through array extracting initial letters
foreach($words as $word){
$inits.=strtoupper(substr($word,0,1));
}
return $inits;
}
$currval = "";
$alp = array('A'...'Z')
foreach($alp as $abc) {
foreach($children as $child){
//print_r($child);
$permalink = get_permalink($child->ID);
$initial = getInitials($child->post_title);
if($initial!='' && $currval != $initial && $initial == $abc) {
$currval = $initial;
echo '<optgroup>'.$initial.'</option>';
}
echo '<option value="'.$permalink.'">'.$child->post_title.'</option>';
}
}
Hello i have again edited the code as per your need.
please check
<?php
function getInitials($name){
//split name using spaces
$words=explode(" ",$name);
$inits='';
//loop through array extracting initial letters
foreach($words as $word){
$inits = strtoupper(substr($word,0,1));
break;
}
return $inits;
}
$currval = "";
$alp = array('A','B','C','D','E','Y','S','Z');
//$children = array('Asin','Bali','Bruxelles','Chicago','Denmark','Edinburgh','Flag','San Francisco');
?>
<select name="test">
<?php
foreach($alp as $key => $abc) {
$showinOpt = false;
foreach($children as $child) {
$permalink = get_permalink($child->ID);
$initial = getInitials($child->post_title);
if($initial == $abc) {
if($currval != $initial) {
$currval = $initial;
echo '<optgroup label="'.$initial.'">'.$initial.'</optgroup>';
$showinOpt = true;
}
echo '<option value="'.$permalink.'">'.$child->post_title.'</option>';
}
}
if(!$showinOpt) {
echo '<optgroup label="'.$abc.'">'.$abc.'</optgroup>';
}
}
?>
</select>
Just add this after you got the $children array.