diff options
author | crupest <crupest@outlook.com> | 2020-09-03 23:00:38 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-09-03 23:00:38 +0800 |
commit | ade9ed64bd06384dfa3ea34f6fca61c58c047680 (patch) | |
tree | 473cfb040d7bfad7a9517da50d26b1c18d560b4e /Timeline/ClientApp/src/app/views/timeline-common | |
parent | 46dc7e12da41056914a0f5fcdabbd20f81ef3bac (diff) | |
download | timeline-ade9ed64bd06384dfa3ea34f6fca61c58c047680.tar.gz timeline-ade9ed64bd06384dfa3ea34f6fca61c58c047680.tar.bz2 timeline-ade9ed64bd06384dfa3ea34f6fca61c58c047680.zip |
Extract out info card template.
Diffstat (limited to 'Timeline/ClientApp/src/app/views/timeline-common')
-rw-r--r-- | Timeline/ClientApp/src/app/views/timeline-common/InfoCardTemplate.tsx | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/Timeline/ClientApp/src/app/views/timeline-common/InfoCardTemplate.tsx b/Timeline/ClientApp/src/app/views/timeline-common/InfoCardTemplate.tsx new file mode 100644 index 00000000..a8de20aa --- /dev/null +++ b/Timeline/ClientApp/src/app/views/timeline-common/InfoCardTemplate.tsx @@ -0,0 +1,26 @@ +import React from "react"; +import clsx from "clsx"; + +import { TimelineCardComponentProps } from "../timeline-common/TimelinePageTemplateUI"; +import SyncStatusBadge from "../timeline-common/SyncStatusBadge"; +import CollapseButton from "../timeline-common/CollapseButton"; + +const InfoCardTemplate: React.FC< + Pick< + TimelineCardComponentProps<"">, + "collapse" | "toggleCollapse" | "syncStatus" | "className" + > & { children: React.ReactElement[] } +> = ({ collapse, toggleCollapse, syncStatus, className, children }) => { + return ( + <div className={clsx("cru-card p-2 clearfix", className)}> + <div className="float-right d-flex align-items-center"> + <SyncStatusBadge status={syncStatus} className="mr-2" /> + <CollapseButton collapse={collapse} onClick={toggleCollapse} /> + </div> + + <div style={{ display: collapse ? "none" : "block" }}>{children}</div> + </div> + ); +}; + +export default InfoCardTemplate; |