Compare commits

..

No commits in common. "968f63be78153c02f1d9f7d0a6adf2c7d6de5bf7" and "5ec79a536d7a0af20acb727252c3688e25f70cec" have entirely different histories.

18 changed files with 141 additions and 2081 deletions

View File

@ -1,9 +1,17 @@
# Praxisbericht-Template-Typst # Praxisbericht-Template-Typst
The template makes use of ABB and DHBW branding. Tempalte für Praxisberichte, T100, T200, T3000 und Bechelor Arbeiten. Im Gegensatz zu https://git.montehaselino.de/DHBW/Praxisbericht-Template wird Typst und nicht LaTeX als typsetting sprache verwendet.
## Format ## Geplante Features:
All pages have a margin of 2.5cm between header/footer/content and the page border. - Inhaltsverzeichnis
Header and footer do not overlap into this margin. - Quelltextverzeichnis
- Abbildungsverzechnis
Bibliography is formated with the IEEE style. Appendecies make use of the APA style. - Tabellenverzeichnis
- Literaturverzeichnis
- Glossar
- Abkürzungsverzeichnis
- Ligratures in code blöcken
- Diagramme
- Literatur
- Fußnoten
- Anhang

View File

@ -1,9 +0,0 @@
= Ein Text im Anhang
#label("Anhang-A")
#lorem(50)
== Noch mehr Text im Anhang
#lorem(50)

View File

View File

@ -1,60 +1,17 @@
#import "../src/template.typ": dhbw-template #import "../src/template.typ": dhbw-template
#let config = ( #show: dhbw-template
lang: "de",
region: "de",
author: (
name: "Sven Vogel",
semester: 4,
program: "Informationstechnik",
course: "TINF22IT2",
faculty: "Technik",
university: "DHBW Mannheim",
company: "ABB AG",
supervisor: "Florian Miedniak",
matriculation-number: 1191225),
thesis: (
title: "Konfiguration & Integration von PROFINET",
subtitle: "für die AC500 SPS",
submission-date: "20. März 2024",
timeframe: "1. Januar 2023 - 20. März 2024",
kind: "T2000",
summary: "",
abstract: "",
keywords: ( "IT", "PROFINET" ),
bibliography: bibliography("refs.yml"),
glossary: (
(
key: "oidc",
short: "OIDC",
long: "OpenID Connect",
desc: [OpenID is an open standard and decentralized authentication protocol promoted by the non-profit #link("https://en.wikipedia.org/wiki/OpenID#OpenID_Foundation")[OpenID Foundation].]
),
(
key: "potato",
short: "potato",
plural: "potatoes",
desc: [#lorem(10)]
),
),
appendices: include "appendix.typ"
))
#show: doc => dhbw-template(config: config, doc: doc)
= Lorem Ipsum = Lorem Ipsum
#lorem(25) #lorem(25)
@oidc
#lorem(100) #lorem(100)
@Anhang-A
== Lorem Ipsum 2 == Lorem Ipsum 2
#lorem(200) #lorem(200)
@texbook
= Lorem Ipsum 3 = Lorem Ipsum 3
@ -74,42 +31,9 @@ $
"Hello", "World"), "Hello", "World"),
caption: [ Some table ]) caption: [ Some table ])
#pagebreak()
#figure( #figure(
```rust ```rust
use std::env; fn main() -> {
use std::fs::OpenOptions;
use std::io::Write;
fn main() {
// Get the file path from the environment variable
let file_path = match env::var("OUTPUT_FILE") {
Ok(path) => path,
Err(_) => {
eprintln!("Error: OUTPUT_FILE environment variable is not set");
return;
} }
};
// Open the file in append mode, create it if it doesn't exist
let mut file = match OpenOptions::new()
.append(true)
.create(true)
.open(&file_path)
{
Ok(file) => file,
Err(e) => {
eprintln!("Error opening file {}: {}", file_path, e);
return;
}
};
// Write "Hello, World" to the file
if let Err(e) = writeln!(file, "Hello, World") {
eprintln!("Error writing to file: {}", e);
} else {
println!("Successfully appended 'Hello, World' to {}", file_path);
}
}
```, caption: [Some code]) ```, caption: [Some code])

View File

@ -1,6 +0,0 @@
texbook:
type: book
title: The {TeX} Book
author: Knuth, Donald E.
date: 1986
publisher: Addison-Wesley Professional

View File

@ -1,14 +1,5 @@
// .--------------------------------------------------------------------------.
// | Abstract |
// '--------------------------------------------------------------------------'
// Author: Sven Vogel #let new_abstract(thesis) = context [
// Edited: 28.06.2024
// License: MIT
#let new_abstract(config) = context [
#let thesis = config.thesis
#pagebreak(weak: true) #pagebreak(weak: true)
#align(center + horizon)[ #align(center + horizon)[

