Skip to content

Commit

Permalink
Add favicon configuration (#801)
Browse files Browse the repository at this point in the history
Added a configuration on favicon inside opensearchDashboards.branding
in the yml file. If user inputs a valid URL, we gurantee basic browser
favicon customization, while remaining places show the default browser/device
favicon icon. If user does not provide a valid URL for favicon, the
opensearch favicon icon will be used.

Signed-off-by: Abby Hu <abigailhu2000@gmail.com>
  • Loading branch information
abbyhu2000 authored and kavilla committed Sep 27, 2021
1 parent 5a28c2a commit 70e00ec
Show file tree
Hide file tree
Showing 10 changed files with 412 additions and 53 deletions.
2 changes: 1 addition & 1 deletion config/opensearch_dashboards.yml
Original file line number Diff line number Diff line change
Expand Up @@ -161,5 +161,5 @@
# loadingLogo:
# defaultUrl: ""
# darkModeUrl: ""
# favicon: ""
# faviconUrl: ""
# applicationTitle: ""
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ export interface InjectedMetadataParams {
defaultUrl?: string;
darkModeUrl?: string;
};
favicon?: string;
faviconUrl?: string;
applicationTitle?: string;
};
};
Expand Down Expand Up @@ -211,7 +211,7 @@ export interface InjectedMetadataSetup {
defaultUrl?: string;
darkModeUrl?: string;
};
favicon?: string;
faviconUrl?: string;
applicationTitle?: string;
};
}
Expand Down
2 changes: 1 addition & 1 deletion src/core/server/opensearch_dashboards_config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ export const config = {
defaultValue: '/',
}),
}),
favicon: schema.string({
faviconUrl: schema.string({
defaultValue: '/',
}),
applicationTitle: schema.string({
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

15 changes: 11 additions & 4 deletions src/core/server/rendering/rendering_service.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -135,7 +135,7 @@ export class RenderingService {
defaultUrl: brandingAssignment.loadingLogoDefault,
darkModeUrl: brandingAssignment.loadingLogoDarkmode,
},
favicon: '',
faviconUrl: brandingAssignment.favicon,
applicationTitle: brandingAssignment.applicationTitle,
},
},
Expand Down Expand Up @@ -223,6 +223,9 @@ export class RenderingService {
loadingLogoDarkmode = undefined;
}

// assign favicon based on brandingValidation function result
const favicon = brandingValidation.isFaviconValid ? branding.faviconUrl : undefined;

// assign applition title based on brandingValidation function result
const applicationTitle = brandingValidation.isTitleValid
? branding.applicationTitle
Expand All @@ -235,6 +238,7 @@ export class RenderingService {
markDarkmode,
loadingLogoDefault,
loadingLogoDarkmode,
favicon,
applicationTitle,
};

Expand Down Expand Up @@ -276,6 +280,8 @@ export class RenderingService {
? await this.checkUrlValid(branding.loadingLogo.darkModeUrl, 'loadingLogo darkMode')
: false;

const isFaviconValid = await this.checkUrlValid(branding.faviconUrl, 'favicon');

const isTitleValid = this.checkTitleValid(branding.applicationTitle, 'applicationTitle');

const brandingValidation: BrandingValidation = {
Expand All @@ -285,6 +291,7 @@ export class RenderingService {
isMarkDarkmodeValid,
isLoadingLogoDefaultValid,
isLoadingLogoDarkmodeValid,
isFaviconValid,
isTitleValid,
};

Expand All @@ -307,15 +314,15 @@ export class RenderingService {
*/
public checkUrlValid = async (url: string, configName?: string): Promise<boolean> => {
if (url.match(/\.(png|svg|gif|PNG|SVG|GIF)$/) === null) {
this.logger.get('branding').warn(configName + ' config is not found or invalid.');
this.logger.get('branding').info(configName + ' config is not found or invalid.');
return false;
}
return await Axios.get(url, { adapter: AxiosHttpAdapter })
.then(() => {
return true;
})
.catch(() => {
this.logger.get('branding').warn(configName + ' config is not found or invalid');
this.logger.get('branding').info(configName + ' config is not found or invalid');
return false;
});
};
Expand All @@ -332,7 +339,7 @@ export class RenderingService {
if (!title || title.length > 36) {
this.logger
.get('branding')
.warn(
.info(
configName +
' config is not found or invalid. Title length should be between 1 to 36 characters.'
);
Expand Down
4 changes: 3 additions & 1 deletion src/core/server/rendering/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ export interface RenderingMetadata {
defaultUrl?: string;
darkModeUrl?: string;
};
favicon?: string;
faviconUrl?: string;
applicationTitle?: string;
};
};
Expand Down Expand Up @@ -148,6 +148,7 @@ export interface BrandingValidation {
isMarkDarkmodeValid: boolean;
isLoadingLogoDefaultValid: boolean;
isLoadingLogoDarkmodeValid: boolean;
isFaviconValid: boolean;
isTitleValid: boolean;
}

Expand All @@ -163,5 +164,6 @@ export interface BrandingAssignment {
markDarkmode?: string;
loadingLogoDefault?: string;
loadingLogoDarkmode?: string;
favicon?: string;
applicationTitle?: string;
}
Loading

0 comments on commit 70e00ec

Please sign in to comment.