mirror of
https://github.com/phuoc-ng/csslayout.git
synced 2025-08-06 06:07:33 +02:00
Add search box
This commit is contained in:
@@ -23,6 +23,7 @@ import PreviousNextButtons from './layouts/previous-next-buttons/Details';
|
|||||||
import PricingTable from './layouts/pricing-table/Details';
|
import PricingTable from './layouts/pricing-table/Details';
|
||||||
import ProgressBar from './layouts/progress-bar/Details';
|
import ProgressBar from './layouts/progress-bar/Details';
|
||||||
import SameHeightColumns from './layouts/same-height-columns/Details';
|
import SameHeightColumns from './layouts/same-height-columns/Details';
|
||||||
|
import SearchBox from './layouts/search-box/Details';
|
||||||
import Separator from './layouts/separator/Details';
|
import Separator from './layouts/separator/Details';
|
||||||
import Sidebar from './layouts/sidebar/Details';
|
import Sidebar from './layouts/sidebar/Details';
|
||||||
import SimpleGrid from './layouts/simple-grid/Details';
|
import SimpleGrid from './layouts/simple-grid/Details';
|
||||||
@@ -60,6 +61,7 @@ const App = () => {
|
|||||||
<Route exact={true} path='/pricing-table'><PricingTable /></Route>
|
<Route exact={true} path='/pricing-table'><PricingTable /></Route>
|
||||||
<Route exact={true} path='/progress-bar'><ProgressBar /></Route>
|
<Route exact={true} path='/progress-bar'><ProgressBar /></Route>
|
||||||
<Route exact={true} path='/same-height-columns'><SameHeightColumns /></Route>
|
<Route exact={true} path='/same-height-columns'><SameHeightColumns /></Route>
|
||||||
|
<Route exact={true} path='/search-box'><SearchBox /></Route>
|
||||||
<Route exact={true} path='/separator'><Separator /></Route>
|
<Route exact={true} path='/separator'><Separator /></Route>
|
||||||
<Route exact={true} path='/sidebar'><Sidebar /></Route>
|
<Route exact={true} path='/sidebar'><Sidebar /></Route>
|
||||||
<Route exact={true} path='/simple-grid'><SimpleGrid /></Route>
|
<Route exact={true} path='/simple-grid'><SimpleGrid /></Route>
|
||||||
|
@@ -20,6 +20,7 @@ import PreviousNextButtonCover from './layouts/previous-next-buttons/Cover';
|
|||||||
import PricingTableCover from './layouts/pricing-table/Cover';
|
import PricingTableCover from './layouts/pricing-table/Cover';
|
||||||
import ProgressBarCover from './layouts/progress-bar/Cover';
|
import ProgressBarCover from './layouts/progress-bar/Cover';
|
||||||
import SameHeightColumnsCover from './layouts/same-height-columns/Cover';
|
import SameHeightColumnsCover from './layouts/same-height-columns/Cover';
|
||||||
|
import SearchBoxCover from './layouts/search-box/Cover';
|
||||||
import SeparatorCover from './layouts/separator/Cover';
|
import SeparatorCover from './layouts/separator/Cover';
|
||||||
import SidebarCover from './layouts/sidebar/Cover';
|
import SidebarCover from './layouts/sidebar/Cover';
|
||||||
import SimpleGridCover from './layouts/simple-grid/Cover';
|
import SimpleGridCover from './layouts/simple-grid/Cover';
|
||||||
@@ -221,6 +222,12 @@ const Home = () => {
|
|||||||
<h4 className="f5 mv0 pt3">Same height columns</h4>
|
<h4 className="f5 mv0 pt3">Same height columns</h4>
|
||||||
</Link>
|
</Link>
|
||||||
</div>
|
</div>
|
||||||
|
<div className="pa1 w-20">
|
||||||
|
<Link to="/search-box" className="link flex flex-column items-center justify-center tc hover-bg-black-10 br2 pa3">
|
||||||
|
<SearchBoxCover />
|
||||||
|
<h4 className="f5 mv0 pt3">Search box</h4>
|
||||||
|
</Link>
|
||||||
|
</div>
|
||||||
<div className="pa1 w-20">
|
<div className="pa1 w-20">
|
||||||
<Link to="/separator" className="link flex flex-column items-center justify-center tc hover-bg-black-10 br2 pa3">
|
<Link to="/separator" className="link flex flex-column items-center justify-center tc hover-bg-black-10 br2 pa3">
|
||||||
<SeparatorCover />
|
<SeparatorCover />
|
||||||
|
@@ -8,7 +8,7 @@ const Cover = () => {
|
|||||||
return (
|
return (
|
||||||
<Frame>
|
<Frame>
|
||||||
<div className="h-100 flex flex-column items-center justify-center pa2">
|
<div className="h-100 flex flex-column items-center justify-center pa2">
|
||||||
<div className="w-100 h2 flex flex-row items-center ba b--black-30 br2 ph1">
|
<div className="w-100 flex flex-row items-center ba b--black-30 br2 pa1">
|
||||||
<div className="mr1"><Circle /></div>
|
<div className="mr1"><Circle /></div>
|
||||||
<Rectangle />
|
<Rectangle />
|
||||||
</div>
|
</div>
|
||||||
|
18
client/layouts/search-box/Cover.jsx
Normal file
18
client/layouts/search-box/Cover.jsx
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
import Circle from '../../placeholders/Circle';
|
||||||
|
import Frame from '../../placeholders/Frame';
|
||||||
|
|
||||||
|
const Cover = () => {
|
||||||
|
return (
|
||||||
|
<Frame>
|
||||||
|
<div className="h-100 flex flex-column items-center justify-center pa2">
|
||||||
|
<div className="w-100 flex flex-row items-center justify-end ba b--black-30 br2 pa1">
|
||||||
|
<Circle />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</Frame>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default Cover;
|
65
client/layouts/search-box/Details.jsx
Normal file
65
client/layouts/search-box/Details.jsx
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
import DetailsLayout from '../../DetailsLayout';
|
||||||
|
import BrowserFrame from '../../placeholders/BrowserFrame';
|
||||||
|
import Circle from '../../placeholders/Circle';
|
||||||
|
import SampleCode from '../../SampleCode';
|
||||||
|
|
||||||
|
const Details = () => {
|
||||||
|
return (
|
||||||
|
<DetailsLayout title="Search box">
|
||||||
|
<BrowserFrame
|
||||||
|
content={
|
||||||
|
<div className="h-100 flex flex-column items-center justify-center">
|
||||||
|
<div className="w5">
|
||||||
|
<div className="mb3 b--black-30 ba br1 flex">
|
||||||
|
<input type="text" placeholder="Search" className="pa1 b--transparent" style={{ flex: 1 }} />
|
||||||
|
<div className="pa2">
|
||||||
|
<Circle />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div className="b--black-30 ba br1 flex flex-row-reverse">
|
||||||
|
<input type="text" placeholder="Search" className="pa1 b--transparent" style={{ flex: 1 }} />
|
||||||
|
<div className="pa2">
|
||||||
|
<Circle />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
source={
|
||||||
|
<SampleCode
|
||||||
|
lang="html"
|
||||||
|
code={`
|
||||||
|
<div style="
|
||||||
|
display: flex;
|
||||||
|
|
||||||
|
/* If you want to place the icon before the text input */
|
||||||
|
flex-direction: row-reverse;
|
||||||
|
|
||||||
|
/* Border */
|
||||||
|
border: 1px solid rgba(0, 0, 0, 0.3);
|
||||||
|
">
|
||||||
|
<!-- Text input -->
|
||||||
|
<input
|
||||||
|
type="text"
|
||||||
|
style="
|
||||||
|
border-color: transparent;
|
||||||
|
/* Take available width */
|
||||||
|
flex: 1;
|
||||||
|
"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- Search icon sticks to the left or right -->
|
||||||
|
...
|
||||||
|
</div>
|
||||||
|
`}
|
||||||
|
/>
|
||||||
|
}
|
||||||
|
/>
|
||||||
|
</DetailsLayout>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default Details;
|
Reference in New Issue
Block a user