@magic-xpa/engine 4.1000.0-dev000.0 → 4.1000.0-dev4100.100

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.
@@ -99,7 +99,7 @@ export class MirrorPrmMap extends PrmMap {
99
99
  while (this.mirrorFromXML(parser.getNextTag(), parser)) {
100
100
  }
101
101
  }
102
- RestoreGlobalParams(xml) {
102
+ RestoreParams(xml) {
103
103
  let parser = new XmlParser(xml);
104
104
  while (this.mirrorFromXML(parser.getNextTag(), parser)) {
105
105
  }
@@ -148,4 +148,4 @@ export class MirrorPrmMap extends PrmMap {
148
148
  }
149
149
  }
150
150
  }
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PrmMap.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/util/PrmMap.ts"],"names":[],"mappings":"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","sourcesContent":["import { Dictionary, List, StringBuilder } from '@magic-xpa/mscorelib';\r\nimport { Logger, XMLConstants, XmlParser } from '@magic-xpa/utils';\r\nimport { ConstInterface } from '../ConstInterface';\r\nimport { IMirrorXML } from './IMirrorXML';\r\nimport {ParamParseResult} from \"./ParamParseResult\";\r\n\r\n\r\n/// <summary> This class manages a dictionary of variables. then name of the variable is the key\r\n/// </summary>\r\nexport class PrmMap<TValue extends IMirrorXML>{\r\n  values: Dictionary<TValue> = null;\r\n\r\n  /// <summary> get the value\r\n  ///\r\n  /// </summary>\r\n  /// <param name=\"s\"></param>\r\n  /// <returns></returns>\r\n  protected getvalue(s: string): TValue {\r\n    if (this.values.ContainsKey(s))\r\n      return this.values.get_Item(s);\r\n    else\r\n      return null;\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  setValue(s: string, v: TValue): void {\r\n    this.values.set_Item(s, v);\r\n  }\r\n\r\n  /// <summary> remove an entry\r\n  /// </summary>\r\n  remove(s: string): void {\r\n    this.values.Remove(s);\r\n  }\r\n\r\n  /// <summary> CTOR\r\n  /// </summary>\r\n  constructor() {\r\n      this.values = new Dictionary<TValue>();\r\n  }\r\n}\r\n\r\n/// <summary> This class manages the mirroring. It holds a list of changed values that need to be\r\n/// mirrored, and manages the writing of those values to an XML buffer\r\n/// </summary>\r\nexport class MirrorPrmMap<TValue extends IMirrorXML> extends PrmMap<TValue> {\r\n\r\n  // List of changed variables\r\n  protected changes: List<string> = null;\r\n\r\n  // Type of variables in the table - use as an id in the XML buffer\r\n  protected  mirroredID: string = null;\r\n\r\n  private type ;\r\n\r\n  /// <summary> CTOR\r\n  /// </summary>\r\n  constructor(type: new () => TValue) {\r\n    super();\r\n    this.type = type;\r\n    this.changes = new List<string>();\r\n  }\r\n\r\n  /// <summary>\r\n  /// create new instance of specified type\r\n  /// </summary>\r\n  private new(): TValue {\r\n    return new this.type();\r\n  }\r\n\r\n\r\n  setValue(s: string, v: TValue, addToChanges?: boolean): void {\r\n    if (arguments.length === 3)\r\n      this.setValue_0(s, v, addToChanges);\r\n    else\r\n      this.setValue_1(s, v);\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  private setValue_0(s: string, v: TValue, addToChanges: boolean): void {\r\n    if (addToChanges && !this.changes.Contains(s))\r\n      this.changes.push(s);\r\n    super.setValue(s, v);\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  private setValue_1(s: string, v: TValue): void {\r\n    if (!this.changes.Contains(s))\r\n      this.changes.push(s);\r\n    super.setValue(s, v);\r\n  }\r\n\r\n  /// <summary> remove\r\n  /// </summary>\r\n  remove(s: string): void {\r\n    if (!this.changes.Contains(s)) {\r\n      this.changes.push(s);\r\n    }\r\n    super.remove(s);\r\n  }\r\n\r\n  /// <summary>\r\n  /// write to an XML buff: write the ID and call each variable to write itself\r\n  /// </summary>\r\n  mirrorAllToXML(): string {\r\n    let xml: StringBuilder = new StringBuilder();\r\n\r\n\r\n    if (this.values != null) {\r\n\r\n      // write the id\r\n      xml.Append(\"<\" + this.mirroredID + \">\");\r\n\r\n      // loop on all variables\r\n      for (let key of this.values.Keys) {\r\n\r\n        if (this.CheckIfSystemReservedParam(key))\r\n          continue;\r\n        xml.Append(\"<\" + ConstInterface.MG_TAG_PARAM + \" \" +\r\n          XMLConstants.MG_ATTR_NAME + \"=\\\"\" + XmlParser.escape(key) + \"\\\" \");\r\n\r\n        // call the variable to write it's own data\r\n          xml.Append(this.values.get_Item(key).mirrorToXML());\r\n\r\n        xml.Append(XMLConstants.TAG_TERM);\r\n      }\r\n\r\n      xml.Append(\"</\" + this.mirroredID + \">\");\r\n    }\r\n    return xml.ToString();\r\n  }\r\n\r\n  /// <summary>\r\n  /// If system reserved param, then do not serialize for re-initialize session\r\n  /// </summary>\r\n  CheckIfSystemReservedParam(key: any): boolean\r\n  {\r\n    if (key == \"UTF8TRANS\" || key === \"REMOTE_HOST\" || key === \"REMOTE_ADDR\" ||\r\n      key === \"CTX\" || key === \"MGARG0\" || key === \"DATA\" || key === \"MGCURRENTREQUESTID\" ||\r\n      key === \"HTTP_MGXPARIAGLOBALUNIQUESESSIONID\" || key === \"MG_POST_BODY\")\r\n      return true;\r\n    else\r\n      return false;\r\n  }\r\n\r\n  /// <summary>\r\n  /// write to an XML buff: write the ID and call each changed variable to write itself\r\n  /// </summary>\r\n  mirrorToXML(): string {\r\n    let xml: StringBuilder = new StringBuilder();\r\n\r\n    if (this.changes.length > 0) {\r\n\r\n      // write the id\r\n      xml.Append(\"<\" + this.mirroredID + \">\");\r\n\r\n      // loop on all changed variables\r\n\r\n\r\n      this.changes.forEach(change => {\r\n\r\n        xml.Append(\"<\" + ConstInterface.MG_TAG_PARAM + \" \" +\r\n          XMLConstants.MG_ATTR_NAME + \"=\\\"\" + XmlParser.escape(change) + \"\\\" \");\r\n\r\n        if (this.values.ContainsKey(change))\r\n        // call the variable to write it's own data\r\n          xml.Append(this.values.get_Item(change).mirrorToXML());\r\n        else\r\n          xml.Append(\"removed=\\\"Y\\\"\");\r\n        xml.Append(\">\");\r\n      });\r\n\r\n      xml.Append(\"</\" + this.mirroredID + \">\");\r\n    }\r\n    this.changes.Clear();\r\n    return xml.ToString();\r\n  }\r\n\r\n  /// <summary> parse the XML and fill the data\r\n  /// </summary>\r\n  fillData(parser: XmlParser): void {\r\n    while (this.mirrorFromXML(parser.getNextTag(), parser)) {\r\n    }\r\n  }\r\n\r\n  RestoreGlobalParams (xml: string )\r\n  {\r\n    let parser: XmlParser = new XmlParser(xml);\r\n    while (this.mirrorFromXML(parser.getNextTag(), parser)) {\r\n    }\r\n  }\r\n\r\n  /// <summary> fill from XML\r\n  /// </summary>\r\n  /// <param name=\"foundTagName\"></param>\r\n  /// <param name=\"xmlParser\"></param>\r\n  /// <returns></returns>\r\n  mirrorFromXML(foundTagName: string, xmlParser: XmlParser): boolean {\r\n    if (foundTagName === null)\r\n      return false;\r\n\r\n    if (foundTagName === this.mirroredID) {\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      this.fillDataEntry(xmlParser);\r\n      return true;\r\n    }\r\n    else if (foundTagName === (\"/\" + this.mirroredID)) {\r\n      // After updating from the server, clear the changes list so they won't be sent again\r\n      this.changes.Clear();\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      return false;\r\n    }\r\n    else {\r\n      Logger.Instance.WriteExceptionToLogWithMsg(\"There is no such tag in MirrorPrmMap.mirrorFromXML(): \" + foundTagName);\r\n      return false;\r\n    }\r\n  }\r\n\r\n\r\n  /// <summary>\r\n  /// parse and fill the params, until the section ends\r\n  /// </summary>\r\n  fillDataEntry(xmlParser: XmlParser): void {\r\n    let nextTag: string = xmlParser.getNextTag();\r\n\r\n    while (nextTag === ConstInterface.MG_TAG_PARAM) {\r\n      let nameStart: number = xmlParser.getXMLdata().indexOf(XMLConstants.MG_ATTR_NAME + \"=\\\"\", xmlParser.getCurrIndex()) +\r\n        XMLConstants.MG_ATTR_NAME.length + 2;\r\n\r\n      xmlParser.setCurrIndex(nameStart);\r\n      let nameEnd: number = xmlParser.getXMLdata().indexOf(\"\\\"\", nameStart);\r\n\r\n      // get the variables data\r\n      let name: string = xmlParser.getXMLsubstring(nameEnd).trim();\r\n      xmlParser.setCurrIndex(nameEnd);\r\n\r\n      // create and init the new value\r\n      let newVal: TValue = this.new();\r\n\r\n      switch (newVal.init(name, xmlParser)) {\r\n        case ParamParseResult.OK:\r\n          this.values.set_Item(name, newVal);\r\n          break;\r\n        case ParamParseResult.TOUPPER:\r\n          this.values.set_Item(name.toUpperCase(), newVal);\r\n          break;\r\n        case ParamParseResult.DELETE:\r\n          this.values.Remove(name);\r\n          break;\r\n      }\r\n\r\n      // move to next tag\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      nextTag = xmlParser.getNextTag();\r\n    }\r\n  }\r\n}\r\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PrmMap.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/util/PrmMap.ts"],"names":[],"mappings":"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","sourcesContent":["import { Dictionary, List, StringBuilder } from '@magic-xpa/mscorelib';\r\nimport { Logger, XMLConstants, XmlParser } from '@magic-xpa/utils';\r\nimport { ConstInterface } from '../ConstInterface';\r\nimport { IMirrorXML } from './IMirrorXML';\r\nimport {ParamParseResult} from \"./ParamParseResult\";\r\n\r\n\r\n/// <summary> This class manages a dictionary of variables. then name of the variable is the key\r\n/// </summary>\r\nexport class PrmMap<TValue extends IMirrorXML>{\r\n  values: Dictionary<TValue> = null;\r\n\r\n  /// <summary> get the value\r\n  ///\r\n  /// </summary>\r\n  /// <param name=\"s\"></param>\r\n  /// <returns></returns>\r\n  protected getvalue(s: string): TValue {\r\n    if (this.values.ContainsKey(s))\r\n      return this.values.get_Item(s);\r\n    else\r\n      return null;\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  setValue(s: string, v: TValue): void {\r\n    this.values.set_Item(s, v);\r\n  }\r\n\r\n  /// <summary> remove an entry\r\n  /// </summary>\r\n  remove(s: string): void {\r\n    this.values.Remove(s);\r\n  }\r\n\r\n  /// <summary> CTOR\r\n  /// </summary>\r\n  constructor() {\r\n      this.values = new Dictionary<TValue>();\r\n  }\r\n}\r\n\r\n/// <summary> This class manages the mirroring. It holds a list of changed values that need to be\r\n/// mirrored, and manages the writing of those values to an XML buffer\r\n/// </summary>\r\nexport class MirrorPrmMap<TValue extends IMirrorXML> extends PrmMap<TValue> {\r\n\r\n  // List of changed variables\r\n  protected changes: List<string> = null;\r\n\r\n  // Type of variables in the table - use as an id in the XML buffer\r\n  protected  mirroredID: string = null;\r\n\r\n  private type ;\r\n\r\n  /// <summary> CTOR\r\n  /// </summary>\r\n  constructor(type: new () => TValue) {\r\n    super();\r\n    this.type = type;\r\n    this.changes = new List<string>();\r\n  }\r\n\r\n  /// <summary>\r\n  /// create new instance of specified type\r\n  /// </summary>\r\n  private new(): TValue {\r\n    return new this.type();\r\n  }\r\n\r\n\r\n  setValue(s: string, v: TValue, addToChanges?: boolean): void {\r\n    if (arguments.length === 3)\r\n      this.setValue_0(s, v, addToChanges);\r\n    else\r\n      this.setValue_1(s, v);\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  private setValue_0(s: string, v: TValue, addToChanges: boolean): void {\r\n    if (addToChanges && !this.changes.Contains(s))\r\n      this.changes.push(s);\r\n    super.setValue(s, v);\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  private setValue_1(s: string, v: TValue): void {\r\n    if (!this.changes.Contains(s))\r\n      this.changes.push(s);\r\n    super.setValue(s, v);\r\n  }\r\n\r\n  /// <summary> remove\r\n  /// </summary>\r\n  remove(s: string): void {\r\n    if (!this.changes.Contains(s)) {\r\n      this.changes.push(s);\r\n    }\r\n    super.remove(s);\r\n  }\r\n\r\n  /// <summary>\r\n  /// write to an XML buff: write the ID and call each variable to write itself\r\n  /// </summary>\r\n  mirrorAllToXML(): string {\r\n    let xml: StringBuilder = new StringBuilder();\r\n\r\n\r\n    if (this.values != null) {\r\n\r\n      // write the id\r\n      xml.Append(\"<\" + this.mirroredID + \">\");\r\n\r\n      // loop on all variables\r\n      for (let key of this.values.Keys) {\r\n\r\n        if (this.CheckIfSystemReservedParam(key))\r\n          continue;\r\n        xml.Append(\"<\" + ConstInterface.MG_TAG_PARAM + \" \" +\r\n          XMLConstants.MG_ATTR_NAME + \"=\\\"\" + XmlParser.escape(key) + \"\\\" \");\r\n\r\n        // call the variable to write it's own data\r\n          xml.Append(this.values.get_Item(key).mirrorToXML());\r\n\r\n        xml.Append(XMLConstants.TAG_TERM);\r\n      }\r\n\r\n      xml.Append(\"</\" + this.mirroredID + \">\");\r\n    }\r\n    return xml.ToString();\r\n  }\r\n\r\n  /// <summary>\r\n  /// If system reserved param, then do not serialize for re-initialize session\r\n  /// </summary>\r\n  CheckIfSystemReservedParam(key: any): boolean\r\n  {\r\n    if (key == \"UTF8TRANS\" || key === \"REMOTE_HOST\" || key === \"REMOTE_ADDR\" ||\r\n      key === \"CTX\" || key === \"MGARG0\" || key === \"DATA\" || key === \"MGCURRENTREQUESTID\" ||\r\n      key === \"HTTP_MGXPARIAGLOBALUNIQUESESSIONID\" || key === \"MG_POST_BODY\")\r\n      return true;\r\n    else\r\n      return false;\r\n  }\r\n\r\n  /// <summary>\r\n  /// write to an XML buff: write the ID and call each changed variable to write itself\r\n  /// </summary>\r\n  mirrorToXML(): string {\r\n    let xml: StringBuilder = new StringBuilder();\r\n\r\n    if (this.changes.length > 0) {\r\n\r\n      // write the id\r\n      xml.Append(\"<\" + this.mirroredID + \">\");\r\n\r\n      // loop on all changed variables\r\n\r\n\r\n      this.changes.forEach(change => {\r\n\r\n        xml.Append(\"<\" + ConstInterface.MG_TAG_PARAM + \" \" +\r\n          XMLConstants.MG_ATTR_NAME + \"=\\\"\" + XmlParser.escape(change) + \"\\\" \");\r\n\r\n        if (this.values.ContainsKey(change))\r\n        // call the variable to write it's own data\r\n          xml.Append(this.values.get_Item(change).mirrorToXML());\r\n        else\r\n          xml.Append(\"removed=\\\"Y\\\"\");\r\n        xml.Append(\">\");\r\n      });\r\n\r\n      xml.Append(\"</\" + this.mirroredID + \">\");\r\n    }\r\n    this.changes.Clear();\r\n    return xml.ToString();\r\n  }\r\n\r\n  /// <summary> parse the XML and fill the data\r\n  /// </summary>\r\n  fillData(parser: XmlParser): void {\r\n    while (this.mirrorFromXML(parser.getNextTag(), parser)) {\r\n    }\r\n  }\r\n\r\n  RestoreParams (xml: string )\r\n  {\r\n    let parser: XmlParser = new XmlParser(xml);\r\n    while (this.mirrorFromXML(parser.getNextTag(), parser)) {\r\n    }\r\n  }\r\n\r\n  /// <summary> fill from XML\r\n  /// </summary>\r\n  /// <param name=\"foundTagName\"></param>\r\n  /// <param name=\"xmlParser\"></param>\r\n  /// <returns></returns>\r\n  mirrorFromXML(foundTagName: string, xmlParser: XmlParser): boolean {\r\n    if (foundTagName === null)\r\n      return false;\r\n\r\n    if (foundTagName === this.mirroredID) {\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      this.fillDataEntry(xmlParser);\r\n      return true;\r\n    }\r\n    else if (foundTagName === (\"/\" + this.mirroredID)) {\r\n      // After updating from the server, clear the changes list so they won't be sent again\r\n      this.changes.Clear();\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      return false;\r\n    }\r\n    else {\r\n      Logger.Instance.WriteExceptionToLogWithMsg(\"There is no such tag in MirrorPrmMap.mirrorFromXML(): \" + foundTagName);\r\n      return false;\r\n    }\r\n  }\r\n\r\n\r\n  /// <summary>\r\n  /// parse and fill the params, until the section ends\r\n  /// </summary>\r\n  fillDataEntry(xmlParser: XmlParser): void {\r\n    let nextTag: string = xmlParser.getNextTag();\r\n\r\n    while (nextTag === ConstInterface.MG_TAG_PARAM) {\r\n      let nameStart: number = xmlParser.getXMLdata().indexOf(XMLConstants.MG_ATTR_NAME + \"=\\\"\", xmlParser.getCurrIndex()) +\r\n        XMLConstants.MG_ATTR_NAME.length + 2;\r\n\r\n      xmlParser.setCurrIndex(nameStart);\r\n      let nameEnd: number = xmlParser.getXMLdata().indexOf(\"\\\"\", nameStart);\r\n\r\n      // get the variables data\r\n      let name: string = xmlParser.getXMLsubstring(nameEnd).trim();\r\n      xmlParser.setCurrIndex(nameEnd);\r\n\r\n      // create and init the new value\r\n      let newVal: TValue = this.new();\r\n\r\n      switch (newVal.init(name, xmlParser)) {\r\n        case ParamParseResult.OK:\r\n          this.values.set_Item(name, newVal);\r\n          break;\r\n        case ParamParseResult.TOUPPER:\r\n          this.values.set_Item(name.toUpperCase(), newVal);\r\n          break;\r\n        case ParamParseResult.DELETE:\r\n          this.values.Remove(name);\r\n          break;\r\n      }\r\n\r\n      // move to next tag\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      nextTag = xmlParser.getNextTag();\r\n    }\r\n  }\r\n}\r\n"]}
@@ -476,6 +476,7 @@ ConstInterface.RC_TOKEN_DATA = "DATA=";
476
476
  ConstInterface.WEBCLIENT_REINITIALIZE_REQUEST = "WCREINITIALIZEREQUEST=Y";
