Refactored tools services endpoints system.
This commit is contained in:
		@@ -1,54 +1,90 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html>
 | 
			
		||||
 | 
			
		||||
<head>
 | 
			
		||||
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | 
			
		||||
  <meta charset="utf-8" />
 | 
			
		||||
  <head>
 | 
			
		||||
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | 
			
		||||
    <meta charset="utf-8" />
 | 
			
		||||
 | 
			
		||||
  <link rel="stylesheet" href="../assets/css/tools/r11form.css">
 | 
			
		||||
  <link rel="stylesheet" href="../assets/css/json.css">
 | 
			
		||||
  <link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/styles/default.min.css">
 | 
			
		||||
  <script src="//cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/highlight.min.js"></script>
 | 
			
		||||
  <script src="../assets/scripts/tools/scripts.js"></script>
 | 
			
		||||
  <script src="../assets/scripts/tools/json.js"></script>
 | 
			
		||||
  <script>hljs.highlightAll();</script>
 | 
			
		||||
</head>
 | 
			
		||||
    <link rel="stylesheet" href="../assets/css/tools/r11form.css">
 | 
			
		||||
    <link rel="stylesheet" href="../assets/css/json.css">
 | 
			
		||||
    <link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/styles/default.min.css">
 | 
			
		||||
    <script src="//cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/highlight.min.js"></script>
 | 
			
		||||
    <script src="../assets/scripts/tools/scripts.js"></script>
 | 
			
		||||
    <script src="../assets/scripts/tools/json.js"></script>
 | 
			
		||||
    <script>hljs.highlightAll();</script>
 | 
			
		||||
  </head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
  <div class="container">
 | 
			
		||||
    <div id="tool" class="tool rwd-expandable">
 | 
			
		||||
      <div class="tool-context">
 | 
			
		||||
        <div class="headline">
 | 
			
		||||
          <h1>Online JSON Formatter</h1>
 | 
			
		||||
  <body>
 | 
			
		||||
    <div class="container">
 | 
			
		||||
      <div id="tool" class="tool rwd-expandable">
 | 
			
		||||
        <div class="tool-context">
 | 
			
		||||
          <div class="headline">
 | 
			
		||||
            <h1>Online JSON Formatter</h1>
 | 
			
		||||
          </div>
 | 
			
		||||
 | 
			
		||||
          <p style="margin-bottom: -30px" id="processInfo"></p>
 | 
			
		||||
 | 
			
		||||
          <pre>
 | 
			
		||||
            <code class="hightlight-json json-block" id="jsonBlock" contenteditable="True">{"enter": "your", "json": "here"}</code>
 | 
			
		||||
          </pre>
 | 
			
		||||
 | 
			
		||||
          <button style="margin-top: 20px"
 | 
			
		||||
                  class="max-width block-label action-button active"
 | 
			
		||||
                  onclick="formatAndValidateJson('processInfo')"
 | 
			
		||||
          >Prettify JSON</button>
 | 
			
		||||
 | 
			
		||||
          <button class="max-width block-label action-button active"
 | 
			
		||||
                  onclick="minimizeJson('processInfo')"
 | 
			
		||||
          >Minimize JSON</button>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <p style="margin-bottom: -30px" id="processInfo"></p>
 | 
			
		||||
 | 
			
		||||
        <pre>
 | 
			
		||||
          <code class="hightlight-json json-block" id="jsonBlock" contenteditable="True">{"enter": "your", "json": "here"}</code>
 | 
			
		||||
        </pre>
 | 
			
		||||
 | 
			
		||||
        <button style="margin-top: 20px"
 | 
			
		||||
                class="max-width block-label action-button active"
 | 
			
		||||
                onclick="formatAndValidateJson('processInfo')"
 | 
			
		||||
        >Prettify JSON</button>
 | 
			
		||||
 | 
			
		||||
        <button class="max-width block-label action-button active"
 | 
			
		||||
                onclick="minimizeJson('processInfo')"
 | 
			
		||||
        >Minimize JSON</button>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
      <div class="tooltip-window rwd-hideable">
 | 
			
		||||
        <h2>What is this?</h2>
 | 
			
		||||
        <p>This tool has 2 main functions:
 | 
			
		||||
        <ul>
 | 
			
		||||
          <li><strong>Prettify JSON</strong> to make it human-readable (add indentation etc.)</li>
 | 
			
		||||
          <li><strong>Minimize JSON</strong> to make it more compact (exactly opposite to above)</li>
 | 
			
		||||
        </ul>
 | 
			
		||||
        </p>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
    <div class="tooltip-window rwd-hideable">
 | 
			
		||||
      <h2>What is this?</h2>
 | 
			
		||||
      <p>This tool has 2 main functions:
 | 
			
		||||
      <ul>
 | 
			
		||||
        <li><strong>Prettify JSON</strong> to make it human-readable (add indentation etc.)</li>
 | 
			
		||||
        <li><strong>Minimize JSON</strong> to make it more compact (exactly opposite to above)</li>
 | 
			
		||||
      </ul>
 | 
			
		||||
      </p>
 | 
			
		||||
    </div>
 | 
			
		||||
    <script>
 | 
			
		||||
 | 
			
		||||
  </div>
 | 
			
		||||
