package WebGUI::Asset::Sku::EMSTicket; =head1 LEGAL ------------------------------------------------------------------- WebGUI is Copyright 2001-2008 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::Asset::Sku'; use Tie::IxHash; use JSON; =head1 NAME Package WebGUI::Asset::Sku::EMSTicket =head1 DESCRIPTION A ticket for the Event Manager. Tickets allow you into invidivual events at a convention. =head1 SYNOPSIS use WebGUI::Asset::Sku::EMSTicket; =head1 METHODS These methods are available from this class: =cut #------------------------------------------------------------------- =head2 addToCart ( {badgeId=>$badgeId }) Does some bookkeeping to keep track of limited quantities of tickets that are available, then adds to cart. =cut sub addToCart { my ($self, $badgeInfo) = @_; my $db = $self->session->db; my @params = ($badgeInfo->{badgeId},$self->getId); # don't let them add a ticket they already have unless ($db->quickScalar("select count(*) from EMSRegistrantTicket where badgeId=? and ticketAssetId=?",\@params)) { $db->write("insert into EMSRegistrantTicket (badgeId, ticketAssetId) values (?,?)", \@params); $self->SUPER::addToCart($badgeInfo); } } #------------------------------------------------------------------- =head2 definition Adds price, seatsAvailable, eventNumber, startDate, endDate and relatedBadges fields. =cut sub definition { my $class = shift; my $session = shift; my $definition = shift; my %properties; tie %properties, 'Tie::IxHash'; my $i18n = WebGUI::International->new($session, "Asset_EventManagementSystem"); my $date = WebGUI::DateTime->new($session, time()); %properties = ( price => { tab => "shop", fieldType => "float", defaultValue => 0.00, label => $i18n->get("price"), hoverHelp => $i18n->get("price help"), }, seatsAvailable => { tab => "shop", fieldType => "integer", defaultValue => 25, label => $i18n->get("seats available"), hoverHelp => $i18n->get("seats available help"), }, eventNumber => { tab => "properties", fieldType => "integer", customDrawMethod=> 'drawEventNumberField', label => $i18n->get("event number"), hoverHelp => $i18n->get("event number help"), }, startDate => { tab => "properties", fieldType => "dateTime", defaultValue => $date->toDatabase, label => $i18n->get("event start date"), hoverHelp => $i18n->get("start date help"), }, duration => { tab => "properties", fieldType => "float", defaultValue => 1.0, subtext => $i18n->get('hours'), label => $i18n->get("duration"), hoverHelp => $i18n->get("duration help"), }, location => { fieldType => "combo", tab => "properties", customDrawMethod=> 'drawLocationField', label => $i18n->get("location"), hoverHelp => $i18n->get("location help"), }, relatedBadgeGroups => { tab => "properties", fieldType => "checkList", customDrawMethod=> 'drawRelatedBadgeGroupsField', label => $i18n->get("related badge groups"), hoverHelp => $i18n->get("related badge groups ticket help"), }, relatedRibbons => { tab => "properties", fieldType => "checkList", customDrawMethod=> 'drawRelatedRibbonsField', label => $i18n->get("related ribbons"), hoverHelp => $i18n->get("related ribbons help"), }, eventMetaData => { noFormPost => 1, fieldType => "hidden", defaultValue => '{}', }, ); push(@{$definition}, { assetName => $i18n->get('ems ticket'), icon => 'EMSTicket.gif', autoGenerateForms => 1, tableName => 'EMSTicket', className => 'WebGUI::Asset::Sku::EMSTicket', properties => \%properties }); 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, }); } #------------------------------------------------------------------- =head2 getConfiguredTitle Returns title + badgeholder name. =cut sub getConfiguredTitle { my $self = shift; my $name = $self->session->db->quickScalar("select name from EMSRegistrant where badgeId=?",[$self->getOptions->{badgeId}]); return $self->getTitle." (".$name.")"; } #------------------------------------------------------------------- =head2 getEditForm () Extended to support event metadata. =cut sub getEditForm { my $self = shift; my $form = $self->SUPER::getEditForm(@_); my $metadata = JSON->new->utf8->decode($self->get("eventMetaData") || '{}'); foreach my $field (@{$self->getParent->getEventMetaFields}) { $form->getTab("meta")->DynamicField( name => "eventmeta ".$field->{label}, value => $metadata->{$field->{label}}, defaultValue => $field->{defaultValues}, options => $field->{possibleValues}, fieldType => $field->{dataType}, label => $field->{label}, ); } return $form; } #------------------------------------------------------------------- =head2 getMaxAllowedInCart Returns 1. =cut sub getMaxAllowedInCart { return 1; } #------------------------------------------------------------------- =head2 getPrice Returns the value of the price field, after applying ribbon discounts. =cut sub getPrice { my $self = shift; my @ribbonIds = split("\n", $self->get('relatedRibbons')); my $price = $self->get("price"); my $discount = 0; my $badgeId = $self->getOptions->{badgeId}; my $ribbonId = $self->session->db->quickScalar("select ribbonAssetId from EMSRegistrantRibbon where badgeId=? limit 1",[$badgeId]); if (defined $ribbonId) { my $ribbon = WebGUI::Asset->new($self->session,$ribbonId,'WebGUI::Asset::Sku::EMSRibbon'); $discount = $ribbon->get('percentageDiscount'); } else { foreach my $item (@{$self->getCart->getItemsByAssetId(\@ribbonIds)}) { if ($item->get('options')->{badgeId} eq $badgeId) { my $ribbon = $item->getSku; $discount = $ribbon->get('percentageDiscount'); last; } } } $price -= ($price * $discount / 100); return $price; } #------------------------------------------------------------------- =head2 getQuantityAvailable Returns seatsAvailable minus the count from the EMSRegistrantTicket table. =cut sub getQuantityAvailable { my $self = shift; my $seatsTaken = $self->session->db->quickScalar("select count(*) from EMSRegistrantTicket where ticketAssetId=?",[$self->getId]); return $self->get("seatsAvailable") - $seatsTaken; } #------------------------------------------------------------------- =head2 indexContent ( ) Adding location and eventNumber as a keyword. See WebGUI::Asset::indexContent() for additonal details. =cut sub indexContent { my $self = shift; my $indexer = $self->SUPER::indexContent; $indexer->addKeywords($self->get('location').' '.$self->get('eventNumber')); return $indexer; } #------------------------------------------------------------------- =head2 onCompletePurchase Marks the ticket as purchased. =cut sub onCompletePurchase { my ($self, $item) = @_; $self->session->db->write("update EMSRegistrantTicket set purchaseComplete=1, transactionItemId=? where ticketAssetId=? and badgeId=?", [$item->getId, $self->getId, $self->getOptions->{badgeId}]); return undef; } #------------------------------------------------------------------- =head2 onRefund ( item) Destroys the ticket so that it can be resold. =cut sub onRefund { my ($self, $item) = @_; $self->session->db->write("delete from EMSRegistrantTicket where transactionItemId=?",[$item->getId]); return undef; } #------------------------------------------------------------------- =head2 onRemoveFromCart Frees up the ticket to be purchased by someone else. =cut sub onRemoveFromCart { my ($self, $item) = @_; $self->session->db->write("delete from EMSRegistrantTicket where ticketAssetId=? and badgeId=?", [$self->getId, $self->getOptions->{badgeId}]); } #------------------------------------------------------------------- =head2 processPropertiesFromFormPost ( ) Extended to support event meta fields. =cut sub processPropertiesFromFormPost { my $self = shift; $self->SUPER::processPropertiesFromFormPost(@_); my $form = $self->session->form; my %metadata = (); foreach my $field (@{$self->getParent->getEventMetaFields}) { $metadata{$field->{label}} = $form->process('eventmeta '.$field->{label}, $field->{dataType}, { defaultValue => $field->{defaultValues}, options => $field->{possibleValues}}); } $self->update({eventMetaData => JSON->new->utf8->encode(\%metadata)}); } #------------------------------------------------------------------- =head2 purge Deletes all ticket purchases of this type. No refunds are given. =cut sub purge { my $self = shift; $self->session->db->write("delete from EMSRegistrantTicket where ticketAssetId=?",[$self->getId]); $self->SUPER::purge; } #------------------------------------------------------------------- =head2 view Displays the ticket description. =cut sub view { my ($self) = @_; # build objects we'll need my $i18n = WebGUI::International->new($self->session, "Asset_EventManagementSystem"); my $form = $self->session->form; # render the page; my $output = '

