Files
gallery3/core/models/item.php
Bharat Mediratta 605d2de336 Lots of new stuff!
Replace theme HTML with *almost* the latest stuff from the
mockups.  (it doesn't include r18467 yet).

Our theme format is now modelled after WordPress / Habari's style
where you have one entry point per type (eg: album.php) which can
load up whatever parts it needs (eg: $theme->display("header"))

Created album and photo helpers which have create() functions
that form the base of our new API, along with tests for them.

Created our own version of the ORM_MPTT since the existing
versions were too buggy and unsupported to depend upon.  Only has
a minimal implementation so far, and the tests are not yet
committed.

Added path(), thumbnail_path() and resize_path() to Item_Model

Extended the scaffolding to allow you to add lots of
photos/albums into your hierarchy.

Deleted modules/mptt -- we're not going to use this anymore.
2008-11-04 21:24:42 +00:00

67 lines
2.0 KiB
PHP

<?php defined("SYSPATH") or die("No direct script access.");
/**
* Gallery - a web based photo album viewer and editor
* Copyright (C) 2000-2008 Bharat Mediratta
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or (at
* your option) any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
*/
class Item_Model extends ORM_MPTT {
protected $children = 'items';
public function is_album() {
return $this->type == 'album';
}
public function is_photo() {
return $this->type == 'photo';
}
private function _get_path() {
$paths = array();
foreach ($this->parents() as $parent) {
if ($parent->id > 1) {
$paths[] = $parent->name;
}
}
$path = implode($paths, "/");
if (!$this->saved) {
$path .= $this->name;
}
return $path;
}
public function path() {
return VARPATH . "albums/{$this->_get_path()}";
}
public function thumbnail_path() {
if ($this->is_album()) {
return VARPATH . "thumbnails/{$this->_get_path()}";
} else {
$pi = pathinfo(VARPATH . "thumbnails/{$this->_get_path()}");
return "{$pi['dirname']}/{$pi['filename']}_thumb.{$pi['extension']}";
}
}
public function resize_path() {
if ($this->is_album()) {
return VARPATH . "thumbnails/{$this->_get_path()}";
} else {
$pi = pathinfo(VARPATH . "thumbnails/{$this->_get_path()}");
return "{$pi['dirname']}/{$pi['filename']}_resize.{$pi['extension']}";
}
}
}