aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjimmacfx <jimmacfx@4fa712ea-3c06-0410-9261-c11b4c06c003>2005-11-25 22:16:10 +0000
committerjimmacfx <jimmacfx@4fa712ea-3c06-0410-9261-c11b4c06c003>2005-11-25 22:16:10 +0000
commit4023001a68b3d85891ab744eb77e7b22a9dd8e3f (patch)
tree8ef9fadd91e07cae3bcc1284cc06a850f818168b
parent796ade427c4b26271d879d2c1f58def958d51568 (diff)
downloadoriginal-4023001a68b3d85891ab744eb77e7b22a9dd8e3f.tar.gz
original-4023001a68b3d85891ab744eb77e7b22a9dd8e3f.tar.bz2
import original 0.11
git-svn-id: https://forgesvn1.novell.com/svn/original/trunk@2 4fa712ea-3c06-0410-9261-c11b4c06c003
-rw-r--r--AUTHORS3
-rw-r--r--COPYING340
-rw-r--r--CVS/Entries9
-rw-r--r--CVS/Repository1
-rw-r--r--CVS/Root1
-rw-r--r--ChangeLog351
-rw-r--r--README28
-rw-r--r--REQUIREMENTS44
-rw-r--r--TODO7
-rw-r--r--convert/CVS/Entries6
-rw-r--r--convert/CVS/Repository1
-rw-r--r--convert/CVS/Root1
-rw-r--r--convert/Makefile44
-rwxr-xr-xconvert/gdk-pixbuf-convertbin0 -> 15595 bytes
-rw-r--r--convert/gdk-pixbuf-convert.c226
-rw-r--r--convert/gdk-pixbuf-convert.d80
-rwxr-xr-xconvert/imgconv46
-rwxr-xr-xconvert/webgallery-zenity.pl160
-rwxr-xr-xconvert/webgallery.pl154
-rw-r--r--logo.xcf.bz2bin0 -> 85758 bytes
-rw-r--r--www/CVS/Entries11
-rw-r--r--www/CVS/Repository1
-rw-r--r--www/CVS/Root1
-rw-r--r--www/bcg.pngbin0 -> 87 bytes
-rw-r--r--www/inc/.config.inc.php.swobin0 -> 12288 bytes
-rw-r--r--www/inc/CVS/Entries8
-rw-r--r--www/inc/CVS/Repository1
-rw-r--r--www/inc/CVS/Root1
-rw-r--r--www/inc/config.inc.php71
-rw-r--r--www/inc/exif.inc.php139
-rw-r--r--www/inc/footer.inc.php27
-rw-r--r--www/inc/funkce.inc.php96
-rw-r--r--www/inc/header.inc.php14
-rw-r--r--www/inc/javascript-eek.inc.php112
-rw-r--r--www/inc/javascript.inc.php51
-rw-r--r--www/inc/styles/CVS/Entries2
-rw-r--r--www/inc/styles/CVS/Repository1
-rw-r--r--www/inc/styles/CVS/Root1
-rw-r--r--www/inc/styles/default/CVS/Entries12
-rw-r--r--www/inc/styles/default/CVS/Repository1
-rw-r--r--www/inc/styles/default/CVS/Root1
-rw-r--r--www/inc/styles/default/bcg.pngbin0 -> 87 bytes
-rw-r--r--www/inc/styles/default/default.css285
-rw-r--r--www/inc/styles/default/left-16.pngbin0 -> 298 bytes
-rw-r--r--www/inc/styles/default/left.pngbin0 -> 523 bytes
-rw-r--r--www/inc/styles/default/logo-mini.pngbin0 -> 4163 bytes
-rw-r--r--www/inc/styles/default/minus.pngbin0 -> 291 bytes
-rw-r--r--www/inc/styles/default/plus.pngbin0 -> 556 bytes
-rw-r--r--www/inc/styles/default/right-16.pngbin0 -> 290 bytes
-rw-r--r--www/inc/styles/default/right.pngbin0 -> 522 bytes
-rw-r--r--www/inc/styles/default/title.pngbin0 -> 3434 bytes
-rw-r--r--www/inc/styles/default/zip.pngbin0 -> 539 bytes
-rw-r--r--www/inc/styles/gorilla/CVS/Entries7
-rw-r--r--www/inc/styles/gorilla/CVS/Repository1
-rw-r--r--www/inc/styles/gorilla/CVS/Root1
-rw-r--r--www/inc/styles/gorilla/gorilla.css258
-rw-r--r--www/inc/styles/gorilla/left.pngbin0 -> 1644 bytes
-rw-r--r--www/inc/styles/gorilla/minus.pngbin0 -> 1403 bytes
-rw-r--r--www/inc/styles/gorilla/plus.pngbin0 -> 1436 bytes
-rw-r--r--www/inc/styles/gorilla/right.pngbin0 -> 1661 bytes
-rw-r--r--www/inc/styles/gorilla/title.pngbin0 -> 2506 bytes
-rw-r--r--www/inc/styles/ie/ie.css8
-rw-r--r--www/inc/stylesheet.inc.css141
-rw-r--r--www/inc/www.class.inc.php210
-rw-r--r--www/index.php284
-rw-r--r--www/left.pngbin0 -> 1644 bytes
-rw-r--r--www/logo-mini.pngbin0 -> 4163 bytes
-rw-r--r--www/logo.pngbin0 -> 15635 bytes
-rw-r--r--www/minus.pngbin0 -> 1403 bytes
-rw-r--r--www/plus.pngbin0 -> 1436 bytes
-rw-r--r--www/right.pngbin0 -> 1661 bytes
-rw-r--r--www/top.pngbin0 -> 1631 bytes
-rw-r--r--www/zip.pngbin0 -> 1027 bytes
73 files changed, 3248 insertions, 0 deletions
diff --git a/AUTHORS b/AUTHORS
new file mode 100644
index 0000000..ee84f3b
--- /dev/null
+++ b/AUTHORS
@@ -0,0 +1,3 @@
+Jakub Steiner <jimmac@ximian.com> (original package, zenity-based frontend)
+Tuomas Kuosmanen <tigert@gimp.org> (Nautilus script)
+Larry Ewing <lewing@ximian.com> (gdk-pixbuf scaler)
diff --git a/COPYING b/COPYING
new file mode 100644
index 0000000..d60c31a
--- /dev/null
+++ b/COPYING
@@ -0,0 +1,340 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 2, June 1991
+
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.
+ 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The licenses for most software are designed to take away your
+freedom to share and change it. By contrast, the GNU General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users. This
+General Public License applies to most of the Free Software
+Foundation's software and to any other program whose authors commit to
+using it. (Some other Free Software Foundation software is covered by
+the GNU Library General Public License instead.) You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+this service if you wish), that you receive source code or can get it
+if you want it, that you can change the software or use pieces of it
+in new free programs; and that you know you can do these things.
+
+ To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have. You must make sure that they, too, receive or can get the
+source code. And you must show them these terms so they know their
+rights.
+
+ We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+ Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software. If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+ Finally, any free program is threatened constantly by software
+patents. We wish to avoid the danger that redistributors of a free
+program will individually obtain patent licenses, in effect making the
+program proprietary. To prevent this, we have made it clear that any
+patent must be licensed for everyone's free use or not licensed at all.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ GNU GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License applies to any program or other work which contains
+a notice placed by the copyright holder saying it may be distributed
+under the terms of this General Public License. The "Program", below,
+refers to any such program or work, and a "work based on the Program"
+means either the Program or any derivative work under copyright law:
+that is to say, a work containing the Program or a portion of it,
+either verbatim or with modifications and/or translated into another
+language. (Hereinafter, translation is included without limitation in
+the term "modification".) Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope. The act of
+running the Program is not restricted, and the output from the Program
+is covered only if its contents constitute a work based on the
+Program (independent of having been made by running the Program).
+Whether that is true depends on what the Program does.
+
+ 1. You may copy and distribute verbatim copies of the Program's
+source code as you receive it, in any medium, provided that you
+conspicuously and appropriately publish on each copy an appropriate
+copyright notice and disclaimer of warranty; keep intact all the
+notices that refer to this License and to the absence of any warranty;
+and give any other recipients of the Program a copy of this License
+along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and
+you may at your option offer warranty protection in exchange for a fee.
+
+ 2. You may modify your copy or copies of the Program or any portion
+of it, thus forming a work based on the Program, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+ a) You must cause the modified files to carry prominent notices
+ stating that you changed the files and the date of any change.
+
+ b) You must cause any work that you distribute or publish, that in
+ whole or in part contains or is derived from the Program or any
+ part thereof, to be licensed as a whole at no charge to all third
+ parties under the terms of this License.
+
+ c) If the modified program normally reads commands interactively
+ when run, you must cause it, when started running for such
+ interactive use in the most ordinary way, to print or display an
+ announcement including an appropriate copyright notice and a
+ notice that there is no warranty (or else, saying that you provide
+ a warranty) and that users may redistribute the program under
+ these conditions, and telling the user how to view a copy of this
+ License. (Exception: if the Program itself is interactive but
+ does not normally print such an announcement, your work based on
+ the Program is not required to print an announcement.)
+
+These requirements apply to the modified work as a whole. If
+identifiable sections of that work are not derived from the Program,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works. But when you
+distribute the same sections as part of a whole which is a work based
+on the Program, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Program.
+
+In addition, mere aggregation of another work not based on the Program
+with the Program (or with a work based on the Program) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+ 3. You may copy and distribute the Program (or a work based on it,
+under Section 2) in object code or executable form under the terms of
+Sections 1 and 2 above provided that you also do one of the following:
+
+ a) Accompany it with the complete corresponding machine-readable
+ source code, which must be distributed under the terms of Sections
+ 1 and 2 above on a medium customarily used for software interchange; or,
+
+ b) Accompany it with a written offer, valid for at least three
+ years, to give any third party, for a charge no more than your
+ cost of physically performing source distribution, a complete
+ machine-readable copy of the corresponding source code, to be
+ distributed under the terms of Sections 1 and 2 above on a medium
+ customarily used for software interchange; or,
+
+ c) Accompany it with the information you received as to the offer
+ to distribute corresponding source code. (This alternative is
+ allowed only for noncommercial distribution and only if you
+ received the program in object code or executable form with such
+ an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for
+making modifications to it. For an executable work, complete source
+code means all the source code for all modules it contains, plus any
+associated interface definition files, plus the scripts used to
+control compilation and installation of the executable. However, as a
+special exception, the source code distributed need not include
+anything that is normally distributed (in either source or binary
+form) with the major components (compiler, kernel, and so on) of the
+operating system on which the executable runs, unless that component
+itself accompanies the executable.
+
+If distribution of executable or object code is made by offering
+access to copy from a designated place, then offering equivalent
+access to copy the source code from the same place counts as
+distribution of the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+ 4. You may not copy, modify, sublicense, or distribute the Program
+except as expressly provided under this License. Any attempt
+otherwise to copy, modify, sublicense or distribute the Program is
+void, and will automatically terminate your rights under this License.
+However, parties who have received copies, or rights, from you under
+this License will not have their licenses terminated so long as such
+parties remain in full compliance.
+
+ 5. You are not required to accept this License, since you have not
+signed it. However, nothing else grants you permission to modify or
+distribute the Program or its derivative works. These actions are
+prohibited by law if you do not accept this License. Therefore, by
+modifying or distributing the Program (or any work based on the
+Program), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+ 6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the
+original licensor to copy, distribute or modify the Program subject to
+these terms and conditions. You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties to
+this License.
+
+ 7. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Program at all. For example, if a patent
+license would not permit royalty-free redistribution of the Program by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Program.
+
+If any portion of this section is held invalid or unenforceable under
+any particular circumstance, the balance of the section is intended to
+apply and the section as a whole is intended to apply in other
+circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system, which is
+implemented by public license practices. Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+ 8. If the distribution and/or use of the Program is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Program under this License
+may add an explicit geographical distribution limitation excluding
+those countries, so that distribution is permitted only in or among
+countries not thus excluded. In such case, this License incorporates
+the limitation as if written in the body of this License.
+
+ 9. The Free Software Foundation may publish revised and/or new versions
+of the General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+Each version is given a distinguishing version number. If the Program
+specifies a version number of this License which applies to it and "any
+later version", you have the option of following the terms and conditions
+either of that version or of any later version published by the Free
+Software Foundation. If the Program does not specify a version number of
+this License, you may choose any version ever published by the Free Software
+Foundation.
+
+ 10. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, write to the author
+to ask for permission. For software which is copyrighted by the Free
+Software Foundation, write to the Free Software Foundation; we sometimes
+make exceptions for this. Our decision will be guided by the two goals
+of preserving the free status of all derivatives of our free software and
+of promoting the sharing and reuse of software generally.
+
+ NO WARRANTY
+
+ 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+ 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGES.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+ Gnomovision version 69, Copyright (C) year name of author
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, the commands you use may
+be called something other than `show w' and `show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary. Here is a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+ `Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+ <signature of Ty Coon>, 1 April 1989
+ Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs. If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library. If this is what you want to do, use the GNU Library General
+Public License instead of this License.
diff --git a/CVS/Entries b/CVS/Entries
new file mode 100644
index 0000000..cb873e4
--- /dev/null
+++ b/CVS/Entries
@@ -0,0 +1,9 @@
+/AUTHORS/1.1.1.1/Tue Oct 21 06:45:08 2003//
+/COPYING/1.1.1.1/Tue Oct 21 06:45:11 2003//
+/README/1.1.1.1/Tue Oct 21 06:45:00 2003//
+/REQUIREMENTS/1.1.1.1/Tue Oct 21 06:45:00 2003//
+/logo.xcf.bz2/1.1.1.1/Tue Oct 21 06:45:08 2003//
+D/convert////
+D/www////
+/TODO/1.2/Sun Oct 26 15:07:52 2003//
+/ChangeLog/1.26/Sun Nov 2 18:58:17 2003//
diff --git a/CVS/Repository b/CVS/Repository
new file mode 100644
index 0000000..4b48dee
--- /dev/null
+++ b/CVS/Repository
@@ -0,0 +1 @@
+original
diff --git a/CVS/Root b/CVS/Root
new file mode 100644
index 0000000..16bd216
--- /dev/null
+++ b/CVS/Root
@@ -0,0 +1 @@
+:ext:jimmac@cvs.tuxfamily.org:/cvsroot/original
diff --git a/ChangeLog b/ChangeLog
new file mode 100644
index 0000000..a712fa0
--- /dev/null
+++ b/ChangeLog
@@ -0,0 +1,351 @@
+2004-02-16 Jakub Steiner <jimmac@ximian.com>
+
+ * www/inc/header.inc.php:
+ * www/inc/javascript.inc.php:
+ * www/inc/www.class.inc.php:
+ * www/inc/config.inc.php: make stylesheet selectable in the
+ document (javascript dependent). Set a cookie so it gets stored
+ across session.
+
+ * www/inc/stylesheet/ie/ie.css: dummy (doesn't crash IE)
+ * www/inc/stylesheet/default/default.css: doesn't jump in
+ thumbnail view
+ * www/inc/stylesheet/gorilla/gorilla.css: implemented centering
+ of the image properly. First, I hacked up a gross javascript
+ kludge then figured a trivial solution with CSS. ehm
+ * www/index.php: solve tall images overlapping description by a
+ small inline style="" definition. This breaks CSS2 validity,
+ though?
+
+2004-01-10 Colin Marquardt <colin@marquardt-home.de>
+
+ * convert/webgallery-zenity.pl: Quote $arg in system calls to
+ handle filenames with spaces.
+
+ * www/index.php,
+ www/inc/header.inc.php,
+ www/inc/footer.inc.php,
+ www/inc/www.class.inc.php,
+ www/inc/funkce.inc.php:
+ Make it validate with W3C.
+ Make resulting HTML more readable.
+
+2003-12-15 Colin Marquardt <colin@marquardt-home.de>
+
+ * convert/webgallery-zenity.pl: Set mtime of web-gallery directory
+ to the mtime of the first image with a good-looking time stamp.
+ Skip directories and non-image files.
+ Set autoflush for PROGRESS in a more readable way.
+ (make_dirs): Better error messages (show them to the user).
+
+2003-12-07 Colin Marquardt <colin@marquardt-home.de>
+
+ * convert/webgallery-zenity.pl: Use gdk-pixbuf-convert if
+ available, otherwise convert. Make error messages more in spirit
+ of the HIG (zenity doesn't support Pango markup though?). Some
+ cleanup.
+
+2003-11-02 Jakub Steiner <jimmac@ximian.com>
+
+ patch from Colin Marquardt <colin@marquardt-home.de>:
+
+ * convert/gdk-pixbuf-convert.c: Add '-quality' switch.
+
+ * convert/webgallery-zenity.pl: Use new '-quality' switch.
+ Make error messages nicer.
+
+2003-11-01 Jakub Steiner <jimmac@ximian.com>
+
+ * www/index.php
+ * www/inc/exif.inc.php
+ * www/inc/funkce.inc.php
+ * www/inc/www.class.inc.php: stylesheet & $gallery_dir updates
+
+ * www/inc/styles/gorilla/left.png
+ * www/inc/styles/gorilla/right.png
+ * www/inc/styles/gorilla/gorilla.css: stylesheet updates
+
+ * www/inc/styles/default/bcg.png
+ * www/inc/styles/default/default.css
+ * www/inc/styles/default/left-16.png
+ * www/inc/styles/default/left.png
+ * www/inc/styles/default/logo-mini.png
+ * www/inc/styles/default/minus.png
+ * www/inc/styles/default/plus.png
+ * www/inc/styles/default/right-16.png
+ * www/inc/styles/default/right.png
+ * www/inc/styles/default/title.png
+ * www/inc/styles/default/zip.png: default stylesheet (WIP)
+
+2003-10-27 Jakub Steiner <jimmac@ximian.com>
+
+ * www/inc/styles/gorilla/gorilla.css
+ * www/inc/styles/gorilla/minus.png
+ * www/inc/styles/gorilla/plus.png
+ * www/inc/styles/gorilla/title.png
+ * www/inc/header.inc.php
+ * www/index.php: more stylesheet work. _Some_ issues. Like
+ killing IE6 *ehm* ;)
+
+ I'll concentrate on doing the original stylesheet first and let
+ my gorilla playground there for a while.
+
+2003-10-27 Jakub Steiner <jimmac@ximian.com>
+
+ * www/index.php:
+ * www/inc/funkce.inc.php: applied a patch from Mark, fixing
+ issues with local relative paths
+
+ Also fixed archive listing in the gallery thumbnail view.
+
+2003-10-27 Jakub Steiner <jimmac@ximian.com>
+
+ * www/index.php: remove legacy style definitions
+
+2003-10-27 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/index.php:
+ (Re)Add year sorting when generating the index page.
+
+2003-10-26 Jakub Steiner <jimmac@ximian.com>
+
+ * www/index.php
+ * www/inc/config.inc.php
+ * www/inc/footer.inc.php
+ * www/inc/funkce.inc.php
+ * www/inc/header.inc.php
+ * www/inc/www.class.inc.php: start breaking style and document
+ structure apart. There will be multiple styles to choose from,
+ including a plaintext one. The navigation and titlebar artwork
+ will be implemented in CSS eventually so no php-fu for this
+ will be required.
+
+ Because of this, the plaintext config option will go, since
+ this will all be defined by using a specific stylesheet.
+
+ Cleaned up the navigation() function.
+
+ Header and footer are unfinished.
+
+ * www/inc/stylesheet.inc.css: removed global stylesheet
+ * www/inc/styles/gorilla/gorilla.css: sample Gorilla stylesheet.
+ It will not be the default. It's just something to start with.
+ The existing artwork will go to the stylesheet directory.
+
+2003-10-26 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/index.php:
+ Change datefile format in expectance
+ of supporting sorting by date of the
+ month.
+
+2003-10-26 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/inc/config.inc.php:
+ Fix comment for $gallery_dir
+
+2003-10-26 Jakub Steiner <jimmac@ximian.com>
+
+ * www/index.php:
+ * www/inc/www.class.inc.php:
+ * www/inc/funkce.inc.php: implement $gallery_dir correctly
+
+2003-10-26 Jakub Steiner <jimmac@ximian.com>
+
+ * www/inc/config.inc.php: get rid of old gallery listing
+
+ * www/inc/www.class.inc.php: rename the SortedDir() function to
+ be the constructor (easier-to-read code).
+
+ * www/index.php: used spaces instead of tabs, the indentation
+ looked weird (3 spaces == 1 tab)
+
+2003-10-26 Jakub Steiner <jimmac@ximian.com>
+
+ * www/inc/www.class.inc.php:
+ * www/index.php: remove old unused classes, start renaming
+ cz>en variables
+
+ * TODO: prepare for the stylesheet stuff
+
+2003-10-26 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/inc/config.inc.php:
+ Remove the trailing / from $gallery_dir
+
+ * www/index.php:
+ Implement using $gallery_dir preference
+
+ * www/galleries:
+ Directory Added; new location for galleries
+
+2003-10-26 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/inc/config.inc.php:
+ Add gallery directory preference; still need
+ to make index.php use this preference.
+
+2003-10-25 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/index.php:
+ Fix include() and require() statements so that they work
+ on more php configurations.
+
+2003-10-25 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/inc/config.inc.php:
+ Turn off EXIF retreival by default
+
+2003-10-25 Colin Marquardt <colin@marquardt-home.de>
+
+ * www/inc/config.inc.php: Set version to "0.7-cvs".
+ Make format more customization friendly.
+
+ * www/inc/exif.inc.php: Quote filename given to exec in case there
+ are spaces in the path.
+
+ * www/inc/config.inc.php: Add examples for jhead.
+
+ * www/inc/exif.inc.php: Use trim() for comparisons, this makes it
+ work with jhead as EXIF extractor.
+
+2003-10-24 Colin Marquardt <colin@marquardt-home.de>
+
+ * www/inc/www.class.inc.php: New class SortDir with SortedDir()
+ and Read() functions. (patch by Markus Ulbricht, thanks)
+
+ * www/index.php: Use SortedDir() function. (patch by Markus Ulbricht)
+
+2003-10-24 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/index.php:
+ Fix navigation bar so it works with register_globals off
+
+2003-10-24 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/inc/header.inc.php:
+ Use Same header for all pages
+
+ * www/index.php:
+ Add heirarchy navigation bar
+
+2003-10-24 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/index.php:
+ Fix new sorting algorithm to show newest galleries first
+
+2003-10-24 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/index.php:
+ Add the ability to use date.txt in each gallery to specify
+ the date for that gallery.
+
+2003-10-23 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ * www/inc/footer.inc.php:
+ * www/inc/header.inc.php:
+ ADDED; Make the header image a link to the root of the site
+ instead of the Original Home Page.
+
+ * www/index.php:
+ Modified to use new header and footer include files;
+ Added comments to sepporate different pages
+
+2003-10-22 Colin Marquardt <colin@marquardt-home.de>
+
+ * www/index.php:
+ * www/inc/config.inc.php:
+ * www/inc/exif.inc.php:
+ * www/inc/funkce.inc.php:
+ * www/inc/www.class.inc.php:
+
+ Make it work with register_globals = Off in php.ini.
+
+2003-10-22 Colin Marquardt <colin@marquardt-home.de>
+
+ * convert/Makefile (uninstall): New target.
+
+2003-10-21 Colin Marquardt <colin@marquardt-home.de>
+
+ * convert/gdk-pixbuf-convert.c: #include
+ <gdk-pixbuf/gdk-pixbuf.h>, not local file.
+ (main): Add meaningful usage text.
+
+ * convert/Makefile: New file.
+
+2003-10-21 Mark Finlay <sisob@tuxfamilyDOTorg>
+
+ Initial Checkin of Original to CVS
+
+2003-08-22 Jakub Steiner <jimmac@ximian.com>
+
+ * convert/webgallery-zenity.pl: modification of Tuomas' script.
+ Uses gnome2's zenity for progress bars, no gtk-perl magic
+ * convert/gdk-pixbuf-convert.c: Larry Ewing's pixbuf-based
+ scaler. This thing is fast!
+
+2002-11-19 Jakub Steiner <jimmac@ximian.com>
+
+ * convert/imgconv:
+ * convert/webgallery.pl: go back to ImageMagcik. It keeps EXIF
+ info while scaling, jpeg thumbnails
+ * www/index.php, www/inc/config.inc.php, www/inc/exif.inc.php:
+ - nicer index
+ - jpeg thumbnail support
+ - don't show EXIF mode switch when no EXIF info available
+ - fix portrait thumbnail scaling (should work fo most aspect
+ ratios now)
+ - previous/next image thumbnails (in image mode)
+ - Mozilla's link navigation (First, Previous, Next, Last, Top)
+ * www/left.png, right.png, top.png, plus.png, minus.png: new icons (from
+ gorilla)
+ * logo.xcf.bz2, www/logo.png, www/logo-mini.png: pretty logo
+
+2002-04-01 Jakub Steiner <jimmac@ximian.com>
+
+ * convert/imgconv:
+ * convert/webgallery.pl: use netpbm instead of ImageMagick;
+ imgconv now uses the same subdir as webgallery.pl
+
+ * www/index.php, www/inc/config.inc.php: portrait thumbnails are now the
+ same height as the landscape ones. Also incorporated suggestion from
+ Eduardo Pérez <100018135@alumnos.uc3m.es> to support ISO 8601
+ date format instead of the US format.
+
+ And last but not least the imgconv has a commented-out line to
+ tar up or zip the HQ or MQ images. index.php links to those in
+ the thumbnail view if you have them uploaded. The minithumbnail
+ view also has a small floppy icon (zip.png) for the HQ version.
+
+
+2001-10-27 Jakub Steiner <jimmac@ximian.com>
+
+ * www/inc/config.inc.php:
+ * www/inc/exif.inc.php: php4 exif handling (untested); also added
+ config option to have fixed thumbnails (looks better on
+ portrait photos)
+ * convert/webgallery.pl: use nautilus metafile to get comments
+
+2001-10-16 Jakub Steiner <jimmac@ximian.com>
+
+ * www/index.php: mini thumbnails
+ * www/inc/exif.inc.php: EXIF stuff (using Metacam), check
+ REQUIREMENTS
+
+2001-04-14 Jakub Steiner <jimmac@ximian.com>
+
+ * REQUIREMENTS: Imagemagick, perl, gtk-perl, bash ;)
+ * convert/webgallery.pl: Tigert's Nautilus web-gallery
+ script for Nautilus. It simply rocks!
+ * *.png: I accidentaly left the gif images in the
+ distribution
+ * index.php: check for mq and hq dirs before creating a link
+
+
+16.10.2000 - few configuration addditions
+ - dropped nasty GIF format for the navigation
+ (1bit mask is screwed under NN4, but its CSS support
+ is so crap, so that the default theme is unusable for it)
+ also imgconv is using png fro thumbnails (64 colors should
+ be enough for everyone (tm))
+15.10.2000 - first public release
diff --git a/README b/README
new file mode 100644
index 0000000..efb7356
--- /dev/null
+++ b/README
@@ -0,0 +1,28 @@
+This package includes two separate applications. In the www dir, there is the
+PHP frontend app, the convert dir includes a simple (too simple i guess) script
+that converts your wildcard of images into three subdirs in the current
+directory. You can easily create and upload all images using:
+
+ mkdir temp
+ cd $_
+ /path/to/imgconv *.png *.gif *.{jpeg,jpg}
+ scp -rp ./web-gallery me@my_server:web_dir/gallery_name
+
+and that's it.
+
+Tuomas Kuosmannen (tigert@gimp.org) has created a Nautilus script to create
+"original" galleries (check the REQUIREMENTS file). Just copy the
+convert/webgallery.pl file to ~/.gnome2/nautilus-scripts and make sure it's got
+the execute bit set.
+
+# UPDATE
+
+ Apart from using netpbm package (http://sourceforge.net/projects/netpbm/) for
+ scaling images, the new webgallery-zenity.pl script uses Larry Ewing's
+ gdk-pixbuf-based scaler. See REQUIREMENTS for details.
+
+ Latest versions of the tools can be found at
+ http://jimmac.musichall.cz/original.php3
+
+--
+Jakub 'Jimmac' Steiner <jimmac@linux.com>
diff --git a/REQUIREMENTS b/REQUIREMENTS
new file mode 100644
index 0000000..119c570
--- /dev/null
+++ b/REQUIREMENTS
@@ -0,0 +1,44 @@
+The web backend requires to have a PHP scripting engine running on
+your web server.
+
+There are two scripts doing the scaling work. convert/imgconv is a plain
+bash script using Imagemagick to generate thumbnails and scaling images.
+You can get Imagemagick at http://www.imagemagick.org/.
+
+# UPDATES #
+
+* netpbm
+ ------
+ You can use netpbm tools instead of ImageMagick for better speed. You can
+ grab netpbm at http://sourceforge.net/projects/netpbm/ but ususally your
+ distro ships with it already. My YDL distro has all the toos in netpbm-progs
+ package.
+
+* webgallery.pl
+ -------------
+
+ Tuomas Kuosmannen created a nautilus script that operates on selection
+ of images. It's way cooler than the bash script. Because the operation
+ can take a while, it has a nifty progressbar. The script itself is in
+ Perl, so you obviously need a functiuoning installation of Perl. For the
+ progressbar to work, you need gtk-perl bindings. You can get them at
+ ftp://ftp.gtk.org. Nautilus is a GUI file manager that rocks for photo
+ management. you can grab it at http://www.eazel.com.
+
+* webgallery-zenity.pl
+ --------------------
+
+ I hacked up Tuomas' script to use only gnome's zenity for the progress bars,
+ so there's no more gtk-perl dependency. Also this script uses Larry Ewing's
+ cool gdk-pixbuf scaler. It is an alternative to ImageMagick's convert
+ (sharing the basic commandline parameters) that discards EXIF information
+ (yet), but is 5 to 8 times as fast. You can really tell on large galleries.
+ You can find both at the convert/ directory. Instructions how to compile
+ gdk-pixbuf-convert.c are included in the file header.
+
+
+If you wan't to have advanced EXIF information for your photos, make sure you
+use a recent ImageMagick so that convert doesn't throw away this info when
+scaling down. Also grab Metacam
+(http://www.cheeseplant.org/~daniel/pages/metacam.html) and configure the path
+to it in inc/config.inc.php.
diff --git a/TODO b/TODO
new file mode 100644
index 0000000..83b0280
--- /dev/null
+++ b/TODO
@@ -0,0 +1,7 @@
+- editable image comments (in php, not using nautilus metadata as ATM)
+- mysql logging (how many people seen particular picture, rating etc) / optional
+- default setting for quality (LQ/MQ/HQ)
+
+
+Jimmac: * make an XHTML document with external CSS stylesheet(s)
+ * get rid of czech comments and variable names
diff --git a/convert/CVS/Entries b/convert/CVS/Entries
new file mode 100644
index 0000000..c0db717
--- /dev/null
+++ b/convert/CVS/Entries
@@ -0,0 +1,6 @@
+/Makefile/1.2/Thu Oct 23 07:35:22 2003//
+/imgconv/1.1.1.1/Tue Oct 21 06:45:11 2003//
+/webgallery.pl/1.1.1.1/Tue Oct 21 06:45:11 2003//
+/gdk-pixbuf-convert.c/1.3/Sun Nov 2 18:57:35 2003//
+/webgallery-zenity.pl/1.2/Sun Nov 2 18:57:35 2003//
+D
diff --git a/convert/CVS/Repository b/convert/CVS/Repository
new file mode 100644
index 0000000..4bbc3e5
--- /dev/null
+++ b/convert/CVS/Repository
@@ -0,0 +1 @@
+original/convert
diff --git a/convert/CVS/Root b/convert/CVS/Root
new file mode 100644
index 0000000..16bd216
--- /dev/null
+++ b/convert/CVS/Root
@@ -0,0 +1 @@
+:ext:jimmac@cvs.tuxfamily.org:/cvsroot/original
diff --git a/convert/Makefile b/convert/Makefile
new file mode 100644
index 0000000..e350747
--- /dev/null
+++ b/convert/Makefile
@@ -0,0 +1,44 @@
+PREFIX = /usr/local
+
+GTKCFLAGS = `pkg-config --cflags gtk+-2.0`
+GTKLDFLAGS += `pkg-config --libs gtk+-2.0`
+GDKPIXBUFCFLAGS = `pkg-config --cflags gdk-pixbuf-2.0`
+GDKPIXBUFLDFLAGS += `pkg-config --libs gdk-pixbuf-2.0`
+
+CPPFLAGS = $(GTKCFLAGS) -D_GNU_SOURCE
+ifeq ($(DEBUG),yes)
+CFLAGS += -O2 -g
+LDFLAGS = -g #-lefence
+else
+CFLAGS += -Os -fomit-frame-pointer
+endif
+CFLAGS += -Wall
+CPPFLAGS += -DPACKAGE=\"$(PACKAGE)\" -DPREFIX=\"$(PREFIX)\" -DPACKAGE_LOCALE_DIR=\"$(PREFIX)/share/locale\"
+CFLAGS += -MD
+
+MEMBERS = gdk-pixbuf-convert
+LIB_MEMBERS =
+
+OBJS = $(patsubst %,%.o,$(MEMBERS))
+SOURCES = $(patsubst %,%.c,$(MEMBERS) $(LIB_MEMBERS))
+LIB_OBJS = $(patsubst %,%.o,$(LIB_MEMBERS))
+LIB_SOURCES = $(patsubst %,%.c,$(LIB_MEMBERS))
+
+DEPS = $(patsubst %,%.d,$(MEMBERS) $(LIB_MEMBERS))
+
+
+all: gdk-pixbuf-convert
+
+gdk-pixbuf-convert: $(OBJS)
+ $(CC) -o $@ $^ $(GDKPIXBUFCFLAGS) $(GDKPIXBUFLDFLAGS) $(LDFLAGS) -L.
+
+clean:
+ rm -f $(MEMBERS) $(OBJS) $(DEPS)
+
+install: all
+ mkdir -p $(PREFIX)/bin
+ install -s $(MEMBERS) $(PREFIX)/bin/
+
+uninstall:
+ $(RM) $(PREFIX)/bin/$(MEMBERS)
+
diff --git a/convert/gdk-pixbuf-convert b/convert/gdk-pixbuf-convert
new file mode 100755
index 0000000..d6943b1
--- /dev/null
+++ b/convert/gdk-pixbuf-convert
Binary files differ
diff --git a/convert/gdk-pixbuf-convert.c b/convert/gdk-pixbuf-convert.c
new file mode 100644
index 0000000..2bdbeca
--- /dev/null
+++ b/convert/gdk-pixbuf-convert.c
@@ -0,0 +1,226 @@
+/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
+
+/*
+ * gdk-pixbuf-convert.c gdk pixbuf replacement for convert geometry commands
+ *
+ * Copyright (C) 2003 Ximian Inc.
+ *
+ * Author: Larry Ewing <lewing@ximian.com>
+ *
+ * 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+/*
+ * build with
+ * gcc `pkg-config --cflags gdk-pixbuf-2.0` gdk-pixbuf-convert.c -o gdk-pixbuf-convert `pkg-config --libs gdk-pixbuf-2.0`
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <string.h>
+#include <gdk-pixbuf/gdk-pixbuf.h>
+#include <glib-object.h>
+
+#define d(x) x
+
+typedef enum {
+ SAVE_JPG,
+ SAVE_PNG
+} OutputType;
+
+GdkPixbuf *
+scale (GdkPixbuf *src, char *geom)
+{
+ GdkPixbuf *dest = NULL;
+ char *s, *e;
+ guint w;
+ guint h;
+ guint src_w, dest_w;
+ guint src_h, dest_h;
+ double scale_w = 1.0;
+ double scale_h = 1.0;
+ gboolean force = FALSE;
+
+ src_w = gdk_pixbuf_get_width (src);
+ src_h = gdk_pixbuf_get_height (src);
+
+ /* d(printf ("%d %d ", src_w, src_h);) */
+
+ s = e = geom;
+
+ w = strtol (s, &e, 10);
+ /* d(printf ("%d ", w);) */
+ if (e != s) {
+ scale_w = w / (double)src_w;
+ } else {
+ w = 100;
+ }
+
+
+ if (*e == 'x')
+ e++;
+ else
+ return NULL;
+
+ s = e;
+
+ h = strtol (s, &e, 10);
+ /* d(printf ("%d ", h);) */
+ if (e != s) {
+ scale_h = h / (double)src_h;
+ } else {
+ h = 100;
+ }
+
+ if (*e == '%') {
+ scale_h = h / 100.0;
+ scale_w = w / 100.0;
+ e++;
+ }
+
+ /* d(printf ("%f %f\n", scale_w, scale_h);) */
+
+ while (*e) {
+ switch (*e) {
+ case '!':
+ force = TRUE;
+ break;
+ case '>':
+ if (scale_w >= 1.0 && scale_h >= 1.0)
+ scale_w = scale_h = 1.0;
+ break;
+ case '<':
+ if (scale_w < 1.0 || scale_h <= 1.0)
+ scale_w = scale_h = 1.0;
+ break;
+ default:
+ break;
+ }
+ e++;
+ }
+
+ if (!force) {
+ /* Keep aspect ratio */
+ scale_w = scale_h = MIN (scale_h, scale_w);
+ }
+
+ dest_w = (int)(src_w * scale_w + 0.5);
+ dest_h = (int)(src_h * scale_h + 0.5);
+
+ /* printf ("%dx%d\n", dest_w, dest_h); */
+
+ /* dest = gdk_pixbuf_scale_simple (src, dest_w, dest_h, GDK_INTERP_BILINEAR);*/
+ dest = gdk_pixbuf_scale_simple (src, dest_w, dest_h, GDK_INTERP_HYPER);
+
+ return dest;
+}
+
+OutputType
+get_filetype (char *filename)
+{
+ gint len = strlen (filename);
+
+ if (len > 4 && g_ascii_strncasecmp (filename + len - 4, ".png", 4)== 0)
+ return SAVE_PNG;
+ else
+ return SAVE_JPG;
+}
+
+int
+convert (char *geom, char *quality, char *sfile, char *dfile)
+{
+ GdkPixbuf *src;
+ GdkPixbuf *dest;
+ GError *error = NULL;
+
+ src = gdk_pixbuf_new_from_file (sfile, &error);
+
+ if (!src) {
+ fprintf (stderr, "Unable to open input file");
+ return 1;
+ }
+
+ if (geom) {
+ dest = scale (src, geom);
+ } else {
+ dest = src;
+ g_object_ref (dest);
+ }
+
+ if (!dest)
+ return 1;
+
+ unlink (dfile);
+ if (get_filetype (dfile) == SAVE_JPG)
+ gdk_pixbuf_save (dest, dfile, "jpeg", &error,
+ "quality", quality, NULL);
+ else
+ gdk_pixbuf_save (dest, dfile, "png", &error, NULL);
+
+ g_object_unref (src);
+ g_object_unref (dest);
+
+ if (error) {
+ return 1;
+ }
+
+ return 0;
+}
+
+int
+main (int argc, char **argv)
+{
+ char *dfile;
+ char *sfile;
+ char *geom = NULL;
+ char *quality = "100";
+
+ g_type_init ();
+
+ if (argc > 4) {
+ int i = 1;
+ if (!g_ascii_strcasecmp (argv[i], "-geometry")) {
+ i++;
+ geom = argv[i++];
+ if (argc < 5)
+ goto usage;
+ }
+ if (!g_ascii_strcasecmp (argv[i], "-quality")) {
+ i++;
+ quality = argv[i++];
+ if (argc < 7)
+ goto usage;
+ if ((atoi(quality) < 0) || (atoi(quality) > 100)) {
+ g_print ("Value for '-quality' must be in range 0-100!\n");
+ goto usage;
+ }
+ }
+ sfile = argv[i++];
+ dfile = argv[i++];
+ } else {
+ goto usage;
+ }
+
+ return convert (geom, quality, sfile, dfile);
+
+ usage:
+ g_print ("Usage:\n");
+ g_print (" gdk-pixbuf-convert -geometry <X>x<Y> [-quality <0-100>] <input> <output>\n");
+ g_print ("\n");
+ g_print ("Example:\n");
+ g_print (" gdk-pixbuf-convert -geometry 120x120 -quality 75 foo.jpg bar.jpg\n");
+ exit (2);
+}
diff --git a/convert/gdk-pixbuf-convert.d b/convert/gdk-pixbuf-convert.d
new file mode 100644
index 0000000..f0e1e76
--- /dev/null
+++ b/convert/gdk-pixbuf-convert.d
@@ -0,0 +1,80 @@
+gdk-pixbuf-convert.o: gdk-pixbuf-convert.c /usr/include/stdio.h \
+ /usr/include/features.h /usr/include/sys/cdefs.h \
+ /usr/include/gnu/stubs.h \
+ /usr/lib/gcc-lib/i386-redhat-linux/3.2.2/include/stddef.h \
+ /usr/include/bits/types.h /usr/include/bits/wordsize.h \
+ /usr/include/bits/typesizes.h /usr/include/libio.h \
+ /usr/include/_G_config.h /usr/include/wchar.h /usr/include/bits/wchar.h \
+ /usr/include/gconv.h \
+ /usr/lib/gcc-lib/i386-redhat-linux/3.2.2/include/stdarg.h \
+ /usr/include/bits/stdio_lim.h /usr/include/bits/sys_errlist.h \
+ /usr/include/stdlib.h /usr/include/bits/waitflags.h \
+ /usr/include/bits/waitstatus.h /usr/include/endian.h \
+ /usr/include/bits/endian.h /usr/include/xlocale.h \
+ /usr/include/sys/types.h /usr/include/time.h /usr/include/sys/select.h \
+ /usr/include/bits/select.h /usr/include/bits/sigset.h \
+ /usr/include/bits/time.h /usr/include/sys/sysmacros.h \
+ /usr/include/bits/pthreadtypes.h /usr/include/bits/sched.h \
+ /usr/include/alloca.h /usr/include/unistd.h \
+ /usr/include/bits/posix_opt.h /usr/include/bits/environments.h \
+ /usr/include/bits/confname.h /usr/include/getopt.h \
+ /usr/include/string.h /usr/include/gtk-2.0/gdk-pixbuf/gdk-pixbuf.h \
+ /usr/include/glib-2.0/glib.h /usr/include/glib-2.0/glib/galloca.h \
+ /usr/include/glib-2.0/glib/gtypes.h \
+ /usr/lib/glib-2.0/include/glibconfig.h \
+ /usr/include/glib-2.0/glib/gmacros.h \
+ /usr/lib/gcc-lib/i386-redhat-linux/3.2.2/include/limits.h \
+ /usr/lib/gcc-lib/i386-redhat-linux/3.2.2/include/syslimits.h \
+ /usr/include/limits.h /usr/include/bits/posix1_lim.h \
+ /usr/include/bits/local_lim.h /usr/include/linux/limits.h \
+ /usr/include/bits/posix2_lim.h /usr/include/bits/xopen_lim.h \
+ /usr/lib/gcc-lib/i386-redhat-linux/3.2.2/include/float.h \
+ /usr/include/glib-2.0/glib/garray.h \
+ /usr/include/glib-2.0/glib/gasyncqueue.h \
+ /usr/include/glib-2.0/glib/gthread.h \
+ /usr/include/glib-2.0/glib/gerror.h /usr/include/glib-2.0/glib/gquark.h \
+ /usr/include/glib-2.0/glib/gbacktrace.h \
+ /usr/include/glib-2.0/glib/gcache.h /usr/include/glib-2.0/glib/glist.h \
+ /usr/include/glib-2.0/glib/gmem.h \
+ /usr/include/glib-2.0/glib/gcompletion.h \
+ /usr/include/glib-2.0/glib/gconvert.h \
+ /usr/include/glib-2.0/glib/gdataset.h \
+ /usr/include/glib-2.0/glib/gdate.h /usr/include/glib-2.0/glib/gdir.h \
+ /usr/include/glib-2.0/glib/gfileutils.h \
+ /usr/include/glib-2.0/glib/ghash.h /usr/include/glib-2.0/glib/ghook.h \
+ /usr/include/glib-2.0/glib/giochannel.h \
+ /usr/include/glib-2.0/glib/gmain.h /usr/include/glib-2.0/glib/gslist.h \
+ /usr/include/glib-2.0/glib/gstring.h \
+ /usr/include/glib-2.0/glib/gunicode.h \
+ /usr/include/glib-2.0/glib/gmarkup.h \
+ /usr/include/glib-2.0/glib/gmessages.h \
+ /usr/include/glib-2.0/glib/gnode.h \
+ /usr/include/glib-2.0/glib/gpattern.h \
+ /usr/include/glib-2.0/glib/gprimes.h \
+ /usr/include/glib-2.0/glib/gqsort.h /usr/include/glib-2.0/glib/gqueue.h \
+ /usr/include/glib-2.0/glib/grand.h /usr/include/glib-2.0/glib/grel.h \
+ /usr/include/glib-2.0/glib/gscanner.h \
+ /usr/include/glib-2.0/glib/gshell.h /usr/include/glib-2.0/glib/gspawn.h \
+ /usr/include/glib-2.0/glib/gstrfuncs.h \
+ /usr/include/glib-2.0/glib/gthreadpool.h \
+ /usr/include/glib-2.0/glib/gtimer.h /usr/include/glib-2.0/glib/gtree.h \
+ /usr/include/glib-2.0/glib/gutils.h \
+ /usr/include/gtk-2.0/gdk-pixbuf/gdk-pixbuf-features.h \
+ /usr/include/glib-2.0/glib-object.h \
+ /usr/include/glib-2.0/gobject/gboxed.h \
+ /usr/include/glib-2.0/gobject/gtype.h \
+ /usr/include/glib-2.0/gobject/genums.h \
+ /usr/include/glib-2.0/gobject/gobject.h \
+ /usr/include/glib-2.0/gobject/gvalue.h \
+ /usr/include/glib-2.0/gobject/gparam.h \
+ /usr/include/glib-2.0/gobject/gclosure.h \
+ /usr/include/glib-2.0/gobject/gsignal.h \
+ /usr/include/glib-2.0/gobject/gmarshal.h \
+ /usr/include/glib-2.0/gobject/gparamspecs.h \
+ /usr/include/glib-2.0/gobject/gsourceclosure.h \
+ /usr/include/glib-2.0/gobject/gtypemodule.h \
+ /usr/include/glib-2.0/gobject/gtypeplugin.h \
+ /usr/include/glib-2.0/gobject/gvaluearray.h \
+ /usr/include/glib-2.0/gobject/gvaluetypes.h \
+ /usr/include/gtk-2.0/gdk-pixbuf/gdk-pixbuf-loader.h \
+ /usr/include/gtk-2.0/gdk-pixbuf/gdk-pixbuf-enum-types.h
diff --git a/convert/imgconv b/convert/imgconv
new file mode 100755
index 0000000..3ac8bc5
--- /dev/null
+++ b/convert/imgconv
@@ -0,0 +1,46 @@
+#!/bin/bash
+
+#sem dodelat err
+
+adresar=$@
+
+mkdir ./web-gallery
+mkdir ./web-gallery/thumbs
+mkdir ./web-gallery/lq
+mkdir ./web-gallery/mq
+mkdir ./web-gallery/hq
+mkdir ./web-gallery/zip #used for image tarballs
+mkdir ./web-gallery/comments
+
+i=1
+for soubor in $adresar
+ do
+ echo "konvertuji $soubor"
+# IMAGEMAGICK
+ #convert -geometry 160x120 -colors 16 -dither $soubor ./web-gallery/thumbs/img-$i.png
+ convert -geometry 120x120 $soubor ./web-gallery/thumbs/img-$i.jpg
+ convert -geometry 640x480 $soubor ./web-gallery/lq/img-$i.jpg
+ convert -geometry 800x600 $soubor ./web-gallery/mq/img-$i.jpg
+
+# NETPBM
+ #jpegtopnm $soubor > temp.pnm
+ ##cat temp.pnm | pnmscale -xysize 120 120 | ppmquant -floyd 16 | pnmtopng -interlace -compression 9 > ./web-gallery/thumbs/img-$i.png
+ #cat temp.pnm | pnmscale -xysize 120 120 | ppmtojpeg --quality 80 --progressive > ./web-gallery/thumbs/img-$i.jpg
+ #cat temp.pnm | pnmscale -xysize 640 640 | ppmtojpeg --quality 80 --progressive > ./web-gallery/lq/img-$i.jpg
+ #cat temp.pnm | pnmscale -xysize 800 800 | ppmtojpeg --quality 80 --progressive > ./web-gallery/mq/img-$i.jpg
+ #rm temp.pnm
+
+ cp $soubor ./web-gallery/hq/img-$i.jpg
+ # template for comment
+ echo "<span>image $i</span> " > ./web-gallery/comments/$i.txt
+ i=`expr $i + 1`
+done
+
+#####################
+# Tar-up/zip images #
+#####################
+
+#tar cvjf web-gallery/zip/mq.tar.bz2 mq/*.jpg
+#tar cvjf web-gallery/zip/hq.tar.bz2 hq/*.jpg
+zip -R web-gallery/zip/mq.zip web-gallery/mq/*.jpg
+zip -R web-gallery/zip/hq.zip web-gallery/hq/*.jpg
diff --git a/convert/webgallery-zenity.pl b/convert/webgallery-zenity.pl
new file mode 100755
index 0000000..a6377d0
--- /dev/null
+++ b/convert/webgallery-zenity.pl
@@ -0,0 +1,160 @@
+#!/usr/bin/perl -w
+
+# little script to generate image galleries for use with original PHP backend
+# uses Gnome's zenity for user dialogs
+# uses gdk-pixbuf-convert if available, otherwise convert (from ImageMagick)
+# (c) 2003-2004 Jakub 'jimmac' Steiner, (c) 2003-2004 Colin Marquardt
+# based on webgallery.pl by Tuomas Kuosmanen
+
+use strict;
+use warnings;
+use FileHandle;
+
+my $num_of_args = scalar @ARGV;
+
+if (!@ARGV or ($num_of_args == 0)) {
+ exec("zenity --error --title \"\" --text \"No args\n\nYou have to select images to work on.\"");
+ exit;
+}
+
+my $GdkPixbufConvert = "gdk-pixbuf-convert";
+my $Convert = "convert";
+my $dir = "web-gallery";
+
+
+# try to find a scaler program
+my $scaler;
+$scaler = `which $GdkPixbufConvert`;
+if ($scaler eq "") {
+ $scaler = `which $Convert`;
+}
+if ($scaler eq "") {
+ exec("zenity --error --title \"Giving Up\" --text \"No scaling program\n\nYou need to have '$GdkPixbufConvert' or '$Convert' available.\"");
+ exit;
+}
+chomp $scaler;
+
+my @args = sort(@ARGV);
+my $NumOfIncrements = 5; # 5 increments per file (as we are
+ # expecting to create 5 files for each
+ # image)
+my $increment = 100 / ($num_of_args * $NumOfIncrements);
+my $progress=0;
+my $reply="";
+
+sub make_dirs {
+ my $ErrMsg;
+ unless (-d "$dir") {
+ mkdir("./$dir") or
+ $ErrMsg .= "Could not create './$dir'!\n";
+ }
+ unless (-d "$dir/thumbs") {
+ mkdir("./$dir/thumbs") or
+ $ErrMsg .= "Could not create './$dir/thumbs'!\n";
+ }
+ unless (-d "$dir/lq") {
+ mkdir("./$dir/lq") or
+ $ErrMsg .= "Could not create './$dir/lq'!\n";
+ }
+ unless (-d "$dir/mq") {
+ mkdir("./$dir/mq") or
+ $ErrMsg .= "Could not create './$dir/mq'!\n";
+ }
+ unless (-d "$dir/hq") {
+ mkdir("./$dir/hq") or
+ $ErrMsg .= "Could not create './$dir/hq'!\n";
+ }
+ unless (-d "$dir/comments") {
+ mkdir("./$dir/comments") or
+ $ErrMsg .= "Could not create './$dir/comments'!\n";
+ }
+ unless (-d "$dir/zip") {
+ mkdir("./$dir/zip") or
+ $ErrMsg .= "Could not create './$dir/zip'!\n";
+ }
+ if ($ErrMsg ne "") {
+ exec("zenity --error --title \"Giving Up\" --text \"Fatal Error\n\n$ErrMsg\"");
+ die "Errors occurred:\n$ErrMsg";
+ }
+}
+make_dirs();
+
+# ------------------------------------------------------------------------
+open(PROGRESS,"| zenity --progress --auto-close --title=\"Scaling\" \\
+ --text=\"Scaling images, please wait\"");
+PROGRESS->autoflush(1);
+
+my $i=1;
+my $SetDirDate = 0;
+foreach my $arg (@args) {
+ if (-d $arg) { # argument is a directory, skip it
+ $progress += ($increment * $NumOfIncrements);
+ print PROGRESS "$progress\n";
+ next;
+ }
+ my $FileType = `file "$arg"`;
+ unless ($FileType =~ /image data/i) { # check for valid file type
+ # maybe check for JPEG and PNG explicitly?
+ #print $FileType;
+ $progress += ($increment * $NumOfIncrements);
+ print PROGRESS "$progress\n";
+ next;
+ }
+ if ($SetDirDate == 0) { # we are looking at the first image
+ $SetDirDate = (stat $arg)[9]; # get mtime
+ if ($SetDirDate > 0) {
+ # (can also return -1 if strange mtime, don't use this
+ # time stamp then)
+ # set mtime of gallery directory to the one of the first
+ # image file:
+ $reply .= `touch -r "$arg" $dir`;
+ print "Setting mtime of $dir to $SetDirDate\n";
+ } else {
+ # give it another try the next time around:
+ $SetDirDate = 0;
+ }
+ }
+ # thumbnails
+ $reply .= `$scaler -geometry 120x120 -quality 60 "$arg" $dir/thumbs/img-$i\.jpg 2>&1`;
+ $progress += $increment;
+ print PROGRESS "$progress\n";
+ # LQ size
+ $reply .= `$scaler -geometry 640x480 -quality 75 "$arg" $dir/lq/img-$i\.jpg 2>&1`;
+ $progress += $increment;
+ print PROGRESS "$progress\n";
+ # MQ size
+ $reply .= `$scaler -geometry 800x600 -quality 75 "$arg" $dir/mq/img-$i\.jpg 2>&1`;
+ $progress += $increment;
+ print PROGRESS "$progress\n";
+ # HQ size (just copy the original)
+ $reply .= `cp "$arg" $dir/hq/img-$i\.jpg 2>&1`;
+ $progress += $increment;
+ print PROGRESS "$progress\n";
+ # comment
+ open(COMM, ">$dir/comments/$i\.txt");
+ print(COMM "<span>image $i</span>\n");
+ close(COMM);
+ $progress += $increment;
+ print PROGRESS "$progress\n";
+ $i++;
+
+ # an error occurred:
+ if ($reply ne "") {
+ print PROGRESS "100\n";
+ close(PROGRESS);
+ exec("zenity --error --title \"Giving Up\" --text \"Fatal Error\n\n$reply\"");
+ die("Error while scaling");
+ }
+}
+print PROGRESS "100\n";
+close(PROGRESS);
+
+# ------------------------------------------------------------------------
+open(PROGRESS, "| zenity --progress --pulsate --auto-close \\
+--title \"Compressing\" --text \"Zipping images\"");
+PROGRESS->autoflush(1);
+print PROGRESS "1";
+system("zip -R $dir/zip/mq.zip $dir/mq/*.jpg");
+system("zip -R $dir/zip/hq.zip $dir/hq/*.jpg");
+print PROGRESS "100\n";
+close(PROGRESS);
diff --git a/convert/webgallery.pl b/convert/webgallery.pl
new file mode 100755
index 0000000..d8a7ce7
--- /dev/null
+++ b/convert/webgallery.pl
@@ -0,0 +1,154 @@
+#!/usr/bin/perl -w
+#
+# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
+# #
+# Web Gallery script for Nautilus - Depends on "original" web backend #
+# for displaying the gallery. #
+# #
+# Written in perl because I suck more with sh scripting. #
+# Also needs gnome-utils for gdialog. #
+# #
+# Hacked together by Tuomas Kuosmanen <tigert@ximian.com> #
+# Tweaked to use NetPBM by Jakub Steiner <jimmac@ximian.com> #
+# Released under the GPL license. #
+# #
+# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
+
+die "No files to convert" unless @ARGV;
+
+use Gtk;
+init Gtk;
+
+@files = sort(@ARGV);
+
+my $dir = "web-gallery";
+
+sub make_dirs {
+
+ unless (-d "$dir") {
+ mkdir("./$dir") or die "Aargh.\n";
+ }
+ unless (-d "$dir/thumbs") {
+ mkdir("./$dir/thumbs") or die "Aargh.\n";
+ }
+ unless (-d "$dir/lq") {
+ mkdir("./$dir/lq") or die "Aargh.\n";
+ }
+ unless (-d "$dir/mq") {
+ mkdir("./$dir/mq") or die "Aargh.\n";
+ }
+ unless (-d "$dir/hq") {
+ mkdir("./$dir/hq") or die "Aargh.\n";
+ }
+ unless (-d "$dir/comments") {
+ mkdir("./$dir/comments") or die "Aargh.\n";
+ }
+}
+
+sub make_gallery_fake {
+ my $foo = shift;
+ print ("PARAM: $foo\n");
+ sleep 1;
+}
+
+
+$w = new Gtk::Window;
+$label = new Gtk::Label(' Web Gallery generation in progress... ');
+$pbar = new Gtk::ProgressBar;
+$vb = new Gtk::VBox(0, 0);
+$b = new Gtk::Button('Cancel');
+$w->add($vb);
+$vb->add($label);
+$vb->add($pbar);
+$vb->add($b);
+
+$b->signal_connect('clicked', sub {Gtk->exit(0)});
+$w->signal_connect('destroy', sub {Gtk->exit(0)});
+
+$w->show_all();
+$i = 0;
+$pbar->update($i);
+
+@files = sort(@ARGV);
+$num_of_files = scalar @files;
+$increment = 1 / ( 5 * $num_of_files );
+$i = 1;
+$progress = 0;
+
+make_dirs();
+#read nautilus metafile if available
+open(METAXML, "./.nautilus-metafile.xml") or print("no metafile");
+@meta_xml = <METAXML>;
+close(METAXML);
+
+
+foreach $file (@files) {
+
+ $pbar->update($progress);
+ $pbar->set_show_text(1);
+ $pbar->set_format_string("$i of $num_of_files");
+ $progress += $increment;
+ while (Gtk->events_pending) {
+ Gtk->main_iteration;
+ }
+
+ # do the stuff, collect error messages to a variable.
+ #$reply=`convert -geometry 120x120 -colors 64 -dither $file $dir/thumbs/img-$i\.png 2>&1`;
+ $reply=`convert -geometry 120x120 $file $dir/thumbs/img-$i\.jpg 2>&1`;
+ #$reply =`jpegtopnm $file | pnmscale -xysize 120 120 | ppmquant -floyd 16 | pnmtopng -interlace -compression 9 > $dir/thumbs/img-$i\.png 2>&1`;
+
+ $pbar->update($progress);
+ $progress += $increment;
+ while (Gtk->events_pending) {
+ Gtk->main_iteration;
+ }
+
+ $reply = $reply . `convert -geometry 640x640 $file $dir/lq/img-$i.jpg 2>&1`;
+ #$reply = $reply . `jpegtopnm $file | pnmscale -xysize 640 640 | ppmtojpeg --quality 80 --progressive > $dir/lq/img-$i.jpg 2>&1`;
+
+ $pbar->update($progress);
+ $progress += $increment;
+ while (Gtk->events_pending) {
+ Gtk->main_iteration;
+ }
+
+ $reply = $reply . `convert -geometry 800x800 $file $dir/mq/img-$i.jpg 2>&1`;
+ #$reply = $reply . `jpegtopnm $file | pnmscale -xysize 800 800 | ppmtojpeg --quality 80 --progressive > $dir/mq/img-$i.jpg 2>&1`;
+
+ $pbar->update($progress);
+ $progress += $increment;
+ while (Gtk->events_pending) {
+ Gtk->main_iteration;
+ }
+
+ $reply = $reply . `cp $file $dir/hq/img-$i.jpg 2>&1`;
+
+ $pbar->update($progress);
+ $progress += $increment;
+ while (Gtk->events_pending) {
+ Gtk->main_iteration;
+ }
+
+ # comment
+ open (COMM, ">$dir/comments/$i\.txt");
+ print(COMM "<span>image $i: </span>\n");
+ #check for comments in the metafile
+ #maybe using a proper XML parser would make sense in future
+ foreach $radek (@meta_xml) {
+ chomp($radek);
+ if ($radek =~ m/.*name="([^"]*)".*annotation="([^"]*).*"/) {
+ if ($1 eq $file) {
+ print(COMM "<span>$2</span>\n");
+ }
+ }
+ }
+ close(COMM);
+
+ $i++;
+
+ # print possible error messages
+ if ($reply ne "") {
+ print("There was an error message: $reply\n");
+ }
+}
+
diff --git a/logo.xcf.bz2 b/logo.xcf.bz2
new file mode 100644
index 0000000..73268eb
--- /dev/null
+++ b/logo.xcf.bz2
Binary files differ
diff --git a/www/CVS/Entries b/www/CVS/Entries
new file mode 100644
index 0000000..ea6e294
--- /dev/null
+++ b/www/CVS/Entries
@@ -0,0 +1,11 @@
+/bcg.png/1.1.1.1/Tue Oct 21 06:45:11 2003//
+/logo-mini.png/1.1.1.1/Tue Oct 21 06:45:11 2003//
+/logo.png/1.1.1.1/Tue Oct 21 06:45:11 2003//
+/zip.png/1.1.1.1/Tue Oct 21 06:45:11 2003//
+D/inc////
+/left.png/1.1.1.1/Sun Oct 26 21:17:37 2003//
+/minus.png/1.1.1.1/Sun Oct 26 21:17:37 2003//
+/plus.png/1.1.1.1/Sun Oct 26 21:17:37 2003//
+/right.png/1.1.1.1/Sun Oct 26 21:17:37 2003//
+/top.png/1.1.1.1/Sun Oct 26 21:17:37 2003//
+/index.php/1.19/Tue Oct 28 22:38:07 2003//
diff --git a/www/CVS/Repository b/www/CVS/Repository
new file mode 100644
index 0000000..a516823
--- /dev/null
+++ b/www/CVS/Repository
@@ -0,0 +1 @@
+original/www
diff --git a/www/CVS/Root b/www/CVS/Root
new file mode 100644
index 0000000..16bd216
--- /dev/null
+++ b/www/CVS/Root
@@ -0,0 +1 @@
+:ext:jimmac@cvs.tuxfamily.org:/cvsroot/original
diff --git a/www/bcg.png b/www/bcg.png
new file mode 100644
index 0000000..d4f7ac8
--- /dev/null
+++ b/www/bcg.png
Binary files differ
diff --git a/www/inc/.config.inc.php.swo b/www/inc/.config.inc.php.swo
new file mode 100644
index 0000000..9cf5367
--- /dev/null
+++ b/www/inc/.config.inc.php.swo
Binary files differ
diff --git a/www/inc/CVS/Entries b/www/inc/CVS/Entries
new file mode 100644
index 0000000..6556eb2
--- /dev/null
+++ b/www/inc/CVS/Entries
@@ -0,0 +1,8 @@
+/.config.inc.php.swo/1.1.1.1/Tue Oct 21 06:45:11 2003//
+D/styles////
+/config.inc.php/1.9/Sun Oct 26 21:19:41 2003//
+/footer.inc.php/1.2/Sun Oct 26 18:43:36 2003//
+/header.inc.php/1.4/Mon Oct 27 11:15:00 2003//
+/exif.inc.php/1.4/Mon Oct 27 14:31:36 2003//
+/funkce.inc.php/1.6/Wed Oct 29 00:02:55 2003//
+/www.class.inc.php/1.7/Tue Oct 28 21:45:27 2003//
diff --git a/www/inc/CVS/Repository b/www/inc/CVS/Repository
new file mode 100644
index 0000000..ada892b
--- /dev/null
+++ b/www/inc/CVS/Repository
@@ -0,0 +1 @@
+original/www/inc
diff --git a/www/inc/CVS/Root b/www/inc/CVS/Root
new file mode 100644
index 0000000..16bd216
--- /dev/null
+++ b/www/inc/CVS/Root
@@ -0,0 +1 @@
+:ext:jimmac@cvs.tuxfamily.org:/cvsroot/original
diff --git a/www/inc/config.inc.php b/www/inc/config.inc.php
new file mode 100644
index 0000000..5bfb36e
--- /dev/null
+++ b/www/inc/config.inc.php
@@ -0,0 +1,71 @@
+<?
+#base dirname
+ eregi("^(.*)/[^/]*$", $ScriptFileName, $x);
+ $root = $x[1];
+# ===========================================================================
+#images
+ $img["left"] = "left.png";
+ $img["right"] = "right.png";
+ $img["top"] = "top.png";
+# ===========================================================================
+#thumbnail behaviour
+ //keep this unset for dynamic thumbnail size
+ //$thumbsize = "fixed";
+ //How the previous and Next thumbnails should be scaled
+ // 1 is 1:1, >1 is smaller, <1 is bigger
+ $PNthumbScale = 1;
+# ===========================================================================
+#colors and backgrounds
+# this has been removed in favour of custom CSS stylesheets
+# ===========================================================================
+#app info
+ $app["name"] = "Original"; // opensource remote image gallery,
+ // initialy not as lovely
+ $app["url"] = "http://jimmac.musichall.cz/original.php3";
+ $app["version"] = "0.8-cvs";
+# ===========================================================================
+# EXIF metadata app path (helper app for php3 and older php4)
+# uncomment the method you want to use if you want EXIF data reported
+# ---------------------------------------------------------------------------
+## use internal function of PHP 4 (does not seem to work yet):
+# $exif_prog = "php4";
+# ---------------------------------------------------------------------------
+## use metacam (give absolute path to the binary on the server):
+# $exif_prog = "/usr/local/bin/metacam";
+## what EXIF data to show (if unset, all will be shown)
+## some example fields for metacam:
+# $exif_show = array("Image Capture Date", "Make", "Model",
+# "Exposure Program", "Exposure Mode",
+# "Focal Length", "Exposure Time",
+# "Aperture Value", "ISO Speed Rating", "White Balance",
+# "Flash", "Scene Capture Type",
+# "Metering Mode", "Max Aperture Value", "Shutter Speed Value"
+# );
+# ---------------------------------------------------------------------------
+## use jhead (give absolute path to the binary on the server):
+# $exif_prog = "/usr/local/bin/jhead";
+## what EXIF data to show (if unset, all will be shown)
+## some example fields for jhead:
+# $exif_show = array(
+# "Date/Time",
+# "Camera make",
+# "Camera model",
+# "Focal length",
+# "Exposure time",
+# "Aperture Value",
+# "ISO equiv.",
+# "Exposure",
+# );
+# ===========================================================================
+## Gallery Directory
+# This is a path relative to the directory where original is installed
+# eg. it can be "../galleries" to use a galleries dir above the original dir.
+ $gallery_dir="galleries";
+
+#css styles
+ $themes = array(
+ "default" => "inc/styles/default/default.css",
+ "ie" => "inc/styles/ie/ie.css",
+ "gorilla" => "inc/styles/gorilla/gorilla.css"
+ );
+?>
diff --git a/www/inc/exif.inc.php b/www/inc/exif.inc.php
new file mode 100644
index 0000000..be76168
--- /dev/null
+++ b/www/inc/exif.inc.php
@@ -0,0 +1,139 @@
+<?php
+if ($exif_prog=="php4") {
+ // php internal handling
+ // read_exif_data is supposed to read the whole jpeg into memory,
+ // so we'll use the thumbnails to save it
+ // THIS IS COMPLETELY UNTESTED!!!!
+ $exif_array = read_exif_data("$thumb");
+ if ($exif_style=="descriptive") {
+ // fancy table look
+ echo "<table border=\"0\" align=\"center\">\n";
+ //co ukazat (podle exif_show
+ if ($exif_show) {
+ while(list($k,$v)=each($exif_array)) {
+ while ($x = current($exif_show)) {
+ if ($x==$k) {
+ echo "<tr>";
+ echo "<td align=\"right\">$k :</td>";
+ echo "<td><b>$v</b></td>";
+ echo "</tr>\n";
+ }
+ next($exif_show);
+ }
+ }
+ } else {
+ //ukaze vsechno
+ while(list($k,$v)=each($exif_array)) {
+ echo "<tr>";
+ echo "<td align=\"right\">$k :</td>";
+ echo "<td><b>$v</b></td>";
+ echo "</tr>\n";
+ }
+ }
+ echo "<tr>\n";
+ echo "<td></td>";
+ # only show if EXIF header exists
+ if ($exif_array["Make"]) {
+ echo "<td><a href=\"$ThisScript?galerie=$galerie&snimek=$snimek";
+ echo "&exif_style=simple&show_thumbs=$show_thumbs\">";
+ echo "<b>display line</b></a></td>\n";
+ }
+ echo "</tr>\n";
+ echo "</table>\n";
+ echo "</table>";
+ } else {
+ // in one line
+ if ($exif_show) {
+ while(list($k,$v)=each($exif_array)) {
+ while ($x = current($exif_show)) {
+ if ($x==$k) {
+ echo "$v | ";
+ }
+ next($exif_show);
+ }
+ }
+ } else {
+ while(list($k,$v)=each($exif_array)) {
+ echo "$v | ";
+ }
+ }
+ # only show if EXIF header exists
+ if ($exif_array["Make"]) {
+ echo "<a href=\"$ThisScript?galerie=$galerie&snimek=$snimek";
+ echo "&exif_style=descriptive&show_thumbs=$show_thumbs\">";
+ echo "<b>display table</b></a>\n";
+ echo "</p>\n";
+ }
+ }
+
+} else {
+ // the old code, handles e.g. metacam and jhead as EXIF extractors
+ // loading lq means it won't work if the convertor doesn't copy EXIF data
+ // (newer ImageMagick can)
+ exec("$exif_prog \"$gallery_dir/$galerie/lq/img-$snimek.jpg\"", $exif_data, $exif_status);
+ if ($exif_status!="2") {
+ if ($exif_style=="descriptive") {
+ // fancy table look
+ echo "<table border=\"0\" align=\"center\">\n";
+ while ($x = current($exif_data)) {
+ eregi("^ *([^:]*): *(.*)", $x, $y);
+ //filter according to $exif_show array
+ if (!$exif_show) { //all fields shown
+ echo "<tr>";
+ echo "<td align=\"right\">$y[1] :</td>";
+ echo "<td><b>$y[2]</b></td>";
+ echo "</tr>\n";
+ } else {
+ reset($exif_show);
+ while ($z = current($exif_show)) {
+ //echo ".$z. ::: .$y[1].<br>";
+ if (trim($z) == trim($y[1])) {
+ echo "<tr>";
+ echo "<td align=\"right\">$y[1] :</td>";
+ echo "<td><b>$y[2]</b></td>";
+ echo "</tr>\n";
+ }
+ next($exif_show);
+ }
+ }
+ next($exif_data);
+ }
+ echo "<tr>\n";
+ echo "<td></td>";
+ # only show if EXIF header exists
+ if ($y[1]!="File") { // don't show when no EXIF
+ echo "<td><a href=\"$ThisScript?galerie=$galerie&snimek=$snimek";
+ echo "&exif_style=simple&show_thumbs=$show_thumbs\">";
+ echo "<b>display line</b></a></td>\n";
+ }
+ echo "</tr>\n";
+ echo "</table>\n";
+ } else {
+ //simple plaintext look
+ echo "<p class=\"exif\" align=\"center\">";
+ while ($x = current($exif_data)) {
+ eregi("^ *([^:]*): *(.*)", $x, $y);
+ if (!$exif_show) { //all fields shown
+ echo "$y[2] |";
+ } else {
+ reset($exif_show);
+ while ($z = current($exif_show)) {
+ if (trim($z) == trim($y[1])) {
+ echo "$y[2] | ";
+ }
+ next($exif_show);
+ }
+ }
+ next($exif_data);
+ }
+ # only show if EXIF header exists
+ if ($y[1]!="File") {
+ echo "<a href=\"$ThisScript?galerie=$galerie&snimek=$snimek";
+ echo "&exif_style=descriptive&show_thumbs=$show_thumbs\">";
+ echo "<b>display table</b></a>\n";
+ echo "</p>\n";
+ }
+ }
+ }
+}
+?>
diff --git a/www/inc/footer.inc.php b/www/inc/footer.inc.php
new file mode 100644
index 0000000..7143fd5
--- /dev/null
+++ b/www/inc/footer.inc.php
@@ -0,0 +1,27 @@
+<?
+/*
+echo "<p class=\"copyright\">\n";
+echo "<a href=\"http://jigsaw.w3.org/css-validator/validator?uri=";
+echo "http://$HostName$ThisScript\">";
+echo "<img align=\"top\" style=\"border:0;width:88px;height:31px\"";
+echo " src=\"http://jigsaw.w3.org/css-validator/images/vcss\"";
+echo " alt=\"Valid CSS!\">";
+echo "</a>\n";
+
+echo "<a href=\"http://validator.w3.org/check?uri=";
+echo "http://$HostName$ThisScript\">";
+echo "<img align=\"top\" style=\"border:0;width:88px;height:31px\"";
+echo " src=\"http://www.w3.org/Icons/valid-html401\"";
+echo " alt=\"Valid HTML 4.01!\">";
+echo "</a>\n";
+*/
+
+echo "\n\n<div class=\"footer\">";
+echo "Generated by\n <em>";
+echo "<a href=\"" . $app["url"] . "\">";
+echo $app["name"];
+echo "</a>";
+echo " ver. " . $app["version"];
+echo "</em>\n";
+echo "</div>\n";
+?>
diff --git a/www/inc/funkce.inc.php b/www/inc/funkce.inc.php
new file mode 100644
index 0000000..2a1e8cc
--- /dev/null
+++ b/www/inc/funkce.inc.php
@@ -0,0 +1,96 @@
+<?php
+function navigation ($gallery, $snapshot, $image) {
+ global $gallery_dir, $root, $ThisScript, $textnav, $img,
+ $show_thumbs, $exif_style, $PNthumbScale;
+
+ $next = $snapshot + 1;
+ $prev = $snapshot - 1;
+
+ if (!$image) { // this will render a navigation bar - max 3 buttons
+ echo "\n<div class=\"navbuttons\">\n";
+ echo "<div class=\"navbuttonsshell\">\n";
+ if ($snapshot > 1) { //previous
+ echo "<a id=\"previcon\" href=\"$ThisScript?galerie=$gallery&amp;snimek=$prev";
+ echo "&amp;exif_style=$exif_style&amp;show_thumbs=$show_thumbs\">";
+ echo "&lt; previous</a>\n";
+ }
+ echo "&nbsp;";
+ if (is_file("$gallery_dir/$gallery/lq/img-$next.jpg")) { //next
+ echo "<a id=\"nexticon\" href=\"$ThisScript?galerie=$gallery&amp;snimek=$next";
+ echo "&amp;exif_style=$exif_style&amp;show_thumbs=$show_thumbs\">";
+ echo "next &gt;</a>\n";
+ }
+ echo "</div>\n</div>\n";
+ } elseif ($image=="prev") { //previous thumbnail
+ if ($snapshot > 1) { //previous
+ echo "<div class=\"prevthumb\">";
+ echo "<a href=\"$ThisScript?galerie=$gallery&amp;snimek=$prev";
+ echo "&amp;exif_style=$exif_style&amp;show_thumbs=$show_thumbs\">";
+ if (file_exists("$gallery_dir/$gallery/thumbs/img-$prev.png")) {
+ $Pthumb = "$gallery_dir/$gallery/thumbs/img-$prev.png";
+ } else {
+ $Pthumb = "$gallery_dir/$gallery/thumbs/img-$prev.jpg";
+ }
+ $v = getimagesize("$root/$Pthumb");
+ echo "<img alt=\"Previous\" src=\"";
+ echo $Pthumb . "\" width=\"" . round($v[0]/$PNthumbScale);
+ echo "\" height=\"" . round($v[1]/$PNthumbScale) . "\" />";
+ echo "<br />Previous";
+ echo "</a></div>\n";
+ }
+ } else { //next thumbnail
+ if (is_file("$gallery_dir/$gallery/lq/img-$next.jpg")) {
+ echo "<div class=\"nextthumb\">";
+ echo "<a href=\"$ThisScript?galerie=$gallery&amp;snimek=$next";
+ echo "&amp;exif_style=$exif_style&amp;show_thumbs=$show_thumbs\">";
+ if (file_exists("$gallery_dir/$gallery/thumbs/img-$next.png")) {
+ $Nthumb = "$gallery_dir/$gallery/thumbs/img-$next.png";
+ } else {
+ $Nthumb = "$gallery_dir/$gallery/thumbs/img-$next.jpg";
+ }
+ $v = getimagesize("$root/$Nthumb");
+ echo "<img alt=\"Next\" src=\"";
+ echo $Nthumb . "\" width=\"" . round($v[0]/$PNthumbScale);
+ echo "\" height=\"" . round($v[1]/$PNthumbScale) . "\" />";
+ echo "<br />Next";
+ echo "</a></div>\n";
+ }
+ }
+
+}
+
+function check($file) {
+ global $gallery_dir, $page;
+
+# if (eregi("[^0-9a-z\_\-\ ]",$file) || !file_exists("$gallery_dir/$file")) {
+# if (eregi("CVS",$file) || !file_exists("$gallery_dir/$file")) {
+ if (!file_exists("$gallery_dir/$file")) {
+ echo "funkce.inc.php/check(): Bad input";
+ $page->footer();
+ exit;
+ }
+}
+
+function browserCheck() {
+ global $HTTP_USER_AGENT;
+
+ if (eregi("(MSIE.[456789]).*Mac.*",$HTTP_USER_AGENT)) {
+ return("macie4+");
+ } elseif (eregi("(MSIE.[678])",$HTTP_USER_AGENT)) {
+ return("ie6+");
+ } elseif (eregi("(MSIE.[45])",$HTTP_USER_AGENT)) {
+ return("ie4+");
+ } elseif (eregi("Opera",$HTTP_USER_AGENT)) {
+ return("opera");
+ } elseif (eregi("(Mozilla.4)",$HTTP_USER_AGENT)) {
+ return("netscape4");
+ } elseif (eregi("(Mozilla.[5-9])",$HTTP_USER_AGENT)) {
+ return("mozilla");
+ } elseif (eregi("KMeleon",$HTTP_USER_AGENT)) {
+ return("mozilla");
+ } else {
+ return("Netscape3");
+ }
+}
+
+?>
diff --git a/www/inc/header.inc.php b/www/inc/header.inc.php
new file mode 100644
index 0000000..3242c1c
--- /dev/null
+++ b/www/inc/header.inc.php
@@ -0,0 +1,14 @@
+<div class="stylenavbar">
+[ style:
+<?
+foreach ($themes as $skin => $url) {
+ echo "<a href=\"#\" title=\"$skin\"";
+ echo " onclick=\"setActiveStyleSheet('$skin')\">";
+ echo "$skin</a> \n";
+}
+?>
+]
+</div>
+<?
+echo "<h1 class=\"title\"><a href=\"http://$HostName$ThisScript\">Photo Gallery<span /></a></h1>\n\n";
+?>
diff --git a/www/inc/javascript-eek.inc.php b/www/inc/javascript-eek.inc.php
new file mode 100644
index 0000000..3672c8c
--- /dev/null
+++ b/www/inc/javascript-eek.inc.php
@@ -0,0 +1,112 @@
+<script language="JavaScript">
+// javascript snipplets mostly nicked from
+// http://liorean.web-graphics.com/scripts
+
+//cookie handling
+
+var cookie={ // The Cookie Handler main object
+ Get:function(n){ // Function for getting cookies
+ var re=new RegExp(n+'=([^;]*);?','gi'); // Create regex for cookies fetching
+ var r=re.exec(document.cookie)||[]; // Fetch cookie using regex
+ return unescape(r.length>1?r[1]:null) // Return unescaped cookie
+ },
+ Set:function(n,v,e,p,d,s){ // Function for setting cookies
+ var t=new Date; // Get current time and date
+ if(e) // If days to expiry is set
+ t.setTime(t.getTime()+(e*8.64e7)); // calculate expiry date
+ document.cookie=n+'='+escape(v)+'; '+(!e?'':'; expires='+t.toUTCString())+(!p?'':'; path='+p)+(!d?'':'; domain='+d)+(!s?'':'; secure') // Set cookie
+ },
+ Del:function(n,p,d){ // Function for deleting cookies
+ var t=cookie.Get(n); // Get cookie
+ document.cookie=n+'='+(!p?'':'; path='+p)+(!d?'':'; domain='+d)+'; expires=Thu, 01-Jan-70 00:00:01 GMT'; // Delete cookie
+ return t // Return the deleted cookie
+ },
+ Sup:function(){ // Function for detecting cookies support
+ cookie.Set('c',true); // Set dummy cookie
+ return cookie.Del('c'); // Return whether dummy was written
+ }
+};
+
+
+// theme switching
+
+var style={ // Theme Switcher main object
+ Set:function(t){ // Function for setting active theme
+ for(var i in this.col) // For each existing title
+ for(var j=0,f;(f=(j<this.col[i].length)?this.col[i][j]:null);j++) // And all stylesheets of that title
+ f.disabled=i!=t?true:false; // Set to enabled or disabled depending on whether title matches user input
+ },
+ Get:function(){ // Function for determining active theme
+ for(var i in this.col) // For each existing title
+ if(!this.col[i][0].disabled) // Unless disabled
+ return i; // Return title
+ return this.Pref() // Otherwise try to determine preferred title
+ },
+ Pref:function(){ // Function to determine preferred title
+ for(var i in this.col) // For each existing title
+ if(!this.col[i][0].disabled) // Unless disabled
+ return i; // Return title
+ return null // Otherwise return null
+ },
+ sum:function(){ // Function to collect existing titles into a collection
+ var s=document.styleSheets,i=0; // Set needed variables
+ for(var f;(f=(i<s.length)?s[i]:null);i++) // For each existing stylesheet
+ switch(f.title){ // Read title
+ case '': // If none or blank
+ break; // Exit
+ default: // Otherwise
+ switch(typeof this.col[f.title]){ // Read title
+ case 'object': // If exists in collection
+ this.col[f.title][this.col[f.title].length]=f; // Add stylesheet to that title in the collection
+ break; // Exit
+ default: // Otherwise
+ this.col[f.title]=[f] // Add new titla to collection and add stylesheet to that title
+ }
+ }
+ },
+ onload:function(){ // Function to send to onload handler
+ style.sum(); // Collect titles
+ if(cookie.Sup()){ // If cookies support exists
+ var c=cookie.Get('style'); // Get preferred theme from cookie
+ style.Set(c||style.Pref()) // Otherwise use the author specified
+ }
+ },
+ onunload:function(){ // Function to send to onunload handler
+ if(cookie.Sup()){ // If cookies support exists
+ var s=style.Get(); // Get active theme
+ cookie.Set('style',s,356,'/') // Write active theme to cookie
+ }
+ },
+ col:{} // Collection for titles
+};
+
+event.Add(style.onload); // Add onload handler
+window.onunload=style.onunload; // Add onunload handler
+
+
+// IE/Mac voodoo
+
+var event={ // The Event Handler main object
+ Add:function(f){ // Function for adding onload handlers
+ event.col[event.col.length]=f; // Add event handler to collection
+ if(typeof window.addEventListener!='undefined') // If W3C compliant
+ window.addEventListener('load',f,false); // Apply event handler
+ else if(!event.ieSet) // Otherwise, unless already set
+ if(typeof document.onreadystatechange!='undefined') // If supported
+ document.onreadystatechange=event.onload; // Add In event handler handler
+ event.ieSet=true; // Specify that event handler already is set
+ return(typeof window.addEventListener!='undefined') // Return whether W3C compliant
+ },
+ onload:function(){ // Function for handling multiple onload handlers in IE
+ var m=/mac/i.test(navigator.platform); // Detect whether mac
+ if(typeof document.readyState!='undefined') // If supported
+ if(m?document.readyState!='interactive':document.readyState!='complete') // And not already finished
+ return; // Exit
+ for(var i=0,f;(f=(i<event.col.length)?event.col[i]:null);i++) // For all event handlers
+ f(); // Run event handler
+ return // Exit
+ },
+ ieSet:false, // Variable to say whether event handler is set or not
+ col:[] // Collection for event handlers
+};
+</script>
diff --git a/www/inc/javascript.inc.php b/www/inc/javascript.inc.php
new file mode 100644
index 0000000..f2e3deb
--- /dev/null
+++ b/www/inc/javascript.inc.php
@@ -0,0 +1,51 @@
+<script language="JavaScript">
+function setActiveStyleSheet(title) {
+ var i, a, main;
+ for(i=0; (a = document.getElementsByTagName("link")[i]); i++) {
+ if(a.getAttribute("rel").indexOf("style") != -1
+ && a.getAttribute("title")) {
+ a.disabled = true;
+ if(a.getAttribute("title") == title) a.disabled = false;
+ }
+ }
+ if (title!="") {
+ writeCookie(title);
+ }
+}
+
+function getInactiveStyleSheet() {
+ var i, a;
+ for(i=0; (a = document.getElementsByTagName("link")[i]); i++) {
+ if(a.getAttribute("rel").indexOf("style") != -1 && a.getAttribute("title") && a.disabled) return a.getAttribute("title");
+ }
+ return null;
+}
+
+function readCookie() {
+ var theme = document.cookie;
+ var theme = unescape(theme);
+
+ return theme;
+}
+
+function writeCookie(theme) {
+ //FIXME - set expires
+ var original_cookie = "theme=" + escape(theme);
+ document.cookie = original_cookie;
+}
+
+function checkForTheme() {
+ var theme = readCookie();
+ //alert(theme);
+ if (theme=="undefined") {
+ var theme = "none";
+ }
+}
+
+// what a kludge. Luckily I found a clean way
+function alignForGorilla() {
+var image_preview = document.getElementById('preview');
+image_preview.style.marginLeft = "-" + (image_preview.width/2 + 16) + "px";
+}
+
+</script>
diff --git a/www/inc/styles/CVS/Entries b/www/inc/styles/CVS/Entries
new file mode 100644
index 0000000..138bf3e
--- /dev/null
+++ b/www/inc/styles/CVS/Entries
@@ -0,0 +1,2 @@
+D/gorilla////
+D/default////
diff --git a/www/inc/styles/CVS/Repository b/www/inc/styles/CVS/Repository
new file mode 100644
index 0000000..4339a69
--- /dev/null
+++ b/www/inc/styles/CVS/Repository
@@ -0,0 +1 @@
+original/www/inc/styles
diff --git a/www/inc/styles/CVS/Root b/www/inc/styles/CVS/Root
new file mode 100644
index 0000000..16bd216
--- /dev/null
+++ b/www/inc/styles/CVS/Root
@@ -0,0 +1 @@
+:ext:jimmac@cvs.tuxfamily.org:/cvsroot/original
diff --git a/www/inc/styles/default/CVS/Entries b/www/inc/styles/default/CVS/Entries
new file mode 100644
index 0000000..9eaa230
--- /dev/null
+++ b/www/inc/styles/default/CVS/Entries
@@ -0,0 +1,12 @@
+/bcg.png/1.1/Tue Oct 21 06:45:11 2003/-kb/
+/default.css/1.1/Wed Oct 29 00:47:30 2003//
+/left-16.png/1.1/Tue Apr 8 13:23:53 2003/-kb/
+/left.png/1.1/Wed Apr 23 11:03:22 2003/-kb/
+/logo-mini.png/1.1/Tue Oct 21 06:45:11 2003/-kb/
+/minus.png/1.1/Thu Mar 28 19:34:49 2002/-kb/
+/plus.png/1.1/Thu Mar 28 19:34:49 2002/-kb/
+/right-16.png/1.1/Tue Apr 8 13:24:17 2003/-kb/
+/right.png/1.1/Wed Apr 23 11:04:26 2003/-kb/
+/title.png/1.1/Tue Oct 28 21:54:11 2003/-kb/
+/zip.png/1.1/Fri May 23 12:44:44 2003/-kb/
+D
diff --git a/www/inc/styles/default/CVS/Repository b/www/inc/styles/default/CVS/Repository
new file mode 100644
index 0000000..ec15a90
--- /dev/null
+++ b/www/inc/styles/default/CVS/Repository
@@ -0,0 +1 @@
+original/www/inc/styles/default
diff --git a/www/inc/styles/default/CVS/Root b/www/inc/styles/default/CVS/Root
new file mode 100644
index 0000000..16bd216
--- /dev/null
+++ b/www/inc/styles/default/CVS/Root
@@ -0,0 +1 @@
+:ext:jimmac@cvs.tuxfamily.org:/cvsroot/original
diff --git a/www/inc/styles/default/bcg.png b/www/inc/styles/default/bcg.png
new file mode 100644
index 0000000..d4f7ac8
--- /dev/null
+++ b/www/inc/styles/default/bcg.png
Binary files differ
diff --git a/www/inc/styles/default/default.css b/www/inc/styles/default/default.css
new file mode 100644
index 0000000..482267d
--- /dev/null
+++ b/www/inc/styles/default/default.css
@@ -0,0 +1,285 @@
+/* Default stylesheet
+ ==================
+
+ stylesheet & artwork
+ (c) 2003 Jakub 'jimmac' Steiner
+
+*/
+
+body {
+ background-color: #f6f6f6;
+ background: url("bcg.png") top left repeat;
+ /*
+ margin: 0px 50px 0px 50px;
+ width: auto;
+ */
+ margin: auto;
+ width: 770px;
+ font-family: "Bitstream Vera Sans", sans-serif;
+ font-size: 10pt;
+}
+
+img {
+ border: 0px;
+}
+
+a:link {
+ color: #909090;
+}
+
+a:visited {
+ color: #808080;
+}
+
+a:hover {
+ color: #f0f0f0;
+ background-color: #707070;
+}
+
+
+h1.title {
+ background-color: #a7a9a6;
+ font-size: 16pt;
+ color: #808080;
+ width: 100%;
+ margin-bottom: 0px;
+ padding: 5px;
+
+}
+
+.title a {
+ display: block;
+ position:relative;
+ width:100%;
+ height:48px;
+ margin:0; padding:0;
+}
+
+.title a:hover {
+ border: 0px;
+ background-color: #a7a9a6;
+}
+
+.title a span {
+ /* this overlays text below with an image */
+ display: block;
+ position:absolute; left:0; top:0; z-index:1;
+ width:338px; height:48px;
+ margin:0; padding:0;
+ background-image: url("title.png");
+ background-attachment: top left;
+ background-repeat: no-repeat;
+}
+
+div.thumbroll {
+ margin: 10px 0px 4px 0px;
+ min-height: 29px;
+}
+
+p.bigthumbnails {
+ text-align: center;
+}
+
+p.bigthumbnails a {
+ padding: 0px;
+ margin: 0px;
+ border: 0px;
+
+}
+/*
+p.bigthumbnails a:link img {
+ border: 1px solid white;
+}
+
+p.bigthumbnails a:hover img {
+ border: 1px solid #909090;
+
+}
+*/
+
+a#minus,a#plus {
+ display: block;
+ position: relative;
+ float: left;
+ width:24px;
+ height:24px;
+ margin:0px; padding:0px;
+}
+
+a#minus {
+ background: url("minus.png") top left no-repeat;
+}
+
+a#plus {
+ background: url("plus.png") top left no-repeat;
+}
+
+a#zip {
+ /* display: block; */
+ position: relative;
+ width:16px;
+ height:16px;
+ margin:0px; padding:0px;
+ font-size: 9px;
+}
+
+a#zip span {
+ background: url("zip.png") top left no-repeat;
+ position:absolute; left:0; top:0; z-index:1;
+ width:16px; height:16px;
+}
+
+div.navigation {
+ background-color: #f6f6f6;
+ width: 100%;
+ padding: 5px;
+ font-size: 10px;
+}
+
+div.navigation a {
+ color: #a0a0a0;
+ font-weight: bold;
+}
+
+div.footer {
+ font-size: 9px;
+ width: 100%;
+ margin-top: 40px;
+ padding: 5px 5px 20px 5px;
+ clear: both;
+ border-top: 1px dotted #909090;
+}
+
+div.year {
+ font-size: 11pt;
+ float: left;
+ margin: 10px;
+}
+
+div.month {
+ margin: 0px 0px 0px 2em;
+ padding: 2px;
+}
+
+div.month h4 {
+ margin: 0px 0px 3px 0px;
+}
+
+/* ul won't work on safari with float: left */
+div.month p {
+ margin: 2px;
+ padding: 0px 0px 0px 6px;
+ list-style: none;
+ font-size: 10px;
+}
+
+div#image {
+ /* width: 800px; */
+ display: block;
+ position: relative;
+ clear: both;
+ margin-left: auto;
+ margin-right: auto;
+ /* border: 1px solid black; */
+ min-height: 480px; /* only works in gecko :/ */
+}
+
+img#preview {
+ position: relative;
+ float: left;
+ margin-right: 8px;
+}
+
+div.comment {
+ margin: 2em 0px;
+ color: #808080;
+ font-size: 9px;
+}
+
+div.comment span {
+ color: black;
+ font-weight: bold;
+ font-size: 10px;
+}
+
+div.navbuttons {
+ position: absolute;
+ top: 580px; left: 50%;
+ margin-left: 260px; /* 260px to the right of the center of the page */
+ width: 64px; height: 32px;
+ z-index: 1;
+}
+
+div.navbuttonsshell {
+ position: relative;
+ width: 100%;
+ margin: 2px;
+}
+
+div.navbuttonsshell a#previcon {
+ display: block;
+ position: absolute;
+ width: 24px; height: 24px;
+ margin: 2px; padding: 0;
+ top: 0px;
+ left: 0px;
+ color: #f6f6f6;
+ font-size: 30px; /* make unreadable */
+ text-indent: 2em; /* push it off screen, since khtml doesn't do 0px fonts */
+ overflow: hidden; /* hide the oveflow text */
+ background: url("left.png") top left no-repeat; /* have a pixmap */
+}
+
+div.navbuttonsshell a#nexticon {
+ display: block;
+ position: absolute;
+ width: 24px; height: 24px;
+ margin: 2px 4px 2px auto; padding: 0;
+ right: 4px; top: 0px;
+ color: #f6f6f6;
+ font-size: 30px; /* make unreadable */
+ text-indent: 2em; /* push it off screen, since khtml doesn't do 0px fonts */
+ overflow: hidden; /* hide the overflow text */
+ background: url("right.png") top left no-repeat; /* have a pixmap */
+}
+
+
+div.prevthumb,div.nextthumb {
+ margin-bottom: 1em;
+}
+
+div.nextthumb a,div.prevthumb a {
+ text-decoration: none;
+}
+
+div#mqhq {
+ margin: 2px 2px 4px 0px;
+ height: 32px;
+}
+
+div#mqhq a {
+ display: block;
+ border: 1px solid #909090;
+ padding: 2px;
+ font-size: 10px;
+ background-color: #f6f6f6;
+ color: black;
+ float: left;
+ width: 48px;
+ text-align: center;
+ margin: 2px;
+ -moz-border-radius: 2px;
+}
+
+div#mqhq a:hover {
+ background-color: #909090;
+ border: 1px solid black;
+ color: white;
+}
+
+div.stylenavbar {
+ position:relative;
+ font-size: 9px;
+ margin: 4px 0px;
+ padding-bottom: 0px;
+}
diff --git a/www/inc/styles/default/left-16.png b/www/inc/styles/default/left-16.png
new file mode 100644
index 0000000..625a1ab
--- /dev/null
+++ b/www/inc/styles/default/left-16.png
Binary files differ
diff --git a/www/inc/styles/default/left.png b/www/inc/styles/default/left.png
new file mode 100644
index 0000000..bd5607c
--- /dev/null
+++ b/www/inc/styles/default/left.png
Binary files differ
diff --git a/www/inc/styles/default/logo-mini.png b/www/inc/styles/default/logo-mini.png
new file mode 100644
index 0000000..8949154
--- /dev/null
+++ b/www/inc/styles/default/logo-mini.png
Binary files differ
diff --git a/www/inc/styles/default/minus.png b/www/inc/styles/default/minus.png
new file mode 100644
index 0000000..19eaef3
--- /dev/null
+++ b/www/inc/styles/default/minus.png
Binary files differ
diff --git a/www/inc/styles/default/plus.png b/www/inc/styles/default/plus.png
new file mode 100644
index 0000000..062d005
--- /dev/null
+++ b/www/inc/styles/default/plus.png
Binary files differ
diff --git a/www/inc/styles/default/right-16.png b/www/inc/styles/default/right-16.png
new file mode 100644
index 0000000..42e783f
--- /dev/null
+++ b/www/inc/styles/default/right-16.png
Binary files differ
diff --git a/www/inc/styles/default/right.png b/www/inc/styles/default/right.png
new file mode 100644
index 0000000..bc5bcc5
--- /dev/null
+++ b/www/inc/styles/default/right.png
Binary files differ
diff --git a/www/inc/styles/default/title.png b/www/inc/styles/default/title.png
new file mode 100644
index 0000000..8a6ad6b
--- /dev/null
+++ b/www/inc/styles/default/title.png
Binary files differ
diff --git a/www/inc/styles/default/zip.png b/www/inc/styles/default/zip.png
new file mode 100644
index 0000000..0bc44ab
--- /dev/null
+++ b/www/inc/styles/default/zip.png
Binary files differ
diff --git a/www/inc/styles/gorilla/CVS/Entries b/www/inc/styles/gorilla/CVS/Entries
new file mode 100644
index 0000000..ad515e3
--- /dev/null
+++ b/www/inc/styles/gorilla/CVS/Entries
@@ -0,0 +1,7 @@
+/minus.png/1.1/Tue Oct 21 06:45:11 2003/-kb/
+/plus.png/1.1/Tue Oct 21 06:45:11 2003/-kb/
+/title.png/1.1/Mon Oct 27 11:01:36 2003/-kb/
+/gorilla.css/1.4/Wed Oct 29 00:23:08 2003//
+/left.png/1.1/Tue Oct 21 06:45:11 2003/-kb/
+/right.png/1.1/Tue Oct 21 06:45:11 2003/-kb/
+D
diff --git a/www/inc/styles/gorilla/CVS/Repository b/www/inc/styles/gorilla/CVS/Repository
new file mode 100644
index 0000000..887b74e
--- /dev/null
+++ b/www/inc/styles/gorilla/CVS/Repository
@@ -0,0 +1 @@
+original/www/inc/styles/gorilla
diff --git a/www/inc/styles/gorilla/CVS/Root b/www/inc/styles/gorilla/CVS/Root
new file mode 100644
index 0000000..16bd216
--- /dev/null
+++ b/www/inc/styles/gorilla/CVS/Root
@@ -0,0 +1 @@
+:ext:jimmac@cvs.tuxfamily.org:/cvsroot/original
diff --git a/www/inc/styles/gorilla/gorilla.css b/www/inc/styles/gorilla/gorilla.css
new file mode 100644
index 0000000..9b23168
--- /dev/null
+++ b/www/inc/styles/gorilla/gorilla.css
@@ -0,0 +1,258 @@
+/* Gorilla stylesheet
+ ==================
+
+ stylesheet & artwork
+ (c) 2003 Jakub 'jimmac' Steiner
+
+ bugs/TODO:
+
+ * navbuttons overlap minithubroll if there's many images
+*/
+
+body {
+ background-color: #dedfce;
+ margin: 0px 50px 0px 50px;
+ width: auto;
+ /*
+ margin: auto;
+ width: 780px;
+ */
+ font-family: "Bitstream Vera Sans", sans-serif;
+ font-size: 10pt;
+}
+
+img {
+ border: 0px;
+}
+
+a {
+}
+
+a:hover {
+}
+
+h1.title {
+ background-color: black;
+ font-size: 16pt;
+ color: #808080;
+ width: 100%;
+ margin-bottom: 0px;
+ padding: 5px;
+
+}
+
+.title a {
+ display: block;
+ position:relative;
+ width:100%;
+ height:48px;
+ margin:0; padding:0;
+}
+
+.title a span {
+ /* this overlays text below with an image */
+ display: block;
+ position:absolute; left:0; top:0; z-index:1;
+ width:400px; height:48px;
+ margin:0; padding:0;
+ background-image: url("title.png");
+ background-attachment: top left;
+ background-repeat: no-repeat;
+}
+
+div.thumbroll {
+ position: relative;
+ margin: 10px 0px 4px 0px;
+ min-height: 28px;
+}
+
+a#minus,a#plus {
+ display: block;
+ position: relative;
+ float: left;
+ width:24px;
+ height:24px;
+ margin:0px; padding:0px;
+}
+
+a#minus {
+ background: url("minus.png") top left no-repeat;
+}
+
+a#plus {
+ background: url("plus.png") top left no-repeat;
+}
+
+.navigation {
+ background-color: #505050;
+ width: 100%;
+ padding: 5px;
+ font-size: 10px;
+ clear: both;
+}
+
+.navigation a {
+ color: #a0a0a0;
+ font-weight: bold;
+}
+
+div.footer {
+ font-size: 9px;
+ background-color: #d9dac9;
+ width: 100%;
+ margin-top: 2em;
+ padding: 5px 5px 20px 5px;
+ clear: both;
+}
+
+div.year {
+ font-size: 11pt;
+ float: left;
+ margin: 10px;
+}
+
+div.month {
+ margin: 0px 0px 0px 2em;
+ padding: 2px;
+}
+
+div.month h4 {
+ margin: 0px 0px 3px 0px;
+}
+
+/* ul won't work on safari with float: left */
+div.month p {
+ margin: 2px;
+ padding: 0px 0px 0px 6px;
+ list-style: none;
+ font-size: 10px;
+}
+
+div#image {
+ position: relative;
+ display: block;
+ clear: both;
+ margin-left: auto;
+ margin-right: auto;
+ /* border: 1px solid black; */
+ min-height: 480px; /* only works in gecko :/ */
+ height: 500px;
+}
+
+img#preview {
+ position: absolute;
+ top: 0px;
+ right: 0px;
+ bottom: 0px;
+ left: 0px;
+ margin-left: auto;
+ margin-right: auto;
+ /* margin-left: -320px; later fixed by javascript; what a kludge this was */
+}
+
+div.comment {
+ margin: 2em 0px;
+ color: #808080;
+ font-size: 9px;
+}
+
+div.comment span {
+ color: black;
+ font-weight: bold;
+ font-size: 10px;
+}
+
+div.prevthumb,div.nextthumb {
+ position: absolute;
+ margin-bottom: 1em;
+ width: 120px;
+ height: 140px;
+}
+
+div.prevthub {
+ top: 0px;
+ left: 0px;
+ text-align: right;
+}
+
+div.nextthumb {
+ margin-left: auto;
+ right: 0px;
+ top: 0px;
+}
+
+div.nextthumb a,div.prevthumb a {
+ text-decoration: none;
+}
+
+div#mqhq a {
+ display: block;
+ border: 2px solid black;
+ padding: 2px;
+ font-size: 10px;
+ font-weight: bold;
+ background-color: #d1940c;
+ color: black;
+ float: left;
+ width: 48px;
+ text-align: center;
+ margin: 2px;
+
+}
+
+div.navbuttons {
+ position: absolute;
+ top: 140px; left: 50%;
+ margin-left: -50px;
+ width: 64px; height: 32px;
+ z-index: 1;
+}
+
+div.navbuttonsshell {
+ position: relative;
+ width: 100%;
+ margin: 2px;
+}
+
+div.navbuttonsshell a#previcon {
+ display: block;
+ position: absolute;
+ width: 24px; height: 24px;
+ margin: 2px; padding: 0;
+ top: 0px;
+ left: 0px;
+ color: #f6f6f6;
+ font-size: 30px; /* make unreadable */
+ text-indent: 2em; /* push it off screen, since khtml doesn't do 0px fonts */
+ overflow: hidden; /* hide the oveflow text */
+ background: url("left.png") top left no-repeat; /* have a pixmap */
+}
+
+div.navbuttonsshell a#nexticon {
+ display: block;
+ position: absolute;
+ width: 24px; height: 24px;
+ margin: 2px 4px 2px auto; padding: 0;
+ right: 4px; top: 0px;
+ color: #f6f6f6;
+ font-size: 30px; /* make unreadable */
+ text-indent: 2em; /* push it off screen, since khtml doesn't do 0px fonts */
+ overflow: hidden; /* hide the overflow text */
+ background: url("right.png") top left no-repeat; /* have a pixmap */
+}
+div#mqhq {
+ margin: 2px 2px 4px 0px;
+ height: 32px;
+}
+
+div.stylenavbar {
+ position:relative;
+ /*
+ left: 0px;
+ right: auto;
+ top:auto;
+ bottom:0px;
+ */
+ margin: 2px;
+ font-size: 9px;
+}
diff --git a/www/inc/styles/gorilla/left.png b/www/inc/styles/gorilla/left.png
new file mode 100644
index 0000000..63d306c
--- /dev/null
+++ b/www/inc/styles/gorilla/left.png
Binary files differ
diff --git a/www/inc/styles/gorilla/minus.png b/www/inc/styles/gorilla/minus.png
new file mode 100644
index 0000000..bc7a830
--- /dev/null
+++ b/www/inc/styles/gorilla/minus.png
Binary files differ
diff --git a/www/inc/styles/gorilla/plus.png b/www/inc/styles/gorilla/plus.png
new file mode 100644
index 0000000..6b103cd
--- /dev/null
+++ b/www/inc/styles/gorilla/plus.png
Binary files differ
diff --git a/www/inc/styles/gorilla/right.png b/www/inc/styles/gorilla/right.png
new file mode 100644
index 0000000..f998098
--- /dev/null
+++ b/www/inc/styles/gorilla/right.png
Binary files differ
diff --git a/www/inc/styles/gorilla/title.png b/www/inc/styles/gorilla/title.png
new file mode 100644
index 0000000..275528f
--- /dev/null
+++ b/www/inc/styles/gorilla/title.png
Binary files differ
diff --git a/www/inc/styles/ie/ie.css b/www/inc/styles/ie/ie.css
new file mode 100644
index 0000000..36cd2c4
--- /dev/null
+++ b/www/inc/styles/ie/ie.css
@@ -0,0 +1,8 @@
+/* IE sucks; this is the only stylesheet doesn't crash it
+ this is low priority for me; if you want a nice stylesheet for IE
+ (if such thing can be written), please send a patch to jimmac@ximian.com
+*/
+
+body {
+ font-family: Verdana, Sans-Serif;
+}
diff --git a/www/inc/stylesheet.inc.css b/www/inc/stylesheet.inc.css
new file mode 100644
index 0000000..9415271
--- /dev/null
+++ b/www/inc/stylesheet.inc.css
@@ -0,0 +1,141 @@
+<!--
+ body {
+ <?php if ($this->background) echo "background-image: url('" . $this->background . "');\n";?>
+ background-color: <?php echo $this->bgcolor?>;
+ font-family: <?php echo $this->font?>;
+ font-size: <?php echo $this->fontsize?>;
+ color: <?php echo $this->textcol?>;
+ }
+
+ a:link {
+ color: <?php echo $this->link?>;
+ }
+
+ a:visited {
+ color: <?php echo $this->vlink?>;
+ }
+
+ a:active {
+ color: <?php echo $this->alink?>;
+ }
+
+ a:hover {
+ color: <?php echo $this->hover?>;
+ }
+
+ td {
+ font-family: <?php echo $this->font?>;
+ font-size: <?php echo $this->fontsize?>;
+ }
+
+ input {
+ font-family: <?php echo $this->font?>;
+ font-size: <?php echo $this->fontsize?>;
+ }
+ .navigation {
+ color: white;
+ background-color: #808080;
+ padding-top: 2px;
+ padding-bottom: 3px;
+ padding-left: 4px;
+ padding-right: 4px;
+ }
+
+ p.exif {
+ font-size: 9px;
+ }
+
+ p.navigation a {
+ color: #f0f0f0;
+ font-weight: bold;
+ padding-top: 2px;
+ padding-bottom: 2px;
+ border: 0px;
+ text-align: left;
+ }
+
+ p.copyright {
+ clear: both;
+ padding-top: 4ex;
+ font-size: 9px;
+ text-align: left;
+ text-decoration: none;
+ }
+
+ h1 {
+ letter-spacing: .5em;
+ }
+
+ img {
+ /* makes really interesting stuff on nn4 ;)
+ display: inline; */
+ margin: 2px;
+ border-top: solid black 1px;
+ border-bottom: solid black 1px;
+ border-left: dotted #808080 1px;
+ border-right: dotted #808080 1px;
+ }
+
+ .navigation img, div.title img {
+ border: 0px;
+ margin: 0px;
+ text-align: left;
+ }
+
+ div.title {
+ font-size: 16pt;
+ font-weight: bold;
+ letter-spacing: .5em;
+ }
+
+ div.title a {
+ text-decoration: none;
+ }
+
+ p.image img {
+ /* margin-left: 10px; */
+ border: 0px;
+ margin: 0px;
+ text-align: center;
+ /*
+ border-bottom: 0px;
+ margin-bottom: 0px;
+ */
+ }
+
+ p.comment {
+ font-size: 10px;
+ text-align: justify;
+ color: #606060;
+ width: 640px;
+ /* margin-left: 130px; */
+ }
+
+ span {
+ color: black;
+ font-weight: bold;
+ }
+
+ img.thumb {
+ border: 1px black solid;
+ margin-top: 2px;
+ margin-bottom: 2px;
+ }
+
+ a:hover img.thumb {
+ border: 1px white solid;
+ }
+
+ div.year {
+ float: left;
+ margin: 2px 1em;
+ }
+
+ div.year p {
+ margin: 2px 2em;
+ }
+
+ div.year h4 {
+ margin: 1em 1em 2px 1em;
+ }
+-->
diff --git a/www/inc/www.class.inc.php b/www/inc/www.class.inc.php
new file mode 100644
index 0000000..6fa319e
--- /dev/null
+++ b/www/inc/www.class.inc.php
@@ -0,0 +1,210 @@
+<?php
+// www.class.inc.php
+class C_www {
+ var $background, $bgcolor, $link, $vlink, $alink, $hover, $language;
+ var $textcol, $font, $fontsize;
+
+ function C_www ($bgcolor="#ffffff", $link="blue", $vlink="#000000",
+ $alink="red", $hover="green",
+ $font="Bitstream Vera Sans, sans-serif",
+ $fontsize="11px", $textcol="black") {
+ #init colors etc
+
+ $this->bgcolor = $bgcolor;
+ $this->link = $link;
+ $this->vlink = $vlink;
+ $this->alink = $alink;
+ $this->hover = $hover;
+ $this->font = $font;
+ $this->fontsize = $fontsize;
+ $this->textcol = $textcol;
+ }
+
+ ////
+ // !vykpise HTML hlavicku dokumentu
+ // Ten CSS style jeste neni moc dodelanej
+ function header($title) {
+ global $gallery_dir,$root, $snimek, $galerie, $ThisScript, $themes;
+
+ echo "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\"\n";
+ echo " \"http://www.w3.org/TR/2000/REC-xhtml1-20000126/DTD/xhtml1-strict.dtd\">\n";
+
+ echo "<html>\n";
+ echo "<head>\n";
+ echo " <title>$title</title>\n";
+ # mozilla style links
+ if ($snimek && $galerie) {
+ #Top
+ echo " <link rel=\"Top\" href=\"$ThisScript\" />\n";
+ #First
+ #Prev
+ $predchozi = $snimek - 1;
+ $dalsi = $snimek + 1;
+ if ($snimek > 1) {
+ echo " <link rel=\"First\" ";
+ echo " href=\"$ThisScript?galerie=$galerie&amp;snimek=1\" />\n";
+ echo " <link rel=\"Previous\" ";
+ echo "href=\"$ThisScript?galerie=$galerie&amp;snimek=$predchozi\" />\n";
+ }
+ #Next
+ if (is_file("$gallery_dir/$galerie/lq/img-$dalsi.jpg")) {
+ echo " <link rel=\"Next\" ";
+ echo " href=\"$ThisScript?galerie=$galerie&amp;snimek=$dalsi\" />\n";
+ }
+ #Last
+ $adr = opendir("$gallery_dir/$galerie/thumbs/");
+ $i = -2;
+ while ($file = readdir($adr)) {
+ $i++;
+ }
+ if ($i!=$snimek) {
+ echo " <link rel=\"Last\" ";
+ echo " href=\"$ThisScript?galerie=$galerie&amp;snimek=$i\" />\n";
+ }
+ }
+
+ /* check the theme in a cookie */
+ $theme = $_COOKIE["theme"];
+ if (!$theme) { //we didn't set the cookie yet
+ if (browserCheck()=="ie6+" || browserCheck()=="ie4+") {
+ $theme = "ie"; //IE crashes on other themes
+ } else {
+ $theme = "default";
+ }
+ }
+ foreach ($themes as $skin => $url) {
+ echo "<link type=\"text/css\" rel=\"";
+ if ($skin==$theme) {
+ echo "stylesheet";
+ } else {
+ echo "alternate stylesheet";
+ }
+ echo "\" href=\"$url\" title=\"$skin\"";
+ echo " media=\"screen\" />\n";
+ }
+
+ require("javascript.inc.php");
+ echo "</head>\n\n";
+ echo "<body onload=\"checkForTheme()";
+ echo "\">\n";
+ }
+
+ ////
+ // !zavre html stranku
+ function footer() {
+ echo "</body>\n";
+ echo "</html>\n";
+ }
+
+ ////
+ // !vypise chybovou hlasku
+ // $title - nadpis a title HTML stranky
+ // $message - vlastni chybova hlaska
+ function error($title, $message) {
+ $this->header($title);
+ echo "<h1>$title</h1>\n";
+ echo $message;
+ $this->footer();
+ exit; //vysere se na vsechno
+ }
+
+
+
+ ////
+ // !zacatek fomrulare
+ function form_start($action, $method, $upload) {
+ echo "<form ";
+ if ($upload) echo "enctype=\"multipart/form-data\" ";
+ echo "target=\"_top\" action=\"$action\" method=\"$method\">\n";
+ echo "<table width=\"600\" border=\"0\">\n";
+ }
+
+ ////
+ // !konec formulare
+ function form_end() {
+ echo "</table>\n";
+ echo "</form>\n";
+ }
+
+ ////
+ // !vykresli polozku formulare
+ // umi text, password, submit, file, hidden, textarea, select
+ // u textarea je default pocet radku...
+ function input($type, $name, $value, $popis, $default) {
+ if ($type!="hidden") {
+ echo "<tr valign=\"top\">\n";
+ echo "<td>$popis</td>\n";
+ echo "<td>";
+ }
+ switch ($type) {
+ case "checkbox":
+ echo "<input type=\"$type\" name=\"$name\" value=\"$value\"";
+ if ($default) echo " checked";
+ echo ">";
+ break;
+ case "password":
+ case "text":
+ echo "<input type=\"$type\" size=\"30\" name=\"$name\" value=\"$value\">";
+ break;
+ case "file":
+ echo "<input type=\"$type\" size=\"30\" name=\"$name\">";
+ break;
+ case "hidden":
+ echo "<input type=\"$type\" name=\"$name\" value=\"$value\">\n";
+ break;
+ case "textarea":
+ echo "<textarea name=\"$name\" cols=\"40\"";
+ if ($default) {
+ echo " rows=\"$default\"";
+ } else {
+ echo " rows=\"10\"";
+ }
+ echo " wrap=\"virtual\">$value</textarea>";
+ break;
+ case "select":
+ echo "<select name=\"$name\" size=\"1\">\n";
+ while (list($optval, $option) = each($value)) {
+ echo "<option value=\"$optval\"";
+ if ($optval == $default) echo " selected";
+ echo ">";
+ echo $option;
+ echo "</option>\n";
+ }
+ echo "</select>";
+ break;
+ case "submit":
+ echo "<input type=\"$type\" name=\"$name\" value=\"$value\">";
+ break;
+ }
+ if ($type!="hidden") {
+ echo "</td>\n";
+ echo "</tr>\n";
+ }
+ }
+
+
+}
+
+# return dirs sorted
+class SortDir {
+ var $items;
+
+ function SortDir($directory) {
+ $handle=opendir($directory);
+ while ($file = readdir($handle)) {
+ if ($file != "." && $file != "..") {
+ $this->items[]=$file;
+ }
+ }
+ closedir($handle);
+ natsort($this->items);
+ }
+
+ function Read() {
+ $getback= (pos($this->items));
+ next($this->items);
+ return $getback;
+ }
+}
+
+?>
diff --git a/www/index.php b/www/index.php
new file mode 100644
index 0000000..0ef7bc8
--- /dev/null
+++ b/www/index.php
@@ -0,0 +1,284 @@
+<?php
+
+# uncomment this to check for uninitialized variables etc.:
+# error_reporting (E_ALL);
+
+# get variables from the _SERVER array in order to not
+# rely on register_globals = On
+# (this will not work with standalone PHP)
+$ThisScript=$_SERVER['PHP_SELF'];
+$ScriptFileName=$_SERVER['SCRIPT_FILENAME'];
+$HostName=$_SERVER['SERVER_NAME'];
+
+require("inc/config.inc.php");
+require("inc/www.class.inc.php");
+require("inc/funkce.inc.php");
+//session_name("navstevnik");
+//session_register("page");
+
+# always get sorted directory entries
+$adr = new SortDir("$gallery_dir");
+
+# get variables passed in from the URL:
+$galerie=$_GET["galerie"];
+$thumbsize=$_GET["thumbsize"];
+$snimek=$_GET["snimek"];
+$y=$_GET["y"];
+$cmnt=$_GET["cmnt"];
+$show_thumbs=$_GET["show_thumbs"];
+$exif_style=$_GET["exif_style"];
+
+$page = new C_www;
+//default colors
+
+if (!is_dir("$gallery_dir/$galerie/thumbs")) {
+ $galerie = "";
+}
+
+$page->header("Photos");
+require("inc/header.inc.php");
+
+// folder > tree
+echo "<div class=\"navigation\"><a href=\"$ThisScript\">Photo Gallery Index</a>";
+
+#########################################
+# Overall Gallery Index #
+#########################################
+if (!$galerie) {
+ # finish off navigation bar
+ echo "</div>\n\n";
+ /*
+ - nacti adresare
+ - setrid podle casu
+ - pro kazdy rok
+ - setrid podle mesice
+ - vypis
+ */
+# TODO: Make date file support date of the month
+# And add info to README about date files
+ while ($file = $adr->Read()) {
+ // checking for inc is only really needed when gallery_dir == $root
+ // hopefully not many galleries will be named inc ;)
+ if (is_dir("$gallery_dir/$file") && !ereg("\.", $file) && $file!="inc") {
+ // Use date file for gallery date if avaliable
+ $datefile = "$root/$gallery_dir/$file/date.txt";
+ if (file_exists($datefile)) {
+ $date_array = file($datefile);
+ $year=trim($date_array[2]);
+ $month=trim($date_array[1]);
+ $galerieyear["$file"]=$year;
+ $galeriemonth["$file"]=$month;
+ } else { // Get Dates from modification times
+ $mtime = filemtime("$gallery_dir/$file");
+ $galerieyear["$file"] = date("Y", $mtime);
+ $galeriemonth["$file"] = date("F", $mtime);
+ }
+ }
+ }
+
+ // re-sort array in order of months - so that they will be printed in order
+ $months = array("December", "November", "October", "September", "August", "July", "June", "May", "April", "March", "February", "January");
+ for ($i = 2010; $i >= 1990; $i--) {
+ foreach ($months as $thismonth) {
+ foreach ($galeriemonth as $foldername => $month) {
+ if (strcasecmp($month, $thismonth) == 0) {
+ if ($galerieyear["$foldername"] == $i) {
+ $galerieyearordered["$foldername"]=$galerieyear["$foldername"];
+ $galeriemonthordered["$foldername"]=$galeriemonth["$foldername"];
+ }
+ }
+ }
+ }
+ }
+
+ foreach ($galerieyearordered as $file => $mtime) {
+ $year=$galerieyearordered["$file"];
+ $month=$galeriemonthordered["$file"];
+ if ($thisyear!=$year) { #if the year is not equal to the current year
+ #This is the first year
+ if ($thisyear) { echo " </div>\n</div>\n";}// end last year if this is
+ // not the first one
+ #This is a new year
+ unset($thismonth);
+ echo "<div class=\"year\"><h3>$year</h3>\n";
+ echo "";
+ }
+ # now months
+ if ($thismonth!=$month) {
+ #first one
+ if ($thismonth) { echo " </div>\n"; } // end of last month if
+ // this is not the first one
+ #new month
+ echo " <div class=\"month\"><h4>$month</h4>\n";
+ }
+
+ echo " <p><a href=\"$ThisScript?galerie=$file\">$file</a></p>\n";
+ $thisyear=$year;
+ $thismonth=$month;
+ }
+ echo " </div>\n</div>\n\n";
+
+##############################
+# Individual Gallery Index #
+##############################
+} elseif (!$snimek) {
+ # finish off navigation header
+ echo "\n &gt; $galerie</div>\n\n<p class=\"bigthumbnails\">\n";
+ //thumbnails
+ $path = "$gallery_dir/$galerie/thumbs";
+ $obrazky = new SortDir($path);
+ check($galerie); // check for nasty input
+ while ($file = $obrazky->read()) {
+ if (is_file("$path/$file") && eregi("^img-([0-9]+)\.(png|jpg)", $file, $x)) {
+ $thumb = "$gallery_dir/$galerie/thumbs/img-${x[1]}.${x[2]}";
+ $velikost = getimagesize("$root/$thumb");
+ echo " <a href=\"$ThisScript?galerie=$galerie&amp;snimek=${x[1]}\">";
+ echo "<img ";
+ if ($thumbsize) {
+ echo "width=\"120\" height=\"80\" ";
+ } else {
+ // scale portraits to 80 height
+ if ($velikost[0]>90) {
+ echo $velikost[3];
+ } else {
+ echo "width=\"";
+ $scaled = round($velikost[0] / 1.5);
+ echo $scaled;
+ echo "\" height=\"${velikost[0]}\"";
+ }
+ }
+ echo " src=\"$thumb\" ";
+ echo "alt=\"photo No. ${x[1]}\" />";
+ echo "</a>\n";
+ }
+ }
+ echo "</p>\n";
+ //and links to archived images:
+ echo "\n<p class=\"archives\">\n";
+ if (file_exists("$gallery_dir/$galerie/zip/mq.zip")) {
+ echo "[ <a href=\"$gallery_dir/$galerie/zip/mq.zip\">zipped MQ images</a> ] ";
+ }
+ if (file_exists("$gallery_dir/$galerie/zip/mq.tar.bz2")) {
+ echo "[ <a href=\"$gallery_dir/$galerie/zip/mq.tar.bz2\">MQ images tarball</a> ] ";
+ }
+ if (file_exists("$gallery_dir/$galerie/zip/hq.zip")) {
+ echo "[ <a href=\"$gallery_dir/$galerie/zip/hq.zip\">zipped HQ images</a> ]";
+ }
+ if (file_exists("$gallery_dir/$galerie/zip/hq.tar.bz2")) {
+ echo "[ <a href=\"$gallery_dir/$galerie/zip/hq.tar.bz2\">HQ images tarball</a> ]";
+ }
+ echo "</p>";
+
+#################################
+# Individual Image #
+#################################
+} else { //low-res image
+ # finish off header
+ echo "\n &gt; <a href=\"$ThisScript?galerie=$galerie\">$galerie</a>\n &gt; Photo";
+ echo " $snimek</div>";
+ $path = "$gallery_dir/$galerie/thumbs";
+ $obrazky = new SortDir("$path");
+ check($galerie);
+ $path = "$gallery_dir/$galerie/lq";
+ $file = "$path/img-$snimek.jpg";
+ if (!file_exists($file)) {
+ echo "No such image";
+ $page->footer();
+ exit;
+ }
+ $velikost = getimagesize("$root/$file");
+ /*
+ navigation($galerie, $snimek, null);
+ */
+
+ // mini thumbnail roll
+
+ if ($show_thumbs) {
+ echo "\n<!--mini thumbnail roll-->\n<div class=\"thumbroll\">";
+ echo "<a id=\"minus\" href=\"$ThisScript?galerie=$galerie&amp;snimek=$snimek";
+ echo "&amp;exif_style=$exif_style\">";
+ echo "</a>\n";
+ echo " : \n";
+ while ($thumbfile = $obrazky->read()) {
+ if ( eregi("^img-([0-9]+)\.(png|jpg)",
+ $thumbfile, $x)) {
+ $thumb = "$gallery_dir/$galerie/thumbs/img-${x[1]}.${x[2]}";
+ echo " <a href=\"$ThisScript?galerie=$galerie&amp;snimek=${x[1]}";
+ echo "&amp;show_thumbs=$show_thumbs&amp;exif_style=$exif_style\">";
+ echo "<img class=\"thumb\" ";
+ // hadess' hack (TM) ;)
+ if ($thumbsize) {
+ echo " width=\"24\" height=\"16\"";
+ } else {
+ $minithumb=getimagesize("$root/$thumb");
+ $w=$minithumb[0]/6;
+ $h=$minithumb[1]/6;
+ echo " width=\"$w\" height=\"$h\"";
+ }
+ echo " src=\"$thumb\" ";
+ echo "alt=\"photo No. ${x[1]}\" />";
+ echo "</a> \n";
+ }
+ }
+ if (file_exists("$gallery_dir/$galerie/zip/hq.zip")) {
+ echo "<a id=\"zip\" href=\"$gallery_dir/$galerie/zip/hq.zip\">";
+ echo "zip<span /></a>";
+ }
+ if (file_exists("$gallery_dir/$galerie/zip/hq.tar.bz2")) {
+ echo "<a id=\"zip\" href=\"$gallery_dir/$galerie/zip/hq.tar.bz2\">";
+ echo "zip<span /></a>";
+ }
+ echo "</div>\n";
+ } else {
+ // show the popup button
+ echo "\n<!--mini thumbnail popup-->\n<div class=\"thumbroll\">";
+ echo "<a id=\"plus\" href=\"$ThisScript?galerie=$galerie&amp;snimek=$snimek";
+ echo "&amp;exif_style=$exif_style&amp;show_thumbs=yes\">";
+ echo "</a>\n";
+ echo "</div>\n";
+ }
+
+ /* main image + thumbnail navigation (prev/next) */
+
+ $divheight = $velikost[1] + 10;
+ echo "<div id=\"image\" style=\"height: ${divheight}px\">\n"; // extra kludge
+ // because of tall
+ // images
+
+ echo "<img id=\"preview\" ${velikost[3]} src=\"$file\" alt=\"$snimek\" />\n";
+ navigation($galerie, $snimek, "prev");
+ navigation($galerie, $snimek, "next");
+ echo "</div>\n"; //image
+
+
+ if ($exif_prog) require("$root/inc/exif.inc.php"); // FIXME: prettify
+ $comment = "$root/$gallery_dir/$galerie/comments/$snimek.txt";
+ if (file_exists($comment)) {
+ $cmnt_array = file($comment);
+ while ($x = current($cmnt_array)) {
+ eregi("^ *(.*) *", $x, $y);
+ $cmnt .= $y[1];
+ next($cmnt_array);
+ }
+ /* php4 only
+ foreach ($cmnt_array as $x) {
+ $cmnt .= $x;
+ }
+ */
+ echo "<div class=\"comment\">$cmnt</div>";
+ }
+ echo "<div id=\"mqhq\">";
+ if (file_exists("$gallery_dir/$galerie/mq/img-$snimek.jpg")) {
+ echo "<a href=\"$gallery_dir/$galerie/mq/img-$snimek.jpg\">MQ</a> ";
+ }
+ if (file_exists("$gallery_dir/$galerie/hq/img-$snimek.jpg")) {
+ echo "<a href=\"$gallery_dir/$galerie/hq/img-$snimek.jpg\">HQ</a>";
+ }
+ echo "</div>\n"; //mqhq
+
+ navigation($galerie, $snimek, null);
+}
+
+require("inc/footer.inc.php");
+$page->footer();
+?>
diff --git a/www/left.png b/www/left.png
new file mode 100644
index 0000000..63d306c
--- /dev/null
+++ b/www/left.png
Binary files differ
diff --git a/www/logo-mini.png b/www/logo-mini.png
new file mode 100644
index 0000000..8949154
--- /dev/null
+++ b/www/logo-mini.png
Binary files differ
diff --git a/www/logo.png b/www/logo.png
new file mode 100644
index 0000000..24878c3
--- /dev/null
+++ b/www/logo.png
Binary files differ
diff --git a/www/minus.png b/www/minus.png
new file mode 100644
index 0000000..bc7a830
--- /dev/null
+++ b/www/minus.png
Binary files differ
diff --git a/www/plus.png b/www/plus.png
new file mode 100644
index 0000000..6b103cd
--- /dev/null
+++ b/www/plus.png
Binary files differ
diff --git a/www/right.png b/www/right.png
new file mode 100644
index 0000000..f998098
--- /dev/null
+++ b/www/right.png
Binary files differ
diff --git a/www/top.png b/www/top.png
new file mode 100644
index 0000000..8cc26b4
--- /dev/null
+++ b/www/top.png
Binary files differ
diff --git a/www/zip.png b/www/zip.png
new file mode 100644
index 0000000..b52d1d7
--- /dev/null
+++ b/www/zip.png
Binary files differ