Files
cloudron-box/src/views/apps.js

236 lines
8.7 KiB
JavaScript
Raw Normal View History

2018-01-22 13:01:38 -08:00
'use strict';
/* 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
});
$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;
});
$scope.$watch('selectedDomain', function (newVal, oldVal) {
if (newVal === oldVal) return;
if (newVal._alldomains) localStorage.removeItem('selectedDomain');
else localStorage.selectedDomain = newVal.domain;
});
$scope.appPostInstallConfirm = {
app: {},
message: '',
confirmed: false,
show: function (app) {
$scope.appPostInstallConfirm.app = app;
$scope.appPostInstallConfirm.message = app.manifest.postInstallMessage;
$scope.appPostInstallConfirm.confirmed = false;
$('#appPostInstallConfirmModal').modal('show');
return false; // prevent propagation and default
},
submit: function () {
if (!$scope.appPostInstallConfirm.confirmed) return;
$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');
});
}
};
$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';
};
Client.onReady(function () {
setTimeout(function () { $('#appSearch').focus(); }, 1);
// 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);
});
});
if (!$scope.user.isAtLeastAdmin) return;
// load local settings and apply tag filter
if (localStorage.selectedTags) {
if (!$scope.tags.length) localStorage.removeItem('selectedTags');
else $scope.selectedTags = localStorage.selectedTags.split(',');
}
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
});
Client.getDomains(function (error, result) {
if (error) Client.error(error);
$scope.domains = result;
$scope.filterDomains = [ALL_DOMAINS_DOMAIN].concat(result);
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();
}]);