refonte de la partie contents
This commit is contained in:
@@ -7,10 +7,13 @@ from .views.default import (
|
|||||||
to_percent,
|
to_percent,
|
||||||
to_decimal,
|
to_decimal,
|
||||||
)
|
)
|
||||||
|
from .models.contents import (
|
||||||
|
get_docs_themes,
|
||||||
|
)
|
||||||
|
|
||||||
@layout_config(template='templates/global_layout.pt')
|
@layout_config(template='templates/global_layout.pt')
|
||||||
class GlobalLayout(object):
|
class GlobalLayout(object):
|
||||||
# page_title = "Pagode Tinh-Do"
|
# page_title = "Cao's blog"
|
||||||
|
|
||||||
def __init__(self, context, request):
|
def __init__(self, context, request):
|
||||||
self.context = context
|
self.context = context
|
||||||
@@ -30,8 +33,8 @@ class GlobalLayout(object):
|
|||||||
return to_percent(x, d)
|
return to_percent(x, d)
|
||||||
|
|
||||||
def isAnonymous(self):
|
def isAnonymous(self):
|
||||||
user = self.request.authenticated_userid
|
logged_in = self.request.authenticated_userid
|
||||||
return user is None
|
return logged_in is None
|
||||||
|
|
||||||
def isAdmin(self):
|
def isAdmin(self):
|
||||||
logged_in = self.request.authenticated_userid
|
logged_in = self.request.authenticated_userid
|
||||||
@@ -42,3 +45,13 @@ class GlobalLayout(object):
|
|||||||
is_admin = True
|
is_admin = True
|
||||||
|
|
||||||
return is_admin
|
return is_admin
|
||||||
|
|
||||||
|
def get_themes(self):
|
||||||
|
# lire toutes les themes
|
||||||
|
logged_in = self.request.authenticated_userid
|
||||||
|
themes = get_docs_themes(self.request, logged_in)
|
||||||
|
dossiers = []
|
||||||
|
for theme in themes:
|
||||||
|
dossiers.append(theme.theme)
|
||||||
|
return dossiers
|
||||||
|
|
||||||
|
|||||||
84
caotek_mesavoirs/models/contents.py
Normal file
84
caotek_mesavoirs/models/contents.py
Normal file
@@ -0,0 +1,84 @@
|
|||||||
|
# -*- coding: utf8 -*-
|
||||||
|
from sqlalchemy import text
|
||||||
|
from sqlalchemy.ext.declarative import declarative_base
|
||||||
|
from sqlalchemy.orm import (
|
||||||
|
scoped_session,
|
||||||
|
sessionmaker,
|
||||||
|
)
|
||||||
|
|
||||||
|
from zope.sqlalchemy import ZopeTransactionExtension, mark_changed
|
||||||
|
|
||||||
|
from datetime import *
|
||||||
|
import transaction
|
||||||
|
from urllib.request import urlopen
|
||||||
|
|
||||||
|
from .default import (
|
||||||
|
execute_query,
|
||||||
|
)
|
||||||
|
|
||||||
|
def get_docs(request, doc_id):
|
||||||
|
"""Lire les doc"""
|
||||||
|
if doc_id == 0:
|
||||||
|
query = "SELECT * FROM docs ORDER BY theme, intitule;"
|
||||||
|
results = request.dbsession.execute(query).fetchall()
|
||||||
|
else:
|
||||||
|
query = "SELECT * FROM docs where doc_id = :doc_id;"
|
||||||
|
results = request.dbsession.execute(query, {'doc_id': doc_id}).first()
|
||||||
|
return results
|
||||||
|
|
||||||
|
def get_docs_bytheme(request, theme, logged_in):
|
||||||
|
"""Lire les doc"""
|
||||||
|
if logged_in == None:
|
||||||
|
anon = "AND statut = 'public' "
|
||||||
|
else:
|
||||||
|
anon = ""
|
||||||
|
if theme == 'BLOG':
|
||||||
|
query = "SELECT * FROM docs WHERE theme=:theme %s ORDER BY cree_le DESC LIMIT 10;" % anon
|
||||||
|
else:
|
||||||
|
query = "SELECT * FROM docs WHERE theme=:theme ORDER BY intitule;"
|
||||||
|
results = request.dbsession.execute(query, {'theme': theme}).fetchall()
|
||||||
|
return results
|
||||||
|
|
||||||
|
def get_docs_tags(request):
|
||||||
|
query = "SELECT * FROM docs_tags;"
|
||||||
|
results = request.dbsession.execute(query).fetchall()
|
||||||
|
return results
|
||||||
|
|
||||||
|
def get_docs_themes(request, logged_in):
|
||||||
|
if logged_in == None:
|
||||||
|
query = "SELECT * FROM docs_themes WHERE statut = 'public';"
|
||||||
|
else:
|
||||||
|
query = "SELECT * FROM docs_themes;"
|
||||||
|
results = request.dbsession.execute(query).fetchall()
|
||||||
|
return results
|
||||||
|
|
||||||
|
def get_docs_bycritere(request, critere, logged_in):
|
||||||
|
if logged_in == None:
|
||||||
|
query = "SELECT * FROM docs WHERE (texte like :critere) OR (intitule like :critere) AND statut = 'public';"
|
||||||
|
else:
|
||||||
|
query = "SELECT * FROM docs WHERE (texte like :critere) OR (intitule like :critere);"
|
||||||
|
results = request.dbsession.execute(query, {'critere': '%' + critere + '%'}).fetchall()
|
||||||
|
return results
|
||||||
|
|
||||||
|
def update_doc(request, doc_id, new_values):
|
||||||
|
"""créér ou modifier le doc"""
|
||||||
|
# formater les champs
|
||||||
|
s = ''
|
||||||
|
for param in new_values.keys():
|
||||||
|
if s:
|
||||||
|
s += ",%s=:%s" % (param, param)
|
||||||
|
else:
|
||||||
|
s = "%s=:%s" % (param, param)
|
||||||
|
|
||||||
|
if doc_id == '0':
|
||||||
|
query = "INSERT INTO docs SET %s;" % s
|
||||||
|
else:
|
||||||
|
new_values['doc_id'] = doc_id
|
||||||
|
query = "update docs SET %s WHERE doc_id = :doc_id;" % s
|
||||||
|
execute_query(request, query, new_values)
|
||||||
|
|
||||||
|
def delete_doc(request, doc_id):
|
||||||
|
"""supprimer la doc"""
|
||||||
|
query = "delete from docs where doc_id = :doc_id;"
|
||||||
|
execute_query(request, query, {'doc_id': doc_id})
|
||||||
|
|
||||||
@@ -17,62 +17,3 @@ def execute_query(request, query, params):
|
|||||||
mark_changed(request.dbsession)
|
mark_changed(request.dbsession)
|
||||||
transaction.commit()
|
transaction.commit()
|
||||||
|
|
||||||
def get_docs(request, doc_id):
|
|
||||||
"""Lire les doc"""
|
|
||||||
if doc_id == 0:
|
|
||||||
query = "SELECT * FROM docs ORDER BY theme, intitule;"
|
|
||||||
results = request.dbsession.execute(query).fetchall()
|
|
||||||
else:
|
|
||||||
query = "SELECT * FROM docs where doc_id = :doc_id;"
|
|
||||||
results = request.dbsession.execute(query, {'doc_id': doc_id}).first()
|
|
||||||
return results
|
|
||||||
|
|
||||||
def get_docs_bytheme(request, theme):
|
|
||||||
"""Lire les doc"""
|
|
||||||
if theme == 'BLOG':
|
|
||||||
query = "SELECT * FROM docs WHERE theme=:theme ORDER BY cree_le DESC LIMIT 10;"
|
|
||||||
else:
|
|
||||||
query = "SELECT * FROM docs WHERE theme=:theme ORDER BY intitule;"
|
|
||||||
results = request.dbsession.execute(query, {'theme': theme}).fetchall()
|
|
||||||
return results
|
|
||||||
|
|
||||||
def get_docs_tags(request):
|
|
||||||
query = "SELECT * FROM docs_tags;"
|
|
||||||
results = request.dbsession.execute(query).fetchall()
|
|
||||||
return results
|
|
||||||
|
|
||||||
def get_docs_themes(request):
|
|
||||||
query = "SELECT * FROM docs_themes;"
|
|
||||||
results = request.dbsession.execute(query).fetchall()
|
|
||||||
return results
|
|
||||||
|
|
||||||
def get_docs_bycritere(request, critere, logged_in):
|
|
||||||
if logged_in == None:
|
|
||||||
query = "SELECT * FROM docs JOIN docs_themes ON docs.theme = docs_themes.theme WHERE (docs.texte like :critere) OR (docs.intitule like :critere) AND docs_themes.visible = 'oui';"
|
|
||||||
else:
|
|
||||||
query = "SELECT * FROM docs JOIN docs_themes ON docs.theme = docs_themes.theme WHERE (docs.texte like :critere) OR (docs.intitule like :critere);"
|
|
||||||
results = request.dbsession.execute(query, {'critere': '%' + critere + '%'}).fetchall()
|
|
||||||
return results
|
|
||||||
|
|
||||||
def update_doc(request, doc_id, new_values):
|
|
||||||
"""créér ou modifier le doc"""
|
|
||||||
# formater les champs
|
|
||||||
s = ''
|
|
||||||
for param in new_values.keys():
|
|
||||||
if s:
|
|
||||||
s += ",%s=:%s" % (param, param)
|
|
||||||
else:
|
|
||||||
s = "%s=:%s" % (param, param)
|
|
||||||
|
|
||||||
if doc_id == '0':
|
|
||||||
query = "INSERT INTO docs SET %s;" % s
|
|
||||||
else:
|
|
||||||
new_values['doc_id'] = doc_id
|
|
||||||
query = "update docs SET %s WHERE doc_id = :doc_id;" % s
|
|
||||||
execute_query(request, query, new_values)
|
|
||||||
|
|
||||||
def delete_doc(request, doc_id):
|
|
||||||
"""supprimer la doc"""
|
|
||||||
query = "delete from docs where doc_id = :doc_id;"
|
|
||||||
execute_query(request, query, {'doc_id': doc_id})
|
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,8 @@ def includeme(config):
|
|||||||
config.add_static_view('static', 'static', cache_max_age=3600)
|
config.add_static_view('static', 'static', cache_max_age=3600)
|
||||||
config.add_route('home', '/')
|
config.add_route('home', '/')
|
||||||
config.add_route('apropos', 'apropos')
|
config.add_route('apropos', 'apropos')
|
||||||
config.add_route('archives', '/archives')
|
# contents
|
||||||
|
config.add_route('folder', '/folder/{theme}')
|
||||||
config.add_route('doc_edit', '/doc_edit/{doc_id}')
|
config.add_route('doc_edit', '/doc_edit/{doc_id}')
|
||||||
config.add_route('doc_view', '/doc_view/{doc_id}')
|
config.add_route('doc_view', '/doc_view/{doc_id}')
|
||||||
config.add_route('doc_search', '/doc_search')
|
config.add_route('doc_search', '/doc_search')
|
||||||
|
|||||||
@@ -8,6 +8,7 @@
|
|||||||
border-radius: 0;
|
border-radius: 0;
|
||||||
min-height: 70px;
|
min-height: 70px;
|
||||||
font-size: 20px !important;
|
font-size: 20px !important;
|
||||||
|
letter-spacing: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.navbar li a, .navbar {
|
.navbar li a, .navbar {
|
||||||
@@ -49,6 +50,12 @@
|
|||||||
color: #000000 !important;
|
color: #000000 !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.menu-item {
|
||||||
|
font-size: 20px !important;
|
||||||
|
letter-spacing: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@media (min-width: 1200px) {
|
@media (min-width: 1200px) {
|
||||||
.container{
|
.container{
|
||||||
max-width: 900px;
|
max-width: 900px;
|
||||||
|
|||||||
@@ -1,37 +0,0 @@
|
|||||||
<div metal:use-macro="load: global_layout.pt">
|
|
||||||
<div metal:fill-slot="content">
|
|
||||||
|
|
||||||
<div class="row" tal:condition="not layout.isAnonymous()">
|
|
||||||
<form method="post" id="frm">
|
|
||||||
<div class="form-group col-xs-4">
|
|
||||||
|
|
||||||
<select class="form-control" name="theme" onChange="$('#frm').submit()">
|
|
||||||
<div tal:repeat="item themes">
|
|
||||||
<option value="${item.theme}" tal:attributes="selected theme == item.theme and 'selected' or None">
|
|
||||||
${item.theme}
|
|
||||||
</option>
|
|
||||||
</div>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
<div class="col-xs-8">
|
|
||||||
<a role="button" class="btn btn-success" href="${request.application_url}/doc_edit/0">Créer un nouveau post</a>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
<div class="row">
|
|
||||||
<table class="table">
|
|
||||||
<tr tal:repeat="ligne docs">
|
|
||||||
<td><a href="/doc_view/${ligne.doc_id}"><b>${ligne.intitule}</b></a></td>
|
|
||||||
<td>${ligne.tag1}</td>
|
|
||||||
<td>${ligne.cree_le.strftime("%d-%m-%Y")}</td>
|
|
||||||
<td>${ligne.modif_le.strftime("%d-%m-%Y")}</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<br />
|
|
||||||
<br />
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
<div metal:use-macro="load: global_layout.pt">
|
<div metal:use-macro="load: ../global_layout.pt">
|
||||||
<div metal:fill-slot="content">
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
<div class="alert alert-danger" tal:condition="message" tal:content="message" />
|
<div class="alert alert-danger" tal:condition="message" tal:content="message" />
|
||||||
@@ -50,6 +50,16 @@
|
|||||||
<input type="text" class="form-control" name="tag2" value="${doc.tag2}" />
|
<input type="text" class="form-control" name="tag2" value="${doc.tag2}" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-xs-2" for="tag2">Statut</label>
|
||||||
|
<div class="col-xs-6">
|
||||||
|
<select class="form-control" id="tag1" name="tag1">
|
||||||
|
<div tal:repeat="item statuts">
|
||||||
|
<option value="${item}" tal:attributes="selected doc.statut==item and 'selected' or None">${item}</option>
|
||||||
|
</div>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<div class="col-sm-offset-2 col-sm-10">
|
<div class="col-sm-offset-2 col-sm-10">
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
<div metal:use-macro="load: global_layout.pt">
|
<div metal:use-macro="load: ../global_layout.pt">
|
||||||
<div metal:fill-slot="content">
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
<div metal:use-macro="load: global_layout.pt">
|
<div metal:use-macro="load: ../global_layout.pt">
|
||||||
<div metal:fill-slot="content">
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
@@ -10,8 +10,12 @@
|
|||||||
Page text goes here.
|
Page text goes here.
|
||||||
</div>
|
</div>
|
||||||
<hr>
|
<hr>
|
||||||
Dernière modification le ${modif_le}<br />
|
Dernière modification le ${doc.modif_le.strftime('%d/%m/%Y')}<br />
|
||||||
Tags : ${tags}
|
Tags : ${tags}
|
||||||
|
|
||||||
|
<div tal:condition="not layout.isAnonymous">
|
||||||
|
Status : ${doc.statut}
|
||||||
|
</div>
|
||||||
|
|
||||||
<br />
|
<br />
|
||||||
<br />
|
<br />
|
||||||
19
caotek_mesavoirs/templates/contents/folder.pt
Normal file
19
caotek_mesavoirs/templates/contents/folder.pt
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
<div metal:use-macro="load: ../global_layout.pt">
|
||||||
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<table class="table">
|
||||||
|
<tr tal:repeat="ligne docs">
|
||||||
|
<td><a href="/doc_view/${ligne.doc_id}"><b>${ligne.intitule}</b></a></td>
|
||||||
|
<td>${ligne.tag1}</td>
|
||||||
|
<td>${ligne.cree_le.strftime("%d-%m-%Y")}</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
@@ -65,6 +65,11 @@
|
|||||||
<br />
|
<br />
|
||||||
<br />
|
<br />
|
||||||
<div class="container">
|
<div class="container">
|
||||||
|
<div align="center" tal:condition="not layout.isAnonymous()">
|
||||||
|
<span class="menu-item" tal:repeat="item layout.get_themes()">
|
||||||
|
<a href="${request.application_url}/folder/${item}">${item}</a>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
<h1 tal:condition="request.path != '/'">${page_title}</h1>
|
<h1 tal:condition="request.path != '/'">${page_title}</h1>
|
||||||
<div id="messages" tal:attributes="class request.is_xhr and 'ajax-replace' or None">
|
<div id="messages" tal:attributes="class request.is_xhr and 'ajax-replace' or None">
|
||||||
<div tal:repeat="queue ('', 'info', 'success', 'warning', 'danger')"
|
<div tal:repeat="queue ('', 'info', 'success', 'warning', 'danger')"
|
||||||
@@ -88,11 +93,11 @@
|
|||||||
|
|
||||||
<footer class="container-fluid bg-black">
|
<footer class="container-fluid bg-black">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<p class="text-center">
|
<p class="text-center" tal:condition="not layout.isAnonymous()">
|
||||||
<a href="https://www.instagram.com/ctphuoc/" alt="instagram" target="_blank">
|
<a href="https://www.instagram.com/ctphuoc/" alt="instagram" target="_blank">
|
||||||
<img src="${request.static_url('caotek_mesavoirs:static/img/instagram.png')}" /></a><br />
|
<img src="${request.static_url('caotek_mesavoirs:static/img/instagram.png')}" /></a><br />
|
||||||
</p>
|
|
||||||
<br />
|
<br />
|
||||||
|
</p>
|
||||||
<p class="text-center">© 2017 - Phuoc Cao |
|
<p class="text-center">© 2017 - Phuoc Cao |
|
||||||
<a href="${request.application_url}/apropos">à propos</a> |
|
<a href="${request.application_url}/apropos">à propos</a> |
|
||||||
<a href="${request.application_url}/doc_search">recherche</a>
|
<a href="${request.application_url}/doc_search">recherche</a>
|
||||||
|
|||||||
@@ -10,7 +10,7 @@
|
|||||||
<div class="col-sm-8">
|
<div class="col-sm-8">
|
||||||
<h3>Derniers posts</h3>
|
<h3>Derniers posts</h3>
|
||||||
<p>
|
<p>
|
||||||
| <a href="${request.application_url}/archives">Voir les archives</a> |
|
| <a href="${request.application_url}/folder/blog">Voir tous les posts</a> |
|
||||||
<a tal:condition="not layout.isAnonymous()" href="${request.application_url}/doc_edit/0">Créer un nouveau post |</a>
|
<a tal:condition="not layout.isAnonymous()" href="${request.application_url}/doc_edit/0">Créer un nouveau post |</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
|||||||
@@ -11,7 +11,7 @@
|
|||||||
<li><a href="${request.application_url}/preferences">Mes préférences</a></li>
|
<li><a href="${request.application_url}/preferences">Mes préférences</a></li>
|
||||||
<li><a href="https://www.markdownguide.org/basic-syntax/">Markdown syntax</a></li>
|
<li><a href="https://www.markdownguide.org/basic-syntax/">Markdown syntax</a></li>
|
||||||
<li tal:condition="layout.isAdmin()"><a href="${request.application_url}/users_list">Gestion des membres</a></li>
|
<li tal:condition="layout.isAdmin()"><a href="${request.application_url}/users_list">Gestion des membres</a></li>
|
||||||
<li tal:condition="layout.isAdmin()"><a href="${request.application_url}/portfolio">Portefeuille</a></li>
|
<li tal:condition="layout.isAdmin()"><a href="${request.application_url}/portfolio">Portfolio</a></li>
|
||||||
|
|
||||||
<li class="divider"></li>
|
<li class="divider"></li>
|
||||||
<li><a href="${request.application_url}/logout">
|
<li><a href="${request.application_url}/logout">
|
||||||
|
|||||||
@@ -59,10 +59,10 @@
|
|||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
<p>
|
<p>
|
||||||
<b>Allocation globale</b> : 60% actions + 5% REITS + 35% obligations<br />
|
<b>Allocation globale</b> : 70% actions + 30% obligations<br />
|
||||||
<b>Allocation actions D</b> (1/2) : 60% US (18%) + 30% Europe (12%)<br />
|
[Inspirée du
|
||||||
<b>Allocation actions C</b> (1/2) : 100% World (30%) <br />
|
<a href="https://www.nbim.no/en/the-fund/how-we-invest/benchmark-index/" target="_blank">Fond souverain Norvégien</a>]<br />
|
||||||
[Cette allocation est inspirée de celle du <a href="https://www.nbim.no/en/the-fund/how-we-invest/benchmark-index/">Fond souverain Norvégien</a>]
|
<b>Allocation actions</b> : 80% Monde (56%) + 20% Croissance (14%)<br />
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|||||||
142
caotek_mesavoirs/views/contents.py
Normal file
142
caotek_mesavoirs/views/contents.py
Normal file
@@ -0,0 +1,142 @@
|
|||||||
|
# -*- coding: utf8 -*-
|
||||||
|
from pyramid.response import Response
|
||||||
|
from pyramid.renderers import render, get_renderer
|
||||||
|
from pyramid.view import (
|
||||||
|
view_config,
|
||||||
|
forbidden_view_config,
|
||||||
|
)
|
||||||
|
from pyramid.httpexceptions import (
|
||||||
|
HTTPFound,
|
||||||
|
HTTPNotFound,
|
||||||
|
HTTPForbidden,
|
||||||
|
)
|
||||||
|
|
||||||
|
from ..models.contents import *
|
||||||
|
|
||||||
|
def isAnonymous(self):
|
||||||
|
logged_in = self.request.authenticated_userid
|
||||||
|
return logged_in is None
|
||||||
|
|
||||||
|
@view_config(route_name='folder', renderer='../templates/contents/folder.pt')
|
||||||
|
def folder(request):
|
||||||
|
theme = request.matchdict['theme']
|
||||||
|
logged_in = request.authenticated_userid
|
||||||
|
|
||||||
|
# lire toutes les docs du theme
|
||||||
|
docs = get_docs_bytheme(request, theme, logged_in)
|
||||||
|
|
||||||
|
return {
|
||||||
|
'page_title': "Contenu de %s" % theme.upper(),
|
||||||
|
'docs': docs,
|
||||||
|
}
|
||||||
|
|
||||||
|
@view_config(route_name='doc_edit', renderer='../templates/contents/doc_edit.pt', permission='view')
|
||||||
|
def doc_edit(request):
|
||||||
|
doc_id = request.matchdict['doc_id']
|
||||||
|
url = request.route_url('doc_edit',doc_id=doc_id)
|
||||||
|
logged_in = request.authenticated_userid
|
||||||
|
|
||||||
|
message = ""
|
||||||
|
themes = get_docs_themes(request, logged_in)
|
||||||
|
tags = get_docs_tags(request)
|
||||||
|
statuts = ['private', 'public']
|
||||||
|
|
||||||
|
if doc_id == '0':
|
||||||
|
titre = "Nouveau doc"
|
||||||
|
# nouveau
|
||||||
|
doc = {}
|
||||||
|
doc['intitule'] = ''
|
||||||
|
doc['texte'] = ''
|
||||||
|
doc['theme'] = ''
|
||||||
|
doc['tag1'] = ''
|
||||||
|
doc['tag2'] = ''
|
||||||
|
doc['statut'] = 'private'
|
||||||
|
else:
|
||||||
|
titre = "Modifier : %s" % str(doc_id)
|
||||||
|
doc = get_docs(request, doc_id)
|
||||||
|
|
||||||
|
if 'form.submitted' in request.params:
|
||||||
|
new_values = {}
|
||||||
|
for param, db_value in doc.items():
|
||||||
|
if param in request.params and request.params[param] != db_value:
|
||||||
|
new_values[param] = request.params[param]
|
||||||
|
|
||||||
|
if new_values:
|
||||||
|
update_doc(request, doc_id, new_values)
|
||||||
|
if doc_id != '0':
|
||||||
|
return HTTPFound(location=request.route_url('doc_view', doc_id=doc_id))
|
||||||
|
else:
|
||||||
|
return HTTPFound(location=request.route_url('folder',theme=request.params['theme']))
|
||||||
|
|
||||||
|
if 'form.deleted' in request.params:
|
||||||
|
if doc_id != '0':
|
||||||
|
delete_doc(request, doc_id)
|
||||||
|
request.session.flash(u"<%s> est supprimée avec succès." % doc.intitule, 'success')
|
||||||
|
return HTTPFound(location=request.route_url('folder',theme=doc.theme))
|
||||||
|
|
||||||
|
return {
|
||||||
|
'page_title': titre,
|
||||||
|
'url': url,
|
||||||
|
'message': message,
|
||||||
|
'doc_id': doc_id,
|
||||||
|
'doc': doc,
|
||||||
|
'themes': themes,
|
||||||
|
'tags': tags,
|
||||||
|
'statuts': statuts,
|
||||||
|
}
|
||||||
|
|
||||||
|
@view_config(route_name='doc_search', renderer='../templates/contents/doc_search.pt')
|
||||||
|
def doc_search(request):
|
||||||
|
|
||||||
|
logged_in = request.authenticated_userid
|
||||||
|
critere = ''
|
||||||
|
docs = []
|
||||||
|
|
||||||
|
if 'form.submitted' in request.params:
|
||||||
|
critere = request.params['critere']
|
||||||
|
# si afficher tous les fiches ?
|
||||||
|
docs = get_docs_bycritere(request, critere, logged_in)
|
||||||
|
|
||||||
|
return {
|
||||||
|
'page_title': "Rechercher",
|
||||||
|
'docs': docs,
|
||||||
|
'critere': critere,
|
||||||
|
}
|
||||||
|
|
||||||
|
@view_config(route_name='doc_view', renderer='../templates/contents/doc_view.pt')
|
||||||
|
def doc_view(request):
|
||||||
|
|
||||||
|
doc_id = request.matchdict['doc_id']
|
||||||
|
|
||||||
|
# lire le document
|
||||||
|
doc = get_docs(request, doc_id)
|
||||||
|
|
||||||
|
if isAnonymous and doc.statut == 'private':
|
||||||
|
# si anonyme, interdire de voir les docs privés
|
||||||
|
return HTTPFound(location=request.route_url('home'))
|
||||||
|
|
||||||
|
if doc_id == '2':
|
||||||
|
# mouvements portfolio, retour vers portfolio
|
||||||
|
url_retour = request.route_url('portfolio')
|
||||||
|
else:
|
||||||
|
url_retour = request.route_url('folder',theme=doc.theme)
|
||||||
|
tags = doc.tag1
|
||||||
|
if doc.tag2:
|
||||||
|
tags += ', ' + doc.tag2
|
||||||
|
|
||||||
|
# insèrer le path de static/img
|
||||||
|
texte = doc.texte.replace('static/img/', "%s/static/img/" % request.application_url)
|
||||||
|
|
||||||
|
# convertir mardown en HTML
|
||||||
|
from markdown2 import Markdown
|
||||||
|
markdowner = Markdown()
|
||||||
|
texte = markdowner.convert(texte)
|
||||||
|
|
||||||
|
return {
|
||||||
|
'page_title': doc.intitule,
|
||||||
|
'doc_id': doc_id,
|
||||||
|
'doc': doc,
|
||||||
|
'texte': texte,
|
||||||
|
'tags': tags,
|
||||||
|
'url_retour':url_retour,
|
||||||
|
}
|
||||||
@@ -16,17 +16,17 @@ from pyramid_mailer.message import Message, Attachment
|
|||||||
from sqlalchemy.exc import DBAPIError
|
from sqlalchemy.exc import DBAPIError
|
||||||
from ..security import groupfinder
|
from ..security import groupfinder
|
||||||
|
|
||||||
from ..models.default import *
|
|
||||||
from ..models.members import (
|
from ..models.members import (
|
||||||
get_member_by_email
|
get_member_by_email
|
||||||
)
|
)
|
||||||
|
from ..models.contents import (
|
||||||
|
get_docs_bytheme
|
||||||
|
)
|
||||||
|
|
||||||
# import datetime
|
# import datetime
|
||||||
import time
|
import time
|
||||||
import hashlib
|
import hashlib
|
||||||
import locale
|
import locale
|
||||||
import json
|
|
||||||
import yfinance as yf
|
|
||||||
|
|
||||||
def to_decimal(x):
|
def to_decimal(x):
|
||||||
import decimal
|
import decimal
|
||||||
@@ -68,106 +68,19 @@ def to_percent(x, d):
|
|||||||
@view_config(route_name='home', renderer='../templates/home.pt')
|
@view_config(route_name='home', renderer='../templates/home.pt')
|
||||||
def home(request):
|
def home(request):
|
||||||
|
|
||||||
|
logged_in = request.authenticated_userid
|
||||||
member = get_member_by_email(request, 'ctphuoc@gmail.com')
|
member = get_member_by_email(request, 'ctphuoc@gmail.com')
|
||||||
id_photo = member.photo_instagram
|
id_photo = member.photo_instagram
|
||||||
|
|
||||||
# lire toutes les docs
|
# lire toutes les docs
|
||||||
items = get_docs_bytheme(request, 'BLOG')
|
items = get_docs_bytheme(request, 'BLOG', logged_in)
|
||||||
|
|
||||||
return {
|
return {
|
||||||
'page_title': "Un geek à la retraite",
|
'page_title': "Méditer, c’est ouvrir la cage",
|
||||||
'items': items,
|
'items': items,
|
||||||
'id_photo': id_photo,
|
'id_photo': id_photo,
|
||||||
}
|
}
|
||||||
|
|
||||||
@view_config(route_name='archives', renderer='../templates/archives.pt')
|
|
||||||
def archives(request):
|
|
||||||
theme = 'blog'
|
|
||||||
|
|
||||||
if 'theme' in request.params:
|
|
||||||
theme = request.params["theme"]
|
|
||||||
|
|
||||||
# lire la table des themes
|
|
||||||
themes = get_docs_themes(request)
|
|
||||||
|
|
||||||
# lire toutes les docs du theme
|
|
||||||
docs = get_docs_bytheme(request, theme)
|
|
||||||
|
|
||||||
return {
|
|
||||||
'page_title': "Archives de %s" % theme,
|
|
||||||
'docs': docs,
|
|
||||||
'themes': themes,
|
|
||||||
'theme': theme,
|
|
||||||
}
|
|
||||||
|
|
||||||
@view_config(route_name='doc_edit', renderer='../templates/doc_edit.pt', permission='view')
|
|
||||||
def doc_edit(request):
|
|
||||||
doc_id = request.matchdict['doc_id']
|
|
||||||
url = request.route_url('doc_edit',doc_id=doc_id)
|
|
||||||
|
|
||||||
message = ""
|
|
||||||
themes = get_docs_themes(request)
|
|
||||||
tags = get_docs_tags(request)
|
|
||||||
|
|
||||||
if doc_id == '0':
|
|
||||||
titre = "Nouveau doc"
|
|
||||||
# nouveau
|
|
||||||
doc = {}
|
|
||||||
doc['intitule'] = ''
|
|
||||||
doc['texte'] = ''
|
|
||||||
doc['theme'] = ''
|
|
||||||
doc['tag1'] = ''
|
|
||||||
doc['tag2'] = ''
|
|
||||||
else:
|
|
||||||
titre = "Modifier : %s" % str(doc_id)
|
|
||||||
doc = get_docs(request, doc_id)
|
|
||||||
|
|
||||||
if 'form.submitted' in request.params:
|
|
||||||
new_values = {}
|
|
||||||
for param, db_value in doc.items():
|
|
||||||
if param in request.params and request.params[param] != db_value:
|
|
||||||
new_values[param] = request.params[param]
|
|
||||||
|
|
||||||
if new_values:
|
|
||||||
update_doc(request, doc_id, new_values)
|
|
||||||
if doc_id != '0':
|
|
||||||
return HTTPFound(location=request.route_url('doc_view', doc_id=doc_id))
|
|
||||||
else:
|
|
||||||
return HTTPFound(location=request.route_url('archives',theme=request.params['theme']))
|
|
||||||
|
|
||||||
if 'form.deleted' in request.params:
|
|
||||||
if doc_id != '0':
|
|
||||||
delete_doc(request, doc_id)
|
|
||||||
request.session.flash(u"<%s> est supprimée avec succès." % doc.intitule, 'success')
|
|
||||||
return HTTPFound(location=request.route_url('archives',theme=doc.theme))
|
|
||||||
|
|
||||||
return {
|
|
||||||
'page_title': titre,
|
|
||||||
'url': url,
|
|
||||||
'message': message,
|
|
||||||
'doc_id': doc_id,
|
|
||||||
'doc': doc,
|
|
||||||
'themes': themes,
|
|
||||||
'tags': tags,
|
|
||||||
}
|
|
||||||
|
|
||||||
@view_config(route_name='doc_search', renderer='../templates/doc_search.pt')
|
|
||||||
def doc_search(request):
|
|
||||||
|
|
||||||
logged_in = request.authenticated_userid
|
|
||||||
critere = ''
|
|
||||||
docs = []
|
|
||||||
|
|
||||||
if 'form.submitted' in request.params:
|
|
||||||
critere = request.params['critere']
|
|
||||||
# si afficher tous les fiches ?
|
|
||||||
docs = get_docs_bycritere(request, critere, logged_in)
|
|
||||||
|
|
||||||
return {
|
|
||||||
'page_title': "Rechercher",
|
|
||||||
'docs': docs,
|
|
||||||
'critere': critere,
|
|
||||||
}
|
|
||||||
|
|
||||||
@view_config(route_name='apropos', renderer='../templates/apropos.pt')
|
@view_config(route_name='apropos', renderer='../templates/apropos.pt')
|
||||||
def apropos(request):
|
def apropos(request):
|
||||||
@@ -177,40 +90,6 @@ def apropos(request):
|
|||||||
'page_title': "A propos",
|
'page_title': "A propos",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@view_config(route_name='doc_view', renderer='../templates/doc_view.pt')
|
|
||||||
def doc_view(request):
|
|
||||||
|
|
||||||
logged_in = request.authenticated_userid
|
|
||||||
doc_id = request.matchdict['doc_id']
|
|
||||||
|
|
||||||
doc = get_docs(request, doc_id)
|
|
||||||
if logged_in == None and doc.theme == 'memo':
|
|
||||||
# si anonyme, interdire de voir les memo
|
|
||||||
return HTTPFound(location=request.route_url('home'))
|
|
||||||
|
|
||||||
url_retour = request.route_url('archives',theme=doc.theme)
|
|
||||||
tags = doc.tag1
|
|
||||||
if doc.tag2:
|
|
||||||
tags += ', ' + doc.tag2
|
|
||||||
|
|
||||||
# insèrer le path de static/img
|
|
||||||
texte = doc.texte.replace('static/img/', "%s/static/img/" % request.application_url)
|
|
||||||
|
|
||||||
# convertir mardown en HTML
|
|
||||||
from markdown2 import Markdown
|
|
||||||
markdowner = Markdown()
|
|
||||||
texte = markdowner.convert(texte)
|
|
||||||
|
|
||||||
return {
|
|
||||||
'page_title': doc.intitule,
|
|
||||||
'doc_id': doc_id,
|
|
||||||
'texte': texte,
|
|
||||||
'modif_le': doc.modif_le.strftime('%d/%m/%Y'),
|
|
||||||
'tags': tags,
|
|
||||||
'url_retour':url_retour
|
|
||||||
}
|
|
||||||
|
|
||||||
def envoyerMail(request, destinataire, objet, corps):
|
def envoyerMail(request, destinataire, objet, corps):
|
||||||
body = """
|
body = """
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user