PHPackages                             laravel-interaction/visit - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Database &amp; ORM](/categories/database)
4. /
5. laravel-interaction/visit

ActiveLibrary[Database &amp; ORM](/categories/database)

laravel-interaction/visit
=========================

User visit behaviour for Laravel.

3.5.0(1mo ago)27MITPHPPHP ^8.0

Since Dec 16Pushed 1mo ago1 watchersCompare

[ Source](https://github.com/laravel-interaction/visit)[ Packagist](https://packagist.org/packages/laravel-interaction/visit)[ Docs](https://github.com/laravel-interaction/visit)[ RSS](/packages/laravel-interaction-visit/feed)WikiDiscussions master Synced yesterday

READMEChangelog (7)Dependencies (12)Versions (28)Used By (0)

Laravel Visit
=============

[](#laravel-visit)

User visit behaviour for Laravel.

[![Latest Stable Version](https://camo.githubusercontent.com/d5eb6f7fc472545dca165c16bf5accc119c0507ec8cf26882262cff2adb8ac10/68747470733a2f2f706f7365722e707567782e6f72672f6c61726176656c2d696e746572616374696f6e2f76697369742f762f737461626c652e737667)](https://packagist.org/packages/laravel-interaction/visit)[![Total Downloads](https://camo.githubusercontent.com/cf0fe91c76c2fac649781df9ef9ad1274bc6ccfab19723ec9b81d722ab660be2/68747470733a2f2f706f7365722e707567782e6f72672f6c61726176656c2d696e746572616374696f6e2f76697369742f646f776e6c6f616473)](https://packagist.org/packages/laravel-interaction/visit)[![Latest Unstable Version](https://camo.githubusercontent.com/9e21a9ac355aec8a7220292349f5451312a0f75b331b716057f26817b36bd06c/68747470733a2f2f706f7365722e707567782e6f72672f6c61726176656c2d696e746572616374696f6e2f76697369742f762f756e737461626c652e737667)](https://packagist.org/packages/laravel-interaction/visit)[![License](https://camo.githubusercontent.com/eb1a5464891c160c6dcff630aa049c2ba888ee4d2427e564651c00982b3775ef/68747470733a2f2f706f7365722e707567782e6f72672f6c61726176656c2d696e746572616374696f6e2f76697369742f6c6963656e7365)](https://packagist.org/packages/laravel-interaction/visit)

Introduction
------------

[](#introduction)

It used to record the number of visits to the model(documentation/subject/question).

[![](https://camo.githubusercontent.com/8a952f1763ec6760916101148bb8ac6d9dbb25703df5adcd840126459734850b/68747470733a2f2f696d672e736869656c64732e696f2f62616467652f2546302539462539332539362d312e326b2d677265656e3f7374796c653d736f6369616c)](https://camo.githubusercontent.com/8a952f1763ec6760916101148bb8ac6d9dbb25703df5adcd840126459734850b/68747470733a2f2f696d672e736869656c64732e696f2f62616467652f2546302539462539332539362d312e326b2d677265656e3f7374796c653d736f6369616c)

Installation
------------

[](#installation)

### Requirements

[](#requirements)

- [PHP 8.0+](https://php.net/releases/)
- [Composer](https://getcomposer.org)
- [Laravel 8.0+](https://laravel.com/docs/releases)

### Instructions

[](#instructions)

Require Laravel Visit using [Composer](https://getcomposer.org).

```
composer require laravel-interaction/visit
```

Publish configuration and migrations

```
php artisan vendor:publish --tag=visit-config
php artisan vendor:publish --tag=visit-migrations
```

Run database migrations.

```
php artisan migrate
```

Usage
-----

[](#usage)

### Setup Visitor

[](#setup-visitor)

```
use Illuminate\Database\Eloquent\Model;
use LaravelInteraction\Visit\Concerns\Visitor;

class User extends Model
{
    use Visitor;
}
```

### Setup Visitable

[](#setup-visitable)

```
use Illuminate\Database\Eloquent\Model;
use LaravelInteraction\Visit\Concerns\Visitable;

class Subject extends Model
{
    use Visitable;
}
```

### Visitor

[](#visitor)

```
use LaravelInteraction\Visit\Tests\Models\Subject;
/** @var \LaravelInteraction\Visit\Tests\Models\User $user */
/** @var \LaravelInteraction\Visit\Tests\Models\Subject $subject */
// Visit to Visitable
$user->visit($subject);

// Compare Visitable
$user->hasVisited($subject);
$user->hasNot
Visited($subject);

// Get visited info
$user->visitVisitors()->count();

// with type
$user->visitVisitors()->withType(Subject::class)->count();

// get visited subjects
Subject::query()->whereVisitedBy($user)->get();

// get subjects doesnt visited
Subject::query()->whereNotVisitedBy($user)->get();
```

### Visitable

[](#visitable)

```
use LaravelInteraction\Visit\Tests\Models\User;
use LaravelInteraction\Visit\Tests\Models\Subject;
/** @var \LaravelInteraction\Visit\Tests\Models\User $user */
/** @var \LaravelInteraction\Visit\Tests\Models\Subject $subject */
// Compare Visitor
$subject->isVisitedBy($user);
$subject->isNotVisitedBy($user);
// Get visitors info
$subject->visitors->each(function (User $user){
    echo $user->getKey();
});

$subjects = Subject::query()->withVisitorsCount()->get();
$subjects->each(function (Subject $subject){
    // like uv
    echo $subject->visitors()->count(); // 1100
    echo $subject->visitors_count; // "1100"
    echo $subject->visitorsCount(); // 1100
    echo $subject->visitorsCountForHumans(); // "1.1K"
    // like pv
    echo $subject->visitableVisits()->count(); // 1100
    echo $subject->visits_count; // "1100"
    echo $subject->visitsCount(); // 1100
    echo $subject->visitsCountForHumans(); // "1.1K"
});
$subjects = Subject::query()->withVisitorsCount(function ($query){
    return $query->whereKey(1);
})->get();
```

With Api Request
----------------

[](#with-api-request)

```
use Illuminate\Http\Request;
use Illuminate\Routing\Controller;
use LaravelInteraction\Visit\Tests\Models\Subject;
use Illuminate\Http\Resources\Json\JsonResource;

class AuctionController extends Controller
{
    public function show($id, Request $request){
        $subject = Subject::query()->findOrFail($id);
        dispatch(function () use ($subject, $request) {
            $subject->record($request);
        })->afterResponse();
        return new JsonResource($subject);
    }
}
```

### Events

[](#events)

EventFired`LaravelInteraction\Visit\Events\Visited`When an object get visited.License
-------

[](#license)

Laravel Eloquent Visit is an open-sourced software licensed under the [MIT license](LICENSE).

###  Health Score

47

—

FairBetter than 94% of packages

Maintenance89

Actively maintained with recent releases

Popularity7

Limited adoption so far

Community11

Small or concentrated contributor base

Maturity69

Established project with proven stability

 Bus Factor1

Top contributor holds 69.6% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~74 days

Recently: every ~274 days

Total

27

Last Release

53d ago

Major Versions

0.3.0 → 1.2.02021-11-30

1.x-dev → 2.0.0-beta.12022-03-10

2.x-dev → 3.0.02022-11-27

PHP version history (3 changes)0.0.1PHP ^7.2 || ^8.0

2.0.0-beta.1PHP ^7.3 || ^8.0

3.0.0PHP ^8.0

### Community

Maintainers

![](https://www.gravatar.com/avatar/5fafa5bffa28dcd722432b244bf3f0bfe773406df29fea295847e2397b95d50b?d=identicon)[zingimmick](/maintainers/zingimmick)

---

Top Contributors

[![zingimmick](https://avatars.githubusercontent.com/u/26657141?v=4)](https://github.com/zingimmick "zingimmick (71 commits)")[![dependabot[bot]](https://avatars.githubusercontent.com/in/29110?v=4)](https://github.com/dependabot[bot] "dependabot[bot] (28 commits)")[![github-actions[bot]](https://avatars.githubusercontent.com/in/15368?v=4)](https://github.com/github-actions[bot] "github-actions[bot] (2 commits)")[![renovate[bot]](https://avatars.githubusercontent.com/in/2740?v=4)](https://github.com/renovate[bot] "renovate[bot] (1 commits)")

---

Tags

eloquentlaravelvisitlaravelvisit

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/laravel-interaction-visit/health.svg)

```
[![Health](https://phpackages.com/badges/laravel-interaction-visit/health.svg)](https://phpackages.com/packages/laravel-interaction-visit)
```

###  Alternatives

[tucker-eric/eloquentfilter

An Eloquent way to filter Eloquent Models

1.8k4.8M26](/packages/tucker-eric-eloquentfilter)[watson/validating

Eloquent model validating trait.

9723.3M47](/packages/watson-validating)[yajra/laravel-oci8

Oracle DB driver for Laravel via OCI8

8703.0M17](/packages/yajra-laravel-oci8)[cybercog/laravel-love

Make Laravel Eloquent models reactable with any type of emotions in a minutes!

1.2k302.7k1](/packages/cybercog-laravel-love)[cviebrock/eloquent-taggable

Easy ability to tag your Eloquent models in Laravel.

567694.8k3](/packages/cviebrock-eloquent-taggable)[clickbar/laravel-magellan

This package provides functionality for working with the postgis extension in Laravel.

423715.4k1](/packages/clickbar-laravel-magellan)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
