Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
W
widget_tee jays angelos
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Ramon Angelo Enriquez
widget_tee jays angelos
Commits
aff87aa5
Commit
aff87aa5
authored
May 16, 2022
by
Paul Angelo Sy
Browse files
Options
Browse Files
Download
Plain Diff
Changed url direction for assignments
parents
a81a0f49
9599c99a
Changes
25
Hide whitespace changes
Inline
Side-by-side
Showing
25 changed files
with
367 additions
and
47 deletions
+367
-47
views.cpython-39.pyc
...ys_angelos/announcements/__pycache__/views.cpython-39.pyc
+0
-0
index.html
widget_tee_jays_angelos/assignments/index.html
+0
-23
db.sqlite3
widget_tee_jays_angelos/db.sqlite3
+0
-0
0003_alter_department_dept_name_and_more.py
...ge/migrations/0003_alter_department_dept_name_and_more.py
+38
-0
0004_remove_widgetuser_email.py
...gelos/homepage/migrations/0004_remove_widgetuser_email.py
+17
-0
0005_widgetuser_email.py
...jays_angelos/homepage/migrations/0005_widgetuser_email.py
+18
-0
0006_widgetuser_picture.py
...ys_angelos/homepage/migrations/0006_widgetuser_picture.py
+18
-0
0007_alter_widgetuser_picture.py
...elos/homepage/migrations/0007_alter_widgetuser_picture.py
+18
-0
0008_alter_widgetuser_picture.py
...elos/homepage/migrations/0008_alter_widgetuser_picture.py
+18
-0
0009_alter_widgetuser_picture.py
...elos/homepage/migrations/0009_alter_widgetuser_picture.py
+18
-0
0010_alter_widgetuser_picture.py
...elos/homepage/migrations/0010_alter_widgetuser_picture.py
+18
-0
0011_alter_widgetuser_picture.py
...elos/homepage/migrations/0011_alter_widgetuser_picture.py
+18
-0
models.py
widget_tee_jays_angelos/homepage/models.py
+6
-5
homepagestyle.css
...e_jays_angelos/homepage/static/homepage/homepagestyle.css
+92
-0
base.html
...et_tee_jays_angelos/homepage/templates/homepage/base.html
+20
-0
details.html
...tee_jays_angelos/homepage/templates/homepage/details.html
+21
-0
index.html
...t_tee_jays_angelos/homepage/templates/homepage/index.html
+15
-0
urls.py
widget_tee_jays_angelos/homepage/urls.py
+2
-2
views.py
widget_tee_jays_angelos/homepage/views.py
+21
-15
enriquez.jpg
widget_tee_jays_angelos/static/images/media/enriquez.jpg
+0
-0
lim.jpg
widget_tee_jays_angelos/static/images/media/lim.jpg
+0
-0
sumawang.jpg
widget_tee_jays_angelos/static/images/media/sumawang.jpg
+0
-0
sy.jpg
widget_tee_jays_angelos/static/images/media/sy.jpg
+0
-0
settings.py
widget_tee_jays_angelos/widget_tee_jays_angelos/settings.py
+5
-1
urls.py
widget_tee_jays_angelos/widget_tee_jays_angelos/urls.py
+4
-1
No files found.
widget_tee_jays_angelos/announcements/__pycache__/views.cpython-39.pyc
0 → 100644
View file @
aff87aa5
File added
widget_tee_jays_angelos/assignments/index.html
deleted
100644 → 0
View file @
a81a0f49
{% extends 'base.html' %}
{% block head %}
{% load static %}
<link
rel=
"stylesheet"
type=
"text/css"
href=
"{% static 'assignments/style.css' %}"
>
{% endblock %}
{% block content %}
<h1>
Assignments Per Course
</h1>
{% if course_list %}
{% for course in course_list %}
<li
class =
"bold"
>
{{course}} {{course.course_title}} {{course.section}}
{% for assignment in assignment_list %}
{% if assignment.course_code == course %}
<ul
class =
"small"
>
<li>
<a
href=
"/assignments/{{assignment.id}}/details"
>
{{assignment.name}}
</a></li>
</ul>
{% endif %}
{% endfor %}
</li>
{% endfor %}
{% else %}
<p>
No assignments are available
</p>
{% endif %}
{% endblock %}
widget_tee_jays_angelos/db.sqlite3
View file @
aff87aa5
No preview for this file type
widget_tee_jays_angelos/homepage/migrations/0003_alter_department_dept_name_and_more.py
0 → 100644
View file @
aff87aa5
# Generated by Django 4.0.3 on 2022-04-05 13:57
from
django.db
import
migrations
,
models
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'homepage'
,
'0002_widgetuser_email_widgetuser_id_num_department'
),
]
operations
=
[
migrations
.
AlterField
(
model_name
=
'department'
,
name
=
'dept_name'
,
field
=
models
.
CharField
(
max_length
=
50
,
null
=
True
),
),
migrations
.
AlterField
(
model_name
=
'department'
,
name
=
'home_unit'
,
field
=
models
.
CharField
(
max_length
=
50
,
null
=
True
),
),
migrations
.
AlterField
(
model_name
=
'widgetuser'
,
name
=
'first_name'
,
field
=
models
.
CharField
(
max_length
=
50
,
null
=
True
),
),
migrations
.
AlterField
(
model_name
=
'widgetuser'
,
name
=
'last_name'
,
field
=
models
.
CharField
(
max_length
=
50
,
null
=
True
),
),
migrations
.
AlterField
(
model_name
=
'widgetuser'
,
name
=
'middle_name'
,
field
=
models
.
CharField
(
max_length
=
50
,
null
=
True
),
),
]
widget_tee_jays_angelos/homepage/migrations/0004_remove_widgetuser_email.py
0 → 100644
View file @
aff87aa5
# Generated by Django 4.0.3 on 2022-05-08 04:48
from
django.db
import
migrations
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'homepage'
,
'0003_alter_department_dept_name_and_more'
),
]
operations
=
[
migrations
.
RemoveField
(
model_name
=
'widgetuser'
,
name
=
'email'
,
),
]
widget_tee_jays_angelos/homepage/migrations/0005_widgetuser_email.py
0 → 100644
View file @
aff87aa5
# Generated by Django 4.0.3 on 2022-05-08 05:02
from
django.db
import
migrations
,
models
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'homepage'
,
'0004_remove_widgetuser_email'
),
]
operations
=
[
migrations
.
AddField
(
model_name
=
'widgetuser'
,
name
=
'email'
,
field
=
models
.
CharField
(
max_length
=
50
,
null
=
True
),
),
]
widget_tee_jays_angelos/homepage/migrations/0006_widgetuser_picture.py
0 → 100644
View file @
aff87aa5
# Generated by Django 4.0.3 on 2022-05-08 08:04
from
django.db
import
migrations
,
models
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'homepage'
,
'0005_widgetuser_email'
),
]
operations
=
[
migrations
.
AddField
(
model_name
=
'widgetuser'
,
name
=
'picture'
,
field
=
models
.
ImageField
(
null
=
True
,
upload_to
=
None
),
),
]
widget_tee_jays_angelos/homepage/migrations/0007_alter_widgetuser_picture.py
0 → 100644
View file @
aff87aa5
# Generated by Django 4.0.3 on 2022-05-08 08:16
from
django.db
import
migrations
,
models
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'homepage'
,
'0006_widgetuser_picture'
),
]
operations
=
[
migrations
.
AlterField
(
model_name
=
'widgetuser'
,
name
=
'picture'
,
field
=
models
.
ImageField
(
null
=
True
,
upload_to
=
'media'
),
),
]
widget_tee_jays_angelos/homepage/migrations/0008_alter_widgetuser_picture.py
0 → 100644
View file @
aff87aa5
# Generated by Django 4.0.3 on 2022-05-10 06:41
from
django.db
import
migrations
,
models
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'homepage'
,
'0007_alter_widgetuser_picture'
),
]
operations
=
[
migrations
.
AlterField
(
model_name
=
'widgetuser'
,
name
=
'picture'
,
field
=
models
.
ImageField
(
blank
=
True
,
null
=
True
,
upload_to
=
'media'
),
),
]
widget_tee_jays_angelos/homepage/migrations/0009_alter_widgetuser_picture.py
0 → 100644
View file @
aff87aa5
# Generated by Django 4.0.3 on 2022-05-10 07:07
from
django.db
import
migrations
,
models
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'homepage'
,
'0008_alter_widgetuser_picture'
),
]
operations
=
[
migrations
.
AlterField
(
model_name
=
'widgetuser'
,
name
=
'picture'
,
field
=
models
.
ImageField
(
blank
=
True
,
null
=
True
,
upload_to
=
'static/media/'
),
),
]
widget_tee_jays_angelos/homepage/migrations/0010_alter_widgetuser_picture.py
0 → 100644
View file @
aff87aa5
# Generated by Django 4.0.3 on 2022-05-10 07:10
from
django.db
import
migrations
,
models
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'homepage'
,
'0009_alter_widgetuser_picture'
),
]
operations
=
[
migrations
.
AlterField
(
model_name
=
'widgetuser'
,
name
=
'picture'
,
field
=
models
.
ImageField
(
blank
=
True
,
null
=
True
,
upload_to
=
'homepage/static/media/'
),
),
]
widget_tee_jays_angelos/homepage/migrations/0011_alter_widgetuser_picture.py
0 → 100644
View file @
aff87aa5
# Generated by Django 4.0.3 on 2022-05-10 14:04
from
django.db
import
migrations
,
models
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'homepage'
,
'0010_alter_widgetuser_picture'
),
]
operations
=
[
migrations
.
AlterField
(
model_name
=
'widgetuser'
,
name
=
'picture'
,
field
=
models
.
ImageField
(
blank
=
True
,
null
=
True
,
upload_to
=
'media/'
),
),
]
widget_tee_jays_angelos/homepage/models.py
View file @
aff87aa5
...
@@ -3,11 +3,12 @@ from django.db import models
...
@@ -3,11 +3,12 @@ from django.db import models
class
WidgetUser
(
models
.
Model
):
class
WidgetUser
(
models
.
Model
):
first_name
=
models
.
CharField
(
max_length
=
50
)
first_name
=
models
.
CharField
(
max_length
=
50
,
null
=
True
)
middle_name
=
models
.
CharField
(
max_length
=
50
)
middle_name
=
models
.
CharField
(
max_length
=
50
,
null
=
True
)
last_name
=
models
.
CharField
(
max_length
=
50
)
last_name
=
models
.
CharField
(
max_length
=
50
,
null
=
True
)
id_num
=
models
.
CharField
(
max_length
=
7
,
null
=
True
)
id_num
=
models
.
CharField
(
max_length
=
7
,
null
=
True
)
email
=
models
.
CharField
(
max_length
=
50
,
null
=
True
)
email
=
models
.
CharField
(
max_length
=
50
,
null
=
True
)
picture
=
models
.
ImageField
(
upload_to
=
"media/"
,
height_field
=
None
,
width_field
=
None
,
max_length
=
100
,
null
=
True
,
blank
=
True
)
def
__str__
(
self
):
def
__str__
(
self
):
return
self
.
last_name
+
", "
+
self
.
first_name
return
self
.
last_name
+
", "
+
self
.
first_name
...
@@ -16,8 +17,8 @@ class WidgetUser(models.Model):
...
@@ -16,8 +17,8 @@ class WidgetUser(models.Model):
class
Department
(
models
.
Model
):
class
Department
(
models
.
Model
):
widget_user
=
models
.
ForeignKey
(
WidgetUser
,
on_delete
=
models
.
CASCADE
,
widget_user
=
models
.
ForeignKey
(
WidgetUser
,
on_delete
=
models
.
CASCADE
,
blank
=
True
,
null
=
True
)
blank
=
True
,
null
=
True
)
dept_name
=
models
.
CharField
(
max_length
=
50
)
dept_name
=
models
.
CharField
(
max_length
=
50
,
null
=
True
)
home_unit
=
models
.
CharField
(
max_length
=
50
)
home_unit
=
models
.
CharField
(
max_length
=
50
,
null
=
True
)
def
__str__
(
self
):
def
__str__
(
self
):
return
self
.
dept_name
+
", "
+
self
.
home_unit
return
self
.
dept_name
+
", "
+
self
.
home_unit
widget_tee_jays_angelos/homepage/static/homepage/homepagestyle.css
0 → 100644
View file @
aff87aa5
h1
,
h2
{
color
:
black
;
font-family
:
'Montserrat'
,
sans-serif
;
position
:
relative
;
}
li
{
color
:
black
;
font-family
:
'Source Sans Pro'
,
sans-serif
;
position
:
relative
;
top
:
10px
;
margin
:
10px
;
}
p
{
font-family
:
'Source Sans Pro'
,
sans-serif
;
font-size
:
18px
;
}
img
{
position
:
absolute
;
left
:
400px
;
top
:
20px
;
border-radius
:
50%
;
}
.picShadow
{
height
:
200px
;
width
:
200px
;
border-radius
:
50%
;
background-color
:
grey
;
position
:
absolute
;
left
:
390px
;
top
:
30px
;
}
.detailsHeaderName
{
color
:
black
;
position
:
absolute
;
left
:
650px
;
top
:
70px
;
}
.detailsHeaderDept
{
font-family
:
'Source Sans Pro'
,
sans-serif
;
color
:
black
;
font-style
:
italic
;
position
:
absolute
;
left
:
650px
;
top
:
120px
;
font-weight
:
lighter
;
}
.rectangleDetailsHeader
{
position
:
absolute
;
left
:
0px
;
top
:
0px
;
height
:
250px
;
width
:
100%
;
background-color
:
#daeaf6
;
}
.homepageRectangleHeader
{
position
:
absolute
;
left
:
0px
;
top
:
0px
;
width
:
100%
;
height
:
80px
;
background-color
:
#ddedea
;
}
.arrow
{
width
:
20px
;
height
:
4px
;
background-color
:
black
;
position
:
relative
;
top
:
10px
;
left
:
5px
;
}
.arrow
:before
{
content
:
""
;
display
:
inline-block
;
position
:
relative
;
top
:
-17px
;
left
:
0px
;
width
:
15px
;
height
:
4px
;
background-color
:
black
;
transform
:
rotate
(
-45deg
);
}
.arrow
:after
{
content
:
""
;
display
:
inline-block
;
position
:
relative
;
top
:
-23px
;
left
:
-1px
;
width
:
15px
;
height
:
4px
;
background-color
:
black
;
transform
:
rotate
(
45deg
);
}
widget_tee_jays_angelos/homepage/templates/homepage/base.html
0 → 100644
View file @
aff87aa5
{% load static %}
<!DOCTYPE html>
<html
lang=
"en"
dir=
"ltr"
>
<head>
<meta
charset=
"utf-8"
>
<meta
http-equiv=
"X-UA-Compatible"
content=
"IE=edge"
>
<meta
name=
"viewport"
content=
"width=device-width, initial-scale=1.0"
>
<link
rel=
"preconnect"
href=
"https://fonts.googleapis.com"
>
<link
rel=
"preconnect"
href=
"https://fonts.gstatic.com"
crossorigin
>
<link
href=
"https://fonts.googleapis.com/css2?family=Montserrat:wght@700&display=swap"
rel=
"stylesheet"
>
<link
href=
"https://fonts.googleapis.com/css2?family=Source+Sans+Pro&display=swap"
rel=
"stylesheet"
>
<link
rel=
"stylesheet"
type=
"text/css"
href=
"{% static 'homepage/homepagestyle.css' %}"
>
<title>
Homepage
</title>
</head>
<body>
{% block content %}
{% endblock %}
</body>
</html>
widget_tee_jays_angelos/homepage/templates/homepage/details.html
0 → 100644
View file @
aff87aa5
{% extends "homepage/base.html "%}
{% block content %}
{% if user %}
<div
class=
"rectangleDetailsHeader"
></div>
<a
href=
"/homepage/"
><div
class=
"arrow"
></div></a>
<h1
class=
"detailsHeaderName"
>
{{ user.first_name }} {{ user.last_name }}
</h1>
<h3
class=
"detailsHeaderDept"
>
Department of {{ userDept.dept_name }}
</h3>
<h2
style=
"position: absolute; left: 300px; top: 270px; background-color: #fcf4dd;"
>
Personal Information
</h2>
<h2
style=
"position: absolute; left: 300px; top: 450px; background-color: #fcf4dd;"
>
Department Information
</h2>
<h2
style=
"position: absolute; left: 850px; top: 270px; background-color: #fcf4dd;"
>
Contact Details
</h2>
<p
style=
"position:absolute; left: 300px; top: 325px;"
>
Complete Name: {{ user.last_name }}, {{user.first_name }} {{ user.middle_name }}
</p>
<p
style=
"position:absolute; left: 300px; top: 370px;"
>
ID Number: {{ user.id_num }}
</p>
<p
style=
"position: absolute; left: 300px; top: 500px;"
>
Department: {{ userDept.dept_name }}
</p>
<p
style=
"position: absolute; left: 300px; top: 545px;"
>
Home Unit: {{ userDept.home_unit }}
</p>
<p
style=
"position: absolute; left: 850px; top: 325px;"
>
Email: {{ user.email }}
</p>
<div
class=
"picShadow"
></div>
<img
src=
"{{ user.picture.url }}"
width=
"200"
height=
"200"
>
{% else %}
<p>
User not found.
</p>
{% endif %}
{% endblock %}
widget_tee_jays_angelos/homepage/templates/homepage/index.html
0 → 100644
View file @
aff87aa5
{% extends "homepage/base.html" %}
{% block content %}
<div
class=
"homepageRectangleHeader"
></div>
<h1
style=
"text-align: center"
>
Welcome to Widget!
</h1>
<h2
style=
"position: relative; top: 20px;"
>
Widget Users
</h2>
{% if user_list %}
<ol
type=
"1"
>
{% for user in user_list %}
<li><a
href=
"/homepage/users/{{ user.id }}/details"
>
{{ user.last_name }}, {{ user.first_name }} {{ user.middle_name }}
</a></li>
{% endfor %}
</ol>
{% else %}
<p>
No users found.
</p>
{% endif %}
{% endblock %}
widget_tee_jays_angelos/homepage/urls.py
View file @
aff87aa5
from
django.urls
import
path
from
django.urls
import
path
from
.
import
views
from
.
import
views
urlpatterns
=
[
urlpatterns
=
[
path
(
''
,
views
.
index
,
name
=
"homepage"
)
path
(
''
,
views
.
index
,
name
=
"homepage"
),
path
(
'users/<int:user_id>/details/'
,
views
.
details
,
name
=
"details"
),
]
]
widget_tee_jays_angelos/homepage/views.py
View file @
aff87aa5
from
django.http
import
HttpResponse
from
django.http
import
HttpResponse
,
Http404
from
homepage.models
import
WidgetUser
,
Department
from
homepage.models
import
WidgetUser
,
Department
from
django.shortcuts
import
render
from
django.template
import
loader
# Create your views here.
# Create your views here.
def
index
(
request
):
def
index
(
request
):
entries
=
WidgetUser
.
objects
.
all
()
.
count
()
user_list
=
WidgetUser
.
objects
.
order_by
(
"last_name"
)
n
=
1
context
=
{
users
=
"WIDGET USERS:<br/>"
"user_list"
:
user_list
,
while
(
n
<=
entries
):
}
userLastName
=
WidgetUser
.
objects
.
get
(
pk
=
n
)
.
last_name
userFirstName
=
WidgetUser
.
objects
.
get
(
pk
=
n
)
.
first_name
userMiddleName
=
WidgetUser
.
objects
.
get
(
pk
=
n
)
.
middle_name
userIdNum
=
WidgetUser
.
objects
.
get
(
pk
=
n
)
.
id_num
userEmail
=
WidgetUser
.
objects
.
get
(
pk
=
n
)
.
email
userDept
=
Department
.
objects
.
get
(
widget_user
=
n
)
.
dept_name
userHome
=
Department
.
objects
.
get
(
widget_user
=
n
)
.
home_unit
users
=
users
+
userLastName
+
", "
+
userFirstName
+
" "
+
userMiddleName
+
": "
+
userIdNum
+
", "
+
userEmail
+
", "
+
userDept
+
", "
+
userHome
+
"<br/>"
n
+=
1
return
HttpResponse
(
users
)
return
render
(
request
,
"homepage/index.html"
,
context
)
def
details
(
request
,
user_id
):
try
:
user
=
WidgetUser
.
objects
.
get
(
pk
=
user_id
)
userDept
=
Department
.
objects
.
get
(
widget_user
=
user
)
except
WidgetUser
.
DoesNotExist
:
raise
Http404
(
"User does not exist."
)
context
=
{
"user"
:
user
,
"userDept"
:
userDept
,
}
return
render
(
request
,
"homepage/details.html"
,
context
)
widget_tee_jays_angelos/static/images/media/enriquez.jpg
0 → 100644
View file @
aff87aa5
862 KB
widget_tee_jays_angelos/static/images/media/lim.jpg
0 → 100644
View file @
aff87aa5
17 KB
widget_tee_jays_angelos/static/images/media/sumawang.jpg
0 → 100644
View file @
aff87aa5
46.3 KB
widget_tee_jays_angelos/static/images/media/sy.jpg
0 → 100644
View file @
aff87aa5
13 KB
widget_tee_jays_angelos/widget_tee_jays_angelos/settings.py
View file @
aff87aa5
...
@@ -123,7 +123,11 @@ USE_TZ = True
...
@@ -123,7 +123,11 @@ USE_TZ = True
# Static files (CSS, JavaScript, Images)
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/4.0/howto/static-files/
# https://docs.djangoproject.com/en/4.0/howto/static-files/
STATIC_URL
=
'static/'
STATIC_URL
=
'/static/'
MEDIA_URL
=
'/images/'
MEDIA_ROOT
=
os
.
path
.
join
(
BASE_DIR
,
'static/images'
)
# Default primary key field type
# Default primary key field type
# https://docs.djangoproject.com/en/4.0/ref/settings/#default-auto-field
# https://docs.djangoproject.com/en/4.0/ref/settings/#default-auto-field
...
...
widget_tee_jays_angelos/widget_tee_jays_angelos/urls.py
View file @
aff87aa5
...
@@ -15,6 +15,8 @@ Including another URLconf
...
@@ -15,6 +15,8 @@ Including another URLconf
"""
"""
from
django.contrib
import
admin
from
django.contrib
import
admin
from
django.urls
import
include
,
path
from
django.urls
import
include
,
path
from
django.conf
import
settings
from
django.conf.urls.static
import
static
urlpatterns
=
[
urlpatterns
=
[
path
(
'forum/'
,
include
(
"forum.urls"
)),
path
(
'forum/'
,
include
(
"forum.urls"
)),
...
@@ -22,5 +24,6 @@ urlpatterns = [
...
@@ -22,5 +24,6 @@ urlpatterns = [
path
(
'homepage/'
,
include
(
"homepage.urls"
)),
path
(
'homepage/'
,
include
(
"homepage.urls"
)),
path
(
'announcements/'
,
include
(
"announcements.urls"
)),
path
(
'announcements/'
,
include
(
"announcements.urls"
)),
path
(
'admin/'
,
admin
.
site
.
urls
),
path
(
'admin/'
,
admin
.
site
.
urls
),
]
]
urlpatterns
+=
static
(
settings
.
MEDIA_URL
,
document_root
=
settings
.
MEDIA_ROOT
)
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment