admin-bro
Version:
Admin panel for apps written in node.js
58 lines (46 loc) • 1.56 kB
text/typescript
import merge from 'lodash/merge'
import AdminBro from '../../../admin-bro'
import { CurrentAdmin } from '../../../current-admin.interface'
import { BrandingOptions, Assets } from '../../../admin-bro-options.interface'
import ViewHelpers from '../view-helpers/view-helpers'
const defaultBranding = {
companyName: 'Company',
softwareBrothers: true,
}
const defaultAssets = {
styles: [],
scripts: [],
}
export const getAssets = async (
admin: AdminBro,
currentAdmin?: CurrentAdmin,
): Promise<Assets> => {
const { assets } = admin.options || {}
const computed = typeof assets === 'function'
? await assets(currentAdmin)
: assets
return merge({}, defaultAssets, computed)
}
export const getBranding = async (
admin: AdminBro,
currentAdmin?: CurrentAdmin,
): Promise<BrandingOptions> => {
const { branding } = admin.options
const h = new ViewHelpers(admin)
const defaultLogo = h.assetPath('logo.svg')
const computed = typeof branding === 'function'
? await branding(currentAdmin)
: branding
const merged = merge({}, defaultBranding, computed)
// checking for undefined because logo can also be `false` or `null`
merged.logo = merged.logo !== undefined ? merged.logo : defaultLogo
return merged
}
export const getFaviconFromBranding = (branding: BrandingOptions): string => {
if (branding.favicon) {
const { favicon } = branding
const type = favicon.match(/.*\.png$/) ? 'image/png' : 'image/x-icon'
return `<link rel="shortcut icon" type="${type}" href="${favicon}" />`
}
return ''
}