global helper functions need to have grep-able names, i.e. a little bit longer
[myslice.git] / plugins / myplugin / static / js / myplugin.js
1 /**
2  * MyPlugin:    demonstration plugin
3  * Version:     0.1
4  * Description: Template for writing new plugins and illustrating the different
5  *              possibilities of the plugin API.
6  *              This file is part of the Manifold project 
7  * Requires:    js/plugin.js
8  * URL:         http://www.myslice.info
9  * Author:      Jordan AugĂ© <jordan.auge@lip6.fr>
10  * Copyright:   Copyright 2012-2013 UPMC Sorbonne UniversitĂ©s
11  * License:     GPLv3
12  */
13
14 (function($){
15
16     var MyPlugin = Plugin.extend({
17
18         /** XXX to check
19          * @brief Plugin constructor
20          * @param options : an associative array of setting values
21          * @param element : 
22          * @return : a jQuery collection of objects on which the plugin is
23          *     applied, which allows to maintain chainability of calls
24          */
25         init: function(options, element) {
26             // Call the parent constructor, see FAQ when forgotten
27             this._super(options, element);
28
29             /* Member variables */
30
31             /* Plugin events */
32
33             /* Setup query and record handlers */
34
35             // Explain this will allow query events to be handled
36             // What happens when we don't define some events ?
37             // Some can be less efficient
38             this.listen_query(options.query_uuid);
39             this.listen_query(options.query_uuid, 'all');
40
41             /* GUI setup and event binding */
42             // call function
43
44         },
45
46         /* PLUGIN EVENTS */
47         // on_show like in hazelnut
48
49
50         /* GUI EVENTS */
51
52         // a function to bind events here: click change
53         // how to raise manifold events
54
55
56         /* GUI MANIPULATION */
57
58         // We advise you to write function to change behaviour of the GUI
59         // Will use naming helpers to access content _inside_ the plugin
60         // always refer to these functions in the remaining of the code
61
62         show_hide_button: function() 
63         {
64             // this.id, this.el, this.cl, this.elts
65             // same output as a jquery selector with some guarantees
66         },
67
68         /* TEMPLATES */
69
70         // see in the html template
71         // How to load a template, use of mustache
72
73         /* QUERY HANDLERS */
74
75         // How to make sure the plugin is not desynchronized
76         // He should manifest its interest in filters, fields or records
77         // functions triggered only if the proper listen is done
78
79         // no prefix
80
81         on_filter_added: function(filter)
82         {
83
84         },
85
86         // ... be sure to list all events here
87
88         /* RECORD HANDLERS */
89         
90         on_record_received: function(record)
91         {
92             //
93         },
94
95         /* INTERNAL FUNCTIONS */
96         _dummy: function() {
97             // only convention, not strictly enforced at the moment
98         },
99
100     });
101
102     /* Plugin registration */
103     $.plugin('MyPlugin', MyPlugin);
104
105     // TODO Here use cases for instanciating plugins in different ways like in the pastie.
106
107 })(jQuery);