package WebGUI::Widget::Poll; #------------------------------------------------------------------- # WebGUI is Copyright 2001 Plain Black Software. #------------------------------------------------------------------- # 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 WebGUI::Privilege; use WebGUI::Session; use WebGUI::SQL; use WebGUI::Utility; use WebGUI::Widget; #------------------------------------------------------------------- sub _viewPoll { my (%poll, $i, $output, $widgetId); $widgetId = shift; %poll = WebGUI::SQL->quickHash("select * from widget,Poll where widget.widgetId=Poll.widgetId and widget.widgetId='$widgetId'",$session{dbh}); if (defined %poll) { if ($poll{displayTitle} == 1) { $output = "

".$poll{title}."

"; } if ($poll{description} ne "") { $output .= $poll{description}.'

'; } $output .= '

'; $output .= WebGUI::Form::hidden('wid',$widgetId); $output .= WebGUI::Form::hidden('func','vote'); $output .= ''.$poll{question}.'
'; for ($i=1; $i<=20; $i++) { if ($poll{'a'.$i} =~ /\w/) { $output .= WebGUI::Form::radio("answer",'a'.$i).' '.$poll{'a'.$i}.'
'; } } $output .= '
'.WebGUI::Form::submit('Vote!'); $output .= '
'; } return $output; } #------------------------------------------------------------------- sub _viewResults { my (%poll, @data, $i, $output, $widgetId, $totalResponses); $widgetId = shift; %poll = WebGUI::SQL->quickHash("select * from widget,Poll where widget.widgetId=Poll.widgetId and widget.widgetId='$widgetId'",$session{dbh}); if (defined %poll) { if ($poll{displayTitle} == 1) { $output = "

".$poll{title}."

"; } if ($poll{description} ne "") { $output .= $poll{description}.'

'; } $output .= ''.$poll{question}.''; ($totalResponses) = WebGUI::SQL->quickArray("select count(*) from pollAnswer where widgetId=$widgetId",$session{dbh}); if ($totalResponses < 1) { $totalResponses = 1; } for ($i=1; $i<=20; $i++) { if ($poll{'a'.$i} =~ /\w/) { $output .= '


'.$poll{'a'.$i}.'
'; @data = WebGUI::SQL->quickArray("select count(*), answer from pollAnswer where answer='a$i' and widgetId=$widgetId group by answer",$session{dbh}); $output .= '
  '.round(100*$data[0]/$totalResponses).'%
'; } } } return $output; } #------------------------------------------------------------------- sub purge { WebGUI::SQL->write("delete from pollAnswer where widgetId=$_[0]",$_[1]); WebGUI::SQL->write("delete from Poll where widgetId=$_[0]",$_[1]); purgeWidget($_[0],$_[1]); } #------------------------------------------------------------------- sub widgetName { return "Poll"; } #------------------------------------------------------------------- sub www_add { my ($output, %hash); tie %hash, "Tie::IxHash"; if (WebGUI::Privilege::canEditPage()) { $output = '

Add Poll

'; $output .= WebGUI::Form::hidden("widget","Poll"); $output .= WebGUI::Form::hidden("func","addSave"); $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; %hash = WebGUI::SQL->buildHash("select groupId,groupName from groups where groupName<>'Reserved' order by groupName",$session{dbh}); $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= '
Title'.WebGUI::Form::text("title",20,30,'Poll').'
Display the title?'.WebGUI::Form::checkbox("displayTitle",1).'
Description'.WebGUI::Form::textArea("description",'').'
Active'.WebGUI::Form::checkbox("active",1,1).'
Who can vote?'.WebGUI::Form::selectList("voteGroup",\%hash,).'
Graph Width'.WebGUI::Form::text("graphWidth",20,3,150).'
Question'.WebGUI::Form::text("question",50,255).'
Answers
(Enter one answer per line. No more than 20.)
'.WebGUI::Form::textArea("answers",'',50,8,0,'on').'
'.WebGUI::Form::submit("save").'
'; return $output; } else { return WebGUI::Privilege::insufficient(); } return $output; } #------------------------------------------------------------------- sub www_addSave { my ($widgetId, @answer); if (WebGUI::Privilege::canEditPage()) { $widgetId = create(); @answer = split("\n",$session{form}{answers}); WebGUI::SQL->write("insert into Poll set widgetId=$widgetId, active='$session{form}{active}', voteGroup='$session{form}{voteGroup}', graphWidth='$session{form}{graphWidth}', question=".quote($session{form}{question}).", a1=".quote($answer[0]).", a2=".quote($answer[1]).", a3=".quote($answer[2]).", a4=".quote($answer[3]).", a5=".quote($answer[4]).", a6=".quote($answer[5]).", a7=".quote($answer[6]).", a8=".quote($answer[7]).", a9=".quote($answer[8]).", a10=".quote($answer[9]).", a11=".quote($answer[10]).", a12=".quote($answer[11]).", a13=".quote($answer[12]).", a14=".quote($answer[13]).", a15=".quote($answer[14]).", a16=".quote($answer[15]).", a17=".quote($answer[16]).", a18=".quote($answer[17]).", a19=".quote($answer[18]).", a20=".quote($answer[19])."",$session{dbh}); return ""; } else { return WebGUI::Privilege::insufficient(); } } #------------------------------------------------------------------- sub www_edit { my ($output, %data, %hash, @array); tie %hash, "Tie::IxHash"; if (WebGUI::Privilege::canEditPage()) { %data = WebGUI::SQL->quickHash("select * from widget,Poll where widget.widgetId=Poll.widgetId and widget.widgetId=$session{form}{wid}",$session{dbh}); $output = '

