%---------------------------------------------------------------------- % % % 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 unify API -- see CellContent env... % XXX revise command naming -- should be obvious from name what is what: % - meta commands -- ??? (currently same as templates) % - general macros -- \usecell{..} % - templates -- \ImagePage{..} % XXX see where we need to \ignorespaces... % XXX might be a good idea to add a spine calculator... % XXX LEGACY BUG: fix \OFFSETFIX % % %---------------------------------------------------------------------- %%% NOTE: \def\@[A-Z]+ macros will be visible to both the %%% code and the generated docs... \edef\photobook@FILEVERSION{v0.1} \edef\photobook@FILEDATE{2021-07-28} %% \documentclass{ltxdoc} %% %% \usepackage[a4paper,margin=25mm,left=55mm,nohead]{geometry} %% \usepackage[numbered]{hypdoc} %% \usepackage{doctools} %% \usepackage{environ} %% %%% \usepackage{imakeidx} %%% \makeindex[ %%% columns=3, %%% title=Alphabetical Index, %%% intoc, %%% options= -s photobook.cls] %% %%% \newcommand\DescribeGlobal[1]{% %%% \DescribeMacro{#1}} %% %% \newcommand\LEGACY{\fbox{LEGACY}} %% \newcommand\EXPERIMENTAL{\fbox{EXPERIMENTAL}} %% %% \setlength\parindent{0pt} %% \setlength\parskip{0.5em} %% %% \def\MetaDoc{} %% \NewEnviron{MetaDocSection}{% %% \global\edef\MetaDoc{% %% \MetaDoc% %% %% \BODY}} %% %% \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 legacy templates/commnads/macros will get reworked soon! } %% %% \tableofcontents %% %%%% 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=