Go to main content

Textpattern CMS support forum

You are not logged in. Register | Login | Help

#1 2005-08-20 03:40:07

graumeister
Plugin Author
From: Ban Bang Por, Samui, Thailand
Registered: 2005-01-16
Posts: 167
Website

[plugin] [ORPHAN] glx_admin_image_resize

Notice: This thread is archived, this plugin is no longer supported but it can be copied from this page.

**********************************************************

Hi all, after mailing with Johan i took ownership of both plugins developed by him glx_admin_image_resize and glx_gravatar. He currently is out of time to maintain them and I use them, so why not?

At grauhirn.org you find version 2006.1 of the plugin with two small fixes in presentation of the form. Documentation and use of the plugin is still the same as described in this thread.

If you have any thought about new features, gimmicks and addons to the plugin please dont wait with suggestions as I am starting to work on a new version soon. This thread would be a good place ;)

todo:

  • handling of gif- and png-graphics
a:10:{s:4:"name";s:15:"glx_admin_image";s:6:"author";s:15:"der GrauMeister";s:10:"author_uri";s:47:"http://grauhirn.org/patterntext/glx_admin_image";s:7:"version";s:6:"2006.1";s:11:"description";s:45:"advanced image editing and thumbnail creation";s:4:"help";s:4924:"<p><style type="text/css">.gho{background-color:#222;color:#ccc;font-family:Verdana,sans-serif;font-size:0.8em;position:relative;margin:15px auto;padding:10px;text-align:left;width:740px;}.gho p{padding:5px;background-color:#282828;border:1px solid #515551;}.gho a:link,.gho a:visited{color:#aa0303;text-decoration:none;}.gho a:hover,.gho a:active{color:#aa0303;text-decoration:underline;}</style><div class="gho"><p>This is a Textpattern-plugin by <a href="http://grauhirn.org/">&#3626;&#3637;&#3648;&#3607;&#3634;&#3626;&#3617;&#3629;&#3591;.&#3629;&#3591;&#3588;&#3660;&#3585;&#3619;</a>. If you find a bug or think the documentation could be a little bit more in depth or understandable, <a href="http://grauhirn.org/contact/">please do not hesitate to contact the author</a>.</p></div></p>

	<h2>glx_admin_image_resize</h2>

	<p>Resize image and creates a thumbnail on upload. Developed by <a href="http://johan.galaxen.net/">Johan Nilsson</a> and maintained by <a href="http://grauhirn.org/">der GrauMeister</a>.</p>

	<h3>Settings</h3>

	<p>You can change the defines at the beginning of the plugincode to suit your needs.</p>

	<h3>CSS</h3>

	<p>This plugin also creates a stylesheet named glx_admin_image_resize, that can be found under the style tab.</p>

	<p>Default stylesheet</p>

<pre><code>label.inline {
margin: 5px;
}
label.block {
margin: 5px 5px 0 0;
display: block;
}
.resize {
float: left;
}
.rotate {
float: right;
}
hr {
border-bottom: 1px solid #DDDDDD;
border-top: none;
border-right: none;
border-left: none;
height: 1px;
clear: both;
}</code></pre>

	<h3>Requirements</h3>

	<ul>
		<li>Textpattern 4.0.0+</li>
		<li>GD 2.0.1 or later</li>
		<li>and some images (jpg) to test it with</li></li>
	</ul>

	<h3>Changelog</h3>

	<p>2005-12-24 v.2006.1</p>
	<ul>
		<li>re-release (revised for Textpattern 4.0.3)</li>
	</ul>

	<p>2005-10-14 v.4.0.2</p>
	<ul>
		<li>Formfields of TXP with same functionality will be hidden</li>
		<li>configuration: width, height or longest side will be scaled to x</li>
	</ul>

	<p>2005-10-14 v.4.0.1</p>
	<ul>
		<li>optimization of square cropping (cutting only the longest side of the picture) (thanks <a href="http://www.buriedshovel.com">heikki74</a>)</li>
	</ul>

	<p>2005-08-20 v.0.5.1b/v.0.5.2b</p>
	<ul>
		<li>Fixed some small bug introduced with Textpattern 4.0 (gho)</li>
	</ul>

	<p>2005-04-04 v.0.5b</p>
	<ul>
		<li>Cookie that saves the latest length for thumb and large image, from an idea by graumeister</li>
		<li>Checkbox that makes it possible to resize image on upload with latest stored value.</li>
		<li>Image opts now appears on thumbnail insert and image replace, thanks ZiQ</li>
		<li>Support for image rotate for php 4.3.0 or lower, thanks Tobias Einarsson</li>
		<li>GD version check, function from MDP Automatic Resize and Thumbnail for textpattern by <a href="http://www.purephotoshop.com">Caged</a></li>
	</ul>

	<p>2005-03-30 v.0.4b<br />
ZiQ added the following</p>
	<ul>
		<li>Submit button, no need to upload an image to create thumbnail, square thumbnail or to resize image anymore.</li>
		<li>Checkbox, if you want to resize the large image</li>
		<li>Quality input field for thumbnail and large image, but this two fields are commented out right now, personally i think its too cluttered to have them there, but you could comment them out if you want them, the values by default is 90 for thumbs and 80 for large images.</li>
	</ul>

	<p>The behavior for the plugin has changed a bit since this version, on upload the plugin will only creates a thumbnail, no resize is now done. When replacing a image it only replace the image, no resize is done or thumbnail is created.</p>

	<p>Other updates</p>

	<ul>
		<li>Image rotating, 180, 90CW, 90CCW, requires php 4.3.0 or greater</li>
		<li>Plugin renamed to glx_amin_image instead of glx_admin_image_resize</li>
		<li>Stylesheet renamed to glx_image_admin, delete old one, I also added some new rules to the stylesheet</li>
	</ul>

	<p>2005-03-27 v.0.3b</p>
	<ul>
		<li>Its now possible to create squared thumbnails</li>
		<li>Better js for outputting the new input fields</li>
		<li>Changed the order of the input fields, they are now above the upload field</li>
		<li>A stylesheet named glx_admin_image_resize is created under the style tab for some very basic styling under the image edit page.</li>
	</ul>

	<p>2005-03-25 v.0.2b<br />
It still uses the same technic to manipulate the image but it is now possible to (in the image edit page)</p></p>

	<ul>
		<li>specify the values for the thumb and the large image</li>
		<li>decide if you want to resize and create a thumbnail or not</li>
	</ul>

	<p>2005-03-25 v.0.1b</p>
	<ul>
		<li>initial release</li>
	</ul>

	<p><div class="gho"><p>plugin compiled at: Tue, 03 Jan 2006 10:02:49 +0100 | current version at <a href="http://grauhirn.org/patterntext/glx_admin_image">http://grauhirn.org/patterntext/glx_admin_image</a></p></div></p>";s:4:"code";s:24763:"
// set this to 0 to show the original thumbnail- and cutting-forms of txp.
define('HIDETXP', 1);
// set this to 1 to force old method of squarethumbproduction
define('METHOD', 2);
if (@ txpinterface == 'admin') {
    register_callback("glx_admin_image", "image");
    register_callback("glx_image_opts", "image");
    register_callback("glx_image_edit_opts", "image", "thumbnail_insert");
    register_callback("glx_image_edit_opts", "image", "image_replace");
    register_callback("glx_image_edit_opts", "image", "image_edit");
};
function glx_admin_image($event, $step) {
    $action = ps("action") ? ps("action") : "resize";
    switch ($action) {
        case "resize":
            glx_image_resize();
            break;
        case "rotate":
            glx_image_rotate();
            break;
        default:
            glx_image_resize();
    };
}
/**
 * Function from MDP Automatic Resize and Thumbnail for textpattern
 * By Caged: <http://www.purephotoshop.com>
 */
function glx_get_gd_version() {
    if(!function_exists('imagecreatetruecolor')){
        $function_create = 'imagecreate';
        $function_copy = 'imagecopyresized';
    } else {
        $function_create = 'imagecreatetruecolor';
        $function_copy = 'imagecopyresampled';
    };
    return array('copy' => $function_copy, 'create' => $function_create);
}
/**
 * Rotate image php 4.3.0 or lower
 * By Tobias Einarsson
 */
function glx_old_image_rotate($src, $angle){
    // check current GD version
    $gd = glx_get_gd_version();
    $width = imagesx($src);
    $height = imagesy($src);
    if($angle == 90 || $angle == 270){
        $dst = $gd['create']($height,$width);
    } else{
        $dst = $gd['create']($width,$height);
    };
    for($y=0;$y<$height;$y++){
        for($x=0;$x<$width;$x++){
            switch($angle){
                case 90:
                    imagecopy($dst, $src, $height-$y-1, $x, $x, $y, 1, 1);
                    break;
                case 180:
                    imagecopy($dst, $src, $x, $y, $width-$x-1, $height-$y-1, 1, 1);
                    break;
                case 270:
                    imagecopy($dst, $src, $y, $width-$x-1, $x, $y, 1, 1);
                    break;
                default:
                    imagecopy($dst, $src, $x, $y, $x, $y, 1, 1);
            };
        };
    };
    imagedestroy($src);
    return($dst);
}
/**
 * Check if value is precent
 * By ZiQ
 */
function ziqIsPercent($x) {
    if (is_numeric($x)) {
        $tmp = intval($x);
        if ($tmp >= 10 && $tmp <= 100) {
            return true;
        };
    };
    return false;
}
function glx_image_rotate() {
    global $path_to_site;
    $rotate_value = ps("rotateValue") ? ps("rotateValue") : 0;
    $image_id = ps("id") ? ps("id") : 0;
    $source = IMPATH.$image_id.'.jpg';
    // get the right degree
    $degrees = 0;
    switch ($rotate_value) {
        case "180":
            $degrees = 180;
            break;
        case "90CW":
            $degrees = 270;
            break;
        case "90CCW":
            $degrees = 90;
            break;
    };
    // rotate image
    $im = imagecreatefromjpeg($source);
    if (function_exists('imagerotate')) {
        $im = imagerotate($im, $degrees, 0);
    } else {
        $im = glx_old_image_rotate($im, $degrees);
    };
    imagejpeg($im, $source, 95);
    imagedestroy($im);
    // get the size from the new image, and update database
    $size = getimagesize($source);
    safe_update('txp_image', "w='".$size[0]."',h='".$size[1]."'", "id='$image_id'");
    // send user to the image edit view
    header("Location: index.php?event=image&step=image_edit&id=".$image_id);
}
function glx_image_resize() {
    global $path_to_site;
    $do_resize_large = ps("doResizeLarge") ? ps("doResizeLarge") : 0;
    $do_resize_thumb = ps("doResizeThumb") ? ps("doResizeThumb") : 1;
    $square_image = ps("square") ? ps("square") : 0;
    // check for saved values
    $largeValue = cs("glx_image_large") ? cs("glx_image_large") : 500;
    $thumbValue = cs("glx_image_thumb") ? cs("glx_image_thumb") : 100;
    $largest_side_large = ps("largeSize") ? ps("largeSize") : $largeValue;
    $largest_side_thumb = ps("thumbSize") ? ps("thumbSize") : $thumbValue;
    $side_thumb = ps("thumbValue") ? ps("thumbValue") : 'longest';
    $image_id = ps("id") ? ps("id") : mysql_insert_id();
    $quality_thumb = ziqIsPercent(ps("thumbQua")) ? intval(ps("thumbQua")) : 90;
    $quality_large = ziqIsPercent(ps("largeQua")) ? intval(ps("largeQua")) : 80;
    // Save values to some cookies
    setcookie('glx_image_large',$largest_side_large,time()+3600*24*365);
    setcookie('glx_image_thumb',$largest_side_thumb,time()+3600*24*365);
    setcookie('glx_image_resize_large',$do_resize_large,time()+3600*24*365);
    setcookie('glx_image_resize_thumb',$do_resize_thumb,time()+3600*24*365);
    setcookie('glx_image_square',$square_image,time()+3600*24*365);
    $source = IMPATH.$image_id.'.jpg';
    if (file_exists($source) && ($do_resize_thumb == 1 || $do_resize_large == 1)) {
        // check current GD version
        $gd = glx_get_gd_version();
        $size = getimagesize($source);
        $x = $size[0];
        $y = $size[1];
        if ($side_thumb == 'longest'){
            if ($x > $y) {
                $max = $x;
                $min = $y;
            } else {
                $max = $y;
                $min = $x;
            };
        } elseif ($side_thumb == 'height'){
            $max = $y;
            $min = $x;
        } else {
            $max = $x;
            $min = $y;
        };
        if ($do_resize_thumb == 1) {
            // thumb
            $rate_thumb = $max / $largest_side_thumb;
            $final_x_thumb = $x / $rate_thumb;
            $final_y_thumb = $y / $rate_thumb;
            // create thumb
            if ($square_image == 1) {
                $resize_thumb = $gd['create']($largest_side_thumb, $largest_side_thumb);
                $im_thumb = imagecreatefromjpeg($source);
                if (METHOD == 2){
                    if($x > $y) {
                        $x0 = ($x - $y) / 2;
                        $x1 = $y;
                        $y0 = 0;
                        $y1 = $y;
                    } else {
                        $x0 = 0;
                        $x1 = $x;
                        $y0 = ($y - $x) / 2;
                        $y1 = $x;
                    };
                    $gd['copy']($resize_thumb, $im_thumb, 0, 0,$x0,$y0, $largest_side_thumb, $largest_side_thumb, $x1, $y1);
                } else {
                    $gd['copy']($resize_thumb, $im_thumb, 0, 0, 0, 0, $largest_side_thumb, $largest_side_thumb, $largest_side_thumb * 1.5, $largest_side_thumb * 1.5);
                };
                $source_thumb = IMPATH.$image_id.'t.jpg';
                imagejpeg($resize_thumb, $source_thumb, $quality_thumb);
                imagedestroy($resize_thumb);
            } else {
                $resize_thumb = $gd['create']($final_x_thumb, $final_y_thumb);
                $im_thumb = imagecreatefromjpeg($source);
                $gd['copy']($resize_thumb, $im_thumb, 0, 0, 0, 0, $final_x_thumb, $final_y_thumb, $x, $y);
                $source_thumb = IMPATH.$image_id.'t.jpg';
                imagejpeg($resize_thumb, $source_thumb, $quality_thumb);
                imagedestroy($resize_thumb);
            };
            $thumb = true;
            safe_update('txp_image', "thumbnail='$thumb'", "id='$image_id'");
        };
        if ($do_resize_large == 1) {
            // large
            $rate_large = $max / $largest_side_large;
            $final_x_large = $x / $rate_large;
            $final_y_large = $y / $rate_large;
            // create large
            if ($x > $final_x_large) {
                $resize_large = $gd['create']($final_x_large, $final_y_large);
                $im_large = imagecreatefromjpeg($source);
                $gd['copy']($resize_large, $im_large, 0, 0, 0, 0, $final_x_large, $final_y_large, $x, $y);
                imagejpeg($resize_large, $source, $quality_large);
                imagedestroy($resize_large);
            };
            // get size from large
            $size = getimagesize($source);
            safe_update('txp_image', "w='".$size[0]."',h='".$size[1]."'", "id='$image_id'");
        };
        // send user to the image edit view
        header("Location: index.php?event=image&step=image_edit&id=".$image_id);
    };
}
function glx_image_opts($event, $step) {
    echo<<<EOF
<script language="JavaScript" type="text/javascript">
<!--
window.onload = function() {
	// resize image on upload?
	var inputDoResizeLarge = document.createElement('input');
	inputDoResizeLarge.setAttribute('name', 'doResizeLarge');
	inputDoResizeLarge.setAttribute('id', 'doResizeLarge');
	inputDoResizeLarge.setAttribute('type', 'checkbox');
	inputDoResizeLarge.setAttribute('value', '1');
	inputDoResizeLarge.checked = false;
	var largeValue = getCookie('glx_image_large') ? ', stored value '+getCookie('glx_image_large')+'px' : ', stored value 500px';
	var labelDoResizeLarge = createLabel('doResizeLarge', 'Resize large image'+largeValue, 'inline');
	var pDoResizeLarge = document.createElement('p');
	pDoResizeLarge.appendChild(inputDoResizeLarge);
	pDoResizeLarge.appendChild(labelDoResizeLarge);
	// get the upload form element, the third form on the page
	var formUpload = document.getElementsByTagName('form').item(2);
	formUpload.appendChild(pDoResizeLarge);
}
function createLabel(forElement, text, elementClass) {
	var labelElement = document.createElement('label');
	labelElement.setAttribute('for', forElement);
	labelElement.className = elementClass;
	var labelTextNode = document.createTextNode(text);
	labelElement.appendChild(labelTextNode);
	return labelElement;
}
function getCookie(name) {
	var dc = document.cookie;
	var prefix = name + "=";
	var begin = dc.indexOf("; " + prefix);
	if (begin == -1) {
		begin = dc.indexOf(prefix);
		if (begin != 0) return null;
	} else {
    	begin += 2;
    }
  	var end = document.cookie.indexOf(";", begin);
	if (end == -1) {
		end = dc.length;
	}
  	return unescape(dc.substring(begin + prefix.length, end));
}
-->
</script>
EOF;
}
function glx_image_edit_opts($event, $step) {
	$id = gps('id');
	global $img_dir;
	$rs = safe_row("*", "txp_image", "id='$id'");
	if ($rs) {
		extract($rs);
	} else {
	    return;
	};
    // check if glx_admin css is found, if not found create it
    $rs = safe_row("name", "txp_css", "name='glx_admin_image' limit 1");
    if (!$rs) {
        $css = "bGFiZWwuaW5saW5lIHsNCgltYXJnaW46IDVweDsJDQp9CQ0KDQpsYWJlbC5ibG9jayB7DQoJbWFyZ2luOiA1cHggNXB4IDAgMDsJDQoJZGlzcGxheTogYmxvY2s7DQp9DQoNCi5yZXNpemUgew0KCWZsb2F0OiBsZWZ0Ow0KfQ0KDQoucm90YXRlIHsNCglmbG9hdDogcmlnaHQ7DQp9DQoNCmhyIHsNCglib3JkZXItYm90dG9tOiAxcHggc29saWQgI0RERERERDsNCglib3JkZXItdG9wOiBub25lOw0KCWJvcmRlci1yaWdodDogbm9uZTsNCglib3JkZXItbGVmdDogbm9uZTsNCgloZWlnaHQ6IDFweDsNCgljbGVhcjogYm90aDsNCn0=";
        safe_insert("txp_css", "name='glx_admin_image', css='$css'");
    };
    echo<<<EOF
<script language="JavaScript" type="text/javascript">
<!--
window.onload = function() {
EOF;
    if (HIDETXP == 1){
        echo "
      document.getElementsByTagName('tr')[6].style.display = 'none';
      document.getElementsByTagName('tr')[7].style.display = 'none';";
    };
    echo "
	// add some style to this!!!!
	loadCSS('css.php?n=glx_admin_image');
	//alert(getCookie('glx_image_large') + \" and \" + getCookie('glx_image_thumb'));
	// checkbox resize large
	var inputDoResizeLarge = document.createElement('input');
	inputDoResizeLarge.setAttribute('name', 'doResizeLarge');
	inputDoResizeLarge.setAttribute('id', 'doResizeLarge');
	inputDoResizeLarge.setAttribute('type', 'checkbox');
	inputDoResizeLarge.setAttribute('value', '1');
	inputDoResizeLarge.checked = false;
	var labelDoResizeLarge = createLabel('doResizeLarge', 'Resize large image', 'inline');
	var pDoResizeLarge = document.createElement('p');
	pDoResizeLarge.appendChild(inputDoResizeLarge);
	pDoResizeLarge.appendChild(labelDoResizeLarge);
	// checkbox resize thumb
	var inputDoResizeThumb = document.createElement('input');
	inputDoResizeThumb.setAttribute('name', 'doResizeThumb');
	inputDoResizeThumb.setAttribute('id', 'doResizeThumb');
	inputDoResizeThumb.setAttribute('type', 'checkbox');
	inputDoResizeThumb.setAttribute('value', '1');
	inputDoResizeThumb.checked = true;
	var labelDoResizeThumb = createLabel('doResizeThumb', 'Create thumbnail', 'inline');
	var pDoResizeThumb = document.createElement('p');
	pDoResizeThumb.appendChild(inputDoResizeThumb);
	pDoResizeThumb.appendChild(labelDoResizeThumb);
	// checkBox sqareImage
	var inputSquare = document.createElement('input');
	inputSquare.setAttribute('name', 'square');
	inputSquare.setAttribute('id', 'square');
	inputSquare.setAttribute('type', 'checkbox');
	inputSquare.setAttribute('value', '1');
	inputSquare.checked = false;
	var labelSquare = createLabel('square', 'Square thumbnail', 'inline');
	var pSquare = document.createElement('p');
	pSquare.appendChild(inputSquare);
	pSquare.appendChild(labelSquare);
	// input thumbSize
	var thumbValue = (getCookie('glx_image_thumb')) ? getCookie('glx_image_thumb') : 100;
	var inputThumbSize = createInput('thumbSize', 'thumbSize', thumbValue);
	var labelThumbSize = createLabel('thumbSize', 'Thumbsize (px)', 'block');
	var pThumb = document.createElement('p');
	pThumb.appendChild(labelThumbSize);
	pThumb.appendChild(inputThumbSize);
	// radio button thumbsize-sideheight
	var inputRadioThumbHeight = document.createElement('input');
	inputRadioThumbHeight.setAttribute('name', 'thumbValue');
	inputRadioThumbHeight.setAttribute('id', 'radioThumb');
	inputRadioThumbHeight.setAttribute('type', 'radio');
	inputRadioThumbHeight.setAttribute('value', 'height');
	inputRadioThumbHeight.checked = false;
	var labelRadioThumbHeight = createLabel('radioThumb', 'height', 'inline');
	var pRadioThumbHeight = document.createElement('p');
	pRadioThumbHeight.appendChild(inputRadioThumbHeight);
	pRadioThumbHeight.appendChild(labelRadioThumbHeight);
	// radio button thumbsize-sidewidth
	var inputRadioThumbWidth = document.createElement('input');
	inputRadioThumbWidth.setAttribute('name', 'thumbValue');
	inputRadioThumbWidth.setAttribute('id', 'radioThumb');
	inputRadioThumbWidth.setAttribute('type', 'radio');
	inputRadioThumbWidth.setAttribute('value', 'width');
	inputRadioThumbWidth.checked = false;
	var labelRadioThumbWidth = createLabel('radioThumb', 'width', 'inline');
	var pRadioThumbWidth = document.createElement('p');
	pRadioThumbWidth.appendChild(inputRadioThumbWidth);
	pRadioThumbWidth.appendChild(labelRadioThumbWidth);
	// radio button thumbsize-sidelongest
	var inputRadioThumbLongest = document.createElement('input');
	inputRadioThumbLongest.setAttribute('name', 'thumbValue');
	inputRadioThumbLongest.setAttribute('id', 'radioThumb');
	inputRadioThumbLongest.setAttribute('type', 'radio');
	inputRadioThumbLongest.setAttribute('value', 'longest');
	inputRadioThumbLongest.checked = false;
	var labelRadioThumbLongest = createLabel('radioThumb', 'longest side', 'inline');
	var pRadioThumbLongest = document.createElement('p');
	pRadioThumbLongest.appendChild(inputRadioThumbLongest);
	pRadioThumbLongest.appendChild(labelRadioThumbLongest);
	// input largeSize
	var largeValue = (getCookie('glx_image_large')) ? getCookie('glx_image_large') : 500;
	var inputLargeSize = createInput('largeSize', 'largeSize', largeValue);
	var labelLargeSize = createLabel('largeSize', 'Largesize (px)', 'block');
	var pLarge = document.createElement('p');
	pLarge.appendChild(labelLargeSize);
	pLarge.appendChild(inputLargeSize);
	// input quality
	var inputQuaThumb = createInput('thumbQua', 'thumbQua', '90');
	var labelQuaThumb = createLabel('thumbQua', 'Quality Thumb (10-100)', 'block');
	var pQuaThumb = document.createElement('p');
	pQuaThumb.appendChild(labelQuaThumb);
	pQuaThumb.appendChild(inputQuaThumb);
	// input quality
	var inputQuaLarge = createInput('largeQua', 'largeQua', '80');
	var labelQuaLarge = createLabel('largeQua', 'Quality Large Image (10-100)', 'block');
	var pQuaLarge = document.createElement('p');
	pQuaLarge.appendChild(labelQuaLarge);
	pQuaLarge.appendChild(inputQuaLarge);
	// add hidden fields
	var inputHiddenAction = document.createElement('input');
	inputHiddenAction.setAttribute('name', 'action');
	inputHiddenAction.setAttribute('type', 'hidden');
	inputHiddenAction.setAttribute('value', 'resize');
	var inputHiddenStep = document.createElement('input');
	inputHiddenStep.setAttribute('name', 'step');
	inputHiddenStep.setAttribute('type', 'hidden');
	inputHiddenStep.setAttribute('value', 'image_edit');
	var inputHiddenId = document.createElement('input');
	inputHiddenId.setAttribute('name', 'id');
	inputHiddenId.setAttribute('type', 'hidden');
	inputHiddenId.setAttribute('value', document.getElementsByName('id').item(0).value);
	var inputHiddenEvent = document.createElement('input');
	inputHiddenEvent.setAttribute('name', 'event');
	inputHiddenEvent.setAttribute('type', 'hidden');
	inputHiddenEvent.setAttribute('value', 'image');
	var inputHiddenFs = document.createElement('input');
	inputHiddenFs.setAttribute('name', 'MAX_FILE_SIZE');
	inputHiddenFs.setAttribute('type', 'hidden');
	inputHiddenFs.setAttribute('value', document.getElementsByName('MAX_FILE_SIZE').item(0).value);
	//add submit
	var submit = document.createElement('input');
	submit.setAttribute('class', 'smallerbox');
	submit.setAttribute('type', 'submit');
	submit.setAttribute('value', 'Resize');
	submit.setAttribute('name', 'Mod');
	// add form
	var formResize = document.createElement('form');
	formResize.setAttribute('action', 'index.php');
	formResize.setAttribute('method', 'post');
	//append form
	formResize.appendChild(pLarge);
	formResize.appendChild(pThumb);
	formResize.appendChild(pRadioThumbWidth);
	formResize.appendChild(pRadioThumbHeight);
	formResize.appendChild(pRadioThumbLongest);
	// this two lines are commented for now, personally I think it is too cluttered with them there.
	//formResize.appendChild(pQuaLarge);
	//formResize.appendChild(pQuaThumb);
	formResize.appendChild(pDoResizeLarge);
	formResize.appendChild(pDoResizeThumb);
	formResize.appendChild(pSquare);
	formResize.appendChild(inputHiddenAction);
	formResize.appendChild(inputHiddenId);
	formResize.appendChild(inputHiddenFs);
	formResize.appendChild(inputHiddenEvent);
	formResize.appendChild(inputHiddenStep);
	formResize.appendChild(submit);
	// Rotate image
	var formRotate = document.createElement('form');
	formRotate.setAttribute('action', 'index.php');
	formRotate.setAttribute('method', 'post');
	// radio button rotate 180
	var inputRadio180 = document.createElement('input');
	inputRadio180.setAttribute('name', 'rotateValue');
	inputRadio180.setAttribute('id', 'radio180');
	inputRadio180.setAttribute('type', 'radio');
	inputRadio180.setAttribute('value', '180');
	inputRadio180.checked = false;
	var labelRadio180 = createLabel('radio180', '180', 'inline');
	var pRadio180 = document.createElement('p');
	pRadio180.appendChild(inputRadio180);
	pRadio180.appendChild(labelRadio180);
	// radio button rotate 90 CW
	var inputRadio90Cw = document.createElement('input');
	inputRadio90Cw.setAttribute('name', 'rotateValue');
	inputRadio90Cw.setAttribute('id', 'radio90Cw');
	inputRadio90Cw.setAttribute('type', 'radio');
	inputRadio90Cw.setAttribute('value', '90CW');
	inputRadio90Cw.checked = false;
	var labelRadio90Cw = createLabel('radio90Cw', '90 CW', 'inline');
	var pRadio90Cw = document.createElement('p');
	pRadio90Cw.appendChild(inputRadio90Cw);
	pRadio90Cw.appendChild(labelRadio90Cw);
	// radio button rotate 90 CCW
	var inputRadio90Ccw = document.createElement('input');
	inputRadio90Ccw.setAttribute('name', 'rotateValue');
	inputRadio90Ccw.setAttribute('id', 'radio90Ccw');
	inputRadio90Ccw.setAttribute('type', 'radio');
	inputRadio90Ccw.setAttribute('value', '90CCW');
	inputRadio90Ccw.checked = false;
	var labelRadio90Ccw = createLabel('radio90Ccw', '90 CCW', 'inline');
	var pRadio90Ccw = document.createElement('p');
	pRadio90Ccw.appendChild(inputRadio90Ccw);
	pRadio90Ccw.appendChild(labelRadio90Ccw);
	// some hidden fields
	var inputRotateHiddenAction = document.createElement('input');
	inputRotateHiddenAction.setAttribute('name', 'action');
	inputRotateHiddenAction.setAttribute('type', 'hidden');
	inputRotateHiddenAction.setAttribute('value', 'rotate');
	var inputRotateHiddenStep = document.createElement('input');
	inputRotateHiddenStep.setAttribute('name', 'step');
	inputRotateHiddenStep.setAttribute('type', 'hidden');
	inputRotateHiddenStep.setAttribute('value', 'image_edit');
	var inputRotateHiddenId = document.createElement('input');
	inputRotateHiddenId.setAttribute('name', 'id');
	inputRotateHiddenId.setAttribute('type', 'hidden');
	inputRotateHiddenId.setAttribute('value', document.getElementsByName('id').item(0).value);
	var inputRotateHiddenEvent = document.createElement('input');
	inputRotateHiddenEvent.setAttribute('name', 'event');
	inputRotateHiddenEvent.setAttribute('type', 'hidden');
	inputRotateHiddenEvent.setAttribute('value', 'image');
	var submitRotate = document.createElement('input');
	submitRotate.setAttribute('class', 'smallerbox');
	submitRotate.setAttribute('type', 'submit');
	submitRotate.setAttribute('value', 'Rotate');
	submitRotate.setAttribute('name', 'Mod');

	var imgThumbnail = document.createElement('img');
	imgThumbnail.setAttribute('class', 'thumbnail');
	imgThumbnail.setAttribute('src', '".hu.$img_dir."/".$id."t".$ext."');
	imgThumbnail.setAttribute('alt', 'thumbnail of the picture');
	imgThumbnail.setAttribute('style', 'display:block;margin:1em 0;');

	// append formRotate
	formRotate.appendChild(pRadio180);
	formRotate.appendChild(pRadio90Cw);
	formRotate.appendChild(pRadio90Ccw);
	formRotate.appendChild(inputRotateHiddenAction);
	formRotate.appendChild(inputRotateHiddenId);
	formRotate.appendChild(inputRotateHiddenEvent);
	formRotate.appendChild(inputRotateHiddenStep);
	formRotate.appendChild(submitRotate);
	formRotate.appendChild(imgThumbnail);
	// create a placeholders for resize and rotate
	var divResize = document.createElement('div');
	divResize.className = 'resize';
	divResize.appendChild(formResize);
	var divRotate = document.createElement('div');
	divRotate.className = 'rotate';
	divRotate.appendChild(formRotate);
	// since we are using floats on the two above, we need to clear...
	var hrClear = document.createElement('hr');
	hrClear.className = 'clear';
	// get the upload form element
	var formUpload = document.getElementsByTagName('form').item(1);
	formUpload.parentNode.insertBefore(divResize, formUpload);
	formUpload.parentNode.insertBefore(divRotate, formUpload);
	formUpload.parentNode.insertBefore(hrClear, formUpload);
}
function createInput(name, id, value) {
	var element = document.createElement('input');
	element.setAttribute('name', name);
	element.setAttribute('id', id);
	element.setAttribute('value', value);
	element.className = 'edit';
	return element;
}
function createLabel(forElement, text, elementClass) {
	var labelElement = document.createElement('label');
	labelElement.setAttribute('for', forElement);
	labelElement.className = elementClass;
	var labelTextNode = document.createTextNode(text);
	labelElement.appendChild(labelTextNode);
	return labelElement;
}
function loadCSS(fileName) {
	var head = document.getElementsByTagName('head').item(0);
	var styleElement = document.createElement('link');
	styleElement.setAttribute('href', fileName);
	styleElement.setAttribute('rel', 'stylesheet');
	styleElement.setAttribute('type', 'text/css');
	head.appendChild(styleElement);
}
/*
 * Cookie stuff
 *
 * http://www.webreference.com/js/column8/index.html
 *
 */
function setCookie(name, value, expires, path, domain, secure) {
	var curCookie = name + '=' + escape(value) +
    	((expires) ? '; expires=' + expires.toLocaleString() : '') +
    	((path) ? '; path=' + path : '') +
    	((domain) ? '; domain=' + domain : '') +
    	((secure) ? '; secure' : '');
	document.cookie = curCookie;
}
function getCookie(name) {
	var dc = document.cookie;
	var prefix = name + '=';
	var begin = dc.indexOf('; ' + prefix);
	if (begin == -1) {
		begin = dc.indexOf(prefix);
		if (begin != 0) return null;
	} else {
    	begin += 2;
    };
  	var end = document.cookie.indexOf(';', begin);
	if (end == -1) {
		end = dc.length;
	};
  	return unescape(dc.substring(begin + prefix.length, end));
}
function deleteCookie(name, path, domain) {
	if (getCookie(name)) {
		document.cookie = name + '=' +
    		((path) ? '; path=' + path : '') +
    		((domain) ? '; domain=' + domain : '') +
    		'; expires=Thu, 01-Jan-70 00:00:01 GMT';
	};
}
-->
</script>
";
}
";s:4:"type";s:1:"1";s:5:"order";s:1:"5";s:3:"md5";s:32:"8df07700361467666130daa9083f5770";}

Last edited by graumeister (2006-08-23 01:16:51)


Samui? Samui! (about the life as farang in thailand)
David’s Neighbour

Offline

#2 2005-08-20 07:12:45

colak
Admin
From: Cyprus
Registered: 2004-11-20
Posts: 9,091
Website GitHub Mastodon Twitter

Re: [plugin] [ORPHAN] glx_admin_image_resize

hi graumeister,
firstly a big thanks for taking over johan’s wonderful plugins.
A request:)
Johan also wrote another great plugin the <a href=“http://johan.galaxen.net/logg/63/textpattern-plugin-glx_if”>glx_if</a>. Would it be very rude of me to ask if you could take over that one too?

