Ghost/ghost/admin/tests/integration/components/gh-psm-template-select-test.js
Kevin Ansfield 24df9781cc Custom Post Templates UI (#878)
refs https://github.com/TryGhost/Ghost/issues/9060

- add `{{gh-psm-template-select}}` component
  - allows selection of a custom template for a post if the active theme has custom templates
  - loads themes on render, only hitting the server if not already in the store
  - disables select if post slug matches a `post-*.hbs` or `page-*.hbs` template
- adds `customTemplate` attr to `Post` model
- adds `templates` attr to `Theme` model with CPs to pull out custom vs post/page override templates
- add `.gh-select.disabled` styles to make disabled selects look visually disabled
2017-10-10 14:26:19 +02:00

88 lines
2.5 KiB
JavaScript

import hbs from 'htmlbars-inline-precompile';
import mockThemes from '../../../mirage/config/themes';
import wait from 'ember-test-helpers/wait';
import {describe, it} from 'mocha';
import {expect} from 'chai';
import {find} from 'ember-native-dom-helpers';
import {setupComponentTest} from 'ember-mocha';
import {startMirage} from 'ghost-admin/initializers/ember-cli-mirage';
describe('Integration: Component: gh-psm-template-select', function() {
setupComponentTest('gh-psm-template-select', {
integration: true
});
let server;
beforeEach(function () {
server = startMirage();
server.create('theme', {
active: true,
name: 'example-theme',
package: {
name: 'Example Theme',
version: '0.1'
},
templates: [
{
filename: 'custom-news-bulletin.hbs',
name: 'News Bulletin',
for: ['post', 'page'],
slug: null
},
{
filename: 'custom-big-images.hbs',
name: 'Big Images',
for: ['post', 'page'],
slug: null
},
{
filename: 'post-one.hbs',
name: 'One',
for: ['post'],
slug: 'one'
},
{
filename: 'page-about.hbs',
name: 'About',
for: ['page'],
slug: 'about'
}
]
});
mockThemes(server);
});
afterEach(function () {
server.shutdown();
});
it('disables template selector if slug matches post template', async function () {
this.set('post', {
slug: 'one',
page: false
});
this.render(hbs`{{gh-psm-template-select post=post}}`);
await wait();
expect(find('select').disabled, 'select is disabled').to.be.true;
expect(find('p').textContent).to.have.string('post-one.hbs');
});
it('disables template selector if slug matches page template', async function () {
this.set('post', {
slug: 'about',
page: true
});
this.render(hbs`{{gh-psm-template-select post=post}}`);
await wait();
expect(find('select').disabled, 'select is disabled').to.be.true;
expect(find('p').textContent).to.have.string('page-about.hbs');
});
});