2010-12-02 23:34:41 +00:00
|
|
|
<?php
|
|
|
|
|
/**
|
|
|
|
|
* fields_Order.php
|
|
|
|
|
*
|
|
|
|
|
* ProcessMaker Open Source Edition
|
|
|
|
|
* Copyright (C) 2004 - 2008 Colosa Inc.23
|
|
|
|
|
*
|
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2012-10-18 11:53:05 -04:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2010-12-02 23:34:41 +00:00
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
2012-10-18 11:53:05 -04:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2010-12-02 23:34:41 +00:00
|
|
|
*
|
|
|
|
|
* For more information, contact Colosa Inc, 2566 Le Jeune Rd.,
|
|
|
|
|
* Coral Gables, FL, 33134, USA, or email info@colosa.com.
|
|
|
|
|
*/
|
2017-12-04 13:25:35 +00:00
|
|
|
if (($RBAC_Response = $RBAC->userCanAccess("PM_FACTORY")) != 1) {
|
2012-10-18 11:53:05 -04:00
|
|
|
return $RBAC_Response;
|
|
|
|
|
}
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2012-10-18 11:53:05 -04:00
|
|
|
//G::genericForceLogin( 'WF_MYINFO' , 'login/noViewPage', $urlLogin = 'login/login' );
|
2010-12-02 23:34:41 +00:00
|
|
|
|
|
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
if (! (isset($_POST['A']) && $_POST['A'] !== '')) {
|
2012-10-18 11:53:05 -04:00
|
|
|
return;
|
|
|
|
|
}
|
2017-12-04 13:25:35 +00:00
|
|
|
if (! (isset($_POST['XMLNODE_NAME']) && $_POST['XMLNODE_NAME'] !== '')) {
|
2012-10-18 11:53:05 -04:00
|
|
|
return;
|
|
|
|
|
}
|
2017-12-04 13:25:35 +00:00
|
|
|
if (! (isset($_POST['NEW_POS']) && $_POST['NEW_POS'] !== '')) {
|
2012-10-18 11:53:05 -04:00
|
|
|
return;
|
|
|
|
|
}
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
$file = PATH_DYNAFORM . G::decrypt($_POST['A'], URL_KEY) . '.xml';
|
2012-10-18 11:53:05 -04:00
|
|
|
$fieldName = $_POST['XMLNODE_NAME'];
|
2017-12-04 13:25:35 +00:00
|
|
|
$newPos = intval($_POST['NEW_POS']);
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
if (! file_exists($file)) {
|
2012-10-18 11:53:05 -04:00
|
|
|
return;
|
|
|
|
|
}
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2012-10-18 11:53:05 -04:00
|
|
|
$xmldoc = new Xml_Document();
|
2017-12-04 13:25:35 +00:00
|
|
|
$xmldoc->parseXmlFile($file);
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
$node = $xmldoc->findNode('/dynaForm/' . $fieldName);
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
if (! isset($node)) {
|
2012-10-18 11:53:05 -04:00
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
$numFields = 0;
|
|
|
|
|
foreach ($xmldoc->children[0]->children as $child) {
|
|
|
|
|
$numFields += ($child->name !== '') ? 1 : 0;
|
|
|
|
|
}
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2012-10-18 11:53:05 -04:00
|
|
|
$newPos = ($newPos < 1) ? 1 : $newPos;
|
|
|
|
|
$newPos = ($newPos > $numFields) ? $numFields : $newPos;
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2012-10-18 11:53:05 -04:00
|
|
|
$rowCounter = (int) 0;
|
2017-12-04 13:25:35 +00:00
|
|
|
$newOrder = array();
|
2012-10-18 11:53:05 -04:00
|
|
|
foreach ($xmldoc->children[0]->children as $index => $child) {
|
|
|
|
|
if ($child->name !== '') {
|
|
|
|
|
$rowCounter ++;
|
|
|
|
|
}
|
|
|
|
|
if ($rowCounter == $newPos) {
|
|
|
|
|
$newOrder[] = $node;
|
|
|
|
|
$rowCounter ++;
|
|
|
|
|
$newPos = - 1;
|
2010-12-02 23:34:41 +00:00
|
|
|
}
|
2012-10-18 11:53:05 -04:00
|
|
|
if ($child->name !== $node->name) {
|
|
|
|
|
$newOrder[] = $xmldoc->children[0]->children[$index];
|
|
|
|
|
} else {
|
|
|
|
|
$rowCounter --;
|
2010-12-02 23:34:41 +00:00
|
|
|
}
|
2012-10-18 11:53:05 -04:00
|
|
|
}
|
|
|
|
|
if ($rowCounter < $newPos) {
|
|
|
|
|
$newOrder[] = $node;
|
|
|
|
|
$rowCounter ++;
|
|
|
|
|
$newPos = - 1;
|
|
|
|
|
}
|
|
|
|
|
$xmldoc->children[0]->children = $newOrder;
|
|
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
$xmldoc->save($file);
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2012-10-18 11:53:05 -04:00
|
|
|
$i = 0;
|
2017-12-04 13:25:35 +00:00
|
|
|
$aFields = array();
|
|
|
|
|
$aFields[] = array('XMLNODE_NAME' => 'char','TYPE' => 'char','UP' => 'char','DOWN' => 'char','row__' => 'integer');
|
|
|
|
|
$oSession = new DBSession(new DBConnection($file, '', '', '', 'myxml'));
|
|
|
|
|
$oDataset = $oSession->Execute('SELECT * FROM dynaForm WHERE NOT( XMLNODE_NAME = "" )');
|
2012-10-18 11:53:05 -04:00
|
|
|
$iMaximun = $oDataset->count();
|
|
|
|
|
while ($aRow = $oDataset->Read()) {
|
2017-12-04 13:25:35 +00:00
|
|
|
$aFields[] = array('XMLNODE_NAME' => $aRow['XMLNODE_NAME'],'TYPE' => $aRow['TYPE'],'UP' => ($i > 0 ? G::LoadTranslation('ID_UP') : ''),'DOWN' => ($i < $iMaximun - 1 ? G::LoadTranslation('ID_DOWN') : ''),'row__' => ($i + 1) );
|
2012-10-18 11:53:05 -04:00
|
|
|
$i ++;
|
|
|
|
|
}
|
|
|
|
|
global $_DBArray;
|
|
|
|
|
$_DBArray['fields'] = $aFields;
|
|
|
|
|
$_SESSION['_DBArray'] = $_DBArray;
|