New upload functionality.

git-svn-id: http://svn.automattic.com/wordpress/trunk@831 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
saxmatt 2004-02-05 14:28:02 +00:00
parent a157baa95c
commit a87acdf1e2
7 changed files with 286 additions and 241 deletions

View File

@ -47,4 +47,91 @@ function wp_dropdown_cats($currentcat, $currentparent = 0, $parent = 0, $level =
} }
} }
function wp_create_thumbnail($file, $max_side, $effect = '') {
// 1 = GIF, 2 = JPEG, 3 = PNG
if(file_exists($file)) {
$type = getimagesize($file);
// if the associated function doesn't exist - then it's not
// handle. duh. i hope.
if(!function_exists('imagegif') && $type[2] == 1) {
$error = 'Filetype not supported. Thumbnail not created.';
}elseif(!function_exists('imagejpeg') && $type[2] == 2) {
$error = 'Filetype not supported. Thumbnail not created.';
}elseif(!function_exists('imagepng') && $type[2] == 3) {
$error = 'Filetype not supported. Thumbnail not created.';
} else {
// create the initial copy from the original file
if($type[2] == 1) {
$image = imagecreatefromgif($file);
} elseif($type[2] == 2) {
$image = imagecreatefromjpeg($file);
} elseif($type[2] == 3) {
$image = imagecreatefrompng($file);
}
if (function_exists('imageantialias'))
imageantialias($image, TRUE);
$image_attr = getimagesize($file);
// figure out the longest side
if($image_attr[0] > $image_attr[1]) {
$image_width = $image_attr[0];
$image_height = $image_attr[1];
$image_new_width = $max_side;
$image_ratio = $image_width/$image_new_width;
$image_new_height = $image_height/$image_ratio;
//width is > height
} else {
$image_width = $image_attr[0];
$image_height = $image_attr[1];
$image_new_height = $max_side;
$image_ratio = $image_height/$image_new_height;
$image_new_width = $image_width/$image_ratio;
//height > width
}
$thumbnail = imagecreatetruecolor($image_new_width, $image_new_height);
@imagecopyresized($thumbnail, $image, 0, 0, 0, 0, $image_new_width, $image_new_height, $image_attr[0], $image_attr[1]);
// move the thumbnail to it's final destination
$path = explode('/', $file);
$thumbpath = substr($file, 0, strrpos($file, '/')) . '/thumb-' . $path[count($path)-1];
if($type[2] == 1) {
if(!imagegif($thumbnail, $thumbpath)) {
$error = "Thumbnail path invalid";
}
} elseif($type[2] == 2) {
if(!imagejpeg($thumbnail, $thumbpath)) {
$error = "Thumbnail path invalid";
}
} elseif($type[2] == 3) {
if(!imagepng($thumbnail, $thumbpath)) {
$error = "Thumbnail path invalid";
}
}
}
}
if(!empty($error))
{
return $error;
}
else
{
return 1;
}
}
?> ?>

View File

@ -78,14 +78,6 @@ setTimeout("redirect();", 600);
<script language="javascript" type="text/javascript"> <script language="javascript" type="text/javascript">
//<![CDATA[ //<![CDATA[
function profile(userID) {
window.open ("profile.php?action=viewprofile&user="+userID, "Profile", "width=500, height=450, location=0, menubar=0, resizable=0, scrollbars=1, status=1, titlebar=0, toolbar=0, screenX=60, left=60, screenY=60, top=60");
}
function launchupload() {
window.open ("upload.php", "wpupload", "width=380,height=360,location=0,menubar=0,resizable=1,scrollbars=yes,status=1,toolbar=0");
}
function helpWindow(url) { function helpWindow(url) {
window.open(url, "Help", "width=640, height=450, location=0, menubar=0, resizable=0, scrollbars=1, status=1, titlebar=0, toolbar=0, screenX=60, left=60, screenY=60, top=60"); window.open(url, "Help", "width=640, height=450, location=0, menubar=0, resizable=0, scrollbars=1, status=1, titlebar=0, toolbar=0, screenX=60, left=60, screenY=60, top=60");
} }
@ -145,10 +137,13 @@ window.onload = blurry;
</script> </script>
</head> </head>
<body> <body>
<h1 id="wphead"><a href="http://wordpress.org" rel="external" title="Visit WordPress.org">WordPress</a></h1>
<?php <?php
if ($profile==0) { if ($profile==0) {
include('menu.php'); include('menu.php');
} }
} ?>
<h2><?php echo $title; ?></h2>
<?php
} // endif not standalone
?> ?>

