From 8da0d5b6387158eab3909cb19228f064cdcf4e24 Mon Sep 17 00:00:00 2001 From: chinonso098 Date: Mon, 7 Oct 2024 16:30:50 -0400 Subject: [PATCH] there should be only 1 instace of startmenu --- .../startmenu/startmenu.component.ts | 4 +- .../taskmanager/taskmanager.component.ts | 2 +- .../system-apps/terminal/terminal.commands.ts | 4 +- .../terminal/terminal.component.ts | 42 +++++++++---------- 4 files changed, 27 insertions(+), 25 deletions(-) diff --git a/src/app/system-apps/startmenu/startmenu.component.ts b/src/app/system-apps/startmenu/startmenu.component.ts index a9cdbac..59a133e 100644 --- a/src/app/system-apps/startmenu/startmenu.component.ts +++ b/src/app/system-apps/startmenu/startmenu.component.ts @@ -55,7 +55,9 @@ export class StartMenuComponent implements OnInit, AfterViewInit { this._triggerProcessService = triggerProcessService; this.processId = this._processIdService.getNewProcessId() - this._runningProcessService.addProcess(this.getComponentDetail()); + if(this._runningProcessService.getProcesses().findIndex(x => x.getProcessName === this.name) === -1){ + this._runningProcessService.addProcess(this.getComponentDetail()); + } } ngOnInit(): void { diff --git a/src/app/system-apps/taskmanager/taskmanager.component.ts b/src/app/system-apps/taskmanager/taskmanager.component.ts index 372f905..2b893de 100644 --- a/src/app/system-apps/taskmanager/taskmanager.component.ts +++ b/src/app/system-apps/taskmanager/taskmanager.component.ts @@ -77,7 +77,7 @@ export class TaskmanagerComponent implements BaseComponent,OnInit,OnDestroy,Afte SECONDS_DELAY = 250 processes:Process[] =[]; - closingNotAllowed:string[] = ["system", "desktop", "filemanager", "taskbar", "startbutton", "clock", "taskbarentry"]; + closingNotAllowed:string[] = ["system", "desktop", "filemanager", "taskbar", "startbutton", "clock", "taskbarentry", "startmenu"]; groupedData: any = {}; selectedRefreshRate = 0; diff --git a/src/app/system-apps/terminal/terminal.commands.ts b/src/app/system-apps/terminal/terminal.commands.ts index 7fe7b68..cf1f39a 100644 --- a/src/app/system-apps/terminal/terminal.commands.ts +++ b/src/app/system-apps/terminal/terminal.commands.ts @@ -16,7 +16,7 @@ export interface OctalRepresentation { permission: string; } -export class TerminalCommands{ +export class TerminalCommandProcessor{ private _triggerProcessService:TriggerProcessService; private _runningProcessService:RunningProcessService; @@ -26,7 +26,7 @@ export class TerminalCommands{ private _consts:Constants = new Constants(); private permissionChart!:Map; - private closingNotAllowed:string[] = ["system", "desktop", "filemanager", "taskbar", "startbutton","clock","taskbarentry"]; + private closingNotAllowed:string[] = ["system", "desktop", "filemanager", "taskbar", "startbutton","clock","taskbarentry","startmenu"]; private files:FileInfo[] = []; private readonly defaultDirectoryPath = this._consts.ROOT; private currentDirectoryPath = this._consts.ROOT; diff --git a/src/app/system-apps/terminal/terminal.component.ts b/src/app/system-apps/terminal/terminal.component.ts index 75b0d91..c79fe9f 100644 --- a/src/app/system-apps/terminal/terminal.component.ts +++ b/src/app/system-apps/terminal/terminal.component.ts @@ -7,7 +7,7 @@ import { BaseComponent } from 'src/app/system-base/base/base.component'; import { ComponentType } from 'src/app/system-files/component.types'; import { Process } from 'src/app/system-files/process'; import { TerminalCommand } from './model/terminal.command'; -import { TerminalCommands } from './terminal.commands'; +import { TerminalCommandProcessor } from './terminal.commands'; import { AppState, BaseState } from 'src/app/system-files/state/state.interface'; import { StateType } from 'src/app/system-files/state/state.type'; import { StateManagmentService } from 'src/app/shared/system-service/state.management.service'; @@ -32,7 +32,7 @@ export class TerminalComponent implements BaseComponent, OnInit, AfterViewInit, private _maximizeWindowSub!: Subscription; private _minimizeWindowSub!: Subscription; private _formBuilder; - private _terminaCommandsImpl!:TerminalCommands; + private _terminaCommandsProc!:TerminalCommandProcessor; private _stateManagmentService:StateManagmentService; private _sessionManagmentService: SessionManagmentService; private _appState!:AppState; @@ -85,7 +85,7 @@ export class TerminalComponent implements BaseComponent, OnInit, AfterViewInit, this._formBuilder = formBuilder; this._stateManagmentService = stateManagmentService; this._sessionManagmentService = sessionManagmentService; - this._terminaCommandsImpl = new TerminalCommands(); + this._terminaCommandsProc = new TerminalCommandProcessor(); this.retrievePastSessionData(); @@ -554,71 +554,71 @@ export class TerminalComponent implements BaseComponent, OnInit, AfterViewInit, } if(rootCmd == "curl"){ - const result = await this._terminaCommandsImpl.curl(cmdStringArr); + const result = await this._terminaCommandsProc.curl(cmdStringArr); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "close"){ - const result = this._terminaCommandsImpl.close(cmdStringArr[1], cmdStringArr[2]); + const result = this._terminaCommandsProc.close(cmdStringArr[1], cmdStringArr[2]); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "date"){ - const result = this._terminaCommandsImpl.date(); + const result = this._terminaCommandsProc.date(); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "download"){ - this._terminaCommandsImpl.download(cmdStringArr[1], cmdStringArr[2]); + this._terminaCommandsProc.download(cmdStringArr[1], cmdStringArr[2]); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = 'downloading ..'; } if(rootCmd == "exit"){ - this._terminaCommandsImpl.exit(this.processId); + this._terminaCommandsProc.exit(this.processId); } if(rootCmd == "help"){ - const result = this._terminaCommandsImpl.help(this.echoCommands, this.utilityCommands, cmdStringArr[1]); + const result = this._terminaCommandsProc.help(this.echoCommands, this.utilityCommands, cmdStringArr[1]); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "open"){ - const result = this._terminaCommandsImpl.open(cmdStringArr[1], cmdStringArr[2]); + const result = this._terminaCommandsProc.open(cmdStringArr[1], cmdStringArr[2]); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "version"){ - const result = this._terminaCommandsImpl.version(this.versionNum); + const result = this._terminaCommandsProc.version(this.versionNum); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "whoami"){ - const result = this._terminaCommandsImpl.whoami(); + const result = this._terminaCommandsProc.whoami(); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "weather"){ - const result = await this._terminaCommandsImpl.weather(cmdStringArr[1]); + const result = await this._terminaCommandsProc.weather(cmdStringArr[1]); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "list"){ - const result = this._terminaCommandsImpl.list(cmdStringArr[1], cmdStringArr[2]); + const result = this._terminaCommandsProc.list(cmdStringArr[1], cmdStringArr[2]); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "pwd"){ - const result = this._terminaCommandsImpl.pwd(); + const result = this._terminaCommandsProc.pwd(); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } @@ -626,7 +626,7 @@ export class TerminalComponent implements BaseComponent, OnInit, AfterViewInit, if(rootCmd == "cd"){ const str = 'string'; const strArr = 'string[]'; - const result = await this._terminaCommandsImpl.cd(cmdStringArr[1], key); + const result = await this._terminaCommandsProc.cd(cmdStringArr[1], key); if(result.type === str || result.type === strArr) terminalCmd.setResponseCode = this.Success; @@ -647,7 +647,7 @@ export class TerminalComponent implements BaseComponent, OnInit, AfterViewInit, if(rootCmd == "ls"){ const str = 'string'; const strArr = 'string[]'; - const result = await this._terminaCommandsImpl.ls(cmdStringArr[1]); + const result = await this._terminaCommandsProc.ls(cmdStringArr[1]); terminalCmd.setResponseCode = this.Success; @@ -664,13 +664,13 @@ export class TerminalComponent implements BaseComponent, OnInit, AfterViewInit, } if(rootCmd == "mkdir"){ - const result = await this._terminaCommandsImpl.mkdir(cmdStringArr[1], cmdStringArr[2]); + const result = await this._terminaCommandsProc.mkdir(cmdStringArr[1], cmdStringArr[2]); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } if(rootCmd == "rm"){ - const result = await this._terminaCommandsImpl.rm(cmdStringArr[1], cmdStringArr[2]); + const result = await this._terminaCommandsProc.rm(cmdStringArr[1], cmdStringArr[2]); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } @@ -678,7 +678,7 @@ export class TerminalComponent implements BaseComponent, OnInit, AfterViewInit, if(rootCmd == "mv"){ - const result = await this._terminaCommandsImpl.mv(cmdStringArr[1], cmdStringArr[2]); + const result = await this._terminaCommandsProc.mv(cmdStringArr[1], cmdStringArr[2]); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result; } @@ -691,7 +691,7 @@ export class TerminalComponent implements BaseComponent, OnInit, AfterViewInit, const source = cmdStringArr[2]; const destination = cmdStringArr[3]; - const result = await this._terminaCommandsImpl.cp(option, source, destination); + const result = await this._terminaCommandsProc.cp(option, source, destination); terminalCmd.setResponseCode = this.Success; terminalCmd.setCommandOutput = result;