You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			125 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			HTML
		
	
			
		
		
	
	
			125 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			HTML
		
	
| {% extends "main.html" %}
 | |
| {%load static%}
 | |
| {% block content %}
 | |
| 
 | |
| <!-- IN THIS TASK FORM THE TASK BELONG ONLY TO A PROJECT AND THE USER MUST CHOOSE TO WHICH EPIC IT BELONGS -->
 | |
| 
 | |
| <div class="w-full px-10 mb-4">
 | |
|     <div class="w-full h-full shadow-md rounded-md mt-5 py-5 px-3 bg-white">
 | |
|         <h1 class="text-3xl text-slate-800 text-center font-semibold">
 | |
|             Create Task For {{project.name}}
 | |
|         </h1>
 | |
| 
 | |
|         <form class="w-full flex flex-col gap-3 justify-center items-center mt-5" method="POST"
 | |
|             action="{% url 'save_task' %}">
 | |
|             {% csrf_token %}
 | |
|             <input required name="name" type="text" placeholder="Task Name"
 | |
|                 class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md">
 | |
| 
 | |
|             <select required name="project" id=""
 | |
|                 class="hidden w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500">
 | |
| 
 | |
|                 <option value="{{project.id}}">{{project.name}}</option>
 | |
| 
 | |
|             </select>
 | |
| 
 | |
|             <select required name="epic" id=""
 | |
|                 class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500">
 | |
|                 <option value="" selected disabled>Select Epic</option>
 | |
|                 {% for epic in epics_of_my_project %}
 | |
|                 <option value="{{epic.id}}">{{epic.title}}</option>
 | |
|                 {% endfor %}
 | |
|             </select>
 | |
| 
 | |
|             <select required name="status" id=""
 | |
|                 class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500">
 | |
|                 <option value="" selected disabled>Status</option>
 | |
|                 <option value="Open">Open</option>
 | |
|                 <option value="Working On">Working On</option>
 | |
|                 <option value="Closed">Closed</option>
 | |
|             </select>
 | |
| 
 | |
|             <select name="assigned_to" required id=""
 | |
|                 class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500">
 | |
|                 <option value="" selected disabled>Assigned To</option>
 | |
|                 {% for staff in staffs %}
 | |
|                 <option value="{{staff.id}}">{{staff.user.first_name}} {{staff.user.last_name}}</option>
 | |
|                 {% endfor %}
 | |
|             </select>
 | |
| 
 | |
|             <textarea required name="description" type="text" placeholder="Task Description" rows="5" cols="5"
 | |
|                 class="w-full py-3 px-3 border border-gray-300 outline-none rounded-md resize-none"></textarea>
 | |
| 
 | |
|             <div class="w-full">
 | |
|                 <label class="text-gray-500">Extra:</label>
 | |
|                 <select required name="extra" id=""
 | |
|                     class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500 mt-1">
 | |
|                     <option value="True">Yes</option>
 | |
|                     <option value="False" selected>No</option>
 | |
|                 </select>
 | |
|             </div>
 | |
| 
 | |
|             <div class="w-full">
 | |
|                 <label class="text-gray-500">Start Date:</label>
 | |
|                 <input required name="start_date" type="date" id="date" name="date"
 | |
|                     class="w-full p-3 border border-gray-300 rounded-md bg-transparent outline-none mt-1">
 | |
|             </div>
 | |
| 
 | |
|             <div class="w-full">
 | |
|                 <label class="text-gray-500">End Date:</label>
 | |
|                 <input required name="end_date" type="date" id="date" name="date"
 | |
|                     class="w-full p-3 border border-gray-300 rounded-md bg-transparent outline-none mt-1">
 | |
|             </div>
 | |
| 
 | |
|             <div class="inbox-box border border-gray-300 py-1 px-3 w-full rounded-md">
 | |
|                 <div class="flex items-center justify-between">
 | |
|                     <input name="cv" type="file" id="actual-btn" accept=".pdf,.docx" hidden multiple />
 | |
|                     <span id="file-name" class="text-gray-500 text-base focus:outline-none outline-none">Upload
 | |
|                         Document(s)</span>
 | |
|                     <label for="actual-btn"
 | |
|                         class="bg-transparent text-gray-500 border border-white py-2 h-14 cursor-pointer flex items-center"><i
 | |
|                             class="fa fa-upload"></i></label>
 | |
| 
 | |
|                 </div>
 | |
|             </div>
 | |
| 
 | |
|             <!-- WHEN THE USER CHOOSE A FILE THE NAME OF THE FILE WILL APPEAR IN THE SPAN -->
 | |
|             <script>
 | |
|                 const fileInput = document.getElementById('actual-btn');
 | |
|                 const fileNameSpan = document.getElementById('file-name');
 | |
| 
 | |
|                 fileInput.addEventListener('change', (event) => {
 | |
|                     const selectedFiles = event.target.files;
 | |
|                     if (selectedFiles.length > 0) {
 | |
|                         const fileNames = Array.from(selectedFiles).map(file => file.name).join(', ');
 | |
|                         fileNameSpan.textContent = fileNames;
 | |
|                     } else {
 | |
|                         fileNameSpan.textContent = 'Upload Documents (PDF, docx)';
 | |
|                     }
 | |
|                 });
 | |
|             </script>
 | |
| 
 | |
|             <div class="w-full flex justify-center items-center mt-3">
 | |
|                 <button type="submit"
 | |
|                     class="w-fit py-1 px-3 bg-blue-500 rounded-md outline-none text-white border border-blue-500 text-xl cursor-pointer hover:bg-white hover:text-blue-500">Add
 | |
|                     Task</button>
 | |
|             </div>
 | |
|         </form>
 | |
|     </div>
 | |
| </div>
 | |
| </div>
 | |
| <!-- POPUP MODAL -->
 | |
| <div class="w-full h-full bg-black bg-opacity-40 z-20 fixed justify-center items-center hidden" id="popUpModal">
 | |
|     <div class="w-[95%] md:w-fit h-fit bg-white rounded-md p-9 relative">
 | |
|         <button class="absolute top-3 right-5 text-slate-800 text-xl cursor-pointer outline-none border-none"
 | |
|             id="closeModalButton">
 | |
|             <i class="fa fa-close"></i>
 | |
|         </button>
 | |
|         <iframe id="popupModalFrame" frameborder="0"></iframe>
 | |
|     </div>
 | |
| </div>
 | |
| 
 | |
| <script type="text/javascript" src='{% static "js/pop-modals.js" %}'></script>
 | |
| </div>
 | |
| 
 | |
| {% endblock content %} |