ProcesMenu.php 42 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130
  1. <?php
  2. require_once dirname(__FILE__) . '/' . 'Lib.php';
  3. Lib::loadClass('V');
  4. Lib::loadClass('User');
  5. Lib::loadClass('ProcesTestyHelper');
  6. class ProcesMenu {
  7. var $MENU_SELECT_PROCES;
  8. var $CRM_PROCES_USERA_UZYTY_MAP = null;
  9. var $CRM_PROCES_USERA_UZYTY_MAP_PROCES_INIT;
  10. var $CRM_PROCES_USERA_WYKONANE_TESTY;
  11. var $_wynik_testu;
  12. var $_wynik_testu_unactual;
  13. var $error;// errory niedopuszczajace do uruchomienia
  14. var $warning;// uwagi
  15. var $CRM_PROCES_USERA_UZYTY;
  16. var $_user_id;
  17. var $_acl;
  18. function __construct() {
  19. $this->MENU_SELECT_PROCES_DATA = V::get('MENU_SELECT_PROCES_DATA', null, $_SESSION);// URL
  20. $this->_user_id = User::getID();
  21. if (User::isAdmin()) {
  22. $this->_user_id = V::get('_user_id', 0, $_POST, 'int');
  23. if (!$this->_user_id) {
  24. $this->_user_id = User::getID();
  25. }
  26. }
  27. Lib::loadClass('UsersHelper');
  28. $this->_acl = UsersHelper::getUserAcl($this->_user_id);
  29. if (!$this->_acl) {
  30. die('Error Acl');
  31. }
  32. // TODO: TEST
  33. if ('' != V::get('DBG', '', $_GET)) {
  34. echo '<div style="background:#eeefef;border:2px solid blue;padding:10px;">';
  35. //$this->_acl->old();
  36. echo '</div>';
  37. echo '<div style="background:#eeefef;border:2px solid green;padding:10px;">';
  38. $this->_acl->old_fixed();
  39. echo '</div>';
  40. }
  41. $this->CRM_PROCES_USERA_UZYTY_MAP = $this->_acl->getUsedProcesMap();
  42. // TODO: run only if needed
  43. $this->_generate_wyniki_testow();
  44. }
  45. static function getInstance() {
  46. static $_instance = null;
  47. if (!$_instance) {
  48. $_instance = new ProcesMenu();
  49. }
  50. return $_instance;
  51. }
  52. function show() {
  53. static $_menu_showed = false;
  54. if (!$_menu_showed) {
  55. $actionName = V::get('_action', 'menu', $_REQUEST);
  56. // podglad testów pracownika
  57. if (User::isAdmin() && $this->_user_id != User::getID()) {
  58. $actionName = 'showMyTests';
  59. }
  60. $actionName .= 'Action';
  61. if (method_exists($this, $actionName)) {
  62. $this->{$actionName}();
  63. }
  64. //$this->show_menu_with_process();
  65. $_menu_showed = true;
  66. }
  67. }
  68. /**
  69. * @return Array
  70. */
  71. function get_wykonane_testy() {
  72. $testy_arr = array();
  73. if ($this->_user_id > 0) {
  74. $ses_cache_key = 'CRM_PROCES_USERA_WYKONANE_TESTY-' . $this->_user_id;
  75. if ('1' == V::get('_CLEAN_CACHE', '', $_GET)) unset($_SESSION[$ses_cache_key]);// TODO: DBG
  76. if (!isset($_SESSION[$ses_cache_key])) {
  77. $proces_map = $this->_acl->getUsedProcesMap();
  78. if (!empty($proces_map)) {
  79. $testy_arr = ProcesTestyHelper::get_tetsy_stats($this->_user_id, 0, array_keys($proces_map));// 30000000 => 0
  80. // check if tests are actual - proces steps may change
  81. if (!empty($testy_arr)) {
  82. $procesy_steps = array();
  83. foreach ($testy_arr as $v_test) {
  84. $procesy_steps[$v_test->ID_PROCES_INIT] = V::get($v_test->ID_PROCES_INIT, null, $proces_map);
  85. }
  86. foreach ($procesy_steps as $k_proces_id => $v_steps_arr) {
  87. $last_test = null;
  88. foreach ($testy_arr as $k_ind => $v_test) {
  89. if ($v_test->ID_PROCES_INIT == $k_proces_id) {
  90. $last_test = $v_test;
  91. $last_test->test_ind = $k_ind;
  92. break;
  93. }
  94. }
  95. if (!$last_test || $last_test->TEST_END == '0000-00-00') {
  96. continue;
  97. }
  98. $max_update_date = ProcesTestyHelper::get_max_update_date($v_steps_arr);
  99. if ($max_update_date) {
  100. $max_update_date = substr($max_update_date, 0, 10);
  101. $test_end = substr($last_test->TEST_END, 0, 10);
  102. if('1' == V::get('DBG_PM', '', $_GET)){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">'."P_INIT({$k_proces_id}) max_update_date({$max_update_date}) TEST_END({$last_test->TEST_END}) not actual(" . ($max_update_date > $last_test->TEST_END) . ")".' (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($last_test);echo'</pre>';}
  103. if ($max_update_date > $test_end) {
  104. $testy_arr[$last_test->test_ind]->unactual = $max_update_date;
  105. $testy_arr[$last_test->test_ind]->unactualId = $last_test->ID;
  106. }
  107. }
  108. }
  109. }
  110. }
  111. $_SESSION[$ses_cache_key] = $testy_arr;
  112. }
  113. return $_SESSION[$ses_cache_key];
  114. }
  115. return $testy_arr;
  116. }
  117. function setError($error) {
  118. $this->error[] = $error;
  119. }
  120. function ifError() {// TODO: RMME
  121. if (!empty($this->error)) {
  122. return true;
  123. }
  124. else {
  125. DEBUG_S(-1,'Wydarzyły się błędy uniemożliwiające kontynuacje pracy modułu',$this->error,__FILE__,__FUNCTION__,__LINE__);
  126. die();
  127. return false;
  128. }
  129. }
  130. function set_current_menu($new_menu) {
  131. $this->MENU_SELECT_PROCES = $new_menu;
  132. }
  133. /**
  134. * Set $_SESSION['MENU_SELECT_PROCES_DATA'] from $this->MENU_SELECT_PROCES_DATA
  135. */
  136. function set_current_menu_data() {
  137. $_SESSION['MENU_SELECT_PROCES_DATA'] = array();
  138. foreach ($this->MENU_SELECT_PROCES_DATA as $k_ind => $v_arr) {
  139. if (!empty($v_arr)) {
  140. $_SESSION['MENU_SELECT_PROCES_DATA'][$k_ind] = $v_arr;
  141. }
  142. }
  143. }
  144. function showMyTestsAction() {
  145. $this->menuAction();
  146. $userAcl = User::getAcl();
  147. $map = $this->_acl->getUsedProcesMap();
  148. $menu_to_show = array_keys($map);
  149. if (empty($menu_to_show)) {
  150. echo '<p>' . "Brak przypisanych procesów." . '</p>';
  151. return;
  152. }
  153. $procesy_init_ids = array();
  154. Lib::loadClass('DB');
  155. $db = DB::getDB();
  156. $sql = "select `ID`,`DESC` from `CRM_PROCES` where `TYPE`='PROCES_INIT' and `ID` in (".implode(",", $menu_to_show).") ";
  157. $res = $db->query($sql);
  158. while ($r = $db->fetch($res)) {
  159. $procesy_init_ids[$r->ID] = $r->DESC;
  160. }
  161. ?>
  162. <style type="text/css">
  163. .tbl-wyniki-testow {}
  164. .tbl-wyniki-testow td {vertical-align:top;font-size:small;}
  165. .tbl-wyniki-testow .proces-box {padding:0 6px;background:#f00;color:#fff;font-weight:bold;font-family:arial;text-decoration:none}
  166. .tbl-wyniki-testow .proces-desc {padding:0 3px;}
  167. .tbl-wyniki-testow .wynik-cell .wyniki-cell-header {height:56px;overflow:hidden;}
  168. .tbl-wyniki-testow .wynik-cell {padding:0 3px;background-color:#f7f7f7;}
  169. .tbl-wyniki-testow .wynik-BRAK_TESTU .proces-box {background-color:silver;}
  170. .tbl-wyniki-testow .wynik-BRAK_PYTAN .proces-box {background-color:#51B7D5;}
  171. .tbl-wyniki-testow .wynik-DOBRY .proces-box {background-color:lightgreen;}
  172. .tbl-wyniki-testow .wynik-DOSTATECZNY .proces-box {background-color:#FFFFB1; color:#777;}
  173. .tbl-wyniki-testow .wynik-NIEDOSTATECZNY .proces-box {background-color:#FC5151;}
  174. .tbl-wyniki-testow .wynik-IDEALNY .proces-box {background-color:gold;}
  175. .tbl-wyniki-testow .wynik-NIEAKTUALNY .proces-box {background-color:silver;}
  176. .tbl-wyniki-testow .row-fluid {margin-bottom:20px;}
  177. </style>
  178. <?php
  179. $userGroups = $this->_acl->fetchGroups();
  180. $idZasobowUsera = array_keys($userGroups);
  181. $idZasobowUsera = reset($idZasobowUsera);
  182. ?>
  183. <div class="container-fluid tbl-wyniki-testow">
  184. <div class="row-fluid">
  185. <?php $i = 0; foreach ($procesy_init_ids as $proces_id => $proces_desc) : ?>
  186. <?php
  187. $wynik_teoretyczny = $this->get_ocena_testu($proces_id, 'TEORETYCZNY');
  188. $wynik_teoretyczny_value = $this->get_ocena_testu_value($proces_id, 'TEORETYCZNY');
  189. if ($wynik_teoretyczny == 'BRAK_PYTAN') {
  190. $wynik_teoretyczny_value = '';
  191. }
  192. $wynik_praktyczny = $this->get_ocena_testu($proces_id, 'PRAKTYCZNY');
  193. $wynik_unactual = $this->isTestUnactual($proces_id, 'TEORETYCZNY');
  194. ?>
  195. <div class="span3 wynik-cell wynik-<?php echo $wynik_teoretyczny; ?>">
  196. <div class="wyniki-cell-header">
  197. <a class="proces-box" href="procesy5.php?task=PROCES_VIEW&id_proces=<?php echo $proces_id; ?>" title="zobacz instrukcję do procesu <?php echo $proces_id; ?>" target="_blank"><?php echo $proces_id; ?></a>
  198. <span class="proces-desc"><?php echo $proces_desc; ?></span>
  199. </div>
  200. <li>
  201. <?php if ($userAcl->getPermsProcesId() == $proces_id) : ?>
  202. <b><a href="index.php?FUNCTION_INIT=MENU_SELECT_PROCES&_action=setPermsAll"> Wyłącz filtr uprawnien dla </a></b>
  203. <?php else : ?>
  204. <a href="index.php?FUNCTION_INIT=MENU_SELECT_PROCES&_action=setPermsByProces&id_proces=<?php echo $proces_id; ?>"> Uruchom filtr uprawnien dla </a>
  205. <?php endif; ?>
  206. <?php echo $proces_id; ?>
  207. </li>
  208. <?php if (!in_array($wynik_teoretyczny, array('DOBRY', 'IDEALNY')) || $wynik_unactual) : ?>
  209. <li>
  210. <a href="procesy5.php?task=CRM_TESTY__ADD_TEST&function_init=fun_CRM_TESTY_ADD&stanowisko_id=<?php echo $idZasobowUsera; ?>&proces_id=<?php echo $proces_id; ?>&test_type=TEORETYCZNY"> Wykonaj test teoretyczny dla </a>
  211. <?php echo $proces_id; ?>
  212. </li>
  213. <?php endif; ?>
  214. <li>Test teoretyczny: <span class="proces-box"><?php echo $wynik_teoretyczny; ?>
  215. <?php if ($wynik_teoretyczny_value) : ?> <em>(<?php echo $wynik_teoretyczny_value; ?>)</em><?php endif; ?>
  216. </span>
  217. </li>
  218. <li class="wynik-<?php echo $wynik_praktyczny; ?>">Test praktyczny: <?php echo $wynik_praktyczny; ?></li>
  219. <?php if ($wynik_unactual) : ?>
  220. <div class="alert alert-error">
  221. <b>Uwaga! Test nieaktualny:</b>
  222. <?php if ($wynik_unactual->unactualId) : ?>
  223. <a class="btn btn-mini btn-primary" href="procesy5.php?task=CRM_TESTY__ADD_TEST&function_init=fun_CRM_TESTY__ADD_FIX&test_id=<?php echo $wynik_unactual->unactualId; ?>">popraw</a>
  224. <?php endif; ?>
  225. <br /><?php echo $wynik_unactual->TEST_END; ?> - zakończenie testu
  226. <br /><?php echo $wynik_unactual->unactual; ?> - ostatnia zmiana w procesie
  227. </div>
  228. <?php endif; ?>
  229. </div>
  230. <?php if (++$i >= 4) : $i = 0; ?>
  231. </div><div class="row-fluid">
  232. <?php endif; ?>
  233. <?php endforeach; ?>
  234. </div>
  235. </div>
  236. <?php
  237. }
  238. function menuAction() {
  239. $testy_teoretyczne = $this->get_actual_tests_count('TEORETYCZNY');
  240. $testy_praktyczne = $this->get_actual_tests_count('PRAKTYCZNY');
  241. $procesy_init_arr = $this->_acl->getUsedProcesInitIds();
  242. $proces_cnt = count($procesy_init_arr);
  243. $testy_ok = $this->get_actual_tests_count();
  244. $MojeTestyTitle = "Ilość Procesów: {$proces_cnt}, Aktualnych testów: {$testy_ok}, Teoretycznych: {$testy_teoretyczne}, Praktycznych: {$testy_praktyczne}";
  245. $userAcl = User::getAcl();
  246. $tbls = $userAcl->getTablesAcl();
  247. $urls = $userAcl->getUrls();
  248. $outMenus = array();
  249. $outBtnsMenus = array();
  250. if (!empty($tbls)) {
  251. foreach ($tbls as $kZasobID => $vTblAcl) {
  252. $outMenus[$kZasobID] = $vTblAcl->getLongLabel();
  253. if ($userAcl->getPermsProcesId()) {
  254. $outBtnsMenus[$kZasobID] = $vTblAcl->getRawLabel();
  255. }
  256. }
  257. }
  258. asort($outMenus);
  259. if ($userAcl->getPermsProcesId()) {
  260. asort($outBtnsMenus);
  261. }
  262. $outUrls = array();
  263. if (!empty($urls)) {
  264. /**
  265. * [147] => Array(
  266. * [TYPE] => URL
  267. * [DESC] => ?MENU_INIT=DODAJ_REKORDY_MIESZKAN_FUNC
  268. * [OPIS] => Narzedzie do wprowadzania zasobow mieszkan indywidualnych
  269. */
  270. foreach ($urls as $kZasobID => $vTitle) {
  271. $outUrls[$kZasobID] = $vTitle;
  272. }
  273. }
  274. asort($outUrls);
  275. $active = '';
  276. $script_name = V::get('SCRIPT_NAME', '', $_SERVER);
  277. if (false !== strpos($script_name, 'index.php')) {
  278. $menu_init = V::get('MENU_INIT', '', $_GET);
  279. switch ($menu_init) {
  280. case 'VIEWTABLE_AJAX': $active = 'menu'; break;
  281. case 'VIEWTABLE_KONTAKTY': $active = 'kontakty'; break;
  282. default: {
  283. $fun_init = V::get('FUNCTION_INIT', '', $_GET);
  284. switch ($fun_init) {
  285. case 'MENU_SELECT_PROCES': $active = 'testy_moje'; break;
  286. case 'PRZYPOMNIJ_FUNC': $active = 'przypomnij'; break;
  287. case 'PRZYPOMNIJ': $active = 'przypomnij'; break;
  288. default:
  289. }
  290. }
  291. }
  292. }
  293. else if (false !== strpos($script_name, 'procesy5.php')) {
  294. $task = V::get('task', '', $_GET);
  295. switch ($task) {
  296. case 'CRM_PROCES': $active = 'procesy'; break;
  297. case 'CRM_LISTA_ZASOBOW': $active = 'zasoby'; break;
  298. case 'CRM_WYSWIETL_OBOWIAZKI': $active = 'obowiazki'; break;
  299. case 'CRM_TESTY': $active = 'testy'; break;
  300. case 'CRM_TESTY_WYNIKI': $active = 'testy_wyniki'; break;
  301. case 'CRM_SEARCH': $active = 'search'; break;
  302. default:
  303. // testy_moje ?FUNCTION_INIT=MENU_SELECT_PROCES&MENU_SELECT_PROCES=show_menu_with_process => _action=showMyTests
  304. }
  305. }
  306. /*
  307. * $_SESSION['USER_PROFILE'][section][key] = val;
  308. */
  309. Lib::loadClass('UserBookmarks');
  310. $userBookmarks = UserBookmarks::getInstance();
  311. $bookmarksJson = array();
  312. $bookmarks = $userBookmarks->getBookmarks();
  313. foreach ($bookmarks as $kZasobID => $vClass) {
  314. if (array_key_exists($kZasobID, $tbls)) {
  315. $bookmarksJson[] = (object)array('id'=>$kZasobID, 'name'=>$tbls[$kZasobID]->getName(), 'label'=>$tbls[$kZasobID]->getRawLabel(), 'opis'=>$tbls[$kZasobID]->getOpis(), 'type'=>'menu', 'class'=>$vClass);
  316. }
  317. else if (array_key_exists($kZasobID, $urls)) {
  318. $bookmarksJson[] = (object)array('id'=>$kZasobID, 'name'=>$urls[$kZasobID], 'type'=>'url', 'class'=>$vClass);
  319. }
  320. }
  321. $userGroupIdsCSV = User::getGroupsIds();
  322. $userGroupIdsCSV = implode(',', $userGroupIdsCSV);
  323. ?>
  324. <div id="SE-menu" class="navbar navbar-inverse" style="position: static;">
  325. <div class="navbar-inner">
  326. <div class="container">
  327. <div class="nav-collapse collapse navbar-inverse-collapse">
  328. <ul class="nav">
  329. <li class="dropdown<?php if ($active == 'menu') echo ' active'; ?>">
  330. <a href="#" class="dropdown-toggle" data-toggle="dropdown">Menu <b class="caret"></b></a>
  331. <ul class="dropdown-menu" id="SE-menu-tables">
  332. <?php foreach ($outMenus as $kZasobID => $vName) : ?>
  333. <li>
  334. <a href="index.php?MENU_INIT=VIEWTABLE_AJAX&ZASOB_ID=<?php echo $kZasobID; ?>">
  335. <i class="bookmark-item-add-<?php echo $kZasobID; ?> bookmark-item-add icon-star-empty" title="Add to favorites" data-zasobid="<?php echo $kZasobID; ?>"></i>
  336. <i class="bookmark-item-rem-<?php echo $kZasobID; ?> bookmark-item-rem icon-star" style="display:none" title="Remove from favorites" data-zasobid="<?php echo $kZasobID; ?>"></i>
  337. <?php echo $vName; ?>
  338. </a>
  339. </li>
  340. <?php endforeach; ?>
  341. </ul>
  342. </li>
  343. <li class="dropdown">
  344. <a href="#" class="dropdown-toggle" data-toggle="dropdown">Narzędzia <b class="caret"></b></a>
  345. <ul class="dropdown-menu">
  346. <?php foreach ($outUrls as $kZasobID => $vTitle) : ?>
  347. <li>
  348. <a href="index.php?FUNCTION_INIT=URL_INIT&ZASOB_ID=<?php echo $kZasobID; ?>" target="_blank" title="<?php echo $vTitle; ?>">
  349. <i class="bookmark-item-add-<?php echo $kZasobID; ?> bookmark-item-add icon-star-empty" title="Add to favorites" data-zasobid="<?php echo $kZasobID; ?>"></i>
  350. <i class="bookmark-item-rem-<?php echo $kZasobID; ?> bookmark-item-rem icon-star" style="display:none" title="Remove from favorites" data-zasobid="<?php echo $kZasobID; ?>"></i>
  351. <code><?php echo $kZasobID; ?></code>
  352. <?php echo (mb_strlen($vTitle, 'utf-8') > 100)? mb_substr($vTitle, 0, 100, 'utf-8') . '...' : $vTitle; ?>
  353. </a>
  354. </li>
  355. <?php endforeach; ?>
  356. </ul>
  357. </li>
  358. <li<?php if ($active == 'procesy') echo ' class="active"'; ?>><a href="procesy5.php?task=CRM_PROCES" title="Wyswietlenie procesow">Procesy</a></li>
  359. <li class="dropdown <?php if ($active == 'zasoby') echo "active"; ?>">
  360. <a id="ProcesMenuZasobDropdownLink" href="#" class="dropdown-toggle" data-toggle="dropdown">Zasoby <b class="caret"></b></a>
  361. <ul class="dropdown-menu">
  362. <li>
  363. <a href="procesy5.php?task=CRM_LISTA_ZASOBOW<?php echo "&filtr_id={$userGroupIdsCSV}&filtr_ids=%2B&filtr_ob=%2B&filtr_img=%2B"; ?>" title="Moje Zasoby">Moje Zasoby</a>
  364. </li>
  365. <?php if ('VIEWTABLE_AJAX' == V::get('MENU_INIT', '', $_REQUEST)) : ?>
  366. <li>
  367. <a href="procesy5.php?task=CRM_LISTA_ZASOBOW<?php if(!empty($_REQUEST['ZASOB_ID'])) echo "&filtr_id={$_REQUEST['ZASOB_ID']}&filtr_ids=%2B&filtr_ob=%2B"; ?>" title="Struktura aktualnie przeglądanej tabeli">Struktura aktualnie przeglądanej tabeli</a>
  368. </li>
  369. <?php endif; ?>
  370. <li>
  371. <a href="procesy5.php?task=CRM_LISTA_ZASOBOW&filtr_id=" title="Wyświetlenie drzewa zasobów">Wszystkie Zasoby</a>
  372. </li>
  373. <li>
  374. <from id="ProcesMenuZasobSearchFrm" class="form-search" method="GET" action="">
  375. <input type="hidden" name="task" value="CRM_LISTA_ZASOBOW">
  376. <div class="input-append" style="padding:2px 6px">
  377. <input id="ProcesMenuZasobSearchInput" type="text" name="filtr_id" class="span2 search-query" placeholder="Nr zasobu">
  378. <input id="ProcesMenuZasobSearchSubmit" type="submit" class="btn" value="Szukaj" />
  379. </div>
  380. </from>
  381. <script>
  382. function procesMenuZasobSearchGo() {
  383. var id = jQuery('#ProcesMenuZasobSearchInput').val();
  384. if ('' !== id) {
  385. window.location.search = '?task=CRM_LISTA_ZASOBOW&filtr_id=' + id;
  386. }
  387. }
  388. jQuery(document).ready(function() {
  389. jQuery('#ProcesMenuZasobSearchInput').on('click', function(e) {
  390. return false;
  391. });
  392. jQuery('#ProcesMenuZasobSearchInput').on('keypress', function(e) {
  393. if (e.which == 13) {
  394. procesMenuZasobSearchGo();
  395. }
  396. });
  397. jQuery('#ProcesMenuZasobSearchSubmit').on('click', function(e) {
  398. procesMenuZasobSearchGo();
  399. });
  400. jQuery('#ProcesMenuZasobDropdownLink').on('click', function(e) {
  401. setTimeout(function(){
  402. jQuery('#ProcesMenuZasobSearchInput').focus();
  403. }, 200);
  404. });
  405. });
  406. </script>
  407. </li>
  408. </ul>
  409. </li>
  410. <li<?php if ($active == 'obowiazki') echo ' class="active"'; ?>><a href="procesy5.php?task=CRM_WYSWIETL_OBOWIAZKI" title="Wyswietlenie OBOWIAZKOW">Obowiązki</a></li>
  411. <li<?php if ($active == 'testy') echo ' class="active"'; ?>><a href="procesy5.php?task=CRM_TESTY" title="Wyswietlenie testów">Testy</a></li>
  412. <li<?php if ($active == 'testy_moje') echo ' class="active"'; ?>><a href="index.php?FUNCTION_INIT=MENU_SELECT_PROCES&_action=showMyTests" title="<?php echo $MojeTestyTitle; ?>">Moje (<?php echo "{$testy_ok} z {$proces_cnt}: T {$testy_teoretyczne}, P {$testy_praktyczne}"; ?>)</a></li>
  413. <?php if (User::get('ADM_ADMIN_LEVEL') <= 2) : ?>
  414. <li<?php if ($active == 'testy_wyniki') echo ' class="active"'; ?>><a href="procesy5.php?task=CRM_TESTY_WYNIKI" title="Wyswietlenie wyników testów">Wyniki</a></li>
  415. <?php endif; ?>
  416. <li<?php if ($active == 'kontakty') echo ' class="active"'; ?>><a href="index.php?MENU_INIT=VIEWTABLE_KONTAKTY" title="Kontakty">Kontakty</a></li>
  417. <li<?php if ($active == 'przypomnij') echo ' class="active"'; ?>><a href="index.php?MENU_INIT=PRZYPOMNIJ&KTO=<?php echo User::getLogin(); ?>" title="Przypomnij">Przypomnij</a></li>
  418. </ul>
  419. <ul class="nav pull-right">
  420. <li<?php if ($active == 'search') echo ' class="active"'; ?>>
  421. <form action="procesy5.php?task=CRM_SEARCH" method="post" class="navbar-search">
  422. <input type="text" name="q" value="" class="q search-query span2">
  423. <input type="image" src="icon/search.png" class="s">
  424. </form>
  425. </li>
  426. <li class="divider-vertical"></li>
  427. <li style="padding:8px 0;"><?php S::show_session_timer(); ?></li>
  428. <li class="divider-vertical"></li>
  429. <li class="dropdown">
  430. <a href="#" class="dropdown-toggle" data-toggle="dropdown"><?php echo User::getName(); ?> <b class="caret"></b></a>
  431. <ul class="dropdown-menu">
  432. <?php if (file_exists('/Library/Server/Web/Data/Sites/Default/')) : ?>
  433. <li><a href="/webcal" target="_blank"><i class="icon-calendar"></i> Kalendarz</a></li>
  434. <?php if (file_exists('/Library/Server/Web/Data/Sites/Default/webmail/loginFromSE.php')) : ?>
  435. <li><a href="/webmail" target="_blank" onclick="jQuery(this).next('form').submit(); return false;"><i class="icon-envelope"></i> Poczta</a>
  436. <form action="https://<?php echo $_SERVER['SERVER_NAME']; ?>/webmail/loginFromSE.php" method="post" style="display:none;">
  437. <input type="hidden" name="_timezone" value="Europe/Berlin">
  438. <input type="hidden" name="_token" value="">
  439. <input type="hidden" name="_action" value="login">
  440. <input type="hidden" name="_task" value="login">
  441. <input type="hidden" name="_url" value="">
  442. <input type="hidden" name="_user" value="<?php echo User::getName(); ?>">
  443. <input type="hidden" name="_pass" value="<?php echo User::get('ADM_PASS_HASH'); ?>">
  444. <input type="hidden" name="EMAIL_IMAP_IMPORT_USERNAME" value="<?php echo V::get('EMAIL_IMAP_IMPORT_USERNAME', '', $_SESSION); ?>">
  445. <input type="hidden" name="EMAIL_IMAP_IMPORT_HOST" value="<?php echo V::get('EMAIL_IMAP_IMPORT_HOST', '', $_SESSION); ?>">
  446. <input type="hidden" name="EMAIL_IMAP_IMPORT_PASSWD_HASH" value="<?php echo V::get('EMAIL_IMAP_IMPORT_PASSWD_HASH', '', $_SESSION); ?>">
  447. <input type="hidden" name="loginFromSE" value="1">
  448. <input type="submit" class="btn" value="P" />
  449. </form>
  450. </li>
  451. <?php elseif (file_exists('/Library/Server/Web/Data/Sites/Default/webmail')) : ?>
  452. <li><a href="/webmail" target="_blank"><i class="icon-envelope"></i> Poczta</a></li>
  453. <?php endif; ?>
  454. <li><a href="https://<?php echo $_SERVER['SERVER_ADDR']; ?>/changepassword" target="_blank">Zmień hasło</a></li>
  455. <li><a href="/profilemanager" target="_blank"><i class="icon-user"></i> Apple Profile Manager</a></li>
  456. <li class="divider"></li>
  457. <?php else: ?>
  458. <li><a href="index.php?LOGIN=PASSEDIT">Zmień hasło</a></li>
  459. <?php endif; ?>
  460. <li><a href="procesy5.php?task=USER" title="<?php echo User::getName(); ?>"><i class="icon-user"></i> Profil</a></li>
  461. <li><a href="index.php?LOGIN=PERMS_RELOAD" title="Przeładuj uprawnienia"><i class="icon-refresh"></i> Przeładuj uprawnienia</a></li>
  462. <?php if (User::isAdmin()) : ?>
  463. <li class="divider"></li>
  464. <li class="nav-header">Pokaż testy pracownika:</li>
  465. <li>
  466. <?php
  467. Lib::loadClass('UsersHelper');
  468. $users = UsersHelper::get_users_list(null, 100, 0, 'ADM_NAME', 'ASC');
  469. $user_sel = array();
  470. foreach ($users as $r) {
  471. $user_sel [$r->ID] = "{$r->ID}: {$r->ADM_NAME} ({$r->ADM_ACCOUNT}, {$r->EMAIL}, {$r->ADM_PHONE})";
  472. }
  473. if (!empty($user_sel)) {
  474. echo '<form action="index.php" method="POST">';
  475. echo '<input type="hidden" name="FUNCTION_INIT" value="MENU_SELECT_PROCES">';
  476. echo '<input type="hidden" name="_action" value="showMyTests">';
  477. echo '<select name="_user_id">';
  478. foreach ($user_sel as $k_option => $v_label) {
  479. $sel = ($k_option == $this->_user_id)? ' selected="selected"' : '';
  480. echo '<option value="' . $k_option . '"' . $sel . '>' . $v_label . '</option>';
  481. }
  482. echo '</select>';
  483. echo ' ';
  484. echo '<input type="submit" value="Wybierz" />';
  485. echo '</form>';
  486. }
  487. ?>
  488. </li>
  489. <?php endif; ?>
  490. <li class="divider"></li>
  491. <li><a href="index.php?LOGIN=LOGOUT"><i class="icon-off"></i> Wyloguj</a></li>
  492. </ul>
  493. </li>
  494. </ul>
  495. </div><!-- /.nav-collapse -->
  496. </div>
  497. </div><!-- /navbar-inner -->
  498. <?php if ($userAcl->getPermsProcesId()) : ?>
  499. <div id="SE-menu-sub">
  500. <a class="btn btn-mini btn-danger" href="index.php?FUNCTION_INIT=MENU_SELECT_PROCES&_action=setPermsAll" title="Wyłącz filtr uprawnień dla procesu <?php echo $userAcl->getPermsProcesId(); ?>">Wyłącz filtr uprawnień: <?php echo $userAcl->getPermsProcesId(); ?></a>
  501. <?php foreach ($outBtnsMenus as $kZasobID => $vName) : ?>
  502. <a class="btn btn-mini" href="index.php?MENU_INIT=VIEWTABLE_AJAX&ZASOB_ID=<?php echo $kZasobID; ?>" title="<?php echo $vName; ?>"><?php echo V::strShortUtf8($vName, 20); ?></a>
  503. <?php endforeach; ?>
  504. <?php foreach ($outUrls as $kZasobID => $vTitle) : ?>
  505. <a class="btn btn-mini" href="index.php?FUNCTION_INIT=URL_INIT&ZASOB_ID=<?php echo $kZasobID; ?>" target="_blank" title="<?php echo $vTitle; ?>"><?php echo V::strShortUtf8($vTitle, 20); ?></a>
  506. <?php endforeach; ?>
  507. </div>
  508. <?php else : ?>
  509. <div id="SE-menu-sub"></div>
  510. <script>
  511. (function ($, undefined) {
  512. var UserBookmarks = function() {
  513. var priv = {}; //private api
  514. var publ = {}; //public api
  515. priv.options = {};
  516. var defaults = {
  517. url: '', //webservice url
  518. urlInit: true, // try to load services on init
  519. preloadData: null,
  520. menuid: '',
  521. debug: false
  522. };
  523. var _cont; // container holding table
  524. var _menu; // container holding stars
  525. var _stateEdit = false;
  526. /*
  527. initialize the plugin.
  528. */
  529. priv.init = function() {
  530. _cont = $(priv.options.id);
  531. _menu = $(priv.options.menuid);
  532. _menu.find('.bookmark-item-add').click(function(e){
  533. e.preventDefault();
  534. e.stopPropagation();
  535. var zasobid = jQuery(this).data('zasobid');
  536. priv.update('add_bookmark', zasobid);
  537. var item = $('#bookmark-item-' + zasobid);
  538. if (item) {
  539. item.addClass('has_bookmark');
  540. }
  541. });
  542. _menu.find('.bookmark-item-rem').click(function(e){
  543. e.preventDefault();
  544. e.stopPropagation();
  545. var zasobid = jQuery(this).data('zasobid');
  546. priv.update('remove_bookmark', zasobid);
  547. });
  548. if (priv.options.urlInit) priv.update();
  549. if (priv.options.preloadData) priv.setData(priv.options.preloadData);
  550. };
  551. priv.setData = function(data) {
  552. _cont.empty();
  553. $.each(data, function(ind, item){
  554. if ('type' in item) {
  555. var l = $('<a></a>');
  556. l.data('id', item.id);
  557. l.addClass('btn');
  558. l.addClass('btn-mini');
  559. var label = item.name, title = '';
  560. if ('class' in item) {
  561. l.addClass(item.class);
  562. }
  563. if (item.type == 'menu') {
  564. l.attr('href', 'index.php?MENU_INIT=VIEWTABLE_AJAX&ZASOB_ID=' + item.id);
  565. if ('label' in item && item.label.length > 0) {
  566. label = item.label;
  567. title = item.label + ' (' + item.name + ')';
  568. }
  569. else if ('opis' in item && item.opis.length > 0) {
  570. label = item.opis;
  571. title = item.opis + ' (' + item.name + ')';
  572. }
  573. } else if (item.type == 'url') {
  574. l.attr('href', 'index.php?FUNCTION_INIT=URL_INIT&ZASOB_ID=' + item.id);
  575. l.attr('target', '_blank');
  576. }
  577. if (label.length > 20) {
  578. var pos = label.indexOf(' - ');
  579. if (pos > 20 || pos < 5) {
  580. pos = 20;
  581. l.text(label.substring(0, pos) + ' ...');
  582. } else {
  583. l.text(label.substring(0, pos));
  584. }
  585. } else {
  586. l.text(label);
  587. }
  588. if (title == '') title = label;
  589. l.attr('title', title);
  590. l.appendTo(_cont);
  591. if (_stateEdit) {
  592. priv.addEditBtns(l);
  593. }
  594. }
  595. // stars visibility
  596. $('.bookmark-item-rem-' + item.id).show();
  597. $('.bookmark-item-add-' + item.id).hide();
  598. });
  599. if (data.length > 0) {
  600. var editBtn = $('<button class="btn btn-mini btn-inverse" style="float:right" title="Edit Bookmarks"><i class="icon-cog icon-white"></i></button>')
  601. editBtn.on('click', priv.edit);
  602. editBtn.prependTo(_cont);
  603. }
  604. };
  605. priv.update = function(task, zasobID, argsAdd) {
  606. task = task || '';
  607. zasobID = zasobID || '';
  608. argsAdd = argsAdd || '';
  609. $.ajax({
  610. url: priv.options.url + '&_task=' + task + '&_zasobID=' + zasobID + argsAdd,
  611. type: 'GET',
  612. dataType: 'json',
  613. contentType: "application/json; charset=utf-8",
  614. data: null,
  615. async: true,
  616. success: function (data) {
  617. $('.bookmark-item-rem').hide();
  618. $('.bookmark-item-add').show();
  619. priv.setData(data);
  620. },
  621. error: function (err) {
  622. console.log('Error');
  623. console.log(err);
  624. }
  625. });
  626. };
  627. priv.changed = function(e) {
  628. if (priv.options.debug) console.log(e.data);
  629. if (priv.options.debug) console.log('id(' + e.data.id + ') cls(' + e.data.cls + ')');
  630. priv.update('change_bookmark', e.data.id, '&btnCls=' + e.data.cls);
  631. return false;
  632. };
  633. priv.removed = function(e) {
  634. if (priv.options.debug) console.log(e.data);
  635. if (priv.options.debug) console.log('id(' + e.data.id + ')');
  636. priv.update('remove_bookmark', e.data.id);
  637. return false;
  638. };
  639. priv.addEditBtns = function(el) {
  640. var next, btn;
  641. el.wrap('<div></div>');
  642. next = $('<span><em> Change color:</em> </span>');
  643. $.each(['btn-default', 'btn-primary', 'btn-info', 'btn-success', 'btn-warning', 'btn-danger'], function(btnInd, btnClass){
  644. btn = $('<button class="btn btn-mini ' + btnClass + '"> &nbsp; </button>');
  645. btn.on('click', {id: el.data('id'), cls: btnClass}, priv.changed);
  646. btn.appendTo(next);
  647. });
  648. btn = $('<button class="btn btn-mini"> remove </button>');
  649. btn.on('click', {id: el.data('id')}, priv.removed);
  650. btn.appendTo(next);
  651. next.insertAfter(el);
  652. };
  653. priv.edit = function(e) {
  654. _stateEdit = !_stateEdit;
  655. var el;
  656. _cont.find('a').each(function(ind, n){
  657. if (priv.options.debug) console.log(n);
  658. el = $(n);
  659. if (_stateEdit) {
  660. priv.addEditBtns(el);
  661. } else {
  662. el.next().remove();
  663. el.unwrap();
  664. }
  665. });
  666. }
  667. publ.init = function(options) {
  668. if (priv.options.debug) console.log('UserBookmarks initialization...');
  669. //merge supplied options with defaults
  670. $.extend(priv.options, defaults, options);
  671. priv.init();
  672. return publ;
  673. };
  674. return publ;
  675. };
  676. $.fn.UserBookmarks = function(options) {
  677. options = options || {};
  678. return this.each(function() {
  679. options.id = this;
  680. $(this).data('UserBookmarks', new UserBookmarks().init(options));
  681. });
  682. };
  683. })(jQuery);
  684. </script>
  685. <script>
  686. jQuery(document).ready(function(){
  687. jQuery('#SE-menu-sub').UserBookmarks({
  688. url: 'index-ajax.php?_cls=UserBookmarks',
  689. urlInit: false,
  690. preloadData: <?php echo json_encode($bookmarksJson); ?>,
  691. menuid: '#SE-menu',
  692. debug: false
  693. });
  694. });
  695. </script>
  696. <?php endif; ?>
  697. </div>
  698. <?php
  699. }
  700. /**
  701. * Generates wyniki
  702. */
  703. function _generate_wyniki_testow() {
  704. $this->_wynik_testu = array();// WYNIK_TESTU_PROCESU
  705. $this->_wynik_testu_unactual = array();
  706. $this_CRM_PROCES_USERA_WYKONANE_TESTY = $this->get_wykonane_testy();
  707. foreach ($this_CRM_PROCES_USERA_WYKONANE_TESTY as $v_test) {
  708. if (isset($this->_wynik_testu[$v_test->ID_PROCES_INIT][$v_test->TEST_TYPE])) {
  709. continue;// only first
  710. }
  711. $this->_wynik_testu[$v_test->ID_PROCES_INIT][$v_test->TEST_TYPE] = $v_test->OCENA;
  712. if (!empty($v_test->unactual)) {
  713. $x_test = new stdClass();
  714. $x_test->TEST_END = substr($v_test->TEST_END, 0, 10);
  715. $x_test->unactual = substr($v_test->unactual, 0, 10);
  716. $x_test->unactualId = $v_test->unactualId;
  717. $this->_wynik_testu_unactual[$v_test->ID_PROCES_INIT][$v_test->TEST_TYPE] = $x_test;
  718. }
  719. }
  720. }
  721. function get_ocena_testu($proces_id, $typ) {
  722. $ocena = $this->get_ocena_testu_value($proces_id, $typ);
  723. if (!$ocena) {
  724. return 'BRAK_TESTU';
  725. }
  726. else if ($ocena == -1) {
  727. return 'BRAK_PYTAN';
  728. }
  729. else if ($ocena == 3) {
  730. return 'IDEALNY';
  731. }
  732. else if ($ocena < 2) {
  733. return 'NIEDOSTATECZNY';
  734. }
  735. else if($ocena < 2.5) {
  736. return 'DOSTATECZNY';
  737. }
  738. else {
  739. return 'DOBRY';
  740. }
  741. }
  742. function get_ocena_testu_value($proces_id, $typ) {
  743. if (isset($this->_wynik_testu[$proces_id][$typ])) {
  744. return $this->_wynik_testu[$proces_id][$typ];
  745. }
  746. return null;
  747. }
  748. function isTestUnactual($proces_id, $typ) {
  749. if (isset($this->_wynik_testu_unactual[$proces_id][$typ])) {
  750. return $this->_wynik_testu_unactual[$proces_id][$typ];
  751. }
  752. return false;
  753. }
  754. function get_actual_tests_count($type = null) {
  755. $this_CRM_PROCES_USERA_WYKONANE_TESTY = $this->get_wykonane_testy();
  756. if ($type == 'TEORETYCZNY') {
  757. $testy_teoretyczne = 0;
  758. foreach ($this_CRM_PROCES_USERA_WYKONANE_TESTY as $int => $v_test) {
  759. if ($v_test->TEST_TYPE=='TEORETYCZNY') {
  760. if ($v_test->OCENA > 2.5) $testy_teoretyczne++;
  761. }
  762. }
  763. return $testy_teoretyczne;
  764. }
  765. else if ($type == 'PRAKTYCZNY') {
  766. $testy_praktyczne = 0;
  767. foreach ($this_CRM_PROCES_USERA_WYKONANE_TESTY as $int => $v_test) {
  768. if ($v_test->TEST_TYPE=='PRAKTYCZNY') {
  769. if ($v_test->OCENA > 2.5) $testy_praktyczne++;
  770. }
  771. }
  772. return $testy_praktyczne;
  773. }
  774. else if ($type == null) {
  775. return count($this_CRM_PROCES_USERA_WYKONANE_TESTY);
  776. }
  777. return 0;
  778. }
  779. function wylacz_filtr_uprawnien_dla_procesu() {// TODO: RMME => _action=setPermsAll
  780. unset($this->MENU_SELECT_PROCES_DATA['uruchom_filtr_uprawnien_dla_procesu']);// usun tryb jednego procesu
  781. $this->set_current_menu_data();// zapisz do sesji
  782. $this->set_perms_for_process();// domyslnie pusty włącza
  783. }
  784. function uruchom_filtr_uprawnien_dla_procesu() {// TODO: RMME => _action=setPermsByProces
  785. $proces_to_filter = V::get('ID_PROCES', '', $_REQUEST);
  786. $map = $this->_acl->getUsedProcesMap();
  787. if (!in_array($proces_to_filter, $map)) {// TODO: chyba array_key_exists ?
  788. $this->setError(" Nie ma takiego procesu dla usera aby ustawic dla niego filtry");
  789. }
  790. $this->ifError();// ? // TODO: RMME
  791. //szukam tabeli do ustalenia permow
  792. $this->unset_all_perms();
  793. $this->MENU_SELECT_PROCES_DATA['uruchom_filtr_uprawnien_dla_procesu'] = $proces_to_filter;
  794. $this->set_current_menu_data();
  795. $this->set_perms_for_process($proces_to_filter);
  796. $this->set_current_menu_data();
  797. //$this->set_current_menu('show_menu_with_process');
  798. //$this->show_menu_with_process();
  799. }
  800. function unset_all_perms() {
  801. $dbg_czysc_permy = true;// @from USERS_FIELDS_PROFILE_INIT()
  802. foreach ($_SESSION as $ses_col_name => $col_vars) {
  803. if (!is_array($col_vars) || empty($col_vars)) continue;
  804. if ('_COLUMN' != substr($ses_col_name, -1 * strlen('_COLUMN'))) {
  805. continue;
  806. }
  807. if (empty($col_vars['PERMEDIT'])) continue;
  808. if ($dbg_czysc_permy) {
  809. foreach ($col_vars['PERMEDIT'] as $col_perm_ind => $col_perm_value) {
  810. if ($col_perm_ind != 'ID') {
  811. $_SESSION[$ses_col_name]['PERMEDIT'][$col_perm_ind] = "";
  812. }
  813. }
  814. }
  815. }
  816. if (isset($_SESSION['MENU_SELECT_PROCES_DATA']['MENU_COLUMN'])) {
  817. foreach ($_SESSION['MENU_SELECT_PROCES_DATA']['MENU_COLUMN'] as $zasob => $val) {
  818. unset($this->MENU_SELECT_PROCES_DATA['MENU_COLUMN'][$zasob]);
  819. unset($_SESSION['MENU_SELECT_PROCES_DATA']['MENU_COLUMN'][$zasob]);
  820. }
  821. }
  822. }
  823. function set_perms_for_process($proces_to_filter = null) {// => setPermsByProcesAction
  824. if ($proces_to_filter) {
  825. $map = $this->_acl->getUsedProcesMap();
  826. if (array_key_exists($proces_to_filter, $map)) {
  827. $CRM_PROCES_USERA_UZYTY = $map[$proces_to_filter];
  828. } else {
  829. $CRM_PROCES_USERA_UZYTY = array();
  830. }
  831. }
  832. else {
  833. $CRM_PROCES_USERA_UZYTY = $this->_acl->getUsedProcesIds();
  834. }
  835. if (!empty($CRM_PROCES_USERA_UZYTY)) {
  836. return;
  837. }
  838. // ! @2013-02-11 zerzniete z USERS_FIELDS_PROFILE_INIT !
  839. $CRM_WSKAZNIK_PROCES_WSKAZNIK_TREE = array();
  840. $CRM_TREE_WSKAZNIK_NARZEDZIE = array();
  841. $TREE_CRM_WSKAZNIK_CONF = array();
  842. $TREE_CRM_WSKAZNIK_SORT_PRIO = array();
  843. $db = DB::getDB();
  844. //kopiuje tabele ze wskaznikow
  845. $sql = "select t1.`ID_PROCES`
  846. , t1.`ID_ZASOB`
  847. , replace(t2.`FORM_TREAT`, ',', '') as FORM_TREAT
  848. , t3.`DESC` as ZASOB_DESC
  849. , t3.`TYPE`
  850. , t4.`DESC` as PARENT_ZASOB_DESC
  851. , t4.`TYPE` as PARENT_TYPE
  852. , t3.`SORT_PRIO` as z__SORT_PRIO
  853. , t3.`OPIS` as ZASOB_OPIS , t1.`ID` as ID_WSKAZNIK
  854. from `CRM_WSKAZNIK` as t1
  855. left join `CRM_PRZYPADEK` as t2 on (t1.ID_PRZYPADEK=t2.ID)
  856. left join `CRM_LISTA_ZASOBOW` as t3 on (t3.ID=t1.ID_ZASOB)
  857. left join `CRM_LISTA_ZASOBOW` as t4 on (t4.ID=t3.PARENT_ID)
  858. where
  859. (
  860. ( t3.`TYPE`='KOMORKA' and t4.`TYPE`='TABELA' )
  861. or (t3.`TYPE`='NARZEDZIE') or (t3.`TYPE`='URL')
  862. )
  863. and t1.`A_STATUS` in('NORMAL', 'WAITING')
  864. and t1.`ID_PROCES` in(" . implode(",", $CRM_PROCES_USERA_UZYTY) . ")
  865. ";
  866. $res = $db->query($sql);
  867. if (!$res) {
  868. return;
  869. }
  870. while ($r = $db->fetch($res)) {
  871. if ($r->TYPE == 'NARZEDZIE') {
  872. if (isset($CRM_TREE_WSKAZNIK_NARZEDZIE[$r->ID_ZASOB])) {
  873. $CRM_TREE_WSKAZNIK_NARZEDZIE[$r->ID_ZASOB] .= $r->FORM_TREAT;
  874. }
  875. else {
  876. $CRM_TREE_WSKAZNIK_NARZEDZIE[$r->ID_ZASOB] = $r->FORM_TREAT;
  877. }
  878. $CRM_WSKAZNIK_PROCES_WSKAZNIK_TREE[$r->ID_PROCES][] = $r->ID_WSKAZNIK;//ustawiam wskaznik od procesu, jak user wybierze proces do roboty, to ja poznam co moze mu sie pojawic
  879. }
  880. else if ($r->TYPE == 'URL') {
  881. $CRM_WSKAZNIK_PROCES_WSKAZNIK_TREE[$r->ID_PROCES][] = $r->ID_WSKAZNIK;//ustawiam wskaznik od procesu, jak user wybierze proces do roboty, to ja poznam co moze mu sie pojawic
  882. $_SESSION['MENU_SELECT_PROCES_DATA']['MENU_COLUMN'][$r->ID_ZASOB]['TYPE'] = $r->TYPE;
  883. $_SESSION['MENU_SELECT_PROCES_DATA']['MENU_COLUMN'][$r->ID_ZASOB]['DESC'] = $r->ZASOB_DESC;
  884. $_SESSION['MENU_SELECT_PROCES_DATA']['MENU_COLUMN'][$r->ID_ZASOB]['OPIS'] = $r->ZASOB_OPIS;
  885. }
  886. else {
  887. if ($r->PARENT_TYPE == 'TABELA') {
  888. $CRM_WSKAZNIK_PROCES_WSKAZNIK_TREE[$r->ID_PROCES][] = $r->ID_WSKAZNIK;//ustawiam wskaznik od procesu, jak user wybierze proces do roboty, to ja poznam co moze mu sie pojawic
  889. if (isset($r->FORM_TREAT)) {
  890. if (isset($TREE_CRM_WSKAZNIK_CONF[$r->PARENT_ZASOB_DESC][$r->ZASOB_DESC])) {
  891. $TREE_CRM_WSKAZNIK_CONF[$r->PARENT_ZASOB_DESC][$r->ZASOB_DESC] .= $r->FORM_TREAT;
  892. }
  893. else {
  894. $TREE_CRM_WSKAZNIK_CONF[$r->PARENT_ZASOB_DESC][$r->ZASOB_DESC] = $r->FORM_TREAT;
  895. }
  896. // echo "<br. . . Dodaje dla:".$r->PARENT_ZASOB_DESC." ".$r->ZASOB_DESC." = ".$r->FORM_TREAT;
  897. }
  898. $TREE_CRM_WSKAZNIK_SORT_PRIO[$r->PARENT_ZASOB_DESC][$r->ZASOB_DESC] = $r->z__SORT_PRIO;
  899. //@2012-10-10 by SQIX : dodajemy opus kolumny z opisu zasobow
  900. if ($r->ZASOB_OPIS) {
  901. $_SESSION[$r->PARENT_ZASOB_DESC."_COLUMN"]['DESC_TO_LANG'][$r->ZASOB_DESC] = $r->ZASOB_OPIS;
  902. }
  903. else if (isset($_SESSION[$r->PARENT_ZASOB_DESC."_COLUMN"]['DESC_TO_LANG'][$r->ZASOB_DESC])
  904. && strlen($_SESSION[$r->PARENT_ZASOB_DESC."_COLUMN"]['DESC_TO_LANG'][$r->ZASOB_DESC]) > 1
  905. ) {
  906. echo "<BR> DODAJ opis dla zasobu ".$r->ID_ZASOB." w postaci <pre>".$_SESSION[$r->PARENT_ZASOB_DESC."_COLUMN"]['DESC_TO_LANG'][$r->ZASOB_DESC]."</pre>";
  907. }
  908. }
  909. }
  910. }
  911. // ! nizej uruchamiamy permy na podstawie wynikow co umozliwialy procesy
  912. foreach ($TREE_CRM_WSKAZNIK_CONF as $ses_column_name => $field_perms_arr) {
  913. foreach ($field_perms_arr as $k_name => $v_perm) {
  914. $v_perm = str_split($v_perm);
  915. $v_perm = array_unique($v_perm);
  916. $v_perm = implode("", $v_perm);
  917. //if(isset($_SESSION[$ses_column_name."_COLUMN"]['PERMEDIT'][$k_name]))
  918. $_SESSION[$ses_column_name."_COLUMN"]['PERMEDIT'][$k_name] = $v_perm;
  919. //else $_SESSION[$ses_column_name."_COLUMN"]['PERMEDIT'][$k_name] = $v_perm."RWX"; //dokladamy permy do istniejacych!!! @2012-10-21- najlepsze na okres przejsciowy do generowania procesow!
  920. $debug_perms[]="_SESSION['".$ses_column_name."_COLUMN']['PERMEDIT'][".$k_name."]']=".$v_perm;
  921. //jezeli jest w kolumnie ID==W , to znaczy, ze mozna dodawac nowy rekord
  922. if ($k_name == 'ID' && strstr($v_perm, 'W')) {
  923. $_SESSION[$ses_column_name."_COLUMN"]['FUNCPERMEDIT']['NEW_RECORD'] = "RWXC";
  924. $_SESSION[$ses_column_name."_COLUMN"]['FUNCPERMEDIT']['TABLE_INSERTDB'] = "RWXC";
  925. }
  926. //jezeli jest funkcja powiazana to uprawnienia dostajemy takie same jak z komorki do tej funkcji!
  927. if (isset($_SESSION[$ses_column_name."_COLUMN"]['TYPESPECIAL'][$k_name])) {
  928. $debug_perms[]="_SESSION['".$ses_column_name."_COLUMN']['FUNCPERMEDIT']['".$_SESSION[$ses_column_name."_COLUMN"]['TYPESPECIAL'][$k_name]."']=".$v_perm;
  929. $_SESSION[$ses_column_name."_COLUMN"]['FUNCPERMEDIT'][$_SESSION[$ses_column_name."_COLUMN"]['TYPESPECIAL'][$k_name]] = $v_perm;
  930. }
  931. }
  932. {// sort DESC by ZASOB.SORT_PRIO
  933. $desc_to_sort = array();
  934. if (!isset($_SESSION[$ses_column_name."_COLUMN"]['DESC'])) {
  935. //echo "<br><font color=red>L2375 Brak definicji w systemie opisanej procesami tabeli <b>".$ses_column_name."</b></font>";
  936. }
  937. else
  938. foreach ($_SESSION[$ses_column_name."_COLUMN"]['DESC'] as $k_ind => $v_val) {
  939. $desc_to_sort[$v_val] = $k_ind;
  940. }
  941. $TREE_CRM_WSKAZNIK_SORT_PRIO[$ses_column_name];
  942. asort($TREE_CRM_WSKAZNIK_SORT_PRIO[$ses_column_name]);
  943. $new_desc = array();
  944. foreach ($TREE_CRM_WSKAZNIK_SORT_PRIO[$ses_column_name] as $k_name => $v_sort_prio) {
  945. if (!isset($desc_to_sort[$k_name])) {
  946. //echo "<br><font color=red>Brak spojnosci definicji dla kolumny : ".$ses_column_name."[<b>".$k_name."</b>] </font>";
  947. }
  948. else {
  949. $new_desc[$desc_to_sort[$k_name]] = $k_name;
  950. }
  951. }
  952. // add columns
  953. foreach ($desc_to_sort as $k_name => $v_ind) {
  954. $new_desc[$v_ind] = $k_name;
  955. }
  956. $_SESSION[$ses_column_name."_COLUMN"]['DESC'] = $new_desc;
  957. }// sort DESC by ZASOB.SORT_PRIO
  958. }
  959. }
  960. /**
  961. * URL: _action=setPermsAll
  962. */
  963. function setPermsAllAction() {
  964. $userAcl = User::getAcl();
  965. $userAcl->fetchAllPerms(true);
  966. $this->menuAction();
  967. }
  968. /**
  969. * URL: _action=setPermsByProces
  970. */
  971. function setPermsByProcesAction() {
  972. $procesID = V::get('id_proces', 0, $_GET, 'int');
  973. if ($procesID <= 0) {
  974. echo '<div class="alert alert-error">' . "Brak ID Procesu" . '</div>';
  975. return;
  976. }
  977. $userAcl = User::getAcl();
  978. if ($userAcl->getPermsProcesId() == $procesID) {
  979. $this->menuAction();
  980. echo '<div class="alert alert-info">' . "Uprawnienia dla ID Procesu {$procesID} już zostały ustawione" . '</div>';
  981. return;
  982. }
  983. $db = DB::getDB();
  984. $proces = $db->get_by_id('CRM_PROCES', $procesID);
  985. if ($proces->TYPE != 'PROCES_INIT') {
  986. $this->menuAction();
  987. echo '<div class="alert alert-error">' . "Proces nie jest typu PROCES_INIT" . '</div>';
  988. return;
  989. }
  990. $userAcl = User::getAcl();
  991. $procesStepList = $userAcl->getUsedProcesIds($procesID);
  992. if (empty($procesStepList)) {
  993. $this->menuAction();
  994. echo '<div class="alert alert-error">' . "Nie ma takiego procesu dla usera aby ustawic dla niego filtry" . '</div>';
  995. return;
  996. }
  997. $userAcl->fetchProcesPerms($procesID, true);
  998. $this->menuAction();
  999. }
  1000. function show_url_menu() {// TODO: raneme; show all tables and actions by selected proces if in proces perm
  1001. if (isset($_SESSION['MENU_SELECT_PROCES_DATA']['MENU_COLUMN'])) {
  1002. ?>
  1003. <div class="btn-group">
  1004. <a class="btn dropdown-toggle" data-toggle="dropdown" href="#">
  1005. Narzędzia <span class="caret"></span>
  1006. </a>
  1007. <ul class="dropdown-menu">
  1008. <?php foreach ($_SESSION['MENU_SELECT_PROCES_DATA']['MENU_COLUMN'] as $id_zasob => $value_zasob) : ?>
  1009. <?php if ($value_zasob['TYPE'] == 'URL') : ?>
  1010. <li>
  1011. <a href="<?php echo $value_zasob['DESC']; ?>" target="_blank">
  1012. <?php echo '' . $value_zasob['OPIS'] . ' <em>(' . $value_zasob['DESC'] . ')</em>'; ?>
  1013. </a>
  1014. </li>
  1015. <?php endif; ?>
  1016. <?php endforeach; ?>
  1017. </ul>
  1018. </div>
  1019. <?php
  1020. }
  1021. }
  1022. function move_test_from_kandydat_to_pracownik($id_kanydata, $id_pracownika) {
  1023. //4673->4680
  1024. //$sql='update CRM_TESTY set A_RECORD_CREATE_AUTHOR='smagielm' where A_RECORD_CREATE_AUTHOR='Kandydat.4673';
  1025. //$sql='update CRM_TESTY set A_RECORD_UPDATE_AUTHOR='smagielm' where A_RECORD_UPDATE_AUTHOR='Kandydat.4673';
  1026. //$sql="update CRM_TESTY set ID_TESTER='4680' where ID_TESTER='4673'";
  1027. }
  1028. }