From 348f84c32fa493189e8eeb452ddb201301293344 Mon Sep 17 00:00:00 2001 From: Stefan Matheis Date: Sat, 5 Jan 2013 14:21:28 +0000 Subject: [PATCH] SOLR-3851: create a new core/delete an existing core should also update the main/left list of cores on the admin UI git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1429286 13f79535-47bb-0310-9956-ffa450edef68 --- solr/CHANGES.txt | 3 + solr/webapp/web/js/scripts/app.js | 174 +++++++++++++++++----------- solr/webapp/web/js/scripts/cores.js | 6 +- 3 files changed, 111 insertions(+), 72 deletions(-) diff --git a/solr/CHANGES.txt b/solr/CHANGES.txt index a2a84217e7b..f592ef211da 100644 --- a/solr/CHANGES.txt +++ b/solr/CHANGES.txt @@ -222,6 +222,9 @@ Optimizations * SOLR-4261: Percentage Infos on Dashboard have a fixed width (steffkes) +* SOLR-3851: create a new core/delete an existing core should also update + the main/left list of cores on the admin UI (steffkes) + Bug Fixes ---------------------- diff --git a/solr/webapp/web/js/scripts/app.js b/solr/webapp/web/js/scripts/app.js index 3df019ab30b..cc35a367262 100644 --- a/solr/webapp/web/js/scripts/app.js +++ b/solr/webapp/web/js/scripts/app.js @@ -172,6 +172,110 @@ var solr_admin = function( app_config ) } }; + sort_cores_data = function sort_cores_data( cores_status ) + { + // build array of core-names for sorting + var core_names = []; + for( var core_name in cores_status ) + { + core_names.push( core_name ); + } + core_names.sort(); + + var core_count = core_names.length; + var cores = {}; + + for( var i = 0; i < core_count; i++ ) + { + var core_name = core_names[i]; + cores[core_name] = cores_status[core_name]; + } + + return cores; + }; + + this.set_cores_data = function set_cores_data( cores ) + { + self.cores_data = sort_cores_data( cores.status ); + + self.menu_element + .empty(); + + var core_count = 0; + for( var core_name in self.cores_data ) + { + core_count++; + var core_path = config.solr_path + '/' + core_name; + var classes = []; + + if( !environment_basepath ) + { + environment_basepath = core_path; + } + + if( cores.status[core_name]['isDefaultCore'] ) + { + classes.push( 'default' ); + } + + var core_tpl = '
  • ' + "\n" + + '

    ' + core_name + '

    ' + "\n" + + ' ' + "\n" + + '
  • '; + + self.menu_element + .append( core_tpl ); + } + + if( cores.initFailures ) + { + var failures = []; + for( var core_name in cores.initFailures ) + { + failures.push + ( + '
  • ' + + '' + core_name.esc() + ':' + "\n" + + cores.initFailures[core_name].esc() + "\n" + + '
  • ' + ); + } + + if( 0 !== failures.length ) + { + var init_failures = $( '#init-failures' ); + + init_failures.show(); + $( 'ul', init_failures ).html( failures.join( "\n" ) ); + } + } + + if( 0 === core_count ) + { + show_global_error + ( + '
    There are no SolrCores running.
    Using the Solr Admin UI currently requires at least one SolrCore.
    ' + ); + } // else: we have at least one core.... + }; + this.run = function() { $.ajax @@ -186,85 +290,17 @@ var solr_admin = function( app_config ) }, success : function( response ) { - self.cores_data = response.status; - var core_count = 0; + self.set_cores_data( response ); for( var core_name in response.status ) { - core_count++; var core_path = config.solr_path + '/' + core_name; - var schema = response['status'][core_name]['schema']; - var solrconfig = response['status'][core_name]['config']; - var classes = []; - if( !environment_basepath ) { environment_basepath = core_path; } - - if( response['status'][core_name]['isDefaultCore'] ) - { - classes.push( 'default' ); - } - - var core_tpl = '
  • ' + "\n" - + '

    ' + core_name + '

    ' + "\n" - + ' ' + "\n" - + '
  • '; - - self.menu_element - .append( core_tpl ); } - if( response.initFailures ) - { - var failures = []; - for( var core_name in response.initFailures ) - { - failures.push - ( - '
  • ' + - '' + core_name.esc() + ':' + "\n" + - response.initFailures[core_name].esc() + "\n" + - '
  • ' - ); - } - - if( 0 !== failures.length ) - { - var init_failures = $( '#init-failures' ); - - init_failures.show(); - $( 'ul', init_failures ).html( failures.join( "\n" ) ); - } - } - - if( 0 === core_count ) - { - show_global_error - ( - '
    There are no SolrCores running.
    Using the Solr Admin UI currently requires at least one SolrCore.
    ' - ); - return; - } // else: we have at least one core.... - var system_url = environment_basepath + '/admin/system?wt=json'; $.ajax ( diff --git a/solr/webapp/web/js/scripts/cores.js b/solr/webapp/web/js/scripts/cores.js index c60ea128ec5..623f09e576f 100644 --- a/solr/webapp/web/js/scripts/cores.js +++ b/solr/webapp/web/js/scripts/cores.js @@ -36,7 +36,7 @@ sammy.bind }, success : function( response, text_status, xhr ) { - app.cores_data = response.status; + app.set_cores_data( response ); params.callback( app.cores_data ); }, error : function( xhr, text_status, error_thrown) @@ -189,7 +189,7 @@ sammy.get // index-data $( '.lastModified dd', index_data_element ) - .html( core_data.index.lastModified ); + .html( core_data.index.lastModified || '-' ); $( '.version dd', index_data_element ) .html( core_data.index.version ); @@ -201,7 +201,7 @@ sammy.get .html( core_data.index.maxDoc ); $( '.deletedDocs dd', index_data_element ) - .html( core_data.index.deletedDocs ); + .html( core_data.index.deletedDocs || '-' ); $( '.optimized dd', index_data_element ) .addClass( !core_data.index.hasDeletions ? 'ico-1' : 'ico-0' );