From c796f10f4e4bb61bae16110ca6d3b1c44ab47a51 Mon Sep 17 00:00:00 2001 From: Georg Hopp Date: Fri, 10 Nov 2017 18:40:43 +0100 Subject: [PATCH] first go version --- .gitignore | 39 +- Gemfile | 50 - Makefile | 30 + README.md | 39 - README.rdoc | 28 - Rakefile | 6 - app/assets/images/.keep | 0 app/assets/images/gpl-v3-logo.svg | 389 - app/assets/images/gpl-v3-red.png | Bin 2920 -> 0 bytes app/assets/images/me-white.png | Bin 4446 -> 0 bytes app/assets/images/me.png | Bin 64202 -> 0 bytes app/assets/javascripts/application.js | 16 - app/assets/javascripts/parallax.coffee | 38 - app/assets/javascripts/welcome.coffee | 3 - app/assets/stylesheets/application.css | 15 - app/assets/stylesheets/welcome.scss | 492 - app/controllers/application_controller.rb | 5 - app/controllers/concerns/.keep | 0 app/controllers/welcome_controller.rb | 4 - app/helpers/application_helper.rb | 2 - app/helpers/welcome_helper.rb | 2 - app/mailers/.keep | 0 app/models/.keep | 0 app/models/concerns/.keep | 0 app/views/layouts/application.html.erb | 72 - app/views/welcome/index.html.erb | 243 - bin/bundle | 3 - bin/rails | 9 - bin/rake | 9 - bin/setup | 29 - bin/spring | 15 - config.ru | 4 - config/application.rb | 26 - config/boot.rb | 3 - config/database.yml | 25 - config/environment.rb | 5 - config/environments/development.rb | 41 - config/environments/production.rb | 79 - config/environments/test.rb | 42 - config/initializers/assets.rb | 11 - config/initializers/backtrace_silencers.rb | 7 - config/initializers/cookies_serializer.rb | 3 - .../initializers/filter_parameter_logging.rb | 4 - config/initializers/inflections.rb | 16 - config/initializers/mime_types.rb | 4 - config/initializers/session_store.rb | 3 - config/initializers/wrap_parameters.rb | 14 - config/locales/en.yml | 23 - config/routes.rb | 58 - config/secrets.yml | 22 - db/seeds.rb | 7 - dictionary | 10 - docker/Dockerfile | 16 + docker/Makefile | 28 + lib/assets/.keep | 0 lib/tasks/.keep | 0 log/.keep | 0 public/404.html | 67 - public/422.html | 67 - public/500.html | 66 - public/favicon.ico | 0 public/robots.txt | 5 - react/Makefile | 40 + react/README.md | 2164 ++++ react/package-lock.json | 9420 +++++++++++++++++ react/package.json | 16 + react/public/favicon.ico | Bin 0 -> 12262 bytes react/public/index.html | 34 + react/public/manifest.json | 15 + react/src/About.css | 37 + react/src/About.js | 75 + react/src/Common/Quote.css | 28 + react/src/Common/Text.css | 8 + react/src/Common/Text.js | 16 + react/src/Common/Textbox.css | 12 + react/src/Common/Textbox.js | 11 + react/src/Common/Title.css | 19 + react/src/Common/Title.js | 16 + react/src/Dictionary/Dictionary.css | 61 + react/src/Dictionary/Dictionary.js | 34 + react/src/Dictionary/Sense.js | 11 + react/src/Dictionary/Source.css | 4 + react/src/Dictionary/Source.js | 25 + react/src/Dictionary/Title.js | 11 + react/src/Footer.css | 36 + react/src/Footer.js | 49 + react/src/Header.css | 83 + react/src/Header.js | 40 + react/src/Links.css | 8 + react/src/Links.js | 71 + react/src/Page.css | 108 + react/src/Page.js | 88 + react/src/Skills.css | 10 + react/src/Skills.js | 78 + react/src/Tests/App.test.js | 8 + react/src/Vitae.css | 8 + react/src/Vitae.js | 41 + .../src}/fonts/ArkitechBold.ttf | Bin .../src}/fonts/ArkitechLight.ttf | Bin .../src}/fonts/ArkitechLight.woff | Bin .../src}/fonts/ArkitechMedium.ttf | Bin {app/assets => react/src}/fonts/Celtknot.ttf | Bin {app/assets => react/src}/fonts/MeathFLF.ttf | Bin .../src}/fonts/PoiretOne-Regular.ttf | Bin .../src}/fonts/RationalInteger.ttf | Bin react/src/images/cc-by-sa-4.0.png | Bin 0 -> 1697 bytes .../src}/images/gpl-v3-red.svg | 0 {app/assets => react/src}/images/me-white.svg | 0 {app/assets => react/src}/images/me.jpg | Bin {app/assets => react/src}/images/me.svg | 0 .../src}/images/waldschrat.jpg | Bin react/src/index.css | 5 + react/src/index.js | 9 + steffers.org.go | 42 + test/controllers/.keep | 0 test/controllers/welcome_controller_test.rb | 9 - test/fixtures/.keep | 0 test/helpers/.keep | 0 test/integration/.keep | 0 test/mailers/.keep | 0 test/models/.keep | 0 test/test_helper.rb | 10 - vendor/assets/javascripts/.keep | 0 vendor/assets/stylesheets/.keep | 0 124 files changed, 12835 insertions(+), 2119 deletions(-) delete mode 100644 Gemfile create mode 100644 Makefile delete mode 100644 README.md delete mode 100644 README.rdoc delete mode 100644 Rakefile delete mode 100644 app/assets/images/.keep delete mode 100644 app/assets/images/gpl-v3-logo.svg delete mode 100644 app/assets/images/gpl-v3-red.png delete mode 100644 app/assets/images/me-white.png delete mode 100644 app/assets/images/me.png delete mode 100644 app/assets/javascripts/application.js delete mode 100644 app/assets/javascripts/parallax.coffee delete mode 100644 app/assets/javascripts/welcome.coffee delete mode 100644 app/assets/stylesheets/application.css delete mode 100644 app/assets/stylesheets/welcome.scss delete mode 100644 app/controllers/application_controller.rb delete mode 100644 app/controllers/concerns/.keep delete mode 100644 app/controllers/welcome_controller.rb delete mode 100644 app/helpers/application_helper.rb delete mode 100644 app/helpers/welcome_helper.rb delete mode 100644 app/mailers/.keep delete mode 100644 app/models/.keep delete mode 100644 app/models/concerns/.keep delete mode 100644 app/views/layouts/application.html.erb delete mode 100644 app/views/welcome/index.html.erb delete mode 100755 bin/bundle delete mode 100755 bin/rails delete mode 100755 bin/rake delete mode 100755 bin/setup delete mode 100755 bin/spring delete mode 100644 config.ru delete mode 100644 config/application.rb delete mode 100644 config/boot.rb delete mode 100644 config/database.yml delete mode 100644 config/environment.rb delete mode 100644 config/environments/development.rb delete mode 100644 config/environments/production.rb delete mode 100644 config/environments/test.rb delete mode 100644 config/initializers/assets.rb delete mode 100644 config/initializers/backtrace_silencers.rb delete mode 100644 config/initializers/cookies_serializer.rb delete mode 100644 config/initializers/filter_parameter_logging.rb delete mode 100644 config/initializers/inflections.rb delete mode 100644 config/initializers/mime_types.rb delete mode 100644 config/initializers/session_store.rb delete mode 100644 config/initializers/wrap_parameters.rb delete mode 100644 config/locales/en.yml delete mode 100644 config/routes.rb delete mode 100644 config/secrets.yml delete mode 100644 db/seeds.rb delete mode 100644 dictionary create mode 100644 docker/Dockerfile create mode 100644 docker/Makefile delete mode 100644 lib/assets/.keep delete mode 100644 lib/tasks/.keep delete mode 100644 log/.keep delete mode 100644 public/404.html delete mode 100644 public/422.html delete mode 100644 public/500.html delete mode 100644 public/favicon.ico delete mode 100644 public/robots.txt create mode 100644 react/Makefile create mode 100644 react/README.md create mode 100644 react/package-lock.json create mode 100644 react/package.json create mode 100644 react/public/favicon.ico create mode 100644 react/public/index.html create mode 100644 react/public/manifest.json create mode 100644 react/src/About.css create mode 100644 react/src/About.js create mode 100644 react/src/Common/Quote.css create mode 100644 react/src/Common/Text.css create mode 100644 react/src/Common/Text.js create mode 100644 react/src/Common/Textbox.css create mode 100644 react/src/Common/Textbox.js create mode 100644 react/src/Common/Title.css create mode 100644 react/src/Common/Title.js create mode 100644 react/src/Dictionary/Dictionary.css create mode 100644 react/src/Dictionary/Dictionary.js create mode 100644 react/src/Dictionary/Sense.js create mode 100644 react/src/Dictionary/Source.css create mode 100644 react/src/Dictionary/Source.js create mode 100644 react/src/Dictionary/Title.js create mode 100644 react/src/Footer.css create mode 100644 react/src/Footer.js create mode 100644 react/src/Header.css create mode 100644 react/src/Header.js create mode 100644 react/src/Links.css create mode 100644 react/src/Links.js create mode 100644 react/src/Page.css create mode 100644 react/src/Page.js create mode 100644 react/src/Skills.css create mode 100644 react/src/Skills.js create mode 100644 react/src/Tests/App.test.js create mode 100644 react/src/Vitae.css create mode 100644 react/src/Vitae.js rename {app/assets => react/src}/fonts/ArkitechBold.ttf (100%) rename {app/assets => react/src}/fonts/ArkitechLight.ttf (100%) rename {app/assets => react/src}/fonts/ArkitechLight.woff (100%) rename {app/assets => react/src}/fonts/ArkitechMedium.ttf (100%) rename {app/assets => react/src}/fonts/Celtknot.ttf (100%) rename {app/assets => react/src}/fonts/MeathFLF.ttf (100%) rename {app/assets => react/src}/fonts/PoiretOne-Regular.ttf (100%) rename {app/assets => react/src}/fonts/RationalInteger.ttf (100%) create mode 100644 react/src/images/cc-by-sa-4.0.png rename {app/assets => react/src}/images/gpl-v3-red.svg (100%) rename {app/assets => react/src}/images/me-white.svg (100%) rename {app/assets => react/src}/images/me.jpg (100%) rename {app/assets => react/src}/images/me.svg (100%) rename {app/assets => react/src}/images/waldschrat.jpg (100%) create mode 100644 react/src/index.css create mode 100644 react/src/index.js create mode 100644 steffers.org.go delete mode 100644 test/controllers/.keep delete mode 100644 test/controllers/welcome_controller_test.rb delete mode 100644 test/fixtures/.keep delete mode 100644 test/helpers/.keep delete mode 100644 test/integration/.keep delete mode 100644 test/mailers/.keep delete mode 100644 test/models/.keep delete mode 100644 test/test_helper.rb delete mode 100644 vendor/assets/javascripts/.keep delete mode 100644 vendor/assets/stylesheets/.keep diff --git a/.gitignore b/.gitignore index 85f392b..f5d1a57 100644 --- a/.gitignore +++ b/.gitignore @@ -1,25 +1,26 @@ -# See https://help.github.com/articles/ignoring-files for more about ignoring files. -# -# If you find yourself ignoring temporary files generated by your text editor -# or operating system, you probably want to add a global ignore instead: -# git config --global core.excludesfile '~/.gitignore_global' +# See https://help.github.com/ignore-files/ for more about ignoring files. -# Ignore bundler config. -/.bundle +# dependencies +/react/node_modules -# Ignore the default SQLite database. -/db/*.sqlite3 -/db/*.sqlite3-journal +# testing +/react/coverage -# Ignore all logfiles and tempfiles. -/log/* -!/log/.keep -/tmp +# production +/react/build -Gemfile.lock +# misc +.DS_Store +.env.local +.env.development.local +.env.test.local +.env.production.local -# Ignore vim swp files -.*.sw? +npm-debug.log* +yarn-debug.log* +yarn-error.log* -# Ignore changes on the application config. -/config/gitlab.yml +.buildchk + +# accumulated docker image data +/docker/data diff --git a/Gemfile b/Gemfile deleted file mode 100644 index 04208a2..0000000 --- a/Gemfile +++ /dev/null @@ -1,50 +0,0 @@ -source 'https://rubygems.org' - - -# Bundle edge Rails instead: gem 'rails', github: 'rails/rails' -gem 'rails', '4.2.6' -# Use sqlite3 as the database for Active Record -gem 'sqlite3' -# Use SCSS for stylesheets -gem 'sass-rails', '~> 5.0' -gem 'sass', '~> 3.4' -gem 'tilt', '~> 2.0' -# Use Uglifier as compressor for JavaScript assets -gem 'uglifier', '>= 1.3.0' -# Use CoffeeScript for .coffee assets and views -gem 'coffee-rails', '~> 4.1.0' -gem 'coffee-script', '~> 2.4' -# See https://github.com/rails/execjs#readme for more supported runtimes -# gem 'therubyracer', platforms: :ruby - -# Use jquery as the JavaScript library -gem 'jquery-rails' -# Turbolinks makes following links in your web application faster. Read more: https://github.com/rails/turbolinks -gem 'turbolinks' -# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder -gem 'jbuilder', '~> 2.0' -# bundle exec rake doc:rails generates the API under doc/api. -gem 'sdoc', '~> 0.4.0', group: :doc - -# Use ActiveModel has_secure_password -# gem 'bcrypt', '~> 3.1.7' - -# Use Unicorn as the app server -gem 'unicorn' - -# Use Capistrano for deployment -# gem 'capistrano-rails', group: :development - -group :development, :test do - # Call 'byebug' anywhere in the code to stop execution and get a debugger console - gem 'byebug' -end - -group :development do - # Access an IRB console on exception pages or by using <%= console %> in views - gem 'web-console', '~> 2.0' - - # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring - gem 'spring' -end - diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..6bbb195 --- /dev/null +++ b/Makefile @@ -0,0 +1,30 @@ +APP_NAME = steffers.org +APP_VERSION = 0.0.1 + +GOPATH ?= $(HOME)/go +GOPROJECT = gitlab.weird-web-workers.org/ghopp/$(APP_NAME) +GOEXE = $(GOPATH)/bin/$(APP_NAME) + +DOCKER_IMAGE_NAME = ghopp/$(APP_NAME) +DOCKER_IMAGE_VERSION = 0.0.1 +DOCKER_IMAGE_TAG = $(DOCKER_IMAGE_NAME)-$(APP_VERSION):$(DOCKER_IMAGE_VERSION) + +export APP_NAME DOCKER_IMAGE_TAG GOEXE + +.PHONY: all clean docker react + +all: docker + +$(GOEXE): $(APP_NAME).go + go install $(GOPROJECT) + +docker: react $(GOEXE) + $(MAKE) -C $@ + +react: + $(MAKE) -C $@ + +clean: + $(MAKE) -C docker clean + $(MAKE) -C react clean + rm -Rf $(GOEXE) diff --git a/README.md b/README.md deleted file mode 100644 index 6e4fb68..0000000 --- a/README.md +++ /dev/null @@ -1,39 +0,0 @@ -# Georg Hopp aka Steffers - -This is the personal HP of Georg Hopp aka Steffers. Yes I know... nobody make -personal HPs in the times of social networks. Well, I do! - -## Description - -This holds together some informations about me... especially the links to my -social media networks. - -## Requirements - - * Rails - * Webserver - -## Contributing - -Well, this is my personel HP... who beside myself would be interested -in contribution?!? - -## License - -> This program is free software: you can redistribute it and/or modify -> it under the terms of the GNU General Public License as published by -> the Free Software Foundation, either version 3 of the License, or -> (at your option) any later version. -> -> This program is distributed in the hope that it will be useful, -> but WITHOUT ANY WARRANTY; without even the implied warranty of -> MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -> GNU General Public License for more details. -> -> You should have received a copy of the GNU General Public License -> along with this program. If not, see . - -## Author - -Georg Hopp <> - diff --git a/README.rdoc b/README.rdoc deleted file mode 100644 index dd4e97e..0000000 --- a/README.rdoc +++ /dev/null @@ -1,28 +0,0 @@ -== README - -This README would normally document whatever steps are necessary to get the -application up and running. - -Things you may want to cover: - -* Ruby version - -* System dependencies - -* Configuration - -* Database creation - -* Database initialization - -* How to run the test suite - -* Services (job queues, cache servers, search engines, etc.) - -* Deployment instructions - -* ... - - -Please feel free to use a different markup language if you do not plan to run -rake doc:app. diff --git a/Rakefile b/Rakefile deleted file mode 100644 index ba6b733..0000000 --- a/Rakefile +++ /dev/null @@ -1,6 +0,0 @@ -# Add your own tasks in files placed in lib/tasks ending in .rake, -# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake. - -require File.expand_path('../config/application', __FILE__) - -Rails.application.load_tasks diff --git a/app/assets/images/.keep b/app/assets/images/.keep deleted file mode 100644 index e69de29..0000000 diff --git a/app/assets/images/gpl-v3-logo.svg b/app/assets/images/gpl-v3-logo.svg deleted file mode 100644 index 6754c99..0000000 --- a/app/assets/images/gpl-v3-logo.svg +++ /dev/null @@ -1,389 +0,0 @@ - - - - - - - - - - - image/svg+xml - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/app/assets/images/gpl-v3-red.png b/app/assets/images/gpl-v3-red.png deleted file mode 100644 index 36b1b4b3781d6363b8bf84aa321118591670cb47..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2920 zcmZ{mc|6mPAICpFW5!%l$(UE8)wY@n1BvHv@ntS@3NifxTPN@AO%F0EjsZ0JN(Bu(cP_xBw8T2>>(R0AN@E z00+YuFPx0_9#CIfD;)6W-zjaa%GpZ$JGZ#V!^GH(kUl2crvMEC1id6j*c z^DF|_Mb7FzGx9#68U{0`b9oY1Kt7!O8zb1;!*k=iOFQR(k%T(Sc1a6! zo@33}j}&Wx+F4B}Sd$5#q-F%RMG25?epOKTbXCwpq=(pXpv|wBdVuR=<5s9_{Fq@D z83Rc3i2!+!tkT?GP~943IJoiofZL%r7+s09E=ai`U_pQ0zhdV_{G!83U`Mk_9)l2L z{t&CRX}%&ll+9s1#;AjHUuw2CXcsboju^$qT4XSP)MhJGT_87a*B4g)PuXJ?&79j`XZ(aU5s657H2x# z#KLrk3y#Mo2=nzPlzy8syt{pnD%ULZJqzMmW>*M}6R(KtL|uSiy^+v~YC>_yejCFK z277jhCFIidTD79%6MqJ@Elna?p{Dq~_M5*9D|Q?yWfm&?yVWRf_$a1#FN-*!Sv9&p z)SD)fWD=np!tYv4y+E(V#dum5t=v?gmpNWw!$jIWeS#RAwV|J?{Gho)AcO$BLZgB$ zoWN1XL3Qwwp8rcQ-r}4SN+zeC8%K2L&2{zGs+mSAm79HA0%o8-C%qu@c=Dp-ugeWf z7oVHUb~v5UXygW4^&e$cseQsJ;tRjJ7>?x+xEez*7d_ST)&TRz?`f%d{Lrn}`>`Wc z`p(ZvG00%Z?_?f*G%V{WfGrRR;ZI zgoRTDIjnVkQ16!!z)E6`O)ph}0_dx(_XhX!4G9s(*}Z-_gN zv%{p4V?9)P;IlslBdtFP3d`4%^Av|=@(iY>sK?%win2~c*aa9-+`U)Taw7+5J8c&=%I>v zw?#7`3F)*s^UM#qhmPJnB5@#u&qy!|t+}HT7U3PUavKvDY?P@)xf2~zh;JOOHH{lo zuT(UW7VFxrOgJS8s{fsk858zY#&yGusEjFTG9Hx);p6|GGalC zk|g-F7n{b#D01W-Hd3Di<7IOa3p&8*wA9QL_xZGC`ywtT{3q7SIUcqQ;hpoH4i~vc zs%Oq+xp$3`25nWZy+jjl6b#hZ(Y2~4I3u3czr9kZn<}hB{FQpu_$$Eb-<^DKMo!vK z4bH=;QD{felRWp_2eR~bpvP}^Htpxtx5Uctw48OQ)F}FZDg$@P9SkztmV2L9jn}<0 zGtrbWb0eVntu~rW-!#RvO{7vX0t3pn9#mDwtoC2cdDTqbuc4o>qo-%K%i+7A6W^qm zuxtI%I!AhYdnMvf2-EcOzM4BD!^nLoekc=ZJgB@nXP$EH&PScaeX90%PfpPK+^@m* zca^OszDjBB#n#q6P%6y-a<3n7dblXh__M#$Kkid+yw#EWwMoBwSsJJJWgF%{Yt@IF| zKNUHB+uR}b__9WyA7mB;8d9_03GE|4s@eJ=IC3{l8itL99`#^gTL3*?1U zzF|lrUanI9p>5VJgsZ`e8Aulm&(oYMVDe*v*^q^}Q&ac>FqjF$%xBB+4fL zy6q-8|1Ae`%x&4yNUTjkvkAptX(q^*yK+7~U2USCUijC;uYZ3$^-~0C{%vcGLEZGf ze5ME*@LIXQR{c8~k=(j0Y|!<4plTp|+u+Hh?=4YLT?OnFj}wFEecWcZ0mDBn6+3=E&2akp4W3_^A8Ogv z;HErjB8y0pw0*rP)vDe3A2X|$%6$%xtFX%s>_Z;Dz1H`qnsEz zZ7k8>Bi!gW8~D!1hmf5TGc%jYm@~@_PwF|?peuL%>qr<|z+)S5Okd=b@2sQPf_ays zSp#{|fP15)00004XF*Lt006O% z3;baP0000WV@Og>004R>004l5008;`004mK004C`008P>0026e000+ooVrmw00002 zVoOIv0RM-N%)bBt00(qQO+^Rb2@wtjBAu*z0ssIIW=TXrRA}C#L%bKCx94+o}{5)K+mq zP&A4IXv_qehnxA%)4AuKX}>=R$Y3C$?(@$*d+)WsXYIB2TI+5?adi7B9w2A>ZsfYH zq%(J_*Iz1g&OI;uvAIf|VHBE9{1)G2BVWOF9KhYS8@}URRyJL>#{>OsdU4?-&dxPz z4Yh3pt=kW7QXj%I-z1%mJSMiF#?!JP8q+DIlv>o#lwhpmuXeIwD?FDjb!Va_TIYL5yo#2{zl*<+x`)jFmK&< z)S}>$nAP%?!3! zl+tV>{PMn46a%P54L(CBD0a_zb?vj?KDZ?Kl&(;kZteK-lb%-G{>^OrW4K7@e9WST zmH4Fj#s@@t%)(FOhvctwesRu4u4kmdM=VOIrVYNZx0K?EZvy@bHdJ*Sj3>MPyt|m< zIb4IpF_T`veeBO>+g_YZ;o_kZ+DsUH9JwbRyP z9kV9y+`Rjp-EUYU4w&w&KZm0E-+(g-xPjT~`Ar))K6Zw>AAkB<&$tsV%NerbjoIL* z)<~bNyllf~XADC-ZGU6_j;JWkZf)H2>^$QdtQ~dY2DkzJ3{9+2Qit)5Gs}LOmd`nT zxB`P`rWBP=R@`7tI`xmZ8Yz2CaWHL;ghc|+RTGzgg5c@G4Ma&*WjX6p$tfofqCn1H z?e?-qrV4h~)z|ZXIZZe>8`R~l;#o(|)a0oqClO9apAIe)^Be@AAOM`RZ}g@HPZJJE znxN`NU*`CsJ79uCC5CbDh(Rm_g`uR867vs-Wd?~NYxawS3*kAvZP#>US;;0v@y?O% z8F&sGun`{%3F#NO5jO(>WW@E#GH($J6J+FroUWYeC-LEFY0fYp6efR0*$*CKC!iSs z(2GVyylr=d|GI74)mvY=m~olHAb@)zWM{tQjSzg5i0w?l@>d2kYKQ;=?=G#%Ra z;2VAmjiA_se|X#ft{Ie?G`M}ol4)WUy9pE&f5uOkp+8t7nNKk(r8GXYv*O*;3o?0d zy4f7S=B>JG(dMq}6W(^rLdk@pl{^brdged{UYhbm-c6(x*W*7?VMVs-VF0iw&lr~S zW%{MGUUzy9mjPo?0{{dF7dTe%{NEnWL4I4dSl@qKp*gC+X+uoYK~A5LJhN4>K0te;~odQ;OMWktsV0yCc8m3iAtP+xX( zSKSx%3KVL+ue!d+@&tOg>$#!A3eh%q-y7fG7lwDd^lsFx)UqSFf|}OAT|fiw1V#PT zsi8zi!=qc4-IPC)g+M{E6d%r0hAE{qRlC0YXYOX~@qTpOZuyRJ+nj5KC!qK8XB_$z zBN6}LLCnDKa0f2iq1PqjnrfLvij3Q!U<&{pSD+~|rBBWWf>K%8^1wfFak!_ey|}OE zRsF(oDbD@`OM`25`vnXO0BU37BX+eC99E%AwGCzBG_5FMeF(2$HL3ux=)|?rwS~D$ zK?c&U*{tp3x&~A2uXnLplXmgA;LHsC0iCaC9fw}CpKpy1j|?rvEG)$e{0Hts{ZS%o za21W#>IOx2c=sdC^vqin+0-%yH2XMB&H!mNM~n^tFx14WbFI~Q9@pcqqlysx2(*u; zSxlKV|I)#locVL-{uuMMYMR2j@xyP)W;NAWtc7;Ld9OL%wr6FYZzKb)QFSd#tBe7QC|2LSK{ ziV??EM}!8UxqEjk^%VLc=t6L7ed{G9T325m$BE#^1OFS!pzLPtKtJVsy#w^?gOgu1{c5voKG@B^{@YBQ}BaZdX@A+fo~!r9S1y$ z9J6$>_wvK_0fFxawEpGIDsyM@0<7S7>A)kLa6y^9{mI?g7hpjJh1!47%wZ;1bJ!-G zwMtsuPiD0LNi>PCG`voGe#~$}akFssrPWW1(pQ~EI#aJ_S|0V5NarLwG6Sv!5f;*G z*VZOvfoEV+qXW0BD*w%t=^l}zDcv*^k^T2Kz7di_LtHFFUm2_B)tJq*#ILaVq(6B%VFDwWUu|E33=itJz>MS zFY!CvJ0>_|k~cF=4Qf9=g6QiT=?LiFBD=qaco$PytZo;I3xGg`OFsPO? zTKl@1m3WSnrDV$V0-~>$T9FwOoGm6MSye_V3MzT==m82nY4y>R(U*L>=YMv+>pHt2 zchQyHl>XM8*elz-wq;WmmX--5LzCH5u)lZOEK!Wr#SZczF^|sj0oNpz z;g12wl3T-DLLGKq%Pbsf!gp>hnEOfAD!7wG$ z%hBCK-4Tm^Yiu_EAwDoxESq*Cca+|V17AM;(zDBXnLl8BqFl&4%G|SDkO%}67F1u} zKUC~bE6HGIcfR|KDwen)3Yn;?PpBH`DifJZy+$x?Z15}az8-rgywbId6OP!zTekS# zmGZ<4DZ!NXnp?}M;W|_(+qlUE`94s$({QV8zFdn~CeM0&a~Ah!t2~K`b+S7%_9~w1 zKreP`{J{x}aRl!0Ij+k6FOXCl$4Y@JO*qmL7CgL;t^;~2w8 zcT;7pd7i&+(Criow0yJT)SBmlwM2bav}3=LIWZ>)ta}3IIEmGWLA7Lmny8Xik$L`Q zeOL7*)tr^>AremAIN%N3g7=Z{cR5e}KlRwA!vcXlCvFb6hyGRCP-z%%IG2=G&u#FT z%^mBtRxCg_hVl4lngbj0I9{-^RXjT`G5`X_jG9?pAMAO%q4fggN_6tJ!8uj)cT9b6 z@qe>6YNz>@Eed5c%|jT##}zmK+*Lguy)CMk4oeaj-$bF#tzgY=$?w9o?UIw=7z5w__!- zX`PYZCU%G0UmUD7S@1&+%)!)AR^dztoKRS3V~KT&YmuWHOIQN1gd)`)uCaQ4dA;`+ zLXn;t{(0#6Ic+)!DsT;MIK?Vl1VJq?%|JCxA`E1rB;VoX_%VF}SftE&ou8d^hi{P) zjXX89eb>7y)Xlgaek>e|{7vYko>K4G3@5W{Yq-COlTDXC8}GL#dK#`=~&?wC^AEzKfdkG`cKYwcJVV%0We_3dQZV|sKgD) z_nx$=MVAo~$m7Oddh5yPbD?*?=yevhH%_#{Zl=I-DueQ|!tcTTSbqM(-!ooOK6KI* zMV84J4!vo0Klsi=x2xAW{Qg{*5{D#F#(WCCk@0E>_~7L5-{ZP-iZ{t+Uv*J(Y;yhj zmS|CFSL3_nGD@vLOjCI-mo+Wc{2VOa!2tdYgVE^&)Q1dmM{z->ZhG+_k46J_nK=d9 z0-z5yyqe5gTF}iXx@g$+nVuZ)EII>fQJdVxQ(-T_@Ps&dfpA{@^XoM)`Cr>u3e96$ zG%3sOxjC;TGww-iI4eyhf0gUpu4h}A{PGeH$qFgUm;lD`qP)yiTICPCX%0uU+!NvA zx5k^x06jSvomk|b(b*?E%c}||I~MUJ4fpqU2t*BE+_8|EL=39{pW#Au1YDdRGD=OQ zHBx=TI_zznyofn2qEXmJBi zFfD?N2Qj+C+5$`33XL-ewOoC^%rk9!)WiSAHsM@+_lV}k;HOSTn8l8i9;%vVbcH@BY_eCx+Tzc zBhuGE=5)FOZUF3NM73>uCe$%*a7rriMdt%tlA9UT?HogxQI0#q<;)iCyDtf3)7?xlQxq7Mt%TMs`0csb{iX;0T*U}kPvKYCjpYE=!-My!fmK)wj$j@J zjq=yF?3(KBml{L&#I`q=FY$N{@S{c=hd>ei*wPuV%u}QL%>(Zd^YWsgH_7Cxvu(9O zQ7Cp9sWx_vLy}y1S?wSCxuBdy6Q%__ROb8aupUB)FaWR`zk)MEdzm&Vb_IsIV+UBy zI_V9AskQ&B#LqLP(Y1cxMwy?#z+B}it_|!D>`#aS@8Kdmzc_E|w4@**U*71*=EpgX zxe{(@@R~%hm^(mO?s)Ae?(DyW+9Z>n%-@r}e2!x#r0`J7&IOD3vlK-fh(yXPo4a4D zkOfxEur|)+u+89Qk7DRHT`r&Ub}ca(3%HO5G7M|bL4!H|N^%3-j7d3aJ4u)`&CXAY z7r|~&hiB3M>{>N*%Xn6jOt#?9>V*rvZ`C71({nxqdSg8|>*B3_9W*Z_9OxIX*oN z-6It9akd5o1eR?9lgTawj^Fl5&`F+e*(G+=LRO=(7kNFQ3J1*U6fIxH_{<(FPl*=! zc$+1K54d~>>&~8N$|`XwZhN4+bwD$USXqr^f9AKsBuxNGwnXYYQF8@~oYLY()>7%n zgJYkxQoA=43DnCKp>UvuoykSxfpoiMdisvV{A}_>#t|Iq=wNapeCf1!nj<{} zwqmcNG>3PchhKwHiTM@);Qs;Zc;&+eYe|a$001R)MObuXVRU6WV{&C-bY%cCFfleQ zFgYzTH&ih+IxsalGc+qOGCD9Y$HD-60000bbVXQnWMOn=I&E)cX=Zr004R>004l5008;`004mK004C`008P>0026e000+ooVrmw00002 zVoOIv0RM-N%)bBt00(qQO+^Rb2@wthIYE;ZXaE3!07*naRCwC#-DQAWMb-x3=XQ@} z;%+1%KoSB32=4Cg_ATztB8xA!u&}TT3oP!sIE%XzBsd`uBkrEbWVHK!Ke{talJV)8 z9zwtG56IkG)m7)-K3#R{ND%s?;W!UlI_qpD)!uiw|K_>FOc%@6R;~r_6>T9m-NVly zgJwh|-2-S^#Bq+Oh^R7A5&!m}xG*Qo4Rgb2sX)XPA_Cc!+O-n+FYDS#Pd9kcD_(KP z?v79QgfhsWSrM$PD~PC2mY6tX$y268jvR&7bEK|XiCb)%SNswz4D+=zKXG#s9dvc6 zKM9nWVy++EI&{Pn)=c-rGRUAAu~I6C`8o>&S;}M^q>D4O_Pl!?V31pNu$^AoTGd(x zm}iW0bnzE2d0kgI0&Q(%H>>DlmY2Qkd-D~GEz&mKQ_CQOWV?@_~sF zgN;bHI5NnfnbD#Z#37z(Z*xCb-P{949%;WC?u`hE*ueNh=PvX{8;9xYB|qt})NDhQ zm}{XjaphuIPv{5aSjSIETV*e+ILXnnzzpY@VV3{%?^d&y)H>RTKrG!N%OHc4qJ=7m zP5daTvq>FXVxm%Gy$^vL#Vgz$5z^W^qE2$N@54$f58d>%np@go$oEzyUCcKXt)h)8S$@H&k_&f>l1rJP)?70A_AwlWJ8L2e~A5fQerw~7^cS{#%;?8sV2-QBDstm7v0ph#Z2#h5_`DL_`b z2e3SDR}xs;X1W+x{=C4pHnOTNdTFc7H1GM)FC_&*5XW(q`;)`t&0p*#@I50*LF;7s?6C>9e{zN{eU z*~ai-bZTK><;j`pmVEE33-CCdP78f*=#FXIA{z)T-| z(o2ceNFd*0BsMcAx=$F<&8*Mjn^iQJq+di|i=E~wSGjVKU(zkg3^HgmTAYF?(m`n; z2;vnZTg{E$@u0Px=rC=P8-x;tigZ%wCU>~Rk=~MH7hMcaXporpV-(SVt^Brc*1G!${A7F4>OurYpmr+Z~4Z; z9}G#iFf+)Yk!W#Sj8<}$hQctar@?x9)dY9iK%TFS^pQ;*FSJN+xhU1yl{OLT?%0Yh z#`&5+)Um$w{U~4S-~}CBWtePx33RXqDD||9^t7H*k>#Y3bTZ2E+7JjWOg0UO+QOR7QEZq?yg2z+xg}bNqkzEI6c`zvG=Vjm{X~{+mP6#WSHUag=rtaQU)plLt1%L zOrcQRM8BHo1?Sq{Km*;gT(eTK<^B>=Ahg6&wvt7p;>ZH5Zj8`B(8gA7F-a&i*|Vls zF{n{qw?wE!flygeMa0eYvH!Tz4NgvWznhb_O-K_Po3Fr4S{+o;)fKR#on&8;c3Eeb zVO^Q_0VIb(YbRUBYPQwcSK?*~6}iGzu2m$o&~y{b5wE4Im=P8Vg{Hg3P?3Q39qCNF zi(20_p{J8UnGxG~-Rrh@L!}<37+a~g@)|yCtb^=rsDZ9C%^f-=)le@#dQoTQRouEW z?Cu7gc22vrGt98Aj9!`UJq~ij^Ic*$1#Z^gGrCw;7i1Y~Gppz+ORhFL$QRVoS)j9A z0ovHio>tY@Esn8=t%XiDL_}L}n01@iLx)-9Tt6$fSMq?9dtI%I0Sbk(E8<}p51 zI=~L5ne1l+l19WlJ@u)lDK%2*YuwJJcF|Qtpq-rz5869v{Oo%JDkXpjR|t;pZ8N#r>MYwllkMPF2in>Kt$g7@MQ?t((EiCm&GAr{u9jTq z@^p(lgAD43G#_)WW;|@^7*YLgCKn4W(XENkS7tiddp2{T7d(?)UdDP})(8A7)X5n6 z+UcoH9eWJLWEtyTg*I@IPi^K>ce0V;AXjNecX-rmyL&Bd63-xmdLfTW*0_!=(dllD8-Dk4$292q}%SjtX+(^f2zw~?~O0MVqWNpgQzPHRU z!@4kyA3Yn^GtBWK{*t!uOw9Kl@U7BijyVgJrlj{Guh>;Khj|-LQ0_UM$xZvC&oIN< znYJy)_tvM62Nbx>kxoq7@>WL7^Qha53lR44k|FMNjah+Mtrph|GDt7dq#zdRKu5Pa z!t1)&cxBIx=_^-zT{%v0yQtxwbC*I|D;8faAS{CnS_;ynAOhOC+G(00l5y(=yipl97VFnqjfV3QQ2IRZM8FKl9s0Z?GWsnirR~uhi)rPv; z!W(j&pm@=&O$|u*7&FLVIiz7}A0gK{&i=#YR0*x&0X>SXYHK{LLI5%OK&Xk@+Tr4APBeT0w-O!W`$iRJ(LfxdouL9=^4PZ1nN1 zs0|GDt?ztp^1|XDd{&1%+8Jcf^k^mpaj=nrV_j3{(5IChU1cfINg&JWCRtriYx~G} z#kQ9}ZuZbj70?V?0Gh>7YK(zw;YoedJ>3?BP=VITd{o7G>>(e&=taZ3~^Q>w@krD9^rlqoh>k>1wPO{W%ecraPMz?q(mhUJa#ErSdi zfhIn7&l01bzc^S2<(BB0yb#r);-;9e3C2+TO#{{DCk~O%S2J>{Ly;Gf~XQe++c7azE zTFVeOCi7ya9%YJ*aET9D-?vRT%M3DD22GLZ@&;JjAiEoFsvpcs@duQ8%AtD8(_i;Q z{+Z@T;2DF6t^GGyyDJoWPOe1p(7^G@Qd+~^;PV=5ay5+O9j#5KzGsHb$0q4C8?JGw z6U9t-eWeO?sbJh=Iwro6kZpc53M>No_VY>7qB-5RydxBl<5DF;FUr;18J;rV46k^_ zh!tvxHjInBVjt0{qO`v{8U7L21YIV#;e%{rn9v;KQv3nMP8Pi-okD}Yo=AS_U(%j1 zVGix?E1~hp>~Xoywx1l?`ne@#dTfS6ST*ghPKJL3ro6*5$gz*U0@pRcB0Irv^+|8Z zpU%+7J3a}~_q;_Z`S?-Rm!iTQ8D>}$Q{N$5`O+Xm zOlp!5$Bc5i+@sShxVK>gKMI9L8N$rO?ECpz=vSLCOGH-k{s7w8+iS}d=xHb))oN>@ zNdikNcV(Di>Y3v1z9DeETlMgC6BN^%=VhlGC};^^i5{?{Uxnfx)jANmUcliN3B9D_ zvZL&tP!gS-mja{he7n#p(cfmWv(qk(3|CI3xVu)gcaNRi(*)a#;dV`U9Y@nHwgj^Y z9AcJGp%Vqq2t{e-PBA5p<>?g#PSidg_Pl4jV044k=*v2yzsF3rCr_na8X2yPOmTNt zk#AEsH%X<_{dBCVM~FYUb17ZBhxOp3IUSm zdZj`y=}dtqVIOma9+BI*%2v4|vJ+d511xUzAY!f%>D=gUGR$y!rntL+cHT@$SF;>! zh#>~+r-Q5jt%>L2|oW35C zc8O%TGBKr{y`M1KrNS+0j8lG#c?d-HaJfXi2@bhw<>H)dwbtKDhWns!X zdYFha8yzB0;060?MPb@SQy&&WTX&0jNq1%`OxR=o?8LeSSD~$~9Aa*x2J(~BOf$-A z83mDHDwv{fzJrZY@S{J@P6SQhW7Q0zq`T*oyGKXjk}(^5+KY?p&^{R;KfFL0ujO`Cd)Q zU<#Ze+S1Iq8UFs5l5EnWEMiA{H@Jg^Mj2s7((_^JS-PiUSj~*~)-rOeb3N>I1^%8_ zT1Mmr3+4soxfO%@{o?;*^QKFbyVRgP{70M;OZ?kDVYD`3cY$A0Hkdwcwnr$E zsq&dY!_jyhgI?YT{ap1-q^_IU%UWVxvsaEs?Kw1xz+e zkBXWRW#)Uw<6X-BlJ5Ogli>o_mHSeuQ?>Qk+hq~qI5B@RDg1t*AvLtz%;Pf^+9Ht+ zCPi39sXTwyHT-d4IHd9YW$?#AW3)>g4m8RUdTH;#YBMgDFSGr4+qyaheo4D_Y+546 zxn{aHSzNQVdyKG_TC!OLWIHOwp5{dgghm^XSx018A2zD-0c3mJOWFwJc(e{p%7lp( zce*FuEW#z*nWniWsUlYKp2rhTR5dYx?TtwJfMV{qsn&v(%PgE>)3I@l>2H)N{%bE= zm|g9Si@jr%S%&+wYi$vAQQ9Zo9E>MUG)^+XKePiI`_5^CYins4z)^~uU{Eu>?KqL^ z(k`70e-CU#(>D_@af#6PHg#VOx0boW8aCEFDk?~Mp{>)3F=bryi;;xl6v%Yo}Oi{O1E$_X!&TkZrLVLjq+J9Rk^vC0CUH(>S*M@1;!dv^+2i8E4NJrVah8Cy5u}v6`S!S5cem^OBGE5g6(R4g?ad(wD zAPPL~tK|FlnT`TYvZ4OHFbYGw=3)5(>|q-NR9 z#j)~MxD@lAK{k|QvYXtdC=&LUo9@L@8d0tdKRUsiqU%ACbFF%U8e%QG*tv-ZwU49Y zK`+mwTR0iCWHeN>oC7;m6Tdmmy-I|>wk<24Gj+pQ03r$;Mz)*WF0VStbf&wvn|w$g zX+y-Ew96*LmdXY;`w=#*Ci~G05BXK-I~x%(H0_gYDJ;;|kc8M-&HIk3?kr)XfI;38 zHfdU@8BTY!+`(y=OolC$4QjLqdi$Wti&I?d8=>iTrCr)5*fRMv>}QxwRpWjdz%HKf z*IG|R8_u{Q6Ab!exUFT_5H`pL(VK`9ZC%Bs#r|rpp?J-^Sr(>y2h~DxuxwuShHLfR zvWn|B2s;|;BPV#GURgHkhd`d*wiO9{>8NDf2IPiFK*s>P7T%uZyrs6-MAxBFm+2v(7?A=@v-_EfMuya!iCyp0D!aaI3jP zskfZ2>ltZZ9<^+i3M4|Of)x_FU>!3R+S5JFGMG>F>y>tiWZ3dp?-fKpa-DClDlQed z-E3?6yF>lQ?Ay|<`&u}%#jRmuv8=HD5}z)Axmclm>w4X{%`livZ9h$riVTDqtW>Dy z8}Vl%j&(+rc^`h!)2_~Rz4^WTo-<1}AIA8WE-u$|`{ggq_p2GQmH2y#GF{h%Ec+X% zZ`k3%bc-Z|7KM5#h;Q7&)-Kbwii@El$7}B=MWLzbp4aaNLzriz*6S?u*MBh2nfCOh zJFM%4X3)2LdeeJ$J>=n5bioUsR?3$e?Nz z=pY`jC|p)*Im)1wTWseA=cT5CNi8UGu$ME>FN5Duj}^p7A&1&VV3@xxWAt9=Zu4Zj z&WtNEuUEa$R!lU^373~zsZdCfC$zCcBABDe5$KvszMnw`sF#9RmyQmUtfk+?4t*@2r0oBMN^wN<(&ou zkF$-nkAwU-;~Lc@7-Leie%?UmX#adQB~CKJ+mLdPqGTKq##Dn%ij1<40}q%6)p0hnA;ROSI#Esp2tdzCz$J9A!5zA)!5N( zHZ1jex~HE(T2ZTl7!TVSY@88j@3>?+mtpcf?jqM(MZA5w=dlvwa6%s_#=B-T+sC$Z zghy?%hg;JvfDF=zS{1~W!%KO zto*ZUas$^>7bKCpEtK#w;p*5Infwh!)%l)=>sQzKj)Mh@e|3jg-9J4I2 zq?teWNH<$0FB881hea(x#HSG0Lwi3c#9FpVUiiiPhKl>Z!M0ZJ0~c=l&4!*z_k30= zM1@)>k?Q|CtMSr*J zi(Ta@@{Io&aa)yXt}|#T9utphwPf*ZC`GoCisQ~7jk2o|hUnbH!w4Mcz4Ch>a!k4f zl0h0!`|nQ=t5{+Ja&2w4Z-o|F)7siF(O3dp0W-j%01O=)4vDXt6TC zRM;Tacd&MbG)uPnKySg#=@v%@X+iA@qN5(h7=9ZL z60vZD?QQUA`Uy;x=M1Guht(`Oa&&GM+wcU>3SUmQNHRzZYI(s1G0lT+FjE)%$kWka zWx7;KVDd#17IyiA;#y%_17s=I&PF)FaTW`#Z(tg-0k2{Y(S6b_lnl~>S`@@5g6Yl; zo)q`R-c1**0a-I{c`hB{El0jNf z%j?!f2SF@kp#41RHf@o!OeFA(%nBma_%mO)&}=)H>jO;oqauXnDo?|J`dOnc_UsH+ zKGgbqG*8?%wDy#X^|#J)m&^Q5@!jd3#Y%-zH&bQ&I);hc!%n(6Q#*+| zed$18Z%;Ta%-bd1!pWeSQHz2Yt_K~%w$Zq_%~r^0|GpD_lgT5MT6{=P`^z!IwMNRd zlRcbkjWiFdx4+r#!*mNLgJwo83SxUSh+ug2=qtyb`l$RGvi!6c)#aj>xhJu1~TTvjC%YQAhP znInup7;0A#ft*_Im}x=!EodtrK7toLY_Jc^G^mmn>%vO$FQM`p)pu&KMhh^OX3&hN zi-M@_m3YteSJOR@l@R9{5Rm)UF^xaiJwO z{7MZ-mg37GMc9vB{3~pS@BQRxPx-H>&C=dF#v!IuKpOJ=1rD?JzUdZF2F-@LtRTuo z?O4M>=lo2XfYc&Rdk5MO3q58{dzp zD5>SX$pR*)dnPLvelSrlviYwgy|0HNpNQ+J7xJtrDod+oJm6f4z~-_ZO1FG6XeQJ} zLDcjsRce7;@w2)Fa2!@Y64c^NZpJtvX_rjMSYn zX^Q_isLKjsP7POE>t>WwymLdkXR=ZuCiJy1&l(E6?;X$E$RS=#R@RCuH{9F?bzRt? zTD;|+w=_ztgG@2^KMZP75FJsYf(X6uNH0a=e@XXDRyu4)S2x=oylsX{JStR<`9|vB zz^`fN1{FZdwT4^$1lnd+5Puxhq98to1<7hoRiW4|hG%8!YNZr`KvV&?s zb*Odi?*wlvQ05C`5v?)0wyChULzE$Kj03|U6O{2sK&?Lnt1;5EW>s@JJ+JCYji*@8 zBeutUpXli(5xZHo9NpYx-+1KLbc-s3CP%Fb;!9?_(xhrGN99nQ z?pdrW38tE1o|r97snb`vz6h1pA=kq!-zZ5M zoVx2hBi*9Ppvh5d!NpT(XMefX-jIj3Vfp7po27d$D-9-Cb+WJY^S!xtca9LHmWUc^ zxUw3aMne&iTL+(tRb4GEK^3tkHcPIK0)4G!ev^D?U0klB=6Xvx;=WXvNj|soqb>>}r^dTFi+RVlSEYLi-K0>1>QE};&jhs zrNRIqg(41gyeG^S^|OdRa;&Xu8V8n@bh8SqB`Z@xXXQt&3StKqBt7V=#wIpZL)nZB z8i68Gr>Lk0FC5N39CtY1&)Ah8udh$&mS8Pxnk#I_yS? z_hkEvcII2B!b(t;wV*k(O^3?R-`XnW&dp%uL|tqUt#q#O`lfC-a1Z0tJ(raXuV~BT z9@N&6S~X+d$=VS2wQ1ToQM*in%9R~;Q4ra+zMR{*NslelYCUTlvP5b>@oi>AEn=pB z7^6dt=SVEOs%YxfL{wje*wc=aoS0rAWzfV(m50;b4xDbsbkC+i*j>I@B+QKqWDAyK z#K1I;?L)>m!;kgITwUbLCQkv_%j(E?u$=qSD4h(N9(DQIEU)Ey%otz#A<&Yo+Fi`A z_NO%rY~Z|blBdeQ)!w!?G~8FpMF3o@Z5CIr%FVYs)j5P5fMT1523iYE-vta(Khgi zcdc%F`4$?lR0QK)u>Hg(N%z6#N4bD6%&=-58{{@)<%*tm_T%IJFAZ|Zpm`9~_R}xc~-wPC<>g#jCwC*U+S(ZuPA8f(2=q1zLMH?ZT{zldV(xJCxz?m$e!x|3-PW z!QQ_iVyGJ&5oWcl8af@w@fYjW^6Ojup1qy*(Z=ESv%AObv5m-bwCQo9qn9)o}$+FXZsWg(t2PRRD9c)2*|g)HDopT`wlm?$(4e`xE?{hB{g`NhW~-a?(AN44MvgiN%=X{W|rP??lIY&9nNP zla|TsK;TRlis)_wd%4@$+BIrH6LFNsU9TTL@r#QM)!$e88T=f`rJZbVd3)<7om&or z>Zquj2lLDjqI)fVwi*1sQJazCb^?E|mtEsmt0(#m1nzEbgUVn-tl}MW6{WcQnTC1M zKs~e(l~pVhCerO?M^N0Pb9p-IHmEjM^@!^3EeC7c!1g`$GbXKq$)M>_^8%v-{JFvFlV2U^3)Ae)i%q^5S_pv) zQe=B5a*G~`WUlkmzR;_*;A`u(ly@7qP+0@p7PwKn{nIX)44a0vT_)fBR1nc-YC7msHwKfT_irln6q~G{09NEP7(E9OLTh#tTli}}`wc8+a>l`Mu zEGGI|U~BU&Hq>B(CiOOqm`8vAFen9!su`~EcZ(CTTrH_A(E6ghn=<=KDzK{i{mtq} zr+XY3Gzn_|&US2I!pVV-5E1GvS6}~evLRt!Rvo;y8-g5RD_gqP?kNa$Uf@EvC~BD@ zNFOuZ>srp>0zGZ)&_~iejtrUvwJV6ux;3chJZ+Jsw`_qe{m1M663c3ea&6}+i}U~@umT9oc_R6?2CJabFBN0C93pmqh(PHN(>qI%m`=P6QMux*Ba zk*7}z&Mgvn)*HvVH^rk&DSj|A-9xB^&W0G1Nm{&eqAm&|b#4qpoF}iREZHgR@;jTb zu6v~FCqL#R1rNwi*$7jO4O!s7&Ek4dHo6)4fIMMa5ZkV@2i$bs`yd~UMX z!~S6(Dy3nFYLv4w=<6J_QZT+EQ#_>DV{uNMli1c5q1sMJmY8CgpT%_0TMzv#u&AMKm>INe)UF^>>(;vz+j`Yt zIVe`Hjg1_>&-Y`j(ZKG?1hh&xex?8sC)wU?3rc_Xy0PIR#YJVypPwd@;^!wkIGYt8 z*r?d;Hqoz9-NX#H)(R%*yc+JG?0erDZluY{d=PE z6J76V^AZb&q9&eO1}zFT87Ri14jHXe#gBB?;Cv{XljmNA4NQO1I2M~@qL2OCLHZ{w?jAWUt(-xI&BfX-)5Dj|Hk!%yX!vp2vCz&JX_skek&m5k zO_8Ro6mmW6(c}v8E30OXF#ou$-NMkRj%KV>V3h`+bmD=;j;SSVk=xqJKfLN@8->w8 z(1+86tGINMEQ!KIrNXQ*Cm#7C z=`z;3i3OQKI#7$F)b>7T`MZmnZLIaf62si(HAM}b-}1QM z32f$>UYa6P+)}l(y^P}&LvY5OUVFJn^g{awvSpq{%Yeuu_ zzeTogVABs_Yd@yl^jkd({72V@&aWC9^M$4=X|fR)yFm29rJt2+YyUPv;WGD>o8=8B z>Pg^a<`3`PE6&^F$)_g{m zEj(;?wRe^p=5Vd(o^~N;m@3w?b=VWuOw^NVCah*1KW>v)yVM&8dW@;Y>)J#?X1`&P zR>{0Kq4{F+M2t64p_ouqmL3K#S90h_&-=`0e-fr3btd%F#=N+OH}7;Z9{*vNu{=(Wcx_b zV;&Pvkx&BZ_I*KIU{)kpub*LoGggrkZ zSo-xC;>~1n(orUx;X1A4+121ZQ#7RZMEonIv-~*evazWj6?#7z@A1KJ$%}*EzWiC% zcA4*%tJLv|UYd1ZnqgD1#*4qeQO#VYCFUfCG`M*(U_9baW(v*mtEmmH8nrCvI#qu; zi3%V6bxA6MXtfRUpoc$u-y1fwrgh{5v~`lrE=-ZQet<1ZO_}_cIGRfn=PcWM+ZNss z3eC6W@^8zfOBF?Lhq>2x6{gFW`?b$FXs-;c@nRPu?rrul-BtU_rZz^1+SB>AG{{gl zr=-OAi}LCpTLIc?6C{6oms%fEC$7hdx->;fu+;t9CRAQNfx-52ieH7s8Bq18TP z;D_!$N_NXd$M9X%8Z-2;c1(x6pD+%tC2DWPxj(*C%r<~?vk3c~UySnanX=3>~)Jl|T? zP#tSuJ4Ik;W0L=TS6eNrjA(}SXSElm60xp(8f-6YC_m6H)w|bhvaILCdKoU~c-=iN z)-_?$*dy(aswM_>@MfdC8K?JevL8ysHGXwe;+VTG9YkPP%8=hD2E-4 zalD{Dc9$$T&`hDwNCPvb%HKDuz3?ho+S#&6lOnCiQpYv?kh6LQtmAnFb-MXG2Wvwh zC+&}?9uJakjZW?JKlw}Fh@Hstm?`?#_bVO{b&F6a=3E|6yKFLSIIDHA*+Wonu>+eV zoVa={_LCIH1%?7)#Oe00qj%-nuCNB7(xiA2X2#T&3v43HN(7@c0yBSeV4Xsszze1i zsb?o~V(#%RBKFhi|I#g&3>twNJn%v~r=So`{V>b4)OPrcgILpr_NsG}ECU_jME_^) zFe?y<(MiYhWSH}BjM%7|#Zx148(jb|rXslaGs;}yvY`0mdUx|IBmLPFY+!R z(;85xu`yiYU@0lES(*8C@qUAwmo9UBSY&~@=9*=qVV-cT=wU5kpV-PdDKICG(l<3m z#eA~eFBJMguZ*Gc_seQm5VsOozuC&>B=EBjCC(L7i1%zZ$3Ly5z32+_E%u8+BA&69 zp(s(TI9VDeQHm!nrcAkVWy+LVqDZk4h31;(M`5aqm(~}ziU*E&Z3=Qn_O-c5w>qoQ z9ldMwGOsvTTdP?o)!W7lnh(`xlnTi6U;8%eXl{0XPP}1(-Zi0*DOt8N*oAs4GhfFF zi{o&IIn4Ubmt!9b%(cK`B}$Z5a;%CA#gmMQiA7>d7tQG|I#()}ZeFs1NTUkzCGfl> zEvc<~Z(XpO@$I}|2caum^O3F7Dy0k>ifUI7J7Vw+CgAFc{>*ur&~}NGz``4J;uSRZf=(1ZV8U4?8ldSu8^Ogqy6>G5*5+j z=5no@_8nh+`2=iZx&nW(o)a5YMki*9xJOb|M+;|&3H_{R#tQL!Wwk4a)da$c<~7KS z-7pL{^ROoDzVbxcStOY61ufzXqT$%htM>fKAv!Aey%Dx>OoKZMJ*=aAJ;O==4O8+Y z68X?O>udVbKlLz6q}i&VXV6&GV1)chZs=CmS<);ciTPOhlg%{kMV9`i{l3xB9?bQz zmx9;E5c7`G26q;i=zO!BCEC#1B+FrzGIX>$BftnVg{@#G95)Yya~%%^W10VMAGm zTPDFEpEcW4gW(J&e>{>{a+ z&=jS@4bm;H4C;hB24gKI^jZU6yt<*#`@##-EsNhhCM6c}o7uG9P1lzA#s;=pAzH4t zOFU@pd7f_2sLGdhi(1t>zUG5;3oC;>6>&5VkN@r4G4&BQ;{!Y zNEK;kB6f3~wuh!>bQ3*C+q8-(gSw*53gTmyxHeI2E9H34+@`Lz`$xfEyy^s>H^3jF z)I#M-JmKY~X=5s3dxz6F6;S~FM4QPsH-i+Q&I+OvOg70PsrFAUHC*^Xx+Sra;D0Re zoJC$Xzs`-u`m49i@S!4eJmDVy^vQA?%C`2E-LOr@Qfvp^#2e`EnL!#*kAyG}P~>0! zYGI1UP-r$Ardtv#2_ld!Uza+EewTX8jV=?hr?#fs*`s!Mhht1w=DtC8mK!u8htM}f z^fbE}0{}Bl_0-YSCySKy?c-43Ib*ZR4FFDEEUUR%_h3Mc$|8t4W^(k%GN+M5J)7d=TLdu|y zsOMAe#vEU!bOfPij5#XZa#)FQhHZJ<>A&S*r~z?5D8L$en}tsdQ*MqN{qz%h!vPNR zq@OLpY;%3+Q15sxJUWa%Qvbnqly4sIrdvoE)DiVm5T8)&9y3!of>J+thu%|{!j+EJM&75v@$jC8$m>uV)g92DUfA1T&JYqOOqwvOuzJ-Yrw>mk<+ z^{PRTL0VB?-)!XiUkaVQ7uqrtg^^l5LtslI>UeuxC{$*Vv5Bd(xt@4K_N(TS>M8U8+))c~DR;w$^4Ohb)Lq`%A{Rrtlhtm``2%IZ`v zFhJ;2J$-@qcx|&0UmGgUHYun26mH)G=3wpse4T?Z8V#9tlhA?KS|^zYZr6}D6QdU4{(Ttx>b z8SG(aYJ$M{Hm^=iB1&xNbtANOqBZvrk2>F0dnYe{!ZgP?)YHa-z!46&xywCiM_psV___|R zmr08Ir&~lB)EN!)dYO|lXW1Xj(`lFov$kEY-`pa>z9S5mB%jA0m@=X(dnr;zgP-iquLCmTY65Ke< z7w?^J8LVV@n;A~9pLb=~BSt&RDoz$L+&+$$r6XDthpAe#kt@|ddGt=YnQljy`NWIDLzj!#Dx!_E9V^Rl#qvaK<0M_2uG_>~ zx?Yvgb0)u+Zt-ML4>UkQtVf|SDfsMSUkZ0kw**#7EM|LKD6Y3Lxwk$_{oqJfyWRnh zE$0+{Ei*iW;`I85FeOo zQ3HGqHq_bQ?B}k;Msl1$pmp-%C4!j$xWxP3^PV!L7VGRpKbq0L)~=6MmNMg22F-&8 zD2Vp(T@@)s>WlYH9hC0*ucR2nH}2G}itJFeBkE5!G|Y2`I?t*$w#ky<+T_KUU~$$z z?QfQ|1X}BgC!Jw_?U{138swLkK{^pMB>PK1e{X4A^^>^{@X_oBy}=pOhB>;@*K5{p zUBRb%U~ zzHj)d8THUa=mOJx+u#l&+KMPL*JL;Pr`SI9)-^Bz0ikK$NhTl+#pxn189iP#CfJRw z9TE>R$pwE;Xpn-~hEgBa&k27ylz2u_#$l%Ea5v?R%>6aWDNgr{x#r&QNe*>}tX*Ua zDR7nNBwQjRS`#PLk;D|I6vqN~2imu4L|8g70v4m9+U-E_334;;Yh)s3dJFNMZBDpAxgH|-M2 zunuog!CQSfSs9)TmZGuw#}m(YTN`^v z)TTDIrM6lxlS8!Bcx!2IOOJUiaBlUzbx$0CX>EUd8|~KkeZtcC+y>R`%Ak4Bz_0ir z1UfgOLi{Rn2pe5uK7$&OssaW1_7MskQN^`3j=(&RcxH$nYU-s(sXU7O{}EC;TaJms3i@Tb=19v%TWElJVK~t{Ip?6Qbd|1>0NPhz?3Urauw; zq+L(0eB2D~61vSX27067LcE?GU1}Tu(GUIn%^CJHe7Qc#++_{Hgqq)#Rg4fi4E>$y zQzgbaNh^sud=VS@x1W7&Uy*;MU3wW-Jh?_RWi1mM`S~B(DzQ^uHSMBUxrl6!35_z% zb}sO=4}_+fRj1~0g-JDVp7q`6KoMJb+gRWG(6klqenP9>HIHUJb1b$r15H;)`M_K^ zXnU$y;uVNk!zs?!YV)*9FT;u_*NCR{@I#|VFvV^5(DAo5%@JuA%E~~r_pVTAk)5@7 zh+EAv&yqSdU*L6RLUH3vvA_>{3asHtbNs`1mF|oyQ0!*|67Nz3K~KMk}pylQ9aTwy9_J6M~!GozV}l+o+aM0v+SC`?7`CCns&Nc zML+%Y)m;bCz}&Qpv?XvZY;C@I=9_CB+ZyFlv(2ct4PuO=ZQ?Nx8kzh{Okt(##lEz& zL5VtE`K<0;|ChJ?o6^l!LQ4R2K#RZZ!GRTj&x75~@~Yk$zuK0`#s%n?r`#K|m7T5c zWiN(r2Bkz2Cah%;5oTMQw5CHUmEb9Hv-TG0YZFDj_o7cNL3{C{0yErc+(nf-_z5;LNa%k)S=+M} zSBhNa%D0^6I%m1`lJe`)Ew&6+M8kCpB5rRY#WmkQZK#`QyJh|yK%T2jsq&X_v1eWF zcx(Q#w;PLKT_cnzQ07bBz)(;5NSX3_ceq4MC{$vRY3|WQ1bJ4~b*bX$$Vu*5T8yi5 zOpUW(9S7gl3 z{!jKFS49k=lh=h}#v1Ku*=zV3qSiH4sJIphRxQ!$06FB zzf7ZK?uWs~i}?#*SJ82libY_CEsc$73YRzW_@0uN7~>M?ULR(O3#ci+fQw z8^}NHw2ie0O{^H{rDpI*#_9m;d<3A!^`EclcTl9r`}TiylkxYS`L5o6-3gQ`IzE$Iq4OrKI3@ubF z%nn&NMqae7d$ z!1u;3_tynNabs<(m4({d+Y_c(l}euLfld|gMXo{CH{2E4T4anJF|IC^S+6F``St~$ zc-ut=c*@Hq)0ZBPW+ii5Uky7uz+34SSq4?0CJW|&i8#g_FIY`GA6Q(;J?TcrRpFVR zdX~9e>t)klX032j_34hHO*E|E3~qtF(r#;Bo`|~FqjD|#*Y(U&=5uArl4rn+EU2NQ zxT(rKt2H9dG0$rb66{%*5ezX|C{*NRJ#6D0rM`BPL+xZ8ZI&L2BI;4EC6W+k*s@s5 zK0SuXD4Yr~sqj7uC-_e?`u$dM&S_a+_EjYJG~yps&9Epj9sJP*!N;2hE4 za^Iu7uZ3bl>YjX0>OD{ms^I*v)0mk5n+yVT;XFqwM~{vftaAlHyBItt;39N(}D`W zW-HJ4S6f@xWZ!zl^GXO(P|-M52w2P0#`?dk!lkB}R*Iwk<7DuGIrgt6AJ}XkIIz;w zUEnS28fPy8traMiFRDCJ6pzbCjxrqUf!{to$73od9UbFgQKzT33dX%=O(JR6r%U-UfwsDPPAIg=P!=y2>+*$xKJkOCWCvccrme_# zrfs%zXyVf%{?DOH-=@iAS>5-`3~6|k2JLLexx^d3(Y5ls*e6plqlK^zw@ie-hMDDZ zyZR>dL>nT%^FG|4^owzkfRgsf?OtaSFOU5RSD?B5gdGoxMO zCNZJm?ozDSd>>b9Q(EF8d%Dj=XIHE_wlLfp{F3N3&;Q)D^lj?PUcN{woHE~e!fWO` zaq0Do_0(2-7bO-c-F>OhsUk~d7C?^3XK8=R8P@5h*I;*Z#QoCfBy$btWM^wj%gHx% z7PNJ^_bLWeWV$arYCpN$oBVNZejZ7-W38R=e3~hg2#S)YwHt({yWgdXg?@IA5#AE> zSq;y2fq&@YEwc;_*v7hUGRw(&MUpwB>~7uOLh}*_nXCCR+45n%WohFPr>*$5Jqkk{ zW0X0L5JZNdZ4S+NWJUCf<^i`BYwTjCN!M6`9258NQ8)E5?eP;Xm!-w(D=Zavm> zuUeYVV(?MJ%{woKEg;)!)cfVI4mJl2f6#KC?M`p$LYUT}jY zW>-0s8yYK9;ju zhC)vW5F~2mtma;S5+qz+vQj9A3>(f`EUW8vsi#Y30P_Y#57@o10CIbg(Kk(8jcLpKC=o6eiX> zcNk@T{+afdEW-rraLY6S?d+lh{@fydx=WJIK1u88(mzKNYtwEz%Bt@{V}Ldd98R>7 zM@cIp?pNY^=OnW>O*A-NPQ*CDWOrM`2^CN71)aR;XD?RKU|uZ>A~fD!9;^7*665^Y zKsma&e>oix_nh`}J?C8=R6V*uCi%1APN92XD|0;jM@{t85?ROFf~AJI&(l8Q1iyEz zL+onv#Q{5srT30BhAwr$?Bx+N=@A@qw zFS8bmn^DCEa!Q5eqB6%@lw2#6``&9_ z^*`O*u3TuzGOLIp$J@w6$8k~>qdSS#cF`&4w|{55(gf>d6hup5eQu?fpVB_!r7Tyf z$P6PqX#b>@a4qkdlDz(gF25PN%93i}x8_SD2?E;KM4q)gnXtqMNdsBccJ$8)Y~t+1 ziYiE$0JB}=cyw~Gwd5xKD?_2DJ!-KX)8*imMV8xz9<_y!jZc2vXC;q;V#(8nn7GAN z3~{Qrss6UyI$4if zyU?~$5!jZ*h3>GKj*hAHI{(k6zrB3B(!*|YA5H!{n*6nYj2yce?@50($rNYno-ib2 z(Ms0xDk8FUryN({4SUPAwSBacD^H?U>1&QRCwcoATkGv5|7g0X(wg}?3^mCZ8|Y|F zH!2gF=K)K^JZ7TMw2G2Ap-^Ehx@?kZRUC^JD;J8pyHZ)cX}%Q`dQ{(~i>untCP053 zR5F@mm_F9y)?Wx5++v^GEMG0>3HXsAaubJZ=;swXCgz((V1K9Tg2R)o632EWzVf(B ztsQW>bL5jHBG6l0K-4y_@^&&#ae;^Y$*W#-p0%uNpz}<(P-vb)p+~htUq=`$_^uw4 zNu3u!G~tC%=zIw&{30~T-liz=q&Z^lTc&{G$G)hs!^!5GSB(-W^IRntm9hSAv{0dM z{oAoN(@U_tl87gD$5O|MbqHMGY5k?$FE7J-X0;B;c3;}ZTvx_ScDL^2dPz3x8C(&( zxV2xEdC&eXT&7K#kA11kSm)c%$DXk zJ!l~Iapbx1$&=Hw`lnE*AiGd#e*(MP+acDK$RK#H&@8+7La0or%tsa0iBPCu zg&D5M#nmW?xVe?S)iH|{SNyxo0wdjOJ)U27gsttayX5)k#Kczd7q^IJT&>g3dfb|H zqur}ToMY6LagWfpZ+F(u?iC?t3yoOjWiR!pn=KG3^S=AcGuqy^^?)5jol;?f zEB0lDwIft!x<{PlId{6sFG8jM>sfK3kE||FPm#K>AOiMw0M}M=?Qi7T!+=DXRIQJf zem-+xa(#c6L+x#W5|?;2dCQC@4j3u+LvmFy!p%PNqwOot3_X17Uahi)iL{i19O^{B z*oD8P{RR4?v(7j65zx~nHmlQ{*^>B#EOHXRyuG|)T%A3&OOyyrcC$HVxY|B`NM0%T zN+o+t+$8V&!lX(StK!L|E5(Td_x14%#POb&U)9sep^KMYA=0l7J?%noM{2vXTq6Eu zk;}X)G$pCtV$OGOldk3Crkf}x^sD2n?=mN-O z-K_S)rgG(0*^pdbToM4X{6RcIo`Q{46yzkZu17w)AL)6AM z^;gg2TR7NMTU7OQJ}1yicj^)hz4Y{^%;#{7xbgm>Kw^b7M%-oA^z(AfN*hp`uVxln zC{*SrFFH_mWuFtY^_Y+K;tQfW3y^DLZKCqi{`&l}SE_}9x0@hrK=Ie~ za-py6sF&|7@l`dY=t0V&| zu(u`R-Y`aJhATX*%rsYfcZJ9QMLktStdg~1S(duThd#HjOOwGEb6uVYzNm!3#<*3h zgs~^8!aF5Mn10gz3jJ|eWy-lJ4);laM~j>3QzHbr+uW|!v5xjA|J_wVddIyUsxIex z6XR^R<|?j7gAZ)aD$4hn@xK%fBVc{6=&e*tEAzc$S8YUuVk=J4!pJdgNXwBpbf!dY|lUpy$j8ELd7NJcH&% zRa)Z(>odSpMw;wGbaR)VOfl6sKYFcBtJ{{vvHsq`wL|0inC$xQrSr(wK}r{E|02gl ziiOH7ROY^A{2!KOVI9sgmSs$t&rGZ0O1Z^C#fE#;1oPeDJE53T#flUwG{G0XROAai zev{N#>(k%k-nFl6wom&@^habhe_jkZdRt3}o@D7`kiiBUptsg_Uf;GH78zYfn?dS1 z&88}uF6zS8tnD6scTd?M<|GygZM`D2#2c3Q!0lo}3q4bXWhQ1?omFaFvA81tN_tep zEjB*sx?PssdMxk{dw9$DHg~-e7u(0tj&YD34bo0Wf3wK`mEXw4(8(1>x=Hu?$}q!J zu-XfqEG=*nu9*6GpJYvi4C}_nw658cGHPjJnWd2)T6xMDT%MvKM2I@pp7ydpXtDwe zU1N$+ku$1@N00l`j5>B+?iU4qbKMS=nVnQGpBN=>zEb1;s8q~Mis!lVOnEhix&nu*GI%n<7m4aAn&kxo+u2J5 z8`)%EPo`vO3nAiZvz?Lj0Vz}NYvUx2I&Z6@QF%RfIEgzKd&Dox1%1!ANT{$P6l|22 z3|C^Fe_H!D&&v7G)zLayE}%4k&Q3_wc5i6JZH5hF1Dae&#Pu0J*b2rfHZM!et!5+h zp7zzHp4$di@w&r_5OJ;hmYVxgwJX9PyEsK@ML_p_W0Db_<<4~3at+Ft@rbPb1E%=a zJY($Z>57a}%Q9}31wy0U;4C+rD>TmEtyyUyk>e59%UxblU6w90I_oRgIqeVpkHm&G zV%rA!6ReypSC;$|#mzFM$}iM>+o^J2wj}Wj+1}&6vj%y|g2fMeJ7syOj$$1znBnK- zFMX*JaYf2~r9kL&2fN986-r^cQI%#f)~s4SV4(x7;WLYT>#HhE1xrj6y4%6YD9|O& zbf_^xp`RSAyB@k|g@ep+2uH2Z#ci;+JLIOjq`)7G4QoWVW-GkcQW&pc&Gg%~xLMVB zN<1j9vyUtG+=)N#mQW7oS<9-%xK<>QRia1ZA1v1T?fc`q;I^vy=8`7U67Q`mo_%kgXRj& z^^I?Rghz4BA-J+V<4y*0jG4e-t+K_ay={}pw_rB5kOGb?}E@|tjtY_Ks% zn32gZ{aB~?MY-uNaHjuDezBL%GiE^@cR6D{=?hP3XD#2Evs_&5VuxAF_uh4g#U>an zG}=)*+0H%562GBPxmkWR&k0q(mqB8y^s2owF4)b*dN;V=1N66jGM(D*o6puGKWeEBh%__TPjcX_>(<#wwB=)rp;Kzp+np|+S$)^M|spFN4Uf&i#=`w zIo5Ki@5O}Pbh}TSX7xd~tCSb_Hx|L_dLNtiSLctydN&9J9Os#od+VozOPc7ow#>XL zetGBG$}(Gw4Oq=pIuo#(2i$6Z_gdd}UedWSMRyKkbqCwgYUe8!!v03vL0?Ntb(SZ$ z8noHnd$|dtZiT0{dQ-4*^v(ZXR)hzLVYH>LZga@+W7Sl5lXa zhD(hw)*W`&$L3yC;6{%+-$1A8qf%LpC|L8Ud)k z^L=KfQQr2NMaoP!*4d_c-Kxu)bi;}Pk04KH!HBfKOe;Gh4T;~_m)AX_v>|O<03yj* z2l`bJz7;oLOnzlQzgiIYz1O|!Bc+CV!`sL=J>e-_fjl?(hpSv~@m|S49U^RP=dksm zcow#|vzO&tUtEDfwi79+=0m&7vRzH1DzezyekL1NipG6x6sA?&5j9ge0(oB0)`sp& zZ1O=by(<2{e7U|uF|&l?%FH*!R4*j2?Cltw2>cb)?Q(%QN0h z_I9)EI5bh@xB_kc%@RNAZ-{^T&OBdQ zby+EV?mPxMK<@cze_d8~F89xO$k96RP7O_tCE`zh`Wr=1V)Y7F` zH%EEd%w=R#A~er-Jme#15Xj9+B*0~mOA@i3;5k#R?NlFHTQB$en{{=m>REK9t)sQ= zTHRx%m0@07K8_SSRPtp0#@)%e&i13wt=6kD!gGeJmMPpk-@*F&S=?iu^OiivB(F@e zyDePiwxk4pO6JvCR&I;Ml{(IPZuY!=vR!0jtJ&HYiIHEW$Stx&^tPjQ1rJm;LlHaJ zDD5xH%FX5e8DWU~tXF+S>Pd;;y$NX_dAeEX@7B{xCwY7#RFSo_l}%mfX1BT9U9R(g z?(?dD+kA7kim;}qZEj6>+e$=xJL(vvo9#U-beFFF>1ThIBimz+t7;9=n|99Esdsgc zl{_DKC7~cXYbUg3BIvGnrP?M7{WEEWnP;ldG#fdo${dv+_-8W4;#YHpp4ZJg=G)nm zzPDyYS)ThG;$bCbD^nP7bvRfoEC)e# z<<^n!QxAwxDp9Re!W@z9p^DpL{51rn~_p>J)FkYHu`ok3t@n|r|sYpOARvkya@t(#1g zXOnS-KO}T=_3i#`-ckDpX&)%+fhzXg_Is7%Mr;Cs0HrvrjhoswVkv< z4_SALkX2DW;3ijl)gB&nn16{`V6hpN_)u5S&*QdlWxEwVDNi7`rl&N}ug*>EDQxHv z5fP_3N|v)LsrHB5vrNOqeyt_v=rng(AoQNW&T?t8BIihNC=ohFTd#Z3-gdLO%gndz zhOH#2G7|n2-#J_ld61JlIY+*CoNQea+$CqHnqFSkF~*}hM5~Dq%doMm;!pe3kh>>0 z@lbv{0DIrY@;sgPc{C5>COIczpRYP#2%8yej4v$~`qg5gu_jpT9^L%SD#_dj(d6&= zkA6~MuFy1p^QZ+14HvqdLt$6*?M+ZGr>Sq?EQS8#0Iji?ZwXl(^IoG%nUnvy#Q$aD>u=Kr;$Z|FkWb}5uR~;B58UOd9E`6 zSDRS#LGSuRoM?fw1Z$|9Y%;7L>veMggS{;jTHt$kSqWE7e1Z9Q$Lr}jE%FW)hSS+LBPaj|>+-8df!J*#ymhttz>+9Nwy zW+$F7iB_jH+S1lrVu}>GLtE>b?K~W$FnMC}+nlOiosU`}d0gB#zD-7Q{FcHuwoKND z3Dy*Gm(Vl5GQxb5Jfpx2apRZsIho@npH!?Tesrf3>}v;G*wBUs=xv}gbUCPo2eL>& zo@=~Q*|#LaRI)y|l55vw6z6FB>nR(7bJ9MG=HLj&*A{Aw)&1l)7n$OFFM1$p%ze@! zuJ#X)d*5*18tx6Z*xS;e#NYBTU8TR{lqqmT;7Sh#O}O4E3Qh zf3u}gCOae+GaH^tMIm}y73=v_+4*d?}*^++9t8YJu%op~kgugc2DI^TFEQ3v@y zcZ$14G$MqKKKIRX*6NneSRGGb#{0o5&a`?$7uI%rc_NgJ{z)rM+|=a~uvN{G&P%#E zFYtwreW=Xo5;n#@Mw@Cs_u6jh(;8015em$5YE>DthZES;OfSjB`gZWT&_c6aZ>!}3 z9LCierTVrXtNeSsVtX>pKOFB1apS%0OzUW?ucuw&bGJF7iXV`e#R|oR;wJdohpu&k z4qEw>jYO6jYU=hlBW&$e8>%t_G{eTQ9=Apl2Bf$BsGp@yfm@j5?PPAC-w!9c)BA?| z#RN0Vw`7GcNrB<6vX-uiEV9{k)F@|YO}4++TVYN&(I~Uc_lh#1k=CTlc4T|RC_QcF z2-(LAeWDE3FkWbpD|A}XPXMj`+Zb2t=1h0^U-H81dU(Imjd2gua%xfH*IG{zi`=Ha z6UCGmrN~6@I#mZ;ZoIvhakBc2WyyXQ8Rl1$6}i!EzO@ngR`Xt+g_lb&!@aD1;}h*< zxZImm_gkmIj;1*oQG@hwt}#k}Cx_6JJ?(z?xW`>i*IK@A`Wa}5jcnsEH~P*ZvyJhh zE9|J-(yZQfFaDPFrtIzG1_i^vXS_rT`5#>30-bmRwlm&I4)lSZoSOJ??dc9>O1)!_ zD+ISM(@~T_Pmj35RA)QITNSJC?{sm@GQa2_*PRyZyRP_l__{05UK0N zqB3*Hb)~bH77xfURjkLY|3^E2HV6?}hUg~8P_MUWkIG?=u#+_s=MNE4S=v^4<8QS; zmi6qbJM&rJIB)u!Z|V`JGJYAG!25dY>jj~>LbvK7l3bVMi@L}QvgNtaM5F9xYsb6H zDYjNAItpv}$#w4YiGC96iGvg>ah1Oq=M$Af8{!rvpI~)aH>>;m_ojMkneD?&xA@N2 zPI0)0y<>CqaqV(N63&sQojrYGvY$;%mJ*&~kOSFy49V8c7E@`nAh#BrSWa*c_>643K;|8pz$|{|2lsnrohKmb*;Ax9}pno8s ztp{9a58v8Uwmcgeq_fxEZ-m(%lBM!E&J>zsgfh1pnhYZQLFi-Kn`WX{#Vc|{6?rMS zLMS$_Ubd4-CKy-YsvQ&hK@V&Bt6v=`S4RxQQ(k}5*(k4;p&U%l(q@wy(p#pQNtIyw|)ZF_EQSCTjd^bw!3ZS3}@QAM}g3bqUe+iA`O-J(uMMe z_=UiFuJpaQ=?aCGxLCHlr2p$XzE8IKEh|K!A|sTVm3aO?ph+?LNb8 zwPGa=3ii_exmB&qdaBncMy6*CK9o zg*LQvnN5@%hc0$;kv>`q%DnGhADSbiuZhj}!G#bJtw$cJ+7R(4$C&6V=ZYJkpDgRU z#lKuAlxvBSL`6O1*w`9|{rK@#bo6iAf{wDq{cN64*JOFB9WC*=p0=+TX&|alUs;Cx zdWGCkb(4BACV0|R`EC#~+JBvI1NnOUt4}>+fX)^72UfL}PR`QWYy*ULt5{Lc+hF6G z?ZIVG8*2IqLkG86=s4RsSI-D-{Y#lpiQVk!lNMFPcczOHuVM3BvNxfPr&FFnXO3g7 z?IEL-TPWs!wD-CK_gO`jJCm^ypPDN4cL6$jH0cBRx#yG_?FGAfK#9;oCBD+dY033N ziG@O6x?Y)>lWlLVh4rWvvg}y5#mUOex3RN*;&`X{OsUWpD;%YkC{}K~sp3MVLQ|4q zV{wONRuCPh7bRe zxZD-Xpf?aP3Gu(>T~|3mw$LO4bdztP_ig3~ot)%Fhik9US60UkI-6sFXT0ScL&dyc zHvh9w(*eDQ2)dYF}go zw6U|bE0oFJ7J6lcwC>H#GULsuI6k|f?wL+{IT6Z5CZIU^LRpep_h2pLhct$9+P??xgaiO1$u#QeiZ_2wxylkZX{orS%%KhCn z<~XOKq)ye0*VzC&+fZ!;x_Q}2&Q#(~S63;SB6BVBfyH)2XRiyze5_k$lhIOGhqU)0 zo!sC}x7){HgKe*soo!z6dlEOy^r4%C_WDnOW0drJX?3y2Y!A{mT)0{?jHO?d# zIKwIxf64QxxC6cKVx8RX0$Uqu4LxpQg4 zm#dAo;1}15%JsQl#LaiSHGSqvXL-e|;$q(ON+S7g0}*<{<$hA&X2azf-Y>VwV9 zHOfJ9wr}=9{6f>Q0 z?o*)9?shj{feFgZaJeqtXw-9j%uyEk)v1p3v{~Lr9;9w5K+<78O~p3{(TqZfRMZ zCcprD3#?|8>)fopeMONa-z&>m`~yX%nc-V7!_Q!({haErt~XcIZrUid$X6z7t-E(! z;wxPY6bKt^<=sv<<@&qb)uy}NXU@?UAG=JBQ+3rsN_a%xJv;f4Eu^tpDlBHZVruW+MmUvd!CMK}N=Gr7`R@Dog6C-Mfi&0&X zi(Tz&eLHJoD_NEZL{0Y7a(5Of(AIR5(8D^IX}%k^HNjps6zGjWmNxR0d)Zur#Prn( zOB#H{*vsYGBVtu&IoL2Gv?kz1=lID#+~Wx&s%%@FG#}-dl<+u{!;&TxX9jgg9cyzQ zN$7uxsyUk59JwMo8$`C%$u-frUO3a6)!zKGj`HNlmXl<*$kIv?_GGB%!}D}(?Q=^E z(BGlSltyn_GsnXF5nYLu9n{J$Qqa-IzYm}xYo%hJ<4uUm-eeihT%YTD}L z2}_ceqOWYMy9FK)+9LVv^7YYQ57{Cf*Vq02sU7mG^nj=f0_{YU8)vj~eHB|P5q726 z^EPyp?c{pBnzjiMZ|}h58Y9XMO(M<=>W#YYMX;$^LJO05z2fF96N1yceB1hhAQ7fn zZOp|oU+v0P_=vnpg?sxMsmvpKVPkzk`=o1d8%Nma` zo=nyj3N7)YLZNv^Smd9sQl!|6$*77_ub3lL>M=9T_h`~C@s=0Fg=X5&RgE5HsafJe zGaO)m>-}VV`&Xp+U(>IO&2_3>jjqDdQC^W3;=5$Ft6S>xW@gxw4C=ZZ=xN5*j?>v@ zLfy=x7(4>fc8Bub2yL;7B8@m(p<_%&`Y1I@DkrH+Zj8JIcfpg-L3_NLSg% zAr(fInBt^4w^Y=p&iAC%QD%;=vb^C8``OnPChAcsBBFj+;yas)TcE&ap0TN}4)&v4 z{ZFY*_I0AoE%t%2I@xTw1J&6+u}<>zrA#(%b5=`OsAizwd2C8W=8bq2IkJCyP-nZNn(P14+J{1+Up=MBqc-(dTUp<9 z(;AhVJTA1zl|B`kZM0*3qQrbx7~(;rD*7(+tC>oSsg$TNZk|`o758&;ee<7XtCDA! zK4#Tbk*p?8T$Vh9UNJ=Xv}v_Kf1B7{N6-07__|kvcp%J?YjtPZOgFhA@@qL?X=^jg zHBYvLRqQaEYi&JzVI%XjceN*j@VpwkiP_a#Z11QhKF{f4>5poeS$bFVX{)))cx8&T zS?-Q*sE9~N8^9`={bIZk-@q4KX)5NV}6Za~yogC}nYWYsErC$2V zMY*h`k3&%+1yse;jF_cVnP(lPFR}zO3y2nhIx7eY1gvi_)3tKDcK&HVrKN1V@n?ng zKu0IzSsm?Uf6tp0w$Vc${gXC?x?_#xS7yGcHnA!g=xe3=ndVI;wVnK(;$0|I(g;_h zx*#g9To!Wls`!G1mOp52Z+&qSZ zvBW}s>~4LF#k6y-(3@_zP_D16E7tvD>}5Ci=!z|kF~uyQnEx7!isE(+=hBpKWy@65D>Pqdkqc~? zU2UnoP_q0RboP!=sJMpZe`7h#FUpoPgwD30%6m(USwS|X3WW;1bvpbk^?}_jv7}-((%k`AO+;gtcTVeia2XU?2CbLKgZrd%Q{@(b&vSDDeqSdzp_ebZJB&Cx(V2o?Ay!^SUZ zK>SUf;7)V&Xj(uwSSkISrn6tUFy22G=)D+)m0>;3Xr9;1$-3@LXM4bUdSkNdl>56K zjPj!Safwx|yg;o)i>lRHT0u8G?AoAwphRyccvXo5ec^InHQ7SSgL>(xSb@cAnwqDq zsdei~ZD{cX{XCTZN`GN(o5h)|+Y`n*&JQ9UV!^ZXjZXNJZMGGhw**DE z4zuJ>lTL{f%hXYYsp-FG`ySibruM)`)>2bon62&U8u#1oXZB^SFM18V*<|SM9t%8= zfsV6|q?8*>b6A6CUty*KNujUfz%L6=^W5Q+xQCPCxD}%WhFimpdU@D_+tJV@bIq1i z?N#&ID!gZ&7LBr6Aoe40l8YqF*HeL$U0PLORVT*vck!SDa^Uve6s6KpmRh2Lx->Y_ z$tvkP>E#t)C^w&JU>kD_o$nb>`mY0h=ewNVXQgi!=zlF0HxfZ78k14Ry41iZNqCw% zD)5EKXJt{h{{vi;mQPKOud|9vT_R;IC-~T0l?|RywL3hoyTB+<>s}MwpVOhuQ$$%U z5Kj~Oz~&BipFip0IIAi!FD=|!!MaP(@<5=XP2$(~RNx_JT0z%M!E6d`YXu#>WjDJz z*o7G!$InektG6PMRw%?|Pus>;Ql2+FeJ+KLmNQSvFx?lrM>Q%$zMYYfIIyx#YE)ZJ z7u8-h!j{%n>AX1hLoF3L+9nE7U{#kIa8T>7o~JgatQLsX-OEd^aK3*SY=GsBRAH1y za^3wV@2YQ`grM)^412rRm1@!1{`q9{1k{oJx<_(QSw|{l~1` zb2hAb%Ajn86#+>{o8k)>c;8{Rx3|p5Z1Dy57zQ?o-$*W0_uMP%#6O%)3WAA1{Ww7bo1gf(8$sW|2a{AXC!=>&~^3k~*c6>lFN~i+KmD#`>gC1-g6Qk2<>1 zOP05416vFV?4z4%FWb@1F1Nx_xgNV^oLaF!e9I80`={?cWxR9k;dMJXv=#0`?TI=X z>{_GDQh_mk68Ok9=IPR6_>?7&s!SK6%2YqEQ(aNKAf-%3UrA%oL1&)RrH zsJFAcyrgQv478hzEw2av z)P13YyXKCHVjt5QpDeN=b!#Y)iWj7$0V;L0oH@SpHtu)5sS6mibv6i-P4t5|6IFZX zdgPXIYQ+Lk#yBr{$xA*JI>rNjrPxnqO^|z8sjCPw{UAb5zS1&$PnlELd z>c!-LIwm%bYWn&!&2_QW{870{UeimlJ3QcwbcmT*s)cThB5(xlbfA|mw1R`!KuH+P z3+5&&yM$ZwlYh8EsMHG?Olx&JH<+5|bMt*@itF|EpuJsUqI0ckj^8*%KLzcSW13*N zz$Dd+K}Z>@)LWSvKQ#IL3l(|KAzrq(S5+EquFw>l*vphy(EYwy_(kMtTF@re@_AZB zTKKgE{k?3itsR?=1@V153>#C68D22ljUKg~?_BH^)BVThzA($a;BfodYY8>2ZV4ZI zNN8G%=1(;X@!_8DBQ-+RMmJh}y6=VNc*v!mRO5NaTTekina%8LWA_V%X2!KAI!zzJ zPp$4q9&L?(IAp#h3EAhoby4; zV*S3rw-It!8DJLtnys~)icJh*24b&GMJR(%p4(~7& z`XGxC_n}Z#6Jhih4k@$KA&sj{Qt1tsc|qs{z0#SD3j89&aci9G%rV6V`KVI4$3l6; zgbru0iyWm?bzy34rWhqu9LxVhOHu&amZ+z}v9hhkZ5}qy=wNO^82T%7{noWEw<}TL zn4j6usO@Mq>t|K2pve$4jZ;P11S^z6l@X>RN~TodW)np5CX%`;w7J7v=|9Fw%@g+W zJHr&(Hsh+_xzj9(#hivHPg&7IEfD*|PF673N?lZXl`s5Ll|VEVrlcoLd!P8D#GRAIEI{4V0E67|QRk5_Wu$0Y@`Ov_?C--r|T z%{9w6R(3*q0r^AZwM9T+dpiqkV3M)1Ma|s!|J82OoYkYsHFkT zZZWnLc6Wm1w{7g?RO={Q!#_=B7h65X923lPo`JdMids$6eS#u`?dBKOb(&36L0~jG z3A;MZzigK4PUeV0bJUk8l_;%uq`DDroWNRo3Qd+U&a=k&!p-I(G?Cp@Cv*=JIyu8{ z6#LGt#>KO-R7a4sj}7jQ8yu}Bp?6p`y2TD}E9~TA2kepSky|>bxz%Gcy1Cv#$$CdC z45ZLdTPnKNW&|$vo?~1XYs1?gMtM2?_e@_1edS6k#PJArUJ8TZWRIV`-pGb=j!%q{ z5~}n+pEg!{cr$<&aGz; zk#dQkSSWN1W%knVm?paUK^)sBa3ZT1WPyxGc`OWCIK6`)y&F$gVOOu|A)WzXCnIxy zFKva1aaO2N_Hgks%{_#gv-_wt$~2)_o@*olU`;I7Io7>u)VRnso-@GfLf>0oPdE9W z?Xi)w6%UD0jC68cz2*2--NXliW;otNv^K0{f4zSLR?qpsEge{xDs1A}Xo0xh4ydvl<-M>E=ql<0=BaKz5CN?<=wI@@l`c#PVYS1|&Cgrk66O3r$OpS6>#Ti0M9A+yo`Vj<* zBt(%Q?r@!zl<4D4w<>9Qlppu(~%2#!e7k`P$p!Ob21Y8Om&!J6$XMvr)olA zCPQ54ejB*V874oF>v3DUsP${g^k@?Lc)3q*e}JCX~9LIot8kd87k!s}{G_N{*#D9-Q``Ud*=r@I_&yC|l5 zak_h=5W__m=X?;`I~K~+dcIUW)pv?O|2QE_$}E(bl55^5Pm4%}O?sWw*xV{Y8~VYU zjhqjy;6N4F!C5Xb+&_Hp_qHu#u0Q&pHT+S}hzZz{sovI6@G__pq}=YxIQh;{Z@NsC zK@M@CV8{3p8&T|Bo4LVlUJmBICrk&p+$qwBylAsO=6VdB!O47_o6?AoL z+VpyeHSJ^z19&qoa|%Vav0NSBP=~h&tnLh}otpEZYVT;1Mt;pk%rHyYwqp&GAwLzNNs(8pO;N=8!OZ9M2B=P1CAb`m5SDARw0fu0u% zRYX=d@PcrGY{iL2I@b->GVtV_4^w+bna>0@U{+e>H5TQ5~`;{u(V&f0Fb{j^by#@?B;Op+3M+Rbj4)WvJQw3XpTTM=73Ou?m%Tw*9}>{FpC z7wM%Swzu5d`{oEuvb9|tr(~T5HCLd}jlQ&eKIF`zq7C)@dkagPE2$z584Yjz+f^W`uNC!igCX8Fp5Rpy&S>QF zBbAx=uHU-JihgHDV?7++uToEQ6?)R`J~D?y_UGIm3ay^FapW1G%!P=&K zR5wSbgV^TLeo^kDdbX4^{l&!eui-xPzEwRZG|xwVTp%*#9CyU=Evx+K&%X6( zMJV*R;%KF5x(fxcXL>fxaI64>J!k_0g_3^Rpw6F3_=gV+&hrn8jy91&M6@T9yrz$h zOm|VciYb++#;7P#Ii#t8j95}D8EhrnTGL#2DpMvjSv6*uiE3j#5yy!d>sX`IxJO3^ z`ONoVur8Fx+RVnON|Go2+GxJx6+Gv4D z2t37jCz<1JTl+y|VmWbvyh(X#FBIrot33e4wFXI`M46YA>4VpNq^pFU5*Y4u-$@v1 zbFars#>c*NhFA2^TX!pCy7Fu?lvN8tk2~47V0l;BRA@#}b6gYV*S}|mQ$1AR7r7q6 zrGVOGfjCk)(5|ThjQ609y7+}+@Rhf7eT#W&BTCx1)^Y(%^f#ZHt;}9NGZBSCj5JPC zLQ*%E`xZ0I^N}Z|O!T3(bTZM2_A~OfEH0aplziI%`3$V>W(VjUnpI%0u*ZTzv`Yl# zz6`3WvS>R`EmB+TQ~J`+wFZM@RG68LQa698@$t-~7B%tHo$p3Rc}7age6yw0c*?{6 zZB$(HCd(Nmbg4uTeKFQGUTCu8qIh%JUNQ;mc|P{=ndLo4Ds-1qxF+WVvNWSj8W}^N zr(zVw0Y~##8WH97obQXYD_(gVJ0n7kOWYERAVZ&&uM1f9{nBY=xsX@y3%0)S~zITrCN-eL0K{nAHDV4;!?v@cZD^P^}vx9VIKLQh!J+d`pv zK267j_|_Rdv!_2AEi~N;wVAt1+O*4$L&BauGt--<2u-qoylYPCte>IQv$Owmks~AL z&}5tTU|B#LHnj&yf6oVdUFuQ05LA1^o5rg&&qR~bo0Mrbu$~ibXdhF2Z6q;(jZ*4BHx!b(uW8a#rT#ZnbuU%;60LLtro-D0s+lST5Q#rq*JQfEkeUn}o zzR%zjr@6u;RcXuF8WYTQpgunKgUfwlfB*5CzAT=c+nu1VOHDT2bfM2&mA2$;h%cR@ zGu?AOob3l~*3j+n>wK`er3f|VrTM`c_oZ{$edFfz@hUUx@r-kw;tlucWM`vjGNU7*v}xgFbfLv8fMe~bZ+RG>zp$!rRF zY7aD5aXc#uESEl((#cTsr0PB2a&zo&bX-1?8Sdd@|5jv(8ncz7mqFohHRk)P56<1Ka7LA4*%80!W5dO)>f z9cjoA?@?f&g7+4=QyuEFrX`D{IsL-WZ07!ZIw(+}K%q{a&H01*`LT%A(~oRlm)py8 zc`Jye0wXktk`M}^Q}I%Gfsbh*TGpnIS0b4)eLa4F^Ctcg_t0^Lmgxu4C?Os!rZPGuECeNrUf^W2bn%>P6xqzmjyKnbOkTupB!mQ(w}U-x z7`b|Zp7vkld+h8Y9X(^N0wszRs0c@GIxp<+80%U=DQ3FH#(tHqGuK1~Ci~j=J~AR4 zGi`pLYN^)kxBA|$q|C(vKk02{Wq3`LmbrW0-*zdX73*<=V?686Amv3H>tYALGTFNR zrIY;}U|mHfRUW>KlPOPyhkBBhE2hC6A_7iM`; z6uzR$45L+A)kt4B!K%u1_m;PHvx8%l8|gLo>^ka&pXaIMhFZHPxro5Nu`sgAETPek z)?Kmda=u~8qcK$Z-26qT|D-EpA!Us>%@z95VZJrdI<_;zJfSHLU^Ru5`mfLpt&cic zi#S172V1+@xWzawl_nVFOP_h&zx~#ll3z90BL^gOR)7uN=rY^Hs?;7fae@n7VvE&s z{(u)J7N!cEqC%)5j#)j=o1V-FR+`6>gejhEr3w6uv~NWyG`^lVFlD+6{86>gS^lg_ zsN5eEBqLw{q(7QwCk^DB*&={aJGpzY&ZkO`I>>rfG(h(_Gkv3?)TBThkvmx%iMu4d zfFuQGTbrmijMa5&|-b-=KI)bnewtgpsa;Ty#);xkgF6*w6P2O zl808vAQI6OSl8LM)gyg)hPw>1cV7Omgi@8M`m|W;Lj$dVxh7aimj+slh^oD74P9)n z*akv@QlG2wjV>>{Wrpl zbn2t=E;K7Hl`>Yf`y6AW+0-}=K03q62ECh2lt3LhY~w`U@@gxsxitncGj;} z*qIL;lP$93AYPYBINo`BFK{Yh)m$%fd1{7+S|bbVlr_wP*z+lwZinTd6IE1&O9wyRBeExvrrP2HoB=mhDF3cJrwHcGrjdN z!dg~w2vQ3DPSON3+@z1xtyy-ig9?(?bE189Z?k)zZ-xm*n&4|+8|_CG1PhgmBTrc^ z5KqC*R+eE~?G>GD0z#8@%`Xs3B#lyJNE@|PtQa+JbB3?I=O{<$=qc}-r85Rt$9cLs z^{A>NvuLamR&k6&3~ZDB&GUn=eBdizn{1|v=y0GUA4_?mDT@W-9*44lQ$1;r4dR1= z)m50Q41wkHCe}+R6)Xnp)_wJLh40bPJ1#NYJ9YwxEAX(S787eHgbegcN2g7=7lr2d z+$&!5xrwzAECQX(Z1Y=R2B~E+1(I$x!4B!5V-Y@dxJP^w3$7|m%qu*XI4mCF@d$$q zGsXz3U{LG~UZqOtKMI;RkxD|TgT2!xy&LaVyXqOu=0H)-hkWTmb~1?W*3!$rGMLqr zguXuXuD|Q5lavu=%7^J$(r9s*C^N^w9#QT!U!kMUnCV}3w6RZA-``Bt0M>V^eRN#p ze$4f->wKt+vM5GGp4ynQTOd|9Ou}l$n`nRu9k4+w1H zk9JnHi2V$W_PARUpQem9IM<`LR8!DWAmD(04p!(7e)5j3tb!UzVV+-D>S%<4^&Gux zX@+lw%B(8HEJbFU@3)@N%{spI6FA99_VZn1Gpbl6-5l#T1}$PAQ--_WW4@M3s?PO@ zE%nsmcfZuUluc~!1CJPNykQcO2+Yti&o?Ypv}zNJeg~^cde4*Ivx3=9(ifLn&sNrP zrdvwP=M~@i@!AC{S1A^>%PR(Am|=|trM&_=IBKD@w$=u_o9%n| z+Cu>aIUlNJ2ia^fx_i$00-w9luMNWt$;ISQlc(I#WF4A$sv!d3=&Y}~M*G|&UN*-` zE^?o<{oTfXGgC_|$e|RuNocZv zxwHwlpUN!Uf$~_=QL{kE;mULzi5lOUFErmQ)$X^Je$H{J!TS45l?Qw!^t`f6_vZlC z^yEU@JA9yD=3H(2%$|9)gchB&&!o~%n5@b%jh3(Qx+%F{=<>A4v|!4kF=;R78l4nj zv^OOzuTn3EI>B~!u$%%1SlKimNY$FkEGG~a*vp-EUubKLP&L~b5Kq=T@9^_ei$ccB zp#wVj(Tql2Y6`5MW=*SwX6u@d4zW~Foe6zm96VuVE8qrSOW03upIgstSc6eC=zz>~Ljvbb=>UM&I}XHLT?#yDs8fsL*mc-aIW{YIzs(3asme zyr;!7jg)zg6+~{~wFi%*$QE|=nQN47D-=r}w)Ej5UT=!4Y^CtloZtAejVy{3(%Y*! z?`a;n#f#o|hW`F;Il&mA(D!hdDPH%5wW*01h7yMxwTM^y!rlrNH6vFZi;gU01yu~P zuIgsZ)7(Zjx0BFH&R4t`)Wf@u_f;oJ)vWDm*IHo_u2kh|hkGoj zp1Vj{x$@K&l-(Y&P>qibX;$D=kQYoY)l}&TLrwAry;Saq+ucP6PnqjZUj}B=#}Q6i zgvFuCRG)dsL#7n898@AtKLcg4KqRDQde`)Huoz}YHPB}S>BS>Uz9diWj5>QlB3V;2 z(#QgL=xjDao$Ut~SVNz1qK#c>+l3NKri}BY4}593(Pq)dgk0Zmo{-f7@rb=gI??aa zDzBeBXP+jEkN2p3o6vXUsr}MQlB#NVnGc%Hnyy#u4u5mFJAL9@!xp05`QG-hSA8GF zg$ryGXL8Kbl0aE35PMOjAPy?VOn2EjBQHinD)NKLdYj({0YUPVTS^Jc7b?TXmNTkA zH8%Gay?mvai=7-PNfW7dny0z0@(cep zBNR%h&Myy3AhqbM6$c4B-+7p0zFr_ywSenxXtX|xjWJMCbBj-CwwY-uR3|-@D-oFM zJ>_;-z(6NYxuB^Ybfh8^bk-3mA9=>t=ICW}`?}eWF3w0)**cowBDW|nR-Qf-Ad%Nx zEK!uLNGU2;l74k(nrejwQXxl%_(M=*tbUEW=vBV*whxRp&TLge9PL8$mHNs>o|JTw zZFI5HVu;6_r`FI9K9`Wt-&g);cfD+21667i3(OHZwUx_5xp^uCDtzv0F9fNH@%ILf zVI?c3UOJ{S+q@ciTKts70x`f?zEdM9DNrMcPC7OlQ7U1+*$p%up$}c}dE***-4v@a z#J3ygA^UTpxiC?v1TT$VC&wI~gl>!yU zn%mHE`zbcCk9VG`M4aF&@1B)&YT1@*H1zeb&`*BnUZK#$79G6nr;rb&JZUH-4NM`e-Zb-H)qaq_y<^+E!O} zHEZgcQ95OFdzdL78aLN8%|o^`RG|@8_q86jYIPe$4zjP4p1ZC2Vs#secdh)EV@!M} z*LT0nQ&tPa!}gu#B*)s`46vge(n~>&>3XQpHN9hPocj7r`tO;(Fx@J83KU35ndN;+ zeN8jRa!BdnNdHx#L#~Ht8K;ic5(quuSy$QB$0}PDdbY+mDT5TX#*Av1pduWXXp_8r zd0G_8YJu2?&J5QYn37WB$sjk~v&ux05SdR>WV!=WP7fa2uh2_jN zP%j0#DvxtE<*7YU=zIS&MwDzD?^{JDdoQL;!g*S(l)at{{k`v=MpK|vFAy@l^_cJ5 zIILZ{=|a~_x;E!}o;+HM7p$&>9gS7xL~hD?hw@l>WX(YoL!idSR&3;STga4(RjM@6 z3m)+l_H~GN&C2x>nx|G$H`A4S*)`Z+hZAz$pFAxBwJx;FEVB)1v`)08NG+15O`yAK zvwfzYdFbKy-gR%ThbT|2qS-!E*jG^FT6bBq(L@P(YB!Yi0#OPB48RQY7dRa)4~v>? zxyD2*_&*!k9rN90r04Rn$J!MYc*YN#OEJr3=361k+Lx#HNm(usv&?5*zqX3kJle!U z5GYtgIaIYO2_;JPM<)l_(RU{0dXVzeEL9od1M}ivC63hfA#~;&BdpH;x$a?}7MikL zAhx83<4y9h_ifiiiq~L~V^Q|jPpC$Sc`9t;d~@?@{g!AN?KHdD!|{g4M^=uu6|Yk1 zSzGG(NUr;sr-i00U+L4B?+O>&--Kqu%`GaG=z=dz_Jvo}n5&1O#^rjD^3)`abFyoV zG0}e=<~bpznGNgMktdC?LTg1`d0KKPi-=MYC4>SY#g1^Mp-tL3R2!pH90%kr6YUl$ zK(eGzXs%bigCV}Ny{D}0h+Gd-o|>S4`#&`y3RN@IEw(n?uEvL`RwPUabTW6JsyrXj z9x3akJtfqi{w|X8q(GIo8xdAg>C5<=A4=)j%8)N9)k^iSzdza432Mx?Wv&M)Pfbv@ z_tZqTY*n^qlnYI`s;8wx&AuXFr0L4)xXW#X z6k1JT_{h!`|7)Yp{^U6Z=sf$YTf$>=J#tGswZ^LIpLDXB4Gh)K%2}mnooIY3O}A=P z8Rr>ydBqInIX5L+HZax5R@eE=+FY4&U;{e)lM|J$pFXxe1+MUfj;)((&EY^e!G9D4 zIUl&C9jz>$A$Zt3ii_KFB>nu!4hk|O1-&9vwScwUawMJN_o>2t+N>L)Fuy$f47BhIM3)7Q4RD|_K3rsj z>pU&FRPAqm=|&%zW4ORjC7CJI{w^%FQmU{%bNL80UNKIhSiwSN_svtTXrUH}5<=f( zq(rKv3h&!4BVu7HA31EPqIqt2vw26t%Ko5(2EmE{On-l|;-BhOThGzF=k`R!18RaA zL8JQdJS~y5FoKJ>U^SzJCi^%Y38KE=zOuUFm+uN}}r z${_kM$y;vsxE6T@&l{2JTg+3N(MQJh!843>fYW^G5O;)ohe4gW zY>lwVedY7~s77pbzhF~6 zL5F(B67+PNa_<>bn)92@qj@Ys)t(O3RYHIr=w*Ozj*r96PBl-tk-o|sOSe0GsyDhj z&sbCZQbNL>j!=T`&a%QVq0eCl-wV~4<6?*E*U(mSgfN;H!6)^OqoadeW`$Lo=|+LV zoDW4FZPZNKH0A(v(g#1ao8fsrqTOLq?2VbUft?iA#sLcKP9JCJwX0C*-pCN{bicH# zdsMhyhXd<1)QOe6=mG_YHMm3&v!7F&>_mXTteg+VvW`Wl+Al4~s8w_grOah%tNsuD zRz=S5Fpt*aVFRi4yNS4h72;4|%S#AiCNbl)(9Z~=&-JfApH63>lMK>`qemwRB~5mr z16`eJm-TW!7|S{qx?%zJcAC?zA`wlbi7?PdagmwE463;kfH`~s0{EJT&6 zXn(q&FES2}bGu!1m9VaFbADHOv<8#y+ zZ3>;`kNWXV#_>PEu`12-g1#-k+C|L>DDzm7(5iqjg{oP}#rDm|F<*-4UAqfiW4ylw zQ=50couv!K1r^oy^mxYcfIjY0>3Rc{`q5Lt{As#2(MnQEV5)ApzVke_Oxdp`3E0RR zKl2inx1(6xcu{9`Rv?SP?j?|v5Ez_s^iOoOUhG_Py2&n7+7uV@7m^OL?&>+e@jO~a z)&&CsyVes-{yZ4#)x0&uV#Q-hqcHN>R(P61oy2Z8>G>fLO3=~qesYS$6OGiJ18e)< zZ}S?8_JAz63JGD-FWqF-pPj{d)zM!2*{`}RQMszt#rD~a{ry4m_>5yIkr!u3rKde^ z6$Pg?Qg;gy4${E~+%CC@$z1caxG9Tx5EVL5Vij9D2>9+~>r+6k;*rhPqi0y}B(|+0s@`oC&h{^bD|)<@}X^NTls`yL#(E2W>koPF79-bvbA$QEO|7IW=_q3ReX^1 zKBn@^LmQydNA_}K+E+UiDpxLauY%4(p)L$^v(37+s^I{-InvFBlnU)jC)??`Z+yO# zEqv%J`)9_FdRQTylm%wwd}#7$8qJ-ehX?a7=Td>`PPII?H#dE(%3mGr2V-r?S3<+} z70D2bvTisaX$Mbx*I)HIODGlFMAS~4v*}_tTkCXIy_&rR0(<0qX!2+d%{}-c7w5GH zO9`%v720c_Dnrd+>D<2=WG73(|sX#*47}5+Iz+qpk3@<-vjV>{(J?*Arbl zBJ_!kxH%F*^wRf#3xu1Cu)G2e@~u4!gvw)i!+$6-Nb!v=bYzNcU7qvdSP)|c^t6)1 z^*Qg$l7$5hyaxk3lk=YC(RP?_D^TJgHL>)t+_SD$3O4ec(2WYI&1KP4Q{TCa9yZf8 zdeOTma|WDXq+c|zAgzu)FaDYH0cnU8S>4@!C9!_a`?6$V!2@)0YhHJ;l;H|}B(Rqw zU872<%AG!SV9WxXV6Lh5=I$&SqrS-TF+JGE?KTMnl1Il{<1iAocMi{j95~ zAR}u-9-#&cL`p!h3-ZZsmO9M!l7S+9!t%Zn3e8aAO+5(c=w6}st-z-X(fpT?2n3W# zHr2u^6!@dVSl8fqnOV1uZZPsi?a<)M7LaA^s)mbR9`U$j{wN~hM6+|=t328s75=Wv z{*ZJ_`sg^TGaa@uUCMPjbX}*lZlk3Vk(Oj92m3~~88&In>-#+X)+73=7dLs5NfasUkP&RXkOH^3PT`J= zIB>x-y#2@=gtEMFa;ZkO6Qbvh9*#F$yg+bDB%FR+=qvqs3wHOVLnN-s`T`r*>drTF zw*wo7&p$#}B_wR)f94tMXovWduFJLJ77FOktU7SSB|Dtg#f zhv?P{ZJP53`Ew%v-|MxK>|FOJkHv{=B#ML*tmzsb2+j4FGYsVr*xOu_ZNl5GrPyD* zYe?%DboBOy3J27$myTe)iEo8!O!X_>Xk8{QtmG%5Sq>KrYN2##vkKd6kz_^xc96^b zBU%INFGRHwFg9M~D=mo-3XO+#jLdm&@>p0*H!BP7?>ie1c$K7L|A>#KoF`Zb`uj}E z!#Z^kLYbZQC~Pt~Ok=E%vbY#*xIk1=@BWjJ!q^McI4}TXq(aRm}y=zl5XJW8~(nc?kWHnzqojQ}F>gW@Du^OSt zCb_{yCVJ8uEt@43NQgLvm0*8U)2ANS<>wJU#tyE>#>uFsJ5q3Zd=5L9V6G>u(^|1^ zdw|gHa9DnO(XR2PN3twA(YD<0AUZf#rO+Lb;nI`v8#U%QN#TEmLLC|G1_$bp`6^D8 zAV_4qt95viB5Uj3Bdsl;Dxkk@^>>RZU--uE*0F_BK}#C-BcpT+l0uK^&f1h1iCBFl?E`Ak3C zm?>1_o+uMXVT)bGUaqjUpsUb`NFBS04K1gWf&wFc#z9U*5|9stCfOikfjCBW{3GQD zyYlCpPl&cdq`f{fANQeM<6hgCl6C2ytVw9k$SiJ-a<}PopfGxsZ;}$aMzWjG{jj}f zyy;-UF>wQ>^z?6Q$*@1{+=wbL_U_!t?IxP*8n4H4lKYgDX4O?(BQ)AhViu{E0tum{ zV1ek`iN&UpydSO;s&OWd*Y;yl*v|~8T_B1C64uW71X;v8c1D^-%A-BvBP-OCKul>NNkFx|GZ^Gmd}l&rPdOp- z)Oc0sJ40*BY!}Ji{^Wq@%N@l{2w+8@`9L4^wSvD{MXl1WzoF>tE`PPTi_%t2U)e*U z7WYH*BuMD)RI~l)4Bg8b(GYZJ3peRq$3ygj#@kl4Ik8+_Zf08`BZp^++7a3tt zdc#IhWL=)?DYEcL=xhIc{iO!SW7C~%U^?{uv` z2JvIo(3109<8aBb(9R%I>7F;l zFJs@)(0qTglSd2*eAmJ)ZA5{;7~u>(HRC`|eaXid>(fDDQp>}(Ft`SeFxPYy9*=Yx zV_*wo<05xT(3ikpV$S?4TSw#A9>G01??WDojuB2bIpcSY3imYm9zLN%iI`!ImX+76 zp*S!>=wHys$3ibyo(bkjvR1~n{u8}OM%#(O-V&Lsk?D{ey)2ghDqd zAvBV}{@#igp^-MWoMbT_Tq`B?u6|h4XF{QBbLw#~?>OA69y8yiWGmwjG{-yS4rwXN z$_i?YQ4_GbKYQ8p1}B926WH9-<_gWP^O0?DkQY!c6_{REo_Bk_AP?0Z z_L{k>y}dm)pd7SzoXg zfd^rIZ>w;nB#wxK6OMGhF{b#1UP@i4ix8nh!zbWP-tD7>WHKxZ7-<3r}gRM*M>4G zqeen@=HyE@D2v5Wd9-I7hlE26S0hv{RAYRzOGJgUB%>u_Te`W_o90OQyFTKa7zs+8 z=mk@S-q)`{=+HU^`Nmn9ci*Fr!j4OUEq@~3E+FZ4W9>#{e2$?;ds4UFaoPFSp-^9C zXxEDbY_$}+u`g>lB7SK%@uSe4F7#6@eje-HCN_~19jTBT)kIF+D|yo-bG>XeC~|!C zI&}6A_uEe5_4*U%_^brnQ+((MwrFs8rSv+}CFg_JI-CeQnQ6FH`B7*5_D` zo_$OddfMiZ)p7vqxXYmW2E$zmT#|L~9#l|Y{;&=7u$K$%%PBb@zSdzSI{1&!)d~|r zqoaV0y#znRB~al0_{T?vwO{E=6s)$NmvY{dJQf8HMpniyGR}YFm`l~}H3VliQ!nKv z#Ss%6KrinLg{FDmzwD$Fx>;MIr*qS)k*gxHW}V^GPsTOdyW1m`S$(ml z5hknlWdq@1EoS+vp^*mj?*#VCP<+qyh*cwry@Vj4Mi?cyU9sLL<--<~_Dr=AKv}kZ>P>4%=s{84-9gfD=oKwBWE9tgt!m5 z#>(y6n=}4jfE5RcVHLc$*L zJg9Px0twd(mHR(|LMQq@>ps<(uEtlk7KnAC0ZH51S>eI8SL^6uHIB+Iad3pEDbz{u zbk;Q%2ZClp)UGDT`7*ZXNdHkCX`F7%`)0ILyrK&_+e>e~^;TdlUkOz@&>3-=;db{* zM)Ijld|?=e3L|mEdqOGq>5d}z3*DzPR?E`4Z@x;QhivXwHjQ4Sl3KQ5ALEU)UNrYk zBXF{t^%;`&tv(#Ja)+)l-A;(!%7;vFxjr~dmC#&o#8Rf24z#i_g+6s$`gzy5 zOK*`7@(0z95$W^q@s-VWaagmqnbjs`Y{zSSX=|}(R}y+U$(wO7nNYP499bmVW&{EU zwCZLnVyng_dq<2S4|rDhqMY|-q3@yo&ut?O_h&ipS2md1>df&=GphVHGGz#a{zYI- z8!EyY?o?xDZ0%g_Jx55`+6>d3VmWUMl`9vjafM=Kt~c3(RuI`MjPa(+y%alkXNPa> zSnJafM1sv{8!YEzZIN7r(6XE9yTm&YZ3IX7(ArC4T#M|mz=1BXdkcmyc`PZYiH)K{ zq0g+QJChYi#Ca*Pu@OSwJIsedp(?lA*S?+>IKQw+Y%Iv&kZ}9R6g=VKi#(iUeUN#coK-cM_#NUlj zCFRLDDc1aqMWPmS9B#REE1@53tYZLOUEgXa%y;dtjINn;X+0B!W_!@t-V&xw%#S=eOW{DbDl^EBLZJ^`9rFS2yRAX3O8?ZwU(yRfrSlaK z(8<-UULIbKGGo*o_!{;%-()8!!MQ?j=*Q|m@K@)IQO~;YpF%Zf@;R@@O4i z(v8ra6ez_2-w1tcTbITqrY&G@JUiBjBI-$E1 zusxf*#%8q+PCo|{NRrfScIqf1RQnYrEXy(*Lk(cL}KT}T@1s}!1QyU`Xt)((hU?wKG zH*KKwg02IE(xKT)tY_CIyf`CNIvfn~cfZv&%1!$nfeTu>!Tiojf;!8D4p9#V$9Y%o zRY+(#rPlfx2M25W#&A1JT+?K!B-?t;$qF{h`Qu#D(Co<~*nTnPL0vec8lAS+`&|>I zE0=mX%6m456_}x!wkPy&N*&?^2m4(k8iYDjyI$Ah?4Nd?Di>N=apWJ-x_&%jptB9$ zLKs_E>FrqWEBB_SoFH*r4hH8qI{B58ns)^IAAPKB}> z!&M8-F}{&k{vrn85XC>pc!%2_%( z-O3wAUOn9$#cMQi747sfg6S9nJ)B_ zK5bJ0r{o6P1Uto7V8tSpTCGL@_v5QfR7_hsZGMBtKcx z7Oqv&xJt99Kx+fBJqUj`!|Q&f^Vw0T%wBqm!*_>5-$=5lr(9#`I?W2sYNJ{OwijAE z3S0kI#cSvMVJ<4Zi8B3VjLM=R>w-1W{%@FnH*0ayHkj}0tOd&Bm-$$lHKt{}#54U> zPyD*cEy9oX7x0tNe+ca2@r)EW)frh*Qoi&<3s?Wr*FslFCR9ejX5LorXhUo+@s~y_ z%!{@PJtd!){Y{SbA6Bz@6mkD$*u{Gu)U|iIOg94m5(@o_!A-XHJV{$P%qBWA&n+Zu zZ3hLnWR!|Hlw3dD)}k8&ooBh8ZPZ??3KvGUyeBQ@gukCU(itrnIMt->8=grgfLnG^ zVQj`mpxWb(Yf@4(-4TMi{dQqwEAV9_ZDzx>P4F9MyT=L)ilRRJTeTXe(|AUyA7B*^ zdBw`D-StOQD2%oQ_X>?Nv~CXnioh{mce#Pfd9%rO3fRyOQf9hL;YPKiP>(ggjD*cC zr^#5qOD0aHqrdsZz&2{HmBp`!__EDCx0piH&3Bt&HfvE3S!F`}N<5fl>cC3x{tUcN zZZO_e^*F9sP2Op>zY6Mtpq&-H)Q>eHXL!l~HDiHUi*LPSYo#KleW-g?OL8T_rVf^>po{jrF0s?Iv+mqh&Ux zzy*%spqxM6)*+xs$&YQ++Co%GL`E>@FNT;AGwRjg)wagw6b)ttF4HcP1P6>X+zY4ZWghca4{sZx9`nXop{ww$#Wh zRHfb#KenaE+t~E%O9MrjpsIY<=#!bZfS|cznYMwb!(5ZIC^gSy)0`DsJ|t}Fu|*R9 zPIZzF=;?Q9x!48G?cLX>r*o}K-zG}*C$N*}Oi|WQ{e@FARF%yk z%D7cvO_#JHQf%XRKruSFIv)R7UbA)J7fn`}9eb0PHF17w24V_R0~}tiDYcvS7@j+TAae4dsOIo6LUV6xy49pcqglp zGu`Gaw`TR!rkLE!2cX(-!DgliP4sU&=^_1gH;x_>x;1$ggFPiwtwQ7iwm_Lq68dFz ztA%MjZdLL`I z4#~8wLH3>6mwuj5>3t{K+tu#Wz2O|46@|ggf?awX`a8k_*v&CYc1xeD-DE86aHEf1 zbPKX%+uAGIpov8Ewcp6)zG;R1euZkGc|LKW70|)@O3rAk?QLVhWM!j4s4sH+(z>kabRAoE8xPpR%U-li?NSwqt42ng?;+NbXv*33 z7>Q=&8-po!mAU?)?uV4&58d``MObk#b_6LubDQU(g|Jd4`I#EmDJpETiTM%~TTxN%v#)g<+t)j_UO=ZRJt|$}5QQA#FN(Hq@g{F&m_797 zLdU2}vfG`6f2#70ZTd9GLtNXhfTU#OdX^U>ALr>ppR}E?$&!gSY$|@V1qRs6LC$rh zoBY?KUht;(eCR{3d(_pAaD+E~?x;xJ-4dIJ0++@w|BQ4J+KLQr3YN8Pk@5 zcv7uHjVT%9R%Np4g*0QY_Is@7F>_Qqvwo7=&FJDkYK*d$So_%+HY4eGzID37#^wPw z_K`K~=4rV%C{`3?)#=7PDXW4gQ29*rl>OHkrLU%K8o`u-~C4|Q>( zjhpLLFL$#*u~MCM(?bCTIr_#=J#|&8v)}s8Yc?b>G>bOJMC*05y_oGH9}7+OXnbUz zQBo?5_51=H#HeN+mXvsdUG6UiwI)O;)=g_E-u0c7PmPF|gK|GfndhQL_R;w*M}0hOT`$L@ z@|Ml@Zj`@n8P#T)n@*!Q+$!odG#Cz3?Y~V~G1PmqQ8M8l?I&2Ublv<(WH^bm1_h07 zUTZ&Ond{^GE{*qH^ArghoDEew-cc&dlWgE_Hc>!RG^+OVt*D+XN|GAmsdfSVFdVr$Cci#{K>HB%(dDP)8H>Y|^|gg&(n4p;;~ z*a^NeR>~KKDI`!>ud!KKSP4v2#`fOyPrrAyCrvWXITH70l-ZM{)65n6-oLCbxTlpJ zMOV+eP{E!}mI+WA*#;k~WcNnPOoKsw=X5>xTHx${Ebj(~uwRZJ@&go0-rr{J<@k28 z!5Z{(oL|OKlV&UsME6S%FY|VkEn|u;QR<&Qw^;OToEgJNy@Y+FmOY!k3b;MyH&kwdz=eLSg-Bg>m1)uR$XK-l^(aV zcZH@JAyko`#`B!-i3KWEE#>wrt;g4qlY>&rOX%gXM#_BYbhoy+KvX+7=ErOGR#$mQ z*OnH9P@O~}VuGg#(tl$Q)gD%`TSocVGba?9>CZYPT4@i5Qcs%iZY3QXEzy-OuJI3r zD3Aymy~6%*j?nw|(&-+d63Pry7%Wj9fII5QQ8p-RvlerHOIbbSvz43RG*<}C@`LYP z=2%~<5vuTQJx|7HyHSzXUo^m7I;duTbk)A^*T0$J-ug~uN|vMs~JUf^SGaEt%)2^ zL+I^7TL=aS>Z#mI1%g;g@oU)At+t4`hEZ^eQO;DjBqjB$_C6&FYVY;$igjG17IS_} zSv}-ijB&UVyl%eVTHS&6wXvsEsAwQIp191%mud`EKCl7fg%VNj_C@2b?o?POjEhp_ z{7Wb{FiI$nlmK-GQZEbW=5Y5KX{OKZ-cYlEK|Xa<{TVrqKo4sf)|e8sWfZfaM;#zh zmkYFhWbE;=NqF}LHG^o|Q!HkvR*ZNhhYE%I(#8LTCfQ_B-=R#Nsx45r%#|yQ?{*P- zm+QHk)d1e4(%U9TnPep^``m1wsu7y)WWUJ}l~?Db5ewi8Cm6zOLe~>Gun}F{l&m?f z>0Y#-;MGP?ZcaD<^s=X1Yp1$wRtbvg1-1F!z7m^>NwD+gTLb8{>I*8-p^peQPMji@14;>xu8FyQ8%lK%4Ank*SHDaynnTz%g zT~B{I8zy;un?LwXDR6{ibdg2upT?2%*_%Zd*(>c#G|7tgS81Xd@sa=P=%$=^a>>QF zwv0IKcr1G_kmIDv-8OY|R;|rgcS`l+KrBb8Kl#)*el2L+Oz)jYt$te^kK}Kh+Sq;W zYo1WbZx-zx!ujU=+-hzAE?!2$FMa1GT?Z{h{lua%A3qlkr@*1UR3S9U>W=lMXVTst z<*xL4UeVbEYTO#VpV2oMgBJ+0_?;E3>#MBVn{B7&;!!^vx$W(32P-N}nk#e%fweuR zM(90%^k8g%G@>@IR|IV7tH|uCwYPaI>=S=9-gT1TmyMR|L3dB8@U5NHv#gtwcFroM zK<(#znqzrFs8Y45X|oZWDrLT#^y{@q52zQLyT?EDI(#ua{v?5|-C&K@*d0ZT``C`T|`qWwLes+O&F-_G)vL=i^E>ij+}S#o7*0^helvfz8BQ4)Rg6tyKETBd+tL zDel!_NQ2Wo1!>!sL z>va$Kv(=l5N%3{W9qesQ!I~MzlTav;kcxufpY9#6xzetR|0Z+$lB&I@KM38cvn=vb z{Y$!fHmDW+Ue;aJt(23j~(=VX3ovT^Llj zMw#xO_my54_@^ruC%XGW=7?I zCp594zCIaoIF}lvo8ZA#-RMjLCCZ|#Agec7u74v!!2mXQmopUZW2PiYos>mpzoA_z zwUbrtZ|FXz3gK|y*fg62Ju{$8Kfyzdp6|Jsy*Msi$o9L?$5n0InZ<{dDR!;N)^=&e z;Z*$Zqy~PQU%4f32_ZDmI@sJ?uj!sq-Po9n_TYf>N)F9%)HOH$DzLY5^X=SlGx4ddDYmnR^l$A(qaZd`YHga}LJ|)4z0ljbMpuoz zh!PGH`b@y#=J=Oa{D}jE&Y_15B8Owo`O!?Ncgqyk~r7Mtrrg&axJ~396$vzjVG1?6tuQ%yGUCdd(+8dtJi8Z1x zaPMZq$2Ef$OBpKBHF7}rNVoX$1D@M-duSPnTzq!Y0$|5dera;h) zpXMvDuAdCI1+UaQcVi^4nCDc%qJ|J(6ud&QwRC-@mGyEygIm#6%AD%M41Gn){Ji#} zS-e`itH$;V8DDF(UF)WOcbzlTgPZE8KvIc;Le~*EA}zO@>YIAGP3HNtlH-NO!hm#a zu*n{@ufppZx%3SrtYvR&df9QcI=4cG*jdqy&2+jiyL!V(62~rZE})ws+$2<+5LRS()cxgr%OhiB>Yw=bd!RH0>LER+~_cw*B4}|S8gjL+0w_hYpu94=QFq! zT_tdN-cqtvm|#=E0nz9k)Cvx_ZrQDHk|6q$mc`6MVf+x{xZ?#1BUU0ofy?8%U)aS! zhj_}!n8$ls=V-nSrlTwBJ<0o(uHX1GU&9wZv7%mzqs_vpQHtJ|b!~34e@~#Ra0gf`ZFcxVZIA0C=4w{5g=B$h8^SM*_K~wCHe9eLbkezYgLEq0 zZKc%DYTtJ`{cNqQHQTgMds`rqX&c&5sLD4@2FJ}CPSuXXr%vWsI5z9>Fe$I3!|%*@ zKr~Ax5Ln6i&QZ9FP?9qHx!%*Bb&p>gLXzHYRAsJ1;}3IZ|B(`^cAQv1)SYfF^WU^; z`hDwaRCsg<1N_E%5_S7$6uQSB1pld5cI)_pwZD^%ZbK$VdAnwr68=Gb8rISj2 zqW6Mt$Xz6C=n}8_(ZPaU%yB5)t*(dCr1@(7E2JHzGK1t{P2ajsU#*rIFAC~5f~~5R z>lxgt8%%mK<3NomP4E-L+m$|P@nD{J<1NKad;w==y==~KkFlny5gJ_^GWI|^xIySq zMSM!a85wVNjo0E}^<7==US*Ag#17|QBC5Sr{LR*O}#0Scv}9C|< zTK?x&NN?fd7w}U_y4%#|`ZK(-`rDc4dk-0;*}g6b$ax1^(N&V3&Z1zYdyHJnomuj6 zzuiq1Dt90UkjPLEw}kJEGSc&A2|ZVv?_w%}HJoK*9@2##4U#NZ`fdE#-pRimt7Px! zrHw-8e{NvrY)c3v8EkXiYXyd(Fe5@l(Eq2Oz&E)Q)BgyG}lc& zaf6~R_0A<1@;krykn;|-qN@!#h^A1LS9O|hTicl>^qQWcX+I+C+VfQkRZ9uoE?GNE zVg;c7(bHIN0W0H)&bFQlj5Ejc`V5H#%h572)$R@XgxaVxb$$W?Mfyn8Z@6R3N7Pvv zWNsz?MqpcS#j=k_bzG^LTT5jaab2pItvu@|p_g<_^E{uJWmndS>rANk+MY$i$+2?% zzFHx0y?I*b9-(rtT5Z9;;1{Yr?jj@VFPeWPVPhL9`diK?P`bCd?m#QLO48%a7D-7- z8JAOa^OAuVlsZ(kS$-iJxj!vrfZFRaV@+52JpOK%($#`GvnbO>=o0+}lcMkQ>+!iy zZNPI)UMNA7jp79Z>r|7au~mXT`bjia8$;4&aZ_w7ts<@6pw#C`D!k(z^TgYNON2sG zoh7-GF!Dva$W2Oih|A9vFwAa>O6sn-oRLBwT9rE*^ydx%oA}V5^{VU3cIib8Tbg60 z+k95*!x=3=cT(U)ui3W9i8-G_@xA7{1Fh(4Lm_1y=BgG-8EcN(FW<6_^YLpnuFxTX zJr^=&eCUSE1>%S}96Y@U{3TUf^fk->Gpm`54p3sv6st`;5 zgzMZIMeD3PZqR44|7wJgDml z5kGXdP>t^*1N9_F`^N4`u@s_I>Ec`<-fq4w&MWL+&#rQcQ(dA{L+gY?^kpyqvsUJo;06M>#6Lc_V&-femZ3Mua0yG>-ETwE z?^Ownv3_06ZRo5d;zW)mVI$q@dw)jy+1ls~H&g6a<_T5$y~HMUcb4XairL(!YP@Yw zV-}}d!oe!cw;#K~AN5T!ZOdq|3z{M(sW;;S~sZh5%ZlHD)%}cG!T`9n-jRT7!Gb^<2&# zNVvC=6IILjhGIdyseAlQEzHVXucpNXb$TOX{DEzhTF?8coF!QxpsUA(#@mS=9*;E4S9qqM4|I%n_X*ERv)uHMQ3}t);`@m z?x|>8UUjds1tUHEQa^&l8%%$8yd<@Jm7LGz?16;ZC?eCEVT$wkcbety*9zrk73wRaK-{fUGfJ>;wO z+xGT9tmzwzEC#r|g0z?y7bh6g`ek0=nxd_@a@r1wTU=hLx20Ul!$ZK9{oxlIe6W zU+2TyH;P$iOF3LWd+LhyjBloNHjZxN{iacm>G5e}p$MN^o15Vjl|mmz*{{*lR{97Y z6H2rgoqATJdnlZh5$|V^AwrMAX7!SB54Vn3EHx`qsrHa)Jh5XpI;S%Xf9vp07EG~s z044qv%d;lgim1=%WfR+3L88>W27&XjqaPfSd8~14=b-f89bO`fgGT$VDwke~H&Ax0@|rU%byY zSCs1&Dtlmkd^`m;K@mSiy#R3kualD_W`bY_25w&c6kx zD0jBt!1VPx#P$rU*Ol4W?Ot_?geHtbu&v=Pu$!V2gnmWRhI;)f=Z}AJAm<&(7L{<2 zx2$9x&o1+d%%%qECI5_h=ec&XZQ60U?eVeY!47E||1)vGh#l*taY}j7`q^a0ibK2I zW1a)01solsm0>NvwT~hM*0Z6uHy)hGN%z z#Og*c$*&EzM{Jn%u{9gXdfs-Zc2#UJcx3!EE)#vXBSq&wJt-yhZe6P0=CLV(lazZT za+^v!hxK=^(V_%D8C!;?+L-{y#zO4j{;6|h?|2jmeI)AG8+7xU(Es$SdtvMALWV^b zE3M5wT3ce_1J&Oer8_QdAB#lJJCGe}U{#~lc*3RL$Xh-vfNK9xjJ`e*3O(b$^#Z;v z8fGjIXEHR~aRQXZpYmJcunO0!akjvEelpqKku!H;3nA%0g!POv*|w1f)rSPu^?Pr| zPx~=l)=QT!YVs9biNJq_LN6GmgP_*;zo6cW{d*FAZN5;ob0mJ>NLyvFuKPV`T?^za zTsQ;-PW3OF>eOe6kC>SA4rGTt;MWb7g~>iqB{U~*6CpIyHlTyYgl774EAqA0_@P-B z`EibF)NKDJJAmJ-5&GJyU@dRj69sm%v%=0%yaoytZ`eRPoe=0R6zV{UyUlZ+f?w1g zDRO7J=#Ms(W*j4t#K1;%-H*b*g~r-Mz091M_%Cec$N1;)$dRf(?t=~DIR7u`Q7UW^ zt2Yuoy1vBk3E0YHvz*2*S+to;duR+c7mkB zsNA0^al8YS)xKPRCUAZ_HPY3RMRoQ1In6Hw!_);?spC#?rj(oNB3Xp$qEAH9gw^0A zBYbG8(93!S3hJ3?#hFash_C;+ZmVW9Pbtw&VeKOEiSt;&@BPL3){7GDoJX-=yT`T~ zNfWnZA?F>)vYTuke=cTu!z5$OSLvrb?~um4h|N;qR-f1>3rD>=G%xV|!cd(X&EA=E zr&4SXFE5pDG|)lrcZbcGAvWsWC~eRAXK`lmgJ27HddSWGV8vgi)sFR^`ikBYs&tou zfvMu}?^<3^?kM(BK%lQ-k-J#B-hQeb&mQTvo*=NBe;5`e^9{ND0GI)YW>m>pS1{?3zLb+1E}CWH>xft`Kn8~0gr=eTS@pok&Owzwo9 z=N-rfmlDM4yU+}eyTLvApfDMzQDKTrV-DgU4sd;&wO#3V0)rZL`Fh1r(i}u6RPCeK z4Elyhowy#!*kLQ>6{`-7LsVi=I%Hi{<4#T=M9lc>{-`T8LL*@fZ<^!3x)u35fnWI0 z_g;6RPJxl)z_YL0NP34qGE$&^EA*7Uwb#lt?x@`d-uwyZq%cjg=W~Seg=!^A`2$zogXngMS+C*LWOjw=U4oaPPLgnqoTRq zPBi4uvZ|Bo8J^{h^{OXAZrS^AS;1`In(hoGwJuE}27BT8tNIou?^^{No&NY;rfcjn zcULTZ+&_MM=EQ=|S#Gx`!-SDp;ufa)&<;_Y{HT#Wbo6lC=4b~A{!b{>NudHA)EP_H zw=sB)M6JworD$fXkg*tkRU2cvzN#{gRb4BPOh=;5L?6oB?Ma8|@_$(j(~r=@`JQ#8 z!p+6TTH6{WWu^&!a+RW!ay~)oa9!jTQ*uqKYURA!S#^?x%gsrv?Zz))MY-S$QL~US z7~2<8YTT`ej!`bk$Q1peMQCw;hI?0eBq~tsuJp01v9p;%7l@urlp_91M|o1Y=k2SM z&b3djtA~8v&{XP&D96SL{^AT9NF;@-qW3--i4~f9c*T-R7L3l&RbMAQC(zyMvc{l+dwu}f78jk9+29t|U5Q^(lR23FOjIpeT}%apk& zNU($F3~AY9t=`DxdWN@*TPe1_{k)o%v{%*p%2m48LksW}GaGmtF0GhvKRPqe)!y)^ zH54=vxwBdTHoBFG2 zr!Qz&R1`D3;&1�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 - this.$slides = $('.section') - this.$menu = $("#nav a") - this.section = 0 - this.$menu.each -> - $target = $(this.hash) - if $target.length - $(this).click -> - $('html, body').animate({scrollTop: $target.offset().top+1}, 1000) - return false - -App.scroll = -> - if not this.$slides - return 0 - v_scroll = $(document).scrollTop() - for slide,i in this.$slides - if v_scroll >= slide.offsetTop - this.section = i - if not $(this.$menu[this.section]).hasClass('active') - $(this.$menu).removeClass('active') - $(this.$menu[this.section]).addClass('active') - -$(document).on "page:change", -> - App.init() - -$(window).on "scroll", -> - App.scroll() - -$(document).ready -> - App.init() - -# vim: set ts=2 sw=2: diff --git a/app/assets/javascripts/welcome.coffee b/app/assets/javascripts/welcome.coffee deleted file mode 100644 index 24f83d1..0000000 --- a/app/assets/javascripts/welcome.coffee +++ /dev/null @@ -1,3 +0,0 @@ -# Place all the behaviors and hooks related to the matching controller here. -# All this logic will automatically be available in application.js. -# You can use CoffeeScript in this file: http://coffeescript.org/ diff --git a/app/assets/stylesheets/application.css b/app/assets/stylesheets/application.css deleted file mode 100644 index f9cd5b3..0000000 --- a/app/assets/stylesheets/application.css +++ /dev/null @@ -1,15 +0,0 @@ -/* - * This is a manifest file that'll be compiled into application.css, which will include all the files - * listed below. - * - * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets, - * or any plugin's vendor/assets/stylesheets directory can be referenced here using a relative path. - * - * You're free to add application-wide styles to this file and they'll appear at the bottom of the - * compiled file so the styles you add here take precedence over styles defined in any styles - * defined in the other CSS/SCSS files in this directory. It is generally better to create a new - * file per style scope. - * - *= require_tree . - *= require_self - */ diff --git a/app/assets/stylesheets/welcome.scss b/app/assets/stylesheets/welcome.scss deleted file mode 100644 index 76676f8..0000000 --- a/app/assets/stylesheets/welcome.scss +++ /dev/null @@ -1,492 +0,0 @@ -@font-face { - font-family: 'Meath'; - src: font-url("MeathFLF.ttf") format('truetype'); -} - -@font-face { - font-family: 'Celtknot'; - src: font-url("Celtknot.ttf") format('truetype'); -} - -@font-face { - font-family: 'PoiretOne'; - src: font-url("PoiretOne-Regular.ttf") format('truetype'); -} - -@font-face { - font-family: 'RationalInteger'; - src: font-url("RationalInteger.ttf") format('truetype'); -} - -@font-face { - font-family: 'Arkitech'; - src: font-url("ArkitechLight.ttf") format('truetype'), - font-url("ArkitechLight.woff") format('woff'); -} - -* { - font-family: Verdana, sans-serif; - color: rgb(41, 49, 51); - margin: 0; - padding: 0; -} - -h1,h2,h3,h4,h5,h6 { - font-weight: normal; -} -h1,h4 { - text-decoration: underline; -} -h1 { - font-size: x-large; -} -a { - text-decoration: none; - color: rgb(110, 210, 12); -} -a:visited { - color: rgb(60, 130, 12); -} -hr { - margin: 5px 0 5px 0; -} -p { - padding-top: 5px; - text-indent: 0.5em; -} - -#header { - background: rgba(0, 0, 0, 0.7); - - position: fixed; - width: 100%; - height: 5em; - margin-top: 1.875em; - - z-index: 10; -} -#nav { - position: absolute; - top: 50%; - left: 85%; - transform: translate(-50%, -50%); - width: 26.875em; - clear: both; -} -#logo { - height: 100%; - width: 60%; -} -#logo img, -#logo .logotitle { - position: relative; - top: 50%; - transform: translate(0, -50%); -} -#logo img { - border: 0.125em solid white; - border-radius: 0.625em; - padding: 2px; - opacity: 0.4; - margin: 0 1em; - float: left; -} -#logo .logotitle a { - color: rgb(255,255,255); - text-decoration: none; - font-size: 1.875em; - font-family: Arkitech; -} -#logo .logotitle span { - color: rgb(255,255,255); - text-decoration: none; - font-family: Arkitech; -} - -#nav ul { - display: block; - list-style: none; -} -#nav li { - float: left; - padding-left: 21px; -} -#nav li a { - color: rgba(255,255,255,0.4); - font-size: 1em; - text-decoration: none; - font-weight: bold; - outline: 0; -} -#nav li a:hover, -#nav li a:active { - color: rgba(255,255,255,0.7); -} -#nav li a.active { - color: rgba(255,255,255,1); - border-bottom: 0.125em solid rgb(255,255,255); -} - -#section1 .content, #section3 .content, #section5 .content { - color: rgb(214,206,204); -} -#section2, #section4, #section6 { - background-color: rgb(255,255,255); - padding: 2em 0 2em 0; -} -#section1 { - background: image_url("me.jpg") center top fixed; -} -#section3 { - background: image_url("waldschrat.jpg") center top fixed; -} -#section1, #section3, #section5 { - height: 100vh; // make this responsive... -} -.content { - position: relative; - width: 90%; - height: 100%; - left: 50%; - transform: translate(-50%, 0); - z-index: 1; -} - -#footer { - background: rgb(22, 27, 28); - position: relative; - width: 100%; - height: 8.75em; - font-size: x-small; -} -#footer p { - color: rgb(214,206,204); -} -#footer ul { - padding-top: 10px; -} -#footer li { - float: left; - padding-left: 10px; - padding-right: 10px; - border-right: 0.0625em solid rgb(214,206,204); -} -#footer .license { - bottom: 0; - width: 100%; - position: absolute; -} -#footer .license img { - display: inline-block; - position: relative; - float: right; - vertical-align: middle; -} -#footer .license div { - display: inline-block; - position: relative; - left: 0; - vertical-align: middle; -} - -#about { - display: block; - list-style: none; - text-align: justify; - width: 100%; - height: 50%; - top: 50%; - transform: translate(0, -50%); - position: absolute; -} -#about:after { - display: inline-block; - width: 100%; - height: 0; - content: ''; -} -#about .textbox { - text-align: justify; - padding: 0.625em; - width: calc(32% - 1.625em); - height: calc(100% - 1.625em); - overflow: hidden; - box-shadow: 0.625em 0.625em 0.625em rgba(0,0,0,0.7); -} -#about .textbox ol { - text-align: left; -} -#about .textbox ol q { - text-align: justify; -} -#about a { - outline: 0; -} -#about .source { - width: calc(32% - 2.875em); - bottom: 1.4375em; -} - - -.textbox { - display: inline-block; - border-color: rgba(100,190,12,0.7); - background-color: rgba(255,255,255,0.7); -} -.textbox h1 { - text-align: center; -} - -.section { - position: relative; - overflow: hidden; -} -.section .watermark { - position: absolute; - opacity: 0.1; - width: 60%; - top: 50%; - left: 50%; - transform: translate(-50%, -50%); - z-index: 0; -} - -.title { - position: relative; - text-align: center; - width: 60%; - padding-bottom: 50px; - left: 50%; - transform: translate(-50%, 0); -} -.title img { - display: inline-block; - vertical-align: middle; -} -.title h2 { - display: inline-block; - vertical-align: middle; -} -.title p { - padding-top: 10px; -} - -.quote-container { - position: relative; - width: 31.25em; - top: 0.625em; - left: 50%; - transform: translate(-50%, 0); -} -.quote { - position: relative; - display: inline-block; - width: 100%; -} -.quote img { - display: inline-block; - vertical-align: middle; -} -.quote div { - display: inline-block; - width: 80%; - text-align: right; - vertical-align: middle; -} -.quote q { - display: block; - font-family: serif; - text-align: center; - font-size: small; -} - -.text { - position: relative; - padding-bottom: 10px; -} -.text p { - padding-top: 5px; - text-align: justify; -} - -#vitae .textbox { - padding: 15px; - width: 80%; - position: absolute; - left: 50%; - top: 50%; - transform: translate(-50%, -50%); -} - -#skills .geekcode { - font-size: x-small; - padding: 10px; - margin: 15px; - background-color: rgba(0, 0, 0, 0.25); - display: inline-block; - left: 50%; - transform: translate(-50%, 0); - position: relative; -} - -#links .gpg pre { - font-size: x-small; - padding: 10px; - margin: 15px; - background-color: rgba(0, 0, 0, 0.25); - display: inline-block; - position: relative; -} - -.textbox { - text-align: center; - border-style: solid; - border-radius: 0.625em; - border-width: 0.1875em; -} - -.separator { - position: relative; - border-bottom: 0.0625em dotted black; - height: 0; - width: 20%; - left: 50%; - transform: translate(-50%, 0); - margin-top: 10px; - margin-bottom: 10px; -} - -.dictionary { - position: relative; - left: 50%; - transform: translate(-50%, 0); - font-size: small; - vertical-align: bottom; -} -.dictionary .headword { - display: inline-block; - color: red; - font-weight: bold; - text-decoration: underline; -} -.dictionary .headword i { - color: inherit; -} -.dictionary .pronounciation { - display: inline-block; - font-family: monospace; -} -.dictionary .conjugation { - display: inline-block; - font-weight: bold; -} -.dictionary ol li { - margin-left: 10px; -} -.dictionary ol li q { - display: block; - text-indent: 0.625em; - font-family: serif; - font-size: small; -} -.dictionary ol li i { - display: block; - right: 0.625em; - font-size: small; - position: absolute; -} -.dictionary ol li:before { - font-weight: bold; -} -.dictionary .sense .example { - font-style: italic; -} -.dictionary .sense .reference { - text-decoration: underline; - font-family: serif; -} -.dictionary ol.fifth { - counter-reset: section 4; - list-style-type: none; -} -.dictionary ol { - counter-reset: section; - list-style-type: none; -} -.dictionary li::before { - counter-increment: section; - content: counters(section,".") " "; -} - -.source { - position: absolute; - font-size: x-small; -} -/* -#title { - position: fixed; - top: 0px; - left: 50%; - transform: translate(-50%, 0); - z-index: 10; -} -#title h1 { - font-family: Meath; - font-weight: bolder; - font-size: 60px; -} -.text { - background: white; - border-style: solid; - border-color: rgb(100, 190, 12); - border-radius: 30px; - border-width: 3px; - padding: 10px; -} -#content { - top: 0px; - left: 0px; - width: 100%; -} -.section { - position: relative; - height: 1200px; -} -.background { - position: absolute; - z-index: -1; - overflow: hidden; -} -.background img { - position: absolute; - top: 0px; - left: 50%; - transform: translate(-50%, 0); -} -#back { - position: fixed; - border-radius: 15px; - border-width: 2px; - z-index: 1; -} -p,h1,h2,h3,h4,h5,h6 { - opacity: 1; -} -h1,h2,h3,h4,h5,h6 { - font-weight: normal; -} -h1,h4 { - text-decoration: underline; -} -h1 { - font-size: x-large; -} -a { - text-decoration: none; - color: rgb(110, 210, 12); -} -a:visited { - color: rgb(60, 130, 12); -} -*/ -/* vim: set ts=2 sw=2: */ diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb deleted file mode 100644 index d83690e..0000000 --- a/app/controllers/application_controller.rb +++ /dev/null @@ -1,5 +0,0 @@ -class ApplicationController < ActionController::Base - # Prevent CSRF attacks by raising an exception. - # For APIs, you may want to use :null_session instead. - protect_from_forgery with: :exception -end diff --git a/app/controllers/concerns/.keep b/app/controllers/concerns/.keep deleted file mode 100644 index e69de29..0000000 diff --git a/app/controllers/welcome_controller.rb b/app/controllers/welcome_controller.rb deleted file mode 100644 index f9b859b..0000000 --- a/app/controllers/welcome_controller.rb +++ /dev/null @@ -1,4 +0,0 @@ -class WelcomeController < ApplicationController - def index - end -end diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb deleted file mode 100644 index de6be79..0000000 --- a/app/helpers/application_helper.rb +++ /dev/null @@ -1,2 +0,0 @@ -module ApplicationHelper -end diff --git a/app/helpers/welcome_helper.rb b/app/helpers/welcome_helper.rb deleted file mode 100644 index eeead45..0000000 --- a/app/helpers/welcome_helper.rb +++ /dev/null @@ -1,2 +0,0 @@ -module WelcomeHelper -end diff --git a/app/mailers/.keep b/app/mailers/.keep deleted file mode 100644 index e69de29..0000000 diff --git a/app/models/.keep b/app/models/.keep deleted file mode 100644 index e69de29..0000000 diff --git a/app/models/concerns/.keep b/app/models/concerns/.keep deleted file mode 100644 index e69de29..0000000 diff --git a/app/views/layouts/application.html.erb b/app/views/layouts/application.html.erb deleted file mode 100644 index cd5bb80..0000000 --- a/app/views/layouts/application.html.erb +++ /dev/null @@ -1,72 +0,0 @@ - - - - Georg Hopp aka Steffers - <%= stylesheet_link_tag 'application', - media: 'all', 'data-turbolinks-track' => true %> - <%= csrf_meta_tags %> - - - - - <%= yield %> - - - - <%= javascript_include_tag 'application', - 'data-turbolinks-track' => true %> - - - diff --git a/app/views/welcome/index.html.erb b/app/views/welcome/index.html.erb deleted file mode 100644 index bcf91bd..0000000 --- a/app/views/welcome/index.html.erb +++ /dev/null @@ -1,243 +0,0 @@ -
-
-
-
-

