Go to main content

Textpattern CMS support forum

You are not logged in. Register | Login | Help

#1 2009-12-16 15:25:32

chume
Member
Registered: 2009-12-03
Posts: 27

[request] Popup image plugin

I need help getting Deans dca_pop and glx_image plugins. I have not been successfully getting them so far from all the available links.
Any clue?
Thank you in adavance.

Offline

#2 2009-12-16 16:55:52

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

Re: [request] Popup image plugin

here’s dca_pop

YToxMDp7czo0OiJuYW1lIjtzOjc6ImRjYV9wb3AiO3M6NjoiYXV0aG9yIjtzOjEwOiJEZWFuIEFsbGVuIjtzOjEwOiJhdXRob3JfdXJpIjtzOjIyOiJodHRwOi8vdGV4dHBhdHRlcm4uY29tIjtzOjc6InZlcnNpb24iO3M6MzoiMC4xIjtzOjExOiJkZXNjcmlwdGlvbiI7czo2MDoiQ3JlYXRlcyBzaXplZCBwb3B1cCB3aW5kb3dzIGZvciBpbWFnZXMgc3RvcmVkIGluIFRleHRwYXR0ZXJuIjtzOjQ6ImhlbHAiO3M6MzYxOiI8cD5XaWxsIGNyZWF0ZSBhIGxpbmsgdG8gYSBzaXplZCBwb3B1cCB3aW5kb3cgdG8gZGlzcGxheSBhbiBpbWFnZS4gVGhlIGltYWdlIG11c3QgaGF2ZSBiZWVuIHVwbG9hZGVkIHZpYSB0aGUgVGV4dHBhdHRlcm4gaW1hZ2UgdGFiPC9wPgoJPHA+WW91IGNhbiB1c2UgZWl0aGVyIHRoZSBuYW1lIG9mIHRoZSBpbWFnZSwgb3IgaXRzIGlkPC9wPgoJPHA+VXNhZ2U6Cgk8YnIgLz4gJiM2MDt0eHA6ZGNhX3BvcCBpZD0iMTkiJiM2MjthIHBpY3R1cmUmIzYwOy90eHA6ZGNhX3BvcCYjNjI7Cgk8YnIgLz4gJiM2MDt0eHA6ZGNhX3BvcCBuYW1lPSJodWdvLmpwZyImIzYyO2Fub3RoZXIgcGljdHVyZSYjNjA7L3R4cDpkY2FfcG9wJiM2Mjs8L3A+IjtzOjQ6ImNvZGUiO3M6NTk2OiIKCglmdW5jdGlvbiBkY2FfcG9wKCRhdHRzLCR0aGluZykgCgl7CgkJZ2xvYmFsICRwYXRoX2Zyb21fcm9vdCwkaW1nX2RpcjsKCQlpZiAoaXNfYXJyYXkoJGF0dHMpKSBleHRyYWN0KCRhdHRzKTsKCQkJCQoJCWlmICghZW1wdHkoJG5hbWUpKSB7CgkJCSRnZXQgPSBzYWZlX3JvdygiKiIsInR4cF9pbWFnZSIsIm5hbWU9JyRuYW1lJyIpOwoJCX0gZWxzZWlmICghZW1wdHkoJGlkKSkgewoJCQkkZ2V0ID0gc2FmZV9yb3coIioiLCJ0eHBfaW1hZ2UiLCJpZD0nJGlkJyIpOwoJCX0gZWxzZSByZXR1cm47CgkKCQlpZiAoJGdldCkgeyBleHRyYWN0KCRnZXQpOyB9IGVsc2UgeyByZXR1cm47IH07CgkJcmV0dXJuIGpvaW4oIiIsYXJyYXkoCgkJCSIgPGEgdGFyZ2V0PVwiX2JsYW5rXCIgaHJlZj1cIiIuJHBhdGhfZnJvbV9yb290LiRpbWdfZGlyLiIvIi4kaWQuJGV4dC4iXCIiLAoJCQkiIG9uY2xpY2s9XCIiLCJ3aW5kb3cub3Blbih0aGlzLmhyZWYsICdwb3B1cHdpbmRvdycsICd3aWR0aD0iLCR3LCIsaGVpZ2h0PSIsJGgsCgkJCSIsc2Nyb2xsYmFycyxyZXNpemFibGUnKTsgcmV0dXJuIGZhbHNlO1wiPiIsCgkJCSR0aGluZywiPC9hPiIKCQkpKTsKCX0KCiI7czo0OiJ0eXBlIjtzOjE6IjAiO3M6NToib3JkZXIiO3M6MToiNSI7czozOiJtZDUiO3M6MzI6IjQyY2IyYzk0NGVhY2JkNzQ0MTJkNThhNGU0YTI3MDU4Ijt9

