Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/search #158

Merged
merged 27 commits into from
Nov 26, 2019
Merged
Show file tree
Hide file tree
Changes from 21 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
773da3c
first iteration
DusanTuzinsky Nov 5, 2019
a8040d2
search in paths rather than names
DusanTuzinsky Nov 5, 2019
85999bf
use fuzzyjs for searching
DusanTuzinsky Nov 23, 2019
a50a6e8
remove fuzzyOptions prop
DusanTuzinsky Nov 23, 2019
44d5a52
clean route tests
DusanTuzinsky Nov 23, 2019
bf9398b
sort max to min
DusanTuzinsky Nov 23, 2019
c866401
Merge branch 'master' into feature/search
DusanTuzinsky Nov 23, 2019
acd6871
clean unwanted code
DusanTuzinsky Nov 23, 2019
97d70db
update react router dom
DusanTuzinsky Nov 23, 2019
c4a7e17
turn Navigation class component into function component
DusanTuzinsky Nov 24, 2019
7dad24c
update navigation active links on location change
DusanTuzinsky Nov 24, 2019
f508dea
use useHistory hook
DusanTuzinsky Nov 24, 2019
38d6d8e
remove eslint-disable for class
DusanTuzinsky Nov 24, 2019
0d27712
use pathname changes to set active category states
DusanTuzinsky Nov 24, 2019
6c1ab1f
we don't need depth level anymore
DusanTuzinsky Nov 24, 2019
5344e15
better explanation of function setActiveCategoriesFromPathname
DusanTuzinsky Nov 24, 2019
49a58d7
rename id to url
DusanTuzinsky Nov 24, 2019
e9fa2d6
disable eslint react-hooks/exhaustive-deps
DusanTuzinsky Nov 24, 2019
9052a48
put search outside of navigation
DusanTuzinsky Nov 24, 2019
1c7d775
restyle the search menu and options
DusanTuzinsky Nov 24, 2019
2ab003a
remove search docs
DusanTuzinsky Nov 24, 2019
a7b1a76
Merge branch 'master' into feature/search
adammockor Nov 25, 2019
3ec1eaa
remove unnecessary else
DusanTuzinsky Nov 25, 2019
7a88421
Merge branch 'feature/search' of https://github.com/lightingbeetle/li…
DusanTuzinsky Nov 25, 2019
6417d10
fix search menu position
DusanTuzinsky Nov 25, 2019
8d810a2
add second search to navigation bar
DusanTuzinsky Nov 25, 2019
e2217a2
Revert "add second search to navigation bar"
DusanTuzinsky Nov 25, 2019
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion packages/styleguide/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,14 @@
"homepage": "/",
"dependencies": {
"@mdx-js/react": "~1.5.0",
"accessible-autocomplete": "~2.0.1",
"array-includes": "~3.0.3",
"chroma-js": "~2.0.2",
"classnames": "~2.2.5",
"common-tags": "~1.8.0",
"core-js": "~2.6.0",
"firacode": "~1.205.0",
"fuzzyjs": "~4.0.3",
"object.entries": "~1.1.0",
"polished": "~2.3.1",
"pretty": "~2.0.0",
Expand All @@ -33,7 +35,7 @@
"react-frame-component": "~4.0.0",
"react-ga": "~2.6.0",
"react-responsive": "~6.0.1",
"react-router-dom": "~5.0.0",
"react-router-dom": "~5.1.2",
"react-select": "~3.0.8",
"styled-components": "~4.1.2",
"svg4everybody": "~2.1.9",
Expand Down
2 changes: 2 additions & 0 deletions packages/styleguide/src/components/App/App.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import Sidebar from './../Sidebar';
import Navigation from './../Navigation';
import NavigationButton from './../NavigationButton';
import Sitemap from './../Sitemap';
import Search from './../Search';

class App extends Component {
static displayName = 'App';
Expand Down Expand Up @@ -135,6 +136,7 @@ class App extends Component {
</PageContent>
<Suspense fallback={<div />}>
<PageSidebar>
<Search list={routes} />
<Navigation
routes={routes}
onNavLinkClick={() => this.handleNavLinkClick()}
Expand Down
237 changes: 102 additions & 135 deletions packages/styleguide/src/components/Navigation/index.js
Original file line number Diff line number Diff line change
@@ -1,152 +1,119 @@
import React from 'react';
import { array, bool, func, string } from 'prop-types';
import React, { useState, useEffect } from 'react';
import { array, bool, func } from 'prop-types';
import cx from 'classnames';
import styled from 'styled-components';

import { withRouter } from 'react-router-dom';
import { withRouter, useLocation } from 'react-router-dom';

import { rem } from './../../style/utils';

import Category from './Category';
import NavLink from './NavLink';

const CLASS_ROOT = 'sg-nav';

class Navigation extends React.Component {
static displayName = 'Navigation';

static propTypes = {
isMain: bool,
routes: array,
pathname: string,
onNavLinkClick: func,
const Navigation = ({
className,
routes = [],
isMain,
onNavLinkClick,
...other
}) => {
const classes = cx(CLASS_ROOT, className);
let location = useLocation();

const [activeCategories, setActiveCategories] = useState({});

/**
* Set category active state
*/
const setCategoryActiveState = (id, value = true) => {
setActiveCategories({
...activeCategories,
[id]: value,
});
};

constructor(props) {
super(props);
this.state = {
activeLinks: [],
};
this.handleClick = this.handleClick.bind(this);
}

componentWillMount() {
const path = this.props.pathname;

let pathArray = [];
pathArray = path.split('/');
pathArray = pathArray.filter(e => String(e).trim());

const activeLinks = this.copyActiveLinks(pathArray.length - 1);
/**
* This method sets every category state (from pathname)
* from first parent to current category to active
*/
const setActiveCategoriesFromPathname = () => {
let url = '';
const locPath = location.pathname;
const categories = locPath
// remove first '/' and last item of the path
.substring(1, locPath.lastIndexOf('/'))
.split('/')
.reduce((acc, curr) => {
url += '/' + curr;
return { ...acc, [url]: true };
}, {});

// set all new active categories
setActiveCategories({ ...activeCategories, ...categories });
};

pathArray.forEach((element, i) => {
activeLinks[i].push(`/${element}`);
});
useEffect(
() => {
setActiveCategoriesFromPathname();
},
// eslint-disable-next-line react-hooks/exhaustive-deps
[location.pathname]
);

const getNavList = (nodes = [], path = '') => (
<StyledNavList isMain={path === ''}>
{nodes.map(node => {
let item = null;
let nestedList = null;

const url = path + node.path;
if (node.nodes) {
item = (
<Category
onClick={() => {
setCategoryActiveState(url, !activeCategories[url]);
}}
isActive={activeCategories[url]}
>
{node.title}
</Category>
);

this.setState({
activeLinks,
});
}

handleClick(activeLink, depthLevel) {
const activeLinks = this.copyActiveLinks(depthLevel);

if (activeLinks[depthLevel].indexOf(activeLink) === -1) {
activeLinks[depthLevel].push(activeLink);
} else {
activeLinks[depthLevel] = this.removeActive(
activeLinks[depthLevel],
activeLink
);
}

this.setState({
activeLinks,
});
}

// eslint-disable-next-line class-methods-use-this
removeActive(arr, element) {
return arr.filter(e => e !== element);
}

copyActiveLinks(depthLevel) {
const activeLinks = this.state.activeLinks.slice(0);

for (let i = 0; i <= depthLevel; i += 1) {
activeLinks[i] = activeLinks[i] || [];
}

return activeLinks;
}

isActive(element, depthLevel) {
const activeLinks = this.copyActiveLinks(depthLevel);

return Array.isArray(activeLinks) || activeLinks.length
? activeLinks[depthLevel].includes(element)
: false;
}

render() {
const {
className,
routes = [],
isMain,
onNavLinkClick,
...other
} = this.props;

const classes = cx(CLASS_ROOT, className);

const getNavList = (nodes = [], path = '', depthLevel = 0) => (
<StyledNavList isMain={depthLevel === 0}>
{nodes.map(node => {
let item = null;
let nestedList = null;

if (node.nodes) {
item = (
<Category
onClick={() => this.handleClick(node.path, depthLevel)}
isActive={this.isActive(node.path, depthLevel)}
>
{node.title}
</Category>
);

const depthLevelUpdated = depthLevel + 1;
nestedList = getNavList(
node.nodes,
path + node.path,
depthLevelUpdated
);
} else {
item = (
<NavLink href={path + node.path} onClick={onNavLinkClick}>
{node.title}
</NavLink>
);
}

return (
<ListItem key={path + node.path}>
{item}
{nestedList}
</ListItem>
nestedList = getNavList(node.nodes, url);
} else {
item = (
<NavLink href={url} onClick={onNavLinkClick}>
{node.title}
</NavLink>
);
})}
</StyledNavList>
);

// div has to wrapp Nav because of nice layout
return (
<StyledNav className={classes} {...other}>
{getNavList(routes)}
</StyledNav>
);
}
}
}

return (
<ListItem key={path + node.path}>
{item}
{nestedList}
</ListItem>
);
})}
</StyledNavList>
);

// div has to wrapp Nav because of nice layout
return (
<StyledNav className={classes} {...other}>
{getNavList(routes)}
</StyledNav>
);
};

Navigation.displayName = 'Navigation';

Navigation.propTypes = {
isMain: bool,
routes: array,
onNavLinkClick: func,
};

const StyledNav = styled.nav`
width: ${props => rem(props.theme.sizes.menuWidth)};
Expand Down Expand Up @@ -178,6 +145,6 @@ const ListItem = styled.li`

export default withRouter(
({ location, match, history, staticContext, ...other }) => (
<Navigation pathname={location.pathname} {...other} />
<Navigation {...other} />
)
);
Loading