Список товаров в категории ShopOS #

Список товаров в категории ShopOS

Немного теории:
http://www.getinfo.ru/article610.html - крутая статья!
http://phpclub.ru/detail/article/db_tree

По топику понятно, что он посвящён именно двигу ShopOS. Классный, в бесплатной сборке он идет без почты (функция умело удалена), но имея гугл и сноровку можно допилить его, что бы он заработал как полнофункциональный магазинчик. Дальше о категориях.

Для начало нужно было получить вот такое меню:
Список товаров в категории ShopOS

Что бы при нажатии на главную категорию выпадал список товаров. Не долго мучаясь отписал на официальном форуме . Увы ответов не получил, готовых решений нет. Понял, что придётся самому.

С ЧПУ (вставить в index.html вашего шаблона):

            {php}        
            $sql = "SELECT cat.categories_id, cd.categories_name FROM vip_categories cat, vip_categories_description cd WHERE cat.categories_status = '1' AND cd.categories_id = cat.categories_id";
            $sql = osDBquery($sql);
            while ($row = os_db_fetch_array($sql)) {
                    $menu[$row['categories_id']] = $row['categories_name'];
            }
            foreach ($menu as $CatId => $CatName )
            {
                echo "
  • ".$CatName."";
                echo "
      ";
                      $query = "SELECT * FROM
                          vip_products p,
                          vip_products_description pd,
                          vip_products_to_categories p2c,
                          vip_categories c
                      WHERE
                          c.categories_status='1'
                          and p.products_status = '1'
                          and p.products_id = p2c.products_id
                          and p.products_id=pd.products_id
                          and p2c.categories_id = '".$CatId."'
                          and c.categories_id = '".$CatId."'
                      ORDER by p.products_date_added";
                      $query = osDBquery($query);
                      while ($row1 = os_db_fetch_array($query)) {
                          echo "
    • ".$row1['products_name']."
    • ";
                      }
                  echo "
  • ";
            }
            {/php}            


На выходе:


Оказалось что необходимость в данном меню отпадает, но появляется новая!
Список товаров в категории ShopOS

Класс! Теперь есть еще уровень вложенности.

С ЧПУ (вставить в index.html вашего шаблона):

    {php}
    $sql = "SELECT cat.categories_id, cat.parent_id, cat.categories_url, cd.categories_name FROM vip_categories cat, vip_categories_description cd WHERE cat.categories_status = '1' AND cd.categories_id = cat.categories_id ORDER BY cat.parent_id, cat.categories_id";
    $sql = osDBquery($sql);
    while ($row = os_db_fetch_array($sql)) {
            $menu[$row['parent_id']][$row['categories_id']] = $row['categories_name'];
    }
    foreach ($menu[0] as $CatId => $CatName )
    {
     echo "
  • ".$CatName."";
     if (isset($menu[$CatId])) {
            echo "
      ";
               foreach ($menu[$CatId] as $ItemId => $ItemName)
               {
                echo "
    • ".$ItemName."";
                echo "
        ";
                        $query = "SELECT * FROM
                                vip_products p,
                                vip_products_description pd,
                                vip_products_to_categories p2c,
                                vip_categories c
                        WHERE
                                c.categories_status='1'
                                and p.products_status = '1'
                                and p.products_id = p2c.products_id
                                and p.products_id=pd.products_id
                                and p2c.categories_id = '".$ItemId."'
                                and c.parent_id = '".$CatId."'
                        ORDER by p.products_date_added";
                        $query = osDBquery($query);
                        while ($row1 = os_db_fetch_array($query)) {
                                echo "
      • ".$row1['products_name']."
      • ";
                        }  
                   echo "
      ";
                echo "
    • ";
               }
              echo "
  • ";
     } else { echo "";}
    }
    {/php}


На выходе:



