diff --git a/packages/preview/tgm-hit-thesis/0.3.0/.gitignore b/packages/preview/tgm-hit-thesis/0.3.0/.gitignore new file mode 100644 index 0000000000..e69de29bb2 diff --git a/packages/preview/tgm-hit-thesis/0.3.0/CHANGELOG.md b/packages/preview/tgm-hit-thesis/0.3.0/CHANGELOG.md new file mode 100644 index 0000000000..ac4bf4b4b6 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/CHANGELOG.md @@ -0,0 +1,104 @@ +# Changelog + +All notable changes to this project will be documented in this file. + +The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/), +and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). + +## [Unreleased] + +
+Migration guide from v0.1.x + + + +
+ +### Added + +### Changed + +### Deprecated + +### Removed + +### Fixed + +### Security + +## [0.3.0] - 2025-03-13 + +
+Migration guide from v0.2.x + +To get a feeling what you need to change, compare [`template/main.typ`](https://github.com/TGM-HIT/typst-diploma-thesis/blob/v0.3.0/template/main.typ) with what you have. In particular, you will probably need to + +- add a parameter `read: path => read(path),` to the initial `thesis()` template call +- remove `strict-chapter-end: true,` if you were using it +- remove all instances of `#chapter-end()` + +Additionally, you should have a look at [`template/bibliography.bib`](https://github.com/TGM-HIT/typst-diploma-thesis/blob/v0.3.0/template/bibliography.bib#L42-L46) which demonstrates how to cite a prompt. +A (German) prose explanation of the usage of prompts can be found in the [Example document](https://github.com/TGM-HIT/typst-diploma-thesis/blob/v0.3.0/example.pdf), section 1.2 _Promptverzeichnis_. + +
+ +### Added +- BREAKING: `thesis()` has an extra `read` parameter for initializing Alexandria +- There is now a separate List of Prompts + +### Changed +- BREAKING: in `glossary-entry()`, the `desc` parameter is now named `description` +- for glossary entries, having only a `long` form is not permitted +- bibliography is now handled by Alexandria +- inline quotes with attribution now display that attribution + +### Removed +- BREAKING: `chapter-end()` and `strict-chapter-end` have been removed + +### Fixed +- setup of the `i-figured` package works again +- the template is now compatible with Typst 0.13 +- descriptions of glossary items are no longer ignored +- an empty glossary is now automatically hidden + +### Security + +## [0.2.0] - 2024-10-23 + +### Changed +- long chapter titles now look nicer in the header +- **breaking:** glossary entries are now defined differently, see [the diff of the template](https://github.com/TGM-HIT/typst-diploma-thesis/commit/8c4d03a14ac3ddab6718cc7e11341924c66703bd#diff-7c3fcb5c97b51160af4b4a26981b152d6995f8ec0077281456d3f51f4b0e9d84) for an example +- **regression:** if there are no glossary references, an empty glossary section will be shown (glossarium 0.5 hides a couple private functions, see [glossarium#70](https://github.com/typst-community/glossarium/issues/70)) + +### Fixed +- fix deprecation warnings and incompatibilities introduced in 0.12, in part by updating codly, glossarium and outrageous + +## [0.1.3] - 2024-09-14 + +### Changed +- get rid of more custom outline styling thanks to outrageous:0.2.0 + +## [0.1.2] - 2024-09-14 + +(this version was released in a broken state) + +## [0.1.1] - 2024-09-09 + +### Added +- adds support for highlighting authors of individual pages of the thesis, which is a requirement for the thesis' grading + +### Changed +- replaces some custom outline styling with [outrageous](https://typst.app/universe/package/outrageous) + +## [0.1.0] - 2024-07-13 + +Initial Release + + +[Unreleased]: https://github.com/TGM-HIT/typst-diploma-thesis/compare/v0.2.0...HEAD +[0.3.0]: https://github.com/TGM-HIT/typst-diploma-thesis/releases/tag/v0.3.0 +[0.2.0]: https://github.com/TGM-HIT/typst-diploma-thesis/releases/tag/v0.2.0 +[0.1.3]: https://github.com/TGM-HIT/typst-diploma-thesis/releases/tag/v0.1.3 +[0.1.2]: https://github.com/TGM-HIT/typst-diploma-thesis/releases/tag/v0.1.2 +[0.1.1]: https://github.com/TGM-HIT/typst-diploma-thesis/releases/tag/v0.1.1 +[0.1.0]: https://github.com/TGM-HIT/typst-diploma-thesis/releases/tag/v0.1.0 diff --git a/packages/preview/tgm-hit-thesis/0.3.0/LICENSE b/packages/preview/tgm-hit-thesis/0.3.0/LICENSE new file mode 100644 index 0000000000..52b4250d96 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2024 Clemens Koza + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/packages/preview/tgm-hit-thesis/0.3.0/README.md b/packages/preview/tgm-hit-thesis/0.3.0/README.md new file mode 100644 index 0000000000..f971b024d5 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/README.md @@ -0,0 +1,17 @@ +# TGM HIT diploma thesis template + +This is a port of the [LaTeX diploma thesis template](https://github.com/TGM-HIT/diploma-thesis) available for students of the information technology department at the TGM technical secondary school in Vienna. + +## Getting Started + +Using the Typst web app, you can create a project by e.g. using this link: https://typst.app/?template=tgm-hit-thesis&version=latest. + +To work locally, use the following command: + +```bash +typst init @preview/tgm-hit-thesis +``` + +## Usage + +The template ([rendered PDF](example.pdf)) contains thesis writing advice (in German) as example content. If you are looking for the details of this template package's function, take a look at the [manual](docs/manual.pdf). diff --git a/packages/preview/tgm-hit-thesis/0.3.0/docs/manual.pdf b/packages/preview/tgm-hit-thesis/0.3.0/docs/manual.pdf new file mode 100644 index 0000000000..95bb2cebec Binary files /dev/null and b/packages/preview/tgm-hit-thesis/0.3.0/docs/manual.pdf differ diff --git a/packages/preview/tgm-hit-thesis/0.3.0/example.pdf b/packages/preview/tgm-hit-thesis/0.3.0/example.pdf new file mode 100644 index 0000000000..dc586f372a Binary files /dev/null and b/packages/preview/tgm-hit-thesis/0.3.0/example.pdf differ diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/assets.typ b/packages/preview/tgm-hit-thesis/0.3.0/src/assets.typ new file mode 100644 index 0000000000..b4d7fc23d9 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/src/assets.typ @@ -0,0 +1 @@ +#import "assets/mod.typ": * \ No newline at end of file diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/assets/logo-left.png b/packages/preview/tgm-hit-thesis/0.3.0/src/assets/logo-left.png new file mode 100644 index 0000000000..b55699f535 Binary files /dev/null and b/packages/preview/tgm-hit-thesis/0.3.0/src/assets/logo-left.png differ diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/assets/logo-right.png b/packages/preview/tgm-hit-thesis/0.3.0/src/assets/logo-right.png new file mode 100644 index 0000000000..4fea8f2911 Binary files /dev/null and b/packages/preview/tgm-hit-thesis/0.3.0/src/assets/logo-right.png differ diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/assets/mod.typ b/packages/preview/tgm-hit-thesis/0.3.0/src/assets/mod.typ new file mode 100644 index 0000000000..a378d9bf18 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/src/assets/mod.typ @@ -0,0 +1,11 @@ +/// The TGM logo. This is a partially applied function and thus can accept most of the parameters +/// that ```typc image()``` can. +/// +/// -> content +#let tgm-logo = image.with("logo-left.png") + +/// The HTL logo. This is a partially applied function and thus can accept most of the parameters +/// that ```typc image()``` can. +/// +/// -> content +#let htl-logo = image.with("logo-right.png") diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/bib.typ b/packages/preview/tgm-hit-thesis/0.3.0/src/bib.typ new file mode 100644 index 0000000000..4adab1049c --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/src/bib.typ @@ -0,0 +1 @@ +#import "@preview/alexandria:0.1.3" as alexandria: load-bibliography as bibliography diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/glossary.typ b/packages/preview/tgm-hit-thesis/0.3.0/src/glossary.typ new file mode 100644 index 0000000000..5790ca4f4d --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/src/glossary.typ @@ -0,0 +1,77 @@ +#import "@preview/glossarium:0.5.2" as glossarium: make-glossary, gls, agls, glspl + +#let _glossary_entries = state("thesis-glossary-entries") + +#let register-glossary(..entries) = { + assert.eq(entries.named(), (:), message: "no named arguments allowed") + let entries = entries.pos() + glossarium.register-glossary(entries) + _glossary_entries.update(entries) +} + +/// Stores a glossary entry for this thesis. One call to this function is equivalent to one array +/// entry in Glossarium's ```typc print-glossary()```'s main parameter. +/// +/// -> content +#let glossary-entry( + /// The key with which the glossary entry can be referenced; must be unique. + /// -> string + key, + /// Mandatory; the short form of the entry shown after the term has been first defined. + /// -> string + short: none, + /// The long form of the term, displayed in the glossary and on the first citation of the term. + /// -> string | content + long: none, + /// The description of the term. + /// -> string | content + description: none, + /// The pluralized short form of the term. + /// -> string | content + plural: none, + /// The pluralized long form of the term. + /// -> string | content + longplural: none, + /// The group the term belongs to. The terms are displayed by groups in the glossary. + /// -> string + group: none, +) = { + assert(short != none or long != none, message: "short or long form of glossary-entry is mandatory") + + let entry = ( + key: key, + short: short, + long: long, + description: description, + plural: plural, + longplural: longplural, + group: group, + ) + let entry = for (k, v) in entry { + if v != none { + ((k): v) + } + } + + entry +} + +/// Displays a glossary of the entries added via @@glossary-entry(). +/// +/// -> content +#let print-glossary( + /// A (level 1) heading that titles this glossary. If the glossary is empty, the title is not shown. + /// -> content + title: none, + /// Any extra parameters to the glossarium function of the same name. + /// -> arguments + ..args, +) = context { + let entries = _glossary_entries.get() + + if glossarium.there-are-refs() or args.named().at("show-all", default: false) { + title + } + + glossarium.print-glossary(entries, ..args) +} diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/l10n.toml b/packages/preview/tgm-hit-thesis/0.3.0/src/l10n.toml new file mode 100644 index 0000000000..8d39e9a096 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/src/l10n.toml @@ -0,0 +1,73 @@ +[conf] +default-lang = "en" + +[lang.en] +thesis = "Diploma Thesis" +supervisor = "Supervisor" +performed-in-year = "Performed in the school year" +submission-note = "Submission note" +approved = "Approved" + +declaration-title = "Statutory declaration" +# declaration-text = """ +# I declare that I have authored this thesis independently, that I have not used \ +# other than the declared sources and that I have explicitly marked all material \ +# which has been quoted either literally or by content from the used sources. +# """ +# declaration-ai-clause = """ +# I also used the following generative AI tools [e.g. ChatGPT, Grammarly Go, \ +# Midjourney] for the following purpose: +# """ +location-date = "Location, Date" + +chapter = "Chapter" +section = "Section" +abstract = "Abstract" + +figure = "Figure" +table = "Table" +listing = "Listing" + +contents = "Contents" +bibliography = "Bibliography" +prompts = "List of Prompts" +list-of-figures = "List of Figures" +list-of-tables = "List of Tables" +list-of-listings = "List of Listings" +glossary = "Glossary" + +[lang.de] +thesis = "Diplomarbeit" +supervisor = "Betreuer" +performed-in-year = "Ausgeführt im Schuljahr" +submission-note = "Abgabevermerk" +approved = "Übernommen von" + +declaration-title = "Eidesstattliche Erklärung" +# declaration-text = """ +# Ich erkläre an Eides statt, dass ich die vorliegende Arbeit selbstständig \ +# verfasst, andere als die angegebenen Quellen/Hilfsmittel nicht benutzt und die \ +# den benutzten Quellen wörtlich und inhaltlich entnommenen Stellen als solche \ +# kenntlich gemacht habe. +# """ +# declaration-ai-clause = """ +# Für die Erstellung der Arbeit habe ich auch folgende Hilfsmittel generativer \ +# KI-Tools [z. B. ChatGPT, Grammarly Go, Midjourney] zu folgendem Zweck verwendet: +# """ +location-date = "Ort, Datum" + +chapter = "Kapitel" +section = "Abschnitt" +abstract = "Kurzfassung" + +figure = "Abbildung" +table = "Tabelle" +listing = "Auflistung" + +contents = "Inhaltsverzeichnis" +bibliography = "Literaturverzeichnis" +prompts = "Promptverzeichnis" +list-of-figures = "Abbildungsverzeichnis" +list-of-tables = "Tabellenverzeichnis" +list-of-listings = "Auflistungsverzeichnis" +glossary = "Glossar" diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/l10n.typ b/packages/preview/tgm-hit-thesis/0.3.0/src/l10n.typ new file mode 100644 index 0000000000..5f42e10c59 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/src/l10n.typ @@ -0,0 +1,33 @@ +#import "@preview/linguify:0.4.2": set-database as _set_database, linguify + +/// *Internal function.* Initializes Linguify with the template's translation file. +/// +/// -> content +#let set-database() = _set_database(toml("l10n.toml")) + +#let thesis = linguify("thesis") +#let supervisor = linguify("supervisor") +#let performed-in-year = linguify("performed-in-year") +#let submission-note = linguify("submission-note") +#let approved = linguify("approved") + +#let declaration-title = linguify("declaration-title") +// #let declaration-text = linguify("declaration-text") +// #let declaration-ai-clause = linguify("declaration-ai-clause") +#let location-date = linguify("location-date") + +#let chapter = linguify("chapter") +#let section = linguify("section") +#let abstract = linguify("abstract") + +#let figure = linguify("figure") +#let table = linguify("table") +#let listing = linguify("listing") + +#let contents = linguify("contents") +#let bibliography = linguify("bibliography") +#let prompts = linguify("prompts") +#let list-of-figures = linguify("list-of-figures") +#let list-of-tables = linguify("list-of-tables") +#let list-of-listings = linguify("list-of-listings") +#let glossary = linguify("glossary") diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/lib.typ b/packages/preview/tgm-hit-thesis/0.3.0/src/lib.typ new file mode 100644 index 0000000000..7ab0e1cd4f --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/src/lib.typ @@ -0,0 +1,495 @@ +#import "assets.typ" +#import "l10n.typ" +#import "glossary.typ" +#import "bib.typ" as bib: bibliography +#import "utils.typ" + +#let _authors = state("thesis-authors") +#let _current_authors = state("thesis-current-authors", ()) + +#import glossary: register-glossary, glossary-entry, gls, glspl + +/// The main template function. Your document will generally start with ```typ #show: thesis(...)```, +/// which it already does after initializing the template. Although all parameters are named, most +/// of them are really mandatory. Parameters that are not given may result in missing content in +/// places where it is not actually optional. +/// +/// -> function +#let thesis( + /// The title of the thesis, displayed on the title page and used for PDF metadata. + /// -> content | string + title: none, + /// A descriptive one-liner that gives the reader an immediate idea about the thesis' topic. + /// -> content | string + subtitle: none, + /// The thesis authors. Each array entry is a `dict` of the form `(name: ..., class: ..., subtitle: ...)` stating their name, class, and the title of their part of the whole thesis project. The names must be regular strings, for the PDF metadata. + /// -> array + authors: (), + /// The term with which to label the supervisor name; if not given or `auto`, this defaults to a language-dependent text. In German, this text is gender-specific and can be overridden with this parameter. + /// -> content | string | auto + supervisor-label: auto, + /// The name of the thesis' supervisor. + /// -> content | string + supervisor: none, + /// The date of submission of the thesis. + /// -> datetime + date: none, + /// The school year in which the thesis was produced. + /// -> content | string + year: none, + /// The division inside the HIT department (i.e. usually "Medientechnik" or "Systemtechnik"). + /// -> content | string + division: none, + /// The image (```typc image()```) to use as the document's logo on the title page. + /// -> content + logo: none, + /// pass ```typc path => read(path)``` into this parameter so that Alexandria can read your + /// bibliography files. + /// -> function + read: none, + /// The (Alexandria) bibliography (```typc bibliography()```) to use for the thesis. + /// -> content + bibliography: none, + + /// The language in which the thesis is written. `"de"` and `"en"` are supported. The choice of language influences certain texts on the title page and in headings, as well as the date format used on the title page. + /// -> string + language: "de", + /// The mode used to show the current authors in the footer; see @@set-current-authors(). This can be `highlight` (all authors are shown, some *strong*) or `only` (only the current authors are shown). + /// -> string + current-authors: "highlight", + /// Changes the paper format of the thesis. Use this option with care, as it will shift various contents around. + /// -> string + paper: "a4", +) = body => { + import "@preview/alexandria:0.1.1" + import "@preview/codly:1.2.0": codly, codly-init + import "@preview/datify:0.1.3" + import "@preview/hydra:0.6.0": hydra, anchor + import "@preview/i-figured:0.2.4" + import "@preview/outrageous:0.4.0" + + assert(current-authors in ("highlight", "only")) + + // basic document & typesetting setup + set document( + title: title, + author: authors.map(author => author.name).join(", "), + date: date, + ) + set page(paper: paper) + set text(lang: language) + set par(justify: true) + + // title page settings - must come before the first content (e.g. state update) + set page(margin: (x: 1in, top: 1in, bottom: 0.75in)) + + // make properties accessible as state + _authors.update(authors) + + // setup linguify + l10n.set-database() + + // setup glossarium + show: glossary.make-glossary + + // setup Alexandria + show: bib.alexandria.alexandria(prefix: "cite:", read: read) + + // setup codly & listing styles + show: codly-init.with() + show figure.where(kind: raw): block.with(width: 95%) + + // outline style + set outline(indent: auto) + show outline.entry: outrageous.show-entry.with( + font: (auto,), + ) + + // general styles + + // figure supplements + show figure.where(kind: image): set figure(supplement: l10n.figure) + show figure.where(kind: table): set figure(supplement: l10n.table) + show figure.where(kind: raw): set figure(supplement: l10n.listing) + + show quote.where(block: false): it => { + it + if it.attribution != none [ #it.attribution] + } + + // table & line styles + set line(stroke: 0.1mm) + set table(stroke: (x, y) => if y == 0 { + (bottom: 0.1mm) + }) + + // references to non-numbered headings + show ref: it => { + if type(it.element) != content { return it } + if it.element.func() != heading { return it } + if it.element.numbering != none { return it } + + link(it.target, it.element.body) + } + + // title page + + { + // header + grid( + columns: (auto, 1fr, auto), + align: center+horizon, + assets.tgm-logo(width: 3.1cm), + { + set text(1.2em) + [Technologisches Gewerbemuseum] + parbreak() + set text(0.77em) + [Höhere Technische Lehranstalt für Informationstechnologie] + if division != none { + linebreak() + [Schwerpunkt #division] + } + }, + assets.htl-logo(width: 3.1cm), + ) + line(length: 100%) + + v(1fr) + + // title & subtitle + align(center, { + if logo != none { + logo + v(0.5em) + } + text(1.44em, weight: "bold")[#l10n.thesis] + v(-0.5em) + text(2.49em, weight: "bold")[#title] + if subtitle != none { + v(-0.7em) + text(1.44em)[#subtitle] + } + }) + + v(1fr) + + // authors & supervisor + authors.map(author => { + grid( + columns: (4fr, 6fr), + row-gutter: 0.8em, + grid.cell(colspan: 2, author.subtitle), + author.name, + author.class, + ) + }).join(v(0.7em)) + v(2em) + if supervisor-label == auto { + supervisor-label = l10n.supervisor + } + [ + *#supervisor-label:* #supervisor \ + #l10n.performed-in-year #year + ] + + // footer + let date-formats = ( + "en": "Month DD, YYYY", + "de": "DD. Month YYYY", + ) + + line(length: 100%) + [ + #l10n.submission-note: \ + #context if text.lang in date-formats { + datify.custom-date-format(date, date-formats.at(text.lang)) + } else { + date.display() + } + #h(1fr) + #l10n.approved: + #h(3cm) + ] + } + + // regular page setup + + // show header & footer on "content" pages, show only page number in chapter title pages + set page( + margin: (x: 1in, y: 1.5in), + header-ascent: 15%, + footer-descent: 15%, + header: context { + if utils.is-chapter-page() { + // no header + } else if utils.is-empty-page() { + // no header + } else { + hydra( + 1, + prev-filter: (ctx, candidates) => candidates.primary.prev.outlined == true, + display: (ctx, candidate) => { + grid( + columns: (auto, 1fr), + column-gutter: 3em, + align: (left+top, right+top), + title, + { + set par(justify: false) + if candidate.has("numbering") and candidate.numbering != none { + l10n.chapter + [ ] + numbering(candidate.numbering, ..counter(heading).at(candidate.location())) + [. ] + } + candidate.body + } + ) + line(length: 100%) + }, + ) + anchor() + } + }, + footer: context { + if utils.is-chapter-page() { + align(center)[ + #counter(page).display("1") + ] + } else if utils.is-empty-page() { + // no footer + } else { + hydra( + 1, + prev-filter: (ctx, candidates) => candidates.primary.prev.outlined == true, + display: (ctx, candidate) => { + line(length: 100%) + grid( + columns: (5fr, 1fr), + align: (left+bottom, right+bottom), + if current-authors == "highlight" { + authors.map(author => { + let is-current = author.name in _current_authors.get() + let author = author.name + if is-current { + author = strong(author) + } + box(author) + }).join[, ] + } else if current-authors == "only" { + authors.filter(author => { + author.name in _current_authors.get() + }).map(author => { + let author = author.name + box(author) + }).join[, ] + } else { + panic("unreachable: current-authors not 'highlight' or 'only'") + }, + counter(page).display("1 / 1", both: true), + ) + }, + ) + } + }, + ) + + show: utils.mark-empty-pages() + + // front matter headings are not outlined + set heading(outlined: false) + // Heading supplements are section or chapter, depending on level + show heading: set heading(supplement: l10n.section) + show heading.where(level: 1): set heading(supplement: l10n.chapter) + // chapters start on a right page and have very big, fancy headings + show heading.where(level: 1): it => { + set text(1.3em) + pagebreak(to: "odd") + v(12%) + if it.numbering != none [ + #it.supplement #counter(heading).display() + #parbreak() + ] + set text(1.3em) + it.body + v(1cm) + } + // the first section of a chapter starts on the next page + show heading.where(level: 2): it => { + if utils.is-first-section() { + pagebreak() + } + it + } + + // main body with i-figured + // scope i-figured to now interact with Glossarium + { + show heading: i-figured.reset-counters + show figure: i-figured.show-figure + show math.equation: i-figured.show-equation + + // the body contains the declaration, abstracts, and then the main matter + + body + } + + // back matter + + // glossary is outlined + { + set heading(outlined: true) + + glossary.print-glossary(title: [= #l10n.glossary ]) + } + + // bibliography is outlined, and we use our own header for the label + if bibliography != none { + bibliography + + let is-prompt(x) = x.details.type == "misc" and x.details.title.starts-with("PROMPT") + + context { + let (references, ..rest) = bib.alexandria.get-bibliography(auto) + let prompts = references.filter(x => is-prompt(x)) + let references = references.filter(x => not is-prompt(x)) + + if references.len() != 0 { + [= #l10n.bibliography ] + bib.alexandria.render-bibliography(title: none, (references: references, ..rest)) + } + + if prompts.len() != 0 { + [= #l10n.prompts ] + bib.alexandria.render-bibliography(title: none, (references: prompts, ..rest)) + } + } + set heading(outlined: true) + + } + + // List of {Figures, Tables, Listings} only shown if there are any such elements + context if query(figure.where(kind: image)).len() != 0 { + [= #l10n.list-of-figures ] + i-figured.outline( + title: none, + target-kind: image, + ) + } + + context if query(figure.where(kind: table)).len() != 0 { + [= #l10n.list-of-tables ] + i-figured.outline( + title: none, + target-kind: table, + ) + } + + context if query(figure.where(kind: raw)).len() != 0 { + [= #l10n.list-of-listings ] + i-figured.outline( + title: none, + target-kind: raw, + ) + } +} + +/// The statutory declaration that the thesis was written without improper help. The text is not +/// part of the template so that it can be adapted according to one's needs. Example texts are given +/// in the template. Heading and signature lines for each author are inserted automatically. +/// +/// -> content +#let declaration( + /// The height of the signature line. The default should be able to fit up to seven authors on one page; for larger teams, the height can be decreased. + /// -> length + signature-height: 1.1cm, + /// The actual declaration. + /// -> content + body, +) = [ + #let caption-spacing = -0.2cm + + = #l10n.declaration-title + + #body + + #v(0.2cm) + + #context _authors.get().map(author => { + show: block.with(breakable: false) + set text(0.9em) + grid( + columns: (4fr, 6fr), + align: center, + [ + #v(signature-height) + #line(length: 80%) + #v(caption-spacing) + #l10n.location-date + ], + [ + #v(signature-height) + #line(length: 80%) + #v(caption-spacing) + #author.name + ], + ) + }).join() +] + +/// Set the authors writing the current part of the thesis. The footer will highlight the names of +/// the given authors until a new list of authors is given with this function. +/// +/// -> content +#let set-current-authors( + /// the names of the authors to highlight + /// -> arguments + ..authors, +) = { + assert(authors.named().len() == 0, message: "named arguments not allowed") + let authors = authors.pos() + context { + let names = _authors.get().map(author => author.name) + for author in authors { + assert(author in names, message: "invalid author: " + author) + } + } + + _current_authors.update(authors) +} + +/// An abstract section. This should appear twice in the thesis regardless of language; first for +/// the German _Kurzfassung_, then for the English abstract. +/// +/// -> content +#let abstract( + /// The language of this abstract. Although it defaults to ```typc auto```, in which case the document's language is used, it's preferable to always set the language explicitly. + /// -> string + lang: auto, + /// The abstract text. + /// -> content + body, +) = [ + #set text(lang: lang) if lang != auto + + #context [ + #[= #l10n.abstract] #label("abstract-" + text.lang) + ] + + #body +] + +/// Starts the main matter of the thesis. This should be called as a show rule (```typ #show: main-matter()```) after the abstracts and will insert +/// the table of contents. All subsequent top level headings will be treated as chapters and thus be +/// numbered and outlined. +/// +/// -> function +#let main-matter() = body => { + [= #l10n.contents ] + outline(title: none) + + set heading(outlined: true, numbering: "1.1") + + body +} diff --git a/packages/preview/tgm-hit-thesis/0.3.0/src/utils.typ b/packages/preview/tgm-hit-thesis/0.3.0/src/utils.typ new file mode 100644 index 0000000000..048ad8c370 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/src/utils.typ @@ -0,0 +1,60 @@ +/// *Internal function.* Returns whether the current page is one where a chapter begins. This is +/// used for styling headers and footers. +/// +/// This function is contextual. +/// +/// -> bool +#let is-chapter-page() = { + // all chapter headings + let chapters = query(heading.where(level: 1)) + // return whether one of the chapter headings is on the current page + chapters.any(c => c.location().page() == here().page()) +} + +// this is an imperfect workaround, see +// - https://github.com/typst/typst/issues/2722 +// - https://github.com/typst/typst/issues/4438 + +#let _empty_page_start = +#let _empty_page_end = + +/// *Internal function.* Marks all pagebreaks for empty page detection via. This is called as a show +/// rule (```typ #show: mark-empty-pages()```) by the main template. +/// +/// -> function +#let mark-empty-pages() = doc => { + show pagebreak: it => { + [#metadata(none)#_empty_page_start] + it + [#metadata(none)#_empty_page_end] + } + doc +} + +/// *Internal function.* Returns whether the current page is empty. This is determined by checking +/// whether the current page is between the start and end of a pagebreak, which may span a whole +/// page when `pagebreak(to: ..)` is used. +/// This is used for styling headers and footers. +/// +/// This function is contextual. +/// +/// -> bool +#let is-empty-page() = { + let page-num = here().page() + query(selector.or(_empty_page_start, _empty_page_end)).chunks(2).any(((start, end)) => { + start.location().page() < page-num and page-num < end.location().page() + }) +} + +/// *Internal function.* This is intended to be called in a section show rule. It returns whether +/// that section is the first in the current chapter +/// +/// This function is contextual. +/// +/// -> bool +#let is-first-section() = { + // all previous headings + let prev = query(selector(heading).before(here(), inclusive: false)) + // returns whether the previous heading is a chapter heading + prev.len() != 0 and prev.last().level == 1 +} diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/assets.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/assets.typ new file mode 100644 index 0000000000..b4d7fc23d9 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/assets.typ @@ -0,0 +1 @@ +#import "assets/mod.typ": * \ No newline at end of file diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/assets/logo.png b/packages/preview/tgm-hit-thesis/0.3.0/template/assets/logo.png new file mode 100644 index 0000000000..e78317e0f2 Binary files /dev/null and b/packages/preview/tgm-hit-thesis/0.3.0/template/assets/logo.png differ diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/assets/mod.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/assets/mod.typ new file mode 100644 index 0000000000..afabea6d0a --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/assets/mod.typ @@ -0,0 +1 @@ +#let logo = image.with("logo.png") diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/bibliography.bib b/packages/preview/tgm-hit-thesis/0.3.0/template/bibliography.bib new file mode 100644 index 0000000000..30644f2159 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/bibliography.bib @@ -0,0 +1,46 @@ +% Hier finden sich alle Referenzen aus Literatur und Internet, welche innerhalb der eigentlichen Arbeit verwendet wurden. +% Zur einfachen Anwendung werden hier einige Beispiele gegeben. + +% Nutzung einer Quelle, welche über das Internet zugänglich ist. +% Einige Parameter sollten bei jeder Referenz vorhanden sein: +% - title: Der Titel der Website (wird meist in der Adresszeile angezeigt) +% - author: Alle Autoren, welche als für den Text verantwortlich gegeben sind. Sollte keiner angegeben sein, könnte etwa „Autoren von {Seitenname}“ verwendet werden +% - url: Ein eindeutiger Link zur referenzierten Quelle, welcher im Optimalfall über mehrere Jahre hinweg verfügbar ist +% - urldate: Ebenfalls sollte das Datum des letzten Zugriffs angegeben sein +% - date: Ebenfalls sollte das Datum der Erstellung angegeben sein +@online{ wiki:syt, + title = {Systemtechnik}, + url = {https://de.wikipedia.org/wiki/Systemtechnik}, + organization = {Wikipedia}, + urldate = {2024-04-04}, + date = {2023-12-03} +} + +% Nutzung von Inhalten eines Buchs. +% Bei Büchern gibt es einige Angaben, welche auf jeden Fall angegeben werden müssen: +% - title: Der Vollständige Titel des Buchs +% - author: Alle beteiligten Autoren +% - year: Erscheinungsdatum der verwendeten Auflage (siehe auch Parameter „edition“) +% - edition: Aktuelle Auflage des Buchs (wenn nicht angegeben: 1. Auflage verwenden) und Markierung spezieller Versionen +% - publisher: Der Verlag, welcher das Buch herausgab (häufig werden vom Verlag noch kleiner Änderungen vorgenommen) +% - pages: Alle Seiten, durch Komma getrennt, welche innerhalb der Arbeit verwendet wurden (mehrere Seiten können auch mit „-“ angegeben werden) +% +% Optional sind auch folgende Parameter interessant: +% - subtitle: Falls Bücher sich etwa nur durch ihren Untertitel unterscheiden +% - pagetotal: Gesamte Anzahl der Seiten der verwendeten Quelle +@book{ physik1, + title = {Physik 1}, + author = {Schweitzer, Christian and Svoboda, Peter and Trieb, Lutz}, + year = {2011}, + subtitle = {Mechanik, Thermodynamik, Optik}, + edition = {7. Auflage}, + publisher = {Veritas}, + pages = {140, 145-150}, + pagetotal = {296} +} + +@misc{ prompt1, + title = {PROMPT, ChatGPT 4o-mini. Formuliere in sachlicher und neutraler Sprache eine Definition des Begriffs Zitierregeln}, + author = {OpenAI}, + date = {2025-03-12}, +} diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/conclusio.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/conclusio.typ new file mode 100644 index 0000000000..60ad6eee54 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/conclusio.typ @@ -0,0 +1,5 @@ +#import "../lib.typ": * + += Conclusio + +Hier findet eine letzte Zusammenfassung der Arbeit statt. diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/danksagung.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/danksagung.typ new file mode 100644 index 0000000000..3d1247fa97 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/danksagung.typ @@ -0,0 +1,5 @@ +#import "../lib.typ": * + += Danksagung + +#lorem(150) \ No newline at end of file diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/einleitung.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/einleitung.typ new file mode 100644 index 0000000000..694b7ea7cf --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/einleitung.typ @@ -0,0 +1,5 @@ +#import "../lib.typ": * + += Einleitung + +Zu Beginn wird die Ausgangslage beschrieben, wobei interessant ist woher das Projekt kommt und welche Ansätze an dessen Konzept beteiligt waren. Hier werden auch Ziele gesetzt und Probleme bestimmt, welche in der Arbeit selbst eine große Rolle spielen. diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/implementierung.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/implementierung.typ new file mode 100644 index 0000000000..a3307bfba4 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/implementierung.typ @@ -0,0 +1,5 @@ +#import "../lib.typ": * + += Implementierung + +Hier wird die Umsetzung des Projekts beschrieben und auf Details zu den einzelnen Technologien eingegangen. Im Optimalfall werden die Lösungen und Wege zu den zuvor definierten Problemen und Zielen geschildert. Eine bestehende Dokumentation, welche während der Arbeit erstellt wurde kann hier von großem Vorteil sein! diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/konzept.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/konzept.typ new file mode 100644 index 0000000000..c06759ebe7 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/konzept.typ @@ -0,0 +1,5 @@ +#import "../lib.typ": * + += Konzept + +Nachdem die Studie abgeschlossen und der Weg bestimmt ist soll nun ein Konzept oder eher noch ein Ablauf zur Lösung beschrieben werden. Hier finden sich Diagramme, Skizzen, Drehbücher, Mockups, ..., welche als Basis für die eigentliche Entwicklung verwendet werden. diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/kurzfassung.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/kurzfassung.typ new file mode 100644 index 0000000000..85d765851f --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/kurzfassung.typ @@ -0,0 +1,9 @@ +#import "../lib.typ": * + +#abstract(lang: "de")[ + #lorem(150) +] + +#abstract(lang: "en")[ + #lorem(150) +] diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/retrospektive.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/retrospektive.typ new file mode 100644 index 0000000000..19fd268f14 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/retrospektive.typ @@ -0,0 +1,5 @@ +#import "../lib.typ": * + += Retrospektive + +Kurz vor dem Ende wird der Verlauf des Projekts analysiert und geprüft, ob die Ziele erreicht und die Probleme gelöst wurden. Es wird auch auf Schwierigkeiten eingegangen, welche erst während der Arbeit zum Vorschein kamen und es können Verbesserungsvorschläge und Erkenntnisse vorgetragen werden. Außerdem kann auch auf den weiteren Verlauf in der Zukunft eingegangen werden. diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/studie.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/studie.typ new file mode 100644 index 0000000000..38cdd4c827 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/studie.typ @@ -0,0 +1,9 @@ +#import "../lib.typ": * + += Studie + +Nach der Definition der Problemstellungen und Ziele soll recherchiert werden, wie diese erreicht, beziehungsweise gelöst werden können. Diese Studie beschäftigt sich mit möglichen Lösungen und Technologien und analysiert deren Eigenschaften um konkrete Vor- und Nachteile zu finden. Beendet wird dieser Abschnitt mit einem Fazit. + +== Fazit + +Das Fazit soll zeigen, wie das Projekt durchgeführt werden kann. \ No newline at end of file diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/vorwort.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/vorwort.typ new file mode 100644 index 0000000000..39b8e297fe --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/chapters/vorwort.typ @@ -0,0 +1,171 @@ +#import "../lib.typ": * + +#let highlighted-link(..args) = { + set text(fill: blue.darken(20%)) + link(..args) +} + += Vorwort + +Die Diplomarbeit ist kein Aufsatz! Auch wenn sie interessant gestaltet werden sollte, ist sie unpersönlich und im passiv zu schreiben. Besonders sind die Quellenangaben, welche entsprechend gewählt und referenziert werden müssen. Innerhalb dieser Vorlage existieren zwei Dateien, die zu genau diesem Zweck erstellt wurden. Die Datei `bibliography.bib` beinhaltet alle Quellenangaben und verwendete Literatur, `glossaries.typ` alle Definitionen von Begriffen und Akronymen, welche in der Arbeit selbst nicht genauer erklärt werden. + +Während der Großteil dieser Vorlage nur die Struktur einer typischen Diplomarbeit vorzeigt enthält das Vorwort Informationen zur Verwendung der Vorlage. Es ist natürlich zur Gänze zu ersetzen. Die Informationen hier umfassen neben vorlagenspezifischen Beispielen auch solche, die sich auf Funktionen von Typst oder #highlighted-link("https://typst.app/universe/")[zur Verfügung stehenden Paketen] beziehen und für die Erstellung von Diplomarbeiten nützlich sein können. Es lohnt sich einen Blick in `chapters/vorwort.typ` zu werfen um zu sehen, wie die Beispiele umgesetzt wurden. + +== Quellen + +Das richtige zitieren spielt innerhalb der wissenschaftlichen Arbeit eine wichtige Rolle. Die Verwaltung von Literatur ist bereits in Typst enthalten, allerdings wird zur Unterstützung des Promptverzeichnisses (siehe @about:prompts) das externe Paket _Alexandria_ für Quellen verwendet; die Benutzung ist aber großteils ident. Die Datei `bibliography.bib` ist bereits vorgegeben, es kann aber wie in der Dokumentation beschrieben auch das _Hayagriva_-Format verwendet werden. + +Als kleines Beispiel findet sich hier nun ein Zitat über Schall, aus dem ersten Phsyik Lehrbuch der Autoren #cite(, form: "author"). + +#quote(attribution: [@cite:physik1[S. 145]], block: true)[ + "Mechanische Longitudinalwellen werden als Schall bezeichnet. In einem Frequenzbereich von 16 Hz bis 20 kHz sind sie für das menschliche Ohr wahrnehmbar. Liegen die Frequenzen unter diesem Bereich, so bezeichnet man diese Wellen als Infraschall, darüber als Ultraschall." +] + +In `bibliography.bib` ist die referenzierte Quelle folgendermaßen definiert: + +#figure( + ```bib + @book{ physik1, + title = {Physik 1}, + author = {Christian Schweitzer, Peter Svoboda, Lutz Trieb}, + year = {2011}, + subtitle = {Mechanik, Thermodynamik, Optik}, + edition = {7. Auflage}, + publisher = {Veritas}, + pages = {140, 145-150}, + pagetotal = {296} + } + ```, + caption: [Eintrag einer Buchquelle in BibTeX], +) + +Als allererstes sieht man die ID dieser Quelle, `physik1`, damit lässt sich diese entweder mit ```typ @cite:physik1``` referenzieren. Der Prefix ```typ @cite:``` ist durch _Alexandria_ bedingt; gewöhnliche Zitate würden keinen Prefix verwenden: ```typ @physik1```. Eine zusätzliche Detailangabe wie etwa für die Seitenzahl ist mit ```typ @cite:physik1[S. 145]``` möglich. Besonders bei direkten Zitaten empfiehlt es sich auch die Seitenzahl anzugeben. + + +In Fließtext ist es manchmal gewünscht, eine Quelle nicht mit der Nummer im @bibliography anzugeben. Die Angabe der Autoren über dem Zitat wurde zum Beispiel mit ```typ #cite(, form: "author")``` generiert. + +Für direkte Zitate ist die ```typ #quote()```-Funktion geeignet. Das Zitat oben ist ein Block-Zitat; im Fließtext könnte ein Zitat so ausschauen: #quote(attribution: [@cite:physik1[S. 145]])[Mechanische Longitudinalwellen werden als Schall bezeichnet.] + +Nach der Verwendung einer Quelle wird diese auch im @bibliography gelistet, welche sich am Ende des Dokuments befindet. Quellen die nicht referenziert werden, werden nicht angezeigt. Es ist also unproblematisch, großzügig Quellen in `bibliography.bib` aufzunehmen: besser mehr Literatur parat zu haben, als sie dann nachträglich suchen zu müssen. + +Relevante Dokumentation: + +- #highlighted-link("https://typst.app/universe/package/alexandria/0.1.2/")[das Alexandria-Paket] -- wird statt dem eingebauten Literaturverzeichnis verwendet +- #highlighted-link("https://typst.app/docs/reference/model/bibliography/")[```typc bibliography()```] -- das eingebaute Literaturverzeichnis +- #highlighted-link("https://typst.app/docs/reference/model/cite/")[```typ @key``` bzw. ```typc cite()```] +- #highlighted-link("https://typst.app/docs/reference/model/quote/")[```typc quote()```] +- #highlighted-link("https://www.bibtex.com/g/bibtex-format/")[das BibTeX-Dateiformat] +- #highlighted-link("https://github.com/typst/hayagriva/blob/main/docs/file-format.md")[das Hayagriva-Dateiformat] + +== Promptverzeichnis + +Für Diplomarbeiten ist in Österreich ein separates @prompts vorgeschrieben: wenn in der Arbeit KI zur Erstellung von Inhalten verwendet wurde, müssen die dazu eingesetzten Prompts in einem _separaten_ Promptverzeichnis aufgeführt werden. Diese Vorlage ist so eingerichtet, dass die Prompts ebenfalls in der Datei `bibliography.bib` aufgeführt werden, zum Beispiel folgendermaßen: + +#figure( + ```bib + @misc{ prompt1, + title = {PROMPT, ChatGPT 4o-mini. Formuliere in sachlicher und neutraler Sprache eine Definition des Begriffs Zitierregeln}, + author = {OpenAI}, + date = {2025-03-12}, + } + ```, + caption: [Eintrag eines Prompts für diese Vorlage im BibTeX-Format], +) + +Entscheidend ist der Referenztyp `@misc` und der Titel, der mit `PROMPT` beginnt. Das Referenzieren passiert mit ```typ @cite:prompt1```: @cite:prompt1 Wie man sieht ist dieses Zitat von der gleichen Form wie ein normales, allerdings führt die Verlinkung auf das separate @prompts. + +Anzumerken ist, dass Zitierregeln für KI-Prompts noch wenig verbreitet sind; @lst:bib-prompt zeigt nur eine Möglichkeit den BibTeX-Eintrag zu strukturieren, wobei die konkret verwendete Technologie im Titel verpackt wird. Eine andere Variante ist denkbar, solange diese dann konsistent eingesetzt wird. + +== Glossar + +Das @glossary enthält Erklärungen von Begriffen und Abkürzen, die im Fließtext keinen Platz haben. Dadurch wird sichergestellt, dass der Lesefluss für Fachkundige nicht gestört wird, die Arbeit aber trotzdem auch für ein breiteres Publikum zugänglich ist. In der Datei `glossaries.typ` werden Begriffe -- oder in diesem Fall eine Abkürzung -- in der folgenden Form definiert: + +#figure( + ```typ + #glossary-entry( + "ac:tgm", + short: "TGM", + long: "Technologisches Gewerbemuseum", + ) + ```, + caption: [Eintrag einer Abkürzung in `glossaries.typ`], +) + +Verwendet werden kann dieser Glossareintrag ähnlich einer Quellenangabe durch ```typ @ac:tgm```. Bei der ersten Verwendung wird die Langform automatisch auch dargestellt: @ac:tgm. Bei weiteren Verwendungen wird dagegen nur die Kurzform angezeigt: @ac:tgm. + +Das für die Glossar-Funktion im Hintergrund verwendete _Glossarium_-Paket stellt auch weitere Funktionen zur Verfügung, die z.B. bei der Anpassung an die deutschen Fälle hilfreich sein können. Außerdem kann so die Langform erzwungen werden: _diese Diplomarbeit wurde im #gls("ac:tgm", display: "Technologischen Gewerbemuseum") erstellt; "#gls("ac:tgm", long: true)" wird man im Fließtext aufgrund der Struktur der deutschen Sprache wahrscheinlich selten finden._ + +Relevante Dokumentation: + +- #highlighted-link("https://typst.app/universe/package/glossarium/0.4.1/")[das Glossarium-Paket] + +#set-current-authors("Arthur Dent", "Tricia McMillan") + +== Autorenschaft innerhalb des Dokuments + +Innerhalb der Diplomarbeit ist es notwendig, dass die Individuelle Autorenschaft der einzelnen Teile nachvollzogen werden kann. Üblich ist dafür, dass die Autoren in der Fußzeile angegeben werden. In dieser Vorlage kann aus zwei Modi gewählt werden: ```typc current-authors: "highlight"``` zeigt alle Autoren in der Fußzeile an, druckt aber die aktuellen Autoren fett; ```typc current-authors: "only"``` zeigt nur die aktuellen Autoren in der Fußzeile an. + +Vor diesem Abschnitt wurden die Autoren auf _Arthur Dent_ und _Tricia McMillan_ gesetzt (siehe den Quellcode dieses Kapitels), deshalb sind diese ab dieser Seite fett gedruckt. + +== Abbildungen und Gleichungen + +Abbildungen, Tabellen, Codestücke und ähnlich eigenständige Inhalte werden oft verwendet, um den Fließtext zu komplementieren. In den vorangegangenen Abschnitten wurden bereits zwei _Auflistungen_, also Codestücke, verwendet. Abbildungen sollten normalerweise im Fließtext referenziert werden, damit die inhaltliche Relevanz explizit klar ist. Zum Beispiel könnte mittels ```typ @lst:figure-definition``` auf den in @lst:figure-definition gezeigten Code verwiesen werden. Die Verweise in diesem Abschnitt benutzen genau diesen Mechanismus, in der PDF-Version der Arbeit sind diese Verweise funktionierende Links. Der Präfix `lst:` wurde dabei durch das _i-figured_-Paket eingefügt und anhand der Art des Inhalts bestimmt, siehe @tbl:figure-kinds. Dieses Paket bewirkt auch, dass Abbildungen nicht durchlaufend nummeriert sind, sondern kapitelweise. + +#figure( + ```typ + #figure( + image(...), + caption: [Ein Bild], + ) + ```, + placement: auto, + caption: [Definition einer Abbildung], +) + +#figure( + table( + columns: 4, + align: (center,) * 3 + (left,), + table.header( + [Supplement], [Inhalt], [Präfix], [Anmerkung], + ), + [Abbildung], [```typ image()```], [`fig:`], [Standard-Abbildungsart für andere Inhalte], + [Tabelle], [```typ table()```], [`tbl:`], [], + [Auflistung], [```typ raw()```], [`lst:`], [```typ raw()``` hat auch die Spezial-Syntax ```typ `...` ``` oder ````typ ```...``` ````], + [Gleichung], [```typ math.equation()```], [`eqt:`], [```typ math.equation()``` hat auch die Spezial-Syntax ```typ $ ... $```], + ), + placement: auto, + caption: [Arten von Abbildungen und deren Präfixe in _i-figured_], +) + +Es ist in wissenschaftlichen Arbeiten auch üblich, Abbildungen zur besseren Seitennutzung zu verschieben -- normalerweise an den oberen oder unteren Rand einer Seite. In Typst kann dazu ```typc figure(.., placement: auto)``` benutzt werden. Die Abbildungen in diesem Abschnitt benutzen diese Funktionalität: obwohl dieser Absatz im Quelltext nach den Abbildungen kommt, wird er vor ihnen angezeigt. Ob die Ergebnisse der automatischen Platzierung zufriedenstellend sind sollte für die Endversion natürlich nochmal manuell geprüft werden. + +Mathematische Gleichungen werden gemäß den Konventionen ein bisschen anders dargestellt und haben in Typst außerdem eine eigene Syntax. Die Definition von @eqt:pythagoras kann im Quelltext des Vorworts eingesehen werden: + +$ a^2 + b^2 = c^2 $ + +Relevante Dokumentation: + +- #highlighted-link("https://typst.app/docs/reference/model/figure/")[```typc figure()```] +- #highlighted-link("https://typst.app/docs/reference/foundations/label/")[```typ <...>``` bzw. ```typc label()```] +- #highlighted-link("https://typst.app/docs/reference/model/table/")[```typc table()```] +- #highlighted-link("https://typst.app/docs/reference/text/raw/")[````typ ```...``` ```` bzw. ```typc raw()```] +- #highlighted-link("https://typst.app/docs/reference/math/equation/")[```typ $ ... $``` bzw. ```typc math.equation()```] +- #highlighted-link("https://typst.app/universe/package/i-figured/0.2.4/")[das i-figured-Paket] + +== Interne Verweise + +Neben Referenzen auf Quellen, Abbildungen und Glossar-Einträge kann die ```typ @key```-Syntax auch verwendet werden, um auf Kapitel und Abschnitte zu referenzieren. Da dieses Kapitel mit dem Label ```typ ``` versehen ist lässt sich zum Beispiel mit ```typ @preface``` leicht ein Verweis einfügen: @preface. Gleichermaßen funktioniert ein Verweis auf @internal-references, in dem dieser Text steht. Im PDF sind auch diese Verweise Links. + +Einige Teile der Diplomarbeit sind durch die Vorlage mit Labels versehen und können damit wenn nötig referenziert werden: +- @declaration +- #text(lang: "de")[@abstract-de] +- #text(lang: "en")[@abstract-en] +- @contents +- @bibliography +- @prompts +- (#l10n.list-of-figures -- kein Link da in der Vorlage keine "normalen" Abbildungen sind) // @list-of-figures +- @list-of-tables +- @list-of-listings +- @glossary +Da diese Überschriften keine Nummerierung haben, werden Referenzen zu ihnen mit dem vollen Namen dargestellt. diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/glossaries.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/glossaries.typ new file mode 100644 index 0000000000..89bd76de49 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/glossaries.typ @@ -0,0 +1,16 @@ +#import "lib.typ": * + +#register-glossary( + glossary-entry( + "ac:tgm", + short: "TGM", + long: "Technologisches Gewerbemuseum", + // group: "Accronyms", + ), + glossary-entry( + "syt", + short: "SYT", + long: "Systemtechnik", + description: ["Als Systemtechnik bezeichnet man verschiedene Aufbau- und Verbindungstechniken, aber auch eine Fachrichtung der Ingenieurwissenschaften. Er bedeutet in der Unterscheidung zu den Mikrotechnologien die Verbindung verschiedener einzelner Module eines Systems und deren Konzeption." @wiki:syt] + ), +) diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/lib.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/lib.typ new file mode 100644 index 0000000000..e47977eb74 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/lib.typ @@ -0,0 +1,3 @@ +#import "@preview/tgm-hit-thesis:0.3.0": * + +#import "assets.typ" diff --git a/packages/preview/tgm-hit-thesis/0.3.0/template/main.typ b/packages/preview/tgm-hit-thesis/0.3.0/template/main.typ new file mode 100644 index 0000000000..bd5bb6d752 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/template/main.typ @@ -0,0 +1,63 @@ +#import "lib.typ": * + +#show: thesis( + title: [Keine Panik!], + subtitle: [Mit Typst durch die Diplomarbeit], + authors: ( + // ATTENTION: chapters/vorwort.typ:102 references this list of example authors. When changing + // this list, you need to adjust/remove that line! + (name: "Arthur Dent", class: [5xHIT], subtitle: [Untertitel des Themengebiets von Arthur Dent]), + (name: "Ford Prefect", class: [5xHIT], subtitle: [Untertitel des Themengebiets von Ford Prefect]), + (name: "Tricia McMillan", class: [5xHIT], subtitle: [Untertitel des Themengebiets von Tricia McMillan]), + (name: "Zaphod Beeblebrox", class: [5xHIT], subtitle: [Untertitel des Themengebiets von Zaphod Beeblebrox]), + ), + // the German default supervisor label is the non-gendered "Betreuer", so you can override it here + // as necessary + supervisor-label: [Betreuer:in], + supervisor: [DSc MSc Deep Thought], + date: datetime(year: 2018, month: 4, day: 4), + year: [2017/18], + division: [Medientechnik, Systemtechnik], + logo: assets.logo(width: 3cm), + read: path => read(path), + bibliography: bibliography("bibliography.bib"), + + // language: "en", + // current-authors: "only", +) + +#include "glossaries.typ" + +#declaration(context if text.lang == "de" [ + Ich erkläre an Eides statt, dass ich die vorliegende Arbeit selbstständig verfasst, andere als die angegebenen Quellen/Hilfsmittel nicht benutzt und die den benutzten Quellen wörtlich und inhaltlich entnommenen Stellen als solche kenntlich gemacht habe. + Für die Erstellung der Arbeit habe ich auch folgende Hilfsmittel generativer KI-Tools [z. B. ChatGPT, Grammarly Go, Midjourney] zu folgendem Zweck verwendet: + + - ChatGPT: eigentlich für eh alles +] else if text.lang == "en" [ + I declare that I have authored this thesis independently, that I have not used other than the declared sources and that I have explicitly marked all material which has been quoted either literally or by content from the used sources. + I also used the following generative AI tools [e.g. ChatGPT, Grammarly Go, Midjourney] for the following purpose: + + - ChatGPT: for basically everything +] else { + panic("no statutory declaration for that language!") +}) + +#include "chapters/kurzfassung.typ" + +#show: main-matter() + +#include "chapters/vorwort.typ" + +#include "chapters/danksagung.typ" + +#include "chapters/einleitung.typ" + +#include "chapters/studie.typ" + +#include "chapters/konzept.typ" + +#include "chapters/implementierung.typ" + +#include "chapters/retrospektive.typ" + +#include "chapters/conclusio.typ" diff --git a/packages/preview/tgm-hit-thesis/0.3.0/thumbnail.png b/packages/preview/tgm-hit-thesis/0.3.0/thumbnail.png new file mode 100644 index 0000000000..318d812ba8 Binary files /dev/null and b/packages/preview/tgm-hit-thesis/0.3.0/thumbnail.png differ diff --git a/packages/preview/tgm-hit-thesis/0.3.0/typst.toml b/packages/preview/tgm-hit-thesis/0.3.0/typst.toml new file mode 100644 index 0000000000..54362d6438 --- /dev/null +++ b/packages/preview/tgm-hit-thesis/0.3.0/typst.toml @@ -0,0 +1,38 @@ +# for a description of available keys, see https://github.com/typst/packages/?tab=readme-ov-file#package-format + +[package] +name = "tgm-hit-thesis" +version = "0.3.0" +entrypoint = "src/lib.typ" +authors = [ + "Clemens Koza " +] +license = "MIT" +description = "Diploma thesis template for students of the HIT department at TGM Wien" +# homepage = "" +repository = "https://github.com/TGM-HIT/typst-diploma-thesis" +keywords = ["TGM", "HIT", "Diplomarbeit", "thesis", "HTL"] +categories = ["thesis"] +disciplines = ["computer-science"] +compiler = "0.11.0" +exclude = [ + ".github", + "docs", + "gallery", + "scripts", + "tests", + ".typstignore", + "Justfile", + "thumbnail.png", + "example.pdf", + # "thumbnail-dark.svg", + # "thumbnail-light.svg", +] + +[template] +path = "template" +entrypoint = "main.typ" +thumbnail = "thumbnail.png" + +# [tool.mytool] +# foo = "bar"