mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-10-31 23:54:30 +01:00 
			
		
		
		
	Compare commits
	
		
			15 Commits
		
	
	
		
			non-BDE-me
			...
			78838b404c
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 78838b404c | ||
|  | 7975fe47a6 | ||
|  | 476fbceeea | ||
|  | 8fbaa0bdc8 | ||
|  | a0de63effd | ||
|  | 09fb1d227e | ||
|  | 2e27d4f05c | ||
|  | 3c34033bf5 | ||
|  | e6f3084588 | ||
|  | 145e55da75 | ||
|  | d3ba95cdca | ||
|  | 8ffb0ebb56 | ||
|  | 5038af9e34 | ||
|  | 819b4214c9 | ||
|  | b8a93b0b75 | 
| @@ -38,6 +38,7 @@ SPDX-License-Identifier: GPL-3.0-or-later | ||||
| </a> | ||||
|  | ||||
| <input id="alias" type="text" class="form-control" placeholder="Nom/note ..."> | ||||
| <button id="trigger" class="btn btn-secondary">Click me !</button> | ||||
|  | ||||
| <hr> | ||||
|  | ||||
| @@ -63,15 +64,46 @@ SPDX-License-Identifier: GPL-3.0-or-later | ||||
|         refreshBalance(); | ||||
|     } | ||||
|  | ||||
|     function process_qrcode() { | ||||
|         let name = alias_obj.val(); | ||||
|         $.get("/api/note/note?search=" + name + "&format=json").done( | ||||
|             function (res) { | ||||
|                 let note = res.results[0]; | ||||
|                 $.post("/api/activity/entry/?format=json", { | ||||
|                     csrfmiddlewaretoken: CSRF_TOKEN, | ||||
|                     activity: {{ activity.id }}, | ||||
|                     note: note.id, | ||||
|                     guest: null | ||||
|                 }).done(function () { | ||||
|                     addMsg(interpolate(gettext( | ||||
|                         "Entry made for %s whose balance is %s €"), | ||||
|                         [note.name, note.balance / 100]), "success", 4000); | ||||
|                     reloadTable(true); | ||||
|                 }).fail(function (xhr) { | ||||
|                     errMsg(xhr.responseJSON, 4000); | ||||
|                 }); | ||||
|             }).fail(function (xhr) { | ||||
|                 errMsg(xhr.responseJSON, 4000); | ||||
|             }); | ||||
|     } | ||||
|  | ||||
|     alias_obj.keyup(function(event) { | ||||
|         let code = event.originalEvent.keyCode | ||||
|         if (65 <= code <= 122 || code === 13) { | ||||
|             debounce(reloadTable)() | ||||
|         } | ||||
|         if (code === 0) | ||||
|             process_qrcode(); | ||||
|     }); | ||||
|  | ||||
|     $(document).ready(init); | ||||
|  | ||||
|     alias_obj2 = document.getElementById("alias"); | ||||
|     $("#trigger").click(function (e) { | ||||
|         addMsg("Clicked", "success", 1000); | ||||
|         alias_obj.val(alias_obj.val() + "\0"); | ||||
|         alias_obj2.dispatchEvent(new KeyboardEvent('keyup')); | ||||
|     }) | ||||
|     function init() { | ||||
|         $(".table-row").click(function (e) { | ||||
|             let target = e.target.parentElement; | ||||
| @@ -168,4 +200,4 @@ SPDX-License-Identifier: GPL-3.0-or-later | ||||
|         }); | ||||
|     } | ||||
| </script> | ||||
| {% endblock %} | ||||
| {% endblock %} | ||||
|   | ||||
| @@ -60,7 +60,10 @@ | ||||
| {% if user_object.pk == user.pk %} | ||||
|     <div class="text-center"> | ||||
|         <a class="small badge badge-secondary" href="{% url 'member:auth_token' %}"> | ||||
|             <i class="fa fa-cogs"></i>{% trans 'API token' %} | ||||
|             <i class="fa fa-cogs"></i> {% trans 'API token' %} | ||||
|         </a> | ||||
|         <a class="small badge badge-secondary" href="{% url 'member:qr_code' user_object.pk %}"> | ||||
|             <i class="fa fa-qrcode"></i> {% trans 'QR Code' %} | ||||
|         </a> | ||||
|     </div> | ||||
| {% endif %} | ||||
|   | ||||
							
								
								
									
										36
									
								
								apps/member/templates/member/qr_code.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								apps/member/templates/member/qr_code.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | ||||
