django-advanced-report-builder 1.2.9__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (360) hide show
  1. advanced_report_builder/.DS_Store +0 -0
  2. advanced_report_builder/.ruff_cache/.gitignore +2 -0
  3. advanced_report_builder/.ruff_cache/0.11.9/16555798982502606642 +0 -0
  4. advanced_report_builder/.ruff_cache/CACHEDIR.TAG +1 -0
  5. advanced_report_builder/__init__.py +0 -0
  6. advanced_report_builder/admin.py +264 -0
  7. advanced_report_builder/apps.py +7 -0
  8. advanced_report_builder/column_types.py +26 -0
  9. advanced_report_builder/columns.py +296 -0
  10. advanced_report_builder/customise.py +2 -0
  11. advanced_report_builder/data_merge/__init__.py +0 -0
  12. advanced_report_builder/data_merge/utils.py +112 -0
  13. advanced_report_builder/data_merge/widget.py +30 -0
  14. advanced_report_builder/duplicate.py +171 -0
  15. advanced_report_builder/exceptions.py +9 -0
  16. advanced_report_builder/field_types.py +466 -0
  17. advanced_report_builder/field_utils.py +401 -0
  18. advanced_report_builder/filter_query.py +862 -0
  19. advanced_report_builder/form_utils.py +12 -0
  20. advanced_report_builder/generate_series.py +14 -0
  21. advanced_report_builder/globals.py +276 -0
  22. advanced_report_builder/includes.py +72 -0
  23. advanced_report_builder/migrations/0001_initial.py +246 -0
  24. advanced_report_builder/migrations/0002_auto_20220209_1657.py +23 -0
  25. advanced_report_builder/migrations/0003_auto_20220215_1219.py +42 -0
  26. advanced_report_builder/migrations/0004_customreport.py +27 -0
  27. advanced_report_builder/migrations/0005_auto_20220303_0958.py +84 -0
  28. advanced_report_builder/migrations/0006_auto_20220310_1147.py +32 -0
  29. advanced_report_builder/migrations/0007_auto_20220322_1939.py +23 -0
  30. advanced_report_builder/migrations/0008_auto_20220404_1144.py +28 -0
  31. advanced_report_builder/migrations/0009_auto_20230428_1554.py +53 -0
  32. advanced_report_builder/migrations/0010_auto_20230428_2033.py +23 -0
  33. advanced_report_builder/migrations/0011_auto_20230620_1449.py +23 -0
  34. advanced_report_builder/migrations/0012_auto_20230718_1642.py +24 -0
  35. advanced_report_builder/migrations/0013_reportqueryorder.py +30 -0
  36. advanced_report_builder/migrations/0014_auto_20240706_2207.py +24 -0
  37. advanced_report_builder/migrations/0015_report_user_created_report_user_updated.py +26 -0
  38. advanced_report_builder/migrations/0016_calendarreport_dashboardreport_options_and_more.py +74 -0
  39. advanced_report_builder/migrations/0017_alter_barchartreport_options_and_more.py +57 -0
  40. advanced_report_builder/migrations/0018_reportquery_target_target_period_type.py +24 -0
  41. advanced_report_builder/migrations/0019_multicellstyle_and_more.py +107 -0
  42. advanced_report_builder/migrations/0020_alter_multicellstyle_font_size.py +18 -0
  43. advanced_report_builder/migrations/0021_multivalueheldquery_and_more.py +36 -0
  44. advanced_report_builder/migrations/0022_dashboardreport_show_options_report_template_style_and_more.py +44 -0
  45. advanced_report_builder/migrations/0023_rename_colour_target_default_colour_and_more.py +41 -0
  46. advanced_report_builder/migrations/0024_alter_target_period_type.py +18 -0
  47. advanced_report_builder/migrations/__init__.py +0 -0
  48. advanced_report_builder/models.py +954 -0
  49. advanced_report_builder/report_builder.py +28 -0
  50. advanced_report_builder/signals.py +3 -0
  51. advanced_report_builder/static/.DS_Store +0 -0
  52. advanced_report_builder/static/advanced_report_builder/.DS_Store +0 -0
  53. advanced_report_builder/static/advanced_report_builder/chart-js/js/chart.esm.js +10553 -0
  54. advanced_report_builder/static/advanced_report_builder/chart-js/js/chart.js +13190 -0
  55. advanced_report_builder/static/advanced_report_builder/chart-js/js/chart.min.js +13 -0
  56. advanced_report_builder/static/advanced_report_builder/chart-js/js/chartjs-adapter-moment.min.js +8 -0
  57. advanced_report_builder/static/advanced_report_builder/chart-js/js/chartjs-plugin-datalabels.min.js +7 -0
  58. advanced_report_builder/static/advanced_report_builder/chart-js/js/chunks/helpers.segment.js +2499 -0
  59. advanced_report_builder/static/advanced_report_builder/chart-js/js/helpers.esm.js +7 -0
  60. advanced_report_builder/static/advanced_report_builder/d3/js/d3.js +20196 -0
  61. advanced_report_builder/static/advanced_report_builder/d3/js/d3.min.js +2 -0
  62. advanced_report_builder/static/advanced_report_builder/d3-funnel/js/d3-funnel.js +6087 -0
  63. advanced_report_builder/static/advanced_report_builder/d3-funnel/js/d3-funnel.min.js +2 -0
  64. advanced_report_builder/static/advanced_report_builder/dashboard/js/dashboard.js +19 -0
  65. advanced_report_builder/static/advanced_report_builder/dot/js/.gitignore +31 -0
  66. advanced_report_builder/static/advanced_report_builder/dot/js/.travis.yml +9 -0
  67. advanced_report_builder/static/advanced_report_builder/dot/js/LICENSE-DOT.txt +24 -0
  68. advanced_report_builder/static/advanced_report_builder/dot/js/README.md +90 -0
  69. advanced_report_builder/static/advanced_report_builder/dot/js/bin/dot-packer +52 -0
  70. advanced_report_builder/static/advanced_report_builder/dot/js/bower.json +21 -0
  71. advanced_report_builder/static/advanced_report_builder/dot/js/doT.js +141 -0
  72. advanced_report_builder/static/advanced_report_builder/dot/js/doT.min.js +8 -0
  73. advanced_report_builder/static/advanced_report_builder/dot/js/doU.js +56 -0
  74. advanced_report_builder/static/advanced_report_builder/dot/js/index.js +143 -0
  75. advanced_report_builder/static/advanced_report_builder/dot/js/package.json +46 -0
  76. advanced_report_builder/static/advanced_report_builder/fullcalendar/.DS_Store +0 -0
  77. advanced_report_builder/static/advanced_report_builder/fullcalendar/LICENSE.txt +20 -0
  78. advanced_report_builder/static/advanced_report_builder/fullcalendar/README.md +10 -0
  79. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/LICENSE.txt +20 -0
  80. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/README.md +8 -0
  81. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/af.js +30 -0
  82. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ar-dz.js +31 -0
  83. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ar-kw.js +31 -0
  84. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ar-ly.js +31 -0
  85. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ar-ma.js +31 -0
  86. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ar-sa.js +31 -0
  87. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ar-tn.js +31 -0
  88. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ar.js +31 -0
  89. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/bg.js +31 -0
  90. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/bs.js +32 -0
  91. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ca.js +30 -0
  92. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/cs.js +32 -0
  93. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/da.js +30 -0
  94. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/de.js +33 -0
  95. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/el.js +30 -0
  96. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/en-au.js +17 -0
  97. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/en-gb.js +17 -0
  98. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/en-nz.js +17 -0
  99. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/es-us.js +30 -0
  100. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/es.js +30 -0
  101. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/et.js +32 -0
  102. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/eu.js +30 -0
  103. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/fa.js +33 -0
  104. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/fi.js +30 -0
  105. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/fr-ca.js +27 -0
  106. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/fr-ch.js +31 -0
  107. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/fr.js +31 -0
  108. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/gl.js +30 -0
  109. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/he.js +27 -0
  110. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/hi.js +32 -0
  111. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/hr.js +32 -0
  112. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/hu.js +30 -0
  113. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/id.js +30 -0
  114. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/is.js +30 -0
  115. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/it.js +32 -0
  116. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ja.js +28 -0
  117. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ka.js +32 -0
  118. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/kk.js +32 -0
  119. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ko.js +26 -0
  120. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/lb.js +30 -0
  121. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/lt.js +30 -0
  122. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/lv.js +32 -0
  123. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/mk.js +28 -0
  124. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ms.js +32 -0
  125. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/nb.js +30 -0
  126. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/nl.js +30 -0
  127. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/nn.js +30 -0
  128. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/pl.js +30 -0
  129. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/pt-br.js +28 -0
  130. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/pt.js +30 -0
  131. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ro.js +32 -0
  132. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/ru.js +32 -0
  133. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/sk.js +32 -0
  134. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/sl.js +30 -0
  135. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/sq.js +32 -0
  136. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/sr-cyrl.js +32 -0
  137. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/sr.js +32 -0
  138. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/sv.js +30 -0
  139. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/th.js +25 -0
  140. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/tr.js +30 -0
  141. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/uk.js +32 -0
  142. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/vi.js +32 -0
  143. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/zh-cn.js +33 -0
  144. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales/zh-tw.js +26 -0
  145. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales-all.js +1348 -0
  146. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/locales-all.min.js +1 -0
  147. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/main.css +1052 -0
  148. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/main.d.ts +2730 -0
  149. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/main.esm.js +8558 -0
  150. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/main.js +8717 -0
  151. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/main.min.css +1 -0
  152. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/main.min.js +6 -0
  153. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/core/package.json +30 -0
  154. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/daygrid/LICENSE.txt +20 -0
  155. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/daygrid/README.md +8 -0
  156. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/daygrid/main.css +78 -0
  157. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/daygrid/main.d.ts +310 -0
  158. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/daygrid/main.esm.js +1627 -0
  159. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/daygrid/main.js +1641 -0
  160. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/daygrid/main.min.css +1 -0
  161. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/daygrid/main.min.js +6 -0
  162. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/daygrid/package.json +33 -0
  163. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/fullcalendar-yearview/LICENSE +21 -0
  164. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/fullcalendar-yearview/css/main.css +85 -0
  165. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/fullcalendar-yearview/js/main.js +2018 -0
  166. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/google-calendar/LICENSE.txt +20 -0
  167. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/google-calendar/README.md +8 -0
  168. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/google-calendar/main.d.ts +20 -0
  169. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/google-calendar/main.esm.js +162 -0
  170. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/google-calendar/main.js +170 -0
  171. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/google-calendar/main.min.js +6 -0
  172. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/google-calendar/package.json +33 -0
  173. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/interaction/LICENSE.txt +20 -0
  174. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/interaction/README.md +8 -0
  175. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/interaction/main.d.ts +323 -0
  176. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/interaction/main.esm.js +2132 -0
  177. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/interaction/main.js +2143 -0
  178. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/interaction/main.min.js +6 -0
  179. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/interaction/package.json +33 -0
  180. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/list/LICENSE.txt +20 -0
  181. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/list/README.md +8 -0
  182. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/list/main.css +118 -0
  183. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/list/main.d.ts +33 -0
  184. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/list/main.esm.js +335 -0
  185. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/list/main.js +343 -0
  186. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/list/main.min.css +1 -0
  187. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/list/main.min.js +6 -0
  188. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/list/package.json +33 -0
  189. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/luxon/LICENSE.txt +20 -0
  190. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/luxon/README.md +8 -0
  191. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/luxon/main.d.ts +14 -0
  192. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/luxon/main.esm.js +162 -0
  193. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/luxon/main.js +170 -0
  194. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/luxon/main.min.js +6 -0
  195. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/luxon/package.json +34 -0
  196. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment/LICENSE.txt +20 -0
  197. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment/README.md +8 -0
  198. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment/main.d.ts +14 -0
  199. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment/main.esm.js +102 -0
  200. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment/main.js +110 -0
  201. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment/main.min.js +6 -0
  202. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment/package.json +34 -0
  203. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment-timezone/LICENSE.txt +20 -0
  204. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment-timezone/README.md +8 -0
  205. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment-timezone/main.d.ts +11 -0
  206. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment-timezone/main.esm.js +58 -0
  207. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment-timezone/main.js +64 -0
  208. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment-timezone/main.min.js +6 -0
  209. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/moment-timezone/package.json +35 -0
  210. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/rrule/LICENSE.txt +20 -0
  211. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/rrule/README.md +8 -0
  212. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/rrule/main.d.ts +9 -0
  213. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/rrule/main.esm.js +121 -0
  214. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/rrule/main.js +128 -0
  215. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/rrule/main.min.js +6 -0
  216. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/rrule/package.json +34 -0
  217. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/timegrid/LICENSE.txt +20 -0
  218. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/timegrid/README.md +8 -0
  219. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/timegrid/main.css +309 -0
  220. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/timegrid/main.d.ts +220 -0
  221. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/timegrid/main.esm.js +1345 -0
  222. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/timegrid/main.js +1357 -0
  223. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/timegrid/main.min.css +1 -0
  224. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/timegrid/main.min.js +6 -0
  225. advanced_report_builder/static/advanced_report_builder/fullcalendar/packages/timegrid/package.json +36 -0
  226. advanced_report_builder/static/advanced_report_builder/fullcalendar/vendor/rrule.js +3782 -0
  227. advanced_report_builder/static/advanced_report_builder/jquery_extendext/js/jQuery.extendext.js +132 -0
  228. advanced_report_builder/static/advanced_report_builder/jquery_extendext/js/jQuery.extendext.min.js +9 -0
  229. advanced_report_builder/static/advanced_report_builder/moment/locales.js +9769 -0
  230. advanced_report_builder/static/advanced_report_builder/moment/locales.min.js +1 -0
  231. advanced_report_builder/static/advanced_report_builder/moment/moment-with-locales.js +14289 -0
  232. advanced_report_builder/static/advanced_report_builder/moment/moment-with-locales.min.js +1 -0
  233. advanced_report_builder/static/advanced_report_builder/moment/moment.min.js +1 -0
  234. advanced_report_builder/static/advanced_report_builder/query_builder/.DS_Store +0 -0
  235. advanced_report_builder/static/advanced_report_builder/query_builder/css/.DS_Store +0 -0
  236. advanced_report_builder/static/advanced_report_builder/query_builder/css/query-builder.dark.css +173 -0
  237. advanced_report_builder/static/advanced_report_builder/query_builder/css/query-builder.dark.min.css +6 -0
  238. advanced_report_builder/static/advanced_report_builder/query_builder/css/query-builder.default.css +173 -0
  239. advanced_report_builder/static/advanced_report_builder/query_builder/css/query-builder.default.min.css +6 -0
  240. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.ar.js +80 -0
  241. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.az.js +79 -0
  242. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.bg.js +79 -0
  243. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.cs.js +79 -0
  244. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.da.js +56 -0
  245. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.de.js +76 -0
  246. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.el.js +80 -0
  247. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.en.js +83 -0
  248. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.es.js +81 -0
  249. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.fa-IR.js +79 -0
  250. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.fr.js +83 -0
  251. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.he.js +81 -0
  252. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.it.js +79 -0
  253. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.nl.js +76 -0
  254. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.no.js +54 -0
  255. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.pl.js +80 -0
  256. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.pt-BR.js +80 -0
  257. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.pt-PT.js +75 -0
  258. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.ro.js +54 -0
  259. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.ru.js +77 -0
  260. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.sq.js +78 -0
  261. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.tr.js +82 -0
  262. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.ua.js +79 -0
  263. advanced_report_builder/static/advanced_report_builder/query_builder/i18n/query-builder.zh-CN.js +80 -0
  264. advanced_report_builder/static/advanced_report_builder/query_builder/js/.DS_Store +0 -0
  265. advanced_report_builder/static/advanced_report_builder/query_builder/js/plugins/.DS_Store +0 -0
  266. advanced_report_builder/static/advanced_report_builder/query_builder/js/plugins/currency/plugin.js +30 -0
  267. advanced_report_builder/static/advanced_report_builder/query_builder/js/query-builder.js +6200 -0
  268. advanced_report_builder/static/advanced_report_builder/query_builder/js/query-builder.min.js +7 -0
  269. advanced_report_builder/static/advanced_report_builder/query_builder/js/query-builder.standalone.js +6477 -0
  270. advanced_report_builder/static/advanced_report_builder/query_builder/js/query-builder.standalone.min.js +7 -0
  271. advanced_report_builder/static/advanced_report_builder/query_builder/scss/.DS_Store +0 -0
  272. advanced_report_builder/static/advanced_report_builder/query_builder/scss/dark.scss +19 -0
  273. advanced_report_builder/static/advanced_report_builder/query_builder/scss/default.scss +186 -0
  274. advanced_report_builder/static/advanced_report_builder/query_builder/scss/plugins/_bt-checkbox.scss +12 -0
  275. advanced_report_builder/static/advanced_report_builder/query_builder/scss/plugins/_bt-tooltip-errors.scss +9 -0
  276. advanced_report_builder/static/advanced_report_builder/query_builder/scss/plugins/_filter-description.scss +21 -0
  277. advanced_report_builder/static/advanced_report_builder/query_builder/scss/plugins/_invert.scss +5 -0
  278. advanced_report_builder/static/advanced_report_builder/query_builder/scss/plugins/_sortable.scss +28 -0
  279. advanced_report_builder/static/advanced_report_builder/query_builder/scss/plugins/bt-tooltip-errors.scss +9 -0
  280. advanced_report_builder/static/advanced_report_builder/query_builder/scss/plugins/filter-description.scss +21 -0
  281. advanced_report_builder/static/advanced_report_builder/query_builder/scss/plugins/invert.scss +5 -0
  282. advanced_report_builder/static/advanced_report_builder/query_builder/scss/plugins/sortable.scss +27 -0
  283. advanced_report_builder/template_types.py +34 -0
  284. advanced_report_builder/templates/advanced_report_builder/calendar/description_modal.html +12 -0
  285. advanced_report_builder/templates/advanced_report_builder/calendar/middle.html +33 -0
  286. advanced_report_builder/templates/advanced_report_builder/calendar/modal.html +10 -0
  287. advanced_report_builder/templates/advanced_report_builder/calendar/report.html +80 -0
  288. advanced_report_builder/templates/advanced_report_builder/charts/bar/middle.html +122 -0
  289. advanced_report_builder/templates/advanced_report_builder/charts/funnel/middle.html +46 -0
  290. advanced_report_builder/templates/advanced_report_builder/charts/funnel/report.html +34 -0
  291. advanced_report_builder/templates/advanced_report_builder/charts/line/middle.html +119 -0
  292. advanced_report_builder/templates/advanced_report_builder/charts/modal.html +12 -0
  293. advanced_report_builder/templates/advanced_report_builder/charts/modal_field.html +13 -0
  294. advanced_report_builder/templates/advanced_report_builder/charts/pie/middle.html +58 -0
  295. advanced_report_builder/templates/advanced_report_builder/charts/report.html +33 -0
  296. advanced_report_builder/templates/advanced_report_builder/data_merge/data_merge.html +144 -0
  297. advanced_report_builder/templates/advanced_report_builder/datatables/fields/modal.html +13 -0
  298. advanced_report_builder/templates/advanced_report_builder/datatables/fields/single_query_builder.html +87 -0
  299. advanced_report_builder/templates/advanced_report_builder/datatables/modal.html +13 -0
  300. advanced_report_builder/templates/advanced_report_builder/datatables/onclick_menu.html +14 -0
  301. advanced_report_builder/templates/advanced_report_builder/datatables/report.html +37 -0
  302. advanced_report_builder/templates/advanced_report_builder/datatables/select_pivot.html +199 -0
  303. advanced_report_builder/templates/advanced_report_builder/error.html +21 -0
  304. advanced_report_builder/templates/advanced_report_builder/extra_query_modal.html +13 -0
  305. advanced_report_builder/templates/advanced_report_builder/kanban/description_modal.html +12 -0
  306. advanced_report_builder/templates/advanced_report_builder/kanban/middle.html +63 -0
  307. advanced_report_builder/templates/advanced_report_builder/kanban/modal.html +10 -0
  308. advanced_report_builder/templates/advanced_report_builder/kanban/report.html +71 -0
  309. advanced_report_builder/templates/advanced_report_builder/multi_values/held_modal.html +14 -0
  310. advanced_report_builder/templates/advanced_report_builder/multi_values/middle.html +61 -0
  311. advanced_report_builder/templates/advanced_report_builder/multi_values/modal.html +15 -0
  312. advanced_report_builder/templates/advanced_report_builder/multi_values/report.html +19 -0
  313. advanced_report_builder/templates/advanced_report_builder/query_builder.html +88 -0
  314. advanced_report_builder/templates/advanced_report_builder/query_modal.html +12 -0
  315. advanced_report_builder/templates/advanced_report_builder/select_column.html +230 -0
  316. advanced_report_builder/templates/advanced_report_builder/single_values/gauge_middle.html +143 -0
  317. advanced_report_builder/templates/advanced_report_builder/single_values/middle.html +63 -0
  318. advanced_report_builder/templates/advanced_report_builder/single_values/modal.html +13 -0
  319. advanced_report_builder/templates/advanced_report_builder/single_values/report.html +56 -0
  320. advanced_report_builder/toggle.py +9 -0
  321. advanced_report_builder/urls.py +237 -0
  322. advanced_report_builder/utils.py +171 -0
  323. advanced_report_builder/variable_date.py +670 -0
  324. advanced_report_builder/view_types.py +27 -0
  325. advanced_report_builder/views/.DS_Store +0 -0
  326. advanced_report_builder/views/__init__.py +0 -0
  327. advanced_report_builder/views/bar_charts.py +746 -0
  328. advanced_report_builder/views/calendar.py +745 -0
  329. advanced_report_builder/views/charts_base.py +625 -0
  330. advanced_report_builder/views/custom.py +147 -0
  331. advanced_report_builder/views/dashboard.py +357 -0
  332. advanced_report_builder/views/datatables/__init__.py +0 -0
  333. advanced_report_builder/views/datatables/datatables.py +151 -0
  334. advanced_report_builder/views/datatables/modal.py +1151 -0
  335. advanced_report_builder/views/datatables/utils.py +701 -0
  336. advanced_report_builder/views/error_pod.py +50 -0
  337. advanced_report_builder/views/funnel_charts.py +289 -0
  338. advanced_report_builder/views/helpers.py +22 -0
  339. advanced_report_builder/views/kanban.py +868 -0
  340. advanced_report_builder/views/line_charts.py +415 -0
  341. advanced_report_builder/views/modals_base.py +213 -0
  342. advanced_report_builder/views/multi_value.py +1160 -0
  343. advanced_report_builder/views/pie_charts.py +290 -0
  344. advanced_report_builder/views/query_modal/__init__.py +0 -0
  345. advanced_report_builder/views/query_modal/mixin.py +161 -0
  346. advanced_report_builder/views/query_modal/modal.py +274 -0
  347. advanced_report_builder/views/report.py +241 -0
  348. advanced_report_builder/views/report_utils_mixin.py +312 -0
  349. advanced_report_builder/views/reports.py +154 -0
  350. advanced_report_builder/views/single_values.py +792 -0
  351. advanced_report_builder/views/targets/__init__.py +0 -0
  352. advanced_report_builder/views/targets/utils.py +251 -0
  353. advanced_report_builder/views/targets/views.py +139 -0
  354. advanced_report_builder/views/value_base.py +198 -0
  355. advanced_report_builder/widgets.py +5 -0
  356. django_advanced_report_builder-1.2.9.dist-info/METADATA +35 -0
  357. django_advanced_report_builder-1.2.9.dist-info/RECORD +360 -0
  358. django_advanced_report_builder-1.2.9.dist-info/WHEEL +5 -0
  359. django_advanced_report_builder-1.2.9.dist-info/licenses/LICENSE +21 -0
  360. django_advanced_report_builder-1.2.9.dist-info/top_level.txt +1 -0
