@magic-xpa/engine 4.1100.0-dev4110.26 → 4.1100.0-dev4110.260
Sign up to get free protection for your applications and to get access to all the features.
- package/{esm2020 → esm2022}/index.mjs +188 -188
- package/{esm2020 → esm2022}/magic-xpa-engine.mjs +1 -1
- package/esm2022/src/AccessHelper.mjs +15 -0
- package/esm2022/src/ClientManager.mjs +418 -0
- package/esm2022/src/CommandsProcessorBase.mjs +56 -0
- package/{esm2020 → esm2022}/src/CommandsProcessorManager.mjs +25 -25
- package/esm2022/src/CommandsTable.mjs +162 -0
- package/esm2022/src/ConstInterface.mjs +517 -0
- package/{esm2020 → esm2022}/src/CurrentClientVersion.mjs +2 -2
- package/esm2022/src/FlowMonitorInterface.mjs +16 -0
- package/esm2022/src/GUIManager.mjs +62 -0
- package/esm2022/src/GlobalCommandsManager.mjs +34 -0
- package/esm2022/src/GuiEventsProcessor.mjs +156 -0
- package/{esm2020 → esm2022}/src/ICommandsTable.mjs +1 -1
- package/esm2022/src/ServerConfig.mjs +122 -0
- package/{esm2020 → esm2022}/src/bridge/IGuiEvent.mjs +19 -19
- package/esm2022/src/bridge/MagicBridge.mjs +41 -0
- package/esm2022/src/commands/ClientOriginatedCommandTaskTag.mjs +12 -0
- package/{esm2020 → esm2022}/src/commands/ClientToServer/AddUserLocateDataViewCommand.mjs +8 -8
- package/{esm2020 → esm2022}/src/commands/ClientToServer/AddUserRangeDataviewCommand.mjs +9 -9
- package/{esm2020 → esm2022}/src/commands/ClientToServer/AddUserSortDataViewCommand.mjs +9 -9
- package/esm2022/src/commands/ClientToServer/BrowserEscEventCommand.mjs +26 -0
- package/{esm2020 → esm2022}/src/commands/ClientToServer/ClientOriginatedCommand.mjs +14 -14
- package/{esm2020 → esm2022}/src/commands/ClientToServer/ClientOriginatedCommandSerializer.mjs +59 -59
- package/esm2022/src/commands/ClientToServer/ColumnSortEventCommand.mjs +29 -0
- package/esm2022/src/commands/ClientToServer/CommandFactory.mjs +261 -0
- package/esm2022/src/commands/ClientToServer/CommandSerializationHelper.mjs +67 -0
- package/esm2022/src/commands/ClientToServer/ComputeEventCommand.mjs +26 -0
- package/{esm2020 → esm2022}/src/commands/ClientToServer/ContextTerminationEventCommand.mjs +24 -21
- package/{esm2020 → esm2022}/src/commands/ClientToServer/ContextTimeoutResetCommand.mjs +23 -20
- package/{esm2020 → esm2022}/src/commands/ClientToServer/ControlItemsRefreshCommand.mjs +8 -8
- package/esm2022/src/commands/ClientToServer/DataViewOutputCommand.mjs +13 -0
- package/{esm2020 → esm2022}/src/commands/ClientToServer/DataviewCommand.mjs +44 -44
- package/esm2022/src/commands/ClientToServer/EvaluateCommand.mjs +40 -0
- package/{esm2020 → esm2022}/src/commands/ClientToServer/EventCommand.mjs +43 -40
- package/esm2022/src/commands/ClientToServer/ExecOperCommand.mjs +70 -0
- package/esm2022/src/commands/ClientToServer/FetchDataControlValuesEventCommand.mjs +25 -0
- package/{esm2020 → esm2022}/src/commands/ClientToServer/GlobalParamsQueryCommand.mjs +10 -10
- package/{esm2020 → esm2022}/src/commands/ClientToServer/ICommandTaskTag.mjs +1 -1
- package/esm2022/src/commands/ClientToServer/IndexChangeEventCommand.mjs +24 -0
- package/esm2022/src/commands/ClientToServer/IniputForceWriteCommand.mjs +26 -0
- package/{esm2020 → esm2022}/src/commands/ClientToServer/NonReversibleExitEventCommand.mjs +26 -23
- package/{esm2020 → esm2022}/src/commands/ClientToServer/QueryCommand.mjs +20 -20
- package/esm2022/src/commands/ClientToServer/RecomputeCommand.mjs +30 -0
- package/esm2022/src/commands/ClientToServer/RefreshEventCommand.mjs +30 -0
- package/esm2022/src/commands/ClientToServer/RefreshScreenEventCommand.mjs +27 -0
- package/esm2022/src/commands/ClientToServer/RollbackEventCommand.mjs +43 -0
- package/esm2022/src/commands/ClientToServer/SelectProgramCommand.mjs +19 -0
- package/{esm2020 → esm2022}/src/commands/ClientToServer/SetTransactionStateDataviewCommand.mjs +9 -9
- package/esm2022/src/commands/ClientToServer/SubformOpenEventCommand.mjs +24 -0
- package/esm2022/src/commands/ClientToServer/SubformRefreshEventCommand.mjs +27 -0
- package/esm2022/src/commands/ClientToServer/TransactionCommand.mjs +34 -0
- package/{esm2020 → esm2022}/src/commands/ClientToServer/UnloadCommand.mjs +18 -15
- package/esm2022/src/commands/ClientToServer/WriteMessageToServerLogCommand.mjs +18 -0
- package/esm2022/src/commands/DataViewCommandBase.mjs +8 -0
- package/{esm2020 → esm2022}/src/commands/IClientCommand.mjs +1 -1
- package/esm2022/src/commands/IClientTargetedCommand.mjs +13 -0
- package/{esm2020 → esm2022}/src/commands/IClientToServerCommandInfo.mjs +2 -2
- package/esm2022/src/commands/ServerToClient/AbortCommand.mjs +65 -0
- package/{esm2020 → esm2022}/src/commands/ServerToClient/AddLocateCommand.mjs +21 -21
- package/{esm2020 → esm2022}/src/commands/ServerToClient/AddRangeCommand.mjs +62 -62
- package/{esm2020 → esm2022}/src/commands/ServerToClient/AddSortCommand.mjs +33 -33
- package/esm2022/src/commands/ServerToClient/ClientRefreshCommand.mjs +25 -0
- package/esm2022/src/commands/ServerToClient/ClientTargetedCommandBase.mjs +24 -0
- package/esm2022/src/commands/ServerToClient/EnhancedVerifyCommand.mjs +45 -0
- package/esm2022/src/commands/ServerToClient/OpenURLCommand.mjs +221 -0
- package/{esm2020 → esm2022}/src/commands/ServerToClient/ResetLocateCommand.mjs +14 -14
- package/{esm2020 → esm2022}/src/commands/ServerToClient/ResetRangeCommand.mjs +14 -14
- package/{esm2020 → esm2022}/src/commands/ServerToClient/ResetSortCommand.mjs +14 -14
- package/esm2022/src/commands/ServerToClient/ResultCommand.mjs +37 -0
- package/esm2022/src/commands/ServerToClient/VerifyCommand.mjs +83 -0
- package/{esm2020 → esm2022}/src/commands/ServerToClient/XMLBasedCommandBuilder.mjs +132 -132
- package/{esm2020 → esm2022}/src/communications/IConnectionStateManager.mjs +1 -1
- package/esm2022/src/communications/InteractiveCommunicationsFailureHandler.mjs +15 -0
- package/{esm2020 → esm2022}/src/data/DataSourceIdKey.mjs +2 -2
- package/esm2022/src/data/DataView.mjs +1613 -0
- package/{esm2020 → esm2022}/src/data/DataViewBase.mjs +3 -3
- package/esm2022/src/data/DataviewManager.mjs +28 -0
- package/esm2022/src/data/DataviewManagerBase.mjs +15 -0
- package/esm2022/src/data/DvCache.mjs +67 -0
- package/esm2022/src/data/Field.mjs +646 -0
- package/esm2022/src/data/FieldBase.mjs +15 -0
- package/esm2022/src/data/FieldsTable.mjs +103 -0
- package/{esm2020 → esm2022}/src/data/IRecordsTable.mjs +1 -1
- package/{esm2020 → esm2022}/src/data/Key.mjs +88 -88
- package/esm2022/src/data/Record.mjs +880 -0
- package/{esm2020 → esm2022}/src/data/RecordOutOfDataViewException.mjs +15 -15
- package/esm2022/src/data/RecordsTable.mjs +267 -0
- package/{esm2020 → esm2022}/src/data/TaskTransactionManager.mjs +107 -103
- package/{esm2020 → esm2022}/src/data/XMLBasedDcValuesBuilder.mjs +74 -74
- package/{esm2020 → esm2022}/src/enums.mjs +23 -23
- package/esm2022/src/env/EnvVariablesTable.mjs +340 -0
- package/esm2022/src/env/Environment.mjs +487 -0
- package/{esm2020 → esm2022}/src/env/ILanguageData.mjs +1 -1
- package/esm2022/src/env/LanguageData.mjs +227 -0
- package/{esm2020 → esm2022}/src/env/MirrorString.mjs +65 -65
- package/esm2022/src/event/ActionManager.mjs +91 -0
- package/esm2022/src/event/Event.mjs +1333 -0
- package/esm2022/src/event/EventHandler.mjs +766 -0
- package/esm2022/src/event/EventHandlerPosition.mjs +204 -0
- package/esm2022/src/event/EventsManager.mjs +2988 -0
- package/{esm2020 → esm2022}/src/event/IEventsManager.mjs +6 -6
- package/esm2022/src/event/RunTimeEvent.mjs +399 -0
- package/{esm2020 → esm2022}/src/event/RunTimeEventBase.mjs +3 -3
- package/esm2022/src/event/UserEventsTable.mjs +47 -0
- package/esm2022/src/exp/ExpTable.mjs +57 -0
- package/esm2022/src/exp/Expression.mjs +200 -0
- package/esm2022/src/exp/ExpressionDict.mjs +727 -0
- package/esm2022/src/exp/ExpressionEvaluator.mjs +4206 -0
- package/esm2022/src/exp/ExpressionLocalJpn.mjs +314 -0
- package/{esm2020 → esm2022}/src/exp/GlobalParamsTable.mjs +85 -85
- package/esm2022/src/exp/YesNoExp.mjs +36 -0
- package/esm2022/src/gui/CreatedFormVector.mjs +23 -0
- package/esm2022/src/gui/FormsTable.mjs +66 -0
- package/esm2022/src/gui/MgControl.mjs +363 -0
- package/esm2022/src/gui/MgForm.mjs +1224 -0
- package/esm2022/src/http/HttpManager.mjs +97 -0
- package/esm2022/src/http/client/HttpClientAsync.mjs +68 -0
- package/{esm2020 → esm2022}/src/http/client/HttpClientBase.mjs +132 -132
- package/esm2022/src/http/client/HttpClientEvents.mjs +39 -0
- package/esm2022/src/http/client/HttpClientSync.mjs +42 -0
- package/esm2022/src/http/client/HttpUtility.mjs +84 -0
- package/{esm2020 → esm2022}/src/http/client/ICommunicationsFailureHandler.mjs +1 -1
- package/{esm2020 → esm2022}/src/remote/AddUserLocateRemoteDataViewCommand.mjs +18 -18
- package/{esm2020 → esm2022}/src/remote/AddUserRangeRemoteDataViewCommand.mjs +18 -18
- package/{esm2020 → esm2022}/src/remote/AddUserSortRemoteDataViewCommand.mjs +18 -18
- package/esm2022/src/remote/RemoteCommandsProcessor.mjs +883 -0
- package/{esm2020 → esm2022}/src/remote/RemoteControlItemsRefreshCommand.mjs +25 -25
- package/{esm2020 → esm2022}/src/remote/RemoteDataViewCommandBase.mjs +24 -24
- package/{esm2020 → esm2022}/src/remote/RemoteDataViewCommandFactory.mjs +60 -60
- package/{esm2020 → esm2022}/src/remote/RemoteDataViewCommandUpdateNonModifiable.mjs +15 -15
- package/{esm2020 → esm2022}/src/remote/RemoteDataviewManager.mjs +17 -17
- package/{esm2020 → esm2022}/src/remote/RemoteInitDataViewCommand.mjs +10 -10
- package/{esm2020 → esm2022}/src/remote/ResetUserLocateRemoteDataviewCommand.mjs +16 -16
- package/{esm2020 → esm2022}/src/remote/ResetUserRangeRemoteDataviewCommand.mjs +12 -12
- package/{esm2020 → esm2022}/src/remote/ResetUserSortRemoteDataviewCommand.mjs +15 -15
- package/esm2022/src/remote/ServerError.mjs +40 -0
- package/{esm2020 → esm2022}/src/remote/SetTransactionStateRemoteDataViewCommand.mjs +19 -19
- package/esm2022/src/rt/Argument.mjs +265 -0
- package/esm2022/src/rt/ArgumentsList.mjs +103 -0
- package/esm2022/src/rt/Boundary.mjs +152 -0
- package/esm2022/src/rt/CompMainPrgTable.mjs +63 -0
- package/esm2022/src/rt/DataviewHeaderBase.mjs +98 -0
- package/{esm2020 → esm2022}/src/rt/DataviewHeaderFactory.mjs +6 -6
- package/esm2022/src/rt/DataviewHeaders.mjs +53 -0
- package/{esm2020 → esm2022}/src/rt/DataviewHeadersSaxHandler.mjs +38 -38
- package/{esm2020 → esm2022}/src/rt/ExecutionStack.mjs +94 -94
- package/{esm2020 → esm2022}/src/rt/ExecutionStackEntry.mjs +17 -17
- package/{esm2020 → esm2022}/src/rt/HandlersTable.mjs +96 -96
- package/{esm2020 → esm2022}/src/rt/IDataSourceViewDefinition.mjs +1 -1
- package/{esm2020 → esm2022}/src/rt/IDataviewHeader.mjs +1 -1
- package/{esm2020 → esm2022}/src/rt/IResultValue.mjs +1 -1
- package/esm2022/src/rt/LastFocusedManager.mjs +65 -0
- package/esm2022/src/rt/Operation.mjs +735 -0
- package/esm2022/src/rt/OperationTable.mjs +67 -0
- package/esm2022/src/rt/Recompute.mjs +355 -0
- package/{esm2020 → esm2022}/src/rt/RecomputeTable.mjs +62 -62
- package/{esm2020 → esm2022}/src/rt/RemoteDataviewHeader.mjs +108 -108
- package/esm2022/src/rt/ResultValue.mjs +10 -0
- package/esm2022/src/rt/TableCache.mjs +177 -0
- package/esm2022/src/rt/TableCacheManager.mjs +67 -0
- package/esm2022/src/rt/Transaction.mjs +53 -0
- package/esm2022/src/security/UserDetails.mjs +71 -0
- package/{esm2020 → esm2022}/src/tasks/IMGDataCollection.mjs +1 -1
- package/esm2022/src/tasks/MGData.mjs +552 -0
- package/esm2022/src/tasks/MGDataCollection.mjs +252 -0
- package/esm2022/src/tasks/RCTimer.mjs +63 -0
- package/{esm2020 → esm2022}/src/tasks/RemoteTaskService.mjs +44 -44
- package/esm2022/src/tasks/Task.mjs +2499 -0
- package/esm2022/src/tasks/TaskBase.mjs +83 -0
- package/{esm2020 → esm2022}/src/tasks/TaskServiceBase.mjs +24 -24
- package/esm2022/src/tasks/TasksTable.mjs +80 -0
- package/esm2022/src/tasks/sort/Sort.mjs +5 -0
- package/{esm2020 → esm2022}/src/tasks/sort/SortCollection.mjs +67 -67
- package/{esm2020 → esm2022}/src/util/ConstUtils.mjs +13 -13
- package/esm2022/src/util/FlowMonitorQueue.mjs +451 -0
- package/{esm2020 → esm2022}/src/util/HeapSort.mjs +69 -69
- package/{esm2020 → esm2022}/src/util/IMirrorXML.mjs +1 -1
- package/{esm2020 → esm2022}/src/util/IServerConfig.mjs +1 -1
- package/{esm2020 → esm2022}/src/util/MgBlockingQueue.mjs +1 -1
- package/esm2022/src/util/MgPriorityBlockingQueue.mjs +74 -0
- package/esm2022/src/util/MgPriorityQueue.mjs +66 -0
- package/{esm2020 → esm2022}/src/util/ParamParseResult.mjs +7 -7
- package/esm2022/src/util/PrmMap.mjs +152 -0
- package/esm2022/src/util/ReturnResult.mjs +46 -0
- package/esm2022/src/util/ReturnResultBase.mjs +18 -0
- package/esm2022/src/util/Scrambler.mjs +89 -0
- package/esm2022/src/util/UniqueIDUtils.mjs +13 -0
- package/{esm2020 → esm2022}/src/util/cookie.service.mjs +91 -91
- package/{fesm2020 → fesm2022}/magic-xpa-engine.mjs +29885 -29693
- package/fesm2022/magic-xpa-engine.mjs.map +1 -0
- package/index.d.ts +187 -187
- package/package.json +8 -14
- package/src/AccessHelper.d.ts +20 -20
- package/src/ClientManager.d.ts +35 -32
- package/src/CommandsProcessorBase.d.ts +23 -23
- package/src/CommandsProcessorManager.d.ts +6 -6
- package/src/CommandsTable.d.ts +22 -22
- package/src/ConstInterface.d.ts +516 -515
- package/src/CurrentClientVersion.d.ts +1 -1
- package/src/FlowMonitorInterface.d.ts +15 -15
- package/src/GUIManager.d.ts +17 -17
- package/src/GlobalCommandsManager.d.ts +17 -17
- package/src/GuiEventsProcessor.d.ts +24 -24
- package/src/ICommandsTable.d.ts +9 -9
- package/src/ServerConfig.d.ts +35 -34
- package/src/bridge/IGuiEvent.d.ts +19 -19
- package/src/bridge/MagicBridge.d.ts +16 -16
- package/src/commands/ClientOriginatedCommandTaskTag.d.ts +8 -8
- package/src/commands/ClientToServer/AddUserLocateDataViewCommand.d.ts +4 -4
- package/src/commands/ClientToServer/AddUserRangeDataviewCommand.d.ts +6 -6
- package/src/commands/ClientToServer/AddUserSortDataViewCommand.d.ts +6 -6
- package/src/commands/ClientToServer/BrowserEscEventCommand.d.ts +9 -8
- package/src/commands/ClientToServer/ClientOriginatedCommand.d.ts +8 -8
- package/src/commands/ClientToServer/ClientOriginatedCommandSerializer.d.ts +6 -6
- package/src/commands/ClientToServer/ColumnSortEventCommand.d.ts +11 -10
- package/src/commands/ClientToServer/CommandFactory.d.ts +64 -64
- package/src/commands/ClientToServer/CommandSerializationHelper.d.ts +20 -20
- package/src/commands/ClientToServer/ComputeEventCommand.d.ts +9 -8
- package/src/commands/ClientToServer/ContextTerminationEventCommand.d.ts +8 -7
- package/src/commands/ClientToServer/ContextTimeoutResetCommand.d.ts +8 -7
- package/src/commands/ClientToServer/ControlItemsRefreshCommand.d.ts +6 -6
- package/src/commands/ClientToServer/DataViewOutputCommand.d.ts +9 -9
- package/src/commands/ClientToServer/DataviewCommand.d.ts +32 -32
- package/src/commands/ClientToServer/EvaluateCommand.d.ts +16 -15
- package/src/commands/ClientToServer/EventCommand.d.ts +16 -15
- package/src/commands/ClientToServer/ExecOperCommand.d.ts +24 -23
- package/src/commands/ClientToServer/FetchDataControlValuesEventCommand.d.ts +9 -8
- package/src/commands/ClientToServer/GlobalParamsQueryCommand.d.ts +5 -5
- package/src/commands/ClientToServer/ICommandTaskTag.d.ts +3 -3
- package/src/commands/ClientToServer/IndexChangeEventCommand.d.ts +9 -8
- package/src/commands/ClientToServer/IniputForceWriteCommand.d.ts +11 -10
- package/src/commands/ClientToServer/NonReversibleExitEventCommand.d.ts +9 -8
- package/src/commands/ClientToServer/QueryCommand.d.ts +8 -8
- package/src/commands/ClientToServer/RecomputeCommand.d.ts +12 -11
- package/src/commands/ClientToServer/RefreshEventCommand.d.ts +13 -12
- package/src/commands/ClientToServer/RefreshScreenEventCommand.d.ts +11 -10
- package/src/commands/ClientToServer/RollbackEventCommand.d.ts +15 -14
- package/src/commands/ClientToServer/SelectProgramCommand.d.ts +7 -6
- package/src/commands/ClientToServer/SetTransactionStateDataviewCommand.d.ts +5 -5
- package/src/commands/ClientToServer/SubformOpenEventCommand.d.ts +9 -8
- package/src/commands/ClientToServer/SubformRefreshEventCommand.d.ts +10 -9
- package/src/commands/ClientToServer/TransactionCommand.d.ts +14 -12
- package/src/commands/ClientToServer/UnloadCommand.d.ts +8 -7
- package/src/commands/ClientToServer/WriteMessageToServerLogCommand.d.ts +6 -6
- package/src/commands/DataViewCommandBase.d.ts +6 -6
- package/src/commands/IClientCommand.d.ts +2 -2
- package/src/commands/IClientTargetedCommand.d.ts +12 -12
- package/src/commands/IClientToServerCommandInfo.d.ts +4 -3
- package/src/commands/ServerToClient/AbortCommand.d.ts +11 -11
- package/src/commands/ServerToClient/AddLocateCommand.d.ts +6 -6
- package/src/commands/ServerToClient/AddRangeCommand.d.ts +10 -10
- package/src/commands/ServerToClient/AddSortCommand.d.ts +9 -9
- package/src/commands/ServerToClient/ClientRefreshCommand.d.ts +7 -7
- package/src/commands/ServerToClient/ClientTargetedCommandBase.d.ts +12 -12
- package/src/commands/ServerToClient/EnhancedVerifyCommand.d.ts +13 -13
- package/src/commands/ServerToClient/OpenURLCommand.d.ts +21 -21
- package/src/commands/ServerToClient/ResetLocateCommand.d.ts +6 -6
- package/src/commands/ServerToClient/ResetRangeCommand.d.ts +6 -6
- package/src/commands/ServerToClient/ResetSortCommand.d.ts +6 -6
- package/src/commands/ServerToClient/ResultCommand.d.ts +10 -10
- package/src/commands/ServerToClient/VerifyCommand.d.ts +17 -17
- package/src/commands/ServerToClient/XMLBasedCommandBuilder.d.ts +11 -11
- package/src/communications/IConnectionStateManager.d.ts +4 -4
- package/src/communications/InteractiveCommunicationsFailureHandler.d.ts +6 -6
- package/src/data/DataSourceIdKey.d.ts +2 -2
- package/src/data/DataView.d.ts +162 -162
- package/src/data/DataViewBase.d.ts +12 -12
- package/src/data/DataviewManager.d.ts +14 -14
- package/src/data/DataviewManagerBase.d.ts +11 -11
- package/src/data/DvCache.d.ts +15 -15
- package/src/data/Field.d.ts +103 -103
- package/src/data/FieldBase.d.ts +23 -23
- package/src/data/FieldsTable.d.ts +27 -27
- package/src/data/IRecordsTable.d.ts +7 -7
- package/src/data/Key.d.ts +15 -15
- package/src/data/Record.d.ts +157 -156
- package/src/data/RecordOutOfDataViewException.d.ts +10 -10
- package/src/data/RecordsTable.d.ts +38 -38
- package/src/data/TaskTransactionManager.d.ts +17 -17
- package/src/data/XMLBasedDcValuesBuilder.d.ts +11 -11
- package/src/enums.d.ts +21 -21
- package/src/env/EnvVariablesTable.d.ts +17 -17
- package/src/env/Environment.d.ts +118 -118
- package/src/env/ILanguageData.d.ts +3 -3
- package/src/env/LanguageData.d.ts +20 -20
- package/src/env/MirrorString.d.ts +15 -15
- package/src/event/ActionManager.d.ts +14 -14
- package/src/event/Event.d.ts +79 -79
- package/src/event/EventHandler.d.ts +66 -66
- package/src/event/EventHandlerPosition.d.ts +25 -25
- package/src/event/EventsManager.d.ts +205 -204
- package/src/event/IEventsManager.d.ts +77 -77
- package/src/event/RunTimeEvent.d.ts +126 -123
- package/src/event/RunTimeEventBase.d.ts +5 -5
- package/src/event/UserEventsTable.d.ts +11 -11
- package/src/exp/ExpTable.d.ts +11 -11
- package/src/exp/Expression.d.ts +37 -37
- package/src/exp/ExpressionDict.d.ts +12 -12
- package/src/exp/ExpressionEvaluator.d.ts +198 -198
- package/src/exp/ExpressionLocalJpn.d.ts +18 -18
- package/src/exp/GlobalParamsTable.d.ts +19 -19
- package/src/exp/YesNoExp.d.ts +9 -9
- package/src/gui/CreatedFormVector.d.ts +10 -10
- package/src/gui/FormsTable.d.ts +15 -15
- package/src/gui/MgControl.d.ts +60 -60
- package/src/gui/MgForm.d.ts +96 -93
- package/src/http/HttpManager.d.ts +25 -25
- package/src/http/client/HttpClientAsync.d.ts +16 -16
- package/src/http/client/HttpClientBase.d.ts +30 -30
- package/src/http/client/HttpClientEvents.d.ts +18 -18
- package/src/http/client/HttpClientSync.d.ts +17 -17
- package/src/http/client/HttpUtility.d.ts +10 -10
- package/src/http/client/ICommunicationsFailureHandler.d.ts +5 -5
- package/src/remote/AddUserLocateRemoteDataViewCommand.d.ts +8 -8
- package/src/remote/AddUserRangeRemoteDataViewCommand.d.ts +8 -8
- package/src/remote/AddUserSortRemoteDataViewCommand.d.ts +8 -8
- package/src/remote/RemoteCommandsProcessor.d.ts +51 -51
- package/src/remote/RemoteControlItemsRefreshCommand.d.ts +8 -8
- package/src/remote/RemoteDataViewCommandBase.d.ts +10 -10
- package/src/remote/RemoteDataViewCommandFactory.d.ts +6 -6
- package/src/remote/RemoteDataViewCommandUpdateNonModifiable.d.ts +8 -8
- package/src/remote/RemoteDataviewManager.d.ts +9 -9
- package/src/remote/RemoteInitDataViewCommand.d.ts +7 -7
- package/src/remote/ResetUserLocateRemoteDataviewCommand.d.ts +7 -7
- package/src/remote/ResetUserRangeRemoteDataviewCommand.d.ts +7 -7
- package/src/remote/ResetUserSortRemoteDataviewCommand.d.ts +7 -7
- package/src/remote/ServerError.d.ts +16 -16
- package/src/remote/SetTransactionStateRemoteDataViewCommand.d.ts +8 -8
- package/src/rt/Argument.d.ts +36 -36
- package/src/rt/ArgumentsList.d.ts +24 -24
- package/src/rt/Boundary.d.ts +27 -27
- package/src/rt/CompMainPrgTable.d.ts +10 -10
- package/src/rt/DataviewHeaderBase.d.ts +34 -34
- package/src/rt/DataviewHeaderFactory.d.ts +5 -5
- package/src/rt/DataviewHeaders.d.ts +12 -12
- package/src/rt/DataviewHeadersSaxHandler.d.ts +10 -10
- package/src/rt/ExecutionStack.d.ts +22 -22
- package/src/rt/ExecutionStackEntry.d.ts +7 -7
- package/src/rt/HandlersTable.d.ts +19 -19
- package/src/rt/IDataSourceViewDefinition.d.ts +6 -6
- package/src/rt/IDataviewHeader.d.ts +10 -10
- package/src/rt/IResultValue.d.ts +4 -4
- package/src/rt/LastFocusedManager.d.ts +23 -23
- package/src/rt/Operation.d.ts +97 -97
- package/src/rt/OperationTable.d.ts +15 -15
- package/src/rt/Recompute.d.ts +41 -41
- package/src/rt/RecomputeTable.d.ts +9 -9
- package/src/rt/RemoteDataviewHeader.d.ts +14 -14
- package/src/rt/ResultValue.d.ts +7 -7
- package/src/rt/TableCache.d.ts +29 -29
- package/src/rt/TableCacheManager.d.ts +10 -10
- package/src/rt/Transaction.d.ts +23 -23
- package/src/security/UserDetails.d.ts +16 -16
- package/src/tasks/IMGDataCollection.d.ts +26 -26
- package/src/tasks/MGData.d.ts +63 -63
- package/src/tasks/MGDataCollection.d.ts +42 -42
- package/src/tasks/RCTimer.d.ts +13 -13
- package/src/tasks/RemoteTaskService.d.ts +16 -16
- package/src/tasks/Task.d.ts +312 -312
- package/src/tasks/TaskBase.d.ts +123 -123
- package/src/tasks/TaskServiceBase.d.ts +16 -16
- package/src/tasks/TasksTable.d.ts +21 -21
- package/src/tasks/sort/Sort.d.ts +4 -4
- package/src/tasks/sort/SortCollection.d.ts +11 -11
- package/src/util/ConstUtils.d.ts +3 -3
- package/src/util/FlowMonitorQueue.d.ts +70 -70
- package/src/util/HeapSort.d.ts +6 -6
- package/src/util/IMirrorXML.d.ts +6 -6
- package/src/util/IServerConfig.d.ts +11 -11
- package/src/util/MgBlockingQueue.d.ts +5 -5
- package/src/util/MgPriorityBlockingQueue.d.ts +17 -17
- package/src/util/MgPriorityQueue.d.ts +13 -13
- package/src/util/ParamParseResult.d.ts +6 -6
- package/src/util/PrmMap.d.ts +28 -28
- package/src/util/ReturnResult.d.ts +18 -18
- package/src/util/ReturnResultBase.d.ts +11 -11
- package/src/util/Scrambler.d.ts +10 -10
- package/src/util/UniqueIDUtils.d.ts +4 -4
- package/src/util/cookie.service.d.ts +8 -8
- package/esm2020/src/AccessHelper.mjs +0 -9
- package/esm2020/src/ClientManager.mjs +0 -399
- package/esm2020/src/CommandsProcessorBase.mjs +0 -58
- package/esm2020/src/CommandsTable.mjs +0 -162
- package/esm2020/src/ConstInterface.mjs +0 -516
- package/esm2020/src/FlowMonitorInterface.mjs +0 -16
- package/esm2020/src/GUIManager.mjs +0 -62
- package/esm2020/src/GlobalCommandsManager.mjs +0 -34
- package/esm2020/src/GuiEventsProcessor.mjs +0 -154
- package/esm2020/src/ServerConfig.mjs +0 -117
- package/esm2020/src/bridge/MagicBridge.mjs +0 -41
- package/esm2020/src/commands/ClientOriginatedCommandTaskTag.mjs +0 -11
- package/esm2020/src/commands/ClientToServer/BrowserEscEventCommand.mjs +0 -23
- package/esm2020/src/commands/ClientToServer/ColumnSortEventCommand.mjs +0 -26
- package/esm2020/src/commands/ClientToServer/CommandFactory.mjs +0 -260
- package/esm2020/src/commands/ClientToServer/CommandSerializationHelper.mjs +0 -69
- package/esm2020/src/commands/ClientToServer/ComputeEventCommand.mjs +0 -23
- package/esm2020/src/commands/ClientToServer/DataViewOutputCommand.mjs +0 -13
- package/esm2020/src/commands/ClientToServer/EvaluateCommand.mjs +0 -36
- package/esm2020/src/commands/ClientToServer/ExecOperCommand.mjs +0 -67
- package/esm2020/src/commands/ClientToServer/FetchDataControlValuesEventCommand.mjs +0 -22
- package/esm2020/src/commands/ClientToServer/IndexChangeEventCommand.mjs +0 -21
- package/esm2020/src/commands/ClientToServer/IniputForceWriteCommand.mjs +0 -23
- package/esm2020/src/commands/ClientToServer/RecomputeCommand.mjs +0 -27
- package/esm2020/src/commands/ClientToServer/RefreshEventCommand.mjs +0 -27
- package/esm2020/src/commands/ClientToServer/RefreshScreenEventCommand.mjs +0 -24
- package/esm2020/src/commands/ClientToServer/RollbackEventCommand.mjs +0 -39
- package/esm2020/src/commands/ClientToServer/SelectProgramCommand.mjs +0 -15
- package/esm2020/src/commands/ClientToServer/SubformOpenEventCommand.mjs +0 -21
- package/esm2020/src/commands/ClientToServer/SubformRefreshEventCommand.mjs +0 -24
- package/esm2020/src/commands/ClientToServer/TransactionCommand.mjs +0 -28
- package/esm2020/src/commands/ClientToServer/WriteMessageToServerLogCommand.mjs +0 -18
- package/esm2020/src/commands/DataViewCommandBase.mjs +0 -10
- package/esm2020/src/commands/IClientTargetedCommand.mjs +0 -9
- package/esm2020/src/commands/ServerToClient/AbortCommand.mjs +0 -65
- package/esm2020/src/commands/ServerToClient/ClientRefreshCommand.mjs +0 -25
- package/esm2020/src/commands/ServerToClient/ClientTargetedCommandBase.mjs +0 -27
- package/esm2020/src/commands/ServerToClient/EnhancedVerifyCommand.mjs +0 -45
- package/esm2020/src/commands/ServerToClient/OpenURLCommand.mjs +0 -221
- package/esm2020/src/commands/ServerToClient/ResultCommand.mjs +0 -37
- package/esm2020/src/commands/ServerToClient/VerifyCommand.mjs +0 -83
- package/esm2020/src/communications/InteractiveCommunicationsFailureHandler.mjs +0 -17
- package/esm2020/src/data/DataView.mjs +0 -1610
- package/esm2020/src/data/DataviewManager.mjs +0 -28
- package/esm2020/src/data/DataviewManagerBase.mjs +0 -15
- package/esm2020/src/data/DvCache.mjs +0 -67
- package/esm2020/src/data/Field.mjs +0 -646
- package/esm2020/src/data/FieldBase.mjs +0 -18
- package/esm2020/src/data/FieldsTable.mjs +0 -103
- package/esm2020/src/data/Record.mjs +0 -846
- package/esm2020/src/data/RecordsTable.mjs +0 -267
- package/esm2020/src/env/EnvVariablesTable.mjs +0 -340
- package/esm2020/src/env/Environment.mjs +0 -489
- package/esm2020/src/env/LanguageData.mjs +0 -226
- package/esm2020/src/event/ActionManager.mjs +0 -91
- package/esm2020/src/event/Event.mjs +0 -1333
- package/esm2020/src/event/EventHandler.mjs +0 -766
- package/esm2020/src/event/EventHandlerPosition.mjs +0 -204
- package/esm2020/src/event/EventsManager.mjs +0 -2975
- package/esm2020/src/event/RunTimeEvent.mjs +0 -392
- package/esm2020/src/event/UserEventsTable.mjs +0 -47
- package/esm2020/src/exp/ExpTable.mjs +0 -59
- package/esm2020/src/exp/Expression.mjs +0 -200
- package/esm2020/src/exp/ExpressionDict.mjs +0 -727
- package/esm2020/src/exp/ExpressionEvaluator.mjs +0 -4212
- package/esm2020/src/exp/ExpressionLocalJpn.mjs +0 -314
- package/esm2020/src/exp/YesNoExp.mjs +0 -36
- package/esm2020/src/gui/CreatedFormVector.mjs +0 -23
- package/esm2020/src/gui/FormsTable.mjs +0 -66
- package/esm2020/src/gui/MgControl.mjs +0 -353
- package/esm2020/src/gui/MgForm.mjs +0 -1181
- package/esm2020/src/http/HttpManager.mjs +0 -97
- package/esm2020/src/http/client/HttpClientAsync.mjs +0 -67
- package/esm2020/src/http/client/HttpClientEvents.mjs +0 -39
- package/esm2020/src/http/client/HttpClientSync.mjs +0 -42
- package/esm2020/src/http/client/HttpUtility.mjs +0 -84
- package/esm2020/src/remote/RemoteCommandsProcessor.mjs +0 -880
- package/esm2020/src/remote/ServerError.mjs +0 -40
- package/esm2020/src/rt/Argument.mjs +0 -265
- package/esm2020/src/rt/ArgumentsList.mjs +0 -103
- package/esm2020/src/rt/Boundary.mjs +0 -152
- package/esm2020/src/rt/CompMainPrgTable.mjs +0 -65
- package/esm2020/src/rt/DataviewHeaderBase.mjs +0 -96
- package/esm2020/src/rt/DataviewHeaders.mjs +0 -53
- package/esm2020/src/rt/LastFocusedManager.mjs +0 -67
- package/esm2020/src/rt/Operation.mjs +0 -735
- package/esm2020/src/rt/OperationTable.mjs +0 -67
- package/esm2020/src/rt/Recompute.mjs +0 -355
- package/esm2020/src/rt/ResultValue.mjs +0 -12
- package/esm2020/src/rt/TableCache.mjs +0 -177
- package/esm2020/src/rt/TableCacheManager.mjs +0 -67
- package/esm2020/src/rt/Transaction.mjs +0 -53
- package/esm2020/src/security/UserDetails.mjs +0 -71
- package/esm2020/src/tasks/MGData.mjs +0 -552
- package/esm2020/src/tasks/MGDataCollection.mjs +0 -252
- package/esm2020/src/tasks/RCTimer.mjs +0 -63
- package/esm2020/src/tasks/Task.mjs +0 -2495
- package/esm2020/src/tasks/TaskBase.mjs +0 -87
- package/esm2020/src/tasks/TasksTable.mjs +0 -80
- package/esm2020/src/tasks/sort/Sort.mjs +0 -7
- package/esm2020/src/util/FlowMonitorQueue.mjs +0 -453
- package/esm2020/src/util/MgPriorityBlockingQueue.mjs +0 -74
- package/esm2020/src/util/MgPriorityQueue.mjs +0 -66
- package/esm2020/src/util/PrmMap.mjs +0 -151
- package/esm2020/src/util/ReturnResult.mjs +0 -46
- package/esm2020/src/util/ReturnResultBase.mjs +0 -18
- package/esm2020/src/util/Scrambler.mjs +0 -89
- package/esm2020/src/util/UniqueIDUtils.mjs +0 -12
- package/fesm2015/magic-xpa-engine.mjs +0 -30835
- package/fesm2015/magic-xpa-engine.mjs.map +0 -1
- package/fesm2020/magic-xpa-engine.mjs.map +0 -1
@@ -0,0 +1,451 @@
|
|
1
|
+
import { BlobType, DisplayConvertor, PIC, VectorType } from '@magic-xpa/gui';
|
2
|
+
import { DateTime, NString, StringBuilder } from '@magic-xpa/mscorelib';
|
3
|
+
import { Constants, DateTimeUtils, InternalInterface, Logger, Queue, StorageAttribute, XMLConstants, XmlParser } from '@magic-xpa/utils';
|
4
|
+
import { FlowMonitorInterface } from '../FlowMonitorInterface';
|
5
|
+
import { ConstInterface } from '../ConstInterface';
|
6
|
+
export class FlowMonitorQueue {
|
7
|
+
static _instance = null;
|
8
|
+
static UNPRINTABLE_STR_LOG = "#UNPRINTABLE#";
|
9
|
+
static S_EVENT_STR1 = ">>Starts ";
|
10
|
+
static S_EVENT_STR2 = " Event";
|
11
|
+
static S_EVENT_PROPAGATED = "Event was propagated";
|
12
|
+
static E_EVENT_STR = "<<Ends Event";
|
13
|
+
static S_RECPRF_STR = "Starts Record Prefix";
|
14
|
+
static E_RECPRF_STR = "Ends Record Prefix";
|
15
|
+
static S_RECSUF_STR = "Starts Record Suffix";
|
16
|
+
static E_RECSUF_STR = "Ends Record Suffix";
|
17
|
+
static S_TASKSUF_STR = "Starts Task Suffix";
|
18
|
+
static E_TASKSUF_STR = "Ends Task Suffix";
|
19
|
+
static S_TASKPRF_STR = "Starts Task Prefix";
|
20
|
+
static E_TASKPRF_STR = "Ends Task Prefix";
|
21
|
+
static S_CTRLPRF_STR = "Starts Control Prefix - ";
|
22
|
+
static E_CTRLPRF_STR = "Ends Control Prefix - ";
|
23
|
+
static S_CTRLSUF_STR = "Starts Control Suffix - ";
|
24
|
+
static E_CTRLSUF_STR = "Ends Control Suffix - ";
|
25
|
+
static S_HANDLER_STR = "Starts handling event {0}";
|
26
|
+
static E_HANDLER_STR = "Ends handling event {0}";
|
27
|
+
static S_CTRLVER_STR = "Starts Control Verification for Control - ";
|
28
|
+
static E_CTRLVER_STR = "Ends Control Verification for Control - ";
|
29
|
+
static RECOMP_STR = "Recomputes - ";
|
30
|
+
static S_VARIABLE_STR = "Starts Variable Change - ";
|
31
|
+
static E_VARIABLE_STR = "Ends Variable Change - ";
|
32
|
+
static VARIABLE_REASON_STR = " - Reason - Previous value";
|
33
|
+
static FLW_PERFIX = "Flow - ";
|
34
|
+
static ACT_TASK = 'T';
|
35
|
+
static ACT_TASK_FLW = 'F';
|
36
|
+
static ACT_RECOMPUTE = 'R';
|
37
|
+
static ACT_FLW_OPER = 'T';
|
38
|
+
static LongTimePattern = "HH:mm:ss:SSS";
|
39
|
+
_queue = new Queue();
|
40
|
+
_enabled = false;
|
41
|
+
_isFlowOperation = false;
|
42
|
+
_isRecompute = false;
|
43
|
+
_isTask = false;
|
44
|
+
_isTaskFlow = false;
|
45
|
+
_isDataView = false;
|
46
|
+
ShouldSerialize = false;
|
47
|
+
static get Instance() {
|
48
|
+
if (FlowMonitorQueue._instance === null)
|
49
|
+
FlowMonitorQueue._instance = new FlowMonitorQueue();
|
50
|
+
return FlowMonitorQueue._instance;
|
51
|
+
}
|
52
|
+
addTaskCngMode(newTaskMode, taskInfo) {
|
53
|
+
let info = "Task Mode Change - ";
|
54
|
+
if (this._enabled && this._isTask) {
|
55
|
+
let activityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_CHNG_MODE);
|
56
|
+
switch (newTaskMode) {
|
57
|
+
case Constants.TASK_MODE_MODIFY:
|
58
|
+
info += "Modify";
|
59
|
+
break;
|
60
|
+
case Constants.TASK_MODE_CREATE:
|
61
|
+
info += "Create";
|
62
|
+
break;
|
63
|
+
case Constants.TASK_MODE_DELETE:
|
64
|
+
info += "Delete";
|
65
|
+
break;
|
66
|
+
case Constants.TASK_MODE_QUERY:
|
67
|
+
info += "Query";
|
68
|
+
break;
|
69
|
+
default:
|
70
|
+
info = null;
|
71
|
+
break;
|
72
|
+
}
|
73
|
+
activityItem.setInfo(info);
|
74
|
+
this._queue.put(activityItem);
|
75
|
+
Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
|
76
|
+
}
|
77
|
+
}
|
78
|
+
fillData(parser) {
|
79
|
+
let endContext = parser.getXMLdata().indexOf("/>", parser.getCurrIndex());
|
80
|
+
if (endContext !== -1 && endContext < parser.getXMLdata().length) {
|
81
|
+
let tag = parser.getXMLsubstring(endContext);
|
82
|
+
parser.add2CurrIndex(tag.indexOf("flwmtr_config") + "flwmtr_config".length);
|
83
|
+
let tokens = XmlParser.getTokens(parser.getXMLsubstring(endContext), XMLConstants.XML_ATTR_DELIM);
|
84
|
+
Logger.Instance.WriteDevToLog("in FlowMonitorQueue.FillData: " + tokens.toString());
|
85
|
+
this.initElements(tokens);
|
86
|
+
parser.setCurrIndex(endContext + XMLConstants.TAG_TERM.length);
|
87
|
+
return;
|
88
|
+
}
|
89
|
+
Logger.Instance.WriteExceptionToLogWithMsg("in FlowMonitorQueue.FillData() out of string bounds");
|
90
|
+
}
|
91
|
+
initElements(tokensVector) {
|
92
|
+
for (let j = 0; j < tokensVector.length; j = j + 2) {
|
93
|
+
let attribute = tokensVector.get_Item(j);
|
94
|
+
let valueStr = tokensVector.get_Item(j + 1);
|
95
|
+
Logger.Instance.WriteDevToLog(attribute + " value: " + valueStr);
|
96
|
+
switch (attribute) {
|
97
|
+
case ConstInterface.MG_ATTR_TASK:
|
98
|
+
this._isTask = XmlParser.getBoolean(valueStr);
|
99
|
+
break;
|
100
|
+
case ConstInterface.MG_ATTR_TASKFLW:
|
101
|
+
this._isTaskFlow = XmlParser.getBoolean(valueStr);
|
102
|
+
break;
|
103
|
+
case ConstInterface.MG_TAG_DATAVIEW:
|
104
|
+
this._isDataView = XmlParser.getBoolean(valueStr);
|
105
|
+
break;
|
106
|
+
case ConstInterface.MG_ATTR_RECOMP:
|
107
|
+
this._isRecompute = XmlParser.getBoolean(valueStr);
|
108
|
+
break;
|
109
|
+
case ConstInterface.MG_ATTR_FLWOP:
|
110
|
+
this._isFlowOperation = XmlParser.getBoolean(valueStr);
|
111
|
+
break;
|
112
|
+
case ConstInterface.MG_ATTR_ENABLED:
|
113
|
+
this.enable(XmlParser.getBoolean(valueStr));
|
114
|
+
break;
|
115
|
+
default:
|
116
|
+
Logger.Instance.WriteExceptionToLogWithMsg("in FlowMonitorQueue.initElements(): unknown attribute: " + attribute);
|
117
|
+
break;
|
118
|
+
}
|
119
|
+
}
|
120
|
+
}
|
121
|
+
buildXML(message) {
|
122
|
+
if (!this._queue.isEmpty() && this.ShouldSerialize) {
|
123
|
+
message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);
|
124
|
+
while (!this._queue.isEmpty()) {
|
125
|
+
let currAct = this._queue.get();
|
126
|
+
currAct.buildXML(message);
|
127
|
+
}
|
128
|
+
message.Append("</" + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);
|
129
|
+
}
|
130
|
+
}
|
131
|
+
isEmpty() {
|
132
|
+
return this._queue.isEmpty();
|
133
|
+
}
|
134
|
+
enable(value) {
|
135
|
+
let wasEnabled = this._enabled;
|
136
|
+
this._enabled = value;
|
137
|
+
this.ShouldSerialize = this._enabled;
|
138
|
+
return wasEnabled;
|
139
|
+
}
|
140
|
+
addTaskEvent(triggeredBy, state, taskInfo) {
|
141
|
+
if (this._enabled && this._isTask) {
|
142
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_EVENT);
|
143
|
+
let info;
|
144
|
+
switch (state) {
|
145
|
+
case FlowMonitorInterface.FLWMTR_START:
|
146
|
+
info = FlowMonitorQueue.S_EVENT_STR1 + triggeredBy + FlowMonitorQueue.S_EVENT_STR2;
|
147
|
+
break;
|
148
|
+
case FlowMonitorInterface.FLWMTR_END:
|
149
|
+
info = FlowMonitorQueue.E_EVENT_STR + triggeredBy;
|
150
|
+
break;
|
151
|
+
case FlowMonitorInterface.FLWMTR_PROPAGATE:
|
152
|
+
info = FlowMonitorQueue.S_EVENT_PROPAGATED;
|
153
|
+
break;
|
154
|
+
default:
|
155
|
+
info = null;
|
156
|
+
break;
|
157
|
+
}
|
158
|
+
act.setInfo(info);
|
159
|
+
this._queue.put(act);
|
160
|
+
Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
|
161
|
+
}
|
162
|
+
}
|
163
|
+
appendVirtualsAndParameters(currentValues) {
|
164
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, InternalInterface.MG_ACT_REC_PREFIX);
|
165
|
+
act.setInfo(currentValues);
|
166
|
+
this._queue.put(act);
|
167
|
+
}
|
168
|
+
addDataViewFlow(task) {
|
169
|
+
if (this._isDataView) {
|
170
|
+
let fldTab = task.DataView.GetFieldsTab();
|
171
|
+
let preparedDisplayString = "";
|
172
|
+
let finaldisplayData = "\n";
|
173
|
+
let fldValue;
|
174
|
+
let data = "";
|
175
|
+
for (let i = 0; i < fldTab.getSize(); i++) {
|
176
|
+
let fldDef = fldTab.getField(i);
|
177
|
+
if (!fldDef.IsEventHandlerField && (fldDef.IsVirtual && !fldDef.VirAsReal) || fldDef.isParam()) {
|
178
|
+
fldValue = fldDef.isNull() ? fldDef.getNullValue() : fldDef.getValue(true);
|
179
|
+
data = this.getFieldData(fldDef.getType(), fldValue, fldDef.getPicture(), fldDef.getCellsType(), task);
|
180
|
+
preparedDisplayString = this.PrepareDisplayString(fldDef.isParam(), fldDef.getVarName(), data, true);
|
181
|
+
finaldisplayData = finaldisplayData + preparedDisplayString + "\n";
|
182
|
+
}
|
183
|
+
}
|
184
|
+
this.appendVirtualsAndParameters(finaldisplayData);
|
185
|
+
}
|
186
|
+
}
|
187
|
+
getFieldData(Storagetype, data, picture, vecCellType, task) {
|
188
|
+
switch (Storagetype) {
|
189
|
+
case StorageAttribute.DOTNET:
|
190
|
+
data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;
|
191
|
+
break;
|
192
|
+
case StorageAttribute.BLOB:
|
193
|
+
{
|
194
|
+
if (BlobType.isValidBlob(data)) {
|
195
|
+
let contentType = BlobType.getContentType(data);
|
196
|
+
if (contentType == BlobType.CONTENT_TYPE_ANSI || contentType == BlobType.CONTENT_TYPE_UNICODE)
|
197
|
+
data = data != null ? BlobType.getString(data) : "";
|
198
|
+
else
|
199
|
+
data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;
|
200
|
+
}
|
201
|
+
else
|
202
|
+
data = "";
|
203
|
+
}
|
204
|
+
break;
|
205
|
+
case StorageAttribute.NUMERIC:
|
206
|
+
case StorageAttribute.DATE:
|
207
|
+
case StorageAttribute.TIME:
|
208
|
+
let conv = DisplayConvertor.Instance;
|
209
|
+
data = conv.mg2disp(data, " ", new PIC(picture, Storagetype, task.getCompIdx()), false, task.getCompIdx(), false);
|
210
|
+
break;
|
211
|
+
case StorageAttribute.BLOB_VECTOR:
|
212
|
+
let vecOutData;
|
213
|
+
if (data == null) {
|
214
|
+
vecOutData = "[]";
|
215
|
+
}
|
216
|
+
else {
|
217
|
+
let cellAtt = vecCellType;
|
218
|
+
let vector = new VectorType(data);
|
219
|
+
if (cellAtt == StorageAttribute.BLOB && !VectorType.validateBlobContents(data))
|
220
|
+
vecOutData = "[]";
|
221
|
+
else {
|
222
|
+
let vecSize = VectorType.getVecSize(data);
|
223
|
+
let cellPicture = (cellAtt == StorageAttribute.NUMERIC || cellAtt == StorageAttribute.DATE || cellAtt == StorageAttribute.TIME) ? PIC.buildPicture(cellAtt, vector.getVecCell(1), task.getCompIdx(), true).getFormat() : picture;
|
224
|
+
vecOutData = "[";
|
225
|
+
for (let i = 0; i < vecSize; i++) {
|
226
|
+
vecOutData += this.getFieldData(cellAtt, vector.getVecCell(i + 1), cellPicture, vecCellType, task);
|
227
|
+
vecOutData += i < vecSize - 1 ? "," : "]";
|
228
|
+
}
|
229
|
+
}
|
230
|
+
}
|
231
|
+
data = vecOutData;
|
232
|
+
break;
|
233
|
+
case StorageAttribute.BOOLEAN:
|
234
|
+
data = data == "1" ? "TRUE" : "FALSE";
|
235
|
+
break;
|
236
|
+
}
|
237
|
+
return data;
|
238
|
+
}
|
239
|
+
PrepareDisplayString(mode, name, valueContent, addDoubleQuotes) {
|
240
|
+
let str = "";
|
241
|
+
let finalStringToDisplay = "";
|
242
|
+
if (addDoubleQuotes)
|
243
|
+
finalStringToDisplay = finalStringToDisplay + "\"";
|
244
|
+
finalStringToDisplay = finalStringToDisplay + name;
|
245
|
+
if (addDoubleQuotes)
|
246
|
+
finalStringToDisplay = finalStringToDisplay + "\"";
|
247
|
+
let paddedName = this.padRight(name, 34);
|
248
|
+
let formatOfStringVirtual = `Virtual`;
|
249
|
+
let formatOfStringParameter = `Parameter`;
|
250
|
+
str = (mode ? formatOfStringParameter : formatOfStringVirtual) + " : " + `${paddedName}` + " : " + `${valueContent.trim()}`;
|
251
|
+
return str;
|
252
|
+
}
|
253
|
+
padRight = (string, length, character = ' ') => {
|
254
|
+
let result = "";
|
255
|
+
let totalLength = length - string.length;
|
256
|
+
for (let i = 0; i < totalLength; i++) {
|
257
|
+
result = character + result;
|
258
|
+
}
|
259
|
+
result = result + string;
|
260
|
+
return result;
|
261
|
+
};
|
262
|
+
addTaskFlowRec(id, state, taskInfo) {
|
263
|
+
if (this._enabled && this._isTaskFlow) {
|
264
|
+
let info;
|
265
|
+
switch (id) {
|
266
|
+
case InternalInterface.MG_ACT_REC_PREFIX:
|
267
|
+
info = state === FlowMonitorInterface.FLWMTR_START
|
268
|
+
? FlowMonitorQueue.S_RECPRF_STR
|
269
|
+
: FlowMonitorQueue.E_RECPRF_STR;
|
270
|
+
id = FlowMonitorInterface.FLWMTR_PREFIX;
|
271
|
+
break;
|
272
|
+
case InternalInterface.MG_ACT_REC_SUFFIX:
|
273
|
+
info = state === FlowMonitorInterface.FLWMTR_START
|
274
|
+
? FlowMonitorQueue.S_RECSUF_STR
|
275
|
+
: FlowMonitorQueue.E_RECSUF_STR;
|
276
|
+
id = FlowMonitorInterface.FLWMTR_SUFFIX;
|
277
|
+
break;
|
278
|
+
case InternalInterface.MG_ACT_TASK_PREFIX:
|
279
|
+
info = state === FlowMonitorInterface.FLWMTR_START
|
280
|
+
? FlowMonitorQueue.S_TASKPRF_STR
|
281
|
+
: FlowMonitorQueue.E_TASKPRF_STR;
|
282
|
+
id = FlowMonitorInterface.FLWMTR_PREFIX;
|
283
|
+
break;
|
284
|
+
case InternalInterface.MG_ACT_TASK_SUFFIX:
|
285
|
+
info = state === FlowMonitorInterface.FLWMTR_START
|
286
|
+
? FlowMonitorQueue.S_TASKSUF_STR
|
287
|
+
: FlowMonitorQueue.E_TASKSUF_STR;
|
288
|
+
id = FlowMonitorInterface.FLWMTR_SUFFIX;
|
289
|
+
break;
|
290
|
+
default:
|
291
|
+
info = null;
|
292
|
+
break;
|
293
|
+
}
|
294
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);
|
295
|
+
act.setInfo(info);
|
296
|
+
this._queue.put(act);
|
297
|
+
Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
|
298
|
+
}
|
299
|
+
}
|
300
|
+
addTaskFlowFld(id, fldName, state, taskInfo) {
|
301
|
+
this.addTaskFlowCtrl(id, fldName, state, taskInfo);
|
302
|
+
}
|
303
|
+
addTaskFlowCtrl(id, ctrlName, state, taskInfo) {
|
304
|
+
if (this._enabled && this._isTaskFlow) {
|
305
|
+
let info;
|
306
|
+
switch (id) {
|
307
|
+
case InternalInterface.MG_ACT_VARIABLE:
|
308
|
+
info = state === FlowMonitorInterface.FLWMTR_START
|
309
|
+
? FlowMonitorQueue.S_VARIABLE_STR
|
310
|
+
: FlowMonitorQueue.E_VARIABLE_STR;
|
311
|
+
id = FlowMonitorInterface.FLWMTR_VARCHG_VALUE;
|
312
|
+
break;
|
313
|
+
case InternalInterface.MG_ACT_CTRL_PREFIX:
|
314
|
+
info = state === FlowMonitorInterface.FLWMTR_START
|
315
|
+
? FlowMonitorQueue.S_CTRLPRF_STR
|
316
|
+
: FlowMonitorQueue.E_CTRLPRF_STR;
|
317
|
+
id = FlowMonitorInterface.FLWMTR_CTRL_PREFIX;
|
318
|
+
break;
|
319
|
+
case InternalInterface.MG_ACT_CTRL_SUFFIX:
|
320
|
+
info = state === FlowMonitorInterface.FLWMTR_START
|
321
|
+
? FlowMonitorQueue.S_CTRLSUF_STR
|
322
|
+
: FlowMonitorQueue.E_CTRLSUF_STR;
|
323
|
+
id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;
|
324
|
+
break;
|
325
|
+
case InternalInterface.MG_ACT_CTRL_VERIFICATION:
|
326
|
+
info = state === FlowMonitorInterface.FLWMTR_START
|
327
|
+
? FlowMonitorQueue.S_CTRLVER_STR
|
328
|
+
: FlowMonitorQueue.E_CTRLVER_STR;
|
329
|
+
id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;
|
330
|
+
break;
|
331
|
+
default:
|
332
|
+
info = null;
|
333
|
+
break;
|
334
|
+
}
|
335
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);
|
336
|
+
if (info !== null) {
|
337
|
+
info = info + ctrlName;
|
338
|
+
if (id === FlowMonitorInterface.FLWMTR_VARCHG_VALUE && state === FlowMonitorInterface.FLWMTR_START)
|
339
|
+
info = info + FlowMonitorQueue.VARIABLE_REASON_STR;
|
340
|
+
act.setInfo(info);
|
341
|
+
Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
|
342
|
+
}
|
343
|
+
this._queue.put(act);
|
344
|
+
}
|
345
|
+
}
|
346
|
+
addTaskFlowHandler(handlerId, state, taskInfo) {
|
347
|
+
if (this._enabled && this._isTaskFlow) {
|
348
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, FlowMonitorInterface.FLWMTR_TSK_HANDLER);
|
349
|
+
let info;
|
350
|
+
switch (state) {
|
351
|
+
case FlowMonitorInterface.FLWMTR_START:
|
352
|
+
info = NString.Format(FlowMonitorQueue.S_HANDLER_STR, handlerId);
|
353
|
+
break;
|
354
|
+
case FlowMonitorInterface.FLWMTR_END:
|
355
|
+
info = NString.Format(FlowMonitorQueue.E_HANDLER_STR, handlerId);
|
356
|
+
break;
|
357
|
+
default:
|
358
|
+
info = null;
|
359
|
+
break;
|
360
|
+
}
|
361
|
+
if (info !== null) {
|
362
|
+
act.setInfo(info);
|
363
|
+
Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
|
364
|
+
}
|
365
|
+
this._queue.put(act);
|
366
|
+
}
|
367
|
+
}
|
368
|
+
addRecompute(triggeredByVarName, taskInfo) {
|
369
|
+
if (this._enabled && this._isRecompute) {
|
370
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_RECOMPUTE, FlowMonitorInterface.FLWMTR_RECOMP);
|
371
|
+
let info = FlowMonitorQueue.RECOMP_STR + triggeredByVarName;
|
372
|
+
act.setInfo(info);
|
373
|
+
this._queue.put(act);
|
374
|
+
Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
|
375
|
+
}
|
376
|
+
}
|
377
|
+
async addFlowFieldOperation(oper, bExecuted, taskInfo) {
|
378
|
+
if (this._enabled && this._isFlowOperation) {
|
379
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);
|
380
|
+
let buffer = new StringBuilder(FlowMonitorQueue.FLW_PERFIX);
|
381
|
+
await oper.AddFlowDescription(buffer);
|
382
|
+
buffer.Append(' ');
|
383
|
+
if (!bExecuted)
|
384
|
+
buffer.Append("[Not Executed]");
|
385
|
+
let info = buffer.ToString();
|
386
|
+
act.setInfo(info);
|
387
|
+
this._queue.put(act);
|
388
|
+
Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
|
389
|
+
}
|
390
|
+
}
|
391
|
+
addFlowOperationUpdate(state, taskInfo) {
|
392
|
+
if (this._enabled && this._isFlowOperation) {
|
393
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);
|
394
|
+
let info;
|
395
|
+
if (state === FlowMonitorInterface.FLWMTR_START)
|
396
|
+
info = "Starts Update";
|
397
|
+
else
|
398
|
+
info = "Ends Update";
|
399
|
+
act.setInfo(info);
|
400
|
+
this._queue.put(act);
|
401
|
+
Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
|
402
|
+
}
|
403
|
+
}
|
404
|
+
addFlowVerifyInfo(info, taskInfo) {
|
405
|
+
this.addFlowInfo(info, taskInfo);
|
406
|
+
}
|
407
|
+
addFlowInvokeOsInfo(info, taskInfo) {
|
408
|
+
this.addFlowInfo(info, taskInfo);
|
409
|
+
}
|
410
|
+
addFlowInfo(info, taskInfo) {
|
411
|
+
if (!this._enabled)
|
412
|
+
return;
|
413
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);
|
414
|
+
let buffer = new StringBuilder("");
|
415
|
+
if (!(info === "")) {
|
416
|
+
buffer.Append(" >> INFORMATION >> ");
|
417
|
+
buffer.Append(info);
|
418
|
+
}
|
419
|
+
let newInfo = buffer.ToString();
|
420
|
+
act.setInfo(newInfo);
|
421
|
+
this._queue.put(act);
|
422
|
+
Logger.Instance.WriteSupportToLog(taskInfo + ": " + newInfo, true);
|
423
|
+
}
|
424
|
+
}
|
425
|
+
class ActivityItem {
|
426
|
+
_id = 0;
|
427
|
+
_type = null;
|
428
|
+
_info = null;
|
429
|
+
_time = null;
|
430
|
+
constructor(enclosingInstance, type, id) {
|
431
|
+
this._type = type;
|
432
|
+
this._id = id;
|
433
|
+
this.setTime();
|
434
|
+
}
|
435
|
+
setTime() {
|
436
|
+
this._time = DateTimeUtils.ToString(DateTime.Now, FlowMonitorQueue.LongTimePattern, Logger.Instance);
|
437
|
+
}
|
438
|
+
setInfo(info_) {
|
439
|
+
this._info = ((info_ !== null) ? XmlParser.escape(info_) : info_);
|
440
|
+
}
|
441
|
+
buildXML(message) {
|
442
|
+
message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_ACT);
|
443
|
+
message.Append(" " + XMLConstants.MG_ATTR_TYPE + "=\"" + this._type + "\"");
|
444
|
+
message.Append(" " + XMLConstants.MG_ATTR_ID + "=\"" + this._id + "\"");
|
445
|
+
if (this._info != null)
|
446
|
+
message.Append(" " + ConstInterface.MG_ATTR_INFO + "=\"" + this._info + "\"");
|
447
|
+
message.Append(" " + ConstInterface.MG_ATTR_TIME + "=\"" + this._time + "\"");
|
448
|
+
message.Append(XMLConstants.TAG_TERM);
|
449
|
+
}
|
450
|
+
}
|
451
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FlowMonitorQueue.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/util/FlowMonitorQueue.ts"],"names":[],"mappings":"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","sourcesContent":["import {BlobType, DisplayConvertor, FieldsTable, IFlowMonitorQueue, PIC, VectorType} from '@magic-xpa/gui';\r\nimport {DateTime, List, NString, StringBuilder} from '@magic-xpa/mscorelib';\r\nimport {Constants, DateTimeUtils, InternalInterface, Logger, Queue, StorageAttribute, XMLConstants, XmlParser} from '@magic-xpa/utils';\r\nimport {Operation} from '../rt/Operation';\r\nimport {FlowMonitorInterface} from '../FlowMonitorInterface';\r\nimport {ConstInterface} from '../ConstInterface';\r\nimport { Task } from '../tasks/Task';\r\nimport { Field } from '../data/Field';\r\n\r\n// @dynamic\r\nexport class FlowMonitorQueue implements IFlowMonitorQueue {\r\n  private static _instance: FlowMonitorQueue = null;\r\n  private static UNPRINTABLE_STR_LOG: string = \"#UNPRINTABLE#\";\r\n  private static S_EVENT_STR1: string = \">>Starts \";\r\n  private static S_EVENT_STR2: string = \" Event\";\r\n  private static S_EVENT_PROPAGATED: string = \"Event was propagated\";\r\n  private static E_EVENT_STR: string = \"<<Ends Event\";\r\n\r\n  private static S_RECPRF_STR: string = \"Starts Record Prefix\";\r\n  private static E_RECPRF_STR: string = \"Ends Record Prefix\";\r\n  private static S_RECSUF_STR: string = \"Starts Record Suffix\";\r\n  private static E_RECSUF_STR: string = \"Ends Record Suffix\";\r\n  private static S_TASKSUF_STR: string = \"Starts Task Suffix\";\r\n  private static E_TASKSUF_STR: string = \"Ends Task Suffix\";\r\n  private static S_TASKPRF_STR: string = \"Starts Task Prefix\";\r\n  private static E_TASKPRF_STR: string = \"Ends Task Prefix\";\r\n  private static S_CTRLPRF_STR: string = \"Starts Control Prefix - \";\r\n  private static E_CTRLPRF_STR: string = \"Ends Control Prefix - \";\r\n  private static S_CTRLSUF_STR: string = \"Starts Control Suffix - \";\r\n  private static E_CTRLSUF_STR: string = \"Ends Control Suffix - \";\r\n  private static S_HANDLER_STR: string = \"Starts handling event {0}\";\r\n  private static E_HANDLER_STR: string = \"Ends handling event {0}\";\r\n  private static S_CTRLVER_STR: string = \"Starts Control Verification for Control - \";\r\n  private static E_CTRLVER_STR: string = \"Ends Control Verification for Control - \";\r\n  private static RECOMP_STR: string = \"Recomputes - \";\r\n  private static S_VARIABLE_STR: string = \"Starts Variable Change - \";\r\n  private static E_VARIABLE_STR: string = \"Ends Variable Change - \";\r\n  private static VARIABLE_REASON_STR: string = \" - Reason - Previous value\";\r\n\r\n\r\n  private static FLW_PERFIX: string = \"Flow - \";\r\n\r\n  private static ACT_TASK: string = 'T';\r\n  private static ACT_TASK_FLW: string = 'F';\r\n  private static ACT_RECOMPUTE: string = 'R';\r\n  private static ACT_FLW_OPER: string = 'T';\r\n\r\n  static LongTimePattern = \"HH:mm:ss:SSS\";\r\n  private _queue: Queue<ActivityItem> = new Queue<ActivityItem>();\r\n  private _enabled: boolean = false;\r\n  private _isFlowOperation: boolean = false;\r\n  private _isRecompute: boolean = false;\r\n  private _isTask: boolean = false;\r\n  private _isTaskFlow: boolean = false;\r\n  private _isDataView: boolean = false;\r\n  ShouldSerialize: boolean = false;\r\n\r\n  static get Instance(): FlowMonitorQueue {\r\n    if (FlowMonitorQueue._instance === null)\r\n      FlowMonitorQueue._instance = new FlowMonitorQueue();\r\n\r\n    return FlowMonitorQueue._instance;\r\n  }\r\n\r\n  addTaskCngMode(newTaskMode: string, taskInfo: string): void {\r\n    let info: string = \"Task Mode Change - \";\r\n    if (this._enabled && this._isTask) {\r\n      let activityItem: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_CHNG_MODE);\r\n\r\n      switch (newTaskMode) {\r\n        case Constants.TASK_MODE_MODIFY:\r\n          info += \"Modify\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_CREATE:\r\n          info += \"Create\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_DELETE:\r\n          info += \"Delete\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_QUERY:\r\n          info += \"Query\";\r\n          break;\r\n\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      activityItem.setInfo(info);\r\n      this._queue.put(activityItem);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   parse the data\r\n  /// </summary>\r\n  fillData(parser: XmlParser): void {\r\n    let endContext: number = parser.getXMLdata().indexOf(\"/>\", parser.getCurrIndex());\r\n    if (endContext !== -1 && endContext < parser.getXMLdata().length) {\r\n      // find last position of its tag\r\n      let tag: string = parser.getXMLsubstring(endContext);\r\n      parser.add2CurrIndex(tag.indexOf(\"flwmtr_config\") + \"flwmtr_config\".length);\r\n\r\n      let tokens: List<string> = XmlParser.getTokens(parser.getXMLsubstring(endContext), XMLConstants.XML_ATTR_DELIM);\r\n      Logger.Instance.WriteDevToLog(\"in FlowMonitorQueue.FillData: \" + tokens.toString());\r\n\r\n      this.initElements(tokens);\r\n      parser.setCurrIndex(endContext + XMLConstants.TAG_TERM.length); // to delete \"/>\" too\r\n      return;\r\n    }\r\n    Logger.Instance.WriteExceptionToLogWithMsg(\"in  FlowMonitorQueue.FillData() out of string bounds\");\r\n  }\r\n\r\n  /// <summary>\r\n  ///   parse the XML data\r\n  /// </summary>\r\n  /// <param name = \"tokensVector\">attribute/value/...attribute/value/ vector</param>\r\n  private initElements(tokensVector: List<string>): void {\r\n\r\n    for (let j: number = 0; j < tokensVector.length; j = j + 2) {\r\n      let attribute: string = <string>tokensVector.get_Item(j);\r\n      let valueStr: string = <string>tokensVector.get_Item(j + 1);\r\n      Logger.Instance.WriteDevToLog(attribute + \" value: \" + valueStr);\r\n\r\n      switch (attribute) {\r\n        case ConstInterface.MG_ATTR_TASK:\r\n          this._isTask = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_TASKFLW:\r\n          this._isTaskFlow = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_TAG_DATAVIEW:\r\n          this._isDataView = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_RECOMP:\r\n          this._isRecompute = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_FLWOP:\r\n          this._isFlowOperation = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_ENABLED:\r\n          this.enable(XmlParser.getBoolean(valueStr));\r\n          break;\r\n\r\n        default:\r\n          Logger.Instance.WriteExceptionToLogWithMsg(\"in FlowMonitorQueue.initElements(): unknown  attribute: \" + attribute);\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   build XML and empty the inner queue\r\n  /// </summary>\r\n  buildXML(message: StringBuilder): void {\r\n    if (!this._queue.isEmpty() && this.ShouldSerialize) {\r\n      message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);\r\n\r\n      while (!this._queue.isEmpty()) {\r\n        let currAct: ActivityItem = <ActivityItem>this._queue.get();\r\n        currAct.buildXML(message);\r\n      } // fill activities\r\n\r\n      message.Append(\"</\" + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);\r\n    } // the queue is not empty\r\n  }\r\n\r\n  /// <summary>\r\n  ///   is the Flow Monitor Queue empty\r\n  /// </summary>\r\n  isEmpty(): boolean {\r\n    return this._queue.isEmpty();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   enable the flow monitor\r\n  /// </summary>\r\n  /// <returns>the previous state (enabled/disabled)</returns>\r\n  enable(value: boolean): boolean {\r\n    let wasEnabled: boolean = this._enabled;\r\n    this._enabled = value;\r\n    this.ShouldSerialize = this._enabled;\r\n    return wasEnabled;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   add Activities to the queue\r\n  /// </summary>\r\n  /// <param name = \"triggeredBy\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskEvent(triggeredBy: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTask) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_EVENT);\r\n\r\n      let info: string;\r\n      switch (state) {\r\n        case FlowMonitorInterface.FLWMTR_START:\r\n          info = FlowMonitorQueue.S_EVENT_STR1 + triggeredBy + FlowMonitorQueue.S_EVENT_STR2;\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_END:\r\n          info = FlowMonitorQueue.E_EVENT_STR + triggeredBy;\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_PROPAGATE:\r\n          info = FlowMonitorQueue.S_EVENT_PROPAGATED;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  private appendVirtualsAndParameters(currentValues: string) : void\r\n  {\r\n    let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, InternalInterface.MG_ACT_REC_PREFIX);\r\n    act.setInfo(currentValues);\r\n    this._queue.put(act);\r\n  }\r\n\r\n  // /// <summary>\r\n  // ///   add virtual and parameter information and send it to server on record prefix\r\n  // /// </summary>\r\n  // /// <param name = \"task\">\r\n  // /// </param>\r\n  addDataViewFlow(task: Task) : void\r\n  { \r\n      if (this._isDataView)\r\n      {\r\n          let fldTab: FieldsTable = task.DataView.GetFieldsTab();\r\n          let preparedDisplayString: string = \"\";\r\n          let finaldisplayData: string = \"\\n\";\r\n          let fldValue: string;\r\n          let data: string = \"\";\r\n          for (let i: number = 0; i < fldTab.getSize(); i++)\r\n          {\r\n              let fldDef: Field = <Field>fldTab.getField(i);\r\n              if (!fldDef.IsEventHandlerField && (fldDef.IsVirtual && !fldDef.VirAsReal) || fldDef.isParam())\r\n              {\r\n                  fldValue = fldDef.isNull() ? fldDef.getNullValue() : fldDef.getValue(true);\r\n                  data = this.getFieldData(fldDef.getType(), fldValue, fldDef.getPicture(), fldDef.getCellsType(), task);\r\n                  preparedDisplayString = this.PrepareDisplayString(fldDef.isParam(), fldDef.getVarName(), data, true);\r\n                  finaldisplayData = finaldisplayData + preparedDisplayString + \"\\n\";\r\n              }\r\n          }\r\n          this.appendVirtualsAndParameters(finaldisplayData);\r\n      }\r\n   }\r\n\r\n  // /// <summary>\r\n  // ///   Get virtuals and parameter values.\r\n  // /// </summary>\r\n  // /// <param name = \"Storagetype\"></param>\r\n  // /// <param name = \"data\"></param>\r\n  // /// <param name = \"picture\"></param>\r\n  // /// <param name = \"vecCellType\"></param>\r\n  // /// <param name = \"task\"></param>\r\n  // /// </param>\r\n  private getFieldData(Storagetype: StorageAttribute, data: string, picture: string, vecCellType: StorageAttribute, task: Task): string\r\n  {\r\n      switch (Storagetype)\r\n      {\r\n          case StorageAttribute.DOTNET:\r\n              data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;\r\n              break;\r\n\r\n          case StorageAttribute.BLOB:\r\n              {\r\n                if(BlobType.isValidBlob(data))\r\n                {\r\n                  let contentType: string = BlobType.getContentType(data);\r\n                  if (contentType == BlobType.CONTENT_TYPE_ANSI || contentType == BlobType.CONTENT_TYPE_UNICODE)\r\n                      data = data != null ? BlobType.getString(data) : \"\";\r\n                  else\r\n                      data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;\r\n                }\r\n                else\r\n                  data = \"\";\r\n              }\r\n              break;\r\n\r\n          case StorageAttribute.NUMERIC:\r\n          case StorageAttribute.DATE:\r\n          case StorageAttribute.TIME:\r\n              let conv: DisplayConvertor= DisplayConvertor.Instance;\r\n              data = conv.mg2disp(data, \" \", new PIC(picture, Storagetype, task.getCompIdx()), false, task.getCompIdx(), false);\r\n              break;\r\n\r\n          case StorageAttribute.BLOB_VECTOR:\r\n              let vecOutData: string;\r\n              if (data == null)\r\n              {\r\n                  vecOutData = \"[]\";\r\n              }\r\n              else\r\n              {\r\n                  let cellAtt: StorageAttribute = vecCellType;\r\n                  let vector: VectorType = new VectorType(data);\r\n                  if (cellAtt == StorageAttribute.BLOB && !VectorType.validateBlobContents(data))\r\n                      vecOutData = \"[]\";\r\n                  else\r\n                  {\r\n                      let vecSize: number = VectorType.getVecSize(data);\r\n                      let cellPicture: string = (cellAtt == StorageAttribute.NUMERIC || cellAtt == StorageAttribute.DATE || cellAtt == StorageAttribute.TIME) ? PIC.buildPicture(cellAtt, vector.getVecCell(1), task.getCompIdx(), true).getFormat() : picture;\r\n                      vecOutData = \"[\";\r\n                      for (let i : number = 0; i < vecSize; i++)\r\n                      {\r\n                          vecOutData += this.getFieldData(cellAtt, vector.getVecCell(i + 1), cellPicture, vecCellType, task);\r\n                          vecOutData += i < vecSize - 1 ? \",\" : \"]\";\r\n                      }\r\n                  }\r\n              }\r\n              data = vecOutData;\r\n              break;\r\n\r\n          case StorageAttribute.BOOLEAN:\r\n              data = data == \"1\" ? \"TRUE\" : \"FALSE\";\r\n              break;\r\n      }\r\n      return data;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Prepare display string that will be sent to the server on record prefix.\r\n  /// </summary>\r\n  /// <param name = \"mode\"></param>\r\n  /// <param name = \"name\"></param>\r\n  /// <param name = \"valueContent\"></param>\r\n  /// <param name = \"addDoubleQuotes\"></param>\r\n  /// </param>\r\n  private PrepareDisplayString(mode: boolean, name: string, valueContent: string, addDoubleQuotes: boolean): string\r\n  {\r\n      let  str: string = \"\";\r\n      let finalStringToDisplay: string = \"\";\r\n      if (addDoubleQuotes)\r\n          finalStringToDisplay = finalStringToDisplay + \"\\\"\";\r\n      finalStringToDisplay = finalStringToDisplay + name;\r\n      if (addDoubleQuotes)\r\n          finalStringToDisplay = finalStringToDisplay + \"\\\"\";\r\n\r\n      let paddedName = this.padRight(name,34);\r\n      let formatOfStringVirtual:string = `Virtual` ;//: ${paddedName} : ${valueContent}`;\r\n      let formatOfStringParameter: string = `Parameter`;//` : ${paddedName} : ${valueContent}`;\r\n     \r\n      str = (mode ? formatOfStringParameter : formatOfStringVirtual) + \" : \" +`${paddedName}`+ \" : \"+`${valueContent.trim()}`;\r\n\r\n      return str;\r\n  }\r\n\r\n   private padRight = (string: string, length: number, character: string = ' '): string => {\r\n    let result = \"\";\r\n    let totalLength = length - string.length;\r\n    for (let i = 0; i < totalLength; i++) {\r\n      result = character + result;\r\n    }\r\n    result = result + string;\r\n    return result;\r\n  };\r\n  /// <summary>\r\n  ///   add task flow for record prefix or sufix\r\n  /// </summary>\r\n  /// <param name = \"id\">is FLWMTR_PREFIX or FLWMTR_SUFFIX\r\n  /// </param>\r\n  /// <param name = \"state\">of the event task activitie\r\n  /// </param>\r\n  addTaskFlowRec(id: number, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let info: string;\r\n\r\n      switch (id) {\r\n        case InternalInterface.MG_ACT_REC_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_RECPRF_STR\r\n            : FlowMonitorQueue.E_RECPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_PREFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_REC_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_RECSUF_STR\r\n            : FlowMonitorQueue.E_RECSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_SUFFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_TASK_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_TASKPRF_STR\r\n            : FlowMonitorQueue.E_TASKPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_PREFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_TASK_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_TASKSUF_STR\r\n            : FlowMonitorQueue.E_TASKSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_SUFFIX;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"id\">is MG_ACT_VARIABLE</param>\r\n  /// <param name = \"fldName\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskFlowFld(id: number, fldName: string, state: number, taskInfo: string): void {\r\n    this.addTaskFlowCtrl(id, fldName, state, taskInfo);\r\n  }\r\n\r\n  /// <param name = \"id\">is FLWMTR_CTRL_PREFIX or FLWMTR_CTRL_SUFFIX</param>\r\n  /// <param name = \"ctrlName\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskFlowCtrl(id: number, ctrlName: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let info: string;\r\n\r\n      switch (id) {\r\n        case InternalInterface.MG_ACT_VARIABLE:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_VARIABLE_STR\r\n            : FlowMonitorQueue.E_VARIABLE_STR;\r\n          id = FlowMonitorInterface.FLWMTR_VARCHG_VALUE;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_CTRL_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLPRF_STR\r\n            : FlowMonitorQueue.E_CTRLPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_PREFIX;\r\n          break;\r\n\r\n\r\n        case InternalInterface.MG_ACT_CTRL_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLSUF_STR\r\n            : FlowMonitorQueue.E_CTRLSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_CTRL_VERIFICATION:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLVER_STR\r\n            : FlowMonitorQueue.E_CTRLVER_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);\r\n      if (info !== null) {\r\n        info = info + ctrlName;\r\n        if (id === FlowMonitorInterface.FLWMTR_VARCHG_VALUE && state === FlowMonitorInterface.FLWMTR_START)\r\n          info = info + FlowMonitorQueue.VARIABLE_REASON_STR;\r\n        act.setInfo(info);\r\n        Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n      }\r\n      this._queue.put(act);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"handlerId\">isid of the handler\r\n  /// </param>\r\n  /// <param name = \"state\">of the event task activitie\r\n  /// </param>\r\n  addTaskFlowHandler(handlerId: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, FlowMonitorInterface.FLWMTR_TSK_HANDLER);\r\n      let info: string;\r\n\r\n      switch (state) {\r\n        case FlowMonitorInterface.FLWMTR_START:\r\n          info = NString.Format(FlowMonitorQueue.S_HANDLER_STR, handlerId);\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_END:\r\n          info = NString.Format(FlowMonitorQueue.E_HANDLER_STR, handlerId);\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      if (info !== null) {\r\n        // BRK_LEVEL_HANDLER_INTERNAL,BRK_LEVEL_HANDLER_SYSTEM,BRK_LEVEL_HANDLER_TIMER\r\n        // BRK_LEVEL_HANDLER_EXPRESSION,BRK_LEVEL_HANDLER_ERROR,BRK_LEVEL_HANDLER_USER\r\n        act.setInfo(info);\r\n        Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n      }\r\n      this._queue.put(act);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"triggeredByVarName\">var name , has triggered Recompute\r\n  /// </param>\r\n  addRecompute(triggeredByVarName: string, taskInfo: string): void {\r\n    if (this._enabled && this._isRecompute) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_RECOMPUTE, FlowMonitorInterface.FLWMTR_RECOMP);\r\n      let info = FlowMonitorQueue.RECOMP_STR + triggeredByVarName;\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Add a field flow operation activity item.\r\n  /// </summary>\r\n  /// <param name = \"oper\">The operation being logged.</param>\r\n  /// <param name = \"bExecuted\">Will the operation be executed.</param>\r\n  async addFlowFieldOperation(oper: Operation, bExecuted: boolean, taskInfo: string): Promise<void> {\r\n    if (this._enabled && this._isFlowOperation) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);\r\n      let buffer: StringBuilder = new StringBuilder(FlowMonitorQueue.FLW_PERFIX);\r\n      await oper.AddFlowDescription(buffer);\r\n      buffer.Append(' ');\r\n\r\n\r\n      if (!bExecuted)\r\n        buffer.Append(\"[Not Executed]\");\r\n\r\n      let info = buffer.ToString();\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"state\">of the update\r\n  /// </param>\r\n  addFlowOperationUpdate(state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isFlowOperation) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER); // MG_OPER_UPDATE\r\n      let info: string;\r\n      if (state === FlowMonitorInterface.FLWMTR_START)\r\n        info = \"Starts Update\";\r\n      else\r\n        info =  \"Ends Update\";\r\n\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"info\">string passed to status line verify action</param>\r\n  addFlowVerifyInfo(info: string, taskInfo: string): void {\r\n    this.addFlowInfo(info, taskInfo);\r\n  }\r\n\r\n  /// <param name = \"info\">string added to flow monitor queue for InvokeOs</param>\r\n  addFlowInvokeOsInfo(info: string, taskInfo: string): void {\r\n    this.addFlowInfo(info, taskInfo);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   user string passed to status line for actions\r\n  /// </summary>\r\n  /// <param name = \"info\">\r\n  /// </param>\r\n  private addFlowInfo(info: string, taskInfo: string): void {\r\n    if (!this._enabled)\r\n      return;\r\n\r\n    let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);\r\n    let buffer: StringBuilder = new StringBuilder(\"\");\r\n\r\n    if (!(info === \"\")) {\r\n      buffer.Append(\" >> INFORMATION >> \");\r\n      buffer.Append(info);\r\n    }\r\n    let newInfo = buffer.ToString();\r\n    act.setInfo(newInfo);\r\n    this._queue.put(act);\r\n\r\n    Logger.Instance.WriteSupportToLog(taskInfo +\": \" + newInfo, true);\r\n  }\r\n}\r\n\r\n/// <summary>\r\n///   all information about current Activity\r\n/// </summary>\r\nclass ActivityItem {\r\n  private _id: number = 0;\r\n  private _type: string = null; // ACTY_TASK|ACT_TASK_FLW|ACT_DATAVIEW|ACT_RECOMPUTE|ACT_FLW_OPER\r\n  private _info: string = null;\r\n  private _time: string = null;\r\n\r\n  constructor(enclosingInstance: FlowMonitorQueue, type: string, id: number) {\r\n    this._type = type;\r\n    this._id = id;\r\n    this.setTime();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   save current time in the needed format\r\n  /// </summary>\r\n  private setTime(): void {\r\n    this._time = DateTimeUtils.ToString(DateTime.Now, FlowMonitorQueue.LongTimePattern, Logger.Instance);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   set added information for the activity\r\n  /// </summary>\r\n  setInfo(info_: string): void {\r\n    this._info = ((info_ !== null) ? XmlParser.escape(info_) : info_);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   build XML string for the activity item\r\n  /// </summary>\r\n  buildXML(message: StringBuilder): void {\r\n    message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_ACT);\r\n    message.Append(\" \" + XMLConstants.MG_ATTR_TYPE + \"=\\\"\" + this._type + \"\\\"\");\r\n    message.Append(\" \" + XMLConstants.MG_ATTR_ID + \"=\\\"\" + this._id + \"\\\"\");\r\n    if (this._info != null)\r\n      message.Append(\" \" + ConstInterface.MG_ATTR_INFO + \"=\\\"\" + this._info + \"\\\"\");\r\n    message.Append(\" \" + ConstInterface.MG_ATTR_TIME + \"=\\\"\" + this._time + \"\\\"\");\r\n    message.Append(XMLConstants.TAG_TERM);\r\n  }\r\n}\r\n"]}
|