PluginProbe ʕ •ᴥ•ʔ
Shortcodes and extra features for Phlox theme / 2.5.13
Shortcodes and extra features for Phlox theme v2.5.13
trunk 1.0.0 1.0.1 1.0.2 1.0.3 1.0.6 1.0.9 1.1.0 1.3.0 1.3.1 1.3.10 1.3.14 1.3.2 1.3.3 1.3.6 1.4.0 1.4.1 1.4.2 1.5.0 1.5.2 1.6.0 1.6.2 1.6.4 1.7.0 1.7.2 2.10.0 2.10.1 2.10.3 2.10.5 2.10.7 2.10.8 2.10.9 2.11.0 2.11.1 2.11.2 2.12.0 2.14.0 2.15.0 2.15.2 2.15.4 2.15.5 2.15.6 2.15.7 2.15.8 2.15.9 2.16.0 2.16.1 2.16.2 2.16.3 2.16.4 2.17.0 2.17.1 2.17.12 2.17.13 2.17.14 2.17.15 2.17.16 2.17.2 2.17.3 2.17.4 2.17.5 2.17.6 2.17.8 2.17.9 2.4.12 2.4.13 2.4.14 2.4.16 2.4.18 2.4.19 2.4.9 2.5.0 2.5.1 2.5.10 2.5.11 2.5.12 2.5.13 2.5.14 2.5.15 2.5.16 2.5.17 2.5.19 2.5.2 2.5.20 2.5.3 2.5.7 2.5.8 2.5.9 2.6.0 2.6.1 2.6.10 2.6.12 2.6.13 2.6.14 2.6.15 2.6.16 2.6.17 2.6.19 2.6.2 2.6.20 2.6.4 2.6.5 2.6.7 2.7.0 2.7.1 2.7.10 2.7.11 2.7.12 2.7.13 2.7.14 2.7.2 2.7.3 2.7.4 2.7.5 2.7.6 2.7.7 2.7.8 2.7.9 2.8.0 2.8.1 2.8.2 2.8.3 2.8.4 2.8.5 2.8.6 2.8.7 2.8.9 2.9.0 2.9.12 2.9.14 2.9.15 2.9.16 2.9.17 2.9.18 2.9.19 2.9.2 2.9.20 2.9.21 2.9.22 2.9.3 2.9.4 2.9.5 2.9.6 2.9.7 2.9.8
auxin-elements / includes / elements / before-after.php
auxin-elements / includes / elements Last commit date
about-widget.php 6 years ago accordion-widget.php 6 years ago accordion.php 6 years ago attachment-url.php 6 years ago audio.php 6 years ago before-after.php 6 years ago button.php 6 years ago code.php 6 years ago contact-box.php 6 years ago contact-form.php 6 years ago custom-list.php 6 years ago divider.php 6 years ago dropcap.php 6 years ago facebook.php 6 years ago flickr.php 6 years ago gallery.php 6 years ago general-element-fields.php 6 years ago gmap.php 6 years ago highlight.php 6 years ago image.php 6 years ago instagram-feed.php 6 years ago latest-items.php 8 years ago latest-posts-slider.php 6 years ago popular-posts-widget.php 6 years ago quote.php 6 years ago recent-posts-grid-carousel.php 6 years ago recent-posts-land-style.php 6 years ago recent-posts-masonry.php 6 years ago recent-posts-tiles-carousel.php 6 years ago recent-posts-tiles.php 6 years ago recent-posts-timeline.php 6 years ago recent-posts-widget.php 6 years ago recent-products.php 6 years ago related-posts.php 8 years ago sample-element.php 6 years ago search.php 6 years ago socials-list.php 6 years ago staff.php 6 years ago tab-widget.php 6 years ago tabs.php 6 years ago testimonial.php 6 years ago text.php 6 years ago touch-slider.php 6 years ago video.php 6 years ago
before-after.php
230 lines
1 <?php
2 /**
3 * Before after slider element
4 *
5 *
6 * @package Auxin
7 * @license LICENSE.txt
8 * @author averta
9 * @link http://phlox.pro/
10 * @copyright (c) 2010-2020 averta
11 */
12 function auxin_get_before_after_master_array( $master_array ) {
13
14 $master_array['aux_before_after'] = array(
15 'name' => __("Before After Slider", 'auxin-elements' ),
16 'auxin_output_callback' => 'auxin_widget_before_after_callback',
17 'base' => 'aux_before_after',
18 'description' => __('Before after comparison slider.', 'auxin-elements' ),
19 'class' => 'aux-widget-before-after',
20 'show_settings_on_create' => true,
21 'weight' => 1,
22 'is_widget' => true,
23 'is_shortcode' => true,
24 'is_so' => true,
25 'is_vc' => true,
26 'category' => THEME_NAME,
27 'group' => '',
28 'admin_enqueue_js' => '',
29 'admin_enqueue_css' => '',
30 'front_enqueue_js' => '',
31 'front_enqueue_css' => '',
32 'icon' => 'aux-element aux-pb-icons-image',
33 'custom_markup' => '',
34 'js_view' => '',
35 'html_template' => '',
36 'deprecated' => '',
37 'content_element' => '',
38 'as_parent' => '',
39 'as_child' => '',
40 'params' => array(
41 array(
42 'heading' => __('Title','auxin-elements' ),
43 'description' => __('Element title, leave it empty if you don`t need title.', 'auxin-elements'),
44 'param_name' => 'title',
45 'type' => 'textfield',
46 'value' => '',
47 'holder' => 'textfield',
48 'class' => 'id',
49 'admin_label' => false,
50 'dependency' => '',
51 'weight' => '',
52 'group' => '' ,
53 'edit_field_class' => ''
54 ),
55 array(
56 'heading' => __('Before image','auxin-elements' ),
57 'description' => '',
58 'param_name' => 'before_attach_id',
59 'type' => 'attach_image',
60 'value' => '',
61 'class' => 'before_attach_id',
62 'admin_label' => false,
63 'dependency' => '',
64 'weight' => '',
65 'group' => '' ,
66 'edit_field_class' => ''
67 ),
68 array(
69 'heading' => __('After image','auxin-elements' ),
70 'description' => '',
71 'param_name' => 'after_attach_id',
72 'type' => 'attach_image',
73 'value' => '',
74 'def_value' => '',
75 'class' => 'after_attach_id',
76 'admin_label' => false,
77 'dependency' => '',
78 'weight' => '',
79 'group' => '' ,
80 'edit_field_class' => ''
81 ),
82 array(
83 'heading' => __( 'Start offset','auxin-elements' ),
84 'description' => __( 'How much of the before image is visible when the page loads, between 0 to 1.', 'auxin-elements' ),
85 'param_name' => 'default_offset',
86 'type' => 'textfield',
87 'value' => '0.5',
88 'def_value' => '',
89 'class' => 'default_offset',
90 'admin_label' => false,
91 'dependency' => '',
92 'weight' => '',
93 'group' => '' ,
94 'edit_field_class' => ''
95 ),
96 array(
97 'heading' => __('Image size','auxin-elements' ),
98 'description' => '',
99 'param_name' => 'size',
100 'type' => 'dropdown',
101 'def_value' => 'large',
102 'value' => array(
103 'thumbnail' => __('Thumbnail' , 'auxin-elements' ),
104 'medium' => __('Medium' , 'auxin-elements' ),
105 'large' => __('Large' , 'auxin-elements' ),
106 'full' => __('Full' , 'auxin-elements' )
107 ),
108 'admin_label' => true,
109 'dependency' => '',
110 'weight' => '',
111 'group' => '' ,
112 'edit_field_class' => ''
113 ),
114 array(
115 'heading' => __('Width','auxin-elements' ),
116 'description' => '',
117 'param_name' => 'width',
118 'type' => 'textfield',
119 'value' => '',
120 'class' => 'width',
121 'admin_label' => true,
122 'dependency' => '',
123 'weight' => '',
124 'group' => '' ,
125 'edit_field_class' => ''
126 ),
127 array(
128 'heading' => __('Height','auxin-elements' ),
129 'description' => '',
130 'param_name' => 'height',
131 'type' => 'textfield',
132 'value' => '',
133 'class' => 'height',
134 'admin_label' => true,
135 'dependency' => '',
136 'weight' => '',
137 'group' => '' ,
138 'edit_field_class' => ''
139 ),
140 array(
141 'heading' => __('Extra class name','auxin-elements' ),
142 'description' => __('If you wish to style particular content element differently, then use this field to add a class name and then refer to it in your css file.', 'auxin-elements' ),
143 'param_name' => 'extra_classes',
144 'type' => 'textfield',
145 'value' => '',
146 'def_value' => '',
147 'class' => 'extra_classes',
148 'admin_label' => false,
149 'dependency' => '',
150 'weight' => '',
151 'group' => '' ,
152 'edit_field_class' => ''
153 )
154 )
155 );
156
157 return $master_array;
158 }
159
160 add_filter( 'auxin_master_array_shortcodes', 'auxin_get_before_after_master_array', 10, 1 );
161
162 // This is the widget call back in fact the front end out put of this widget comes from this function
163 function auxin_widget_before_after_callback( $atts, $shortcode_content = null ){
164
165 // Defining default attributes
166 $default_atts = array(
167 'title' => '', // header title
168 'before_attach_id' => '', // attachment id of before image
169 'after_attach_id' => '', // attachment id of after image
170 'width' => '', // final width of image
171 'height' => '', // final height of image
172 'size' => 'large',
173 'crop' => true,
174 'default_offset' => '0.5',
175
176 'extra_classes' => '', // custom css class names for this element
177 'custom_el_id' => '', // custom id attribute for this element
178 'base_class' => 'aux-widget-before-after' // base class name for container
179 );
180
181 $result = auxin_get_widget_scafold( $atts, $default_atts, $shortcode_content );
182 extract( $result['parsed_atts'] );
183
184 $before_image = '';
185 $after_image = '';
186 $style_attr = '';
187
188 if ( ! empty( $width ) && is_numeric( $width ) ) {
189 $style_attr .= 'max-width:' . $width . 'px;';
190 }
191
192 if ( ! empty( $height ) && is_numeric( $height ) ) {
193 $style_attr .= 'max-height:' . $height . 'px ';
194 }
195
196 if( ! empty( $before_attach_id ) && is_numeric( $before_attach_id ) ) {
197 $before_image = wp_get_attachment_image( $before_attach_id, $size );
198 }
199
200 if( ! empty( $after_attach_id ) && is_numeric( $after_attach_id ) ) {
201 $after_image = wp_get_attachment_image( $after_attach_id, $size );
202 }
203
204 ob_start();
205
206 // widget header ------------------------------
207 echo $result['widget_header'];
208 echo $result['widget_title'];
209
210
211 // widget output -----------------------
212 if ( !empty( $after_image ) ) {
213 ?>
214 <div class="aux-before-after" style="<?php echo $style_attr ?>" data-offset="<?php echo $default_offset; ?>">
215 <?php echo $before_image ?>
216 <?php echo $after_image; ?>
217 </div>
218 <?php } else { ?>
219 <div class="aux-before-after" style="<?php echo $style_attr ?>" data-offset="<?php echo $default_offset; ?>">
220 <?php echo $before_image ?>
221 </div>
222 <?php
223 }
224
225 // widget footer ------------------------------
226 echo $result['widget_footer'];
227
228 return ob_get_clean();
229 }
230