Skip to content

Commit

Permalink
Merge pull request #5564 from christianbeeznest/ofaj-21647-3
Browse files Browse the repository at this point in the history
Internal: Add filemanaer with personal files in tinyMCE legacy - refs BT#21647
  • Loading branch information
christianbeeznest authored May 31, 2024
2 parents 8b6860e + 6b29202 commit 9e807f8
Showing 1 changed file with 34 additions and 18 deletions.
52 changes: 34 additions & 18 deletions src/CoreBundle/Component/Editor/CkEditor/CkEditor.php
Original file line number Diff line number Diff line change
Expand Up @@ -71,13 +71,26 @@ public function editorReplace(): string

return "<script>
window.addEventListener('message', function(event) {
// Check if the received message contains the URL data
if (event.data.url) {
if (window.parent.tinyMCECallback) {
window.parent.tinyMCECallback(event.data.url);
delete window.parent.tinyMCECallback;
// Check if we are in an iframe
if (window.parent !== window) {
// Send the message to the parent window
window.parent.postMessage(event.data, '*');
// Access the callback function in the parent window
const parentWindow = window.parent.window[0].window;
if (parentWindow && parentWindow.tinyMCECallback) {
parentWindow.tinyMCECallback(event.data.url);
delete parentWindow.tinyMCECallback;
}
} else if (window.tinyMCECallback) {
// Handle the message in the main context
window.tinyMCECallback(event.data.url);
delete window.tinyMCECallback;
}
}
});
document.addEventListener('DOMContentLoaded', function() {
window.chEditors = window.chEditors || [];
window.chEditors.push($javascript)
Expand Down Expand Up @@ -177,38 +190,40 @@ private function getImagePicker(): string
}

/**
* Generates the JavaScript function for opening the file manager picker in TinyMCE.
*
* Determines the URL based on whether the context is a course or a user.
* Falls back to the image picker if neither is found.
* Generates a JavaScript function for TinyMCE file manager picker.
*
* @return string The JavaScript function for TinyMCE's file manager picker.
* @param bool $onlyPersonalfiles If true, only shows personal files.
* @return string JavaScript function as string.
*/
private function getFileManagerPicker(): string
private function getFileManagerPicker($onlyPersonalfiles = true): string
{
$course = api_get_course_entity();
$user = api_get_user_entity();
$course = api_get_course_entity();

$url = null;
if (null !== $course) {
$resourceNodeId = $course->getResourceNode()->getId();
$url = api_get_path(WEB_PATH).'resources/document/'.$resourceNodeId.'/manager?'.api_get_cidreq().'&type=images';
} else {
if ($onlyPersonalfiles) {
if (null !== $user) {
$resourceNodeId = $user->getResourceNode()->getId();
$url = api_get_path(WEB_PATH).'resources/filemanager/personal_list/'.$resourceNodeId;
$url = api_get_path(WEB_PATH) . 'resources/filemanager/personal_list/' . $resourceNodeId;
}
} else {
if (null !== $course) {
$resourceNodeId = $course->getResourceNode()->getId();
$url = api_get_path(WEB_PATH) . 'resources/document/' . $resourceNodeId . '/manager?' . api_get_cidreq() . '&type=images';
} elseif (null !== $user) {
$resourceNodeId = $user->getResourceNode()->getId();
$url = api_get_path(WEB_PATH) . 'resources/filemanager/personal_list/' . $resourceNodeId;
}
}

if (null === $url) {
if (!isset($url)) {
return $this->getImagePicker();
}

return '
function(cb, value, meta) {
window.tinyMCECallback = cb;
let fileType = meta.filetype;
let fileManagerUrl = "'.$url.'";
let fileManagerUrl = "' . $url . '";
if (fileType === "image") {
fileManagerUrl += "?type=images";
Expand All @@ -226,6 +241,7 @@ function(cb, value, meta) {
';
}


/**
* Get the empty template.
*/
Expand Down

0 comments on commit 9e807f8

Please sign in to comment.