Dodanie MySQL-python do requirements.txt.
[redakcja.git] / apps / toolbar / models.py
1 from django.db import models
2 from django.utils.translation import ugettext_lazy as _
3
4
5 class ButtonGroup(models.Model):
6     name = models.CharField(max_length=32)
7     slug = models.SlugField()
8     position = models.IntegerField(default=0)
9     
10     class Meta:
11         ordering = ('position', 'name',)
12         verbose_name, verbose_name_plural = _('button group'), _('button groups')
13     
14     def __unicode__(self):
15         return self.name
16
17     def to_dict(self, with_buttons=False):
18         d = {'name': self.name, 'position': self.position}
19
20         if with_buttons:
21             d['buttons'] = [ b.to_dict() for b in self.button_set.all() ]
22
23         return d
24
25 #class ButtonGroupManager(models.Manager):
26 #
27 #    def with_buttons(self):
28 #        from django.db import connection
29 #        cursor = connection.cursor()
30 #        cursor.execute("""
31 #            SELECT g.name, g.slug, CONCAT(b.slug),
32 #            FROM toolbar_buttongroup as g LEFT JOIN toolbar_button as b
33 #
34 #            WHERE p.id = r.poll_id
35 #            GROUP BY 1, 2, 3
36 #            ORDER BY 3 DESC""")
37 #        result_list = []
38 #        for row in cursor.fetchall():
39 #            p = self.model(id=row[0], question=row[1], poll_date=row[2])
40 #            p.num_responses = row[3]
41 #            result_list.append(p)
42 #        return result_list
43
44 class Button(models.Model):
45     label = models.CharField(max_length=32)
46     slug = models.SlugField(unique=True) #unused
47
48     # behaviour
49     params = models.TextField(default='[]') # TODO: should be a JSON field
50     scriptlet = models.ForeignKey('Scriptlet', null=True, blank=True)
51     link = models.CharField(max_length=256, blank=True, default='')
52
53     # ui related stuff
54     key = models.CharField(blank=True, max_length=1)
55     key_mod = models.PositiveIntegerField(blank=True, default=1)
56     tooltip = models.CharField(blank=True, max_length=120)
57
58     # Why the button is restricted to have the same position in each group ?
59     # position = models.IntegerField(default=0)   
60     group = models.ManyToManyField(ButtonGroup)
61     
62     class Meta:
63         ordering = ('slug',)
64         verbose_name, verbose_name_plural = _('button'), _('buttons')
65
66     def hotkey_code(self):
67         return ord(self.key.upper()) | (self.key_mod << 8)
68
69     def hotkey_name(self):
70         if not self.key:
71             return ''
72
73         mods = []
74         if self.key_mod & 0x01: mods.append('Alt')
75         if self.key_mod & 0x02: mods.append('Ctrl')
76         if self.key_mod & 0x04: mods.append('Shift')
77         mods.append(str(self.key))
78         return '[' + '+'.join(mods) + ']'
79
80     def to_dict(self):
81         return {
82             'label': self.label,
83             'tooltip': (self.tooltip or '') + self.hotkey_name(),
84             'key': self.key,
85             'key_mod': self.key_mod,
86             'params': self.params,
87             'scriptlet_id': self.scriptlet_id
88         }
89     
90     def __unicode__(self):
91         return self.label
92
93 class Scriptlet(models.Model):
94     name = models.CharField(max_length=64, primary_key=True)
95     code = models.TextField()
96
97     # TODO: add this later and remap code property to this
98     # code_min = models.TextField()
99
100     def __unicode__(self):
101         return _(u'javascript')+u':'+self.name