All Posts programming How to show posts of my kmt theme on demo but not on others' websites

How to show posts of my kmt theme on demo but not on others' websites

ยท 353 words ยท 2 minute read

I want to create documentation and tutorials about my Hugo theme KMT, but I want to simplify my setup by adding them inside the theme itself. But if I added the posts in kmt theme, they’ll show up on all websites that use the Kmt theme!

Another project for demo ๐Ÿ”—

I can use another instance/project that uses kmt theme, and add posts in it, and deploy it as the kmt theme demo. But.. but this is more complicated.. I think.

Published drafts (read the update below) ๐Ÿ”—

There is a simpler strategy I used. Just let the deployed version of my kmt theme demo include draft posts. Here are the steps.

All posts of the kmt theme demo are drafts ๐Ÿ”—

I just made all posts as drafts in each post frontmatter.

title = 'some title'
date = 2024-01-15T20:49:30+02:00
- draft = false
+ draft = false

Include draft posts in the generated website before deployment ๐Ÿ”—

I use Netlify to demo my kmt theme, so I just need to include -D argument in all Hugo commands in netlify.toml like this.

[build]
    publish = "public"
-    command = "hugo --gc --minify"
+    command = "hugo -D --gc --minify"

[context.production.environment]
    HUGO_VERSION = "0.120.4"
    HUGO_ENV = "production"
    HUGO_ENABLEGITINFO = "true"

[context.split1]
-    command = "hugo --gc --minify --enableGitInfo"
+    command = "hugo -D --gc --minify --enableGitInfo"

[context.split1.environment]
    HUGO_VERSION = "0.120.4"
    HUGO_ENV = "production"

[context.deploy-preview]
-    command = "hugo --gc --minify --buildFuture -b $DEPLOY_PRIME_URL"
+    command = "hugo -D --gc --minify --buildFuture -b $DEPLOY_PRIME_URL"

[context.deploy-preview.environment]
    HUGO_VERSION = "0.120.4"

[context.branch-deploy]
-    command = "hugo --gc --minify -b $DEPLOY_PRIME_URL"
+    command = "hugo -D --gc --minify -b $DEPLOY_PRIME_URL"

[context.branch-deploy.environment]
    HUGO_VERSION = "0.120.4"

[context.next.environment]
    HUGO_ENABLEGITINFO = "true"

If you are using another hosting service such as cloudflare pages or github pages, set the deploy command to include -D argument and you’ll be fine.

Update : 24 Jan 2024 ๐Ÿ”—

I decided to use a separated project as a demo. But it will not be a new project. I will use my own website https://AbanoubHanna.com as the demo of the theme and I will publish the documentation there too.

Translations:  ุงู„ุนุฑุจูŠุฉ (ูƒูŠู ุชุธู‡ุฑ ุงู„ู…ู‚ุงู„ุงุช ุงู„ุฎุงุตุฉ ุจู€ ุซูŠู… ู‡ูˆุฌูˆ ููŠ ู…ูˆู‚ุน ุงู„ุซูŠู… ุฏูˆู† ุฃู† ุชุธู‡ุฑ ู‡ุฐู‡ ุงู„ู…ู‚ุงู„ุงุช ููŠ ุงู„ู…ูˆุงู‚ุน ุงู„ุชูŠ ุชุณุชุฎุฏู… ุงู„ุซูŠู… ุŸ)