o: ActiveSupport::Cache::Entry :@compressedF:@expires_in0:@created_atf1375442887.892643:@value"ñ2{I" class:EFI"BundledAsset; FI"logical_path; FI"slick/slick.editors.js; TI" pathname; FI"j/Users/bogumil/www/engines/slickgrid-requirejs-rails/vendor/assets/javascripts/slick/slick.editors.js; TI"content_type; FI"application/javascript; FI" mtime; FI"2013-08-01T19:44:50+02:00; FI"length; Fi 1I"digest; F"%a6c7d805ee3cac87f46a8b5dfc9ed4ffI"source; FI" 1/*** * Contains basic SlickGrid editors. * @module Editors * @namespace Slick */ // Universal module definition (function (root, factory) { if (typeof define === 'function' && define.amd) { // AMD. Register as an anonymous module. define(['jquery'], factory); } else { // Browser globals root.Slick.Editors = factory(root.jQuery); } }(this, function ($) { function TextEditor(args) { var $input; var defaultValue; var scope = this; this.init = function () { $input = $("") .appendTo(args.container) .bind("keydown.nav", function (e) { if (e.keyCode === $.ui.keyCode.LEFT || e.keyCode === $.ui.keyCode.RIGHT) { e.stopImmediatePropagation(); } }) .focus() .select(); }; this.destroy = function () { $input.remove(); }; this.focus = function () { $input.focus(); }; this.getValue = function () { return $input.val(); }; this.setValue = function (val) { $input.val(val); }; this.loadValue = function (item) { defaultValue = item[args.column.field] || ""; $input.val(defaultValue); $input[0].defaultValue = defaultValue; $input.select(); }; this.serializeValue = function () { return $input.val(); }; this.applyValue = function (item, state) { item[args.column.field] = state; }; this.isValueChanged = function () { return (!($input.val() == "" && defaultValue == null)) && ($input.val() != defaultValue); }; this.validate = function () { if (args.column.validator) { var validationResults = args.column.validator($input.val()); if (!validationResults.valid) { return validationResults; } } return { valid: true, msg: null }; }; this.init(); } function IntegerEditor(args) { var $input; var defaultValue; var scope = this; this.init = function () { $input = $(""); $input.bind("keydown.nav", function (e) { if (e.keyCode === $.ui.keyCode.LEFT || e.keyCode === $.ui.keyCode.RIGHT) { e.stopImmediatePropagation(); } }); $input.appendTo(args.container); $input.focus().select(); }; this.destroy = function () { $input.remove(); }; this.focus = function () { $input.focus(); }; this.loadValue = function (item) { defaultValue = item[args.column.field]; $input.val(defaultValue); $input[0].defaultValue = defaultValue; $input.select(); }; this.serializeValue = function () { return parseInt($input.val(), 10) || 0; }; this.applyValue = function (item, state) { item[args.column.field] = state; }; this.isValueChanged = function () { return (!($input.val() == "" && defaultValue == null)) && ($input.val() != defaultValue); }; this.validate = function () { if (isNaN($input.val())) { return { valid: false, msg: "Please enter a valid integer" }; } return { valid: true, msg: null }; }; this.init(); } function DateEditor(args) { var $input; var defaultValue; var scope = this; var calendarOpen = false; this.init = function () { $input = $(""); $input.appendTo(args.container); $input.focus().select(); $input.datepicker({ showOn: "button", buttonImageOnly: true, buttonImage: "../images/calendar.gif", beforeShow: function () { calendarOpen = true }, onClose: function () { calendarOpen = false } }); $input.width($input.width() - 18); }; this.destroy = function () { $.datepicker.dpDiv.stop(true, true); $input.datepicker("hide"); $input.datepicker("destroy"); $input.remove(); }; this.show = function () { if (calendarOpen) { $.datepicker.dpDiv.stop(true, true).show(); } }; this.hide = function () { if (calendarOpen) { $.datepicker.dpDiv.stop(true, true).hide(); } }; this.position = function (position) { if (!calendarOpen) { return; } $.datepicker.dpDiv .css("top", position.top + 30) .css("left", position.left); }; this.focus = function () { $input.focus(); }; this.loadValue = function (item) { defaultValue = item[args.column.field]; $input.val(defaultValue); $input[0].defaultValue = defaultValue; $input.select(); }; this.serializeValue = function () { return $input.val(); }; this.applyValue = function (item, state) { item[args.column.field] = state; }; this.isValueChanged = function () { return (!($input.val() == "" && defaultValue == null)) && ($input.val() != defaultValue); }; this.validate = function () { return { valid: true, msg: null }; }; this.init(); } function YesNoSelectEditor(args) { var $select; var defaultValue; var scope = this; this.init = function () { $select = $(""); $select.appendTo(args.container); $select.focus(); }; this.destroy = function () { $select.remove(); }; this.focus = function () { $select.focus(); }; this.loadValue = function (item) { $select.val((defaultValue = item[args.column.field]) ? "yes" : "no"); $select.select(); }; this.serializeValue = function () { return ($select.val() == "yes"); }; this.applyValue = function (item, state) { item[args.column.field] = state; }; this.isValueChanged = function () { return ($select.val() != defaultValue); }; this.validate = function () { return { valid: true, msg: null }; }; this.init(); } function CheckboxEditor(args) { var $select; var defaultValue; var scope = this; this.init = function () { $select = $(""); $select.appendTo(args.container); $select.focus(); }; this.destroy = function () { $select.remove(); }; this.focus = function () { $select.focus(); }; this.loadValue = function (item) { defaultValue = !!item[args.column.field]; if (defaultValue) { $select.attr("checked", "checked"); } else { $select.removeAttr("checked"); } }; this.serializeValue = function () { return !!$select.attr("checked"); }; this.applyValue = function (item, state) { item[args.column.field] = state; }; this.isValueChanged = function () { return (this.serializeValue() !== defaultValue); }; this.validate = function () { return { valid: true, msg: null }; }; this.init(); } function PercentCompleteEditor(args) { var $input, $picker; var defaultValue; var scope = this; this.init = function () { $input = $(""); $input.width($(args.container).innerWidth() - 25); $input.appendTo(args.container); $picker = $("
").appendTo(args.container); $picker.append("