%---------------------------------------------------------------------- % % % This does the following: % - sets up the document/pdf for viewing as a book % - adds support for page bleeds % - adds basic templates for image pages (XXX) % % % XXX see where we need to \ignorespaces... % % XXX BUG: fix \OFFSETFIX % % XXX might be a good idea to add a spine calculator... % %---------------------------------------------------------------------- %%% NOTE: \def\@[A-Z]+ macros will be visible to both the %%% code and the generated docs... \def\photobook@FILEVERSION{v0.1} \def\photobook@FILEDATE{2021-07-28} %% \documentclass{ltxdoc} %% %% \usepackage[a4paper,margin=25mm,left=55mm,nohead]{geometry} %% \usepackage[numbered]{hypdoc} %% \usepackage{doctools} %% %%% \newcommand\DescribeGlobal[1]{% %%% \DescribeMacro{#1}} %% %% \newcommand\LEGACY{\fbox{LEGACY}} %% %% \setlength\parindent{0pt} %% \setlength\parskip{0.5em} %% %% \begin{document} %% %% \title{\textsf{photobook} --- Document class for building photo-books %% \thanks{This file describes version \FILEVERSION, %% last revised \FILEDATE.}} %% %% \author{Alex A. Naanou\thanks{E-mail: alex.nanou@gmail.com}} %% %% \date{Released \FILEDATE} %% %% \maketitle %% %% \fbox{\bf% %% Note: all older templates/commnads/macros will get reworked soon! } %% %%%% Usage % %% >> \documentclass[]{photobook} %% % %---------------------------------------------------------------------- \NeedsTeXFormat{LaTeX2e} \ProvidesClass{photobook} [\photobook@FILEDATE \space \photobook@FILEVERSION Photo book document class] % - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - %%%% Options %% \RequirePackage{kvoptions} % - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - % Helpers... \newcommand\@DeclareLiteralOptionTo[2]{% \DeclareVoidOption{#2}{% \expandafter\edef\csname photobook@#1\endcsname{#2}}} % - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - %%%%% Page geometry % %% \DescribeMacro{blockwidth=} %% \DescribeMacro{blockheight=} %% \DescribeMacro{bindingoffset=} %% \DescribeMacro{bleed=} % %% This is similar to what |geometry| does, but adds bleed support. %% %% \begin{minipage}{\textwidth} %% \begin{verbatim} %% %% <---> bleed <---> bleed %% %% + - - - - - - - - - - - - - - - - - - - - - + - + ^ %% . . . | bleed %% . +--------------------------------------+----- v . . --- %% . | ^ . = . %% . | . . . . . . | . . = . ^ %% . |<-- blockwidth ----------------------->= . | %% . | . | . . = . | %% . | | . = . textheight %% . | . Page | . . = . | %% . | blockheight . = . | %% . | . | . . = . | %% . | | <---> bindingoffset | %% . | . . . . . . | . . = . v %% . | v . = . %% . +---------------------------------------+----- ^ . . --- %% . . . . | bleed %% + - - - - - - - - - - - - - - - - - - - - - + - + v %% . . %% | <-- textwidth --------------> . | %% ^ binding line %% %% \end{verbatim} %% \end{minipage} %% % % NOTE: if blockwidth/blockheight are set they will force recalculations % and overriding of the paperwidth/paperheight if they were changed % by the user code anywhere between \documentclass[..]{photobook} % and \begin{document}... \DeclareStringOption{blockwidth} \DeclareStringOption{blockheight} \DeclareStringOption[0pt]{bindingoffset}[10mm] \DeclareStringOption[5mm]{bleed}[5mm] %%%%% layout % %% \DescribeMacro{layoutmode=} %% \DescribeMacro{block} %% \DescribeMacro{endpaper} %% \DescribeMacro{cover} %% \DescribeMacro{jacket} %% %% >> layoutmode=