當前位置: 首頁>>代碼示例>>Python>>正文


Python ICollection.providedBy方法代碼示例

本文整理匯總了Python中plone.app.collection.interfaces.ICollection.providedBy方法的典型用法代碼示例。如果您正苦於以下問題:Python ICollection.providedBy方法的具體用法?Python ICollection.providedBy怎麽用?Python ICollection.providedBy使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在plone.app.collection.interfaces.ICollection的用法示例。


在下文中一共展示了ICollection.providedBy方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: queryCatalog

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
    def queryCatalog(self, limit):
        """
        """
        querybuilder = QueryBuilder(self, self.request)
        if not hasattr(self.data, 'sort_on'):
            self.data.sort_on = 'effective'
        if not hasattr(self.data, 'sort_order'):
            self.data.sort_order = False
        if not hasattr(self.data, 'sort_folderorder'):
            self.data.sort_folderorder = False

        sort_order = 'descending' if self.data.sort_order else 'ascending'
        sort_on = self.data.sort_on

        if self.data.sort_folderorder:
            sort_on = 'getObjPositionInParent'

        query = list(self.data.query)

        if ICollection.providedBy(self.context):
            query += self.context.query and self.context.query or []
            parent = aq_parent(aq_inner(self.context))
            if ICollection.providedBy(parent):
                query += parent.query and parent.query or []
        return querybuilder(query=query,
                            sort_on=sort_on,
                            sort_order=sort_order,
                            limit=limit)
開發者ID:UPCnet,項目名稱:genweb.smartportlet,代碼行數:30,代碼來源:__init__.py

示例2: walk

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
        def walk(items, result, parent):
            for item in items:
                collection = []
                if COLLECTION and IContentListingObject.providedBy(item):
                    item = item.getObject()
                elif IATTopic.providedBy(item):
                    collection = item.queryCatalog(b_size=100, full_objects=True)
                elif COLLECTION and ICollection.providedBy(item):
                    collection = item.getQuery()

                if collection:
                    result[item.title_or_id()] = []
                    walk(collection, result, item.title_or_id())
                else:
                    # add only published items
                    if wft.getInfoFor(item, "review_state") != "published":
                        IStatusMessage(self.request).\
                        add(_(u'Some of the items in your list are private. '
                               'They were not included in the wizard - '
                               'MailChimp supports only published content.'),
                            type='error')
                        continue

                    result[parent].append({'uid': IUUID(item),
                                           'title': item.title_or_id()})
            return result
開發者ID:RedTurtle,項目名稱:redturtle.monkey,代碼行數:28,代碼來源:campaign.py

示例3: contentsMethod

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
 def contentsMethod(self):
     context = aq_inner(self.context)
     if IATTopic.providedBy(context) or ICollection.providedBy(context):
         contentsMethod = context.queryCatalog
     else:
         contentsMethod = context.getFolderContents
     return contentsMethod
開發者ID:redomino,項目名稱:redomino.tabsandslides,代碼行數:9,代碼來源:common.py

示例4: get_items

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
    def get_items(self):
        context = aq_inner(self.context)
        if IATFolder.providedBy(context) or \
                IATBTreeFolder.providedBy(context):
            res = self.context.getFolderContents(
                contentFilter={
                    'sort_on': 'getObjPositionInParent',
                    'portal_type': self.settings.allowed_types,
                    'limit': self.settings.limit
                }
            )
        elif IATTopic.providedBy(context):
            if self.settings.limit and self.settings.limit > 0:
                res = context.queryCatalog(batch=True,
                                           b_size=self.settings.limit,
                                           portal_type=
                                           self.settings.allowed_types,
                                           )
            else:
                res = context.queryCatalog(
                    portal_type=self.settings.allowed_types,
                    limit=self.settings.limit
                )
        elif ICollection.providedBy(context):
            query = queryparser.parseFormquery(
                context, context.getRawQuery())
            query['portal_type'] = self.settings.allowed_types
            query['limit'] = self.settings.limit
            if self.settings.limit and self.settings.limit > 0:
                res = context.queryCatalog(batch=True,
                                           b_size=self.settings.limit)
            else:
                res = context.queryCatalog(query)

        return res
