Skip to content

Commit

Permalink
feat: Changes in xblock_v2 to support studio_view [FC-0076] (openedx#…
Browse files Browse the repository at this point in the history
…36029)

Updates to support studio_view (editors) in xblock_v2 iframe.

- Send a message when cancel button is clicked on xblock_v2 iframe only in studio_view
- Send a message when save.end event is notified on xblock_v2 iframe.
- Send notify function in runtime. This is to avoid errors when saving the Xblock
  • Loading branch information
ChrisChV authored Jan 16, 2025
1 parent 8aeaaf4 commit e930bc6
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 4 deletions.
29 changes: 29 additions & 0 deletions common/templates/xblock_v2/xblock_iframe.html
Original file line number Diff line number Diff line change
Expand Up @@ -215,6 +215,16 @@
}
return url;
},
notify: (eventName, data) => {
/**
* Used in `studio_view` to notify events and errors
**/
window.parent.postMessage({
type: 'xblock-event',
eventName,
data,
}, '*');
}
};

/**
Expand Down Expand Up @@ -258,6 +268,25 @@
const blockJS = { element };
callback(blockJS);
}

if ('{{ view_name | safe }}' === 'studio_view') {
// Used when rendering the `studio_view`, in order to avoid open a new tab on click cancel or save
const selectors = [
'.cancel-button',
'.save-button',
'.action-cancel',
'.action-save',
];

for (const selector of selectors) {
const queryObject = document.querySelector(selector);
if (queryObject) {
queryObject.addEventListener('click', function() {
event.preventDefault();
});
}
}
}
}

// Recursively initialize the JavaScript code of each XBlock:
Expand Down
5 changes: 1 addition & 4 deletions openedx/core/djangoapps/xblock/rest_api/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,7 @@ def embed_block_view(request, usage_key: UsageKeyV2, view_name: str):
'fragment': fragment,
'handler_urls_json': json.dumps(handler_urls),
'lms_root_url': lms_root_url,
'view_name': view_name,
'is_development': settings.DEBUG,
}
response = render(request, 'xblock_v2/xblock_iframe.html', context, content_type='text/html')
Expand Down Expand Up @@ -322,10 +323,6 @@ def post(self, request, usage_key, version: LatestVersion | int = LatestVersion.
# Save after the callback so any changes made in the callback will get persisted.
block.save()

# Signal that we've modified this block
context_impl = get_learning_context_impl(usage_key)
context_impl.send_block_updated_event(usage_key)

block_dict = {
"id": str(block.usage_key),
"display_name": get_block_display_name(block), # note this is also present in metadata
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -314,6 +314,10 @@ def save_block(self, block):
)
self.authored_data_store.mark_unchanged(block)

# Signal that we've modified this block
learning_context = get_learning_context_impl(usage_key)
learning_context.send_block_updated_event(usage_key)

def _get_component_from_usage_key(self, usage_key):
"""
Note that Components aren't ever really truly deleted, so this will
Expand Down

0 comments on commit e930bc6

Please sign in to comment.