Compare commits
	
		
			4 Commits
		
	
	
		
			1.0.0
			...
			feee9d6dac
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| feee9d6dac | |||
| 9654fb017d | |||
| 1741397ee7 | |||
| da0c8d710b | 
							
								
								
									
										23
									
								
								.drone.yml
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								.drone.yml
									
									
									
									
									
								
							| @ -11,15 +11,30 @@ steps: | |||||||
|     - poetry install |     - poetry install | ||||||
|     - poetry env info |     - poetry env info | ||||||
|     - poetry run pytest |     - poetry run pytest | ||||||
| - name: build container | - name: build container (prod) | ||||||
|   image: plugins/docker |   image: plugins/docker | ||||||
|   settings: |   settings: | ||||||
|     repo: registry.kucharczyk.xyz/timetracker |     repo: registry.kucharczyk.xyz/timetracker | ||||||
|     tags: |     tags: | ||||||
|       - latest |       - latest | ||||||
|  |   when: | ||||||
|  |     branch: | ||||||
|  |       - main | ||||||
|  |  | ||||||
|  | - name: build container (non-prod) | ||||||
|  |   image: plugins/docker | ||||||
|  |   settings: | ||||||
|  |     repo: registry.kucharczyk.xyz/timetracker | ||||||
|  |     tags: | ||||||
|  |       - ${DRONE_COMMIT_REF} | ||||||
|  |       - ${DRONE_COMMIT_BRANCH} | ||||||
|  |   when: | ||||||
|  |     branch: | ||||||
|  |       exclude: | ||||||
|  |         - main | ||||||
|  |      | ||||||
|  |      | ||||||
| trigger: | trigger: | ||||||
|   event: |   event: | ||||||
|   - push |   - push | ||||||
|   - cron |   - cron | ||||||
|   exclude: |  | ||||||
|     - pull_request |  | ||||||
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -5,4 +5,5 @@ __pycache__ | |||||||
| node_modules | node_modules | ||||||
| package-lock.json | package-lock.json | ||||||
| db.sqlite3 | db.sqlite3 | ||||||
| static | static | ||||||
|  | dist/ | ||||||
| @ -1,3 +1,8 @@ | |||||||
|  | ## Unrelease | ||||||
|  |  | ||||||
|  | * Add React | ||||||
|  | * Make it possible to edit sessions (https://git.kucharczyk.xyz/lukas/timetracker/issues/46) | ||||||
|  |  | ||||||
| ## 1.0.0 / 2023-01-20 19:54+01:00 | ## 1.0.0 / 2023-01-20 19:54+01:00 | ||||||
|  |  | ||||||
| * Breaking | * Breaking | ||||||
|  | |||||||
| @ -62,12 +62,14 @@ | |||||||
|                         </button> |                         </button> | ||||||
|                     </a> |                     </a> | ||||||
|                 {% endif %} |                 {% endif %} | ||||||
|                 <button type="button" title="Edit" class="py-1 px-2 flex justify-center items-center  bg-blue-600 hover:bg-blue-700 focus:ring-blue-500 focus:ring-offset-blue-200 text-white transition ease-in duration-200 text-center text-base font-semibold shadow-md focus:outline-none focus:ring-2 focus:ring-offset-2 w-7 h-4 rounded-lg "> |                 <a href="{% url 'edit_session' data.id %}"> | ||||||
|                     <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" class="w-5 h-5"> |                     <button type="button" title="Edit" class="py-1 px-2 flex justify-center items-center  bg-blue-600 hover:bg-blue-700 focus:ring-blue-500 focus:ring-offset-blue-200 text-white transition ease-in duration-200 text-center text-base font-semibold shadow-md focus:outline-none focus:ring-2 focus:ring-offset-2 w-7 h-4 rounded-lg "> | ||||||
|                         <path d="M5.433 13.917l1.262-3.155A4 4 0 017.58 9.42l6.92-6.918a2.121 2.121 0 013 3l-6.92 6.918c-.383.383-.84.685-1.343.886l-3.154 1.262a.5.5 0 01-.65-.65z" /> |                         <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" class="w-5 h-5"> | ||||||
|                         <path d="M3.5 5.75c0-.69.56-1.25 1.25-1.25H10A.75.75 0 0010 3H4.75A2.75 2.75 0 002 5.75v9.5A2.75 2.75 0 004.75 18h9.5A2.75 2.75 0 0017 15.25V10a.75.75 0 00-1.5 0v5.25c0 .69-.56 1.25-1.25 1.25h-9.5c-.69 0-1.25-.56-1.25-1.25v-9.5z" /> |                             <path d="M5.433 13.917l1.262-3.155A4 4 0 017.58 9.42l6.92-6.918a2.121 2.121 0 013 3l-6.92 6.918c-.383.383-.84.685-1.343.886l-3.154 1.262a.5.5 0 01-.65-.65z" /> | ||||||
|                     </svg> |                             <path d="M3.5 5.75c0-.69.56-1.25 1.25-1.25H10A.75.75 0 0010 3H4.75A2.75 2.75 0 002 5.75v9.5A2.75 2.75 0 004.75 18h9.5A2.75 2.75 0 0017 15.25V10a.75.75 0 00-1.5 0v5.25c0 .69-.56 1.25-1.25 1.25h-9.5c-.69 0-1.25-.56-1.25-1.25v-9.5z" /> | ||||||
|                 </button> |                         </svg> | ||||||
|  |                     </button> | ||||||
|  |                 </a> | ||||||
|                 <a href="{% url 'delete_session' data.id %}"> |                 <a href="{% url 'delete_session' data.id %}"> | ||||||
|                     <button type="button" edit="Delete" class="py-1 px-2 flex justify-center items-center  bg-red-600 hover:bg-red-700 focus:ring-red-500 focus:ring-offset-blue-200 text-white transition ease-in duration-200 text-center text-base font-semibold shadow-md focus:outline-none focus:ring-2 focus:ring-offset-2 w-7 h-4 rounded-lg "> |                     <button type="button" edit="Delete" class="py-1 px-2 flex justify-center items-center  bg-red-600 hover:bg-red-700 focus:ring-red-500 focus:ring-offset-blue-200 text-white transition ease-in duration-200 text-center text-base font-semibold shadow-md focus:outline-none focus:ring-2 focus:ring-offset-2 w-7 h-4 rounded-lg "> | ||||||
|                         <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" class="w-5 h-5"> |                         <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" class="w-5 h-5"> | ||||||
|  | |||||||
| @ -23,6 +23,7 @@ urlpatterns = [ | |||||||
|         name="delete_session", |         name="delete_session", | ||||||
|     ), |     ), | ||||||
|     path("add-purchase/", views.add_purchase, name="add_purchase"), |     path("add-purchase/", views.add_purchase, name="add_purchase"), | ||||||
|  |     path("edit-session/<int:session_id>", views.edit_session, name="edit_session"), | ||||||
|     path("list-sessions/", views.list_sessions, name="list_sessions"), |     path("list-sessions/", views.list_sessions, name="list_sessions"), | ||||||
|     path( |     path( | ||||||
|         "list-sessions/by-purchase/<int:purchase_id>", |         "list-sessions/by-purchase/<int:purchase_id>", | ||||||
|  | |||||||
| @ -47,6 +47,18 @@ def update_session(request, session_id=None): | |||||||
|     return redirect("list_sessions") |     return redirect("list_sessions") | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def edit_session(request, session_id=None): | ||||||
|  |     context = {} | ||||||
|  |     session = Session.objects.get(id=session_id) | ||||||
|  |     form = SessionForm(request.POST or None, instance=session) | ||||||
|  |     if form.is_valid(): | ||||||
|  |         form.save() | ||||||
|  |         return redirect("list_sessions") | ||||||
|  |     context["title"] = "Edit Session" | ||||||
|  |     context["form"] = form | ||||||
|  |     return render(request, "add.html", context) | ||||||
|  |  | ||||||
|  |  | ||||||
| def start_session(request, purchase_id=None): | def start_session(request, purchase_id=None): | ||||||
|     session = SessionForm({"purchase": purchase_id, "timestamp_start": now_with_tz()}) |     session = SessionForm({"purchase": purchase_id, "timestamp_start": now_with_tz()}) | ||||||
|     session.save() |     session.save() | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user