/** * Created by logicp on 6/05/17. */ (function($, Drupal, drupalSettings) { Drupal.behaviors.status= { attach: function (context, settings) { Drupal.AjaxCommands.prototype.generatePreview = function(ajax, response, status) { if (validateUrl(response.url)) { var cleanUrl = response.url.replace(/^http(s?):\/\//i, ""); // console.log(cleanUrl); $.ajax({ type: 'POST', url: '/statusmessage/generate-preview/build' , data: {'data': cleanUrl}, success: function (response) { // console.log(response.data); if (response.data != null) { var parser = new DOMParser(); // var doc = parser.parseFromString(response.data, "text/html"); let markup = document.createElement('div'); markup.innerHTML = response.data; let statusTextBox = document.getElementById('edit-message'); let oldPreviewIframe = document.querySelector('.statusmessage-preview-iframe'); if (oldPreviewIframe !== null) { oldPreviewIframe.parentNode.removeChild(oldPreviewIframe); } var cssLink = document.createElement("link") cssLink.href = "/modules/statusmessage/css/preview.css"; cssLink .rel = "stylesheet"; cssLink .type = "text/css"; previewIframe = document.createElement('iframe'); previewIframe.classList.add('statusmessage-preview-iframe'); statusTextBox.parentNode.appendChild(previewIframe); previewIframe.contentWindow.document.open(); previewIframe.contentWindow.document.appendChild(markup); previewIframe.contentWindow.document.documentElement.appendChild(cssLink); previewIframe.contentWindow.document.close(); } } }); } }; function validateUrl(input) { if (input !== null) { return input.match(new RegExp("([a-zA-Z0-9]+://)?([a-zA-Z0-9_]+:[a-zA-Z0-9_]+@)?([a-zA-Z0-9.-]+\\.[A-Za-z]{2,4})(:[0-9]+)?(/.*)?")); } } Drupal.AjaxCommands.prototype.clearPreview = function(ajax, response, status) { if (response.clear == true) { let oldPreviewIframe = document.querySelector('.statusmessage-preview-iframe'); if (oldPreviewIframe !== null) { oldPreviewIframe.parentNode.removeChild(oldPreviewIframe); Drupal.attachBehaviors(); } } }; } }; $(document).ready(function() { //Place listener on status post button //If status message is empty, prevent submit and alert the user let statusPostButton = document.getElementById('edit-post'); let alertDialog = document.createElement('div'); alertDialog.id = 'status-dialog'; alertDialog.title = 'Status Alert'; alertDialog.innerHTML = '
Enter a status message
'; statusPostButton.addEventListener('click', function() { let textBox = document.getElementById('edit-message'); console.dir(textBox); comparison = textBox.value === 0; console.log(comparison); if (textBox.value.length === 0) { event.preventDefault(); event.stopPropagation(); event.stopImmediatePropagation(); // alert('Enter a status message'); $(alertDialog).dialog(); } else { textBox.value = ""; } }); }); // let uploadButton = $('#edit-media-upload'); // uploadButton.hide(); // $('.status-media-upload').click(function() { // console.log('This is firing'); // if (uploadButton.is(':visible')) { // uploadButton.hide(); // } else { // uploadButton.show(); // } // }); })(jQuery, Drupal, drupalSettings);