2
0
mirror of https://github.com/fhem/fhem-mirror.git synced 2025-04-08 07:24:21 +00:00

HM_Template:improve Editor

git-svn-id: https://svn.fhem.de/fhem/trunk@14462 2b470e98-0d58-463d-a4d8-8e2adae1ed80
This commit is contained in:
martinp876 2017-06-04 09:55:12 +00:00
parent 371a7ca263
commit b3c2fc8277

View File

@ -17,36 +17,36 @@ sub HMtemplate_noDup(@);
use Blocking;
use HMConfig;
my %HtState =(
s0=>{name=>"init" ,cmd=>["defTmpl","edit","delete","select"] ,info=>[ "delete to remove a template definition"
,"defTmpl to greate a template"
,"- use an entity as default"
,"edit to modify a template definition"
,"select to apply a template to a entity"
]}
,s1=>{name=>"edit" ,cmd=>["dismiss","save","saveAs"] ,info=>[ "change attr Reg_ as desired"
,"change attr tpl_params as desired"
,"save if finished"
,"saveAs to create a copy"
,"dismiss will reset HMtemplate"
]}
,s2=>{name=>"defTmpl",cmd=>["dismiss","save","saveAs"] ,info=>[ "1)set attr tpl_type"
,"2)set attr tpl_source"
,"3)set attr tpl_peer if peer required"
,"4)set attr tpl_params if params are desired"
,"5)set attr tpl_description for the template"
]}
,s3=>{name=>"defTmpl",cmd=>["defTmpl","edit","delete"] ,info=>[ "delete"
]}
,s4=>{name=>"select" ,cmd=>["dismiss","apply"] ,info=>[ "apply the selected template to an entity"
,"1) choose target entity"
,"2) select a peer if required"
,"3) select type if required"
,"4) fill all attr tpl_param_"
,"5) set apply to execute and write the register"
]}
,s5=>{name=>"defTmpl",cmd=>["defTmpl","edit","delete"] ,info=>[ "s5 info1"
,"s5 info2"
]}
s0=>{name=>"init" ,cmd=>["select" ,"defTmpl","delete","edit"] ,info=>[ "delete to remove a template definition"
,"defTmpl to greate a template"
,"- use an entity as default"
,"edit to modify a template definition"
,"select to apply a template to a entity"
]}
,s1=>{name=>"edit" ,cmd=>["dismiss","save" ,"saveAs","importReg"] ,info=>[ "change attr Reg_ as desired"
,"change attr tpl_params ':' separated"
,"save if finished"
,"saveAs to create a copy"
,"dismiss will reset HMtemplate"
]}
,s2=>{name=>"defTmpl",cmd=>["dismiss","save","saveAs"] ,info=>[ "1)set attr tpl_type"
,"2)set attr tpl_source"
,"3)set attr tpl_peer if peer required"
,"4)set attr tpl_params ':' separated"
,"5)set attr tpl_description for the template"
]}
,s3=>{name=>"defTmpl",cmd=>["defTmpl","edit" ,"delete"] ,info=>[ "delete"
]}
,s4=>{name=>"select" ,cmd=>["dismiss","apply" ,"select"] ,info=>[ "apply the selected template to an entity"
,"1) choose target entity"
,"2) select a peer if required"
,"3) select type if required"
,"4) fill all attr tpl_param_"
,"5) set apply to execute and write the register"
]}
,s5=>{name=>"defTmpl",cmd=>["defTmpl","edit" ,"delete"] ,info=>[ "s5 info1"
,"s5 info2"
]}
);
sub HMtemplate_Initialize($$) {################################################
@ -229,12 +229,23 @@ sub HMtemplate_GetFn($@) {#####################################################
." ".join(" ",map{$_.=":".$culHmTpl->{$tN}{reg}{$_}} keys %{$culHmTpl->{$tN}{reg}})
;
}
elsif($cmd eq "regInfo"){##print protocol-events-------------------------
my @regArr = map { $_ =~ s/Reg_//g; $_ }
grep /^Reg_/,keys %{$attr{$name}};
if (InternalVal($name,"tpl_type","" =~ m/peer-(short|long)/)){
$_ = "lg".$_ foreach (@regArr);
}
return CUL_HM_getRegInfo(\@regArr,1,1); #
}
else{
my @cmdLst = ( "defineCmd"
,"regInfo"
);
my $tList = ":".join(",",sort keys%{$culHmTpl});
$_ .=$tList foreach(grep/^(defineCmd)$/,@cmdLst);
$_ .=":noArg" foreach(grep/^(regInfo)$/,@cmdLst);# no arguments
$ret = "Unknown argument $cmd, choose one of ".join (" ",sort @cmdLst);
}
@ -267,7 +278,7 @@ sub HMtemplate_SetFn($@) {#####################################################
}
elsif ($cmd eq "defTmpl" ) {#
my ($tName) = @a;
return "spezify template name" if (!defined $tName);
return "specify template name" if (!defined $tName);
return "$tName is already defined" if (defined $culHmTpl->{$tName});
readingsSingleUpdate($hash,"state","define",0);
${$eSt}="s2";
@ -353,6 +364,38 @@ sub HMtemplate_SetFn($@) {#####################################################
,@p
);
}
elsif ($cmd eq "importReg" ){#
my ($eName) = @a;
return "please enter a device to be used "if(!$eName);
my @fnd = grep /^$eName /,
map {$hash->{READINGS}{$_}{VAL}}
grep /^usage_/,keys %{$hash->{READINGS}};
return "template not assigned to $eName" if (scalar(@fnd) != 1);
HMtemplate_import($name,$eName,InternalVal($name,"tpl_type",""),InternalVal($name,"tpl_peer",""));
# my @fnd = map { $_ =~ s/ .*//g; $_ }
# map {$hash->{READINGS}{$_}{VAL}}
# grep /^usage_/,keys %{$hash->{READINGS}};
# my @reg;
# my $first = 1;
# foreach my $d(@fnd){
# my $dHash = CUL_HM_getDeviceHash($defs{$d});
# my $st = AttrVal($dHash->{NAME},"subType","");
# my $md = AttrVal($dHash->{NAME},"model","");
# my @dr = (CUL_HM_getRegN($st,$md,"01"));
#
# if ($first){
# @reg = @dr;
# $first = 0;
# }
# else{
# @reg = HMtemplate_intersection(\@reg,\@dr);
# }
# }
# return join("\n",sort @reg);
}
elsif ($cmd eq "edit" ) {#
my ($templ) = @a;
return "$templ is not defined" if (! defined $culHmTpl->{$templ});
@ -414,10 +457,19 @@ sub HMtemplate_SetFn($@) {#####################################################
return HMtemplate_save($name,$tName);
}
else{
#"select","edit","delete", "defTmpl","dismiss","save","saveAs","importReg","apply"]
my @cmdLst = @{$HtState{${$eSt}}{cmd}};
my $tList = ":".join(",",sort keys%{$culHmTpl});
$_ .=$tList foreach(grep/^(edit|delete|select)$/,@cmdLst);
if (grep/^importReg$/,@cmdLst){
my @fnd = map { $_ =~ s/ .*//g; $_ }
map {$hash->{READINGS}{$_}{VAL}}
grep /^usage_/,keys %{$hash->{READINGS}};
my $eList = ":".join(",",sort @fnd);
$_ .=$eList foreach(grep/^(importReg)$/,@cmdLst);
}
$_ .=":noArg" foreach(grep/^(save|dismiss|apply)$/,@cmdLst);# no arguments
$ret = "Unknown argument $cmd, choose one of ".join (" ",sort @cmdLst);
}
my $i = 0;
@ -425,13 +477,19 @@ sub HMtemplate_SetFn($@) {#####################################################
$hash->{"tpl_Info".$i++}= $_ foreach (@{$HtState{${$eSt}}{info}});
return $ret;
}
sub HMtemplate_intersection($$) {#
my ($x, $y) = @_;
my %seen;
@seen{ @$x } = (1) x @$x;
return grep { $seen{ $_} } @$y;
}
sub HMtemplate_import(@){####################################################
my ($name,$eName,$tType,$tPeer) = @_;
my @regReads;
my ($ty,$match) = ("","");
if ($tType eq "basic"){
@regReads = grep !/\-.*\-/ ,grep /\.?R-/,keys %{$defs{$eName}{READINGS}};
if ($tType eq "basic"){
@regReads = grep !/\-.*\-/ ,grep /\.?R-/ ,keys %{$defs{$eName}{READINGS}};
}
elsif ($tType =~ m/peer-(Long|Short)/){
$ty = $1 eq "Long" ? "lg" : "sh";
@ -440,16 +498,18 @@ sub HMtemplate_import(@){####################################################
}
elsif ($tType eq "peer-both"){
$match = ".*-";
@regReads = grep /\-.*\-/ ,grep /\.?R-$tPeer/,keys %{$defs{$eName}{READINGS}};
@regReads = grep /\-.*\-/ ,grep /\.?R-$tPeer/,keys %{$defs{$eName}{READINGS}};
}
foreach my $rR (@regReads){
my $rN = $rR;
$rN =~ s/\.?R-$match$ty//;
$attr{$name}{"Reg_".$rN} = $defs{$eName}{READINGS}{$rR}{VAL};
$attr{$name}{"Reg_".$rN} =~ s/ .*//;# remove units which are in the readings
my $lits = ":".join(",",(sort (keys %{$culHmRegDef->{$ty.$rN}{lit}}))) if ($culHmRegDef->{$ty.$rN}{c} eq "lit");
$modules{HMtemplate}{AttrList} .= " Reg_".$rN.$lits;
if (!$attr{$name}{"Reg_".$rN}){ #dont overwrite existing
$attr{$name}{"Reg_".$rN} = $defs{$eName}{READINGS}{$rR}{VAL};
$attr{$name}{"Reg_".$rN} =~ s/ .*//;# remove units which are in the readings
my $lits = ":".join(",",(sort (keys %{$culHmRegDef->{$ty.$rN}{lit}}))) if ($culHmRegDef->{$ty.$rN}{c} eq "lit");
$modules{HMtemplate}{AttrList} .= " Reg_".$rN.$lits;
}
}
}