mirror of
https://github.com/richard-loafle/fuse-angular.git
synced 2025-01-09 20:15:07 +00:00
Merge branch 'dev' into dev-starter
This commit is contained in:
commit
ce0cce00d9
2749
package-lock.json
generated
2749
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
44
package.json
44
package.json
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "fuse-angular",
|
"name": "fuse-angular",
|
||||||
"version": "17.0.1",
|
"version": "17.1.0",
|
||||||
"description": "Fuse - Angular Admin Template and Starter Project",
|
"description": "Fuse - Angular Admin Template and Starter Project",
|
||||||
"author": "https://themeforest.net/user/srcn",
|
"author": "https://themeforest.net/user/srcn",
|
||||||
"license": "https://themeforest.net/licenses/standard",
|
"license": "https://themeforest.net/licenses/standard",
|
||||||
|
@ -13,25 +13,25 @@
|
||||||
"test": "ng test"
|
"test": "ng test"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@angular/animations": "15.0.0",
|
"@angular/animations": "15.0.3",
|
||||||
"@angular/cdk": "15.0.0",
|
"@angular/cdk": "15.0.2",
|
||||||
"@angular/common": "15.0.0",
|
"@angular/common": "15.0.3",
|
||||||
"@angular/compiler": "15.0.0",
|
"@angular/compiler": "15.0.3",
|
||||||
"@angular/core": "15.0.0",
|
"@angular/core": "15.0.3",
|
||||||
"@angular/forms": "15.0.0",
|
"@angular/forms": "15.0.3",
|
||||||
"@angular/material": "15.0.0",
|
"@angular/material": "15.0.2",
|
||||||
"@angular/material-luxon-adapter": "15.0.0",
|
"@angular/material-luxon-adapter": "15.0.2",
|
||||||
"@angular/platform-browser": "15.0.0",
|
"@angular/platform-browser": "15.0.3",
|
||||||
"@angular/platform-browser-dynamic": "15.0.0",
|
"@angular/platform-browser-dynamic": "15.0.3",
|
||||||
"@angular/router": "15.0.0",
|
"@angular/router": "15.0.3",
|
||||||
"@ngneat/transloco": "4.1.1",
|
"@ngneat/transloco": "4.2.1",
|
||||||
"apexcharts": "3.36.3",
|
"apexcharts": "3.36.3",
|
||||||
"crypto-js": "3.3.0",
|
"crypto-js": "3.3.0",
|
||||||
"highlight.js": "11.6.0",
|
"highlight.js": "11.7.0",
|
||||||
"lodash-es": "4.17.21",
|
"lodash-es": "4.17.21",
|
||||||
"luxon": "3.1.0",
|
"luxon": "3.1.1",
|
||||||
"ng-apexcharts": "1.7.4",
|
"ng-apexcharts": "1.7.4",
|
||||||
"ngx-quill": "19.0.1",
|
"ngx-quill": "20.0.1",
|
||||||
"perfect-scrollbar": "1.5.5",
|
"perfect-scrollbar": "1.5.5",
|
||||||
"quill": "1.3.7",
|
"quill": "1.3.7",
|
||||||
"rxjs": "7.5.7",
|
"rxjs": "7.5.7",
|
||||||
|
@ -39,16 +39,16 @@
|
||||||
"zone.js": "0.12.0"
|
"zone.js": "0.12.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@angular-devkit/build-angular": "15.0.0",
|
"@angular-devkit/build-angular": "15.0.3",
|
||||||
"@angular/cli": "15.0.0",
|
"@angular/cli": "15.0.3",
|
||||||
"@angular/compiler-cli": "15.0.0",
|
"@angular/compiler-cli": "15.0.3",
|
||||||
"@tailwindcss/line-clamp": "0.4.2",
|
"@tailwindcss/line-clamp": "0.4.2",
|
||||||
"@tailwindcss/typography": "0.5.8",
|
"@tailwindcss/typography": "0.5.8",
|
||||||
"@types/chroma-js": "2.1.4",
|
"@types/chroma-js": "2.1.4",
|
||||||
"@types/crypto-js": "3.1.47",
|
"@types/crypto-js": "3.1.47",
|
||||||
"@types/highlight.js": "10.1.0",
|
"@types/highlight.js": "10.1.0",
|
||||||
"@types/jasmine": "4.3.0",
|
"@types/jasmine": "4.3.1",
|
||||||
"@types/lodash": "4.14.189",
|
"@types/lodash": "4.14.191",
|
||||||
"@types/lodash-es": "4.17.6",
|
"@types/lodash-es": "4.17.6",
|
||||||
"@types/luxon": "3.1.0",
|
"@types/luxon": "3.1.0",
|
||||||
"autoprefixer": "10.4.13",
|
"autoprefixer": "10.4.13",
|
||||||
|
@ -60,7 +60,7 @@
|
||||||
"karma-jasmine": "5.1.0",
|
"karma-jasmine": "5.1.0",
|
||||||
"karma-jasmine-html-reporter": "2.0.0",
|
"karma-jasmine-html-reporter": "2.0.0",
|
||||||
"lodash": "4.17.21",
|
"lodash": "4.17.21",
|
||||||
"postcss": "8.4.19",
|
"postcss": "8.4.20",
|
||||||
"tailwindcss": "3.2.4",
|
"tailwindcss": "3.2.4",
|
||||||
"typescript": "4.8.4"
|
"typescript": "4.8.4"
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,22 +20,22 @@ textarea {
|
||||||
}
|
}
|
||||||
|
|
||||||
&:-webkit-autofill {
|
&:-webkit-autofill {
|
||||||
-webkit-transition: 'background-color 9999s ease-out';
|
transition: background-color 600000s 0s, color 600000s 0s !important;
|
||||||
-webkit-transition-delay: 9999s;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&:-webkit-autofill:hover {
|
&:-webkit-autofill:hover {
|
||||||
-webkit-transition: 'background-color 9999s ease-out';
|
transition: background-color 600000s 0s, color 600000s 0s !important;
|
||||||
-webkit-transition-delay: 9999s;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&:-webkit-autofill:focus {
|
&:-webkit-autofill:focus {
|
||||||
-webkit-transition: 'background-color 9999s ease-out';
|
transition: background-color 600000s 0s, color 600000s 0s !important;
|
||||||
-webkit-transition-delay: 9999s;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&:-webkit-autofill:active {
|
&:-webkit-autofill:active {
|
||||||
-webkit-transition: 'background-color 9999s ease-out';
|
transition: background-color 600000s 0s, color 600000s 0s !important;
|
||||||
-webkit-transition-delay: 9999s;
|
}
|
||||||
|
|
||||||
|
[data-autocompleted] {
|
||||||
|
background-color: transparent !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -315,6 +315,10 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.mdc-checkbox__native-control {
|
||||||
|
opacity: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* @ Chip
|
/* @ Chip
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
|
@ -131,11 +131,11 @@ $dark-base: (
|
||||||
|
|
||||||
/* Define a light & dark Angular Material theme with the generated palettes */
|
/* Define a light & dark Angular Material theme with the generated palettes */
|
||||||
$light-theme: mat.define-light-theme((
|
$light-theme: mat.define-light-theme((
|
||||||
color: ($palettes)
|
color: $palettes
|
||||||
));
|
));
|
||||||
|
|
||||||
$dark-theme: mat.define-dark-theme((
|
$dark-theme: mat.define-dark-theme((
|
||||||
color: ($palettes)
|
color: $palettes
|
||||||
));
|
));
|
||||||
|
|
||||||
/* Merge the custom base colors with the generated themes */
|
/* Merge the custom base colors with the generated themes */
|
||||||
|
|
|
@ -1,3 +1,3 @@
|
||||||
import { Version } from '@fuse/version/version';
|
import { Version } from '@fuse/version/version';
|
||||||
|
|
||||||
export const FUSE_VERSION = new Version('17.0.1').full;
|
export const FUSE_VERSION = new Version('17.1.0').full;
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
import { Injectable } from '@angular/core';
|
import { Injectable } from '@angular/core';
|
||||||
import { ActivatedRouteSnapshot, CanActivate, CanActivateChild, CanLoad, Route, Router, RouterStateSnapshot, UrlSegment, UrlTree } from '@angular/router';
|
import { CanMatch, Route, Router, UrlSegment, UrlTree } from '@angular/router';
|
||||||
import { Observable, of, switchMap } from 'rxjs';
|
import { Observable, of, switchMap } from 'rxjs';
|
||||||
import { AuthService } from 'app/core/auth/auth.service';
|
import { AuthService } from 'app/core/auth/auth.service';
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
providedIn: 'root'
|
providedIn: 'root'
|
||||||
})
|
})
|
||||||
export class AuthGuard implements CanActivate, CanActivateChild, CanLoad
|
export class AuthGuard implements CanMatch
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
|
@ -23,38 +23,14 @@ export class AuthGuard implements CanActivate, CanActivateChild, CanLoad
|
||||||
// -----------------------------------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Can activate
|
* Can match
|
||||||
*
|
|
||||||
* @param route
|
|
||||||
* @param state
|
|
||||||
*/
|
|
||||||
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean> | Promise<boolean> | boolean
|
|
||||||
{
|
|
||||||
const redirectUrl = state.url === '/sign-out' ? '/' : state.url;
|
|
||||||
return this._check(redirectUrl);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Can activate child
|
|
||||||
*
|
|
||||||
* @param childRoute
|
|
||||||
* @param state
|
|
||||||
*/
|
|
||||||
canActivateChild(childRoute: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree
|
|
||||||
{
|
|
||||||
const redirectUrl = state.url === '/sign-out' ? '/' : state.url;
|
|
||||||
return this._check(redirectUrl);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Can load
|
|
||||||
*
|
*
|
||||||
* @param route
|
* @param route
|
||||||
* @param segments
|
* @param segments
|
||||||
*/
|
*/
|
||||||
canLoad(route: Route, segments: UrlSegment[]): Observable<boolean> | Promise<boolean> | boolean
|
canMatch(route: Route, segments: UrlSegment[]): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree
|
||||||
{
|
{
|
||||||
return this._check('/');
|
return this._check(segments);
|
||||||
}
|
}
|
||||||
|
|
||||||
// -----------------------------------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------------------------------
|
||||||
|
@ -64,29 +40,28 @@ export class AuthGuard implements CanActivate, CanActivateChild, CanLoad
|
||||||
/**
|
/**
|
||||||
* Check the authenticated status
|
* Check the authenticated status
|
||||||
*
|
*
|
||||||
* @param redirectURL
|
* @param segments
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
private _check(redirectURL: string): Observable<boolean>
|
private _check(segments: UrlSegment[]): Observable<boolean | UrlTree>
|
||||||
{
|
{
|
||||||
// Check the authentication status
|
// Check the authentication status
|
||||||
return this._authService.check()
|
return this._authService.check().pipe(
|
||||||
.pipe(
|
switchMap((authenticated) => {
|
||||||
switchMap((authenticated) => {
|
|
||||||
|
|
||||||
// If the user is not authenticated...
|
// If the user is not authenticated...
|
||||||
if ( !authenticated )
|
if ( !authenticated )
|
||||||
{
|
{
|
||||||
// Redirect to the sign-in page
|
// Redirect to the sign-in page with a redirectUrl param
|
||||||
this._router.navigate(['sign-in'], {queryParams: {redirectURL}});
|
const redirectURL = `/${segments.join('/')}`;
|
||||||
|
const urlTree = this._router.parseUrl(`sign-in?redirectURL=${redirectURL}`);
|
||||||
|
|
||||||
// Prevent the access
|
return of(urlTree);
|
||||||
return of(false);
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Allow the access
|
// Allow the access
|
||||||
return of(true);
|
return of(true);
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
import { Injectable } from '@angular/core';
|
import { Injectable } from '@angular/core';
|
||||||
import { ActivatedRouteSnapshot, CanActivate, CanActivateChild, CanLoad, Route, Router, RouterStateSnapshot, UrlSegment, UrlTree } from '@angular/router';
|
import { CanMatch, Route, Router, UrlSegment, UrlTree } from '@angular/router';
|
||||||
import { Observable, of, switchMap } from 'rxjs';
|
import { Observable, of, switchMap } from 'rxjs';
|
||||||
import { AuthService } from 'app/core/auth/auth.service';
|
import { AuthService } from 'app/core/auth/auth.service';
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
providedIn: 'root'
|
providedIn: 'root'
|
||||||
})
|
})
|
||||||
export class NoAuthGuard implements CanActivate, CanActivateChild, CanLoad
|
export class NoAuthGuard implements CanMatch
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
|
@ -23,34 +23,12 @@ export class NoAuthGuard implements CanActivate, CanActivateChild, CanLoad
|
||||||
// -----------------------------------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Can activate
|
* Can match
|
||||||
*
|
|
||||||
* @param route
|
|
||||||
* @param state
|
|
||||||
*/
|
|
||||||
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean> | Promise<boolean> | boolean
|
|
||||||
{
|
|
||||||
return this._check();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Can activate child
|
|
||||||
*
|
|
||||||
* @param childRoute
|
|
||||||
* @param state
|
|
||||||
*/
|
|
||||||
canActivateChild(childRoute: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree
|
|
||||||
{
|
|
||||||
return this._check();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Can load
|
|
||||||
*
|
*
|
||||||
* @param route
|
* @param route
|
||||||
* @param segments
|
* @param segments
|
||||||
*/
|
*/
|
||||||
canLoad(route: Route, segments: UrlSegment[]): Observable<boolean> | Promise<boolean> | boolean
|
canMatch(route: Route, segments: UrlSegment[]): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree
|
||||||
{
|
{
|
||||||
return this._check();
|
return this._check();
|
||||||
}
|
}
|
||||||
|
@ -66,24 +44,10 @@ export class NoAuthGuard implements CanActivate, CanActivateChild, CanLoad
|
||||||
*/
|
*/
|
||||||
private _check(): Observable<boolean>
|
private _check(): Observable<boolean>
|
||||||
{
|
{
|
||||||
// Check the authentication status
|
// Check the authentication status and return an observable of
|
||||||
return this._authService.check()
|
// "true" or "false" to allow or prevent the access
|
||||||
.pipe(
|
return this._authService.check().pipe(
|
||||||
switchMap((authenticated) => {
|
switchMap((authenticated) => of(!authenticated))
|
||||||
|
);
|
||||||
// If the user is authenticated...
|
|
||||||
if ( authenticated )
|
|
||||||
{
|
|
||||||
// Redirect to the root
|
|
||||||
this._router.navigate(['']);
|
|
||||||
|
|
||||||
// Prevent the access
|
|
||||||
return of(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Allow the access
|
|
||||||
return of(true);
|
|
||||||
})
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user