mirror of
https://github.com/bitwarden/browser
synced 2025-12-17 08:43:33 +00:00
79 lines
2.5 KiB
JavaScript
79 lines
2.5 KiB
JavaScript
angular
|
|
.module('bit.vault')
|
|
|
|
.controller('vaultAddSiteController', function ($scope, $state, $stateParams, siteService, folderService,
|
|
cryptoService, $q, toastr, utilsService, $analytics, i18nService) {
|
|
$scope.i18n = i18nService;
|
|
var from = $stateParams.from,
|
|
folderId = $stateParams.folderId;
|
|
|
|
$scope.site = {
|
|
folderId: folderId,
|
|
name: $stateParams.name,
|
|
uri: $stateParams.uri
|
|
};
|
|
|
|
if ($stateParams.site) {
|
|
angular.extend($scope.site, $stateParams.site);
|
|
}
|
|
|
|
if (!$stateParams.site && $scope.site.name && $scope.site.uri) {
|
|
$('#username').focus();
|
|
}
|
|
else {
|
|
$('#name').focus();
|
|
}
|
|
utilsService.initListSectionItemListeners($(document), angular);
|
|
|
|
$q.when(folderService.getAllDecrypted()).then(function (folders) {
|
|
$scope.folders = folders;
|
|
});
|
|
|
|
$scope.savePromise = null;
|
|
$scope.save = function (model) {
|
|
if (!model.name) {
|
|
toastr.error(i18nService.nameRequired, i18nService.errorsOccurred);
|
|
return;
|
|
}
|
|
|
|
$scope.savePromise = $q.when(siteService.encrypt(model)).then(function (siteModel) {
|
|
var site = new Site(siteModel, true);
|
|
return $q.when(siteService.saveWithServer(site)).then(function (site) {
|
|
$analytics.eventTrack('Added Site');
|
|
toastr.success(i18nService.addedSite);
|
|
$scope.close();
|
|
});
|
|
});
|
|
};
|
|
|
|
$scope.close = function () {
|
|
if (from === 'current') {
|
|
$state.go('tabs.current', {
|
|
animation: 'out-slide-down'
|
|
});
|
|
}
|
|
else if (from === 'folder') {
|
|
$state.go('viewFolder', {
|
|
animation: 'out-slide-down',
|
|
folderId: folderId
|
|
});
|
|
}
|
|
else {
|
|
$state.go('tabs.vault', {
|
|
animation: 'out-slide-down'
|
|
});
|
|
}
|
|
};
|
|
|
|
$scope.generatePassword = function () {
|
|
$analytics.eventTrack('Clicked Generate Password');
|
|
$state.go('passwordGenerator', {
|
|
animation: 'in-slide-up',
|
|
addState: {
|
|
from: from,
|
|
site: $scope.site
|
|
}
|
|
});
|
|
};
|
|
});
|