diff --git a/docs/upgrades/upgrade_7.5.2-7.5.3.pl b/docs/upgrades/upgrade_7.5.2-7.5.3.pl index c0b7049a7..c4d199aea 100644 --- a/docs/upgrades/upgrade_7.5.2-7.5.3.pl +++ b/docs/upgrades/upgrade_7.5.2-7.5.3.pl @@ -116,6 +116,12 @@ sub upgradeEMS { ribbonAssetId varchar(22) binary not null, primary key (badgeId,ribbonAssetId) )"); + $db->write("create table EMSBadgeGroup ( + badgeGroupId varchar(22) binary not null primary key, + emsAssetId varchar(22) binary not null, + name varchar(100), + badgeList text + )"); $db->write("create table EMSBadge ( assetId varchar(22) binary not null, revisionDate bigint not null, @@ -132,7 +138,8 @@ sub upgradeEMS { duration float not null default 1.0, eventNumber int, location varchar(100), - relatedBadges mediumtext, + relatedBadgeGroups mediumtext, + relatedRibbons mediumtext, primary key (assetId, revisionDate) )"); $db->write("create table EMSToken ( @@ -144,6 +151,7 @@ sub upgradeEMS { $db->write("create table EMSRibbon ( assetId varchar(22) binary not null, revisionDate bigint not null, + percentageDiscount float not null default 10.0, price float not null default 0.00, primary key (assetId, revisionDate) )"); diff --git a/lib/WebGUI/Asset.pm b/lib/WebGUI/Asset.pm index c2fa15c66..ce5b59132 100644 --- a/lib/WebGUI/Asset.pm +++ b/lib/WebGUI/Asset.pm @@ -2325,6 +2325,7 @@ sub www_add { } my %properties = ( %prototypeProperties, + parentId => $self->getId, groupIdView => $self->get("groupIdView"), groupIdEdit => $self->get("groupIdEdit"), ownerUserId => $self->get("ownerUserId"), diff --git a/lib/WebGUI/Asset/Sku/EMSRibbon.pm b/lib/WebGUI/Asset/Sku/EMSRibbon.pm index 03964f974..0f433f710 100644 --- a/lib/WebGUI/Asset/Sku/EMSRibbon.pm +++ b/lib/WebGUI/Asset/Sku/EMSRibbon.pm @@ -63,6 +63,13 @@ sub definition { label => $i18n->get("price"), hoverHelp => $i18n->get("price help"), }, + percentageDiscount => { + tab => "shop", + fieldType => "float", + defaultValue => 10.0, + label => $i18n->get("percentage discount"), + hoverHelp => $i18n->get("percentage discount help"), + }, ); push(@{$definition}, { assetName => $i18n->get('ems ribbon'), @@ -192,6 +199,21 @@ sub www_addToCart { return $self->getParent->www_buildBadge($badgeId); } +#------------------------------------------------------------------- + +=head2 www_delete + +Override to return to appropriate page. + +=cut + +sub www_delete { + my ($self) = @_; + $self->SUPER::www_delete; + return $self->getParent->www_buildBadge(undef,'ribbons'); +} + + #------------------------------------------------------------------- =head2 www_edit () diff --git a/lib/WebGUI/Asset/Sku/EMSTicket.pm b/lib/WebGUI/Asset/Sku/EMSTicket.pm index 9231fd6a4..a07f51e3c 100644 --- a/lib/WebGUI/Asset/Sku/EMSTicket.pm +++ b/lib/WebGUI/Asset/Sku/EMSTicket.pm @@ -19,7 +19,6 @@ use Tie::IxHash; use base 'WebGUI::Asset::Sku'; - =head1 NAME Package WebGUI::Asset::Sku::EMSTicket @@ -86,8 +85,8 @@ sub definition { }, eventNumber => { tab => "properties", - fieldType => "integer", - defaultValue => $session->db->quickScalar("select max(eventNumber)+1 from EMSTicket"), + fieldType => "integer", + customDrawMethod=> 'drawEventNumberField', label => $i18n->get("event number"), hoverHelp => $i18n->get("event number help"), }, @@ -107,19 +106,25 @@ sub definition { hoverHelp => $i18n->get("duration help"), }, location => { + fieldType => "combo", tab => "properties", - fieldType => "combo", - options => $session->db->buildHashRef("select distinct(location) from EMSTicket order by location"), + customDrawMethod=> 'drawLocationField', label => $i18n->get("location"), hoverHelp => $i18n->get("location help"), }, - relatedBadges => { + relatedBadgeGroups => { tab => "properties", - fieldType => "checkList", - options => {}, - defaultValue => undef, - label => $i18n->get("related badges"), - hoverHelp => $i18n->get("related badges help"), + fieldType => "checkList", + customDrawMethod=> 'drawRelatedBadgeGroupsField', + label => $i18n->get("related badge groups"), + hoverHelp => $i18n->get("related badge groups help"), + }, + relatedRibbons => { + tab => "properties", + fieldType => "checkList", + customDrawMethod=> 'drawRelatedRibbonsField', + label => $i18n->get("related ribbons"), + hoverHelp => $i18n->get("related ribbons help"), }, ); push(@{$definition}, { @@ -133,6 +138,83 @@ sub definition { return $class->SUPER::definition($session, $definition); } +#------------------------------------------------------------------- + +=head2 drawEventNumberField () + +Draws the field for the eventNumber property. + +=cut + +sub drawEventNumberField { + my ($self, $params) = @_; + my $default = $self->session->db->quickScalar("select max(eventNumber)+1 from EMSTicket left join asset using (assetId) + where parentId=?",[$self->get('parentId')]); + return WebGUI::Form::integer($self->session, { + name => $params->{name}, + value => $self->get($params->{name}), + defaultValue => $default, + }); +} + +#------------------------------------------------------------------- + +=head2 drawLocationField () + +Draws the field for the location property. + +=cut + +sub drawLocationField { + my ($self, $params) = @_; + my $options = $self->session->db->buildHashRef("select distinct(location) from EMSTicket left join asset using (assetId) + where parentId=? order by location",[$self->get('parentId')]); + return WebGUI::Form::combo($self->session, { + name => $params->{name}, + value => $self->get($params->{name}), + options => $options, + }); +} + +#------------------------------------------------------------------- + +=head2 drawRelatedBadgeGroupsField () + +Draws the field for the relatedBadgeGroups property. + +=cut + +sub drawRelatedBadgeGroupsField { + my ($self, $params) = @_; + return WebGUI::Form::checkList($self->session, { + name => $params->{name}, + value => $self->get($params->{name}), + vertical => 1, + options => $self->getParent->getBadgeGroups, + }); +} + +#------------------------------------------------------------------- + +=head2 drawRelatedRibbonsField () + +Draws the field for the relatedRibbons property. + +=cut + +sub drawRelatedRibbonsField { + my ($self, $params) = @_; + my %ribbons = (); + foreach my $ribbon (@{$self->getParent->getRibbons}) { + $ribbons{$ribbon->getId} = $ribbon->getTitle; + } + return WebGUI::Form::checkList($self->session, { + name => $params->{name}, + value => $self->get($params->{name}), + vertical => 1, + options => \%ribbons, + }); +} #------------------------------------------------------------------- @@ -164,13 +246,20 @@ sub getMaxAllowedInCart { =head2 getPrice -Returns the value of the price field +Returns the value of the price field, after applying ribbon discounts. =cut sub getPrice { my $self = shift; - return $self->get("price"); + my @ribbonIds = split("\n", $self->get('relatedRibbons')); + my $price = $self->get("price"); + foreach my $item (@{$self->getCart->getItemsByAssetId(\@ribbonIds)}) { + my $ribbon = $item->getSku; + $price -= ($price * $ribbon->get('percentageDiscount') / 100); + last; + } + return $price; } #------------------------------------------------------------------- @@ -296,6 +385,21 @@ sub www_addToCart { return $self->getParent->www_buildBadge($badgeId); } +#------------------------------------------------------------------- + +=head2 www_delete + +Override to return to appropriate page. + +=cut + +sub www_delete { + my ($self) = @_; + $self->SUPER::www_delete; + return $self->getParent->www_buildBadge(undef,'tickets'); +} + + #------------------------------------------------------------------- =head2 www_edit () diff --git a/lib/WebGUI/Asset/Sku/EMSToken.pm b/lib/WebGUI/Asset/Sku/EMSToken.pm index 9be3b2c08..8a32f1907 100644 --- a/lib/WebGUI/Asset/Sku/EMSToken.pm +++ b/lib/WebGUI/Asset/Sku/EMSToken.pm @@ -189,6 +189,21 @@ sub www_addToCart { return $self->getParent->www_buildBadge($badgeId); } +#------------------------------------------------------------------- + +=head2 www_delete + +Override to return to appropriate page. + +=cut + +sub www_delete { + my ($self) = @_; + $self->SUPER::www_delete; + return $self->getParent->www_buildBadge(undef,'tokens'); +} + + #------------------------------------------------------------------- =head2 www_edit () diff --git a/lib/WebGUI/Asset/Wobject/EventManagementSystem.pm b/lib/WebGUI/Asset/Wobject/EventManagementSystem.pm index 9a676b638..6dc944b6d 100644 --- a/lib/WebGUI/Asset/Wobject/EventManagementSystem.pm +++ b/lib/WebGUI/Asset/Wobject/EventManagementSystem.pm @@ -109,6 +109,71 @@ sub definition { #------------------------------------------------------------------- +=head2 getBadges () + +Returns an array reference of badge objects. + +=cut + +sub getBadges { + my $self = shift; + return $self->getLineage(['children'],{returnObjects=>1, includeOnlyClasses=>['WebGUI::Asset::Sku::EMSBadge']}); +} + +#------------------------------------------------------------------- + +=head2 getBadgeGroups () + +Returns a hash reference of id,name pairs of badge groups. + +=cut + +sub getBadgeGroups { + my $self = shift; + return $self->session->db->buildHashRef("select badgeGroupId,name from EMSBadgeGroup where emsAssetId=?",[$self->getId]); +} + +#------------------------------------------------------------------- + +=head2 getRibbons () + +Returns an array reference of ribbon objects. + +=cut + +sub getRibbons { + my $self = shift; + return $self->getLineage(['children'],{returnObjects=>1, includeOnlyClasses=>['WebGUI::Asset::Sku::EMSRibbon']}); +} + +#------------------------------------------------------------------- + +=head2 getTickets () + +Returns an array reference of ticket objects. + +=cut + +sub getTickets { + my $self = shift; + return $self->getLineage(['children'],{returnObjects=>1, includeOnlyClasses=>['WebGUI::Asset::Sku::EMSTicket']}); +} + +#------------------------------------------------------------------- + +=head2 getTokens () + +Returns an array reference of badge objects. + +=cut + +sub getTokens { + my $self = shift; + return $self->getLineage(['children'],{returnObjects=>1, includeOnlyClasses=>['WebGUI::Asset::Sku::EMSToken']}); +} + +#------------------------------------------------------------------- + =head2 prepareView ( ) See WebGUI::Asset::prepareView() for details. @@ -181,9 +246,12 @@ sub view { my $output = q|
+ Add a badge • View Events - • View Cart
+ • View Cart + • Badge Groups +|.$self->get('badgeInstructions').q|
@@ -394,7 +462,6 @@ sub www_buildBadge { }); } $var{otherBadgesInCart} = \@otherBadges; - #return JSON->new->pretty->encode(\@otherBadges); # render return $self->processStyle($self->processTemplate(\%var,$self->get('badgeBuilderTemplateId'))); @@ -410,6 +477,8 @@ Deletes a badge group. sub www_deleteBadgeGroup { my $self = shift; + return $self->session->privilege->insufficient() unless $self->canEdit; + $self->session->db->deleteRow("EMSBadgeGroup","badgeGroupId",$self->session->form->get("badgeGroupId")); return $self->www_manageBadgeGroups; } @@ -424,29 +493,33 @@ Displays an edit screen for a badge group. sub www_editBadgeGroup { my $self = shift; + return $self->session->privilege->insufficient() unless $self->canEdit; my ($form, $db) = $self->session->quick(qw(form db)); my $f = WebGUI::HTMLForm->new($self->session, action=>$self->getUrl); my $badgeGroup = $db->getRow("EMSBadgeGroup","badgeGroupId",$form->get('badgeGroupId')); + $badgeGroup->{badgeList} = ($badgeGroup->{badgeList} ne "") ? JSON::decode_json($badgeGroup->{badgeList}) : []; my $i18n = WebGUI::International->new($self->session, "Asset_EventManagementSystem"); $f->hidden(name=>'func', value=>'editBadgeGroupSave'); $f->hidden(name=>'badgeGroupId', value=>$form->get('badgeGroupId')); $f->text( name => 'name', value => $badgeGroup->{name}, - label =>, - hoverHelp =>, + label => $i18n->get('badge group name'), + hoverHelp => $i18n->get('badge group name help'), ); $f->checkList( name => 'badgeList', - value => JSON::decode_json($badgeGroup->{badgeList}), + value => $badgeGroup->{badgeList}, options => $db->buildHashRef("select asset.assetId,assetData.title from asset left join assetData using (assetId) where asset.parentId=? and assetData.revisionDate= - (SELECT max(revisionDate) from assetData where assetData.assetId=asset.assetId)", - [$self->getId]), - label => , - hoverHelp =>, - ); - return $self->processStyle($f->print); + (SELECT max(revisionDate) from assetData where assetData.assetId=asset.assetId) + and asset.className='WebGUI::Asset::Sku::EMSBadge'", [$self->getId]), + vertical => 1, + label => $i18n->get('badge list'), + hoverHelp => $i18n->get('badge list help'), + ); + $f->submit; + return $self->processStyle('|.$i18n->get('add a badge group').q| + • |.$i18n->get('view badges').q| + • |.$i18n->get('view tickets').q| +
|; + my $groups = $session->db->read("select badgeGroupId,name from EMSBadgeGroup where emsAssetId=?",[$self->getId]); + my $badgeGroups = $self->getBadgeGroups; + foreach my $id (keys %{$badgeGroups}) { + $output .= q|