/** * ============LICENSE_START======================================================================== * ONAP : ccsdk feature sdnr wt odlux * ================================================================================================= * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved. * ================================================================================================= * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except * in compliance with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under the License * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express * or implied. See the License for the specific language governing permissions and limitations under * the License. * ============LICENSE_END========================================================================== */ import * as React from 'react'; import * as marked from 'marked'; import * as hljs from 'highlight.js'; import { requestRestExt } from '../services/restService'; const defaultRenderer = new marked.Renderer(); defaultRenderer.link = (href, title, text) => ( `${text}` ); interface AboutState { content: string | null; } class AboutComponent extends React.Component { constructor(props: any) { super(props); this.state = { content: null } this.loadAboutContent(); } private loadAboutContent(): void { requestRestExt('/about').then((response) => { this.setState({ content: response.status == 200 ? response.data : `${response.status} ${response.message}` || "Server error" }) }).catch((error) => { this.setState({ content: error }) }) } render() { const markedOptions: marked.MarkedOptions = { gfm: true, breaks: false, pedantic: false, sanitize: true, smartLists: true, smartypants: false, langPrefix: 'hljs ', ...({}), highlight: (code, lang) => { if (!!(lang && hljs.getLanguage(lang))) { return hljs.highlight(lang, code).value; } return code; } }; const className = "about-table" const style: React.CSSProperties = {}; const html = (marked(this.state.content || 'loading', { renderer: markedOptions && markedOptions.renderer || defaultRenderer })); return (
); } }; export const About = AboutComponent; export default About;