Merge branch 'dev' into dev-starter

This commit is contained in:
Sercan Yemen 2022-12-12 14:51:27 +03:00
commit ce0cce00d9
8 changed files with 1486 additions and 1454 deletions

2747
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -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"
} }

View File

@ -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;
} }
} }

View File

@ -315,6 +315,10 @@
} }
} }
.mdc-checkbox__native-control {
opacity: 0 !important;
}
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */
/* @ Chip /* @ Chip
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */

View File

@ -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 */

View File

@ -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;

View File

@ -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,24 +40,23 @@ 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

View File

@ -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);
})
); );
} }
} }