-
Notifications
You must be signed in to change notification settings - Fork 0
/
theme.php
169 lines (151 loc) · 5 KB
/
theme.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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
<?php
/**
* MyTheme is a custom Theme class for the K2 theme.
*
* @package Habari
*/
// We must tell Habari to use MyTheme as the custom theme class:
define( 'THEME_CLASS', 'MyTheme' );
/**
* A custom theme for K2 output
*/
class MyTheme extends Theme
{
protected $defaults = array(
'login_display_location' => 'sidebar',
'home_label' => 'Blog',
'show_author' => false,
);
/**
* Add the K2 menu block to the nav area upon theme activation if there's nothing already there
*/
public function action_theme_activated()
{
$opts = Options::get_group( __CLASS__ );
if ( empty( $opts ) ) {
Options::set_group( __CLASS__, $this->defaults );
}
}
/**
* Execute on theme init to apply these filters to output
*/
public function action_init_theme()
{
// Apply Format::autop() to post content...
Format::apply( 'autop', 'post_content_out' );
// Apply Format::autop() to comment content...
Format::apply( 'autop', 'comment_content_out' );
// Apply Format::tag_and_list() to post tags...
Format::apply( 'tag_and_list', 'post_tags_out' );
// Remove the comment on the following line to limit post length on the home page to 1 paragraph or 100 characters
//Format::apply_with_hook_params( 'more', 'post_content_out', _t('more'), 100, 1 );
}
/**
* Add additional template variables to the template output.
*
* You can assign additional output values in the template here, instead of
* having the PHP execute directly in the template. The advantage is that
* you would easily be able to switch between template types (RawPHP/Smarty)
* without having to port code from one to the other.
*
* You could use this area to provide "recent comments" data to the template,
* for instance.
*
* Note that the variables added here should possibly *always* be added,
* especially 'user'.
*
* Also, this function gets executed *after* regular data is assigned to the
* template. So the values here, unless checked, will overwrite any existing
* values.
*/
public function add_template_vars()
{
//Theme Options
$this->assign( 'display_login', Options::get( __CLASS__ . '__login_display_location', 'sidebar' ) );
$this->assign( 'home_label' , Options::get( __CLASS__ . '__home_label', _t( 'Blog' ) ) );
$this->assign( 'show_author', Options::get( __CLASS__ . '__show_author', false ) );
if( !$this->template_engine->assigned( 'pages' ) ) {
$this->assign('pages', Posts::get( array( 'content_type' => 'page', 'status' => Post::status('published'), 'nolimit' => 1 ) ) );
}
if( !$this->template_engine->assigned( 'page' ) ) {
$page = Controller::get_var( 'page' );
$this->assign('page', isset( $page ) ? $page : 1 );
}
parent::add_template_vars();
if ( User::identify()->loggedin ) {
Stack::add( 'template_header_javascript', Site::get_url('scripts') . '/jquery.js', 'jquery' );
}
}
/**
* function action_theme_ui
* Create and display the Theme configuration
**/
public function action_theme_ui()
{
$opts = Options::get_group( __CLASS__ );
if ( empty( $opts ) ) {
Options::set_group( __CLASS__, $this->defaults );
}
$controls = array();
$controls['home_label'] = array(
'label' => _t('Home tab label:', 'deanpaul'),
'type' => 'text'
);
$controls['login_display_location'] = array(
'label' => _t('Login display:', 'deanpaul'),
'type' => 'select',
'options' => array(
'nowhere' => _t( 'Nowhere', 'deanpaul' ),
'header' => _t( 'As a navigation tab', 'deanpaul' ),
'sidebar' => _t( 'In the sidebar', 'deanpaul' )
)
);
$controls['show_author'] = array(
'label' => _t( 'Display author:', 'deanpaul' ),
'type' => 'checkbox',
);
$ui = new FormUI( strtolower( get_class( $this ) ) );
$wrapper = $ui->append( 'wrapper', 'config', 'config' );
$wrapper->class = "settings clear";
foreach ( $controls as $option_name => $option ) {
$field = $wrapper->append( $option['type'], $option_name, __CLASS__. '__' . $option_name, $option['label'] );
$field->template = 'optionscontrol_' . $option['type'];
$field->class = "item clear";
if ( $option['type'] === 'select' and isset( $option['options'] ) ) {
$field->options = $option['options'];
}
}
$ui->append( 'submit', 'save', _t( 'Save', 'deanpaul' ) );
$ui->on_success( array( $this, 'config_updated') );
$ui->out();
}
/**
* function config_updated
* Return a success message
**/
public function config_updated( $ui )
{
Session::notice( _t( 'Configuration updated', 'deanpaul' ) );
$ui->save();
}
public function k2_comment_class( $comment, $post )
{
$class = 'class="comment';
if ( $comment->status == Comment::STATUS_UNAPPROVED ) {
$class.= '-unapproved';
}
// check to see if the comment is by a registered user
if ( $u = User::get( $comment->email ) ) {
$class.= ' byuser comment-author-' . Utils::slugify( $u->displayname );
}
if( $comment->email == $post->author->email ) {
$class.= ' bypostauthor';
}
$class.= '"';
return $class;
}
public function action_form_comment( $form ) {
$form->cf_content->caption = '';
}
}
?>