2018-01-22 13:01:38 -08:00
|
|
|
'use strict';
|
|
|
|
|
|
2019-01-22 10:54:03 +01:00
|
|
|
/* global angular:false */
|
|
|
|
|
/* global $:false */
|
2018-01-22 13:01:38 -08:00
|
|
|
|
2021-01-28 10:07:35 -08:00
|
|
|
angular.module('Application').controller('AppsController', ['$scope', '$translate', '$interval', '$location', 'Client', function ($scope, $translate, $interval, $location, Client) {
|
2019-05-20 23:40:02 +02:00
|
|
|
var ALL_DOMAINS_DOMAIN = { _alldomains: true, domain: 'All Domains' }; // dummy record for the single select filter
|
2021-03-02 17:30:01 -08:00
|
|
|
var GROUP_ACCESS_UNSET = { _unset: true, name: 'Select Group' }; // dummy record for the single select filter
|
2019-05-20 23:40:02 +02:00
|
|
|
|
2018-01-22 13:01:38 -08:00
|
|
|
$scope.installedApps = Client.getInstalledApps();
|
2019-04-12 11:06:56 +02:00
|
|
|
$scope.tags = Client.getAppTags();
|
2020-09-26 17:50:23 +02:00
|
|
|
$scope.states = [
|
|
|
|
|
{ state: '', label: 'All States' },
|
|
|
|
|
{ state: 'running', label: 'Running' },
|
2020-10-06 13:01:01 -07:00
|
|
|
{ state: 'stopped', label: 'Stopped' },
|
2022-05-14 14:45:22 +02:00
|
|
|
{ state: 'update_available', label: 'Update Available' },
|
2020-10-06 13:01:01 -07:00
|
|
|
{ state: 'not_responding', label: 'Not Responding' }
|
2020-09-26 17:50:23 +02:00
|
|
|
];
|
|
|
|
|
$scope.selectedState = $scope.states[0];
|
2019-04-12 11:06:56 +02:00
|
|
|
$scope.selectedTags = [];
|
2021-02-16 20:10:11 +01:00
|
|
|
$scope.selectedGroup = GROUP_ACCESS_UNSET;
|
2019-05-20 23:40:02 +02:00
|
|
|
$scope.selectedDomain = ALL_DOMAINS_DOMAIN;
|
|
|
|
|
$scope.filterDomains = [ ALL_DOMAINS_DOMAIN ];
|
2018-01-22 13:01:38 -08:00
|
|
|
$scope.config = Client.getConfig();
|
|
|
|
|
$scope.user = Client.getUserInfo();
|
|
|
|
|
$scope.domains = [];
|
2020-01-06 15:27:31 +01:00
|
|
|
$scope.appSearch = '';
|
2021-02-16 20:10:11 +01:00
|
|
|
$scope.groups = [ GROUP_ACCESS_UNSET ];
|
2018-01-22 13:01:38 -08:00
|
|
|
|
2022-05-14 14:45:22 +02:00
|
|
|
$translate(['apps.stateFilterHeader', 'apps.domainsFilterHeader', 'apps.groupsFilterHeader', 'app.states.running', 'app.states.stopped', 'app.states.notResponding', 'app.states.updateAvailable']).then(function (tr) {
|
2020-12-15 15:48:25 +01:00
|
|
|
if (tr['apps.domainsFilterHeader']) ALL_DOMAINS_DOMAIN.domain = tr['apps.domainsFilterHeader'];
|
2021-03-02 17:30:01 -08:00
|
|
|
if (tr['apps.groupsFilterHeader']) GROUP_ACCESS_UNSET.name = tr['apps.groupsFilterHeader'];
|
2020-12-15 15:48:25 +01:00
|
|
|
if (tr['apps.stateFilterHeader']) $scope.states[0].label = tr['apps.stateFilterHeader'];
|
|
|
|
|
if (tr['app.states.running']) $scope.states[1].label = tr['app.states.running'];
|
|
|
|
|
if (tr['app.states.stopped']) $scope.states[2].label = tr['app.states.stopped'];
|
2022-05-14 14:45:22 +02:00
|
|
|
if (tr['app.states.notResponding']) $scope.states[4].label = tr['app.states.notResponding'];
|
|
|
|
|
if (tr['app.states.updateAvailable']) $scope.states[3].label = tr['app.states.updateAvailable'];
|
2020-12-15 15:48:25 +01:00
|
|
|
});
|
|
|
|
|
|
2020-01-06 16:23:31 +01:00
|
|
|
$scope.$watch('selectedTags', function (newVal, oldVal) {
|
|
|
|
|
if (newVal === oldVal) return;
|
|
|
|
|
|
|
|
|
|
localStorage.selectedTags = newVal.join(',');
|
|
|
|
|
});
|
|
|
|
|
|
2021-11-11 15:11:09 +01:00
|
|
|
$scope.$watch('selectedState', function (newVal, oldVal) {
|
|
|
|
|
if (newVal === oldVal) return;
|
|
|
|
|
|
|
|
|
|
if (newVal === $scope.states[0]) localStorage.removeItem('selectedState');
|
|
|
|
|
else localStorage.selectedState = newVal.state;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$scope.$watch('selectedGroup', function (newVal, oldVal) {
|
|
|
|
|
if (newVal === oldVal) return;
|
|
|
|
|
|
|
|
|
|
if (newVal === GROUP_ACCESS_UNSET) localStorage.removeItem('selectedGroup');
|
|
|
|
|
else localStorage.selectedGroup = newVal.id;
|
|
|
|
|
});
|
|
|
|
|
|
2020-01-06 16:23:31 +01:00
|
|
|
$scope.$watch('selectedDomain', function (newVal, oldVal) {
|
|
|
|
|
if (newVal === oldVal) return;
|
|
|
|
|
|
|
|
|
|
if (newVal._alldomains) localStorage.removeItem('selectedDomain');
|
|
|
|
|
else localStorage.selectedDomain = newVal.domain;
|
|
|
|
|
});
|
|
|
|
|
|
2018-06-14 15:46:55 +02:00
|
|
|
$scope.appPostInstallConfirm = {
|
|
|
|
|
app: {},
|
|
|
|
|
message: '',
|
|
|
|
|
confirmed: false,
|
|
|
|
|
|
|
|
|
|
show: function (app) {
|
|
|
|
|
$scope.appPostInstallConfirm.app = app;
|
|
|
|
|
$scope.appPostInstallConfirm.message = app.manifest.postInstallMessage;
|
2019-09-18 18:10:51 +02:00
|
|
|
$scope.appPostInstallConfirm.confirmed = false;
|
2018-06-14 15:46:55 +02:00
|
|
|
|
|
|
|
|
$('#appPostInstallConfirmModal').modal('show');
|
|
|
|
|
|
|
|
|
|
return false; // prevent propagation and default
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
submit: function () {
|
2018-06-15 13:39:30 +02:00
|
|
|
if (!$scope.appPostInstallConfirm.confirmed) return;
|
|
|
|
|
|
2018-06-14 15:46:55 +02:00
|
|
|
$scope.appPostInstallConfirm.app.pendingPostInstallConfirmation = false;
|
|
|
|
|
delete localStorage['confirmPostInstall_' + $scope.appPostInstallConfirm.app.id];
|
|
|
|
|
|
|
|
|
|
$('#appPostInstallConfirmModal').modal('hide');
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2022-07-07 13:32:20 +02:00
|
|
|
$scope.applinksAdd = {
|
|
|
|
|
error: {},
|
|
|
|
|
busy: false,
|
|
|
|
|
upstreamUri: '',
|
|
|
|
|
|
|
|
|
|
show: function () {
|
|
|
|
|
$scope.applinksAdd.error = {};
|
|
|
|
|
$scope.applinksAdd.busy = false;
|
|
|
|
|
$scope.applinksAdd.upstreamUri = '';
|
|
|
|
|
|
2022-07-07 16:41:12 +02:00
|
|
|
$scope.applinksAddForm.$setUntouched();
|
|
|
|
|
$scope.applinksAddForm.$setPristine();
|
|
|
|
|
|
2022-07-07 13:32:20 +02:00
|
|
|
$('#applinksAddModal').modal('show');
|
|
|
|
|
|
|
|
|
|
return false; // prevent propagation and default
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
submit: function () {
|
|
|
|
|
if (!$scope.applinksAdd.upstreamUri) return;
|
|
|
|
|
|
|
|
|
|
Client.addApplink({ upstreamUri: $scope.applinksAdd.upstreamUri }, function (error, result) {
|
|
|
|
|
if (error) return console.error('Failed to add applink', error);
|
|
|
|
|
|
|
|
|
|
$('#applinksAddModal').modal('hide');
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2022-07-07 16:25:04 +02:00
|
|
|
$scope.applinksEdit = {
|
|
|
|
|
error: {},
|
2022-07-07 16:41:12 +02:00
|
|
|
busyEdit: false,
|
|
|
|
|
busyRemove: false,
|
2022-07-07 16:25:04 +02:00
|
|
|
id: '',
|
|
|
|
|
upstreamUri: '',
|
|
|
|
|
|
|
|
|
|
show: function (applink) {
|
|
|
|
|
$scope.applinksEdit.error = {};
|
2022-07-07 16:41:12 +02:00
|
|
|
$scope.applinksEdit.busyEdit = false;
|
|
|
|
|
$scope.applinksEdit.busyRemove = false;
|
2022-07-07 16:25:04 +02:00
|
|
|
$scope.applinksEdit.id = applink.id;
|
|
|
|
|
$scope.applinksEdit.upstreamUri = applink.upstreamUri;
|
|
|
|
|
|
2022-07-07 16:41:12 +02:00
|
|
|
$scope.applinksEditForm.$setUntouched();
|
|
|
|
|
$scope.applinksEditForm.$setPristine();
|
|
|
|
|
|
2022-07-07 16:25:04 +02:00
|
|
|
$('#applinksEditModal').modal('show');
|
|
|
|
|
|
|
|
|
|
return false; // prevent propagation and default
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
submit: function () {
|
2022-07-07 16:41:12 +02:00
|
|
|
$scope.applinksEdit.busyEdit = true;
|
|
|
|
|
|
|
|
|
|
var data = {
|
|
|
|
|
upstreamUri: $scope.applinksEdit.upstreamUri
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
Client.updateApplink($scope.applinksEdit.id, data, function (error) {
|
|
|
|
|
$scope.applinksEdit.busyEdit = false;
|
|
|
|
|
|
|
|
|
|
if (error) return console.error('Failed to update applink', error);
|
|
|
|
|
|
|
|
|
|
$('#applinksEditModal').modal('hide');
|
|
|
|
|
});
|
2022-07-07 16:25:04 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
|
|
remove: function () {
|
2022-07-07 16:41:12 +02:00
|
|
|
$scope.applinksEdit.busyRemove = true;
|
|
|
|
|
|
2022-07-07 16:25:04 +02:00
|
|
|
Client.removeApplink($scope.applinksEdit.id, function (error) {
|
2022-07-07 16:41:12 +02:00
|
|
|
$scope.applinksEdit.busyRemove = false;
|
|
|
|
|
|
2022-07-07 16:25:04 +02:00
|
|
|
if (error) return console.error('Failed to remove applink', error);
|
|
|
|
|
|
|
|
|
|
Client.refreshInstalledApps();
|
|
|
|
|
|
|
|
|
|
$('#applinksEditModal').modal('hide');
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2019-09-18 18:10:51 +02:00
|
|
|
$scope.showAppConfigure = function (app, view) {
|
|
|
|
|
$location.path('/app/' + app.id + '/' + view);
|
2018-01-22 13:01:38 -08:00
|
|
|
};
|
|
|
|
|
|
2021-09-21 15:26:05 -07:00
|
|
|
$scope.isOperator = function (app) {
|
|
|
|
|
return app.accessLevel === 'operator' || app.accessLevel === 'admin';
|
|
|
|
|
};
|
|
|
|
|
|
2019-09-18 18:10:51 +02:00
|
|
|
Client.onReady(function () {
|
2020-04-28 15:52:04 +02:00
|
|
|
setTimeout(function () { $('#appSearch').focus(); }, 1);
|
|
|
|
|
|
2020-01-07 12:17:40 +01:00
|
|
|
// refresh the new list immediately when switching from another view (appstore)
|
|
|
|
|
Client.refreshInstalledApps(function () {
|
|
|
|
|
var refreshAppsTimer = $interval(Client.refreshInstalledApps.bind(Client, function () {}), 5000);
|
|
|
|
|
$scope.$on('$destroy', function () {
|
|
|
|
|
$interval.cancel(refreshAppsTimer);
|
|
|
|
|
});
|
2020-04-28 15:52:04 +02:00
|
|
|
});
|
2020-01-07 12:17:40 +01:00
|
|
|
|
2020-04-28 15:52:04 +02:00
|
|
|
if (!$scope.user.isAtLeastAdmin) return;
|
2020-01-07 12:17:40 +01:00
|
|
|
|
2020-04-28 15:52:04 +02:00
|
|
|
// load local settings and apply tag filter
|
|
|
|
|
if (localStorage.selectedTags) {
|
|
|
|
|
if (!$scope.tags.length) localStorage.removeItem('selectedTags');
|
|
|
|
|
else $scope.selectedTags = localStorage.selectedTags.split(',');
|
|
|
|
|
}
|
2020-01-07 12:17:40 +01:00
|
|
|
|
2021-11-11 15:11:09 +01:00
|
|
|
if (localStorage.selectedState) $scope.selectedState = $scope.states.find(function (s) { return s.state === localStorage.selectedState; }) || $scope.states[0];
|
|
|
|
|
|
2021-02-16 20:10:11 +01:00
|
|
|
Client.getGroups(function (error, result) {
|
|
|
|
|
if (error) Client.error(error);
|
|
|
|
|
|
|
|
|
|
$scope.groups = [ GROUP_ACCESS_UNSET ].concat(result);
|
2021-11-11 15:11:09 +01:00
|
|
|
|
|
|
|
|
if (localStorage.selectedGroup) $scope.selectedGroup = $scope.groups.find(function (g) { return g.id === localStorage.selectedGroup; }) || GROUP_ACCESS_UNSET;
|
2021-02-16 20:10:11 +01:00
|
|
|
});
|
|
|
|
|
|
2020-04-28 15:52:04 +02:00
|
|
|
Client.getDomains(function (error, result) {
|
|
|
|
|
if (error) Client.error(error);
|
2020-01-07 12:17:40 +01:00
|
|
|
|
2020-04-28 15:52:04 +02:00
|
|
|
$scope.domains = result;
|
|
|
|
|
$scope.filterDomains = [ALL_DOMAINS_DOMAIN].concat(result);
|
2020-01-07 12:17:40 +01:00
|
|
|
|
2020-04-28 15:52:04 +02:00
|
|
|
if (localStorage.selectedDomain) $scope.selectedDomain = $scope.filterDomains.find(function (d) { return d.domain === localStorage.selectedDomain; }) || ALL_DOMAINS_DOMAIN;
|
2018-01-22 13:01:38 -08:00
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
2022-07-07 13:32:20 +02:00
|
|
|
// setup all the dialog focus handling
|
|
|
|
|
['applinksAddModal'].forEach(function (id) {
|
|
|
|
|
$('#' + id).on('shown.bs.modal', function () {
|
|
|
|
|
$(this).find("[autofocus]:first").focus();
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
2020-06-24 23:06:12 -07:00
|
|
|
$('.collapse').on('shown.bs.collapse', function(){
|
|
|
|
|
$(this).parent().find('.fa-angle-right').removeClass('fa-angle-right').addClass('fa-angle-down');
|
|
|
|
|
}).on('hidden.bs.collapse', function(){
|
|
|
|
|
$(this).parent().find('.fa-angle-down').removeClass('fa-angle-down').addClass('fa-angle-right');
|
|
|
|
|
});
|
|
|
|
|
|
2018-01-22 13:01:38 -08:00
|
|
|
$('.modal-backdrop').remove();
|
|
|
|
|
}]);
|