abstract-shortcode-generator.php
8 years ago
admin-shortcodes.js
7 years ago
class-shortcode-button.php
7 years ago
mce-plugin.js
8 years ago
shortcode-give-donation-grid.php
7 years ago
shortcode-give-donation-history.php
8 years ago
shortcode-give-donor-wall.php
7 years ago
shortcode-give-form.php
8 years ago
shortcode-give-goal.php
8 years ago
shortcode-give-login.php
8 years ago
shortcode-give-profile-editor.php
8 years ago
shortcode-give-receipt.php
8 years ago
shortcode-give-register.php
8 years ago
shortcode-give-totals.php
8 years ago
admin-shortcodes.js
230 lines
| 1 | /*! |
| 2 | * Give Admin Shortcodes JS |
| 3 | * |
| 4 | * @description: The Give Admin Shortcode scripts. Only enqueued on the admin widgets screen; used to show shortcode dialogs, show/hide, and other functions |
| 5 | * @package: Give |
| 6 | * @subpackage: Assets/JS |
| 7 | * @author: Paul Ryley |
| 8 | * @copyright: Copyright (c) 2016, WordImpress |
| 9 | * @license: http://opensource.org/licenses/gpl-2.0.php GNU Public License |
| 10 | * @since: 1.3.0 |
| 11 | */ |
| 12 | |
| 13 | /* global ajaxurl, jQuery, scShortcodes, tinymce */ |
| 14 | |
| 15 | import {GiveWarningAlert, GiveErrorAlert, GiveConfirmModal} from '../../../assets/src/js/plugins/modal'; |
| 16 | |
| 17 | var scShortcode, scButton; |
| 18 | |
| 19 | |
| 20 | jQuery( function( $ ) { |
| 21 | |
| 22 | let doc = $( this ); |
| 23 | |
| 24 | /** |
| 25 | * Show continue button title setting field only if display style is not All Fields. |
| 26 | */ |
| 27 | window.render_continue_button_title_field = function() { |
| 28 | var selected_display_style = $('.mce-txt', '.mce-give-display-style').text(), |
| 29 | expected_display_styles = [ '- Select -', 'All Fields' ]; |
| 30 | |
| 31 | if( -1 !== $.inArray( selected_display_style, expected_display_styles ) ) { |
| 32 | $('.mce-give-continue-button-title').closest('.mce-container' ).hide() |
| 33 | } else { |
| 34 | $('.mce-give-continue-button-title').closest('.mce-container' ).show() |
| 35 | } |
| 36 | }; |
| 37 | |
| 38 | window.scForm = { |
| 39 | |
| 40 | open: function( editor_id ) { |
| 41 | var editor = tinymce.get( editor_id ); |
| 42 | |
| 43 | if ( ! editor ) { |
| 44 | return; |
| 45 | } |
| 46 | |
| 47 | var data, field, required, valid, win; |
| 48 | |
| 49 | data = { |
| 50 | action : 'give_shortcode', |
| 51 | shortcode : scShortcode |
| 52 | }; |
| 53 | |
| 54 | $.post( ajaxurl, data, function( response ) { |
| 55 | |
| 56 | // what happens if response === false? |
| 57 | if ( ! response.body ) { |
| 58 | console.error( 'Bad AJAX response!' ); |
| 59 | return; |
| 60 | } |
| 61 | |
| 62 | if ( response.body.length === 0 ) { |
| 63 | window.send_to_editor( '[' + response.shortcode + ']' ); |
| 64 | |
| 65 | scForm.destroy(); |
| 66 | |
| 67 | return; |
| 68 | } |
| 69 | |
| 70 | /** |
| 71 | * Render continue button title setting field on basis of display style value. |
| 72 | */ |
| 73 | $.each( response.body, function( index, item ){ |
| 74 | |
| 75 | if( 'display_style' === item.name ) { |
| 76 | response.body[index].onselect = function(){ |
| 77 | render_continue_button_title_field(); |
| 78 | }; |
| 79 | } |
| 80 | }); |
| 81 | |
| 82 | var popup = { |
| 83 | title : response.title, |
| 84 | body : response.body, |
| 85 | classes: 'sc-popup', |
| 86 | minWidth: 320, |
| 87 | buttons : [ { |
| 88 | text : response.ok, |
| 89 | classes : 'primary sc-primary', |
| 90 | onclick : function() { |
| 91 | // Get the top most window object |
| 92 | win = editor.windowManager.getWindows()[0]; |
| 93 | |
| 94 | // Get the shortcode required attributes |
| 95 | required = scShortcodes[ scShortcode ]; |
| 96 | |
| 97 | valid = true; |
| 98 | |
| 99 | // Do some validation voodoo |
| 100 | for ( var id in required ) { |
| 101 | if ( required.hasOwnProperty( id ) ) { |
| 102 | |
| 103 | field = win.find( '#' + id )[0]; |
| 104 | |
| 105 | if ( typeof field !== 'undefined' && field.state.data.value === '' ) { |
| 106 | |
| 107 | valid = false; |
| 108 | |
| 109 | new GiveErrorAlert({ |
| 110 | modalContent:{ |
| 111 | desc: required[ id ], |
| 112 | cancelBtnTitle: give_vars.ok, |
| 113 | } |
| 114 | }).render(); |
| 115 | |
| 116 | break; |
| 117 | } |
| 118 | } |
| 119 | } |
| 120 | |
| 121 | if ( valid ) { |
| 122 | win.submit(); |
| 123 | } |
| 124 | } |
| 125 | }, |
| 126 | { |
| 127 | text : response.close, |
| 128 | onclick : 'close' |
| 129 | }, ], |
| 130 | onsubmit: function( e ) { |
| 131 | var attributes = ''; |
| 132 | |
| 133 | for ( var key in e.data ) { |
| 134 | if ( e.data.hasOwnProperty( key ) && e.data[ key ] !== '' ) { |
| 135 | attributes += ' ' + key + '="' + e.data[ key ] + '"'; |
| 136 | } |
| 137 | } |
| 138 | |
| 139 | // Insert shortcode into the WP_Editor |
| 140 | window.send_to_editor( '[' + response.shortcode + attributes + ']' ); |
| 141 | }, |
| 142 | onclose: function() { |
| 143 | scForm.destroy(); |
| 144 | }, |
| 145 | onopen: function() { |
| 146 | // Conditional fields. |
| 147 | render_continue_button_title_field(); |
| 148 | } |
| 149 | }; |
| 150 | |
| 151 | // Change the buttons if server-side validation failed |
| 152 | if ( response.ok.constructor === Array ) { |
| 153 | popup.buttons[0].text = response.ok[0]; |
| 154 | popup.buttons[0].onclick = 'close'; |
| 155 | delete popup.buttons[1]; |
| 156 | } |
| 157 | |
| 158 | editor.windowManager.open( popup ); |
| 159 | }); |
| 160 | }, |
| 161 | |
| 162 | destroy: function() { |
| 163 | var tmp = $( '#scTemp' ); |
| 164 | |
| 165 | if ( tmp.length ) { |
| 166 | tinymce.get( 'scTemp' ).remove(); |
| 167 | tmp.remove(); |
| 168 | } |
| 169 | } |
| 170 | }; |
| 171 | |
| 172 | var scOpen = function() { |
| 173 | scButton.addClass( 'active' ).parent().find( '.sc-menu' ).show(); |
| 174 | }; |
| 175 | |
| 176 | var scClose = function() { |
| 177 | if ( typeof scButton !== 'undefined' ) { |
| 178 | scButton.removeClass( 'active' ).parent().find( '.sc-menu' ).hide(); |
| 179 | } |
| 180 | }; |
| 181 | |
| 182 | doc.on( 'click', function( e ) { |
| 183 | if ( ! $( e.target ).closest( '.sc-wrap' ).length ) { |
| 184 | scClose(); |
| 185 | } |
| 186 | }); |
| 187 | |
| 188 | doc.on( 'click', '.sc-button', function( e ) { |
| 189 | e.preventDefault(); |
| 190 | |
| 191 | scButton = $( this ); |
| 192 | |
| 193 | if ( scButton.hasClass( 'active' ) ) { |
| 194 | scClose(); |
| 195 | } else { |
| 196 | scOpen(); |
| 197 | } |
| 198 | }); |
| 199 | |
| 200 | doc.on( 'click', '.sc-shortcode', function( e ) { |
| 201 | e.preventDefault(); |
| 202 | |
| 203 | // scShortcode is used by scForm to trigger the correct popup |
| 204 | scShortcode = $( this ).attr( 'data-shortcode' ); |
| 205 | |
| 206 | if ( scShortcode ) { |
| 207 | if ( ! tinymce.get( window.wpActiveEditor ) ) { |
| 208 | |
| 209 | if ( ! $( '#scTemp' ).length ) { |
| 210 | |
| 211 | $( 'body' ).append( '<textarea id="scTemp" style="display: none;" />' ); |
| 212 | |
| 213 | tinymce.init({ |
| 214 | mode : "exact", |
| 215 | elements : "scTemp", |
| 216 | plugins : ['give_shortcode', 'wplink'] |
| 217 | }); |
| 218 | } |
| 219 | |
| 220 | setTimeout( function() { tinymce.execCommand( 'Give_Shortcode' ); }, 200 ); |
| 221 | } else { |
| 222 | tinymce.execCommand( 'Give_Shortcode' ); |
| 223 | } |
| 224 | |
| 225 | setTimeout( function() { scClose(); }, 100 ); |
| 226 | } else { |
| 227 | console.warn( 'That is not a valid shortcode link.' ); |
| 228 | } |
| 229 | }); |
| 230 | }); |