{"id":2327,"date":"2020-09-06T09:26:45","date_gmt":"2020-09-06T08:26:45","guid":{"rendered":"https:\/\/denbeke.be\/blog\/?p=2327"},"modified":"2020-09-07T15:01:24","modified_gmt":"2020-09-07T14:01:24","slug":"i-built-a-portfolio-website-for-a-photographer-dylancalluy-com","status":"publish","type":"post","link":"https:\/\/denbeke.be\/blog\/webdevelopment\/i-built-a-portfolio-website-for-a-photographer-dylancalluy-com\/","title":{"rendered":"I built a portfolio website for a photographer: dylancalluy.com"},"content":{"rendered":"\n<p>A couple of months ago, Dylan Calluy \u2014 an aspiring Antwerp-based photographer \u2014 asked me to build a portfolio website for him. He wanted a nice-looking gallery to share his work with the world.<\/p>\n\n\n\n<p>So we designed the website together. Then I handcrafted the responsive web application for him, combined with a sleek web interface where Dylan can manage all his beautiful content all by himself.<\/p>\n\n\n\n<p>Go check it out at <a href=\"https:\/\/dylancalluy.com\" target=\"_blank\" rel=\"noreferrer noopener\">dylancalluy.com<\/a>!<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" width=\"1024\" height=\"788\" src=\"https:\/\/denbeke.be\/blog\/wp-content\/uploads\/2020\/08\/Dylan-Calluy-photography-portfolio-website-dylancalluy.com_-1024x788.png\" alt=\"\" class=\"wp-image-2328\" srcset=\"https:\/\/denbeke.be\/blog\/wp-content\/uploads\/2020\/08\/Dylan-Calluy-photography-portfolio-website-dylancalluy.com_-1024x788.png 1024w, https:\/\/denbeke.be\/blog\/wp-content\/uploads\/2020\/08\/Dylan-Calluy-photography-portfolio-website-dylancalluy.com_-300x231.png 300w, https:\/\/denbeke.be\/blog\/wp-content\/uploads\/2020\/08\/Dylan-Calluy-photography-portfolio-website-dylancalluy.com_-768x591.png 768w, https:\/\/denbeke.be\/blog\/wp-content\/uploads\/2020\/08\/Dylan-Calluy-photography-portfolio-website-dylancalluy.com_.png 1145w\" sizes=\"(max-width: 1024px) 100vw, 1024px\" \/><figcaption><a href=\"https:\/\/dylancalluy.com\" target=\"_blank\" rel=\"noreferrer noopener\">dylancalluy.com<\/a><\/figcaption><\/figure>\n\n\n\n<p><\/p>\n\n\n\n<p>For the more tech savvy people:<\/p>\n\n\n\n<ul><li>The front-end is a SPA, built with VueJS.<\/li><li>The back-end is a headless WordPress installation with custom admin pages and custom REST routes to allow Dylan for managing all his content.<\/li><li>For the contact form I use my own service called <a rel=\"noreferrer noopener\" href=\"https:\/\/github.com\/DenBeke\/mailbear\" target=\"_blank\">MailBear<\/a>. It is an API to which you can send POST requests containing the form data. MailBear then sends it to the recipient (Dylan in this case).<\/li><li>All is served with <a href=\"https:\/\/caddyserver.com\" target=\"_blank\" rel=\"noreferrer noopener\">Caddy<\/a> webserver.<\/li><li>Everything is running in its own Docker container.<\/li><\/ul>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>A couple of months ago, Dylan Calluy \u2014 an aspiring Antwerp-based photographer \u2014 asked me to build a portfolio website for him. He wanted a nice-looking gallery to share his work with the world. So we designed the website together. Then I handcrafted the responsive web application for him, combined with a sleek web interface [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[112],"tags":[288,267,110,108],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v15.6.2 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>I built a portfolio website for a photographer: dylancalluy.com &ndash; DenBeke<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/denbeke.be\/blog\/webdevelopment\/i-built-a-portfolio-website-for-a-photographer-dylancalluy-com\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"I built a portfolio website for a photographer: dylancalluy.com &ndash; DenBeke\" \/>\n<meta property=\"og:description\" content=\"A couple of months ago, Dylan Calluy \u2014 an aspiring Antwerp-based photographer \u2014 asked me to build a portfolio website for him. He wanted a nice-looking gallery to share his work with the world. So we designed the website together. Then I handcrafted the responsive web application for him, combined with a sleek web interface [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/denbeke.be\/blog\/webdevelopment\/i-built-a-portfolio-website-for-a-photographer-dylancalluy-com\/\" \/>\n<meta property=\"og:site_name\" content=\"DenBeke\" \/>\n<meta property=\"article:published_time\" content=\"2020-09-06T08:26:45+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2020-09-07T14:01:24+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/denbeke.be\/blog\/wp-content\/uploads\/2020\/08\/Dylan-Calluy-photography-portfolio-website-dylancalluy.com_-1024x788.png\" \/>\n<meta name=\"twitter:card\" content=\"summary\" \/>\n<meta name=\"twitter:creator\" content=\"@MthsBk\" \/>\n<meta name=\"twitter:site\" content=\"@MthsBk\" \/>\n<meta name=\"twitter:label1\" content=\"Est. reading time\">\n\t<meta name=\"twitter:data1\" content=\"1 minute\">\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebSite\",\"@id\":\"https:\/\/denbeke.be\/blog\/#website\",\"url\":\"https:\/\/denbeke.be\/blog\/\",\"name\":\"DenBeke\",\"description\":\"Mathias Beke\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":\"https:\/\/denbeke.be\/blog\/?s={search_term_string}\",\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"en-US\"},{\"@type\":\"ImageObject\",\"@id\":\"https:\/\/denbeke.be\/blog\/webdevelopment\/i-built-a-portfolio-website-for-a-photographer-dylancalluy-com\/#primaryimage\",\"inLanguage\":\"en-US\",\"url\":\"https:\/\/denbeke.be\/blog\/wp-content\/uploads\/2020\/08\/Dylan-Calluy-photography-portfolio-website-dylancalluy.com_.png\",\"width\":1145,\"height\":881},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/denbeke.be\/blog\/webdevelopment\/i-built-a-portfolio-website-for-a-photographer-dylancalluy-com\/#webpage\",\"url\":\"https:\/\/denbeke.be\/blog\/webdevelopment\/i-built-a-portfolio-website-for-a-photographer-dylancalluy-com\/\",\"name\":\"I built a portfolio website for a photographer: dylancalluy.com &ndash; DenBeke\",\"isPartOf\":{\"@id\":\"https:\/\/denbeke.be\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/denbeke.be\/blog\/webdevelopment\/i-built-a-portfolio-website-for-a-photographer-dylancalluy-com\/#primaryimage\"},\"datePublished\":\"2020-09-06T08:26:45+00:00\",\"dateModified\":\"2020-09-07T14:01:24+00:00\",\"author\":{\"@id\":\"https:\/\/denbeke.be\/blog\/#\/schema\/person\/386878f712fe3fe22227216f087772dc\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/denbeke.be\/blog\/webdevelopment\/i-built-a-portfolio-website-for-a-photographer-dylancalluy-com\/\"]}]},{\"@type\":\"Person\",\"@id\":\"https:\/\/denbeke.be\/blog\/#\/schema\/person\/386878f712fe3fe22227216f087772dc\",\"name\":\"Mathias Beke\",\"image\":{\"@type\":\"ImageObject\",\"@id\":\"https:\/\/denbeke.be\/blog\/#personlogo\",\"inLanguage\":\"en-US\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/015ba35e6ce4f5859e3888ca99807575?s=96&d=mm&r=g\",\"caption\":\"Mathias Beke\"}}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","_links":{"self":[{"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/posts\/2327"}],"collection":[{"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/comments?post=2327"}],"version-history":[{"count":1,"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/posts\/2327\/revisions"}],"predecessor-version":[{"id":2329,"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/posts\/2327\/revisions\/2329"}],"wp:attachment":[{"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/media?parent=2327"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/categories?post=2327"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/denbeke.be\/blog\/wp-json\/wp\/v2\/tags?post=2327"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}