\n"
@head.sort.each{|columntitle,columndescription|
klasse = poll[columntitle]
case klasse
when nil
value = UNKNOWN
klasse = "undecided"
when YESVAL
value = YES
when NOVAL
value = NO
when MAYBEVAL
value = MAYBE
end
ret += "
#{value}
\n"
}
ret += "
#{poll['timestamp'].strftime('%d.%m, %H:%M')}
"
ret += "
\n"
end
}
# PARTICIPATE
ret += participate_to_html(edituser, config) unless @data.keys.include?(edituser)
# SUMMARY
ret += "
total
\n"
@head.sort.each{|columntitle,columndescription|
yes = 0
undecided = 0
@data.each_value{|participant|
if participant[columntitle] == YESVAL
yes += 1
elsif !participant.has_key?(columntitle) or participant[columntitle] == MAYBEVAL
undecided += 1
end
}
if @data.empty?
percent_f = 0
else
percent_f = 100*yes/@data.size
end
percent = "#{percent_f}%" unless @data.empty?
if undecided > 0
percent += "-#{(100.0*(undecided+yes)/@data.size).round}%"
end
ret += "
#{yes}
\n"
}
ret += "
"
ret += "
\n"
ret
end
def participate_to_html(edituser, config)
checked = {}
if @data.include?(edituser)
@head.each_key{|k| checked[k] = @data[edituser][k]}
else
@head.each_key{|k| checked[k] = NOVAL}
end
ret = "
\n"
ret += "
"
ret += "
\n"
unless config
@head.sort.each{|columntitle,columndescription|
ret += "
"
[[YES, YESVAL],[NO, NOVAL],[MAYBE, MAYBEVAL]].each{|valhuman, valbinary|
ret += "
"
}
ret += "
"
}
ret += "
"
else
ret += "
"
end
if @data.include?(edituser)
ret += ""
ret += " "
else
ret += ""
end
ret += "
\n"
ret += "
\n"
ret
end
def comment_to_html
ret = "
"
ret += "
Comments
"
unless @comment.empty?
@comment.each_with_index{|c,i|
time,name,comment = c
ret += <
COMMENT
}
end
# ADD COMMENT
ret += <
ADDCOMMENT
ret += "
\n"
ret
end
def history_to_html
ret = ""
maxrev=VCS.revno
revision= defined?(REVISION) ? REVISION : maxrev
log = VCS.history
log.shift
log.collect!{|s| s.scan(/\nrevno:.*\ncommitter.*\n.*\ntimestamp: (.*)\nmessage:\n (.*)/).flatten}
log.collect!{|t,c| [Time.parse(t),c]}
((revision-2)..(revision+2)).each do |i|
if i >0 && i<=maxrev
ret += " "
ret += "" if revision != i
ret += "#{i}"
ret += "" if revision != i
end
end
ret += " last" if defined?(REVISION)
ret
end
def add_participant(olduser, name, agreed)
name.strip!
if name == ""
maximum = @data.keys.collect{|e| e.scan(/^Anonymous #(\d*)/).flatten[0]}.compact.collect{|i| i.to_i}.max
maximum ||= 0
name = "Anonymous ##{maximum + 1}"
end
htmlname = CGI.escapeHTML(name)
@data.delete(CGI.escapeHTML(olduser))
@data[htmlname] = {"timestamp" => Time.now }
@head.each_key{|columntitle|
@data[htmlname][columntitle] = agreed[columntitle.to_s]
}
store "Participant #{name.strip} edited"
end
def delete(name)
htmlname = CGI.escapeHTML(name.strip)
if @data.has_key?(htmlname)
@data.delete(htmlname)
store "Participant #{name.strip} deleted"
end
end
def store comment
File.open("data.yaml", 'w') do |out|
out << "# This is a dudle poll file\n"
out << self.to_yaml
out.chmod(0660)
end
VCS.commit(CGI.escapeHTML(comment))
end
###############################
# comment related functions
###############################
def add_comment name, comment
@comment << [Time.now, CGI.escapeHTML(name.strip), CGI.escapeHTML(comment.strip).gsub("\r\n"," ")]
store "Comment added by #{name}"
end
def delete_comment index
store "Comment from #{@comment.delete_at(index)[1]} deleted"
end
###############################
# column related functions
###############################
def parsecolumntitle title
title.strip
end
def delete_column title
parsedtitle = parsecolumntitle(title)
if @head.include?(parsedtitle)
@head.delete(parsedtitle)
store "Column #{parsedtitle} deleted"
return true
else
return false
end
end
def edit_column(newtitle, description, oldtitle = nil)
@head.delete(oldtitle) if oldtitle
parsedtitle = parsecolumntitle(newtitle)
@head[parsedtitle] = CGI.escapeHTML(description.strip)
store "Column #{parsedtitle} edited"
true
end
def edit_column_htmlform(activecolumn)
if activecolumn
title = activecolumn
description = @head[title]
title = CGI.escapeHTML(title)
end
return <
END
end
end
Comments
" unless @comment.empty? @comment.each_with_index{|c,i| time,name,comment = c ret += <