codiad/components/settings/init.js

259 lines
6.2 KiB
JavaScript
Raw Normal View History

/*
* Copyright (c) Codiad, distributed
* as-is and without warranty under the MIT License. See
* [root]/license.txt for more. This information must remain intact.
*/
(function(global, $) {
$(function() {
codiad.settings.init();
});
codiad.settings = {
controller: 'components/settings/controller.php',
settings: null,
init: function() {
var _this = this;
/*
* Storage Event:
* Note: Event fires only if change was made in different window and not in this one
* Details: http://dev.w3.org/html5/webstorage/#dom-localstorage
*
* Workaround for Storage-Event:
*/
$( 'body' ).append( '<iframe src="components/settings/dialog.php?action=iframe"></iframe>' );
//Load Settings
this.load();
},
get_option: async function( option ) {
let result;
try {
result = await $.ajax({
url: this.controller + '?action=get_option',
type: "POST",
dataType: 'html',
data: {
option: option
},
});
return result;
} catch (error) {
console.log(error);
throw error;
}
},
get_options: async function() {
let result;
let _self = codiad.settings;
try {
if( _self.settings == null ) {
result = await $.ajax({
url: this.controller + '?action=get_options',
type: "POST",
dataType: 'html',
data: {
},
});
result = JSON.parse( result );
} else {
result = _self.settings
}
return result;
} catch (error) {
console.log(error);
throw error;
}
},
//////////////////////////////////////////////////////////////////
// Save Settings
//////////////////////////////////////////////////////////////////
save: function( settings ) {
var systemRegex = /^codiad/;
var pluginRegex = /^codiad.plugin/;
$.ajax({
type: 'POST',
url: this.controller + '?action=save',
data: {settings: JSON.stringify( settings )},
success: function( data ) {
data = data.replace(/},/gi, ",").split(",");
length = data.length;
for( i = 0;i < length; i++ ) {
parsed = codiad.jsend.parse( data );
}
codiad.modal.unload();
},
});
/* Notify listeners */
amplify.publish( 'settings.save', {} );
},
//////////////////////////////////////////////////////////////////
// Load Settings
//////////////////////////////////////////////////////////////////
load: function() {
codiad.editor.getSettings();
amplify.publish( 'settings.loaded', null );
},
//////////////////////////////////////////////////////////////////
//
// Show Settings Dialog
//
// Parameter
//
// data_file - {String} - Location of settings file based on BASE_URL
//
//////////////////////////////////////////////////////////////////
show: function( data_file ) {
var _this = this;
codiad.modal.load( 800, 'components/settings/dialog.php?action=settings' );
codiad.modal.hideOverlay();
codiad.modal.load_process.done( function() {
if ( typeof( data_file ) == 'string' ) {
codiad.settings._showTab( data_file );
} else {
_this._loadTabValues( 'components/settings/settings.editor.php' );
}
/* Notify listeners */
amplify.publish( 'settings.dialog.show', {} );
});
},
update_option: function( option, value ) {
if( option == undefined || value == undefined ) {
return false;
}
let _self = codiad.settings;
jQuery.ajax({
url: this.controller + '?action=update_option',
type: "POST",
dataType: 'html',
data: {
option: option,
value: value
},
success: function( data ) {
console.log( `Update Option ( ${option} ): ` + data );
_self.settings = null;
},
error: function(jqXHR, textStatus, errorThrown) {
console.log('jqXHR:');
console.log(jqXHR);
console.log('textStatus:');
console.log(textStatus);
console.log('errorThrown:');
console.log(errorThrown);
},
});
},
//////////////////////////////////////////////////////////////////
//
// {Private} Show Specific Tab
//
// Parameter
//
// data_file - {String} - Location of settings file based on BASE_URL
//
//////////////////////////////////////////////////////////////////
_showTab: function( data_file ) {
var _this = this;
if ( typeof( data_file ) != 'string' ) {
return false;
}
$( '.settings-view .config-menu .active' ).removeClass( 'active' );
$( '.settings-view .config-menu li[data-file="' + data_file + '"]' ).addClass( 'active' );
$( '.settings-view .panels .active' ).hide().removeClass( 'active' );
//Load panel
if( $( '.settings-view .panel[data-file="' + data_file + '"]' ).length === 0 ) {
$( '.settings-view .panels' ).append( '<div class="panel active" data-file="' + data_file + '"></div>' );
$( '.settings-view .panel[data-file="' + data_file + '"]' ).load( data_file, function() {
//TODO Show and hide loading information
/* Notify listeners */
var name = $( '.settings-view .config-menu li[data-file="' + data_file + '"]' ).attr( 'data-name' );
amplify.publish( 'settings.dialog.tab_loaded', name );
_this._loadTabValues( data_file );
});
} else {
$( '.settings-view .panel[data-file="' + data_file + '"]' ).show().addClass( 'active' );
}
},
//////////////////////////////////////////////////////////////////
//
// {Private} Load Settings of Specific Tab
//
// Parameter
//
// data_file - {String} - Location of settings file based on BASE_URL
//
//////////////////////////////////////////////////////////////////
_loadTabValues: function( data_file ) {
//Load settings
$( '.settings-view .panel[data-file="' + data_file + '"] .setting').each( async function( i, item ) {
let key = await $( item ).attr( 'data-setting' );
let value = await codiad.settings.get_option( key );
//console.log( key, value, i, $( item ).attr( 'data-setting' ) );
if ( value != null && value != undefined ) {
$( item ).val( value );
}
});
}
};
})(this, jQuery);