diff options
Diffstat (limited to 'plugins/jetpack/modules/widgets/simple-payments.php')
-rw-r--r-- | plugins/jetpack/modules/widgets/simple-payments.php | 241 |
1 files changed, 149 insertions, 92 deletions
diff --git a/plugins/jetpack/modules/widgets/simple-payments.php b/plugins/jetpack/modules/widgets/simple-payments.php index f31af1b0..4eb60bdb 100644 --- a/plugins/jetpack/modules/widgets/simple-payments.php +++ b/plugins/jetpack/modules/widgets/simple-payments.php @@ -10,7 +10,7 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { /** * Simple Payments Button * - * Display a Simple Payment Button as a Widget. + * Display a Simple Payments Button as a Widget. */ class Jetpack_Simple_Payments_Widget extends WP_Widget { // https://developer.paypal.com/docs/integration/direct/rest/currency-codes/ @@ -50,14 +50,20 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { /** This filter is documented in modules/widgets/facebook-likebox.php */ apply_filters( 'jetpack_widget_name', __( 'Simple Payments', 'jetpack' ) ), array( - 'classname' => 'jetpack-simple-payments', - 'description' => __( 'Add a Simple Payment Button as a Widget.', 'jetpack' ), + 'classname' => 'jetpack-simple-payments', + 'description' => __( 'Add a Simple Payments Button as a Widget.', 'jetpack' ), 'customize_selective_refresh' => true, ) ); - if ( is_customize_preview() ) { - add_action( 'admin_enqueue_scripts', array( $this, 'admin_enqueue_styles_and_scripts' ) ); + global $pagenow; + if ( is_customize_preview() || 'widgets.php' === $pagenow ) { + add_action( 'admin_enqueue_scripts', array( $this, 'admin_enqueue_styles' ) ); + } + + $jetpack_simple_payments = Jetpack_Simple_Payments::getInstance(); + if ( is_customize_preview() && $jetpack_simple_payments->is_enabled_jetpack_simple_payments() ) { + add_action( 'admin_enqueue_scripts', array( $this, 'admin_enqueue_scripts' ) ); add_filter( 'customize_refresh_nonces', array( $this, 'filter_nonces' ) ); add_action( 'wp_ajax_customize-jetpack-simple-payments-buttons-get', array( $this, 'ajax_get_payment_buttons' ) ); @@ -78,22 +84,22 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { * @return array Default values for the widget options. */ private function defaults() { - $current_user = wp_get_current_user(); + $current_user = wp_get_current_user(); $default_product_id = $this->get_first_product_id(); return array( - 'title' => '', - 'product_post_id' => $default_product_id, - 'form_action' => '', - 'form_product_id' => 0, - 'form_product_title' => '', + 'title' => '', + 'product_post_id' => $default_product_id, + 'form_action' => '', + 'form_product_id' => 0, + 'form_product_title' => '', 'form_product_description' => '', - 'form_product_image_id' => 0, - 'form_product_image_src' => '', - 'form_product_currency' => '', - 'form_product_price' => '', - 'form_product_multiple' => '', - 'form_product_email' => $current_user->user_email, + 'form_product_image_id' => 0, + 'form_product_image_src' => '', + 'form_product_currency' => '', + 'form_product_price' => '', + 'form_product_multiple' => '', + 'form_product_email' => $current_user->user_email, ); } @@ -112,14 +118,18 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { wp_enqueue_style( 'jetpack-simple-payments-widget-style', plugins_url( 'simple-payments/style.css', __FILE__ ), array(), '20180518' ); } - function admin_enqueue_styles_and_scripts(){ - wp_enqueue_style( 'jetpack-simple-payments-widget-customizer', plugins_url( 'simple-payments/customizer.css', __FILE__ ) ); + function admin_enqueue_styles() { + wp_enqueue_style( 'jetpack-simple-payments-widget-customizer', plugins_url( 'simple-payments/customizer.css', __FILE__ ) ); + } + function admin_enqueue_scripts() { wp_enqueue_media(); wp_enqueue_script( 'jetpack-simple-payments-widget-customizer', plugins_url( '/simple-payments/customizer.js', __FILE__ ), array( 'jquery' ), false, true ); - wp_localize_script( 'jetpack-simple-payments-widget-customizer', 'jpSimplePaymentsStrings', array( - 'deleteConfirmation' => __( 'Are you sure you want to delete this item? It will be disabled and removed from all locations where it currently appears.', 'jetpack' ) - ) ); + wp_localize_script( + 'jetpack-simple-payments-widget-customizer', 'jpSimplePaymentsStrings', array( + 'deleteConfirmation' => __( 'Are you sure you want to delete this item? It will be disabled and removed from all locations where it currently appears.', 'jetpack' ), + ) + ); } public function ajax_get_payment_buttons() { @@ -136,12 +146,14 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { wp_send_json_error( 'insufficient_post_permissions', 403 ); } - $product_posts = get_posts( array( - 'numberposts' => 100, - 'orderby' => 'date', - 'post_type' => Jetpack_Simple_Payments::$post_type_product, - 'post_status' => 'publish', - ) ); + $product_posts = get_posts( + array( + 'numberposts' => 100, + 'orderby' => 'date', + 'post_type' => Jetpack_Simple_Payments::$post_type_product, + 'post_status' => 'publish', + ) + ); $formatted_products = array_map( array( $this, 'format_product_post_for_ajax_reponse' ), $product_posts ); @@ -150,7 +162,7 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { public function format_product_post_for_ajax_reponse( $product_post ) { return array( - 'ID' => $product_post->ID, + 'ID' => $product_post->ID, 'post_title' => $product_post->post_title, ); } @@ -182,17 +194,17 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { $product_post_id = isset( $params['product_post_id'] ) ? intval( $params['product_post_id'] ) : 0; $product_post = array( - 'ID' => $product_post_id, - 'post_type' => Jetpack_Simple_Payments::$post_type_product, - 'post_status' => 'publish', - 'post_title' => $params['post_title'], - 'post_content' => $params['post_content'], + 'ID' => $product_post_id, + 'post_type' => Jetpack_Simple_Payments::$post_type_product, + 'post_status' => 'publish', + 'post_title' => $params['post_title'], + 'post_content' => $params['post_content'], '_thumbnail_id' => ! empty( $params['image_id'] ) ? $params['image_id'] : -1, - 'meta_input' => array( + 'meta_input' => array( 'spay_currency' => $params['currency'], - 'spay_price' => $params['price'], + 'spay_price' => $params['price'], 'spay_multiple' => isset( $params['multiple'] ) ? intval( $params['multiple'] ) : 0, - 'spay_email' => is_email( $params['email'] ), + 'spay_email' => is_email( $params['email'] ), ), ); @@ -209,7 +221,7 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { $tracks_properties = array( 'id' => $product_post_id, 'currency' => $params['currency'], - 'price' => $params['price'] + 'price' => $params['price'], ); if ( 0 === $product_post['ID'] ) { $this->record_event( 'created', 'create', $tracks_properties ); @@ -217,10 +229,12 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { $this->record_event( 'updated', 'update', $tracks_properties ); } - wp_send_json_success( array( - 'product_post_id' => $product_post_id, - 'product_post_title' => $params['post_title'], - ) ); + wp_send_json_success( + array( + 'product_post_id' => $product_post_id, + 'product_post_title' => $params['post_title'], + ) + ); } public function ajax_delete_payment_button() { @@ -236,13 +250,13 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { wp_send_json_error( 'missing_params', 400 ); } - $params = wp_unslash( $_POST['params'] ); + $params = wp_unslash( $_POST['params'] ); $illegal_params = array_diff( array_keys( $params ), array( 'product_post_id' ) ); if ( ! empty( $illegal_params ) ) { wp_send_json_error( 'illegal_params', 400 ); } - $product_id = ( int ) $params['product_post_id']; + $product_id = (int) $params['product_post_id']; $product_post = get_post( $product_id ); $return = array( 'status' => $product_post->post_status ); @@ -258,36 +272,60 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { wp_send_json_success( $return ); } + /** + * Returns the number of decimal places on string representing a price. + * + * @param string $number Price to check. + * @return number number of decimal places. + */ + private function get_decimal_places( $number ) { + $parts = explode( '.', $number ); + if ( count( $parts ) > 2 ) { + return null; + } + + return isset( $parts[1] ) ? strlen( $parts[1] ) : 0; + } + public function validate_ajax_params( $params ) { $errors = new WP_Error(); $illegal_params = array_diff( array_keys( $params ), array( 'product_post_id', 'post_title', 'post_content', 'image_id', 'currency', 'price', 'multiple', 'email' ) ); if ( ! empty( $illegal_params ) ) { - $errors.add( 'illegal_params' ); + $errors->add( 'illegal_params', __( 'Invalid parameters.', 'jetpack' ) ); } if ( empty( $params['post_title'] ) ) { - $errors->add( 'post_title', __( 'People need to know what they\'re paying for! Please add a brief title.' ) ); + $errors->add( 'post_title', __( "People need to know what they're paying for! Please add a brief title.", 'jetpack' ) ); } - if ( empty( $params['price'] ) || floatval( $params['price'] ) <= 0 ) { - $errors->add( 'price', __( 'Everything comes with a price tag these days. Please add a your product price.' ) ); + if ( empty( $params['price'] ) || ! is_numeric( $params['price'] ) || floatval( $params['price'] ) <= 0 ) { + $errors->add( 'price', __( 'Everything comes with a price tag these days. Please add a your product price.', 'jetpack' ) ); + } + + // Japan's Yen is the only supported currency with a zero decimal precision. + $precision = strtoupper( $params['currency'] ) === 'JPY' ? 0 : 2; + $price_decimal_places = $this->get_decimal_places( $params['price'] ); + if ( is_null( $price_decimal_places ) || $price_decimal_places > $precision ) { + $errors->add( 'price', __( 'Invalid price', 'jetpack' ) ); } if ( empty( $params['email'] ) || ! is_email( $params['email'] ) ) { - $errors->add( 'email', __( 'We want to make sure payments reach you, so please add an email address.' ) ); + $errors->add( 'email', __( 'We want to make sure payments reach you, so please add an email address.', 'jetpack' ) ); } return $errors; } function get_first_product_id() { - $product_posts = get_posts( array( - 'numberposts' => 1, - 'orderby' => 'date', - 'post_type' => Jetpack_Simple_Payments::$post_type_product, - 'post_status' => 'publish', - ) ); + $product_posts = get_posts( + array( + 'numberposts' => 1, + 'orderby' => 'date', + 'post_type' => Jetpack_Simple_Payments::$post_type_product, + 'post_status' => 'publish', + ) + ); return ! empty( $product_posts ) ? $product_posts[0]->ID : null; } @@ -316,10 +354,12 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { if ( ! empty( $instance['form_action'] ) && in_array( $instance['form_action'], array( 'add', 'edit' ) ) && is_customize_preview() ) { require( dirname( __FILE__ ) . '/simple-payments/widget.php' ); } else { - $jsp = Jetpack_Simple_Payments::getInstance(); - $simple_payments_button = $jsp->parse_shortcode( array( - 'id' => $instance['product_post_id'], - ) ); + $jsp = Jetpack_Simple_Payments::getInstance(); + $simple_payments_button = $jsp->parse_shortcode( + array( + 'id' => $instance['product_post_id'], + ) + ); if ( ! is_null( $simple_payments_button ) || is_customize_preview() ) { echo $simple_payments_button; @@ -341,7 +381,7 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { * @param array $mixed Array of values for the old form instance. * @return mixed $mixed Field value. */ - private function get_latest_field_value( $new_instance, $old_instance, $field) { + private function get_latest_field_value( $new_instance, $old_instance, $field ) { return ! empty( $new_instance[ $field ] ) ? sanitize_text_field( $new_instance[ $field ] ) : $old_instance[ $field ]; @@ -355,21 +395,21 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { * @return array $fields Product Fields from the Product Post. */ private function get_product_from_post( $product_post_id ) { - $product_post = get_post( $product_post_id ); + $product_post = get_post( $product_post_id ); $form_product_id = $product_post_id; - if( ! empty( $product_post ) ) { + if ( ! empty( $product_post ) ) { $form_product_image_id = get_post_thumbnail_id( $product_post_id ); return array( - 'form_product_id' => $form_product_id, - 'form_product_title' => get_the_title( $product_post ), + 'form_product_id' => $form_product_id, + 'form_product_title' => get_the_title( $product_post ), 'form_product_description' => $product_post->post_content, - 'form_product_image_id' => $form_product_image_id, - 'form_product_image_src' => wp_get_attachment_image_url( $form_product_image_id, 'thumbnail' ), - 'form_product_currency' => get_post_meta( $product_post_id, 'spay_currency', true ), - 'form_product_price' => get_post_meta( $product_post_id, 'spay_price', true ), - 'form_product_multiple' => get_post_meta( $product_post_id, 'spay_multiple', true ) || '0', - 'form_product_email' => get_post_meta( $product_post_id, 'spay_email', true ), + 'form_product_image_id' => $form_product_image_id, + 'form_product_image_src' => wp_get_attachment_image_url( $form_product_image_id, 'thumbnail' ), + 'form_product_currency' => get_post_meta( $product_post_id, 'spay_currency', true ), + 'form_product_price' => get_post_meta( $product_post_id, 'spay_price', true ), + 'form_product_multiple' => get_post_meta( $product_post_id, 'spay_multiple', true ) || '0', + 'form_product_email' => get_post_meta( $product_post_id, 'spay_email', true ), ); } @@ -398,7 +438,7 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { jetpack_tracks_record_event( $current_user, 'jetpack_wpa_simple_payments_button_' . $event_action, $event_properties ); $jetpack = Jetpack::init(); // $jetpack->stat automatically prepends the stat group with 'jetpack-' - $jetpack->stat( 'simple_payments', $stat_name ) ; + $jetpack->stat( 'simple_payments', $stat_name ); $jetpack->do_stats( 'server_side' ); } @@ -419,14 +459,14 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { $old_instance = wp_parse_args( $old_instance, $defaults ); $required_widget_props = array( - 'title' => $this->get_latest_field_value( $new_instance, $old_instance, 'title' ), + 'title' => $this->get_latest_field_value( $new_instance, $old_instance, 'title' ), 'product_post_id' => $this->get_latest_field_value( $new_instance, $old_instance, 'product_post_id' ), - 'form_action' => $this->get_latest_field_value( $new_instance, $old_instance, 'form_action' ), + 'form_action' => $this->get_latest_field_value( $new_instance, $old_instance, 'form_action' ), ); if ( strcmp( $new_instance['form_action'], $old_instance['form_action'] ) !== 0 ) { if ( $new_instance['form_action'] == 'edit' ) { - return array_merge( $this->get_product_from_post( ( int ) $old_instance['product_post_id'] ), $required_widget_props ); + return array_merge( $this->get_product_from_post( (int) $old_instance['product_post_id'] ), $required_widget_props ); } if ( $new_instance['form_action'] == 'clear' ) { @@ -440,17 +480,19 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { ? sanitize_text_field( $new_instance['form_product_email'] ) : $defaults['form_product_email']; - return array_merge( $required_widget_props, array( - 'form_product_id' => ( int ) $new_instance['form_product_id'], - 'form_product_title' => sanitize_text_field( $new_instance['form_product_title'] ), - 'form_product_description' => sanitize_text_field( $new_instance['form_product_description'] ), - 'form_product_image_id' => $form_product_image_id, - 'form_product_image_src' => wp_get_attachment_image_url( $form_product_image_id, 'thumbnail' ), - 'form_product_currency' => sanitize_text_field( $new_instance['form_product_currency'] ), - 'form_product_price' => sanitize_text_field( $new_instance['form_product_price'] ), - 'form_product_multiple' => sanitize_text_field( $new_instance['form_product_multiple'] ), - 'form_product_email' => $form_product_email, - ) ); + return array_merge( + $required_widget_props, array( + 'form_product_id' => (int) $new_instance['form_product_id'], + 'form_product_title' => sanitize_text_field( $new_instance['form_product_title'] ), + 'form_product_description' => sanitize_text_field( $new_instance['form_product_description'] ), + 'form_product_image_id' => $form_product_image_id, + 'form_product_image_src' => wp_get_attachment_image_url( $form_product_image_id, 'thumbnail' ), + 'form_product_currency' => sanitize_text_field( $new_instance['form_product_currency'] ), + 'form_product_price' => sanitize_text_field( $new_instance['form_product_price'] ), + 'form_product_multiple' => sanitize_text_field( $new_instance['form_product_multiple'] ), + 'form_product_email' => $form_product_email, + ) + ); } /** @@ -461,21 +503,36 @@ if ( ! class_exists( 'Jetpack_Simple_Payments_Widget' ) ) { * @param array $instance Previously saved values from database. */ function form( $instance ) { + $jetpack_simple_payments = Jetpack_Simple_Payments::getInstance(); + if ( ! method_exists( $jetpack_simple_payments, 'is_enabled_jetpack_simple_payments' ) ) { + return; + } + if ( ! $jetpack_simple_payments->is_enabled_jetpack_simple_payments() ) { + require dirname( __FILE__ ) . '/simple-payments/admin-warning.php'; + return; + } + $instance = wp_parse_args( $instance, $this->defaults() ); - $product_posts = get_posts( array( - 'numberposts' => 100, - 'orderby' => 'date', - 'post_type' => Jetpack_Simple_Payments::$post_type_product, - 'post_status' => 'publish', - ) ); + $product_posts = get_posts( + array( + 'numberposts' => 100, + 'orderby' => 'date', + 'post_type' => Jetpack_Simple_Payments::$post_type_product, + 'post_status' => 'publish', + ) + ); - require( dirname( __FILE__ ) . '/simple-payments/form.php' ); + require dirname( __FILE__ ) . '/simple-payments/form.php'; } } // Register Jetpack_Simple_Payments_Widget widget. function register_widget_jetpack_simple_payments() { + if ( ! class_exists( 'Jetpack_Simple_Payments' ) ) { + return; + } + $jetpack_simple_payments = Jetpack_Simple_Payments::getInstance(); if ( ! $jetpack_simple_payments->is_enabled_jetpack_simple_payments() ) { return; |