PHP code example of d4l / kirby-static-site-generator
1. Go to this page and download the library: Download d4l/kirby-static-site-generator library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
d4l / kirby-static-site-generator example snippets
return [
'd4l' => [
'static_site_generator' => [
'endpoint' => null, # set to any string like 'generate-static-site' to use the built-in endpoint (necessary when using the blueprint field)
'output_folder' => './static', # you can specify an absolute or relative path
'preserve' => [], # preserve individual files / folders in the root level of the output folder (anything starting with "." is always preserved)
'base_url' => '/', # if the static site is not mounted to the root folder of your domain, change accordingly here
'skip_media' => false, # set to true to skip copying media files, e.g. when they are already on a CDN; combinable with 'preserve' => ['media']
'skip_templates' => [], # ignore pages with given templates (home is always rendered)
'custom_routes' => [], # see below for more information on custom routes
'custom_filters' => [], # see below for more information on custom filters
'ignore_untranslated_pages' => false, # set to true to ignore pages without an own language
'index_file_name' => 'index.html' # you can change the directory index file name, e.g. to 'index.json' when generating an API
]
]
];
$customRoutes = [
[ // minimal configuration to render a route (must match, else skipped)
'path' => 'my/route',
],
[ // minimal configuration to render a page
'path' => 'foo/bar',
'page' => 'some-page-id'
],
[ // advanced configuration to render a route (write to different path)
'path' => 'sitemap.xml',
'route' => 'my/sitemap/route'
],
[ // advanced configuration to render a page
'path' => 'foo/baz',
'page' => page('some-page-id'),
'languageCode' => 'en',
'baseUrl' => '/custom-base-url/',
'data' => [
'foo' => 'bar'
]
]
];
$customFilters = [
['slug', '==', 'foo'], // will render page if its slug is exactly 'foo'
['url', '!*=', 'bar'], // will render page if its url doesn't contain 'bar'
['uri', '*', '/[1-9]/'], // will render page if its uri match regex '/[1-9]/'
['depth', '>', '2'], // will render page if its depth is greater than 2
['category', 'bar'], // will render page if its value in 'category' field is 'bar' ('category' being a single value field)
['tags', 'bar', ','], // will render page if its value in 'tags' field
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.