- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我是这个 & date/time/PHP 的新手,这让我的大脑很受伤。
1) 如何使用WP Post Status Transitions注册发布状态更改的确切日期和时间(我们将其命名为 valueX)?
2) 现在我从我的主题选项 (valueY) 中获取其他值 - 它可以是一个时间段(例如 30 天)或日期和时间
3) 如何用valueX 和valueY 计算得到valueZ -> 那就是日期&帖子更改为草稿或自行删除的时间!
这最终应该如何工作:
这一切听起来很合乎逻辑,但我没有足够的技能来做到这一点。
我的代码:
注意:
发布 -> 草稿
if ( !function_exists('tt_icon_time_left') ) {
function tt_icon_time_left() {
//Set Timezone To Local
date_default_timezone_set('Europe/London');
// Check post status
if ( get_post_status($post->ID) == "publish" ) {
//Get Property Publish Date
$time_post_published = get_the_time( 'H:i:s d.m.Y' );
// Get Active Post Expiration Value From Theme Options
global $theme_option;
$post_time_integer = $theme_option['post-time-left'];
// Get Active Post Expiration Value From Meta
$single_post_time_left = get_post_meta( get_the_ID(), 'post_time_left', true );
// Decide If Theme Options Or Meta Active Post Expiration Value
if ( $single_post_time_left <= 0 && $post_time_integer <= 0 ) {
$post_time = 0;
}
else if ( $single_post_time_left < $post_time_integer && $single_post_time_left > 0 || $single_post_time_left > $post_time_integer ) {
$post_time = $single_post_time_left;
}
else {
$post_time = $post_time_integer;
}
// Active Post Expiration Value To Seconds
$post_time_seconds = $post_time * 86400;
// Active Post Age In Seconds
$active_post_age = strtotime($time_post_published);
$active_post_age = time() - $active_post_age;
// Calculate Active Post Expiration Date
$post_expiration_time = date( 'H:i:s d.m.Y' ,strtotime( $time_post_published ) + $post_time_seconds );
// Show Icon And Time Left Until Active Post Changes To Draft In Tooltip ONLY SHOWN IN SUBMIT LISTING
if ( $post_time > 0 && $active_post_age <= $post_time_seconds ) {
global $post;
if ( is_page_template( 'template-post-submit-listing.php' ) ) {
return '<i class="fa fa-clock-o" data-toggle="tooltip" title="' . __( 'Post expires on ' . $post_expiration_time, 'tt' ) . '"></i>';
}
else {
return false;
}
}
草稿 -> 删除
// Change Active Post To Draft If Time Is Up
else if ( $post_time > 0 && $active_post_age > $post_time_seconds ) {
$postt['post_status'] = 'draft';
wp_update_post($post);
}
else {
return false;
}
}
// Chech post status
else if ( get_post_status($post->ID) == "draft" ) {
$time_post_published = $publish_time;
// Get Draft Expiration Value From Theme Options
global $theme_option;
$draft_time_integer = $theme_option['draft-time-left'];
// Get Draft Expiration Value From Meta
$single_draft_time_left = get_post_meta( get_the_ID(), 'draft_time_left', true );
// Decide If Theme Options Or Meta Draft Expiration Value
if ( $single_draft_time_left <= 0 && $draft_time_integer <= 0 ) {
$draft_time = 0;
}
else if ( $single_draft_time_left < $draft_time_integer && $single_draft_time_left > 0 || $single_draft_time_left > $draft_time_integer ) {
$draft_time = $single_draft_time_left;
}
else {
$draft_time = $draft_time_integer;
}
// Draft Expiration Value To Seconds
$draft_time_seconds = $draft_time * 86400;
// Draft Age In Seconds
$draft_age = strtotime($time_property_modified);
$draft_age = time() - $draft_age;
// Calculate Draft Expiration Date
$draft_expiration_time = date( 'H:i:s d.m.Y' ,strtotime( $time_property_modified ) + $draft_time_seconds );
// Show Icon And Time Left Until Draft Gets Deleted In Tooltip ONLY IN SUBMIT LISTING
if ( $draft_time && $draft_age <= $draft_time_seconds ) {
global $post;
if ( is_page_template( 'template-property-submit-listing.php' ) ) {
return '<i class="fa fa-clock-o" data-toggle="tooltip" title="' . __( 'Property gets deleted on ' . $draft_expiration_time , 'tt' ) . '"></i>';
}
else {
return false;
}
}
// Delete Draft If Time Is Up
else if( $draft_time && $draft_age > $draft_time_seconds ) {
// I got this
}
}
else {
return false;
}
}
}
最佳答案
1) How to use WP Post Status Transitions to register exact date & time of post status change (let's name it valueX)?
在我看来,处理这个问题的更好方法不是使用 Post Transition Status Hook ,而是使用 Wordpress Cron - 当管理员更改帖子状态时将调用 Hook 。我们将只使用一个 Post Transition Status 来在名为 firstPublishTime
的自定义字段中注册第一次发布帖子:
add_action('transition_post_status', 'first_publish_time_register', 10, 3);
function first_publish_time_register($new, $old, $post) {
if ($new == 'publish' && $old != 'publish' && $post->post_type == 'post') { // change this to whatever post type you like
$firstPublishTime = get_post_meta($post->ID, 'firstPublishTime', true);
if(empty($firstPublishTime)) {
// First time the post is publish, register the time
add_post_meta($post->ID, 'firstPublishTime', strftime('%F %T'), true);
}
}
}
2) Now I bring other value from my theme options (valueY) - it's either a period (e.g 30 days) or date & time
对于下一部分,我将考虑您有两个主题选项,两个时间段:一个用于名为 your_theme_option1
的“发布到草稿”延迟,另一个用于“草稿到删除延迟”命名为 your_theme_option2
;采用 YY-MM-DD-HH-MM-SS
格式。例如 00-00-30-00-00-00
表示 30 天,00-01-00-00-00-00
表示一个月等。
3) How to make a calculation with valueX and valueY to get valueZ -> that's date & time when post deletes itself!
这就是乐趣所在。我们将注册一个每小时执行一次的 WP Cron(请注意,它不是服务器 cron,如果该小时内没有人访问您的网站,则不会处理) .以下代码将每小时执行一次 cron_postStatus()
函数:
register_activation_hook(__FILE__, 'cron_postStatus_activation');
add_action('postStatus_event', 'cron_postStatus');
function cron_postStatus_activation() {
wp_schedule_event(time(), 'hourly', 'postStatus_event');
}
现在是重要的部分:
function cron_postStatus() {
// Get the theme options
$published_to_draft_delay = get_option('your_theme_option1');
$draft_to_deleted_delay = get_option('your_theme_option2');
if(!$published_to_draft_delay || !$draft_to_deleted_delay) {
return new WP_Error('broke', __('Theme options unavailable'));
}
$published_to_draft_delay = explode('-', $published_to_draft_delay);
$draft_to_deleted_delay = explode('-', $draft_to_deleted_delay);
$published_to_draft_delay = new DateInterval(
'P'.$published_to_draft_delay[0].'Y'.
$published_to_draft_delay[1].'M'.
$published_to_draft_delay[2].'D'.
'T'.$published_to_draft_delay[3].'H'.
$published_to_draft_delay[4].'M'.
$published_to_draft_delay[5].'S'
);
$draft_to_deleted_delay = new DateInterval(
'P'.$draft_to_deleted_delay[0].'Y'.
$draft_to_deleted_delay[1].'M'.
$draft_to_deleted_delay[2].'D'.
'T'.$draft_to_deleted_delay[3].'H'.
$draft_to_deleted_delay[4].'M'.
$draft_to_deleted_delay[5].'S'
);
$now = new DateTime();
// Get all the unpublished posts
$unpublished_posts = new WP_Query(array(
'posts_per_page' => -1,
'post_type' => 'post', // change this to whatever post type you like
'meta_key' => 'expirationDate',
'post_status' => 'draft'
));
while($unpublished_posts->have_posts()) {
$unpublished_posts->the_post();
$expirationDate = get_post_meta(get_the_ID(), 'expirationDate', true);
if(!empty($expirationDate)) {
// Date comparison
$dt = new DateTime($expirationDate);
$dt->add($draft_to_deleted_delay);
if($dt > $now) {
// Expiration date reached, unpublish the post
wp_delete_post(get_the_ID(), true);
}
}
}
// Get all the published posts
$published_posts = new WP_Query(array(
'posts_per_page' => -1,
'post_type' => 'post', // change this to whatever post type you like
'meta_key' => 'firstPublishTime'
));
while($published_posts->have_posts()) {
$published_posts->the_post();
$first_publish = get_post_meta(get_the_ID(), 'firstPublishTime', true);
if(!empty($first_publish)) {
// Date comparison
$dt = new DateTime($first_publish);
$dt->add($published_to_draft_delay);
if($dt > $now) {
// Expiration date reached, unpublish the post
wp_transition_post_status('draft', 'publish', $published_posts->post);
add_post_meta($post->ID, 'expirationDate', strftime('%F %T'), true);
}
}
}
wp_reset_postdata();
}
在这里,我决定使用 DateInterval
为了轻松操纵到期日期。首先,我们从 wp_options
获取到期日期选项,将它们构建在 DateInterval
对象中,然后获取当前时间。然后我们将执行两个查询,一个用于草稿,一个用于已发布的帖子。对于草稿,我们检查是否有 expirationDate
元值,如果有并且我们到了删除时间,我们会从数据库中删除该帖子。对于已发布的帖子,如果我们到了到期日期,我们会将状态更改为草稿,并添加一个名为 expirationDate
的自定义值 - 这是为了区分 cron 的“发布到草稿”更改以及管理层的变动。
请注意,这是未经测试的代码
这是一个函数,您可以使用它来根据请求获取剩余到期时间:
function getExpirationInfos($post) {
// Get all informations
$first_publish = get_post_meta($post->ID, 'firstPublishTime', true);
$expirationDate = get_post_meta($post->ID, 'expirationDate', true);
if(empty($first_publish)) {
return '';
}
$published_to_draft_delay = get_option('your_theme_option1');
$draft_to_deleted_delay = get_option('your_theme_option2')
$published_to_draft_delay = explode('-', $published_to_draft_delay);
$draft_to_deleted_delay = explode('-', $draft_to_deleted_delay);
$published_to_draft_delay = new DateInterval(
'P'.$published_to_draft_delay[0].'Y'.
$published_to_draft_delay[1].'M'.
$published_to_draft_delay[2].'D'.
'T'.$published_to_draft_delay[3].'H'.
$published_to_draft_delay[4].'M'.
$published_to_draft_delay[5].'S'
);
$draft_to_deleted_delay = new DateInterval(
'P'.$draft_to_deleted_delay[0].'Y'.
$draft_to_deleted_delay[1].'M'.
$draft_to_deleted_delay[2].'D'.
'T'.$draft_to_deleted_delay[3].'H'.
$draft_to_deleted_delay[4].'M'.
$draft_to_deleted_delay[5].'S'
);
$now = new DateTime();
// Calculate time left
if($post->post_status == 'publish') {
$dt = new DateTime($first_publish);
$dt->add($published_to_draft_delay);
} else {
if(empty($expirationDate)) {
return '';
}
$dt = new DateTime($expirationDate);
$dt->add($draft_to_deleted_delay);
}
$et = date_diff($dt, $now);
$expirationTimeString = (($et->y > 0) ? $et->format('y') . ' years, ' : '') .
(($et->m > 0) ? $et->format('y') . ' months, ' : '') .
(($et->d > 0) ? $et->format('m') . ' days, ' : '') .
(($et->h > 0) ? $et->format('h') . ' hours, ' : '') .
(($et->i > 0) ? $et->format('i') . ' minutes, ' : '') .
(($et->s > 0) ? $et->format('s') . ' seconds, ' : '');
$expirationTimeString = substr($expirationTimeString, 0, -2);
// Return HTML
return '<i class="fa fa-clock-o" data-toggle="tooltip" title="' . __( 'Property gets deleted on', 'tt' ) . ' ' . $expirationTimeString . '"></i>';
}
然后在您的模板中执行 echo getExpirationInfos($post);
以显示到期日期。
关于php - 如何使用 WP 帖子状态转换来处理帖子到期日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32052361/
我的数据库中有两张表,一张用于 field ,另一张用于预订。我需要的是一个查询来选择所有未预订的 field 。见下文: 餐 table 预订具有以下字段: bk_id venue_id 作为(预订
嗨,我是编码新手,我有一些培训项目,其中包括从 HTML 表单输入 MySQL 数据库。它就像你玩过的游戏的日志。第一个日期输入是您开始游戏的时间,第二个日期输入是您完成游戏的时间。但我需要检查器或类
我是这个 sql 编码的新手,我正在尝试学习新的东西。因此,我创建了一个交货表,其中包含一些属性,如商品代码、交货日期、交货数量。所以如何从同一张表中获取第一个交货日期(最小日期)和交货数量以及最晚交
我从支付网关返回了这个日期 2014-05-15T08:40:52+01:00 我得到 2014-05-15T08:40:52 但我无法识别时区 +01:00 的含义 我的位置时区是 UTC−06:0
我快要疯了,请帮忙。 我有一列包含日期时间值。 我需要找到每天的最小值和最大值。 数据看起来像这样 2012-11-23 05:49:26.000 2012-11-23 07:55:43.000
我从 json 数据中获取日期为 2015 年 4 月 15 日晚上 10:15我只想在 html 页面中显示 json 响应数据的时间,例如 10:15 PM这里我放了我的js函数和html代码 J
是否有 javascript 库或其他机制允许我将 .NET 日期/时间格式字符串(即 yyyy-MM-dd HH:mm:ss)传递给 javascript函数并让它相应地解析提供的日期时间值?我一直
我正在使用以下代码以正确的格式获取当前的 UTC 时间,但客户返回并要求时间戳现在使用 EST 而不是 UTC。我搜索了 Google 和 stackoverflow,但找不到适用于我现有代码的答案。
我有以下日期的平均温度数据。我想找到连续至少 5 天低于或高于 0 摄氏度的开始日期。 date_short mean.temp 1 2018-05-18 17.54 2 2018-05-19
它可以在其他网络浏览器中使用,但 IE11 返回无效日期。 为了调试我使用了下面的代码。 console.log('before - ' + date.value); date.value = new
我在 Excel 中有一个数据的 Web 提取,其中日期列带有/Date(1388624400000)/。我需要在 Excel 中将其转换为日期。 最佳答案 能够从 here 中推断出它. 假设字符串
嗨,我的 Schmema 有一个带有 ISO 日期的字段: ISODate("2015-04-30T14:47:46.501Z") Paypal 在成功付款后以该形式返回日期对象: Time/Date
我的 table : CREATE TABLE `tbdata` ( `ID` INT(10) NOT NULL AUTO_INCREMENT, `PatientID` INT(10) NOT
我正在 Ubuntu 服务器 12.04 中编写一个 shell 脚本,它应该比较日志文件中的一些数据。在日志文件中,日期以以下格式给出: [Mon Apr 08 15:02:54 2013] 如您所
我想使用 GROUP BY WITH ROLLUP 创建一个表并获取总行数而不是 null。 $sql ="SELECT IF(YEAR(transaktioner.datum
我正在创建博客文章,在成功迁移我的博客文件后,当我转到我网站的博客页面时返回一个错误(无法解析其余部分:':“Ymd”'来自'post.date|date: "Ymd"') 我似乎无法确定这是语法错误
我正在尝试获取要插入到 CAML 查询中的月份范围,即:2010-09-01 和 2010-09-30。 我使用以下代码生成这两个值: var month = "10/2010"; var month
如何将代码document.write("直到指定日期")更改为writeMessage(date)中的日期?此外,writeMessage(date) 中的日期未正确显示(仅显示年份)。感谢您帮助解
我在 Windows (XP) 和 Linux 上都尝试过 utime()。在 Windows 上我得到一个 EACCES 错误,在 Linux 上我没有得到任何错误(但时间没有改变)。我的 utim
我正在尝试计算发生在同一日期的值的总和(在 XYZmin 中)。 我的数据看起来像这样, bar <- structure(list(date = structure(c(15622, 15622,
我是一名优秀的程序员,十分优秀!