View File

@ -153,14 +153,6 @@ if ($action != 'editcomment') {
?> ?>
<?php <?php
if ($action != 'editcomment') {
if ( ($use_fileupload) && ($user_level >= $fileupload_minlevel)
&& (in_array($user_login, $allowed_users) || (trim($fileupload_allowedusers)=="")) ) { ?>
<p><input type="button" value="Upload a file or image" onclick="launchupload();" tabindex="10" /></p>
<?php }
}
// if the level is 5+, allow user to edit the timestamp - not on 'new post' screen though // if the level is 5+, allow user to edit the timestamp - not on 'new post' screen though
// if (($user_level > 4) && ($action != "post")) // if (($user_level > 4) && ($action != "post"))

View File

@ -119,11 +119,7 @@ edCanvas = document.getElementById('content');
} ?> } ?>
<input name="referredby" type="hidden" id="referredby" value="<?php echo $HTTP_SERVER_VARS['HTTP_REFERER']; ?>" /> <input name="referredby" type="hidden" id="referredby" value="<?php echo $HTTP_SERVER_VARS['HTTP_REFERER']; ?>" />
</p> </p>
<?php
if ( ($use_fileupload) && ($user_level >= $fileupload_minlevel)
&& (in_array($user_login, $allowed_users) || (trim($fileupload_allowedusers)=="")) ) { ?>
<p><input type="button" value="Upload a file or image" onclick="launchupload();" tabindex="10" /></p>
<?php } ?>
</div> </div>
</form> </form>

View File

@ -1,4 +1,3 @@
<h1 id="wphead"><a href="http://wordpress.org" rel="external">WordPress</a></h1>
<ul id="adminmenu"> <ul id="adminmenu">
<?php <?php
@ -13,13 +12,15 @@ foreach ($menu as $item) {
// 0 = user level, 1 = file, 2 = name // 0 = user level, 1 = file, 2 = name
$self = str_replace('/wp-admin/', '', $PHP_SELF); $self = str_replace('/wp-admin/', '', $PHP_SELF);
if ((substr($self, -20) == substr($item[1], -20)) || ($parent_file && ($item[1] == $parent_file))) $class = ' class="current"'; if ((substr($self, -20) == substr($item[1], -20)) || ($parent_file && ($item[1] == $parent_file))) $class = ' class="current"';
if ($user_level >= $item[0]) echo "\n\t<li><a href='{$item[1]}'$class>{$item[2]}</a></li>"; if ($user_level >= $item[0]) {
if (('upload.php' == $item[1] && $use_fileupload && ($user_level >= $fileupload_minlevel)
&& (in_array($user_login, explode(' ', $allowed_users)) || (trim($fileupload_allowedusers)==""))) || 'upload.php' != $item[1])
echo "\n\t<li><a href='{$item[1]}'$class>{$item[2]}</a></li>";
}
} }
} }
?> ?>
<li><a href="<?php echo "$siteurl/$blogfilename"; ?>">View site</a></li> <li><a href="<?php echo "$siteurl/$blogfilename"; ?>" title="View your site">View site</a></li>
<li class="last"><a href="<?php echo $siteurl ?>/wp-login.php?action=logout">Logout (<?php echo stripslashes($user_nickname) ?>)</a></li> <li class="last"><a href="<?php echo $siteurl ?>/wp-login.php?action=logout" title="Logout of this account">Logout (<?php echo stripslashes($user_nickname) ?>)</a></li>
</ul> </ul>
<h2><?php echo $title; ?></h2>

View File

@ -5,6 +5,7 @@
3 users.php Users 3 users.php Users
4 options.php Options 4 options.php Options
4 templates.php Templates 4 templates.php Templates
5 upload.php Upload
0 profile.php My Profile 0 profile.php My Profile
*** ***
(Everything after the '***' is a comment.) (Everything after the '***' is a comment.)

View File

