From a0845325d90a3718f8b8f3f7556614754c323722 Mon Sep 17 00:00:00 2001 From: Roman Hotsiy Date: Wed, 21 Mar 2018 19:54:45 +0200 Subject: [PATCH] fix: fix second-level heading in description --- src/components/Markdown/styles.ts | 5 +++++ src/components/SideMenu/MenuItem.tsx | 18 +++++++++--------- src/components/SideMenu/styled.elements.ts | 12 +++++++----- src/services/MenuBuilder.ts | 2 +- .../__tests__/MarkdownRenderer.test.ts | 3 ++- 5 files changed, 24 insertions(+), 16 deletions(-) diff --git a/src/components/Markdown/styles.ts b/src/components/Markdown/styles.ts index 2622e3f830..be07a38703 100644 --- a/src/components/Markdown/styles.ts +++ b/src/components/Markdown/styles.ts @@ -22,6 +22,11 @@ export const markdownCss = css` margin-top: 0; } + h2 { + ${headerCommonMixin(2)}; + color: ${props => props.theme.colors.text}; + } + code { color: #e53935; background-color: rgba(38, 50, 56, 0.04); diff --git a/src/components/SideMenu/MenuItem.tsx b/src/components/SideMenu/MenuItem.tsx index c25917ea75..92cf14995b 100644 --- a/src/components/SideMenu/MenuItem.tsx +++ b/src/components/SideMenu/MenuItem.tsx @@ -44,15 +44,15 @@ export class MenuItem extends React.Component { {item.type === 'operation' ? ( ) : ( - - {item.name} - {(item.depth > 0 && - item.items.length > 0 && ( - - )) || - null} - - )} + + {item.name} + {(item.depth > 0 && + item.items.length > 0 && ( + + )) || + null} + + )} {!withoutChildren && item.items && item.items.length > 0 && ( diff --git a/src/components/SideMenu/styled.elements.ts b/src/components/SideMenu/styled.elements.ts index a99584c6d6..f945b2b2fb 100644 --- a/src/components/SideMenu/styled.elements.ts +++ b/src/components/SideMenu/styled.elements.ts @@ -5,7 +5,7 @@ import styled, { css, withProps } from '../../styled-components'; export const OperationBadge = withProps<{ type: string }>(styled.span).attrs({ className: props => `operation-type ${props.type}`, -})` +}) ` width: 26px; display: inline-block; height: ${props => props.theme.code.fontSize};; @@ -70,7 +70,7 @@ function menuItemActiveBg(depth): string { } } -export const MenuItemUl = withProps<{ active: boolean }>(styled.ul)` +export const MenuItemUl = withProps<{ active: boolean }>(styled.ul) ` margin: 0; padding: 0; @@ -81,7 +81,7 @@ export const MenuItemUl = withProps<{ active: boolean }>(styled.ul)` ${props => (props.active ? '' : 'display: none;')}; `; -export const MenuItemLi = withProps<{ depth: number }>(styled.li)` +export const MenuItemLi = withProps<{ depth: number }>(styled.li) ` list-style: none inside none; overflow: hidden; text-overflow: ellipsis; @@ -114,17 +114,19 @@ export const MenuItemLabel = withProps<{ depth: number; active: boolean; deprecated?: boolean; + type?: string; }>(styled.label).attrs({ role: 'menuitem', className: props => classnames('-depth' + props.depth, { active: props.active, }), -})` +}) ` cursor: pointer; color: ${props => (props.active ? props.theme.colors.main : props.theme.colors.text)}; margin: 0; padding: 12.5px ${props => props.theme.spacingUnit}px; + ${({ depth, type, theme }) => type === 'section' && depth > 1 && 'padding-left: ' + theme.spacingUnit * 2 + 'px;' || ''} display: flex; justify-content: space-between; font-family: ${props => props.theme.headingsFont.family}; @@ -138,7 +140,7 @@ export const MenuItemLabel = withProps<{ } `; -export const MenuItemTitle = withProps<{ width?: string }>(styled.span)` +export const MenuItemTitle = withProps<{ width?: string }>(styled.span) ` display: inline-block; vertical-align: middle; width: ${props => (props.width ? props.width : 'auto')}; diff --git a/src/services/MenuBuilder.ts b/src/services/MenuBuilder.ts index e789e1e92b..441e780ab8 100644 --- a/src/services/MenuBuilder.ts +++ b/src/services/MenuBuilder.ts @@ -62,7 +62,7 @@ export class MenuBuilder { const group = new GroupModel('section', heading, parent); group.depth = depth; if (heading.items) { - group.items = mapHeadingsDeep(group, group.items, depth + 1); + group.items = mapHeadingsDeep(group, heading.items, depth + 1); } return group; }); diff --git a/src/services/__tests__/MarkdownRenderer.test.ts b/src/services/__tests__/MarkdownRenderer.test.ts index 13d4461761..35d05fc1be 100644 --- a/src/services/__tests__/MarkdownRenderer.test.ts +++ b/src/services/__tests__/MarkdownRenderer.test.ts @@ -11,8 +11,9 @@ describe('Markdown renderer', () => { expect(Object.keys(renderer.headings)).toHaveLength(1); expect(renderer.headings[0].name).toEqual('Sub Intro'); }); + test('should return a level-2 heading as a child of level-1', () => { - const headings = renderer.extractHeadings('# Introduction \n ## Sub Intro', false); + const headings = renderer.extractHeadings('# Introduction \n ## Sub Intro'); expect(headings).toHaveLength(1); expect(headings[0].name).toEqual('Introduction'); expect(headings[0].items).toBeDefined();