Skip to content

Commit

Permalink
Merge branch 'fix-ngonchanges-not-working-for-themed-components_contr…
Browse files Browse the repository at this point in the history
…ibute-7.4' into fix-ngonchanges-not-working-for-themed-components_contribute-7.6
  • Loading branch information
alexandrevryghem committed Aug 6, 2023
2 parents 404ccd9 + a7bef6f commit ff0c1a2
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 19 deletions.
19 changes: 5 additions & 14 deletions src/app/shared/theme-support/theme.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ export const themeStateSelector = createFeatureSelector<ThemeState>('theme');

export const currentThemeSelector = createSelector(
themeStateSelector,
(state: ThemeState): string => hasValue(state) ? state.currentTheme : undefined
(state: ThemeState): string => hasValue(state) ? state.currentTheme : BASE_THEME_NAME,
);

@Injectable({
Expand Down Expand Up @@ -240,14 +240,7 @@ export class ThemeService {
if (hasValue(parentThemeName)) {
// inherit the head tags of the parent theme
return this.createHeadTags(parentThemeName);
}
const defaultThemeConfig = getDefaultThemeConfig();
const defaultThemeName = defaultThemeConfig.name;
if (
hasNoValue(defaultThemeName) ||
themeName === defaultThemeName ||
themeName === BASE_THEME_NAME
) {
} else {
// last resort, use fallback favicon.ico
return [
this.createHeadTag({
Expand All @@ -260,9 +253,6 @@ export class ThemeService {
})
];
}

// inherit the head tags of the default theme
return this.createHeadTags(defaultThemeConfig.name);
}

return headTagConfigs.map(this.createHeadTag.bind(this));
Expand Down Expand Up @@ -425,9 +415,10 @@ export class ThemeService {
* @private
*/
private getActionForMatch(newTheme: Theme, currentThemeName: string): SetThemeAction | NoOpAction {
if (hasValue(newTheme) && newTheme.config.name !== currentThemeName) {
const newThemeName: string = newTheme?.config.name ?? BASE_THEME_NAME;
if (newThemeName !== currentThemeName) {
// If we have a match, and it isn't already the active theme, set it as the new theme
return new SetThemeAction(newTheme.config.name);
return new SetThemeAction(newThemeName);
} else {
// Otherwise, do nothing
return new NoOpAction();
Expand Down
4 changes: 1 addition & 3 deletions src/app/shared/theme-support/themed.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,6 @@ export abstract class ThemedComponent<T> implements OnInit, OnDestroy, OnChanges
}

ngOnInit(): void {
this.destroyComponentInstance();
this.initComponentInstance();
}

Expand All @@ -96,8 +95,6 @@ export abstract class ThemedComponent<T> implements OnInit, OnDestroy, OnChanges
}

if (hasNoValue(this.lazyLoadObs)) {
this.destroyComponentInstance();

this.lazyLoadObs = combineLatest([
observableOf(changes),
this.resolveThemedComponent(this.themeService.getThemeName()).pipe(
Expand All @@ -120,6 +117,7 @@ export abstract class ThemedComponent<T> implements OnInit, OnDestroy, OnChanges
}

this.lazyLoadSub = this.lazyLoadObs.subscribe(([simpleChanges, constructor]: [SimpleChanges, GenericConstructor<T>]) => {
this.destroyComponentInstance();
const factory = this.resolver.resolveComponentFactory(constructor);
this.compRef = this.vcr.createComponent(factory, undefined, undefined, [this.themedElementContent.nativeElement.childNodes]);
if (hasValue(simpleChanges)) {
Expand Down
7 changes: 5 additions & 2 deletions src/config/config.util.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@ import { environment } from '../environments/environment';
import { hasNoValue } from '../app/shared/empty.util';

import { AppConfig } from './app-config.interface';
import { ThemeConfig } from './theme.model';
import { ThemeConfig, NamedThemeConfig } from './theme.model';
import { BASE_THEME_NAME } from '../app/shared/theme-support/theme.constants';

/**
* Extend Angular environment with app config.
Expand Down Expand Up @@ -44,7 +45,9 @@ const getDefaultThemeConfig = (): ThemeConfig => {
hasNoValue(themeConfig.regex) &&
hasNoValue(themeConfig.handle) &&
hasNoValue(themeConfig.uuid)
);
) ?? {
name: BASE_THEME_NAME,
} as NamedThemeConfig;
};

export {
Expand Down

0 comments on commit ff0c1a2

Please sign in to comment.