@@ -12,401 +12,401 @@ |
||
| 12 | 12 | // Don't duplicate me! |
| 13 | 13 | if ( ! class_exists( 'Redux_Slides', false ) ) { |
| 14 | 14 | |
| 15 | - /** |
|
| 16 | - * Main Redux_slides class |
|
| 17 | - * |
|
| 18 | - * @since 1.0.0 |
|
| 19 | - */ |
|
| 20 | - class Redux_Slides extends Redux_Field { |
|
| 21 | - |
|
| 22 | - /** |
|
| 23 | - * Set field and value defaults. |
|
| 24 | - */ |
|
| 25 | - public function set_defaults() { |
|
| 26 | - $defaults = array( |
|
| 27 | - 'show' => array( |
|
| 28 | - 'title' => true, |
|
| 29 | - 'description' => true, |
|
| 30 | - 'url' => true, |
|
| 31 | - ), |
|
| 32 | - 'content_title' => esc_html__( 'Slide', 'redux-framework' ), |
|
| 33 | - ); |
|
| 34 | - |
|
| 35 | - $this->field = wp_parse_args( $this->field, $defaults ); |
|
| 36 | - } |
|
| 37 | - |
|
| 38 | - /** |
|
| 39 | - * Field Render Function. |
|
| 40 | - * Takes the vars and outputs the HTML for the field in the settings |
|
| 41 | - * |
|
| 42 | - * @since 1.0.0 |
|
| 43 | - * @access public |
|
| 44 | - * @return void |
|
| 45 | - */ |
|
| 46 | - public function render() { |
|
| 47 | - // translators: New accordion title. |
|
| 48 | - echo '<div class="redux-slides-accordion" data-new-content-title="' . esc_attr( sprintf( __( 'New %s', 'redux-framework' ), $this->field['content_title'] ) ) . '">'; |
|
| 49 | - |
|
| 50 | - $x = 0; |
|
| 51 | - |
|
| 52 | - if ( is_array( $this->value ) && ! empty( $this->value ) ) { |
|
| 53 | - $slides = $this->value; |
|
| 54 | - |
|
| 55 | - foreach ( $slides as $slide ) { |
|
| 56 | - if ( empty( $slide ) ) { |
|
| 57 | - continue; |
|
| 58 | - } |
|
| 59 | - |
|
| 60 | - $defaults = array( |
|
| 61 | - 'title' => '', |
|
| 62 | - 'description' => '', |
|
| 63 | - 'sort' => '', |
|
| 64 | - 'url' => '', |
|
| 65 | - 'image' => '', |
|
| 66 | - 'thumb' => '', |
|
| 67 | - 'attachment_id' => '', |
|
| 68 | - 'height' => '', |
|
| 69 | - 'width' => '', |
|
| 70 | - 'select' => array(), |
|
| 71 | - ); |
|
| 72 | - |
|
| 73 | - $slide = wp_parse_args( $slide, $defaults ); |
|
| 74 | - |
|
| 75 | - if ( empty( $slide['thumb'] ) && ! empty( $slide['attachment_id'] ) ) { |
|
| 76 | - $img = wp_get_attachment_image_src( $slide['attachment_id'], 'full' ); |
|
| 77 | - $slide['image'] = $img[0]; |
|
| 78 | - $slide['width'] = $img[1]; |
|
| 79 | - $slide['height'] = $img[2]; |
|
| 80 | - } |
|
| 81 | - |
|
| 82 | - echo '<div class="redux-slides-accordion-group"><fieldset class="redux-field" data-id="' . esc_attr( $this->field['id'] ) . '"><h3><span class="redux-slides-header">' . esc_html( $slide['title'] ) . '</span></h3><div>'; |
|
| 83 | - |
|
| 84 | - $hide = ''; |
|
| 85 | - if ( empty( $slide['image'] ) ) { |
|
| 86 | - $hide = ' hide'; |
|
| 87 | - } |
|
| 88 | - |
|
| 89 | - $alt = wp_prepare_attachment_for_js( $slide['attachment_id'] ); |
|
| 90 | - $alt = $alt['alt'] ?? ''; |
|
| 91 | - |
|
| 92 | - echo '<div class="screenshot' . esc_attr( $hide ) . '">'; |
|
| 93 | - echo '<a class="of-uploaded-image" href="' . esc_url( $slide['image'] ) . '">'; |
|
| 94 | - echo '<img |
|
| 15 | + /** |
|
| 16 | + * Main Redux_slides class |
|
| 17 | + * |
|
| 18 | + * @since 1.0.0 |
|
| 19 | + */ |
|
| 20 | + class Redux_Slides extends Redux_Field { |
|
| 21 | + |
|
| 22 | + /** |
|
| 23 | + * Set field and value defaults. |
|
| 24 | + */ |
|
| 25 | + public function set_defaults() { |
|
| 26 | + $defaults = array( |
|
| 27 | + 'show' => array( |
|
| 28 | + 'title' => true, |
|
| 29 | + 'description' => true, |
|
| 30 | + 'url' => true, |
|
| 31 | + ), |
|
| 32 | + 'content_title' => esc_html__( 'Slide', 'redux-framework' ), |
|
| 33 | + ); |
|
| 34 | + |
|
| 35 | + $this->field = wp_parse_args( $this->field, $defaults ); |
|
| 36 | + } |
|
| 37 | + |
|
| 38 | + /** |
|
| 39 | + * Field Render Function. |
|
| 40 | + * Takes the vars and outputs the HTML for the field in the settings |
|
| 41 | + * |
|
| 42 | + * @since 1.0.0 |
|
| 43 | + * @access public |
|
| 44 | + * @return void |
|
| 45 | + */ |
|
| 46 | + public function render() { |
|
| 47 | + // translators: New accordion title. |
|
| 48 | + echo '<div class="redux-slides-accordion" data-new-content-title="' . esc_attr( sprintf( __( 'New %s', 'redux-framework' ), $this->field['content_title'] ) ) . '">'; |
|
| 49 | + |
|
| 50 | + $x = 0; |
|
| 51 | + |
|
| 52 | + if ( is_array( $this->value ) && ! empty( $this->value ) ) { |
|
| 53 | + $slides = $this->value; |
|
| 54 | + |
|
| 55 | + foreach ( $slides as $slide ) { |
|
| 56 | + if ( empty( $slide ) ) { |
|
| 57 | + continue; |
|
| 58 | + } |
|
| 59 | + |
|
| 60 | + $defaults = array( |
|
| 61 | + 'title' => '', |
|
| 62 | + 'description' => '', |
|
| 63 | + 'sort' => '', |
|
| 64 | + 'url' => '', |
|
| 65 | + 'image' => '', |
|
| 66 | + 'thumb' => '', |
|
| 67 | + 'attachment_id' => '', |
|
| 68 | + 'height' => '', |
|
| 69 | + 'width' => '', |
|
| 70 | + 'select' => array(), |
|
| 71 | + ); |
|
| 72 | + |
|
| 73 | + $slide = wp_parse_args( $slide, $defaults ); |
|
| 74 | + |
|
| 75 | + if ( empty( $slide['thumb'] ) && ! empty( $slide['attachment_id'] ) ) { |
|
| 76 | + $img = wp_get_attachment_image_src( $slide['attachment_id'], 'full' ); |
|
| 77 | + $slide['image'] = $img[0]; |
|
| 78 | + $slide['width'] = $img[1]; |
|
| 79 | + $slide['height'] = $img[2]; |
|
| 80 | + } |
|
| 81 | + |
|
| 82 | + echo '<div class="redux-slides-accordion-group"><fieldset class="redux-field" data-id="' . esc_attr( $this->field['id'] ) . '"><h3><span class="redux-slides-header">' . esc_html( $slide['title'] ) . '</span></h3><div>'; |
|
| 83 | + |
|
| 84 | + $hide = ''; |
|
| 85 | + if ( empty( $slide['image'] ) ) { |
|
| 86 | + $hide = ' hide'; |
|
| 87 | + } |
|
| 88 | + |
|
| 89 | + $alt = wp_prepare_attachment_for_js( $slide['attachment_id'] ); |
|
| 90 | + $alt = $alt['alt'] ?? ''; |
|
| 91 | + |
|
| 92 | + echo '<div class="screenshot' . esc_attr( $hide ) . '">'; |
|
| 93 | + echo '<a class="of-uploaded-image" href="' . esc_url( $slide['image'] ) . '">'; |
|
| 94 | + echo '<img |
|
| 95 | 95 | class="redux-slides-image" |
| 96 | 96 | id="image_image_id_' . esc_attr( $x ) . '" src="' . esc_url( $slide['thumb'] ) . '" |
| 97 | 97 | alt="' . esc_attr( $alt ) . '" |
| 98 | 98 | target="_blank" rel="external" />'; |
| 99 | 99 | |
| 100 | - echo '</a>'; |
|
| 101 | - echo '</div>'; |
|
| 100 | + echo '</a>'; |
|
| 101 | + echo '</div>'; |
|
| 102 | 102 | |
| 103 | - echo '<div class="redux_slides_add_remove">'; |
|
| 103 | + echo '<div class="redux_slides_add_remove">'; |
|
| 104 | 104 | |
| 105 | - echo '<span class="button media_upload_button" id="add_' . esc_attr( $x ) . '">' . esc_html__( 'Upload', 'redux-framework' ) . '</span>'; |
|
| 105 | + echo '<span class="button media_upload_button" id="add_' . esc_attr( $x ) . '">' . esc_html__( 'Upload', 'redux-framework' ) . '</span>'; |
|
| 106 | 106 | |
| 107 | - $hide = ''; |
|
| 108 | - if ( empty( $slide['image'] ) ) { |
|
| 109 | - $hide = ' hide'; |
|
| 110 | - } |
|
| 107 | + $hide = ''; |
|
| 108 | + if ( empty( $slide['image'] ) ) { |
|
| 109 | + $hide = ' hide'; |
|
| 110 | + } |
|
| 111 | 111 | |
| 112 | - echo '<span |
|
| 112 | + echo '<span |
|
| 113 | 113 | class="button remove-image' . esc_attr( $hide ) . '" |
| 114 | 114 | id="reset_' . esc_attr( $x ) . '" |
| 115 | 115 | rel="' . esc_attr( $slide['attachment_id'] ) . '">' . |
| 116 | - esc_html__( 'Remove', 'redux-framework' ) . '</span>'; |
|
| 116 | + esc_html__( 'Remove', 'redux-framework' ) . '</span>'; |
|
| 117 | 117 | |
| 118 | - echo '</div>' . "\n"; |
|
| 118 | + echo '</div>' . "\n"; |
|
| 119 | 119 | |
| 120 | - echo '<ul id="' . esc_attr( $this->field['id'] ) . '-ul" class="redux-slides-list">'; |
|
| 120 | + echo '<ul id="' . esc_attr( $this->field['id'] ) . '-ul" class="redux-slides-list">'; |
|
| 121 | 121 | |
| 122 | - if ( $this->field['show']['title'] ) { |
|
| 123 | - $title_type = 'text'; |
|
| 124 | - } else { |
|
| 125 | - $title_type = 'hidden'; |
|
| 126 | - } |
|
| 122 | + if ( $this->field['show']['title'] ) { |
|
| 123 | + $title_type = 'text'; |
|
| 124 | + } else { |
|
| 125 | + $title_type = 'hidden'; |
|
| 126 | + } |
|
| 127 | 127 | |
| 128 | - $placeholder = ( isset( $this->field['placeholder']['title'] ) ) ? esc_attr( $this->field['placeholder']['title'] ) : __( 'Title', 'redux-framework' ); |
|
| 129 | - echo '<li>'; |
|
| 130 | - echo '<input |
|
| 128 | + $placeholder = ( isset( $this->field['placeholder']['title'] ) ) ? esc_attr( $this->field['placeholder']['title'] ) : __( 'Title', 'redux-framework' ); |
|
| 129 | + echo '<li>'; |
|
| 130 | + echo '<input |
|
| 131 | 131 | type="' . esc_attr( $title_type ) . '" |
| 132 | 132 | id="' . esc_attr( $this->field['id'] ) . '-title_' . esc_attr( $x ) . '" |
| 133 | 133 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][title]' . $this->field['name_suffix'] ) . '" |
| 134 | 134 | value="' . esc_attr( $slide['title'] ) . '" |
| 135 | 135 | placeholder="' . esc_attr( $placeholder ) . '" class="full-text slide-title" />'; |
| 136 | 136 | |
| 137 | - echo '</li>'; |
|
| 137 | + echo '</li>'; |
|
| 138 | 138 | |
| 139 | - if ( $this->field['show']['description'] ) { |
|
| 140 | - $placeholder = ( isset( $this->field['placeholder']['description'] ) ) ? esc_attr( $this->field['placeholder']['description'] ) : __( 'Description', 'redux-framework' ); |
|
| 141 | - echo '<li>'; |
|
| 142 | - echo '<textarea |
|
| 139 | + if ( $this->field['show']['description'] ) { |
|
| 140 | + $placeholder = ( isset( $this->field['placeholder']['description'] ) ) ? esc_attr( $this->field['placeholder']['description'] ) : __( 'Description', 'redux-framework' ); |
|
| 141 | + echo '<li>'; |
|
| 142 | + echo '<textarea |
|
| 143 | 143 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][description]' . $this->field['name_suffix'] ) . '" |
| 144 | 144 | id="' . esc_attr( $this->field['id'] ) . '-description_' . esc_attr( $x ) . '" |
| 145 | 145 | placeholder="' . esc_attr( $placeholder ) . '" |
| 146 | 146 | class="large-text" |
| 147 | 147 | rows="6">' . esc_textarea( $slide['description'] ) . '</textarea>'; |
| 148 | 148 | |
| 149 | - echo '</li>'; |
|
| 150 | - } |
|
| 149 | + echo '</li>'; |
|
| 150 | + } |
|
| 151 | 151 | |
| 152 | - $placeholder = ( isset( $this->field['placeholder']['url'] ) ) ? esc_attr( $this->field['placeholder']['url'] ) : __( 'URL', 'redux-framework' ); |
|
| 153 | - if ( $this->field['show']['url'] ) { |
|
| 154 | - $url_type = 'text'; |
|
| 155 | - } else { |
|
| 156 | - $url_type = 'hidden'; |
|
| 157 | - } |
|
| 152 | + $placeholder = ( isset( $this->field['placeholder']['url'] ) ) ? esc_attr( $this->field['placeholder']['url'] ) : __( 'URL', 'redux-framework' ); |
|
| 153 | + if ( $this->field['show']['url'] ) { |
|
| 154 | + $url_type = 'text'; |
|
| 155 | + } else { |
|
| 156 | + $url_type = 'hidden'; |
|
| 157 | + } |
|
| 158 | 158 | |
| 159 | - echo '<li>'; |
|
| 160 | - echo '<input |
|
| 159 | + echo '<li>'; |
|
| 160 | + echo '<input |
|
| 161 | 161 | type="' . esc_attr( $url_type ) . '" |
| 162 | 162 | id="' . esc_attr( $this->field['id'] . '-url_' ) . esc_attr( $x ) . '" |
| 163 | 163 | name="' . esc_attr( $this->field['name'] . '[' . esc_attr( $x ) . '][url]' . $this->field['name_suffix'] ) . '" |
| 164 | 164 | value="' . esc_attr( $slide['url'] ) . '" |
| 165 | 165 | class="full-text" placeholder="' . esc_attr( $placeholder ) . '" />'; |
| 166 | - echo '</li>'; |
|
| 166 | + echo '</li>'; |
|
| 167 | 167 | |
| 168 | - echo '<li>'; |
|
| 169 | - echo '<input |
|
| 168 | + echo '<li>'; |
|
| 169 | + echo '<input |
|
| 170 | 170 | type="hidden" |
| 171 | 171 | class="slide-sort" |
| 172 | 172 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][sort]' . $this->field['name_suffix'] ) . '" |
| 173 | 173 | id="' . esc_attr( $this->field['id'] ) . '-sort_' . esc_attr( $x ) . '" |
| 174 | 174 | value="' . esc_attr( $slide['sort'] ) . '" />'; |
| 175 | 175 | |
| 176 | - echo '<li>'; |
|
| 177 | - echo '<input |
|
| 176 | + echo '<li>'; |
|
| 177 | + echo '<input |
|
| 178 | 178 | type="hidden" |
| 179 | 179 | class="upload-id" |
| 180 | 180 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][attachment_id]' . $this->field['name_suffix'] ) . '" |
| 181 | 181 | id="' . esc_attr( $this->field['id'] ) . '-image_id_' . esc_attr( $x ) . '" |
| 182 | 182 | value="' . esc_attr( $slide['attachment_id'] ) . '" />'; |
| 183 | 183 | |
| 184 | - echo '<input |
|
| 184 | + echo '<input |
|
| 185 | 185 | type="hidden" |
| 186 | 186 | class="upload" name="' . esc_attr( $this->field['name'] . '[' . $x . '][image]' . $this->field['name_suffix'] ) . '" |
| 187 | 187 | id="' . esc_attr( $this->field['id'] ) . '-image_url_' . esc_attr( $x ) . '" |
| 188 | 188 | value="' . esc_attr( $slide['image'] ) . '" readonly="readonly" />'; |
| 189 | 189 | |
| 190 | - echo '<input |
|
| 190 | + echo '<input |
|
| 191 | 191 | type="hidden" |
| 192 | 192 | class="upload-height" |
| 193 | 193 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][height]' . $this->field['name_suffix'] ) . '" |
| 194 | 194 | id="' . esc_attr( $this->field['id'] ) . '-image_height_' . esc_attr( $x ) . '" |
| 195 | 195 | value="' . esc_attr( $slide['height'] ) . '" />'; |
| 196 | 196 | |
| 197 | - echo '<input |
|
| 197 | + echo '<input |
|
| 198 | 198 | type="hidden" |
| 199 | 199 | class="upload-width" |
| 200 | 200 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][width]' . $this->field['name_suffix'] ) . '" |
| 201 | 201 | id="' . esc_attr( $this->field['id'] ) . '-image_width_' . esc_attr( $x ) . '" |
| 202 | 202 | value="' . esc_attr( $slide['width'] ) . '" />'; |
| 203 | 203 | |
| 204 | - echo '</li>'; |
|
| 204 | + echo '</li>'; |
|
| 205 | 205 | |
| 206 | - echo '<input |
|
| 206 | + echo '<input |
|
| 207 | 207 | type="hidden" |
| 208 | 208 | class="upload-thumbnail" |
| 209 | 209 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][thumb]' . $this->field['name_suffix'] ) . '" |
| 210 | 210 | id="' . esc_attr( $this->field['id'] ) . '-thumb_url_' . esc_attr( $x ) . '" |
| 211 | 211 | value="' . esc_attr( $slide['thumb'] ) . '" readonly="readonly" />'; |
| 212 | - echo '</li>'; |
|
| 212 | + echo '</li>'; |
|
| 213 | 213 | |
| 214 | - echo '<li>'; |
|
| 215 | - echo '<a href="javascript:void(0);" class="button deletion redux-slides-remove">' . esc_html__( 'Delete', 'redux-framework' ) . '</a>'; |
|
| 216 | - echo '</li>'; |
|
| 214 | + echo '<li>'; |
|
| 215 | + echo '<a href="javascript:void(0);" class="button deletion redux-slides-remove">' . esc_html__( 'Delete', 'redux-framework' ) . '</a>'; |
|
| 216 | + echo '</li>'; |
|
| 217 | 217 | |
| 218 | - echo '</ul>'; |
|
| 219 | - echo '</div>'; |
|
| 220 | - echo '</fieldset>'; |
|
| 221 | - echo '</div>'; |
|
| 218 | + echo '</ul>'; |
|
| 219 | + echo '</div>'; |
|
| 220 | + echo '</fieldset>'; |
|
| 221 | + echo '</div>'; |
|
| 222 | 222 | |
| 223 | - ++$x; |
|
| 224 | - } |
|
| 225 | - } |
|
| 223 | + ++$x; |
|
| 224 | + } |
|
| 225 | + } |
|
| 226 | 226 | |
| 227 | - if ( 0 === $x ) { |
|
| 228 | - echo '<div class="redux-slides-accordion-group">'; |
|
| 229 | - echo '<fieldset class="redux-field" data-id="' . esc_attr( $this->field['id'] ) . '">'; |
|
| 230 | - echo '<h3>'; |
|
| 227 | + if ( 0 === $x ) { |
|
| 228 | + echo '<div class="redux-slides-accordion-group">'; |
|
| 229 | + echo '<fieldset class="redux-field" data-id="' . esc_attr( $this->field['id'] ) . '">'; |
|
| 230 | + echo '<h3>'; |
|
| 231 | 231 | |
| 232 | - // translators: Content title for new accordion. |
|
| 233 | - echo '<span class="redux-slides-header">' . esc_html( sprintf( __( 'New %s', 'redux-framework' ), esc_attr( $this->field['content_title'] ) ) ) . '</span>'; |
|
| 234 | - echo '</h3>'; |
|
| 235 | - echo '<div>'; |
|
| 232 | + // translators: Content title for new accordion. |
|
| 233 | + echo '<span class="redux-slides-header">' . esc_html( sprintf( __( 'New %s', 'redux-framework' ), esc_attr( $this->field['content_title'] ) ) ) . '</span>'; |
|
| 234 | + echo '</h3>'; |
|
| 235 | + echo '<div>'; |
|
| 236 | 236 | |
| 237 | - $hide = ' hide'; |
|
| 237 | + $hide = ' hide'; |
|
| 238 | 238 | |
| 239 | - echo '<div class="screenshot' . esc_attr( $hide ) . '">'; |
|
| 240 | - echo '<a class="of-uploaded-image" href="">'; |
|
| 241 | - echo '<img class="redux-slides-image" id="image_image_id_' . esc_attr( $x ) . '" src="" alt="placeholder" target="_blank" rel="external" />'; |
|
| 242 | - echo '</a>'; |
|
| 243 | - echo '</div>'; |
|
| 239 | + echo '<div class="screenshot' . esc_attr( $hide ) . '">'; |
|
| 240 | + echo '<a class="of-uploaded-image" href="">'; |
|
| 241 | + echo '<img class="redux-slides-image" id="image_image_id_' . esc_attr( $x ) . '" src="" alt="placeholder" target="_blank" rel="external" />'; |
|
| 242 | + echo '</a>'; |
|
| 243 | + echo '</div>'; |
|
| 244 | 244 | |
| 245 | - // Upload controls DIV. |
|
| 246 | - echo '<div class="upload_button_div">'; |
|
| 245 | + // Upload controls DIV. |
|
| 246 | + echo '<div class="upload_button_div">'; |
|
| 247 | 247 | |
| 248 | - // If the user has WP3.5+ show upload/remove button. |
|
| 249 | - echo '<span class="button media_upload_button" id="add_' . esc_attr( $x ) . '">' . esc_html__( 'Upload', 'redux-framework' ) . '</span>'; |
|
| 248 | + // If the user has WP3.5+ show upload/remove button. |
|
| 249 | + echo '<span class="button media_upload_button" id="add_' . esc_attr( $x ) . '">' . esc_html__( 'Upload', 'redux-framework' ) . '</span>'; |
|
| 250 | 250 | |
| 251 | - echo '<span class="button remove-image' . esc_attr( $hide ) . '" id="reset_' . esc_attr( $x ) . '" rel="' . esc_attr( $this->parent->args['opt_name'] . '[' . $this->field['id'] ) . '][attachment_id]">' . esc_html__( 'Remove', 'redux-framework' ) . '</span>'; |
|
| 251 | + echo '<span class="button remove-image' . esc_attr( $hide ) . '" id="reset_' . esc_attr( $x ) . '" rel="' . esc_attr( $this->parent->args['opt_name'] . '[' . $this->field['id'] ) . '][attachment_id]">' . esc_html__( 'Remove', 'redux-framework' ) . '</span>'; |
|
| 252 | 252 | |
| 253 | - echo '</div>' . "\n"; |
|
| 253 | + echo '</div>' . "\n"; |
|
| 254 | 254 | |
| 255 | - echo '<ul id="' . esc_attr( $this->field['id'] ) . '-ul" class="redux-slides-list">'; |
|
| 255 | + echo '<ul id="' . esc_attr( $this->field['id'] ) . '-ul" class="redux-slides-list">'; |
|
| 256 | 256 | |
| 257 | - if ( $this->field['show']['title'] ) { |
|
| 258 | - $title_type = 'text'; |
|
| 259 | - } else { |
|
| 260 | - $title_type = 'hidden'; |
|
| 261 | - } |
|
| 257 | + if ( $this->field['show']['title'] ) { |
|
| 258 | + $title_type = 'text'; |
|
| 259 | + } else { |
|
| 260 | + $title_type = 'hidden'; |
|
| 261 | + } |
|
| 262 | 262 | |
| 263 | - $placeholder = ( isset( $this->field['placeholder']['title'] ) ) ? esc_attr( $this->field['placeholder']['title'] ) : __( 'Title', 'redux-framework' ); |
|
| 263 | + $placeholder = ( isset( $this->field['placeholder']['title'] ) ) ? esc_attr( $this->field['placeholder']['title'] ) : __( 'Title', 'redux-framework' ); |
|
| 264 | 264 | |
| 265 | - echo '<li>'; |
|
| 266 | - echo '<input |
|
| 265 | + echo '<li>'; |
|
| 266 | + echo '<input |
|
| 267 | 267 | type="' . esc_attr( $title_type ) . '" |
| 268 | 268 | id="' . esc_attr( $this->field['id'] . '-title_' . $x ) . '" |
| 269 | 269 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][title]' . $this->field['name_suffix'] ) . '" |
| 270 | 270 | value="" |
| 271 | 271 | placeholder="' . esc_attr( $placeholder ) . '" |
| 272 | 272 | class="full-text slide-title" />'; |
| 273 | - echo '</li>'; |
|
| 273 | + echo '</li>'; |
|
| 274 | 274 | |
| 275 | - if ( $this->field['show']['description'] ) { |
|
| 276 | - $placeholder = ( isset( $this->field['placeholder']['description'] ) ) ? esc_attr( $this->field['placeholder']['description'] ) : __( 'Description', 'redux-framework' ); |
|
| 275 | + if ( $this->field['show']['description'] ) { |
|
| 276 | + $placeholder = ( isset( $this->field['placeholder']['description'] ) ) ? esc_attr( $this->field['placeholder']['description'] ) : __( 'Description', 'redux-framework' ); |
|
| 277 | 277 | |
| 278 | - echo '<li>'; |
|
| 279 | - echo '<textarea |
|
| 278 | + echo '<li>'; |
|
| 279 | + echo '<textarea |
|
| 280 | 280 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][description]' . $this->field['name_suffix'] ) . '" |
| 281 | 281 | id="' . esc_attr( $this->field['id'] . '-description_' . $x ) . '" |
| 282 | 282 | placeholder="' . esc_attr( $placeholder ) . '" |
| 283 | 283 | class="large-text" |
| 284 | 284 | rows="6"></textarea>'; |
| 285 | - echo '</li>'; |
|
| 286 | - } |
|
| 285 | + echo '</li>'; |
|
| 286 | + } |
|
| 287 | 287 | |
| 288 | - $placeholder = ( isset( $this->field['placeholder']['url'] ) ) ? esc_attr( $this->field['placeholder']['url'] ) : __( 'URL', 'redux-framework' ); |
|
| 288 | + $placeholder = ( isset( $this->field['placeholder']['url'] ) ) ? esc_attr( $this->field['placeholder']['url'] ) : __( 'URL', 'redux-framework' ); |
|
| 289 | 289 | |
| 290 | - if ( $this->field['show']['url'] ) { |
|
| 291 | - $url_type = 'text'; |
|
| 292 | - } else { |
|
| 293 | - $url_type = 'hidden'; |
|
| 294 | - } |
|
| 290 | + if ( $this->field['show']['url'] ) { |
|
| 291 | + $url_type = 'text'; |
|
| 292 | + } else { |
|
| 293 | + $url_type = 'hidden'; |
|
| 294 | + } |
|
| 295 | 295 | |
| 296 | - echo '<li>'; |
|
| 297 | - echo '<input |
|
| 296 | + echo '<li>'; |
|
| 297 | + echo '<input |
|
| 298 | 298 | type="' . esc_attr( $url_type ) . '" |
| 299 | 299 | id="' . esc_attr( $this->field['id'] . '-url_' . $x ) . '" |
| 300 | 300 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][url]' . $this->field['name_suffix'] ) . '" |
| 301 | 301 | value="" class="full-text" placeholder="' . esc_attr( $placeholder ) . '" />'; |
| 302 | - echo '</li>'; |
|
| 302 | + echo '</li>'; |
|
| 303 | 303 | |
| 304 | - echo '<li>'; |
|
| 305 | - echo '<input |
|
| 304 | + echo '<li>'; |
|
| 305 | + echo '<input |
|
| 306 | 306 | type="hidden" |
| 307 | 307 | class="slide-sort" |
| 308 | 308 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][sort]' . $this->field['name_suffix'] ) . '" |
| 309 | 309 | id="' . esc_attr( $this->field['id'] . '-sort_' . $x ) . '" |
| 310 | 310 | value="' . esc_attr( $x ) . '" />'; |
| 311 | 311 | |
| 312 | - echo '<li>'; |
|
| 313 | - echo '<input |
|
| 312 | + echo '<li>'; |
|
| 313 | + echo '<input |
|
| 314 | 314 | type="hidden" |
| 315 | 315 | class="upload-id" |
| 316 | 316 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][attachment_id]' . $this->field['name_suffix'] ) . '" |
| 317 | 317 | id="' . esc_attr( $this->field['id'] . '-image_id_' . $x ) . '" |
| 318 | 318 | value="" />'; |
| 319 | 319 | |
| 320 | - echo '<input |
|
| 320 | + echo '<input |
|
| 321 | 321 | type="hidden" |
| 322 | 322 | class="upload" |
| 323 | 323 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][image]' . $this->field['name_suffix'] ) . '" |
| 324 | 324 | id="' . esc_attr( $this->field['id'] . '-image_url_' . $x ) . '" |
| 325 | 325 | value="" readonly="readonly" />'; |
| 326 | 326 | |
| 327 | - echo '<input |
|
| 327 | + echo '<input |
|
| 328 | 328 | type="hidden" |
| 329 | 329 | class="upload-height" |
| 330 | 330 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][height]' . $this->field['name_suffix'] ) . '" |
| 331 | 331 | id="' . esc_attr( $this->field['id'] . '-image_height_' . $x ) . '" |
| 332 | 332 | value="" />'; |
| 333 | 333 | |
| 334 | - echo '<input |
|
| 334 | + echo '<input |
|
| 335 | 335 | type="hidden" |
| 336 | 336 | class="upload-width" |
| 337 | 337 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][width]' . $this->field['name_suffix'] ) . '" |
| 338 | 338 | id="' . esc_attr( $this->field['id'] . '-image_width_' . $x ) . '" |
| 339 | 339 | value="" />'; |
| 340 | - echo '</li>'; |
|
| 340 | + echo '</li>'; |
|
| 341 | 341 | |
| 342 | - echo '<input |
|
| 342 | + echo '<input |
|
| 343 | 343 | type="hidden" |
| 344 | 344 | class="upload-thumbnail" |
| 345 | 345 | name="' . esc_attr( $this->field['name'] . '[' . $x . '][thumb]' . $this->field['name_suffix'] ) . '" |
| 346 | 346 | id="' . esc_attr( $this->field['id'] . '-thumb_url_' . $x ) . '" |
| 347 | 347 | value="" />'; |
| 348 | - echo '</li>'; |
|
| 349 | - |
|
| 350 | - echo '<li>'; |
|
| 351 | - echo '<a href="javascript:void(0);" class="button deletion redux-slides-remove">' . esc_html__( 'Delete', 'redux-framework' ) . '</a>'; |
|
| 352 | - echo '</li>'; |
|
| 353 | - |
|
| 354 | - echo '</ul>'; |
|
| 355 | - echo '</div>'; |
|
| 356 | - echo '</fieldset>'; |
|
| 357 | - echo '</div>'; |
|
| 358 | - } |
|
| 359 | - |
|
| 360 | - echo '</div>'; |
|
| 361 | - |
|
| 362 | - // translators: Content title for accordion. |
|
| 363 | - echo '<a href="javascript:void(0);" class="button redux-slides-add button-primary" rel-id="' . esc_attr( $this->field['id'] ) . '-ul" rel-name="' . esc_attr( $this->field['name'] . '[title][]' . $this->field['name_suffix'] ) . '">' . esc_html( sprintf( __( 'Add %s', 'redux-framework' ), esc_html( $this->field['content_title'] ) ) ) . '</a>'; |
|
| 364 | - echo '<br/>'; |
|
| 365 | - } |
|
| 366 | - |
|
| 367 | - /** |
|
| 368 | - * Enqueue Function. |
|
| 369 | - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 370 | - * |
|
| 371 | - * @since 1.0.0 |
|
| 372 | - * @access public |
|
| 373 | - * @return void |
|
| 374 | - */ |
|
| 375 | - public function enqueue() { |
|
| 376 | - if ( function_exists( 'wp_enqueue_media' ) ) { |
|
| 377 | - wp_enqueue_media(); |
|
| 378 | - } else { |
|
| 379 | - wp_enqueue_script( 'media-upload' ); |
|
| 380 | - } |
|
| 381 | - |
|
| 382 | - if ( $this->parent->args['dev_mode'] ) { |
|
| 383 | - wp_enqueue_style( 'redux-field-media' ); |
|
| 384 | - |
|
| 385 | - wp_enqueue_style( |
|
| 386 | - 'redux-field-slides', |
|
| 387 | - Redux_Core::$url . 'inc/fields/slides/redux-slides.css', |
|
| 388 | - array(), |
|
| 389 | - $this->timestamp |
|
| 390 | - ); |
|
| 391 | - } |
|
| 392 | - |
|
| 393 | - wp_enqueue_script( |
|
| 394 | - 'redux-field-media', |
|
| 395 | - Redux_Core::$url . 'assets/js/media/media' . Redux_Functions::is_min() . '.js', |
|
| 396 | - array( 'jquery', 'redux-js' ), |
|
| 397 | - $this->timestamp, |
|
| 398 | - true |
|
| 399 | - ); |
|
| 400 | - |
|
| 401 | - wp_enqueue_script( |
|
| 402 | - 'redux-field-slides', |
|
| 403 | - Redux_Core::$url . 'inc/fields/slides/redux-slides' . Redux_Functions::is_min() . '.js', |
|
| 404 | - array( 'jquery', 'jquery-ui-core', 'jquery-ui-accordion', 'jquery-ui-sortable', 'redux-field-media' ), |
|
| 405 | - $this->timestamp, |
|
| 406 | - true |
|
| 407 | - ); |
|
| 408 | - } |
|
| 409 | - } |
|
| 348 | + echo '</li>'; |
|
| 349 | + |
|
| 350 | + echo '<li>'; |
|
| 351 | + echo '<a href="javascript:void(0);" class="button deletion redux-slides-remove">' . esc_html__( 'Delete', 'redux-framework' ) . '</a>'; |
|
| 352 | + echo '</li>'; |
|
| 353 | + |
|
| 354 | + echo '</ul>'; |
|
| 355 | + echo '</div>'; |
|
| 356 | + echo '</fieldset>'; |
|
| 357 | + echo '</div>'; |
|
| 358 | + } |
|
| 359 | + |
|
| 360 | + echo '</div>'; |
|
| 361 | + |
|
| 362 | + // translators: Content title for accordion. |
|
| 363 | + echo '<a href="javascript:void(0);" class="button redux-slides-add button-primary" rel-id="' . esc_attr( $this->field['id'] ) . '-ul" rel-name="' . esc_attr( $this->field['name'] . '[title][]' . $this->field['name_suffix'] ) . '">' . esc_html( sprintf( __( 'Add %s', 'redux-framework' ), esc_html( $this->field['content_title'] ) ) ) . '</a>'; |
|
| 364 | + echo '<br/>'; |
|
| 365 | + } |
|
| 366 | + |
|
| 367 | + /** |
|
| 368 | + * Enqueue Function. |
|
| 369 | + * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 370 | + * |
|
| 371 | + * @since 1.0.0 |
|
| 372 | + * @access public |
|
| 373 | + * @return void |
|
| 374 | + */ |
|
| 375 | + public function enqueue() { |
|
| 376 | + if ( function_exists( 'wp_enqueue_media' ) ) { |
|
| 377 | + wp_enqueue_media(); |
|
| 378 | + } else { |
|
| 379 | + wp_enqueue_script( 'media-upload' ); |
|
| 380 | + } |
|
| 381 | + |
|
| 382 | + if ( $this->parent->args['dev_mode'] ) { |
|
| 383 | + wp_enqueue_style( 'redux-field-media' ); |
|
| 384 | + |
|
| 385 | + wp_enqueue_style( |
|
| 386 | + 'redux-field-slides', |
|
| 387 | + Redux_Core::$url . 'inc/fields/slides/redux-slides.css', |
|
| 388 | + array(), |
|
| 389 | + $this->timestamp |
|
| 390 | + ); |
|
| 391 | + } |
|
| 392 | + |
|
| 393 | + wp_enqueue_script( |
|
| 394 | + 'redux-field-media', |
|
| 395 | + Redux_Core::$url . 'assets/js/media/media' . Redux_Functions::is_min() . '.js', |
|
| 396 | + array( 'jquery', 'redux-js' ), |
|
| 397 | + $this->timestamp, |
|
| 398 | + true |
|
| 399 | + ); |
|
| 400 | + |
|
| 401 | + wp_enqueue_script( |
|
| 402 | + 'redux-field-slides', |
|
| 403 | + Redux_Core::$url . 'inc/fields/slides/redux-slides' . Redux_Functions::is_min() . '.js', |
|
| 404 | + array( 'jquery', 'jquery-ui-core', 'jquery-ui-accordion', 'jquery-ui-sortable', 'redux-field-media' ), |
|
| 405 | + $this->timestamp, |
|
| 406 | + true |
|
| 407 | + ); |
|
| 408 | + } |
|
| 409 | + } |
|
| 410 | 410 | } |
| 411 | 411 | |
| 412 | 412 | class_alias( 'Redux_Slides', 'ReduxFramework_Slides' ); |
@@ -71,7 +71,7 @@ |
||
| 71 | 71 | data-placeholder="' . esc_attr( $placeholder ) . '" |
| 72 | 72 | name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '" |
| 73 | 73 | class="redux-select-item redux-select-images ' . esc_attr( $this->field['class'] ) . '"' . |
| 74 | - $width . ' rows="6"' . esc_attr( $select2_data ) . '>'; // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 74 | + $width . ' rows="6"' . esc_attr( $select2_data ) . '>'; // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 75 | 75 | |
| 76 | 76 | echo '<option></option>'; |
| 77 | 77 | |
@@ -12,169 +12,169 @@ |
||
| 12 | 12 | |
| 13 | 13 | if ( ! class_exists( 'Redux_Select_Image', false ) ) { |
| 14 | 14 | |
| 15 | - /** |
|
| 16 | - * Class Redux_Select_Image |
|
| 17 | - */ |
|
| 18 | - class Redux_Select_Image extends Redux_Field { |
|
| 19 | - |
|
| 20 | - /** |
|
| 21 | - * Set field defaults. |
|
| 22 | - */ |
|
| 23 | - public function set_defaults() { |
|
| 24 | - $defaults = array( |
|
| 25 | - 'options' => array(), |
|
| 26 | - 'placeholder' => esc_html__( 'Select an item', 'redux-framework' ), |
|
| 27 | - ); |
|
| 28 | - |
|
| 29 | - $this->field = wp_parse_args( $this->field, $defaults ); |
|
| 30 | - } |
|
| 31 | - |
|
| 32 | - /** |
|
| 33 | - * Field Render Function. |
|
| 34 | - * Takes the vars and outputs the HTML for the field in the settings |
|
| 35 | - * |
|
| 36 | - * @since ReduxFramework 1.0.0 |
|
| 37 | - */ |
|
| 38 | - public function render() { |
|
| 39 | - |
|
| 40 | - // If options is NOT empty, the process. |
|
| 41 | - if ( ! empty( $this->field['options'] ) ) { |
|
| 42 | - |
|
| 43 | - // bean counter. |
|
| 44 | - $x = 1; |
|
| 45 | - |
|
| 46 | - // Process width. |
|
| 47 | - if ( ! empty( $this->field['width'] ) ) { |
|
| 48 | - $width = ' style="width:' . esc_attr( $this->field['width'] ) . ';"'; |
|
| 49 | - } else { |
|
| 50 | - $width = ' style="width: 40%;"'; |
|
| 51 | - } |
|
| 52 | - |
|
| 53 | - // Process placeholder. |
|
| 54 | - $placeholder = esc_attr( $this->field['placeholder'] ); |
|
| 55 | - |
|
| 56 | - $this->select2_config['allowClear'] = true; |
|
| 57 | - |
|
| 58 | - if ( isset( $this->field['select2'] ) ) { |
|
| 59 | - $this->field['select2'] = wp_parse_args( $this->field['select2'], $this->select2_config ); |
|
| 60 | - } else { |
|
| 61 | - $this->field['select2'] = $this->select2_config; |
|
| 62 | - } |
|
| 63 | - |
|
| 64 | - $this->field['select2'] = Redux_Functions::sanitize_camel_case_array_keys( $this->field['select2'] ); |
|
| 65 | - |
|
| 66 | - $select2_data = Redux_Functions::create_data_string( $this->field['select2'] ); |
|
| 67 | - |
|
| 68 | - // Begin the <select> tag. |
|
| 69 | - echo '<select |
|
| 15 | + /** |
|
| 16 | + * Class Redux_Select_Image |
|
| 17 | + */ |
|
| 18 | + class Redux_Select_Image extends Redux_Field { |
|
| 19 | + |
|
| 20 | + /** |
|
| 21 | + * Set field defaults. |
|
| 22 | + */ |
|
| 23 | + public function set_defaults() { |
|
| 24 | + $defaults = array( |
|
| 25 | + 'options' => array(), |
|
| 26 | + 'placeholder' => esc_html__( 'Select an item', 'redux-framework' ), |
|
| 27 | + ); |
|
| 28 | + |
|
| 29 | + $this->field = wp_parse_args( $this->field, $defaults ); |
|
| 30 | + } |
|
| 31 | + |
|
| 32 | + /** |
|
| 33 | + * Field Render Function. |
|
| 34 | + * Takes the vars and outputs the HTML for the field in the settings |
|
| 35 | + * |
|
| 36 | + * @since ReduxFramework 1.0.0 |
|
| 37 | + */ |
|
| 38 | + public function render() { |
|
| 39 | + |
|
| 40 | + // If options is NOT empty, the process. |
|
| 41 | + if ( ! empty( $this->field['options'] ) ) { |
|
| 42 | + |
|
| 43 | + // bean counter. |
|
| 44 | + $x = 1; |
|
| 45 | + |
|
| 46 | + // Process width. |
|
| 47 | + if ( ! empty( $this->field['width'] ) ) { |
|
| 48 | + $width = ' style="width:' . esc_attr( $this->field['width'] ) . ';"'; |
|
| 49 | + } else { |
|
| 50 | + $width = ' style="width: 40%;"'; |
|
| 51 | + } |
|
| 52 | + |
|
| 53 | + // Process placeholder. |
|
| 54 | + $placeholder = esc_attr( $this->field['placeholder'] ); |
|
| 55 | + |
|
| 56 | + $this->select2_config['allowClear'] = true; |
|
| 57 | + |
|
| 58 | + if ( isset( $this->field['select2'] ) ) { |
|
| 59 | + $this->field['select2'] = wp_parse_args( $this->field['select2'], $this->select2_config ); |
|
| 60 | + } else { |
|
| 61 | + $this->field['select2'] = $this->select2_config; |
|
| 62 | + } |
|
| 63 | + |
|
| 64 | + $this->field['select2'] = Redux_Functions::sanitize_camel_case_array_keys( $this->field['select2'] ); |
|
| 65 | + |
|
| 66 | + $select2_data = Redux_Functions::create_data_string( $this->field['select2'] ); |
|
| 67 | + |
|
| 68 | + // Begin the <select> tag. |
|
| 69 | + echo '<select |
|
| 70 | 70 | data-id="' . esc_attr( $this->field['id'] ) . '" |
| 71 | 71 | data-placeholder="' . esc_attr( $placeholder ) . '" |
| 72 | 72 | name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '" |
| 73 | 73 | class="redux-select-item redux-select-images ' . esc_attr( $this->field['class'] ) . '"' . |
| 74 | - $width . ' rows="6"' . esc_attr( $select2_data ) . '>'; // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 75 | - |
|
| 76 | - echo '<option></option>'; |
|
| 77 | - |
|
| 78 | - // Enum through the options array. |
|
| 79 | - foreach ( $this->field['options'] as $v ) { |
|
| 80 | - |
|
| 81 | - // No array? No problem! |
|
| 82 | - if ( ! is_array( $v ) ) { |
|
| 83 | - $v = array( 'img' => $v ); |
|
| 84 | - } |
|
| 85 | - |
|
| 86 | - // No title set? Make it blank. |
|
| 87 | - if ( ! isset( $v['title'] ) ) { |
|
| 88 | - $v['title'] = ''; |
|
| 89 | - } |
|
| 90 | - |
|
| 91 | - // No alt? Set it to title. We do this so the alt tag shows |
|
| 92 | - // something. It also makes HTML/SEO purists happy. |
|
| 93 | - if ( ! isset( $v['alt'] ) ) { |
|
| 94 | - $v['alt'] = $v['title']; |
|
| 95 | - } |
|
| 96 | - |
|
| 97 | - // Set the selected entry. |
|
| 98 | - $selected = selected( $this->value, $v['img'], false ); |
|
| 99 | - |
|
| 100 | - // If selected returns something other than a blank space, we |
|
| 101 | - // found our default/saved name. Save the array number in a |
|
| 102 | - // variable to use later on when we want to extract its associated |
|
| 103 | - // url. |
|
| 104 | - if ( '' !== $selected ) { |
|
| 105 | - $arr_num = $x; |
|
| 106 | - } |
|
| 107 | - |
|
| 108 | - // Add the option tag, with values. |
|
| 109 | - echo '<option value="' . esc_url( $v['img'] ) . '" ' . esc_html( $selected ) . '>' . esc_attr( $v['alt'] ) . '</option>'; |
|
| 110 | - |
|
| 111 | - // Add a bean. |
|
| 112 | - ++$x; |
|
| 113 | - } |
|
| 114 | - |
|
| 115 | - // Close the <select> tag. |
|
| 116 | - echo '</select>'; |
|
| 117 | - |
|
| 118 | - // Some space. |
|
| 119 | - echo '<br /><br />'; |
|
| 120 | - |
|
| 121 | - // Show the preview image. |
|
| 122 | - echo '<div>'; |
|
| 123 | - |
|
| 124 | - // just in case. You never know. |
|
| 125 | - if ( ! isset( $arr_num ) ) { |
|
| 126 | - $this->value = ''; |
|
| 127 | - } |
|
| 128 | - |
|
| 129 | - // Set the default image. To get the url from the default name, |
|
| 130 | - // we save the array count from the for/each loop, when the default image |
|
| 131 | - // is mark as selected. Since the for/each loop starts at one, we must |
|
| 132 | - // subtract one from the saved array number. We then pull the url |
|
| 133 | - // out of the options array, and there we go. |
|
| 134 | - if ( '' === $this->value ) { |
|
| 135 | - // phpcs:ignore PluginCheck.CodeAnalysis.ImageFunctions.NonEnqueuedImage -- No image/icon to enqueue. |
|
| 136 | - echo '<img src="#" class="redux-preview-image" style="visibility:hidden;" id="image_' . esc_attr( $this->field['id'] ) . '">'; |
|
| 137 | - } else { |
|
| 138 | - // phpcs:ignore PluginCheck.CodeAnalysis.ImageFunctions.NonEnqueuedImage -- No image/icon to enqueue. |
|
| 139 | - echo '<img src=' . esc_url( $this->value ) . ' class="redux-preview-image" id="image_' . esc_attr( $this->field['id'] ) . '">'; |
|
| 140 | - } |
|
| 141 | - |
|
| 142 | - // Close the <div> tag. |
|
| 143 | - echo '</div>'; |
|
| 144 | - } else { |
|
| 145 | - |
|
| 146 | - // No options specified. Really? |
|
| 147 | - echo '<strong>' . esc_html__( 'No items of this type were found.', 'redux-framework' ) . '</strong>'; |
|
| 148 | - } |
|
| 149 | - } |
|
| 150 | - |
|
| 151 | - /** |
|
| 152 | - * Enqueue Function. |
|
| 153 | - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 154 | - * |
|
| 155 | - * @since ReduxFramework 1.0.0 |
|
| 156 | - */ |
|
| 157 | - public function enqueue() { |
|
| 158 | - wp_enqueue_style( 'select2-css' ); |
|
| 159 | - |
|
| 160 | - wp_enqueue_script( |
|
| 161 | - 'redux-field-select-image', |
|
| 162 | - Redux_Core::$url . 'inc/fields/select_image/redux-select-image' . Redux_Functions::is_min() . '.js', |
|
| 163 | - array( 'jquery', 'select2-js', 'redux-js' ), |
|
| 164 | - $this->timestamp, |
|
| 165 | - true |
|
| 166 | - ); |
|
| 167 | - |
|
| 168 | - if ( $this->parent->args['dev_mode'] ) { |
|
| 169 | - wp_enqueue_style( |
|
| 170 | - 'redux-field-select-image', |
|
| 171 | - Redux_Core::$url . 'inc/fields/select_image/redux-select-image.css', |
|
| 172 | - array(), |
|
| 173 | - $this->timestamp |
|
| 174 | - ); |
|
| 175 | - } |
|
| 176 | - } |
|
| 177 | - } |
|
| 74 | + $width . ' rows="6"' . esc_attr( $select2_data ) . '>'; // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 75 | + |
|
| 76 | + echo '<option></option>'; |
|
| 77 | + |
|
| 78 | + // Enum through the options array. |
|
| 79 | + foreach ( $this->field['options'] as $v ) { |
|
| 80 | + |
|
| 81 | + // No array? No problem! |
|
| 82 | + if ( ! is_array( $v ) ) { |
|
| 83 | + $v = array( 'img' => $v ); |
|
| 84 | + } |
|
| 85 | + |
|
| 86 | + // No title set? Make it blank. |
|
| 87 | + if ( ! isset( $v['title'] ) ) { |
|
| 88 | + $v['title'] = ''; |
|
| 89 | + } |
|
| 90 | + |
|
| 91 | + // No alt? Set it to title. We do this so the alt tag shows |
|
| 92 | + // something. It also makes HTML/SEO purists happy. |
|
| 93 | + if ( ! isset( $v['alt'] ) ) { |
|
| 94 | + $v['alt'] = $v['title']; |
|
| 95 | + } |
|
| 96 | + |
|
| 97 | + // Set the selected entry. |
|
| 98 | + $selected = selected( $this->value, $v['img'], false ); |
|
| 99 | + |
|
| 100 | + // If selected returns something other than a blank space, we |
|
| 101 | + // found our default/saved name. Save the array number in a |
|
| 102 | + // variable to use later on when we want to extract its associated |
|
| 103 | + // url. |
|
| 104 | + if ( '' !== $selected ) { |
|
| 105 | + $arr_num = $x; |
|
| 106 | + } |
|
| 107 | + |
|
| 108 | + // Add the option tag, with values. |
|
| 109 | + echo '<option value="' . esc_url( $v['img'] ) . '" ' . esc_html( $selected ) . '>' . esc_attr( $v['alt'] ) . '</option>'; |
|
| 110 | + |
|
| 111 | + // Add a bean. |
|
| 112 | + ++$x; |
|
| 113 | + } |
|
| 114 | + |
|
| 115 | + // Close the <select> tag. |
|
| 116 | + echo '</select>'; |
|
| 117 | + |
|
| 118 | + // Some space. |
|
| 119 | + echo '<br /><br />'; |
|
| 120 | + |
|
| 121 | + // Show the preview image. |
|
| 122 | + echo '<div>'; |
|
| 123 | + |
|
| 124 | + // just in case. You never know. |
|
| 125 | + if ( ! isset( $arr_num ) ) { |
|
| 126 | + $this->value = ''; |
|
| 127 | + } |
|
| 128 | + |
|
| 129 | + // Set the default image. To get the url from the default name, |
|
| 130 | + // we save the array count from the for/each loop, when the default image |
|
| 131 | + // is mark as selected. Since the for/each loop starts at one, we must |
|
| 132 | + // subtract one from the saved array number. We then pull the url |
|
| 133 | + // out of the options array, and there we go. |
|
| 134 | + if ( '' === $this->value ) { |
|
| 135 | + // phpcs:ignore PluginCheck.CodeAnalysis.ImageFunctions.NonEnqueuedImage -- No image/icon to enqueue. |
|
| 136 | + echo '<img src="#" class="redux-preview-image" style="visibility:hidden;" id="image_' . esc_attr( $this->field['id'] ) . '">'; |
|
| 137 | + } else { |
|
| 138 | + // phpcs:ignore PluginCheck.CodeAnalysis.ImageFunctions.NonEnqueuedImage -- No image/icon to enqueue. |
|
| 139 | + echo '<img src=' . esc_url( $this->value ) . ' class="redux-preview-image" id="image_' . esc_attr( $this->field['id'] ) . '">'; |
|
| 140 | + } |
|
| 141 | + |
|
| 142 | + // Close the <div> tag. |
|
| 143 | + echo '</div>'; |
|
| 144 | + } else { |
|
| 145 | + |
|
| 146 | + // No options specified. Really? |
|
| 147 | + echo '<strong>' . esc_html__( 'No items of this type were found.', 'redux-framework' ) . '</strong>'; |
|
| 148 | + } |
|
| 149 | + } |
|
| 150 | + |
|
| 151 | + /** |
|
| 152 | + * Enqueue Function. |
|
| 153 | + * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 154 | + * |
|
| 155 | + * @since ReduxFramework 1.0.0 |
|
| 156 | + */ |
|
| 157 | + public function enqueue() { |
|
| 158 | + wp_enqueue_style( 'select2-css' ); |
|
| 159 | + |
|
| 160 | + wp_enqueue_script( |
|
| 161 | + 'redux-field-select-image', |
|
| 162 | + Redux_Core::$url . 'inc/fields/select_image/redux-select-image' . Redux_Functions::is_min() . '.js', |
|
| 163 | + array( 'jquery', 'select2-js', 'redux-js' ), |
|
| 164 | + $this->timestamp, |
|
| 165 | + true |
|
| 166 | + ); |
|
| 167 | + |
|
| 168 | + if ( $this->parent->args['dev_mode'] ) { |
|
| 169 | + wp_enqueue_style( |
|
| 170 | + 'redux-field-select-image', |
|
| 171 | + Redux_Core::$url . 'inc/fields/select_image/redux-select-image.css', |
|
| 172 | + array(), |
|
| 173 | + $this->timestamp |
|
| 174 | + ); |
|
| 175 | + } |
|
| 176 | + } |
|
| 177 | + } |
|
| 178 | 178 | } |
| 179 | 179 | |
| 180 | 180 | class_alias( 'Redux_Select_Image', 'ReduxFramework_Select_Image' ); |
@@ -94,7 +94,7 @@ discard block |
||
| 94 | 94 | |
| 95 | 95 | $the_value = $k; |
| 96 | 96 | |
| 97 | - if ( ! empty( $this->field['tiles'] ) && true === (bool) $this->field['tiles'] ) { |
|
| 97 | + if ( ! empty( $this->field['tiles'] ) && true === ( bool ) $this->field['tiles'] ) { |
|
| 98 | 98 | $the_value = $v['img']; |
| 99 | 99 | } |
| 100 | 100 | |
@@ -123,14 +123,14 @@ discard block |
||
| 123 | 123 | } else { |
| 124 | 124 | foreach ( $v['presets'] as $pk => $pv ) { |
| 125 | 125 | if ( isset( $v['merge'] ) && false !== $v['merge'] ) { |
| 126 | - if ( ( true === $v['merge'] || in_array( $pk, $v['merge'], true ) ) && is_array( $this->parent->options[ $pk ] ) ) { |
|
| 127 | - $pv = array_merge( $this->parent->options[ $pk ], $pv ); |
|
| 126 | + if ( ( true === $v['merge'] || in_array( $pk, $v['merge'], true ) ) && is_array( $this->parent->options[$pk] ) ) { |
|
| 127 | + $pv = array_merge( $this->parent->options[$pk], $pv ); |
|
| 128 | 128 | } |
| 129 | 129 | } |
| 130 | 130 | |
| 131 | - if ( empty( $pv ) && isset( $this->parent->options[ $pk ] ) && ! empty( $this->parent->options[ $pk ] ) ) { |
|
| 131 | + if ( empty( $pv ) && isset( $this->parent->options[$pk] ) && ! empty( $this->parent->options[$pk] ) ) { |
|
| 132 | 132 | $selected = false; |
| 133 | - } elseif ( ! empty( $pv ) && ! isset( $this->parent->options[ $pk ] ) ) { |
|
| 133 | + } elseif ( ! empty( $pv ) && ! isset( $this->parent->options[$pk] ) ) { |
|
| 134 | 134 | $selected = false; |
| 135 | 135 | } |
| 136 | 136 | |
@@ -227,10 +227,10 @@ discard block |
||
| 227 | 227 | if ( ! empty( $data ) && ! is_array( $data ) ) { |
| 228 | 228 | switch ( $mode ) { |
| 229 | 229 | case 'background-image': |
| 230 | - if ( isset( $this->field['tiles'] ) && true === (bool) $this->field['tiles'] ) { |
|
| 230 | + if ( isset( $this->field['tiles'] ) && true === ( bool ) $this->field['tiles'] ) { |
|
| 231 | 231 | $img = $data; |
| 232 | 232 | } else { |
| 233 | - $img = $this->field['options'][ $data ]['img'] ?? ''; |
|
| 233 | + $img = $this->field['options'][$data]['img'] ?? ''; |
|
| 234 | 234 | } |
| 235 | 235 | |
| 236 | 236 | if ( '' !== $img ) { |
@@ -12,243 +12,243 @@ |
||
| 12 | 12 | // Don't duplicate me! |
| 13 | 13 | if ( ! class_exists( 'Redux_Image_Select', false ) ) { |
| 14 | 14 | |
| 15 | - /** |
|
| 16 | - * Main Redux_image_select class |
|
| 17 | - * |
|
| 18 | - * @since 1.0.0 |
|
| 19 | - */ |
|
| 20 | - class Redux_Image_Select extends Redux_Field { |
|
| 21 | - |
|
| 22 | - /** |
|
| 23 | - * Set field defaults. |
|
| 24 | - */ |
|
| 25 | - public function set_defaults() { |
|
| 26 | - $defaults = array( |
|
| 27 | - 'tiles' => false, |
|
| 28 | - 'mode' => 'background-image', |
|
| 29 | - 'presets' => false, |
|
| 30 | - 'options' => array(), |
|
| 31 | - 'width' => '', |
|
| 32 | - 'height' => '', |
|
| 33 | - ); |
|
| 34 | - |
|
| 35 | - $this->field = wp_parse_args( $this->field, $defaults ); |
|
| 36 | - } |
|
| 37 | - |
|
| 38 | - /** |
|
| 39 | - * Field Render Function. |
|
| 40 | - * Takes the vars and outputs the HTML for the field in the settings |
|
| 41 | - * |
|
| 42 | - * @since 1.0.0 |
|
| 43 | - * @access public |
|
| 44 | - * @return void |
|
| 45 | - */ |
|
| 46 | - public function render() { |
|
| 47 | - if ( ! empty( $this->field['options'] ) ) { |
|
| 48 | - echo '<div class="redux-table-container">'; |
|
| 49 | - echo '<ul class="redux-image-select">'; |
|
| 50 | - |
|
| 51 | - $x = 1; |
|
| 52 | - |
|
| 53 | - foreach ( $this->field['options'] as $k => $v ) { |
|
| 54 | - |
|
| 55 | - if ( ! is_array( $v ) ) { |
|
| 56 | - $v = array( 'img' => $v ); |
|
| 57 | - } |
|
| 58 | - |
|
| 59 | - if ( ! isset( $v['title'] ) ) { |
|
| 60 | - $v['title'] = ''; |
|
| 61 | - } |
|
| 62 | - |
|
| 63 | - if ( ! isset( $v['alt'] ) ) { |
|
| 64 | - $v['alt'] = $v['title']; |
|
| 65 | - } |
|
| 66 | - |
|
| 67 | - if ( ! isset( $v['class'] ) ) { |
|
| 68 | - $v['class'] = ''; |
|
| 69 | - } |
|
| 70 | - |
|
| 71 | - $style = ''; |
|
| 72 | - |
|
| 73 | - if ( ! empty( $this->field['width'] ) ) { |
|
| 74 | - $style .= 'width: ' . $this->field['width']; |
|
| 75 | - |
|
| 76 | - if ( is_numeric( $this->field['width'] ) ) { |
|
| 77 | - $style .= 'px'; |
|
| 78 | - } |
|
| 79 | - |
|
| 80 | - $style .= ';'; |
|
| 81 | - } else { |
|
| 82 | - $style .= ' width: 100%; '; |
|
| 83 | - } |
|
| 84 | - |
|
| 85 | - if ( ! empty( $this->field['height'] ) ) { |
|
| 86 | - $style .= 'height: ' . $this->field['height']; |
|
| 87 | - |
|
| 88 | - if ( is_numeric( $this->field['height'] ) ) { |
|
| 89 | - $style .= 'px'; |
|
| 90 | - } |
|
| 91 | - |
|
| 92 | - $style .= ';'; |
|
| 93 | - } |
|
| 94 | - |
|
| 95 | - $the_value = $k; |
|
| 96 | - |
|
| 97 | - if ( ! empty( $this->field['tiles'] ) && true === (bool) $this->field['tiles'] ) { |
|
| 98 | - $the_value = $v['img']; |
|
| 99 | - } |
|
| 100 | - |
|
| 101 | - $selected = ( '' !== checked( $this->value, $the_value, false ) ) ? ' redux-image-select-selected' : ''; |
|
| 102 | - |
|
| 103 | - $presets = ''; |
|
| 104 | - $is_preset = false; |
|
| 105 | - |
|
| 106 | - $this->field['class'] = trim( str_replace( 'no-update', '', $this->field['class'] ) ); |
|
| 107 | - $this->field['class'] .= ' no-update '; |
|
| 108 | - |
|
| 109 | - if ( isset( $this->field['presets'] ) && false !== $this->field['presets'] ) { |
|
| 110 | - $this->field['class'] = trim( $this->field['class'] ); |
|
| 111 | - if ( ! isset( $v['presets'] ) ) { |
|
| 112 | - $v['presets'] = array(); |
|
| 113 | - } |
|
| 114 | - |
|
| 115 | - if ( ! is_array( $v['presets'] ) ) { |
|
| 116 | - $v['presets'] = json_decode( $v['presets'], true ); |
|
| 117 | - } |
|
| 118 | - |
|
| 119 | - // Only highlight the preset if it's the same. |
|
| 120 | - if ( $selected ) { |
|
| 121 | - if ( empty( $v['presets'] ) ) { |
|
| 122 | - $selected = false; |
|
| 123 | - } else { |
|
| 124 | - foreach ( $v['presets'] as $pk => $pv ) { |
|
| 125 | - if ( isset( $v['merge'] ) && false !== $v['merge'] ) { |
|
| 126 | - if ( ( true === $v['merge'] || in_array( $pk, $v['merge'], true ) ) && is_array( $this->parent->options[ $pk ] ) ) { |
|
| 127 | - $pv = array_merge( $this->parent->options[ $pk ], $pv ); |
|
| 128 | - } |
|
| 129 | - } |
|
| 130 | - |
|
| 131 | - if ( empty( $pv ) && isset( $this->parent->options[ $pk ] ) && ! empty( $this->parent->options[ $pk ] ) ) { |
|
| 132 | - $selected = false; |
|
| 133 | - } elseif ( ! empty( $pv ) && ! isset( $this->parent->options[ $pk ] ) ) { |
|
| 134 | - $selected = false; |
|
| 135 | - } |
|
| 136 | - |
|
| 137 | - if ( ! $selected ) { // We're still not using the same preset. Let's unset that shall we? |
|
| 138 | - $this->value = ''; |
|
| 139 | - break; |
|
| 140 | - } |
|
| 141 | - } |
|
| 142 | - } |
|
| 143 | - } |
|
| 144 | - |
|
| 145 | - $v['presets']['redux-backup'] = 1; |
|
| 146 | - |
|
| 147 | - $presets = ' data-presets="' . esc_attr( htmlspecialchars( wp_json_encode( $v['presets'] ), ENT_QUOTES ) ) . '"'; |
|
| 148 | - $is_preset = true; |
|
| 149 | - |
|
| 150 | - $this->field['class'] = trim( $this->field['class'] ) . ' redux-presets'; |
|
| 151 | - } |
|
| 152 | - |
|
| 153 | - $is_preset_class = $is_preset ? '-preset-' : ' '; |
|
| 154 | - |
|
| 155 | - $merge = ''; |
|
| 156 | - if ( isset( $v['merge'] ) && false !== $v['merge'] ) { |
|
| 157 | - $merge = is_array( $v['merge'] ) ? implode( '|', $v['merge'] ) : 'true'; |
|
| 158 | - $merge = ' data-merge="' . esc_attr( htmlspecialchars( $merge, ENT_QUOTES ) ) . '"'; |
|
| 159 | - } |
|
| 160 | - |
|
| 161 | - echo '<li class="redux-image-select">'; |
|
| 162 | - echo '<label class="' . esc_attr( $selected ) . ' redux-image-select' . esc_attr( $is_preset_class ) . esc_attr( $this->field['id'] . '_' . $x ) . '" for="' . esc_attr( $this->field['id'] . '_' . ( array_search( $k, array_keys( $this->field['options'] ), true ) + 1 ) ) . '">'; |
|
| 163 | - // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped |
|
| 164 | - echo '<input type="radio" class="' . esc_attr( $this->field['class'] ) . '" id="' . esc_attr( $this->field['id'] . '_' . ( array_search( $k, array_keys( $this->field['options'] ), true ) + 1 ) ) . '" name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '" value="' . esc_attr( $the_value ) . '" ' . checked( $this->value, $the_value, false ) . $presets . $merge . '/>'; |
|
| 165 | - if ( ! empty( $this->field['tiles'] ) && true === $this->field['tiles'] ) { |
|
| 166 | - echo '<span class="tiles ' . esc_attr( $v['class'] ) . '" style="background-image: url(' . esc_url( $v['img'] ) . ');" rel="' . esc_url( $v['img'] ) . '""> </span>'; |
|
| 167 | - } else { |
|
| 168 | - // phpcs:ignore PluginCheck.CodeAnalysis.ImageFunctions.NonEnqueuedImage -- No image/icon to enqueue. |
|
| 169 | - echo '<img src="' . esc_url( $v['img'] ) . '" title="' . esc_attr( $v['alt'] ) . '" alt="' . esc_attr( $v['alt'] ) . '" class="' . esc_attr( $v['class'] ) . '" style="' . esc_attr( $style ) . '"' . esc_attr( $presets ) . esc_attr( $merge ) . ' />'; |
|
| 170 | - } |
|
| 171 | - |
|
| 172 | - if ( '' !== $v['title'] ) { |
|
| 173 | - echo '<br /><span>' . wp_kses_post( ( $v['title'] ) ) . '</span>'; |
|
| 174 | - } |
|
| 175 | - |
|
| 176 | - echo '</label>'; |
|
| 177 | - echo '</li>'; |
|
| 178 | - |
|
| 179 | - ++$x; |
|
| 180 | - } |
|
| 181 | - |
|
| 182 | - echo '</ul>'; |
|
| 183 | - echo '</div>'; |
|
| 184 | - } |
|
| 185 | - } |
|
| 186 | - |
|
| 187 | - /** |
|
| 188 | - * Enqueue Function. |
|
| 189 | - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 190 | - * |
|
| 191 | - * @since 1.0.0 |
|
| 192 | - * @access public |
|
| 193 | - * @return void |
|
| 194 | - */ |
|
| 195 | - public function enqueue() { |
|
| 196 | - |
|
| 197 | - wp_enqueue_script( |
|
| 198 | - 'redux-field-image-select', |
|
| 199 | - Redux_Core::$url . 'inc/fields/image_select/redux-image-select' . Redux_Functions::is_min() . '.js', |
|
| 200 | - array( 'jquery', 'redux-js' ), |
|
| 201 | - $this->timestamp, |
|
| 202 | - true |
|
| 203 | - ); |
|
| 204 | - |
|
| 205 | - if ( $this->parent->args['dev_mode'] ) { |
|
| 206 | - wp_enqueue_style( |
|
| 207 | - 'redux-field-image-select', |
|
| 208 | - Redux_Core::$url . 'inc/fields/image_select/redux-image-select.css', |
|
| 209 | - array(), |
|
| 210 | - $this->timestamp |
|
| 211 | - ); |
|
| 212 | - } |
|
| 213 | - } |
|
| 214 | - |
|
| 215 | - /** |
|
| 216 | - * Compile CSS data for output. |
|
| 217 | - * |
|
| 218 | - * @param string $data css string. |
|
| 219 | - * |
|
| 220 | - * @return string |
|
| 221 | - */ |
|
| 222 | - public function css_style( $data ): string { |
|
| 223 | - $css = ''; |
|
| 224 | - $output = ''; |
|
| 225 | - |
|
| 226 | - $mode = ( isset( $this->field['mode'] ) && ! empty( $this->field['mode'] ) ? $this->field['mode'] : 'background-image' ); |
|
| 227 | - |
|
| 228 | - if ( ! empty( $data ) && ! is_array( $data ) ) { |
|
| 229 | - switch ( $mode ) { |
|
| 230 | - case 'background-image': |
|
| 231 | - if ( isset( $this->field['tiles'] ) && true === (bool) $this->field['tiles'] ) { |
|
| 232 | - $img = $data; |
|
| 233 | - } else { |
|
| 234 | - $img = $this->field['options'][ $data ]['img'] ?? ''; |
|
| 235 | - } |
|
| 236 | - |
|
| 237 | - if ( '' !== $img ) { |
|
| 238 | - $output = "background-image: url('" . esc_url( $img ) . "');"; |
|
| 239 | - } |
|
| 240 | - break; |
|
| 241 | - |
|
| 242 | - default: |
|
| 243 | - $output = $mode . ': ' . $data . ';'; |
|
| 244 | - } |
|
| 245 | - } |
|
| 246 | - |
|
| 247 | - $css .= $output; |
|
| 248 | - |
|
| 249 | - return $css; |
|
| 250 | - } |
|
| 251 | - } |
|
| 15 | + /** |
|
| 16 | + * Main Redux_image_select class |
|
| 17 | + * |
|
| 18 | + * @since 1.0.0 |
|
| 19 | + */ |
|
| 20 | + class Redux_Image_Select extends Redux_Field { |
|
| 21 | + |
|
| 22 | + /** |
|
| 23 | + * Set field defaults. |
|
| 24 | + */ |
|
| 25 | + public function set_defaults() { |
|
| 26 | + $defaults = array( |
|
| 27 | + 'tiles' => false, |
|
| 28 | + 'mode' => 'background-image', |
|
| 29 | + 'presets' => false, |
|
| 30 | + 'options' => array(), |
|
| 31 | + 'width' => '', |
|
| 32 | + 'height' => '', |
|
| 33 | + ); |
|
| 34 | + |
|
| 35 | + $this->field = wp_parse_args( $this->field, $defaults ); |
|
| 36 | + } |
|
| 37 | + |
|
| 38 | + /** |
|
| 39 | + * Field Render Function. |
|
| 40 | + * Takes the vars and outputs the HTML for the field in the settings |
|
| 41 | + * |
|
| 42 | + * @since 1.0.0 |
|
| 43 | + * @access public |
|
| 44 | + * @return void |
|
| 45 | + */ |
|
| 46 | + public function render() { |
|
| 47 | + if ( ! empty( $this->field['options'] ) ) { |
|
| 48 | + echo '<div class="redux-table-container">'; |
|
| 49 | + echo '<ul class="redux-image-select">'; |
|
| 50 | + |
|
| 51 | + $x = 1; |
|
| 52 | + |
|
| 53 | + foreach ( $this->field['options'] as $k => $v ) { |
|
| 54 | + |
|
| 55 | + if ( ! is_array( $v ) ) { |
|
| 56 | + $v = array( 'img' => $v ); |
|
| 57 | + } |
|
| 58 | + |
|
| 59 | + if ( ! isset( $v['title'] ) ) { |
|
| 60 | + $v['title'] = ''; |
|
| 61 | + } |
|
| 62 | + |
|
| 63 | + if ( ! isset( $v['alt'] ) ) { |
|
| 64 | + $v['alt'] = $v['title']; |
|
| 65 | + } |
|
| 66 | + |
|
| 67 | + if ( ! isset( $v['class'] ) ) { |
|
| 68 | + $v['class'] = ''; |
|
| 69 | + } |
|
| 70 | + |
|
| 71 | + $style = ''; |
|
| 72 | + |
|
| 73 | + if ( ! empty( $this->field['width'] ) ) { |
|
| 74 | + $style .= 'width: ' . $this->field['width']; |
|
| 75 | + |
|
| 76 | + if ( is_numeric( $this->field['width'] ) ) { |
|
| 77 | + $style .= 'px'; |
|
| 78 | + } |
|
| 79 | + |
|
| 80 | + $style .= ';'; |
|
| 81 | + } else { |
|
| 82 | + $style .= ' width: 100%; '; |
|
| 83 | + } |
|
| 84 | + |
|
| 85 | + if ( ! empty( $this->field['height'] ) ) { |
|
| 86 | + $style .= 'height: ' . $this->field['height']; |
|
| 87 | + |
|
| 88 | + if ( is_numeric( $this->field['height'] ) ) { |
|
| 89 | + $style .= 'px'; |
|
| 90 | + } |
|
| 91 | + |
|
| 92 | + $style .= ';'; |
|
| 93 | + } |
|
| 94 | + |
|
| 95 | + $the_value = $k; |
|
| 96 | + |
|
| 97 | + if ( ! empty( $this->field['tiles'] ) && true === (bool) $this->field['tiles'] ) { |
|
| 98 | + $the_value = $v['img']; |
|
| 99 | + } |
|
| 100 | + |
|
| 101 | + $selected = ( '' !== checked( $this->value, $the_value, false ) ) ? ' redux-image-select-selected' : ''; |
|
| 102 | + |
|
| 103 | + $presets = ''; |
|
| 104 | + $is_preset = false; |
|
| 105 | + |
|
| 106 | + $this->field['class'] = trim( str_replace( 'no-update', '', $this->field['class'] ) ); |
|
| 107 | + $this->field['class'] .= ' no-update '; |
|
| 108 | + |
|
| 109 | + if ( isset( $this->field['presets'] ) && false !== $this->field['presets'] ) { |
|
| 110 | + $this->field['class'] = trim( $this->field['class'] ); |
|
| 111 | + if ( ! isset( $v['presets'] ) ) { |
|
| 112 | + $v['presets'] = array(); |
|
| 113 | + } |
|
| 114 | + |
|
| 115 | + if ( ! is_array( $v['presets'] ) ) { |
|
| 116 | + $v['presets'] = json_decode( $v['presets'], true ); |
|
| 117 | + } |
|
| 118 | + |
|
| 119 | + // Only highlight the preset if it's the same. |
|
| 120 | + if ( $selected ) { |
|
| 121 | + if ( empty( $v['presets'] ) ) { |
|
| 122 | + $selected = false; |
|
| 123 | + } else { |
|
| 124 | + foreach ( $v['presets'] as $pk => $pv ) { |
|
| 125 | + if ( isset( $v['merge'] ) && false !== $v['merge'] ) { |
|
| 126 | + if ( ( true === $v['merge'] || in_array( $pk, $v['merge'], true ) ) && is_array( $this->parent->options[ $pk ] ) ) { |
|
| 127 | + $pv = array_merge( $this->parent->options[ $pk ], $pv ); |
|
| 128 | + } |
|
| 129 | + } |
|
| 130 | + |
|
| 131 | + if ( empty( $pv ) && isset( $this->parent->options[ $pk ] ) && ! empty( $this->parent->options[ $pk ] ) ) { |
|
| 132 | + $selected = false; |
|
| 133 | + } elseif ( ! empty( $pv ) && ! isset( $this->parent->options[ $pk ] ) ) { |
|
| 134 | + $selected = false; |
|
| 135 | + } |
|
| 136 | + |
|
| 137 | + if ( ! $selected ) { // We're still not using the same preset. Let's unset that shall we? |
|
| 138 | + $this->value = ''; |
|
| 139 | + break; |
|
| 140 | + } |
|
| 141 | + } |
|
| 142 | + } |
|
| 143 | + } |
|
| 144 | + |
|
| 145 | + $v['presets']['redux-backup'] = 1; |
|
| 146 | + |
|
| 147 | + $presets = ' data-presets="' . esc_attr( htmlspecialchars( wp_json_encode( $v['presets'] ), ENT_QUOTES ) ) . '"'; |
|
| 148 | + $is_preset = true; |
|
| 149 | + |
|
| 150 | + $this->field['class'] = trim( $this->field['class'] ) . ' redux-presets'; |
|
| 151 | + } |
|
| 152 | + |
|
| 153 | + $is_preset_class = $is_preset ? '-preset-' : ' '; |
|
| 154 | + |
|
| 155 | + $merge = ''; |
|
| 156 | + if ( isset( $v['merge'] ) && false !== $v['merge'] ) { |
|
| 157 | + $merge = is_array( $v['merge'] ) ? implode( '|', $v['merge'] ) : 'true'; |
|
| 158 | + $merge = ' data-merge="' . esc_attr( htmlspecialchars( $merge, ENT_QUOTES ) ) . '"'; |
|
| 159 | + } |
|
| 160 | + |
|
| 161 | + echo '<li class="redux-image-select">'; |
|
| 162 | + echo '<label class="' . esc_attr( $selected ) . ' redux-image-select' . esc_attr( $is_preset_class ) . esc_attr( $this->field['id'] . '_' . $x ) . '" for="' . esc_attr( $this->field['id'] . '_' . ( array_search( $k, array_keys( $this->field['options'] ), true ) + 1 ) ) . '">'; |
|
| 163 | + // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped |
|
| 164 | + echo '<input type="radio" class="' . esc_attr( $this->field['class'] ) . '" id="' . esc_attr( $this->field['id'] . '_' . ( array_search( $k, array_keys( $this->field['options'] ), true ) + 1 ) ) . '" name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '" value="' . esc_attr( $the_value ) . '" ' . checked( $this->value, $the_value, false ) . $presets . $merge . '/>'; |
|
| 165 | + if ( ! empty( $this->field['tiles'] ) && true === $this->field['tiles'] ) { |
|
| 166 | + echo '<span class="tiles ' . esc_attr( $v['class'] ) . '" style="background-image: url(' . esc_url( $v['img'] ) . ');" rel="' . esc_url( $v['img'] ) . '""> </span>'; |
|
| 167 | + } else { |
|
| 168 | + // phpcs:ignore PluginCheck.CodeAnalysis.ImageFunctions.NonEnqueuedImage -- No image/icon to enqueue. |
|
| 169 | + echo '<img src="' . esc_url( $v['img'] ) . '" title="' . esc_attr( $v['alt'] ) . '" alt="' . esc_attr( $v['alt'] ) . '" class="' . esc_attr( $v['class'] ) . '" style="' . esc_attr( $style ) . '"' . esc_attr( $presets ) . esc_attr( $merge ) . ' />'; |
|
| 170 | + } |
|
| 171 | + |
|
| 172 | + if ( '' !== $v['title'] ) { |
|
| 173 | + echo '<br /><span>' . wp_kses_post( ( $v['title'] ) ) . '</span>'; |
|
| 174 | + } |
|
| 175 | + |
|
| 176 | + echo '</label>'; |
|
| 177 | + echo '</li>'; |
|
| 178 | + |
|
| 179 | + ++$x; |
|
| 180 | + } |
|
| 181 | + |
|
| 182 | + echo '</ul>'; |
|
| 183 | + echo '</div>'; |
|
| 184 | + } |
|
| 185 | + } |
|
| 186 | + |
|
| 187 | + /** |
|
| 188 | + * Enqueue Function. |
|
| 189 | + * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 190 | + * |
|
| 191 | + * @since 1.0.0 |
|
| 192 | + * @access public |
|
| 193 | + * @return void |
|
| 194 | + */ |
|
| 195 | + public function enqueue() { |
|
| 196 | + |
|
| 197 | + wp_enqueue_script( |
|
| 198 | + 'redux-field-image-select', |
|
| 199 | + Redux_Core::$url . 'inc/fields/image_select/redux-image-select' . Redux_Functions::is_min() . '.js', |
|
| 200 | + array( 'jquery', 'redux-js' ), |
|
| 201 | + $this->timestamp, |
|
| 202 | + true |
|
| 203 | + ); |
|
| 204 | + |
|
| 205 | + if ( $this->parent->args['dev_mode'] ) { |
|
| 206 | + wp_enqueue_style( |
|
| 207 | + 'redux-field-image-select', |
|
| 208 | + Redux_Core::$url . 'inc/fields/image_select/redux-image-select.css', |
|
| 209 | + array(), |
|
| 210 | + $this->timestamp |
|
| 211 | + ); |
|
| 212 | + } |
|
| 213 | + } |
|
| 214 | + |
|
| 215 | + /** |
|
| 216 | + * Compile CSS data for output. |
|
| 217 | + * |
|
| 218 | + * @param string $data css string. |
|
| 219 | + * |
|
| 220 | + * @return string |
|
| 221 | + */ |
|
| 222 | + public function css_style( $data ): string { |
|
| 223 | + $css = ''; |
|
| 224 | + $output = ''; |
|
| 225 | + |
|
| 226 | + $mode = ( isset( $this->field['mode'] ) && ! empty( $this->field['mode'] ) ? $this->field['mode'] : 'background-image' ); |
|
| 227 | + |
|
| 228 | + if ( ! empty( $data ) && ! is_array( $data ) ) { |
|
| 229 | + switch ( $mode ) { |
|
| 230 | + case 'background-image': |
|
| 231 | + if ( isset( $this->field['tiles'] ) && true === (bool) $this->field['tiles'] ) { |
|
| 232 | + $img = $data; |
|
| 233 | + } else { |
|
| 234 | + $img = $this->field['options'][ $data ]['img'] ?? ''; |
|
| 235 | + } |
|
| 236 | + |
|
| 237 | + if ( '' !== $img ) { |
|
| 238 | + $output = "background-image: url('" . esc_url( $img ) . "');"; |
|
| 239 | + } |
|
| 240 | + break; |
|
| 241 | + |
|
| 242 | + default: |
|
| 243 | + $output = $mode . ': ' . $data . ';'; |
|
| 244 | + } |
|
| 245 | + } |
|
| 246 | + |
|
| 247 | + $css .= $output; |
|
| 248 | + |
|
| 249 | + return $css; |
|
| 250 | + } |
|
| 251 | + } |
|
| 252 | 252 | } |
| 253 | 253 | |
| 254 | 254 | class_alias( 'Redux_Image_Select', 'ReduxFramework_Image_Select' ); |
@@ -12,67 +12,67 @@ discard block |
||
| 12 | 12 | // Don't duplicate me! |
| 13 | 13 | if ( ! class_exists( 'Redux_Color_Rgba', false ) ) { |
| 14 | 14 | |
| 15 | - /** |
|
| 16 | - * Main Redux_color_rgba class |
|
| 17 | - * |
|
| 18 | - * @since 1.0.0 |
|
| 19 | - */ |
|
| 20 | - class Redux_Color_Rgba extends Redux_Field { |
|
| 21 | - |
|
| 22 | - /** |
|
| 23 | - * Set field and value defaults. |
|
| 24 | - */ |
|
| 25 | - public function set_defaults() { |
|
| 26 | - $defaults = array( |
|
| 27 | - 'color' => '', |
|
| 28 | - 'alpha' => 1, |
|
| 29 | - 'rgba' => '', |
|
| 30 | - ); |
|
| 31 | - |
|
| 32 | - $option_defaults = array( |
|
| 33 | - 'show_input' => true, |
|
| 34 | - 'show_initial' => false, |
|
| 35 | - 'show_alpha' => true, |
|
| 36 | - 'show_palette' => false, |
|
| 37 | - 'show_palette_only' => false, |
|
| 38 | - 'max_palette_size' => 10, |
|
| 39 | - 'show_selection_palette' => false, |
|
| 40 | - 'allow_empty' => true, |
|
| 41 | - 'clickout_fires_change' => false, |
|
| 42 | - 'choose_text' => esc_html__( 'Choose', 'redux-framework' ), |
|
| 43 | - 'cancel_text' => esc_html__( 'Cancel', 'redux-framework' ), |
|
| 44 | - 'show_buttons' => true, |
|
| 45 | - 'input_text' => esc_html__( 'Select Color', 'redux-framework' ), |
|
| 46 | - 'palette' => null, |
|
| 47 | - ); |
|
| 48 | - |
|
| 49 | - $this->value = wp_parse_args( $this->value, $defaults ); |
|
| 50 | - |
|
| 51 | - if ( isset( $this->field ) && ! is_array( $this->field ) ) { |
|
| 52 | - return; |
|
| 53 | - } |
|
| 54 | - |
|
| 55 | - $this->field['options'] = isset( $this->field['options'] ) ? wp_parse_args( $this->field['options'], $option_defaults ) : $option_defaults; |
|
| 56 | - |
|
| 57 | - // Convert an empty array to null, if there. |
|
| 58 | - $this->field['options']['palette'] = empty( $this->field['options']['palette'] ) ? null : $this->field['options']['palette']; |
|
| 59 | - |
|
| 60 | - $this->field['output_transparent'] = $this->field['output_transparent'] ?? false; |
|
| 61 | - } |
|
| 62 | - |
|
| 63 | - /** |
|
| 64 | - * Field Render Function. |
|
| 65 | - * Takes the vars and outputs the HTML for the field in the settings |
|
| 66 | - * |
|
| 67 | - * @since 1.0.0 |
|
| 68 | - * @access public |
|
| 69 | - * @return void |
|
| 70 | - */ |
|
| 71 | - public function render() { |
|
| 72 | - $field_id = $this->field['id']; |
|
| 73 | - |
|
| 74 | - // Color picker container. |
|
| 75 | - echo '<div |
|
| 15 | + /** |
|
| 16 | + * Main Redux_color_rgba class |
|
| 17 | + * |
|
| 18 | + * @since 1.0.0 |
|
| 19 | + */ |
|
| 20 | + class Redux_Color_Rgba extends Redux_Field { |
|
| 21 | + |
|
| 22 | + /** |
|
| 23 | + * Set field and value defaults. |
|
| 24 | + */ |
|
| 25 | + public function set_defaults() { |
|
| 26 | + $defaults = array( |
|
| 27 | + 'color' => '', |
|
| 28 | + 'alpha' => 1, |
|
| 29 | + 'rgba' => '', |
|
| 30 | + ); |
|
| 31 | + |
|
| 32 | + $option_defaults = array( |
|
| 33 | + 'show_input' => true, |
|
| 34 | + 'show_initial' => false, |
|
| 35 | + 'show_alpha' => true, |
|
| 36 | + 'show_palette' => false, |
|
| 37 | + 'show_palette_only' => false, |
|
| 38 | + 'max_palette_size' => 10, |
|
| 39 | + 'show_selection_palette' => false, |
|
| 40 | + 'allow_empty' => true, |
|
| 41 | + 'clickout_fires_change' => false, |
|
| 42 | + 'choose_text' => esc_html__( 'Choose', 'redux-framework' ), |
|
| 43 | + 'cancel_text' => esc_html__( 'Cancel', 'redux-framework' ), |
|
| 44 | + 'show_buttons' => true, |
|
| 45 | + 'input_text' => esc_html__( 'Select Color', 'redux-framework' ), |
|
| 46 | + 'palette' => null, |
|
| 47 | + ); |
|
| 48 | + |
|
| 49 | + $this->value = wp_parse_args( $this->value, $defaults ); |
|
| 50 | + |
|
| 51 | + if ( isset( $this->field ) && ! is_array( $this->field ) ) { |
|
| 52 | + return; |
|
| 53 | + } |
|
| 54 | + |
|
| 55 | + $this->field['options'] = isset( $this->field['options'] ) ? wp_parse_args( $this->field['options'], $option_defaults ) : $option_defaults; |
|
| 56 | + |
|
| 57 | + // Convert an empty array to null, if there. |
|
| 58 | + $this->field['options']['palette'] = empty( $this->field['options']['palette'] ) ? null : $this->field['options']['palette']; |
|
| 59 | + |
|
| 60 | + $this->field['output_transparent'] = $this->field['output_transparent'] ?? false; |
|
| 61 | + } |
|
| 62 | + |
|
| 63 | + /** |
|
| 64 | + * Field Render Function. |
|
| 65 | + * Takes the vars and outputs the HTML for the field in the settings |
|
| 66 | + * |
|
| 67 | + * @since 1.0.0 |
|
| 68 | + * @access public |
|
| 69 | + * @return void |
|
| 70 | + */ |
|
| 71 | + public function render() { |
|
| 72 | + $field_id = $this->field['id']; |
|
| 73 | + |
|
| 74 | + // Color picker container. |
|
| 75 | + echo '<div |
|
| 76 | 76 | class="redux-color-rgba-container ' . esc_attr( $this->field['class'] ) . '" |
| 77 | 77 | data-id="' . esc_attr( $field_id ) . '" |
| 78 | 78 | data-show-input="' . esc_attr( $this->field['options']['show_input'] ) . '" |
@@ -91,18 +91,18 @@ discard block |
||
| 91 | 91 | data-palette="' . rawurlencode( wp_json_encode( $this->field['options']['palette'] ) ) . '" |
| 92 | 92 | >'; |
| 93 | 93 | |
| 94 | - // Colour picker layout. |
|
| 95 | - if ( '' === $this->value['color'] || 'transparent' === $this->value['color'] ) { |
|
| 96 | - $color = ''; |
|
| 97 | - } else { |
|
| 98 | - $color = Redux_Helpers::hex2rgba( $this->value['color'], $this->value['alpha'] ); |
|
| 99 | - } |
|
| 94 | + // Colour picker layout. |
|
| 95 | + if ( '' === $this->value['color'] || 'transparent' === $this->value['color'] ) { |
|
| 96 | + $color = ''; |
|
| 97 | + } else { |
|
| 98 | + $color = Redux_Helpers::hex2rgba( $this->value['color'], $this->value['alpha'] ); |
|
| 99 | + } |
|
| 100 | 100 | |
| 101 | - if ( '' === $this->value['rgba'] && '' !== $this->value['color'] ) { |
|
| 102 | - $this->value['rgba'] = Redux_Helpers::hex2rgba( $this->value['color'], $this->value['alpha'] ); |
|
| 103 | - } |
|
| 101 | + if ( '' === $this->value['rgba'] && '' !== $this->value['color'] ) { |
|
| 102 | + $this->value['rgba'] = Redux_Helpers::hex2rgba( $this->value['color'], $this->value['alpha'] ); |
|
| 103 | + } |
|
| 104 | 104 | |
| 105 | - echo '<input |
|
| 105 | + echo '<input |
|
| 106 | 106 | name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '[color]" |
| 107 | 107 | id="' . esc_attr( $field_id ) . '-color-display" |
| 108 | 108 | class="redux-color-rgba" |
@@ -115,7 +115,7 @@ discard block |
||
| 115 | 115 | data-output-transparent="' . esc_attr( $this->field['output_transparent'] ) . '" |
| 116 | 116 | />'; |
| 117 | 117 | |
| 118 | - echo '<input |
|
| 118 | + echo '<input |
|
| 119 | 119 | type="hidden" |
| 120 | 120 | class="redux-hidden-color" |
| 121 | 121 | data-id="' . esc_attr( $field_id ) . '-color" |
@@ -123,8 +123,8 @@ discard block |
||
| 123 | 123 | value="' . esc_attr( $this->value['color'] ) . '" |
| 124 | 124 | />'; |
| 125 | 125 | |
| 126 | - // Hidden input for alpha channel. |
|
| 127 | - echo '<input |
|
| 126 | + // Hidden input for alpha channel. |
|
| 127 | + echo '<input |
|
| 128 | 128 | type="hidden" |
| 129 | 129 | class="redux-hidden-alpha" |
| 130 | 130 | data-id="' . esc_attr( $field_id ) . '-alpha" |
@@ -133,8 +133,8 @@ discard block |
||
| 133 | 133 | value="' . esc_attr( $this->value['alpha'] ) . '" |
| 134 | 134 | />'; |
| 135 | 135 | |
| 136 | - // Hidden input for rgba. |
|
| 137 | - echo '<input |
|
| 136 | + // Hidden input for rgba. |
|
| 137 | + echo '<input |
|
| 138 | 138 | type="hidden" |
| 139 | 139 | class="redux-hidden-rgba" |
| 140 | 140 | data-id="' . esc_attr( $field_id ) . '-rgba" |
@@ -143,142 +143,142 @@ discard block |
||
| 143 | 143 | value="' . esc_attr( $this->value['rgba'] ) . '" |
| 144 | 144 | />'; |
| 145 | 145 | |
| 146 | - echo '</div>'; |
|
| 147 | - } |
|
| 148 | - |
|
| 149 | - /** |
|
| 150 | - * Enqueue Function. |
|
| 151 | - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 152 | - * |
|
| 153 | - * @since 1.0.0 |
|
| 154 | - * @access public |
|
| 155 | - * @return void |
|
| 156 | - */ |
|
| 157 | - public function enqueue() { |
|
| 158 | - |
|
| 159 | - // Set up min files for dev_mode = false. |
|
| 160 | - $min = Redux_Functions::is_min(); |
|
| 161 | - |
|
| 162 | - // Field dependent JS. |
|
| 163 | - wp_enqueue_script( |
|
| 164 | - 'redux-field-color-rgba', |
|
| 165 | - Redux_Core::$url . 'inc/fields/color_rgba/redux-color-rgba' . $min . '.js', |
|
| 166 | - array( 'jquery', 'redux-spectrum-js', 'redux-js' ), |
|
| 167 | - $this->timestamp, |
|
| 168 | - true |
|
| 169 | - ); |
|
| 170 | - |
|
| 171 | - // Spectrum CSS. |
|
| 172 | - if ( ! wp_style_is( 'redux-spectrum-css' ) ) { |
|
| 173 | - wp_enqueue_style( 'redux-spectrum-css' ); |
|
| 174 | - } |
|
| 175 | - |
|
| 176 | - if ( $this->parent->args['dev_mode'] ) { |
|
| 177 | - wp_enqueue_style( |
|
| 178 | - 'redux-field-color-rgba', |
|
| 179 | - Redux_Core::$url . 'inc/fields/color_rgba/redux-color-rgba.css', |
|
| 180 | - array(), |
|
| 181 | - $this->timestamp |
|
| 182 | - ); |
|
| 183 | - } |
|
| 184 | - } |
|
| 185 | - |
|
| 186 | - /** |
|
| 187 | - * -> getColorVal. Returns formatted color val in hex or rgba. |
|
| 188 | - * If this field requires any scripts or css, define this function and register/enqueue the scripts/css |
|
| 189 | - * |
|
| 190 | - * @since 1.0.0 |
|
| 191 | - * @access private |
|
| 192 | - * @return string |
|
| 193 | - */ |
|
| 194 | - private function get_color_val(): string { |
|
| 195 | - |
|
| 196 | - // No notices. |
|
| 197 | - $color = ''; |
|
| 198 | - $alpha = 1; |
|
| 199 | - $rgba = ''; |
|
| 200 | - |
|
| 201 | - // Must be an array. |
|
| 202 | - if ( is_array( $this->value ) ) { |
|
| 203 | - |
|
| 204 | - // Enum array to parse values. |
|
| 205 | - foreach ( $this->value as $id => $val ) { |
|
| 206 | - |
|
| 207 | - // Sanitize alpha. |
|
| 208 | - if ( 'alpha' === $id ) { |
|
| 209 | - $alpha = is_numeric( $val ) ? $val : 1; |
|
| 210 | - } elseif ( 'color' === $id ) { |
|
| 211 | - $color = ! empty( $val ) ? $val : ''; |
|
| 212 | - } elseif ( 'rgba' === $id ) { |
|
| 213 | - $rgba = Redux_Helpers::hex2rgba( $color, $alpha ); |
|
| 214 | - } |
|
| 215 | - } |
|
| 216 | - |
|
| 217 | - // Only build rgba output if alpha ia less than 1. |
|
| 218 | - if ( $alpha < 1 && '' !== $alpha ) { |
|
| 219 | - $color = $rgba; |
|
| 220 | - } |
|
| 221 | - } |
|
| 222 | - |
|
| 223 | - return $color; |
|
| 224 | - } |
|
| 225 | - |
|
| 226 | - /** |
|
| 227 | - * Generate CSS style. |
|
| 228 | - * |
|
| 229 | - * @param string $data Field data. |
|
| 230 | - * |
|
| 231 | - * @return string |
|
| 232 | - */ |
|
| 233 | - public function css_style( $data ): string { |
|
| 234 | - return ''; |
|
| 235 | - } |
|
| 236 | - |
|
| 237 | - /** |
|
| 238 | - * Output Function. |
|
| 239 | - * Used to enqueue to the front-end |
|
| 240 | - * |
|
| 241 | - * @since 1.0.0 |
|
| 242 | - * @access public |
|
| 243 | - * |
|
| 244 | - * @param string|null|array $style css data. |
|
| 245 | - * |
|
| 246 | - * @return void |
|
| 247 | - */ |
|
| 248 | - public function output( $style = '' ) { |
|
| 249 | - if ( ! empty( $this->value ) ) { |
|
| 250 | - $mode = ( isset( $this->field['mode'] ) && ! empty( $this->field['mode'] ) ? $this->field['mode'] : 'color' ); |
|
| 251 | - |
|
| 252 | - $color_val = $this->get_color_val(); |
|
| 253 | - |
|
| 254 | - $style = $mode . ':' . $color_val . ';'; |
|
| 255 | - |
|
| 256 | - if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { |
|
| 257 | - if ( ! empty( $color_val ) ) { |
|
| 258 | - $css = Redux_Functions::parse_css( $this->field['output'], $style, $color_val ); |
|
| 259 | - $this->parent->outputCSS .= esc_attr( $css ); |
|
| 260 | - } |
|
| 261 | - } |
|
| 262 | - |
|
| 263 | - if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { |
|
| 264 | - if ( ! empty( $color_val ) ) { |
|
| 265 | - $css = Redux_Functions::parse_css( $this->field['compiler'], $style, $color_val ); |
|
| 266 | - $this->parent->compilerCSS .= esc_attr( $css ); |
|
| 267 | - } |
|
| 268 | - } |
|
| 269 | - } |
|
| 270 | - } |
|
| 271 | - |
|
| 272 | - /** |
|
| 273 | - * Enable output_variables to be generated. |
|
| 274 | - * |
|
| 275 | - * @since 4.0.3 |
|
| 276 | - * @return void |
|
| 277 | - */ |
|
| 278 | - public function output_variables() { |
|
| 279 | - // No code needed, just defining the method is enough. |
|
| 280 | - } |
|
| 281 | - } |
|
| 146 | + echo '</div>'; |
|
| 147 | + } |
|
| 148 | + |
|
| 149 | + /** |
|
| 150 | + * Enqueue Function. |
|
| 151 | + * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 152 | + * |
|
| 153 | + * @since 1.0.0 |
|
| 154 | + * @access public |
|
| 155 | + * @return void |
|
| 156 | + */ |
|
| 157 | + public function enqueue() { |
|
| 158 | + |
|
| 159 | + // Set up min files for dev_mode = false. |
|
| 160 | + $min = Redux_Functions::is_min(); |
|
| 161 | + |
|
| 162 | + // Field dependent JS. |
|
| 163 | + wp_enqueue_script( |
|
| 164 | + 'redux-field-color-rgba', |
|
| 165 | + Redux_Core::$url . 'inc/fields/color_rgba/redux-color-rgba' . $min . '.js', |
|
| 166 | + array( 'jquery', 'redux-spectrum-js', 'redux-js' ), |
|
| 167 | + $this->timestamp, |
|
| 168 | + true |
|
| 169 | + ); |
|
| 170 | + |
|
| 171 | + // Spectrum CSS. |
|
| 172 | + if ( ! wp_style_is( 'redux-spectrum-css' ) ) { |
|
| 173 | + wp_enqueue_style( 'redux-spectrum-css' ); |
|
| 174 | + } |
|
| 175 | + |
|
| 176 | + if ( $this->parent->args['dev_mode'] ) { |
|
| 177 | + wp_enqueue_style( |
|
| 178 | + 'redux-field-color-rgba', |
|
| 179 | + Redux_Core::$url . 'inc/fields/color_rgba/redux-color-rgba.css', |
|
| 180 | + array(), |
|
| 181 | + $this->timestamp |
|
| 182 | + ); |
|
| 183 | + } |
|
| 184 | + } |
|
| 185 | + |
|
| 186 | + /** |
|
| 187 | + * -> getColorVal. Returns formatted color val in hex or rgba. |
|
| 188 | + * If this field requires any scripts or css, define this function and register/enqueue the scripts/css |
|
| 189 | + * |
|
| 190 | + * @since 1.0.0 |
|
| 191 | + * @access private |
|
| 192 | + * @return string |
|
| 193 | + */ |
|
| 194 | + private function get_color_val(): string { |
|
| 195 | + |
|
| 196 | + // No notices. |
|
| 197 | + $color = ''; |
|
| 198 | + $alpha = 1; |
|
| 199 | + $rgba = ''; |
|
| 200 | + |
|
| 201 | + // Must be an array. |
|
| 202 | + if ( is_array( $this->value ) ) { |
|
| 203 | + |
|
| 204 | + // Enum array to parse values. |
|
| 205 | + foreach ( $this->value as $id => $val ) { |
|
| 206 | + |
|
| 207 | + // Sanitize alpha. |
|
| 208 | + if ( 'alpha' === $id ) { |
|
| 209 | + $alpha = is_numeric( $val ) ? $val : 1; |
|
| 210 | + } elseif ( 'color' === $id ) { |
|
| 211 | + $color = ! empty( $val ) ? $val : ''; |
|
| 212 | + } elseif ( 'rgba' === $id ) { |
|
| 213 | + $rgba = Redux_Helpers::hex2rgba( $color, $alpha ); |
|
| 214 | + } |
|
| 215 | + } |
|
| 216 | + |
|
| 217 | + // Only build rgba output if alpha ia less than 1. |
|
| 218 | + if ( $alpha < 1 && '' !== $alpha ) { |
|
| 219 | + $color = $rgba; |
|
| 220 | + } |
|
| 221 | + } |
|
| 222 | + |
|
| 223 | + return $color; |
|
| 224 | + } |
|
| 225 | + |
|
| 226 | + /** |
|
| 227 | + * Generate CSS style. |
|
| 228 | + * |
|
| 229 | + * @param string $data Field data. |
|
| 230 | + * |
|
| 231 | + * @return string |
|
| 232 | + */ |
|
| 233 | + public function css_style( $data ): string { |
|
| 234 | + return ''; |
|
| 235 | + } |
|
| 236 | + |
|
| 237 | + /** |
|
| 238 | + * Output Function. |
|
| 239 | + * Used to enqueue to the front-end |
|
| 240 | + * |
|
| 241 | + * @since 1.0.0 |
|
| 242 | + * @access public |
|
| 243 | + * |
|
| 244 | + * @param string|null|array $style css data. |
|
| 245 | + * |
|
| 246 | + * @return void |
|
| 247 | + */ |
|
| 248 | + public function output( $style = '' ) { |
|
| 249 | + if ( ! empty( $this->value ) ) { |
|
| 250 | + $mode = ( isset( $this->field['mode'] ) && ! empty( $this->field['mode'] ) ? $this->field['mode'] : 'color' ); |
|
| 251 | + |
|
| 252 | + $color_val = $this->get_color_val(); |
|
| 253 | + |
|
| 254 | + $style = $mode . ':' . $color_val . ';'; |
|
| 255 | + |
|
| 256 | + if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { |
|
| 257 | + if ( ! empty( $color_val ) ) { |
|
| 258 | + $css = Redux_Functions::parse_css( $this->field['output'], $style, $color_val ); |
|
| 259 | + $this->parent->outputCSS .= esc_attr( $css ); |
|
| 260 | + } |
|
| 261 | + } |
|
| 262 | + |
|
| 263 | + if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { |
|
| 264 | + if ( ! empty( $color_val ) ) { |
|
| 265 | + $css = Redux_Functions::parse_css( $this->field['compiler'], $style, $color_val ); |
|
| 266 | + $this->parent->compilerCSS .= esc_attr( $css ); |
|
| 267 | + } |
|
| 268 | + } |
|
| 269 | + } |
|
| 270 | + } |
|
| 271 | + |
|
| 272 | + /** |
|
| 273 | + * Enable output_variables to be generated. |
|
| 274 | + * |
|
| 275 | + * @since 4.0.3 |
|
| 276 | + * @return void |
|
| 277 | + */ |
|
| 278 | + public function output_variables() { |
|
| 279 | + // No code needed, just defining the method is enough. |
|
| 280 | + } |
|
| 281 | + } |
|
| 282 | 282 | } |
| 283 | 283 | |
| 284 | 284 | class_alias( 'Redux_Color_Rgba', 'ReduxFramework_Color_Rgba' ); |
@@ -13,25 +13,25 @@ discard block |
||
| 13 | 13 | // Don't duplicate me! |
| 14 | 14 | if ( ! class_exists( 'Redux_Date', false ) ) { |
| 15 | 15 | |
| 16 | - /** |
|
| 17 | - * Main Redux_date class |
|
| 18 | - * |
|
| 19 | - * @since 1.0.0 |
|
| 20 | - */ |
|
| 21 | - class Redux_Date extends Redux_Field { |
|
| 16 | + /** |
|
| 17 | + * Main Redux_date class |
|
| 18 | + * |
|
| 19 | + * @since 1.0.0 |
|
| 20 | + */ |
|
| 21 | + class Redux_Date extends Redux_Field { |
|
| 22 | 22 | |
| 23 | - /** |
|
| 24 | - * Field Render Function. |
|
| 25 | - * Takes the vars and outputs the HTML for the field in the settings |
|
| 26 | - * |
|
| 27 | - * @since 1.0.0 |
|
| 28 | - * @access public |
|
| 29 | - * @return void |
|
| 30 | - */ |
|
| 31 | - public function render() { |
|
| 32 | - $placeholder = $this->field['placeholder'] ?? ''; |
|
| 23 | + /** |
|
| 24 | + * Field Render Function. |
|
| 25 | + * Takes the vars and outputs the HTML for the field in the settings |
|
| 26 | + * |
|
| 27 | + * @since 1.0.0 |
|
| 28 | + * @access public |
|
| 29 | + * @return void |
|
| 30 | + */ |
|
| 31 | + public function render() { |
|
| 32 | + $placeholder = $this->field['placeholder'] ?? ''; |
|
| 33 | 33 | |
| 34 | - echo '<input |
|
| 34 | + echo '<input |
|
| 35 | 35 | data-id="' . esc_attr( $this->field['id'] ) . '" |
| 36 | 36 | type="text" |
| 37 | 37 | id="' . esc_attr( $this->field['id'] ) . '-date" |
@@ -39,35 +39,35 @@ discard block |
||
| 39 | 39 | value="' . esc_attr( $this->value ) . '" |
| 40 | 40 | placeholder="' . esc_attr( $placeholder ) . '" |
| 41 | 41 | class="redux-datepicker regular-text ' . esc_attr( $this->field['class'] ) . '" />'; |
| 42 | - } |
|
| 42 | + } |
|
| 43 | 43 | |
| 44 | - /** |
|
| 45 | - * Enqueue Function. |
|
| 46 | - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 47 | - * |
|
| 48 | - * @since 1.0.0 |
|
| 49 | - * @access public |
|
| 50 | - * @return void |
|
| 51 | - */ |
|
| 52 | - public function enqueue() { |
|
| 53 | - if ( $this->parent->args['dev_mode'] ) { |
|
| 54 | - wp_enqueue_style( |
|
| 55 | - 'redux-field-date', |
|
| 56 | - Redux_Core::$url . 'inc/fields/date/redux-date.css', |
|
| 57 | - array(), |
|
| 58 | - $this->timestamp |
|
| 59 | - ); |
|
| 60 | - } |
|
| 44 | + /** |
|
| 45 | + * Enqueue Function. |
|
| 46 | + * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 47 | + * |
|
| 48 | + * @since 1.0.0 |
|
| 49 | + * @access public |
|
| 50 | + * @return void |
|
| 51 | + */ |
|
| 52 | + public function enqueue() { |
|
| 53 | + if ( $this->parent->args['dev_mode'] ) { |
|
| 54 | + wp_enqueue_style( |
|
| 55 | + 'redux-field-date', |
|
| 56 | + Redux_Core::$url . 'inc/fields/date/redux-date.css', |
|
| 57 | + array(), |
|
| 58 | + $this->timestamp |
|
| 59 | + ); |
|
| 60 | + } |
|
| 61 | 61 | |
| 62 | - wp_enqueue_script( |
|
| 63 | - 'redux-field-date', |
|
| 64 | - Redux_Core::$url . 'inc/fields/date/redux-date' . Redux_Functions::is_min() . '.js', |
|
| 65 | - array( 'jquery', 'jquery-ui-core', 'jquery-ui-datepicker', 'redux-js' ), |
|
| 66 | - $this->timestamp, |
|
| 67 | - true |
|
| 68 | - ); |
|
| 69 | - } |
|
| 70 | - } |
|
| 62 | + wp_enqueue_script( |
|
| 63 | + 'redux-field-date', |
|
| 64 | + Redux_Core::$url . 'inc/fields/date/redux-date' . Redux_Functions::is_min() . '.js', |
|
| 65 | + array( 'jquery', 'jquery-ui-core', 'jquery-ui-datepicker', 'redux-js' ), |
|
| 66 | + $this->timestamp, |
|
| 67 | + true |
|
| 68 | + ); |
|
| 69 | + } |
|
| 70 | + } |
|
| 71 | 71 | } |
| 72 | 72 | |
| 73 | 73 | class_alias( 'Redux_Date', 'ReduxFramework_Date' ); |
@@ -11,206 +11,206 @@ |
||
| 11 | 11 | |
| 12 | 12 | if ( ! class_exists( 'Redux_Spinner', false ) ) { |
| 13 | 13 | |
| 14 | - /** |
|
| 15 | - * Class Redux_Spinner |
|
| 16 | - */ |
|
| 17 | - class Redux_Spinner extends Redux_Field { |
|
| 18 | - |
|
| 19 | - /** |
|
| 20 | - * Set field and value defaults. |
|
| 21 | - */ |
|
| 22 | - public function set_defaults() { |
|
| 23 | - $params = array( |
|
| 24 | - 'min' => 0, |
|
| 25 | - 'max' => 1, |
|
| 26 | - 'step' => 1, |
|
| 27 | - 'default' => '', |
|
| 28 | - 'edit' => true, |
|
| 29 | - 'plus' => '+', |
|
| 30 | - 'minus' => '-', |
|
| 31 | - 'format' => '', |
|
| 32 | - 'prefix' => '', |
|
| 33 | - 'suffix' => '', |
|
| 34 | - 'point' => '.', |
|
| 35 | - 'places' => null, |
|
| 36 | - ); |
|
| 37 | - |
|
| 38 | - $this->field = wp_parse_args( $this->field, $params ); |
|
| 39 | - } |
|
| 40 | - |
|
| 41 | - /** |
|
| 42 | - * Field Render Function. |
|
| 43 | - * Takes the vars and outputs the HTML for the field in the settings |
|
| 44 | - * |
|
| 45 | - * @since ReduxFramework 3.0.0 |
|
| 46 | - */ |
|
| 47 | - public function render() { |
|
| 48 | - $data_string = ''; |
|
| 49 | - |
|
| 50 | - foreach ( $this->field as $key => $val ) { |
|
| 51 | - if ( in_array( $key, array( 'min', 'max', 'step', 'default', 'plus', 'minus', 'prefix', 'suffix', 'point', 'places' ), true ) ) { |
|
| 52 | - $data_string .= ' data-' . esc_attr( $key ) . '="' . esc_attr( $val ) . '" '; |
|
| 53 | - } |
|
| 54 | - } |
|
| 55 | - |
|
| 56 | - $data_string .= ' data-val=' . $this->value; |
|
| 57 | - |
|
| 58 | - // Don't allow input edit if there's a step. |
|
| 59 | - $readonly = ''; |
|
| 60 | - if ( isset( $this->field['edit'] ) && false === $this->field['edit'] ) { |
|
| 61 | - $readonly = ' readonly="readonly"'; |
|
| 62 | - } |
|
| 63 | - |
|
| 64 | - echo '<div id="' . esc_attr( $this->field['id'] ) . '-spinner" class="redux_spinner" rel="' . esc_attr( $this->field['id'] ) . '">'; |
|
| 65 | - |
|
| 66 | - echo '<input type="text" ' . $data_string . ' name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '" id="' . esc_attr( $this->field['id'] ) . '" value="' . esc_attr( $this->value ) . '" class="mini spinner-input ' . esc_attr( $this->field['class'] ) . '"' . $readonly . '/>'; // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 67 | - |
|
| 68 | - echo '</div>'; |
|
| 69 | - } |
|
| 70 | - |
|
| 71 | - /** |
|
| 72 | - * Clean the field data to the fields defaults given the parameters. |
|
| 73 | - * |
|
| 74 | - * @since Redux_Framework 3.1.1 |
|
| 75 | - */ |
|
| 76 | - private function clean() { |
|
| 77 | - if ( empty( $this->field['min'] ) ) { |
|
| 78 | - $this->field['min'] = 0; |
|
| 79 | - } else { |
|
| 80 | - $this->field['min'] = intval( $this->field['min'] ); |
|
| 81 | - } |
|
| 82 | - |
|
| 83 | - if ( empty( $this->field['max'] ) ) { |
|
| 84 | - $this->field['max'] = $this->field['min'] + 1; |
|
| 85 | - } else { |
|
| 86 | - $this->field['max'] = intval( $this->field['max'] ); |
|
| 87 | - } |
|
| 88 | - |
|
| 89 | - if ( empty( $this->field['step'] ) || $this->field['step'] > $this->field['max'] ) { |
|
| 90 | - $this->field['step'] = 1; |
|
| 91 | - } else { |
|
| 92 | - $this->field['step'] = intval( $this->field['step'] ); |
|
| 93 | - } |
|
| 94 | - |
|
| 95 | - if ( empty( $this->value ) && ! empty( $this->field['default'] ) && $this->field['min'] >= 1 ) { |
|
| 96 | - $this->value = intval( $this->field['default'] ); |
|
| 97 | - } |
|
| 98 | - |
|
| 99 | - if ( empty( $this->value ) && $this->field['min'] >= 1 ) { |
|
| 100 | - $this->value = $this->field['min']; |
|
| 101 | - } |
|
| 102 | - |
|
| 103 | - if ( empty( $this->value ) ) { |
|
| 104 | - $this->value = 0; |
|
| 105 | - } |
|
| 106 | - |
|
| 107 | - // Extra Validation. |
|
| 108 | - if ( $this->value < $this->field['min'] ) { |
|
| 109 | - $this->value = $this->field['min']; |
|
| 110 | - } elseif ( $this->value > $this->field['max'] ) { |
|
| 111 | - $this->value = $this->field['max']; |
|
| 112 | - } |
|
| 113 | - } |
|
| 114 | - |
|
| 115 | - /** |
|
| 116 | - * Enqueue Function. |
|
| 117 | - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 118 | - * |
|
| 119 | - * @since ReduxFramework 3.0.0 |
|
| 120 | - */ |
|
| 121 | - public function enqueue() { |
|
| 122 | - wp_enqueue_script( |
|
| 123 | - 'redux-field-spinner-custom', |
|
| 124 | - Redux_Core::$url . 'inc/fields/spinner/vendor/jquery.ui.spinner' . Redux_Functions::is_min() . '.js', |
|
| 125 | - array( 'jquery', 'redux-js' ), |
|
| 126 | - $this->timestamp, |
|
| 127 | - true |
|
| 128 | - ); |
|
| 129 | - |
|
| 130 | - wp_enqueue_script( |
|
| 131 | - 'redux-field-spinner', |
|
| 132 | - Redux_Core::$url . 'inc/fields/spinner/redux-spinner' . Redux_Functions::is_min() . '.js', |
|
| 133 | - array( 'jquery', 'redux-field-spinner-custom', 'jquery-ui-core', 'jquery-ui-dialog', 'redux-js' ), |
|
| 134 | - $this->timestamp, |
|
| 135 | - true |
|
| 136 | - ); |
|
| 137 | - |
|
| 138 | - if ( $this->parent->args['dev_mode'] ) { |
|
| 139 | - wp_enqueue_style( |
|
| 140 | - 'redux-field-spinner', |
|
| 141 | - Redux_Core::$url . 'inc/fields/spinner/redux-spinner.css', |
|
| 142 | - array(), |
|
| 143 | - $this->timestamp |
|
| 144 | - ); |
|
| 145 | - } |
|
| 146 | - } |
|
| 147 | - |
|
| 148 | - /** |
|
| 149 | - * CSS/compiler output. |
|
| 150 | - * |
|
| 151 | - * @param string|null|array $style CSS styles. |
|
| 152 | - */ |
|
| 153 | - public function output( $style = '' ) { |
|
| 154 | - if ( ! empty( $this->value ) ) { |
|
| 155 | - if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { |
|
| 156 | - $css = $this->parse_css( $this->value, $this->field['output'] ); |
|
| 157 | - $this->parent->outputCSS .= esc_attr( $css ); |
|
| 158 | - } |
|
| 159 | - |
|
| 160 | - if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { |
|
| 161 | - $css = $this->parse_css( $this->value, $this->field['compiler'] ); |
|
| 162 | - $this->parent->compilerCSS .= esc_attr( $css ); |
|
| 163 | - } |
|
| 164 | - } |
|
| 165 | - } |
|
| 166 | - |
|
| 167 | - /** |
|
| 168 | - * Compile CSS data for output. |
|
| 169 | - * |
|
| 170 | - * @param mixed $value Value. |
|
| 171 | - * @param mixed $output . |
|
| 172 | - * |
|
| 173 | - * @return string |
|
| 174 | - */ |
|
| 175 | - private function parse_css( $value, $output ): string { |
|
| 176 | - // No notices. |
|
| 177 | - $css = ''; |
|
| 178 | - |
|
| 179 | - $unit = $this->field['output_unit'] ?? 'px'; |
|
| 180 | - |
|
| 181 | - // Must be an array. |
|
| 182 | - if ( is_array( $output ) ) { |
|
| 183 | - foreach ( $output as $selector => $mode ) { |
|
| 184 | - if ( '' !== $mode && '' !== $selector ) { |
|
| 185 | - $css .= $selector . '{' . $mode . ':' . $value . $unit . ';}'; |
|
| 186 | - } |
|
| 187 | - } |
|
| 188 | - } |
|
| 189 | - |
|
| 190 | - return $css; |
|
| 191 | - } |
|
| 192 | - |
|
| 193 | - /** |
|
| 194 | - * Generate CSS style (unused, but needed). |
|
| 195 | - * |
|
| 196 | - * @param string $data Field data. |
|
| 197 | - * |
|
| 198 | - * @return string |
|
| 199 | - */ |
|
| 200 | - public function css_style( $data ): string { |
|
| 201 | - return ''; |
|
| 202 | - } |
|
| 203 | - |
|
| 204 | - /** |
|
| 205 | - * Enable output_variables to be generated. |
|
| 206 | - * |
|
| 207 | - * @since 4.0.3 |
|
| 208 | - * @return void |
|
| 209 | - */ |
|
| 210 | - public function output_variables() { |
|
| 211 | - // No code needed, just defining the method is enough. |
|
| 212 | - } |
|
| 213 | - } |
|
| 14 | + /** |
|
| 15 | + * Class Redux_Spinner |
|
| 16 | + */ |
|
| 17 | + class Redux_Spinner extends Redux_Field { |
|
| 18 | + |
|
| 19 | + /** |
|
| 20 | + * Set field and value defaults. |
|
| 21 | + */ |
|
| 22 | + public function set_defaults() { |
|
| 23 | + $params = array( |
|
| 24 | + 'min' => 0, |
|
| 25 | + 'max' => 1, |
|
| 26 | + 'step' => 1, |
|
| 27 | + 'default' => '', |
|
| 28 | + 'edit' => true, |
|
| 29 | + 'plus' => '+', |
|
| 30 | + 'minus' => '-', |
|
| 31 | + 'format' => '', |
|
| 32 | + 'prefix' => '', |
|
| 33 | + 'suffix' => '', |
|
| 34 | + 'point' => '.', |
|
| 35 | + 'places' => null, |
|
| 36 | + ); |
|
| 37 | + |
|
| 38 | + $this->field = wp_parse_args( $this->field, $params ); |
|
| 39 | + } |
|
| 40 | + |
|
| 41 | + /** |
|
| 42 | + * Field Render Function. |
|
| 43 | + * Takes the vars and outputs the HTML for the field in the settings |
|
| 44 | + * |
|
| 45 | + * @since ReduxFramework 3.0.0 |
|
| 46 | + */ |
|
| 47 | + public function render() { |
|
| 48 | + $data_string = ''; |
|
| 49 | + |
|
| 50 | + foreach ( $this->field as $key => $val ) { |
|
| 51 | + if ( in_array( $key, array( 'min', 'max', 'step', 'default', 'plus', 'minus', 'prefix', 'suffix', 'point', 'places' ), true ) ) { |
|
| 52 | + $data_string .= ' data-' . esc_attr( $key ) . '="' . esc_attr( $val ) . '" '; |
|
| 53 | + } |
|
| 54 | + } |
|
| 55 | + |
|
| 56 | + $data_string .= ' data-val=' . $this->value; |
|
| 57 | + |
|
| 58 | + // Don't allow input edit if there's a step. |
|
| 59 | + $readonly = ''; |
|
| 60 | + if ( isset( $this->field['edit'] ) && false === $this->field['edit'] ) { |
|
| 61 | + $readonly = ' readonly="readonly"'; |
|
| 62 | + } |
|
| 63 | + |
|
| 64 | + echo '<div id="' . esc_attr( $this->field['id'] ) . '-spinner" class="redux_spinner" rel="' . esc_attr( $this->field['id'] ) . '">'; |
|
| 65 | + |
|
| 66 | + echo '<input type="text" ' . $data_string . ' name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '" id="' . esc_attr( $this->field['id'] ) . '" value="' . esc_attr( $this->value ) . '" class="mini spinner-input ' . esc_attr( $this->field['class'] ) . '"' . $readonly . '/>'; // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 67 | + |
|
| 68 | + echo '</div>'; |
|
| 69 | + } |
|
| 70 | + |
|
| 71 | + /** |
|
| 72 | + * Clean the field data to the fields defaults given the parameters. |
|
| 73 | + * |
|
| 74 | + * @since Redux_Framework 3.1.1 |
|
| 75 | + */ |
|
| 76 | + private function clean() { |
|
| 77 | + if ( empty( $this->field['min'] ) ) { |
|
| 78 | + $this->field['min'] = 0; |
|
| 79 | + } else { |
|
| 80 | + $this->field['min'] = intval( $this->field['min'] ); |
|
| 81 | + } |
|
| 82 | + |
|
| 83 | + if ( empty( $this->field['max'] ) ) { |
|
| 84 | + $this->field['max'] = $this->field['min'] + 1; |
|
| 85 | + } else { |
|
| 86 | + $this->field['max'] = intval( $this->field['max'] ); |
|
| 87 | + } |
|
| 88 | + |
|
| 89 | + if ( empty( $this->field['step'] ) || $this->field['step'] > $this->field['max'] ) { |
|
| 90 | + $this->field['step'] = 1; |
|
| 91 | + } else { |
|
| 92 | + $this->field['step'] = intval( $this->field['step'] ); |
|
| 93 | + } |
|
| 94 | + |
|
| 95 | + if ( empty( $this->value ) && ! empty( $this->field['default'] ) && $this->field['min'] >= 1 ) { |
|
| 96 | + $this->value = intval( $this->field['default'] ); |
|
| 97 | + } |
|
| 98 | + |
|
| 99 | + if ( empty( $this->value ) && $this->field['min'] >= 1 ) { |
|
| 100 | + $this->value = $this->field['min']; |
|
| 101 | + } |
|
| 102 | + |
|
| 103 | + if ( empty( $this->value ) ) { |
|
| 104 | + $this->value = 0; |
|
| 105 | + } |
|
| 106 | + |
|
| 107 | + // Extra Validation. |
|
| 108 | + if ( $this->value < $this->field['min'] ) { |
|
| 109 | + $this->value = $this->field['min']; |
|
| 110 | + } elseif ( $this->value > $this->field['max'] ) { |
|
| 111 | + $this->value = $this->field['max']; |
|
| 112 | + } |
|
| 113 | + } |
|
| 114 | + |
|
| 115 | + /** |
|
| 116 | + * Enqueue Function. |
|
| 117 | + * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 118 | + * |
|
| 119 | + * @since ReduxFramework 3.0.0 |
|
| 120 | + */ |
|
| 121 | + public function enqueue() { |
|
| 122 | + wp_enqueue_script( |
|
| 123 | + 'redux-field-spinner-custom', |
|
| 124 | + Redux_Core::$url . 'inc/fields/spinner/vendor/jquery.ui.spinner' . Redux_Functions::is_min() . '.js', |
|
| 125 | + array( 'jquery', 'redux-js' ), |
|
| 126 | + $this->timestamp, |
|
| 127 | + true |
|
| 128 | + ); |
|
| 129 | + |
|
| 130 | + wp_enqueue_script( |
|
| 131 | + 'redux-field-spinner', |
|
| 132 | + Redux_Core::$url . 'inc/fields/spinner/redux-spinner' . Redux_Functions::is_min() . '.js', |
|
| 133 | + array( 'jquery', 'redux-field-spinner-custom', 'jquery-ui-core', 'jquery-ui-dialog', 'redux-js' ), |
|
| 134 | + $this->timestamp, |
|
| 135 | + true |
|
| 136 | + ); |
|
| 137 | + |
|
| 138 | + if ( $this->parent->args['dev_mode'] ) { |
|
| 139 | + wp_enqueue_style( |
|
| 140 | + 'redux-field-spinner', |
|
| 141 | + Redux_Core::$url . 'inc/fields/spinner/redux-spinner.css', |
|
| 142 | + array(), |
|
| 143 | + $this->timestamp |
|
| 144 | + ); |
|
| 145 | + } |
|
| 146 | + } |
|
| 147 | + |
|
| 148 | + /** |
|
| 149 | + * CSS/compiler output. |
|
| 150 | + * |
|
| 151 | + * @param string|null|array $style CSS styles. |
|
| 152 | + */ |
|
| 153 | + public function output( $style = '' ) { |
|
| 154 | + if ( ! empty( $this->value ) ) { |
|
| 155 | + if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { |
|
| 156 | + $css = $this->parse_css( $this->value, $this->field['output'] ); |
|
| 157 | + $this->parent->outputCSS .= esc_attr( $css ); |
|
| 158 | + } |
|
| 159 | + |
|
| 160 | + if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { |
|
| 161 | + $css = $this->parse_css( $this->value, $this->field['compiler'] ); |
|
| 162 | + $this->parent->compilerCSS .= esc_attr( $css ); |
|
| 163 | + } |
|
| 164 | + } |
|
| 165 | + } |
|
| 166 | + |
|
| 167 | + /** |
|
| 168 | + * Compile CSS data for output. |
|
| 169 | + * |
|
| 170 | + * @param mixed $value Value. |
|
| 171 | + * @param mixed $output . |
|
| 172 | + * |
|
| 173 | + * @return string |
|
| 174 | + */ |
|
| 175 | + private function parse_css( $value, $output ): string { |
|
| 176 | + // No notices. |
|
| 177 | + $css = ''; |
|
| 178 | + |
|
| 179 | + $unit = $this->field['output_unit'] ?? 'px'; |
|
| 180 | + |
|
| 181 | + // Must be an array. |
|
| 182 | + if ( is_array( $output ) ) { |
|
| 183 | + foreach ( $output as $selector => $mode ) { |
|
| 184 | + if ( '' !== $mode && '' !== $selector ) { |
|
| 185 | + $css .= $selector . '{' . $mode . ':' . $value . $unit . ';}'; |
|
| 186 | + } |
|
| 187 | + } |
|
| 188 | + } |
|
| 189 | + |
|
| 190 | + return $css; |
|
| 191 | + } |
|
| 192 | + |
|
| 193 | + /** |
|
| 194 | + * Generate CSS style (unused, but needed). |
|
| 195 | + * |
|
| 196 | + * @param string $data Field data. |
|
| 197 | + * |
|
| 198 | + * @return string |
|
| 199 | + */ |
|
| 200 | + public function css_style( $data ): string { |
|
| 201 | + return ''; |
|
| 202 | + } |
|
| 203 | + |
|
| 204 | + /** |
|
| 205 | + * Enable output_variables to be generated. |
|
| 206 | + * |
|
| 207 | + * @since 4.0.3 |
|
| 208 | + * @return void |
|
| 209 | + */ |
|
| 210 | + public function output_variables() { |
|
| 211 | + // No code needed, just defining the method is enough. |
|
| 212 | + } |
|
| 213 | + } |
|
| 214 | 214 | } |
| 215 | 215 | |
| 216 | 216 | class_alias( 'Redux_Spinner', 'ReduxFramework_Spinner' ); |
@@ -12,53 +12,53 @@ |
||
| 12 | 12 | |
| 13 | 13 | if ( ! class_exists( 'Redux_Radio', false ) ) { |
| 14 | 14 | |
| 15 | - /** |
|
| 16 | - * Class Redux_Radio |
|
| 17 | - */ |
|
| 18 | - class Redux_Radio extends Redux_Field { |
|
| 15 | + /** |
|
| 16 | + * Class Redux_Radio |
|
| 17 | + */ |
|
| 18 | + class Redux_Radio extends Redux_Field { |
|
| 19 | 19 | |
| 20 | - /** |
|
| 21 | - * Field Render Function. |
|
| 22 | - * Takes the vars and outputs the HTML for the field in the settings |
|
| 23 | - * |
|
| 24 | - * @since ReduxFramework 1.0.0 |
|
| 25 | - */ |
|
| 26 | - public function render() { |
|
| 27 | - if ( ! empty( $this->field['data'] ) && empty( $this->field['options'] ) ) { |
|
| 28 | - if ( empty( $this->field['args'] ) ) { |
|
| 29 | - $this->field['args'] = array(); |
|
| 30 | - } |
|
| 20 | + /** |
|
| 21 | + * Field Render Function. |
|
| 22 | + * Takes the vars and outputs the HTML for the field in the settings |
|
| 23 | + * |
|
| 24 | + * @since ReduxFramework 1.0.0 |
|
| 25 | + */ |
|
| 26 | + public function render() { |
|
| 27 | + if ( ! empty( $this->field['data'] ) && empty( $this->field['options'] ) ) { |
|
| 28 | + if ( empty( $this->field['args'] ) ) { |
|
| 29 | + $this->field['args'] = array(); |
|
| 30 | + } |
|
| 31 | 31 | |
| 32 | - if ( is_array( $this->field['data'] ) ) { |
|
| 33 | - $this->field['options'] = $this->field['data']; |
|
| 34 | - } else { |
|
| 35 | - $this->field['options'] = $this->parent->wordpress_data->get( $this->field['data'], $this->field['args'], $this->parent->args['opt_name'], $this->value ); |
|
| 36 | - } |
|
| 37 | - } |
|
| 32 | + if ( is_array( $this->field['data'] ) ) { |
|
| 33 | + $this->field['options'] = $this->field['data']; |
|
| 34 | + } else { |
|
| 35 | + $this->field['options'] = $this->parent->wordpress_data->get( $this->field['data'], $this->field['args'], $this->parent->args['opt_name'], $this->value ); |
|
| 36 | + } |
|
| 37 | + } |
|
| 38 | 38 | |
| 39 | - $this->field['data_class'] = ( isset( $this->field['multi_layout'] ) ) ? 'data-' . $this->field['multi_layout'] : 'data-full'; |
|
| 39 | + $this->field['data_class'] = ( isset( $this->field['multi_layout'] ) ) ? 'data-' . $this->field['multi_layout'] : 'data-full'; |
|
| 40 | 40 | |
| 41 | - if ( isset( $this->field['options'] ) && ! empty( $this->field['options'] ) ) { |
|
| 42 | - echo '<ul class="' . esc_attr( $this->field['data_class'] ) . '">'; |
|
| 41 | + if ( isset( $this->field['options'] ) && ! empty( $this->field['options'] ) ) { |
|
| 42 | + echo '<ul class="' . esc_attr( $this->field['data_class'] ) . '">'; |
|
| 43 | 43 | |
| 44 | - foreach ( $this->field['options'] as $k => $v ) { |
|
| 45 | - echo '<li>'; |
|
| 46 | - echo '<label for="' . esc_attr( $this->field['id'] . '_' . array_search( $k, array_keys( $this->field['options'] ), true ) ) . '">'; |
|
| 47 | - echo '<input |
|
| 44 | + foreach ( $this->field['options'] as $k => $v ) { |
|
| 45 | + echo '<li>'; |
|
| 46 | + echo '<label for="' . esc_attr( $this->field['id'] . '_' . array_search( $k, array_keys( $this->field['options'] ), true ) ) . '">'; |
|
| 47 | + echo '<input |
|
| 48 | 48 | type="radio" |
| 49 | 49 | class="radio ' . esc_attr( $this->field['class'] ) . '" |
| 50 | 50 | id="' . esc_attr( $this->field['id'] . '_' . array_search( $k, array_keys( $this->field['options'] ), true ) ) . '" |
| 51 | 51 | name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '" |
| 52 | 52 | value="' . esc_attr( $k ) . '" ' . ( ! is_array( $this->value ) ? checked( $this->value, $k, false ) : '' ) . '/>'; |
| 53 | - echo ' <span>' . wp_kses_post( $v ) . '</span>'; |
|
| 54 | - echo '</label>'; |
|
| 55 | - echo '</li>'; |
|
| 56 | - } |
|
| 53 | + echo ' <span>' . wp_kses_post( $v ) . '</span>'; |
|
| 54 | + echo '</label>'; |
|
| 55 | + echo '</li>'; |
|
| 56 | + } |
|
| 57 | 57 | |
| 58 | - echo '</ul>'; |
|
| 59 | - } |
|
| 60 | - } |
|
| 61 | - } |
|
| 58 | + echo '</ul>'; |
|
| 59 | + } |
|
| 60 | + } |
|
| 61 | + } |
|
| 62 | 62 | } |
| 63 | 63 | |
| 64 | 64 | class_alias( 'Redux_Radio', 'ReduxFramework_Radio' ); |
@@ -12,94 +12,94 @@ |
||
| 12 | 12 | |
| 13 | 13 | if ( ! class_exists( 'Redux_Text', false ) ) { |
| 14 | 14 | |
| 15 | - /** |
|
| 16 | - * Class Redux_Text |
|
| 17 | - */ |
|
| 18 | - class Redux_Text extends Redux_Field { |
|
| 19 | - |
|
| 20 | - /** |
|
| 21 | - * Field Render Function. |
|
| 22 | - * Takes the vars and outputs the HTML for the field in the settings |
|
| 23 | - * |
|
| 24 | - * @since ReduxFramework 1.0.0 |
|
| 25 | - */ |
|
| 26 | - public function render() { |
|
| 27 | - if ( ! empty( $this->field['data'] ) && empty( $this->field['options'] ) ) { |
|
| 28 | - if ( empty( $this->field['args'] ) ) { |
|
| 29 | - $this->field['args'] = array(); |
|
| 30 | - } |
|
| 31 | - |
|
| 32 | - $this->field['options'] = $this->parent->wordpress_data->get( $this->field['data'], $this->field['args'], $this->parent->args['opt_name'], $this->value ); |
|
| 33 | - $this->field['class'] .= ' hasOptions '; |
|
| 34 | - } |
|
| 35 | - |
|
| 36 | - if ( empty( $this->value ) && ! empty( $this->field['data'] ) && ! empty( $this->field['options'] ) ) { |
|
| 37 | - $this->value = $this->field['options']; |
|
| 38 | - } |
|
| 39 | - |
|
| 40 | - $qtip_title = isset( $this->field['text_hint']['title'] ) ? 'qtip-title="' . $this->field['text_hint']['title'] . '" ' : ''; |
|
| 41 | - $qtip_text = isset( $this->field['text_hint']['content'] ) ? 'qtip-content="' . $this->field['text_hint']['content'] . '" ' : ''; |
|
| 42 | - |
|
| 43 | - $readonly = ( isset( $this->field['readonly'] ) && $this->field['readonly'] ) ? ' readonly="readonly"' : ''; |
|
| 44 | - $autocomplete = ( isset( $this->field['autocomplete'] ) && false === $this->field['autocomplete'] ) ? ' autocomplete="off"' : ''; |
|
| 45 | - |
|
| 46 | - if ( isset( $this->field['options'] ) && ! empty( $this->field['options'] ) ) { |
|
| 47 | - $placeholder = ''; |
|
| 48 | - |
|
| 49 | - if ( isset( $this->field['placeholder'] ) ) { |
|
| 50 | - $placeholder = $this->field['placeholder']; |
|
| 51 | - } |
|
| 52 | - |
|
| 53 | - foreach ( $this->field['options'] as $k => $v ) { |
|
| 54 | - if ( ! empty( $placeholder ) ) { |
|
| 55 | - $placeholder = ( is_array( $this->field['placeholder'] ) && isset( $this->field['placeholder'][ $k ] ) ) ? ' placeholder="' . esc_attr( $this->field['placeholder'][ $k ] ) . '" ' : ''; |
|
| 56 | - } |
|
| 57 | - |
|
| 58 | - echo '<div class="input_wrapper">'; |
|
| 59 | - echo '<label for="' . esc_attr( $this->field['id'] . '-text-' . $k ) . '">' . esc_html( $v ) . '</label> '; |
|
| 60 | - |
|
| 61 | - $value = $this->value[ $k ] ?? ''; |
|
| 62 | - $value = ! empty( $this->value[ $k ] ) ? $this->value[ $k ] : ''; |
|
| 63 | - |
|
| 64 | - // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 65 | - echo '<input type="text" id="' . esc_attr( $this->field['id'] . '-text-' . $k ) . '" ' . esc_attr( $qtip_title ) . esc_attr( $qtip_text ) . ' name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] . '[' . esc_attr( $k ) ) . ']" ' . $placeholder . ' value="' . esc_attr( $value ) . '" class="regular-text ' . esc_attr( $this->field['class'] ) . '" ' . esc_html( $readonly ) . esc_html( $autocomplete ) . '/><br />'; |
|
| 66 | - echo '</div>'; |
|
| 67 | - } |
|
| 68 | - } else { |
|
| 69 | - $placeholder = ( isset( $this->field['placeholder'] ) && ! is_array( $this->field['placeholder'] ) ) ? ' placeholder="' . esc_attr( $this->field['placeholder'] ) . '" ' : ''; |
|
| 70 | - |
|
| 71 | - // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 72 | - echo '<input ' . esc_attr( $qtip_title ) . esc_attr( $qtip_text ) . 'type="text" id="' . esc_attr( $this->field['id'] ) . '" name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '" ' . $placeholder . 'value="' . esc_attr( $this->value ) . '" class="regular-text ' . esc_attr( $this->field['class'] ) . '"' . esc_html( $readonly ) . esc_html( $autocomplete ) . ' />'; |
|
| 73 | - } |
|
| 74 | - } |
|
| 75 | - |
|
| 76 | - /** |
|
| 77 | - * Enqueue Function. |
|
| 78 | - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 79 | - * |
|
| 80 | - * @since ReduxFramework 3.0.0 |
|
| 81 | - */ |
|
| 82 | - public function enqueue() { |
|
| 83 | - if ( $this->parent->args['dev_mode'] ) { |
|
| 84 | - wp_enqueue_style( |
|
| 85 | - 'redux-field-text', |
|
| 86 | - Redux_Core::$url . 'inc/fields/text/redux-text.css', |
|
| 87 | - array(), |
|
| 88 | - $this->timestamp |
|
| 89 | - ); |
|
| 90 | - } |
|
| 91 | - } |
|
| 92 | - |
|
| 93 | - /** |
|
| 94 | - * Enable output_variables to be generated. |
|
| 95 | - * |
|
| 96 | - * @since 4.0.3 |
|
| 97 | - * @return void |
|
| 98 | - */ |
|
| 99 | - public function output_variables() { |
|
| 100 | - // No code needed, just defining the method is enough. |
|
| 101 | - } |
|
| 102 | - } |
|
| 15 | + /** |
|
| 16 | + * Class Redux_Text |
|
| 17 | + */ |
|
| 18 | + class Redux_Text extends Redux_Field { |
|
| 19 | + |
|
| 20 | + /** |
|
| 21 | + * Field Render Function. |
|
| 22 | + * Takes the vars and outputs the HTML for the field in the settings |
|
| 23 | + * |
|
| 24 | + * @since ReduxFramework 1.0.0 |
|
| 25 | + */ |
|
| 26 | + public function render() { |
|
| 27 | + if ( ! empty( $this->field['data'] ) && empty( $this->field['options'] ) ) { |
|
| 28 | + if ( empty( $this->field['args'] ) ) { |
|
| 29 | + $this->field['args'] = array(); |
|
| 30 | + } |
|
| 31 | + |
|
| 32 | + $this->field['options'] = $this->parent->wordpress_data->get( $this->field['data'], $this->field['args'], $this->parent->args['opt_name'], $this->value ); |
|
| 33 | + $this->field['class'] .= ' hasOptions '; |
|
| 34 | + } |
|
| 35 | + |
|
| 36 | + if ( empty( $this->value ) && ! empty( $this->field['data'] ) && ! empty( $this->field['options'] ) ) { |
|
| 37 | + $this->value = $this->field['options']; |
|
| 38 | + } |
|
| 39 | + |
|
| 40 | + $qtip_title = isset( $this->field['text_hint']['title'] ) ? 'qtip-title="' . $this->field['text_hint']['title'] . '" ' : ''; |
|
| 41 | + $qtip_text = isset( $this->field['text_hint']['content'] ) ? 'qtip-content="' . $this->field['text_hint']['content'] . '" ' : ''; |
|
| 42 | + |
|
| 43 | + $readonly = ( isset( $this->field['readonly'] ) && $this->field['readonly'] ) ? ' readonly="readonly"' : ''; |
|
| 44 | + $autocomplete = ( isset( $this->field['autocomplete'] ) && false === $this->field['autocomplete'] ) ? ' autocomplete="off"' : ''; |
|
| 45 | + |
|
| 46 | + if ( isset( $this->field['options'] ) && ! empty( $this->field['options'] ) ) { |
|
| 47 | + $placeholder = ''; |
|
| 48 | + |
|
| 49 | + if ( isset( $this->field['placeholder'] ) ) { |
|
| 50 | + $placeholder = $this->field['placeholder']; |
|
| 51 | + } |
|
| 52 | + |
|
| 53 | + foreach ( $this->field['options'] as $k => $v ) { |
|
| 54 | + if ( ! empty( $placeholder ) ) { |
|
| 55 | + $placeholder = ( is_array( $this->field['placeholder'] ) && isset( $this->field['placeholder'][ $k ] ) ) ? ' placeholder="' . esc_attr( $this->field['placeholder'][ $k ] ) . '" ' : ''; |
|
| 56 | + } |
|
| 57 | + |
|
| 58 | + echo '<div class="input_wrapper">'; |
|
| 59 | + echo '<label for="' . esc_attr( $this->field['id'] . '-text-' . $k ) . '">' . esc_html( $v ) . '</label> '; |
|
| 60 | + |
|
| 61 | + $value = $this->value[ $k ] ?? ''; |
|
| 62 | + $value = ! empty( $this->value[ $k ] ) ? $this->value[ $k ] : ''; |
|
| 63 | + |
|
| 64 | + // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 65 | + echo '<input type="text" id="' . esc_attr( $this->field['id'] . '-text-' . $k ) . '" ' . esc_attr( $qtip_title ) . esc_attr( $qtip_text ) . ' name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] . '[' . esc_attr( $k ) ) . ']" ' . $placeholder . ' value="' . esc_attr( $value ) . '" class="regular-text ' . esc_attr( $this->field['class'] ) . '" ' . esc_html( $readonly ) . esc_html( $autocomplete ) . '/><br />'; |
|
| 66 | + echo '</div>'; |
|
| 67 | + } |
|
| 68 | + } else { |
|
| 69 | + $placeholder = ( isset( $this->field['placeholder'] ) && ! is_array( $this->field['placeholder'] ) ) ? ' placeholder="' . esc_attr( $this->field['placeholder'] ) . '" ' : ''; |
|
| 70 | + |
|
| 71 | + // phpcs:ignore WordPress.Security.EscapeOutput |
|
| 72 | + echo '<input ' . esc_attr( $qtip_title ) . esc_attr( $qtip_text ) . 'type="text" id="' . esc_attr( $this->field['id'] ) . '" name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] ) . '" ' . $placeholder . 'value="' . esc_attr( $this->value ) . '" class="regular-text ' . esc_attr( $this->field['class'] ) . '"' . esc_html( $readonly ) . esc_html( $autocomplete ) . ' />'; |
|
| 73 | + } |
|
| 74 | + } |
|
| 75 | + |
|
| 76 | + /** |
|
| 77 | + * Enqueue Function. |
|
| 78 | + * If this field requires any scripts, or css define this function and register/enqueue the scripts/css |
|
| 79 | + * |
|
| 80 | + * @since ReduxFramework 3.0.0 |
|
| 81 | + */ |
|
| 82 | + public function enqueue() { |
|
| 83 | + if ( $this->parent->args['dev_mode'] ) { |
|
| 84 | + wp_enqueue_style( |
|
| 85 | + 'redux-field-text', |
|
| 86 | + Redux_Core::$url . 'inc/fields/text/redux-text.css', |
|
| 87 | + array(), |
|
| 88 | + $this->timestamp |
|
| 89 | + ); |
|
| 90 | + } |
|
| 91 | + } |
|
| 92 | + |
|
| 93 | + /** |
|
| 94 | + * Enable output_variables to be generated. |
|
| 95 | + * |
|
| 96 | + * @since 4.0.3 |
|
| 97 | + * @return void |
|
| 98 | + */ |
|
| 99 | + public function output_variables() { |
|
| 100 | + // No code needed, just defining the method is enough. |
|
| 101 | + } |
|
| 102 | + } |
|
| 103 | 103 | } |
| 104 | 104 | |
| 105 | 105 | class_alias( 'Redux_Text', 'ReduxFramework_Text' ); |
@@ -52,14 +52,14 @@ |
||
| 52 | 52 | |
| 53 | 53 | foreach ( $this->field['options'] as $k => $v ) { |
| 54 | 54 | if ( ! empty( $placeholder ) ) { |
| 55 | - $placeholder = ( is_array( $this->field['placeholder'] ) && isset( $this->field['placeholder'][ $k ] ) ) ? ' placeholder="' . esc_attr( $this->field['placeholder'][ $k ] ) . '" ' : ''; |
|
| 55 | + $placeholder = ( is_array( $this->field['placeholder'] ) && isset( $this->field['placeholder'][$k] ) ) ? ' placeholder="' . esc_attr( $this->field['placeholder'][$k] ) . '" ' : ''; |
|
| 56 | 56 | } |
| 57 | 57 | |
| 58 | 58 | echo '<div class="input_wrapper">'; |
| 59 | 59 | echo '<label for="' . esc_attr( $this->field['id'] . '-text-' . $k ) . '">' . esc_html( $v ) . '</label> '; |
| 60 | 60 | |
| 61 | - $value = $this->value[ $k ] ?? ''; |
|
| 62 | - $value = ! empty( $this->value[ $k ] ) ? $this->value[ $k ] : ''; |
|
| 61 | + $value = $this->value[$k] ?? ''; |
|
| 62 | + $value = ! empty( $this->value[$k] ) ? $this->value[$k] : ''; |
|
| 63 | 63 | |
| 64 | 64 | // phpcs:ignore WordPress.Security.EscapeOutput |
| 65 | 65 | echo '<input type="text" id="' . esc_attr( $this->field['id'] . '-text-' . $k ) . '" ' . esc_attr( $qtip_title ) . esc_attr( $qtip_text ) . ' name="' . esc_attr( $this->field['name'] . $this->field['name_suffix'] . '[' . esc_attr( $k ) ) . ']" ' . $placeholder . ' value="' . esc_attr( $value ) . '" class="regular-text ' . esc_attr( $this->field['class'] ) . '" ' . esc_html( $readonly ) . esc_html( $autocomplete ) . '/><br />'; |
@@ -19,36 +19,36 @@ |
||
| 19 | 19 | */ |
| 20 | 20 | class Init { |
| 21 | 21 | |
| 22 | - /** |
|
| 23 | - * Init constructor. |
|
| 24 | - * |
|
| 25 | - * @access public |
|
| 26 | - */ |
|
| 27 | - public function __construct() { |
|
| 28 | - global $pagenow; |
|
| 29 | - |
|
| 30 | - if ( 'widgets.php' === $pagenow ) { |
|
| 31 | - return; |
|
| 32 | - } |
|
| 33 | - |
|
| 34 | - require_once REDUXTEMPLATES_DIR_PATH . 'classes/class-templates.php'; |
|
| 35 | - |
|
| 36 | - add_action( 'init', array( $this, 'load' ) ); |
|
| 37 | - |
|
| 38 | - if ( did_action( 'init' ) ) { // In case the devs load it at the wrong place. |
|
| 39 | - $this->load(); |
|
| 40 | - } |
|
| 41 | - } |
|
| 42 | - |
|
| 43 | - /** |
|
| 44 | - * Load everything up after init. |
|
| 45 | - * |
|
| 46 | - * @access public |
|
| 47 | - * @since 4.0.0 |
|
| 48 | - */ |
|
| 49 | - public static function load() { |
|
| 50 | - new ReduxTemplates\Templates(); |
|
| 51 | - } |
|
| 22 | + /** |
|
| 23 | + * Init constructor. |
|
| 24 | + * |
|
| 25 | + * @access public |
|
| 26 | + */ |
|
| 27 | + public function __construct() { |
|
| 28 | + global $pagenow; |
|
| 29 | + |
|
| 30 | + if ( 'widgets.php' === $pagenow ) { |
|
| 31 | + return; |
|
| 32 | + } |
|
| 33 | + |
|
| 34 | + require_once REDUXTEMPLATES_DIR_PATH . 'classes/class-templates.php'; |
|
| 35 | + |
|
| 36 | + add_action( 'init', array( $this, 'load' ) ); |
|
| 37 | + |
|
| 38 | + if ( did_action( 'init' ) ) { // In case the devs load it at the wrong place. |
|
| 39 | + $this->load(); |
|
| 40 | + } |
|
| 41 | + } |
|
| 42 | + |
|
| 43 | + /** |
|
| 44 | + * Load everything up after init. |
|
| 45 | + * |
|
| 46 | + * @access public |
|
| 47 | + * @since 4.0.0 |
|
| 48 | + */ |
|
| 49 | + public static function load() { |
|
| 50 | + new ReduxTemplates\Templates(); |
|
| 51 | + } |
|
| 52 | 52 | } |
| 53 | 53 | |
| 54 | 54 | new Init(); |