Last edited by colak (2005-08-20 07:47:20)


Yiannis
——————————
NeMe | hblack.art | EMAP | A Sea change | Toolkit of Care
I do my best editing after I click on the submit button.

Offline

#3 2005-08-20 07:20:50

druzli
Member
From: Denmark / Iceland
Registered: 2004-06-28
Posts: 60
Website

Re: [plugin] [ORPHAN] glx_admin_image_resize

Nice of you to adopt his plugins, I really like and use alot glx_admin_image_resize. Will post here if I think of anything.


regards,

Agust

Offline

#4 2005-08-21 19:05:21

heikki74
Member
From: Finland
Registered: 2004-08-17
Posts: 100

Re: [plugin] [ORPHAN] glx_admin_image_resize

Hi graumeister, you still have one place to fix:

// get the upload form element, the second form on the page var formUpload = document.getElementsByTagName(‘form’).item(1);

to:

// get the upload form element, the third form on the page var formUpload = document.getElementsByTagName(‘form’).item(2);

Offline

#5 2005-08-22 12:17:21

graumeister
Plugin Author
From: Ban Bang Por, Samui, Thailand
Registered: 2005-01-16
Posts: 167
Website

Re: [plugin] [ORPHAN] glx_admin_image_resize

kiitos heikki, i have fixed it and put version 0.5.2b online at grauhirn.org.


