mirror of
https://github.com/avatao-content/frontend-tutorial-framework
synced 2025-01-16 03:11:56 +00:00
Merge pull request #12 from avatao-content/pmgeh
Implement manipulation of supervisor processes from frontend
This commit is contained in:
commit
ddc4430bde
@ -17,6 +17,7 @@ import { MessagesComponent } from './messages/messages.component';
|
||||
import { WebSocketService } from './services/websocket.service';
|
||||
import { TerminalComponent } from './terminal/terminal.component';
|
||||
import { FSMUpdateService } from './services/fsmupdate.service';
|
||||
import { ProcessManagerService } from './services/processmanager.service';
|
||||
import { AppRoutingModule } from './app-routing.module';
|
||||
|
||||
|
||||
@ -42,7 +43,8 @@ import { AppRoutingModule } from './app-routing.module';
|
||||
MarkdownService,
|
||||
WebSocketService,
|
||||
TerminadoService,
|
||||
FSMUpdateService
|
||||
FSMUpdateService,
|
||||
ProcessManagerService
|
||||
],
|
||||
bootstrap: [
|
||||
AppComponent
|
||||
|
4
src/app/services/processcommand.ts
Normal file
4
src/app/services/processcommand.ts
Normal file
@ -0,0 +1,4 @@
|
||||
export class ProcessCommand {
|
||||
command: string;
|
||||
process_name: string;
|
||||
}
|
39
src/app/services/processmanager.service.ts
Normal file
39
src/app/services/processmanager.service.ts
Normal file
@ -0,0 +1,39 @@
|
||||
import { Injectable } from '@angular/core';
|
||||
|
||||
import { WebSocketService } from './websocket.service';
|
||||
import { ProcessCommand } from './processcommand';
|
||||
import { filter } from 'rxjs/operators';
|
||||
|
||||
|
||||
@Injectable()
|
||||
export class ProcessManagerService {
|
||||
key = 'processmanager';
|
||||
process_name: string;
|
||||
|
||||
constructor(private webSocketService: WebSocketService) {}
|
||||
|
||||
init() {
|
||||
this.webSocketService.connect();
|
||||
}
|
||||
|
||||
subscribeCallback(process_name: string, callback: (event: any) => void) {
|
||||
this.webSocketService.observeKey<ProcessCommand>(this.key)
|
||||
.pipe(filter(message => message.data.process_name === process_name)).subscribe(callback);
|
||||
}
|
||||
|
||||
sendCommand(command: string, process_name: string) {
|
||||
this.webSocketService.send(this.key, {'command': command, 'process_name': process_name});
|
||||
}
|
||||
|
||||
startProcess(process_name: string) {
|
||||
this.sendCommand('start', process_name);
|
||||
}
|
||||
|
||||
stopProcess(process_name: string) {
|
||||
this.sendCommand('stop', process_name);
|
||||
}
|
||||
|
||||
restartProcess(process_name: string) {
|
||||
this.sendCommand('restart', process_name);
|
||||
}
|
||||
}
|
@ -3,7 +3,7 @@
|
||||
class="btn btn-secondary"
|
||||
[class.active]="filename === file"
|
||||
[class.disabled]="filename === file"
|
||||
(click)="selectCode(file); requestCode()"
|
||||
(click)="sendCodeContents(); selectCode(file); requestCode()"
|
||||
[disabled]="filename === file">
|
||||
{{file}}
|
||||
</button>
|
||||
@ -23,8 +23,8 @@
|
||||
type="submit"
|
||||
class="btn btn-secondary"
|
||||
[class.btn-success]="saveButtonState === 'SAVED'"
|
||||
[class.btn-warning]="saveButtonState === 'SAVING'"
|
||||
[class.btn-info]="saveButtonState === 'SAVING'"
|
||||
[class.disabled]="saveButtonState === 'SAVING'"
|
||||
><span *ngIf="saveButtonState === 'DIRTY'">Save!</span>
|
||||
<span *ngIf="saveButtonState === 'SAVED'">Saved!</span>
|
||||
<span *ngIf="saveButtonState === 'SAVING'">Saving...</span></button>
|
||||
<span *ngIf="saveButtonState === 'SAVED'">Done!</span>
|
||||
<span *ngIf="saveButtonState === 'SAVING'"><div class="loader"></div>Reloading...</span></button>
|
||||
|
@ -7,3 +7,21 @@
|
||||
.btn-secondary {
|
||||
border-radius: 0;
|
||||
}
|
||||
|
||||
.loader {
|
||||
border: 2px solid #ffffff;
|
||||
border-radius: 50%;
|
||||
border-top: 2px solid #212529;
|
||||
width: 15px;
|
||||
height: 15px;
|
||||
animation: spin 2s linear infinite;
|
||||
display: inline-block;
|
||||
margin-right: 5px;
|
||||
position: relative;
|
||||
top: 2px;
|
||||
}
|
||||
|
||||
@keyframes spin {
|
||||
0% { transform: rotate(0deg); }
|
||||
100% { transform: rotate(360deg); }
|
||||
}
|
||||
|
@ -14,6 +14,7 @@ import 'brace/mode/sql';
|
||||
import 'brace/theme/monokai';
|
||||
import { SourceCode } from './source-code';
|
||||
import { WebSocketService } from '../services/websocket.service';
|
||||
import { ProcessManagerService } from '../services/processmanager.service';
|
||||
|
||||
const modelist = brace.acequire('ace/ext/modelist');
|
||||
|
||||
@ -35,15 +36,18 @@ export class WebideComponent implements OnInit {
|
||||
command_handlers = { 'reload': this.reloadHandler.bind(this),
|
||||
'read': this.readHandler.bind(this),
|
||||
'select': this.selectHandler.bind(this),
|
||||
'write': this.writeHandler.bind(this)};
|
||||
'write': () => {}};
|
||||
|
||||
constructor(private webSocketService: WebSocketService,
|
||||
private changeDetectorRef: ChangeDetectorRef) { }
|
||||
private changeDetectorRef: ChangeDetectorRef,
|
||||
private processManagerService: ProcessManagerService) { }
|
||||
|
||||
ngOnInit() {
|
||||
this.webSocketService.connect();
|
||||
this.subscribeWS();
|
||||
this.requestCode();
|
||||
this.processManagerService.init();
|
||||
this.processManagerService.subscribeCallback('login', (event) => { this.setButtonStateSaved(); });
|
||||
}
|
||||
|
||||
subscribeWS() {
|
||||
@ -72,7 +76,7 @@ export class WebideComponent implements OnInit {
|
||||
this.updateFileData(data);
|
||||
}
|
||||
|
||||
writeHandler(data: SourceCode) {
|
||||
setButtonStateSaved() {
|
||||
this.saveButtonState = 'SAVED';
|
||||
}
|
||||
|
||||
@ -81,11 +85,16 @@ export class WebideComponent implements OnInit {
|
||||
}
|
||||
|
||||
sendCode() {
|
||||
this.sendCodeContents();
|
||||
this.saveButtonState = 'SAVING';
|
||||
this.processManagerService.restartProcess('login');
|
||||
}
|
||||
|
||||
sendCodeContents() {
|
||||
this.webSocketService.send(this.key_id, {
|
||||
'command': 'write',
|
||||
'content': this.code
|
||||
});
|
||||
this.saveButtonState = 'SAVING';
|
||||
}
|
||||
|
||||
requestCode() {
|
||||
|
Loading…
Reference in New Issue
Block a user