var dom = require('../lib/dom'); var dispose = require('../lib/dispose'); var _ = require('underscore'); var kd = require('../lib/koDom'); var AbstractWidget = require('./AbstractWidget'); /** * Switch - A bi-state Switch widget */ function Switch(field) { AbstractWidget.call(this, field, {defaultTextColor: '#2CB0AF'}); } dispose.makeDisposable(Switch); _.extend(Switch.prototype, AbstractWidget.prototype); Switch.prototype.buildConfigDom = function() { return null; }; Switch.prototype.buildDom = function(row) { var value = row[this.field.colId()]; return dom('div.field_clip', dom('div.widget_switch', kd.toggleClass('switch_on', value), kd.toggleClass('switch_transition', row._isRealChange), dom('div.switch_slider'), dom('div.switch_circle'), dom.on('click', () => { if (!this.field.column().isRealFormula()) { value.setAndSave(!value.peek()); } }) ) ); }; module.exports = Switch;