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.
149 lines
6.9 KiB
HTML
149 lines
6.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-5 s:px-9 mb-5">
|
|
<div class="w-full h-full shadow-md rounded-md py-5 px-3 bg-white">
|
|
<h1 class="text-3xl text-secondosiblue text-center font-semibold">
|
|
Create Task {% if project %} For {{project.name}} {% endif %}
|
|
</h1>
|
|
|
|
<form class="w-full flex flex-col gap-5 justify-center items-center mt-5" method="POST"
|
|
{% if project and not requirement %}
|
|
action="{% url 'addprojecttask' project.project_id %}"
|
|
{% elif project and requirement %}
|
|
action="{% url 'adduserstorytask' project.project_id requirement.id %}"
|
|
{% else %}
|
|
action="{% url 'addtask' %}"
|
|
{% endif %}>
|
|
{% csrf_token %}
|
|
<div class="w-full">
|
|
<label class="text-gray-500">Task Name:</label>
|
|
<input required name="name" type="text"
|
|
class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md mt-1">
|
|
</div>
|
|
|
|
|
|
{% if project %}
|
|
<select required name="project" id=""
|
|
class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500 hidden">
|
|
<option value="{{project.id}}">{{project.name}}</option>
|
|
</select>
|
|
{% else %}
|
|
<div class="w-full">
|
|
<label class="text-gray-500">Project:</label>
|
|
<select required name="epic"
|
|
class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500 mt-1">
|
|
{% for project in projects %}
|
|
<option value="{{project.id}}">{{project.name}}</option>
|
|
{% endfor %}
|
|
</select>
|
|
</div>
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
<div class="w-full">
|
|
<label class="text-gray-500">Epic:</label>
|
|
<select required name="epic"
|
|
class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500 mt-1">
|
|
<option value="" selected disabled>Select Epic</option>
|
|
{% for epic in epics_of_my_project %}
|
|
<option value="{{epic.id}}">{{epic.title}}</option>
|
|
{% endfor %}
|
|
</select>
|
|
</div>
|
|
|
|
<div class="w-full">
|
|
<label class="text-gray-500">Status:</label>
|
|
<select required name="status"
|
|
class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500 mt-1">
|
|
<option value="Open">Open</option>
|
|
<option value="Working On">Working On</option>
|
|
<option value="Closed">Closed</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div class="w-full">
|
|
<label class="text-gray-500">Assigned To:</label>
|
|
<select name="assigned_to" required
|
|
class="w-full h-[50px] py-1 px-3 border border-gray-300 outline-none rounded-md text-gray-500 mt-1">
|
|
<option value="" selected disabled>Select Assigned To</option>
|
|
{% for staff in staffs %}
|
|
<option value="{{staff.id}}">{{staff.user.first_name}} {{staff.user.last_name}}</option>
|
|
{% endfor %}
|
|
</select>
|
|
</div>
|
|
|
|
<div class="w-full">
|
|
<label class="text-gray-500">Task Description:</label>
|
|
<textarea required name="description" type="text" placeholder="Description..." rows="5" cols="5"
|
|
class="w-full py-3 px-3 border border-gray-300 outline-none rounded-md resize-none mt-1"></textarea>
|
|
</div>
|
|
|
|
<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="w-full">
|
|
<label class="text-gray-500">Documents:</label>
|
|
<div class="inbox-box border border-gray-300 w-full rounded-md px-3 mt-1">
|
|
<div class="flex items-center justify-between">
|
|
<input name="" type="file" class="file-input" accept=".pdf,.docx" hidden multiple />
|
|
<span class="file-name text-gray-500 text-base focus:outline-none outline-none">Upload
|
|
Document(s)</span>
|
|
<label
|
|
class="file-label bg-transparent text-gray-500 border border-white h-14 cursor-pointer flex items-center">
|
|
<i class="fa fa-upload" style="font-size: 25px;"></i>
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="w-full flex justify-center items-center mt-3">
|
|
<button type="submit"
|
|
class="w-fit py-1 px-5 bg-osiblue rounded-md outline-none text-white border border-osiblue text-xl cursor-pointer hover:bg-white hover:text-osiblue duration-300">Save</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>
|
|
|
|
<!-------------- JS SCRIPTS --------------->
|
|
<script type="text/javascript" src='{% static "js/upload-input-tag.js" %}'></script>
|
|
|
|
<script type="text/javascript" src='{% static "js/pop-modals.js" %}'></script>
|
|
|
|
</div>
|
|
|
|
{% endblock content %} |