@magic-xpa/engine 4.1000.0-dev4100.1 → 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"]}
@@ -39,7 +39,6 @@ var ClientTargetedCommandType;
39
39
  })(ClientTargetedCommandType || (ClientTargetedCommandType = {}));
40
40
 
41
41
  class ConstInterface {
42
- ;
43
42
  }
44
43
  ConstInterface.MG_TAG_CONTEXT = "context";
45
44
  ConstInterface.MG_TAG_ENV = "env";
@@ -477,6 +476,7 @@ ConstInterface.RC_TOKEN_DATA = "DATA=";
477
476
  ConstInterface.WEBCLIENT_REINITIALIZE_REQUEST = "WCREINITIALIZEREQUEST=Y";
478
477
  ConstInterface.MAIN_PROG_VIEW = "MainProgramsDataView";
479
478
  ConstInterface.GLOBAL_PARAM_LIST = "GlobalParamList";
479
+ ConstInterface.ENV_VAR_LIST = "EnvVarList";
480
480
  ConstInterface.LAST_EXCEPTION = "LastException";
481
481
  ConstInterface.CTX_REMOVED_FROM_SRVR = "CtxRemovedFromSrvr";
482
482
  ConstInterface.LAST_ROUTE_EVENT = "LastRouteEvent";
@@ -5275,10 +5275,12 @@ class RemoteCommandsProcessor extends CommandsProcessorBase {
5275
5275
  return __awaiter(this, void 0, void 0, function* () {
5276
5276
  let mainPrgViewStringForServer = yield this.BuildXMLForMainProgramDataView();
5277
5277
  let globalParamsString = AccessHelper.globalParams.mirrorAllToXML();
5278
+ let changedEnvVarList = AccessHelper.envParamsTable.mirrorAllToXML();
5278
5279
  let dataStorage = window.localStorage;
5279
5280
  dataStorage.setItem(ConstInterface.IS_SESSION_REINITIALIZING, "true");
5280
5281
  dataStorage.setItem(ConstInterface.MAIN_PROG_VIEW, mainPrgViewStringForServer.toString());
5281
5282
  dataStorage.setItem(ConstInterface.GLOBAL_PARAM_LIST, globalParamsString);
5283
+ dataStorage.setItem(ConstInterface.ENV_VAR_LIST, changedEnvVarList);
5282
5284
  dataStorage.setItem(ConstInterface.LAST_EXCEPTION, RemoteCommandsProcessor.lastExceptionMessage);
5283
5285
  if (RuntimeContextBase.Instance.RemovedContextFromServer)
5284
5286
  dataStorage.setItem(ConstInterface.CTX_REMOVED_FROM_SRVR, "1");
@@ -5515,6 +5517,7 @@ class RemoteCommandsProcessor extends CommandsProcessorBase {
5515
5517
  let reqBuf;
5516
5518
  let isInitialCall = sessionStage === CommandsProcessorBase_SessionStage.INITIAL;
5517
5519
  let globalParamsString = null;
5520
+ let envVarsString = null;
5518
5521
  if (this.DelayCommandExecution)
5519
5522
  return;
5520
5523
  if (Logger.Instance.LogLevel == Logger_LogLevels.RequestInfo && !isInitialCall)
@@ -5540,12 +5543,16 @@ class RemoteCommandsProcessor extends CommandsProcessorBase {
5540
5543
  let buffer = new StringBuilder();
5541
5544
  if (!RemoteCommandsProcessor.IsSessionReInitializing)
5542
5545
  buffer.Append(reqBuf);
5543
- if (RemoteCommandsProcessor.IsSessionReInitializing)
5546
+ if (RemoteCommandsProcessor.IsSessionReInitializing) {
5544
5547
  globalParamsString = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.GLOBAL_PARAM_LIST);
5545
- else
5548
+ envVarsString = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.ENV_VAR_LIST);
5549
+ }
5550
+ else {
5546
5551
  globalParamsString = AccessHelper.globalParams.mirrorToXML();
5552
+ envVarsString = AccessHelper.envParamsTable.mirrorToXML();
5553
+ }
5547
5554
  changes.Append(globalParamsString);
5548
- changes.Append(AccessHelper.envParamsTable.mirrorToXML());
5555
+ changes.Append(envVarsString);
5549
5556
  if (changes.Length > 0) {
5550
5557
  changes.Insert(0, "<" + ConstInterface.MG_TAG_ENV_CHANGES + ">");
5551
5558
  changes.Append("</" + ConstInterface.MG_TAG_ENV_CHANGES + ">");
@@ -5584,13 +5591,15 @@ class RemoteCommandsProcessor extends CommandsProcessorBase {
5584
5591
  dataStorage.removeItem(ConstInterface.IS_SESSION_REINITIALIZING);
5585
5592
  dataStorage.removeItem(ConstInterface.MAIN_PROG_VIEW);
5586
5593
  dataStorage.removeItem(ConstInterface.GLOBAL_PARAM_LIST);
5594
+ dataStorage.removeItem(ConstInterface.ENV_VAR_LIST);
5587
5595
  dataStorage.removeItem(ConstInterface.LAST_EXCEPTION);
5588
5596
  }
5589
5597
  }
5590
5598
  FlowMonitorQueue.Instance.enable(false);
5591
5599
  yield this.ProcessResponse(respBuf, AccessHelper.mgDataTable.currMgdID, null, res);
5592
5600
  if (RemoteCommandsProcessor.IsSessionReInitializing) {
5593
- AccessHelper.globalParams.RestoreGlobalParams(globalParamsString);
5601
+ AccessHelper.globalParams.RestoreParams(globalParamsString);
5602
+ AccessHelper.envParamsTable.RestoreParams(envVarsString);
5594
5603
  let dataStorage = window.localStorage;
5595
5604
  let ctxRemoved = dataStorage.getItem(ConstInterface.CTX_REMOVED_FROM_SRVR);
5596
5605
  if (ctxRemoved === "1") {
@@ -6919,7 +6928,7 @@ ExpressionDict.expDesc = [
6919
6928
  null,
6920
6929
  new ExpDesc('N', 0, 0, 0, "", false),
6921
6930
  null,
6922
- new ExpDesc('B', 0, 2, 2, "BN", false),
6931
+ null,
6923
6932
  new ExpDesc('B', 0, 2, 2, "V ", false),
6924
6933
  null,
6925
6934
  null,
@@ -7368,12 +7377,12 @@ ExpressionDict.expDesc = [
7368
7377
  null,
7369
7378
  new ExpDesc('A', 0, 1, 1, "A", false),
7370
7379
  new ExpDesc('N', 0, 2, 2, "AA", false),
7371
- new ExpDesc('B', 0, -2, -2, "V ", false),
7372
- new ExpDesc('B', 0, 1, 1, "N", false),
7373
- new ExpDesc('B', 0, -2, -2, "V ", false),
7374
- new ExpDesc('B', 0, 1, 1, "N", false),
7375
- new ExpDesc('B', 0, 2, 2, "VB", false),
7376
- new ExpDesc('B', 0, 1, 1, "N", false),
7380
+ null,
7381
+ null,
7382
+ null,
7383
+ null,
7384
+ null,
7385
+ null,
7377
7386
  new ExpDesc('N', 0, 1, 1, "N", false),
7378
7387
  null,
7379
7388
  null,
@@ -7460,48 +7469,6 @@ ExpressionDict.expDesc = [
7460
7469
  new ExpDesc('U', 0, 0, 0, '', false),
7461
7470
  ];
7462
7471
 
7463
- var DataViewCommandType;
7464
- (function (DataViewCommandType) {
7465
- DataViewCommandType[DataViewCommandType["Init"] = 0] = "Init";
7466
- DataViewCommandType[DataViewCommandType["Clear"] = 1] = "Clear";
7467
- DataViewCommandType[DataViewCommandType["Prepare"] = 2] = "Prepare";
7468
- DataViewCommandType[DataViewCommandType["FirstChunk"] = 3] = "FirstChunk";
7469
- DataViewCommandType[DataViewCommandType["RecomputeUnit"] = 4] = "RecomputeUnit";
7470
- DataViewCommandType[DataViewCommandType["ExecuteLocalUpdates"] = 5] = "ExecuteLocalUpdates";
7471
- DataViewCommandType[DataViewCommandType["InitDataControlViews"] = 6] = "InitDataControlViews";
7472
- DataViewCommandType[DataViewCommandType["OpenTransaction"] = 7] = "OpenTransaction";
7473
- DataViewCommandType[DataViewCommandType["CloseTransaction"] = 8] = "CloseTransaction";
7474
- DataViewCommandType[DataViewCommandType["SetTransactionState"] = 9] = "SetTransactionState";
7475
- DataViewCommandType[DataViewCommandType["AddUserRange"] = 10] = "AddUserRange";
7476
- DataViewCommandType[DataViewCommandType["ResetUserRange"] = 11] = "ResetUserRange";
7477
- DataViewCommandType[DataViewCommandType["DbDisconnect"] = 12] = "DbDisconnect";
7478
- DataViewCommandType[DataViewCommandType["AddUserLocate"] = 13] = "AddUserLocate";
7479
- DataViewCommandType[DataViewCommandType["ResetUserLocate"] = 14] = "ResetUserLocate";
7480
- DataViewCommandType[DataViewCommandType["AddUserSort"] = 15] = "AddUserSort";
7481
- DataViewCommandType[DataViewCommandType["ResetUserSort"] = 16] = "ResetUserSort";
7482
- DataViewCommandType[DataViewCommandType["DataViewToDataSource"] = 17] = "DataViewToDataSource";
7483
- DataViewCommandType[DataViewCommandType["DbDelete"] = 18] = "DbDelete";
7484
- DataViewCommandType[DataViewCommandType["ControlItemsRefresh"] = 19] = "ControlItemsRefresh";
7485
- DataViewCommandType[DataViewCommandType["SQLExecute"] = 20] = "SQLExecute";
7486
- })(DataViewCommandType || (DataViewCommandType = {}));
7487
- class DataviewCommand extends ClientOriginatedCommandTaskTag {
7488
- constructor() {
7489
- super();
7490
- this.CommandType = 0;
7491
- this.TaskTag = null;
7492
- }
7493
- get CommandTypeAttribute() {
7494
- throw new NotImplementedException();
7495
- }
7496
- SerializeCommandData() {
7497
- Debug.Assert(false, "Dataview commands need not be serialized");
7498
- return null;
7499
- }
7500
- get ShouldSerialize() {
7501
- return false;
7502
- }
7503
- }
7504
-
7505
7472
  class EventHandlerPosition {
7506
7473
  constructor() {
7507
7474
  this._handlerIdx = 0;
@@ -7698,6 +7665,48 @@ EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC = 2;
7698
7665
  EventHandlerPosition.PHASE_GLOBAL = 3;
7699
7666
  EventHandlerPosition.PHASE_GLOBAL_SPECIFIC = 4;
7700
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
+
7701
7710
  class AddUserRangeDataviewCommand extends DataviewCommand {
7702
7711
  constructor() {
7703
7712
  super();
@@ -8096,6 +8105,13 @@ class SelectProgramCommand extends ExecOperCommand {
8096
8105
  }
8097
8106
  }
8098
8107
 
8108
+ class ControlItemsRefreshCommand extends DataviewCommand {
8109
+ constructor() {
8110
+ super();
8111
+ this.Control = null;
8112
+ }
8113
+ }
8114
+
8099
8115
  class CommandFactory {
8100
8116
  static CreateEventCommand(taskTag, magicEvent) {
8101
8117
  let eventCommand = new EventCommand(magicEvent);
@@ -8114,6 +8130,13 @@ class CommandFactory {
8114
8130
  dataviewCommand.TaskTag = taskId;
8115
8131
  return dataviewCommand;
8116
8132
  }
8133
+ static CreateControlItemsRefreshCommand(taskId, control) {
8134
+ let command = new ControlItemsRefreshCommand();
8135
+ command.CommandType = DataViewCommandType.ControlItemsRefresh;
8136
+ command.TaskTag = taskId;
8137
+ command.Control = control;
8138
+ return command;
8139
+ }
8117
8140
  static CreateAddUserRangeDataviewCommand(taskId, userRange) {
8118
8141
  let addUserRangeDataviewCommand = new AddUserRangeDataviewCommand();
8119
8142
  addUserRangeDataviewCommand.TaskTag = taskId;
@@ -8323,13 +8346,6 @@ class CommandFactory {
8323
8346
  }
8324
8347
  }
8325
8348
 
8326
- class Sort {
8327
- constructor() {
8328
- this.fldIdx = 0;
8329
- this.dir = false;
8330
- }
8331
- }
8332
-
8333
8349
  var ParamParseResult;
8334
8350
  (function (ParamParseResult) {
8335
8351
  ParamParseResult[ParamParseResult["OK"] = 0] = "OK";
@@ -8435,7 +8451,7 @@ class MirrorPrmMap extends PrmMap {
8435
8451
  while (this.mirrorFromXML(parser.getNextTag(), parser)) {
8436
8452
  }
8437
8453
  }
8438
- RestoreGlobalParams(xml) {
8454
+ RestoreParams(xml) {
8439
8455
  let parser = new XmlParser(xml);
8440
8456
  while (this.mirrorFromXML(parser.getNextTag(), parser)) {
8441
8457
  }
@@ -9907,8 +9923,7 @@ class MirrorString {
9907
9923
  this._reserved = false;
9908
9924
  }
9909
9925
  mirrorToXML() {
9910
- return ConstInterface.MG_ATTR_ENV_VALUE + "=\"" + XmlParser.escape(this._value) + "\" " +
9911
- ConstInterface.MG_ATTR_ENV_WRITEINI + "=F";
9926
+ return ConstInterface.MG_ATTR_ENV_VALUE + "=\"" + XmlParser.escape(this._value) + "\"";
9912
9927
  }
9913
9928
  init(name, xmlParser) {
9914
9929
  let valueStart, valueEnd, reserveStart, paramEnd;
@@ -11091,6 +11106,11 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
11091
11106
  this.eval_op_VarDisplayName(resVal, val1);
11092
11107
  expStrTracker.resetNullResult();
11093
11108
  break;
11109
+ case ExpressionInterface.EXP_OP_CONTROL_ITEMS_REFRESH:
11110
+ val2 = valStack.pop();
11111
+ val1 = valStack.pop();
11112
+ yield this.eval_op_controlItemRefresh(val1, val2, resVal);
11113
+ break;
11094
11114
  case ExpressionInterface.EXP_OP_VARCONTROLID:
11095
11115
  val1 = valStack.pop();
11096
11116
  this.eval_op_VarControlID(resVal, val1);
@@ -11479,11 +11499,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
11479
11499
  val1 = valStack.pop();
11480
11500
  this.eval_op_eoy(resVal, val1);
11481
11501
  break;
11482
- case ExpressionInterface.EXP_OP_ROLLBACK:
11483
- val2 = valStack.pop();
11484
- val1 = valStack.pop();
11485
- yield this.eval_op_rollback(resVal);
11486
- break;
11487
11502
  case ExpressionInterface.EXP_OP_VARSET:
11488
11503
  val2 = valStack.pop();
11489
11504
  val1 = valStack.pop();
@@ -11848,41 +11863,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
11848
11863
  val1 = valStack.pop();
11849
11864
  this.eval_op_taskType(resVal, val1);
11850
11865
  break;
11851
- case ExpressionInterface.EXP_OP_RANGE_ADD:
11852
- nArgs = valStack.pop();
11853
- if (nArgs > 0) {
11854
- Exp_params = new Array(nArgs);
11855
- for (j = 0; j < nArgs; j++)
11856
- Exp_params[nArgs - 1 - j] = valStack.pop();
11857
- yield this.eval_op_range_add(resVal, Exp_params);
11858
- }
11859
- break;
11860
- case ExpressionInterface.EXP_OP_RANGE_RESET:
11861
- val1 = valStack.pop();
11862
- yield this.eval_op_range_reset(resVal, val1);
11863
- break;
11864
- case ExpressionInterface.EXP_OP_LOCATE_ADD:
11865
- nArgs = valStack.pop();
11866
- if (nArgs > 0) {
11867
- Exp_params = new Array(nArgs);
11868
- for (j = 0; j < nArgs; j++)
11869
- Exp_params[nArgs - 1 - j] = valStack.pop();
11870
- yield this.eval_op_locate_add(resVal, Exp_params);
11871
- }
11872
- break;
11873
- case ExpressionInterface.EXP_OP_LOCATE_RESET:
11874
- val1 = valStack.pop();
11875
- yield this.eval_op_locate_reset(resVal, val1);
11876
- break;
11877
- case ExpressionInterface.EXP_OP_SORT_ADD:
11878
- val2 = valStack.pop();
11879
- val1 = valStack.pop();
11880
- yield this.eval_op_sort_add(resVal, val1, val2);
11881
- break;
11882
- case ExpressionInterface.EXP_OP_SORT_RESET:
11883
- val1 = valStack.pop();
11884
- yield this.eval_op_sort_reset(resVal, val1);
11885
- break;
11886
11866
  case ExpressionInterface.EXP_OP_TSK_INSTANCE:
11887
11867
  val1 = valStack.pop();
11888
11868
  this.eval_op_tsk_instance(resVal, val1);
@@ -13235,6 +13215,28 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
13235
13215
  resVal.StrVal = fld.VarDisplayName;
13236
13216
  }
13237
13217
  }
13218
+ eval_op_controlItemRefresh(val1, val2, resVal) {
13219
+ const _super = Object.create(null, {
13220
+ GetContextTask: { get: () => super.GetContextTask }
13221
+ });
13222
+ return __awaiter(this, void 0, void 0, function* () {
13223
+ let success = false;
13224
+ let parent = val2.MgNumVal.NUM_2_LONG();
13225
+ resVal.Attr = StorageAttribute.BOOLEAN;
13226
+ if ((parent >= 0 && parent < (this.ExpTask.getTaskDepth(false))) || parent === ExpressionEvaluator.TRIGGER_TASK) {
13227
+ let tsk = _super.GetContextTask.call(this, parent);
13228
+ if (tsk != null && tsk.getForm() != null) {
13229
+ let control = tsk.getForm().GetCtrl(val1.StrVal);
13230
+ if (control != null && control.isChoiceControl() && control.isDataCtrl()) {
13231
+ let command = CommandFactory.CreateControlItemsRefreshCommand(tsk.getTaskTag(), control);
13232
+ yield tsk.DataviewManager.CurrentDataviewManager.Execute(command);
13233
+ success = true;
13234
+ }
13235
+ }
13236
+ }
13237
+ resVal.BoolVal = success;
13238
+ });
13239
+ }
13238
13240
  eval_op_VarControlID(resVal, val1) {
13239
13241
  let ret = 0;
13240
13242
  if (val1.MgNumVal !== null) {
@@ -13529,14 +13531,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
13529
13531
  yield fld.updateDisplay();
13530
13532
  });
13531
13533
  }
13532
- eval_op_rollback(resVal) {
13533
- return __awaiter(this, void 0, void 0, function* () {
13534
- let task = this.ExpTask.GetContextTask() || this.ExpTask;
13535
- yield AccessHelper.eventsManager.handleInternalEventWithTask(task, InternalInterface.MG_ACT_ROLLBACK);
13536
- resVal.Attr = StorageAttribute.BOOLEAN;
13537
- resVal.BoolVal = true;
13538
- });
13539
- }
13540
13534
  eval_op_like(source, maskOrg, resVal) {
13541
13535
  let i;
13542
13536
  let j;
@@ -14097,75 +14091,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
14097
14091
  resultStr.Replace('\\@', '@');
14098
14092
  resVal.StrVal = resultStr.ToString();
14099
14093
  }
14100
- eval_op_range_add(resVal, Exp_params) {
14101
- return __awaiter(this, void 0, void 0, function* () {
14102
- resVal.Attr = StorageAttribute.BOOLEAN;
14103
- resVal.BoolVal = yield this.add_rt_ranges(Exp_params, false);
14104
- });
14105
- }
14106
- eval_op_range_reset(resVal, parent) {
14107
- const _super = Object.create(null, {
14108
- GetContextTask: { get: () => super.GetContextTask }
14109
- });
14110
- return __awaiter(this, void 0, void 0, function* () {
14111
- resVal.Attr = StorageAttribute.BOOLEAN;
14112
- let iParent = parent.MgNumVal.NUM_2_LONG();
14113
- if ((iParent >= 0 && iParent < (this.ExpTask.getTaskDepth(false))) || iParent === ExpressionEvaluator.TRIGGER_TASK) {
14114
- let task = _super.GetContextTask.call(this, iParent);
14115
- if (task !== null) {
14116
- let command = CommandFactory.CreateDataViewCommand(task.getTaskTag(), DataViewCommandType.ResetUserRange);
14117
- yield task.DataviewManager.Execute(command);
14118
- resVal.BoolVal = true;
14119
- }
14120
- }
14121
- });
14122
- }
14123
- eval_op_locate_add(resVal, Exp_params) {
14124
- return __awaiter(this, void 0, void 0, function* () {
14125
- resVal.Attr = StorageAttribute.BOOLEAN;
14126
- resVal.BoolVal = yield this.add_rt_ranges(Exp_params, true);
14127
- });
14128
- }
14129
- eval_op_locate_reset(resVal, parent) {
14130
- const _super = Object.create(null, {
14131
- GetContextTask: { get: () => super.GetContextTask }
14132
- });
14133
- return __awaiter(this, void 0, void 0, function* () {
14134
- resVal.Attr = StorageAttribute.BOOLEAN;
14135
- let iParent = parent.MgNumVal.NUM_2_LONG();
14136
- if ((iParent >= 0 && iParent < (this.ExpTask.getTaskDepth(false))) || iParent === ExpressionEvaluator.TRIGGER_TASK) {
14137
- let task = _super.GetContextTask.call(this, iParent);
14138
- if (task !== null) {
14139
- let command = CommandFactory.CreateDataViewCommand(task.getTaskTag(), DataViewCommandType.ResetUserLocate);
14140
- yield task.DataviewManager.Execute(command);
14141
- resVal.BoolVal = true;
14142
- }
14143
- }
14144
- });
14145
- }
14146
- eval_op_sort_add(resVal, varnum, dir) {
14147
- return __awaiter(this, void 0, void 0, function* () {
14148
- resVal.Attr = StorageAttribute.BOOLEAN;
14149
- resVal.BoolVal = yield this.add_sort(varnum, dir);
14150
- });
14151
- }
14152
- eval_op_sort_reset(resVal, parent) {
14153
- const _super = Object.create(null, {
14154
- GetContextTask: { get: () => super.GetContextTask }
14155
- });
14156
- return __awaiter(this, void 0, void 0, function* () {
14157
- resVal.Attr = StorageAttribute.BOOLEAN;
14158
- let iParent = parent.MgNumVal.NUM_2_LONG();
14159
- if ((iParent >= 0 && iParent < (this.ExpTask.getTaskDepth(false))) || iParent === ExpressionEvaluator.TRIGGER_TASK) {
14160
- let task = _super.GetContextTask.call(this, iParent);
14161
- if (task !== null) {
14162
- let command = CommandFactory.CreateDataViewCommand(task.getTaskTag(), DataViewCommandType.ResetUserSort);
14163
- yield task.DataviewManager.Execute(command);
14164
- resVal.BoolVal = true;
14165
- }
14166
- }
14167
- });
14168
- }
14169
14094
  eval_op_tsk_instance(resVal, Parent) {
14170
14095
  let tag = 0;
14171
14096
  let iParent = Parent.MgNumVal.NUM_2_LONG();
@@ -14179,88 +14104,6 @@ class ExpressionEvaluator extends GuiExpressionEvaluator {
14179
14104
  resVal.MgNumVal = new NUM_TYPE();
14180
14105
  resVal.MgNumVal.NUM_4_LONG(tag);
14181
14106
  }
14182
- add_sort(varnum, dir) {
14183
- return __awaiter(this, void 0, void 0, function* () {
14184
- if (varnum.MgNumVal === null)
14185
- return false;
14186
- let itm = varnum.MgNumVal.NUM_2_LONG();
14187
- if (itm === 0)
14188
- return false;
14189
- let fld = this.GetFieldOfContextTask(itm);
14190
- if (fld === null)
14191
- return false;
14192
- let task = fld.getTask();
14193
- let vee_idx = fld.getId() + 1;
14194
- let expr_64 = new Sort();
14195
- expr_64.fldIdx = vee_idx;
14196
- expr_64.dir = dir.BoolVal;
14197
- let sort = expr_64;
14198
- let command = CommandFactory.CreateAddUserSortDataviewCommand(task.getTaskTag(), sort);
14199
- yield task.DataviewManager.Execute(command);
14200
- return true;
14201
- });
14202
- }
14203
- add_rt_ranges(Exp_params, locate) {
14204
- return __awaiter(this, void 0, void 0, function* () {
14205
- let varnum = Exp_params[0];
14206
- let min = Exp_params[1];
14207
- if (varnum.MgNumVal === null)
14208
- return false;
14209
- let itm = varnum.MgNumVal.NUM_2_LONG();
14210
- if (itm === 0)
14211
- return false;
14212
- let fld = this.GetFieldOfContextTask(itm);
14213
- if (fld === null)
14214
- return false;
14215
- let task = fld.getTask();
14216
- let vee_idx = fld.getId() + 1;
14217
- let expr_78 = new UserRange();
14218
- expr_78.veeIdx = vee_idx;
14219
- let rng = expr_78;
14220
- if (min.IsNull)
14221
- rng.nullMin = true;
14222
- if (!rng.nullMin && (min.Attr === StorageAttribute.ALPHA || min.Attr === StorageAttribute.UNICODE) && min.StrVal.length === 0)
14223
- rng.discardMin = true;
14224
- else {
14225
- if (!rng.nullMin) {
14226
- if (!StorageAttributeCheck.isTheSameType(fld.getType(), min.Attr))
14227
- return false;
14228
- if (StorageAttributeCheck.StorageFldAlphaUnicodeOrBlob(fld.getType(), min.Attr))
14229
- this.ConvertExpVal(min, fld.getType());
14230
- rng.min = min.ToMgVal();
14231
- }
14232
- }
14233
- if (Exp_params.length === 3) {
14234
- let max = Exp_params[2];
14235
- if (max.IsNull)
14236
- rng.nullMax = true;
14237
- if (!rng.nullMax && (max.Attr === StorageAttribute.ALPHA || max.Attr === StorageAttribute.UNICODE) && max.StrVal.length === 0)
14238
- rng.discardMax = true;
14239
- else {
14240
- if (!rng.nullMax) {
14241
- if (!StorageAttributeCheck.isTheSameType(fld.getType(), max.Attr))
14242
- return false;
14243
- if (StorageAttributeCheck.StorageFldAlphaUnicodeOrBlob(fld.getType(), max.Attr))
14244
- this.ConvertExpVal(max, fld.getType());
14245
- rng.max = max.ToMgVal();
14246
- }
14247
- }
14248
- }
14249
- else
14250
- rng.discardMax = true;
14251
- if (!rng.discardMin || !rng.discardMax) {
14252
- if (locate) {
14253
- let command = CommandFactory.CreateAddUserLocateDataviewCommand(task.getTaskTag(), rng);
14254
- yield task.DataviewManager.Execute(command);
14255
- }
14256
- else {
14257
- let command2 = CommandFactory.CreateAddUserRangeDataviewCommand(task.getTaskTag(), rng);
14258
- yield task.DataviewManager.Execute(command2);
14259
- }
14260
- }
14261
- return true;
14262
- });
14263
- }
14264
14107
  eval_op_getParam(resVal, name) {
14265
14108
  Debug.Assert(!name.IsNull && name.StrVal !== null);
14266
14109
  let expVal = GlobalParams.Instance.get(name.StrVal);
@@ -19596,6 +19439,13 @@ class DataviewManager extends DataviewManagerBase {
19596
19439
  }
19597
19440
  }
19598
19441
 
19442
+ class Sort {
19443
+ constructor() {
19444
+ this.fldIdx = 0;
19445
+ this.dir = false;
19446
+ }
19447
+ }
19448
+
19599
19449
  class SortCollection {
19600
19450
  constructor() {
19601
19451
  this._sortTab = null;
@@ -19871,6 +19721,7 @@ class MgForm extends MgFormBase {
19871
19721
  try {
19872
19722
  yield this.RefreshDisplay(Constants.TASK_REFRESH_FORM);
19873
19723
  yield this.setCurrRowByDisplayLine(this.GetDataview().getTopRecIdx() + this.getLastValidRow(), false, true);
19724
+ visibleLine = this.getLastValidRow();
19874
19725
  }
19875
19726
  catch (Exception) {
19876
19727
  }
@@ -30388,7 +30239,7 @@ class CommandsTable {
30388
30239
  }
30389
30240
  }
30390
30241
 
30391
- let CurrentClientVersion = '4.1000.0-dev4100.1';
30242
+ let CurrentClientVersion = '4.1000.0-dev4100.100';
30392
30243
 
30393
30244
  class ClientManager {
30394
30245
  constructor() {
@@ -30829,13 +30680,6 @@ class MagicBridge {
30829
30680
  }
30830
30681
  }
30831
30682
 
30832
- class ControlItemsRefreshCommand extends DataviewCommand {
30833
- constructor() {
30834
- super();
30835
- this.Control = null;
30836
- }
30837
- }
30838
-
30839
30683
  class DataViewOutputCommand extends DataviewCommand {
30840
30684
  constructor(OutputCommandType) {
30841
30685
  super();