webmcp

annotate framework/env/ui/paginate.lua @ 405:c5f9a1b2f225

Updated year of copyright notice
author jbe
date Wed Jan 06 02:54:45 2016 +0100 (2016-01-06)
parents 8cf6d927d074
children c43f251262d8
rev   line source
jbe/bsw@0 1 --[[--
jbe/bsw@0 2 ui.paginate{
jbe@349 3 selector = selector, -- a selector for items from the database (will be modified)
jbe@349 4 anchor = anchor, -- optional name of anchor in document to jump to
jbe@349 5 per_page = per_page, -- items per page, defaults to 10
jbe@349 6 container_attr = container_attr, -- html attr for the container element
jbe@349 7 name = name, -- name of the CGI get variable, defaults to "page"
jbe@349 8 page = page, -- directly specify a page, and ignore 'name' parameter
jbe@48 9 content = function()
jbe@349 10 ... -- code block which should be encapsulated with page selection links
jbe/bsw@0 11 end
jbe/bsw@0 12 }
jbe/bsw@0 13
jbe@223 14 This function preceeds and appends the output of the given 'content' function with page selection links. The passed selector will be modified to show only a limited amount ('per_page') of items. The currently displayed page will be determined directly by request.get_param{...}, and not via the param.get(...) function, in order to pass page selections automatically to sub-views.
jbe@1 15
jbe/bsw@0 16 --]]--
jbe/bsw@0 17
jbe/bsw@0 18 function ui.paginate(args)
jbe/bsw@0 19 local selector = args.selector
jbe/bsw@0 20 local per_page = args.per_page or 10
jbe/bsw@0 21 local name = args.name or 'page'
jbe/bsw@0 22 local content = args.content
jbe/bsw@0 23 local count_selector = selector:get_db_conn():new_selector()
jbe/bsw@0 24 count_selector:add_field('count(1)')
jbe/bsw@0 25 count_selector:add_from(selector)
jbe/bsw@0 26 count_selector:single_object_mode()
jbe/bsw@0 27 local count = count_selector:exec().count
jbe@8 28 local page_count = 1
jbe@8 29 if count > 0 then
jbe@8 30 page_count = math.floor((count - 1) / per_page) + 1
jbe@8 31 end
jbe@223 32 local current_page = atom.integer:load(request.get_param{name=name}) or 1
jbe/bsw@2 33 if current_page > page_count then
jbe/bsw@2 34 current_page = page_count
jbe/bsw@2 35 end
jbe/bsw@0 36 selector:limit(per_page)
jbe/bsw@0 37 selector:offset((current_page - 1) * per_page)
jbe@92 38 local id = request.get_id_string()
jbe@92 39 local params = request.get_param_strings()
jbe/bsw@0 40 local function pagination_elements()
jbe/bsw@0 41 if page_count > 1 then
jbe/bsw@0 42 for page = 1, page_count do
jbe/bsw@0 43 if page > 1 then
jbe/bsw@0 44 slot.put(" ")
jbe/bsw@0 45 end
jbe/bsw@0 46 params[name] = page
jbe/bsw@0 47 local attr = {}
jbe/bsw@0 48 if current_page == page then
jbe/bsw@0 49 attr.class = "active"
jbe/bsw@0 50 end
jbe/bsw@0 51 ui.link{
jbe/bsw@11 52 attr = attr,
jbe/bsw@0 53 module = request.get_module(),
jbe/bsw@0 54 view = request.get_view(),
jbe/bsw@0 55 id = id,
jbe/bsw@0 56 params = params,
bsw@80 57 anchor = args.anchor,
jbe@223 58 text = tostring(page)
jbe/bsw@0 59 }
jbe/bsw@0 60 end
jbe/bsw@0 61 end
jbe/bsw@0 62 end
jbe/bsw@0 63 ui.container{
poelzi@35 64 attr = args.container_attr or { class = 'ui_paginate' },
jbe/bsw@0 65 content = function()
jbe/bsw@0 66 ui.container{
jbe/bsw@0 67 attr = { class = 'ui_paginate_head ui_paginate_select' },
jbe/bsw@0 68 content = pagination_elements
jbe/bsw@0 69 }
jbe/bsw@0 70 ui.container{
jbe/bsw@0 71 attr = { class = 'ui_paginate_content' },
jbe/bsw@0 72 content = content
jbe/bsw@0 73 }
jbe/bsw@0 74 ui.container{
jbe/bsw@0 75 attr = { class = 'ui_paginate_foot ui_paginate_select' },
jbe/bsw@0 76 content = pagination_elements
jbe/bsw@0 77 }
jbe/bsw@0 78 end
jbe/bsw@0 79 }
jbe/bsw@0 80 end

Impressum / About Us