Compare commits
15 Commits
6e17d96b8b
...
v0.9.2
Author | SHA1 | Date | |
---|---|---|---|
d9ab5e8ab1
|
|||
b8502b5466
|
|||
ca46ff32a8
|
|||
f7737687db
|
|||
6850224e84
|
|||
![]() |
08bcc0672b | ||
211bdc54db | |||
![]() |
f8ebdfe1f8 | ||
![]() |
b5e1f1d663 | ||
d8dc47e3b0
|
|||
3beac874c1
|
|||
0dc0ed4249
|
|||
5d763827e8
|
|||
7b3831f5fb
|
|||
89c3be0bf0
|
1
.gitattributes
vendored
1
.gitattributes
vendored
@@ -1,2 +1,3 @@
|
|||||||
*.ttf filter=lfs diff=lfs merge=lfs -text
|
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||||
*.otf filter=lfs diff=lfs merge=lfs -text
|
*.otf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
42
Makefile
42
Makefile
@@ -1,11 +1,19 @@
|
|||||||
.PHONY: view_example
|
.PHONY: view_documentation
|
||||||
view_example: documentation.pdf
|
view_documentation: documentation.pdf
|
||||||
xdg-open $<
|
xdg-open $<
|
||||||
|
|
||||||
.PHONY: watch_documentation
|
.PHONY: watch_documentation
|
||||||
watch_documentation:
|
watch_documentation:
|
||||||
typst watch --font-path template/fonts documentation.typ & xdg-open documentation.pdf
|
typst watch --font-path template/fonts documentation.typ & xdg-open documentation.pdf
|
||||||
|
|
||||||
|
.PHONY: watch_bp_cs
|
||||||
|
watch_bp_cs: bp.pdf
|
||||||
|
xdg-open bp.pdf & typst watch --root . --font-path template/fonts theses/bp.typ bp.pdf
|
||||||
|
|
||||||
|
.PHONY: watch_dp_cs
|
||||||
|
watch_dp_cs: dp.pdf
|
||||||
|
xdg-open dp.pdf & typst watch --root . --font-path template/fonts theses/dp.typ dp.pdf
|
||||||
|
|
||||||
.PHONY: documentation
|
.PHONY: documentation
|
||||||
documentation: documentation.pdf
|
documentation: documentation.pdf
|
||||||
|
|
||||||
@@ -13,7 +21,8 @@ PACKDIR := pack/tultemplate2
|
|||||||
BUNDLEDIR := pack/bundle
|
BUNDLEDIR := pack/bundle
|
||||||
|
|
||||||
TO_PACK := $(shell find template -type f) template/LICENSE
|
TO_PACK := $(shell find template -type f) template/LICENSE
|
||||||
BUNDLE_TARGETS := $(TO_PACK:%=$(BUNDLEDIR)/%) $(BUNDLEDIR)/citations.bib $(BUNDLEDIR)/Makefile
|
BUNDLE_TARGETS := $(TO_PACK:%=$(BUNDLEDIR)/%) $(BUNDLEDIR)/citations.bib $(BUNDLEDIR)/bp.typ \
|
||||||
|
$(BUNDLEDIR)/dp.typ $(BUNDLEDIR)/Makefile
|
||||||
PACK_TARGETS := $(TO_PACK:%=$(PACKDIR)/%) $(PACKDIR)/documentation.typ \
|
PACK_TARGETS := $(TO_PACK:%=$(PACKDIR)/%) $(PACKDIR)/documentation.typ \
|
||||||
$(PACKDIR)/documentation.pdf $(PACKDIR)/citations.bib
|
$(PACKDIR)/documentation.pdf $(PACKDIR)/citations.bib
|
||||||
|
|
||||||
@@ -22,11 +31,12 @@ pack: pack/tultemplate2.zip
|
|||||||
|
|
||||||
.PHONY: bundle
|
.PHONY: bundle
|
||||||
bundle: $(BUNDLE_TARGETS)
|
bundle: $(BUNDLE_TARGETS)
|
||||||
|
@echo "!! Bundles are made for tultemplategen and not for direct use !!"
|
||||||
|
|
||||||
.PHONY: clean
|
.PHONY: clean
|
||||||
clean:
|
clean:
|
||||||
rm -rf pack
|
rm -rf pack
|
||||||
rm -f documentation.pdf
|
rm -f documentation.pdf bp.pdf dp.pdf
|
||||||
|
|
||||||
pack/tultemplate2.zip: $(PACK_TARGETS)
|
pack/tultemplate2.zip: $(PACK_TARGETS)
|
||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
@@ -37,9 +47,17 @@ $(PACKDIR)/%: %
|
|||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
ln -f $< $@
|
ln -f $< $@
|
||||||
|
|
||||||
$(BUNDLEDIR)/citations.bib:
|
$(BUNDLEDIR)/citations.bib: citations.bib
|
||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
touch $@
|
ln -f $< $@
|
||||||
|
|
||||||
|
$(BUNDLEDIR)/bp.typ: theses/bp.typ
|
||||||
|
@mkdir -p $(@D)
|
||||||
|
awk 'BEGIN{RS=""; ORS="\n\n"} NR>2{print}' $< | sed 's/\.\.\/template\//template\//' > $@
|
||||||
|
|
||||||
|
$(BUNDLEDIR)/dp.typ: theses/dp.typ
|
||||||
|
@mkdir -p $(@D)
|
||||||
|
awk 'BEGIN{RS=""; ORS="\n\n"} NR>2{print}' $< | sed 's/\.\.\/template\//template\//' > $@
|
||||||
|
|
||||||
$(BUNDLEDIR)/Makefile: templategen.mk
|
$(BUNDLEDIR)/Makefile: templategen.mk
|
||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
@@ -53,7 +71,11 @@ $(BUNDLEDIR)/template/LICENSE: LICENSE
|
|||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
ln -f $< $@
|
ln -f $< $@
|
||||||
|
|
||||||
$(PACKDIR)/template/tul_citace.csl $(BUNDLEDIR)/template/tul_citace.csl: template/tul_citace.csl
|
$(PACKDIR)/template/tul_citace.csl: template/tul_citace.csl
|
||||||
|
@mkdir -p $(@D)
|
||||||
|
cat $< | sed 's/^\s*\(.*\)$$/\1/' | tr -d '\n' > $@
|
||||||
|
|
||||||
|
$(BUNDLEDIR)/template/tul_citace.csl: template/tul_citace.csl
|
||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
cat $< | sed 's/^\s*\(.*\)$$/\1/' | tr -d '\n' > $@
|
cat $< | sed 's/^\s*\(.*\)$$/\1/' | tr -d '\n' > $@
|
||||||
|
|
||||||
@@ -75,6 +97,12 @@ $(BUNDLEDIR)/template/%: template/%
|
|||||||
|
|
||||||
TEMPLATE_SRCS := $(shell find template -type f)
|
TEMPLATE_SRCS := $(shell find template -type f)
|
||||||
|
|
||||||
|
bp.pdf: theses/bp.typ
|
||||||
|
typst compile --font-path template/fonts --root . $< $@
|
||||||
|
|
||||||
|
dp.pdf: theses/dp.typ
|
||||||
|
typst compile --font-path template/fonts --root . $< $@
|
||||||
|
|
||||||
documentation.pdf: documentation.typ $(TEMPLATE_SRCS)
|
documentation.pdf: documentation.typ $(TEMPLATE_SRCS)
|
||||||
typst compile --font-path template/fonts $<
|
typst compile --font-path template/fonts $<
|
||||||
|
|
||||||
|
@@ -105,6 +105,10 @@ Velmi jednoduché. Stačí na začátek řádku dát znak `=` kolikrát chcete.
|
|||||||
A pak obsah
|
A pak obsah
|
||||||
```
|
```
|
||||||
|
|
||||||
|
#highlight[
|
||||||
|
V rámci šablony classic lze použít nadpisy *maximálně* třetí úrovně -- jinak šablona vyhodí chybu.
|
||||||
|
]
|
||||||
|
|
||||||
== Zvýrazňování textu
|
== Zvýrazňování textu
|
||||||
|
|
||||||
Syntaxe je velmi podobná například markdownu. Stačí:
|
Syntaxe je velmi podobná například markdownu. Stačí:
|
||||||
@@ -168,8 +172,7 @@ A některé funkce berou klasický obsah -- v těch je možné psát obsah jako
|
|||||||
== Obrázky
|
== Obrázky
|
||||||
|
|
||||||
Obrázky je možné vkládat samotné i třeba s popiskem.
|
Obrázky je možné vkládat samotné i třeba s popiskem.
|
||||||
|
Obrázek se vloží pomocí funkce `image`.
|
||||||
Obrázek se vloží pomocí funkce `image`:
|
|
||||||
|
|
||||||
Přidání popisku a zároveň zalistování obrázku v indexu (aby se na ně třeba dalo odkazovat) lze
|
Přidání popisku a zároveň zalistování obrázku v indexu (aby se na ně třeba dalo odkazovat) lze
|
||||||
udělat pomocí funkce `figure`.
|
udělat pomocí funkce `figure`.
|
||||||
@@ -323,6 +326,7 @@ Zvýrazněné hodnoty jsou základní -- pokud vynecháte parametr, pak bude pou
|
|||||||
- `document` (typ dokumentu)
|
- `document` (typ dokumentu)
|
||||||
- *`"other"`* - nespecifikovaný (neformální) typ dokumentu
|
- *`"other"`* - nespecifikovaný (neformální) typ dokumentu
|
||||||
- `bp` - Bakalářská práce
|
- `bp` - Bakalářská práce
|
||||||
|
- `dp` - Diplomová práce
|
||||||
#line()
|
#line()
|
||||||
- `title` (nadpis dokumentu)
|
- `title` (nadpis dokumentu)
|
||||||
- Ve formátu `(<zkratka_jazyka>: "<nadpis>")`, například `(cs: "Můj nadpis")`
|
- Ve formátu `(<zkratka_jazyka>: "<nadpis>")`, například `(cs: "Můj nadpis")`
|
||||||
@@ -352,7 +356,7 @@ Zvýrazněné hodnoty jsou základní -- pokud vynecháte parametr, pak bude pou
|
|||||||
- Je vyžadován jazyk, který je vybrán pro celou šablonu -- tohle je pojistka, aby uživatel šablony
|
- Je vyžadován jazyk, který je vybrán pro celou šablonu -- tohle je pojistka, aby uživatel šablony
|
||||||
nevynechal vybraný jazyk
|
nevynechal vybraný jazyk
|
||||||
#line()
|
#line()
|
||||||
- `branch` (studijní obor)
|
- `specialization` (specializace)
|
||||||
- Stejně jako #link(<arg_programme>, [`programme`])
|
- Stejně jako #link(<arg_programme>, [`programme`])
|
||||||
#line()
|
#line()
|
||||||
- `abstract` (abstrakt)
|
- `abstract` (abstrakt)
|
||||||
|
@@ -20,7 +20,7 @@
|
|||||||
faculty_id, faculty_color, language, assignment_document, citation_file,
|
faculty_id, faculty_color, language, assignment_document, citation_file,
|
||||||
|
|
||||||
// document info
|
// document info
|
||||||
title, author, author_pronouns, supervisor, consultant, study_programme, study_branch,
|
title, author, author_pronouns, supervisor, consultant, study_programme, study_specialization,
|
||||||
year_of_study, abstract_content, acknowledgement_content, keywords,
|
year_of_study, abstract_content, acknowledgement_content, keywords,
|
||||||
|
|
||||||
content
|
content
|
||||||
@@ -31,8 +31,8 @@
|
|||||||
|
|
||||||
assert_not_none(study_programme, "study programme");
|
assert_not_none(study_programme, "study programme");
|
||||||
assert_dict_has((language,), study_programme, "study programme");
|
assert_dict_has((language,), study_programme, "study programme");
|
||||||
assert_not_none(study_branch, "study branch");
|
assert_not_none(study_specialization, "study specialization");
|
||||||
assert_dict_has((language,), study_branch, "study branch");
|
assert_dict_has((language,), study_specialization, "study specialization");
|
||||||
|
|
||||||
assert_not_none(abstract_content, "abstract");
|
assert_not_none(abstract_content, "abstract");
|
||||||
assert_dict_has(force_langs, abstract_content, "abstract");
|
assert_dict_has(force_langs, abstract_content, "abstract");
|
||||||
@@ -49,7 +49,7 @@
|
|||||||
|
|
||||||
mainpage(
|
mainpage(
|
||||||
faculty_id, language, "bp", title, author, supervisor, consultant, study_programme,
|
faculty_id, language, "bp", title, author, supervisor, consultant, study_programme,
|
||||||
study_branch, year_of_study,
|
study_specialization, year_of_study,
|
||||||
);
|
);
|
||||||
assignment(language, assignment_document);
|
assignment(language, assignment_document);
|
||||||
default_styling(false, faculty_color, {
|
default_styling(false, faculty_color, {
|
||||||
|
@@ -5,6 +5,7 @@
|
|||||||
|
|
||||||
// thesis types
|
// thesis types
|
||||||
#import "bp.typ": bp
|
#import "bp.typ": bp
|
||||||
|
#import "dp.typ": dp
|
||||||
#import "other.typ": other
|
#import "other.typ": other
|
||||||
|
|
||||||
#let template_classic(
|
#let template_classic(
|
||||||
@@ -12,7 +13,7 @@
|
|||||||
language, faculty_id, document_type, citation_file, assignment_document,
|
language, faculty_id, document_type, citation_file, assignment_document,
|
||||||
|
|
||||||
// document info
|
// document info
|
||||||
title, author, author_pronouns, supervisor, consultant, study_programme, study_branch,
|
title, author, author_pronouns, supervisor, consultant, study_programme, study_specialization,
|
||||||
year_of_study, abstract, acknowledgement, keywords,
|
year_of_study, abstract, acknowledgement, keywords,
|
||||||
|
|
||||||
// content
|
// content
|
||||||
@@ -21,12 +22,13 @@
|
|||||||
// argument pre-checking
|
// argument pre-checking
|
||||||
let document_types = (
|
let document_types = (
|
||||||
"bp": bp,
|
"bp": bp,
|
||||||
|
"dp": dp,
|
||||||
"other": other,
|
"other": other,
|
||||||
)
|
)
|
||||||
assert_in_dict(document_type, document_types, "document type");
|
assert_in_dict(document_type, document_types, "document type");
|
||||||
map_none(title, (v) => assert_dict_has((language,), v, "title"));
|
map_none(title, (v) => assert_dict_has((language,), v, "title"));
|
||||||
map_none(study_programme, (v) => assert_dict_has((language,), v, "study programme"));
|
map_none(study_programme, (v) => assert_dict_has((language,), v, "study programme"));
|
||||||
map_none(study_branch, (v) => assert_dict_has((language,), v, "study branch"));
|
map_none(study_specialization, (v) => assert_dict_has((language,), v, "study specialization"));
|
||||||
map_none(acknowledgement, (v) => assert_dict_has((language,), v, "acknowledgement content"));
|
map_none(acknowledgement, (v) => assert_dict_has((language,), v, "acknowledgement content"));
|
||||||
|
|
||||||
document_types.at(document_type)(
|
document_types.at(document_type)(
|
||||||
@@ -41,7 +43,7 @@
|
|||||||
supervisor,
|
supervisor,
|
||||||
consultant,
|
consultant,
|
||||||
study_programme,
|
study_programme,
|
||||||
study_branch,
|
study_specialization,
|
||||||
year_of_study,
|
year_of_study,
|
||||||
abstract,
|
abstract,
|
||||||
acknowledgement,
|
acknowledgement,
|
||||||
|
@@ -36,7 +36,7 @@
|
|||||||
|
|
||||||
// text
|
// text
|
||||||
set text(font: serif_font);
|
set text(font: serif_font);
|
||||||
set par(justify: true);
|
set par(justify: true, first-line-indent: 0.63cm);
|
||||||
|
|
||||||
// figures
|
// figures
|
||||||
let figure_numbering(realcount, c) = {
|
let figure_numbering(realcount, c) = {
|
||||||
@@ -70,6 +70,13 @@
|
|||||||
v(2cm);
|
v(2cm);
|
||||||
it
|
it
|
||||||
};
|
};
|
||||||
|
show heading.where(): it => {
|
||||||
|
if it.level > 3 {
|
||||||
|
panic("maximum allowed heading level is 3");
|
||||||
|
} else {
|
||||||
|
it
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// other
|
// other
|
||||||
show raw: set text(font: mono_font, size: mono_font_compensation);
|
show raw: set text(font: mono_font, size: mono_font_compensation);
|
||||||
@@ -84,6 +91,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
set highlight(fill: faculty_color.lighten(90%));
|
set highlight(fill: faculty_color.lighten(90%));
|
||||||
|
set line(stroke: (paint: faculty_color, thickness: .7pt), length: 100%);
|
||||||
|
|
||||||
content
|
content
|
||||||
}
|
}
|
||||||
@@ -127,7 +135,7 @@
|
|||||||
faculty_id,
|
faculty_id,
|
||||||
language,
|
language,
|
||||||
document_type,
|
document_type,
|
||||||
title, author, supervisor, consultant, study_programme, study_branch, year_of_study,
|
title, author, supervisor, consultant, study_programme, study_specialization, year_of_study,
|
||||||
) = {
|
) = {
|
||||||
let info_name_value_padding = 5em;
|
let info_name_value_padding = 5em;
|
||||||
let info_name_min_width = 10em;
|
let info_name_min_width = 10em;
|
||||||
@@ -153,7 +161,7 @@
|
|||||||
("supervisor", person_info(supervisor, "supervisor"), false),
|
("supervisor", person_info(supervisor, "supervisor"), false),
|
||||||
("consultant", person_info(consultant, "consultant"), false),
|
("consultant", person_info(consultant, "consultant"), false),
|
||||||
("study_programme", study_programme, false),
|
("study_programme", study_programme, false),
|
||||||
("study_branch", study_branch, false),
|
("study_specialization", study_specialization, false),
|
||||||
("year_of_study", map_none(year_of_study, (v) => str(v) + "."), false),
|
("year_of_study", map_none(year_of_study, (v) => str(v) + "."), false),
|
||||||
)
|
)
|
||||||
context {
|
context {
|
||||||
@@ -189,7 +197,7 @@
|
|||||||
faculty_id,
|
faculty_id,
|
||||||
language,
|
language,
|
||||||
document_type,
|
document_type,
|
||||||
title, author, supervisor, consultant, study_programme, study_branch, year_of_study,
|
title, author, supervisor, consultant, study_programme, study_specialization, year_of_study,
|
||||||
) = {
|
) = {
|
||||||
import "../utils.typ": has_all_none, map_none
|
import "../utils.typ": has_all_none, map_none
|
||||||
let nonetype = type(none);
|
let nonetype = type(none);
|
||||||
@@ -204,7 +212,7 @@
|
|||||||
info(
|
info(
|
||||||
faculty_id, language, document_type, map_none(title, (v) => v.at(language)),
|
faculty_id, language, document_type, map_none(title, (v) => v.at(language)),
|
||||||
author, supervisor, consultant, map_none(study_programme, (v) => v.at(language)),
|
author, supervisor, consultant, map_none(study_programme, (v) => v.at(language)),
|
||||||
map_none(study_branch, (v) => v.at(language)), year_of_study,
|
map_none(study_specialization, (v) => v.at(language)), year_of_study,
|
||||||
);
|
);
|
||||||
v(5em);
|
v(5em);
|
||||||
}, bottom);
|
}, bottom);
|
||||||
@@ -378,9 +386,13 @@
|
|||||||
|
|
||||||
#let bibliogr(language, citations_file) = {
|
#let bibliogr(language, citations_file) = {
|
||||||
if language == "cs" {
|
if language == "cs" {
|
||||||
bibliography(citations_file, style: "../tul_citace.csl");
|
bibliography(
|
||||||
|
citations_file, style: "../tul_citace.csl", title: get_lang_item(language, "bibliography"),
|
||||||
|
);
|
||||||
} else if language == "en" {
|
} else if language == "en" {
|
||||||
bibliography(citations_file, style: "iso-690-numeric");
|
bibliography(
|
||||||
|
citations_file, style: "iso-690-numeric", title: get_lang_item(language, "bibliography"),
|
||||||
|
);
|
||||||
} else {
|
} else {
|
||||||
panic("unknown language for bibliography '" + language + "'");
|
panic("unknown language for bibliography '" + language + "'");
|
||||||
}
|
}
|
||||||
|
68
template/classic/dp.typ
Normal file
68
template/classic/dp.typ
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
#import "../lang.typ": get_lang_item
|
||||||
|
#import "common.typ": (
|
||||||
|
mainpage,
|
||||||
|
default_styling,
|
||||||
|
assignment,
|
||||||
|
disclaimer,
|
||||||
|
abstract,
|
||||||
|
acknowledgement,
|
||||||
|
toc,
|
||||||
|
abbrlist,
|
||||||
|
imagelist,
|
||||||
|
tablelist,
|
||||||
|
bibliogr
|
||||||
|
)
|
||||||
|
#import "../attachments.typ": attachment_list
|
||||||
|
#import "../utils.typ": is_none, assert_dict_has, assert_not_none, assert_type_signature, map_none
|
||||||
|
|
||||||
|
#let dp(
|
||||||
|
// general settings
|
||||||
|
faculty_id, faculty_color, language, assignment_document, citation_file,
|
||||||
|
|
||||||
|
// document info
|
||||||
|
title, author, author_pronouns, supervisor, consultant, study_programme, study_specialization,
|
||||||
|
year_of_study, abstract_content, acknowledgement_content, keywords,
|
||||||
|
|
||||||
|
content
|
||||||
|
) = {
|
||||||
|
let force_langs = ("cs", "en");
|
||||||
|
assert_not_none(title, "title");
|
||||||
|
assert_dict_has(force_langs, title, "title");
|
||||||
|
|
||||||
|
assert_not_none(study_programme, "study programme");
|
||||||
|
assert_dict_has((language,), study_programme, "study programme");
|
||||||
|
map_none(study_specialization, (v) => assert_dict_has((language,), v, "study specialization"));
|
||||||
|
|
||||||
|
assert_not_none(abstract_content, "abstract");
|
||||||
|
assert_dict_has(force_langs, abstract_content, "abstract");
|
||||||
|
if not is_none(keywords) {
|
||||||
|
assert_dict_has(force_langs, keywords, "keywords");
|
||||||
|
}
|
||||||
|
assert_not_none(acknowledgement_content, "acknowledgement content");
|
||||||
|
if language == "cs" {
|
||||||
|
assert_not_none(author_pronouns, "author gender");
|
||||||
|
}
|
||||||
|
|
||||||
|
assert_type_signature(supervisor, "string | none", "supervisor");
|
||||||
|
assert_type_signature(consultant, "string | none", "consultant");
|
||||||
|
|
||||||
|
mainpage(
|
||||||
|
faculty_id, language, "dp", title, author, supervisor, consultant, study_programme,
|
||||||
|
study_specialization, year_of_study,
|
||||||
|
);
|
||||||
|
assignment(language, assignment_document);
|
||||||
|
default_styling(false, faculty_color, {
|
||||||
|
disclaimer(language, faculty_id, "dp", author, author_pronouns);
|
||||||
|
abstract("cs", title, abstract_content, keywords);
|
||||||
|
abstract("en", title, abstract_content, keywords);
|
||||||
|
acknowledgement(language, author, acknowledgement_content);
|
||||||
|
toc(language);
|
||||||
|
tablelist(language);
|
||||||
|
imagelist(language);
|
||||||
|
abbrlist(language);
|
||||||
|
pagebreak(weak: true);
|
||||||
|
content;
|
||||||
|
bibliogr(language, citation_file);
|
||||||
|
attachment_list(language);
|
||||||
|
});
|
||||||
|
}
|
@@ -9,6 +9,7 @@
|
|||||||
abbrlist,
|
abbrlist,
|
||||||
imagelist,
|
imagelist,
|
||||||
tablelist,
|
tablelist,
|
||||||
|
bibliogr,
|
||||||
)
|
)
|
||||||
#import "../attachments.typ": attachment_list
|
#import "../attachments.typ": attachment_list
|
||||||
#import "../utils.typ": is_none, assert_not_none, assert_dict_has, assert_in_arr
|
#import "../utils.typ": is_none, assert_not_none, assert_dict_has, assert_in_arr
|
||||||
@@ -18,7 +19,7 @@
|
|||||||
faculty_id, faculty_color, language, assignment_document, citation_file,
|
faculty_id, faculty_color, language, assignment_document, citation_file,
|
||||||
|
|
||||||
// document info
|
// document info
|
||||||
title, author, _, supervisor, consultant, study_programme, study_branch, year_of_study,
|
title, author, _, supervisor, consultant, study_programme, study_specialization, year_of_study,
|
||||||
abstract_content, _, keywords,
|
abstract_content, _, keywords,
|
||||||
|
|
||||||
content
|
content
|
||||||
@@ -28,7 +29,7 @@
|
|||||||
|
|
||||||
mainpage(
|
mainpage(
|
||||||
faculty_id, language, none, title, author, supervisor, consultant, study_programme,
|
faculty_id, language, none, title, author, supervisor, consultant, study_programme,
|
||||||
study_branch, year_of_study,
|
study_specialization, year_of_study,
|
||||||
);
|
);
|
||||||
default_styling(true, faculty_color, {
|
default_styling(true, faculty_color, {
|
||||||
toc(language);
|
toc(language);
|
||||||
@@ -37,7 +38,7 @@
|
|||||||
abbrlist(language);
|
abbrlist(language);
|
||||||
pagebreak(to: "even", weak: true);
|
pagebreak(to: "even", weak: true);
|
||||||
content;
|
content;
|
||||||
bibliography(citation_file, style: "../tul_citace.csl");
|
bibliogr(language, citation_file);
|
||||||
attachment_list(language);
|
attachment_list(language);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@@ -5,14 +5,16 @@
|
|||||||
"supervisor": "Vedoucí práce",
|
"supervisor": "Vedoucí práce",
|
||||||
"consultant": "Konzultant práce",
|
"consultant": "Konzultant práce",
|
||||||
"study_programme": "Studijní program",
|
"study_programme": "Studijní program",
|
||||||
"study_branch": "Studijní obor",
|
"study_specialization": "Specializace",
|
||||||
"year_of_study": "Ročník",
|
"year_of_study": "Ročník",
|
||||||
|
|
||||||
"bp": "Bakalářská práce",
|
"bp": "Bakalářská práce",
|
||||||
|
"dp": "Diplomová práce",
|
||||||
|
|
||||||
"city": "Liberec",
|
"city": "Liberec",
|
||||||
|
|
||||||
"toc": "Obsah",
|
"toc": "Obsah",
|
||||||
|
"bibliography": "Použitá literatura",
|
||||||
|
|
||||||
"disclaimer": "Prohlášení",
|
"disclaimer": "Prohlášení",
|
||||||
"disclaimer_content": "Prohlašuj{g:i|i|eme}, že {svůj} {práce:tu} js{g:em|em|me} vypracoval{g:|a|i} samostatně jako původní dílo s použitím uvedené literatury a na základě konzultací s vedoucím {{g:mé|mé|naší}} bakalářské práce a konzultantem.\n\nJs{g:em|em|me} si vědom{g:|a|i} toho, že na {{g:moji|moji|naši}} {práce:tu} se plně vztahuje zákon č. 121/2000 Sb., o právu autorském, zejména § 60 – školní dílo.\n\nBer{g:u|u|eme} na vědomí, že Technická univerzita v Liberci nezasahuje do {g:mých|mých|našich} autorských práv užitím {{g:mé|mé|naší}} {práce:té} pro vnitřní potřebu Technické univerzity v Liberci.\n\nUžij{g:i|i|eme}-li {práce:tu} nebo poskytn{g:u|u|eme}-li licenci k {jejímu} využití, js{g:em|em|me} si vědom{g:|a|i} povinnosti informovat o této skutečnosti Technickou univerzitu v Liberci; v tomto případě má Technická univerzita v Liberci právo od{g:e|e|} {g:mne|mne|nás} požadovat úhradu nákladů, které vynaložila na vytvoření díla, až do jejich skutečné výše.\n\nSoučasně čestně prohlašuj{g:i|i|eme}, že text elektronické podoby práce vložený do IS/STAG se shoduje s textem tištěné podoby práce.\n\nBer{g:u|u|eme} na vědomí, že {{g:můj|můj|naše}} {práce:ta} bude {zveřejněn} Technickou univerzitou v Liberci v souladu s § 47b zákona č. 111/1998 Sb., o vysokých školách a o změně a doplnění dalších zákonů (zákon o vysokých školách), ve znění pozdějších předpisů.\n\nJs{g:em|em|me} si vědom{g:|a|i} následků, které podle zákona o vysokých školách mohou vyplývat z porušení tohoto prohlášení.",
|
"disclaimer_content": "Prohlašuj{g:i|i|eme}, že {svůj} {práce:tu} js{g:em|em|me} vypracoval{g:|a|i} samostatně jako původní dílo s použitím uvedené literatury a na základě konzultací s vedoucím {{g:mé|mé|naší}} bakalářské práce a konzultantem.\n\nJs{g:em|em|me} si vědom{g:|a|i} toho, že na {{g:moji|moji|naši}} {práce:tu} se plně vztahuje zákon č. 121/2000 Sb., o právu autorském, zejména § 60 – školní dílo.\n\nBer{g:u|u|eme} na vědomí, že Technická univerzita v Liberci nezasahuje do {g:mých|mých|našich} autorských práv užitím {{g:mé|mé|naší}} {práce:té} pro vnitřní potřebu Technické univerzity v Liberci.\n\nUžij{g:i|i|eme}-li {práce:tu} nebo poskytn{g:u|u|eme}-li licenci k {jejímu} využití, js{g:em|em|me} si vědom{g:|a|i} povinnosti informovat o této skutečnosti Technickou univerzitu v Liberci; v tomto případě má Technická univerzita v Liberci právo od{g:e|e|} {g:mne|mne|nás} požadovat úhradu nákladů, které vynaložila na vytvoření díla, až do jejich skutečné výše.\n\nSoučasně čestně prohlašuj{g:i|i|eme}, že text elektronické podoby práce vložený do IS/STAG se shoduje s textem tištěné podoby práce.\n\nBer{g:u|u|eme} na vědomí, že {{g:můj|můj|naše}} {práce:ta} bude {zveřejněn} Technickou univerzitou v Liberci v souladu s § 47b zákona č. 111/1998 Sb., o vysokých školách a o změně a doplnění dalších zákonů (zákon o vysokých školách), ve znění pozdějších předpisů.\n\nJs{g:em|em|me} si vědom{g:|a|i} následků, které podle zákona o vysokých školách mohou vyplývat z porušení tohoto prohlášení.",
|
||||||
@@ -31,6 +33,21 @@
|
|||||||
"svůj": "svoji",
|
"svůj": "svoji",
|
||||||
"jejímu": "jejímu",
|
"jejímu": "jejímu",
|
||||||
"zveřejněn": "zveřejněna"
|
"zveřejněn": "zveřejněna"
|
||||||
|
},
|
||||||
|
|
||||||
|
"dp": {
|
||||||
|
"práce:ta": "diplomová práce",
|
||||||
|
"práce:tu": "diplomovou práci",
|
||||||
|
"práce:té": "diplomové práce",
|
||||||
|
"moji": "moji",
|
||||||
|
"naše": "naše",
|
||||||
|
"naši": "naši",
|
||||||
|
"naší": "naší",
|
||||||
|
"mé": "mé",
|
||||||
|
"můj": "moje",
|
||||||
|
"svůj": "svoji",
|
||||||
|
"jejímu": "jejímu",
|
||||||
|
"zveřejněn": "zveřejněna"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@@ -56,14 +73,16 @@
|
|||||||
"supervisor": "Supervisor",
|
"supervisor": "Supervisor",
|
||||||
"consultant": "Consultant",
|
"consultant": "Consultant",
|
||||||
"study_programme": "Study programme",
|
"study_programme": "Study programme",
|
||||||
"study_branch": "Study branch",
|
"study_specialization": "Specialization",
|
||||||
"year_of_study": "Year of study",
|
"year_of_study": "Year of study",
|
||||||
|
|
||||||
"bp": "Bachelor thesis",
|
"bp": "Bachelor thesis",
|
||||||
|
"dp": "Diploma thesis",
|
||||||
|
|
||||||
"city": "Liberec",
|
"city": "Liberec",
|
||||||
|
|
||||||
"toc": "Contents",
|
"toc": "Contents",
|
||||||
|
"bibliography": "Bibliography",
|
||||||
|
|
||||||
"disclaimer": "Declaration",
|
"disclaimer": "Declaration",
|
||||||
"disclaimer_content": "{g:I|We} hereby certify, {g:I|we}, {g:myself|ourselves}, have written {g:my|our} {thesis} as an original and primary work using the literature listed below and consulting it with {g:my|our} thesis supervisor and {g:my|our} thesis counsellor.\n\n{g:I|We} acknowledge that {g:my|our} {thesis} is fully governed by Act No. 121/2000 Coll., the Copyright Act, in particular Article 60 – School Work.\n\n{g:I|We} acknowledge that the Technical University of Liberec does not infringe {g:my|our} copyrights by using {g:my|our} {thesis} for internal purposes of the Technical University of Liberec.\n\n{g:I|We} {g:am|are} aware of {g:my|our} obligation to inform the Technical University of Liberec on having used or granted license to use the results of {g:my|our} {thesis}; in such a case the Technical University of Liberec may require reimbursement of the costs incurred for creating the result up to their actual amount.\n\nAt the same time, {g:I|we} honestly declare that the text of the printed version of {g:my|our} {thesis} is identical with the text of the electronic version uploaded into the IS STAG.\n\n{g:I|We} acknowledge that the Technical University of Liberec will make {g:my|our} {thesis} public in accordance with paragraph 47b of Act No. 111/1998 Coll., on Higher Education Institutions and on Amendment to Other Acts (the Higher Education Act), as amended.\n\n{g:I|We} {g:am|are} aware of the consequences which may under the Higher Education Act result from a breach of this declaration.",
|
"disclaimer_content": "{g:I|We} hereby certify, {g:I|we}, {g:myself|ourselves}, have written {g:my|our} {thesis} as an original and primary work using the literature listed below and consulting it with {g:my|our} thesis supervisor and {g:my|our} thesis counsellor.\n\n{g:I|We} acknowledge that {g:my|our} {thesis} is fully governed by Act No. 121/2000 Coll., the Copyright Act, in particular Article 60 – School Work.\n\n{g:I|We} acknowledge that the Technical University of Liberec does not infringe {g:my|our} copyrights by using {g:my|our} {thesis} for internal purposes of the Technical University of Liberec.\n\n{g:I|We} {g:am|are} aware of {g:my|our} obligation to inform the Technical University of Liberec on having used or granted license to use the results of {g:my|our} {thesis}; in such a case the Technical University of Liberec may require reimbursement of the costs incurred for creating the result up to their actual amount.\n\nAt the same time, {g:I|we} honestly declare that the text of the printed version of {g:my|our} {thesis} is identical with the text of the electronic version uploaded into the IS STAG.\n\n{g:I|We} acknowledge that the Technical University of Liberec will make {g:my|our} {thesis} public in accordance with paragraph 47b of Act No. 111/1998 Coll., on Higher Education Institutions and on Amendment to Other Acts (the Higher Education Act), as amended.\n\n{g:I|We} {g:am|are} aware of the consequences which may under the Higher Education Act result from a breach of this declaration.",
|
||||||
@@ -71,6 +90,10 @@
|
|||||||
"disclaimer_replace": {
|
"disclaimer_replace": {
|
||||||
"bp": {
|
"bp": {
|
||||||
"thesis": "bachelor thesis"
|
"thesis": "bachelor thesis"
|
||||||
|
},
|
||||||
|
|
||||||
|
"dp": {
|
||||||
|
"thesis": "diploma thesis"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@@ -32,7 +32,7 @@
|
|||||||
// - supervisor (str): The name of the document's supervisor.
|
// - supervisor (str): The name of the document's supervisor.
|
||||||
// - consultant (str): The name of the document's consultant.
|
// - consultant (str): The name of the document's consultant.
|
||||||
// - programme (dictionary): Study programme.
|
// - programme (dictionary): Study programme.
|
||||||
// - branch (disctionary): Study branch
|
// - specialization (disctionary): Study specialization
|
||||||
// - abstract (dictionary): The abstract.
|
// - abstract (dictionary): The abstract.
|
||||||
// - keywords (dictionary): The abstract keywords.
|
// - keywords (dictionary): The abstract keywords.
|
||||||
// - assignment (str): Filepath of the assignment document/page.
|
// - assignment (str): Filepath of the assignment document/page.
|
||||||
@@ -47,7 +47,7 @@
|
|||||||
// document info
|
// document info
|
||||||
title: none, keywords: none, abstract: none, acknowledgement: none, author: none,
|
title: none, keywords: none, abstract: none, acknowledgement: none, author: none,
|
||||||
author_pronouns: none, supervisor: none, consultant: none, programme: none,
|
author_pronouns: none, supervisor: none, consultant: none, programme: none,
|
||||||
branch: none, year_of_study: none,
|
specialization: none, year_of_study: none,
|
||||||
|
|
||||||
// links
|
// links
|
||||||
assignment: none, citations: "citations.bib",
|
assignment: none, citations: "citations.bib",
|
||||||
@@ -81,7 +81,9 @@
|
|||||||
assert_type_signature(
|
assert_type_signature(
|
||||||
programme, "dictionary[string : string] | none", "study programme argument"
|
programme, "dictionary[string : string] | none", "study programme argument"
|
||||||
);
|
);
|
||||||
assert_type_signature(branch, "dictionary[string : string] | none", "study branch argument");
|
assert_type_signature(
|
||||||
|
specialization, "dictionary[string : string] | none", "study specialization argument"
|
||||||
|
);
|
||||||
assert_type_signature(year_of_study, "integer | none", "year of study");
|
assert_type_signature(year_of_study, "integer | none", "year of study");
|
||||||
assert_type_signature(assignment, "string | none", "assignment document argument");
|
assert_type_signature(assignment, "string | none", "assignment document argument");
|
||||||
assert_type_signature(citations, "string", "citations file argument");
|
assert_type_signature(citations, "string", "citations file argument");
|
||||||
@@ -102,7 +104,7 @@
|
|||||||
templates.at(style)(
|
templates.at(style)(
|
||||||
lang, faculty, document, citations, assignment,
|
lang, faculty, document, citations, assignment,
|
||||||
title, author, author_pronouns, supervisor, consultant,
|
title, author, author_pronouns, supervisor, consultant,
|
||||||
programme, branch, year_of_study, abstract, acknowledgement, keywords, content
|
programme, specialization, year_of_study, abstract, acknowledgement, keywords, content
|
||||||
);
|
);
|
||||||
|
|
||||||
import "prototyping.typ": assert_release_ready
|
import "prototyping.typ": assert_release_ready
|
||||||
|
313
theses/bp.typ
Normal file
313
theses/bp.typ
Normal file
@@ -0,0 +1,313 @@
|
|||||||
|
#import "../template/template.typ": *
|
||||||
|
|
||||||
|
#show: tultemplate2.with(
|
||||||
|
style: "classic",
|
||||||
|
faculty: "fm",
|
||||||
|
lang: "cs",
|
||||||
|
document: "bp",
|
||||||
|
title: (
|
||||||
|
cs: "Ukázka dokumentu typu Bakalářská práce pro FM TUL v češtině",
|
||||||
|
en: "Example document for a Bachelor's thesis for FM TUL in Czech",
|
||||||
|
),
|
||||||
|
author: "Matěj Žucha",
|
||||||
|
author_pronouns: "masculine",
|
||||||
|
supervisor: "Ondřej Mekina",
|
||||||
|
consultant: "Michal Procházka (nepovinný údaj)",
|
||||||
|
programme: (cs: "Můj krásný studijní program"),
|
||||||
|
specialization: (cs: "Moje krásná studijní specializace"),
|
||||||
|
abstract: (
|
||||||
|
cs: [
|
||||||
|
Tento dokument slouží jako praktická ukázka všech důležitcýh funkcí šablony _tultemplate2_,
|
||||||
|
s názornými příklady použítí a jejich podrobným popisem.
|
||||||
|
],
|
||||||
|
en: [
|
||||||
|
This document serves as a practical demonstration of all the important features of the
|
||||||
|
_tultemplate2_ template, with useful examples and their respective descriptions.
|
||||||
|
],
|
||||||
|
),
|
||||||
|
keywords: (
|
||||||
|
cs: ("Ukázka", "Klíčových", "Slov", "Česky"),
|
||||||
|
en: ("Example", "Keywords", "In", "English"),
|
||||||
|
),
|
||||||
|
acknowledgement: (cs: "Lorem ipsum dolor sit amet."),
|
||||||
|
citations: "citations.bib",
|
||||||
|
)
|
||||||
|
|
||||||
|
= Co najdete v této šabloně
|
||||||
|
|
||||||
|
Tato šablona má sloužit jako ukázková bakalářská práce napsaná pomocí jazyka *Typst* a šablony
|
||||||
|
*tultemplate2*. Může posloužit jako jednoduchý základ i pro vaši práci, stačí se naučit používat
|
||||||
|
pár užitečných funkcí, jako např. vkládání obrázků, tabulek, citací nebo odkazů.
|
||||||
|
|
||||||
|
Na rozdíl od souboru _example.typ_, který je dostupný ke stažení na stránkách projektu, obsahuje
|
||||||
|
tento dokument jenom to nejpotřebnější ze znalostí, co postačí k úspěšnému napsání práce. Jen pro
|
||||||
|
úplnost je zde ve zkratce něco málo o jazyce typst a motivaci k tvorbě této šablony:
|
||||||
|
|
||||||
|
Typst je profesionální sázecí nástroj podobný markdownu, LaTeXu/TeXu, groffu, atd.
|
||||||
|
|
||||||
|
Typst je moderní obdobou starších nástrojů, které postrádají spoustu důležitých funkcí, bez kterých
|
||||||
|
se v dnešní době prakticky nedá fungovat. Uživatel často musí importovat nepřeberné množství
|
||||||
|
balíčků, které poskytují (podle mě) naprosto základní funkcionalitu - jako například správná podpora
|
||||||
|
UTF-8 znaků, formátování prvků na základě jazykového lokálu, apod.
|
||||||
|
|
||||||
|
= Začínáme se šablonou
|
||||||
|
|
||||||
|
Tuto šablonu jste si pravděpodobně stáhli z generátoru na webu www.tulsablona.cz a vložili ji do Typst
|
||||||
|
online editoru. Tím pádem vidíte kromě zdrojového kódu také výsledný PDF soubor. Jak už asi víte, hlavní
|
||||||
|
rozdíl mezi tradičními textovými procesory jako Microsoft Word nebo LibreOffice Writer a mezi sázecími
|
||||||
|
programy jako LaTeX nebo Typst je právě způsob, kterým se upravuje vzhled a obsah dokumentu.
|
||||||
|
|
||||||
|
Zatímco ve Wordu jsou uživatelé zvyklí, že pomocí tlačítek a klávesových zkratek mění dokument napřímo,
|
||||||
|
Typst (a i LaTeX) používají tzv. zdrojový soubor, který není ničím jiným než obyčejným textovým souborem,
|
||||||
|
a následně na vyžádání umí tento zdrojový soubor zkompilovat tj. proměnit na výsledný dokument, např. ve formátu PDF.
|
||||||
|
|
||||||
|
Proto zde najdete popis všech důležitých funkcí nikoliv jako galerii obrázků toho, na která tlačítka se má
|
||||||
|
klikat, nýbrž jako ukázka a návod všech speciálních sekvencí textu, které Typst podporuje a které šablona vyhodnocuje jinak než obsah zprávy.
|
||||||
|
|
||||||
|
== Odstavce
|
||||||
|
|
||||||
|
Jak jsou někteří z vás možná zvyklí z Markdownu, odstavce, nadpisy a vlastně pro přehlednost všechny
|
||||||
|
logicky oddělené bloky se oddělují prázným řádkem. Toho jste si jistě mohli při prohlížení tohoto souboru
|
||||||
|
všimnout. Můžete si vyzkoušet, co se stane, když
|
||||||
|
použijete jenom ukončení řádku enterem,
|
||||||
|
|
||||||
|
nebo když použijete zmíněný prázdný řádek,
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
anebo co se stane při použití dvou a více prázdných řádků. (spoiler: 1 a více prázdných řádků mají identické
|
||||||
|
chování, pouze ukončení řádku je interpretováno stejně jako např. mezerník)
|
||||||
|
|
||||||
|
Uživatel má tím pádem svobodu v tom, jestli ve zdrojovém souboru používá dlouhé řádky plné textu,
|
||||||
|
nebo
|
||||||
|
má
|
||||||
|
raději
|
||||||
|
přehlednější
|
||||||
|
formátování
|
||||||
|
a sám si obsah dělí na řádky, protože ve výsledném PDF souboru se stejně spojí do jednoho celistvého odstavce.
|
||||||
|
Musí akorát ručně dbát na to, aby odstavce nebyly příliš krátké, ani příliš dlouhé.
|
||||||
|
|
||||||
|
S souvislosti s odstavci bych ještě zmínil, že Typst se za vás stará také o zarovnávání písma a slov do bloků
|
||||||
|
a dělení slov mezi řádky. Chováním odpovídá pravidlům českého pravopisu a typografie, takže se o to nemusíte vůbec starat.
|
||||||
|
|
||||||
|
== Nadpisy
|
||||||
|
|
||||||
|
První důležitá funkce kromě psaní samotného textu, k čemuž není zapotřebí žádná speciální syntax, jsou nadpisy.
|
||||||
|
Stejně jako v jiných programech, i Typst podporuje nadpisy více úrovní. Pro nadpis první úrovně se používá znaménko
|
||||||
|
rovná se a mezera na začátku řádku, čili ve zdrojovém souboru Typstu je používán takto:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
= Můj nadpis první úrovně
|
||||||
|
```
|
||||||
|
|
||||||
|
Pro nadpis druhé úrovně pak použijeme dvě rovná se, pro nadpis třetí úrovně tři rovná se.
|
||||||
|
Šablona *tultemplate2* Vám ovšem bohužel nedovolí nadpis čtvrté a další úrovně, protože by takový
|
||||||
|
nadpis porušoval směrnice TUL o formátování dokumentů. Ale nemusíte se bát. Pokud takový nadpis
|
||||||
|
uděláte -- šablona vyhodí chybu, aby vás na to upozornila.
|
||||||
|
|
||||||
|
```typst
|
||||||
|
= Nadpis
|
||||||
|
== Podnadpis
|
||||||
|
=== Podpodnadpis
|
||||||
|
|
||||||
|
A pak obsah
|
||||||
|
```
|
||||||
|
|
||||||
|
== Číslování kapitol
|
||||||
|
|
||||||
|
Asi jste si všimli, že každý nadpis začíná číslem dané kapitoly. Toto číslování provádí Typst automaticky, promítne se následně i v sekci Obsah na začátku souboru, nemusíte se tak opět o nic starat.
|
||||||
|
|
||||||
|
= Používání funkcí
|
||||||
|
|
||||||
|
Používání většiny funkcionalit Typstu je prováděno pomocí tzv. volání funkce. Je to velmi podobné předchozím ukázkám,
|
||||||
|
akorát místo toho, aby se text obalil pouze jedním symbolem či podobnou jednoduchou značkou, obalíme text jménem dané funkce. Syntaxe vypadá nějak takto:
|
||||||
|
```typst
|
||||||
|
#Název_funkce[samotný text nebo jiné parametry]
|
||||||
|
```
|
||||||
|
Pokud v editoru napíšete symbol hashtagu, začne vám automaticky našeptávat všechny možné funkce a jejich popisy. Přejdeme rovnou k dalším praktickým příkladům.
|
||||||
|
|
||||||
|
== Zvýrazňování textu
|
||||||
|
|
||||||
|
Syntaxe základního zvýraznění je velmi podobná například Markdownu. Stačí použít následující symboly:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
*tučně*
|
||||||
|
_kurzívou_
|
||||||
|
```
|
||||||
|
|
||||||
|
Další stylování lze dělat právě přes funkce, viz třeba:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#underline[podtrženo]
|
||||||
|
#strike[přeškrtnuto]
|
||||||
|
#highlight[zvýrazněno]
|
||||||
|
```
|
||||||
|
|
||||||
|
Pro úplnost a ukázku je zde přímo v textu *tučný text*, _text kurzívou_, #underline[podtržený text], #strike[přeškrtnutý text] a #highlight[text zvýrazněný podle barvy příslušící vaší fakultě].
|
||||||
|
|
||||||
|
== Odkazy<links>
|
||||||
|
|
||||||
|
Odkazy je možné dělat na URL/URI zdroje, e-maily, telefony, atd...
|
||||||
|
Odkázat URL (URI) je možné bez zavolání funkce, odkaz stačí prostě a jednodušše napsat:
|
||||||
|
https://git.zumepro.cz/tul/tultemplate2
|
||||||
|
|
||||||
|
```typst
|
||||||
|
https://git.zumepro.cz/tul/tultemplate2
|
||||||
|
```
|
||||||
|
|
||||||
|
Tohle interně volá funkci `link`.
|
||||||
|
|
||||||
|
Pokud odkazujeme na méně časté věci (jako e-maily), můžeme použít funkci `link` přímo.
|
||||||
|
```typst
|
||||||
|
#link("mailto:ondrej@mekina.cz")
|
||||||
|
```
|
||||||
|
|
||||||
|
Dalši předpony (URI schémata) můžete najít třeba na Wikipedii
|
||||||
|
https://en.wikipedia.org/wiki/List_of_URI_schemes.
|
||||||
|
|
||||||
|
== Obrázky
|
||||||
|
|
||||||
|
Obrázky je možné vkládat samotné, nebo i s popiskem.
|
||||||
|
Obrázek se vloží pomocí funkce `image`.
|
||||||
|
|
||||||
|
Přidání popisku a zároveň zalistování obrázku v indexu (aby se na ně třeba dalo odkazovat) lze
|
||||||
|
udělat pomocí funkce `figure`.
|
||||||
|
|
||||||
|
#block([
|
||||||
|
```typst
|
||||||
|
#figure(
|
||||||
|
image("mujobrazek.jpg"),
|
||||||
|
caption: [
|
||||||
|
*Krásný* obrázek, který vypadá jako obrázek.
|
||||||
|
]
|
||||||
|
)
|
||||||
|
```
|
||||||
|
], breakable: false)
|
||||||
|
|
||||||
|
Tady je praktická ukázka jednoduchého vložení obrázku s popiskem:
|
||||||
|
|
||||||
|
#figure(image("../template/assets/tul_logo.svg", width: 25%), caption: [
|
||||||
|
Logo *TUL*
|
||||||
|
])
|
||||||
|
|
||||||
|
První parametr funkce je zobrazovaný obsah, v našem případě zmíněný `image`. K němu můžeme psát různé parametry, v příkladu máme třeba nastavení šířky obrázku v procentech. Jako poslední je parametr `caption`, s jehož pomocí můžeme nastavit popisek obrázku/figury.
|
||||||
|
|
||||||
|
Obrázky se zobrazí na začátku dokumentu v seznamu (pokud to daný typ dokumentu vyžaduje). I toto za vás Typst dělá automaticky, vám tak stačí do textu přidávat obrázky, jak se to hodí, a všechny se poté korektně zobrazí v Seznamu obrázků s odkazem i správně uvedenou stránkou, na které se obrázek nachází. Obrázky jsou také automaticky číslovány podle předepsaného způsobu, podobně jako kapitoly.
|
||||||
|
|
||||||
|
== Tabulky
|
||||||
|
|
||||||
|
Tabulky lze vytvářet takto:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#figure(table(
|
||||||
|
columns: 3,
|
||||||
|
table.header([], [*Sloupec 1*], [*Sloupec 2*]),
|
||||||
|
[*Řádek 1*], [a], [b],
|
||||||
|
[*Řádek 2*], [c], [d],
|
||||||
|
), caption: "Moje krásná tabulka")
|
||||||
|
```
|
||||||
|
|
||||||
|
Parametr `columns` udává počet sloupců tabulky. Poté následuje libovolný počet buněk tabulky, pro lepší přehlednost jsou v příkladu jednotlivé řádky oddělené. Nakonec je zde opět parametr `caption` sloužící k zadání popisku tabulky.
|
||||||
|
|
||||||
|
#highlight[Hlavičku tabulky (první řádek) je dobré zabalit do funkce header (viz. výše)], to je
|
||||||
|
kvůli tomu, že Typst do vygenerovaného PDF souboru poté přidá metadata (například pro osoby se
|
||||||
|
zrakovým postižením).
|
||||||
|
|
||||||
|
#figure(table(
|
||||||
|
columns: 3,
|
||||||
|
table.header([], [*Sloupec 1*], [*Sloupec 2*]),
|
||||||
|
[*Řádek 1*], [a], [b],
|
||||||
|
[*Řádek 2*], [c], [d],
|
||||||
|
), caption: "Moje krásná tabulka")
|
||||||
|
|
||||||
|
Tabulky se zobrazí na začátku dokumentu v seznamu (pokud to daný typ dokumentu vyžaduje). Jak už jste asi pochopili, i toto provede šablona automaticky.
|
||||||
|
|
||||||
|
== Citace
|
||||||
|
|
||||||
|
Šablona podporuje správu citací pomocí standardního BibTeX @bibtex souboru, stejně jako
|
||||||
|
například LaTeX. Generování citací v BibTeX zápisu umí téměř každá stránka nebo program, které mají pro citace podporu.
|
||||||
|
Kód takovéto citace ve vhodném formátu stačí přidat do souboru _citations.bib_, poté je možné se
|
||||||
|
na ně odkazovat pomocí `@jmeno_citace`, nebo `#cite(<jmeno_citace>)`. Můžu se tak třeba odkázat na
|
||||||
|
citaci Typstu #cite(<typst>).
|
||||||
|
|
||||||
|
Formát souboru _citations.bib_ je naprosto stejný jako pro LaTeX. Tyto citace lze přímo vložit
|
||||||
|
třeba z webu https://www.citace.com ve formátu BibTeX -- Typst tento formát také umí přečíst.
|
||||||
|
Můžete se do souboru s příponou .bib podívat, zjistíte, že je to opravdu jen obyčejný textový soubor se specifickou strukturou.
|
||||||
|
V přiloženém ukázkovém souboru už nějaké citace jsou - např. již použitá citace se jménem `typst`.
|
||||||
|
|
||||||
|
Soubor, ze kterého se načtou citace lze změnit pomocí argumentu šablony (tj. struktura na začátku souboru):
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#show: tultemplate2.with(
|
||||||
|
...
|
||||||
|
citations: "jinysoubor.bib",
|
||||||
|
...
|
||||||
|
)
|
||||||
|
```
|
||||||
|
|
||||||
|
== Vnitřní odkazy a kotvy<ukazka_odkazu>
|
||||||
|
|
||||||
|
Trochu navážeme na Odkazy (@links).
|
||||||
|
|
||||||
|
Můžete dělat i vnitřní odkazy třeba na kapitoly, stránky nebo obrázky s popiskem (zabalené ve
|
||||||
|
`figure`).
|
||||||
|
|
||||||
|
```typst
|
||||||
|
= Dobrá kapitola<dobra_kapitola>
|
||||||
|
|
||||||
|
Podívejme se na Dobrou kapitolu (@dobra_kapitola).
|
||||||
|
```
|
||||||
|
|
||||||
|
Takhle vypadá kotva:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
<nazev_kotvy>
|
||||||
|
```
|
||||||
|
|
||||||
|
Kotvu dáte někam do souboru a můžete na ní odkazovat stejně jako na citace:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
@nazev_kotvy
|
||||||
|
```
|
||||||
|
Můžeme se podívat na názornou ukázku odkazu (@ukazka_odkazu).
|
||||||
|
|
||||||
|
== Zkratky
|
||||||
|
|
||||||
|
LaTeX TUL šablona má k začátku dokumentu seznam zkratek. Proto jsme ho přidali i do této šablony.
|
||||||
|
Seznam zkratek je v této šabloně nastaven tak, aby se zobrazoval pouze pokud je v něm alespoň jedna
|
||||||
|
zkratka (přišlo nám to poměrně logické).
|
||||||
|
|
||||||
|
Zkratku #abbr("ABC", "Abeceda") vytvoříte (definujete) pomocí:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#abbr("ABC", "Abeceda")
|
||||||
|
```
|
||||||
|
|
||||||
|
Potom zkratku #abbr("ABC") už můžete použít přímo (bez opakované definice):
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#abbr("ABC")
|
||||||
|
```
|
||||||
|
|
||||||
|
Šablona zajistí následující věci:
|
||||||
|
- Zkratka se zobrazí v seznamu zkratek
|
||||||
|
- Při prvním použití zkratky vás šablona donutí zkratku definovat
|
||||||
|
- Definice zkratky bude použita právě jednou (poprvé)
|
||||||
|
|
||||||
|
Při prvním použití zkratky (při definici) bude zkratka v textu vypadat takto:
|
||||||
|
#abbr("ZK", "Zkratka").
|
||||||
|
Při dalších použití bude vypadat takto: #abbr("ZK").
|
||||||
|
|
||||||
|
#highlight[
|
||||||
|
Tedy zkratku _nepřidáváte_ přímo do seznamu zkratek, ale elegantně jí používáte přímo v textu.
|
||||||
|
]
|
||||||
|
|
||||||
|
== Přílohy
|
||||||
|
|
||||||
|
Na konec souboru (nebo klidně doprostřed či na začátek, hlavní je, že pouze jednou) je také možné dát strukturu generující přílohy. Momentálně jsou podporované čtyři typy příloh: odkaz, obsah, PDF soubor vložený na konec dokumentu a odkaz na externí soubor (například přiložený do systému s bakalářskou prací).
|
||||||
|
Jako demonstrace by měla postačit praktická ukázka, která ve zdrojovém kódu následuje hned za tímto odstavcem, a která generuje přílohy tohoto dokumentu.
|
||||||
|
|
||||||
|
#attachments(
|
||||||
|
attach_link("Zdrojový kód této šablony", "https://git.zumepro.cz/tul/tultemplate2"),
|
||||||
|
attach_content("Testovací obsah vygenerovaný Typstem", [Sem lze psát _stylovaný_ obsah.]),
|
||||||
|
)
|
312
theses/dp.typ
Normal file
312
theses/dp.typ
Normal file
@@ -0,0 +1,312 @@
|
|||||||
|
#import "../template/template.typ": *
|
||||||
|
|
||||||
|
#show: tultemplate2.with(
|
||||||
|
style: "classic",
|
||||||
|
faculty: "fm",
|
||||||
|
lang: "cs",
|
||||||
|
document: "dp",
|
||||||
|
title: (
|
||||||
|
cs: "Ukázka dokumentu typu Diplomová práce pro FM TUL v češtině",
|
||||||
|
en: "Example document for a Master's thesis for FM TUL in Czech",
|
||||||
|
),
|
||||||
|
author: "Matěj Žucha",
|
||||||
|
author_pronouns: "masculine",
|
||||||
|
supervisor: "Ondřej Mekina",
|
||||||
|
consultant: "Michal Procházka (nepovinný údaj)",
|
||||||
|
programme: (cs: "Můj krásný studijní program"),
|
||||||
|
abstract: (
|
||||||
|
cs: [
|
||||||
|
Tento dokument slouží jako praktická ukázka všech důležitcýh funkcí šablony _tultemplate2_,
|
||||||
|
s názornými příklady použítí a jejich podrobným popisem.
|
||||||
|
],
|
||||||
|
en: [
|
||||||
|
This document serves as a practical demonstration of all the important features of the
|
||||||
|
_tultemplate2_ template, with useful examples and their respective descriptions.
|
||||||
|
]
|
||||||
|
),
|
||||||
|
keywords: (
|
||||||
|
cs: ("Ukázka", "Klíčových", "Slov", "Česky"),
|
||||||
|
en: ("Example", "Keywords", "In", "English"),
|
||||||
|
),
|
||||||
|
acknowledgement: (cs: "Lorem ipsum dolor sit amet."),
|
||||||
|
citations: "citations.bib",
|
||||||
|
)
|
||||||
|
|
||||||
|
= Co najdete v této šabloně
|
||||||
|
|
||||||
|
Tato šablona má sloužit jako ukázková bakalářská práce napsaná pomocí jazyka *Typst* a šablony
|
||||||
|
*tultemplate2*. Může posloužit jako jednoduchý základ i pro vaši práci, stačí se naučit používat
|
||||||
|
pár užitečných funkcí, jako např. vkládání obrázků, tabulek, citací nebo odkazů.
|
||||||
|
|
||||||
|
Na rozdíl od souboru _example.typ_, který je dostupný ke stažení na stránkách projektu, obsahuje
|
||||||
|
tento dokument jenom to nejpotřebnější ze znalostí, co postačí k úspěšnému napsání práce. Jen pro
|
||||||
|
úplnost je zde ve zkratce něco málo o jazyce typst a motivaci k tvorbě této šablony:
|
||||||
|
|
||||||
|
Typst je profesionální sázecí nástroj podobný markdownu, LaTeXu/TeXu, groffu, atd.
|
||||||
|
|
||||||
|
Typst je moderní obdobou starších nástrojů, které postrádají spoustu důležitých funkcí, bez kterých
|
||||||
|
se v dnešní době prakticky nedá fungovat. Uživatel často musí importovat nepřeberné množství
|
||||||
|
balíčků, které poskytují (podle mě) naprosto základní funkcionalitu - jako například správná podpora
|
||||||
|
UTF-8 znaků, formátování prvků na základě jazykového lokálu, apod.
|
||||||
|
|
||||||
|
= Začínáme se šablonou
|
||||||
|
|
||||||
|
Tuto šablonu jste si pravděpodobně stáhli z generátoru na webu www.tulsablona.cz a vložili ji do Typst
|
||||||
|
online editoru. Tím pádem vidíte kromě zdrojového kódu také výsledný PDF soubor. Jak už asi víte, hlavní
|
||||||
|
rozdíl mezi tradičními textovými procesory jako Microsoft Word nebo LibreOffice Writer a mezi sázecími
|
||||||
|
programy jako LaTeX nebo Typst je právě způsob, kterým se upravuje vzhled a obsah dokumentu.
|
||||||
|
|
||||||
|
Zatímco ve Wordu jsou uživatelé zvyklí, že pomocí tlačítek a klávesových zkratek mění dokument napřímo,
|
||||||
|
Typst (a i LaTeX) používají tzv. zdrojový soubor, který není ničím jiným než obyčejným textovým souborem,
|
||||||
|
a následně na vyžádání umí tento zdrojový soubor zkompilovat tj. proměnit na výsledný dokument, např. ve formátu PDF.
|
||||||
|
|
||||||
|
Proto zde najdete popis všech důležitých funkcí nikoliv jako galerii obrázků toho, na která tlačítka se má
|
||||||
|
klikat, nýbrž jako ukázka a návod všech speciálních sekvencí textu, které Typst podporuje a které šablona vyhodnocuje jinak než obsah zprávy.
|
||||||
|
|
||||||
|
== Odstavce
|
||||||
|
|
||||||
|
Jak jsou někteří z vás možná zvyklí z Markdownu, odstavce, nadpisy a vlastně pro přehlednost všechny
|
||||||
|
logicky oddělené bloky se oddělují prázným řádkem. Toho jste si jistě mohli při prohlížení tohoto souboru
|
||||||
|
všimnout. Můžete si vyzkoušet, co se stane, když
|
||||||
|
použijete jenom ukončení řádku enterem,
|
||||||
|
|
||||||
|
nebo když použijete zmíněný prázdný řádek,
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
anebo co se stane při použití dvou a více prázdných řádků. (spoiler: 1 a více prázdných řádků mají identické
|
||||||
|
chování, pouze ukončení řádku je interpretováno stejně jako např. mezerník)
|
||||||
|
|
||||||
|
Uživatel má tím pádem svobodu v tom, jestli ve zdrojovém souboru používá dlouhé řádky plné textu,
|
||||||
|
nebo
|
||||||
|
má
|
||||||
|
raději
|
||||||
|
přehlednější
|
||||||
|
formátování
|
||||||
|
a sám si obsah dělí na řádky, protože ve výsledném PDF souboru se stejně spojí do jednoho celistvého odstavce.
|
||||||
|
Musí akorát ručně dbát na to, aby odstavce nebyly příliš krátké, ani příliš dlouhé.
|
||||||
|
|
||||||
|
S souvislosti s odstavci bych ještě zmínil, že Typst se za vás stará také o zarovnávání písma a slov do bloků
|
||||||
|
a dělení slov mezi řádky. Chováním odpovídá pravidlům českého pravopisu a typografie, takže se o to nemusíte vůbec starat.
|
||||||
|
|
||||||
|
== Nadpisy
|
||||||
|
|
||||||
|
První důležitá funkce kromě psaní samotného textu, k čemuž není zapotřebí žádná speciální syntax, jsou nadpisy.
|
||||||
|
Stejně jako v jiných programech, i Typst podporuje nadpisy více úrovní. Pro nadpis první úrovně se používá znaménko
|
||||||
|
rovná se a mezera na začátku řádku, čili ve zdrojovém souboru Typstu je používán takto:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
= Můj nadpis první úrovně
|
||||||
|
```
|
||||||
|
|
||||||
|
Pro nadpis druhé úrovně pak použijeme dvě rovná se, pro nadpis třetí úrovně tři rovná se.
|
||||||
|
Šablona *tultemplate2* Vám ovšem bohužel nedovolí nadpis čtvrté a další úrovně, protože by takový
|
||||||
|
nadpis porušoval směrnice TUL o formátování dokumentů. Ale nemusíte se bát. Pokud takový nadpis
|
||||||
|
uděláte -- šablona vyhodí chybu, aby vás na to upozornila.
|
||||||
|
|
||||||
|
```typst
|
||||||
|
= Nadpis
|
||||||
|
== Podnadpis
|
||||||
|
=== Podpodnadpis
|
||||||
|
|
||||||
|
A pak obsah
|
||||||
|
```
|
||||||
|
|
||||||
|
== Číslování kapitol
|
||||||
|
|
||||||
|
Asi jste si všimli, že každý nadpis začíná číslem dané kapitoly. Toto číslování provádí Typst automaticky, promítne se následně i v sekci Obsah na začátku souboru, nemusíte se tak opět o nic starat.
|
||||||
|
|
||||||
|
= Používání funkcí
|
||||||
|
|
||||||
|
Používání většiny funkcionalit Typstu je prováděno pomocí tzv. volání funkce. Je to velmi podobné předchozím ukázkám,
|
||||||
|
akorát místo toho, aby se text obalil pouze jedním symbolem či podobnou jednoduchou značkou, obalíme text jménem dané funkce. Syntaxe vypadá nějak takto:
|
||||||
|
```typst
|
||||||
|
#Název_funkce[samotný text nebo jiné parametry]
|
||||||
|
```
|
||||||
|
Pokud v editoru napíšete symbol hashtagu, začne vám automaticky našeptávat všechny možné funkce a jejich popisy. Přejdeme rovnou k dalším praktickým příkladům.
|
||||||
|
|
||||||
|
== Zvýrazňování textu
|
||||||
|
|
||||||
|
Syntaxe základního zvýraznění je velmi podobná například Markdownu. Stačí použít následující symboly:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
*tučně*
|
||||||
|
_kurzívou_
|
||||||
|
```
|
||||||
|
|
||||||
|
Další stylování lze dělat právě přes funkce, viz třeba:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#underline[podtrženo]
|
||||||
|
#strike[přeškrtnuto]
|
||||||
|
#highlight[zvýrazněno]
|
||||||
|
```
|
||||||
|
|
||||||
|
Pro úplnost a ukázku je zde přímo v textu *tučný text*, _text kurzívou_, #underline[podtržený text], #strike[přeškrtnutý text] a #highlight[text zvýrazněný podle barvy příslušící vaší fakultě].
|
||||||
|
|
||||||
|
== Odkazy<links>
|
||||||
|
|
||||||
|
Odkazy je možné dělat na URL/URI zdroje, e-maily, telefony, atd...
|
||||||
|
Odkázat URL (URI) je možné bez zavolání funkce, odkaz stačí prostě a jednodušše napsat:
|
||||||
|
https://git.zumepro.cz/tul/tultemplate2
|
||||||
|
|
||||||
|
```typst
|
||||||
|
https://git.zumepro.cz/tul/tultemplate2
|
||||||
|
```
|
||||||
|
|
||||||
|
Tohle interně volá funkci `link`.
|
||||||
|
|
||||||
|
Pokud odkazujeme na méně časté věci (jako e-maily), můžeme použít funkci `link` přímo.
|
||||||
|
```typst
|
||||||
|
#link("mailto:ondrej@mekina.cz")
|
||||||
|
```
|
||||||
|
|
||||||
|
Dalši předpony (URI schémata) můžete najít třeba na Wikipedii
|
||||||
|
https://en.wikipedia.org/wiki/List_of_URI_schemes.
|
||||||
|
|
||||||
|
== Obrázky
|
||||||
|
|
||||||
|
Obrázky je možné vkládat samotné, nebo i s popiskem.
|
||||||
|
Obrázek se vloží pomocí funkce `image`.
|
||||||
|
|
||||||
|
Přidání popisku a zároveň zalistování obrázku v indexu (aby se na ně třeba dalo odkazovat) lze
|
||||||
|
udělat pomocí funkce `figure`.
|
||||||
|
|
||||||
|
#block([
|
||||||
|
```typst
|
||||||
|
#figure(
|
||||||
|
image("mujobrazek.jpg"),
|
||||||
|
caption: [
|
||||||
|
*Krásný* obrázek, který vypadá jako obrázek.
|
||||||
|
]
|
||||||
|
)
|
||||||
|
```
|
||||||
|
], breakable: false)
|
||||||
|
|
||||||
|
Tady je praktická ukázka jednoduchého vložení obrázku s popiskem:
|
||||||
|
|
||||||
|
#figure(image("../template/assets/tul_logo.svg", width: 25%), caption: [
|
||||||
|
Logo *TUL*
|
||||||
|
])
|
||||||
|
|
||||||
|
První parametr funkce je zobrazovaný obsah, v našem případě zmíněný `image`. K němu můžeme psát různé parametry, v příkladu máme třeba nastavení šířky obrázku v procentech. Jako poslední je parametr `caption`, s jehož pomocí můžeme nastavit popisek obrázku/figury.
|
||||||
|
|
||||||
|
Obrázky se zobrazí na začátku dokumentu v seznamu (pokud to daný typ dokumentu vyžaduje). I toto za vás Typst dělá automaticky, vám tak stačí do textu přidávat obrázky, jak se to hodí, a všechny se poté korektně zobrazí v Seznamu obrázků s odkazem i správně uvedenou stránkou, na které se obrázek nachází. Obrázky jsou také automaticky číslovány podle předepsaného způsobu, podobně jako kapitoly.
|
||||||
|
|
||||||
|
== Tabulky
|
||||||
|
|
||||||
|
Tabulky lze vytvářet takto:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#figure(table(
|
||||||
|
columns: 3,
|
||||||
|
table.header([], [*Sloupec 1*], [*Sloupec 2*]),
|
||||||
|
[*Řádek 1*], [a], [b],
|
||||||
|
[*Řádek 2*], [c], [d],
|
||||||
|
), caption: "Moje krásná tabulka")
|
||||||
|
```
|
||||||
|
|
||||||
|
Parametr `columns` udává počet sloupců tabulky. Poté následuje libovolný počet buněk tabulky, pro lepší přehlednost jsou v příkladu jednotlivé řádky oddělené. Nakonec je zde opět parametr `caption` sloužící k zadání popisku tabulky.
|
||||||
|
|
||||||
|
#highlight[Hlavičku tabulky (první řádek) je dobré zabalit do funkce header (viz. výše)], to je
|
||||||
|
kvůli tomu, že Typst do vygenerovaného PDF souboru poté přidá metadata (například pro osoby se
|
||||||
|
zrakovým postižením).
|
||||||
|
|
||||||
|
#figure(table(
|
||||||
|
columns: 3,
|
||||||
|
table.header([], [*Sloupec 1*], [*Sloupec 2*]),
|
||||||
|
[*Řádek 1*], [a], [b],
|
||||||
|
[*Řádek 2*], [c], [d],
|
||||||
|
), caption: "Moje krásná tabulka")
|
||||||
|
|
||||||
|
Tabulky se zobrazí na začátku dokumentu v seznamu (pokud to daný typ dokumentu vyžaduje). Jak už jste asi pochopili, i toto provede šablona automaticky.
|
||||||
|
|
||||||
|
== Citace
|
||||||
|
|
||||||
|
Šablona podporuje správu citací pomocí standardního BibTeX @bibtex souboru, stejně jako
|
||||||
|
například LaTeX. Generování citací v BibTeX zápisu umí téměř každá stránka nebo program, které mají pro citace podporu.
|
||||||
|
Kód takovéto citace ve vhodném formátu stačí přidat do souboru _citations.bib_, poté je možné se
|
||||||
|
na ně odkazovat pomocí `@jmeno_citace`, nebo `#cite(<jmeno_citace>)`. Můžu se tak třeba odkázat na
|
||||||
|
citaci Typstu #cite(<typst>).
|
||||||
|
|
||||||
|
Formát souboru _citations.bib_ je naprosto stejný jako pro LaTeX. Tyto citace lze přímo vložit
|
||||||
|
třeba z webu https://www.citace.com ve formátu BibTeX -- Typst tento formát také umí přečíst.
|
||||||
|
Můžete se do souboru s příponou .bib podívat, zjistíte, že je to opravdu jen obyčejný textový soubor se specifickou strukturou.
|
||||||
|
V přiloženém ukázkovém souboru už nějaké citace jsou - např. již použitá citace se jménem `typst`.
|
||||||
|
|
||||||
|
Soubor, ze kterého se načtou citace lze změnit pomocí argumentu šablony (tj. struktura na začátku souboru):
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#show: tultemplate2.with(
|
||||||
|
...
|
||||||
|
citations: "jinysoubor.bib",
|
||||||
|
...
|
||||||
|
)
|
||||||
|
```
|
||||||
|
|
||||||
|
== Vnitřní odkazy a kotvy<ukazka_odkazu>
|
||||||
|
|
||||||
|
Trochu navážeme na Odkazy (@links).
|
||||||
|
|
||||||
|
Můžete dělat i vnitřní odkazy třeba na kapitoly, stránky nebo obrázky s popiskem (zabalené ve
|
||||||
|
`figure`).
|
||||||
|
|
||||||
|
```typst
|
||||||
|
= Dobrá kapitola<dobra_kapitola>
|
||||||
|
|
||||||
|
Podívejme se na Dobrou kapitolu (@dobra_kapitola).
|
||||||
|
```
|
||||||
|
|
||||||
|
Takhle vypadá kotva:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
<nazev_kotvy>
|
||||||
|
```
|
||||||
|
|
||||||
|
Kotvu dáte někam do souboru a můžete na ní odkazovat stejně jako na citace:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
@nazev_kotvy
|
||||||
|
```
|
||||||
|
Můžeme se podívat na názornou ukázku odkazu (@ukazka_odkazu).
|
||||||
|
|
||||||
|
== Zkratky
|
||||||
|
|
||||||
|
LaTeX TUL šablona má k začátku dokumentu seznam zkratek. Proto jsme ho přidali i do této šablony.
|
||||||
|
Seznam zkratek je v této šabloně nastaven tak, aby se zobrazoval pouze pokud je v něm alespoň jedna
|
||||||
|
zkratka (přišlo nám to poměrně logické).
|
||||||
|
|
||||||
|
Zkratku #abbr("ABC", "Abeceda") vytvoříte (definujete) pomocí:
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#abbr("ABC", "Abeceda")
|
||||||
|
```
|
||||||
|
|
||||||
|
Potom zkratku #abbr("ABC") už můžete použít přímo (bez opakované definice):
|
||||||
|
|
||||||
|
```typst
|
||||||
|
#abbr("ABC")
|
||||||
|
```
|
||||||
|
|
||||||
|
Šablona zajistí následující věci:
|
||||||
|
- Zkratka se zobrazí v seznamu zkratek
|
||||||
|
- Při prvním použití zkratky vás šablona donutí zkratku definovat
|
||||||
|
- Definice zkratky bude použita právě jednou (poprvé)
|
||||||
|
|
||||||
|
Při prvním použití zkratky (při definici) bude zkratka v textu vypadat takto:
|
||||||
|
#abbr("ZK", "Zkratka").
|
||||||
|
Při dalších použití bude vypadat takto: #abbr("ZK").
|
||||||
|
|
||||||
|
#highlight[
|
||||||
|
Tedy zkratku _nepřidáváte_ přímo do seznamu zkratek, ale elegantně jí používáte přímo v textu.
|
||||||
|
]
|
||||||
|
|
||||||
|
== Přílohy
|
||||||
|
|
||||||
|
Na konec souboru (nebo klidně doprostřed či na začátek, hlavní je, že pouze jednou) je také možné dát strukturu generující přílohy. Momentálně jsou podporované čtyři typy příloh: odkaz, obsah, PDF soubor vložený na konec dokumentu a odkaz na externí soubor (například přiložený do systému s diplomovou prací).
|
||||||
|
Jako demonstrace by měla postačit praktická ukázka, která ve zdrojovém kódu následuje hned za tímto odstavcem, a která generuje přílohy tohoto dokumentu.
|
||||||
|
|
||||||
|
#attachments(
|
||||||
|
attach_link("Zdrojový kód této šablony", "https://git.zumepro.cz/tul/tultemplate2"),
|
||||||
|
attach_content("Testovací obsah vygenerovaný Typstem", [Sem lze psát _stylovaný_ obsah.]),
|
||||||
|
)
|
Reference in New Issue
Block a user