File "class-device.php"

Full path: /home/webcknlt/admissiontell.com/wp-content/plugins/vibes/includes/system/class-device.php
File size: 6.07 B (6.07 KB bytes)
MIME-type: text/x-php
Charset: utf-8

Download   Open   Edit   Advanced Editor &nnbsp; Back

<?php
/**
 * Device handling
 *
 * Handles all device operations and detection.
 *
 * @package System
 * @author  Pierre Lannoy <https://pierre.lannoy.fr/>.
 * @since   1.0.0
 */

namespace Vibes\System;

use Vibes\System\UserAgent;
use Vibes\System\Environment;

/**
 * Define the device functionality.
 *
 * Handles all device operations and detection.
 *
 * @package System
 * @author  Pierre Lannoy <https://pierre.lannoy.fr/>.
 * @since   1.0.0
 */
class Device {

	/**
	 * The list of available classes.
	 *
	 * @since  1.0.0
	 * @var    array    $verbs    Maintains the classes list.
	 */
	public static $classes = [ 'bot', 'mobile', 'desktop', 'other' ];

	/**
	 * The list of available types.
	 *
	 * @since  1.0.0
	 * @var    array    $types    Maintains the types list.
	 */
	public static $types = [ 'smartphone', 'featurephone', 'tablet', 'phablet', 'console', 'portable_media_player', 'car_browser', 'tv', 'smart_display', 'smart_speaker', 'wearable', 'peripheral', 'camera', 'other' ];

	/**
	 * The list of observable devices.
	 *
	 * @since  1.0.0
	 * @var    array    $verbs    Maintains the observable devices list.
	 */
	public static $observable = [];

	/**
	 * Defines all needed globals.
	 *
	 * @since 1.0.0
	 */
	public static function init() {
		$removable        = [ 'other' ];
		self::$observable = array_merge( [ 'other' ], array_diff( self::$classes, $removable ), array_diff( self::$types, $removable ) );
	}

	/**
	 * Get device type.
	 *
	 * @since 1.0.0
	 */
	public static function get_class() {
		$ua = UserAgent::get();
		if ( $ua->class_is_desktop ) {
			return 'desktop';
		}
		if ( $ua->class_is_mobile ) {
			return 'mobile';
		}
		if ( $ua->class_is_bot ) {
			return 'bot';
		}
		return 'other';
	}

	/**
	 * Get class name.
	 *
	 * @since 1.0.0
	 */
	public static function get_class_name( $class = '' ) {
		if ( '' === $class ) {
			$class = self::get_class();
		}
		switch ( $class ) {
			case 'bot':
				return esc_html__( 'Bot', 'vibes' );
			case 'desktop':
				return esc_html__( 'Desktop', 'vibes' );
			case 'mobile':
				return esc_html__( 'Mobile', 'vibes' );
			default:
				return esc_html__( 'Other', 'vibes' );
		}
	}

	/**
	 * Get device type.
	 *
	 * @since 1.0.0
	 */
	public static function get_device() {
		$ua = UserAgent::get();
		if ( $ua->class_is_desktop ) {
			return 'desktop';
		}
		if ( $ua->class_is_bot ) {
			return 'bot';
		}
		if ( $ua->class_is_mobile ) {
			if ( $ua->device_is_smartphone ) {
				return 'smartphone';
			}
			if ( $ua->device_is_featurephone ) {
				return 'featurephone';
			}
			if ( $ua->device_is_tablet ) {
				return 'tablet';
			}
			if ( $ua->device_is_phablet ) {
				return 'phablet';
			}
			if ( $ua->device_is_console ) {
				return 'console';
			}
			if ( $ua->device_is_portable_media_player ) {
				return 'portable_media_player';
			}
			if ( $ua->device_is_car_browser ) {
				return 'car_browser';
			}
			if ( $ua->device_is_tv ) {
				return 'tv';
			}
			if ( $ua->device_is_smart_display ) {
				return 'smart_display';
			}
			if ( $ua->device_is_camera ) {
				return 'camera';
			}
			if ( property_exists( $ua, 'device_is_smart_speaker' ) ) {
				if ( $ua->device_is_smart_speaker ) {
					return 'smart_speaker';
				}
			}
			if ( property_exists( $ua, 'device_is_wearable' ) ) {
				if ( $ua->device_is_wearable ) {
					return 'wearable';
				}
			}
			if ( property_exists( $ua, 'device_is_peripheral' ) ) {
				if ( $ua->device_is_peripheral ) {
					return 'peripheral';
				}
			}
		}
		return 'other';
	}



	/**
	 * Get device name.
	 *
	 * @since 1.0.0
	 */
	public static function get_device_name( $device = '' ) {
		if ( '' === $device ) {
			$device = self::get_device();
		}
		switch ( $device ) {
			case 'smartphone':
				return esc_html__( 'Smartphone', 'vibes' );
			case 'featurephone':
				return esc_html__( 'Feature Phone', 'vibes' );
			case 'tablet':
				return esc_html__( 'Tablet', 'vibes' );
			case 'phablet':
				return esc_html__( 'Phablet', 'vibes' );
			case 'console':
				return esc_html__( 'Game Console', 'vibes' );
			case 'portable_media_player':
				return esc_html__( 'Portable Media Player', 'vibes' );
			case 'car_browser':
				return esc_html__( 'Car Browser', 'vibes' );
			case 'tv':
				return esc_html__( 'TV', 'vibes' );
			case 'smart_display':
				return esc_html__( 'Smart Display', 'vibes' );
			case 'smart_speaker':
				return esc_html__( 'Smart Speaker', 'vibes' );
			case 'wearable':
				return esc_html__( 'Wearable', 'vibes' );
			case 'peripheral':
				return esc_html__( 'Peripheral', 'vibes' );
			case 'camera':
				return esc_html__( 'Camera', 'vibes' );
			default:
				return esc_html__( 'Other', 'vibes' );
		}
	}

	/**
	 * Get icon.
	 *
	 * @param   string  $type   The device type.
	 * @return  string  The icon.
	 * @since 1.0.0
	 */
	public static function get_icon( $type ) {
		switch ( $type ) {
			case 'desktop':
				$result = '🖥️';
				break;
			case 'mobile':
			case 'featurephone':
			case 'phablet':
			case 'tablet':
			case 'smartphone':
				$result = '📱️';
				break;
			case 'console':
				$result = '🎮️';
				break;
			case 'portable_media_player':
				$result = '📀️';
				break;
			case 'car_browser':
				$result = '🚙️';
				break;
			case 'tv':
			case 'smart_display':
				$result = '📺️';
				break;
			case 'camera':
				$result = '📸️';
				break;
			case 'smart_speaker':
				$result = '🔊️';
				break;
			case 'wearable':
				$result = '⌚️';
				break;
			case 'peripheral':
				$result = '🖨️️';
				break;
			case 'bot':
				$result = '🤖️️';
				break;
			default:
				$result = '🥷';
		}
		return $result;
	}

	/**
	 * Get id name.
	 *
	 * @param   string  $type   The device type.
	 * @return  string  The id name.
	 * @since 1.0.0
	 */
	public static function get_id_name( $type ) {
		return ucwords( str_replace( '_', ' ', $type ) );
	}

	/**
	 * Get icon and id name.
	 *
	 * @param   string  $type   The device type or class.
	 * @return  string  The icon and id name.
	 * @since 1.0.0
	 */
	public static function get_icon_id_name( $type ) {
		return self::get_icon( $type ) . ' ' . self::get_id_name( $type );
	}

}

Device::init();