HEX
Server: nginx/1.27.1
System: Linux in-3 5.15.0-161-generic #171-Ubuntu SMP Sat Oct 11 08:17:01 UTC 2025 x86_64
User: ivenus-clone (3297)
PHP: 7.4.33
Disabled: exec,passthru,shell_exec,system,proc_open,popen,parse_ini_file,show_source
Upload Files
File: /storage/v4513/tepnot/public_html/wp-content/plugins/dokan-pro/includes/Announcement/Single.php
<?php

namespace WeDevs\DokanPro\Announcement;

if ( ! defined( 'ABSPATH' ) ) {
    exit; // Exit if accessed directly
}

/**
 * Class Single
 *
 * @since   3.9.4
 *
 * @package WeDevs\DokanPro\Announcement
 */
class Single {
    /**
     * @since 3.9.4
     *
     * @var array $data
     */
    private $data = [
        'id'                  => 0,
        'notice_id'           => 0,
        'vendor_id'           => 0,
        'title'               => '',
        'content'             => '',
        'status'              => '',
        'read_status'         => '',
        'date'                => '',
        'date_gmt'            => '',
        'human_readable_date' => '',
    ];

    /**
     * Single constructor.
     *
     * @param array $args
     */
    public function __construct( $args = [] ) {
        $this->data = wp_parse_args( $args, $this->data );
        $this->set_human_readable_date();
    }

    /**
     * Get announcement data
     *
     * @since 3.9.4
     *
     * @return array
     */
    public function get_data() {
        return [
            'id'                  => $this->get_id(),
            'notice_id'           => $this->get_notice_id(),
            'vendor_id'           => $this->get_vendor_id(),
            'title'               => $this->get_title(),
            'content'             => $this->get_content(),
            'status'              => $this->get_status(),
            'read_status'         => $this->get_read_status(),
            'date'                => $this->get_date(),
            'date_gmt'            => $this->get_date_gmt(),
            'human_readable_date' => $this->get_human_readable_date(),
        ];
    }

    /**
     * Get announcement id
     *
     * @since 3.9.4
     *
     * @return int
     */
    public function get_id(): int {
        // if notice id is set, dynamically set id as notice id
        // otherwise, this might be confusing determining if the current item is a notice or announcement
        // the general rules is, if vendor id is provided, notice will be provided, otherwise announcement
        return $this->get_notice_id() ? $this->get_notice_id() : absint( $this->data['id'] );
    }

    /**
     * Get vendor notice id
     *
     * @since 3.9.4
     *
     * @return int
     */
    public function get_notice_id(): int {
        return absint( $this->data['notice_id'] );
    }

    /**
     * Get vendor id
     *
     * @since 3.9.4
     *
     * @return int
     */
    public function get_vendor_id(): int {
        return absint( $this->data['vendor_id'] );
    }

    /**
     * Get announcement title
     *
     * @since 3.9.4
     *
     * @return string
     */
    public function get_title(): string {
        return $this->data['title'];
    }

    /**
     * Get announcement content
     *
     * @since 3.9.4
     *
     * @return string
     */
    public function get_content(): string {
        return $this->data['content'];
    }

    /**
     * Get announcement status
     *
     * @since 3.9.4
     *
     * @return string
     */
    public function get_status(): string {
        return $this->data['status'];
    }

    /**
     * Get announcement read status
     *
     * @since 3.9.4
     *
     * @return string
     */
    public function get_read_status(): string {
        return $this->data['read_status'];
    }

    /**
     * Get announcement date
     *
     * @since 3.9.4
     *
     * @return string
     */
    public function get_date(): string {
        return $this->data['date'];
    }

    /**
     * Get announcement date in GMT
     *
     * @since 3.9.4
     *
     * @return string
     */
    public function get_date_gmt(): string {
        return $this->data['date_gmt'];
    }

    /**
     * Get human-readable announcement date
     *
     * @since 3.9.4
     *
     * @return string
     */
    public function get_human_readable_date(): string {
        return $this->data['human_readable_date'];
    }

    /**
     * Set announcement id
     *
     * @since 3.9.4
     *
     * @param int $id
     *
     * @return $this
     */
    public function set_id( $id ): Single {
        $this->data['id'] = absint( $id );

        return $this;
    }

    /**
     * Set vendor single notice id
     *
     * @since 3.9.4
     *
     * @param int $id
     *
     * @return $this
     */
    public function set_notice_id( $id ): Single {
        $this->data['notice_id'] = absint( $id );

        return $this;
    }

    /**
     * Set vendor id
     *
     * @since 3.9.4
     *
     * @param int $id
     *
     * @return $this
     */
    public function set_vendor_id( $id ): Single {
        $this->data['vendor_id'] = absint( $id );

        return $this;
    }

    /**
     * Set announcement title
     *
     * @since 3.9.4
     *
     * @param string $title
     *
     * @return $this
     */
    public function set_title( $title ): Single {
        $this->data['title'] = $title;

        return $this;
    }

    /**
     * Set announcement content
     *
     * @since 3.9.4
     *
     * @param string $content
     *
     * @return $this
     */
    public function set_content( $content ): Single {
        $this->data['content'] = $content;

        return $this;
    }

    /**
     * Set announcement status
     *
     * @since 3.9.4
     *
     * @param string $status
     *
     * @return $this
     */
    public function set_status( $status ): Single {
        $this->data['status'] = in_array( $status, [ 'publish', 'future', 'draft' ], true ) ? $status : 'draft';

        return $this;
    }

    /**
     * Set announcement read status
     *
     * @since 3.9.4
     *
     * @param string $read_status
     *
     * @return $this
     */
    public function set_read_status( $read_status ): Single {
        $this->data['read_status'] = in_array( $read_status, [ 'read', 'unread', 'trash' ], true ) ? $read_status : 'unread';

        return $this;
    }

    /**
     * Set human-readable announcement date
     *
     * @since 3.9.4
     *
     * @return $this
     */
    public function set_human_readable_date(): Single {
        if ( empty( $this->get_date() ) ) {
            return $this;
        }

        $this->data['human_readable_date'] = sprintf(
        // translators: %s, Time elapsed from announcement creation.
            __( '%s ago', 'dokan' ),
            human_time_diff(
                dokan_current_datetime()->modify( $this->get_date() )->getTimestamp(),
                dokan_current_datetime()->getTimestamp()
            )
        );

        return $this;
    }

    /**
     * Check if the current item is a notice
     *
     * @since 3.9.4
     *
     * @return bool
     */
    public function is_notice(): bool {
        return (bool) $this->get_notice_id();
    }

    /**
     * Check if the current item is an announcement
     *
     * @since 3.9.4
     *
     * @return bool
     */
    public function is_announcement(): bool {
        return ! $this->get_notice_id();
    }
}