Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
gargantext
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
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
humanities
gargantext
Commits
8b8d869f
Commit
8b8d869f
authored
Oct 23, 2014
by
Administrator
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[FEATURE] Adding form to add corpus in jumbotron of corpus page.
parent
5fcbcd00
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
82 additions
and
64 deletions
+82
-64
views.py
gargantext_web/views.py
+67
-62
admin.py
node/admin.py
+2
-2
project.html
templates/project.html
+11
-0
projects.html
templates/projects.html
+2
-0
No files found.
gargantext_web/views.py
View file @
8b8d869f
...
@@ -6,7 +6,10 @@ from django.template.loader import get_template
...
@@ -6,7 +6,10 @@ from django.template.loader import get_template
from
django.template
import
Context
from
django.template
import
Context
#from documents.models import Project, Corpus, Document
#from documents.models import Project, Corpus, Document
from
node.models
import
Node
,
NodeType
,
Project
from
node.models
import
Language
,
DatabaseType
,
Resource
from
node.models
import
Node
,
NodeType
,
Project
,
Corpus
from
node.admin
import
CorpusForm
,
ProjectForm
from
django.contrib.auth.models
import
User
from
django.contrib.auth.models
import
User
...
@@ -114,9 +117,7 @@ def project(request, project_id):
...
@@ -114,9 +117,7 @@ def project(request, project_id):
except
ValueError
:
except
ValueError
:
raise
Http404
()
raise
Http404
()
t
=
get_template
(
'project.html'
)
user
=
request
.
user
user
=
request
.
user
date
=
datetime
.
datetime
.
now
()
date
=
datetime
.
datetime
.
now
()
project
=
Node
.
objects
.
get
(
id
=
project_id
)
project
=
Node
.
objects
.
get
(
id
=
project_id
)
...
@@ -131,15 +132,46 @@ def project(request, project_id):
...
@@ -131,15 +132,46 @@ def project(request, project_id):
dashboard
[
'count'
]
=
corpus
.
children
.
count
()
dashboard
[
'count'
]
=
corpus
.
children
.
count
()
board
.
append
(
dashboard
)
board
.
append
(
dashboard
)
html
=
t
.
render
(
Context
({
\
'user'
:
user
,
\
'date'
:
date
,
\
'project'
:
project
,
\
'board'
:
board
,
\
'number'
:
number
,
\
}))
return
HttpResponse
(
html
)
form
=
CorpusForm
(
request
=
request
)
if
request
.
method
==
'POST'
:
#form = CorpusForm(request.POST, request.FILES)
name
=
str
(
request
.
POST
[
'name'
])
try
:
#language = Language.objects.get(name=str(request.POST['language']))
language
=
Language
.
objects
.
get
(
name
=
'French'
)
except
Exception
as
e
:
print
(
e
)
language
=
None
if
name
!=
""
:
project_id
=
1047
node_type
=
NodeType
.
objects
.
get
(
name
=
'Corpus'
)
parent
=
Node
.
objects
.
get
(
id
=
project_id
)
Node
(
parent
=
parent
,
type
=
node_type
,
name
=
name
,
user
=
request
.
user
,
language
=
language
)
.
save
()
# try:
# for resource in node.resource.all():
# fileparser = PubmedFileParser.PubmedFileParser(file='/var/www/gargantext/media/' + str(resource.file))
# fileparser.parse(node)
#
# except Exception as error:
# print(error)
return
HttpResponseRedirect
(
'/project/'
+
str
(
project_id
))
else
:
form
=
CorpusForm
(
request
=
request
)
return
render
(
request
,
'project.html'
,
{
'form'
:
form
,
'user'
:
user
,
'date'
:
date
,
'project'
:
project
,
'board'
:
board
,
'number'
:
number
,
})
def
corpus
(
request
,
project_id
,
corpus_id
):
def
corpus
(
request
,
project_id
,
corpus_id
):
if
not
request
.
user
.
is_authenticated
():
if
not
request
.
user
.
is_authenticated
():
...
@@ -239,67 +271,40 @@ def corpus(request, project_id, corpus_id):
...
@@ -239,67 +271,40 @@ def corpus(request, project_id, corpus_id):
return
HttpResponse
(
html
)
return
HttpResponse
(
html
)
from
node.admin
import
CorpusForm
,
ProjectForm
class
NameForm
(
forms
.
Form
):
your_name
=
forms
.
CharField
(
label
=
'Your name'
,
max_length
=
100
)
sender
=
forms
.
EmailField
()
message
=
forms
.
CharField
(
widget
=
forms
.
Textarea
)
fichier
=
forms
.
FileField
()
def
add_corpus
(
request
):
def
add_corpus
(
request
):
# if this is a POST request we need to process the form data
form
=
CorpusForm
(
request
=
request
)
# print(request.method)
if
request
.
method
==
'POST'
:
if
request
.
method
==
'POST'
:
# create a form instance and populate it with data from the request:
#form = CorpusForm(request.POST, request.FILES)
form
=
CorpusForm
(
request
.
POST
,
request
.
FILES
)
name
=
str
(
request
.
POST
[
'name'
])
print
(
form
)
# check whether it's valid:
try
:
if
form
.
is_valid
():
#language = Language.objects.get(name=str(request.POST['language']))
node
=
form
.
save
()
language
=
Language
.
objects
.
get
(
name
=
'French'
)
# print(form.cleaned_data['name'])
except
Exception
as
e
:
print
(
e
)
try
:
language
=
None
for
resource
in
node
.
resource
.
all
():
fileparser
=
PubmedFileParser
.
PubmedFileParser
(
file
=
'/var/www/gargantext/media/'
+
str
(
resource
.
file
))
if
name
!=
""
:
fileparser
.
parse
(
node
)
project_id
=
1047
node_type
=
NodeType
.
objects
.
get
(
name
=
'Corpus'
)
parent
=
Node
.
objects
.
get
(
id
=
project_id
)
Corpus
(
parent
=
parent
,
type
=
node_type
,
name
=
name
,
user
=
request
.
user
,
language
=
language
)
.
save
()
# try:
# for resource in node.resource.all():
# fileparser = PubmedFileParser.PubmedFileParser(file='/var/www/gargantext/media/' + str(resource.file))
# fileparser.parse(node)
#
# except Exception as error:
# print(error)
except
Exception
as
error
:
return
HttpResponseRedirect
(
'/project/'
+
str
(
project_id
))
print
(
error
)
# redirect to a new URL:
return
HttpResponseRedirect
(
'/projects/'
)
# else:
# print('Not valid')
# print(request.POST)
# form = CorpusForm(request=request)
#
# if a GET (or any other method) we'll create a blank form
else
:
else
:
print
(
'Not valid'
)
print
(
request
.
POST
)
form
=
CorpusForm
(
request
=
request
)
form
=
CorpusForm
(
request
=
request
)
return
render
(
request
,
'add_corpus.html'
,
{
'form'
:
form
})
return
render
(
request
,
'add_corpus.html'
,
{
'form'
:
form
})
def
add_project
(
request
):
if
request
.
method
==
'POST'
:
print
(
request
.
POST
)
#request.POST['user'] = request.user
form
=
ProjectForm
(
request
.
POST
)
print
(
form
)
if
form
.
is_valid
():
node
=
form
.
save
()
return
HttpResponseRedirect
(
'/projects/'
)
else
:
form
=
ProjectForm
()
return
render
(
request
,
'add_project.html'
,
{
'form'
:
form
})
def
delete_project
(
request
,
node_id
):
def
delete_project
(
request
,
node_id
):
Node
.
objects
.
filter
(
id
=
node_id
)
.
all
()
.
delete
()
Node
.
objects
.
filter
(
id
=
node_id
)
.
all
()
.
delete
()
...
...
node/admin.py
View file @
8b8d869f
...
@@ -96,8 +96,8 @@ class CorpusForm(ModelForm):
...
@@ -96,8 +96,8 @@ class CorpusForm(ModelForm):
pass
pass
class
Meta
:
class
Meta
:
model
=
Corpus
model
=
Corpus
exclude
=
[
'
ngrams'
,
'metadata
'
]
exclude
=
[
'
parent'
,
'user'
,
'type'
,
'ngrams'
,
'metadata'
,
'resource'
,
'date
'
]
class
CorpusAdmin
(
NodeAdmin
):
class
CorpusAdmin
(
NodeAdmin
):
_parent_nodetype_name
=
'Project'
_parent_nodetype_name
=
'Project'
...
...
templates/project.html
View file @
8b8d869f
...
@@ -15,14 +15,25 @@
...
@@ -15,14 +15,25 @@
<div
class=
"container theme-showcase"
role=
"main"
>
<div
class=
"container theme-showcase"
role=
"main"
>
<div
class=
"jumbotron"
>
<div
class=
"jumbotron"
>
<div
class=
"row"
>
<div
class=
"col-md-3"
>
{% if project %}
{% if project %}
<h1>
{{ project.name }}
</h1>
<h1>
{{ project.name }}
</h1>
<h3>
{{number}} corpora
</h3>
<h3>
{{number}} corpora
</h3>
<p>
<p>
</div>
<a
class=
"btn btn-primary btn-lg"
role=
"button"
href=
"/add/corpus/"
>
Add a corpus
</a></p>
<a
class=
"btn btn-primary btn-lg"
role=
"button"
href=
"/add/corpus/"
>
Add a corpus
</a></p>
<div
class=
"col-md-4"
>
<form
enctype=
"multipart/form-data"
action=
"/project/{{project.id}}/"
method=
"post"
>
{% csrf_token %}
{{ form.non_field_errors }}
{{ form.as_p}}
<input
type=
"submit"
value=
"Add Corpus"
/>
</form>
{% endif %}
{% endif %}
</div>
</div>
</div>
</div>
</div>
<!-- Add jumbotron container for each type of coprus (presse, science etc.) --!>
<!-- Add jumbotron container for each type of coprus (presse, science etc.) --!>
...
...
templates/projects.html
View file @
8b8d869f
...
@@ -17,6 +17,8 @@
...
@@ -17,6 +17,8 @@
<div
class=
"col-md-3"
>
<div
class=
"col-md-3"
>
<h1>
My {{number}} projects
</h1>
<h1>
My {{number}} projects
</h1>
<p>
Template showing my working space
</p>
<p>
Template showing my working space
</p>
</div>
<div
class=
"col-md-4"
></div>
<div
class=
"col-md-4"
></div>
<div
class=
"col-md-4"
></div>
<div
class=
"col-md-4"
></div>
<div
class=
"col-md-4"
></div>
<div
class=
"col-md-4"
>
<div
class=
"col-md-4"
>
...
...
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