Added functionality to manage subscription groups from within a Collaboration System
This commit is contained in:
parent
975e76ad2a
commit
09b1ab2e1e
3 changed files with 125 additions and 7 deletions
|
|
@ -375,6 +375,11 @@ sub definition {
|
||||||
|
|
||||||
my $richEditorOptions = $session->db->buildHashRef("select distinct(assetData.assetId), assetData.title from asset, assetData where asset.className='WebGUI::Asset::RichEdit' and asset.assetId=assetData.assetId order by assetData.title");
|
my $richEditorOptions = $session->db->buildHashRef("select distinct(assetData.assetId), assetData.title from asset, assetData where asset.className='WebGUI::Asset::RichEdit' and asset.assetId=assetData.assetId order by assetData.title");
|
||||||
|
|
||||||
|
#my $subManageButton = " ";
|
||||||
|
#if($self->get("subscriptionGroupId")) {
|
||||||
|
# $subManageButton = $session->icon->manage("op=editGroup;gid=".$self->get("subscriptionGroupId"));
|
||||||
|
#}
|
||||||
|
|
||||||
my %properties;
|
my %properties;
|
||||||
tie %properties, 'Tie::IxHash';
|
tie %properties, 'Tie::IxHash';
|
||||||
%properties = (
|
%properties = (
|
||||||
|
|
@ -519,11 +524,6 @@ sub definition {
|
||||||
label=>$i18n->get('archive after'),
|
label=>$i18n->get('archive after'),
|
||||||
hoverHelp=>$i18n->get('archive after description'),
|
hoverHelp=>$i18n->get('archive after description'),
|
||||||
},
|
},
|
||||||
subscriptionGroupId =>{
|
|
||||||
noFormPost=>1,
|
|
||||||
fieldType=>"hidden",
|
|
||||||
defaultValue=>undef
|
|
||||||
},
|
|
||||||
lastPostDate =>{
|
lastPostDate =>{
|
||||||
noFormPost=>1,
|
noFormPost=>1,
|
||||||
fieldType=>"hidden",
|
fieldType=>"hidden",
|
||||||
|
|
@ -720,7 +720,15 @@ sub definition {
|
||||||
visible=>$useKarma,
|
visible=>$useKarma,
|
||||||
label=>$i18n->get("default karma scale"),
|
label=>$i18n->get("default karma scale"),
|
||||||
hoverHelp=>$i18n->get('default karma scale help'),
|
hoverHelp=>$i18n->get('default karma scale help'),
|
||||||
}
|
},
|
||||||
|
|
||||||
|
subscriptionGroupId =>{
|
||||||
|
fieldType=>"subscriptionGroup",
|
||||||
|
tab=>'security',
|
||||||
|
label=>$i18n->get("subscription group label"),
|
||||||
|
hoverHelp=>$i18n->get("subscription group hoverHelp"),
|
||||||
|
defaultValue=>undef,
|
||||||
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
push(@{$definition}, {
|
push(@{$definition}, {
|
||||||
|
|
|
||||||
101
lib/WebGUI/Form/SubscriptionGroup.pm
Normal file
101
lib/WebGUI/Form/SubscriptionGroup.pm
Normal file
|
|
@ -0,0 +1,101 @@
|
||||||
|
package WebGUI::Form::SubscriptionGroup;
|
||||||
|
|
||||||
|
=head1 LEGAL
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
WebGUI is Copyright 2001-2007 Plain Black Corporation.
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Please read the legal notices (docs/legal.txt) and the license
|
||||||
|
(docs/license.txt) that came with this distribution before using
|
||||||
|
this software.
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
http://www.plainblack.com info@plainblack.com
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use base 'WebGUI::Form::Hidden';
|
||||||
|
use WebGUI::International;
|
||||||
|
|
||||||
|
=head1 NAME
|
||||||
|
|
||||||
|
Package WebGUI::Form::SubscriptionGroup
|
||||||
|
|
||||||
|
=head1 DESCRIPTION
|
||||||
|
|
||||||
|
Creates a hidden subscription group field. Returns the field and a button to manage the group specified by value
|
||||||
|
|
||||||
|
=head1 SEE ALSO
|
||||||
|
|
||||||
|
This is a subclass of WebGUI::Form::Hidden.
|
||||||
|
|
||||||
|
=head1 METHODS
|
||||||
|
|
||||||
|
The following methods are specifically available from this class. Check the superclass for additional methods.
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------
|
||||||
|
|
||||||
|
=head2 definition ( [ additionalTerms ] )
|
||||||
|
|
||||||
|
See the super class for additional details.
|
||||||
|
|
||||||
|
=head3 additionalTerms
|
||||||
|
|
||||||
|
The following additional parameters have been added via this sub class.
|
||||||
|
|
||||||
|
=head4 profileEnabled
|
||||||
|
|
||||||
|
Flag that tells the User Profile system that this is a valid form element in a User Profile
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub definition {
|
||||||
|
my $class = shift;
|
||||||
|
my $session = shift;
|
||||||
|
my $definition = shift || [];
|
||||||
|
my $i18n = WebGUI::International->new($session);
|
||||||
|
push(@{$definition}, {
|
||||||
|
formName=>{
|
||||||
|
defaultValue=>$i18n->get("hidden")
|
||||||
|
},
|
||||||
|
profileEnabled=>{
|
||||||
|
defaultValue=>0
|
||||||
|
},
|
||||||
|
});
|
||||||
|
return $class->SUPER::definition($session, $definition);
|
||||||
|
}
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------
|
||||||
|
|
||||||
|
=head2 toHtmlWithWrapper ( )
|
||||||
|
|
||||||
|
Renders the form field to HTML as a table row. The row is not displayed because there is nothing to display, but it may not be left away because <input> may not be a child of <table> according to the XHTML standard.
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub toHtmlWithWrapper {
|
||||||
|
my $self = shift;
|
||||||
|
my $value = $self->fixMacros($self->fixQuotes($self->fixSpecialCharacters($self->get("value")))) || '';
|
||||||
|
|
||||||
|
my $manageButton = " ";
|
||||||
|
if($value) {
|
||||||
|
$manageButton = $self->session->icon->manage("op=editGroup;gid=".$value);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($self->passUiLevelCheck) {
|
||||||
|
my ($fieldClass, $rowClass, $labelClass, $hoverHelp, $subtext) = $self->prepareWrapper;
|
||||||
|
return '<tr'.$rowClass.'>
|
||||||
|
<td'.$labelClass.$hoverHelp.' valign="top" style="width: 180px;"><label for="'.$self->get("id").'">'.$self->get("label").'</label></td>
|
||||||
|
<td valign="top"'.$fieldClass.'>'.$manageButton.$self->toHtmlAsHidden."</td>
|
||||||
|
</tr>\n";
|
||||||
|
} else {
|
||||||
|
return $self->toHtmlAsHidden;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
1;
|
||||||
|
|
||||||
|
|
@ -1652,6 +1652,15 @@ the Collaboration Asset, the user will be notified.|,
|
||||||
lastUpdated => 1170543345,
|
lastUpdated => 1170543345,
|
||||||
},
|
},
|
||||||
|
|
||||||
|
'subscription group label' => {
|
||||||
|
message => q|Subscription Group|,
|
||||||
|
lastUpdated => 1170543345,
|
||||||
|
},
|
||||||
|
|
||||||
|
'subscription group hoverHelp' => {
|
||||||
|
message => q|Manage the users in the subscription group for this Collaboration System|,
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue