|
<?php
|
|
// turn on warnings and notice during developement
|
|
include('initialize/PhpErrorSettings.inc.php');
|
|
// Project: Web Reference Database (refbase) <http://www.refbase.net>
|
|
// Copyright: Matthias Steffens <mailto:refbase@extracts.de> and the file's
|
|
// original author(s).
|
|
//
|
|
// This code is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY. Please see the GNU General Public
|
|
// License for more details.
|
|
//
|
|
// File: ./query_manager.php
|
|
// Repository: $HeadURL: file:///svn/p/refbase/code/branches/bleeding-edge/query_manager.php $
|
|
// Author(s): Matthias Steffens <mailto:refbase@extracts.de>
|
|
//
|
|
// Created: 04-Feb-04, 22:29
|
|
// Modified: $Date: 2017-04-13 02:00:18 +0000 (Thu, 13 Apr 2017) $
|
|
// $Author: karnesky $
|
|
// $Revision: 1416 $
|
|
|
|
// This script enables you to manage your custom queries.
|
|
// It offers a form to save the current query or update/delete any of your saved queries.
|
|
// Saved queries are user specific and can be accessed from a popup on the main page.
|
|
// TODO: I18n
|
|
|
|
|
|
// Incorporate some include files:
|
|
include 'initialize/db.inc.php'; // 'db.inc.php' is included to hide username and password
|
|
include 'includes/header.inc.php'; // include header
|
|
include 'includes/footer.inc.php'; // include footer
|
|
include 'includes/include.inc.php'; // include common functions
|
|
include 'initialize/ini.inc.php'; // include common variables
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
// START A SESSION:
|
|
// call the 'start_session()' function (from 'include.inc.php') which will also read out available session variables:
|
|
start_session(true);
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
// Initialize preferred display language:
|
|
// (note that 'locales.inc.php' has to be included *after* the call to the 'start_session()' function)
|
|
include 'includes/locales.inc.php'; // include the locales
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
// Extract session variables (only necessary if register globals is OFF!):
|
|
if (isset($_SESSION['errors']))
|
|
$errors = $_SESSION['errors'];
|
|
else
|
|
$errors = array(); // initialize variable (in order to prevent 'Undefined index/variable...' messages)
|
|
|
|
if (isset($_SESSION['formVars']))
|
|
$formVars = $_SESSION['formVars'];
|
|
else
|
|
$formVars = array(); // initialize variable (in order to prevent 'Undefined index/variable...' messages)
|
|
|
|
// The current values of the session variables 'errors' and 'formVars' get stored in '$errors' or '$formVars', respectively. (either automatically if
|
|
// register globals is ON, or explicitly if register globals is OFF [by uncommenting the code above]).
|
|
// We need to clear these session variables here, since they would otherwise be still there on a subsequent call of 'query_manager.php'!
|
|
// Note: though we clear the session variables, the current error message (or form variables) is still available to this script via '$errors' (or '$formVars', respectively).
|
|
deleteSessionVariable("errors"); // function 'deleteSessionVariable()' is defined in 'include.inc.php'
|
|
deleteSessionVariable("formVars");
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
// A user must be logged in to save, modify or delete any queries:
|
|
if (!isset($_SESSION['loginEmail']))
|
|
{
|
|
// return an appropriate error message:
|
|
$HeaderString = returnMsg($loc["Warning_LoginToUseSavedQueries"] . "!", "warning", "strong", "HeaderString"); // function 'returnMsg()' is defined in 'include.inc.php'
|
|
|
|
// save the URL of the currently displayed page:
|
|
$referer = $_SERVER['HTTP_REFERER'];
|
|
|
|
// Write back session variables:
|
|
saveSessionVariable("referer", $referer); // function 'saveSessionVariable()' is defined in 'include.inc.php'
|
|
|
|
header("Location: user_login.php");
|
|
exit; // >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> !EXIT! <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
|
|
}
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
// Extract the view type requested by the user (either 'Mobile', 'Print', 'Web' or ''):
|
|
// ('' will produce the default 'Web' output style)
|
|
if (isset($_REQUEST['viewType']))
|
|
$viewType = $_REQUEST['viewType'];
|
|
else
|
|
$viewType = "";
|
|
|
|
|
|
// Check if the script was called with parameters (like: 'query_manager.php?customQuery=1&sqlQuery=...&showQuery=...&showLinks=...')
|
|
// If so, the parameter 'customQuery=1' will be set:
|
|
if (isset($_REQUEST['customQuery']))
|
|
$customQuery = $_REQUEST['customQuery']; // accept any previous SQL queries
|
|
else
|
|
$customQuery = "0";
|
|
|
|
if (isset($_REQUEST['queryAction']))
|
|
$queryAction = $_REQUEST['queryAction']; // check whether the user wants to *add* a query or *edit* an existing one
|
|
else
|
|
$queryAction = "add"; // *add* query will be the default action if no parameter is given
|
|
|
|
if (isset($_REQUEST['queryID']))
|
|
$queryID = $_REQUEST['queryID']; // fetch the query ID of the query to edit
|
|
else
|
|
$queryID = "";
|
|
|
|
|
|
// Setup some required variables:
|
|
|
|
// If there's no stored message available:
|
|
if (!isset($_SESSION['HeaderString']))
|
|
{
|
|
if (empty($errors)) // provide one of the default messages:
|
|
{
|
|
$errors = array(); // re-assign an empty array (in order to prevent 'Undefined variable "errors"...' messages when calling the 'fieldError' function later on)
|
|
if ($queryAction == "edit") // *edit* query
|
|
$HeaderString = "Edit saved query:";
|
|
else // *add* query will be the default action if no parameter is given
|
|
{
|
|
if ($customQuery == "1") // the script was called with parameters
|
|
$HeaderString = "Save your current query:"; // Provide the default message
|
|
else // the script was called without any custom SQL query
|
|
$HeaderString = "Save a query for later retrieval:"; // Provide the default message
|
|
}
|
|
}
|
|
else // -> there were errors validating the data entered by the user
|
|
$HeaderString = returnMsg($loc["Warning_InputDataError"] . ":", "warning", "strong"); // function 'returnMsg()' is defined in 'include.inc.php'
|
|
|
|
}
|
|
else
|
|
{
|
|
$HeaderString = $_SESSION['HeaderString']; // extract 'HeaderString' session variable (only necessary if register globals is OFF!)
|
|
|
|
// Note: though we clear the session variable, the current message is still available to this script via '$HeaderString':
|
|
deleteSessionVariable("HeaderString"); // function 'deleteSessionVariable()' is defined in 'include.inc.php'
|
|
}
|
|
|
|
|
|
// Adjust the page (= button) title & the help text:
|
|
if ($queryAction == "edit") // *edit* query
|
|
{
|
|
$pageTitle = "Edit Query"; // set the correct page title
|
|
|
|
$helpText = "Modify the elements of your query as needed and click the <em>Edit Query</em> button. You can change the name of your query, refine the SQL query string or modify any of the display options.";
|
|
}
|
|
else // *add* query
|
|
{
|
|
$pageTitle = "Add Query"; // set the correct page title
|
|
|
|
// Adjust the help text:
|
|
if ($customQuery == "1") // if the script was called with parameters
|
|
$helpText = "Name your query and click the <em>Add Query</em> button. If you like, you can refine your query or modify any of the display options before saving.";
|
|
else
|
|
$helpText = "Enter your query and set the display options to suit your needs. Then, name your query and click the <em>Add Query</em> button.";
|
|
}
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
if ($queryAction == "edit" && empty($errors))
|
|
{
|
|
$exit = false;
|
|
|
|
// CONSTRUCT SQL QUERY:
|
|
// for the selected query, select *all* fields that are available in the form:
|
|
$query = "SELECT query_id, user_id, query_name, display_type, view_type, query, show_query, show_links, show_rows, cite_style_selector, cite_order"
|
|
. " FROM $tableQueries WHERE query_id = " . quote_smart($queryID); // since we'll only fetch one record, the ORDER BY clause is obsolete here
|
|
|
|
|
|
// (1) OPEN CONNECTION, (2) SELECT DATABASE
|
|
connectToMySQLDatabase(); // function 'connectToMySQLDatabase()' is defined in 'include.inc.php'
|
|
|
|
// (3a) RUN the query on the database through the connection:
|
|
$result = queryMySQLDatabase($query); // function 'queryMySQLDatabase()' is defined in 'include.inc.php'
|
|
|
|
if (@ mysqli_num_rows($result) == 1) // this condition is added here to avoid the case that editing a query item which got deleted in the meantime invokes a seemingly correct but empty 'edit query' form
|
|
{
|
|
// (3b) EXTRACT results:
|
|
$row = mysqli_fetch_array($result); // fetch the current row into the array $row (it'll be always *one* row, but anyhow)
|
|
|
|
// check whether the user tries to edit a query that does not belong to his own set of saved queries:
|
|
if ($row['user_id'] != getUserID($loginEmail)) // the function 'getUserID' and the '$loginEmail' variable are specified in 'include.inc.php'
|
|
{
|
|
$HeaderString = "You can only edit your own queries!";
|
|
$exit = true;
|
|
}
|
|
}
|
|
else // the query did NOT return any results (since we searched for a unique primary key of the queries table, the number of rows found can be only 1 or 0)
|
|
{
|
|
$HeaderString = "The specified query does not exist!";
|
|
$exit = true;
|
|
}
|
|
|
|
if ($exit)
|
|
{
|
|
// return an appropriate error message:
|
|
$HeaderString = returnMsg($HeaderString, "warning", "strong", "HeaderString"); // function 'returnMsg()' is defined in 'include.inc.php'
|
|
|
|
header("Location: index.php"); // relocate back to the main page
|
|
exit; // >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> !EXIT! <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
// assign correct values to the form variables:
|
|
if (empty($errors))
|
|
{
|
|
if ($queryAction == "edit")
|
|
{
|
|
// fetch attributes of the current query into variables:
|
|
$queryID = $row['query_id'];
|
|
$queryName = $row['query_name'];
|
|
$displayType = $row['display_type'];
|
|
$queryViewType = $row['view_type'];
|
|
$showQuery = $row['show_query'];
|
|
$showLinks = $row['show_links'];
|
|
$showRows = $row['show_rows'];
|
|
$citeStyle = encodeHTML($row['cite_style_selector']);
|
|
$citeOrder = $row['cite_order'];
|
|
$sqlQuery = $row['query'];
|
|
$origQueryName = $row['query_name'];
|
|
}
|
|
else // $queryAction == "add"
|
|
{
|
|
$queryID = "0"; // since '' would cause an SQL error we use '0' to indicate that there's no query ID
|
|
$queryName = "";
|
|
$queryViewType = ""; // ('' will produce the default 'Web' view)
|
|
$origQueryName = "";
|
|
|
|
if ($customQuery == "1") // the script was called with parameters
|
|
{
|
|
$displayType = $_REQUEST['displayType']; // extract the type of display requested by the user (either 'Display', 'Cite' or '')
|
|
$showQuery = $_REQUEST['showQuery']; // extract the $showQuery parameter
|
|
$showLinks = $_REQUEST['showLinks']; // extract the $showLinks parameter
|
|
$showRows = $_REQUEST['showRows']; // extract the $showRows parameter
|
|
$citeStyle = $_REQUEST['citeStyle']; // get the cite style chosen by the user (only occurs in 'extract.php' form and in query result lists)
|
|
$citeOrder = $_REQUEST['citeOrder']; // get the citation sort order chosen by the user (only occurs in 'extract.php' form and in query result lists)
|
|
|
|
$sqlQuery = $_REQUEST['sqlQuery']; // accept any previous SQL queries
|
|
$sqlQuery = stripSlashesIfMagicQuotes($sqlQuery); // function 'stripSlashesIfMagicQuotes()' is defined in 'include.inc.php'
|
|
}
|
|
else // if there was no previous SQL query provide the default query and options:
|
|
{
|
|
$displayType = ""; // ('' will produce the default view)
|
|
$showQuery = "0";
|
|
$showLinks = "1";
|
|
$showRows = $_SESSION['userRecordsPerPage']; // get the default number of records per page preferred by the current user
|
|
$citeStyle = "";
|
|
$citeOrder = "";
|
|
|
|
// TODO: build the complete SQL query using functions 'buildFROMclause()' and 'buildORDERclause()'
|
|
$sqlQuery = buildSELECTclause($displayType, $showLinks, "created_by, modified_date, modified_time, modified_by", false, false, $defaultFieldsListViewMajor); // function 'buildSELECTclause()' is defined in 'include.inc.php', and '$defaultFieldsListViewMajor' is defined in 'ini.inc.php'
|
|
$sqlQuery .= " FROM $tableRefs WHERE modified_date = CURDATE() ORDER BY modified_date DESC, modified_time DESC";
|
|
}
|
|
}
|
|
}
|
|
else // there were some errors on submit
|
|
{
|
|
// load the form data that were entered by the user:
|
|
$queryID = $formVars['queryID'];
|
|
$queryName = $formVars['queryName'];
|
|
$displayType = $formVars['displayType'];
|
|
$queryViewType = $formVars['queryViewType'];
|
|
|
|
if (isset($formVars['showQuery']))
|
|
$showQuery = $formVars['showQuery'];
|
|
else
|
|
$showQuery = "";
|
|
|
|
if (isset($formVars['showLinks']))
|
|
$showLinks = $formVars['showLinks'];
|
|
else
|
|
$showLinks = "";
|
|
|
|
$showRows = $formVars['showRows'];
|
|
|
|
if (isset($formVars['citeStyle']))
|
|
$citeStyle = $formVars['citeStyle'];
|
|
else
|
|
$citeStyle = "";
|
|
if (preg_match("/%20/", $citeStyle)) // if '$citeStyle' still contains URL encoded data... ('%20' is the URL encoded form of a space, see note below!)
|
|
$citeStyle = rawurldecode($citeStyle); // ...URL decode 'citeStyle' statement (it was URL encoded before incorporation into a hidden tag of the 'sqlSearch' form to avoid any HTML syntax errors)
|
|
// NOTE: URL encoded data that are included within a *link* will get URL decoded automatically *before* extraction via '$_REQUEST'!
|
|
// But, opposed to that, URL encoded data that are included within a form by means of a *hidden form tag* will NOT get URL decoded automatically! Then, URL decoding has to be done manually (as is done here)!
|
|
|
|
$citeOrder = $formVars['citeOrder'];
|
|
|
|
$sqlQuery = $formVars['sqlQuery'];
|
|
$sqlQuery = stripSlashesIfMagicQuotes($sqlQuery); // function 'stripSlashesIfMagicQuotes()' is defined in 'include.inc.php'
|
|
|
|
if (isset($formVars['origQueryName']))
|
|
$origQueryName = rawurldecode($formVars['origQueryName']); // get the original query name that was included within a hidden form tag (and since it got URL encoded, we'll need to decode it again)
|
|
else
|
|
$origQueryName = "";
|
|
}
|
|
|
|
// set display options according to the fetched attribute values:
|
|
if ($showQuery == "1")
|
|
$checkQuery = " checked";
|
|
else
|
|
$checkQuery = "";
|
|
|
|
if ($showLinks == "1")
|
|
$checkLinks = " checked";
|
|
else
|
|
$checkLinks = "";
|
|
|
|
if (preg_match("/^Print$/i", $queryViewType))
|
|
{
|
|
$webViewTypeSelected = "";
|
|
$printViewTypeSelected = " selected";
|
|
$mobileViewTypeSelected = "";
|
|
}
|
|
elseif (preg_match("/^Mobile$/i", $queryViewType))
|
|
{
|
|
$webViewTypeSelected = "";
|
|
$printViewTypeSelected = "";
|
|
$mobileViewTypeSelected = " selected";
|
|
}
|
|
else // '$queryViewType' is 'Web' or ''
|
|
{
|
|
$webViewTypeSelected = " selected";
|
|
$printViewTypeSelected = "";
|
|
$mobileViewTypeSelected = "";
|
|
}
|
|
|
|
|
|
// Show the login status:
|
|
showLogin(); // (function 'showLogin()' is defined in 'include.inc.php')
|
|
|
|
// (2a) Display header:
|
|
// call the 'displayHTMLhead()' and 'showPageHeader()' functions (which are defined in 'header.inc.php'):
|
|
displayHTMLhead(encodeHTML($officialDatabaseName) . " -- " . $pageTitle, "index,follow", "Manage queries that are used to search the " . encodeHTML($officialDatabaseName), "", false, "", $viewType, array());
|
|
showPageHeader($HeaderString);
|
|
|
|
// (2b) Start <form> and <table> holding the form elements:
|
|
// note: we provide a default value for the 'submit' form tag so that hitting <enter> within a text entry field will act as if the user clicked the 'Add/Edit Query' button
|
|
?>
|
|
|
|
<form action="query_modify.php" method="POST" name="saveQuery">
|
|
<input type="hidden" name="formType" value="saveQuery">
|
|
<input type="hidden" name="submit" value="<?php echo $pageTitle; ?>">
|
|
<input type="hidden" name="queryAction" value="<?php echo encodeHTML($queryAction); ?>">
|
|
<input type="hidden" name="queryID" value="<?php echo encodeHTML($queryID); ?>">
|
|
<input type="hidden" name="displayType" value="<?php echo encodeHTML($displayType); ?>">
|
|
<input type="hidden" name="citeStyle" value="<?php echo rawurlencode($citeStyle); ?>">
|
|
<input type="hidden" name="citeOrder" value="<?php echo encodeHTML($citeOrder); ?>">
|
|
<input type="hidden" name="origQueryName" value="<?php echo rawurlencode($origQueryName); ?>">
|
|
<table align="center" border="0" cellpadding="0" cellspacing="10" width="95%" summary="This table holds forms that enable you to manage your custom queries">
|
|
<tr>
|
|
<td width="120" valign="middle">
|
|
<div class="sect"><?php echo $loc["QueryName"]; ?>:</div>
|
|
</td>
|
|
<td><?php echo fieldError("queryName", $errors); ?>
|
|
|
|
<input type="text" name="queryName" value="<?php echo encodeHTML($queryName); ?>" size="62">
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td> </td>
|
|
<td>
|
|
<input type="submit" name="submit" value="<?php echo $pageTitle; ?>"><?php
|
|
|
|
if ($queryAction == "edit") // add a DELETE button (CAUTION: the delete button must be displayed *AFTER* the edit button, otherwise DELETE will be the default action if the user hits return!!)
|
|
// (this is since the first displayed submit button represents the default submit action in several browsers!! [like OmniWeb or Mozilla])
|
|
{
|
|
?>
|
|
|
|
<input type="submit" name="submit" value="Delete Query"><?php
|
|
}
|
|
?>
|
|
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<table class="showhide" align="center" border="0" cellpadding="0" cellspacing="10" width="95%">
|
|
<tr>
|
|
<td class="small" width="120" valign="top">
|
|
<a href="javascript:toggleVisibility('searchopt','optToggleimg','optToggletxt','<?php echo rawurlencode($loc["SearchAndDisplayOptions"]); ?>')"<?php echo addAccessKey("attribute", "search_opt"); ?> title="<?php echo $loc["LinkTitle_ToggleVisibility"] . addAccessKey("title", "search_opt"); ?>">
|
|
<img id="optToggleimg" class="toggleimg" src="img/closed.gif" alt="<?php echo $loc["LinkTitle_ToggleVisibility"]; ?>" width="9" height="9" hspace="0" border="0">
|
|
<span id="optToggletxt" class="toggletxt"><?php echo $loc["SearchAndDisplayOptions"]; ?></span>
|
|
</a>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<table id="searchopt" align="center" border="0" cellpadding="0" cellspacing="10" width="95%" summary="This table holds search & display options" style="display: none;">
|
|
<tr>
|
|
<td width="120" valign="top">
|
|
<div class="sect"><?php echo $loc["SQLQuery"]; ?>:</div>
|
|
</td>
|
|
<td colspan="2"><?php echo fieldError("sqlQuery", $errors); ?>
|
|
|
|
<textarea name="sqlQuery" rows="6" cols="60"><?php echo encodeHTML($sqlQuery); ?>
|
|
|
|
</textarea>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td valign="middle">
|
|
<div class="sect"><?php echo $loc["DisplayOptions"]; ?>:</div>
|
|
</td>
|
|
<td width="205" valign="middle">
|
|
<input type="checkbox" name="showLinks" value="1"<?php echo $checkLinks; ?>> <?php echo $loc["ShowLinks"]; ?>
|
|
|
|
</td>
|
|
<td valign="middle">
|
|
<?php echo $loc["ShowRecordsPerPage_Prefix"]; ?> <input type="text" name="showRows" value="<?php echo encodeHTML($showRows); ?>" size="4" title="<?php echo $loc["DescriptionShowRecordsPerPage"]; ?>"> <?php echo $loc["ShowRecordsPerPage_Suffix"]; ?>
|
|
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td> </td>
|
|
<td valign="top">
|
|
<input type="checkbox" name="showQuery" value="1"<?php echo $checkQuery; ?>> <?php echo $loc["DisplaySQLquery"]; ?>
|
|
|
|
</td>
|
|
<td valign="top">
|
|
<?php echo $loc["ViewType"]; ?>:
|
|
<select name="queryViewType">
|
|
<option value="Web"<?php echo $webViewTypeSelected; ?>><?php echo $loc["web"]; ?></option>
|
|
<option value="Print"<?php echo $printViewTypeSelected; ?>><?php echo $loc["print"]; ?></option>
|
|
<option value="Mobile"<?php echo $mobileViewTypeSelected; ?>><?php echo $loc["mobile"]; ?></option>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<table class="showhide" align="center" border="0" cellpadding="0" cellspacing="10" width="95%">
|
|
<tr>
|
|
<td class="small" width="120" valign="top">
|
|
<a href="javascript:toggleVisibility('helptxt','helpToggleimg','helpToggletxt','<?php echo rawurlencode($loc["Help"]); ?>')"<?php echo addAccessKey("attribute", "search_help"); ?> title="<?php echo $loc["LinkTitle_ToggleVisibility"] . addAccessKey("title", "search_help"); ?>">
|
|
<img id="helpToggleimg" class="toggleimg" src="img/closed.gif" alt="<?php echo $loc["LinkTitle_ToggleVisibility"]; ?>" width="9" height="9" hspace="0" border="0">
|
|
<span id="helpToggletxt" class="toggletxt"><?php echo $loc["Help"]; ?></span>
|
|
</a>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<table id="helptxt" align="center" border="0" cellpadding="0" cellspacing="10" width="95%" summary="This table holds some help text and example queries" style="display: none;">
|
|
<tr>
|
|
<td width="120" valign="top">
|
|
<div class="sect"><?php echo $loc["Help"]; ?>:</div>
|
|
</td>
|
|
<td class="helpbody" valign="top">
|
|
<div class="even">
|
|
<?php echo $helpText; ?>
|
|
|
|
</div>
|
|
<div class="odd">
|
|
<?php echo $loc["MySQL-Info"]; ?>
|
|
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</form><?php
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
// SHOW ERROR IN RED:
|
|
function fieldError($fieldName, $errors)
|
|
{
|
|
if (isset($errors[$fieldName]))
|
|
return returnMsg($errors[$fieldName], "warning2", "strong", "", "", "<br>"); // function 'returnMsg()' is defined in 'include.inc.php'
|
|
}
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
// DISPLAY THE HTML FOOTER:
|
|
// call the 'showPageFooter()' and 'displayHTMLfoot()' functions (which are defined in 'footer.inc.php')
|
|
showPageFooter($HeaderString);
|
|
|
|
displayHTMLfoot();
|
|
|
|
// --------------------------------------------------------------------
|
|
?>
|