--- loncom/interface/lonparmset.pm 2005/08/27 00:03:32 1.242
+++ loncom/interface/lonparmset.pm 2005/08/30 01:25:53 1.246
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Handler to set parameters for assessments
#
-# $Id: lonparmset.pm,v 1.242 2005/08/27 00:03:32 banghart Exp $
+# $Id: lonparmset.pm,v 1.246 2005/08/30 01:25:53 banghart Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -1950,7 +1950,7 @@ sub crsenv {
'disablesigfigs'
);
foreach my $parameter (sort(keys(%values))) {
- unless ($parameter =~ m/^internal\./) {
+ unless (($parameter =~ m/^internal\./)||($parameter =~ m/^metadata\./)) {
if (! $descriptions{$parameter}) {
$descriptions{$parameter}=$parameter;
push(@Display_Order,$parameter);
@@ -2728,8 +2728,11 @@ ENDMAINFORMHEAD
sub setinstmeta {
my ($r)=@_;
my $next_meta;
- if ($env{'form.nextmeta'}) {
- $next_meta = $env{'form.nextmeta'};
+ my $output;
+ my $item_num;
+ my $put_result;
+ if ($env{'form.serial'}) {
+ $next_meta = $env{'form.serial'};
} else {
$next_meta = 1;
}
@@ -2742,37 +2745,75 @@ sub setinstmeta {
'Set Instructor Metadata'));
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
- if ($env{'form.state'}eq 'add') {
- $r->print('Compose a new metadata item:
');
- $r->print('
');
- } elsif ($env{'form.state'}eq 'save') {
- $r->print('Here we save the metadata');
- } else {
- foreach my $key (sort keys %env) {
- my $found_one = 0;
- if ($key=~m/^course\.$env{'request.course.id'}\.metadata\.title/) {
- unless ($found_one) {
- $found_one = 1;
- $r->print('Existing Metadata
');
- }
- $r->print($env{$key}.'
');
- $key=~~m/^course\.$env{'request.course.id'}\.metadata\.title\.(d*)\./;
- if ($1 ge $next_meta) {
- $next_meta = $1 ++;
- }
- }
+ my $key_base = $env{'course.'.$env{'request.course.id'}.'.metadata.'};
+ foreach my $field (%env) {
+ # start by looking for populated fields
+ if ($field=~m/type(\d+)/) {
+ my $item_num = $1;
+ my $name = 'metadata.'.$item_num.'.type';
+ my $value = $env{'form.type'.$item_num};
+ $put_result = &Apache::lonnet::put('environment',
+ {$name=>$value},$dom,$crs);
+ $name = 'metadata.'.$item_num.'.values';
+ $value = $env{'form.values'.$item_num};
+ $put_result = &Apache::lonnet::put('environment',
+ {$name=>$value},$dom,$crs);
}
- $r->print('Add Metadata Item
');
- }
+ if ($field=~m/newfield/) {
+ my $item_num = $env{'form.serial'};
+ my $name = 'metadata.'.$item_num.'.type';
+ my $value = $env{'form.typenew'};
+ $put_result = &Apache::lonnet::put('environment',
+ {$name=>$value},$dom,$crs);
+ $name = 'metadata.'.$item_num.'.values';
+ $value = $env{'form.valuesnew'};
+ $put_result = &Apache::lonnet::put('environment',
+ {$name=>$value},$dom,$crs);
+ $name = 'metadata.'.$item_num.'.title';
+ $value = $env{'form.titlenew'};
+ $put_result = &Apache::lonnet::put('environment',
+ {$name=>$value},$dom,$crs);
+
+ }
+
+
+ }
+ &Apache::lonnet::coursedescription($env{'request.course.id'});
+ foreach my $key (sort keys %env) {
+ if ($key=~m/^course\.$env{'request.course.id'}\.metadata\.\d+\.title$/) {
+ $key=~m/(^course\.$env{'request.course.id'}\.metadata\.)(\d+)\.title/;
+ $key_base = $1;
+ $item_num = $2;
+ if ($item_num ge $next_meta) {
+ $next_meta = $item_num + 1;
+ }
+ $output.=''.$env{$key}.' | ';
+ $output.='Select one: ';
+ $output.='Select many: | ';
+ $output.=' |
';
+ }
+ }
+ $output.='Create new instructor metadata item ';
+ $output.=' | ';
+ $output.='Select one: ';
+ $output.='Select many: | ';
+ $output.=' |
';
+ $output.='';
+ $output.='';
+ $r->print(<
+
+
+
+ Title | Options | Choices |
+ $output
+
+
+
+
+ENDenv
+
+
$r->print('