Samui? Samui! (about the life as farang in thailand)
David’s Neighbour

Offline

#6 2005-08-22 13:05:13

druzli
Member
From: Denmark / Iceland
Registered: 2004-06-28
Posts: 60
Website

Re: [plugin] [ORPHAN] glx_admin_image_resize

The .txt file still says it´s # glx_admin_image v0.5.1b. and also the plugin in the list of plugins in textpattern admin. But seems to be the updated plugin working.

Just so u know :)

Thx for your work!


regards,

Agust

Offline

#7 2005-08-22 13:13:18

graumeister
Plugin Author
From: Ban Bang Por, Samui, Thailand
Registered: 2005-01-16
Posts: 167
Website

Re: [plugin] [ORPHAN] glx_admin_image_resize

druzli: takk fyrir. its fixed


Samui? Samui! (about the life as farang in thailand)
David’s Neighbour

Offline

#8 2005-08-23 07:47:10

druzli
Member
From: Denmark / Iceland
Registered: 2004-06-28
Posts: 60
Website

Re: [plugin] [ORPHAN] glx_admin_image_resize

Hehe nice icelandic !

Np, anytime


regards,

Agust

Offline

#9 2005-08-23 11:15:05

graumeister
Plugin Author
From: Ban Bang Por, Samui, Thailand
Registered: 2005-01-16
Posts: 167
Website