Edit Poll

'; $output .= WebGUI::Form::hidden("wid",$session{form}{wid}); $output .= WebGUI::Form::hidden("func","editSave"); $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; %hash = WebGUI::SQL->buildHash("select groupId,groupName from groups where groupName<>'Reserved' order by groupName",$session{dbh}); $array[0] = $data{voteGroup}; $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= '
Title'.WebGUI::Form::text("title",20,30,$data{title}).'
Display the title?'.WebGUI::Form::checkbox("displayTitle",1,$data{displayTitle}).'
Description'.WebGUI::Form::textArea("description",$data{description}).'
Active'.WebGUI::Form::checkbox("active",1,$data{active}).'
Who can vote?'.WebGUI::Form::selectList("voteGroup",\%hash,\@array).'
Graph Width'.WebGUI::Form::text("graphWidth",20,3,$data{graphWidth}).'
Question'.WebGUI::Form::text("question",50,255,$data{question}).'
Answers
(Enter one answer per line. No more than 20.)
'.WebGUI::Form::textArea("answers",$data{a1}."\n".$data{a2}."\n".$data{a3}."\n".$data{a4}."\n".$data{a5}."\n".$data{a6}."\n".$data{a7}."\n".$data{a8}."\n".$data{a9}."\n".$data{a10}."\n".$data{a11}."\n".$data{a12}."\n".$data{a13}."\n".$data{a14}."\n".$data{a15}."\n".$data{a16}."\n".$data{a17}."\n".$data{a18}."\n".$data{a19}."\n".$data{a20}."\n",50,8,0,'on').'
'.WebGUI::Form::submit("save").'
'; return $output; } else { return WebGUI::Privilege::insufficient(); } } #------------------------------------------------------------------- sub www_editSave { my (@answer); if (WebGUI::Privilege::canEditPage()) { update(); @answer = split("\n",$session{form}{answers}); WebGUI::SQL->write("update Poll set active='$session{form}{active}', voteGroup='$session{form}{voteGroup}', graphWidth=$session{form}{graphWidth}, question=".quote($session{form}{question}).", a1=".quote($answer[0]).", a2=".quote($answer[1]).", a3=".quote($answer[2]).", a4=".quote($answer[3]).", a5=".quote($answer[4]).", a6=".quote($answer[5]).", a7=".quote($answer[6]).", a8=".quote($answer[7]).", a9=".quote($answer[8]).", a10=".quote($answer[9]).", a11=".quote($answer[10]).", a12=".quote($answer[11]).", a13=".quote($answer[12]).", a14=".quote($answer[13]).", a15=".quote($answer[14]).", a16=".quote($answer[15]).", a17=".quote($answer[16]).", a18=".quote($answer[17]).", a19=".quote($answer[18]).", a20=".quote($answer[19])." where widgetId=$session{form}{wid}",$session{dbh}); return ""; } else { return WebGUI::Privilege::insufficient(); } } #------------------------------------------------------------------- sub www_view { my ($hasVoted, %data, $output); %data = WebGUI::SQL->quickHash("select * from widget,Poll where widget.widgetId=Poll.widgetId and widget.widgetId='$_[0]'",$session{dbh}); if ($data{active} eq "0") { $output = _viewResults($_[0]); } elsif (WebGUI::Privilege::isInGroup($data{voteGroup},$session{user}{userId})) { ($hasVoted) = WebGUI::SQL->quickArray("select count(*) from pollAnswer where (userId=$session{user}{userId} or (userId=1 and ipAddress<>'$session{env}{REMOTE_ADDR}')) and widgetId=$_[0]",$session{dbh}); unless (WebGUI::Privilege::isInGroup($data{voteGroup},$session{user}{userId})) { $hasVoted = 1; } if ($hasVoted) { $output = _viewResults($_[0]); } else { $output = _viewPoll($_[0]); } } else { $output = _viewResults($_[0]); } return $output; } #------------------------------------------------------------------- sub www_vote { my ($voteGroup); ($voteGroup) = WebGUI::SQL->quickArray("select voteGroup from Poll where widgetId='$session{form}{wid}'",$session{dbh}); if (WebGUI::Privilege::isInGroup($voteGroup,$session{user}{userId})) { WebGUI::SQL->write("insert into pollAnswer set widgetId=$session{form}{wid}, userId=$session{user}{userId}, answer='$session{form}{answer}', ipAddress='$session{env}{REMOTE_ADDR}'",$session{dbh}); } return ""; } 1;