All Downloads are FREE. Search and download functionalities are using the official Maven repository.

plugins.withItemsResolver.utils.ts Maven / Gradle / Ivy

There is a newer version: 7.28.2
Show newest version
import { isEmpty } from 'lodash'

import propsResolver from '../../utils/propsResolver'
import { libAsterisk } from '../Menu/helpers'

export const EXPRESSION_SYMBOL = ':'

interface Item {
    href?: string
    title?: string
    pathMapping?: Record
    queryMapping?: Record
    items?: Item[]
    datasource?: string
}

interface DatasourceModels {
    [key: string]: Array>
}

interface ResolveExpressionResult {
    key: string | undefined;
    value: string | undefined;
}

const resolveItem = (item: Item, datasourceModels: DatasourceModels, datasource: string): Item => {
    const { datasource: childrenDataSource } = item

    let datasourceModel: Record = {}

    if (childrenDataSource) {
        datasourceModel = datasourceModels[childrenDataSource]?.[0]
    } else {
        datasourceModel = datasourceModels[datasource]?.[0]
    }

    if (isEmpty(datasourceModel)) { return item }

    let newHref = item.href || ''
    let newTitle = item.title

    if (newHref) {
        const pathVariables = Object.entries(item.pathMapping || {})

        pathVariables.forEach(([key, valueObj]) => {
            if (key in datasourceModel) {
                newHref = newHref.replaceAll(valueObj.value, datasourceModel[key])
            }
        })

        let hasQuery = false
        const queryVariables = Object.entries(item.queryMapping || {})

        queryVariables.forEach(([queryKey, queryValueObj]) => {
            const queryObj = propsResolver({ [queryKey]: queryValueObj.value }, datasourceModel)

            Object.entries(queryObj).forEach(([key, value]) => {
                newHref += `${hasQuery ? '&' : '?'}${key}=${value}`
                if (!hasQuery) { hasQuery = true }
            })
        })
    }

    if (newTitle) {
        const { title } = propsResolver({ title: newTitle }, datasourceModel)

        newTitle = title
    }

    let newItems: Item[] = []

    if (item.items) {
        newItems = item.items.map(i => resolveItem(i, datasourceModels, childrenDataSource || datasource))
    }

    return {
        ...item,
        ...(item.items && { items: newItems }),
        ...(item.href && { href: newHref }),
        ...(item.title && { title: newTitle }),
    }
}

export const resolveItems = (items: Item[], datasourceModels: DatasourceModels, datasource: string): Item[] => {
    return items.map(item => resolveItem(item, datasourceModels, datasource))
}

export const resolveExpression = (location: { pathname: string }, path: string): ResolveExpressionResult => {
    if (!location || !path) { return { key: undefined, value: undefined } }
    let key

    const expressionPosition = path.split('/').findIndex((e) => {
        key = e.substring(1).replaceAll(libAsterisk, '')

        return e.startsWith(EXPRESSION_SYMBOL)
    })
    const value = location.pathname.split('/')[expressionPosition]

    return { key, value }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy