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


Python Scope.content方法代碼示例

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


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

示例1: studio_view

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def studio_view(self, context):
        """
        Render a form for editing this XBlock
        """
        fragment = Fragment()
        context = {'fields': []}
        # Build a list of all the fields that can be edited:
        for field_name in self.editable_fields:
            field = self.fields[field_name]
            assert field.scope in (Scope.content, Scope.settings), (
                "Only Scope.content or Scope.settings fields can be used with "
                "StudioEditableXBlockMixin. Other scopes are for user-specific data and are "
                "not generally created/configured by content authors in Studio."
            )
            field_info = self._make_field_info(field_name, field)
            if field_info is not None:
                context["fields"].append(field_info)
        fragment.content = loader.render_django_template('templates/studio_edit.html', context)
        fragment.add_javascript(loader.load_unicode('public/studio_edit.js'))
        fragment.initialize_js('StudioEditableXBlockMixin')
        return fragment 
開發者ID:edx,項目名稱:xblock-utils,代碼行數:23,代碼來源:studio_editable.py

示例2: author_preview_view

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def author_preview_view(self, context):
        """
        View for previewing contents in studio.
        """
        children_contents = []

        fragment = Fragment()
        for child_id in self.children:
            child = self.runtime.get_block(child_id)
            child_fragment = self._render_child_fragment(child, context, 'preview_view')
            fragment.add_fragment_resources(child_fragment)
            children_contents.append(child_fragment.content)

        render_context = {
            'block': self,
            'children_contents': children_contents
        }
        render_context.update(context)
        fragment.add_content(self.loader.render_django_template(self.CHILD_PREVIEW_TEMPLATE, render_context))
        return fragment 
開發者ID:edx,項目名稱:xblock-utils,代碼行數:22,代碼來源:studio_editable.py

示例3: fetch_available_3pm_transcripts

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def fetch_available_3pm_transcripts(self):
        """
        Fetch all available transcripts from 3PlayMedia API for current file ID.

        :return: (generator of OrderedDicts) all transcript's data
        """
        feedback, transcripts_list = self.get_3pm_transcripts_list(
            self.threeplaymedia_file_id, self.threeplaymedia_apikey
        )
        log.debug("Fetched 3PM transcripts list results:\n{}".format(feedback))

        if feedback['status'] is Status.error:
            log.error("3PlayMedia transcripts fetching API request has failed!\n{}".format(feedback['message']))
            raise StopIteration

        for transcript_data in transcripts_list:
            transcript = self.fetch_single_3pm_translation(transcript_data)
            if transcript is None:
                raise StopIteration
            transcript_ordered_dict = transcript._asdict()
            transcript_ordered_dict['content'] = ''  # we don't want to parse it to JSON
            yield transcript_ordered_dict 
開發者ID:appsembler,項目名稱:xblock-video,代碼行數:24,代碼來源:mixins.py

示例4: fetch_from_three_play_media

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def fetch_from_three_play_media(self, request, _suffix=''):
        """
        Proxy handler to hide real API url.

        Arguments:
            request (webob.Request): The request to handle
            suffix (string): not used
            query string: 'language_id=transcript_id'
        Returns:
            webob.Response: WebVTT transcripts wrapped in Response object.
        """
        lang_id, transcript_id = request.query_string.split('=')
        transcript = self.fetch_single_3pm_translation(transcript_data={'id': transcript_id, 'language_id': lang_id})
        if transcript is None:
            return Response()
        return Response(transcript.content, content_type='text/vtt') 
開發者ID:appsembler,項目名稱:xblock-video,代碼行數:18,代碼來源:mixins.py

示例5: __init__

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def __init__(self, authored_data, student_data):
        # Make sure that we don't repeatedly nest CmsFieldData instances
        if isinstance(authored_data, CmsFieldData):
            authored_data = authored_data._authored_data  # pylint: disable=protected-access

        self._authored_data = authored_data
        self._student_data = student_data

        super(CmsFieldData, self).__init__({
            Scope.content: authored_data,
            Scope.settings: authored_data,
            Scope.parent: authored_data,
            Scope.children: authored_data,
            Scope.user_state_summary: student_data,
            Scope.user_state: student_data,
            Scope.user_info: student_data,
            Scope.preferences: student_data,
        }) 
開發者ID:jruiperezv,項目名稱:ANALYSE,代碼行數:20,代碼來源:field_data.py

示例6: load_transcript

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def load_transcript(self, data, suffix=''):
        """
        Store user's cc language selection
        """
        threeplay_id = data.get('threeplay_id')
        transcript_id = data.get('transcript_id')
        content = ''

        if threeplay_id:
            content = Transcript.get_transcript_by_threeplay_id(
                api_key=self.get_attribute_or_default('api_key_3play'),
                threeplay_id=threeplay_id,
                transcript_id=transcript_id,
            )

        return {'content': content} 
開發者ID:edx-solutions,項目名稱:xblock-ooyala,代碼行數:18,代碼來源:ooyala_player.py

示例7: render_children

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def render_children(self, context, fragment, can_reorder=True, can_add=False):
        """
        Renders the children of the module with HTML appropriate for Studio. If can_reorder is
        True, then the children will be rendered to support drag and drop.
        """
        contents = []

        child_context = {'reorderable_items': set()}
        if context:
            child_context.update(context)

        for child_id in self.children:
            child = self.runtime.get_block(child_id)
            if can_reorder:
                child_context['reorderable_items'].add(child.scope_ids.usage_id)
            view_to_render = 'author_view' if hasattr(child, 'author_view') else 'student_view'
            rendered_child = child.render(view_to_render, child_context)
            fragment.add_fragment_resources(rendered_child)

            contents.append({
                'id': str(child.scope_ids.usage_id),
                'content': rendered_child.content
            })

        fragment.add_content(self.runtime.render_template("studio_render_children_view.html", {
            'items': contents,
            'xblock_context': context,
            'can_add': can_add,
            'can_reorder': can_reorder,
        })) 
開發者ID:edx,項目名稱:xblock-utils,代碼行數:32,代碼來源:studio_editable.py

示例8: static_content

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def static_content(self):
        """
        Proxy to `xmodule.contentstore.StaticContent` class.
        """
        contentstore_service = self.runtime.service(self, 'contentstore')
        if contentstore_service:
            return contentstore_service.StaticContent

        return import_from('xmodule.contentstore.content', 'StaticContent') 
開發者ID:appsembler,項目名稱:xblock-video,代碼行數:11,代碼來源:mixins.py

示例9: create_transcript_file

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def create_transcript_file(self, ext='.vtt', trans_str='', reference_name=''):
        """
        Upload a transcript, fetched from a video platform's API, to video xblock.

        Arguments:
            ext (str): format of transcript file, default is vtt.
            trans_str (str): multiple string for convert to vtt file.
            reference_name (str): name of transcript file.
        Returns:
            File's file_name and external_url.
        """
        # Define location of default transcript as a future asset and prepare content to store in assets
        file_name = reference_name.replace(" ", "_") + ext
        course_key = self.course_key
        content_loc = self.static_content.compute_location(course_key, file_name)  # AssetLocator object
        content = self.static_content(
            content_loc,
            file_name,
            'application/json',
            trans_str.encode('UTF-8')
        )  # StaticContent object
        external_url = '/' + str(content_loc)

        # Commit the content
        self.contentstore().save(content)

        return file_name, external_url 
開發者ID:appsembler,項目名稱:xblock-video,代碼行數:29,代碼來源:mixins.py

示例10: fetch_single_3pm_translation

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def fetch_single_3pm_translation(self, transcript_data, format_id=TPMApiTranscriptFormatID.WEBVTT):
        """
        Fetch single transcript for given file ID in given format.

        :param transcript_data:
        :param format_id: defauts to VTT
        :return: (namedtuple instance) transcript data
        """
        transcript_id = transcript_data.get('id', '')
        lang_id = transcript_data.get('language_id')
        external_api_url = '{domain}files/{file_id}/transcripts/{tid}?apikey={api_key}&format_id={format_id}'.format(
            domain=self.THREE_PLAY_MEDIA_API_DOMAIN,
            file_id=self.threeplaymedia_file_id,
            tid=transcript_id,
            api_key=self.threeplaymedia_apikey,
            format_id=format_id
        )
        try:
            content = requests.get(external_api_url).text
        except Exception:  # pylint: disable=broad-except
            log.exception(_("Transcript fetching failure: language [{}]").format(TPMApiLanguage(lang_id)))
            return

        lang_code = TPMApiLanguage(lang_id)
        lang_label = lang_code.name
        video_id = self.get_player().media_id(self.href)
        source = TranscriptSource.THREE_PLAY_MEDIA
        return Transcript(
            id=transcript_id,
            content=content,
            lang=lang_code.iso_639_1_code,
            lang_id=lang_id,
            label=lang_label,
            video_id=video_id,
            format=format_id,
            source=source,
            url=external_api_url,
        ) 
開發者ID:appsembler,項目名稱:xblock-video,代碼行數:40,代碼來源:mixins.py

示例11: _update_with_callback

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def _update_with_callback(xblock, user, old_metadata=None, old_content=None):
    """
    Updates the xblock in the modulestore.
    But before doing so, it calls the xblock's editor_saved callback function.
    """
    if callable(getattr(xblock, "editor_saved", None)):
        if old_metadata is None:
            old_metadata = own_metadata(xblock)
        if old_content is None:
            old_content = xblock.get_explicitly_set_fields_by_scope(Scope.content)
        xblock.editor_saved(user, old_metadata, old_content)

    # Update after the callback so any changes made in the callback will get persisted.
    return modulestore().update_item(xblock, user.id) 