'.$self->getTitle.' ('.$self->get('eventNumber').')

' .'

'.$self->get('description').'

' .'

'.$self->get('startDate').'

'; # build the add to cart form if ($form->get('badgeId') ne '') { my $addToCart = WebGUI::HTMLForm->new($self->session, action=>$self->getUrl); $addToCart->hidden(name=>"func", value=>"addToCart"); $addToCart->hidden(name=>"badgeId", value=>$form->get('badgeId')); $addToCart->submit(value=>$i18n->get('add to cart','Shop'), label=>$self->getPrice); $output .= $addToCart->print; } return $output; } #------------------------------------------------------------------- =head2 www_addToCart Takes form variable badgeId and add the ticket to the cart. =cut sub www_addToCart { my ($self) = @_; return $self->session->privilege->noAccess() unless $self->getParent->canView; my $badgeId = $self->session->form->get('badgeId'); $self->addToCart({badgeId=>$badgeId}); 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 () Displays the edit form. =cut sub www_edit { my ($self) = @_; return $self->session->privilege->insufficient() unless $self->canEdit; return $self->session->privilege->locked() unless $self->canEditIfLocked; $self->session->style->setRawHeadTags(q| |); my $i18n = WebGUI::International->new($self->session, "Asset_EventManagementSystem"); my $form = $self->getEditForm; $form->hidden({name=>'proceed', value=>'viewAll'}); return $self->processStyle('

'.$i18n->get('ems ticket').'

'.$form->print); } #------------------------------------------------------------------- =head2 www_viewAll () Displays the list of tickets in the parent. =cut sub www_viewAll { my $self = shift; return $self->getParent->www_buildBadge(undef,"tickets"); } 1;