mirror of
https://github.com/xuthus83/pigallery2.git
synced 2025-01-14 14:43:17 +08:00
creating login screen design
This commit is contained in:
parent
6fb57a7b0a
commit
d78e1a9ce5
@ -1,7 +1,7 @@
|
|||||||
# PiGallery2
|
# PiGallery2
|
||||||
[data:image/s3,"s3://crabby-images/282c4/282c497b8f17de7785001ae835da82f826a5fdde" alt="npm version"](https://badge.fury.io/js/pigallery2)
|
[data:image/s3,"s3://crabby-images/282c4/282c497b8f17de7785001ae835da82f826a5fdde" alt="npm version"](https://badge.fury.io/js/pigallery2)
|
||||||
[data:image/s3,"s3://crabby-images/a50b1/a50b149ee39a806df49c1ea76f96a2d3b3320da8" alt="Build Status"](https://travis-ci.org/bpatrik/pigallery2)
|
[data:image/s3,"s3://crabby-images/a50b1/a50b149ee39a806df49c1ea76f96a2d3b3320da8" alt="Build Status"](https://travis-ci.org/bpatrik/pigallery2)
|
||||||
[data:image/s3,"s3://crabby-images/19d97/19d97cd8958ff5fd732f6a7021fc9b9dec8f237d" alt="Coverage Status"](https://coveralls.io/github/bpatrik/pigallery2?branch=master)
|
[data:image/s3,"s3://crabby-images/84aa6/84aa602b8dc14dc42248c957a177cecaba688194" alt="Coverage Status"](https://coveralls.io/github/bpatrik/PiGallery2?branch=master)
|
||||||
[data:image/s3,"s3://crabby-images/72e1e/72e1eeccaa4be6b8c6203f4826c33e824c1856cb" alt="Heroku"](https://pigallery2.herokuapp.com)
|
[data:image/s3,"s3://crabby-images/72e1e/72e1eeccaa4be6b8c6203f4826c33e824c1856cb" alt="Heroku"](https://pigallery2.herokuapp.com)
|
||||||
[data:image/s3,"s3://crabby-images/e62f7/e62f7cc1adc15e74c8e8c5810debf674d7519b24" alt="Code Climate"](https://codeclimate.com/github/bpatrik/pigallery2)
|
[data:image/s3,"s3://crabby-images/e62f7/e62f7cc1adc15e74c8e8c5810debf674d7519b24" alt="Code Climate"](https://codeclimate.com/github/bpatrik/pigallery2)
|
||||||
[data:image/s3,"s3://crabby-images/6c060/6c060bc4696a895956f56ed163fa4ec9775bbc6f" alt="Dependency Status"](https://david-dm.org/bpatrik/pigallery2)
|
[data:image/s3,"s3://crabby-images/6c060/6c060bc4696a895956f56ed163fa4ec9775bbc6f" alt="Dependency Status"](https://david-dm.org/bpatrik/pigallery2)
|
||||||
|
@ -8,7 +8,6 @@ import {Config} from "../../../common/config/private/Config";
|
|||||||
export class AuthenticationMWs {
|
export class AuthenticationMWs {
|
||||||
|
|
||||||
private static async getSharingUser(req: Request) {
|
private static async getSharingUser(req: Request) {
|
||||||
console.log(req);
|
|
||||||
if (Config.Client.Sharing.enabled === true &&
|
if (Config.Client.Sharing.enabled === true &&
|
||||||
Config.Client.Sharing.passwordProtected === false &&
|
Config.Client.Sharing.passwordProtected === false &&
|
||||||
(!!req.query.sk || !!req.params.sharingKey)) {
|
(!!req.query.sk || !!req.params.sharingKey)) {
|
||||||
|
@ -10,6 +10,7 @@ interface SharingConfig {
|
|||||||
}
|
}
|
||||||
|
|
||||||
interface ClientConfig {
|
interface ClientConfig {
|
||||||
|
applicationTitle: string;
|
||||||
iconSize: number;
|
iconSize: number;
|
||||||
thumbnailSizes: Array<number>;
|
thumbnailSizes: Array<number>;
|
||||||
Search: SearchConfig;
|
Search: SearchConfig;
|
||||||
@ -28,6 +29,7 @@ interface ClientConfig {
|
|||||||
export class PublicConfigClass {
|
export class PublicConfigClass {
|
||||||
|
|
||||||
public Client: ClientConfig = {
|
public Client: ClientConfig = {
|
||||||
|
applicationTitle: "PiGallery 2",
|
||||||
thumbnailSizes: [200, 400, 600],
|
thumbnailSizes: [200, 400, 600],
|
||||||
iconSize: 30,
|
iconSize: 30,
|
||||||
Search: {
|
Search: {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
export class LoginCredential {
|
export class LoginCredential {
|
||||||
constructor(public username: string = "", public password: string = "") {
|
constructor(public username: string = "", public password: string = "", public rememberMe: boolean = false) {
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,7 @@ import {SlimLoadingBarModule} from "ng2-slim-loading-bar";
|
|||||||
import {GalleryShareComponent} from "./gallery/share/share.gallery.component";
|
import {GalleryShareComponent} from "./gallery/share/share.gallery.component";
|
||||||
import {ShareLoginComponent} from "./sharelogin/share-login.component";
|
import {ShareLoginComponent} from "./sharelogin/share-login.component";
|
||||||
import {ShareService} from "./gallery/share.service";
|
import {ShareService} from "./gallery/share.service";
|
||||||
|
import "hammerjs";
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class GoogleMapsConfig {
|
export class GoogleMapsConfig {
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
<span class="icon-bar"></span>
|
<span class="icon-bar"></span>
|
||||||
</button>
|
</button>
|
||||||
<a class="navbar-brand" href="#"><img src="assets/icon_inv.png" style="max-height: 26px; display: inline;"/>
|
<a class="navbar-brand" href="#"><img src="assets/icon_inv.png" style="max-height: 26px; display: inline;"/>
|
||||||
PiGallery2</a>
|
{{title}}</a>
|
||||||
</div>
|
</div>
|
||||||
<div id="navbar" class="collapse navbar-collapse">
|
<div id="navbar" class="collapse navbar-collapse">
|
||||||
<ul class="nav navbar-nav">
|
<ul class="nav navbar-nav">
|
||||||
|
@ -16,10 +16,12 @@ export class FrameComponent {
|
|||||||
|
|
||||||
user: BehaviorSubject<UserDTO>;
|
user: BehaviorSubject<UserDTO>;
|
||||||
authenticationRequired: boolean = false;
|
authenticationRequired: boolean = false;
|
||||||
|
public title: string;
|
||||||
|
|
||||||
constructor(private _authService: AuthenticationService) {
|
constructor(private _authService: AuthenticationService) {
|
||||||
this.user = this._authService.user;
|
this.user = this._authService.user;
|
||||||
this.authenticationRequired = Config.Client.authenticationRequired;
|
this.authenticationRequired = Config.Client.authenticationRequired;
|
||||||
|
this.title = Config.Client.applicationTitle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -30,7 +30,6 @@ export class ShareService {
|
|||||||
this.sharingKey = this.param || this.queryParam;
|
this.sharingKey = this.param || this.queryParam;
|
||||||
if (this.resolve) {
|
if (this.resolve) {
|
||||||
this.resolve();
|
this.resolve();
|
||||||
console.log("resolving", this.sharingKey);
|
|
||||||
this.inited = true;
|
this.inited = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,3 +1,57 @@
|
|||||||
body {
|
.container {
|
||||||
background: #eee;
|
}
|
||||||
}
|
|
||||||
|
.title h1 {
|
||||||
|
font-size: 80px;
|
||||||
|
font-weight: bold;
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title img {
|
||||||
|
height: 80px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title {
|
||||||
|
margin-top: 40px;
|
||||||
|
width: 100%;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.card {
|
||||||
|
padding: 15px;
|
||||||
|
max-width: 350px;
|
||||||
|
width: 100% !important;
|
||||||
|
background-color: #F7F7F7;
|
||||||
|
margin: 0 auto;
|
||||||
|
border-radius: 2px;
|
||||||
|
box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.3);
|
||||||
|
overflow: hidden;
|
||||||
|
height: 295px;
|
||||||
|
margin-top: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*Margin by pixel:*/
|
||||||
|
@media screen and ( min-height: 600px ) {
|
||||||
|
.card {
|
||||||
|
margin-top: calc((100vh - 120px - 295px) / 2 - 60px)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.has-margin {
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.input-group .form-control, .checkbox {
|
||||||
|
padding: 10px;
|
||||||
|
font-size: 16px;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.error-message {
|
||||||
|
color: #d9534f;
|
||||||
|
}
|
||||||
|
|
||||||
|
button {
|
||||||
|
width: 100%;
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
@ -1,16 +1,94 @@
|
|||||||
<div class="container">
|
<div class="container">
|
||||||
<div class="col-sm-offset-3 col-sm-6 col-lg-4 col-lg-offset-4">
|
|
||||||
<form class="form-signin" #LoginForm="ngForm">
|
<div class="row title">
|
||||||
<h2 class="form-signin-heading">Please sign in</h2>
|
<h1><img src="assets/icon.png"/>{{title}}</h1>
|
||||||
<div *ngIf="loginError">
|
</div>
|
||||||
{{loginError}}
|
|
||||||
|
<div class="row card">
|
||||||
|
<div class="col-md-12">
|
||||||
|
<h1>Please log in</h1>
|
||||||
|
<form name="form" id="form" class="form-horizontal" #LoginForm="ngForm" (submit)="onLogin()">
|
||||||
|
<div class="error-message">
|
||||||
|
{{loginError}}
|
||||||
</div>
|
</div>
|
||||||
<input type="text" class="form-control" placeholder="Username" autofocus
|
<div class="input-group has-margin">
|
||||||
[(ngModel)]="loginCredential.username" name="name" required>
|
<span class="input-group-addon"><i class="glyphicon glyphicon-user"></i></span>
|
||||||
<input type="password" class="form-control" placeholder="Password"
|
<input id="username"
|
||||||
[(ngModel)]="loginCredential.password" name="password" required>
|
type="text"
|
||||||
<br/>
|
class="form-control"
|
||||||
<button class="btn btn-lg btn-primary btn-block" [disabled]="!LoginForm.form.valid" (click)="onLogin()">Sign in</button>
|
placeholder="Username"
|
||||||
</form>
|
autofocus
|
||||||
|
[(ngModel)]="loginCredential.username"
|
||||||
|
name="username" required>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="input-group">
|
||||||
|
<span class="input-group-addon"><i class="glyphicon glyphicon-lock"></i></span>
|
||||||
|
<input id="password"
|
||||||
|
class="form-control"
|
||||||
|
type="password"
|
||||||
|
[(ngModel)]="loginCredential.password"
|
||||||
|
name="password"
|
||||||
|
placeholder="Password"
|
||||||
|
required>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="checkbox">
|
||||||
|
<label><input type="checkbox" name="rememberMe" [(ngModel)]="loginCredential.rememberMe" value="">Remember me</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<!-- Button -->
|
||||||
|
<div class="col-sm-12 controls">
|
||||||
|
<button class="btn btn-primary pull-right"
|
||||||
|
[disabled]="!LoginForm.form.valid"
|
||||||
|
type="submit"
|
||||||
|
name="action">Login
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div> <!-- /container -->
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
<div class="login mat-typography" fxLayoutGap="80px" fxLayoutAlign="start center" fxFlexFill fxLayout="column">
|
||||||
|
<h1><img src="assets/icon.png">PiGallery 2</h1>
|
||||||
|
<form class="form-signin" #LoginForm="ngForm" (submit)="onLogin()" fxLayout="row">
|
||||||
|
<md-card fxFlex="400px">
|
||||||
|
<md-card-header>
|
||||||
|
<md-card-title>Please sign in</md-card-title>
|
||||||
|
</md-card-header>
|
||||||
|
<md-card-content fxFlexFill fxLayoutAlign="center center" fxLayout="column">
|
||||||
|
<div *ngIf="loginError">
|
||||||
|
{{loginError}}
|
||||||
|
</div>
|
||||||
|
<md-input-container>
|
||||||
|
<input fxFlexFill mdInput autofocus [(ngModel)]="loginCredential.username" name="name" required>
|
||||||
|
<md-placeholder>
|
||||||
|
<i class="material-icons app-input-icon">face</i> Username
|
||||||
|
</md-placeholder>
|
||||||
|
</md-input-container>
|
||||||
|
<md-input-container>
|
||||||
|
<input fxFlexFill mdInput type="password" [(ngModel)]="loginCredential.password" name="password" required>
|
||||||
|
<md-placeholder>
|
||||||
|
<i class="material-icons app-input-icon">lock_open</i> Password
|
||||||
|
</md-placeholder>
|
||||||
|
</md-input-container>
|
||||||
|
<div fxLayout="row" fxLayoutAlign="start center">
|
||||||
|
<md-checkbox [(ngModel)]="loginCredential.rememberM">Remember me</md-checkbox>
|
||||||
|
</div>
|
||||||
|
</md-card-content>
|
||||||
|
<md-card-actions fxLayout="row" fxLayoutAlign="end center">
|
||||||
|
<button md-raised-button color="primary"
|
||||||
|
[disabled]="!LoginForm.form.valid"
|
||||||
|
type="submit"
|
||||||
|
name="action">Login
|
||||||
|
</button>
|
||||||
|
</md-card-actions>
|
||||||
|
</md-card>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
-->
|
||||||
|
@ -3,6 +3,7 @@ import {LoginCredential} from "../../../common/entities/LoginCredential";
|
|||||||
import {AuthenticationService} from "../model/network/authentication.service";
|
import {AuthenticationService} from "../model/network/authentication.service";
|
||||||
import {Router} from "@angular/router";
|
import {Router} from "@angular/router";
|
||||||
import {ErrorCodes} from "../../../common/entities/Error";
|
import {ErrorCodes} from "../../../common/entities/Error";
|
||||||
|
import {Config} from "../../../common/config/public/Config";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'login',
|
selector: 'login',
|
||||||
@ -12,9 +13,11 @@ import {ErrorCodes} from "../../../common/entities/Error";
|
|||||||
export class LoginComponent implements OnInit {
|
export class LoginComponent implements OnInit {
|
||||||
loginCredential: LoginCredential;
|
loginCredential: LoginCredential;
|
||||||
loginError: any = null;
|
loginError: any = null;
|
||||||
|
title: string;
|
||||||
|
|
||||||
constructor(private _authService: AuthenticationService, private _router: Router) {
|
constructor(private _authService: AuthenticationService, private _router: Router) {
|
||||||
this.loginCredential = new LoginCredential();
|
this.loginCredential = new LoginCredential();
|
||||||
|
this.title = Config.Client.applicationTitle;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngOnInit() {
|
ngOnInit() {
|
||||||
@ -27,9 +30,9 @@ export class LoginComponent implements OnInit {
|
|||||||
this.loginError = null;
|
this.loginError = null;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await this._authService.login(this.loginCredential);
|
console.log(await this._authService.login(this.loginCredential));
|
||||||
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
if (error && error.code === ErrorCodes.CREDENTIAL_NOT_FOUND) {
|
if (error && error.code === ErrorCodes.CREDENTIAL_NOT_FOUND) {
|
||||||
this.loginError = "Wrong username or password";
|
this.loginError = "Wrong username or password";
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,6 @@ import {BehaviorSubject} from "rxjs/BehaviorSubject";
|
|||||||
import {UserService} from "./user.service";
|
import {UserService} from "./user.service";
|
||||||
import {LoginCredential} from "../../../../common/entities/LoginCredential";
|
import {LoginCredential} from "../../../../common/entities/LoginCredential";
|
||||||
import {Cookie} from "ng2-cookies";
|
import {Cookie} from "ng2-cookies";
|
||||||
import {ErrorCodes} from "../../../../common/entities/Error";
|
|
||||||
import {Config} from "../../../../common/config/public/Config";
|
import {Config} from "../../../../common/config/public/Config";
|
||||||
|
|
||||||
declare module ServerInject {
|
declare module ServerInject {
|
||||||
@ -44,15 +43,9 @@ export class AuthenticationService {
|
|||||||
|
|
||||||
|
|
||||||
public async login(credential: LoginCredential): Promise<UserDTO> {
|
public async login(credential: LoginCredential): Promise<UserDTO> {
|
||||||
try {
|
|
||||||
const user = await this._userService.login(credential);
|
const user = await this._userService.login(credential);
|
||||||
this.user.next(user);
|
this.user.next(user);
|
||||||
return user;
|
return user;
|
||||||
} catch (error) {
|
|
||||||
if (typeof error.code !== "undefined") {
|
|
||||||
console.log(ErrorCodes[error.code] + ", message: ", error.message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -6,11 +6,7 @@
|
|||||||
<title>PiGallery2</title>
|
<title>PiGallery2</title>
|
||||||
<link rel="shortcut icon" href="assets/icon.png">
|
<link rel="shortcut icon" href="assets/icon.png">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet"
|
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
|
||||||
integrity="sha384-1q8mTJOASx8j1Au+a5WDVnPi2lkFfwwEAa8hDDdjZlpLegxhjVME1fgjWPGmkzs7"
|
|
||||||
crossorigin="anonymous">
|
|
||||||
|
|
||||||
|
|
||||||
<script type="text/javascript" src="config_inject.js"></script>
|
<script type="text/javascript" src="config_inject.js"></script>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
|
@ -1 +1,11 @@
|
|||||||
/* You can add global styles to this file, and also import other style files */
|
html {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
* {
|
||||||
|
border-radius: 0 !important;
|
||||||
|
}
|
||||||
|
@ -82,6 +82,7 @@
|
|||||||
"mocha": "^3.4.2",
|
"mocha": "^3.4.2",
|
||||||
"ng2-cookies": "^1.0.12",
|
"ng2-cookies": "^1.0.12",
|
||||||
"ng2-slim-loading-bar": "^4.0.0",
|
"ng2-slim-loading-bar": "^4.0.0",
|
||||||
|
"ngx-bootstrap": "^1.7.1",
|
||||||
"phantomjs-prebuilt": "^2.1.14",
|
"phantomjs-prebuilt": "^2.1.14",
|
||||||
"protractor": "^5.1.2",
|
"protractor": "^5.1.2",
|
||||||
"remap-istanbul": "^0.9.5",
|
"remap-istanbul": "^0.9.5",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user