@magic-xpa/engine 4.900.0-dev490.25 → 4.900.0-dev490.250

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.
@@ -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,{"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 === 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"]}
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
- this._subformTaskId = valueStr;
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.substring(this._mlsContent.length - MLS_EOF_CHARS_TO_READ, 8);
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 line = 0; line < linePairs * 2; line += 2) {
6320
- if (this._mlsStrings.get_Item(tokens[line].toString()) == null)
6321
- this._mlsStrings.set_Item(tokens[line].toString(), tokens[line + 1].toString());
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
- this.CacheTableFldIdx = NNumber.Parse(data[1]);
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
- task.ComputeMainDisplay();
20992
- return task.FormIsLegal() ? ReturnResult.SuccessfulResult : new ReturnResult(MsgInterface.BRKTAB_STR_ERR_FORM);
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 (TableCacheManager.Instance.TableExists(valueStr))
21398
- this._table = TableCacheManager.Instance.GetTableById(valueStr);
21399
- else {
21400
- this._table = new TableCache(valueStr);
21401
- TableCacheManager.Instance.InsertTable(this._table);
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
- this._table.SetTableIdent(valueStr);
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
- throw new ApplicationException("in RecomputeTable.fillData() invalid task id: ");
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
- this.hasLocate = true;
23306
+ if (+valueStr == 1)
23307
+ this.hasLocate = true;
23287
23308
  break;
23288
23309
  case ConstInterface.MG_ATTR_AS_PARENT:
23289
- this.ModeAsParent = true;
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
- let propMainDisplay = this.getProp(PropInterface.PROP_TYPE_MAIN_DISPLAY);
25319
- let mainDisplayIndex = propMainDisplay.GetComputedValueInteger();
25320
- mainDisplayIndex = this.GetRealMainDisplayIndexOnCurrentTask(mainDisplayIndex);
25321
- this._forms.InitFormFromXmlString(mainDisplayIndex);
25322
- this.EnsureValidForm();
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 = yield Task.CommandsProcessor.GetContent(taskCacheURL, true);
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.25';
30391
+ let CurrentClientVersion = '4.900.0-dev490.250';
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
- pic = control.getPIC();
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);