mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-05-19 17:14:45 +00:00
app.config and login
This commit is contained in:
parent
eaf07c129a
commit
8809c1e122
@ -10,6 +10,7 @@
|
|||||||
"assets": [
|
"assets": [
|
||||||
"assets",
|
"assets",
|
||||||
"favicon-96x96.png",
|
"favicon-96x96.png",
|
||||||
|
"app.config.json",
|
||||||
|
|
||||||
{ "glob": "**/*", "input": "../node_modules/ng2-alfresco-core/bundles/assets", "output": "./assets/" },
|
{ "glob": "**/*", "input": "../node_modules/ng2-alfresco-core/bundles/assets", "output": "./assets/" },
|
||||||
{ "glob": "**/*", "input": "../node_modules/ng2-alfresco-datatable/bundles/assets", "output": "./assets/" },
|
{ "glob": "**/*", "input": "../node_modules/ng2-alfresco-datatable/bundles/assets", "output": "./assets/" },
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
"@angular/material": "2.0.0-beta.10",
|
"@angular/material": "2.0.0-beta.10",
|
||||||
"@angular/platform-browser": "4.3.6",
|
"@angular/platform-browser": "4.3.6",
|
||||||
"@angular/platform-browser-dynamic": "4.3.6",
|
"@angular/platform-browser-dynamic": "4.3.6",
|
||||||
"@angular/router": "~3.1.1",
|
"@angular/router": "4.3.6",
|
||||||
"@ngx-translate/core": "7.0.0",
|
"@ngx-translate/core": "7.0.0",
|
||||||
"alfresco-js-api": "1.9.0",
|
"alfresco-js-api": "1.9.0",
|
||||||
"core-js": "^2.4.1",
|
"core-js": "^2.4.1",
|
||||||
|
18
src/app.config.json
Normal file
18
src/app.config.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"ecmHost": "http://{hostname}:{port}/ecm",
|
||||||
|
"application": {
|
||||||
|
"name": "Alfresco Example Content Application",
|
||||||
|
"build": "1234"
|
||||||
|
},
|
||||||
|
"document-list": {
|
||||||
|
"supportedPageSizes": [25, 50, 100]
|
||||||
|
},
|
||||||
|
"files": {
|
||||||
|
"excluded": [
|
||||||
|
".DS_Store",
|
||||||
|
"desktop.ini",
|
||||||
|
"thumbs.db",
|
||||||
|
".git"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
@ -1,20 +1 @@
|
|||||||
<!--The content below is only a placeholder and can be replaced.-->
|
<router-outlet></router-outlet>
|
||||||
<div style="text-align:center">
|
|
||||||
<h1>
|
|
||||||
Welcome to {{title}}!
|
|
||||||
</h1>
|
|
||||||
<img width="300" src="">
|
|
||||||
</div>
|
|
||||||
<h2>Here are some links to help you start: </h2>
|
|
||||||
<ul>
|
|
||||||
<li>
|
|
||||||
<h2><a target="_blank" rel="noopener" href="https://angular.io/tutorial">Tour of Heroes</a></h2>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<h2><a target="_blank" rel="noopener" href="https://github.com/angular/angular-cli/wiki">CLI Documentation</a></h2>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<h2><a target="_blank" rel="noopener" href="https://blog.angular.io/">Angular blog</a></h2>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
|
@ -1,10 +1,60 @@
|
|||||||
import { Component } from '@angular/core';
|
/*!
|
||||||
|
* @license
|
||||||
|
* Copyright 2017 Alfresco Software, Ltd.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { Component, OnInit } from '@angular/core';
|
||||||
|
import { Router, ActivatedRoute, NavigationEnd } from '@angular/router';
|
||||||
|
import { TranslationService, PageTitleService } from 'ng2-alfresco-core';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-root',
|
selector: 'app-root',
|
||||||
templateUrl: './app.component.html',
|
templateUrl: './app.component.html',
|
||||||
styleUrls: ['./app.component.scss']
|
styleUrls: ['./app.component.scss']
|
||||||
})
|
})
|
||||||
export class AppComponent {
|
export class AppComponent implements OnInit {
|
||||||
title = 'app';
|
constructor(
|
||||||
|
private route: ActivatedRoute,
|
||||||
|
private router: Router,
|
||||||
|
private pageTitle: PageTitleService,
|
||||||
|
private translateService: TranslationService) {
|
||||||
|
}
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
const { router, pageTitle, route, translateService } = this;
|
||||||
|
|
||||||
|
router
|
||||||
|
.events
|
||||||
|
.filter(event => event instanceof NavigationEnd)
|
||||||
|
.subscribe(() => {
|
||||||
|
let currentRoute = route.root;
|
||||||
|
|
||||||
|
while (currentRoute.firstChild) {
|
||||||
|
currentRoute = currentRoute.firstChild;
|
||||||
|
}
|
||||||
|
|
||||||
|
const snapshot: any = currentRoute.snapshot || {};
|
||||||
|
const data: any = snapshot.data || {};
|
||||||
|
|
||||||
|
if (data.i18nTitle) {
|
||||||
|
translateService.get(data.i18nTitle).subscribe(title => {
|
||||||
|
pageTitle.setTitle(title);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
pageTitle.setTitle(data.title || '');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,17 +1,25 @@
|
|||||||
import { BrowserModule } from '@angular/platform-browser';
|
import { BrowserModule } from '@angular/platform-browser';
|
||||||
import { NgModule } from '@angular/core';
|
import { NgModule } from '@angular/core';
|
||||||
|
import { RouterModule } from '@angular/router';
|
||||||
|
|
||||||
import { AdfModule } from './adf.module';
|
import { AdfModule } from './adf.module';
|
||||||
import { AppComponent } from './app.component';
|
import { AppComponent } from './app.component';
|
||||||
|
import { APP_ROUTES } from './app.routes';
|
||||||
|
|
||||||
|
import { LoginComponent } from './components/login/login.component';
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
declarations: [
|
|
||||||
AppComponent
|
|
||||||
],
|
|
||||||
imports: [
|
imports: [
|
||||||
BrowserModule,
|
BrowserModule,
|
||||||
|
RouterModule.forRoot(APP_ROUTES, {
|
||||||
|
enableTracing: true
|
||||||
|
}),
|
||||||
AdfModule
|
AdfModule
|
||||||
],
|
],
|
||||||
|
declarations: [
|
||||||
|
AppComponent,
|
||||||
|
LoginComponent
|
||||||
|
],
|
||||||
providers: [],
|
providers: [],
|
||||||
bootstrap: [AppComponent]
|
bootstrap: [AppComponent]
|
||||||
})
|
})
|
||||||
|
35
src/app/app.routes.ts
Normal file
35
src/app/app.routes.ts
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
/*!
|
||||||
|
* @license
|
||||||
|
* Copyright 2017 Alfresco Software, Ltd.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { Routes } from '@angular/router';
|
||||||
|
|
||||||
|
import { LoginComponent } from './components/login/login.component';
|
||||||
|
|
||||||
|
export const APP_ROUTES: Routes = [
|
||||||
|
{
|
||||||
|
path: '**',
|
||||||
|
redirectTo: '/login',
|
||||||
|
pathMatch: 'full'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'login',
|
||||||
|
component: LoginComponent,
|
||||||
|
data: {
|
||||||
|
title: 'Sign in'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
];
|
8
src/app/components/login/login.component.html
Normal file
8
src/app/components/login/login.component.html
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
<alfresco-login
|
||||||
|
#alfrescoLogin
|
||||||
|
copyrightText="© 2017 Alfresco Software, Inc. All rights reserved."
|
||||||
|
providers="ECM"
|
||||||
|
[showRememberMe]="false"
|
||||||
|
[showLoginActions]="false"
|
||||||
|
(onSuccess)="onLoginSuccess($event)">
|
||||||
|
</alfresco-login>
|
144
src/app/components/login/login.component.spec.ts
Normal file
144
src/app/components/login/login.component.spec.ts
Normal file
@ -0,0 +1,144 @@
|
|||||||
|
/*!
|
||||||
|
* @license
|
||||||
|
* Copyright 2017 Alfresco Software, Ltd.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { RouterTestingModule } from '@angular/router/testing';
|
||||||
|
import { Router, ActivatedRoute } from '@angular/router';
|
||||||
|
import { TestBed, async } from '@angular/core/testing';
|
||||||
|
import { Observable } from 'rxjs/Rx';
|
||||||
|
import { AlfrescoAuthenticationService, UserPreferencesService } from 'ng2-alfresco-core';
|
||||||
|
import { LoginModule } from 'ng2-alfresco-login';
|
||||||
|
|
||||||
|
import { LoginComponent } from './login.component';
|
||||||
|
|
||||||
|
describe('LoginComponent', () => {
|
||||||
|
let router: Router;
|
||||||
|
let route: ActivatedRoute;
|
||||||
|
let authService: AlfrescoAuthenticationService;
|
||||||
|
let userPrefService: UserPreferencesService;
|
||||||
|
|
||||||
|
class TestConfig {
|
||||||
|
private testBed;
|
||||||
|
private componentInstance;
|
||||||
|
private fixture;
|
||||||
|
|
||||||
|
constructor(config: any = {}) {
|
||||||
|
const routerProvider = {
|
||||||
|
provide: Router,
|
||||||
|
useValue: {
|
||||||
|
navigateByUrl: jasmine.createSpy('navigateByUrl'),
|
||||||
|
navigate: jasmine.createSpy('navigate')
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const authProvider = {
|
||||||
|
provide: AlfrescoAuthenticationService,
|
||||||
|
useValue: {
|
||||||
|
isEcmLoggedIn: jasmine.createSpy('navigateByUrl')
|
||||||
|
.and.returnValue(config.isEcmLoggedIn || false)
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const preferencesProvider = {
|
||||||
|
provide: UserPreferencesService,
|
||||||
|
useValue: {
|
||||||
|
setStoragePrefix: jasmine.createSpy('setStoragePrefix')
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
this.testBed = TestBed.configureTestingModule({
|
||||||
|
imports: [
|
||||||
|
RouterTestingModule,
|
||||||
|
LoginModule
|
||||||
|
],
|
||||||
|
declarations: [
|
||||||
|
LoginComponent
|
||||||
|
],
|
||||||
|
providers: [
|
||||||
|
routerProvider,
|
||||||
|
authProvider,
|
||||||
|
preferencesProvider,
|
||||||
|
{
|
||||||
|
provide: ActivatedRoute,
|
||||||
|
useValue: {
|
||||||
|
params: Observable.of({ redirect: config.redirect })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
|
||||||
|
this.fixture = TestBed.createComponent(LoginComponent);
|
||||||
|
this.componentInstance = this.fixture.componentInstance;
|
||||||
|
this.fixture.detectChanges();
|
||||||
|
}
|
||||||
|
|
||||||
|
get userPrefService() {
|
||||||
|
return TestBed.get(UserPreferencesService);
|
||||||
|
}
|
||||||
|
|
||||||
|
get authService() {
|
||||||
|
return TestBed.get(AlfrescoAuthenticationService);
|
||||||
|
}
|
||||||
|
|
||||||
|
get routerService() {
|
||||||
|
return TestBed.get(Router);
|
||||||
|
}
|
||||||
|
|
||||||
|
get component() {
|
||||||
|
return this.componentInstance;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
it('load app when user is already logged in', () => {
|
||||||
|
const testConfig = new TestConfig({
|
||||||
|
isEcmLoggedIn: true
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(testConfig.routerService.navigateByUrl).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('requires user to be logged in', () => {
|
||||||
|
const testConfig = new TestConfig({
|
||||||
|
isEcmLoggedIn: false,
|
||||||
|
redirect: '/personal-files'
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(testConfig.routerService.navigate).toHaveBeenCalledWith(['/login', {}]);
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('onLoginSuccess()', () => {
|
||||||
|
let testConfig;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
testConfig = new TestConfig({
|
||||||
|
isEcmLoggedIn: false,
|
||||||
|
redirect: 'somewhere-over-the-rainbow'
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('redirects on success', () => {
|
||||||
|
testConfig.component.onLoginSuccess();
|
||||||
|
|
||||||
|
expect(testConfig.routerService.navigateByUrl).toHaveBeenCalledWith('somewhere-over-the-rainbow');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('sets user preference store prefix', () => {
|
||||||
|
testConfig.component.onLoginSuccess({ username: 'bogus' });
|
||||||
|
|
||||||
|
expect(testConfig.userPrefService.setStoragePrefix).toHaveBeenCalledWith('bogus');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
69
src/app/components/login/login.component.ts
Normal file
69
src/app/components/login/login.component.ts
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
/*!
|
||||||
|
* @license
|
||||||
|
* Copyright 2017 Alfresco Software, Ltd.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { Component } from '@angular/core';
|
||||||
|
import { Router, ActivatedRoute } from '@angular/router';
|
||||||
|
import { Validators } from '@angular/forms';
|
||||||
|
|
||||||
|
import { AlfrescoAuthenticationService, UserPreferencesService } from 'ng2-alfresco-core';
|
||||||
|
|
||||||
|
const skipRedirectUrls: string[] = [
|
||||||
|
'/logout',
|
||||||
|
'/personal-files'
|
||||||
|
];
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
templateUrl: './login.component.html'
|
||||||
|
})
|
||||||
|
export class LoginComponent {
|
||||||
|
|
||||||
|
private redirectUrl = '';
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
private router: Router,
|
||||||
|
private route: ActivatedRoute,
|
||||||
|
private auth: AlfrescoAuthenticationService,
|
||||||
|
private userPreferences: UserPreferencesService
|
||||||
|
) {
|
||||||
|
if (auth.isEcmLoggedIn()) {
|
||||||
|
this.redirect();
|
||||||
|
}
|
||||||
|
|
||||||
|
route.params.subscribe((params: any) => {
|
||||||
|
if (skipRedirectUrls.indexOf(params.redirect) > -1) {
|
||||||
|
const remainingParams = Object.assign({}, params);
|
||||||
|
|
||||||
|
delete remainingParams.redirect;
|
||||||
|
|
||||||
|
router.navigate(['/login', remainingParams]);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.redirectUrl = params.redirect;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
redirect() {
|
||||||
|
this.router.navigateByUrl(this.redirectUrl || '');
|
||||||
|
}
|
||||||
|
|
||||||
|
onLoginSuccess(data) {
|
||||||
|
if (data && data.username) {
|
||||||
|
this.userPreferences.setStoragePrefix(data.username);
|
||||||
|
}
|
||||||
|
this.redirect();
|
||||||
|
}
|
||||||
|
}
|
@ -164,10 +164,6 @@
|
|||||||
dependencies:
|
dependencies:
|
||||||
tslib "^1.7.1"
|
tslib "^1.7.1"
|
||||||
|
|
||||||
"@angular/router@~3.1.1":
|
|
||||||
version "3.1.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/@angular/router/-/router-3.1.2.tgz#1046c943ace795027e2e5057df8c897da968fcd6"
|
|
||||||
|
|
||||||
"@angular/tsc-wrapped@4.3.6":
|
"@angular/tsc-wrapped@4.3.6":
|
||||||
version "4.3.6"
|
version "4.3.6"
|
||||||
resolved "https://registry.yarnpkg.com/@angular/tsc-wrapped/-/tsc-wrapped-4.3.6.tgz#1aa66e0ab2c4799a4ad14b675e13953aa5fcd436"
|
resolved "https://registry.yarnpkg.com/@angular/tsc-wrapped/-/tsc-wrapped-4.3.6.tgz#1aa66e0ab2c4799a4ad14b675e13953aa5fcd436"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user