use vue components with the shopware statemanager
Requires Vue, jQuery and Shopware JS environment.
vueify(<Component>) : <Shopware-jQuery-Plugin>
$.plugin('myComponent', vueify({
template: `
<div>
<i>Hello, {{ who }}!</i>
<button @click="toggleWho">toggle</button>
</div>
`,
data() {
return { who: 'world' };
},
methods: {
toggleWho(e) {
this.who = this.who === 'world' ? 'there' : 'world';
}
}
}));
StateManager.addPlugin('[data-my-component="true"]', 'myComponent', ['l', 'xl']);
Can be require
d. If not, vueify
is available globally.
Can be used with vue-files:
const MyComponent = require('components/my-component.vue');
$.plugin('myComponent', vueify(MyComponent));
Vueify has support for options, which get passed to vue as properties. Including support for shopware inline-option style.
$.plugin('myComponent', vueify({
props: {
value: Number,
additional: String
},
template: '<div>{{ value }}</div>'
}));
StateManager.addPlugin('[data-my-component="true"]', 'myComponent', { additional: 'Foobar' });
<div data-my-component="true" data-value="135"></div>
$.override
is supported. Vueify makes the parent-component available to developers as supercomponent
.
$.plugin('myComponent', vueify({
template: `
<div>
{{ message }}
<a @click.prevent="triggerPonies">click me</a>
</div>
`,
data() {
return { message: 'initial message' };
},
methods: {
triggerPonies() {
this.message = 'component message';
alert('hurray! message is: ' + this.message);
}
}
}));
// no vueify here
$.overridePlugin('myComponent', {
methods: {
triggerPonies() {
this.supercomponent.methods.triggerPonies.call(this);
this.message = 'child message';
}
}
});
$.overridePlugin
works as you expect it. You can override any property with it, including props
and template
.
To access the Vue-instance externally you need to get hold of the plugin-data first.
const plugin = $('.element').data('plugin_myComponent');
const vm = plugin.vm;
And vice versa:
$.plugin('myComponent', vueify({
methods: {
enableCake() {
const plugin = this.$options.$plugin;
const $el = plugin.$el;
}
}
}));
Remember init()
and destroy()
? Yeah, screw those. now we've got a better lifecycle.
You may use any Lifecycle Events Vue offers you.
Once a Vueified™ plugin gets added to an element, the $el
s content will get replaced by the vue-component.
When that plugin then gets destroyed, the original content will get re-added and the vue-component disappears.
$.plugin('myComponent', vueify({
template: '<div>Hello, world!</div>'
}));
StateManager.addPlugin('[data-my-component="true"]', 'myComponent', ['xl']);
<div data-my-component="true">
<b>original content</b>
</div>
When viewport equals xl:
<div data-my-component="true">
<div>Hello, world!</div>
</div>
When viewport equals anything but xl:
<div data-my-component="true">
<b>original content</b>
</div>
When using slots you will need to use the standalone vue-build.
- Improve README
- Fix webpack requiring $.PluginBase
- Initial Release