Мне ЧПУ не надо - БЕЗ ЧПУ (вставить в index.html вашего шаблона):


    {php}
    $sql = "SELECT cat.categories_id, cat.parent_id, cat.categories_url, cd.categories_name FROM vip_categories cat, vip_categories_description cd WHERE cat.categories_status = '1' AND cd.categories_id = cat.categories_id ORDER BY cat.parent_id, cat.categories_id";
    $sql = osDBquery($sql);
    while ($row = os_db_fetch_array($sql)) {
            $menu[$row['parent_id']][$row['categories_id']] = $row['categories_name'];
    }
    foreach ($menu[0] as $CatId => $CatName )
    {
     echo "
  • ".$CatName."";
     if (isset($menu[$CatId])) {
            echo "
      ";
               foreach ($menu[$CatId] as $ItemId => $ItemName)
               {
                echo "
    • ".$ItemName."";
                echo "
        ";
                        $query = "SELECT * FROM
                                vip_products p,
                                vip_products_description pd,
                                vip_products_to_categories p2c,
                                vip_categories c
                        WHERE
                                c.categories_status='1'
                                and p.products_status = '1'
                                and p.products_id = p2c.products_id
                                and p.products_id=pd.products_id
                                and p2c.categories_id = '".$ItemId."'
                                and c.parent_id = '".$CatId."'
                        ORDER by p.products_date_added";
                        $query = osDBquery($query);
                        while ($row1 = os_db_fetch_array($query)) {
                                //echo "
        ";
                                //print_r($row1);
                                //echo "
        ";
                                echo "
      • ".$row1['products_name']."
      • ";
                        }  
                   echo "
      ";
                echo "
    • ";
               }
              echo "
  • ";
     } else { echo "";}
    }
    {/php}


На выходе:

Получили что хотели, на не совсем так. Теперь я не могу попасть в раздел КАТЕГОРИИ, он то не кликабельный (я использую ява меню при клике на категорию выпадает вложенный UL), а это существенно и в ТЗ прописано.

Поэтому этот вариант мне не подходит, совсем. Будем работать с {$box_CATEGORIES}.

Идем в наш_сайт\themes\наш_шаблон\source\inc\show_category.inc.php. Проверяем что бы параметр $MaxLevel равен был 1, это значит, что по умолчанию будет показываться 1 уровень вложенности.
В том же файлике находим:
if ($old_level > $level) {

и после вставляем:
                        if ( isset($GLOBALS['cPath']) ) {
                            if ( !strpos($GLOBALS['cPath'], "_")===false ) {
                            $path = explode('_',$GLOBALS['cPath']);
                                $query = "SELECT * FROM
                                    vip_products p,
                                    vip_products_description pd,
                                    vip_products_to_categories p2c,
                                    vip_categories c
                                WHERE
                                    c.categories_status='1'
                                    and p.products_status = '1'
                                    and p.products_id = p2c.products_id
                                    and p.products_id=pd.products_id
                                    and p2c.categories_id = '".$path[1]."'
                                    and c.parent_id = '".$path[0]."'
                                ORDER by p.products_date_added";
                                $query = osDBquery($query);
                                $categories_string .= "
    ";
                                    while ($row1 = os_db_fetch_array($query)) {
                                        $categories_string .= "
  • ".$row1['products_name']."
  • ";
                                    }      
                                    $categories_string .= "
";
                            }
                        }

Итого: если есть параметр cPath (он показывает категорию текущую), то смотрим вложенная она, если да, то разбиваем и получаем айди категории и подкатегории. А дальше запрос - рисуем список.
Список товаров в категории ShopOS

Теперь, когда вы нажимаете на подкатегорию выпадает еще и список товаров. Оптимизируйте и ковыряйте -) Да и не забудьте в коде поменять префикс БД на свой.

