2024-08-24 20:23:27 +02:00
|
|
|
{{*
|
|
|
|
* Copyright (C) 2010-2024, the Friendica project
|
|
|
|
* SPDX-FileCopyrightText: 2010-2024 the Friendica project
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
*}}
|
2023-03-14 00:48:10 +01:00
|
|
|
<div class="generic-page-wrapper">
|
2022-12-08 22:14:47 +01:00
|
|
|
<h2>{{$l10n.compose_title}}</h2>
|
2023-03-13 10:37:12 +01:00
|
|
|
{{if $l10n.always_open_compose}}
|
2022-10-16 11:49:27 -04:00
|
|
|
<p>{{$l10n.always_open_compose nofilter}}</p>
|
|
|
|
{{/if}}
|
2019-07-14 21:49:38 -04:00
|
|
|
<div id="profile-jot-wrapper">
|
2023-03-14 10:38:03 +01:00
|
|
|
<form class="comment-edit-form" data-item-id="{{$id}}" id="comment-edit-form-{{$id}}" action="compose/{{$type}}" method="post">
|
2023-03-13 10:37:12 +01:00
|
|
|
{{*<!--<input type="hidden" name="return" value="{{$return_path}}" />-->*}}
|
2019-07-14 21:49:38 -04:00
|
|
|
<input type="hidden" name="post_id_random" value="{{$rand_num}}" />
|
|
|
|
<input type="hidden" name="post_type" value="{{$posttype}}" />
|
|
|
|
<input type="hidden" name="wall" value="{{$wall}}" />
|
|
|
|
|
|
|
|
<div id="jot-title-wrap">
|
2022-10-16 11:24:50 -04:00
|
|
|
<input type="text" name="title" id="jot-title" class="jothidden jotforms form-control" placeholder="{{$l10n.placeholdertitle}}" title="{{$l10n.placeholdertitle}}" value="{{$title}}" tabindex="1" dir="auto" />
|
2019-07-14 21:49:38 -04:00
|
|
|
</div>
|
2023-03-13 10:37:12 +01:00
|
|
|
{{if $l10n.placeholdercategory}}
|
2019-07-14 21:49:38 -04:00
|
|
|
<div id="jot-category-wrap">
|
2022-10-16 11:24:50 -04:00
|
|
|
<input name="category" id="jot-category" class="jothidden jotforms form-control" type="text" placeholder="{{$l10n.placeholdercategory}}" title="{{$l10n.placeholdercategory}}" value="{{$category}}" tabindex="2" dir="auto" />
|
2019-07-14 21:49:38 -04:00
|
|
|
</div>
|
2023-03-13 10:37:12 +01:00
|
|
|
{{/if}}
|
2019-07-14 21:49:38 -04:00
|
|
|
|
|
|
|
<p class="comment-edit-bb-{{$id}} comment-icon-list">
|
|
|
|
<span>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" class="btn btn-sm template-icon bb-img" aria-label="{{$l10n.edimg}}" title="{{$l10n.edimg}}" data-role="insert-formatting" data-bbcode="img" data-id="{{$id}}" tabindex="6">
|
2019-07-14 21:49:38 -04:00
|
|
|
<i class="fa fa-picture-o"></i>
|
|
|
|
</button>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" class="btn btn-sm template-icon bb-attach" aria-label="{{$l10n.edattach}}" title="{{$l10n.edattach}}" ondragenter="return commentLinkDrop(event, {{$id}});" ondragover="return commentLinkDrop(event, {{$id}});" ondrop="commentLinkDropper(event);" onclick="commentGetLink({{$id}}, '{{$l10n.prompttext}}');" tabindex="7">
|
2019-07-14 21:49:38 -04:00
|
|
|
<i class="fa fa-paperclip"></i>
|
|
|
|
</button>
|
|
|
|
</span>
|
|
|
|
<span>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" class="btn btn-sm template-icon bb-url" aria-label="{{$l10n.edurl}}" title="{{$l10n.edurl}}" onclick="insertFormatting('url',{{$id}});" tabindex="8">
|
2019-07-14 21:49:38 -04:00
|
|
|
<i class="fa fa-link"></i>
|
|
|
|
</button>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" class="btn btn-sm template-icon underline" aria-label="{{$l10n.eduline}}" title="{{$l10n.eduline}}" onclick="insertFormatting('u',{{$id}});" tabindex="9">
|
2019-07-14 21:49:38 -04:00
|
|
|
<i class="fa fa-underline"></i>
|
|
|
|
</button>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" class="btn btn-sm template-icon italic" aria-label="{{$l10n.editalic}}" title="{{$l10n.editalic}}" onclick="insertFormatting('i',{{$id}});" tabindex="10">
|
2019-07-14 21:49:38 -04:00
|
|
|
<i class="fa fa-italic"></i>
|
|
|
|
</button>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" class="btn btn-sm template-icon bold" aria-label="{{$l10n.edbold}}" title="{{$l10n.edbold}}" onclick="insertFormatting('b',{{$id}});" tabindex="11">
|
2019-07-14 21:49:38 -04:00
|
|
|
<i class="fa fa-bold"></i>
|
|
|
|
</button>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" class="btn btn-sm template-icon quote" aria-label="{{$l10n.edquote}}" title="{{$l10n.edquote}}" onclick="insertFormatting('quote',{{$id}});" tabindex="12">
|
2019-07-14 21:49:38 -04:00
|
|
|
<i class="fa fa-quote-left"></i>
|
|
|
|
</button>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button id="button_emojipicker" type="button" class="btn btn-sm template-icon emojis" aria-label="{{$l10n.edemojis}}" title="{{$l10n.edemojis}}" tabindex="13">
|
2023-05-04 10:54:29 +00:00
|
|
|
<i class="fa fa-smile-o"></i>
|
|
|
|
</button>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" class="btn btn-sm template-icon bb-url" aria-label="{{$l10n.contentwarn}}" title="{{$l10n.contentwarn}}" onclick="insertFormatting('abstract',{{$id}});" tabindex="14">
|
2023-06-15 12:55:54 -04:00
|
|
|
<i class="fa fa-eye"></i>
|
|
|
|
</button>
|
2019-07-14 21:49:38 -04:00
|
|
|
</span>
|
|
|
|
</p>
|
2024-09-19 14:08:41 +02:00
|
|
|
<div id="dropzone-{{$id}}" class="dropzone">
|
2023-03-14 10:38:03 +01:00
|
|
|
<p>
|
2024-08-22 10:59:06 +02:00
|
|
|
<textarea id="comment-edit-text-{{$id}}" class="comment-edit-text form-control text-autosize expandable-textarea" name="body" placeholder="{{$l10n.default}}" rows="18" tabindex="3" dir="auto" onkeydown="sendOnCtrlEnter(event, 'comment-edit-submit-{{$id}}')">{{$body}}</textarea>
|
2023-03-14 10:38:03 +01:00
|
|
|
</p>
|
|
|
|
</div>
|
2019-07-14 21:49:38 -04:00
|
|
|
<p class="comment-edit-submit-wrapper">
|
|
|
|
{{if $type == 'post'}}
|
|
|
|
<span role="presentation" class="form-inline">
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" name="permissions" class="btn btn-sm template-icon" id="toggle-permissions" title="{{$l10n.toggle_permissions_tooltip}}" onclick="togglePermissions()" style="margin-right: 10px;" tabindex="5">
|
|
|
|
<i class="fa fa-ellipsis-h"></i> {{$l10n.toggle_permissions}}
|
|
|
|
</button>
|
|
|
|
<input type="text" name="location" class="form-control" id="jot-location" value="{{$location}}" placeholder="{{$l10n.location_set}}" tabindex="6"/>
|
|
|
|
<button type="button" class="btn btn-sm template-icon" id="profile-location"
|
2023-03-13 10:37:12 +01:00
|
|
|
data-title-set="{{$l10n.location_set}}"
|
|
|
|
data-title-disabled="{{$l10n.location_disabled}}"
|
|
|
|
data-title-unavailable="{{$l10n.location_unavailable}}"
|
|
|
|
data-title-clear="{{$l10n.location_clear}}"
|
|
|
|
title="{{$l10n.location_set}}"
|
2024-08-22 10:59:06 +02:00
|
|
|
tabindex="7">
|
2019-07-14 21:49:38 -04:00
|
|
|
<i class="fa fa-map-marker" aria-hidden="true"></i>
|
|
|
|
</button>
|
|
|
|
</span>
|
|
|
|
{{/if}}
|
|
|
|
<span role="presentation" id="profile-rotator-wrapper">
|
2022-10-16 11:24:50 -04:00
|
|
|
<img role="presentation" id="profile-rotator" src="images/rotator.gif" alt="{{$l10n.wait}}" title="{{$l10n.wait}}" style="display: none;" />
|
2019-07-14 21:49:38 -04:00
|
|
|
</span>
|
|
|
|
<span role="presentation" id="character-counter" class="grey text-info"></span>
|
2024-08-22 10:59:06 +02:00
|
|
|
<button type="button" class="btn btn-default" onclick="preview_comment({{$id}});" id="comment-edit-preview-link-{{$id}}" tabindex="8"><i class="fa fa-eye"></i> {{$l10n.preview}}</button>
|
|
|
|
<button type="submit" class="btn btn-primary" id="comment-edit-submit-{{$id}}" name="submit" tabindex="9"><i class="fa fa-envelope"></i> {{$l10n.submit}}</button>
|
2019-07-14 21:49:38 -04:00
|
|
|
</p>
|
|
|
|
|
|
|
|
<div id="comment-edit-preview-{{$id}}" class="comment-edit-preview" style="display:none;"></div>
|
|
|
|
|
2024-08-22 10:59:06 +02:00
|
|
|
<div id="permissions-section" style="display: none;">
|
2025-01-10 23:26:15 +01:00
|
|
|
<script>
|
|
|
|
dzFactory.setupDropzone('#dropzone-{{$id}}', 'comment-edit-text-{{$id}}');
|
|
|
|
</script>
|
2019-07-14 21:49:38 -04:00
|
|
|
{{if $type == 'post'}}
|
2022-10-16 11:24:50 -04:00
|
|
|
<h3>{{$l10n.visibility_title}}</h3>
|
2019-11-28 12:53:12 -05:00
|
|
|
{{$acl_selector nofilter}}
|
2019-07-14 22:48:08 -04:00
|
|
|
|
2019-07-14 21:49:38 -04:00
|
|
|
<div class="jotplugins">
|
|
|
|
{{$jotplugins nofilter}}
|
|
|
|
</div>
|
2021-08-01 13:01:31 +00:00
|
|
|
|
|
|
|
{{if $scheduled_at}}{{$scheduled_at nofilter}}{{/if}}
|
2022-04-13 05:31:32 +00:00
|
|
|
{{if $created_at}}{{$created_at nofilter}}{{/if}}
|
2019-11-28 12:53:12 -05:00
|
|
|
{{else}}
|
2023-05-13 19:54:35 -04:00
|
|
|
<input type="hidden" name="circle_allow" value="{{$circle_allow}}"/>
|
2019-11-28 12:53:12 -05:00
|
|
|
<input type="hidden" name="contact_allow" value="{{$contact_allow}}"/>
|
2023-05-13 19:54:35 -04:00
|
|
|
<input type="hidden" name="circle_deny" value="{{$circle_deny}}"/>
|
2019-11-28 12:53:12 -05:00
|
|
|
<input type="hidden" name="contact_deny" value="{{$contact_deny}}"/>
|
2019-07-14 21:49:38 -04:00
|
|
|
{{/if}}
|
2024-08-22 10:59:06 +02:00
|
|
|
</div>
|
|
|
|
</form>
|
|
|
|
</div>
|
2022-12-08 20:38:44 +01:00
|
|
|
</div>
|
2023-03-13 03:32:28 +01:00
|
|
|
<script>
|
2024-08-03 07:41:59 +02:00
|
|
|
document.addEventListener("DOMContentLoaded", function() {
|
|
|
|
var textareas = document.querySelectorAll(".expandable-textarea");
|
|
|
|
|
2024-08-03 15:28:38 +02:00
|
|
|
textareas.forEach(function(textarea) {
|
|
|
|
textarea.addEventListener("input", function() {
|
|
|
|
this.style.height = "auto";
|
|
|
|
this.style.height = (this.scrollHeight) + "px";
|
|
|
|
});
|
2024-08-03 07:41:59 +02:00
|
|
|
|
2024-08-03 15:28:38 +02:00
|
|
|
// Set initial height
|
|
|
|
textarea.style.height = "auto";
|
|
|
|
textarea.style.height = (textarea.scrollHeight) + "px";
|
|
|
|
});
|
2024-08-01 21:10:33 +02:00
|
|
|
});
|
2024-08-22 10:59:06 +02:00
|
|
|
|
2024-09-15 17:55:50 +02:00
|
|
|
function togglePermissions() {
|
|
|
|
var permissionsSection = document.getElementById('permissions-section');
|
|
|
|
if (permissionsSection.style.display === 'none' || permissionsSection.style.display === '') {
|
|
|
|
permissionsSection.style.display = 'block';
|
|
|
|
} else {
|
|
|
|
permissionsSection.style.display = 'none';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Warn the user before leaving the page
|
|
|
|
var formSubmitting = false;
|
|
|
|
|
|
|
|
function setFormSubmitting() {
|
|
|
|
formSubmitting = true;
|
2024-09-16 18:22:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
document.addEventListener("DOMContentLoaded", function() {
|
|
|
|
var textareas = document.querySelectorAll(".expandable-textarea");
|
|
|
|
|
|
|
|
textareas.forEach(function(textarea) {
|
|
|
|
// Set initial height and restore saved content
|
|
|
|
textarea.style.height = "auto";
|
|
|
|
textarea.style.height = (textarea.scrollHeight) + "px";
|
|
|
|
|
|
|
|
const savedContent = localStorage.getItem(`comment-edit-text-${textarea.id}`);
|
|
|
|
const lastSaved = localStorage.getItem(`last-saved-${textarea.id}`);
|
|
|
|
|
|
|
|
if (savedContent && lastSaved) {
|
|
|
|
// Check whether 10 minutes have elapsed since the last save
|
|
|
|
const currentTime = new Date().getTime();
|
|
|
|
const timeElapsed = currentTime - parseInt(lastSaved, 10);
|
|
|
|
|
|
|
|
if (timeElapsed <= 600000) { // 600000 ms = 10 Minuten
|
|
|
|
textarea.value = savedContent;
|
|
|
|
textarea.style.height = "auto";
|
|
|
|
textarea.style.height = (textarea.scrollHeight) + "px";
|
|
|
|
} else {
|
|
|
|
// Content is older than 10 minutes, therefore delete
|
|
|
|
localStorage.removeItem(`comment-edit-text-${textarea.id}`);
|
|
|
|
localStorage.removeItem(`last-saved-${textarea.id}`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// Auto-save content to localStorage every 5 seconds
|
|
|
|
setInterval(() => {
|
|
|
|
var textareas = document.querySelectorAll(".expandable-textarea");
|
|
|
|
textareas.forEach(function(textarea) {
|
|
|
|
if (textarea.value.trim() !== "") {
|
|
|
|
// Saving the content
|
|
|
|
localStorage.setItem(`comment-edit-text-${textarea.id}`, textarea.value);
|
|
|
|
|
|
|
|
// Saving the timestamp of the last save
|
|
|
|
const currentTime = new Date().getTime();
|
|
|
|
localStorage.setItem(`last-saved-${textarea.id}`, currentTime.toString());
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}, 5000);
|
|
|
|
|
|
|
|
// Remove content saved when submitting the form
|
|
|
|
function setFormSubmitting() {
|
|
|
|
formSubmitting = true;
|
|
|
|
|
|
|
|
// Removing the content from localStorage
|
2024-09-15 17:55:50 +02:00
|
|
|
var textareas = document.querySelectorAll(".expandable-textarea");
|
|
|
|
textareas.forEach(function(textarea) {
|
|
|
|
localStorage.removeItem(`comment-edit-text-${textarea.id}`);
|
2024-09-16 18:22:58 +02:00
|
|
|
localStorage.removeItem(`last-saved-${textarea.id}`);
|
2024-09-15 17:55:50 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
window.addEventListener("beforeunload", function (event) {
|
|
|
|
if (!formSubmitting) {
|
2024-09-16 18:22:58 +02:00
|
|
|
// Get the value of the text field
|
|
|
|
var textField = document.getElementById('comment-edit-text-{{$id}}').value.trim();
|
|
|
|
|
|
|
|
// Check whether the text field contains at least one character
|
|
|
|
if (textField.length > 0) {
|
|
|
|
var confirmationMessage = 'Are you sure you want to reload the page? All unsaved changes will be lost.';
|
|
|
|
event.returnValue = confirmationMessage;
|
|
|
|
return confirmationMessage;
|
|
|
|
}
|
2024-09-15 17:55:50 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// Set the formSubmitting flag when the form is submitted
|
|
|
|
document.getElementById('comment-edit-form-{{$id}}').addEventListener('submit', setFormSubmitting);
|
2023-05-13 19:54:35 -04:00
|
|
|
</script>
|