Ghost/ghost/zip/test/fixtures/test-theme
juan-g 11e9904ff3 Theme translations and blog localisation (#8437)
refs #5345, refs #3801

- Blog localisation
  - default is `en` (English)
  - you can change the language code in the admin panel, see https://github.com/TryGhost/Ghost-Admin/pull/703
  - blog behaviour changes depending on the language e.g. date helper format
  - theme translation get's loaded if available depending on the language setting
  - falls back to english if not available

- Theme translation
  - complete automatic translation of Ghost's frontend for site visitors (themes, etc.), to quickly deploy a site in a non-English language
  - added {{t}} and {{lang}} helper
  - no backend or admin panel translations (!)
  - easily readable translation keys - very simple translation
  - server restart required when adding new language files or changing existing files in the theme
  - no language code validation for now (will be added soon)
  - a full theme translation requires to translate Ghost core templates (e.g. subscriber form)
  - when activating a different theme, theme translations are auto re-loaded
  - when switching language of blog, theme translations are auto re-loaded

- Bump gscan to version 1.3.0 to support more known helpers

**Documentation can be found at https://themes.ghost.org/v1.20.0/docs/i18n.**
2018-01-09 14:50:57 +01:00
..
assets/css Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
locales Theme translations and blog localisation (#8437) 2018-01-09 14:50:57 +01:00
partials Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
author.hbs Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
default.hbs Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
error-404.hbs Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
error.hbs Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
index.hbs Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
package.json Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
page.hbs Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
post.hbs Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00
README.md 2018 2018-01-02 21:44:41 +00:00
tag.hbs Tests: Sort out usage of content folder in tests (#9034) 2017-09-21 15:05:35 +01:00

Casper

The default theme for Ghost. This is the latest development version of Casper. If you're just looking to download the latest release, head over to the releases page.

 

screenshot-desktop

 

First time using a Ghost theme?

Ghost uses a simple templating language called Handlebars for its themes.

We've documented our default theme pretty heavily so that it should be fairly easy to work out what's going on just by reading the code and the comments. Once you feel comfortable with how everything works, we also have full theme API documentation which explains every possible Handlebars helper and template.

The main files are:

  • default.hbs - The main template file
  • index.hbs - Used for the home page
  • post.hbs - Used for individual posts
  • page.hbs - Used for individual pages
  • tag.hbs - Used for tag archives
  • author.hbs - Used for author archives

One really neat trick is that you can also create custom one-off templates just by adding the slug of a page to a template file. For example:

  • page-about.hbs - Custom template for the /about/ page
  • tag-news.hbs - Custom template for /tag/news/ archive
  • author-ali.hbs - Custom template for /author/ali/ archive

Development

Casper styles are compiled using Gulp/PostCSS to polyfill future CSS spec. You'll need Node and Gulp installed globally. After that, from the theme's root directory:

$ npm install

$ gulp

Now you can edit /assets/css/ files, which will be compiled to /assets/built/ automatically.

PostCSS Features Used

  • Autoprefixer - Don't worry about writing browser prefixes of any kind, it's all done automatically with support for the latest 2 major versions of every browser.
  • Variables - Simple pure CSS variables
  • Color Function

SVG Icons

Casper uses inline SVG icons, included via Handlebars partials. You can find all icons inside /partials/icons. To use an icon just include the name of the relevant file, eg. To include the SVG icon in /partials/icons/rss.hbs - use {{> "icons/rss"}}.

You can add your own SVG icons in the same manner.

Copyright & License

Copyright (c) 2013-2018 Ghost Foundation - Released under the MIT license.