-
Notifications
You must be signed in to change notification settings - Fork 23
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
10 changed files
with
219 additions
and
19 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,152 @@ | ||
# wip | ||
<p align="center"> | ||
<img src="docs/images/Logo.png" alt="Laravisit Logo" width="300"> | ||
<br><br> | ||
</p> | ||
|
||
[![The Latest Version on Packagist](https://img.shields.io/packagist/v/coderflexx/laravisit.svg?style=flat-square)](https://packagist.org/packages/coderflexx/laravisit) | ||
[![GitHub Tests Action Status](https://img.shields.io/github/workflow/status/coderflexx/laravisit/run-tests?label=tests)](https://github.com/coderflexx/laravisit/actions?query=workflow%3Arun-tests+branch%3Amain) | ||
[![GitHub Code Style Action Status](https://img.shields.io/github/workflow/status/coderflexx/laravisit/Check%20&%20fix%20styling?label=code%20style)](https://github.com/coderflexx/laravisit/actions?query=workflow%3A"Check+%26+fix+styling"+branch%3Amain) | ||
|
||
A clean way to track your pages & understand your user's behavior | ||
|
||
## Installation | ||
|
||
You can install the package via composer: | ||
|
||
```bash | ||
composer require coderflexx/laravisit | ||
``` | ||
|
||
You can publish the config file with: | ||
|
||
```bash | ||
vendor:publish --provider="Coderflex\\Laravisit\\LaravisitServiceProvider" | ||
``` | ||
|
||
then, run database migration | ||
```bash | ||
php artisan migrate | ||
``` | ||
|
||
This is the contents of the published config file: | ||
```php | ||
return [ | ||
/* | ||
|-------------------------------------------------------------------------- | ||
| User Namespace | ||
|-------------------------------------------------------------------------- | ||
| | ||
| This value informs Laravist which namespace you will be | ||
| selecting to get the user model instance | ||
| If this value equals to null, "\Coderflex\Laravisit\Models\User" will be used | ||
| by default. | ||
| | ||
*/ | ||
'user_namespace' => "\Coderflex\Laravisit\Models\User", | ||
]; | ||
``` | ||
|
||
|
||
## Usage | ||
|
||
### Use `HasVisits` Trait | ||
|
||
The first thing you need to do is, to use `HasVisits` trait | ||
|
||
```php | ||
namespace App\Models\Post; | ||
|
||
use Coderflex\Laravisit\Concerns\HasVisits; | ||
use Illuminate\Database\Eloquent\Factories\HasFactory; | ||
use Illuminate\Database\Eloquent\Model; | ||
|
||
class Post extends Model | ||
{ | ||
... | ||
use HasFactory; | ||
use HasVisits; | ||
... | ||
} | ||
``` | ||
After this step, you are reading to go, and when you need to track a page, do it like this: | ||
|
||
```php | ||
$post->visit(); | ||
``` | ||
|
||
You can chain methods to the `visit` method. Here is a list of the available methods: | ||
|
||
| METHOD | SYNTAX | DESCRIPTION | EXAMPLE | | ||
| ----------- | ----------- | ----------- | ----------- | | ||
| `withIp()` | string `$ip = null` | Set an Ip address (default `request()->ip()`) | `$post->visit()->withIp()` | | ||
|`withData()` | array `$data` | Set custom data | `$post->visit()->withData(['region' => 'USA'])` | | ||
| `withUser()` | Model `$user = null` | Set a user model (default `auth()->user()`) | `$user->visit()->withUser()` | | ||
|
||
--- | ||
|
||
By default, you will have unique visits __each day__ using `dailyInterval()` method. Meaning, when the users access the page multiple times in the day time frame, you will see just `one record` related to them. | ||
|
||
If you want to log users access to page with different __timeframes__, here are a bunch of useful methods: | ||
|
||
| METHOD | SYNTAX | DESCRIPTION | EXAMPLE | | ||
| ----------- | ----------- | ----------- | ----------- | | ||
| `hourlyInterval()` | `void` | Log visits each hour | `$post->visit()->hourlyIntervals()->withIp();` | | ||
| `dailylyInterval()` | `void` | Log visits each daily | `$post->visit()->dailylyIntervals()->withIp();` | | ||
| `weeklyInterval()` | `void` | Log visits each week | `$post->visit()->weeklyIntervals()->withIp();` | | ||
| `monthlyInterval()` | `void` | Log visits each month | `$post->visit()->monthlyIntervals()->withIp();` | | ||
| `yearlyInterval()` | `void` | Log visits each year | `$post->visit()->yearlyIntervals()->withIp();` | | ||
| `customInterval()` | mixed `$interval` | Log visits within a custom interval | `$post->visit()->customInterval( now()->subYear() )->withIp();` | | ||
|
||
### Get The Records With Popular Time Frames | ||
After the visits get logged, you can retrieve the data by the following method: | ||
|
||
| METHOD | SYNTAX | DESCRIPTION | EXAMPLE | | ||
| ----------- | ----------- | ----------- | ----------- | | ||
| `withTotalVisitCount()` | `void` | get total visit count | `Post::withTotalVisitCount()->first()->visit_count_total` | | ||
| `popularAllTime()` | `void` | get popular visits all time | `Post::popularAllTime()->get()` | | ||
| `popularLastDays()` | int `$days` | get popular visits last given days | `Post::popularLastDays(10)->get()` | | ||
| `popularThisWeek()` | `void` | get popular visits this week | `Post::popularThisWeek()->get()` | | ||
| `popularLastWeek()` | `void` | get popular visits last week | `Post::popularLastWeek()->get()` | | ||
| `popularThisMonth()` | `void` | get popular visits this month | `Post::popularThisMonth()->get()` | | ||
| `popularLastMonth()` | `void` | get popular visits last month | `Post::popularLastMonth()->get()` | | ||
| `popularThisYear()` | `void` | get popular visits this year | `Post::popularThisYear()->get()` | | ||
| `popularLastYear()` | `void` | get popular visits last year | `Post::popularLastYear()->get()` | | ||
| `popularBetween()` | Carbon `$from`, Carbon `$to` | get popular visits between custom two dates | `Post::popularBetween(Carbon::createFromDate(2019, 1, 9), Carbon::createFromDat(2022, 1, 3))->get();` | | ||
|
||
## Visit Presenter | ||
This package is coming with helpful decorate model properties, and it uses [Laravel Presenter](https://github.com/coderflexx/laravel-presenter) package under the hood. | ||
|
||
| METHOD | SYNTAX | DESCRIPTION | EXAMPLE | | ||
| ----------- | ----------- | ----------- | ----------- | | ||
| `ip()` | `void` | Get the associated IP from the model instance | `$post->visits->first()->present()->id`| | ||
| `user()` | `void` | Get the associated User from the model instance | `$post->visits->first()->present()->user->name`| | ||
|
||
## Testing | ||
|
||
```bash | ||
composer test | ||
``` | ||
|
||
## Changelog | ||
|
||
Please see [CHANGELOG](CHANGELOG.md) for more information on what has changed recently. | ||
|
||
## Contributing | ||
|
||
Please see [CONTRIBUTING](.github/CONTRIBUTING.md) for details. | ||
|
||
## Security Vulnerabilities | ||
|
||
Please review [our security policy](../../security/policy) on how to report security vulnerabilities. | ||
|
||
## Inspiration | ||
- [Codecourse Laravel Model Popularity](https://codecourse.com/courses/laravel-model-popularity) | ||
|
||
## Credits | ||
|
||
- [Oussama Sid](https://github.com/ousid) | ||
- [All Contributors](../../contributors) | ||
|
||
## License | ||
|
||
The MIT License (MIT). Please see [License File](LICENSE.md) for more information. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
<?php | ||
|
||
namespace Coderflex\Laravisit\Models; | ||
|
||
|
||
use Illuminate\Contracts\Auth\MustVerifyEmail; | ||
use Illuminate\Database\Eloquent\Factories\HasFactory; | ||
use Illuminate\Foundation\Auth\User as Authenticatable; | ||
use Illuminate\Notifications\Notifiable; | ||
|
||
class User extends Authenticatable | ||
{ | ||
use HasFactory, Notifiable; | ||
|
||
/** | ||
* The attributes that are mass assignable. | ||
* | ||
* @var array<int, string> | ||
*/ | ||
protected $fillable = [ | ||
'name', | ||
'email', | ||
'password', | ||
]; | ||
|
||
/** | ||
* The attributes that should be hidden for serialization. | ||
* | ||
* @var array<int, string> | ||
*/ | ||
protected $hidden = [ | ||
'password', | ||
'remember_token', | ||
]; | ||
|
||
/** | ||
* The attributes that should be cast. | ||
* | ||
* @var array<string, string> | ||
*/ | ||
protected $casts = [ | ||
'email_verified_at' => 'datetime', | ||
]; | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.