emrl/site-template

There is no license information available for the latest version (4.0.0) of this package.

4.0.0 2022-05-12 18:09 UTC

README

Initial setup

Copy .env.example to .env.

Set a variable for your development hostname/domain (ie: mysite.test):

$ TLD=mysite.test

Replace site-template.test with your development domain in .env.

$ sed -i "s/site-template.test/$TLD/g" .env

Install mkcert if you haven't already. Then generate the SSL certificates:

$ mkcert -key-file server.key -cert-file server.crt "$TLD"

Update your local hosts file and add entry for domain

$ echo -e "127.0.0.1 $TLD" | sudo tee -a /etc/hosts

Developing with Docker

Update .env with database variables. Make sure the auth keys and salts are not empty.

DB_HOST=mysql
DB_DATABASE=dev
DB_USERNAME=dev
DB_PASSWORD=dev

First you will need to make sure you have credentials saved for Advanced Custom Fields. If not, you can use the following command (replace ACF_KEY with your actual license key):

$ docker compose run --rm --user application --entrypoint composer php config --global --auth http-basic.connect.advancedcustomfields.com ACF_KEY "https://$TLD"

Install dependencies

$ docker compose run --rm --user application --entrypoint composer php install
$ docker compose run --rm --user node node npm install
$ docker compose run --rm python pip install -r requirements.txt

Start containers:

$ docker compose up

Docker will start the following containers by default:

ContainerPurpose
phpApache & PHP, runs application
mysqlMySQL database
nodeRuns webpack build process on port 8080

Now you can view the site at the domain you specified previously.

ℹ️ The Python container for mkdocs does not start by default. You can run it along with the other containers or independently.

# Start all containers
$ docker compose --profile docs up

# Or independently
$ docker compose up python
ContainerPurpose
pythonRuns mkdocs build process at http://localhost:8000

To allow sending of email, you can start the MailHog container as well.

ℹ️ The MailHog container does not start by default. You can run it along with the other containers or independently.

# Start with all containers
$ docker compose --profile mail up

# Or independently
$ docker compose up mailhog

Running commands through Docker

Example: use Deployer to pull in content from staging site:

# If container is already running
$ docker compose exec --user application php vendor/bin/dep content:pull stage=staging

# If container has stopped
$ docker compose run --rm --user application --entrypoint /app/vendor/bin/dep php content:pull stage=staging

Fluid spacing

See https://utopia.fyi/clamp/calculator for generating CSS clamp() values.

Spacing

Files

Root directory

FileDescription
/.editorconfigEditorConfig
/.env.exampleExample environment variables
/.gitignoreFiles to exclude from Git
/.php-cs-fixer.dist.phpPHP Coding Standards Fixer configuration
/.phpcs.xml.distPHP_Codesniffer configuration
/app.phpApplication bootstrap
/bitbucket-pipelines.ymlBitbucket Pipelines configuration
/composer.jsonComposer configuration
/config.phpWordPress configuration
/deploy.phpDeployer configuration
/docker-compose.ymlDocker Compose configuration
/mkdocs.ymlMkDocs configuration
/package.jsonnpm configuration
/phpunit.xml.distPHPUnit configuration
/requirements.txtpip configuration, for docs
/webpack.config.jswebpack configuration
/wp-cli.ymlWP-CLI configuration

Config directory

The /config/ directory contains any configuration files.

Docs directory

The /docs/ directory holds documentation source files that are eventually built into the /public/kb/ directory.

Public directory

The /public/ directory is the server's document root.

FileDescription
/public/c/WordPress content directory
/public/w/WordPress core, installed by Composer
/public/.htaccessApache server configuration
/public/index.phpEntry point
/public/manifest.webmanifestManifest file
/public/wp-config.phpWordPress configuration file. This simply includes config.php

Resources directory

Source files for scripts, styles, images, icons, and other media. Files are packaged by webpack and output to /public/c/dist/.

Kb directory

The /public/kb/ directory serves the Knowledge Base. It is created by MkDocs and the result of building the source files in the /docs/ directory.

Plugins directory

The /public/c/plugins/ directory stores plugins. Since Composer can manage all plugins in the WordPress Plugin Repository, all files in this directory are ignored by Git.

If a commercial plugin is to be used, it will need to be unignored in the /.gitignore file.

Mu-plugins directory

The /public/c/mu-plugins/ directory stores Must Use Plugins.

FileDescription
/public/c/mu-plugins/advanced-custom-fields-pro.phpLoads Advanced Custom Fields plugin
/public/c/mu-plugins/commands.phpRegisters WP-CLI commands
/public/c/mu-plugins/error-reporting.phpTurns off error reporting for deprecation errors coming from WordPress core or plugins
/public/c/mu-plugins/register-theme-directory.phpRegisters custom theme directory, along with WordPress' default theme directory

Src directory

The /src/ directory contains custom functionality for the site (post types, theme setup, etc).

Tests directory

The /tests/ directory contains PHP unit tests.

Theme directory

The /theme/ directory acts as the WordPress theme.