From df80810456f4a13d48eba24bfa1fa79b360c8426 Mon Sep 17 00:00:00 2001 From: Ted Trask Date: Thu, 2 Feb 2012 20:59:08 +0000 Subject: Changed viewfunctions.lua to htmlviewfunctions.lua and made it an actual module It should have been a module all along, but wasn't Unfortunately, this means changes to pretty much every view file --- lib/viewfunctions.lua | 370 -------------------------------------------------- 1 file changed, 370 deletions(-) delete mode 100644 lib/viewfunctions.lua (limited to 'lib/viewfunctions.lua') diff --git a/lib/viewfunctions.lua b/lib/viewfunctions.lua deleted file mode 100644 index e447fc3..0000000 --- a/lib/viewfunctions.lua +++ /dev/null @@ -1,370 +0,0 @@ -html = require("acf.html") -require("session") - -function getlabel(myitem, value) - if myitem and (myitem.type == "select" or myitem.type == "multi") then - for x,val in ipairs(myitem.option) do - local v,l - if type(val) == "string" then - v = val - l = val - else - v = val.value - l = val.label - end - if v == value then - return l - end - end - end - return tostring(value) -end - -function displayitemcustom(myitem, header_level) - if not myitem then return end - if myitem.type == "group" then - header_level = header_level or 2 - io.write(""..html.html_escape(myitem.label).."") - if myitem.descr then io.write('

' .. string.gsub(html.html_escape(myitem.descr), "\n", "
") .. "

\n") end - if myitem.errtxt then io.write('

' .. string.gsub(html.html_escape(myitem.errtxt), "\n", "
") .. "

\n") end - local seqorder = {} - local order = {} - for name,item in pairs(myitem.value) do - if tonumber(item.seq) then - seqorder[#seqorder+1] = {seq=tonumber(item.seq), name=name} - else - order[#order+1] = name - end - end - table.sort(seqorder, function(a,b) if a.seq ~= b.seq then return a.seq > b.seq else return a.name > b.name end end) - table.sort(order) - for i,val in ipairs(seqorder) do - table.insert(order, 1, val.name) - end - for x,name in ipairs(order) do - if myitem.value[name] then - displayitemcustom(myitem.value[name], tonumber(header_level)+1) - end - end - elseif myitem.type ~= "hidden" then - io.write("" .. html.html_escape(myitem.label) .. "\n") - io.write("
") - io.write(string.gsub(html.html_escape(tostring(myitem.value)), "\n", "
") .. "\n") - if myitem.descr then io.write("

" .. string.gsub(html.html_escape(myitem.descr), "\n", "
") .. "

\n") end - if myitem.errtxt then io.write("

" .. string.gsub(html.html_escape(myitem.errtxt), "\n", "
") .. "

\n") end - io.write("
\n") - end -end -function displayitem(myitem) - if not myitem then return end - io.write("" .. html.html_escape(myitem.label) .. "\n") - io.write("
") - io.write(string.gsub(html.html_escape(tostring(myitem.value)), "\n", "
") .. "\n") - if myitem.descr then io.write("

" .. string.gsub(html.html_escape(myitem.descr), "\n", "
") .. "

\n") end - if myitem.errtxt then io.write("

" .. string.gsub(html.html_escape(myitem.errtxt), "\n", "
") .. "

\n") end - io.write("
\n") -end - -function displayformitem(myitem, name, viewtype, header_level, group) - if not myitem then return end - if name then myitem.name = name end - if group and group ~= "" then myitem.name = group.."."..myitem.name end - if myitem.type ~= "hidden" and myitem.type ~= "group" then - io.write("" .. html.html_escape(myitem.label) .. "\n") - io.write("
\n") - end - if (viewtype == "viewonly") then - myitem.disabled = "true" - end - if myitem.type == "group" then - header_level = header_level or 2 - io.write(""..html.html_escape(myitem.label).."") - if myitem.descr then io.write('

' .. string.gsub(html.html_escape(myitem.descr), "\n", "
") .. "

\n") end - if myitem.errtxt then io.write('

' .. string.gsub(html.html_escape(myitem.errtxt), "\n", "
") .. "

