ajout recherche.pt
This commit is contained in:
@@ -36,11 +36,16 @@ def get_docs_bytheme(request, theme):
|
|||||||
results = request.dbsession.execute(query, {'theme': theme}).fetchall()
|
results = request.dbsession.execute(query, {'theme': theme}).fetchall()
|
||||||
return results
|
return results
|
||||||
|
|
||||||
def get_blog_themes(request):
|
def get_docs_themes(request):
|
||||||
query = "SELECT * FROM blog_themes;"
|
query = "SELECT * FROM docs_themes;"
|
||||||
results = request.dbsession.execute(query).fetchall()
|
results = request.dbsession.execute(query).fetchall()
|
||||||
return results
|
return results
|
||||||
|
|
||||||
|
def get_docs_bycritere(request, critere):
|
||||||
|
query = "SELECT * FROM docs WHERE texte like :critere;"
|
||||||
|
results = request.dbsession.execute(query, {'critere': '%' + critere + '%'}).fetchall()
|
||||||
|
return results
|
||||||
|
|
||||||
def update_doc(request, doc_id, intitule, texte, theme):
|
def update_doc(request, doc_id, intitule, texte, theme):
|
||||||
"""créér ou modifier le doc"""
|
"""créér ou modifier le doc"""
|
||||||
if doc_id == '0':
|
if doc_id == '0':
|
||||||
@@ -53,5 +58,5 @@ def update_doc(request, doc_id, intitule, texte, theme):
|
|||||||
def delete_doc(request, doc_id):
|
def delete_doc(request, doc_id):
|
||||||
"""supprimer la doc"""
|
"""supprimer la doc"""
|
||||||
query = "delete from docs where doc_id = :doc_id;"
|
query = "delete from docs where doc_id = :doc_id;"
|
||||||
results = request.dbsession.execute(query, {'doc_id': doc_id})
|
execute_query(request, query, {'doc_id': doc_id})
|
||||||
|
|
||||||
|
|||||||
@@ -1,10 +1,11 @@
|
|||||||
def includeme(config):
|
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('archives', '/archives/{theme}')
|
config.add_route('archives', '/archives/{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('memo_view', '/memo_view/{doc_id}')
|
config.add_route('doc_search', '/doc_search')
|
||||||
# actifs
|
# actifs
|
||||||
config.add_route('actif_edit', '/actif_edit/{no_id}')
|
config.add_route('actif_edit', '/actif_edit/{no_id}')
|
||||||
config.add_route('actif2_edit', '/actif2_edit/{no_id}')
|
config.add_route('actif2_edit', '/actif2_edit/{no_id}')
|
||||||
|
|||||||
@@ -55,6 +55,10 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.container h2{
|
||||||
|
color: crimson !important;
|
||||||
|
}
|
||||||
|
|
||||||
.container-fluid {
|
.container-fluid {
|
||||||
padding-top: 2em;
|
padding-top: 2em;
|
||||||
padding-bottom: 1em;
|
padding-bottom: 1em;
|
||||||
|
|||||||
Binary file not shown.
|
Before Width: | Height: | Size: 3.6 KiB After Width: | Height: | Size: 3.5 KiB |
34
caotek_mesavoirs/templates/apropos.pt
Normal file
34
caotek_mesavoirs/templates/apropos.pt
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
<metal:block use-macro="main_template">
|
||||||
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
|
<br />
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-6">
|
||||||
|
<div class="panel panel-default text-center">
|
||||||
|
<div class="panel-body">
|
||||||
|
<blockquote>
|
||||||
|
L'argent qu'on possède est l'instrument de la liberté; celui qu'on pourchasse est celui de la servitude.
|
||||||
|
</blockquote>
|
||||||
|
</div>
|
||||||
|
<div class="panel-footer">
|
||||||
|
<h4>Rousseau</h4>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-5">
|
||||||
|
<div class="panel panel-default text-center">
|
||||||
|
<div class="panel-body">
|
||||||
|
<blockquote>
|
||||||
|
L'intelligence ce n'est pas ce que l'on sait mais ce que l'on fait quand on ne sait pas.
|
||||||
|
<br />
|
||||||
|
</blockquote>
|
||||||
|
</div>
|
||||||
|
<div class="panel-footer">
|
||||||
|
<h4>Jean Piaget</h4>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</metal:block>
|
||||||
@@ -2,6 +2,9 @@
|
|||||||
<div metal:fill-slot="content">
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
|
<p tal:condition="not layout.isAnonymous()">
|
||||||
|
<a href="${request.application_url}/doc_edit/0">Créer un nouveau post</a>
|
||||||
|
</p>
|
||||||
<table class="table">
|
<table class="table">
|
||||||
<tr tal:repeat="ligne docs">
|
<tr tal:repeat="ligne docs">
|
||||||
<td><a href="/doc_view/${ligne.doc_id}"><b>${ligne.intitule}</b></a></td>
|
<td><a href="/doc_view/${ligne.doc_id}"><b>${ligne.intitule}</b></a></td>
|
||||||
|
|||||||
@@ -37,16 +37,12 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<div class="col-sm-offset-2 col-sm-8">
|
<div class="col-sm-offset-2 col-sm-10">
|
||||||
<button class="btn btn-primary" type="submit" name="form.submitted">
|
|
||||||
<span class="glyphicon glyphicon-ok"></span> Enregistrer</button>
|
|
||||||
<a href="${request.application_url}/doc_view/${doc_id}" class="btn btn-default" role="button">
|
<a href="${request.application_url}/doc_view/${doc_id}" class="btn btn-default" role="button">
|
||||||
<span class="glyphicon glyphicon-chevron-left"></span> Annuler</a>
|
<span class="glyphicon glyphicon-chevron-left"></span> Annuler</a>
|
||||||
</div>
|
<button class="btn btn-primary" type="submit" name="form.submitted">
|
||||||
</div>
|
<span class="glyphicon glyphicon-ok"></span> Enregistrer</button>
|
||||||
<div class="form-group" tal:condition="doc_id != '0'">
|
<button class="btn btn-warning" type="submit" name="form.deleted" tal:condition="doc_id != '0'">
|
||||||
<div class="col-sm-offset-2 col-sm-8">
|
|
||||||
<button class="btn btn-warning" type="submit" name="form.deleted">
|
|
||||||
<span class="glyphicon glyphicon-remove"></span> Supprimer</button>
|
<span class="glyphicon glyphicon-remove"></span> Supprimer</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
77
caotek_mesavoirs/templates/doc_search.pt
Normal file
77
caotek_mesavoirs/templates/doc_search.pt
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
<metal:block use-macro="main_template">
|
||||||
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<form id="search-form" class="form-horizontal" role="form" action="/doc_search" method="post">
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="col-sm-offset-2 col-sm-8">
|
||||||
|
<div class="input-group" align="center">
|
||||||
|
<input type="text" class="form-control" name="critere" value="${critere}" />
|
||||||
|
<span class="input-group-btn">
|
||||||
|
<button id="submitButton" class="btn btn-primary" type="submit" name="form.submitted">
|
||||||
|
Rechercher
|
||||||
|
</button>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div><!-- row -->
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div tal:condition="docs">
|
||||||
|
<table class="table table-striped table-bordered">
|
||||||
|
<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>
|
||||||
|
<div tal:condition="not docs">
|
||||||
|
<p class="text-danger text-center">Aucun document ne correspond à la recherche</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
|
||||||
|
<script>
|
||||||
|
$(document).ready(function() {
|
||||||
|
$('#search-form').formValidation({
|
||||||
|
framework: 'bootstrap',
|
||||||
|
message: 'This value is not valid',
|
||||||
|
icon: {
|
||||||
|
valid: 'glyphicon glyphicon-ok',
|
||||||
|
invalid: 'glyphicon glyphicon-remove',
|
||||||
|
validating: 'glyphicon glyphicon-refresh'
|
||||||
|
},
|
||||||
|
fields: {
|
||||||
|
critere: {
|
||||||
|
validators: {
|
||||||
|
notEmpty: {
|
||||||
|
message: 'Veuillez saisir le texte à rechercher'
|
||||||
|
},
|
||||||
|
stringLength: {
|
||||||
|
min: 3,
|
||||||
|
max: 30,
|
||||||
|
message: 'Le texte doit avoir de 3 à 30 caractères de long'
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$('form input').on('keypress', function(e) {
|
||||||
|
var code = e.keyCode || e.which;
|
||||||
|
if (code === 13) {
|
||||||
|
e.preventDefault();
|
||||||
|
// simuler clic bouton submit
|
||||||
|
document.getElementById("submitButton").click();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</metal:block>
|
||||||
@@ -1,14 +1,16 @@
|
|||||||
<metal:block use-macro="main_template">
|
<metal:block use-macro="main_template">
|
||||||
<div metal:fill-slot="content">
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
<a href="${url_retour}">[ Fermer ]</a>
|
<p>
|
||||||
<a href="${request.application_url}/doc_edit/${doc_id}" tal:condition="not layout.isAnonymous">[ Modifier ]</a>
|
<a href="${url_retour}">[ Fermer ]</a>
|
||||||
<br />
|
<a href="${request.application_url}/doc_edit/${doc_id}" tal:condition="not layout.isAnonymous()">[ Modifier ]</a>
|
||||||
|
</p>
|
||||||
<hr>
|
<hr>
|
||||||
<div tal:replace="structure texte">
|
<div tal:replace="structure texte">
|
||||||
Page text goes here.
|
Page text goes here.
|
||||||
</div>
|
</div>
|
||||||
<hr>
|
<hr>
|
||||||
|
Dernière modification le ${modif_le}
|
||||||
<br />
|
<br />
|
||||||
<br />
|
<br />
|
||||||
|
|
||||||
|
|||||||
@@ -55,7 +55,6 @@
|
|||||||
<div class="collapse navbar-collapse" id="myNavbar">
|
<div class="collapse navbar-collapse" id="myNavbar">
|
||||||
<ul class="nav navbar-nav navbar-right">
|
<ul class="nav navbar-nav navbar-right">
|
||||||
<!-- <li><a href="${request.application_url}/histo_list">HISTORIQUE</a></li> -->
|
<!-- <li><a href="${request.application_url}/histo_list">HISTORIQUE</a></li> -->
|
||||||
<li tal:condition="layout.isAnonymous()"><a href="${request.application_url}/login">se connecter</a></li>
|
|
||||||
${panel('dropdown_menu_panel')}
|
${panel('dropdown_menu_panel')}
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
@@ -89,21 +88,16 @@
|
|||||||
|
|
||||||
<footer class="container-fluid bg-footer">
|
<footer class="container-fluid bg-footer">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-xs-offset-2 col-xs-4">
|
<p class="text-center">
|
||||||
<p>L'argent que l'on possède est l'instrument de la liberté; celui que l'on pourchasse est celui de la servitude - <b>Rousseau</b></p>
|
Apprendre Restructured Text <a href="https://github.com/ralsina/rst-cheatsheet/blob/master/rst-cheatsheet.rst" target="_blank">(reST)</a><br />
|
||||||
<p>L'intelligence ce n'est pas ce que l'on sait mais ce que l'on fait quand on ne sait pas - <b>Jean Piaget</b></p>
|
Apprendre Markdown <a href="https://www.markdownguide.org/basic-syntax/" target="_blank">(md)</a><br />
|
||||||
</div>
|
|
||||||
<div class="col-xs-offset-2 col-xs-4">
|
|
||||||
<p>
|
|
||||||
Apprendre Restructured Text <a href="https://github.com/ralsina/rst-cheatsheet/blob/master/rst-cheatsheet.rst">(reST)</a><br />
|
|
||||||
Apprendre Markdown <a href="https://www.markdownguide.org/basic-syntax/">(md)</a><br />
|
|
||||||
<a href="http://www.marinestylefitness.com/">Marine Style Fitness </a><br />
|
|
||||||
</p>
|
</p>
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<br />
|
<br />
|
||||||
<div class="row">
|
<p class="text-center">© 2017 - Phuoc Cao |
|
||||||
<p class="text-center">© 2017 - www.caotek.fr - Powered by <a href="https://trypyramid.com/">Pyramid</a></p>
|
<a href="${request.application_url}/apropos">A propos</a> |
|
||||||
|
<a href="${request.application_url}/doc_search">recherche</a> |
|
||||||
|
<a href="${request.application_url}/login" tal:condition="layout.isAnonymous()">se connecter</a> |
|
||||||
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</footer>
|
</footer>
|
||||||
|
|
||||||
|
|||||||
@@ -102,7 +102,7 @@ def doc_edit(request):
|
|||||||
url = request.route_url('doc_edit',doc_id=doc_id)
|
url = request.route_url('doc_edit',doc_id=doc_id)
|
||||||
|
|
||||||
message = ""
|
message = ""
|
||||||
themes = get_blog_themes(request)
|
themes = get_docs_themes(request)
|
||||||
|
|
||||||
if doc_id == '0':
|
if doc_id == '0':
|
||||||
titre = "Nouveau doc"
|
titre = "Nouveau doc"
|
||||||
@@ -126,15 +126,15 @@ def doc_edit(request):
|
|||||||
if doc_id != '0':
|
if doc_id != '0':
|
||||||
return HTTPFound(location=request.route_url('doc_view', doc_id=doc_id))
|
return HTTPFound(location=request.route_url('doc_view', doc_id=doc_id))
|
||||||
else:
|
else:
|
||||||
return HTTPFound(location=request.route_url('doc_list'))
|
return HTTPFound(location=request.route_url('archives',theme=doc.theme))
|
||||||
else:
|
else:
|
||||||
message = "Veuillez saisir un intitule et un texte."
|
message = "Veuillez saisir un intitule et un texte."
|
||||||
|
|
||||||
if 'form.deleted' in request.params:
|
if 'form.deleted' in request.params:
|
||||||
if doc_id != '0':
|
if doc_id != '0':
|
||||||
delete_doc(request, doc_id)
|
delete_doc(request, doc_id)
|
||||||
request.session.flash(u"<%s> est supprimée avec succès." % intitule, 'success')
|
request.session.flash(u"<%s> est supprimée avec succès." % doc.intitule, 'success')
|
||||||
return HTTPFound(location=request.route_url('doc_list'))
|
return HTTPFound(location=request.route_url('archives',theme=doc.theme))
|
||||||
|
|
||||||
return {
|
return {
|
||||||
'page_title': titre,
|
'page_title': titre,
|
||||||
@@ -147,24 +147,61 @@ def doc_edit(request):
|
|||||||
'themes': themes,
|
'themes': themes,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@view_config(route_name='doc_search', renderer='../templates/doc_search.pt')
|
||||||
|
def doc_search(request):
|
||||||
|
|
||||||
|
critere = ''
|
||||||
|
docs = []
|
||||||
|
|
||||||
|
if 'form.submitted' in request.params:
|
||||||
|
critere = request.params['critere']
|
||||||
|
# si afficher tous les fiches ?
|
||||||
|
docs = get_docs_bycritere(request, critere)
|
||||||
|
|
||||||
|
return {
|
||||||
|
'page_title': "Rechercher",
|
||||||
|
'docs': docs,
|
||||||
|
'critere': critere,
|
||||||
|
}
|
||||||
|
|
||||||
|
@view_config(route_name='apropos', renderer='../templates/apropos.pt')
|
||||||
|
def apropos(request):
|
||||||
|
|
||||||
|
|
||||||
|
return {
|
||||||
|
'page_title': "A propos",
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@view_config(route_name='doc_view', renderer='../templates/doc_view.pt')
|
@view_config(route_name='doc_view', renderer='../templates/doc_view.pt')
|
||||||
@view_config(route_name='memo_view', renderer='../templates/doc_view.pt', permission='view')
|
|
||||||
def doc_view(request):
|
def doc_view(request):
|
||||||
|
|
||||||
|
logged_in = request.authenticated_userid
|
||||||
doc_id = request.matchdict['doc_id']
|
doc_id = request.matchdict['doc_id']
|
||||||
|
|
||||||
doc = get_docs(request, 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'))
|
||||||
|
|
||||||
intitule = doc.intitule
|
intitule = doc.intitule
|
||||||
url_retour = request.route_url('archives',theme=doc.theme)
|
url_retour = request.route_url('archives',theme=doc.theme)
|
||||||
|
|
||||||
# insèrer le path de static/img
|
# insèrer le path de static/img
|
||||||
img_path = 'image:: %s/static/img/' % request.application_url
|
texte = doc.texte.replace('static/img/', "%s/static/img/" % request.application_url)
|
||||||
|
|
||||||
texte = doc.texte.replace('image:: static/img/', img_path)
|
|
||||||
# convertir reST en HTML
|
# convertir reST en HTML
|
||||||
texte = publish_parts(texte, writer_name='html')['html_body']
|
# texte = publish_parts(texte, writer_name='html')['html_body']
|
||||||
|
|
||||||
|
# convertir mardown en HTML
|
||||||
|
from markdown2 import Markdown
|
||||||
|
markdowner = Markdown()
|
||||||
|
texte = markdowner.convert(texte)
|
||||||
|
|
||||||
return {
|
return {
|
||||||
'page_title': intitule,
|
'page_title': intitule,
|
||||||
'texte': texte,
|
'texte': texte,
|
||||||
|
'modif_le': doc.modif_le.strftime('%d/%m/%Y'),
|
||||||
'doc_id': doc_id,
|
'doc_id': doc_id,
|
||||||
'url_retour':url_retour
|
'url_retour':url_retour
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user