version 1.107, 2005/08/25 20:46:32
|
version 1.137, 2005/12/13 11:52:37
|
Line 243 sub fieldnames {
|
Line 243 sub fieldnames {
|
'authorspace' => 'Author Space', |
'authorspace' => 'Author Space', |
'modifyinguser' => 'Last Modifying User', |
'modifyinguser' => 'Last Modifying User', |
'subject' => 'Subject', |
'subject' => 'Subject', |
|
'standards' => 'Standards', |
'keywords' => 'Keyword(s)', |
'keywords' => 'Keyword(s)', |
'notes' => 'Notes', |
'notes' => 'Notes', |
'abstract' => 'Abstract', |
'abstract' => 'Abstract', |
'lowestgradelevel' => 'Lowest Grade Level', |
'lowestgradelevel' => 'Lowest Grade Level', |
'highestgradelevel' => 'Highest Grade Level'); |
'highestgradelevel' => 'Highest Grade Level', |
|
'courserestricted' => 'Course Restricting Metadata'); |
|
|
if (! defined($file_type) || $file_type ne 'portfolio') { |
if (! defined($file_type) || $file_type ne 'portfolio') { |
%fields = |
%fields = |
(%fields, |
(%fields, |
'domain' => 'Domain', |
'domain' => 'Domain', |
'standards' => 'Standards', |
|
'mime' => 'MIME Type', |
'mime' => 'MIME Type', |
'language' => 'Language', |
'language' => 'Language', |
'creationdate' => 'Creation Date', |
'creationdate' => 'Creation Date', |
Line 282 sub fieldnames {
|
Line 284 sub fieldnames {
|
'stdno' => 'Total number of students who have worked on this problem', |
'stdno' => 'Total number of students who have worked on this problem', |
'difficulty' => 'Degree of difficulty', |
'difficulty' => 'Degree of difficulty', |
'disc' => 'Degree of discrimination', |
'disc' => 'Degree of discrimination', |
'dependencies' => 'Resources used by this resource', |
'dependencies' => 'Resources used by this resource', |
); |
); |
} |
} |
return &Apache::lonlocal::texthash(%fields); |
return &Apache::lonlocal::texthash(%fields); |
} |
} |
|
|
sub select_course { |
sub select_course { |
my ($r)=@_; |
my %courses; |
$r->print('<h3>Instructor Selected Meta-Data</h3><br />'); |
my $output; |
$r->print('<form action="" method="post">'); |
foreach my $key (keys (%env)) { |
$r->print('Select your course<br />'); |
if ($key =~ m/\.metadata\./) { |
$r->print('<select name="metacourse" >'); |
$key =~ m/^course\.(.+)(\.metadata.+$)/; |
my $meta_not_found = 1; |
my $course = $1; |
foreach my $key (keys %env) { |
my $coursekey = 'course.'.$course.'.description'; |
if ($key =~ /\.metadata\./) { |
my $value = $env{$coursekey}; |
if ($meta_not_found) { |
$courses{$coursekey} = $value; |
undef($meta_not_found); |
|
$r->print('<h3>Instructor Selected Meta-Data</h3><br />'); |
|
$r->print('<form action="" method="post">'); |
|
$r->print('Select your course<br />'); |
|
$r->print('<select name="metacourse" >'); |
|
} |
|
my $course_key = $key; |
|
$course_key =~ s/\.metadata\..*//; |
|
$r->print('<option value="'.$course_key.'">'); |
|
$r->print($env{$course_key.'.description'}); |
|
$r->print('</option>'); |
|
} |
} |
} |
} |
|
$output = '<h3>Associate resource with a course</h3><br />'; |
|
$output .= '<form action="" method="post">'; |
|
$output .= 'Select course <br />'; |
|
$output .= '<select name="metacourse" >'; |
|
my $meta_not_found = 1; |
|
foreach my $key (keys (%courses)) { |
|
if ($meta_not_found) { |
|
undef($meta_not_found); |
|
$output .= '<h3>Portfolio Meta-Data</h3><br />'; |
|
$output .= '<form action="" method="post">'; |
|
$output .= 'Select your course<br />'; |
|
$output .= '<select name="metacourse" >'; |
|
} |
|
$key =~ m/(^.+)\.description$/; |
|
$output .= '<option value="'.$1.'">'; |
|
$output .= $courses{$key}; |
|
$output .= '</option>'; |
|
} |
unless ($meta_not_found) { |
unless ($meta_not_found) { |
$r->print('</select><br />'); |
$output .= '</select><br />'; |
$r->print('<input type="submit" value="Assign Instructor Metadata" />'); |
$output .= '<input type="submit" value="Associate" />'; |
$r->print('</form>'); |
$output .= '</form>'; |
} |
} |
return 'ok'; |
return ($output); |
} |
} |
# Pretty printing of metadata field |
# Pretty printing of metadata field |
|
|
Line 470 sub relatedfield {
|
Line 479 sub relatedfield {
|
|
|
sub prettyinput { |
sub prettyinput { |
my ($type,$value,$fieldname,$formname, |
my ($type,$value,$fieldname,$formname, |
$relatedsearchflag,$relatedsep,$relatedvalue,$size)=@_; |
$relatedsearchflag,$relatedsep,$relatedvalue,$size,$course_key)=@_; |
if (! defined($size)) { |
if (! defined($size)) { |
$size = 80; |
$size = 80; |
} |
} |
|
my $output; |
|
if (defined($course_key)) { |
|
my $stu_add; |
|
my $only_one; |
|
my %meta_options; |
|
my @cur_values_inst; |
|
my $cur_values_stu; |
|
my $values = $env{$course_key.'.metadata.'.$type.'.values'}; |
|
if ($env{$course_key.'.metadata.'.$type.'.options'} =~ m/stuadd/) { |
|
$stu_add = 'true'; |
|
} |
|
if ($env{$course_key.'.metadata.'.$type.'.options'} =~ m/onlyone/) { |
|
$only_one = 'true'; |
|
} |
|
# need to take instructor values out of list where instructor and student |
|
# values may be mixed. |
|
if ($values) { |
|
foreach my $item (split(/,/,$values)) { |
|
$item =~ s/^\s+//; |
|
$meta_options{$item} = $item; |
|
} |
|
foreach my $item (split(/,/,$value)) { |
|
$item =~ s/^\s+//; |
|
if ($meta_options{$item}) { |
|
push(@cur_values_inst,$item); |
|
} else { |
|
$cur_values_stu .= $item.','; |
|
} |
|
} |
|
} else { |
|
$cur_values_stu = $value; |
|
} |
|
if ($type eq 'courserestricted') { |
|
return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />'); |
|
} |
|
if (($type eq 'keywords') || ($type eq 'subject') |
|
|| ($type eq 'author')||($type eq 'notes') |
|
|| ($type eq 'abstract')|| ($type eq 'title')|| ($type eq 'standards')) { |
|
if ($values) { |
|
if ($only_one) { |
|
$output .= (&Apache::loncommon::select_form($cur_values_inst[0],'new_'.$type,%meta_options)); |
|
} else { |
|
$output .= (&Apache::loncommon::multiple_select_form('new_'.$type,\@cur_values_inst,undef,\%meta_options)); |
|
} |
|
} |
|
if ($stu_add) { |
|
$output .= '<input type="text" name="'.$fieldname.'" size="'.$size.'" '. |
|
'value="'.$cur_values_stu.'" />'. |
|
&relatedfield(1,$relatedsearchflag,$relatedsep,$fieldname, |
|
$relatedvalue); |
|
} |
|
return ($output); |
|
} |
|
if (($type eq 'lowestgradelevel') || |
|
($type eq 'highestgradelevel')) { |
|
return &Apache::loncommon::select_level_form($value,$fieldname). |
|
&relatedfield(0,$relatedsearchflag,$relatedsep); |
|
} |
|
return(); |
|
} |
# Language |
# Language |
if ($type eq 'language') { |
if ($type eq 'language') { |
return &selectbox($fieldname, |
return &selectbox($fieldname, |
Line 534 sub prettyinput {
|
Line 603 sub prettyinput {
|
",'rights')\">".&mt('Select').'</a>'. |
",'rights')\">".&mt('Select').'</a>'. |
&relatedfield(0,$relatedsearchflag,$relatedsep); |
&relatedfield(0,$relatedsearchflag,$relatedsep); |
} |
} |
|
if ($type eq 'courserestricted') { |
|
return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />'); |
|
} |
|
|
# Dates |
# Dates |
if (($type eq 'creationdate') || |
if (($type eq 'creationdate') || |
($type eq 'lastrevisiondate')) { |
($type eq 'lastrevisiondate')) { |
Line 575 sub handler {
|
Line 648 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'); |
&select_course($r); |
|
} elsif ($uri=~/^\/\~/) { |
} elsif ($uri=~/^\/\~/) { |
# Construction space |
# Construction space |
$r->print(&Apache::loncommon::bodytag |
$r->print(&Apache::loncommon::bodytag |
Line 928 sub present_editable_metadata {
|
Line 1002 sub present_editable_metadata {
|
# Header |
# Header |
my $disuri=$uri; |
my $disuri=$uri; |
my $fn=&Apache::lonnet::filelocation('',$uri); |
my $fn=&Apache::lonnet::filelocation('',$uri); |
|
my $metacourse; |
$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 1059 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 999 ENDEDIT
|
Line 1075 ENDEDIT
|
my @fields; |
my @fields; |
if ($file_type eq 'portfolio') { |
if ($file_type eq 'portfolio') { |
@fields = ('author','title','subject','keywords','abstract','notes','lowestgradelevel', |
@fields = ('author','title','subject','keywords','abstract','notes','lowestgradelevel', |
'highestgradelevel'); |
'highestgradelevel','standards','courserestricted'); |
} else { |
} else { |
@fields = ('author','title','subject','keywords','abstract','notes', |
@fields = ('author','title','subject','keywords','abstract','notes', |
'copyright','customdistributionfile','language', |
'copyright','customdistributionfile','language', |
Line 1007 ENDEDIT
|
Line 1083 ENDEDIT
|
'lowestgradelevel','highestgradelevel','sourceavail','sourcerights', |
'lowestgradelevel','highestgradelevel','sourceavail','sourcerights', |
'obsolete','obsoletereplacement'); |
'obsolete','obsoletereplacement'); |
} |
} |
foreach (@fields) { |
if ($env{'form.metacourse'} ) { |
if (defined($env{'form.new_'.$_})) { |
$Apache::lonpublisher::metadatafields{'courserestricted'} = $env{'form.metacourse'}; |
$Apache::lonpublisher::metadatafields{$_}= |
$metacourse = $env{'form.metacourse'}; |
$env{'form.new_'.$_}; |
} else { |
|
if (! $Apache::lonpublisher::metadatafields{'courserestricted'}) { |
|
$Apache::lonpublisher::metadatafields{'courserestricted'}= |
|
'none'; |
|
$metacourse = 'none'; |
|
} else { |
|
$metacourse = $Apache::lonpublisher::metadatafields{'courserestricted'}; |
} |
} |
if (! $Apache::lonpublisher::metadatafields{'copyright'}) { |
} |
|
if (! $Apache::lonpublisher::metadatafields{'copyright'}) { |
$Apache::lonpublisher::metadatafields{'copyright'}= |
$Apache::lonpublisher::metadatafields{'copyright'}= |
'default'; |
'default'; |
} |
} |
$output.=('<p>'.$lt{$_}.': '. |
if ($metacourse ne 'none') { |
&prettyinput($_, |
$r->print('Using: <strong> '.$env{$metacourse.".description"}. |
$Apache::lonpublisher::metadatafields{$_}, |
"</strong> metadata framework<br />"); |
'new_'.$_,'defaultmeta').'</p>'); |
|
if ($env{'form.metacourse'}) { |
|
|
|
$r->print('This is the instructor metadata area<br />'); |
|
my @keywords = sort(split /, /,$env{$env{'form.metacourse'}.'.metadata.keywords'}); |
|
$r->print($env{'form.metacourse'}.'<br />'); |
|
$r->print('<form method="post" action="" size="3" >'); |
|
foreach my $word (@keywords) { |
|
my $checked; |
|
if ($Apache::lonpublisher::metadatafields{'coursekeyword'}=~ m/$word/) { |
|
$checked = 1; |
|
} else { |
} else { |
undef($checked); |
$r->print("This resources is not associated with a metadata framework<br />"); |
} |
} |
$r->print(&Apache::lonhtmlcommon::checkbox('keywords',$checked,$word).$word.'<br />'); |
foreach my $field_name(@fields) { |
} |
|
$r->print('<br /><input type="submit" name="store" value="Assign Meta-data" />'); |
if (defined($env{'form.new_'.$field_name})) { |
$r->print('</form>'); |
$Apache::lonpublisher::metadatafields{$field_name}= |
return 'ok'; |
join(',',&Apache::loncommon::get_env_multiple('form.new_'.$field_name)); |
|
} |
|
if ($metacourse ne 'none') { |
|
# handle restrictions here |
|
if ($env{$metacourse.'.metadata.'.$field_name.'.options'} =~ m/active/){ |
|
$output.=('<p>'.$lt{$field_name}.': '. |
|
&prettyinput($field_name, |
|
$Apache::lonpublisher::metadatafields{$field_name}, |
|
'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse).'</p>'); |
|
} elsif ($field_name eq 'courserestricted') { |
|
$output.=( |
|
&prettyinput($field_name, |
|
$Apache::lonpublisher::metadatafields{$field_name}, |
|
'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse)); |
|
} |
|
} else { |
|
if ($field_name ne 'courserestricted') { |
|
$output.=('<p>'.$lt{$field_name}.': '. |
|
&prettyinput($field_name, |
|
$Apache::lonpublisher::metadatafields{$field_name}, |
|
'new_'.$field_name,'defaultmeta').'</p>'); |
|
} else { |
|
$output.=&prettyinput($field_name, |
|
$Apache::lonpublisher::metadatafields{$field_name}, |
|
'new_'.$field_name,'defaultmeta'); |
|
} |
} |
} |
} |
} |
|
|
if ($env{'form.store'}) { |
if ($env{'form.store'}) { |
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 (&Apache::loncommon::get_env_multiple('form.new_keywords')) { |
join (', ', &Apache::loncommon::get_env_multiple('form.keywords')); |
$Apache::lonpublisher::metadatafields{'keywords'} = |
|
join (',', &Apache::loncommon::get_env_multiple('form.new_keywords')); |
|
} |
} |
} |
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
next if ($_ =~ /\./); |
next if ($_ =~ /\./); |
Line 1059 ENDEDIT
|
Line 1159 ENDEDIT
|
$Apache::lonpublisher::metadatakeys{$unikey}) |
$Apache::lonpublisher::metadatakeys{$unikey}) |
) { |
) { |
my $value= |
my $value= |
$Apache::lonpublisher::metadatafields{$unikey.'.'.$_}; |
$Apache::lonpublisher::metadatafields{$unikey.'.'.$_}; |
$value=~s/\"/\'\'/g; |
$value=~s/\"/\'\'/g; |
$file_content.=' '.$_.'="'.$value.'"' ; |
$file_content.=' '.$_.'="'.$value.'"' ; |
# print $mfh ' '.$_.'="'.$value.'"'; |
# print $mfh ' '.$_.'="'.$value.'"'; |
Line 1073 ENDEDIT
|
Line 1173 ENDEDIT
|
if ($fn =~ /\/portfolio\//) { |
if ($fn =~ /\/portfolio\//) { |
$fn =~ /\/portfolio\/(.*)$/; |
$fn =~ /\/portfolio\/(.*)$/; |
my $new_fn = '/'.$1; |
my $new_fn = '/'.$1; |
$env{'form.'.$formname}=$file_content; |
$env{'form.'.$formname}=$file_content."\n"; |
$env{'form.'.$formname.'.filename'}=$new_fn; |
$env{'form.'.$formname.'.filename'}=$new_fn; |
&Apache::lonnet::userfileupload('uploaddoc','', |
&Apache::lonnet::userfileupload('uploaddoc','', |
'portfolio'.$env{'form.currentpath'}); |
'portfolio'.$env{'form.currentpath'}); |
my $status =&Apache::lonnet::userfileupload($formname,'','portfolio'); |
|
if (&Apache::lonnet::userfileupload($formname,'','portfolio') eq 'error: no uploaded file') { |
if (&Apache::lonnet::userfileupload($formname,'','portfolio') eq 'error: no uploaded file') { |
$r->print('<p><font color="red">'. |
$r->print('<p><font color="red">'. |
&mt('Could not write metadata').', '. |
&mt('Could not write metadata').', '. |
Line 1100 ENDEDIT
|
Line 1199 ENDEDIT
|
} |
} |
} |
} |
} |
} |
$r->print($output.'<br /><input type="submit" name="store" value="'. |
$r->print($output.'<br /><input type="submit" name="store" value="'. |
&mt('Store Catalog Information').'">'); |
&mt('Store Catalog Information').'">'); |
|
|
} |
} |
$r->print('</form>'); |
$r->print('</form>'); |
|
if ($metacourse eq 'none') { |
|
$r->print(&select_course()); |
|
} |
return; |
return; |
} |
} |
|
|