medarbetare_metabox
class medarbetare_Meta_Box {
public function __construct() {
if ( is_admin() ) {
add_action( 'load-post.php', array( $this, 'init_metabox' ) );
add_action( 'load-post-new.php', array( $this, 'init_metabox' ) );
}
}
public function init_metabox() {
add_action( 'add_meta_boxes', array( $this, 'add_metabox' ) );
add_action( 'save_post', array( $this, 'save_metabox' ), 10, 2 );
}
public function add_metabox() {
add_meta_box(
'medarbetare',
__( 'Medarbetare', 'varduppdrag' ),
array( $this, 'render_metabox' ),
'medarbetare',
'normal',
'high'
);
}
public function render_metabox( $post ) {
// Add nonce for security and authentication.
wp_nonce_field( 'medarbetare_nonce_action', 'medarbetare_nonce' );
// Retrieve an existing value from the database.
$medarbetare_namn = get_post_meta( $post->ID, 'medarbetare_namn', true );
$medarbetare_titel = get_post_meta( $post->ID, 'medarbetare_titel', true );
$medarbetare_telefon = get_post_meta( $post->ID, 'medarbetare_telefon', true );
$medarbetare_epost = get_post_meta( $post->ID, 'medarbetare_epost', true );
// Set default values.
if( empty( $medarbetare_namn ) ) $medarbetare_namn = '';
if( empty( $medarbetare_titel ) ) $medarbetare_titel = '';
if( empty( $medarbetare_telefon ) ) $medarbetare_telefon = '';
if( empty( $medarbetare_epost ) ) $medarbetare_epost = '';
// Form fields.
echo '<table class="form-table">';
echo ' <tr>';
echo ' <th><label for="medarbetare_namn" class="medarbetare_namn_label">' . __( 'Namn', 'varduppdrag' ) . '</label></th>';
echo ' <td>';
echo ' <input type="text" id="medarbetare_namn" name="medarbetare_namn" class="medarbetare_namn_field" placeholder="' . esc_attr__( '', 'varduppdrag' ) . '" value="' . esc_attr( $medarbetare_namn ) . '">';
echo ' </td>';
echo ' </tr>';
echo ' <tr>';
echo ' <th><label for="medarbetare_titel" class="medarbetare_titel_label">' . __( 'Titel', 'varduppdrag' ) . '</label></th>';
echo ' <td>';
echo ' <input type="text" id="medarbetare_titel" name="medarbetare_titel" class="medarbetare_titel_field" placeholder="' . esc_attr__( '', 'varduppdrag' ) . '" value="' . esc_attr( $medarbetare_titel ) . '">';
echo ' </td>';
echo ' </tr>';
echo ' <tr>';
echo ' <th><label for="medarbetare_telefon" class="medarbetare_telefon_label">' . __( 'Telefon', 'varduppdrag' ) . '</label></th>';
echo ' <td>';
echo ' <input type="number" id="medarbetare_telefon" name="medarbetare_telefon" class="medarbetare_telefon_field" placeholder="' . esc_attr__( '', 'varduppdrag' ) . '" value="' . esc_attr( $medarbetare_telefon ) . '">';
echo ' </td>';
echo ' </tr>';
echo ' <tr>';
echo ' <th><label for="medarbetare_epost" class="medarbetare_epost_label">' . __( 'E-post', 'varduppdrag' ) . '</label></th>';
echo ' <td>';
echo ' <input type="email" id="medarbetare_epost" name="medarbetare_epost" class="medarbetare_epost_field" placeholder="' . esc_attr__( '', 'varduppdrag' ) . '" value="' . esc_attr( $medarbetare_epost ) . '">';
echo ' </td>';
echo ' </tr>';
echo '</table>';
}
public function save_metabox( $post_id, $post ) {
// Add nonce for security and authentication.
$nonce_name = isset( $_POST['medarbetare_nonce'] ) ? $_POST['medarbetare_nonce'] : '';
$nonce_action = 'medarbetare_nonce_action';
// Check if a nonce is set.
if ( ! isset( $nonce_name ) )
return;
// Check if a nonce is valid.
if ( ! wp_verify_nonce( $nonce_name, $nonce_action ) )
return;
// Check if the user has permissions to save data.
if ( ! current_user_can( 'edit_post', $post_id ) )
return;
// Check if it's not an autosave.
if ( wp_is_post_autosave( $post_id ) )
return;
// Sanitize user input.
$medarbetare_new_namn = isset( $_POST[ 'medarbetare_namn' ] ) ? sanitize_text_field( $_POST[ 'medarbetare_namn' ] ) : '';
$medarbetare_new_titel = isset( $_POST[ 'medarbetare_titel' ] ) ? sanitize_text_field( $_POST[ 'medarbetare_titel' ] ) : '';
$medarbetare_new_telefon = isset( $_POST[ 'medarbetare_telefon' ] ) ? floatval( $_POST[ 'medarbetare_telefon' ] ) : '';
$medarbetare_new_epost = isset( $_POST[ 'medarbetare_epost' ] ) ? sanitize_email( $_POST[ 'medarbetare_epost' ] ) : '';
// Update the meta field in the database.
update_post_meta( $post_id, 'medarbetare_namn', $medarbetare_new_namn );
update_post_meta( $post_id, 'medarbetare_titel', $medarbetare_new_titel );
update_post_meta( $post_id, 'medarbetare_telefon', $medarbetare_new_telefon );
update_post_meta( $post_id, 'medarbetare_epost', $medarbetare_new_epost );
}
}
new medarbetare_Meta_Box;