Upgrade to Xinha 0.931. Xinha has been optimized for size and dozens of issues have been closed

out since the last upgrade . Add Firefox and Xinha buttons to main page to show our support.
This commit is contained in:
Chris Morgan
2007-05-31 22:43:05 +00:00
committed by WineHQ
parent ff46a4485d
commit 2d4b27530d
354 changed files with 19793 additions and 21419 deletions

View File

@@ -1,252 +1,252 @@
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>Destroydrop &raquo; Javascripts &raquo; Tree &raquo; Api</title>
<meta http-equiv="content-type" content="text/html;charset=iso-8859-1" />
<link rel="stylesheet" href="/dd.css" type="text/css" />
<link rel="shortcut icon" href="/favicon.ico" />
</head>
<body>
<div id="shadow">
<div id="content">
<div id="location">
<h1><a href="/">Destroydrop</a> &raquo; <a href="/javascripts/">Javascripts</a> &raquo; <a href="/javascripts/tree/">Tree</a> &raquo; <a href="/javascripts/tree/api/">Api</a></h1>
</div>
<div class="line"></div>
<div id="files">
<h3>Overview</h3>
<div class="line"></div>
<div class="item">
<ul class="arrow">
<li><a href="#functions">Functions</a>
<ul class="arrow">
<li><a href="#add">add</a></li>
<li><a href="#openall">openAll</a></li>
<li><a href="#closeall">closeAll</a></li>
<li><a href="#opento">openTo</a></li>
</ul>
</li>
<li><a href="#configuration">Configuration</a></li>
</ul>
</div>
<a name="functions"></a>
<h3>Functions</h3>
<div class="line"></div>
<div class="item">
<a name="add"></a>
<h4 class="func">add()</h4>
<p>Adds a node to the tree.<br />Can only be called before the tree is drawn.</p>
<p>id, pid and name are required.</p>
<h4>Parameters</h4>
<table class="files">
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
</tr>
<tr>
<td>id</td>
<td>Number</td>
<td>Unique identity number.</td>
</tr>
<tr>
<td>pid</td>
<td>Number</td>
<td>Number refering to the parent node. The value for the root node has to be -1.</td>
</tr>
<tr>
<td>name</td>
<td>String</td>
<td>Text label for the node.</td>
</tr>
<tr>
<td>url</td>
<td>String</td>
<td>Url for the node.</td>
</tr>
<tr>
<td>title</td>
<td>String</td>
<td>Title for the node.</td>
</tr>
<tr>
<td>target</td>
<td>String</td>
<td>Target for the node.</td>
</tr>
<tr>
<td>icon</td>
<td>String</td>
<td>Image file to use as the icon. Uses default if not specified.</td>
</tr>
<tr>
<td>iconOpen</td>
<td>String</td>
<td>Image file to use as the open icon. Uses default if not specified.</td>
</tr>
<tr>
<td>open</td>
<td>Boolean</td>
<td>Is the node open.</td>
</tr>
</table>
<br />
<h4>Example</h4>
<p><code>mytree.add(1, 0, 'My node', 'node.html', 'node title', 'mainframe', 'img/musicfolder.gif');</code></p>
<br />
<a name="openall"></a>
<h4 class="func">openAll()</h4>
<p>Opens all the nodes.<br />Can be called before and after the tree is drawn.</p>
<h4>Example</h4>
<p><code>mytree.openAll();</code></p>
<br />
<a name="closeall"></a>
<h4 class="func">closeAll()</h4>
<p>Closes all the nodes.<br />Can be called before and after the tree is drawn.</p>
<h4>Example</h4>
<p><code>mytree.closeAll();</code></p>
<br />
<a name="opento"></a>
<h4 class="func">openTo()</h4>
<p>Opens the tree to a certain node and can also select the node.<br />
Can only be called after the tree is drawn.</p>
<h4>Parameters</h4>
<table class="files">
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
</tr>
<tr>
<td>id</td>
<td>Number</td>
<td>Identity number for the node.</td>
</tr>
<tr>
<td>select</td>
<td>Boolean</td>
<td>Should the node be selected.</td>
</tr>
</table>
<h4>Example</h4>
<p><code>mytree.openTo(4, true);</code></p>
</div>
<a name="configuration"></a>
<h3>Configuration</h3>
<div class="line"></div>
<div class="item">
<table class="files">
<tr>
<th>Variable</th>
<th>Type</th>
<th>Default</th>
<th>Description</th>
</tr>
<tr>
<td>target</td>
<td>String</td>
<td>true</td>
<td>Target for all the nodes.</td>
</tr>
<tr>
<td>folderLinks</td>
<td>Boolean</td>
<td>true</td>
<td>Should folders be links.</td>
</tr>
<tr>
<td>useSelection</td>
<td>Boolean</td>
<td>true</td>
<td>Nodes can be selected(highlighted).</td>
</tr>
<tr>
<td>useCookies</td>
<td>Boolean</td>
<td>true</td>
<td>The tree uses cookies to rember it's state.</td>
</tr>
<tr>
<td>useLines</td>
<td>Boolean</td>
<td>true</td>
<td>Tree is drawn with lines.</td>
</tr>
<tr>
<td>useIcons</td>
<td>Boolean</td>
<td>true</td>
<td>Tree is drawn with icons.</td>
</tr>
<tr>
<td>useStatusText</td>
<td>Boolean</td>
<td>false</td>
<td>Displays node names in the statusbar instead of the url.</td>
</tr>
<tr>
<td>closeSameLevel</td>
<td>Boolean</td>
<td>false</td>
<td>Only one node within a parent can be expanded at the same time. openAll() and closeAll() functions do not work when this is enabled.</td>
</tr>
<tr>
<td>inOrder</td>
<td>Boolean</td>
<td>false</td>
<td>If parent nodes are always added before children, setting this to true speeds up the tree.</td>
</tr>
</table>
<h4>Example</h4>
<p><code>mytree.config.target = "mytarget";</code></p>
</div>
</div>
<div class="line"></div>
<div id="copy">
<p class="right"><a href="http://validator.w3.org/check/referer">XHTML</a>, <a href="http://jigsaw.w3.org/css-validator/check/referer">CSS</a></p>
<p><a href="mailto&#58;drop&#64;destroydrop&#46;com">&copy;2002-2003 Geir Landr&ouml;</a></p>
</div>
</div>
</div>
</body>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>Destroydrop &raquo; Javascripts &raquo; Tree &raquo; Api</title>
<meta http-equiv="content-type" content="text/html;charset=iso-8859-1" />
<link rel="stylesheet" href="/dd.css" type="text/css" />
<link rel="shortcut icon" href="/favicon.ico" />
</head>
<body>
<div id="shadow">
<div id="content">
<div id="location">
<h1><a href="/">Destroydrop</a> &raquo; <a href="/javascripts/">Javascripts</a> &raquo; <a href="/javascripts/tree/">Tree</a> &raquo; <a href="/javascripts/tree/api/">Api</a></h1>
</div>
<div class="line"></div>
<div id="files">
<h3>Overview</h3>
<div class="line"></div>
<div class="item">
<ul class="arrow">
<li><a href="#functions">Functions</a>
<ul class="arrow">
<li><a href="#add">add</a></li>
<li><a href="#openall">openAll</a></li>
<li><a href="#closeall">closeAll</a></li>
<li><a href="#opento">openTo</a></li>
</ul>
</li>
<li><a href="#configuration">Configuration</a></li>
</ul>
</div>
<a name="functions"></a>
<h3>Functions</h3>
<div class="line"></div>
<div class="item">
<a name="add"></a>
<h4 class="func">add()</h4>
<p>Adds a node to the tree.<br />Can only be called before the tree is drawn.</p>
<p>id, pid and name are required.</p>
<h4>Parameters</h4>
<table class="files">
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
</tr>
<tr>
<td>id</td>
<td>Number</td>
<td>Unique identity number.</td>
</tr>
<tr>
<td>pid</td>
<td>Number</td>
<td>Number refering to the parent node. The value for the root node has to be -1.</td>
</tr>
<tr>
<td>name</td>
<td>String</td>
<td>Text label for the node.</td>
</tr>
<tr>
<td>url</td>
<td>String</td>
<td>Url for the node.</td>
</tr>
<tr>
<td>title</td>
<td>String</td>
<td>Title for the node.</td>
</tr>
<tr>
<td>target</td>
<td>String</td>
<td>Target for the node.</td>
</tr>
<tr>
<td>icon</td>
<td>String</td>
<td>Image file to use as the icon. Uses default if not specified.</td>
</tr>
<tr>
<td>iconOpen</td>
<td>String</td>
<td>Image file to use as the open icon. Uses default if not specified.</td>
</tr>
<tr>
<td>open</td>
<td>Boolean</td>
<td>Is the node open.</td>
</tr>
</table>
<br />
<h4>Example</h4>
<p><code>mytree.add(1, 0, 'My node', 'node.html', 'node title', 'mainframe', 'img/musicfolder.gif');</code></p>
<br />
<a name="openall"></a>
<h4 class="func">openAll()</h4>
<p>Opens all the nodes.<br />Can be called before and after the tree is drawn.</p>
<h4>Example</h4>
<p><code>mytree.openAll();</code></p>
<br />
<a name="closeall"></a>
<h4 class="func">closeAll()</h4>
<p>Closes all the nodes.<br />Can be called before and after the tree is drawn.</p>
<h4>Example</h4>
<p><code>mytree.closeAll();</code></p>
<br />
<a name="opento"></a>
<h4 class="func">openTo()</h4>
<p>Opens the tree to a certain node and can also select the node.<br />
Can only be called after the tree is drawn.</p>
<h4>Parameters</h4>
<table class="files">
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
</tr>
<tr>
<td>id</td>
<td>Number</td>
<td>Identity number for the node.</td>
</tr>
<tr>
<td>select</td>
<td>Boolean</td>
<td>Should the node be selected.</td>
</tr>
</table>
<h4>Example</h4>
<p><code>mytree.openTo(4, true);</code></p>
</div>
<a name="configuration"></a>
<h3>Configuration</h3>
<div class="line"></div>
<div class="item">
<table class="files">
<tr>
<th>Variable</th>
<th>Type</th>
<th>Default</th>
<th>Description</th>
</tr>
<tr>
<td>target</td>
<td>String</td>
<td>true</td>
<td>Target for all the nodes.</td>
</tr>
<tr>
<td>folderLinks</td>
<td>Boolean</td>
<td>true</td>
<td>Should folders be links.</td>
</tr>
<tr>
<td>useSelection</td>
<td>Boolean</td>
<td>true</td>
<td>Nodes can be selected(highlighted).</td>
</tr>
<tr>
<td>useCookies</td>
<td>Boolean</td>
<td>true</td>
<td>The tree uses cookies to rember it's state.</td>
</tr>
<tr>
<td>useLines</td>
<td>Boolean</td>
<td>true</td>
<td>Tree is drawn with lines.</td>
</tr>
<tr>
<td>useIcons</td>
<td>Boolean</td>
<td>true</td>
<td>Tree is drawn with icons.</td>
</tr>
<tr>
<td>useStatusText</td>
<td>Boolean</td>
<td>false</td>
<td>Displays node names in the statusbar instead of the url.</td>
</tr>
<tr>
<td>closeSameLevel</td>
<td>Boolean</td>
<td>false</td>
<td>Only one node within a parent can be expanded at the same time. openAll() and closeAll() functions do not work when this is enabled.</td>
</tr>
<tr>
<td>inOrder</td>
<td>Boolean</td>
<td>false</td>
<td>If parent nodes are always added before children, setting this to true speeds up the tree.</td>
</tr>
</table>
<h4>Example</h4>
<p><code>mytree.config.target = "mytarget";</code></p>
</div>
</div>
<div class="line"></div>
<div id="copy">
<p class="right"><a href="http://validator.w3.org/check/referer">XHTML</a>, <a href="http://jigsaw.w3.org/css-validator/check/referer">CSS</a></p>
<p><a href="mailto&#58;drop&#64;destroydrop&#46;com">&copy;2002-2003 Geir Landr&ouml;</a></p>
</div>
</div>
</div>
</body>
</html>

