get_results(
"SELECT ID, post_title FROM $wpdb->posts WHERE ID != '$post_id' AND post_type = '$post_type' AND post_status = 'publish'"
);
$sql = "SELECT DISTINCT meta_value
FROM $wpdb->postmeta
WHERE meta_key = 'hasp_overwrite_post_id'
";
$future_overwrite_posts = $wpdb->get_row( $sql, ARRAY_N );
if ( empty( $future_overwrite_posts ) ) return $publish_posts;
foreach( $publish_posts as $key => $publish_post ) {
if ( in_array( $publish_post->ID, $future_overwrite_posts ) ) {
unset( $pulish_posts[$key] );
}
}
return $publish_posts;
}
function load_script_css() {
// JavaScript
wp_enqueue_script( 'jquery-ui-datepicker' );
wp_enqueue_script( 'hasp-jquery-ui-timepicker-addon', HASP_URL.'/js/jquery-ui-timepicker-addon.js', array( 'jquery-ui-datepicker' ), '1.4.5', true );
wp_enqueue_script( 'hasp-js', HASP_URL.'/js/script.js', array( 'jquery' ), '1.0', true );
// CSS
wp_enqueue_style( 'jquery-ui-theme', '//ajax.googleapis.com/ajax/libs/jqueryui/1.11.2/themes/smoothness/jquery-ui.min.css', '', '1.11.2', 'all' );
wp_enqueue_style( 'hasp-css', HASP_URL.'/css/style.css', array(), null );
}
function hasp_add_columns()
{
$post_types = get_post_types(array(
'public' => true,
));
foreach( $post_types as $post_type ) {
add_filter( 'manage_edit-'.$post_type.'_columns', array( $this, 'add_custom_posts_columns_name' ) );
if ( $post_type == 'page' ) {
add_action( 'manage_pages_custom_column', array( $this, 'add_custom_posts_columns' ), 10, 2 );
} else {
add_action( 'manage_posts_custom_column', array( $this, 'add_custom_posts_columns' ), 10, 2 );
}
}
}
function add_custom_posts_columns_name( $columns )
{
$columns['hasp'] = __( 'Schedule', 'hasp' );
return $columns;
}
function add_custom_posts_columns( $column, $post_id )
{
if( $column == 'hasp' ) {
$hasp_expire_enable = get_post_meta( $post_id, 'hasp_expire_enable', true );
$hasp_expire_date = get_post_meta( $post_id, 'hasp_expire_date', true );
$hasp_overwrite_enable = get_post_meta( $post_id, 'hasp_overwrite_enable', true );
$hasp_overwrite_post_id = get_post_meta( $post_id, 'hasp_overwrite_post_id', true );
if( $hasp_expire_enable && $hasp_expire_date ) {
echo __( 'Expired on:', 'hasp' ).'
'.date( 'Y/m/d H:i', strtotime( $hasp_expire_date ) ).'
';
}
if ( $hasp_overwrite_enable && $hasp_overwrite_post_id ) {
echo __( 'Overwrite:', 'hasp' ).'
'.get_the_title( $hasp_overwrite_post_id );
}
}
}
/*
* Action Method
*/
function action_to_publish( $post )
{
if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) return false;
if ( !isset( $_POST['action'] ) ) return false;
$post_id = $post->ID;
$this->save_expire( $post_id );
$this->clear_overwrite( $post_id );
}
function action_to_future( $post )
{
if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) return false;
if ( !isset( $_POST['action'] ) ) return false;
$post_id = $post->ID;
$this->save_expire( $post_id );
$this->save_overwrite( $post_id );
}
function action_to_trash( $post_id )
{
$this->clear_expire( $post_id );
$this->clear_overwrite( $post_id );
}
function save_expire( $post_id )
{
$hasp_expire_enable = isset( $_POST['hasp_expire_enable'] ) ? 1 : 0;
$hasp_expire_date = isset( $_POST['hasp_expire_date'] ) && $_POST['hasp_expire_date'] ? $_POST['hasp_expire_date'].':00' : '';
update_post_meta( $post_id, 'hasp_expire_enable', $hasp_expire_enable );
update_post_meta( $post_id, 'hasp_expire_date', $hasp_expire_date );
return $post_id;
}
function save_overwrite( $post_id )
{
$hasp_overwrite_enable = isset( $_POST['hasp_overwrite_enable'] ) ? 1 : 0;
$hasp_overwrite_post_id = $_POST['hasp_overwrite_post_id'];
update_post_meta( $post_id, 'hasp_overwrite_enable', $hasp_overwrite_enable );
update_post_meta( $post_id, 'hasp_overwrite_post_id', $hasp_overwrite_post_id );
return $post_id;
}
function clear_expire( $post_id )
{
update_post_meta( $post_id, 'hasp_expire_enable', '' );
update_post_meta( $post_id, 'hasp_expire_date', '' );
}
function clear_overwrite( $post_id )
{
update_post_meta( $post_id, 'hasp_overwrite_enable', '' );
update_post_meta( $post_id, 'hasp_overwrite_post_id', '' );
}
/*
* Run Method
*/
function do_expire()
{
global $wpdb;
$sql = "SELECT posts.ID
FROM $wpdb->posts AS posts
INNER JOIN $wpdb->postmeta AS postmeta1 ON ( posts.ID = postmeta1.post_id )
INNER JOIN $wpdb->postmeta AS postmeta2 ON ( posts.ID = postmeta2.post_id )
WHERE posts.post_status = 'publish'
AND ( postmeta1.meta_key = 'hasp_expire_enable' AND postmeta1.meta_value = '1' )
AND ( postmeta2.meta_key = 'hasp_expire_date' AND postmeta2.meta_value <= '".current_time( 'mysql' )."' )
GROUP BY posts.ID
";
$result = $wpdb->get_results( $sql );
if ( empty( $result ) ) return false;
foreach ( $result as $post ) {
$post_id = $post->ID;
// publish → draft
$overwrite_post = array();
$overwrite_post['ID'] = $post_id;
$overwrite_post['post_status'] = 'draft';
wp_update_post( $overwrite_post );
$this->clear_expire( $post_id );
}
}
function do_overwrite()
{
global $wpdb;
$sql = "SELECT posts.ID
FROM $wpdb->posts AS posts
INNER JOIN $wpdb->postmeta AS postmeta1 ON ( posts.ID = postmeta1.post_id )
WHERE posts.post_status = 'publish'
AND ( postmeta1.meta_key = 'hasp_overwrite_enable' AND postmeta1.meta_value = '1' )
AND posts.post_date <= '".current_time( 'mysql' )."'
GROUP BY posts.ID
";
$result = $wpdb->get_results( $sql );
if ( empty( $result ) ) return false;
foreach( $result as $post ) {
$post_id = $post->ID;
$hasp_overwrite_enable = get_post_meta( $post_id, 'hasp_overwrite_enable', true );
$hasp_overwrite_post_id = get_post_meta( $post_id, 'hasp_overwrite_post_id', true );
if ( $hasp_overwrite_enable && $hasp_overwrite_post_id ) {
$overwrite_post_name = get_post_field( 'post_name', $hasp_overwrite_post_id );
$from_overwrite_post = array();
$from_overwrite_post['ID'] = $hasp_overwrite_post_id;
$from_overwrite_post['post_status'] = 'draft';
$from_overwrite_post['post_name'] = $overwrite_post_name. '-'. date( 'Ymd' );
wp_update_post( $from_overwrite_post );
$to_overwrite_post = array();
$to_overwrite_post['ID'] = $post_id;
$to_overwrite_post['post_name'] = $overwrite_post_name;
wp_update_post( $to_overwrite_post );
$this->clear_overwrite( $post_id );
}
}
}
}
?>