Vue-Socket.io/src/Main.js
2018-03-15 19:20:30 -04:00

55 lines
1.6 KiB
JavaScript
Executable file

import Observer from './Observer'
import Emitter from './Emitter'
export default {
install(Vue, connection, store){
if(!connection) throw new Error("[Vue-Socket.io] cannot locate connection")
let observer = new Observer(connection, store)
Vue.prototype.$socket = observer.Socket;
Vue.mixin({
created(){
let sockets = this.$options['sockets']
// define on and off as non-enumerable properties
Object.defineProperty(this.$options.sockets, 'on', {
value: (label, callback) => {
Emitter.addListener(label, callback, this);
this.$options.sockets[label] = callback;
}
});
Object.defineProperty(this.$options.sockets, 'off', {
value: (label, callback) => {
Emitter.removeListener(label, callback, this);
delete this.$options.sockets[label];
}
});
if(sockets){
Object.keys(sockets).forEach((key) => {
Emitter.addListener(key, sockets[key], this);
});
}
},
beforeDestroy(){
let sockets = this.$options['sockets']
if(sockets){
Object.keys(sockets).forEach((key) => {
Emitter.removeListener(key, sockets[key], this);
delete this.$options.sockets[key];
});
}
}
})
}
}