@ -1,254 +1,227 @@
<?php <?php
/* WP File Upload - original hack by shockingbird.com */ $title = 'Upload Image or File';
$standalone="1"; require_once('admin-header.php');
require_once("./admin-header.php");
if ($user_level == 0) //Checks to see if user has logged in if ($user_level == 0) //Checks to see if user has logged in
die ("Cheatin' uh ?"); die ("Cheatin' uh ?");
if (!$use_fileupload) //Checks if file upload is enabled in the config if (!$use_fileupload) //Checks if file upload is enabled in the config
die ("The admin disabled this function"); die ("The admin disabled this function");
$allowed_types = explode(" ", trim($fileupload_allowedtypes)); $allowed_types = explode(' ', trim($fileupload_allowedtypes));
?><html> if ($HTTP_POST_VARS['submit']) {
<head> $action = 'upload';
<title>WordPress &raquo; Upload images/files</title> } else {
<style type="text/css"> $action = '';
<!--
body {
margin: 30px;
} }
if (!is_writable($fileupload_realpath))
$action = 'not-writable';
?>
<div class="wrap">
<?php <?php
if (!$is_NS4) { switch ($action) {
case 'not-writable':
?> ?>
textarea,input,select { <p>It doesn't look like you can use the file upload feature at this time because the directory you have specified (<code><?php echo $fileupload_realpath; ?></code>) doesn't appear to be writable by WordPress. Check the permissions on the directory and for typos.</p>
background-color: white;
border-width: 1px;
border-color: #cccccc;
border-style: solid;
padding: 2px;
margin: 1px;
}
<?php if (!$is_gecko) { ?>
.checkbox {
border-width: 0px;
border-color: transparent;
border-style: solid;
padding: 0px;
margin: 0px;
}
.uploadform {
background-color: white;
<?php if ($is_winIE) { ?>
filter: alpha(opacity:100);
<?php } ?>
border-width: 1px;
border-color: #333333;
border-style: solid;
padding: 2px;
margin: 1px;
width: 265px;
height: 24px;
}
<?php } ?>
<?php <?php
} break;
case '':
foreach ($allowed_types as $type) {
$type_tags[] = "<code>$type</code>";
}
$i = implode(', ', $type_tags);
?> ?>
--> <p>You can upload files with the extension <?php echo $i ?> as long as they are no larger than <?php echo $fileupload_maxk; ?> <abbr title="Kilobytes">KB</abbr>. If you&#8217;re an admin your can configure these values under <a href="options.php">options</a>.</p>
</style> <form action="upload.php" method="post" enctype="multipart/form-data">
<script type="text/javascript"> <p>
<!-- // idocs.com's popup tutorial rules ! <label for="img1">File:</label>
function targetopener(blah, closeme, closeonly) { <br />
if (! (window.focus && window.opener))return true; <input type="hidden" name="MAX_FILE_SIZE" value="<?php echo $fileupload_maxk * 1024 ?>" />
window.opener.focus(); <input type="file" name="img1" id="img1" size="35" class="uploadform" /></p>
if (! closeonly)window.opener.document.post.content.value += blah; <p>
if (closeme)window.close(); <label for="imgdesc">Description:</label><br />
return false; <input type="text" name="imgdesc" id="imgdesc" size="30" class="uploadform" />
} </p>
//-->
</script> <p>Create a thumbnail?</p>
</head> <p>
<body> <label for="thumbsize_no">
<input type="radio" name="thumbsize" value="none" checked="checked" id="thumbsize_no" />
<table align="center" width="100%" height="100%" cellpadding="15" cellspacing="0" border="1" style="border-width: 1px; border-color: #cccccc;"> No thanks</label>
<tbody> <br />
<tr> <label for="thumbsize_small">
<td valign="top" style="background-color: transparent; <?php if ($is_gecko || $is_macIE) { ?>background-image: url('../wp-images/bgbookmarklet3.gif');<?php } elseif ($is_winIE) { ?>background-color: #cccccc; filter: alpha(opacity:60);<?php } ?>;"> <input type="radio" name="thumbsize" value="small" id="thumbsize_small" />
<?php Small (200px largest side)</label>
<br />
if (!$HTTP_POST_VARS["submit"]) { <label for="thumbsize_large">
$i = implode(", ", $allowed_types); <input type="radio" name="thumbsize" value="large" id="thumbsize_large" />
?> Large (400px largest side)</label>
<p><strong>File upload</strong></p> <br />
<p>You can upload files of type:<br /><em><?php echo $i ?></em></p> <label for="thumbsize_custom">
<p>The maximum size of the file should be:<br /><em><?php echo $fileupload_maxk ?> KB</em></p> <input type="radio" name="thumbsize" value="custom" id="thumbsize_custom" />
<form action="upload.php" method="post" enctype="multipart/form-data"> Custom size</label>
<input type="hidden" name="MAX_FILE_SIZE" value="<?php echo $fileupload_maxk*1024 ?>" /> :
<input type="file" name="img1" size="30" class="uploadform" /> <input type="text" name="imgthumbsizecustom" size="4" />
<br /><br /> px (largest side) </p>
Description:<br /> <p><input type="submit" name="submit" value="Upload File" /></p>
<input type="text" name="imgdesc" size="30" class="uploadform" /> </form>
<br /><br /> </div><?php
<input type="submit" name="submit" value="upload !" class="search" /> break;
</form> case 'upload':
</td>
</tr>
</tbody>
</table>
</body>
</html><?php die();
}
?> ?>
<?php //Makes sure they choose a file
<?php //Makes sure they choose a file
//print_r($HTTP_POST_FILES); //print_r($HTTP_POST_FILES);
//die(); //die();
if (!empty($HTTP_POST_VARS)) { //$img1_name != "") {
$imgalt = (isset($HTTP_POST_VARS['imgalt'])) ? $HTTP_POST_VARS['imgalt'] : $imgalt; $imgalt = (isset($HTTP_POST_VARS['imgalt'])) ? $HTTP_POST_VARS['imgalt'] : $imgalt;
$img1_name = (strlen($imgalt)) ? $HTTP_POST_VARS['imgalt'] : $HTTP_POST_FILES['img1']['name']; $img1_name = (strlen($imgalt)) ? $HTTP_POST_VARS['imgalt'] : $HTTP_POST_FILES['img1']['name'];
$img1_type = (strlen($imgalt)) ? $HTTP_POST_VARS['img1_type'] : $HTTP_POST_FILES['img1']['type']; $img1_type = (strlen($imgalt)) ? $HTTP_POST_VARS['img1_type'] : $HTTP_POST_FILES['img1']['type'];
$imgdesc = str_replace('"', '&amp;quot;', $HTTP_POST_VARS['imgdesc']); $imgdesc = str_replace('"', '&amp;quot;', $HTTP_POST_VARS['imgdesc']);
$imgtype = explode(".",$img1_name); $imgtype = explode(".",$img1_name);
$imgtype = $imgtype[count($imgtype)-1]; $imgtype = $imgtype[count($imgtype)-1];
if (in_array($imgtype, $allowed_types) == false) { if (in_array($imgtype, $allowed_types) == false) {
die("File $img1_name of type $imgtype is not allowed."); die("File $img1_name of type $imgtype is not allowed.");
} }
if (strlen($imgalt)) { if (strlen($imgalt)) {
$pathtofile = $fileupload_realpath."/".$imgalt; $pathtofile = $fileupload_realpath."/".$imgalt;
$img1 = $HTTP_POST_VARS['img1']; $img1 = $HTTP_POST_VARS['img1'];
} else { } else {
$pathtofile = $fileupload_realpath."/".$img1_name; $pathtofile = $fileupload_realpath."/".$img1_name;
$img1 = $HTTP_POST_FILES['img1']['tmp_name']; $img1 = $HTTP_POST_FILES['img1']['tmp_name'];
} }
// makes sure not to upload duplicates, rename duplicates // makes sure not to upload duplicates, rename duplicates
$i = 1; $i = 1;
$pathtofile2 = $pathtofile; $pathtofile2 = $pathtofile;
$tmppathtofile = $pathtofile2; $tmppathtofile = $pathtofile2;
$img2_name = $img1_name; $img2_name = $img1_name;
while (file_exists($pathtofile2)) { while (file_exists($pathtofile2)) {
$pos = strpos($tmppathtofile, '.'.trim($imgtype)); $pos = strpos($tmppathtofile, '.'.trim($imgtype));
$pathtofile_start = substr($tmppathtofile, 0, $pos); $pathtofile_start = substr($tmppathtofile, 0, $pos);
$pathtofile2 = $pathtofile_start.'_'.zeroise($i++, 2).'.'.trim($imgtype); $pathtofile2 = $pathtofile_start.'_'.zeroise($i++, 2).'.'.trim($imgtype);
$img2_name = explode('/', $pathtofile2); $img2_name = explode('/', $pathtofile2);
$img2_name = $img2_name[count($img2_name)-1]; $img2_name = $img2_name[count($img2_name)-1];
} }
if (file_exists($pathtofile) && !strlen($imgalt)) { if (file_exists($pathtofile) && !strlen($imgalt)) {
$i = explode(" ",$fileupload_allowedtypes); $i = explode(" ",$fileupload_allowedtypes);
$i = implode(", ",array_slice($i, 1, count($i)-2)); $i = implode(", ",array_slice($i, 1, count($i)-2));
$moved = move_uploaded_file($img1, $pathtofile2); $moved = move_uploaded_file($img1, $pathtofile2);
// if move_uploaded_file() fails, try copy() // if move_uploaded_file() fails, try copy()
if (!$moved) { if (!$moved) {
$moved = copy($img1, $pathtofile2); $moved = copy($img1, $pathtofile2);
} }
if (!$moved) { if (!$moved) {
die("Couldn't Upload Your File to $pathtofile2."); die("Couldn't Upload Your File to $pathtofile2.");
} else { } else {
@unlink($img1); @unlink($img1);
} }
// duplicate-renaming function contributed by Gary Lawrence Murphy // duplicate-renaming function contributed by Gary Lawrence Murphy
?> ?>
<p><strong>Duplicate File?</strong></p> <p><strong>Duplicate File?</strong></p>
<p><b><em>The filename '<?php echo $img1_name; ?>' already exists!</em></b></p> <p><b><em>The filename '<?php echo $img1_name; ?>' already exists!</em></b></p>
<p> filename '<?php echo $img1; ?>' moved to '<?php echo "$pathtofile2 - $img2_name"; ?>'</p> <p> filename '<?php echo $img1; ?>' moved to '<?php echo "$pathtofile2 - $img2_name"; ?>'</p>
<p>Confirm or rename:</p> <p>Confirm or rename:</p>
<form action="upload.php" method="post" enctype="multipart/form-data"> <form action="upload.php" method="post" enctype="multipart/form-data">
<input type="hidden" name="MAX_FILE_SIZE" value="<?php echo $fileupload_maxk*1024 ?>" /> <input type="hidden" name="MAX_FILE_SIZE" value="<?php echo $fileupload_maxk*1024 ?>" />
<input type="hidden" name="img1_type" value="<?php echo $img1_type;?>" /> <input type="hidden" name="img1_type" value="<?php echo $img1_type;?>" />
<input type="hidden" name="img1_name" value="<?php echo $img2_name;?>" /> <input type="hidden" name="img1_name" value="<?php echo $img2_name;?>" />
<input type="hidden" name="img1_size" value="<?php echo $img1_size;?>" /> <input type="hidden" name="img1_size" value="<?php echo $img1_size;?>" />
<input type="hidden" name="img1" value="<?php echo $pathtofile2;?>" /> <input type="hidden" name="img1" value="<?php echo $pathtofile2;?>" />
Alternate name:<br /><input type="text" name="imgalt" size="30" class="uploadform" value="<?php echo $img2_name;?>" /><br /> <input type="hidden" name="thumbsize" value="<?php echo $_REQUEST['thumbsize'];?>" />
<br /> <input type="hidden" name="imgthumbsizecustom" value="<?php echo $_REQUEST['imgthumbsizecustom'];?>" />
Description:<br /><input type="text" name="imgdesc" size="30" class="uploadform" value="<?php echo $imgdesc;?>" /> Alternate name:<br /><input type="text" name="imgalt" size="30" class="uploadform" value="<?php echo $img2_name;?>" /><br />
<br /> <br />
<input type="submit" name="submit" value="confirm !" class="search" /> Description:<br /><input type="text" name="imgdesc" size="30" class="uploadform" value="<?php echo $imgdesc;?>" />
</form> <br />
</td> <input type="submit" name="submit" value="Rename" class="search" />
</tr> </form>
</tbody> </div>
</table> <?php
</body> require('admin-footer.php');
</html><?php die(); die();
} }
if (!strlen($imgalt)) { if (!strlen($imgalt)) {
@$moved = move_uploaded_file($img1, $pathtofile); //Path to your images directory, chmod the dir to 777 @$moved = move_uploaded_file($img1, $pathtofile); //Path to your images directory, chmod the dir to 777
// move_uploaded_file() can fail if open_basedir in PHP.INI doesn't // move_uploaded_file() can fail if open_basedir in PHP.INI doesn't
// include your tmp directory. Try copy instead? // include your tmp directory. Try copy instead?
if(!moved) { if(!moved) {
$moved = copy($img1, $pathtofile); $moved = copy($img1, $pathtofile);
} }
// Still couldn't get it. Give up. // Still couldn't get it. Give up.
if (!moved) { if (!moved) {
die("Couldn't Upload Your File to $pathtofile."); die("Couldn't Upload Your File to $pathtofile.");
} else { } else {
@unlink($img1); @unlink($img1);
} }
} else {
rename($img1, $pathtofile) } else {
or die("Couldn't Upload Your File to $pathtofile."); rename($img1, $pathtofile)
} or die("Couldn't Upload Your File to $pathtofile.");
}
if($HTTP_POST_VARS['thumbsize'] != 'none' ) {
if($HTTP_POST_VARS['thumbsize'] == 'small') {
$max_side = 200;
}
elseif($HTTP_POST_VARS['thumbsize'] == 'large') {
$max_side = 400;
}
elseif($HTTP_POST_VARS['thumbsize'] == 'custom') {
$max_side = $HTTP_POST_VARS['imgthumbsizecustom'];
}
$result = wp_create_thumbnail($pathtofile, $max_side, NULL);
if($result != 1) {
print $result;
}
}
}
if ( ereg('image/',$img1_type)) { if ( ereg('image/',$img1_type)) {
$piece_of_code = "&lt;img src=&quot;$fileupload_url/$img1_name&quot; alt=&quot;$imgdesc&quot; /&gt;"; $piece_of_code = "&lt;img src=&quot;$fileupload_url/$img1_name&quot; alt=&quot;$imgdesc&quot; /&gt;";
} else { } else {
$piece_of_code = "&lt;a href=&quot;$fileupload_url/$img1_name&quot; title=&quot;$imgdesc&quot; /&gt;$imgdesc&lt;/a&gt;"; $piece_of_code = "&lt;a href=&quot;$fileupload_url/$img1_name&quot; title=&quot;$imgdesc&quot; /&gt;$imgdesc&lt;/a&gt;";
}; };
?> ?>
<p><strong>File uploaded !</strong></p> <h3>File uploaded!</h3>
<p>Your file <b><?php echo "$img1_name"; ?></b> was uploaded successfully !</p> <p>Your file <code><?php echo $img1_name; ?></code> was uploaded successfully !</p>
<p>Here's the code to display it:</p> <p>Here&#8217;s the code to display it:</p>
<p><form> <p><code><?php echo $piece_of_code; ?></code>
<!--<textarea cols="25" rows="3" wrap="virtual"><?php echo "&lt;img src=&quot;$fileupload_url/$img1_name&quot; border=&quot;0&quot; alt=&quot;&quot; /&gt;"; ?></textarea>-->
<input type="text" name="imgpath" value="<?php echo $piece_of_code; ?>" size="38" style="padding: 5px; margin: 2px;" /><br />
<input type="button" name="close" value="Add the code to your post !" class="search" onClick="targetopener('<?php echo $piece_of_code; ?>')" style="margin: 2px;" />
</form>
</p> </p>
<p><strong>Image Details</strong>: <br /> <p><strong>Image Details</strong>: <br />
name: Name:
<?php echo "$img1_name"; ?> <?php echo $img1_name; ?>
<br /> <br />
size: Size:
<?php echo round($img1_size/1024,2); ?> KB <?php echo round($img1_size / 1024, 2); ?> <abbr title="Kilobyte">KB</abbr><br />
<br /> Type:
type: <?php echo $img1_type; ?>
<?php echo "$img1_type"; ?>
</p> </p>
<p align="right"> </div>
<form> <p><a href="upload.php">Start over</a>.</p>
<input type="button" name="close" value="Close this window" class="search" onClick="window.close()" /> <?php
</form> break;
</p> }
</td> include('admin-footer.php');
</tr> ?>
</tbody>
</table>
</body>
</html>