package WebGUI::Wobject::Poll; #------------------------------------------------------------------- # WebGUI is Copyright 2001-2003 Plain Black LLC. #------------------------------------------------------------------- # 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 #------------------------------------------------------------------- use strict; use Tie::CPHash; use WebGUI::Form; use WebGUI::HTMLForm; use WebGUI::Icon; use WebGUI::International; use WebGUI::Privilege; use WebGUI::Session; use WebGUI::SQL; use WebGUI::URL; use WebGUI::User; use WebGUI::Utility; use WebGUI::Wobject; our @ISA = qw(WebGUI::Wobject); #------------------------------------------------------------------- sub _hasVoted { my ($hasVoted) = WebGUI::SQL->quickArray("select count(*) from Poll_answer where wobjectId=".$_[0]->get("wobjectId")." and ((userId=$session{user}{userId} and userId<>1) or (userId=1 and ipAddress='$session{env}{REMOTE_ADDR}'))"); return $hasVoted; } #------------------------------------------------------------------- sub duplicate { my ($w, $f, $sth, @row); $w = $_[0]->SUPER::duplicate($_[1]); $sth = WebGUI::SQL->read("select * from Poll_answer where wobjectId=".$_[0]->get("wobjectId")); while (@row = $sth->array) { WebGUI::SQL->write("insert into Poll_answer values (".$w.", '$row[1]', $row[2], '$row[3]')"); } $sth->finish; } #------------------------------------------------------------------- sub name { return WebGUI::International::get(1,$_[0]->get("namespace")); } #------------------------------------------------------------------- sub new { my $class = shift; my $property = shift; my $self = WebGUI::Wobject->new( -properties=>$property, -extendedProperties=>{ active=>{ defaultValue=>1 }, karmaPerVote=>{ defaultValue=>0 }, graphWidth=>{ defaultValue=>150 }, voteGroup=>{ defaultValue=>7 }, question=>{}, randomizeAnswers=>{ defaultValue=>1, fieldType=>"yesNo" }, a1=>{}, a2=>{}, a3=>{}, a4=>{}, a5=>{}, a6=>{}, a7=>{}, a8=>{}, a9=>{}, a10=>{}, a11=>{}, a12=>{}, a13=>{}, a14=>{}, a15=>{}, a16=>{}, a17=>{}, a18=>{}, a19=>{}, a20=>{} }, -useTemplate=>1 ); bless $self, $class; } #------------------------------------------------------------------- sub purge { WebGUI::SQL->write("delete from Poll_answer where wobjectId=".$_[0]->get("wobjectId")); $_[0]->SUPER::purge(); } #------------------------------------------------------------------- sub www_edit { my ($i, $answers); for ($i=1; $i<=20; $i++) { if ($_[0]->get('a'.$i) =~ /\C/) { $answers .= $_[0]->getValue("a".$i)."\n"; } } my $privileges = WebGUI::HTMLForm->new; my $layout = WebGUI::HTMLForm->new; my $properties = WebGUI::HTMLForm->new; $privileges->yesNo( -name=>"active", -label=>WebGUI::International::get(3,$_[0]->get("namespace")), -value=>$_[0]->getValue("active") ); $privileges->group( -name=>"voteGroup", -label=>WebGUI::International::get(4,$_[0]->get("namespace")), -value=>[$_[0]->getValue("voteGroup")] ); if ($session{setting}{useKarma}) { $properties->integer( -name=>"karmaPerVote", -label=>WebGUI::International::get(20,$_[0]->get("namespace")), -value=>$_[0]->getValue("karmaPerVote") ); } else { $properties->hidden("karmaPerVote",$_[0]->getValue("karmaPerVote")); } $layout->integer( -name=>"graphWidth", -label=>WebGUI::International::get(5,$_[0]->get("namespace")), -value=>$_[0]->getValue("graphWidth") ); $properties->text( -name=>"question", -label=>WebGUI::International::get(6,$_[0]->get("namespace")), -value=>$_[0]->getValue("question") ); $properties->textarea( -name=>"answers", -label=>WebGUI::International::get(7,$_[0]->get("namespace")), -subtext=>('
'.WebGUI::International::get(8,$_[0]->get("namespace")).'
'), -value=>$answers ); $layout->yesNo( -name=>"randomizeAnswers", -label=>WebGUI::International::get(72,$_[0]->get("namespace")), -value=>$_[0]->getValue("randomizeAnswers") ); my $output = $_[0]->SUPER::www_edit( -layout=>$layout->printRowsOnly, -properties=>$properties->printRowsOnly, -privileges=>$privileges->printRowsOnly, -headingId=>9, -helpId=>1 ); if ($_[0]->get("wobjectId") ne "new") { $output .= '