477
477
  ConstInterface.MAIN_PROG_VIEW = "MainProgramsDataView";
478
478
  ConstInterface.GLOBAL_PARAM_LIST = "GlobalParamList";
479
+ ConstInterface.ENV_VAR_LIST = "EnvVarList";
479
480
  ConstInterface.LAST_EXCEPTION = "LastException";
480
481
  ConstInterface.CTX_REMOVED_FROM_SRVR = "CtxRemovedFromSrvr";
481
482
  ConstInterface.LAST_ROUTE_EVENT = "LastRouteEvent";
@@ -5274,10 +5275,12 @@ class RemoteCommandsProcessor extends CommandsProcessorBase {
5274
5275
  return __awaiter(this, void 0, void 0, function* () {
5275
5276
  let mainPrgViewStringForServer = yield this.BuildXMLForMainProgramDataView();
5276
5277
  let globalParamsString = AccessHelper.globalParams.mirrorAllToXML();
5278
+ let changedEnvVarList = AccessHelper.envParamsTable.mirrorAllToXML();
5277
5279
  let dataStorage = window.localStorage;
5278
5280
  dataStorage.setItem(ConstInterface.IS_SESSION_REINITIALIZING, "true");
5279
5281
  dataStorage.setItem(ConstInterface.MAIN_PROG_VIEW, mainPrgViewStringForServer.toString());
5280
5282
  dataStorage.setItem(ConstInterface.GLOBAL_PARAM_LIST, globalParamsString);
5283
+ dataStorage.setItem(ConstInterface.ENV_VAR_LIST, changedEnvVarList);
5281
5284
  dataStorage.setItem(ConstInterface.LAST_EXCEPTION, RemoteCommandsProcessor.lastExceptionMessage);
5282
5285
  if (RuntimeContextBase.Instance.RemovedContextFromServer)
5283
5286
  dataStorage.setItem(ConstInterface.CTX_REMOVED_FROM_SRVR, "1");
@@ -5514,6 +5517,7 @@ class RemoteCommandsProcessor extends CommandsProcessorBase {
5514
5517
  let reqBuf;
5515
5518
  let isInitialCall = sessionStage === CommandsProcessorBase_SessionStage.INITIAL;
5516
5519
  let globalParamsString = null;
5520
+ let envVarsString = null;
5517
5521
  if (this.DelayCommandExecution)
5518
5522
  return;
5519
5523
  if (Logger.Instance.LogLevel == Logger_LogLevels.RequestInfo && !isInitialCall)
@@ -5539,12 +5543,16 @@ class RemoteCommandsProcessor extends CommandsProcessorBase {
5539
5543
  let buffer = new StringBuilder();
5540
5544
  if (!RemoteCommandsProcessor.IsSessionReInitializing)
5541
5545
  buffer.Append(reqBuf);
5542
- if (RemoteCommandsProcessor.IsSessionReInitializing)
5546
+ if (RemoteCommandsProcessor.IsSessionReInitializing) {
5543
5547
  globalParamsString = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.GLOBAL_PARAM_LIST);
5544
- else
5548
+ envVarsString = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.ENV_VAR_LIST);
5549
+ }
5550
+ else {
5545
5551
  globalParamsString = AccessHelper.globalParams.mirrorToXML();
5552
+ envVarsString = AccessHelper.envParamsTable.mirrorToXML();
5553
+ }
5546
5554
  changes.Append(globalParamsString);
5547
- changes.Append(AccessHelper.envParamsTable.mirrorToXML());
5555
+ changes.Append(envVarsString);
5548
5556
  if (changes.Length > 0) {
5549
5557
  changes.Insert(0, "<" + ConstInterface.MG_TAG_ENV_CHANGES + ">");
5550
5558
  changes.Append("</" + ConstInterface.MG_TAG_ENV_CHANGES + ">");
@@ -5583,13 +5591,15 @@ class RemoteCommandsProcessor extends CommandsProcessorBase {
5583
5591
  dataStorage.removeItem(ConstInterface.IS_SESSION_REINITIALIZING);
5584
5592
  dataStorage.removeItem(ConstInterface.MAIN_PROG_VIEW);
5585
5593
  dataStorage.removeItem(ConstInterface.GLOBAL_PARAM_LIST);
5594
+ dataStorage.removeItem(ConstInterface.ENV_VAR_LIST);
5586
5595
  dataStorage.removeItem(ConstInterface.LAST_EXCEPTION);
5587
5596
  }
5588
5597
  }
5589
5598
  FlowMonitorQueue.Instance.enable(false);
5590
5599
  yield this.ProcessResponse(respBuf, AccessHelper.mgDataTable.currMgdID, null, res);
5591
5600
  if (RemoteCommandsProcessor.IsSessionReInitializing) {
5592
- AccessHelper.globalParams.RestoreGlobalParams(globalParamsString);
5601
+ AccessHelper.globalParams.RestoreParams(globalParamsString);
5602
+ AccessHelper.envParamsTable.RestoreParams(envVarsString);
5593
5603
  let dataStorage = window.localStorage;
5594
5604
  let ctxRemoved = dataStorage.getItem(ConstInterface.CTX_REMOVED_FROM_SRVR);
5595
5605
  if (ctxRemoved === "1") {
@@ -6918,7 +6928,7 @@ ExpressionDict.expDesc = [
6918
6928
  null,
6919
6929
  new ExpDesc('N', 0, 0, 0, "", false),
6920
6930
  null,
6921
- new ExpDesc('B', 0, 2, 2, "BN", false),
6931
+ null,
6922
6932
  new ExpDesc('B', 0, 2, 2, "V ", false),
6923
6933
  null,
6924
6934
  null,
@@ -7367,12 +7377,12 @@ ExpressionDict.expDesc = [
7367
7377
  null,
7368
7378
  new ExpDesc('A', 0, 1, 1, "A", false),
7369
7379
  new ExpDesc('N', 0, 2, 2, "AA", false),
7370
- new ExpDesc('B', 0, -2, -2, "V ", false),
7371
- new ExpDesc('B', 0, 1, 1, "N", false),
7372
- new ExpDesc('B', 0, -2, -2, "V ", false),
7373
- new ExpDesc('B', 0, 1, 1, "N", false),
7374
- new ExpDesc('B', 0, 2, 2, "VB", false),
7375
- new ExpDesc('B', 0, 1, 1, "N", false),
7380
+ null,
7381
+ null,
7382
+ null,
7383
+ null,
7384
+ null,
7385
+ null,
7376
7386
  new ExpDesc('N', 0, 1, 1, "N", false),
7377
7387
  null,
7378
7388
  null,
@@ -7459,48 +7469,6 @@ ExpressionDict.expDesc = [
7459
7469
  new ExpDesc('U', 0, 0, 0, '', false),
7460
7470
  ];
7461
7471
 
7462
- var DataViewCommandType;
7463
- (function (DataViewCommandType) {
7464
- DataViewCommandType[DataViewCommandType["Init"] = 0] = "Init";
7465
- DataViewCommandType[DataViewCommandType["Clear"] = 1] = "Clear";
7466
- DataViewCommandType[DataViewCommandType["Prepare"] = 2] = "Prepare";
7467
- DataViewCommandType[DataViewCommandType["FirstChunk"] = 3] = "FirstChunk";
7468
- DataViewCommandType[DataViewCommandType["RecomputeUnit"] = 4] = "RecomputeUnit";
7469
- DataViewCommandType[DataViewCommandType["ExecuteLocalUpdates"] = 5] = "ExecuteLocalUpdates";
7470
- DataViewCommandType[DataViewCommandType["InitDataControlViews"] = 6] = "InitDataControlViews";
7471
- DataViewCommandType[DataViewCommandType["OpenTransaction"] = 7] = "OpenTransaction";
7472
- DataViewCommandType[DataViewCommandType["CloseTransaction"] = 8] = "CloseTransaction";
7473
- DataViewCommandType[DataViewCommandType["SetTransactionState"] = 9] = "SetTransactionState";
7474
- DataViewCommandType[DataViewCommandType["AddUserRange"] = 10] = "AddUserRange";
7475
- DataViewCommandType[DataViewCommandType["ResetUserRange"] = 11] = "ResetUserRange";
7476
- DataViewCommandType[DataViewCommandType["DbDisconnect"] = 12] = "DbDisconnect";
7477
- DataViewCommandType[DataViewCommandType["AddUserLocate"] = 13] = "AddUserLocate";
7478
- DataViewCommandType[DataViewCommandType["ResetUserLocate"] = 14] = "ResetUserLocate";
7479
- DataViewCommandType[DataViewCommandType["AddUserSort"] = 15] = "AddUserSort";
7480
- DataViewCommandType[DataViewCommandType["ResetUserSort"] = 16] = "ResetUserSort";
7481
- DataViewCommandType[DataViewCommandType["DataViewToDataSource"] = 17] = "DataViewToDataSource";
7482
- DataViewCommandType[DataViewCommandType["DbDelete"] = 18] = "DbDelete";
7483
- DataViewCommandType[DataViewCommandType["ControlItemsRefresh"] = 19] = "ControlItemsRefresh";
7484
- DataViewCommandType[DataViewCommandType["SQLExecute"] = 20] = "SQLExecute";
7485
- })(DataViewCommandType || (DataViewCommandType = {}));
7486
- class DataviewCommand extends ClientOriginatedCommandTaskTag {
7487
- constructor() {
7488
- super();
7489
- this.CommandType = 0;
7490
- this.TaskTag = null;
7491
- }
7492
- get CommandTypeAttribute() {
7493
- throw new NotImplementedException();
7494
- }
7495
- SerializeCommandData() {
7496
- Debug.Assert(false, "Dataview commands need not be serialized");
7497
- return null;
7498
- }
7499
- get ShouldSerialize() {
7500
- return false;
7501
- }
7502
- }
7503
-
7504
7472
  class EventHandlerPosition {
7505
7473
  constructor() {
7506
7474
  this._handlerIdx = 0;
@@ -7697,6 +7665,48 @@ EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC = 2;
7697
7665
  EventHandlerPosition.PHASE_GLOBAL = 3;
7698
7666
  EventHandlerPosition.PHASE_GLOBAL_SPECIFIC = 4;
7699
7667
 
7668
+ var DataViewCommandType;
7669
+ (function (DataViewCommandType) {
7670
+ DataViewCommandType[DataViewCommandType["Init"] = 0] = "Init";
7671
+ DataViewCommandType[DataViewCommandType["Clear"] = 1] = "Clear";
7672
+ DataViewCommandType[DataViewCommandType["Prepare"] = 2] = "Prepare";
7673
+ DataViewCommandType[DataViewCommandType["FirstChunk"] = 3] = "FirstChunk";
7674
+ DataViewCommandType[DataViewCommandType["RecomputeUnit"] = 4] = "RecomputeUnit";
7675
+ DataViewCommandType[DataViewCommandType["ExecuteLocalUpdates"] = 5] = "ExecuteLocalUpdates";
7676
+ DataViewCommandType[DataViewCommandType["InitDataControlViews"] = 6] = "InitDataControlViews";
7677
+ DataViewCommandType[DataViewCommandType["OpenTransaction"] = 7] = "OpenTransaction";
7678
+ DataViewCommandType[DataViewCommandType["CloseTransaction"] = 8] = "CloseTransaction";
7679
+ DataViewCommandType[DataViewCommandType["SetTransactionState"] = 9] = "SetTransactionState";
7680
+ DataViewCommandType[DataViewCommandType["AddUserRange"] = 10] = "AddUserRange";
7681
+ DataViewCommandType[DataViewCommandType["ResetUserRange"] = 11] = "ResetUserRange";
7682
+ DataViewCommandType[DataViewCommandType["DbDisconnect"] = 12] = "DbDisconnect";
7683
+ DataViewCommandType[DataViewCommandType["AddUserLocate"] = 13] = "AddUserLocate";
7684
+ DataViewCommandType[DataViewCommandType["ResetUserLocate"] = 14] = "ResetUserLocate";
7685
+ DataViewCommandType[DataViewCommandType["AddUserSort"] = 15] = "AddUserSort";
7686
+ DataViewCommandType[DataViewCommandType["ResetUserSort"] = 16] = "ResetUserSort";
7687
+ DataViewCommandType[DataViewCommandType["DataViewToDataSource"] = 17] = "DataViewToDataSource";
7688
+ DataViewCommandType[DataViewCommandType["DbDelete"] = 18] = "DbDelete";
7689
+ DataViewCommandType[DataViewCommandType["ControlItemsRefresh"] = 19] = "ControlItemsRefresh";
7690
+ DataViewCommandType[DataViewCommandType["SQLExecute"] = 20] = "SQLExecute";
7691
+ })(DataViewCommandType || (DataViewCommandType = {}));
7692
+ class DataviewCommand extends ClientOriginatedCommandTaskTag {
7693
+ constructor() {
7694
+ super();
7695
+ this.CommandType = 0;
7696
+ this.TaskTag = null;
7697
+ }
7698
+ get CommandTypeAttribute() {
7699
+ throw new NotImplementedException();
7700
+ }
7701
+ SerializeCommandData() {
7702
+ Debug.Assert(false, "Dataview commands need not be serialized");
7703
+ return null;
7704
+ }
7705
+ get ShouldSerialize() {
7706
+ return false;
7707
+ }
7708
+ }
7709
+
7700
7710
  class AddUserRangeDataviewCommand extends DataviewCommand {
7701
7711
  constructor() {
7702
7712
  super();
@@ -8336,13 +8346,6 @@ class CommandFactory {
8336
8346
  }
8337
8347
  }
8338
8348
 
8339
- class Sort {
8340
- constructor() {
8341
- this.fldIdx = 0;
8342
- this.dir = false;
8343
- }
8344
- }
8345
-
8346
8349
  var ParamParseResult;
8347
8350
  (function (ParamParseResult) {
8348
8351
  ParamParseResult[ParamParseResult["OK"] = 0] = "OK";
@@ -8448,7 +8451,7 @@ class MirrorPrmMap extends PrmMap {
8448
8451
  while (this.mirrorFromXML(parser.getNextTag(), parser)) {
8449
8452
  }
8450
8453
  }
8451
- RestoreGlobalParams(xml) {
8454
+ RestoreParams(xml) {
8452
8455
  let parser = new XmlParser(xml);
8453
8456
  while (this.mirrorFromXML(parser.getNextTag(), parser)) {
8454
8457
  }
@@ -9920,8 +9923,7 @@ class MirrorString {
9920
9923
  this._reserved = false;
9921
9924
  }
9922
9925
  mirrorToXML() {
9923
- return ConstInterface.MG_ATTR_ENV_VALUE + "=\"" + XmlParser.escape(this._value) + "\" " +
9924
- ConstInterface.MG_ATTR_ENV_WRITEINI + "=F";
9926
+ return ConstInterface.MG_ATTR_ENV_VALUE + "=\"" + XmlParser.escape(this._value) + "\"";
9925
9927
  }
9926
9928
  init(name, xmlParser) {
9927
9929
  let valueStart, valueEnd, reserveStart, paramEnd;
@@ -11497,11 +11499,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
11497
11499
  val1 = valStack.pop();
11498
11500
  this.eval_op_eoy(resVal, val1);
11499
11501
  break;
11500
- case ExpressionInterface.EXP_OP_ROLLBACK:
11501
- val2 = valStack.pop();
11502
- val1 = valStack.pop();
11503
- yield this.eval_op_rollback(resVal);
11504
- break;
11505
11502
  case ExpressionInterface.EXP_OP_VARSET:
11506
11503
  val2 = valStack.pop();
11507
11504
  val1 = valStack.pop();
@@ -11866,41 +11863,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
11866
11863
  val1 = valStack.pop();
11867
11864
  this.eval_op_taskType(resVal, val1);
11868
11865
  break;
11869
- case ExpressionInterface.EXP_OP_RANGE_ADD:
11870
- nArgs = valStack.pop();
11871
- if (nArgs > 0) {
11872
- Exp_params = new Array(nArgs);
11873
- for (j = 0; j < nArgs; j++)
11874
- Exp_params[nArgs - 1 - j] = valStack.pop();
11875
- yield this.eval_op_range_add(resVal, Exp_params);
11876
- }
11877
- break;
11878
- case ExpressionInterface.EXP_OP_RANGE_RESET:
11879
- val1 = valStack.pop();
11880
- yield this.eval_op_range_reset(resVal, val1);
11881
- break;
11882
- case ExpressionInterface.EXP_OP_LOCATE_ADD:
11883
- nArgs = valStack.pop();
11884
- if (nArgs > 0) {
11885
- Exp_params = new Array(nArgs);
11886
- for (j = 0; j < nArgs; j++)
11887
- Exp_params[nArgs - 1 - j] = valStack.pop();
11888
- yield this.eval_op_locate_add(resVal, Exp_params);
11889
- }
11890
- break;
11891
- case ExpressionInterface.EXP_OP_LOCATE_RESET:
11892
- val1 = valStack.pop();
11893
- yield this.eval_op_locate_reset(resVal, val1);
11894
- break;
11895
- case ExpressionInterface.EXP_OP_SORT_ADD:
11896
- val2 = valStack.pop();
11897
- val1 = valStack.pop();
11898
- yield this.eval_op_sort_add(resVal, val1, val2);
11899
- break;
11900
- case ExpressionInterface.EXP_OP_SORT_RESET:
11901
- val1 = valStack.pop();
11902
- yield this.eval_op_sort_reset(resVal, val1);
11903
- break;
11904
11866
  case ExpressionInterface.EXP_OP_TSK_INSTANCE:
11905
11867
  val1 = valStack.pop();
11906
11868
  this.eval_op_tsk_instance(resVal, val1);
@@ -13569,14 +13531,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
13569
13531
  yield fld.updateDisplay();
13570
13532
  });
13571
13533
  }
13572
- eval_op_rollback(resVal) {
13573
- return __awaiter(this, void 0, void 0, function* () {
13574
- let task = this.ExpTask.GetContextTask() || this.ExpTask;
13575
- yield AccessHelper.eventsManager.handleInternalEventWithTask(task, InternalInterface.MG_ACT_ROLLBACK);
13576
- resVal.Attr = StorageAttribute.BOOLEAN;
13577
- resVal.BoolVal = true;
13578
- });
13579
- }
13580
13534
  eval_op_like(source, maskOrg, resVal) {
13581
13535
  let i;
13582
13536
  let j;
@@ -14137,75 +14091,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
14137
14091
  resultStr.Replace('\\@', '@');
14138
14092
  resVal.StrVal = resultStr.ToString();
14139
14093
  }
14140
- eval_op_range_add(resVal, Exp_params) {
14141
- return __awaiter(this, void 0, void 0, function* () {
14142
- resVal.Attr = StorageAttribute.BOOLEAN;
14143
- resVal.BoolVal = yield this.add_rt_ranges(Exp_params, false);
14144
- });
14145
- }
14146
- eval_op_range_reset(resVal, parent) {
14147
- const _super = Object.create(null, {
14148
- GetContextTask: { get: () => super.GetContextTask }
14149
- });
14150
- return __awaiter(this, void 0, void 0, function* () {
14151
- resVal.Attr = StorageAttribute.BOOLEAN;
14152
- let iParent = parent.MgNumVal.NUM_2_LONG();
14153
- if ((iParent >= 0 && iParent < (this.ExpTask.getTaskDepth(false))) || iParent === ExpressionEvaluator.TRIGGER_TASK) {
14154
- let task = _super.GetContextTask.call(this, iParent);
14155
- if (task !== null) {
14156
- let command = CommandFactory.CreateDataViewCommand(task.getTaskTag(), DataViewCommandType.ResetUserRange);
14157
- yield task.DataviewManager.Execute(command);
14158
- resVal.BoolVal = true;
14159
- }
14160
- }
14161
- });
14162
- }
14163
- eval_op_locate_add(resVal, Exp_params) {
14164
- return __awaiter(this, void 0, void 0, function* () {
14165
- resVal.Attr = StorageAttribute.BOOLEAN;
14166
- resVal.BoolVal = yield this.add_rt_ranges(Exp_params, true);
14167
- });
14168
- }
14169
- eval_op_locate_reset(resVal, parent) {
14170
- const _super = Object.create(null, {
14171
- GetContextTask: { get: () => super.GetContextTask }
14172
- });
14173
- return __awaiter(this, void 0, void 0, function* () {
14174
- resVal.Attr = StorageAttribute.BOOLEAN;
14175
- let iParent = parent.MgNumVal.NUM_2_LONG();
14176
- if ((iParent >= 0 && iParent < (this.ExpTask.getTaskDepth(false))) || iParent === ExpressionEvaluator.TRIGGER_TASK) {
14177
- let task = _super.GetContextTask.call(this, iParent);
14178
- if (task !== null) {
14179
- let command = CommandFactory.CreateDataViewCommand(task.getTaskTag(), DataViewCommandType.ResetUserLocate);
14180
- yield task.DataviewManager.Execute(command);
14181
- resVal.BoolVal = true;
14182
- }
14183
- }
14184
- });
14185
- }
14186
- eval_op_sort_add(resVal, varnum, dir) {
14187
- return __awaiter(this, void 0, void 0, function* () {
14188
- resVal.Attr = StorageAttribute.BOOLEAN;
14189
- resVal.BoolVal = yield this.add_sort(varnum, dir);
14190
- });
14191
- }
14192
- eval_op_sort_reset(resVal, parent) {
14193
- const _super = Object.create(null, {
14194
- GetContextTask: { get: () => super.GetContextTask }
14195
- });
14196
- return __awaiter(this, void 0, void 0, function* () {
14197
- resVal.Attr = StorageAttribute.BOOLEAN;
14198
- let iParent = parent.MgNumVal.NUM_2_LONG();
14199
- if ((iParent >= 0 && iParent < (this.ExpTask.getTaskDepth(false))) || iParent === ExpressionEvaluator.TRIGGER_TASK) {
14200
- let task = _super.GetContextTask.call(this, iParent);
14201
- if (task !== null) {
14202
- let command = CommandFactory.CreateDataViewCommand(task.getTaskTag(), DataViewCommandType.ResetUserSort);
14203
- yield task.DataviewManager.Execute(command);
14204
- resVal.BoolVal = true;
14205
- }
14206
- }
14207
- });
14208
- }
14209
14094
  eval_op_tsk_instance(resVal, Parent) {
14210
14095
  let tag = 0;
14211
14096
  let iParent = Parent.MgNumVal.NUM_2_LONG();
@@ -14219,88 +14104,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
14219
14104
  resVal.MgNumVal = new NUM_TYPE();
14220
14105
  resVal.MgNumVal.NUM_4_LONG(tag);
14221
14106
  }
14222
- add_sort(varnum, dir) {
14223
- return __awaiter(this, void 0, void 0, function* () {
14224
- if (varnum.MgNumVal === null)
14225
- return false;
14226
- let itm = varnum.MgNumVal.NUM_2_LONG();
14227
- if (itm === 0)
14228
- return false;
14229
- let fld = this.GetFieldOfContextTask(itm);
14230
- if (fld === null)
14231
- return false;
14232
- let task = fld.getTask();
14233
- let vee_idx = fld.getId() + 1;
14234
- let expr_64 = new Sort();
14235
- expr_64.fldIdx = vee_idx;
14236
- expr_64.dir = dir.BoolVal;
14237
- let sort = expr_64;
14238
- let command = CommandFactory.CreateAddUserSortDataviewCommand(task.getTaskTag(), sort);
14239
- yield task.DataviewManager.Execute(command);
14240
- return true;
14241
- });
14242
- }
14243
- add_rt_ranges(Exp_params, locate) {
14244
- return __awaiter(this, void 0, void 0, function* () {
14245
- let varnum = Exp_params[0];
14246
- let min = Exp_params[1];
14247
- if (varnum.MgNumVal === null)
14248
- return false;
14249
- let itm = varnum.MgNumVal.NUM_2_LONG();
14250
- if (itm === 0)
14251
- return false;
14252
- let fld = this.GetFieldOfContextTask(itm);
14253
- if (fld === null)
14254
- return false;
14255
- let task = fld.getTask();
14256
- let vee_idx = fld.getId() + 1;
14257
- let expr_78 = new UserRange();
14258
- expr_78.veeIdx = vee_idx;
14259
- let rng = expr_78;
14260
- if (min.IsNull)
14261
- rng.nullMin = true;
14262
- if (!rng.nullMin && (min.Attr === StorageAttribute.ALPHA || min.Attr === StorageAttribute.UNICODE) && min.StrVal.length === 0)
14263
- rng.discardMin = true;
14264
- else {
14265
- if (!rng.nullMin) {
14266
- if (!StorageAttributeCheck.isTheSameType(fld.getType(), min.Attr))
14267
- return false;
14268
- if (StorageAttributeCheck.StorageFldAlphaUnicodeOrBlob(fld.getType(), min.Attr))
14269
- this.ConvertExpVal(min, fld.getType());
14270
- rng.min = min.ToMgVal();
14271
- }
14272
- }
14273
- if (Exp_params.length === 3) {
14274
- let max = Exp_params[2];
14275
- if (max.IsNull)
14276
- rng.nullMax = true;
14277
- if (!rng.nullMax && (max.Attr === StorageAttribute.ALPHA || max.Attr === StorageAttribute.UNICODE) && max.StrVal.length === 0)
14278
- rng.discardMax = true;
14279
- else {
14280
- if (!rng.nullMax) {
14281
- if (!StorageAttributeCheck.isTheSameType(fld.getType(), max.Attr))
14282
- return false;
14283
- if (StorageAttributeCheck.StorageFldAlphaUnicodeOrBlob(fld.getType(), max.Attr))
14284
- this.ConvertExpVal(max, fld.getType());
14285
- rng.max = max.ToMgVal();
14286
- }
14287
- }
14288
- }
14289
- else
14290
- rng.discardMax = true;
14291
- if (!rng.discardMin || !rng.discardMax) {
14292
- if (locate) {
14293
- let command = CommandFactory.CreateAddUserLocateDataviewCommand(task.getTaskTag(), rng);
14294
- yield task.DataviewManager.Execute(command);
14295
- }
14296
- else {
14297
- let command2 = CommandFactory.CreateAddUserRangeDataviewCommand(task.getTaskTag(), rng);
14298
- yield task.DataviewManager.Execute(command2);
14299
- }
14300
- }
14301
- return true;
14302
- });
14303
- }
14304
14107
  eval_op_getParam(resVal, name) {
14305
14108
  Debug.Assert(!name.IsNull && name.StrVal !== null);
14306
14109
  let expVal = GlobalParams.Instance.get(name.StrVal);
@@ -19636,6 +19439,13 @@ class DataviewManager extends DataviewManagerBase {
19636
19439
  }
19637
19440
  }
19638
19441
 
19442
+ class Sort {
19443
+ constructor() {
19444
+ this.fldIdx = 0;
19445
+ this.dir = false;
19446
+ }
19447
+ }
19448
+
19639
19449
  class SortCollection {
19640
19450
  constructor() {
19641
19451
  this._sortTab = null;
@@ -19871,11 +19681,7 @@ class MgForm extends MgFormBase {
19871
19681
  this.GetDataview().setTopRecIdxModified(true);
19872
19682
  try {
19873
19683
  this._suffixDone = false;
19874
- let newDisplayLine = this.GetDataview().getCurrRecIdx() + size;
19875
- if (unit === Constants.MOVE_UNIT_PAGE && this.isLineMode())
19876
- if (newDisplayLine > this.GetDataview().getSize() - 1)
19877
- visibleLine -= newDisplayLine - (this.GetDataview().getSize() - 1);
19878
- yield this.setCurrRowByDisplayLine(newDisplayLine, true, false);
19684
+ yield this.setCurrRowByDisplayLine(this.GetDataview().getCurrRecIdx() + size, true, false);
19879
19685
  this.GetDataview().setTopRecIdxModified(false);
19880
19686
  yield this.RefreshDisplay(Constants.TASK_REFRESH_FORM);
19881
19687
  }
@@ -19915,6 +19721,7 @@ class MgForm extends MgFormBase {
19915
19721
  try {
19916
19722
  yield this.RefreshDisplay(Constants.TASK_REFRESH_FORM);
19917
19723
  yield this.setCurrRowByDisplayLine(this.GetDataview().getTopRecIdx() + this.getLastValidRow(), false, true);
19724
+ visibleLine = this.getLastValidRow();
19918
19725
  }
19919
19726
  catch (Exception) {
19920
19727
  }
@@ -30432,7 +30239,7 @@ class CommandsTable {
30432
30239
  }
30433
30240
  }
30434
30241
 
30435
- let CurrentClientVersion = '4.1000.0-dev000.0';
30242
+ let CurrentClientVersion = '4.1000.0-dev4100.100';
30436
30243
 
30437
30244
  class ClientManager {
30438
30245
  constructor() {