@magic-xpa/engine 4.900.0-dev490.24 → 4.900.0-dev490.241
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.
- package/esm2020/src/ClientManager.mjs +9 -4
- package/esm2020/src/CurrentClientVersion.mjs +2 -2
- package/esm2020/src/bridge/MagicBridge.mjs +3 -3
- package/esm2020/src/data/Field.mjs +3 -2
- package/esm2020/src/env/LanguageData.mjs +3 -1
- package/esm2020/src/event/EventsManager.mjs +2 -2
- package/esm2020/src/exp/ExpressionEvaluator.mjs +2 -2
- package/esm2020/src/gui/MgControl.mjs +3 -2
- package/esm2020/src/rt/RecomputeTable.mjs +12 -4
- package/esm2020/src/rt/RemoteDataviewHeader.mjs +10 -7
- package/esm2020/src/tasks/RemoteTaskService.mjs +3 -3
- package/esm2020/src/tasks/Task.mjs +15 -7
- package/esm2020/src/util/cookie.service.mjs +2 -2
- package/fesm2015/magic-xpa-engine.mjs +60 -28
- package/fesm2015/magic-xpa-engine.mjs.map +1 -1
- package/fesm2020/magic-xpa-engine.mjs +53 -25
- package/fesm2020/magic-xpa-engine.mjs.map +1 -1
- package/package.json +4 -4
- package/src/ClientManager.d.ts +1 -1
- package/src/bridge/MagicBridge.d.ts +1 -1
- package/src/tasks/RemoteTaskService.d.ts +1 -1
- package/src/tasks/Task.d.ts +1 -1
|
@@ -81,7 +81,7 @@ export class CookieService {
|
|
|
81
81
|
var cookie = cookies[i];
|
|
82
82
|
var eqPos = cookie.indexOf('=');
|
|
83
83
|
var name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
|
|
84
|
-
if (cookieName === decodeURI(name)) {
|
|
84
|
+
if (cookieName === NString.TrimStart(decodeURI(name))) {
|
|
85
85
|
document.cookie = name + '=;expires=Thu, 01 Jan 1970 00:00:00 GMT';
|
|
86
86
|
return true;
|
|
87
87
|
}
|
|
@@ -89,4 +89,4 @@ export class CookieService {
|
|
|
89
89
|
return false;
|
|
90
90
|
}
|
|
91
91
|
}
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cookie.service.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/util/cookie.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAE/C,MAAM,OAAO,aAAa;IAEjB,MAAM,CAAC,UAAU,CAAC,UAAkB;QAEzC,IAAI,UAAU,IAAI,GAAG;YACnB,OAAO,QAAQ,CAAC,MAAM,CAAC;QAEzB,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IACpC,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,IAAY,EAAE,KAAa,EAAE,OAAuB,EAAE,IAAK,EAAE,MAAQ,EAAE,MAAO,EAAE,QAAS;QAC/G,IAAI,YAAY,GAAW,kBAAkB,CAAC,IAAI,CAAC,GAAG,GAAG,GAAG,kBAAkB,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,GAAG,GAAG,CAAC;QACzH,IAAI,OAAO,EAAE;YACX,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;gBAC/B,MAAM,WAAW,GAAS,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;gBAE5C,YAAY,IAAI,UAAU,GAAG,WAAW,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC;aAC9D;iBACI,IAAG,CAAC,OAAO,OAAO,KAAK,QAAQ,CAAC,EACrC;gBACE,MAAM,WAAW,GAAS,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;gBAE5C,YAAY,IAAI,UAAU,GAAG,WAAW,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC;aAC9D;iBACI;gBACH,YAAY,IAAI,UAAU,GAAG,OAAO,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC;aAC1D;SACF;QAED,IAAI,IAAI,EAAE;YACR,YAAY,IAAI,OAAO,GAAG,IAAI,GAAG,GAAG,CAAC;SACtC;QAED,IAAI,MAAM,EAAE;YACV,YAAY,IAAI,SAAS,GAAG,MAAM,GAAG,GAAG,CAAC;SAC1C;QAED,IAAI,MAAM,KAAK,KAAK,IAAI,QAAQ,KAAK,MAAM,EAAE;YAC3C,MAAM,GAAG,IAAI,CAAC;YACd,OAAO,CAAC,IAAI,CACV,UAAU,IAAI,qDAAqD,CACpE,CAAC;SACH;QACD,IAAI,MAAM,EAAE;YACV,YAAY,IAAI,SAAS,CAAC;SAC3B;QAED,IAAI,CAAC,QAAQ,EAAE;YACb,QAAQ,GAAG,KAAK,CAAC;SAClB;QAED,YAAY,IAAI,WAAW,GAAG,QAAQ,GAAG,GAAG,CAAC;QAE7C,QAAQ,CAAC,MAAM,GAAG,YAAY,CAAC;QAE/B,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,YAAY;QAE/B,YAAY,GAAG,YAAY,CAAC,IAAI,EAAE,CAAC;QAEnC,IAAI,YAAY,GAAG,EAAE,CAAC;QAGtB,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,GAAG,YAAY,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE;YAG9D,YAAY,IAAI,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YAGjD,IAAI,OAAO,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE;gBACrC,YAAY,IAAI,GAAG,CAAC;aACrB;SACF;QACD,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,YAAY;QAE/B,IAAI,YAAY,GAAG,EAAE,CAAC;QAGtB,IAAI,UAAU,GAAG,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAGzC,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,GAAG,UAAU,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE;YAI5D,YAAY,IAAI,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;SAC1D;QAGD,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,MAAM,CAAC,SAAS,CAAC,UAAU;QACzB,IAAI,IAAI,GAAG,OAAO,CAAC,SAAS,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC;QAC/C,IAAI,aAAa,GAAG,kBAAkB,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QACxD,IAAI,EAAE,GAAG,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAClC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;YACd,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE;gBACzB,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;aACpB;YACD,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACxB,IAAI,MAAM,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;gBAC7E,OAAO,MAAM,CAAC;aACf;SACF;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,CAAC,YAAY,CAAC,UAAU;QAC5B,IAAI,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAEzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACvC,IAAI,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;YACxB,IAAI,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAChC,IAAI,IAAI,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;YACzD,IAAI,UAAU,KAAK,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,EAAE;gBACrD,QAAQ,CAAC,MAAM,GAAG,IAAI,GAAG,yCAAyC,CAAC;gBACnE,OAAO,IAAI,CAAC;aACb;SACF;QACD,OAAO,KAAK,CAAC;IACf,CAAC;CAEF","sourcesContent":["import { NString } from '@magic-xpa/mscorelib';\n\nexport class CookieService {\n\n  public static getCookies(cookieName: string) {\n\n    if (cookieName == '*')\n      return document.cookie;\n\n    return this.getCookie(cookieName);\n  }\n\n  public static setCookie(name: string, value: string, expires?: number | Date, path?, domain ?, secure?, sameSite?): boolean {\n    let cookieString: string = encodeURIComponent(name) + '=' + encodeURIComponent(CookieService.encode_cookie(value)) + ';';\n    if (expires) {\n      if (typeof expires === 'number') {\n        const dateExpires: Date = new Date(expires);\n\n        cookieString += 'expires=' + dateExpires.toUTCString() + ';';\n      }\n      else if((typeof expires === 'string'))\n      {\n        const dateExpires: Date = new Date(expires);\n\n        cookieString += 'expires=' + dateExpires.toUTCString() + ';';\n      }\n      else {\n        cookieString += 'expires=' + expires.toUTCString() + ';';\n      }\n    }\n\n    if (path) {\n      cookieString += 'path=' + path + ';';\n    }\n\n    if (domain) {\n      cookieString += 'domain=' + domain + ';';\n    }\n\n    if (secure === false && sameSite === 'None') {\n      secure = true;\n      console.warn(\n        `cookie ${name} was forced with secure flag because sameSite=None.`\n      );\n    }\n    if (secure) {\n      cookieString += 'secure;';\n    }\n\n    if (!sameSite) {\n      sameSite = 'Lax';\n    }\n\n    cookieString += 'sameSite=' + sameSite + ';';\n\n    document.cookie = cookieString;\n\n    return this.getCookie(name);\n  }\n\n  static encode_cookie(cookie_value) {\n\n    cookie_value = cookie_value.trim();\n    //This variable holds the encoded cookie characters\n    var coded_string = '';\n\n    // Run through each character in the cookie value\n    for (var counter = 0; counter < cookie_value.length; counter++) {\n\n      // Add the character's numeric code to the string\n      coded_string += cookie_value.charCodeAt(counter);\n\n      // Separate each code with a plus sign (+)\n      if (counter < cookie_value.length - 1) {\n        coded_string += '+';\n      }\n    }\n    return coded_string;\n  }\n\n  static decode_cookie(coded_string) {\n    // This variable holds the decoded cookie value\n    var cookie_value = '';\n\n    // Use + to split the coded string into an array\n    var code_array = coded_string.split('+');\n\n    // Loop through the array\n    for (var counter = 0; counter < code_array.length; counter++) {\n\n      // Convert the code into a character and\n      // add it to the cookie value string\n      cookie_value += String.fromCharCode(code_array[counter]);\n    }\n    // return coded_string;\n\n    return cookie_value;\n  }\n\n  static getCookie(cookieName): any {\n    let name = NString.TrimStart(cookieName + '=');\n    let decodedCookie = decodeURIComponent(document.cookie);\n    let ca = decodedCookie.split(';');\n    for (let i = 0; i < ca.length; i++) {\n      let c = ca[i];\n      while (c.charAt(0) == ' ') {\n        c = c.substring(1);\n      }\n      if (c.indexOf(name) >= 0) {\n        let decode = CookieService.decode_cookie(c.substring(name.length, c.length));\n        return decode;\n      }\n    }\n    return '';\n  }\n\n  static deleteCookie(cookieName): boolean {\n    var cookies = document.cookie.split(';');\n\n    for (var i = 0; i < cookies.length; i++) {\n      var cookie = cookies[i];\n      var eqPos = cookie.indexOf('=');\n      var name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;\n      if (cookieName === NString.TrimStart(decodeURI(name))) {\n        document.cookie = name + '=;expires=Thu, 01 Jan 1970 00:00:00 GMT';\n        return true;\n      }\n    }\n    return false;\n  }\n\n}\n"]}
|
|
@@ -1241,7 +1241,8 @@ class MgControl extends MgControlBase {
|
|
|
1241
1241
|
if (!isTagProcessed) {
|
|
1242
1242
|
switch (attribute) {
|
|
1243
1243
|
case ConstInterface.MG_ATTR_SUBFORM_TASK:
|
|
1244
|
-
|
|
1244
|
+
if (valueStr.trim() != "")
|
|
1245
|
+
this._subformTaskId = valueStr;
|
|
1245
1246
|
break;
|
|
1246
1247
|
case ConstInterface.MG_ATTR_REFRESHON:
|
|
1247
1248
|
this.refreshOnString = valueStr.trim();
|
|
@@ -6323,6 +6324,8 @@ class LanguageData {
|
|
|
6323
6324
|
}
|
|
6324
6325
|
}
|
|
6325
6326
|
else if (this._mlsFileUrl != null) {
|
|
6327
|
+
if (this._mlsFileUrl.startsWith("./"))
|
|
6328
|
+
this._mlsFileUrl = NString.Replace(this._mlsFileUrl, './', './assets/cache/');
|
|
6326
6329
|
let contentStr = yield CommandsProcessorManager.GetContent(this._mlsFileUrl, true);
|
|
6327
6330
|
let buffer = contentStr;
|
|
6328
6331
|
if (buffer != null && buffer.length > 0) {
|
|
@@ -10362,7 +10365,7 @@ class CookieService {
|
|
|
10362
10365
|
var cookie = cookies[i];
|
|
10363
10366
|
var eqPos = cookie.indexOf('=');
|
|
10364
10367
|
var name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
|
|
10365
|
-
if (cookieName === decodeURI(name)) {
|
|
10368
|
+
if (cookieName === NString.TrimStart(decodeURI(name))) {
|
|
10366
10369
|
document.cookie = name + '=;expires=Thu, 01 Jan 1970 00:00:00 GMT';
|
|
10367
10370
|
return true;
|
|
10368
10371
|
}
|
|
@@ -14498,7 +14501,7 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
|
|
|
14498
14501
|
}
|
|
14499
14502
|
path = args[3];
|
|
14500
14503
|
domain = args[4];
|
|
14501
|
-
resVal.BoolVal = CookieService.setCookie(cookieName, args[0], nativeDt, path, domain, secure, sameSite);
|
|
14504
|
+
resVal.BoolVal = CookieService.setCookie(cookieName, (args[0] != null ? args[0].toString() : ""), nativeDt, path, domain, secure, sameSite);
|
|
14502
14505
|
}
|
|
14503
14506
|
eval_op_get_cookie(cookieName, resVal) {
|
|
14504
14507
|
resVal.StrVal = CookieService.getCookie(cookieName);
|
|
@@ -16586,7 +16589,8 @@ class Field extends FieldBase {
|
|
|
16586
16589
|
}
|
|
16587
16590
|
break;
|
|
16588
16591
|
case ConstInterface.MG_ATTR_CHACHED_FLD_ID:
|
|
16589
|
-
|
|
16592
|
+
if (data[0] != "")
|
|
16593
|
+
this.CacheTableFldIdx = NNumber.Parse(data[1]);
|
|
16590
16594
|
break;
|
|
16591
16595
|
case ConstInterface.MG_ATTR_LOCATE:
|
|
16592
16596
|
this.Locate = new Boundary(this.getTask(), NNumber.Parse(data[1]), NNumber.Parse(data[0]), this.getType(), this.getSize(), this.CacheTableFldIdx);
|
|
@@ -20988,8 +20992,10 @@ class RemoteTaskService extends TaskServiceBase {
|
|
|
20988
20992
|
return OwnerTransactionTask;
|
|
20989
20993
|
}
|
|
20990
20994
|
static PreparePropMainDisplay(task) {
|
|
20991
|
-
|
|
20992
|
-
|
|
20995
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
20996
|
+
yield task.ComputeMainDisplay();
|
|
20997
|
+
return task.FormIsLegal() ? ReturnResult.SuccessfulResult : new ReturnResult(MsgInterface.BRKTAB_STR_ERR_FORM);
|
|
20998
|
+
});
|
|
20993
20999
|
}
|
|
20994
21000
|
}
|
|
20995
21001
|
|
|
@@ -21394,15 +21400,18 @@ class RemoteDataviewHeader extends DataviewHeaderBase {
|
|
|
21394
21400
|
setAttribute(attribute, valueStr) {
|
|
21395
21401
|
switch (attribute) {
|
|
21396
21402
|
case ConstInterface.MG_ATTR_CACHED_TABLE:
|
|
21397
|
-
if (
|
|
21398
|
-
|
|
21399
|
-
|
|
21400
|
-
|
|
21401
|
-
|
|
21403
|
+
if (valueStr != "") {
|
|
21404
|
+
if (TableCacheManager.Instance.TableExists(valueStr))
|
|
21405
|
+
this._table = TableCacheManager.Instance.GetTableById(valueStr);
|
|
21406
|
+
else {
|
|
21407
|
+
this._table = new TableCache(valueStr);
|
|
21408
|
+
TableCacheManager.Instance.InsertTable(this._table);
|
|
21409
|
+
}
|
|
21402
21410
|
}
|
|
21403
21411
|
break;
|
|
21404
21412
|
case ConstInterface.MG_ATTR_IDENT:
|
|
21405
|
-
|
|
21413
|
+
if (valueStr != "")
|
|
21414
|
+
this._table.SetTableIdent(valueStr);
|
|
21406
21415
|
break;
|
|
21407
21416
|
default:
|
|
21408
21417
|
super.setAttribute(attribute, valueStr);
|
|
@@ -22516,9 +22525,17 @@ class RecomputeTable {
|
|
|
22516
22525
|
this.fillData_1(task.DataView, task, parser);
|
|
22517
22526
|
}
|
|
22518
22527
|
else
|
|
22519
|
-
|
|
22528
|
+
parser.setCurrIndex(parser.getXMLdata().indexOf(XMLConstants.TAG_CLOSE, parser.getCurrIndex()) + 1);
|
|
22520
22529
|
}
|
|
22521
22530
|
fillData_1(dataView, task, parser) {
|
|
22531
|
+
if (parser.getNextTag() == XMLConstants.MG_TAG_RECOMPUTE) {
|
|
22532
|
+
let currrentIndex = parser.getCurrIndex();
|
|
22533
|
+
let encoded = parser.ReadContentOfCurrentElement().trim();
|
|
22534
|
+
let decoded = Base64.decode(encoded.substr(0, encoded.length).trim());
|
|
22535
|
+
let newXmlData = parser.getXMLdata().replace(encoded.trim(), decoded);
|
|
22536
|
+
parser.setXMLdata(newXmlData);
|
|
22537
|
+
parser.setCurrIndex(currrentIndex);
|
|
22538
|
+
}
|
|
22522
22539
|
while (this.initInnerObjects(parser, parser.getNextTag(), dataView, task)) {
|
|
22523
22540
|
}
|
|
22524
22541
|
}
|
|
@@ -23283,10 +23300,12 @@ class Task extends TaskBase {
|
|
|
23283
23300
|
this.setDescriptor(valueStr);
|
|
23284
23301
|
break;
|
|
23285
23302
|
case ConstInterface.MG_ATTR_HAS_LOCATE:
|
|
23286
|
-
|
|
23303
|
+
if (+valueStr == 1)
|
|
23304
|
+
this.hasLocate = true;
|
|
23287
23305
|
break;
|
|
23288
23306
|
case ConstInterface.MG_ATTR_AS_PARENT:
|
|
23289
|
-
|
|
23307
|
+
if (+valueStr == 1)
|
|
23308
|
+
this.ModeAsParent = true;
|
|
23290
23309
|
break;
|
|
23291
23310
|
case ConstInterface.MG_ATTR_TASK_UNIQUE_SORT:
|
|
23292
23311
|
this.UniqueSort = valueStr[0];
|
|
@@ -23622,6 +23641,7 @@ class Task extends TaskBase {
|
|
|
23622
23641
|
result = yield this.DataviewManager.Execute(dataViewCommand);
|
|
23623
23642
|
if (!result.Success)
|
|
23624
23643
|
return null;
|
|
23644
|
+
this.ResumeSubformLayout();
|
|
23625
23645
|
}
|
|
23626
23646
|
nonInteractiveTask = yield this.StartSubTasks(moveToFirstControl, nonInteractiveTask, callByDestSubForm);
|
|
23627
23647
|
this.InStartProcess = false;
|
|
@@ -25315,16 +25335,18 @@ class Task extends TaskBase {
|
|
|
25315
25335
|
}
|
|
25316
25336
|
}
|
|
25317
25337
|
ComputeMainDisplay() {
|
|
25318
|
-
|
|
25319
|
-
|
|
25320
|
-
|
|
25321
|
-
|
|
25322
|
-
|
|
25338
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
25339
|
+
let propMainDisplay = this.getProp(PropInterface.PROP_TYPE_MAIN_DISPLAY);
|
|
25340
|
+
let mainDisplayIndex = yield propMainDisplay.getValueInt();
|
|
25341
|
+
mainDisplayIndex = this.GetRealMainDisplayIndexOnCurrentTask(mainDisplayIndex);
|
|
25342
|
+
this._forms.InitFormFromXmlString(mainDisplayIndex);
|
|
25343
|
+
this.EnsureValidForm();
|
|
25344
|
+
});
|
|
25323
25345
|
}
|
|
25324
25346
|
PrepareTaskForm() {
|
|
25325
25347
|
return __awaiter(this, void 0, void 0, function* () {
|
|
25326
25348
|
yield TaskServiceBase.PreparePropOpenTaskWindow(this);
|
|
25327
|
-
return RemoteTaskService.PreparePropMainDisplay(this);
|
|
25349
|
+
return yield RemoteTaskService.PreparePropMainDisplay(this);
|
|
25328
25350
|
});
|
|
25329
25351
|
}
|
|
25330
25352
|
FormIsLegal() {
|
|
@@ -25395,7 +25417,12 @@ class Task extends TaskBase {
|
|
|
25395
25417
|
let tokensVector = XmlParser.getTokens(RuntimeContextBase.Instance.Parser.getXMLsubstring(endTaskUrlIdx), XMLConstants.XML_ATTR_DELIM);
|
|
25396
25418
|
let taskCacheURL = tokensVector.get_Item(1);
|
|
25397
25419
|
let refListStr = tokensVector.get_Item(3);
|
|
25398
|
-
let taskContentOriginal =
|
|
25420
|
+
let taskContentOriginal = "";
|
|
25421
|
+
if (taskCacheURL.trim() != "") {
|
|
25422
|
+
if (taskCacheURL.startsWith("./"))
|
|
25423
|
+
taskCacheURL = NString.Replace(taskCacheURL, './', './assets/cache/');
|
|
25424
|
+
taskContentOriginal = yield Task.CommandsProcessor.GetContent(taskCacheURL, true);
|
|
25425
|
+
}
|
|
25399
25426
|
let taskContentFinal = new StringBuilder(xmlData.substr(0, RuntimeContextBase.Instance.Parser.getCurrIndex() - (ConstInterface.MG_TAG_TASKURL.length + 1)), taskContentOriginal.length);
|
|
25400
25427
|
let reflist = this.getReflist(refListStr, ';', true, -1);
|
|
25401
25428
|
let refListIdx = 0;
|
|
@@ -27685,7 +27712,7 @@ class EventsManager {
|
|
|
27685
27712
|
val = Manager.GetCtrlVal(ctrl);
|
|
27686
27713
|
task.CurrentEditingControl = null;
|
|
27687
27714
|
if (!task.cancelWasRaised() &&
|
|
27688
|
-
(ctrl.Type !== MgControlType.CTRL_TYPE_BROWSER && (!isNullOrUndefined(ctrl._field) && ctrl._field.getType() === StorageAttribute.DATE || val !== null) && typeof val != 'undefined' &&
|
|
27715
|
+
(ctrl.Type !== MgControlType.CTRL_TYPE_BROWSER && (!isNullOrUndefined(ctrl._field) && (ctrl._field.getType() === StorageAttribute.DATE || ctrl._field.getType() == StorageAttribute.NUMERIC) || val !== null) && typeof val != 'undefined' &&
|
|
27689
27716
|
!(yield ctrl.validateAndSetValue(val, true)))) {
|
|
27690
27717
|
this.setStopExecution(true);
|
|
27691
27718
|
return false;
|
|
@@ -30358,7 +30385,7 @@ class CommandsTable {
|
|
|
30358
30385
|
}
|
|
30359
30386
|
}
|
|
30360
30387
|
|
|
30361
|
-
let CurrentClientVersion = '4.900.0-dev490.
|
|
30388
|
+
let CurrentClientVersion = '4.900.0-dev490.241';
|
|
30362
30389
|
|
|
30363
30390
|
class ClientManager {
|
|
30364
30391
|
constructor() {
|
|
@@ -30627,7 +30654,7 @@ class ClientManager {
|
|
|
30627
30654
|
}
|
|
30628
30655
|
return pic;
|
|
30629
30656
|
}
|
|
30630
|
-
static GetFormattedValue(taskId, controlName, value) {
|
|
30657
|
+
static GetFormattedValue(taskId, controlName, value, rowId) {
|
|
30631
30658
|
let pic = null;
|
|
30632
30659
|
let task = MGDataCollection.Instance.GetTaskByID(taskId);
|
|
30633
30660
|
let control = null;
|
|
@@ -30635,7 +30662,12 @@ class ClientManager {
|
|
|
30635
30662
|
if (controlName !== null && task !== null)
|
|
30636
30663
|
control = task.getForm().GetCtrl(controlName);
|
|
30637
30664
|
if (control != null && control.DataType == StorageAttribute.NUMERIC) {
|
|
30638
|
-
|
|
30665
|
+
if (control.isRepeatable() && control.getProp(PropInterface.PROP_TYPE_FORMAT).isExpression()) {
|
|
30666
|
+
let picval = control.getProp(PropInterface.PROP_TYPE_FORMAT).getPrevValue(+rowId);
|
|
30667
|
+
pic = new PIC(picval, StorageAttribute.NUMERIC, control.getForm().getTask().getCompIdx());
|
|
30668
|
+
}
|
|
30669
|
+
else
|
|
30670
|
+
pic = control.getPIC();
|
|
30639
30671
|
let dispValue = String(value);
|
|
30640
30672
|
let newPic = pic.getUnformattedNumericPic();
|
|
30641
30673
|
let num = DisplayConvertor.Instance.toNum(dispValue, newPic, 0);
|
|
@@ -30738,8 +30770,8 @@ class MagicBridge {
|
|
|
30738
30770
|
static GetControlPictureMask(taskId, controlName) {
|
|
30739
30771
|
return ClientManager.GetControlPictureMask(taskId, controlName);
|
|
30740
30772
|
}
|
|
30741
|
-
static GetFormattedValue(taskId, controlName, value) {
|
|
30742
|
-
return ClientManager.GetFormattedValue(taskId, controlName, value);
|
|
30773
|
+
static GetFormattedValue(taskId, controlName, value, rowId) {
|
|
30774
|
+
return ClientManager.GetFormattedValue(taskId, controlName, value, rowId);
|
|
30743
30775
|
}
|
|
30744
30776
|
static GetRangedValue(taskId, controlName, value) {
|
|
30745
30777
|
return ClientManager.GetRangedValue(taskId, controlName, value);
|