@magic-xpa/engine 4.900.0-dev490.28 → 4.900.0-dev490.280
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 +10 -5
- 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 +67 -32
- package/fesm2015/magic-xpa-engine.mjs.map +1 -1
- package/fesm2020/magic-xpa-engine.mjs +60 -29
- 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();
|
|
@@ -6312,17 +6313,22 @@ class LanguageData {
|
|
|
6312
6313
|
if (this._mlsContent.length > 0) {
|
|
6313
6314
|
let linePairs = 0;
|
|
6314
6315
|
let srcLine = this._mlsContent + 3;
|
|
6316
|
+
let transLine;
|
|
6315
6317
|
this._mlsStrings = new Hashtable();
|
|
6316
|
-
let linesStr = this._mlsContent.
|
|
6318
|
+
let linesStr = this._mlsContent.substr(this._mlsContent.length - MLS_EOF_CHARS_TO_READ, 8);
|
|
6317
6319
|
linePairs = parseInt(linesStr.toString(), 16);
|
|
6318
6320
|
let tokens = StrUtil.tokenize(srcLine.toString(), "\n");
|
|
6319
|
-
for (let
|
|
6320
|
-
|
|
6321
|
-
|
|
6321
|
+
for (let pairNum = 0; pairNum < linePairs * 2; pairNum += 2) {
|
|
6322
|
+
srcLine = tokens[pairNum].substr(0, tokens[pairNum].length - 1);
|
|
6323
|
+
transLine = tokens[pairNum + 1].substr(0, tokens[pairNum + 1].length - 1);
|
|
6324
|
+
if (this._mlsStrings.get_Item(srcLine.toString()) == null)
|
|
6325
|
+
this._mlsStrings.set_Item(srcLine.toString(), transLine);
|
|
6322
6326
|
}
|
|
6323
6327
|
}
|
|
6324
6328
|
}
|
|
6325
6329
|
else if (this._mlsFileUrl != null) {
|
|
6330
|
+
if (this._mlsFileUrl.startsWith("./"))
|
|
6331
|
+
this._mlsFileUrl = NString.Replace(this._mlsFileUrl, './', './assets/cache/');
|
|
6326
6332
|
let contentStr = yield CommandsProcessorManager.GetContent(this._mlsFileUrl, true);
|
|
6327
6333
|
let buffer = contentStr;
|
|
6328
6334
|
if (buffer != null && buffer.length > 0) {
|
|
@@ -10362,7 +10368,7 @@ class CookieService {
|
|
|
10362
10368
|
var cookie = cookies[i];
|
|
10363
10369
|
var eqPos = cookie.indexOf('=');
|
|
10364
10370
|
var name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
|
|
10365
|
-
if (cookieName === decodeURI(name)) {
|
|
10371
|
+
if (cookieName === NString.TrimStart(decodeURI(name))) {
|
|
10366
10372
|
document.cookie = name + '=;expires=Thu, 01 Jan 1970 00:00:00 GMT';
|
|
10367
10373
|
return true;
|
|
10368
10374
|
}
|
|
@@ -14498,7 +14504,7 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
|
|
|
14498
14504
|
}
|
|
14499
14505
|
path = args[3];
|
|
14500
14506
|
domain = args[4];
|
|
14501
|
-
resVal.BoolVal = CookieService.setCookie(cookieName, args[0], nativeDt, path, domain, secure, sameSite);
|
|
14507
|
+
resVal.BoolVal = CookieService.setCookie(cookieName, (args[0] != null ? args[0].toString() : ""), nativeDt, path, domain, secure, sameSite);
|
|
14502
14508
|
}
|
|
14503
14509
|
eval_op_get_cookie(cookieName, resVal) {
|
|
14504
14510
|
resVal.StrVal = CookieService.getCookie(cookieName);
|
|
@@ -16586,7 +16592,8 @@ class Field extends FieldBase {
|
|
|
16586
16592
|
}
|
|
16587
16593
|
break;
|
|
16588
16594
|
case ConstInterface.MG_ATTR_CHACHED_FLD_ID:
|
|
16589
|
-
|
|
16595
|
+
if (data[0] != "")
|
|
16596
|
+
this.CacheTableFldIdx = NNumber.Parse(data[1]);
|
|
16590
16597
|
break;
|
|
16591
16598
|
case ConstInterface.MG_ATTR_LOCATE:
|
|
16592
16599
|
this.Locate = new Boundary(this.getTask(), NNumber.Parse(data[1]), NNumber.Parse(data[0]), this.getType(), this.getSize(), this.CacheTableFldIdx);
|
|
@@ -20988,8 +20995,10 @@ class RemoteTaskService extends TaskServiceBase {
|
|
|
20988
20995
|
return OwnerTransactionTask;
|
|
20989
20996
|
}
|
|
20990
20997
|
static PreparePropMainDisplay(task) {
|
|
20991
|
-
|
|
20992
|
-
|
|
20998
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
20999
|
+
yield task.ComputeMainDisplay();
|
|
21000
|
+
return task.FormIsLegal() ? ReturnResult.SuccessfulResult : new ReturnResult(MsgInterface.BRKTAB_STR_ERR_FORM);
|
|
21001
|
+
});
|
|
20993
21002
|
}
|
|
20994
21003
|
}
|
|
20995
21004
|
|
|
@@ -21394,15 +21403,18 @@ class RemoteDataviewHeader extends DataviewHeaderBase {
|
|
|
21394
21403
|
setAttribute(attribute, valueStr) {
|
|
21395
21404
|
switch (attribute) {
|
|
21396
21405
|
case ConstInterface.MG_ATTR_CACHED_TABLE:
|
|
21397
|
-
if (
|
|
21398
|
-
|
|
21399
|
-
|
|
21400
|
-
|
|
21401
|
-
|
|
21406
|
+
if (valueStr != "") {
|
|
21407
|
+
if (TableCacheManager.Instance.TableExists(valueStr))
|
|
21408
|
+
this._table = TableCacheManager.Instance.GetTableById(valueStr);
|
|
21409
|
+
else {
|
|
21410
|
+
this._table = new TableCache(valueStr);
|
|
21411
|
+
TableCacheManager.Instance.InsertTable(this._table);
|
|
21412
|
+
}
|
|
21402
21413
|
}
|
|
21403
21414
|
break;
|
|
21404
21415
|
case ConstInterface.MG_ATTR_IDENT:
|
|
21405
|
-
|
|
21416
|
+
if (valueStr != "")
|
|
21417
|
+
this._table.SetTableIdent(valueStr);
|
|
21406
21418
|
break;
|
|
21407
21419
|
default:
|
|
21408
21420
|
super.setAttribute(attribute, valueStr);
|
|
@@ -22516,9 +22528,17 @@ class RecomputeTable {
|
|
|
22516
22528
|
this.fillData_1(task.DataView, task, parser);
|
|
22517
22529
|
}
|
|
22518
22530
|
else
|
|
22519
|
-
|
|
22531
|
+
parser.setCurrIndex(parser.getXMLdata().indexOf(XMLConstants.TAG_CLOSE, parser.getCurrIndex()) + 1);
|
|
22520
22532
|
}
|
|
22521
22533
|
fillData_1(dataView, task, parser) {
|
|
22534
|
+
if (parser.getNextTag() == XMLConstants.MG_TAG_RECOMPUTE) {
|
|
22535
|
+
let currrentIndex = parser.getCurrIndex();
|
|
22536
|
+
let encoded = parser.ReadContentOfCurrentElement().trim();
|
|
22537
|
+
let decoded = Base64.decode(encoded.substr(0, encoded.length).trim());
|
|
22538
|
+
let newXmlData = parser.getXMLdata().replace(encoded.trim(), decoded);
|
|
22539
|
+
parser.setXMLdata(newXmlData);
|
|
22540
|
+
parser.setCurrIndex(currrentIndex);
|
|
22541
|
+
}
|
|
22522
22542
|
while (this.initInnerObjects(parser, parser.getNextTag(), dataView, task)) {
|
|
22523
22543
|
}
|
|
22524
22544
|
}
|
|
@@ -23283,10 +23303,12 @@ class Task extends TaskBase {
|
|
|
23283
23303
|
this.setDescriptor(valueStr);
|
|
23284
23304
|
break;
|
|
23285
23305
|
case ConstInterface.MG_ATTR_HAS_LOCATE:
|
|
23286
|
-
|
|
23306
|
+
if (+valueStr == 1)
|
|
23307
|
+
this.hasLocate = true;
|
|
23287
23308
|
break;
|
|
23288
23309
|
case ConstInterface.MG_ATTR_AS_PARENT:
|
|
23289
|
-
|
|
23310
|
+
if (+valueStr == 1)
|
|
23311
|
+
this.ModeAsParent = true;
|
|
23290
23312
|
break;
|
|
23291
23313
|
case ConstInterface.MG_ATTR_TASK_UNIQUE_SORT:
|
|
23292
23314
|
this.UniqueSort = valueStr[0];
|
|
@@ -23622,6 +23644,7 @@ class Task extends TaskBase {
|
|
|
23622
23644
|
result = yield this.DataviewManager.Execute(dataViewCommand);
|
|
23623
23645
|
if (!result.Success)
|
|
23624
23646
|
return null;
|
|
23647
|
+
this.ResumeSubformLayout();
|
|
23625
23648
|
}
|
|
23626
23649
|
nonInteractiveTask = yield this.StartSubTasks(moveToFirstControl, nonInteractiveTask, callByDestSubForm);
|
|
23627
23650
|
this.InStartProcess = false;
|
|
@@ -25315,16 +25338,18 @@ class Task extends TaskBase {
|
|
|
25315
25338
|
}
|
|
25316
25339
|
}
|
|
25317
25340
|
ComputeMainDisplay() {
|
|
25318
|
-
|
|
25319
|
-
|
|
25320
|
-
|
|
25321
|
-
|
|
25322
|
-
|
|
25341
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
25342
|
+
let propMainDisplay = this.getProp(PropInterface.PROP_TYPE_MAIN_DISPLAY);
|
|
25343
|
+
let mainDisplayIndex = yield propMainDisplay.getValueInt();
|
|
25344
|
+
mainDisplayIndex = this.GetRealMainDisplayIndexOnCurrentTask(mainDisplayIndex);
|
|
25345
|
+
this._forms.InitFormFromXmlString(mainDisplayIndex);
|
|
25346
|
+
this.EnsureValidForm();
|
|
25347
|
+
});
|
|
25323
25348
|
}
|
|
25324
25349
|
PrepareTaskForm() {
|
|
25325
25350
|
return __awaiter(this, void 0, void 0, function* () {
|
|
25326
25351
|
yield TaskServiceBase.PreparePropOpenTaskWindow(this);
|
|
25327
|
-
return RemoteTaskService.PreparePropMainDisplay(this);
|
|
25352
|
+
return yield RemoteTaskService.PreparePropMainDisplay(this);
|
|
25328
25353
|
});
|
|
25329
25354
|
}
|
|
25330
25355
|
FormIsLegal() {
|
|
@@ -25395,7 +25420,12 @@ class Task extends TaskBase {
|
|
|
25395
25420
|
let tokensVector = XmlParser.getTokens(RuntimeContextBase.Instance.Parser.getXMLsubstring(endTaskUrlIdx), XMLConstants.XML_ATTR_DELIM);
|
|
25396
25421
|
let taskCacheURL = tokensVector.get_Item(1);
|
|
25397
25422
|
let refListStr = tokensVector.get_Item(3);
|
|
25398
|
-
let taskContentOriginal =
|
|
25423
|
+
let taskContentOriginal = "";
|
|
25424
|
+
if (taskCacheURL.trim() != "") {
|
|
25425
|
+
if (taskCacheURL.startsWith("./"))
|
|
25426
|
+
taskCacheURL = NString.Replace(taskCacheURL, './', './assets/cache/');
|
|
25427
|
+
taskContentOriginal = yield Task.CommandsProcessor.GetContent(taskCacheURL, true);
|
|
25428
|
+
}
|
|
25399
25429
|
let taskContentFinal = new StringBuilder(xmlData.substr(0, RuntimeContextBase.Instance.Parser.getCurrIndex() - (ConstInterface.MG_TAG_TASKURL.length + 1)), taskContentOriginal.length);
|
|
25400
25430
|
let reflist = this.getReflist(refListStr, ';', true, -1);
|
|
25401
25431
|
let refListIdx = 0;
|
|
@@ -27685,7 +27715,7 @@ class EventsManager {
|
|
|
27685
27715
|
val = Manager.GetCtrlVal(ctrl);
|
|
27686
27716
|
task.CurrentEditingControl = null;
|
|
27687
27717
|
if (!task.cancelWasRaised() &&
|
|
27688
|
-
(ctrl.Type !== MgControlType.CTRL_TYPE_BROWSER && (!isNullOrUndefined(ctrl._field) && ctrl._field.getType() === StorageAttribute.DATE || val !== null) && typeof val != 'undefined' &&
|
|
27718
|
+
(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
27719
|
!(yield ctrl.validateAndSetValue(val, true)))) {
|
|
27690
27720
|
this.setStopExecution(true);
|
|
27691
27721
|
return false;
|
|
@@ -30358,7 +30388,7 @@ class CommandsTable {
|
|
|
30358
30388
|
}
|
|
30359
30389
|
}
|
|
30360
30390
|
|
|
30361
|
-
let CurrentClientVersion = '4.900.0-dev490.
|
|
30391
|
+
let CurrentClientVersion = '4.900.0-dev490.280';
|
|
30362
30392
|
|
|
30363
30393
|
class ClientManager {
|
|
30364
30394
|
constructor() {
|
|
@@ -30627,7 +30657,7 @@ class ClientManager {
|
|
|
30627
30657
|
}
|
|
30628
30658
|
return pic;
|
|
30629
30659
|
}
|
|
30630
|
-
static GetFormattedValue(taskId, controlName, value) {
|
|
30660
|
+
static GetFormattedValue(taskId, controlName, value, rowId) {
|
|
30631
30661
|
let pic = null;
|
|
30632
30662
|
let task = MGDataCollection.Instance.GetTaskByID(taskId);
|
|
30633
30663
|
let control = null;
|
|
@@ -30635,7 +30665,12 @@ class ClientManager {
|
|
|
30635
30665
|
if (controlName !== null && task !== null)
|
|
30636
30666
|
control = task.getForm().GetCtrl(controlName);
|
|
30637
30667
|
if (control != null && control.DataType == StorageAttribute.NUMERIC) {
|
|
30638
|
-
|
|
30668
|
+
if (control.isRepeatable() && control.getProp(PropInterface.PROP_TYPE_FORMAT).isExpression()) {
|
|
30669
|
+
let picval = control.getProp(PropInterface.PROP_TYPE_FORMAT).getPrevValue(+rowId);
|
|
30670
|
+
pic = new PIC(picval, StorageAttribute.NUMERIC, control.getForm().getTask().getCompIdx());
|
|
30671
|
+
}
|
|
30672
|
+
else
|
|
30673
|
+
pic = control.getPIC();
|
|
30639
30674
|
let dispValue = String(value);
|
|
30640
30675
|
let newPic = pic.getUnformattedNumericPic();
|
|
30641
30676
|
let num = DisplayConvertor.Instance.toNum(dispValue, newPic, 0);
|
|
@@ -30738,8 +30773,8 @@ class MagicBridge {
|
|
|
30738
30773
|
static GetControlPictureMask(taskId, controlName) {
|
|
30739
30774
|
return ClientManager.GetControlPictureMask(taskId, controlName);
|
|
30740
30775
|
}
|
|
30741
|
-
static GetFormattedValue(taskId, controlName, value) {
|
|
30742
|
-
return ClientManager.GetFormattedValue(taskId, controlName, value);
|
|
30776
|
+
static GetFormattedValue(taskId, controlName, value, rowId) {
|
|
30777
|
+
return ClientManager.GetFormattedValue(taskId, controlName, value, rowId);
|
|
30743
30778
|
}
|
|
30744
30779
|
static GetRangedValue(taskId, controlName, value) {
|
|
30745
30780
|
return ClientManager.GetRangedValue(taskId, controlName, value);
|