Textpattern CMS support forum
You are not logged in. Register | Login | Help
- Topics: Active | Unanswered
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
Re: [plugin] [ORPHAN] bas_img_selector
Mine says 0.1 too, but I know its the new version because the previous one totally broke the admin page. Now it doesn’t.
Thanks for the update! – love this plugin.
One question though: how can I get “More” to open by default? (the ‘add’ and ‘tag’ options)?
Offline
Re: [plugin] [ORPHAN] bas_img_selector
maarten wrote:
Sorry, the actual adding of the pictures doesnt’t work… Nothing happens when I click ‘add’
Dunno if you figured it out already, but by default the plugin adds the image as the “article image” hidden in the “Extended Settings” on the Write tab. You are free to select between the insert locations “Article image”, “Body” and “Excerpt” by expanding image_selector’s “More” section.
Thomas Stache
Offline
Re: [plugin] [ORPHAN] bas_img_selector
Maarten send me the error report per email.
It seems to be an IE special. In Firefox it works, but i get the very same error as maarten in IE.
Something with the radio buttons ( javascript checking which one is selected), it seems.
I’m working on that, but for students in germany the studies go on in middle october and i have to visit my university :)
edit: YES, the version’s info says 0.1, but it is not 0.1. It is developers fool. I’m a kind of numeric illiterate.
Last edited by Bastian (2005-10-19 19:01:28)
Offline
Re: [plugin] [ORPHAN] bas_img_selector
One question though: how can I get “More” to open by default? (the ‘add’ and ‘tag’ options)?
Offline
Re: [plugin] [ORPHAN] bas_img_selector
@jameslomax:
I sent you the file per email. Hope it works, if it doesn’t: I have my email-address
@all
What customising of the image selector do you expect?
Don’t mention that you want that damm thing work. Instead write my it don’t.
Really, i write the plugin for a single man, who is not able to insert images, because he don’t know about html.
So what options should be covered by new versions?
I played a little with includeing a slideshow maker. My girlfriends camera, for example, can shot a serie of 16 images, which can be played as a little film with some javascript. Interested?
I use albumpattern and local i have included ap-images to image selector. Interested?
Doing things for myself is pretty easy, because i know my root and system varis, i know what i want.
I don’t implement things, if i don’t know what.
So tell me and i try!
Last edited by Bastian (2005-10-19 20:00:39)
Offline
Re: [plugin] [ORPHAN] bas_img_selector
Hi Bastian.
Thanks for the plugin. I have used it successfully in the past and I prefer it to img_popper. But at present it doesn’t show up. I’m using very recent builds and hardly any other plugins. Any ideas?
-Dale
Offline