123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- /**
- * 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 = '<p>Enter a status message</p>';
- 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);
|