mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-03 08:25:06 +03:00
24df9781cc
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
88 lines
2.5 KiB
JavaScript
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');
|
|
});
|
|
});
|