Вход Регистрация
Файл: Arhmobi_esdcms/photos/photos.php
Строк: 161
<?php

include_once '../sys/inc/start.php';
$doc = new document ();
$doc->title __('Фотоальбомы');


if (!empty(
$_GET ['id'])) {
    
$ank = new user((int) $_GET ['id']);
} else {
    
$ank $user;
}

if (!
$ank->group) {
    
$doc->access_denied(__('Ошибка пользователя'));
}

// папка фотоальбомов пользователей
$photos = new files(FILES '/.photos');
// папка альбомов пользователя
$albums_path FILES '/.photos/' $ank->id;

if (!@
is_dir($albums_path)) {
    if (!
$albums_dir $photos->mkdir($ank->nick$ank->id)) {
        
$doc->access_denied(__('Не удалось создать папку под фотоальбомы пользователя'));
    }
    
$albums_dir->group_show 0;
    
$albums_dir->group_write max($ank->group2);
    
$albums_dir->group_edit max($ank->group4);
    
$albums_dir->id_user $ank->id;
    unset(
$albums_dir);
}

$albums_dir = new files($albums_path);

if (empty(
$_GET ['album']) || !$albums_dir->is_dir($_GET ['album'])) {
    
$doc->err(__('Запрошеный альбом не существует'));
    
$doc->ret(__('К альбомам %s'$name), 'albums.php?id=' $ank->id);
    
header('Refresh: 1; url=albums.php?id=' $ank->id);
    exit();
}

$album_name = (string) $_GET ['album'];
$album = new files($albums_path '/' $album_name);
$doc->title $album->runame;

$doc->description __('Фотоальбом пользователя %s:%s'$ank->nick$album->runame);
$doc->keywords [] = $album->runame;
$doc->keywords [] = $ank->nick;

