import { moduleForWidget, widgetTest } from 'helpers/widget-test';
import { createWidget } from 'discourse/widgets/widget';
import { withPluginApi } from 'discourse/lib/plugin-api';
import hbs from 'discourse/widgets/hbs-compiler';
moduleForWidget('base');
widgetTest('widget attributes are passed in via args', {
template: `{{mount-widget widget="hello-test" args=args}}`,
beforeEach() {
createWidget('hello-test', {
tagName: 'div.test',
template: hbs`Hello {{attrs.name}}`
});
this.set('args', { name: 'Robin' });
},
test(assert) {
assert.equal(this.$('.test').text(), "Hello Robin");
}
});
widgetTest("hbs template - no tagName", {
template: `{{mount-widget widget="hbs-test" args=args}}`,
beforeEach() {
createWidget('hbs-test', {
template: hbs`
Hello {{attrs.name}}
`
});
this.set('args', { name: 'Robin' });
},
test(assert) {
assert.equal(this.$('div.test').text(), "Hello Robin");
}
});
widgetTest("hbs template - with tagName", {
template: `{{mount-widget widget="hbs-test" args=args}}`,
beforeEach() {
createWidget('hbs-test', {
tagName: 'div.test',
template: hbs`Hello {{attrs.name}}`
});
this.set('args', { name: 'Robin' });
},
test(assert) {
assert.equal(this.$('div.test').text(), "Hello Robin");
}
});
widgetTest('buildClasses', {
template: `{{mount-widget widget="classname-test" args=args}}`,
beforeEach() {
createWidget('classname-test', {
tagName: 'div.test',
buildClasses(attrs) {
return ['static', attrs.dynamic];
}
});
this.set('args', { dynamic: 'cool-class' });
},
test(assert) {
assert.ok(this.$('.test.static.cool-class').length, 'it has all the classes');
}
});
widgetTest('buildAttributes', {
template: `{{mount-widget widget="attributes-test" args=args}}`,
beforeEach() {
createWidget('attributes-test', {
tagName: 'div.test',
buildAttributes(attrs) {
return { "data-evil": 'trout', "aria-label": attrs.label };
}
});
this.set('args', { label: 'accessibility' });
},
test(assert) {
assert.ok(this.$('.test[data-evil=trout]').length);
assert.ok(this.$('.test[aria-label=accessibility]').length);
}
});
widgetTest('buildId', {
template: `{{mount-widget widget="id-test" args=args}}`,
beforeEach() {
createWidget('id-test', {
buildId(attrs) {
return `test-${attrs.id}`;
}
});
this.set('args', { id: 1234 });
},
test(assert) {
assert.ok(this.$('#test-1234').length);
}
});
widgetTest('widget state', {
template: `{{mount-widget widget="state-test"}}`,
beforeEach() {
createWidget('state-test', {
tagName: 'button.test',
buildKey: () => `button-test`,
template: hbs`{{state.clicks}} clicks`,
defaultState() {
return { clicks: 0 };
},
click() {
this.state.clicks++;
}
});
},
test(assert) {
assert.ok(this.$('button.test').length, 'it renders the button');
assert.equal(this.$('button.test').text(), "0 clicks");
click(this.$('button'));
andThen(() => {
assert.equal(this.$('button.test').text(), "1 clicks");
});
}
});
widgetTest('widget update with promise', {
template: `{{mount-widget widget="promise-test"}}`,
beforeEach() {
createWidget('promise-test', {
tagName: 'button.test',
buildKey: () => 'promise-test',
template: hbs`
{{#if state.name}}
{{state.name}}
{{else}}
No name
{{/if}}
`,
click() {
return new Ember.RSVP.Promise(resolve => {
Ember.run.next(() => {
this.state.name = "Robin";
resolve();
});
});
}
});
},
test(assert) {
assert.equal(this.$('button.test').text().trim(), "No name");
click(this.$('button'));
andThen(() => {
assert.equal(this.$('button.test').text().trim(), "Robin");
});
}
});
widgetTest('widget attaching', {
template: `{{mount-widget widget="attach-test"}}`,
beforeEach() {
createWidget('test-embedded', { tagName: 'div.embedded' });
createWidget('attach-test', {
tagName: 'div.container',
template: hbs`{{attach widget="test-embedded"}}`
});
},
test(assert) {
assert.ok(this.$('.container').length, "renders container");
assert.ok(this.$('.container .embedded').length, "renders attached");
}
});
widgetTest("handlebars fa-icon", {
template: `{{mount-widget widget="hbs-icon-test" args=args}}`,
beforeEach() {
createWidget('hbs-icon-test', {
template: hbs`{{fa-icon "arrow-down"}}`
});
},
test(assert) {
assert.equal(this.$('i.fa.fa-arrow-down').length, 1);
}
});
widgetTest("handlebars i18n", {
template: `{{mount-widget widget="hbs-i18n-test" args=args}}`,
beforeEach() {
createWidget('hbs-i18n-test', {
template: hbs`
{{i18n "hbs_test0"}}
{{i18n attrs.key}}
test
`
});
I18n.extras = [ {
"hbs_test0": "evil",
"hbs_test1": "trout"
} ];
this.set('args', { key: 'hbs_test1' });
},
test(assert) {
// comin up
assert.equal(this.$('span.string').text(), 'evil');
assert.equal(this.$('span.var').text(), 'trout');
assert.equal(this.$('a').prop('title'), 'evil');
}
});
widgetTest('handlebars #each', {
template: `{{mount-widget widget="hbs-each-test" args=args}}`,
beforeEach() {
createWidget('hbs-each-test', {
tagName: 'ul',
template: hbs`
{{#each attrs.items as |item|}}
{{item}}
{{/each}}
`
});
this.set('args', {
items: ['one', 'two', 'three']
});
},
test(assert) {
assert.equal(this.$('ul li').length, 3);
assert.equal(this.$('ul li:eq(0)').text(), "one");
}
});
widgetTest('widget decorating', {
template: `{{mount-widget widget="decorate-test"}}`,
beforeEach() {
createWidget('decorate-test', {
tagName: 'div.decorate',
template: hbs`main content`
});
withPluginApi('0.1', api => {
api.decorateWidget('decorate-test:before', dec => {
return dec.h('b', 'before');
});
api.decorateWidget('decorate-test:after', dec => {
return dec.h('i', 'after');
});
});
},
test(assert) {
assert.ok(this.$('.decorate').length);
assert.equal(this.$('.decorate b').text(), 'before');
assert.equal(this.$('.decorate i').text(), 'after');
}
});
widgetTest('widget settings', {
template: `{{mount-widget widget="settings-test"}}`,
beforeEach() {
createWidget('settings-test', {
tagName: 'div.settings',
template: hbs`age is {{settings.age}}`,
settings: { age: 36 }
});
},
test(assert) {
assert.equal(this.$('.settings').text(), 'age is 36');
}
});
widgetTest('override settings', {
template: `{{mount-widget widget="ov-settings-test"}}`,
beforeEach() {
createWidget('ov-settings-test', {
tagName: 'div.settings',
template: hbs`age is {{settings.age}}`,
settings: { age: 36 },
});
withPluginApi('0.1', api => {
api.changeWidgetSetting('ov-settings-test', 'age', 37);
});
},
test(assert) {
assert.equal(this.$('.settings').text(), 'age is 37');
}
});