<?php
-$page_security = 15;
+$page_security = 20;
$path_to_root="..";
include_once($path_to_root . "/includes/session.inc");
include_once($path_to_root . "/includes/date_functions.inc");
include_once($path_to_root . "/admin/db/company_db.inc");
+include_once($path_to_root . "/admin/db/maintenance_db.inc");
include_once($path_to_root . "/modules/installed_modules.php");
include_once($path_to_root . "/includes/ui.inc");
$tabs = array('orders', 'AP', 'stock', 'manuf', 'proj', 'GL', 'system');
-$names = array(_("Sales"), _("Purchases"), _("Items and Inventory"), _("Manufacturing"),
+$names = array(_("Sales"), _("Purchases"), _("Items and Inventory"), _("Manufacturing"),
_("Dimensions"), _("Banking and General Ledger"), _("Setup"));
-
+
//---------------------------------------------------------------------------------------------
if (isset($_GET['selected_id']))
{
$selected_id = $_GET['selected_id'];
-}
+}
elseif (isset($_POST['selected_id']))
{
$selected_id = $_POST['selected_id'];
{
if ($selected == $tabs[$i])
echo "<option selected value='".$tabs[$i]."'>" . $names[$i]. "</option>\n";
- else
+ else
echo "<option value='".$tabs[$i]."'>" . $names[$i]. "</option>\n";
- }
+ }
echo "</select></td>\n";
echo "</tr>\n";
}
function check_data()
{
+ if ($_POST['name'] == "" || $_POST['path'] == "")
+ return false;
return true;
}
if (!is_array($aryData) || !$strIndex || !$strSortBy)
// return the array
return $aryData;
-
+
// create our temporary arrays
$arySort = $aryResult = array();
-
+
// loop through the array
foreach ($aryData as $aryRow)
// set up the value in the array
$arySort[$aryRow[$strIndex]] = $aryRow[$strSortBy];
-
+
// apply the natural sort
natsort($arySort);
if ($strSortType=="desc")
// reverse the array
arsort($arySort);
-
+
// loop through the sorted and original data
foreach ($arySort as $arySortKey => $arySorted)
foreach ($aryData as $aryOriginal)
// return the return
return $aryResult;
-}
+}
function write_modules()
{
$mods = array_natsort($installed_modules, 'tab', 'tab');
$installed_modules = $mods;
//reset($installed_languages);
- $n = count($installed_modules);
+ $n = count($installed_modules);
$msg = "<?php\n\n";
-
+
$msg .= "/*****************************************************************\n";
$msg .= "External modules for FrontAccounting\n";
$msg .= "******************************************************************/\n";
$msg .= "\n\n";
$msg .= "\$installed_modules = array (\n";
- $msg .= "\t0 => ";
+ if ($n > 0)
+ $msg .= "\t0 => ";
for ($i = 0; $i < $n; $i++)
{
if ($i > 0)
$filename = $path_to_root . "/modules/installed_modules.php";
// Check if the file exists and is writable first.
- if (file_exists($filename) && is_writable($filename))
+ if (file_exists($filename) && is_writable($filename))
{
- if (!$zp = fopen($filename, 'w'))
+ if (!$zp = fopen($filename, 'w'))
{
display_error(_("Cannot open the modules file - ") . $filename);
return false;
- }
- else
+ }
+ else
{
- if (!fwrite($zp, $msg))
+ if (!fwrite($zp, $msg))
{
display_error(_("Cannot write to the modules file - ") . $filename);
fclose($zp);
// Close file
fclose($zp);
}
- }
- else
+ }
+ else
{
display_error(_("The modules file ") . $filename . _(" is not writable. Change its permissions so it is, then re-run the operation."));
return false;
function handle_submit()
{
- global $path_to_root, $installed_modules;
+ global $path_to_root, $installed_modules, $db_connections;
if (!check_data())
return false;
$installed_modules[$id]['tab'] = $_POST['tab'];
$installed_modules[$id]['name'] = $_POST['name'];
$installed_modules[$id]['path'] = $_POST['path'];
- $directory = $path_to_root . "/modules/" . $_POST['path'];
+ $directory = $path_to_root . "/modules/" . $_POST['path'];
if (!file_exists($directory))
{
mkdir($directory);
- }
+ }
if (is_uploaded_file($_FILES['uploadfile']['tmp_name']))
{
$installed_modules[$id]['filename'] = $_FILES['uploadfile']['name'];
}
else
$installed_modules[$id]['filename'] = $_POST['filename'];
+ if (is_uploaded_file($_FILES['uploadfile2']['tmp_name']))
+ {
+ $file1 = $_FILES['uploadfile2']['tmp_name'];
+ $file2 = $directory . "/".$_FILES['uploadfile2']['name'];
+ if (file_exists($file2))
+ unlink($file2);
+ move_uploaded_file($file1, $file2);
+ $db_name = $_SESSION["wa_current_user"]->company;
+ db_import($file2, $db_connections[$db_name]);
+ }
if (!write_modules())
return false;
return true;
{
global $path_to_root, $installed_modules;
- $id = $_GET['id'];
+ $id = $_GET['id'];
$path = $installed_modules[$id]['path'];
- $filename = "$path_to_root/modules/$path";
- if ($h = opendir($filename))
+ $filename = "$path_to_root/modules/$path";
+ if ($h = opendir($filename))
{
- while (($file = readdir($h)) !== false)
+ while (($file = readdir($h)) !== false)
{
if (is_file("$filename/$file"))
unlink("$filename/$file");
$n = $selected_id;
else
$n = count($installed_modules);
-
+
start_form(true, true);
echo "
document.forms[0].submit()
}
</script>";
-
+
start_table($table_style2);
- if ($selected_id != -1)
+ if ($selected_id != -1)
{
$mod = $installed_modules[$selected_id];
$_POST['tab'] = $mod['tab'];
$_POST['filename'] = $mod['filename'];
hidden('selected_id', $selected_id);
hidden('filename', $_POST['filename']);
- }
+ }
tab_list_row(_("Menu Tab"), 'tab', null);
text_row_ex(_("Name"), 'name', 30);
text_row_ex(_("Folder"), 'path', 20);
label_row(_("Module File"), "<input name='uploadfile' type='file'>");
+ label_row(_("SQL File"), "<input name='uploadfile2' type='file'>");
end_table(0);
display_note(_("Select your module PHP file from your local harddisk."), 0, 1);
- echo "<center><input onclick='javascript:updateModule()' type='button' style='width:150' value='". _("Save"). "'>";
+ echo "<center><input onclick='javascript:updateModule()' type='button' style='width:150px' value='". _("Save"). "'></center>";
end_form();
if (isset($_GET['c']))
{
- if ($_GET['c'] == 'df')
+ if ($_GET['c'] == 'df')
{
handle_delete();
}
- if ($_GET['c'] == 'u')
+ if ($_GET['c'] == 'u')
{
- if (handle_submit())
+ if (handle_submit())
{
//meta_forward($_SERVER['PHP_SELF']);
}
- }
+ }
}
//---------------------------------------------------------------------------------------------