flipboxfactory / craft-tracker
Track various actions such as page views and clicks
Installs: 13
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
Type:craft-plugin
pkg:composer/flipboxfactory/craft-tracker
Requires
- craftcms/cms: ^3.2
 - flipboxfactory/craft-ember: ^2.1
 
Requires (Dev)
- codeception/codeception: ^3.0
 - squizlabs/php_codesniffer: ^3.4
 
This package is auto-updated.
Last update: 2025-10-05 02:09:24 UTC
README
Installation
To install, use composer:
composer require flipboxfactory/craft-tracker
Testing
$ ./vendor/bin/phpunit
Contributing
Please see CONTRIBUTING for details.
Credits
License
Please see License File for more information.
Examples
List Event Counts via RollUp object
<ul> {% for rollUp in craft.tracker.rollUp.author(currentUser).all() %} <li> <h3>{{ rollUp.entry.title }}</h3> Hit Count: {{ rollUp.count }} </li> {% endfor %} </ul>
List All Events By Entry
{% set entryId = 1 %}
<ul>
{% for event in craft.tracker.query.entryId(entryId).all() %}
    <li>
        <h3>{{ event.title }} -- {{ event.event }}</h3>
        <strong>User Agent:</strong> {{ event.userAgent }} <br />
        <strong>IP:</strong> {{ event.remoteIp }} <br />
        <strong>OS:</strong> {{ event.clientOs }} <br />
        <string>Created At:</string> {{ event.dateCreated }} <br />
        <strong>Metadata:</strong>
        <ul>
            {% for key, value in event.metadata|json_decode %}
                <li>
                    <strong>{{ key }}</strong> - {{ value }}
                </li>
            {% endfor %}
        </ul>
    </li>
{% endfor %}
</ul>
Record Event via TWIG Template
{# Basic 'Page View' type tracking #} {% do craft.tracker.track({entry: entry}) %} {# Explicitly set track attributes #} {% do craft.tracker.track({entry: entry, event: "Viewed::PDF"}) %}
Record Event (AJAX / JQuery)
{% set metadata = {foo: "bar"} %}
<a href="https://google.com"
   data-event="Click::LinkToGoogle"
   data-entry-id="131"
   data-element-id="125"
   data-metadata="{{ metadata|json_encode() }}"
   data-title="Lorem ipsum dolor sit amet, consectetur adipiscing elit">Goto Google</a>
<script src="https://code.jquery.com/jquery-3.5.1.min.js"
        integrity="sha256-9/aliU8dGd2tb6OSsuzixeV4y/faTqgFtohetphbbj0=" crossorigin="anonymous"></script>
<script>
    $(function () {
        $('[data-event][data-entry-id]').click(function () {
            let data = $(this).data();
            data.{{ craft.app.config.general.csrfTokenName }} = "{{ craft.app.request.csrfToken }}"
            console.log("Begin track event", data);
            $.ajax({
                async: false,
                type: "POST",
                url: "{{ actionUrl('/tracker/track/event') }}",
                data: JSON.stringify(data),
                headers: {
                    Accept: "application/json; charset=utf-8",
                    "Content-Type": "application/json; charset=utf-8"
                },
                contentType: "application/json",
                dataType: "json",
                success: function (response) {
                    console.log("End track event", response);
                },
            });
        });
    });
</script>