hisorange / browser-detect by hisorange

Browser & Mobile detection package for Laravel.
7,030,143
1,103
28
Package Data
Maintainer Username: hisorange
Maintainer Contact: hello@hisorange.me (Varga Zsolt)
Package Create Date: 2013-12-06
Package Last Update: 2024-12-10
Home Page: https://browser-detect.com
Language: PHP
License: MIT
Last Refreshed: 2025-01-21 03:16:02
Package Statistics
Total Downloads: 7,030,143
Monthly Downloads: 153,507
Daily Downloads: 8,154
Total Stars: 1,103
Total Watchers: 28
Total Forks: 143
Total Open Issues: 15

Browser Detection by hisorange

Latest Stable Version Build Status Coverage Status Total Downloads Dependency Status License

Easy to use package to identify the user's browser details and device type. Magic is not involved the results are generated by multiple well tested and developed packages. Supporting every laravel version between 5.0 » 5.6, also tested on every release PHP between 5.6 » 7.2.

How to install


composer require hisorange/browser-detect

Yep, that's it! At least for lavarel 5.5 and above, for 5.4 and below please read the extended installation.

How to use


In your classes and controllers just call the Browser facade:

// Determine the user's device type is simple as this:
Browser::isMobile();
Browser::isTablet();
Browser::isDesktop();

// Every wondered if it is a bot who loading your page?
if (Browser::isBot()) {
    echo 'No need to wonder anymore!';
}

// Check for vendors.
if (Browser::isFirefox() || Browser::isOpera()) {
    $output .= '<script src="firefox-fix.js"></script>';
}

Even in your blade templates:

{{-- Directives are built in laravel 5.5 and above! --}}
@mobile
    <p>This is the MOBILE template!</p>
    @include('your-mobile-template')
@endmobile

@tablet
    <p>This is the TABLET template!</p>
    <link rel="stylesheet" href="tablet.css" title="Reduce the page size, load what the user need">
@endtablet

@desktop
    <p>This is the DESKTOP template!</p>
@enddesktop

// Every key is supported.
@browser('isBot')
    <p>Bots are identified too :)</p>
@endbrowser

Available API calls


Every call on the Browser facade is mirrored to the result object, so the following informations are available on your result too, where you can use the array syntax to access them.

| Call | Response | Internal Type | | :--- | :--- | :---: | | Browser::userAgent() | Current visitor's HTTP_USER_AGENT string. | (string) | | Browser::isMobile() | Is this a mobile device. | (boolean) | | Browser::isTablet() | Is this a tablet device. | (boolean) | | Browser::isDesktop() | Is this a desktop computer. | (boolean) | | Browser::isBot() | Is this a crawler / bot. | (boolean) | | Browser related functions ||| | Browser::browserName() | Browser's human friendly name like Firefox 3.6, Chrome 42. | (string) | | Browser::browserFamily() | Browser's vendor like Chrome, Firefox, Opera. | (string) | | Browser::browserVersion() | Browser's human friendly version string. | (string) | | Browser::browserVersionMajor() | Browser's semantic major version. | (integer) | | Browser::browserVersionMinor() | Browser's semantic minor version. | (integer) | | Browser::browserVersionPatch() | Browser's semantic patch version. | (integer) | | Browser::browserEngine() | Browser's engine like: Blink, WebKit, Gecko. | (string) | | Operating system related functions ||| | Browser::platformName() | Operating system's human friendly name like Windows XP, MacOS 10. | (string) | | Browser::platformFamily() | Operating system's vendor like Linux, Windows, MacOS. | (string) | | Browser::platformVersion() | Operating system's human friendly version like XP, Vista, 10. | (integer) | | Browser::platformVersionMajor() | Operating system's semantic major version. | (integer) | | Browser::platformVersionMinor() | Operating system's semantic minor version. | (integer) | | Browser::platformVersionPatch() | Operating system's semantic patch version. | (integer) | | Device related functions ||| | Browser::deviceFamily() | Device's vendor like Samsung, Apple, Huawei. | (string) | | Browser::deviceModel() | Device's brand name like iPad, iPhone, Nexus. | (string) | | Browser::mobileGrade() | Device's mobile grade in scale of A,B,C for performance. | (string) | | Browser vendor related functions ||| | Browser::isChrome() | Is this a chrome browser. | (boolean) | | Browser::isFirefox() | Is this a firefox browser. | (boolean) | | Browser::isOpera() | Is this an opera browser. | (boolean) | | Browser::isSafari() | Is this a safari browser. | (boolean) | | Browser::isIE() | Checks if the browser is an some kind of Internet Explorer (or Trident) | (boolean) | | Browser::isIEVersion() | Compares to a given IE version | (boolean) |

Version support


The following matrix is being continuously tested by the great and awesome Travis CI!

| ----- | PHP 5.6 | PHP 7.0 | PHP 7.1 | PHP 7.2 | | :---: | :-----: | :-----: | :-----: | :-----: | | Laravel 5.0 | ✓ | - | - | - | | Laravel 5.1 | ✓ | - | - | - | | Laravel 5.2 | ✓ | - | - | - | | Laravel 5.3 | ✓ | - | - | - | | Laravel 5.4 | ✓ | ✓ | ✓ | ✓ | | Laravel 5.5 | - | ✓ | ✓ | ✓ | | Laravel 5.6 | - | - | ✓ | ✓ |

* Cannot auto test the laravel 5.4 on PHP 7.1 because of version incompatibility between the PHPUnit, Laravel and the package testing library, but the versions are tested manually.

Laravel 4.x support

Laravel 4.x releases are not actively developed but you can still use the browser detect 1.x for it; You can find those releases under the versions tab. Please read the readme from the release use choose, after version 2.x the package was redesigned from the sketch so nor the installation nor the usage is the same.

Extended Installation


If you are using laravel 5.4 and below you have to add the service provider in your config/app.php like this:

    'providers' => [
        // Package Service Providers...
        \hisorange\BrowserDetect\ServiceProvider::class,
    ]

and don't forget to add the facade in the same file like this:

    'aliases' => [
        'Browser' => \hisorange\BrowserDetect\Facade::class,
    ]

Extended Usage Information


The code is designed to be an easy to use style, so every call you make on the Browser facade will access the result object and get the data for you, but you can parse agents other then the current user's.

// When you call the detect function you will get a result object, from the current user's agent.
$result = Browser::detect();

// If you wana get browser details from a user agent other then the current user call the parse function.
$result = Browser::parse('Opera/9.80 (Windows NT 6.0) Presto/2.12.388 Version/12.14');

Changlog


See the detailed changes in the CHANGELOG file.