View File

@ -1,35 +0,0 @@
#let show-appendix(config: dictionary) = context {
counter(heading).update(0)
let title = if text.lang == "en" {
"Appendix"
} else {
"Anhang"
}
if "appendices" in config.thesis {
pagebreak(weak: true)
heading(level: 1, numbering: none, title)
v(-2em)
// APA style appendix
show heading: it => {
let number = if it.numbering != none {
counter(heading).display(it.numbering)
}
block()[
#title #number - #it.body
]
}
show heading.where(level: 1): it => v(2em) + it + v(1em)
show heading.where(level: 2): it => v(1em) + it + v(0.5em)
show heading.where(level: 3): it => v(0.5em) + it + v(0.25em)
set heading(numbering: "A.1", supplement: title)
config.thesis.appendices
}
}

View File

@ -1,8 +1,7 @@
#let new_confidentiality_statement_page(config) = context [ #let new_confidentiality_statement_page(
thesis,
#let thesis = config.thesis author) = context [
#let author = config.author
#v(2em) #v(2em)
#if text.lang == "de" [ #if text.lang == "de" [

View File

@ -1,8 +1,5 @@
#let new_declaration_of_authorship(config) = context [ #let new_declaration_of_authorship(thesis, author) = context [
#let thesis = config.thesis
#let author = config.author
#v(2em) #v(2em)
#if text.lang == "de" [ #if text.lang == "de" [

7
src/pages/glossar.typ Normal file
View File

@ -0,0 +1,7 @@
#let new-glossar(glossary) = {
import "@preview/glossarium:0.4.1": make-glossary, print-glossary, gls, glspl
show: make-glossary
print-glossary(glossary)
}

View File

@ -55,34 +55,10 @@
pagebreak(weak: true) pagebreak(weak: true)
outline( outline(
target: heading.where(supplement: [chapter]),
title: heading(level: 3, title), title: heading(level: 3, title),
indent: auto) indent: auto)
} }
#let render_appendix_outline() = context {
let supplement = if text.lang == "en" {
[Appendix]
} else {
[Anhang]
}
if query(heading.where(supplement: supplement)).len() > 0 {
let title = if (text.lang == "de") {
"Anhangsverzeichnis"
} else if text.lang == "en" {
"Table of Appendices"
}
pagebreak(weak: true)
outline(
target: heading.where(supplement: supplement),
title: heading(level: 3, title),
indent: auto)
}
}
#let new_outline() = { #let new_outline() = {
show outline.entry.where( show outline.entry.where(
level: 1, level: 1,
@ -97,7 +73,5 @@
render_raw_outline() render_raw_outline()
render_appendix_outline()
render_heading_outline() render_heading_outline()
} }

View File

@ -1,8 +1,5 @@
#let new_prerelease_note(config) = context [ #let new_prerelease_note(thesis, author) = context [
#let thesis = config.thesis
#let author = config.author
#v(2em) #v(2em)
#if text.lang == "de" [ #if text.lang == "de" [

View File

Before

Width:  |  Height:  |  Size: 3.3 KiB

After

Width:  |  Height:  |  Size: 3.3 KiB

View File

Before

Width:  |  Height:  |  Size: 52 KiB

After

Width:  |  Height:  |  Size: 52 KiB

View File

@ -1,11 +1,22 @@
#let new_title_page(config) = context [ #let new_title_page(
thesis,
author) = context [
#let thesis = config.thesis #let LogoHeight = 1.5cm
#let author = config.author
#set align(center) #set align(center)
// logo of ABB and DHBW
#grid(
// set width of columns
// we need two, so make both half the page width
columns: (50%, 50%),
// left align logo of ABB
align(left, image("res/ABB.svg", height: LogoHeight)),
// right align logo of DHBW
align(right, image("res/DHBW.svg", height: LogoHeight)))
// title // title
#v(2cm) #v(2cm)
#text(size: 2em, weight: "semibold", thesis.title) #text(size: 2em, weight: "semibold", thesis.title)
@ -119,5 +130,5 @@
) )
) )
#counter(page).update(0) #counter(page).update(1)
] ]

File diff suppressed because it is too large Load Diff

View File

