Brak opisu

index.html 17KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400
  1. {% extends "layouts/default.html" %}
  2. {% block title %} Dashboard {% endblock title %}
  3. {% block stylesheets %}
  4. <link rel="stylesheet" href="/static/assets/css/suggestags.css">
  5. <link href="/static/assets/css/dataTables.contextualActions.min.css" rel="stylesheet">
  6. <link href="/static/assets/css/dataTables.select.min.css" rel="stylesheet">
  7. {% endblock stylesheets %}
  8. {% block content %}
  9. <div class="panel-header bg-primary-gradient mt--4">
  10. <div class="page-inner py-5">
  11. <div class="d-flex align-items-left align-items-md-center flex-column flex-md-row ">
  12. <div>
  13. <h2 class="text-white pb-2 fw-bold">Dashboard</h2>
  14. </div>
  15. <div class="ml-md-auto py-2 py-md-0">
  16. <a href="javascript:void(0);" onclick="load_add_case();" class="btn btn-white btn-sm btn-border btn-round mr-2">
  17. <span class="btn-label">
  18. <i class="fa fa-plus"></i>
  19. </span>
  20. Create new case
  21. </a>
  22. </div>
  23. </div>
  24. <div class="chart-container mt--2 mb--2">
  25. <canvas id="htmlLegendsChart" style="display: block; width: auto; height: 100px;" width="auto" height="100px" class="chartjs-render-monitor"></canvas>
  26. </div>
  27. </div>
  28. </div>
  29. <div class="page-inner mt--5">
  30. <div class="row row-card-no-pd">
  31. <div class="col-sm-6 col-md-4">
  32. <div class="card card-stats card-round">
  33. <div class="card-body ">
  34. <div class="row">
  35. <div class="col-5">
  36. <div class="icon-big text-center">
  37. <i class="flaticon-file-1 text-success"></i>
  38. </div>
  39. </div>
  40. <div class="col-7 col-stats">
  41. <div class="numbers">
  42. <p class="card-category">Cases (open / all)</p>
  43. <h4 class="card-title">{{ data.cases_open_count }} / {{ data.cases_count }}</h4>
  44. </div>
  45. </div>
  46. </div>
  47. </div>
  48. </div>
  49. </div>
  50. <div class="col-sm-6 col-md-4">
  51. <div class="card card-stats card-round">
  52. <div class="card-body ">
  53. <div class="row">
  54. <div class="col-5">
  55. <div class="icon-big text-center">
  56. <i class="flaticon-suitcase text-warning"></i>
  57. </div>
  58. </div>
  59. <div class="col-7 col-stats">
  60. <div class="numbers">
  61. <p class="card-category">Attributed open cases</p>
  62. <h4 class="card-title">{{ data.user_open_count }}</h4>
  63. </div>
  64. </div>
  65. </div>
  66. </div>
  67. </div>
  68. </div>
  69. <div class="col-sm-6 col-md-4">
  70. <div class="card card-stats card-round">
  71. <div class="card-body ">
  72. <div class="row">
  73. <div class="col-5">
  74. <div class="icon-big text-center">
  75. <i id='icon_user_task' class=""></i>
  76. </div>
  77. </div>
  78. <div class="col-7 col-stats">
  79. <div class="numbers">
  80. <p class="card-category">Attributed open tasks</p>
  81. <h4 class="card-title" id="user_attr_count"></h4>
  82. </div>
  83. </div>
  84. </div>
  85. </div>
  86. </div>
  87. </div>
  88. </div>
  89. <div class="row" id="rowPendingCasesReview" style="display: none;">
  90. <div class="col-md-12">
  91. <section class="card">
  92. <div class="card-header">
  93. <div class="card-title">Attributed cases review
  94. <div class="text-faded float-right">
  95. <small id="ureviews_last_updated"></small>
  96. <button type="button" class="btn btn-xs btn-dark ml-2"
  97. onclick="update_ureviews_list();">Refresh
  98. </button>
  99. </div>
  100. </div>
  101. </div>
  102. <div class="card-body">
  103. <div class="table-responsive" id="ureviews_table_wrapper">
  104. <table class="table display table-striped table-hover" width="100%" cellspacing="0" id="ureview_table" >
  105. <thead>
  106. <tr>
  107. <th>Case name</th>
  108. <th>Review Status</th>
  109. </tr>
  110. </thead>
  111. <tfoot>
  112. <tr>
  113. <th>Case name</th>
  114. <th>Review Status</th>
  115. </tr>
  116. </tfoot>
  117. </table>
  118. </div>
  119. </div>
  120. </section>
  121. </div>
  122. </div>
  123. <div class="row">
  124. <div class="col-md-12">
  125. {{ form.hidden_tag() }}
  126. <section class="card">
  127. <div class="card-header">
  128. <div class="card-title">Attributed open tasks
  129. <div class="text-faded float-right">
  130. <small id="utasks_last_updated"></small>
  131. <button type="button" class="btn btn-xs btn-dark ml-2"
  132. onclick="update_utasks_list();">Refresh
  133. </button>
  134. </div>
  135. </div>
  136. </div>
  137. <div class="card-body">
  138. <div class="table-responsive" id="utasks_table_wrapper">
  139. <table class="table display table-striped table-hover" width="100%" cellspacing="0" id="utasks_table" >
  140. <thead>
  141. <tr>
  142. <th>Title</th>
  143. <th>Description</th>
  144. <th>Status</th>
  145. <th>Case</th>
  146. <th>Last update</th>
  147. <th>Tags</th>
  148. </tr>
  149. </thead>
  150. <tfoot>
  151. <tr>
  152. <th>Title</th>
  153. <th>Description</th>
  154. <th>Status</th>
  155. <th>Case</th>
  156. <th>Last update</th>
  157. <th>Tags</th>
  158. </tr>
  159. </tfoot>
  160. </table>
  161. </div>
  162. </div>
  163. </section>
  164. </div>
  165. </div>
  166. <div class="row">
  167. <div class="col-md-12">
  168. <section class="card">
  169. <div class="card-header">
  170. <div class="card-title">Attributed open cases
  171. <div class="text-faded float-right">
  172. <small id="ucases_last_updated"></small>
  173. <button type="button" class="btn btn-xs btn-dark ml-2"
  174. onclick="update_ucases_list(true);">Show closed cases
  175. </button>
  176. <button type="button" class="btn btn-xs btn-dark ml-2"
  177. onclick="update_ucases_list();">Refresh
  178. </button>
  179. </div>
  180. </div>
  181. </div>
  182. <div class="card-body">
  183. <div class="table-responsive" id="ucases_table_wrapper">
  184. <table class="table display table-striped table-hover" width="100%" cellspacing="0" id="ucases_table" >
  185. <thead>
  186. <tr>
  187. <th>Title</th>
  188. <th>Description</th>
  189. <th>Client</th>
  190. <th>Opening date</th>
  191. <th>Tags</th>
  192. </tr>
  193. </thead>
  194. <tfoot>
  195. <tr>
  196. <th>Title</th>
  197. <th>Description</th>
  198. <th>Client</th>
  199. <th>Opening date</th>
  200. <th>Tags</th>
  201. </tr>
  202. </tfoot>
  203. </table>
  204. </div>
  205. </div>
  206. </section>
  207. </div>
  208. </div>
  209. <div class="row">
  210. <div class="col-md-12">
  211. <section class="card">
  212. <div class="card-header">
  213. <div class="card-title">Global tasks
  214. <div class="text-faded float-right">
  215. <small id="tasks_last_updated"></small>
  216. <button type="button" class="btn btn-xs btn-dark ml-2"
  217. onclick="add_gtask();">
  218. Add global task
  219. </button>
  220. <button type="button" class="btn btn-xs btn-dark ml-2"
  221. onclick="update_gtasks_list();">Refresh
  222. </button>
  223. </div>
  224. </div>
  225. </div>
  226. <div class="card-body">
  227. <div class="table-responsive" id="gtasks_table_wrapper">
  228. <table class="table display table-striped table-hover" width="100%" cellspacing="0" id="gtasks_table" >
  229. <thead>
  230. <tr>
  231. <th>Title</th>
  232. <th>Description</th>
  233. <th>Status</th>
  234. <th>Assigned to</th>
  235. <th>Last update</th>
  236. <th>Tags</th>
  237. </tr>
  238. </thead>
  239. <tfoot>
  240. <tr>
  241. <th>Title</th>
  242. <th>Description</th>
  243. <th>Status</th>
  244. <th>Assigned to</th>
  245. <th>Last update</th>
  246. <th>Tags</th>
  247. </tr>
  248. </tfoot>
  249. </table>
  250. </div>
  251. </div>
  252. </section>
  253. </div>
  254. </div>
  255. </div>
  256. <div class="modal " tabindex="-1" role="dialog" id="modal_add_gtask" data-backdrop="true">
  257. <div class="modal-xl modal-dialog" role="document">
  258. <div class="modal-content" id="modal_add_gtask_content">
  259. </div>
  260. <!-- /.modal-content -->
  261. </div>
  262. <!-- /.modal-dialog -->
  263. </div>
  264. {% endblock content %}
  265. {% block javascripts %}
  266. <script src="/static/assets/js/plugin/tagsinput/suggesttag.js"></script>
  267. <script src="/static/assets/js/plugin/select/select2.js"></script>
  268. <script src="/static/assets/js/plugin/datatables/dataTables.cellEdit.js"></script>
  269. <script src="/static/assets/js/plugin/datatables/dataTables.buttons.min.js"></script>
  270. <script src="/static/assets/js/plugin/datatables/dataTables.contextualActions.min.js"></script>
  271. <script src="/static/assets/js/plugin/datatables/dataTables.select.min.js"></script>
  272. <script src="/static/assets/js/plugin/datatables/buttons.html5.min.js"></script>
  273. <script src="/static/assets/js/plugin/datatables/buttons.print.min.js"></script>
  274. <script src="/static/assets/js/iris/dashboard.js"></script>
  275. <script src="/static/assets/js/core/charts.js"></script>
  276. <script src="/static/assets/js/core/Chart.PieceLabel.min.js"></script>
  277. <script>
  278. htmlLegendsChart = document.getElementById('htmlLegendsChart').getContext('2d');
  279. $.ajax({
  280. url: '/dashboard/case_charts' + case_param(),
  281. type: "GET",
  282. dataType: "JSON",
  283. success: function (data) {
  284. jsdata = data;
  285. if (jsdata.status == "success") {
  286. // Chart with HTML Legends
  287. var gradientStroke = htmlLegendsChart.createLinearGradient(500, 0, 100, 0);
  288. gradientStroke.addColorStop(0, '#177dff');
  289. gradientStroke.addColorStop(1, '#80b6f4');
  290. var gradientFill = htmlLegendsChart.createLinearGradient(500, 0, 100, 0);
  291. gradientFill.addColorStop(0, "rgba(23, 125, 255, 0.7)");
  292. gradientFill.addColorStop(1, "rgba(128, 182, 244, 0.3)");
  293. var myHtmlLegendsChart = new Chart(htmlLegendsChart, {
  294. type: 'line',
  295. data: {
  296. labels: jsdata.data[0],
  297. datasets: [ {
  298. label: "Open case",
  299. borderColor: gradientStroke,
  300. pointBackgroundColor: gradientStroke,
  301. pointRadius: 0,
  302. backgroundColor: gradientFill,
  303. legendColor: '#fff',
  304. fill: true,
  305. borderWidth: 1,
  306. data: jsdata.data[1]
  307. }]
  308. },
  309. options : {
  310. responsive: true,
  311. maintainAspectRatio: false,
  312. legend: {
  313. display: false
  314. },
  315. tooltips: {
  316. bodySpacing: 4,
  317. mode:"nearest",
  318. intersect: 0,
  319. position:"nearest",
  320. xPadding:10,
  321. yPadding:10,
  322. caretPadding:10
  323. },
  324. layout:{
  325. padding:{left:15,right:15,top:15,bottom:15}
  326. },
  327. scales: {
  328. yAxes: [{
  329. ticks: {
  330. display: false
  331. },
  332. gridLines: {
  333. drawTicks: false,
  334. display: false
  335. }
  336. }],
  337. xAxes: [{
  338. gridLines: {
  339. zeroLineColor: "transparent",
  340. display: false
  341. },
  342. ticks: {
  343. padding: 20,
  344. fontColor: "rgba(0,0,0,0.5)",
  345. fontStyle: "500",
  346. display: false
  347. }
  348. }]
  349. },
  350. legendCallback: function(chart) {
  351. var text = [];
  352. text.push('<ul class="' + chart.id + '-legend html-legend">');
  353. for (var i = 0; i < chart.data.datasets.length; i++) {
  354. text.push('<li><span style="background-color:' + chart.data.datasets[i].legendColor + '"></span>');
  355. if (chart.data.datasets[i].label) {
  356. text.push(chart.data.datasets[i].label);
  357. }
  358. text.push('</li>');
  359. }
  360. text.push('</ul>');
  361. return text.join('');
  362. }
  363. }
  364. });
  365. //var myLegendContainer = document.getElementById("myChartLegend");
  366. // generate HTML legend
  367. //myLegendContainer.innerHTML = myHtmlLegendsChart.generateLegend();
  368. }
  369. },
  370. error: function (error) {
  371. notify_error(error);
  372. }
  373. });
  374. </script>
  375. {% endblock javascripts %}