This repository has been archived by the owner on Aug 27, 2021. It is now read-only.
forked from humanmade/Custom-Meta-Boxes
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcustom-meta-boxes.php
executable file
·160 lines (126 loc) · 4.69 KB
/
custom-meta-boxes.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
<?php
/*
Plugin Name: Custom Meta Boxes
Plugin URI: https://github.com/humanmade/Custom-Meta-Boxes
Description: Lets you easily create metaboxes with custom fields that will blow your mind. Originally a fork of https://github.com/jaredatch/Custom-Metaboxes-and-Fields-for-WordPress.
Version: 1.0.2
License: GPL-2.0+
Author: Human Made Limited
Author URI: http://hmn.md
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License, version 2, as
published by the Free Software Foundation.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
if ( ! defined( 'CMB_DEV') )
define( 'CMB_DEV', false );
if ( ! defined( 'CMB_PATH') )
define( 'CMB_PATH', plugin_dir_path( __FILE__ ) );
if ( ! defined( 'CMB_URL' ) )
define( 'CMB_URL', plugins_url( '', __FILE__ ) );
include_once( CMB_PATH . '/classes.fields.php' );
include_once( CMB_PATH . '/class.cmb-meta-box.php' );
// Make it possible to add fields in locations other than post edit screen.
include_once( CMB_PATH . '/fields-anywhere.php' );
// include_once( CMB_PATH . '/example-functions.php' );
/**
* Get all the meta boxes on init
*
* @return null
*/
function cmb_init() {
if ( ! is_admin() )
return;
// Load translations
$textdomain = 'cmb';
$locale = apply_filters( 'plugin_locale', get_locale(), $textdomain );
// By default, try to load language files from /wp-content/languages/custom-meta-boxes/
load_textdomain( $textdomain, WP_LANG_DIR . '/custom-meta-boxes/' . $textdomain . '-' . $locale . '.mo' );
load_textdomain( $textdomain, CMB_PATH . '/languages/' . $textdomain . '-' . $locale . '.mo' );
$meta_boxes = apply_filters( 'cmb_meta_boxes', array() );
if ( ! empty( $meta_boxes ) )
foreach ( $meta_boxes as $meta_box )
new CMB_Meta_Box( $meta_box );
}
add_action( 'init', 'cmb_init', 50 );
/**
* Return an array of built in available fields
*
* Key is field name, Value is class used by field.
* Available fields can be modified using the 'cmb_field_types' filter.
*
* @return array
*/
function _cmb_available_fields() {
return apply_filters( 'cmb_field_types', array(
'text' => 'CMB_Text_Field',
'text_small' => 'CMB_Text_Small_Field',
'text_url' => 'CMB_URL_Field',
'url' => 'CMB_URL_Field',
'radio' => 'CMB_Radio_Field',
'checkbox' => 'CMB_Checkbox',
'file' => 'CMB_File_Field',
'image' => 'CMB_Image_Field',
'wysiwyg' => 'CMB_wysiwyg',
'textarea' => 'CMB_Textarea_Field',
'textarea_code' => 'CMB_Textarea_Field_Code',
'select' => 'CMB_Select',
'taxonomy_select' => 'CMB_Taxonomy',
'post_select' => 'CMB_Post_Select',
'date' => 'CMB_Date_Field',
'date_unix' => 'CMB_Date_Timestamp_Field',
'datetime_unix' => 'CMB_Datetime_Timestamp_Field',
'time' => 'CMB_Time_Field',
'colorpicker' => 'CMB_Color_Picker',
'title' => 'CMB_Title',
'group' => 'CMB_Group_Field',
'gmap' => 'CMB_Gmap_Field',
'number' => 'CMB_Number_Field'
) );
}
/**
* Get a field class by type
*
* @param string $type
* @return string $class, or false if not found.
*/
function _cmb_field_class_for_type( $type ) {
$map = _cmb_available_fields();
if ( isset( $map[$type] ) )
return $map[$type];
return false;
}
/**
* For the order of repeatable fields to be guaranteed, orderby meta_id needs to be set.
* Note usermeta has a different meta_id column name.
*
* Only do this for older versions as meta is now ordered by ID (since 3.8)
* See http://core.trac.wordpress.org/ticket/25511
*
* @param string $query
* @return string $query
*/
function cmb_fix_meta_query_order($query) {
$pattern = '/^SELECT (post_id|user_id), meta_key, meta_value FROM \w* WHERE post_id IN \([\d|,]*\)$/';
if (
0 === strpos( $query, "SELECT post_id, meta_key, meta_value" ) &&
preg_match( $pattern, $query, $matches )
) {
if ( isset( $matches[1] ) && 'user_id' == $matches[1] )
$meta_id_column = 'umeta_id';
else
$meta_id_column = 'meta_id';
$meta_query_orderby = ' ORDER BY ' . $meta_id_column;
if ( false === strpos( $query, $meta_query_orderby ) )
$query .= $meta_query_orderby;
}
return $query;
}
if ( version_compare( get_bloginfo( 'version' ), '3.8', '<' ) )
add_filter( 'query', 'cmb_fix_meta_query_order', 1 );