Textpattern CMS support forum
You are not logged in. Register | Login | Help
- Topics: Active | Unanswered
Re: [plugin] [ORPHAN] bas_img_selector
Line 129 is:
<textarea cols=“50”>insertThis += ‘<p id=“basInsertAs” style=“display:none”>Insert As<br /><label><input type=“radio” name=“insertAs” value=“xhtml” class=“radio” checked=“checked” />XHTML</label><br /><label><input type=“radio” name=“insertAs” value=“txp” class=“radio” />TXP</label><br /><label><input type=“radio” name=“insertAs” value=“textile” class=“radio” />Textile</label></p>’;
</textarea>
And if you want to use textile by default it should be
<textarea cols=“50”>insertThis += ‘<p id=“basInsertAs” style=“display:block”>Insert As<br /><label><input type=“radio” name=“insertAs” value=“xhtml” class=“radio” />XHTML</label><br /><label><input type=“radio” name=“insertAs” value=“txp” class=“radio” checked=“checked” />TXP</label><br /><label><input type=“radio” name=“insertAs” value=“textile” class=“radio” />Textile</label></p>’;
</textarea>
display:block to see the Insert As Radiobuttons. And the moving checked=“checked” from xhtml-input to the txp-input , to make txp-tags default.
If you strg+c it, beware of the ‘!
Last edited by Bastian (2005-06-02 23:07:27)
Offline
Re: [plugin] [ORPHAN] bas_img_selector
I seem to be doing something wrong.
Its still entering default xhmtl and has changed the name of the xhtml radio button to txp. But its still xhtml.
This is the file I’m using now:
http://jameslomax.com/bas.txt
Any idea?
Thanks!
Last edited by jameslomax (2005-06-03 00:17:34)
Offline
Re: [plugin] [ORPHAN] bas_img_selector
This is with expanded options, insert into body as txp-tag as default.
I hope it works and have a good night!
Last edited by Bastian (2005-06-03 00:51:04)
Offline
Offline
Re: [plugin] [ORPHAN] bas_img_selector
Update:
Using this in 4.0 messes up my write page, locating the buttons etc at the top of the page, forcing the article text are and everything else below it and making it unbalanced and inefficient.
Any ideas on how to correct this?
Offline
Re: [plugin] [ORPHAN] bas_img_selector
Yes, i have an idea, that happend to my to.
That problem is that i used td-tag number 18 to inserted the plugin into the write screen.
But it seems that no 18 is not alsways besides the body-textarea.
In next version i will use regex the finde the td wich has the “textile help” Link inside.
Im working on that, stay tuned :)
Offline
Re: [plugin] [ORPHAN] bas_img_selector
OK I will!
This plug in is essential for me.
Offline
#83 2005-09-28 20:21:33
- paolo
- New Member
- Registered: 2005-09-28
- Posts: 6
Re: [plugin] [ORPHAN] bas_img_selector
Hi guys,
I wanted to use this plugin but… the link is broken :)
Offline
Re: [plugin] [ORPHAN] bas_img_selector
I got an older version (0.3) of this plugin from <a href=“http://forum.textpattern.com/viewtopic.php?pid=48710#p48710”>this post</a>. Its working but its giving me errors in the backend. Anyways here it is…
Copy the plugin out of this textarea:
<textarea>a:9:{s:7:"version";s:3:"0.3";s:6:"author";s:18:"Bastian Sackermann";s:10:"author_uri";s:20:"http://samisdat.org/";s:11:"description";s:110:"Generates a dropdown list of all images. Selected images can be inserted into article, excerpt or image field.";s:4:"type";i:1;s:4:"name";s:16:"bas_img_selector";s:4:"help";s:1858:"
	<h1>Image Selector Help</h1>

	<p>By default the plugin should gives you:</p>

	<ul>
	<li>A dropdownlist with sort criterias.</li>
		<li>A dropdownlist with the images.</li>
		<li>Radiobuttons to select a format the image is inserted with.</li>
		<li>Radiobuttons to select where the image is inserted in.</li>
	</ul>

	<p>You can edit *$bas_prefs* if you want:</p>

	<ul>
	<li><strong>orginal</strong> Set this to false, to show not the orginal images. <br />
 Makes sense, if set <strong>thumbs</strong> to <strong>true</strong> and used the plugin to insert thumbnails only.</li>
		<li><strong>thumbs</strong> Set this to false and the thumbnails don&#8217;t appear in the dropdown.</li>
		<li><strong>sortable</strong> Set this to false, if you don&#8217;t want the image list sortable.</li>
		<li><strong>format</strong> Defines the format of the inserted image, can be <strong>xhtml</strong>, <strong>txp</strong> or <strong>textile</strong>. Or leave it on <strong>user</strong> for users choice.</li>
		<li><strong>insert_in</strong> This one could be <strong>Body</strong>, <strong>Excerpt</strong> or <strong>Image</strong> (Note the capitalization for this three!). <br />
Or leave it on <strong>user</strong> for users choice.</li>
		<li><strong>zem_article_image</strong> Set it to <strong>true</strong>, if you use zem_article_image. In image field the id&#8217;s will bee comma-separated.</li>
		<li><strong>img_dir</strong> The default $prefs[&#8220;path_from_root&#8221;].$prefs[&#8220;img_dir&#8221;].&#8221;/&#8221; should be the right image path, but if not, edit this.</li>
		<li><strong>img_dir</strong> Here is the image folder stored.</li>
		<li><strong>expanded</strong> Set to <strong>false</strong> and the image selector is not expanded at start.</li>
		<li><strong>Thumb prefix</strong> is the thumb prefix :)</li>
	</ul>




 ";s:4:"code";s:13660:"if (@txpinterface == 'admin')
	register_callback("bas_img_select", "article");
function bas_img_select($event, $step) {
	$prefs = get_prefs();
	//You can editing the following lines to make sure, that the plug fits to your needs.
         //See the Help for more informations
	$bas_prefs[0]['option']= 'orginal';
	$bas_prefs[0]['value'] = 'true'; # false|true
	$bas_prefs[1]['option']= 'thumbs';
	$bas_prefs[1]['value'] = 'true'; # false|true
	$bas_prefs[2]['option']= 'sortable';
	$bas_prefs[2]['value'] = 'true'; # false|true
	$bas_prefs[3]['option']= 'format';
	$bas_prefs[3]['value'] = 'user'; # user|xhtml|txp|textile
	$bas_prefs[4]['option']= 'insert_in';
	$bas_prefs[4]['value'] = 'user'; # user|Body|Excerpt|Image
	$bas_prefs[5]['option']= 'zem_article_image';
	$bas_prefs[5]['value'] = 'false'; # false|true
	$bas_prefs[6]['option'] = "img_dir";
	$bas_prefs[6]['value'] =  $prefs["path_from_root"].$prefs["img_dir"]."/"; # override this, if img_dir is not bee found
	$bas_prefs[7]['option']= 'expanded';
	$bas_prefs[7]['value'] = 'true'; # false|true
	$bas_prefs[8]['option']= 'Thumb prefix';
	$bas_prefs[8]['value'] = 'Thumb: '; # What you want
	//Stop editing here -------------------------------------------------------------

	$GLOBALS['bas_prefs'] = $bas_prefs;

	$bas_img = bas_get_img();
	$bas_img_cat  = bas_get_cats($bas_img);
	$bas_out = bas_prefs_for_js($bas_img_cat);
	$bas_out.= bas_img_for_js($bas_img);
	bas_display($bas_out);
}

//-------------------------------------------------------------
function bas_get_img(){
	global $bas_prefs;
	global $txpcfg;
	$bas_img['db'] = getRows('SELECT * FROM '.$txpcfg['table_prefix'].'txp_image ORDER BY date DESC');
	//orginal and thumbs
	if($bas_prefs[1]['value'] == 'true' && $bas_prefs[0]['value'] == 'true'){
		$count = 0;
		for($i=0;$i<count($bas_img['db']);$i++){
			if($bas_img['db'][$i]["thumbnail"] == 0){
				$bas_img['all'][$i+$count] = $bas_img['db'][$i];
			}
			else{
				$bas_img['all'][$i+$count] = $bas_img['db'][$i];
				$count++;
				$bas_img['all'][$i+$count] = bas_get_thumb($bas_img['db'][$i]);
                                 //if thumbnail is set in db, but file could not be found
                                 if(!isset($bas_img['all'][$i+$count]['id'])){
					array_pop($bas_img['all']);
					$count--;
				}
			}
		}
		return $bas_img['all'];
	}
	//just thumbs
	elseif($bas_prefs[1]['value'] == 'true' && $bas_prefs[0]['value'] == 'false'){
		$count = 0;
		for($i=0;$i<count($bas_img['db']);$i++){
			if($bas_img['db'][$i]["thumbnail"] == 1){
				$bas_img['thumbs'][$count] = bas_get_thumb($bas_img['db'][$i]);
				//if thumbnail is set in db, but file could not be found
				if(isset($bas_img['thumbs'][$count]['id']))
					$count++;
				else
					array_pop($bas_img['thumbs']);
			}
		}
		return $bas_img['thumbs'];
	}
	//no thumbs
	elseif($bas_prefs[1]['value'] == 'false' && $bas_prefs[0]['value'] == 'true'){
		return $bas_img['db'];
	}
}

//Thumbs themself are not in the db, so we have to catch them -------------------------------------------------------------
function bas_get_thumb($orginal){
	global $bas_prefs;
	//perhaps thumb and orginal img don't have the same format
	$format = array('.png','.gif','.jpg');
	for($i=0;$i<count($format);$i++){
		if(is_file("../images/".$orginal['id']."t".$format[$i])){
			$thumb = $orginal;
			$thumb['name'] = $bas_prefs[8]['value']. $thumb['name'];
			$thumb['ext'] = $format[$i];
			$size = getimagesize("../images/".$thumb['id']."t".$format[$i]);
			$thumb['w'] = $size[0];
			$thumb['h'] = $size[1];
                         $thumb['thumbnail'] = 2;
		}
	}
	return $thumb;
}
//Get only the used cats. -------------------------------------------------------------
function bas_get_cats($bas_img){
	for($i=0;$i<count($bas_img);$i++){
         	if($bas_img[$i]['category'] != '')
			$bas_cat[$i] = $bas_img[$i]['category'];
         }
         $bas_cat = array_values(array_unique($bas_cat));
         return $bas_cat;
}
//Let Javascript know, which images we have -------------------------------------------------------------
function bas_img_for_js($bas_img){
	$js_array .= 'var bas_img = new Array();'.chr(13);
	for($i=0;$i<count($bas_img);$i++){
		$js_array.= 'bas_img["'.$i.'"] = new Array("'.$bas_img[$i]["id"].'","'.$bas_img[$i]["name"].'","'.$bas_img[$i]["category"].'","'.$bas_img[$i]["ext"].'","'.$bas_img[$i]["w"].'","'.$bas_img[$i]["h"].'","'.$bas_img[$i]["alt"].'","'.$bas_img[$i]["caption"].'","'.$bas_img[$i]["date"].'","'.$bas_img[$i]["author"].'","'.$bas_img[$i]["thumbnail"].'");'.chr(13);
	}
	return $js_array;
}
//Let Javascript know, which preferences are set -------------------------------------------------------------
function bas_prefs_for_js($bas_cat){
	for($i=0;$i<count($bas_cat);$i++){
		$bas_cat[$i] = '"'.$bas_cat[$i].'"';
	}
	$bas_cat = join(",",$bas_cat);
	$js_array .= "var bas_img_cat = new Array(".$bas_cat.");".chr(13);
	$prefs = $GLOBALS['bas_prefs'];
	$js_array .= 'var bas_prefs = new Array();'.chr(13);
	for($i=0;$i<count($prefs);$i++){
		$js_array.= 'bas_prefs["'.$prefs[$i]['option'].'"] = "'.$prefs[$i]['value'].'"'.chr(13);
	}
	return $js_array;
}

//bas_display inserts the drop-down-list into the write sreen. -------------------------------------------------------------
function bas_display($bas_out){
global $bas_prefs;
($bas_prefs[7]['value'] == 'true')?$expand = 'block':$expand = 'none';

echo '
<script language="JavaScript" type="text/javascript">
<!--
'.$bas_out.'


var start =  "<p>Select Image</p>";
var start = "<a href=\"#\" onclick=\"toggleDisplay(\'bas_img_options\');\">Select Image</a></p><div id=\"bas_img_options\" style=\"display:'.$expand.';\">";
var sort = "";
var img_list = "";
var preview = "";
var format = "";
var insert_in = "";
var insert_here = "";
var save_sort_by = "";
bas_ini();


function bas_ini(){
	bas_code_sort();
	bas_code_images();
	bas_code_format();
	bas_code_insert_in();
	bas_display_ini();
}

function bas_resort() {
	var sort_by = save_sort_by;
	var bas_img_sort = new Array();
	var count = 0;
	//sort by cat
	if(sort_by.search(/cat-/) != -1){
		var cat = sort_by.replace(/cat-/,"");
		for (i=0;i<bas_img.length;i++ ) {
			if(bas_img[i][2] == cat){
				bas_img_sort[count] = bas_img[i][0];
				count++;
			}
                 }
         }
	//sort by name
	if(sort_by == "name-a" || sort_by == "name-z"){
		for (i=0;i<bas_img.length;i++ ) {
			bas_img_sort[count] = bas_img[i][1]+"|"+bas_img[i][0];
			count++;
		}
		bas_img_sort.sort();
		if(sort_by == "name-z")
			bas_img_sort.reverse();
		for(i=0;i<bas_img_sort.length;i++){
			var teil = bas_img_sort[i].split("|");
			bas_img_sort[i] = teil[1];
		}
         }
	//sort by date
	if(sort_by == "date-new" || sort_by == "date-old"){
		for (i=0;i<bas_img.length;i++ ) {
			bas_img_sort[count] = bas_img[i][0];
			count++;
		}
		if(sort_by == "date-old")
			bas_img_sort.reverse();
	}
	//show all
	if(sort_by == "all"){
		for (i=0;i<bas_img.length;i++ ){
			bas_img_sort[count] = bas_img[i][0];
			count++;
		}
	}
	bas_code_images_sort(bas_img_sort);
	bas_display();
}
function bas_code_sort(){
	if(bas_prefs["sortable"] == "true"){
		var sort_by = document.forms["article"].elements["sort_by"];
		sort += "<p>";
		sort += \'<select name="sort_by" size="1" onChange="save_sort_by = this.value;bas_resort();">\';
		sort += \'<option value="all" selected="selected">sort By</option>\';
		for (i=0;i<bas_img_cat.length;i++ ){
			sort += \'<option value="cat-\'+bas_img_cat[i]+\'">Cat: \'+bas_img_cat[i]+\'</option>\';
		}
		sort += \'<option value="name-a">Name A first</option>\';
		sort += \'<option value="name-z">Name z first</option>\';
		sort += \'<option value="date-new">Date newest first</option>\';
		sort += \'<option value="date-old">Date oldest first</option>\';
		sort += \'<option value="all">Show all</option>\';
		sort += \'</select>\';
		sort += \'</p>\';
	}
}
function bas_code_images(){
	img_list = "";
	img_list += \'<p>\';
	img_list += \'<select name="bas_img" size="1">\';
	img_list += \'<option value="none" selected="selected">Select Image</option>\';
	for (i=0; i<bas_img.length ; i++ ){
		if(bas_img[i] != "")
			img_list += \'<option value="\'+i+\'">\'+bas_img[i][1]+\'</option>\';
	}
	img_list += \'</select>\';
	img_list += \'</p>\';
}
function bas_code_images_sort(bas_img_sort){
	img_list = "";
	img_list += \'<p>\';
	img_list += \'<select name="bas_img" size="1">\';
	img_list += \'<option value="none" selected="selected">Select Image</option>\';
	for(i=0;i<bas_img_sort.length;i++){
		for (x=0;x<bas_img.length;x++ ){
			if(bas_img[x][0] == bas_img_sort[i])
				img_list += \'<option value="\'+i+\'">\'+bas_img[x][1]+\'</option>\';
		}
	}
	img_list += \'</select>\';
	img_list += \'</p>\';
}
function bas_code_format(){
	if(bas_prefs[\'format\'] == \'user\' && bas_prefs["insert_in"] != \'Image\'){
		format += \'<p>Insert as<br />\';
		format += \'<input type="radio" name="format" value="xhtml" checked="checked" > XHTML<br />\';
		format += \'<input type="radio" name="format" value="txp"> TXP<br />\';
		format += \'<input type="radio" name="format" value="textile"> Textile<br />\'
		format += \'</p>\';
	}
}
function bas_code_insert_in(){
	insert_in += \'<p>\';
	if(bas_prefs["insert_in"] == \'user\'){
		insert_in += \'Insert selected in<br />\';
		insert_in += \'<input type="radio" name="insert_in" value="Body" checked="checked" /> Body<br />\';
		insert_in += \'<input type="radio" name="insert_in" value="Image" /> Image Field<br />\';
		insert_in += \'<input type="radio" name="insert_in" value="Excerpt" /> Excerpt<br />\';
	}
	insert_in += "<input type=\"button\" value=\"Insert\" onClick=\"if(document.forms[\'article\'].elements[\'bas_img\'].value != \'none\')bas_insert();\" />";
	insert_in += \'</p>\';
	insert_in += \'</div>\';
}

function bas_display(){
	var insert_this = start+sort+img_list+preview+format+insert_in;
	var cell = document.getElementsByTagName("td")[insert_here].innerHTML;
	cell = cell.split("<!--BAS-->");
	cell = insert_this + "<!--BAS-->" + cell[1];
	document.getElementsByTagName("td")[insert_here].innerHTML = cell;

}
function bas_display_ini(){
	var insert_this = start+sort+img_list+preview+format+insert_in;
	var cells = document.getElementsByTagName("td");
	for (i=0; i<cells.length ; i++ ) {
		var cell = document.getElementsByTagName("td")[i].innerHTML;
		insert_here = i;
		var pattern = "Textile Help";
		if(cell.search(pattern) != -1){
			cell = insert_this + "<!--BAS-->" + cell;
			document.getElementsByTagName("td")[i].innerHTML = cell;
			i = cells.length;
		}
	}
}
function bas_insert() {
	var bas_selected_img = document.forms["article"].elements["bas_img"].value;
	if(bas_prefs["insert_in"] == "user"){
		for (i=0;i<document.getElementsByName("insert_in").length;i++ ){
			if(document.forms["article"].elements["insert_in"][i].checked == true)
				var where = document.forms["article"].elements["insert_in"][i].value;
		}
	}
	else
		var where = bas_prefs["insert_in"];
	if(bas_prefs["format"] == "user")
		for (i=0;i<document.getElementsByName("format").length;i++ ){
			if(document.forms["article"].elements["format"][i].checked == true)
				var format = document.forms["article"].elements["format"][i].value;
		}
	else
		var format = bas_prefs["format"];
	if(where != "Image"){
		var out = bas_formating(bas_selected_img,format);
		bas_img_insert_text(out,where);
	}
	if(where == "Image")
		bas_img_insert_field(bas_img[bas_selected_img][0]);
}
function bas_formating(bas_selected_img,format) {
	var code = "";
	if(format == "textile"){
		code = "!"+bas_prefs["img_dir"]+bas_img[bas_selected_img][0]+bas_img[bas_selected_img][3]+"!";
	}
	if(format == "txp"){
		if(bas_img[bas_selected_img][10] == 2)
			code = \'<txp:thumbnail id="\'+bas_img[bas_selected_img][0]+\'" />\';
		else
			code = \'<txp:image id="\'+bas_img[bas_selected_img][0]+\'" />\';
	}
	if(format == "xhtml"){
		code = \'<img src="\'+bas_prefs[\'img_dir\']+bas_img[bas_selected_img][0]+bas_img[bas_selected_img][3]+\'" style="height:\'+bas_img[bas_selected_img][4]+\'px;width:\'+bas_img[bas_selected_img][5]+\'px" alt="\'+bas_img[bas_selected_img][6]+\'" />\';
	}
return code;
}

/* bas_img_insert_text() based on a script by Torsten Anacker  */
/* http://aktuell.de.selfhtml.org/tippstricks/javascript/bbcode/ */

function bas_img_insert_text(out,where) {
	var input = document.forms["article"].elements[where];
	input.focus();
	if(typeof document.selection != "undefined") {
		var range = document.selection.createRange();
		var insText = range.text;
		range.text = out + insText;
		range = document.selection.createRange();
		if(insText.length == 0)
			range.move("character", -out.length);
                 else
			range.moveStart("character", out.length);
		range.select();
	}
	else if(typeof input.selectionStart != "undefined"){
		var start = input.selectionStart;
		var end = input.selectionEnd;
		var insText = input.value.substring(start, end);
		input.value = input.value.substr(0, start) + out + insText + input.value.substr(end);
		var pos;
		if (insText.length == 0)
			pos = start + out.length;
		else
			pos = start + out.length ;
		input.selectionStart = pos;
		input.selectionEnd = pos;
	}
	else
		input.value = input.value + out;
}

function bas_img_insert_field(bas_selected_img) {
         if(bas_prefs["zem_article_image"] == "true"){
		var save = document.forms["article"].elements["Image"].value;
		if(save == "")
			document.forms["article"].elements["Image"].value = bas_selected_img;
		else
			document.forms["article"].elements["Image"].value = save+ "," + bas_selected_img;
	}
	else
		document.forms["article"].elements["Image"].value = bas_selected_img;
}

-->
</script>
';
}


";s:3:"md5";s:32:"9d10e7af539816ce20f9bf74b2a13a45";}</textarea>
“Take a point, stretch it into a line, curl it into a circle, twist it into a sphere, and punch through the sphere.”
— Albert Einstein
Offline
Re: [plugin] [ORPHAN] bas_img_selector
I’ve installed v0.3 but it’s giving me the following notices:
Notice: Undefined variable: js_array in /home/Sites/Customers/www.xpressit.nl/web/textpattern/lib/txplib_misc.php(429) : eval()’d code on line 123
Notice: Undefined variable: js_array in /home/Sites/Customers/www.xpressit.nl/web/textpattern/lib/txplib_misc.php(429) : eval()’d code on line 111
Is someone willing/able to post v0.4 or tell me how I can correct this?
thanks in advance.
Offline
Re: [plugin] [ORPHAN] bas_img_selector
Here is the bas_img_selector v0.5
Tested with txp 4.0.1 and using IE 6 and Firefox.
Please let me know, if you find erros, bugs or something like this.
Bastian
Last edited by Bastian (2005-10-13 19:44:23)
Offline
Re: [plugin] [ORPHAN] bas_img_selector
Thanks so much for the update bastian! Much appreciated. I’ll let you know if any problems arise.
Jamie
Offline
Re: [plugin] [ORPHAN] bas_img_selector
Bastian,
It works excellent, I think it’s a perfect plugin. thanks a lot!!!
Sorry, the actual adding of the pictures doesnt’t work… Nothing happens when I click ‘add’
Maarten
Last edited by maarten (2005-10-16 19:28:53)
Offline
Re: [plugin] [ORPHAN] bas_img_selector
Don’t see a thing (R 1036). Also, mine still reports version .1.
Anybody?
Offline