Add nice whole file support
							
								
								
									
										19
									
								
								accounting/migrations/0017_auto_20160810_0547.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,19 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
| from __future__ import unicode_literals | ||||
|  | ||||
| from django.db import migrations, models | ||||
|  | ||||
|  | ||||
| class Migration(migrations.Migration): | ||||
|  | ||||
|     dependencies = [ | ||||
|         ('accounting', '0016_auto_20160807_2000'), | ||||
|     ] | ||||
|  | ||||
|     operations = [ | ||||
|         migrations.AlterField( | ||||
|             model_name='operation', | ||||
|             name='invoice', | ||||
|             field=models.ForeignKey(blank=True, related_name='operations', to='core.SithFile', null=True, verbose_name='invoice'), | ||||
|         ), | ||||
|     ] | ||||
| @@ -7,7 +7,7 @@ from django.utils.translation import ugettext_lazy as _ | ||||
| from django.template import defaultfilters | ||||
|  | ||||
| from decimal import Decimal | ||||
| from core.models import User | ||||
| from core.models import User, SithFile | ||||
| from club.models import Club | ||||
|  | ||||
| class CurrencyField(models.DecimalField): | ||||
| @@ -156,7 +156,7 @@ class Operation(models.Model): | ||||
|     remark = models.TextField(_('remark'), max_length=255) | ||||
|     mode = models.CharField(_('payment method'), max_length=255, choices=settings.SITH_ACCOUNTING_PAYMENT_METHOD) | ||||
|     cheque_number = models.IntegerField(_('cheque number'), default=-1) | ||||
|     invoice = models.FileField(upload_to='invoices', verbose_name=_("invoice"), null=True, blank=True) | ||||
|     invoice = models.ForeignKey(SithFile, related_name='operations', verbose_name=_("invoice"), null=True, blank=True) | ||||
|     done = models.BooleanField(_('is done'), default=False) | ||||
|     accounting_type = models.ForeignKey('AccountingType', related_name="operations", verbose_name=_("accounting type")) | ||||
|     target_type = models.CharField(_('target type'), max_length=10, | ||||
|   | ||||
| @@ -27,6 +27,7 @@ | ||||
|             <td>{% trans %}Nature{% endtrans %}</td> | ||||
|             <td>{% trans %}Done{% endtrans %}</td> | ||||
|             <td>{% trans %}Comment{% endtrans %}</td> | ||||
|             <td>{% trans %}File{% endtrans %}</td> | ||||
|             <td>{% trans %}Actions{% endtrans %}</td> | ||||
|         </tr> | ||||
|         </thead> | ||||
| @@ -51,6 +52,11 @@ | ||||
|             <td>{% trans %}No{% endtrans %}</td> | ||||
|             {% endif %} | ||||
|             <td>{{ o.remark }}</td> | ||||
|             {% if o.invoice %} | ||||
|             <td><a href="{{ url('core:download') + '?file=' + o.invoice.name }}">{{ o.invoice.name }}</a></td> | ||||
|             {% else %} | ||||
|             <td>-</td> | ||||
|             {% endif %} | ||||
|             <td> | ||||
|                 {% if not o.journal.closed %} | ||||
|                 <a href="{{ url('accounting:op_edit', op_id=o.id) }}">{% trans %}Edit{% endtrans %}</a> | ||||
|   | ||||
| @@ -4,8 +4,10 @@ from django.shortcuts import render | ||||
| from django.core.urlresolvers import reverse_lazy | ||||
| from django.forms.models import modelform_factory | ||||
| from django.forms import HiddenInput | ||||
| from django.forms.extras.widgets import SelectDateWidget | ||||
|  | ||||
| from core.views import CanViewMixin, CanEditMixin, CanEditPropMixin, CanCreateMixin | ||||
| from core.views.forms import SelectFile | ||||
| from accounting.models import BankAccount, ClubAccount, GeneralJournal, Operation, AccountingType, Company | ||||
|  | ||||
| # Accounting types | ||||
| @@ -166,7 +168,7 @@ class OperationCreateView(CanCreateMixin, CreateView): | ||||
|     form_class = modelform_factory(Operation, | ||||
|             fields=['amount', 'label', 'remark', 'journal', 'target_type', 'target_id', 'target_label', 'date', 'mode', | ||||
|                 'cheque_number', 'invoice', 'accounting_type', 'done'], | ||||
|             widgets={'journal': HiddenInput}) | ||||
|             widgets={'journal': HiddenInput, 'date': SelectDateWidget}) | ||||
|     template_name = 'core/create.jinja' | ||||
|  | ||||
|     def get_initial(self): | ||||
| @@ -183,8 +185,10 @@ class OperationEditView(CanEditMixin, UpdateView): | ||||
|     """ | ||||
|     model = Operation | ||||
|     pk_url_kwarg = "op_id" | ||||
|     fields = ['amount', 'label', 'remark', 'target_type', 'target_id', 'target_label', 'date', 'mode', 'cheque_number', | ||||
|             'invoice', 'accounting_type', 'done'] | ||||
|     form_class = modelform_factory(Operation, | ||||
|             fields = ['amount', 'label', 'remark', 'target_type', 'target_id', 'target_label', 'date', 'mode', 'cheque_number', | ||||
|                     'invoice', 'accounting_type', 'done'], | ||||
|             widgets={'date': SelectDateWidget, 'invoice': SelectFile}) | ||||
|     template_name = 'core/edit.jinja' | ||||
|  | ||||
| # Company views | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| from django.contrib import admin | ||||
| from core.models import User, Page, RealGroup | ||||
| from core.models import User, Page, RealGroup, SithFile | ||||
| from django.contrib.auth.models import Group as AuthGroup | ||||
|  | ||||
|  | ||||
| @@ -7,4 +7,5 @@ admin.site.register(User) | ||||
| admin.site.unregister(AuthGroup) | ||||
| admin.site.register(RealGroup) | ||||
| admin.site.register(Page) | ||||
| admin.site.register(SithFile) | ||||
|  | ||||
|   | ||||
							
								
								
									
										56
									
								
								core/migrations/0009_auto_20160810_0547.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,56 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
| from __future__ import unicode_literals | ||||
|  | ||||
| from django.db import migrations, models | ||||
| import django.db.models.deletion | ||||
| import core.models | ||||
| from django.conf import settings | ||||
|  | ||||
|  | ||||
| class Migration(migrations.Migration): | ||||
|  | ||||
|     dependencies = [ | ||||
|         ('core', '0008_pagerev_revision'), | ||||
|     ] | ||||
|  | ||||
|     operations = [ | ||||
|         migrations.CreateModel( | ||||
|             name='SithFile', | ||||
|             fields=[ | ||||
|                 ('id', models.AutoField(serialize=False, verbose_name='ID', auto_created=True, primary_key=True)), | ||||
|                 ('name', models.CharField(max_length=30, verbose_name='file name')), | ||||
|                 ('file', models.FileField(upload_to=core.models.get_directory, blank=True, null=True, verbose_name='file')), | ||||
|                 ('is_folder', models.BooleanField(default=True, verbose_name='is folder')), | ||||
|                 ('mime_type', models.CharField(max_length=30, verbose_name='mime type')), | ||||
|                 ('size', models.IntegerField(default=0, verbose_name='size')), | ||||
|                 ('date', models.DateTimeField(auto_now=True, verbose_name='date')), | ||||
|                 ('edit_groups', models.ManyToManyField(to='core.Group', blank=True, verbose_name='edit group', related_name='editable_files')), | ||||
|                 ('owner', models.ForeignKey(related_name='owned_files', to=settings.AUTH_USER_MODEL, verbose_name='owner')), | ||||
|                 ('parent', models.ForeignKey(blank=True, related_name='children', to='core.SithFile', null=True, verbose_name='parent')), | ||||
|                 ('view_groups', models.ManyToManyField(to='core.Group', blank=True, verbose_name='view group', related_name='viewable_files')), | ||||
|             ], | ||||
|             options={ | ||||
|                 'verbose_name': 'file', | ||||
|             }, | ||||
|         ), | ||||
|         migrations.AlterField( | ||||
|             model_name='page', | ||||
|             name='edit_groups', | ||||
|             field=models.ManyToManyField(to='core.Group', blank=True, verbose_name='edit group', related_name='editable_page'), | ||||
|         ), | ||||
|         migrations.AlterField( | ||||
|             model_name='page', | ||||
|             name='owner_group', | ||||
|             field=models.ForeignKey(default=1, related_name='owned_page', to='core.Group', verbose_name='owner group'), | ||||
|         ), | ||||
|         migrations.AlterField( | ||||
|             model_name='page', | ||||
|             name='parent', | ||||
|             field=models.ForeignKey(on_delete=django.db.models.deletion.SET_NULL, blank=True, related_name='children', to='core.Page', null=True, verbose_name='parent'), | ||||
|         ), | ||||
|         migrations.AlterField( | ||||
|             model_name='page', | ||||
|             name='view_groups', | ||||
|             field=models.ManyToManyField(to='core.Group', blank=True, verbose_name='view group', related_name='viewable_page'), | ||||
|         ), | ||||
|     ] | ||||
							
								
								
									
										111
									
								
								core/models.py
									
									
									
									
									
								
							
							
						
						| @@ -287,6 +287,108 @@ class Preferences(models.Model): | ||||
|         help_text=_('Show your account statistics to others'), | ||||
|     ) | ||||
|  | ||||
| def get_directory(instance, filename): | ||||
|     return './{0}/{1}'.format(instance.get_parent_path(), filename) | ||||
|  | ||||
| class SithFile(models.Model): | ||||
|     name = models.CharField(_('file name'), max_length=30, blank=False) | ||||
|     parent = models.ForeignKey('self', related_name="children", verbose_name=_("parent"), null=True, blank=True) | ||||
|     file = models.FileField(upload_to=get_directory, verbose_name=_("file"), null=True, blank=True) | ||||
|     owner = models.ForeignKey(User, related_name="owned_files", verbose_name=_("owner")) | ||||
|     edit_groups = models.ManyToManyField(Group, related_name="editable_files", verbose_name=_("edit group"), blank=True) | ||||
|     view_groups = models.ManyToManyField(Group, related_name="viewable_files", verbose_name=_("view group"), blank=True) | ||||
|     is_folder = models.BooleanField(_("is folder"), default=True) | ||||
|     mime_type = models.CharField(_('mime type'), max_length=30) | ||||
|     size = models.IntegerField(_("size"), default=0) | ||||
|     date = models.DateTimeField(_('date'), auto_now=True) | ||||
|  | ||||
|     class Meta: | ||||
|         verbose_name = _("file") | ||||
|  | ||||
|     def is_owned_by(self, user): | ||||
|         return user.id == self.owner.id | ||||
|  | ||||
|     def delete(self): | ||||
|         for c in self.children.all(): | ||||
|             c.delete() | ||||
|         self.file.delete() | ||||
|         return super(SithFile, self).delete() | ||||
|  | ||||
|     def clean(self): | ||||
|         """ | ||||
|         Cleans up the file | ||||
|         """ | ||||
|         super(SithFile, self).clean() | ||||
|         if '/' in self.name: | ||||
|             raise ValidationError(_("Character '/' not authorized in name")) | ||||
|         if self == self.parent: | ||||
|             raise ValidationError( | ||||
|                 _('Loop in folder tree'), | ||||
|                 code='loop', | ||||
|             ) | ||||
|         if (self == self.parent or (self.parent is not None and self in self.get_parent_list())): | ||||
|             raise ValidationError( | ||||
|                 _('Loop in folder tree'), | ||||
|                 code='loop', | ||||
|             ) | ||||
|         if self.parent and self.parent.is_file: | ||||
|             raise ValidationError(_('You can not make a file be a children of a non folder file')) | ||||
|         if ((self.parent is None and SithFile.objects.exclude(id=self.id).filter(parent=None, name=self.name).exists()) or | ||||
|                 (self.parent and self.parent.children.exclude(id=self.id).filter(name=self.name).exists())): | ||||
|             raise ValidationError( | ||||
|                 _('Duplicate file'), | ||||
|                 code='duplicate', | ||||
|             ) | ||||
|         if self.is_folder: | ||||
|             try: | ||||
|                 self.file.delete() | ||||
|             except: pass | ||||
|             self.file = None | ||||
|             self.mime_type = "inode/directory" | ||||
|         if self.is_file and (self.file is None or self.file == ""): | ||||
|             raise ValidationError(_("You must provide a file")) | ||||
|  | ||||
|     def save(self, *args, **kwargs): | ||||
|         copy_rights = False | ||||
|         if self.id is None: | ||||
|             copy_rights = True | ||||
|         super(SithFile, self).save(*args, **kwargs) | ||||
|         if copy_rights: | ||||
|             self.copy_rights() | ||||
|  | ||||
|     def copy_rights(self): | ||||
|         """Copy, if possible, the rights of the parent folder""" | ||||
|         if self.parent is not None: | ||||
|             self.edit_groups = self.parent.edit_groups.all() | ||||
|             self.view_groups = self.parent.view_groups.all() | ||||
|             self.save() | ||||
|  | ||||
|     def __getattribute__(self, attr): | ||||
|         if attr == "is_file": | ||||
|             return not self.is_folder | ||||
|         else: | ||||
|             return object.__getattribute__(self, attr) | ||||
|  | ||||
|     def __str__(self): | ||||
|         if self.is_folder: | ||||
|             return _("Folder: ") + self.name | ||||
|         else: | ||||
|             return _("File: ") + self.name | ||||
|  | ||||
|     def get_parent_list(self): | ||||
|         l = [] | ||||
|         p = self.parent | ||||
|         while p is not None: | ||||
|             l.append(p) | ||||
|             p = p.parent | ||||
|         return l | ||||
|  | ||||
|     def get_parent_path(self): | ||||
|         return '/'.join([p.name for p in self.get_parent_list()]) | ||||
|  | ||||
|     def get_display_name(self): | ||||
|         return self.name | ||||
|  | ||||
| class LockError(Exception): | ||||
|     """There was a lock error on the object""" | ||||
|     pass | ||||
| @@ -311,17 +413,16 @@ class Page(models.Model): | ||||
|     query, but don't rely on it when playing with a Page object, use get_full_name() instead! | ||||
|     """ | ||||
|     name = models.CharField(_('page name'), max_length=30, blank=False) | ||||
|     parent = models.ForeignKey('self', related_name="children", null=True, blank=True, on_delete=models.SET_NULL) | ||||
|     parent = models.ForeignKey('self', related_name="children", verbose_name=_("parent"), null=True, blank=True, on_delete=models.SET_NULL) | ||||
|     # Attention: this field may not be valid until you call save(). It's made for fast query, but don't rely on it when | ||||
|     # playing with a Page object, use get_full_name() instead! | ||||
|     _full_name = models.CharField(_('page name'), max_length=255, blank=True) | ||||
|     owner_group = models.ForeignKey(Group, related_name="owned_page", | ||||
|     owner_group = models.ForeignKey(Group, related_name="owned_page", verbose_name=_("owner group"), | ||||
|                                     default=settings.SITH_GROUPS['root']['id']) | ||||
|     edit_groups = models.ManyToManyField(Group, related_name="editable_page", blank=True) | ||||
|     view_groups = models.ManyToManyField(Group, related_name="viewable_page", blank=True) | ||||
|     edit_groups = models.ManyToManyField(Group, related_name="editable_page", verbose_name=_("edit group"), blank=True) | ||||
|     view_groups = models.ManyToManyField(Group, related_name="viewable_page", verbose_name=_("view group"), blank=True) | ||||
|     lock_mutex = {} | ||||
|  | ||||
|  | ||||
|     class Meta: | ||||
|         unique_together = ('name', 'parent') | ||||
|         permissions = ( | ||||
|   | ||||
| @@ -8,9 +8,9 @@ select, | ||||
| button, | ||||
| textarea | ||||
| { | ||||
|     margin: 0; | ||||
|     border: 1px solid; | ||||
|     padding: 4px; | ||||
|     margin: 1px; | ||||
|     border: none; | ||||
|     padding: 1px; | ||||
|     display: inline-block; | ||||
|     vertical-align: middle; | ||||
|     white-space: normal; | ||||
|   | ||||
							
								
								
									
										4
									
								
								core/static/core/js/jquery-3.1.0.min.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										782
									
								
								core/static/core/js/multiple-select.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,782 @@ | ||||
| /** | ||||
|  * @author zhixin wen <wenzhixin2010@gmail.com> | ||||
|  * @version 1.2.1 | ||||
|  * | ||||
|  * http://wenzhixin.net.cn/p/multiple-select/ | ||||
|  */ | ||||
|  | ||||
| (function ($) { | ||||
|  | ||||
|     'use strict'; | ||||
|  | ||||
|     // it only does '%s', and return '' when arguments are undefined | ||||
|     var sprintf = function (str) { | ||||
|         var args = arguments, | ||||
|             flag = true, | ||||
|             i = 1; | ||||
|  | ||||
|         str = str.replace(/%s/g, function () { | ||||
|             var arg = args[i++]; | ||||
|  | ||||
|             if (typeof arg === 'undefined') { | ||||
|                 flag = false; | ||||
|                 return ''; | ||||
|             } | ||||
|             return arg; | ||||
|         }); | ||||
|         return flag ? str : ''; | ||||
|     }; | ||||
|  | ||||
|     var removeDiacritics = function (str) { | ||||
|         var defaultDiacriticsRemovalMap = [ | ||||
|             {'base':'A', 'letters':/[\u0041\u24B6\uFF21\u00C0\u00C1\u00C2\u1EA6\u1EA4\u1EAA\u1EA8\u00C3\u0100\u0102\u1EB0\u1EAE\u1EB4\u1EB2\u0226\u01E0\u00C4\u01DE\u1EA2\u00C5\u01FA\u01CD\u0200\u0202\u1EA0\u1EAC\u1EB6\u1E00\u0104\u023A\u2C6F]/g}, | ||||
|             {'base':'AA','letters':/[\uA732]/g}, | ||||
|             {'base':'AE','letters':/[\u00C6\u01FC\u01E2]/g}, | ||||
|             {'base':'AO','letters':/[\uA734]/g}, | ||||
|             {'base':'AU','letters':/[\uA736]/g}, | ||||
|             {'base':'AV','letters':/[\uA738\uA73A]/g}, | ||||
|             {'base':'AY','letters':/[\uA73C]/g}, | ||||
|             {'base':'B', 'letters':/[\u0042\u24B7\uFF22\u1E02\u1E04\u1E06\u0243\u0182\u0181]/g}, | ||||
|             {'base':'C', 'letters':/[\u0043\u24B8\uFF23\u0106\u0108\u010A\u010C\u00C7\u1E08\u0187\u023B\uA73E]/g}, | ||||
|             {'base':'D', 'letters':/[\u0044\u24B9\uFF24\u1E0A\u010E\u1E0C\u1E10\u1E12\u1E0E\u0110\u018B\u018A\u0189\uA779]/g}, | ||||
|             {'base':'DZ','letters':/[\u01F1\u01C4]/g}, | ||||
|             {'base':'Dz','letters':/[\u01F2\u01C5]/g}, | ||||
|             {'base':'E', 'letters':/[\u0045\u24BA\uFF25\u00C8\u00C9\u00CA\u1EC0\u1EBE\u1EC4\u1EC2\u1EBC\u0112\u1E14\u1E16\u0114\u0116\u00CB\u1EBA\u011A\u0204\u0206\u1EB8\u1EC6\u0228\u1E1C\u0118\u1E18\u1E1A\u0190\u018E]/g}, | ||||
|             {'base':'F', 'letters':/[\u0046\u24BB\uFF26\u1E1E\u0191\uA77B]/g}, | ||||
|             {'base':'G', 'letters':/[\u0047\u24BC\uFF27\u01F4\u011C\u1E20\u011E\u0120\u01E6\u0122\u01E4\u0193\uA7A0\uA77D\uA77E]/g}, | ||||
|             {'base':'H', 'letters':/[\u0048\u24BD\uFF28\u0124\u1E22\u1E26\u021E\u1E24\u1E28\u1E2A\u0126\u2C67\u2C75\uA78D]/g}, | ||||
|             {'base':'I', 'letters':/[\u0049\u24BE\uFF29\u00CC\u00CD\u00CE\u0128\u012A\u012C\u0130\u00CF\u1E2E\u1EC8\u01CF\u0208\u020A\u1ECA\u012E\u1E2C\u0197]/g}, | ||||
|             {'base':'J', 'letters':/[\u004A\u24BF\uFF2A\u0134\u0248]/g}, | ||||
|             {'base':'K', 'letters':/[\u004B\u24C0\uFF2B\u1E30\u01E8\u1E32\u0136\u1E34\u0198\u2C69\uA740\uA742\uA744\uA7A2]/g}, | ||||
|             {'base':'L', 'letters':/[\u004C\u24C1\uFF2C\u013F\u0139\u013D\u1E36\u1E38\u013B\u1E3C\u1E3A\u0141\u023D\u2C62\u2C60\uA748\uA746\uA780]/g}, | ||||
|             {'base':'LJ','letters':/[\u01C7]/g}, | ||||
|             {'base':'Lj','letters':/[\u01C8]/g}, | ||||
|             {'base':'M', 'letters':/[\u004D\u24C2\uFF2D\u1E3E\u1E40\u1E42\u2C6E\u019C]/g}, | ||||
|             {'base':'N', 'letters':/[\u004E\u24C3\uFF2E\u01F8\u0143\u00D1\u1E44\u0147\u1E46\u0145\u1E4A\u1E48\u0220\u019D\uA790\uA7A4]/g}, | ||||
|             {'base':'NJ','letters':/[\u01CA]/g}, | ||||
|             {'base':'Nj','letters':/[\u01CB]/g}, | ||||
|             {'base':'O', 'letters':/[\u004F\u24C4\uFF2F\u00D2\u00D3\u00D4\u1ED2\u1ED0\u1ED6\u1ED4\u00D5\u1E4C\u022C\u1E4E\u014C\u1E50\u1E52\u014E\u022E\u0230\u00D6\u022A\u1ECE\u0150\u01D1\u020C\u020E\u01A0\u1EDC\u1EDA\u1EE0\u1EDE\u1EE2\u1ECC\u1ED8\u01EA\u01EC\u00D8\u01FE\u0186\u019F\uA74A\uA74C]/g}, | ||||
|             {'base':'OI','letters':/[\u01A2]/g}, | ||||
|             {'base':'OO','letters':/[\uA74E]/g}, | ||||
|             {'base':'OU','letters':/[\u0222]/g}, | ||||
|             {'base':'P', 'letters':/[\u0050\u24C5\uFF30\u1E54\u1E56\u01A4\u2C63\uA750\uA752\uA754]/g}, | ||||
|             {'base':'Q', 'letters':/[\u0051\u24C6\uFF31\uA756\uA758\u024A]/g}, | ||||
|             {'base':'R', 'letters':/[\u0052\u24C7\uFF32\u0154\u1E58\u0158\u0210\u0212\u1E5A\u1E5C\u0156\u1E5E\u024C\u2C64\uA75A\uA7A6\uA782]/g}, | ||||
|             {'base':'S', 'letters':/[\u0053\u24C8\uFF33\u1E9E\u015A\u1E64\u015C\u1E60\u0160\u1E66\u1E62\u1E68\u0218\u015E\u2C7E\uA7A8\uA784]/g}, | ||||
|             {'base':'T', 'letters':/[\u0054\u24C9\uFF34\u1E6A\u0164\u1E6C\u021A\u0162\u1E70\u1E6E\u0166\u01AC\u01AE\u023E\uA786]/g}, | ||||
|             {'base':'TZ','letters':/[\uA728]/g}, | ||||
|             {'base':'U', 'letters':/[\u0055\u24CA\uFF35\u00D9\u00DA\u00DB\u0168\u1E78\u016A\u1E7A\u016C\u00DC\u01DB\u01D7\u01D5\u01D9\u1EE6\u016E\u0170\u01D3\u0214\u0216\u01AF\u1EEA\u1EE8\u1EEE\u1EEC\u1EF0\u1EE4\u1E72\u0172\u1E76\u1E74\u0244]/g}, | ||||
|             {'base':'V', 'letters':/[\u0056\u24CB\uFF36\u1E7C\u1E7E\u01B2\uA75E\u0245]/g}, | ||||
|             {'base':'VY','letters':/[\uA760]/g}, | ||||
|             {'base':'W', 'letters':/[\u0057\u24CC\uFF37\u1E80\u1E82\u0174\u1E86\u1E84\u1E88\u2C72]/g}, | ||||
|             {'base':'X', 'letters':/[\u0058\u24CD\uFF38\u1E8A\u1E8C]/g}, | ||||
|             {'base':'Y', 'letters':/[\u0059\u24CE\uFF39\u1EF2\u00DD\u0176\u1EF8\u0232\u1E8E\u0178\u1EF6\u1EF4\u01B3\u024E\u1EFE]/g}, | ||||
|             {'base':'Z', 'letters':/[\u005A\u24CF\uFF3A\u0179\u1E90\u017B\u017D\u1E92\u1E94\u01B5\u0224\u2C7F\u2C6B\uA762]/g}, | ||||
|             {'base':'a', 'letters':/[\u0061\u24D0\uFF41\u1E9A\u00E0\u00E1\u00E2\u1EA7\u1EA5\u1EAB\u1EA9\u00E3\u0101\u0103\u1EB1\u1EAF\u1EB5\u1EB3\u0227\u01E1\u00E4\u01DF\u1EA3\u00E5\u01FB\u01CE\u0201\u0203\u1EA1\u1EAD\u1EB7\u1E01\u0105\u2C65\u0250]/g}, | ||||
|             {'base':'aa','letters':/[\uA733]/g}, | ||||
|             {'base':'ae','letters':/[\u00E6\u01FD\u01E3]/g}, | ||||
|             {'base':'ao','letters':/[\uA735]/g}, | ||||
|             {'base':'au','letters':/[\uA737]/g}, | ||||
|             {'base':'av','letters':/[\uA739\uA73B]/g}, | ||||
|             {'base':'ay','letters':/[\uA73D]/g}, | ||||
|             {'base':'b', 'letters':/[\u0062\u24D1\uFF42\u1E03\u1E05\u1E07\u0180\u0183\u0253]/g}, | ||||
|             {'base':'c', 'letters':/[\u0063\u24D2\uFF43\u0107\u0109\u010B\u010D\u00E7\u1E09\u0188\u023C\uA73F\u2184]/g}, | ||||
|             {'base':'d', 'letters':/[\u0064\u24D3\uFF44\u1E0B\u010F\u1E0D\u1E11\u1E13\u1E0F\u0111\u018C\u0256\u0257\uA77A]/g}, | ||||
|             {'base':'dz','letters':/[\u01F3\u01C6]/g}, | ||||
|             {'base':'e', 'letters':/[\u0065\u24D4\uFF45\u00E8\u00E9\u00EA\u1EC1\u1EBF\u1EC5\u1EC3\u1EBD\u0113\u1E15\u1E17\u0115\u0117\u00EB\u1EBB\u011B\u0205\u0207\u1EB9\u1EC7\u0229\u1E1D\u0119\u1E19\u1E1B\u0247\u025B\u01DD]/g}, | ||||
|             {'base':'f', 'letters':/[\u0066\u24D5\uFF46\u1E1F\u0192\uA77C]/g}, | ||||
|             {'base':'g', 'letters':/[\u0067\u24D6\uFF47\u01F5\u011D\u1E21\u011F\u0121\u01E7\u0123\u01E5\u0260\uA7A1\u1D79\uA77F]/g}, | ||||
|             {'base':'h', 'letters':/[\u0068\u24D7\uFF48\u0125\u1E23\u1E27\u021F\u1E25\u1E29\u1E2B\u1E96\u0127\u2C68\u2C76\u0265]/g}, | ||||
|             {'base':'hv','letters':/[\u0195]/g}, | ||||
|             {'base':'i', 'letters':/[\u0069\u24D8\uFF49\u00EC\u00ED\u00EE\u0129\u012B\u012D\u00EF\u1E2F\u1EC9\u01D0\u0209\u020B\u1ECB\u012F\u1E2D\u0268\u0131]/g}, | ||||
|             {'base':'j', 'letters':/[\u006A\u24D9\uFF4A\u0135\u01F0\u0249]/g}, | ||||
|             {'base':'k', 'letters':/[\u006B\u24DA\uFF4B\u1E31\u01E9\u1E33\u0137\u1E35\u0199\u2C6A\uA741\uA743\uA745\uA7A3]/g}, | ||||
|             {'base':'l', 'letters':/[\u006C\u24DB\uFF4C\u0140\u013A\u013E\u1E37\u1E39\u013C\u1E3D\u1E3B\u017F\u0142\u019A\u026B\u2C61\uA749\uA781\uA747]/g}, | ||||
|             {'base':'lj','letters':/[\u01C9]/g}, | ||||
|             {'base':'m', 'letters':/[\u006D\u24DC\uFF4D\u1E3F\u1E41\u1E43\u0271\u026F]/g}, | ||||
|             {'base':'n', 'letters':/[\u006E\u24DD\uFF4E\u01F9\u0144\u00F1\u1E45\u0148\u1E47\u0146\u1E4B\u1E49\u019E\u0272\u0149\uA791\uA7A5]/g}, | ||||
|             {'base':'nj','letters':/[\u01CC]/g}, | ||||
|             {'base':'o', 'letters':/[\u006F\u24DE\uFF4F\u00F2\u00F3\u00F4\u1ED3\u1ED1\u1ED7\u1ED5\u00F5\u1E4D\u022D\u1E4F\u014D\u1E51\u1E53\u014F\u022F\u0231\u00F6\u022B\u1ECF\u0151\u01D2\u020D\u020F\u01A1\u1EDD\u1EDB\u1EE1\u1EDF\u1EE3\u1ECD\u1ED9\u01EB\u01ED\u00F8\u01FF\u0254\uA74B\uA74D\u0275]/g}, | ||||
|             {'base':'oi','letters':/[\u01A3]/g}, | ||||
|             {'base':'ou','letters':/[\u0223]/g}, | ||||
|             {'base':'oo','letters':/[\uA74F]/g}, | ||||
|             {'base':'p','letters':/[\u0070\u24DF\uFF50\u1E55\u1E57\u01A5\u1D7D\uA751\uA753\uA755]/g}, | ||||
|             {'base':'q','letters':/[\u0071\u24E0\uFF51\u024B\uA757\uA759]/g}, | ||||
|             {'base':'r','letters':/[\u0072\u24E1\uFF52\u0155\u1E59\u0159\u0211\u0213\u1E5B\u1E5D\u0157\u1E5F\u024D\u027D\uA75B\uA7A7\uA783]/g}, | ||||
|             {'base':'s','letters':/[\u0073\u24E2\uFF53\u00DF\u015B\u1E65\u015D\u1E61\u0161\u1E67\u1E63\u1E69\u0219\u015F\u023F\uA7A9\uA785\u1E9B]/g}, | ||||
|             {'base':'t','letters':/[\u0074\u24E3\uFF54\u1E6B\u1E97\u0165\u1E6D\u021B\u0163\u1E71\u1E6F\u0167\u01AD\u0288\u2C66\uA787]/g}, | ||||
|             {'base':'tz','letters':/[\uA729]/g}, | ||||
|             {'base':'u','letters':/[\u0075\u24E4\uFF55\u00F9\u00FA\u00FB\u0169\u1E79\u016B\u1E7B\u016D\u00FC\u01DC\u01D8\u01D6\u01DA\u1EE7\u016F\u0171\u01D4\u0215\u0217\u01B0\u1EEB\u1EE9\u1EEF\u1EED\u1EF1\u1EE5\u1E73\u0173\u1E77\u1E75\u0289]/g}, | ||||
|             {'base':'v','letters':/[\u0076\u24E5\uFF56\u1E7D\u1E7F\u028B\uA75F\u028C]/g}, | ||||
|             {'base':'vy','letters':/[\uA761]/g}, | ||||
|             {'base':'w','letters':/[\u0077\u24E6\uFF57\u1E81\u1E83\u0175\u1E87\u1E85\u1E98\u1E89\u2C73]/g}, | ||||
|             {'base':'x','letters':/[\u0078\u24E7\uFF58\u1E8B\u1E8D]/g}, | ||||
|             {'base':'y','letters':/[\u0079\u24E8\uFF59\u1EF3\u00FD\u0177\u1EF9\u0233\u1E8F\u00FF\u1EF7\u1E99\u1EF5\u01B4\u024F\u1EFF]/g}, | ||||
|             {'base':'z','letters':/[\u007A\u24E9\uFF5A\u017A\u1E91\u017C\u017E\u1E93\u1E95\u01B6\u0225\u0240\u2C6C\uA763]/g} | ||||
|         ]; | ||||
|  | ||||
|         for (var i = 0; i < defaultDiacriticsRemovalMap.length; i++) { | ||||
|             str = str.replace(defaultDiacriticsRemovalMap[i].letters, defaultDiacriticsRemovalMap[i].base); | ||||
|         } | ||||
|  | ||||
|         return str; | ||||
|  | ||||
|    }; | ||||
|  | ||||
|     function MultipleSelect($el, options) { | ||||
|         var that = this, | ||||
|             name = $el.attr('name') || options.name || ''; | ||||
|  | ||||
|         this.options = options; | ||||
|  | ||||
|         // hide select element | ||||
|         this.$el = $el.hide(); | ||||
|  | ||||
|         // label element | ||||
|         this.$label = this.$el.closest('label'); | ||||
|         if (this.$label.length === 0 && this.$el.attr('id')) { | ||||
|             this.$label = $(sprintf('label[for="%s"]', this.$el.attr('id').replace(/:/g, '\\:'))); | ||||
|         } | ||||
|  | ||||
|         // restore class and title from select element | ||||
|         this.$parent = $(sprintf( | ||||
|             '<div class="ms-parent %s" %s/>', | ||||
|             $el.attr('class') || '', | ||||
|             sprintf('title="%s"', $el.attr('title')))); | ||||
|  | ||||
|         // add placeholder to choice button | ||||
|         this.$choice = $(sprintf([ | ||||
|                 '<button type="button" class="ms-choice">', | ||||
|                 '<span class="placeholder">%s</span>', | ||||
|                 '<div></div>', | ||||
|                 '</button>' | ||||
|             ].join(''), | ||||
|             this.options.placeholder)); | ||||
|  | ||||
|         // default position is bottom | ||||
|         this.$drop = $(sprintf('<div class="ms-drop %s"%s></div>', | ||||
|             this.options.position, | ||||
|             sprintf(' style="width: %s"', this.options.dropWidth))); | ||||
|  | ||||
|         this.$el.after(this.$parent); | ||||
|         this.$parent.append(this.$choice); | ||||
|         this.$parent.append(this.$drop); | ||||
|  | ||||
|         if (this.$el.prop('disabled')) { | ||||
|             this.$choice.addClass('disabled'); | ||||
|         } | ||||
|         this.$parent.css('width', | ||||
|             this.options.width || | ||||
|             this.$el.css('width') || | ||||
|             this.$el.outerWidth() + 20); | ||||
|  | ||||
|         this.selectAllName = 'data-name="selectAll' + name + '"'; | ||||
|         this.selectGroupName = 'data-name="selectGroup' + name + '"'; | ||||
|         this.selectItemName = 'data-name="selectItem' + name + '"'; | ||||
|  | ||||
|         if (!this.options.keepOpen) { | ||||
|             $(document).click(function (e) { | ||||
|                 if ($(e.target)[0] === that.$choice[0] || | ||||
|                     $(e.target).parents('.ms-choice')[0] === that.$choice[0]) { | ||||
|                     return; | ||||
|                 } | ||||
|                 if (($(e.target)[0] === that.$drop[0] || | ||||
|                     $(e.target).parents('.ms-drop')[0] !== that.$drop[0] && e.target !== $el[0]) && | ||||
|                     that.options.isOpen) { | ||||
|                     that.close(); | ||||
|                 } | ||||
|             }); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     MultipleSelect.prototype = { | ||||
|         constructor: MultipleSelect, | ||||
|  | ||||
|         init: function () { | ||||
|             var that = this, | ||||
|                 $ul = $('<ul></ul>'); | ||||
|  | ||||
|             this.$drop.html(''); | ||||
|  | ||||
|             if (this.options.filter) { | ||||
|                 this.$drop.append([ | ||||
|                     '<div class="ms-search">', | ||||
|                     '<input type="text" autocomplete="off" autocorrect="off" autocapitilize="off" spellcheck="false">', | ||||
|                     '</div>'].join('') | ||||
|                 ); | ||||
|             } | ||||
|  | ||||
|             if (this.options.selectAll && !this.options.single) { | ||||
|                 $ul.append([ | ||||
|                     '<li class="ms-select-all">', | ||||
|                     '<label>', | ||||
|                     sprintf('<input type="checkbox" %s /> ', this.selectAllName), | ||||
|                     this.options.selectAllDelimiter[0], | ||||
|                     this.options.selectAllText, | ||||
|                     this.options.selectAllDelimiter[1], | ||||
|                     '</label>', | ||||
|                     '</li>' | ||||
|                 ].join('')); | ||||
|             } | ||||
|  | ||||
|             $.each(this.$el.children(), function (i, elm) { | ||||
|                 $ul.append(that.optionToHtml(i, elm)); | ||||
|             }); | ||||
|             $ul.append(sprintf('<li class="ms-no-results">%s</li>', this.options.noMatchesFound)); | ||||
|             this.$drop.append($ul); | ||||
|  | ||||
|             this.$drop.find('ul').css('max-height', this.options.maxHeight + 'px'); | ||||
|             this.$drop.find('.multiple').css('width', this.options.multipleWidth + 'px'); | ||||
|  | ||||
|             this.$searchInput = this.$drop.find('.ms-search input'); | ||||
|             this.$selectAll = this.$drop.find('input[' + this.selectAllName + ']'); | ||||
|             this.$selectGroups = this.$drop.find('input[' + this.selectGroupName + ']'); | ||||
|             this.$selectItems = this.$drop.find('input[' + this.selectItemName + ']:enabled'); | ||||
|             this.$disableItems = this.$drop.find('input[' + this.selectItemName + ']:disabled'); | ||||
|             this.$noResults = this.$drop.find('.ms-no-results'); | ||||
|  | ||||
|             this.events(); | ||||
|             this.updateSelectAll(true); | ||||
|             this.update(true); | ||||
|  | ||||
|             if (this.options.isOpen) { | ||||
|                 this.open(); | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         optionToHtml: function (i, elm, group, groupDisabled) { | ||||
|             var that = this, | ||||
|                 $elm = $(elm), | ||||
|                 classes = $elm.attr('class') || '', | ||||
|                 title = sprintf('title="%s"', $elm.attr('title')), | ||||
|                 multiple = this.options.multiple ? 'multiple' : '', | ||||
|                 disabled, | ||||
|                 type = this.options.single ? 'radio' : 'checkbox'; | ||||
|  | ||||
|             if ($elm.is('option')) { | ||||
|                 var value = $elm.val(), | ||||
|                     text = that.options.textTemplate($elm), | ||||
|                     selected = $elm.prop('selected'), | ||||
|                     style = sprintf('style="%s"', this.options.styler(value)), | ||||
|                     $el; | ||||
|  | ||||
|                 disabled = groupDisabled || $elm.prop('disabled'); | ||||
|  | ||||
|                 $el = $([ | ||||
|                     sprintf('<li class="%s %s" %s %s>', multiple, classes, title, style), | ||||
|                     sprintf('<label class="%s">', disabled ? 'disabled' : ''), | ||||
|                     sprintf('<input type="%s" %s%s%s%s>', | ||||
|                         type, this.selectItemName, | ||||
|                         selected ? ' checked="checked"' : '', | ||||
|                         disabled ? ' disabled="disabled"' : '', | ||||
|                         sprintf(' data-group="%s"', group)), | ||||
|                     sprintf('<span>%s</span>', text), | ||||
|                     '</label>', | ||||
|                     '</li>' | ||||
|                 ].join('')); | ||||
|                 $el.find('input').val(value); | ||||
|                 return $el; | ||||
|             } | ||||
|             if ($elm.is('optgroup')) { | ||||
|                 var label = that.options.labelTemplate($elm), | ||||
|                     $group = $('<div/>'); | ||||
|  | ||||
|                 group = 'group_' + i; | ||||
|                 disabled = $elm.prop('disabled'); | ||||
|  | ||||
|                 $group.append([ | ||||
|                     '<li class="group">', | ||||
|                     sprintf('<label class="optgroup %s" data-group="%s">', disabled ? 'disabled' : '', group), | ||||
|                     this.options.hideOptgroupCheckboxes || this.options.single ? '' : | ||||
|                         sprintf('<input type="checkbox" %s %s>', | ||||
|                         this.selectGroupName, disabled ? 'disabled="disabled"' : ''), | ||||
|                     label, | ||||
|                     '</label>', | ||||
|                     '</li>' | ||||
|                 ].join('')); | ||||
|  | ||||
|                 $.each($elm.children(), function (i, elm) { | ||||
|                     $group.append(that.optionToHtml(i, elm, group, disabled)); | ||||
|                 }); | ||||
|                 return $group.html(); | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         events: function () { | ||||
|             var that = this, | ||||
|                 toggleOpen = function (e) { | ||||
|                     e.preventDefault(); | ||||
|                     that[that.options.isOpen ? 'close' : 'open'](); | ||||
|                 }; | ||||
|  | ||||
|             if (this.$label) { | ||||
|                 this.$label.off('click').on('click', function (e) { | ||||
|                     if (e.target.nodeName.toLowerCase() !== 'label' || e.target !== this) { | ||||
|                         return; | ||||
|                     } | ||||
|                     toggleOpen(e); | ||||
|                     if (!that.options.filter || !that.options.isOpen) { | ||||
|                         that.focus(); | ||||
|                     } | ||||
|                     e.stopPropagation(); // Causes lost focus otherwise | ||||
|                 }); | ||||
|             } | ||||
|  | ||||
|             this.$choice.off('click').on('click', toggleOpen) | ||||
|                 .off('focus').on('focus', this.options.onFocus) | ||||
|                 .off('blur').on('blur', this.options.onBlur); | ||||
|  | ||||
|             this.$parent.off('keydown').on('keydown', function (e) { | ||||
|                 switch (e.which) { | ||||
|                     case 27: // esc key | ||||
|                         that.close(); | ||||
|                         that.$choice.focus(); | ||||
|                         break; | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|             this.$searchInput.off('keydown').on('keydown',function (e) { | ||||
|                 // Ensure shift-tab causes lost focus from filter as with clicking away | ||||
|                 if (e.keyCode === 9 && e.shiftKey) { | ||||
|                     that.close(); | ||||
|                 } | ||||
|             }).off('keyup').on('keyup', function (e) { | ||||
|                 // enter or space | ||||
|                 // Avoid selecting/deselecting if no choices made | ||||
|                 if (that.options.filterAcceptOnEnter && (e.which === 13 || e.which == 32) && that.$searchInput.val()) { | ||||
|                     that.$selectAll.click(); | ||||
|                     that.close(); | ||||
|                     that.focus(); | ||||
|                     return; | ||||
|                 } | ||||
|                 that.filter(); | ||||
|             }); | ||||
|  | ||||
|             this.$selectAll.off('click').on('click', function () { | ||||
|                 var checked = $(this).prop('checked'), | ||||
|                     $items = that.$selectItems.filter(':visible'); | ||||
|  | ||||
|                 if ($items.length === that.$selectItems.length) { | ||||
|                     that[checked ? 'checkAll' : 'uncheckAll'](); | ||||
|                 } else { // when the filter option is true | ||||
|                     that.$selectGroups.prop('checked', checked); | ||||
|                     $items.prop('checked', checked); | ||||
|                     that.options[checked ? 'onCheckAll' : 'onUncheckAll'](); | ||||
|                     that.update(); | ||||
|                 } | ||||
|             }); | ||||
|             this.$selectGroups.off('click').on('click', function () { | ||||
|                 var group = $(this).parent().attr('data-group'), | ||||
|                     $items = that.$selectItems.filter(':visible'), | ||||
|                     $children = $items.filter(sprintf('[data-group="%s"]', group)), | ||||
|                     checked = $children.length !== $children.filter(':checked').length; | ||||
|  | ||||
|                 $children.prop('checked', checked); | ||||
|                 that.updateSelectAll(); | ||||
|                 that.update(); | ||||
|                 that.options.onOptgroupClick({ | ||||
|                     label: $(this).parent().text(), | ||||
|                     checked: checked, | ||||
|                     children: $children.get(), | ||||
|                     instance: that | ||||
|                 }); | ||||
|             }); | ||||
|             this.$selectItems.off('click').on('click', function () { | ||||
|                 that.updateSelectAll(); | ||||
|                 that.update(); | ||||
|                 that.updateOptGroupSelect(); | ||||
|                 that.options.onClick({ | ||||
|                     label: $(this).parent().text(), | ||||
|                     value: $(this).val(), | ||||
|                     checked: $(this).prop('checked'), | ||||
|                     instance: that | ||||
|                 }); | ||||
|  | ||||
|                 if (that.options.single && that.options.isOpen && !that.options.keepOpen) { | ||||
|                     that.close(); | ||||
|                 } | ||||
|  | ||||
|                 if (that.options.single) { | ||||
|                     var clickedVal = $(this).val(); | ||||
|                     that.$selectItems.filter(function() { | ||||
|                         return $(this).val() !== clickedVal; | ||||
|                     }).each(function() { | ||||
|                         $(this).prop('checked', false); | ||||
|                     }); | ||||
|                     that.update(); | ||||
|                 } | ||||
|             }); | ||||
|         }, | ||||
|  | ||||
|         open: function () { | ||||
|             if (this.$choice.hasClass('disabled')) { | ||||
|                 return; | ||||
|             } | ||||
|             this.options.isOpen = true; | ||||
|             this.$choice.find('>div').addClass('open'); | ||||
|             this.$drop[this.animateMethod('show')](); | ||||
|  | ||||
|             // fix filter bug: no results show | ||||
|             this.$selectAll.parent().show(); | ||||
|             this.$noResults.hide(); | ||||
|  | ||||
|             // Fix #77: 'All selected' when no options | ||||
|             if (!this.$el.children().length) { | ||||
|                 this.$selectAll.parent().hide(); | ||||
|                 this.$noResults.show(); | ||||
|             } | ||||
|  | ||||
|             if (this.options.container) { | ||||
|                 var offset = this.$drop.offset(); | ||||
|                 this.$drop.appendTo($(this.options.container)); | ||||
|                 this.$drop.offset({ | ||||
|                     top: offset.top, | ||||
|                     left: offset.left | ||||
|                 }); | ||||
|             } | ||||
|  | ||||
|             if (this.options.filter) { | ||||
|                 this.$searchInput.val(''); | ||||
|                 this.$searchInput.focus(); | ||||
|                 this.filter(); | ||||
|             } | ||||
|             this.options.onOpen(); | ||||
|         }, | ||||
|  | ||||
|         close: function () { | ||||
|             this.options.isOpen = false; | ||||
|             this.$choice.find('>div').removeClass('open'); | ||||
|             this.$drop[this.animateMethod('hide')](); | ||||
|             if (this.options.container) { | ||||
|                 this.$parent.append(this.$drop); | ||||
|                 this.$drop.css({ | ||||
|                     'top': 'auto', | ||||
|                     'left': 'auto' | ||||
|                 }); | ||||
|             } | ||||
|             this.options.onClose(); | ||||
|         }, | ||||
|  | ||||
|         animateMethod: function (method) { | ||||
|             var methods = { | ||||
|                 show: { | ||||
|                     fade: 'fadeIn', | ||||
|                     slide: 'slideDown' | ||||
|                 }, | ||||
|                 hide: { | ||||
|                     fade: 'fadeOut', | ||||
|                     slide: 'slideUp' | ||||
|                 } | ||||
|             }; | ||||
|  | ||||
|             return methods[method][this.options.animate] || method; | ||||
|         }, | ||||
|  | ||||
|         update: function (isInit) { | ||||
|             var selects = this.options.displayValues ? this.getSelects() : this.getSelects('text'), | ||||
|                 $span = this.$choice.find('>span'), | ||||
|                 sl = selects.length; | ||||
|  | ||||
|             if (sl === 0) { | ||||
|                 $span.addClass('placeholder').html(this.options.placeholder); | ||||
|             } else if (this.options.allSelected && sl === this.$selectItems.length + this.$disableItems.length) { | ||||
|                 $span.removeClass('placeholder').html(this.options.allSelected); | ||||
|             } else if (this.options.ellipsis && sl > this.options.minimumCountSelected) { | ||||
|                 $span.removeClass('placeholder').text(selects.slice(0, this.options.minimumCountSelected) | ||||
|                     .join(this.options.delimiter) + '...'); | ||||
|             } else if (this.options.countSelected && sl > this.options.minimumCountSelected) { | ||||
|                 $span.removeClass('placeholder').html(this.options.countSelected | ||||
|                     .replace('#', selects.length) | ||||
|                     .replace('%', this.$selectItems.length + this.$disableItems.length)); | ||||
|             } else { | ||||
|                 $span.removeClass('placeholder').text(selects.join(this.options.delimiter)); | ||||
|             } | ||||
|  | ||||
|             if (this.options.addTitle) { | ||||
|                 $span.prop('title', this.getSelects('text')); | ||||
|             } | ||||
|  | ||||
|             // set selects to select | ||||
|             this.$el.val(this.getSelects()).trigger('change'); | ||||
|  | ||||
|             // add selected class to selected li | ||||
|             this.$drop.find('li').removeClass('selected'); | ||||
|             this.$drop.find('input:checked').each(function () { | ||||
|                 $(this).parents('li').first().addClass('selected'); | ||||
|             }); | ||||
|  | ||||
|             // trigger <select> change event | ||||
|             if (!isInit) { | ||||
|                 this.$el.trigger('change'); | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         updateSelectAll: function (isInit) { | ||||
|             var $items = this.$selectItems; | ||||
|  | ||||
|             if (!isInit) { | ||||
|                 $items = $items.filter(':visible'); | ||||
|             } | ||||
|             this.$selectAll.prop('checked', $items.length && | ||||
|                 $items.length === $items.filter(':checked').length); | ||||
|             if (!isInit && this.$selectAll.prop('checked')) { | ||||
|                 this.options.onCheckAll(); | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         updateOptGroupSelect: function () { | ||||
|             var $items = this.$selectItems.filter(':visible'); | ||||
|             $.each(this.$selectGroups, function (i, val) { | ||||
|                 var group = $(val).parent().attr('data-group'), | ||||
|                     $children = $items.filter(sprintf('[data-group="%s"]', group)); | ||||
|                 $(val).prop('checked', $children.length && | ||||
|                     $children.length === $children.filter(':checked').length); | ||||
|             }); | ||||
|         }, | ||||
|  | ||||
|         //value or text, default: 'value' | ||||
|         getSelects: function (type) { | ||||
|             var that = this, | ||||
|                 texts = [], | ||||
|                 values = []; | ||||
|             this.$drop.find(sprintf('input[%s]:checked', this.selectItemName)).each(function () { | ||||
|                 texts.push($(this).parents('li').first().text()); | ||||
|                 values.push($(this).val()); | ||||
|             }); | ||||
|  | ||||
|             if (type === 'text' && this.$selectGroups.length) { | ||||
|                 texts = []; | ||||
|                 this.$selectGroups.each(function () { | ||||
|                     var html = [], | ||||
|                         text = $.trim($(this).parent().text()), | ||||
|                         group = $(this).parent().data('group'), | ||||
|                         $children = that.$drop.find(sprintf('[%s][data-group="%s"]', that.selectItemName, group)), | ||||
|                         $selected = $children.filter(':checked'); | ||||
|  | ||||
|                     if (!$selected.length) { | ||||
|                         return; | ||||
|                     } | ||||
|  | ||||
|                     html.push('['); | ||||
|                     html.push(text); | ||||
|                     if ($children.length > $selected.length) { | ||||
|                         var list = []; | ||||
|                         $selected.each(function () { | ||||
|                             list.push($(this).parent().text()); | ||||
|                         }); | ||||
|                         html.push(': ' + list.join(', ')); | ||||
|                     } | ||||
|                     html.push(']'); | ||||
|                     texts.push(html.join('')); | ||||
|                 }); | ||||
|             } | ||||
|             return type === 'text' ? texts : values; | ||||
|         }, | ||||
|  | ||||
|         setSelects: function (values) { | ||||
|             var that = this; | ||||
|             this.$selectItems.prop('checked', false); | ||||
|             this.$disableItems.prop('checked', false); | ||||
|             $.each(values, function (i, value) { | ||||
|                 that.$selectItems.filter(sprintf('[value="%s"]', value)).prop('checked', true); | ||||
|                 that.$disableItems.filter(sprintf('[value="%s"]', value)).prop('checked', true); | ||||
|             }); | ||||
|             this.$selectAll.prop('checked', this.$selectItems.length === | ||||
|                 this.$selectItems.filter(':checked').length + this.$disableItems.filter(':checked').length); | ||||
|  | ||||
|             $.each(that.$selectGroups, function (i, val) { | ||||
|                 var group = $(val).parent().attr('data-group'), | ||||
|                     $children = that.$selectItems.filter('[data-group="' + group + '"]'); | ||||
|                 $(val).prop('checked', $children.length && | ||||
|                     $children.length === $children.filter(':checked').length); | ||||
|             }); | ||||
|  | ||||
|             this.update(); | ||||
|         }, | ||||
|  | ||||
|         enable: function () { | ||||
|             this.$choice.removeClass('disabled'); | ||||
|         }, | ||||
|  | ||||
|         disable: function () { | ||||
|             this.$choice.addClass('disabled'); | ||||
|         }, | ||||
|  | ||||
|         checkAll: function () { | ||||
|             this.$selectItems.prop('checked', true); | ||||
|             this.$selectGroups.prop('checked', true); | ||||
|             this.$selectAll.prop('checked', true); | ||||
|             this.update(); | ||||
|             this.options.onCheckAll(); | ||||
|         }, | ||||
|  | ||||
|         uncheckAll: function () { | ||||
|             this.$selectItems.prop('checked', false); | ||||
|             this.$selectGroups.prop('checked', false); | ||||
|             this.$selectAll.prop('checked', false); | ||||
|             this.update(); | ||||
|             this.options.onUncheckAll(); | ||||
|         }, | ||||
|  | ||||
|         focus: function () { | ||||
|             this.$choice.focus(); | ||||
|             this.options.onFocus(); | ||||
|         }, | ||||
|  | ||||
|         blur: function () { | ||||
|             this.$choice.blur(); | ||||
|             this.options.onBlur(); | ||||
|         }, | ||||
|  | ||||
|         refresh: function () { | ||||
|             this.init(); | ||||
|         }, | ||||
|  | ||||
|         filter: function () { | ||||
|             var that = this, | ||||
|                 text = $.trim(this.$searchInput.val()).toLowerCase(); | ||||
|  | ||||
|             if (text.length === 0) { | ||||
|                 this.$selectAll.parent().show(); | ||||
|                 this.$selectItems.parent().show(); | ||||
|                 this.$disableItems.parent().show(); | ||||
|                 this.$selectGroups.parent().show(); | ||||
|                 this.$noResults.hide(); | ||||
|             } else { | ||||
|                 this.$selectItems.each(function () { | ||||
|                     var $parent = $(this).parent(); | ||||
|                     $parent[removeDiacritics($parent.text().toLowerCase()).indexOf(removeDiacritics(text)) < 0 ? 'hide' : 'show'](); | ||||
|                 }); | ||||
|                 this.$disableItems.parent().hide(); | ||||
|                 this.$selectGroups.each(function () { | ||||
|                     var $parent = $(this).parent(); | ||||
|                     var group = $parent.attr('data-group'), | ||||
|                         $items = that.$selectItems.filter(':visible'); | ||||
|                     $parent[$items.filter(sprintf('[data-group="%s"]', group)).length ? 'show' : 'hide'](); | ||||
|                 }); | ||||
|  | ||||
|                 //Check if no matches found | ||||
|                 if (this.$selectItems.parent().filter(':visible').length) { | ||||
|                     this.$selectAll.parent().show(); | ||||
|                     this.$noResults.hide(); | ||||
|                 } else { | ||||
|                     this.$selectAll.parent().hide(); | ||||
|                     this.$noResults.show(); | ||||
|                 } | ||||
|             } | ||||
|             this.updateOptGroupSelect(); | ||||
|             this.updateSelectAll(); | ||||
|             this.options.onFilter(text); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     $.fn.multipleSelect = function () { | ||||
|         var option = arguments[0], | ||||
|             args = arguments, | ||||
|  | ||||
|             value, | ||||
|             allowedMethods = [ | ||||
|                 'getSelects', 'setSelects', | ||||
|                 'enable', 'disable', | ||||
|                 'open', 'close', | ||||
|                 'checkAll', 'uncheckAll', | ||||
|                 'focus', 'blur', | ||||
|                 'refresh', 'close' | ||||
|             ]; | ||||
|  | ||||
|         this.each(function () { | ||||
|             var $this = $(this), | ||||
|                 data = $this.data('multipleSelect'), | ||||
|                 options = $.extend({}, $.fn.multipleSelect.defaults, | ||||
|                     $this.data(), typeof option === 'object' && option); | ||||
|  | ||||
|             if (!data) { | ||||
|                 data = new MultipleSelect($this, options); | ||||
|                 $this.data('multipleSelect', data); | ||||
|             } | ||||
|  | ||||
|             if (typeof option === 'string') { | ||||
|                 if ($.inArray(option, allowedMethods) < 0) { | ||||
|                     throw 'Unknown method: ' + option; | ||||
|                 } | ||||
|                 value = data[option](args[1]); | ||||
|             } else { | ||||
|                 data.init(); | ||||
|                 if (args[1]) { | ||||
|                     value = data[args[1]].apply(data, [].slice.call(args, 2)); | ||||
|                 } | ||||
|             } | ||||
|         }); | ||||
|  | ||||
|         return typeof value !== 'undefined' ? value : this; | ||||
|     }; | ||||
|  | ||||
|     $.fn.multipleSelect.defaults = { | ||||
|         name: '', | ||||
|         isOpen: false, | ||||
|         placeholder: '', | ||||
|         selectAll: true, | ||||
|         selectAllDelimiter: ['[', ']'], | ||||
|         minimumCountSelected: 3, | ||||
|         ellipsis: false, | ||||
|         multiple: false, | ||||
|         multipleWidth: 80, | ||||
|         single: false, | ||||
|         filter: false, | ||||
|         width: undefined, | ||||
|         dropWidth: undefined, | ||||
|         maxHeight: 250, | ||||
|         container: null, | ||||
|         position: 'bottom', | ||||
|         keepOpen: false, | ||||
|         animate: 'none', // 'none', 'fade', 'slide' | ||||
|         displayValues: false, | ||||
|         delimiter: ', ', | ||||
|         addTitle: false, | ||||
|         filterAcceptOnEnter: false, | ||||
|         hideOptgroupCheckboxes: false, | ||||
|  | ||||
|         selectAllText: 'Tout sélectionner', | ||||
|         allSelected: 'Tout sélectionné', | ||||
|         countSelected: '# sur % sélectionnés', | ||||
|         noMatchesFound: 'Introuvable', | ||||
|  | ||||
|         styler: function () { | ||||
|             return false; | ||||
|         }, | ||||
|         textTemplate: function ($elm) { | ||||
|             return $elm.html(); | ||||
|         }, | ||||
|         labelTemplate: function ($elm) { | ||||
|             return $elm.attr('label'); | ||||
|         }, | ||||
|  | ||||
|         onOpen: function () { | ||||
|             return false; | ||||
|         }, | ||||
|         onClose: function () { | ||||
|             return false; | ||||
|         }, | ||||
|         onCheckAll: function () { | ||||
|             return false; | ||||
|         }, | ||||
|         onUncheckAll: function () { | ||||
|             return false; | ||||
|         }, | ||||
|         onFocus: function () { | ||||
|             return false; | ||||
|         }, | ||||
|         onBlur: function () { | ||||
|             return false; | ||||
|         }, | ||||
|         onOptgroupClick: function () { | ||||
|             return false; | ||||
|         }, | ||||
|         onClick: function () { | ||||
|             return false; | ||||
|         }, | ||||
|         onFilter: function () { | ||||
|             return false; | ||||
|         } | ||||
|     }; | ||||
| })(jQuery); | ||||
							
								
								
									
										11
									
								
								core/static/core/js/script.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,11 @@ | ||||
| console.log('Guy'); | ||||
|  | ||||
| $( function() { | ||||
|     dialog = $( ".choose_file_widget" ).dialog({ | ||||
|         autoOpen: false, | ||||
|         modal: true, | ||||
|     }); | ||||
|     $( ".choose_file_button" ).button().on( "click", function() { | ||||
|         dialog.dialog( "open" ); | ||||
|     }); | ||||
| } ); | ||||
							
								
								
									
										330
									
								
								core/static/core/js/ui/AUTHORS.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,330 @@ | ||||
| Authors ordered by first contribution | ||||
| A list of current team members is available at http://jqueryui.com/about | ||||
|  | ||||
| Paul Bakaus <paul.bakaus@gmail.com> | ||||
| Richard Worth <rdworth@gmail.com> | ||||
| Yehuda Katz <wycats@gmail.com> | ||||
| Sean Catchpole <sean@sunsean.com> | ||||
| John Resig <jeresig@gmail.com> | ||||
| Tane Piper <piper.tane@gmail.com> | ||||
| Dmitri Gaskin <dmitrig01@gmail.com> | ||||
| Klaus Hartl <klaus.hartl@gmail.com> | ||||
| Stefan Petre <stefan.petre@gmail.com> | ||||
| Gilles van den Hoven <gilles@webunity.nl> | ||||
| Micheil Bryan Smith <micheil@brandedcode.com> | ||||
| Jörn Zaefferer <joern.zaefferer@gmail.com> | ||||
| Marc Grabanski <m@marcgrabanski.com> | ||||
| Keith Wood <kbwood@iinet.com.au> | ||||
| Brandon Aaron <brandon.aaron@gmail.com> | ||||
| Scott González <scott.gonzalez@gmail.com> | ||||
| Eduardo Lundgren <eduardolundgren@gmail.com> | ||||
| Aaron Eisenberger <aaronchi@gmail.com> | ||||
| Joan Piedra <theneojp@gmail.com> | ||||
| Bruno Basto <b.basto@gmail.com> | ||||
| Remy Sharp <remy@leftlogic.com> | ||||
| Bohdan Ganicky <bohdan.ganicky@gmail.com> | ||||
| David Bolter <david.bolter@gmail.com> | ||||
| Chi Cheng <cloudream@gmail.com> | ||||
| Ca-Phun Ung <pazu2k@gmail.com> | ||||
| Ariel Flesler <aflesler@gmail.com> | ||||
| Maggie Wachs <maggie@filamentgroup.com> | ||||
| Scott Jehl <scottjehl@gmail.com> | ||||
| Todd Parker <todd@filamentgroup.com> | ||||
| Andrew Powell <andrew@shellscape.org> | ||||
| Brant Burnett <btburnett3@gmail.com> | ||||
| Douglas Neiner <doug@dougneiner.com> | ||||
| Paul Irish <paul.irish@gmail.com> | ||||
| Ralph Whitbeck <ralph.whitbeck@gmail.com> | ||||
| Thibault Duplessis <thibault.duplessis@gmail.com> | ||||
| Dominique Vincent <dominique.vincent@toitl.com> | ||||
| Jack Hsu <jack.hsu@gmail.com> | ||||
| Adam Sontag <ajpiano@ajpiano.com> | ||||
| Carl Fürstenberg <carl@excito.com> | ||||
| Kevin Dalman <development@allpro.net> | ||||
| Alberto Fernández Capel <afcapel@gmail.com> | ||||
| Jacek Jędrzejewski (http://jacek.jedrzejewski.name) | ||||
| Ting Kuei <ting@kuei.com> | ||||
| Samuel Cormier-Iijima <sam@chide.it> | ||||
| Jon Palmer <jonspalmer@gmail.com> | ||||
| Ben Hollis <bhollis@amazon.com> | ||||
| Justin MacCarthy <Justin@Rubystars.biz> | ||||
| Eyal Kobrigo <kobrigo@hotmail.com> | ||||
| Tiago Freire <tiago.freire@gmail.com> | ||||
| Diego Tres <diegotres@gmail.com> | ||||
| Holger Rüprich <holger@rueprich.de> | ||||
| Ziling Zhao <zilingzhao@gmail.com> | ||||
| Mike Alsup <malsup@gmail.com> | ||||
| Robson Braga Araujo <robsonbraga@gmail.com> | ||||
| Pierre-Henri Ausseil <ph.ausseil@gmail.com> | ||||
| Christopher McCulloh <cmcculloh@gmail.com> | ||||
| Andrew Newcomb <ext.github@preceptsoftware.co.uk> | ||||
| Lim Chee Aun <cheeaun@gmail.com> | ||||
| Jorge Barreiro <yortx.barry@gmail.com> | ||||
| Daniel Steigerwald <daniel@steigerwald.cz> | ||||
| John Firebaugh <john_firebaugh@bigfix.com> | ||||
| John Enters <github@darkdark.net> | ||||
| Andrey Kapitcyn <ru.m157y@gmail.com> | ||||
| Dmitry Petrov <dpetroff@gmail.com> | ||||
| Eric Hynds <eric@hynds.net> | ||||
| Chairat Sunthornwiphat <pipo@sixhead.com> | ||||
| Josh Varner <josh.varner@gmail.com> | ||||
| Stéphane Raimbault <stephane.raimbault@gmail.com> | ||||
| Jay Merrifield <fracmak@gmail.com> | ||||
| J. Ryan Stinnett <jryans@gmail.com> | ||||
| Peter Heiberg <peter@heiberg.se> | ||||
| Alex Dovenmuehle <adovenmuehle@gmail.com> | ||||
| Jamie Gegerson <git@jamiegegerson.com> | ||||
| Raymond Schwartz <skeetergraphics@gmail.com> | ||||
| Phillip Barnes <philbar@gmail.com> | ||||
| Kyle Wilkinson <kai@wikyd.org> | ||||
| Khaled AlHourani <me@khaledalhourani.com> | ||||
| Marian Rudzynski <mr@impaled.org> | ||||
| Jean-Francois Remy <jeff@melix.org> | ||||
| Doug Blood <dougblood@gmail.com> | ||||
| Filippo Cavallarin <filippo.cavallarin@codseq.it> | ||||
| Heiko Henning <heiko@thehennings.ch> | ||||
| Aliaksandr Rahalevich <saksmlz@gmail.com> | ||||
| Mario Visic <mario@mariovisic.com> | ||||
| Xavi Ramirez <xavi.rmz@gmail.com> | ||||
| Max Schnur <max.schnur@gmail.com> | ||||
| Saji Nediyanchath <saji89@gmail.com> | ||||
| Corey Frang <gnarf37@gmail.com> | ||||
| Aaron Peterson <aaronp123@yahoo.com> | ||||
| Ivan Peters <ivan@ivanpeters.com> | ||||
| Mohamed Cherif Bouchelaghem <cherifbouchelaghem@yahoo.fr> | ||||
| Marcos Sousa <falecomigo@marcossousa.com> | ||||
| Michael DellaNoce <mdellanoce@mailtrust.com> | ||||
| George Marshall <echosx@gmail.com> | ||||
| Tobias Brunner <tobias@strongswan.org> | ||||
| Martin Solli <msolli@gmail.com> | ||||
| David Petersen <public@petersendidit.com> | ||||
| Dan Heberden <danheberden@gmail.com> | ||||
| William Kevin Manire <williamkmanire@gmail.com> | ||||
| Gilmore Davidson <gilmoreorless@gmail.com> | ||||
| Michael Wu <michaelmwu@gmail.com> | ||||
| Adam Parod <mystic414@gmail.com> | ||||
| Guillaume Gautreau <guillaume+github@ghusse.com> | ||||
| Marcel Toele <EleotleCram@gmail.com> | ||||
| Dan Streetman <ddstreet@ieee.org> | ||||
| Matt Hoskins <matt@nipltd.com> | ||||
| Giovanni Giacobbi <giovanni@giacobbi.net> | ||||
| Kyle Florence <kyle.florence@gmail.com> | ||||
| Pavol Hluchý <lopo@losys.sk> | ||||
| Hans Hillen <hans.hillen@gmail.com> | ||||
| Mark Johnson <virgofx@live.com> | ||||
| Trey Hunner <treyhunner@gmail.com> | ||||
| Shane Whittet <whittet@gmail.com> | ||||
| Edward A Faulkner <ef@alum.mit.edu> | ||||
| Adam Baratz <adam@adambaratz.com> | ||||
| Kato Kazuyoshi <kato.kazuyoshi@gmail.com> | ||||
| Eike Send <eike.send@gmail.com> | ||||
| Kris Borchers <kris.borchers@gmail.com> | ||||
| Eddie Monge <eddie@eddiemonge.com> | ||||
| Israel Tsadok <itsadok@gmail.com> | ||||
| Carson McDonald <carson@ioncannon.net> | ||||
| Jason Davies <jason@jasondavies.com> | ||||
| Garrison Locke <gplocke@gmail.com> | ||||
| David Murdoch <david@davidmurdoch.com> | ||||
| Benjamin Scott Boyle <benjamins.boyle@gmail.com> | ||||
| Jesse Baird <jebaird@gmail.com> | ||||
| Jonathan Vingiano <jvingiano@gmail.com> | ||||
| Dylan Just <dev@ephox.com> | ||||
| Hiroshi Tomita <tomykaira@gmail.com> | ||||
| Glenn Goodrich <glenn.goodrich@gmail.com> | ||||
| Tarafder Ashek-E-Elahi <mail.ashek@gmail.com> | ||||
| Ryan Neufeld <ryan@neufeldmail.com> | ||||
| Marc Neuwirth <marc.neuwirth@gmail.com> | ||||
| Philip Graham <philip.robert.graham@gmail.com> | ||||
| Benjamin Sterling <benjamin.sterling@kenzomedia.com> | ||||
| Wesley Walser <waw325@gmail.com> | ||||
| Kouhei Sutou <kou@clear-code.com> | ||||
| Karl Kirch <karlkrch@gmail.com> | ||||
| Chris Kelly <ckdake@ckdake.com> | ||||
| Jason Oster <jay@kodewerx.org> | ||||
| Felix Nagel <info@felixnagel.com> | ||||
| Alexander Polomoshnov <alex.polomoshnov@gmail.com> | ||||
| David Leal <dgleal@gmail.com> | ||||
| Igor Milla <igor.fsp.milla@gmail.com> | ||||
| Dave Methvin <dave.methvin@gmail.com> | ||||
| Florian Gutmann <f.gutmann@chronimo.com> | ||||
| Marwan Al Jubeh <marwan.aljubeh@gmail.com> | ||||
| Milan Broum <midlis@googlemail.com> | ||||
| Sebastian Sauer <info@dynpages.de> | ||||
| Gaëtan Muller <m.gaetan89@gmail.com> | ||||
| Michel Weimerskirch <michel@weimerskirch.net> | ||||
| William Griffiths <william@ycymro.com> | ||||
| Stojce Slavkovski <stojce@gmail.com> | ||||
| David Soms <david.soms@gmail.com> | ||||
| David De Sloovere <david.desloovere@outlook.com> | ||||
| Michael P. Jung <michael.jung@terreon.de> | ||||
| Shannon Pekary <spekary@gmail.com> | ||||
| Dan Wellman <danwellman@hotmail.com> | ||||
| Matthew Edward Hutton <meh@corefiling.co.uk> | ||||
| James Khoury <james@jameskhoury.com> | ||||
| Rob Loach <robloach@gmail.com> | ||||
| Alberto Monteiro <betimbrasil@gmail.com> | ||||
| Alex Rhea <alex.rhea@gmail.com> | ||||
| Krzysztof Rosiński <rozwell69@gmail.com> | ||||
| Ryan Olton <oltonr@gmail.com> | ||||
| Genie <386@mail.com> | ||||
| Rick Waldron <waldron.rick@gmail.com> | ||||
| Ian Simpson <spoonlikesham@gmail.com> | ||||
| Lev Kitsis <spam4lev@gmail.com> | ||||
| TJ VanToll <tj.vantoll@gmail.com> | ||||
| Justin Domnitz <jdomnitz@gmail.com> | ||||
| Douglas Cerna <douglascerna@yahoo.com> | ||||
| Bert ter Heide <bertjh@hotmail.com> | ||||
| Jasvir Nagra <jasvir@gmail.com> | ||||
| Yuriy Khabarov <13real008@gmail.com> | ||||
| Harri Kilpiö <harri.kilpio@gmail.com> | ||||
| Lado Lomidze <lado.lomidze@gmail.com> | ||||
| Amir E. Aharoni <amir.aharoni@mail.huji.ac.il> | ||||
| Simon Sattes <simon.sattes@gmail.com> | ||||
| Jo Liss <joliss42@gmail.com> | ||||
| Guntupalli Karunakar <karunakarg@yahoo.com> | ||||
| Shahyar Ghobadpour <shahyar@gmail.com> | ||||
| Lukasz Lipinski <uzza17@gmail.com> | ||||
| Timo Tijhof <krinklemail@gmail.com> | ||||
| Jason Moon <jmoon@socialcast.com> | ||||
| Martin Frost <martinf55@hotmail.com> | ||||
| Eneko Illarramendi <eneko@illarra.com> | ||||
| EungJun Yi <semtlenori@gmail.com> | ||||
| Courtland Allen <courtlandallen@gmail.com> | ||||
| Viktar Varvanovich <non4eg@gmail.com> | ||||
| Danny Trunk <dtrunk90@gmail.com> | ||||
| Pavel Stetina <pavel.stetina@nangu.tv> | ||||
| Michael Stay <metaweta@gmail.com> | ||||
| Steven Roussey <sroussey@gmail.com> | ||||
| Michael Hollis <hollis21@gmail.com> | ||||
| Lee Rowlands <lee.rowlands@previousnext.com.au> | ||||
| Timmy Willison <timmywillisn@gmail.com> | ||||
| Karl Swedberg <kswedberg@gmail.com> | ||||
| Baoju Yuan <the_guy_1987@hotmail.com> | ||||
| Maciej Mroziński <maciej.k.mrozinski@gmail.com> | ||||
| Luis Dalmolin <luis.nh@gmail.com> | ||||
| Mark Aaron Shirley <maspwr@gmail.com> | ||||
| Martin Hoch <martin@fidion.de> | ||||
| Jiayi Yang <tr870829@gmail.com> | ||||
| Philipp Benjamin Köppchen <xgxtpbk@gws.ms> | ||||
| Sindre Sorhus <sindresorhus@gmail.com> | ||||
| Bernhard Sirlinger <bernhard.sirlinger@tele2.de> | ||||
| Jared A. Scheel <jared@jaredscheel.com> | ||||
| Rafael Xavier de Souza <rxaviers@gmail.com> | ||||
| John Chen <zhang.z.chen@intel.com> | ||||
| Robert Beuligmann <robertbeuligmann@gmail.com> | ||||
| Dale Kocian <dale.kocian@gmail.com> | ||||
| Mike Sherov <mike.sherov@gmail.com> | ||||
| Andrew Couch <andy@couchand.com> | ||||
| Marc-Andre Lafortune <github@marc-andre.ca> | ||||
| Nate Eagle <nate.eagle@teamaol.com> | ||||
| David Souther <davidsouther@gmail.com> | ||||
| Mathias Stenbom <mathias@stenbom.com> | ||||
| Sergey Kartashov <ebishkek@yandex.ru> | ||||
| Avinash R <nashpapa@gmail.com> | ||||
| Ethan Romba <ethanromba@gmail.com> | ||||
| Cory Gackenheimer <cory.gack@gmail.com> | ||||
| Juan Pablo Kaniefsky <jpkaniefsky@gmail.com> | ||||
| Roman Salnikov <bardt.dz@gmail.com> | ||||
| Anika Henke <anika@selfthinker.org> | ||||
| Samuel Bovée <samycookie2000@yahoo.fr> | ||||
| Fabrício Matté <ult_combo@hotmail.com> | ||||
| Viktor Kojouharov <vkojouharov@gmail.com> | ||||
| Pawel Maruszczyk (http://hrabstwo.net) | ||||
| Pavel Selitskas <p.selitskas@gmail.com> | ||||
| Bjørn Johansen <post@bjornjohansen.no> | ||||
| Matthieu Penant <thieum22@hotmail.com> | ||||
| Dominic Barnes <dominic@dbarnes.info> | ||||
| David Sullivan <david.sullivan@gmail.com> | ||||
| Thomas Jaggi <thomas@responsive.ch> | ||||
| Vahid Sohrabloo <vahid4134@gmail.com> | ||||
| Travis Carden <travis.carden@gmail.com> | ||||
| Bruno M. Custódio <bruno@brunomcustodio.com> | ||||
| Nathanael Silverman <nathanael.silverman@gmail.com> | ||||
| Christian Wenz <christian@wenz.org> | ||||
| Steve Urmston <steve@urm.st> | ||||
| Zaven Muradyan <megalivoithos@gmail.com> | ||||
| Woody Gilk <shadowhand@deviantart.com> | ||||
| Zbigniew Motyka <zbigniew.motyka@gmail.com> | ||||
| Suhail Alkowaileet <xsoh.k7@gmail.com> | ||||
| Toshi MARUYAMA <marutosijp2@yahoo.co.jp> | ||||
| David Hansen <hansede@gmail.com> | ||||
| Brian Grinstead <briangrinstead@gmail.com> | ||||
| Christian Klammer <christian314159@gmail.com> | ||||
| Steven Luscher <jquerycla@steveluscher.com> | ||||
| Gan Eng Chin <engchin.gan@gmail.com> | ||||
| Gabriel Schulhof <gabriel.schulhof@intel.com> | ||||
| Alexander Schmitz <arschmitz@gmail.com> | ||||
| Vilhjálmur Skúlason <vis@dmm.is> | ||||
| Siebrand Mazeland <siebrand@kitano.nl> | ||||
| Mohsen Ekhtiari <mohsenekhtiari@yahoo.com> | ||||
| Pere Orga <gotrunks@gmail.com> | ||||
| Jasper de Groot <mail@ugomobi.com> | ||||
| Stephane Deschamps <stephane.deschamps@gmail.com> | ||||
| Jyoti Deka <dekajp@gmail.com> | ||||
| Andrei Picus <office.nightcrawler@gmail.com> | ||||
| Ondrej Novy <novy@ondrej.org> | ||||
| Jacob McCutcheon <jacob.mccutcheon@gmail.com> | ||||
| Monika Piotrowicz <monika.piotrowicz@gmail.com> | ||||
| Imants Horsts <imants.horsts@inbox.lv> | ||||
| Eric Dahl <eric.c.dahl@gmail.com> | ||||
| Dave Stein <dave@behance.com> | ||||
| Dylan Barrell <dylan@barrell.com> | ||||
| Daniel DeGroff <djdegroff@gmail.com> | ||||
| Michael Wiencek <mwtuea@gmail.com> | ||||
| Thomas Meyer <meyertee@gmail.com> | ||||
| Ruslan Yakhyaev <ruslan@ruslan.io> | ||||
| Brian J. Dowling <bjd-dev@simplicity.net> | ||||
| Ben Higgins <ben@extrahop.com> | ||||
| Yermo Lamers <yml@yml.com> | ||||
| Patrick Stapleton <github@gdi2290.com> | ||||
| Trisha Crowley <trisha.crowley@gmail.com> | ||||
| Usman Akeju <akeju00+github@gmail.com> | ||||
| Rodrigo Menezes <rod333@gmail.com> | ||||
| Jacques Perrault <jacques_perrault@us.ibm.com> | ||||
| Frederik Elvhage <frederik.elvhage@googlemail.com> | ||||
| Will Holley <willholley@gmail.com> | ||||
| Uri Gilad <antishok@gmail.com> | ||||
| Richard Gibson <richard.gibson@gmail.com> | ||||
| Simen Bekkhus <sbekkhus91@gmail.com> | ||||
| Chen Eshchar <eshcharc@gmail.com> | ||||
| Bruno Pérel <brunoperel@gmail.com> | ||||
| Mohammed Alshehri <m@dralshehri.com> | ||||
| Lisa Seacat DeLuca <ldeluca@us.ibm.com> | ||||
| Anne-Gaelle Colom <coloma@westminster.ac.uk> | ||||
| Adam Foster <slimfoster@gmail.com> | ||||
| Luke Page <luke.a.page@gmail.com> | ||||
| Daniel Owens <daniel@matchstickmixup.com> | ||||
| Michael Orchard <morchard@scottlogic.co.uk> | ||||
| Marcus Warren <marcus@envoke.com> | ||||
| Nils Heuermann <nils@world-of-scripts.de> | ||||
| Marco Ziech <marco@ziech.net> | ||||
| Patricia Juarez <patrixd@gmail.com> | ||||
| Ben Mosher <me@benmosher.com> | ||||
| Ablay Keldibek <atomio.ak@gmail.com> | ||||
| Thomas Applencourt <thomas.applencourt@irsamc.ups-tlse.fr> | ||||
| Jiabao Wu <jiabao.foss@gmail.com> | ||||
| Eric Lee Carraway <github@ericcarraway.com> | ||||
| Victor Homyakov <vkhomyackov@gmail.com> | ||||
| Myeongjin Lee <aranet100@gmail.com> | ||||
| Liran Sharir <lsharir@gmail.com> | ||||
| Weston Ruter <weston@xwp.co> | ||||
| Mani Mishra <manimishra902@gmail.com> | ||||
| Hannah Methvin <hannahmethvin@gmail.com> | ||||
| Leonardo Balter <leonardo.balter@gmail.com> | ||||
| Benjamin Albert <benjamin_a5@yahoo.com> | ||||
| Michał Gołębiowski <m.goleb@gmail.com> | ||||
| Alyosha Pushak <alyosha.pushak@gmail.com> | ||||
| Fahad Ahmad <fahadahmad41@hotmail.com> | ||||
| Matt Brundage <github@mattbrundage.com> | ||||
| Francesc Baeta <francesc.baeta@gmail.com> | ||||
| Piotr Baran <piotros@wp.pl> | ||||
| Mukul Hase <mukulhase@gmail.com> | ||||
| Konstantin Dinev <kdinev@mail.bw.edu> | ||||
| Rand Scullard <rand@randscullard.com> | ||||
| Dan Strohl <dan@wjcg.net> | ||||
| Maksim Ryzhikov <rv.maksim@gmail.com> | ||||
| Amine HADDAD <haddad@allegorie.tv> | ||||
| Amanpreet Singh <apsdehal@gmail.com> | ||||
| Alexey Balchunas <bleshik@gmail.com> | ||||
| Peter Kehl <peter.kehl@gmail.com> | ||||
| Peter Dave Hello <hsu@peterdavehello.org> | ||||
							
								
								
									
										43
									
								
								core/static/core/js/ui/LICENSE.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,43 @@ | ||||
| Copyright jQuery Foundation and other contributors, https://jquery.org/ | ||||
|  | ||||
| This software consists of voluntary contributions made by many | ||||
| individuals. For exact contribution history, see the revision history | ||||
| available at https://github.com/jquery/jquery-ui | ||||
|  | ||||
| The following license applies to all parts of this software except as | ||||
| documented below: | ||||
|  | ||||
| ==== | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining | ||||
| a copy of this software and associated documentation files (the | ||||
| "Software"), to deal in the Software without restriction, including | ||||
| without limitation the rights to use, copy, modify, merge, publish, | ||||
| distribute, sublicense, and/or sell copies of the Software, and to | ||||
| permit persons to whom the Software is furnished to do so, subject to | ||||
| the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be | ||||
| included in all copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||||
| EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||||
| MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||||
| NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | ||||
| LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION | ||||
| OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||||
| WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
|  | ||||
| ==== | ||||
|  | ||||
| Copyright and related rights for sample code are waived via CC0. Sample | ||||
| code is defined as all source code contained within the demos directory. | ||||
|  | ||||
| CC0: http://creativecommons.org/publicdomain/zero/1.0/ | ||||
|  | ||||
| ==== | ||||
|  | ||||
| All files located in the node_modules and external directories are | ||||
| externally maintained libraries used by this software which have their | ||||
| own licenses; we recommend you read them, as their terms may differ from | ||||
| the terms above. | ||||
							
								
								
									
										11008
									
								
								core/static/core/js/ui/external/jquery/jquery.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								core/static/core/js/ui/images/ui-icons_444444_256x240.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								core/static/core/js/ui/images/ui-icons_555555_256x240.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								core/static/core/js/ui/images/ui-icons_777620_256x240.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.4 KiB | 
							
								
								
									
										
											BIN
										
									
								
								core/static/core/js/ui/images/ui-icons_777777_256x240.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								core/static/core/js/ui/images/ui-icons_cc0000_256x240.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.4 KiB | 
							
								
								
									
										
											BIN
										
									
								
								core/static/core/js/ui/images/ui-icons_ffffff_256x240.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.2 KiB | 
							
								
								
									
										559
									
								
								core/static/core/js/ui/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,559 @@ | ||||
| <!doctype html> | ||||
| <html lang="us"> | ||||
| <head> | ||||
| 	<meta charset="utf-8"> | ||||
| 	<title>jQuery UI Example Page</title> | ||||
| 	<link href="jquery-ui.css" rel="stylesheet"> | ||||
| 	<style> | ||||
| 	body{ | ||||
| 		font-family: "Trebuchet MS", sans-serif; | ||||
| 		margin: 50px; | ||||
| 	} | ||||
| 	.demoHeaders { | ||||
| 		margin-top: 2em; | ||||
| 	} | ||||
| 	#dialog-link { | ||||
| 		padding: .4em 1em .4em 20px; | ||||
| 		text-decoration: none; | ||||
| 		position: relative; | ||||
| 	} | ||||
| 	#dialog-link span.ui-icon { | ||||
| 		margin: 0 5px 0 0; | ||||
| 		position: absolute; | ||||
| 		left: .2em; | ||||
| 		top: 50%; | ||||
| 		margin-top: -8px; | ||||
| 	} | ||||
| 	#icons { | ||||
| 		margin: 0; | ||||
| 		padding: 0; | ||||
| 	} | ||||
| 	#icons li { | ||||
| 		margin: 2px; | ||||
| 		position: relative; | ||||
| 		padding: 4px 0; | ||||
| 		cursor: pointer; | ||||
| 		float: left; | ||||
| 		list-style: none; | ||||
| 	} | ||||
| 	#icons span.ui-icon { | ||||
| 		float: left; | ||||
| 		margin: 0 4px; | ||||
| 	} | ||||
| 	.fakewindowcontain .ui-widget-overlay { | ||||
| 		position: absolute; | ||||
| 	} | ||||
| 	select { | ||||
| 		width: 200px; | ||||
| 	} | ||||
| 	</style> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <h1>Welcome to jQuery UI!</h1> | ||||
|  | ||||
| <div class="ui-widget"> | ||||
| 	<p>This page demonstrates the widgets and theme you selected in Download Builder. Please make sure you are using them with a compatible jQuery version.</p> | ||||
| </div> | ||||
|  | ||||
| <h1>YOUR COMPONENTS:</h1> | ||||
|  | ||||
|  | ||||
| <!-- Accordion --> | ||||
| <h2 class="demoHeaders">Accordion</h2> | ||||
| <div id="accordion"> | ||||
| 	<h3>First</h3> | ||||
| 	<div>Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet.</div> | ||||
| 	<h3>Second</h3> | ||||
| 	<div>Phasellus mattis tincidunt nibh.</div> | ||||
| 	<h3>Third</h3> | ||||
| 	<div>Nam dui erat, auctor a, dignissim quis.</div> | ||||
| </div> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Autocomplete --> | ||||
| <h2 class="demoHeaders">Autocomplete</h2> | ||||
| <div> | ||||
| 	<input id="autocomplete" title="type "a""> | ||||
| </div> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Button --> | ||||
| <h2 class="demoHeaders">Button</h2> | ||||
| <button id="button">A button element</button> | ||||
| <button id="button-icon">An icon-only button</button> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Checkboxradio --> | ||||
| <h2 class="demoHeaders">Checkboxradio</h2> | ||||
| <form style="margin-top: 1em;"> | ||||
| 	<div id="radioset"> | ||||
| 		<input type="radio" id="radio1" name="radio"><label for="radio1">Choice 1</label> | ||||
| 		<input type="radio" id="radio2" name="radio" checked="checked"><label for="radio2">Choice 2</label> | ||||
| 		<input type="radio" id="radio3" name="radio"><label for="radio3">Choice 3</label> | ||||
| 	</div> | ||||
| </form> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Controlgroup --> | ||||
| <h2 class="demoHeaders">Controlgroup</h2> | ||||
| <fieldset> | ||||
| 	<legend>Rental Car</legend> | ||||
| 	<div id="controlgroup"> | ||||
| 		<select id="car-type"> | ||||
| 			<option>Compact car</option> | ||||
| 			<option>Midsize car</option> | ||||
| 			<option>Full size car</option> | ||||
| 			<option>SUV</option> | ||||
| 			<option>Luxury</option> | ||||
| 			<option>Truck</option> | ||||
| 			<option>Van</option> | ||||
| 		</select> | ||||
| 		<label for="transmission-standard">Standard</label> | ||||
| 		<input type="radio" name="transmission" id="transmission-standard"> | ||||
| 		<label for="transmission-automatic">Automatic</label> | ||||
| 		<input type="radio" name="transmission" id="transmission-automatic"> | ||||
| 		<label for="insurance">Insurance</label> | ||||
| 		<input type="checkbox" name="insurance" id="insurance"> | ||||
| 		<label for="horizontal-spinner" class="ui-controlgroup-label"># of cars</label> | ||||
| 		<input id="horizontal-spinner" class="ui-spinner-input"> | ||||
| 		<button>Book Now!</button> | ||||
| 	</div> | ||||
| </fieldset> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Tabs --> | ||||
| <h2 class="demoHeaders">Tabs</h2> | ||||
| <div id="tabs"> | ||||
| 	<ul> | ||||
| 		<li><a href="#tabs-1">First</a></li> | ||||
| 		<li><a href="#tabs-2">Second</a></li> | ||||
| 		<li><a href="#tabs-3">Third</a></li> | ||||
| 	</ul> | ||||
| 	<div id="tabs-1">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</div> | ||||
| 	<div id="tabs-2">Phasellus mattis tincidunt nibh. Cras orci urna, blandit id, pretium vel, aliquet ornare, felis. Maecenas scelerisque sem non nisl. Fusce sed lorem in enim dictum bibendum.</div> | ||||
| 	<div id="tabs-3">Nam dui erat, auctor a, dignissim quis, sollicitudin eu, felis. Pellentesque nisi urna, interdum eget, sagittis et, consequat vestibulum, lacus. Mauris porttitor ullamcorper augue.</div> | ||||
| </div> | ||||
|  | ||||
|  | ||||
|  | ||||
| <h2 class="demoHeaders">Dialog</h2> | ||||
| <p> | ||||
| 	<button id="dialog-link" class="ui-button ui-corner-all ui-widget"> | ||||
| 		<span class="ui-icon ui-icon-newwin"></span>Open Dialog | ||||
| 	</button> | ||||
| </p> | ||||
|  | ||||
| <h2 class="demoHeaders">Overlay and Shadow Classes</h2> | ||||
| <div style="position: relative; width: 96%; height: 200px; padding:1% 2%; overflow:hidden;" class="fakewindowcontain"> | ||||
| 	<p>Lorem ipsum dolor sit amet,  Nulla nec tortor. Donec id elit quis purus consectetur consequat. </p><p>Nam congue semper tellus. Sed erat dolor, dapibus sit amet, venenatis ornare, ultrices ut, nisi. Aliquam ante. Suspendisse scelerisque dui nec velit. Duis augue augue, gravida euismod, vulputate ac, facilisis id, sem. Morbi in orci. </p><p>Nulla purus lacus, pulvinar vel, malesuada ac, mattis nec, quam. Nam molestie scelerisque quam. Nullam feugiat cursus lacus.orem ipsum dolor sit amet, consectetur adipiscing elit. Donec libero risus, commodo vitae, pharetra mollis, posuere eu, pede. Nulla nec tortor. Donec id elit quis purus consectetur consequat. </p><p>Nam congue semper tellus. Sed erat dolor, dapibus sit amet, venenatis ornare, ultrices ut, nisi. Aliquam ante. Suspendisse scelerisque dui nec velit. Duis augue augue, gravida euismod, vulputate ac, facilisis id, sem. Morbi in orci. Nulla purus lacus, pulvinar vel, malesuada ac, mattis nec, quam. Nam molestie scelerisque quam. </p><p>Nullam feugiat cursus lacus.orem ipsum dolor sit amet, consectetur adipiscing elit. Donec libero risus, commodo vitae, pharetra mollis, posuere eu, pede. Nulla nec tortor. Donec id elit quis purus consectetur consequat. Nam congue semper tellus. Sed erat dolor, dapibus sit amet, venenatis ornare, ultrices ut, nisi. Aliquam ante. </p><p>Suspendisse scelerisque dui nec velit. Duis augue augue, gravida euismod, vulputate ac, facilisis id, sem. Morbi in orci. Nulla purus lacus, pulvinar vel, malesuada ac, mattis nec, quam. Nam molestie scelerisque quam. Nullam feugiat cursus lacus.orem ipsum dolor sit amet, consectetur adipiscing elit. Donec libero risus, commodo vitae, pharetra mollis, posuere eu, pede. Nulla nec tortor. Donec id elit quis purus consectetur consequat. Nam congue semper tellus. Sed erat dolor, dapibus sit amet, venenatis ornare, ultrices ut, nisi. </p> | ||||
|  | ||||
| 	<!-- ui-dialog --> | ||||
| 	<div class="ui-widget-overlay ui-front"></div> | ||||
| 	<div style="position: absolute; width: 320px; left: 50px; top: 30px; padding: 1.2em" class="ui-widget ui-front ui-widget-content ui-corner-all ui-widget-shadow"> | ||||
| 		Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. | ||||
| 	</div> | ||||
|  | ||||
| </div> | ||||
|  | ||||
| <!-- ui-dialog --> | ||||
| <div id="dialog" title="Dialog Title"> | ||||
| 	<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p> | ||||
| </div> | ||||
|  | ||||
|  | ||||
|  | ||||
| <h2 class="demoHeaders">Framework Icons (content color preview)</h2> | ||||
| <ul id="icons" class="ui-widget ui-helper-clearfix"> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-n"><span class="ui-icon ui-icon-caret-1-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-ne"><span class="ui-icon ui-icon-caret-1-ne"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-e"><span class="ui-icon ui-icon-caret-1-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-se"><span class="ui-icon ui-icon-caret-1-se"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-s"><span class="ui-icon ui-icon-caret-1-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-sw"><span class="ui-icon ui-icon-caret-1-sw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-w"><span class="ui-icon ui-icon-caret-1-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-nw"><span class="ui-icon ui-icon-caret-1-nw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-2-n-s"><span class="ui-icon ui-icon-caret-2-n-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-2-e-w"><span class="ui-icon ui-icon-caret-2-e-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-n"><span class="ui-icon ui-icon-triangle-1-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-ne"><span class="ui-icon ui-icon-triangle-1-ne"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-e"><span class="ui-icon ui-icon-triangle-1-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-se"><span class="ui-icon ui-icon-triangle-1-se"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-s"><span class="ui-icon ui-icon-triangle-1-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-sw"><span class="ui-icon ui-icon-triangle-1-sw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-w"><span class="ui-icon ui-icon-triangle-1-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-nw"><span class="ui-icon ui-icon-triangle-1-nw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-2-n-s"><span class="ui-icon ui-icon-triangle-2-n-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-2-e-w"><span class="ui-icon ui-icon-triangle-2-e-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-n"><span class="ui-icon ui-icon-arrow-1-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-ne"><span class="ui-icon ui-icon-arrow-1-ne"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-e"><span class="ui-icon ui-icon-arrow-1-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-se"><span class="ui-icon ui-icon-arrow-1-se"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-s"><span class="ui-icon ui-icon-arrow-1-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-sw"><span class="ui-icon ui-icon-arrow-1-sw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-w"><span class="ui-icon ui-icon-arrow-1-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-nw"><span class="ui-icon ui-icon-arrow-1-nw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-2-n-s"><span class="ui-icon ui-icon-arrow-2-n-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-2-ne-sw"><span class="ui-icon ui-icon-arrow-2-ne-sw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-2-e-w"><span class="ui-icon ui-icon-arrow-2-e-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-2-se-nw"><span class="ui-icon ui-icon-arrow-2-se-nw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowstop-1-n"><span class="ui-icon ui-icon-arrowstop-1-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowstop-1-e"><span class="ui-icon ui-icon-arrowstop-1-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowstop-1-s"><span class="ui-icon ui-icon-arrowstop-1-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowstop-1-w"><span class="ui-icon ui-icon-arrowstop-1-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-n"><span class="ui-icon ui-icon-arrowthick-1-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-ne"><span class="ui-icon ui-icon-arrowthick-1-ne"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-e"><span class="ui-icon ui-icon-arrowthick-1-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-se"><span class="ui-icon ui-icon-arrowthick-1-se"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-s"><span class="ui-icon ui-icon-arrowthick-1-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-sw"><span class="ui-icon ui-icon-arrowthick-1-sw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-w"><span class="ui-icon ui-icon-arrowthick-1-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-nw"><span class="ui-icon ui-icon-arrowthick-1-nw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-2-n-s"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-2-ne-sw"><span class="ui-icon ui-icon-arrowthick-2-ne-sw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-2-e-w"><span class="ui-icon ui-icon-arrowthick-2-e-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-2-se-nw"><span class="ui-icon ui-icon-arrowthick-2-se-nw"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthickstop-1-n"><span class="ui-icon ui-icon-arrowthickstop-1-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthickstop-1-e"><span class="ui-icon ui-icon-arrowthickstop-1-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthickstop-1-s"><span class="ui-icon ui-icon-arrowthickstop-1-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthickstop-1-w"><span class="ui-icon ui-icon-arrowthickstop-1-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturnthick-1-w"><span class="ui-icon ui-icon-arrowreturnthick-1-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturnthick-1-n"><span class="ui-icon ui-icon-arrowreturnthick-1-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturnthick-1-e"><span class="ui-icon ui-icon-arrowreturnthick-1-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturnthick-1-s"><span class="ui-icon ui-icon-arrowreturnthick-1-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturn-1-w"><span class="ui-icon ui-icon-arrowreturn-1-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturn-1-n"><span class="ui-icon ui-icon-arrowreturn-1-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturn-1-e"><span class="ui-icon ui-icon-arrowreturn-1-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturn-1-s"><span class="ui-icon ui-icon-arrowreturn-1-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowrefresh-1-w"><span class="ui-icon ui-icon-arrowrefresh-1-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowrefresh-1-n"><span class="ui-icon ui-icon-arrowrefresh-1-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowrefresh-1-e"><span class="ui-icon ui-icon-arrowrefresh-1-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowrefresh-1-s"><span class="ui-icon ui-icon-arrowrefresh-1-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-4"><span class="ui-icon ui-icon-arrow-4"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-4-diag"><span class="ui-icon ui-icon-arrow-4-diag"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-extlink"><span class="ui-icon ui-icon-extlink"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-newwin"><span class="ui-icon ui-icon-newwin"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-refresh"><span class="ui-icon ui-icon-refresh"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-shuffle"><span class="ui-icon ui-icon-shuffle"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-transfer-e-w"><span class="ui-icon ui-icon-transfer-e-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-transferthick-e-w"><span class="ui-icon ui-icon-transferthick-e-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-folder-collapsed"><span class="ui-icon ui-icon-folder-collapsed"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-folder-open"><span class="ui-icon ui-icon-folder-open"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-document"><span class="ui-icon ui-icon-document"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-document-b"><span class="ui-icon ui-icon-document-b"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-note"><span class="ui-icon ui-icon-note"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-mail-closed"><span class="ui-icon ui-icon-mail-closed"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-mail-open"><span class="ui-icon ui-icon-mail-open"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-suitcase"><span class="ui-icon ui-icon-suitcase"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-comment"><span class="ui-icon ui-icon-comment"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-person"><span class="ui-icon ui-icon-person"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-print"><span class="ui-icon ui-icon-print"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-trash"><span class="ui-icon ui-icon-trash"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-locked"><span class="ui-icon ui-icon-locked"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-unlocked"><span class="ui-icon ui-icon-unlocked"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-bookmark"><span class="ui-icon ui-icon-bookmark"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-tag"><span class="ui-icon ui-icon-tag"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-home"><span class="ui-icon ui-icon-home"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-flag"><span class="ui-icon ui-icon-flag"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-calculator"><span class="ui-icon ui-icon-calculator"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-cart"><span class="ui-icon ui-icon-cart"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-pencil"><span class="ui-icon ui-icon-pencil"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-clock"><span class="ui-icon ui-icon-clock"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-disk"><span class="ui-icon ui-icon-disk"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-calendar"><span class="ui-icon ui-icon-calendar"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-zoomin"><span class="ui-icon ui-icon-zoomin"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-zoomout"><span class="ui-icon ui-icon-zoomout"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-search"><span class="ui-icon ui-icon-search"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-wrench"><span class="ui-icon ui-icon-wrench"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-gear"><span class="ui-icon ui-icon-gear"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-heart"><span class="ui-icon ui-icon-heart"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-star"><span class="ui-icon ui-icon-star"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-link"><span class="ui-icon ui-icon-link"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-cancel"><span class="ui-icon ui-icon-cancel"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-plus"><span class="ui-icon ui-icon-plus"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-plusthick"><span class="ui-icon ui-icon-plusthick"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-minus"><span class="ui-icon ui-icon-minus"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-minusthick"><span class="ui-icon ui-icon-minusthick"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-close"><span class="ui-icon ui-icon-close"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-closethick"><span class="ui-icon ui-icon-closethick"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-key"><span class="ui-icon ui-icon-key"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-lightbulb"><span class="ui-icon ui-icon-lightbulb"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-scissors"><span class="ui-icon ui-icon-scissors"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-clipboard"><span class="ui-icon ui-icon-clipboard"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-copy"><span class="ui-icon ui-icon-copy"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-contact"><span class="ui-icon ui-icon-contact"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-image"><span class="ui-icon ui-icon-image"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-video"><span class="ui-icon ui-icon-video"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-script"><span class="ui-icon ui-icon-script"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-alert"><span class="ui-icon ui-icon-alert"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-info"><span class="ui-icon ui-icon-info"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-notice"><span class="ui-icon ui-icon-notice"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-help"><span class="ui-icon ui-icon-help"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-check"><span class="ui-icon ui-icon-check"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-bullet"><span class="ui-icon ui-icon-bullet"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-radio-off"><span class="ui-icon ui-icon-radio-off"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-radio-on"><span class="ui-icon ui-icon-radio-on"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-pin-w"><span class="ui-icon ui-icon-pin-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-pin-s"><span class="ui-icon ui-icon-pin-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-play"><span class="ui-icon ui-icon-play"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-pause"><span class="ui-icon ui-icon-pause"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-seek-next"><span class="ui-icon ui-icon-seek-next"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-seek-prev"><span class="ui-icon ui-icon-seek-prev"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-seek-end"><span class="ui-icon ui-icon-seek-end"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-seek-first"><span class="ui-icon ui-icon-seek-first"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-stop"><span class="ui-icon ui-icon-stop"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-eject"><span class="ui-icon ui-icon-eject"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-volume-off"><span class="ui-icon ui-icon-volume-off"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-volume-on"><span class="ui-icon ui-icon-volume-on"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-power"><span class="ui-icon ui-icon-power"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-signal-diag"><span class="ui-icon ui-icon-signal-diag"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-signal"><span class="ui-icon ui-icon-signal"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-battery-0"><span class="ui-icon ui-icon-battery-0"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-battery-1"><span class="ui-icon ui-icon-battery-1"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-battery-2"><span class="ui-icon ui-icon-battery-2"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-battery-3"><span class="ui-icon ui-icon-battery-3"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-plus"><span class="ui-icon ui-icon-circle-plus"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-minus"><span class="ui-icon ui-icon-circle-minus"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-close"><span class="ui-icon ui-icon-circle-close"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-triangle-e"><span class="ui-icon ui-icon-circle-triangle-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-triangle-s"><span class="ui-icon ui-icon-circle-triangle-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-triangle-w"><span class="ui-icon ui-icon-circle-triangle-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-triangle-n"><span class="ui-icon ui-icon-circle-triangle-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-arrow-e"><span class="ui-icon ui-icon-circle-arrow-e"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-arrow-s"><span class="ui-icon ui-icon-circle-arrow-s"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-arrow-w"><span class="ui-icon ui-icon-circle-arrow-w"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-arrow-n"><span class="ui-icon ui-icon-circle-arrow-n"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-zoomin"><span class="ui-icon ui-icon-circle-zoomin"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-zoomout"><span class="ui-icon ui-icon-circle-zoomout"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-check"><span class="ui-icon ui-icon-circle-check"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circlesmall-plus"><span class="ui-icon ui-icon-circlesmall-plus"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circlesmall-minus"><span class="ui-icon ui-icon-circlesmall-minus"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-circlesmall-close"><span class="ui-icon ui-icon-circlesmall-close"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-squaresmall-plus"><span class="ui-icon ui-icon-squaresmall-plus"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-squaresmall-minus"><span class="ui-icon ui-icon-squaresmall-minus"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-squaresmall-close"><span class="ui-icon ui-icon-squaresmall-close"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-dotted-vertical"><span class="ui-icon ui-icon-grip-dotted-vertical"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-dotted-horizontal"><span class="ui-icon ui-icon-grip-dotted-horizontal"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-solid-vertical"><span class="ui-icon ui-icon-grip-solid-vertical"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-solid-horizontal"><span class="ui-icon ui-icon-grip-solid-horizontal"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-gripsmall-diagonal-se"><span class="ui-icon ui-icon-gripsmall-diagonal-se"></span></li> | ||||
| 	<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-diagonal-se"><span class="ui-icon ui-icon-grip-diagonal-se"></span></li> | ||||
| </ul> | ||||
|  | ||||
|  | ||||
| <!-- Slider --> | ||||
| <h2 class="demoHeaders">Slider</h2> | ||||
| <div id="slider"></div> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Datepicker --> | ||||
| <h2 class="demoHeaders">Datepicker</h2> | ||||
| <div id="datepicker"></div> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Progressbar --> | ||||
| <h2 class="demoHeaders">Progressbar</h2> | ||||
| <div id="progressbar"></div> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Progressbar --> | ||||
| <h2 class="demoHeaders">Selectmenu</h2> | ||||
| <select id="selectmenu"> | ||||
| 	<option>Slower</option> | ||||
| 	<option>Slow</option> | ||||
| 	<option selected="selected">Medium</option> | ||||
| 	<option>Fast</option> | ||||
| 	<option>Faster</option> | ||||
| </select> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Spinner --> | ||||
| <h2 class="demoHeaders">Spinner</h2> | ||||
| <input id="spinner"> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Menu --> | ||||
| <h2 class="demoHeaders">Menu</h2> | ||||
| <ul style="width:100px;" id="menu"> | ||||
| 	<li><div>Item 1</div></li> | ||||
| 	<li><div>Item 2</div></li> | ||||
| 	<li><div>Item 3</div> | ||||
| 		<ul> | ||||
| 			<li><div>Item 3-1</div></li> | ||||
| 			<li><div>Item 3-2</div></li> | ||||
| 			<li><div>Item 3-3</div></li> | ||||
| 			<li><div>Item 3-4</div></li> | ||||
| 			<li><div>Item 3-5</div></li> | ||||
| 		</ul> | ||||
| 	</li> | ||||
| 	<li><div>Item 4</div></li> | ||||
| 	<li><div>Item 5</div></li> | ||||
| </ul> | ||||
|  | ||||
|  | ||||
|  | ||||
| <!-- Tooltip --> | ||||
| <h2 class="demoHeaders">Tooltip</h2> | ||||
| <p id="tooltip"> | ||||
| 	<a href="#" title="That's what this widget is">Tooltips</a> can be attached to any element. When you hover | ||||
| the element with your mouse, the title attribute is displayed in a little box next to the element, just like a native tooltip. | ||||
| </p> | ||||
|  | ||||
|  | ||||
| <!-- Highlight / Error --> | ||||
| <h2 class="demoHeaders">Highlight / Error</h2> | ||||
| <div class="ui-widget"> | ||||
| 	<div class="ui-state-highlight ui-corner-all" style="margin-top: 20px; padding: 0 .7em;"> | ||||
| 		<p><span class="ui-icon ui-icon-info" style="float: left; margin-right: .3em;"></span> | ||||
| 		<strong>Hey!</strong> Sample ui-state-highlight style.</p> | ||||
| 	</div> | ||||
| </div> | ||||
| <br> | ||||
| <div class="ui-widget"> | ||||
| 	<div class="ui-state-error ui-corner-all" style="padding: 0 .7em;"> | ||||
| 		<p><span class="ui-icon ui-icon-alert" style="float: left; margin-right: .3em;"></span> | ||||
| 		<strong>Alert:</strong> Sample ui-state-error style.</p> | ||||
| 	</div> | ||||
| </div> | ||||
|  | ||||
| <script src="external/jquery/jquery.js"></script> | ||||
| <script src="jquery-ui.js"></script> | ||||
| <script> | ||||
|  | ||||
| $( "#accordion" ).accordion(); | ||||
|  | ||||
|  | ||||
|  | ||||
| var availableTags = [ | ||||
| 	"ActionScript", | ||||
| 	"AppleScript", | ||||
| 	"Asp", | ||||
| 	"BASIC", | ||||
| 	"C", | ||||
| 	"C++", | ||||
| 	"Clojure", | ||||
| 	"COBOL", | ||||
| 	"ColdFusion", | ||||
| 	"Erlang", | ||||
| 	"Fortran", | ||||
| 	"Groovy", | ||||
| 	"Haskell", | ||||
| 	"Java", | ||||
| 	"JavaScript", | ||||
| 	"Lisp", | ||||
| 	"Perl", | ||||
| 	"PHP", | ||||
| 	"Python", | ||||
| 	"Ruby", | ||||
| 	"Scala", | ||||
| 	"Scheme" | ||||
| ]; | ||||
| $( "#autocomplete" ).autocomplete({ | ||||
| 	source: availableTags | ||||
| }); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#button" ).button(); | ||||
| $( "#button-icon" ).button({ | ||||
| 	icon: "ui-icon-gear", | ||||
| 	showLabel: false | ||||
| }); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#radioset" ).buttonset(); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#controlgroup" ).controlgroup(); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#tabs" ).tabs(); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#dialog" ).dialog({ | ||||
| 	autoOpen: false, | ||||
| 	width: 400, | ||||
| 	buttons: [ | ||||
| 		{ | ||||
| 			text: "Ok", | ||||
| 			click: function() { | ||||
| 				$( this ).dialog( "close" ); | ||||
| 			} | ||||
| 		}, | ||||
| 		{ | ||||
| 			text: "Cancel", | ||||
| 			click: function() { | ||||
| 				$( this ).dialog( "close" ); | ||||
| 			} | ||||
| 		} | ||||
| 	] | ||||
| }); | ||||
|  | ||||
| // Link to open the dialog | ||||
| $( "#dialog-link" ).click(function( event ) { | ||||
| 	$( "#dialog" ).dialog( "open" ); | ||||
| 	event.preventDefault(); | ||||
| }); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#datepicker" ).datepicker({ | ||||
| 	inline: true | ||||
| }); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#slider" ).slider({ | ||||
| 	range: true, | ||||
| 	values: [ 17, 67 ] | ||||
| }); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#progressbar" ).progressbar({ | ||||
| 	value: 20 | ||||
| }); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#spinner" ).spinner(); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#menu" ).menu(); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#tooltip" ).tooltip(); | ||||
|  | ||||
|  | ||||
|  | ||||
| $( "#selectmenu" ).selectmenu(); | ||||
|  | ||||
|  | ||||
| // Hover states on the static widgets | ||||
| $( "#dialog-link, #icons li" ).hover( | ||||
| 	function() { | ||||
| 		$( this ).addClass( "ui-state-hover" ); | ||||
| 	}, | ||||
| 	function() { | ||||
| 		$( this ).removeClass( "ui-state-hover" ); | ||||
| 	} | ||||
| ); | ||||
| </script> | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										1313
									
								
								core/static/core/js/ui/jquery-ui.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										18686
									
								
								core/static/core/js/ui/jquery-ui.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										7
									
								
								core/static/core/js/ui/jquery-ui.min.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										13
									
								
								core/static/core/js/ui/jquery-ui.min.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										886
									
								
								core/static/core/js/ui/jquery-ui.structure.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,886 @@ | ||||
| /*! | ||||
|  * jQuery UI CSS Framework 1.12.0 | ||||
|  * http://jqueryui.com | ||||
|  * | ||||
|  * Copyright jQuery Foundation and other contributors | ||||
|  * Released under the MIT license. | ||||
|  * http://jquery.org/license | ||||
|  * | ||||
|  * http://api.jqueryui.com/category/theming/ | ||||
|  */ | ||||
| .ui-draggable-handle { | ||||
| 	-ms-touch-action: none; | ||||
| 	touch-action: none; | ||||
| } | ||||
| /* Layout helpers | ||||
| ----------------------------------*/ | ||||
| .ui-helper-hidden { | ||||
| 	display: none; | ||||
| } | ||||
| .ui-helper-hidden-accessible { | ||||
| 	border: 0; | ||||
| 	clip: rect(0 0 0 0); | ||||
| 	height: 1px; | ||||
| 	margin: -1px; | ||||
| 	overflow: hidden; | ||||
| 	padding: 0; | ||||
| 	position: absolute; | ||||
| 	width: 1px; | ||||
| } | ||||
| .ui-helper-reset { | ||||
| 	margin: 0; | ||||
| 	padding: 0; | ||||
| 	border: 0; | ||||
| 	outline: 0; | ||||
| 	line-height: 1.3; | ||||
| 	text-decoration: none; | ||||
| 	font-size: 100%; | ||||
| 	list-style: none; | ||||
| } | ||||
| .ui-helper-clearfix:before, | ||||
| .ui-helper-clearfix:after { | ||||
| 	content: ""; | ||||
| 	display: table; | ||||
| 	border-collapse: collapse; | ||||
| } | ||||
| .ui-helper-clearfix:after { | ||||
| 	clear: both; | ||||
| } | ||||
| .ui-helper-zfix { | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	position: absolute; | ||||
| 	opacity: 0; | ||||
| 	filter:Alpha(Opacity=0); /* support: IE8 */ | ||||
| } | ||||
|  | ||||
| .ui-front { | ||||
| 	z-index: 100; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-disabled { | ||||
| 	cursor: default !important; | ||||
| 	pointer-events: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
| .ui-icon { | ||||
| 	display: inline-block; | ||||
| 	vertical-align: middle; | ||||
| 	margin-top: -.25em; | ||||
| 	position: relative; | ||||
| 	text-indent: -99999px; | ||||
| 	overflow: hidden; | ||||
| 	background-repeat: no-repeat; | ||||
| } | ||||
|  | ||||
| .ui-widget-icon-block { | ||||
| 	left: 50%; | ||||
| 	margin-left: -8px; | ||||
| 	display: block; | ||||
| } | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	position: fixed; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| } | ||||
| .ui-resizable { | ||||
| 	position: relative; | ||||
| } | ||||
| .ui-resizable-handle { | ||||
| 	position: absolute; | ||||
| 	font-size: 0.1px; | ||||
| 	display: block; | ||||
| 	-ms-touch-action: none; | ||||
| 	touch-action: none; | ||||
| } | ||||
| .ui-resizable-disabled .ui-resizable-handle, | ||||
| .ui-resizable-autohide .ui-resizable-handle { | ||||
| 	display: none; | ||||
| } | ||||
| .ui-resizable-n { | ||||
| 	cursor: n-resize; | ||||
| 	height: 7px; | ||||
| 	width: 100%; | ||||
| 	top: -5px; | ||||
| 	left: 0; | ||||
| } | ||||
| .ui-resizable-s { | ||||
| 	cursor: s-resize; | ||||
| 	height: 7px; | ||||
| 	width: 100%; | ||||
| 	bottom: -5px; | ||||
| 	left: 0; | ||||
| } | ||||
| .ui-resizable-e { | ||||
| 	cursor: e-resize; | ||||
| 	width: 7px; | ||||
| 	right: -5px; | ||||
| 	top: 0; | ||||
| 	height: 100%; | ||||
| } | ||||
| .ui-resizable-w { | ||||
| 	cursor: w-resize; | ||||
| 	width: 7px; | ||||
| 	left: -5px; | ||||
| 	top: 0; | ||||
| 	height: 100%; | ||||
| } | ||||
| .ui-resizable-se { | ||||
| 	cursor: se-resize; | ||||
| 	width: 12px; | ||||
| 	height: 12px; | ||||
| 	right: 1px; | ||||
| 	bottom: 1px; | ||||
| } | ||||
| .ui-resizable-sw { | ||||
| 	cursor: sw-resize; | ||||
| 	width: 9px; | ||||
| 	height: 9px; | ||||
| 	left: -5px; | ||||
| 	bottom: -5px; | ||||
| } | ||||
| .ui-resizable-nw { | ||||
| 	cursor: nw-resize; | ||||
| 	width: 9px; | ||||
| 	height: 9px; | ||||
| 	left: -5px; | ||||
| 	top: -5px; | ||||
| } | ||||
| .ui-resizable-ne { | ||||
| 	cursor: ne-resize; | ||||
| 	width: 9px; | ||||
| 	height: 9px; | ||||
| 	right: -5px; | ||||
| 	top: -5px; | ||||
| } | ||||
| .ui-selectable { | ||||
| 	-ms-touch-action: none; | ||||
| 	touch-action: none; | ||||
| } | ||||
| .ui-selectable-helper { | ||||
| 	position: absolute; | ||||
| 	z-index: 100; | ||||
| 	border: 1px dotted black; | ||||
| } | ||||
| .ui-sortable-handle { | ||||
| 	-ms-touch-action: none; | ||||
| 	touch-action: none; | ||||
| } | ||||
| .ui-accordion .ui-accordion-header { | ||||
| 	display: block; | ||||
| 	cursor: pointer; | ||||
| 	position: relative; | ||||
| 	margin: 2px 0 0 0; | ||||
| 	padding: .5em .5em .5em .7em; | ||||
| 	font-size: 100%; | ||||
| } | ||||
| .ui-accordion .ui-accordion-content { | ||||
| 	padding: 1em 2.2em; | ||||
| 	border-top: 0; | ||||
| 	overflow: auto; | ||||
| } | ||||
| .ui-autocomplete { | ||||
| 	position: absolute; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	cursor: default; | ||||
| } | ||||
| .ui-menu { | ||||
| 	list-style: none; | ||||
| 	padding: 0; | ||||
| 	margin: 0; | ||||
| 	display: block; | ||||
| 	outline: 0; | ||||
| } | ||||
| .ui-menu .ui-menu { | ||||
| 	position: absolute; | ||||
| } | ||||
| .ui-menu .ui-menu-item { | ||||
| 	margin: 0; | ||||
| 	cursor: pointer; | ||||
| 	/* support: IE10, see #8844 */ | ||||
| 	list-style-image: url("data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7"); | ||||
| } | ||||
| .ui-menu .ui-menu-item-wrapper { | ||||
| 	position: relative; | ||||
| 	padding: 3px 1em 3px .4em; | ||||
| } | ||||
| .ui-menu .ui-menu-divider { | ||||
| 	margin: 5px 0; | ||||
| 	height: 0; | ||||
| 	font-size: 0; | ||||
| 	line-height: 0; | ||||
| 	border-width: 1px 0 0 0; | ||||
| } | ||||
| .ui-menu .ui-state-focus, | ||||
| .ui-menu .ui-state-active { | ||||
| 	margin: -1px; | ||||
| } | ||||
|  | ||||
| /* icon support */ | ||||
| .ui-menu-icons { | ||||
| 	position: relative; | ||||
| } | ||||
| .ui-menu-icons .ui-menu-item-wrapper { | ||||
| 	padding-left: 2em; | ||||
| } | ||||
|  | ||||
| /* left-aligned */ | ||||
| .ui-menu .ui-icon { | ||||
| 	position: absolute; | ||||
| 	top: 0; | ||||
| 	bottom: 0; | ||||
| 	left: .2em; | ||||
| 	margin: auto 0; | ||||
| } | ||||
|  | ||||
| /* right-aligned */ | ||||
| .ui-menu .ui-menu-icon { | ||||
| 	left: auto; | ||||
| 	right: 0; | ||||
| } | ||||
| .ui-button { | ||||
| 	padding: .4em 1em; | ||||
| 	display: inline-block; | ||||
| 	position: relative; | ||||
| 	line-height: normal; | ||||
| 	margin-right: .1em; | ||||
| 	cursor: pointer; | ||||
| 	vertical-align: middle; | ||||
| 	text-align: center; | ||||
| 	-webkit-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-ms-user-select: none; | ||||
| 	user-select: none; | ||||
|  | ||||
| 	/* Support: IE <= 11 */ | ||||
| 	overflow: visible; | ||||
| } | ||||
|  | ||||
| .ui-button, | ||||
| .ui-button:link, | ||||
| .ui-button:visited, | ||||
| .ui-button:hover, | ||||
| .ui-button:active { | ||||
| 	text-decoration: none; | ||||
| } | ||||
|  | ||||
| /* to make room for the icon, a width needs to be set here */ | ||||
| .ui-button-icon-only { | ||||
| 	width: 2em; | ||||
| 	box-sizing: border-box; | ||||
| 	text-indent: -9999px; | ||||
| 	white-space: nowrap; | ||||
| } | ||||
|  | ||||
| /* no icon support for input elements */ | ||||
| input.ui-button.ui-button-icon-only { | ||||
| 	text-indent: 0; | ||||
| } | ||||
|  | ||||
| /* button icon element(s) */ | ||||
| .ui-button-icon-only .ui-icon { | ||||
| 	position: absolute; | ||||
| 	top: 50%; | ||||
| 	left: 50%; | ||||
| 	margin-top: -8px; | ||||
| 	margin-left: -8px; | ||||
| } | ||||
|  | ||||
| .ui-button.ui-icon-notext .ui-icon { | ||||
| 	padding: 0; | ||||
| 	width: 2.1em; | ||||
| 	height: 2.1em; | ||||
| 	text-indent: -9999px; | ||||
| 	white-space: nowrap; | ||||
|  | ||||
| } | ||||
|  | ||||
| input.ui-button.ui-icon-notext .ui-icon { | ||||
| 	width: auto; | ||||
| 	height: auto; | ||||
| 	text-indent: 0; | ||||
| 	white-space: normal; | ||||
| 	padding: .4em 1em; | ||||
| } | ||||
|  | ||||
| /* workarounds */ | ||||
| /* Support: Firefox 5 - 40 */ | ||||
| input.ui-button::-moz-focus-inner, | ||||
| button.ui-button::-moz-focus-inner { | ||||
| 	border: 0; | ||||
| 	padding: 0; | ||||
| } | ||||
| .ui-controlgroup { | ||||
| 	vertical-align: middle; | ||||
| 	display: inline-block; | ||||
| } | ||||
| .ui-controlgroup > .ui-controlgroup-item { | ||||
| 	float: left; | ||||
| 	margin-left: 0; | ||||
| 	margin-right: 0; | ||||
| } | ||||
| .ui-controlgroup > .ui-controlgroup-item:focus, | ||||
| .ui-controlgroup > .ui-controlgroup-item.ui-visual-focus { | ||||
| 	z-index: 9999; | ||||
| } | ||||
| .ui-controlgroup-vertical > .ui-controlgroup-item { | ||||
| 	display: block; | ||||
| 	float: none; | ||||
| 	width: 100%; | ||||
| 	margin-top: 0; | ||||
| 	margin-bottom: 0; | ||||
| 	text-align: left; | ||||
| } | ||||
| .ui-controlgroup-vertical .ui-controlgroup-item { | ||||
| 	box-sizing: border-box; | ||||
| } | ||||
| .ui-controlgroup .ui-controlgroup-label { | ||||
| 	padding: .4em 1em; | ||||
| } | ||||
| .ui-controlgroup .ui-controlgroup-label span { | ||||
| 	font-size: 80%; | ||||
| } | ||||
| .ui-controlgroup-horizontal .ui-controlgroup-label + .ui-controlgroup-item { | ||||
| 	border-left: none; | ||||
| } | ||||
| .ui-controlgroup-vertical .ui-controlgroup-label + .ui-controlgroup-item { | ||||
| 	border-top: none; | ||||
| } | ||||
| .ui-controlgroup-horizontal .ui-controlgroup-label.ui-widget-content { | ||||
| 	border-right: none; | ||||
| } | ||||
| .ui-controlgroup-vertical .ui-controlgroup-label.ui-widget-content { | ||||
| 	border-bottom: none; | ||||
| } | ||||
|  | ||||
| /* Spinner specific style fixes */ | ||||
| .ui-controlgroup-vertical .ui-spinner-input { | ||||
|  | ||||
| 	/* Support: IE8 only, Android < 4.4 only */ | ||||
| 	width: 75%; | ||||
| 	width: calc( 100% - 2.4em ); | ||||
| } | ||||
| .ui-controlgroup-vertical .ui-spinner .ui-spinner-up { | ||||
| 	border-top-style: solid; | ||||
| } | ||||
|  | ||||
| .ui-checkboxradio-label .ui-icon-background { | ||||
| 	box-shadow: inset 1px 1px 1px #ccc; | ||||
| 	border-radius: .12em; | ||||
| 	border: none; | ||||
| } | ||||
| .ui-checkboxradio-radio-label .ui-icon-background { | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	border-radius: 1em; | ||||
| 	overflow: visible; | ||||
| 	border: none; | ||||
| } | ||||
| .ui-checkboxradio-radio-label.ui-checkboxradio-checked .ui-icon, | ||||
| .ui-checkboxradio-radio-label.ui-checkboxradio-checked:hover .ui-icon { | ||||
| 	background-image: none; | ||||
| 	width: 8px; | ||||
| 	height: 8px; | ||||
| 	border-width: 4px; | ||||
| 	border-style: solid; | ||||
| } | ||||
| .ui-checkboxradio-disabled { | ||||
| 	pointer-events: none; | ||||
| } | ||||
| .ui-datepicker { | ||||
| 	width: 17em; | ||||
| 	padding: .2em .2em 0; | ||||
| 	display: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-header { | ||||
| 	position: relative; | ||||
| 	padding: .2em 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev, | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	position: absolute; | ||||
| 	top: 2px; | ||||
| 	width: 1.8em; | ||||
| 	height: 1.8em; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover, | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	top: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev { | ||||
| 	left: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next { | ||||
| 	right: 2px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev-hover { | ||||
| 	left: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-next-hover { | ||||
| 	right: 1px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-prev span, | ||||
| .ui-datepicker .ui-datepicker-next span { | ||||
| 	display: block; | ||||
| 	position: absolute; | ||||
| 	left: 50%; | ||||
| 	margin-left: -8px; | ||||
| 	top: 50%; | ||||
| 	margin-top: -8px; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title { | ||||
| 	margin: 0 2.3em; | ||||
| 	line-height: 1.8em; | ||||
| 	text-align: center; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-title select { | ||||
| 	font-size: 1em; | ||||
| 	margin: 1px 0; | ||||
| } | ||||
| .ui-datepicker select.ui-datepicker-month, | ||||
| .ui-datepicker select.ui-datepicker-year { | ||||
| 	width: 45%; | ||||
| } | ||||
| .ui-datepicker table { | ||||
| 	width: 100%; | ||||
| 	font-size: .9em; | ||||
| 	border-collapse: collapse; | ||||
| 	margin: 0 0 .4em; | ||||
| } | ||||
| .ui-datepicker th { | ||||
| 	padding: .7em .3em; | ||||
| 	text-align: center; | ||||
| 	font-weight: bold; | ||||
| 	border: 0; | ||||
| } | ||||
| .ui-datepicker td { | ||||
| 	border: 0; | ||||
| 	padding: 1px; | ||||
| } | ||||
| .ui-datepicker td span, | ||||
| .ui-datepicker td a { | ||||
| 	display: block; | ||||
| 	padding: .2em; | ||||
| 	text-align: right; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane { | ||||
| 	background-image: none; | ||||
| 	margin: .7em 0 0 0; | ||||
| 	padding: 0 .2em; | ||||
| 	border-left: 0; | ||||
| 	border-right: 0; | ||||
| 	border-bottom: 0; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button { | ||||
| 	float: right; | ||||
| 	margin: .5em .2em .4em; | ||||
| 	cursor: pointer; | ||||
| 	padding: .2em .6em .3em .6em; | ||||
| 	width: auto; | ||||
| 	overflow: visible; | ||||
| } | ||||
| .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { | ||||
| 	float: left; | ||||
| } | ||||
|  | ||||
| /* with multiple calendars */ | ||||
| .ui-datepicker.ui-datepicker-multi { | ||||
| 	width: auto; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group table { | ||||
| 	width: 95%; | ||||
| 	margin: 0 auto .4em; | ||||
| } | ||||
| .ui-datepicker-multi-2 .ui-datepicker-group { | ||||
| 	width: 50%; | ||||
| } | ||||
| .ui-datepicker-multi-3 .ui-datepicker-group { | ||||
| 	width: 33.3%; | ||||
| } | ||||
| .ui-datepicker-multi-4 .ui-datepicker-group { | ||||
| 	width: 25%; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-left-width: 0; | ||||
| } | ||||
| .ui-datepicker-multi .ui-datepicker-buttonpane { | ||||
| 	clear: left; | ||||
| } | ||||
| .ui-datepicker-row-break { | ||||
| 	clear: both; | ||||
| 	width: 100%; | ||||
| 	font-size: 0; | ||||
| } | ||||
|  | ||||
| /* RTL support */ | ||||
| .ui-datepicker-rtl { | ||||
| 	direction: rtl; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev { | ||||
| 	right: 2px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next { | ||||
| 	left: 2px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-prev:hover { | ||||
| 	right: 1px; | ||||
| 	left: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-next:hover { | ||||
| 	left: 1px; | ||||
| 	right: auto; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane { | ||||
| 	clear: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button { | ||||
| 	float: left; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current, | ||||
| .ui-datepicker-rtl .ui-datepicker-group { | ||||
| 	float: right; | ||||
| } | ||||
| .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header, | ||||
| .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { | ||||
| 	border-right-width: 0; | ||||
| 	border-left-width: 1px; | ||||
| } | ||||
|  | ||||
| /* Icons */ | ||||
| .ui-datepicker .ui-icon { | ||||
| 	display: block; | ||||
| 	text-indent: -99999px; | ||||
| 	overflow: hidden; | ||||
| 	background-repeat: no-repeat; | ||||
| 	left: .5em; | ||||
| 	top: .3em; | ||||
| } | ||||
| .ui-dialog { | ||||
| 	position: absolute; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	padding: .2em; | ||||
| 	outline: 0; | ||||
| } | ||||
| .ui-dialog .ui-dialog-titlebar { | ||||
| 	padding: .4em 1em; | ||||
| 	position: relative; | ||||
| } | ||||
| .ui-dialog .ui-dialog-title { | ||||
| 	float: left; | ||||
| 	margin: .1em 0; | ||||
| 	white-space: nowrap; | ||||
| 	width: 90%; | ||||
| 	overflow: hidden; | ||||
| 	text-overflow: ellipsis; | ||||
| } | ||||
| .ui-dialog .ui-dialog-titlebar-close { | ||||
| 	position: absolute; | ||||
| 	right: .3em; | ||||
| 	top: 50%; | ||||
| 	width: 20px; | ||||
| 	margin: -10px 0 0 0; | ||||
| 	padding: 1px; | ||||
| 	height: 20px; | ||||
| } | ||||
| .ui-dialog .ui-dialog-content { | ||||
| 	position: relative; | ||||
| 	border: 0; | ||||
| 	padding: .5em 1em; | ||||
| 	background: none; | ||||
| 	overflow: auto; | ||||
| } | ||||
| .ui-dialog .ui-dialog-buttonpane { | ||||
| 	text-align: left; | ||||
| 	border-width: 1px 0 0 0; | ||||
| 	background-image: none; | ||||
| 	margin-top: .5em; | ||||
| 	padding: .3em 1em .5em .4em; | ||||
| } | ||||
| .ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { | ||||
| 	float: right; | ||||
| } | ||||
| .ui-dialog .ui-dialog-buttonpane button { | ||||
| 	margin: .5em .4em .5em 0; | ||||
| 	cursor: pointer; | ||||
| } | ||||
| .ui-dialog .ui-resizable-n { | ||||
| 	height: 2px; | ||||
| 	top: 0; | ||||
| } | ||||
| .ui-dialog .ui-resizable-e { | ||||
| 	width: 2px; | ||||
| 	right: 0; | ||||
| } | ||||
| .ui-dialog .ui-resizable-s { | ||||
| 	height: 2px; | ||||
| 	bottom: 0; | ||||
| } | ||||
| .ui-dialog .ui-resizable-w { | ||||
| 	width: 2px; | ||||
| 	left: 0; | ||||
| } | ||||
| .ui-dialog .ui-resizable-se, | ||||
| .ui-dialog .ui-resizable-sw, | ||||
| .ui-dialog .ui-resizable-ne, | ||||
| .ui-dialog .ui-resizable-nw { | ||||
| 	width: 7px; | ||||
| 	height: 7px; | ||||
| } | ||||
| .ui-dialog .ui-resizable-se { | ||||
| 	right: 0; | ||||
| 	bottom: 0; | ||||
| } | ||||
| .ui-dialog .ui-resizable-sw { | ||||
| 	left: 0; | ||||
| 	bottom: 0; | ||||
| } | ||||
| .ui-dialog .ui-resizable-ne { | ||||
| 	right: 0; | ||||
| 	top: 0; | ||||
| } | ||||
| .ui-dialog .ui-resizable-nw { | ||||
| 	left: 0; | ||||
| 	top: 0; | ||||
| } | ||||
| .ui-draggable .ui-dialog-titlebar { | ||||
| 	cursor: move; | ||||
| } | ||||
| .ui-progressbar { | ||||
| 	height: 2em; | ||||
| 	text-align: left; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .ui-progressbar .ui-progressbar-value { | ||||
| 	margin: -1px; | ||||
| 	height: 100%; | ||||
| } | ||||
| .ui-progressbar .ui-progressbar-overlay { | ||||
| 	background: url("data:image/gif;base64,R0lGODlhKAAoAIABAAAAAP///yH/C05FVFNDQVBFMi4wAwEAAAAh+QQJAQABACwAAAAAKAAoAAACkYwNqXrdC52DS06a7MFZI+4FHBCKoDeWKXqymPqGqxvJrXZbMx7Ttc+w9XgU2FB3lOyQRWET2IFGiU9m1frDVpxZZc6bfHwv4c1YXP6k1Vdy292Fb6UkuvFtXpvWSzA+HycXJHUXiGYIiMg2R6W459gnWGfHNdjIqDWVqemH2ekpObkpOlppWUqZiqr6edqqWQAAIfkECQEAAQAsAAAAACgAKAAAApSMgZnGfaqcg1E2uuzDmmHUBR8Qil95hiPKqWn3aqtLsS18y7G1SzNeowWBENtQd+T1JktP05nzPTdJZlR6vUxNWWjV+vUWhWNkWFwxl9VpZRedYcflIOLafaa28XdsH/ynlcc1uPVDZxQIR0K25+cICCmoqCe5mGhZOfeYSUh5yJcJyrkZWWpaR8doJ2o4NYq62lAAACH5BAkBAAEALAAAAAAoACgAAAKVDI4Yy22ZnINRNqosw0Bv7i1gyHUkFj7oSaWlu3ovC8GxNso5fluz3qLVhBVeT/Lz7ZTHyxL5dDalQWPVOsQWtRnuwXaFTj9jVVh8pma9JjZ4zYSj5ZOyma7uuolffh+IR5aW97cHuBUXKGKXlKjn+DiHWMcYJah4N0lYCMlJOXipGRr5qdgoSTrqWSq6WFl2ypoaUAAAIfkECQEAAQAsAAAAACgAKAAAApaEb6HLgd/iO7FNWtcFWe+ufODGjRfoiJ2akShbueb0wtI50zm02pbvwfWEMWBQ1zKGlLIhskiEPm9R6vRXxV4ZzWT2yHOGpWMyorblKlNp8HmHEb/lCXjcW7bmtXP8Xt229OVWR1fod2eWqNfHuMjXCPkIGNileOiImVmCOEmoSfn3yXlJWmoHGhqp6ilYuWYpmTqKUgAAIfkECQEAAQAsAAAAACgAKAAAApiEH6kb58biQ3FNWtMFWW3eNVcojuFGfqnZqSebuS06w5V80/X02pKe8zFwP6EFWOT1lDFk8rGERh1TTNOocQ61Hm4Xm2VexUHpzjymViHrFbiELsefVrn6XKfnt2Q9G/+Xdie499XHd2g4h7ioOGhXGJboGAnXSBnoBwKYyfioubZJ2Hn0RuRZaflZOil56Zp6iioKSXpUAAAh+QQJAQABACwAAAAAKAAoAAACkoQRqRvnxuI7kU1a1UU5bd5tnSeOZXhmn5lWK3qNTWvRdQxP8qvaC+/yaYQzXO7BMvaUEmJRd3TsiMAgswmNYrSgZdYrTX6tSHGZO73ezuAw2uxuQ+BbeZfMxsexY35+/Qe4J1inV0g4x3WHuMhIl2jXOKT2Q+VU5fgoSUI52VfZyfkJGkha6jmY+aaYdirq+lQAACH5BAkBAAEALAAAAAAoACgAAAKWBIKpYe0L3YNKToqswUlvznigd4wiR4KhZrKt9Upqip61i9E3vMvxRdHlbEFiEXfk9YARYxOZZD6VQ2pUunBmtRXo1Lf8hMVVcNl8JafV38aM2/Fu5V16Bn63r6xt97j09+MXSFi4BniGFae3hzbH9+hYBzkpuUh5aZmHuanZOZgIuvbGiNeomCnaxxap2upaCZsq+1kAACH5BAkBAAEALAAAAAAoACgAAAKXjI8By5zf4kOxTVrXNVlv1X0d8IGZGKLnNpYtm8Lr9cqVeuOSvfOW79D9aDHizNhDJidFZhNydEahOaDH6nomtJjp1tutKoNWkvA6JqfRVLHU/QUfau9l2x7G54d1fl995xcIGAdXqMfBNadoYrhH+Mg2KBlpVpbluCiXmMnZ2Sh4GBqJ+ckIOqqJ6LmKSllZmsoq6wpQAAAh+QQJAQABACwAAAAAKAAoAAAClYx/oLvoxuJDkU1a1YUZbJ59nSd2ZXhWqbRa2/gF8Gu2DY3iqs7yrq+xBYEkYvFSM8aSSObE+ZgRl1BHFZNr7pRCavZ5BW2142hY3AN/zWtsmf12p9XxxFl2lpLn1rseztfXZjdIWIf2s5dItwjYKBgo9yg5pHgzJXTEeGlZuenpyPmpGQoKOWkYmSpaSnqKileI2FAAACH5BAkBAAEALAAAAAAoACgAAAKVjB+gu+jG4kORTVrVhRlsnn2dJ3ZleFaptFrb+CXmO9OozeL5VfP99HvAWhpiUdcwkpBH3825AwYdU8xTqlLGhtCosArKMpvfa1mMRae9VvWZfeB2XfPkeLmm18lUcBj+p5dnN8jXZ3YIGEhYuOUn45aoCDkp16hl5IjYJvjWKcnoGQpqyPlpOhr3aElaqrq56Bq7VAAAOw=="); | ||||
| 	height: 100%; | ||||
| 	filter: alpha(opacity=25); /* support: IE8 */ | ||||
| 	opacity: 0.25; | ||||
| } | ||||
| .ui-progressbar-indeterminate .ui-progressbar-value { | ||||
| 	background-image: none; | ||||
| } | ||||
| .ui-selectmenu-menu { | ||||
| 	padding: 0; | ||||
| 	margin: 0; | ||||
| 	position: absolute; | ||||
| 	top: 0; | ||||
| 	left: 0; | ||||
| 	display: none; | ||||
| } | ||||
| .ui-selectmenu-menu .ui-menu { | ||||
| 	overflow: auto; | ||||
| 	overflow-x: hidden; | ||||
| 	padding-bottom: 1px; | ||||
| } | ||||
| .ui-selectmenu-menu .ui-menu .ui-selectmenu-optgroup { | ||||
| 	font-size: 1em; | ||||
| 	font-weight: bold; | ||||
| 	line-height: 1.5; | ||||
| 	padding: 2px 0.4em; | ||||
| 	margin: 0.5em 0 0 0; | ||||
| 	height: auto; | ||||
| 	border: 0; | ||||
| } | ||||
| .ui-selectmenu-open { | ||||
| 	display: block; | ||||
| } | ||||
| .ui-selectmenu-text { | ||||
| 	display: block; | ||||
| 	margin-right: 20px; | ||||
| 	overflow: hidden; | ||||
| 	text-overflow: ellipsis; | ||||
| } | ||||
| .ui-selectmenu-button.ui-button { | ||||
| 	text-align: left; | ||||
| 	white-space: nowrap; | ||||
| 	width: 14em; | ||||
| } | ||||
| .ui-selectmenu-icon.ui-icon { | ||||
| 	float: right; | ||||
| 	margin-top: 0; | ||||
| } | ||||
| .ui-slider { | ||||
| 	position: relative; | ||||
| 	text-align: left; | ||||
| } | ||||
| .ui-slider .ui-slider-handle { | ||||
| 	position: absolute; | ||||
| 	z-index: 2; | ||||
| 	width: 1.2em; | ||||
| 	height: 1.2em; | ||||
| 	cursor: default; | ||||
| 	-ms-touch-action: none; | ||||
| 	touch-action: none; | ||||
| } | ||||
| .ui-slider .ui-slider-range { | ||||
| 	position: absolute; | ||||
| 	z-index: 1; | ||||
| 	font-size: .7em; | ||||
| 	display: block; | ||||
| 	border: 0; | ||||
| 	background-position: 0 0; | ||||
| } | ||||
|  | ||||
| /* support: IE8 - See #6727 */ | ||||
| .ui-slider.ui-state-disabled .ui-slider-handle, | ||||
| .ui-slider.ui-state-disabled .ui-slider-range { | ||||
| 	filter: inherit; | ||||
| } | ||||
|  | ||||
| .ui-slider-horizontal { | ||||
| 	height: .8em; | ||||
| } | ||||
| .ui-slider-horizontal .ui-slider-handle { | ||||
| 	top: -.3em; | ||||
| 	margin-left: -.6em; | ||||
| } | ||||
| .ui-slider-horizontal .ui-slider-range { | ||||
| 	top: 0; | ||||
| 	height: 100%; | ||||
| } | ||||
| .ui-slider-horizontal .ui-slider-range-min { | ||||
| 	left: 0; | ||||
| } | ||||
| .ui-slider-horizontal .ui-slider-range-max { | ||||
| 	right: 0; | ||||
| } | ||||
|  | ||||
| .ui-slider-vertical { | ||||
| 	width: .8em; | ||||
| 	height: 100px; | ||||
| } | ||||
| .ui-slider-vertical .ui-slider-handle { | ||||
| 	left: -.3em; | ||||
| 	margin-left: 0; | ||||
| 	margin-bottom: -.6em; | ||||
| } | ||||
| .ui-slider-vertical .ui-slider-range { | ||||
| 	left: 0; | ||||
| 	width: 100%; | ||||
| } | ||||
| .ui-slider-vertical .ui-slider-range-min { | ||||
| 	bottom: 0; | ||||
| } | ||||
| .ui-slider-vertical .ui-slider-range-max { | ||||
| 	top: 0; | ||||
| } | ||||
| .ui-spinner { | ||||
| 	position: relative; | ||||
| 	display: inline-block; | ||||
| 	overflow: hidden; | ||||
| 	padding: 0; | ||||
| 	vertical-align: middle; | ||||
| } | ||||
| .ui-spinner-input { | ||||
| 	border: none; | ||||
| 	background: none; | ||||
| 	color: inherit; | ||||
| 	padding: .222em 0; | ||||
| 	margin: .2em 0; | ||||
| 	vertical-align: middle; | ||||
| 	margin-left: .4em; | ||||
| 	margin-right: 2em; | ||||
| } | ||||
| .ui-spinner-button { | ||||
| 	width: 1.6em; | ||||
| 	height: 50%; | ||||
| 	font-size: .5em; | ||||
| 	padding: 0; | ||||
| 	margin: 0; | ||||
| 	text-align: center; | ||||
| 	position: absolute; | ||||
| 	cursor: default; | ||||
| 	display: block; | ||||
| 	overflow: hidden; | ||||
| 	right: 0; | ||||
| } | ||||
| /* more specificity required here to override default borders */ | ||||
| .ui-spinner a.ui-spinner-button { | ||||
| 	border-top-style: none; | ||||
| 	border-bottom-style: none; | ||||
| 	border-right-style: none; | ||||
| } | ||||
| .ui-spinner-up { | ||||
| 	top: 0; | ||||
| } | ||||
| .ui-spinner-down { | ||||
| 	bottom: 0; | ||||
| } | ||||
| .ui-tabs { | ||||
| 	position: relative;/* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */ | ||||
| 	padding: .2em; | ||||
| } | ||||
| .ui-tabs .ui-tabs-nav { | ||||
| 	margin: 0; | ||||
| 	padding: .2em .2em 0; | ||||
| } | ||||
| .ui-tabs .ui-tabs-nav li { | ||||
| 	list-style: none; | ||||
| 	float: left; | ||||
| 	position: relative; | ||||
| 	top: 0; | ||||
| 	margin: 1px .2em 0 0; | ||||
| 	border-bottom-width: 0; | ||||
| 	padding: 0; | ||||
| 	white-space: nowrap; | ||||
| } | ||||
| .ui-tabs .ui-tabs-nav .ui-tabs-anchor { | ||||
| 	float: left; | ||||
| 	padding: .5em 1em; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-tabs .ui-tabs-nav li.ui-tabs-active { | ||||
| 	margin-bottom: -1px; | ||||
| 	padding-bottom: 1px; | ||||
| } | ||||
| .ui-tabs .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor, | ||||
| .ui-tabs .ui-tabs-nav li.ui-state-disabled .ui-tabs-anchor, | ||||
| .ui-tabs .ui-tabs-nav li.ui-tabs-loading .ui-tabs-anchor { | ||||
| 	cursor: text; | ||||
| } | ||||
| .ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor { | ||||
| 	cursor: pointer; | ||||
| } | ||||
| .ui-tabs .ui-tabs-panel { | ||||
| 	display: block; | ||||
| 	border-width: 0; | ||||
| 	padding: 1em 1.4em; | ||||
| 	background: none; | ||||
| } | ||||
| .ui-tooltip { | ||||
| 	padding: 8px; | ||||
| 	position: absolute; | ||||
| 	z-index: 9999; | ||||
| 	max-width: 300px; | ||||
| } | ||||
| body .ui-tooltip { | ||||
| 	border-width: 2px; | ||||
| } | ||||
							
								
								
									
										5
									
								
								core/static/core/js/ui/jquery-ui.structure.min.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										444
									
								
								core/static/core/js/ui/jquery-ui.theme.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,444 @@ | ||||
| /*! | ||||
|  * jQuery UI CSS Framework 1.12.0 | ||||
|  * http://jqueryui.com | ||||
|  * | ||||
|  * Copyright jQuery Foundation and other contributors | ||||
|  * Released under the MIT license. | ||||
|  * http://jquery.org/license | ||||
|  * | ||||
|  * http://api.jqueryui.com/category/theming/ | ||||
|  * | ||||
|  * To view and modify this theme, visit http://jqueryui.com/themeroller/?scope=&folderName=base&cornerRadiusShadow=8px&offsetLeftShadow=0px&offsetTopShadow=0px&thicknessShadow=5px&opacityShadow=30&bgImgOpacityShadow=0&bgTextureShadow=flat&bgColorShadow=666666&opacityOverlay=30&bgImgOpacityOverlay=0&bgTextureOverlay=flat&bgColorOverlay=aaaaaa&iconColorError=cc0000&fcError=5f3f3f&borderColorError=f1a899&bgTextureError=flat&bgColorError=fddfdf&iconColorHighlight=777620&fcHighlight=777620&borderColorHighlight=dad55e&bgTextureHighlight=flat&bgColorHighlight=fffa90&iconColorActive=ffffff&fcActive=ffffff&borderColorActive=003eff&bgTextureActive=flat&bgColorActive=007fff&iconColorHover=555555&fcHover=2b2b2b&borderColorHover=cccccc&bgTextureHover=flat&bgColorHover=ededed&iconColorDefault=777777&fcDefault=454545&borderColorDefault=c5c5c5&bgTextureDefault=flat&bgColorDefault=f6f6f6&iconColorContent=444444&fcContent=333333&borderColorContent=dddddd&bgTextureContent=flat&bgColorContent=ffffff&iconColorHeader=444444&fcHeader=333333&borderColorHeader=dddddd&bgTextureHeader=flat&bgColorHeader=e9e9e9&cornerRadius=3px&fwDefault=normal&fsDefault=1em&ffDefault=Arial%2CHelvetica%2Csans-serif | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /* Component containers | ||||
| ----------------------------------*/ | ||||
| .ui-widget { | ||||
| 	font-family: Arial,Helvetica,sans-serif; | ||||
| 	font-size: 1em; | ||||
| } | ||||
| .ui-widget .ui-widget { | ||||
| 	font-size: 1em; | ||||
| } | ||||
| .ui-widget input, | ||||
| .ui-widget select, | ||||
| .ui-widget textarea, | ||||
| .ui-widget button { | ||||
| 	font-family: Arial,Helvetica,sans-serif; | ||||
| 	font-size: 1em; | ||||
| } | ||||
| .ui-widget.ui-widget-content { | ||||
| 	border: 1px solid #c5c5c5; | ||||
| } | ||||
| .ui-widget-content { | ||||
| 	border: 1px solid #dddddd; | ||||
| 	background: #ffffff; | ||||
| 	color: #333333; | ||||
| } | ||||
| .ui-widget-content a { | ||||
| 	color: #333333; | ||||
| } | ||||
| .ui-widget-header { | ||||
| 	border: 1px solid #dddddd; | ||||
| 	background: #e9e9e9; | ||||
| 	color: #333333; | ||||
| 	font-weight: bold; | ||||
| } | ||||
| .ui-widget-header a { | ||||
| 	color: #333333; | ||||
| } | ||||
|  | ||||
| /* Interaction states | ||||
| ----------------------------------*/ | ||||
| .ui-state-default, | ||||
| .ui-widget-content .ui-state-default, | ||||
| .ui-widget-header .ui-state-default, | ||||
| .ui-button, | ||||
|  | ||||
| /* We use html here because we need a greater specificity to make sure disabled | ||||
| works properly when clicked or hovered */ | ||||
| html .ui-button.ui-state-disabled:hover, | ||||
| html .ui-button.ui-state-disabled:active { | ||||
| 	border: 1px solid #c5c5c5; | ||||
| 	background: #f6f6f6; | ||||
| 	font-weight: normal; | ||||
| 	color: #454545; | ||||
| } | ||||
| .ui-state-default a, | ||||
| .ui-state-default a:link, | ||||
| .ui-state-default a:visited, | ||||
| a.ui-button, | ||||
| a:link.ui-button, | ||||
| a:visited.ui-button, | ||||
| .ui-button { | ||||
| 	color: #454545; | ||||
| 	text-decoration: none; | ||||
| } | ||||
| .ui-state-hover, | ||||
| .ui-widget-content .ui-state-hover, | ||||
| .ui-widget-header .ui-state-hover, | ||||
| .ui-state-focus, | ||||
| .ui-widget-content .ui-state-focus, | ||||
| .ui-widget-header .ui-state-focus, | ||||
| .ui-button:hover, | ||||
| .ui-button:focus { | ||||
| 	border: 1px solid #cccccc; | ||||
| 	background: #ededed; | ||||
| 	font-weight: normal; | ||||
| 	color: #2b2b2b; | ||||
| } | ||||
| .ui-state-hover a, | ||||
| .ui-state-hover a:hover, | ||||
| .ui-state-hover a:link, | ||||
| .ui-state-hover a:visited, | ||||
| .ui-state-focus a, | ||||
| .ui-state-focus a:hover, | ||||
| .ui-state-focus a:link, | ||||
| .ui-state-focus a:visited, | ||||
| a.ui-button:hover, | ||||
| a.ui-button:focus { | ||||
| 	color: #2b2b2b; | ||||
| 	text-decoration: none; | ||||
| } | ||||
|  | ||||
| .ui-visual-focus { | ||||
| 	box-shadow: 0 0 3px 1px rgb(94, 158, 214); | ||||
| } | ||||
| .ui-state-active, | ||||
| .ui-widget-content .ui-state-active, | ||||
| .ui-widget-header .ui-state-active, | ||||
| a.ui-button:active, | ||||
| .ui-button:active, | ||||
| .ui-button.ui-state-active:hover { | ||||
| 	border: 1px solid #003eff; | ||||
| 	background: #007fff; | ||||
| 	font-weight: normal; | ||||
| 	color: #ffffff; | ||||
| } | ||||
| .ui-icon-background, | ||||
| .ui-state-active .ui-icon-background { | ||||
| 	border: #003eff; | ||||
| 	background-color: #ffffff; | ||||
| } | ||||
| .ui-state-active a, | ||||
| .ui-state-active a:link, | ||||
| .ui-state-active a:visited { | ||||
| 	color: #ffffff; | ||||
| 	text-decoration: none; | ||||
| } | ||||
|  | ||||
| /* Interaction Cues | ||||
| ----------------------------------*/ | ||||
| .ui-state-highlight, | ||||
| .ui-widget-content .ui-state-highlight, | ||||
| .ui-widget-header .ui-state-highlight { | ||||
| 	border: 1px solid #dad55e; | ||||
| 	background: #fffa90; | ||||
| 	color: #777620; | ||||
| } | ||||
| .ui-state-checked { | ||||
| 	border: 1px solid #dad55e; | ||||
| 	background: #fffa90; | ||||
| } | ||||
| .ui-state-highlight a, | ||||
| .ui-widget-content .ui-state-highlight a, | ||||
| .ui-widget-header .ui-state-highlight a { | ||||
| 	color: #777620; | ||||
| } | ||||
| .ui-state-error, | ||||
| .ui-widget-content .ui-state-error, | ||||
| .ui-widget-header .ui-state-error { | ||||
| 	border: 1px solid #f1a899; | ||||
| 	background: #fddfdf; | ||||
| 	color: #5f3f3f; | ||||
| } | ||||
| .ui-state-error a, | ||||
| .ui-widget-content .ui-state-error a, | ||||
| .ui-widget-header .ui-state-error a { | ||||
| 	color: #5f3f3f; | ||||
| } | ||||
| .ui-state-error-text, | ||||
| .ui-widget-content .ui-state-error-text, | ||||
| .ui-widget-header .ui-state-error-text { | ||||
| 	color: #5f3f3f; | ||||
| } | ||||
| .ui-priority-primary, | ||||
| .ui-widget-content .ui-priority-primary, | ||||
| .ui-widget-header .ui-priority-primary { | ||||
| 	font-weight: bold; | ||||
| } | ||||
| .ui-priority-secondary, | ||||
| .ui-widget-content .ui-priority-secondary, | ||||
| .ui-widget-header .ui-priority-secondary { | ||||
| 	opacity: .7; | ||||
| 	filter:Alpha(Opacity=70); /* support: IE8 */ | ||||
| 	font-weight: normal; | ||||
| } | ||||
| .ui-state-disabled, | ||||
| .ui-widget-content .ui-state-disabled, | ||||
| .ui-widget-header .ui-state-disabled { | ||||
| 	opacity: .35; | ||||
| 	filter:Alpha(Opacity=35); /* support: IE8 */ | ||||
| 	background-image: none; | ||||
| } | ||||
| .ui-state-disabled .ui-icon { | ||||
| 	filter:Alpha(Opacity=35); /* support: IE8 - See #6059 */ | ||||
| } | ||||
|  | ||||
| /* Icons | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* states and images */ | ||||
| .ui-icon { | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| } | ||||
| .ui-icon, | ||||
| .ui-widget-content .ui-icon { | ||||
| 	background-image: url("images/ui-icons_444444_256x240.png"); | ||||
| } | ||||
| .ui-widget-header .ui-icon { | ||||
| 	background-image: url("images/ui-icons_444444_256x240.png"); | ||||
| } | ||||
| .ui-button .ui-icon { | ||||
| 	background-image: url("images/ui-icons_777777_256x240.png"); | ||||
| } | ||||
| .ui-state-hover .ui-icon, | ||||
| .ui-state-focus .ui-icon, | ||||
| .ui-button:hover .ui-icon, | ||||
| .ui-button:focus .ui-icon, | ||||
| .ui-state-default .ui-icon { | ||||
| 	background-image: url("images/ui-icons_555555_256x240.png"); | ||||
| } | ||||
| .ui-state-active .ui-icon, | ||||
| .ui-button:active .ui-icon { | ||||
| 	background-image: url("images/ui-icons_ffffff_256x240.png"); | ||||
| } | ||||
| .ui-state-highlight .ui-icon, | ||||
| .ui-button .ui-state-highlight.ui-icon { | ||||
| 	background-image: url("images/ui-icons_777620_256x240.png"); | ||||
| } | ||||
| .ui-state-error .ui-icon, | ||||
| .ui-state-error-text .ui-icon { | ||||
| 	background-image: url("images/ui-icons_cc0000_256x240.png"); | ||||
| } | ||||
|  | ||||
| /* positioning */ | ||||
| .ui-icon-blank { background-position: 16px 16px; } | ||||
| .ui-icon-caret-1-n { background-position: 0 0; } | ||||
| .ui-icon-caret-1-ne { background-position: -16px 0; } | ||||
| .ui-icon-caret-1-e { background-position: -32px 0; } | ||||
| .ui-icon-caret-1-se { background-position: -48px 0; } | ||||
| .ui-icon-caret-1-s { background-position: -65px 0; } | ||||
| .ui-icon-caret-1-sw { background-position: -80px 0; } | ||||
| .ui-icon-caret-1-w { background-position: -96px 0; } | ||||
| .ui-icon-caret-1-nw { background-position: -112px 0; } | ||||
| .ui-icon-caret-2-n-s { background-position: -128px 0; } | ||||
| .ui-icon-caret-2-e-w { background-position: -144px 0; } | ||||
| .ui-icon-triangle-1-n { background-position: 0 -16px; } | ||||
| .ui-icon-triangle-1-ne { background-position: -16px -16px; } | ||||
| .ui-icon-triangle-1-e { background-position: -32px -16px; } | ||||
| .ui-icon-triangle-1-se { background-position: -48px -16px; } | ||||
| .ui-icon-triangle-1-s { background-position: -65px -16px; } | ||||
| .ui-icon-triangle-1-sw { background-position: -80px -16px; } | ||||
| .ui-icon-triangle-1-w { background-position: -96px -16px; } | ||||
| .ui-icon-triangle-1-nw { background-position: -112px -16px; } | ||||
| .ui-icon-triangle-2-n-s { background-position: -128px -16px; } | ||||
| .ui-icon-triangle-2-e-w { background-position: -144px -16px; } | ||||
| .ui-icon-arrow-1-n { background-position: 0 -32px; } | ||||
| .ui-icon-arrow-1-ne { background-position: -16px -32px; } | ||||
| .ui-icon-arrow-1-e { background-position: -32px -32px; } | ||||
| .ui-icon-arrow-1-se { background-position: -48px -32px; } | ||||
| .ui-icon-arrow-1-s { background-position: -65px -32px; } | ||||
| .ui-icon-arrow-1-sw { background-position: -80px -32px; } | ||||
| .ui-icon-arrow-1-w { background-position: -96px -32px; } | ||||
| .ui-icon-arrow-1-nw { background-position: -112px -32px; } | ||||
| .ui-icon-arrow-2-n-s { background-position: -128px -32px; } | ||||
| .ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } | ||||
| .ui-icon-arrow-2-e-w { background-position: -160px -32px; } | ||||
| .ui-icon-arrow-2-se-nw { background-position: -176px -32px; } | ||||
| .ui-icon-arrowstop-1-n { background-position: -192px -32px; } | ||||
| .ui-icon-arrowstop-1-e { background-position: -208px -32px; } | ||||
| .ui-icon-arrowstop-1-s { background-position: -224px -32px; } | ||||
| .ui-icon-arrowstop-1-w { background-position: -240px -32px; } | ||||
| .ui-icon-arrowthick-1-n { background-position: 1px -48px; } | ||||
| .ui-icon-arrowthick-1-ne { background-position: -16px -48px; } | ||||
| .ui-icon-arrowthick-1-e { background-position: -32px -48px; } | ||||
| .ui-icon-arrowthick-1-se { background-position: -48px -48px; } | ||||
| .ui-icon-arrowthick-1-s { background-position: -64px -48px; } | ||||
| .ui-icon-arrowthick-1-sw { background-position: -80px -48px; } | ||||
| .ui-icon-arrowthick-1-w { background-position: -96px -48px; } | ||||
| .ui-icon-arrowthick-1-nw { background-position: -112px -48px; } | ||||
| .ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } | ||||
| .ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } | ||||
| .ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } | ||||
| .ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } | ||||
| .ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } | ||||
| .ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } | ||||
| .ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } | ||||
| .ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } | ||||
| .ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } | ||||
| .ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } | ||||
| .ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } | ||||
| .ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } | ||||
| .ui-icon-arrowreturn-1-w { background-position: -64px -64px; } | ||||
| .ui-icon-arrowreturn-1-n { background-position: -80px -64px; } | ||||
| .ui-icon-arrowreturn-1-e { background-position: -96px -64px; } | ||||
| .ui-icon-arrowreturn-1-s { background-position: -112px -64px; } | ||||
| .ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } | ||||
| .ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } | ||||
| .ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } | ||||
| .ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } | ||||
| .ui-icon-arrow-4 { background-position: 0 -80px; } | ||||
| .ui-icon-arrow-4-diag { background-position: -16px -80px; } | ||||
| .ui-icon-extlink { background-position: -32px -80px; } | ||||
| .ui-icon-newwin { background-position: -48px -80px; } | ||||
| .ui-icon-refresh { background-position: -64px -80px; } | ||||
| .ui-icon-shuffle { background-position: -80px -80px; } | ||||
| .ui-icon-transfer-e-w { background-position: -96px -80px; } | ||||
| .ui-icon-transferthick-e-w { background-position: -112px -80px; } | ||||
| .ui-icon-folder-collapsed { background-position: 0 -96px; } | ||||
| .ui-icon-folder-open { background-position: -16px -96px; } | ||||
| .ui-icon-document { background-position: -32px -96px; } | ||||
| .ui-icon-document-b { background-position: -48px -96px; } | ||||
| .ui-icon-note { background-position: -64px -96px; } | ||||
| .ui-icon-mail-closed { background-position: -80px -96px; } | ||||
| .ui-icon-mail-open { background-position: -96px -96px; } | ||||
| .ui-icon-suitcase { background-position: -112px -96px; } | ||||
| .ui-icon-comment { background-position: -128px -96px; } | ||||
| .ui-icon-person { background-position: -144px -96px; } | ||||
| .ui-icon-print { background-position: -160px -96px; } | ||||
| .ui-icon-trash { background-position: -176px -96px; } | ||||
| .ui-icon-locked { background-position: -192px -96px; } | ||||
| .ui-icon-unlocked { background-position: -208px -96px; } | ||||
| .ui-icon-bookmark { background-position: -224px -96px; } | ||||
| .ui-icon-tag { background-position: -240px -96px; } | ||||
| .ui-icon-home { background-position: 0 -112px; } | ||||
| .ui-icon-flag { background-position: -16px -112px; } | ||||
| .ui-icon-calendar { background-position: -32px -112px; } | ||||
| .ui-icon-cart { background-position: -48px -112px; } | ||||
| .ui-icon-pencil { background-position: -64px -112px; } | ||||
| .ui-icon-clock { background-position: -80px -112px; } | ||||
| .ui-icon-disk { background-position: -96px -112px; } | ||||
| .ui-icon-calculator { background-position: -112px -112px; } | ||||
| .ui-icon-zoomin { background-position: -128px -112px; } | ||||
| .ui-icon-zoomout { background-position: -144px -112px; } | ||||
| .ui-icon-search { background-position: -160px -112px; } | ||||
| .ui-icon-wrench { background-position: -176px -112px; } | ||||
| .ui-icon-gear { background-position: -192px -112px; } | ||||
| .ui-icon-heart { background-position: -208px -112px; } | ||||
| .ui-icon-star { background-position: -224px -112px; } | ||||
| .ui-icon-link { background-position: -240px -112px; } | ||||
| .ui-icon-cancel { background-position: 0 -128px; } | ||||
| .ui-icon-plus { background-position: -16px -128px; } | ||||
| .ui-icon-plusthick { background-position: -32px -128px; } | ||||
| .ui-icon-minus { background-position: -48px -128px; } | ||||
| .ui-icon-minusthick { background-position: -64px -128px; } | ||||
| .ui-icon-close { background-position: -80px -128px; } | ||||
| .ui-icon-closethick { background-position: -96px -128px; } | ||||
| .ui-icon-key { background-position: -112px -128px; } | ||||
| .ui-icon-lightbulb { background-position: -128px -128px; } | ||||
| .ui-icon-scissors { background-position: -144px -128px; } | ||||
| .ui-icon-clipboard { background-position: -160px -128px; } | ||||
| .ui-icon-copy { background-position: -176px -128px; } | ||||
| .ui-icon-contact { background-position: -192px -128px; } | ||||
| .ui-icon-image { background-position: -208px -128px; } | ||||
| .ui-icon-video { background-position: -224px -128px; } | ||||
| .ui-icon-script { background-position: -240px -128px; } | ||||
| .ui-icon-alert { background-position: 0 -144px; } | ||||
| .ui-icon-info { background-position: -16px -144px; } | ||||
| .ui-icon-notice { background-position: -32px -144px; } | ||||
| .ui-icon-help { background-position: -48px -144px; } | ||||
| .ui-icon-check { background-position: -64px -144px; } | ||||
| .ui-icon-bullet { background-position: -80px -144px; } | ||||
| .ui-icon-radio-on { background-position: -96px -144px; } | ||||
| .ui-icon-radio-off { background-position: -112px -144px; } | ||||
| .ui-icon-pin-w { background-position: -128px -144px; } | ||||
| .ui-icon-pin-s { background-position: -144px -144px; } | ||||
| .ui-icon-play { background-position: 0 -160px; } | ||||
| .ui-icon-pause { background-position: -16px -160px; } | ||||
| .ui-icon-seek-next { background-position: -32px -160px; } | ||||
| .ui-icon-seek-prev { background-position: -48px -160px; } | ||||
| .ui-icon-seek-end { background-position: -64px -160px; } | ||||
| .ui-icon-seek-start { background-position: -80px -160px; } | ||||
| /* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ | ||||
| .ui-icon-seek-first { background-position: -80px -160px; } | ||||
| .ui-icon-stop { background-position: -96px -160px; } | ||||
| .ui-icon-eject { background-position: -112px -160px; } | ||||
| .ui-icon-volume-off { background-position: -128px -160px; } | ||||
| .ui-icon-volume-on { background-position: -144px -160px; } | ||||
| .ui-icon-power { background-position: 0 -176px; } | ||||
| .ui-icon-signal-diag { background-position: -16px -176px; } | ||||
| .ui-icon-signal { background-position: -32px -176px; } | ||||
| .ui-icon-battery-0 { background-position: -48px -176px; } | ||||
| .ui-icon-battery-1 { background-position: -64px -176px; } | ||||
| .ui-icon-battery-2 { background-position: -80px -176px; } | ||||
| .ui-icon-battery-3 { background-position: -96px -176px; } | ||||
| .ui-icon-circle-plus { background-position: 0 -192px; } | ||||
| .ui-icon-circle-minus { background-position: -16px -192px; } | ||||
| .ui-icon-circle-close { background-position: -32px -192px; } | ||||
| .ui-icon-circle-triangle-e { background-position: -48px -192px; } | ||||
| .ui-icon-circle-triangle-s { background-position: -64px -192px; } | ||||
| .ui-icon-circle-triangle-w { background-position: -80px -192px; } | ||||
| .ui-icon-circle-triangle-n { background-position: -96px -192px; } | ||||
| .ui-icon-circle-arrow-e { background-position: -112px -192px; } | ||||
| .ui-icon-circle-arrow-s { background-position: -128px -192px; } | ||||
| .ui-icon-circle-arrow-w { background-position: -144px -192px; } | ||||
| .ui-icon-circle-arrow-n { background-position: -160px -192px; } | ||||
| .ui-icon-circle-zoomin { background-position: -176px -192px; } | ||||
| .ui-icon-circle-zoomout { background-position: -192px -192px; } | ||||
| .ui-icon-circle-check { background-position: -208px -192px; } | ||||
| .ui-icon-circlesmall-plus { background-position: 0 -208px; } | ||||
| .ui-icon-circlesmall-minus { background-position: -16px -208px; } | ||||
| .ui-icon-circlesmall-close { background-position: -32px -208px; } | ||||
| .ui-icon-squaresmall-plus { background-position: -48px -208px; } | ||||
| .ui-icon-squaresmall-minus { background-position: -64px -208px; } | ||||
| .ui-icon-squaresmall-close { background-position: -80px -208px; } | ||||
| .ui-icon-grip-dotted-vertical { background-position: 0 -224px; } | ||||
| .ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } | ||||
| .ui-icon-grip-solid-vertical { background-position: -32px -224px; } | ||||
| .ui-icon-grip-solid-horizontal { background-position: -48px -224px; } | ||||
| .ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } | ||||
| .ui-icon-grip-diagonal-se { background-position: -80px -224px; } | ||||
|  | ||||
|  | ||||
| /* Misc visuals | ||||
| ----------------------------------*/ | ||||
|  | ||||
| /* Corner radius */ | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-left, | ||||
| .ui-corner-tl { | ||||
| 	border-top-left-radius: 3px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-top, | ||||
| .ui-corner-right, | ||||
| .ui-corner-tr { | ||||
| 	border-top-right-radius: 3px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-left, | ||||
| .ui-corner-bl { | ||||
| 	border-bottom-left-radius: 3px; | ||||
| } | ||||
| .ui-corner-all, | ||||
| .ui-corner-bottom, | ||||
| .ui-corner-right, | ||||
| .ui-corner-br { | ||||
| 	border-bottom-right-radius: 3px; | ||||
| } | ||||
|  | ||||
| /* Overlays */ | ||||
| .ui-widget-overlay { | ||||
| 	background: #aaaaaa; | ||||
| 	opacity: .3; | ||||
| 	filter: Alpha(Opacity=30); /* support: IE8 */ | ||||
| } | ||||
| .ui-widget-shadow { | ||||
| 	-webkit-box-shadow: 0px 0px 5px #666666; | ||||
| 	box-shadow: 0px 0px 5px #666666; | ||||
| } | ||||
							
								
								
									
										5
									
								
								core/static/core/js/ui/jquery-ui.theme.min.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										74
									
								
								core/static/core/js/ui/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,74 @@ | ||||
| { | ||||
| 	"name": "jquery-ui", | ||||
| 	"title": "jQuery UI", | ||||
| 	"description": "A curated set of user interface interactions, effects, widgets, and themes built on top of the jQuery JavaScript Library.", | ||||
| 	"version": "1.12.0", | ||||
| 	"homepage": "http://jqueryui.com", | ||||
| 	"author": { | ||||
| 		"name": "jQuery Foundation and other contributors", | ||||
| 		"url": "https://github.com/jquery/jquery-ui/blob/1.12.0/AUTHORS.txt" | ||||
| 	}, | ||||
| 	"main": "ui/widget.js", | ||||
| 	"maintainers": [ | ||||
| 		{ | ||||
| 			"name": "Scott González", | ||||
| 			"email": "scott.gonzalez@gmail.com", | ||||
| 			"url": "http://scottgonzalez.com" | ||||
| 		}, | ||||
| 		{ | ||||
| 			"name": "Jörn Zaefferer", | ||||
| 			"email": "joern.zaefferer@gmail.com", | ||||
| 			"url": "http://bassistance.de" | ||||
| 		}, | ||||
| 		{ | ||||
| 			"name": "Mike Sherov", | ||||
| 			"email": "mike.sherov@gmail.com", | ||||
| 			"url": "http://mike.sherov.com" | ||||
| 		}, | ||||
| 		{ | ||||
| 			"name": "TJ VanToll", | ||||
| 			"email": "tj.vantoll@gmail.com", | ||||
| 			"url": "http://tjvantoll.com" | ||||
| 		}, | ||||
| 		{ | ||||
| 			"name": "Felix Nagel", | ||||
| 			"email": "info@felixnagel.com", | ||||
| 			"url": "http://www.felixnagel.com" | ||||
| 		}, | ||||
| 		{ | ||||
| 			"name": "Alex Schmitz", | ||||
| 			"email": "arschmitz@gmail.com", | ||||
| 			"url": "https://github.com/arschmitz" | ||||
| 		} | ||||
| 	], | ||||
| 	"repository": { | ||||
| 		"type": "git", | ||||
| 		"url": "git://github.com/jquery/jquery-ui.git" | ||||
| 	}, | ||||
| 	"bugs": "https://bugs.jqueryui.com/", | ||||
| 	"license": "MIT", | ||||
| 	"scripts": { | ||||
| 		"test": "grunt" | ||||
| 	}, | ||||
| 	"dependencies": {}, | ||||
| 	"devDependencies": { | ||||
| 		"commitplease": "2.3.0", | ||||
| 		"grunt": "0.4.5", | ||||
| 		"grunt-bowercopy": "1.2.4", | ||||
| 		"grunt-cli": "0.1.13", | ||||
| 		"grunt-compare-size": "0.4.0", | ||||
| 		"grunt-contrib-concat": "0.5.1", | ||||
| 		"grunt-contrib-csslint": "0.5.0", | ||||
| 		"grunt-contrib-jshint": "0.12.0", | ||||
| 		"grunt-contrib-qunit": "1.0.1", | ||||
| 		"grunt-contrib-requirejs": "0.4.4", | ||||
| 		"grunt-contrib-uglify": "0.11.1", | ||||
| 		"grunt-git-authors": "3.1.0", | ||||
| 		"grunt-html": "6.0.0", | ||||
| 		"grunt-jscs": "2.1.0", | ||||
| 		"load-grunt-tasks": "3.4.0", | ||||
| 		"rimraf": "2.5.1", | ||||
| 		"testswarm": "1.1.0" | ||||
| 	}, | ||||
| 	"keywords": [] | ||||
| } | ||||
							
								
								
									
										191
									
								
								core/static/core/multiple-select.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,191 @@ | ||||
| /** | ||||
|  * @author zhixin wen <wenzhixin2010@gmail.com> | ||||
|  */ | ||||
|  | ||||
| .ms-parent { | ||||
|     display: inline-block; | ||||
|     position: relative; | ||||
|     vertical-align: middle; | ||||
| } | ||||
|  | ||||
| .ms-choice { | ||||
|     display: block; | ||||
|     width: 100%; | ||||
|     height: 26px; | ||||
|     padding: 0; | ||||
|     overflow: hidden; | ||||
|     cursor: pointer; | ||||
|     border: 1px solid #aaa; | ||||
|     text-align: left; | ||||
|     white-space: nowrap; | ||||
|     line-height: 26px; | ||||
|     color: #444; | ||||
|     text-decoration: none; | ||||
|     -webkit-border-radius: 4px; | ||||
|     -moz-border-radius: 4px; | ||||
|     border-radius: 4px; | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .ms-choice.disabled { | ||||
|     background-color: #f4f4f4; | ||||
|     background-image: none; | ||||
|     border: 1px solid #ddd; | ||||
|     cursor: default; | ||||
| } | ||||
|  | ||||
| .ms-choice > span { | ||||
|     position: absolute; | ||||
|     top: 0; | ||||
|     left: 0; | ||||
|     right: 20px; | ||||
|     white-space: nowrap; | ||||
|     overflow: hidden; | ||||
|     text-overflow: ellipsis; | ||||
|     display: block; | ||||
|     padding-left: 8px; | ||||
| } | ||||
|  | ||||
| .ms-choice > span.placeholder { | ||||
|     color: #999; | ||||
| } | ||||
|  | ||||
| .ms-choice > div { | ||||
|     position: absolute; | ||||
|     top: 0; | ||||
|     right: 0; | ||||
|     width: 20px; | ||||
|     height: 25px; | ||||
|     background: url('multiple-select.png') left top no-repeat; | ||||
| } | ||||
|  | ||||
| .ms-choice > div.open { | ||||
|     background: url('multiple-select.png') right top no-repeat; | ||||
| } | ||||
|  | ||||
| .ms-drop { | ||||
|     width: 100%; | ||||
|     overflow: hidden; | ||||
|     display: none; | ||||
|     margin-top: -1px; | ||||
|     padding: 0; | ||||
|     position: absolute; | ||||
|     z-index: 1000; | ||||
|     background: #fff; | ||||
|     color: #000; | ||||
|     border: 1px solid #aaa; | ||||
|     -webkit-border-radius: 4px; | ||||
|     -moz-border-radius: 4px; | ||||
|     border-radius: 4px; | ||||
| } | ||||
|  | ||||
| .ms-drop.bottom { | ||||
|     top: 100%; | ||||
|     -webkit-box-shadow: 0 4px 5px rgba(0, 0, 0, .15); | ||||
|     -moz-box-shadow: 0 4px 5px rgba(0, 0, 0, .15); | ||||
|     box-shadow: 0 4px 5px rgba(0, 0, 0, .15); | ||||
| } | ||||
|  | ||||
| .ms-drop.top { | ||||
|     bottom: 100%; | ||||
|     -webkit-box-shadow: 0 -4px 5px rgba(0, 0, 0, .15); | ||||
|     -moz-box-shadow: 0 -4px 5px rgba(0, 0, 0, .15); | ||||
|     box-shadow: 0 -4px 5px rgba(0, 0, 0, .15); | ||||
| } | ||||
|  | ||||
| .ms-search { | ||||
|     display: inline-block; | ||||
|     margin: 0; | ||||
|     min-height: 26px; | ||||
|     padding: 4px; | ||||
|     position: relative; | ||||
|     white-space: nowrap; | ||||
|     width: 100%; | ||||
|     z-index: 10000; | ||||
| } | ||||
|  | ||||
| .ms-search input { | ||||
|     width: 100%; | ||||
|     height: auto !important; | ||||
|     min-height: 24px; | ||||
|     padding: 0 20px 0 5px; | ||||
|     margin: 0; | ||||
|     outline: 0; | ||||
|     font-family: sans-serif; | ||||
|     font-size: 1em; | ||||
|     border: 1px solid #aaa; | ||||
|     -webkit-border-radius: 0; | ||||
|     -moz-border-radius: 0; | ||||
|     border-radius: 0; | ||||
|     -webkit-box-shadow: none; | ||||
|     -moz-box-shadow: none; | ||||
|     box-shadow: none; | ||||
|     background: #fff url('multiple-select.png') no-repeat 100% -22px; | ||||
|     background: url('multiple-select.png') no-repeat 100% -22px, -webkit-gradient(linear, left bottom, left top, color-stop(0.85, white), color-stop(0.99, #eeeeee)); | ||||
|     background: url('multiple-select.png') no-repeat 100% -22px, -webkit-linear-gradient(center bottom, white 85%, #eeeeee 99%); | ||||
|     background: url('multiple-select.png') no-repeat 100% -22px, -moz-linear-gradient(center bottom, white 85%, #eeeeee 99%); | ||||
|     background: url('multiple-select.png') no-repeat 100% -22px, -o-linear-gradient(bottom, white 85%, #eeeeee 99%); | ||||
|     background: url('multiple-select.png') no-repeat 100% -22px, -ms-linear-gradient(top, #ffffff 85%, #eeeeee 99%); | ||||
|     background: url('multiple-select.png') no-repeat 100% -22px, linear-gradient(top, #ffffff 85%, #eeeeee 99%); | ||||
| } | ||||
|  | ||||
| .ms-search, .ms-search input { | ||||
|     -webkit-box-sizing: border-box; | ||||
|     -khtml-box-sizing: border-box; | ||||
|     -moz-box-sizing: border-box; | ||||
|     -ms-box-sizing: border-box; | ||||
|     box-sizing: border-box; | ||||
| } | ||||
|  | ||||
| .ms-drop ul { | ||||
|     overflow: auto; | ||||
|     margin: 0; | ||||
|     padding: 5px 8px; | ||||
| } | ||||
|  | ||||
| .ms-drop ul > li { | ||||
|     list-style: none; | ||||
|     display: list-item; | ||||
|     background-image: none; | ||||
|     position: static; | ||||
| } | ||||
|  | ||||
| .ms-drop ul > li .disabled { | ||||
|     opacity: .35; | ||||
|     filter: Alpha(Opacity=35); | ||||
| } | ||||
|  | ||||
| .ms-drop ul > li.multiple { | ||||
|     display: block; | ||||
|     float: left; | ||||
| } | ||||
|  | ||||
| .ms-drop ul > li.group { | ||||
|     clear: both; | ||||
| } | ||||
|  | ||||
| .ms-drop ul > li.multiple label { | ||||
|     width: 100%; | ||||
|     display: block; | ||||
|     white-space: nowrap; | ||||
|     overflow: hidden; | ||||
|     text-overflow: ellipsis; | ||||
| } | ||||
|  | ||||
| .ms-drop ul > li label { | ||||
|     font-weight: normal; | ||||
|     display: block; | ||||
|     white-space: nowrap; | ||||
| } | ||||
|  | ||||
| .ms-drop ul > li label.optgroup { | ||||
|     font-weight: bold; | ||||
| } | ||||
|  | ||||
| .ms-drop input[type="checkbox"] { | ||||
|     vertical-align: middle; | ||||
| } | ||||
|  | ||||
| .ms-drop .ms-no-results { | ||||
|     display: none; | ||||
| } | ||||
							
								
								
									
										
											BIN
										
									
								
								core/static/core/multiple-select.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.3 KiB | 
| @@ -1 +0,0 @@ | ||||
| console.log('Guy'); | ||||
| @@ -27,6 +27,12 @@ header a:hover { | ||||
|     color: #2D3; | ||||
| } | ||||
|  | ||||
| #popupheader { | ||||
|     width: 88%; | ||||
|     margin: 0px auto; | ||||
|     padding: 0.3em 1%; | ||||
| } | ||||
|  | ||||
| /*---------------------------------NAV---------------------------------*/ | ||||
| nav { | ||||
|     display: block; | ||||
| @@ -54,7 +60,6 @@ nav a:hover { | ||||
|     margin: 0px auto; | ||||
|     padding: 1em 1%; | ||||
|     background: white; | ||||
|     overflow: auto; | ||||
| } | ||||
|  | ||||
| h1, h2, h3, h4, h5, h6 { | ||||
| @@ -177,6 +182,9 @@ footer{ | ||||
| } | ||||
|  | ||||
| /*--------------------------------MODALE-------------------------------*/ | ||||
| .choose_file_widget { | ||||
|     display: inline; | ||||
| } | ||||
| .form-wrapper { | ||||
|     display: inline-block; | ||||
|     position: absolute; | ||||
|   | ||||
| @@ -6,14 +6,15 @@ | ||||
|         <link rel="stylesheet" href="{{ static('core/base.css') }}"> | ||||
|         <link rel="stylesheet" href="{{ static('core/form.css') }}"> | ||||
|         <link rel="stylesheet" href="{{ static('core/style.css') }}"> | ||||
|         <script src="{{ static('core/script.js') }}"></script> | ||||
|         <link rel="stylesheet" href="{{ static('core/multiple-select.css') }}"> | ||||
|         <link rel="stylesheet" href="{{ static('core/js/ui/jquery-ui.min.css') }}"> | ||||
|         {% endblock %} | ||||
|     </head> | ||||
|  | ||||
|     <body> | ||||
|         {% block header %} | ||||
|         <div id="logo"><a href="{{ url('core:index') }}"><img src="{{ static('core/img/logo.png') }}" | ||||
|                                                               alt="{% trans %}Logo{% endtrans %}" /></a></div> | ||||
|         {% block header %} | ||||
|         <header> | ||||
|             {% if not user.is_authenticated() %} | ||||
|             <a href="{{ url('core:login') }}">{% trans %}Login{% endtrans %}</a> | | ||||
| @@ -25,6 +26,7 @@ | ||||
|             {% endif %} | ||||
|         </header> | ||||
|         {% endblock %} | ||||
|         {% block nav %} | ||||
|         <nav> | ||||
|             <a href="{{ url('core:user_list') }}">{% trans %}Users{% endtrans %}</a> | ||||
|             <a href="{{ url('core:page', page_name="Index") }}">{% trans %}Wiki{% endtrans %}</a> | ||||
| @@ -32,6 +34,7 @@ | ||||
|             <a href="{{ url('club:club_list') }}">{% trans %}Clubs{% endtrans %}</a> | ||||
|             <a href="{{ url('core:page', "Services") }}">{% trans %}Services{% endtrans %}</a> | ||||
|         </nav> | ||||
|         {% endblock %} | ||||
|  | ||||
|         <div id="content"> | ||||
|             {% if error %} | ||||
| @@ -51,5 +54,24 @@ | ||||
|             {{ tests }} | ||||
|             {% endblock %} | ||||
|         --> | ||||
|         <script src="{{ static('core/js/jquery-3.1.0.min.js') }}"></script> | ||||
|         <script src="{{ static('core/js/ui/jquery-ui.min.js') }}"></script> | ||||
|         <script src="{{ static('core/js/multiple-select.js') }}"></script> | ||||
|         <script src="{{ static('core/js/script.js') }}"></script> | ||||
|         <script> | ||||
|     $('select').multipleSelect({ | ||||
|         filter: true, | ||||
|         single: true, | ||||
|         {% if not popup %} | ||||
|         position: 'top', | ||||
|         {% endif %} | ||||
|     }); | ||||
|     $('select[multiple=multiple]').multipleSelect({ | ||||
|         filter: true, | ||||
|         {% if not popup %} | ||||
|         position: 'top', | ||||
|         {% endif %} | ||||
|     }); | ||||
|         </script> | ||||
|     </body> | ||||
| </html> | ||||
|   | ||||
							
								
								
									
										61
									
								
								core/templates/core/file.jinja
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,61 @@ | ||||
| {% extends "core/base.jinja" %} | ||||
|  | ||||
| {% block title %} | ||||
| {% if file %} | ||||
| {{ file.get_display_name() }} | ||||
| {% elif file_list %} | ||||
| {% trans %}File list{% endtrans %} | ||||
| {% elif new_file %} | ||||
| {% trans %}New file{% endtrans %} | ||||
| {% else %} | ||||
| {% trans %}Not found{% endtrans %} | ||||
| {% endif %} | ||||
| {% endblock %} | ||||
|  | ||||
| {% macro print_file_name(file) %} | ||||
| {% if file %} | ||||
| {{ print_file_name(file.parent) }} > | ||||
| <a href="{{ url('core:file_detail', file_id=file.id, popup=popup) }}">{{ file.get_display_name() }}</a> | ||||
| {% else %} | ||||
| <a href="{{ url('core:file_list', popup) }}">{% trans %}Files{% endtrans %}</a> | ||||
| {% endif %} | ||||
| {% endmacro %} | ||||
|  | ||||
| {% block header %} | ||||
| {% if popup != "" %} | ||||
| <div id="popupheader">{{ user.get_display_name() }}</div> | ||||
| {% else %} | ||||
| {{ super() }} | ||||
| {% endif %} | ||||
| {% endblock %} | ||||
| {% block nav %} | ||||
| {% if popup != "" %} | ||||
| {% else %} | ||||
| {{ super() }} | ||||
| {% endif %} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block content %} | ||||
| {{ print_file_name(file) }} | ||||
|  | ||||
| <div class="tool-bar"> | ||||
|     <div class="tools"> | ||||
|         {% if file %} | ||||
|         <a href="{{ url('core:file_detail', file.id, popup) }}">{% trans %}View{% endtrans %}</a> | ||||
|         {% if can_edit(file, user) %} | ||||
|         <a href="{{ url('core:file_edit', file_id=file.id, popup=popup) }}">{% trans %}Edit{% endtrans %}</a> | ||||
|         {% endif %} | ||||
|         {% if can_edit_prop(file, user) %} | ||||
|         <a href="{{ url('core:file_prop', file_id=file.id, popup=popup) }}">{% trans %}Prop{% endtrans %}</a> | ||||
|         {% endif %} | ||||
|         {% endif %} | ||||
|     </div> | ||||
| </div> | ||||
| <hr> | ||||
|  | ||||
| {% if file %} | ||||
| {% block file %} | ||||
| {% endblock %} | ||||
| {% endif %} | ||||
|  | ||||
| {% endblock %} | ||||
							
								
								
									
										14
									
								
								core/templates/core/file_delete_confirm.jinja
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,14 @@ | ||||
| {% extends "core/file.jinja" %} | ||||
|  | ||||
| {% block file %} | ||||
| <h2>{% trans %}Delete confirmation{% endtrans %}</h2> | ||||
| <form action="" method="post">{% csrf_token %} | ||||
|     <p>{% trans obj=object %}Are you sure you want to delete "{{ obj }}"?{% endtrans %}</p> | ||||
|     <input type="submit" value="{% trans %}Confirm{% endtrans %}" /> | ||||
|     <input type="submit" name="cancel" value="{% trans %}Cancel{% endtrans %}" /> | ||||
| </form> | ||||
| {% endblock %} | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										45
									
								
								core/templates/core/file_detail.jinja
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,45 @@ | ||||
| {% extends "core/file.jinja" %} | ||||
|  | ||||
|  | ||||
| {% block file %} | ||||
| <h3> | ||||
| {% if file.is_folder %} | ||||
| 📁 | ||||
| {% else %} | ||||
| 🗎 | ||||
| {% endif %} | ||||
| {{ file.get_display_name() }} | ||||
| </h3> | ||||
| <p>{% trans %}Owner: {% endtrans %}{{ file.owner.get_display_name() }}</p> | ||||
| {% if file.is_folder %} | ||||
| <form action="" method="post" enctype="multipart/form-data"> | ||||
|     {% csrf_token %} | ||||
|     {{ form.as_p() }} | ||||
|     <p><input type="submit" value="{% trans %}Add{% endtrans %}"></p> | ||||
| </form> | ||||
| <ul> | ||||
|     {% for f in file.children.order_by('-is_folder', 'name').all() %} | ||||
|     <li> | ||||
|         {% if f.is_folder %} | ||||
|         📁 | ||||
|         {% else %} | ||||
|         🗎 | ||||
|         {% endif %} | ||||
|         <a href="{{ url('core:file_detail', file_id=f.id, popup=popup) }}">{{ f.get_display_name() }}</a></li> | ||||
|     {% endfor %} | ||||
| </ul> | ||||
| {% else %} | ||||
| <p>{% trans %}Real name: {% endtrans %}{{ file.file.name.split('/')[-1] }}</p> | ||||
| <p>{% trans %}Date: {% endtrans %}{{ file.date|localtime|date(DATETIME_FORMAT) }} - | ||||
| {{ file.date|localtime|time(DATETIME_FORMAT) }}</p> | ||||
| <p>{% trans %}Type: {% endtrans %}{{ file.mime_type }}</p> | ||||
| <p>{% trans %}Size: {% endtrans %}{{ file.size }} {% trans %}bytes{% endtrans %}</p> | ||||
|  | ||||
| <p><a href="{{ url('core:download', file_id=file.id) }}">{% trans %}Download{% endtrans %}</a></p> | ||||
| {% endif %} | ||||
| <p><a href="{{ url('core:file_delete', file_id=file.id, popup=popup) }}">{% trans %}Delete{% endtrans %}</a></p> | ||||
| {% endblock %} | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										13
									
								
								core/templates/core/file_edit.jinja
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,13 @@ | ||||
| {% extends "core/file.jinja" %} | ||||
|  | ||||
| {% block file %} | ||||
| <h2>{% trans obj=object %}Edit {{ obj }}{% endtrans %}</h2> | ||||
| <form action="" method="post"> | ||||
|     {% csrf_token %} | ||||
|     {{ form.as_p() }} | ||||
|     <p><input type="submit" value="{% trans %}Save{% endtrans %}" /></p> | ||||
| </form> | ||||
| {% endblock %} | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										29
									
								
								core/templates/core/file_list.jinja
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,29 @@ | ||||
| {% extends "core/file.jinja" %} | ||||
|  | ||||
| {% block content %} | ||||
| {{ super() }} | ||||
| <form action="" method="post" enctype="multipart/form-data"> | ||||
|     {% csrf_token %} | ||||
|     {{ form.as_p() }} | ||||
|     <p><input type="submit" value="{% trans %}Add{% endtrans %}"></p> | ||||
| </form> | ||||
| {% if file_list %} | ||||
| <h3>{% trans %}File list{% endtrans %}</h3> | ||||
| <ul> | ||||
|     {% for f in file_list %} | ||||
|     <li> | ||||
|         {% if f.is_folder %} | ||||
|         📁 | ||||
|         {% else %} | ||||
|         🗎 | ||||
|         {% endif %} | ||||
|         <a href="{{ url('core:file_detail', file_id=f.id, popup=popup) }}">{{ f.name }}</a></li> | ||||
|     {% endfor %} | ||||
| </ul> | ||||
| {% else %} | ||||
| <p>{% trans %}There is no file in this website.{% endtrans %}</p> | ||||
| {% endif %} | ||||
| {% endblock %} | ||||
|  | ||||
|  | ||||
|  | ||||
| @@ -5,7 +5,7 @@ | ||||
| <script> | ||||
| function make_preview() { | ||||
|     $.ajax({ | ||||
|         url: "{{ url('core:api_markdown') }}", | ||||
|         url: "{{ url('api:api_markdown') }}", | ||||
|         method: "GET", | ||||
|         data: { text: $("#id_content").val() } | ||||
|     }).done(function (msg) { | ||||
|   | ||||
| @@ -30,6 +30,15 @@ urlpatterns = [ | ||||
|     url(r'^user/tools/$', UserToolsView.as_view(), name='user_tools'), | ||||
|     url(r'^user/(?P<user_id>[0-9]+)/account$', UserAccountView.as_view(), name='user_account'), | ||||
|  | ||||
|     # File views | ||||
|     # url(r'^file/add/(?P<popup>popup)?$', FileCreateView.as_view(), name='file_new'), | ||||
|     url(r'^file/(?P<popup>popup)?$', FileListView.as_view(), name='file_list'), | ||||
|     url(r'^file/(?P<file_id>[0-9]+)/(?P<popup>popup)?$', FileView.as_view(), name='file_detail'), | ||||
|     url(r'^file/(?P<file_id>[0-9]+)/edit/(?P<popup>popup)?$', FileEditView.as_view(), name='file_edit'), | ||||
|     url(r'^file/(?P<file_id>[0-9]+)/prop/(?P<popup>popup)?$', FileEditPropView.as_view(), name='file_prop'), | ||||
|     url(r'^file/(?P<file_id>[0-9]+)/delete/(?P<popup>popup)?$', FileDeleteView.as_view(), name='file_delete'), | ||||
|     url(r'^file/(?P<file_id>[0-9]+)/download$', send_file, name='download'), | ||||
|  | ||||
|     # Page views | ||||
|     url(r'^page/$', PageListView.as_view(), name='page_list'), | ||||
|     url(r'^page/create$', PageCreateView.as_view(), name='page_new'), | ||||
|   | ||||
| @@ -98,5 +98,6 @@ class CanViewMixin(View): | ||||
|  | ||||
| from .user import * | ||||
| from .page import * | ||||
| from .files import * | ||||
| from .site import * | ||||
| from .group import * | ||||
|   | ||||
							
								
								
									
										195
									
								
								core/views/files.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,195 @@ | ||||
| # This file contains all the views that concern the page model | ||||
| from django.shortcuts import render, redirect, get_object_or_404 | ||||
| from django.views.generic import ListView, DetailView | ||||
| from django.views.generic.edit import UpdateView, CreateView, FormMixin, DeleteView | ||||
| from django.contrib.auth.decorators import login_required, permission_required | ||||
| from django.forms.models import modelform_factory | ||||
| from django.forms import CheckboxSelectMultiple | ||||
| from django.conf import settings | ||||
| from django.utils.translation import ugettext as _ | ||||
| from django.http import HttpResponse | ||||
| from django.core.servers.basehttp import FileWrapper | ||||
| from django.core.urlresolvers import reverse | ||||
| from django.core.exceptions import PermissionDenied, ObjectDoesNotExist | ||||
| from django import forms | ||||
|  | ||||
| import os | ||||
|  | ||||
| from core.models import SithFile | ||||
| from core.views import CanViewMixin, CanEditMixin, CanEditPropMixin, CanCreateMixin, can_view, not_found | ||||
|  | ||||
| def send_file(request, file_id): | ||||
|     """ | ||||
|     Send a file through Django without loading the whole file into | ||||
|     memory at once. The FileWrapper will turn the file object into an | ||||
|     iterator for chunks of 8KB. | ||||
|     """ | ||||
|     f = SithFile.objects.filter(id=file_id).first() | ||||
|     if f is None or f.is_folder: | ||||
|         return not_found(request) | ||||
|     if not can_view(f, request.user): | ||||
|         raise PermissionDenied | ||||
|     name = f.file.name | ||||
|     with open(settings.MEDIA_ROOT + name, 'rb') as filename: | ||||
|         wrapper = FileWrapper(filename) | ||||
|         response = HttpResponse(wrapper, content_type=f.mime_type) | ||||
|         response['Content-Length'] = os.path.getsize(settings.MEDIA_ROOT + name) | ||||
|         response['Content-Disposition'] = 'inline; filename="%s"' % f.name | ||||
|         return response | ||||
|  | ||||
| class AddFileForm(forms.Form): | ||||
|     folder_name = forms.CharField(label=_("Add a new folder"), max_length=30, required=False) | ||||
|     file_field = forms.FileField(widget=forms.ClearableFileInput(attrs={'multiple': True}), label=_("Files"), | ||||
|             required=False) | ||||
|  | ||||
|     def process(self, parent, owner, files): | ||||
|         try: | ||||
|             if self.cleaned_data['folder_name'] != "": | ||||
|                 folder = SithFile(parent=parent, name=self.cleaned_data['folder_name'], owner=owner) | ||||
|                 folder.clean() | ||||
|                 folder.save() | ||||
|         except Exception as e: | ||||
|             self.add_error(None, _("Error creating folder %(folder_name)s: %(msg)s") % | ||||
|                     {'folder_name': self.cleaned_data['folder_name'], 'msg': str(e.message)}) | ||||
|         for f in files: | ||||
|             new_file = SithFile(parent=parent, name=f.name, file=f, owner=owner, is_folder=False, | ||||
|                     mime_type=f.content_type, size=f._size) | ||||
|             try: | ||||
|                 new_file.clean() | ||||
|                 new_file.save() | ||||
|                 print(f.__dict__) | ||||
|             except Exception as e: | ||||
|                 self.add_error(None, _("Error uploading file %(file_name)s: %(msg)s") % | ||||
|                         {'file_name': f, 'msg': str(e.message)}) | ||||
|  | ||||
| class FileListView(CanViewMixin, ListView, FormMixin): | ||||
|     template_name = 'core/file_list.jinja' | ||||
|     context_object_name = "file_list" | ||||
|     form_class = AddFileForm | ||||
|  | ||||
|     def get(self, request, *args, **kwargs): | ||||
|         self.form = self.get_form() | ||||
|         return super(FileListView, self).get(request, *args, **kwargs) | ||||
|  | ||||
|     def post(self, request, *args, **kwargs): | ||||
|         self.object_list = self.get_queryset() | ||||
|         self.form = self.get_form() | ||||
|         files = request.FILES.getlist('file_field') | ||||
|         if self.form.is_valid(): | ||||
|             self.form.process(parent=None, owner=request.user, files=files) | ||||
|             if self.form.is_valid(): | ||||
|                 return super(FileListView, self).form_valid(self.form) | ||||
|         return self.form_invalid(self.form) | ||||
|  | ||||
|     def get_success_url(self): | ||||
|         return reverse('core:file_list', kwargs={'popup': self.kwargs['popup'] or ""}) | ||||
|  | ||||
|     def get_queryset(self): | ||||
|         return SithFile.objects.filter(parent=None) | ||||
|  | ||||
|     def get_context_data(self, **kwargs): | ||||
|         kwargs = super(FileListView, self).get_context_data(**kwargs) | ||||
|         kwargs['popup'] = "" | ||||
|         kwargs['form'] = self.form | ||||
|         if self.kwargs['popup']: | ||||
|             kwargs['popup'] = 'popup' | ||||
|         return kwargs | ||||
|  | ||||
| class FileEditView(CanEditMixin, UpdateView): | ||||
|     model = SithFile | ||||
|     pk_url_kwarg = "file_id" | ||||
|     template_name = 'core/file_edit.jinja' | ||||
|     context_object_name = "file" | ||||
|  | ||||
|     def get_form_class(self): | ||||
|         fields = ['name'] | ||||
|         if self.object.is_file: | ||||
|             fields = ['file'] + fields | ||||
|         return modelform_factory(SithFile, fields=fields) | ||||
|  | ||||
|     def get_success_url(self): | ||||
|         if self.kwargs['popup']: | ||||
|             return reverse('core:file_detail', kwargs={'file_id': self.object.id, 'popup': "popup"}) | ||||
|         return reverse('core:file_detail', kwargs={'file_id': self.object.id, 'popup': ""}) | ||||
|  | ||||
|     def get_context_data(self, **kwargs): | ||||
|         kwargs = super(FileEditView, self).get_context_data(**kwargs) | ||||
|         kwargs['popup'] = "" | ||||
|         if self.kwargs['popup']: | ||||
|             kwargs['popup'] = 'popup' | ||||
|         return kwargs | ||||
|  | ||||
| class FileEditPropView(CanEditPropMixin, UpdateView): | ||||
|     model = SithFile | ||||
|     pk_url_kwarg = "file_id" | ||||
|     template_name = 'core/file_edit.jinja' | ||||
|     context_object_name = "file" | ||||
|     fields = ['parent', 'owner', 'edit_groups', 'view_groups'] | ||||
|  | ||||
|     def get_form(self, form_class=None): | ||||
|         form = super(FileEditPropView, self).get_form(form_class) | ||||
|         form.fields['parent'].queryset = SithFile.objects.filter(is_folder=True) | ||||
|         return form | ||||
|  | ||||
|     def get_success_url(self): | ||||
|         return reverse('core:file_detail', kwargs={'file_id': self.object.id, 'popup': self.kwargs['popup'] or ""}) | ||||
|  | ||||
|     def get_context_data(self, **kwargs): | ||||
|         kwargs = super(FileEditPropView, self).get_context_data(**kwargs) | ||||
|         kwargs['popup'] = "" | ||||
|         if self.kwargs['popup']: | ||||
|             kwargs['popup'] = 'popup' | ||||
|         return kwargs | ||||
|  | ||||
| class FileView(CanEditMixin, DetailView, FormMixin): | ||||
|     """This class handle the upload of new files into a folder""" | ||||
|     model = SithFile | ||||
|     pk_url_kwarg = "file_id" | ||||
|     template_name = 'core/file_detail.jinja' | ||||
|     context_object_name = "file" | ||||
|     form_class = AddFileForm | ||||
|  | ||||
|     def get(self, request, *args, **kwargs): | ||||
|         self.form = self.get_form() | ||||
|         return super(FileView, self).get(request, *args, **kwargs) | ||||
|  | ||||
|     def post(self, request, *args, **kwargs): | ||||
|         self.object = self.get_object() | ||||
|         self.form = self.get_form() | ||||
|         files = request.FILES.getlist('file_field') | ||||
|         if self.form.is_valid(): | ||||
|             self.form.process(parent=self.object, owner=request.user, files=files) | ||||
|             if self.form.is_valid(): | ||||
|                 return super(FileView, self).form_valid(self.form) | ||||
|         return self.form_invalid(self.form) | ||||
|  | ||||
|     def get_success_url(self): | ||||
|         return reverse('core:file_detail', kwargs={'file_id': self.object.id, 'popup': self.kwargs['popup'] or ""}) | ||||
|  | ||||
|     def get_context_data(self, **kwargs): | ||||
|         kwargs = super(FileView, self).get_context_data(**kwargs) | ||||
|         kwargs['popup'] = "" | ||||
|         kwargs['form'] = self.form | ||||
|         if self.kwargs['popup']: | ||||
|             kwargs['popup'] = 'popup' | ||||
|         return kwargs | ||||
|  | ||||
| class FileDeleteView(CanEditPropMixin, DeleteView): | ||||
|     model = SithFile | ||||
|     pk_url_kwarg = "file_id" | ||||
|     template_name = 'core/file_delete_confirm.jinja' | ||||
|     context_object_name = "file" | ||||
|  | ||||
|     def get_success_url(self): | ||||
|         self.object.file.delete() # Doing it here or overloading delete() is the same, so let's do it here | ||||
|         if self.object.parent is None: | ||||
|             return reverse('core:file_list', kwargs={'popup': self.kwargs['popup'] or ""}) | ||||
|         return reverse('core:file_detail', kwargs={'file_id': self.object.parent.id, 'popup': self.kwargs['popup'] or ""}) | ||||
|  | ||||
|     def get_context_data(self, **kwargs): | ||||
|         kwargs = super(FileDeleteView, self).get_context_data(**kwargs) | ||||
|         kwargs['popup'] = "" | ||||
|         if self.kwargs['popup']: | ||||
|             kwargs['popup'] = 'popup' | ||||
|         return kwargs | ||||
|  | ||||
| @@ -1,7 +1,8 @@ | ||||
| from django.contrib.auth.forms import UserCreationForm, AuthenticationForm, UserChangeForm | ||||
| from django import forms | ||||
| from django.contrib.auth import logout, login, authenticate | ||||
| from django.forms import CheckboxSelectMultiple | ||||
| from django.forms import CheckboxSelectMultiple, Select | ||||
| from django.utils.translation import ugettext as _ | ||||
| import logging | ||||
|  | ||||
| from core.models import User, Page, RealGroup | ||||
| @@ -51,3 +52,13 @@ class PagePropForm(forms.ModelForm): | ||||
|         self.fields['edit_groups'].required = False | ||||
|         self.fields['view_groups'].required = False | ||||
|  | ||||
| class SelectFile(Select): | ||||
|     def render(self, name, value, attrs=None): | ||||
|         output = '<span class="choose_file_widget" title="%(title)s">%(content)s</span>' % { | ||||
|                 'title': _("Choose file"), | ||||
|                 'content': super(SelectFile, self).render(name, value, attrs), | ||||
|                 } | ||||
|         output += '<span class="choose_file_button">' + _("Choose file") + '</span>' | ||||
|         print(output) | ||||
|         return output | ||||
|  | ||||
|   | ||||
| @@ -15,10 +15,6 @@ class PageListView(CanViewMixin, ListView): | ||||
|     model = Page | ||||
|     template_name = 'core/page_list.jinja' | ||||
|  | ||||
|     def get_context_data(self, **kwargs): | ||||
|         context = super(PageListView, self).get_context_data(**kwargs) | ||||
|         return context | ||||
|  | ||||
| class PageView(CanViewMixin, DetailView): | ||||
|     model = Page | ||||
|     template_name = 'core/page_detail.jinja' | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| from django.shortcuts import render, redirect, get_object_or_404 | ||||
| from django.http import HttpResponse | ||||
| from django.db import models | ||||
|  | ||||
| import os | ||||
|  | ||||
| def index(request, context=None): | ||||
|     if context == None: | ||||
|         return render(request, "core/index.jinja", {'title': 'Bienvenue!'}) | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Report-Msgid-Bugs-To: \n" | ||||
| "POT-Creation-Date: 2016-08-07 20:00+0200\n" | ||||
| "POT-Creation-Date: 2016-08-10 05:00+0200\n" | ||||
| "PO-Revision-Date: 2016-07-18\n" | ||||
| "Last-Translator: Skia <skia@libskia.so>\n" | ||||
| "Language-Team: AE info <ae.info@utbm.fr>\n" | ||||
| @@ -19,7 +19,7 @@ msgstr "" | ||||
| #: accounting/models.py:33 accounting/models.py:45 accounting/models.py:68 | ||||
| #: accounting/models.py:111 club/models.py:18 counter/models.py:52 | ||||
| #: counter/models.py:77 counter/models.py:105 launderette/models.py:14 | ||||
| #: launderette/models.py:42 launderette/models.py:65 | ||||
| #: launderette/models.py:54 launderette/models.py:77 | ||||
| msgid "name" | ||||
| msgstr "nom" | ||||
|  | ||||
| @@ -40,12 +40,12 @@ msgstr "numero de compte" | ||||
| msgid "%(club_account)s on %(bank_account)s" | ||||
| msgstr "%(club_account)s sur %(bank_account)s" | ||||
|  | ||||
| #: accounting/models.py:109 club/models.py:112 counter/models.py:259 | ||||
| #: launderette/models.py:94 | ||||
| #: accounting/models.py:109 club/models.py:112 counter/models.py:268 | ||||
| #: launderette/models.py:112 | ||||
| msgid "start date" | ||||
| msgstr "date de début" | ||||
|  | ||||
| #: accounting/models.py:110 club/models.py:113 counter/models.py:260 | ||||
| #: accounting/models.py:110 club/models.py:113 counter/models.py:269 | ||||
| msgid "end date" | ||||
| msgstr "date de fin" | ||||
|  | ||||
| @@ -54,7 +54,7 @@ msgid "is closed" | ||||
| msgstr "est fermé" | ||||
|  | ||||
| #: accounting/models.py:114 accounting/models.py:153 counter/models.py:25 | ||||
| #: counter/models.py:197 | ||||
| #: counter/models.py:206 | ||||
| msgid "amount" | ||||
| msgstr "montant" | ||||
|  | ||||
| @@ -66,12 +66,12 @@ msgstr "montant effectif" | ||||
| msgid "number" | ||||
| msgstr "numéro" | ||||
|  | ||||
| #: accounting/models.py:154 core/models.py:466 counter/models.py:200 | ||||
| #: counter/models.py:235 eboutic/models.py:13 eboutic/models.py:46 | ||||
| #: accounting/models.py:154 core/models.py:560 counter/models.py:209 | ||||
| #: counter/models.py:244 eboutic/models.py:13 eboutic/models.py:46 | ||||
| msgid "date" | ||||
| msgstr "date" | ||||
|  | ||||
| #: accounting/models.py:155 accounting/models.py:241 counter/models.py:228 | ||||
| #: accounting/models.py:155 accounting/models.py:241 counter/models.py:237 | ||||
| msgid "label" | ||||
| msgstr "intitulé" | ||||
|  | ||||
| @@ -79,7 +79,7 @@ msgstr "intitulé" | ||||
| msgid "remark" | ||||
| msgstr "remarque" | ||||
|  | ||||
| #: accounting/models.py:157 counter/models.py:201 eboutic/models.py:48 | ||||
| #: accounting/models.py:157 counter/models.py:210 eboutic/models.py:48 | ||||
| #: subscription/models.py:34 | ||||
| msgid "payment method" | ||||
| msgstr "méthode de paiement" | ||||
| @@ -121,7 +121,7 @@ msgstr "Compte" | ||||
| msgid "Company" | ||||
| msgstr "Entreprise" | ||||
|  | ||||
| #: accounting/models.py:163 sith/settings.py:259 sith/settings_sample.py:259 | ||||
| #: accounting/models.py:163 sith/settings.py:260 sith/settings_sample.py:260 | ||||
| msgid "Other" | ||||
| msgstr "Autre" | ||||
|  | ||||
| @@ -204,9 +204,9 @@ msgstr "Nouveau compte club" | ||||
| #: accounting/templates/accounting/bank_account_details.jinja:18 | ||||
| #: accounting/templates/accounting/bank_account_list.jinja:15 | ||||
| #: accounting/templates/accounting/club_account_details.jinja:44 | ||||
| #: accounting/templates/accounting/journal_details.jinja:56 | ||||
| #: club/templates/club/club_detail.jinja:7 core/templates/core/page.jinja:31 | ||||
| #: core/templates/core/user_base.jinja:8 | ||||
| #: accounting/templates/accounting/journal_details.jinja:62 | ||||
| #: club/templates/club/club_detail.jinja:7 core/templates/core/file.jinja:46 | ||||
| #: core/templates/core/page.jinja:31 core/templates/core/user_base.jinja:8 | ||||
| #: core/templates/core/user_tools.jinja:37 | ||||
| #: counter/templates/counter/counter_list.jinja:15 | ||||
| #: counter/templates/counter/counter_list.jinja:18 | ||||
| @@ -216,6 +216,7 @@ msgstr "Éditer" | ||||
|  | ||||
| #: accounting/templates/accounting/bank_account_details.jinja:19 | ||||
| #: accounting/templates/accounting/bank_account_list.jinja:16 | ||||
| #: core/templates/core/file_detail.jinja:38 | ||||
| #: core/templates/core/group_list.jinja:13 | ||||
| #: launderette/templates/launderette/launderette_admin.jinja:16 | ||||
| #: launderette/views.py:146 | ||||
| @@ -280,22 +281,22 @@ msgid "Closed" | ||||
| msgstr "Fermé" | ||||
|  | ||||
| #: accounting/templates/accounting/club_account_details.jinja:23 | ||||
| #: accounting/templates/accounting/journal_details.jinja:30 | ||||
| #: accounting/templates/accounting/journal_details.jinja:31 | ||||
| msgid "Actions" | ||||
| msgstr "Actions" | ||||
|  | ||||
| #: accounting/templates/accounting/club_account_details.jinja:39 | ||||
| #: accounting/templates/accounting/journal_details.jinja:49 | ||||
| #: accounting/templates/accounting/journal_details.jinja:50 | ||||
| msgid "Yes" | ||||
| msgstr "Oui" | ||||
|  | ||||
| #: accounting/templates/accounting/club_account_details.jinja:41 | ||||
| #: accounting/templates/accounting/journal_details.jinja:51 | ||||
| #: accounting/templates/accounting/journal_details.jinja:52 | ||||
| msgid "No" | ||||
| msgstr "Non" | ||||
|  | ||||
| #: accounting/templates/accounting/club_account_details.jinja:43 | ||||
| #: core/templates/core/page.jinja:28 | ||||
| #: core/templates/core/file.jinja:44 core/templates/core/page.jinja:28 | ||||
| msgid "View" | ||||
| msgstr "Voir" | ||||
|  | ||||
| @@ -356,6 +357,10 @@ msgstr "Effectué" | ||||
| msgid "Comment" | ||||
| msgstr "Commentaire" | ||||
|  | ||||
| #: accounting/templates/accounting/journal_details.jinja:30 | ||||
| msgid "File" | ||||
| msgstr "Fichier" | ||||
|  | ||||
| #: club/models.py:20 | ||||
| msgid "unix name" | ||||
| msgstr "nom unix" | ||||
| @@ -381,7 +386,7 @@ msgid "You can not make loops in clubs" | ||||
| msgstr "Vous ne pouvez pas faire de boucles dans les clubs" | ||||
|  | ||||
| #: club/models.py:110 eboutic/models.py:12 eboutic/models.py:45 | ||||
| #: launderette/models.py:69 launderette/models.py:98 | ||||
| #: launderette/models.py:81 launderette/models.py:116 | ||||
| msgid "user" | ||||
| msgstr "nom d'utilisateur" | ||||
|  | ||||
| @@ -415,7 +420,8 @@ msgstr "Anciens membres" | ||||
| msgid "Back to list" | ||||
| msgstr "Retour à la liste" | ||||
|  | ||||
| #: club/templates/club/club_detail.jinja:10 core/templates/core/page.jinja:34 | ||||
| #: club/templates/club/club_detail.jinja:10 core/templates/core/file.jinja:49 | ||||
| #: core/templates/core/page.jinja:34 | ||||
| msgid "Prop" | ||||
| msgstr "Propriétés" | ||||
|  | ||||
| @@ -430,7 +436,7 @@ msgstr "Éditer le club" | ||||
| #: club/templates/club/club_edit.jinja:8 | ||||
| #: club/templates/club/club_edit_prop.jinja:8 | ||||
| #: core/templates/core/create.jinja:8 core/templates/core/edit.jinja:8 | ||||
| #: core/templates/core/page_prop.jinja:8 | ||||
| #: core/templates/core/file_edit.jinja:8 core/templates/core/page_prop.jinja:8 | ||||
| #: core/templates/core/pagerev_edit.jinja:24 | ||||
| #: counter/templates/counter/counter_edit.jinja:8 | ||||
| #: subscription/templates/subscription/subscription.jinja:12 | ||||
| @@ -560,27 +566,97 @@ msgstr "Definit si l'on montre les statistiques de l'utilisateur" | ||||
| msgid "Show your account statistics to others" | ||||
| msgstr "Montrez vos statistiques de compte aux autres" | ||||
|  | ||||
| #: core/models.py:313 core/models.py:317 | ||||
| #: core/models.py:294 | ||||
| msgid "file name" | ||||
| msgstr "nom du fichier" | ||||
|  | ||||
| #: core/models.py:295 core/models.py:409 | ||||
| msgid "parent" | ||||
| msgstr "parent" | ||||
|  | ||||
| #: core/models.py:296 core/models.py:305 | ||||
| msgid "file" | ||||
| msgstr "fichier" | ||||
|  | ||||
| #: core/models.py:297 | ||||
| msgid "owner" | ||||
| msgstr "propriétaire" | ||||
|  | ||||
| #: core/models.py:298 core/models.py:415 | ||||
| msgid "edit group" | ||||
| msgstr "groupe d'édition" | ||||
|  | ||||
| #: core/models.py:299 core/models.py:416 | ||||
| msgid "view group" | ||||
| msgstr "groupe de vue" | ||||
|  | ||||
| #: core/models.py:300 | ||||
| msgid "is folder" | ||||
| msgstr "est un dossier" | ||||
|  | ||||
| #: core/models.py:301 | ||||
| msgid "mime type" | ||||
| msgstr "type mime" | ||||
|  | ||||
| #: core/models.py:302 | ||||
| msgid "size" | ||||
| msgstr "taille" | ||||
|  | ||||
| #: core/models.py:316 | ||||
| msgid "Character '/' not authorized in name" | ||||
| msgstr "Le caractère '/' n'est pas autorisé dans les noms de fichier" | ||||
|  | ||||
| #: core/models.py:319 core/models.py:324 | ||||
| msgid "Loop in folder tree" | ||||
| msgstr "Boucle dans l'arborescence des dossiers" | ||||
|  | ||||
| #: core/models.py:328 | ||||
| msgid "You can not make a file be a children of a non folder file" | ||||
| msgstr "" | ||||
| "Vous ne pouvez pas mettre un fichier enfant de quelque chose qui n'est pas " | ||||
| "un dossier" | ||||
|  | ||||
| #: core/models.py:332 | ||||
| msgid "Duplicate file" | ||||
| msgstr "Un fichier de ce nom existe déjà" | ||||
|  | ||||
| #: core/models.py:342 | ||||
| msgid "You must provide a file" | ||||
| msgstr "Vous devez fournir un fichier" | ||||
|  | ||||
| #: core/models.py:367 | ||||
| msgid "Folder: " | ||||
| msgstr "Dossier : " | ||||
|  | ||||
| #: core/models.py:369 | ||||
| msgid "File: " | ||||
| msgstr "Fichier : " | ||||
|  | ||||
| #: core/models.py:408 core/models.py:412 | ||||
| msgid "page name" | ||||
| msgstr "nom de la page" | ||||
|  | ||||
| #: core/models.py:350 | ||||
| msgid "Duplicate page" | ||||
| msgstr "Duppliquer la page" | ||||
| #: core/models.py:413 | ||||
| msgid "owner group" | ||||
| msgstr "groupe propriétaire" | ||||
|  | ||||
| #: core/models.py:356 | ||||
| #: core/models.py:444 | ||||
| msgid "Duplicate page" | ||||
| msgstr "Une page de ce nom existe déjà" | ||||
|  | ||||
| #: core/models.py:450 | ||||
| msgid "Loop in page tree" | ||||
| msgstr "Boucle dans l'arborescence des pages" | ||||
|  | ||||
| #: core/models.py:463 | ||||
| #: core/models.py:557 | ||||
| msgid "revision" | ||||
| msgstr "révision" | ||||
|  | ||||
| #: core/models.py:464 | ||||
| #: core/models.py:558 | ||||
| msgid "page title" | ||||
| msgstr "titre de la page" | ||||
|  | ||||
| #: core/models.py:465 | ||||
| #: core/models.py:559 | ||||
| msgid "page content" | ||||
| msgstr "contenu de la page" | ||||
|  | ||||
| @@ -596,48 +672,48 @@ msgstr "404. Non trouvé" | ||||
| msgid "Welcome!" | ||||
| msgstr "Bienvenue!" | ||||
|  | ||||
| #: core/templates/core/base.jinja:15 | ||||
| #: core/templates/core/base.jinja:17 | ||||
| msgid "Logo" | ||||
| msgstr "Logo" | ||||
|  | ||||
| #: core/templates/core/base.jinja:19 | ||||
| #: core/templates/core/base.jinja:20 core/templates/core/login.jinja:4 | ||||
| #: core/templates/core/password_reset_complete.jinja:5 | ||||
| msgid "Login" | ||||
| msgstr "Connexion" | ||||
|  | ||||
| #: core/templates/core/base.jinja:20 core/templates/core/register.jinja:18 | ||||
| #: core/templates/core/base.jinja:21 core/templates/core/register.jinja:18 | ||||
| msgid "Register" | ||||
| msgstr "S'enregister" | ||||
|  | ||||
| #: core/templates/core/base.jinja:23 | ||||
| #: core/templates/core/base.jinja:24 | ||||
| msgid "Tools" | ||||
| msgstr "Outils" | ||||
|  | ||||
| #: core/templates/core/base.jinja:24 | ||||
| #: core/templates/core/base.jinja:25 | ||||
| msgid "Logout" | ||||
| msgstr "Déconnexion" | ||||
|  | ||||
| #: core/templates/core/base.jinja:29 | ||||
| #: core/templates/core/base.jinja:31 | ||||
| msgid "Users" | ||||
| msgstr "Utilisateurs" | ||||
|  | ||||
| #: core/templates/core/base.jinja:30 | ||||
| #: core/templates/core/base.jinja:32 | ||||
| msgid "Wiki" | ||||
| msgstr "Wiki" | ||||
|  | ||||
| #: core/templates/core/base.jinja:31 | ||||
| #: core/templates/core/base.jinja:33 | ||||
| msgid "Pages" | ||||
| msgstr "Pages" | ||||
|  | ||||
| #: core/templates/core/base.jinja:32 | ||||
| #: core/templates/core/base.jinja:34 | ||||
| msgid "Clubs" | ||||
| msgstr "Clubs" | ||||
|  | ||||
| #: core/templates/core/base.jinja:33 | ||||
| #: core/templates/core/base.jinja:35 | ||||
| msgid "Services" | ||||
| msgstr "Services" | ||||
|  | ||||
| #: core/templates/core/base.jinja:46 | ||||
| #: core/templates/core/base.jinja:49 | ||||
| msgid "Site made by good people" | ||||
| msgstr "Site réalisé par des gens biens" | ||||
|  | ||||
| @@ -664,11 +740,59 @@ msgstr "Confirmation" | ||||
| msgid "Cancel" | ||||
| msgstr "Annuler" | ||||
|  | ||||
| #: core/templates/core/edit.jinja:4 | ||||
| #: core/templates/core/edit.jinja:4 core/templates/core/file_edit.jinja:4 | ||||
| #, python-format | ||||
| msgid "Edit %(obj)s" | ||||
| msgstr "Éditer %(obj)s" | ||||
|  | ||||
| #: core/templates/core/file.jinja:7 core/templates/core/file_list.jinja:6 | ||||
| msgid "File list" | ||||
| msgstr "Liste des fichiers" | ||||
|  | ||||
| #: core/templates/core/file.jinja:9 | ||||
| msgid "New file" | ||||
| msgstr "Nouveau fichier" | ||||
|  | ||||
| #: core/templates/core/file.jinja:11 core/templates/core/page.jinja:11 | ||||
| msgid "Not found" | ||||
| msgstr "Non trouvé" | ||||
|  | ||||
| #: core/templates/core/file.jinja:20 core/views/files.py:103 | ||||
| msgid "Files" | ||||
| msgstr "Fichiers" | ||||
|  | ||||
| #: core/templates/core/file_detail.jinja:15 | ||||
| msgid "Owner: " | ||||
| msgstr "Propriétaire : " | ||||
|  | ||||
| #: core/templates/core/file_detail.jinja:20 | ||||
| msgid "Upload" | ||||
| msgstr "Téléverser" | ||||
|  | ||||
| #: core/templates/core/file_detail.jinja:34 | ||||
| msgid "Real name: " | ||||
| msgstr "Nom réel : " | ||||
|  | ||||
| #: core/templates/core/file_detail.jinja:35 | ||||
| msgid "Type: " | ||||
| msgstr "Type : " | ||||
|  | ||||
| #: core/templates/core/file_detail.jinja:36 | ||||
| msgid "Size: " | ||||
| msgstr "Taille : " | ||||
|  | ||||
| #: core/templates/core/file_detail.jinja:36 | ||||
| msgid "bytes" | ||||
| msgstr "octets" | ||||
|  | ||||
| #: core/templates/core/file_detail.jinja:37 | ||||
| msgid "Download" | ||||
| msgstr "Télécharger" | ||||
|  | ||||
| #: core/templates/core/file_list.jinja:19 | ||||
| msgid "There is no file in this website." | ||||
| msgstr "Il n'y a pas de fichier sur ce site web." | ||||
|  | ||||
| #: core/templates/core/group_edit.jinja:5 | ||||
| msgid "Edit group" | ||||
| msgstr "Éditer le groupe" | ||||
| @@ -691,13 +815,13 @@ msgstr "Nouveau groupe" | ||||
| msgid "Hello, world. You're at the core index using Jinja2." | ||||
| msgstr "Hello, world! Vous êtes sur la page d'accueil utilisant Jinja2." | ||||
|  | ||||
| #: core/templates/core/login.jinja:6 | ||||
| #: core/templates/core/login.jinja:10 | ||||
| msgid "Your username and password didn't match. Please try again." | ||||
| msgstr "" | ||||
| "Votre nom d'utilisateur et votre mot de passe ne correspondent pas. Merci de " | ||||
| "réessayer." | ||||
|  | ||||
| #: core/templates/core/login.jinja:11 | ||||
| #: core/templates/core/login.jinja:15 | ||||
| msgid "" | ||||
| "Your account doesn't have access to this page. To proceed,\n" | ||||
| "    please login with an account that has access." | ||||
| @@ -705,16 +829,16 @@ msgstr "" | ||||
| "Votre compte n'a pas accès à cette page. Merci de vous identifier avec un " | ||||
| "compte qui a accès." | ||||
|  | ||||
| #: core/templates/core/login.jinja:14 | ||||
| #: core/templates/core/login.jinja:18 | ||||
| msgid "Please login to see this page." | ||||
| msgstr "Merci de vous identifier pour voir cette page." | ||||
|  | ||||
| #: core/templates/core/login.jinja:22 | ||||
| #: core/templates/core/login.jinja:26 | ||||
| #: counter/templates/counter/counter_main.jinja:48 | ||||
| msgid "login" | ||||
| msgstr "login" | ||||
|  | ||||
| #: core/templates/core/login.jinja:26 | ||||
| #: core/templates/core/login.jinja:30 | ||||
| msgid "Lost password?" | ||||
| msgstr "Mot de passe perdu ?" | ||||
|  | ||||
| @@ -727,10 +851,6 @@ msgstr "Liste des pages" | ||||
| msgid "Create page" | ||||
| msgstr "Créer une page" | ||||
|  | ||||
| #: core/templates/core/page.jinja:11 | ||||
| msgid "Not found" | ||||
| msgstr "Non trouvé" | ||||
|  | ||||
| #: core/templates/core/page.jinja:29 | ||||
| msgid "History" | ||||
| msgstr "Historique" | ||||
| @@ -1014,6 +1134,15 @@ msgstr "Comptabilité générale" | ||||
| msgid "Club account: " | ||||
| msgstr "Compte club : " | ||||
|  | ||||
| #: core/views/files.py:134 | ||||
| #, python-format | ||||
| msgid "Error uploading file %(file_name)s: %(msg)s" | ||||
| msgstr "Erreur d'envoie du fichier %(file_name)s : %(msg)s" | ||||
|  | ||||
| #: core/views/forms.py:58 core/views/forms.py:61 | ||||
| msgid "Choose file" | ||||
| msgstr "Choisir un fichier" | ||||
|  | ||||
| #: counter/models.py:24 | ||||
| msgid "account id" | ||||
| msgstr "numéro de compte" | ||||
| @@ -1076,31 +1205,31 @@ msgstr "vendeurs" | ||||
| msgid "counter" | ||||
| msgstr "comptoir" | ||||
|  | ||||
| #: counter/models.py:203 | ||||
| #: counter/models.py:212 | ||||
| msgid "bank" | ||||
| msgstr "banque" | ||||
|  | ||||
| #: counter/models.py:205 counter/models.py:236 | ||||
| #: counter/models.py:214 counter/models.py:245 | ||||
| msgid "is validated" | ||||
| msgstr "est validé" | ||||
|  | ||||
| #: counter/models.py:208 | ||||
| #: counter/models.py:217 | ||||
| msgid "refilling" | ||||
| msgstr "rechargement" | ||||
|  | ||||
| #: counter/models.py:231 eboutic/models.py:79 | ||||
| #: counter/models.py:240 eboutic/models.py:79 | ||||
| msgid "unit price" | ||||
| msgstr "prix unitaire" | ||||
|  | ||||
| #: counter/models.py:232 eboutic/models.py:80 | ||||
| #: counter/models.py:241 eboutic/models.py:80 | ||||
| msgid "quantity" | ||||
| msgstr "quantité" | ||||
|  | ||||
| #: counter/models.py:239 | ||||
| #: counter/models.py:248 | ||||
| msgid "selling" | ||||
| msgstr "vente" | ||||
|  | ||||
| #: counter/models.py:263 | ||||
| #: counter/models.py:272 | ||||
| msgid "permanency" | ||||
| msgstr "permanence" | ||||
|  | ||||
| @@ -1250,7 +1379,7 @@ msgstr "ANN" | ||||
| msgid "You have not enough money to buy all the basket" | ||||
| msgstr "Vous n'avez pas assez d'argent pour acheter le panier" | ||||
|  | ||||
| #: eboutic/models.py:47 sith/settings.py:253 sith/settings_sample.py:253 | ||||
| #: eboutic/models.py:47 sith/settings.py:254 sith/settings_sample.py:254 | ||||
| msgid "Credit card" | ||||
| msgstr "Carte banquaire" | ||||
|  | ||||
| @@ -1309,47 +1438,47 @@ msgstr "Le paiement a été effectué" | ||||
| msgid "Return to eboutic" | ||||
| msgstr "Retourner à l'eboutic" | ||||
|  | ||||
| #: eboutic/views.py:131 | ||||
| #: eboutic/views.py:135 | ||||
| msgid "You do not have enough money to buy the basket" | ||||
| msgstr "Vous n'avez pas assez d'argent pour acheter le panier" | ||||
|  | ||||
| #: launderette/models.py:43 launderette/models.py:66 | ||||
| #: launderette/models.py:55 launderette/models.py:78 | ||||
| msgid "launderette" | ||||
| msgstr "laverie" | ||||
|  | ||||
| #: launderette/models.py:44 launderette/models.py:67 launderette/models.py:95 | ||||
| #: launderette/models.py:56 launderette/models.py:79 launderette/models.py:113 | ||||
| msgid "type" | ||||
| msgstr "type" | ||||
|  | ||||
| #: launderette/models.py:45 | ||||
| #: launderette/models.py:57 | ||||
| msgid "is working" | ||||
| msgstr "fonctionne" | ||||
|  | ||||
| #: launderette/models.py:48 | ||||
| #: launderette/models.py:60 | ||||
| msgid "Machine" | ||||
| msgstr "Machine" | ||||
|  | ||||
| #: launderette/models.py:68 | ||||
| #: launderette/models.py:80 | ||||
| msgid "borrow date" | ||||
| msgstr "date d'emprunt" | ||||
|  | ||||
| #: launderette/models.py:72 | ||||
| #: launderette/models.py:84 | ||||
| msgid "Token" | ||||
| msgstr "Jeton" | ||||
|  | ||||
| #: launderette/models.py:78 | ||||
| #: launderette/models.py:90 | ||||
| msgid "Token name can not be blank" | ||||
| msgstr "Le nom du jeton ne peut pas être vide" | ||||
|  | ||||
| #: launderette/models.py:96 | ||||
| #: launderette/models.py:114 | ||||
| msgid "machine" | ||||
| msgstr "machine" | ||||
|  | ||||
| #: launderette/models.py:97 | ||||
| #: launderette/models.py:115 | ||||
| msgid "token" | ||||
| msgstr "jeton" | ||||
|  | ||||
| #: launderette/models.py:101 | ||||
| #: launderette/models.py:119 | ||||
| msgid "Slot" | ||||
| msgstr "Créneau" | ||||
|  | ||||
| @@ -1391,12 +1520,12 @@ msgid "Washing and drying" | ||||
| msgstr "Lavage et séchage" | ||||
|  | ||||
| #: launderette/templates/launderette/launderette_book.jinja:26 | ||||
| #: sith/settings.py:341 sith/settings_sample.py:341 | ||||
| #: sith/settings.py:342 sith/settings_sample.py:342 | ||||
| msgid "Washing" | ||||
| msgstr "Lavage" | ||||
|  | ||||
| #: launderette/templates/launderette/launderette_book.jinja:30 | ||||
| #: sith/settings.py:341 sith/settings_sample.py:341 | ||||
| #: sith/settings.py:342 sith/settings_sample.py:342 | ||||
| msgid "Drying" | ||||
| msgstr "Séchage" | ||||
|  | ||||
| @@ -1451,83 +1580,83 @@ msgstr "L'utilisateur n'a pas réservé de créneau" | ||||
| msgid "Token not found" | ||||
| msgstr "Jeton non trouvé" | ||||
|  | ||||
| #: sith/settings.py:250 sith/settings.py:257 sith/settings.py:275 | ||||
| #: sith/settings_sample.py:250 sith/settings_sample.py:257 | ||||
| #: sith/settings_sample.py:275 | ||||
| msgid "Check" | ||||
| msgstr "Chèque" | ||||
|  | ||||
| #: sith/settings.py:251 sith/settings.py:258 sith/settings.py:276 | ||||
| #: sith/settings_sample.py:251 sith/settings_sample.py:258 | ||||
| #: sith/settings_sample.py:276 | ||||
| msgid "Check" | ||||
| msgstr "Chèque" | ||||
|  | ||||
| #: sith/settings.py:252 sith/settings.py:259 sith/settings.py:277 | ||||
| #: sith/settings_sample.py:252 sith/settings_sample.py:259 | ||||
| #: sith/settings_sample.py:277 | ||||
| msgid "Cash" | ||||
| msgstr "Espèces" | ||||
|  | ||||
| #: sith/settings.py:252 sith/settings_sample.py:252 | ||||
| #: sith/settings.py:253 sith/settings_sample.py:253 | ||||
| msgid "Transfert" | ||||
| msgstr "Virement" | ||||
|  | ||||
| #: sith/settings.py:263 sith/settings_sample.py:263 | ||||
| #: sith/settings.py:264 sith/settings_sample.py:264 | ||||
| msgid "Belfort" | ||||
| msgstr "Belfort" | ||||
|  | ||||
| #: sith/settings.py:264 sith/settings_sample.py:264 | ||||
| #: sith/settings.py:265 sith/settings_sample.py:265 | ||||
| msgid "Sevenans" | ||||
| msgstr "Sevenans" | ||||
|  | ||||
| #: sith/settings.py:265 sith/settings_sample.py:265 | ||||
| #: sith/settings.py:266 sith/settings_sample.py:266 | ||||
| msgid "Montbéliard" | ||||
| msgstr "Montbéliard" | ||||
|  | ||||
| #: sith/settings.py:289 sith/settings_sample.py:289 | ||||
| #: sith/settings.py:290 sith/settings_sample.py:290 | ||||
| msgid "One semester" | ||||
| msgstr "Un semestre" | ||||
|  | ||||
| #: sith/settings.py:294 sith/settings_sample.py:294 | ||||
| #: sith/settings.py:295 sith/settings_sample.py:295 | ||||
| msgid "Two semesters" | ||||
| msgstr "Deux semestres" | ||||
|  | ||||
| #: sith/settings.py:299 sith/settings_sample.py:299 | ||||
| #: sith/settings.py:300 sith/settings_sample.py:300 | ||||
| msgid "Common core cursus" | ||||
| msgstr "Cursus tronc commun" | ||||
|  | ||||
| #: sith/settings.py:304 sith/settings_sample.py:304 | ||||
| #: sith/settings.py:305 sith/settings_sample.py:305 | ||||
| msgid "Branch cursus" | ||||
| msgstr "Cursus branche" | ||||
|  | ||||
| #: sith/settings.py:312 sith/settings_sample.py:312 | ||||
| #: sith/settings.py:313 sith/settings_sample.py:313 | ||||
| msgid "President" | ||||
| msgstr "Président" | ||||
|  | ||||
| #: sith/settings.py:313 sith/settings_sample.py:313 | ||||
| #: sith/settings.py:314 sith/settings_sample.py:314 | ||||
| msgid "Vice-President" | ||||
| msgstr "Vice-Président" | ||||
|  | ||||
| #: sith/settings.py:314 sith/settings_sample.py:314 | ||||
| #: sith/settings.py:315 sith/settings_sample.py:315 | ||||
| msgid "Treasurer" | ||||
| msgstr "Trésorier" | ||||
|  | ||||
| #: sith/settings.py:315 sith/settings_sample.py:315 | ||||
| #: sith/settings.py:316 sith/settings_sample.py:316 | ||||
| msgid "Communication supervisor" | ||||
| msgstr "Responsable com" | ||||
|  | ||||
| #: sith/settings.py:316 sith/settings_sample.py:316 | ||||
| #: sith/settings.py:317 sith/settings_sample.py:317 | ||||
| msgid "Secretary" | ||||
| msgstr "Secrétaire" | ||||
|  | ||||
| #: sith/settings.py:317 sith/settings_sample.py:317 | ||||
| #: sith/settings.py:318 sith/settings_sample.py:318 | ||||
| msgid "IT supervisor" | ||||
| msgstr "Responsable info" | ||||
|  | ||||
| #: sith/settings.py:318 sith/settings_sample.py:318 | ||||
| #: sith/settings.py:319 sith/settings_sample.py:319 | ||||
| msgid "Board member" | ||||
| msgstr "Membre du bureau" | ||||
|  | ||||
| #: sith/settings.py:319 sith/settings_sample.py:319 | ||||
| #: sith/settings.py:320 sith/settings_sample.py:320 | ||||
| msgid "Active member" | ||||
| msgstr "Membre actif" | ||||
|  | ||||
| #: sith/settings.py:320 sith/settings_sample.py:320 | ||||
| #: sith/settings.py:321 sith/settings_sample.py:321 | ||||
| msgid "Curious" | ||||
| msgstr "Curieux" | ||||
|  | ||||
|   | ||||
| @@ -107,6 +107,7 @@ TEMPLATES = [ | ||||
|                 "can_edit_prop": "core.views.can_edit_prop", | ||||
|                 "can_edit": "core.views.can_edit", | ||||
|                 "can_view": "core.views.can_view", | ||||
|                 "send_file": "core.views.send_file", | ||||
|                 "get_subscriber": "subscription.views.get_subscriber", | ||||
|                 "settings": "sith.settings", | ||||
|             }, | ||||
|   | ||||
| @@ -32,3 +32,4 @@ urlpatterns = [ | ||||
|     url(r'^api/v1/', include('api.urls', namespace="api", app_name="api")), | ||||
|     url(r'^admin/', include(admin.site.urls)), | ||||
| ] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) # TODO: remove me for production!!! | ||||
|  | ||||
|   | ||||