UPD 02.09.11. для еще одного уровня + оптимизирован код.
вставить в оригинальный файл show_category.inc.php после ( $foo[$cid]['name'].$ProductsCount. ''; - 114 строчка)
                        if ($level == 3) {
                            if ( !empty($Aktiv)) {
                                //$categories_string .= $cid;
                                $query = "SELECT * FROM
                                    vip_products_to_categories p2c,
                                    vip_products p,
                                    vip_products_description pd
                                WHERE
                                    p2c.categories_id = '".$cid."'
                                    and p.products_status = '1'
                                    and p.products_id = p2c.products_id
                                    and p.products_id=pd.products_id
                                ORDER by p.products_date_added";
                                $query = osDBquery($query);
                                $categories_string .= "
    ";
                                    while ($row1 = os_db_fetch_array($query)) {
                                        $categories_string .= "
  • [url=/product_info.php?products_id={$row1[]".$row1['products_name']."[/url]";
                                    }      
                                    $categories_string .= "
";
                            }
                        }

Кнопки Мне нравится - Facebook & Vkontkte, +1 Google и кнопка Твитнуть #

От сегодня в подробном описании поста появились кнопки:
Кнопки Мне нравится - Facebook & Vkontkte, +1 Google и кнопка Твитнуть

Материальчик где генерировать кода:
http://vkontakte.ru/developers.php?o=-1&p=Like
http://developers.facebook.com/docs/reference/plugins/like/
https://services.google.com/fb/forms/plusonesignup/
http://twitter.com/goodies/tweetbutton

Вот так выглядит код на этом сайте:
В шапке (между тегами head):






В месте где сами кнопки:









Табы на Jquery #

Табы на Jquery

Самый просто из виденных мною способов построения Табов:
(function($) {
$(function() {

    $('ul.tabs').delegate('li:not(.current)', 'click', function() {
        $(this).addClass('current').siblings().removeClass('current')
            .parents('div.section').find('div.box').hide().eq($(this).index()).fadeIn(150);
    })

})
})(jQuery)

СМОТРЕТЬ / Скачать

Стена изображений на jQuery #

Стена изображений на jQuery

Красиво и оригинально. Расположение как и размеры изображений рандомные, после перезагрузки страницы порядок будет разный.
ДЕМО / СКАЧАТЬ

Запуск php в фоновом режиме #

Запуск php в фоновом режиме

Столкнулся с необходимостью запустить скрипт в фоновом режиме. Гугле подсказывает, что можно:

Если есть возможность использовать set_time_limit(), то можно попробовать применить следующую конструкцию:

ignore_user_abort(1);  // Игнорировать обрыв связи с браузером
set_time_limit(0);       // Время работы скрипта неограниченно
do{
   // Что хотим, то воротим..
     if (file_exists( 'stop.txt'  ))
      break;                //Остановка скрипта, работающего в фоновом режиме
} while( true );
?>

Если же нету, то можно использовать этот метод:

$start_time = microtime();                               // Узнаем время запуска скрипта
$start_array = explode(' ',$start_time);             // Разделяем секунды и миллисекунды
$start_time = $start_array[1] + $start_array[0]; // Сумируем секунды и миллисекунды получаем стартовое время скрипта
ignore_user_abort(1);                                      // Игнорировать обрыв связи с браузером
$max_exec = ini_get( 'max_execution_time' );   // Получаем максимальное время работы скрипта
do{
   // Что хотим, то воротим..
   $now_time = microtime();                             // Узнаем текущее время
   $now_array = explode(' ',$now_time);
   $now_time = $now_array[1] + $now_array[0];
   $exec_time = $now_time - $start_time;         // Вычитаем из текущего времени начальное начальное
      if (file_exists( 'stop.txt' ))
      break;                                                     // Остановка скрипта, работающего в фоновом режиме
} while($exec_time > ($max_exec - 5));           // Проверяем время работы, если до конца работы скрипта
                                                                    // осталось менее 5 секунд, завершаем работу цикла.
$http = fsockopen('site.ru', 80);                       // Запускаем этот же скрипт новым процессом и завершаем работу текущего
fputs($http, "GET http://site.ru/script.php HTTP/1.0\r\n");
fputs($http, "Host: site.ru\r\n");
fputs($http, "\r\n");
fclose($http);
?>

Вот и реализация фонового режима работы. Безболезненно остановить работу скрипта можно удалив stop.txt.

Пример ниже демонстрирует как можно запустить PHP скрипт "в фоновом режиме". Запуск скрипта инициируется запросом скрипта по HTTP, но выполнение скрипта не заканчивается при обрыве соединения. Может использоваться для выполнения служебных действий на стороне сервера при невозможности использования для этих целей системной утилиты cron.

function doSomthing()
{
    // here we do somthing on server side
}
ignore_user_abort(false);
if (ob_get_level() == 0)
    ob_start();
// redirect lient to some site or abort connecion
header("Location: http://www.example.com/");
ob_flush();
flush();
$counter = 1;
while (true)
{
    ob_flush();
    flush();
    sleep(1);
    doSomthing();
    $counter++;
    if ($counter == 30)
        break;
}
ob_end_flush();
?>

Вот такие дела, остановился все же на CRON'e без гемморно и по моему правильней всего -)

Секреты #