Re: [plugin] [ORPHAN] glx_admin_image_resize

@colak: sorry, I managed it to dont read your reply ;) is there anything which needs to be done with that plugin? because Johan will come back and I dont want take to much work of his shoulders ;)


Samui? Samui! (about the life as farang in thailand)
David’s Neighbour

Offline

#10 2005-08-25 23:48:20

starzabove
Member
Registered: 2004-04-13
Posts: 76

Re: [plugin] [ORPHAN] glx_admin_image_resize

Thanks so much graumeister! What a community we have here!
I had a client very much befuddled by how the last version was appearing in the top right of the image editing window in 4.0.


90+ Textpattern installs and still going…

Offline

#11 2005-09-20 19:23:52

andjules
Member
From: toronto
Registered: 2004-10-20
Posts: 44

Re: [plugin] [ORPHAN] glx_admin_image_resize

yes, I also saw the form postioning glitch. thanks for fixing.

I don’t know if it’s a bug, but i can’t seem to get a resized, square thumbnail – please help – when i click ‘square thumbnail’, no matter what other checkboxes are checked/off, the thumbnail ends up being square (good) but it’s not a ‘thumbnail’ – rather a full resolution crop of the top left of the original image

Offline

#12 2005-09-20 20:42:17

heikki74
Member
From: Finland
Registered: 2004-08-17
Posts: 100

Re: [plugin] [ORPHAN] glx_admin_image_resize

I don’t know if it’s a bug, but i can’t seem to get a resized, square thumbnail – please help – when i click ‘square thumbnail’, no matter what other checkboxes are checked/off, the thumbnail ends up being square (good) but it’s not a ‘thumbnail’ – rather a full resolution crop of the top left of the original image

That’s how the plugin is supposed to work. Txp has it’s own thumbnail generator which has square option too.

I did modify the plugin (0.5b) to do square cropping differently. If someone wants to take a look at the modified code I put it temporarily for download. Check out the “glx_image_resize” function and inside that the part about thumbs.

Last edited by heikki74 (2005-09-20 20:44:49)

Offline

Board footer

Powered by FluxBB