mirror of
https://github.com/Ombi-app/Ombi.git
synced 2025-07-16 02:02:55 -07:00
Dynamic Background Animation
This commit is contained in:
parent
87ab783f77
commit
c7ee68040d
7 changed files with 74 additions and 7 deletions
12
src/Ombi/ClientApp/app/animations/fadeinout.ts
Normal file
12
src/Ombi/ClientApp/app/animations/fadeinout.ts
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
import { animate, style, transition, trigger } from "@angular/animations";
|
||||||
|
import { AnimationEntryMetadata } from "@angular/core";
|
||||||
|
|
||||||
|
export const fadeInOutAnimation: AnimationEntryMetadata = trigger("fadeInOut", [
|
||||||
|
transition(":enter", [ // :enter is alias to 'void => *'
|
||||||
|
style({ opacity: 0 }),
|
||||||
|
animate(1000, style({ opacity: 1 })),
|
||||||
|
]),
|
||||||
|
transition(":leave", [ // :leave is alias to '* => void'
|
||||||
|
animate(1000, style({ opacity: 0 })),
|
||||||
|
]),
|
||||||
|
]);
|
|
@ -1,5 +1,5 @@
|
||||||
<div *ngIf="landingPageSettings && customizationSettings">
|
<div *ngIf="landingPageSettings && customizationSettings">
|
||||||
<div *ngIf="background" class="bg" [style.background-image]="background"></div>
|
<div *ngIf="background" @fadeInOut class="bg" [style.background-image]="background"></div>
|
||||||
|
|
||||||
<div class="centered col-md-12">
|
<div class="centered col-md-12">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { PlatformLocation } from "@angular/common";
|
import { PlatformLocation } from "@angular/common";
|
||||||
import { Component, OnInit } from "@angular/core";
|
import { AfterViewInit, Component, OnDestroy, OnInit } from "@angular/core";
|
||||||
|
|
||||||
import { IMediaServerStatus } from "../interfaces";
|
import { IMediaServerStatus } from "../interfaces";
|
||||||
import { ICustomizationSettings, ILandingPageSettings } from "../interfaces";
|
import { ICustomizationSettings, ILandingPageSettings } from "../interfaces";
|
||||||
|
@ -9,11 +9,15 @@ import { SettingsService } from "../services";
|
||||||
import { DomSanitizer } from "@angular/platform-browser";
|
import { DomSanitizer } from "@angular/platform-browser";
|
||||||
import { ImageService } from "../services";
|
import { ImageService } from "../services";
|
||||||
|
|
||||||
|
import { setTimeout } from "core-js/library/web/timers";
|
||||||
|
import { fadeInOutAnimation } from "../animations/fadeinout";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
templateUrl: "./landingpage.component.html",
|
templateUrl: "./landingpage.component.html",
|
||||||
|
animations: [fadeInOutAnimation],
|
||||||
styleUrls: ["./landingpage.component.scss"],
|
styleUrls: ["./landingpage.component.scss"],
|
||||||
})
|
})
|
||||||
export class LandingPageComponent implements OnInit {
|
export class LandingPageComponent implements AfterViewInit, OnInit, OnDestroy {
|
||||||
|
|
||||||
public customizationSettings: ICustomizationSettings;
|
public customizationSettings: ICustomizationSettings;
|
||||||
public landingPageSettings: ILandingPageSettings;
|
public landingPageSettings: ILandingPageSettings;
|
||||||
|
@ -41,4 +45,24 @@ export class LandingPageComponent implements OnInit {
|
||||||
this.mediaServerStatus = x;
|
this.mediaServerStatus = x;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ngOnDestroy() {
|
||||||
|
setTimeout(() => {
|
||||||
|
this.images.getRandomBackground().subscribe(x => {
|
||||||
|
this.background = "";
|
||||||
|
});
|
||||||
|
}, 1000);
|
||||||
|
setTimeout(() => {
|
||||||
|
this.images.getRandomBackground().subscribe(x => {
|
||||||
|
this.background = this.sanitizer
|
||||||
|
.bypassSecurityTrustStyle("linear-gradient(-10deg, transparent 20%, rgba(0,0,0,0.7) 20.0%, rgba(0,0,0,0.7) 80.0%, transparent 80%), url(" + x.url + ")");
|
||||||
|
});
|
||||||
|
}, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ngAfterViewInit() {
|
||||||
|
setInterval(() => {
|
||||||
|
this.ngOnDestroy();
|
||||||
|
}, 10000);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,7 @@ include the remember me checkbox
|
||||||
-->
|
-->
|
||||||
<div *ngIf="form && customizationSettings">
|
<div *ngIf="form && customizationSettings">
|
||||||
|
|
||||||
<div *ngIf="background" class="bg" [style.background-image]="background"></div>
|
<div *ngIf="background" @fadeInOut class="bg" [style.background-image]="background"></div>
|
||||||
<div class="container" id="login">
|
<div class="container" id="login">
|
||||||
<div class="card card-container">
|
<div class="card card-container">
|
||||||
<!-- <img class="profile-img-card" src="//lh3.googleusercontent.com/-6V8xOA6M7BA/AAAAAAAAAAI/AAAAAAAAAAA/rzlHcD0KYwo/photo.jpg?sz=120" alt="" /> -->
|
<!-- <img class="profile-img-card" src="//lh3.googleusercontent.com/-6V8xOA6M7BA/AAAAAAAAAAI/AAAAAAAAAAA/rzlHcD0KYwo/photo.jpg?sz=120" alt="" /> -->
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { Component, OnInit } from "@angular/core";
|
import { AfterViewInit, Component, OnDestroy, OnInit } from "@angular/core";
|
||||||
import { FormBuilder, FormGroup, Validators } from "@angular/forms";
|
import { FormBuilder, FormGroup, Validators } from "@angular/forms";
|
||||||
import { ActivatedRoute, Router } from "@angular/router";
|
import { ActivatedRoute, Router } from "@angular/router";
|
||||||
import { TranslateService } from "@ngx-translate/core";
|
import { TranslateService } from "@ngx-translate/core";
|
||||||
|
@ -13,11 +13,14 @@ import { StatusService } from "../services";
|
||||||
import { DomSanitizer } from "@angular/platform-browser";
|
import { DomSanitizer } from "@angular/platform-browser";
|
||||||
import { ImageService } from "../services";
|
import { ImageService } from "../services";
|
||||||
|
|
||||||
|
import { fadeInOutAnimation } from "../animations/fadeinout";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
templateUrl: "./login.component.html",
|
templateUrl: "./login.component.html",
|
||||||
|
animations: [fadeInOutAnimation],
|
||||||
styleUrls: ["./login.component.scss"],
|
styleUrls: ["./login.component.scss"],
|
||||||
})
|
})
|
||||||
export class LoginComponent implements OnInit {
|
export class LoginComponent implements AfterViewInit, OnDestroy, OnInit {
|
||||||
|
|
||||||
public form: FormGroup;
|
public form: FormGroup;
|
||||||
public customizationSettings: ICustomizationSettings;
|
public customizationSettings: ICustomizationSettings;
|
||||||
|
@ -102,4 +105,24 @@ export class LoginComponent implements OnInit {
|
||||||
}, err => this.notify.error(this.errorBody));
|
}, err => this.notify.error(this.errorBody));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ngOnDestroy() {
|
||||||
|
setTimeout(() => {
|
||||||
|
this.images.getRandomBackground().subscribe(x => {
|
||||||
|
this.background = "";
|
||||||
|
});
|
||||||
|
}, 1000);
|
||||||
|
setTimeout(() => {
|
||||||
|
this.images.getRandomBackground().subscribe(x => {
|
||||||
|
this.background = this.sanitizer
|
||||||
|
.bypassSecurityTrustStyle("linear-gradient(-10deg, transparent 20%, rgba(0,0,0,0.7) 20.0%, rgba(0,0,0,0.7) 80.0%, transparent 80%), url(" + x.url + ")");
|
||||||
|
});
|
||||||
|
}, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ngAfterViewInit() {
|
||||||
|
setInterval(() => {
|
||||||
|
this.ngOnDestroy();
|
||||||
|
}, 10000);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -92,5 +92,13 @@
|
||||||
<None Include="wwwroot\loading.css" />
|
<None Include="wwwroot\loading.css" />
|
||||||
<None Include="wwwroot\translations\*.json" />
|
<None Include="wwwroot\translations\*.json" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<None Remove="ClientApp\app\animations\fadeinout.ts" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<TypeScriptCompile Include="ClientApp\app\animations\fadeinout.ts" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
|
|
@ -80,7 +80,7 @@ module.exports = (env: any) => {
|
||||||
},
|
},
|
||||||
plugins: [
|
plugins: [
|
||||||
new webpack.ProvidePlugin({ $: "jquery", jQuery: "jquery", Hammer: "hammerjs/hammer" }), // Global identifiers
|
new webpack.ProvidePlugin({ $: "jquery", jQuery: "jquery", Hammer: "hammerjs/hammer" }), // Global identifiers
|
||||||
new webpack.ContextReplacementPlugin(/\@angular(\\|\/)core(\\|\/)esm5/, path.join(__dirname, './client')), // Workaround for https://github.com/angular/angular/issues/20357
|
new webpack.ContextReplacementPlugin(/\@angular(\\|\/)core(\\|\/)esm5/, path.join(__dirname, "./client")), // Workaround for https://github.com/angular/angular/issues/20357
|
||||||
new webpack.ContextReplacementPlugin(/\@angular\b.*\b(bundles|linker)/, path.join(__dirname, "./ClientApp")), // Workaround for https://github.com/angular/angular/issues/11580
|
new webpack.ContextReplacementPlugin(/\@angular\b.*\b(bundles|linker)/, path.join(__dirname, "./ClientApp")), // Workaround for https://github.com/angular/angular/issues/11580
|
||||||
new webpack.ContextReplacementPlugin(/angular(\\|\/)core(\\|\/)@angular/, path.join(__dirname, "./ClientApp")), // Workaround for https://github.com/angular/angular/issues/14898
|
new webpack.ContextReplacementPlugin(/angular(\\|\/)core(\\|\/)@angular/, path.join(__dirname, "./ClientApp")), // Workaround for https://github.com/angular/angular/issues/14898
|
||||||
extractCSS,
|
extractCSS,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue