@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.
- package/esm2020/src/ConstInterface.mjs +2 -1
- package/esm2020/src/CurrentClientVersion.mjs +2 -2
- package/esm2020/src/env/MirrorString.mjs +2 -3
- package/esm2020/src/exp/ExpressionDict.mjs +8 -8
- package/esm2020/src/exp/ExpressionEvaluator.mjs +2 -176
- package/esm2020/src/gui/MgForm.mjs +3 -6
- package/esm2020/src/remote/RemoteCommandsProcessor.mjs +14 -5
- package/esm2020/src/util/PrmMap.mjs +2 -2
- package/fesm2015/magic-xpa-engine.mjs +75 -268
- package/fesm2015/magic-xpa-engine.mjs.map +1 -1
- package/fesm2020/magic-xpa-engine.mjs +75 -241
- package/fesm2020/magic-xpa-engine.mjs.map +1 -1
- package/package.json +4 -4
- package/src/ConstInterface.d.ts +1 -0
- package/src/exp/ExpressionEvaluator.d.ts +0 -9
- package/src/util/PrmMap.d.ts +1 -1
|
@@ -99,7 +99,7 @@ export class MirrorPrmMap extends PrmMap {
|
|
|
99
99
|
while (this.mirrorFromXML(parser.getNextTag(), parser)) {
|
|
100
100
|
}
|
|
101
101
|
}
|
|
102
|
-
|
|
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
|
-
|
|
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(
|
|
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.
|
|
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
|
-
|
|
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
|
-
|
|
7371
|
-
|
|
7372
|
-
|
|
7373
|
-
|
|
7374
|
-
|
|
7375
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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-
|
|
30242
|
+
let CurrentClientVersion = '4.1000.0-dev4100.100';
|
|
30436
30243
|
|
|
30437
30244
|
class ClientManager {
|
|
30438
30245
|
constructor() {
|