bp_format_time( int|string $time = '', bool $exclude_time = false, bool $gmt = true )
Format a date based on a UNIX timestamp.
Description
This function can be used to turn a UNIX timestamp into a properly formatted (and possibly localized) string, userful for ouputting the date & time an action took place.
Not to be confused with bp_core_time_since()
, this function is best used for displaying a more exact date and time vs. a human-readable time.
Note: This function may be improved or removed at a later date, as it is hardly used and adds an additional layer of complexity to calculating dates and times together with timezone offsets and i18n.
Parameters
- $time
-
(Optional) The UNIX timestamp to be formatted.
Default value: ''
- $exclude_time
-
(Optional) True to return only the month + day, false to return month, day, and time. Default: false.
Default value: false
- $gmt
-
(Optional) True to display in local time, false to leave in GMT. Default: true.
Default value: true
Return
(mixed) A string representation of $time, in the format "March 18, 2014 at 2:00 pm" (or whatever your 'date_format' and 'time_format' settings are on your root blog). False on failure.
Source
File: bp-core/bp-core-template.php
394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 | function bp_format_time( $time = '' , $exclude_time = false, $gmt = true ) { // Bail if time is empty or not numeric // @todo We should output something smarter here. if ( empty ( $time ) || ! is_numeric ( $time ) ) { return false; } // Get GMT offset from root blog. if ( true === $gmt ) { // Use Timezone string if set. $timezone_string = bp_get_option( 'timezone_string' ); if ( ! empty ( $timezone_string ) ) { $timezone_object = timezone_open( $timezone_string ); $datetime_object = date_create( "@{$time}" ); $timezone_offset = timezone_offset_get( $timezone_object , $datetime_object ) / HOUR_IN_SECONDS; // Fall back on less reliable gmt_offset. } else { $timezone_offset = bp_get_option( 'gmt_offset' ); } // Calculate time based on the offset. $calculated_time = $time + ( $timezone_offset * HOUR_IN_SECONDS ); // No localizing, so just use the time that was submitted. } else { $calculated_time = $time ; } // Formatted date: "March 18, 2014". $formatted_date = date_i18n( bp_get_option( 'date_format' ), $calculated_time , $gmt ); // Should we show the time also? if ( true !== $exclude_time ) { // Formatted time: "2:00 pm". $formatted_time = date_i18n( bp_get_option( 'time_format' ), $calculated_time , $gmt ); // Return string formatted with date and time. $formatted_date = sprintf( esc_html__( '%1$s at %2$s' , 'buddyboss' ), $formatted_date , $formatted_time ); } /** * Filters the date based on a UNIX timestamp. * * @since BuddyPress 1.0.0 * * @param string $formatted_date Formatted date from the timestamp. */ return apply_filters( 'bp_format_time' , $formatted_date ); } |
Changelog
Version | Description |
---|---|
BuddyPress 1.1.0 | Introduced. |
Questions?
We're always happy to help with code or other questions you might have! Search our developer docs, contact support, or connect with our sales team.