root / snf-astakos-app / astakos / im / tables.py @ a5cef8d0
History | View | Annotate | Download (1.6 kB)
1 |
import django_tables2 as tables |
---|---|
2 |
|
3 |
from django.utils.translation import ugettext as _ |
4 |
from django_tables2 import A |
5 |
from astakos.im.models import * |
6 |
from django.utils.safestring import mark_safe |
7 |
|
8 |
DEFAULT_DATE_FORMAT = "d/m/Y"
|
9 |
|
10 |
|
11 |
MEMBER_STATUS_DISPLAY = { |
12 |
100: _('Owner'), |
13 |
0: _('Requested'), |
14 |
1: _('Pending'), |
15 |
2: _('Accepted'), |
16 |
3: _('Removing'), |
17 |
4: _('Removed'), |
18 |
-1: _('Unregistered'), |
19 |
} |
20 |
|
21 |
class UserProjectApplicationsTable(tables.Table): |
22 |
|
23 |
def __init__(self, *args, **kwargs): |
24 |
self.user = None |
25 |
|
26 |
if 'request' in kwargs and kwargs.get('request').user: |
27 |
self.user = kwargs.get('request').user |
28 |
|
29 |
if 'user' in kwargs: |
30 |
self.user = kwargs.pop('user') |
31 |
|
32 |
super(UserProjectApplicationsTable, self).__init__(*args, **kwargs) |
33 |
|
34 |
|
35 |
name = tables.LinkColumn('astakos.im.views.project_detail', args=(A('pk'),)) |
36 |
issue_date = tables.DateColumn(format=DEFAULT_DATE_FORMAT) |
37 |
start_date = tables.DateColumn(format=DEFAULT_DATE_FORMAT) |
38 |
state = tables.Column(verbose_name="Status")
|
39 |
members_count = tables.Column(verbose_name="Enrolled", default=0, |
40 |
sortable=False)
|
41 |
membership_status = tables.Column(verbose_name="My status", empty_values=(),
|
42 |
orderable=False)
|
43 |
|
44 |
def render_membership_status(self, *args, **kwargs): |
45 |
return MEMBER_STATUS_DISPLAY.get(kwargs.get('record').member_status(self.user)) |
46 |
|
47 |
class Meta: |
48 |
model = ProjectApplication |
49 |
fields = ('name', 'membership_status', 'issue_date', 'start_date', |
50 |
'state', 'members_count') |
51 |
|