webmcp

annotate framework/env/ui/paginate.lua @ 14:a29c8ffb3f82

New function ui.filters{...}

Also changed version information to "1.0.8"
author jbe/bsw
date Sat Feb 20 21:00:58 2010 +0100 (2010-02-20)
parents d76a8857ba62
children 81dfcfd960ed
rev   line source
jbe/bsw@0 1 --[[--
jbe/bsw@0 2 ui.paginate{
jbe/bsw@0 3 selector = selector, -- a selector for items from the database
jbe/bsw@0 4 per_page = per_page, -- items per page, defaults to 10
jbe/bsw@0 5 name = name, -- name of the CGI get variable, defaults to "page"
jbe@1 6 page = page, -- directly specify a page, and ignore 'name' parameter
jbe/bsw@0 7 content = function()
jbe/bsw@0 8 ... -- code block which should be encapsulated with page selection links
jbe/bsw@0 9 end
jbe/bsw@0 10 }
jbe/bsw@0 11
jbe@1 12 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 cgi.params, and not via the param.get(...) function, in order to pass page selections automatically to sub-views.
jbe@1 13
jbe/bsw@0 14 --]]--
jbe/bsw@0 15
jbe/bsw@0 16 function ui.paginate(args)
jbe/bsw@0 17 local selector = args.selector
jbe/bsw@0 18 local per_page = args.per_page or 10
jbe/bsw@0 19 local name = args.name or 'page'
jbe/bsw@0 20 local content = args.content
jbe/bsw@0 21 local count_selector = selector:get_db_conn():new_selector()
jbe/bsw@0 22 count_selector:add_field('count(1)')
jbe/bsw@0 23 count_selector:add_from(selector)
jbe/bsw@0 24 count_selector:single_object_mode()
jbe/bsw@0 25 local count = count_selector:exec().count
jbe@8 26 local page_count = 1
jbe@8 27 if count > 0 then
jbe@8 28 page_count = math.floor((count - 1) / per_page) + 1
jbe@8 29 end
jbe@1 30 local current_page = atom.integer:load(cgi.params[name]) or 1
jbe/bsw@2 31 if current_page > page_count then
jbe/bsw@2 32 current_page = page_count
jbe/bsw@2 33 end
jbe/bsw@0 34 selector:limit(per_page)
jbe/bsw@0 35 selector:offset((current_page - 1) * per_page)
jbe/bsw@0 36 local id = param.get_id_cgi()
jbe/bsw@0 37 local params = param.get_all_cgi()
jbe/bsw@0 38 local function pagination_elements()
jbe/bsw@0 39 if page_count > 1 then
jbe/bsw@0 40 for page = 1, page_count do
jbe/bsw@0 41 if page > 1 then
jbe/bsw@0 42 slot.put(" ")
jbe/bsw@0 43 end
jbe/bsw@0 44 params[name] = page
jbe/bsw@0 45 local attr = {}
jbe/bsw@0 46 if current_page == page then
jbe/bsw@0 47 attr.class = "active"
jbe/bsw@0 48 end
jbe/bsw@11 49 local partial
jbe/bsw@11 50 if ui.is_partial_loading_enabled() then
jbe/bsw@11 51 partial = {
jbe/bsw@11 52 params = {
jbe/bsw@11 53 [name] = tostring(page)
jbe/bsw@11 54 }
jbe/bsw@11 55 }
jbe/bsw@11 56 end
jbe/bsw@0 57 ui.link{
jbe/bsw@11 58 attr = attr,
jbe/bsw@0 59 module = request.get_module(),
jbe/bsw@0 60 view = request.get_view(),
jbe/bsw@0 61 id = id,
jbe/bsw@0 62 params = params,
jbe/bsw@11 63 text = tostring(page),
jbe/bsw@11 64 partial = partial
jbe/bsw@0 65 }
jbe/bsw@0 66 end
jbe/bsw@0 67 end
jbe/bsw@0 68 end
jbe/bsw@0 69 ui.container{
jbe/bsw@0 70 attr = { class = 'ui_paginate' },
jbe/bsw@0 71 content = function()
jbe/bsw@0 72 ui.container{
jbe/bsw@0 73 attr = { class = 'ui_paginate_head ui_paginate_select' },
jbe/bsw@0 74 content = pagination_elements
jbe/bsw@0 75 }
jbe/bsw@0 76 ui.container{
jbe/bsw@0 77 attr = { class = 'ui_paginate_content' },
jbe/bsw@0 78 content = content
jbe/bsw@0 79 }
jbe/bsw@0 80 ui.container{
jbe/bsw@0 81 attr = { class = 'ui_paginate_foot ui_paginate_select' },
jbe/bsw@0 82 content = pagination_elements
jbe/bsw@0 83 }
jbe/bsw@0 84 end
jbe/bsw@0 85 }
jbe/bsw@0 86 end

Impressum / About Us