!window.Common && (window.Common = {}); !Common.Views && (Common.Views = {}); define([ 'common/main/lib/component/Window', 'common/main/lib/component/MetricSpinner', 'common/main/lib/component/TextareaField' ], function () { 'use strict'; Common.Views.EmbedDialog = Common.UI.Window.extend(_.extend({ options: { width: 300, header: true, style: 'min-width: 300px;', cls: 'modal-dlg', buttons: null }, initialize : function(options) { _.extend(this.options, { title: this.textTitle }, options || {}); this.template = [ '
', '', '', '', '', '', '', '', '', '
', '', '
', '
', '', '
', '
', '
', '
', '
', '
', '' ].join(''); this.options.tpl = _.template(this.template)(this.options); this.embedConfig = this.options.embedConfig; this.embedCode = ''; Common.UI.Window.prototype.initialize.call(this, this.options); }, render: function() { Common.UI.Window.prototype.render.call(this); this.spnWidth = new Common.UI.MetricSpinner({ el: $('#embed-size-spin-width'), step: 1, width: 70, defaultUnit : "px", value: '400 px', minValue: 400, maxValue: 10000 }); this.spnWidth.on('change', _.bind(function(field, newValue, oldValue, eOpts){ this.updateEmbedCode(); }, this)); this.spnHeight = new Common.UI.MetricSpinner({ el: $('#embed-size-spin-height'), step: 1, width: 70, defaultUnit : "px", value: '600 px', minValue: 600, maxValue: 10000 }); this.spnHeight.on('change', _.bind(function(field, newValue, oldValue, eOpts){ this.updateEmbedCode(); }, this)); this.textareaInput = new Common.UI.TextareaField({ el : $('#embed-textarea'), style : 'width: 100%; height: 65px;', value : '' }); this.textareaInput._input.attr('readonly', true); this.updateEmbedCode(); this.getChild().find('.dlg-btn').on('click', _.bind(this.onBtnClick, this)); }, getFocusedComponents: function() { return [this.spnWidth, this.spnHeight, this.textareaInput]; }, getDefaultFocusableComponent: function () { return this.textareaInput; }, onBtnClick: function(event) { this.textareaInput._input.select(); if ( !document.execCommand('copy') ) { Common.UI.warning({ msg: this.warnCopy, buttons: ['ok'] }); } }, updateEmbedCode: function() { this.textareaInput.setValue(Common.Utils.String.format(this.embedCode, this.embedConfig.embedUrl, this.spnWidth.getNumberValue(), this.spnHeight.getNumberValue())); }, textTitle: 'Embed', textWidth: 'Width', textHeight: 'Height', txtCopy: 'Copy to clipboard', warnCopy: 'Browser\'s error! Use keyboard shortcut [Ctrl] + [C]' }, Common.Views.EmbedDialog || {})); Common.Views.ShareDialog = Common.UI.Window.extend(_.extend({ options: { width: 300, header: true, style: 'min-width: 300px;', cls: 'modal-dlg', buttons: null }, initialize : function(options) { _.extend(this.options, { title: this.textTitle }, options || {}); this.template = [ '
', '', '', '', '', '', '', '', '
', '', '
', '', '
', '
', '
', '' ].join(''); this.options.tpl = _.template(this.template)(this.options); this.embedConfig = this.options.embedConfig; Common.UI.Window.prototype.initialize.call(this, this.options); }, render: function() { Common.UI.Window.prototype.render.call(this); this.textUrl = new Common.UI.InputField({ el : $('#share-link-txt'), editable : false, value: this.embedConfig.shareUrl || '' }); this.updateShareCode(); this.getChild().find('.dlg-btn').on('click', _.bind(this.onBtnClick, this)); }, onBtnClick: function(event) { this.textUrl._input.select(); if ( !document.execCommand('copy') ) { Common.UI.warning({ msg: this.warnCopy, buttons: ['ok'] }); } }, updateShareCode: function() { var me = this, _encoded = encodeURIComponent(this.embedConfig.shareUrl), docTitle = this.embedConfig.docTitle || '', _mailto = 'mailto:?subject=I have shared a document with you: ' + docTitle + '&body=I have shared a document with you: ' + _encoded; this.getChild().find('.share-buttons > span').on('click', function(e){ var _url; switch ($(e.target).attr('data-name')) { case 'facebook': _url = 'https://www.facebook.com/sharer/sharer.php?u=' + me.embedConfig.shareUrl + '&t=' + encodeURI(docTitle); window.open(_url, '', 'menubar=no,toolbar=no,resizable=yes,scrollbars=yes,height=300,width=600'); break; case 'twitter': _url = 'https://twitter.com/share?url='+ _encoded; !!docTitle && (_url += encodeURIComponent('&text=' + docTitle)); window.open(_url, '', 'menubar=no,toolbar=no,resizable=yes,scrollbars=yes,height=300,width=600'); break; case 'email': window.open(_mailto, '_self'); break; } }); }, textTitle: 'Share Link', txtCopy: 'Copy to clipboard', warnCopy: 'Browser\'s error! Use keyboard shortcut [Ctrl] + [C]' }, Common.Views.ShareDialog || {})) });