thoughtco/statamic-ab-tester

dev-main 2024-09-16 09:44 UTC

This package is auto-updated.

Last update: 2024-12-16 10:20:35 UTC


README

Installation

composer require thoughtco/statamic-ab-tester

Usage

Experiment types

There are two types of experiments you can run:

Entry

An Entry experiment lets you select an entry and display its content on the page. This can be selected from any collection and will be available as an entry variable inside the ab tag.

Manual

A Manual experiment lets you determine what you want to do inside the experiment, e.g. show a different nav UI, show a different button style. You can use the autogenerated variant:id or use variant:label to determine what to show to the user.

Tags

This package provides tags that you can use in your Statamic templates:

ab

This tag sets an A/B test for the given handle. It will randomly choose a experiment variant, record a hit and provide the experiment and handle to the content of the tag.

If you want your variant to persist over the session lifetime, set session="true"

{{ ab experiment="experiment_handle" session="true" }}
    {{ experiment }} {{ variant }}
{{ /ab }}

ab:success

This tag marks an A/B test as successful.

{{ ab:success experiment="experiment_handle" variant="variant_handle" }}

or if you've used session="true" on the ab tag:

{{ ab:success experiment="experiment_handle" from_session="true" }}

ab:failure

This tag marks an A/B test as a failure.

{{ ab:failure experiment="experiment_handle" variant="variant_handle" }}

or if you've used session="true" on the ab tag:

{{ ab:failure experiment="experiment_handle" from_session="true" }}

Facade

This package provides a facade for interacting with experiments: \Thoughtco\StatamicABTester\Experiment

get an experiment

$experiment = \Thoughtco\StatamicABTester\Experiment::find('experiment_handle');

get all experiments

\Thoughtco\StatamicABTester\Experiment::all();

query experiments

\Thoughtco\StatamicABTester\Experiment::query()->where('handle', 'test')->get();

Experiment

Once you have an experiment you can record hits, successes, failures and get results.

hit

Mark an experiment as being viewed: $experiment->recordHit($variantHandle);

success

Mark an experiment as being successful: $experiment->recordSuccess($variantHandle);

failure

Mark an experiment as being a failure: $experiment->recordFailure($variantHandle);

results

Get the results of an experiment: $experiment->results();