Add upstream
897
wp-content/plugins/jetpack/modules/contact-form/admin.php
Normal file
@@ -0,0 +1,897 @@
|
||||
<?php
|
||||
|
||||
use Automattic\Jetpack\Assets;
|
||||
|
||||
/**
|
||||
* Add a contact form button to the post composition screen
|
||||
*/
|
||||
add_action( 'media_buttons', 'grunion_media_button', 999 );
|
||||
function grunion_media_button() {
|
||||
global $post_ID, $temp_ID, $pagenow;
|
||||
|
||||
if ( 'press-this.php' === $pagenow ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$iframe_post_id = (int) ( 0 == $post_ID ? $temp_ID : $post_ID );
|
||||
$title = __( 'Add Contact Form', 'jetpack' );
|
||||
$plugin_url = esc_url( GRUNION_PLUGIN_URL );
|
||||
$site_url = esc_url( admin_url( "/admin-ajax.php?post_id={$iframe_post_id}&action=grunion_form_builder&TB_iframe=true&width=768" ) );
|
||||
?>
|
||||
|
||||
<a id="insert-jetpack-contact-form" class="button thickbox" title="<?php echo esc_attr( $title ); ?>" data-editor="content" href="<?php echo $site_url; ?>&id=add_form">
|
||||
<span class="jetpack-contact-form-icon"></span> <?php echo esc_html( $title ); ?>
|
||||
</a>
|
||||
|
||||
<?php
|
||||
}
|
||||
|
||||
add_action( 'wp_ajax_grunion_form_builder', 'grunion_display_form_view' );
|
||||
|
||||
function grunion_display_form_view() {
|
||||
if ( current_user_can( 'edit_posts' ) ) {
|
||||
require_once GRUNION_PLUGIN_DIR . 'grunion-form-view.php';
|
||||
}
|
||||
exit;
|
||||
}
|
||||
|
||||
// feedback specific css items
|
||||
add_action( 'admin_print_styles', 'grunion_admin_css' );
|
||||
function grunion_admin_css() {
|
||||
global $current_screen;
|
||||
if ( is_null( $current_screen ) ) {
|
||||
return;
|
||||
}
|
||||
if ( 'edit-feedback' !== $current_screen->id ) {
|
||||
return;
|
||||
}
|
||||
|
||||
wp_enqueue_script( 'wp-lists' );
|
||||
?>
|
||||
|
||||
<style type='text/css'>
|
||||
.add-new-h2, .view-switch, body.no-js .tablenav select[name^=action], body.no-js #doaction, body.no-js #doaction2 {
|
||||
display: none
|
||||
}
|
||||
|
||||
.column-feedback_from img {
|
||||
float:left;
|
||||
margin-right:10px;
|
||||
margin-top:3px;
|
||||
}
|
||||
|
||||
.widefat .column-feedback_from {
|
||||
width: 17%;
|
||||
}
|
||||
.widefat .column-feedback_date {
|
||||
width: 17%;
|
||||
}
|
||||
|
||||
.spam a {
|
||||
color: #BC0B0B;
|
||||
}
|
||||
|
||||
.untrash a {
|
||||
color: #D98500;
|
||||
}
|
||||
|
||||
.unspam a {
|
||||
color: #D98500;
|
||||
}
|
||||
|
||||
</style>
|
||||
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Hack a 'Bulk Spam' option for bulk edit in other than spam view
|
||||
* Hack a 'Bulk Delete' option for bulk edit in spam view
|
||||
*
|
||||
* There isn't a better way to do this until
|
||||
* http://core.trac.wordpress.org/changeset/17297 is resolved
|
||||
*/
|
||||
add_action( 'admin_head', 'grunion_add_bulk_edit_option' );
|
||||
function grunion_add_bulk_edit_option() {
|
||||
|
||||
$screen = get_current_screen();
|
||||
|
||||
if ( is_null( $screen ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
if ( 'edit-feedback' != $screen->id ) {
|
||||
return;
|
||||
}
|
||||
|
||||
// When viewing spam we want to be able to be able to bulk delete
|
||||
// When viewing anything we want to be able to bulk move to spam
|
||||
if ( isset( $_GET['post_status'] ) && 'spam' == $_GET['post_status'] ) {
|
||||
// Create Delete Permanently bulk item
|
||||
$option_val = 'delete';
|
||||
$option_txt = __( 'Delete Permanently', 'jetpack' );
|
||||
$pseudo_selector = 'last-child';
|
||||
|
||||
} else {
|
||||
// Create Mark Spam bulk item
|
||||
$option_val = 'spam';
|
||||
$option_txt = __( 'Mark as Spam', 'jetpack' );
|
||||
$pseudo_selector = 'first-child';
|
||||
}
|
||||
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
jQuery(document).ready(function($) {
|
||||
$('#posts-filter .actions select').filter('[name=action], [name=action2]').find('option:<?php echo $pseudo_selector; ?>').after('<option value="<?php echo $option_val; ?>"><?php echo esc_attr( $option_txt ); ?></option>' );
|
||||
})
|
||||
</script>
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Hack an 'Empty Spam' button to spam view
|
||||
*
|
||||
* Leverages core's delete_all functionality
|
||||
*/
|
||||
add_action( 'admin_head', 'grunion_add_empty_spam_button' );
|
||||
function grunion_add_empty_spam_button() {
|
||||
$screen = get_current_screen();
|
||||
|
||||
if ( is_null( $screen ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Only add to feedback, only to spam view
|
||||
if ( 'edit-feedback' != $screen->id
|
||||
|| empty( $_GET['post_status'] )
|
||||
|| 'spam' !== $_GET['post_status'] ) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Get HTML for the button
|
||||
$button_html = wp_nonce_field( 'bulk-destroy', '_destroy_nonce', true, false );
|
||||
$button_html .= get_submit_button( __( 'Empty Spam', 'jetpack' ), 'apply', 'delete_all', false );
|
||||
|
||||
// Add the button next to the filter button via js
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
jQuery(document).ready(function($) {
|
||||
$('#posts-filter #post-query-submit').after('<?php echo $button_html; ?>' );
|
||||
})
|
||||
</script>
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle a bulk spam report
|
||||
*/
|
||||
add_action( 'admin_init', 'grunion_handle_bulk_spam' );
|
||||
function grunion_handle_bulk_spam() {
|
||||
global $pagenow;
|
||||
|
||||
if ( 'edit.php' != $pagenow
|
||||
|| ( empty( $_REQUEST['post_type'] ) || 'feedback' != $_REQUEST['post_type'] ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Slip in a success message
|
||||
if ( ! empty( $_REQUEST['message'] ) && 'marked-spam' == $_REQUEST['message'] ) {
|
||||
add_action( 'admin_notices', 'grunion_message_bulk_spam' );
|
||||
}
|
||||
|
||||
if ( ( empty( $_REQUEST['action'] ) || 'spam' != $_REQUEST['action'] ) && ( empty( $_REQUEST['action2'] ) || 'spam' != $_REQUEST['action2'] ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
check_admin_referer( 'bulk-posts' );
|
||||
|
||||
if ( empty( $_REQUEST['post'] ) ) {
|
||||
wp_safe_redirect( wp_get_referer() );
|
||||
exit;
|
||||
}
|
||||
|
||||
$post_ids = array_map( 'intval', $_REQUEST['post'] );
|
||||
|
||||
foreach ( $post_ids as $post_id ) {
|
||||
if ( ! current_user_can( 'edit_page', $post_id ) ) {
|
||||
wp_die( __( 'You are not allowed to manage this item.', 'jetpack' ) );
|
||||
}
|
||||
|
||||
$post = array(
|
||||
'ID' => $post_id,
|
||||
'post_status' => 'spam',
|
||||
);
|
||||
$akismet_values = get_post_meta( $post_id, '_feedback_akismet_values', true );
|
||||
wp_update_post( $post );
|
||||
|
||||
/**
|
||||
* Fires after a comment has been marked by Akismet.
|
||||
*
|
||||
* Typically this means the comment is spam.
|
||||
*
|
||||
* @module contact-form
|
||||
*
|
||||
* @since 2.2.0
|
||||
*
|
||||
* @param string $comment_status Usually is 'spam', otherwise 'ham'.
|
||||
* @param array $akismet_values From '_feedback_akismet_values' in comment meta
|
||||
*/
|
||||
do_action( 'contact_form_akismet', 'spam', $akismet_values );
|
||||
}
|
||||
|
||||
$redirect_url = add_query_arg( 'message', 'marked-spam', wp_get_referer() );
|
||||
wp_safe_redirect( $redirect_url );
|
||||
exit;
|
||||
}
|
||||
|
||||
function grunion_message_bulk_spam() {
|
||||
echo '<div class="updated"><p>' . __( 'Feedback(s) marked as spam', 'jetpack' ) . '</p></div>';
|
||||
}
|
||||
|
||||
// remove admin UI parts that we don't support in feedback management
|
||||
add_action( 'admin_menu', 'grunion_admin_menu' );
|
||||
function grunion_admin_menu() {
|
||||
global $menu, $submenu;
|
||||
unset( $submenu['edit.php?post_type=feedback'] );
|
||||
}
|
||||
|
||||
add_filter( 'bulk_actions-edit-feedback', 'grunion_admin_bulk_actions' );
|
||||
function grunion_admin_bulk_actions( $actions ) {
|
||||
global $current_screen;
|
||||
if ( 'edit-feedback' != $current_screen->id ) {
|
||||
return $actions;
|
||||
}
|
||||
|
||||
unset( $actions['edit'] );
|
||||
return $actions;
|
||||
}
|
||||
|
||||
add_filter( 'views_edit-feedback', 'grunion_admin_view_tabs' );
|
||||
function grunion_admin_view_tabs( $views ) {
|
||||
global $current_screen;
|
||||
if ( 'edit-feedback' != $current_screen->id ) {
|
||||
return $views;
|
||||
}
|
||||
|
||||
unset( $views['publish'] );
|
||||
|
||||
preg_match( '|post_type=feedback\'( class="current")?\>(.*)\<span class=|', $views['all'], $match );
|
||||
if ( ! empty( $match[2] ) ) {
|
||||
$views['all'] = str_replace( $match[2], __( 'Messages', 'jetpack' ) . ' ', $views['all'] );
|
||||
}
|
||||
|
||||
return $views;
|
||||
}
|
||||
|
||||
add_filter( 'manage_feedback_posts_columns', 'grunion_post_type_columns_filter' );
|
||||
function grunion_post_type_columns_filter( $cols ) {
|
||||
$cols = array(
|
||||
'cb' => '<input type="checkbox" />',
|
||||
'feedback_from' => __( 'From', 'jetpack' ),
|
||||
'feedback_message' => __( 'Message', 'jetpack' ),
|
||||
'feedback_date' => __( 'Date', 'jetpack' ),
|
||||
);
|
||||
|
||||
return $cols;
|
||||
}
|
||||
|
||||
add_action( 'manage_posts_custom_column', 'grunion_manage_post_columns', 10, 2 );
|
||||
function grunion_manage_post_columns( $col, $post_id ) {
|
||||
global $post;
|
||||
|
||||
/**
|
||||
* Only call parse_fields_from_content if we're dealing with a Grunion custom column.
|
||||
*/
|
||||
if ( ! in_array( $col, array( 'feedback_date', 'feedback_from', 'feedback_message' ) ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$content_fields = Grunion_Contact_Form_Plugin::parse_fields_from_content( $post_id );
|
||||
|
||||
switch ( $col ) {
|
||||
case 'feedback_from':
|
||||
$author_name = isset( $content_fields['_feedback_author'] ) ? $content_fields['_feedback_author'] : '';
|
||||
$author_email = isset( $content_fields['_feedback_author_email'] ) ? $content_fields['_feedback_author_email'] : '';
|
||||
$author_url = isset( $content_fields['_feedback_author_url'] ) ? $content_fields['_feedback_author_url'] : '';
|
||||
$author_ip = isset( $content_fields['_feedback_ip'] ) ? $content_fields['_feedback_ip'] : '';
|
||||
$form_url = isset( $post->post_parent ) ? get_permalink( $post->post_parent ) : null;
|
||||
|
||||
$author_name_line = '';
|
||||
if ( ! empty( $author_name ) ) {
|
||||
if ( ! empty( $author_email ) ) {
|
||||
$author_name_line = get_avatar( $author_email, 32 );
|
||||
}
|
||||
|
||||
$author_name_line .= sprintf( '<strong>%s</strong><br />', esc_html( $author_name ) );
|
||||
}
|
||||
|
||||
$author_email_line = '';
|
||||
if ( ! empty( $author_email ) ) {
|
||||
$author_email_line = sprintf( "<a href='%1\$s' target='_blank'>%2\$s</a><br />", esc_url( 'mailto:' . $author_email ), esc_html( $author_email ) );
|
||||
}
|
||||
|
||||
$author_url_line = '';
|
||||
if ( ! empty( $author_url ) ) {
|
||||
$author_url_line = sprintf( "<a href='%1\$s'>%1\$s</a><br />", esc_url( $author_url ) );
|
||||
}
|
||||
|
||||
echo $author_name_line;
|
||||
echo $author_email_line;
|
||||
echo $author_url_line;
|
||||
echo "<a href='edit.php?post_type=feedback&s=" . urlencode( $author_ip );
|
||||
echo "&mode=detail'>" . esc_html( $author_ip ) . '</a><br />';
|
||||
if ( $form_url ) {
|
||||
echo '<a href="' . esc_url( $form_url ) . '">' . esc_html( $form_url ) . '</a>';
|
||||
}
|
||||
break;
|
||||
|
||||
case 'feedback_message':
|
||||
$post_type_object = get_post_type_object( $post->post_type );
|
||||
if ( isset( $content_fields['_feedback_subject'] ) ) {
|
||||
echo '<strong>';
|
||||
echo esc_html( $content_fields['_feedback_subject'] );
|
||||
echo '</strong>';
|
||||
echo '<br />';
|
||||
}
|
||||
echo sanitize_text_field( get_the_content( '' ) );
|
||||
echo '<br />';
|
||||
|
||||
$extra_fields = get_post_meta( $post_id, '_feedback_extra_fields', true );
|
||||
if ( ! empty( $extra_fields ) ) {
|
||||
echo '<br /><hr />';
|
||||
echo '<table cellspacing="0" cellpadding="0" style="">' . "\n";
|
||||
foreach ( (array) $extra_fields as $k => $v ) {
|
||||
// Remove prefix from exta fields
|
||||
echo "<tr><td align='right'><b>" . esc_html( preg_replace( '#^\d+_#', '', $k ) ) . '</b></td><td>' . sanitize_text_field( $v ) . "</td></tr>\n";
|
||||
}
|
||||
echo '</table>';
|
||||
}
|
||||
|
||||
echo '<div class="row-actions">';
|
||||
if ( $post->post_status == 'trash' ) {
|
||||
echo '<span class="untrash" id="feedback-restore-' . $post_id;
|
||||
echo '"><a title="';
|
||||
echo esc_attr__( 'Restore this item from the Trash', 'jetpack' );
|
||||
echo '" href="' . wp_nonce_url( admin_url( sprintf( $post_type_object->_edit_link . '&action=untrash', $post->ID ) ), 'untrash-' . $post->post_type . '_' . $post->ID );
|
||||
echo '">' . __( 'Restore', 'jetpack' ) . '</a></span> | ';
|
||||
|
||||
echo "<span class='delete'> <a class='submitdelete' title='";
|
||||
echo esc_attr( __( 'Delete this item permanently', 'jetpack' ) );
|
||||
echo "' href='" . get_delete_post_link( $post->ID, '', true );
|
||||
echo "'>" . __( 'Delete Permanently', 'jetpack' ) . '</a></span>';
|
||||
?>
|
||||
|
||||
<script>
|
||||
jQuery(document).ready(function($) {
|
||||
$('#feedback-restore-<?php echo $post_id; ?>').click(function(e) {
|
||||
e.preventDefault();
|
||||
$.post(ajaxurl, {
|
||||
action: 'grunion_ajax_spam',
|
||||
post_id: '<?php echo $post_id; ?>',
|
||||
make_it: 'publish',
|
||||
sub_menu: jQuery('.subsubsub .current').attr('href'),
|
||||
_ajax_nonce: '<?php echo wp_create_nonce( 'grunion-post-status-' . $post_id ); ?>'
|
||||
},
|
||||
function(r) {
|
||||
$('#post-<?php echo $post_id; ?>')
|
||||
.css({backgroundColor: '#59C859'})
|
||||
.fadeOut(350, function() {
|
||||
$(this).remove();
|
||||
$('.subsubsub').html(r);
|
||||
});
|
||||
}
|
||||
);
|
||||
});
|
||||
});
|
||||
</script>
|
||||
|
||||
<?php
|
||||
} elseif ( $post->post_status == 'publish' ) {
|
||||
echo '<span class="spam" id="feedback-spam-' . $post_id;
|
||||
echo '"><a title="';
|
||||
echo __( 'Mark this message as spam', 'jetpack' );
|
||||
echo '" href="' . wp_nonce_url( admin_url( 'admin-ajax.php?post_id=' . $post_id . '&action=spam' ), 'spam-feedback_' . $post_id );
|
||||
echo '">Spam</a></span>';
|
||||
echo ' | ';
|
||||
|
||||
echo '<span class="delete" id="feedback-trash-' . $post_id;
|
||||
echo '">';
|
||||
echo '<a class="submitdelete" title="' . esc_attr__( 'Trash', 'jetpack' );
|
||||
echo '" href="' . get_delete_post_link( $post_id );
|
||||
echo '">' . __( 'Trash', 'jetpack' ) . '</a></span>';
|
||||
|
||||
?>
|
||||
|
||||
<script>
|
||||
jQuery(document).ready( function($) {
|
||||
$('#feedback-spam-<?php echo $post_id; ?>').click( function(e) {
|
||||
e.preventDefault();
|
||||
$.post( ajaxurl, {
|
||||
action: 'grunion_ajax_spam',
|
||||
post_id: '<?php echo $post_id; ?>',
|
||||
make_it: 'spam',
|
||||
sub_menu: jQuery('.subsubsub .current').attr('href'),
|
||||
_ajax_nonce: '<?php echo wp_create_nonce( 'grunion-post-status-' . $post_id ); ?>'
|
||||
},
|
||||
function( r ) {
|
||||
$('#post-<?php echo $post_id; ?>')
|
||||
.css( {backgroundColor:'#FF7979'} )
|
||||
.fadeOut(350, function() {
|
||||
$(this).remove();
|
||||
$('.subsubsub').html(r);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
$('#feedback-trash-<?php echo $post_id; ?>').click(function(e) {
|
||||
e.preventDefault();
|
||||
$.post(ajaxurl, {
|
||||
action: 'grunion_ajax_spam',
|
||||
post_id: '<?php echo $post_id; ?>',
|
||||
make_it: 'trash',
|
||||
sub_menu: jQuery('.subsubsub .current').attr('href'),
|
||||
_ajax_nonce: '<?php echo wp_create_nonce( 'grunion-post-status-' . $post_id ); ?>'
|
||||
},
|
||||
function(r) {
|
||||
$('#post-<?php echo $post_id; ?>')
|
||||
.css({backgroundColor: '#FF7979'})
|
||||
.fadeOut(350, function() {
|
||||
$(this).remove();
|
||||
$('.subsubsub').html(r);
|
||||
});
|
||||
}
|
||||
);
|
||||
});
|
||||
});
|
||||
</script>
|
||||
|
||||
<?php
|
||||
} elseif ( $post->post_status == 'spam' ) {
|
||||
echo '<span class="unspam unapprove" id="feedback-ham-' . $post_id;
|
||||
echo '"><a title="';
|
||||
echo __( 'Mark this message as NOT spam', 'jetpack' );
|
||||
echo '" href="">Not Spam</a></span>';
|
||||
echo ' | ';
|
||||
|
||||
echo "<span class='delete' id='feedback-trash-" . $post_id;
|
||||
echo "'> <a class='submitdelete' title='";
|
||||
echo esc_attr( __( 'Delete this item permanently', 'jetpack' ) );
|
||||
echo "' href='" . get_delete_post_link( $post->ID, '', true );
|
||||
echo "'>" . __( 'Delete Permanently', 'jetpack' ) . '</a></span>';
|
||||
?>
|
||||
|
||||
<script>
|
||||
jQuery(document).ready( function($) {
|
||||
$('#feedback-ham-<?php echo $post_id; ?>').click( function(e) {
|
||||
e.preventDefault();
|
||||
$.post( ajaxurl, {
|
||||
action: 'grunion_ajax_spam',
|
||||
post_id: '<?php echo $post_id; ?>',
|
||||
make_it: 'ham',
|
||||
sub_menu: jQuery('.subsubsub .current').attr('href'),
|
||||
_ajax_nonce: '<?php echo wp_create_nonce( 'grunion-post-status-' . $post_id ); ?>'
|
||||
},
|
||||
function( r ) {
|
||||
$('#post-<?php echo $post_id; ?>')
|
||||
.css( {backgroundColor:'#59C859'} )
|
||||
.fadeOut(350, function() {
|
||||
$(this).remove();
|
||||
$('.subsubsub').html(r);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
</script>
|
||||
|
||||
<?php
|
||||
}
|
||||
break;
|
||||
|
||||
case 'feedback_date':
|
||||
$date_time_format = _x( '%1$s \a\t %2$s', '{$date_format} \a\t {$time_format}', 'jetpack' );
|
||||
$date_time_format = sprintf( $date_time_format, get_option( 'date_format' ), get_option( 'time_format' ) );
|
||||
$time = date_i18n( $date_time_format, get_the_time( 'U' ) );
|
||||
|
||||
echo $time;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
function grunion_esc_attr( $attr ) {
|
||||
$out = esc_attr( $attr );
|
||||
// we also have to entity-encode square brackets so they don't interfere with the shortcode parser
|
||||
// FIXME: do this better - just stripping out square brackets for now since they mysteriously keep reappearing
|
||||
$out = str_replace( '[', '', $out );
|
||||
$out = str_replace( ']', '', $out );
|
||||
return $out;
|
||||
}
|
||||
|
||||
function grunion_sort_objects( $a, $b ) {
|
||||
if ( isset( $a['order'] ) && isset( $b['order'] ) ) {
|
||||
return $a['order'] - $b['order'];
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
// take an array of field types from the form builder, and construct a shortcode form
|
||||
// returns both the shortcode form, and HTML markup representing a preview of the form
|
||||
function grunion_ajax_shortcode() {
|
||||
check_ajax_referer( 'grunion_shortcode' );
|
||||
|
||||
if ( ! current_user_can( 'edit_posts' ) ) {
|
||||
die( '-1' );
|
||||
}
|
||||
|
||||
$attributes = array();
|
||||
|
||||
foreach ( array( 'subject', 'to' ) as $attribute ) {
|
||||
if ( isset( $_POST[ $attribute ] ) && strlen( $_POST[ $attribute ] ) ) {
|
||||
$attributes[ $attribute ] = stripslashes( $_POST[ $attribute ] );
|
||||
}
|
||||
}
|
||||
|
||||
if ( is_array( $_POST['fields'] ) ) {
|
||||
$fields = stripslashes_deep( $_POST['fields'] );
|
||||
usort( $fields, 'grunion_sort_objects' );
|
||||
|
||||
$field_shortcodes = array();
|
||||
|
||||
foreach ( $fields as $field ) {
|
||||
$field_attributes = array();
|
||||
|
||||
if ( isset( $field['required'] ) && 'true' === $field['required'] ) {
|
||||
$field_attributes['required'] = 'true';
|
||||
}
|
||||
|
||||
foreach ( array( 'options', 'label', 'type' ) as $attribute ) {
|
||||
if ( isset( $field[ $attribute ] ) ) {
|
||||
$field_attributes[ $attribute ] = $field[ $attribute ];
|
||||
}
|
||||
}
|
||||
|
||||
$field_shortcodes[] = new Grunion_Contact_Form_Field( $field_attributes );
|
||||
}
|
||||
}
|
||||
|
||||
$grunion = new Grunion_Contact_Form( $attributes, $field_shortcodes );
|
||||
|
||||
die( "\n$grunion\n" );
|
||||
}
|
||||
|
||||
// takes a post_id, extracts the contact-form shortcode from that post (if there is one), parses it,
|
||||
// and constructs a json object representing its contents and attributes
|
||||
function grunion_ajax_shortcode_to_json() {
|
||||
global $post, $grunion_form;
|
||||
|
||||
check_ajax_referer( 'grunion_shortcode_to_json' );
|
||||
|
||||
if ( ! empty( $_POST['post_id'] ) && ! current_user_can( 'edit_post', $_POST['post_id'] ) ) {
|
||||
die( '-1' );
|
||||
} elseif ( ! current_user_can( 'edit_posts' ) ) {
|
||||
die( '-1' );
|
||||
}
|
||||
|
||||
if ( ! isset( $_POST['content'] ) || ! is_numeric( $_POST['post_id'] ) ) {
|
||||
die( '-1' );
|
||||
}
|
||||
|
||||
$content = stripslashes( $_POST['content'] );
|
||||
|
||||
// doesn't look like a post with a [contact-form] already.
|
||||
if ( false === has_shortcode( $content, 'contact-form' ) ) {
|
||||
die( '' );
|
||||
}
|
||||
|
||||
$post = get_post( $_POST['post_id'] );
|
||||
|
||||
do_shortcode( $content );
|
||||
|
||||
$grunion = Grunion_Contact_Form::$last;
|
||||
|
||||
$out = array(
|
||||
'to' => '',
|
||||
'subject' => '',
|
||||
'fields' => array(),
|
||||
);
|
||||
|
||||
foreach ( $grunion->fields as $field ) {
|
||||
$out['fields'][ $field->get_attribute( 'id' ) ] = $field->attributes;
|
||||
}
|
||||
|
||||
$to = $grunion->get_attribute( 'to' );
|
||||
$subject = $grunion->get_attribute( 'subject' );
|
||||
foreach ( array( 'to', 'subject' ) as $attribute ) {
|
||||
$value = $grunion->get_attribute( $attribute );
|
||||
if ( isset( $grunion->defaults[ $attribute ] ) && $value == $grunion->defaults[ $attribute ] ) {
|
||||
$value = '';
|
||||
}
|
||||
$out[ $attribute ] = $value;
|
||||
}
|
||||
|
||||
die( json_encode( $out ) );
|
||||
}
|
||||
|
||||
|
||||
add_action( 'wp_ajax_grunion_shortcode', 'grunion_ajax_shortcode' );
|
||||
add_action( 'wp_ajax_grunion_shortcode_to_json', 'grunion_ajax_shortcode_to_json' );
|
||||
|
||||
|
||||
// process row-action spam/not spam clicks
|
||||
add_action( 'wp_ajax_grunion_ajax_spam', 'grunion_ajax_spam' );
|
||||
function grunion_ajax_spam() {
|
||||
global $wpdb;
|
||||
|
||||
if ( empty( $_POST['make_it'] ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$post_id = (int) $_POST['post_id'];
|
||||
check_ajax_referer( 'grunion-post-status-' . $post_id );
|
||||
if ( ! current_user_can( 'edit_page', $post_id ) ) {
|
||||
wp_die( __( 'You are not allowed to manage this item.', 'jetpack' ) );
|
||||
}
|
||||
|
||||
require_once dirname( __FILE__ ) . '/grunion-contact-form.php';
|
||||
|
||||
$current_menu = '';
|
||||
if ( isset( $_POST['sub_menu'] ) && preg_match( '|post_type=feedback|', $_POST['sub_menu'] ) ) {
|
||||
if ( preg_match( '|post_status=spam|', $_POST['sub_menu'] ) ) {
|
||||
$current_menu = 'spam';
|
||||
} elseif ( preg_match( '|post_status=trash|', $_POST['sub_menu'] ) ) {
|
||||
$current_menu = 'trash';
|
||||
} else {
|
||||
$current_menu = 'messages';
|
||||
}
|
||||
}
|
||||
|
||||
$post = get_post( $post_id );
|
||||
$post_type_object = get_post_type_object( $post->post_type );
|
||||
$akismet_values = get_post_meta( $post_id, '_feedback_akismet_values', true );
|
||||
if ( $_POST['make_it'] == 'spam' ) {
|
||||
$post->post_status = 'spam';
|
||||
$status = wp_insert_post( $post );
|
||||
wp_transition_post_status( 'spam', 'publish', $post );
|
||||
|
||||
/** This action is already documented in modules/contact-form/admin.php */
|
||||
do_action( 'contact_form_akismet', 'spam', $akismet_values );
|
||||
} elseif ( $_POST['make_it'] == 'ham' ) {
|
||||
$post->post_status = 'publish';
|
||||
$status = wp_insert_post( $post );
|
||||
wp_transition_post_status( 'publish', 'spam', $post );
|
||||
|
||||
/** This action is already documented in modules/contact-form/admin.php */
|
||||
do_action( 'contact_form_akismet', 'ham', $akismet_values );
|
||||
|
||||
$comment_author_email = $reply_to_addr = $message = $to = $headers = false;
|
||||
$blog_url = wp_parse_url( site_url() );
|
||||
|
||||
// resend the original email
|
||||
$email = get_post_meta( $post_id, '_feedback_email', true );
|
||||
$content_fields = Grunion_Contact_Form_Plugin::parse_fields_from_content( $post_id );
|
||||
|
||||
if ( ! empty( $email ) && ! empty( $content_fields ) ) {
|
||||
if ( isset( $content_fields['_feedback_author_email'] ) ) {
|
||||
$comment_author_email = $content_fields['_feedback_author_email'];
|
||||
}
|
||||
|
||||
if ( isset( $email['to'] ) ) {
|
||||
$to = $email['to'];
|
||||
}
|
||||
|
||||
if ( isset( $email['message'] ) ) {
|
||||
$message = $email['message'];
|
||||
}
|
||||
|
||||
if ( isset( $email['headers'] ) ) {
|
||||
$headers = $email['headers'];
|
||||
} else {
|
||||
$headers = 'From: "' . $content_fields['_feedback_author'] . '" <wordpress@' . $blog_url['host'] . ">\r\n";
|
||||
|
||||
if ( ! empty( $comment_author_email ) ) {
|
||||
$reply_to_addr = $comment_author_email;
|
||||
} elseif ( is_array( $to ) ) {
|
||||
$reply_to_addr = $to[0];
|
||||
}
|
||||
|
||||
if ( $reply_to_addr ) {
|
||||
$headers .= 'Reply-To: "' . $content_fields['_feedback_author'] . '" <' . $reply_to_addr . ">\r\n";
|
||||
}
|
||||
|
||||
$headers .= 'Content-Type: text/plain; charset="' . get_option( 'blog_charset' ) . '"';
|
||||
}
|
||||
|
||||
/**
|
||||
* Filters the subject of the email sent after a contact form submission.
|
||||
*
|
||||
* @module contact-form
|
||||
*
|
||||
* @since 3.0.0
|
||||
*
|
||||
* @param string $content_fields['_feedback_subject'] Feedback's subject line.
|
||||
* @param array $content_fields['_feedback_all_fields'] Feedback's data from old fields.
|
||||
*/
|
||||
$subject = apply_filters( 'contact_form_subject', $content_fields['_feedback_subject'], $content_fields['_feedback_all_fields'] );
|
||||
|
||||
Grunion_Contact_Form::wp_mail( $to, $subject, $message, $headers );
|
||||
}
|
||||
} elseif ( $_POST['make_it'] == 'publish' ) {
|
||||
if ( ! current_user_can( $post_type_object->cap->delete_post, $post_id ) ) {
|
||||
wp_die( __( 'You are not allowed to move this item out of the Trash.', 'jetpack' ) );
|
||||
}
|
||||
|
||||
if ( ! wp_untrash_post( $post_id ) ) {
|
||||
wp_die( __( 'Error in restoring from Trash.', 'jetpack' ) );
|
||||
}
|
||||
} elseif ( $_POST['make_it'] == 'trash' ) {
|
||||
if ( ! current_user_can( $post_type_object->cap->delete_post, $post_id ) ) {
|
||||
wp_die( __( 'You are not allowed to move this item to the Trash.', 'jetpack' ) );
|
||||
}
|
||||
|
||||
if ( ! wp_trash_post( $post_id ) ) {
|
||||
wp_die( __( 'Error in moving to Trash.', 'jetpack' ) );
|
||||
}
|
||||
}
|
||||
|
||||
$sql = "
|
||||
SELECT post_status,
|
||||
COUNT( * ) AS post_count
|
||||
FROM `{$wpdb->posts}`
|
||||
WHERE post_type = 'feedback'
|
||||
GROUP BY post_status
|
||||
";
|
||||
$status_count = (array) $wpdb->get_results( $sql, ARRAY_A );
|
||||
|
||||
$status = array();
|
||||
$status_html = '';
|
||||
foreach ( $status_count as $i => $row ) {
|
||||
$status[ $row['post_status'] ] = $row['post_count'];
|
||||
}
|
||||
|
||||
if ( isset( $status['publish'] ) ) {
|
||||
$status_html .= '<li><a href="edit.php?post_type=feedback"';
|
||||
if ( $current_menu == 'messages' ) {
|
||||
$status_html .= ' class="current"';
|
||||
}
|
||||
|
||||
$status_html .= '>' . __( 'Messages', 'jetpack' ) . ' <span class="count">';
|
||||
$status_html .= '(' . number_format( $status['publish'] ) . ')';
|
||||
$status_html .= '</span></a> |</li>';
|
||||
}
|
||||
|
||||
if ( isset( $status['trash'] ) ) {
|
||||
$status_html .= '<li><a href="edit.php?post_status=trash&post_type=feedback"';
|
||||
if ( $current_menu == 'trash' ) {
|
||||
$status_html .= ' class="current"';
|
||||
}
|
||||
|
||||
$status_html .= '>' . __( 'Trash', 'jetpack' ) . ' <span class="count">';
|
||||
$status_html .= '(' . number_format( $status['trash'] ) . ')';
|
||||
$status_html .= '</span></a>';
|
||||
if ( isset( $status['spam'] ) ) {
|
||||
$status_html .= ' |';
|
||||
}
|
||||
$status_html .= '</li>';
|
||||
}
|
||||
|
||||
if ( isset( $status['spam'] ) ) {
|
||||
$status_html .= '<li><a href="edit.php?post_status=spam&post_type=feedback"';
|
||||
if ( $current_menu == 'spam' ) {
|
||||
$status_html .= ' class="current"';
|
||||
}
|
||||
|
||||
$status_html .= '>' . __( 'Spam', 'jetpack' ) . ' <span class="count">';
|
||||
$status_html .= '(' . number_format( $status['spam'] ) . ')';
|
||||
$status_html .= '</span></a></li>';
|
||||
}
|
||||
|
||||
echo $status_html;
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add the scripts that will add the "Check for Spam" button to the Feedbacks dashboard page.
|
||||
*/
|
||||
function grunion_enable_spam_recheck() {
|
||||
if ( ! defined( 'AKISMET_VERSION' ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$screen = get_current_screen();
|
||||
|
||||
// Only add to feedback, only to non-spam view
|
||||
if ( 'edit-feedback' != $screen->id || ( ! empty( $_GET['post_status'] ) && 'spam' == $_GET['post_status'] ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Add the scripts that handle the spam check event.
|
||||
wp_register_script(
|
||||
'grunion-admin',
|
||||
Assets::get_file_url_for_environment(
|
||||
'_inc/build/contact-form/js/grunion-admin.min.js',
|
||||
'modules/contact-form/js/grunion-admin.js'
|
||||
),
|
||||
array( 'jquery' )
|
||||
);
|
||||
wp_enqueue_script( 'grunion-admin' );
|
||||
|
||||
wp_enqueue_style( 'grunion.css' );
|
||||
|
||||
// Add the actual "Check for Spam" button.
|
||||
add_action( 'admin_head', 'grunion_check_for_spam_button' );
|
||||
}
|
||||
|
||||
add_action( 'admin_enqueue_scripts', 'grunion_enable_spam_recheck' );
|
||||
|
||||
/**
|
||||
* Add the "Check for Spam" button to the Feedbacks dashboard page.
|
||||
*/
|
||||
function grunion_check_for_spam_button() {
|
||||
// Get HTML for the button
|
||||
$button_html = get_submit_button(
|
||||
__( 'Check for Spam', 'jetpack' ),
|
||||
'secondary',
|
||||
'jetpack-check-feedback-spam',
|
||||
false,
|
||||
array( 'class' => 'jetpack-check-feedback-spam' )
|
||||
);
|
||||
$button_html .= '<span class="jetpack-check-feedback-spam-spinner"></span>';
|
||||
|
||||
// Add the button next to the filter button via js
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
jQuery( function( $ ) {
|
||||
$( '#posts-filter #post-query-submit' ).after( '<?php echo $button_html; ?>' );
|
||||
} );
|
||||
</script>
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Recheck all approved feedbacks for spam.
|
||||
*/
|
||||
function grunion_recheck_queue() {
|
||||
global $wpdb;
|
||||
|
||||
$query = 'post_type=feedback&post_status=publish';
|
||||
|
||||
if ( isset( $_POST['limit'], $_POST['offset'] ) ) {
|
||||
$query .= '&posts_per_page=' . intval( $_POST['limit'] ) . '&offset=' . intval( $_POST['offset'] );
|
||||
}
|
||||
|
||||
$approved_feedbacks = get_posts( $query );
|
||||
|
||||
foreach ( $approved_feedbacks as $feedback ) {
|
||||
$meta = get_post_meta( $feedback->ID, '_feedback_akismet_values', true );
|
||||
|
||||
/**
|
||||
* Filter whether the submitted feedback is considered as spam.
|
||||
*
|
||||
* @module contact-form
|
||||
*
|
||||
* @since 3.4.0
|
||||
*
|
||||
* @param bool false Is the submitted feedback spam? Default to false.
|
||||
* @param array $meta Feedack values returned by the Akismet plugin.
|
||||
*/
|
||||
$is_spam = apply_filters( 'jetpack_contact_form_is_spam', false, $meta );
|
||||
|
||||
if ( $is_spam ) {
|
||||
wp_update_post(
|
||||
array(
|
||||
'ID' => $feedback->ID,
|
||||
'post_status' => 'spam',
|
||||
)
|
||||
);
|
||||
/** This action is already documented in modules/contact-form/admin.php */
|
||||
do_action( 'contact_form_akismet', 'spam', $meta );
|
||||
}
|
||||
}
|
||||
|
||||
wp_send_json(
|
||||
array(
|
||||
'processed' => count( $approved_feedbacks ),
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
add_action( 'wp_ajax_grunion_recheck_queue', 'grunion_recheck_queue' );
|
||||
@@ -0,0 +1,52 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* Plugin Name: Feedback CPT Permissions over-ride
|
||||
*/
|
||||
|
||||
if ( class_exists( 'WP_REST_Posts_Controller' ) ) {
|
||||
|
||||
/**
|
||||
* Class Grunion_Contact_Form_Endpoint
|
||||
* Used as 'rest_controller_class' parameter when 'feedback' post type is registered in modules/contact-form/grunion-contact-form.php.
|
||||
*/
|
||||
class Grunion_Contact_Form_Endpoint extends WP_REST_Posts_Controller {
|
||||
/**
|
||||
* Check whether a given request has proper authorization to view feedback items.
|
||||
*
|
||||
* @param WP_REST_Request $request Full details about the request.
|
||||
* @return WP_Error|boolean
|
||||
*/
|
||||
public function get_items_permissions_check( $request ) {
|
||||
if ( ! is_user_member_of_blog( get_current_user_id(), get_current_blog_id() ) ) {
|
||||
return new WP_Error(
|
||||
'rest_cannot_view',
|
||||
esc_html__( 'Sorry, you cannot view this resource.', 'jetpack' ),
|
||||
array( 'status' => 401 )
|
||||
);
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check whether a given request has proper authorization to view feedback item.
|
||||
*
|
||||
* @param WP_REST_Request $request Full details about the request.
|
||||
* @return WP_Error|boolean
|
||||
*/
|
||||
public function get_item_permissions_check( $request ) {
|
||||
if ( ! is_user_member_of_blog( get_current_user_id(), get_current_blog_id() ) ) {
|
||||
return new WP_Error(
|
||||
'rest_cannot_view',
|
||||
esc_html__( 'Sorry, you cannot view this resource.', 'jetpack' ),
|
||||
array( 'status' => 401 )
|
||||
);
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,825 @@
|
||||
/* Do not modify this file directly. It is concatenated from individual module CSS files. */
|
||||
/* ==========================================================================
|
||||
** Normalize
|
||||
** ======================================================================== */
|
||||
|
||||
html {
|
||||
direction: rtl;
|
||||
}
|
||||
|
||||
body {
|
||||
font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif;
|
||||
font-size: 16px;
|
||||
line-height: 1.4em;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
/* Links */
|
||||
a,
|
||||
a:visited {
|
||||
color: #0087be;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
a:hover,
|
||||
a:focus,
|
||||
a:active {
|
||||
color: $link-highlight;
|
||||
}
|
||||
|
||||
/* ==========================================================================
|
||||
** Card
|
||||
** ======================================================================= */
|
||||
|
||||
.card,
|
||||
body {
|
||||
display: block;
|
||||
position: relative;
|
||||
margin: 0 auto 10px auto;
|
||||
padding: 16px;
|
||||
box-sizing: border-box;
|
||||
background: white;
|
||||
box-shadow: 0 0 0 1px rgba(200, 215, 225, 0.5), 0 1px 2px #e9eff3;
|
||||
}
|
||||
|
||||
body {
|
||||
margin: 0;
|
||||
background: #f5f5f5;
|
||||
}
|
||||
|
||||
.card:after {
|
||||
content: ".";
|
||||
display: block;
|
||||
height: 0;
|
||||
clear: both;
|
||||
visibility: hidden;
|
||||
}
|
||||
|
||||
.card:hover,
|
||||
.card:focus {
|
||||
box-shadow: 0 0 0 1px #999, 0 1px 2px #e9eff3;
|
||||
}
|
||||
|
||||
.card .delete-field {
|
||||
display: block;
|
||||
float: left;
|
||||
}
|
||||
|
||||
@media ( min-width: 481px ) {
|
||||
.card {
|
||||
margin-bottom: 16px;
|
||||
padding: 24px;
|
||||
}
|
||||
body {
|
||||
padding: 24px;
|
||||
}
|
||||
}
|
||||
|
||||
.card.is-compact {
|
||||
margin-bottom: 1px;
|
||||
}
|
||||
|
||||
@media ( min-width: 481px ) {
|
||||
.card.is-compact {
|
||||
margin-bottom: 1px;
|
||||
padding: 16px 24px;
|
||||
}
|
||||
}
|
||||
|
||||
.card > div {
|
||||
margin-top: 24px;
|
||||
}
|
||||
|
||||
.card > div:first-child {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Labels
|
||||
** ======================================================================= */
|
||||
|
||||
label {
|
||||
display: block;
|
||||
font-size: 14px;
|
||||
font-weight: 600;
|
||||
margin-bottom: 5px;
|
||||
margin-top: 8px;
|
||||
}
|
||||
|
||||
label:first-of-type {
|
||||
margin-top: 4px;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Text Inputs
|
||||
** ======================================================================= */
|
||||
|
||||
input[type="text"],
|
||||
input[type="tel"],
|
||||
input[type="email"],
|
||||
input[type="url"] {
|
||||
border-radius: 0;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
box-sizing: border-box;
|
||||
margin: 0;
|
||||
padding: 7px 14px;
|
||||
width: 100%;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 1.5;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
input[type="text"]:-ms-input-placeholder,
|
||||
input[type="tel"]:-ms-input-placeholder,
|
||||
input[type="email"]:-ms-input-placeholder,
|
||||
input[type="url"]:-ms-input-placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
input[type="text"]::-ms-input-placeholder,
|
||||
input[type="tel"]::-ms-input-placeholder,
|
||||
input[type="email"]::-ms-input-placeholder,
|
||||
input[type="url"]::-ms-input-placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
input[type="text"]::placeholder,
|
||||
input[type="tel"]::placeholder,
|
||||
input[type="email"]::placeholder,
|
||||
input[type="url"]::placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
input[type="text"]:hover,
|
||||
input[type="tel"]:hover,
|
||||
input[type="email"]:hover,
|
||||
input[type="url"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:focus,
|
||||
input[type="tel"]:focus,
|
||||
input[type="email"]:focus,
|
||||
input[type="url"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="text"]:focus::-ms-clear,
|
||||
input[type="tel"]:focus::-ms-clear,
|
||||
input[type="email"]:focus::-ms-clear,
|
||||
input[type="url"]:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled,
|
||||
input[type="tel"]:disabled,
|
||||
input[type="email"]:disabled,
|
||||
input[type="url"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled:hover,
|
||||
input[type="tel"]:disabled:hover,
|
||||
input[type="email"]:disabled:hover,
|
||||
input[type="url"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled:-ms-input-placeholder,
|
||||
input[type="tel"]:disabled:-ms-input-placeholder,
|
||||
input[type="email"]:disabled:-ms-input-placeholder,
|
||||
input[type="url"]:disabled:-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled::-ms-input-placeholder,
|
||||
input[type="tel"]:disabled::-ms-input-placeholder,
|
||||
input[type="email"]:disabled::-ms-input-placeholder,
|
||||
input[type="url"]:disabled::-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled::placeholder,
|
||||
input[type="tel"]:disabled::placeholder,
|
||||
input[type="email"]:disabled::placeholder,
|
||||
input[type="url"]:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Textareas
|
||||
** ======================================================================= */
|
||||
|
||||
textarea {
|
||||
border-radius: 0;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
box-sizing: border-box;
|
||||
margin: 0;
|
||||
padding: 7px 14px;
|
||||
height: 92px;
|
||||
width: 100%;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 1.5;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
textarea:-ms-input-placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
textarea::-ms-input-placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
textarea::placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
textarea:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
textarea:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
textarea:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
textarea:disabled:-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:disabled::-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Checkboxes
|
||||
** ======================================================================= */
|
||||
|
||||
.checkbox,
|
||||
input[type="checkbox"] {
|
||||
-webkit-appearance: none;
|
||||
display: inline-block;
|
||||
box-sizing: border-box;
|
||||
margin: 2px 0 0;
|
||||
padding: 7px 14px;
|
||||
width: 16px;
|
||||
height: 16px;
|
||||
float: right;
|
||||
outline: 0;
|
||||
padding: 0;
|
||||
box-shadow: none;
|
||||
background-color: #fff;
|
||||
border: 1px solid #c8d7e1;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 0;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
transition: all .15s ease-in-out;
|
||||
clear: none;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.checkbox:checked:before,
|
||||
input[type="checkbox"]:checked:before {
|
||||
content: '\f147';
|
||||
font-family: Dashicons;
|
||||
margin: -3px -4px 0 0;
|
||||
float: right;
|
||||
display: inline-block;
|
||||
vertical-align: middle;
|
||||
width: 16px;
|
||||
font-size: 20px;
|
||||
line-height: 1;
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
speak: none;
|
||||
color: #00aadc;
|
||||
}
|
||||
|
||||
.checkbox:disabled:checked:before,
|
||||
input[type="checkbox"]:disabled:checked:before {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
.checkbox:hover,
|
||||
input[type="checkbox"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
.checkbox:focus,
|
||||
input[type="checkbox"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
.checkbox:disabled,
|
||||
input[type="checkbox"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
.checkbox:disabled:hover,
|
||||
input[type="checkbox"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
.checkbox + span,
|
||||
input[type="checkbox"] + span {
|
||||
display: block;
|
||||
font-weight: normal;
|
||||
margin-right: 24px;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Radio buttons
|
||||
** ======================================================================== */
|
||||
|
||||
.radio-button,
|
||||
input[type=radio] {
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-sizing: border-box;
|
||||
-webkit-appearance: none;
|
||||
clear: none;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
line-height: 0;
|
||||
height: 16px;
|
||||
margin: 2px 0 0 4px;
|
||||
float: right;
|
||||
outline: 0;
|
||||
padding: 0;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
width: 16px;
|
||||
min-width: 16px;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
border-radius: 50%;
|
||||
line-height: 10px;
|
||||
}
|
||||
|
||||
.radio-button:hover,
|
||||
input[type="radio"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
.radio-button:focus,
|
||||
input[type="radio"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
.radio-button:focus::-ms-clear,
|
||||
input[type="radio"]:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.radio-button:checked:before,
|
||||
input[type="radio"]:checked:before {
|
||||
float: right;
|
||||
display: inline-block;
|
||||
content: '\2022';
|
||||
margin: 3px;
|
||||
width: 8px;
|
||||
height: 8px;
|
||||
text-indent: -9999px;
|
||||
background: #00aadc;
|
||||
vertical-align: middle;
|
||||
border-radius: 50%;
|
||||
animation: grow .2s ease-in-out;
|
||||
}
|
||||
|
||||
.radio-button:disabled,
|
||||
input[type="radio"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
opacity: 1;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
.radio-button:disabled:hover,
|
||||
input[type="radio"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
.radio-button:disabled:-ms-input-placeholder,
|
||||
input[type="radio"]:disabled:-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
.radio-button:disabled::-ms-input-placeholder,
|
||||
input[type="radio"]:disabled::-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
.radio-button:disabled::placeholder,
|
||||
input[type="radio"]:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
.radio-button:disabled:checked::before,
|
||||
input[type="radio"]:disabled:checked:before {
|
||||
background: #e9eff3;
|
||||
}
|
||||
|
||||
.radio-button + span,
|
||||
input[type="radio"] + span {
|
||||
display: block;
|
||||
font-weight: normal;
|
||||
margin-right: 24px;
|
||||
}
|
||||
|
||||
@keyframes grow {
|
||||
0% {
|
||||
transform: scale(0.3);
|
||||
}
|
||||
|
||||
60% {
|
||||
transform: scale(1.15);
|
||||
}
|
||||
|
||||
100% {
|
||||
transform: scale(1);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes grow {
|
||||
0% {
|
||||
transform: scale(0.3);
|
||||
}
|
||||
|
||||
60% {
|
||||
transform: scale(1.15);
|
||||
}
|
||||
|
||||
100% {
|
||||
transform: scale(1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Selects
|
||||
** ======================================================================== */
|
||||
|
||||
select {
|
||||
background: #fff url() no-repeat left 10px center;
|
||||
border-color: #c8d7e1;
|
||||
border-style: solid;
|
||||
border-radius: 4px;
|
||||
border-width: 1px 1px 2px;
|
||||
color: #2e4453;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
margin: 0;
|
||||
outline: 0;
|
||||
overflow: hidden;
|
||||
font-size: 14px;
|
||||
line-height: 21px;
|
||||
font-weight: 600;
|
||||
text-overflow: ellipsis;
|
||||
text-decoration: none;
|
||||
vertical-align: top;
|
||||
white-space: nowrap;
|
||||
box-sizing: border-box;
|
||||
/* Aligns the text to the 8px baseline grid and adds padding on right to allow for the arrow. */
|
||||
padding: 7px 14px 9px 32px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
}
|
||||
|
||||
select:hover {
|
||||
background-image: url();
|
||||
}
|
||||
|
||||
select:focus {
|
||||
background-image: url();
|
||||
border-color: #00aadc;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
outline: 0;
|
||||
-moz-outline:none;
|
||||
-moz-user-focus:ignore;
|
||||
}
|
||||
|
||||
select:disabled,
|
||||
select:hover:disabled {
|
||||
background: url() no-repeat left 10px center;;
|
||||
}
|
||||
|
||||
select.is-compact {
|
||||
min-width: 0;
|
||||
padding: 0 6px 2px 20px;
|
||||
margin: 0 4px;
|
||||
background-position: left 5px center;
|
||||
background-size: 12px 12px;
|
||||
}
|
||||
|
||||
/* Make it display:block when it follows a label */
|
||||
label select,
|
||||
label + select {
|
||||
display: block;
|
||||
min-width: 200px;
|
||||
}
|
||||
|
||||
label select.is-compact,
|
||||
label + select.is-compact {
|
||||
display: inline-block;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
/* IE: Remove the default arrow */
|
||||
select::-ms-expand {
|
||||
display: none;
|
||||
}
|
||||
|
||||
/* IE: Remove default background and color styles on focus */
|
||||
select::-ms-value {
|
||||
background: none;
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
/* Firefox: Remove the focus outline, see http://stackoverflow.com/questions/3773430/remove-outline-from-select-box-in-ff/18853002#18853002 */
|
||||
select:-moz-focusring {
|
||||
color: transparent;
|
||||
text-shadow: 0 0 0 #2e4453;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Buttons
|
||||
** ======================================================================== */
|
||||
|
||||
input[type="submit"] {
|
||||
padding: 0;
|
||||
font-size: 14px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
vertical-align: baseline;
|
||||
background: white;
|
||||
border-color: #c8d7e1;
|
||||
border-style: solid;
|
||||
border-width: 1px 1px 2px;
|
||||
color: #2e4453;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
margin: 24px 0 0;
|
||||
outline: 0;
|
||||
overflow: hidden;
|
||||
font-weight: 500;
|
||||
text-overflow: ellipsis;
|
||||
text-decoration: none;
|
||||
vertical-align: top;
|
||||
box-sizing: border-box;
|
||||
font-size: 14px;
|
||||
line-height: 21px;
|
||||
border-radius: 4px;
|
||||
padding: 7px 14px 9px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
}
|
||||
|
||||
input[type="submit"]:hover {
|
||||
border-color: #a8bece;
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
input[type="submit"]:active {
|
||||
border-width: 2px 1px 1px;
|
||||
}
|
||||
|
||||
input[type="submit"]:visited {
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
input[type="submit"][disabled],
|
||||
input[type="submit"]:disabled {
|
||||
color: #e9eff3;
|
||||
background: white;
|
||||
border-color: #e9eff3;
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="submit"][disabled]:active,
|
||||
input[type="submit"]:disabled:active {
|
||||
border-width: 1px 1px 2px;
|
||||
}
|
||||
|
||||
input[type="submit"]:focus {
|
||||
border-color: #00aadc;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="submit"].hidden {
|
||||
display: none;
|
||||
}
|
||||
|
||||
input[type="submit"] .gridicon {
|
||||
position: relative;
|
||||
top: 4px;
|
||||
margin-top: -2px;
|
||||
width: 18px;
|
||||
height: 18px;
|
||||
}
|
||||
|
||||
input[type="submit"].button-primary {
|
||||
background: #00aadc;
|
||||
border-color: #008ab3;
|
||||
color: white;
|
||||
}
|
||||
|
||||
input[type="submit"].button-primary:hover,
|
||||
input[type="submit"].button-primary:focus {
|
||||
border-color: #005082;
|
||||
color: white;
|
||||
}
|
||||
|
||||
input[type="submit"].button-primary[disabled],
|
||||
input[type="submit"].button-primary:disabled {
|
||||
background: #bceefd;
|
||||
border-color: #8cc9e2;
|
||||
color: white;
|
||||
}
|
||||
|
||||
input[type="submit"].button-primary {
|
||||
color: white;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Inline editor styles
|
||||
** ======================================================================== */
|
||||
|
||||
|
||||
.ui-sortable-handle {
|
||||
cursor: move;
|
||||
}
|
||||
|
||||
.grunion-section-header {
|
||||
font-size: 21px;
|
||||
margin-top: 32px;
|
||||
font-weight: 600;
|
||||
}
|
||||
|
||||
.grunion-form-settings:hover {
|
||||
box-shadow: 0 0 0 1px rgba(200, 215, 225, 0.5), 0 1px 2px #e9eff3;
|
||||
}
|
||||
|
||||
.grunion-section-header:first-child {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
.grunion-type-options {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.grunion-type {
|
||||
flex-grow: 0;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.grunion-type select {
|
||||
-webkit-appearance: none;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.grunion-required {
|
||||
padding: 27px 16px 0 0;
|
||||
flex-grow: 0;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.grunion-options {
|
||||
padding-top: 16px;
|
||||
}
|
||||
|
||||
.grunion-options ol {
|
||||
list-style: none;
|
||||
padding: 0;
|
||||
margin: 8px 0 0;
|
||||
}
|
||||
|
||||
.grunion-options li {
|
||||
display: flex;
|
||||
margin-bottom: 16px;
|
||||
}
|
||||
|
||||
.grunion-field-edit .grunion-options {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.delete-option,
|
||||
.delete-field {
|
||||
color: #0087be;
|
||||
text-decoration: none;
|
||||
width: 40px;
|
||||
line-height: 40px;
|
||||
font-size: 21px;
|
||||
text-align: center;
|
||||
font-weight: 600;
|
||||
}
|
||||
|
||||
.delete-field {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.grunion-controls {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.grunion-update-controls {
|
||||
text-align: left;
|
||||
flex-grow: 1;
|
||||
}
|
||||
|
||||
#add-field {
|
||||
flex-grow: 0;
|
||||
}
|
||||
|
||||
.delete-option:before,
|
||||
.delete-field:before {
|
||||
font-family: Dashicons;
|
||||
/* content: "\f158"; /* This is the bolder X */
|
||||
content: "\f335"; /* This is the thinner X */
|
||||
display: inline-block;
|
||||
speak: none;
|
||||
}
|
||||
|
||||
.grunion-field-edit.grunion-field-checkbox-multiple .grunion-options,
|
||||
.grunion-field-edit.grunion-field-radio .grunion-options,
|
||||
.grunion-field-edit.grunion-field-select .grunion-options {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.screen-reader-text {
|
||||
position: absolute;
|
||||
margin: -1px;
|
||||
padding: 0;
|
||||
height: 1px;
|
||||
width: 1px;
|
||||
overflow: hidden;
|
||||
clip: rect(0 0 0 0);
|
||||
border: 0;
|
||||
word-wrap: normal !important; /* many screen reader and browser combinations announce broken words as they would appear visually */
|
||||
}
|
||||
1
wp-content/plugins/jetpack/modules/contact-form/css/editor-inline-editing-style-rtl.min.css
vendored
Normal file
@@ -0,0 +1,764 @@
|
||||
/* ==========================================================================
|
||||
** Normalize
|
||||
** ======================================================================== */
|
||||
|
||||
html {
|
||||
direction: ltr;
|
||||
}
|
||||
|
||||
body {
|
||||
font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif;
|
||||
font-size: 16px;
|
||||
line-height: 1.4em;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
/* Links */
|
||||
a,
|
||||
a:visited {
|
||||
color: #0087be;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
a:hover,
|
||||
a:focus,
|
||||
a:active {
|
||||
color: $link-highlight;
|
||||
}
|
||||
|
||||
/* ==========================================================================
|
||||
** Card
|
||||
** ======================================================================= */
|
||||
|
||||
.card,
|
||||
body {
|
||||
display: block;
|
||||
position: relative;
|
||||
margin: 0 auto 10px auto;
|
||||
padding: 16px;
|
||||
box-sizing: border-box;
|
||||
background: white;
|
||||
box-shadow: 0 0 0 1px rgba(200, 215, 225, 0.5), 0 1px 2px #e9eff3;
|
||||
}
|
||||
|
||||
body {
|
||||
margin: 0;
|
||||
background: #f5f5f5;
|
||||
}
|
||||
|
||||
.card:after {
|
||||
content: ".";
|
||||
display: block;
|
||||
height: 0;
|
||||
clear: both;
|
||||
visibility: hidden;
|
||||
}
|
||||
|
||||
.card:hover,
|
||||
.card:focus {
|
||||
box-shadow: 0 0 0 1px #999, 0 1px 2px #e9eff3;
|
||||
}
|
||||
|
||||
.card .delete-field {
|
||||
display: block;
|
||||
float: right;
|
||||
}
|
||||
|
||||
@media ( min-width: 481px ) {
|
||||
.card {
|
||||
margin-bottom: 16px;
|
||||
padding: 24px;
|
||||
}
|
||||
body {
|
||||
padding: 24px;
|
||||
}
|
||||
}
|
||||
|
||||
.card.is-compact {
|
||||
margin-bottom: 1px;
|
||||
}
|
||||
|
||||
@media ( min-width: 481px ) {
|
||||
.card.is-compact {
|
||||
margin-bottom: 1px;
|
||||
padding: 16px 24px;
|
||||
}
|
||||
}
|
||||
|
||||
.card > div {
|
||||
margin-top: 24px;
|
||||
}
|
||||
|
||||
.card > div:first-child {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Labels
|
||||
** ======================================================================= */
|
||||
|
||||
label {
|
||||
display: block;
|
||||
font-size: 14px;
|
||||
font-weight: 600;
|
||||
margin-bottom: 5px;
|
||||
margin-top: 8px;
|
||||
}
|
||||
|
||||
label:first-of-type {
|
||||
margin-top: 4px;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Text Inputs
|
||||
** ======================================================================= */
|
||||
|
||||
input[type="text"],
|
||||
input[type="tel"],
|
||||
input[type="email"],
|
||||
input[type="url"] {
|
||||
border-radius: 0;
|
||||
appearance: none;
|
||||
box-sizing: border-box;
|
||||
margin: 0;
|
||||
padding: 7px 14px;
|
||||
width: 100%;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 1.5;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
input[type="text"]::placeholder,
|
||||
input[type="tel"]::placeholder,
|
||||
input[type="email"]::placeholder,
|
||||
input[type="url"]::placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
input[type="text"]:hover,
|
||||
input[type="tel"]:hover,
|
||||
input[type="email"]:hover,
|
||||
input[type="url"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:focus,
|
||||
input[type="tel"]:focus,
|
||||
input[type="email"]:focus,
|
||||
input[type="url"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="text"]:focus::-ms-clear,
|
||||
input[type="tel"]:focus::-ms-clear,
|
||||
input[type="email"]:focus::-ms-clear,
|
||||
input[type="url"]:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled,
|
||||
input[type="tel"]:disabled,
|
||||
input[type="email"]:disabled,
|
||||
input[type="url"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled:hover,
|
||||
input[type="tel"]:disabled:hover,
|
||||
input[type="email"]:disabled:hover,
|
||||
input[type="url"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled::placeholder,
|
||||
input[type="tel"]:disabled::placeholder,
|
||||
input[type="email"]:disabled::placeholder,
|
||||
input[type="url"]:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Textareas
|
||||
** ======================================================================= */
|
||||
|
||||
textarea {
|
||||
border-radius: 0;
|
||||
appearance: none;
|
||||
box-sizing: border-box;
|
||||
margin: 0;
|
||||
padding: 7px 14px;
|
||||
height: 92px;
|
||||
width: 100%;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 1.5;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
textarea::placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
textarea:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
textarea:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
textarea:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
textarea:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Checkboxes
|
||||
** ======================================================================= */
|
||||
|
||||
.checkbox,
|
||||
input[type="checkbox"] {
|
||||
-webkit-appearance: none;
|
||||
display: inline-block;
|
||||
box-sizing: border-box;
|
||||
margin: 2px 0 0;
|
||||
padding: 7px 14px;
|
||||
width: 16px;
|
||||
height: 16px;
|
||||
float: left;
|
||||
outline: 0;
|
||||
padding: 0;
|
||||
box-shadow: none;
|
||||
background-color: #fff;
|
||||
border: 1px solid #c8d7e1;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 0;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
appearance: none;
|
||||
transition: all .15s ease-in-out;
|
||||
clear: none;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.checkbox:checked:before,
|
||||
input[type="checkbox"]:checked:before {
|
||||
content: '\f147';
|
||||
font-family: Dashicons;
|
||||
margin: -3px 0 0 -4px;
|
||||
float: left;
|
||||
display: inline-block;
|
||||
vertical-align: middle;
|
||||
width: 16px;
|
||||
font-size: 20px;
|
||||
line-height: 1;
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
speak: none;
|
||||
color: #00aadc;
|
||||
}
|
||||
|
||||
.checkbox:disabled:checked:before,
|
||||
input[type="checkbox"]:disabled:checked:before {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
.checkbox:hover,
|
||||
input[type="checkbox"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
.checkbox:focus,
|
||||
input[type="checkbox"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
.checkbox:disabled,
|
||||
input[type="checkbox"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
.checkbox:disabled:hover,
|
||||
input[type="checkbox"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
.checkbox + span,
|
||||
input[type="checkbox"] + span {
|
||||
display: block;
|
||||
font-weight: normal;
|
||||
margin-left: 24px;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Radio buttons
|
||||
** ======================================================================== */
|
||||
|
||||
.radio-button,
|
||||
input[type=radio] {
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-sizing: border-box;
|
||||
-webkit-appearance: none;
|
||||
clear: none;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
line-height: 0;
|
||||
height: 16px;
|
||||
margin: 2px 4px 0 0;
|
||||
float: left;
|
||||
outline: 0;
|
||||
padding: 0;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
width: 16px;
|
||||
min-width: 16px;
|
||||
appearance: none;
|
||||
border-radius: 50%;
|
||||
line-height: 10px;
|
||||
}
|
||||
|
||||
.radio-button:hover,
|
||||
input[type="radio"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
.radio-button:focus,
|
||||
input[type="radio"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
.radio-button:focus::-ms-clear,
|
||||
input[type="radio"]:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.radio-button:checked:before,
|
||||
input[type="radio"]:checked:before {
|
||||
float: left;
|
||||
display: inline-block;
|
||||
content: '\2022';
|
||||
margin: 3px;
|
||||
width: 8px;
|
||||
height: 8px;
|
||||
text-indent: -9999px;
|
||||
background: #00aadc;
|
||||
vertical-align: middle;
|
||||
border-radius: 50%;
|
||||
animation: grow .2s ease-in-out;
|
||||
}
|
||||
|
||||
.radio-button:disabled,
|
||||
input[type="radio"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
opacity: 1;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
.radio-button:disabled:hover,
|
||||
input[type="radio"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
.radio-button:disabled::placeholder,
|
||||
input[type="radio"]:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
.radio-button:disabled:checked::before,
|
||||
input[type="radio"]:disabled:checked:before {
|
||||
background: #e9eff3;
|
||||
}
|
||||
|
||||
.radio-button + span,
|
||||
input[type="radio"] + span {
|
||||
display: block;
|
||||
font-weight: normal;
|
||||
margin-left: 24px;
|
||||
}
|
||||
|
||||
@keyframes grow {
|
||||
0% {
|
||||
transform: scale(0.3);
|
||||
}
|
||||
|
||||
60% {
|
||||
transform: scale(1.15);
|
||||
}
|
||||
|
||||
100% {
|
||||
transform: scale(1);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes grow {
|
||||
0% {
|
||||
transform: scale(0.3);
|
||||
}
|
||||
|
||||
60% {
|
||||
transform: scale(1.15);
|
||||
}
|
||||
|
||||
100% {
|
||||
transform: scale(1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Selects
|
||||
** ======================================================================== */
|
||||
|
||||
select {
|
||||
background: #fff url() no-repeat right 10px center;
|
||||
border-color: #c8d7e1;
|
||||
border-style: solid;
|
||||
border-radius: 4px;
|
||||
border-width: 1px 1px 2px;
|
||||
color: #2e4453;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
margin: 0;
|
||||
outline: 0;
|
||||
overflow: hidden;
|
||||
font-size: 14px;
|
||||
line-height: 21px;
|
||||
font-weight: 600;
|
||||
text-overflow: ellipsis;
|
||||
text-decoration: none;
|
||||
vertical-align: top;
|
||||
white-space: nowrap;
|
||||
box-sizing: border-box;
|
||||
/* Aligns the text to the 8px baseline grid and adds padding on right to allow for the arrow. */
|
||||
padding: 7px 32px 9px 14px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
}
|
||||
|
||||
select:hover {
|
||||
background-image: url();
|
||||
}
|
||||
|
||||
select:focus {
|
||||
background-image: url();
|
||||
border-color: #00aadc;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
outline: 0;
|
||||
-moz-outline:none;
|
||||
-moz-user-focus:ignore;
|
||||
}
|
||||
|
||||
select:disabled,
|
||||
select:hover:disabled {
|
||||
background: url() no-repeat right 10px center;;
|
||||
}
|
||||
|
||||
select.is-compact {
|
||||
min-width: 0;
|
||||
padding: 0 20px 2px 6px;
|
||||
margin: 0 4px;
|
||||
background-position: right 5px center;
|
||||
background-size: 12px 12px;
|
||||
}
|
||||
|
||||
/* Make it display:block when it follows a label */
|
||||
label select,
|
||||
label + select {
|
||||
display: block;
|
||||
min-width: 200px;
|
||||
}
|
||||
|
||||
label select.is-compact,
|
||||
label + select.is-compact {
|
||||
display: inline-block;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
/* IE: Remove the default arrow */
|
||||
select::-ms-expand {
|
||||
display: none;
|
||||
}
|
||||
|
||||
/* IE: Remove default background and color styles on focus */
|
||||
select::-ms-value {
|
||||
background: none;
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
/* Firefox: Remove the focus outline, see http://stackoverflow.com/questions/3773430/remove-outline-from-select-box-in-ff/18853002#18853002 */
|
||||
select:-moz-focusring {
|
||||
color: transparent;
|
||||
text-shadow: 0 0 0 #2e4453;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Buttons
|
||||
** ======================================================================== */
|
||||
|
||||
input[type="submit"] {
|
||||
padding: 0;
|
||||
font-size: 14px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
vertical-align: baseline;
|
||||
background: white;
|
||||
border-color: #c8d7e1;
|
||||
border-style: solid;
|
||||
border-width: 1px 1px 2px;
|
||||
color: #2e4453;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
margin: 24px 0 0;
|
||||
outline: 0;
|
||||
overflow: hidden;
|
||||
font-weight: 500;
|
||||
text-overflow: ellipsis;
|
||||
text-decoration: none;
|
||||
vertical-align: top;
|
||||
box-sizing: border-box;
|
||||
font-size: 14px;
|
||||
line-height: 21px;
|
||||
border-radius: 4px;
|
||||
padding: 7px 14px 9px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
}
|
||||
|
||||
input[type="submit"]:hover {
|
||||
border-color: #a8bece;
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
input[type="submit"]:active {
|
||||
border-width: 2px 1px 1px;
|
||||
}
|
||||
|
||||
input[type="submit"]:visited {
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
input[type="submit"][disabled],
|
||||
input[type="submit"]:disabled {
|
||||
color: #e9eff3;
|
||||
background: white;
|
||||
border-color: #e9eff3;
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="submit"][disabled]:active,
|
||||
input[type="submit"]:disabled:active {
|
||||
border-width: 1px 1px 2px;
|
||||
}
|
||||
|
||||
input[type="submit"]:focus {
|
||||
border-color: #00aadc;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="submit"].hidden {
|
||||
display: none;
|
||||
}
|
||||
|
||||
input[type="submit"] .gridicon {
|
||||
position: relative;
|
||||
top: 4px;
|
||||
margin-top: -2px;
|
||||
width: 18px;
|
||||
height: 18px;
|
||||
}
|
||||
|
||||
input[type="submit"].button-primary {
|
||||
background: #00aadc;
|
||||
border-color: #008ab3;
|
||||
color: white;
|
||||
}
|
||||
|
||||
input[type="submit"].button-primary:hover,
|
||||
input[type="submit"].button-primary:focus {
|
||||
border-color: #005082;
|
||||
color: white;
|
||||
}
|
||||
|
||||
input[type="submit"].button-primary[disabled],
|
||||
input[type="submit"].button-primary:disabled {
|
||||
background: #bceefd;
|
||||
border-color: #8cc9e2;
|
||||
color: white;
|
||||
}
|
||||
|
||||
input[type="submit"].button-primary {
|
||||
color: white;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Inline editor styles
|
||||
** ======================================================================== */
|
||||
|
||||
|
||||
.ui-sortable-handle {
|
||||
cursor: move;
|
||||
}
|
||||
|
||||
.grunion-section-header {
|
||||
font-size: 21px;
|
||||
margin-top: 32px;
|
||||
font-weight: 600;
|
||||
}
|
||||
|
||||
.grunion-form-settings:hover {
|
||||
box-shadow: 0 0 0 1px rgba(200, 215, 225, 0.5), 0 1px 2px #e9eff3;
|
||||
}
|
||||
|
||||
.grunion-section-header:first-child {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
.grunion-type-options {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.grunion-type {
|
||||
flex-grow: 0;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.grunion-type select {
|
||||
-webkit-appearance: none;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.grunion-required {
|
||||
padding: 27px 0 0 16px;
|
||||
flex-grow: 0;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.grunion-options {
|
||||
padding-top: 16px;
|
||||
}
|
||||
|
||||
.grunion-options ol {
|
||||
list-style: none;
|
||||
padding: 0;
|
||||
margin: 8px 0 0;
|
||||
}
|
||||
|
||||
.grunion-options li {
|
||||
display: flex;
|
||||
margin-bottom: 16px;
|
||||
}
|
||||
|
||||
.grunion-field-edit .grunion-options {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.delete-option,
|
||||
.delete-field {
|
||||
color: #0087be;
|
||||
text-decoration: none;
|
||||
width: 40px;
|
||||
line-height: 40px;
|
||||
font-size: 21px;
|
||||
text-align: center;
|
||||
font-weight: 600;
|
||||
}
|
||||
|
||||
.delete-field {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
right: 0;
|
||||
}
|
||||
|
||||
.grunion-controls {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.grunion-update-controls {
|
||||
text-align: right;
|
||||
flex-grow: 1;
|
||||
}
|
||||
|
||||
#add-field {
|
||||
flex-grow: 0;
|
||||
}
|
||||
|
||||
.delete-option:before,
|
||||
.delete-field:before {
|
||||
font-family: Dashicons;
|
||||
/* content: "\f158"; /* This is the bolder X */
|
||||
content: "\f335"; /* This is the thinner X */
|
||||
display: inline-block;
|
||||
speak: none;
|
||||
}
|
||||
|
||||
.grunion-field-edit.grunion-field-checkbox-multiple .grunion-options,
|
||||
.grunion-field-edit.grunion-field-radio .grunion-options,
|
||||
.grunion-field-edit.grunion-field-select .grunion-options {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.screen-reader-text {
|
||||
position: absolute;
|
||||
margin: -1px;
|
||||
padding: 0;
|
||||
height: 1px;
|
||||
width: 1px;
|
||||
overflow: hidden;
|
||||
clip: rect(0 0 0 0);
|
||||
border: 0;
|
||||
word-wrap: normal !important; /* many screen reader and browser combinations announce broken words as they would appear visually */
|
||||
}
|
||||
2
wp-content/plugins/jetpack/modules/contact-form/css/editor-inline-editing-style.min.css
vendored
Normal file
@@ -0,0 +1,613 @@
|
||||
/* Do not modify this file directly. It is concatenated from individual module CSS files. */
|
||||
/* ==========================================================================
|
||||
** Normalize
|
||||
** ======================================================================== */
|
||||
|
||||
body,
|
||||
label {
|
||||
font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif;
|
||||
font-size: 16px;
|
||||
line-height: 1.4em;
|
||||
}
|
||||
|
||||
/* ==========================================================================
|
||||
** Card
|
||||
** ======================================================================= */
|
||||
|
||||
.card {
|
||||
display: block;
|
||||
position: relative;
|
||||
margin: 0 auto;
|
||||
padding: 16px;
|
||||
box-sizing: border-box;
|
||||
background: white;
|
||||
box-shadow: 0 0 0 1px rgba(200, 215, 225, 0.5), 0 1px 2px #e9eff3;
|
||||
}
|
||||
|
||||
.card:after {
|
||||
content: ".";
|
||||
display: block;
|
||||
height: 0;
|
||||
clear: both;
|
||||
visibility: hidden;
|
||||
}
|
||||
|
||||
@media ( min-width: 481px ) {
|
||||
.card {
|
||||
padding: 24px;
|
||||
}
|
||||
}
|
||||
|
||||
.card > div {
|
||||
margin-top: 24px;
|
||||
}
|
||||
|
||||
.card > div:first-child {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Labels
|
||||
** ======================================================================= */
|
||||
|
||||
label {
|
||||
display: block;
|
||||
font-size: 14px;
|
||||
font-weight: 600;
|
||||
margin-bottom: 5px;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Text Inputs
|
||||
** ======================================================================= */
|
||||
|
||||
input[type="text"],
|
||||
input[type="tel"],
|
||||
input[type="email"],
|
||||
input[type="url"] {
|
||||
border-radius: 0;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
box-sizing: border-box;
|
||||
margin: 0;
|
||||
padding: 7px 14px;
|
||||
width: 100%;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 1.5;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
input[type="text"]:-ms-input-placeholder,
|
||||
input[type="tel"]:-ms-input-placeholder,
|
||||
input[type="email"]:-ms-input-placeholder,
|
||||
input[type="url"]:-ms-input-placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
input[type="text"]::-ms-input-placeholder,
|
||||
input[type="tel"]::-ms-input-placeholder,
|
||||
input[type="email"]::-ms-input-placeholder,
|
||||
input[type="url"]::-ms-input-placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
input[type="text"]::placeholder,
|
||||
input[type="tel"]::placeholder,
|
||||
input[type="email"]::placeholder,
|
||||
input[type="url"]::placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
input[type="text"]:hover,
|
||||
input[type="tel"]:hover,
|
||||
input[type="email"]:hover,
|
||||
input[type="url"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:focus,
|
||||
input[type="tel"]:focus,
|
||||
input[type="email"]:focus,
|
||||
input[type="url"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="text"]:focus::-ms-clear,
|
||||
input[type="tel"]:focus::-ms-clear,
|
||||
input[type="email"]:focus::-ms-clear,
|
||||
input[type="url"]:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled,
|
||||
input[type="tel"]:disabled,
|
||||
input[type="email"]:disabled,
|
||||
input[type="url"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled:hover,
|
||||
input[type="tel"]:disabled:hover,
|
||||
input[type="email"]:disabled:hover,
|
||||
input[type="url"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled:-ms-input-placeholder,
|
||||
input[type="tel"]:disabled:-ms-input-placeholder,
|
||||
input[type="email"]:disabled:-ms-input-placeholder,
|
||||
input[type="url"]:disabled:-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled::-ms-input-placeholder,
|
||||
input[type="tel"]:disabled::-ms-input-placeholder,
|
||||
input[type="email"]:disabled::-ms-input-placeholder,
|
||||
input[type="url"]:disabled::-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled::placeholder,
|
||||
input[type="tel"]:disabled::placeholder,
|
||||
input[type="email"]:disabled::placeholder,
|
||||
input[type="url"]:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Textareas
|
||||
** ======================================================================= */
|
||||
|
||||
textarea {
|
||||
border-radius: 0;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
box-sizing: border-box;
|
||||
margin: 0;
|
||||
padding: 7px 14px;
|
||||
height: 92px;
|
||||
width: 100%;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 1.5;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
textarea:-ms-input-placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
textarea::-ms-input-placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
textarea::placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
textarea:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
textarea:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
textarea:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
textarea:disabled:-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:disabled::-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Checkboxes
|
||||
** ======================================================================= */
|
||||
|
||||
input[type="checkbox"] {
|
||||
-webkit-appearance: none;
|
||||
display: inline-block;
|
||||
box-sizing: border-box;
|
||||
margin: 2px 0 0;
|
||||
padding: 7px 14px;
|
||||
width: 16px;
|
||||
height: 16px;
|
||||
float: right;
|
||||
outline: 0;
|
||||
padding: 0;
|
||||
box-shadow: none;
|
||||
background-color: #fff;
|
||||
border: 1px solid #c8d7e1;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 0;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
transition: all .15s ease-in-out;
|
||||
clear: none;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:checked:before {
|
||||
content: '\f147';
|
||||
font-family: Dashicons;
|
||||
margin: -3px -4px 0 0;
|
||||
float: right;
|
||||
display: inline-block;
|
||||
vertical-align: middle;
|
||||
width: 16px;
|
||||
font-size: 20px;
|
||||
line-height: 1;
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
speak: none;
|
||||
color: #00aadc;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:disabled:checked:before {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="checkbox"] + span {
|
||||
display: block;
|
||||
font-weight: normal;
|
||||
margin-right: 24px;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Radio buttons
|
||||
** ======================================================================== */
|
||||
|
||||
input[type=radio] {
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-sizing: border-box;
|
||||
-webkit-appearance: none;
|
||||
clear: none;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
line-height: 0;
|
||||
height: 16px;
|
||||
margin: 2px 0 0 4px;
|
||||
float: right;
|
||||
outline: 0;
|
||||
padding: 0;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
width: 16px;
|
||||
min-width: 16px;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
border-radius: 50%;
|
||||
line-height: 10px;
|
||||
}
|
||||
|
||||
input[type="radio"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="radio"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="radio"]:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
input[type="radio"]:checked:before {
|
||||
float: right;
|
||||
display: inline-block;
|
||||
content: '\2022';
|
||||
margin: 3px;
|
||||
width: 8px;
|
||||
height: 8px;
|
||||
text-indent: -9999px;
|
||||
background: #00aadc;
|
||||
vertical-align: middle;
|
||||
border-radius: 50%;
|
||||
animation: grow .2s ease-in-out;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
opacity: 1;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled:-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled::-ms-input-placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled:checked:before {
|
||||
background: #e9eff3;
|
||||
}
|
||||
|
||||
input[type="radio"] + span {
|
||||
display: block;
|
||||
font-weight: normal;
|
||||
margin-right: 24px;
|
||||
}
|
||||
|
||||
@keyframes grow {
|
||||
0% {
|
||||
transform: scale(0.3);
|
||||
}
|
||||
|
||||
60% {
|
||||
transform: scale(1.15);
|
||||
}
|
||||
|
||||
100% {
|
||||
transform: scale(1);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes grow {
|
||||
0% {
|
||||
transform: scale(0.3);
|
||||
}
|
||||
|
||||
60% {
|
||||
transform: scale(1.15);
|
||||
}
|
||||
|
||||
100% {
|
||||
transform: scale(1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Selects
|
||||
** ======================================================================== */
|
||||
|
||||
select {
|
||||
background: #fff url() no-repeat left 10px center;
|
||||
border-color: #c8d7e1;
|
||||
border-style: solid;
|
||||
border-radius: 4px;
|
||||
border-width: 1px 1px 2px;
|
||||
color: #2e4453;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
margin: 0;
|
||||
outline: 0;
|
||||
overflow: hidden;
|
||||
font-size: 14px;
|
||||
line-height: 21px;
|
||||
font-weight: 600;
|
||||
text-overflow: ellipsis;
|
||||
text-decoration: none;
|
||||
vertical-align: top;
|
||||
white-space: nowrap;
|
||||
box-sizing: border-box;
|
||||
/* Aligns the text to the 8px baseline grid and adds padding on right to allow for the arrow. */
|
||||
padding: 7px 14px 9px 32px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
}
|
||||
|
||||
select:hover {
|
||||
background-image: url();
|
||||
}
|
||||
|
||||
select:focus {
|
||||
background-image: url();
|
||||
border-color: #00aadc;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
outline: 0;
|
||||
-moz-outline:none;
|
||||
-moz-user-focus:ignore;
|
||||
}
|
||||
|
||||
select:disabled,
|
||||
select:hover:disabled {
|
||||
background: url() no-repeat left 10px center;;
|
||||
}
|
||||
|
||||
select.is-compact {
|
||||
min-width: 0;
|
||||
padding: 0 6px 2px 20px;
|
||||
margin: 0 4px;
|
||||
background-position: left 5px center;
|
||||
background-size: 12px 12px;
|
||||
}
|
||||
|
||||
/* Make it display:block when it follows a label */
|
||||
label select,
|
||||
label + select {
|
||||
display: block;
|
||||
min-width: 200px;
|
||||
}
|
||||
|
||||
label select.is-compact,
|
||||
label + select.is-compact {
|
||||
display: inline-block;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
/* IE: Remove the default arrow */
|
||||
select::-ms-expand {
|
||||
display: none;
|
||||
}
|
||||
|
||||
/* IE: Remove default background and color styles on focus */
|
||||
select::-ms-value {
|
||||
background: none;
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
/* Firefox: Remove the focus outline, see http://stackoverflow.com/questions/3773430/remove-outline-from-select-box-in-ff/18853002#18853002 */
|
||||
select:-moz-focusring {
|
||||
color: transparent;
|
||||
text-shadow: 0 0 0 #2e4453;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Buttons
|
||||
** ======================================================================== */
|
||||
|
||||
input[type="submit"] {
|
||||
padding: 0;
|
||||
font-size: 14px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
vertical-align: baseline;
|
||||
background: white;
|
||||
border-color: #c8d7e1;
|
||||
border-style: solid;
|
||||
border-width: 1px 1px 2px;
|
||||
color: #2e4453;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
margin: 24px 0 0;
|
||||
outline: 0;
|
||||
overflow: hidden;
|
||||
font-weight: 500;
|
||||
text-overflow: ellipsis;
|
||||
text-decoration: none;
|
||||
vertical-align: top;
|
||||
box-sizing: border-box;
|
||||
font-size: 14px;
|
||||
line-height: 21px;
|
||||
border-radius: 4px;
|
||||
padding: 7px 14px 9px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
}
|
||||
|
||||
input[type="submit"]:hover {
|
||||
border-color: #a8bece;
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
input[type="submit"]:active {
|
||||
border-width: 2px 1px 1px;
|
||||
}
|
||||
|
||||
input[type="submit"]:visited {
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
input[type="submit"][disabled],
|
||||
input[type="submit"]:disabled {
|
||||
color: #e9eff3;
|
||||
background: white;
|
||||
border-color: #e9eff3;
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="submit"][disabled]:active,
|
||||
input[type="submit"]:disabled:active {
|
||||
border-width: 1px 1px 2px;
|
||||
}
|
||||
|
||||
input[type="submit"]:focus {
|
||||
border-color: #00aadc;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
/* ==========================================================================
|
||||
** Preview styles
|
||||
** ======================================================================== */
|
||||
|
||||
.wpview.wpview-wrap[data-wpview-type=contact-form] iframe.inline-edit-contact-form {
|
||||
width: 100%;
|
||||
min-height: 500px;
|
||||
border: 0;
|
||||
overflow: hidden;
|
||||
margin-bottom: 0;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.contact-submit.contact-submit {
|
||||
margin-top: 0;
|
||||
margin-bottom: 0;
|
||||
}
|
||||
1
wp-content/plugins/jetpack/modules/contact-form/css/editor-style-rtl.min.css
vendored
Normal file
@@ -0,0 +1,554 @@
|
||||
/* ==========================================================================
|
||||
** Normalize
|
||||
** ======================================================================== */
|
||||
|
||||
body,
|
||||
label {
|
||||
font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif;
|
||||
font-size: 16px;
|
||||
line-height: 1.4em;
|
||||
}
|
||||
|
||||
/* ==========================================================================
|
||||
** Card
|
||||
** ======================================================================= */
|
||||
|
||||
.card {
|
||||
display: block;
|
||||
position: relative;
|
||||
margin: 0 auto;
|
||||
padding: 16px;
|
||||
box-sizing: border-box;
|
||||
background: white;
|
||||
box-shadow: 0 0 0 1px rgba(200, 215, 225, 0.5), 0 1px 2px #e9eff3;
|
||||
}
|
||||
|
||||
.card:after {
|
||||
content: ".";
|
||||
display: block;
|
||||
height: 0;
|
||||
clear: both;
|
||||
visibility: hidden;
|
||||
}
|
||||
|
||||
@media ( min-width: 481px ) {
|
||||
.card {
|
||||
padding: 24px;
|
||||
}
|
||||
}
|
||||
|
||||
.card > div {
|
||||
margin-top: 24px;
|
||||
}
|
||||
|
||||
.card > div:first-child {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Labels
|
||||
** ======================================================================= */
|
||||
|
||||
label {
|
||||
display: block;
|
||||
font-size: 14px;
|
||||
font-weight: 600;
|
||||
margin-bottom: 5px;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Text Inputs
|
||||
** ======================================================================= */
|
||||
|
||||
input[type="text"],
|
||||
input[type="tel"],
|
||||
input[type="email"],
|
||||
input[type="url"] {
|
||||
border-radius: 0;
|
||||
appearance: none;
|
||||
box-sizing: border-box;
|
||||
margin: 0;
|
||||
padding: 7px 14px;
|
||||
width: 100%;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 1.5;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
input[type="text"]::placeholder,
|
||||
input[type="tel"]::placeholder,
|
||||
input[type="email"]::placeholder,
|
||||
input[type="url"]::placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
input[type="text"]:hover,
|
||||
input[type="tel"]:hover,
|
||||
input[type="email"]:hover,
|
||||
input[type="url"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:focus,
|
||||
input[type="tel"]:focus,
|
||||
input[type="email"]:focus,
|
||||
input[type="url"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="text"]:focus::-ms-clear,
|
||||
input[type="tel"]:focus::-ms-clear,
|
||||
input[type="email"]:focus::-ms-clear,
|
||||
input[type="url"]:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled,
|
||||
input[type="tel"]:disabled,
|
||||
input[type="email"]:disabled,
|
||||
input[type="url"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled:hover,
|
||||
input[type="tel"]:disabled:hover,
|
||||
input[type="email"]:disabled:hover,
|
||||
input[type="url"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="text"]:disabled::placeholder,
|
||||
input[type="tel"]:disabled::placeholder,
|
||||
input[type="email"]:disabled::placeholder,
|
||||
input[type="url"]:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Textareas
|
||||
** ======================================================================= */
|
||||
|
||||
textarea {
|
||||
border-radius: 0;
|
||||
appearance: none;
|
||||
box-sizing: border-box;
|
||||
margin: 0;
|
||||
padding: 7px 14px;
|
||||
height: 92px;
|
||||
width: 100%;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 1.5;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
textarea::placeholder {
|
||||
color: #87a6bc;
|
||||
}
|
||||
|
||||
textarea:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
textarea:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
textarea:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
textarea:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
textarea:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Checkboxes
|
||||
** ======================================================================= */
|
||||
|
||||
input[type="checkbox"] {
|
||||
-webkit-appearance: none;
|
||||
display: inline-block;
|
||||
box-sizing: border-box;
|
||||
margin: 2px 0 0;
|
||||
padding: 7px 14px;
|
||||
width: 16px;
|
||||
height: 16px;
|
||||
float: left;
|
||||
outline: 0;
|
||||
padding: 0;
|
||||
box-shadow: none;
|
||||
background-color: #fff;
|
||||
border: 1px solid #c8d7e1;
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
line-height: 0;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
appearance: none;
|
||||
transition: all .15s ease-in-out;
|
||||
clear: none;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:checked:before {
|
||||
content: '\f147';
|
||||
font-family: Dashicons;
|
||||
margin: -3px 0 0 -4px;
|
||||
float: left;
|
||||
display: inline-block;
|
||||
vertical-align: middle;
|
||||
width: 16px;
|
||||
font-size: 20px;
|
||||
line-height: 1;
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
speak: none;
|
||||
color: #00aadc;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:disabled:checked:before {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
input[type="checkbox"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="checkbox"] + span {
|
||||
display: block;
|
||||
font-weight: normal;
|
||||
margin-left: 24px;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Radio buttons
|
||||
** ======================================================================== */
|
||||
|
||||
input[type=radio] {
|
||||
color: #2e4453;
|
||||
font-size: 16px;
|
||||
border: 1px solid #c8d7e1;
|
||||
background-color: #fff;
|
||||
transition: all .15s ease-in-out;
|
||||
box-sizing: border-box;
|
||||
-webkit-appearance: none;
|
||||
clear: none;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
line-height: 0;
|
||||
height: 16px;
|
||||
margin: 2px 4px 0 0;
|
||||
float: left;
|
||||
outline: 0;
|
||||
padding: 0;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
width: 16px;
|
||||
min-width: 16px;
|
||||
appearance: none;
|
||||
border-radius: 50%;
|
||||
line-height: 10px;
|
||||
}
|
||||
|
||||
input[type="radio"]:hover {
|
||||
border-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="radio"]:focus {
|
||||
border-color: #0087be;
|
||||
outline: none;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
input[type="radio"]:focus::-ms-clear {
|
||||
display: none;
|
||||
}
|
||||
|
||||
input[type="radio"]:checked:before {
|
||||
float: left;
|
||||
display: inline-block;
|
||||
content: '\2022';
|
||||
margin: 3px;
|
||||
width: 8px;
|
||||
height: 8px;
|
||||
text-indent: -9999px;
|
||||
background: #00aadc;
|
||||
vertical-align: middle;
|
||||
border-radius: 50%;
|
||||
animation: grow .2s ease-in-out;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled {
|
||||
background: #f3f6f8;
|
||||
border-color: #e9eff3;
|
||||
color: #a8bece;
|
||||
opacity: 1;
|
||||
-webkit-text-fill-color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled:hover {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled::placeholder {
|
||||
color: #a8bece;
|
||||
}
|
||||
|
||||
input[type="radio"]:disabled:checked:before {
|
||||
background: #e9eff3;
|
||||
}
|
||||
|
||||
input[type="radio"] + span {
|
||||
display: block;
|
||||
font-weight: normal;
|
||||
margin-left: 24px;
|
||||
}
|
||||
|
||||
@keyframes grow {
|
||||
0% {
|
||||
transform: scale(0.3);
|
||||
}
|
||||
|
||||
60% {
|
||||
transform: scale(1.15);
|
||||
}
|
||||
|
||||
100% {
|
||||
transform: scale(1);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes grow {
|
||||
0% {
|
||||
transform: scale(0.3);
|
||||
}
|
||||
|
||||
60% {
|
||||
transform: scale(1.15);
|
||||
}
|
||||
|
||||
100% {
|
||||
transform: scale(1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Selects
|
||||
** ======================================================================== */
|
||||
|
||||
select {
|
||||
background: #fff url() no-repeat right 10px center;
|
||||
border-color: #c8d7e1;
|
||||
border-style: solid;
|
||||
border-radius: 4px;
|
||||
border-width: 1px 1px 2px;
|
||||
color: #2e4453;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
margin: 0;
|
||||
outline: 0;
|
||||
overflow: hidden;
|
||||
font-size: 14px;
|
||||
line-height: 21px;
|
||||
font-weight: 600;
|
||||
text-overflow: ellipsis;
|
||||
text-decoration: none;
|
||||
vertical-align: top;
|
||||
white-space: nowrap;
|
||||
box-sizing: border-box;
|
||||
/* Aligns the text to the 8px baseline grid and adds padding on right to allow for the arrow. */
|
||||
padding: 7px 32px 9px 14px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
}
|
||||
|
||||
select:hover {
|
||||
background-image: url();
|
||||
}
|
||||
|
||||
select:focus {
|
||||
background-image: url();
|
||||
border-color: #00aadc;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
outline: 0;
|
||||
-moz-outline:none;
|
||||
-moz-user-focus:ignore;
|
||||
}
|
||||
|
||||
select:disabled,
|
||||
select:hover:disabled {
|
||||
background: url() no-repeat right 10px center;;
|
||||
}
|
||||
|
||||
select.is-compact {
|
||||
min-width: 0;
|
||||
padding: 0 20px 2px 6px;
|
||||
margin: 0 4px;
|
||||
background-position: right 5px center;
|
||||
background-size: 12px 12px;
|
||||
}
|
||||
|
||||
/* Make it display:block when it follows a label */
|
||||
label select,
|
||||
label + select {
|
||||
display: block;
|
||||
min-width: 200px;
|
||||
}
|
||||
|
||||
label select.is-compact,
|
||||
label + select.is-compact {
|
||||
display: inline-block;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
/* IE: Remove the default arrow */
|
||||
select::-ms-expand {
|
||||
display: none;
|
||||
}
|
||||
|
||||
/* IE: Remove default background and color styles on focus */
|
||||
select::-ms-value {
|
||||
background: none;
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
/* Firefox: Remove the focus outline, see http://stackoverflow.com/questions/3773430/remove-outline-from-select-box-in-ff/18853002#18853002 */
|
||||
select:-moz-focusring {
|
||||
color: transparent;
|
||||
text-shadow: 0 0 0 #2e4453;
|
||||
}
|
||||
|
||||
|
||||
/* ==========================================================================
|
||||
** Buttons
|
||||
** ======================================================================== */
|
||||
|
||||
input[type="submit"] {
|
||||
padding: 0;
|
||||
font-size: 14px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
vertical-align: baseline;
|
||||
background: white;
|
||||
border-color: #c8d7e1;
|
||||
border-style: solid;
|
||||
border-width: 1px 1px 2px;
|
||||
color: #2e4453;
|
||||
cursor: pointer;
|
||||
display: inline-block;
|
||||
margin: 24px 0 0;
|
||||
outline: 0;
|
||||
overflow: hidden;
|
||||
font-weight: 500;
|
||||
text-overflow: ellipsis;
|
||||
text-decoration: none;
|
||||
vertical-align: top;
|
||||
box-sizing: border-box;
|
||||
font-size: 14px;
|
||||
line-height: 21px;
|
||||
border-radius: 4px;
|
||||
padding: 7px 14px 9px;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
appearance: none;
|
||||
}
|
||||
|
||||
input[type="submit"]:hover {
|
||||
border-color: #a8bece;
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
input[type="submit"]:active {
|
||||
border-width: 2px 1px 1px;
|
||||
}
|
||||
|
||||
input[type="submit"]:visited {
|
||||
color: #2e4453;
|
||||
}
|
||||
|
||||
input[type="submit"][disabled],
|
||||
input[type="submit"]:disabled {
|
||||
color: #e9eff3;
|
||||
background: white;
|
||||
border-color: #e9eff3;
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
input[type="submit"][disabled]:active,
|
||||
input[type="submit"]:disabled:active {
|
||||
border-width: 1px 1px 2px;
|
||||
}
|
||||
|
||||
input[type="submit"]:focus {
|
||||
border-color: #00aadc;
|
||||
box-shadow: 0 0 0 2px #78dcfa;
|
||||
}
|
||||
|
||||
/* ==========================================================================
|
||||
** Preview styles
|
||||
** ======================================================================== */
|
||||
|
||||
.wpview.wpview-wrap[data-wpview-type=contact-form] iframe.inline-edit-contact-form {
|
||||
width: 100%;
|
||||
min-height: 500px;
|
||||
border: 0;
|
||||
overflow: hidden;
|
||||
margin-bottom: 0;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.contact-submit.contact-submit {
|
||||
margin-top: 0;
|
||||
margin-bottom: 0;
|
||||
}
|
||||
2
wp-content/plugins/jetpack/modules/contact-form/css/editor-style.min.css
vendored
Normal file
@@ -0,0 +1,27 @@
|
||||
/* Do not modify this file directly. It is concatenated from individual module CSS files. */
|
||||
i.mce-i-grunion {
|
||||
font-size: 20px;
|
||||
}
|
||||
|
||||
i.mce-i-grunion:before,
|
||||
.jetpack-contact-form-icon:before {
|
||||
width: 24px;
|
||||
vertical-align: top;
|
||||
content: '';
|
||||
display: block;
|
||||
height: 24px;
|
||||
background-size: 24px;
|
||||
background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path fill="rgb(85, 93, 102)" d="M13 7.5h5v2h-5zm0 7h5v2h-5zM19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V5h14v14zM11 6H6v5h5V6zm-1 4H7V7h3v3zm1 3H6v5h5v-5zm-1 4H7v-3h3v3z"/></svg>');
|
||||
margin-top: -4px;
|
||||
}
|
||||
i.mce-i-grunion:before {
|
||||
margin-top: -2px;
|
||||
margin-right: -2px;
|
||||
}
|
||||
|
||||
.jetpack-contact-form-icon {
|
||||
opacity: 0.7;
|
||||
vertical-align: text-top;
|
||||
display: inline-block;
|
||||
height: 18px;
|
||||
}
|
||||
1
wp-content/plugins/jetpack/modules/contact-form/css/editor-ui-rtl.min.css
vendored
Normal file
@@ -0,0 +1 @@
|
||||
i.mce-i-grunion{font-size:20px}.jetpack-contact-form-icon:before,i.mce-i-grunion:before{width:24px;vertical-align:top;content:'';display:block;height:24px;background-size:24px;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path fill="rgb(85, 93, 102)" d="M13 7.5h5v2h-5zm0 7h5v2h-5zM19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V5h14v14zM11 6H6v5h5V6zm-1 4H7V7h3v3zm1 3H6v5h5v-5zm-1 4H7v-3h3v3z"/></svg>');margin-top:-4px}i.mce-i-grunion:before{margin-top:-2px;margin-right:-2px}.jetpack-contact-form-icon{opacity:.7;vertical-align:text-top;display:inline-block;height:18px}
|
||||
@@ -0,0 +1,26 @@
|
||||
i.mce-i-grunion {
|
||||
font-size: 20px;
|
||||
}
|
||||
|
||||
i.mce-i-grunion:before,
|
||||
.jetpack-contact-form-icon:before {
|
||||
width: 24px;
|
||||
vertical-align: top;
|
||||
content: '';
|
||||
display: block;
|
||||
height: 24px;
|
||||
background-size: 24px;
|
||||
background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path fill="rgb(85, 93, 102)" d="M13 7.5h5v2h-5zm0 7h5v2h-5zM19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V5h14v14zM11 6H6v5h5V6zm-1 4H7V7h3v3zm1 3H6v5h5v-5zm-1 4H7v-3h3v3z"/></svg>');
|
||||
margin-top: -4px;
|
||||
}
|
||||
i.mce-i-grunion:before {
|
||||
margin-top: -2px;
|
||||
margin-left: -2px;
|
||||
}
|
||||
|
||||
.jetpack-contact-form-icon {
|
||||
opacity: 0.7;
|
||||
vertical-align: text-top;
|
||||
display: inline-block;
|
||||
height: 18px;
|
||||
}
|
||||
2
wp-content/plugins/jetpack/modules/contact-form/css/editor-ui.min.css
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
/* Do not modify this file directly. It is concatenated from individual module CSS files. */
|
||||
i.mce-i-grunion{font-size:20px}.jetpack-contact-form-icon:before,i.mce-i-grunion:before{width:24px;vertical-align:top;content:'';display:block;height:24px;background-size:24px;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path fill="rgb(85, 93, 102)" d="M13 7.5h5v2h-5zm0 7h5v2h-5zM19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V5h14v14zM11 6H6v5h5V6zm-1 4H7V7h3v3zm1 3H6v5h5v-5zm-1 4H7v-3h3v3z"/></svg>');margin-top:-4px}i.mce-i-grunion:before{margin-top:-2px;margin-left:-2px}.jetpack-contact-form-icon{opacity:.7;vertical-align:text-top;display:inline-block;height:18px}
|
||||
@@ -0,0 +1 @@
|
||||
.contact-form .clear-form{clear:both}.contact-form input:-ms-input-placeholder{transition:opacity .3s ease-out}.contact-form input::-ms-input-placeholder{transition:opacity .3s ease-out}.contact-form input::placeholder{transition:opacity .3s ease-out}.contact-form input:hover:-ms-input-placeholder{opacity:.5}.contact-form input:hover::-ms-input-placeholder{opacity:.5}.contact-form input:hover::placeholder{opacity:.5}.contact-form input:focus:-ms-input-placeholder{opacity:.3}.contact-form input:focus::-ms-input-placeholder{opacity:.3}.contact-form input:focus::placeholder{opacity:.3}.contact-form input[type=email],.contact-form input[type=tel],.contact-form input[type=text],.contact-form input[type=url]{box-sizing:border-box;margin-bottom:.75em;width:100%}.contact-form select{margin-bottom:.75em}.contact-form textarea{box-sizing:border-box;float:none;height:200px;margin-bottom:.75em;width:100%}.contact-form input[type=checkbox],.contact-form input[type=radio]{float:none;margin-bottom:.75em;vertical-align:bottom;vertical-align:-webkit-baseline-middle;vertical-align:-moz-middle-with-baseline}.contact-form label{margin-bottom:.25em;float:none;font-weight:700;display:block}.contact-form label.checkbox,.contact-form label.checkbox-multiple,.contact-form label.radio{margin-bottom:.25em;float:none;font-weight:400;display:inline-block}.contact-form .grunion-field-checkbox-multiple-wrap,.contact-form .grunion-field-checkbox-wrap,.contact-form .grunion-field-radio-wrap{margin-bottom:.5em}.contact-form label span{color:#aaa;margin-right:.25em;font-weight:400}.contact-form-submission{margin-bottom:4em;padding:1.5em 1em}.contact-form-submission p{margin:0 auto;word-wrap:break-word}.form-errors .form-error-message{color:red}.textwidget .contact-form input[type=email],.textwidget .contact-form input[type=tel],.textwidget .contact-form input[type=text],.textwidget .contact-form input[type=url],.textwidget .contact-form textarea,.wp-block-column .contact-form input[type=email],.wp-block-column .contact-form input[type=tel],.wp-block-column .contact-form input[type=text],.wp-block-column .contact-form input[type=url],.wp-block-column .contact-form textarea{width:100%}#jetpack-check-feedback-spam{margin:1px 0 0 8px}.jetpack-check-feedback-spam-spinner{display:inline-block;margin-top:7px}@media only screen and (min-width:600px){.contact-form input[type=email],.contact-form input[type=tel],.contact-form input[type=text],.contact-form input[type=url]{width:50%}}
|
||||
116
wp-content/plugins/jetpack/modules/contact-form/css/grunion.css
Normal file
@@ -0,0 +1,116 @@
|
||||
.contact-form .clear-form {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.contact-form input::placeholder {
|
||||
transition: opacity .3s ease-out;
|
||||
}
|
||||
.contact-form input:hover::placeholder {
|
||||
opacity: 0.5;
|
||||
}
|
||||
.contact-form input:focus::placeholder {
|
||||
opacity: 0.3;
|
||||
}
|
||||
|
||||
.contact-form input[type='text'],
|
||||
.contact-form input[type='email'],
|
||||
.contact-form input[type='tel'],
|
||||
.contact-form input[type='url'] {
|
||||
box-sizing: border-box;
|
||||
margin-bottom: 0.75em;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.contact-form select {
|
||||
margin-bottom: 0.75em;
|
||||
}
|
||||
|
||||
.contact-form textarea {
|
||||
box-sizing: border-box;
|
||||
float: none;
|
||||
height: 200px;
|
||||
margin-bottom: 0.75em;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.contact-form input[type='radio'],
|
||||
.contact-form input[type='checkbox'] {
|
||||
float: none;
|
||||
margin-bottom: 0.75em;
|
||||
vertical-align: bottom;
|
||||
vertical-align: -webkit-baseline-middle;
|
||||
vertical-align: -moz-middle-with-baseline;
|
||||
}
|
||||
|
||||
.contact-form label {
|
||||
margin-bottom: 0.25em;
|
||||
float: none;
|
||||
font-weight: bold;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.contact-form label.checkbox,
|
||||
.contact-form label.checkbox-multiple,
|
||||
.contact-form label.radio {
|
||||
margin-bottom: 0.25em;
|
||||
float: none;
|
||||
font-weight: normal;
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
.contact-form .grunion-field-checkbox-wrap,
|
||||
.contact-form .grunion-field-checkbox-multiple-wrap,
|
||||
.contact-form .grunion-field-radio-wrap {
|
||||
margin-bottom: 0.5em;
|
||||
}
|
||||
|
||||
.contact-form label span {
|
||||
color: #AAA;
|
||||
margin-left: 0.25em;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
.contact-form-submission {
|
||||
margin-bottom: 4em;
|
||||
padding: 1.5em 1em;
|
||||
}
|
||||
|
||||
.contact-form-submission p {
|
||||
margin: 0 auto;
|
||||
word-wrap: break-word;
|
||||
}
|
||||
|
||||
.form-errors .form-error-message {
|
||||
color: red;
|
||||
}
|
||||
|
||||
.textwidget .contact-form input[type='text'],
|
||||
.textwidget .contact-form input[type='email'],
|
||||
.textwidget .contact-form input[type='tel'],
|
||||
.textwidget .contact-form input[type='url'],
|
||||
.textwidget .contact-form textarea,
|
||||
.wp-block-column .contact-form input[type='text'],
|
||||
.wp-block-column .contact-form input[type='email'],
|
||||
.wp-block-column .contact-form input[type='tel'],
|
||||
.wp-block-column .contact-form input[type='url'],
|
||||
.wp-block-column .contact-form textarea {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
#jetpack-check-feedback-spam {
|
||||
margin: 1px 8px 0px 0px;
|
||||
}
|
||||
|
||||
.jetpack-check-feedback-spam-spinner {
|
||||
display: inline-block;
|
||||
margin-top: 7px;
|
||||
}
|
||||
|
||||
@media only screen and (min-width: 600px) {
|
||||
.contact-form input[type='text'],
|
||||
.contact-form input[type='email'],
|
||||
.contact-form input[type='tel'],
|
||||
.contact-form input[type='url'] {
|
||||
width: 50%;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,160 @@
|
||||
.ui-datepicker {
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
-webkit-border-radius: 0;
|
||||
-moz-border-radius: 0;
|
||||
border-radius: 0;
|
||||
background-color: #fff;
|
||||
border: 1px solid #dfdfdf;
|
||||
border-top: none;
|
||||
-webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.075);
|
||||
box-shadow: 0 3px 6px rgba(0, 0, 0, 0.075);
|
||||
width: auto;
|
||||
}
|
||||
|
||||
.ui-datepicker * {
|
||||
padding: 0;
|
||||
-webkit-border-radius: 0;
|
||||
-moz-border-radius: 0;
|
||||
border-radius: 0;
|
||||
}
|
||||
|
||||
.ui-datepicker table {
|
||||
width: auto;
|
||||
margin: 0;
|
||||
border: none;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-widget-header,
|
||||
.ui-datepicker .ui-datepicker-header {
|
||||
background-image: none;
|
||||
border: none;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-header .ui-state-hover {
|
||||
background: transparent;
|
||||
border-color: transparent;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-title {
|
||||
margin: 0;
|
||||
padding: 10px 0;
|
||||
font-size: 14px;
|
||||
line-height: 14px;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-prev,
|
||||
.ui-datepicker .ui-datepicker-next {
|
||||
position: relative;
|
||||
top: 0;
|
||||
height: 34px;
|
||||
width: 34px;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-state-hover.ui-datepicker-prev,
|
||||
.ui-datepicker .ui-state-hover.ui-datepicker-next {
|
||||
border: none;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-prev,
|
||||
.ui-datepicker .ui-datepicker-prev-hover {
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-next,
|
||||
.ui-datepicker .ui-datepicker-next-hover {
|
||||
right: 0;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-next span,
|
||||
.ui-datepicker .ui-datepicker-prev span {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-prev {
|
||||
float: left;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-next {
|
||||
float: right;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-prev:before,
|
||||
.ui-datepicker .ui-datepicker-next:before {
|
||||
font: normal 20px/34px 'dashicons';
|
||||
padding-left: 7px;
|
||||
speak: none;
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
width: 34px;
|
||||
height: 34px;
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-prev:before {
|
||||
content: '\f341';
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-next:before {
|
||||
content: '\f345';
|
||||
}
|
||||
|
||||
.ui-datepicker .ui-datepicker-prev-hover:before,
|
||||
.ui-datepicker .ui-datepicker-next-hover:before {
|
||||
opacity: 0.7;
|
||||
}
|
||||
|
||||
.ui-datepicker select.ui-datepicker-month,
|
||||
.ui-datepicker select.ui-datepicker-year {
|
||||
width: 33%;
|
||||
}
|
||||
|
||||
.ui-datepicker thead {
|
||||
font-weight: 600;
|
||||
}
|
||||
|
||||
.ui-datepicker th {
|
||||
padding: 10px;
|
||||
border-width: 1px;
|
||||
}
|
||||
|
||||
.ui-datepicker td {
|
||||
padding: 0;
|
||||
border: 1px solid #f4f4f4;
|
||||
}
|
||||
|
||||
.ui-datepicker td.ui-datepicker-other-month {
|
||||
border: transparent;
|
||||
}
|
||||
|
||||
.ui-datepicker td.ui-datepicker-week-end {
|
||||
background-color: #f4f4f4;
|
||||
border: 1px solid #f4f4f4;
|
||||
}
|
||||
|
||||
.ui-datepicker td.ui-datepicker-today {
|
||||
background-color: #f0f0c0;
|
||||
}
|
||||
|
||||
.ui-datepicker td.ui-datepicker-current-day {
|
||||
background: #bbdd88;
|
||||
}
|
||||
|
||||
.ui-datepicker td .ui-state-default {
|
||||
background: transparent;
|
||||
border: none;
|
||||
text-align: center;
|
||||
text-decoration: none;
|
||||
width: auto;
|
||||
display: block;
|
||||
padding: 5px 10px;
|
||||
font-weight: normal;
|
||||
color: #444;
|
||||
}
|
||||
|
||||
.ui-datepicker td.ui-state-disabled .ui-state-default {
|
||||
opacity: 0.5;
|
||||
}
|
||||
@@ -0,0 +1,301 @@
|
||||
<?php
|
||||
|
||||
use Automattic\Jetpack\Assets;
|
||||
|
||||
/*
|
||||
* A prototype to allow inline editing / editor views for contact forms.\
|
||||
*
|
||||
* Originally developed in: http://github.com/automattic/gm2016-grunion-editor
|
||||
* Authors: Michael Arestad, Andrew Ozz, and George Stephanis
|
||||
*/
|
||||
|
||||
class Grunion_Editor_View {
|
||||
|
||||
/**
|
||||
* Add hooks according to screen.
|
||||
*
|
||||
* @param WP_Screen $screen Data about current screen.
|
||||
*/
|
||||
public static function add_hooks( $screen ) {
|
||||
if ( isset( $screen->base ) && 'post' === $screen->base ) {
|
||||
add_action( 'admin_notices', array( __CLASS__, 'handle_editor_view_js' ) );
|
||||
add_action( 'admin_head', array( __CLASS__, 'admin_head' ) );
|
||||
}
|
||||
}
|
||||
|
||||
public static function admin_head() {
|
||||
remove_action( 'media_buttons', 'grunion_media_button', 999 );
|
||||
add_action( 'media_buttons', array( __CLASS__, 'grunion_media_button' ), 999 );
|
||||
}
|
||||
|
||||
public static function grunion_media_button() {
|
||||
$title = __( 'Add Contact Form', 'jetpack' );
|
||||
?>
|
||||
|
||||
<button type="button" id="insert-jetpack-contact-form" class="button" title="<?php echo esc_attr( $title ); ?>" href="javascript:;">
|
||||
<span class="jetpack-contact-form-icon"></span>
|
||||
<?php echo esc_html( $title ); ?>
|
||||
</button>
|
||||
|
||||
<?php
|
||||
}
|
||||
|
||||
public static function mce_external_plugins( $plugin_array ) {
|
||||
$plugin_array['grunion_form'] = Assets::get_file_url_for_environment(
|
||||
'_inc/build/contact-form/js/tinymce-plugin-form-button.min.js',
|
||||
'modules/contact-form/js/tinymce-plugin-form-button.js'
|
||||
);
|
||||
return $plugin_array;
|
||||
}
|
||||
|
||||
public static function mce_buttons( $buttons ) {
|
||||
$size = sizeof( $buttons );
|
||||
$buttons1 = array_slice( $buttons, 0, $size - 1 );
|
||||
$buttons2 = array_slice( $buttons, $size - 1 );
|
||||
return array_merge(
|
||||
$buttons1,
|
||||
array( 'grunion' ),
|
||||
$buttons2
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* WordPress Shortcode Editor View JS Code
|
||||
*/
|
||||
public static function handle_editor_view_js() {
|
||||
add_action( 'admin_print_footer_scripts', array( __CLASS__, 'editor_view_js_templates' ), 1 );
|
||||
add_filter( 'mce_external_plugins', array( __CLASS__, 'mce_external_plugins' ) );
|
||||
add_filter( 'mce_buttons', array( __CLASS__, 'mce_buttons' ) );
|
||||
|
||||
wp_enqueue_style( 'grunion-editor-ui', plugins_url( 'css/editor-ui.css', __FILE__ ) );
|
||||
wp_style_add_data( 'grunion-editor-ui', 'rtl', 'replace' );
|
||||
wp_enqueue_script(
|
||||
'grunion-editor-view',
|
||||
Assets::get_file_url_for_environment(
|
||||
'_inc/build/contact-form/js/editor-view.min.js',
|
||||
'modules/contact-form/js/editor-view.js'
|
||||
),
|
||||
array( 'wp-util', 'jquery', 'quicktags' ),
|
||||
false,
|
||||
true
|
||||
);
|
||||
wp_localize_script(
|
||||
'grunion-editor-view', 'grunionEditorView', array(
|
||||
'inline_editing_style' => plugins_url( 'css/editor-inline-editing-style.css', __FILE__ ),
|
||||
'inline_editing_style_rtl' => plugins_url( 'css/editor-inline-editing-style-rtl.css', __FILE__ ),
|
||||
'dashicons_css_url' => includes_url( 'css/dashicons.css' ),
|
||||
'default_form' => '[contact-field label="' . __( 'Name', 'jetpack' ) . '" type="name" required="true" /]' .
|
||||
'[contact-field label="' . __( 'Email', 'jetpack' ) . '" type="email" required="true" /]' .
|
||||
'[contact-field label="' . __( 'Website', 'jetpack' ) . '" type="url" /]' .
|
||||
'[contact-field label="' . __( 'Message', 'jetpack' ) . '" type="textarea" /]',
|
||||
'labels' => array(
|
||||
'submit_button_text' => __( 'Submit', 'jetpack' ),
|
||||
/** This filter is documented in modules/contact-form/grunion-contact-form.php */
|
||||
'required_field_text' => apply_filters( 'jetpack_required_field_text', __( '(required)', 'jetpack' ) ),
|
||||
'edit_close_ays' => __( 'Are you sure you\'d like to stop editing this form without saving your changes?', 'jetpack' ),
|
||||
'quicktags_label' => __( 'contact form', 'jetpack' ),
|
||||
'tinymce_label' => __( 'Add contact form', 'jetpack' ),
|
||||
),
|
||||
)
|
||||
);
|
||||
|
||||
add_editor_style( plugin_dir_url( __FILE__ ) . 'css/editor-style.css' );
|
||||
}
|
||||
|
||||
/**
|
||||
* JS Templates.
|
||||
*/
|
||||
public static function editor_view_js_templates() {
|
||||
?>
|
||||
<script type="text/html" id="tmpl-grunion-contact-form">
|
||||
<form class="card jetpack-contact-form-shortcode-preview" action='#' method='post' class='contact-form commentsblock' onsubmit="return false;">
|
||||
{{{ data.body }}}
|
||||
<p class='contact-submit'>
|
||||
<input type='submit' value='{{ data.submit_button_text }}' class='pushbutton-wide'/>
|
||||
</p>
|
||||
</form>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-email">
|
||||
<div>
|
||||
<label for='{{ data.id }}' class='grunion-field-label email'>{{ data.label }}<# if ( data.required ) print( " <span>" + data.required + "</span>" ) #></label>
|
||||
<input type='email' name='{{ data.id }}' id='{{ data.id }}' value='{{ data.value }}' class='{{ data.class }}' placeholder='{{ data.placeholder }}' />
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-telephone">
|
||||
<div>
|
||||
<label for='{{ data.id }}' class='grunion-field-label telephone'>{{ data.label }}<# if ( data.required ) print( " <span>" + data.required + "</span>" ) #></label>
|
||||
<input type='tel' name='{{ data.id }}' id='{{ data.id }}' value='{{ data.value }}' class='{{ data.class }}' placeholder='{{ data.placeholder }}' />
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-textarea">
|
||||
<div>
|
||||
<label for='contact-form-comment-{{ data.id }}' class='grunion-field-label textarea'>{{ data.label }}<# if ( data.required ) print( " <span>" + data.required + "</span>" ) #></label>
|
||||
<textarea name='{{ data.id }}' id='contact-form-comment-{{ data.id }}' rows='20' class='{{ data.class }}' placeholder='{{ data.placeholder }}'>{{ data.value }}</textarea>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-radio">
|
||||
<div>
|
||||
<label class='grunion-field-label'>{{ data.label }}<# if ( data.required ) print( " <span>" + data.required + "</span>" ) #></label>
|
||||
<# _.each( data.options, function( option ) { #>
|
||||
<label class='grunion-radio-label radio'>
|
||||
<input type='radio' name='{{ data.id }}' value='{{ option }}' class="{{ data.class }}" <# if ( option === data.value ) print( "checked='checked'" ) #> />
|
||||
<span>{{ option }}</span>
|
||||
</label>
|
||||
<# }); #>
|
||||
<div class='clear-form'></div>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-checkbox">
|
||||
<div>
|
||||
<label class='grunion-field-label checkbox'>
|
||||
<input type='checkbox' name='{{ data.id }}' value='<?php esc_attr__( 'Yes', 'jetpack' ); ?>' class="{{ data.class }}" <# if ( data.value ) print( 'checked="checked"' ) #> />
|
||||
<span>{{ data.label }}</span><# if ( data.required ) print( " <span>" + data.required + "</span>" ) #>
|
||||
</label>
|
||||
<div class='clear-form'></div>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-checkbox-multiple">
|
||||
<div>
|
||||
<label class='grunion-field-label'>{{ data.label }}<# if ( data.required ) print( " <span>" + data.required + "</span>" ) #></label>
|
||||
<# _.each( data.options, function( option ) { #>
|
||||
<label class='grunion-checkbox-multiple-label checkbox-multiple'>
|
||||
<input type='checkbox' name='{{ data.id }}[]' value='{{ option }}' class="{{ data.class }}" <# if ( option === data.value || _.contains( data.value, option ) ) print( "checked='checked'" ) #> />
|
||||
<span>{{ option }}</span>
|
||||
</label>
|
||||
<# }); #>
|
||||
<div class='clear-form'></div>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-select">
|
||||
<div>
|
||||
<label for='{{ data.id }}' class='grunion-field-label select'>{{ data.label }}<# if ( data.required ) print( " <span>" + data.required + "</span>" ) #></label>
|
||||
<select name='{{ data.id }}' id='{{ data.id }}' class="{{ data.class }}">
|
||||
<# _.each( data.options, function( option ) { #>
|
||||
<option <# if ( option === data.value ) print( "selected='selected'" ) #>>{{ option }}</option>
|
||||
<# }); #>
|
||||
</select>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-date">
|
||||
<div>
|
||||
<label for='{{ data.id }}' class='grunion-field-label {{ data.type }}'>{{ data.label }}<# if ( data.required ) print( " <span>" + data.required + "</span>" ) #></label>
|
||||
<input type='text' name='{{ data.id }}' id='{{ data.id }}' value='{{ data.value }}' class="{{ data.class }}" />
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-text">
|
||||
<div>
|
||||
<label for='{{ data.id }}' class='grunion-field-label {{ data.type }}'>{{ data.label }}<# if ( data.required ) print( " <span>" + data.required + "</span>" ) #></label>
|
||||
<input type='text' name='{{ data.id }}' id='{{ data.id }}' value='{{ data.value }}' class='{{ data.class }}' placeholder='{{ data.placeholder }}' />
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-url">
|
||||
<div>
|
||||
<label for='{{ data.id }}' class='grunion-field-label {{ data.type }}'>{{ data.label }}<# if ( data.required ) print( " <span>" + data.required + "</span>" ) #></label>
|
||||
<input type='url' name='{{ data.id }}' id='{{ data.id }}' value='{{ data.value }}' class='{{ data.class }}' placeholder='{{ data.placeholder }}' />
|
||||
</div>
|
||||
</script>
|
||||
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-edit">
|
||||
<div class="card is-compact grunion-field-edit grunion-field-{{ data.type }}" aria-label="<?php esc_attr_e( 'Form Field', 'jetpack' ); ?>">
|
||||
<label class="grunion-name">
|
||||
<span><?php esc_html_e( 'Field Label', 'jetpack' ); ?></span>
|
||||
<input type="text" name="label" placeholder="<?php esc_attr_e( 'Label', 'jetpack' ); ?>" value="{{ data.label }}"/>
|
||||
</label>
|
||||
|
||||
<?php
|
||||
$grunion_field_types = array(
|
||||
'text' => __( 'Text', 'jetpack' ),
|
||||
'name' => __( 'Name', 'jetpack' ),
|
||||
'email' => __( 'Email', 'jetpack' ),
|
||||
'url' => __( 'Website', 'jetpack' ),
|
||||
'textarea' => __( 'Textarea', 'jetpack' ),
|
||||
'checkbox' => __( 'Checkbox', 'jetpack' ),
|
||||
'checkbox-multiple' => __( 'Checkbox with Multiple Items', 'jetpack' ),
|
||||
'select' => __( 'Drop down', 'jetpack' ),
|
||||
'radio' => __( 'Radio', 'jetpack' ),
|
||||
'date' => __( 'Date', 'jetpack' ),
|
||||
);
|
||||
?>
|
||||
<div class="grunion-type-options">
|
||||
<label class="grunion-type">
|
||||
<?php esc_html_e( 'Field Type', 'jetpack' ); ?>
|
||||
<select name="type">
|
||||
<?php foreach ( $grunion_field_types as $type => $label ) : ?>
|
||||
<option <# if ( '<?php echo esc_js( $type ); ?>' === data.type ) print( "selected='selected'" ) #> value="<?php echo esc_attr( $type ); ?>">
|
||||
<?php echo esc_html( $label ); ?>
|
||||
</option>
|
||||
<?php endforeach; ?>
|
||||
</select>
|
||||
</label>
|
||||
|
||||
<label class="grunion-required">
|
||||
<input type="checkbox" name="required" value="1" <# if ( data.required ) print( 'checked="checked"' ) #> />
|
||||
<span><?php esc_html_e( 'Required?', 'jetpack' ); ?></span>
|
||||
</label>
|
||||
</div>
|
||||
|
||||
<label class="grunion-options">
|
||||
<?php esc_html_e( 'Options', 'jetpack' ); ?>
|
||||
<ol>
|
||||
<# if ( data.options ) { #>
|
||||
<# _.each( data.options, function( option ) { #>
|
||||
<li><input type="text" name="option" value="{{ option }}" /> <a class="delete-option" href="javascript:;"><span class="screen-reader-text"><?php esc_html_e( 'Delete Option', 'jetpack' ); ?></span></a></li>
|
||||
<# }); #>
|
||||
<# } else { #>
|
||||
<li><input type="text" name="option" /> <a class="delete-option" href="javascript:;"><span class="screen-reader-text"><?php esc_html_e( 'Delete Option', 'jetpack' ); ?></span></a></li>
|
||||
<li><input type="text" name="option" /> <a class="delete-option" href="javascript:;"><span class="screen-reader-text"><?php esc_html_e( 'Delete Option', 'jetpack' ); ?></span></a></li>
|
||||
<li><input type="text" name="option" /> <a class="delete-option" href="javascript:;"><span class="screen-reader-text"><?php esc_html_e( 'Delete Option', 'jetpack' ); ?></span></a></li>
|
||||
<# } #>
|
||||
<li><a class="add-option" href="javascript:;"><?php esc_html_e( 'Add new option...', 'jetpack' ); ?></a></li>
|
||||
</ol>
|
||||
</label>
|
||||
|
||||
<a href="javascript:;" class="delete-field"><span class="screen-reader-text"><?php esc_html_e( 'Delete Field', 'jetpack' ); ?></span></a>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-field-edit-option">
|
||||
<li><input type="text" name="option" /> <a class="delete-option" href="javascript:;"><span class="screen-reader-text"><?php esc_html_e( 'Delete Option', 'jetpack' ); ?></span></a></li>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="tmpl-grunion-editor-inline">
|
||||
<h1 id="form-settings-header" class="grunion-section-header"><?php esc_html_e( 'Contact form information', 'jetpack' ); ?></h1>
|
||||
<section class="card grunion-form-settings" aria-labelledby="form-settings-header">
|
||||
<label><?php esc_html_e( 'What would you like the subject of the email to be?', 'jetpack' ); ?>
|
||||
<input type="text" name="subject" value="{{ data.subject }}" />
|
||||
</label>
|
||||
<label><?php esc_html_e( 'Which email address should we send the submissions to?', 'jetpack' ); ?>
|
||||
<input type="text" name="to" value="{{ data.to }}" />
|
||||
</label>
|
||||
</section>
|
||||
<h1 id="form-fields-header" class="grunion-section-header"><?php esc_html_e( 'Contact form fields', 'jetpack' ); ?></h1>
|
||||
<section class="grunion-fields" aria-labelledby="form-fields-header">
|
||||
{{{ data.fields }}}
|
||||
</section>
|
||||
<section class="grunion-controls">
|
||||
<?php submit_button( esc_html__( 'Add Field', 'jetpack' ), 'secondary', 'add-field', false ); ?>
|
||||
|
||||
<div class="grunion-update-controls">
|
||||
<?php submit_button( esc_html__( 'Cancel', 'jetpack' ), 'delete', 'cancel', false ); ?>
|
||||
<?php submit_button( esc_html__( 'Update Form', 'jetpack' ), 'primary', 'submit', false ); ?>
|
||||
</div>
|
||||
</section>
|
||||
</script>
|
||||
|
||||
</div>
|
||||
<?php
|
||||
}
|
||||
}
|
||||
|
||||
add_action( 'current_screen', array( 'Grunion_Editor_View', 'add_hooks' ) );
|
||||
@@ -0,0 +1,269 @@
|
||||
<?php
|
||||
|
||||
use Automattic\Jetpack\Assets;
|
||||
|
||||
/**
|
||||
* Template for form builder
|
||||
*/
|
||||
|
||||
/**
|
||||
* Filter to modify the limit of 5 additional contact form fields.
|
||||
*
|
||||
* @module contact-form
|
||||
*
|
||||
* @since 3.2.0
|
||||
*
|
||||
* @param int 5 Maximum number of additional fields.
|
||||
*/
|
||||
$max_new_fields = apply_filters( 'grunion_max_new_fields', 5 );
|
||||
|
||||
wp_register_script(
|
||||
'grunion',
|
||||
Assets::get_file_url_for_environment(
|
||||
'_inc/build/contact-form/js/grunion.min.js',
|
||||
'modules/contact-form/js/grunion.js'
|
||||
),
|
||||
array( 'jquery-ui-sortable', 'jquery-ui-draggable' ),
|
||||
JETPACK__VERSION
|
||||
);
|
||||
|
||||
wp_localize_script(
|
||||
'grunion', 'GrunionFB_i18n', array(
|
||||
'nameLabel' => esc_attr( _x( 'Name', 'Label for HTML form "Name" field in contact form builder', 'jetpack' ) ),
|
||||
'emailLabel' => esc_attr( _x( 'Email', 'Label for HTML form "Email" field in contact form builder', 'jetpack' ) ),
|
||||
'urlLabel' => esc_attr( _x( 'Website', 'Label for HTML form "URL/Website" field in contact form builder', 'jetpack' ) ),
|
||||
'commentLabel' => esc_attr( _x( 'Comment', 'noun', 'jetpack' ) ),
|
||||
'newLabel' => esc_attr( _x( 'New Field', 'Default label for new HTML form field in contact form builder', 'jetpack' ) ),
|
||||
'optionsLabel' => esc_attr( _x( 'Options', 'Label for the set of options to be included in a user-created dropdown in contact form builder', 'jetpack' ) ),
|
||||
'optionsLabel' => esc_attr( _x( 'Option', 'Label for an option to be included in a user-created dropdown in contact form builder', 'jetpack' ) ),
|
||||
'firstOptionLabel' => esc_attr( _x( 'First option', 'Default label for the first option to be included in a user-created dropdown in contact form builder', 'jetpack' ) ),
|
||||
'problemGeneratingForm' => esc_attr( _x( "Oops, there was a problem generating your form. You'll likely need to try again.", 'error message in contact form builder', 'jetpack' ) ),
|
||||
'moveInstructions' => esc_attr__( "Drag up or down\nto re-arrange", 'jetpack' ),
|
||||
'moveLabel' => esc_attr( _x( 'move', 'Label to drag HTML form fields around to change their order in contact form builder', 'jetpack' ) ),
|
||||
'editLabel' => esc_attr( _x( 'edit', 'Link to edit an HTML form field in contact form builder', 'jetpack' ) ),
|
||||
'savedMessage' => esc_attr__( 'Saved successfully', 'jetpack' ),
|
||||
'requiredLabel' => esc_attr( _x( '(required)', 'This HTML form field is marked as required by the user in contact form builder', 'jetpack' ) ),
|
||||
'exitConfirmMessage' => esc_attr__( 'Are you sure you want to exit the form editor without saving? Any changes you have made will be lost.', 'jetpack' ),
|
||||
'maxNewFields' => intval( $max_new_fields ),
|
||||
)
|
||||
);
|
||||
|
||||
?>
|
||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||||
<html xmlns="http://www.w3.org/1999/xhtml">
|
||||
<head>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
||||
<title><?php esc_html_e( 'Contact Form', 'jetpack' ); ?></title>
|
||||
<script type="text/javascript">
|
||||
var ajaxurl = '<?php echo admin_url( 'admin-ajax.php' ); ?>';
|
||||
var postId = <?php echo absint( $_GET['post_id'] ); ?>;
|
||||
var ajax_nonce_shortcode = '<?php echo wp_create_nonce( 'grunion_shortcode' ); ?>';
|
||||
var ajax_nonce_json = '<?php echo wp_create_nonce( 'grunion_shortcode_to_json' ); ?>';
|
||||
</script>
|
||||
<?php wp_print_scripts( 'grunion' ); ?>
|
||||
<script type="text/javascript">
|
||||
jQuery(document).ready(function () {
|
||||
FB.ContactForm.init();
|
||||
FB.ContactForm.resizePop();
|
||||
});
|
||||
jQuery(window).resize(function() {
|
||||
setTimeout(function () { FB.ContactForm.resizePop(); }, 50);
|
||||
});
|
||||
</script>
|
||||
<style>
|
||||
/* Reset */
|
||||
html { height: 100%; }
|
||||
body, div, ul, ol, li, h1, h2, h3, h4, h5, h6, form, fieldset, legend, input, button, textarea, p, blockquote, th, td { margin: 0; padding: 0; }
|
||||
body { background: #F9F9F9; font-family:"Lucida Grande",Verdana,Arial,"Bitstream Vera Sans",sans-serif; font-size:12px; color: #333; line-height:1.5em; height: 100%; width: 100%; padding-bottom: 20px !important; }
|
||||
a { color: #21759B; text-decoration: none; }
|
||||
a:hover { text-decoration: underline; text-shadow: none !important; }
|
||||
h1 { font-size: 21px; color:#5A5A5A; font-family:Georgia,"Times New Roman",Times,serif; font-weight:normal; margin-bottom: 21px; }
|
||||
h3 { font-size: 13px; color: #666; margin-bottom: 18px; }
|
||||
input { width: 301px; }
|
||||
input[type='text'] { padding: 3px 5px; margin-right: 4px; -moz-border-radius:3px; border-radius:3px; -webkit-border-radius:3px; }
|
||||
input[type='text']:focus { border: 2px solid #80B8D9; outline: 0 !important; }
|
||||
input[type='checkbox'], input[type='radio'] { width: auto !important; float: left; margin-top: 3px; margin-right: 8px; }
|
||||
input.fieldError, select.fieldError, textarea.fieldError { border: 2px solid #D56F55; }
|
||||
img { border: none; }
|
||||
label { color: #222; font-weight: bold; display: block; margin-bottom: 4px; }
|
||||
label.radio { width: auto; margin: -2px 0 0 5px; }
|
||||
label span.label-required { color: #AAA; margin-left: 4px; font-weight: normal; }
|
||||
td { vertical-align: top; }
|
||||
select { width: 300px; }
|
||||
textarea { height: 100px; width: 311px; }
|
||||
/* Core */
|
||||
#media-upload-header { border-bottom: 1px solid #DFDFDF; font-weight:bold; margin:0; padding:3px 5px 0 5px; position:relative; background: #FFF; }
|
||||
#sidemenu { bottom:-1px; font-size:12px; list-style:none outside none; padding-left:10px; position:relative; left:0; margin:0 5px; overflow:hidden; }
|
||||
#sidemenu a { text-decoration:none; border-top: 1px solid #FFF; display:block; float:left; line-height:28px; padding:0 13px; outline: none; }
|
||||
#sidemenu a.current { background-color:#F9F9F9; border-color:#DFDFDF #DFDFDF #F9F9F9; color:#D54E21; -moz-border-radius:4px 4px 0 0; border-radius:4px 4px 0 0; -webkit-border-radius:4px 4px 0 0; border-style:solid; border-width:1px; font-weight:normal; }
|
||||
#sidemenu li { display:inline; margin-bottom:6px; line-height:200%; list-style:none outside none; margin:0; padding:0; text-align:center; white-space:nowrap; }
|
||||
.button { background-color:#f2f2f2; border-color:#BBBBBB; min-width:80px; text-align:center; color:#464646; text-shadow:0 1px 0 #FFFFFF; border-style:solid; border-width:1px; cursor:pointer; width: auto; font-size:11px !important; line-height:13px; padding:3px 11px; margin-top: 12px; text-decoration:none; -moz-border-radius:11px; border-radius:11px; -webkit-border-radius:11px }
|
||||
.button-primary { background-color:#21759B; font-weight: bold; border-color:#298CBA; text-align:center; color:#EAF2FA; text-shadow:0 -1px 0 rgba(0, 0, 0, 0.3); border-style:solid; border-width:1px; cursor:pointer; width: auto; font-size:11px !important; line-height:13px; padding:3px 11px; margin-top: 21px; text-decoration:none; -moz-border-radius:11px; border-radius:11px; -webkit-border-radius:11px }
|
||||
.clear { clear: both; }
|
||||
.fb-add-field { padding-left: 10px; }
|
||||
.fb-add-option { margin: 0 0 14px 100px; }
|
||||
.fb-container { margin: 21px; padding-bottom: 20px; }
|
||||
.fb-desc, #fb-add-field { margin-top: 34px; }
|
||||
.fb-extra-fields { margin-bottom: 2px; }
|
||||
.fb-form-case { background: #FFF; padding: 13px; border: 1px solid #E2E2E2; width: 336px; -moz-border-radius:4px; border-radius:4px; -webkit-border-radius:4px }
|
||||
.fb-form-case a { outline: none; }
|
||||
.fb-form-case input[type='text'], .fb-form-case textarea { background: #E1E1E1; }
|
||||
.fb-radio-label { display: inline-block; float: left; width: 290px; }
|
||||
.fb-new-fields { position: relative; border: 1px dashed #FFF; background: #FFF; padding: 4px 10px 10px; cursor: default; }
|
||||
.fb-new-fields:hover { border: 1px dashed #BBDBEA; background: #F7FBFD; }
|
||||
.fb-options { width: 170px !important; }
|
||||
.fb-remove { background: url('<?php echo GRUNION_PLUGIN_URL; ?>/images/grunion-remove-field.gif') no-repeat; position: absolute; cursor: pointer !important; right: -26px; top: 27px; width: 20px; height: 23px; }
|
||||
.fb-remove:hover { background: url('<?php echo GRUNION_PLUGIN_URL; ?>/images/grunion-remove-field-hover.gif') no-repeat; }
|
||||
.fb-remove-small { top: 2px !important; }
|
||||
.fb-remove-option { position: absolute; top: 1px; right: 10px; width: 20px; height: 23px; background: url('<?php echo GRUNION_PLUGIN_URL; ?>/images/grunion-remove-option.gif') no-repeat; }
|
||||
.fb-remove-option:hover { background: url('<?php echo GRUNION_PLUGIN_URL; ?>/images/grunion-remove-option-hover.gif') no-repeat; }
|
||||
.fb-reorder { cursor: move; position: relative; }
|
||||
.fb-reorder:hover div { display: block !important; width: 130px !important; position: absolute; top: 0; right: 0; z-index: 200; padding: 5px 10px; color: #555; font-size: 11px; background: #FFF; border: 1px solid #CCC; -moz-border-radius:4px; border-radius:4px; -webkit-border-radius:4px; }
|
||||
.fb-right { position: absolute; right: 0; top: 0; width: 315px; margin: 57px 21px 0 0; }
|
||||
.fb-right .fb-new-fields { border: none; background: #F9F9F9; padding: 0; }
|
||||
.fb-right input[type='text'] { width: 195px; margin-bottom: 14px; }
|
||||
.fb-right label { color: #444; width: 100px; float: left; font-weight: normal; }
|
||||
.fb-right select { width: 195px !important; margin-bottom: 14px; }
|
||||
.fb-right textarea { margin-bottom: 13px; }
|
||||
.fb-right p { color: #999; line-height: 19px; }
|
||||
.fb-settings input[type='text'], .fb-settings textarea { background-image: none !important; }
|
||||
.fb-success { position: absolute; top: -3px; right: 100px; padding: 6px 23px 4px 23px; background: #FFFFE0; font-weight: normal; border: 1px solid #E6DB55; color: #333; -moz-border-radius:4px; border-radius:4px; -webkit-border-radius:4px; }
|
||||
.right { float: right; }
|
||||
/* rtl */
|
||||
body.rtl{ direction: rtl; font-family:Tahoma,Arial,sans-serif}
|
||||
.rtl input[type='text'] { margin-left: 4px; margin-right: 0; }
|
||||
.rtl input[type='checkbox'], .rtl input[type='radio'] { float: right; }
|
||||
.rtl input[type='radio'] { margin-left: 8px; margin-right: 0; }
|
||||
.rtl label.radio { margin: -2px 5px 0 0; }
|
||||
.rtl label span.label-required { margin-right: 4px; margin-left:0 }
|
||||
.rtl #sidemenu { padding-right:10px; padding-left: 0; left:auto; right: 0; }
|
||||
.rtl #sidemenu a { float:right; }
|
||||
.rtl .fb-add-field { padding-right: 10px; padding-left: 0; }
|
||||
.rtl .fb-add-option { margin: 0 100px 14px 0; }
|
||||
.rtl .fb-radio-label { margin-right: 8px; margin-left: 0; float: right; }
|
||||
.rtl .fb-remove { right: auto; left: -26px; transform: scaleX(-1); }
|
||||
.rtl .fb-remove-option { right: auto; left: 10px; }
|
||||
.rtl .fb-reorder:hover div { left: 0; right: auto; }
|
||||
.rtl .fb-right { left: 0; right: auto; margin: 57px 0 0 21px; }
|
||||
.rtl .fb-right label { float: right; }
|
||||
.rtl .fb-success { right: auto; left: 100px;}
|
||||
.rtl .right { float: left; }
|
||||
@media only screen and (min--moz-device-pixel-ratio: 1.5), only screen and (-o-min-device-pixel-ratio: 3/2), only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (min-device-pixel-ratio: 1.5) {
|
||||
.fb-remove { background: url('<?php echo GRUNION_PLUGIN_URL; ?>/images/grunion-remove-field-2x.png') no-repeat; background-size: 20px 23px; }
|
||||
.fb-remove:hover { background: url('<?php echo GRUNION_PLUGIN_URL; ?>/images/grunion-remove-field-hover-2x.png') no-repeat; background-size: 20px 23px; }
|
||||
.fb-remove-option { background: url('<?php echo GRUNION_PLUGIN_URL; ?>/images/grunion-remove-option-2x.png') no-repeat; background-size: 20px 23px; }
|
||||
.fb-remove-option:hover { background: url('<?php echo GRUNION_PLUGIN_URL; ?>/images/grunion-remove-option-hover-2x.png') no-repeat; background-size: 20px 23px; }
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
|
||||
<body
|
||||
<?php
|
||||
if ( is_rtl() ) {
|
||||
echo 'class="rtl"'; }
|
||||
?>
|
||||
>
|
||||
<div id="media-upload-header">
|
||||
<div id="fb-success" class="fb-success" style="display: none;"><?php esc_html_e( 'Your new field was saved successfully', 'jetpack' ); ?></div>
|
||||
<ul id="sidemenu">
|
||||
<li id="tab-preview"><a class="current" href=""><?php esc_html_e( 'Form builder', 'jetpack' ); ?></a></li>
|
||||
<li id="tab-settings"><a href=""><?php esc_html_e( 'Email notifications', 'jetpack' ); ?></a></li>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="fb-right">
|
||||
<div id="fb-desc" class="fb-desc">
|
||||
<h3><?php esc_html_e( 'How does this work?', 'jetpack' ); ?></h3>
|
||||
<p><?php esc_html_e( 'By adding a contact form, your readers will be able to submit feedback to you. All feedback is automatically scanned for spam, and the legitimate feedback will be emailed to you.', 'jetpack' ); ?></p>
|
||||
<h3 style="margin-top: 21px;"><?php esc_html_e( 'Can I add more fields?', 'jetpack' ); ?></h3>
|
||||
<p>
|
||||
<?php
|
||||
printf(
|
||||
esc_html( _x( 'Sure thing. %1$s to add a new text box, textarea, radio, checkbox, or dropdown field.', '%1$s = "Click here" in an HTML link', 'jetpack' ) ),
|
||||
'<a href="#" class="fb-add-field" style="padding-left: 0;">' . esc_html__( 'Click here', 'jetpack' ) . '</a>'
|
||||
);
|
||||
?>
|
||||
</p>
|
||||
<h3 style="margin-top: 21px;"><?php esc_html_e( 'Can I view my feedback within WordPress?', 'jetpack' ); ?></h3>
|
||||
<p>
|
||||
<?php
|
||||
printf(
|
||||
esc_html( _x( 'Yep, you can read your feedback at any time by clicking the "%1$s" link in the admin menu.', '%1$s = "Feedback" in an HTML link', 'jetpack' ) ),
|
||||
'<a id="fb-feedback" href="' . admin_url( 'edit.php?post_type=feedback' ) . '">' . esc_html__( 'Feedback', 'jetpack' ) . '</a>'
|
||||
);
|
||||
?>
|
||||
</p>
|
||||
<div class="clear"></div>
|
||||
</div>
|
||||
<div id="fb-email-desc" class="fb-desc" style="display: none;">
|
||||
<h3><?php esc_html_e( 'Do I need to fill this out?', 'jetpack' ); ?></h3>
|
||||
<p><?php esc_html_e( 'Nope. However, if you’d like to modify where your feedback is sent, or the subject line you can. If you don’t make any changes here, feedback will be sent to the author of the page/post and the subject will be the name of this page/post.', 'jetpack' ); ?></p>
|
||||
<h3 style="margin-top: 21px;"><?php esc_html_e( 'Can I send a notification to more than one person?', 'jetpack' ); ?></h3>
|
||||
<p><?php esc_html_e( 'Yep. You can enter multiple email addresses in the Email address field, and separate them with commas. A notification email will then be sent to each email address.', 'jetpack' ); ?></p>
|
||||
<div class="clear"></div>
|
||||
</div>
|
||||
<div id="fb-add-field" style="display: none;">
|
||||
<h3><?php esc_html_e( 'Edit this new field', 'jetpack' ); ?></h3>
|
||||
|
||||
<label for="fb-new-label"><?php esc_html_e( 'Label', 'jetpack' ); ?></label>
|
||||
<input type="text" id="fb-new-label" value="<?php esc_attr_e( 'New field', 'jetpack' ); ?>" />
|
||||
|
||||
<label for="fb-new-label"><?php esc_html_e( 'Field type', 'jetpack' ); ?></label>
|
||||
<select id="fb-new-type">
|
||||
<option value="checkbox"><?php esc_html_e( 'Checkbox', 'jetpack' ); ?></option>
|
||||
<option value="checkbox-multiple"><?php esc_html_e( 'Checkbox with Multiple Items', 'jetpack' ); ?></option>
|
||||
<option value="select"><?php esc_html_e( 'Drop down', 'jetpack' ); ?></option>
|
||||
<option value="email"><?php esc_html_e( 'Email', 'jetpack' ); ?></option>
|
||||
<option value="name"><?php esc_html_e( 'Name', 'jetpack' ); ?></option>
|
||||
<option value="radio"><?php esc_html_e( 'Radio', 'jetpack' ); ?></option>
|
||||
<option value="text" selected="selected"><?php esc_html_e( 'Text', 'jetpack' ); ?></option>
|
||||
<option value="textarea"><?php esc_html_e( 'Textarea', 'jetpack' ); ?></option>
|
||||
<option value="url"><?php esc_html_e( 'Website', 'jetpack' ); ?></option>
|
||||
</select>
|
||||
<div class="clear"></div>
|
||||
|
||||
<div id="fb-options" style="display: none;">
|
||||
<div id="fb-new-options">
|
||||
<label for="fb-option0"><?php esc_html_e( 'Options', 'jetpack' ); ?></label>
|
||||
<input type="text" id="fb-option0" optionid="0" value="<?php esc_attr_e( 'First option', 'jetpack' ); ?>" class="fb-options" />
|
||||
</div>
|
||||
<div id="fb-add-option" class="fb-add-option">
|
||||
<a href="#" id="fb-another-option"><?php esc_html_e( 'Add another option', 'jetpack' ); ?></a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="fb-required">
|
||||
<label for="fb-new-label"></label>
|
||||
<input type="checkbox" id="fb-new-required" />
|
||||
<label for="fb-new-label" class="fb-radio-label"><?php esc_html_e( 'Required?', 'jetpack' ); ?></label>
|
||||
<div class="clear"></div>
|
||||
</div>
|
||||
|
||||
<input type="hidden" id="fb-field-id" />
|
||||
<input type="submit" class="button" value="<?php esc_attr_e( 'Save this field', 'jetpack' ); ?>" id="fb-save-field" name="save">
|
||||
</div>
|
||||
</div>
|
||||
<form id="fb-preview">
|
||||
<div id="fb-preview-form" class="fb-container">
|
||||
<h1><?php esc_html_e( 'Here’s what your form will look like', 'jetpack' ); ?></h1>
|
||||
<div id="sortable" class="fb-form-case">
|
||||
|
||||
<div id="fb-extra-fields" class="fb-extra-fields"></div>
|
||||
|
||||
<a href="#" id="fb-new-field" class="fb-add-field"><?php esc_html_e( 'Add a new field', 'jetpack' ); ?></a>
|
||||
</div>
|
||||
<input type="submit" class="button-primary" tabindex="4" value="<?php esc_attr_e( 'Add this form to my post', 'jetpack' ); ?>" id="fb-save-form" name="save">
|
||||
</div>
|
||||
<div id="fb-email-settings" class="fb-container" style="display: none;">
|
||||
<h1><?php esc_html_e( 'Email settings', 'jetpack' ); ?></h1>
|
||||
<div class="fb-form-case fb-settings">
|
||||
<label for="fb-fieldname"><?php esc_html_e( 'Enter your email address', 'jetpack' ); ?></label>
|
||||
<input type="text" id="fb-field-my-email" style="background: #FFF !important;" />
|
||||
|
||||
<label for="fb-fieldemail" style="margin-top: 14px;"><?php esc_html_e( 'What should the subject line be?', 'jetpack' ); ?></label>
|
||||
<input type="text" id="fb-field-subject" style="background: #FFF !important;" />
|
||||
</div>
|
||||
<input type="submit" class="button-primary" value="<?php esc_attr_e( 'Save and go back to form builder', 'jetpack' ); ?>" id="fb-prev-form" name="save">
|
||||
</div>
|
||||
</form>
|
||||
</body>
|
||||
</html>
|
||||
|
After Width: | Height: | Size: 2.2 KiB |
|
After Width: | Height: | Size: 1.8 KiB |
|
After Width: | Height: | Size: 153 B |
|
After Width: | Height: | Size: 188 B |
|
After Width: | Height: | Size: 201 B |
|
After Width: | Height: | Size: 207 B |
|
After Width: | Height: | Size: 144 B |
|
After Width: | Height: | Size: 139 B |
|
After Width: | Height: | Size: 99 B |
|
After Width: | Height: | Size: 94 B |
|
After Width: | Height: | Size: 73 B |
|
After Width: | Height: | Size: 73 B |
@@ -0,0 +1,284 @@
|
||||
/* global grunionEditorView, tinyMCE, QTags, wp */
|
||||
( function( $, wp, grunionEditorView ) {
|
||||
wp.mce = wp.mce || {};
|
||||
if ( 'undefined' === typeof wp.mce.views ) {
|
||||
return;
|
||||
}
|
||||
|
||||
wp.mce.grunion_wp_view_renderer = {
|
||||
shortcode_string: 'contact-form',
|
||||
template: wp.template( 'grunion-contact-form' ),
|
||||
field_templates: {
|
||||
email: wp.template( 'grunion-field-email' ),
|
||||
telephone: wp.template( 'grunion-field-telephone' ),
|
||||
textarea: wp.template( 'grunion-field-textarea' ),
|
||||
radio: wp.template( 'grunion-field-radio' ),
|
||||
checkbox: wp.template( 'grunion-field-checkbox' ),
|
||||
'checkbox-multiple': wp.template( 'grunion-field-checkbox-multiple' ),
|
||||
select: wp.template( 'grunion-field-select' ),
|
||||
date: wp.template( 'grunion-field-date' ),
|
||||
text: wp.template( 'grunion-field-text' ),
|
||||
name: wp.template( 'grunion-field-text' ),
|
||||
url: wp.template( 'grunion-field-url' ),
|
||||
},
|
||||
edit_template: wp.template( 'grunion-field-edit' ),
|
||||
editor_inline: wp.template( 'grunion-editor-inline' ),
|
||||
editor_option: wp.template( 'grunion-field-edit-option' ),
|
||||
getContent: function() {
|
||||
var content = this.shortcode.content,
|
||||
index = 0,
|
||||
field,
|
||||
named,
|
||||
body = '';
|
||||
|
||||
// If it's the legacy `[contact-form /]` syntax, populate default fields.
|
||||
if ( ! content ) {
|
||||
content = grunionEditorView.default_form;
|
||||
}
|
||||
|
||||
// Render the fields.
|
||||
while ( ( field = wp.shortcode.next( 'contact-field', content, index ) ) ) {
|
||||
index = field.index + field.content.length;
|
||||
named = field.shortcode.attrs.named;
|
||||
if ( ! named.type || ! this.field_templates[ named.type ] ) {
|
||||
named.type = 'text';
|
||||
}
|
||||
if ( named.required ) {
|
||||
named.required = grunionEditorView.labels.required_field_text;
|
||||
}
|
||||
if ( named.options && 'string' === typeof named.options ) {
|
||||
named.options = named.options.split( ',' );
|
||||
}
|
||||
body += this.field_templates[ named.type ]( named );
|
||||
}
|
||||
|
||||
var options = {
|
||||
body: body,
|
||||
submit_button_text: grunionEditorView.labels.submit_button_text,
|
||||
};
|
||||
|
||||
return this.template( options );
|
||||
},
|
||||
edit: function( data, update_callback ) {
|
||||
var shortcode_data = wp.shortcode.next( this.shortcode_string, data ),
|
||||
shortcode = shortcode_data.shortcode,
|
||||
$tinyMCE_document = $( tinyMCE.activeEditor.getDoc() ),
|
||||
$view = $tinyMCE_document.find( '.wpview.wpview-wrap' ).filter( function() {
|
||||
return $( this ).attr( 'data-mce-selected' );
|
||||
} ),
|
||||
$editframe = $( '<iframe scrolling="no" class="inline-edit-contact-form" />' ),
|
||||
index = 0,
|
||||
named,
|
||||
fields = '',
|
||||
field;
|
||||
|
||||
if ( ! shortcode.content ) {
|
||||
shortcode.content = grunionEditorView.default_form;
|
||||
}
|
||||
|
||||
// Render the fields.
|
||||
while ( ( field = wp.shortcode.next( 'contact-field', shortcode.content, index ) ) ) {
|
||||
index = field.index + field.content.length;
|
||||
named = field.shortcode.attrs.named;
|
||||
if ( named.options && 'string' === typeof named.options ) {
|
||||
named.options = named.options.split( ',' );
|
||||
}
|
||||
fields += this.edit_template( named );
|
||||
}
|
||||
|
||||
$editframe.on( 'checkheight', function() {
|
||||
var innerDoc = this.contentDocument ? this.contentDocument : this.contentWindow.document;
|
||||
this.style.height = '10px';
|
||||
this.style.height = 5 + innerDoc.body.scrollHeight + 'px';
|
||||
tinyMCE.activeEditor.execCommand( 'wpAutoResize' );
|
||||
} );
|
||||
|
||||
$editframe.on( 'load', function() {
|
||||
var stylesheet_url =
|
||||
1 === window.isRtl
|
||||
? grunionEditorView.inline_editing_style_rtl
|
||||
: grunionEditorView.inline_editing_style,
|
||||
$stylesheet = $( '<link rel="stylesheet" href="' + stylesheet_url + '" />' ),
|
||||
$dashicons_css = $(
|
||||
'<link rel="stylesheet" href="' + grunionEditorView.dashicons_css_url + '" />'
|
||||
);
|
||||
|
||||
$stylesheet.on( 'load', function() {
|
||||
$editframe
|
||||
.contents()
|
||||
.find( 'body' )
|
||||
.css( 'visibility', 'visible' );
|
||||
$editframe.trigger( 'checkheight' );
|
||||
} );
|
||||
$editframe
|
||||
.contents()
|
||||
.find( 'head' )
|
||||
.append( $stylesheet )
|
||||
.append( $dashicons_css );
|
||||
|
||||
$editframe
|
||||
.contents()
|
||||
.find( 'body' )
|
||||
.html(
|
||||
wp.mce.grunion_wp_view_renderer.editor_inline( {
|
||||
to: shortcode.attrs.named.to,
|
||||
subject: shortcode.attrs.named.subject,
|
||||
fields: fields,
|
||||
} )
|
||||
)
|
||||
.css( 'visibility', 'hidden' );
|
||||
|
||||
$editframe
|
||||
.contents()
|
||||
.find( 'input:first' )
|
||||
.focus();
|
||||
|
||||
setTimeout( function() {
|
||||
$editframe.trigger( 'checkheight' );
|
||||
}, 250 );
|
||||
|
||||
// Add a second timeout for super long forms racing, and to not slow it down for shorter forms unnecessarily.
|
||||
setTimeout( function() {
|
||||
$editframe.trigger( 'checkheight' );
|
||||
}, 500 );
|
||||
|
||||
var $editfields = $editframe.contents().find( '.grunion-fields' ),
|
||||
$buttons = $editframe.contents().find( '.grunion-controls' );
|
||||
|
||||
$editfields.sortable();
|
||||
|
||||
// Now, add all the listeners!
|
||||
|
||||
$editfields.on( 'change select', 'select[name=type]', function() {
|
||||
$( this ).closest( '.grunion-field-edit' )[ 0 ].className =
|
||||
'card is-compact grunion-field-edit grunion-field-' + $( this ).val();
|
||||
$editframe.trigger( 'checkheight' );
|
||||
} );
|
||||
|
||||
$editfields.on( 'click', '.delete-option', function( e ) {
|
||||
e.preventDefault();
|
||||
$( this )
|
||||
.closest( 'li' )
|
||||
.remove();
|
||||
$editframe.trigger( 'checkheight' );
|
||||
} );
|
||||
|
||||
$editfields.on( 'click', '.add-option', function( e ) {
|
||||
var $new_option = $( wp.mce.grunion_wp_view_renderer.editor_option() );
|
||||
e.preventDefault();
|
||||
$( this )
|
||||
.closest( 'li' )
|
||||
.before( $new_option );
|
||||
$editframe.trigger( 'checkheight' );
|
||||
$new_option.find( 'input:first' ).focus();
|
||||
} );
|
||||
|
||||
$editfields.on( 'click', '.delete-field', function( e ) {
|
||||
e.preventDefault();
|
||||
$( this )
|
||||
.closest( '.card' )
|
||||
.remove();
|
||||
$editframe.trigger( 'checkheight' );
|
||||
} );
|
||||
|
||||
$buttons.find( 'input[name=submit]' ).on( 'click', function() {
|
||||
var new_data = shortcode;
|
||||
|
||||
new_data.type = 'closed';
|
||||
new_data.attrs = {};
|
||||
new_data.content = '';
|
||||
|
||||
$editfields.children().each( function() {
|
||||
var field_shortcode = {
|
||||
tag: 'contact-field',
|
||||
type: 'single',
|
||||
attrs: {
|
||||
label: $( this )
|
||||
.find( 'input[name=label]' )
|
||||
.val(),
|
||||
type: $( this )
|
||||
.find( 'select[name=type]' )
|
||||
.val(),
|
||||
},
|
||||
},
|
||||
options = [];
|
||||
|
||||
if ( $( this ).find( 'input[name=required]:checked' ).length ) {
|
||||
field_shortcode.attrs.required = '1';
|
||||
}
|
||||
|
||||
$( this )
|
||||
.find( 'input[name=option]' )
|
||||
.each( function() {
|
||||
if ( $( this ).val() ) {
|
||||
options.push( $( this ).val() );
|
||||
}
|
||||
} );
|
||||
if ( options.length ) {
|
||||
field_shortcode.attrs.options = options.join( ',' );
|
||||
}
|
||||
|
||||
new_data.content += wp.shortcode.string( field_shortcode );
|
||||
} );
|
||||
|
||||
if (
|
||||
$editframe
|
||||
.contents()
|
||||
.find( 'input[name=to]' )
|
||||
.val()
|
||||
) {
|
||||
new_data.attrs.to = $editframe
|
||||
.contents()
|
||||
.find( 'input[name=to]' )
|
||||
.val();
|
||||
}
|
||||
if (
|
||||
$editframe
|
||||
.contents()
|
||||
.find( 'input[name=subject]' )
|
||||
.val()
|
||||
) {
|
||||
new_data.attrs.subject = $editframe
|
||||
.contents()
|
||||
.find( 'input[name=subject]' )
|
||||
.val();
|
||||
}
|
||||
|
||||
update_callback( wp.shortcode.string( new_data ) );
|
||||
} );
|
||||
|
||||
$buttons.find( 'input[name=cancel]' ).on( 'click', function() {
|
||||
update_callback( wp.shortcode.string( shortcode ) );
|
||||
} );
|
||||
|
||||
$buttons.find( 'input[name=add-field]' ).on( 'click', function() {
|
||||
var $new_field = $( wp.mce.grunion_wp_view_renderer.edit_template( {} ) );
|
||||
$editfields.append( $new_field );
|
||||
$editfields.sortable( 'refresh' );
|
||||
$editframe.trigger( 'checkheight' );
|
||||
$new_field.find( 'input:first' ).focus();
|
||||
} );
|
||||
} );
|
||||
|
||||
$view.html( $editframe );
|
||||
},
|
||||
};
|
||||
wp.mce.views.register( 'contact-form', wp.mce.grunion_wp_view_renderer );
|
||||
|
||||
// Add the 'text' editor button.
|
||||
QTags.addButton( 'grunion_shortcode', grunionEditorView.labels.quicktags_label, function() {
|
||||
QTags.insertContent( '[contact-form]' + grunionEditorView.default_form + '[/contact-form]' );
|
||||
} );
|
||||
|
||||
var $wp_content_wrap = $( '#wp-content-wrap' );
|
||||
$( '#insert-jetpack-contact-form' ).on( 'click', function( e ) {
|
||||
e.preventDefault();
|
||||
if ( $wp_content_wrap.hasClass( 'tmce-active' ) ) {
|
||||
tinyMCE.execCommand( 'grunion_add_form' );
|
||||
} else if ( $wp_content_wrap.hasClass( 'html-active' ) ) {
|
||||
QTags.insertContent( '[contact-form]' + grunionEditorView.default_form + '[/contact-form]' );
|
||||
} else {
|
||||
window.console.error( 'Neither TinyMCE nor QuickTags is active. Unable to insert form.' );
|
||||
}
|
||||
} );
|
||||
} )( jQuery, wp, grunionEditorView );
|
||||
@@ -0,0 +1,30 @@
|
||||
/* global ajaxurl */
|
||||
jQuery( function( $ ) {
|
||||
$( document ).on( 'click', '#jetpack-check-feedback-spam:not(.button-disabled)', function( e ) {
|
||||
e.preventDefault();
|
||||
|
||||
$( '#jetpack-check-feedback-spam:not(.button-disabled)' ).addClass( 'button-disabled' );
|
||||
$( '.jetpack-check-feedback-spam-spinner' )
|
||||
.addClass( 'spinner' )
|
||||
.show();
|
||||
grunion_check_for_spam( 0, 100 );
|
||||
} );
|
||||
|
||||
function grunion_check_for_spam( offset, limit ) {
|
||||
$.post(
|
||||
ajaxurl,
|
||||
{
|
||||
action: 'grunion_recheck_queue',
|
||||
offset: offset,
|
||||
limit: limit,
|
||||
},
|
||||
function( result ) {
|
||||
if ( result.processed < limit ) {
|
||||
window.location.reload();
|
||||
} else {
|
||||
grunion_check_for_spam( offset + limit, limit );
|
||||
}
|
||||
}
|
||||
);
|
||||
}
|
||||
} );
|
||||
@@ -0,0 +1,3 @@
|
||||
jQuery( function( $ ) {
|
||||
$( '.contact-form input.jp-contact-form-date' ).datepicker();
|
||||
} );
|
||||
1180
wp-content/plugins/jetpack/modules/contact-form/js/grunion.js
Normal file
@@ -0,0 +1,37 @@
|
||||
/* global grunionEditorView, tinymce */
|
||||
( function() {
|
||||
tinymce.create( 'tinymce.plugins.grunion_form', {
|
||||
init: function( editor ) {
|
||||
editor.addButton( 'grunion', {
|
||||
title: grunionEditorView.labels.tinymce_label,
|
||||
cmd: 'grunion_add_form',
|
||||
icon: 'grunion',
|
||||
} );
|
||||
editor.addCommand( 'grunion_add_form', function() {
|
||||
if ( grunionEditorView.default_form ) {
|
||||
editor.execCommand(
|
||||
'mceInsertContent',
|
||||
0,
|
||||
'[contact-form]' + grunionEditorView.default_form + '[/contact-form]'
|
||||
);
|
||||
} else {
|
||||
editor.execCommand( 'mceInsertContent', 0, '[contact-form /]' );
|
||||
}
|
||||
} );
|
||||
},
|
||||
|
||||
createControl: function() {
|
||||
return null;
|
||||
},
|
||||
|
||||
getInfo: function() {
|
||||
return {
|
||||
longname: 'Grunion Contact Form',
|
||||
author: 'Automattic',
|
||||
version: '1',
|
||||
};
|
||||
},
|
||||
} );
|
||||
|
||||
tinymce.PluginManager.add( 'grunion_form', tinymce.plugins.grunion_form );
|
||||
} )();
|
||||