overleaf/services/web/frontend/js/ide/permissions/PermissionsManager.js
Hugh O'Brien 7a315bfa4d Merge pull request #2759 from overleaf/hb-read-only-on-connection-lost
Read only mode on lost connection and local file contents on Out of Sync error

GitOrigin-RevId: e31a259be122ad162e98746cd06a7794a95e78fa
2020-05-02 03:19:31 +00:00

51 lines
1.7 KiB
JavaScript

/* eslint-disable
no-return-assign,
no-undef,
no-unused-vars,
*/
// TODO: This file was created by bulk-decaffeinate.
// Fix any style issues and re-enable lint.
/*
* decaffeinate suggestions:
* DS102: Remove unnecessary code created because of implicit returns
* DS207: Consider shorter variations of null checks
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
*/
define([], function() {
let PermissionsManager
return (PermissionsManager = class PermissionsManager {
constructor(ide, $scope) {
this.ide = ide
this.$scope = $scope
this.$scope.permissions = {
read: false,
write: false,
admin: false,
comment: false
}
this.$scope.$watch('permissionsLevel', permissionsLevel => {
if (permissionsLevel != null) {
if (permissionsLevel === 'readOnly') {
this.$scope.permissions.read = true
this.$scope.permissions.write = false
this.$scope.permissions.admin = false
this.$scope.permissions.comment = true
} else if (permissionsLevel === 'readAndWrite') {
this.$scope.permissions.read = true
this.$scope.permissions.write = true
this.$scope.permissions.comment = true
} else if (permissionsLevel === 'owner') {
this.$scope.permissions.read = true
this.$scope.permissions.write = true
this.$scope.permissions.admin = true
this.$scope.permissions.comment = true
}
}
if (this.$scope.anonymous) {
return (this.$scope.permissions.comment = false)
}
})
}
})
})