@@ -215,16 +215,16 @@ discard block |
||
| 215 | 215 | function getpaid_prepare_item_tax( $item, $tax_name, $tax_amount, $recurring_tax_amount ) { |
| 216 | 216 | |
| 217 | 217 | $initial_tax = $tax_amount; |
| 218 | - $recurring_tax = 0; |
|
| 218 | + $recurring_tax = 0; |
|
| 219 | 219 | |
| 220 | 220 | if ( $item->is_recurring() ) { |
| 221 | - $recurring_tax = $recurring_tax_amount; |
|
| 222 | - } |
|
| 221 | + $recurring_tax = $recurring_tax_amount; |
|
| 222 | + } |
|
| 223 | 223 | |
| 224 | - return array( |
|
| 225 | - 'name' => sanitize_text_field( $tax_name ), |
|
| 226 | - 'initial_tax' => $initial_tax, |
|
| 227 | - 'recurring_tax' => $recurring_tax, |
|
| 224 | + return array( |
|
| 225 | + 'name' => sanitize_text_field( $tax_name ), |
|
| 226 | + 'initial_tax' => $initial_tax, |
|
| 227 | + 'recurring_tax' => $recurring_tax, |
|
| 228 | 228 | ); |
| 229 | 229 | |
| 230 | 230 | } |
@@ -328,7 +328,7 @@ discard block |
||
| 328 | 328 | */ |
| 329 | 329 | function wpinv_should_validate_vat_number() { |
| 330 | 330 | $validate = wpinv_get_option( 'validate_vat_number' ); |
| 331 | - return ! empty( $validate ); |
|
| 331 | + return ! empty( $validate ); |
|
| 332 | 332 | } |
| 333 | 333 | |
| 334 | 334 | function wpinv_sales_tax_for_year( $year = null ) { |
@@ -8,7 +8,7 @@ discard block |
||
| 8 | 8 | */ |
| 9 | 9 | |
| 10 | 10 | if ( ! defined( 'ABSPATH' ) ) { |
| 11 | - exit; // Exit if accessed directly |
|
| 11 | + exit; // Exit if accessed directly |
|
| 12 | 12 | } |
| 13 | 13 | |
| 14 | 14 | /** |
@@ -17,10 +17,10 @@ discard block |
||
| 17 | 17 | class GetPaid_Meta_Box_Item_VAT { |
| 18 | 18 | |
| 19 | 19 | /** |
| 20 | - * Output the metabox. |
|
| 21 | - * |
|
| 22 | - * @param WP_Post $post |
|
| 23 | - */ |
|
| 20 | + * Output the metabox. |
|
| 21 | + * |
|
| 22 | + * @param WP_Post $post |
|
| 23 | + */ |
|
| 24 | 24 | public static function output( $post ) { |
| 25 | 25 | |
| 26 | 26 | // Prepare the item. |
@@ -46,10 +46,10 @@ discard block |
||
| 46 | 46 | } |
| 47 | 47 | |
| 48 | 48 | /** |
| 49 | - * Output the VAT rules settings. |
|
| 50 | - * |
|
| 51 | - * @param WPInv_Item $item |
|
| 52 | - */ |
|
| 49 | + * Output the VAT rules settings. |
|
| 50 | + * |
|
| 51 | + * @param WPInv_Item $item |
|
| 52 | + */ |
|
| 53 | 53 | public static function output_vat_rules( $item ) { |
| 54 | 54 | ?> |
| 55 | 55 | |
@@ -87,10 +87,10 @@ discard block |
||
| 87 | 87 | } |
| 88 | 88 | |
| 89 | 89 | /** |
| 90 | - * Output the VAT class settings. |
|
| 91 | - * |
|
| 92 | - * @param WPInv_Item $item |
|
| 93 | - */ |
|
| 90 | + * Output the VAT class settings. |
|
| 91 | + * |
|
| 92 | + * @param WPInv_Item $item |
|
| 93 | + */ |
|
| 94 | 94 | public static function output_vat_classes( $item ) { |
| 95 | 95 | ?> |
| 96 | 96 | |
@@ -55,27 +55,27 @@ |
||
| 55 | 55 | public static function vat_rates_settings() {} |
| 56 | 56 | |
| 57 | 57 | /** |
| 58 | - * |
|
| 59 | - * @deprecated |
|
| 60 | - */ |
|
| 58 | + * |
|
| 59 | + * @deprecated |
|
| 60 | + */ |
|
| 61 | 61 | public static function vat_settings() {} |
| 62 | 62 | |
| 63 | 63 | /** |
| 64 | - * |
|
| 65 | - * @deprecated |
|
| 66 | - */ |
|
| 64 | + * |
|
| 65 | + * @deprecated |
|
| 66 | + */ |
|
| 67 | 67 | public static function maxmind_folder() {} |
| 68 | 68 | |
| 69 | 69 | /** |
| 70 | - * |
|
| 71 | - * @deprecated |
|
| 72 | - */ |
|
| 70 | + * |
|
| 71 | + * @deprecated |
|
| 72 | + */ |
|
| 73 | 73 | public static function geoip2_download_database() {} |
| 74 | 74 | |
| 75 | 75 | /** |
| 76 | - * |
|
| 77 | - * @deprecated |
|
| 78 | - */ |
|
| 76 | + * |
|
| 77 | + * @deprecated |
|
| 78 | + */ |
|
| 79 | 79 | public static function geoip2_download_file() {} |
| 80 | 80 | |
| 81 | 81 | /** |
@@ -9,32 +9,32 @@ |
||
| 9 | 9 | defined( 'ABSPATH' ) || exit; |
| 10 | 10 | |
| 11 | 11 | return array( |
| 12 | - 'AT', |
|
| 13 | - 'BE', |
|
| 14 | - 'BG', |
|
| 15 | - 'HR', |
|
| 16 | - 'CY', |
|
| 17 | - 'CZ', |
|
| 18 | - 'DK', |
|
| 19 | - 'EE', |
|
| 20 | - 'FI', |
|
| 21 | - 'FR', |
|
| 22 | - 'DE', |
|
| 23 | - 'GB', |
|
| 24 | - 'GR', |
|
| 25 | - 'HU', |
|
| 26 | - 'IE', |
|
| 27 | - 'IT', |
|
| 28 | - 'LV', |
|
| 29 | - 'LT', |
|
| 30 | - 'LU', |
|
| 31 | - 'MT', |
|
| 32 | - 'NL', |
|
| 33 | - 'PL', |
|
| 34 | - 'PT', |
|
| 35 | - 'RO', |
|
| 36 | - 'SK', |
|
| 37 | - 'SI', |
|
| 38 | - 'ES', |
|
| 39 | - 'SE' |
|
| 12 | + 'AT', |
|
| 13 | + 'BE', |
|
| 14 | + 'BG', |
|
| 15 | + 'HR', |
|
| 16 | + 'CY', |
|
| 17 | + 'CZ', |
|
| 18 | + 'DK', |
|
| 19 | + 'EE', |
|
| 20 | + 'FI', |
|
| 21 | + 'FR', |
|
| 22 | + 'DE', |
|
| 23 | + 'GB', |
|
| 24 | + 'GR', |
|
| 25 | + 'HU', |
|
| 26 | + 'IE', |
|
| 27 | + 'IT', |
|
| 28 | + 'LV', |
|
| 29 | + 'LT', |
|
| 30 | + 'LU', |
|
| 31 | + 'MT', |
|
| 32 | + 'NL', |
|
| 33 | + 'PL', |
|
| 34 | + 'PT', |
|
| 35 | + 'RO', |
|
| 36 | + 'SK', |
|
| 37 | + 'SI', |
|
| 38 | + 'ES', |
|
| 39 | + 'SE' |
|
| 40 | 40 | ); |
@@ -13,233 +13,233 @@ |
||
| 13 | 13 | |
| 14 | 14 | return array( |
| 15 | 15 | |
| 16 | - 'id' => array( |
|
| 17 | - 'description' => __( 'Unique identifier for the item.', 'invoicing' ), |
|
| 18 | - 'type' => 'integer', |
|
| 19 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 20 | - 'readonly' => true, |
|
| 21 | - ), |
|
| 22 | - |
|
| 23 | - 'parent_id' => array( |
|
| 24 | - 'description' => __( 'Parent item ID.', 'invoicing' ), |
|
| 25 | - 'type' => 'integer', |
|
| 26 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 27 | - 'default' => 0, |
|
| 28 | - ), |
|
| 29 | - |
|
| 30 | - 'status' => array( |
|
| 31 | - 'description' => __( 'A named status for the item.', 'invoicing' ), |
|
| 32 | - 'type' => 'string', |
|
| 33 | - 'enum' => array( 'draft', 'pending', 'publish' ), |
|
| 34 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 35 | - 'default' => 'draft', |
|
| 36 | - ), |
|
| 37 | - |
|
| 38 | - 'version' => array( |
|
| 39 | - 'description' => __( 'Plugin version when the item was created.', 'invoicing' ), |
|
| 40 | - 'type' => 'string', |
|
| 41 | - 'context' => array( 'view', 'edit' ), |
|
| 42 | - 'readonly' => true, |
|
| 43 | - ), |
|
| 44 | - |
|
| 45 | - 'date_created' => array( |
|
| 46 | - 'description' => __( "The date the item was created, in the site's timezone.", 'invoicing' ), |
|
| 47 | - 'type' => 'string', |
|
| 48 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 49 | - ), |
|
| 50 | - |
|
| 51 | - 'date_created_gmt' => array( |
|
| 52 | - 'description' => __( 'The GMT date the item was created.', 'invoicing' ), |
|
| 53 | - 'type' => 'string', |
|
| 54 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 55 | - 'readonly' => true, |
|
| 56 | - ), |
|
| 57 | - |
|
| 58 | - 'date_modified' => array( |
|
| 59 | - 'description' => __( "The date the item was last modified, in the site's timezone.", 'invoicing' ), |
|
| 60 | - 'type' => 'string', |
|
| 61 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 62 | - 'readonly' => true, |
|
| 63 | - ), |
|
| 64 | - |
|
| 65 | - 'date_modified_gmt' => array( |
|
| 66 | - 'description' => __( 'The GMT date the item was last modified.', 'invoicing' ), |
|
| 67 | - 'type' => 'string', |
|
| 68 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 69 | - 'readonly' => true, |
|
| 70 | - ), |
|
| 71 | - |
|
| 72 | - 'name' => array( |
|
| 73 | - 'description' => __( "The item's name.", 'invoicing' ), |
|
| 74 | - 'type' => 'string', |
|
| 75 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 76 | - 'required' => true, |
|
| 77 | - ), |
|
| 78 | - |
|
| 79 | - 'description' => array( |
|
| 80 | - 'description' => __( "The item's description.", 'invoicing' ), |
|
| 81 | - 'type' => 'string', |
|
| 82 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 83 | - ), |
|
| 84 | - |
|
| 85 | - 'owner' => array( |
|
| 86 | - 'description' => __( 'The owner of the item (user id).', 'invoicing' ), |
|
| 87 | - 'type' => 'integer', |
|
| 88 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 89 | - ), |
|
| 90 | - |
|
| 91 | - 'price' => array( |
|
| 92 | - 'description' => __( 'The price of the item.', 'invoicing' ), |
|
| 93 | - 'type' => 'number', |
|
| 94 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 95 | - 'required' => true, |
|
| 96 | - ), |
|
| 97 | - |
|
| 98 | - 'the_price' => array( |
|
| 99 | - 'description' => __( 'The formatted price of the item.', 'invoicing' ), |
|
| 100 | - 'type' => 'string', |
|
| 101 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 102 | - 'readonly' => true, |
|
| 103 | - ), |
|
| 104 | - |
|
| 105 | - 'type' => array( |
|
| 106 | - 'description' => __( 'The item type.', 'invoicing' ), |
|
| 107 | - 'type' => 'string', |
|
| 108 | - 'enum' => wpinv_item_types(), |
|
| 109 | - 'default' => 'custom', |
|
| 110 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 111 | - ), |
|
| 112 | - |
|
| 113 | - 'vat_rule' => array( |
|
| 114 | - 'description' => __( 'VAT rule applied to the item.', 'invoicing' ), |
|
| 115 | - 'type' => 'string', |
|
| 116 | - 'enum' => array_keys( getpaid_get_tax_rules() ), |
|
| 117 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 118 | - ), |
|
| 119 | - |
|
| 120 | - 'vat_class' => array( |
|
| 121 | - 'description' => __( 'VAT class for the item.', 'invoicing' ), |
|
| 122 | - 'type' => 'string', |
|
| 123 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 124 | - 'enum' => array_keys( getpaid_get_tax_classes() ), |
|
| 125 | - ), |
|
| 126 | - |
|
| 127 | - 'custom_id' => array( |
|
| 128 | - 'description' => __( 'Custom id for the item.', 'invoicing' ), |
|
| 129 | - 'type' => 'string', |
|
| 130 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 131 | - ), |
|
| 16 | + 'id' => array( |
|
| 17 | + 'description' => __( 'Unique identifier for the item.', 'invoicing' ), |
|
| 18 | + 'type' => 'integer', |
|
| 19 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 20 | + 'readonly' => true, |
|
| 21 | + ), |
|
| 22 | + |
|
| 23 | + 'parent_id' => array( |
|
| 24 | + 'description' => __( 'Parent item ID.', 'invoicing' ), |
|
| 25 | + 'type' => 'integer', |
|
| 26 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 27 | + 'default' => 0, |
|
| 28 | + ), |
|
| 29 | + |
|
| 30 | + 'status' => array( |
|
| 31 | + 'description' => __( 'A named status for the item.', 'invoicing' ), |
|
| 32 | + 'type' => 'string', |
|
| 33 | + 'enum' => array( 'draft', 'pending', 'publish' ), |
|
| 34 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 35 | + 'default' => 'draft', |
|
| 36 | + ), |
|
| 37 | + |
|
| 38 | + 'version' => array( |
|
| 39 | + 'description' => __( 'Plugin version when the item was created.', 'invoicing' ), |
|
| 40 | + 'type' => 'string', |
|
| 41 | + 'context' => array( 'view', 'edit' ), |
|
| 42 | + 'readonly' => true, |
|
| 43 | + ), |
|
| 44 | + |
|
| 45 | + 'date_created' => array( |
|
| 46 | + 'description' => __( "The date the item was created, in the site's timezone.", 'invoicing' ), |
|
| 47 | + 'type' => 'string', |
|
| 48 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 49 | + ), |
|
| 50 | + |
|
| 51 | + 'date_created_gmt' => array( |
|
| 52 | + 'description' => __( 'The GMT date the item was created.', 'invoicing' ), |
|
| 53 | + 'type' => 'string', |
|
| 54 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 55 | + 'readonly' => true, |
|
| 56 | + ), |
|
| 57 | + |
|
| 58 | + 'date_modified' => array( |
|
| 59 | + 'description' => __( "The date the item was last modified, in the site's timezone.", 'invoicing' ), |
|
| 60 | + 'type' => 'string', |
|
| 61 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 62 | + 'readonly' => true, |
|
| 63 | + ), |
|
| 64 | + |
|
| 65 | + 'date_modified_gmt' => array( |
|
| 66 | + 'description' => __( 'The GMT date the item was last modified.', 'invoicing' ), |
|
| 67 | + 'type' => 'string', |
|
| 68 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 69 | + 'readonly' => true, |
|
| 70 | + ), |
|
| 71 | + |
|
| 72 | + 'name' => array( |
|
| 73 | + 'description' => __( "The item's name.", 'invoicing' ), |
|
| 74 | + 'type' => 'string', |
|
| 75 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 76 | + 'required' => true, |
|
| 77 | + ), |
|
| 78 | + |
|
| 79 | + 'description' => array( |
|
| 80 | + 'description' => __( "The item's description.", 'invoicing' ), |
|
| 81 | + 'type' => 'string', |
|
| 82 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 83 | + ), |
|
| 84 | + |
|
| 85 | + 'owner' => array( |
|
| 86 | + 'description' => __( 'The owner of the item (user id).', 'invoicing' ), |
|
| 87 | + 'type' => 'integer', |
|
| 88 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 89 | + ), |
|
| 90 | + |
|
| 91 | + 'price' => array( |
|
| 92 | + 'description' => __( 'The price of the item.', 'invoicing' ), |
|
| 93 | + 'type' => 'number', |
|
| 94 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 95 | + 'required' => true, |
|
| 96 | + ), |
|
| 97 | + |
|
| 98 | + 'the_price' => array( |
|
| 99 | + 'description' => __( 'The formatted price of the item.', 'invoicing' ), |
|
| 100 | + 'type' => 'string', |
|
| 101 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 102 | + 'readonly' => true, |
|
| 103 | + ), |
|
| 104 | + |
|
| 105 | + 'type' => array( |
|
| 106 | + 'description' => __( 'The item type.', 'invoicing' ), |
|
| 107 | + 'type' => 'string', |
|
| 108 | + 'enum' => wpinv_item_types(), |
|
| 109 | + 'default' => 'custom', |
|
| 110 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 111 | + ), |
|
| 112 | + |
|
| 113 | + 'vat_rule' => array( |
|
| 114 | + 'description' => __( 'VAT rule applied to the item.', 'invoicing' ), |
|
| 115 | + 'type' => 'string', |
|
| 116 | + 'enum' => array_keys( getpaid_get_tax_rules() ), |
|
| 117 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 118 | + ), |
|
| 119 | + |
|
| 120 | + 'vat_class' => array( |
|
| 121 | + 'description' => __( 'VAT class for the item.', 'invoicing' ), |
|
| 122 | + 'type' => 'string', |
|
| 123 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 124 | + 'enum' => array_keys( getpaid_get_tax_classes() ), |
|
| 125 | + ), |
|
| 126 | + |
|
| 127 | + 'custom_id' => array( |
|
| 128 | + 'description' => __( 'Custom id for the item.', 'invoicing' ), |
|
| 129 | + 'type' => 'string', |
|
| 130 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 131 | + ), |
|
| 132 | 132 | |
| 133 | - 'custom_name' => array( |
|
| 134 | - 'description' => __( 'Custom name for the item.', 'invoicing' ), |
|
| 135 | - 'type' => 'string', |
|
| 136 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 137 | - ), |
|
| 138 | - |
|
| 139 | - 'custom_singular_name' => array( |
|
| 140 | - 'description' => __( 'Custom singular name for the item.', 'invoicing' ), |
|
| 141 | - 'type' => 'string', |
|
| 142 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 143 | - ), |
|
| 144 | - |
|
| 145 | - 'is_dynamic_pricing' => array( |
|
| 146 | - 'description' => __( 'Whether or not customers can enter their own prices when checking out.', 'invoicing' ), |
|
| 147 | - 'type' => 'integer', |
|
| 148 | - 'enum' => array( 0, 1 ), |
|
| 149 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 150 | - ), |
|
| 151 | - |
|
| 152 | - 'minimum_price' => array( |
|
| 153 | - 'description' => __( 'For dynamic prices, this is the minimum price that a user can set.', 'invoicing' ), |
|
| 154 | - 'type' => 'number', |
|
| 155 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 156 | - ), |
|
| 157 | - |
|
| 158 | - 'is_recurring' => array( |
|
| 159 | - 'description' => __( 'Whether or not this is a subscription item.', 'invoicing' ), |
|
| 160 | - 'type' => 'integer', |
|
| 161 | - 'enum' => array( 0, 1 ), |
|
| 162 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 163 | - ), |
|
| 164 | - |
|
| 165 | - 'initial_price' => array( |
|
| 166 | - 'description' => __( 'The initial price of the item.', 'invoicing' ), |
|
| 167 | - 'type' => 'number', |
|
| 168 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 169 | - 'readonly' => true, |
|
| 170 | - ), |
|
| 171 | - |
|
| 172 | - 'the_initial_price' => array( |
|
| 173 | - 'description' => __( 'The formatted initial price of the item.', 'invoicing' ), |
|
| 174 | - 'type' => 'string', |
|
| 175 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 176 | - 'readonly' => true, |
|
| 177 | - ), |
|
| 178 | - |
|
| 179 | - 'recurring_price' => array( |
|
| 180 | - 'description' => __( 'The recurring price of the item.', 'invoicing' ), |
|
| 181 | - 'type' => 'number', |
|
| 182 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 183 | - 'readonly' => true, |
|
| 184 | - ), |
|
| 185 | - |
|
| 186 | - 'the_recurring_price' => array( |
|
| 187 | - 'description' => __( 'The formatted recurring price of the item.', 'invoicing' ), |
|
| 188 | - 'type' => 'string', |
|
| 189 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 190 | - 'readonly' => true, |
|
| 191 | - ), |
|
| 192 | - |
|
| 193 | - 'recurring_period' => array( |
|
| 194 | - 'description' => __( 'The recurring period for a recurring item.', 'invoicing' ), |
|
| 195 | - 'type' => 'string', |
|
| 196 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 197 | - 'enum' => array( 'D', 'W', 'M', 'Y' ), |
|
| 198 | - ), |
|
| 199 | - |
|
| 200 | - 'recurring_interval' => array( |
|
| 201 | - 'description' => __( 'The recurring interval for a subscription item.', 'invoicing' ), |
|
| 202 | - 'type' => 'integer', |
|
| 203 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 204 | - ), |
|
| 205 | - |
|
| 206 | - 'recurring_limit' => array( |
|
| 207 | - 'description' => __( 'The maximum number of renewals for a subscription item.', 'invoicing' ), |
|
| 208 | - 'type' => 'integer', |
|
| 209 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 210 | - ), |
|
| 211 | - |
|
| 212 | - 'is_free_trial' => array( |
|
| 213 | - 'description' => __( 'Whether the item has a free trial period.', 'invoicing' ), |
|
| 214 | - 'type' => 'integer', |
|
| 215 | - 'enum' => array( 0, 1 ), |
|
| 216 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 217 | - ), |
|
| 218 | - |
|
| 219 | - 'trial_period' => array( |
|
| 220 | - 'description' => __( 'The trial period.', 'invoicing' ), |
|
| 221 | - 'type' => 'string', |
|
| 222 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 223 | - 'enum' => array( 'D', 'W', 'M', 'Y' ), |
|
| 224 | - ), |
|
| 225 | - |
|
| 226 | - 'trial_interval' => array( |
|
| 227 | - 'description' => __( 'The trial interval.', 'invoicing' ), |
|
| 228 | - 'type' => 'integer', |
|
| 229 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 230 | - ), |
|
| 231 | - |
|
| 232 | - 'first_renewal_date' => array( |
|
| 233 | - 'description' => __( 'The first renewal date in case the item was to be bought today.', 'invoicing' ), |
|
| 234 | - 'type' => 'string', |
|
| 235 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 236 | - 'readonly' => true, |
|
| 237 | - ), |
|
| 238 | - |
|
| 239 | - 'edit_url' => array( |
|
| 240 | - 'description' => __( 'The URL to edit an item.', 'invoicing' ), |
|
| 241 | - 'type' => 'string', |
|
| 242 | - 'context' => array( 'view', 'edit', 'embed' ), |
|
| 243 | - 'readonly' => true, |
|
| 244 | - ), |
|
| 133 | + 'custom_name' => array( |
|
| 134 | + 'description' => __( 'Custom name for the item.', 'invoicing' ), |
|
| 135 | + 'type' => 'string', |
|
| 136 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 137 | + ), |
|
| 138 | + |
|
| 139 | + 'custom_singular_name' => array( |
|
| 140 | + 'description' => __( 'Custom singular name for the item.', 'invoicing' ), |
|
| 141 | + 'type' => 'string', |
|
| 142 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 143 | + ), |
|
| 144 | + |
|
| 145 | + 'is_dynamic_pricing' => array( |
|
| 146 | + 'description' => __( 'Whether or not customers can enter their own prices when checking out.', 'invoicing' ), |
|
| 147 | + 'type' => 'integer', |
|
| 148 | + 'enum' => array( 0, 1 ), |
|
| 149 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 150 | + ), |
|
| 151 | + |
|
| 152 | + 'minimum_price' => array( |
|
| 153 | + 'description' => __( 'For dynamic prices, this is the minimum price that a user can set.', 'invoicing' ), |
|
| 154 | + 'type' => 'number', |
|
| 155 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 156 | + ), |
|
| 157 | + |
|
| 158 | + 'is_recurring' => array( |
|
| 159 | + 'description' => __( 'Whether or not this is a subscription item.', 'invoicing' ), |
|
| 160 | + 'type' => 'integer', |
|
| 161 | + 'enum' => array( 0, 1 ), |
|
| 162 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 163 | + ), |
|
| 164 | + |
|
| 165 | + 'initial_price' => array( |
|
| 166 | + 'description' => __( 'The initial price of the item.', 'invoicing' ), |
|
| 167 | + 'type' => 'number', |
|
| 168 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 169 | + 'readonly' => true, |
|
| 170 | + ), |
|
| 171 | + |
|
| 172 | + 'the_initial_price' => array( |
|
| 173 | + 'description' => __( 'The formatted initial price of the item.', 'invoicing' ), |
|
| 174 | + 'type' => 'string', |
|
| 175 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 176 | + 'readonly' => true, |
|
| 177 | + ), |
|
| 178 | + |
|
| 179 | + 'recurring_price' => array( |
|
| 180 | + 'description' => __( 'The recurring price of the item.', 'invoicing' ), |
|
| 181 | + 'type' => 'number', |
|
| 182 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 183 | + 'readonly' => true, |
|
| 184 | + ), |
|
| 185 | + |
|
| 186 | + 'the_recurring_price' => array( |
|
| 187 | + 'description' => __( 'The formatted recurring price of the item.', 'invoicing' ), |
|
| 188 | + 'type' => 'string', |
|
| 189 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 190 | + 'readonly' => true, |
|
| 191 | + ), |
|
| 192 | + |
|
| 193 | + 'recurring_period' => array( |
|
| 194 | + 'description' => __( 'The recurring period for a recurring item.', 'invoicing' ), |
|
| 195 | + 'type' => 'string', |
|
| 196 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 197 | + 'enum' => array( 'D', 'W', 'M', 'Y' ), |
|
| 198 | + ), |
|
| 199 | + |
|
| 200 | + 'recurring_interval' => array( |
|
| 201 | + 'description' => __( 'The recurring interval for a subscription item.', 'invoicing' ), |
|
| 202 | + 'type' => 'integer', |
|
| 203 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 204 | + ), |
|
| 205 | + |
|
| 206 | + 'recurring_limit' => array( |
|
| 207 | + 'description' => __( 'The maximum number of renewals for a subscription item.', 'invoicing' ), |
|
| 208 | + 'type' => 'integer', |
|
| 209 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 210 | + ), |
|
| 211 | + |
|
| 212 | + 'is_free_trial' => array( |
|
| 213 | + 'description' => __( 'Whether the item has a free trial period.', 'invoicing' ), |
|
| 214 | + 'type' => 'integer', |
|
| 215 | + 'enum' => array( 0, 1 ), |
|
| 216 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 217 | + ), |
|
| 218 | + |
|
| 219 | + 'trial_period' => array( |
|
| 220 | + 'description' => __( 'The trial period.', 'invoicing' ), |
|
| 221 | + 'type' => 'string', |
|
| 222 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 223 | + 'enum' => array( 'D', 'W', 'M', 'Y' ), |
|
| 224 | + ), |
|
| 225 | + |
|
| 226 | + 'trial_interval' => array( |
|
| 227 | + 'description' => __( 'The trial interval.', 'invoicing' ), |
|
| 228 | + 'type' => 'integer', |
|
| 229 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 230 | + ), |
|
| 231 | + |
|
| 232 | + 'first_renewal_date' => array( |
|
| 233 | + 'description' => __( 'The first renewal date in case the item was to be bought today.', 'invoicing' ), |
|
| 234 | + 'type' => 'string', |
|
| 235 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 236 | + 'readonly' => true, |
|
| 237 | + ), |
|
| 238 | + |
|
| 239 | + 'edit_url' => array( |
|
| 240 | + 'description' => __( 'The URL to edit an item.', 'invoicing' ), |
|
| 241 | + 'type' => 'string', |
|
| 242 | + 'context' => array( 'view', 'edit', 'embed' ), |
|
| 243 | + 'readonly' => true, |
|
| 244 | + ), |
|
| 245 | 245 | ); |
@@ -13,7 +13,7 @@ discard block |
||
| 13 | 13 | * Bail if we are not in WP. |
| 14 | 14 | */ |
| 15 | 15 | if ( ! defined( 'ABSPATH' ) ) { |
| 16 | - exit; |
|
| 16 | + exit; |
|
| 17 | 17 | } |
| 18 | 18 | |
| 19 | 19 | /** |
@@ -21,201 +21,201 @@ discard block |
||
| 21 | 21 | */ |
| 22 | 22 | if ( ! class_exists( 'AyeCode_UI_Settings' ) ) { |
| 23 | 23 | |
| 24 | - /** |
|
| 25 | - * A Class to be able to change settings for Font Awesome. |
|
| 26 | - * |
|
| 27 | - * Class AyeCode_UI_Settings |
|
| 28 | - * @ver 1.0.0 |
|
| 29 | - * @todo decide how to implement textdomain |
|
| 30 | - */ |
|
| 31 | - class AyeCode_UI_Settings { |
|
| 32 | - |
|
| 33 | - /** |
|
| 34 | - * Class version version. |
|
| 35 | - * |
|
| 36 | - * @var string |
|
| 37 | - */ |
|
| 38 | - public $version = '1.0.1'; |
|
| 39 | - |
|
| 40 | - /** |
|
| 41 | - * Class textdomain. |
|
| 42 | - * |
|
| 43 | - * @var string |
|
| 44 | - */ |
|
| 45 | - public $textdomain = 'aui'; |
|
| 46 | - |
|
| 47 | - /** |
|
| 48 | - * Latest version of Bootstrap at time of publish published. |
|
| 49 | - * |
|
| 50 | - * @var string |
|
| 51 | - */ |
|
| 52 | - public $latest = "4.5.3"; |
|
| 53 | - |
|
| 54 | - /** |
|
| 55 | - * Current version of select2 being used. |
|
| 56 | - * |
|
| 57 | - * @var string |
|
| 58 | - */ |
|
| 59 | - public $select2_version = "4.0.11"; |
|
| 60 | - |
|
| 61 | - /** |
|
| 62 | - * The title. |
|
| 63 | - * |
|
| 64 | - * @var string |
|
| 65 | - */ |
|
| 66 | - public $name = 'AyeCode UI'; |
|
| 67 | - |
|
| 68 | - /** |
|
| 69 | - * The relative url to the assets. |
|
| 70 | - * |
|
| 71 | - * @var string |
|
| 72 | - */ |
|
| 73 | - public $url = ''; |
|
| 74 | - |
|
| 75 | - /** |
|
| 76 | - * Holds the settings values. |
|
| 77 | - * |
|
| 78 | - * @var array |
|
| 79 | - */ |
|
| 80 | - private $settings; |
|
| 81 | - |
|
| 82 | - /** |
|
| 83 | - * AyeCode_UI_Settings instance. |
|
| 84 | - * |
|
| 85 | - * @access private |
|
| 86 | - * @since 1.0.0 |
|
| 87 | - * @var AyeCode_UI_Settings There can be only one! |
|
| 88 | - */ |
|
| 89 | - private static $instance = null; |
|
| 90 | - |
|
| 91 | - /** |
|
| 92 | - * Main AyeCode_UI_Settings Instance. |
|
| 93 | - * |
|
| 94 | - * Ensures only one instance of AyeCode_UI_Settings is loaded or can be loaded. |
|
| 95 | - * |
|
| 96 | - * @since 1.0.0 |
|
| 97 | - * @static |
|
| 98 | - * @return AyeCode_UI_Settings - Main instance. |
|
| 99 | - */ |
|
| 100 | - public static function instance() { |
|
| 101 | - if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) { |
|
| 102 | - |
|
| 103 | - self::$instance = new AyeCode_UI_Settings; |
|
| 104 | - |
|
| 105 | - add_action( 'init', array( self::$instance, 'init' ) ); // set settings |
|
| 106 | - |
|
| 107 | - if ( is_admin() ) { |
|
| 108 | - add_action( 'admin_menu', array( self::$instance, 'menu_item' ) ); |
|
| 109 | - add_action( 'admin_init', array( self::$instance, 'register_settings' ) ); |
|
| 110 | - |
|
| 111 | - // Maybe show example page |
|
| 112 | - add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) ); |
|
| 113 | - } |
|
| 24 | + /** |
|
| 25 | + * A Class to be able to change settings for Font Awesome. |
|
| 26 | + * |
|
| 27 | + * Class AyeCode_UI_Settings |
|
| 28 | + * @ver 1.0.0 |
|
| 29 | + * @todo decide how to implement textdomain |
|
| 30 | + */ |
|
| 31 | + class AyeCode_UI_Settings { |
|
| 32 | + |
|
| 33 | + /** |
|
| 34 | + * Class version version. |
|
| 35 | + * |
|
| 36 | + * @var string |
|
| 37 | + */ |
|
| 38 | + public $version = '1.0.1'; |
|
| 39 | + |
|
| 40 | + /** |
|
| 41 | + * Class textdomain. |
|
| 42 | + * |
|
| 43 | + * @var string |
|
| 44 | + */ |
|
| 45 | + public $textdomain = 'aui'; |
|
| 46 | + |
|
| 47 | + /** |
|
| 48 | + * Latest version of Bootstrap at time of publish published. |
|
| 49 | + * |
|
| 50 | + * @var string |
|
| 51 | + */ |
|
| 52 | + public $latest = "4.5.3"; |
|
| 53 | + |
|
| 54 | + /** |
|
| 55 | + * Current version of select2 being used. |
|
| 56 | + * |
|
| 57 | + * @var string |
|
| 58 | + */ |
|
| 59 | + public $select2_version = "4.0.11"; |
|
| 60 | + |
|
| 61 | + /** |
|
| 62 | + * The title. |
|
| 63 | + * |
|
| 64 | + * @var string |
|
| 65 | + */ |
|
| 66 | + public $name = 'AyeCode UI'; |
|
| 67 | + |
|
| 68 | + /** |
|
| 69 | + * The relative url to the assets. |
|
| 70 | + * |
|
| 71 | + * @var string |
|
| 72 | + */ |
|
| 73 | + public $url = ''; |
|
| 74 | + |
|
| 75 | + /** |
|
| 76 | + * Holds the settings values. |
|
| 77 | + * |
|
| 78 | + * @var array |
|
| 79 | + */ |
|
| 80 | + private $settings; |
|
| 81 | + |
|
| 82 | + /** |
|
| 83 | + * AyeCode_UI_Settings instance. |
|
| 84 | + * |
|
| 85 | + * @access private |
|
| 86 | + * @since 1.0.0 |
|
| 87 | + * @var AyeCode_UI_Settings There can be only one! |
|
| 88 | + */ |
|
| 89 | + private static $instance = null; |
|
| 90 | + |
|
| 91 | + /** |
|
| 92 | + * Main AyeCode_UI_Settings Instance. |
|
| 93 | + * |
|
| 94 | + * Ensures only one instance of AyeCode_UI_Settings is loaded or can be loaded. |
|
| 95 | + * |
|
| 96 | + * @since 1.0.0 |
|
| 97 | + * @static |
|
| 98 | + * @return AyeCode_UI_Settings - Main instance. |
|
| 99 | + */ |
|
| 100 | + public static function instance() { |
|
| 101 | + if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) { |
|
| 102 | + |
|
| 103 | + self::$instance = new AyeCode_UI_Settings; |
|
| 104 | + |
|
| 105 | + add_action( 'init', array( self::$instance, 'init' ) ); // set settings |
|
| 106 | + |
|
| 107 | + if ( is_admin() ) { |
|
| 108 | + add_action( 'admin_menu', array( self::$instance, 'menu_item' ) ); |
|
| 109 | + add_action( 'admin_init', array( self::$instance, 'register_settings' ) ); |
|
| 110 | + |
|
| 111 | + // Maybe show example page |
|
| 112 | + add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) ); |
|
| 113 | + } |
|
| 114 | 114 | |
| 115 | - add_action( 'customize_register', array( self::$instance, 'customizer_settings' )); |
|
| 116 | - |
|
| 117 | - do_action( 'ayecode_ui_settings_loaded' ); |
|
| 118 | - } |
|
| 119 | - |
|
| 120 | - return self::$instance; |
|
| 121 | - } |
|
| 122 | - |
|
| 123 | - /** |
|
| 124 | - * Setup some constants. |
|
| 125 | - */ |
|
| 126 | - public function constants(){ |
|
| 127 | - define('AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be"); |
|
| 128 | - define('AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d'); |
|
| 129 | - if (!defined('AUI_PRIMARY_COLOR')) define('AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL); |
|
| 130 | - if (!defined('AUI_SECONDARY_COLOR')) define('AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL); |
|
| 131 | - } |
|
| 132 | - |
|
| 133 | - /** |
|
| 134 | - * Initiate the settings and add the required action hooks. |
|
| 135 | - */ |
|
| 136 | - public function init() { |
|
| 137 | - $this->constants(); |
|
| 138 | - $this->settings = $this->get_settings(); |
|
| 139 | - $this->url = $this->get_url(); |
|
| 140 | - |
|
| 141 | - /** |
|
| 142 | - * Maybe load CSS |
|
| 143 | - * |
|
| 144 | - * We load super early in case there is a theme version that might change the colors |
|
| 145 | - */ |
|
| 146 | - if ( $this->settings['css'] ) { |
|
| 147 | - add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), 1 ); |
|
| 148 | - } |
|
| 149 | - if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) { |
|
| 150 | - add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 ); |
|
| 151 | - } |
|
| 152 | - |
|
| 153 | - // maybe load JS |
|
| 154 | - if ( $this->settings['js'] ) { |
|
| 155 | - add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 ); |
|
| 156 | - } |
|
| 157 | - if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) { |
|
| 158 | - add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 ); |
|
| 159 | - } |
|
| 160 | - |
|
| 161 | - // Maybe set the HTML font size |
|
| 162 | - if ( $this->settings['html_font_size'] ) { |
|
| 163 | - add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 ); |
|
| 164 | - } |
|
| 165 | - |
|
| 166 | - |
|
| 167 | - } |
|
| 168 | - |
|
| 169 | - /** |
|
| 170 | - * Check if we should load the admin scripts or not. |
|
| 171 | - * |
|
| 172 | - * @return bool |
|
| 173 | - */ |
|
| 174 | - public function load_admin_scripts(){ |
|
| 175 | - $result = true; |
|
| 176 | - |
|
| 177 | - if(!empty($this->settings['disable_admin'])){ |
|
| 178 | - $url_parts = explode("\n",$this->settings['disable_admin']); |
|
| 179 | - foreach($url_parts as $part){ |
|
| 180 | - if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){ |
|
| 181 | - return false; // return early, no point checking further |
|
| 182 | - } |
|
| 183 | - } |
|
| 184 | - } |
|
| 115 | + add_action( 'customize_register', array( self::$instance, 'customizer_settings' )); |
|
| 116 | + |
|
| 117 | + do_action( 'ayecode_ui_settings_loaded' ); |
|
| 118 | + } |
|
| 119 | + |
|
| 120 | + return self::$instance; |
|
| 121 | + } |
|
| 122 | + |
|
| 123 | + /** |
|
| 124 | + * Setup some constants. |
|
| 125 | + */ |
|
| 126 | + public function constants(){ |
|
| 127 | + define('AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be"); |
|
| 128 | + define('AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d'); |
|
| 129 | + if (!defined('AUI_PRIMARY_COLOR')) define('AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL); |
|
| 130 | + if (!defined('AUI_SECONDARY_COLOR')) define('AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL); |
|
| 131 | + } |
|
| 132 | + |
|
| 133 | + /** |
|
| 134 | + * Initiate the settings and add the required action hooks. |
|
| 135 | + */ |
|
| 136 | + public function init() { |
|
| 137 | + $this->constants(); |
|
| 138 | + $this->settings = $this->get_settings(); |
|
| 139 | + $this->url = $this->get_url(); |
|
| 140 | + |
|
| 141 | + /** |
|
| 142 | + * Maybe load CSS |
|
| 143 | + * |
|
| 144 | + * We load super early in case there is a theme version that might change the colors |
|
| 145 | + */ |
|
| 146 | + if ( $this->settings['css'] ) { |
|
| 147 | + add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), 1 ); |
|
| 148 | + } |
|
| 149 | + if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) { |
|
| 150 | + add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 ); |
|
| 151 | + } |
|
| 152 | + |
|
| 153 | + // maybe load JS |
|
| 154 | + if ( $this->settings['js'] ) { |
|
| 155 | + add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 ); |
|
| 156 | + } |
|
| 157 | + if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) { |
|
| 158 | + add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 ); |
|
| 159 | + } |
|
| 160 | + |
|
| 161 | + // Maybe set the HTML font size |
|
| 162 | + if ( $this->settings['html_font_size'] ) { |
|
| 163 | + add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 ); |
|
| 164 | + } |
|
| 165 | + |
|
| 166 | + |
|
| 167 | + } |
|
| 168 | + |
|
| 169 | + /** |
|
| 170 | + * Check if we should load the admin scripts or not. |
|
| 171 | + * |
|
| 172 | + * @return bool |
|
| 173 | + */ |
|
| 174 | + public function load_admin_scripts(){ |
|
| 175 | + $result = true; |
|
| 176 | + |
|
| 177 | + if(!empty($this->settings['disable_admin'])){ |
|
| 178 | + $url_parts = explode("\n",$this->settings['disable_admin']); |
|
| 179 | + foreach($url_parts as $part){ |
|
| 180 | + if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){ |
|
| 181 | + return false; // return early, no point checking further |
|
| 182 | + } |
|
| 183 | + } |
|
| 184 | + } |
|
| 185 | 185 | |
| 186 | - return $result; |
|
| 187 | - } |
|
| 186 | + return $result; |
|
| 187 | + } |
|
| 188 | 188 | |
| 189 | - /** |
|
| 190 | - * Add a html font size to the footer. |
|
| 191 | - */ |
|
| 192 | - public function html_font_size(){ |
|
| 193 | - $this->settings = $this->get_settings(); |
|
| 194 | - echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>"; |
|
| 195 | - } |
|
| 189 | + /** |
|
| 190 | + * Add a html font size to the footer. |
|
| 191 | + */ |
|
| 192 | + public function html_font_size(){ |
|
| 193 | + $this->settings = $this->get_settings(); |
|
| 194 | + echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>"; |
|
| 195 | + } |
|
| 196 | 196 | |
| 197 | - /** |
|
| 198 | - * Adds the styles. |
|
| 199 | - */ |
|
| 200 | - public function enqueue_style() { |
|
| 197 | + /** |
|
| 198 | + * Adds the styles. |
|
| 199 | + */ |
|
| 200 | + public function enqueue_style() { |
|
| 201 | 201 | |
| 202 | - $css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend'; |
|
| 202 | + $css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend'; |
|
| 203 | 203 | |
| 204 | - $rtl = is_rtl() ? '-rtl' : ''; |
|
| 204 | + $rtl = is_rtl() ? '-rtl' : ''; |
|
| 205 | 205 | |
| 206 | - if($this->settings[$css_setting]){ |
|
| 207 | - $compatibility = $this->settings[$css_setting]=='core' ? false : true; |
|
| 208 | - $url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css'; |
|
| 209 | - wp_register_style( 'ayecode-ui', $url, array(), $this->latest ); |
|
| 210 | - wp_enqueue_style( 'ayecode-ui' ); |
|
| 206 | + if($this->settings[$css_setting]){ |
|
| 207 | + $compatibility = $this->settings[$css_setting]=='core' ? false : true; |
|
| 208 | + $url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css'; |
|
| 209 | + wp_register_style( 'ayecode-ui', $url, array(), $this->latest ); |
|
| 210 | + wp_enqueue_style( 'ayecode-ui' ); |
|
| 211 | 211 | |
| 212 | - // flatpickr |
|
| 213 | - wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest ); |
|
| 212 | + // flatpickr |
|
| 213 | + wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest ); |
|
| 214 | 214 | |
| 215 | 215 | |
| 216 | - // fix some wp-admin issues |
|
| 217 | - if(is_admin()){ |
|
| 218 | - $custom_css = " |
|
| 216 | + // fix some wp-admin issues |
|
| 217 | + if(is_admin()){ |
|
| 218 | + $custom_css = " |
|
| 219 | 219 | body{ |
| 220 | 220 | background-color: #f1f1f1; |
| 221 | 221 | font-family: -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif; |
@@ -251,29 +251,29 @@ discard block |
||
| 251 | 251 | } |
| 252 | 252 | "; |
| 253 | 253 | |
| 254 | - // @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377 |
|
| 255 | - $custom_css .= " |
|
| 254 | + // @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377 |
|
| 255 | + $custom_css .= " |
|
| 256 | 256 | .edit-post-sidebar input[type=color].components-text-control__input{ |
| 257 | 257 | padding: 0; |
| 258 | 258 | } |
| 259 | 259 | "; |
| 260 | - wp_add_inline_style( 'ayecode-ui', $custom_css ); |
|
| 261 | - } |
|
| 260 | + wp_add_inline_style( 'ayecode-ui', $custom_css ); |
|
| 261 | + } |
|
| 262 | 262 | |
| 263 | - // custom changes |
|
| 264 | - wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) ); |
|
| 263 | + // custom changes |
|
| 264 | + wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) ); |
|
| 265 | 265 | |
| 266 | - } |
|
| 267 | - } |
|
| 266 | + } |
|
| 267 | + } |
|
| 268 | 268 | |
| 269 | - /** |
|
| 270 | - * Get inline script used if bootstrap enqueued |
|
| 271 | - * |
|
| 272 | - * If this remains small then its best to use this than to add another JS file. |
|
| 273 | - */ |
|
| 274 | - public function inline_script(){ |
|
| 275 | - ob_start(); |
|
| 276 | - ?> |
|
| 269 | + /** |
|
| 270 | + * Get inline script used if bootstrap enqueued |
|
| 271 | + * |
|
| 272 | + * If this remains small then its best to use this than to add another JS file. |
|
| 273 | + */ |
|
| 274 | + public function inline_script(){ |
|
| 275 | + ob_start(); |
|
| 276 | + ?> |
|
| 277 | 277 | <script> |
| 278 | 278 | |
| 279 | 279 | /** |
@@ -760,25 +760,25 @@ discard block |
||
| 760 | 760 | |
| 761 | 761 | </script> |
| 762 | 762 | <?php |
| 763 | - $output = ob_get_clean(); |
|
| 763 | + $output = ob_get_clean(); |
|
| 764 | 764 | |
| 765 | - /* |
|
| 765 | + /* |
|
| 766 | 766 | * We only add the <script> tags for code highlighting, so we strip them from the output. |
| 767 | 767 | */ |
| 768 | - return str_replace( array( |
|
| 769 | - '<script>', |
|
| 770 | - '</script>' |
|
| 771 | - ), '', $output ); |
|
| 772 | - } |
|
| 773 | - |
|
| 774 | - /** |
|
| 775 | - * Get inline script used if bootstrap file browser enqueued. |
|
| 776 | - * |
|
| 777 | - * If this remains small then its best to use this than to add another JS file. |
|
| 778 | - */ |
|
| 779 | - public function inline_script_file_browser(){ |
|
| 780 | - ob_start(); |
|
| 781 | - ?> |
|
| 768 | + return str_replace( array( |
|
| 769 | + '<script>', |
|
| 770 | + '</script>' |
|
| 771 | + ), '', $output ); |
|
| 772 | + } |
|
| 773 | + |
|
| 774 | + /** |
|
| 775 | + * Get inline script used if bootstrap file browser enqueued. |
|
| 776 | + * |
|
| 777 | + * If this remains small then its best to use this than to add another JS file. |
|
| 778 | + */ |
|
| 779 | + public function inline_script_file_browser(){ |
|
| 780 | + ob_start(); |
|
| 781 | + ?> |
|
| 782 | 782 | <script> |
| 783 | 783 | // run on doc ready |
| 784 | 784 | jQuery(document).ready(function () { |
@@ -786,184 +786,184 @@ discard block |
||
| 786 | 786 | }); |
| 787 | 787 | </script> |
| 788 | 788 | <?php |
| 789 | - $output = ob_get_clean(); |
|
| 789 | + $output = ob_get_clean(); |
|
| 790 | 790 | |
| 791 | - /* |
|
| 791 | + /* |
|
| 792 | 792 | * We only add the <script> tags for code highlighting, so we strip them from the output. |
| 793 | 793 | */ |
| 794 | - return str_replace( array( |
|
| 795 | - '<script>', |
|
| 796 | - '</script>' |
|
| 797 | - ), '', $output ); |
|
| 798 | - } |
|
| 799 | - |
|
| 800 | - /** |
|
| 801 | - * Adds the Font Awesome JS. |
|
| 802 | - */ |
|
| 803 | - public function enqueue_scripts() { |
|
| 804 | - |
|
| 805 | - $js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend'; |
|
| 806 | - |
|
| 807 | - // select2 |
|
| 808 | - wp_register_script( 'select2', $this->url.'assets/js/select2.min.js', array('jquery'), $this->select2_version ); |
|
| 809 | - |
|
| 810 | - // flatpickr |
|
| 811 | - wp_register_script( 'flatpickr', $this->url.'assets/js/flatpickr.min.js', array(), $this->latest ); |
|
| 812 | - |
|
| 813 | - // Bootstrap file browser |
|
| 814 | - wp_register_script( 'aui-custom-file-input', $url = $this->url.'assets/js/bs-custom-file-input.min.js', array('jquery'), $this->select2_version ); |
|
| 815 | - wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() ); |
|
| 816 | - |
|
| 817 | - $load_inline = false; |
|
| 818 | - |
|
| 819 | - if($this->settings[$js_setting]=='core-popper'){ |
|
| 820 | - // Bootstrap bundle |
|
| 821 | - $url = $this->url.'assets/js/bootstrap.bundle.min.js'; |
|
| 822 | - wp_register_script( 'bootstrap-js-bundle', $url, array('select2','jquery'), $this->latest ); |
|
| 823 | - // if in admin then add to footer for compatibility. |
|
| 824 | - is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle'); |
|
| 825 | - $script = $this->inline_script(); |
|
| 826 | - wp_add_inline_script( 'bootstrap-js-bundle', $script ); |
|
| 827 | - }elseif($this->settings[$js_setting]=='popper'){ |
|
| 828 | - $url = $this->url.'assets/js/popper.min.js'; |
|
| 829 | - wp_register_script( 'bootstrap-js-popper', $url, array('select2','jquery'), $this->latest ); |
|
| 830 | - wp_enqueue_script( 'bootstrap-js-popper' ); |
|
| 831 | - $load_inline = true; |
|
| 832 | - }else{ |
|
| 833 | - $load_inline = true; |
|
| 834 | - } |
|
| 835 | - |
|
| 836 | - // Load needed inline scripts by faking the loading of a script if the main script is not being loaded |
|
| 837 | - if($load_inline){ |
|
| 838 | - wp_register_script( 'bootstrap-dummy', '',array('select2','jquery') ); |
|
| 839 | - wp_enqueue_script( 'bootstrap-dummy' ); |
|
| 840 | - $script = $this->inline_script(); |
|
| 841 | - wp_add_inline_script( 'bootstrap-dummy', $script ); |
|
| 842 | - } |
|
| 843 | - |
|
| 844 | - } |
|
| 845 | - |
|
| 846 | - /** |
|
| 847 | - * Enqueue flatpickr if called. |
|
| 848 | - */ |
|
| 849 | - public function enqueue_flatpickr(){ |
|
| 850 | - wp_enqueue_style( 'flatpickr' ); |
|
| 851 | - wp_enqueue_script( 'flatpickr' ); |
|
| 852 | - } |
|
| 853 | - |
|
| 854 | - /** |
|
| 855 | - * Get the url path to the current folder. |
|
| 856 | - * |
|
| 857 | - * @return string |
|
| 858 | - */ |
|
| 859 | - public function get_url() { |
|
| 860 | - |
|
| 861 | - $url = ''; |
|
| 862 | - // check if we are inside a plugin |
|
| 863 | - $file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) ); |
|
| 864 | - |
|
| 865 | - // add check in-case user has changed wp-content dir name. |
|
| 866 | - $wp_content_folder_name = basename(WP_CONTENT_DIR); |
|
| 867 | - $dir_parts = explode("/$wp_content_folder_name/",$file_dir); |
|
| 868 | - $url_parts = explode("/$wp_content_folder_name/",plugins_url()); |
|
| 869 | - |
|
| 870 | - if(!empty($url_parts[0]) && !empty($dir_parts[1])){ |
|
| 871 | - $url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] ); |
|
| 872 | - } |
|
| 873 | - |
|
| 874 | - return $url; |
|
| 875 | - } |
|
| 876 | - |
|
| 877 | - /** |
|
| 878 | - * Register the database settings with WordPress. |
|
| 879 | - */ |
|
| 880 | - public function register_settings() { |
|
| 881 | - register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' ); |
|
| 882 | - } |
|
| 883 | - |
|
| 884 | - /** |
|
| 885 | - * Add the WordPress settings menu item. |
|
| 886 | - * @since 1.0.10 Calling function name direct will fail theme check so we don't. |
|
| 887 | - */ |
|
| 888 | - public function menu_item() { |
|
| 889 | - $menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme |
|
| 890 | - call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array( |
|
| 891 | - $this, |
|
| 892 | - 'settings_page' |
|
| 893 | - ) ); |
|
| 894 | - } |
|
| 895 | - |
|
| 896 | - /** |
|
| 897 | - * Get a list of themes and their default JS settings. |
|
| 898 | - * |
|
| 899 | - * @return array |
|
| 900 | - */ |
|
| 901 | - public function theme_js_settings(){ |
|
| 902 | - return array( |
|
| 903 | - 'ayetheme' => 'popper', |
|
| 904 | - 'listimia' => 'required', |
|
| 905 | - 'listimia_backend' => 'core-popper', |
|
| 906 | - 'avada' => 'required', |
|
| 907 | - ); |
|
| 908 | - } |
|
| 909 | - |
|
| 910 | - /** |
|
| 911 | - * Get the current Font Awesome output settings. |
|
| 912 | - * |
|
| 913 | - * @return array The array of settings. |
|
| 914 | - */ |
|
| 915 | - public function get_settings() { |
|
| 916 | - |
|
| 917 | - $db_settings = get_option( 'ayecode-ui-settings' ); |
|
| 918 | - $js_default = 'core-popper'; |
|
| 919 | - $js_default_backend = $js_default; |
|
| 920 | - |
|
| 921 | - // maybe set defaults (if no settings set) |
|
| 922 | - if(empty($db_settings)){ |
|
| 923 | - $active_theme = strtolower( get_template() ); // active parent theme. |
|
| 924 | - $theme_js_settings = self::theme_js_settings(); |
|
| 925 | - if(isset($theme_js_settings[$active_theme])){ |
|
| 926 | - $js_default = $theme_js_settings[$active_theme]; |
|
| 927 | - $js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default; |
|
| 928 | - } |
|
| 929 | - } |
|
| 930 | - |
|
| 931 | - $defaults = array( |
|
| 932 | - 'css' => 'compatibility', // core, compatibility |
|
| 933 | - 'js' => $js_default, // js to load, core-popper, popper |
|
| 934 | - 'html_font_size' => '16', // js to load, core-popper, popper |
|
| 935 | - 'css_backend' => 'compatibility', // core, compatibility |
|
| 936 | - 'js_backend' => $js_default_backend, // js to load, core-popper, popper |
|
| 937 | - 'disable_admin' => '', // URL snippets to disable loading on admin |
|
| 938 | - ); |
|
| 939 | - |
|
| 940 | - $settings = wp_parse_args( $db_settings, $defaults ); |
|
| 941 | - |
|
| 942 | - /** |
|
| 943 | - * Filter the Bootstrap settings. |
|
| 944 | - * |
|
| 945 | - * @todo if we add this filer people might use it and then it defeates the purpose of this class :/ |
|
| 946 | - */ |
|
| 947 | - return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults ); |
|
| 948 | - } |
|
| 949 | - |
|
| 950 | - |
|
| 951 | - /** |
|
| 952 | - * The settings page html output. |
|
| 953 | - */ |
|
| 954 | - public function settings_page() { |
|
| 955 | - if ( ! current_user_can( 'manage_options' ) ) { |
|
| 956 | - wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) ); |
|
| 957 | - } |
|
| 958 | - ?> |
|
| 794 | + return str_replace( array( |
|
| 795 | + '<script>', |
|
| 796 | + '</script>' |
|
| 797 | + ), '', $output ); |
|
| 798 | + } |
|
| 799 | + |
|
| 800 | + /** |
|
| 801 | + * Adds the Font Awesome JS. |
|
| 802 | + */ |
|
| 803 | + public function enqueue_scripts() { |
|
| 804 | + |
|
| 805 | + $js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend'; |
|
| 806 | + |
|
| 807 | + // select2 |
|
| 808 | + wp_register_script( 'select2', $this->url.'assets/js/select2.min.js', array('jquery'), $this->select2_version ); |
|
| 809 | + |
|
| 810 | + // flatpickr |
|
| 811 | + wp_register_script( 'flatpickr', $this->url.'assets/js/flatpickr.min.js', array(), $this->latest ); |
|
| 812 | + |
|
| 813 | + // Bootstrap file browser |
|
| 814 | + wp_register_script( 'aui-custom-file-input', $url = $this->url.'assets/js/bs-custom-file-input.min.js', array('jquery'), $this->select2_version ); |
|
| 815 | + wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() ); |
|
| 816 | + |
|
| 817 | + $load_inline = false; |
|
| 818 | + |
|
| 819 | + if($this->settings[$js_setting]=='core-popper'){ |
|
| 820 | + // Bootstrap bundle |
|
| 821 | + $url = $this->url.'assets/js/bootstrap.bundle.min.js'; |
|
| 822 | + wp_register_script( 'bootstrap-js-bundle', $url, array('select2','jquery'), $this->latest ); |
|
| 823 | + // if in admin then add to footer for compatibility. |
|
| 824 | + is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle'); |
|
| 825 | + $script = $this->inline_script(); |
|
| 826 | + wp_add_inline_script( 'bootstrap-js-bundle', $script ); |
|
| 827 | + }elseif($this->settings[$js_setting]=='popper'){ |
|
| 828 | + $url = $this->url.'assets/js/popper.min.js'; |
|
| 829 | + wp_register_script( 'bootstrap-js-popper', $url, array('select2','jquery'), $this->latest ); |
|
| 830 | + wp_enqueue_script( 'bootstrap-js-popper' ); |
|
| 831 | + $load_inline = true; |
|
| 832 | + }else{ |
|
| 833 | + $load_inline = true; |
|
| 834 | + } |
|
| 835 | + |
|
| 836 | + // Load needed inline scripts by faking the loading of a script if the main script is not being loaded |
|
| 837 | + if($load_inline){ |
|
| 838 | + wp_register_script( 'bootstrap-dummy', '',array('select2','jquery') ); |
|
| 839 | + wp_enqueue_script( 'bootstrap-dummy' ); |
|
| 840 | + $script = $this->inline_script(); |
|
| 841 | + wp_add_inline_script( 'bootstrap-dummy', $script ); |
|
| 842 | + } |
|
| 843 | + |
|
| 844 | + } |
|
| 845 | + |
|
| 846 | + /** |
|
| 847 | + * Enqueue flatpickr if called. |
|
| 848 | + */ |
|
| 849 | + public function enqueue_flatpickr(){ |
|
| 850 | + wp_enqueue_style( 'flatpickr' ); |
|
| 851 | + wp_enqueue_script( 'flatpickr' ); |
|
| 852 | + } |
|
| 853 | + |
|
| 854 | + /** |
|
| 855 | + * Get the url path to the current folder. |
|
| 856 | + * |
|
| 857 | + * @return string |
|
| 858 | + */ |
|
| 859 | + public function get_url() { |
|
| 860 | + |
|
| 861 | + $url = ''; |
|
| 862 | + // check if we are inside a plugin |
|
| 863 | + $file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) ); |
|
| 864 | + |
|
| 865 | + // add check in-case user has changed wp-content dir name. |
|
| 866 | + $wp_content_folder_name = basename(WP_CONTENT_DIR); |
|
| 867 | + $dir_parts = explode("/$wp_content_folder_name/",$file_dir); |
|
| 868 | + $url_parts = explode("/$wp_content_folder_name/",plugins_url()); |
|
| 869 | + |
|
| 870 | + if(!empty($url_parts[0]) && !empty($dir_parts[1])){ |
|
| 871 | + $url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] ); |
|
| 872 | + } |
|
| 873 | + |
|
| 874 | + return $url; |
|
| 875 | + } |
|
| 876 | + |
|
| 877 | + /** |
|
| 878 | + * Register the database settings with WordPress. |
|
| 879 | + */ |
|
| 880 | + public function register_settings() { |
|
| 881 | + register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' ); |
|
| 882 | + } |
|
| 883 | + |
|
| 884 | + /** |
|
| 885 | + * Add the WordPress settings menu item. |
|
| 886 | + * @since 1.0.10 Calling function name direct will fail theme check so we don't. |
|
| 887 | + */ |
|
| 888 | + public function menu_item() { |
|
| 889 | + $menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme |
|
| 890 | + call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array( |
|
| 891 | + $this, |
|
| 892 | + 'settings_page' |
|
| 893 | + ) ); |
|
| 894 | + } |
|
| 895 | + |
|
| 896 | + /** |
|
| 897 | + * Get a list of themes and their default JS settings. |
|
| 898 | + * |
|
| 899 | + * @return array |
|
| 900 | + */ |
|
| 901 | + public function theme_js_settings(){ |
|
| 902 | + return array( |
|
| 903 | + 'ayetheme' => 'popper', |
|
| 904 | + 'listimia' => 'required', |
|
| 905 | + 'listimia_backend' => 'core-popper', |
|
| 906 | + 'avada' => 'required', |
|
| 907 | + ); |
|
| 908 | + } |
|
| 909 | + |
|
| 910 | + /** |
|
| 911 | + * Get the current Font Awesome output settings. |
|
| 912 | + * |
|
| 913 | + * @return array The array of settings. |
|
| 914 | + */ |
|
| 915 | + public function get_settings() { |
|
| 916 | + |
|
| 917 | + $db_settings = get_option( 'ayecode-ui-settings' ); |
|
| 918 | + $js_default = 'core-popper'; |
|
| 919 | + $js_default_backend = $js_default; |
|
| 920 | + |
|
| 921 | + // maybe set defaults (if no settings set) |
|
| 922 | + if(empty($db_settings)){ |
|
| 923 | + $active_theme = strtolower( get_template() ); // active parent theme. |
|
| 924 | + $theme_js_settings = self::theme_js_settings(); |
|
| 925 | + if(isset($theme_js_settings[$active_theme])){ |
|
| 926 | + $js_default = $theme_js_settings[$active_theme]; |
|
| 927 | + $js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default; |
|
| 928 | + } |
|
| 929 | + } |
|
| 930 | + |
|
| 931 | + $defaults = array( |
|
| 932 | + 'css' => 'compatibility', // core, compatibility |
|
| 933 | + 'js' => $js_default, // js to load, core-popper, popper |
|
| 934 | + 'html_font_size' => '16', // js to load, core-popper, popper |
|
| 935 | + 'css_backend' => 'compatibility', // core, compatibility |
|
| 936 | + 'js_backend' => $js_default_backend, // js to load, core-popper, popper |
|
| 937 | + 'disable_admin' => '', // URL snippets to disable loading on admin |
|
| 938 | + ); |
|
| 939 | + |
|
| 940 | + $settings = wp_parse_args( $db_settings, $defaults ); |
|
| 941 | + |
|
| 942 | + /** |
|
| 943 | + * Filter the Bootstrap settings. |
|
| 944 | + * |
|
| 945 | + * @todo if we add this filer people might use it and then it defeates the purpose of this class :/ |
|
| 946 | + */ |
|
| 947 | + return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults ); |
|
| 948 | + } |
|
| 949 | + |
|
| 950 | + |
|
| 951 | + /** |
|
| 952 | + * The settings page html output. |
|
| 953 | + */ |
|
| 954 | + public function settings_page() { |
|
| 955 | + if ( ! current_user_can( 'manage_options' ) ) { |
|
| 956 | + wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) ); |
|
| 957 | + } |
|
| 958 | + ?> |
|
| 959 | 959 | <div class="wrap"> |
| 960 | 960 | <h1><?php echo $this->name; ?></h1> |
| 961 | 961 | <p><?php _e("Here you can adjust settings if you are having compatibility issues.","aui");?></p> |
| 962 | 962 | <form method="post" action="options.php"> |
| 963 | 963 | <?php |
| 964 | - settings_fields( 'ayecode-ui-settings' ); |
|
| 965 | - do_settings_sections( 'ayecode-ui-settings' ); |
|
| 966 | - ?> |
|
| 964 | + settings_fields( 'ayecode-ui-settings' ); |
|
| 965 | + do_settings_sections( 'ayecode-ui-settings' ); |
|
| 966 | + ?> |
|
| 967 | 967 | |
| 968 | 968 | <h2><?php _e( 'Frontend', 'aui' ); ?></h2> |
| 969 | 969 | <table class="form-table wpbs-table-settings"> |
@@ -1043,55 +1043,55 @@ discard block |
||
| 1043 | 1043 | </table> |
| 1044 | 1044 | |
| 1045 | 1045 | <?php |
| 1046 | - submit_button(); |
|
| 1047 | - ?> |
|
| 1046 | + submit_button(); |
|
| 1047 | + ?> |
|
| 1048 | 1048 | </form> |
| 1049 | 1049 | |
| 1050 | 1050 | <div id="wpbs-version"><?php echo $this->version; ?></div> |
| 1051 | 1051 | </div> |
| 1052 | 1052 | |
| 1053 | 1053 | <?php |
| 1054 | - } |
|
| 1055 | - |
|
| 1056 | - public function customizer_settings($wp_customize){ |
|
| 1057 | - $wp_customize->add_section('aui_settings', array( |
|
| 1058 | - 'title' => __('AyeCode UI','aui'), |
|
| 1059 | - 'priority' => 120, |
|
| 1060 | - )); |
|
| 1061 | - |
|
| 1062 | - // ============================= |
|
| 1063 | - // = Color Picker = |
|
| 1064 | - // ============================= |
|
| 1065 | - $wp_customize->add_setting('aui_options[color_primary]', array( |
|
| 1066 | - 'default' => AUI_PRIMARY_COLOR, |
|
| 1067 | - 'sanitize_callback' => 'sanitize_hex_color', |
|
| 1068 | - 'capability' => 'edit_theme_options', |
|
| 1069 | - 'type' => 'option', |
|
| 1070 | - 'transport' => 'refresh', |
|
| 1071 | - )); |
|
| 1072 | - $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array( |
|
| 1073 | - 'label' => __('Primary Color','aui'), |
|
| 1074 | - 'section' => 'aui_settings', |
|
| 1075 | - 'settings' => 'aui_options[color_primary]', |
|
| 1076 | - ))); |
|
| 1077 | - |
|
| 1078 | - $wp_customize->add_setting('aui_options[color_secondary]', array( |
|
| 1079 | - 'default' => '#6c757d', |
|
| 1080 | - 'sanitize_callback' => 'sanitize_hex_color', |
|
| 1081 | - 'capability' => 'edit_theme_options', |
|
| 1082 | - 'type' => 'option', |
|
| 1083 | - 'transport' => 'refresh', |
|
| 1084 | - )); |
|
| 1085 | - $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array( |
|
| 1086 | - 'label' => __('Secondary Color','aui'), |
|
| 1087 | - 'section' => 'aui_settings', |
|
| 1088 | - 'settings' => 'aui_options[color_secondary]', |
|
| 1089 | - ))); |
|
| 1090 | - } |
|
| 1091 | - |
|
| 1092 | - public static function bs3_compat_css() { |
|
| 1093 | - ob_start(); |
|
| 1094 | - ?> |
|
| 1054 | + } |
|
| 1055 | + |
|
| 1056 | + public function customizer_settings($wp_customize){ |
|
| 1057 | + $wp_customize->add_section('aui_settings', array( |
|
| 1058 | + 'title' => __('AyeCode UI','aui'), |
|
| 1059 | + 'priority' => 120, |
|
| 1060 | + )); |
|
| 1061 | + |
|
| 1062 | + // ============================= |
|
| 1063 | + // = Color Picker = |
|
| 1064 | + // ============================= |
|
| 1065 | + $wp_customize->add_setting('aui_options[color_primary]', array( |
|
| 1066 | + 'default' => AUI_PRIMARY_COLOR, |
|
| 1067 | + 'sanitize_callback' => 'sanitize_hex_color', |
|
| 1068 | + 'capability' => 'edit_theme_options', |
|
| 1069 | + 'type' => 'option', |
|
| 1070 | + 'transport' => 'refresh', |
|
| 1071 | + )); |
|
| 1072 | + $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array( |
|
| 1073 | + 'label' => __('Primary Color','aui'), |
|
| 1074 | + 'section' => 'aui_settings', |
|
| 1075 | + 'settings' => 'aui_options[color_primary]', |
|
| 1076 | + ))); |
|
| 1077 | + |
|
| 1078 | + $wp_customize->add_setting('aui_options[color_secondary]', array( |
|
| 1079 | + 'default' => '#6c757d', |
|
| 1080 | + 'sanitize_callback' => 'sanitize_hex_color', |
|
| 1081 | + 'capability' => 'edit_theme_options', |
|
| 1082 | + 'type' => 'option', |
|
| 1083 | + 'transport' => 'refresh', |
|
| 1084 | + )); |
|
| 1085 | + $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array( |
|
| 1086 | + 'label' => __('Secondary Color','aui'), |
|
| 1087 | + 'section' => 'aui_settings', |
|
| 1088 | + 'settings' => 'aui_options[color_secondary]', |
|
| 1089 | + ))); |
|
| 1090 | + } |
|
| 1091 | + |
|
| 1092 | + public static function bs3_compat_css() { |
|
| 1093 | + ob_start(); |
|
| 1094 | + ?> |
|
| 1095 | 1095 | /* Bootstrap 3 compatibility */ |
| 1096 | 1096 | body.modal-open .modal-backdrop.show:not(.in) {opacity:0.5;} |
| 1097 | 1097 | body.modal-open .modal.show:not(.in) {opacity:1;z-index: 99999} |
@@ -1109,453 +1109,453 @@ discard block |
||
| 1109 | 1109 | |
| 1110 | 1110 | body.modal-open .modal.bsui .modal-dialog{left: auto;} |
| 1111 | 1111 | <?php |
| 1112 | - return ob_get_clean(); |
|
| 1113 | - } |
|
| 1112 | + return ob_get_clean(); |
|
| 1113 | + } |
|
| 1114 | 1114 | |
| 1115 | 1115 | |
| 1116 | - public static function custom_css($compatibility = true) { |
|
| 1117 | - $settings = get_option('aui_options'); |
|
| 1116 | + public static function custom_css($compatibility = true) { |
|
| 1117 | + $settings = get_option('aui_options'); |
|
| 1118 | 1118 | |
| 1119 | - ob_start(); |
|
| 1119 | + ob_start(); |
|
| 1120 | 1120 | |
| 1121 | - $primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR; |
|
| 1122 | - $secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR; |
|
| 1123 | - //AUI_PRIMARY_COLOR_ORIGINAL |
|
| 1124 | - ?> |
|
| 1121 | + $primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR; |
|
| 1122 | + $secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR; |
|
| 1123 | + //AUI_PRIMARY_COLOR_ORIGINAL |
|
| 1124 | + ?> |
|
| 1125 | 1125 | <style> |
| 1126 | 1126 | |
| 1127 | 1127 | |
| 1128 | 1128 | |
| 1129 | 1129 | <?php |
| 1130 | 1130 | |
| 1131 | - // BS compat @todo add option check |
|
| 1132 | - //echo self::bs3_compat_css(); |
|
| 1131 | + // BS compat @todo add option check |
|
| 1132 | + //echo self::bs3_compat_css(); |
|
| 1133 | 1133 | |
| 1134 | - if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){ |
|
| 1135 | - echo self::css_primary($primary_color,$compatibility); |
|
| 1136 | - } |
|
| 1134 | + if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){ |
|
| 1135 | + echo self::css_primary($primary_color,$compatibility); |
|
| 1136 | + } |
|
| 1137 | 1137 | |
| 1138 | - if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){ |
|
| 1139 | - echo self::css_secondary($settings['color_secondary'],$compatibility); |
|
| 1140 | - } |
|
| 1138 | + if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){ |
|
| 1139 | + echo self::css_secondary($settings['color_secondary'],$compatibility); |
|
| 1140 | + } |
|
| 1141 | 1141 | ?> |
| 1142 | 1142 | </style> |
| 1143 | 1143 | <?php |
| 1144 | 1144 | |
| 1145 | 1145 | |
| 1146 | - /* |
|
| 1146 | + /* |
|
| 1147 | 1147 | * We only add the <script> tags for code highlighting, so we strip them from the output. |
| 1148 | 1148 | */ |
| 1149 | - return str_replace( array( |
|
| 1150 | - '<style>', |
|
| 1151 | - '</style>' |
|
| 1152 | - ), '', ob_get_clean()); |
|
| 1153 | - } |
|
| 1154 | - |
|
| 1155 | - public static function css_primary($color_code,$compatibility){; |
|
| 1156 | - $color_code = sanitize_hex_color($color_code); |
|
| 1157 | - if(!$color_code){return '';} |
|
| 1158 | - /** |
|
| 1159 | - * c = color, b = background color, o = border-color, f = fill |
|
| 1160 | - */ |
|
| 1161 | - $selectors = array( |
|
| 1162 | - 'a' => array('c'), |
|
| 1163 | - '.btn-primary' => array('b','o'), |
|
| 1164 | - '.btn-primary.disabled' => array('b','o'), |
|
| 1165 | - '.btn-primary:disabled' => array('b','o'), |
|
| 1166 | - '.btn-outline-primary' => array('c','o'), |
|
| 1167 | - '.btn-outline-primary:hover' => array('b','o'), |
|
| 1168 | - '.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'), |
|
| 1169 | - '.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'), |
|
| 1170 | - '.show>.btn-outline-primary.dropdown-toggle' => array('b','o'), |
|
| 1171 | - '.btn-link' => array('c'), |
|
| 1172 | - '.dropdown-item.active' => array('b'), |
|
| 1173 | - '.custom-control-input:checked~.custom-control-label::before' => array('b','o'), |
|
| 1174 | - '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'), |
|
| 1149 | + return str_replace( array( |
|
| 1150 | + '<style>', |
|
| 1151 | + '</style>' |
|
| 1152 | + ), '', ob_get_clean()); |
|
| 1153 | + } |
|
| 1154 | + |
|
| 1155 | + public static function css_primary($color_code,$compatibility){; |
|
| 1156 | + $color_code = sanitize_hex_color($color_code); |
|
| 1157 | + if(!$color_code){return '';} |
|
| 1158 | + /** |
|
| 1159 | + * c = color, b = background color, o = border-color, f = fill |
|
| 1160 | + */ |
|
| 1161 | + $selectors = array( |
|
| 1162 | + 'a' => array('c'), |
|
| 1163 | + '.btn-primary' => array('b','o'), |
|
| 1164 | + '.btn-primary.disabled' => array('b','o'), |
|
| 1165 | + '.btn-primary:disabled' => array('b','o'), |
|
| 1166 | + '.btn-outline-primary' => array('c','o'), |
|
| 1167 | + '.btn-outline-primary:hover' => array('b','o'), |
|
| 1168 | + '.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'), |
|
| 1169 | + '.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'), |
|
| 1170 | + '.show>.btn-outline-primary.dropdown-toggle' => array('b','o'), |
|
| 1171 | + '.btn-link' => array('c'), |
|
| 1172 | + '.dropdown-item.active' => array('b'), |
|
| 1173 | + '.custom-control-input:checked~.custom-control-label::before' => array('b','o'), |
|
| 1174 | + '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'), |
|
| 1175 | 1175 | // '.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules... |
| 1176 | 1176 | // '.custom-range::-moz-range-thumb' => array('b'), |
| 1177 | 1177 | // '.custom-range::-ms-thumb' => array('b'), |
| 1178 | - '.nav-pills .nav-link.active' => array('b'), |
|
| 1179 | - '.nav-pills .show>.nav-link' => array('b'), |
|
| 1180 | - '.page-link' => array('c'), |
|
| 1181 | - '.page-item.active .page-link' => array('b','o'), |
|
| 1182 | - '.badge-primary' => array('b'), |
|
| 1183 | - '.alert-primary' => array('b','o'), |
|
| 1184 | - '.progress-bar' => array('b'), |
|
| 1185 | - '.list-group-item.active' => array('b','o'), |
|
| 1186 | - '.bg-primary' => array('b','f'), |
|
| 1187 | - '.btn-link.btn-primary' => array('c'), |
|
| 1188 | - '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'), |
|
| 1189 | - ); |
|
| 1190 | - |
|
| 1191 | - $important_selectors = array( |
|
| 1192 | - '.bg-primary' => array('b','f'), |
|
| 1193 | - '.border-primary' => array('o'), |
|
| 1194 | - '.text-primary' => array('c'), |
|
| 1195 | - ); |
|
| 1196 | - |
|
| 1197 | - $color = array(); |
|
| 1198 | - $color_i = array(); |
|
| 1199 | - $background = array(); |
|
| 1200 | - $background_i = array(); |
|
| 1201 | - $border = array(); |
|
| 1202 | - $border_i = array(); |
|
| 1203 | - $fill = array(); |
|
| 1204 | - $fill_i = array(); |
|
| 1205 | - |
|
| 1206 | - $output = ''; |
|
| 1207 | - |
|
| 1208 | - // build rules into each type |
|
| 1209 | - foreach($selectors as $selector => $types){ |
|
| 1210 | - $selector = $compatibility ? ".bsui ".$selector : $selector; |
|
| 1211 | - $types = array_combine($types,$types); |
|
| 1212 | - if(isset($types['c'])){$color[] = $selector;} |
|
| 1213 | - if(isset($types['b'])){$background[] = $selector;} |
|
| 1214 | - if(isset($types['o'])){$border[] = $selector;} |
|
| 1215 | - if(isset($types['f'])){$fill[] = $selector;} |
|
| 1216 | - } |
|
| 1217 | - |
|
| 1218 | - // build rules into each type |
|
| 1219 | - foreach($important_selectors as $selector => $types){ |
|
| 1220 | - $selector = $compatibility ? ".bsui ".$selector : $selector; |
|
| 1221 | - $types = array_combine($types,$types); |
|
| 1222 | - if(isset($types['c'])){$color_i[] = $selector;} |
|
| 1223 | - if(isset($types['b'])){$background_i[] = $selector;} |
|
| 1224 | - if(isset($types['o'])){$border_i[] = $selector;} |
|
| 1225 | - if(isset($types['f'])){$fill_i[] = $selector;} |
|
| 1226 | - } |
|
| 1227 | - |
|
| 1228 | - // add any color rules |
|
| 1229 | - if(!empty($color)){ |
|
| 1230 | - $output .= implode(",",$color) . "{color: $color_code;} "; |
|
| 1231 | - } |
|
| 1232 | - if(!empty($color_i)){ |
|
| 1233 | - $output .= implode(",",$color_i) . "{color: $color_code !important;} "; |
|
| 1234 | - } |
|
| 1235 | - |
|
| 1236 | - // add any background color rules |
|
| 1237 | - if(!empty($background)){ |
|
| 1238 | - $output .= implode(",",$background) . "{background-color: $color_code;} "; |
|
| 1239 | - } |
|
| 1240 | - if(!empty($background_i)){ |
|
| 1241 | - $output .= implode(",",$background_i) . "{background-color: $color_code !important;} "; |
|
| 1242 | - } |
|
| 1243 | - |
|
| 1244 | - // add any border color rules |
|
| 1245 | - if(!empty($border)){ |
|
| 1246 | - $output .= implode(",",$border) . "{border-color: $color_code;} "; |
|
| 1247 | - } |
|
| 1248 | - if(!empty($border_i)){ |
|
| 1249 | - $output .= implode(",",$border_i) . "{border-color: $color_code !important;} "; |
|
| 1250 | - } |
|
| 1251 | - |
|
| 1252 | - // add any fill color rules |
|
| 1253 | - if(!empty($fill)){ |
|
| 1254 | - $output .= implode(",",$fill) . "{fill: $color_code;} "; |
|
| 1255 | - } |
|
| 1256 | - if(!empty($fill_i)){ |
|
| 1257 | - $output .= implode(",",$fill_i) . "{fill: $color_code !important;} "; |
|
| 1258 | - } |
|
| 1259 | - |
|
| 1260 | - |
|
| 1261 | - $prefix = $compatibility ? ".bsui " : ""; |
|
| 1262 | - |
|
| 1263 | - // darken |
|
| 1264 | - $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075"); |
|
| 1265 | - $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10"); |
|
| 1266 | - $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125"); |
|
| 1267 | - |
|
| 1268 | - // lighten |
|
| 1269 | - $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25"); |
|
| 1270 | - |
|
| 1271 | - // opacity see https://css-tricks.com/8-digit-hex-codes/ |
|
| 1272 | - $op_25 = $color_code."40"; // 25% opacity |
|
| 1273 | - |
|
| 1274 | - |
|
| 1275 | - // button states |
|
| 1276 | - $output .= $prefix ." .btn-primary:hover{background-color: ".$darker_075."; border-color: ".$darker_10.";} "; |
|
| 1277 | - $output .= $prefix ." .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1278 | - $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: ".$darker_10."; border-color: ".$darker_125.";} "; |
|
| 1279 | - $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1280 | - |
|
| 1281 | - |
|
| 1282 | - // dropdown's |
|
| 1283 | - $output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} "; |
|
| 1284 | - |
|
| 1285 | - |
|
| 1286 | - // input states |
|
| 1287 | - $output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1288 | - |
|
| 1289 | - // page link |
|
| 1290 | - $output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1291 | - |
|
| 1292 | - return $output; |
|
| 1293 | - } |
|
| 1294 | - |
|
| 1295 | - public static function css_secondary($color_code,$compatibility){; |
|
| 1296 | - $color_code = sanitize_hex_color($color_code); |
|
| 1297 | - if(!$color_code){return '';} |
|
| 1298 | - /** |
|
| 1299 | - * c = color, b = background color, o = border-color, f = fill |
|
| 1300 | - */ |
|
| 1301 | - $selectors = array( |
|
| 1302 | - '.btn-secondary' => array('b','o'), |
|
| 1303 | - '.btn-secondary.disabled' => array('b','o'), |
|
| 1304 | - '.btn-secondary:disabled' => array('b','o'), |
|
| 1305 | - '.btn-outline-secondary' => array('c','o'), |
|
| 1306 | - '.btn-outline-secondary:hover' => array('b','o'), |
|
| 1307 | - '.btn-outline-secondary.disabled' => array('c'), |
|
| 1308 | - '.btn-outline-secondary:disabled' => array('c'), |
|
| 1309 | - '.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'), |
|
| 1310 | - '.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'), |
|
| 1311 | - '.btn-outline-secondary.dropdown-toggle' => array('b','o'), |
|
| 1312 | - '.badge-secondary' => array('b'), |
|
| 1313 | - '.alert-secondary' => array('b','o'), |
|
| 1314 | - '.btn-link.btn-secondary' => array('c'), |
|
| 1315 | - ); |
|
| 1316 | - |
|
| 1317 | - $important_selectors = array( |
|
| 1318 | - '.bg-secondary' => array('b','f'), |
|
| 1319 | - '.border-secondary' => array('o'), |
|
| 1320 | - '.text-secondary' => array('c'), |
|
| 1321 | - ); |
|
| 1322 | - |
|
| 1323 | - $color = array(); |
|
| 1324 | - $color_i = array(); |
|
| 1325 | - $background = array(); |
|
| 1326 | - $background_i = array(); |
|
| 1327 | - $border = array(); |
|
| 1328 | - $border_i = array(); |
|
| 1329 | - $fill = array(); |
|
| 1330 | - $fill_i = array(); |
|
| 1331 | - |
|
| 1332 | - $output = ''; |
|
| 1333 | - |
|
| 1334 | - // build rules into each type |
|
| 1335 | - foreach($selectors as $selector => $types){ |
|
| 1336 | - $selector = $compatibility ? ".bsui ".$selector : $selector; |
|
| 1337 | - $types = array_combine($types,$types); |
|
| 1338 | - if(isset($types['c'])){$color[] = $selector;} |
|
| 1339 | - if(isset($types['b'])){$background[] = $selector;} |
|
| 1340 | - if(isset($types['o'])){$border[] = $selector;} |
|
| 1341 | - if(isset($types['f'])){$fill[] = $selector;} |
|
| 1342 | - } |
|
| 1343 | - |
|
| 1344 | - // build rules into each type |
|
| 1345 | - foreach($important_selectors as $selector => $types){ |
|
| 1346 | - $selector = $compatibility ? ".bsui ".$selector : $selector; |
|
| 1347 | - $types = array_combine($types,$types); |
|
| 1348 | - if(isset($types['c'])){$color_i[] = $selector;} |
|
| 1349 | - if(isset($types['b'])){$background_i[] = $selector;} |
|
| 1350 | - if(isset($types['o'])){$border_i[] = $selector;} |
|
| 1351 | - if(isset($types['f'])){$fill_i[] = $selector;} |
|
| 1352 | - } |
|
| 1353 | - |
|
| 1354 | - // add any color rules |
|
| 1355 | - if(!empty($color)){ |
|
| 1356 | - $output .= implode(",",$color) . "{color: $color_code;} "; |
|
| 1357 | - } |
|
| 1358 | - if(!empty($color_i)){ |
|
| 1359 | - $output .= implode(",",$color_i) . "{color: $color_code !important;} "; |
|
| 1360 | - } |
|
| 1361 | - |
|
| 1362 | - // add any background color rules |
|
| 1363 | - if(!empty($background)){ |
|
| 1364 | - $output .= implode(",",$background) . "{background-color: $color_code;} "; |
|
| 1365 | - } |
|
| 1366 | - if(!empty($background_i)){ |
|
| 1367 | - $output .= implode(",",$background_i) . "{background-color: $color_code !important;} "; |
|
| 1368 | - } |
|
| 1369 | - |
|
| 1370 | - // add any border color rules |
|
| 1371 | - if(!empty($border)){ |
|
| 1372 | - $output .= implode(",",$border) . "{border-color: $color_code;} "; |
|
| 1373 | - } |
|
| 1374 | - if(!empty($border_i)){ |
|
| 1375 | - $output .= implode(",",$border_i) . "{border-color: $color_code !important;} "; |
|
| 1376 | - } |
|
| 1377 | - |
|
| 1378 | - // add any fill color rules |
|
| 1379 | - if(!empty($fill)){ |
|
| 1380 | - $output .= implode(",",$fill) . "{fill: $color_code;} "; |
|
| 1381 | - } |
|
| 1382 | - if(!empty($fill_i)){ |
|
| 1383 | - $output .= implode(",",$fill_i) . "{fill: $color_code !important;} "; |
|
| 1384 | - } |
|
| 1385 | - |
|
| 1386 | - |
|
| 1387 | - $prefix = $compatibility ? ".bsui " : ""; |
|
| 1388 | - |
|
| 1389 | - // darken |
|
| 1390 | - $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075"); |
|
| 1391 | - $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10"); |
|
| 1392 | - $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125"); |
|
| 1393 | - |
|
| 1394 | - // lighten |
|
| 1395 | - $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25"); |
|
| 1396 | - |
|
| 1397 | - // opacity see https://css-tricks.com/8-digit-hex-codes/ |
|
| 1398 | - $op_25 = $color_code."40"; // 25% opacity |
|
| 1399 | - |
|
| 1400 | - |
|
| 1401 | - // button states |
|
| 1402 | - $output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075."; border-color: ".$darker_10.";} "; |
|
| 1403 | - $output .= $prefix ." .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1404 | - $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: ".$darker_10."; border-color: ".$darker_125.";} "; |
|
| 1405 | - $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1406 | - |
|
| 1407 | - |
|
| 1408 | - return $output; |
|
| 1409 | - } |
|
| 1410 | - |
|
| 1411 | - /** |
|
| 1412 | - * Increases or decreases the brightness of a color by a percentage of the current brightness. |
|
| 1413 | - * |
|
| 1414 | - * @param string $hexCode Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF` |
|
| 1415 | - * @param float $adjustPercent A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker. |
|
| 1416 | - * |
|
| 1417 | - * @return string |
|
| 1418 | - */ |
|
| 1419 | - public static function css_hex_lighten_darken($hexCode, $adjustPercent) { |
|
| 1420 | - $hexCode = ltrim($hexCode, '#'); |
|
| 1421 | - |
|
| 1422 | - if (strlen($hexCode) == 3) { |
|
| 1423 | - $hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2]; |
|
| 1424 | - } |
|
| 1425 | - |
|
| 1426 | - $hexCode = array_map('hexdec', str_split($hexCode, 2)); |
|
| 1427 | - |
|
| 1428 | - foreach ($hexCode as & $color) { |
|
| 1429 | - $adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color; |
|
| 1430 | - $adjustAmount = ceil($adjustableLimit * $adjustPercent); |
|
| 1431 | - |
|
| 1432 | - $color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT); |
|
| 1433 | - } |
|
| 1434 | - |
|
| 1435 | - return '#' . implode($hexCode); |
|
| 1436 | - } |
|
| 1437 | - |
|
| 1438 | - /** |
|
| 1439 | - * Check if we should display examples. |
|
| 1440 | - */ |
|
| 1441 | - public function maybe_show_examples(){ |
|
| 1442 | - if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){ |
|
| 1443 | - echo "<head>"; |
|
| 1444 | - wp_head(); |
|
| 1445 | - echo "</head>"; |
|
| 1446 | - echo "<body>"; |
|
| 1447 | - echo $this->get_examples(); |
|
| 1448 | - echo "</body>"; |
|
| 1449 | - exit; |
|
| 1450 | - } |
|
| 1451 | - } |
|
| 1452 | - |
|
| 1453 | - /** |
|
| 1454 | - * Get developer examples. |
|
| 1455 | - * |
|
| 1456 | - * @return string |
|
| 1457 | - */ |
|
| 1458 | - public function get_examples(){ |
|
| 1459 | - $output = ''; |
|
| 1460 | - |
|
| 1461 | - |
|
| 1462 | - // open form |
|
| 1463 | - $output .= "<form class='p-5 m-5 border rounded'>"; |
|
| 1464 | - |
|
| 1465 | - // input example |
|
| 1466 | - $output .= aui()->input(array( |
|
| 1467 | - 'type' => 'text', |
|
| 1468 | - 'id' => 'text-example', |
|
| 1469 | - 'name' => 'text-example', |
|
| 1470 | - 'placeholder' => 'text placeholder', |
|
| 1471 | - 'title' => 'Text input example', |
|
| 1472 | - 'value' => '', |
|
| 1473 | - 'required' => false, |
|
| 1474 | - 'help_text' => 'help text', |
|
| 1475 | - 'label' => 'Text input example label' |
|
| 1476 | - )); |
|
| 1477 | - |
|
| 1478 | - // input example |
|
| 1479 | - $output .= aui()->input(array( |
|
| 1480 | - 'type' => 'url', |
|
| 1481 | - 'id' => 'text-example2', |
|
| 1482 | - 'name' => 'text-example', |
|
| 1483 | - 'placeholder' => 'url placeholder', |
|
| 1484 | - 'title' => 'Text input example', |
|
| 1485 | - 'value' => '', |
|
| 1486 | - 'required' => false, |
|
| 1487 | - 'help_text' => 'help text', |
|
| 1488 | - 'label' => 'Text input example label' |
|
| 1489 | - )); |
|
| 1490 | - |
|
| 1491 | - // checkbox example |
|
| 1492 | - $output .= aui()->input(array( |
|
| 1493 | - 'type' => 'checkbox', |
|
| 1494 | - 'id' => 'checkbox-example', |
|
| 1495 | - 'name' => 'checkbox-example', |
|
| 1496 | - 'placeholder' => 'checkbox-example', |
|
| 1497 | - 'title' => 'Checkbox example', |
|
| 1498 | - 'value' => '1', |
|
| 1499 | - 'checked' => true, |
|
| 1500 | - 'required' => false, |
|
| 1501 | - 'help_text' => 'help text', |
|
| 1502 | - 'label' => 'Checkbox checked' |
|
| 1503 | - )); |
|
| 1504 | - |
|
| 1505 | - // checkbox example |
|
| 1506 | - $output .= aui()->input(array( |
|
| 1507 | - 'type' => 'checkbox', |
|
| 1508 | - 'id' => 'checkbox-example2', |
|
| 1509 | - 'name' => 'checkbox-example2', |
|
| 1510 | - 'placeholder' => 'checkbox-example', |
|
| 1511 | - 'title' => 'Checkbox example', |
|
| 1512 | - 'value' => '1', |
|
| 1513 | - 'checked' => false, |
|
| 1514 | - 'required' => false, |
|
| 1515 | - 'help_text' => 'help text', |
|
| 1516 | - 'label' => 'Checkbox un-checked' |
|
| 1517 | - )); |
|
| 1518 | - |
|
| 1519 | - // switch example |
|
| 1520 | - $output .= aui()->input(array( |
|
| 1521 | - 'type' => 'checkbox', |
|
| 1522 | - 'id' => 'switch-example', |
|
| 1523 | - 'name' => 'switch-example', |
|
| 1524 | - 'placeholder' => 'checkbox-example', |
|
| 1525 | - 'title' => 'Switch example', |
|
| 1526 | - 'value' => '1', |
|
| 1527 | - 'checked' => true, |
|
| 1528 | - 'switch' => true, |
|
| 1529 | - 'required' => false, |
|
| 1530 | - 'help_text' => 'help text', |
|
| 1531 | - 'label' => 'Switch on' |
|
| 1532 | - )); |
|
| 1533 | - |
|
| 1534 | - // switch example |
|
| 1535 | - $output .= aui()->input(array( |
|
| 1536 | - 'type' => 'checkbox', |
|
| 1537 | - 'id' => 'switch-example2', |
|
| 1538 | - 'name' => 'switch-example2', |
|
| 1539 | - 'placeholder' => 'checkbox-example', |
|
| 1540 | - 'title' => 'Switch example', |
|
| 1541 | - 'value' => '1', |
|
| 1542 | - 'checked' => false, |
|
| 1543 | - 'switch' => true, |
|
| 1544 | - 'required' => false, |
|
| 1545 | - 'help_text' => 'help text', |
|
| 1546 | - 'label' => 'Switch off' |
|
| 1547 | - )); |
|
| 1548 | - |
|
| 1549 | - // close form |
|
| 1550 | - $output .= "</form>"; |
|
| 1551 | - |
|
| 1552 | - return $output; |
|
| 1553 | - } |
|
| 1554 | - |
|
| 1555 | - } |
|
| 1556 | - |
|
| 1557 | - /** |
|
| 1558 | - * Run the class if found. |
|
| 1559 | - */ |
|
| 1560 | - AyeCode_UI_Settings::instance(); |
|
| 1178 | + '.nav-pills .nav-link.active' => array('b'), |
|
| 1179 | + '.nav-pills .show>.nav-link' => array('b'), |
|
| 1180 | + '.page-link' => array('c'), |
|
| 1181 | + '.page-item.active .page-link' => array('b','o'), |
|
| 1182 | + '.badge-primary' => array('b'), |
|
| 1183 | + '.alert-primary' => array('b','o'), |
|
| 1184 | + '.progress-bar' => array('b'), |
|
| 1185 | + '.list-group-item.active' => array('b','o'), |
|
| 1186 | + '.bg-primary' => array('b','f'), |
|
| 1187 | + '.btn-link.btn-primary' => array('c'), |
|
| 1188 | + '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'), |
|
| 1189 | + ); |
|
| 1190 | + |
|
| 1191 | + $important_selectors = array( |
|
| 1192 | + '.bg-primary' => array('b','f'), |
|
| 1193 | + '.border-primary' => array('o'), |
|
| 1194 | + '.text-primary' => array('c'), |
|
| 1195 | + ); |
|
| 1196 | + |
|
| 1197 | + $color = array(); |
|
| 1198 | + $color_i = array(); |
|
| 1199 | + $background = array(); |
|
| 1200 | + $background_i = array(); |
|
| 1201 | + $border = array(); |
|
| 1202 | + $border_i = array(); |
|
| 1203 | + $fill = array(); |
|
| 1204 | + $fill_i = array(); |
|
| 1205 | + |
|
| 1206 | + $output = ''; |
|
| 1207 | + |
|
| 1208 | + // build rules into each type |
|
| 1209 | + foreach($selectors as $selector => $types){ |
|
| 1210 | + $selector = $compatibility ? ".bsui ".$selector : $selector; |
|
| 1211 | + $types = array_combine($types,$types); |
|
| 1212 | + if(isset($types['c'])){$color[] = $selector;} |
|
| 1213 | + if(isset($types['b'])){$background[] = $selector;} |
|
| 1214 | + if(isset($types['o'])){$border[] = $selector;} |
|
| 1215 | + if(isset($types['f'])){$fill[] = $selector;} |
|
| 1216 | + } |
|
| 1217 | + |
|
| 1218 | + // build rules into each type |
|
| 1219 | + foreach($important_selectors as $selector => $types){ |
|
| 1220 | + $selector = $compatibility ? ".bsui ".$selector : $selector; |
|
| 1221 | + $types = array_combine($types,$types); |
|
| 1222 | + if(isset($types['c'])){$color_i[] = $selector;} |
|
| 1223 | + if(isset($types['b'])){$background_i[] = $selector;} |
|
| 1224 | + if(isset($types['o'])){$border_i[] = $selector;} |
|
| 1225 | + if(isset($types['f'])){$fill_i[] = $selector;} |
|
| 1226 | + } |
|
| 1227 | + |
|
| 1228 | + // add any color rules |
|
| 1229 | + if(!empty($color)){ |
|
| 1230 | + $output .= implode(",",$color) . "{color: $color_code;} "; |
|
| 1231 | + } |
|
| 1232 | + if(!empty($color_i)){ |
|
| 1233 | + $output .= implode(",",$color_i) . "{color: $color_code !important;} "; |
|
| 1234 | + } |
|
| 1235 | + |
|
| 1236 | + // add any background color rules |
|
| 1237 | + if(!empty($background)){ |
|
| 1238 | + $output .= implode(",",$background) . "{background-color: $color_code;} "; |
|
| 1239 | + } |
|
| 1240 | + if(!empty($background_i)){ |
|
| 1241 | + $output .= implode(",",$background_i) . "{background-color: $color_code !important;} "; |
|
| 1242 | + } |
|
| 1243 | + |
|
| 1244 | + // add any border color rules |
|
| 1245 | + if(!empty($border)){ |
|
| 1246 | + $output .= implode(",",$border) . "{border-color: $color_code;} "; |
|
| 1247 | + } |
|
| 1248 | + if(!empty($border_i)){ |
|
| 1249 | + $output .= implode(",",$border_i) . "{border-color: $color_code !important;} "; |
|
| 1250 | + } |
|
| 1251 | + |
|
| 1252 | + // add any fill color rules |
|
| 1253 | + if(!empty($fill)){ |
|
| 1254 | + $output .= implode(",",$fill) . "{fill: $color_code;} "; |
|
| 1255 | + } |
|
| 1256 | + if(!empty($fill_i)){ |
|
| 1257 | + $output .= implode(",",$fill_i) . "{fill: $color_code !important;} "; |
|
| 1258 | + } |
|
| 1259 | + |
|
| 1260 | + |
|
| 1261 | + $prefix = $compatibility ? ".bsui " : ""; |
|
| 1262 | + |
|
| 1263 | + // darken |
|
| 1264 | + $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075"); |
|
| 1265 | + $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10"); |
|
| 1266 | + $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125"); |
|
| 1267 | + |
|
| 1268 | + // lighten |
|
| 1269 | + $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25"); |
|
| 1270 | + |
|
| 1271 | + // opacity see https://css-tricks.com/8-digit-hex-codes/ |
|
| 1272 | + $op_25 = $color_code."40"; // 25% opacity |
|
| 1273 | + |
|
| 1274 | + |
|
| 1275 | + // button states |
|
| 1276 | + $output .= $prefix ." .btn-primary:hover{background-color: ".$darker_075."; border-color: ".$darker_10.";} "; |
|
| 1277 | + $output .= $prefix ." .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1278 | + $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: ".$darker_10."; border-color: ".$darker_125.";} "; |
|
| 1279 | + $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1280 | + |
|
| 1281 | + |
|
| 1282 | + // dropdown's |
|
| 1283 | + $output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} "; |
|
| 1284 | + |
|
| 1285 | + |
|
| 1286 | + // input states |
|
| 1287 | + $output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1288 | + |
|
| 1289 | + // page link |
|
| 1290 | + $output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1291 | + |
|
| 1292 | + return $output; |
|
| 1293 | + } |
|
| 1294 | + |
|
| 1295 | + public static function css_secondary($color_code,$compatibility){; |
|
| 1296 | + $color_code = sanitize_hex_color($color_code); |
|
| 1297 | + if(!$color_code){return '';} |
|
| 1298 | + /** |
|
| 1299 | + * c = color, b = background color, o = border-color, f = fill |
|
| 1300 | + */ |
|
| 1301 | + $selectors = array( |
|
| 1302 | + '.btn-secondary' => array('b','o'), |
|
| 1303 | + '.btn-secondary.disabled' => array('b','o'), |
|
| 1304 | + '.btn-secondary:disabled' => array('b','o'), |
|
| 1305 | + '.btn-outline-secondary' => array('c','o'), |
|
| 1306 | + '.btn-outline-secondary:hover' => array('b','o'), |
|
| 1307 | + '.btn-outline-secondary.disabled' => array('c'), |
|
| 1308 | + '.btn-outline-secondary:disabled' => array('c'), |
|
| 1309 | + '.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'), |
|
| 1310 | + '.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'), |
|
| 1311 | + '.btn-outline-secondary.dropdown-toggle' => array('b','o'), |
|
| 1312 | + '.badge-secondary' => array('b'), |
|
| 1313 | + '.alert-secondary' => array('b','o'), |
|
| 1314 | + '.btn-link.btn-secondary' => array('c'), |
|
| 1315 | + ); |
|
| 1316 | + |
|
| 1317 | + $important_selectors = array( |
|
| 1318 | + '.bg-secondary' => array('b','f'), |
|
| 1319 | + '.border-secondary' => array('o'), |
|
| 1320 | + '.text-secondary' => array('c'), |
|
| 1321 | + ); |
|
| 1322 | + |
|
| 1323 | + $color = array(); |
|
| 1324 | + $color_i = array(); |
|
| 1325 | + $background = array(); |
|
| 1326 | + $background_i = array(); |
|
| 1327 | + $border = array(); |
|
| 1328 | + $border_i = array(); |
|
| 1329 | + $fill = array(); |
|
| 1330 | + $fill_i = array(); |
|
| 1331 | + |
|
| 1332 | + $output = ''; |
|
| 1333 | + |
|
| 1334 | + // build rules into each type |
|
| 1335 | + foreach($selectors as $selector => $types){ |
|
| 1336 | + $selector = $compatibility ? ".bsui ".$selector : $selector; |
|
| 1337 | + $types = array_combine($types,$types); |
|
| 1338 | + if(isset($types['c'])){$color[] = $selector;} |
|
| 1339 | + if(isset($types['b'])){$background[] = $selector;} |
|
| 1340 | + if(isset($types['o'])){$border[] = $selector;} |
|
| 1341 | + if(isset($types['f'])){$fill[] = $selector;} |
|
| 1342 | + } |
|
| 1343 | + |
|
| 1344 | + // build rules into each type |
|
| 1345 | + foreach($important_selectors as $selector => $types){ |
|
| 1346 | + $selector = $compatibility ? ".bsui ".$selector : $selector; |
|
| 1347 | + $types = array_combine($types,$types); |
|
| 1348 | + if(isset($types['c'])){$color_i[] = $selector;} |
|
| 1349 | + if(isset($types['b'])){$background_i[] = $selector;} |
|
| 1350 | + if(isset($types['o'])){$border_i[] = $selector;} |
|
| 1351 | + if(isset($types['f'])){$fill_i[] = $selector;} |
|
| 1352 | + } |
|
| 1353 | + |
|
| 1354 | + // add any color rules |
|
| 1355 | + if(!empty($color)){ |
|
| 1356 | + $output .= implode(",",$color) . "{color: $color_code;} "; |
|
| 1357 | + } |
|
| 1358 | + if(!empty($color_i)){ |
|
| 1359 | + $output .= implode(",",$color_i) . "{color: $color_code !important;} "; |
|
| 1360 | + } |
|
| 1361 | + |
|
| 1362 | + // add any background color rules |
|
| 1363 | + if(!empty($background)){ |
|
| 1364 | + $output .= implode(",",$background) . "{background-color: $color_code;} "; |
|
| 1365 | + } |
|
| 1366 | + if(!empty($background_i)){ |
|
| 1367 | + $output .= implode(",",$background_i) . "{background-color: $color_code !important;} "; |
|
| 1368 | + } |
|
| 1369 | + |
|
| 1370 | + // add any border color rules |
|
| 1371 | + if(!empty($border)){ |
|
| 1372 | + $output .= implode(",",$border) . "{border-color: $color_code;} "; |
|
| 1373 | + } |
|
| 1374 | + if(!empty($border_i)){ |
|
| 1375 | + $output .= implode(",",$border_i) . "{border-color: $color_code !important;} "; |
|
| 1376 | + } |
|
| 1377 | + |
|
| 1378 | + // add any fill color rules |
|
| 1379 | + if(!empty($fill)){ |
|
| 1380 | + $output .= implode(",",$fill) . "{fill: $color_code;} "; |
|
| 1381 | + } |
|
| 1382 | + if(!empty($fill_i)){ |
|
| 1383 | + $output .= implode(",",$fill_i) . "{fill: $color_code !important;} "; |
|
| 1384 | + } |
|
| 1385 | + |
|
| 1386 | + |
|
| 1387 | + $prefix = $compatibility ? ".bsui " : ""; |
|
| 1388 | + |
|
| 1389 | + // darken |
|
| 1390 | + $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075"); |
|
| 1391 | + $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10"); |
|
| 1392 | + $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125"); |
|
| 1393 | + |
|
| 1394 | + // lighten |
|
| 1395 | + $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25"); |
|
| 1396 | + |
|
| 1397 | + // opacity see https://css-tricks.com/8-digit-hex-codes/ |
|
| 1398 | + $op_25 = $color_code."40"; // 25% opacity |
|
| 1399 | + |
|
| 1400 | + |
|
| 1401 | + // button states |
|
| 1402 | + $output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075."; border-color: ".$darker_10.";} "; |
|
| 1403 | + $output .= $prefix ." .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1404 | + $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: ".$darker_10."; border-color: ".$darker_125.";} "; |
|
| 1405 | + $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} "; |
|
| 1406 | + |
|
| 1407 | + |
|
| 1408 | + return $output; |
|
| 1409 | + } |
|
| 1410 | + |
|
| 1411 | + /** |
|
| 1412 | + * Increases or decreases the brightness of a color by a percentage of the current brightness. |
|
| 1413 | + * |
|
| 1414 | + * @param string $hexCode Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF` |
|
| 1415 | + * @param float $adjustPercent A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker. |
|
| 1416 | + * |
|
| 1417 | + * @return string |
|
| 1418 | + */ |
|
| 1419 | + public static function css_hex_lighten_darken($hexCode, $adjustPercent) { |
|
| 1420 | + $hexCode = ltrim($hexCode, '#'); |
|
| 1421 | + |
|
| 1422 | + if (strlen($hexCode) == 3) { |
|
| 1423 | + $hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2]; |
|
| 1424 | + } |
|
| 1425 | + |
|
| 1426 | + $hexCode = array_map('hexdec', str_split($hexCode, 2)); |
|
| 1427 | + |
|
| 1428 | + foreach ($hexCode as & $color) { |
|
| 1429 | + $adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color; |
|
| 1430 | + $adjustAmount = ceil($adjustableLimit * $adjustPercent); |
|
| 1431 | + |
|
| 1432 | + $color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT); |
|
| 1433 | + } |
|
| 1434 | + |
|
| 1435 | + return '#' . implode($hexCode); |
|
| 1436 | + } |
|
| 1437 | + |
|
| 1438 | + /** |
|
| 1439 | + * Check if we should display examples. |
|
| 1440 | + */ |
|
| 1441 | + public function maybe_show_examples(){ |
|
| 1442 | + if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){ |
|
| 1443 | + echo "<head>"; |
|
| 1444 | + wp_head(); |
|
| 1445 | + echo "</head>"; |
|
| 1446 | + echo "<body>"; |
|
| 1447 | + echo $this->get_examples(); |
|
| 1448 | + echo "</body>"; |
|
| 1449 | + exit; |
|
| 1450 | + } |
|
| 1451 | + } |
|
| 1452 | + |
|
| 1453 | + /** |
|
| 1454 | + * Get developer examples. |
|
| 1455 | + * |
|
| 1456 | + * @return string |
|
| 1457 | + */ |
|
| 1458 | + public function get_examples(){ |
|
| 1459 | + $output = ''; |
|
| 1460 | + |
|
| 1461 | + |
|
| 1462 | + // open form |
|
| 1463 | + $output .= "<form class='p-5 m-5 border rounded'>"; |
|
| 1464 | + |
|
| 1465 | + // input example |
|
| 1466 | + $output .= aui()->input(array( |
|
| 1467 | + 'type' => 'text', |
|
| 1468 | + 'id' => 'text-example', |
|
| 1469 | + 'name' => 'text-example', |
|
| 1470 | + 'placeholder' => 'text placeholder', |
|
| 1471 | + 'title' => 'Text input example', |
|
| 1472 | + 'value' => '', |
|
| 1473 | + 'required' => false, |
|
| 1474 | + 'help_text' => 'help text', |
|
| 1475 | + 'label' => 'Text input example label' |
|
| 1476 | + )); |
|
| 1477 | + |
|
| 1478 | + // input example |
|
| 1479 | + $output .= aui()->input(array( |
|
| 1480 | + 'type' => 'url', |
|
| 1481 | + 'id' => 'text-example2', |
|
| 1482 | + 'name' => 'text-example', |
|
| 1483 | + 'placeholder' => 'url placeholder', |
|
| 1484 | + 'title' => 'Text input example', |
|
| 1485 | + 'value' => '', |
|
| 1486 | + 'required' => false, |
|
| 1487 | + 'help_text' => 'help text', |
|
| 1488 | + 'label' => 'Text input example label' |
|
| 1489 | + )); |
|
| 1490 | + |
|
| 1491 | + // checkbox example |
|
| 1492 | + $output .= aui()->input(array( |
|
| 1493 | + 'type' => 'checkbox', |
|
| 1494 | + 'id' => 'checkbox-example', |
|
| 1495 | + 'name' => 'checkbox-example', |
|
| 1496 | + 'placeholder' => 'checkbox-example', |
|
| 1497 | + 'title' => 'Checkbox example', |
|
| 1498 | + 'value' => '1', |
|
| 1499 | + 'checked' => true, |
|
| 1500 | + 'required' => false, |
|
| 1501 | + 'help_text' => 'help text', |
|
| 1502 | + 'label' => 'Checkbox checked' |
|
| 1503 | + )); |
|
| 1504 | + |
|
| 1505 | + // checkbox example |
|
| 1506 | + $output .= aui()->input(array( |
|
| 1507 | + 'type' => 'checkbox', |
|
| 1508 | + 'id' => 'checkbox-example2', |
|
| 1509 | + 'name' => 'checkbox-example2', |
|
| 1510 | + 'placeholder' => 'checkbox-example', |
|
| 1511 | + 'title' => 'Checkbox example', |
|
| 1512 | + 'value' => '1', |
|
| 1513 | + 'checked' => false, |
|
| 1514 | + 'required' => false, |
|
| 1515 | + 'help_text' => 'help text', |
|
| 1516 | + 'label' => 'Checkbox un-checked' |
|
| 1517 | + )); |
|
| 1518 | + |
|
| 1519 | + // switch example |
|
| 1520 | + $output .= aui()->input(array( |
|
| 1521 | + 'type' => 'checkbox', |
|
| 1522 | + 'id' => 'switch-example', |
|
| 1523 | + 'name' => 'switch-example', |
|
| 1524 | + 'placeholder' => 'checkbox-example', |
|
| 1525 | + 'title' => 'Switch example', |
|
| 1526 | + 'value' => '1', |
|
| 1527 | + 'checked' => true, |
|
| 1528 | + 'switch' => true, |
|
| 1529 | + 'required' => false, |
|
| 1530 | + 'help_text' => 'help text', |
|
| 1531 | + 'label' => 'Switch on' |
|
| 1532 | + )); |
|
| 1533 | + |
|
| 1534 | + // switch example |
|
| 1535 | + $output .= aui()->input(array( |
|
| 1536 | + 'type' => 'checkbox', |
|
| 1537 | + 'id' => 'switch-example2', |
|
| 1538 | + 'name' => 'switch-example2', |
|
| 1539 | + 'placeholder' => 'checkbox-example', |
|
| 1540 | + 'title' => 'Switch example', |
|
| 1541 | + 'value' => '1', |
|
| 1542 | + 'checked' => false, |
|
| 1543 | + 'switch' => true, |
|
| 1544 | + 'required' => false, |
|
| 1545 | + 'help_text' => 'help text', |
|
| 1546 | + 'label' => 'Switch off' |
|
| 1547 | + )); |
|
| 1548 | + |
|
| 1549 | + // close form |
|
| 1550 | + $output .= "</form>"; |
|
| 1551 | + |
|
| 1552 | + return $output; |
|
| 1553 | + } |
|
| 1554 | + |
|
| 1555 | + } |
|
| 1556 | + |
|
| 1557 | + /** |
|
| 1558 | + * Run the class if found. |
|
| 1559 | + */ |
|
| 1560 | + AyeCode_UI_Settings::instance(); |
|
| 1561 | 1561 | } |
| 1562 | 1562 | \ No newline at end of file |
@@ -36,36 +36,36 @@ discard block |
||
| 36 | 36 | 'desc_tip' => true, |
| 37 | 37 | 'default' => '', |
| 38 | 38 | 'advanced' => false |
| 39 | - ), |
|
| 39 | + ), |
|
| 40 | 40 | |
| 41 | 41 | 'form' => array( |
| 42 | - 'title' => __( 'Form', 'invoicing' ), |
|
| 43 | - 'desc' => __( 'Enter a form id in case you want to display a specific payment form', 'invoicing' ), |
|
| 44 | - 'type' => 'text', |
|
| 45 | - 'desc_tip' => true, |
|
| 46 | - 'default' => '', |
|
| 47 | - 'placeholder' => __('1','invoicing'), |
|
| 48 | - 'advanced' => false |
|
| 49 | - ), |
|
| 50 | - |
|
| 51 | - 'item' => array( |
|
| 52 | - 'title' => __( 'Items', 'invoicing' ), |
|
| 53 | - 'desc' => __( 'Enter comma separated list of invoicing item id and quantity (item_id|quantity). Ex. 101|2. This will be ignored in case you specify a form above. Enter 0 as the quantity to let users select their own quantities', 'invoicing' ), |
|
| 54 | - 'type' => 'text', |
|
| 55 | - 'desc_tip' => true, |
|
| 56 | - 'default' => '', |
|
| 57 | - 'placeholder' => __('1','invoicing'), |
|
| 58 | - 'advanced' => false |
|
| 59 | - ), |
|
| 42 | + 'title' => __( 'Form', 'invoicing' ), |
|
| 43 | + 'desc' => __( 'Enter a form id in case you want to display a specific payment form', 'invoicing' ), |
|
| 44 | + 'type' => 'text', |
|
| 45 | + 'desc_tip' => true, |
|
| 46 | + 'default' => '', |
|
| 47 | + 'placeholder' => __('1','invoicing'), |
|
| 48 | + 'advanced' => false |
|
| 49 | + ), |
|
| 50 | + |
|
| 51 | + 'item' => array( |
|
| 52 | + 'title' => __( 'Items', 'invoicing' ), |
|
| 53 | + 'desc' => __( 'Enter comma separated list of invoicing item id and quantity (item_id|quantity). Ex. 101|2. This will be ignored in case you specify a form above. Enter 0 as the quantity to let users select their own quantities', 'invoicing' ), |
|
| 54 | + 'type' => 'text', |
|
| 55 | + 'desc_tip' => true, |
|
| 56 | + 'default' => '', |
|
| 57 | + 'placeholder' => __('1','invoicing'), |
|
| 58 | + 'advanced' => false |
|
| 59 | + ), |
|
| 60 | 60 | |
| 61 | 61 | 'button' => array( |
| 62 | - 'title' => __( 'Button', 'invoicing' ), |
|
| 63 | - 'desc' => __( 'Enter button label in case you would like to display the forms in a popup.', 'invoicing' ), |
|
| 64 | - 'type' => 'text', |
|
| 65 | - 'desc_tip' => true, |
|
| 66 | - 'default' => '', |
|
| 67 | - 'advanced' => false |
|
| 68 | - ) |
|
| 62 | + 'title' => __( 'Button', 'invoicing' ), |
|
| 63 | + 'desc' => __( 'Enter button label in case you would like to display the forms in a popup.', 'invoicing' ), |
|
| 64 | + 'type' => 'text', |
|
| 65 | + 'desc_tip' => true, |
|
| 66 | + 'default' => '', |
|
| 67 | + 'advanced' => false |
|
| 68 | + ) |
|
| 69 | 69 | |
| 70 | 70 | ) |
| 71 | 71 | |
@@ -75,96 +75,96 @@ discard block |
||
| 75 | 75 | parent::__construct( $options ); |
| 76 | 76 | } |
| 77 | 77 | |
| 78 | - /** |
|
| 79 | - * The Super block output function. |
|
| 80 | - * |
|
| 81 | - * @param array $args |
|
| 82 | - * @param array $widget_args |
|
| 83 | - * @param string $content |
|
| 84 | - * |
|
| 85 | - * @return string |
|
| 86 | - */ |
|
| 78 | + /** |
|
| 79 | + * The Super block output function. |
|
| 80 | + * |
|
| 81 | + * @param array $args |
|
| 82 | + * @param array $widget_args |
|
| 83 | + * @param string $content |
|
| 84 | + * |
|
| 85 | + * @return string |
|
| 86 | + */ |
|
| 87 | 87 | public function output( $args = array(), $widget_args = array(), $content = '' ) { |
| 88 | 88 | |
| 89 | - // Is the shortcode set up correctly? |
|
| 90 | - if ( empty( $args['form'] ) && empty( $args['item'] ) ) { |
|
| 91 | - return aui()->alert( |
|
| 92 | - array( |
|
| 93 | - 'type' => 'warning', |
|
| 94 | - 'content' => __( 'No payment form or item selected', 'invoicing' ), |
|
| 95 | - ) |
|
| 96 | - ); |
|
| 97 | - } |
|
| 98 | - |
|
| 99 | - // Payment form or button? |
|
| 100 | - if ( ! empty( $args['form'] ) ) { |
|
| 101 | - return $this->handle_payment_form( $args ); |
|
| 102 | - } else { |
|
| 103 | - return $this->handle_buy_item( $args ); |
|
| 104 | - } |
|
| 105 | - |
|
| 106 | - } |
|
| 107 | - |
|
| 108 | - /** |
|
| 109 | - * Displaying a payment form |
|
| 110 | - * |
|
| 111 | - * @return string |
|
| 112 | - */ |
|
| 89 | + // Is the shortcode set up correctly? |
|
| 90 | + if ( empty( $args['form'] ) && empty( $args['item'] ) ) { |
|
| 91 | + return aui()->alert( |
|
| 92 | + array( |
|
| 93 | + 'type' => 'warning', |
|
| 94 | + 'content' => __( 'No payment form or item selected', 'invoicing' ), |
|
| 95 | + ) |
|
| 96 | + ); |
|
| 97 | + } |
|
| 98 | + |
|
| 99 | + // Payment form or button? |
|
| 100 | + if ( ! empty( $args['form'] ) ) { |
|
| 101 | + return $this->handle_payment_form( $args ); |
|
| 102 | + } else { |
|
| 103 | + return $this->handle_buy_item( $args ); |
|
| 104 | + } |
|
| 105 | + |
|
| 106 | + } |
|
| 107 | + |
|
| 108 | + /** |
|
| 109 | + * Displaying a payment form |
|
| 110 | + * |
|
| 111 | + * @return string |
|
| 112 | + */ |
|
| 113 | 113 | protected function handle_payment_form( $args = array() ) { |
| 114 | 114 | |
| 115 | - if ( empty( $args['button'] ) ) { |
|
| 116 | - ob_start(); |
|
| 117 | - getpaid_display_payment_form( $args['form'] ); |
|
| 118 | - return ob_get_clean(); |
|
| 119 | - } |
|
| 115 | + if ( empty( $args['button'] ) ) { |
|
| 116 | + ob_start(); |
|
| 117 | + getpaid_display_payment_form( $args['form'] ); |
|
| 118 | + return ob_get_clean(); |
|
| 119 | + } |
|
| 120 | 120 | |
| 121 | - return $this->payment_form_button( $args['form'], $args['button'] ); |
|
| 122 | - } |
|
| 121 | + return $this->payment_form_button( $args['form'], $args['button'] ); |
|
| 122 | + } |
|
| 123 | 123 | |
| 124 | - /** |
|
| 125 | - * Displays a payment form button. |
|
| 126 | - * |
|
| 127 | - * @return string |
|
| 128 | - */ |
|
| 124 | + /** |
|
| 125 | + * Displays a payment form button. |
|
| 126 | + * |
|
| 127 | + * @return string |
|
| 128 | + */ |
|
| 129 | 129 | protected function payment_form_button( $form, $button ) { |
| 130 | - return getpaid_get_payment_button( $button, $form ); |
|
| 131 | - } |
|
| 132 | - |
|
| 133 | - /** |
|
| 134 | - * Selling an item |
|
| 135 | - * |
|
| 136 | - * @return string |
|
| 137 | - */ |
|
| 130 | + return getpaid_get_payment_button( $button, $form ); |
|
| 131 | + } |
|
| 132 | + |
|
| 133 | + /** |
|
| 134 | + * Selling an item |
|
| 135 | + * |
|
| 136 | + * @return string |
|
| 137 | + */ |
|
| 138 | 138 | protected function handle_buy_item( $args = array() ) { |
| 139 | 139 | |
| 140 | - if ( empty( $args['button'] ) ) { |
|
| 141 | - return $this->buy_item_form( $args['item'] ); |
|
| 142 | - } |
|
| 140 | + if ( empty( $args['button'] ) ) { |
|
| 141 | + return $this->buy_item_form( $args['item'] ); |
|
| 142 | + } |
|
| 143 | 143 | |
| 144 | - return $this->buy_item_button( $args['item'], $args['button'] ); |
|
| 144 | + return $this->buy_item_button( $args['item'], $args['button'] ); |
|
| 145 | 145 | |
| 146 | - } |
|
| 146 | + } |
|
| 147 | 147 | |
| 148 | - /** |
|
| 149 | - * Displays a buy item form. |
|
| 150 | - * |
|
| 151 | - * @return string |
|
| 152 | - */ |
|
| 148 | + /** |
|
| 149 | + * Displays a buy item form. |
|
| 150 | + * |
|
| 151 | + * @return string |
|
| 152 | + */ |
|
| 153 | 153 | protected function buy_item_form( $item ) { |
| 154 | - $items = getpaid_convert_items_to_array( $item ); |
|
| 155 | - ob_start(); |
|
| 156 | - getpaid_display_item_payment_form( $items ); |
|
| 157 | - return ob_get_clean(); |
|
| 158 | - } |
|
| 159 | - |
|
| 160 | - /** |
|
| 161 | - * Displays a buy item button. |
|
| 162 | - * |
|
| 163 | - * @return string |
|
| 164 | - */ |
|
| 154 | + $items = getpaid_convert_items_to_array( $item ); |
|
| 155 | + ob_start(); |
|
| 156 | + getpaid_display_item_payment_form( $items ); |
|
| 157 | + return ob_get_clean(); |
|
| 158 | + } |
|
| 159 | + |
|
| 160 | + /** |
|
| 161 | + * Displays a buy item button. |
|
| 162 | + * |
|
| 163 | + * @return string |
|
| 164 | + */ |
|
| 165 | 165 | protected function buy_item_button( $item, $button ) { |
| 166 | - $button = getpaid_get_payment_button( $button, null, $item ); |
|
| 167 | - return apply_filters( 'getpaid_buy_item_button_widget', $button, $item ); |
|
| 166 | + $button = getpaid_get_payment_button( $button, null, $item ); |
|
| 167 | + return apply_filters( 'getpaid_buy_item_button_widget', $button, $item ); |
|
| 168 | 168 | } |
| 169 | 169 | |
| 170 | 170 | } |
@@ -13,58 +13,58 @@ discard block |
||
| 13 | 13 | class GetPaid_Authorize_Net_Gateway extends GetPaid_Authorize_Net_Legacy_Gateway { |
| 14 | 14 | |
| 15 | 15 | /** |
| 16 | - * Payment method id. |
|
| 17 | - * |
|
| 18 | - * @var string |
|
| 19 | - */ |
|
| 16 | + * Payment method id. |
|
| 17 | + * |
|
| 18 | + * @var string |
|
| 19 | + */ |
|
| 20 | 20 | public $id = 'authorizenet'; |
| 21 | 21 | |
| 22 | 22 | /** |
| 23 | - * An array of features that this gateway supports. |
|
| 24 | - * |
|
| 25 | - * @var array |
|
| 26 | - */ |
|
| 23 | + * An array of features that this gateway supports. |
|
| 24 | + * |
|
| 25 | + * @var array |
|
| 26 | + */ |
|
| 27 | 27 | protected $supports = array( 'subscription', 'sandbox', 'tokens', 'addons' ); |
| 28 | 28 | |
| 29 | 29 | /** |
| 30 | - * Payment method order. |
|
| 31 | - * |
|
| 32 | - * @var int |
|
| 33 | - */ |
|
| 30 | + * Payment method order. |
|
| 31 | + * |
|
| 32 | + * @var int |
|
| 33 | + */ |
|
| 34 | 34 | public $order = 4; |
| 35 | 35 | |
| 36 | 36 | /** |
| 37 | - * Endpoint for requests from Authorize.net. |
|
| 38 | - * |
|
| 39 | - * @var string |
|
| 40 | - */ |
|
| 41 | - protected $notify_url; |
|
| 42 | - |
|
| 43 | - /** |
|
| 44 | - * Endpoint for requests to Authorize.net. |
|
| 45 | - * |
|
| 46 | - * @var string |
|
| 47 | - */ |
|
| 37 | + * Endpoint for requests from Authorize.net. |
|
| 38 | + * |
|
| 39 | + * @var string |
|
| 40 | + */ |
|
| 41 | + protected $notify_url; |
|
| 42 | + |
|
| 43 | + /** |
|
| 44 | + * Endpoint for requests to Authorize.net. |
|
| 45 | + * |
|
| 46 | + * @var string |
|
| 47 | + */ |
|
| 48 | 48 | protected $endpoint; |
| 49 | 49 | |
| 50 | 50 | /** |
| 51 | - * Currencies this gateway is allowed for. |
|
| 52 | - * |
|
| 53 | - * @var array |
|
| 54 | - */ |
|
| 55 | - public $currencies = array( 'USD', 'CAD', 'GBP', 'DKK', 'NOK', 'PLN', 'SEK', 'AUD', 'EUR', 'NZD' ); |
|
| 51 | + * Currencies this gateway is allowed for. |
|
| 52 | + * |
|
| 53 | + * @var array |
|
| 54 | + */ |
|
| 55 | + public $currencies = array( 'USD', 'CAD', 'GBP', 'DKK', 'NOK', 'PLN', 'SEK', 'AUD', 'EUR', 'NZD' ); |
|
| 56 | 56 | |
| 57 | 57 | /** |
| 58 | - * URL to view a transaction. |
|
| 59 | - * |
|
| 60 | - * @var string |
|
| 61 | - */ |
|
| 58 | + * URL to view a transaction. |
|
| 59 | + * |
|
| 60 | + * @var string |
|
| 61 | + */ |
|
| 62 | 62 | public $view_transaction_url = 'https://{sandbox}authorize.net/ui/themes/sandbox/Transaction/TransactionReceipt.aspx?transid=%s'; |
| 63 | 63 | |
| 64 | 64 | /** |
| 65 | - * Class constructor. |
|
| 66 | - */ |
|
| 67 | - public function __construct() { |
|
| 65 | + * Class constructor. |
|
| 66 | + */ |
|
| 67 | + public function __construct() { |
|
| 68 | 68 | |
| 69 | 69 | $this->title = __( 'Credit Card / Debit Card', 'invoicing' ); |
| 70 | 70 | $this->method_title = __( 'Authorize.Net', 'invoicing' ); |
@@ -76,11 +76,11 @@ discard block |
||
| 76 | 76 | } |
| 77 | 77 | |
| 78 | 78 | /** |
| 79 | - * Displays the payment method select field. |
|
| 80 | - * |
|
| 81 | - * @param int $invoice_id 0 or invoice id. |
|
| 82 | - * @param GetPaid_Payment_Form $form Current payment form. |
|
| 83 | - */ |
|
| 79 | + * Displays the payment method select field. |
|
| 80 | + * |
|
| 81 | + * @param int $invoice_id 0 or invoice id. |
|
| 82 | + * @param GetPaid_Payment_Form $form Current payment form. |
|
| 83 | + */ |
|
| 84 | 84 | public function payment_fields( $invoice_id, $form ) { |
| 85 | 85 | |
| 86 | 86 | // Let the user select a payment method. |
@@ -91,16 +91,16 @@ discard block |
||
| 91 | 91 | } |
| 92 | 92 | |
| 93 | 93 | /** |
| 94 | - * Creates a customer profile. |
|
| 95 | - * |
|
| 96 | - * |
|
| 97 | - * @param WPInv_Invoice $invoice Invoice. |
|
| 94 | + * Creates a customer profile. |
|
| 95 | + * |
|
| 96 | + * |
|
| 97 | + * @param WPInv_Invoice $invoice Invoice. |
|
| 98 | 98 | * @param array $submission_data Posted checkout fields. |
| 99 | 99 | * @param bool $save Whether or not to save the payment as a token. |
| 100 | 100 | * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-create-customer-profile |
| 101 | - * @return string|WP_Error Payment profile id. |
|
| 102 | - */ |
|
| 103 | - public function create_customer_profile( $invoice, $submission_data, $save = true ) { |
|
| 101 | + * @return string|WP_Error Payment profile id. |
|
| 102 | + */ |
|
| 103 | + public function create_customer_profile( $invoice, $submission_data, $save = true ) { |
|
| 104 | 104 | |
| 105 | 105 | // Remove non-digits from the number |
| 106 | 106 | $submission_data['authorizenet']['cc_number'] = preg_replace('/\D/', '', $submission_data['authorizenet']['cc_number'] ); |
@@ -167,14 +167,14 @@ discard block |
||
| 167 | 167 | } |
| 168 | 168 | |
| 169 | 169 | /** |
| 170 | - * Retrieves a customer profile. |
|
| 171 | - * |
|
| 172 | - * |
|
| 173 | - * @param string $profile_id profile id. |
|
| 174 | - * @return string|WP_Error Profile id. |
|
| 170 | + * Retrieves a customer profile. |
|
| 171 | + * |
|
| 172 | + * |
|
| 173 | + * @param string $profile_id profile id. |
|
| 174 | + * @return string|WP_Error Profile id. |
|
| 175 | 175 | * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-get-customer-profile |
| 176 | - */ |
|
| 177 | - public function get_customer_profile( $profile_id ) { |
|
| 176 | + */ |
|
| 177 | + public function get_customer_profile( $profile_id ) { |
|
| 178 | 178 | |
| 179 | 179 | // Generate args. |
| 180 | 180 | $args = array( |
@@ -189,17 +189,17 @@ discard block |
||
| 189 | 189 | } |
| 190 | 190 | |
| 191 | 191 | /** |
| 192 | - * Creates a customer profile. |
|
| 193 | - * |
|
| 194 | - * |
|
| 192 | + * Creates a customer profile. |
|
| 193 | + * |
|
| 194 | + * |
|
| 195 | 195 | * @param string $profile_id profile id. |
| 196 | - * @param WPInv_Invoice $invoice Invoice. |
|
| 196 | + * @param WPInv_Invoice $invoice Invoice. |
|
| 197 | 197 | * @param array $submission_data Posted checkout fields. |
| 198 | 198 | * @param bool $save Whether or not to save the payment as a token. |
| 199 | 199 | * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-create-customer-profile |
| 200 | - * @return string|WP_Error Profile id. |
|
| 201 | - */ |
|
| 202 | - public function create_customer_payment_profile( $customer_profile, $invoice, $submission_data, $save ) { |
|
| 200 | + * @return string|WP_Error Profile id. |
|
| 201 | + */ |
|
| 202 | + public function create_customer_payment_profile( $customer_profile, $invoice, $submission_data, $save ) { |
|
| 203 | 203 | |
| 204 | 204 | // Remove non-digits from the number |
| 205 | 205 | $submission_data['authorizenet']['cc_number'] = preg_replace('/\D/', '', $submission_data['authorizenet']['cc_number'] ); |
@@ -259,15 +259,15 @@ discard block |
||
| 259 | 259 | } |
| 260 | 260 | |
| 261 | 261 | /** |
| 262 | - * Retrieves a customer payment profile. |
|
| 263 | - * |
|
| 264 | - * |
|
| 265 | - * @param string $customer_profile_id customer profile id. |
|
| 262 | + * Retrieves a customer payment profile. |
|
| 263 | + * |
|
| 264 | + * |
|
| 265 | + * @param string $customer_profile_id customer profile id. |
|
| 266 | 266 | * @param string $payment_profile_id payment profile id. |
| 267 | - * @return string|WP_Error Profile id. |
|
| 267 | + * @return string|WP_Error Profile id. |
|
| 268 | 268 | * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-get-customer-payment-profile |
| 269 | - */ |
|
| 270 | - public function get_customer_payment_profile( $customer_profile_id, $payment_profile_id ) { |
|
| 269 | + */ |
|
| 270 | + public function get_customer_payment_profile( $customer_profile_id, $payment_profile_id ) { |
|
| 271 | 271 | |
| 272 | 272 | // Generate args. |
| 273 | 273 | $args = array( |
@@ -283,15 +283,15 @@ discard block |
||
| 283 | 283 | } |
| 284 | 284 | |
| 285 | 285 | /** |
| 286 | - * Charges a customer payment profile. |
|
| 287 | - * |
|
| 286 | + * Charges a customer payment profile. |
|
| 287 | + * |
|
| 288 | 288 | * @param string $customer_profile_id customer profile id. |
| 289 | 289 | * @param string $payment_profile_id payment profile id. |
| 290 | - * @param WPInv_Invoice $invoice Invoice. |
|
| 290 | + * @param WPInv_Invoice $invoice Invoice. |
|
| 291 | 291 | * @link https://developer.authorize.net/api/reference/index.html#payment-transactions-charge-a-customer-profile |
| 292 | - * @return WP_Error|object |
|
| 293 | - */ |
|
| 294 | - public function charge_customer_payment_profile( $customer_profile_id, $payment_profile_id, $invoice ) { |
|
| 292 | + * @return WP_Error|object |
|
| 293 | + */ |
|
| 294 | + public function charge_customer_payment_profile( $customer_profile_id, $payment_profile_id, $invoice ) { |
|
| 295 | 295 | |
| 296 | 296 | // Generate args. |
| 297 | 297 | $args = array( |
@@ -337,41 +337,41 @@ discard block |
||
| 337 | 337 | } |
| 338 | 338 | |
| 339 | 339 | /** |
| 340 | - * Processes a customer charge. |
|
| 341 | - * |
|
| 340 | + * Processes a customer charge. |
|
| 341 | + * |
|
| 342 | 342 | * @param stdClass $result Api response. |
| 343 | - * @param WPInv_Invoice $invoice Invoice. |
|
| 344 | - */ |
|
| 345 | - public function process_charge_response( $result, $invoice ) { |
|
| 343 | + * @param WPInv_Invoice $invoice Invoice. |
|
| 344 | + */ |
|
| 345 | + public function process_charge_response( $result, $invoice ) { |
|
| 346 | 346 | |
| 347 | 347 | wpinv_clear_errors(); |
| 348 | - $response_code = (int) $result->transactionResponse->responseCode; |
|
| 348 | + $response_code = (int) $result->transactionResponse->responseCode; |
|
| 349 | 349 | |
| 350 | - // Succeeded. |
|
| 351 | - if ( 1 == $response_code || 4 == $response_code ) { |
|
| 350 | + // Succeeded. |
|
| 351 | + if ( 1 == $response_code || 4 == $response_code ) { |
|
| 352 | 352 | |
| 353 | - // Maybe set a transaction id. |
|
| 354 | - if ( ! empty( $result->transactionResponse->transId ) ) { |
|
| 355 | - $invoice->set_transaction_id( $result->transactionResponse->transId ); |
|
| 356 | - } |
|
| 353 | + // Maybe set a transaction id. |
|
| 354 | + if ( ! empty( $result->transactionResponse->transId ) ) { |
|
| 355 | + $invoice->set_transaction_id( $result->transactionResponse->transId ); |
|
| 356 | + } |
|
| 357 | 357 | |
| 358 | - $invoice->add_note( sprintf( __( 'Authentication code: %s (%s).', 'invoicing' ), $result->transactionResponse->authCode, $result->transactionResponse->accountNumber ), false, false, true ); |
|
| 358 | + $invoice->add_note( sprintf( __( 'Authentication code: %s (%s).', 'invoicing' ), $result->transactionResponse->authCode, $result->transactionResponse->accountNumber ), false, false, true ); |
|
| 359 | 359 | |
| 360 | - if ( 1 == $response_code ) { |
|
| 361 | - return $invoice->mark_paid(); |
|
| 362 | - } |
|
| 360 | + if ( 1 == $response_code ) { |
|
| 361 | + return $invoice->mark_paid(); |
|
| 362 | + } |
|
| 363 | 363 | |
| 364 | - $invoice->set_status( 'wpi-onhold' ); |
|
| 365 | - $invoice->add_note( |
|
| 364 | + $invoice->set_status( 'wpi-onhold' ); |
|
| 365 | + $invoice->add_note( |
|
| 366 | 366 | sprintf( |
| 367 | 367 | __( 'Held for review: %s', 'invoicing' ), |
| 368 | 368 | $result->transactionResponse->messages->message[0]->description |
| 369 | 369 | ) |
| 370 | - ); |
|
| 370 | + ); |
|
| 371 | 371 | |
| 372 | - return $invoice->save(); |
|
| 372 | + return $invoice->save(); |
|
| 373 | 373 | |
| 374 | - } |
|
| 374 | + } |
|
| 375 | 375 | |
| 376 | 376 | wpinv_set_error( 'card_declined', __( 'Credit card declined.', 'invoicing' ) ); |
| 377 | 377 | |
@@ -383,13 +383,13 @@ discard block |
||
| 383 | 383 | } |
| 384 | 384 | |
| 385 | 385 | /** |
| 386 | - * Returns payment information. |
|
| 387 | - * |
|
| 388 | - * |
|
| 389 | - * @param array $card Card details. |
|
| 390 | - * @return array |
|
| 391 | - */ |
|
| 392 | - public function get_payment_information( $card ) { |
|
| 386 | + * Returns payment information. |
|
| 387 | + * |
|
| 388 | + * |
|
| 389 | + * @param array $card Card details. |
|
| 390 | + * @return array |
|
| 391 | + */ |
|
| 392 | + public function get_payment_information( $card ) { |
|
| 393 | 393 | return array( |
| 394 | 394 | |
| 395 | 395 | 'creditCard' => array ( |
@@ -402,25 +402,25 @@ discard block |
||
| 402 | 402 | } |
| 403 | 403 | |
| 404 | 404 | /** |
| 405 | - * Returns the customer profile meta name. |
|
| 406 | - * |
|
| 407 | - * |
|
| 408 | - * @param WPInv_Invoice $invoice Invoice. |
|
| 409 | - * @return string |
|
| 410 | - */ |
|
| 411 | - public function get_customer_profile_meta_name( $invoice ) { |
|
| 405 | + * Returns the customer profile meta name. |
|
| 406 | + * |
|
| 407 | + * |
|
| 408 | + * @param WPInv_Invoice $invoice Invoice. |
|
| 409 | + * @return string |
|
| 410 | + */ |
|
| 411 | + public function get_customer_profile_meta_name( $invoice ) { |
|
| 412 | 412 | return $this->is_sandbox( $invoice ) ? 'getpaid_authorizenet_sandbox_customer_profile_id' : 'getpaid_authorizenet_customer_profile_id'; |
| 413 | 413 | } |
| 414 | 414 | |
| 415 | 415 | /** |
| 416 | - * Validates the submitted data. |
|
| 417 | - * |
|
| 418 | - * |
|
| 419 | - * @param array $submission_data Posted checkout fields. |
|
| 416 | + * Validates the submitted data. |
|
| 417 | + * |
|
| 418 | + * |
|
| 419 | + * @param array $submission_data Posted checkout fields. |
|
| 420 | 420 | * @param WPInv_Invoice $invoice |
| 421 | - * @return WP_Error|string The payment profile id |
|
| 422 | - */ |
|
| 423 | - public function validate_submission_data( $submission_data, $invoice ) { |
|
| 421 | + * @return WP_Error|string The payment profile id |
|
| 422 | + */ |
|
| 423 | + public function validate_submission_data( $submission_data, $invoice ) { |
|
| 424 | 424 | |
| 425 | 425 | // Validate authentication details. |
| 426 | 426 | $auth = $this->get_auth_params(); |
@@ -452,13 +452,13 @@ discard block |
||
| 452 | 452 | } |
| 453 | 453 | |
| 454 | 454 | /** |
| 455 | - * Returns invoice line items. |
|
| 456 | - * |
|
| 457 | - * |
|
| 458 | - * @param WPInv_Invoice $invoice Invoice. |
|
| 459 | - * @return array |
|
| 460 | - */ |
|
| 461 | - public function get_line_items( $invoice ) { |
|
| 455 | + * Returns invoice line items. |
|
| 456 | + * |
|
| 457 | + * |
|
| 458 | + * @param WPInv_Invoice $invoice Invoice. |
|
| 459 | + * @return array |
|
| 460 | + */ |
|
| 461 | + public function get_line_items( $invoice ) { |
|
| 462 | 462 | $items = array(); |
| 463 | 463 | |
| 464 | 464 | foreach ( $invoice->get_items() as $item ) { |
@@ -496,15 +496,15 @@ discard block |
||
| 496 | 496 | } |
| 497 | 497 | |
| 498 | 498 | /** |
| 499 | - * Process Payment. |
|
| 500 | - * |
|
| 501 | - * |
|
| 502 | - * @param WPInv_Invoice $invoice Invoice. |
|
| 503 | - * @param array $submission_data Posted checkout fields. |
|
| 504 | - * @param GetPaid_Payment_Form_Submission $submission Checkout submission. |
|
| 505 | - * @return array |
|
| 506 | - */ |
|
| 507 | - public function process_payment( $invoice, $submission_data, $submission ) { |
|
| 499 | + * Process Payment. |
|
| 500 | + * |
|
| 501 | + * |
|
| 502 | + * @param WPInv_Invoice $invoice Invoice. |
|
| 503 | + * @param array $submission_data Posted checkout fields. |
|
| 504 | + * @param GetPaid_Payment_Form_Submission $submission Checkout submission. |
|
| 505 | + * @return array |
|
| 506 | + */ |
|
| 507 | + public function process_payment( $invoice, $submission_data, $submission ) { |
|
| 508 | 508 | |
| 509 | 509 | // Validate the submitted data. |
| 510 | 510 | $payment_profile_id = $this->validate_submission_data( $submission_data, $invoice ); |
@@ -537,69 +537,69 @@ discard block |
||
| 537 | 537 | |
| 538 | 538 | exit; |
| 539 | 539 | |
| 540 | - } |
|
| 540 | + } |
|
| 541 | 541 | |
| 542 | - /** |
|
| 543 | - * Processes the initial payment. |
|
| 544 | - * |
|
| 542 | + /** |
|
| 543 | + * Processes the initial payment. |
|
| 544 | + * |
|
| 545 | 545 | * @param WPInv_Invoice $invoice Invoice. |
| 546 | - */ |
|
| 547 | - protected function process_initial_payment( $invoice ) { |
|
| 546 | + */ |
|
| 547 | + protected function process_initial_payment( $invoice ) { |
|
| 548 | 548 | |
| 549 | - $payment_profile_id = get_post_meta( $invoice->get_id(), 'getpaid_authorizenet_profile_id', true ); |
|
| 549 | + $payment_profile_id = get_post_meta( $invoice->get_id(), 'getpaid_authorizenet_profile_id', true ); |
|
| 550 | 550 | $customer_profile = get_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), true ); |
| 551 | - $result = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $invoice ); |
|
| 551 | + $result = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $invoice ); |
|
| 552 | 552 | |
| 553 | - // Do we have an error? |
|
| 554 | - if ( is_wp_error( $result ) ) { |
|
| 555 | - wpinv_set_error( $result->get_error_code(), $result->get_error_message() ); |
|
| 556 | - wpinv_send_back_to_checkout( $invoice ); |
|
| 557 | - } |
|
| 553 | + // Do we have an error? |
|
| 554 | + if ( is_wp_error( $result ) ) { |
|
| 555 | + wpinv_set_error( $result->get_error_code(), $result->get_error_message() ); |
|
| 556 | + wpinv_send_back_to_checkout( $invoice ); |
|
| 557 | + } |
|
| 558 | 558 | |
| 559 | - // Process the response. |
|
| 560 | - $this->process_charge_response( $result, $invoice ); |
|
| 559 | + // Process the response. |
|
| 560 | + $this->process_charge_response( $result, $invoice ); |
|
| 561 | 561 | |
| 562 | - if ( wpinv_get_errors() ) { |
|
| 563 | - wpinv_send_back_to_checkout( $invoice ); |
|
| 564 | - } |
|
| 562 | + if ( wpinv_get_errors() ) { |
|
| 563 | + wpinv_send_back_to_checkout( $invoice ); |
|
| 564 | + } |
|
| 565 | 565 | |
| 566 | - } |
|
| 566 | + } |
|
| 567 | 567 | |
| 568 | 568 | /** |
| 569 | - * Processes recurring payments. |
|
| 570 | - * |
|
| 569 | + * Processes recurring payments. |
|
| 570 | + * |
|
| 571 | 571 | * @param WPInv_Invoice $invoice Invoice. |
| 572 | 572 | * @param WPInv_Subscription $subscription Subscription. |
| 573 | - */ |
|
| 574 | - public function process_subscription( $invoice, $subscription ) { |
|
| 573 | + */ |
|
| 574 | + public function process_subscription( $invoice, $subscription ) { |
|
| 575 | 575 | |
| 576 | 576 | // Check if there is an initial amount to charge. |
| 577 | 577 | if ( (float) $invoice->get_total() > 0 ) { |
| 578 | - $this->process_initial_payment( $invoice ); |
|
| 578 | + $this->process_initial_payment( $invoice ); |
|
| 579 | 579 | } |
| 580 | 580 | |
| 581 | 581 | // Activate the subscription. |
| 582 | 582 | $duration = strtotime( $subscription->get_expiration() ) - strtotime( $subscription->get_date_created() ); |
| 583 | 583 | $expiry = date( 'Y-m-d H:i:s', ( current_time( 'timestamp' ) + $duration ) ); |
| 584 | 584 | |
| 585 | - $subscription->set_next_renewal_date( $expiry ); |
|
| 586 | - $subscription->set_date_created( current_time( 'mysql' ) ); |
|
| 587 | - $subscription->set_profile_id( $invoice->generate_key() ); |
|
| 588 | - $subscription->activate(); |
|
| 585 | + $subscription->set_next_renewal_date( $expiry ); |
|
| 586 | + $subscription->set_date_created( current_time( 'mysql' ) ); |
|
| 587 | + $subscription->set_profile_id( $invoice->generate_key() ); |
|
| 588 | + $subscription->activate(); |
|
| 589 | 589 | |
| 590 | - // Redirect to the success page. |
|
| 590 | + // Redirect to the success page. |
|
| 591 | 591 | wpinv_send_to_success_page( array( 'invoice_key' => $invoice->get_key() ) ); |
| 592 | 592 | |
| 593 | 593 | } |
| 594 | 594 | |
| 595 | - /** |
|
| 596 | - * (Maybe) renews an authorize.net subscription profile. |
|
| 597 | - * |
|
| 598 | - * |
|
| 599 | - * @param bool $should_expire |
|
| 595 | + /** |
|
| 596 | + * (Maybe) renews an authorize.net subscription profile. |
|
| 597 | + * |
|
| 598 | + * |
|
| 599 | + * @param bool $should_expire |
|
| 600 | 600 | * @param WPInv_Subscription $subscription |
| 601 | - */ |
|
| 602 | - public function maybe_renew_subscription( $should_expire, $subscription ) { |
|
| 601 | + */ |
|
| 602 | + public function maybe_renew_subscription( $should_expire, $subscription ) { |
|
| 603 | 603 | |
| 604 | 604 | // Ensure its our subscription && it's active. |
| 605 | 605 | if ( $this->id != $subscription->get_gateway() || ! $subscription->has_status( 'active trialling' ) ) { |
@@ -616,18 +616,18 @@ discard block |
||
| 616 | 616 | |
| 617 | 617 | return false; |
| 618 | 618 | |
| 619 | - } |
|
| 619 | + } |
|
| 620 | 620 | |
| 621 | 621 | /** |
| 622 | - * Renews a subscription. |
|
| 623 | - * |
|
| 622 | + * Renews a subscription. |
|
| 623 | + * |
|
| 624 | 624 | * @param WPInv_Subscription $subscription |
| 625 | - */ |
|
| 626 | - public function renew_subscription( $subscription ) { |
|
| 625 | + */ |
|
| 626 | + public function renew_subscription( $subscription ) { |
|
| 627 | 627 | |
| 628 | - // Generate the renewal invoice. |
|
| 629 | - $new_invoice = $subscription->create_payment(); |
|
| 630 | - $old_invoice = $subscription->get_parent_payment(); |
|
| 628 | + // Generate the renewal invoice. |
|
| 629 | + $new_invoice = $subscription->create_payment(); |
|
| 630 | + $old_invoice = $subscription->get_parent_payment(); |
|
| 631 | 631 | |
| 632 | 632 | if ( empty( $new_invoice ) ) { |
| 633 | 633 | $old_invoice->add_note( __( 'Error generating a renewal invoice.', 'invoicing' ), false, false, false ); |
@@ -636,37 +636,37 @@ discard block |
||
| 636 | 636 | } |
| 637 | 637 | |
| 638 | 638 | // Charge the payment method. |
| 639 | - $payment_profile_id = get_post_meta( $old_invoice->get_id(), 'getpaid_authorizenet_profile_id', true ); |
|
| 640 | - $customer_profile = get_user_meta( $old_invoice->get_user_id(), $this->get_customer_profile_meta_name( $old_invoice ), true ); |
|
| 641 | - $result = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $new_invoice ); |
|
| 642 | - |
|
| 643 | - // Do we have an error? |
|
| 644 | - if ( is_wp_error( $result ) ) { |
|
| 645 | - |
|
| 646 | - $old_invoice->add_note( |
|
| 647 | - sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), $result->get_error_message() ), |
|
| 648 | - true, |
|
| 649 | - false, |
|
| 650 | - true |
|
| 651 | - ); |
|
| 652 | - $subscription->failing(); |
|
| 653 | - return; |
|
| 654 | - |
|
| 655 | - } |
|
| 656 | - |
|
| 657 | - // Process the response. |
|
| 658 | - $this->process_charge_response( $result, $new_invoice ); |
|
| 659 | - |
|
| 660 | - if ( wpinv_get_errors() ) { |
|
| 661 | - |
|
| 662 | - $old_invoice->add_note( |
|
| 663 | - sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), getpaid_get_errors_html() ), |
|
| 664 | - true, |
|
| 665 | - false, |
|
| 666 | - true |
|
| 667 | - ); |
|
| 668 | - $subscription->failing(); |
|
| 669 | - return; |
|
| 639 | + $payment_profile_id = get_post_meta( $old_invoice->get_id(), 'getpaid_authorizenet_profile_id', true ); |
|
| 640 | + $customer_profile = get_user_meta( $old_invoice->get_user_id(), $this->get_customer_profile_meta_name( $old_invoice ), true ); |
|
| 641 | + $result = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $new_invoice ); |
|
| 642 | + |
|
| 643 | + // Do we have an error? |
|
| 644 | + if ( is_wp_error( $result ) ) { |
|
| 645 | + |
|
| 646 | + $old_invoice->add_note( |
|
| 647 | + sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), $result->get_error_message() ), |
|
| 648 | + true, |
|
| 649 | + false, |
|
| 650 | + true |
|
| 651 | + ); |
|
| 652 | + $subscription->failing(); |
|
| 653 | + return; |
|
| 654 | + |
|
| 655 | + } |
|
| 656 | + |
|
| 657 | + // Process the response. |
|
| 658 | + $this->process_charge_response( $result, $new_invoice ); |
|
| 659 | + |
|
| 660 | + if ( wpinv_get_errors() ) { |
|
| 661 | + |
|
| 662 | + $old_invoice->add_note( |
|
| 663 | + sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), getpaid_get_errors_html() ), |
|
| 664 | + true, |
|
| 665 | + false, |
|
| 666 | + true |
|
| 667 | + ); |
|
| 668 | + $subscription->failing(); |
|
| 669 | + return; |
|
| 670 | 670 | |
| 671 | 671 | } |
| 672 | 672 | |
@@ -675,13 +675,13 @@ discard block |
||
| 675 | 675 | } |
| 676 | 676 | |
| 677 | 677 | /** |
| 678 | - * Processes invoice addons. |
|
| 679 | - * |
|
| 680 | - * @param WPInv_Invoice $invoice |
|
| 681 | - * @param GetPaid_Form_Item[] $items |
|
| 682 | - * @return WPInv_Invoice |
|
| 683 | - */ |
|
| 684 | - public function process_addons( $invoice, $items ) { |
|
| 678 | + * Processes invoice addons. |
|
| 679 | + * |
|
| 680 | + * @param WPInv_Invoice $invoice |
|
| 681 | + * @param GetPaid_Form_Item[] $items |
|
| 682 | + * @return WPInv_Invoice |
|
| 683 | + */ |
|
| 684 | + public function process_addons( $invoice, $items ) { |
|
| 685 | 685 | |
| 686 | 686 | global $getpaid_authorize_addons; |
| 687 | 687 | |
@@ -701,7 +701,7 @@ discard block |
||
| 701 | 701 | $invoice->recalculate_total(); |
| 702 | 702 | |
| 703 | 703 | $payment_profile_id = get_post_meta( $invoice->get_id(), 'getpaid_authorizenet_profile_id', true ); |
| 704 | - $customer_profile = get_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), true ); |
|
| 704 | + $customer_profile = get_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), true ); |
|
| 705 | 705 | |
| 706 | 706 | add_filter( 'getpaid_authorizenet_charge_customer_payment_profile_args', array( $this, 'filter_addons_request' ), 10, 2 ); |
| 707 | 707 | $result = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $invoice ); |
@@ -716,11 +716,11 @@ discard block |
||
| 716 | 716 | } |
| 717 | 717 | |
| 718 | 718 | /** |
| 719 | - * Processes invoice addons. |
|
| 720 | - * |
|
| 719 | + * Processes invoice addons. |
|
| 720 | + * |
|
| 721 | 721 | * @param array $args |
| 722 | - * @return array |
|
| 723 | - */ |
|
| 722 | + * @return array |
|
| 723 | + */ |
|
| 724 | 724 | public function filter_addons_request( $args ) { |
| 725 | 725 | |
| 726 | 726 | global $getpaid_authorize_addons; |
@@ -754,11 +754,11 @@ discard block |
||
| 754 | 754 | } |
| 755 | 755 | |
| 756 | 756 | /** |
| 757 | - * Filters the gateway settings. |
|
| 758 | - * |
|
| 759 | - * @param array $admin_settings |
|
| 760 | - */ |
|
| 761 | - public function admin_settings( $admin_settings ) { |
|
| 757 | + * Filters the gateway settings. |
|
| 758 | + * |
|
| 759 | + * @param array $admin_settings |
|
| 760 | + */ |
|
| 761 | + public function admin_settings( $admin_settings ) { |
|
| 762 | 762 | |
| 763 | 763 | $currencies = sprintf( |
| 764 | 764 | __( 'Supported Currencies: %s', 'invoicing' ), |
@@ -798,7 +798,7 @@ discard block |
||
| 798 | 798 | 'readonly' => true, |
| 799 | 799 | ); |
| 800 | 800 | |
| 801 | - return $admin_settings; |
|
| 802 | - } |
|
| 801 | + return $admin_settings; |
|
| 802 | + } |
|
| 803 | 803 | |
| 804 | 804 | } |
@@ -235,7 +235,7 @@ |
||
| 235 | 235 | do_action( 'getpaid_checkout_invoice_exception', $invoice ); |
| 236 | 236 | } |
| 237 | 237 | |
| 238 | - // Do we have any errors? |
|
| 238 | + // Do we have any errors? |
|
| 239 | 239 | if ( wpinv_get_errors() ) { |
| 240 | 240 | wp_send_json_error( getpaid_get_errors_html( true, false ) ); |
| 241 | 241 | } |