srchub

srchub Git Source Tree


Root/pluf/src/Pluf/AB/Views.php

<?php
/* -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
# ***** BEGIN LICENSE BLOCK *****
# This file is part of Plume Framework, a simple PHP Application Framework.
# Copyright (C) 2001-2010 Loic d'Anterroches and contributors.
#
# Plume Framework is free software; you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2.1 of the License, or
# (at your option) any later version.
#
# Plume Framework is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
#
# ***** END LICENSE BLOCK ***** */

Pluf::loadFunction('Pluf_Shortcuts_RenderToResponse');
Pluf::loadFunction('Pluf_HTTP_URL_urlForView');

/**
 * Manage and visualize the tests.
 *
 * It is possible to mark a test as inactive by picking a
 * winner.
 *
 * Check the urls.php file for the URL definition to integrate the
 * dashboard in your application/project.
 *
 * The permission used are:
 *
 * Pluf_AB.view-dashboard: The user can view the dasboard.
 * Pluf_AB.edit-test: The user can edit a test.
 *
 */
class Pluf_AB_Views
{
    /**
     * Display the currently running tests.
     *
     * The name of the view in the urls must be 'pluf_ab_dashboard'.
     */
    public $dasboard_precond = array(array('Pluf_Precondition::hasPerm',
                                           'Pluf_AB.view-dashboard'));
    public function dashboard($request, $match)
    {
        $url = Pluf_HTTP_URL_urlForView('pluf_ab_dashboard');
        $can_edit = $request->user->hasPerm('Pluf_AB.edit-test');
        if ($can_edit && $request->method == 'POST') {
            // We mark the winner.
            $form = new Pluf_AB_Form_MarkWinner($request->POST);
            if ($form->isValid()) {
                $form->save();
                $request->user->setMessage(__('The test has been updated.'));
                return new Pluf_HTTP_Response_Redirect($url);
            }
        } else {
            // To have it available for the control of the errors in
            // the template.
            $form = new Pluf_AB_Form_MarkWinner();
        }
        // Get the list of tests
        $db = Pluf_AB::getDb();
        $active = array();
        $stopped = array();
        foreach ($db->tests->find() as $test) {
            $test['stats'] = Pluf_AB::getTestStats($test);
            if ($test['active']) {
                $active[] = $test;
            } else {
                $stopped[] = $test;
            }
        }
        return Pluf_Shortcuts_RenderToResponse('pluf/ab/dashboard.html', 
                                               array('active' => $active,
                                                     'stopped' => $stopped,
                                                     'form' => $form,
                                                     'can_edit' => $can_edit,
                                                     ),
                                               $request);
    }

    /**
     * Display the list of funnels.
     *
     */
    public $funnels_precond = array(array('Pluf_Precondition::hasPerm',
                                           'Pluf_AB.view-funnels'));
    public function funnels($request, $match)
    {
        $url = Pluf_HTTP_URL_urlForView('pluf_ab_funnels');
        $funnels = Pluf_AB_Funnel::getFunnels();
        return Pluf_Shortcuts_RenderToResponse('pluf/ab/funnels.html', 
                                               array('funnels' => $funnels,
                                                     ),
                                               $request);
    }

    /**
     * Display a given funnel stats.
     *
     */
    public $funnel_precond = array(array('Pluf_Precondition::hasPerm',
                                         'Pluf_AB.view-funnels'));
    public function funnel($request, $match)
    {
        $periods = array('yesterday' => __('Yesterday'),
                         'today' => __('Today'),
                         '7days' => __('Last 7 days'),
                         'all' => __('All time'));
        $period = 'today';
        $nperiod = $periods[$period];
        if (isset($request->REQUEST['p']) 
            and isset($periods[$request->REQUEST['p']])) {
            $period = $request->REQUEST['p'];
            $nperiod = $periods[$request->REQUEST['p']];
        }
        $props = Pluf_AB_Funnel::getFunnelProps($match[1], $period);
        $prop = null;
        if (isset($request->REQUEST['prop']) and 
            in_array($request->REQUEST['prop'], array_keys($props))) {
            $prop = $request->REQUEST['prop'];
        }
        $stats = Pluf_AB_Funnel::getStats($match[1], $period, $prop);
        return Pluf_Shortcuts_RenderToResponse('pluf/ab/funnel.html', 
                                               array('stats' => $stats,
                                                     'funnel' => $match[1],
                                                     'nperiod' => $nperiod,
                                                     'period' => $period,
                                                     'props' => $props,
                                                     'prop' => $prop,
                                                     ),
                                               $request);
    }

    /**
     * A simple view to redirect a user and convert it.
     *
     * To convert the user for the test 'my_test' and redirect it to
     * the URL 'http://www.example.com' add the following view in your
     * urls.php:
     *
     * <pre>
     *  array('regex' => '#^/goto/example/$#',
     *         'base' => $base,
     *         'model' => 'Pluf_AB_Views',
     *         'method' => 'convRedirect',
     *         'name' => 'go_to_example',
     *         'params' => array('url' => 'http://www.example.com',
     *                           'test' => 'my_test')
     *         );
     * </pre>
     * 
     * Try to put a url which reflects the final url after redirection
     * to minimize the confusion for the user. In this example, in
     * your code or template you use the named url 'go_to_example'.
     *
     */
    public function convRedirect($request, $match, $p)
    {
        Pluf_AB::convert($p['test'], $request);        
        return new Pluf_HTTP_Response_Redirect($p['url']);
    }
}






Archive Download this file

Branches

Number of commits:
Page rendered in 0.11286s using 11 queries.