From 869de0d11338ce0ed97feafd7ab3acfb931a0e72 Mon Sep 17 00:00:00 2001 From: nightwing Date: Sun, 3 Feb 2013 17:38:58 +0400 Subject: [PATCH] improve textarea plugin --- build_support/editor_textarea.html | 2 +- lib/ace/ext/textarea.js | 62 ++++++++++++++++++++---------- 2 files changed, 42 insertions(+), 22 deletions(-) diff --git a/build_support/editor_textarea.html b/build_support/editor_textarea.html index 9d878a1e..bb691c11 100644 --- a/build_support/editor_textarea.html +++ b/build_support/editor_textarea.html @@ -88,7 +88,7 @@ inject(function () { var ace = window.__ace_shadowed__; var t = document.querySelector("textarea"); textAce = ace.transformTextarea(t, window.__ace_loader__); - textAce.setDisplaySettings(true); + setTimeout(function(){textAce.setDisplaySettings(true)}); }); diff --git a/lib/ace/ext/textarea.js b/lib/ace/ext/textarea.js index a36db850..fe5066b0 100644 --- a/lib/ace/ext/textarea.js +++ b/lib/ace/ext/textarea.js @@ -177,7 +177,8 @@ exports.transformTextarea = function(element, loader) { left: "0px", right: "0px", bottom: "0px", - border: "1px solid gray" + border: "1px solid gray", + position: "absolute" }); container.appendChild(editorDiv); @@ -198,7 +199,7 @@ exports.transformTextarea = function(element, loader) { var settingDiv = document.createElement("div"); var settingDivStyles = { top: "0px", - left: "0px", + left: "20%", right: "0px", bottom: "0px", position: "absolute", @@ -207,7 +208,8 @@ exports.transformTextarea = function(element, loader) { color: "white", display: "none", overflow: "auto", - fontSize: "14px" + fontSize: "14px", + boxShadow: "-5px 2px 3px gray" }; if (!UA.isOldIE) { settingDivStyles.backgroundColor = "rgba(0, 0, 0, 0.6)"; @@ -228,7 +230,7 @@ exports.transformTextarea = function(element, loader) { editor.focus(); // Add the settingPanel opener to the editor's div. - editorDiv.appendChild(settingOpener); + container.appendChild(settingOpener); // Create the API. setupApi(editor, editorDiv, settingDiv, ace, options, loader); @@ -280,13 +282,22 @@ function setupApi(editor, editorDiv, settingDiv, ace, options, loader) { loader = loader || load; function toBool(value) { - return value == "true"; + return value === "true" || value == true; } editor.setDisplaySettings = function(display) { if (display == null) display = settingDiv.style.display == "none"; - settingDiv.style.display = display ? "block" : "none"; + if (display) { + settingDiv.style.display = "block"; + settingDiv.hideButton.focus(); + editor.on("focus", function onFocus() { + editor.removeListener("focus", onFocus); + settingDiv.style.display = "none" + }); + } else { + editor.focus(); + }; }; editor.setOption = function(key, value) { @@ -393,10 +404,7 @@ function setupApi(editor, editorDiv, settingDiv, ace, options, loader) { } function setupSettingPanel(settingDiv, settingOpener, editor, options) { - var BOOL = { - "true": true, - "false": false - }; + var BOOL = null; var desc = { mode: "Mode:", @@ -484,6 +492,14 @@ function setupSettingPanel(settingDiv, settingOpener, editor, options) { table.push(""); function renderOption(builder, option, obj, cValue) { + if (!obj) { + builder.push( + "" + ); + return + } builder.push("
SettingValue