開發者ID:jruiperezv,項目名稱:ANALYSE,代碼行數:16,代碼來源:item.py

示例12: _compute_visibility_state

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def _compute_visibility_state(xblock, child_info, is_unit_with_changes):
    """
    Returns the current publish state for the specified xblock and its children
    """
    if xblock.visible_to_staff_only:
        return VisibilityState.staff_only
    elif is_unit_with_changes:
        # Note that a unit that has never been published will fall into this category,
        # as well as previously published units with draft content.
        return VisibilityState.needs_attention
    is_unscheduled = xblock.start == DEFAULT_START_DATE
    is_live = datetime.now(UTC) > xblock.start
    children = child_info and child_info.get('children', [])
    if children and len(children) > 0:
        all_staff_only = True
        all_unscheduled = True
        all_live = True
        for child in child_info['children']:
            child_state = child['visibility_state']
            if child_state == VisibilityState.needs_attention:
                return child_state
            elif not child_state == VisibilityState.staff_only:
                all_staff_only = False
                if not child_state == VisibilityState.unscheduled:
                    all_unscheduled = False
                    if not child_state == VisibilityState.live:
                        all_live = False
        if all_staff_only:
            return VisibilityState.staff_only
        elif all_unscheduled:
            return VisibilityState.unscheduled if is_unscheduled else VisibilityState.needs_attention
        elif all_live:
            return VisibilityState.live if is_live else VisibilityState.needs_attention
        else:
            return VisibilityState.ready if not is_unscheduled else VisibilityState.needs_attention
    if is_unscheduled:
        return VisibilityState.unscheduled
    elif is_live:
        return VisibilityState.live
    else:
        return VisibilityState.ready 
開發者ID:jruiperezv,項目名稱:ANALYSE,代碼行數:43,代碼來源:item.py

示例13: load_resource

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def load_resource(self, resource_path):
        """
        Gets the content of a resource
        """
        resource_content = pkg_resources.resource_string(__name__, resource_path)
        return unicode(resource_content) 
開發者ID:MarCnu,項目名稱:videojsXBlock,代碼行數:8,代碼來源:videojs.py

示例14: _duplicate_item

# 需要導入模塊: from xblock.fields import Scope [as 別名]
# 或者: from xblock.fields.Scope import content [as 別名]
def _duplicate_item(parent_usage_key, duplicate_source_usage_key, user, display_name=None):
    """
    Duplicate an existing xblock as a child of the supplied parent_usage_key.
    """
    store = modulestore()
    with store.bulk_operations(duplicate_source_usage_key.course_key):
        source_item = store.get_item(duplicate_source_usage_key)
        # Change the blockID to be unique.
        dest_usage_key = source_item.location.replace(name=uuid4().hex)
        category = dest_usage_key.block_type

        # Update the display name to indicate this is a duplicate (unless display name provided).
        duplicate_metadata = own_metadata(source_item)
        if display_name is not None:
            duplicate_metadata['display_name'] = display_name
        else:
            if source_item.display_name is None:
                duplicate_metadata['display_name'] = _("Duplicate of {0}").format(source_item.category)
            else:
                duplicate_metadata['display_name'] = _("Duplicate of '{0}'").format(source_item.display_name)

        dest_module = store.create_item(
            user.id,
            dest_usage_key.course_key,
            dest_usage_key.block_type,
            block_id=dest_usage_key.block_id,
            definition_data=source_item.get_explicitly_set_fields_by_scope(Scope.content),
            metadata=duplicate_metadata,
            runtime=source_item.runtime,
        )

        # Children are not automatically copied over (and not all xblocks have a 'children' attribute).
        # Because DAGs are not fully supported, we need to actually duplicate each child as well.
        if source_item.has_children:
            dest_module.children = []
            for child in source_item.children:
                dupe = _duplicate_item(dest_module.location, child, user=user)
                dest_module.children.append(dupe)
            store.update_item(dest_module, user.id)

        if 'detached' not in source_item.runtime.load_block_type(category)._class_tags:
            parent = store.get_item(parent_usage_key)
            # If source was already a child of the parent, add duplicate immediately afterward.
            # Otherwise, add child to end.
            if source_item.location in parent.children:
                source_index = parent.children.index(source_item.location)
                parent.children.insert(source_index + 1, dest_module.location)
            else:
                parent.children.append(dest_module.location)
            store.update_item(parent, user.id)

        return dest_module.location 
開發者ID:jruiperezv,項目名稱:ANALYSE,代碼行數:54,代碼來源:item.py


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