開發者ID:EricGrivilers,項目名稱:collective.easyslider,代碼行數:37,代碼來源:views.py

示例5: editCarouselLink

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
 def editCarouselLink(self):
     provider = self.collection()
     if provider is not None:
         if ICollection.providedBy(provider):
             return provider.absolute_url() + '/edit'
         return provider.absolute_url() + '/criterion_edit_form'
     return None
開發者ID:RedTurtle,項目名稱:collective.carousel,代碼行數:9,代碼來源:carousel.py

示例6: getCriteriaKeys

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
 def getCriteriaKeys(self):
     li = []
     if IATTopic.providedBy(self.context) or ICollection.providedBy(self.context) or IDXCollection.providedBy(self.context):
         criteria = IListBaseQueryCriteria(self.context)()
         for criterion in [a['i'] for a in criteria]:
             li.append(self.name+'.'+criterion)
     return li
開發者ID:collective,項目名稱:Solgema.fullcalendar,代碼行數:9,代碼來源:widgets.py

示例7: __call__

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
    def __call__(self, context, **query):
        ctool = getToolByName(context, 'portal_faceted', None)
        if ctool:
            search = ctool.search
        else:
            logger.debug('portal_faceted not present, using portal_catalog')
            ctool = getToolByName(context, 'portal_catalog')
            search = ctool.searchResults

        # Also get query from Topic
        buildQuery = getattr(context, 'buildQuery', None)
        newquery = buildQuery and buildQuery() or {}
        formquery = None

        # Get query from Collection
        if HAS_PAT:
            if PACI.ICollection.providedBy(context):
                infos = ICollection_behavior(context)
                sort_order = ('descending'
                              if infos.sort_reversed
                              else 'ascending')
                sort_on = infos.sort_on
                formquery = infos.query

        if ICollection.providedBy(context):
            getRawQuery = getattr(context, 'getRawQuery', lambda: [])
            formquery = getRawQuery()

            getSortOn = getattr(context, 'getSort_on', lambda: None)
            sort_on = getSortOn()

            if sort_on:
                getSortReversed = getattr(
                    context, 'getSort_reversed', lambda: None)
                sort_order = getSortReversed()
                if sort_order:
                    sort_order = 'descending'
                else:
                    sort_order = 'ascending'
            else:
                sort_order = None

        if formquery is not None:
            newquery = parseFormquery(context, formquery, sort_on, sort_order)

        if not isinstance(newquery, dict):
            newquery = {}

        # Avoid mixing sorting params from faceted and collection
        if 'sort_on' not in query:
            query.pop('sort_order', None)

        if 'sort_on' in query and 'sort_order' not in query:
            newquery.pop('sort_order', None)

        newquery.update(query)

        notify(QueryWillBeExecutedEvent(context, newquery))
        return search(**newquery)
開發者ID:Martronic-SA,項目名稱:eea.facetednavigation,代碼行數:61,代碼來源:catalog.py

示例8: available

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
 def available(self):
     # only show on collection/topic
     if not self.context.restrictedTraverse('@@iscalendarlayout')():
         return False
     if ICollection.providedBy(self.context):
         return True
     if IATTopic.providedBy(self.context):
         return True
     return False
開發者ID:ploneUN,項目名稱:ploneun.calendar,代碼行數:11,代碼來源:listingbuttons.py

示例9: get_collection_query

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
def get_collection_query(obj):
    """ return collection's query params
    """

    if IATTopic.providedBy(obj):
        # old style collection
        return obj.buildQuery()

    if ICollection.providedBy(obj):
        # new style collection
        return parse_new_collection_query(obj)
開發者ID:abstract-open-solutions,項目名稱:collective.basesearch,代碼行數:13,代碼來源:utils.py