\n") end - displayformcontents(myitem, nil, nil, tonumber(header_level)+1, myitem.name) - elseif myitem.type == "multi" then - -- FIXME multiple select doesn't work in haserl, so use series of checkboxes - --myitem.type = "select" - --myitem.multiple = "true" - myitem.class = nil - local tempname = myitem.name - local tempval = myitem.value or {} - local reverseval = {} - for x,val in ipairs(tempval) do - reverseval[val] = x - end - local reverseopt = {} - for x,val in ipairs(myitem.option) do - local v,l - if type(val) == "string" then - v = val - l = val - else - v = val.value - l = val.label - end - reverseopt[v] = x - myitem.value = v - myitem.checked = reverseval[v] - myitem.name = tempname .. "." .. x - io.write(html.form.checkbox(myitem) .. html.html_escape(l) .. "
\n") - end - -- Check for values not in options - if myitem.errtxt then - myitem.class = "error" - io.write('

\n') - end - for x,val in ipairs(tempval) do - if not reverseopt[val] then - myitem.value = val - myitem.checked = true - io.write(html.form.checkbox(myitem) .. html.html_escape(val) .. "
\n") - end - end - if myitem.errtxt then - io.write('

\n') - end - myitem.name = tempname - myitem.value = tempval - elseif myitem.type == "boolean" then - local tempval = myitem.value - if (myitem.value == true) then myitem.checked = "" end - myitem.value = "true" - io.write(html.form.checkbox(myitem) .. "\n") - myitem.value = tempval - elseif myitem.type == "list" then - local tempval = myitem.value - myitem.value = table.concat(myitem.value, "\n") - io.write(html.form.longtext(myitem) .. "\n") - myitem.value = tempval - else - io.write((html.form[myitem.type](myitem) or "") .. "\n") - end - if myitem.type ~= "hidden" and myitem.type ~= "group" then - if myitem.descr then io.write('

' .. string.gsub(html.html_escape(myitem.descr), "\n", "
") .. "

\n") end - if myitem.default then io.write('

Default:' .. string.gsub(html.html_escape(getlabel(myitem, myitem.default)), "\n", "
") .. "

\n") end - if myitem.errtxt then io.write('

' .. string.gsub(html.html_escape(myitem.errtxt), "\n", "
") .. "

\n") end - io.write("
\n") - end -end - -function displayformstart(myform, page_info) - if not myform then return end - if not myform.action and page_info then - myform.action = page_info.script .. page_info.prefix .. page_info.controller .. "/" .. page_info.action - end - io.write('
\n') - if myform.descr then io.write('

' .. string.gsub(html.html_escape(myform.descr), "\n", "
") .. "

\n") end - if myform.errtxt then io.write('

' .. string.gsub(html.html_escape(myform.errtxt), "\n", "
") .. "

\n") end - io.write('
\n') - if myform.value.redir then - displayformitem(myform.value.redir, "redir") - end -end - -function displayformcontents(myform, order, finishingorder, header_level, group) - if not myform then return end - if not order and not finishingorder then - tmporder = {} - for name,item in pairs(myform.value) do - if tonumber(item.seq) then - tmporder[#tmporder+1] = {seq=tonumber(item.seq), name=name} - end - end - if #tmporder>0 then - table.sort(tmporder, function(a,b) if a.seq ~= b.seq then return a.seq < b.seq else return a.name < b.name end end) - order = {} - for i,val in ipairs(tmporder) do - order[#order+1] = val.name - end - end - end - local reverseorder= {["redir"]=0} - if order then - for x,name in ipairs(order) do - reverseorder[name] = x - if myform.value[name] then - myform.value[name].name = name - displayformitem(myform.value[name], nil, nil, header_level, group) - end - end - end - local reversefinishingorder = {} - if finishingorder then - for x,name in ipairs(finishingorder) do - reversefinishingorder[name] = x - end - end - for name,item in pairs(myform.value) do - if nil == reverseorder[name] and nil == reversefinishingorder[name] then - item.name = name - displayformitem(item, nil, nil, header_level, group) - end - end - if finishingorder then - for x,name in ipairs(finishingorder) do - if myform.value[name] then - myform.value[name].name = name - displayformitem(myform.value[name], nil, nil, header_level, group) - end - end - end -end - -function displayformend(myform) - if not myform then return end - io.write('
\n') - io.write('
') - io.write('
\n') -end - -function displayform(myform, order, finishingorder, page_info, header_level) - if not myform then return end - displayformstart(myform, page_info) - displayformcontents(myform, order, finishingorder, header_level) - displayformend(myform) -end - -function displaycommandresults(commands, session, preserveerrors) - local cmdresult = {} - for i,cmd in ipairs(commands) do - if session[cmd.."result"] then - cmdresult[#cmdresult + 1] = session[cmd.."result"] - if not preserveerrors or not session[cmd.."result"].errtxt then - session[cmd.."result"] = nil - end - end - end - if #cmdresult > 0 then - io.write("

