HEX
Server: Microsoft-IIS/8.5
System: Windows NT YDAWBH120 6.3 build 9600 (Windows Server 2012 R2 Standard Edition) AMD64
User: tentjecom_web (0)
PHP: 7.4.14
Disabled: NONE
Upload Files
File: D:/HostingSpaces/HKemperman1/osthoes.nl/wwwroot/js/Debug/dnn.controls.dnnlabeledit.js
/// <reference name="MicrosoftAjax.js" />
/// <reference name="dnn.controls.js" assembly="DotNetNuke.WebControls" />
/// <reference name="dnn.js" assembly="DotNetNuke.WebUtility" />
/// <reference name="dnn.dom.positioning.js" assembly="DotNetNuke.WebUtility" />
/// <reference name="dnn.xmlhttp.js" assembly="DotNetNuke.WebUtility" />

Type.registerNamespace('dnn.controls');

dnn.extend(dnn.controls, {
    initLabelEdit: function (ctl) 
    {
	    if (ctl)
	    {
		    var lbl = new dnn.controls.DNNLabelEdit(ctl);
		    lbl.initialize();
		    return lbl;
	    }
    }
});

//------- Constructor -------//
dnn.controls.DNNLabelEdit = function (o)
{
	dnn.controls.DNNLabelEdit.initializeBase(this, [o]);	

    this.control = this.container;//backwards compat
    
	this.editWrapper = null;	//stores dnn wrapper for abstracted edit control
	this.editContainer = null; //stores container of the control (necessary for iframe controls)
	this.editControl = null; //stores reference to underlying edit control (input, span, textarea)
	this.prevText = '';	
		
	this.onblurSave = (this.getProp('blursave', '1') == '1');
	
	this.toolbarId = this.getProp('tbId', '');
	this.nsPrefix = this.getProp('nsPrefix', '');
	this.toolbarEventName = this.getProp('tbEvent', 'onmousemove');
	this.toolbar = null;
	//this.scriptPath = dnn.dom.getScriptPath();
	//var oThisScript = dnn.dom.getScript('dnn.controls.dnnlabeledit.js');
	//if (oThisScript)
	//	this.scriptPath = oThisScript.src.replace('dnn.controls.dnnlabeledit.js', '');
		
	this.css = o.className;	
	this.cssEdit = this.getProp('cssEdit', '');
	this.cssWork = this.getProp('cssWork', '');
	this.cssOver = this.getProp('cssOver', '');
	this.sysImgPath = this.getProp('sysimgpath', '');
	this.callBack = this.getProp('callback', '');
	this.callBackStatFunc = this.getProp('callbackSF', '');
	if (this.callBackStatFunc.length > 0)
	    this.add_handler('callBackStatus', eval(this.callBackStatFunc));
	
	this.beforeSaveFunc = this.getProp('beforeSaveF', '');
	if (this.beforeSaveFunc.length > 0)
	    this.add_handler('beforeSave', eval(this.beforeSaveFunc));
	    
	this.eventName = this.getProp('eventName', 'onclick');
	//this.editEnabled = dnn.dom.getAttr(o, 'editEnabled', '1') == '1';
	this.multiLineEnabled = this.getProp('multiline', '0') == '1';
	this.saveOnEnter = this.getProp('saveonenter', '1') == '1';
	this.richTextEnabled = this.getProp('richtext', '0') == '1';
	this.supportsCE = (document.body.contentEditable != null);
	if (dnn.dom.browser.isType(dnn.dom.browser.Safari) || dnn.dom.browser.isType(dnn.dom.browser.Opera))		
		this.supportsCE = false;//Safari content editable still buggy...
	this.supportsRichText = (this.supportsCE || (dnn.dom.browser.isType(dnn.dom.browser.Mozilla) && navigator.productSub >= '20050111'));	//i belive firefox only works well with 1.5 or later, need a better way to detect this!
	
	if (this.eventName != 'none')
	    this.addHandlers(o, this.getDynamicEventObject(this._getEventName(this.eventName), this.performEdit), this);
	
	if (this.toolbarId.length > 0)
	    this.addHandlers(o, this.getDynamicEventObject(this._getEventName(this.toolbarEventName), this.showToolBar), this);

    this.addHandlers(o, {'mousemove': this.mouseMove, 
                        'mouseout': this.mouseOut}, this);

    this._toolbarActionDelegate = dnn.createDelegate(this, this.toolbarAction);                        
    this._initToolbarDelegate = dnn.createDelegate(this, this.initToolbar);
    this._performEditDelegate = dnn.createDelegate(this, this.performEdit);
}

