Question

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

Was it helpful?

Solution

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>';
    }
}

OTHER TIPS

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.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top