Merge commit '808a866c8b' into webgui8. 7.9.4 release point
Conflicts: docs/upgrades/packages-7.9.3/root_import_gallery-templates_default-gallery-edit-album.wgpkg docs/upgrades/upgrade_7.9.2-7.9.3.pl lib/WebGUI.pm lib/WebGUI/Asset/MapPoint.pm lib/WebGUI/Asset/Wobject/Calendar.pm lib/WebGUI/Asset/Wobject/Gallery.pm lib/WebGUI/Asset/Wobject/GalleryAlbum.pm lib/WebGUI/Asset/Wobject/WikiMaster.pm lib/WebGUI/AssetClipboard.pm lib/WebGUI/AssetVersioning.pm lib/WebGUI/Auth.pm t/Asset/Asset.t
This commit is contained in:
commit
b30491f3a6
31 changed files with 1974 additions and 415 deletions
|
|
@ -367,6 +367,29 @@ override processPropertiesFromFormPost => sub {
|
|||
return undef;
|
||||
};
|
||||
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 rotate ( angle )
|
||||
|
||||
Rotate the photo clockwise by the specified C<angle> (in degrees) including the
|
||||
thumbnail and all resolutions.
|
||||
|
||||
=cut
|
||||
|
||||
sub rotate {
|
||||
my $self = shift;
|
||||
my $angle = shift;
|
||||
my $storage = $self->getStorageLocation;
|
||||
|
||||
# Rotate all files in the storage
|
||||
foreach my $file (@{$storage->getFiles}) {
|
||||
$storage->rotate($file, $angle);
|
||||
}
|
||||
# Re-create thumbnail
|
||||
$self->generateThumbnail;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 setFile ( filename )
|
||||
|
|
|
|||
|
|
@ -54,10 +54,10 @@ property address2 => (
|
|||
property city => (
|
||||
tab => "properties",
|
||||
fieldType => "text",
|
||||
label => ["city label", 'Asset_MapPoint'],
|
||||
hoverHelp => ["city description", 'Asset_MapPoint'],
|
||||
);
|
||||
property state => (
|
||||
label => $i18n->get("city label"),
|
||||
hoverHelp => $i18n->get("city description"),
|
||||
},
|
||||
property region => {
|
||||
tab => "properties",
|
||||
fieldType => "text",
|
||||
label => ["state label", 'Asset_MapPoint'],
|
||||
|
|
@ -276,6 +276,8 @@ sub getTemplateVarsEditForm {
|
|||
my $definition = __PACKAGE__->definition($session)->[0]->{properties};
|
||||
for my $key ( keys %{$definition} ) {
|
||||
next if $definition->{$key}->{noFormPost};
|
||||
next if $key eq 'latitude'
|
||||
|| $key eq 'longitude';
|
||||
$definition->{$key}->{name} = $key;
|
||||
$definition->{$key}->{value} = $self->$key;
|
||||
$var->{ "form_$key" }
|
||||
|
|
|
|||
|
|
@ -51,6 +51,7 @@ use JSON qw();
|
|||
use WebGUI::International;
|
||||
use WebGUI::HTML;
|
||||
use WebGUI::ProgressBar;
|
||||
use WebGUI::Storage;
|
||||
|
||||
use Archive::Any;
|
||||
|
||||
|
|
@ -931,6 +932,7 @@ sub www_addArchive {
|
|||
$var->{ form_start }
|
||||
= WebGUI::Form::formHeader( $session, {
|
||||
action => $self->getUrl('func=addArchiveSave'),
|
||||
name => 'name="galleryAlbumAddArchive"',
|
||||
});
|
||||
$var->{ form_end }
|
||||
= WebGUI::Form::formFooter( $session );
|
||||
|
|
@ -1362,6 +1364,43 @@ sub www_edit {
|
|||
$session->errorHandler->error("Couldn't demote asset '$assetId' because we couldn't instantiate it.");
|
||||
}
|
||||
}
|
||||
# Rotate to the left
|
||||
elsif ( grep { $_ =~ /^rotateLeft-(.{22})$/ } $form->param ) {
|
||||
my $assetId = ( grep { $_ =~ /^rotateLeft-(.{22})$/ } $form->param )[0];
|
||||
$assetId =~ s/^rotateLeft-//;
|
||||
my $asset = WebGUI::Asset->newByDynamicClass( $session, $assetId );
|
||||
|
||||
if ( $asset ) {
|
||||
# Add revision and create a new version tag by doing so
|
||||
my $newRevision = $asset->addRevision;
|
||||
# Rotate photo (i.e. all attached image files) by 90° CCW
|
||||
$newRevision->rotate(-90);
|
||||
# Auto-commit version tag
|
||||
$newRevision->requestAutoCommit;
|
||||
}
|
||||
else {
|
||||
$session->log->error("Couldn't rotate asset '$assetId' because we couldn't instantiate it.");
|
||||
}
|
||||
}
|
||||
# Rotate to the right
|
||||
elsif ( grep { $_ =~ /^rotateRight-(.{22})$/ } $form->param ) {
|
||||
my $assetId = ( grep { $_ =~ /^rotateRight-(.{22})$/ } $form->param )[0];
|
||||
$assetId =~ s/^rotateRight-//;
|
||||
my $asset = WebGUI::Asset->newByDynamicClass( $session, $assetId );
|
||||
|
||||
if ( $asset ) {
|
||||
# Add revision and create a new version tag by doing so
|
||||
my $newRevision = $asset->addRevision;
|
||||
# Rotate photo (i.e. all attached image files) by 90° CW
|
||||
$newRevision->rotate(90);
|
||||
# Auto-commit version tag
|
||||
$newRevision->requestAutoCommit;
|
||||
}
|
||||
else {
|
||||
$session->log->error("Couldn't rotate asset '$assetId' because we couldn't instantiate it.");
|
||||
}
|
||||
}
|
||||
# Delete the file
|
||||
elsif ( grep { $_ =~ /^delete-(.{22})$/ } $form->param ) {
|
||||
my $assetId = ( grep { $_ =~ /^delete-(.{22})$/ } $form->param )[0];
|
||||
$assetId =~ s/^delete-//;
|
||||
|
|
@ -1381,6 +1420,7 @@ sub www_edit {
|
|||
$var->{ form_start }
|
||||
= WebGUI::Form::formHeader( $session, {
|
||||
action => $self->getParent->getUrl('func=editSave;assetId=new;class='.__PACKAGE__),
|
||||
extras => 'name="galleryAlbumAdd"',
|
||||
})
|
||||
. WebGUI::Form::hidden( $session, {
|
||||
name => "ownerUserId",
|
||||
|
|
@ -1399,6 +1439,7 @@ sub www_edit {
|
|||
$var->{ form_start }
|
||||
= WebGUI::Form::formHeader( $session, {
|
||||
action => $self->getUrl('func=edit'),
|
||||
extras => 'name="galleryAlbumEdit"',
|
||||
})
|
||||
. WebGUI::Form::hidden( $session, {
|
||||
name => "ownerUserId",
|
||||
|
|
@ -1460,23 +1501,44 @@ sub www_edit {
|
|||
id => "assetIdThumbnail_$file->{ assetId }",
|
||||
} );
|
||||
|
||||
# Raw HTML here to provide proper value for the image
|
||||
my $promoteLabel = $i18n->get( 'Move Up', 'Icon' );
|
||||
$file->{ form_promote }
|
||||
= qq{<input type="submit" name="promote-$file->{assetId}" class="promote" value="$promoteLabel" />}
|
||||
;
|
||||
= WebGUI::Form::submit( $session, {
|
||||
name => "promote-$file->{assetId}",
|
||||
value => $i18n->get( 'Move Up', 'Icon' ),
|
||||
class => "promote",
|
||||
});
|
||||
|
||||
my $demoteLabel = $i18n->get( 'Move Down', 'Icon' );
|
||||
$file->{ form_demote }
|
||||
= qq{<input type="submit" name="demote-$file->{assetId}" class="demote" value="$demoteLabel" />}
|
||||
;
|
||||
= WebGUI::Form::submit( $session, {
|
||||
name => "demote-$file->{assetId}",
|
||||
value => $i18n->get( 'Move Down', 'Icon' ),
|
||||
class => "demote",
|
||||
});
|
||||
|
||||
my $deleteConfirm = $i18n->get( 'template delete message', 'Asset_Photo' );
|
||||
my $deleteLabel = $i18n->get( 'Delete', 'Icon' );
|
||||
$file->{ form_delete }
|
||||
= qq{<input type="submit" name="delete-$file->{assetId}" class="delete" value="$deleteLabel" }
|
||||
. qq{ onclick="return confirm('$deleteConfirm')" />}
|
||||
;
|
||||
= WebGUI::Form::submit( $session, {
|
||||
name => "delete-$file->{assetId}",
|
||||
value => $i18n->get( 'Delete', 'Icon' ),
|
||||
class => "delete",
|
||||
extras => "onclick=\"return confirm('$deleteConfirm')\"",
|
||||
});
|
||||
|
||||
$file->{ form_rotateLeft }
|
||||
= WebGUI::Form::submit( $session, {
|
||||
name => "rotateLeft-$file->{assetId}",
|
||||
value => $i18n->get( 'rotate left' ),
|
||||
class => "rotateLeft",
|
||||
});
|
||||
|
||||
$file->{ form_rotateRight }
|
||||
= WebGUI::Form::submit( $session, {
|
||||
name => "rotateRight-$file->{assetId}",
|
||||
value => $i18n->get( 'rotate right' ),
|
||||
class => "rotateRight",
|
||||
});
|
||||
|
||||
$file->{ form_synopsis }
|
||||
= WebGUI::Form::HTMLArea( $session, {
|
||||
|
|
|
|||
|
|
@ -188,6 +188,8 @@ use WebGUI::International;
|
|||
use HTML::Parser;
|
||||
use URI::Escape;
|
||||
use WebGUI::Utility qw/isIn/;
|
||||
use WebGUI::Form;
|
||||
use Clone qw/clone/;
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
|
|
@ -209,12 +211,29 @@ sub appendFeaturedPageVars {
|
|||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 appendKeywordPageVars ( var )
|
||||
|
||||
Append the template variables to C<var> for keyword (catagory) pages.
|
||||
|
||||
=cut
|
||||
|
||||
sub appendKeywordPageVars {
|
||||
my ( $self, $var ) = @_;
|
||||
my $session = $self->session;
|
||||
my $topKeywords = $self->getTopLevelKeywordsList;
|
||||
my $keywordHierarchy = $self->getKeywordHierarchy( $topKeywords, );
|
||||
$var->{keywords_loop} = $self->getKeywordVariables( $keywordHierarchy );
|
||||
return $var;
|
||||
}
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 appendMostPopular ($var, [ $limit ])
|
||||
|
||||
=head3 $var
|
||||
|
||||
A hash reference of template variables. An array reference containing the most popular wiki pages
|
||||
in order of popularity.
|
||||
in order of popularity will be appended to it.
|
||||
|
||||
=head3 $limit
|
||||
|
||||
|
|
@ -441,6 +460,180 @@ sub canEditPages {
|
|||
return $self->session->user->isInGroup($self->groupToEditPages) || $self->canAdminister;
|
||||
}
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
sub definition {
|
||||
my $class = shift;
|
||||
my $session = shift;
|
||||
my $definition = shift;
|
||||
my $i18n = WebGUI::International->new($session, 'Asset_WikiMaster');
|
||||
|
||||
my %properties;
|
||||
tie %properties, 'Tie::IxHash';
|
||||
%properties =
|
||||
(
|
||||
groupToEditPages => { fieldType => 'group',
|
||||
defaultValue => ['2'],
|
||||
tab => 'security',
|
||||
hoverHelp => $i18n->get('groupToEditPages hoverHelp'),
|
||||
label => $i18n->get('groupToEditPages label') },
|
||||
|
||||
groupToAdminister => { fieldType => 'group',
|
||||
defaultValue => ['3'],
|
||||
tab => 'security',
|
||||
hoverHelp => $i18n->get('groupToAdminister hoverHelp'),
|
||||
label => $i18n->get('groupToAdminister label') },
|
||||
|
||||
richEditor => { fieldType => 'selectRichEditor',
|
||||
defaultValue => 'PBrichedit000000000001',
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('richEditor hoverHelp'),
|
||||
label => $i18n->get('richEditor label') },
|
||||
|
||||
frontPageTemplateId => { fieldType => 'template',
|
||||
namespace => 'WikiMaster_front',
|
||||
defaultValue => 'WikiFrontTmpl000000001',
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('frontPageTemplateId hoverHelp'),
|
||||
label => $i18n->get('frontPageTemplateId label') },
|
||||
|
||||
pageTemplateId => { fieldType => 'template',
|
||||
namespace => 'WikiPage',
|
||||
defaultValue => 'WikiPageTmpl0000000001',
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('pageTemplateId hoverHelp'),
|
||||
label => $i18n->get('pageTemplateId label') },
|
||||
|
||||
pageHistoryTemplateId => { fieldType => 'template',
|
||||
namespace => 'WikiPage_pageHistory',
|
||||
defaultValue => 'WikiPHTmpl000000000001',
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('pageHistoryTemplateId hoverHelp'),
|
||||
label => $i18n->get('pageHistoryTemplateId label') },
|
||||
|
||||
mostPopularTemplateId => { fieldType => 'template',
|
||||
namespace => 'WikiMaster_mostPopular',
|
||||
defaultValue => 'WikiMPTmpl000000000001',
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('mostPopularTemplateId hoverHelp'),
|
||||
label => $i18n->get('mostPopularTemplateId label') },
|
||||
|
||||
recentChangesTemplateId => { fieldType => 'template',
|
||||
namespace => 'WikiMaster_recentChanges',
|
||||
defaultValue => 'WikiRCTmpl000000000001',
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('recentChangesTemplateId hoverHelp'),
|
||||
label => $i18n->get('recentChangesTemplateId label') },
|
||||
|
||||
byKeywordTemplateId => { fieldType => 'template',
|
||||
namespace => 'WikiMaster_byKeyword',
|
||||
defaultValue => 'WikiKeyword00000000001',
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('byKeywordTemplateId hoverHelp'),
|
||||
label => $i18n->get('byKeywordTemplateId label') },
|
||||
|
||||
searchTemplateId => { fieldType => 'template',
|
||||
namespace => 'WikiMaster_search',
|
||||
defaultValue => 'WikiSearchTmpl00000001',
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('searchTemplateId hoverHelp'),
|
||||
label => $i18n->get('searchTemplateId label') },
|
||||
|
||||
pageEditTemplateId => { fieldType => 'template',
|
||||
namespace => 'WikiPage_edit',
|
||||
defaultValue => 'WikiPageEditTmpl000001',
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('pageEditTemplateId hoverHelp'),
|
||||
label => $i18n->get('pageEditTemplateId label') },
|
||||
|
||||
recentChangesCount => { fieldType => 'integer',
|
||||
defaultValue => 50,
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('recentChangesCount hoverHelp'),
|
||||
label => $i18n->get('recentChangesCount label') },
|
||||
|
||||
recentChangesCountFront => { fieldType => 'integer',
|
||||
defaultValue => 10,
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('recentChangesCountFront hoverHelp'),
|
||||
label => $i18n->get('recentChangesCountFront label') },
|
||||
|
||||
mostPopularCount => { fieldType => 'integer',
|
||||
defaultValue => 50,
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('mostPopularCount hoverHelp'),
|
||||
label => $i18n->get('mostPopularCount label') },
|
||||
|
||||
mostPopularCountFront => { fieldType => 'integer',
|
||||
defaultValue => 10,
|
||||
tab => 'display',
|
||||
hoverHelp => $i18n->get('mostPopularCountFront hoverHelp'),
|
||||
label => $i18n->get('mostPopularCountFront label') },
|
||||
approvalWorkflow =>{
|
||||
fieldType=>"workflow",
|
||||
defaultValue=>"pbworkflow000000000003",
|
||||
type=>'WebGUI::VersionTag',
|
||||
tab=>'security',
|
||||
label=>$i18n->get('approval workflow'),
|
||||
hoverHelp=>$i18n->get('approval workflow description'),
|
||||
},
|
||||
thumbnailSize => {
|
||||
fieldType => "integer",
|
||||
defaultValue => 0,
|
||||
tab => "display",
|
||||
label => $i18n->get("thumbnail size"),
|
||||
hoverHelp => $i18n->get("thumbnail size help")
|
||||
},
|
||||
maxImageSize => {
|
||||
fieldType => "integer",
|
||||
defaultValue => 0,
|
||||
tab => "display",
|
||||
label => $i18n->get("max image size"),
|
||||
hoverHelp => $i18n->get("max image size help")
|
||||
},
|
||||
allowAttachments => {
|
||||
fieldType => "integer",
|
||||
defaultValue => 0,
|
||||
tab => "security",
|
||||
label => $i18n->get("allow attachments"),
|
||||
hoverHelp => $i18n->get("allow attachments help"),
|
||||
},
|
||||
useContentFilter =>{
|
||||
fieldType=>"yesNo",
|
||||
defaultValue=>1,
|
||||
tab=>'display',
|
||||
label=>$i18n->get('content filter'),
|
||||
hoverHelp=>$i18n->get('content filter description'),
|
||||
},
|
||||
filterCode =>{
|
||||
fieldType=>"filterContent",
|
||||
defaultValue=>'javascript',
|
||||
tab=>'security',
|
||||
label=>$i18n->get('filter code'),
|
||||
hoverHelp=>$i18n->get('filter code description'),
|
||||
},
|
||||
topLevelKeywords =>{
|
||||
fieldType => "keywords",
|
||||
defaultValue => '',
|
||||
tab => 'properties',
|
||||
label => $i18n->get('top level keywords'),
|
||||
hoverHelp => $i18n->get('top level keywords description'),
|
||||
},
|
||||
);
|
||||
|
||||
push @$definition,
|
||||
{
|
||||
assetName => $i18n->get('assetName'),
|
||||
icon => 'wikiMaster.gif',
|
||||
autoGenerateForms => 1,
|
||||
tableName => 'WikiMaster',
|
||||
className => 'WebGUI::Asset::Wobject::WikiMaster',
|
||||
properties => \%properties,
|
||||
};
|
||||
|
||||
return $class->next::method($session, $definition);
|
||||
>>>>>>> 808a866c8b2a426e4958d38c34e8753a8555fc90
|
||||
}
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 getFeaturedPageIds ( )
|
||||
|
|
@ -462,6 +655,108 @@ sub getFeaturedPageIds {
|
|||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 getKeywordHierarchy ( $keywords, $seen )
|
||||
|
||||
Starting with the top level keywords, return the hierarchy of keywords as a recursive arrayref of hashrefs.
|
||||
The traversal is left-most, depth first.
|
||||
|
||||
The hierarchy data structure that looks like this:
|
||||
|
||||
[
|
||||
{
|
||||
title => 'title', # same as the keyword, since this is a keyword (category) page
|
||||
url => 'url', # url from the keyword page, via getUrl so it contains the gateway URL
|
||||
# If a keyword page does not exist for the keyword, this key/value pair will not be present.
|
||||
children => [ # Array reference of sub-categories referenced by this category
|
||||
{ # If there are no children, this key/value pair will not be present
|
||||
...
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
|
||||
=head3 $keywords
|
||||
|
||||
An array reference of keywords. If this is blank, then it will use the top level keywords from
|
||||
itself as a default.
|
||||
|
||||
=head3 $seen
|
||||
|
||||
A hash reference that keeps track of which keywords have already been seen. This prevents
|
||||
infinite loops from happening during the traversal.
|
||||
|
||||
=cut
|
||||
|
||||
sub getKeywordHierarchy {
|
||||
my ( $self, $keywords, $seen ) = @_;
|
||||
my $session = $self->session;
|
||||
my $hierarchy = [];
|
||||
$keywords ||= $self->getTopLevelKeywordsList;
|
||||
$seen ||= {};
|
||||
KEYWORD: foreach my $keyword (sort @{ $keywords }) {
|
||||
my $page = $self->getLineage(['children'], {
|
||||
returnObjects => 1,
|
||||
whereClause => 'assetData.title = '.$session->db->quote($keyword),
|
||||
limit => 1,
|
||||
includeOnlyClasses => [qw/WebGUI::Asset::WikiPage/],
|
||||
})->[0];
|
||||
if (! $page) {
|
||||
push @{ $hierarchy }, { title => $keyword, url => '', };
|
||||
next KEYWORD;
|
||||
}
|
||||
my $datum = {
|
||||
title => $keyword, ##Note, same as keyword
|
||||
url => $page->getUrl,
|
||||
};
|
||||
##Prevent recursion if seen again
|
||||
if (! $seen->{$keyword}++) {
|
||||
my $children = $self->getKeywordHierarchy(WebGUI::Keyword::string2list($page->get('keywords')), $seen, );
|
||||
if (@{ $children } ) {
|
||||
$datum->{children} = $children;
|
||||
}
|
||||
}
|
||||
push @{ $hierarchy }, $datum;
|
||||
}
|
||||
return $hierarchy;
|
||||
}
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 getKeywordVariables ( $hierarchy, $level )
|
||||
|
||||
Take a data structure representing a hierarchy of keywords, and append template variables
|
||||
to them similar to a Navigation so you can build useful things with them.
|
||||
|
||||
=head3 $hierarchy
|
||||
|
||||
A data structure similar to that produced by getKeywordHierarchy
|
||||
|
||||
=head3 $level
|
||||
|
||||
The current level in any part of the hierarchy.
|
||||
|
||||
=cut
|
||||
|
||||
sub getKeywordVariables {
|
||||
my ( $self, $hierarchy, $level ) = @_;
|
||||
$level ||= 0;
|
||||
my $variables = [];
|
||||
|
||||
KEYWORD: foreach my $member (@{ $hierarchy }) {
|
||||
my $varBlock = clone $member;
|
||||
$varBlock->{level} = $level;
|
||||
$varBlock->{indent_loop} = [ map { { indent => $_ } } 1..$level ];
|
||||
delete $varBlock->{children};
|
||||
push @{$variables}, $varBlock;
|
||||
if ( exists $member->{children} ) {
|
||||
push @{$variables}, @{ $self->getKeywordVariables($member->{children}, $level+1) };
|
||||
}
|
||||
}
|
||||
return $variables;
|
||||
}
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 getRssFeedItems ()
|
||||
|
||||
Returns an array reference of hash references. Each hash reference has a title,
|
||||
|
|
@ -521,6 +816,19 @@ sub getTemplateVars {
|
|||
return $var;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 getTopLevelKeywordsList ( )
|
||||
|
||||
Return the top level keywords as an array reference.
|
||||
|
||||
=cut
|
||||
|
||||
sub getTopLevelKeywordsList {
|
||||
my ( $self ) = @_;
|
||||
return WebGUI::Keyword::string2list($self->get('topLevelKeywords'));
|
||||
}
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 prepareView
|
||||
|
|
@ -611,6 +919,7 @@ sub view {
|
|||
$self->appendSearchBoxVars($var);
|
||||
$self->appendRecentChanges($var, $self->recentChangesCountFront);
|
||||
$self->appendMostPopular($var, $self->mostPopularCountFront);
|
||||
$self->appendKeywordPageVars($var);
|
||||
return $self->processTemplate($var, undef, $template);
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -100,9 +100,12 @@ sub duplicate {
|
|||
my $newAsset
|
||||
= $parent->addChild( $self->get, undef, $self->get("revisionDate"), { skipAutoCommitWorkflows => $options->{skipAutoCommitWorkflows} } );
|
||||
|
||||
$session->log->error(
|
||||
sprintf "Unable to add child %s (%s) to %s (%s)", $self->getTitle, $self->getId, $parent->getTitle, $parent->getId
|
||||
);
|
||||
if (! $newAsset) {
|
||||
$self->session->log->error(
|
||||
sprintf "Unable to add child %s (%s) to %s (%s)", $self->getTitle, $self->getId, $parent->getTitle, $parent->getId
|
||||
);
|
||||
return undef;
|
||||
}
|
||||
# Duplicate metadata fields
|
||||
my $sth = $session->db->read(
|
||||
"select * from metaData_values where assetId = ?",
|
||||
|
|
|
|||
|
|
@ -397,7 +397,7 @@ sub deactivateAccount {
|
|||
$var{'yes.label'} = $i18n->get(44);
|
||||
$var{'no.url'} = $self->session->url->page();
|
||||
$var{'no.label'} = $i18n->get(45);
|
||||
return WebGUI::Asset::Template->newById($self->session,$self->get('getDeactivateAccountTemplateId'))->process(\%var);
|
||||
return WebGUI::Asset::Template->new($self->session,$self->getDeactivateAccountTemplateId)->process(\%var);
|
||||
}
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
|
|
|||
|
|
@ -331,6 +331,14 @@ our $HELP = {
|
|||
name => 'form_demote',
|
||||
description => 'helpvar form_demote',
|
||||
},
|
||||
{
|
||||
name => 'form_rotateLeft',
|
||||
description => 'helpvar form_rotateLeft',
|
||||
},
|
||||
{
|
||||
name => 'form_rotateRight',
|
||||
description => 'helpvar form_rotateRight',
|
||||
},
|
||||
{
|
||||
name => 'form_synopsis',
|
||||
description => 'helpvar form_synopsis',
|
||||
|
|
|
|||
69
lib/WebGUI/Help/Asset_MapPoint.pm
Normal file
69
lib/WebGUI/Help/Asset_MapPoint.pm
Normal file
|
|
@ -0,0 +1,69 @@
|
|||
package WebGUI::Help::Asset_MapPoint;
|
||||
use strict;
|
||||
|
||||
our $HELP = {
|
||||
|
||||
'edit template' => {
|
||||
title => 'edit template',
|
||||
body => '',
|
||||
isa => [
|
||||
{ namespace => 'Asset_Template',
|
||||
tag => 'template variables'
|
||||
},
|
||||
],
|
||||
fields => [],
|
||||
variables => [
|
||||
{ name => 'form_header', required => 1, },
|
||||
{ name => 'form_footer', required => 1, },
|
||||
{ name => 'form_submit', },
|
||||
{ name => 'form_title', },
|
||||
{ name => 'form_synopsis', },
|
||||
{ name => 'form_storageIdPhoto', },
|
||||
{ name => 'currentPhoto', },
|
||||
{ name => 'form_website', },
|
||||
{ name => 'form_address1', },
|
||||
{ name => 'form_address2', },
|
||||
{ name => 'form_address3', },
|
||||
{ name => 'form_city', },
|
||||
{ name => 'form_region', },
|
||||
{ name => 'form_zipCode', },
|
||||
{ name => 'form_country', },
|
||||
{ name => 'form_phone', },
|
||||
{ name => 'form_fax', },
|
||||
{ name => 'form_email', },
|
||||
],
|
||||
related => []
|
||||
},
|
||||
|
||||
'map point asset template variables' => {
|
||||
private => 1,
|
||||
title => 'map point asset template variables',
|
||||
body => '',
|
||||
isa => [
|
||||
{ namespace => 'Asset',
|
||||
tag => 'asset template asset variables'
|
||||
},
|
||||
],
|
||||
fields => [],
|
||||
variables => [
|
||||
{ name => 'latitude', },
|
||||
{ name => 'longitude', },
|
||||
{ name => 'storageIdPhoto', },
|
||||
{ name => 'website', },
|
||||
{ name => 'address1', },
|
||||
{ name => 'address2', },
|
||||
{ name => 'address3', },
|
||||
{ name => 'city', },
|
||||
{ name => 'region', },
|
||||
{ name => 'zipCode', },
|
||||
{ name => 'country', },
|
||||
{ name => 'phone', },
|
||||
{ name => 'fax', },
|
||||
{ name => 'email', },
|
||||
],
|
||||
related => []
|
||||
},
|
||||
|
||||
};
|
||||
|
||||
1;
|
||||
|
|
@ -102,6 +102,26 @@ our $HELP = {
|
|||
{ 'name' => 'recentChangesLabel variable', },
|
||||
{ 'name' => 'addPageUrl', },
|
||||
{ 'name' => 'addPageLabel', },
|
||||
{ 'name' => 'keywords_loop',
|
||||
'variables' => [
|
||||
{ 'name' => 'title',
|
||||
'description' => 'keyword title',
|
||||
},
|
||||
{ 'name' => 'url',
|
||||
'description' => 'keyword url',
|
||||
},
|
||||
{ 'name' => 'level',
|
||||
'description' => 'keyword level',
|
||||
},
|
||||
{ 'name' => 'indent_loop',
|
||||
'variables' => [
|
||||
{ 'name' => 'indent',
|
||||
'description' => 'keyword indent',
|
||||
},
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
],
|
||||
fields => [],
|
||||
related => [],
|
||||
|
|
|
|||
|
|
@ -306,9 +306,13 @@ sub www_runCronJob {
|
|||
}
|
||||
|
||||
# Run the instance
|
||||
$instance->start( 1 );
|
||||
$task->delete( 1 ) if ( $task->get("runOnce") );
|
||||
return "done";
|
||||
my $error = $instance->start( 1 );
|
||||
if ($error) {
|
||||
$task->delete(1);
|
||||
return "error";
|
||||
}
|
||||
$task->delete( 1 ) if ( $task->get("runOnce") );
|
||||
return "done";
|
||||
}
|
||||
$session->errorHandler->warn("No task ID passed to cron job runner.");
|
||||
return "error";
|
||||
|
|
|
|||
|
|
@ -23,6 +23,18 @@ our $I18N = {
|
|||
context => "Label for Save button",
|
||||
},
|
||||
|
||||
'rotate left' => {
|
||||
message => "90° CCW",
|
||||
lastUpdated => 1270582436,
|
||||
context => "Label for rotate left button",
|
||||
},
|
||||
|
||||
'rotate right' => {
|
||||
message => "90° CW",
|
||||
lastUpdated => 1270582436,
|
||||
context => "Label for rotate right button",
|
||||
},
|
||||
|
||||
'save message' => {
|
||||
message => 'Album settings saved.',
|
||||
lastUpdated => 0,
|
||||
|
|
@ -38,12 +50,11 @@ our $I18N = {
|
|||
lastUpdated => 0,
|
||||
},
|
||||
|
||||
|
||||
'delete message' => {
|
||||
message => 'Album has been deleted. <a href="%s">Return to Gallery</a>',
|
||||
lastUpdated => 0,
|
||||
},
|
||||
|
||||
|
||||
'help common title' => {
|
||||
message => 'Gallery Album Variables (Common)',
|
||||
lastUpdated => 0,
|
||||
|
|
@ -524,6 +535,18 @@ our $I18N = {
|
|||
lastUpdated => 1213631346,
|
||||
context => q{Description of template variable},
|
||||
},
|
||||
|
||||
'helpvar form_rotateLeft' => {
|
||||
message => q{A button to rotate the photo by 90° counter clockwise.},
|
||||
lastUpdated => 1270582436,
|
||||
context => q{Description of template variable},
|
||||
},
|
||||
|
||||
'helpvar form_rotateRight' => {
|
||||
message => q{A button to rotate the photo by 90° clockwise.},
|
||||
lastUpdated => 1270582436,
|
||||
context => q{Description of template variable},
|
||||
},
|
||||
|
||||
'helpvar form_delete' => {
|
||||
message => q{A button to delete the image.},
|
||||
|
|
|
|||
|
|
@ -133,11 +133,217 @@ our $I18N = {
|
|||
lastUpdated => 0,
|
||||
context => 'Description of asset property',
|
||||
},
|
||||
|
||||
'assetName' => {
|
||||
message => "MapPoint",
|
||||
lastUpdated => 0,
|
||||
context => "Name of this asset",
|
||||
},
|
||||
|
||||
'edit template' => {
|
||||
message => "MapPoint Edit Point Template",
|
||||
lastUpdated => 0,
|
||||
context => "template variable section title",
|
||||
},
|
||||
|
||||
'form_header' => {
|
||||
message => "HTML code to start the edit form.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_footer' => {
|
||||
message => "HTML code to end the edit form.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_submit' => {
|
||||
message => "A button to submit the edit form.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_title' => {
|
||||
message => "A text form element for entering the title.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_synopsis' => {
|
||||
message => "A textarea form element for entering the synopsis.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_storageIdPhoto' => {
|
||||
message => "A file form element for uploading a photo relating to the map point.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'currentPhoto' => {
|
||||
message => "An image tag linking to any currently uploaded photo.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_website' => {
|
||||
message => "A text field for entering in a URL related to the map point.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_address1' => {
|
||||
message => "A text field for entering in one part of an address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_address2' => {
|
||||
message => "A text field for entering in another part of an address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_address3' => {
|
||||
message => "A text field for entering in the last past of an address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_city' => {
|
||||
message => "A text field for entering in city part of the address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_region' => {
|
||||
message => "A text field for entering in region, or state, part of the address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_zipCode' => {
|
||||
message => "A text field for entering in the zip code part of the address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_country' => {
|
||||
message => "A text field for entering in the country part of the address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_phone' => {
|
||||
message => "A text field for entering in a phone number.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_fax' => {
|
||||
message => "A text field for entering in a phone number.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'form_email' => {
|
||||
message => "A text field for entering in an email address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'storageIdPhoto' => {
|
||||
message => "The storage location for this MapPoint.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'website' => {
|
||||
message => "The website for this MapPoint.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'address1' => {
|
||||
message => "The first line of the address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'address2' => {
|
||||
message => "The second line of the address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'address3' => {
|
||||
message => "The third line of the address.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'city' => {
|
||||
message => "The city for this MapPoint.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'region' => {
|
||||
message => "The region, or state or province, for this MapPoint.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'zipCode' => {
|
||||
message => "The zip code for this MapPoint.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'country' => {
|
||||
message => "The country for this MapPoint.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'phone' => {
|
||||
message => "The phone number for this MapPoint.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'fax' => {
|
||||
message => "The fax number for this MapPoint.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'email' => {
|
||||
message => "The email address for this MapPoint.",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'map point asset template variables' => {
|
||||
message => "Map Point Asset Template Variables",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'latitude' => {
|
||||
message => "The latitude of the MapPoint",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
'longitude' => {
|
||||
message => "The longitude of the MapPoint",
|
||||
lastUpdated => 0,
|
||||
context => "template variable help",
|
||||
},
|
||||
|
||||
};
|
||||
|
||||
1;
|
||||
|
|
|
|||
|
|
@ -42,6 +42,18 @@ our $I18N = {
|
|||
context => q|Hover help for edit wobject screen|,
|
||||
},
|
||||
|
||||
'top level keywords' => {
|
||||
message => q|Top Level Keywords|,
|
||||
lastUpdated => 0,
|
||||
context => q|Label for edit wobject screen|,
|
||||
},
|
||||
|
||||
'top level keywords description' => {
|
||||
message => q|These keywords provide the root for the hierarchial keyword display.|,
|
||||
lastUpdated => 0,
|
||||
context => q|Hover help for edit wobject screen|,
|
||||
},
|
||||
|
||||
'content filter' => {
|
||||
message => q|Use Content Filter?|,
|
||||
lastUpdated => 0,
|
||||
|
|
@ -523,6 +535,43 @@ listing of pages that are related to a specific keyword?| },
|
|||
lastUpdated => 0,
|
||||
context => q{Label for link to unsubscribe from e-mail notifications},
|
||||
},
|
||||
|
||||
'keywords_loop' => {
|
||||
message => q{A loop containing all the top level keywords, links to their keyword pages, and all sub pages below them.},
|
||||
lastUpdated => 0,
|
||||
context => q{Help for template variable},
|
||||
},
|
||||
|
||||
'keyword title' => {
|
||||
message => q{The name of a keyword.},
|
||||
lastUpdated => 0,
|
||||
context => q{Help for template variable},
|
||||
},
|
||||
|
||||
'keyword url' => {
|
||||
message => q{The URL to the keyword page for that keyword. If no page exists, this variable will be empty.},
|
||||
lastUpdated => 0,
|
||||
context => q{Help for template variable},
|
||||
},
|
||||
|
||||
'keyword level' => {
|
||||
message => q{The depth of this keyword. Top-level keywords for the wiki are level 0.},
|
||||
lastUpdated => 0,
|
||||
context => q{Help for template variable},
|
||||
},
|
||||
|
||||
'indent_loop' => {
|
||||
message => q{A loop that runs 1 time for each level.},
|
||||
lastUpdated => 0,
|
||||
context => q{Help for template variable},
|
||||
},
|
||||
|
||||
'keyword indent' => {
|
||||
message => q{The loop iterator for the indent_loop.},
|
||||
lastUpdated => 0,
|
||||
context => q{Help for template variable},
|
||||
},
|
||||
|
||||
};
|
||||
|
||||
1;
|
||||
|
|
|
|||
|
|
@ -4680,6 +4680,12 @@ Users may override this setting in their profile.
|
|||
context => 'Message shown to the user when data is being loaded, typically via AJAX, like in the Survey.'
|
||||
},
|
||||
|
||||
'Go' => {
|
||||
message => 'Go',
|
||||
lastUpdated => 0,
|
||||
context => 'Label for buttons that take you someplace else'
|
||||
},
|
||||
|
||||
};
|
||||
|
||||
1;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue