516 lines
14 KiB
JavaScript
516 lines
14 KiB
JavaScript
// Generated by CoffeeScript 1.6.1
|
|
(function() {
|
|
var $el, Mini, WSF_AUTOCOMPLETE_CONTROL, WSF_BUTTON_CONTROL, WSF_CHECKBOX_CONTROL, WSF_CHECKBOX_LIST_CONTROL, WSF_CONTROL, WSF_FORM_ELEMENT_CONTROL, WSF_HTML_CONTROL, WSF_INPUT_CONTROL, WSF_MAX_VALIDATOR, WSF_MIN_VALIDATOR, WSF_PROGRESS_CONTROL, WSF_REGEXP_VALIDATOR, WSF_TEXTAREA_CONTROL, WSF_VALIDATOR, cache, controls, name, state, template, tmpl, trigger_callback, type, typemap, validatormap, _ref, _ref1, _ref2,
|
|
__hasProp = {}.hasOwnProperty,
|
|
__extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; };
|
|
|
|
cache = {};
|
|
|
|
template = tmpl = function(str, data) {
|
|
var fn;
|
|
fn = (!/\W/.test(str) ? cache[str] = cache[str] || tmpl(str) : new Function("obj", "var p=[],print=function(){p.push.apply(p,arguments);};" + "with(obj){p.push('" + str.replace(/[\r\t\n]/g, " ").split("{{").join("\t").replace(/((^|}})[^\t]*)'/g, "$1\r").replace(/\t=(.*?)}}/g, "',$1,'").split("\t").join("');").split("}}").join("p.push('").split("\r").join("\\'") + "');}return p.join('');"));
|
|
if (data) {
|
|
return fn(data);
|
|
} else {
|
|
return fn;
|
|
}
|
|
};
|
|
|
|
Mini = {
|
|
compile: function(t) {
|
|
return {
|
|
render: template(t)
|
|
};
|
|
}
|
|
};
|
|
|
|
trigger_callback = function(control_name, event) {
|
|
return $.ajax({
|
|
data: {
|
|
control_name: control_name,
|
|
event: event,
|
|
states: JSON.stringify(window.states)
|
|
},
|
|
cache: false
|
|
}).done(function(new_states) {
|
|
var name, state, _ref;
|
|
for (name in new_states) {
|
|
state = new_states[name];
|
|
if ((_ref = controls[name]) != null) {
|
|
_ref.update(state);
|
|
}
|
|
}
|
|
});
|
|
};
|
|
|
|
WSF_VALIDATOR = (function() {
|
|
|
|
function WSF_VALIDATOR(parent_control, settings) {
|
|
this.parent_control = parent_control;
|
|
this.settings = settings;
|
|
this.error = this.settings.error;
|
|
return;
|
|
}
|
|
|
|
WSF_VALIDATOR.prototype.validate = function() {
|
|
return true;
|
|
};
|
|
|
|
return WSF_VALIDATOR;
|
|
|
|
})();
|
|
|
|
WSF_REGEXP_VALIDATOR = (function(_super) {
|
|
|
|
__extends(WSF_REGEXP_VALIDATOR, _super);
|
|
|
|
function WSF_REGEXP_VALIDATOR() {
|
|
WSF_REGEXP_VALIDATOR.__super__.constructor.apply(this, arguments);
|
|
this.pattern = new RegExp(this.settings.expression, 'g');
|
|
}
|
|
|
|
WSF_REGEXP_VALIDATOR.prototype.validate = function() {
|
|
var res, val;
|
|
val = this.parent_control.value();
|
|
res = val.match(this.pattern);
|
|
return res !== null;
|
|
};
|
|
|
|
return WSF_REGEXP_VALIDATOR;
|
|
|
|
})(WSF_VALIDATOR);
|
|
|
|
WSF_MIN_VALIDATOR = (function(_super) {
|
|
|
|
__extends(WSF_MIN_VALIDATOR, _super);
|
|
|
|
function WSF_MIN_VALIDATOR() {
|
|
return WSF_MIN_VALIDATOR.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_MIN_VALIDATOR.prototype.validate = function() {
|
|
var val;
|
|
val = this.parent_control.value();
|
|
return val.length >= this.settings.min;
|
|
};
|
|
|
|
return WSF_MIN_VALIDATOR;
|
|
|
|
})(WSF_VALIDATOR);
|
|
|
|
WSF_MAX_VALIDATOR = (function(_super) {
|
|
|
|
__extends(WSF_MAX_VALIDATOR, _super);
|
|
|
|
function WSF_MAX_VALIDATOR() {
|
|
return WSF_MAX_VALIDATOR.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_MAX_VALIDATOR.prototype.validate = function() {
|
|
var val;
|
|
val = this.parent_control.value();
|
|
return val.length <= this.settings.max;
|
|
};
|
|
|
|
return WSF_MAX_VALIDATOR;
|
|
|
|
})(WSF_VALIDATOR);
|
|
|
|
validatormap = {
|
|
"WSF_REGEXP_VALIDATOR": WSF_REGEXP_VALIDATOR,
|
|
"WSF_MIN_VALIDATOR": WSF_MIN_VALIDATOR,
|
|
"WSF_MAX_VALIDATOR": WSF_MAX_VALIDATOR
|
|
};
|
|
|
|
WSF_CONTROL = (function() {
|
|
|
|
function WSF_CONTROL(control_name, $el) {
|
|
this.control_name = control_name;
|
|
this.$el = $el;
|
|
return;
|
|
}
|
|
|
|
WSF_CONTROL.prototype.attach_events = function() {};
|
|
|
|
WSF_CONTROL.prototype.update = function(state) {};
|
|
|
|
WSF_CONTROL.prototype.on = function(name, callback, context) {
|
|
if (this._events == null) {
|
|
this._events = {};
|
|
}
|
|
if (this._events[name] == null) {
|
|
this._events[name] = [];
|
|
}
|
|
this._events[name].push({
|
|
callback: callback,
|
|
context: context
|
|
});
|
|
return this;
|
|
};
|
|
|
|
WSF_CONTROL.prototype.trigger = function(name) {
|
|
var ev, _i, _len, _ref, _ref1;
|
|
if (((_ref = this._events) != null ? _ref[name] : void 0) == null) {
|
|
return this;
|
|
}
|
|
_ref1 = this._events[name];
|
|
for (_i = 0, _len = _ref1.length; _i < _len; _i++) {
|
|
ev = _ref1[_i];
|
|
ev.callback.call(ev.context);
|
|
}
|
|
return this;
|
|
};
|
|
|
|
return WSF_CONTROL;
|
|
|
|
})();
|
|
|
|
controls = {};
|
|
|
|
WSF_BUTTON_CONTROL = (function(_super) {
|
|
|
|
__extends(WSF_BUTTON_CONTROL, _super);
|
|
|
|
function WSF_BUTTON_CONTROL() {
|
|
return WSF_BUTTON_CONTROL.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_BUTTON_CONTROL.prototype.attach_events = function() {
|
|
var self;
|
|
self = this;
|
|
return this.$el.click(function(e) {
|
|
e.preventDefault();
|
|
return self.click();
|
|
});
|
|
};
|
|
|
|
WSF_BUTTON_CONTROL.prototype.click = function() {
|
|
if (window.states[this.control_name]['callback_click']) {
|
|
return trigger_callback(this.control_name, 'click');
|
|
}
|
|
};
|
|
|
|
WSF_BUTTON_CONTROL.prototype.update = function(state) {
|
|
if (state.text != null) {
|
|
window.states[this.control_name]['text'] = state.text;
|
|
return this.$el.text(state.text);
|
|
}
|
|
};
|
|
|
|
return WSF_BUTTON_CONTROL;
|
|
|
|
})(WSF_CONTROL);
|
|
|
|
WSF_INPUT_CONTROL = (function(_super) {
|
|
|
|
__extends(WSF_INPUT_CONTROL, _super);
|
|
|
|
function WSF_INPUT_CONTROL() {
|
|
return WSF_INPUT_CONTROL.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_INPUT_CONTROL.prototype.attach_events = function() {
|
|
var self;
|
|
self = this;
|
|
return this.$el.change(function() {
|
|
return self.change();
|
|
});
|
|
};
|
|
|
|
WSF_INPUT_CONTROL.prototype.change = function() {
|
|
window.states[this.control_name]['text'] = this.$el.val();
|
|
if (window.states[this.control_name]['callback_change']) {
|
|
trigger_callback(this.control_name, 'change');
|
|
}
|
|
return this.trigger('change');
|
|
};
|
|
|
|
WSF_INPUT_CONTROL.prototype.value = function() {
|
|
return this.$el.val();
|
|
};
|
|
|
|
WSF_INPUT_CONTROL.prototype.update = function(state) {
|
|
if (state.text != null) {
|
|
window.states[this.control_name]['text'] = state.text;
|
|
return this.$el.val(state.text);
|
|
}
|
|
};
|
|
|
|
return WSF_INPUT_CONTROL;
|
|
|
|
})(WSF_CONTROL);
|
|
|
|
WSF_TEXTAREA_CONTROL = (function(_super) {
|
|
|
|
__extends(WSF_TEXTAREA_CONTROL, _super);
|
|
|
|
function WSF_TEXTAREA_CONTROL() {
|
|
return WSF_TEXTAREA_CONTROL.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
return WSF_TEXTAREA_CONTROL;
|
|
|
|
})(WSF_INPUT_CONTROL);
|
|
|
|
WSF_AUTOCOMPLETE_CONTROL = (function(_super) {
|
|
|
|
__extends(WSF_AUTOCOMPLETE_CONTROL, _super);
|
|
|
|
function WSF_AUTOCOMPLETE_CONTROL() {
|
|
return WSF_AUTOCOMPLETE_CONTROL.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_AUTOCOMPLETE_CONTROL.prototype.attach_events = function() {
|
|
var self;
|
|
WSF_AUTOCOMPLETE_CONTROL.__super__.attach_events.apply(this, arguments);
|
|
self = this;
|
|
return this.$el.typeahead({
|
|
name: this.control_name,
|
|
template: window.states[this.control_name]['template'],
|
|
engine: Mini,
|
|
remote: {
|
|
url: "",
|
|
replace: function(url, uriEncodedQuery) {
|
|
window.states[self.control_name]['text'] = self.$el.val();
|
|
return '?' + $.param({
|
|
control_name: self.control_name,
|
|
event: 'autocomplete',
|
|
states: JSON.stringify(window.states)
|
|
});
|
|
},
|
|
filter: function(parsedResponse) {
|
|
return parsedResponse[self.control_name]['suggestions'];
|
|
}
|
|
}
|
|
});
|
|
};
|
|
|
|
return WSF_AUTOCOMPLETE_CONTROL;
|
|
|
|
})(WSF_INPUT_CONTROL);
|
|
|
|
WSF_CHECKBOX_CONTROL = (function(_super) {
|
|
|
|
__extends(WSF_CHECKBOX_CONTROL, _super);
|
|
|
|
function WSF_CHECKBOX_CONTROL() {
|
|
return WSF_CHECKBOX_CONTROL.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_CHECKBOX_CONTROL.prototype.attach_events = function() {
|
|
var self;
|
|
self = this;
|
|
this.checked_value = window.states[this.control_name]['checked_value'];
|
|
return this.$el.change(function() {
|
|
return self.change();
|
|
});
|
|
};
|
|
|
|
WSF_CHECKBOX_CONTROL.prototype.change = function() {
|
|
window.states[this.control_name]['checked'] = this.$el.is(':checked');
|
|
if (window.states[this.control_name]['callback_change']) {
|
|
trigger_callback(this.control_name, 'change');
|
|
}
|
|
return this.trigger('change');
|
|
};
|
|
|
|
WSF_CHECKBOX_CONTROL.prototype.value = function() {
|
|
return this.$el.is(':checked');
|
|
};
|
|
|
|
WSF_CHECKBOX_CONTROL.prototype.update = function(state) {
|
|
if (state.text != null) {
|
|
window.states[this.control_name]['checked'] = state.checked;
|
|
return this.$el.prop('checked', state.checked);
|
|
}
|
|
};
|
|
|
|
return WSF_CHECKBOX_CONTROL;
|
|
|
|
})(WSF_CONTROL);
|
|
|
|
WSF_FORM_ELEMENT_CONTROL = (function(_super) {
|
|
|
|
__extends(WSF_FORM_ELEMENT_CONTROL, _super);
|
|
|
|
function WSF_FORM_ELEMENT_CONTROL() {
|
|
return WSF_FORM_ELEMENT_CONTROL.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_FORM_ELEMENT_CONTROL.prototype.attach_events = function() {
|
|
var self, validator, _i, _len, _ref;
|
|
self = this;
|
|
this.value_control = controls[window.states[this.control_name]['value_control']];
|
|
if (this.value_control != null) {
|
|
this.value_control.on('change', this.change, this);
|
|
}
|
|
this.serverside_validator = false;
|
|
this.validators = [];
|
|
_ref = window.states[this.control_name]['validators'];
|
|
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
|
validator = _ref[_i];
|
|
if (validatormap[validator.name] != null) {
|
|
this.validators.push(new validatormap[validator.name](this, validator));
|
|
} else {
|
|
this.serverside_validator = true;
|
|
}
|
|
}
|
|
};
|
|
|
|
WSF_FORM_ELEMENT_CONTROL.prototype.change = function() {
|
|
var validator, _i, _len, _ref;
|
|
_ref = this.validators;
|
|
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
|
validator = _ref[_i];
|
|
if (!validator.validate()) {
|
|
this.showerror(validator.error);
|
|
return;
|
|
}
|
|
}
|
|
this.showerror("");
|
|
if (this.serverside_validator) {
|
|
trigger_callback(this.control_name, 'validate');
|
|
}
|
|
};
|
|
|
|
WSF_FORM_ELEMENT_CONTROL.prototype.showerror = function(message) {
|
|
var errordiv;
|
|
this.$el.removeClass("has-error");
|
|
this.$el.find(".validation").remove();
|
|
if (message.length > 0) {
|
|
this.$el.addClass("has-error");
|
|
errordiv = $("<div />").addClass('help-block').addClass('validation').text(message);
|
|
return this.$el.find(".col-lg-10").append(errordiv);
|
|
}
|
|
};
|
|
|
|
WSF_FORM_ELEMENT_CONTROL.prototype.update = function(state) {
|
|
if (state.error != null) {
|
|
return this.showerror(state.error);
|
|
}
|
|
};
|
|
|
|
WSF_FORM_ELEMENT_CONTROL.prototype.value = function() {
|
|
return this.value_control.value();
|
|
};
|
|
|
|
return WSF_FORM_ELEMENT_CONTROL;
|
|
|
|
})(WSF_CONTROL);
|
|
|
|
WSF_HTML_CONTROL = (function(_super) {
|
|
|
|
__extends(WSF_HTML_CONTROL, _super);
|
|
|
|
function WSF_HTML_CONTROL() {
|
|
return WSF_HTML_CONTROL.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_HTML_CONTROL.prototype.value = function() {
|
|
return this.$el.html();
|
|
};
|
|
|
|
WSF_HTML_CONTROL.prototype.update = function(state) {
|
|
if (state.html != null) {
|
|
window.states[this.control_name]['html'] = state.html;
|
|
return this.$el.html(state.html);
|
|
}
|
|
};
|
|
|
|
return WSF_HTML_CONTROL;
|
|
|
|
})(WSF_CONTROL);
|
|
|
|
WSF_CHECKBOX_LIST_CONTROL = (function(_super) {
|
|
|
|
__extends(WSF_CHECKBOX_LIST_CONTROL, _super);
|
|
|
|
function WSF_CHECKBOX_LIST_CONTROL() {
|
|
return WSF_CHECKBOX_LIST_CONTROL.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_CHECKBOX_LIST_CONTROL.prototype.attach_events = function() {
|
|
var control, name, self;
|
|
self = this;
|
|
this.subcontrols = [];
|
|
for (name in controls) {
|
|
control = controls[name];
|
|
if (this.$el.has(control.$el).length > 0) {
|
|
this.subcontrols.push(control);
|
|
control.on('change', this.change, this);
|
|
}
|
|
}
|
|
};
|
|
|
|
WSF_CHECKBOX_LIST_CONTROL.prototype.change = function() {
|
|
return this.trigger("change");
|
|
};
|
|
|
|
WSF_CHECKBOX_LIST_CONTROL.prototype.value = function() {
|
|
var result, subc, _i, _len, _ref;
|
|
result = [];
|
|
_ref = this.subcontrols;
|
|
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
|
subc = _ref[_i];
|
|
if (subc.value()) {
|
|
result.push(subc.checked_value);
|
|
}
|
|
}
|
|
return result;
|
|
};
|
|
|
|
return WSF_CHECKBOX_LIST_CONTROL;
|
|
|
|
})(WSF_CONTROL);
|
|
|
|
WSF_PROGRESS_CONTROL = (function(_super) {
|
|
|
|
__extends(WSF_PROGRESS_CONTROL, _super);
|
|
|
|
function WSF_PROGRESS_CONTROL() {
|
|
return WSF_PROGRESS_CONTROL.__super__.constructor.apply(this, arguments);
|
|
}
|
|
|
|
WSF_PROGRESS_CONTROL.prototype.update = function(state) {
|
|
if (state.progress != null) {
|
|
window.states[this.control_name]['progress'] = state.progress;
|
|
return $('#' + this.control_name).children('.progress-bar').attr('aria-valuenow', state.progress).width(state.progress + '%');
|
|
}
|
|
};
|
|
|
|
return WSF_PROGRESS_CONTROL;
|
|
|
|
})(WSF_CONTROL);
|
|
|
|
typemap = {
|
|
"WSF_BUTTON_CONTROL": WSF_BUTTON_CONTROL,
|
|
"WSF_INPUT_CONTROL": WSF_INPUT_CONTROL,
|
|
"WSF_TEXTAREA_CONTROL": WSF_TEXTAREA_CONTROL,
|
|
"WSF_AUTOCOMPLETE_CONTROL": WSF_AUTOCOMPLETE_CONTROL,
|
|
"WSF_CHECKBOX_CONTROL": WSF_CHECKBOX_CONTROL,
|
|
"WSF_FORM_ELEMENT_CONTROL": WSF_FORM_ELEMENT_CONTROL,
|
|
"WSF_HTML_CONTROL": WSF_HTML_CONTROL,
|
|
"WSF_CHECKBOX_LIST_CONTROL": WSF_CHECKBOX_LIST_CONTROL,
|
|
"WSF_PROGRESS_CONTROL": WSF_PROGRESS_CONTROL
|
|
};
|
|
|
|
_ref = window.states;
|
|
for (name in _ref) {
|
|
state = _ref[name];
|
|
$el = $('[data-name=' + name + ']');
|
|
type = $el.data('type');
|
|
if ((type != null) && (typemap[type] != null)) {
|
|
controls[name] = new typemap[type](name, $el);
|
|
}
|
|
}
|
|
|
|
_ref1 = window.states;
|
|
for (name in _ref1) {
|
|
state = _ref1[name];
|
|
if ((_ref2 = controls[name]) != null) {
|
|
_ref2.attach_events();
|
|
}
|
|
}
|
|
|
|
}).call(this);
|