Skip to content

Commit

Permalink
displayShareButton and displaySettingsButton booleans
Browse files Browse the repository at this point in the history
Refactor to these two boolean values which control show/hide of the two buttons, with some shared logic in the controller.

Remove unnecessary CSS for show/hide (use ng-if instead)

Fix up tests to suit
  • Loading branch information
megahirt committed Feb 4, 2022
1 parent a0b7b65 commit 82cd457
Show file tree
Hide file tree
Showing 5 changed files with 10 additions and 27 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@
<breadcrumbs id="top" class="breadcrumbs d-none d-md-block"></breadcrumbs>
</div>
<ul class="nav navbar-nav">
<li class="nav-item" ng-if="$ctrl.isLexiconProject" id="settings-dropdown-button" uib-dropdown data-ng-class="{'app-settings-available': $ctrl.header.settings.length > 0 && $ctrl.currentUserIsProjectManager}">
<li class="nav-item" ng-if="$ctrl.displaySettingsButton" id="settings-dropdown-button" uib-dropdown>
<a id="settingsBtn" class="btn btn-primary my-auto" uib-dropdown-toggle title="Settings" href="#">
<i class="fa fa-cog iconPadding"></i><span>Settings</span>
</a>
Expand All @@ -95,7 +95,7 @@
{% endverbatim %}
</div>
</li>
<li class='nav-item' ng-if="$ctrl.isLexiconProject">
<li class='nav-item' ng-if="$ctrl.displayShareButton">
<a id="shareBtn" class="btn btn-primary my-auto" title="Share" href="#"
ng-click="$ctrl.openShareWithOthersModal()">
<i class="fa fa-share-alt iconPadding"></i><span>Share</span>
Expand Down
14 changes: 1 addition & 13 deletions src/Site/views/languageforge/theme/default/sass/_global.scss
Original file line number Diff line number Diff line change
Expand Up @@ -264,18 +264,6 @@
}
}

#settings-dropdown-button:not(.app-settings-available) {
.dropdown-toggle {
visibility: hidden;
}
}

#settings-dropdown-button.app-settings-available {
.dropdown-toggle {
visibility: visible;
}
}

#settingsBtn {
margin: 12px;
margin-right: 6px;
Expand All @@ -287,7 +275,7 @@
font-size: 1rem;
}
}

#settingsBtn::after {
display:none;
}
Expand Down
15 changes: 5 additions & 10 deletions src/angular-app/bellows/core/navbar.controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,15 +21,16 @@ export class NavbarController implements angular.IController {
project: Project;
interfaceConfig: InterfaceConfig;
currentUserIsProjectManager: boolean;
displayHeaderButtons: boolean;
displayShareButton: boolean;
displaySettingsButton: boolean;
projectTypeNames: ProjectTypeNames;
siteName: string;
isLexiconProject: boolean = false;

static $inject = [
'$scope',
'$uibModal',
'projectService',
'projectService',
'sessionService',
'offlineCacheUtils',
'applicationHeaderService'];
Expand Down Expand Up @@ -75,21 +76,15 @@ export class NavbarController implements angular.IController {
this.currentUserIsProjectManager =
(session.data.userProjectRole === ProjectRoles.MANAGER.key) ||
(session.data.userProjectRole === ProjectRoles.TECH_SUPPORT.key);
this.displayHeaderButtons =
this.displayShareButton =
(this.currentUserIsProjectManager || (this.project.allowSharing && this.session.data.userIsProjectMember));
this.displaySettingsButton = (this.currentUserIsProjectManager && this.header.settings.length > 0);
}

this.rights.canCreateProject =
session.hasSiteRight(this.sessionService.domain.PROJECTS, this.sessionService.operation.CREATE);
this.siteName = session.baseSite();
});
this.$scope.$on('$locationChangeStart', (event, next, current) => {
if (current.includes('/lexicon') && !current.includes('/new-project') && this.displayHeaderButtons) {
this.isLexiconProject = true;
}else{
this.isLexiconProject = false;
}
});
}

onUpdate = ($event: { interfaceConfig: InterfaceConfig}): void => {
Expand Down
2 changes: 1 addition & 1 deletion test/app/bellows/project-settings.e2e-spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ describe('Bellows E2E Project Settings app', () => {
await loginPage.loginAsMember();
await projectsPage.get();
await projectsPage.clickOnProject(constants.testProjectName);
expect<string>(await settingsPage.settingsMenuLink.getAttribute('class')).not.toContain('app-settings-available');
expect<boolean>(await settingsPage.settingsMenuLink.isDisplayed()).toBe(false);
});

it('System Admin can manage project', async () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ describe('Lexicon E2E Configuration Input Systems', () => {
await loginPage.loginAsUser();
await projectsPage.get();
await projectsPage.clickOnProject(constants.testProjectName);
expect<any>(await configPage.settingsMenuLink.getAttribute('class')).not.toContain('app-settings-available');
expect<boolean>(await configPage.settingsMenuLink.isDisplayed()).toBe(false);
});

it('setup: login as manager, select test project, goto configuration', async () => {
Expand Down

0 comments on commit 82cd457

Please sign in to comment.