def expand_containers(self, items, containers, _url, chain=(), context=None): #seen_context = False _url = _url.rstrip("/") current = False for key, container in containers: assert IAlchemistContainer.providedBy(container) # do not include doc containers for docs who do not specifically # declare the parent group instance as a workspace.group_name if IDoc.implementedBy(container.domain_model): group = get_group_for_context(container) assert IGroup.providedBy(group) doc_type_key = naming.polymorphic_identity(container.domain_model) if not group.is_type_workspaced(doc_type_key): continue label = container.domain_model.__name__ descriptor = utils.get_descriptor(container.domain_model) order = 999 if descriptor: order = descriptor.order label = getattr(descriptor, "container_name", None) or \ getattr(descriptor, "display_name", None) if context is not None: current = container.__name__ == context.__name__ selected = not len(chain) and current if current: #seen_context = True nodes = self.expand(chain) else: nodes = () key_url = "%s/%s" % (_url, key) items.append({ "id": self.get_nav_entry_id(key_url), "order": order, "label": translate(label, target_language=get_default_language(), domain="bungeni"), "url": key_url, "current": current, "selected": selected, "kind": "container", "nodes": nodes, }) items.sort(key=lambda item:(item['order'], item['label']))
def _query(self, **kw): session = Session() user = utils.get_login_user() reverse = True if (kw.get("sort_dir", "desc") == "desc") else False results = [] domain_status = self.item_status_filter(kw) for domain_class, status in domain_status.iteritems(): if IDoc.implementedBy(domain_class): query = session.query(domain_class ).filter(domain_class.status.in_(status) ).enable_eagerloads(False ).join(domain.UserSubscription ).filter(domain.UserSubscription.principal_id == user.user_id) query = self.filter_group(query, domain_class, kw) query = self.filter_title(query, domain_class, kw) #filter on status_date query = self.filter_status_date(query, domain_class, kw) query = self.order_query(query, domain_class, kw, reverse) results.extend(query.all()) count = len(results) if (kw.get("sort_on", None) and kw.get("sort_dir", None)): results.sort(key=lambda x: getattr(x, str(kw.get("sort_on"))), reverse=reverse) return (results, count)
def _query(self, **kw): session = Session() user = utils.get_login_user() reverse = True if (kw.get("sort_dir", "desc") == "desc") else False results = [] domain_status = self.item_status_filter(kw) for domain_class, status in domain_status.iteritems(): if IDoc.implementedBy(domain_class): query = session.query(domain_class).filter( domain_class.status.in_(status) ).enable_eagerloads(False).join( domain.UserSubscription).filter( domain.UserSubscription.principal_id == user.user_id) query = self.filter_group(query, domain_class, kw) query = self.filter_title(query, domain_class, kw) #filter on status_date query = self.filter_status_date(query, domain_class, kw) query = self.order_query(query, domain_class, kw, reverse) results.extend(query.all()) count = len(results) if (kw.get("sort_on", None) and kw.get("sort_dir", None)): results.sort(key=lambda x: getattr(x, str(kw.get("sort_on"))), reverse=reverse) return (results, count)