dnn.controls.DNNLabelEdit.prototype =
{

    isEditMode: function()
    {
        return (this.container.style.display != '')
    },

    initToolbar: function()
    {
        if (this.toolbar == null)
        {
            var status = dnn.dom.scriptStatus('dnn.controls.dnntoolbar.js');
            if (status == 'complete')
            {
                this.toolbar = new dnn.controls.DNNToolBar(this.ns);
                this.toolbar.loadDefinition(this.toolbarId, this.nsPrefix, this.container, this.container.parentNode, this.container, this._toolbarActionDelegate);
                this.handleToolbarDisplay();
            }
            else if (status == '')	//not loaded
                dnn.dom.loadScript(dnn.dom.getScriptPath() + 'dnn.controls.dnntoolbar.js', '', this._initToolbarDelegate);
        }

    },

    toolbarAction: function(btn, src)
    {
        var action = btn.clickAction;
        if (action == 'edit')
            this.performEdit();
        else if (action == 'save')
        {
            this.persistEdit();
            this.toolbar.hide();
        }
        else if (action == 'cancel')
        {
            this.cancelEdit();
            this.toolbar.hide();
        }
        else if (this.isFormatButton(action))
        {
            if (this.editWrapper)
            {
                var link;
                if (action == 'createlink' && dnn.dom.browser.isType(dnn.dom.browser.InternetExplorer) == false)
                    link = prompt(btn.tooltip);

                this.editWrapper.focus();
                this.editWrapper.execCommand(action, null, link);
            }
        }

    },

    performEdit: function()
    {
        if (this.toolbar)
            this.toolbar.hide();

        this.initEditWrapper();
        if (this.editContainer != null)
        {
            //this.editContainer.style.height = (dnn.dom.positioning.elementHeight(this.container) + 4) + 'px';
            //var dims = new dnn.dom.positioning.dims(this.container.parentNode);
            //this.editContainer.style.width = (dims.w - dims.l) + 'px';
            //this.editContainer.style.width = dnn.dom.positioning.elementWidth(this.container.parentNode) + 'px' //'100%';
            this.editContainer.style.width = '100%';
            this.editContainer.style.display = '';
            //this.editContainer.style.visibility = '';	//firefox workaround... can't do display none
            this.editContainer.style.overflow = 'auto';
            this.editContainer.style.overflowX = 'hidden';

            this.prevText = this.container.innerHTML;
            if (dnn.dom.browser.isType(dnn.dom.browser.Safari) && this.container.innerText)		//safari gets strange chars... use innerText
                this.prevText = this.container.innerText;
            this.editWrapper.setText(this.prevText);
            this.initEditControl();
            this.container.style.display = 'none';
            this.handleToolbarDisplay();

            var arg = new Sys.CancelEventArgs();
            this.invoke_handler('beforeEdit', arg);
            if (arg.get_cancel())
            {
                this.cancelEdit();
                return;
            }

        }
    },

    showToolBar: function()
    {
        this.initToolbar();
        if (this.toolbar)
            this.toolbar.show(false);
    },

    mouseMove: function(e)
    {
        if (this.toolbarId.length > 0 && this.toolbarEventName == 'onmousemove')
            this.showToolBar();
        this.container.className = this.css + ' ' + this.cssOver;
    },

    mouseOut: function()
    {
        if (this.toolbar)
            this.toolbar.beginHide();
        this.container.className = this.css;
    },

    initEditWrapper: function()
    {
        if (this.editWrapper == null)
        {
            var richText = (this.richTextEnabled && this.supportsRichText);
            var script = (richText ? 'dnn.controls.dnnrichtext.js' : 'dnn.controls.dnninputtext.js');

            var status = dnn.dom.scriptStatus(script);
            if (status == 'complete')
            {
                var txt;
                if (this.richTextEnabled && this.supportsRichText)
                {
                    var func = dnn.dom.getObjMethRef(this, 'initEditControl');
                    txt = new dnn.controls.DNNRichText(func);
                }
                else
                    txt = new dnn.controls.DNNInputText(this.multiLineEnabled);

                this.editWrapper = txt;
                this.editContainer = this.editWrapper.container;
                this.container.parentNode.insertBefore(this.editContainer, this.container);
                if (this.richTextEnabled && this.supportsCE)	//control is instantly available (not an iframe)
                    this.initEditControl();
            }
            else if (status == '') //not loaded
                dnn.dom.loadScript(dnn.dom.getScriptPath() + script, '', this._performEditDelegate);
        }
    },

    initEditControl: function()
    {
        if (this.editWrapper.initialized)
        {
            this.editControl = this.editWrapper.control;
            this.editControl.className = this.container.className + ' ' + this.cssEdit;
            this.editWrapper.focus();
            if (this.editWrapper.loaded == false)
            {
                var eventObj = { keypress: this.handleKeyPress,
                    mousemove: this.mouseMove,
                    mouseout: this.mouseOut
                };

                if (this.onblurSave)
                    eventObj.blur = this.persistEdit;

                if (this.editWrapper.supportsCE || this.editWrapper.isRichText == false)	//if browser supports contentEditable or is a simple INPUT control
                    this.addHandlers(this.editControl, eventObj, this);
                else	//IFRAME event handlers
                    this.addHandlers(this.editContainer.contentWindow.document, eventObj, this);

                this.editWrapper.loaded = true;
            }
        }
    },

    persistEdit: function()
    {
        if (this.editWrapper.getText() != this.prevText)
        {
            if (this.invoke_compatHandler('beforeSave', null, this))
            {
                this.editControl.className = this.container.className + ' ' + this.cssWork;
                eval(this.callBack.replace('[TEXT]', dnn.escapeForEval(this.editWrapper.getText())));
            }
        }
        else
            this.showLabel();
    },

    cancelEdit: function()
    {
        this.editWrapper.setText(this.prevText);
        this.showLabel();
    },

    callBackStatus: function(result, ctx, req)
    {
        var lbl = ctx;
        lbl.invoke_compatHandler('callBackStatus', result, ctx, req);
    },

    callBackSuccess: function(result, ctx, req)
    {
        ctx.callBackStatus(result, ctx);
        ctx.invoke_handler('callBackSuccess', new dnn.controls.DNNCallbackEventArgs(result, ctx, req));
        ctx.showLabel();
	    ctx.flashLabel();
    },

    //obsolete
    raiseEvent: function(sFunc, evt, element)
    {
        if (this[sFunc].length > 0)
        {
            var ptr = eval(this[sFunc]);
            return ptr(evt, element) != false;
        }
        return true;
    },


    handleToolbarDisplay: function()
    {
        if (this.toolbar)
        {
            var inEdit = this.isEditMode();
            var btn;
            for (var key in this.toolbar.buttons)
            {
                btn = this.toolbar.buttons[key];
                if (typeof btn == 'function')	//safeguard against other js frameworks
                    continue;

	            if (key == 'edit') {
	            	btn.visible = !inEdit;
		            if (btn.visible) {
			            this.toolbar.css = this.toolbar.css.replace(" editMode", "");
		            } else {
			            this.toolbar.css = this.toolbar.css + " editMode";
		            }
	            } else if (this.isFormatButton(key))
		            btn.visible = (inEdit && this.editWrapper && this.editWrapper.isRichText);
	            else
		            btn.visible = inEdit;

            }
            this.toolbar.refresh();
        }
    },

    isFormatButton: function(key)
    {
        return '~bold~italic~underline~justifyleft~justifycenter~justifyright~insertorderedlist~insertunorderedlist~outdent~indent~createlink~'.indexOf('~' + key + '~') > -1;
    },

    showLabel: function()
    {
        this.container.innerHTML = this.editWrapper.getText();
        this.container.style.display = '';
        this.container.className = this.css;
        //this.editContainer.style.width = 0; //firefox workaround
        //this.editContainer.style.visibility = 'hidden';	//firefox workaround
        this.editContainer.style.display = 'none';
        this.handleToolbarDisplay();
    },
    
    flashLabel: function () {
    	var handler = this;
	    this.container.style.backgroundColor = "#fffacd";
	    setTimeout(function () {
		    handler.container.style.backgroundColor = "#fffff0";
		    setTimeout(function () {
			    handler.container.style.backgroundColor = "transparent";
            }, 300);
        }, 2500);
	},

    callBackFail: function(result, ctx, req)
    {
        ctx.invoke_handler('callBackFail', new dnn.controls.DNNCallbackEventArgs(result, ctx, req));
        ctx.cancelEdit();
    },

    handleKeyPress: function(e)
    {
        if (e.charCode == KEY_RETURN && this.editWrapper.supportsMultiLine == false)
        {
            if (this.saveOnEnter)
                this.persistEdit();
            e.preventDefault();
        }
        else if (e.charCode == KEY_ESCAPE)
        {
            this.cancelEdit();
            e.preventDefault();
        }
    },

    dispose: function()
    {
        this._toolbarActionDelegate = null;
        this._initToolbarDelegate = null;
        this._performEditDelegate = null;
        dnn.controls.DNNLabelEdit.callBaseMethod(this, 'dispose');
    }

}

dnn.controls.DNNLabelEdit.registerClass('dnn.controls.DNNLabelEdit', dnn.controls.control);