Einzelnen Beitrag anzeigen

Benutzerbild von fkerber
fkerber
(CodeLib-Manager)

Registriert seit: 9. Jul 2003
Ort: Ensdorf
6.723 Beiträge
 
Delphi XE Professional
 
#9

Re: RegEx o.ä. - Problem

  Alt 14. Aug 2007, 02:02
Hi!
Ich erstelle jetzt ausnahmsweise zwei Beiträge hintereinander, da der hier dann kompakt den Code enthält.

Ausgeführt wird der Code (Javascript-Code) in einem "Event", dass der tinyMCE abfeuert, wenn Text in den Editor geladen wird oder aus ihm ausgelesen wird...

Unterstützt wird die Umwandlung der Formatierungen "Fett", "Kursiv", "Unterstrichen" und "Ausrichtung". Von Haus aus kann der Editor Schriftformatierungen (also Farbe und Schriftgröße) von "normal" zu <span> und zurück umwandeln. Diese Elemente werden also in untenstehendem Code quasi übersprungen.

Einen Fehler konnte ich nicht finden, alles hat bislang einwandfrei funktioniert. Über die Art und Weise der Umwandlung kann man vllt. streiten und deswegen würde ich euch um Anregungen bitten, falls ihr etwas anders/schneller/besser machen würdet.

Nun also der Code:

Code:
function myCustomCleanup(type, value)
{

  if (type == "get_from_editor")
  {
    value = value.replace(/[b]/g, "<span style='font-weight: bold'>");
    value = value.replace(/<\/strong>/g, "<\/span>");

    value = value.replace(/<u>/g, "<span style='text-decoration: underline'>");
    value = value.replace(/<\/u>/g, "<\/span>");

    value = value.replace(/[i]/g, "<span style='font-style: italic'>");
    value = value.replace(/<\/em>/g, "<\/span>");

    value = value.replace(/align=\"([a-z]*)\"/g, " style='text-align: $1' ")

   return value;
  }


  if (type == "insert_to_editor")
  {
    var i;
    var bold_array = new Array;
    var italic_array = new Array;
    var underline_array = new Array;
    var span_array = new Array;
    var color_array = new Array;
    var fs_array = new Array;
    var position;
    var pos;
    var k = 0;
    var value1 = "";
    var lastinserted = new Array();
 
    value = value.replace(/style=\'text-align: ([a-z]*)\'/g, " align='$1' ");
    value = value.replace(/style=\"text-align: ([a-z]*)\"/g, " align='$1' ");

    i = 0;
    while (value.indexOf("<span style='font-weight: bold'>", i) != -1)
    {
      position = value.indexOf("<span style='font-weight: bold'>", i);
      bold_array.push(position+"b");
      i = 1+position;
    }

    i = 0;
    while (value.indexOf("<span style='font-style: italic'>", i) != -1)
    {
      position = value.indexOf("<span style='font-style: italic'>", i);
      italic_array.push(position+"i");
      i = 1+position;
    }

    i = 0;
    while (value.indexOf("<span style='text-decoration: underline'>", i) != -1)
    {
      position = value.indexOf("<span style='text-decoration: underline'>", i);
      underline_array.push(position+"u");
      i = 1+position;
    }

    i = 0;
    while (value.indexOf("<span style='color", i) != -1)
    {
      position = value.indexOf("<span style='color", i);
      color_array.push(position+"x");
      i = 1+position;
    }

    i = 0;
    while (value.indexOf("<span style='font-size", i) != -1)
    {
      position = value.indexOf("<span style='font-size", i);
      fs_array.push(position+"x");
      i = 1+position;
    }


    i = 0;
    while (value.indexOf("</span>", i) != -1)
    {
       position = value.indexOf("</span>", i);
       span_array.push(position+"e");
       i = 1+position;
    }

    function Numsort (a, b)
    {
      a=a.substr(0,((a.length)-1));
      b=b.substr(0,((b.length)-1));
     return a - b;
    }

    bold_array = bold_array.concat(italic_array);
    bold_array = bold_array.concat(underline_array);
    bold_array = bold_array.concat(color_array);
    bold_array = bold_array.concat(fs_array);
    bold_array = bold_array.concat(span_array);

    bold_array.sort(Numsort);

    for (i =0; i < bold_array.length; i++)
    {
      pos = bold_array[i].substr(0,((bold_array[i].length)-1));
      endpos = value.indexOf(">",pos);
 
      value1=value1+value.substring(k, pos);
 
 
      if (bold_array[i].substr((bold_array[i].length-1),1) == "b")
      {
        value1 = value1 + "[b]";
        lastinserted.push("[/b]");
      }

      if (bold_array[i].substr((bold_array[i].length-1),1) == "i")
      {
        value1 = value1 + "[i]";
        lastinserted.push("[/i]");
      }

      if (bold_array[i].substr((bold_array[i].length-1),1) == "u")
      {
        value1 = value1 + "<u>";
        lastinserted.push("</u>");
      }

      if (bold_array[i].substr((bold_array[i].length-1),1) == "x")
      {
        value1 = value1 + value.substring(pos,endpos+1);
        lastinserted.push("</span>");
      } 


      if (bold_array[i].substr((bold_array[i].length-1),1) == "e")
      { 
        value1 = value1 + lastinserted.pop();
      }
 
      k = endpos+1;
 
      if (i == (bold_array.length-1))
      {
        value1 = value1 + value.substr(k);
      }
    } /*for-Schleife*/

    if (value1 != "")
    {
      value = value1;
    }
   return value;
  } /*Insert to Editor*/
 return value;
}
Also: Feuer frei


Ciao und danke
Frederic

[edit=Phoenix]Holla, Formatierung war zerlegt. Neu gespeichert wegen Cache... Mfg, Phoenix[/edit]
Frederic Kerber
  Mit Zitat antworten Zitat