forked from grayghostvisuals/wp-flex
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathheader.php
executable file
·117 lines (103 loc) · 7.36 KB
/
header.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
<!doctype html>
<!--[if IE 8]><html class="no-js lt-ie9" <?php language_attributes(); ?>><![endif]-->
<!--[if gt IE 8]><!--><html class="no-js" <?php language_attributes(); ?>><!--<![endif]-->
<head>
<meta charset="<?php bloginfo( 'charset' ); ?>">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title><?php wp_title( '»', true, 'left' ); ?></title>
<?php if ( is_search() || is_404() ) : ?>
<meta name="robots" content="noindex, nofollow">
<?php else: ?>
<meta name="robots" content="all">
<?php endif; ?>
<?php if ( is_home() ) : ?>
<meta name="description" content="<?php esc_attr( bloginfo( 'name' ) ); esc_attr( bloginfo( 'description' ) ); ?>">
<?php elseif ( is_single() ) : ?>
<meta name="description" content="<?php esc_attr( wp_title() ) ?>">
<?php elseif ( is_archive() ) : ?>
<meta name="description" content="<?php esc_attr( bloginfo( 'name' ) ); ?> » Archives">
<?php elseif ( is_search() ) : ?>
<meta name="description" content="<?php esc_html( $s ) ?>">
<?php else : ?>
<meta name="description" content="<?php esc_attr( bloginfo( 'name' ) ); ?> : <?php esc_attr( bloginfo( 'description' ) ); ?>">
<?php endif; ?>
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=1">
<meta name="HandheldFriendly" content="True">
<meta name="MobileOptimized" content="320">
<meta name="apple-mobile-web-app-capable" content="yes">
<link rel="profile" href="http://gmpg.org/xfn/11">
<link rel="pingback" href="<?php bloginfo( 'pingback_url' ); ?>">
<link rel="alternate" type="application/rss+xml" title="RSS 2.0" href="<?php bloginfo( 'rss2_url' ); ?>">
<!-- required for comment functionality -->
<?php if ( is_singular() && get_option( 'thread_comments' ) ) wp_enqueue_script( 'comment-reply' ); ?>
<!-- required for all wordpress themes and placed at the end of the head tag element -->
<?php wp_head(); ?>
</head>
<body <?php body_class(); ?>>
<header role="banner">
<?php $header = get_header_image() ?>
<?php if ( isset( $header ) || $header ) : ?>
<div id="header-image">
<a href="<?php echo home_url() ?>"><img src="<?php header_image(); ?>" height="<?php echo get_custom_header()->height; ?>" width="<?php echo get_custom_header()->width; ?>" alt=""></a>
</div>
<?php endif; ?>
<h1 class="blogname"><a href="<?php echo home_url(); ?>"><?php esc_attr( bloginfo( 'name' ) ); ?></a></h1>
<h2 class="tagline"><?php echo esc_attr( bloginfo( 'description' ) ); ?></h2>
<?php
function wpflex_custom_nav() {
if ( 'wp_nav_menu' ) :
wp_nav_menu( array(
'theme_location' => 'primary', // Location in the theme to be used--must be registered with register_nav_menu() in order to be selectable by the user
'menu' => 'primary', // The menu that is desired; accepts (matching in order) id, slug, name
'container' => 'nav', // Whether or not to wrap the ul, and what to wrap it with. Allowed tags are 'div' and 'nav.' Use false for no container
'container_class' => '', // What will the container from the previous option have as its 'class' name. (if you used a div as the 'container')
'container_id' => '', // What will the container from the previous option have as its 'id' name. (if you used a div as the 'container')
'menu_class' => '', // The navigations containg element surrounding li elements will have this class (i.e. <ul class="menu_class"><li></li></ul>)
'menu_id' => '', // The ID that is applied to the ul element which forms the menu
'echo' => true, // Removes the custom nav menu entirely from view and the HTML markup
'fallback_cb' => 'wpflex_nav_fallback', // wp_nav_menu falback call function. If wp_nav_menu is not used by the author then do the following within the callback
'before' => '', // Output text before the anchor tag of the link. This value can be a string or HTML
'after' => '', // Output text before the anchor tag of the link. This value can be a string or HTML
'link_before' => '', // If HTML is injected in this value then the anchor is strippped away entirely. Only use strings of content ( NO HTML)
'link_after' => '', // If HTML is injected in this value then the anchor is strippped away entirely. Only use strings of content ( NO HTML )
'items_wrap' => '<ul id="%1$s" class="%2$s">%3$s</ul>', // Whatever to wrap the items with, and how to wrap them
'depth' => 0, // how many levels of the hierarchy are to be included where 0 means all
'walker' => '' // Custom walker object to use (Note: You must pass an actual object to use, not a string)- Feel free to make this clearer
));
else :
wpflex_nav_fallback();
endif;
}
function wpflex_nav_fallback() {
$wpflex_nav = array(
'depth' => 0, // All Pages and sub-pages are displayed (no depth restriction)
'show_date' => '', // Display creation or last modified date next to each Page. The default value is the null value (do not display dates).
'date_format' => get_option( 'date_format' ), // Controls the format of the Page date set by the show_date parameter (example: "l, F j, Y"). This parameter defaults to the date format configured in your WordPress options
'child_of' => 0, // Displays the sub-pages of a single Page only; uses the ID for a Page as the value Defaults to 0 (displays all Pages).
'exclude' => '', // Define a comma-separated list of Page IDs to be excluded from the list (example: 'exclude' => '3,7,31'). There is no default value
'include' => '', // Only include certain Pages in the list generated by wp_list_pages. Accepts a comma-separated list of Page IDs. There is no default value
'title_li' => '', // Set the text and style of the Page list's heading
'echo' => 1, // Results are echoed (displayed)
'authors' => '', // Only include Pages authored by the authors in this comma-separated list of author IDs
'sort_column' => 'menu_order, post_title', // Sorted by Page Order over Page Title.
'sort_order' => 'ASC', // Change the sort order of the list of Pages (either ascending=ASC or descending=DESC). The default is ASC
'link_before' => '', // Sets the text or html that precedes the link text inside the anchor tag
'link_after' => '', // Sets the text or html that follows the link text inside the anchor tag
'walker' => '', // Custom walker object to use (Note: You must pass an actual object to use, not a string)- Feel free to make this clearer
'post_type' => 'page', // List custom post types. Default is 'page'.
'post_status' => 'publish' // Comma-separated list of all post status types to return. For example: 'publish,private'
);?>
<ol>
<?php
if ( wp_list_pages( $wpflex_nav ) ) : while ( wp_list_pages( $wpflex_nav ) ) :
wp_list_pages( $wpflex_nav );
endwhile;
endif;
?>
</ol>
<?php } // end wp_nav_fallback
wpflex_custom_nav();
?>
</header>
<article><a href="<?php bloginfo( 'rss2_url' ) ?>">RSS Feed</a></article>
<?php get_search_form(); ?>