aboutsummaryrefslogtreecommitdiff
path: root/Timeline/ClientApp/src/app/views/timeline-common/InfoCardTemplate.tsx
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
commit92cc0f89d8c4314f4eebc76a0d12c9436f28f71a (patch)
tree7a600df9aec5c812d6049d912f4cdac07c5c9f69 /Timeline/ClientApp/src/app/views/timeline-common/InfoCardTemplate.tsx
parentc5a3df9b035f3aa47571236aefea8108ea4e4ad4 (diff)
downloadtimeline-92cc0f89d8c4314f4eebc76a0d12c9436f28f71a.tar.gz
timeline-92cc0f89d8c4314f4eebc76a0d12c9436f28f71a.tar.bz2
timeline-92cc0f89d8c4314f4eebc76a0d12c9436f28f71a.zip
Extract out info card template.
Diffstat (limited to 'Timeline/ClientApp/src/app/views/timeline-common/InfoCardTemplate.tsx')
-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;