version 1.107, 2005/08/25 20:46:32
|
version 1.111, 2005/10/14 04:24:12
|
Line 290 sub fieldnames {
|
Line 290 sub fieldnames {
|
|
|
sub select_course { |
sub select_course { |
my ($r)=@_; |
my ($r)=@_; |
$r->print('<h3>Instructor Selected Meta-Data</h3><br />'); |
my @courses; |
|
foreach my $key (keys (%env)) { |
|
|
|
if ($key =~ m/^(course\..+)\.metadata\..+\.options/) { |
|
my $course_key = $1; |
|
$course_key .= '.description'; |
|
$r->print($env{$course_key}.' of '.$course_key.'<br />'); |
|
push @courses, $key; |
|
} |
|
} |
|
foreach (@courses) { |
|
$r->print($_.' was found<br />'); |
|
} |
|
$r->print('<h3>Portfolio Meta-Data</h3><br />'); |
$r->print('<form action="" method="post">'); |
$r->print('<form action="" method="post">'); |
$r->print('Select your course<br />'); |
$r->print('Select your test course<br />'); |
$r->print('<select name="metacourse" >'); |
$r->print('<select name="metacourse" >'); |
my $meta_not_found = 1; |
my $meta_not_found = 1; |
foreach my $key (keys %env) { |
foreach my $key (keys (%env)) { |
|
|
if ($key =~ /\.metadata\./) { |
if ($key =~ /\.metadata\./) { |
if ($meta_not_found) { |
if ($meta_not_found) { |
undef($meta_not_found); |
undef($meta_not_found); |
$r->print('<h3>Instructor Selected Meta-Data</h3><br />'); |
$r->print('<h3>Portfolio Meta-Data</h3><br />'); |
$r->print('<form action="" method="post">'); |
$r->print('<form action="" method="post">'); |
$r->print('Select your course<br />'); |
$r->print('Select your course<br />'); |
$r->print('<select name="metacourse" >'); |
$r->print('<select name="metacourse" >'); |
Line 313 sub select_course {
|
Line 327 sub select_course {
|
} |
} |
unless ($meta_not_found) { |
unless ($meta_not_found) { |
$r->print('</select><br />'); |
$r->print('</select><br />'); |
$r->print('<input type="submit" value="Assign Instructor Metadata" />'); |
$r->print('<input type="submit" value="Assign Portfolio Metadata" />'); |
$r->print('</form>'); |
$r->print('</form>'); |
} |
} |
return 'ok'; |
return 'ok'; |
Line 575 sub handler {
|
Line 589 sub handler {
|
# Looking for all bombs? |
# Looking for all bombs? |
&report_bombs($r,$uri); |
&report_bombs($r,$uri); |
} elsif ($uri=~/\/portfolio\//) { |
} elsif ($uri=~/\/portfolio\//) { |
|
($resdomain,$resuser)= |
|
(&Apache::lonnet::declutter($uri)=~m|^(\w+)/(\w+)/portfolio|); |
$r->print(&Apache::loncommon::bodytag |
$r->print(&Apache::loncommon::bodytag |
('Edit Portfolio File Information','','','',$resdomain)); |
('Edit Portfolio File Information','','','',$resdomain)); |
&present_editable_metadata($r,$uri,'portfolio'); |
&present_editable_metadata($r,$uri,'portfolio'); |
Line 930 sub present_editable_metadata {
|
Line 946 sub present_editable_metadata {
|
my $fn=&Apache::lonnet::filelocation('',$uri); |
my $fn=&Apache::lonnet::filelocation('',$uri); |
$disuri=~s/^\/\~/\/priv\//; |
$disuri=~s/^\/\~/\/priv\//; |
$disuri=~s/\.meta$//; |
$disuri=~s/\.meta$//; |
|
$disuri=~s|^/editupload||; |
my $target=$uri; |
my $target=$uri; |
$target=~s/^\/\~/\/res\/$env{'request.role.domain'}\//; |
$target=~s/^\/\~/\/res\/$env{'request.role.domain'}\//; |
$target=~s/\.meta$//; |
$target=~s/\.meta$//; |
Line 983 ENDDEL
|
Line 1000 ENDDEL
|
%Apache::lonpublisher::metadatakeys=(); |
%Apache::lonpublisher::metadatakeys=(); |
my $result=&Apache::lonnet::getfile($fn); |
my $result=&Apache::lonnet::getfile($fn); |
if ($result == -1){ |
if ($result == -1){ |
$r->print('Creating new '.$fn); |
$r->print('Creating new '.$disuri); |
} else { |
} else { |
&Apache::lonpublisher::metaeval($result); |
&Apache::lonpublisher::metaeval($result); |
} |
} |
Line 998 ENDEDIT
|
Line 1015 ENDEDIT
|
my $output; |
my $output; |
my @fields; |
my @fields; |
if ($file_type eq 'portfolio') { |
if ($file_type eq 'portfolio') { |
@fields = ('author','title','subject','keywords','abstract','notes','lowestgradelevel', |
@fields = ('author','metadata.title','metadata.subject','metadata.keywords','abstract','notes','lowestgradelevel', |
'highestgradelevel'); |
'highestgradelevel'); |
} else { |
} else { |
@fields = ('author','title','subject','keywords','abstract','notes', |
@fields = ('author','title','subject','keywords','abstract','notes', |
Line 1021 ENDEDIT
|
Line 1038 ENDEDIT
|
$Apache::lonpublisher::metadatafields{$_}, |
$Apache::lonpublisher::metadatafields{$_}, |
'new_'.$_,'defaultmeta').'</p>'); |
'new_'.$_,'defaultmeta').'</p>'); |
if ($env{'form.metacourse'}) { |
if ($env{'form.metacourse'}) { |
|
$r->print('This is the instructor metadata area<br />'); |
$r->print('This is the instructor metadata area<br />'); |
# have to find all the metadata items, so we'll loop through and find them |
my @keywords = sort(split /, /,$env{$env{'form.metacourse'}.'.metadata.keywords'}); |
$r->print('<form method="post" action="" size="3" >'); |
$r->print($env{'form.metacourse'}.'<br />'); |
$r->print('The course is: '.$env{'form.metacourse'}.'<br>'); |
$r->print('<form method="post" action="" size="3" >'); |
foreach my $key (sort keys %env) { |
foreach my $word (@keywords) { |
if ($key=~m/^($env{'form.metacourse'}\.metadata\.)(\d+)\.title/) { |
my $checked; |
my $key_base = $1; |
if ($Apache::lonpublisher::metadatafields{'coursekeyword'}=~ m/$word/) { |
my $item_num = $2; |
$checked = 1; |
# found one, so let's display it |
} else { |
my $title = $env{$key_base.$item_num.'.title'}; |
undef($checked); |
my $type = $env{$key_base.$item_num.'.type'}; |
|
my @choices = sort(split /, /,$env{$key_base.$item_num.'.values'}); |
|
$r->print($title.'<br />'); |
|
$r->print($type.'<br />'); |
|
|
|
foreach my $word (@choices) { |
|
my $checked; |
|
if ($Apache::lonpublisher::metadatafields{'coursekeyword'}=~ m/$word/) { |
|
$checked = 1; |
|
} else { |
|
undef($checked); |
|
} |
|
$r->print(&Apache::lonhtmlcommon::checkbox('instmeta_'.$env{'form.metacourse'}.'_'.$item_num,$checked,$word).$word.'<br />'); |
|
} |
} |
} |
$r->print(&Apache::lonhtmlcommon::checkbox('keywords',$checked,$word).$word.'<br />'); |
} |
} |
|
$r->print('<br /><input type="submit" name="store" value="Assign Meta-data" />'); |
$r->print('<br /><input type="submit" name="store" value="Assign Meta-data" />'); |
$r->print('</form>'); |
$r->print('</form>'); |
return 'ok'; |
return 'ok'; |
Line 1044 ENDEDIT
|
Line 1073 ENDEDIT
|
my $mfh; |
my $mfh; |
my $formname='store'; |
my $formname='store'; |
my $file_content; |
my $file_content; |
if (&Apache::loncommon::get_env_multiple('form.keywords')) { |
foreach my $meta_field (keys %env) { |
$Apache::lonpublisher::metadatafields{'coursekeyword'} = |
if ($meta_field=~m/^form.instmeta_(.+)_(\d+)$/) { |
|
$r->print('Found a field<br>'); |
|
} |
|
if (&Apache::loncommon::get_env_multiple('form.keywords')) { |
|
$Apache::lonpublisher::metadatafields{'coursekeyword'} = |
join (', ', &Apache::loncommon::get_env_multiple('form.keywords')); |
join (', ', &Apache::loncommon::get_env_multiple('form.keywords')); |
|
} |
} |
} |
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
next if ($_ =~ /\./); |
next if ($_ =~ /\./); |