| 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 |