WindykacjaUpdateStatus.php 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  1. <?php
  2. Lib::loadClass('RouteBase');
  3. Lib::loadClass('FeatureAttrSelected');
  4. Lib::loadClass('Response');
  5. Lib::loadClass('Windykacja_StatsModel');
  6. Lib::loadClass('Windykacja_StatsHelper');
  7. // Tool with Lock actions on primary key
  8. class Route_UrlAction_WindykacjaUpdateStatus extends RouteBase {
  9. function defaultAction() {
  10. $postTask = V::get('_postTask', '', $_POST);
  11. switch ($postTask) { // PostTask outputs html; TODO: move to WPS functions
  12. case 'updateSelected': return $this->updateSelectedPostTask();
  13. case 'updateAll': return $this->updateAllPostTask();
  14. }
  15. UI::layout([ $this, 'defaultView' ]);
  16. }
  17. function viewTop() {
  18. echo UI::h('h3', [], "Aktualizacja statusu windykacji klientów");
  19. }
  20. function defaultView() {
  21. $totalSelected = FeatureAttrSelected::getTotalSelected($typeName = "default_db/USERS2_WINDYKACJA_STATUS");
  22. $totalClients = (int)DB::getPDO()->fetchValue("
  23. select count(*) as total
  24. from USERS2_WINDYKACJA_STATUS t
  25. ");
  26. $totalToUpdateClients = (int)DB::getPDO()->fetchValue("
  27. select count(*) as total
  28. from USERS2_WINDYKACJA_STATUS t
  29. where t.A_STATUS_UPDATE_DATE < :today
  30. ", [
  31. ':today' => date("Y-m-d"),
  32. ]);
  33. // UI::h('div', [ 'class' => "alert alert-success" ], "Wszystkie wybrane rekordy są aktualne");
  34. $this->viewTop();
  35. echo UI::h('div', [ 'style' => "font-size:14px" ], [
  36. ($totalSelected)
  37. ? UI::h('div', [ 'style' => "margin: 32px 0" ], [
  38. UI::h('p', [], "Wybrano <b>{$totalSelected}</b> rekordów"),
  39. UI::hButtonPost("aktualizuj", [
  40. 'class' => "btn-primary",
  41. 'data' => [
  42. '_route' => "UrlAction_WindykacjaUpdateStatus",
  43. '_postTask' => "updateSelected",
  44. ]
  45. ]),
  46. ])
  47. : '',
  48. ($totalToUpdateClients)
  49. ? UI::h('div', [ 'style' => "margin: 32px 0" ], [
  50. UI::h('p', [], "Rekordów wymagających aktualizacji jest <b>{$totalToUpdateClients}</b>"),
  51. UI::hButtonPost("aktualizuj wszystkie", [
  52. 'class' => "btn-primary",
  53. 'data' => [
  54. '_route' => "UrlAction_WindykacjaUpdateStatus",
  55. '_postTask' => "updateAll",
  56. ]
  57. ]),
  58. ])
  59. : '',
  60. ]);
  61. // $selected = FeatureAttrSelected::getAllSelected($typeName = "default_db/USERS2_WINDYKACJA_STATUS");
  62. // DBG::nicePrint($selected, '$selected');
  63. if(0){ // text create tasks
  64. $taskUrl = $this->getLink('testSleep', [ 'sleep' => 10 ]);
  65. echo UI::h('script', [], "
  66. var DBG = 0;
  67. var DBG1 = 1;
  68. var xhr = new XMLHttpRequest();
  69. xhr.onreadystatechange = function () {
  70. if (xhr.readyState == 4) {
  71. DBG1 && console.log('ready state = 4');
  72. }
  73. };
  74. xhr.open('GET', '{$taskUrl}', true);
  75. // xhr.setRequestHeader('Content-type', 'application/json; charset=utf-8');
  76. xhr.timeout = 1000;
  77. xhr.ontimeout = function () {
  78. DBG1 && console.log('Timed out!!!');
  79. }
  80. xhr.send();
  81. ");
  82. }
  83. }
  84. function testSleepAction() {
  85. $totalSleep = V::get('sleep', 2, $_REQUEST);
  86. while ($totalSleep-- > 0) {
  87. DBG::log("DBG:testSleep[{$totalSleep}]");
  88. sleep(1);
  89. }
  90. DBG::log("DBG:testSleep::END");
  91. }
  92. function updateSelectedPostTask() { UI::layout([ $this, 'updateSelectedPostTaskView' ]); }
  93. function updateSelectedPostTaskView() {
  94. $totalSelected = FeatureAttrSelected::getTotalSelected($typeName = "default_db/USERS2_WINDYKACJA_STATUS");
  95. // - `A_STATUS_UPDATE_DATE`: "Data ostatniej aktualizacji danych"
  96. // - synchronizacja (ręczna, codziennie)
  97. // - [ ] sync on client view (btn just reload): "?MENU_INIT=USERS2_WINDYKACJA_STATUS&q={$q}&_p={$p}&_f={$f}&_user_id={$idUser}"
  98. // - [ ] sync all (partial) ""?MENU_INIT=USERS2_WINDYKACJA_STATUS&task=stats_update"
  99. // - `LAST_PAY_DATE`: "data ostatniej wpłaty"
  100. // - `PAY_DATE`: "data wymagalności ostatniej faktury"
  101. // - `LAST_SMS_MSG_ID`, `LAST_SMS_STATUS`
  102. // - `LAST_MAIL_MSG_ID`, `LAST_MAIL_STATUS`
  103. $sqlSelected = FeatureAttrSelected::getAllSelectedAsSqlSubQuery($typeName = "default_db/USERS2_WINDYKACJA_STATUS");
  104. $totalToUpdateSelected = DB::getPDO()->fetchValue("
  105. select count(*) as total
  106. from USERS2_WINDYKACJA_STATUS t
  107. where t.ID in ( {$sqlSelected} )
  108. and t.A_STATUS_UPDATE_DATE < :today
  109. ", [
  110. ':today' => date("Y-m-d"),
  111. ]);
  112. $totalToUpdateClients = (int)DB::getPDO()->fetchValue("
  113. select count(*) as total
  114. from USERS2_WINDYKACJA_STATUS t
  115. where t.A_STATUS_UPDATE_DATE < :today
  116. ", [
  117. ':today' => date("Y-m-d"),
  118. ]);
  119. $this->viewTop();
  120. echo UI::h('div', [ 'class' => "alert alert-info" ], [
  121. "Zaznaczono {$totalSelected}",
  122. ($totalToUpdateSelected == 0) ? " ale wszystkie są aktualne" : "",
  123. ($totalToUpdateSelected > 0 && $totalToUpdateSelected < $totalSelected) ? " z czego do aktualizacji {$totalToUpdateSelected}." : "",
  124. ($totalToUpdateSelected == $totalSelected) ? ", wszystkie do aktualizacji." : "",
  125. ]);
  126. // $todoRows = DB::getPDO()->fetchAll("
  127. // select t.ID, t.ID_BILLING_USERS
  128. // , t.A_STATUS_UPDATE_DATE
  129. // , t.LAST_PAY_DATE
  130. // , t.PAY_DATE
  131. // , t.LAST_SMS_MSG_ID
  132. // , t.LAST_MAIL_MSG_ID
  133. // from USERS2_WINDYKACJA_STATUS t
  134. // where t.ID in ( {$sqlSelected} )
  135. // ");
  136. // UI::table([ 'caption' => "DBG: Wszystkie zaznaczone rekordy", 'rows' => $todoRows ]);
  137. echo UI::h('script', ['src'=>"static/vendor.js", 'type'=>"text/javascript"]);
  138. echo UI::h('div', [ 'id' => "p5-widget-windykacja-status-update" ]);
  139. UI::inlineJS(__FILE__ . '.view.js', [
  140. 'HTML_ID' => "p5-widget-windykacja-status-update",
  141. 'TOTAL' => $totalSelected,
  142. 'EXECUTE_SINGLE_TASK_URL' => $this->getLink("updateOneFromSelectedAjaxTask"),
  143. ]);
  144. echo UI::h('div', [ 'style' => "font-size:14px" ], [
  145. ($totalToUpdateClients)
  146. ? UI::h('div', [ 'style' => "margin: 32px 0" ], [
  147. UI::h('p', [], "Rekordów wymagających aktualizacji jest <b>{$totalToUpdateClients}</b>"),
  148. UI::hButtonPost("aktualizuj wszystkie", [
  149. 'class' => "btn-primary",
  150. 'data' => [
  151. '_route' => "UrlAction_WindykacjaUpdateStatus",
  152. '_postTask' => "updateAll",
  153. ]
  154. ]),
  155. ])
  156. : '',
  157. ]);
  158. }
  159. function updateAllPostTask() { UI::layout([ $this, 'updateAllPostTaskView' ]); }
  160. function updateAllPostTaskView() {
  161. $totalClients = (int)DB::getPDO()->fetchValue("
  162. select count(*) as total
  163. from USERS2_WINDYKACJA_STATUS t
  164. ");
  165. $this->viewTop();
  166. echo UI::h('script', ['src'=>"static/vendor.js", 'type'=>"text/javascript"]);
  167. echo UI::h('div', [ 'id' => "p5-widget-windykacja-status-update" ]);
  168. UI::inlineJS(__FILE__ . '.view.js', [
  169. 'HTML_ID' => "p5-widget-windykacja-status-update",
  170. 'TOTAL' => $totalClients,
  171. 'EXECUTE_SINGLE_TASK_URL' => $this->getLink("updateOneFromAllAjaxTask"),
  172. ]);
  173. }
  174. function updateOneFromSelectedAjaxTaskAction() { Response::sendTryCatchJson([ $this, 'updateOneFromSelectedAjaxTask' ]); }
  175. function updateOneFromSelectedAjaxTask($args) {
  176. $total = (int)FeatureAttrSelected::getTotalSelected($typeName = "default_db/USERS2_WINDYKACJA_STATUS");
  177. $sqlSelected = FeatureAttrSelected::getAllSelectedAsSqlSubQuery($typeName = "default_db/USERS2_WINDYKACJA_STATUS");
  178. $totalToUpdate = (int)DB::getPDO()->fetchValue("
  179. select count(*) as total
  180. from USERS2_WINDYKACJA_STATUS t
  181. where t.ID in ( {$sqlSelected} )
  182. and t.A_STATUS_UPDATE_DATE < :today
  183. ", [
  184. ':today' => date("Y-m-d"),
  185. ]);
  186. $totalDone = $total - $totalToUpdate;
  187. $percentDone = ($totalDone / $total) * 100;
  188. {
  189. $toUpdateClientID = (int)DB::getPDO()->fetchValue("
  190. select t.ID_BILLING_USERS
  191. from USERS2_WINDYKACJA_STATUS t
  192. where t.ID in ( {$sqlSelected} )
  193. and t.A_STATUS_UPDATE_DATE < :today
  194. order by ID DESC
  195. limit 1
  196. ", [
  197. ':today' => date("Y-m-d"),
  198. ]);
  199. $user = Windykacja_StatsModel::get_user_by_id($toUpdateClientID);
  200. if ($user) {
  201. $billing_docs = Windykacja_StatsModel::getBillDocsByDate($user->ID);
  202. Windykacja_StatsHelper::update_stats($user, $billing_docs);
  203. }
  204. }
  205. return [
  206. 'type' => "success",
  207. 'msg' => "ok",
  208. 'body' => [
  209. 'total' => $total,
  210. 'totalDone' => $totalDone,
  211. 'totalToUpdate' => $totalToUpdate,
  212. 'percentDone' => $percentDone,
  213. ],
  214. ];
  215. }
  216. function updateOneFromAllAjaxTaskAction() { Response::sendTryCatchJson([ $this, 'updateOneFromAllAjaxTask' ]); }
  217. function updateOneFromAllAjaxTask($args) {
  218. $total = (int)DB::getPDO()->fetchValue("
  219. select count(*) as total
  220. from USERS2_WINDYKACJA_STATUS t
  221. ");
  222. $totalToUpdate = (int)DB::getPDO()->fetchValue("
  223. select count(*) as total
  224. from USERS2_WINDYKACJA_STATUS t
  225. where t.A_STATUS_UPDATE_DATE < :today
  226. ", [
  227. ':today' => date("Y-m-d"),
  228. ]);
  229. $totalDone = $total - $totalToUpdate;
  230. $percentDone = ($totalDone / $total) * 100;
  231. {
  232. $toUpdateClientListIds = DB::getPDO()->fetchValuesList("
  233. select t.ID_BILLING_USERS
  234. from USERS2_WINDYKACJA_STATUS t
  235. where t.A_STATUS_UPDATE_DATE < :today
  236. order by ID DESC
  237. limit 10
  238. ", [
  239. ':today' => date("Y-m-d"),
  240. ]);
  241. foreach ($toUpdateClientListIds as $toUpdateClientID) {
  242. $user = Windykacja_StatsModel::get_user_by_id($toUpdateClientID);
  243. if ($user) {
  244. $billing_docs = Windykacja_StatsModel::getBillDocsByDate($user->ID);
  245. Windykacja_StatsHelper::update_stats($user, $billing_docs);
  246. } else {
  247. DB::getPDO()->update('USERS2_WINDYKACJA_STATUS', 'ID_BILLING_USERS', $toUpdateClientID, [
  248. 'A_STATUS_UPDATE_DATE' => date("Y-m-d"),
  249. ]);
  250. }
  251. }
  252. }
  253. return [
  254. 'type' => "success",
  255. 'msg' => "ok",
  256. 'body' => [
  257. 'total' => $total,
  258. 'totalDone' => $totalDone,
  259. 'totalToUpdate' => $totalToUpdate,
  260. 'percentDone' => $percentDone,
  261. ],
  262. ];
  263. }
  264. }