You've already forked nginx-proxy-manager
							
							
				mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-10-24 20:52:57 +03:00 
			
		
		
		
	Add search function for redirection
This commit is contained in:
		| @@ -3,6 +3,14 @@ | |||||||
|     <div class="card-header"> |     <div class="card-header"> | ||||||
|         <h3 class="card-title">Redirection Hosts</h3> |         <h3 class="card-title">Redirection Hosts</h3> | ||||||
|         <div class="card-options"> |         <div class="card-options"> | ||||||
|  |             <form class="search-form" role="search"> | ||||||
|  |                 <div class="input-icon"> | ||||||
|  |                     <span class="input-icon-addon"> | ||||||
|  |                       <i class="fe fe-search"></i> | ||||||
|  |                     </span> | ||||||
|  |                     <input name="source-query" type="text" value="" class="form-control form-control-sm" placeholder="Search Host…" aria-label="Search in Hosts"> | ||||||
|  |                 </div> | ||||||
|  |             </form> | ||||||
|             <a href="#" class="btn btn-outline-secondary btn-sm ml-2 help"><i class="fe fe-help-circle"></i></a> |             <a href="#" class="btn btn-outline-secondary btn-sm ml-2 help"><i class="fe fe-help-circle"></i></a> | ||||||
|             <% if (showAddButton) { %> |             <% if (showAddButton) { %> | ||||||
|             <a href="#" class="btn btn-outline-yellow btn-sm ml-2 add-item">Add Redirection Host</a> |             <a href="#" class="btn btn-outline-yellow btn-sm ml-2 add-item">Add Redirection Host</a> | ||||||
|   | |||||||
| @@ -14,7 +14,28 @@ module.exports = Mn.View.extend({ | |||||||
|         list_region: '.list-region', |         list_region: '.list-region', | ||||||
|         add:         '.add-item', |         add:         '.add-item', | ||||||
|         help:        '.help', |         help:        '.help', | ||||||
|         dimmer:      '.dimmer' |         dimmer:      '.dimmer', | ||||||
|  |         search:      '.search-form', | ||||||
|  |         query:       'input[name="source-query"]' | ||||||
|  |     }, | ||||||
|  |  | ||||||
|  |     fetch: App.Api.Nginx.RedirectionHosts.getAll, | ||||||
|  |  | ||||||
|  |     showData: function(response) { | ||||||
|  |         this.showChildView('list_region', new ListView({ | ||||||
|  |             collection: new RedirectionHostModel.Collection(response) | ||||||
|  |         })); | ||||||
|  |     }, | ||||||
|  |  | ||||||
|  |     showError: function(err) { | ||||||
|  |         this.showChildView('list_region', new ErrorView({ | ||||||
|  |             code:    err.code, | ||||||
|  |             message: err.message, | ||||||
|  |             retry:   function () { | ||||||
|  |                 App.Controller.showNginxRedirection(); | ||||||
|  |             } | ||||||
|  |         })); | ||||||
|  |         console.error(err); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|     regions: { |     regions: { | ||||||
| @@ -30,6 +51,17 @@ module.exports = Mn.View.extend({ | |||||||
|         'click @ui.help': function (e) { |         'click @ui.help': function (e) { | ||||||
|             e.preventDefault(); |             e.preventDefault(); | ||||||
|             App.Controller.showHelp(App.i18n('redirection-hosts', 'help-title'), App.i18n('redirection-hosts', 'help-content')); |             App.Controller.showHelp(App.i18n('redirection-hosts', 'help-title'), App.i18n('redirection-hosts', 'help-content')); | ||||||
|  |         }, | ||||||
|  |  | ||||||
|  |         'submit @ui.search': function (e) { | ||||||
|  |             e.preventDefault(); | ||||||
|  |             let query = this.ui.query.val(); | ||||||
|  |  | ||||||
|  |             this.fetch(['owner', 'certificate'], query) | ||||||
|  |                 .then(response => this.showData(response)) | ||||||
|  |                 .catch(err => { | ||||||
|  |                     this.showError(err); | ||||||
|  |                 }); | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
| @@ -40,13 +72,11 @@ module.exports = Mn.View.extend({ | |||||||
|     onRender: function () { |     onRender: function () { | ||||||
|         let view = this; |         let view = this; | ||||||
|  |  | ||||||
|         App.Api.Nginx.RedirectionHosts.getAll(['owner', 'certificate']) |         view.fetch(['owner', 'certificate']) | ||||||
|             .then(response => { |             .then(response => { | ||||||
|                 if (!view.isDestroyed()) { |                 if (!view.isDestroyed()) { | ||||||
|                     if (response && response.length) { |                     if (response && response.length) { | ||||||
|                         view.showChildView('list_region', new ListView({ |                         view.showData(response); | ||||||
|                             collection: new RedirectionHostModel.Collection(response) |  | ||||||
|                         })); |  | ||||||
|                     } else { |                     } else { | ||||||
|                         let manage = App.Cache.User.canManage('redirection_hosts'); |                         let manage = App.Cache.User.canManage('redirection_hosts'); | ||||||
|  |  | ||||||
| @@ -64,15 +94,7 @@ module.exports = Mn.View.extend({ | |||||||
|                 } |                 } | ||||||
|             }) |             }) | ||||||
|             .catch(err => { |             .catch(err => { | ||||||
|                 view.showChildView('list_region', new ErrorView({ |                 view.showError(err); | ||||||
|                     code:    err.code, |  | ||||||
|                     message: err.message, |  | ||||||
|                     retry:   function () { |  | ||||||
|                         App.Controller.showNginxRedirection(); |  | ||||||
|                     } |  | ||||||
|                 })); |  | ||||||
|  |  | ||||||
|                 console.error(err); |  | ||||||
|             }) |             }) | ||||||
|             .then(() => { |             .then(() => { | ||||||
|                 view.ui.dimmer.removeClass('active'); |                 view.ui.dimmer.removeClass('active'); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user