BUG 9319 "Problema con el Case Label" SOLVED
- By changing the "Case Label", this is not updated in the APP_CACHE_VIEW table - Solved problem to changing the "Case Label", now is updated in the APP_CACHE_VIEW table Note: - When you change the "Case Title" of a task, affecting every case, if it is the current task of the case (otherwise it would not affect the APP_CACHE_VIEW table) - If a task is saved empty the "Case Title" the APP_TITLE take the value #APP_NUMBER (all cases are in the task, this in APP_CACHE_VIEW table)
This commit is contained in:
@@ -451,6 +451,10 @@ public function kgetassigType($pro_uid, $tas){
|
||||
|
||||
function update($fields)
|
||||
{
|
||||
ini_set("max_execution_time", 0);
|
||||
|
||||
require_once ("classes/model/AppCacheView.php");
|
||||
|
||||
$con = Propel::getConnection(TaskPeer::DATABASE_NAME);
|
||||
try
|
||||
{
|
||||
@@ -471,6 +475,74 @@ public function kgetassigType($pro_uid, $tas){
|
||||
$result=$this->save();
|
||||
$result=($result==0)?($contentResult>0?1:0):$result;
|
||||
$con->commit();
|
||||
|
||||
if ($result == 1 && array_key_exists("TAS_DEF_TITLE", $fields)) {
|
||||
//Get cases
|
||||
$criteriaAPPCV = new Criteria("workflow");
|
||||
|
||||
$criteriaAPPCV->setDistinct();
|
||||
$criteriaAPPCV->addSelectColumn(AppCacheViewPeer::APP_UID);
|
||||
$criteriaAPPCV->add(AppCacheViewPeer::TAS_UID, $fields["TAS_UID"]);
|
||||
|
||||
$rsCriteriaAPPCV = AppCacheViewPeer::doSelectRS($criteriaAPPCV);
|
||||
$rsCriteriaAPPCV->setFetchmode(ResultSet::FETCHMODE_ASSOC);
|
||||
|
||||
while ($rsCriteriaAPPCV->next()) {
|
||||
$row = $rsCriteriaAPPCV->getRow();
|
||||
|
||||
$appcv_application_uid = $row["APP_UID"];
|
||||
|
||||
//Get DEL_INDEX_MAX
|
||||
$criteria = new Criteria("workflow");
|
||||
|
||||
$criteria->addAsColumn("DEL_INDEX_MAX", "MAX(" . AppCacheViewPeer::DEL_INDEX . ")");
|
||||
$criteria->add(AppCacheViewPeer::APP_UID, $appcv_application_uid);
|
||||
|
||||
$rsCriteria = AppCacheViewPeer::doSelectRS($criteria);
|
||||
$rsCriteria->setFetchmode(ResultSet::FETCHMODE_ASSOC);
|
||||
|
||||
$rsCriteria->next();
|
||||
$row = $rsCriteria->getRow();
|
||||
|
||||
$appcvDelIndexMax = $row["DEL_INDEX_MAX"];
|
||||
|
||||
//Current task?
|
||||
$criteria = new Criteria("workflow");
|
||||
|
||||
$criteria->addSelectColumn(AppCacheViewPeer::APP_UID);
|
||||
$criteria->add(AppCacheViewPeer::APP_UID, $appcv_application_uid);
|
||||
$criteria->add(AppCacheViewPeer::DEL_INDEX, $appcvDelIndexMax);
|
||||
$criteria->add(AppCacheViewPeer::TAS_UID, $fields["TAS_UID"]);
|
||||
|
||||
$rsCriteria = AppCacheViewPeer::doSelectRS($criteria);
|
||||
$rsCriteria->setFetchmode(ResultSet::FETCHMODE_ASSOC);
|
||||
|
||||
if ($rsCriteria->next()) {
|
||||
$appTitle = $fields["TAS_DEF_TITLE"];
|
||||
|
||||
$app = new Application();
|
||||
$arrayAppField = $app->Load($appcv_application_uid);
|
||||
|
||||
$appTitle = (!empty($appTitle))? $appTitle : "#" . $arrayAppField["APP_NUMBER"];
|
||||
$appTitleNew = G::replaceDataField($appTitle, unserialize($arrayAppField["APP_DATA"]));
|
||||
|
||||
if (isset($arrayAppField["APP_TITLE"]) && $arrayAppField["APP_TITLE"] != $appTitleNew) {
|
||||
//Updating the value in content, where...
|
||||
$criteria1 = new Criteria("workflow");
|
||||
$criteria1->add(ContentPeer::CON_CATEGORY, "APP_TITLE");
|
||||
$criteria1->add(ContentPeer::CON_ID, $appcv_application_uid);
|
||||
$criteria1->add(ContentPeer::CON_LANG, SYS_LANG);
|
||||
|
||||
//Update set
|
||||
$criteria2 = new Criteria("workflow");
|
||||
$criteria2->add(ContentPeer::CON_VALUE, $appTitleNew);
|
||||
|
||||
BasePeer::doUpdate($criteria1, $criteria2, Propel::getConnection("workflow"));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
else
|
||||
|
||||
@@ -141,36 +141,70 @@ var saveDataTaskTemporal = function(iForm)
|
||||
var saveTaskData = function(oForm, iForm, iType)
|
||||
{
|
||||
iLastTab = iForm;
|
||||
|
||||
if (!saveDataTaskTemporal(iForm)) {
|
||||
return false;
|
||||
}
|
||||
oTaskData.TAS_UID = getField('TAS_UID').value;
|
||||
/* while (oTaskData.TAS_TITLE.charAt(0)==' '){
|
||||
|
||||
oTaskData.TAS_UID = getField("TAS_UID").value;
|
||||
|
||||
/*
|
||||
while (oTaskData.TAS_TITLE.charAt(0)==" "){
|
||||
oTaskData.TAS_TITLE = oTaskData.TAS_TITLE.substring(1,oTaskData.TAS_TITLE.length) ;
|
||||
} */
|
||||
}
|
||||
*/
|
||||
|
||||
oTaskData.TAS_TITLE = oTaskData.TAS_TITLE.trim();
|
||||
if(oTaskData.TAS_TITLE==''){
|
||||
|
||||
if (oTaskData.TAS_TITLE == "") {
|
||||
alert(G_STRINGS.ID_REQ_TITLE );
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
var sParameters = 'function=saveTaskData';
|
||||
//Panel processing //iForm = 6 //Case Labels
|
||||
var pnlProcessing;
|
||||
|
||||
pnlProcessing = new leimnud.module.panel();
|
||||
|
||||
pnlProcessing.options = {
|
||||
//title: "",
|
||||
//theme: this.options.theme,
|
||||
limit: true,
|
||||
size: {w: 250, h: 110},
|
||||
position: {x: 50, y: 50, center: true},
|
||||
control: {close: false, resize: false},
|
||||
statusBar: true,
|
||||
fx:{shadow: true, modal: true}
|
||||
};
|
||||
|
||||
pnlProcessing.make();
|
||||
|
||||
//pnlProcessing.loader.show();
|
||||
pnlProcessing.addContent("<div style=\"margin-left: 1em; padding: 0.80em 0 1em 4em; background: url(/images/classic/loader_B.gif) no-repeat left top;\">" + _("ID_PROCESSING") + "</div>");
|
||||
|
||||
//Set AJAX
|
||||
var sParameters = "function=saveTaskData";
|
||||
|
||||
var oRPC = new leimnud.module.rpc.xmlhttp({
|
||||
url : '../tasks/tasks_Ajax',
|
||||
async : false,
|
||||
method: 'POST',
|
||||
args : sParameters + '&oData=' + oTaskData.toJSONString()
|
||||
url: "../tasks/tasks_Ajax",
|
||||
method: "POST",
|
||||
args: sParameters + "&oData=" + oTaskData.toJSONString()
|
||||
});
|
||||
oRPC.make();
|
||||
if (oTaskData.TAS_TITLE)
|
||||
{
|
||||
Pm.data.db.task[getField('INDEX').value].label = Pm.data.db.task[getField('INDEX').value].object.elements.label.innerHTML = oTaskData.TAS_TITLE.replace(re2, "&");
|
||||
|
||||
oRPC.callback = function (rpc) {
|
||||
//pnlProcessing.loader.hide();
|
||||
pnlProcessing.remove();
|
||||
|
||||
if (oTaskData.TAS_TITLE) {
|
||||
Pm.data.db.task[getField("INDEX").value].label = Pm.data.db.task[getField("INDEX").value].object.elements.label.innerHTML = oTaskData.TAS_TITLE.replace(re2, "&");
|
||||
}
|
||||
if (oTaskData.TAS_START)
|
||||
{
|
||||
oTaskData.TAS_START = (oTaskData.TAS_START == 'TRUE' ? true : false);
|
||||
|
||||
if (oTaskData.TAS_START) {
|
||||
oTaskData.TAS_START = ((oTaskData.TAS_START == "TRUE")? true : false);
|
||||
Pm.data.render.setTaskINI({task: oTaskData.TAS_UID, value: oTaskData.TAS_START});
|
||||
}
|
||||
|
||||
try {
|
||||
new leimnud.module.app.info().make({
|
||||
label: changesSavedLabel
|
||||
@@ -179,7 +213,11 @@ var saveTaskData = function(oForm, iForm, iType)
|
||||
catch (e) {
|
||||
//No show confirmation
|
||||
}
|
||||
|
||||
Pm.tmp.propertiesPanel.remove();
|
||||
}.extend(this);
|
||||
|
||||
oRPC.make();
|
||||
};
|
||||
|
||||
var showTriggers = function(sStep, sType)
|
||||
|
||||
Reference in New Issue
Block a user