</body>
 | 
			
		||||
      const editorEle = document.getElementById('jsonBlock');
 | 
			
		||||
 | 
			
		||||
      // Handle the `paste` event
 | 
			
		||||
      editorEle.addEventListener('paste', function (e) {
 | 
			
		||||
        // Prevent the default action
 | 
			
		||||
        e.preventDefault();
 | 
			
		||||
 | 
			
		||||
        // Get the copied text from the clipboard
 | 
			
		||||
        const text = e.clipboardData
 | 
			
		||||
            ? (e.originalEvent || e).clipboardData.getData('text/plain')
 | 
			
		||||
            : // For IE
 | 
			
		||||
            window.clipboardData
 | 
			
		||||
                ? window.clipboardData.getData('Text')
 | 
			
		||||
                : '';
 | 
			
		||||
 | 
			
		||||
        if (document.queryCommandSupported('insertText')) {
 | 
			
		||||
          document.execCommand('insertText', false, text);
 | 
			
		||||
        } else {
 | 
			
		||||
          // Insert text at the current position of caret
 | 
			
		||||
          const range = document.getSelection().getRangeAt(0);
 | 
			
		||||
          range.deleteContents();
 | 
			
		||||
 | 
			
		||||
          const textNode = document.createTextNode(text);
 | 
			
		||||
          range.insertNode(textNode);
 | 
			
		||||
          range.selectNodeContents(textNode);
 | 
			
		||||
          range.collapse(false);
 | 
			
		||||
 | 
			
		||||
          const selection = window.getSelection();
 | 
			
		||||
          selection.removeAllRanges();
 | 
			
		||||
          selection.addRange(range);
 | 
			
		||||
        }
 | 
			
		||||
      });
 | 
			
		||||
    </script>
 | 
			
		||||
  </body>
 | 
			
		||||
</html>
 | 
			
		||||
 
 | 
			
		||||
@@ -1,79 +1,79 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html>
 | 
			
		||||
 | 
			
		||||
<head>
 | 
			
		||||
    <!-- <link rel="stylesheet" href="styles.css"> -->
 | 
			
		||||
    <link rel="stylesheet" href="../assets/css/tools/r11form.css">
 | 
			
		||||
    <script src="../assets/scripts/tools/scripts.js"></script>
 | 
			
		||||
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | 
			
		||||
    <meta charset="utf-8" />
 | 
			
		||||
</head>
 | 
			
		||||
    <head>
 | 
			
		||||
        <!-- <link rel="stylesheet" href="styles.css"> -->
 | 
			
		||||
        <link rel="stylesheet" href="../assets/css/tools/r11form.css">
 | 
			
		||||
        <script src="../assets/scripts/tools/scripts.js"></script>
 | 
			
		||||
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | 
			
		||||
        <meta charset="utf-8" />
 | 
			
		||||
    </head>
 | 
			
		||||
 | 
			
		||||
