framework/js/lib/component.js

65 lines
1.1 KiB
JavaScript
Raw Normal View History

2015-04-25 20:58:39 +08:00
/**
*/
export default class Component {
/**
*/
constructor(props) {
this.props = props || {};
this.element = m.prop();
}
/**
*/
$(selector) {
return selector ? $(this.element()).find(selector) : $(this.element());
}
onload(element) {
this.element(element);
}
config() {
}
2015-04-25 20:58:39 +08:00
/**
*/
static component(props) {
props = props || {};
2015-05-02 07:15:11 +08:00
if (this.props) {
props = this.props(props);
}
2015-04-25 20:58:39 +08:00
var view = function(component) {
component.props = props;
var vdom = component.view();
vdom.attrs = vdom.attrs || {};
if (!vdom.attrs.config) {
vdom.attrs.config = function() {
var args = [].slice.apply(arguments);
if (!args[1]) {
component.onload.apply(component, args);
}
component.config.apply(component, args);
}
}
return vdom;
2015-04-25 20:58:39 +08:00
};
view.$original = this.prototype.view;
var output = {
props: props,
component: this,
controller: this.bind(undefined, props),
view: view
};
if (props.key) {
output.attrs = {key: props.key};
}
return output;
}
}