| {% extends "base.html" %} | ||||
| {% comment %} | ||||
| SPDX-License-Identifier: GPL-3.0-or-later | ||||
| {% endcomment %} | ||||
| {% load i18n %} | ||||
|  | ||||
| {% block content %} | ||||
| <div class="card bg-light"> | ||||
|   	<h3 class="card-header text-center"> | ||||
| 		{% trans "QR Code for" %} {{ user_object.username }} ({{ user_object.first_name }} {{user_object.last_name }}) | ||||
|   	</h3> | ||||
|   	<div class="text-center" id="qrcode"> | ||||
|   	</div> | ||||
| </div> | ||||
|  | ||||
|  | ||||
| {% endblock %} | ||||
|  | ||||
| {% block extrajavascript %} | ||||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/qrcodejs/1.0.0/qrcode.min.js" integrity="sha512-CNgIRecGo7nphbeZ04Sc13ka07paqdeTu0WR1IM4kNcpmBAUSHSQX0FslNhTDadL4O5SAGapGt4FodqL8My0mA==" crossorigin="anonymous" referrerpolicy="no-referrer"></script> | ||||
| <script> | ||||
| 	var qrc = new QRCode(document.getElementById("qrcode"), { | ||||
| 		text: "{{ user_object.pk }}\0", | ||||
| 		width: 1024, | ||||
| 		height: 1024 | ||||
| 	}); | ||||
| </script> | ||||
| {% endblock %} | ||||
|  | ||||
| {% block extracss %} | ||||
| <style> | ||||
| img { | ||||
|     width: 100% | ||||
| } | ||||
| </style> | ||||
| {% endblock %} | ||||
| @@ -25,4 +25,5 @@ urlpatterns = [ | ||||
|     path('user/<int:pk>/aliases/', views.ProfileAliasView.as_view(), name="user_alias"), | ||||
|     path('user/<int:pk>/trust', views.ProfileTrustView.as_view(), name="user_trust"), | ||||
|     path('manage-auth-token/', views.ManageAuthTokens.as_view(), name='auth_token'), | ||||
|     path('user/<int:pk>/qr_code/', views.QRCodeView.as_view(), name='qr_code'), | ||||
| ] | ||||
|   | ||||
| @@ -388,6 +388,14 @@ class ManageAuthTokens(LoginRequiredMixin, TemplateView): | ||||
|         context['token'] = Token.objects.get_or_create(user=self.request.user)[0] | ||||
|         return context | ||||
|  | ||||
| class QRCodeView(LoginRequiredMixin, DetailView): | ||||
|     """ | ||||
|     Affiche le QR Code | ||||
|     """ | ||||
|     model = User | ||||
|     context_object_name = "user_object" | ||||
|     template_name = "member/qr_code.html" | ||||
|     extra_context = {"title": _("QR Code")} | ||||
|  | ||||
| # ******************************* # | ||||
| #              CLUB               # | ||||
|   | ||||
| @@ -279,7 +279,6 @@ class WEISurveyAlgorithm2024(WEISurveyAlgorithm): | ||||
|         # surveys = [s for s in surveys if s.bus_id != None] | ||||
|         # surveys = [s for s in surveys if not hasattr(s.information, 'hardcoded') or not s.information.hardcoded] | ||||
|  | ||||
|  | ||||
|         # surveys = [s for s in surveys if s.registration.user_id in free_users] | ||||
|  | ||||
|         # hardcoded_first_year_mb = WEIMembership.objects.filter(bus != None,registration__first_year=True) | ||||
| @@ -288,15 +287,13 @@ class WEISurveyAlgorithm2024(WEISurveyAlgorithm): | ||||
|         hardcoded_first_year_mb = WEIMembership.objects.filter(registration__first_year=True) | ||||
|         hardcoded_first_year = {mb.user.id if mb.bus else None: mb.bus.id if mb.bus else None for mb in hardcoded_first_year_mb} | ||||
|  | ||||
|  | ||||
|         # Reset previous algorithm run | ||||
|         for survey in surveys: | ||||
|             survey.free() | ||||
|             if survey.registration.user_id in hardcoded_first_year.keys(): | ||||
|                 survey.select_bus(hardcoded_first_year[s.registration.user_id]) | ||||
|                 survey.select_bus(hardcoded_first_year[survey.registration.user_id]) | ||||
|             survey.save() | ||||
|  | ||||
|  | ||||
|         non_men = [s for s in surveys if s.registration.gender != 'male'] | ||||
|         men = [s for s in surveys if s.registration.gender == 'male'] | ||||
|  | ||||
|   | ||||
| @@ -1032,6 +1032,7 @@ msgid "" | ||||
| "Register on the mailing list to stay informed of the sport events of the " | ||||
| "campus (1 mail/week)" | ||||
| msgstr "" | ||||
| "S'inscrire sur la liste de diffusion pour rester informé·e des actualités " | ||||
| "sportives sur le campus (1 mail par semaine)" | ||||
|  | ||||
| #: apps/member/models.py:113 | ||||
|   | ||||
| @@ -158,7 +158,12 @@ SPDX-License-Identifier: GPL-3.0-or-later | ||||
|         </div> | ||||
|     </nav> | ||||
|     <div class="{% block containertype %}container{% endblock %} my-3"> | ||||
|         <div id="messages"> | ||||
| 	<div id="messages"> | ||||
| 	    {% if user.is_authenticated %} | ||||
| 		<div class="alert alert-info"> | ||||
| 		    Venez au festival des Sens de l'Art du 2 au 7 décembre 🐘 ! | ||||
| 		</div> | ||||
| 	    {% endif %} | ||||
|             {% if user.is_authenticated %} | ||||
|                 {% if not user|is_member:"BDE" %} | ||||
|                     <div class="alert alert-danger"> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user