webmcp
annotate framework/env/ui/paginate.lua @ 14:a29c8ffb3f82
New function ui.filters{...}
Also changed version information to "1.0.8"
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 |