承接 alifahmmed/metrics-tracker 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

alifahmmed/metrics-tracker

最新稳定版本:1.0.7

Composer 安装命令:

composer require alifahmmed/metrics-tracker

包简介

A Laravel helper package for store impression, click of a post with filter and ctr.

README 文档

README

A Laravel package to track impressions, clicks, and CTR (Click-Through Rate) for any model like pages, posts, banners, or other content. Inspired by platforms like Fiverr and Upwork.

✨ Features

  • ✅ Track impressions (when content is viewed)
  • ✅ Track clicks (when user interacts)
  • ✅ Automatically generates CTR (Click-Through Rate)
  • ✅ Supports polymorphic relationships
  • ✅ Artisan command to clean old records

📦 Installation

composer require alifahmmed/metrics-tracker

Then publish the migration:

php artisan vendor:publish --tag=public
php artisan migrate

🔧 Setup

🎮 1. How to Use in Controller You can easily integrate metrics tracking (impressions and clicks) directly in your controllers.

👁️ Store Impressions (e.g., in index() method) To track impressions when showing a list of items:

use AlifAhmmed\MetricsTracker\Helpers\MetricsTracker;

$data = YourModel::all(); // Replace with your model
MetricsTracker::trackImpressionsForCollection($data);

This will:

Store an impression only once per user/IP per day

Automatically attach a metric_token to each model for tracking clicks

🖱️ Store Clicks (e.g., in show() method) To track clicks when a user views or interacts with a single item:

use AlifAhmmed\MetricsTracker\Helpers\MetricsTracker;

$data = YourModel::findOrFail($id); // Replace with your model
MetricsTracker::trackClickAndGenerateToken($data);

This will:

Store a click only if an impression exists for today

Attach the metric_token to the model for reference

🔍 2. Filter Metrics by Days You can filter impressions and clicks by a specific range of days using this snippet:

$request->validate([
    'days' => 'required|in:1,7,14,30,60,90,180,365',
]);

$days = $request->days;

$metrics = MetricsTracker::getMetricsByDays($days);

Accepted values for days: 1, 7, 14, 30, 60, 90, 180, 365

This will return all metrics grouped by:

trackable_type

type (impression or click)

date

📈 3. Calculate CTR (Click-Through Rate) To calculate CTR for a specific model, ID, and day range, use:

use App\Models\YourModel;

$ctr = MetricsTracker::calculateCTR(YourModel::class, $trackableId, 30);

Replace YourModel::class with your actual model class.

Replace $trackableId with the model ID.

Replace 30 with any day value (1, 7, 14, 30, 60, 90, 180, 365).

If there are no impressions, the CTR will return 0.

📊 How It Works 👁️ Impression is tracked when an element becomes visible in the viewport.

🖱️ Click is tracked when an element is clicked.

📈 CTR (Click-Through Rate) is calculated based on total clicks / total impressions * 100.

🛠 Artisan Commands Clean up metrics older than 90 days (adjustable):

php artisan metrics:clean

🧪 Example Usage (Controller or API) If you're building a SPA or headless app, you can also generate tokens server-side:

use AlifAhmmed\MetricsTracker\Helpers\MetricsTracker;

$token = MetricsTracker::generateMetricToken($post);

🧑‍💻 Author S M Alif Ahmmed

⚖ License MIT License. Use it freely in personal and commercial projects.

⭐ Like it? Give it a ⭐ on GitHub and share it with your Laravel friends!

统计信息

  • 总下载量: 19
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-04-20