2024-01-26 08:15:06 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
function clean {
|
2024-07-30 22:36:26 +00:00
|
|
|
rm -fr output_*/ source/build/
|
2024-01-26 08:15:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Create a new daily email.
|
|
|
|
function create-daily {
|
|
|
|
local date="${1}"
|
|
|
|
local title="${2}"
|
|
|
|
|
|
|
|
if [ "${date}" == "next" ]; then
|
|
|
|
next_date=$(ls -1 source/_daily_emails | tail -n 1 | tr -d '.md' | xargs -I {} date +%Y-%m-%d -d '{} +1 day')
|
|
|
|
else
|
|
|
|
next_date="${date}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
filepath="source/_daily_emails/${next_date}.md"
|
|
|
|
|
|
|
|
shift 1
|
|
|
|
|
|
|
|
# Generate the title and slug.
|
|
|
|
title="${*}"
|
|
|
|
slug=$(echo "${title}" | \
|
|
|
|
tr '[:upper:]' '[:lower:]' | \
|
|
|
|
sed 's/[^a-z0-9]/-/g' | \
|
|
|
|
sed 's/\-\-+/-/g' | \
|
|
|
|
sed 's/^\-//;s/\-$//')
|
|
|
|
|
|
|
|
# Create the file.
|
2024-07-30 23:47:49 +00:00
|
|
|
cp -f --no-clobber resources/daily-email-stub.md "${filepath}"
|
2024-01-26 08:15:06 +00:00
|
|
|
|
|
|
|
date=$(date -d "${next_date}" +%Y-%m-%d)
|
|
|
|
day=$(date -d "${next_date}" +%d)
|
|
|
|
month=$(date -d "${next_date}" +%m)
|
|
|
|
year=$(date -d "${next_date}" +%Y)
|
|
|
|
|
|
|
|
# Replace the placeholders.
|
|
|
|
sed -i "s/{{ date }}/${date}/" "${filepath}"
|
|
|
|
sed -i "s/{{ title }}/${title}/" "${filepath}"
|
2024-05-21 21:40:37 +00:00
|
|
|
sed -i "s#{{ permalink }}#daily/${year}/${month}/${day}/${slug}#" "${filepath}"
|
2024-01-26 08:15:06 +00:00
|
|
|
|
|
|
|
# Create a commit with the appropriate date in the message
|
|
|
|
git add "${filepath}"
|
|
|
|
git commit --quiet -m "Add daily email for ${date}
|
|
|
|
|
|
|
|
${title}"
|
|
|
|
|
2024-04-24 21:47:40 +00:00
|
|
|
echo "${filepath}"
|
2024-01-26 08:15:06 +00:00
|
|
|
}
|
|
|
|
|
2024-07-30 23:48:47 +00:00
|
|
|
# Build CSS assets, this is meant to be run within the `assets` directory.
|
2024-01-26 08:15:06 +00:00
|
|
|
function npm:build:css {
|
|
|
|
local args=()
|
|
|
|
|
|
|
|
if [[ "${NODE_ENV:-}" == "production" ]]; then
|
|
|
|
args=(--minify)
|
|
|
|
else
|
|
|
|
args=(--watch)
|
|
|
|
fi
|
|
|
|
|
2024-07-30 19:19:27 +00:00
|
|
|
tailwindcss \
|
|
|
|
--config tailwind.config.ts \
|
|
|
|
--output ../source/build/tailwind.css "${args[@]}"
|
2024-01-26 08:15:06 +00:00
|
|
|
}
|
|
|
|
|
2024-08-20 08:46:12 +00:00
|
|
|
function setup {
|
|
|
|
git submodule update --recursive --init
|
|
|
|
git submodule update --recursive --remote || true
|
|
|
|
|
|
|
|
composer install
|
|
|
|
(cd assets && pnpm install)
|
|
|
|
|
|
|
|
(cd assets && NODE_ENV=production npm:build:css)
|
|
|
|
APP_ENV=prod generate
|
|
|
|
}
|
|
|
|
|
2024-01-26 08:15:06 +00:00
|
|
|
function publish {
|
2024-03-22 15:17:09 +00:00
|
|
|
git push
|
2024-08-18 16:44:00 +00:00
|
|
|
|
2024-08-18 11:09:39 +00:00
|
|
|
tag-release
|
|
|
|
git push --tags
|
2024-02-17 08:56:50 +00:00
|
|
|
|
2024-01-26 08:15:06 +00:00
|
|
|
git stash
|
|
|
|
clean
|
2024-08-18 11:09:39 +00:00
|
|
|
|
2024-08-18 16:44:00 +00:00
|
|
|
# Copy cached files, such as generated CSS files.
|
|
|
|
cp -r cache/* source
|
|
|
|
|
|
|
|
# export NODE_ENV=production
|
|
|
|
# (cd assets && npm:build:css)
|
|
|
|
APP_ENV=prod generate
|
2024-01-26 08:15:06 +00:00
|
|
|
|
2024-06-16 23:33:38 +00:00
|
|
|
rsync --archive --verbose --compress --update --delete \
|
2024-07-31 11:46:06 +00:00
|
|
|
output_prod/ ssh.oliverdavies.uk:/var/www/vhosts/www.oliverdavies.uk
|
2024-01-26 08:15:06 +00:00
|
|
|
|
|
|
|
git stash pop
|
|
|
|
}
|
|
|
|
|
2024-05-03 14:21:56 +00:00
|
|
|
function test {
|
2024-07-30 19:26:39 +00:00
|
|
|
phpunit "${@}"
|
2024-05-03 14:21:56 +00:00
|
|
|
}
|
|
|
|
|
2024-01-26 08:15:06 +00:00
|
|
|
# vim: ft=bash
|