diff options
-rw-r--r-- | includes/js/MultiComboBox.js | 72 | ||||
-rw-r--r-- | templates/dojo.inc.php | 35 | ||||
-rw-r--r-- | templates/editbookmark.tpl.php | 8 | ||||
-rw-r--r-- | templates/sidebar.block.menu2.php | 1 | ||||
-rw-r--r-- | templates/top.inc.php | 22 |
5 files changed, 117 insertions, 21 deletions
diff --git a/includes/js/MultiComboBox.js b/includes/js/MultiComboBox.js new file mode 100644 index 0000000..b263c8b --- /dev/null +++ b/includes/js/MultiComboBox.js @@ -0,0 +1,72 @@ +/* + Copyright (c) 2004-2008, The Dojo Foundation All Rights Reserved. + Available via Academic Free License >= 2.1 OR the modified BSD license. + see: http://dojotoolkit.org/license for details +*/ + +/* SemanticScuttle: This script is a light modification of dojox.form.MultiComboBox +This fork allows specific use until DOJO 1.2.3 in Google CDN. */ + + + +if(!dojo._hasResource["js.MultiComboBox"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code. +dojo._hasResource["js.MultiComboBox"] = true; +dojo.provide("js.MultiComboBox"); +dojo.experimental("js.MultiComboBox"); +dojo.require("dijit.form.ComboBox"); +dojo.require("dijit.form.ValidationTextBox"); + +dojo.declare("js.MultiComboBox", + [dijit.form.ValidationTextBox, dijit.form.ComboBoxMixin],{ + // + // summary: A ComboBox that accpets multiple inputs on a single line? + // + // delimiter: String + // The character to use to separate items in the ComboBox input + delimiter: ",", + _previousMatches: false, + + _setValueAttr: function(value){ + if (this.delimiter && value.length != 0){ + value = value+this.delimiter+" "; + arguments[0] = this._addPreviousMatches(value); + } + this.inherited(arguments); + }, + + _addPreviousMatches: function(/* String */text){ + if(this._previousMatches){ + if(!text.match(new RegExp("^"+this._previousMatches))){ + text = this._previousMatches+text; + } + } + text = this._cleanupDelimiters(text); // SScuttle: this line was moved + return text; // String + }, + + _cleanupDelimiters: function(/* String */text){ + if(this.delimiter){ + text = text.replace(new RegExp(" +"), " "); + text = text.replace(new RegExp("^ *"+this.delimiter+"* *"), ""); + text = text.replace(new RegExp(this.delimiter+" *"+this.delimiter), this.delimiter); + } + return text; + }, + + _autoCompleteText: function(/* String */text){ + arguments[0] = this._addPreviousMatches(text); + this.inherited(arguments); + }, + + _startSearch: function(/* String */text){ + text = this._cleanupDelimiters(text); + var re = new RegExp("^.*"+this.delimiter+" *"); + + if((this._previousMatches = text.match(re))){ + arguments[0] = text.replace(re, ""); + } + this.inherited(arguments); + } +}); + +}
\ No newline at end of file diff --git a/templates/dojo.inc.php b/templates/dojo.inc.php new file mode 100644 index 0000000..bc754a0 --- /dev/null +++ b/templates/dojo.inc.php @@ -0,0 +1,35 @@ +<?php +/*************************************************************************** + Copyright (C) 2005 - 2006 Scuttle project + http://sourceforge.net/projects/scuttle/ + http://scuttle.org/ + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + ***************************************************************************/ + +?> + +<?php if (isset($loadjs)) :?> +<script type="text/javascript" + src="http://ajax.googleapis.com/ajax/libs/dojo/1.2/dojo/dojo.xd.js" + djConfig="parseOnLoad:true, isDebug:false, usePlainJson:true, baseUrl: '<?php echo ROOT ?>', modulePaths: {'js': 'includes/js'},"></script> + +<script type="text/javascript"> +dojo.require("dojo.parser"); +dojo.require("dojo.data.ItemFileReadStore"); +dojo.require("js.MultiComboBox"); // DOJO module adapted for SemanticScuttle +dojo.require("dijit.Tree"); +</script> +<?php endif ?>
\ No newline at end of file diff --git a/templates/editbookmark.tpl.php b/templates/editbookmark.tpl.php index 4f97dac..9592384 100644 --- a/templates/editbookmark.tpl.php +++ b/templates/editbookmark.tpl.php @@ -15,8 +15,12 @@ switch ($row['bStatus']) { $accessPrivate = ' selected="selected"'; break; } + +$this->includeTemplate("dojo.inc"); ?> + + <script type="text/javascript"> //window.onload = function() { // document.getElementById("address").focus(); @@ -44,7 +48,7 @@ switch ($row['bStatus']) { <th align="left"><?php echo T_('Tags'); ?></th> <td class="scuttletheme"> <span dojoType="dojo.data.ItemFileReadStore" jsId="memberTagStore" url="<?php echo ROOT?>ajax/gettags.php"></span> - <input type="text" dojoType="dojox.form.MultiComboBox" id="tags" name="tags" size="75" value="<?php echo filter(implode(', ', $row['tags']), 'xml'); ?>" store="memberTagStore" delimiter="," searchAttr="tag" hasDownArrow="false"/></td> + <input type="text" dojoType="js.MultiComboBox" id="tags2" name="tags" size="75" value="<?php echo filter(implode(', ', $row['tags']), 'xml'); ?>" store="memberTagStore" delimiter="," searchAttr="tag" hasDownArrow="false"/></td> <td>← <?php echo T_('Comma-separated'); ?></td> </tr> <tr> @@ -99,7 +103,7 @@ switch ($row['bStatus']) { <?php // Dynamic tag selection -$this->includeTemplate('dynamictags.inc'); +//$this->includeTemplate('dynamictags.inc'); // Bookmarklets and import links if (empty($_REQUEST['popup']) && (!isset($showdelete) || !$showdelete)) { diff --git a/templates/sidebar.block.menu2.php b/templates/sidebar.block.menu2.php index 40bf27b..439ed33 100644 --- a/templates/sidebar.block.menu2.php +++ b/templates/sidebar.block.menu2.php @@ -21,6 +21,7 @@ if(!isset($user) || $user == '') { $menu2Tags = $GLOBALS['menu2Tags']; if (sizeOf($menu2Tags) > 0) { + $this->includeTemplate("dojo.inc"); ?> <h2><?php echo '<span>'.T_('Menu Tags').'</span> ';?></h2> diff --git a/templates/top.inc.php b/templates/top.inc.php index e149c34..d2f05ea 100644 --- a/templates/top.inc.php +++ b/templates/top.inc.php @@ -4,8 +4,7 @@ <head> <title><?php echo filter($GLOBALS['sitename'] . (isset($pagetitle) ? ': ' . $pagetitle : '')); ?></title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> -<link rel="icon" type="image/png" - href="<?php echo ROOT ?>icon.png" /> +<link rel="icon" type="image/png" href="<?php echo ROOT ?>icon.png" /> <link rel="stylesheet" type="text/css" href="<?php echo ROOT ?>scuttle.css" /> <?php @@ -16,26 +15,11 @@ if(isset($rsschannels)) { } } ?> - -<?php if (isset($loadjs)) :?> - -<script type="text/javascript" - src="<?php echo ROOT ?>jsScuttle.php"></script> - - <link rel="stylesheet" type="text/css" href="http://ajax.googleapis.com/ajax/libs/dojo/1.2/dijit/themes/nihilo/nihilo.css"> -<script type="text/javascript" - src="http://ajax.googleapis.com/ajax/libs/dojo/1.2/dojo/dojo.xd.js" - djConfig="parseOnLoad:true, isDebug:false, usePlainJson:true"></script> - -<script type="text/javascript"> -dojo.require("dojo.parser"); -dojo.require("dojo.data.ItemFileReadStore"); -dojo.require("dojox.form.MultiComboBox"); -dojo.require("dijit.Tree"); -</script> +<?php if (isset($loadjs)) :?> +<script type="text/javascript" src="<?php echo ROOT ?>jsScuttle.php"></script> <?php endif ?> </head> |