\documentclass[svgnames]{l3doc}
\usepackage{pdfpages, twemojis}
\usepackage[osf, mono = false]{libertine}
\usepackage[fontset = fandol, linespread = 1.2, autoindent = 0pt]{ctex}
\AddToHook{env/function/before}{\vspace*{-.5\baselineskip}}
\ExplSyntaxOn \makeatletter
\DeclareDocumentCommand \key { s m }
  {
    \IfBooleanTF {#1} { \textcolor{red}{\ttfamily \bfseries #2} }
      {
        \ttfamily
        \seq_set_from_clist:Nn \l_tmpa_seq {#2}
        \seq_set_map:NNn \l_tmpb_seq \l_tmpa_seq
          { \exp_not:n { \textcolor{red}{\bfseries ##1} } }
        \seq_use:Nn \l_tmpb_seq { ,~ } \:=\:
      }
  }
\DeclareCommandCopy \val \meta
\def \TFF {true\textup{\textbar\underline{\textbf{false}}}}
\def \TTF {\textup{\underline{\textbf{true}}\textbar}false}
\def \HoLogo@ApLaTeX #1{
  \HOLOGO@mbox {A\kern -.05em p\kern -.05em \hologo{LaTeX}}}
\makeatother \ExplSyntaxOff
\newlist{keyval}{itemize}{10}
\setlist[keyval]{leftmargin = 0pt, labelsep = 0pt}
\makeindex
\title{^^A
  \bfseries \cls{litetable} 宏包 --- 多彩的課程表\thanks{^^A
    \url{https://github.com/myhsia/litetable},
    \url{https://ctan.org/pkg/litetable}^^A
  }^^A
}
\author{^^A
  夏明宇 \texttt{<^^A
    \href{mailto:xiamingyu@westlake.edu.cn}{xiamingyu@westlake.edu.cn}>^^A
  }\thanks{^^A
    \href{https://github.com/ljguo1020}{郭李軍}^^A
    開發了解析 \meta{left} \texttt{->} \meta{right} 型數據結構的接口.^^A
  }^^A
}
\date{Released 2025-08-20\quad \texttt{v3.7B}}

\begin{document}

\maketitle

\begin{documentation}

\section{介紹}

\pkg{litetable} 宏包提供了一個多彩的課程表設計,
基於 Ti\textit k\/Z
由 \pkg{expl3} 開發.
支援 \hologo{pdfLaTeX},\hologo{XeLaTeX},\hologo{ApLaTeX} 同
\hologo{LuaLaTeX} 等多種編譯方式. 點擊跳轉
\href{http://mirrors.ctan.org/macros/latex/contrib/litetable/litetable.pdf}{[\textsf{English}]}
\href{http://mirrors.ctan.org/macros/latex/contrib/litetable/litetable-zh-cn.pdf}{[\textsf{简体中文}]} 手册.

\section{用户接口}

要加載此宏包,只需寫下
\begin{quote}
  |\usepackage{litetable}|
\end{quote}

\DescribeEnv{litetable}
環境 \env{litetable} 可生成空白課程表,
需在命令 \cs{timelist} 同 \cs{weeklist} 後執行
\begin{quote}
  |\begin{litetable}|
    \oarg{keys} \marg{title} \oarg{keys}| ... |%
  |\end{litetable}|
\end{quote}
强制參數用於設定課程表標題,
可選參數接受以下鍵
\begin{keyval}
  \item [\key{scale}] \textcolor{gray}{\val{float} 可設定課程表的縮放比例(默認值: |1.0|).}
  \item [\key{color}] \val{color} 可設定課程表框架的背景色
  (默認值:|gray|),鍵名可省略.
  \item [\key{sem}] \val{string}
  可設定頁面右上角的學期信息.
  \item [\key{hline}] \val{string} 可設定水平线的樣式
  (默認值:|solid|).
\end{keyval}

\begin{function}{\weeklist}
  \begin{syntax}
    \cs{weeklist} \oarg{keys} \marg{list} \oarg{keys}
  \end{syntax}
  强制參數接收數組,
  用於設定課程表頂部的工作日列表同列寬.
  可選參數接受以下鍵
  \begin{keyval}
    \item [\key{format}] \val{format commands}
    可設置工作日列表格式(默認值:|\bfseries|).
    \item [\key{sep}] \val{string}
    可設定工作日列表的分隔符.
  \end{keyval}
  \begin{verbatim}
    \weeklist [ format = \bfseries \scshape, sep = \textbar ]
      { Mon -> 1.05, Tue -> 1.05, Wed -> 1.1, Thu -> 1.1, Fri -> .9 }
  \end{verbatim}
\end{function}

\begin{function}{\timelist}
  \begin{syntax}
    \cs{timelist} \oarg{keys} \marg{list} \oarg{keys}
  \end{syntax}
  强制參數均接收數組,用於設置課程表的左側的時間列表.
  可選參數接受以下鍵
  \begin{keyval}
    \item [\key{numformat}] \val{format}
    可設定時間列表的序號字體
    (默認值:|\ttfamily \bfseries|).
    \item [\key{timeformat}] \val{format} 可設定時間列表的時間字體
    (默認值:|\ttfamily|).
    \item [\key{hidetime}] \val\TFF 用於隱藏時間列表中的時間,只保留序號
    (初始值:|false|).
  \end{keyval}
  \begin{verbatim}
    \timelist [ numformat = \bfseries, timeformat = \ttfamily ]
      { 08:30 -> 10:00, 10:30 -> 12:00, 13:00 -> 14:30, 15:00 -> 16:30 }
  \end{verbatim}
\end{function}

\begin{function}{\course}
  \begin{syntax}
    \cs{course} \oarg{keys} \marg{start} \oarg{keys} \marg{end} \oarg{keys}
  \end{syntax}
  用於在當前工作日添加課程盒子,
  需在 \env{litetable} 環境中執行.
  兩個强制參數分别用於設置課程的開始同結束序號.
  可選參數接收下列鍵
  \begin{keyval}
    \item [\key{color}] \val{color} 用於設置課程盒子的颜色
    (默認值:|teal|). 鍵名可省略.
    \item [\key{subject}] \val{string} 用於設置課程名稱.
    \item [\key{location}] \val{string} 用於設置課程地點.
    \item [\key{lecture}] \val{string} 用於設置授課教師.
    \item [\key{comment}] \val{string} 用於給課程添加脚注.
  \end{keyval}
  \begin{texnote}
    \begin{itemize}[leftmargin = 2em]
      \item 若 \meta{start} |=| \meta{end}(課程盒子的高度为 $1$),
      若 \key*{location} 和 \key*{lecture} 會輸出在同一行,
      而且 \key*{comment} 將隱藏.
      \item 即使誤將 \meta{start} 同 \meta{end} 寫反,
      模板也會自動糾正.
      \item 若 \key*{location} 同 \key*{lecture} 均未使用,
      則 \key*{subject} 將輸出在課程盒子的
      竖直方向中心.
      \item 超出課程表範圍的課程盒子將唔顯示,
      并會返回警告.
      輸入用例見 Appendix \ref{mwe}.
    \end{itemize}
  \end{texnote}
\end{function}

\begin{function}{\newday}
  \begin{syntax}
    \cs{newday} \oarg{integral value}
  \end{syntax}
  使其後面添加的課程盒子後移 \meta{intergal value} 個工作日.
  可選參數的默認值为 |1|.
\end{function}

\begin{function}{\more}
  \begin{syntax}
    \cs{more} \marg{comment}
  \end{syntax}
  在課程表的右下角添加備注.
\end{function}

\clearpage \appendix \linespread{1.25}

\section{工作範例} \label{mwe}

\verbatiminput{litetable-demo.tex}

\includepdf{litetable-demo.pdf}

\end{documentation}

\IndexPrologue{%
  \part*{索引}
  \markboth{索引}{索引}
  \addcontentsline{toc}{part}{索引}
  意大利體的數字表示描述對應索引項的頁碼;
  帶下劃綫的數字表示定義對應索引項的代碼行號;
  羅馬字體的數字表示使用對應索引項的代碼行號.
}

\PrintIndex

\end{document}