Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-RAN
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
spbro
OpenXG-RAN
Commits
fa03569f
Commit
fa03569f
authored
Apr 05, 2022
by
El Mghazli Yacine
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
APIv2.2
parent
108d9a96
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
60 additions
and
56 deletions
+60
-56
common/utils/websrv/frontend/src/app/api/commands.api.ts
common/utils/websrv/frontend/src/app/api/commands.api.ts
+4
-6
common/utils/websrv/frontend/src/app/components/commands/commands.component.html
...ntend/src/app/components/commands/commands.component.html
+39
-34
common/utils/websrv/frontend/src/app/components/commands/commands.component.ts
...rontend/src/app/components/commands/commands.component.ts
+14
-13
common/utils/websrv/frontend/src/app/controls/var.control.ts
common/utils/websrv/frontend/src/app/controls/var.control.ts
+3
-3
No files found.
common/utils/websrv/frontend/src/app/api/commands.api.ts
View file @
fa03569f
...
@@ -29,14 +29,12 @@ const route = '/oaisoftmodem';
...
@@ -29,14 +29,12 @@ const route = '/oaisoftmodem';
export
class
CommandsApi
{
export
class
CommandsApi
{
constructor
(
private
httpClient
:
HttpClient
)
{
}
constructor
(
private
httpClient
:
HttpClient
)
{
}
public
readVariables$
=
(
)
=>
this
.
httpClient
.
get
<
IVariable
[]
>
(
environment
.
backend
+
route
+
'
/variables/
'
);
public
readVariables$
=
(
moduleName
?:
string
)
=>
this
.
httpClient
.
get
<
IVariable
[]
>
(
environment
.
backend
+
route
+
'
/
'
+
(
moduleName
?
(
'
/
'
+
moduleName
)
:
""
)
+
'
/variables/
'
);
public
readCommands$
=
(
)
=>
this
.
httpClient
.
get
<
ICommand
[]
>
(
environment
.
backend
+
route
+
'
/commands/
'
);
public
readCommands$
=
(
moduleName
?:
string
)
=>
this
.
httpClient
.
get
<
ICommand
[]
>
(
environment
.
backend
+
route
+
'
/
'
+
(
moduleName
?
(
'
/
'
+
moduleName
)
:
""
)
+
'
/commands/
'
);
public
r
eadModuleVariables$
=
(
moduleName
:
string
)
=>
this
.
httpClient
.
get
<
IVariable
[]
>
(
environment
.
backend
+
route
+
'
/
'
+
moduleName
+
'
/variables/
'
);
public
r
unCommand$
=
(
moduleName
:
string
,
command
:
ICommand
)
=>
this
.
httpClient
.
post
<
string
>
(
environment
.
backend
+
route
+
'
/
'
+
moduleName
+
'
/commands/
'
,
command
);
public
readModuleCommands$
=
(
moduleName
:
string
)
=>
this
.
httpClient
.
get
<
ICommand
[]
>
(
environment
.
backend
+
route
+
'
/
'
+
moduleName
+
'
/commands/
'
);
public
setVariable$
=
(
variable
:
IVariable
,
moduleName
?:
string
)
=>
this
.
httpClient
.
post
<
string
>
(
environment
.
backend
+
route
+
(
moduleName
?
(
'
/
'
+
moduleName
)
:
""
)
+
'
/variables/
'
,
variable
);
public
runCommand$
=
(
moduleName
:
string
,
variable
:
IVariable
)
=>
this
.
httpClient
.
post
<
string
>
(
environment
.
backend
+
route
+
'
/
'
+
moduleName
+
'
/commands/
'
,
variable
);
}
}
common/utils/websrv/frontend/src/app/components/commands/commands.component.html
View file @
fa03569f
<div
*ngIf=
"vars$ | async as vars"
>
<div
*ngIf=
"vars$ | async as vars"
>
<h1
mat-dialog-title
>
V
ariables
</h1>
<h1
mat-dialog-title
>
Softmodem v
ariables
</h1>
<div
*ngFor=
"let variable of vars"
>
<div
*ngFor=
"let variable of vars"
>
<mat-form-field>
<mat-form-field>
<mat-label>
{{ variable.nameFC.value }}
</mat-label>
<mat-label>
{{ variable.nameFC.value }}
</mat-label>
...
@@ -12,54 +12,59 @@
...
@@ -12,54 +12,59 @@
</div>
</div>
<div
*ngIf=
"cmds$ | async as cmds"
fxLaypout=
"row"
>
<div
*ngIf=
"cmds$ | async as cmds"
fxLaypout=
"row"
>
<h1
mat-dialog-title
>
Menus
</h1>
<mat-form-field>
<mat-form-field>
<mat-label>
Command
</mat-label>
<mat-label>
Module
</mat-label>
<mat-select
[formControl]=
"selectedCmd!.nameFC"
[value]=
"selectedCmd!.nameFC.value"
<mat-select
[formControl]=
"selectedCmd!.nameFC"
[value]=
"selectedCmd!.nameFC.value"
(selectionChange)=
"onCmdSelect()"
>
(selectionChange)=
"
onCmdSelect()"
>
<mat-option
*ngFor=
"let cmd of cmds"
[value]=
"cmd"
>
{{ cmd.nameFC.value }}
<mat-option
*ngFor=
"let cmd of cmds"
[value]=
"cmd
.nameFC.value
"
>
{{ cmd.nameFC.value }}
</mat-option>
</mat-option>
</mat-select>
</mat-select>
</mat-form-field>
</mat-form-field>
<div
*ngIf=
"subvars$ | async as subvars"
fxLaypout=
"column"
>
<div
*ngIf=
"subvars$ | async as subvars"
fxLaypout=
"column"
>
<h1
mat-dialog-title
>
Sub-Variables
</h1>
<div
*ngIf=
"subvars.length"
>
<div
*ngFor=
"let variable of subvars"
>
<h1
mat-dialog-title
>
{{ selectedCmd!.nameFC.value }} variables
</h1>
<mat-form-field>
<div
*ngFor=
"let variable of subvars"
>
<mat-label>
{{ variable.nameFC.value }}
</mat-label>
<input
input
matInput
[formControl]=
"variable.valueFC"
/>
</mat-form-field>
<button
mat-raised-button
color=
"primary"
[disabled]=
"!variable.modifiableFC.value"
(click)=
"onVarSubmit(variable)"
>
submit
</button>
</div>
</div>
<div
*ngIf=
"subcmds$ | async as subcmds"
fxLaypout=
"column"
fxLayoutGap=
"10px"
>
<h1
mat-dialog-title
>
Sub-commands
</h1>
<mat-form-field>
<mat-label>
Command
</mat-label>
<mat-select
[formControl]=
"selectedSubCmd!.nameFC"
[value]=
"selectedSubCmd!.nameFC.value"
(selectionChange)=
"onSubCmdSelect()"
>
<mat-option
*ngFor=
"let cmd of subcmds"
[value]=
"cmd"
>
{{ cmd.nameFC.value }}
</mat-option>
</mat-select>
</mat-form-field>
<div
*ngIf=
"args$ | async as args"
fxLaypout=
"column"
>
<h1
mat-dialog-title
>
Sub-Variables
</h1>
<div
*ngFor=
"let variable of args"
>
<mat-form-field>
<mat-form-field>
<mat-label>
{{ variable.nameFC.value }}
</mat-label>
<mat-label>
{{ variable.nameFC.value }}
</mat-label>
<input
input
matInput
[formControl]=
"variable.valueFC"
/>
<input
input
matInput
[formControl]=
"variable.valueFC"
/>
</mat-form-field>
</mat-form-field>
<button
mat-raised-button
color=
"primary"
[disabled]=
"!variable.modifiableFC.value"
<button
mat-raised-button
color=
"primary"
[disabled]=
"!variable.modifiableFC.value"
(click)=
"on
Sub
VarSubmit(variable)"
>
(click)=
"onVarSubmit(variable)"
>
s
ubmi
t
s
e
t
</button>
</button>
</div>
</div>
</div>
</div>
</div>
<div
*ngIf=
"subcmds$ | async as subcmds"
fxLaypout=
"column"
fxLayoutGap=
"10px"
>
<div
*ngIf=
"subcmds.length"
>
<h1
mat-dialog-title
>
{{ selectedCmd!.nameFC.value }} commands
</h1>
<mat-form-field>
<mat-label>
Command
</mat-label>
<mat-select
[formControl]=
"selectedSubCmd!.nameFC"
[value]=
"selectedSubCmd!.nameFC.value"
(selectionChange)=
"onSubCmdSelect()"
>
<mat-option
*ngFor=
"let cmd of subcmds"
[value]=
"cmd.nameFC.value"
>
{{ cmd.nameFC.value }}
</mat-option>
</mat-select>
</mat-form-field>
</div>
<div
*ngIf=
"args$ | async as args"
fxLaypout=
"column"
>
<div
*ngIf=
"args.length"
>
<h1
mat-dialog-title
>
Sub-Variables
</h1>
<div
*ngFor=
"let variable of args"
>
<mat-form-field>
<mat-label>
{{ variable.nameFC.value }}
</mat-label>
<input
input
matInput
[formControl]=
"variable.valueFC"
/>
</mat-form-field>
<button
mat-raised-button
color=
"primary"
[disabled]=
"!variable.modifiableFC.value"
(click)=
"onSubVarSubmit(variable)"
>
submit
</button>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
\ No newline at end of file
common/utils/websrv/frontend/src/app/components/commands/commands.component.ts
View file @
fa03569f
import
{
Component
}
from
'
@angular/core
'
;
import
{
Component
}
from
'
@angular/core
'
;
import
{
FormControl
}
from
'
@angular/forms
'
;
import
{
Observable
}
from
'
rxjs/internal/Observable
'
;
import
{
Observable
}
from
'
rxjs/internal/Observable
'
;
import
{
map
}
from
'
rxjs/internal/operators/map
'
;
import
{
map
}
from
'
rxjs/internal/operators/map
'
;
import
{
tap
}
from
'
rxjs/internal/operators/tap
'
;
import
{
CommandsApi
,
IArgType
}
from
'
src/app/api/commands.api
'
;
import
{
CommandsApi
,
IArgType
}
from
'
src/app/api/commands.api
'
;
import
{
CmdCtrl
}
from
'
src/app/controls/cmd.control
'
;
import
{
CmdCtrl
}
from
'
src/app/controls/cmd.control
'
;
import
{
Var
iableCtrl
as
Var
Ctrl
}
from
'
src/app/controls/var.control
'
;
import
{
VarCtrl
}
from
'
src/app/controls/var.control
'
;
import
{
LoadingService
}
from
'
src/app/services/loading.service
'
;
import
{
LoadingService
}
from
'
src/app/services/loading.service
'
;
...
@@ -35,38 +35,39 @@ export class CommandsComponent {
...
@@ -35,38 +35,39 @@ export class CommandsComponent {
public
loadingService
:
LoadingService
,
public
loadingService
:
LoadingService
,
)
{
)
{
this
.
vars$
=
this
.
commandsApi
.
readVariables$
().
pipe
(
this
.
vars$
=
this
.
commandsApi
.
readVariables$
().
pipe
(
map
((
ivars
)
=>
i
vars
.
map
(
ivar
=>
new
VarCtrl
(
ivar
)))
map
((
vars
)
=>
vars
.
map
(
ivar
=>
new
VarCtrl
(
ivar
)))
);
);
this
.
cmds$
=
this
.
commandsApi
.
readCommands$
().
pipe
(
this
.
cmds$
=
this
.
commandsApi
.
readCommands$
().
pipe
(
map
((
ivars
)
=>
ivars
.
map
(
ivar
=>
new
CmdCtrl
(
ivar
)))
map
((
cmds
)
=>
cmds
.
map
(
ivar
=>
new
CmdCtrl
(
ivar
))),
tap
(
controls
=>
[
this
.
selectedCmd
]
=
controls
)
);
);
}
}
onCmdSelect
()
{
onCmdSelect
()
{
this
.
subcmds$
=
this
.
commandsApi
.
readModuleCommands$
(
`
${
this
.
selectedCmd
?.
nameFC
.
value
}
`
).
pipe
(
this
.
subcmds$
=
this
.
commandsApi
.
readCommands$
(
`
${
this
.
selectedCmd
!
.
nameFC
.
value
}
`
).
pipe
(
map
(
cmds
=>
cmds
.
map
(
cmd
=>
new
CmdCtrl
(
cmd
))),
map
(
cmds
=>
cmds
.
map
(
cmd
=>
new
CmdCtrl
(
cmd
))),
// tap(cmds => [this.selectedSubCmd] = cmd
s)
tap
(
controls
=>
[
this
.
selectedSubCmd
]
=
control
s
)
)
)
this
.
subvars$
=
this
.
commandsApi
.
readModuleVariables$
(
`
${
this
.
selectedCmd
?.
nameFC
.
value
}
`
).
pipe
(
this
.
subvars$
=
this
.
commandsApi
.
readVariables$
(
`
${
this
.
selectedCmd
!
.
nameFC
.
value
}
`
).
pipe
(
map
(
vars
=>
vars
.
map
(
v
=>
new
VarCtrl
(
v
))),
map
(
vars
=>
vars
.
map
(
v
=>
new
VarCtrl
(
v
))),
tap
(
controls
=>
[
this
.
selectedSubVar
]
=
controls
)
// tap(vars => [this.selectedSubVar] = vars)
)
)
}
}
onSubCmdSelect
()
{
onSubCmdSelect
()
{
this
.
args$
=
this
.
commandsApi
.
read
ModuleVariables$
(
`
${
this
.
selectedCmd
?.
nameFC
.
value
}
/
${
this
.
selectedSubCmd
?
.
nameFC
.
value
}
`
).
pipe
(
this
.
args$
=
this
.
commandsApi
.
read
Variables$
(
`
${
this
.
selectedCmd
!
.
nameFC
.
value
}
/
${
this
.
selectedSubCmd
!
.
nameFC
.
value
}
`
).
pipe
(
map
(
vars
=>
vars
.
map
(
v
=>
new
VarCtrl
(
v
))),
map
(
vars
=>
vars
.
map
(
v
=>
new
VarCtrl
(
v
))),
// tap(vars => [this.selectedSubVar
] = vars)
tap
(
vars
=>
[
this
.
selectedArg
]
=
vars
)
)
)
}
}
onVarSubmit
(
control
:
VarCtrl
)
{
onVarSubmit
(
control
:
VarCtrl
)
{
this
.
commandsApi
.
runCommand$
(
`
${
this
.
selectedCmd
?.
nameFC
.
value
}
/
${
control
.
nameFC
.
value
}
`
,
control
.
valueFC
.
value
).
subscribe
();
this
.
commandsApi
.
setVariable$
(
control
.
api
()
).
subscribe
();
}
}
onSubVarSubmit
(
control
:
VarCtrl
)
{
onSubVarSubmit
(
control
:
VarCtrl
)
{
this
.
commandsApi
.
runCommand$
(
`
${
this
.
selectedCmd
?.
nameFC
.
value
}
/
${
this
.
selectedSubCmd
?.
nameFC
.
value
}
/
${
control
.
nameFC
.
value
}
`
,
control
.
valueFC
.
value
).
subscribe
();
this
.
commandsApi
.
setVariable$
(
control
.
api
(),
`
${
this
.
selectedCmd
?.
nameFC
.
value
}
/
${
this
.
selectedSubCmd
?.
nameFC
.
value
}
/
${
control
.
nameFC
.
value
}
`
).
subscribe
();
}
}
}
}
common/utils/websrv/frontend/src/app/controls/var.control.ts
View file @
fa03569f
...
@@ -10,7 +10,7 @@ const enum VariablesFCN {
...
@@ -10,7 +10,7 @@ const enum VariablesFCN {
}
}
export
class
Var
iable
Ctrl
extends
FormGroup
{
export
class
VarCtrl
extends
FormGroup
{
constructor
(
ivar
:
IVariable
)
{
constructor
(
ivar
:
IVariable
)
{
super
({});
super
({});
...
@@ -49,11 +49,11 @@ export class VariableCtrl extends FormGroup {
...
@@ -49,11 +49,11 @@ export class VariableCtrl extends FormGroup {
}
}
get
typeFC
()
{
get
typeFC
()
{
return
this
.
get
(
VariablesFCN
.
valu
e
)
as
FormControl
;
return
this
.
get
(
VariablesFCN
.
typ
e
)
as
FormControl
;
}
}
set
typeFC
(
control
:
FormControl
)
{
set
typeFC
(
control
:
FormControl
)
{
this
.
setControl
(
VariablesFCN
.
valu
e
,
control
);
this
.
setControl
(
VariablesFCN
.
typ
e
,
control
);
}
}
get
modifiableFC
()
{
get
modifiableFC
()
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment