SpectaQL's theming system is a powerful way to tweak or augment the default theme as much or as little as you like. If you want to just modify some things, you can do that. Or if you want to completely change any or all aspects of SpectaQL's output, you can do that, too.
- Building a SpectaQL theme tutorial - A step-by-step blog post building a SpectaQL theme.
spectaql-dark-theme
- An example dark theme based on the default SpectaQL theme.spectaql-theme-example
- An example node project using SpectaQL andspectaql-dark-theme
Any custom theme that you use will be "overlaid" on top of SpectaQL's default theme directory and structure. This means that your theme gets all the templates, javascripts, CSS and helpers included in the default theme "for free".
Any files that your theme includes will be added on top of the default theme's structure. This means you can:
- Override existing files to modify their behavior
- Include new files to be considered or included during the build process
- Both!
The "theme" system works on a directory structure convention. Here's how that structure looks:
your-theme-dir/
├── javascripts/
│
├── stylesheets/
│ └── main.scss
│
├── views/
│ ├── partials/
│ ├── main.hbs
│ └── embedded.hbs
│
├── helpers/
│
└── data/
└── index.js
Let's discuss each directory:
Any files you add to this folder will be concatenated and then minified into the spectaql.min.js
file of your build's target directory along with the default files.
If you want to simply add an additional JS file to your build, this is your way. Just add it to this folder in your theme directory. You can also replace/overwrite any of SpectaQL's default javascript files.
Any .css
files that you add to this folder will be concatenated and minified into the spectaql.min.css
file of your build's target directory along with the default CSS.
SpectaQL supports SCSS, and the default CSS is built by processing main.scss
in the default theme's stylesheets/
directory. If your theme provides a main.scss
file, it will completely replace the default theme and be used to direct the SCSS -> CSS build. You can then import other .scss
files from your own custom main.scss
file.
An example or replacing the whole theme:
// mytheme/stylesheets/main.scss
// This will replace the default theme
// You can (but don't have to!) import structural styles from base and
// syntax highlighting from the spectaql default theme
@import 'base';
@import 'syntax-highlighting';
#spectaql {
// Your custom styles here!
}
If you do not want to replace the default theme, provide a custom.scss
instead of main.scss
in your stylesheets
dir. The custom.scss
file allows you to override the default theme's variables and styles without completely replacing the default theme. See custom.scss
for a full list of variables you can replace.
// mytheme/stylesheets/custom.scss
// This can override variables and styles in the default theme
// Variable overrides
$background: #222222;
$text-color: white;
#spectaql {
// Your style overrides here!
}
You can override syntax highlighting styles by specifying a syntax-highlighting.scss
file. You can use any syntax theme from Highlight.js. Check out theme demos then grab the theme styles of your choice.
SpectaQL uses Handlebars as its templating engine - please read up on their docs if you'd like to alter this area. Any .hbs
files that you add to this folder will be overlaid on top of the default theme's directory.
SpectaQL will look for the the main.hbs
file in the resulting views
directory as the entry point for Handlebars. If your theme provides a main.hbs
file, that will overwrite the default one and be used to direct the HBS -> HTML build.
If you only want to tweak and/or add certain partials, you can do so by only including those customized or additional files in your theme. They will be overlaid on top of the default theme directory in a supplemental manner.
SpectaQL also supports running a theme in "embeddable" mode to produce output that can be embedded into an existing HTML page. In "embeddable" mode, the embedded.hbs
file will be used as the entry point for Handlebars. Depending on the changes you've made, if you want your theme to support "embeddable" mode properly you may need to customize the embedded.hbs
file in your theme.
Handlebars allows for Javascript "helpers" to be used throughout its templates. These helpers must exist in the helpers/
directory.
All of SpectaQL's default theme helpers will be available to any custom theme "for free".
If you'd like to add more helpers or overwrite an existing helper, simply put your JS file(s) into this folder and they will be copied on top of the default theme's directory and will be available for use in your templates.
NOTE: This is an experimental API and it could change in a breaking manner at any time before "major" release. Use at your own risk!
By default, SpectaQL will use all the non-hidden data that your GraphQL schema has provided, and arrange it in an sane, but opinionated default manner. It will group Queries
and Mutations
under an Operations
header, then it will display all regular Types
, and finally it will display all Subscriptions
. You can see the default arranger source for more on how the default is done.
However, if you'd like to completely customize the data that's displayed, and have some basic control over how it's displayed, you can provide a "dynamic data arranger" module. Here's how:
- Create your dynamic data arranger module. It should export a function that expects the same arguments that are provided in the example dynamic data arranger
- Save it to
data/index.js
in your theme directory.
NOTE: Again, this is an experimental API and it could change in a breaking manner at any time before "major" release. Use at your own risk!