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,415 @@
1
+ import base64
2
+ import json
3
+ from datetime import datetime
4
+
5
+ from crispy_forms.layout import Div
6
+ from date_offset.date_offset import DateOffset
7
+ from django.forms import BooleanField, CharField, ChoiceField
8
+ from django.shortcuts import get_object_or_404
9
+ from django.urls import reverse
10
+ from django_menus.menu import MenuItem
11
+ from django_modals.fields import FieldEx
12
+ from django_modals.form_helpers import HorizontalNoEnterHelper
13
+ from django_modals.modals import FormModal
14
+ from django_modals.processes import PERMISSION_OFF, PROCESS_EDIT_DELETE
15
+ from django_modals.widgets.colour_picker import ColourPickerWidget
16
+ from django_modals.widgets.select2 import Select2Multiple
17
+
18
+ from advanced_report_builder.exceptions import ReportError
19
+ from advanced_report_builder.globals import (
20
+ ANNOTATION_VALUE_DAY,
21
+ ANNOTATION_VALUE_MONTH,
22
+ ANNOTATION_VALUE_QUARTER,
23
+ ANNOTATION_VALUE_WEEK,
24
+ ANNOTATION_VALUE_YEAR,
25
+ )
26
+ from advanced_report_builder.models import LineChartReport, ReportType
27
+ from advanced_report_builder.toggle import RBToggle
28
+ from advanced_report_builder.utils import (
29
+ decode_attribute,
30
+ encode_attribute,
31
+ get_report_builder_class,
32
+ split_attr,
33
+ )
34
+ from advanced_report_builder.views.charts_base import (
35
+ ChartBaseFieldForm,
36
+ ChartBaseView,
37
+ ChartJSTable,
38
+ )
39
+ from advanced_report_builder.views.modals_base import (
40
+ QueryBuilderModalBase,
41
+ QueryBuilderModalBaseMixin,
42
+ )
43
+ from advanced_report_builder.views.query_modal.mixin import MultiQueryModalMixin
44
+
45
+
46
+ class LineChartJSTable(ChartJSTable):
47
+ def get_table_array(self, request, results):
48
+ results = super().get_table_array(request, results)
49
+ if len(results) == 0:
50
+ return results
51
+
52
+ date_offset = DateOffset()
53
+ record_count = len(results[0]) - 1
54
+ try:
55
+ next_date = datetime.strptime(results[0][0], '%Y-%m-%d').date()
56
+ except ValueError as e:
57
+ raise ReportError(e)
58
+
59
+ new_results = []
60
+ for record in results:
61
+ if record[0] == '' or record[0] is None:
62
+ continue
63
+ current_date = datetime.strptime(record[0], '%Y-%m-%d').date()
64
+ if current_date != next_date:
65
+ while next_date < current_date:
66
+ row = [next_date.strftime('%Y-%m-%d')] + ['0' for _ in range(record_count)]
67
+ new_results.append(row)
68
+ next_date = self.get_next_date(date_offset, date_in=next_date)
69
+
70
+ row = [record[0]]
71
+ for x in record[1:]:
72
+ if x == '':
73
+ row.append('')
74
+ else:
75
+ row.append(x)
76
+ new_results.append(row)
77
+ next_date = self.get_next_date(date_offset, date_in=next_date)
78
+
79
+ return new_results
80
+
81
+ def get_next_date(self, date_offset, date_in):
82
+ if self.axis_scale == ANNOTATION_VALUE_YEAR:
83
+ next_date = date_offset.get_offset('1y', start_date_time=date_in)
84
+ elif self.axis_scale == ANNOTATION_VALUE_QUARTER:
85
+ next_date = date_offset.get_offset('3m', start_date_time=date_in)
86
+ elif self.axis_scale == ANNOTATION_VALUE_MONTH:
87
+ next_date = date_offset.get_offset('1m', start_date_time=date_in)
88
+ elif self.axis_scale == ANNOTATION_VALUE_WEEK:
89
+ next_date = date_offset.get_offset('1w', start_date_time=date_in)
90
+ elif self.axis_scale == ANNOTATION_VALUE_DAY:
91
+ next_date = date_offset.get_offset('1d', start_date_time=date_in)
92
+ else:
93
+ raise AssertionError()
94
+ return next_date
95
+
96
+
97
+ class LineChartView(ChartBaseView):
98
+ chart_js_table = LineChartJSTable
99
+
100
+ def dispatch(self, request, *args, **kwargs):
101
+ self.report = kwargs.get('report')
102
+ self.chart_report = self.report.linechartreport
103
+ return super().dispatch(request, *args, **kwargs)
104
+
105
+ def get_context_data(self, **kwargs):
106
+ context = super().get_context_data(**kwargs)
107
+ self.table.line_chart_report = self.chart_report
108
+ self.table.datatable_template = self.get_report_template()
109
+ context['line_chart_report'] = self.chart_report
110
+ return context
111
+
112
+ def set_extra_number_field_kwargs(self, data_attr, options, multiple_index, additional_options):
113
+ line_colour = None
114
+ if additional_options is not None:
115
+ line_colour = additional_options.get('positive_colour')
116
+ if line_colour is None or line_colour == '':
117
+ line_colour = data_attr.get('line_colour') or '801C70'
118
+ line_colour = self.add_colour_offset(line_colour, multiple_index=multiple_index)
119
+ options.update({'colour': line_colour})
120
+
121
+ def edit_report_menu(self, request, chart_report_id, slug_str):
122
+ return [
123
+ MenuItem(
124
+ f'advanced_report_builder:line_chart_modal,pk-{chart_report_id}{slug_str}',
125
+ menu_display='Edit',
126
+ font_awesome='fas fa-pencil-alt',
127
+ css_classes=['btn-primary'],
128
+ ),
129
+ *self.duplicate_menu(request=request, report_id=chart_report_id),
130
+ ]
131
+
132
+ def setup_table(self, base_model):
133
+ axis_scale = self.chart_report.axis_scale
134
+ targets = None
135
+
136
+ if getattr(self.chart_report, 'has_targets', False):
137
+ targets = self.chart_report.targets
138
+ self.table = self.chart_js_table(model=base_model, axis_scale=axis_scale, targets=targets)
139
+
140
+
141
+ class LineChartModal(MultiQueryModalMixin, QueryBuilderModalBase):
142
+ template_name = 'advanced_report_builder/charts/modal.html'
143
+ process = PROCESS_EDIT_DELETE
144
+ permission_delete = PERMISSION_OFF
145
+ model = LineChartReport
146
+ show_order_by = False
147
+
148
+ widgets = {
149
+ 'line_colour': ColourPickerWidget,
150
+ 'show_totals': RBToggle,
151
+ 'has_targets': RBToggle,
152
+ 'report_tags': Select2Multiple,
153
+ 'targets': Select2Multiple,
154
+ }
155
+
156
+ form_fields = [
157
+ 'name',
158
+ 'notes',
159
+ 'report_type',
160
+ 'report_tags',
161
+ 'axis_value_type',
162
+ 'axis_scale',
163
+ 'date_field',
164
+ 'fields',
165
+ 'x_label',
166
+ 'y_label',
167
+ 'show_totals',
168
+ 'has_targets',
169
+ 'targets',
170
+ ]
171
+
172
+ def form_setup(self, form, *_args, **_kwargs):
173
+ form.add_trigger(
174
+ 'has_targets',
175
+ 'onchange',
176
+ [
177
+ {
178
+ 'selector': '#div_id_targets',
179
+ 'values': {'checked': 'show'},
180
+ 'default': 'hide',
181
+ },
182
+ ],
183
+ )
184
+
185
+ if 'data' in _kwargs and len(_kwargs['data']) > 0:
186
+ date_field = _kwargs['data'].get('date_field')
187
+ report_type_id = _kwargs['data'].get('report_type')
188
+ report_type = get_object_or_404(ReportType, id=report_type_id)
189
+ else:
190
+ date_field = form.instance.date_field
191
+ report_type = form.instance.report_type
192
+
193
+ self.setup_field(
194
+ field_type='date',
195
+ form=form,
196
+ field_name='date_field',
197
+ selected_field_id=date_field,
198
+ report_type=report_type,
199
+ )
200
+
201
+ form.fields['notes'].widget.attrs['rows'] = 3
202
+
203
+ url = reverse(
204
+ 'advanced_report_builder:line_chart_field_modal',
205
+ kwargs={'slug': 'selector-99999-data-FIELD_INFO-report_type_id-REPORT_TYPE_ID'},
206
+ )
207
+
208
+ fields = [
209
+ 'name',
210
+ 'notes',
211
+ 'report_type',
212
+ 'report_tags',
213
+ 'axis_scale',
214
+ 'axis_value_type',
215
+ 'date_field',
216
+ FieldEx(
217
+ 'fields',
218
+ template='advanced_report_builder/select_column.html',
219
+ extra_context={'select_column_url': url, 'command_prefix': ''},
220
+ ),
221
+ 'x_label',
222
+ 'y_label',
223
+ 'show_totals',
224
+ 'has_targets',
225
+ 'targets',
226
+ ]
227
+ if self.object.id:
228
+ self.add_extra_queries(form=form, fields=fields)
229
+ return fields
230
+
231
+ def select2_date_field(self, **kwargs):
232
+ return self.get_fields_for_select2(
233
+ field_type='date',
234
+ report_type=kwargs['report_type'],
235
+ search_string=kwargs.get('search'),
236
+ )
237
+
238
+
239
+ class LineChartFieldForm(ChartBaseFieldForm):
240
+ def setup_modal(self, *args, **kwargs):
241
+ data = json.loads(base64.b64decode(self.slug['data']))
242
+ report_type, base_model = self.get_report_type_details()
243
+
244
+ data_attr = split_attr(data)
245
+
246
+ self.fields['title'] = CharField(initial=data['title'])
247
+
248
+ self.fields['line_colour'] = CharField(required=False, widget=ColourPickerWidget)
249
+ self.fields['line_colour'].initial = data_attr.get('line_colour')
250
+
251
+ self.fields['has_filter'] = BooleanField(required=False, widget=RBToggle())
252
+ self.fields['filter'] = CharField(required=False)
253
+ if data_attr.get('has_filter') == '1':
254
+ self.fields['has_filter'].initial = True
255
+ if 'filter' in data_attr:
256
+ self.fields['filter'].initial = decode_attribute(data_attr['filter'])
257
+
258
+ self.fields['multiple_columns'] = BooleanField(required=False, widget=RBToggle())
259
+ self.fields['append_column_title'] = BooleanField(required=False, widget=RBToggle())
260
+ report_builder_class = get_report_builder_class(model=base_model, report_type=report_type)
261
+
262
+ self.setup_colour_field(
263
+ form_fields=self.fields,
264
+ base_model=base_model,
265
+ report_builder_class=report_builder_class,
266
+ name='positive_colour_field',
267
+ data_attr=data_attr,
268
+ label='Line colour field',
269
+ )
270
+ multiple_column_field = []
271
+ self._get_query_builder_foreign_key_fields(
272
+ base_model=base_model,
273
+ report_builder_class=report_builder_class,
274
+ fields=multiple_column_field,
275
+ )
276
+
277
+ self.fields['multiple_column_field'] = ChoiceField(choices=multiple_column_field, required=False)
278
+
279
+ if data_attr.get('multiple_columns') == '1':
280
+ self.fields['multiple_columns'].initial = True
281
+ self.fields['multiple_column_field'].initial = data_attr.get('multiple_column_field')
282
+
283
+ if data_attr.get('append_column_title') == '1':
284
+ self.fields['append_column_title'].initial = True
285
+
286
+ super().setup_modal(*args, **kwargs)
287
+
288
+ def get_additional_attributes(self):
289
+ attributes = []
290
+ self.get_report_type_details()
291
+
292
+ attributes.append(f'line_colour-{self.cleaned_data["line_colour"]}')
293
+
294
+ if self.cleaned_data['has_filter']:
295
+ attributes.append('has_filter-1')
296
+
297
+ if self.cleaned_data['filter']:
298
+ b64_filter = encode_attribute(self.cleaned_data['filter'])
299
+ attributes.append(f'filter-{b64_filter}')
300
+ if self.cleaned_data['multiple_columns']:
301
+ attributes.append('multiple_columns-1')
302
+ if self.cleaned_data['positive_colour_field']:
303
+ attributes.append(f'positive_colour_field-{self.cleaned_data["positive_colour_field"]}')
304
+ attributes.append(f'multiple_column_field-{self.cleaned_data["multiple_column_field"]}')
305
+ if self.cleaned_data['append_column_title']:
306
+ attributes.append('append_column_title-1')
307
+
308
+ if attributes:
309
+ return '-'.join(attributes)
310
+ return None
311
+
312
+
313
+ class LineChartFieldModal(QueryBuilderModalBaseMixin, FormModal):
314
+ form_class = LineChartFieldForm
315
+ size = 'xl'
316
+ template_name = 'advanced_report_builder/charts/modal_field.html'
317
+ no_header_x = True
318
+ helper_class = HorizontalNoEnterHelper
319
+
320
+ @property
321
+ def modal_title(self):
322
+ data = json.loads(base64.b64decode(self.slug['data']))
323
+ return f'Edit {data["title"]}'
324
+
325
+ def form_valid(self, form):
326
+ selector = self.slug['selector']
327
+
328
+ _attr = form.get_additional_attributes()
329
+ self.add_command(
330
+ {
331
+ 'function': 'set_attr',
332
+ 'selector': f'#{selector}',
333
+ 'attr': 'data-attr',
334
+ 'val': _attr,
335
+ }
336
+ )
337
+
338
+ self.add_command(
339
+ {
340
+ 'function': 'html',
341
+ 'selector': f'#{selector} span',
342
+ 'html': form.cleaned_data['title'],
343
+ }
344
+ )
345
+ self.add_command({'function': 'update_selection'})
346
+ return self.command_response('close')
347
+
348
+ # noinspection PyMethodMayBeStatic
349
+ def form_setup(self, form, *_args, **_kwargs):
350
+ form.add_trigger(
351
+ 'has_filter',
352
+ 'onchange',
353
+ [
354
+ {
355
+ 'selector': '#filter_fields_div',
356
+ 'values': {'checked': 'show'},
357
+ 'default': 'hide',
358
+ }
359
+ ],
360
+ )
361
+
362
+ form.add_trigger(
363
+ 'multiple_columns',
364
+ 'onchange',
365
+ [
366
+ {
367
+ 'selector': '#multiple_columns_fields_div',
368
+ 'values': {'checked': 'show'},
369
+ 'default': 'hide',
370
+ },
371
+ ],
372
+ )
373
+
374
+ return [
375
+ 'title',
376
+ 'line_colour',
377
+ Div(
378
+ FieldEx(
379
+ 'has_filter',
380
+ template='django_modals/fields/label_checkbox.html',
381
+ field_class='col-6 input-group-sm',
382
+ ),
383
+ Div(
384
+ FieldEx(
385
+ 'filter',
386
+ template='advanced_report_builder/datatables/fields/single_query_builder.html',
387
+ ),
388
+ FieldEx(
389
+ 'multiple_columns',
390
+ template='django_modals/fields/label_checkbox.html',
391
+ field_class='col-6 input-group-sm',
392
+ ),
393
+ Div(
394
+ FieldEx(
395
+ 'append_column_title',
396
+ template='django_modals/fields/label_checkbox.html',
397
+ field_class='col-6 input-group-sm',
398
+ ),
399
+ FieldEx('multiple_column_field'),
400
+ FieldEx('positive_colour_field'),
401
+ css_id='multiple_columns_fields_div',
402
+ ),
403
+ css_id='filter_fields_div',
404
+ ),
405
+ css_id='annotations_fields_div',
406
+ ),
407
+ ]
408
+
409
+ def ajax_get_query_builder_fields(self, **kwargs):
410
+ field_auto_id = kwargs['field_auto_id']
411
+
412
+ report_type_id = self.slug['report_type_id']
413
+ query_builder_filters = self.get_query_builder_report_type_field(report_type_id=report_type_id)
414
+
415
+ return self.command_response(f'query_builder_{field_auto_id}', data=json.dumps(query_builder_filters))
@@ -0,0 +1,213 @@
1
+ import json
2
+
3
+ from django.conf import settings
4
+ from django.forms import JSONField
5
+ from django.http import JsonResponse
6
+ from django.shortcuts import get_object_or_404
7
+ from django.urls import reverse
8
+ from django_modals.modals import ModelFormModal
9
+ from django_modals.widgets.select2 import Select2
10
+
11
+ from advanced_report_builder.column_types import NUMBER_FIELDS
12
+ from advanced_report_builder.field_types import FieldTypes
13
+ from advanced_report_builder.field_utils import ReportBuilderFieldUtils
14
+ from advanced_report_builder.globals import FieldType
15
+ from advanced_report_builder.models import ReportQuery, ReportType
16
+ from advanced_report_builder.utils import get_report_builder_class
17
+
18
+
19
+ class QueryBuilderModalBaseMixin(ReportBuilderFieldUtils):
20
+ @staticmethod
21
+ def get_report_builder_class(report_type_id):
22
+ if not report_type_id:
23
+ return None, None
24
+
25
+ report_type = get_object_or_404(ReportType, pk=report_type_id)
26
+ base_model = report_type.content_type.model_class()
27
+ report_builder_class = get_report_builder_class(model=base_model, report_type=report_type)
28
+ return report_builder_class, base_model
29
+
30
+ def get_query_builder_report_type_field(self, report_type_id):
31
+ report_builder_class, base_model = self.get_report_builder_class(report_type_id=report_type_id)
32
+ if report_builder_class is None:
33
+ # noinspection PyUnresolvedReferences
34
+ return self.command_response()
35
+ query_builder_filters = []
36
+ self._get_query_builder_fields(
37
+ base_model=base_model,
38
+ query_builder_filters=query_builder_filters,
39
+ report_builder_class=report_builder_class,
40
+ )
41
+
42
+ return query_builder_filters
43
+
44
+ def _get_query_builder_fields(
45
+ self,
46
+ base_model,
47
+ query_builder_filters,
48
+ report_builder_class,
49
+ ):
50
+ field_types = FieldTypes()
51
+ field_results = []
52
+ field_results_types = {
53
+ FieldType.NULL_FIELD: {},
54
+ FieldType.ABSTRACT_USER: {},
55
+ FieldType.FILTER_FOREIGN_KEY: {},
56
+ FieldType.STRING: {},
57
+ FieldType.NUMBER: {},
58
+ FieldType.BOOLEAN: {},
59
+ FieldType.DATE: {},
60
+ FieldType.MANY_TO_MANY: {},
61
+ }
62
+ field_types.get_field_types(
63
+ field_results=field_results,
64
+ field_results_types=field_results_types,
65
+ base_model=base_model,
66
+ report_builder_class=report_builder_class,
67
+ )
68
+
69
+ field_types.get_filters(
70
+ fields=field_results, query_builder_filters=query_builder_filters, field_results_types=field_results_types
71
+ )
72
+
73
+ def ajax_get_fields(self, **kwargs):
74
+ report_type_id = kwargs['report_type']
75
+ report_builder_class, base_model = self.get_report_builder_class(report_type_id=report_type_id)
76
+ fields = []
77
+ tables = []
78
+ self._get_fields(
79
+ base_model=base_model,
80
+ fields=fields,
81
+ tables=tables,
82
+ report_builder_class=report_builder_class,
83
+ field_types=NUMBER_FIELDS,
84
+ extra_fields=report_builder_class.extra_chart_field,
85
+ )
86
+ return self.command_response('report_fields', data=json.dumps({'fields': fields, 'tables': tables}))
87
+
88
+ def get_fields_for_select2(self, field_type, report_type, search_string):
89
+ fields = []
90
+ if report_type != '':
91
+ report_builder_fields, base_model = self.get_report_builder_class(report_type_id=report_type)
92
+ fields = []
93
+ if field_type == 'date':
94
+ self._get_date_fields(
95
+ base_model=base_model,
96
+ fields=fields,
97
+ report_builder_class=report_builder_fields,
98
+ search_string=search_string,
99
+ )
100
+ elif field_type == 'number':
101
+ self._get_number_fields(
102
+ base_model=base_model,
103
+ fields=fields,
104
+ report_builder_class=report_builder_fields,
105
+ search_string=search_string,
106
+ )
107
+ elif field_type == 'link':
108
+ self._get_column_link_fields(
109
+ base_model=base_model,
110
+ fields=fields,
111
+ report_builder_class=report_builder_fields,
112
+ search_string=search_string,
113
+ )
114
+ elif field_type == 'colour':
115
+ self._get_colour_fields(
116
+ base_model=base_model,
117
+ fields=fields,
118
+ report_builder_class=report_builder_fields,
119
+ search_string=search_string,
120
+ )
121
+ elif field_type == 'all':
122
+ self._get_fields(
123
+ base_model=base_model,
124
+ fields=fields,
125
+ report_builder_class=report_builder_fields,
126
+ for_select2=True,
127
+ search_string=search_string,
128
+ )
129
+ elif field_type in ('order', 'django_order'):
130
+ self._get_fields(
131
+ base_model=base_model,
132
+ fields=fields,
133
+ report_builder_class=report_builder_fields,
134
+ for_select2=True,
135
+ search_string=search_string,
136
+ show_order_by_fields=True,
137
+ must_have_django_field=field_type == 'django_order',
138
+ )
139
+ elif field_type == 'include_names':
140
+ self._get_include_names(
141
+ base_model=base_model,
142
+ fields=fields,
143
+ report_builder_class=report_builder_fields,
144
+ search_string=search_string,
145
+ )
146
+
147
+ return JsonResponse({'results': fields})
148
+
149
+ def setup_field(self, field_type, form, field_name, selected_field_id, report_type):
150
+ _fields = []
151
+ if selected_field_id:
152
+ form.fields[field_name].initial = selected_field_id
153
+ base_model = report_type.content_type.model_class()
154
+ report_builder_class = get_report_builder_class(model=base_model, report_type=report_type)
155
+ self.get_field_display_value(
156
+ field_type=field_type,
157
+ fields_values=_fields,
158
+ base_model=base_model,
159
+ report_builder_class=report_builder_class,
160
+ selected_field_value=selected_field_id,
161
+ for_select2=True,
162
+ )
163
+
164
+ form.fields[field_name].widget = Select2(attrs={'ajax': True})
165
+ form.fields[field_name].widget.select_data = _fields
166
+
167
+
168
+ class QueryBuilderModalBase(QueryBuilderModalBaseMixin, ModelFormModal):
169
+ size = 'xl'
170
+
171
+ def __init__(self, *args, **kwargs):
172
+ self.report_query = None
173
+ self.show_query_name = False
174
+ super().__init__(*args, **kwargs)
175
+
176
+ def ajax_get_query_builder_fields(self, **kwargs):
177
+ report_type_id = kwargs['report_type']
178
+
179
+ field_auto_id = kwargs['field_auto_id']
180
+ if report_type_id:
181
+ query_builder_filters = self.get_query_builder_report_type_field(report_type_id=report_type_id)
182
+
183
+ return self.command_response(f'query_builder_{field_auto_id}', data=json.dumps(query_builder_filters))
184
+ else:
185
+ return self.command_response()
186
+
187
+ def add_query_data(self, form):
188
+ form.fields['extra_query_data'] = JSONField(required=False, label='Numerator filter')
189
+ if self.object.id:
190
+ query_id = self.slug.get('query_id')
191
+ if query_id:
192
+ self.report_query = get_object_or_404(ReportQuery, id=query_id)
193
+ else:
194
+ self.report_query = self.object.reportquery_set.first()
195
+ if self.report_query:
196
+ form.fields['extra_query_data'].initial = self.report_query.extra_query
197
+
198
+ def form_valid(self, form):
199
+ org_id = self.object.id if hasattr(self, 'object') else None
200
+ chart_report = form.save(commit=False)
201
+ chart_report._current_user = self.request.user
202
+ chart_report.save()
203
+ form.save_m2m()
204
+
205
+ self.post_save(created=org_id is None, form=form)
206
+ if not self.response_commands:
207
+ url_name = getattr(settings, 'REPORT_BUILDER_DETAIL_URL_NAME', '')
208
+ if org_id is None and url_name:
209
+ url = reverse(url_name, kwargs={'slug': chart_report.slug})
210
+ self.add_command('redirect', url=url)
211
+ else:
212
+ self.add_command('reload')
213
+ return self.command_response()