COMPUTER SCIENTIST

-
- Computer-scientist n.s. - /kəmˈpjuːtə-ˈsaɪəntɪst/ -
    -
  1. - A writer of computer programs; a harmless drudge that busies - himself in tracing the bug, and detailing the significance of - bits. -
  2. -
-
-

- Shamelessly taken and slightly modified definition of lexicographer - from Samual Johnsons - - "Dictionary of the english language (1755)" - - Phonetics from - - PhoTransEdit - -

-
-
-

DAD

-
- Dad n.s. - /dæd/ -
    -
  1. - [The child's way of expressing father. It is remarkable, that, - in all parts of the world, the word for father, as first taught - to children, is compounded of a and t, or the kindred letter d - differently placed; as tad, Welsh; ἄττα, Greek; atta, Gothick; - tata, Latin. Mammas atque tatas habet Afra, Mart.] Father. -
  2. -
-
-

- Taken from the - - "Dictionary of the english language (1755)" - - Phonetics from - - PhoTransEdit - -

-
-
-

HUMANIST

-
- Humanist n.s. - /ˈhjuːmənɪst/ -
    -
  1. a person devoted to or versed in the humanities.
  2. -
  3. a person who follows a form of scientific or philosophical - humanism. - Someone who bumps his head against walls of ignorance until - he's knocked out but nevertheless starts over again as soon - as possible. - Georg Hopp -
  4. -
-
-

- Taken from the - Dictionary.com - Phonetics from - - PhoTransEdit - -

-
-
-
-
-
- <%= image_tag "me.png", class: "watermark", - width: "528px", height: "600px" %> -
-
-
-

Skills

-

- I'm still not sure if I am just lucky that no one notices that I lack - any kind of skill or I am just totally unaware of my skills. Anyway, I - try to outline some of my abilities here. -

-
-
-

As Computer-Scientist

-

- As you might have noticed I am not a brilliant web designer. - Well, who cares… -

-

- I could start with a comprehensive list of things I have done in the - past, sometimes even usefull in a way, but to be honest this list - would be long and boring and it would't express very much, would it? - So if you are really interested just visit my - Gitlab server. An - overview of the projects hosted there can be found on - Weird Web Workers. -

- If you are really interested in a skill profile look on one of my - social profiles. They might be not bleeding - edge, but they are a good starting point. If you need to know more - just send me a mail. -

-

- In summary, I have done much and I know a little of something but the - most important skill I have is to learn things I do not know right - now. -

-
------BEGIN GEEK CODE BLOCK-----
-Version: 3.1
-GIT/CS/L/P/O d--- s: !a C UL++++ P L+++$ !E--- W+++ N o? K? !w---
-!O- !M-- V-- PS+++ PE-- Y+ PGP+ t+ 5+ X R tv- b++ G e h---- r+++
-y+++
-------END GEEK CODE BLOCK------
-
-
-

As Dad

-

- There is absolutely nothing more satisfiable and at the same time - depressing than trying to be a good dad or mum. Whenever you come - to the point of giving up your kids do something totally amazing and - reesteblish your believes. Not to talk about the - I do love you so much, can you please… face. -

-
-
-

As Socialist

-

- I beleave to have understood the biggest problem in modern society - (money, btw.) and still think about the best way to transport - this knowledge to the masses. -

-
-
-
-
-
-
-
-
-
-

Vitae

-

- Oh no, not again… Why is everyone so possesed to know what - you have done in the past. Let's just forget about it and look at - the here and now and maybe try a small look into the future. -

-
-
-

- Right now I am the person who created this page. A pleasant guy with - a strong attitude to fairness and the desire to make the world a - better place. By the way I think I am a decent computer-programmer - and have at least scratched on the surface of unixoid operating - systems. -

-

- At some time I might become one of the legions that have witten - something that is at least of little use for society. -

-
-
-
-
-
-
- <%= image_tag "me.svg", class: "watermark", height: "600px" %> -
- -
-
- diff --git a/bin/bundle b/bin/bundle deleted file mode 100755 index 66e9889..0000000 --- a/bin/bundle +++ /dev/null @@ -1,3 +0,0 @@ -#!/usr/bin/env ruby -ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__) -load Gem.bin_path('bundler', 'bundle') diff --git a/bin/rails b/bin/rails deleted file mode 100755 index 0138d79..0000000 --- a/bin/rails +++ /dev/null @@ -1,9 +0,0 @@ -#!/usr/bin/env ruby -begin - load File.expand_path('../spring', __FILE__) -rescue LoadError => e - raise unless e.message.include?('spring') -end -APP_PATH = File.expand_path('../../config/application', __FILE__) -require_relative '../config/boot' -require 'rails/commands' diff --git a/bin/rake b/bin/rake deleted file mode 100755 index d87d5f5..0000000 --- a/bin/rake +++ /dev/null @@ -1,9 +0,0 @@ -#!/usr/bin/env ruby -begin - load File.expand_path('../spring', __FILE__) -rescue LoadError => e - raise unless e.message.include?('spring') -end -require_relative '../config/boot' -require 'rake' -Rake.application.run diff --git a/bin/setup b/bin/setup deleted file mode 100755 index acdb2c1..0000000 --- a/bin/setup +++ /dev/null @@ -1,29 +0,0 @@ -#!/usr/bin/env ruby -require 'pathname' - -# path to your application root. -APP_ROOT = Pathname.new File.expand_path('../../', __FILE__) - -Dir.chdir APP_ROOT do - # This script is a starting point to setup your application. - # Add necessary setup steps to this file: - - puts "== Installing dependencies ==" - system "gem install bundler --conservative" - system "bundle check || bundle install" - - # puts "\n== Copying sample files ==" - # unless File.exist?("config/database.yml") - # system "cp config/database.yml.sample config/database.yml" - # end - - puts "\n== Preparing database ==" - system "bin/rake db:setup" - - puts "\n== Removing old logs and tempfiles ==" - system "rm -f log/*" - system "rm -rf tmp/cache" - - puts "\n== Restarting application server ==" - system "touch tmp/restart.txt" -end diff --git a/bin/spring b/bin/spring deleted file mode 100755 index 7fe232c..0000000 --- a/bin/spring +++ /dev/null @@ -1,15 +0,0 @@ -#!/usr/bin/env ruby - -# This file loads spring without using Bundler, in order to be fast. -# It gets overwritten when you run the `spring binstub` command. - -unless defined?(Spring) - require 'rubygems' - require 'bundler' - - if (match = Bundler.default_lockfile.read.match(/^GEM$.*?^ (?: )*spring \((.*?)\)$.*?^$/m)) - Gem.paths = { 'GEM_PATH' => [Bundler.bundle_path.to_s, *Gem.path].uniq.join(Gem.path_separator) } - gem 'spring', match[1] - require 'spring/binstub' - end -end diff --git a/config.ru b/config.ru deleted file mode 100644 index bd83b25..0000000 --- a/config.ru +++ /dev/null @@ -1,4 +0,0 @@ -# This file is used by Rack-based servers to start the application. - -require ::File.expand_path('../config/environment', __FILE__) -run Rails.application diff --git a/config/application.rb b/config/application.rb deleted file mode 100644 index cb11aa2..0000000 --- a/config/application.rb +++ /dev/null @@ -1,26 +0,0 @@ -require File.expand_path('../boot', __FILE__) - -require 'rails/all' - -# Require the gems listed in Gemfile, including any gems -# you've limited to :test, :development, or :production. -Bundler.require(*Rails.groups) - -module SteffersOrg - class Application < Rails::Application - # Settings in config/environments/* take precedence over those specified here. - # Application configuration should go into files in config/initializers - # -- all .rb files in that directory are automatically loaded. - - # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone. - # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC. - # config.time_zone = 'Central Time (US & Canada)' - - # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded. - # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s] - # config.i18n.default_locale = :de - - # Do not swallow errors in after_commit/after_rollback callbacks. - config.active_record.raise_in_transactional_callbacks = true - end -end diff --git a/config/boot.rb b/config/boot.rb deleted file mode 100644 index 6b750f0..0000000 --- a/config/boot.rb +++ /dev/null @@ -1,3 +0,0 @@ -ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__) - -require 'bundler/setup' # Set up gems listed in the Gemfile. diff --git a/config/database.yml b/config/database.yml deleted file mode 100644 index 1c1a37c..0000000 --- a/config/database.yml +++ /dev/null @@ -1,25 +0,0 @@ -# SQLite version 3.x -# gem install sqlite3 -# -# Ensure the SQLite 3 gem is defined in your Gemfile -# gem 'sqlite3' -# -default: &default - adapter: sqlite3 - pool: 5 - timeout: 5000 - -development: - <<: *default - database: db/development.sqlite3 - -# Warning: The database defined as "test" will be erased and -# re-generated from your development database when you run "rake". -# Do not set this db to the same as development or production. -test: - <<: *default - database: db/test.sqlite3 - -production: - <<: *default - database: db/production.sqlite3 diff --git a/config/environment.rb b/config/environment.rb deleted file mode 100644 index ee8d90d..0000000 --- a/config/environment.rb +++ /dev/null @@ -1,5 +0,0 @@ -# Load the Rails application. -require File.expand_path('../application', __FILE__) - -# Initialize the Rails application. -Rails.application.initialize! diff --git a/config/environments/development.rb b/config/environments/development.rb deleted file mode 100644 index b55e214..0000000 --- a/config/environments/development.rb +++ /dev/null @@ -1,41 +0,0 @@ -Rails.application.configure do - # Settings specified here will take precedence over those in config/application.rb. - - # In the development environment your application's code is reloaded on - # every request. This slows down response time but is perfect for development - # since you don't have to restart the web server when you make code changes. - config.cache_classes = false - - # Do not eager load code on boot. - config.eager_load = false - - # Show full error reports and disable caching. - config.consider_all_requests_local = true - config.action_controller.perform_caching = false - - # Don't care if the mailer can't send. - config.action_mailer.raise_delivery_errors = false - - # Print deprecation notices to the Rails logger. - config.active_support.deprecation = :log - - # Raise an error on page load if there are pending migrations. - config.active_record.migration_error = :page_load - - # Debug mode disables concatenation and preprocessing of assets. - # This option may cause significant delays in view rendering with a large - # number of complex assets. - config.assets.debug = true - - # Asset digests allow you to set far-future HTTP expiration dates on all assets, - # yet still be able to expire them through the digest params. - config.assets.digest = true - - # Adds additional error checking when serving assets at runtime. - # Checks for improperly declared sprockets dependencies. - # Raises helpful error messages. - config.assets.raise_runtime_errors = true - - # Raises error for missing translations - # config.action_view.raise_on_missing_translations = true -end diff --git a/config/environments/production.rb b/config/environments/production.rb deleted file mode 100644 index 5c1b32e..0000000 --- a/config/environments/production.rb +++ /dev/null @@ -1,79 +0,0 @@ -Rails.application.configure do - # Settings specified here will take precedence over those in config/application.rb. - - # Code is not reloaded between requests. - config.cache_classes = true - - # Eager load code on boot. This eager loads most of Rails and - # your application in memory, allowing both threaded web servers - # and those relying on copy on write to perform better. - # Rake tasks automatically ignore this option for performance. - config.eager_load = true - - # Full error reports are disabled and caching is turned on. - config.consider_all_requests_local = false - config.action_controller.perform_caching = true - - # Enable Rack::Cache to put a simple HTTP cache in front of your application - # Add `rack-cache` to your Gemfile before enabling this. - # For large-scale production use, consider using a caching reverse proxy like - # NGINX, varnish or squid. - # config.action_dispatch.rack_cache = true - - # Disable serving static files from the `/public` folder by default since - # Apache or NGINX already handles this. - config.serve_static_files = ENV['RAILS_SERVE_STATIC_FILES'].present? - - # Compress JavaScripts and CSS. - config.assets.js_compressor = :uglifier - # config.assets.css_compressor = :sass - - # Do not fallback to assets pipeline if a precompiled asset is missed. - config.assets.compile = false - - # Asset digests allow you to set far-future HTTP expiration dates on all assets, - # yet still be able to expire them through the digest params. - config.assets.digest = true - - # `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb - - # Specifies the header that your server uses for sending files. - # config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache - # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX - - # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies. - # config.force_ssl = true - - # Use the lowest log level to ensure availability of diagnostic information - # when problems arise. - config.log_level = :debug - - # Prepend all log lines with the following tags. - # config.log_tags = [ :subdomain, :uuid ] - - # Use a different logger for distributed setups. - # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new) - - # Use a different cache store in production. - # config.cache_store = :mem_cache_store - - # Enable serving of images, stylesheets, and JavaScripts from an asset server. - # config.action_controller.asset_host = 'http://assets.example.com' - - # Ignore bad email addresses and do not raise email delivery errors. - # Set this to true and configure the email server for immediate delivery to raise delivery errors. - # config.action_mailer.raise_delivery_errors = false - - # Enable locale fallbacks for I18n (makes lookups for any locale fall back to - # the I18n.default_locale when a translation cannot be found). - config.i18n.fallbacks = true - - # Send deprecation notices to registered listeners. - config.active_support.deprecation = :notify - - # Use default logging formatter so that PID and timestamp are not suppressed. - config.log_formatter = ::Logger::Formatter.new - - # Do not dump schema after migrations. - config.active_record.dump_schema_after_migration = false -end diff --git a/config/environments/test.rb b/config/environments/test.rb deleted file mode 100644 index 1c19f08..0000000 --- a/config/environments/test.rb +++ /dev/null @@ -1,42 +0,0 @@ -Rails.application.configure do - # Settings specified here will take precedence over those in config/application.rb. - - # The test environment is used exclusively to run your application's - # test suite. You never need to work with it otherwise. Remember that - # your test database is "scratch space" for the test suite and is wiped - # and recreated between test runs. Don't rely on the data there! - config.cache_classes = true - - # Do not eager load code on boot. This avoids loading your whole application - # just for the purpose of running a single test. If you are using a tool that - # preloads Rails for running tests, you may have to set it to true. - config.eager_load = false - - # Configure static file server for tests with Cache-Control for performance. - config.serve_static_files = true - config.static_cache_control = 'public, max-age=3600' - - # Show full error reports and disable caching. - config.consider_all_requests_local = true - config.action_controller.perform_caching = false - - # Raise exceptions instead of rendering exception templates. - config.action_dispatch.show_exceptions = false - - # Disable request forgery protection in test environment. - config.action_controller.allow_forgery_protection = false - - # Tell Action Mailer not to deliver emails to the real world. - # The :test delivery method accumulates sent emails in the - # ActionMailer::Base.deliveries array. - config.action_mailer.delivery_method = :test - - # Randomize the order test cases are executed. - config.active_support.test_order = :random - - # Print deprecation notices to the stderr. - config.active_support.deprecation = :stderr - - # Raises error for missing translations - # config.action_view.raise_on_missing_translations = true -end diff --git a/config/initializers/assets.rb b/config/initializers/assets.rb deleted file mode 100644 index 01ef3e6..0000000 --- a/config/initializers/assets.rb +++ /dev/null @@ -1,11 +0,0 @@ -# Be sure to restart your server when you modify this file. - -# Version of your assets, change this if you want to expire all your assets. -Rails.application.config.assets.version = '1.0' - -# Add additional assets to the asset load path -# Rails.application.config.assets.paths << Emoji.images_path - -# Precompile additional assets. -# application.js, application.css, and all non-JS/CSS in app/assets folder are already added. -# Rails.application.config.assets.precompile += %w( search.js ) diff --git a/config/initializers/backtrace_silencers.rb b/config/initializers/backtrace_silencers.rb deleted file mode 100644 index 59385cd..0000000 --- a/config/initializers/backtrace_silencers.rb +++ /dev/null @@ -1,7 +0,0 @@ -# Be sure to restart your server when you modify this file. - -# You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces. -# Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ } - -# You can also remove all the silencers if you're trying to debug a problem that might stem from framework code. -# Rails.backtrace_cleaner.remove_silencers! diff --git a/config/initializers/cookies_serializer.rb b/config/initializers/cookies_serializer.rb deleted file mode 100644 index 7f70458..0000000 --- a/config/initializers/cookies_serializer.rb +++ /dev/null @@ -1,3 +0,0 @@ -# Be sure to restart your server when you modify this file. - -Rails.application.config.action_dispatch.cookies_serializer = :json diff --git a/config/initializers/filter_parameter_logging.rb b/config/initializers/filter_parameter_logging.rb deleted file mode 100644 index 4a994e1..0000000 --- a/config/initializers/filter_parameter_logging.rb +++ /dev/null @@ -1,4 +0,0 @@ -# Be sure to restart your server when you modify this file. - -# Configure sensitive parameters which will be filtered from the log file. -Rails.application.config.filter_parameters += [:password] diff --git a/config/initializers/inflections.rb b/config/initializers/inflections.rb deleted file mode 100644 index ac033bf..0000000 --- a/config/initializers/inflections.rb +++ /dev/null @@ -1,16 +0,0 @@ -# Be sure to restart your server when you modify this file. - -# Add new inflection rules using the following format. Inflections -# are locale specific, and you may define rules for as many different -# locales as you wish. All of these examples are active by default: -# ActiveSupport::Inflector.inflections(:en) do |inflect| -# inflect.plural /^(ox)$/i, '\1en' -# inflect.singular /^(ox)en/i, '\1' -# inflect.irregular 'person', 'people' -# inflect.uncountable %w( fish sheep ) -# end - -# These inflection rules are supported but not enabled by default: -# ActiveSupport::Inflector.inflections(:en) do |inflect| -# inflect.acronym 'RESTful' -# end diff --git a/config/initializers/mime_types.rb b/config/initializers/mime_types.rb deleted file mode 100644 index dc18996..0000000 --- a/config/initializers/mime_types.rb +++ /dev/null @@ -1,4 +0,0 @@ -# Be sure to restart your server when you modify this file. - -# Add new mime types for use in respond_to blocks: -# Mime::Type.register "text/richtext", :rtf diff --git a/config/initializers/session_store.rb b/config/initializers/session_store.rb deleted file mode 100644 index 65e57cd..0000000 --- a/config/initializers/session_store.rb +++ /dev/null @@ -1,3 +0,0 @@ -# Be sure to restart your server when you modify this file. - -Rails.application.config.session_store :cookie_store, key: '_steffers_org_session' diff --git a/config/initializers/wrap_parameters.rb b/config/initializers/wrap_parameters.rb deleted file mode 100644 index 33725e9..0000000 --- a/config/initializers/wrap_parameters.rb +++ /dev/null @@ -1,14 +0,0 @@ -# Be sure to restart your server when you modify this file. - -# This file contains settings for ActionController::ParamsWrapper which -# is enabled by default. - -# Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array. -ActiveSupport.on_load(:action_controller) do - wrap_parameters format: [:json] if respond_to?(:wrap_parameters) -end - -# To enable root element in JSON for ActiveRecord objects. -# ActiveSupport.on_load(:active_record) do -# self.include_root_in_json = true -# end diff --git a/config/locales/en.yml b/config/locales/en.yml deleted file mode 100644 index 0653957..0000000 --- a/config/locales/en.yml +++ /dev/null @@ -1,23 +0,0 @@ -# Files in the config/locales directory are used for internationalization -# and are automatically loaded by Rails. If you want to use locales other -# than English, add the necessary files in this directory. -# -# To use the locales, use `I18n.t`: -# -# I18n.t 'hello' -# -# In views, this is aliased to just `t`: -# -# <%= t('hello') %> -# -# To use a different locale, set it with `I18n.locale`: -# -# I18n.locale = :es -# -# This would use the information in config/locales/es.yml. -# -# To learn more, please read the Rails Internationalization guide -# available at http://guides.rubyonrails.org/i18n.html. - -en: - hello: "Hello world" diff --git a/config/routes.rb b/config/routes.rb deleted file mode 100644 index f336c96..0000000 --- a/config/routes.rb +++ /dev/null @@ -1,58 +0,0 @@ -Rails.application.routes.draw do - get 'welcome/index' - - # The priority is based upon order of creation: first created -> highest priority. - # See how all your routes lay out with "rake routes". - - # You can have the root of your site routed with "root" - root 'welcome#index' - - # Example of regular route: - # get 'products/:id' => 'catalog#view' - - # Example of named route that can be invoked with purchase_url(id: product.id) - # get 'products/:id/purchase' => 'catalog#purchase', as: :purchase - - # Example resource route (maps HTTP verbs to controller actions automatically): - # resources :products - - # Example resource route with options: - # resources :products do - # member do - # get 'short' - # post 'toggle' - # end - # - # collection do - # get 'sold' - # end - # end - - # Example resource route with sub-resources: - # resources :products do - # resources :comments, :sales - # resource :seller - # end - - # Example resource route with more complex sub-resources: - # resources :products do - # resources :comments - # resources :sales do - # get 'recent', on: :collection - # end - # end - - # Example resource route with concerns: - # concern :toggleable do - # post 'toggle' - # end - # resources :posts, concerns: :toggleable - # resources :photos, concerns: :toggleable - - # Example resource route within a namespace: - # namespace :admin do - # # Directs /admin/products/* to Admin::ProductsController - # # (app/controllers/admin/products_controller.rb) - # resources :products - # end -end diff --git a/config/secrets.yml b/config/secrets.yml deleted file mode 100644 index e105584..0000000 --- a/config/secrets.yml +++ /dev/null @@ -1,22 +0,0 @@ -# Be sure to restart your server when you modify this file. - -# Your secret key is used for verifying the integrity of signed cookies. -# If you change this key, all old signed cookies will become invalid! - -# Make sure the secret is at least 30 characters and all random, -# no regular words or you'll be exposed to dictionary attacks. -# You can use `rake secret` to generate a secure secret key. - -# Make sure the secrets in this file are kept private -# if you're sharing your code publicly. - -development: - secret_key_base: cc267893ac3dd3c3cc6959aa3192a6f0c134942c93a3b88730c25a85932823f4d8fd6b40cba9216cd4f60aa97c8a98618139912bc00c6b9392f77b1e269495e7 - -test: - secret_key_base: a3ed5abf88dfc94e95dae735d4b23b717a3c95024dedfe90eb16686071f0be55725b908a78fa6d0a4bc64d34dcfd89311d2f655213c7264d986bbcb52ea43a2b - -# Do not keep production secrets in the repository, -# instead read values from the environment. -production: - secret_key_base: <%= ENV["SECRET_KEY_BASE"] %> diff --git a/db/seeds.rb b/db/seeds.rb deleted file mode 100644 index 4edb1e8..0000000 --- a/db/seeds.rb +++ /dev/null @@ -1,7 +0,0 @@ -# This file should contain all the record creation needed to seed the database with its default values. -# The data can then be loaded with the rake db:seed (or created alongside the db with db:setup). -# -# Examples: -# -# cities = City.create([{ name: 'Chicago' }, { name: 'Copenhagen' }]) -# Mayor.create(name: 'Emanuel', city: cities.first) diff --git a/dictionary b/dictionary deleted file mode 100644 index 7a12ba0..0000000 --- a/dictionary +++ /dev/null @@ -1,10 +0,0 @@ -Lexicographer: -A writer of dictionaries; a harmless drudge that busies himself in tracing the -original, and detailing the signification of words. - -computer scientist: | kəmˈpjuːtə ˈsaɪəntɪst | -A writer of computer programs; a harmless drudge that busies himself in -tracing the bug, and detailing the significance of bits. - -Shamelessly taken and slightly modified from Samual Johnsons -"Dictionary of the english language" 1755 diff --git a/docker/Dockerfile b/docker/Dockerfile new file mode 100644 index 0000000..9009f1d --- /dev/null +++ b/docker/Dockerfile @@ -0,0 +1,16 @@ +FROM scratch + +USER 65534:65534 + +ADD data/ / + +VOLUME /document-root +ENV DOCUMENT_ROOT /document-root + +LABEL version="0.0.1" +LABEL maintainer="Georg Hopp " +LABEL description="The whole steffers.org homepage as docker container" + +EXPOSE 8080 + +ENTRYPOINT ["/bin/steffers.org"] diff --git a/docker/Makefile b/docker/Makefile new file mode 100644 index 0000000..cb92875 --- /dev/null +++ b/docker/Makefile @@ -0,0 +1,28 @@ +BIN_DIR = data/bin +DOCROOT_DIR = data/document-root +LIB_DIR = data/lib64 + +LIBS = $(LIB_DIR)/ld-linux-x86-64.so.2 \ + $(LIB_DIR)/libc.so.6 \ + $(LIB_DIR)/libpthread.so.0 + +EXE = $(BIN_DIR)/$(APP_NAME) + +.PHONY: all clean react + +all: $(LIBS) $(EXE) react Dockerfile + docker build -t $(DOCKER_IMAGE_TAG) . + +$(LIBS): + install -D /lib64/$(notdir $@) $@ + +$(EXE): + install -D $(GOEXE) $@ + +react: + install -d ${DOCROOT_DIR} + rsync -vaurl --delete ../react/build/ ${DOCROOT_DIR} + +clean: + docker rmi -f $(DOCKER_IMAGE_TAG) + rm -Rf data diff --git a/lib/assets/.keep b/lib/assets/.keep deleted file mode 100644 index e69de29..0000000 diff --git a/lib/tasks/.keep b/lib/tasks/.keep deleted file mode 100644 index e69de29..0000000 diff --git a/log/.keep b/log/.keep deleted file mode 100644 index e69de29..0000000 diff --git a/public/404.html b/public/404.html deleted file mode 100644 index b612547..0000000 --- a/public/404.html +++ /dev/null @@ -1,67 +0,0 @@ - - - - The page you were looking for doesn't exist (404) - - - - - - -
-
-

The page you were looking for doesn't exist.

-

You may have mistyped the address or the page may have moved.

-
-

If you are the application owner check the logs for more information.

-
- - diff --git a/public/422.html b/public/422.html deleted file mode 100644 index a21f82b..0000000 --- a/public/422.html +++ /dev/null @@ -1,67 +0,0 @@ - - - - The change you wanted was rejected (422) - - - - - - -
-
-

The change you wanted was rejected.

-

Maybe you tried to change something you didn't have access to.

-
-

If you are the application owner check the logs for more information.

-
- - diff --git a/public/500.html b/public/500.html deleted file mode 100644 index 061abc5..0000000 --- a/public/500.html +++ /dev/null @@ -1,66 +0,0 @@ - - - - We're sorry, but something went wrong (500) - - - - - - -
-
-

We're sorry, but something went wrong.

-
-

If you are the application owner check the logs for more information.

-
- - diff --git a/public/favicon.ico b/public/favicon.ico deleted file mode 100644 index e69de29..0000000 diff --git a/public/robots.txt b/public/robots.txt deleted file mode 100644 index 3c9c7c0..0000000 --- a/public/robots.txt +++ /dev/null @@ -1,5 +0,0 @@ -# See http://www.robotstxt.org/robotstxt.html for documentation on how to use the robots.txt file -# -# To ban all spiders from the entire site uncomment the next two lines: -# User-agent: * -# Disallow: / diff --git a/react/Makefile b/react/Makefile new file mode 100644 index 0000000..fa71865 --- /dev/null +++ b/react/Makefile @@ -0,0 +1,40 @@ +SOURCES = src/About.css \ + src/About.js \ + src/Footer.css \ + src/Footer.js \ + src/Header.css \ + src/Header.js \ + src/Links.css \ + src/Links.js \ + src/Page.css \ + src/Page.js \ + src/Skills.css \ + src/Skills.js \ + src/Vitae.css \ + src/Vitae.js \ + src/index.css \ + src/index.js \ + src/Common/Quote.css \ + src/Common/Textbox.css \ + src/Common/Textbox.js \ + src/Common/Text.css \ + src/Common/Text.js \ + src/Common/Title.css \ + src/Common/Title.js \ + src/Dictionary/Dictionary.css \ + src/Dictionary/Dictionary.js \ + src/Dictionary/Sense.js \ + src/Dictionary/Source.css \ + src/Dictionary/Source.js \ + src/Dictionary/Title.js + +.PHONY: all clean + +all: .buildchk + +.buildchk: $(SOURCES) + npm run build + touch $@ + +clean: + rm -Rf build/* diff --git a/react/README.md b/react/README.md new file mode 100644 index 0000000..98e26c9 --- /dev/null +++ b/react/README.md @@ -0,0 +1,2164 @@ +This project was bootstrapped with [Create React App](https://github.com/facebookincubator/create-react-app). + +Below you will find some information on how to perform common tasks.
+You can find the most recent version of this guide [here](https://github.com/facebookincubator/create-react-app/blob/master/packages/react-scripts/template/README.md). + +## Table of Contents + +- [Updating to New Releases](#updating-to-new-releases) +- [Sending Feedback](#sending-feedback) +- [Folder Structure](#folder-structure) +- [Available Scripts](#available-scripts) + - [npm start](#npm-start) + - [npm test](#npm-test) + - [npm run build](#npm-run-build) + - [npm run eject](#npm-run-eject) +- [Supported Language Features and Polyfills](#supported-language-features-and-polyfills) +- [Syntax Highlighting in the Editor](#syntax-highlighting-in-the-editor) +- [Displaying Lint Output in the Editor](#displaying-lint-output-in-the-editor) +- [Debugging in the Editor](#debugging-in-the-editor) +- [Formatting Code Automatically](#formatting-code-automatically) +- [Changing the Page ``](#changing-the-page-title) +- [Installing a Dependency](#installing-a-dependency) +- [Importing a Component](#importing-a-component) +- [Code Splitting](#code-splitting) +- [Adding a Stylesheet](#adding-a-stylesheet) +- [Post-Processing CSS](#post-processing-css) +- [Adding a CSS Preprocessor (Sass, Less etc.)](#adding-a-css-preprocessor-sass-less-etc) +- [Adding Images, Fonts, and Files](#adding-images-fonts-and-files) +- [Using the `public` Folder](#using-the-public-folder) + - [Changing the HTML](#changing-the-html) + - [Adding Assets Outside of the Module System](#adding-assets-outside-of-the-module-system) + - [When to Use the `public` Folder](#when-to-use-the-public-folder) +- [Using Global Variables](#using-global-variables) +- [Adding Bootstrap](#adding-bootstrap) + - [Using a Custom Theme](#using-a-custom-theme) +- [Adding Flow](#adding-flow) +- [Adding Custom Environment Variables](#adding-custom-environment-variables) + - [Referencing Environment Variables in the HTML](#referencing-environment-variables-in-the-html) + - [Adding Temporary Environment Variables In Your Shell](#adding-temporary-environment-variables-in-your-shell) + - [Adding Development Environment Variables In `.env`](#adding-development-environment-variables-in-env) +- [Can I Use Decorators?](#can-i-use-decorators) +- [Integrating with an API Backend](#integrating-with-an-api-backend) + - [Node](#node) + - [Ruby on Rails](#ruby-on-rails) +- [Proxying API Requests in Development](#proxying-api-requests-in-development) + - ["Invalid Host Header" Errors After Configuring Proxy](#invalid-host-header-errors-after-configuring-proxy) + - [Configuring the Proxy Manually](#configuring-the-proxy-manually) + - [Configuring a WebSocket Proxy](#configuring-a-websocket-proxy) +- [Using HTTPS in Development](#using-https-in-development) +- [Generating Dynamic `<meta>` Tags on the Server](#generating-dynamic-meta-tags-on-the-server) +- [Pre-Rendering into Static HTML Files](#pre-rendering-into-static-html-files) +- [Injecting Data from the Server into the Page](#injecting-data-from-the-server-into-the-page) +- [Running Tests](#running-tests) + - [Filename Conventions](#filename-conventions) + - [Command Line Interface](#command-line-interface) + - [Version Control Integration](#version-control-integration) + - [Writing Tests](#writing-tests) + - [Testing Components](#testing-components) + - [Using Third Party Assertion Libraries](#using-third-party-assertion-libraries) + - [Initializing Test Environment](#initializing-test-environment) + - [Focusing and Excluding Tests](#focusing-and-excluding-tests) + - [Coverage Reporting](#coverage-reporting) + - [Continuous Integration](#continuous-integration) + - [Disabling jsdom](#disabling-jsdom) + - [Snapshot Testing](#snapshot-testing) + - [Editor Integration](#editor-integration) +- [Developing Components in Isolation](#developing-components-in-isolation) + - [Getting Started with Storybook](#getting-started-with-storybook) + - [Getting Started with Styleguidist](#getting-started-with-styleguidist) +- [Making a Progressive Web App](#making-a-progressive-web-app) + - [Opting Out of Caching](#opting-out-of-caching) + - [Offline-First Considerations](#offline-first-considerations) + - [Progressive Web App Metadata](#progressive-web-app-metadata) +- [Analyzing the Bundle Size](#analyzing-the-bundle-size) +- [Deployment](#deployment) + - [Static Server](#static-server) + - [Other Solutions](#other-solutions) + - [Serving Apps with Client-Side Routing](#serving-apps-with-client-side-routing) + - [Building for Relative Paths](#building-for-relative-paths) + - [Azure](#azure) + - [Firebase](#firebase) + - [GitHub Pages](#github-pages) + - [Heroku](#heroku) + - [Netlify](#netlify) + - [Now](#now) + - [S3 and CloudFront](#s3-and-cloudfront) + - [Surge](#surge) +- [Advanced Configuration](#advanced-configuration) +- [Troubleshooting](#troubleshooting) + - [`npm start` doesn’t detect changes](#npm-start-doesnt-detect-changes) + - [`npm test` hangs on macOS Sierra](#npm-test-hangs-on-macos-sierra) + - [`npm run build` exits too early](#npm-run-build-exits-too-early) + - [`npm run build` fails on Heroku](#npm-run-build-fails-on-heroku) + - [`npm run build` fails to minify](#npm-run-build-fails-to-minify) + - [Moment.js locales are missing](#momentjs-locales-are-missing) +- [Something Missing?](#something-missing) + +## Updating to New Releases + +Create React App is divided into two packages: + +* `create-react-app` is a global command-line utility that you use to create new projects. +* `react-scripts` is a development dependency in the generated projects (including this one). + +You almost never need to update `create-react-app` itself: it delegates all the setup to `react-scripts`. + +When you run `create-react-app`, it always creates the project with the latest version of `react-scripts` so you’ll get all the new features and improvements in newly created apps automatically. + +To update an existing project to a new version of `react-scripts`, [open the changelog](https://github.com/facebookincubator/create-react-app/blob/master/CHANGELOG.md), find the version you’re currently on (check `package.json` in this folder if you’re not sure), and apply the migration instructions for the newer versions. + +In most cases bumping the `react-scripts` version in `package.json` and running `npm install` in this folder should be enough, but it’s good to consult the [changelog](https://github.com/facebookincubator/create-react-app/blob/master/CHANGELOG.md) for potential breaking changes. + +We commit to keeping the breaking changes minimal so you can upgrade `react-scripts` painlessly. + +## Sending Feedback + +We are always open to [your feedback](https://github.com/facebookincubator/create-react-app/issues). + +## Folder Structure + +After creation, your project should look like this: + +``` +my-app/ + README.md + node_modules/ + package.json + public/ + index.html + favicon.ico + src/ + App.css + App.js + App.test.js + index.css + index.js + logo.svg +``` + +For the project to build, **these files must exist with exact filenames**: + +* `public/index.html` is the page template; +* `src/index.js` is the JavaScript entry point. + +You can delete or rename the other files. + +You may create subdirectories inside `src`. For faster rebuilds, only files inside `src` are processed by Webpack.<br> +You need to **put any JS and CSS files inside `src`**, otherwise Webpack won’t see them. + +Only files inside `public` can be used from `public/index.html`.<br> +Read instructions below for using assets from JavaScript and HTML. + +You can, however, create more top-level directories.<br> +They will not be included in the production build so you can use them for things like documentation. + +## Available Scripts + +In the project directory, you can run: + +### `npm start` + +Runs the app in the development mode.<br> +Open [http://localhost:3000](http://localhost:3000) to view it in the browser. + +The page will reload if you make edits.<br> +You will also see any lint errors in the console. + +### `npm test` + +Launches the test runner in the interactive watch mode.<br> +See the section about [running tests](#running-tests) for more information. + +### `npm run build` + +Builds the app for production to the `build` folder.<br> +It correctly bundles React in production mode and optimizes the build for the best performance. + +The build is minified and the filenames include the hashes.<br> +Your app is ready to be deployed! + +See the section about [deployment](#deployment) for more information. + +### `npm run eject` + +**Note: this is a one-way operation. Once you `eject`, you can’t go back!** + +If you aren’t satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project. + +Instead, it will copy all the configuration files and the transitive dependencies (Webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own. + +You don’t have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it. + +## Supported Language Features and Polyfills + +This project supports a superset of the latest JavaScript standard.<br> +In addition to [ES6](https://github.com/lukehoban/es6features) syntax features, it also supports: + +* [Exponentiation Operator](https://github.com/rwaldron/exponentiation-operator) (ES2016). +* [Async/await](https://github.com/tc39/ecmascript-asyncawait) (ES2017). +* [Object Rest/Spread Properties](https://github.com/sebmarkbage/ecmascript-rest-spread) (stage 3 proposal). +* [Dynamic import()](https://github.com/tc39/proposal-dynamic-import) (stage 3 proposal) +* [Class Fields and Static Properties](https://github.com/tc39/proposal-class-public-fields) (part of stage 3 proposal). +* [JSX](https://facebook.github.io/react/docs/introducing-jsx.html) and [Flow](https://flowtype.org/) syntax. + +Learn more about [different proposal stages](https://babeljs.io/docs/plugins/#presets-stage-x-experimental-presets-). + +While we recommend to use experimental proposals with some caution, Facebook heavily uses these features in the product code, so we intend to provide [codemods](https://medium.com/@cpojer/effective-javascript-codemods-5a6686bb46fb) if any of these proposals change in the future. + +Note that **the project only includes a few ES6 [polyfills](https://en.wikipedia.org/wiki/Polyfill)**: + +* [`Object.assign()`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign) via [`object-assign`](https://github.com/sindresorhus/object-assign). +* [`Promise`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise) via [`promise`](https://github.com/then/promise). +* [`fetch()`](https://developer.mozilla.org/en/docs/Web/API/Fetch_API) via [`whatwg-fetch`](https://github.com/github/fetch). + +If you use any other ES6+ features that need **runtime support** (such as `Array.from()` or `Symbol`), make sure you are including the appropriate polyfills manually, or that the browsers you are targeting already support them. + +## Syntax Highlighting in the Editor + +To configure the syntax highlighting in your favorite text editor, head to the [relevant Babel documentation page](https://babeljs.io/docs/editors) and follow the instructions. Some of the most popular editors are covered. + +## Displaying Lint Output in the Editor + +>Note: this feature is available with `react-scripts@0.2.0` and higher.<br> +>It also only works with npm 3 or higher. + +Some editors, including Sublime Text, Atom, and Visual Studio Code, provide plugins for ESLint. + +They are not required for linting. You should see the linter output right in your terminal as well as the browser console. However, if you prefer the lint results to appear right in your editor, there are some extra steps you can do. + +You would need to install an ESLint plugin for your editor first. Then, add a file called `.eslintrc` to the project root: + +```js +{ + "extends": "react-app" +} +``` + +Now your editor should report the linting warnings. + +Note that even if you edit your `.eslintrc` file further, these changes will **only affect the editor integration**. They won’t affect the terminal and in-browser lint output. This is because Create React App intentionally provides a minimal set of rules that find common mistakes. + +If you want to enforce a coding style for your project, consider using [Prettier](https://github.com/jlongster/prettier) instead of ESLint style rules. + +## Debugging in the Editor + +**This feature is currently only supported by [Visual Studio Code](https://code.visualstudio.com) and [WebStorm](https://www.jetbrains.com/webstorm/).** + +Visual Studio Code and WebStorm support debugging out of the box with Create React App. This enables you as a developer to write and debug your React code without leaving the editor, and most importantly it enables you to have a continuous development workflow, where context switching is minimal, as you don’t have to switch between tools. + +### Visual Studio Code + +You would need to have the latest version of [VS Code](https://code.visualstudio.com) and VS Code [Chrome Debugger Extension](https://marketplace.visualstudio.com/items?itemName=msjsdiag.debugger-for-chrome) installed. + +Then add the block below to your `launch.json` file and put it inside the `.vscode` folder in your app’s root directory. + +```json +{ + "version": "0.2.0", + "configurations": [{ + "name": "Chrome", + "type": "chrome", + "request": "launch", + "url": "http://localhost:3000", + "webRoot": "${workspaceRoot}/src", + "userDataDir": "${workspaceRoot}/.vscode/chrome", + "sourceMapPathOverrides": { + "webpack:///src/*": "${webRoot}/*" + } + }] +} +``` +>Note: the URL may be different if you've made adjustments via the [HOST or PORT environment variables](#advanced-configuration). + +Start your app by running `npm start`, and start debugging in VS Code by pressing `F5` or by clicking the green debug icon. You can now write code, set breakpoints, make changes to the code, and debug your newly modified code—all from your editor. + +### WebStorm + +You would need to have [WebStorm](https://www.jetbrains.com/webstorm/) and [JetBrains IDE Support](https://chrome.google.com/webstore/detail/jetbrains-ide-support/hmhgeddbohgjknpmjagkdomcpobmllji) Chrome extension installed. + +In the WebStorm menu `Run` select `Edit Configurations...`. Then click `+` and select `JavaScript Debug`. Paste `http://localhost:3000` into the URL field and save the configuration. + +>Note: the URL may be different if you've made adjustments via the [HOST or PORT environment variables](#advanced-configuration). + +Start your app by running `npm start`, then press `^D` on macOS or `F9` on Windows and Linux or click the green debug icon to start debugging in WebStorm. + +The same way you can debug your application in IntelliJ IDEA Ultimate, PhpStorm, PyCharm Pro, and RubyMine. + +## Formatting Code Automatically + +Prettier is an opinionated code formatter with support for JavaScript, CSS and JSON. With Prettier you can format the code you write automatically to ensure a code style within your project. See the [Prettier's GitHub page](https://github.com/prettier/prettier) for more information, and look at this [page to see it in action](https://prettier.github.io/prettier/). + +To format our code whenever we make a commit in git, we need to install the following dependencies: + +```sh +npm install --save husky lint-staged prettier +``` + +Alternatively you may use `yarn`: + +```sh +yarn add husky lint-staged prettier +``` + +* `husky` makes it easy to use githooks as if they are npm scripts. +* `lint-staged` allows us to run scripts on staged files in git. See this [blog post about lint-staged to learn more about it](https://medium.com/@okonetchnikov/make-linting-great-again-f3890e1ad6b8). +* `prettier` is the JavaScript formatter we will run before commits. + +Now we can make sure every file is formatted correctly by adding a few lines to the `package.json` in the project root. + +Add the following line to `scripts` section: + +```diff + "scripts": { ++ "precommit": "lint-staged", + "start": "react-scripts start", + "build": "react-scripts build", +``` + +Next we add a 'lint-staged' field to the `package.json`, for example: + +```diff + "dependencies": { + // ... + }, ++ "lint-staged": { ++ "src/**/*.{js,jsx,json,css}": [ ++ "prettier --single-quote --write", ++ "git add" ++ ] ++ }, + "scripts": { +``` + +Now, whenever you make a commit, Prettier will format the changed files automatically. You can also run `./node_modules/.bin/prettier --single-quote --write "src/**/*.{js,jsx}"` to format your entire project for the first time. + +Next you might want to integrate Prettier in your favorite editor. Read the section on [Editor Integration](https://github.com/prettier/prettier#editor-integration) on the Prettier GitHub page. + +## Changing the Page `<title>` + +You can find the source HTML file in the `public` folder of the generated project. You may edit the `<title>` tag in it to change the title from “React App” to anything else. + +Note that normally you wouldn’t edit files in the `public` folder very often. For example, [adding a stylesheet](#adding-a-stylesheet) is done without touching the HTML. + +If you need to dynamically update the page title based on the content, you can use the browser [`document.title`](https://developer.mozilla.org/en-US/docs/Web/API/Document/title) API. For more complex scenarios when you want to change the title from React components, you can use [React Helmet](https://github.com/nfl/react-helmet), a third party library. + +If you use a custom server for your app in production and want to modify the title before it gets sent to the browser, you can follow advice in [this section](#generating-dynamic-meta-tags-on-the-server). Alternatively, you can pre-build each page as a static HTML file which then loads the JavaScript bundle, which is covered [here](#pre-rendering-into-static-html-files). + +## Installing a Dependency + +The generated project includes React and ReactDOM as dependencies. It also includes a set of scripts used by Create React App as a development dependency. You may install other dependencies (for example, React Router) with `npm`: + +```sh +npm install --save react-router +``` + +Alternatively you may use `yarn`: + +```sh +yarn add react-router +``` + +This works for any library, not just `react-router`. + +## Importing a Component + +This project setup supports ES6 modules thanks to Babel.<br> +While you can still use `require()` and `module.exports`, we encourage you to use [`import` and `export`](http://exploringjs.com/es6/ch_modules.html) instead. + +For example: + +### `Button.js` + +```js +import React, { Component } from 'react'; + +class Button extends Component { + render() { + // ... + } +} + +export default Button; // Don’t forget to use export default! +``` + +### `DangerButton.js` + + +```js +import React, { Component } from 'react'; +import Button from './Button'; // Import a component from another file + +class DangerButton extends Component { + render() { + return <Button color="red" />; + } +} + +export default DangerButton; +``` + +Be aware of the [difference between default and named exports](http://stackoverflow.com/questions/36795819/react-native-es-6-when-should-i-use-curly-braces-for-import/36796281#36796281). It is a common source of mistakes. + +We suggest that you stick to using default imports and exports when a module only exports a single thing (for example, a component). That’s what you get when you use `export default Button` and `import Button from './Button'`. + +Named exports are useful for utility modules that export several functions. A module may have at most one default export and as many named exports as you like. + +Learn more about ES6 modules: + +* [When to use the curly braces?](http://stackoverflow.com/questions/36795819/react-native-es-6-when-should-i-use-curly-braces-for-import/36796281#36796281) +* [Exploring ES6: Modules](http://exploringjs.com/es6/ch_modules.html) +* [Understanding ES6: Modules](https://leanpub.com/understandinges6/read#leanpub-auto-encapsulating-code-with-modules) + +## Code Splitting + +Instead of downloading the entire app before users can use it, code splitting allows you to split your code into small chunks which you can then load on demand. + +This project setup supports code splitting via [dynamic `import()`](http://2ality.com/2017/01/import-operator.html#loading-code-on-demand). Its [proposal](https://github.com/tc39/proposal-dynamic-import) is in stage 3. The `import()` function-like form takes the module name as an argument and returns a [`Promise`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise) which always resolves to the namespace object of the module. + +Here is an example: + +### `moduleA.js` + +```js +const moduleA = 'Hello'; + +export { moduleA }; +``` +### `App.js` + +```js +import React, { Component } from 'react'; + +class App extends Component { + handleClick = () => { + import('./moduleA') + .then(({ moduleA }) => { + // Use moduleA + }) + .catch(err => { + // Handle failure + }); + }; + + render() { + return ( + <div> + <button onClick={this.handleClick}>Load</button> + </div> + ); + } +} + +export default App; +``` + +This will make `moduleA.js` and all its unique dependencies as a separate chunk that only loads after the user clicks the 'Load' button. + +You can also use it with `async` / `await` syntax if you prefer it. + +### With React Router + +If you are using React Router check out [this tutorial](http://serverless-stack.com/chapters/code-splitting-in-create-react-app.html) on how to use code splitting with it. You can find the companion GitHub repository [here](https://github.com/AnomalyInnovations/serverless-stack-demo-client/tree/code-splitting-in-create-react-app). + +## Adding a Stylesheet + +This project setup uses [Webpack](https://webpack.js.org/) for handling all assets. Webpack offers a custom way of “extending” the concept of `import` beyond JavaScript. To express that a JavaScript file depends on a CSS file, you need to **import the CSS from the JavaScript file**: + +### `Button.css` + +```css +.Button { + padding: 20px; +} +``` + +### `Button.js` + +```js +import React, { Component } from 'react'; +import './Button.css'; // Tell Webpack that Button.js uses these styles + +class Button extends Component { + render() { + // You can use them as regular CSS styles + return <div className="Button" />; + } +} +``` + +**This is not required for React** but many people find this feature convenient. You can read about the benefits of this approach [here](https://medium.com/seek-ui-engineering/block-element-modifying-your-javascript-components-d7f99fcab52b). However you should be aware that this makes your code less portable to other build tools and environments than Webpack. + +In development, expressing dependencies this way allows your styles to be reloaded on the fly as you edit them. In production, all CSS files will be concatenated into a single minified `.css` file in the build output. + +If you are concerned about using Webpack-specific semantics, you can put all your CSS right into `src/index.css`. It would still be imported from `src/index.js`, but you could always remove that import if you later migrate to a different build tool. + +## Post-Processing CSS + +This project setup minifies your CSS and adds vendor prefixes to it automatically through [Autoprefixer](https://github.com/postcss/autoprefixer) so you don’t need to worry about it. + +For example, this: + +```css +.App { + display: flex; + flex-direction: row; + align-items: center; +} +``` + +becomes this: + +```css +.App { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -ms-flex-direction: row; + flex-direction: row; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +``` + +If you need to disable autoprefixing for some reason, [follow this section](https://github.com/postcss/autoprefixer#disabling). + +## Adding a CSS Preprocessor (Sass, Less etc.) + +Generally, we recommend that you don’t reuse the same CSS classes across different components. For example, instead of using a `.Button` CSS class in `<AcceptButton>` and `<RejectButton>` components, we recommend creating a `<Button>` component with its own `.Button` styles, that both `<AcceptButton>` and `<RejectButton>` can render (but [not inherit](https://facebook.github.io/react/docs/composition-vs-inheritance.html)). + +Following this rule often makes CSS preprocessors less useful, as features like mixins and nesting are replaced by component composition. You can, however, integrate a CSS preprocessor if you find it valuable. In this walkthrough, we will be using Sass, but you can also use Less, or another alternative. + +First, let’s install the command-line interface for Sass: + +```sh +npm install --save node-sass-chokidar +``` + +Alternatively you may use `yarn`: + +```sh +yarn add node-sass-chokidar +``` + +Then in `package.json`, add the following lines to `scripts`: + +```diff + "scripts": { ++ "build-css": "node-sass-chokidar src/ -o src/", ++ "watch-css": "npm run build-css && node-sass-chokidar src/ -o src/ --watch --recursive", + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test --env=jsdom", +``` + +>Note: To use a different preprocessor, replace `build-css` and `watch-css` commands according to your preprocessor’s documentation. + +Now you can rename `src/App.css` to `src/App.scss` and run `npm run watch-css`. The watcher will find every Sass file in `src` subdirectories, and create a corresponding CSS file next to it, in our case overwriting `src/App.css`. Since `src/App.js` still imports `src/App.css`, the styles become a part of your application. You can now edit `src/App.scss`, and `src/App.css` will be regenerated. + +To share variables between Sass files, you can use Sass imports. For example, `src/App.scss` and other component style files could include `@import "./shared.scss";` with variable definitions. + +To enable importing files without using relative paths, you can add the `--include-path` option to the command in `package.json`. + +``` +"build-css": "node-sass-chokidar --include-path ./src --include-path ./node_modules src/ -o src/", +"watch-css": "npm run build-css && node-sass-chokidar --include-path ./src --include-path ./node_modules src/ -o src/ --watch --recursive", +``` + +This will allow you to do imports like + +```scss +@import 'styles/_colors.scss'; // assuming a styles directory under src/ +@import 'nprogress/nprogress'; // importing a css file from the nprogress node module +``` + +At this point you might want to remove all CSS files from the source control, and add `src/**/*.css` to your `.gitignore` file. It is generally a good practice to keep the build products outside of the source control. + +As a final step, you may find it convenient to run `watch-css` automatically with `npm start`, and run `build-css` as a part of `npm run build`. You can use the `&&` operator to execute two scripts sequentially. However, there is no cross-platform way to run two scripts in parallel, so we will install a package for this: + +```sh +npm install --save npm-run-all +``` + +Alternatively you may use `yarn`: + +```sh +yarn add npm-run-all +``` + +Then we can change `start` and `build` scripts to include the CSS preprocessor commands: + +```diff + "scripts": { + "build-css": "node-sass-chokidar src/ -o src/", + "watch-css": "npm run build-css && node-sass-chokidar src/ -o src/ --watch --recursive", +- "start": "react-scripts start", +- "build": "react-scripts build", ++ "start-js": "react-scripts start", ++ "start": "npm-run-all -p watch-css start-js", ++ "build": "npm run build-css && react-scripts build", + "test": "react-scripts test --env=jsdom", + "eject": "react-scripts eject" + } +``` + +Now running `npm start` and `npm run build` also builds Sass files. + +**Why `node-sass-chokidar`?** + +`node-sass` has been reported as having the following issues: + +- `node-sass --watch` has been reported to have *performance issues* in certain conditions when used in a virtual machine or with docker. + +- Infinite styles compiling [#1939](https://github.com/facebookincubator/create-react-app/issues/1939) + +- `node-sass` has been reported as having issues with detecting new files in a directory [#1891](https://github.com/sass/node-sass/issues/1891) + + `node-sass-chokidar` is used here as it addresses these issues. + +## Adding Images, Fonts, and Files + +With Webpack, using static assets like images and fonts works similarly to CSS. + +You can **`import` a file right in a JavaScript module**. This tells Webpack to include that file in the bundle. Unlike CSS imports, importing a file gives you a string value. This value is the final path you can reference in your code, e.g. as the `src` attribute of an image or the `href` of a link to a PDF. + +To reduce the number of requests to the server, importing images that are less than 10,000 bytes returns a [data URI](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs) instead of a path. This applies to the following file extensions: bmp, gif, jpg, jpeg, and png. SVG files are excluded due to [#1153](https://github.com/facebookincubator/create-react-app/issues/1153). + +Here is an example: + +```js +import React from 'react'; +import logo from './logo.png'; // Tell Webpack this JS file uses this image + +console.log(logo); // /logo.84287d09.png + +function Header() { + // Import result is the URL of your image + return <img src={logo} alt="Logo" />; +} + +export default Header; +``` + +This ensures that when the project is built, Webpack will correctly move the images into the build folder, and provide us with correct paths. + +This works in CSS too: + +```css +.Logo { + background-image: url(./logo.png); +} +``` + +Webpack finds all relative module references in CSS (they start with `./`) and replaces them with the final paths from the compiled bundle. If you make a typo or accidentally delete an important file, you will see a compilation error, just like when you import a non-existent JavaScript module. The final filenames in the compiled bundle are generated by Webpack from content hashes. If the file content changes in the future, Webpack will give it a different name in production so you don’t need to worry about long-term caching of assets. + +Please be advised that this is also a custom feature of Webpack. + +**It is not required for React** but many people enjoy it (and React Native uses a similar mechanism for images).<br> +An alternative way of handling static assets is described in the next section. + +## Using the `public` Folder + +>Note: this feature is available with `react-scripts@0.5.0` and higher. + +### Changing the HTML + +The `public` folder contains the HTML file so you can tweak it, for example, to [set the page title](#changing-the-page-title). +The `<script>` tag with the compiled code will be added to it automatically during the build process. + +### Adding Assets Outside of the Module System + +You can also add other assets to the `public` folder. + +Note that we normally encourage you to `import` assets in JavaScript files instead. +For example, see the sections on [adding a stylesheet](#adding-a-stylesheet) and [adding images and fonts](#adding-images-fonts-and-files). +This mechanism provides a number of benefits: + +* Scripts and stylesheets get minified and bundled together to avoid extra network requests. +* Missing files cause compilation errors instead of 404 errors for your users. +* Result filenames include content hashes so you don’t need to worry about browsers caching their old versions. + +However there is an **escape hatch** that you can use to add an asset outside of the module system. + +If you put a file into the `public` folder, it will **not** be processed by Webpack. Instead it will be copied into the build folder untouched. To reference assets in the `public` folder, you need to use a special variable called `PUBLIC_URL`. + +Inside `index.html`, you can use it like this: + +```html +<link rel="shortcut icon" href="%PUBLIC_URL%/favicon.ico"> +``` + +Only files inside the `public` folder will be accessible by `%PUBLIC_URL%` prefix. If you need to use a file from `src` or `node_modules`, you’ll have to copy it there to explicitly specify your intention to make this file a part of the build. + +When you run `npm run build`, Create React App will substitute `%PUBLIC_URL%` with a correct absolute path so your project works even if you use client-side routing or host it at a non-root URL. + +In JavaScript code, you can use `process.env.PUBLIC_URL` for similar purposes: + +```js +render() { + // Note: this is an escape hatch and should be used sparingly! + // Normally we recommend using `import` for getting asset URLs + // as described in “Adding Images and Fonts” above this section. + return <img src={process.env.PUBLIC_URL + '/img/logo.png'} />; +} +``` + +Keep in mind the downsides of this approach: + +* None of the files in `public` folder get post-processed or minified. +* Missing files will not be called at compilation time, and will cause 404 errors for your users. +* Result filenames won’t include content hashes so you’ll need to add query arguments or rename them every time they change. + +### When to Use the `public` Folder + +Normally we recommend importing [stylesheets](#adding-a-stylesheet), [images, and fonts](#adding-images-fonts-and-files) from JavaScript. +The `public` folder is useful as a workaround for a number of less common cases: + +* You need a file with a specific name in the build output, such as [`manifest.webmanifest`](https://developer.mozilla.org/en-US/docs/Web/Manifest). +* You have thousands of images and need to dynamically reference their paths. +* You want to include a small script like [`pace.js`](http://github.hubspot.com/pace/docs/welcome/) outside of the bundled code. +* Some library may be incompatible with Webpack and you have no other option but to include it as a `<script>` tag. + +Note that if you add a `<script>` that declares global variables, you also need to read the next section on using them. + +## Using Global Variables + +When you include a script in the HTML file that defines global variables and try to use one of these variables in the code, the linter will complain because it cannot see the definition of the variable. + +You can avoid this by reading the global variable explicitly from the `window` object, for example: + +```js +const $ = window.$; +``` + +This makes it obvious you are using a global variable intentionally rather than because of a typo. + +Alternatively, you can force the linter to ignore any line by adding `// eslint-disable-line` after it. + +## Adding Bootstrap + +You don’t have to use [React Bootstrap](https://react-bootstrap.github.io) together with React but it is a popular library for integrating Bootstrap with React apps. If you need it, you can integrate it with Create React App by following these steps: + +Install React Bootstrap and Bootstrap from npm. React Bootstrap does not include Bootstrap CSS so this needs to be installed as well: + +```sh +npm install --save react-bootstrap bootstrap@3 +``` + +Alternatively you may use `yarn`: + +```sh +yarn add react-bootstrap bootstrap@3 +``` + +Import Bootstrap CSS and optionally Bootstrap theme CSS in the beginning of your ```src/index.js``` file: + +```js +import 'bootstrap/dist/css/bootstrap.css'; +import 'bootstrap/dist/css/bootstrap-theme.css'; +// Put any other imports below so that CSS from your +// components takes precedence over default styles. +``` + +Import required React Bootstrap components within ```src/App.js``` file or your custom component files: + +```js +import { Navbar, Jumbotron, Button } from 'react-bootstrap'; +``` + +Now you are ready to use the imported React Bootstrap components within your component hierarchy defined in the render method. Here is an example [`App.js`](https://gist.githubusercontent.com/gaearon/85d8c067f6af1e56277c82d19fd4da7b/raw/6158dd991b67284e9fc8d70b9d973efe87659d72/App.js) redone using React Bootstrap. + +### Using a Custom Theme + +Sometimes you might need to tweak the visual styles of Bootstrap (or equivalent package).<br> +We suggest the following approach: + +* Create a new package that depends on the package you wish to customize, e.g. Bootstrap. +* Add the necessary build steps to tweak the theme, and publish your package on npm. +* Install your own theme npm package as a dependency of your app. + +Here is an example of adding a [customized Bootstrap](https://medium.com/@tacomanator/customizing-create-react-app-aa9ffb88165) that follows these steps. + +## Adding Flow + +Flow is a static type checker that helps you write code with fewer bugs. Check out this [introduction to using static types in JavaScript](https://medium.com/@preethikasireddy/why-use-static-types-in-javascript-part-1-8382da1e0adb) if you are new to this concept. + +Recent versions of [Flow](http://flowtype.org/) work with Create React App projects out of the box. + +To add Flow to a Create React App project, follow these steps: + +1. Run `npm install --save flow-bin` (or `yarn add flow-bin`). +2. Add `"flow": "flow"` to the `scripts` section of your `package.json`. +3. Run `npm run flow init` (or `yarn flow init`) to create a [`.flowconfig` file](https://flowtype.org/docs/advanced-configuration.html) in the root directory. +4. Add `// @flow` to any files you want to type check (for example, to `src/App.js`). + +Now you can run `npm run flow` (or `yarn flow`) to check the files for type errors. +You can optionally use an IDE like [Nuclide](https://nuclide.io/docs/languages/flow/) for a better integrated experience. +In the future we plan to integrate it into Create React App even more closely. + +To learn more about Flow, check out [its documentation](https://flowtype.org/). + +## Adding Custom Environment Variables + +>Note: this feature is available with `react-scripts@0.2.3` and higher. + +Your project can consume variables declared in your environment as if they were declared locally in your JS files. By +default you will have `NODE_ENV` defined for you, and any other environment variables starting with +`REACT_APP_`. + +**The environment variables are embedded during the build time**. Since Create React App produces a static HTML/CSS/JS bundle, it can’t possibly read them at runtime. To read them at runtime, you would need to load HTML into memory on the server and replace placeholders in runtime, just like [described here](#injecting-data-from-the-server-into-the-page). Alternatively you can rebuild the app on the server anytime you change them. + +>Note: You must create custom environment variables beginning with `REACT_APP_`. Any other variables except `NODE_ENV` will be ignored to avoid accidentally [exposing a private key on the machine that could have the same name](https://github.com/facebookincubator/create-react-app/issues/865#issuecomment-252199527). Changing any environment variables will require you to restart the development server if it is running. + +These environment variables will be defined for you on `process.env`. For example, having an environment +variable named `REACT_APP_SECRET_CODE` will be exposed in your JS as `process.env.REACT_APP_SECRET_CODE`. + +There is also a special built-in environment variable called `NODE_ENV`. You can read it from `process.env.NODE_ENV`. When you run `npm start`, it is always equal to `'development'`, when you run `npm test` it is always equal to `'test'`, and when you run `npm run build` to make a production bundle, it is always equal to `'production'`. **You cannot override `NODE_ENV` manually.** This prevents developers from accidentally deploying a slow development build to production. + +These environment variables can be useful for displaying information conditionally based on where the project is +deployed or consuming sensitive data that lives outside of version control. + +First, you need to have environment variables defined. For example, let’s say you wanted to consume a secret defined +in the environment inside a `<form>`: + +```jsx +render() { + return ( + <div> + <small>You are running this application in <b>{process.env.NODE_ENV}</b> mode.</small> + <form> + <input type="hidden" defaultValue={process.env.REACT_APP_SECRET_CODE} /> + </form> + </div> + ); +} +``` + +During the build, `process.env.REACT_APP_SECRET_CODE` will be replaced with the current value of the `REACT_APP_SECRET_CODE` environment variable. Remember that the `NODE_ENV` variable will be set for you automatically. + +When you load the app in the browser and inspect the `<input>`, you will see its value set to `abcdef`, and the bold text will show the environment provided when using `npm start`: + +```html +<div> + <small>You are running this application in <b>development</b> mode.</small> + <form> + <input type="hidden" value="abcdef" /> + </form> +</div> +``` + +The above form is looking for a variable called `REACT_APP_SECRET_CODE` from the environment. In order to consume this +value, we need to have it defined in the environment. This can be done using two ways: either in your shell or in +a `.env` file. Both of these ways are described in the next few sections. + +Having access to the `NODE_ENV` is also useful for performing actions conditionally: + +```js +if (process.env.NODE_ENV !== 'production') { + analytics.disable(); +} +``` + +When you compile the app with `npm run build`, the minification step will strip out this condition, and the resulting bundle will be smaller. + +### Referencing Environment Variables in the HTML + +>Note: this feature is available with `react-scripts@0.9.0` and higher. + +You can also access the environment variables starting with `REACT_APP_` in the `public/index.html`. For example: + +```html +<title>%REACT_APP_WEBSITE_NAME% +``` + +Note that the caveats from the above section apply: + +* Apart from a few built-in variables (`NODE_ENV` and `PUBLIC_URL`), variable names must start with `REACT_APP_` to work. +* The environment variables are injected at build time. If you need to inject them at runtime, [follow this approach instead](#generating-dynamic-meta-tags-on-the-server). + +### Adding Temporary Environment Variables In Your Shell + +Defining environment variables can vary between OSes. It’s also important to know that this manner is temporary for the +life of the shell session. + +#### Windows (cmd.exe) + +```cmd +set REACT_APP_SECRET_CODE=abcdef&&npm start +``` + +(Note: the lack of whitespace is intentional.) + +#### Linux, macOS (Bash) + +```bash +REACT_APP_SECRET_CODE=abcdef npm start +``` + +### Adding Development Environment Variables In `.env` + +>Note: this feature is available with `react-scripts@0.5.0` and higher. + +To define permanent environment variables, create a file called `.env` in the root of your project: + +``` +REACT_APP_SECRET_CODE=abcdef +``` + +`.env` files **should be** checked into source control (with the exclusion of `.env*.local`). + +#### What other `.env` files are can be used? + +>Note: this feature is **available with `react-scripts@1.0.0` and higher**. + +* `.env`: Default. +* `.env.local`: Local overrides. **This file is loaded for all environments except test.** +* `.env.development`, `.env.test`, `.env.production`: Environment-specific settings. +* `.env.development.local`, `.env.test.local`, `.env.production.local`: Local overrides of environment-specific settings. + +Files on the left have more priority than files on the right: + +* `npm start`: `.env.development.local`, `.env.development`, `.env.local`, `.env` +* `npm run build`: `.env.production.local`, `.env.production`, `.env.local`, `.env` +* `npm test`: `.env.test.local`, `.env.test`, `.env` (note `.env.local` is missing) + +These variables will act as the defaults if the machine does not explicitly set them.
+Please refer to the [dotenv documentation](https://github.com/motdotla/dotenv) for more details. + +>Note: If you are defining environment variables for development, your CI and/or hosting platform will most likely need +these defined as well. Consult their documentation how to do this. For example, see the documentation for [Travis CI](https://docs.travis-ci.com/user/environment-variables/) or [Heroku](https://devcenter.heroku.com/articles/config-vars). + +## Can I Use Decorators? + +Many popular libraries use [decorators](https://medium.com/google-developers/exploring-es7-decorators-76ecb65fb841) in their documentation.
+Create React App doesn’t support decorator syntax at the moment because: + +* It is an experimental proposal and is subject to change. +* The current specification version is not officially supported by Babel. +* If the specification changes, we won’t be able to write a codemod because we don’t use them internally at Facebook. + +However in many cases you can rewrite decorator-based code without decorators just as fine.
+Please refer to these two threads for reference: + +* [#214](https://github.com/facebookincubator/create-react-app/issues/214) +* [#411](https://github.com/facebookincubator/create-react-app/issues/411) + +Create React App will add decorator support when the specification advances to a stable stage. + +## Integrating with an API Backend + +These tutorials will help you to integrate your app with an API backend running on another port, +using `fetch()` to access it. + +### Node +Check out [this tutorial](https://www.fullstackreact.com/articles/using-create-react-app-with-a-server/). +You can find the companion GitHub repository [here](https://github.com/fullstackreact/food-lookup-demo). + +### Ruby on Rails + +Check out [this tutorial](https://www.fullstackreact.com/articles/how-to-get-create-react-app-to-work-with-your-rails-api/). +You can find the companion GitHub repository [here](https://github.com/fullstackreact/food-lookup-demo-rails). + +## Proxying API Requests in Development + +>Note: this feature is available with `react-scripts@0.2.3` and higher. + +People often serve the front-end React app from the same host and port as their backend implementation.
+For example, a production setup might look like this after the app is deployed: + +``` +/ - static server returns index.html with React app +/todos - static server returns index.html with React app +/api/todos - server handles any /api/* requests using the backend implementation +``` + +Such setup is **not** required. However, if you **do** have a setup like this, it is convenient to write requests like `fetch('/api/todos')` without worrying about redirecting them to another host or port during development. + +To tell the development server to proxy any unknown requests to your API server in development, add a `proxy` field to your `package.json`, for example: + +```js + "proxy": "http://localhost:4000", +``` + +This way, when you `fetch('/api/todos')` in development, the development server will recognize that it’s not a static asset, and will proxy your request to `http://localhost:4000/api/todos` as a fallback. The development server will only attempt to send requests without a `text/html` accept header to the proxy. + +Conveniently, this avoids [CORS issues](http://stackoverflow.com/questions/21854516/understanding-ajax-cors-and-security-considerations) and error messages like this in development: + +``` +Fetch API cannot load http://localhost:4000/api/todos. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:3000' is therefore not allowed access. If an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with CORS disabled. +``` + +Keep in mind that `proxy` only has effect in development (with `npm start`), and it is up to you to ensure that URLs like `/api/todos` point to the right thing in production. You don’t have to use the `/api` prefix. Any unrecognized request without a `text/html` accept header will be redirected to the specified `proxy`. + +The `proxy` option supports HTTP, HTTPS and WebSocket connections.
+If the `proxy` option is **not** flexible enough for you, alternatively you can: + +* [Configure the proxy yourself](#configuring-the-proxy-manually) +* Enable CORS on your server ([here’s how to do it for Express](http://enable-cors.org/server_expressjs.html)). +* Use [environment variables](#adding-custom-environment-variables) to inject the right server host and port into your app. + +### "Invalid Host Header" Errors After Configuring Proxy + +When you enable the `proxy` option, you opt into a more strict set of host checks. This is necessary because leaving the backend open to remote hosts makes your computer vulnerable to DNS rebinding attacks. The issue is explained in [this article](https://medium.com/webpack/webpack-dev-server-middleware-security-issues-1489d950874a) and [this issue](https://github.com/webpack/webpack-dev-server/issues/887). + +This shouldn’t affect you when developing on `localhost`, but if you develop remotely like [described here](https://github.com/facebookincubator/create-react-app/issues/2271), you will see this error in the browser after enabling the `proxy` option: + +>Invalid Host header + +To work around it, you can specify your public development host in a file called `.env.development` in the root of your project: + +``` +HOST=mypublicdevhost.com +``` + +If you restart the development server now and load the app from the specified host, it should work. + +If you are still having issues or if you’re using a more exotic environment like a cloud editor, you can bypass the host check completely by adding a line to `.env.development.local`. **Note that this is dangerous and exposes your machine to remote code execution from malicious websites:** + +``` +# NOTE: THIS IS DANGEROUS! +# It exposes your machine to attacks from the websites you visit. +DANGEROUSLY_DISABLE_HOST_CHECK=true +``` + +We don’t recommend this approach. + +### Configuring the Proxy Manually + +>Note: this feature is available with `react-scripts@1.0.0` and higher. + +If the `proxy` option is **not** flexible enough for you, you can specify an object in the following form (in `package.json`).
+You may also specify any configuration value [`http-proxy-middleware`](https://github.com/chimurai/http-proxy-middleware#options) or [`http-proxy`](https://github.com/nodejitsu/node-http-proxy#options) supports. +```js +{ + // ... + "proxy": { + "/api": { + "target": "", + "ws": true + // ... + } + } + // ... +} +``` + +All requests matching this path will be proxies, no exceptions. This includes requests for `text/html`, which the standard `proxy` option does not proxy. + +If you need to specify multiple proxies, you may do so by specifying additional entries. +You may also narrow down matches using `*` and/or `**`, to match the path exactly or any subpath. +```js +{ + // ... + "proxy": { + // Matches any request starting with /api + "/api": { + "target": "", + "ws": true + // ... + }, + // Matches any request starting with /foo + "/foo": { + "target": "", + "ssl": true, + "pathRewrite": { + "^/foo": "/foo/beta" + } + // ... + }, + // Matches /bar/abc.html but not /bar/sub/def.html + "/bar/*.html": { + "target": "", + // ... + }, + // Matches /baz/abc.html and /baz/sub/def.html + "/baz/**/*.html": { + "target": "" + // ... + } + } + // ... +} +``` + +### Configuring a WebSocket Proxy + +When setting up a WebSocket proxy, there are a some extra considerations to be aware of. + +If you’re using a WebSocket engine like [Socket.io](https://socket.io/), you must have a Socket.io server running that you can use as the proxy target. Socket.io will not work with a standard WebSocket server. Specifically, don't expect Socket.io to work with [the websocket.org echo test](http://websocket.org/echo.html). + +There’s some good documentation available for [setting up a Socket.io server](https://socket.io/docs/). + +Standard WebSockets **will** work with a standard WebSocket server as well as the websocket.org echo test. You can use libraries like [ws](https://github.com/websockets/ws) for the server, with [native WebSockets in the browser](https://developer.mozilla.org/en-US/docs/Web/API/WebSocket). + +Either way, you can proxy WebSocket requests manually in `package.json`: + +```js +{ + // ... + "proxy": { + "/socket": { + // Your compatible WebSocket server + "target": "ws://", + // Tell http-proxy-middleware that this is a WebSocket proxy. + // Also allows you to proxy WebSocket requests without an additional HTTP request + // https://github.com/chimurai/http-proxy-middleware#external-websocket-upgrade + "ws": true + // ... + } + } + // ... +} +``` + +## Using HTTPS in Development + +>Note: this feature is available with `react-scripts@0.4.0` and higher. + +You may require the dev server to serve pages over HTTPS. One particular case where this could be useful is when using [the "proxy" feature](#proxying-api-requests-in-development) to proxy requests to an API server when that API server is itself serving HTTPS. + +To do this, set the `HTTPS` environment variable to `true`, then start the dev server as usual with `npm start`: + +#### Windows (cmd.exe) + +```cmd +set HTTPS=true&&npm start +``` + +(Note: the lack of whitespace is intentional.) + +#### Linux, macOS (Bash) + +```bash +HTTPS=true npm start +``` + +Note that the server will use a self-signed certificate, so your web browser will almost definitely display a warning upon accessing the page. + +## Generating Dynamic `` Tags on the Server + +Since Create React App doesn’t support server rendering, you might be wondering how to make `` tags dynamic and reflect the current URL. To solve this, we recommend to add placeholders into the HTML, like this: + +```html + + + + + +``` + +Then, on the server, regardless of the backend you use, you can read `index.html` into memory and replace `__OG_TITLE__`, `__OG_DESCRIPTION__`, and any other placeholders with values depending on the current URL. Just make sure to sanitize and escape the interpolated values so that they are safe to embed into HTML! + +If you use a Node server, you can even share the route matching logic between the client and the server. However duplicating it also works fine in simple cases. + +## Pre-Rendering into Static HTML Files + +If you’re hosting your `build` with a static hosting provider you can use [react-snapshot](https://www.npmjs.com/package/react-snapshot) to generate HTML pages for each route, or relative link, in your application. These pages will then seamlessly become active, or “hydrated”, when the JavaScript bundle has loaded. + +There are also opportunities to use this outside of static hosting, to take the pressure off the server when generating and caching routes. + +The primary benefit of pre-rendering is that you get the core content of each page _with_ the HTML payload—regardless of whether or not your JavaScript bundle successfully downloads. It also increases the likelihood that each route of your application will be picked up by search engines. + +You can read more about [zero-configuration pre-rendering (also called snapshotting) here](https://medium.com/superhighfives/an-almost-static-stack-6df0a2791319). + +## Injecting Data from the Server into the Page + +Similarly to the previous section, you can leave some placeholders in the HTML that inject global variables, for example: + +```js + + + + +``` + +Then, on the server, you can replace `__SERVER_DATA__` with a JSON of real data right before sending the response. The client code can then read `window.SERVER_DATA` to use it. **Make sure to [sanitize the JSON before sending it to the client](https://medium.com/node-security/the-most-common-xss-vulnerability-in-react-js-applications-2bdffbcc1fa0) as it makes your app vulnerable to XSS attacks.** + +## Running Tests + +>Note: this feature is available with `react-scripts@0.3.0` and higher.
+>[Read the migration guide to learn how to enable it in older projects!](https://github.com/facebookincubator/create-react-app/blob/master/CHANGELOG.md#migrating-from-023-to-030) + +Create React App uses [Jest](https://facebook.github.io/jest/) as its test runner. To prepare for this integration, we did a [major revamp](https://facebook.github.io/jest/blog/2016/09/01/jest-15.html) of Jest so if you heard bad things about it years ago, give it another try. + +Jest is a Node-based runner. This means that the tests always run in a Node environment and not in a real browser. This lets us enable fast iteration speed and prevent flakiness. + +While Jest provides browser globals such as `window` thanks to [jsdom](https://github.com/tmpvar/jsdom), they are only approximations of the real browser behavior. Jest is intended to be used for unit tests of your logic and your components rather than the DOM quirks. + +We recommend that you use a separate tool for browser end-to-end tests if you need them. They are beyond the scope of Create React App. + +### Filename Conventions + +Jest will look for test files with any of the following popular naming conventions: + +* Files with `.js` suffix in `__tests__` folders. +* Files with `.test.js` suffix. +* Files with `.spec.js` suffix. + +The `.test.js` / `.spec.js` files (or the `__tests__` folders) can be located at any depth under the `src` top level folder. + +We recommend to put the test files (or `__tests__` folders) next to the code they are testing so that relative imports appear shorter. For example, if `App.test.js` and `App.js` are in the same folder, the test just needs to `import App from './App'` instead of a long relative path. Colocation also helps find tests more quickly in larger projects. + +### Command Line Interface + +When you run `npm test`, Jest will launch in the watch mode. Every time you save a file, it will re-run the tests, just like `npm start` recompiles the code. + +The watcher includes an interactive command-line interface with the ability to run all tests, or focus on a search pattern. It is designed this way so that you can keep it open and enjoy fast re-runs. You can learn the commands from the “Watch Usage” note that the watcher prints after every run: + +![Jest watch mode](http://facebook.github.io/jest/img/blog/15-watch.gif) + +### Version Control Integration + +By default, when you run `npm test`, Jest will only run the tests related to files changed since the last commit. This is an optimization designed to make your tests run fast regardless of how many tests you have. However it assumes that you don’t often commit the code that doesn’t pass the tests. + +Jest will always explicitly mention that it only ran tests related to the files changed since the last commit. You can also press `a` in the watch mode to force Jest to run all tests. + +Jest will always run all tests on a [continuous integration](#continuous-integration) server or if the project is not inside a Git or Mercurial repository. + +### Writing Tests + +To create tests, add `it()` (or `test()`) blocks with the name of the test and its code. You may optionally wrap them in `describe()` blocks for logical grouping but this is neither required nor recommended. + +Jest provides a built-in `expect()` global function for making assertions. A basic test could look like this: + +```js +import sum from './sum'; + +it('sums numbers', () => { + expect(sum(1, 2)).toEqual(3); + expect(sum(2, 2)).toEqual(4); +}); +``` + +All `expect()` matchers supported by Jest are [extensively documented here](http://facebook.github.io/jest/docs/expect.html).
+You can also use [`jest.fn()` and `expect(fn).toBeCalled()`](http://facebook.github.io/jest/docs/expect.html#tohavebeencalled) to create “spies” or mock functions. + +### Testing Components + +There is a broad spectrum of component testing techniques. They range from a “smoke test” verifying that a component renders without throwing, to shallow rendering and testing some of the output, to full rendering and testing component lifecycle and state changes. + +Different projects choose different testing tradeoffs based on how often components change, and how much logic they contain. If you haven’t decided on a testing strategy yet, we recommend that you start with creating simple smoke tests for your components: + +```js +import React from 'react'; +import ReactDOM from 'react-dom'; +import App from './App'; + +it('renders without crashing', () => { + const div = document.createElement('div'); + ReactDOM.render(, div); +}); +``` + +This test mounts a component and makes sure that it didn’t throw during rendering. Tests like this provide a lot value with very little effort so they are great as a starting point, and this is the test you will find in `src/App.test.js`. + +When you encounter bugs caused by changing components, you will gain a deeper insight into which parts of them are worth testing in your application. This might be a good time to introduce more specific tests asserting specific expected output or behavior. + +If you’d like to test components in isolation from the child components they render, we recommend using [`shallow()` rendering API](http://airbnb.io/enzyme/docs/api/shallow.html) from [Enzyme](http://airbnb.io/enzyme/). To install it, run: + +```sh +npm install --save enzyme react-test-renderer +``` + +Alternatively you may use `yarn`: + +```sh +yarn add enzyme react-test-renderer +``` + +You can write a smoke test with it too: + +```js +import React from 'react'; +import { shallow } from 'enzyme'; +import App from './App'; + +it('renders without crashing', () => { + shallow(); +}); +``` + +Unlike the previous smoke test using `ReactDOM.render()`, this test only renders `` and doesn’t go deeper. For example, even if `` itself renders a `