File: clicky.rst

package info (click to toggle)
python-django-analytical 3.2.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 720 kB
  • sloc: python: 4,693; makefile: 7
file content (155 lines) | stat: -rw-r--r-- 5,840 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
==========================
Clicky -- traffic analysis
==========================

Clicky_ is an online web analytics tool.  It is similar to Google
Analytics in that it provides statistics on who is visiting your website
and what they are doing.  Clicky provides its data in real time and is
designed to be very easy to use.

.. _Clicky: http://getclicky.com/


.. clicky-installation:

Installation
============

To start using the Clicky integration, you must have installed the
django-analytical package and have added the ``analytical`` application
to :const:`INSTALLED_APPS` in your project :file:`settings.py` file.
See :doc:`../install` for details.

Next you need to add the Clicky template tag to your templates. This
step is only needed if you are not using the generic
:ttag:`analytical.*` tags.  If you are, skip to
:ref:`clicky-configuration`.

The Clicky tracking code is inserted into templates using a template
tag.  Load the :mod:`clicky` template tag library and insert the
:ttag:`clicky` tag.  Because every page that you want to track must
have the tag, it is useful to add it to your base template.  Insert
the tag at the bottom of the HTML body::

    {% load clicky %}
    ...
    {% clicky %}
    </body>
    </html>


.. _clicky-configuration:

Configuration
=============

Before you can use the Clicky integration, you must first set your
website Site ID.  You can also customize the data that Clicky tracks.


.. _clicky-site-id:

Setting the Site ID
-------------------

Every website you track with Clicky gets its own Site ID, and the
:ttag:`clicky` tag will include it in the rendered Javascript code.
You can find the Site ID in the *Info* tab of the website *Preferences*
page, in your Clicky account.  Set :const:`CLICKY_SITE_ID` in the
project :file:`settings.py` file::

    CLICKY_SITE_ID = 'XXXXXXXX'

If you do not set a Site ID, the tracking code will not be rendered.


.. _clicky-internal-ips:

Internal IP addresses
---------------------

Usually you do not want to track clicks from your development or
internal IP addresses.  By default, if the tags detect that the client
comes from any address in the :const:`CLICKY_INTERNAL_IPS` setting,
the tracking code is commented out.  It takes the value of
:const:`ANALYTICAL_INTERNAL_IPS` by default (which in turn is
:const:`INTERNAL_IPS` by default).  See :ref:`identifying-visitors` for
important information about detecting the visitor IP address.


.. _clicky-custom-data:

Custom data
-----------

As described in the Clicky `customized tracking`_ documentation page,
the data that is tracked by Clicky can be customized by setting the
:data:`clicky_custom` Javascript variable before loading the tracking
code.  Using template context variables, you can let the :ttag:`clicky`
tag pass custom data to Clicky automatically.  You can set the context
variables in your view when you render a template containing the
tracking code::

    context = RequestContext({'clicky_title': 'A better page title'})
    return some_template.render(context)

It is annoying to do this for every view, so you may want to set custom
properties in a context processor that you add to the
:data:`TEMPLATE_CONTEXT_PROCESSORS` list in :file:`settings.py`::

    def clicky_global_properties(request):
        return {'clicky_timeout': 10}

Just remember that if you set the same context variable in the
:class:`~django.template.context.RequestContext` constructor and in a
context processor, the latter clobbers the former.

Here is a table with the most important variables.  All variables listed
on the `customized tracking`_ documentation page can be set by replacing
``clicky_custom.`` with ``clicky_``.

==================  ===============  ===================================
Context variable    Clicky property  Description
==================  ===============  ===================================
``clicky_session``  session_         Session data.  A dictionary
                                     containing ``username`` and/or
                                     ``group`` keys.
------------------  ---------------  -----------------------------------
``clicky_goal``     goal_            A succeeded goal.  A dictionary
                                     containing ``id`` and optionally
                                     ``revenue`` keys.
------------------  ---------------  -----------------------------------
``clicky_split``    split_           Split testing page version.  A
                                     dictionary containing ``name``,
                                     ``version`` and optionally ``goal``
                                     keys.
------------------  ---------------  -----------------------------------
``clicky_href``     href_            The URL as tracked by Clicky.
                                     Default is the page URL.
------------------  ---------------  -----------------------------------
``clicky_title``    title_           The page title as tracked by
                                     Clicky.  Default is the HTML title.
==================  ===============  ===================================

.. _`customized tracking`: http://getclicky.com/help/customization
.. _session: http://getclicky.com/help/customization#session
.. _goal: http://getclicky.com/help/customization#goal
.. _href: http://getclicky.com/help/customization#href
.. _title: http://getclicky.com/help/customization#title
.. _split: http://getclicky.com/help/customization#split


.. _clicky-identify-user:

Identifying authenticated users
-------------------------------

If you have not set the session_ property explicitly, the username of an
authenticated user is passed to Clicky automatically.  See
:ref:`identifying-visitors`.


----

Thanks go to Clicky for their support with the development of this
application.