@ -7,14 +7,8 @@
// Edited: 27.06.2024 // Edited: 27.06.2024
// License: MIT // License: MIT
#let HeaderPaddingBottom = 1.5em
#let LogoHeight = 3em
#let HeaderUnderlinePaddingTop = 0pt
// global style of document // global style of document
#let global_styled_doc(config: dictionary, body: content) = context [ #let global_styled_doc(doc: content) = context [
#let thesis = config.thesis
// set page geometry // set page geometry
// paper format of A4 // paper format of A4
#set page( #set page(
@ -32,22 +26,12 @@
font: "Montserrat", font: "Montserrat",
weight: "semibold") weight: "semibold")
#set heading(supplement: [chapter])
// Set header spacing // Set header spacing
#show heading.where(level: 1): it => v(2em) + it + v(1em) #show heading.where(level: 1): it => v(2em) + it + v(1em)
#show heading.where(level: 2): it => v(1em) + it + v(0.5em) #show heading.where(level: 2): it => v(1em) + it + v(0.5em)
#show heading.where(level: 3): it => v(0.5em) + it + v(0.25em) #show heading.where(level: 3): it => v(0.5em) + it + v(0.25em)
#set raw(tab-size: 4, theme: "res/github.tmTheme") #set raw(tab-size: 4)
#show raw.where(block: true): code => {
show raw.line: line => {
text(fill: gray)[#line.number]
h(1em)
line.body
}
code
}
#set block(spacing: 2em) #set block(spacing: 2em)
#set par( #set par(
@ -55,45 +39,50 @@
first-line-indent: 1em, first-line-indent: 1em,
leading: 1em) leading: 1em)
#show link: set text(fill: red.darken(15%)) #doc
#show ref: set text(fill: red.darken(15%)) ]
#set heading(numbering: none) #let HeaderPaddingBottom = 1.5em
#let LogoHeight = 3em
#let HeaderUnderlinePaddingTop = 0pt
#let prelude_styled(body: content, thesis) = context [
#set page( #set page(
header-ascent: HeaderUnderlinePaddingTop + HeaderPaddingBottom, header-ascent: HeaderUnderlinePaddingTop + HeaderPaddingBottom,
numbering: "I",
margin: (top: 2.5cm + LogoHeight + HeaderUnderlinePaddingTop + HeaderPaddingBottom),
header: [
#grid(
columns: (1fr, auto),
align: (horizon, bottom),
context [ _ #thesis.title _ ],
image("pages/res/DHBW.svg", height: LogoHeight)
)
#v(HeaderUnderlinePaddingTop - 1em)
#line(length: 100%)
])
#body
]
#let content_styled(body: content, thesis) = [
// setup equate for sub equation labeling
#import "@preview/equate:0.2.0": equate
#show: equate.with(breakable: true, sub-numbering: true)
#set math.equation(numbering: "(1.1)")
#set heading(numbering: "1.")
#page(
header-ascent: HeaderUnderlinePaddingTop + HeaderPaddingBottom,
numbering: "1/1",
footer-descent: 1em, footer-descent: 1em,
margin: (top: 2.5cm + LogoHeight + HeaderUnderlinePaddingTop + HeaderPaddingBottom, bottom: 2.5cm + 1em), margin: (top: 2.5cm + LogoHeight + HeaderUnderlinePaddingTop + HeaderPaddingBottom, bottom: 2.5cm + 1em),
numbering: (..nums) => { header: context [
let current-page = here().page() #let headers-before = query(selector(heading.where(numbering: "1.", level: 1)).before(here()))
if current-page == 1{
[]
} else if query(<end-of-prelude>).first().location().page() > current-page {
numbering("I", nums.pos().first())
} else if query(<end-of-content>).first().location().page() >= current-page {
numbering("1 / 1", ..nums)
} else {
numbering("a", nums.pos().first())
}
},
header: context {
set align(left)
if here().page() == 1 {
// logo of ABB and DHBW
grid(
// set width of columns
// we need two, so make both half the page width
columns: (50%, 50%),
// left align logo of ABB
align(left, image("res/ABB.svg", height: LogoHeight)),
// right align logo of DHBW
align(right, image("res/DHBW.svg", height: LogoHeight)))
} else if query(<end-of-prelude>).first().location().page() <= here().page() { #let header-title = thesis.title
let headers-before = query(selector(heading.where(numbering: "1.", level: 1)).before(here()))
let header-title = thesis.title #if headers-before.len() > 0 {
if headers-before.len() > 0 {
header-title = headers-before.last().body header-title = headers-before.last().body
} else { } else {
let headers-after = query(selector(heading.where(numbering: "1.", level: 1)).after(here())) let headers-after = query(selector(heading.where(numbering: "1.", level: 1)).after(here()))
@ -103,47 +92,15 @@
} }
} }
grid( #grid(
columns: (1fr, auto), columns: (1fr, auto),
align: (horizon, bottom), align: (horizon, bottom),
context [ _ #header-title _ ], context [ _ #header-title _ ],
image("res/DHBW.svg", height: LogoHeight)) image("pages/res/DHBW.svg", height: LogoHeight)
v(HeaderUnderlinePaddingTop - 1em)
line(length: 100%)
} else {
grid(
columns: (1fr, auto),
align: (horizon, bottom),
context [ _ #config.thesis.title _ ],
image("res/DHBW.svg", height: LogoHeight)
) )
v(HeaderUnderlinePaddingTop - 1em) #v(HeaderUnderlinePaddingTop - 1em)
line(length: 100%) #line(length: 100%)
} ])[
})
#body
]
#let content_styled(config: dictionary, body: content) = [
// setup equate for sub equation labeling
#import "@preview/equate:0.2.0": equate
#show: equate.with(breakable: true, sub-numbering: true)
#set math.equation(numbering: "(1.1)")
#set heading(numbering: "1.")
#let thesis = config.thesis
#body
]
#let end_styled(config: dictionary, body: content) = [
#set heading(numbering: "1.")
#let thesis = config.thesis
#body #body
]
] ]

View File

@ -8,18 +8,12 @@
// License: MIT // License: MIT
// start of template pages and styles // start of template pages and styles
#let dhbw-template(config: dictionary, doc: content) = [ #let dhbw-template(doc) = [
#import "style.typ": global_styled_doc, content_styled, end_styled #import "style.typ": global_styled_doc, prelude_styled, content_styled
// set document properties
#set document(
author: config.author.name,
keywords: config.thesis.keywords,
title: config.thesis.title)
// apply global style to every element in the argument content // apply global style to every element in the argument content
#global_styled_doc(config: config, body: [ #global_styled_doc(doc: [
#import "pages/titlepage.typ": new_title_page #import "pages/titlepage.typ": new_title_page
#import "pages/declaration-of-authorship.typ": new_declaration_of_authorship #import "pages/declaration-of-authorship.typ": new_declaration_of_authorship
@ -27,67 +21,60 @@
#import "pages/prerelease-note.typ": new_prerelease_note #import "pages/prerelease-note.typ": new_prerelease_note
#import "pages/outline.typ": new_outline #import "pages/outline.typ": new_outline
#import "pages/abstract.typ": new_abstract #import "pages/abstract.typ": new_abstract
#import "pages/appendix.typ": show-appendix #import "pages/glossar.typ": new-glossar
// configure text locale #set text(lang: "de", region: "de")
#set text(lang: config.lang, region: config.region)
#let author = (
name: "Sven Vogel",
semester: 4,
program: "Informationstechnik",
course: "TINF22IT2",
faculty: "Technik",
university: "DHBW Mannheim",
company: "ABB AG",
supervisor: "Florian Miedniak",
matriculation-number: 1191225
)
#let thesis = (
title: "Konfiguration & Integration von PROFINET",
subtitle: "für die AC500 SPS",
submission-date: "20. März 2024",
timeframe: "1. Januar 2023 - 20. März 2024",
kind: "T2000",
summary: "",
abstract: "",
)
#let glossary = ()
// preppend title page // preppend title page
#new_title_page(config) #new_title_page(thesis, author)
// prelude includes: title, declaration of authorship, confidentiality statement, outline and abstract #prelude_styled(thesis, body: [
// these will have roman page numbers #pagebreak(weak: true)
#new_declaration_of_authorship(thesis, author)
#pagebreak(weak: true) #pagebreak(weak: true)
#new_declaration_of_authorship(config) #new_confidentiality_statement_page(thesis, author)
#pagebreak(weak: true) #pagebreak(weak: true)
#new_confidentiality_statement_page(config) #new_prerelease_note(thesis, author)
#pagebreak(weak: true)
#new_prerelease_note(config)
#pagebreak(weak: true) #pagebreak(weak: true)
#new_outline() #new_outline()
// glossary is built inline here because the links must be #pagebreak(weak: true)
// exposed to the entire document #new_abstract(thesis)
#import "@preview/glossarium:0.4.1": make-glossary, print-glossary, gls, glspl
#show: make-glossary
#pagebreak(weak: true) #pagebreak(weak: true)
#new-glossar(glossary)
])
#heading(supplement: [outline], "Glossar") #content_styled(thesis, body: [
#print-glossary(config.thesis.glossary)
#pagebreak(weak: true)
#new_abstract(config)
#pagebreak(weak: true)
#counter(page).update(1)
// mark end of prelude
#metadata("prelude terminate") <end-of-prelude>
#content_styled(config: config, body: [
// code of document follows here // code of document follows here
#doc #doc
]) ])
#metadata("content terminate") <end-of-content>
#end_styled(config: config, body: [
// add bibliography if set
#if config.thesis.bibliography != none {
pagebreak(weak: true)
set bibliography(style: "ieee")
config.thesis.bibliography
counter(page).update(1)
}
// appendix
#show-appendix(config: config)
])
]) ])
] ]