aboutsummaryrefslogtreecommitdiff
path: root/Timeline/ClientApp/src/app/views/timeline-common
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-09-03 23:00:38 +0800
committercrupest <crupest@outlook.com>2020-09-03 23:00:38 +0800
commitade9ed64bd06384dfa3ea34f6fca61c58c047680 (patch)
tree473cfb040d7bfad7a9517da50d26b1c18d560b4e /Timeline/ClientApp/src/app/views/timeline-common
parent46dc7e12da41056914a0f5fcdabbd20f81ef3bac (diff)
downloadtimeline-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.tsx26
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;