mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-10-22 19:43:32 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			109 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| const Mn            = require('backbone.marionette');
 | |
| const App           = require('../../main');
 | |
| const DeadHostModel = require('../../../models/dead-host');
 | |
| const ListView      = require('./list/main');
 | |
| const ErrorView     = require('../../error/main');
 | |
| const EmptyView     = require('../../empty/main');
 | |
| const template      = require('./main.ejs');
 | |
| 
 | |
| module.exports = Mn.View.extend({
 | |
|     id:       'nginx-dead',
 | |
|     template: template,
 | |
| 
 | |
|     ui: {
 | |
|         list_region: '.list-region',
 | |
|         add:         '.add-item',
 | |
|         help:        '.help',
 | |
|         dimmer:      '.dimmer',
 | |
|         search:      '.search-form',
 | |
|         query:       'input[name="source-query"]'
 | |
|     },
 | |
| 
 | |
|     fetch: App.Api.Nginx.DeadHosts.getAll,
 | |
| 
 | |
|     showData: function(response) {
 | |
|         this.showChildView('list_region', new ListView({
 | |
|             collection: new DeadHostModel.Collection(response)
 | |
|         }));
 | |
|     },
 | |
| 
 | |
|     showError: function(err) {
 | |
|         this.showChildView('list_region', new ErrorView({
 | |
|             code:    err.code,
 | |
|             message: err.message,
 | |
|             retry:   function () {
 | |
|                 App.Controller.showNginxDead();
 | |
|             }
 | |
|         }));
 | |
| 
 | |
|         console.error(err);
 | |
|     },
 | |
| 
 | |
|     showEmpty: function() {
 | |
|         let manage = App.Cache.User.canManage('dead_hosts');
 | |
| 
 | |
|         this.showChildView('list_region', new EmptyView({
 | |
|             title:      App.i18n('dead-hosts', 'empty'),
 | |
|             subtitle:   App.i18n('all-hosts', 'empty-subtitle', {manage: manage}),
 | |
|             link:       manage ? App.i18n('dead-hosts', 'add') : null,
 | |
|             btn_color:  'danger',
 | |
|             permission: 'dead_hosts',
 | |
|             action:     function () {
 | |
|                 App.Controller.showNginxDeadForm();
 | |
|             }
 | |
|         }));
 | |
|     },
 | |
| 
 | |
|     regions: {
 | |
|         list_region: '@ui.list_region'
 | |
|     },
 | |
| 
 | |
|     events: {
 | |
|         'click @ui.add': function (e) {
 | |
|             e.preventDefault();
 | |
|             App.Controller.showNginxDeadForm();
 | |
|         },
 | |
| 
 | |
|         'click @ui.help': function (e) {
 | |
|             e.preventDefault();
 | |
|             App.Controller.showHelp(App.i18n('dead-hosts', 'help-title'), App.i18n('dead-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);
 | |
|                 });
 | |
|         }
 | |
|     },
 | |
| 
 | |
|     templateContext: {
 | |
|         showAddButton: App.Cache.User.canManage('dead_hosts')
 | |
|     },
 | |
| 
 | |
|     onRender: function () {
 | |
|         let view = this;
 | |
| 
 | |
|         view.fetch(['owner', 'certificate'])
 | |
|             .then(response => {
 | |
|                 if (!view.isDestroyed()) {
 | |
|                     if (response && response.length) {
 | |
|                         view.showData(response);
 | |
|                     } else {
 | |
|                         view.showEmpty();
 | |
|                     }
 | |
|                 }
 | |
|             })
 | |
|             .catch(err => {
 | |
|                 view.showError(err);
 | |
|             })
 | |
|             .then(() => {
 | |
|                 view.ui.dimmer.removeClass('active');
 | |
|             });
 | |
|     }
 | |
| });
 |