<body onload="init();">
 | 
			
		||||
    <div class="container">
 | 
			
		||||
        <div id="tool" class="tool rwd-expandable">
 | 
			
		||||
            <div class="tool-context">
 | 
			
		||||
                <div class="headline">
 | 
			
		||||
                    <h1>Online XML Formatter</h1>
 | 
			
		||||
                </div>
 | 
			
		||||
                <select name="processors" id="processors" class="hidden">
 | 
			
		||||
                    <option value="libxml">libXML</option>
 | 
			
		||||
                </select>
 | 
			
		||||
 | 
			
		||||
                <div class="display-space-between">
 | 
			
		||||
                    <div>
 | 
			
		||||
                        <b><span id="formatinfo"></span></b><br>
 | 
			
		||||
                        <label for="xmlArea"><b>Insert your XML:</b></label>
 | 
			
		||||
    <body onload="init();">
 | 
			
		||||
        <div class="container">
 | 
			
		||||
            <div id="tool" class="tool rwd-expandable">
 | 
			
		||||
                <div class="tool-context">
 | 
			
		||||
                    <div class="headline">
 | 
			
		||||
                        <h1>Online XML Formatter</h1>
 | 
			
		||||
                    </div>
 | 
			
		||||
                    <div>
 | 
			
		||||
                        <button class="action-button active" id="clearXMLButton" style="padding: 3px 10px;"
 | 
			
		||||
                            onclick="clearDataField()">Clear</button>
 | 
			
		||||
                        <button class="action-button active" id="defaultXMLButton" style="padding: 3px 10px;"
 | 
			
		||||
                            onclick="fillDefaultXML(this)">Insert default XML</button>
 | 
			
		||||
                    <select name="processors" id="processors" class="hidden">
 | 
			
		||||
                        <option value="libxml">libXML</option>
 | 
			
		||||
                    </select>
 | 
			
		||||
 | 
			
		||||
                    <div class="display-space-between">
 | 
			
		||||
                        <div>
 | 
			
		||||
                            <b><span id="formatinfo"></span></b><br>
 | 
			
		||||
                            <label for="xmlArea"><b>Insert your XML:</b></label>
 | 
			
		||||
                        </div>
 | 
			
		||||
                        <div>
 | 
			
		||||
                            <button class="action-button active" id="clearXMLButton" style="padding: 3px 10px;"
 | 
			
		||||
                                onclick="clearDataField()">Clear</button>
 | 
			
		||||
                            <button class="action-button active" id="defaultXMLButton" style="padding: 3px 10px;"
 | 
			
		||||
                                onclick="fillDefaultXML(this)">Insert default XML</button>
 | 
			
		||||
                        </div>
 | 
			
		||||
 | 
			
		||||
                    </div>
 | 
			
		||||
 | 
			
		||||
                    <textarea id="xmlArea" name="xmlArea" rows="15"
 | 
			
		||||
                        class="textarea-700 bordered-field vertically-resizeable max-width"
 | 
			
		||||
                        onblur="setDefaultContent(this, 'Insert XML here');"
 | 
			
		||||
                        onfocus="clearDefaultContent(this, 'Insert XML here');"></textarea>
 | 
			
		||||
                    <br><br>
 | 
			
		||||
                    <button id="prettifyButton" class="max-width block-label action-button active"
 | 
			
		||||
                        onclick="performFormatRequest('prettifypost', true, 'xmlArea', 'xmlArea')">Prettify XML</button>
 | 
			
		||||
                    <button id="minimizeButton" class="max-width block-label action-button active"
 | 
			
		||||
                        onclick="performFormatRequest('minimizepost', true, 'xmlArea', 'xmlArea')">Minimize XML</button>
 | 
			
		||||
 | 
			
		||||
                </div>
 | 
			
		||||
                
 | 
			
		||||
                <textarea id="xmlArea" name="xmlArea" rows="15"
 | 
			
		||||
                    class="textarea-700 bordered-field vertically-resizeable max-width"
 | 
			
		||||
                    onblur="setDefaultContent(this, 'Insert XML here');"
 | 
			
		||||
                    onfocus="clearDefaultContent(this, 'Insert XML here');"></textarea>
 | 
			
		||||
                <br><br>
 | 
			
		||||
                <button id="prettifyButton" class="max-width block-label action-button active"
 | 
			
		||||
                    onclick="performFormatRequest('prettifypost', true, 'xmlArea', 'xmlArea')">Prettify XML</button>
 | 
			
		||||
                <button id="minimizeButton" class="max-width block-label action-button active"
 | 
			
		||||
                    onclick="performFormatRequest('minimizepost', true, 'xmlArea', 'xmlArea')">Minimize XML</button>
 | 
			
		||||
                
 | 
			
		||||
            </div>
 | 
			
		||||
        </div>
 | 
			
		||||
        <div class="tooltip-window rwd-hideable">
 | 
			
		||||
            <h2>What is this?</h2>
 | 
			
		||||
            <p>This tool has 2 main functions: 
 | 
			
		||||
                <ul>
 | 
			
		||||
                    <li><strong>Prettify XML</strong> to make it human-readable (add indentation etc.)</li>
 | 
			
		||||
                    <li><strong>Minimize XML</strong> to make it more compact (exactly opposite to above)</li>
 | 
			
		||||
                </ul>
 | 
			
		||||
            </p>
 | 
			
		||||
            <div class="tooltip-window rwd-hideable">
 | 
			
		||||
                <h2>What is this?</h2>
 | 
			
		||||
                <p>This tool has 2 main functions:
 | 
			
		||||
                    <ul>
 | 
			
		||||
                        <li><strong>Prettify XML</strong> to make it human-readable (add indentation etc.)</li>
 | 
			
		||||
                        <li><strong>Minimize XML</strong> to make it more compact (exactly opposite to above)</li>
 | 
			
		||||
                    </ul>
 | 
			
		||||
                </p>
 | 
			
		||||
            </div>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <script>
 | 
			
		||||
            function getProcessor() {
 | 
			
		||||
                return "libxml";
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            function getVersion() {
 | 
			
		||||
                return "1.0"
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
    </div>
 | 
			
		||||
            function init() {
 | 
			
		||||
                setDefaultContent(document.getElementById("xmlArea"), 'Insert XML here');
 | 
			
		||||
            }
 | 
			
		||||
        </script>
 | 
			
		||||
 | 
			
		||||
    <script>
 | 
			
		||||
        function getProcessor() {
 | 
			
		||||
            return "libxml";
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        function getVersion() {
 | 
			
		||||
            return "1.0"
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        function init() {
 | 
			
		||||
            setDefaultContent(document.getElementById("xmlArea"), 'Insert XML here');
 | 
			
		||||
        }
 | 
			
		||||
    </script>
 | 
			
		||||
 | 
			
		||||
</body>
 | 
			
		||||
    </body>
 | 
			
		||||
 | 
			
		||||
</html>
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user