@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
7 lines • 15 kB
JavaScript
// TODO BUG 17.4.2020 - this file should contain very precise information about the intended structure of nae.json BUT this is a .d.ts file.
// If we include other interfaces from the lib into this file, schematic compilation fails. Schematics reference this file without problem
// but they can't reference files above their sourceRoot declared in their tsconfig file. Since this file is .d.ts it runs without anybody
// noticing. However as soon as we include other interfaces from the lib here, schematics will reference them and fail to compile.
// We need to find a good solution for this.
export {};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../projects/netgrif-components-core/src/commons/schema.ts"],"names":[],"mappings":"AAAA,4IAA4I;AAC5I,2IAA2I;AAC3I,2IAA2I;AAC3I,mIAAmI;AACnI,6CAA6C","sourcesContent":["// TODO BUG 17.4.2020 - this file should contain very precise information about the intended structure of nae.json BUT this is a .d.ts file.\n//  If we include other interfaces from the lib into this file, schematic compilation fails. Schematics reference this file without problem\n//  but they can't reference files above their sourceRoot declared in their tsconfig file. Since this file is .d.ts it runs without anybody\n//  noticing. However as soon as we include other interfaces from the lib here, schematics will reference them and fail to compile.\n//  We need to find a good solution for this.\n\n/**\n * This file is single point of truth for NAE frontend configuration schema.\n */\n\nexport type Resources =\n    | Resource\n    | Array<Resource>;\n\n/**\n * Schema for NAE configuration object\n */\nexport interface NetgrifApplicationEngine {\n    providers: SetAuthAndResourcesAddress;\n    theme: Theme;\n    locales?: Locales;\n    filters?: Filters;\n    views: Views;\n    services?: Services;\n\n    [k: string]: any;\n}\n\nexport interface Locales {\n    /**\n     * Key is locale code (ISO639-1 '-' ISO3166-1)\n     * Value is a file of translation\n     */\n    [k: string]: string;\n}\n\nexport interface SetAuthAndResourcesAddress {\n    auth: Auth;\n    resources: Resources;\n\n    [k: string]: any;\n}\n\nexport interface Auth {\n    address: string;\n    authentication: string;\n    sessionBearer?: string;\n    endpoints?: string | { [k: string]: string };\n    sso?: Sso;\n\n    [k: string]: any;\n}\n\nexport interface Sso {\n    enable: boolean;\n    redirectUrl: string;\n    refreshUrl: string;\n    clientId: string;\n    scopes: Array<string>;\n}\n\nexport interface Resource {\n    name: string;\n    address: string;\n    format: string;\n    openApi?: string;\n}\n\nexport interface Theme {\n    name: string;\n    pallets: {\n        light: {\n            primary:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            secondary?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            warn?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            [k: string]: any;\n        };\n        dark?: {\n            primary?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            secondary?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            warn?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            [k: string]: any;\n        };\n        [k: string]: any;\n    };\n\n    [k: string]: any;\n}\n\nexport interface Filters {\n    [k: string]: ConfigFilter;\n}\n\nexport interface ConfigFilter {\n    title: string;\n    access?: string;\n    body: object | Array<object>;\n    type: 'Task' | 'Case';\n    mergeOperator?: 'AND' | 'OR';\n\n    [k: string]: any;\n}\n\nexport interface Views {\n    /**\n     * This interface was referenced by `undefined`'s JSON-Schema definition\n     * via the `patternProperty` \"^[a-zA-Z0-9_]+$\".\n     */\n    [k: string]: View;\n}\n\nexport interface View {\n    layout?: {\n        name: string;\n        enableCaseTitle?: boolean;\n        isCaseTitleRequired?: boolean;\n        showDeleteMenu?: boolean;\n        confirmWorkflowDeletion?: boolean;\n        params?: {\n            orientation?: string;\n            [k: string]: any;\n        };\n        /**\n         * Override autogenerated name. 'Component' will be appended automatically.\n         */\n        componentName?: string;\n        [k: string]: any;\n    };\n    /**\n     * Use own custom component for this view\n     */\n    component?: {\n        class: string;\n        from: string;\n    };\n    // layout: CaseLayout | TaskLayout;\n    access:\n        | 'public' | 'private'\n        | Access;\n    navigation:\n        | boolean\n        | {\n        title?: string;\n        icon?: string;\n        translate?: boolean;\n        [k: string]: any;\n    };\n    children?: Views;\n    routing: {\n        path: string;\n        match?: boolean;\n    };\n\n    [k: string]: any;\n}\n\n/**\n * Defines the access constraints of an application view\n */\nexport interface Access {\n    /**\n     * `string` and `Array<string>` types are deprecated and support for them will be removed in a future version.\n     *\n     *  For `string` values the format is: <net import id>.<role name>\n     */\n    role?: Array<string> | string | RoleAccess | Array<RoleAccess>;\n    bannedRole?: Array<string> | string | RoleAccess | Array<RoleAccess>;\n    group?: Array<string> | string;\n    authority?: Array<string> | string;\n\n    [k: string]: any;\n}\n\n/**\n * Defines a single role access constraint\n */\nexport interface RoleAccess {\n    /**\n     * Process identifier (import ID)\n     */\n    processId: string;\n    /**\n     * Role import ID\n     */\n    roleId: string;\n}\n\nexport interface CaseLayout {\n    name: 'caseView';\n    params: object;\n}\n\nexport interface TaskLayout {\n    name: 'taskView';\n    params: object;\n}\n\nexport interface Services {\n    log?: {\n        level?: string;\n        logWithDate?: boolean;\n        serializeParams?: boolean;\n        includeLogLevel?: boolean;\n        publishers?: Array<any>;\n        [k: string]: any;\n    };\n    auth?: {\n        /**\n         * @deprecated in 6.3.0 use [onLogoutRedirect]{@link Services#auth.onLogoutRedirect} instead\n         *\n         * Determines the route the application should redirect to when the logout action is performed\n         *\n         * This value should be retrieved by calling the [getOnLogoutPath]{@link ConfigurationService#getOnLogoutPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        logoutRedirect?: string;\n        /**\n         * @deprecated in 6.3.0 use [toLoginRedirect]{@link Services#auth.toLoginRedirect} instead\n         *\n         * Determines the route the application should redirect to when a guard prevents entry to some route\n         *\n         * This value should be retrieved by calling the [getToLoginPath]{@link ConfigurationService#getToLoginPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        loginRedirect?: string;\n        /**\n         * Determines the route the application should redirect to when the logout action is performed\n         *\n         * This value should be retrieved by calling the [getOnLogoutPath]{@link ConfigurationService#getOnLogoutPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        onLogoutRedirect?: string;\n        /**\n         * Determines the route the application should redirect to when a guard prevents entry to some route\n         *\n         * This value should be retrieved by calling the [getToLoginPath]{@link ConfigurationService#getToLoginPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        toLoginRedirect?: string;\n        /**\n         * Determines the route the application should redirect to when the login action is performed\n         *\n         * This value should be retrieved by calling the [getOnLoginPath]{@link ConfigurationService#getOnLoginPath} method of the\n         * {@link ConfigurationService}\n         */\n        onLoginRedirect?: string;\n    };\n    routing?: {\n        defaultRedirect?: string;\n        wildcardRedirect?: string;\n    };\n    dataFields?: {\n        template?: string,\n        appearance?: string\n    };\n    legal: {\n        termsOfService: string,\n        privacyPolicy: string\n    };\n    groupNavigation?: {\n        groupNavigationRoute: string,\n    };\n    doubleDrawer?: {\n        url: string,\n    }\n\n    [k: string]: any;\n}\n"]}