From 39eb43bb54e0cd8f6b93a91a24fd073e16eedc15 Mon Sep 17 00:00:00 2001 From: L3D Date: Mon, 24 May 2021 02:12:37 +0200 Subject: [PATCH 01/78] updating gitignore --- .gitignore | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 031b8d0..4824d71 100644 --- a/.gitignore +++ b/.gitignore @@ -14,7 +14,11 @@ tags # lektor .cache/ - +.content/ +.models/ +.flowblocks/ +temp/ + # ---> Windows # Windows thumbnail cache files Thumbs.db -- 2.39.5 From 282a5aeb3976c4b43a8defad930604621218d38e Mon Sep 17 00:00:00 2001 From: L3D Date: Mon, 24 May 2021 02:22:11 +0200 Subject: [PATCH 02/78] clean old stuff --- assets/finanzen/.htaccess | 4 ---- 1 file changed, 4 deletions(-) delete mode 100644 assets/finanzen/.htaccess diff --git a/assets/finanzen/.htaccess b/assets/finanzen/.htaccess deleted file mode 100644 index d9e6c9d..0000000 --- a/assets/finanzen/.htaccess +++ /dev/null @@ -1,4 +0,0 @@ -AuthType Basic -AuthName "Chaos Intern" -AuthUserFile /var/www/clients/client8/web4/private/.htpasswd -Require valid-user -- 2.39.5 From 2a648f89d72428533115235aae6438190c270e91 Mon Sep 17 00:00:00 2001 From: L3D Date: Thu, 24 Jun 2021 23:44:12 +0200 Subject: [PATCH 03/78] redesigning waffle website --- .gitignore | 5 +- assets/css/font-awesome.min.css | 1 - assets/css/fonts.css | 92 + assets/css/images/arrow.svg | 5 - assets/css/images/ie/banner-overlay.png | 3 - assets/css/images/layers-2x.png | 3 - assets/css/images/layers.png | 3 - assets/css/images/marker-icon-2x.png | 3 - assets/css/images/marker-icon.png | 3 - assets/css/images/marker-shadow.png | 3 - assets/css/leaflet.css | 635 -- assets/css/lightgallery.css | 985 --- assets/css/reset.css | 45 + assets/css/style.css | 1707 ++++ assets/css/xml.css | 122 + .../lato-v17-latin/lato-v17-latin-300.eot | 3 + .../lato-v17-latin/lato-v17-latin-300.svg | 435 + .../lato-v17-latin/lato-v17-latin-300.ttf | 3 + .../lato-v17-latin/lato-v17-latin-300.woff | 3 + .../lato-v17-latin/lato-v17-latin-300.woff2 | 3 + .../lato-v17-latin-300italic.eot | 3 + .../lato-v17-latin-300italic.svg | 443 + .../lato-v17-latin-300italic.ttf | 3 + .../lato-v17-latin-300italic.woff | 3 + .../lato-v17-latin-300italic.woff2 | 3 + .../lato-v17-latin/lato-v17-latin-700.eot | 3 + .../lato-v17-latin/lato-v17-latin-700.svg | 438 + .../lato-v17-latin/lato-v17-latin-700.ttf | 3 + .../lato-v17-latin/lato-v17-latin-700.woff | 3 + .../lato-v17-latin/lato-v17-latin-700.woff2 | 3 + .../lato-v17-latin/lato-v17-latin-900.eot | 3 + .../lato-v17-latin/lato-v17-latin-900.svg | 439 + .../lato-v17-latin/lato-v17-latin-900.ttf | 3 + .../lato-v17-latin/lato-v17-latin-900.woff | 3 + .../lato-v17-latin/lato-v17-latin-900.woff2 | 3 + .../lato-v17-latin/lato-v17-latin-italic.eot | 3 + .../lato-v17-latin/lato-v17-latin-italic.svg | 450 + .../lato-v17-latin/lato-v17-latin-italic.ttf | 3 + .../lato-v17-latin/lato-v17-latin-italic.woff | 3 + .../lato-v17-latin-italic.woff2 | 3 + .../lato-v17-latin/lato-v17-latin-regular.eot | 3 + .../lato-v17-latin/lato-v17-latin-regular.svg | 435 + .../lato-v17-latin/lato-v17-latin-regular.ttf | 3 + .../lato-v17-latin-regular.woff | 3 + .../lato-v17-latin-regular.woff2 | 3 + assets/fonts/lg.eot | 3 - assets/fonts/lg.svg | 47 - assets/fonts/lg.ttf | 3 - assets/fonts/lg.woff | 3 - .../noto-serif-v9-latin-700.eot | 3 + .../noto-serif-v9-latin-700.svg | 492 ++ .../noto-serif-v9-latin-700.ttf | 3 + .../noto-serif-v9-latin-700.woff | 3 + .../noto-serif-v9-latin-700.woff2 | 3 + .../noto-serif-v9-latin-italic.eot | 3 + .../noto-serif-v9-latin-italic.svg | 386 + .../noto-serif-v9-latin-italic.ttf | 3 + .../noto-serif-v9-latin-italic.woff | 3 + .../noto-serif-v9-latin-italic.woff2 | 3 + .../noto-serif-v9-latin-regular.eot | 3 + .../noto-serif-v9-latin-regular.svg | 489 ++ .../noto-serif-v9-latin-regular.ttf | 3 + .../noto-serif-v9-latin-regular.woff | 3 + .../noto-serif-v9-latin-regular.woff2 | 3 + assets/fonts/roboto-italic_300.ttf | 3 - assets/fonts/roboto-italic_400.ttf | 3 - assets/fonts/roboto-italic_500.ttf | 3 - assets/fonts/roboto.css | 37 - assets/fonts/roboto_300.ttf | 3 - assets/fonts/roboto_400.ttf | 3 - assets/fonts/roboto_500.ttf | 3 - assets/images/background_waffle.svg | 1101 +++ assets/images/footer_triangles.svg | 44 + assets/images/header_bottom_triangles.svg | 51 + assets/images/header_top_triangles.svg | 25 + assets/images/icons/manifest.json | 11 + assets/images/icons/site.webmanifest | 4 +- assets/images/icons/social/feed.svg | 3 + assets/images/icons/social/gitea.svg | 20 + assets/images/icons/social/github.svg | 3 + assets/images/icons/social/hackint.svg | 9 + assets/images/icons/social/mastodon.svg | 3 + assets/images/icons/social/podcast.svg | 7 + assets/images/icons/social/reddit.svg | 3 + assets/images/icons/social/telegram.svg | 1 + assets/images/icons/social/twitter.svg | 13 + assets/images/photos/c3woc_croissant_01.jpg | 3 + .../{waffel.jpeg => photos/waffel_.jpg} | 0 assets/js/jquery.min.js | 2 - assets/js/jquery.mousewheel.min.js | 8 - assets/js/jquery.scrollex.min.js | 2 - assets/js/jquery.scrolly.min.js | 2 - assets/js/leaflet.js | 5 - assets/js/lightgallery-all.min.js | 5 - assets/js/main.js | 152 - assets/js/nav_toggle.js | 8 + assets/js/openstreetmap.js | 95 - assets/js/picturefill.min.js | 4 - assets/js/skel.min.js | 2 - assets/js/util.js | 587 -- assets/js/webcomponents.js | 7209 ----------------- assets/js/webcomponents.min.js | 14 - assets/scss/ie9.scss | 54 - assets/scss/libs/_functions.scss | 34 - assets/scss/libs/_mixins.scss | 377 - assets/scss/libs/_skel.scss | 548 -- assets/scss/libs/_vars.scss | 56 - assets/scss/main.scss | 1800 +++- assets/scss/parts/_banner.scss | 127 - assets/scss/parts/_basic.scss | 218 - assets/scss/parts/_box.scss | 20 - assets/scss/parts/_button.scss | 152 - assets/scss/parts/_col.scss | 43 - assets/scss/parts/_dropotron.scss | 66 - assets/scss/parts/_footer.scss | 69 - assets/scss/parts/_form.scss | 182 - assets/scss/parts/_goto-next.scss | 37 - assets/scss/parts/_header.scss | 250 - assets/scss/parts/_icon.scss | 46 - assets/scss/parts/_image.scss | 71 - assets/scss/parts/_list.scss | 161 - assets/scss/parts/_loader.scss | 134 - assets/scss/parts/_project.scss | 12 - assets/scss/parts/_section-article.scss | 79 - assets/scss/parts/_spotlight.scss | 224 - assets/scss/parts/_startpage.scss | 7 - assets/scss/parts/_table.scss | 101 - assets/scss/parts/_wrapper.scss | 116 - assets/scss/parts/_youtube.scss | 51 - assets/webfonts/fa-brands-400.eot | 3 - assets/webfonts/fa-brands-400.svg | 3300 -------- assets/webfonts/fa-brands-400.ttf | 3 - assets/webfonts/fa-brands-400.woff | 3 - assets/webfonts/fa-brands-400.woff2 | 3 - assets/webfonts/fa-regular-400.eot | 3 - assets/webfonts/fa-regular-400.svg | 803 -- assets/webfonts/fa-regular-400.ttf | 3 - assets/webfonts/fa-regular-400.woff | 3 - assets/webfonts/fa-regular-400.woff2 | 3 - assets/webfonts/fa-solid-900.eot | 3 - assets/webfonts/fa-solid-900.svg | 4520 ----------- assets/webfonts/fa-solid-900.ttf | 3 - assets/webfonts/fa-solid-900.woff | 3 - assets/webfonts/fa-solid-900.woff2 | 3 - assets/youtube-embed.html | 121 - c3woc.lektorproject | 8 +- configs/scss.ini | 2 + content/blog/35c3/contents+en.lr | 101 - content/blog/35c3/contents.lr | 101 - content/blog/35c3/waffel_act.jpg | 3 - content/blog/35c3/waffel_beauty.jpg | 3 - content/blog/35c3/waffel_delivery.jpg | 3 - content/blog/35c3/waffel_doener.jpg | 3 - content/blog/35c3/waffel_loc.jpg | 3 - content/blog/35c3/waffel_love.jpg | 3 - content/blog/35c3/waffel_njom.jpg | 3 - content/blog/35c3/waffel_shift.jpg | 3 - content/blog/35c3/waffel_stamp.jpg | 3 - content/blog/35c3/waffel_stempel.jpg | 3 - content/blog/35c3/waffel_sticker.jpg | 3 - content/blog/35c3/waffel_tschunk.jpg | 3 - content/blog/35c3/waffel_tschunk_action.jpg | 3 - content/blog/35c3/waffel_tschunk_raw.jpg | 3 - content/blog/35c3/waffel_weg.jpg | 3 - content/blog/36c3-helfer/contents+en.lr | 37 - content/blog/36c3-helfer/contents.lr | 37 - content/blog/36c3-konzept/contents+en.lr | 41 - content/blog/36c3-konzept/contents.lr | 41 - content/blog/binary-waffles/binary.png | 3 - content/blog/binary-waffles/contents+en.lr | 43 - content/blog/binary-waffles/contents.lr | 44 - content/blog/camp-18/ambiente.jpg | 3 - content/blog/camp-18/contents+en.lr | 44 - content/blog/camp-18/contents.lr | 44 - content/blog/camp-18/garten.jpg | 3 - content/blog/camp-18/waffel-profi.jpg | 3 - content/blog/camp-18/waffel-standort.jpg | 3 - content/blog/cccamp19/contents+en.lr | 40 - content/blog/cccamp19/contents.lr | 40 - content/blog/cep19/birthdaykid.JPG | 3 - content/blog/cep19/cep19.jpg | 3 - content/blog/cep19/cep_19.jpg | 3 - content/blog/cep19/cep__19.jpg | 3 - content/blog/cep19/contents+en.lr | 30 - content/blog/cep19/contents.lr | 30 - content/blog/cep19/index.jpg | 3 - content/blog/cep19/mampf.JPG | 3 - content/blog/cep19/mozart.JPG | 3 - content/blog/cep19/music.JPG | 3 - content/blog/cep19/schweif.JPG | 3 - content/blog/cep19/star.JPG | 3 - content/blog/cep19/teig.JPG | 3 - .../chaospott-macht-waffeln/chaospott.png | 3 - .../chaospott-macht-waffeln/contents+en.lr | 42 - .../blog/chaospott-macht-waffeln/contents.lr | 42 - content/blog/contents+en.lr | 7 - content/blog/contents.lr | 9 - content/blog/cosin-2018/contents.lr | 37 - content/blog/cosin-2018/food.jpg | 3 - content/blog/cosin-2018/njom.jpg | 3 - content/blog/cosin-2018/ofen.jpg | 3 - content/blog/cosin-2018/pizza.jpg | 3 - content/blog/cosin-2018/pizza_klein.jpg | 3 - content/blog/cosin-2018/waffeln.jpg | 3 - content/blog/ecreating-waffles/contents+en.lr | 31 - content/blog/ecreating-waffles/contents.lr | 31 - content/blog/eh18/contents+en.lr | 33 - content/blog/eh18/contents.lr | 33 - content/blog/eh18/eh18-pxl.jpg | 3 - content/blog/eh19/chaospott.png | 3 - content/blog/eh19/contents+en.lr | 62 - content/blog/eh19/contents.lr | 61 - content/blog/eh19/ruehren.jpg | 3 - content/blog/eh19/ruehren.mp4 | 3 - content/blog/eh19/stream.png | 3 - .../erster-analoger-waffelzaehler/backing.jpg | 3 - .../contents+en.lr | 41 - .../erster-analoger-waffelzaehler/contents.lr | 42 - .../overview.jpg | 3 - .../waffelzaehler.jpg | 3 - content/blog/fidm18/FidM18.jpg | 3 - content/blog/fidm18/contents+en.lr | 30 - content/blog/fidm18/contents.lr | 30 - content/blog/first-post/contents+en.lr | 19 - content/blog/first-post/contents.lr | 19 - content/blog/froscon18/contents+en.lr | 40 - content/blog/froscon18/contents.lr | 40 - content/blog/froscon18/hello.jpg | 3 - content/blog/froscon18/licht.jpg | 3 - content/blog/froscon18/overflow.jpg | 3 - content/blog/froscon18/team.jpg | 3 - content/blog/froscon18/teig.jpg | 3 - content/blog/froscon18/waffel.jpg | 3 - content/blog/geekend_nov_2018/contents+en.lr | 51 - content/blog/geekend_nov_2018/contents.lr | 51 - content/blog/geekend_nov_2018/ergebnis.jpg | 3 - content/blog/geekend_nov_2018/ruehren.jpg | 3 - content/blog/geekend_nov_2018/table.jpg | 3 - content/blog/geekend_nov_2018/teig.jpg | 3 - content/blog/geekend_nov_2018/zutaten.jpg | 3 - content/blog/gluehpn/beginning.jpg | 3 - content/blog/gluehpn/contents+en.lr | 59 - content/blog/gluehpn/contents.lr | 59 - content/blog/gluehpn/fine.jpg | 3 - content/blog/gluehpn/practise.jpg | 3 - content/blog/gluehpn/spende.jpg | 3 - content/blog/gluehpn/vegan.jpg | 3 - content/blog/gluehpn/waffle.jpg | 3 - content/blog/gluehpn/waffle_.jpg | 3 - content/blog/gpn18-tag2/2gether.jpg | 3 - content/blog/gpn18-tag2/contents.lr | 47 - content/blog/gpn18-tag2/gn8.jpg | 3 - content/blog/gpn18-tag2/kaesescheiben.jpg | 3 - content/blog/gpn18-tag2/waffelstillstand.jpg | 3 - content/blog/gpn18-tag2/zutaten.jpg | 3 - content/blog/gpn18-waffelputzen/contents.lr | 36 - .../blog/gpn18-waffelputzen/steinwolle.jpg | 3 - .../blog/gpn18-waffelputzen/waffeleisen.jpg | 3 - content/blog/gpn18/bei_der_bar.jpg | 3 - content/blog/gpn18/contents.lr | 52 - content/blog/gpn18/eroberung.jpg | 3 - content/blog/gpn18/waffelpower_1.jpg | 3 - content/blog/gpn18/waffelpower_2.jpg | 3 - content/blog/gpn18/waffelpower_3.jpg | 3 - content/blog/gwpn/contents.lr | 68 - content/blog/gwpn/vegan.jpg | 3 - content/blog/gwpn/voc.png | 3 - content/blog/gwpn/waffelpower.jpg | 3 - content/blog/gwpn/waffelstillstand.jpg | 3 - content/blog/gwpn/weiter.jpg | 3 - content/blog/gwpn/woc.png | 3 - content/blog/logo/c3woc.svg.png | 3 - content/blog/logo/contents+en.lr | 24 - content/blog/logo/contents.lr | 24 - content/blog/makerfaire-buildup/cat-01.jpg | 3 - content/blog/makerfaire-buildup/cat-02.jpg | 3 - content/blog/makerfaire-buildup/cat-03.jpg | 3 - content/blog/makerfaire-buildup/contents.lr | 29 - content/blog/makerfaire18/action01.jpg | 3 - content/blog/makerfaire18/action02.jpg | 3 - content/blog/makerfaire18/ballpit.jpg | 3 - content/blog/makerfaire18/contents.lr | 37 - .../blog/makerfaire18/waffelstillstand.jpg | 3 - content/blog/makerfaire18/winkekatze.jpg | 3 - content/blog/makerfaire18/winkekatze02.jpg | 3 - content/blog/nicht-jeder-ag-Waffeln/1.JPG | 3 - content/blog/nicht-jeder-ag-Waffeln/2.JPG | 3 - content/blog/nicht-jeder-ag-Waffeln/3.JPG | 3 - content/blog/nicht-jeder-ag-Waffeln/4.JPG | 3 - .../blog/nicht-jeder-ag-Waffeln/contents.lr | 55 - content/blog/rc3-streams/contents+en.lr | 21 - content/blog/rc3-streams/contents.lr | 21 - content/blog/rc3-workshop/contents+en.lr | 33 - content/blog/rc3-workshop/contents.lr | 34 - .../rc3-workshop/rc3-waffelworkshop-hd.png | 3 - .../blog/rc3-workshop/rc3-waffelworkshop.png | 3 - .../contents+en.lr | 70 - .../sei-teil-einer-genossenschaft/contents.lr | 72 - .../blog/state-of-the-waffle/contents+en.lr | 19 - content/blog/state-of-the-waffle/contents.lr | 19 - content/blog/tb-doenerwaffel/contents+en.lr | 45 - content/blog/tb-doenerwaffel/contents.lr | 45 - content/blog/tb-doenerwaffel/grill.jpg | 3 - content/blog/tb-doenerwaffel/messer.jpg | 3 - content/blog/tb-doenerwaffel/ovp.jpg | 3 - .../blog/toolbox-waffelt-jetzt/contents+en.lr | 26 - .../blog/toolbox-waffelt-jetzt/contents.lr | 26 - .../toolbox-waffelt-jetzt/toolbox-kiste.jpg | 3 - .../blog/toolbox-waffelt-jetzt/toolbox_1.jpg | 3 - content/blog/uh18/contents+en.lr | 53 - content/blog/uh18/contents.lr | 53 - content/blog/uh18/hacker_1.jpg | 3 - content/blog/uh18/hacker_2.jpg | 3 - content/blog/uh18/schiff_1.jpg | 3 - content/blog/uh18/schiff_2.jpg | 3 - content/blog/uh18/waffel_1.jpg | 3 - content/blog/uh18/waffel_2.jpg | 3 - content/blog/upgrade-1/a-random-box.jpg | 3 - content/blog/upgrade-1/contents.lr | 53 - content/blog/upgrade-1/unboxing-1.jpg | 3 - content/blog/upgrade-1/unboxing-10.jpg | 3 - content/blog/upgrade-1/unboxing-11.jpg | 3 - content/blog/upgrade-1/unboxing-12.jpg | 3 - content/blog/upgrade-1/unboxing-13.jpg | 3 - content/blog/upgrade-1/unboxing-2.jpg | 3 - content/blog/upgrade-1/unboxing-3.jpg | 3 - content/blog/upgrade-1/unboxing-4.jpg | 3 - content/blog/upgrade-1/unboxing-5.jpg | 3 - content/blog/upgrade-1/unboxing-6.jpg | 3 - content/blog/upgrade-1/unboxing-7.jpg | 3 - content/blog/upgrade-1/unboxing-8.jpg | 3 - content/blog/upgrade-1/unboxing-9.jpg | 3 - .../blog/waffellove-in-darmstadt/contents.lr | 36 - .../blog/waffellove-in-darmstadt/waffel_1.jpg | 3 - .../blog/waffellove-in-darmstadt/waffel_2.jpg | 3 - .../blog/waffellove-in-darmstadt/waffel_4.jpg | 3 - .../blog/waffellove-in-darmstadt/waffel_5.jpg | 3 - .../blog/waffellove-in-darmstadt/waffel_6.jpg | 3 - .../blog/waffellove-in-darmstadt/waffel_7.jpg | 3 - .../blog/waffellove-in-darmstadt/waffel_8.jpg | 3 - .../400px-Gpn19-plakat-webv2.png | 3 - .../blog/we-need-you-at-gpn19/contents+en.lr | 40 - content/blog/we-need-you-at-gpn19/contents.lr | 40 - .../we_tweet_about_waffles/contents+en.lr | 32 - .../blog/we_tweet_about_waffles/contents.lr | 36 - .../blog/we_tweet_about_waffles/waffel_1.jpg | 3 - .../blog/we_tweet_about_waffles/waffel_2.jpg | 3 - content/contents+en.lr | 148 - content/contents.lr | 295 +- content/datenschutz/contents+en.lr | 26 - content/datenschutz/contents.lr | 31 - content/feed_blog.xml/contents.lr | 5 - content/feed_rezepte.xml/contents.lr | 5 - content/finanzen/35c3/contents+en.lr | 21 - content/finanzen/35c3/contents.lr | 23 - content/finanzen/36c3/contents.lr | 67 - content/finanzen/cccamp19/contents.lr | 41 - content/finanzen/contents+en.lr | 67 - content/finanzen/contents.lr | 69 - content/finanzen/gpn19/contents.lr | 25 - content/finanzen/helfen/contents+en.lr | 84 - content/finanzen/helfen/contents.lr | 86 - content/impressum/contents+en.lr | 31 - content/impressum/contents.lr | 46 - content/kontakt/big_case.jpg | 3 - content/kontakt/binary.png | 3 - content/kontakt/case.jpg | 3 - content/kontakt/chaospott.png | 3 - content/kontakt/contents+en.lr | 152 - content/kontakt/contents.lr | 155 - content/kontakt/doppeleisen.jpg | 3 - content/kontakt/eisen.jpg | 3 - content/kontakt/eisen_bruessel.jpg | 3 - content/kontakt/rowenta.jpg | 3 - content/mitmachen/contents+en.lr | 104 - content/mitmachen/contents.lr | 111 - content/rezept/bruehstueck/contents+en.lr | 68 - content/rezept/bruehstueck/contents.lr | 68 - content/rezept/contents+en.lr | 40 - content/rezept/contents.lr | 4 +- content/rezept/currywurst/contents+en.lr | 45 - content/rezept/currywurst/contents.lr | 47 - content/rezept/doener/contents.lr | 51 - content/rezept/gluten/contents+en.lr | 48 - content/rezept/gluten/contents.lr | 48 - content/rezept/klassisch/contents.lr | 13 + .../rezept/klassisch/rezept.yaml/contents.lr | 376 + content/rezept/knoblauch/contents.lr | 39 - content/rezept/normal/contents+en.lr | 36 - content/rezept/normal/contents.lr | 36 - content/rezept/okara/contents+en.lr | 76 - content/rezept/okara/contents.lr | 78 - content/rezept/soja/contents+en.lr | 77 - content/rezept/soja/contents.lr | 77 - content/rezept/vegan/contents+en.lr | 44 - content/rezept/vegan/contents.lr | 45 - content/sitemap.xml/contents.lr | 4 - content/sweet_waffle.jpg | 3 + content/waffeln.ics/contents.lr | 182 +- databags/nav-bar.ini | 23 - databags/navigation.ini | 45 - databags/navigation.json | 38 + flowblocks/events.ini | 46 + flowblocks/flow_amounts.ini | 16 + flowblocks/flow_boxes_section.ini | 38 + flowblocks/flow_calendar.ini | 8 + flowblocks/flow_claim_boxes.ini | 29 + flowblocks/flow_ingredients.ini | 36 + flowblocks/flow_notes.ini | 7 + flowblocks/flow_one_innerbox_section.ini | 34 + flowblocks/flow_oven.ini | 15 + flowblocks/flow_processing.ini | 8 + flowblocks/flow_seperator.ini | 3 + flowblocks/flow_servings.ini | 16 + flowblocks/flow_social_media_link.ini | 52 + flowblocks/flow_steps.ini | 25 + flowblocks/flow_substitutions.ini | 32 + flowblocks/flow_text_image_section.ini | 40 + flowblocks/flow_text_section.ini | 12 + flowblocks/flow_third_box_section.ini | 9 + flowblocks/press_table.ini | 19 - flowblocks/pro_img.ini | 9 - flowblocks/pro_video.ini | 33 - flowblocks/startpage_section.ini | 37 - flowblocks/termine.ini | 31 - models/aggregator_page.ini | 18 + models/blog-post.ini | 48 +- models/blog.ini | 21 +- models/calendar.ini | 49 + models/flow_block_page.ini | 28 + models/header_slim.ini | 4 + models/header_with_logo.ini | 31 + models/homepage.ini | 19 + models/image.ini | 16 + models/kalender.ini | 45 - models/page.ini | 25 +- models/podcast-post.ini | 80 + models/podcast.ini | 55 + models/presse.ini | 72 - models/projekt-post.ini | 52 - models/projekte.ini | 49 - models/rezept-post.ini | 37 + models/rezept.ini | 27 + models/start.ini | 250 - models/vereinsheim.ini | 34 - models/waffeln.ini | 20 - models/zutaten.ini | 81 + templates/aggregator_page.html | 63 + templates/blocks/events.ics | 0 templates/blocks/flow_boxes_section.html | 33 + templates/blocks/flow_calendar.html | 52 + templates/blocks/flow_claim_boxes.html | 13 + .../blocks/flow_one_innerbox_section.html | 24 + templates/blocks/flow_seperator.html | 3 + templates/blocks/flow_social_media_link.html | 28 + templates/blocks/flow_text_image_section.html | 46 + templates/blocks/flow_text_section.html | 5 + templates/blocks/flow_third_box_section.html | 50 + templates/blocks/navigation.html | 62 + templates/blocks/press_table.html | 1 - templates/blocks/pro_img.html | 4 - templates/blocks/pro_video.html | 8 - templates/blocks/startpage_section.html | 10 - templates/blocks/termine.html | 1 - templates/blocks/termine.ics | 1 - templates/blog-post.html | 46 +- templates/blog.html | 58 +- templates/calendar.ics | 12 + templates/events/event.ics | 25 + templates/events/header.ics | 14 + templates/events/timezone.ics | 20 + templates/feed_blog.xml | 34 - templates/feed_projekte.xml | 33 - templates/header_slim.html | 32 + templates/header_with_logo.html | 54 + templates/homepage.html | 20 + templates/kalender.html | 40 - templates/layout.html | 377 +- templates/macros/blog.html | 76 +- templates/macros/pagination.html | 34 +- templates/macros/podcast.html | 77 + templates/macros/projekt.html | 49 - templates/macros/rezept.html | 318 + templates/macros/translator.j2 | 14 - templates/page.html | 42 +- templates/partials/head.html | 37 - templates/partials/spacestate.html | 28 - templates/podcast-post.html | 18 + templates/podcast.html | 54 + templates/podcastfeed.xml | 132 + templates/presse.html | 79 - templates/projekt-post.html | 28 - templates/projekte.html | 42 - templates/rezept-post.html | 18 + templates/rezept.html | 27 + templates/sitemap.xml | 2 + templates/start.html | 183 - templates/vereinsheim.html | 49 - templates/waffeln.ics | 20 - templates/zutaten.yaml | 173 + 500 files changed, 12455 insertions(+), 29209 deletions(-) delete mode 100644 assets/css/font-awesome.min.css create mode 100644 assets/css/fonts.css delete mode 100644 assets/css/images/arrow.svg delete mode 100644 assets/css/images/ie/banner-overlay.png delete mode 100644 assets/css/images/layers-2x.png delete mode 100644 assets/css/images/layers.png delete mode 100644 assets/css/images/marker-icon-2x.png delete mode 100644 assets/css/images/marker-icon.png delete mode 100644 assets/css/images/marker-shadow.png delete mode 100644 assets/css/leaflet.css delete mode 100644 assets/css/lightgallery.css create mode 100644 assets/css/reset.css create mode 100644 assets/css/style.css create mode 100644 assets/css/xml.css create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300.eot create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300.svg create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300.ttf create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300.woff create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300.woff2 create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300italic.eot create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300italic.svg create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300italic.ttf create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300italic.woff create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-300italic.woff2 create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-700.eot create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-700.svg create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-700.ttf create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-700.woff create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-700.woff2 create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-900.eot create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-900.svg create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-900.ttf create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-900.woff create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-900.woff2 create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-italic.eot create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-italic.svg create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-italic.ttf create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-italic.woff create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-italic.woff2 create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-regular.eot create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-regular.svg create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-regular.ttf create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-regular.woff create mode 100644 assets/fonts/lato-v17-latin/lato-v17-latin-regular.woff2 delete mode 100644 assets/fonts/lg.eot delete mode 100644 assets/fonts/lg.svg delete mode 100644 assets/fonts/lg.ttf delete mode 100644 assets/fonts/lg.woff create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.eot create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.svg create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.ttf create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.woff create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.woff2 create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.eot create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.svg create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.ttf create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.woff create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.woff2 create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.eot create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.svg create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.ttf create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.woff create mode 100644 assets/fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.woff2 delete mode 100644 assets/fonts/roboto-italic_300.ttf delete mode 100644 assets/fonts/roboto-italic_400.ttf delete mode 100644 assets/fonts/roboto-italic_500.ttf delete mode 100644 assets/fonts/roboto.css delete mode 100644 assets/fonts/roboto_300.ttf delete mode 100644 assets/fonts/roboto_400.ttf delete mode 100644 assets/fonts/roboto_500.ttf create mode 100644 assets/images/background_waffle.svg create mode 100644 assets/images/footer_triangles.svg create mode 100644 assets/images/header_bottom_triangles.svg create mode 100644 assets/images/header_top_triangles.svg create mode 100644 assets/images/icons/manifest.json create mode 100644 assets/images/icons/social/feed.svg create mode 100644 assets/images/icons/social/gitea.svg create mode 100644 assets/images/icons/social/github.svg create mode 100644 assets/images/icons/social/hackint.svg create mode 100644 assets/images/icons/social/mastodon.svg create mode 100644 assets/images/icons/social/podcast.svg create mode 100644 assets/images/icons/social/reddit.svg create mode 100644 assets/images/icons/social/telegram.svg create mode 100644 assets/images/icons/social/twitter.svg create mode 100644 assets/images/photos/c3woc_croissant_01.jpg rename assets/images/{waffel.jpeg => photos/waffel_.jpg} (100%) delete mode 100644 assets/js/jquery.min.js delete mode 100644 assets/js/jquery.mousewheel.min.js delete mode 100644 assets/js/jquery.scrollex.min.js delete mode 100644 assets/js/jquery.scrolly.min.js delete mode 100644 assets/js/leaflet.js delete mode 100644 assets/js/lightgallery-all.min.js delete mode 100644 assets/js/main.js create mode 100644 assets/js/nav_toggle.js delete mode 100644 assets/js/openstreetmap.js delete mode 100644 assets/js/picturefill.min.js delete mode 100644 assets/js/skel.min.js delete mode 100644 assets/js/util.js delete mode 100644 assets/js/webcomponents.js delete mode 100644 assets/js/webcomponents.min.js delete mode 100644 assets/scss/ie9.scss delete mode 100644 assets/scss/libs/_functions.scss delete mode 100644 assets/scss/libs/_mixins.scss delete mode 100644 assets/scss/libs/_skel.scss delete mode 100644 assets/scss/libs/_vars.scss delete mode 100644 assets/scss/parts/_banner.scss delete mode 100644 assets/scss/parts/_basic.scss delete mode 100644 assets/scss/parts/_box.scss delete mode 100644 assets/scss/parts/_button.scss delete mode 100644 assets/scss/parts/_col.scss delete mode 100644 assets/scss/parts/_dropotron.scss delete mode 100644 assets/scss/parts/_footer.scss delete mode 100644 assets/scss/parts/_form.scss delete mode 100644 assets/scss/parts/_goto-next.scss delete mode 100644 assets/scss/parts/_header.scss delete mode 100644 assets/scss/parts/_icon.scss delete mode 100644 assets/scss/parts/_image.scss delete mode 100644 assets/scss/parts/_list.scss delete mode 100644 assets/scss/parts/_loader.scss delete mode 100644 assets/scss/parts/_project.scss delete mode 100644 assets/scss/parts/_section-article.scss delete mode 100644 assets/scss/parts/_spotlight.scss delete mode 100644 assets/scss/parts/_startpage.scss delete mode 100644 assets/scss/parts/_table.scss delete mode 100644 assets/scss/parts/_wrapper.scss delete mode 100644 assets/scss/parts/_youtube.scss delete mode 100644 assets/webfonts/fa-brands-400.eot delete mode 100644 assets/webfonts/fa-brands-400.svg delete mode 100644 assets/webfonts/fa-brands-400.ttf delete mode 100644 assets/webfonts/fa-brands-400.woff delete mode 100644 assets/webfonts/fa-brands-400.woff2 delete mode 100644 assets/webfonts/fa-regular-400.eot delete mode 100644 assets/webfonts/fa-regular-400.svg delete mode 100644 assets/webfonts/fa-regular-400.ttf delete mode 100644 assets/webfonts/fa-regular-400.woff delete mode 100644 assets/webfonts/fa-regular-400.woff2 delete mode 100644 assets/webfonts/fa-solid-900.eot delete mode 100644 assets/webfonts/fa-solid-900.svg delete mode 100644 assets/webfonts/fa-solid-900.ttf delete mode 100644 assets/webfonts/fa-solid-900.woff delete mode 100644 assets/webfonts/fa-solid-900.woff2 delete mode 100644 assets/youtube-embed.html delete mode 100644 content/blog/35c3/contents+en.lr delete mode 100644 content/blog/35c3/contents.lr delete mode 100644 content/blog/35c3/waffel_act.jpg delete mode 100644 content/blog/35c3/waffel_beauty.jpg delete mode 100644 content/blog/35c3/waffel_delivery.jpg delete mode 100644 content/blog/35c3/waffel_doener.jpg delete mode 100644 content/blog/35c3/waffel_loc.jpg delete mode 100644 content/blog/35c3/waffel_love.jpg delete mode 100644 content/blog/35c3/waffel_njom.jpg delete mode 100644 content/blog/35c3/waffel_shift.jpg delete mode 100644 content/blog/35c3/waffel_stamp.jpg delete mode 100644 content/blog/35c3/waffel_stempel.jpg delete mode 100644 content/blog/35c3/waffel_sticker.jpg delete mode 100644 content/blog/35c3/waffel_tschunk.jpg delete mode 100644 content/blog/35c3/waffel_tschunk_action.jpg delete mode 100644 content/blog/35c3/waffel_tschunk_raw.jpg delete mode 100644 content/blog/35c3/waffel_weg.jpg delete mode 100644 content/blog/36c3-helfer/contents+en.lr delete mode 100644 content/blog/36c3-helfer/contents.lr delete mode 100644 content/blog/36c3-konzept/contents+en.lr delete mode 100644 content/blog/36c3-konzept/contents.lr delete mode 100644 content/blog/binary-waffles/binary.png delete mode 100644 content/blog/binary-waffles/contents+en.lr delete mode 100644 content/blog/binary-waffles/contents.lr delete mode 100644 content/blog/camp-18/ambiente.jpg delete mode 100644 content/blog/camp-18/contents+en.lr delete mode 100644 content/blog/camp-18/contents.lr delete mode 100644 content/blog/camp-18/garten.jpg delete mode 100644 content/blog/camp-18/waffel-profi.jpg delete mode 100644 content/blog/camp-18/waffel-standort.jpg delete mode 100644 content/blog/cccamp19/contents+en.lr delete mode 100644 content/blog/cccamp19/contents.lr delete mode 100644 content/blog/cep19/birthdaykid.JPG delete mode 100644 content/blog/cep19/cep19.jpg delete mode 100644 content/blog/cep19/cep_19.jpg delete mode 100644 content/blog/cep19/cep__19.jpg delete mode 100644 content/blog/cep19/contents+en.lr delete mode 100644 content/blog/cep19/contents.lr delete mode 100644 content/blog/cep19/index.jpg delete mode 100644 content/blog/cep19/mampf.JPG delete mode 100644 content/blog/cep19/mozart.JPG delete mode 100644 content/blog/cep19/music.JPG delete mode 100644 content/blog/cep19/schweif.JPG delete mode 100644 content/blog/cep19/star.JPG delete mode 100644 content/blog/cep19/teig.JPG delete mode 100644 content/blog/chaospott-macht-waffeln/chaospott.png delete mode 100644 content/blog/chaospott-macht-waffeln/contents+en.lr delete mode 100644 content/blog/chaospott-macht-waffeln/contents.lr delete mode 100644 content/blog/contents+en.lr delete mode 100644 content/blog/contents.lr delete mode 100644 content/blog/cosin-2018/contents.lr delete mode 100644 content/blog/cosin-2018/food.jpg delete mode 100644 content/blog/cosin-2018/njom.jpg delete mode 100644 content/blog/cosin-2018/ofen.jpg delete mode 100644 content/blog/cosin-2018/pizza.jpg delete mode 100644 content/blog/cosin-2018/pizza_klein.jpg delete mode 100644 content/blog/cosin-2018/waffeln.jpg delete mode 100644 content/blog/ecreating-waffles/contents+en.lr delete mode 100644 content/blog/ecreating-waffles/contents.lr delete mode 100644 content/blog/eh18/contents+en.lr delete mode 100644 content/blog/eh18/contents.lr delete mode 100644 content/blog/eh18/eh18-pxl.jpg delete mode 100644 content/blog/eh19/chaospott.png delete mode 100644 content/blog/eh19/contents+en.lr delete mode 100644 content/blog/eh19/contents.lr delete mode 100644 content/blog/eh19/ruehren.jpg delete mode 100644 content/blog/eh19/ruehren.mp4 delete mode 100644 content/blog/eh19/stream.png delete mode 100644 content/blog/erster-analoger-waffelzaehler/backing.jpg delete mode 100644 content/blog/erster-analoger-waffelzaehler/contents+en.lr delete mode 100644 content/blog/erster-analoger-waffelzaehler/contents.lr delete mode 100644 content/blog/erster-analoger-waffelzaehler/overview.jpg delete mode 100644 content/blog/erster-analoger-waffelzaehler/waffelzaehler.jpg delete mode 100644 content/blog/fidm18/FidM18.jpg delete mode 100644 content/blog/fidm18/contents+en.lr delete mode 100644 content/blog/fidm18/contents.lr delete mode 100644 content/blog/first-post/contents+en.lr delete mode 100644 content/blog/first-post/contents.lr delete mode 100644 content/blog/froscon18/contents+en.lr delete mode 100644 content/blog/froscon18/contents.lr delete mode 100644 content/blog/froscon18/hello.jpg delete mode 100644 content/blog/froscon18/licht.jpg delete mode 100644 content/blog/froscon18/overflow.jpg delete mode 100644 content/blog/froscon18/team.jpg delete mode 100644 content/blog/froscon18/teig.jpg delete mode 100644 content/blog/froscon18/waffel.jpg delete mode 100644 content/blog/geekend_nov_2018/contents+en.lr delete mode 100644 content/blog/geekend_nov_2018/contents.lr delete mode 100644 content/blog/geekend_nov_2018/ergebnis.jpg delete mode 100644 content/blog/geekend_nov_2018/ruehren.jpg delete mode 100644 content/blog/geekend_nov_2018/table.jpg delete mode 100644 content/blog/geekend_nov_2018/teig.jpg delete mode 100644 content/blog/geekend_nov_2018/zutaten.jpg delete mode 100644 content/blog/gluehpn/beginning.jpg delete mode 100644 content/blog/gluehpn/contents+en.lr delete mode 100644 content/blog/gluehpn/contents.lr delete mode 100644 content/blog/gluehpn/fine.jpg delete mode 100644 content/blog/gluehpn/practise.jpg delete mode 100644 content/blog/gluehpn/spende.jpg delete mode 100644 content/blog/gluehpn/vegan.jpg delete mode 100644 content/blog/gluehpn/waffle.jpg delete mode 100644 content/blog/gluehpn/waffle_.jpg delete mode 100644 content/blog/gpn18-tag2/2gether.jpg delete mode 100644 content/blog/gpn18-tag2/contents.lr delete mode 100644 content/blog/gpn18-tag2/gn8.jpg delete mode 100644 content/blog/gpn18-tag2/kaesescheiben.jpg delete mode 100644 content/blog/gpn18-tag2/waffelstillstand.jpg delete mode 100644 content/blog/gpn18-tag2/zutaten.jpg delete mode 100644 content/blog/gpn18-waffelputzen/contents.lr delete mode 100644 content/blog/gpn18-waffelputzen/steinwolle.jpg delete mode 100644 content/blog/gpn18-waffelputzen/waffeleisen.jpg delete mode 100644 content/blog/gpn18/bei_der_bar.jpg delete mode 100644 content/blog/gpn18/contents.lr delete mode 100644 content/blog/gpn18/eroberung.jpg delete mode 100644 content/blog/gpn18/waffelpower_1.jpg delete mode 100644 content/blog/gpn18/waffelpower_2.jpg delete mode 100644 content/blog/gpn18/waffelpower_3.jpg delete mode 100644 content/blog/gwpn/contents.lr delete mode 100644 content/blog/gwpn/vegan.jpg delete mode 100644 content/blog/gwpn/voc.png delete mode 100644 content/blog/gwpn/waffelpower.jpg delete mode 100644 content/blog/gwpn/waffelstillstand.jpg delete mode 100644 content/blog/gwpn/weiter.jpg delete mode 100644 content/blog/gwpn/woc.png delete mode 100644 content/blog/logo/c3woc.svg.png delete mode 100644 content/blog/logo/contents+en.lr delete mode 100644 content/blog/logo/contents.lr delete mode 100644 content/blog/makerfaire-buildup/cat-01.jpg delete mode 100644 content/blog/makerfaire-buildup/cat-02.jpg delete mode 100644 content/blog/makerfaire-buildup/cat-03.jpg delete mode 100644 content/blog/makerfaire-buildup/contents.lr delete mode 100644 content/blog/makerfaire18/action01.jpg delete mode 100644 content/blog/makerfaire18/action02.jpg delete mode 100644 content/blog/makerfaire18/ballpit.jpg delete mode 100644 content/blog/makerfaire18/contents.lr delete mode 100644 content/blog/makerfaire18/waffelstillstand.jpg delete mode 100644 content/blog/makerfaire18/winkekatze.jpg delete mode 100644 content/blog/makerfaire18/winkekatze02.jpg delete mode 100644 content/blog/nicht-jeder-ag-Waffeln/1.JPG delete mode 100644 content/blog/nicht-jeder-ag-Waffeln/2.JPG delete mode 100644 content/blog/nicht-jeder-ag-Waffeln/3.JPG delete mode 100644 content/blog/nicht-jeder-ag-Waffeln/4.JPG delete mode 100644 content/blog/nicht-jeder-ag-Waffeln/contents.lr delete mode 100644 content/blog/rc3-streams/contents+en.lr delete mode 100644 content/blog/rc3-streams/contents.lr delete mode 100644 content/blog/rc3-workshop/contents+en.lr delete mode 100644 content/blog/rc3-workshop/contents.lr delete mode 100644 content/blog/rc3-workshop/rc3-waffelworkshop-hd.png delete mode 100644 content/blog/rc3-workshop/rc3-waffelworkshop.png delete mode 100644 content/blog/sei-teil-einer-genossenschaft/contents+en.lr delete mode 100644 content/blog/sei-teil-einer-genossenschaft/contents.lr delete mode 100644 content/blog/state-of-the-waffle/contents+en.lr delete mode 100644 content/blog/state-of-the-waffle/contents.lr delete mode 100644 content/blog/tb-doenerwaffel/contents+en.lr delete mode 100644 content/blog/tb-doenerwaffel/contents.lr delete mode 100644 content/blog/tb-doenerwaffel/grill.jpg delete mode 100644 content/blog/tb-doenerwaffel/messer.jpg delete mode 100644 content/blog/tb-doenerwaffel/ovp.jpg delete mode 100644 content/blog/toolbox-waffelt-jetzt/contents+en.lr delete mode 100644 content/blog/toolbox-waffelt-jetzt/contents.lr delete mode 100644 content/blog/toolbox-waffelt-jetzt/toolbox-kiste.jpg delete mode 100644 content/blog/toolbox-waffelt-jetzt/toolbox_1.jpg delete mode 100644 content/blog/uh18/contents+en.lr delete mode 100644 content/blog/uh18/contents.lr delete mode 100644 content/blog/uh18/hacker_1.jpg delete mode 100644 content/blog/uh18/hacker_2.jpg delete mode 100644 content/blog/uh18/schiff_1.jpg delete mode 100644 content/blog/uh18/schiff_2.jpg delete mode 100644 content/blog/uh18/waffel_1.jpg delete mode 100644 content/blog/uh18/waffel_2.jpg delete mode 100644 content/blog/upgrade-1/a-random-box.jpg delete mode 100644 content/blog/upgrade-1/contents.lr delete mode 100644 content/blog/upgrade-1/unboxing-1.jpg delete mode 100644 content/blog/upgrade-1/unboxing-10.jpg delete mode 100644 content/blog/upgrade-1/unboxing-11.jpg delete mode 100644 content/blog/upgrade-1/unboxing-12.jpg delete mode 100644 content/blog/upgrade-1/unboxing-13.jpg delete mode 100644 content/blog/upgrade-1/unboxing-2.jpg delete mode 100644 content/blog/upgrade-1/unboxing-3.jpg delete mode 100644 content/blog/upgrade-1/unboxing-4.jpg delete mode 100644 content/blog/upgrade-1/unboxing-5.jpg delete mode 100644 content/blog/upgrade-1/unboxing-6.jpg delete mode 100644 content/blog/upgrade-1/unboxing-7.jpg delete mode 100644 content/blog/upgrade-1/unboxing-8.jpg delete mode 100644 content/blog/upgrade-1/unboxing-9.jpg delete mode 100644 content/blog/waffellove-in-darmstadt/contents.lr delete mode 100644 content/blog/waffellove-in-darmstadt/waffel_1.jpg delete mode 100644 content/blog/waffellove-in-darmstadt/waffel_2.jpg delete mode 100644 content/blog/waffellove-in-darmstadt/waffel_4.jpg delete mode 100644 content/blog/waffellove-in-darmstadt/waffel_5.jpg delete mode 100644 content/blog/waffellove-in-darmstadt/waffel_6.jpg delete mode 100644 content/blog/waffellove-in-darmstadt/waffel_7.jpg delete mode 100644 content/blog/waffellove-in-darmstadt/waffel_8.jpg delete mode 100644 content/blog/we-need-you-at-gpn19/400px-Gpn19-plakat-webv2.png delete mode 100644 content/blog/we-need-you-at-gpn19/contents+en.lr delete mode 100644 content/blog/we-need-you-at-gpn19/contents.lr delete mode 100644 content/blog/we_tweet_about_waffles/contents+en.lr delete mode 100644 content/blog/we_tweet_about_waffles/contents.lr delete mode 100644 content/blog/we_tweet_about_waffles/waffel_1.jpg delete mode 100644 content/blog/we_tweet_about_waffles/waffel_2.jpg delete mode 100644 content/contents+en.lr delete mode 100644 content/datenschutz/contents+en.lr delete mode 100644 content/datenschutz/contents.lr delete mode 100644 content/feed_blog.xml/contents.lr delete mode 100644 content/feed_rezepte.xml/contents.lr delete mode 100644 content/finanzen/35c3/contents+en.lr delete mode 100644 content/finanzen/35c3/contents.lr delete mode 100644 content/finanzen/36c3/contents.lr delete mode 100644 content/finanzen/cccamp19/contents.lr delete mode 100644 content/finanzen/contents+en.lr delete mode 100644 content/finanzen/contents.lr delete mode 100644 content/finanzen/gpn19/contents.lr delete mode 100644 content/finanzen/helfen/contents+en.lr delete mode 100644 content/finanzen/helfen/contents.lr delete mode 100644 content/impressum/contents+en.lr delete mode 100644 content/impressum/contents.lr delete mode 100644 content/kontakt/big_case.jpg delete mode 100644 content/kontakt/binary.png delete mode 100644 content/kontakt/case.jpg delete mode 100644 content/kontakt/chaospott.png delete mode 100644 content/kontakt/contents+en.lr delete mode 100644 content/kontakt/contents.lr delete mode 100644 content/kontakt/doppeleisen.jpg delete mode 100644 content/kontakt/eisen.jpg delete mode 100644 content/kontakt/eisen_bruessel.jpg delete mode 100644 content/kontakt/rowenta.jpg delete mode 100644 content/mitmachen/contents+en.lr delete mode 100644 content/mitmachen/contents.lr delete mode 100644 content/rezept/bruehstueck/contents+en.lr delete mode 100644 content/rezept/bruehstueck/contents.lr delete mode 100644 content/rezept/contents+en.lr delete mode 100644 content/rezept/currywurst/contents+en.lr delete mode 100644 content/rezept/currywurst/contents.lr delete mode 100644 content/rezept/doener/contents.lr delete mode 100644 content/rezept/gluten/contents+en.lr delete mode 100644 content/rezept/gluten/contents.lr create mode 100644 content/rezept/klassisch/contents.lr create mode 100644 content/rezept/klassisch/rezept.yaml/contents.lr delete mode 100644 content/rezept/knoblauch/contents.lr delete mode 100644 content/rezept/normal/contents+en.lr delete mode 100644 content/rezept/normal/contents.lr delete mode 100644 content/rezept/okara/contents+en.lr delete mode 100644 content/rezept/okara/contents.lr delete mode 100644 content/rezept/soja/contents+en.lr delete mode 100644 content/rezept/soja/contents.lr delete mode 100644 content/rezept/vegan/contents+en.lr delete mode 100644 content/rezept/vegan/contents.lr delete mode 100644 content/sitemap.xml/contents.lr create mode 100644 content/sweet_waffle.jpg delete mode 100644 databags/nav-bar.ini delete mode 100644 databags/navigation.ini create mode 100644 databags/navigation.json create mode 100644 flowblocks/events.ini create mode 100644 flowblocks/flow_amounts.ini create mode 100644 flowblocks/flow_boxes_section.ini create mode 100644 flowblocks/flow_calendar.ini create mode 100644 flowblocks/flow_claim_boxes.ini create mode 100644 flowblocks/flow_ingredients.ini create mode 100644 flowblocks/flow_notes.ini create mode 100644 flowblocks/flow_one_innerbox_section.ini create mode 100644 flowblocks/flow_oven.ini create mode 100644 flowblocks/flow_processing.ini create mode 100644 flowblocks/flow_seperator.ini create mode 100644 flowblocks/flow_servings.ini create mode 100644 flowblocks/flow_social_media_link.ini create mode 100644 flowblocks/flow_steps.ini create mode 100644 flowblocks/flow_substitutions.ini create mode 100644 flowblocks/flow_text_image_section.ini create mode 100644 flowblocks/flow_text_section.ini create mode 100644 flowblocks/flow_third_box_section.ini delete mode 100644 flowblocks/press_table.ini delete mode 100644 flowblocks/pro_img.ini delete mode 100644 flowblocks/pro_video.ini delete mode 100644 flowblocks/startpage_section.ini delete mode 100644 flowblocks/termine.ini create mode 100644 models/aggregator_page.ini create mode 100644 models/calendar.ini create mode 100644 models/flow_block_page.ini create mode 100644 models/header_slim.ini create mode 100644 models/header_with_logo.ini create mode 100644 models/homepage.ini create mode 100644 models/image.ini delete mode 100644 models/kalender.ini create mode 100644 models/podcast-post.ini create mode 100644 models/podcast.ini delete mode 100644 models/presse.ini delete mode 100644 models/projekt-post.ini delete mode 100644 models/projekte.ini create mode 100644 models/rezept-post.ini create mode 100644 models/rezept.ini delete mode 100644 models/start.ini delete mode 100644 models/vereinsheim.ini delete mode 100644 models/waffeln.ini create mode 100644 models/zutaten.ini create mode 100644 templates/aggregator_page.html create mode 100644 templates/blocks/events.ics create mode 100644 templates/blocks/flow_boxes_section.html create mode 100644 templates/blocks/flow_calendar.html create mode 100644 templates/blocks/flow_claim_boxes.html create mode 100644 templates/blocks/flow_one_innerbox_section.html create mode 100644 templates/blocks/flow_seperator.html create mode 100644 templates/blocks/flow_social_media_link.html create mode 100644 templates/blocks/flow_text_image_section.html create mode 100644 templates/blocks/flow_text_section.html create mode 100644 templates/blocks/flow_third_box_section.html create mode 100644 templates/blocks/navigation.html delete mode 100644 templates/blocks/press_table.html delete mode 100644 templates/blocks/pro_img.html delete mode 100644 templates/blocks/pro_video.html delete mode 100644 templates/blocks/startpage_section.html delete mode 100644 templates/blocks/termine.html create mode 100644 templates/calendar.ics create mode 100644 templates/events/event.ics create mode 100644 templates/events/header.ics create mode 100644 templates/events/timezone.ics delete mode 100644 templates/feed_blog.xml delete mode 100644 templates/feed_projekte.xml create mode 100644 templates/header_slim.html create mode 100644 templates/header_with_logo.html create mode 100644 templates/homepage.html delete mode 100644 templates/kalender.html create mode 100644 templates/macros/podcast.html delete mode 100644 templates/macros/projekt.html create mode 100644 templates/macros/rezept.html delete mode 100644 templates/macros/translator.j2 delete mode 100644 templates/partials/head.html delete mode 100644 templates/partials/spacestate.html create mode 100644 templates/podcast-post.html create mode 100644 templates/podcast.html create mode 100644 templates/podcastfeed.xml delete mode 100644 templates/presse.html delete mode 100644 templates/projekt-post.html delete mode 100644 templates/projekte.html create mode 100644 templates/rezept-post.html create mode 100644 templates/rezept.html delete mode 100644 templates/start.html delete mode 100644 templates/vereinsheim.html delete mode 100644 templates/waffeln.ics create mode 100644 templates/zutaten.yaml diff --git a/.gitignore b/.gitignore index 4824d71..01423b9 100644 --- a/.gitignore +++ b/.gitignore @@ -58,4 +58,7 @@ tmp/ libsass/ sass-spec/ sassc/ - +# validator +rezept.json +rezept.yaml +schema.json diff --git a/assets/css/font-awesome.min.css b/assets/css/font-awesome.min.css deleted file mode 100644 index 897ff54..0000000 --- a/assets/css/font-awesome.min.css +++ /dev/null @@ -1 +0,0 @@ -.fa,.fab,.fal,.far,.fas{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:inline-block;font-style:normal;font-variant:normal;text-rendering:auto;line-height:1}.fa-lg{font-size:1.33333em;line-height:.75em;vertical-align:-.0667em}.fa-xs{font-size:.75em}.fa-sm{font-size:.875em}.fa-1x{font-size:1em}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-6x{font-size:6em}.fa-7x{font-size:7em}.fa-8x{font-size:8em}.fa-9x{font-size:9em}.fa-10x{font-size:10em}.fa-fw{text-align:center;width:1.25em}.fa-ul{list-style-type:none;margin-left:2.5em;padding-left:0}.fa-ul>li{position:relative}.fa-li{left:-2em;position:absolute;text-align:center;width:2em;line-height:inherit}.fa-border{border:.08em solid #eee;border-radius:.1em;padding:.2em .25em .15em}.fa-pull-left{float:left}.fa-pull-right{float:right}.fa.fa-pull-left,.fab.fa-pull-left,.fal.fa-pull-left,.far.fa-pull-left,.fas.fa-pull-left{margin-right:.3em}.fa.fa-pull-right,.fab.fa-pull-right,.fal.fa-pull-right,.far.fa-pull-right,.fas.fa-pull-right{margin-left:.3em}.fa-spin{animation:fa-spin 2s infinite linear}.fa-pulse{animation:fa-spin 1s infinite steps(8)}@keyframes fa-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.fa-rotate-90{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=1)";transform:rotate(90deg)}.fa-rotate-180{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2)";transform:rotate(180deg)}.fa-rotate-270{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=3)";transform:rotate(270deg)}.fa-flip-horizontal{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1)";transform:scaleX(-1)}.fa-flip-vertical{transform:scaleY(-1)}.fa-flip-both,.fa-flip-horizontal.fa-flip-vertical,.fa-flip-vertical{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)"}.fa-flip-both,.fa-flip-horizontal.fa-flip-vertical{transform:scale(-1)}:root .fa-flip-both,:root .fa-flip-horizontal,:root .fa-flip-vertical,:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270{filter:none}.fa-stack{display:inline-block;height:2em;line-height:2em;position:relative;vertical-align:middle;width:2.5em}.fa-stack-1x,.fa-stack-2x{left:0;position:absolute;text-align:center;width:100%}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-500px:before{content:"\f26e"}.fa-accessible-icon:before{content:"\f368"}.fa-accusoft:before{content:"\f369"}.fa-acquisitions-incorporated:before{content:"\f6af"}.fa-ad:before{content:"\f641"}.fa-address-book:before{content:"\f2b9"}.fa-address-card:before{content:"\f2bb"}.fa-adjust:before{content:"\f042"}.fa-adn:before{content:"\f170"}.fa-adobe:before{content:"\f778"}.fa-adversal:before{content:"\f36a"}.fa-affiliatetheme:before{content:"\f36b"}.fa-air-freshener:before{content:"\f5d0"}.fa-algolia:before{content:"\f36c"}.fa-align-center:before{content:"\f037"}.fa-align-justify:before{content:"\f039"}.fa-align-left:before{content:"\f036"}.fa-align-right:before{content:"\f038"}.fa-alipay:before{content:"\f642"}.fa-allergies:before{content:"\f461"}.fa-amazon:before{content:"\f270"}.fa-amazon-pay:before{content:"\f42c"}.fa-ambulance:before{content:"\f0f9"}.fa-american-sign-language-interpreting:before{content:"\f2a3"}.fa-amilia:before{content:"\f36d"}.fa-anchor:before{content:"\f13d"}.fa-android:before{content:"\f17b"}.fa-angellist:before{content:"\f209"}.fa-angle-double-down:before{content:"\f103"}.fa-angle-double-left:before{content:"\f100"}.fa-angle-double-right:before{content:"\f101"}.fa-angle-double-up:before{content:"\f102"}.fa-angle-down:before{content:"\f107"}.fa-angle-left:before{content:"\f104"}.fa-angle-right:before{content:"\f105"}.fa-angle-up:before{content:"\f106"}.fa-angry:before{content:"\f556"}.fa-angrycreative:before{content:"\f36e"}.fa-angular:before{content:"\f420"}.fa-ankh:before{content:"\f644"}.fa-app-store:before{content:"\f36f"}.fa-app-store-ios:before{content:"\f370"}.fa-apper:before{content:"\f371"}.fa-apple:before{content:"\f179"}.fa-apple-alt:before{content:"\f5d1"}.fa-apple-pay:before{content:"\f415"}.fa-archive:before{content:"\f187"}.fa-archway:before{content:"\f557"}.fa-arrow-alt-circle-down:before{content:"\f358"}.fa-arrow-alt-circle-left:before{content:"\f359"}.fa-arrow-alt-circle-right:before{content:"\f35a"}.fa-arrow-alt-circle-up:before{content:"\f35b"}.fa-arrow-circle-down:before{content:"\f0ab"}.fa-arrow-circle-left:before{content:"\f0a8"}.fa-arrow-circle-right:before{content:"\f0a9"}.fa-arrow-circle-up:before{content:"\f0aa"}.fa-arrow-down:before{content:"\f063"}.fa-arrow-left:before{content:"\f060"}.fa-arrow-right:before{content:"\f061"}.fa-arrow-up:before{content:"\f062"}.fa-arrows-alt:before{content:"\f0b2"}.fa-arrows-alt-h:before{content:"\f337"}.fa-arrows-alt-v:before{content:"\f338"}.fa-artstation:before{content:"\f77a"}.fa-assistive-listening-systems:before{content:"\f2a2"}.fa-asterisk:before{content:"\f069"}.fa-asymmetrik:before{content:"\f372"}.fa-at:before{content:"\f1fa"}.fa-atlas:before{content:"\f558"}.fa-atlassian:before{content:"\f77b"}.fa-atom:before{content:"\f5d2"}.fa-audible:before{content:"\f373"}.fa-audio-description:before{content:"\f29e"}.fa-autoprefixer:before{content:"\f41c"}.fa-avianex:before{content:"\f374"}.fa-aviato:before{content:"\f421"}.fa-award:before{content:"\f559"}.fa-aws:before{content:"\f375"}.fa-baby:before{content:"\f77c"}.fa-baby-carriage:before{content:"\f77d"}.fa-backspace:before{content:"\f55a"}.fa-backward:before{content:"\f04a"}.fa-bacon:before{content:"\f7e5"}.fa-balance-scale:before{content:"\f24e"}.fa-ban:before{content:"\f05e"}.fa-band-aid:before{content:"\f462"}.fa-bandcamp:before{content:"\f2d5"}.fa-barcode:before{content:"\f02a"}.fa-bars:before{content:"\f0c9"}.fa-baseball-ball:before{content:"\f433"}.fa-basketball-ball:before{content:"\f434"}.fa-bath:before{content:"\f2cd"}.fa-battery-empty:before{content:"\f244"}.fa-battery-full:before{content:"\f240"}.fa-battery-half:before{content:"\f242"}.fa-battery-quarter:before{content:"\f243"}.fa-battery-three-quarters:before{content:"\f241"}.fa-bed:before{content:"\f236"}.fa-beer:before{content:"\f0fc"}.fa-behance:before{content:"\f1b4"}.fa-behance-square:before{content:"\f1b5"}.fa-bell:before{content:"\f0f3"}.fa-bell-slash:before{content:"\f1f6"}.fa-bezier-curve:before{content:"\f55b"}.fa-bible:before{content:"\f647"}.fa-bicycle:before{content:"\f206"}.fa-bimobject:before{content:"\f378"}.fa-binoculars:before{content:"\f1e5"}.fa-biohazard:before{content:"\f780"}.fa-birthday-cake:before{content:"\f1fd"}.fa-bitbucket:before{content:"\f171"}.fa-bitcoin:before{content:"\f379"}.fa-bity:before{content:"\f37a"}.fa-black-tie:before{content:"\f27e"}.fa-blackberry:before{content:"\f37b"}.fa-blender:before{content:"\f517"}.fa-blender-phone:before{content:"\f6b6"}.fa-blind:before{content:"\f29d"}.fa-blog:before{content:"\f781"}.fa-blogger:before{content:"\f37c"}.fa-blogger-b:before{content:"\f37d"}.fa-bluetooth:before{content:"\f293"}.fa-bluetooth-b:before{content:"\f294"}.fa-bold:before{content:"\f032"}.fa-bolt:before{content:"\f0e7"}.fa-bomb:before{content:"\f1e2"}.fa-bone:before{content:"\f5d7"}.fa-bong:before{content:"\f55c"}.fa-book:before{content:"\f02d"}.fa-book-dead:before{content:"\f6b7"}.fa-book-medical:before{content:"\f7e6"}.fa-book-open:before{content:"\f518"}.fa-book-reader:before{content:"\f5da"}.fa-bookmark:before{content:"\f02e"}.fa-bowling-ball:before{content:"\f436"}.fa-box:before{content:"\f466"}.fa-box-open:before{content:"\f49e"}.fa-boxes:before{content:"\f468"}.fa-braille:before{content:"\f2a1"}.fa-brain:before{content:"\f5dc"}.fa-bread-slice:before{content:"\f7ec"}.fa-briefcase:before{content:"\f0b1"}.fa-briefcase-medical:before{content:"\f469"}.fa-broadcast-tower:before{content:"\f519"}.fa-broom:before{content:"\f51a"}.fa-brush:before{content:"\f55d"}.fa-btc:before{content:"\f15a"}.fa-bug:before{content:"\f188"}.fa-building:before{content:"\f1ad"}.fa-bullhorn:before{content:"\f0a1"}.fa-bullseye:before{content:"\f140"}.fa-burn:before{content:"\f46a"}.fa-buromobelexperte:before{content:"\f37f"}.fa-bus:before{content:"\f207"}.fa-bus-alt:before{content:"\f55e"}.fa-business-time:before{content:"\f64a"}.fa-buysellads:before{content:"\f20d"}.fa-calculator:before{content:"\f1ec"}.fa-calendar:before{content:"\f133"}.fa-calendar-alt:before{content:"\f073"}.fa-calendar-check:before{content:"\f274"}.fa-calendar-day:before{content:"\f783"}.fa-calendar-minus:before{content:"\f272"}.fa-calendar-plus:before{content:"\f271"}.fa-calendar-times:before{content:"\f273"}.fa-calendar-week:before{content:"\f784"}.fa-camera:before{content:"\f030"}.fa-camera-retro:before{content:"\f083"}.fa-campground:before{content:"\f6bb"}.fa-canadian-maple-leaf:before{content:"\f785"}.fa-candy-cane:before{content:"\f786"}.fa-cannabis:before{content:"\f55f"}.fa-capsules:before{content:"\f46b"}.fa-car:before{content:"\f1b9"}.fa-car-alt:before{content:"\f5de"}.fa-car-battery:before{content:"\f5df"}.fa-car-crash:before{content:"\f5e1"}.fa-car-side:before{content:"\f5e4"}.fa-caret-down:before{content:"\f0d7"}.fa-caret-left:before{content:"\f0d9"}.fa-caret-right:before{content:"\f0da"}.fa-caret-square-down:before{content:"\f150"}.fa-caret-square-left:before{content:"\f191"}.fa-caret-square-right:before{content:"\f152"}.fa-caret-square-up:before{content:"\f151"}.fa-caret-up:before{content:"\f0d8"}.fa-carrot:before{content:"\f787"}.fa-cart-arrow-down:before{content:"\f218"}.fa-cart-plus:before{content:"\f217"}.fa-cash-register:before{content:"\f788"}.fa-cat:before{content:"\f6be"}.fa-cc-amazon-pay:before{content:"\f42d"}.fa-cc-amex:before{content:"\f1f3"}.fa-cc-apple-pay:before{content:"\f416"}.fa-cc-diners-club:before{content:"\f24c"}.fa-cc-discover:before{content:"\f1f2"}.fa-cc-jcb:before{content:"\f24b"}.fa-cc-mastercard:before{content:"\f1f1"}.fa-cc-paypal:before{content:"\f1f4"}.fa-cc-stripe:before{content:"\f1f5"}.fa-cc-visa:before{content:"\f1f0"}.fa-centercode:before{content:"\f380"}.fa-centos:before{content:"\f789"}.fa-certificate:before{content:"\f0a3"}.fa-chair:before{content:"\f6c0"}.fa-chalkboard:before{content:"\f51b"}.fa-chalkboard-teacher:before{content:"\f51c"}.fa-charging-station:before{content:"\f5e7"}.fa-chart-area:before{content:"\f1fe"}.fa-chart-bar:before{content:"\f080"}.fa-chart-line:before{content:"\f201"}.fa-chart-pie:before{content:"\f200"}.fa-check:before{content:"\f00c"}.fa-check-circle:before{content:"\f058"}.fa-check-double:before{content:"\f560"}.fa-check-square:before{content:"\f14a"}.fa-cheese:before{content:"\f7ef"}.fa-chess:before{content:"\f439"}.fa-chess-bishop:before{content:"\f43a"}.fa-chess-board:before{content:"\f43c"}.fa-chess-king:before{content:"\f43f"}.fa-chess-knight:before{content:"\f441"}.fa-chess-pawn:before{content:"\f443"}.fa-chess-queen:before{content:"\f445"}.fa-chess-rook:before{content:"\f447"}.fa-chevron-circle-down:before{content:"\f13a"}.fa-chevron-circle-left:before{content:"\f137"}.fa-chevron-circle-right:before{content:"\f138"}.fa-chevron-circle-up:before{content:"\f139"}.fa-chevron-down:before{content:"\f078"}.fa-chevron-left:before{content:"\f053"}.fa-chevron-right:before{content:"\f054"}.fa-chevron-up:before{content:"\f077"}.fa-child:before{content:"\f1ae"}.fa-chrome:before{content:"\f268"}.fa-church:before{content:"\f51d"}.fa-circle:before{content:"\f111"}.fa-circle-notch:before{content:"\f1ce"}.fa-city:before{content:"\f64f"}.fa-clinic-medical:before{content:"\f7f2"}.fa-clipboard:before{content:"\f328"}.fa-clipboard-check:before{content:"\f46c"}.fa-clipboard-list:before{content:"\f46d"}.fa-clock:before{content:"\f017"}.fa-clone:before{content:"\f24d"}.fa-closed-captioning:before{content:"\f20a"}.fa-cloud:before{content:"\f0c2"}.fa-cloud-download-alt:before{content:"\f381"}.fa-cloud-meatball:before{content:"\f73b"}.fa-cloud-moon:before{content:"\f6c3"}.fa-cloud-moon-rain:before{content:"\f73c"}.fa-cloud-rain:before{content:"\f73d"}.fa-cloud-showers-heavy:before{content:"\f740"}.fa-cloud-sun:before{content:"\f6c4"}.fa-cloud-sun-rain:before{content:"\f743"}.fa-cloud-upload-alt:before{content:"\f382"}.fa-cloudscale:before{content:"\f383"}.fa-cloudsmith:before{content:"\f384"}.fa-cloudversify:before{content:"\f385"}.fa-cocktail:before{content:"\f561"}.fa-code:before{content:"\f121"}.fa-code-branch:before{content:"\f126"}.fa-codepen:before{content:"\f1cb"}.fa-codiepie:before{content:"\f284"}.fa-coffee:before{content:"\f0f4"}.fa-cog:before{content:"\f013"}.fa-cogs:before{content:"\f085"}.fa-coins:before{content:"\f51e"}.fa-columns:before{content:"\f0db"}.fa-comment:before{content:"\f075"}.fa-comment-alt:before{content:"\f27a"}.fa-comment-dollar:before{content:"\f651"}.fa-comment-dots:before{content:"\f4ad"}.fa-comment-medical:before{content:"\f7f5"}.fa-comment-slash:before{content:"\f4b3"}.fa-comments:before{content:"\f086"}.fa-comments-dollar:before{content:"\f653"}.fa-compact-disc:before{content:"\f51f"}.fa-compass:before{content:"\f14e"}.fa-compress:before{content:"\f066"}.fa-compress-arrows-alt:before{content:"\f78c"}.fa-concierge-bell:before{content:"\f562"}.fa-confluence:before{content:"\f78d"}.fa-connectdevelop:before{content:"\f20e"}.fa-contao:before{content:"\f26d"}.fa-cookie:before{content:"\f563"}.fa-cookie-bite:before{content:"\f564"}.fa-copy:before{content:"\f0c5"}.fa-copyright:before{content:"\f1f9"}.fa-couch:before{content:"\f4b8"}.fa-cpanel:before{content:"\f388"}.fa-creative-commons:before{content:"\f25e"}.fa-creative-commons-by:before{content:"\f4e7"}.fa-creative-commons-nc:before{content:"\f4e8"}.fa-creative-commons-nc-eu:before{content:"\f4e9"}.fa-creative-commons-nc-jp:before{content:"\f4ea"}.fa-creative-commons-nd:before{content:"\f4eb"}.fa-creative-commons-pd:before{content:"\f4ec"}.fa-creative-commons-pd-alt:before{content:"\f4ed"}.fa-creative-commons-remix:before{content:"\f4ee"}.fa-creative-commons-sa:before{content:"\f4ef"}.fa-creative-commons-sampling:before{content:"\f4f0"}.fa-creative-commons-sampling-plus:before{content:"\f4f1"}.fa-creative-commons-share:before{content:"\f4f2"}.fa-creative-commons-zero:before{content:"\f4f3"}.fa-credit-card:before{content:"\f09d"}.fa-critical-role:before{content:"\f6c9"}.fa-crop:before{content:"\f125"}.fa-crop-alt:before{content:"\f565"}.fa-cross:before{content:"\f654"}.fa-crosshairs:before{content:"\f05b"}.fa-crow:before{content:"\f520"}.fa-crown:before{content:"\f521"}.fa-crutch:before{content:"\f7f7"}.fa-css3:before{content:"\f13c"}.fa-css3-alt:before{content:"\f38b"}.fa-cube:before{content:"\f1b2"}.fa-cubes:before{content:"\f1b3"}.fa-cut:before{content:"\f0c4"}.fa-cuttlefish:before{content:"\f38c"}.fa-d-and-d:before{content:"\f38d"}.fa-d-and-d-beyond:before{content:"\f6ca"}.fa-dashcube:before{content:"\f210"}.fa-database:before{content:"\f1c0"}.fa-deaf:before{content:"\f2a4"}.fa-delicious:before{content:"\f1a5"}.fa-democrat:before{content:"\f747"}.fa-deploydog:before{content:"\f38e"}.fa-deskpro:before{content:"\f38f"}.fa-desktop:before{content:"\f108"}.fa-dev:before{content:"\f6cc"}.fa-deviantart:before{content:"\f1bd"}.fa-dharmachakra:before{content:"\f655"}.fa-dhl:before{content:"\f790"}.fa-diagnoses:before{content:"\f470"}.fa-diaspora:before{content:"\f791"}.fa-dice:before{content:"\f522"}.fa-dice-d20:before{content:"\f6cf"}.fa-dice-d6:before{content:"\f6d1"}.fa-dice-five:before{content:"\f523"}.fa-dice-four:before{content:"\f524"}.fa-dice-one:before{content:"\f525"}.fa-dice-six:before{content:"\f526"}.fa-dice-three:before{content:"\f527"}.fa-dice-two:before{content:"\f528"}.fa-digg:before{content:"\f1a6"}.fa-digital-ocean:before{content:"\f391"}.fa-digital-tachograph:before{content:"\f566"}.fa-directions:before{content:"\f5eb"}.fa-discord:before{content:"\f392"}.fa-discourse:before{content:"\f393"}.fa-divide:before{content:"\f529"}.fa-dizzy:before{content:"\f567"}.fa-dna:before{content:"\f471"}.fa-dochub:before{content:"\f394"}.fa-docker:before{content:"\f395"}.fa-dog:before{content:"\f6d3"}.fa-dollar-sign:before{content:"\f155"}.fa-dolly:before{content:"\f472"}.fa-dolly-flatbed:before{content:"\f474"}.fa-donate:before{content:"\f4b9"}.fa-door-closed:before{content:"\f52a"}.fa-door-open:before{content:"\f52b"}.fa-dot-circle:before{content:"\f192"}.fa-dove:before{content:"\f4ba"}.fa-download:before{content:"\f019"}.fa-draft2digital:before{content:"\f396"}.fa-drafting-compass:before{content:"\f568"}.fa-dragon:before{content:"\f6d5"}.fa-draw-polygon:before{content:"\f5ee"}.fa-dribbble:before{content:"\f17d"}.fa-dribbble-square:before{content:"\f397"}.fa-dropbox:before{content:"\f16b"}.fa-drum:before{content:"\f569"}.fa-drum-steelpan:before{content:"\f56a"}.fa-drumstick-bite:before{content:"\f6d7"}.fa-drupal:before{content:"\f1a9"}.fa-dumbbell:before{content:"\f44b"}.fa-dumpster:before{content:"\f793"}.fa-dumpster-fire:before{content:"\f794"}.fa-dungeon:before{content:"\f6d9"}.fa-dyalog:before{content:"\f399"}.fa-earlybirds:before{content:"\f39a"}.fa-ebay:before{content:"\f4f4"}.fa-edge:before{content:"\f282"}.fa-edit:before{content:"\f044"}.fa-egg:before{content:"\f7fb"}.fa-eject:before{content:"\f052"}.fa-elementor:before{content:"\f430"}.fa-ellipsis-h:before{content:"\f141"}.fa-ellipsis-v:before{content:"\f142"}.fa-ello:before{content:"\f5f1"}.fa-ember:before{content:"\f423"}.fa-empire:before{content:"\f1d1"}.fa-envelope:before{content:"\f0e0"}.fa-envelope-open:before{content:"\f2b6"}.fa-envelope-open-text:before{content:"\f658"}.fa-envelope-square:before{content:"\f199"}.fa-envira:before{content:"\f299"}.fa-equals:before{content:"\f52c"}.fa-eraser:before{content:"\f12d"}.fa-erlang:before{content:"\f39d"}.fa-ethereum:before{content:"\f42e"}.fa-ethernet:before{content:"\f796"}.fa-etsy:before{content:"\f2d7"}.fa-euro-sign:before{content:"\f153"}.fa-exchange-alt:before{content:"\f362"}.fa-exclamation:before{content:"\f12a"}.fa-exclamation-circle:before{content:"\f06a"}.fa-exclamation-triangle:before{content:"\f071"}.fa-expand:before{content:"\f065"}.fa-expand-arrows-alt:before{content:"\f31e"}.fa-expeditedssl:before{content:"\f23e"}.fa-external-link-alt:before{content:"\f35d"}.fa-external-link-square-alt:before{content:"\f360"}.fa-eye:before{content:"\f06e"}.fa-eye-dropper:before{content:"\f1fb"}.fa-eye-slash:before{content:"\f070"}.fa-facebook:before{content:"\f09a"}.fa-facebook-f:before{content:"\f39e"}.fa-facebook-messenger:before{content:"\f39f"}.fa-facebook-square:before{content:"\f082"}.fa-fantasy-flight-games:before{content:"\f6dc"}.fa-fast-backward:before{content:"\f049"}.fa-fast-forward:before{content:"\f050"}.fa-fax:before{content:"\f1ac"}.fa-feather:before{content:"\f52d"}.fa-feather-alt:before{content:"\f56b"}.fa-fedex:before{content:"\f797"}.fa-fedora:before{content:"\f798"}.fa-female:before{content:"\f182"}.fa-fighter-jet:before{content:"\f0fb"}.fa-figma:before{content:"\f799"}.fa-file:before{content:"\f15b"}.fa-file-alt:before{content:"\f15c"}.fa-file-archive:before{content:"\f1c6"}.fa-file-audio:before{content:"\f1c7"}.fa-file-code:before{content:"\f1c9"}.fa-file-contract:before{content:"\f56c"}.fa-file-csv:before{content:"\f6dd"}.fa-file-download:before{content:"\f56d"}.fa-file-excel:before{content:"\f1c3"}.fa-file-export:before{content:"\f56e"}.fa-file-image:before{content:"\f1c5"}.fa-file-import:before{content:"\f56f"}.fa-file-invoice:before{content:"\f570"}.fa-file-invoice-dollar:before{content:"\f571"}.fa-file-medical:before{content:"\f477"}.fa-file-medical-alt:before{content:"\f478"}.fa-file-pdf:before{content:"\f1c1"}.fa-file-powerpoint:before{content:"\f1c4"}.fa-file-prescription:before{content:"\f572"}.fa-file-signature:before{content:"\f573"}.fa-file-upload:before{content:"\f574"}.fa-file-video:before{content:"\f1c8"}.fa-file-word:before{content:"\f1c2"}.fa-fill:before{content:"\f575"}.fa-fill-drip:before{content:"\f576"}.fa-film:before{content:"\f008"}.fa-filter:before{content:"\f0b0"}.fa-fingerprint:before{content:"\f577"}.fa-fire:before{content:"\f06d"}.fa-fire-alt:before{content:"\f7e4"}.fa-fire-extinguisher:before{content:"\f134"}.fa-firefox:before{content:"\f269"}.fa-first-aid:before{content:"\f479"}.fa-first-order:before{content:"\f2b0"}.fa-first-order-alt:before{content:"\f50a"}.fa-firstdraft:before{content:"\f3a1"}.fa-fish:before{content:"\f578"}.fa-fist-raised:before{content:"\f6de"}.fa-flag:before{content:"\f024"}.fa-flag-checkered:before{content:"\f11e"}.fa-flag-usa:before{content:"\f74d"}.fa-flask:before{content:"\f0c3"}.fa-flickr:before{content:"\f16e"}.fa-flipboard:before{content:"\f44d"}.fa-flushed:before{content:"\f579"}.fa-fly:before{content:"\f417"}.fa-folder:before{content:"\f07b"}.fa-folder-minus:before{content:"\f65d"}.fa-folder-open:before{content:"\f07c"}.fa-folder-plus:before{content:"\f65e"}.fa-font:before{content:"\f031"}.fa-font-awesome:before{content:"\f2b4"}.fa-font-awesome-alt:before{content:"\f35c"}.fa-font-awesome-flag:before{content:"\f425"}.fa-font-awesome-logo-full:before{content:"\f4e6"}.fa-fonticons:before{content:"\f280"}.fa-fonticons-fi:before{content:"\f3a2"}.fa-football-ball:before{content:"\f44e"}.fa-fort-awesome:before{content:"\f286"}.fa-fort-awesome-alt:before{content:"\f3a3"}.fa-forumbee:before{content:"\f211"}.fa-forward:before{content:"\f04e"}.fa-foursquare:before{content:"\f180"}.fa-free-code-camp:before{content:"\f2c5"}.fa-freebsd:before{content:"\f3a4"}.fa-frog:before{content:"\f52e"}.fa-frown:before{content:"\f119"}.fa-frown-open:before{content:"\f57a"}.fa-fulcrum:before{content:"\f50b"}.fa-funnel-dollar:before{content:"\f662"}.fa-futbol:before{content:"\f1e3"}.fa-galactic-republic:before{content:"\f50c"}.fa-galactic-senate:before{content:"\f50d"}.fa-gamepad:before{content:"\f11b"}.fa-gas-pump:before{content:"\f52f"}.fa-gavel:before{content:"\f0e3"}.fa-gem:before{content:"\f3a5"}.fa-genderless:before{content:"\f22d"}.fa-get-pocket:before{content:"\f265"}.fa-gg:before{content:"\f260"}.fa-gg-circle:before{content:"\f261"}.fa-ghost:before{content:"\f6e2"}.fa-gift:before{content:"\f06b"}.fa-gifts:before{content:"\f79c"}.fa-git:before{content:"\f1d3"}.fa-git-square:before{content:"\f1d2"}.fa-github:before{content:"\f09b"}.fa-github-alt:before{content:"\f113"}.fa-github-square:before{content:"\f092"}.fa-gitkraken:before{content:"\f3a6"}.fa-gitlab:before{content:"\f296"}.fa-gitter:before{content:"\f426"}.fa-glass-cheers:before{content:"\f79f"}.fa-glass-martini:before{content:"\f000"}.fa-glass-martini-alt:before{content:"\f57b"}.fa-glass-whiskey:before{content:"\f7a0"}.fa-glasses:before{content:"\f530"}.fa-glide:before{content:"\f2a5"}.fa-glide-g:before{content:"\f2a6"}.fa-globe:before{content:"\f0ac"}.fa-globe-africa:before{content:"\f57c"}.fa-globe-americas:before{content:"\f57d"}.fa-globe-asia:before{content:"\f57e"}.fa-globe-europe:before{content:"\f7a2"}.fa-gofore:before{content:"\f3a7"}.fa-golf-ball:before{content:"\f450"}.fa-goodreads:before{content:"\f3a8"}.fa-goodreads-g:before{content:"\f3a9"}.fa-google:before{content:"\f1a0"}.fa-google-drive:before{content:"\f3aa"}.fa-google-play:before{content:"\f3ab"}.fa-google-plus:before{content:"\f2b3"}.fa-google-plus-g:before{content:"\f0d5"}.fa-google-plus-square:before{content:"\f0d4"}.fa-google-wallet:before{content:"\f1ee"}.fa-gopuram:before{content:"\f664"}.fa-graduation-cap:before{content:"\f19d"}.fa-gratipay:before{content:"\f184"}.fa-grav:before{content:"\f2d6"}.fa-greater-than:before{content:"\f531"}.fa-greater-than-equal:before{content:"\f532"}.fa-grimace:before{content:"\f57f"}.fa-grin:before{content:"\f580"}.fa-grin-alt:before{content:"\f581"}.fa-grin-beam:before{content:"\f582"}.fa-grin-beam-sweat:before{content:"\f583"}.fa-grin-hearts:before{content:"\f584"}.fa-grin-squint:before{content:"\f585"}.fa-grin-squint-tears:before{content:"\f586"}.fa-grin-stars:before{content:"\f587"}.fa-grin-tears:before{content:"\f588"}.fa-grin-tongue:before{content:"\f589"}.fa-grin-tongue-squint:before{content:"\f58a"}.fa-grin-tongue-wink:before{content:"\f58b"}.fa-grin-wink:before{content:"\f58c"}.fa-grip-horizontal:before{content:"\f58d"}.fa-grip-lines:before{content:"\f7a4"}.fa-grip-lines-vertical:before{content:"\f7a5"}.fa-grip-vertical:before{content:"\f58e"}.fa-gripfire:before{content:"\f3ac"}.fa-grunt:before{content:"\f3ad"}.fa-guitar:before{content:"\f7a6"}.fa-gulp:before{content:"\f3ae"}.fa-h-square:before{content:"\f0fd"}.fa-hacker-news:before{content:"\f1d4"}.fa-hacker-news-square:before{content:"\f3af"}.fa-hackerrank:before{content:"\f5f7"}.fa-hamburger:before{content:"\f805"}.fa-hammer:before{content:"\f6e3"}.fa-hamsa:before{content:"\f665"}.fa-hand-holding:before{content:"\f4bd"}.fa-hand-holding-heart:before{content:"\f4be"}.fa-hand-holding-usd:before{content:"\f4c0"}.fa-hand-lizard:before{content:"\f258"}.fa-hand-middle-finger:before{content:"\f806"}.fa-hand-paper:before{content:"\f256"}.fa-hand-peace:before{content:"\f25b"}.fa-hand-point-down:before{content:"\f0a7"}.fa-hand-point-left:before{content:"\f0a5"}.fa-hand-point-right:before{content:"\f0a4"}.fa-hand-point-up:before{content:"\f0a6"}.fa-hand-pointer:before{content:"\f25a"}.fa-hand-rock:before{content:"\f255"}.fa-hand-scissors:before{content:"\f257"}.fa-hand-spock:before{content:"\f259"}.fa-hands:before{content:"\f4c2"}.fa-hands-helping:before{content:"\f4c4"}.fa-handshake:before{content:"\f2b5"}.fa-hanukiah:before{content:"\f6e6"}.fa-hard-hat:before{content:"\f807"}.fa-hashtag:before{content:"\f292"}.fa-hat-wizard:before{content:"\f6e8"}.fa-haykal:before{content:"\f666"}.fa-hdd:before{content:"\f0a0"}.fa-heading:before{content:"\f1dc"}.fa-headphones:before{content:"\f025"}.fa-headphones-alt:before{content:"\f58f"}.fa-headset:before{content:"\f590"}.fa-heart:before{content:"\f004"}.fa-heart-broken:before{content:"\f7a9"}.fa-heartbeat:before{content:"\f21e"}.fa-helicopter:before{content:"\f533"}.fa-highlighter:before{content:"\f591"}.fa-hiking:before{content:"\f6ec"}.fa-hippo:before{content:"\f6ed"}.fa-hips:before{content:"\f452"}.fa-hire-a-helper:before{content:"\f3b0"}.fa-history:before{content:"\f1da"}.fa-hockey-puck:before{content:"\f453"}.fa-holly-berry:before{content:"\f7aa"}.fa-home:before{content:"\f015"}.fa-hooli:before{content:"\f427"}.fa-hornbill:before{content:"\f592"}.fa-horse:before{content:"\f6f0"}.fa-horse-head:before{content:"\f7ab"}.fa-hospital:before{content:"\f0f8"}.fa-hospital-alt:before{content:"\f47d"}.fa-hospital-symbol:before{content:"\f47e"}.fa-hot-tub:before{content:"\f593"}.fa-hotdog:before{content:"\f80f"}.fa-hotel:before{content:"\f594"}.fa-hotjar:before{content:"\f3b1"}.fa-hourglass:before{content:"\f254"}.fa-hourglass-end:before{content:"\f253"}.fa-hourglass-half:before{content:"\f252"}.fa-hourglass-start:before{content:"\f251"}.fa-house-damage:before{content:"\f6f1"}.fa-houzz:before{content:"\f27c"}.fa-hryvnia:before{content:"\f6f2"}.fa-html5:before{content:"\f13b"}.fa-hubspot:before{content:"\f3b2"}.fa-i-cursor:before{content:"\f246"}.fa-ice-cream:before{content:"\f810"}.fa-icicles:before{content:"\f7ad"}.fa-id-badge:before{content:"\f2c1"}.fa-id-card:before{content:"\f2c2"}.fa-id-card-alt:before{content:"\f47f"}.fa-igloo:before{content:"\f7ae"}.fa-image:before{content:"\f03e"}.fa-images:before{content:"\f302"}.fa-imdb:before{content:"\f2d8"}.fa-inbox:before{content:"\f01c"}.fa-indent:before{content:"\f03c"}.fa-industry:before{content:"\f275"}.fa-infinity:before{content:"\f534"}.fa-info:before{content:"\f129"}.fa-info-circle:before{content:"\f05a"}.fa-instagram:before{content:"\f16d"}.fa-intercom:before{content:"\f7af"}.fa-internet-explorer:before{content:"\f26b"}.fa-invision:before{content:"\f7b0"}.fa-ioxhost:before{content:"\f208"}.fa-italic:before{content:"\f033"}.fa-itunes:before{content:"\f3b4"}.fa-itunes-note:before{content:"\f3b5"}.fa-java:before{content:"\f4e4"}.fa-jedi:before{content:"\f669"}.fa-jedi-order:before{content:"\f50e"}.fa-jenkins:before{content:"\f3b6"}.fa-jira:before{content:"\f7b1"}.fa-joget:before{content:"\f3b7"}.fa-joint:before{content:"\f595"}.fa-joomla:before{content:"\f1aa"}.fa-journal-whills:before{content:"\f66a"}.fa-js:before{content:"\f3b8"}.fa-js-square:before{content:"\f3b9"}.fa-jsfiddle:before{content:"\f1cc"}.fa-kaaba:before{content:"\f66b"}.fa-kaggle:before{content:"\f5fa"}.fa-key:before{content:"\f084"}.fa-keybase:before{content:"\f4f5"}.fa-keyboard:before{content:"\f11c"}.fa-keycdn:before{content:"\f3ba"}.fa-khanda:before{content:"\f66d"}.fa-kickstarter:before{content:"\f3bb"}.fa-kickstarter-k:before{content:"\f3bc"}.fa-kiss:before{content:"\f596"}.fa-kiss-beam:before{content:"\f597"}.fa-kiss-wink-heart:before{content:"\f598"}.fa-kiwi-bird:before{content:"\f535"}.fa-korvue:before{content:"\f42f"}.fa-landmark:before{content:"\f66f"}.fa-language:before{content:"\f1ab"}.fa-laptop:before{content:"\f109"}.fa-laptop-code:before{content:"\f5fc"}.fa-laptop-medical:before{content:"\f812"}.fa-laravel:before{content:"\f3bd"}.fa-lastfm:before{content:"\f202"}.fa-lastfm-square:before{content:"\f203"}.fa-laugh:before{content:"\f599"}.fa-laugh-beam:before{content:"\f59a"}.fa-laugh-squint:before{content:"\f59b"}.fa-laugh-wink:before{content:"\f59c"}.fa-layer-group:before{content:"\f5fd"}.fa-leaf:before{content:"\f06c"}.fa-leanpub:before{content:"\f212"}.fa-lemon:before{content:"\f094"}.fa-less:before{content:"\f41d"}.fa-less-than:before{content:"\f536"}.fa-less-than-equal:before{content:"\f537"}.fa-level-down-alt:before{content:"\f3be"}.fa-level-up-alt:before{content:"\f3bf"}.fa-life-ring:before{content:"\f1cd"}.fa-lightbulb:before{content:"\f0eb"}.fa-line:before{content:"\f3c0"}.fa-link:before{content:"\f0c1"}.fa-linkedin:before{content:"\f08c"}.fa-linkedin-in:before{content:"\f0e1"}.fa-linode:before{content:"\f2b8"}.fa-linux:before{content:"\f17c"}.fa-lira-sign:before{content:"\f195"}.fa-list:before{content:"\f03a"}.fa-list-alt:before{content:"\f022"}.fa-list-ol:before{content:"\f0cb"}.fa-list-ul:before{content:"\f0ca"}.fa-location-arrow:before{content:"\f124"}.fa-lock:before{content:"\f023"}.fa-lock-open:before{content:"\f3c1"}.fa-long-arrow-alt-down:before{content:"\f309"}.fa-long-arrow-alt-left:before{content:"\f30a"}.fa-long-arrow-alt-right:before{content:"\f30b"}.fa-long-arrow-alt-up:before{content:"\f30c"}.fa-low-vision:before{content:"\f2a8"}.fa-luggage-cart:before{content:"\f59d"}.fa-lyft:before{content:"\f3c3"}.fa-magento:before{content:"\f3c4"}.fa-magic:before{content:"\f0d0"}.fa-magnet:before{content:"\f076"}.fa-mail-bulk:before{content:"\f674"}.fa-mailchimp:before{content:"\f59e"}.fa-male:before{content:"\f183"}.fa-mandalorian:before{content:"\f50f"}.fa-map:before{content:"\f279"}.fa-map-marked:before{content:"\f59f"}.fa-map-marked-alt:before{content:"\f5a0"}.fa-map-marker:before{content:"\f041"}.fa-map-marker-alt:before{content:"\f3c5"}.fa-map-pin:before{content:"\f276"}.fa-map-signs:before{content:"\f277"}.fa-markdown:before{content:"\f60f"}.fa-marker:before{content:"\f5a1"}.fa-mars:before{content:"\f222"}.fa-mars-double:before{content:"\f227"}.fa-mars-stroke:before{content:"\f229"}.fa-mars-stroke-h:before{content:"\f22b"}.fa-mars-stroke-v:before{content:"\f22a"}.fa-mask:before{content:"\f6fa"}.fa-mastodon:before{content:"\f4f6"}.fa-maxcdn:before{content:"\f136"}.fa-medal:before{content:"\f5a2"}.fa-medapps:before{content:"\f3c6"}.fa-medium:before{content:"\f23a"}.fa-medium-m:before{content:"\f3c7"}.fa-medkit:before{content:"\f0fa"}.fa-medrt:before{content:"\f3c8"}.fa-meetup:before{content:"\f2e0"}.fa-megaport:before{content:"\f5a3"}.fa-meh:before{content:"\f11a"}.fa-meh-blank:before{content:"\f5a4"}.fa-meh-rolling-eyes:before{content:"\f5a5"}.fa-memory:before{content:"\f538"}.fa-mendeley:before{content:"\f7b3"}.fa-menorah:before{content:"\f676"}.fa-mercury:before{content:"\f223"}.fa-meteor:before{content:"\f753"}.fa-microchip:before{content:"\f2db"}.fa-microphone:before{content:"\f130"}.fa-microphone-alt:before{content:"\f3c9"}.fa-microphone-alt-slash:before{content:"\f539"}.fa-microphone-slash:before{content:"\f131"}.fa-microscope:before{content:"\f610"}.fa-microsoft:before{content:"\f3ca"}.fa-minus:before{content:"\f068"}.fa-minus-circle:before{content:"\f056"}.fa-minus-square:before{content:"\f146"}.fa-mitten:before{content:"\f7b5"}.fa-mix:before{content:"\f3cb"}.fa-mixcloud:before{content:"\f289"}.fa-mizuni:before{content:"\f3cc"}.fa-mobile:before{content:"\f10b"}.fa-mobile-alt:before{content:"\f3cd"}.fa-modx:before{content:"\f285"}.fa-monero:before{content:"\f3d0"}.fa-money-bill:before{content:"\f0d6"}.fa-money-bill-alt:before{content:"\f3d1"}.fa-money-bill-wave:before{content:"\f53a"}.fa-money-bill-wave-alt:before{content:"\f53b"}.fa-money-check:before{content:"\f53c"}.fa-money-check-alt:before{content:"\f53d"}.fa-monument:before{content:"\f5a6"}.fa-moon:before{content:"\f186"}.fa-mortar-pestle:before{content:"\f5a7"}.fa-mosque:before{content:"\f678"}.fa-motorcycle:before{content:"\f21c"}.fa-mountain:before{content:"\f6fc"}.fa-mouse-pointer:before{content:"\f245"}.fa-mug-hot:before{content:"\f7b6"}.fa-music:before{content:"\f001"}.fa-napster:before{content:"\f3d2"}.fa-neos:before{content:"\f612"}.fa-network-wired:before{content:"\f6ff"}.fa-neuter:before{content:"\f22c"}.fa-newspaper:before{content:"\f1ea"}.fa-nimblr:before{content:"\f5a8"}.fa-nintendo-switch:before{content:"\f418"}.fa-node:before{content:"\f419"}.fa-node-js:before{content:"\f3d3"}.fa-not-equal:before{content:"\f53e"}.fa-notes-medical:before{content:"\f481"}.fa-npm:before{content:"\f3d4"}.fa-ns8:before{content:"\f3d5"}.fa-nutritionix:before{content:"\f3d6"}.fa-object-group:before{content:"\f247"}.fa-object-ungroup:before{content:"\f248"}.fa-odnoklassniki:before{content:"\f263"}.fa-odnoklassniki-square:before{content:"\f264"}.fa-oil-can:before{content:"\f613"}.fa-old-republic:before{content:"\f510"}.fa-om:before{content:"\f679"}.fa-opencart:before{content:"\f23d"}.fa-openid:before{content:"\f19b"}.fa-opera:before{content:"\f26a"}.fa-optin-monster:before{content:"\f23c"}.fa-osi:before{content:"\f41a"}.fa-otter:before{content:"\f700"}.fa-outdent:before{content:"\f03b"}.fa-page4:before{content:"\f3d7"}.fa-pagelines:before{content:"\f18c"}.fa-pager:before{content:"\f815"}.fa-paint-brush:before{content:"\f1fc"}.fa-paint-roller:before{content:"\f5aa"}.fa-palette:before{content:"\f53f"}.fa-palfed:before{content:"\f3d8"}.fa-pallet:before{content:"\f482"}.fa-paper-plane:before{content:"\f1d8"}.fa-paperclip:before{content:"\f0c6"}.fa-parachute-box:before{content:"\f4cd"}.fa-paragraph:before{content:"\f1dd"}.fa-parking:before{content:"\f540"}.fa-passport:before{content:"\f5ab"}.fa-pastafarianism:before{content:"\f67b"}.fa-paste:before{content:"\f0ea"}.fa-patreon:before{content:"\f3d9"}.fa-pause:before{content:"\f04c"}.fa-pause-circle:before{content:"\f28b"}.fa-paw:before{content:"\f1b0"}.fa-paypal:before{content:"\f1ed"}.fa-peace:before{content:"\f67c"}.fa-pen:before{content:"\f304"}.fa-pen-alt:before{content:"\f305"}.fa-pen-fancy:before{content:"\f5ac"}.fa-pen-nib:before{content:"\f5ad"}.fa-pen-square:before{content:"\f14b"}.fa-pencil-alt:before{content:"\f303"}.fa-pencil-ruler:before{content:"\f5ae"}.fa-penny-arcade:before{content:"\f704"}.fa-people-carry:before{content:"\f4ce"}.fa-pepper-hot:before{content:"\f816"}.fa-percent:before{content:"\f295"}.fa-percentage:before{content:"\f541"}.fa-periscope:before{content:"\f3da"}.fa-person-booth:before{content:"\f756"}.fa-phabricator:before{content:"\f3db"}.fa-phoenix-framework:before{content:"\f3dc"}.fa-phoenix-squadron:before{content:"\f511"}.fa-phone:before{content:"\f095"}.fa-phone-slash:before{content:"\f3dd"}.fa-phone-square:before{content:"\f098"}.fa-phone-volume:before{content:"\f2a0"}.fa-php:before{content:"\f457"}.fa-pied-piper:before{content:"\f2ae"}.fa-pied-piper-alt:before{content:"\f1a8"}.fa-pied-piper-hat:before{content:"\f4e5"}.fa-pied-piper-pp:before{content:"\f1a7"}.fa-piggy-bank:before{content:"\f4d3"}.fa-pills:before{content:"\f484"}.fa-pinterest:before{content:"\f0d2"}.fa-pinterest-p:before{content:"\f231"}.fa-pinterest-square:before{content:"\f0d3"}.fa-pizza-slice:before{content:"\f818"}.fa-place-of-worship:before{content:"\f67f"}.fa-plane:before{content:"\f072"}.fa-plane-arrival:before{content:"\f5af"}.fa-plane-departure:before{content:"\f5b0"}.fa-play:before{content:"\f04b"}.fa-play-circle:before{content:"\f144"}.fa-playstation:before{content:"\f3df"}.fa-plug:before{content:"\f1e6"}.fa-plus:before{content:"\f067"}.fa-plus-circle:before{content:"\f055"}.fa-plus-square:before{content:"\f0fe"}.fa-podcast:before{content:"\f2ce"}.fa-poll:before{content:"\f681"}.fa-poll-h:before{content:"\f682"}.fa-poo:before{content:"\f2fe"}.fa-poo-storm:before{content:"\f75a"}.fa-poop:before{content:"\f619"}.fa-portrait:before{content:"\f3e0"}.fa-pound-sign:before{content:"\f154"}.fa-power-off:before{content:"\f011"}.fa-pray:before{content:"\f683"}.fa-praying-hands:before{content:"\f684"}.fa-prescription:before{content:"\f5b1"}.fa-prescription-bottle:before{content:"\f485"}.fa-prescription-bottle-alt:before{content:"\f486"}.fa-print:before{content:"\f02f"}.fa-procedures:before{content:"\f487"}.fa-product-hunt:before{content:"\f288"}.fa-project-diagram:before{content:"\f542"}.fa-pushed:before{content:"\f3e1"}.fa-puzzle-piece:before{content:"\f12e"}.fa-python:before{content:"\f3e2"}.fa-qq:before{content:"\f1d6"}.fa-qrcode:before{content:"\f029"}.fa-question:before{content:"\f128"}.fa-question-circle:before{content:"\f059"}.fa-quidditch:before{content:"\f458"}.fa-quinscape:before{content:"\f459"}.fa-quora:before{content:"\f2c4"}.fa-quote-left:before{content:"\f10d"}.fa-quote-right:before{content:"\f10e"}.fa-quran:before{content:"\f687"}.fa-r-project:before{content:"\f4f7"}.fa-radiation:before{content:"\f7b9"}.fa-radiation-alt:before{content:"\f7ba"}.fa-rainbow:before{content:"\f75b"}.fa-random:before{content:"\f074"}.fa-raspberry-pi:before{content:"\f7bb"}.fa-ravelry:before{content:"\f2d9"}.fa-react:before{content:"\f41b"}.fa-reacteurope:before{content:"\f75d"}.fa-readme:before{content:"\f4d5"}.fa-rebel:before{content:"\f1d0"}.fa-receipt:before{content:"\f543"}.fa-recycle:before{content:"\f1b8"}.fa-red-river:before{content:"\f3e3"}.fa-reddit:before{content:"\f1a1"}.fa-reddit-alien:before{content:"\f281"}.fa-reddit-square:before{content:"\f1a2"}.fa-redhat:before{content:"\f7bc"}.fa-redo:before{content:"\f01e"}.fa-redo-alt:before{content:"\f2f9"}.fa-registered:before{content:"\f25d"}.fa-renren:before{content:"\f18b"}.fa-reply:before{content:"\f3e5"}.fa-reply-all:before{content:"\f122"}.fa-replyd:before{content:"\f3e6"}.fa-republican:before{content:"\f75e"}.fa-researchgate:before{content:"\f4f8"}.fa-resolving:before{content:"\f3e7"}.fa-restroom:before{content:"\f7bd"}.fa-retweet:before{content:"\f079"}.fa-rev:before{content:"\f5b2"}.fa-ribbon:before{content:"\f4d6"}.fa-ring:before{content:"\f70b"}.fa-road:before{content:"\f018"}.fa-robot:before{content:"\f544"}.fa-rocket:before{content:"\f135"}.fa-rocketchat:before{content:"\f3e8"}.fa-rockrms:before{content:"\f3e9"}.fa-route:before{content:"\f4d7"}.fa-rss:before{content:"\f09e"}.fa-rss-square:before{content:"\f143"}.fa-ruble-sign:before{content:"\f158"}.fa-ruler:before{content:"\f545"}.fa-ruler-combined:before{content:"\f546"}.fa-ruler-horizontal:before{content:"\f547"}.fa-ruler-vertical:before{content:"\f548"}.fa-running:before{content:"\f70c"}.fa-rupee-sign:before{content:"\f156"}.fa-sad-cry:before{content:"\f5b3"}.fa-sad-tear:before{content:"\f5b4"}.fa-safari:before{content:"\f267"}.fa-sass:before{content:"\f41e"}.fa-satellite:before{content:"\f7bf"}.fa-satellite-dish:before{content:"\f7c0"}.fa-save:before{content:"\f0c7"}.fa-schlix:before{content:"\f3ea"}.fa-school:before{content:"\f549"}.fa-screwdriver:before{content:"\f54a"}.fa-scribd:before{content:"\f28a"}.fa-scroll:before{content:"\f70e"}.fa-sd-card:before{content:"\f7c2"}.fa-search:before{content:"\f002"}.fa-search-dollar:before{content:"\f688"}.fa-search-location:before{content:"\f689"}.fa-search-minus:before{content:"\f010"}.fa-search-plus:before{content:"\f00e"}.fa-searchengin:before{content:"\f3eb"}.fa-seedling:before{content:"\f4d8"}.fa-sellcast:before{content:"\f2da"}.fa-sellsy:before{content:"\f213"}.fa-server:before{content:"\f233"}.fa-servicestack:before{content:"\f3ec"}.fa-shapes:before{content:"\f61f"}.fa-share:before{content:"\f064"}.fa-share-alt:before{content:"\f1e0"}.fa-share-alt-square:before{content:"\f1e1"}.fa-share-square:before{content:"\f14d"}.fa-shekel-sign:before{content:"\f20b"}.fa-shield-alt:before{content:"\f3ed"}.fa-ship:before{content:"\f21a"}.fa-shipping-fast:before{content:"\f48b"}.fa-shirtsinbulk:before{content:"\f214"}.fa-shoe-prints:before{content:"\f54b"}.fa-shopping-bag:before{content:"\f290"}.fa-shopping-basket:before{content:"\f291"}.fa-shopping-cart:before{content:"\f07a"}.fa-shopware:before{content:"\f5b5"}.fa-shower:before{content:"\f2cc"}.fa-shuttle-van:before{content:"\f5b6"}.fa-sign:before{content:"\f4d9"}.fa-sign-in-alt:before{content:"\f2f6"}.fa-sign-language:before{content:"\f2a7"}.fa-sign-out-alt:before{content:"\f2f5"}.fa-signal:before{content:"\f012"}.fa-signature:before{content:"\f5b7"}.fa-sim-card:before{content:"\f7c4"}.fa-simplybuilt:before{content:"\f215"}.fa-sistrix:before{content:"\f3ee"}.fa-sitemap:before{content:"\f0e8"}.fa-sith:before{content:"\f512"}.fa-skating:before{content:"\f7c5"}.fa-sketch:before{content:"\f7c6"}.fa-skiing:before{content:"\f7c9"}.fa-skiing-nordic:before{content:"\f7ca"}.fa-skull:before{content:"\f54c"}.fa-skull-crossbones:before{content:"\f714"}.fa-skyatlas:before{content:"\f216"}.fa-skype:before{content:"\f17e"}.fa-slack:before{content:"\f198"}.fa-slack-hash:before{content:"\f3ef"}.fa-slash:before{content:"\f715"}.fa-sleigh:before{content:"\f7cc"}.fa-sliders-h:before{content:"\f1de"}.fa-slideshare:before{content:"\f1e7"}.fa-smile:before{content:"\f118"}.fa-smile-beam:before{content:"\f5b8"}.fa-smile-wink:before{content:"\f4da"}.fa-smog:before{content:"\f75f"}.fa-smoking:before{content:"\f48d"}.fa-smoking-ban:before{content:"\f54d"}.fa-sms:before{content:"\f7cd"}.fa-snapchat:before{content:"\f2ab"}.fa-snapchat-ghost:before{content:"\f2ac"}.fa-snapchat-square:before{content:"\f2ad"}.fa-snowboarding:before{content:"\f7ce"}.fa-snowflake:before{content:"\f2dc"}.fa-snowman:before{content:"\f7d0"}.fa-snowplow:before{content:"\f7d2"}.fa-socks:before{content:"\f696"}.fa-solar-panel:before{content:"\f5ba"}.fa-sort:before{content:"\f0dc"}.fa-sort-alpha-down:before{content:"\f15d"}.fa-sort-alpha-up:before{content:"\f15e"}.fa-sort-amount-down:before{content:"\f160"}.fa-sort-amount-up:before{content:"\f161"}.fa-sort-down:before{content:"\f0dd"}.fa-sort-numeric-down:before{content:"\f162"}.fa-sort-numeric-up:before{content:"\f163"}.fa-sort-up:before{content:"\f0de"}.fa-soundcloud:before{content:"\f1be"}.fa-sourcetree:before{content:"\f7d3"}.fa-spa:before{content:"\f5bb"}.fa-space-shuttle:before{content:"\f197"}.fa-speakap:before{content:"\f3f3"}.fa-spider:before{content:"\f717"}.fa-spinner:before{content:"\f110"}.fa-splotch:before{content:"\f5bc"}.fa-spotify:before{content:"\f1bc"}.fa-spray-can:before{content:"\f5bd"}.fa-square:before{content:"\f0c8"}.fa-square-full:before{content:"\f45c"}.fa-square-root-alt:before{content:"\f698"}.fa-squarespace:before{content:"\f5be"}.fa-stack-exchange:before{content:"\f18d"}.fa-stack-overflow:before{content:"\f16c"}.fa-stamp:before{content:"\f5bf"}.fa-star:before{content:"\f005"}.fa-star-and-crescent:before{content:"\f699"}.fa-star-half:before{content:"\f089"}.fa-star-half-alt:before{content:"\f5c0"}.fa-star-of-david:before{content:"\f69a"}.fa-star-of-life:before{content:"\f621"}.fa-staylinked:before{content:"\f3f5"}.fa-steam:before{content:"\f1b6"}.fa-steam-square:before{content:"\f1b7"}.fa-steam-symbol:before{content:"\f3f6"}.fa-step-backward:before{content:"\f048"}.fa-step-forward:before{content:"\f051"}.fa-stethoscope:before{content:"\f0f1"}.fa-sticker-mule:before{content:"\f3f7"}.fa-sticky-note:before{content:"\f249"}.fa-stop:before{content:"\f04d"}.fa-stop-circle:before{content:"\f28d"}.fa-stopwatch:before{content:"\f2f2"}.fa-store:before{content:"\f54e"}.fa-store-alt:before{content:"\f54f"}.fa-strava:before{content:"\f428"}.fa-stream:before{content:"\f550"}.fa-street-view:before{content:"\f21d"}.fa-strikethrough:before{content:"\f0cc"}.fa-stripe:before{content:"\f429"}.fa-stripe-s:before{content:"\f42a"}.fa-stroopwafel:before{content:"\f551"}.fa-studiovinari:before{content:"\f3f8"}.fa-stumbleupon:before{content:"\f1a4"}.fa-stumbleupon-circle:before{content:"\f1a3"}.fa-subscript:before{content:"\f12c"}.fa-subway:before{content:"\f239"}.fa-suitcase:before{content:"\f0f2"}.fa-suitcase-rolling:before{content:"\f5c1"}.fa-sun:before{content:"\f185"}.fa-superpowers:before{content:"\f2dd"}.fa-superscript:before{content:"\f12b"}.fa-supple:before{content:"\f3f9"}.fa-surprise:before{content:"\f5c2"}.fa-suse:before{content:"\f7d6"}.fa-swatchbook:before{content:"\f5c3"}.fa-swimmer:before{content:"\f5c4"}.fa-swimming-pool:before{content:"\f5c5"}.fa-synagogue:before{content:"\f69b"}.fa-sync:before{content:"\f021"}.fa-sync-alt:before{content:"\f2f1"}.fa-syringe:before{content:"\f48e"}.fa-table:before{content:"\f0ce"}.fa-table-tennis:before{content:"\f45d"}.fa-tablet:before{content:"\f10a"}.fa-tablet-alt:before{content:"\f3fa"}.fa-tablets:before{content:"\f490"}.fa-tachometer-alt:before{content:"\f3fd"}.fa-tag:before{content:"\f02b"}.fa-tags:before{content:"\f02c"}.fa-tape:before{content:"\f4db"}.fa-tasks:before{content:"\f0ae"}.fa-taxi:before{content:"\f1ba"}.fa-teamspeak:before{content:"\f4f9"}.fa-teeth:before{content:"\f62e"}.fa-teeth-open:before{content:"\f62f"}.fa-telegram:before{content:"\f2c6"}.fa-telegram-plane:before{content:"\f3fe"}.fa-temperature-high:before{content:"\f769"}.fa-temperature-low:before{content:"\f76b"}.fa-tencent-weibo:before{content:"\f1d5"}.fa-tenge:before{content:"\f7d7"}.fa-terminal:before{content:"\f120"}.fa-text-height:before{content:"\f034"}.fa-text-width:before{content:"\f035"}.fa-th:before{content:"\f00a"}.fa-th-large:before{content:"\f009"}.fa-th-list:before{content:"\f00b"}.fa-the-red-yeti:before{content:"\f69d"}.fa-theater-masks:before{content:"\f630"}.fa-themeco:before{content:"\f5c6"}.fa-themeisle:before{content:"\f2b2"}.fa-thermometer:before{content:"\f491"}.fa-thermometer-empty:before{content:"\f2cb"}.fa-thermometer-full:before{content:"\f2c7"}.fa-thermometer-half:before{content:"\f2c9"}.fa-thermometer-quarter:before{content:"\f2ca"}.fa-thermometer-three-quarters:before{content:"\f2c8"}.fa-think-peaks:before{content:"\f731"}.fa-thumbs-down:before{content:"\f165"}.fa-thumbs-up:before{content:"\f164"}.fa-thumbtack:before{content:"\f08d"}.fa-ticket-alt:before{content:"\f3ff"}.fa-times:before{content:"\f00d"}.fa-times-circle:before{content:"\f057"}.fa-tint:before{content:"\f043"}.fa-tint-slash:before{content:"\f5c7"}.fa-tired:before{content:"\f5c8"}.fa-toggle-off:before{content:"\f204"}.fa-toggle-on:before{content:"\f205"}.fa-toilet:before{content:"\f7d8"}.fa-toilet-paper:before{content:"\f71e"}.fa-toolbox:before{content:"\f552"}.fa-tools:before{content:"\f7d9"}.fa-tooth:before{content:"\f5c9"}.fa-torah:before{content:"\f6a0"}.fa-torii-gate:before{content:"\f6a1"}.fa-tractor:before{content:"\f722"}.fa-trade-federation:before{content:"\f513"}.fa-trademark:before{content:"\f25c"}.fa-traffic-light:before{content:"\f637"}.fa-train:before{content:"\f238"}.fa-tram:before{content:"\f7da"}.fa-transgender:before{content:"\f224"}.fa-transgender-alt:before{content:"\f225"}.fa-trash:before{content:"\f1f8"}.fa-trash-alt:before{content:"\f2ed"}.fa-trash-restore:before{content:"\f829"}.fa-trash-restore-alt:before{content:"\f82a"}.fa-tree:before{content:"\f1bb"}.fa-trello:before{content:"\f181"}.fa-tripadvisor:before{content:"\f262"}.fa-trophy:before{content:"\f091"}.fa-truck:before{content:"\f0d1"}.fa-truck-loading:before{content:"\f4de"}.fa-truck-monster:before{content:"\f63b"}.fa-truck-moving:before{content:"\f4df"}.fa-truck-pickup:before{content:"\f63c"}.fa-tshirt:before{content:"\f553"}.fa-tty:before{content:"\f1e4"}.fa-tumblr:before{content:"\f173"}.fa-tumblr-square:before{content:"\f174"}.fa-tv:before{content:"\f26c"}.fa-twitch:before{content:"\f1e8"}.fa-twitter:before{content:"\f099"}.fa-twitter-square:before{content:"\f081"}.fa-typo3:before{content:"\f42b"}.fa-uber:before{content:"\f402"}.fa-ubuntu:before{content:"\f7df"}.fa-uikit:before{content:"\f403"}.fa-umbrella:before{content:"\f0e9"}.fa-umbrella-beach:before{content:"\f5ca"}.fa-underline:before{content:"\f0cd"}.fa-undo:before{content:"\f0e2"}.fa-undo-alt:before{content:"\f2ea"}.fa-uniregistry:before{content:"\f404"}.fa-universal-access:before{content:"\f29a"}.fa-university:before{content:"\f19c"}.fa-unlink:before{content:"\f127"}.fa-unlock:before{content:"\f09c"}.fa-unlock-alt:before{content:"\f13e"}.fa-untappd:before{content:"\f405"}.fa-upload:before{content:"\f093"}.fa-ups:before{content:"\f7e0"}.fa-usb:before{content:"\f287"}.fa-user:before{content:"\f007"}.fa-user-alt:before{content:"\f406"}.fa-user-alt-slash:before{content:"\f4fa"}.fa-user-astronaut:before{content:"\f4fb"}.fa-user-check:before{content:"\f4fc"}.fa-user-circle:before{content:"\f2bd"}.fa-user-clock:before{content:"\f4fd"}.fa-user-cog:before{content:"\f4fe"}.fa-user-edit:before{content:"\f4ff"}.fa-user-friends:before{content:"\f500"}.fa-user-graduate:before{content:"\f501"}.fa-user-injured:before{content:"\f728"}.fa-user-lock:before{content:"\f502"}.fa-user-md:before{content:"\f0f0"}.fa-user-minus:before{content:"\f503"}.fa-user-ninja:before{content:"\f504"}.fa-user-nurse:before{content:"\f82f"}.fa-user-plus:before{content:"\f234"}.fa-user-secret:before{content:"\f21b"}.fa-user-shield:before{content:"\f505"}.fa-user-slash:before{content:"\f506"}.fa-user-tag:before{content:"\f507"}.fa-user-tie:before{content:"\f508"}.fa-user-times:before{content:"\f235"}.fa-users:before{content:"\f0c0"}.fa-users-cog:before{content:"\f509"}.fa-usps:before{content:"\f7e1"}.fa-ussunnah:before{content:"\f407"}.fa-utensil-spoon:before{content:"\f2e5"}.fa-utensils:before{content:"\f2e7"}.fa-vaadin:before{content:"\f408"}.fa-vector-square:before{content:"\f5cb"}.fa-venus:before{content:"\f221"}.fa-venus-double:before{content:"\f226"}.fa-venus-mars:before{content:"\f228"}.fa-viacoin:before{content:"\f237"}.fa-viadeo:before{content:"\f2a9"}.fa-viadeo-square:before{content:"\f2aa"}.fa-vial:before{content:"\f492"}.fa-vials:before{content:"\f493"}.fa-viber:before{content:"\f409"}.fa-video:before{content:"\f03d"}.fa-video-slash:before{content:"\f4e2"}.fa-vihara:before{content:"\f6a7"}.fa-vimeo:before{content:"\f40a"}.fa-vimeo-square:before{content:"\f194"}.fa-vimeo-v:before{content:"\f27d"}.fa-vine:before{content:"\f1ca"}.fa-vk:before{content:"\f189"}.fa-vnv:before{content:"\f40b"}.fa-volleyball-ball:before{content:"\f45f"}.fa-volume-down:before{content:"\f027"}.fa-volume-mute:before{content:"\f6a9"}.fa-volume-off:before{content:"\f026"}.fa-volume-up:before{content:"\f028"}.fa-vote-yea:before{content:"\f772"}.fa-vr-cardboard:before{content:"\f729"}.fa-vuejs:before{content:"\f41f"}.fa-walking:before{content:"\f554"}.fa-wallet:before{content:"\f555"}.fa-warehouse:before{content:"\f494"}.fa-water:before{content:"\f773"}.fa-weebly:before{content:"\f5cc"}.fa-weibo:before{content:"\f18a"}.fa-weight:before{content:"\f496"}.fa-weight-hanging:before{content:"\f5cd"}.fa-weixin:before{content:"\f1d7"}.fa-whatsapp:before{content:"\f232"}.fa-whatsapp-square:before{content:"\f40c"}.fa-wheelchair:before{content:"\f193"}.fa-whmcs:before{content:"\f40d"}.fa-wifi:before{content:"\f1eb"}.fa-wikipedia-w:before{content:"\f266"}.fa-wind:before{content:"\f72e"}.fa-window-close:before{content:"\f410"}.fa-window-maximize:before{content:"\f2d0"}.fa-window-minimize:before{content:"\f2d1"}.fa-window-restore:before{content:"\f2d2"}.fa-windows:before{content:"\f17a"}.fa-wine-bottle:before{content:"\f72f"}.fa-wine-glass:before{content:"\f4e3"}.fa-wine-glass-alt:before{content:"\f5ce"}.fa-wix:before{content:"\f5cf"}.fa-wizards-of-the-coast:before{content:"\f730"}.fa-wolf-pack-battalion:before{content:"\f514"}.fa-won-sign:before{content:"\f159"}.fa-wordpress:before{content:"\f19a"}.fa-wordpress-simple:before{content:"\f411"}.fa-wpbeginner:before{content:"\f297"}.fa-wpexplorer:before{content:"\f2de"}.fa-wpforms:before{content:"\f298"}.fa-wpressr:before{content:"\f3e4"}.fa-wrench:before{content:"\f0ad"}.fa-x-ray:before{content:"\f497"}.fa-xbox:before{content:"\f412"}.fa-xing:before{content:"\f168"}.fa-xing-square:before{content:"\f169"}.fa-y-combinator:before{content:"\f23b"}.fa-yahoo:before{content:"\f19e"}.fa-yandex:before{content:"\f413"}.fa-yandex-international:before{content:"\f414"}.fa-yarn:before{content:"\f7e3"}.fa-yelp:before{content:"\f1e9"}.fa-yen-sign:before{content:"\f157"}.fa-yin-yang:before{content:"\f6ad"}.fa-yoast:before{content:"\f2b1"}.fa-youtube:before{content:"\f167"}.fa-youtube-square:before{content:"\f431"}.fa-zhihu:before{content:"\f63f"}.sr-only{border:0;clip:rect(0,0,0,0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.sr-only-focusable:active,.sr-only-focusable:focus{clip:auto;height:auto;margin:0;overflow:visible;position:static;width:auto}@font-face{font-family:"Font Awesome 5 Brands";font-style:normal;font-weight:normal;font-display:auto;src:url(../webfonts/fa-brands-400.eot);src:url(../webfonts/fa-brands-400.eot?#iefix) format("embedded-opentype"),url(../webfonts/fa-brands-400.woff2) format("woff2"),url(../webfonts/fa-brands-400.woff) format("woff"),url(../webfonts/fa-brands-400.ttf) format("truetype"),url(../webfonts/fa-brands-400.svg#fontawesome) format("svg")}.fab{font-family:"Font Awesome 5 Brands"}@font-face{font-family:"Font Awesome 5 Free";font-style:normal;font-weight:400;font-display:auto;src:url(../webfonts/fa-regular-400.eot);src:url(../webfonts/fa-regular-400.eot?#iefix) format("embedded-opentype"),url(../webfonts/fa-regular-400.woff2) format("woff2"),url(../webfonts/fa-regular-400.woff) format("woff"),url(../webfonts/fa-regular-400.ttf) format("truetype"),url(../webfonts/fa-regular-400.svg#fontawesome) format("svg")}.far{font-weight:400}@font-face{font-family:"Font Awesome 5 Free";font-style:normal;font-weight:900;font-display:auto;src:url(../webfonts/fa-solid-900.eot);src:url(../webfonts/fa-solid-900.eot?#iefix) format("embedded-opentype"),url(../webfonts/fa-solid-900.woff2) format("woff2"),url(../webfonts/fa-solid-900.woff) format("woff"),url(../webfonts/fa-solid-900.ttf) format("truetype"),url(../webfonts/fa-solid-900.svg#fontawesome) format("svg")}.fa,.far,.fas{font-family:"Font Awesome 5 Free"}.fa,.fas{font-weight:900} diff --git a/assets/css/fonts.css b/assets/css/fonts.css new file mode 100644 index 0000000..efeb3c2 --- /dev/null +++ b/assets/css/fonts.css @@ -0,0 +1,92 @@ +/* lato-regular - latin */ +@font-face { + font-family: 'Lato'; + font-style: normal; + font-weight: 400; + src: url('../fonts/lato-v17-latin/lato-v17-latin-regular.eot'); /* IE9 Compat Modes */ + src: local(''), + url('../fonts/lato-v17-latin/lato-v17-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ + url('../fonts/lato-v17-latin/lato-v17-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */ + url('../fonts/lato-v17-latin/lato-v17-latin-regular.woff') format('woff'), /* Modern Browsers */ + url('../fonts/lato-v17-latin/lato-v17-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */ + url('../fonts/lato-v17-latin/lato-v17-latin-regular.svg#Lato') format('svg'); /* Legacy iOS */ +} +/* lato-italic - latin */ +@font-face { + font-family: 'Lato Italic'; + font-style: italic; + font-weight: 400; + src: url('../fonts/lato-v17-latin/lato-v17-latin-italic.eot'); /* IE9 Compat Modes */ + src: local(''), + url('../fonts/lato-v17-latin/lato-v17-latin-italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ + url('../fonts/lato-v17-latin/lato-v17-latin-italic.woff2') format('woff2'), /* Super Modern Browsers */ + url('../fonts/lato-v17-latin/lato-v17-latin-italic.woff') format('woff'), /* Modern Browsers */ + url('../fonts/lato-v17-latin/lato-v17-latin-italic.ttf') format('truetype'), /* Safari, Android, iOS */ + url('../fonts/lato-v17-latin/lato-v17-latin-italic.svg#Lato') format('svg'); /* Legacy iOS */ +} +/* lato-700 - latin */ +@font-face { + font-family: 'Lato Bold'; + font-style: normal; + font-weight: 700; + src: url('../fonts/lato-v17-latin/lato-v17-latin-700.eot'); /* IE9 Compat Modes */ + src: local(''), + url('../fonts/lato-v17-latin/lato-v17-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ + url('../fonts/lato-v17-latin/lato-v17-latin-700.woff2') format('woff2'), /* Super Modern Browsers */ + url('../fonts/lato-v17-latin/lato-v17-latin-700.woff') format('woff'), /* Modern Browsers */ + url('../fonts/lato-v17-latin/lato-v17-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */ + url('../fonts/lato-v17-latin/lato-v17-latin-700.svg#Lato') format('svg'); /* Legacy iOS */ +} +/* lato-900 - latin */ +@font-face { + font-family: 'Lato Black'; + font-style: normal; + font-weight: 900; + src: url('../fonts/lato-v17-latin/lato-v17-latin-900.eot'); /* IE9 Compat Modes */ + src: local(''), + url('../fonts/lato-v17-latin/lato-v17-latin-900.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ + url('../fonts/lato-v17-latin/lato-v17-latin-900.woff2') format('woff2'), /* Super Modern Browsers */ + url('../fonts/lato-v17-latin/lato-v17-latin-900.woff') format('woff'), /* Modern Browsers */ + url('../fonts/lato-v17-latin/lato-v17-latin-900.ttf') format('truetype'), /* Safari, Android, iOS */ + url('../fonts/lato-v17-latin/lato-v17-latin-900.svg#Lato') format('svg'); /* Legacy iOS */ +} + +/* noto-serif-regular - latin */ +@font-face { + font-family: 'Noto Serif'; + font-style: normal; + font-weight: 400; + src: url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.eot'); /* IE9 Compat Modes */ + src: local(''), + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.woff') format('woff'), /* Modern Browsers */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-regular.svg#NotoSerif') format('svg'); /* Legacy iOS */ +} +/* noto-serif-italic - latin */ +@font-face { + font-family: 'Noto Serif Italic'; + font-style: italic; + font-weight: 400; + src: url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.eot'); /* IE9 Compat Modes */ + src: local(''), + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.woff2') format('woff2'), /* Super Modern Browsers */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.woff') format('woff'), /* Modern Browsers */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.ttf') format('truetype'), /* Safari, Android, iOS */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-italic.svg#NotoSerif') format('svg'); /* Legacy iOS */ +} +/* noto-serif-700 - latin */ +@font-face { + font-family: 'Noto Serif Bold'; + font-style: normal; + font-weight: 700; + src: url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.eot'); /* IE9 Compat Modes */ + src: local(''), + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.woff2') format('woff2'), /* Super Modern Browsers */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.woff') format('woff'), /* Modern Browsers */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */ + url('../fonts/noto-serif-v9-latin/noto-serif-v9-latin-700.svg#NotoSerif') format('svg'); /* Legacy iOS */ +} diff --git a/assets/css/images/arrow.svg b/assets/css/images/arrow.svg deleted file mode 100644 index 78f3ab3..0000000 --- a/assets/css/images/arrow.svg +++ /dev/null @@ -1,5 +0,0 @@ - - - - - \ No newline at end of file diff --git a/assets/css/images/ie/banner-overlay.png b/assets/css/images/ie/banner-overlay.png deleted file mode 100644 index e5d2492..0000000 --- a/assets/css/images/ie/banner-overlay.png +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:fe8e42238c5513cbb9f6eb93710da48809854341a34f33b2d23691311c8f7bbe -size 113 diff --git a/assets/css/images/layers-2x.png b/assets/css/images/layers-2x.png deleted file mode 100644 index d3cf7e5..0000000 --- a/assets/css/images/layers-2x.png +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:066daca850d8ffbef007af00b06eac0015728dee279c51f3cb6c716df7c42edf -size 1259 diff --git a/assets/css/images/layers.png b/assets/css/images/layers.png deleted file mode 100644 index 7b44754..0000000 --- a/assets/css/images/layers.png +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:1dbbe9d028e292f36fcba8f8b3a28d5e8932754fc2215b9ac69e4cdecf5107c6 -size 696 diff --git a/assets/css/images/marker-icon-2x.png b/assets/css/images/marker-icon-2x.png deleted file mode 100644 index 09e8445..0000000 --- a/assets/css/images/marker-icon-2x.png +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:00179c4c1ee830d3a108412ae0d294f55776cfeb085c60129a39aa6fc4ae2528 -size 2464 diff --git a/assets/css/images/marker-icon.png b/assets/css/images/marker-icon.png deleted file mode 100644 index b1789c7..0000000 --- a/assets/css/images/marker-icon.png +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:574c3a5cca85f4114085b6841596d62f00d7c892c7b03f28cbfa301deb1dc437 -size 1466 diff --git a/assets/css/images/marker-shadow.png b/assets/css/images/marker-shadow.png deleted file mode 100644 index dc11121..0000000 --- a/assets/css/images/marker-shadow.png +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:264f5c640339f042dd729062cfc04c17f8ea0f29882b538e3848ed8f10edb4da -size 618 diff --git a/assets/css/leaflet.css b/assets/css/leaflet.css deleted file mode 100644 index a0932d5..0000000 --- a/assets/css/leaflet.css +++ /dev/null @@ -1,635 +0,0 @@ -/* required styles */ - -.leaflet-pane, -.leaflet-tile, -.leaflet-marker-icon, -.leaflet-marker-shadow, -.leaflet-tile-container, -.leaflet-pane > svg, -.leaflet-pane > canvas, -.leaflet-zoom-box, -.leaflet-image-layer, -.leaflet-layer { - position: absolute; - left: 0; - top: 0; - } -.leaflet-container { - overflow: hidden; - } -.leaflet-tile, -.leaflet-marker-icon, -.leaflet-marker-shadow { - -webkit-user-select: none; - -moz-user-select: none; - user-select: none; - -webkit-user-drag: none; - } -/* Safari renders non-retina tile on retina better with this, but Chrome is worse */ -.leaflet-safari .leaflet-tile { - image-rendering: -webkit-optimize-contrast; - } -/* hack that prevents hw layers "stretching" when loading new tiles */ -.leaflet-safari .leaflet-tile-container { - width: 1600px; - height: 1600px; - -webkit-transform-origin: 0 0; - } -.leaflet-marker-icon, -.leaflet-marker-shadow { - display: block; - } -/* .leaflet-container svg: reset svg max-width decleration shipped in Joomla! (joomla.org) 3.x */ -/* .leaflet-container img: map is broken in FF if you have max-width: 100% on tiles */ -.leaflet-container .leaflet-overlay-pane svg, -.leaflet-container .leaflet-marker-pane img, -.leaflet-container .leaflet-shadow-pane img, -.leaflet-container .leaflet-tile-pane img, -.leaflet-container img.leaflet-image-layer, -.leaflet-container .leaflet-tile { - max-width: none !important; - max-height: none !important; - } - -.leaflet-container.leaflet-touch-zoom { - -ms-touch-action: pan-x pan-y; - touch-action: pan-x pan-y; - } -.leaflet-container.leaflet-touch-drag { - -ms-touch-action: pinch-zoom; - /* Fallback for FF which doesn't support pinch-zoom */ - touch-action: none; - touch-action: pinch-zoom; -} -.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom { - -ms-touch-action: none; - touch-action: none; -} -.leaflet-container { - -webkit-tap-highlight-color: transparent; -} -.leaflet-container a { - -webkit-tap-highlight-color: rgba(51, 181, 229, 0.4); -} -.leaflet-tile { - filter: inherit; - visibility: hidden; - } -.leaflet-tile-loaded { - visibility: inherit; - } -.leaflet-zoom-box { - width: 0; - height: 0; - -moz-box-sizing: border-box; - box-sizing: border-box; - z-index: 800; - } -/* workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=888319 */ -.leaflet-overlay-pane svg { - -moz-user-select: none; - } - -.leaflet-pane { z-index: 400; } - -.leaflet-tile-pane { z-index: 200; } -.leaflet-overlay-pane { z-index: 400; } -.leaflet-shadow-pane { z-index: 500; } -.leaflet-marker-pane { z-index: 600; } -.leaflet-tooltip-pane { z-index: 650; } -.leaflet-popup-pane { z-index: 700; } - -.leaflet-map-pane canvas { z-index: 100; } -.leaflet-map-pane svg { z-index: 200; } - -.leaflet-vml-shape { - width: 1px; - height: 1px; - } -.lvml { - behavior: url(#default#VML); - display: inline-block; - position: absolute; - } - - -/* control positioning */ - -.leaflet-control { - position: relative; - z-index: 800; - pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */ - pointer-events: auto; - } -.leaflet-top, -.leaflet-bottom { - position: absolute; - z-index: 1000; - pointer-events: none; - } -.leaflet-top { - top: 0; - } -.leaflet-right { - right: 0; - } -.leaflet-bottom { - bottom: 0; - } -.leaflet-left { - left: 0; - } -.leaflet-control { - float: left; - clear: both; - } -.leaflet-right .leaflet-control { - float: right; - } -.leaflet-top .leaflet-control { - margin-top: 10px; - } -.leaflet-bottom .leaflet-control { - margin-bottom: 10px; - } -.leaflet-left .leaflet-control { - margin-left: 10px; - } -.leaflet-right .leaflet-control { - margin-right: 10px; - } - - -/* zoom and fade animations */ - -.leaflet-fade-anim .leaflet-tile { - will-change: opacity; - } -.leaflet-fade-anim .leaflet-popup { - opacity: 0; - -webkit-transition: opacity 0.2s linear; - -moz-transition: opacity 0.2s linear; - transition: opacity 0.2s linear; - } -.leaflet-fade-anim .leaflet-map-pane .leaflet-popup { - opacity: 1; - } -.leaflet-zoom-animated { - -webkit-transform-origin: 0 0; - -ms-transform-origin: 0 0; - transform-origin: 0 0; - } -.leaflet-zoom-anim .leaflet-zoom-animated { - will-change: transform; - } -.leaflet-zoom-anim .leaflet-zoom-animated { - -webkit-transition: -webkit-transform 0.25s cubic-bezier(0,0,0.25,1); - -moz-transition: -moz-transform 0.25s cubic-bezier(0,0,0.25,1); - transition: transform 0.25s cubic-bezier(0,0,0.25,1); - } -.leaflet-zoom-anim .leaflet-tile, -.leaflet-pan-anim .leaflet-tile { - -webkit-transition: none; - -moz-transition: none; - transition: none; - } - -.leaflet-zoom-anim .leaflet-zoom-hide { - visibility: hidden; - } - - -/* cursors */ - -.leaflet-interactive { - cursor: pointer; - } -.leaflet-grab { - cursor: -webkit-grab; - cursor: -moz-grab; - cursor: grab; - } -.leaflet-crosshair, -.leaflet-crosshair .leaflet-interactive { - cursor: crosshair; - } -.leaflet-popup-pane, -.leaflet-control { - cursor: auto; - } -.leaflet-dragging .leaflet-grab, -.leaflet-dragging .leaflet-grab .leaflet-interactive, -.leaflet-dragging .leaflet-marker-draggable { - cursor: move; - cursor: -webkit-grabbing; - cursor: -moz-grabbing; - cursor: grabbing; - } - -/* marker & overlays interactivity */ -.leaflet-marker-icon, -.leaflet-marker-shadow, -.leaflet-image-layer, -.leaflet-pane > svg path, -.leaflet-tile-container { - pointer-events: none; - } - -.leaflet-marker-icon.leaflet-interactive, -.leaflet-image-layer.leaflet-interactive, -.leaflet-pane > svg path.leaflet-interactive { - pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */ - pointer-events: auto; - } - -/* visual tweaks */ - -.leaflet-container { - background: #ddd; - outline: 0; - } -.leaflet-container a { - color: #0078A8; - } -.leaflet-container a.leaflet-active { - outline: 2px solid orange; - } -.leaflet-zoom-box { - border: 2px dotted #38f; - background: rgba(255,255,255,0.5); - } - - -/* general typography */ -.leaflet-container { - font: 12px/1.5 "Helvetica Neue", Arial, Helvetica, sans-serif; - } - - -/* general toolbar styles */ - -.leaflet-bar { - box-shadow: 0 1px 5px rgba(0,0,0,0.65); - border-radius: 4px; - } -.leaflet-bar a, -.leaflet-bar a:hover { - background-color: #fff; - border-bottom: 1px solid #ccc; - width: 26px; - height: 26px; - line-height: 26px; - display: block; - text-align: center; - text-decoration: none; - color: black; - } -.leaflet-bar a, -.leaflet-control-layers-toggle { - background-position: 50% 50%; - background-repeat: no-repeat; - display: block; - } -.leaflet-bar a:hover { - background-color: #f4f4f4; - } -.leaflet-bar a:first-child { - border-top-left-radius: 4px; - border-top-right-radius: 4px; - } -.leaflet-bar a:last-child { - border-bottom-left-radius: 4px; - border-bottom-right-radius: 4px; - border-bottom: none; - } -.leaflet-bar a.leaflet-disabled { - cursor: default; - background-color: #f4f4f4; - color: #bbb; - } - -.leaflet-touch .leaflet-bar a { - width: 30px; - height: 30px; - line-height: 30px; - } -.leaflet-touch .leaflet-bar a:first-child { - border-top-left-radius: 2px; - border-top-right-radius: 2px; - } -.leaflet-touch .leaflet-bar a:last-child { - border-bottom-left-radius: 2px; - border-bottom-right-radius: 2px; - } - -/* zoom control */ - -.leaflet-control-zoom-in, -.leaflet-control-zoom-out { - font: bold 18px 'Lucida Console', Monaco, monospace; - text-indent: 1px; - } - -.leaflet-touch .leaflet-control-zoom-in, .leaflet-touch .leaflet-control-zoom-out { - font-size: 22px; - } - - -/* layers control */ - -.leaflet-control-layers { - box-shadow: 0 1px 5px rgba(0,0,0,0.4); - background: #fff; - border-radius: 5px; - } -.leaflet-control-layers-toggle { - background-image: url(images/layers.png); - width: 36px; - height: 36px; - } -.leaflet-retina .leaflet-control-layers-toggle { - background-image: url(images/layers-2x.png); - background-size: 26px 26px; - } -.leaflet-touch .leaflet-control-layers-toggle { - width: 44px; - height: 44px; - } -.leaflet-control-layers .leaflet-control-layers-list, -.leaflet-control-layers-expanded .leaflet-control-layers-toggle { - display: none; - } -.leaflet-control-layers-expanded .leaflet-control-layers-list { - display: block; - position: relative; - } -.leaflet-control-layers-expanded { - padding: 6px 10px 6px 6px; - color: #333; - background: #fff; - } -.leaflet-control-layers-scrollbar { - overflow-y: scroll; - overflow-x: hidden; - padding-right: 5px; - } -.leaflet-control-layers-selector { - margin-top: 2px; - position: relative; - top: 1px; - } -.leaflet-control-layers label { - display: block; - } -.leaflet-control-layers-separator { - height: 0; - border-top: 1px solid #ddd; - margin: 5px -10px 5px -6px; - } - -/* Default icon URLs */ -.leaflet-default-icon-path { - background-image: url(images/marker-icon.png); - } - - -/* attribution and scale controls */ - -.leaflet-container .leaflet-control-attribution { - background: #fff; - background: rgba(255, 255, 255, 0.7); - margin: 0; - } -.leaflet-control-attribution, -.leaflet-control-scale-line { - padding: 0 5px; - color: #333; - } -.leaflet-control-attribution a { - text-decoration: none; - } -.leaflet-control-attribution a:hover { - text-decoration: underline; - } -.leaflet-container .leaflet-control-attribution, -.leaflet-container .leaflet-control-scale { - font-size: 11px; - } -.leaflet-left .leaflet-control-scale { - margin-left: 5px; - } -.leaflet-bottom .leaflet-control-scale { - margin-bottom: 5px; - } -.leaflet-control-scale-line { - border: 2px solid #777; - border-top: none; - line-height: 1.1; - padding: 2px 5px 1px; - font-size: 11px; - white-space: nowrap; - overflow: hidden; - -moz-box-sizing: border-box; - box-sizing: border-box; - - background: #fff; - background: rgba(255, 255, 255, 0.5); - } -.leaflet-control-scale-line:not(:first-child) { - border-top: 2px solid #777; - border-bottom: none; - margin-top: -2px; - } -.leaflet-control-scale-line:not(:first-child):not(:last-child) { - border-bottom: 2px solid #777; - } - -.leaflet-touch .leaflet-control-attribution, -.leaflet-touch .leaflet-control-layers, -.leaflet-touch .leaflet-bar { - box-shadow: none; - } -.leaflet-touch .leaflet-control-layers, -.leaflet-touch .leaflet-bar { - border: 2px solid rgba(0,0,0,0.2); - background-clip: padding-box; - } - - -/* popup */ - -.leaflet-popup { - position: absolute; - text-align: center; - margin-bottom: 20px; - } -.leaflet-popup-content-wrapper { - padding: 1px; - text-align: left; - border-radius: 12px; - } -.leaflet-popup-content { - margin: 13px 19px; - line-height: 1.4; - } -.leaflet-popup-content p { - margin: 18px 0; - } -.leaflet-popup-tip-container { - width: 40px; - height: 20px; - position: absolute; - left: 50%; - margin-left: -20px; - overflow: hidden; - pointer-events: none; - } -.leaflet-popup-tip { - width: 17px; - height: 17px; - padding: 1px; - - margin: -10px auto 0; - - -webkit-transform: rotate(45deg); - -moz-transform: rotate(45deg); - -ms-transform: rotate(45deg); - transform: rotate(45deg); - } -.leaflet-popup-content-wrapper, -.leaflet-popup-tip { - background: white; - color: #333; - box-shadow: 0 3px 14px rgba(0,0,0,0.4); - } -.leaflet-container a.leaflet-popup-close-button { - position: absolute; - top: 0; - right: 0; - padding: 4px 4px 0 0; - border: none; - text-align: center; - width: 18px; - height: 14px; - font: 16px/14px Tahoma, Verdana, sans-serif; - color: #c3c3c3; - text-decoration: none; - font-weight: bold; - background: transparent; - } -.leaflet-container a.leaflet-popup-close-button:hover { - color: #999; - } -.leaflet-popup-scrolled { - overflow: auto; - border-bottom: 1px solid #ddd; - border-top: 1px solid #ddd; - } - -.leaflet-oldie .leaflet-popup-content-wrapper { - zoom: 1; - } -.leaflet-oldie .leaflet-popup-tip { - width: 24px; - margin: 0 auto; - - -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)"; - filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678); - } -.leaflet-oldie .leaflet-popup-tip-container { - margin-top: -1px; - } - -.leaflet-oldie .leaflet-control-zoom, -.leaflet-oldie .leaflet-control-layers, -.leaflet-oldie .leaflet-popup-content-wrapper, -.leaflet-oldie .leaflet-popup-tip { - border: 1px solid #999; - } - - -/* div icon */ - -.leaflet-div-icon { - background: #fff; - border: 1px solid #666; - } - - -/* Tooltip */ -/* Base styles for the element that has a tooltip */ -.leaflet-tooltip { - position: absolute; - padding: 6px; - background-color: #fff; - border: 1px solid #fff; - border-radius: 3px; - color: #222; - white-space: nowrap; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; - pointer-events: none; - box-shadow: 0 1px 3px rgba(0,0,0,0.4); - } -.leaflet-tooltip.leaflet-clickable { - cursor: pointer; - pointer-events: auto; - } -.leaflet-tooltip-top:before, -.leaflet-tooltip-bottom:before, -.leaflet-tooltip-left:before, -.leaflet-tooltip-right:before { - position: absolute; - pointer-events: none; - border: 6px solid transparent; - background: transparent; - content: ""; - } - -/* Directions */ - -.leaflet-tooltip-bottom { - margin-top: 6px; -} -.leaflet-tooltip-top { - margin-top: -6px; -} -.leaflet-tooltip-bottom:before, -.leaflet-tooltip-top:before { - left: 50%; - margin-left: -6px; - } -.leaflet-tooltip-top:before { - bottom: 0; - margin-bottom: -12px; - border-top-color: #fff; - } -.leaflet-tooltip-bottom:before { - top: 0; - margin-top: -12px; - margin-left: -6px; - border-bottom-color: #fff; - } -.leaflet-tooltip-left { - margin-left: -6px; -} -.leaflet-tooltip-right { - margin-left: 6px; -} -.leaflet-tooltip-left:before, -.leaflet-tooltip-right:before { - top: 50%; - margin-top: -6px; - } -.leaflet-tooltip-left:before { - right: 0; - margin-right: -12px; - border-left-color: #fff; - } -.leaflet-tooltip-right:before { - left: 0; - margin-left: -12px; - border-right-color: #fff; - } diff --git a/assets/css/lightgallery.css b/assets/css/lightgallery.css deleted file mode 100644 index 5bea576..0000000 --- a/assets/css/lightgallery.css +++ /dev/null @@ -1,985 +0,0 @@ -/*! lightgallery - v1.6.11 - 2018-05-22 -* http://sachinchoolur.github.io/lightGallery/ -* Copyright (c) 2018 Sachin N; Licensed GPLv3 */ -@font-face { - font-family: 'lg'; - src: url("../fonts/lg.eot?n1z373"); - src: url("../fonts/lg.eot?#iefixn1z373") format("embedded-opentype"), url("../fonts/lg.woff?n1z373") format("woff"), url("../fonts/lg.ttf?n1z373") format("truetype"), url("../fonts/lg.svg?n1z373#lg") format("svg"); - font-weight: normal; - font-style: normal; -} -.lg-icon { - font-family: 'lg'; - speak: none; - font-style: normal; - font-weight: normal; - font-variant: normal; - text-transform: none; - line-height: 1; - /* Better Font Rendering =========== */ - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; -} - -.lg-actions .lg-next, .lg-actions .lg-prev { - background-color: rgba(0, 0, 0, 0.45); - border-radius: 2px; - color: #999; - cursor: pointer; - display: block; - font-size: 22px; - margin-top: -10px; - padding: 8px 10px 9px; - position: absolute; - top: 50%; - z-index: 5080; - border: none; - outline: none; -} -.lg-actions .lg-next.disabled, .lg-actions .lg-prev.disabled { - pointer-events: none; - opacity: 0.5; -} -.lg-actions .lg-next:hover, .lg-actions .lg-prev:hover { - color: #FFF; -} -.lg-actions .lg-next { - right: 20px; -} -.lg-actions .lg-next:before { - content: "\e095"; -} -.lg-actions .lg-prev { - left: 20px; -} -.lg-actions .lg-prev:after { - content: "\e094"; -} - -@-webkit-keyframes lg-right-end { - 0% { - left: 0; - } - 50% { - left: -30px; - } - 100% { - left: 0; - } -} -@-moz-keyframes lg-right-end { - 0% { - left: 0; - } - 50% { - left: -30px; - } - 100% { - left: 0; - } -} -@-ms-keyframes lg-right-end { - 0% { - left: 0; - } - 50% { - left: -30px; - } - 100% { - left: 0; - } -} -@keyframes lg-right-end { - 0% { - left: 0; - } - 50% { - left: -30px; - } - 100% { - left: 0; - } -} -@-webkit-keyframes lg-left-end { - 0% { - left: 0; - } - 50% { - left: 30px; - } - 100% { - left: 0; - } -} -@-moz-keyframes lg-left-end { - 0% { - left: 0; - } - 50% { - left: 30px; - } - 100% { - left: 0; - } -} -@-ms-keyframes lg-left-end { - 0% { - left: 0; - } - 50% { - left: 30px; - } - 100% { - left: 0; - } -} -@keyframes lg-left-end { - 0% { - left: 0; - } - 50% { - left: 30px; - } - 100% { - left: 0; - } -} -.lg-outer.lg-right-end .lg-object { - -webkit-animation: lg-right-end 0.3s; - -o-animation: lg-right-end 0.3s; - animation: lg-right-end 0.3s; - position: relative; -} -.lg-outer.lg-left-end .lg-object { - -webkit-animation: lg-left-end 0.3s; - -o-animation: lg-left-end 0.3s; - animation: lg-left-end 0.3s; - position: relative; -} - -.lg-toolbar { - z-index: 5082; - left: 0; - position: absolute; - top: 0; - width: 100%; - background-color: rgba(0, 0, 0, 0.45); -} -.lg-toolbar .lg-icon { - color: #999; - cursor: pointer; - float: right; - font-size: 24px; - height: 47px; - line-height: 27px; - padding: 10px 0; - text-align: center; - width: 50px; - text-decoration: none !important; - outline: medium none; - -webkit-transition: color 0.2s linear; - -o-transition: color 0.2s linear; - transition: color 0.2s linear; -} -.lg-toolbar .lg-icon:hover { - color: #FFF; -} -.lg-toolbar .lg-close:after { - content: "\e070"; -} -.lg-toolbar .lg-download:after { - content: "\e0f2"; -} - -.lg-sub-html { - background-color: rgba(0, 0, 0, 0.45); - bottom: 0; - color: #EEE; - font-size: 16px; - left: 0; - padding: 10px 40px; - position: fixed; - right: 0; - text-align: center; - z-index: 5080; -} -.lg-sub-html h4 { - margin: 0; - font-size: 13px; - font-weight: bold; -} -.lg-sub-html p { - font-size: 12px; - margin: 5px 0 0; -} - -#lg-counter { - color: #999; - display: inline-block; - font-size: 16px; - padding-left: 20px; - padding-top: 12px; - vertical-align: middle; -} - -.lg-toolbar, .lg-prev, .lg-next { - opacity: 1; - -webkit-transition: -webkit-transform 0.35s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.35s cubic-bezier(0, 0, 0.25, 1) 0s, color 0.2s linear; - -moz-transition: -moz-transform 0.35s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.35s cubic-bezier(0, 0, 0.25, 1) 0s, color 0.2s linear; - -o-transition: -o-transform 0.35s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.35s cubic-bezier(0, 0, 0.25, 1) 0s, color 0.2s linear; - transition: transform 0.35s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.35s cubic-bezier(0, 0, 0.25, 1) 0s, color 0.2s linear; -} - -.lg-hide-items .lg-prev { - opacity: 0; - -webkit-transform: translate3d(-10px, 0, 0); - transform: translate3d(-10px, 0, 0); -} -.lg-hide-items .lg-next { - opacity: 0; - -webkit-transform: translate3d(10px, 0, 0); - transform: translate3d(10px, 0, 0); -} -.lg-hide-items .lg-toolbar { - opacity: 0; - -webkit-transform: translate3d(0, -10px, 0); - transform: translate3d(0, -10px, 0); -} - -body:not(.lg-from-hash) .lg-outer.lg-start-zoom .lg-object { - -webkit-transform: scale3d(0.5, 0.5, 0.5); - transform: scale3d(0.5, 0.5, 0.5); - opacity: 0; - -webkit-transition: -webkit-transform 250ms cubic-bezier(0, 0, 0.25, 1) 0s, opacity 250ms cubic-bezier(0, 0, 0.25, 1) !important; - -moz-transition: -moz-transform 250ms cubic-bezier(0, 0, 0.25, 1) 0s, opacity 250ms cubic-bezier(0, 0, 0.25, 1) !important; - -o-transition: -o-transform 250ms cubic-bezier(0, 0, 0.25, 1) 0s, opacity 250ms cubic-bezier(0, 0, 0.25, 1) !important; - transition: transform 250ms cubic-bezier(0, 0, 0.25, 1) 0s, opacity 250ms cubic-bezier(0, 0, 0.25, 1) !important; - -webkit-transform-origin: 50% 50%; - -moz-transform-origin: 50% 50%; - -ms-transform-origin: 50% 50%; - transform-origin: 50% 50%; -} -body:not(.lg-from-hash) .lg-outer.lg-start-zoom .lg-item.lg-complete .lg-object { - -webkit-transform: scale3d(1, 1, 1); - transform: scale3d(1, 1, 1); - opacity: 1; -} - -.lg-outer .lg-thumb-outer { - background-color: #0D0A0A; - bottom: 0; - position: absolute; - width: 100%; - z-index: 5080; - max-height: 350px; - -webkit-transform: translate3d(0, 100%, 0); - transform: translate3d(0, 100%, 0); - -webkit-transition: -webkit-transform 0.25s cubic-bezier(0, 0, 0.25, 1) 0s; - -moz-transition: -moz-transform 0.25s cubic-bezier(0, 0, 0.25, 1) 0s; - -o-transition: -o-transform 0.25s cubic-bezier(0, 0, 0.25, 1) 0s; - transition: transform 0.25s cubic-bezier(0, 0, 0.25, 1) 0s; -} -.lg-outer .lg-thumb-outer.lg-grab .lg-thumb-item { - cursor: -webkit-grab; - cursor: -moz-grab; - cursor: -o-grab; - cursor: -ms-grab; - cursor: grab; -} -.lg-outer .lg-thumb-outer.lg-grabbing .lg-thumb-item { - cursor: move; - cursor: -webkit-grabbing; - cursor: -moz-grabbing; - cursor: -o-grabbing; - cursor: -ms-grabbing; - cursor: grabbing; -} -.lg-outer .lg-thumb-outer.lg-dragging .lg-thumb { - -webkit-transition-duration: 0s !important; - transition-duration: 0s !important; -} -.lg-outer.lg-thumb-open .lg-thumb-outer { - -webkit-transform: translate3d(0, 0%, 0); - transform: translate3d(0, 0%, 0); -} -.lg-outer .lg-thumb { - padding: 10px 0; - height: 100%; - margin-bottom: -5px; -} -.lg-outer .lg-thumb-item { - border-radius: 5px; - cursor: pointer; - float: left; - overflow: hidden; - height: 100%; - border: 2px solid #FFF; - border-radius: 4px; - margin-bottom: 5px; -} -@media (min-width: 1025px) { - .lg-outer .lg-thumb-item { - -webkit-transition: border-color 0.25s ease; - -o-transition: border-color 0.25s ease; - transition: border-color 0.25s ease; - } -} -.lg-outer .lg-thumb-item.active, .lg-outer .lg-thumb-item:hover { - border-color: #a90707; -} -.lg-outer .lg-thumb-item img { - width: 100%; - height: 100%; - object-fit: cover; -} -.lg-outer.lg-has-thumb .lg-item { - padding-bottom: 120px; -} -.lg-outer.lg-can-toggle .lg-item { - padding-bottom: 0; -} -.lg-outer.lg-pull-caption-up .lg-sub-html { - -webkit-transition: bottom 0.25s ease; - -o-transition: bottom 0.25s ease; - transition: bottom 0.25s ease; -} -.lg-outer.lg-pull-caption-up.lg-thumb-open .lg-sub-html { - bottom: 100px; -} -.lg-outer .lg-toogle-thumb { - background-color: #0D0A0A; - border-radius: 2px 2px 0 0; - color: #999; - cursor: pointer; - font-size: 24px; - height: 39px; - line-height: 27px; - padding: 5px 0; - position: absolute; - right: 20px; - text-align: center; - top: -39px; - width: 50px; -} -.lg-outer .lg-toogle-thumb:after { - content: "\e1ff"; -} -.lg-outer .lg-toogle-thumb:hover { - color: #FFF; -} - -.lg-outer .lg-video-cont { - display: inline-block; - vertical-align: middle; - max-width: 1140px; - max-height: 100%; - width: 100%; - padding: 0 5px; -} -.lg-outer .lg-video { - width: 100%; - height: 0; - padding-bottom: 56.25%; - overflow: hidden; - position: relative; -} -.lg-outer .lg-video .lg-object { - display: inline-block; - position: absolute; - top: 0; - left: 0; - width: 100% !important; - height: 100% !important; -} -.lg-outer .lg-video .lg-video-play { - width: 84px; - height: 59px; - position: absolute; - left: 50%; - top: 50%; - margin-left: -42px; - margin-top: -30px; - z-index: 5080; - cursor: pointer; -} -.lg-outer .lg-has-iframe .lg-video { - -webkit-overflow-scrolling: touch; - overflow: auto; -} -.lg-outer .lg-has-vimeo .lg-video-play { - background: url("../img/vimeo-play.png") no-repeat scroll 0 0 transparent; -} -.lg-outer .lg-has-vimeo:hover .lg-video-play { - background: url("../img/vimeo-play.png") no-repeat scroll 0 -58px transparent; -} -.lg-outer .lg-has-html5 .lg-video-play { - background: transparent url("../img/video-play.png") no-repeat scroll 0 0; - height: 64px; - margin-left: -32px; - margin-top: -32px; - width: 64px; - opacity: 0.8; -} -.lg-outer .lg-has-html5:hover .lg-video-play { - opacity: 1; -} -.lg-outer .lg-has-youtube .lg-video-play { - background: url("../img/youtube-play.png") no-repeat scroll 0 0 transparent; -} -.lg-outer .lg-has-youtube:hover .lg-video-play { - background: url("../img/youtube-play.png") no-repeat scroll 0 -60px transparent; -} -.lg-outer .lg-video-object { - width: 100% !important; - height: 100% !important; - position: absolute; - top: 0; - left: 0; -} -.lg-outer .lg-has-video .lg-video-object { - visibility: hidden; -} -.lg-outer .lg-has-video.lg-video-playing .lg-object, .lg-outer .lg-has-video.lg-video-playing .lg-video-play { - display: none; -} -.lg-outer .lg-has-video.lg-video-playing .lg-video-object { - visibility: visible; -} - -.lg-progress-bar { - background-color: #333; - height: 5px; - left: 0; - position: absolute; - top: 0; - width: 100%; - z-index: 5083; - opacity: 0; - -webkit-transition: opacity 0.08s ease 0s; - -moz-transition: opacity 0.08s ease 0s; - -o-transition: opacity 0.08s ease 0s; - transition: opacity 0.08s ease 0s; -} -.lg-progress-bar .lg-progress { - background-color: #a90707; - height: 5px; - width: 0; -} -.lg-progress-bar.lg-start .lg-progress { - width: 100%; -} -.lg-show-autoplay .lg-progress-bar { - opacity: 1; -} - -.lg-autoplay-button:after { - content: "\e01d"; -} -.lg-show-autoplay .lg-autoplay-button:after { - content: "\e01a"; -} - -.lg-outer.lg-css3.lg-zoom-dragging .lg-item.lg-complete.lg-zoomable .lg-img-wrap, .lg-outer.lg-css3.lg-zoom-dragging .lg-item.lg-complete.lg-zoomable .lg-image { - -webkit-transition-duration: 0s; - transition-duration: 0s; -} -.lg-outer.lg-use-transition-for-zoom .lg-item.lg-complete.lg-zoomable .lg-img-wrap { - -webkit-transition: -webkit-transform 0.3s cubic-bezier(0, 0, 0.25, 1) 0s; - -moz-transition: -moz-transform 0.3s cubic-bezier(0, 0, 0.25, 1) 0s; - -o-transition: -o-transform 0.3s cubic-bezier(0, 0, 0.25, 1) 0s; - transition: transform 0.3s cubic-bezier(0, 0, 0.25, 1) 0s; -} -.lg-outer.lg-use-left-for-zoom .lg-item.lg-complete.lg-zoomable .lg-img-wrap { - -webkit-transition: left 0.3s cubic-bezier(0, 0, 0.25, 1) 0s, top 0.3s cubic-bezier(0, 0, 0.25, 1) 0s; - -moz-transition: left 0.3s cubic-bezier(0, 0, 0.25, 1) 0s, top 0.3s cubic-bezier(0, 0, 0.25, 1) 0s; - -o-transition: left 0.3s cubic-bezier(0, 0, 0.25, 1) 0s, top 0.3s cubic-bezier(0, 0, 0.25, 1) 0s; - transition: left 0.3s cubic-bezier(0, 0, 0.25, 1) 0s, top 0.3s cubic-bezier(0, 0, 0.25, 1) 0s; -} -.lg-outer .lg-item.lg-complete.lg-zoomable .lg-img-wrap { - -webkit-transform: translate3d(0, 0, 0); - transform: translate3d(0, 0, 0); - -webkit-backface-visibility: hidden; - -moz-backface-visibility: hidden; - backface-visibility: hidden; -} -.lg-outer .lg-item.lg-complete.lg-zoomable .lg-image { - -webkit-transform: scale3d(1, 1, 1); - transform: scale3d(1, 1, 1); - -webkit-transition: -webkit-transform 0.3s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.15s !important; - -moz-transition: -moz-transform 0.3s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.15s !important; - -o-transition: -o-transform 0.3s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.15s !important; - transition: transform 0.3s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.15s !important; - -webkit-transform-origin: 0 0; - -moz-transform-origin: 0 0; - -ms-transform-origin: 0 0; - transform-origin: 0 0; - -webkit-backface-visibility: hidden; - -moz-backface-visibility: hidden; - backface-visibility: hidden; -} - -#lg-zoom-in:after { - content: "\e311"; -} - -#lg-actual-size { - font-size: 20px; -} -#lg-actual-size:after { - content: "\e033"; -} - -#lg-zoom-out { - opacity: 0.5; - pointer-events: none; -} -#lg-zoom-out:after { - content: "\e312"; -} -.lg-zoomed #lg-zoom-out { - opacity: 1; - pointer-events: auto; -} - -.lg-outer .lg-pager-outer { - bottom: 60px; - left: 0; - position: absolute; - right: 0; - text-align: center; - z-index: 5080; - height: 10px; -} -.lg-outer .lg-pager-outer.lg-pager-hover .lg-pager-cont { - overflow: visible; -} -.lg-outer .lg-pager-cont { - cursor: pointer; - display: inline-block; - overflow: hidden; - position: relative; - vertical-align: top; - margin: 0 5px; -} -.lg-outer .lg-pager-cont:hover .lg-pager-thumb-cont { - opacity: 1; - -webkit-transform: translate3d(0, 0, 0); - transform: translate3d(0, 0, 0); -} -.lg-outer .lg-pager-cont.lg-pager-active .lg-pager { - box-shadow: 0 0 0 2px white inset; -} -.lg-outer .lg-pager-thumb-cont { - background-color: #fff; - color: #FFF; - bottom: 100%; - height: 83px; - left: 0; - margin-bottom: 20px; - margin-left: -60px; - opacity: 0; - padding: 5px; - position: absolute; - width: 120px; - border-radius: 3px; - -webkit-transition: opacity 0.15s ease 0s, -webkit-transform 0.15s ease 0s; - -moz-transition: opacity 0.15s ease 0s, -moz-transform 0.15s ease 0s; - -o-transition: opacity 0.15s ease 0s, -o-transform 0.15s ease 0s; - transition: opacity 0.15s ease 0s, transform 0.15s ease 0s; - -webkit-transform: translate3d(0, 5px, 0); - transform: translate3d(0, 5px, 0); -} -.lg-outer .lg-pager-thumb-cont img { - width: 100%; - height: 100%; -} -.lg-outer .lg-pager { - background-color: rgba(255, 255, 255, 0.5); - border-radius: 50%; - box-shadow: 0 0 0 8px rgba(255, 255, 255, 0.7) inset; - display: block; - height: 12px; - -webkit-transition: box-shadow 0.3s ease 0s; - -o-transition: box-shadow 0.3s ease 0s; - transition: box-shadow 0.3s ease 0s; - width: 12px; -} -.lg-outer .lg-pager:hover, .lg-outer .lg-pager:focus { - box-shadow: 0 0 0 8px white inset; -} -.lg-outer .lg-caret { - border-left: 10px solid transparent; - border-right: 10px solid transparent; - border-top: 10px dashed; - bottom: -10px; - display: inline-block; - height: 0; - left: 50%; - margin-left: -5px; - position: absolute; - vertical-align: middle; - width: 0; -} - -.lg-fullscreen:after { - content: "\e20c"; -} -.lg-fullscreen-on .lg-fullscreen:after { - content: "\e20d"; -} - -.lg-outer #lg-dropdown-overlay { - background-color: rgba(0, 0, 0, 0.25); - bottom: 0; - cursor: default; - left: 0; - position: fixed; - right: 0; - top: 0; - z-index: 5081; - opacity: 0; - visibility: hidden; - -webkit-transition: visibility 0s linear 0.18s, opacity 0.18s linear 0s; - -o-transition: visibility 0s linear 0.18s, opacity 0.18s linear 0s; - transition: visibility 0s linear 0.18s, opacity 0.18s linear 0s; -} -.lg-outer.lg-dropdown-active .lg-dropdown, .lg-outer.lg-dropdown-active #lg-dropdown-overlay { - -webkit-transition-delay: 0s; - transition-delay: 0s; - -moz-transform: translate3d(0, 0px, 0); - -o-transform: translate3d(0, 0px, 0); - -ms-transform: translate3d(0, 0px, 0); - -webkit-transform: translate3d(0, 0px, 0); - transform: translate3d(0, 0px, 0); - opacity: 1; - visibility: visible; -} -.lg-outer.lg-dropdown-active { - color: #FFF; -} - -#lg-share { display: none; } - -.lg-outer .lg-dropdown { - background-color: #fff; - border-radius: 2px; - font-size: 14px; - list-style-type: none; - margin: 0; - padding: 10px 0; - position: absolute; - right: 0; - text-align: left; - top: 50px; - opacity: 0; - visibility: hidden; - -moz-transform: translate3d(0, 5px, 0); - -o-transform: translate3d(0, 5px, 0); - -ms-transform: translate3d(0, 5px, 0); - -webkit-transform: translate3d(0, 5px, 0); - transform: translate3d(0, 5px, 0); - -webkit-transition: -webkit-transform 0.18s linear 0s, visibility 0s linear 0.5s, opacity 0.18s linear 0s; - -moz-transition: -moz-transform 0.18s linear 0s, visibility 0s linear 0.5s, opacity 0.18s linear 0s; - -o-transition: -o-transform 0.18s linear 0s, visibility 0s linear 0.5s, opacity 0.18s linear 0s; - transition: transform 0.18s linear 0s, visibility 0s linear 0.5s, opacity 0.18s linear 0s; -} -.lg-outer .lg-dropdown:after { - content: ""; - display: block; - height: 0; - width: 0; - position: absolute; - border: 8px solid transparent; - border-bottom-color: #FFF; - right: 16px; - top: -16px; -} -.lg-outer .lg-dropdown > li:last-child { - margin-bottom: 0px; -} -.lg-outer .lg-dropdown > li:hover a, .lg-outer .lg-dropdown > li:hover .lg-icon { - color: #333; -} -.lg-outer .lg-dropdown a { - color: #333; - display: block; - white-space: pre; - padding: 4px 12px; - font-family: "Open Sans","Helvetica Neue",Helvetica,Arial,sans-serif; - font-size: 12px; -} -.lg-outer .lg-dropdown a:hover { - background-color: rgba(0, 0, 0, 0.07); -} -.lg-outer .lg-dropdown .lg-dropdown-text { - display: inline-block; - line-height: 1; - margin-top: -3px; - vertical-align: middle; -} -.lg-outer .lg-dropdown .lg-icon { - color: #333; - display: inline-block; - float: none; - font-size: 20px; - height: auto; - line-height: 1; - margin-right: 8px; - padding: 0; - vertical-align: middle; - width: auto; -} -.lg-outer #lg-share { - position: relative; -} -.lg-outer #lg-share:after { - content: "\e80d"; -} -.lg-outer #lg-share-facebook .lg-icon { - color: #3b5998; -} -.lg-outer #lg-share-facebook .lg-icon:after { - content: "\e901"; -} -.lg-outer #lg-share-twitter .lg-icon { - color: #00aced; -} -.lg-outer #lg-share-twitter .lg-icon:after { - content: "\e904"; -} -.lg-outer #lg-share-googleplus .lg-icon { - color: #dd4b39; -} -.lg-outer #lg-share-googleplus .lg-icon:after { - content: "\e902"; -} -.lg-outer #lg-share-pinterest .lg-icon { - color: #cb2027; -} -.lg-outer #lg-share-pinterest .lg-icon:after { - content: "\e903"; -} - -.lg-group:after { - content: ""; - display: table; - clear: both; -} - -.lg-outer { - width: 100%; - height: 100%; - position: fixed; - top: 0; - left: 0; - z-index: 5050; - text-align: left; - opacity: 0; - -webkit-transition: opacity 0.15s ease 0s; - -o-transition: opacity 0.15s ease 0s; - transition: opacity 0.15s ease 0s; -} -.lg-outer * { - -webkit-box-sizing: border-box; - -moz-box-sizing: border-box; - box-sizing: border-box; -} -.lg-outer.lg-visible { - opacity: 1; -} -.lg-outer.lg-css3 .lg-item.lg-prev-slide, .lg-outer.lg-css3 .lg-item.lg-next-slide, .lg-outer.lg-css3 .lg-item.lg-current { - -webkit-transition-duration: inherit !important; - transition-duration: inherit !important; - -webkit-transition-timing-function: inherit !important; - transition-timing-function: inherit !important; -} -.lg-outer.lg-css3.lg-dragging .lg-item.lg-prev-slide, .lg-outer.lg-css3.lg-dragging .lg-item.lg-next-slide, .lg-outer.lg-css3.lg-dragging .lg-item.lg-current { - -webkit-transition-duration: 0s !important; - transition-duration: 0s !important; - opacity: 1; -} -.lg-outer.lg-grab img.lg-object { - cursor: -webkit-grab; - cursor: -moz-grab; - cursor: -o-grab; - cursor: -ms-grab; - cursor: grab; -} -.lg-outer.lg-grabbing img.lg-object { - cursor: move; - cursor: -webkit-grabbing; - cursor: -moz-grabbing; - cursor: -o-grabbing; - cursor: -ms-grabbing; - cursor: grabbing; -} -.lg-outer .lg { - height: 100%; - width: 100%; - position: relative; - overflow: hidden; - margin-left: auto; - margin-right: auto; - max-width: 100%; - max-height: 100%; -} -.lg-outer .lg-inner { - width: 100%; - height: 100%; - position: absolute; - left: 0; - top: 0; - white-space: nowrap; -} -.lg-outer .lg-item { - background: url("../img/loading.gif") no-repeat scroll center center transparent; - display: none !important; -} -.lg-outer.lg-css3 .lg-prev-slide, .lg-outer.lg-css3 .lg-current, .lg-outer.lg-css3 .lg-next-slide { - display: inline-block !important; -} -.lg-outer.lg-css .lg-current { - display: inline-block !important; -} -.lg-outer .lg-item, .lg-outer .lg-img-wrap { - display: inline-block; - text-align: center; - position: absolute; - width: 100%; - height: 100%; -} -.lg-outer .lg-item:before, .lg-outer .lg-img-wrap:before { - content: ""; - display: inline-block; - height: 50%; - width: 1px; - margin-right: -1px; -} -.lg-outer .lg-img-wrap { - position: absolute; - padding: 0 5px; - left: 0; - right: 0; - top: 0; - bottom: 0; -} -.lg-outer .lg-item.lg-complete { - background-image: none; -} -.lg-outer .lg-item.lg-current { - z-index: 5060; -} -.lg-outer .lg-image { - display: inline-block; - vertical-align: middle; - max-width: 100%; - max-height: 100%; - width: auto !important; - height: auto !important; -} -.lg-outer.lg-show-after-load .lg-item .lg-object, .lg-outer.lg-show-after-load .lg-item .lg-video-play { - opacity: 0; - -webkit-transition: opacity 0.15s ease 0s; - -o-transition: opacity 0.15s ease 0s; - transition: opacity 0.15s ease 0s; -} -.lg-outer.lg-show-after-load .lg-item.lg-complete .lg-object, .lg-outer.lg-show-after-load .lg-item.lg-complete .lg-video-play { - opacity: 1; -} -.lg-outer .lg-empty-html { - display: none; -} -.lg-outer.lg-hide-download #lg-download { - display: none; -} - -.lg-backdrop { - position: fixed; - top: 0; - left: 0; - right: 0; - bottom: 0; - z-index: 5040; - background-color: #000; - opacity: 0; - -webkit-transition: opacity 0.15s ease 0s; - -o-transition: opacity 0.15s ease 0s; - transition: opacity 0.15s ease 0s; -} -.lg-backdrop.in { - opacity: 1; -} - -.lg-css3.lg-no-trans .lg-prev-slide, .lg-css3.lg-no-trans .lg-next-slide, .lg-css3.lg-no-trans .lg-current { - -webkit-transition: none 0s ease 0s !important; - -moz-transition: none 0s ease 0s !important; - -o-transition: none 0s ease 0s !important; - transition: none 0s ease 0s !important; -} -.lg-css3.lg-use-css3 .lg-item { - -webkit-backface-visibility: hidden; - -moz-backface-visibility: hidden; - backface-visibility: hidden; -} -.lg-css3.lg-use-left .lg-item { - -webkit-backface-visibility: hidden; - -moz-backface-visibility: hidden; - backface-visibility: hidden; -} -.lg-css3.lg-fade .lg-item { - opacity: 0; -} -.lg-css3.lg-fade .lg-item.lg-current { - opacity: 1; -} -.lg-css3.lg-fade .lg-item.lg-prev-slide, .lg-css3.lg-fade .lg-item.lg-next-slide, .lg-css3.lg-fade .lg-item.lg-current { - -webkit-transition: opacity 0.1s ease 0s; - -moz-transition: opacity 0.1s ease 0s; - -o-transition: opacity 0.1s ease 0s; - transition: opacity 0.1s ease 0s; -} -.lg-css3.lg-slide.lg-use-css3 .lg-item { - opacity: 0; -} -.lg-css3.lg-slide.lg-use-css3 .lg-item.lg-prev-slide { - -webkit-transform: translate3d(-100%, 0, 0); - transform: translate3d(-100%, 0, 0); -} -.lg-css3.lg-slide.lg-use-css3 .lg-item.lg-next-slide { - -webkit-transform: translate3d(100%, 0, 0); - transform: translate3d(100%, 0, 0); -} -.lg-css3.lg-slide.lg-use-css3 .lg-item.lg-current { - -webkit-transform: translate3d(0, 0, 0); - transform: translate3d(0, 0, 0); - opacity: 1; -} -.lg-css3.lg-slide.lg-use-css3 .lg-item.lg-prev-slide, .lg-css3.lg-slide.lg-use-css3 .lg-item.lg-next-slide, .lg-css3.lg-slide.lg-use-css3 .lg-item.lg-current { - -webkit-transition: -webkit-transform 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s; - -moz-transition: -moz-transform 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s; - -o-transition: -o-transform 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s; - transition: transform 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s; -} -.lg-css3.lg-slide.lg-use-left .lg-item { - opacity: 0; - position: absolute; - left: 0; -} -.lg-css3.lg-slide.lg-use-left .lg-item.lg-prev-slide { - left: -100%; -} -.lg-css3.lg-slide.lg-use-left .lg-item.lg-next-slide { - left: 100%; -} -.lg-css3.lg-slide.lg-use-left .lg-item.lg-current { - left: 0; - opacity: 1; -} -.lg-css3.lg-slide.lg-use-left .lg-item.lg-prev-slide, .lg-css3.lg-slide.lg-use-left .lg-item.lg-next-slide, .lg-css3.lg-slide.lg-use-left .lg-item.lg-current { - -webkit-transition: left 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s; - -moz-transition: left 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s; - -o-transition: left 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s; - transition: left 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s; -} - -/*# sourceMappingURL=lightgallery.css.map */ diff --git a/assets/css/reset.css b/assets/css/reset.css new file mode 100644 index 0000000..ab42a2f --- /dev/null +++ b/assets/css/reset.css @@ -0,0 +1,45 @@ +body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,label,input,textarea,p,blockquote,th,td { + margin:0; + padding:0; +} + +table { + border-collapse:collapse; + border-spacing:0; +} + +fieldset,img { + border:0; +} + +address,caption,cite,code,dfn,em,strong,th,var { + font-style:normal; + font-weight:normal; +} + +ol,ul,li { + list-style:none; + margin: 0; + padding: 0; +} + +caption,th { + text-align:left; +} + +h1,h2,h3,h4,h5,h6 { + font-size:100%; + font-weight:normal; +} + +q:before,q:after { + content:''; +} + +abbr,acronym { + border:0; +} + +a { + text-decoration: none; +} diff --git a/assets/css/style.css b/assets/css/style.css new file mode 100644 index 0000000..cdbee90 --- /dev/null +++ b/assets/css/style.css @@ -0,0 +1,1707 @@ +/* + * Namensschema der CSS-Klassen nach BEM (Block Element Modifier, + * http://getbem.com/naming/). Mit der Erweiterung, dass Modifier einzeln + * mit Bindestrich angegeben werden. Also: + * + * + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {{- '\n ' -}} {%- else -%} {{- '\n ' -}}
    {{- '\n ' -}} Keine Zutaten definiert {{- '\n ' -}}