View File

@@ -14,7 +14,7 @@
border: 0px;
vertical-align: middle;
}
.dtree a {
.dtree a,.dtree a:visited {
color: #333;
text-decoration: none;
}

File diff suppressed because it is too large Load Diff

View File

@@ -1,53 +1,53 @@
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>Destroydrop &raquo; Javascripts &raquo; Tree</title>
<link rel="StyleSheet" href="dtree.css" type="text/css" />
<script type="text/javascript" src="dtree.js"></script>
</head>
<body>
<h1><a href="/">Destroydrop</a> &raquo; <a href="/javascripts/">Javascripts</a> &raquo; <a href="/javascripts/tree/">Tree</a></h1>
<h2>Example</h2>
<div class="dtree">
<p><a href="javascript: d.openAll();">open all</a> | <a href="javascript: d.closeAll();">close all</a></p>
<script type="text/javascript">
<!--
d = new dTree('d');
d.add(0,-1,'My example tree');
d.add(1,0,'Node 1','example01.html');
d.add(2,0,'Node 2','example01.html');
d.add(3,1,'Node 1.1','example01.html');
d.add(4,0,'Node 3','example01.html');
d.add(5,3,'Node 1.1.1','example01.html');
d.add(6,5,'Node 1.1.1.1','example01.html');
d.add(7,0,'Node 4','example01.html');
d.add(8,1,'Node 1.2','example01.html');
d.add(9,0,'My Pictures','example01.html','Pictures I\'ve taken over the years','','','img/imgfolder.gif');
d.add(10,9,'The trip to Iceland','example01.html','Pictures of Gullfoss and Geysir');
d.add(11,9,'Mom\'s birthday','example01.html');
d.add(12,0,'Recycle Bin','example01.html','','','img/trash.gif');
document.write(d);
//-->
</script>
</div>
<p><a href="mailto&#58;drop&#64;destroydrop&#46;com">&copy;2002-2003 Geir Landr&ouml;</a></p>
</body>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>Destroydrop &raquo; Javascripts &raquo; Tree</title>
<link rel="StyleSheet" href="dtree.css" type="text/css" />
<script type="text/javascript" src="dtree.js"></script>
</head>
<body>
<h1><a href="/">Destroydrop</a> &raquo; <a href="/javascripts/">Javascripts</a> &raquo; <a href="/javascripts/tree/">Tree</a></h1>
<h2>Example</h2>
<div class="dtree">
<p><a href="javascript: d.openAll();">open all</a> | <a href="javascript: d.closeAll();">close all</a></p>
<script type="text/javascript">
<!--
d = new dTree('d');
d.add(0,-1,'My example tree');
d.add(1,0,'Node 1','example01.html');
d.add(2,0,'Node 2','example01.html');
d.add(3,1,'Node 1.1','example01.html');
d.add(4,0,'Node 3','example01.html');
d.add(5,3,'Node 1.1.1','example01.html');
d.add(6,5,'Node 1.1.1.1','example01.html');
d.add(7,0,'Node 4','example01.html');
d.add(8,1,'Node 1.2','example01.html');
d.add(9,0,'My Pictures','example01.html','Pictures I\'ve taken over the years','','','img/imgfolder.gif');
d.add(10,9,'The trip to Iceland','example01.html','Pictures of Gullfoss and Geysir');
d.add(11,9,'Mom\'s birthday','example01.html');
d.add(12,0,'Recycle Bin','example01.html','','','img/trash.gif');
document.write(d);
//-->
</script>
</div>
<p><a href="mailto&#58;drop&#64;destroydrop&#46;com">&copy;2002-2003 Geir Landr&ouml;</a></p>
</body>
</html>

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.0 KiB

After

Width:  |  Height:  |  Size: 1018 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 239 B

After

Width:  |  Height:  |  Size: 228 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 676 B

After

Width:  |  Height:  |  Size: 641 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 372 B

After

Width:  |  Height:  |  Size: 355 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 376 B

After

Width:  |  Height:  |  Size: 365 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 622 B

After

Width:  |  Height:  |  Size: 609 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 69 B

After

Width:  |  Height:  |  Size: 62 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 66 B

After

Width:  |  Height:  |  Size: 55 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 66 B

After

Width:  |  Height:  |  Size: 46 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 86 B

After

Width:  |  Height:  |  Size: 82 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 85 B

After

Width:  |  Height:  |  Size: 76 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 688 B

After

Width:  |  Height:  |  Size: 653 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 633 B

After

Width:  |  Height:  |  Size: 626 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 861 B

After

Width:  |  Height:  |  Size: 64 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 870 B

After

Width:  |  Height:  |  Size: 67 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1012 B

After

Width:  |  Height:  |  Size: 1001 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 582 B

After

Width:  |  Height:  |  Size: 556 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 89 B

After

Width:  |  Height:  |  Size: 86 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 88 B

After

Width:  |  Height:  |  Size: 82 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.0 KiB

After

Width:  |  Height:  |  Size: 1.0 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.0 KiB

After

Width:  |  Height:  |  Size: 1.0 KiB

View File

@@ -1,107 +1,107 @@
<h1 id="[h1]"><l10n>Insert/Modify Link</l10n></h1>
<div style="position:relative">
<div id="[dTree]">(the dTree goes in here)</div>
<div id="[options]" >
<fieldset>
<legend><label><input type="radio" name="[type]" value="url" checked onclick="
document.getElementById('[urltable]').style.display=this.checked?'':'none';
document.getElementById('[mailtable]').style.display=this.checked?'none':'';
document.getElementById('[anchortable]').style.display=this.checked?'none':'';
" /> <l10n>URL Link</l10n></label></legend>
<table id="[urltable]" width="100%">
<tr>
<th><label for="[href]"><l10n>URL:</l10n> </label></th>
<td><input type="text" name="[href]" style="width:100%" value="http://www.example.com/" /></td>
</tr>
<tr valign="top">
<th><l10n>Target:</l10n></th>
<td>
<div><label><input type="radio" name="[target]" value="" onclick="document.getElementById('[popuptable]').style.display='none';" checked /> <l10n>Ordinary Link</l10n></label></div>
<div><label><input type="radio" name="[target]" value="_top" onclick="document.getElementById('[popuptable]').style.display='none';" /> <l10n>Same Window (jump out of frames)</l10n></label></div>
<div><label><input type="radio" name="[target]" value="_blank" onclick="document.getElementById('[popuptable]').style.display='none';"/> <l10n>New Window</l10n> </label></div>
<div>
<label><input type="radio" name="[target]" value="popup" onclick="document.getElementById('[popuptable]').style.display='';" /> <l10n>Popup Window</l10n> </label>
<div style="padding-left:10px">
<table id="[popuptable]">
<tr>
<th align="left"><l10n>Size:</l10n></th>
<td colspan="3"><input type="text" name="[p_width]" size="4" />x<input type="text" name="[p_height]" size="4" /> <l10n>(px)</l10n></td>
</tr>
<tr>
<th align="left"><l10n>Name:</l10n></th>
<td colspan="3"><input type="text" name="[p_name]" atyle="width:100%" value="_(PopupWindow)" /></td>
</tr>
<tr>
<th align="left"><l10n>Menu Bar:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="menubar=yes" /></td>
<th align="left"><l10n>Toolbar:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="toolbar=yes" checked /></td>
</tr>
<tr>
<th align="left"><l10n>Location Bar:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="location=yes" /></td>
<th align="left"><l10n>Status Bar:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="status=yes" /></td>
</tr>
<tr>
<th align="left"><l10n>Scrollbars:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="scrollbars=yes" checked /></td>
<th align="left"><l10n>Resizeable:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="resizeable=yes" checked /></td>
</tr>
</table>
</div>
</div>
</td>
</tr>
</table>
</fieldset>
<fieldset>
<legend><label><input type="radio" name="[type]" value="mailto" onclick="
document.getElementById('[mailtable]').style.display=this.checked?'':'none';
document.getElementById('[urltable]').style.display=this.checked?'none':'';
document.getElementById('[anchortable]').style.display=this.checked?'none':'';
"/> <l10n>Email Link</l10n></label></legend>
<table id="[mailtable]" width="100%">
<tr>
<th><label for="[to]"><l10n>Email Address:</l10n> </label></th>
<td><input type="text" name="[to]" style="width:100%" value="alice@example.com" /></td>
</tr>
<tr>
<th><label for="[subject]"><l10n>Subject:</l10n> </label></th>
<td><input type="text" name="[subject]" style="width:100%" value="" /></td>
</tr>
<tr>
<th><label for="[body]"><l10n>Message Template:</l10n> </label></th>
<td><textarea name="[body]" style="width:100%" rows="5"></textarea></td>
</tr>
</table>
</fieldset>
<fieldset id="[anchorfieldset]">
<legend><label><input type="radio" name="[type]" value="anchor" onclick="
document.getElementById('[urltable]').style.display=this.checked?'none':'';
document.getElementById('[mailtable]').style.display=this.checked?'none':'';
document.getElementById('[anchortable]').style.display=this.checked?'':'none';
"/> <l10n>Anchor-Link</l10n></label></legend>
<table id="[anchortable]" width="100%">
<tr>
<th><label for="[anchor]"><l10n>Anchor:</l10n> </label></th>
<td>
<select name="[anchor]" id="[anchor]">
</select>
</td>
</tr>
</table>
</fieldset>
<div style="text-align:right">
<input type="button" id="[ok]" value="_(OK)" />
<input type="button" id="[clear]" value="_(REMOVE LINK)" onclick="this.form['[href]'].value='';this.form['[to]'].value='';document.getElementById('[ok]').click();" />
<input type="button" id="[cancel]" value="_(CANCEL)" />
</div>
</div>
<h1 id="[h1]"><l10n>Insert/Modify Link</l10n></h1>
<div style="position:relative">
<div id="[dTree]">(the dTree goes in here)</div>
<div id="[options]" >
<fieldset>
<legend><label><input type="radio" name="[type]" value="url" checked="checked" onclick="
document.getElementById('[urltable]').style.display=this.checked?'':'none';
document.getElementById('[mailtable]').style.display=this.checked?'none':'';
document.getElementById('[anchortable]').style.display=this.checked?'none':'';
" /> <l10n>URL Link</l10n></label></legend>
<table id="[urltable]" width="100%">
<tr>
<th><label for="[href]"><l10n>URL:</l10n> </label></th>
<td><input type="text" name="[href]" style="width:100%" value="http://www.example.com/" onfocus="if (this.value == 'http://www.example.com/') this.value = '';" /></td>
</tr>
<tr valign="top">
<th><l10n>Target:</l10n></th>
<td>
<div><label><input type="radio" name="[target]" value="" onclick="document.getElementById('[popuptable]').style.display='none';" checked="checked" /> <l10n>Ordinary Link</l10n></label></div>
<div><label><input type="radio" name="[target]" value="_top" onclick="document.getElementById('[popuptable]').style.display='none';" /> <l10n>Same Window (jump out of frames)</l10n></label></div>
<div><label><input type="radio" name="[target]" value="_blank" onclick="document.getElementById('[popuptable]').style.display='none';"/> <l10n>New Window</l10n> </label></div>
<div>
<label><input type="radio" name="[target]" value="popup" onclick="document.getElementById('[popuptable]').style.display='';" /> <l10n>Popup Window</l10n> </label>
<div style="padding-left:10px">
<table id="[popuptable]">
<tr>
<th align="left"><l10n>Size:</l10n></th>
<td colspan="3"><input type="text" name="[p_width]" size="4" />x<input type="text" name="[p_height]" size="4" /> <l10n>(px)</l10n></td>
</tr>
<tr>
<th align="left"><l10n>Name:</l10n></th>
<td colspan="3"><input type="text" name="[p_name]" atyle="width:100%" value="_(PopupWindow)" /></td>
</tr>
<tr>
<th align="left"><l10n>Menu Bar:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="menubar=yes" /></td>
<th align="left"><l10n>Toolbar:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="toolbar=yes" checked="checked" /></td>
</tr>
<tr>
<th align="left"><l10n>Location Bar:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="location=yes" /></td>
<th align="left"><l10n>Status Bar:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="status=yes" /></td>
</tr>
<tr>
<th align="left"><l10n>Scrollbars:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="scrollbars=yes" checked="checked" /></td>
<th align="left"><l10n>Resizeable:</l10n></th>
<td><input type="checkbox" name="[p_options]" value="resizeable=yes" checked="checked" /></td>
</tr>
</table>
</div>
</div>
</td>
</tr>
</table>
</fieldset>
<fieldset>
<legend><label><input type="radio" name="[type]" value="mailto" onclick="
document.getElementById('[mailtable]').style.display=this.checked?'':'none';
document.getElementById('[urltable]').style.display=this.checked?'none':'';
document.getElementById('[anchortable]').style.display=this.checked?'none':'';
"/> <l10n>Email Link</l10n></label></legend>
<table id="[mailtable]" width="100%">
<tr>
<th><label for="[to]"><l10n>Email Address:</l10n> </label></th>
<td><input type="text" name="[to]" style="width:100%" value="alice@example.com" onfocus="if (this.value == 'alice@example.com') this.value = '';" /></td>
</tr>
<tr>
<th><label for="[subject]"><l10n>Subject:</l10n> </label></th>
<td><input type="text" name="[subject]" style="width:100%" value="" /></td>
</tr>
<tr>
<th><label for="[body]"><l10n>Message Template:</l10n> </label></th>
<td><textarea name="[body]" style="width:100%" rows="5"></textarea></td>
</tr>
</table>
</fieldset>
<fieldset id="[anchorfieldset]">
<legend><label><input type="radio" name="[type]" value="anchor" onclick="
document.getElementById('[urltable]').style.display=this.checked?'none':'';
document.getElementById('[mailtable]').style.display=this.checked?'none':'';
document.getElementById('[anchortable]').style.display=this.checked?'':'none';
"/> <l10n>Anchor-Link</l10n></label></legend>
<table id="[anchortable]" width="100%">
<tr>
<th><label for="[anchor]"><l10n>Anchor:</l10n> </label></th>
<td>
<select name="[anchor]" id="[anchor]">
</select>
</td>
</tr>
</table>
</fieldset>
<div style="text-align:right">
<input type="button" id="[ok]" value="_(OK)" />
<input type="button" id="[clear]" value="_(Remove Link)" onclick="this.form['[href]'].value='';this.form['[to]'].value='';document.getElementById('[ok]').click();" />
<input type="button" id="[cancel]" value="_(Cancel)" />
</div>
</div>
</div>

View File

@@ -4,8 +4,7 @@
{
"You must select some text before making a new link.": "Sie müssen einen Text markieren um einen Link zu erstellen",
"Are you sure you wish to remove this link?": "Wollen Sie diesen Link wirklich entfernen?",
"REMOVE LINK": "LINK ENTFERNEN",
"CANCEL": "ABBRECHEN",
"Remove Link": "Link entfernen",
"URL Link": "URL Adresse",
"Ordinary Link": "Standard Link",
"Same Window (jump out of frames)": "Selbes Fenster (ganzer Bereich)",

View File

@@ -3,8 +3,7 @@
{
"You must select some text before making a new link.": "Vous devez sélectionner un texte avant de créer un nouveau lien",
"Are you sure you wish to remove this link?": "Confirmez-vous la suppression de ce lien ?",
"REMOVE LINK": "Supprimer",
"CANCEL": "Annuler",
"Remove Link": "Supprimer",
"URL Link": "Lien URL",
"Ordinary Link": "Lien standard",
"Same Window (jump out of frames)": "Même fenêtre (sort des frames)",

View File

@@ -0,0 +1,24 @@
// I18N constants
// LANG: "ja", ENCODING: UTF-8
{
"You must select some text before making a new link.": "リンクを作成するにはテキストを選択する必要があります",
"Are you sure you wish to remove this link?": "本当にこのリンクを削除しますか?",
"Remove Link": "リンク削除",
"URL Link": "URLリンク",
"Ordinary Link": "標準リンク",
"Same Window (jump out of frames)": "同一ウィンドウ (フレーム最上位)",
"New Window": "新しいウィンドウ",
"Popup Window": "ポップアップウィンドウ",
"Email Link": "Eメールリンク",
"Email Address:": "アドレス:",
"Subject:": "件名:",
"Message Template:": "本文雛形:",
"Size:": "サイズ:",
"Name:": "名前:",
"Menu Bar:": "メニュー",
"Toolbar:": "ツールバー",
"Location Bar:": "アドレスバー",
"Status Bar:": "ステータスバー",
"Scrollbars:": "スクロール",
"Resizeable:": "リサイズ"
};

View File

@@ -1,5 +1,5 @@
// I18N constants
// LANG: "no", ENCODING: UTF-8
// LANG: "nb", ENCODING: UTF-8
// translated: Kim Steinhaug, http://www.steinhaug.com/, kim@steinhaug.com
{
"You must select some text before making a new link.": "Du må markere tekst eller et bilde før du kan lage en lenke.",

View File

@@ -4,8 +4,7 @@
{
"You must select some text before making a new link.": "Zaznacz tekst przed dodaniem odnośnika.",
"Are you sure you wish to remove this link?": "Na pewno chcesz usunąć odnośnik?",
"REMOVE LINK": "USUŃ ODNOŚNIK",
"CANCEL": "ANULUJ",
"Remove Link": "USUŃ ODNOŚNIK",
"URL Link": "Adres URL",
"Ordinary Link": "Zwykły odnośnik",
"Same Window (jump out of frames)": "To samo okno (wyskocz z ramek)",

View File

@@ -1,551 +1,385 @@
/** htmlArea - James' Fork - Linker Plugin **/
Linker._pluginInfo =
{
name : "Linker",
version : "1.0",
developer: "James Sleeman",
developer_url: "http://www.gogo.co.nz/",
c_owner : "Gogo Internet Services",
license : "htmlArea",
sponsor : "Gogo Internet Services",
sponsor_url : "http://www.gogo.co.nz/"
Linker._pluginInfo={name:"Linker",version:"1.0",developer:"James Sleeman",developer_url:"http://www.gogo.co.nz/",c_owner:"Gogo Internet Services",license:"htmlArea",sponsor:"Gogo Internet Services",sponsor_url:"http://www.gogo.co.nz/"};
Xinha.loadStyle("dTree/dtree.css","Linker");
Xinha.Config.prototype.Linker={"treeCaption":document.location.host,"backend":_editor_url+"plugins/Linker/scan.php","backend_data":null,"files":null};
function Linker(_1,_2){
this.editor=_1;
this.lConfig=_1.config.Linker;
var _3=this;
if(_1.config.btnList.createlink){
_1.config.btnList.createlink[3]=function(e,_5,_6){
_3._createLink(_3._getSelectedAnchor());
};
HTMLArea.loadStyle('dTree/dtree.css', 'Linker');
HTMLArea.Config.prototype.Linker =
{
'backend' : _editor_url + 'plugins/Linker/scan.php',
'files' : null
};
function Linker(editor, args)
{
this.editor = editor;
this.lConfig = editor.config.Linker;
var linker = this;
if(editor.config.btnList.createlink)
{
editor.config.btnList.createlink[3]
= function(e, objname, obj) { linker._createLink(linker._getSelectedAnchor()); };
}
else
{
editor.config.registerButton(
'createlink', 'Insert/Modify Hyperlink', [_editor_url + "images/ed_buttons_main.gif",6,1], false,
function(e, objname, obj) { linker._createLink(linker._getSelectedAnchor()); }
);
}
// See if we can find 'createlink'
editor.config.addToolbarElement("createlink", "createlink", 0);
}else{
_1.config.registerButton("createlink","Insert/Modify Hyperlink",[_editor_url+"images/ed_buttons_main.gif",6,1],false,function(e,_8,_9){
_3._createLink(_3._getSelectedAnchor());
});
}
Linker.prototype._lc = function(string)
{
return HTMLArea._lc(string, 'Linker');
_1.config.addToolbarElement("createlink","createlink",0);
}
Linker.prototype._lc=function(_a){
return Xinha._lc(_a,"Linker");
};
Linker.prototype._createLink = function(a)
{
if(!a && this.editor._selectionEmpty(this.editor._getSelection()))
{
alert(this._lc("You must select some text before making a new link."));
return false;
}
var inputs =
{
type: 'url',
href: 'http://www.example.com/',
target: '',
p_width: '',
p_height: '',
p_options: ['menubar=no','toolbar=yes','location=no','status=no','scrollbars=yes','resizeable=yes'],
to: 'alice@example.com',
subject: '',
body: ''
};
if(a && a.tagName.toLowerCase() == 'a')
{
var m = a.href.match(/^mailto:(.*@[^?&]*)(\?(.*))?$/);
var anchor = a.href.match(/^#(.*)$/);
if(m)
{
// Mailto
inputs.type = 'mailto';
inputs.to = m[1];
if(m[3])
{
var args = m[3].split('&');
for(var x = 0; x<args.length; x++)
{
var j = args[x].match(/(subject|body)=(.*)/);
if(j)
{
inputs[j[1]] = decodeURIComponent(j[2]);
}
}
}
}
else if (anchor)
{
//Anchor-Link
inputs.type = 'anchor';
inputs.anchor = m[1];
}
else
{
if(a.getAttribute('onclick'))
{
var m = a.getAttribute('onclick').match(/window\.open\(\s*this\.href\s*,\s*'([a-z0-9_]*)'\s*,\s*'([a-z0-9_=,]*)'\s*\)/i);
// Popup Window
inputs.href = a.href ? a.href : '';
inputs.target = 'popup';
inputs.p_name = m[1];
inputs.p_options = [ ];
var args = m[2].split(',');
for(var x = 0; x < args.length; x++)
{
var i = args[x].match(/(width|height)=([0-9]+)/);
if(i)
{
inputs['p_' + i[1]] = parseInt(i[2]);
}
else
{
inputs.p_options.push(args[x]);
}
}
}
else
{
// Normal
inputs.href = a.href;
inputs.target = a.target;
}
}
}
var linker = this;
// If we are not editing a link, then we need to insert links now using execCommand
// because for some reason IE is losing the selection between now and when doOK is
// complete. I guess because we are defocusing the iframe when we click stuff in the
// linker dialog.
this.a = a; // Why doesn't a get into the closure below, but if I set it as a property then it's fine?
var doOK = function()
{
//if(linker.a) alert(linker.a.tagName);
var a = linker.a;
var values = linker._dialog.hide();
var atr =
{
href: '',
target:'',
title:'',
onclick:''
};
if(values.type == 'url')
{
if(values.href)
{
atr.href = values.href;
atr.target = values.target;
if(values.target == 'popup')
{
if(values.p_width)
{
values.p_options.push('width=' + values.p_width);
}
if(values.p_height)
{
values.p_options.push('height=' + values.p_height);
}
atr.onclick = 'try{if(document.designMode && document.designMode == \'on\') return false;}catch(e){} window.open(this.href, \'' + (values.p_name.replace(/[^a-z0-9_]/i, '_')) + '\', \'' + values.p_options.join(',') + '\');return false;';
}
}
}
else if(values.type == 'anchor')
{
if(values.anchor)
{
atr.href = values.anchor.value;
}
}
else
{
if(values.to)
{
atr.href = 'mailto:' + values.to;
if(values.subject) atr.href += '?subject=' + encodeURIComponent(values.subject);
if(values.body) atr.href += (values.subject ? '&' : '?') + 'body=' + encodeURIComponent(values.body);
}
}
if(a && a.tagName.toLowerCase() == 'a')
{
if(!atr.href)
{
if(confirm(linker._dialog._lc('Are you sure you wish to remove this link?')))
{
var p = a.parentNode;
while(a.hasChildNodes())
{
p.insertBefore(a.removeChild(a.childNodes[0]), a);
}
p.removeChild(a);
}
}
else
{
// Update the link
for(var i in atr)
{
a.setAttribute(i, atr[i]);
}
// If we change a mailto link in IE for some hitherto unknown
// reason it sets the innerHTML of the link to be the
// href of the link. Stupid IE.
if(HTMLArea.is_ie)
{
if(/mailto:([^?<>]*)(\?[^<]*)?$/i.test(a.innerHTML))
{
a.innerHTML = RegExp.$1;
}
}
}
}
else
{
if(!atr.href) return true;
// Insert a link, we let the browser do this, we figure it knows best
var tmp = HTMLArea.uniq('http://www.example.com/Link');
linker.editor._doc.execCommand('createlink', false, tmp);
// Fix them up
var anchors = linker.editor._doc.getElementsByTagName('a');
for(var i = 0; i < anchors.length; i++)
{
var a = anchors[i];
if(a.href == tmp)
{
// Found one.
for(var i in atr)
{
a.setAttribute(i, atr[i]);
}
}
}
}
};
this._dialog.show(inputs, doOK);
Linker.prototype._createLink=function(a){
if(!a&&this.editor.selectionEmpty(this.editor.getSelection())){
alert(this._lc("You must select some text before making a new link."));
return false;
}
var _c={type:"url",href:"http://www.example.com/",target:"",p_width:"",p_height:"",p_options:["menubar=no","toolbar=yes","location=no","status=no","scrollbars=yes","resizeable=yes"],to:"alice@example.com",subject:"",body:"",anchor:""};
if(a&&a.tagName.toLowerCase()=="a"){
var _d=this.editor.fixRelativeLinks(a.getAttribute("href"));
var m=_d.match(/^mailto:(.*@[^?&]*)(\?(.*))?$/);
var _f=_d.match(/^#(.*)$/);
if(m){
_c.type="mailto";
_c.to=m[1];
if(m[3]){
var _10=m[3].split("&");
for(var x=0;x<_10.length;x++){
var j=_10[x].match(/(subject|body)=(.*)/);
if(j){
_c[j[1]]=decodeURIComponent(j[2]);
}
}
}
}else{
if(_f){
_c.type="anchor";
_c.anchor=_f[1];
}else{
if(a.getAttribute("onclick")){
var m=a.getAttribute("onclick").match(/window\.open\(\s*this\.href\s*,\s*'([a-z0-9_]*)'\s*,\s*'([a-z0-9_=,]*)'\s*\)/i);
_c.href=_d?_d:"";
_c.target="popup";
_c.p_name=m[1];
_c.p_options=[];
var _10=m[2].split(",");
for(var x=0;x<_10.length;x++){
var i=_10[x].match(/(width|height)=([0-9]+)/);
if(i){
_c["p_"+i[1]]=parseInt(i[2]);
}else{
_c.p_options.push(_10[x]);
}
}
}else{
_c.href=_d;
_c.target=a.target;
}
}
}
}
var _14=this;
this.a=a;
var _15=function(){
var a=_14.a;
var _17=_14._dialog.hide();
var atr={href:"",target:"",title:"",onclick:""};
if(_17.type=="url"){
if(_17.href){
atr.href=_17.href;
atr.target=_17.target;
if(_17.target=="popup"){
if(_17.p_width){
_17.p_options.push("width="+_17.p_width);
}
if(_17.p_height){
_17.p_options.push("height="+_17.p_height);
}
atr.onclick="if(window.top && window.top.Xinha){return false}window.open(this.href, '"+(_17.p_name.replace(/[^a-z0-9_]/i,"_"))+"', '"+_17.p_options.join(",")+"');return false;";
}
}
}else{
if(_17.type=="anchor"){
if(_17.anchor){
atr.href=_17.anchor.value;
}
}else{
if(_17.to){
atr.href="mailto:"+_17.to;
if(_17.subject){
atr.href+="?subject="+encodeURIComponent(_17.subject);
}
if(_17.body){
atr.href+=(_17.subject?"&":"?")+"body="+encodeURIComponent(_17.body);
}
}
}
}
if(a&&a.tagName.toLowerCase()=="a"){
if(!atr.href){
if(confirm(_14._dialog._lc("Are you sure you wish to remove this link?"))){
var p=a.parentNode;
while(a.hasChildNodes()){
p.insertBefore(a.removeChild(a.childNodes[0]),a);
}
p.removeChild(a);
_14.editor.updateToolbar();
return;
}
}else{
for(var i in atr){
a.setAttribute(i,atr[i]);
}
if(Xinha.is_ie){
if(/mailto:([^?<>]*)(\?[^<]*)?$/i.test(a.innerHTML)){
a.innerHTML=RegExp.$1;
}
}
}
}else{
if(!atr.href){
return true;
}
var tmp=Xinha.uniq("http://www.example.com/Link");
_14.editor._doc.execCommand("createlink",false,tmp);
var _1c=_14.editor._doc.getElementsByTagName("a");
for(var i=0;i<_1c.length;i++){
var _1d=_1c[i];
if(_1d.href==tmp){
if(!a){
a=_1d;
}
for(var j in atr){
_1d.setAttribute(j,atr[j]);
}
}
}
}
_14.editor.selectNodeContents(a);
_14.editor.updateToolbar();
};
Linker.prototype._getSelectedAnchor = function()
{
var sel = this.editor._getSelection();
var rng = this.editor._createRange(sel);
var a = this.editor._activeElement(sel);
if(a != null && a.tagName.toLowerCase() == 'a')
{
return a;
}
else
{
a = this.editor._getFirstAncestor(sel, 'a');
if(a != null)
{
return a;
}
}
return null;
this._dialog.show(_c,_15);
};
Linker.prototype.onGenerate = function()
{
this._dialog = new Linker.Dialog(this);
Linker.prototype._getSelectedAnchor=function(){
var sel=this.editor.getSelection();
var rng=this.editor.createRange(sel);
var a=this.editor.activeElement(sel);
if(a!=null&&a.tagName.toLowerCase()=="a"){
return a;
}else{
a=this.editor._getFirstAncestor(sel,"a");
if(a!=null){
return a;
}
}
return null;
};
// Inline Dialog for Linker
Linker.Dialog_dTrees = [ ];
Linker.Dialog = function (linker)
{
var lDialog = this;
this.Dialog_nxtid = 0;
this.linker = linker;
this.id = { }; // This will be filled below with a replace, nifty
this.ready = false;
this.files = false;
this.html = false;
this.dialog = false;
// load the dTree script
this._prepareDialog();
Linker.prototype.onGenerateOnce=function(){
this._dialog=new Linker.Dialog(this);
};
Linker.Dialog.prototype._prepareDialog = function()
{
var lDialog = this;
var linker = this.linker;
// We load some stuff up int he background, recalling this function
// when they have loaded. This is to keep the editor responsive while
// we prepare the dialog.
if(typeof dTree == 'undefined')
{
HTMLArea._loadback(_editor_url + 'plugins/Linker/dTree/dtree.js',
function() {lDialog._prepareDialog(); }
);
return;
}
if(this.files == false)
{
if(linker.lConfig.backend)
{
//get files from backend
HTMLArea._getback(linker.lConfig.backend,
function(txt) {
try {
eval('lDialog.files = '+txt);
} catch(Error) {
lDialog.files = [ {url:'',title:Error.toString()} ];
}
lDialog._prepareDialog(); });
}
else if(linker.lConfig.files != null)
{
//get files from plugin-config
lDialog.files = linker.lConfig.files;
lDialog._prepareDialog();
}
return;
}
var files = this.files;
if(this.html == false)
{
HTMLArea._getback(_editor_url + 'plugins/Linker/dialog.html', function(txt) { lDialog.html = txt; lDialog._prepareDialog(); });
return;
}
var html = this.html;
// Now we have everything we need, so we can build the dialog.
var dialog = this.dialog = new HTMLArea.Dialog(linker.editor, this.html, 'Linker');
var dTreeName = HTMLArea.uniq('dTree_');
this.dTree = new dTree(dTreeName, _editor_url + 'plugins/Linker/dTree/');
eval(dTreeName + ' = this.dTree');
this.dTree.add(this.Dialog_nxtid++, -1, document.location.host, null, document.location.host);
this.makeNodes(files, 0);
// Put it in
var ddTree = this.dialog.getElementById('dTree');
//ddTree.innerHTML = this.dTree.toString();
ddTree.innerHTML = '';
ddTree.style.position = 'absolute';
ddTree.style.left = 1 + 'px';
ddTree.style.top = 0 + 'px';
ddTree.style.overflow = 'auto';
this.ddTree = ddTree;
this.dTree._linker_premade = this.dTree.toString();
var options = this.dialog.getElementById('options');
options.style.position = 'absolute';
options.style.top = 0 + 'px';
options.style.right = 0 + 'px';
options.style.width = 320 + 'px';
options.style.overflow = 'auto';
// Hookup the resizer
this.dialog.onresize = function()
{
options.style.height = ddTree.style.height = (parseInt(dialog.height) - dialog.getElementById('h1').offsetHeight) + 'px';
ddTree.style.width = (parseInt(dialog.width) - 322 ) + 'px';
}
this.ready = true;
Linker.Dialog_dTrees=[];
Linker.Dialog=function(_22){
var _23=this;
this.Dialog_nxtid=0;
this.linker=_22;
this.id={};
this.ready=false;
this.files=false;
this.html=false;
this.dialog=false;
this._prepareDialog();
};
Linker.Dialog.prototype.makeNodes = function(files, parent)
{
for(var i = 0; i < files.length; i++)
{
if(typeof files[i] == 'string')
{
this.dTree.add(Linker.nxtid++, parent,
files[i].replace(/^.*\//, ''),
'javascript:document.getElementsByName(\'' + this.dialog.id.href + '\')[0].value=decodeURIComponent(\'' + encodeURIComponent(files[i]) + '\');document.getElementsByName(\'' + this.dialog.id.type + '\')[0].click();document.getElementsByName(\'' + this.dialog.id.href + '\')[0].focus();void(0);',
files[i]);
}
else if(files[i].length)
{
var id = this.Dialog_nxtid++;
this.dTree.add(id, parent, files[i][0].replace(/^.*\//, ''), null, files[i][0]);
this.makeNodes(files[i][1], id);
}
else if(typeof files[i] == 'object')
{
if(files[i].children) {
var id = this.Dialog_nxtid++;
} else {
var id = Linker.nxtid++;
}
if(files[i].title) var title = files[i].title;
else if(files[i].url) var title = files[i].url.replace(/^.*\//, '');
else var title = "no title defined";
if(files[i].url) var link = 'javascript:document.getElementsByName(\'' + this.dialog.id.href + '\')[0].value=decodeURIComponent(\'' + encodeURIComponent(files[i].url) + '\');document.getElementsByName(\'' + this.dialog.id.type + '\')[0].click();document.getElementsByName(\'' + this.dialog.id.href + '\')[0].focus();void(0);';
else var link = '';
this.dTree.add(id, parent, title, link, title);
if(files[i].children) {
this.makeNodes(files[i].children, id);
}
}
}
Linker.Dialog.prototype._prepareDialog=function(){
var _24=this;
var _25=this.linker;
if(typeof dTree=="undefined"){
Xinha._loadback(_editor_url+"plugins/Linker/dTree/dtree.js",function(){
_24._prepareDialog();
});
return;
}
if(this.files==false){
if(_25.lConfig.backend){
Xinha._postback(_25.lConfig.backend,_25.lConfig.backend_data,function(txt){
try{
_24.files=eval(txt);
}
catch(Error){
_24.files=[{url:"",title:Error.toString()}];
}
_24._prepareDialog();
});
}else{
if(_25.lConfig.files!=null){
_24.files=_25.lConfig.files;
_24._prepareDialog();
}
}
return;
}
var _27=this.files;
if(this.html==false){
Xinha._getback(_editor_url+"plugins/Linker/dialog.html",function(txt){
_24.html=txt;
_24._prepareDialog();
});
return;
}
var _29=this.html;
var _2a=this.dialog=new Xinha.Dialog(_25.editor,this.html,"Linker");
var _2b=Xinha.uniq("dTree_");
this.dTree=new dTree(_2b,_editor_url+"plugins/Linker/dTree/");
eval(_2b+" = this.dTree");
this.dTree.add(this.Dialog_nxtid++,-1,_25.lConfig.treeCaption,null,_25.lConfig.treeCaption);
this.makeNodes(_27,0);
var _2c=this.dialog.getElementById("dTree");
_2c.innerHTML="";
_2c.style.position="absolute";
_2c.style.left=1+"px";
_2c.style.top=0+"px";
_2c.style.overflow="auto";
_2c.style.backgroundColor="white";
this.ddTree=_2c;
this.dTree._linker_premade=this.dTree.toString();
var _2d=this.dialog.getElementById("options");
_2d.style.position="absolute";
_2d.style.top=0+"px";
_2d.style.right=0+"px";
_2d.style.width=320+"px";
_2d.style.overflow="auto";
this.dialog.onresize=function(){
var h=parseInt(_2a.height)-_2a.getElementById("h1").offsetHeight;
var w=parseInt(_2a.width)-322;
if(w<0){
w=0;
}
if(h<0){
h=0;
}
_2d.style.height=_2c.style.height=h+"px";
_2c.style.width=w+"px";
};
Linker.Dialog.prototype._lc = Linker.prototype._lc;
Linker.Dialog.prototype.show = function(inputs, ok, cancel)
{
if(!this.ready)
{
var lDialog = this;
window.setTimeout(function() {lDialog.show(inputs,ok,cancel);},100);
return;
}
if(this.ddTree.innerHTML == '')
{
this.ddTree.innerHTML = this.dTree._linker_premade;
}
if(inputs.type=='url')
{
this.dialog.getElementById('urltable').style.display = '';
this.dialog.getElementById('mailtable').style.display = 'none';
this.dialog.getElementById('anchortable').style.display = 'none';
}
else if(inputs.type=='anchor')
{
this.dialog.getElementById('urltable').style.display = 'none';
this.dialog.getElementById('mailtable').style.display = 'none';
this.dialog.getElementById('anchortable').style.display = '';
}
else
{
this.dialog.getElementById('urltable').style.display = 'none';
this.dialog.getElementById('mailtable').style.display = '';
this.dialog.getElementById('anchortable').style.display = 'none';
}
if(inputs.target=='popup')
{
this.dialog.getElementById('popuptable').style.display = '';
}
else
{
this.dialog.getElementById('popuptable').style.display = 'none';
}
var anchor = this.dialog.getElementById('anchor');
for(var i=0;i<anchor.childNodes.length;i++) {
anchor.removeChild(anchor.childNodes[i]);
}
var html = this.linker.editor.getHTML();
var anchors = new Array();
var m = html.match(/<a[^>]+name="([^"]+)"/gi);
if(m)
{
for(i=0;i<m.length;i++)
{
var n = m[i].match(/name="([^"]+)"/i);
if(!anchors.contains(n[1])) anchors.push(n[1]);
}
}
m = html.match(/id="([^"]+)"/gi);
if(m)
{
for(i=0;i<m.length;i++)
{
n = m[i].match(/id="([^"]+)"/i);
if(!anchors.contains(n[1])) anchors.push(n[1]);
}
}
for(i=0;i<anchors.length;i++)
{
var opt = document.createElement('option');
opt.value = '#'+anchors[i];
opt.innerHTML = anchors[i];
anchor.appendChild(opt);
}
//if no anchors found completely hide Anchor-Link
if(anchor.childNodes.length==0) {
this.dialog.getElementById('anchorfieldset').style.display = "none";
}
// Connect the OK and Cancel buttons
var dialog = this.dialog;
var lDialog = this;
if(ok)
{
this.dialog.getElementById('ok').onclick = ok;
}
else
{
this.dialog.getElementById('ok').onclick = function() {lDialog.hide();};
}
if(cancel)
{
this.dialog.getElementById('cancel').onclick = cancel;
}
else
{
this.dialog.getElementById('cancel').onclick = function() { lDialog.hide()};
}
// Show the dialog
this.linker.editor.disableToolbar(['fullscreen','linker']);
this.dialog.show(inputs);
// Init the sizes
this.dialog.onresize();
this.ready=true;
};
Linker.Dialog.prototype.hide = function()
{
this.linker.editor.enableToolbar();
return this.dialog.hide();
};
Linker.Dialog.prototype.makeNodes=function(_30,_31){
for(var i=0;i<_30.length;i++){
if(typeof _30[i]=="string"){
this.dTree.add(Linker.nxtid++,_31,_30[i].replace(/^.*\//,""),"javascript:document.getElementsByName('"+this.dialog.id.href+"')[0].value=decodeURIComponent('"+encodeURIComponent(_30[i])+"');document.getElementsByName('"+this.dialog.id.type+"')[0].click();document.getElementsByName('"+this.dialog.id.href+"')[0].focus();void(0);",_30[i]);
}else{
if(_30[i].length){
var id=this.Dialog_nxtid++;
this.dTree.add(id,_31,_30[i][0].replace(/^.*\//,""),null,_30[i][0]);
this.makeNodes(_30[i][1],id);
}else{
if(typeof _30[i]=="object"){
if(_30[i].children){
var id=this.Dialog_nxtid++;
}else{
var id=Linker.nxtid++;
}
if(_30[i].title){
var _34=_30[i].title;
}else{
if(_30[i].url){
var _34=_30[i].url.replace(/^.*\//,"");
}else{
var _34="no title defined";
}
}
if(_30[i].url){
var _35="javascript:document.getElementsByName('"+this.dialog.id.href+"')[0].value=decodeURIComponent('"+encodeURIComponent(_30[i].url)+"');document.getElementsByName('"+this.dialog.id.type+"')[0].click();document.getElementsByName('"+this.dialog.id.href+"')[0].focus();void(0);";
}else{
var _35="";
}
this.dTree.add(id,_31,_34,_35,_34);
if(_30[i].children){
this.makeNodes(_30[i].children,id);
}
}
}
}
}
};
Linker.Dialog.prototype._lc=Linker.prototype._lc;
Linker.Dialog.prototype.show=function(_36,ok,_38){
if(!this.ready){
var _39=this;
window.setTimeout(function(){
_39.show(_36,ok,_38);
},100);
return;
}
if(this.ddTree.innerHTML==""){
this.ddTree.innerHTML=this.dTree._linker_premade;
}
if(_36.type=="url"){
this.dialog.getElementById("urltable").style.display="";
this.dialog.getElementById("mailtable").style.display="none";
this.dialog.getElementById("anchortable").style.display="none";
}else{
if(_36.type=="anchor"){
this.dialog.getElementById("urltable").style.display="none";
this.dialog.getElementById("mailtable").style.display="none";
this.dialog.getElementById("anchortable").style.display="";
}else{
this.dialog.getElementById("urltable").style.display="none";
this.dialog.getElementById("mailtable").style.display="";
this.dialog.getElementById("anchortable").style.display="none";
}
}
if(_36.target=="popup"){
this.dialog.getElementById("popuptable").style.display="";
}else{
this.dialog.getElementById("popuptable").style.display="none";
}
var _3a=this.dialog.getElementById("anchor");
for(var i=_3a.length;i>=0;i--){
_3a[i]=null;
}
var _3c=this.linker.editor.getHTML();
var _3d=new Array();
var m=_3c.match(/<a[^>]+name="([^"]+)"/gi);
if(m){
for(i=0;i<m.length;i++){
var n=m[i].match(/name="([^"]+)"/i);
if(!_3d.contains(n[1])){
_3d.push(n[1]);
}
}
}
m=_3c.match(/id="([^"]+)"/gi);
if(m){
for(i=0;i<m.length;i++){
n=m[i].match(/id="([^"]+)"/i);
if(!_3d.contains(n[1])){
_3d.push(n[1]);
}
}
}
for(i=0;i<_3d.length;i++){
var opt=new Option(_3d[i],"#"+_3d[i],false,(_36.anchor==_3d[i]));
_3a[_3a.length]=opt;
}
if(_3a.length==0){
this.dialog.getElementById("anchorfieldset").style.display="none";
}
if(_36.href=="http://www.example.com/"&&_36.to=="alice@example.com"){
this.dialog.getElementById("clear").style.display="none";
}else{
this.dialog.getElementById("clear").style.display="";
}
var _41=this.dialog;
var _39=this;
if(ok){
this.dialog.getElementById("ok").onclick=ok;
}else{
this.dialog.getElementById("ok").onclick=function(){
_39.hide();
};
}
if(_38){
this.dialog.getElementById("cancel").onclick=_38;
}else{
this.dialog.getElementById("cancel").onclick=function(){
_39.hide();
};
}
this.linker.editor.disableToolbar(["fullscreen","linker"]);
this.dialog.show(_36);
this.dialog.onresize();
};
Linker.Dialog.prototype.hide=function(){
this.linker.editor.enableToolbar();
return this.dialog.hide();
};

View File

@@ -1,162 +1,106 @@
<?php
// /home/username/foo/public_html/
$dir = dirname(__FILE__)."/../..";
$include = '/\.(php|shtml|html|htm|shtm|cgi|txt|doc|pdf|rtf|xls|csv)$/';
$exclude = '';
$dirinclude = '';
$direxclude = '/(^|\/)[._]|htmlarea/'; // Exclude the htmlarea tree by default
$hash = '';
foreach(explode(',', 'dir,include,exclude,dirinclude,direxclude') as $k)
{
if(isset($_REQUEST[$k]))
{
if(get_magic_quotes_gpc())
{
$_REQUEST[$k] = stripslashes($_REQUEST[$k]);
}
$hash .= $k . '=' . $_REQUEST[$k];
$$k = $_REQUEST[$k];
}
}
if($hash)
{
session_start();
if(!isset($_SESSION[sha1($hash)]))
{
?>
[ ];
<?php
exit;
}
}
function scan($dir, $durl = '')
{
global $include, $exclude, $dirinclude, $direxclude;
static $seen = array();
$files = array();
$dir = realpath($dir);
if(isset($seen[$dir]))
{
return $files;
}
$seen[$dir] = TRUE;
$dh = @opendir($dir);
while($dh && ($file = readdir($dh)))
{
if($file !== '.' && $file !== '..')
{
$path = realpath($dir . '/' . $file);
$url = $durl . '/' . $file;
if(($dirinclude && !preg_match($dirinclude, $url)) || ($direxclude && preg_match($direxclude, $url))) continue;
if(is_dir($path))
{
if($subdir = scan($path, $url))
{
$files[] = array('url'=>$url, 'children'=>$subdir);
}
}
elseif(is_file($path))
{
if(($include && !preg_match($include, $url)) || ($exclude && preg_match($exclude, $url))) continue;
$files[] = array('url'=>$url);
}
}
}
@closedir($dh);
return dirsort($files);
}
function dirsort($files)
{
usort($files, 'dircomp');
return $files;
}
function dircomp($a, $b)
{
if(is_array($a)) $a = $a[0];
if(is_array($b)) $b = $b[0];
return strcmp(strtolower($a), strtolower($b));
}
function to_js($var, $tabs = 0)
{
if(is_numeric($var))
{
return $var;
}
if(is_string($var))
{
return "'" . js_encode($var) . "'";
}
if(is_array($var))
{
$useObject = false;
foreach(array_keys($var) as $k) {
if(!is_numeric($k)) $useObject = true;
}
$js = array();
foreach($var as $k => $v)
{
$i = "";
if($useObject) {
if(preg_match('#[a-zA-Z]+[a-zA-Z0-9]*#', $k)) {
$i .= "$k: ";
} else {
$i .= "'$k': ";
}
}
$i .= to_js($v, $tabs + 1);
$js[] = $i;
}
if($useObject) {
$ret = "{\n" . tabify(implode(",\n", $js), $tabs) . "\n}";
} else {
$ret = "[\n" . tabify(implode(",\n", $js), $tabs) . "\n]";
}
return $ret;
}
return 'null';
}
function tabify($text, $tabs)
{
if($text)
{
return str_repeat(" ", $tabs) . preg_replace('/\n(.)/', "\n" . str_repeat(" ", $tabs) . "\$1", $text);
}
}
function js_encode($string)
{
static $strings = "\\,\",',%,&,<,>,{,},@,\n,\r";
if(!is_array($strings))
{
$tr = array();
foreach(explode(',', $strings) as $chr)
{
$tr[$chr] = sprintf('\x%02X', ord($chr));
}
$strings = $tr;
}
return strtr($string, $strings);
}
echo to_js(scan($dir));
?>
<?php
// /home/username/foo/public_html/
$dir = dirname(__FILE__)."/../..";
$include = '/\.(php|shtml|html|htm|shtm|cgi|txt|doc|pdf|rtf|xls|csv)$/';
$exclude = '';
$dirinclude = '';
$direxclude = '/(^|\/)[._]|htmlarea/'; // Exclude the htmlarea tree by default
// New backend config data passing
// if data was passed using xinha_pass_to_backend() we extract and use it
// as the items above
require_once(realpath(dirname(__FILE__) . '/../../contrib/php-xinha.php'));
if($passed_data = xinha_read_passed_data())
{
extract($passed_data);
}
// Old deprecated backend config data passing
// not described because you shouldn't use it.
//------------------------------------------------------------------------
$hash = '';
foreach(explode(',', 'dir,include,exclude,dirinclude,direxclude') as $k)
{
if(isset($_REQUEST[$k]))
{
if(get_magic_quotes_gpc())
{
$_REQUEST[$k] = stripslashes($_REQUEST[$k]);
}
$hash .= $k . '=' . $_REQUEST[$k];
$$k = $_REQUEST[$k];
}
}
if($hash)
{
session_start();
if(!isset($_SESSION[sha1($hash)]))
{
?>
[ ];
<?php
exit;
}
}
//------------------------------------------------------------------------
function scan($dir, $durl = '')
{
global $include, $exclude, $dirinclude, $direxclude;
static $seen = array();
$files = array();
$dir = realpath($dir);
if(isset($seen[$dir]))
{
return $files;
}
$seen[$dir] = TRUE;
$dh = @opendir($dir);
while($dh && ($file = readdir($dh)))
{
if($file !== '.' && $file !== '..')
{
$path = realpath($dir . '/' . $file);
$url = $durl . '/' . $file;
if(($dirinclude && !preg_match($dirinclude, $url)) || ($direxclude && preg_match($direxclude, $url))) continue;
if(is_dir($path))
{
if($subdir = scan($path, $url))
{
$files[] = array('url'=>$url, 'children'=>$subdir);
}
}
elseif(is_file($path))
{
if(($include && !preg_match($include, $url)) || ($exclude && preg_match($exclude, $url))) continue;
$files[] = array('url'=>$url);
}
}
}
@closedir($dh);
return dirsort($files);
}
function dirsort($files)
{
usort($files, 'dircomp');
return $files;
}
function dircomp($a, $b)
{
if(is_array($a)) $a = array_shift($a);
if(is_array($b)) $b = array_shift($b);
return strcmp(strtolower($a), strtolower($b));
}
echo xinha_to_js(scan($dir));
?>