if (!empty(
$_GET ['act']) && $ank->id == $user->id) {
    switch (
$_GET ['act']) {
        case 
'prop' :
            
$doc->title .= ' - Параметры';

            if (!empty(
$_POST ['prop'])) {
                if (
$album->id_user $user->id) {

                    if (isset(
$_POST['group_show'])) {
                        
$album->group_show $_POST['group_show'];
                    }

                    
$album->runame text::input_text(@$_POST ['name']);
                    
$album->description text::input_text(@$_POST ['description']);
                    
$doc->msg(__('Альбом успешно переименован'));
                    
$doc->ret(__('Альбомы %s'$ank->nick), 'albums.php?id=' $ank->id);
                } else {
                    
$doc->err(__('Не удалось сменит название альбома'));
                    
$doc->ret(__('В альбом'), '?id=' $ank->id '&amp;album=' urlencode($album->name));
                    
$doc->ret(__('Альбомы %s'$ank->nick), 'albums.php?id=' $ank->id);
                }
            }

            
$form = new form(new url(null, array('act' => 'prop')));
            
$form->text('name''Название'$album->runame);
            
$form->textarea('description''Описание'$album->description);
            
$options = array();
            
$options [] = array('0'__('Всем'), $album->group_show == "0");
            
$options [] = array('1'__('Зарегистрированным'), $album->group_show == "1");
            
$form->select('group_show'__('Показывать папку:'), $options);
            
$form->button('Применить''prop');
            
$form->display();

            
$doc->ret(__('В альбом'), '?id=' $ank->id '&amp;album=' urlencode($album->name));
            exit();
        case 
'photo_add' :
            
$doc->title .= ' - ' __('Выгрузка фото');

            if (!empty(
$_FILES ['file'])) {
                if (
$_FILES ['file'] ['error']) {
                    
$doc->err(__('Ошибка при загрузке'));
                } elseif (!
$_FILES ['file'] ['size']) {
                    
$doc->err(__('Содержимое файла пусто'));
                } elseif (!
preg_match('#.jpe?g$#ui'$_FILES ['file'] ['name'])) {
                    
$doc->err(__('Неверное расширение файла'));
                } elseif (!
$img = @imagecreatefromjpeg($_FILES ['file'] ['tmp_name'])) {
                    
$doc->err(__('Файл не является изображением JPEG'));
                } elseif (@
imagesx($img) < 128) {
                    
$doc->err(__('Ширина изображения должна быть не менее 128 px'));
                } elseif (@
imagesy($img) < 128) {
                    
$doc->err(__('Высота изображения должна быть не менее 128 px'));
                } else {
                    if (
$files_ok $album->filesAdd(array($_FILES ['file'] ['tmp_name'] => $_FILES ['file'] ['name']))) {
                        
$files_ok [$_FILES ['file'] ['tmp_name']]->id_user $ank->id;
                        
$files_ok [$_FILES ['file'] ['tmp_name']]->group_edit max($ank->group$album->group_write2);

                        unset(
$files_ok);
                        
$doc->msg(__('Фотография "%s" успешно добавлена'$_FILES ['file'] ['name']));
                        
$q $db->prepare("SELECT * FROM `chit` WHERE `id_friend`  = ?  AND `confirm` = ? ");
                        
$q->execute(Array($user->id'1'));
                        while (
$f $q->fetch()) {
                            
$frend = new user((int) $f['id_user']);
                            
$msg = ("[user]{$user->id}[/user] добавил" . ($user->sex '' 'а') . " новую  [url=/photos/photos.php?id=$ank->id&album=$album->name&photo={$_FILES ['file'] ['name']}]фотографию[/url]");
                            
$res $db->prepare("INSERT INTO `mynews` (`id_user`, `id_kont`, `msg`, `time`) VALUES (?,?,?,?)");
                            
$res->execute(Array($user->id$frend->id$msgTIME));
                        }
                    } else {
                        
$doc->err(__('Не удалось сохранить выгруженный файл'));
                    }
                }
            }

            
$form = new form(new url(null, array('act' => 'photo_add')));
            
$form->file('file'__('Фотография') . ' (*.jpg)');
            
$form->button(__('Выгрузить'));
            
$form->display();

            
$doc->ret(__('В альбом'), '?id=' $ank->id '&amp;album=' urlencode($album->name));
            exit();
        case 
'delete' :
            
$doc->title .= ' - Удаление';

            if (!empty(
$_POST ['delete'])) {

                if (empty(
$_POST ['captcha']) || empty($_POST ['captcha_session']) || !captcha::check($_POST ['captcha'], $_POST ['captcha_session']))
                    
$doc->err(__('Проверочное число введено неверно'));
                elseif (
$album->delete()) {
                    
$doc->msg(__('Альбом успешно удален'));
                    
$doc->ret(__('Альбомы %s'$ank->nick), 'albums.php?id=' $ank->id);
                    
header('Refresh: 1; url=albums.php?id=' $ank->id '&' passgen());
                } else {

                    
$doc->err(__('Не удалось удалить альбом'));
                    
$doc->ret(__('В альбом'), '?id=' $ank->id '&amp;album=' urlencode($album->name));
                    
$doc->ret(__('Альбомы %s'$ank->nick), 'albums.php?id=' $ank->id);
                    
header('Refresh: 1; url=?id=' $ank->id '&album=' urlencode($album->name) . '&' passgen());
                }
                exit();
            }

            
$form = new form(new url(null, array('act' => 'delete')));
            
$form->captcha();
            
$form->button(__('Удалить альбом'), 'delete');
            
$form->display();

            
$doc->ret(__('В альбом'), '?id=' $ank->id '&amp;album=' urlencode($album->name));
            exit();
    } 
// switch
}

$list $album->getList('time_add:desc'); // получение содержимого папки альбома
$files $list ['files']; // получение только файлов

$pages = new pages(count($files));
$start $pages->my_start();
$end $pages->end();

$listing = new listing();
for (
$i $start$i $end && $i $pages->posts$i++) {
    
$post $listing->post();
    
$post->image $files [$i]->image();
    
$post->url "photo.php?id=$ank->id&amp;album=" urlencode($album->name) . "&amp;photo=" urlencode($files [$i]->name);
    
$post->title text::toValue($files [$i]->runame);

    if (
$comments $files [$i]->comments) {
        
$post->counter __('%s комментари' misc::number($comments'й''я''ев'), $comments);
    }

    if (
$properties $files [$i]->properties) {
        
// Параметры файла (только основное)
        
$post->content[] = $properties;
    }
}

$listing->display(__('Фотографии отсутствуют'));
$pages->display('?id=' $ank->id '&amp;album=' urlencode($album->name) . '&amp;'); // вывод страниц

if ($ank->id == $user->id) {
    
$doc->act(__('Выгрузить фото'), '?id=' $ank->id '&amp;album=' urlencode($album->name) . '&amp;act=photo_add');
    
$doc->act(__('Параметры'), '?id=' $ank->id '&amp;album=' urlencode($album->name) . '&amp;act=prop');
    
$doc->act(__('Удалить альбом'), '?id=' $ank->id '&amp;album=' urlencode($album->name) . '&amp;act=delete');
}

$doc->ret(__('Альбомы %s'$ank->nick), 'albums.php?id=' $ank->id);
Онлайн: 3
Реклама