| 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@0 | 49         ui.link{ | 
| jbe/bsw@0 | 50           attr = attr, | 
| jbe/bsw@0 | 51           module = request.get_module(), | 
| jbe/bsw@0 | 52           view   = request.get_view(), | 
| jbe/bsw@0 | 53           id     = id, | 
| jbe/bsw@0 | 54           params = params, | 
| jbe/bsw@0 | 55           text   = tostring(page) | 
| jbe/bsw@0 | 56         } | 
| jbe/bsw@0 | 57       end | 
| jbe/bsw@0 | 58     end | 
| jbe/bsw@0 | 59   end | 
| jbe/bsw@0 | 60   ui.container{ | 
| jbe/bsw@0 | 61     attr = { class = 'ui_paginate' }, | 
| jbe/bsw@0 | 62     content = function() | 
| jbe/bsw@0 | 63       ui.container{ | 
| jbe/bsw@0 | 64         attr = { class = 'ui_paginate_head ui_paginate_select' }, | 
| jbe/bsw@0 | 65         content = pagination_elements | 
| jbe/bsw@0 | 66       } | 
| jbe/bsw@0 | 67       ui.container{ | 
| jbe/bsw@0 | 68         attr = { class = 'ui_paginate_content' }, | 
| jbe/bsw@0 | 69         content = content | 
| jbe/bsw@0 | 70       } | 
| jbe/bsw@0 | 71       ui.container{ | 
| jbe/bsw@0 | 72         attr = { class = 'ui_paginate_foot ui_paginate_select' }, | 
| jbe/bsw@0 | 73         content = pagination_elements | 
| jbe/bsw@0 | 74       } | 
| jbe/bsw@0 | 75     end | 
| jbe/bsw@0 | 76   } | 
| jbe/bsw@0 | 77 end |