Merge branch 'master' of stigma.nowoczesnapolska.org.pl:platforma
[redakcja.git] / apps / toolbar / models.py
index ae101e0..8d123fd 100644 (file)
@@ -19,11 +19,13 @@ class Button(models.Model):
     slug = models.SlugField(unique=True) #unused
 
     # behaviour
     slug = models.SlugField(unique=True) #unused
 
     # behaviour
-    params = models.TextField() # TODO: should be a JSON field
-    scriptlet = models.ForeignKey('Scriptlet')
+    params = models.TextField(default='[]') # TODO: should be a JSON field
+    scriptlet = models.ForeignKey('Scriptlet', null=True, blank=True)
+    link = models.CharField(max_length=256, blank=True, default='')
 
     # ui related stuff
     key = models.CharField(blank=True, max_length=1)
 
     # ui related stuff
     key = models.CharField(blank=True, max_length=1)
+    key_mod = models.PositiveIntegerField(blank=True, default=1)
     tooltip = models.CharField(blank=True, max_length=120)
 
     # Why the button is restricted to have the same position in each group ?
     tooltip = models.CharField(blank=True, max_length=120)
 
     # Why the button is restricted to have the same position in each group ?
@@ -33,6 +35,20 @@ class Button(models.Model):
     class Meta:
         ordering = ('label',)
         verbose_name, verbose_name_plural = _('button'), _('buttons')
     class Meta:
         ordering = ('label',)
         verbose_name, verbose_name_plural = _('button'), _('buttons')
+
+    def hotkey_code(self):
+        return ord(self.key.upper()) | (self.key_mod << 8)
+
+    def hotkey_name(self):
+        if not self.key:
+            return ''
+
+        mods = []
+        if self.key_mod & 0x01: mods.append('Alt')
+        if self.key_mod & 0x02: mods.append('Ctrl')
+        if self.key_mod & 0x04: mods.append('Shift')
+        mods.append('"'+self.key+'"')
+        return '+'.join(mods)
     
     def __unicode__(self):
         return self.label
     
     def __unicode__(self):
         return self.label