@@ -0,0 +1,745 @@
1
+ import json
2
+ from datetime import timedelta
3
+
4
+ from ajax_helpers.utils import random_string
5
+ from django.conf import settings
6
+ from django.forms import CharField, IntegerField, ModelChoiceField, NumberInput
7
+ from django.http import JsonResponse
8
+ from django.shortcuts import get_object_or_404
9
+ from django.urls import reverse
10
+ from django.views.generic import TemplateView
11
+ from django_datatables.columns import DateColumn, DateTimeColumn, MenuColumn
12
+ from django_datatables.datatables import DatatableExcludedRow
13
+ from django_datatables.helpers import DUMMY_ID, row_link
14
+ from django_datatables.widgets import DataTableReorderWidget
15
+ from django_menus.menu import HtmlMenu, MenuItem
16
+ from django_modals.fields import FieldEx
17
+ from django_modals.form_helpers import HorizontalNoEnterHelper
18
+ from django_modals.helper import modal_button, modal_button_method
19
+ from django_modals.modals import Modal, ModelFormModal
20
+ from django_modals.processes import PERMISSION_OFF, PROCESS_EDIT_DELETE
21
+ from django_modals.widgets.select2 import Select2, Select2Multiple
22
+
23
+ from advanced_report_builder.columns import ReportBuilderNumberColumn
24
+ from advanced_report_builder.data_merge.utils import DataMergeUtils
25
+ from advanced_report_builder.data_merge.widget import DataMergeWidget
26
+ from advanced_report_builder.filter_query import FilterQueryMixin
27
+ from advanced_report_builder.models import (
28
+ CalendarReport,
29
+ CalendarReportDataSet,
30
+ CalendarReportDescription,
31
+ ReportType,
32
+ )
33
+ from advanced_report_builder.utils import crispy_modal_link_args, get_report_builder_class
34
+ from advanced_report_builder.views.charts_base import ChartJSTable
35
+ from advanced_report_builder.views.datatables.utils import DescriptionColumn
36
+ from advanced_report_builder.views.helpers import QueryBuilderModelForm
37
+ from advanced_report_builder.views.modals_base import QueryBuilderModalBase
38
+ from advanced_report_builder.views.report import ReportBase
39
+
40
+
41
+ class CalendarTable(ChartJSTable):
42
+ DATE_COLUMNS = (DateColumn, DateTimeColumn)
43
+
44
+ def get_table_array(self, request, results):
45
+ result_processes = self.get_result_processes()
46
+ for p in result_processes:
47
+ p.setup_results(request, self.page_results)
48
+ for c in self.columns:
49
+ c.setup_results(request, self.page_results)
50
+ results_list = []
51
+ for data_dict in results:
52
+ try:
53
+ for p in result_processes:
54
+ p.row_result(data_dict, self.page_results)
55
+ row_data = []
56
+ for column in self.columns:
57
+ if isinstance(column, DescriptionColumn):
58
+ row_data.append(column.row_result(data_dict, self.page_results, columns=self.columns))
59
+ elif isinstance(column, self.DATE_COLUMNS) and hasattr(column, 'iso_row_result'):
60
+ row_data.append(column.iso_row_result(data_dict, self.page_results))
61
+ else:
62
+ row_data.append(column.row_result(data_dict, self.page_results))
63
+
64
+ results_list.append(row_data)
65
+ except DatatableExcludedRow:
66
+ pass
67
+ return results_list
68
+
69
+
70
+ class CalendarView(DataMergeUtils, ReportBase, FilterQueryMixin, TemplateView):
71
+ number_field = ReportBuilderNumberColumn
72
+ template_name = 'advanced_report_builder/calendar/report.html'
73
+ chart_js_table = CalendarTable
74
+
75
+ def __init__(self, *args, **kwargs):
76
+ self.chart_report = None
77
+ super().__init__(*args, **kwargs)
78
+
79
+ def setup_menu(self):
80
+ super().setup_menu()
81
+ if self.dashboard_report and self.enable_edit:
82
+ report_menu = self.pod_dashboard_edit_menu()
83
+ elif self.dashboard_report and not self.enable_edit:
84
+ report_menu = self.pod_dashboard_view_menu()
85
+ else:
86
+ report_menu = self.pod_report_menu()
87
+ self.add_menu('button_menu', 'button_group').add_items(
88
+ *report_menu,
89
+ *self.queries_option_menus(report=self.report, dashboard_report=self.dashboard_report),
90
+ )
91
+
92
+ def dispatch(self, request, *args, **kwargs):
93
+ self.report = kwargs.get('report')
94
+ self.chart_report = self.report.calendarreport
95
+ self.dashboard_report = kwargs.get('dashboard_report')
96
+ self.enable_edit = kwargs.get('enable_edit')
97
+ return super().dispatch(request, *args, **kwargs)
98
+
99
+ def view_filter_extra(self, query, table):
100
+ if table.extra_query_filter:
101
+ query = query.filter(table.extra_query_filter)
102
+ return self.view_filter(query, table)
103
+
104
+ def get_calendar_events(self, base_model, calendar_report_data_set, lanes, label=None, extra_query_filter=None):
105
+ table = self.chart_js_table(model=base_model)
106
+
107
+ report_builder_class = get_report_builder_class(
108
+ model=base_model, report_type=calendar_report_data_set.report_type
109
+ )
110
+ table_indexes = ['start_date_field', 'end_date_field']
111
+ table.add_columns(calendar_report_data_set.start_date_field)
112
+ if calendar_report_data_set.end_date_type == CalendarReportDataSet.END_DATE_TYPE_FIELD:
113
+ table.add_columns(calendar_report_data_set.end_date_field)
114
+ elif (
115
+ calendar_report_data_set.end_date_type == CalendarReportDataSet.END_DATE_TYPE_DURATION_FIELD
116
+ and calendar_report_data_set.end_duration_field is not None
117
+ ):
118
+ _, _, _, start_field_col_field = self.get_field_details(
119
+ base_model=base_model,
120
+ field=calendar_report_data_set.start_date_field,
121
+ report_builder_class=report_builder_class,
122
+ )
123
+ _, _, _, end_duration_col_field = self.get_field_details(
124
+ base_model=base_model,
125
+ field=calendar_report_data_set.end_duration_field,
126
+ report_builder_class=report_builder_class,
127
+ )
128
+
129
+ class DurationEndDateColumn(DateColumn):
130
+ def col_setup(self):
131
+ self.field = [start_field_col_field, end_duration_col_field]
132
+
133
+ def row_result(self, data, _page_result):
134
+ start_date = data.get(self.model_path + start_field_col_field)
135
+ end_duration = data.get(self.model_path + end_duration_col_field)
136
+ if end_duration is None or end_duration <= 0:
137
+ end_duration = 3600
138
+ end_date = start_date + timedelta(seconds=end_duration)
139
+ try:
140
+ date = end_date.strftime('%d/%m/%Y')
141
+ time_str = end_date.strftime('%H:%M')
142
+ return date + ' ' + time_str
143
+ except AttributeError:
144
+ return ''
145
+
146
+ table.add_columns(DurationEndDateColumn(column_name='EndDate'))
147
+
148
+ else:
149
+ _, _, _, start_field_col_field = self.get_field_details(
150
+ base_model=base_model,
151
+ field=calendar_report_data_set.start_date_field,
152
+ report_builder_class=report_builder_class,
153
+ )
154
+
155
+ class FixedDurationEndDateColumn(DateColumn):
156
+ def row_result(self, data, _page_result):
157
+ start_date = data.get(self.model_path + start_field_col_field)
158
+ end_duration = calendar_report_data_set.end_duration
159
+ if end_duration is None:
160
+ end_duration = 3600
161
+
162
+ end_date = start_date + timedelta(seconds=end_duration)
163
+ try:
164
+ date = end_date.strftime('%d/%m/%Y')
165
+ time_str = end_date.strftime('%H:%M')
166
+ return date + ' ' + time_str
167
+ except AttributeError:
168
+ return ''
169
+
170
+ table.add_columns(FixedDurationEndDateColumn(column_name='EndDate'))
171
+
172
+ if (
173
+ calendar_report_data_set.display_type
174
+ in (
175
+ CalendarReportDataSet.DISPLAY_TYPE_NAME_AND_DESCRIPTION,
176
+ CalendarReportDataSet.DISPLAY_TYPE_HEADING_ONLY,
177
+ )
178
+ and calendar_report_data_set.heading_field is not None
179
+ ):
180
+ table_indexes.append('heading')
181
+ table.add_columns(calendar_report_data_set.heading_field)
182
+
183
+ if calendar_report_data_set.background_colour_field is not None:
184
+ table_indexes.append('background_colour')
185
+ table.add_columns(calendar_report_data_set.background_colour_field)
186
+
187
+ if (
188
+ calendar_report_data_set.display_type
189
+ in (
190
+ CalendarReportDataSet.DISPLAY_TYPE_NAME_AND_DESCRIPTION,
191
+ CalendarReportDataSet.DISPLAY_TYPE_DESCRIPTION_ONLY,
192
+ )
193
+ and calendar_report_data_set.calendar_report_description is not None
194
+ ):
195
+ description = calendar_report_data_set.calendar_report_description.description
196
+ columns, column_map = self.get_data_merge_columns(
197
+ base_model=base_model, report_builder_class=report_builder_class, html=description, table=table
198
+ )
199
+ description_column_name = (
200
+ 'description'
201
+ if calendar_report_data_set.display_type == CalendarReportDataSet.DISPLAY_TYPE_NAME_AND_DESCRIPTION
202
+ else 'heading'
203
+ )
204
+ table_indexes.append(description_column_name)
205
+ table.add_columns(
206
+ DescriptionColumn(
207
+ column_name=description_column_name, field='', html=description, column_map=column_map
208
+ )
209
+ )
210
+ table.add_columns(*columns)
211
+
212
+ table.table_options['indexes'] = table_indexes
213
+
214
+ if calendar_report_data_set.link_field and self.kwargs.get('enable_links'):
215
+ _, col_type_override, _, _ = self.get_field_details(
216
+ base_model=base_model,
217
+ field=calendar_report_data_set.link_field,
218
+ report_builder_class=report_builder_class,
219
+ )
220
+ field = col_type_override.field[0] if isinstance(col_type_override.field, list) else 'id'
221
+ if field not in table.columns:
222
+ table.add_columns(f'.{field}')
223
+ table.has_link = True
224
+ table.table_options['row_href'] = row_link(col_type_override.url, field)
225
+ else:
226
+ table.has_link = False
227
+
228
+ table.datatable_template = 'advanced_report_builder/calendar/middle.html'
229
+
230
+ table.query_data = calendar_report_data_set.query_data
231
+ table.extra_query_filter = extra_query_filter
232
+ table.view_filter = self.view_filter_extra
233
+ lanes.append({'datatable': table, 'label': label, 'calendar_report_data_set': calendar_report_data_set})
234
+
235
+ def get_context_data(self, **kwargs):
236
+ context = super().get_context_data(**kwargs)
237
+ context['title'] = self.get_title()
238
+ calendar_report_data_sets = self.chart_report.calendarreportdataset_set.all()
239
+ lanes = []
240
+ headings = []
241
+
242
+ for calendar_report_data_set in calendar_report_data_sets:
243
+ base_model = calendar_report_data_set.get_base_model()
244
+ self.get_calendar_events(
245
+ base_model=base_model, calendar_report_data_set=calendar_report_data_set, lanes=lanes
246
+ )
247
+ view_type = None
248
+ if self.dashboard_report and self.dashboard_report.options is not None:
249
+ view_type = self.dashboard_report.options.get('calendar_view_type')
250
+ if view_type is not None:
251
+ view_type = int(view_type)
252
+ if view_type == 0:
253
+ view_type = None
254
+
255
+ context['view_type'] = self.chart_report.get_view_type_for_calendar(view_type=view_type)
256
+ context['calendar_report'] = self.chart_report
257
+ context['headings'] = headings
258
+ context['lanes'] = lanes
259
+ context['field_id'] = random_string()
260
+ return context
261
+
262
+ def view_filter(self, query, table):
263
+ if not table.query_data:
264
+ return query
265
+
266
+ return self.process_query_filters(query=query, search_filter_data=table.query_data)
267
+
268
+ # noinspection PyMethodMayBeStatic
269
+ def pod_dashboard_view_menu(self):
270
+ return []
271
+
272
+ def pod_report_menu(self):
273
+ return self.edit_report_menu(request=self.request, chart_report_id=self.chart_report.id)
274
+
275
+ def edit_report_menu(self, request, chart_report_id):
276
+ return [
277
+ MenuItem(
278
+ f'advanced_report_builder:calendar_modal,pk-{chart_report_id}',
279
+ menu_display='Edit',
280
+ font_awesome='fas fa-pencil-alt',
281
+ css_classes=['btn-primary'],
282
+ ),
283
+ *self.duplicate_menu(request=request, report_id=chart_report_id),
284
+ ]
285
+
286
+ def pod_dashboard_edit_menu(self):
287
+ return [
288
+ MenuItem(
289
+ f'advanced_report_builder:dashboard_report_modal,pk-{self.dashboard_report.id}',
290
+ menu_display='Edit',
291
+ font_awesome='fas fa-pencil-alt',
292
+ css_classes=['btn-primary'],
293
+ )
294
+ ]
295
+
296
+ # noinspection PyMethodMayBeStatic
297
+ def queries_option_menus(self, report, dashboard_report):
298
+ return []
299
+
300
+
301
+ class CalendarModal(ModelFormModal):
302
+ size = 'xl'
303
+ process = PROCESS_EDIT_DELETE
304
+ permission_delete = PERMISSION_OFF
305
+ model = CalendarReport
306
+ widgets = {'report_tags': Select2Multiple}
307
+ ajax_commands = ['datatable', 'button']
308
+
309
+ form_fields = ['name', 'notes', 'report_tags', 'height', 'view_type']
310
+
311
+ def form_setup(self, form, *_args, **_kwargs):
312
+ org_id = self.object.id if hasattr(self, 'object') else None
313
+ form.fields['notes'].widget.attrs['rows'] = 3
314
+
315
+ if org_id is not None:
316
+ lane_menu_items = [
317
+ MenuItem(
318
+ f'advanced_report_builder:calendar_data_set_duplicate_modal,pk-{DUMMY_ID}',
319
+ menu_display='Duplicate',
320
+ css_classes='btn btn-sm btn-outline-dark',
321
+ font_awesome='fas fa-clone',
322
+ ),
323
+ MenuItem(
324
+ f'advanced_report_builder:calendar_data_set_modal,pk-{DUMMY_ID}',
325
+ menu_display='Edit',
326
+ css_classes='btn btn-sm btn-outline-dark',
327
+ font_awesome='fas fa-pencil',
328
+ ),
329
+ ]
330
+
331
+ form.fields['data_sets'] = CharField(
332
+ required=False,
333
+ label='Data Sets',
334
+ widget=DataTableReorderWidget(
335
+ model=CalendarReportDataSet,
336
+ order_field='order',
337
+ fields=[
338
+ '_.index',
339
+ '.id',
340
+ 'name',
341
+ MenuColumn(
342
+ column_name='menu',
343
+ field='id',
344
+ column_defs={'orderable': False, 'className': 'dt-right'},
345
+ menu=HtmlMenu(self.request, 'button_group').add_items(*lane_menu_items),
346
+ ),
347
+ ],
348
+ attrs={'filter': {'calendar_report__id': self.object.id}},
349
+ ),
350
+ )
351
+
352
+ description_menu_items = [
353
+ MenuItem(
354
+ f'advanced_report_builder:calendar_description_duplicate_modal,pk-{DUMMY_ID}',
355
+ menu_display='Duplicate',
356
+ css_classes='btn btn-sm btn-outline-dark',
357
+ font_awesome='fas fa-clone',
358
+ ),
359
+ MenuItem(
360
+ f'advanced_report_builder:calendar_description_modal,pk-{DUMMY_ID}',
361
+ menu_display='Edit',
362
+ css_classes='btn btn-sm btn-outline-dark',
363
+ font_awesome='fas fa-pencil',
364
+ ),
365
+ ]
366
+
367
+ form.fields['descriptions'] = CharField(
368
+ required=False,
369
+ label='Descriptions',
370
+ widget=DataTableReorderWidget(
371
+ model=CalendarReportDescription,
372
+ order_field='order',
373
+ fields=[
374
+ '_.index',
375
+ '.id',
376
+ 'name',
377
+ MenuColumn(
378
+ column_name='menu',
379
+ field='id',
380
+ column_defs={'orderable': False, 'className': 'dt-right'},
381
+ menu=HtmlMenu(self.request, 'button_group').add_items(*description_menu_items),
382
+ ),
383
+ ],
384
+ attrs={'filter': {'calendar_report__id': self.object.id}},
385
+ ),
386
+ )
387
+
388
+ modal_button('Custom Close', 'close', 'btn-warning')
389
+
390
+ return [
391
+ *self.form_fields,
392
+ crispy_modal_link_args(
393
+ 'advanced_report_builder:calendar_data_set_modal',
394
+ 'Add Data Set',
395
+ 'calendar_report_id-',
396
+ self.object.id,
397
+ div=True,
398
+ div_classes='form-buttons',
399
+ button_classes='btn btn-primary',
400
+ font_awesome='fa fa-plus',
401
+ ),
402
+ 'data_sets',
403
+ crispy_modal_link_args(
404
+ 'advanced_report_builder:calendar_description_modal',
405
+ 'Add Description',
406
+ 'calendar_report_id-',
407
+ self.object.id,
408
+ div=True,
409
+ div_classes='form-buttons',
410
+ button_classes='btn btn-primary',
411
+ font_awesome='fa fa-plus',
412
+ ),
413
+ 'descriptions',
414
+ ]
415
+
416
+ def datatable_sort(self, **kwargs):
417
+ form = self.get_form()
418
+ widget = form.fields[kwargs['table_id'][3:]].widget
419
+ _model = widget.attrs['table_model']
420
+ current_sort = dict(_model.objects.filter(calendar_report=self.object.id).values_list('id', 'order'))
421
+ for s in kwargs['sort']:
422
+ if current_sort[s[1]] != s[0]:
423
+ o = _model.objects.get(id=s[1])
424
+ o.order = s[0]
425
+ o.save()
426
+ return self.command_response('')
427
+
428
+ def post_save(self, created, form):
429
+ if created:
430
+ self.modal_redirect(self.request.resolver_match.view_name, slug=f'pk-{self.object.id}-new-True')
431
+ else:
432
+ url_name = getattr(settings, 'REPORT_BUILDER_DETAIL_URL_NAME', '')
433
+ if url_name and self.slug.get('new'):
434
+ url = reverse(url_name, kwargs={'slug': self.object.slug})
435
+ self.command_response('redirect', url=url)
436
+
437
+
438
+ class CalendarDataSetForm(QueryBuilderModelForm):
439
+ cancel_class = 'btn-secondary modal-cancel'
440
+
441
+ class DurationWidget(NumberInput):
442
+ crispy_kwargs = {'appended_text': 'Seconds', 'input_size': 'input-group-sm'}
443
+
444
+ def clean(self):
445
+ cleaned_data = super().clean()
446
+ start_date_field = cleaned_data['start_date_field']
447
+ if start_date_field is None:
448
+ self.add_error('start_date_field', 'Please select a start period')
449
+ end_date_type = cleaned_data['end_date_type']
450
+ if end_date_type == CalendarReportDataSet.END_DATE_TYPE_FIELD and cleaned_data['end_date_field'] is None:
451
+ self.add_error('end_date_field', 'Please select a end period')
452
+ elif (
453
+ end_date_type == CalendarReportDataSet.END_DATE_TYPE_DURATION_FIELD
454
+ and cleaned_data['end_duration_field'] is None
455
+ ):
456
+ self.add_error('end_duration_field', 'Please select a end period')
457
+ elif end_date_type == CalendarReportDataSet.END_DATE_TYPE_DURATION_FIXED and (
458
+ cleaned_data['end_duration'] is None or cleaned_data['end_duration'] == ''
459
+ ):
460
+ self.add_error('end_duration', 'Please select a end period')
461
+ return cleaned_data
462
+
463
+ class Meta:
464
+ model = CalendarReportDataSet
465
+ fields = [
466
+ 'name',
467
+ 'report_type',
468
+ 'display_type',
469
+ 'heading_field',
470
+ 'calendar_report_description',
471
+ 'background_colour_field',
472
+ 'link_field',
473
+ 'start_date_field',
474
+ 'end_date_type',
475
+ 'end_date_field',
476
+ 'end_duration_field',
477
+ 'end_duration',
478
+ 'query_data',
479
+ ]
480
+ widgets = {
481
+ 'display_type': Select2,
482
+ 'end_date_type': Select2,
483
+ }
484
+
485
+ end_duration = IntegerField(widget=DurationWidget, required=False)
486
+
487
+
488
+ class CalendarDataSetModal(QueryBuilderModalBase):
489
+ template_name = 'advanced_report_builder/calendar/modal.html'
490
+ size = 'xl'
491
+ process = PROCESS_EDIT_DELETE
492
+ permission_delete = PERMISSION_OFF
493
+ model = CalendarReportDataSet
494
+ helper_class = HorizontalNoEnterHelper
495
+ form_class = CalendarDataSetForm
496
+
497
+ def form_setup(self, form, *_args, **_kwargs):
498
+ if 'data' in _kwargs:
499
+ heading_field = _kwargs['data'].get('heading_field')
500
+ start_date_field = _kwargs['data'].get('start_date_field')
501
+ end_date_field = _kwargs['data'].get('end_date_field')
502
+ end_duration_field = _kwargs['data'].get('end_duration_field')
503
+ report_type_id = _kwargs['data'].get('report_type')
504
+ background_colour_field = _kwargs['data'].get('background_colour_field')
505
+ link_field = _kwargs['data'].get('link_field')
506
+ calendar_report_description = CalendarReportDescription.objects.filter(
507
+ pk=_kwargs['data'].get('calendar_report_description')
508
+ ).first()
509
+ report_type = get_object_or_404(ReportType, id=report_type_id)
510
+
511
+ else:
512
+ heading_field = form.instance.heading_field
513
+ report_type = form.instance.report_type
514
+ start_date_field = form.instance.start_date_field
515
+ end_date_field = form.instance.end_date_field
516
+ end_duration_field = form.instance.end_duration_field
517
+ background_colour_field = form.instance.background_colour_field
518
+ link_field = form.instance.link_field
519
+ calendar_report_description = form.instance.calendar_report_description
520
+
521
+ form.fields['calendar_report_description'].widget = Select2(attrs={'ajax': True})
522
+ if calendar_report_description is not None:
523
+ form.fields['calendar_report_description'].widget.select_data = [
524
+ {'id': calendar_report_description.id, 'text': calendar_report_description.name}
525
+ ]
526
+ form.fields['calendar_report_description'].label = 'Description'
527
+ form.fields['calendar_report_description'].required = False
528
+
529
+ form.fields['report_type'] = ModelChoiceField(queryset=ReportType.objects.all(), widget=Select2, required=False)
530
+
531
+ form.add_trigger(
532
+ 'display_type',
533
+ 'onchange',
534
+ [
535
+ {
536
+ 'selector': '#div_id_calendar_report_description',
537
+ 'values': {CalendarReportDataSet.DISPLAY_TYPE_HEADING_ONLY: 'hide'},
538
+ 'default': 'show',
539
+ },
540
+ {
541
+ 'selector': '#div_id_heading_field',
542
+ 'values': {CalendarReportDataSet.DISPLAY_TYPE_DESCRIPTION_ONLY: 'hide'},
543
+ 'default': 'show',
544
+ },
545
+ ],
546
+ )
547
+ form.add_trigger(
548
+ 'end_date_type',
549
+ 'onchange',
550
+ [
551
+ {
552
+ 'selector': '#div_id_end_date_field',
553
+ 'values': {CalendarReportDataSet.END_DATE_TYPE_FIELD: 'show'},
554
+ 'default': 'hide',
555
+ },
556
+ {
557
+ 'selector': '#div_id_end_duration_field',
558
+ 'values': {CalendarReportDataSet.END_DATE_TYPE_DURATION_FIELD: 'show'},
559
+ 'default': 'hide',
560
+ },
561
+ {
562
+ 'selector': '#div_id_end_duration',
563
+ 'values': {CalendarReportDataSet.END_DATE_TYPE_DURATION_FIXED: 'show'},
564
+ 'default': 'hide',
565
+ },
566
+ ],
567
+ )
568
+ self.setup_field(
569
+ field_type='all',
570
+ form=form,
571
+ field_name='heading_field',
572
+ selected_field_id=heading_field,
573
+ report_type=report_type,
574
+ )
575
+
576
+ self.setup_field(
577
+ field_type='date',
578
+ form=form,
579
+ field_name='start_date_field',
580
+ selected_field_id=start_date_field,
581
+ report_type=report_type,
582
+ )
583
+
584
+ self.setup_field(
585
+ field_type='date',
586
+ form=form,
587
+ field_name='end_date_field',
588
+ selected_field_id=end_date_field,
589
+ report_type=report_type,
590
+ )
591
+
592
+ self.setup_field(
593
+ field_type='number',
594
+ form=form,
595
+ field_name='end_duration_field',
596
+ selected_field_id=end_duration_field,
597
+ report_type=report_type,
598
+ )
599
+
600
+ self.setup_field(
601
+ field_type='colour',
602
+ form=form,
603
+ field_name='background_colour_field',
604
+ selected_field_id=background_colour_field,
605
+ report_type=report_type,
606
+ )
607
+
608
+ self.setup_field(
609
+ field_type='link', form=form, field_name='link_field', selected_field_id=link_field, report_type=report_type
610
+ )
611
+
612
+ return (
613
+ 'name',
614
+ 'report_type',
615
+ 'display_type',
616
+ 'heading_field',
617
+ 'calendar_report_description',
618
+ 'start_date_field',
619
+ 'end_date_type',
620
+ 'end_date_field',
621
+ 'end_duration_field',
622
+ 'end_duration',
623
+ 'background_colour_field',
624
+ 'link_field',
625
+ FieldEx('query_data', template='advanced_report_builder/query_builder.html'),
626
+ )
627
+
628
+ def select2_heading_field(self, **kwargs):
629
+ return self.get_fields_for_select2(
630
+ field_type='all', report_type=kwargs['report_type'], search_string=kwargs.get('search')
631
+ )
632
+
633
+ def select2_order_by_field(self, **kwargs):
634
+ return self.get_fields_for_select2(
635
+ field_type='django_order', report_type=kwargs['report_type'], search_string=kwargs.get('search')
636
+ )
637
+
638
+ def select2_start_date_field(self, **kwargs):
639
+ return self.get_fields_for_select2(
640
+ field_type='date', report_type=kwargs['report_type'], search_string=kwargs.get('search')
641
+ )
642
+
643
+ def select2_end_date_field(self, **kwargs):
644
+ return self.get_fields_for_select2(
645
+ field_type='date', report_type=kwargs['report_type'], search_string=kwargs.get('search')
646
+ )
647
+
648
+ def select2_end_duration_field(self, **kwargs):
649
+ return self.get_fields_for_select2(
650
+ field_type='number', report_type=kwargs['report_type'], search_string=kwargs.get('search')
651
+ )
652
+
653
+ def select2_link_field(self, **kwargs):
654
+ return self.get_fields_for_select2(
655
+ field_type='link', report_type=kwargs['report_type'], search_string=kwargs.get('search')
656
+ )
657
+
658
+ def select2_background_colour_field(self, **kwargs):
659
+ return self.get_fields_for_select2(
660
+ field_type='colour', report_type=kwargs['report_type'], search_string=kwargs.get('search')
661
+ )
662
+
663
+ def select2_calendar_report_description(self, **kwargs):
664
+ descriptions = []
665
+ report_type_id = kwargs['report_type']
666
+ if report_type_id != '':
667
+ calendar_report_id = self.object.calendar_report_id
668
+ _filter = CalendarReportDescription.objects.filter(
669
+ report_type_id=report_type_id, calendar_report_id=calendar_report_id
670
+ )
671
+ search = kwargs.get('search')
672
+ if search:
673
+ _filter = _filter.filter(name__icontains=search)
674
+ for description in _filter.values('id', 'name'):
675
+ descriptions.append({'id': description['id'], 'text': description['name']})
676
+
677
+ return JsonResponse({'results': descriptions})
678
+
679
+ def form_valid(self, form):
680
+ form.save()
681
+ return self.command_response('reload')
682
+
683
+
684
+ class CalendarDataSetDuplicateModal(Modal):
685
+ def modal_content(self):
686
+ return 'Are you sure you want to duplicate this lane?'
687
+
688
+ def get_modal_buttons(self):
689
+ return [modal_button_method('Confirm', 'duplicate'), modal_button('Cancel', 'close', 'btn-secondary')]
690
+
691
+ def button_duplicate(self, **_kwargs):
692
+ calendar_report_data_set = get_object_or_404(CalendarReportDataSet, id=self.slug['pk'])
693
+ calendar_report_data_set.pk = None
694
+ calendar_report_data_set.name = f'Copy of {calendar_report_data_set.name}'
695
+ calendar_report_data_set.order = None
696
+ calendar_report_data_set.save()
697
+ return self.command_response('reload')
698
+
699
+
700
+ class CalendarDescriptionModal(DataMergeUtils, QueryBuilderModalBase):
701
+ template_name = 'advanced_report_builder/calendar/description_modal.html'
702
+ size = 'xl'
703
+ process = PROCESS_EDIT_DELETE
704
+ permission_delete = PERMISSION_OFF
705
+ model = CalendarReportDescription
706
+
707
+ widgets = {'report_tags': Select2Multiple}
708
+
709
+ form_fields = ['name', 'report_type', 'description']
710
+
711
+ def form_setup(self, form, *_args, **_kwargs):
712
+ form.fields['description'].widget = DataMergeWidget()
713
+
714
+ return ('name', 'report_type', 'description')
715
+
716
+ def ajax_get_description_data_merge_menu(self, **kwargs):
717
+ field_auto_id = kwargs['field_auto_id']
718
+ menus = []
719
+ if kwargs['report_type'] != '':
720
+ report_builder_class, base_model = self.get_report_builder_class(report_type_id=kwargs['report_type'])
721
+
722
+ self.get_menu_fields(base_model=base_model, report_builder_class=report_builder_class, menus=menus)
723
+
724
+ menus = [{'code': 'data_merge', 'text': 'Data Merge', 'menu': menus}]
725
+
726
+ return self.command_response(f'build_data_merge_menu_{field_auto_id}', data=json.dumps(menus))
727
+
728
+ def form_valid(self, form):
729
+ form.save()
730
+ return self.command_response('reload')
731
+
732
+
733
+ class CalendarDescriptionDuplicateModal(Modal):
734
+ def modal_content(self):
735
+ return 'Are you sure you want to duplicate this description?'
736
+
737
+ def get_modal_buttons(self):
738
+ return [modal_button_method('Confirm', 'duplicate'), modal_button('Cancel', 'close', 'btn-secondary')]
739
+
740
+ def button_duplicate(self, **_kwargs):
741
+ calendar_report_description = get_object_or_404(CalendarReportDescription, id=self.slug['pk'])
742
+ calendar_report_description.pk = None
743
+ calendar_report_description.name = f'Copy of {calendar_report_description.name}'
744
+ calendar_report_description.save()
745
+ return self.command_response('reload')