Exemple #1
0
function import($db)
{
    $IMPORT_STEP = 100;
    //переменная, определяющая сколько будет обработано строк за 1 прогон
    //ini_set("max_execution_time", "60"); //1 мин
    $html = "";
    //html который возвращаем клиенту
    //ключевые параметры, обозначают текущую строку в обработке, если 1, то еще не было загрузки
    $file_name = "";
    if (isset($_POST['filename'])) {
        $file_name = stripslashes($_POST['filename']);
    }
    $upload_failure = false;
    //загрузку файла и подсчет количества строк делаем 1 раз при первой загрузке
    if ($file_name == "") {
        $upload_file_field = "uploadedfile";
        $uploaddir = $_SERVER['DOCUMENT_ROOT'] . dirname($_SERVER['PHP_SELF']) . "/" . "upload" . "/";
        if (strpos($_FILES[$upload_file_field]['name'], ".csv") === false) {
            $html .= date('m.d.Y H:m:s') . ": " . "<p style='color:red;'>Выберите файл в формате *.csv file!</p>";
            $upload_failure = true;
        } else {
            if (move_uploaded_file($_FILES[$upload_file_field]['tmp_name'], $uploaddir . $_FILES[$upload_file_field]['name'])) {
                $html .= date('m.d.Y H:m:s') . ": " . "Файл успешно загружен! Импорт начинается..." . "<br />";
                $file_name = $uploaddir . $_FILES[$upload_file_field]['name'];
            } else {
                $html .= date('m.d.Y H:m:s') . ": " . "<p style='color:red;'>Что-то пошло не так при загрузке файла: " . $_FILES['uploadedfile']['error'] . "</p>";
                $upload_failure = true;
            }
        }
    } else {
        //if (isset($_POST['filename'])) $file_name = intval($_POST['filename']);
        //else  $currentRow = 1;
    }
    if (!$upload_failure) {
        $makeImportCategories = false;
        $makeImportManufacturers = false;
        $makeImportProducts = false;
        //Комментируем блок, если это необходимо
        $makeImportCategories = true;
        $makeImportManufacturers = true;
        $makeImportProducts = true;
        //подключение к БД
        $db->connectToDb();
        $table_prefix = $db->getTablePrefix() . $db->getVMTablePrefix();
        if ($makeImportCategories) {
            $category_import = new Categories();
        }
        if ($makeImportManufacturers) {
            $manufacturer_import = new Manufacturers();
        }
        if ($makeImportProducts) {
            $product_import = new Products();
        }
        //инициализируем начальные номера основных записей таблиц
        if ($makeImportCategories) {
            $html .= $category_import->init($db, $table_prefix);
        }
        if ($makeImportManufacturers) {
            $html .= $manufacturer_import->init($db, $table_prefix);
        }
        if ($makeImportProducts) {
            $html .= $product_import->init($db, $table_prefix);
        }
        //принимаени POST переменные
        //ключевые параметры, обозначают текущую строку в обработке, если 1, то еще не было загрузки
        if (isset($_POST['currow'])) {
            $currentRow = intval($_POST['currow']);
        } else {
            $currentRow = 1;
        }
        if (isset($_POST['wh'])) {
            $warehouse = $_POST['wh'];
        }
        if (isset($_POST['rowcount'])) {
            if ($_POST['rowcount'] > 1) {
                $rowCount = intval($_POST['rowcount']);
            } else {
                $rowCount = count(file($file_name));
            }
        } else {
            $rowCount = count(file($file_name));
        }
        if (isset($_POST['maxrow'])) {
            if ($_POST['maxrow'] > 0) {
                $max_row = intval($_POST['maxrow']);
            } else {
                $max_row = 100000;
            }
            //максимальное количество строк для импорта
        } else {
            $max_row = 100000;
        }
        //максимальное количество строк для импорта
        if (isset($_POST['startrow'])) {
            if (intval($_POST['startrow']) > 0) {
                $init_row = intval($_POST['startrow']) - 2;
            } else {
                $init_row = 0;
            }
            //пропускаем все строки до данной строки (начинаем прием с этой строки)
        } else {
            $init_row = 0;
        }
        //пропускаем все строки до данной строки (начинаем прием с этой строки)
        //если начальная строка пользователя меньше текущей строки обработки, то должны обрабатывать с текущей строки
        if ($init_row < $currentRow) {
            $init_row = $currentRow + $init_row;
        }
        //2. read csv file
        $fileArr = file($file_name);
        $row = 1;
        //счетчик итераций в одной обработке
        $opCount = count($fileArr);
        $fileArr = array_slice($fileArr, $init_row);
        for ($j = $init_row; $j < $opCount; $j++) {
            if ($row + $currentRow < $max_row) {
                $data = fgetcsv_array($fileArr, ";");
                if (trim($data[0]) != "") {
                    //основной импорт
                    for ($i = 0; $i < count($data); $i++) {
                        $dataUTF[$i] = iconv('windows-1251', 'UTF-8', $data[$i]);
                    }
                    if ($makeImportCategories) {
                        $html .= $category_import->process($dataUTF);
                    }
                    if ($makeImportManufacturers) {
                        $html .= $manufacturer_import->process($dataUTF);
                    }
                    if ($makeImportProducts) {
                        $html .= $product_import->process($dataUTF, $category_import->getCategory(), $manufacturer_import->getManufacturer(), $warehouse);
                    }
                }
            }
            if ($row > $IMPORT_STEP) {
                if ($html != "") {
                    $html = date('m.d.Y H:m:s') . ": " . $html;
                }
                echo '{"currow":"' . ($row + $currentRow) . '", "rowcount":"' . intval($rowCount) . '", "filename":"' . addslashes($file_name) . '", "state":"process", "log":"' . $html . '"}';
                flush();
                return;
            }
            $row++;
        }
        $html = '<br />' . date('m.d.Y H:m:s') . ": " . "Импорт завершен!" . '<br />' . "<strong>Не забудьте обновить карту сайта на закладке Админ</strong>" . '<br />' . $html;
        echo '{"currow":"' . ($row + $currentRow) . '", "rowcount":"' . $rowCount . '", "filename":"' . addslashes($file_name) . '", "state":"complete", "log":"' . $html . '"}';
    }
}
 public static function getCategory($id)
 {
     $categories = new Categories();
     return $categories->getCategory($id);
 }
<?php

include_once "../core/model.php";
include_once "../models/categories.php";
include_once "../views/functions.php";
$id_category = getIdFromUrl();
$category = new Categories();
$category->getCategory($id_category);
include_once "admin-header.php";
echo "<a href='" . PATHSITE . "/admin-categories'>Вернуться</a>";
// or href="javascript:history.go(-1)"
?>
<h2>Просмотр категории</h2>
<form name="admin-category" action="http://localhost/iba/category/update" method="post" onsubmit="alert('Данные успешно сохранены!');">

 <label>Номер категории:</label>
 <input type="text" id="id_category" name="id_category" maxlength="11" value="<?php 
echo $category->id;
?>
" readonly="readonly">

 <label>Название категории:</label>
 <input type="text" id="name" name="name" maxlength="30" value="<?php 
echo $category->name;
?>
">
 
 <label>Родительская категория:</label>
 <input type="text" id="id_parent" name="id_parent" maxlength="11" value="<?php 
echo $category->id_parent;
?>