blob: 9fe4338477a793b7e867a33d1d9ddb3aa4d5900f [file] [log] [blame]
Kanchan Chauhanb3fe6a42016-03-16 18:01:22 +05301{% extends "templates/web.html" %}
2
Jannat Patel5a425112021-07-01 17:17:34 +05303{% block title %}
4 {{ doc.project_name }}
5{% endblock %}
6
7{% block head_include %}
Suraj Shettyf0e8a512022-07-06 15:10:39 +05308 <link rel="stylesheet" href="/assets/frappe/css/fonts/fontawesome/font-awesome.min.css">
Jannat Patel5a425112021-07-01 17:17:34 +05309{% endblock %}
Kanchan Chauhanb3fe6a42016-03-16 18:01:22 +053010
Kanchan Chauhan239b3512016-05-02 11:43:44 +053011{% block header %}
Saurabh80e45822022-11-21 17:42:53 +053012 <h3 class="my-account-header">{{ doc.project_name }}</h3>
Kanchan Chauhan2ad801c2016-03-22 16:00:41 +053013{% endblock %}
14
Kanchan Chauhanb3fe6a42016-03-16 18:01:22 +053015{% block style %}
Jannat Patel5a425112021-07-01 17:17:34 +053016 <style>
17 {
18 % include "templates/includes/projects.css"%
19 }
20 </style>
Rushabh Mehtab2269dd2016-03-23 18:28:50 +053021{% endblock %}
Kanchan Chauhanb3fe6a42016-03-16 18:01:22 +053022
Kanchan Chauhanb3fe6a42016-03-16 18:01:22 +053023{% block page_content %}
Saurabh80e45822022-11-21 17:42:53 +053024 <div class="web-list-item transaction-list-item">
25 <div class="row align-items-center">
26 <div class="col-sm-4 "><b>Status: {{ doc.status }}</b></div>
27 <div class="col-sm-4 "><b>Progress: {{ doc.percent_complete }}%</b></div>
28 <div class="col-sm-4 "><b>Hours Spent: {{ doc.actual_time | round }}</b></div>
29 </div>
Jannat Patel5a425112021-07-01 17:17:34 +053030 </div>
Rushabh Mehtac20c5362016-03-25 17:19:28 +053031
Jannat Patel5a425112021-07-01 17:17:34 +053032 {{ progress_bar(doc.percent_complete) }}
Kanchan Chauhanb3fe6a42016-03-16 18:01:22 +053033
Saurabh80e45822022-11-21 17:42:53 +053034 <hr>
35
Saurabh80e45822022-11-21 17:42:53 +053036 <div class="row align-items-center">
37 <div class="col-sm-6 my-account-header"> <h4>Tasks</h4></div>
38 <div class="col-sm-6 text-right">
39 <a class="btn btn-secondary btn-light btn-sm" href='/tasks/new?project={{ doc.project_name }}'>{{ _("New task") }}</a>
Jannat Patel5a425112021-07-01 17:17:34 +053040 </div>
Saurabh80e45822022-11-21 17:42:53 +053041 </div>
Saurabh5d9960a2022-11-21 19:37:57 +053042 {% if doc.tasks %}
Saurabh80e45822022-11-21 17:42:53 +053043 <div class="website-list">
44 <div class="result">
45 <div class="web-list-item transaction-list-item">
46 <div class="row align-items-center">
47 <div class="col-sm-4"><b>Tasks</b></div>
48 <div class="col-sm-2"><b>Status</b></div>
49 <div class="col-sm-2"><b>End Date</b></div>
50 <div class="col-sm-2"><b>Assignment</b></div>
51 <div class="col-sm-2"><b>Modified On</b></div>
52 </div>
53 </div>
54 {% include "erpnext/templates/includes/projects/project_tasks.html" %}
55 </div>
56 </div>
Jannat Patel5a425112021-07-01 17:17:34 +053057 {% else %}
Saurabh5d9960a2022-11-21 19:37:57 +053058 {{ empty_state('Task')}}
Jannat Patel5a425112021-07-01 17:17:34 +053059 {% endif %}
Rushabh Mehtab2269dd2016-03-23 18:28:50 +053060
Saurabh80e45822022-11-21 17:42:53 +053061 <h4 class="my-account-header">Timesheets</h4>
Saurabh5d9960a2022-11-21 19:37:57 +053062 {% if doc.timesheets %}
Jannat Patel5a425112021-07-01 17:17:34 +053063 <div class="website-list">
64 <div class="result">
65 <div class="web-list-item transaction-list-item">
Saurabh80e45822022-11-21 17:42:53 +053066 <div class="row align-items-center">
67 <div class="col-xs-2"><b>Timesheet</b></div>
68 <div class="col-xs-2"><b>Status</b></div>
69 <div class="col-xs-2"><b>From</b></div>
70 <div class="col-xs-2"><b>To</b></div>
71 <div class="col-xs-2"><b>Modified By</b></div>
72 <div class="col-xs-2"><b>Modified On</b></div>
Jannat Patel5a425112021-07-01 17:17:34 +053073 </div>
74 </div>
Saurabh80e45822022-11-21 17:42:53 +053075 {% include "erpnext/templates/includes/projects/project_timesheets.html" %}
Jannat Patel5a425112021-07-01 17:17:34 +053076 </div>
77 </div>
78 {% else %}
Saurabh5d9960a2022-11-21 19:37:57 +053079 {{ empty_state('Timesheet')}}
Jannat Patel5a425112021-07-01 17:17:34 +053080 {% endif %}
Rushabh Mehtab2269dd2016-03-23 18:28:50 +053081
Jannat Patel5a425112021-07-01 17:17:34 +053082 {% if doc.attachments %}
83 <div class='padding'></div>
Rushabh Mehtab2269dd2016-03-23 18:28:50 +053084
Jannat Patel5a425112021-07-01 17:17:34 +053085 <h4>{{ _("Attachments") }}</h4>
86 <div class="project-attachments">
87 {% for attachment in doc.attachments %}
88 <div class="attachment">
89 <a class="no-decoration attachment-link" href="{{ attachment.file_url }}" target="blank">
90 <div class="row">
91 <div class="col-xs-9">
92 <span class="indicator red file-name">
93 {{ attachment.file_name }}</span>
94 </div>
95 <div class="col-xs-3">
96 <span class="pull-right file-size">{{ attachment.file_size }}</span>
97 </div>
98 </div>
99 </a>
100 </div>
101 {% endfor %}
102 </div>
103 {% endif %}
JodeQ10dfd4a2018-09-10 13:40:43 +0200104
Kanchan Chauhanb3fe6a42016-03-16 18:01:22 +0530105</div>
106
107<script>
Saurabh80e45822022-11-21 17:42:53 +0530108 { % include "frappe/public/js/frappe/provide.js" % }
109 { % include "frappe/public/js/frappe/form/formatters.js" % }
110 </script>
Kanchan Chauhanb3fe6a42016-03-16 18:01:22 +0530111
Kanchan Chauhane14389e2016-03-23 14:14:38 +0530112{% endblock %}
Jannat Patel5a425112021-07-01 17:17:34 +0530113
114{% macro progress_bar(percent_complete) %}
115{% if percent_complete %}
Saurabh80e45822022-11-21 17:42:53 +0530116 <span class="small py-2">Project Progress:</span>
117 <div class="progress progress-hg" style="height: 15px;">
118 <div
119 class="progress-bar progress-bar-{{ 'warning' if percent_complete|round < 100 else 'success' }} active"\
120 role="progressbar" aria-valuenow="{{ percent_complete|round|int }}" aria-valuemin="0"\
121 aria-valuemax="100" style="width:{{ percent_complete|round|int }}%;">
122 </div>
Jannat Patel5a425112021-07-01 17:17:34 +0530123 </div>
Jannat Patel5a425112021-07-01 17:17:34 +0530124{% endif %}
125{% endmacro %}
Saurabh5d9960a2022-11-21 19:37:57 +0530126
127
128{% macro empty_state(section_name) %}
129<div class="frappe-list align-items-center">
130 <div class=" text-muted flex justify-center align-center" style="">
131 <div class=" text-muted flex text-center">
132 <div class="msg-box no-border">
133 <div>
134 <img src="/assets/frappe/images/ui-states/list-empty-state.svg" alt="Generic Empty State" class="null-state">
135 </div>
136 <p>You haven't created a {{ section_name }} yet</p>
137 </div>
138 </div>
139 </div>
140 </div>
141{% endmacro %}