Command Result

\n
\n") - for i,result in ipairs(cmdresult) do - if type(result.value) == "string" and result.value ~= "" then io.write(string.gsub(html.html_escape(result.value), "\n", "
") .. "\n") end - if result.descr then io.write('

' .. string.gsub(html.html_escape(result.descr), "\n", "
") .. "

\n") end - if result.errtxt then io.write('

' .. string.gsub(html.html_escape(result.errtxt), "\n", "
") .. "

\n") end - end - io.write("
\n") - end -end - --- Divide up data into pages of size pagesize --- clientdata can be a page number or a table where clientdata.page is the page number -function paginate(data, clientdata, pagesize) - local subset = data - local page_data = { numpages=1, page=1, pagesize=pagesize, num=#data } - if #data > pagesize then - page_data.numpages = math.floor((#data + pagesize -1)/pagesize) - if clientdata and clientdata.page and tonumber(clientdata.page) then - page_data.page = tonumber(clientdata.page) - elseif clientdata and tonumber(clientdata) then - page_data.page = tonumber(clientdata) - end - if page_data.page > page_data.numpages then - page_data.page = page_data.numpages - elseif page_data.page < 0 then - page_data.page = 0 - end - if page_data.page > 0 then - subset = {} - for i=((page_data.page-1)*pagesize)+1, page_data.page*pagesize do - table.insert(subset, data[i]) - end - end - end - return subset, page_data -end - -function displaypagination(page_data, page_info) - local min, max - if page_data.page == 0 then - min = 1 - max = page_data.num - else - min = math.min(((page_data.page-1)*page_data.pagesize)+1, page_data.num) - max = math.min(page_data.page*page_data.pagesize, page_data.num) - end - if min == max then - io.write("Record "..min.." of "..page_data.num.."\n") - else - io.write("Records "..min.."-"..max.." of "..page_data.num.."\n") - end - - if page_data.numpages > 1 then - -- Pre-determine the links for each page - local link = page_info.script .. page_info.orig_action .. "?" - local clientdata = {} - for name,val in pairs(page_info.clientdata) do - if name ~= "sessionid" and name ~= "page" then - clientdata[#clientdata + 1] = name.."="..val - end - end - if #clientdata > 0 then - link = link .. table.concat(clientdata, "&") .. "&" - end - link = link.."page=" - - function pagelink(page) - io.write(html.link{value=link..page, label=page}.."\n") - end - - -- Print out < 1 n-50 n-25 n-10 n-2 n-1 n n+1 n+2 n+10 n+25 n+50 numpages > - io.write('
Pages:') - local p = page_data.page - if p > 1 then - io.write("\n") - end - if p ~= 1 then - pagelink(1) - end - local links = {(p-3)-(p-3)%10, p-2, p-1, p, p+1, p+2, (p+12)-(p+12)%10} - table.insert(links, 1, links[1]-1-(links[1]-1)%25) - table.insert(links, 1, links[1]-1-(links[1]-1)%50) - table.insert(links, links[#links]+25-links[#links]%25) - table.insert(links, links[#links]+50-links[#links]%50) - for i,num in ipairs(links) do - if num==p and p~=0 then - io.write(p.."\n") - elseif num>1 and num\n") - end - end - if p~=0 then - io.write(html.link{value=link.."0", label="all"}.."\n") - end - io.write("
") - end -end - --- give a cfe and get back a string of what is inside --- great for troubleshooting and seeing what is really being passed to the view -function cfe_unpack ( a ) - if type(a) == "table" then - value = session.serialize("cfe", a) - value = "
" .. html.html_escape(value) .. "
" - return value - end -end -- cgit v1.2.3