/** * Created by vladimir on 26.05.15. */ if (Common === undefined) var Common = {}; define([ 'common/main/lib/util/utils', 'common/main/lib/component/InputField', 'common/main/lib/component/Window' ], function () { 'use strict'; DE.Views.StyleTitleDialog = Common.UI.Window.extend(_.extend({ options: { width: 350, height: 200, style: 'min-width: 230px;', cls: 'modal-dlg' }, initialize : function(options) { _.extend(this.options, { title: this.textHeader }, options || {}); this.template = [ '
', '', '
', '', '
', '
', '' ].join(''); this.options.tpl = _.template(this.template, this.options); Common.UI.Window.prototype.initialize.call(this, this.options); }, render: function() { Common.UI.Window.prototype.render.call(this); var me = this, $window = this.getChild(); me.inputTitle = new Common.UI.InputField({ el : $('#id-dlg-style-title'), allowBlank : false, blankError : me.txtEmpty, style : 'width: 100%;', validateOnBlur: false, validation : function(value) { var isvalid = value != ''; if (isvalid) { return true; } else { return me.txtNotEmpty; } } }); $window.find('.dlg-btn').on('click', _.bind(this.onBtnClick, this)); $window.find('input').on('keypress', _.bind(this.onKeyPress, this)); this.cmbNextStyle = new Common.UI.ComboBox({ el : $('#id-dlg-style-next-par'), style : 'width: 100%;', menuStyle : 'width: 100%; max-height: 290px;', editable : false, cls : 'input-group-nr', data : this.options.formats }); this.cmbNextStyle.setValue(this.options.formats[0].value); }, show: function() { Common.UI.Window.prototype.show.apply(this, arguments); var me = this; _.delay(function(){ me.inputTitle.cmpEl.find('input').focus(); },500); }, getTitle: function () { var me = this; return me.inputTitle.getValue(); }, getNextStyle: function () { var me = this; return me.cmbNextStyle.getValue(); }, onBtnClick: function(event) { this._handleInput(event.currentTarget.attributes['result'].value); }, onKeyPress: function(event) { if (event.keyCode == Common.UI.Keys.RETURN) { this._handleInput('ok'); return false; } }, _handleInput: function(state) { if (this.options.handler) { if (state == 'ok') { var checkurl = this.inputTitle.checkValidate(); if (checkurl !== true) { this.inputTitle.cmpEl.find('input').focus(); return; } } this.options.handler.call(this, this, state); } this.close(); }, textTitle: 'Title', textHeader: 'Create New Style', txtEmpty: 'This field is required', txtNotEmpty: 'Field must not be empty', textNextStyle: 'Next paragraph style' }, DE.Views.StyleTitleDialog || {})) });