-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
Added List component to the sistent components page #6086
base: master
Are you sure you want to change the base?
Changes from 11 commits
96771e4
9f5a6b7
eb49d84
3ab022b
458e7c1
ba2ea46
d28c247
041ab14
fe0b59a
41ee8a9
458e964
b79062e
2f84a3a
e38d79f
e176d60
a8df902
f4ca16e
b05dbba
d2fe14d
fddf86f
bc3c90d
374d2cf
3d8042a
c351c30
7bca8c5
cc194c9
3722bc5
eb021c2
7f04cc0
33460eb
d0fd5a6
82fd698
8fa096b
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Large diffs are not rendered by default.
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
import React from "react"; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This file is not required, as pages will be dynamically created. so you don't require to create any pages under this dirc |
||
import { ListCode } from "../../../../../sections/Projects/Sistent/components/list/code"; | ||
|
||
const ListCodePage = () => { | ||
return <ListCode />; | ||
}; | ||
|
||
export default ListCodePage; |
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
import React from "react"; | ||
import { ListGuidance } from "../../../../../sections/Projects/Sistent/components/list/guidance"; | ||
|
||
const ListGuidancePage = () => { | ||
return <ListGuidance />; | ||
}; | ||
export default ListGuidancePage; |
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same as above stated |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
import React from "react"; | ||
import SistentList from "../../../../../sections/Projects/Sistent/components/list"; | ||
const SistentListPage = () => { | ||
return <SistentList/>; | ||
}; | ||
export default SistentListPage; |
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Rather than putting list data on componentsData, their is another file called content.js under same dirc There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok sir I will check and make the required changes. |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
import React, { useState } from "react"; | ||
import Code from "../../../../../components/CodeBlock"; | ||
|
||
export const CodeBlock = ({ name, code }) => { | ||
const [showCode, setShowCode] = useState(false); | ||
const onChange = () => { | ||
setShowCode((prev) => !prev); | ||
}; | ||
|
||
return ( | ||
<div className="show-code"> | ||
<input type="checkbox" name={name} id={name} onChange={onChange} /> | ||
<label htmlFor={name} className="label"> | ||
Show Code | ||
</label> | ||
{showCode && ( | ||
<Code codeString={code} language="javascript" /> | ||
)} | ||
</div> | ||
); | ||
}; |
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok, sir. |
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -0,0 +1,199 @@ | ||||||
import React from "react"; | ||||||
import { navigate } from "gatsby"; | ||||||
import { useLocation } from "@reach/router"; | ||||||
import { List, ListItemIcon, ListItemAvatar, ListItemText,ListItem,ListSubheader, ListItemButton, SistentThemeProvider, Divider } from "@layer5/sistent"; | ||||||
import { CodeBlock } from "./code-block"; | ||||||
import { SistentLayout } from "../../sistent-layout"; | ||||||
//import { FaArrowRight,FaUser, FaFolder, FaFile } from "react-icons/fa"; | ||||||
import TabButton from "../../../../../reusecore/Button"; | ||||||
import { useStyledDarkMode } from "../../../../../theme/app/useStyledDarkMode"; | ||||||
|
||||||
const codes = [ | ||||||
// Basic List with List Items | ||||||
` <SistentThemeProvider> | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can you remove SistentThemeProvider from code example blocks
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok, sir. |
||||||
<List> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent 1" /></ListItem> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent 2" /></ListItem> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent 3" /></ListItem> | ||||||
</List> | ||||||
</SistentThemeProvider>`, | ||||||
|
||||||
// List with Icons in List Items | ||||||
` <SistentThemeProvider> | ||||||
<List> | ||||||
<ListItem><ListItemIcon>🌟</ListItemIcon><ListItemText primary="Layer5 Sistent Starred" /></ListItem> | ||||||
<ListItem><ListItemIcon>📅</ListItemIcon><ListItemText primary="Layer5 Sistent Calender" /></ListItem> | ||||||
<ListItem><ListItemIcon>🔔</ListItemIcon><ListItemText primary="Layer5 Sistent Notification" /></ListItem> | ||||||
</List> | ||||||
</SistentThemeProvider>`, | ||||||
|
||||||
// List with Avatars | ||||||
` <SistentThemeProvider> | ||||||
<List> | ||||||
<ListItem><ListItemAvatar>👤</ListItemAvatar><ListItemText primary="Layer5 Sistent User 1" /></ListItem> | ||||||
<ListItem><ListItemAvatar>👩💻</ListItemAvatar><ListItemText primary="Layer5 Sistent User 2" /></ListItem> | ||||||
<ListItem><ListItemAvatar>👤</ListItemAvatar><ListItemText primary="Layer5 Sistent User 3" /></ListItem> | ||||||
</List> | ||||||
</SistentThemeProvider>`, | ||||||
|
||||||
// List with Subheader | ||||||
` <SistentThemeProvider> | ||||||
<List> | ||||||
<ListSubheader>Section 1</ListSubheader> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent A" /></ListItem> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent B" /></ListItem> | ||||||
<ListSubheader>Section 2</ListSubheader> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent C" /></ListItem> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent D" /></ListItem> | ||||||
</List> | ||||||
</SistentThemeProvider>`, | ||||||
|
||||||
// List with Action Buttons | ||||||
` <SistentThemeProvider> | ||||||
<List> | ||||||
<ListItemButton onClick={() => alert("Clicked!")}> Layer5 Sistent Action 1</ListItemButton> | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @csengineer1990 If you could provide a nested list code example, here is example link There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Should I add the nested list code example only in the code.js file, or should I also include it in the overview section to explain the concept of nested lists? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
I've added the example of a nested list in the code section. Please check it and let me know if it's okay or if any changes are needed. |
||||||
<ListItemButton onClick={() => alert("Clicked!")}>Layer5 Sistent Action 2</ListItemButton> | ||||||
</List> | ||||||
</SistentThemeProvider>`, | ||||||
]; | ||||||
|
||||||
export const ListCode = () => { | ||||||
const location = useLocation(); | ||||||
const { isDark } = useStyledDarkMode(); | ||||||
|
||||||
return ( | ||||||
<SistentLayout title="List"> | ||||||
<div className="content"> | ||||||
<a id="Identity"><h2>List</h2></a> | ||||||
<p> | ||||||
The List component displays a list of items in a structured and | ||||||
accessible manner. Variants include simple lists, lists with icons, | ||||||
lists with avatars, and lists with action buttons. | ||||||
</p> | ||||||
|
||||||
<div className="filterBtns"> | ||||||
<TabButton | ||||||
className={location.pathname === "/projects/sistent/components/list" ? "active" : ""} | ||||||
onClick={() => navigate("/projects/sistent/components/list")} | ||||||
title="Overview" | ||||||
/> | ||||||
<TabButton | ||||||
className={location.pathname === "/projects/sistent/components/list/guidance" ? "active" : ""} | ||||||
onClick={() => navigate("/projects/sistent/components/list/guidance")} | ||||||
title="Guidance" | ||||||
/> | ||||||
<TabButton | ||||||
className={location.pathname === "/projects/sistent/components/list/code" ? "active" : ""} | ||||||
onClick={() => navigate("/projects/sistent/components/list/code")} | ||||||
title="Code" | ||||||
/> | ||||||
</div> | ||||||
<div className="main-content"> | ||||||
{/* Simple List */} | ||||||
<a id="Simple List"><h3>Simple List</h3></a> | ||||||
<p>This is a basic list with plain text items.</p> | ||||||
<div className="showcase"> | ||||||
<div className="items"> | ||||||
|
||||||
<SistentThemeProvider initialMode={isDark ? "dark" : "light"}> | ||||||
<List> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent Item 1" /></ListItem> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent Item 2" /></ListItem> | ||||||
<ListItem><ListItemText primary="Layer5 Sistent Item 3" /></ListItem> | ||||||
</List> | ||||||
</SistentThemeProvider> | ||||||
|
||||||
</div> | ||||||
<CodeBlock name="simple-list" code={codes[0]} /> | ||||||
</div> | ||||||
|
||||||
{/* List with Icons */} | ||||||
<a id="List With Icons"><h3>List with Icons</h3></a> | ||||||
<p>List items can be paired with icons to add visual cues.</p> | ||||||
<div className="showcase"> | ||||||
<div className="items"> | ||||||
<SistentThemeProvider initialMode={isDark ? "dark" : "light"}> | ||||||
<List> | ||||||
<ListItem> | ||||||
<ListItemIcon>🌟</ListItemIcon> | ||||||
<ListItemText primary="Layer5 Sistent Starred" /> | ||||||
</ListItem> | ||||||
<ListItem> | ||||||
<ListItemIcon>📅</ListItemIcon> | ||||||
<ListItemText primary="Layer5 Sistent Calendar" /> | ||||||
</ListItem> | ||||||
<ListItem> | ||||||
<ListItemIcon>🔔</ListItemIcon> | ||||||
<ListItemText primary="Layer5 Sistent Notification" /> | ||||||
</ListItem> | ||||||
</List> | ||||||
</SistentThemeProvider> | ||||||
</div> | ||||||
<CodeBlock name="icon-list" code={codes[1]} /> | ||||||
</div> | ||||||
|
||||||
{/* List with Avatars */} | ||||||
<a id="List With Avatars"><h3>List with Avatars</h3></a> | ||||||
<p>Use avatars for list items representing people or entities.</p> | ||||||
<div className="showcase"> | ||||||
<div className="items"> | ||||||
<SistentThemeProvider initialMode={isDark ? "dark" : "light"}> | ||||||
<List> | ||||||
<ListItem><ListItemAvatar>👤</ListItemAvatar><ListItemText primary="Layer5 Sistent User 1" /></ListItem> | ||||||
<ListItem><ListItemAvatar>👩💻</ListItemAvatar><ListItemText primary="Layer5 Sistent User 2" /></ListItem> | ||||||
<ListItem><ListItemAvatar>👩💻</ListItemAvatar><ListItemText primary="Layer5 Sistent User 3" /></ListItem> | ||||||
</List> | ||||||
</SistentThemeProvider> | ||||||
</div> | ||||||
<CodeBlock name="avatar-list" code={codes[2]} /> | ||||||
</div> | ||||||
|
||||||
{/* List with Subheader */} | ||||||
<a id="List With Subheader"><h3>List with Subheader</h3></a> | ||||||
<p>Organize list items under different subheaders for better grouping.</p> | ||||||
<div className="showcase"> | ||||||
<div className="items"> | ||||||
<SistentThemeProvider initialMode={isDark ? "dark" : "light"}> | ||||||
<List> | ||||||
<ListSubheader>Section 1</ListSubheader> | ||||||
<ListItem> | ||||||
<ListItemText primary="Layer5 Sistent Item A" /> | ||||||
</ListItem> | ||||||
<ListItem> | ||||||
<ListItemText primary="Layer5 Sistent Item B" /> | ||||||
</ListItem> | ||||||
<Divider /> | ||||||
<ListSubheader>Section 2</ListSubheader> | ||||||
<ListItem> | ||||||
<ListItemText primary="Layer5 Sistent Item C" /> | ||||||
</ListItem> | ||||||
<ListItem> | ||||||
<ListItemText primary="Layer5 Sistent Item D" /> | ||||||
</ListItem> | ||||||
</List> | ||||||
</SistentThemeProvider> | ||||||
</div> | ||||||
<CodeBlock name="subheader-list" code={codes[3]} /> | ||||||
</div> | ||||||
|
||||||
{/* List with Action Buttons */} | ||||||
<a id="List With ActionButtons"><h3>List with Action Buttons</h3></a> | ||||||
<p>Lists can also have action buttons for added interactivity.</p> | ||||||
<div className="showcase"> | ||||||
<div className="items"> | ||||||
<SistentThemeProvider initialMode={isDark ? "dark" : "light"}> | ||||||
<List> | ||||||
{/* <ListItem text="Action Item 1" secondaryAction={<button>Action</button>} /> | ||||||
<ListItem text="Action Item 2" secondaryAction={<button>More</button>} /> */} | ||||||
<ListItemButton onClick={() => alert("Clicked!")}> Layer5 Sistent Action Item 1</ListItemButton> | ||||||
<ListItemButton onClick={() => alert("Clicked!")}>Layer5 Sistent Action Item 2</ListItemButton> | ||||||
</List> | ||||||
</SistentThemeProvider> | ||||||
</div> | ||||||
<CodeBlock name="button-list" code={codes[4]} /> | ||||||
</div> | ||||||
</div> | ||||||
</div> | ||||||
</SistentLayout> | ||||||
); | ||||||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
revert this file, i.e. feature_data.json