?iť?

Your IP : 3.133.147.158


Current Path : /home/scgforma/www/soc064/htdocs/core/js/
Upload File :
Current File : /home/scgforma/www/soc064/htdocs/core/js/editinplace.js

// Copyright (C) 2011-2014	Regis Houssin		<regis.houssin@inodbox.com>
// Copyright (C) 2011-2017	Laurent Destailleur	<eldy@users.sourceforge.net>
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
// or see http://www.gnu.org/
//

//
// \file       htdocs/core/js/editinplace.js
// \brief      File that include javascript functions for edit in place
//

$(document).ready(function() {
	var element = $('#jeditable_element').html();
	var table_element = $('#jeditable_table_element').html();
	var fk_element = $('#jeditable_fk_element').html();
	
	
	if ($('.editval_string').length > 0) {
		$('.editval_string').editable(urlSaveInPlace, {
			type		: 'text',
			id			: 'field',
			width		: withInPlace,				/* Size of string area in px ? */
			tooltip		: tooltipInPlace,
			placeholder	: placeholderInPlace,
			cancel		: cancelInPlace,
			submit		: submitInPlace,
			indicator	: indicatorInPlace,
			submitdata	: function(result, settings) {
				return getParameters(this, 'string');
			},
			callback	: function(result, settings) {
				getResult(this, result);
			},
			onreset		: function(result, settings) {
				getDefault(settings);
			}
		});
		$('.editkey_string').hover(
				function () {
					console.log("We are hover (entry) an editkey_string");
					$('#viewval_' + $(this).attr('id')).addClass("viewval_hover");
				},
				function () {
					console.log("We are no more hover an editkey_string");
					$('#viewval_' + $(this).attr('id')).removeClass("viewval_hover");
				}
		);
		$('.editkey_string').click(function() {
			console.log("We click on the edit field");
			$('#viewval_' + $(this).attr('id')).click();
			$('#viewval_' + $(this).attr('id')).hide();
			$('#editval_' + $(this).attr('id')).show().click();
		});
		$('.viewval_string.active').click(function() {
			console.log("We click on the viewed value");
			$('#viewval_' + $(this).attr('id').substr(8)).hide();
			$('#editval_' + $(this).attr('id').substr(8)).show().click();
		});
	}
	
	if ($('.editval_textarea').length > 0) {
		$('.editval_textarea').editable(urlSaveInPlace, {
			type		: 'textarea',
			rows		: $('#textarea_' + $('.editval_textarea').attr('id').substr(8) + '_rows').val(),
			cols		: $('#textarea_' + $('.editval_textarea').attr('id').substr(8) + '_cols').val(),
			id			: 'field',
			tooltip		: tooltipInPlace,
			placeholder	: '&nbsp;',
			cancel		: cancelInPlace,
			submit		: submitInPlace,
			indicator	: indicatorInPlace,
			loadurl		: urlLoadInPlace,
			loaddata	: function(result, settings) {
				return getParameters(this, 'textarea');
			},
			submitdata	: function(result, settings) {
				return getParameters(this, 'textarea');
			},
			callback	: function(result, settings) {
				getResult(this, result);
			},
			onreset		: function(result, settings) {
				getDefault(settings);
			}
		});
		$('.editkey_textarea').hover(
				function () {
					console.log("We are hover (entry) an editkey_textarea");
					$('#viewval_' + $(this).attr('id')).addClass("viewval_hover");
				},
				function () {
					console.log("We are no more hover (exit) an editkey_textarea");
					$('#viewval_' + $(this).attr('id')).removeClass("viewval_hover");
				}
		);
		$('.editkey_textarea').click(function() {
			$('#viewval_' + $(this).attr('id')).click();
		});
		$('.viewval_textarea.active').click(function() {
			$('#viewval_' + $(this).attr('id').substr(8)).hide();
			$('#editval_' + $(this).attr('id').substr(8)).show().click();
		});
		$('.editkey_textarea').click(function() {
			$('#viewval_' + $(this).attr('id')).hide();
			$('#editval_' + $(this).attr('id')).show().click();
		});
	}
	
	if (typeof ckeditorConfig != 'undefined') {
		$('.editval_ckeditor').editable(urlSaveInPlace, {
			type		: 'ckeditor',
			id			: 'field',
			onblur		: 'ignore',
			tooltip		: tooltipInPlace,
			placeholder	: '&nbsp;',
			cancel		: cancelInPlace,
			submit		: submitInPlace,
			indicator	: indicatorInPlace,
			ckeditor	: {
				customConfig: ckeditorConfig,
				toolbar: $('#ckeditor_toolbar').val(),
				filebrowserBrowseUrl : ckeditorFilebrowserBrowseUrl,
				filebrowserImageBrowseUrl : ckeditorFilebrowserImageBrowseUrl,
				filebrowserWindowWidth : '900',
	            filebrowserWindowHeight : '500',
	            filebrowserImageWindowWidth : '900',
	            filebrowserImageWindowHeight : '500'
			},
			submitdata	: function(result, settings) {
				return getParameters(this, 'ckeditor');
			},
			callback	: function(result, settings) {
				getResult(this, result);
			},
			onreset		: function(result, settings) {
				getDefault(settings);
			}
		});
		$('.editkey_ckeditor').hover(
				function () {
					console.log("We are hover (entry) an editkey_ckeditor");
					$('#viewval_' + $(this).attr('id')).addClass("viewval_hover");
				},
				function () {
					console.log("We are no more hover (exit) an editkey_ckeditor");
					$('#viewval_' + $(this).attr('id')).removeClass("viewval_hover");
				}
		);
		$('.editkey_ckeditor').click(function() {
			$( '#viewval_' + $(this).attr('id') ).click();
		});
		$('.viewval_ckeditor.active').click(function() {
			$('#viewval_' + $(this).attr('id').substr(8)).hide();
			$('#editval_' + $(this).attr('id').substr(8)).show().click();
		});
		$('.editkey_ckeditor').click(function() {
			$('#viewval_' + $(this).attr('id')).hide();
			$('#editval_' + $(this).attr('id')).show().click();
		});
	}
	
	if ($('.editval_numeric').length > 0) {
		$('.editval_numeric').editable(urlSaveInPlace, {
			type		: 'text',
			id			: 'field',
			width		: 100,
			tooltip		: tooltipInPlace,
			placeholder	: placeholderInPlace,
			cancel		: cancelInPlace,
			submit		: submitInPlace,
			indicator	: indicatorInPlace,
			submitdata	: function(result, settings) {
				return getParameters(this, 'numeric');
			},
			callback	: function(result, settings) {
				getResult(this, result);
			},
			onreset		: function(result, settings) {
				getDefault(settings);
			}
		});
		$('.editkey_numeric').hover(
				function () {
					console.log("We are hover an editkey_numeric");
					$( '#viewval_' + $(this).attr('id') ).addClass("viewval_hover");
				},
				function () {
					console.log("We are no more hover (exit) an editkey_textarea");
					$( '#viewval_' + $(this).attr('id') ).removeClass("viewval_hover");
				}
		);
		$('.editkey_numeric').click(function() {
			$( '#viewval_' + $(this).attr('id') ).click();
		});
		$('.viewval_numeric.active').click(function() {
			$('#viewval_' + $(this).attr('id').substr(8)).hide();
			$('#editval_' + $(this).attr('id').substr(8)).show().click();
		});
		$('.editkey_numeric').click(function() {
			$('#viewval_' + $(this).attr('id')).hide();
			$('#editval_' + $(this).attr('id')).show().click();
		});
	}
	
	if ($('.editval_datepicker').length > 0) {
		$('.editval_datepicker').editable(urlSaveInPlace, {
			type		: 'datepicker',
			id			: 'field',
			onblur		: 'ignore',
			tooltip		: tooltipInPlace,
			placeholder	: '&nbsp;',
			cancel		: cancelInPlace,
			submit		: submitInPlace,
			indicator	: indicatorInPlace,
			submitdata	: function(result, settings) {
				return getParameters(this, 'datepicker');
			},
			callback	: function(result, settings) {
				getResult(this, result);
			},
			onreset		: function(result, settings) {
				getDefault(settings);
			}
		});
		$('.editkey_datepicker').hover(
				function () {
					console.log("We are hover (entry) editkey_datepicker");
					$('#viewval_' + $(this).attr('id')).addClass("viewval_hover");
				},
				function () {
					console.log("We are no more hover (exit) an editkey_datepicker");
					$('#viewval_' + $(this).attr('id')).removeClass("viewval_hover");
				}
		);
		$('.viewval_datepicker.active').click(function() {
			$('#viewval_' + $(this).attr('id').substr(8)).hide();
			$('#editval_' + $(this).attr('id').substr(8)).show().click();
		});
		$('.editkey_datepicker').click(function() {
			$('#viewval_' + $(this).attr('id')).hide();
			$('#editval_' + $(this).attr('id')).show().click();
		});
	}
	
	if ($('.editval_select').length > 0) {
		$('.editval_select').editable(urlSaveInPlace, {
			type		: 'select',
			id			: 'field',
			onblur		: 'ignore',
			cssclass	: 'flat',
			tooltip		: tooltipInPlace,
			placeholder	: '&nbsp;',
			cancel		: cancelInPlace,
			submit		: submitInPlace,
			indicator	: indicatorInPlace,
			loadurl		: urlLoadInPlace,
			loaddata	: function(result, settings) {
				return getParameters(this, 'select');
			},
			submitdata	: function(result, settings) {
				return getParameters(this, 'select');
			},
			callback	: function(result, settings) {
				getResult(this, result);
			},
			onreset		: function(result, settings) {
				getDefault(settings);
			}
		});
		$('.editkey_select').hover(
				function () {
					console.log("We are hover (entry) an editkey_select");
					$('#viewval_' + $(this).attr('id')).addClass("viewval_hover");
				},
				function () {
					console.log("We are no more hover (exit) an editkey_select");
					$('#viewval_' + $(this).attr('id')).removeClass("viewval_hover");
				}
		);
		$('.viewval_select.active').click(function() {
			$('#viewval_' + $(this).attr('id').substr(8)).hide();
			$('#editval_' + $(this).attr('id').substr(8)).show().click();
		});
		$('.editkey_select').click(function() {
			$('#viewval_' + $(this).attr('id')).hide();
			$('#editval_' + $(this).attr('id')).show().click();
		});
	}
	
	// for test only (not stable)
	if ($('.editval_autocomplete').length > 0) {
		$('.editval_autocomplete').editable(urlSaveInPlace, {
			type		: 'autocomplete',
			id			: 'field',
			width		: 300,
			onblur		: 'ignore',
			tooltip		: tooltipInPlace,
			placeholder	: '&nbsp;',
			cancel		: cancelInPlace,
			submit		: submitInPlace,
			indicator	: indicatorInPlace,
			autocomplete : {
				source : urlLoadInPlace,
				data : function(result, settings) {
					return getParameters(this, 'select');
				}
			},
			submitdata	: function(result, settings) {
				return getParameters(this, 'select');
			},
			callback	: function(result, settings) {
				getResult(this, result);
			},
			onreset		: function(result, settings) {
				getDefault(settings);
			}
		});
		$('.editkey_autocomplete').hover(
				function () {
					console.log("We are no more hover (exit) an editkey_autocomplete");
					$('#viewval_' + $(this).attr('id')).addClass("viewval_hover");
				},
				function () {
					$('#viewval_' + $(this).attr('id')).removeClass("viewval_hover");
				}
		);
		$('.viewval_autocomplete.active').click(function() {
			$('#viewval_' + $(this).attr('id').substr(8)).hide();
			$('#editval_' + $(this).attr('id').substr(8)).show().click();
		});
		$('.editkey_autocomplete').click(function() {
			$('#viewval_' + $(this).attr('id')).hide();
			$('#editval_' + $(this).attr('id')).show().click();
		});
	}
	
	function getParameters(obj, type) {
		var htmlname		= $(obj).attr('id').substr(8);
		var element			= $('#element_' + htmlname).val();
		var table_element	= $('#table_element_' + htmlname).val();
		var fk_element		= $('#fk_element_' + htmlname).val();
		var loadmethod		= $('#loadmethod_' + htmlname).val();
		var savemethod		= $('#savemethod_' + htmlname).val();
		var ext_element		= $('#ext_element_' + htmlname).val();
		var timestamp		= $('#timestamp').val();
		
		return {
			type: type,
			element: element,
			table_element: table_element,
			fk_element: fk_element,
			loadmethod: loadmethod,
			savemethod: savemethod,
			timestamp: timestamp,
			ext_element: ext_element
		};
	}
	
	function getResult(obj, result) {
		var res = $.parseJSON(result);
		if (res.error) {
			$(obj).html(obj.revert);
			var htmlname = $(obj).attr('id').substr(8);
			var errormsg = $( '#errormsg_' + htmlname ).val();
			if (errormsg != undefined) {
				$.jnotify(errormsg, "error", true);
			} else {
				$.jnotify(res.error, "error", true);
			}
			
		} else {
			var htmlname = $(obj).attr('id').substr(8);
			var successmsg = $( '#successmsg_' + htmlname ).val();
			if (successmsg != undefined) {
				$.jnotify(successmsg, "ok");
			}
			$(obj).html(res.value);
			$(obj).hide();
			$('#viewval_' + htmlname).html(res.view);
			$('#viewval_' + htmlname).show();
		}
	}
	
	function getDefault(settings) {
		var htmlname = $(settings).attr('id').substr(8);
		$('#editval_' + htmlname).hide();
		$('#viewval_' + htmlname).show();
	}
});