+ {%- endif -%} + {%- else -%} + {{- '\n ' -}}
    + {{- '\n ' -}} Keine Zutaten definiert + {{- '\n ' -}}
{%- endif -%} - {%- else -%} - {{- '\n ' -}}
    - {{- '\n ' -}} Keine Zutaten definiert - {{- '\n ' -}}
- {%- endif -%} - {%- endfor -%} + {%- endfor -%} + {%- endif -%} {%- endif -%} + {{- '\n ' -}} + {{- '\n ' -}} {%- endif -%} - {{- '\n ' -}} - {{- '\n ' -}} - {%- endif -%} {#- Rezept Schritte... -- 2.39.5 From 138bea089abdbfbf9f8e5814d6c3f8aab2e6d541 Mon Sep 17 00:00:00 2001 From: L3D Date: Sat, 31 Jul 2021 18:48:28 +0200 Subject: [PATCH 05/78] parts for templates --- .../rezept/klassisch/rezept.yaml/contents.lr | 2 +- templates/macros/rezept.html | 343 +----------------- templates/zutaten.yaml | 149 +------- templates/zutaten/ingredients.yaml | 87 +++++ templates/zutaten/oven.yaml | 28 ++ templates/zutaten/rezept.html | 115 ++++++ templates/zutaten/steps.yaml | 30 ++ templates/zutaten/yields.yaml | 11 + templates/zutaten/zutaten.html | 225 ++++++++++++ 9 files changed, 512 insertions(+), 478 deletions(-) create mode 100644 templates/zutaten/ingredients.yaml create mode 100644 templates/zutaten/oven.yaml create mode 100644 templates/zutaten/rezept.html create mode 100644 templates/zutaten/steps.yaml create mode 100644 templates/zutaten/yields.yaml create mode 100644 templates/zutaten/zutaten.html diff --git a/content/rezept/klassisch/rezept.yaml/contents.lr b/content/rezept/klassisch/rezept.yaml/contents.lr index d743238..37c22c1 100644 --- a/content/rezept/klassisch/rezept.yaml/contents.lr +++ b/content/rezept/klassisch/rezept.yaml/contents.lr @@ -311,7 +311,7 @@ oven_fan: Off --- oven_time: 100s --- -oven_type: waffle iron +oven_type: Waffeleisen --- steps: diff --git a/templates/macros/rezept.html b/templates/macros/rezept.html index ea636a2..ad8171f 100644 --- a/templates/macros/rezept.html +++ b/templates/macros/rezept.html @@ -13,348 +13,21 @@ {{- '\n ' -}}

{{- '\n ' -}} {{- '\n ' -}} - {%- if from_index -%} + {%- if post.orf | default(false) -%} + {#- + Render recepie based on open recipe format + defined in zutaten.yml + -#} {%- for child in post.children -%} {%- if child._template == 'zutaten.yaml' -%} - {{ '\n ' -}}
  • {{ child.recipe_name }}
  • - {%- endif -%} - {%- endfor -%} - {%- else -%} - {%- for child in post.children -%} - {%- if child._template == 'zutaten.yaml' -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}} - {%- if child.recipe_uuid is defined and child.recipe_uuid != "" -%} -

    + {%- if from_index -%} + {{ '\n ' -}}

    {{ child.recipe_name }}

    {%- else -%} -

    - {%- endif -%} - {%- if child.recipe_name and child.recipe_name != "" -%} - {{ child.recipe_name }}

    - {%- else -%} - {{ child.title }} - {%- endif -%} - {%- if child.servings is defined and child.servings != "" -%} - {%- if child.servings.blocks != [] -%} - {%- for prt in child.servings.blocks -%} - {{- '\n ' -}} -

    Portionsgröße: Für {{ prt.serving_number | default('1') }} - {{- ' ' -}} - {%- if prt.serving_units is defined and prt.serving_units != "" -%} - {{- prt.serving_units -}} - {%- else -%} - Stück - {%- endif -%} -

    - {%- set prt_loop = loop.index -%} - {%- if child.ingredients is defined and child.ingredients != "" %} - {%- if child.ingredients.blocks != [] -%} - {{- '\n ' -}}
      - {%- for ing in child.ingredients.blocks %} - {%- if ing.ingredient is defined and ing.ingredient != "" -%} - {%- if ing.amounts is defined and ing.amounts != "" and ing.amounts.blocks is defined and ing.amounts.blocks != "" -%} - {%- if ing.amounts.blocks != [] -%} - {%- set ingredient_counter = loop.index -%} - {%- for amt in ing.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} - {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} - {%- if ing.processing.blocks != [] -%} - {{- ' | ' -}} - Verarbeitungshinweis #{{- ingredient_counter | string -}} - {%- endif -%} - {%- endif -%} - {%- if ing.notes is defined and ing.notes != "" and ing.notes.blocks is defined and ing.notes.blocks != "" -%} - {%- if ing.notes.blocks != [] -%} - {{- ' | ' -}} - Notiz #{{- ingredient_counter | string -}} - {{- '\n ' -}} - {%- endif -%} - {%- endif -%} - {%- if ing.substitutions is defined and ing.substitutions != "" -%} - {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} - {%- if ing.substitutions.blocks != [] -%} - {{- '\n ' -}}
        - {{- '\n ' -}}
      • - {{- '\n ' -}} Ausweichmöglichkeit: - {{- '\n ' -}}
          - {%- for sst in ing.substitutions.blocks -%} - {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} - {%- if sst.amounts.blocks != [] -%} - {%- for amt2 in sst.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt2.amount is defined and amt2.amount != "" and amt2.amount != 0 and amt2.amount != '0' -%} - {{- '\n ' -}}
        • - {{- '\n ' -}} - {%- if sst.processing is defined and sst.processing != "" and sst.processing.blocks is defined and sst.processing.blocks != "" -%} - {%- if sst.processing.blocks != [] -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}} - Verarbeitungshinweis - {%- for tmp_prc2 in sst.processing.blocks -%} - {%- if loop.index == 2 -%} - {{- 'e' -}} - {%- endif -%} - {%- endfor -%} - : - {{- '\n ' -}} -
              - {%- for prc2 in sst.processing.blocks -%} - {{- '\n ' -}}
            • - {{- '\n ' -}} - {{ prc2.process }} - {{- '\n ' -}}
            • - {%- endfor -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}}
          - {%- endif -%} - {%- endif -%} - {%- if sst.notes is defined and sst.notes != "" and sst.notes.blocks is defined and sst.notes.blocks != "" -%} - {%- if ing.notes.blocks != [] -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}} - Notiz - {%- for tmp_nde1 in sst.notes.blocks -%} - {%- if loop.index == 2 -%} - {{- 'en' -}} - {%- endif -%} - {%- endfor -%} - : - {{- '\n ' -}} -
              - {%- for nde2 in sst.notes.blocks -%} - {{- '\n ' -}}
            • - {{- '\n ' -}} - {{ nde2.note }} - {{- '\n ' -}}
            • - {%- endfor -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}}
          - {%- endif -%} - {%- endif -%} - {{- '\n ' -}}
        • - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {{- '\n ' -}}
        - {{- '\n ' -}}
      • - {{- '\n ' -}}
      - {%- endif -%} - {%- endif -%} - {%- endif -%} - {{- '\n ' -}}
    • - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {{- '\n ' -}}
    - {%- else -%} - {{- '\n ' -}}
      - {{- '\n ' -}} Keine Zutaten definiert - {{- '\n ' -}}
    - {%- endif -%} - {%- else -%} - {{- '\n ' -}}
      - {{- '\n ' -}} Keine Zutaten definiert - {{- '\n ' -}}
    - {%- endif -%} + {%- include "zutaten/rezept.html" -%} - - - {%- if child.ingredients is defined and child.ingredients != "" %} - {%- if child.ingredients.blocks != [] -%} - {{- '\n ' -}}
      - {%- for ing1 in child.ingredients.blocks %} - {%- if ing1.ingredient is defined and ing1.ingredient != "" -%} - {%- if ing1.amounts is defined and ing1.amounts != "" and ing1.amounts.blocks is defined and ing1.amounts.blocks != "" -%} - {%- if ing1.amounts.blocks != [] -%} - {%- set ingredient_counter = loop.index -%} - {%- for amt in ing1.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} - {%- if ing1.processing is defined and ing1.processing != "" and ing1.processing.blocks is defined and ing1.processing.blocks != "" -%} - {%- if ing1.processing.blocks != [] -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} - Verarbeitungshinweis - {%- for tmp_prc in ing1.processing.blocks -%} - {%- if loop.index == 2 -%} - {{- 'e' -}} - {%- endif -%} - {%- endfor -%} - {{- ' #' -}} - {{- ingredient_counter | string -}}: - {{- '\n ' -}} -
        - {%- for prc in ing1.processing.blocks -%} - {{- '\n ' -}}
      • - {{- '\n ' -}} - {{ prc.process }} - {{- '\n ' -}}
      • - {%- endfor -%} - {{- '\n ' -}}
      - {{- '\n ' -}}
    • - {{- '\n ' -}}
    - {%- endif -%} - {%- endif -%} - {%- if ing1.notes is defined and ing1.notes != "" and ing1.notes.blocks is defined and ing1.notes.blocks != "" -%} - {%- if ing1.notes.blocks != [] -%} - {{- '\n ' -}}
      - {{- '\n ' -}}
    • - {{- '\n ' -}} - Notiz - {%- for tmp_nde in ing1.notes.blocks -%} - {%- if loop.index == 2 -%} - {{- 'en' -}} - {%- endif -%} - {%- endfor -%} - {{- ' #' -}} {{- ingredient_counter | string -}}: - {{- '\n ' -}} -
        - {%- for nde in ing1.notes.blocks -%} - {{- '\n ' -}}
      • - {{- '\n ' -}} - {{ nde.note }} - {{- '\n ' -}}
      • - {%- endfor -%} - {{- '\n ' -}}
      - {{- '\n ' -}}
    • - {{- '\n ' -}}
    - {%- endif -%} - {%- endif -%} - {{- '\n ' -}} - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {{- '\n ' -}} - {%- else -%} - {{- '\n ' -}}
      - {{- '\n ' -}} Keine Zutaten definiert - {{- '\n ' -}}
    - {%- endif -%} - {%- else -%} - {{- '\n ' -}}
      - {{- '\n ' -}} Keine Zutaten definiert - {{- '\n ' -}}
    - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {%- endif -%} - {#- - - Rezept Schritte... - - -#} - {%- if child.steps is defined and child.steps.blocks is defined and child.steps != "" -%} - {%- if child.steps.blocks is defined and child.steps.blocks != "" and child.steps.blocks != [] -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}}

    Zubereitung

    - {{- '\n ' -}}
      - {%- for stp in child.steps.blocks -%} - {%- if stp.step is defined and stp.step != "" -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} {{ stp.step }} - {%- if stp.haccp_type is defined and stp.haccp_type != "" and stp.haccp_string is defined and stp.haccp_string != "" -%} - {{- '\n ' -}}
        - {{- '\n ' -}}
      • - {{- '\n ' -}}{{ stp.haccp_string }} - {{- '\n ' -}}
      • - {{- '\n ' -}}
      - {%- endif %} - {%- if stp.notes is defined and stp.notes != "" and stp.notes.blocks is defined %} - {%- if stp.notes.blocks != [] -%} - {{- '\n ' -}}
        - {%- for nde in stp.notes.blocks -%} - {{- '\n ' -}}
      • - {{- '\n ' -}} {{- nde.note -}} - {{- '\n ' -}}
      • - {%- endfor -%} - {{- '\n ' -}}
      - {%- endif -%} - {%- endif -%} - {{- '\n ' -}}
    • - {%- endif %} - {%- endfor -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {%- endif -%} - {%- endif -%} - - {%- if child.oven is defined and child.oven != "" and child.oven.blocks or - child.oven_type is defined and child.oven_type != "" or - child.oven_time is defined and child.oven_time != "" -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}}

    Backhinweise

    - {{- '\n ' -}}
      - {%- if child.oven is defined and child.oven != "" and child.oven.blocks is defined and child.oven.blocks != "" -%} - {% if child.oven.blocks is defined and child.oven.blocks != [] -%} - {%- for ovn in child.oven.blocks -%} - {%- if ovn.amount is defined and ovn.amount != "" -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} Ofentemperatur: {{ ovn.amount }} {{ ovn.unit | default('C') }} - {{- '\n ' -}}
    • - {%- endif -%} - {%- endfor -%} {%- endif -%} {%- endif -%} - {%- if child.oven_type is defined and child.oven_type != "" -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} Ofentype: {{ child.oven_type }} - {{- '\n ' -}}
    • - {%- endif -%} - {%- if child.oven_time is defined and child.oven_time != "" -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} Backzeit: {{ child.oven_time }} - {{- '\n ' -}}
    • - {%- endif -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {%- endif -%} - - {#- - {%- if child.source_authors is defined and child.source_authors != "" -%} - {{ '\n \n source_authors:'}} "{{ child.source_authors }}" - {%- endif -%} - {%- if child.x_license is defined and child.x_license != "" -%} - {{ '\n X-License:' }} "{{ child.x_license }}" - {%- endif -%} - {{ '\n source_url:' }} "{{ '../'|url(external=true) }}" - -#} - {#- source: "https://open-recipe-format.readthedocs.io/en/latest/topics/tutorials/walkthrough.html" -#} - {%- endfor -%} {%- endif %} {{- '\n ' -}}
    diff --git a/templates/zutaten.yaml b/templates/zutaten.yaml index e6335e9..b924372 100644 --- a/templates/zutaten.yaml +++ b/templates/zutaten.yaml @@ -17,151 +17,16 @@ usda_lookup: "https://fdc.nal.usda.gov/fdc-app.html" -#} {%- else -%} recipe_name: "{{ this.title }}" {%- endif -%} -{%- if this.recipe_uuid is defined and this.recipe_uuid != "" -%} - {{ '\nrecipe_uuid:' }} "{{ this.recipe_uuid }}" -{%- endif -%} -{%- if this.servings is defined and this.servings != "" -%} - {%- for prt in this.servings.blocks -%} - {%- if loop.index == 1 -%} - {{ '\nyields:' }} - {%- endif -%} - {{ '\n - servings:' }} {{ prt.serving_number | default('1') }} - {%- endfor -%} -{%- endif -%} -{%- if this.ingredients is defined and this.ingredients != "" %} - {{ '\ningredients:' }} - {%- for ing in this.ingredients.blocks %} - {%- if ing.ingredient is defined and ing.ingredient != "" -%} - {{ '\n -' }} "{{ ing.ingredient | lower }}": - {%- if ing.amounts is defined and ing.amounts != "" and ing.amounts.blocks is defined and ing.amounts.blocks != "" -%} - {{ '\n amounts:' }} - {%- if ing.amounts.blocks == [] -%} - {{ ' []' }} - {%- else -%} - {%- for amt in ing.amounts.blocks -%} - {{ '\n - amount:' }} "{{ amt.amount }}" - {{- '\n unit:' }} "{{ amt.unit | default('each') }}" - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} - {%- for prc in ing.processing.blocks -%} - {%- if loop.index == 1 -%} - {{ '\n processing:' }} - {%- endif -%} - {{ '\n -' }} "{{ prc.process }}" - {%- endfor -%} - {%- endif -%} - {%- if ing.notes is defined and ing.notes != "" and ing.notes.blocks is defined and ing.notes.blocks != "" -%} - {%- for nde in ing.notes.blocks -%} - {%- if loop.index == 1 -%} - {{ '\n notes:' }} - {%- endif -%} - {{ '\n -' }} "{{ nde.note }}" - {%- endfor -%} - {%- endif -%} - {%- if ing.usda_num is defined and ing.usda_num != "" -%} - {{ '\n usda_num:' }} {{ ing.usda_num }} - {%- endif -%} - {%- if ing.substitutions is defined and ing.substitutions != "" -%} - {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} - {%- if ing.substitutions.blocks != [] -%} - {%- for sst in ing.substitutions.blocks -%} - {%- if loop.index == 1 -%} - {{ '\n substitutions:' }} - {%- endif -%} - {{ '\n -' }} "{{ sst.ingredient | lower }}" - {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} - {{ '\n amounts:' }} - {%- if sst.amounts.blocks == [] -%} - {{ ' []' }} - {%- else -%} - {%- for amt2 in sst.amounts.blocks -%} - {{ '\n - amount:' }} "{{ amt2.amount }}" - {{- '\n unit:' }} "{{ amt2.unit | default('each') }}" - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- if sst.usda_num is defined and sst.usda_num != "" -%} - {{ '\n usda_num:' }} {{ sst.usda_num }} - {%- endif -%} - {%- if sst.processing is defined and sst.processing != "" and sst.processing.blocks is defined and sst.processing.blocks != "" -%} - {%- for prc2 in sst.processing.blocks -%} - {%- if loop.index == 1 -%} - {{ '\n processing:' }} - {%- endif -%} - {{ '\n -' }} "{{ prc2.process }}" - {%- endfor -%} - {%- endif -%} - {%- if sst.notes is defined and sst.notes != "" and sst.notes.blocks is defined and sst.notes.blocks != "" -%} - {%- for nde2 in sst.notes.blocks -%} - {%- if loop.index == 1 -%} - {{ '\n notes:' }} - {%- endif -%} - {{ '\n -' }} "{{ nde2.note }}" - {%- endfor -%} - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- endif -%} - {%- endif -%} - {%- endfor -%} -{%- else -%} - {{ '\ningredients: []' }} -{%- endif -%} +{{- '\nrecipe_uuid: ' -}} "{{ this._gid }}" -{%- if this.steps is defined and this.steps.blocks is defined and this.steps != "" -%} - {%- if this.steps.blocks is defined and this.steps.blocks != "" and this.steps.blocks != [] -%} - {{ '\n\nsteps:' }} - {%- for stp in this.steps.blocks -%} - {%- if stp.step is defined and stp.step != "" -%} - {{ '\n - step:' }} "{{ stp.step }}" - {%- if stp.haccp_type is defined and stp.haccp_type != "" and stp.haccp_string is defined and stp.haccp_string != "" -%} - {{ '\n haccp:' }} - {{- '\n '}}{{ stp.haccp_type|lower }}: "{{ stp.haccp_string }}" - {%- endif %} - {%- if stp.notes is defined and stp.notes != "" and stp.notes.blocks is defined %} - {%- for nde in stp.notes.blocks %} - {%- if loop.index == 1 -%} - {{ '\n notes:' }} - {%- endif -%} - {{ '\n -' }} "{{ nde.note }}" - {%- endfor %} - {%- endif %} - {%- endif %} - {%- endfor -%} - {{ '\n' }} - {%- else -%} - {{ '\nsteps: []' }} - {%- endif -%} -{%- else -%} - {{ '\n\nsteps: []' }} -{%- endif -%} +{%- include "zutaten/yields.yaml" -%} -{%- if this.oven is defined and this.oven != "" and this.oven.blocks is defined and this.oven.blocks != "" -%} - {% if this.oven.blocks is defined and this.oven.blocks != [] -%} - {%- for ovn in this.oven.blocks -%} - {%- if ovn.amount is defined and ovn.amount != "" -%} - {%- if loop.index == 1 -%} - {{ '\noven_temp:' }} - {%- endif -%} - {{ '\n - amount:' }} {{ ovn.amount }} - {{- '\n unit:' }} {{ ovn.unit | default('C') }} - {%- endif -%} - {%- endfor -%} - {%- endif -%} -{%- endif -%} -{%- if this.oven_type is defined and this.oven_type != "" -%} - {{ '\nX-oven_type:' }} "{{ this.oven_type }}" -{%- endif -%} -{%- if this.oven_time is defined and this.oven_time != "" -%} - {{ '\noven_time:' }} "{{ this.oven_time }}" -{%- endif -%} -{%- if this.oven_fan is defined and this.oven_fan != "" -%} - {{ '\noven_fan:' }} "{{ this.oven_fan | default('Off') }}" -{%- endif -%} +{%- include "zutaten/ingredients.yaml" -%} + +{%- include "zutaten/steps.yaml" -%} + +{%- include "zutaten/oven.yaml" -%} {%- if this.source_authors is defined and this.source_authors != "" -%} {{ '\n\nsource_authors:'}} "{{ this.source_authors }}" diff --git a/templates/zutaten/ingredients.yaml b/templates/zutaten/ingredients.yaml new file mode 100644 index 0000000..4ef858b --- /dev/null +++ b/templates/zutaten/ingredients.yaml @@ -0,0 +1,87 @@ +{#- + Recepie incredient collection / for loop +-#} + +{%- if this.ingredients is defined and this.ingredients != "" %} + {{- '\ningredients:' -}} + {%- for ing in this.ingredients.blocks | default('[]') %} + {%- if ing.ingredient is defined and ing.ingredient != "" -%} + {{- '\n - ' -}} "{{- ing.ingredient | lower -}}": + {%- if ing.amounts is defined and ing.amounts != "" and ing.amounts.blocks is defined and ing.amounts.blocks != "" -%} + {{- '\n amounts:' -}} + {%- if ing.amounts.blocks == [] -%} + {{- ' []' -}} + {%- else -%} + {%- for amt in ing.amounts.blocks -%} + {{- '\n - amount: ' -}} "{{ amt.amount }}" + {{- '\n unit: ' -}} "{{ amt.unit | default('each') }}" + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} + {%- for prc in ing.processing.blocks -%} + {%- if loop.index == 1 -%} + {{- '\n processing:' -}} + {%- endif -%} + {{- '\n - ' -}} "{{ prc.process }}" + {%- endfor -%} + {%- endif -%} + {%- if ing.notes is defined and ing.notes != "" and ing.notes.blocks is defined and ing.notes.blocks != "" -%} + {%- for nde in ing.notes.blocks -%} + {%- if loop.index == 1 -%} + {{- '\n notes:' -}} + {%- endif -%} + {{- '\n - ' -}} "{{ nde.note }}" + {%- endfor -%} + {%- endif -%} + {%- if ing.usda_num is defined and ing.usda_num != "" -%} + {{- '\n usda_num: ' -}} {{- ing.usda_num -}} + {%- endif -%} + {%- if ing.substitutions is defined and ing.substitutions != "" -%} + {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} + {%- if ing.substitutions.blocks != [] -%} + {%- for sst in ing.substitutions.blocks -%} + {%- if loop.index == 1 -%} + {{- '\n substitutions:' -}} + {%- endif -%} + {{- '\n - ' -}} "{{- sst.ingredient | lower -}}" + {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} + {{- '\n amounts:' -}} + {%- if sst.amounts.blocks == [] -%} + {{- ' []' -}} + {%- else -%} + {%- for amt2 in sst.amounts.blocks -%} + {{- '\n - amount:' -}} "{{ amt2.amount }}" + {{- '\n unit:' -}} "{{ amt2.unit | default('each') }}" + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- if sst.usda_num is defined and sst.usda_num != "" -%} + {{- '\n usda_num: ' -}} {{- sst.usda_num -}} + {%- endif -%} + {%- if sst.processing is defined and sst.processing != "" and sst.processing.blocks is defined and sst.processing.blocks != "" -%} + {%- for prc2 in sst.processing.blocks -%} + {%- if loop.index == 1 -%} + {{- '\n processing:' -}} + {%- endif -%} + {{- '\n - ' -}} "{{ prc2.process }}" + {%- endfor -%} + {%- endif -%} + {%- if sst.notes is defined and sst.notes != "" and sst.notes.blocks is defined and sst.notes.blocks != "" -%} + {%- for nde2 in sst.notes.blocks -%} + {%- if loop.index == 1 -%} + {{- '\n notes:' -}} + {%- endif -%} + {{- '\n - ' -}} "{{ nde2.note }}" + {%- endfor -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} +{%- else -%} + {{- '\ningredients: []' -}} +{%- endif -%} + diff --git a/templates/zutaten/oven.yaml b/templates/zutaten/oven.yaml new file mode 100644 index 0000000..1b03646 --- /dev/null +++ b/templates/zutaten/oven.yaml @@ -0,0 +1,28 @@ +{#- + Oven informations +-#} +{%- if this.oven is defined and this.oven != "" and this.oven.blocks is defined and this.oven.blocks != "" -%} + {% if this.oven.blocks is defined and this.oven.blocks != [] -%} + {%- for ovn in this.oven.blocks -%} + {%- if ovn.amount is defined and ovn.amount != "" -%} + {%- if loop.index == 1 -%} + {{- '\noven_temp:' -}} + {%- endif -%} + {{- '\n - amount: ' -}} '{{- ovn.amount -}}' + {{- '\n unit: ' -}} {{- ovn.unit | default('C') -}} + {%- endif -%} + {%- endfor -%} + {%- endif -%} +{%- endif -%} + +{%- if this.oven_type is defined and this.oven_type != "" -%} + {{- '\nX-oven_type: ' -}} "{{- this.oven_type -}}" +{%- endif -%} + +{%- if this.oven_time is defined and this.oven_time != "" -%} + {{- '\noven_time: ' -}} "{{- this.oven_time -}}" +{%- endif -%} + +{%- if this.oven_fan is defined and this.oven_fan != "" -%} + {{- '\noven_fan: ' -}} "{{- this.oven_fan | default('Off') -}}" +{%- endif -%} diff --git a/templates/zutaten/rezept.html b/templates/zutaten/rezept.html new file mode 100644 index 0000000..c4c20c8 --- /dev/null +++ b/templates/zutaten/rezept.html @@ -0,0 +1,115 @@ +{#- + HTML Rendering des Rezept aus dem zutaten.yaml template + für die Detailseite des Rezepts. +-#} + +{%- for child in post.children -%} + {%- if child._template == 'zutaten.yaml' -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}} + {%- if child.recipe_uuid is defined and child.recipe_uuid != "" -%} +

    + {%- else -%} +

    + {%- endif -%} + {%- if child.recipe_name and child.recipe_name != "" -%} + {{ child.recipe_name }}

    + {%- else -%} + {{ child.title }} + {%- endif -%} + {%- if child.servings is defined and child.servings != "" -%} + {%- if child.servings.blocks != [] -%} + {%- include "zutaten/zutaten.html" -%} + {%- endif -%} + {%- endif -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {%- endif -%} +{#- + + Rezept Schritte... + +-#} +{%- if child.steps is defined and child.steps.blocks is defined and child.steps != "" -%} + {%- if child.steps.blocks is defined and child.steps.blocks != "" and child.steps.blocks != [] -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}}

    Zubereitung

    + {{- '\n ' -}}
      + {%- for stp in child.steps.blocks -%} + {%- if stp.step is defined and stp.step != "" -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} {{ stp.step }} + {%- if stp.haccp_type is defined and stp.haccp_type != "" and stp.haccp_string is defined and stp.haccp_string != "" -%} + {{- '\n ' -}}
        + {{- '\n ' -}}
      • + {{- '\n ' -}}{{ stp.haccp_string }} + {{- '\n ' -}}
      • + {{- '\n ' -}}
      + {%- endif %} + {%- if stp.notes is defined and stp.notes != "" and stp.notes.blocks is defined %} + {%- if stp.notes.blocks != [] -%} + {{- '\n ' -}}
        + {%- for nde in stp.notes.blocks -%} + {{- '\n ' -}}
      • + {{- '\n ' -}} {{- nde.note -}} + {{- '\n ' -}}
      • + {%- endfor -%} + {{- '\n ' -}}
      + {%- endif -%} + {%- endif -%} + {{- '\n ' -}}
    • + {%- endif %} + {%- endfor -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {%- endif -%} +{%- endif -%} + +{%- if child.oven is defined and child.oven != "" and child.oven.blocks or + child.oven_type is defined and child.oven_type != "" or + child.oven_time is defined and child.oven_time != "" -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}}

    Backhinweise

    + {{- '\n ' -}}
      + {%- if child.oven is defined and child.oven != "" and child.oven.blocks is defined and child.oven.blocks != "" -%} + {% if child.oven.blocks is defined and child.oven.blocks != [] -%} + {%- for ovn in child.oven.blocks -%} + {%- if ovn.amount is defined and ovn.amount != "" -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} Ofentemperatur: {{ ovn.amount }} {{ ovn.unit | default('C') }} + {{- '\n ' -}}
    • + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- if child.oven_type is defined and child.oven_type != "" -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} Ofentype: {{ child.oven_type }} + {{- '\n ' -}}
    • + {%- endif -%} + {%- if child.oven_time is defined and child.oven_time != "" -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} Backzeit: {{ child.oven_time }} + {{- '\n ' -}}
    • + {%- endif -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}}
    +{%- endif -%} + +{#- + {%- if child.source_authors is defined and child.source_authors != "" -%} + {{ '\n \n source_authors:'}} "{{ child.source_authors }}" + {%- endif -%} + {%- if child.x_license is defined and child.x_license != "" -%} + {{ '\n X-License:' }} "{{ child.x_license }}" + {%- endif -%} + {{ '\n source_url:' }} "{{ '../'|url(external=true) }}" +-#} + {#- source: "https://open-recipe-format.readthedocs.io/en/latest/topics/tutorials/walkthrough.html" -#} + +{%- endfor -%} diff --git a/templates/zutaten/steps.yaml b/templates/zutaten/steps.yaml new file mode 100644 index 0000000..eb80d09 --- /dev/null +++ b/templates/zutaten/steps.yaml @@ -0,0 +1,30 @@ +{#- + Recipe Steps for loop +-#} +{%- if this.steps is defined and this.steps.blocks is defined and this.steps != "" -%} + {%- if this.steps.blocks is defined and this.steps.blocks != "" and this.steps.blocks != [] -%} + {{- '\n\nsteps:' -}} + {%- for stp in this.steps.blocks -%} + {%- if stp.step is defined and stp.step != "" -%} + {{- '\n - step: ' -}} "{{- stp.step -}}" + {%- if stp.haccp_type is defined and stp.haccp_type != "" and stp.haccp_string is defined and stp.haccp_string != "" -%} + {{- '\n haccp:' -}} + {{- '\n ' -}} {{- stp.haccp_type|lower -}}: "{{- stp.haccp_string -}}" + {%- endif %} + {%- if stp.notes is defined and stp.notes != "" and stp.notes.blocks is defined %} + {%- for nde in stp.notes.blocks %} + {%- if loop.index == 1 -%} + {{- '\n notes:' -}} + {%- endif -%} + {{- '\n - ' -}} "{{ nde.note }}" + {%- endfor %} + {%- endif %} + {%- endif %} + {%- endfor -%} + {{- '\n' -}} + {%- else -%} + {{- '\nsteps: []' -}} + {%- endif -%} +{%- else -%} + {{- '\n\nsteps: []' -}} +{%- endif -%} diff --git a/templates/zutaten/yields.yaml b/templates/zutaten/yields.yaml new file mode 100644 index 0000000..dab962f --- /dev/null +++ b/templates/zutaten/yields.yaml @@ -0,0 +1,11 @@ +{#- + Template to collect yields for the recipe,yml +-#} +{%- if this.servings is defined and this.servings != "" -%} + {%- for prt in this.servings.blocks -%} + {%- if loop.index == 1 -%} + {{ '\nyields:' }} + {%- endif -%} + {{ '\n - servings:' }} {{ prt.serving_number | default('1') }} + {%- endfor -%} +{%- endif -%} diff --git a/templates/zutaten/zutaten.html b/templates/zutaten/zutaten.html new file mode 100644 index 0000000..a85f71e --- /dev/null +++ b/templates/zutaten/zutaten.html @@ -0,0 +1,225 @@ +{%- for prt in child.servings.blocks -%} + {{- '\n ' -}} +

    Portionsgröße: Für {{ prt.serving_number | default('1') }} + {{- ' ' -}} + {%- if prt.serving_units is defined and prt.serving_units != "" -%} + {{- prt.serving_units -}} + {%- else -%} + Stück + {%- endif -%} +

    + {%- set prt_loop = loop.index -%} + {%- if child.ingredients is defined and child.ingredients != "" %} + {%- if child.ingredients.blocks != [] -%} + {{- '\n ' -}}
      + {%- for ing in child.ingredients.blocks %} + {%- if ing.ingredient is defined and ing.ingredient != "" -%} + {%- if ing.amounts is defined and ing.amounts != "" and ing.amounts.blocks is defined and ing.amounts.blocks != "" -%} + {%- if ing.amounts.blocks != [] -%} + {%- set ingredient_counter = loop.index -%} + {%- for amt in ing.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} + {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} + {%- if ing.processing.blocks != [] -%} + {{- ' | ' -}} + Verarbeitungshinweis #{{- ingredient_counter | string -}} + {%- endif -%} + {%- endif -%} + {%- if ing.notes is defined and ing.notes != "" and ing.notes.blocks is defined and ing.notes.blocks != "" -%} + {%- if ing.notes.blocks != [] -%} + {{- ' | ' -}} + Notiz #{{- ingredient_counter | string -}} + {{- '\n ' -}} + {%- endif -%} + {%- endif -%} + {%- if ing.substitutions is defined and ing.substitutions != "" -%} + {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} + {%- if ing.substitutions.blocks != [] -%} + {{- '\n ' -}}
        + {{- '\n ' -}}
      • + {{- '\n ' -}} Ausweichmöglichkeit: + {{- '\n ' -}}
          + {%- for sst in ing.substitutions.blocks -%} + {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} + {%- if sst.amounts.blocks != [] -%} + {%- for amt2 in sst.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt2.amount is defined and amt2.amount != "" and amt2.amount != 0 and amt2.amount != '0' -%} + {{- '\n ' -}}
        • + {{- '\n ' -}} + {%- if sst.processing is defined and sst.processing != "" and sst.processing.blocks is defined and sst.processing.blocks != "" -%} + {%- if sst.processing.blocks != [] -%} + {{- '\n ' -}}
            + {{- '\n ' -}}
          • + {{- '\n ' -}} + Verarbeitungshinweis + {%- for tmp_prc2 in sst.processing.blocks -%} + {%- if loop.index == 2 -%} + {{- 'e' -}} + {%- endif -%} + {%- endfor -%} + : + {{- '\n ' -}} +
              + {%- for prc2 in sst.processing.blocks -%} + {{- '\n ' -}}
            • + {{- '\n ' -}} + {{ prc2.process }} + {{- '\n ' -}}
            • + {%- endfor -%} + {{- '\n ' -}}
            + {{- '\n ' -}}
          • + {{- '\n ' -}}
          + {%- endif -%} + {%- endif -%} + {%- if sst.notes is defined and sst.notes != "" and sst.notes.blocks is defined and sst.notes.blocks != "" -%} + {%- if ing.notes.blocks != [] -%} + {{- '\n ' -}}
            + {{- '\n ' -}}
          • + {{- '\n ' -}} + Notiz + {%- for tmp_nde1 in sst.notes.blocks -%} + {%- if loop.index == 2 -%} + {{- 'en' -}} + {%- endif -%} + {%- endfor -%} + : + {{- '\n ' -}} +
              + {%- for nde2 in sst.notes.blocks -%} + {{- '\n ' -}}
            • + {{- '\n ' -}} + {{ nde2.note }} + {{- '\n ' -}}
            • + {%- endfor -%} + {{- '\n ' -}}
            + {{- '\n ' -}}
          • + {{- '\n ' -}}
          + {%- endif -%} + {%- endif -%} + {{- '\n ' -}}
        • + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {{- '\n ' -}}
        + {{- '\n ' -}}
      • + {{- '\n ' -}}
      + {%- endif -%} + {%- endif -%} + {%- endif -%} + {{- '\n ' -}}
    • + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {{- '\n ' -}}
    + {%- else -%} + {{- '\n ' -}}
      + {{- '\n ' -}} Keine Zutaten definiert + {{- '\n ' -}}
    + {%- endif -%} + {%- else -%} + {{- '\n ' -}}
      + {{- '\n ' -}} Keine Zutaten definiert + {{- '\n ' -}}
    + {%- endif -%} + + + {%- if child.ingredients is defined and child.ingredients != "" %} + {%- if child.ingredients.blocks != [] -%} + {{- '\n ' -}}
      + {%- for ing1 in child.ingredients.blocks %} + {%- if ing1.ingredient is defined and ing1.ingredient != "" -%} + {%- if ing1.amounts is defined and ing1.amounts != "" and ing1.amounts.blocks is defined and ing1.amounts.blocks != "" -%} + {%- if ing1.amounts.blocks != [] -%} + {%- set ingredient_counter = loop.index -%} + {%- for amt in ing1.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} + {%- if ing1.processing is defined and ing1.processing != "" and ing1.processing.blocks is defined and ing1.processing.blocks != "" -%} + {%- if ing1.processing.blocks != [] -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} + Verarbeitungshinweis + {%- for tmp_prc in ing1.processing.blocks -%} + {%- if loop.index == 2 -%} + {{- 'e' -}} + {%- endif -%} + {%- endfor -%} + {{- ' #' -}} + {{- ingredient_counter | string -}}: + {{- '\n ' -}} +
        + {%- for prc in ing1.processing.blocks -%} + {{- '\n ' -}}
      • + {{- '\n ' -}} + {{ prc.process }} + {{- '\n ' -}}
      • + {%- endfor -%} + {{- '\n ' -}}
      + {{- '\n ' -}}
    • + {{- '\n ' -}}
    + {%- endif -%} + {%- endif -%} + {%- if ing1.notes is defined and ing1.notes != "" and ing1.notes.blocks is defined and ing1.notes.blocks != "" -%} + {%- if ing1.notes.blocks != [] -%} + {{- '\n ' -}}
      + {{- '\n ' -}}
    • + {{- '\n ' -}} + Notiz + {%- for tmp_nde in ing1.notes.blocks -%} + {%- if loop.index == 2 -%} + {{- 'en' -}} + {%- endif -%} + {%- endfor -%} + {{- ' #' -}} {{- ingredient_counter | string -}}: + {{- '\n ' -}} +
        + {%- for nde in ing1.notes.blocks -%} + {{- '\n ' -}}
      • + {{- '\n ' -}} + {{ nde.note }} + {{- '\n ' -}}
      • + {%- endfor -%} + {{- '\n ' -}}
      + {{- '\n ' -}}
    • + {{- '\n ' -}}
    + {%- endif -%} + {%- endif -%} + {{- '\n ' -}} + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {{- '\n ' -}} + {%- else -%} + {{- '\n ' -}}
      + {{- '\n ' -}} Keine Zutaten definiert + {{- '\n ' -}}
    + {%- endif -%} + {%- else -%} + {{- '\n ' -}}
      + {{- '\n ' -}} Keine Zutaten definiert + {{- '\n ' -}}
    + {%- endif -%} +{%- endfor -%} -- 2.39.5 From ee82ebf6b4f9a66ccd590f3b184fa17124a3a918 Mon Sep 17 00:00:00 2001 From: L3D Date: Sat, 31 Jul 2021 21:13:24 +0200 Subject: [PATCH 06/78] Expand templates --- content/rezept/klassisch/contents.lr | 3 +- models/rezept-post.ini | 5 + models/rezept.ini | 2 +- templates/macros/rezept.html | 2 +- templates/zutaten/hinweise.html | 35 +++++ templates/zutaten/rezept.html | 99 +++--------- templates/zutaten/zubereitung.html | 35 +++++ templates/zutaten/zutat_menge.html | 117 +++++++++++++++ templates/zutaten/zutat_notes.html | 66 ++++++++ templates/zutaten/zutaten.html | 215 ++++----------------------- 10 files changed, 304 insertions(+), 275 deletions(-) create mode 100644 templates/zutaten/hinweise.html create mode 100644 templates/zutaten/zubereitung.html create mode 100644 templates/zutaten/zutat_menge.html create mode 100644 templates/zutaten/zutat_notes.html diff --git a/content/rezept/klassisch/contents.lr b/content/rezept/klassisch/contents.lr index a95fc21..9a0c4db 100644 --- a/content/rezept/klassisch/contents.lr +++ b/content/rezept/klassisch/contents.lr @@ -4,8 +4,7 @@ author: L3D --- body: -klassischer Waffelteig - +Der klassischer Waffelteig ist zu finden auf: [rezept.yaml](rezept.yaml) --- pub_date: 2021-07-19 diff --git a/models/rezept-post.ini b/models/rezept-post.ini index 3017185..b77a7b2 100644 --- a/models/rezept-post.ini +++ b/models/rezept-post.ini @@ -33,5 +33,10 @@ type = boolean label = Body type = markdown +[fields.weight] +label = Ranking +default = 128 +type = integer + [children] model = zutaten diff --git a/models/rezept.ini b/models/rezept.ini index 95e5e1d..e75c688 100644 --- a/models/rezept.ini +++ b/models/rezept.ini @@ -20,7 +20,7 @@ type = markdown [children] model = rezept-post -order_by = -pub_date, title +order_by = -weight, title [pagination] enabled = true diff --git a/templates/macros/rezept.html b/templates/macros/rezept.html index ad8171f..90eca1e 100644 --- a/templates/macros/rezept.html +++ b/templates/macros/rezept.html @@ -9,7 +9,7 @@ {% endif %} {{- '\n ' -}}
    {{- '\n ' -}} {{- '\n ' -}}
    {{- '\n ' -}} diff --git a/templates/zutaten/hinweise.html b/templates/zutaten/hinweise.html new file mode 100644 index 0000000..d3d1421 --- /dev/null +++ b/templates/zutaten/hinweise.html @@ -0,0 +1,35 @@ +{#- + Hinweise zum Backen... +-#} +{%- if child.oven is defined and child.oven != "" and child.oven.blocks or + child.oven_type is defined and child.oven_type != "" or + child.oven_time is defined and child.oven_time != "" -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}}

    Backhinweise

    + {{- '\n ' -}}
      + {%- if child.oven is defined and child.oven != "" and child.oven.blocks is defined and child.oven.blocks != "" -%} + {% if child.oven.blocks is defined and child.oven.blocks != [] -%} + {%- for ovn in child.oven.blocks -%} + {%- if ovn.amount is defined and ovn.amount != "" -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} Ofentemperatur: {{ ovn.amount }} {{ ovn.unit | default('C') }} + {{- '\n ' -}}
    • + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- if child.oven_type is defined and child.oven_type != "" -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} Ofentype: {{ child.oven_type }} + {{- '\n ' -}}
    • + {%- endif -%} + {%- if child.oven_time is defined and child.oven_time != "" -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} Backzeit: {{ child.oven_time }} + {{- '\n ' -}}
    • + {%- endif -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}}
    +{%- endif -%} diff --git a/templates/zutaten/rezept.html b/templates/zutaten/rezept.html index c4c20c8..a1171ba 100644 --- a/templates/zutaten/rezept.html +++ b/templates/zutaten/rezept.html @@ -5,6 +5,11 @@ {%- for child in post.children -%} {%- if child._template == 'zutaten.yaml' -%} + {#- + + Zunächst werden die Zutaten des Rezept definiert... + + -#} {{- '\n ' -}}
    {{- '\n ' -}}
    {{- '\n ' -}} @@ -20,96 +25,28 @@ {%- endif -%} {%- if child.servings is defined and child.servings != "" -%} {%- if child.servings.blocks != [] -%} + {%- include "zutaten/zutaten.html" -%} + {%- endif -%} {%- endif -%} {{- '\n ' -}}
    {{- '\n ' -}}
    - {%- endif -%} -{#- + {#- - Rezept Schritte... + Nachdem die Zutaten des Rezept nun angegeben sind, + folgt die Zubereitung der waffelfähigen Teigprodukte... --#} -{%- if child.steps is defined and child.steps.blocks is defined and child.steps != "" -%} - {%- if child.steps.blocks is defined and child.steps.blocks != "" and child.steps.blocks != [] -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}}

    Zubereitung

    - {{- '\n ' -}}
      - {%- for stp in child.steps.blocks -%} - {%- if stp.step is defined and stp.step != "" -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} {{ stp.step }} - {%- if stp.haccp_type is defined and stp.haccp_type != "" and stp.haccp_string is defined and stp.haccp_string != "" -%} - {{- '\n ' -}}
        - {{- '\n ' -}}
      • - {{- '\n ' -}}{{ stp.haccp_string }} - {{- '\n ' -}}
      • - {{- '\n ' -}}
      - {%- endif %} - {%- if stp.notes is defined and stp.notes != "" and stp.notes.blocks is defined %} - {%- if stp.notes.blocks != [] -%} - {{- '\n ' -}}
        - {%- for nde in stp.notes.blocks -%} - {{- '\n ' -}}
      • - {{- '\n ' -}} {{- nde.note -}} - {{- '\n ' -}}
      • - {%- endfor -%} - {{- '\n ' -}}
      - {%- endif -%} - {%- endif -%} - {{- '\n ' -}}
    • - {%- endif %} - {%- endfor -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {%- endif -%} -{%- endif -%} - -{%- if child.oven is defined and child.oven != "" and child.oven.blocks or - child.oven_type is defined and child.oven_type != "" or - child.oven_time is defined and child.oven_time != "" -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}}

    Backhinweise

    - {{- '\n ' -}}
      - {%- if child.oven is defined and child.oven != "" and child.oven.blocks is defined and child.oven.blocks != "" -%} - {% if child.oven.blocks is defined and child.oven.blocks != [] -%} - {%- for ovn in child.oven.blocks -%} - {%- if ovn.amount is defined and ovn.amount != "" -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} Ofentemperatur: {{ ovn.amount }} {{ ovn.unit | default('C') }} - {{- '\n ' -}}
    • - {%- endif -%} - {%- endfor -%} + -#} + {%- if child.steps is defined and child.steps.blocks is defined and child.steps != "" -%} + {%- if child.steps.blocks is defined and child.steps.blocks != "" and child.steps.blocks != [] -%} + {%- include "zutaten/zubereitung.html" -%} + {%- endif -%} {%- endif -%} - {%- endif -%} - {%- if child.oven_type is defined and child.oven_type != "" -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} Ofentype: {{ child.oven_type }} - {{- '\n ' -}}
    • - {%- endif -%} - {%- if child.oven_time is defined and child.oven_time != "" -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} Backzeit: {{ child.oven_time }} - {{- '\n ' -}}
    • - {%- endif -%} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}}
    -{%- endif -%} -{#- - {%- if child.source_authors is defined and child.source_authors != "" -%} - {{ '\n \n source_authors:'}} "{{ child.source_authors }}" - {%- endif -%} - {%- if child.x_license is defined and child.x_license != "" -%} - {{ '\n X-License:' }} "{{ child.x_license }}" - {%- endif -%} - {{ '\n source_url:' }} "{{ '../'|url(external=true) }}" --#} + {%- include "zutaten/hinweise.html" -%} + {#- source: "https://open-recipe-format.readthedocs.io/en/latest/topics/tutorials/walkthrough.html" -#} + {%- endif -%} {%- endfor -%} diff --git a/templates/zutaten/zubereitung.html b/templates/zutaten/zubereitung.html new file mode 100644 index 0000000..13e0734 --- /dev/null +++ b/templates/zutaten/zubereitung.html @@ -0,0 +1,35 @@ +{#- + Die Zubereitung des Rezept... +-#} +{{- '\n ' -}}
    +{{- '\n ' -}}
    +{{- '\n ' -}}

    Zubereitung

    +{{- '\n ' -}}
      +{%- for stp in child.steps.blocks -%} + {%- if stp.step is defined and stp.step != "" -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} {{ stp.step }} + {%- if stp.haccp_type is defined and stp.haccp_type != "" and stp.haccp_string is defined and stp.haccp_string != "" -%} + {{- '\n ' -}}
        + {{- '\n ' -}}
      • + {{- '\n ' -}}{{ stp.haccp_string }} + {{- '\n ' -}}
      • + {{- '\n ' -}}
      + {%- endif %} + {%- if stp.notes is defined and stp.notes != "" and stp.notes.blocks is defined %} + {%- if stp.notes.blocks != [] -%} + {{- '\n ' -}}
        + {%- for nde in stp.notes.blocks -%} + {{- '\n ' -}}
      • + {{- '\n ' -}} {{- nde.note -}} + {{- '\n ' -}}
      • + {%- endfor -%} + {{- '\n ' -}}
      + {%- endif -%} + {%- endif -%} + {{- '\n ' -}}
    • + {%- endif %} +{%- endfor -%} +{{- '\n ' -}}
    +{{- '\n ' -}}
    +{{- '\n ' -}}
    diff --git a/templates/zutaten/zutat_menge.html b/templates/zutaten/zutat_menge.html new file mode 100644 index 0000000..f0d845b --- /dev/null +++ b/templates/zutaten/zutat_menge.html @@ -0,0 +1,117 @@ + {%- if ing.ingredient is defined and ing.ingredient != "" -%} + {%- if ing.amounts is defined and ing.amounts != "" and ing.amounts.blocks is defined and ing.amounts.blocks != "" -%} + {%- if ing.amounts.blocks != [] -%} + {%- set ingredient_counter = loop.index -%} + {%- for amt in ing.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} + {{- '\n ' -}}
  • + {{- '\n ' -}} + {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} + {%- if ing.processing.blocks != [] -%} + {{- ' | ' -}} + Verarbeitungshinweis #{{- ingredient_counter | string -}} + {%- endif -%} + {%- endif -%} + {%- if ing.notes is defined and ing.notes != "" and ing.notes.blocks is defined and ing.notes.blocks != "" -%} + {%- if ing.notes.blocks != [] -%} + {{- ' | ' -}} + Notiz #{{- ingredient_counter | string -}} + {{- '\n ' -}} + {%- endif -%} + {%- endif -%} + {%- if ing.substitutions is defined and ing.substitutions != "" -%} + {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} + {%- if ing.substitutions.blocks != [] -%} + {{- '\n ' -}}
      + {{- '\n ' -}}
    • + {{- '\n ' -}} Ausweichmöglichkeit: + {{- '\n ' -}}
        + {%- for sst in ing.substitutions.blocks -%} + {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} + {%- if sst.amounts.blocks != [] -%} + {%- for amt2 in sst.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt2.amount is defined and amt2.amount != "" and amt2.amount != 0 and amt2.amount != '0' -%} + {{- '\n ' -}}
      • + {{- '\n ' -}} + {%- if sst.processing is defined and sst.processing != "" and sst.processing.blocks is defined and sst.processing.blocks != "" -%} + {%- if sst.processing.blocks != [] -%} + {{- '\n ' -}}
          + {{- '\n ' -}}
        • + {{- '\n ' -}} + Verarbeitungshinweis + {%- for tmp_prc2 in sst.processing.blocks -%} + {%- if loop.index == 2 -%} + {{- 'e' -}} + {%- endif -%} + {%- endfor -%} + : + {{- '\n ' -}} +
            + {%- for prc2 in sst.processing.blocks -%} + {{- '\n ' -}}
          • + {{- '\n ' -}} + {{ prc2.process }} + {{- '\n ' -}}
          • + {%- endfor -%} + {{- '\n ' -}}
          + {{- '\n ' -}}
        • + {{- '\n ' -}}
        + {%- endif -%} + {%- endif -%} + {%- if sst.notes is defined and sst.notes != "" and sst.notes.blocks is defined and sst.notes.blocks != "" -%} + {%- if ing.notes.blocks != [] -%} + {{- '\n ' -}}
          + {{- '\n ' -}}
        • + {{- '\n ' -}} + Notiz + {%- for tmp_nde1 in sst.notes.blocks -%} + {%- if loop.index == 2 -%} + {{- 'en' -}} + {%- endif -%} + {%- endfor -%} + : + {{- '\n ' -}} +
            + {%- for nde2 in sst.notes.blocks -%} + {{- '\n ' -}}
          • + {{- '\n ' -}} + {{ nde2.note }} + {{- '\n ' -}}
          • + {%- endfor -%} + {{- '\n ' -}}
          + {{- '\n ' -}}
        • + {{- '\n ' -}}
        + {%- endif -%} + {%- endif -%} + {{- '\n ' -}}
      • + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {{- '\n ' -}}
      + {{- '\n ' -}}
    • + {{- '\n ' -}}
    + {%- endif -%} + {%- endif -%} + {%- endif -%} + {{- '\n ' -}}
  • + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} + diff --git a/templates/zutaten/zutat_notes.html b/templates/zutaten/zutat_notes.html new file mode 100644 index 0000000..8d08df1 --- /dev/null +++ b/templates/zutaten/zutat_notes.html @@ -0,0 +1,66 @@ + {%- for ing1 in child.ingredients.blocks %} + {%- if ing1.ingredient is defined and ing1.ingredient != "" -%} + {%- if ing1.amounts is defined and ing1.amounts != "" and ing1.amounts.blocks is defined and ing1.amounts.blocks != "" -%} + {%- if ing1.amounts.blocks != [] -%} + {%- set ingredient_counter = loop.index -%} + {%- for amt in ing1.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} + {%- if ing1.processing is defined and ing1.processing != "" and ing1.processing.blocks is defined and ing1.processing.blocks != "" -%} + {%- if ing1.processing.blocks != [] -%} + {{- '\n ' -}}
  • + {{- '\n ' -}} + Verarbeitungshinweis + {%- for tmp_prc in ing1.processing.blocks -%} + {%- if loop.index == 2 -%} + {{- 'e' -}} + {%- endif -%} + {%- endfor -%} + {{- ' #' -}} + {{- ingredient_counter | string -}}: + {{- '\n ' -}} +
      + {%- for prc in ing1.processing.blocks -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} + {{ prc.process }} + {{- '\n ' -}}
    • + {%- endfor -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
  • + {{- '\n ' -}} + {%- endif -%} + {%- endif -%} + {%- if ing1.notes is defined and ing1.notes != "" and ing1.notes.blocks is defined and ing1.notes.blocks != "" -%} + {%- if ing1.notes.blocks != [] -%} + {{- '\n ' -}}
      + {{- '\n ' -}}
    • + {{- '\n ' -}} + Notiz + {%- for tmp_nde in ing1.notes.blocks -%} + {%- if loop.index == 2 -%} + {{- 'en' -}} + {%- endif -%} + {%- endfor -%} + {{- ' #' -}} {{- ingredient_counter | string -}}: + {{- '\n ' -}} +
        + {%- for nde in ing1.notes.blocks -%} + {{- '\n ' -}}
      • + {{- '\n ' -}} + {{ nde.note }} + {{- '\n ' -}}
      • + {%- endfor -%} + {{- '\n ' -}}
      + {{- '\n ' -}}
    • + {{- '\n ' -}}
    + {%- endif -%} + {%- endif -%} + {{- '\n ' -}} + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} diff --git a/templates/zutaten/zutaten.html b/templates/zutaten/zutaten.html index a85f71e..0a82190 100644 --- a/templates/zutaten/zutaten.html +++ b/templates/zutaten/zutaten.html @@ -1,136 +1,31 @@ +{#- + Hier werden die Zutaten für das Rezept gerendert... +-#} {%- for prt in child.servings.blocks -%} + {#- + + Zunächst schauen wir, für was für Mengen das Rezept definiert ist. + Für jede fefinierte Menge haben wir einen neuen Durchlauf in dem for loop + + -#} {{- '\n ' -}}

    Portionsgröße: Für {{ prt.serving_number | default('1') }} - {{- ' ' -}} - {%- if prt.serving_units is defined and prt.serving_units != "" -%} - {{- prt.serving_units -}} - {%- else -%} - Stück - {%- endif -%} + {{- ' ' -}} + {{- prt.serving_units| default('Stück') -}}

    {%- set prt_loop = loop.index -%} + {#- + in der prt_loop variable speichern wir in welchem loop index die zutat steht. + Damit greifen wir später auf den selben index zu. + -#} {%- if child.ingredients is defined and child.ingredients != "" %} {%- if child.ingredients.blocks != [] -%} {{- '\n ' -}}
      - {%- for ing in child.ingredients.blocks %} - {%- if ing.ingredient is defined and ing.ingredient != "" -%} - {%- if ing.amounts is defined and ing.amounts != "" and ing.amounts.blocks is defined and ing.amounts.blocks != "" -%} - {%- if ing.amounts.blocks != [] -%} - {%- set ingredient_counter = loop.index -%} - {%- for amt in ing.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} - {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} - {%- if ing.processing.blocks != [] -%} - {{- ' | ' -}} - Verarbeitungshinweis #{{- ingredient_counter | string -}} - {%- endif -%} - {%- endif -%} - {%- if ing.notes is defined and ing.notes != "" and ing.notes.blocks is defined and ing.notes.blocks != "" -%} - {%- if ing.notes.blocks != [] -%} - {{- ' | ' -}} - Notiz #{{- ingredient_counter | string -}} - {{- '\n ' -}} - {%- endif -%} - {%- endif -%} - {%- if ing.substitutions is defined and ing.substitutions != "" -%} - {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} - {%- if ing.substitutions.blocks != [] -%} - {{- '\n ' -}}
        - {{- '\n ' -}}
      • - {{- '\n ' -}} Ausweichmöglichkeit: - {{- '\n ' -}}
          - {%- for sst in ing.substitutions.blocks -%} - {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} - {%- if sst.amounts.blocks != [] -%} - {%- for amt2 in sst.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt2.amount is defined and amt2.amount != "" and amt2.amount != 0 and amt2.amount != '0' -%} - {{- '\n ' -}}
        • - {{- '\n ' -}} - {%- if sst.processing is defined and sst.processing != "" and sst.processing.blocks is defined and sst.processing.blocks != "" -%} - {%- if sst.processing.blocks != [] -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}} - Verarbeitungshinweis - {%- for tmp_prc2 in sst.processing.blocks -%} - {%- if loop.index == 2 -%} - {{- 'e' -}} - {%- endif -%} - {%- endfor -%} - : - {{- '\n ' -}} -
              - {%- for prc2 in sst.processing.blocks -%} - {{- '\n ' -}}
            • - {{- '\n ' -}} - {{ prc2.process }} - {{- '\n ' -}}
            • - {%- endfor -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}}
          - {%- endif -%} - {%- endif -%} - {%- if sst.notes is defined and sst.notes != "" and sst.notes.blocks is defined and sst.notes.blocks != "" -%} - {%- if ing.notes.blocks != [] -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}} - Notiz - {%- for tmp_nde1 in sst.notes.blocks -%} - {%- if loop.index == 2 -%} - {{- 'en' -}} - {%- endif -%} - {%- endfor -%} - : - {{- '\n ' -}} -
              - {%- for nde2 in sst.notes.blocks -%} - {{- '\n ' -}}
            • - {{- '\n ' -}} - {{ nde2.note }} - {{- '\n ' -}}
            • - {%- endfor -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}}
          - {%- endif -%} - {%- endif -%} - {{- '\n ' -}}
        • - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {{- '\n ' -}}
        - {{- '\n ' -}}
      • - {{- '\n ' -}}
      - {%- endif -%} - {%- endif -%} - {%- endif -%} - {{- '\n ' -}}
    • - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- endif -%} - {%- endfor -%} + + {%- include "zutaten/zutat_menge.html" -%} + {{- '\n ' -}}
    - {%- else -%} + {%- else -%} {{- '\n ' -}}
      {{- '\n ' -}} Keine Zutaten definiert {{- '\n ' -}}
    @@ -145,72 +40,12 @@ {%- if child.ingredients is defined and child.ingredients != "" %} {%- if child.ingredients.blocks != [] -%} {{- '\n ' -}}
      - {%- for ing1 in child.ingredients.blocks %} - {%- if ing1.ingredient is defined and ing1.ingredient != "" -%} - {%- if ing1.amounts is defined and ing1.amounts != "" and ing1.amounts.blocks is defined and ing1.amounts.blocks != "" -%} - {%- if ing1.amounts.blocks != [] -%} - {%- set ingredient_counter = loop.index -%} - {%- for amt in ing1.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} - {%- if ing1.processing is defined and ing1.processing != "" and ing1.processing.blocks is defined and ing1.processing.blocks != "" -%} - {%- if ing1.processing.blocks != [] -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} - Verarbeitungshinweis - {%- for tmp_prc in ing1.processing.blocks -%} - {%- if loop.index == 2 -%} - {{- 'e' -}} - {%- endif -%} - {%- endfor -%} - {{- ' #' -}} - {{- ingredient_counter | string -}}: - {{- '\n ' -}} -
        - {%- for prc in ing1.processing.blocks -%} - {{- '\n ' -}}
      • - {{- '\n ' -}} - {{ prc.process }} - {{- '\n ' -}}
      • - {%- endfor -%} - {{- '\n ' -}}
      - {{- '\n ' -}}
    • - {{- '\n ' -}}
    - {%- endif -%} - {%- endif -%} - {%- if ing1.notes is defined and ing1.notes != "" and ing1.notes.blocks is defined and ing1.notes.blocks != "" -%} - {%- if ing1.notes.blocks != [] -%} - {{- '\n ' -}}
      - {{- '\n ' -}}
    • - {{- '\n ' -}} - Notiz - {%- for tmp_nde in ing1.notes.blocks -%} - {%- if loop.index == 2 -%} - {{- 'en' -}} - {%- endif -%} - {%- endfor -%} - {{- ' #' -}} {{- ingredient_counter | string -}}: - {{- '\n ' -}} -
        - {%- for nde in ing1.notes.blocks -%} - {{- '\n ' -}}
      • - {{- '\n ' -}} - {{ nde.note }} - {{- '\n ' -}}
      • - {%- endfor -%} - {{- '\n ' -}}
      - {{- '\n ' -}}
    • - {{- '\n ' -}}
    - {%- endif -%} - {%- endif -%} - {{- '\n ' -}} - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- endif -%} - {%- endfor -%} + + + {%- include "zutaten/zutat_notes.html" -%} + + + {{- '\n ' -}} {%- else -%} {{- '\n ' -}}
      -- 2.39.5 From 0f7cf7892d95e6c857fb163e03d97f4dfd2f00ce Mon Sep 17 00:00:00 2001 From: L3D Date: Sun, 8 Aug 2021 19:02:09 +0200 Subject: [PATCH 07/78] improve HTML rendering --- content/contents.lr | 8 +- content/rezept/klassisch/contents.lr | 2 + .../rezept/klassisch/rezept.yaml/contents.lr | 8 + content/waffle_apfelmus.jpg | 3 + flowblocks/flow_processing.ini | 7 + templates/zutaten/rezept.html | 2 + templates/zutaten/zutat_menge.html | 195 ++++++++---------- templates/zutaten/zutaten.html | 9 +- 8 files changed, 121 insertions(+), 113 deletions(-) create mode 100644 content/waffle_apfelmus.jpg diff --git a/content/contents.lr b/content/contents.lr index c155552..b76f1db 100644 --- a/content/contents.lr +++ b/content/contents.lr @@ -55,7 +55,7 @@ inner_box: ##### flow_one_innerbox_section ##### title: klassischer Waffelteig ----- -box_image: sweet_waffle.jpg +box_image: waffle_apfelmus.jpg ----- box_content: @@ -66,6 +66,8 @@ Aus Eiern, Butter, Zucker, Mehl, Milch, Vanille, Backpulver und optional ein wen box_link: klassische Waffel ----- box_url: /rezept/klassisch/ +----- +image_alt: ##### flow_one_innerbox_section ##### title: laktosefreier Waffelteig ----- @@ -80,6 +82,8 @@ Das gilt für alle Zutaten, auser den Eiern. Mit beispielsweise veganer Magarine box_link: laktosefrei ----- box_url: /rezept/laktose/ +----- +image_alt: ##### flow_one_innerbox_section ##### title: Waffel mit Akzent ----- @@ -94,6 +98,8 @@ Es gibt Zimt, Kardamom, Chilli, frische Kräuter und vieles mehr. Probiert es do box_link: verfeinerter Teig ----- box_url: /rezept/gewuerz/ +----- +image_alt: #### flow_seperator #### #### flow_boxes_section #### title: Sei teil der Waffel Community diff --git a/content/rezept/klassisch/contents.lr b/content/rezept/klassisch/contents.lr index 9a0c4db..d09be94 100644 --- a/content/rezept/klassisch/contents.lr +++ b/content/rezept/klassisch/contents.lr @@ -10,3 +10,5 @@ Der klassischer Waffelteig ist zu finden auf: pub_date: 2021-07-19 --- orf: yes +--- +weight: 1 diff --git a/content/rezept/klassisch/rezept.yaml/contents.lr b/content/rezept/klassisch/rezept.yaml/contents.lr index 37c22c1..9e2d013 100644 --- a/content/rezept/klassisch/rezept.yaml/contents.lr +++ b/content/rezept/klassisch/rezept.yaml/contents.lr @@ -41,10 +41,16 @@ processing: ##### flow_processing ##### process: rohe Eier strikt räumlich getrennt von anderen Lebensmitteln verarbeiten +----- +short: ##### flow_processing ##### process: Ei vor dem Aufschlagen waschen und wenn möglich desinfizieren +----- +short: ##### flow_processing ##### process: alle Teile des Ei sind nach dem Aufschlagen so schnell wie möglich zu verarbeiten +----- +short: ---- notes: @@ -119,6 +125,8 @@ processing: ##### flow_processing ##### process: weich oder zerlassen +----- +short: yes ---- notes: ---- diff --git a/content/waffle_apfelmus.jpg b/content/waffle_apfelmus.jpg new file mode 100644 index 0000000..5b517be --- /dev/null +++ b/content/waffle_apfelmus.jpg @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:7df29dc48655c39218a83a146a5f1f20a5ddd770157555c94ea9a75fbc26abcd +size 844348 diff --git a/flowblocks/flow_processing.ini b/flowblocks/flow_processing.ini index dbd4001..fda86c0 100644 --- a/flowblocks/flow_processing.ini +++ b/flowblocks/flow_processing.ini @@ -6,3 +6,10 @@ button_label = Zutat verarbeitungsmöglichkeit label = describe the processing of this item type = string description = Examples: whole, diced, minced, steamed, raw +width = 2/3 + +[fields.short] +type = boolean +label = Kurzbeschreibung +description = Ankreuzen wenn es hier ausschließlich eine kurzbeschreibung gibt +width = 1/3 diff --git a/templates/zutaten/rezept.html b/templates/zutaten/rezept.html index a1171ba..0ed4425 100644 --- a/templates/zutaten/rezept.html +++ b/templates/zutaten/rezept.html @@ -28,6 +28,8 @@ {%- include "zutaten/zutaten.html" -%} + {%- else -%} +

      ungültige Rezeptangaben

      {%- endif -%} {%- endif -%} {{- '\n ' -}} diff --git a/templates/zutaten/zutat_menge.html b/templates/zutaten/zutat_menge.html index f0d845b..f15fbc6 100644 --- a/templates/zutaten/zutat_menge.html +++ b/templates/zutaten/zutat_menge.html @@ -1,117 +1,90 @@ - {%- if ing.ingredient is defined and ing.ingredient != "" -%} - {%- if ing.amounts is defined and ing.amounts != "" and ing.amounts.blocks is defined and ing.amounts.blocks != "" -%} - {%- if ing.amounts.blocks != [] -%} - {%- set ingredient_counter = loop.index -%} - {%- for amt in ing.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} - {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} - {%- if ing.processing.blocks != [] -%} - {{- ' | ' -}} - Verarbeitungshinweis #{{- ingredient_counter | string -}} - {%- endif -%} - {%- endif -%} - {%- if ing.notes is defined and ing.notes != "" and ing.notes.blocks is defined and ing.notes.blocks != "" -%} - {%- if ing.notes.blocks != [] -%} - {{- ' | ' -}} - Notiz #{{- ingredient_counter | string -}} - {{- '\n ' -}} - {%- endif -%} - {%- endif -%} - {%- if ing.substitutions is defined and ing.substitutions != "" -%} - {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} - {%- if ing.substitutions.blocks != [] -%} - {{- '\n ' -}}
        - {{- '\n ' -}}
      • - {{- '\n ' -}} Ausweichmöglichkeit: - {{- '\n ' -}}
          - {%- for sst in ing.substitutions.blocks -%} - {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} - {%- if sst.amounts.blocks != [] -%} - {%- for amt2 in sst.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt2.amount is defined and amt2.amount != "" and amt2.amount != 0 and amt2.amount != '0' -%} - {{- '\n ' -}}
        • - {{- '\n ' -}} - {%- if sst.processing is defined and sst.processing != "" and sst.processing.blocks is defined and sst.processing.blocks != "" -%} - {%- if sst.processing.blocks != [] -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}} - Verarbeitungshinweis - {%- for tmp_prc2 in sst.processing.blocks -%} - {%- if loop.index == 2 -%} - {{- 'e' -}} - {%- endif -%} - {%- endfor -%} - : - {{- '\n ' -}} -
              - {%- for prc2 in sst.processing.blocks -%} - {{- '\n ' -}}
            • - {{- '\n ' -}} - {{ prc2.process }} - {{- '\n ' -}}
            • - {%- endfor -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}}
          - {%- endif -%} - {%- endif -%} - {%- if sst.notes is defined and sst.notes != "" and sst.notes.blocks is defined and sst.notes.blocks != "" -%} - {%- if ing.notes.blocks != [] -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}} - Notiz - {%- for tmp_nde1 in sst.notes.blocks -%} - {%- if loop.index == 2 -%} - {{- 'en' -}} - {%- endif -%} - {%- endfor -%} - : - {{- '\n ' -}} -
              - {%- for nde2 in sst.notes.blocks -%} - {{- '\n ' -}}
            • - {{- '\n ' -}} - {{ nde2.note }} - {{- '\n ' -}}
            • - {%- endfor -%} - {{- '\n ' -}}
            - {{- '\n ' -}}
          • - {{- '\n ' -}}
          - {%- endif -%} - {%- endif -%} - {{- '\n ' -}}
        • - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {{- '\n ' -}}
        - {{- '\n ' -}}
      • - {{- '\n ' -}}
      +{#- + + Hier wird eine Zutaten tabelle gerendert. + Zusammen mit einem Link auf den Verarbeitungshinweis + oder eine Notiz zur Zutat. + Der Text zum Hinweis oder der Notiz wird hier nicht gerendert. + +-#} +{%- if child.ingredients.blocks != [] -%} + {%- for ing in child.ingredients.blocks -%} + {%- if ing.ingredient is defined and ing.ingredient != "" -%} + {%- if ing.amounts is defined and ing.amounts != "" and ing.amounts.blocks is defined and ing.amounts.blocks != "" -%} + {%- if ing.amounts.blocks != [] -%} + {#- + + Wenn eine Zutat-Menge definiert ist, wird diese im folgenden for loop gerendert. + Sollte es unterschiedliche Teig-Mengen geben, ist die reinfolge der Zutatenmenge relevant. + Wenn also ein Rezept für 2 größen definiert ist, wird für die erste größe die erste Zutat genommen. + Und für die zweite größe die andere. + + ABER, wenn eine der Zutat Null bzw. 0 ist, dann wird diese eine Zutat nicht gerendert. + + -#} + {%- set ingredient_counter = loop.index -%} + {%- for amt in ing.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' and amt.amount != 'Null' -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} + {#- + Hier wird eine kurznotiz zur verarbeitung gerendert + oder ein Link zur Verarbeitungsnotiz. + -#} + {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} + {%- if ing.processing.blocks != [] -%} + {%- for prc in ing.processing.blocks -%} + {%- if loop.index == 1 -%} + {%- if prc.short|default(False) -%} + {{- ' ' -}} + ({{ prc.process }}) + {%- else -%} + {{- ' ' -}} + (Angaben zur Verarbeitung von {{ ing.ingredient }} beachten) {%- endif -%} {%- endif -%} - {%- endif -%} - {{- '\n ' -}}
    • + {%- endfor -%} {%- endif -%} {%- endif -%} - {%- endfor -%} + {%- if ing.substitutions is defined and ing.substitutions != "" -%} + {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} + {%- if ing.substitutions.blocks != [] -%} + {%- for sst in ing.substitutions.blocks -%} + {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} + {%- if sst.amounts.blocks != [] -%} + {%- for amt2 in sst.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt2.amount is defined and amt2.amount != "" and amt2.amount != 0 and amt2.amount != '0' -%} + {{- ' ' -}} + {%- endif -%} {%- endif -%} - {%- endif -%} - {%- endif -%} - {%- endfor -%} + {%- endfor -%} + {%- else -%} + {#- + Wenn eine Zutat keine klare Menge hat, wird diese ohne genaue größenangabe gerendert. + + -#} + {%- endif -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} +{%- endif -%} diff --git a/templates/zutaten/zutaten.html b/templates/zutaten/zutaten.html index 0a82190..114f50c 100644 --- a/templates/zutaten/zutaten.html +++ b/templates/zutaten/zutaten.html @@ -1,5 +1,8 @@ {#- - Hier werden die Zutaten für das Rezept gerendert... + Hier werden die einzelnen + Zutaten für das Rezept gerendert... + + Und falls vorhanden noch der Hinweis auf Angaben zur Zutat. -#} {%- for prt in child.servings.blocks -%} {#- @@ -22,6 +25,10 @@ {%- if child.ingredients.blocks != [] -%} {{- '\n ' -}}
        + {#- + Hier wird nun die konkrete Zutat angegeben. + Also zB. Eier: 4 Stück. + -#} {%- include "zutaten/zutat_menge.html" -%} {{- '\n ' -}}
      -- 2.39.5 From 4fdc74717fd4afd6d7ec7687e15311bbea38b5bd Mon Sep 17 00:00:00 2001 From: L3D Date: Sun, 8 Aug 2021 21:23:11 +0200 Subject: [PATCH 08/78] Improve HTML Rendering --- templates/zutaten/rezept.html | 10 ++ templates/zutaten/zutat_einzeln.html | 70 +++++++++++ .../zutaten/zutat_einzeln_ohne_menge.html | 58 +++++++++ templates/zutaten/zutat_menge.html | 61 +-------- templates/zutaten/zutat_notes.html | 116 ++++++++---------- templates/zutaten/zutaten.html | 20 --- 6 files changed, 195 insertions(+), 140 deletions(-) create mode 100644 templates/zutaten/zutat_einzeln.html create mode 100644 templates/zutaten/zutat_einzeln_ohne_menge.html diff --git a/templates/zutaten/rezept.html b/templates/zutaten/rezept.html index 0ed4425..24eda36 100644 --- a/templates/zutaten/rezept.html +++ b/templates/zutaten/rezept.html @@ -34,6 +34,16 @@ {%- endif -%} {{- '\n ' -}} {{- '\n ' -}} + {#- + + Render die Notizen und Angaben zur Verarbeitung der Rezepte + + -#} + {%- if child.ingredients is defined and child.ingredients != "" %} + {%- if child.ingredients.blocks != [] -%} + {%- include "zutaten/zutat_notes.html" -%} + {%- endif -%} + {%- endif -%} {#- Nachdem die Zutaten des Rezept nun angegeben sind, diff --git a/templates/zutaten/zutat_einzeln.html b/templates/zutaten/zutat_einzeln.html new file mode 100644 index 0000000..a36c4a4 --- /dev/null +++ b/templates/zutaten/zutat_einzeln.html @@ -0,0 +1,70 @@ +{#- + + Wenn eine Zutat-Menge definiert ist, wird diese im folgenden for loop gerendert. + Sollte es unterschiedliche Teig-Mengen geben, ist die reinfolge der Zutatenmenge relevant. + Wenn also ein Rezept für 2 größen definiert ist, wird für die erste größe die erste Zutat genommen. + Und für die zweite größe die andere. + + ABER, wenn eine der Zutat Null bzw. 0 ist, dann wird diese eine Zutat nicht gerendert. + +-#} +{%- set ingredient_counter = loop.index -%} +{%- for amt in ing.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' and amt.amount != 'Null' -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} + {#- + Hier wird eine kurznotiz zur verarbeitung gerendert + oder ein Link zur Verarbeitungsnotiz. + -#} + {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} + {%- if ing.processing.blocks != [] -%} + {%- for prc in ing.processing.blocks -%} + {%- if loop.index == 1 -%} + {%- if prc.short|default(False) -%} + {{- ' ' -}} + ({{ prc.process }}) + {%- else -%} + {{- ' ' -}} + (Angaben zur Verarbeitung von {{ ing.ingredient }} beachten) + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {#- + Render alternativzutat, wenn verfügbar! + -#} + {%- if ing.substitutions is defined and ing.substitutions != "" -%} + {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} + {%- if ing.substitutions.blocks != [] -%} + {%- for sst in ing.substitutions.blocks -%} + {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} + {%- if sst.amounts.blocks != [] -%} + {%- for amt2 in sst.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt2.amount is defined and amt2.amount != "" and amt2.amount != 0 and amt2.amount != '0' -%} + {{- ' ' -}} + {%- endif -%} + {%- endif -%} +{%- endfor -%} + diff --git a/templates/zutaten/zutat_einzeln_ohne_menge.html b/templates/zutaten/zutat_einzeln_ohne_menge.html new file mode 100644 index 0000000..fab1b3d --- /dev/null +++ b/templates/zutaten/zutat_einzeln_ohne_menge.html @@ -0,0 +1,58 @@ +{#- + + Wenn keine Zutat-Menge definiert ist, wird statt dessen + in folgenden Loop nur die Zutat gerendert. + +-#} +{{- '\n ' -}}
    • +{{- '\n ' -}} ({{ prc.process }}) + {%- else -%} + {{- ' ' -}} + (Angaben zur Verarbeitung von {{ ing.ingredient }} beachten) + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} +{%- endif -%} +{#- + Render alternativzutat, wenn verfügbar! +-#} +{%- if ing.substitutions is defined and ing.substitutions != "" -%} + {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} + {%- if ing.substitutions.blocks != [] -%} + {%- for sst in ing.substitutions.blocks -%} + {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} + {%- if sst.amounts.blocks != [] -%} + {%- for amt2 in sst.amounts.blocks -%} + {%- if loop.index == prt_loop -%} + {%- if amt2.amount is defined and amt2.amount != "" and amt2.amount != 0 and amt2.amount != '0' -%} + {{- ' ' -}} diff --git a/templates/zutaten/zutat_menge.html b/templates/zutaten/zutat_menge.html index f15fbc6..a62498a 100644 --- a/templates/zutaten/zutat_menge.html +++ b/templates/zutaten/zutat_menge.html @@ -21,68 +21,15 @@ ABER, wenn eine der Zutat Null bzw. 0 ist, dann wird diese eine Zutat nicht gerendert. -#} - {%- set ingredient_counter = loop.index -%} - {%- for amt in ing.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' and amt.amount != 'Null' -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} - {#- - Hier wird eine kurznotiz zur verarbeitung gerendert - oder ein Link zur Verarbeitungsnotiz. - -#} - {%- if ing.processing is defined and ing.processing != "" and ing.processing.blocks is defined and ing.processing.blocks != "" -%} - {%- if ing.processing.blocks != [] -%} - {%- for prc in ing.processing.blocks -%} - {%- if loop.index == 1 -%} - {%- if prc.short|default(False) -%} - {{- ' ' -}} - ({{ prc.process }}) - {%- else -%} - {{- ' ' -}} - (Angaben zur Verarbeitung von {{ ing.ingredient }} beachten) - {%- endif -%} - {%- endif -%} - {%- endfor -%} - {%- endif -%} - {%- endif -%} - {%- if ing.substitutions is defined and ing.substitutions != "" -%} - {%- if ing.substitutions.blocks is defined and ing.substitutions.blocks != "" -%} - {%- if ing.substitutions.blocks != [] -%} - {%- for sst in ing.substitutions.blocks -%} - {%- if sst.amounts is defined and sst.amounts != "" and sst.amounts.blocks is defined and sst.amounts.blocks != "" -%} - {%- if sst.amounts.blocks != [] -%} - {%- for amt2 in sst.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt2.amount is defined and amt2.amount != "" and amt2.amount != 0 and amt2.amount != '0' -%} - {{- ' ' -}} - {%- endif -%} - {%- endif -%} - {%- endfor -%} + {%- include "zutaten/zutat_einzeln.html" -%} {%- else -%} {#- - Wenn eine Zutat keine klare Menge hat, wird diese ohne genaue größenangabe gerendert. + Wenn eine Zutat keine klare Menge hat, + wird diese hier ohne genaue größenangabe gerendert. -#} + {%- include "zutaten/zutat_einzeln_ohne_menge.html" -%} {%- endif -%} {%- endif -%} {%- endif -%} diff --git a/templates/zutaten/zutat_notes.html b/templates/zutaten/zutat_notes.html index 8d08df1..26bf02a 100644 --- a/templates/zutaten/zutat_notes.html +++ b/templates/zutaten/zutat_notes.html @@ -1,66 +1,56 @@ - {%- for ing1 in child.ingredients.blocks %} - {%- if ing1.ingredient is defined and ing1.ingredient != "" -%} - {%- if ing1.amounts is defined and ing1.amounts != "" and ing1.amounts.blocks is defined and ing1.amounts.blocks != "" -%} - {%- if ing1.amounts.blocks != [] -%} - {%- set ingredient_counter = loop.index -%} - {%- for amt in ing1.amounts.blocks -%} - {%- if loop.index == prt_loop -%} - {%- if amt.amount is defined and amt.amount != "" and amt.amount != 0 and amt.amount != '0' -%} - {%- if ing1.processing is defined and ing1.processing != "" and ing1.processing.blocks is defined and ing1.processing.blocks != "" -%} - {%- if ing1.processing.blocks != [] -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} - Verarbeitungshinweis - {%- for tmp_prc in ing1.processing.blocks -%} - {%- if loop.index == 2 -%} - {{- 'e' -}} - {%- endif -%} - {%- endfor -%} - {{- ' #' -}} - {{- ingredient_counter | string -}}: - {{- '\n ' -}} -
        - {%- for prc in ing1.processing.blocks -%} - {{- '\n ' -}}
      • - {{- '\n ' -}} - {{ prc.process }} - {{- '\n ' -}}
      • - {%- endfor -%} - {{- '\n ' -}}
      - {{- '\n ' -}}
    • - {{- '\n ' -}}
    - {%- endif -%} - {%- endif -%} - {%- if ing1.notes is defined and ing1.notes != "" and ing1.notes.blocks is defined and ing1.notes.blocks != "" -%} - {%- if ing1.notes.blocks != [] -%} - {{- '\n ' -}}
      - {{- '\n ' -}}
    • - {{- '\n ' -}} - Notiz - {%- for tmp_nde in ing1.notes.blocks -%} - {%- if loop.index == 2 -%} - {{- 'en' -}} - {%- endif -%} - {%- endfor -%} - {{- ' #' -}} {{- ingredient_counter | string -}}: - {{- '\n ' -}} -
        - {%- for nde in ing1.notes.blocks -%} - {{- '\n ' -}}
      • - {{- '\n ' -}} - {{ nde.note }} - {{- '\n ' -}}
      • - {%- endfor -%} - {{- '\n ' -}}
      - {{- '\n ' -}}
    • - {{- '\n ' -}}
    - {%- endif -%} - {%- endif -%} - {{- '\n ' -}} - {%- endif -%} +{#- + + Render die Notizen und Angaben zur Verarbeitung der Rezepte + +-#} +{%- if child.ingredients is defined and child.ingredients != "" %} + {%- if child.ingredients.blocks != [] -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}}

    Hinweise zu den Zutaten

    + {%- for ing in child.ingredients.blocks %} + {%- if ing.ingredient is defined and ing.ingredient != "" -%} + {#- + Verarbeitungshinweise der Zutat + -#} + {%- if ing.processing is defined and ing.processing != "" -%} + {%- if ing.processing.blocks != [] -%} + {%- for prc in ing.processing.blocks -%} + {%- if not prc.short|default(false) -%} + {%- if loop.index == 1 -%} + {{- '\n ' -}}

    Verarbeitung von {{ ing.ingredient }}:

    + {{- '\n ' -}}
      {%- endif -%} - {%- endfor -%} - {%- endif -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} + {{ prc.process }} + {{- '\n ' -}}
    • + {%- endif -%} + {%- endfor -%} + {{- '\n ' -}}
    {%- endif -%} {%- endif -%} - {%- endfor -%} + {#- + Notiz der Zutat + -#} + {%- if ing.notes is defined and ing.notes != "" -%} + {%- if ing.notes.blocks != [] -%} + {%- for nde in ing.notes.blocks -%} + {%- if loop.index == 1 -%} + {{- '\n ' -}}

    Notiz zu {{ ing.ingredient }}:

    + {{- '\n ' -}}
      + {%- endif -%} + {{- '\n ' -}}
    • + {{- '\n ' -}} + {{ nde.note }} + {{- '\n ' -}}
    • + {%- endfor -%} + {{- '\n ' -}}
    + {%- endif -%} + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {%- endif -%} +{%- endif -%} diff --git a/templates/zutaten/zutaten.html b/templates/zutaten/zutaten.html index 114f50c..99a977f 100644 --- a/templates/zutaten/zutaten.html +++ b/templates/zutaten/zutaten.html @@ -44,24 +44,4 @@ {%- endif -%} - {%- if child.ingredients is defined and child.ingredients != "" %} - {%- if child.ingredients.blocks != [] -%} - {{- '\n ' -}}
      - - - {%- include "zutaten/zutat_notes.html" -%} - - - - {{- '\n ' -}}
    - {%- else -%} - {{- '\n ' -}}
      - {{- '\n ' -}} Keine Zutaten definiert - {{- '\n ' -}}
    - {%- endif -%} - {%- else -%} - {{- '\n ' -}}
      - {{- '\n ' -}} Keine Zutaten definiert - {{- '\n ' -}}
    - {%- endif -%} {%- endfor -%} -- 2.39.5 From 20b9271cee40effd507fb25c12774299e87d63b1 Mon Sep 17 00:00:00 2001 From: L3D Date: Sun, 8 Aug 2021 23:35:54 +0200 Subject: [PATCH 09/78] Improve HTML Rendering --- content/rezept/klassisch/contents.lr | 5 +-- .../rezept/klassisch/rezept.yaml/contents.lr | 18 +++++++- flowblocks/flow_notes.ini | 8 +++- models/rezept-post.ini | 5 ++- templates/macros/rezept.html | 21 ++------- templates/macros/rezept_body.html | 10 +++++ templates/rezept-post.html | 22 ++++----- templates/zutaten/zutat_notes.html | 45 +++++++++++++++---- 8 files changed, 89 insertions(+), 45 deletions(-) create mode 100644 templates/macros/rezept_body.html diff --git a/content/rezept/klassisch/contents.lr b/content/rezept/klassisch/contents.lr index d09be94..04cd930 100644 --- a/content/rezept/klassisch/contents.lr +++ b/content/rezept/klassisch/contents.lr @@ -2,10 +2,7 @@ title: klassischer Waffelteig --- author: L3D --- -body: - -Der klassischer Waffelteig ist zu finden auf: -[rezept.yaml](rezept.yaml) +body: --- pub_date: 2021-07-19 --- diff --git a/content/rezept/klassisch/rezept.yaml/contents.lr b/content/rezept/klassisch/rezept.yaml/contents.lr index 9e2d013..521b62d 100644 --- a/content/rezept/klassisch/rezept.yaml/contents.lr +++ b/content/rezept/klassisch/rezept.yaml/contents.lr @@ -56,8 +56,12 @@ notes: ##### flow_notes ##### note: Statt Eier sollte man, wenn möglich, Vollei verwenden +----- +html: ##### flow_notes ##### -note: Eier nicht im Orginalkaton lagern +note: Eier möglichst nicht im Orginalkaton lagern +----- +html: ---- substitutions: #### flow_ingredients #### @@ -82,6 +86,8 @@ notes: ##### flow_notes ##### note: 1l Vollei entspricht 20 Eiern +----- +html: ---- substitutions: #### flow_ingredients #### @@ -176,6 +182,8 @@ notes: note: Backpulver vergrößert das Volumen des Teigs +----- +html: yes ---- substitutions: #### flow_ingredients #### @@ -200,6 +208,8 @@ notes: ##### flow_notes ##### note: Wenn möglich Frischmilch verwenden +----- +html: no ---- substitutions: #### flow_ingredients #### @@ -267,6 +277,8 @@ notes: ###### flow_notes ###### note: Alternativ zu Sprudel kann auch fast jedes andere Kohlensäurehaltige Getränk verwendet werden. +------ +html: #### flow_ingredients #### ingredient: Rum ---- @@ -280,6 +292,8 @@ notes: ##### flow_notes ##### note: optional +----- +html: yes ---- substitutions: #### flow_ingredients #### @@ -382,3 +396,5 @@ notes: ##### flow_notes ##### note: Waffeln optional zB. mit Puderzucker und Apfelmus verzieren. +----- +html: diff --git a/flowblocks/flow_notes.ini b/flowblocks/flow_notes.ini index 0e5aef4..7d807f0 100644 --- a/flowblocks/flow_notes.ini +++ b/flowblocks/flow_notes.ini @@ -3,5 +3,11 @@ name = Notizen und Details button_label = Notizen und Details [fields.note] -label = Notiz +label = Notiz zur Zutat type = string +width = 3/4 + +[fields.html] +type = boolean +width = 1/4 +label = hide in HTML version diff --git a/models/rezept-post.ini b/models/rezept-post.ini index b77a7b2..e3c4963 100644 --- a/models/rezept-post.ini +++ b/models/rezept-post.ini @@ -26,11 +26,12 @@ width = 1/2 [fields.orf] label = Render from Open Recepie Format -description = Render recepie with data from the ORF childpage +description = Render recepie with data from the ORF childpage. (create/open childpage and follow instruction for more) type = boolean [fields.body] -label = Body +label = Rezept Body +description = Freitextfeld für weitere Angaben zum Rezept type = markdown [fields.weight] diff --git a/templates/macros/rezept.html b/templates/macros/rezept.html index 90eca1e..943214f 100644 --- a/templates/macros/rezept.html +++ b/templates/macros/rezept.html @@ -1,18 +1,5 @@ {%- macro render_rezept_post(post, from_index=false, section_class='-odd') -%} {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {%- if from_index -%} - {{- '\n ' -}}

    {{ post.title }}

    - {%- else -%} - {{- '\n ' -}}

    {{ post.title }}

    - {% endif %} - {{- '\n ' -}}
    - {{- '\n ' -}} - {{- '\n ' -}}
    - {{- '\n ' -}}
    {%- if post.orf | default(false) -%} {#- Render recepie based on open recipe format @@ -29,11 +16,9 @@ {%- endif -%} {%- endif -%} {%- endfor -%} + {%- include "macros/rezept_body.html" -%} + {%- else -%} + {%- include "macros/rezept_body.html" -%} {%- endif %} - {{- '\n ' -}}
    - {{- '\n ' -}}
    - {{- '\n ' -}} {{- post.body -}} - {{- '\n ' -}}
    - {{- '\n ' -}}
    {{- '\n ' -}}
    {%- endmacro -%} diff --git a/templates/macros/rezept_body.html b/templates/macros/rezept_body.html new file mode 100644 index 0000000..8e7f376 --- /dev/null +++ b/templates/macros/rezept_body.html @@ -0,0 +1,10 @@ +{#- + Render post.body +-#} +{%- if post.body is defined and post.body != "" -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}} {{- post.body -}} + {{- '\n ' -}}
    + {{- '\n ' -}}
    +{%- endif -%} diff --git a/templates/rezept-post.html b/templates/rezept-post.html index 2da46da..6ed221c 100644 --- a/templates/rezept-post.html +++ b/templates/rezept-post.html @@ -1,18 +1,18 @@ -{% extends "header_slim.html" %} -{% from "macros/rezept.html" import render_rezept_post %} +{%- extends "header_slim.html" -%} +{%- from "macros/rezept.html" import render_rezept_post -%} {%- block title -%}{{ this.title }}{%- endblock -%} {%- block meta_description -%} {%- if this.meta_description is defined and this.meta_description != "" -%} - {{ this.meta_description }} + {{- this.meta_description -}} {%- else -%} C3WOC {%- endif -%} {%- endblock -%} -{% block body %} -
    -
    -

    {{ this.title }}

    -
    -
    - {{ render_rezept_post(this) }} -{% endblock %} +{%- block body -%} + + {{- render_rezept_post(this) -}} + + {#- + LINK zu Gesundheitsamt / Hygienehinweise... + -#} +{%- endblock -%} diff --git a/templates/zutaten/zutat_notes.html b/templates/zutaten/zutat_notes.html index 26bf02a..ca47d86 100644 --- a/templates/zutaten/zutat_notes.html +++ b/templates/zutaten/zutat_notes.html @@ -36,16 +36,45 @@ {%- if ing.notes is defined and ing.notes != "" -%} {%- if ing.notes.blocks != [] -%} {%- for nde in ing.notes.blocks -%} - {%- if loop.index == 1 -%} - {{- '\n ' -}}

    Notiz zu {{ ing.ingredient }}:

    - {{- '\n ' -}}
      + {%- if not nde.html | default(False) -%} + {%- if loop.index == 1 -%} + {{- '\n ' -}}

      Notiz zu {{ ing.ingredient }}:

      + {{- '\n ' -}}
        + {%- endif -%} + {{- '\n ' -}}
      • + {{- '\n ' -}} + {{ nde.note }} + {{- '\n ' -}}
      • + {%- if loop.index == loop.length -%} + {{- '\n ' -}}
      + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} + {%- endif -%} + {%- if ing.substitutions is defined and ing.substitutions != "" -%} + {%- if ing.substitutions.blocks != [] -%} + {%- for alt in ing.substitutions.blocks -%} + {%- if alt.notes is defined and alt.notes != "" -%} + {%- if alt.notes.blocks != [] -%} + {%- for ntz in alt.notes.blocks -%} + {%- if not ntz.html | default(False) -%} + {%- if loop.index == 1 -%} + {{- '\n ' -}}

      Notiz zu {{ alt.ingredient }}:

      + {{- '\n ' -}}
        + {%- endif -%} + {{- '\n ' -}}
      • + {{- '\n ' -}} + {{ ntz.note }} + {{- '\n ' -}}
      • + {%- if loop.index == loop.length -%} + {{- '\n ' -}}
      + {%- endif -%} + {%- endif -%} + {%- endfor -%} + {%- endif -%} {%- endif -%} - {{- '\n ' -}}
    • - {{- '\n ' -}} - {{ nde.note }} - {{- '\n ' -}}
    • {%- endfor -%} - {{- '\n ' -}}
    {%- endif -%} {%- endif -%} {%- endif -%} -- 2.39.5 From f92f8bc1705d228a3ee2c9c17ab6ab9185b65462 Mon Sep 17 00:00:00 2001 From: L3D Date: Mon, 9 Aug 2021 01:14:49 +0200 Subject: [PATCH 10/78] Improve preview --- content/rezept/klassisch/rezept.yaml/contents.lr | 4 ++-- templates/zutaten/hinweise.html | 9 ++++++++- templates/zutaten/oven.yaml | 3 ++- 3 files changed, 12 insertions(+), 4 deletions(-) diff --git a/content/rezept/klassisch/rezept.yaml/contents.lr b/content/rezept/klassisch/rezept.yaml/contents.lr index 521b62d..be2c105 100644 --- a/content/rezept/klassisch/rezept.yaml/contents.lr +++ b/content/rezept/klassisch/rezept.yaml/contents.lr @@ -85,7 +85,7 @@ processing: notes: ##### flow_notes ##### -note: 1l Vollei entspricht 20 Eiern +note: 1 l Vollei entspricht 20 Eiern ----- html: ---- @@ -276,7 +276,7 @@ processing: notes: ###### flow_notes ###### -note: Alternativ zu Sprudel kann auch fast jedes andere Kohlensäurehaltige Getränk verwendet werden. +note: Alternativ zu Sprudel kann auch fast jedes andere Kohlensäurehaltige Getränk verwendet werden ------ html: #### flow_ingredients #### diff --git a/templates/zutaten/hinweise.html b/templates/zutaten/hinweise.html index d3d1421..4334ad1 100644 --- a/templates/zutaten/hinweise.html +++ b/templates/zutaten/hinweise.html @@ -13,7 +13,14 @@ {%- for ovn in child.oven.blocks -%} {%- if ovn.amount is defined and ovn.amount != "" -%} {{- '\n ' -}}
  • - {{- '\n ' -}} Ofentemperatur: {{ ovn.amount }} {{ ovn.unit | default('C') }} + {{- '\n ' -}} Ofentemperatur: {{ ovn.amount }} + {%- if ovn.unit | default('C') == 'C' -%} + {{- ' °C' -}} + {%- else -%} + {{- ' ' -}} + {{- ovn.unit -}} + {%- endif -%} + {{- '\n ' -}}
  • {%- endif -%} {%- endfor -%} diff --git a/templates/zutaten/oven.yaml b/templates/zutaten/oven.yaml index 1b03646..e71c326 100644 --- a/templates/zutaten/oven.yaml +++ b/templates/zutaten/oven.yaml @@ -9,7 +9,8 @@ {{- '\noven_temp:' -}} {%- endif -%} {{- '\n - amount: ' -}} '{{- ovn.amount -}}' - {{- '\n unit: ' -}} {{- ovn.unit | default('C') -}} + {{- '\n unit: ' -}} + {{- if ovn.unit | default('C') -}} {%- endif -%} {%- endfor -%} {%- endif -%} -- 2.39.5 From 4e4c25cc14b8abe82eb9a351658ee842f2d3f623 Mon Sep 17 00:00:00 2001 From: L3D Date: Mon, 9 Aug 2021 01:47:52 +0200 Subject: [PATCH 11/78] fix typo --- templates/zutaten/oven.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/templates/zutaten/oven.yaml b/templates/zutaten/oven.yaml index e71c326..c04583e 100644 --- a/templates/zutaten/oven.yaml +++ b/templates/zutaten/oven.yaml @@ -10,7 +10,7 @@ {%- endif -%} {{- '\n - amount: ' -}} '{{- ovn.amount -}}' {{- '\n unit: ' -}} - {{- if ovn.unit | default('C') -}} + {{- ovn.unit | default('C') -}} {%- endif -%} {%- endfor -%} {%- endif -%} -- 2.39.5 From 8787c089204da919a6d7630a1fac55937fb98ce3 Mon Sep 17 00:00:00 2001 From: L3D Date: Tue, 10 Aug 2021 01:03:46 +0200 Subject: [PATCH 12/78] Update image --- content/contents.lr | 2 +- content/waffle_colored_stawberry.jpg | 3 +++ 2 files changed, 4 insertions(+), 1 deletion(-) create mode 100644 content/waffle_colored_stawberry.jpg diff --git a/content/contents.lr b/content/contents.lr index b76f1db..bab25e0 100644 --- a/content/contents.lr +++ b/content/contents.lr @@ -87,7 +87,7 @@ image_alt: ##### flow_one_innerbox_section ##### title: Waffel mit Akzent ----- -box_image: sweet_waffle.jpg +box_image: waffle_colored_stawberry.jpg ----- box_content: diff --git a/content/waffle_colored_stawberry.jpg b/content/waffle_colored_stawberry.jpg new file mode 100644 index 0000000..7daf02c --- /dev/null +++ b/content/waffle_colored_stawberry.jpg @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:6a6a5be206751fb797738a124e3a5de8da97db25da5d324894a20d88add563f2 +size 841563 -- 2.39.5 From a73a072b0982b7a5b668e1cc915bf2b3c34a77c8 Mon Sep 17 00:00:00 2001 From: L3D Date: Tue, 10 Aug 2021 21:16:09 +0200 Subject: [PATCH 13/78] Adding hygienic label in ORF --- content/contents.lr | 2 +- models/zutaten.ini | 6 ++++++ templates/zutaten.yaml | 28 ++++++++++++++++------------ 3 files changed, 23 insertions(+), 13 deletions(-) diff --git a/content/contents.lr b/content/contents.lr index bab25e0..f462386 100644 --- a/content/contents.lr +++ b/content/contents.lr @@ -93,7 +93,7 @@ box_content: Der klassische Waffelteig lässt sich mit Zutaten eurer Wahl verfeiern und verwandelt das Waffeln essen in ein neues Abendteuer. -Es gibt Zimt, Kardamom, Chilli, frische Kräuter und vieles mehr. Probiert es doch mal aus. +Es gibt zum Beispiel Zimt, Kardamom, Chilli, frische Kräuter und vieles mehr. Probiert es doch mal aus. ----- box_link: verfeinerter Teig ----- diff --git a/models/zutaten.ini b/models/zutaten.ini index 49df051..af49d15 100644 --- a/models/zutaten.ini +++ b/models/zutaten.ini @@ -75,7 +75,13 @@ width = 1/3 [fields.source_authors] label = Author type = string +width = 1/2 [fields.x_license] label = License type = string +width = 1/2 + +[fields.render_hygiene] +label = Render Hygiene Hinweise +type = boolean diff --git a/templates/zutaten.yaml b/templates/zutaten.yaml index b924372..f3e7e4e 100644 --- a/templates/zutaten.yaml +++ b/templates/zutaten.yaml @@ -1,24 +1,24 @@ --- -{# -definition_ORF: "https://open-recipe-format.readthedocs.io/en/latest/topics/reference/orf.html" -json_schema: "https://raw.githubusercontent.com/techhat/openrecipeformat/master/schema.json" -validator: "https://json-schema.org/" -validator_steps: +{#- +X-definition_ORF: "https://open-recipe-format.readthedocs.io/en/latest/topics/reference/orf.html" +X-json_schema: "https://raw.githubusercontent.com/techhat/openrecipeformat/master/schema.json" +X-validator: "https://json-schema.org/" +X-validator_steps: - "pip3 install jsonschema" - "install yq" - "wget {{ json_schema }}" - "curl rezep.yaml | yq -j > rezept.json" - "jsonschema -i rezept.json schema.json" -usda_lookup: "https://fdc.nal.usda.gov/fdc-app.html" -#} +X-usda_lookup: "https://fdc.nal.usda.gov/fdc-app.html" -#} {%- if this.recipe_name and this.recipe_name != "" -%} - recipe_name: "{{ this.recipe_name | default(this.title) }}" + {{- '\nrecipe_name: ' -}} "{{- this.recipe_name | default(this.title) -}}" {%- else -%} - recipe_name: "{{ this.title }}" + {{- '\nrecipe_name: ' -}} "{{- this.title -}}" {%- endif -%} -{{- '\nrecipe_uuid: ' -}} "{{ this._gid }}" +{{- '\nrecipe_uuid: ' -}} "{{- this._gid -}}" {%- include "zutaten/yields.yaml" -%} @@ -29,10 +29,14 @@ usda_lookup: "https://fdc.nal.usda.gov/fdc-app.html" -#} {%- include "zutaten/oven.yaml" -%} {%- if this.source_authors is defined and this.source_authors != "" -%} - {{ '\n\nsource_authors:'}} "{{ this.source_authors }}" + {{- '\n\nsource_authors: ' -}} "{{ this.source_authors }}" {%- endif -%} {%- if this.x_license is defined and this.x_license != "" -%} - {{ '\nX-License:' }} "{{ this.x_license }}" + {{- '\nX-License: ' -}} "{{ this.x_license }}" +{%- endif -%} +{%- if this.render_hygiene | default(True) -%} + {{- '\nX-hygiene_flyer: ' -}} "https://wiki.c3gelb.de/doku.php?id=public:flyer" + {{- '\nX-hygiene_video: ' -}} "https://youtu.be//w-4_5J0xk7A" {%- endif -%} {{ '\nsource_url:' }} "{{ '../'|url(external=true) }}" -{#- source: "https://open-recipe-format.readthedocs.io/en/latest/topics/tutorials/walkthrough.html" -#} +{#- X-ORF_source: "https://open-recipe-format.readthedocs.io/en/latest/topics/tutorials/walkthrough.html" -#} -- 2.39.5 From 51e58d79d77ced65b7bab00699ed6aa4f063c69b Mon Sep 17 00:00:00 2001 From: L3D Date: Wed, 11 Aug 2021 01:21:25 +0200 Subject: [PATCH 14/78] adding hygiene --- databags/navigation.json | 1 + templates/layout.html | 4 +++- templates/macros/rezept.html | 7 ++++--- templates/rezept-post.html | 7 +------ templates/zutaten.yaml | 3 ++- templates/zutaten/hygiene.html | 33 +++++++++++++++++++++++++++++++++ templates/zutaten/rezept.html | 23 +++++++++++------------ 7 files changed, 55 insertions(+), 23 deletions(-) create mode 100644 templates/zutaten/hygiene.html diff --git a/databags/navigation.json b/databags/navigation.json index beb995b..dd822d8 100644 --- a/databags/navigation.json +++ b/databags/navigation.json @@ -23,6 +23,7 @@ "list_childs": true, "items": { "Mitmachen": "/mitmachen", + "Hygiene": "/hygiene", "Bilder": "https://waffel.li/", "Videos": "https://waffel.tv/" } diff --git a/templates/layout.html b/templates/layout.html index 2a49976..59b121b 100644 --- a/templates/layout.html +++ b/templates/layout.html @@ -197,8 +197,10 @@ __ ____ _| |_| |_| | ___ Datenschutz
    -
    +
    © {{ none|datetimeformat('YYYY', 'UTC', locale='de_DE') }} C3 Waffel Operation Center +
    + Diese Webseite steht unter der MIT License. diff --git a/templates/macros/rezept.html b/templates/macros/rezept.html index 943214f..12f54e6 100644 --- a/templates/macros/rezept.html +++ b/templates/macros/rezept.html @@ -8,15 +8,16 @@ {%- for child in post.children -%} {%- if child._template == 'zutaten.yaml' -%} {%- if from_index -%} - {{ '\n ' -}}

    {{ child.recipe_name }}

    + {{ '\n ' -}} {{ child.recipe_name }} {%- else -%} - {%- include "zutaten/rezept.html" -%} - {%- endif -%} {%- endif -%} {%- endfor -%} {%- include "macros/rezept_body.html" -%} + {%- if not from_index -%} + {%- include "zutaten/hygiene.html" -%} + {%- endif %} {%- else -%} {%- include "macros/rezept_body.html" -%} {%- endif %} diff --git a/templates/rezept-post.html b/templates/rezept-post.html index 6ed221c..30592c7 100644 --- a/templates/rezept-post.html +++ b/templates/rezept-post.html @@ -9,10 +9,5 @@ {%- endif -%} {%- endblock -%} {%- block body -%} - - {{- render_rezept_post(this) -}} - - {#- - LINK zu Gesundheitsamt / Hygienehinweise... - -#} + {{- render_rezept_post(this) -}} {%- endblock -%} diff --git a/templates/zutaten.yaml b/templates/zutaten.yaml index f3e7e4e..5dd3dc8 100644 --- a/templates/zutaten.yaml +++ b/templates/zutaten.yaml @@ -36,7 +36,8 @@ X-usda_lookup: "https://fdc.nal.usda.gov/fdc-app.html" -#} {%- endif -%} {%- if this.render_hygiene | default(True) -%} {{- '\nX-hygiene_flyer: ' -}} "https://wiki.c3gelb.de/doku.php?id=public:flyer" - {{- '\nX-hygiene_video: ' -}} "https://youtu.be//w-4_5J0xk7A" + {{- '\nX-hygiene_video: ' -}} "https://youtu.be/w-4_5J0xk7A" + {{- '\nX-hygiene_eggs: ' -}} "https://www.bvl.bund.de/DE/Arbeitsbereiche/01_Lebensmittel/03_Verbraucher/03_UmgangLM/02_LMzubereiten/03_Eier/lm_zubereitung_eier_node.html" {%- endif -%} {{ '\nsource_url:' }} "{{ '../'|url(external=true) }}" {#- X-ORF_source: "https://open-recipe-format.readthedocs.io/en/latest/topics/tutorials/walkthrough.html" -#} diff --git a/templates/zutaten/hygiene.html b/templates/zutaten/hygiene.html new file mode 100644 index 0000000..e69fce0 --- /dev/null +++ b/templates/zutaten/hygiene.html @@ -0,0 +1,33 @@ +{%- for child in post.children -%} + {%- if child._template == 'zutaten.yaml' -%} + {%- if child.render_hygiene | default(True) -%} + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {{- '\n ' -}}

    Hygiene

    + {{- '\n ' -}}

    Beim Zubereiten von Speisen ist Hygiene besonders wichtig.
    + {{- '\n ' -}} Eine saubere Arbeitsfläche, saubere Werkzeuge und frisch gewaschene Hände sollten selbstverständlich sein.
    + {{- '\n ' -}} Wer gesundheitlich angeschlagen ist, sollte besser keine Lebensmittel zubereiten. + {{- '\n ' -}} Bei Symptomen von einigen Krankheiten ist es jedem nach dem + {{- '\n ' -}} Infektionsschutzgesetz sogar untersagt, + {{- '\n ' -}} in diesem Bereich tätig zu sein.

    + {{- '\n ' -}}

    Beim Umgang mit rohen Eiern ist erhöhte Vorsicht geboten. Beachtet hierbei bitte den + {{- '\n ' -}} Hygienischen Umgang mit Eiern + {{- '\n ' -}} des Bundesamts für Verbraucherschutz und Lebensmittelsicherheit.

    + {{- '\n ' -}}

    Wer im Lebensmittelbereich arbeitet und bei der Zubereitung von Speisen direkten Kontakt mit Lebensmitteln hat, + {{- '\n ' -}} braucht zwingend ein Gesundheitszeugnis. Zumindest gilt dies bei der Arbeit im Lebensmittelsektor. Oder wenn es sich + {{- '\n ' -}} nicht mehr im Rahmen eines Privathaushaltes abspielt.
    + {{- '\n ' -}} Auch bei kleineren Veranstaltungen wie Vereins- und Straßenfesten ist es ratsam, allen mit Lebensmitteln und Speisen + {{- '\n ' -}} hantierenden Menschen zumindest auf den + {{- '\n ' -}} Leitfaden für den Umgang mit Lebensmitteln auf Vereins- und Straßenfesten + {{- '\n ' -}} hinzuweisen.

    + {{- '\n ' -}}

    Weitere wertvolle Hinweise zur Hygiene gibt es als + {{- '\n ' -}} Flyer bei C3GELB, + {{- '\n ' -}} auf bfr.bund.de oder auch als Video auf + {{- '\n ' -}} youtu.be/w-4_5J0xk7A und auf infektionsschutz.de. + {{- '\n ' -}}

    +

    TODO: alles außer flyer und ersten absatz auf eigene /hygiene unterseite packen!

    + {{- '\n ' -}}
    + {{- '\n ' -}}
    + {%- endif -%} + {%- endif -%} +{%- endfor -%} diff --git a/templates/zutaten/rezept.html b/templates/zutaten/rezept.html index 24eda36..6027ff3 100644 --- a/templates/zutaten/rezept.html +++ b/templates/zutaten/rezept.html @@ -34,17 +34,7 @@ {%- endif -%} {{- '\n ' -}} {{- '\n ' -}} - {#- - - Render die Notizen und Angaben zur Verarbeitung der Rezepte - - -#} - {%- if child.ingredients is defined and child.ingredients != "" %} - {%- if child.ingredients.blocks != [] -%} - {%- include "zutaten/zutat_notes.html" -%} - {%- endif -%} - {%- endif -%} - {#- + {#- Nachdem die Zutaten des Rezept nun angegeben sind, folgt die Zubereitung der waffelfähigen Teigprodukte... @@ -55,8 +45,17 @@ {%- include "zutaten/zubereitung.html" -%} {%- endif -%} {%- endif -%} - {%- include "zutaten/hinweise.html" -%} + {#- + + Render die Notizen und Angaben zur Verarbeitung der einzelnen Zutaten + + -#} + {%- if child.ingredients is defined and child.ingredients != "" %} + {%- if child.ingredients.blocks != [] -%} + {%- include "zutaten/zutat_notes.html" -%} + {%- endif -%} + {%- endif -%} {#- source: "https://open-recipe-format.readthedocs.io/en/latest/topics/tutorials/walkthrough.html" -#} -- 2.39.5 From fbd43028890458f6311ad52d5965b6b2e43a6289 Mon Sep 17 00:00:00 2001 From: L3D Date: Wed, 11 Aug 2021 01:51:48 +0200 Subject: [PATCH 15/78] Hygiene --- content/hygiene/contents.lr | 30 ++++++++++++++++++++++++++++++ models/calendar.ini | 3 +-- models/flow_block_page.ini | 28 ---------------------------- models/header_slim.ini | 3 +-- models/image.ini | 16 ---------------- models/page.ini | 2 +- templates/page.html | 22 +++++++++++----------- 7 files changed, 44 insertions(+), 60 deletions(-) create mode 100644 content/hygiene/contents.lr delete mode 100644 models/flow_block_page.ini delete mode 100644 models/image.ini diff --git a/content/hygiene/contents.lr b/content/hygiene/contents.lr new file mode 100644 index 0000000..f4ba241 --- /dev/null +++ b/content/hygiene/contents.lr @@ -0,0 +1,30 @@ +_model: page +--- +title: Hygiene +--- +body: + +Beim Zubereiten von Speisen ist Hygiene besonders wichtig.
    +Eine saubere Arbeitsfläche, saubere Werkzeuge und frisch gewaschene Hände sollten selbstverständlich sein.
    +Wer gesundheitlich angeschlagen ist, sollte besser keine Lebensmittel zubereiten. +Bei Symptomen von einigen Krankheiten ist es jedem nach dem +Infektionsschutzgesetz sogar untersagt, +in diesem Bereich tätig zu sein. + +Beim Umgang mit rohen Eiern ist erhöhte Vorsicht geboten. Beachtet hierbei bitte den +Hygienischen Umgang mit Eiern +des Bundesamts für Verbraucherschutz und Lebensmittelsicherheit. + +Wer im Lebensmittelbereich arbeitet und bei der Zubereitung von Speisen direkten Kontakt mit Lebensmitteln hat, +braucht zwingend ein Gesundheitszeugnis. Zumindest gilt dies bei der Arbeit im Lebensmittelsektor. Oder wenn es sich +nicht mehr im Rahmen eines Privathaushaltes abspielt. + +Auch bei kleineren Veranstaltungen wie Vereins- und Straßenfesten ist es ratsam, allen mit Lebensmitteln und Speisen +hantierenden Menschen zumindest auf den +Leitfaden für den Umgang mit Lebensmitteln auf Vereins- und Straßenfesten +hinzuweisen. + +Weitere wertvolle Hinweise zur Hygiene gibt es als + Flyer bei C3GELB, +auf bfr.bund.de oder auch als Video auf + youtu.be/w-4_5J0xk7A und auf infektionsschutz.de. diff --git a/models/calendar.ini b/models/calendar.ini index 6714f85..6f48e81 100644 --- a/models/calendar.ini +++ b/models/calendar.ini @@ -2,7 +2,7 @@ name = Kalender ICS Feed label = {{ this.title }} protected = yes -hidden = no +hidden = yes [fields.title] label = Titel @@ -25,7 +25,6 @@ label = Events type = flow flow_blocks = events - [fields.lang] label = Kalender sprache type = string diff --git a/models/flow_block_page.ini b/models/flow_block_page.ini deleted file mode 100644 index 52d9254..0000000 --- a/models/flow_block_page.ini +++ /dev/null @@ -1,28 +0,0 @@ -[model] -name = Flow Block Page -label = {{ this.title }} -inherits = header_slim - -[fields.title] -label = Title -description = Der Seitentitel und die Überschrift dieser Seite -type = string - -[fields.meta_description] -label = Meta Beschreibung -description = Hier kommt die Beschreibung rein, die von Suchmachinen, Seitencrawlern und Previews auf diese Seite generiert werden -type = string - -[fields.teaser] -label = Teaser -description = Erster, hervorgehobener Absatz des Texts (Vorspann). -type = markdown - -[fields.body] -label = Body -type = markdown - -[fields.section] -label = Sections -type = flow -flow_blocks = flow_text_section diff --git a/models/header_slim.ini b/models/header_slim.ini index a0e394c..07a1540 100644 --- a/models/header_slim.ini +++ b/models/header_slim.ini @@ -1,4 +1,3 @@ [model] -name = Header SLIM -label = Header SLIM protected = yes +hidden = no diff --git a/models/image.ini b/models/image.ini deleted file mode 100644 index f1bf7cd..0000000 --- a/models/image.ini +++ /dev/null @@ -1,16 +0,0 @@ -[model] -name = image -label = Image - -[fields.description] -label = Description -type = string - -[fields.photographer] -label = Photographer -type = string - -[fields.copyright] -label = Copyright -type = string - diff --git a/models/page.ini b/models/page.ini index a551ece..fb1f85f 100644 --- a/models/page.ini +++ b/models/page.ini @@ -1,5 +1,5 @@ [model] -name = Page +name = Standard Seite (Page) label = {{ this.title }} inherits = header_slim diff --git a/templates/page.html b/templates/page.html index 59bffd9..5c514c1 100644 --- a/templates/page.html +++ b/templates/page.html @@ -2,22 +2,22 @@ {%- block title -%}{{ this.title }}{%- endblock -%} {%- block meta_description -%} {%- if this.meta_description is defined and this.meta_description != "" -%} - {{ this.meta_description }} + {{- this.meta_description -}} {%- else -%} - Werkkooperative der Technikfreundinnen eG + C3 Waffel Operation Center {%- endif -%} {%- endblock -%} -{% block body %} +{%- block body %}
    -
    -

    {{ this.title }}

    -
    +
    +

    {{ this.title }}

    +
    -
    -
    - {{ this.body }} -
    +
    +
    + {{ this.body }}
    +
    -{% endblock %} \ No newline at end of file +{%- endblock -%} -- 2.39.5 From 16fd9f186d294701fff0cb19af519d3f5c61901c Mon Sep 17 00:00:00 2001 From: L3D Date: Wed, 11 Aug 2021 20:46:31 +0200 Subject: [PATCH 16/78] Update recepie stuff --- templates/zutaten/hygiene.html | 20 +------------------- templates/zutaten/zutat_notes.html | 2 +- 2 files changed, 2 insertions(+), 20 deletions(-) diff --git a/templates/zutaten/hygiene.html b/templates/zutaten/hygiene.html index e69fce0..96ff053 100644 --- a/templates/zutaten/hygiene.html +++ b/templates/zutaten/hygiene.html @@ -6,26 +6,8 @@ {{- '\n ' -}}

    Hygiene

    {{- '\n ' -}}

    Beim Zubereiten von Speisen ist Hygiene besonders wichtig.
    {{- '\n ' -}} Eine saubere Arbeitsfläche, saubere Werkzeuge und frisch gewaschene Hände sollten selbstverständlich sein.
    - {{- '\n ' -}} Wer gesundheitlich angeschlagen ist, sollte besser keine Lebensmittel zubereiten. - {{- '\n ' -}} Bei Symptomen von einigen Krankheiten ist es jedem nach dem - {{- '\n ' -}} Infektionsschutzgesetz sogar untersagt, - {{- '\n ' -}} in diesem Bereich tätig zu sein.

    - {{- '\n ' -}}

    Beim Umgang mit rohen Eiern ist erhöhte Vorsicht geboten. Beachtet hierbei bitte den - {{- '\n ' -}} Hygienischen Umgang mit Eiern - {{- '\n ' -}} des Bundesamts für Verbraucherschutz und Lebensmittelsicherheit.

    - {{- '\n ' -}}

    Wer im Lebensmittelbereich arbeitet und bei der Zubereitung von Speisen direkten Kontakt mit Lebensmitteln hat, - {{- '\n ' -}} braucht zwingend ein Gesundheitszeugnis. Zumindest gilt dies bei der Arbeit im Lebensmittelsektor. Oder wenn es sich - {{- '\n ' -}} nicht mehr im Rahmen eines Privathaushaltes abspielt.
    - {{- '\n ' -}} Auch bei kleineren Veranstaltungen wie Vereins- und Straßenfesten ist es ratsam, allen mit Lebensmitteln und Speisen - {{- '\n ' -}} hantierenden Menschen zumindest auf den - {{- '\n ' -}} Leitfaden für den Umgang mit Lebensmitteln auf Vereins- und Straßenfesten - {{- '\n ' -}} hinzuweisen.

    - {{- '\n ' -}}

    Weitere wertvolle Hinweise zur Hygiene gibt es als - {{- '\n ' -}} Flyer bei C3GELB, - {{- '\n ' -}} auf bfr.bund.de oder auch als Video auf - {{- '\n ' -}} youtu.be/w-4_5J0xk7A und auf infektionsschutz.de. + {{- '\n ' -}} Weiteres Dazu auf c3woc.de/hygiene und als Flyer auf c3gelb.de. {{- '\n ' -}}

    -

    TODO: alles außer flyer und ersten absatz auf eigene /hygiene unterseite packen!

    {{- '\n ' -}} {{- '\n ' -}} {%- endif -%} diff --git a/templates/zutaten/zutat_notes.html b/templates/zutaten/zutat_notes.html index ca47d86..dd9b498 100644 --- a/templates/zutaten/zutat_notes.html +++ b/templates/zutaten/zutat_notes.html @@ -38,7 +38,7 @@ {%- for nde in ing.notes.blocks -%} {%- if not nde.html | default(False) -%} {%- if loop.index == 1 -%} - {{- '\n ' -}}

    Notiz zu {{ ing.ingredient }}:

    + {{- '\n ' -}}

    Notiz zu {{ ing.ingredient }}:

    {{- '\n ' -}}