and glx_admin_image

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:5:"4.0.1";s:11:"description";s:45:"advanced image editing and thumbnail creation";s:4:"help";s:4057:"<p><h1>glx_admin_image_resize</h1><br />
<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></p>

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

	<p><p>Default stylesheet</p></p>

<pre>
<code>
label.inline {
margin: 5px;
}

	<p>label.block {
margin: 5px 5px 0 0;
display: block;
}</p>

	<p>.resize {
float: left;
}</p>

	<p>.rotate {
float: right;
}</p>

	<p>hr {
border-bottom: 1px solid #DDDDDD;
border-top: none;
border-right: none;
border-left: none;
height: 1px;
clear: both;
}
</code>
</pre></p>

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

	<p><h2>Changelog</h2></p>

    <p><strong>4.0.1</strong> 2005-10-14</p>

    <ul class="changelog">
    <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><strong>0.5.1b/0.5.2b</strong> 2005-08-20</p>

    <ul class="changelog">
    <li>Fixed some small bug introduced with Textpattern 4.0 (gho)</li>
    </ul>

    <p><strong>0.5b</strong> 2005-04-04</p>

    <ul class="changelog">
    <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><strong>0.4b</strong> 2005-03-30<br />
<br />
ZiQ added the following</p>

    <ul class="changelog">
    <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 class="changelog">
    <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><strong>0.3b</strong> 2005-03-27</p>
    <ul class="changelog">
    <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><strong>0.2b</strong> 2005-03-25<br />
<br />
It still uses the same technic to manipulate the image but it is now possible to (in the image edit page)</p>

    <ul class="changelog">
    <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><strong>0.1b</strong> 2005-03-25</p>
    <ul class="changelog">
    <li>First release</li>
    </ul>";s:4:"code";s:21751:"
// 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;
    $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 ($x > $y) {
            $max = $x;
            $min = $y;
        } else {
            $max = $y;
            $min = $x;
        };
        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) {
    // 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() {

	// 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);

	// 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);
	// 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');

	// 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);

	// 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>
EOF;
}
";s:4:"type";s:1:"1";s:5:"order";s:1:"5";s:3:"md5";s:32:"86f2e5f0a51cf4462c4eb9c1663c9e2c";}

Edit: as the above are very old plugins (Dean’s is the first one ever made), maybe you can tell us what you are trying to achieve as there may be better solutions.

Last edited by colak (2009-12-16 17:24:23)


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 2009-12-16 23:25:29

chume
Member
Registered: 2009-12-03
Posts: 27

Re: [request] Popup image plugin

Thank you much colak.
As per your suggestion, I just need to pop-up about 3 pictures in an article with a text link.
I most certainly appreciate any info for a new plug-in that can handle such a task.
Thanks you.

chume

Offline

#4 2009-12-17 02:43:57

hakjoon
Member
From: Arlington, VA
Registered: 2004-07-29
Posts: 1,634
Website

Re: [request] Popup image plugin

If you are attaching them to the article as article images you can use hak_article_image


Shoving is the answer – pusher robot

Offline

#5 2009-12-17 19:44:41

chume
Member
Registered: 2009-12-03
Posts: 27

Re: [request] Popup image plugin

Thank you so much hakjoon.
The dca_pop plugin worked like a charm.

chume

Offline

Board footer

Powered by FluxBB