示例10: edit_collection

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
 def edit_collection(self):
     provider = self.collection()
     smanager = SecurityManagement.getSecurityManager()
     allowed = smanager.checkPermission(ChangeTopics, provider)
     if allowed:
         provider = self.collection()
         if provider is not None:
             if ICollection.providedBy(provider):
                 return provider.absolute_url() + '/edit'
             return provider.absolute_url() + '/criterion_edit_form'
     return None
開發者ID:thet,項目名稱:collective.banner,代碼行數:13,代碼來源:portlet.py

示例11: results

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
    def results(self, batch=True, b_start=0, b_size=None, inherit=False, extra=[]):
        querybuilder = QueryBuilder(self, self.REQUEST)
        sort_order = 'reverse' if self.sort_reversed else 'ascending'
        if not b_size:
            b_size = self.item_count
        query = isinstance(self.query, list) and deepcopy(self.query) or []
        if inherit:
            parent = aq_parent(self)
            if ICollection.providedBy(parent):
                query += parent.query and deepcopy(parent.query) or []
                inparent = aq_parent(self)
                if ICollection.providedBy(inparent):
                    query += inparent.query and deepcopy(inparent.query) or []
        query = query + extra

        res = querybuilder(
            query=query,
            batch=batch, b_start=b_start, b_size=b_size,
            sort_on=self.sort_on, sort_order=sort_order,
            limit=self.limit)
        return res
開發者ID:UPCnet,項目名稱:vilaix.core,代碼行數:23,代碼來源:content.py

示例12: getCollection

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
    def getCollection(self, item):
        col = item.getCollection()
        if item.limit > 0:
            if HAS_COLLECTIONS and ICollection.providedBy(col) or \
                    HAS_PAC and IDXCollection.providedBy(col):
                results = col.queryCatalog(b_size=item.limit)
            else:
                results = col.queryCatalog(sort_limit=item.limit)[:item.limit]
        else:
            results = col.queryCatalog()

        return results
開發者ID:collective,項目名稱:Products.Doormat,代碼行數:14,代碼來源:views.py

示例13: results

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
    def results(self, provider):
        results = []
        if provider is not None:
            # by default we assume that only Collections are addable
            # as a carousel provider

            # It doesn't make sense to show *all* objects from a collection
            # - some of them might return hundreeds of objects
            if ICollection.providedBy(provider):
                res = provider.results(b_size=7)
                return res
            return provider.queryCatalog()[:7]
        return results
開發者ID:Madec,項目名稱:collective.carousel,代碼行數:15,代碼來源:viewlets.py

示例14: getEventsForCalendar

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
    def getEventsForCalendar(self):
        navigation_root_path = self.root()

        self.options = {}
        if navigation_root_path:
            root_content = self.rootTopic()
            if root_content:
                if IATTopic.providedBy(root_content):
                    self.options = root_content.buildQuery()
                elif ICollection.providedBy(root_content):
                    self.options = parseFormquery(root_content, root_content.getField('query').getRaw(root_content))

        _define_search_options(self, self.options)
        weeks = self._get_calendar_structure()
        return weeks
開發者ID:collective,項目名稱:collective.portlet.calendar,代碼行數:17,代碼來源:calendar.py

示例15: results

# 需要導入模塊: from plone.app.collection.interfaces import ICollection [as 別名]
# 或者: from plone.app.collection.interfaces.ICollection import providedBy [as 別名]
    def results(self, provider):
        results = []
        if provider is not None:
            # by default we assume that only Collections are addable
            # as a carousel provider

            # It doesn't make sense to show *all* objects from a collection
            # - some of them might return hundreeds of objects
            registry = getUtility(IRegistry)
            carousel_viewlet_max_size = registry.forInterface(
                ICarouselSettings, False).carousel_viewlet_max_size or 7
            if ICollection.providedBy(provider):
                res = provider.results(b_size=carousel_viewlet_max_size)
                return res
            return provider.queryCatalog()[:carousel_viewlet_max_size]
        return results
開發者ID:bogdangi,項目名稱:collective.carousel,代碼行數:18,代碼來源:viewlets.py


注:本文中的plone.app.collection.interfaces.ICollection.providedBy方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。