@magic-xpa/engine 4.900.0-dev490.22 → 4.900.0-dev490.221
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/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/Operation.mjs +3 -3
- 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 -30
- package/fesm2015/magic-xpa-engine.mjs.map +1 -1
- package/fesm2020/magic-xpa-engine.mjs +53 -27
- 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":"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","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();
|
|
@@ -9469,8 +9470,8 @@ class Operation {
|
|
|
9469
9470
|
if (rtEvnt !== null) {
|
|
9470
9471
|
this._routeParams = rtEvnt.getRouteParamList();
|
|
9471
9472
|
if ((yield rtEvnt.getArgList().getArg(0).getValue(StorageAttribute.ALPHA, 0)).trim() === this._routerPath &&
|
|
9472
|
-
((rtEvnt.getArgList().getArg(1).skipArg()) ||
|
|
9473
|
-
(yield rtEvnt.getArgList().getArg(1).getValue(StorageAttribute.ALPHA, 0)).trim() === this._originalRouterOutletName))
|
|
9473
|
+
((rtEvnt.getArgList().getArg(1).skipArg() && destSubForm === this._task.getForm().DefaultRouterOutlet) ||
|
|
9474
|
+
(!rtEvnt.getArgList().getArg(1).skipArg() && (yield rtEvnt.getArgList().getArg(1).getValue(StorageAttribute.ALPHA, 0)).trim() === this._originalRouterOutletName)))
|
|
9474
9475
|
canRoute = true;
|
|
9475
9476
|
if (!canRoute)
|
|
9476
9477
|
return false;
|
|
@@ -10362,7 +10363,7 @@ class CookieService {
|
|
|
10362
10363
|
var cookie = cookies[i];
|
|
10363
10364
|
var eqPos = cookie.indexOf('=');
|
|
10364
10365
|
var name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
|
|
10365
|
-
if (cookieName === decodeURI(name)) {
|
|
10366
|
+
if (cookieName === NString.TrimStart(decodeURI(name))) {
|
|
10366
10367
|
document.cookie = name + '=;expires=Thu, 01 Jan 1970 00:00:00 GMT';
|
|
10367
10368
|
return true;
|
|
10368
10369
|
}
|
|
@@ -14498,7 +14499,7 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
|
|
|
14498
14499
|
}
|
|
14499
14500
|
path = args[3];
|
|
14500
14501
|
domain = args[4];
|
|
14501
|
-
resVal.BoolVal = CookieService.setCookie(cookieName, args[0], nativeDt, path, domain, secure, sameSite);
|
|
14502
|
+
resVal.BoolVal = CookieService.setCookie(cookieName, (args[0] != null ? args[0].toString() : ""), nativeDt, path, domain, secure, sameSite);
|
|
14502
14503
|
}
|
|
14503
14504
|
eval_op_get_cookie(cookieName, resVal) {
|
|
14504
14505
|
resVal.StrVal = CookieService.getCookie(cookieName);
|
|
@@ -16586,7 +16587,8 @@ class Field extends FieldBase {
|
|
|
16586
16587
|
}
|
|
16587
16588
|
break;
|
|
16588
16589
|
case ConstInterface.MG_ATTR_CHACHED_FLD_ID:
|
|
16589
|
-
|
|
16590
|
+
if (data[0] != "")
|
|
16591
|
+
this.CacheTableFldIdx = NNumber.Parse(data[1]);
|
|
16590
16592
|
break;
|
|
16591
16593
|
case ConstInterface.MG_ATTR_LOCATE:
|
|
16592
16594
|
this.Locate = new Boundary(this.getTask(), NNumber.Parse(data[1]), NNumber.Parse(data[0]), this.getType(), this.getSize(), this.CacheTableFldIdx);
|
|
@@ -20988,8 +20990,10 @@ class RemoteTaskService extends TaskServiceBase {
|
|
|
20988
20990
|
return OwnerTransactionTask;
|
|
20989
20991
|
}
|
|
20990
20992
|
static PreparePropMainDisplay(task) {
|
|
20991
|
-
|
|
20992
|
-
|
|
20993
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
20994
|
+
yield task.ComputeMainDisplay();
|
|
20995
|
+
return task.FormIsLegal() ? ReturnResult.SuccessfulResult : new ReturnResult(MsgInterface.BRKTAB_STR_ERR_FORM);
|
|
20996
|
+
});
|
|
20993
20997
|
}
|
|
20994
20998
|
}
|
|
20995
20999
|
|
|
@@ -21394,15 +21398,18 @@ class RemoteDataviewHeader extends DataviewHeaderBase {
|
|
|
21394
21398
|
setAttribute(attribute, valueStr) {
|
|
21395
21399
|
switch (attribute) {
|
|
21396
21400
|
case ConstInterface.MG_ATTR_CACHED_TABLE:
|
|
21397
|
-
if (
|
|
21398
|
-
|
|
21399
|
-
|
|
21400
|
-
|
|
21401
|
-
|
|
21401
|
+
if (valueStr != "") {
|
|
21402
|
+
if (TableCacheManager.Instance.TableExists(valueStr))
|
|
21403
|
+
this._table = TableCacheManager.Instance.GetTableById(valueStr);
|
|
21404
|
+
else {
|
|
21405
|
+
this._table = new TableCache(valueStr);
|
|
21406
|
+
TableCacheManager.Instance.InsertTable(this._table);
|
|
21407
|
+
}
|
|
21402
21408
|
}
|
|
21403
21409
|
break;
|
|
21404
21410
|
case ConstInterface.MG_ATTR_IDENT:
|
|
21405
|
-
|
|
21411
|
+
if (valueStr != "")
|
|
21412
|
+
this._table.SetTableIdent(valueStr);
|
|
21406
21413
|
break;
|
|
21407
21414
|
default:
|
|
21408
21415
|
super.setAttribute(attribute, valueStr);
|
|
@@ -22516,9 +22523,17 @@ class RecomputeTable {
|
|
|
22516
22523
|
this.fillData_1(task.DataView, task, parser);
|
|
22517
22524
|
}
|
|
22518
22525
|
else
|
|
22519
|
-
|
|
22526
|
+
parser.setCurrIndex(parser.getXMLdata().indexOf(XMLConstants.TAG_CLOSE, parser.getCurrIndex()) + 1);
|
|
22520
22527
|
}
|
|
22521
22528
|
fillData_1(dataView, task, parser) {
|
|
22529
|
+
if (parser.getNextTag() == XMLConstants.MG_TAG_RECOMPUTE) {
|
|
22530
|
+
let currrentIndex = parser.getCurrIndex();
|
|
22531
|
+
let encoded = parser.ReadContentOfCurrentElement().trim();
|
|
22532
|
+
let decoded = Base64.decode(encoded.substr(0, encoded.length).trim());
|
|
22533
|
+
let newXmlData = parser.getXMLdata().replace(encoded.trim(), decoded);
|
|
22534
|
+
parser.setXMLdata(newXmlData);
|
|
22535
|
+
parser.setCurrIndex(currrentIndex);
|
|
22536
|
+
}
|
|
22522
22537
|
while (this.initInnerObjects(parser, parser.getNextTag(), dataView, task)) {
|
|
22523
22538
|
}
|
|
22524
22539
|
}
|
|
@@ -23283,10 +23298,12 @@ class Task extends TaskBase {
|
|
|
23283
23298
|
this.setDescriptor(valueStr);
|
|
23284
23299
|
break;
|
|
23285
23300
|
case ConstInterface.MG_ATTR_HAS_LOCATE:
|
|
23286
|
-
|
|
23301
|
+
if (+valueStr == 1)
|
|
23302
|
+
this.hasLocate = true;
|
|
23287
23303
|
break;
|
|
23288
23304
|
case ConstInterface.MG_ATTR_AS_PARENT:
|
|
23289
|
-
|
|
23305
|
+
if (+valueStr == 1)
|
|
23306
|
+
this.ModeAsParent = true;
|
|
23290
23307
|
break;
|
|
23291
23308
|
case ConstInterface.MG_ATTR_TASK_UNIQUE_SORT:
|
|
23292
23309
|
this.UniqueSort = valueStr[0];
|
|
@@ -23622,6 +23639,7 @@ class Task extends TaskBase {
|
|
|
23622
23639
|
result = yield this.DataviewManager.Execute(dataViewCommand);
|
|
23623
23640
|
if (!result.Success)
|
|
23624
23641
|
return null;
|
|
23642
|
+
this.ResumeSubformLayout();
|
|
23625
23643
|
}
|
|
23626
23644
|
nonInteractiveTask = yield this.StartSubTasks(moveToFirstControl, nonInteractiveTask, callByDestSubForm);
|
|
23627
23645
|
this.InStartProcess = false;
|
|
@@ -25315,16 +25333,18 @@ class Task extends TaskBase {
|
|
|
25315
25333
|
}
|
|
25316
25334
|
}
|
|
25317
25335
|
ComputeMainDisplay() {
|
|
25318
|
-
|
|
25319
|
-
|
|
25320
|
-
|
|
25321
|
-
|
|
25322
|
-
|
|
25336
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
25337
|
+
let propMainDisplay = this.getProp(PropInterface.PROP_TYPE_MAIN_DISPLAY);
|
|
25338
|
+
let mainDisplayIndex = yield propMainDisplay.getValueInt();
|
|
25339
|
+
mainDisplayIndex = this.GetRealMainDisplayIndexOnCurrentTask(mainDisplayIndex);
|
|
25340
|
+
this._forms.InitFormFromXmlString(mainDisplayIndex);
|
|
25341
|
+
this.EnsureValidForm();
|
|
25342
|
+
});
|
|
25323
25343
|
}
|
|
25324
25344
|
PrepareTaskForm() {
|
|
25325
25345
|
return __awaiter(this, void 0, void 0, function* () {
|
|
25326
25346
|
yield TaskServiceBase.PreparePropOpenTaskWindow(this);
|
|
25327
|
-
return RemoteTaskService.PreparePropMainDisplay(this);
|
|
25347
|
+
return yield RemoteTaskService.PreparePropMainDisplay(this);
|
|
25328
25348
|
});
|
|
25329
25349
|
}
|
|
25330
25350
|
FormIsLegal() {
|
|
@@ -25395,7 +25415,12 @@ class Task extends TaskBase {
|
|
|
25395
25415
|
let tokensVector = XmlParser.getTokens(RuntimeContextBase.Instance.Parser.getXMLsubstring(endTaskUrlIdx), XMLConstants.XML_ATTR_DELIM);
|
|
25396
25416
|
let taskCacheURL = tokensVector.get_Item(1);
|
|
25397
25417
|
let refListStr = tokensVector.get_Item(3);
|
|
25398
|
-
let taskContentOriginal =
|
|
25418
|
+
let taskContentOriginal = "";
|
|
25419
|
+
if (taskCacheURL.trim() != "") {
|
|
25420
|
+
if (taskCacheURL.startsWith("./"))
|
|
25421
|
+
taskCacheURL = NString.Replace(taskCacheURL, './', './assets/cache/');
|
|
25422
|
+
taskContentOriginal = yield Task.CommandsProcessor.GetContent(taskCacheURL, true);
|
|
25423
|
+
}
|
|
25399
25424
|
let taskContentFinal = new StringBuilder(xmlData.substr(0, RuntimeContextBase.Instance.Parser.getCurrIndex() - (ConstInterface.MG_TAG_TASKURL.length + 1)), taskContentOriginal.length);
|
|
25400
25425
|
let reflist = this.getReflist(refListStr, ';', true, -1);
|
|
25401
25426
|
let refListIdx = 0;
|
|
@@ -27685,7 +27710,7 @@ class EventsManager {
|
|
|
27685
27710
|
val = Manager.GetCtrlVal(ctrl);
|
|
27686
27711
|
task.CurrentEditingControl = null;
|
|
27687
27712
|
if (!task.cancelWasRaised() &&
|
|
27688
|
-
(ctrl.Type !== MgControlType.CTRL_TYPE_BROWSER && (!isNullOrUndefined(ctrl._field) && ctrl._field.getType() === StorageAttribute.DATE || val !== null) && typeof val != 'undefined' &&
|
|
27713
|
+
(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
27714
|
!(yield ctrl.validateAndSetValue(val, true)))) {
|
|
27690
27715
|
this.setStopExecution(true);
|
|
27691
27716
|
return false;
|
|
@@ -30358,7 +30383,7 @@ class CommandsTable {
|
|
|
30358
30383
|
}
|
|
30359
30384
|
}
|
|
30360
30385
|
|
|
30361
|
-
let CurrentClientVersion = '4.900.0-dev490.
|
|
30386
|
+
let CurrentClientVersion = '4.900.0-dev490.221';
|
|
30362
30387
|
|
|
30363
30388
|
class ClientManager {
|
|
30364
30389
|
constructor() {
|
|
@@ -30627,7 +30652,7 @@ class ClientManager {
|
|
|
30627
30652
|
}
|
|
30628
30653
|
return pic;
|
|
30629
30654
|
}
|
|
30630
|
-
static GetFormattedValue(taskId, controlName, value) {
|
|
30655
|
+
static GetFormattedValue(taskId, controlName, value, rowId) {
|
|
30631
30656
|
let pic = null;
|
|
30632
30657
|
let task = MGDataCollection.Instance.GetTaskByID(taskId);
|
|
30633
30658
|
let control = null;
|
|
@@ -30635,7 +30660,12 @@ class ClientManager {
|
|
|
30635
30660
|
if (controlName !== null && task !== null)
|
|
30636
30661
|
control = task.getForm().GetCtrl(controlName);
|
|
30637
30662
|
if (control != null && control.DataType == StorageAttribute.NUMERIC) {
|
|
30638
|
-
|
|
30663
|
+
if (control.isRepeatable() && control.getProp(PropInterface.PROP_TYPE_FORMAT).isExpression()) {
|
|
30664
|
+
let picval = control.getProp(PropInterface.PROP_TYPE_FORMAT).getPrevValue(+rowId);
|
|
30665
|
+
pic = new PIC(picval, StorageAttribute.NUMERIC, control.getForm().getTask().getCompIdx());
|
|
30666
|
+
}
|
|
30667
|
+
else
|
|
30668
|
+
pic = control.getPIC();
|
|
30639
30669
|
let dispValue = String(value);
|
|
30640
30670
|
let newPic = pic.getUnformattedNumericPic();
|
|
30641
30671
|
let num = DisplayConvertor.Instance.toNum(dispValue, newPic, 0);
|
|
@@ -30738,8 +30768,8 @@ class MagicBridge {
|
|
|
30738
30768
|
static GetControlPictureMask(taskId, controlName) {
|
|
30739
30769
|
return ClientManager.GetControlPictureMask(taskId, controlName);
|
|
30740
30770
|
}
|
|
30741
|
-
static GetFormattedValue(taskId, controlName, value) {
|
|
30742
|
-
return ClientManager.GetFormattedValue(taskId, controlName, value);
|
|
30771
|
+
static GetFormattedValue(taskId, controlName, value, rowId) {
|
|
30772
|
+
return ClientManager.GetFormattedValue(taskId, controlName, value, rowId);
|
|
30743
30773
|
}
|
|
30744
30774
|
static GetRangedValue(taskId, controlName, value) {
|
|
30745
30775
|
return ClientManager.GetRangedValue(taskId, controlName, value);
|