-
Notifications
You must be signed in to change notification settings - Fork 44
/
Copy pathclass-usage-demo.php
394 lines (349 loc) · 14.7 KB
/
class-usage-demo.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
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
<?php
/*
Plugin Name: Demo Admin Page
Plugin URI: http://en.bainternet.info
Description: My Admin Page Class usage demo
Version: 1.2.9
Author: Bainternet, Ohad Raz
Author URI: http://en.bainternet.info
*/
//include the main class file
require_once("admin-page-class/admin-page-class.php");
/**
* configure your admin page
*/
$config = array(
'menu' => 'settings', //sub page to settings page
'page_title' => __('Demo Admin Page','apc'), //The name of this page
'capability' => 'edit_themes', // The capability needed to view the page
'option_group' => 'demo_options', //the name of the option to create in the database
'id' => 'admin_page', // meta box id, unique per page
'fields' => array(), // list of fields (can be added by field arrays)
'local_images' => false, // Use local or hosted images (meta box images for add/remove)
'use_with_theme' => false //change path if used with theme set to true, false for a plugin or anything else for a custom path(default false).
);
/**
* instantiate your admin page
*/
$options_panel = new BF_Admin_Page_Class($config);
$options_panel->OpenTabs_container('');
/**
* define your admin page tabs listing
*/
$options_panel->TabsListing(array(
'links' => array(
'options_1' => __('Simple Options','apc'),
'options_2' => __('Fancy Options','apc'),
'options_3' => __('Editor Options','apc'),
'options_4' => __('WordPress Options','apc'),
'options_5' => __('Advanced Options','apc'),
'options_6' => __('Field Validation','apc'),
'options_7' => __('Import Export','apc'),
)
));
/**
* Open admin page first tab
*/
$options_panel->OpenTab('options_1');
/**
* Add fields to your admin page first tab
*
* Simple options:
* input text, checbox, select, radio
* textarea
*/
//title
$options_panel->Title(__("Simple Options","apc"));
//An optionl descrption paragraph
$options_panel->addParagraph(__("This is a simple paragraph","apc"));
//text field
$options_panel->addText('text_field_id', array('name'=> __('My Text ','apc'), 'std'=> 'text', 'desc' => __('Simple text field description','apc')));
//textarea field
$options_panel->addTextarea('textarea_field_id',array('name'=> __('My Textarea ','apc'), 'std'=> 'textarea', 'desc' => __('Simple textarea field description','apc')));
//checkbox field
$options_panel->addCheckbox('checkbox_field_id',array('name'=> __('My Checkbox ','apc'), 'std' => true, 'desc' => __('Simple checkbox field description','apc')));
//select field
$options_panel->addSelect('select_field_id',array('selectkey1'=>'Select Value1','selectkey2'=>'Select Value2'),array('name'=> __('My select ','apc'), 'std'=> array('selectkey2'), 'desc' => __('Simple select field description','apc')));
//radio field
$options_panel->addRadio('radio_field_id',array('radiokey1'=>'Radio Value1','radiokey2'=>'Radio Value2'),array('name'=> __('My Radio Filed','apc'), 'std'=> array('radiokey2'), 'desc' => __('Simple radio field description','apc')));
/**
* Close first tab
*/
$options_panel->CloseTab();
/**
* Open admin page Second tab
*/
$options_panel->OpenTab('options_2');
/**
* Add fields to your admin page 2nd tab
*
* Fancy options:
* typography field
* image uploader
* Pluploader
* date picker
* time picker
* color picker
*/
//title
$options_panel->Title(__('Fancy Options','apc'));
//Typography field
$options_panel->addTypo('typography_field_id',array('name' => __("My Typography","apc"),'std' => array('size' => '14px', 'color' => '#000000', 'face' => 'arial', 'style' => 'normal'), 'desc' => __('Typography field description','apc')));
//Image field
$options_panel->addImage('image_field_id',array('name'=> __('My Image ','apc'),'preview_height' => '120px', 'preview_width' => '440px', 'desc' => __('Simple image field description','apc')));
//PLupload field
$options_panel->addPlupload('plupload_field_ID',array('name' => __('PlUpload Field','apc'), 'multiple' => true, 'desc' => __('Simple multiple image field description','apc')));
//date field
$options_panel->addDate('date_field_id',array('name'=> __('My Date ','apc'), 'desc' => __('Simple date picker field description','apc')));
//Time field
$options_panel->addTime('time_field_id',array('name'=> __('My Time ','apc'), 'desc' => __('Simple time picker field description','apc')));
//Color field
$options_panel->addColor('color_field_id',array('name'=> __('My Color ','apc'), 'desc' => __('Simple color picker field description','apc')));
/**
* Close second tab
*/
$options_panel->CloseTab();
/**
* Open admin page 3rd tab
*/
$options_panel->OpenTab('options_3');
/**
* Add fields to your admin page 3rd tab
*
* Editor options:
* WYSIWYG (tinyMCE editor)
* Syntax code editor (css,html,js,php)
*/
//title
$options_panel->Title(__("Editor Options","apc"));
//wysiwyg field
$options_panel->addWysiwyg('wysiwyg_field_id',array('name'=> __('My wysiwyg Editor ','apc'), 'desc' => __('wysiwyg field description','apc')));
//code editor field
$options_panel->addCode('code_field_id',array('name'=> __('Code Editor ','apc'),'syntax' => 'php', 'desc' => __('code editor field description','apc')));
/**
* Close 3rd tab
*/
$options_panel->CloseTab();
/**
* Open admin page 4th tab
*/
$options_panel->OpenTab('options_4');
/**
* Add fields to your admin page 4th tab
*
* WordPress Options:
* Taxonomies dropdown
* posts dropdown
* Taxonomies checkboxes list
* posts checkboxes list
*
*/
//title
$options_panel->Title(__("WordPress Options","apc"));
//taxonomy select field
$options_panel->addTaxonomy('taxonomy_field_id',array('taxonomy' => 'category'),array('name'=> __('My Taxonomy Select','apc'),'class' => 'no-fancy','desc' => __('This field has a <pre>.no-fancy</pre> class which disables the fancy select2 functions','apc') ));
//posts select field
$options_panel->addPosts('posts_field_id',array('args' => array('post_type' => 'post')),array('name'=> __('My Posts Select','apc'), 'desc' => __('posts select field description','apc')));
//Roles select field
$options_panel->addRoles('roles_field_id',array(),array('name'=> __('My Roles Select','apc'), 'desc' => __('roles select field description','apc')));
//taxonomy checkbox field
$options_panel->addTaxonomy('taxonomy2_field_id',array('taxonomy' => 'category','type' => 'checkbox_list'),array('name'=> __('My Taxonomy Checkboxes','apc'), 'desc' => __('taxonomy checkboxes field description','apc')));
//posts checkbox field
$options_panel->addPosts('posts2_field_id',array('post_type' => 'post','type' => 'checkbox_list'),array('name'=> __('My Posts Checkboxes','apc'), 'class' => 'no-toggle','desc' => __('This field has a <pre>.no-toggle</pre> class which disables the fancy Iphone like toggle','apc')));
//Roles checkbox field
$options_panel->addRoles('roles2_field_id',array('type' => 'checkbox_list' ),array('name'=> __('My Roles Checkboxes','apc'), 'desc' => __('roles checboxes field description','apc')));
/**
* Close 4th tab
*/
$options_panel->CloseTab();
/**
* Open admin page 5th tab
*/
$options_panel->OpenTab('options_5');
//title
$options_panel->Title(__("Advanced Options","apc"));
//sortable field
$options_panel->addSortable('sortable_field_id',array('1' => 'One','2'=> 'Two', '3' => 'three', '4'=> 'four'),array('name' => __('My Sortable Field','apc'), 'desc' => __('Sortable field description','apc')));
/*
* To Create a reapeater Block first create an array of fields
* use the same functions as above but add true as a last param
*/
$repeater_fields[] = $options_panel->addText('re_text_field_id',array('name'=> __('My Text ','apc')),true);
$repeater_fields[] = $options_panel->addTextarea('re_textarea_field_id',array('name'=> __('My Textarea ','apc')),true);
$repeater_fields[] = $options_panel->addImage('image_field_id',array('name'=> __('My Image ','apc')),true);
$repeater_fields[] = $options_panel->addCheckbox('checkbox_field_id',array('name'=> __('My Checkbox ','apc')),true);
/*
* Then just add the fields to the repeater block
*/
//repeater block
$options_panel->addRepeaterBlock('re_',array('sortable' => true, 'inline' => true, 'name' => __('This is a Repeater Block','apc'),'fields' => $repeater_fields, 'desc' => __('Repeater field description','apc')));
/**
* To Create a Conditional Block first create an array of fields (just like a repeater block
* use the same functions as above but add true as a last param
*/
$Conditinal_fields[] = $options_panel->addText('con_text_field_id',array('name'=> __('My Text ','apc')),true);
$Conditinal_fields[] = $options_panel->addTextarea('con_textarea_field_id',array('name'=> __('My Textarea ','apc')),true);
$Conditinal_fields[] = $options_panel->addImage('con_image_field_id',array('name'=> __('My Image ','apc')),true);
$Conditinal_fields[] = $options_panel->addCheckbox('con_checkbox_field_id',array('name'=> __('My Checkbox ','apc')),true);
/**
* Then just add the fields to the repeater block
*/
//conditinal block
$options_panel->addCondition('conditinal_fields',
array(
'name' => __('Enable conditinal fields? ','apc'),
'desc' => __('<small>Turn ON if you want to enable the <strong>conditinal fields</strong>.</small>','apc'),
'fields' => $Conditinal_fields,
'std' => false
));
/**
* Close 5th tab
*/
$options_panel->CloseTab();
/**
* Open admin page 6th tab
* field validation
* `email` => validate email
* `alphanumeric` => validate alphanumeric
* `url` => validate url
* `length` => check for string length
* `maxlength` => check for max string length
* `minlength` => check for min string length
* `maxvalue` => check for max numeric value
* `minvalue` => check for min numeric value
* `numeric` => check for numeric value
*/
$options_panel->OpenTab('options_6');
//email validation
$options_panel->addText('email_text_field_id',
array(
'name' => __('My Email validation ','apc'),
'std' => '[email protected]',
'desc' => __("Field with email validation","apc"),
'validate' => array(
'email' => array('param' => '','message' => __("must be a valid email address","apc"))
)
)
);
//alphanumeric validation
$options_panel->addText('an_text_field_id',
array(
'name' => __('My alpha numeric validation ','apc'),
'std' => 'abcd1234',
'desc' => __("Field with alpa numeric validation, try entring something like #$","apc"),
'validate' => array(
'alphanumeric' => array('param' => '','message' => __("must be a valid alpha numeric chars only","apc"))
)
)
);
// string length exceeds maximum length validation
$options_panel->addText('max_text_field_id',
array(
'name' => __('My Max length of string validation ','apc'),
'std' => 'abcdefghi',
'desc' => __("Field with max string lenght validation,So try entering a longer string","apc"),
'validate' => array(
'maxlength' => array('param' => 10,'message' => __("must be not exceed 10 chars long","apc"))
)
)
);
// string length exceeds maximum length validation
$options_panel->addText('min_text_field_id',
array(
'name' => __('My Min length of string validation ','apc'),
'std' => 'abcdefghi',
'desc' => __("Field with min string lenght validation, So try entering a shorter string","apc"),
'validate' => array(
'minlength' => array('param' => 8,'message' => __("must be a minimum length of 8 chars long","apc"))
)
)
);
// check for exactly length of string validation
$options_panel->addText('exact_text_field_id',
array(
'name' => __('My exactly length of string validation ','apc'),
'std' => 'abcdefghij',
'desc' => __("Field with exact string lenght validation, So try entering a shorter or longer string","apc"),
'validate' => array(
'length' => array('param' => 10,'message' => __("must be exactly 10 chars long","apc"))
)
)
);
//is_numeric
$options_panel->addText('n_text_field_id',
array(
'name' => __('My numeric validation ','apc'),
'std' => 1,
'desc' => __("Field with numeric value validation","apc"),
'validate' => array(
'numeric' => array('param' => '','message' => __("must be numeric value","apc"))
)
)
);
//min numeric value
$options_panel->addText('nmin_text_field_id',
array(
'name' => __('My Min numeric validation ','apc'),
'std' => 9,
'desc' => __("Field with min numeric value validation","apc"),
'validate' => array(
'minvalue' => array('param' => 8,'message' => __("must be numeric with a min value of 8","apc"))
)
)
);
//max numeric value
$options_panel->addText('nmax_text_field_id',
array(
'name' => __('My Max numeric validation ','apc'),
'std' => 9,
'desc' => __("Field with max numeric value validation","apc"),
'validate' => array(
'maxvalue' => array('param' => 10,'message' => __("must be numeric with a Max value of 10","apc"))
)
)
);
//is_url validation
$options_panel->addText('url_text_field_id',
array(
'name' => __('My URL validation ','apc'),
'std' => 'http://en.bainternet.info',
'desc' => __("Field with url value validation","apc"),
'validate' => array(
'url' => array('param' => '','message' => __("must be a valid URL","apc"))
)
)
);
/**
* Close 6th tab
*/
$options_panel->CloseTab();
/**
* Open admin page 7th tab
*/
$options_panel->OpenTab('options_7');
//title
$options_panel->Title(__("Import Export","apc"));
/**
* add import export functionallty
*/
$options_panel->addImportExport();
/**
* Close 7th tab
*/
$options_panel->CloseTab();
$options_panel->CloseTab();
//Now Just for the fun I'll add Help tabs
$options_panel->HelpTab(array(
'id' =>'tab_id',
'title' => __('My help tab title','apc'),
'content' =>'<p>'.__('This is my Help Tab content','apc').'</p>'
));
$options_panel->HelpTab(array(
'id' => 'tab_id2',
'title' => __('My 2nd help tab title','apc'),
'callback' => 'help_tab_callback_demo'
));
//help tab callback function
function help_tab_callback_demo(){
echo '<p>'.__('This is my 2nd Help Tab content from a callback function','apc').'</p>';
}