'; $output .= '' .WebGUI::International::get(10,$_[0]->get("namespace")).''; } return $output; } #------------------------------------------------------------------- sub www_editSave { my (@answer, $i, $property); @answer = split("\n",$session{form}{answers}); for ($i=1; $i<=20; $i++) { $property->{'a'.$i} = $answer[($i-1)]; } return $_[0]->SUPER::www_editSave($property); } #------------------------------------------------------------------- sub www_resetVotes { return WebGUI::Privilege::insufficient() unless (WebGUI::Privilege::canEditWobject($_[0]->get("wobjectId"))); $_[0]->deleteCollateral("Poll_answer","wobjectId",$_[0]->get("wobjectId")); return ""; } #------------------------------------------------------------------- sub www_view { my (%var, $answer, @answers, $showPoll, $f); $var{question} = $_[0]->get("question"); if ($_[0]->get("active") eq "0") { $showPoll = 0; } elsif (WebGUI::Privilege::isInGroup($_[0]->get("voteGroup"),$session{user}{userId})) { if ($_[0]->_hasVoted()) { $showPoll = 0; } else { $showPoll = 1; } } else { $showPoll = 0; } $var{canVote} = $showPoll; my ($totalResponses) = WebGUI::SQL->quickArray("select count(*) from Poll_answer where wobjectId=" .$_[0]->get("wobjectId")); $var{"responses.label"} = WebGUI::International::get(12,$_[0]->get("namespace")); $var{"responses.total"} = $totalResponses; $var{"form.start"} = WebGUI::Form::formHeader(); $var{"form.start"} .= WebGUI::Form::hidden({name=>'wid',value=>$_[0]->get("wobjectId")}); $var{"form.start"} .= WebGUI::Form::hidden({name=>'func',value=>'vote'}); $var{"form.submit"} = WebGUI::Form::submit({value=>WebGUI::International::get(11,$_[0]->get("namespace"))}); $var{"form.end"} = ""; $totalResponses = 1 if ($totalResponses < 1); for (my $i=1; $i<=20; $i++) { if ($_[0]->get('a'.$i) =~ /\C/) { my ($tally) = WebGUI::SQL->quickArray("select count(*) from Poll_answer where answer='a" .$i."' and wobjectId=".$_[0]->get("wobjectId")." group by answer"); push(@answers,{ "answer.form"=>WebGUI::Form::radio({name=>"answer",value=>"a".$i}), "answer.text"=>$_[0]->get('a'.$i), "answer.graphWidth"=>round($_[0]->get("graphWidth")*$tally/$totalResponses), "answer.number"=>$i, "answer.percent"=>round(100*$tally/$totalResponses), "answer.total"=>($tally+0) }); } } randomizeArray(\@answers) if ($_[0]->get("randomizeAnswers")); $var{answer_loop} = \@answers; return $_[0]->processTemplate($_[0]->get("templateId"),\%var); } #------------------------------------------------------------------- sub www_vote { my $u; if ($session{form}{answer} ne "" && WebGUI::Privilege::isInGroup($_[0]->get("voteGroup"),$session{user}{userId}) && !($_[0]->_hasVoted())) { WebGUI::SQL->write("insert into Poll_answer values (".$_[0]->get("wobjectId").", '$session{form}{answer}', $session{user}{userId}, '$session{env}{REMOTE_ADDR}')"); if ($session{setting}{useKarma}) { $u = WebGUI::User->new($session{user}{userId}); $u->karma($_[0]->get("karmaPerVote"),$_[0]->get("namespace")." (".$_[0]->get("wobjectId").")","Voted on this poll."); } } return ""; } 1;