From 446ccf26aca8211168b7adde7b66e53a1b20f702 Mon Sep 17 00:00:00 2001 From: tealjulia Date: Tue, 27 Sep 2022 17:02:00 -0400 Subject: [PATCH 1/9] renames for connection form refactor --- .../CreateConnection/CreateConnection.tsx | 2 +- .../components/TryAfterErrorBlock.module.scss | 14 ++++++++++ .../components/TryAfterErrorBlock.tsx | 27 +++++++++++++++++++ 3 files changed, 42 insertions(+), 1 deletion(-) create mode 100644 airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss create mode 100644 airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.tsx diff --git a/airbyte-webapp/src/components/CreateConnection/CreateConnection.tsx b/airbyte-webapp/src/components/CreateConnection/CreateConnection.tsx index d84727c643bd..2a27f73bc0eb 100644 --- a/airbyte-webapp/src/components/CreateConnection/CreateConnection.tsx +++ b/airbyte-webapp/src/components/CreateConnection/CreateConnection.tsx @@ -16,8 +16,8 @@ import { ConnectionForm } from "views/Connection/ConnectionForm"; import { DestinationRead, SourceRead } from "../../core/request/AirbyteClient"; import { useDiscoverSchema } from "../../hooks/services/useSourceHook"; +import TryAfterErrorBlock from "./components/TryAfterErrorBlock"; import styles from "./CreateConnection.module.scss"; -import TryAfterErrorBlock from "./TryAfterErrorBlock"; interface CreateConnectionProps { source: SourceRead; diff --git a/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss b/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss new file mode 100644 index 000000000000..fae2399b7e23 --- /dev/null +++ b/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss @@ -0,0 +1,14 @@ +@use "../../scss/variables"; + +.container { + padding: 40px; + text-align: center; +} + +.message { + padding: variables.$spacing-lg 0 variables.$spacing-md; +} + +.retryButton { + min-width: 239px; +} diff --git a/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.tsx b/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.tsx new file mode 100644 index 000000000000..4c7a1145e86d --- /dev/null +++ b/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.tsx @@ -0,0 +1,27 @@ +import React from "react"; +import { FormattedMessage } from "react-intl"; + +import { StatusIcon } from "components/StatusIcon"; +import { Button } from "components/ui/Button"; +import { Text } from "components/ui/Text"; + +import styles from "./TryAfterErrorBlock.module.scss"; + +interface TryAfterErrorBlockProps { + message?: React.ReactNode; + onClick: () => void; +} + +const TryAfterErrorBlock: React.FC = ({ message, onClick }) => ( +
+ + + {message || } + + +
+); + +export default TryAfterErrorBlock; From e4fdc128f145019e5ccbee714920d843491c1bfe Mon Sep 17 00:00:00 2001 From: tealjulia Date: Wed, 28 Sep 2022 13:37:46 -0400 Subject: [PATCH 2/9] connection form, namespace definition, section --- .../ConnectionForm/ConnectionForm.module.scss | 40 ++++++ .../ConnectionForm/ConnectionForm.tsx | 134 ++++++------------ .../NamespaceDefinitionField.module.scss | 1 + .../components/NamespaceDefinitionField.tsx | 15 +- .../components/Section.module.scss | 11 ++ .../ConnectionForm/components/Section.tsx | 17 +++ 6 files changed, 116 insertions(+), 102 deletions(-) create mode 100644 airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss create mode 100644 airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss create mode 100644 airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.module.scss create mode 100644 airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.tsx diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss new file mode 100644 index 000000000000..232d8c598ace --- /dev/null +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss @@ -0,0 +1,40 @@ +.formContainer { + display: flex; + flex-direction: column; + gap: 10px; +} + +.readonly { + pointer-events: none; +} + +.flexRow { + display: flex; + flex-direction: row; + justify-content: flex-start; + align-items: flex-start; + gap: 10px; +} + +.leftFieldCol { + flex: 1; + max-width: 640px; + padding-right: 30px; +} + +.rightFieldCol { + flex: 1; + max-width: 300px; +} + +.namespaceFormatLabel { + flex: 5 0 0; + display: flex; + flex-direction: column; + justify-content: space-between; +} + +.tryArrow { + margin: 0 10px -1px 0; + font-size: 14px; +} diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx index 10a2da74154c..de3523a2a2f9 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx @@ -1,14 +1,15 @@ -import { Field, FieldProps, Form, Formik } from "formik"; +import classNames from "classnames"; +import { Field, FieldProps, Formik } from "formik"; import React from "react"; import { FormattedMessage, useIntl } from "react-intl"; import { useToggle } from "react-use"; import styled from "styled-components"; -import { H5 } from "components/base/Titles"; import { FormChangeTracker } from "components/FormChangeTracker"; import { ControlLabels } from "components/LabeledControl"; import { Card } from "components/ui/Card"; import { Input } from "components/ui/Input"; +import { Text } from "components/ui/Text"; import { NamespaceDefinitionType } from "core/request/AirbyteClient"; import { useConnectionFormService } from "hooks/services/ConnectionForm/ConnectionFormService"; @@ -18,80 +19,21 @@ import EditControls from "./components/EditControls"; import { NamespaceDefinitionField } from "./components/NamespaceDefinitionField"; import { OperationsSection } from "./components/OperationsSection"; import ScheduleField from "./components/ScheduleField"; +import { Section } from "./components/Section"; import SchemaField from "./components/SyncCatalogField"; +import styles from "./ConnectionForm.module.css"; import { connectionValidationSchema } from "./formConfig"; +// This is removed in KC's main refactor PR. Removing it would require major scope creep for this PR. const ConnectorLabel = styled(ControlLabels)` max-width: 328px; margin-right: 20px; vertical-align: top; `; -const NamespaceFormatLabel = styled(ControlLabels)` - flex: 5 0 0; - display: flex; - flex-direction: column; - justify-content: space-between; -`; - -export const FlexRow = styled.div` - display: flex; - flex-direction: row; - justify-content: flex-start; - align-items: flex-start; - gap: 10px; -`; - -export const LeftFieldCol = styled.div` - flex: 1; - max-width: 640px; - padding-right: 30px; -`; - -export const RightFieldCol = styled.div` - flex: 1; - max-width: 300px; -`; - -export const StyledSection = styled.div` - padding: 20px 20px; - display: flex; - flex-direction: column; - gap: 15px; - - &:not(:last-child) { - box-shadow: 0 1px 0 rgba(139, 139, 160, 0.25); - } -`; - -interface SectionProps { - title?: React.ReactNode; -} - -const LabelHeading = styled(H5)` - line-height: 16px; - display: inline; -`; - -const Section: React.FC> = ({ title, children }) => ( - - - {title &&
{title}
} - {children} -
-
-); - -const FormContainer = styled(Form)` - display: flex; - flex-direction: column; - gap: 10px; -`; - export type ConnectionFormMode = "create" | "edit" | "readonly"; export interface ConnectionFormProps { - className?: string; successMessage?: React.ReactNode; /** Should be passed when connection is updated with withRefreshCatalog flag */ @@ -100,7 +42,6 @@ export interface ConnectionFormProps { } export const ConnectionForm: React.FC = ({ - className, successMessage, canSubmitUntouchedForm, additionalSchemaControl, @@ -110,6 +51,10 @@ export const ConnectionForm: React.FC = ({ const [editingTransformation, toggleEditingTransformation] = useToggle(false); const { formatMessage } = useIntl(); + const readonlyClass = classNames({ + [styles.readonly]: mode === "readonly", + }); + return ( = ({ onSubmit={onFormSubmit} > {({ isSubmitting, isValid, dirty, resetForm, values }) => ( - +
{mode === "create" && (
{({ field, meta }: FieldProps) => ( - - +
+
+ - + } message={formatMessage({ id: "form.connectionName.message", })} /> - - +
+
= ({ id: "form.connectionName.placeholder", })} /> - - +
+
)}
@@ -158,26 +103,27 @@ export const ConnectionForm: React.FC = ({ - -
+
+ -
+ {values.namespaceDefinition === NamespaceDefinitionType.customformat && ( {({ field, meta }: FieldProps) => ( - - - +
+ } message={} /> - - +
+
= ({ id: "connectionForm.namespaceFormat.placeholder", })} /> - - +
+
)} )} {({ field }: FieldProps) => ( - - +
+
= ({ id: "form.prefix.message", })} /> - - +
+
= ({ data-testid="prefixInput" style={{ pointerEvents: mode === "readonly" ? "none" : "auto" }} /> - - +
+
)}
- - + +
- +
{mode === "edit" && ( = ({ /> )} -
+ )}
); diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss b/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss new file mode 100644 index 000000000000..7fd4485ab708 --- /dev/null +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss @@ -0,0 +1 @@ +@forward "../ConnectionFormFields.module.scss"; diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.tsx b/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.tsx index efc7888ad940..b1ff8ab1c5bb 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.tsx +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.tsx @@ -5,8 +5,7 @@ import { FormattedMessage } from "react-intl"; import { ControlLabels, DropDown } from "components"; import { NamespaceDefinitionType } from "../../../../core/request/AirbyteClient"; -import { FlexRow, LeftFieldCol, RightFieldCol } from "../ConnectionForm"; - +import styles from "./NamespaceDefinitionField.module.scss"; export const StreamOptions = [ { value: NamespaceDefinitionType.source, @@ -29,8 +28,8 @@ export const NamespaceDefinitionField: React.FC> = ({ field, const [, meta] = useField(field.name); return ( - - +
+
> = ({ field, label={} message={} /> - - +
+
> = ({ field, value={field.value} onChange={({ value }) => form.setFieldValue(field.name, value)} /> - - +
+
); }; diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.module.scss b/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.module.scss new file mode 100644 index 000000000000..94531f4b7f92 --- /dev/null +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.module.scss @@ -0,0 +1,11 @@ +.section { + padding: 20px; + display: flex; + flex-direction: column; + gap: 15px; + + // TODO: We may be able to get rid of this. + &:not(:last-child) { + box-shadow: 0 1px 0 rgba(139, 139, 160, 25%); + } +} diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.tsx b/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.tsx new file mode 100644 index 000000000000..b34d33f05080 --- /dev/null +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.tsx @@ -0,0 +1,17 @@ +import { Card } from "components/ui"; +import { Text } from "components/ui/Text"; + +import styles from "./Section.module.scss"; + +interface SectionProps { + title?: React.ReactNode; +} + +export const Section: React.FC> = ({ title, children }) => ( + +
+ {title && {title}} + {children} +
+
+); From 2e2402baf088a8899c90764f0ed53793f0127268 Mon Sep 17 00:00:00 2001 From: tealjulia Date: Wed, 28 Sep 2022 13:40:45 -0400 Subject: [PATCH 3/9] operations section --- .../ConnectionForm/components/OperationsSection.tsx | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/components/OperationsSection.tsx b/airbyte-webapp/src/views/Connection/ConnectionForm/components/OperationsSection.tsx index 6dfa6f10cfb0..1e5a77f78819 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/components/OperationsSection.tsx +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/components/OperationsSection.tsx @@ -2,14 +2,14 @@ import { Field, FieldArray } from "formik"; import React from "react"; import { useIntl } from "react-intl"; -import { H5 } from "components/base/Titles"; import { Card } from "components/ui/Card"; +import { Text } from "components/ui/Text"; import { useConnectionFormService } from "hooks/services/ConnectionForm/ConnectionFormService"; import { FeatureItem, useFeature } from "hooks/services/Feature"; -import { StyledSection } from "../ConnectionForm"; import { NormalizationField } from "./NormalizationField"; +import { Section } from "./Section"; import { TransformationField } from "./TransformationField"; interface OperationsSectionProps { @@ -35,16 +35,16 @@ export const OperationsSection: React.FC = ({ return ( - +
{supportsNormalization || supportsTransformations ? ( -
+ {[ supportsNormalization && formatMessage({ id: "connectionForm.normalization.title" }), supportsTransformations && formatMessage({ id: "connectionForm.transformation.title" }), ] .filter(Boolean) .join(" & ")} -
+ ) : null} {supportsNormalization && } {supportsTransformations && ( @@ -58,7 +58,7 @@ export const OperationsSection: React.FC = ({ )} )} - +
); }; From 66dca4eb3d77b83a650aed81163bc5d3cffc7ac7 Mon Sep 17 00:00:00 2001 From: tealjulia Date: Wed, 28 Sep 2022 16:15:49 -0400 Subject: [PATCH 4/9] cleanup for text sizes --- .../ConnectionForm/ConnectionForm.module.scss | 12 ------------ .../Connection/ConnectionForm/ConnectionForm.tsx | 6 +++--- .../components/NamespaceDefinitionField.module.scss | 9 ++++++++- .../Connection/ConnectionForm/components/Section.tsx | 6 +++++- 4 files changed, 16 insertions(+), 17 deletions(-) diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss index 232d8c598ace..d92bbbf6789c 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss @@ -26,15 +26,3 @@ flex: 1; max-width: 300px; } - -.namespaceFormatLabel { - flex: 5 0 0; - display: flex; - flex-direction: column; - justify-content: space-between; -} - -.tryArrow { - margin: 0 10px -1px 0; - font-size: 14px; -} diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx index de3523a2a2f9..d004446c7542 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx @@ -21,7 +21,7 @@ import { OperationsSection } from "./components/OperationsSection"; import ScheduleField from "./components/ScheduleField"; import { Section } from "./components/Section"; import SchemaField from "./components/SyncCatalogField"; -import styles from "./ConnectionForm.module.css"; +import styles from "./ConnectionForm.module.scss"; import { connectionValidationSchema } from "./formConfig"; // This is removed in KC's main refactor PR. Removing it would require major scope creep for this PR. @@ -75,7 +75,7 @@ export const ConnectionForm: React.FC = ({ nextLine error={!!meta.error && meta.touched} label={ - + } @@ -104,7 +104,7 @@ export const ConnectionForm: React.FC = ({
- + diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss b/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss index 7fd4485ab708..7cf8b0ba1dca 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss @@ -1 +1,8 @@ -@forward "../ConnectionFormFields.module.scss"; +@forward "../ConnectionForm.module.scss"; + +.namespaceFormatLabel { + flex: 5 0 0; + display: flex; + flex-direction: column; + justify-content: space-between; +} diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.tsx b/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.tsx index b34d33f05080..57d28f56ed95 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.tsx +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.tsx @@ -10,7 +10,11 @@ interface SectionProps { export const Section: React.FC> = ({ title, children }) => (
- {title && {title}} + {title && ( + + {title} + + )} {children}
From ecce2019a604d04e89c783977cc70afc73443503 Mon Sep 17 00:00:00 2001 From: tealjulia Date: Thu, 29 Sep 2022 11:17:33 -0400 Subject: [PATCH 5/9] updated connection name to use Text --- .../components/TryAfterErrorBlock.module.scss | 2 +- .../pages/ConnectionItemPage/ConnectionName.module.scss | 6 ++---- .../pages/ConnectionItemPage/ConnectionName.tsx | 5 ++++- .../components/NamespaceDefinitionField.module.scss | 7 ------- 4 files changed, 7 insertions(+), 13 deletions(-) diff --git a/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss b/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss index fae2399b7e23..5b73e2b8991b 100644 --- a/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss +++ b/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss @@ -1,7 +1,7 @@ @use "../../scss/variables"; .container { - padding: 40px; + padding: variables.$spacing-2xl; text-align: center; } diff --git a/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionName.module.scss b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionName.module.scss index 05ba9b001d70..689a99b2c03a 100644 --- a/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionName.module.scss +++ b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionName.module.scss @@ -20,6 +20,8 @@ display: none; position: absolute; right: variables.$spacing-xl; + + // used to control svg size, not text size font-size: 18px; color: colors.$blue; } @@ -35,11 +37,7 @@ width: 100%; h2 { - font-weight: 700; - font-size: 24px; - line-height: 29px; text-align: center; - color: colors.$dark-blue-900; margin: variables.$spacing-md; word-wrap: break-word; } diff --git a/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionName.tsx b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionName.tsx index 303699871935..8bb38d8df64f 100644 --- a/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionName.tsx +++ b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionName.tsx @@ -3,6 +3,7 @@ import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; import React, { ChangeEvent, useState } from "react"; import { Input } from "components"; +import { Text } from "components/ui/Text"; import { buildConnectionUpdate } from "core/domain/connection"; import { WebBackendConnectionRead } from "core/request/AirbyteClient"; @@ -85,7 +86,9 @@ export const ConnectionName: React.FC = ({ connection }) => ) : ( diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss b/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss index 7cf8b0ba1dca..0a3d7654d1e2 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/components/NamespaceDefinitionField.module.scss @@ -1,8 +1 @@ @forward "../ConnectionForm.module.scss"; - -.namespaceFormatLabel { - flex: 5 0 0; - display: flex; - flex-direction: column; - justify-content: space-between; -} From 0c48c06a85a9b94448262340534e463ff28216c3 Mon Sep 17 00:00:00 2001 From: tealjulia Date: Thu, 29 Sep 2022 12:05:38 -0400 Subject: [PATCH 6/9] use variables and text component --- .../ConnectionReplicationTab.module.scss | 14 +++++++++++++ .../ConnectionReplicationTab.tsx | 20 +++++-------------- .../ConnectionForm/ConnectionForm.module.scss | 8 +++++--- .../components/Section.module.scss | 6 ++++-- 4 files changed, 28 insertions(+), 20 deletions(-) create mode 100644 airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.module.scss diff --git a/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.module.scss b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.module.scss new file mode 100644 index 000000000000..1973c031da26 --- /dev/null +++ b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.module.scss @@ -0,0 +1,14 @@ +@use "../../../../../scss/variables"; + +.tryArrow { + margin: 0 variables.$spacing-md -1px 0; + + // used to control svg size + font-size: 14px; +} + +.content { + max-width: 1279px; + margin: 0 auto; + padding-bottom: variables.$spacing-md; +} diff --git a/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.tsx b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.tsx index 97bc17dac7ca..97cb8b508f6c 100644 --- a/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.tsx +++ b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.tsx @@ -3,7 +3,6 @@ import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; import React, { useMemo, useState } from "react"; import { FormattedMessage, useIntl } from "react-intl"; import { useAsyncFn, useUnmount } from "react-use"; -import styled from "styled-components"; import { LabeledSwitch } from "components/LabeledSwitch"; import LoadingSchema from "components/LoadingSchema"; @@ -27,6 +26,8 @@ import { equal, naturalComparatorBy } from "utils/objects"; import { CatalogDiffModal } from "views/Connection/CatalogDiffModal/CatalogDiffModal"; import { ConnectionForm } from "views/Connection/ConnectionForm"; +import styles from "./ConnectionReplicationTab.module.scss"; + interface ConnectionReplicationTabProps { onAfterSaveSchema: () => void; connectionId: string; @@ -74,17 +75,6 @@ const ResetWarningModal: React.FC = ({ onCancel, onClose ); }; -const Content = styled.div` - max-width: 1279px; - margin: 0 auto; - padding-bottom: 10px; -`; - -const TryArrow = styled(FontAwesomeIcon)` - margin: 0 10px -1px 0; - font-size: 14px; -`; - export const ConnectionReplicationTab: React.FC = ({ onAfterSaveSchema, connectionId, @@ -221,7 +211,7 @@ export const ConnectionReplicationTab: React.FC = }; return ( - +
{!isRefreshingCatalog && connection ? ( = onClick={onRefreshSourceSchema} type="button" variant="secondary" - icon={} + icon={} > @@ -249,6 +239,6 @@ export const ConnectionReplicationTab: React.FC = ) : ( )} - +
); }; diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss index d92bbbf6789c..ef0b0aa1659e 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.module.scss @@ -1,7 +1,9 @@ +@use "../../../scss/variables"; + .formContainer { display: flex; flex-direction: column; - gap: 10px; + gap: variables.$spacing-md; } .readonly { @@ -13,13 +15,13 @@ flex-direction: row; justify-content: flex-start; align-items: flex-start; - gap: 10px; + gap: variables.$spacing-md; } .leftFieldCol { flex: 1; max-width: 640px; - padding-right: 30px; + padding-right: variables.$spacing-xl; } .rightFieldCol { diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.module.scss b/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.module.scss index 94531f4b7f92..54c545da209f 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.module.scss +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/components/Section.module.scss @@ -1,8 +1,10 @@ +@use "../../../../scss/variables"; + .section { - padding: 20px; + padding: variables.$spacing-xl; display: flex; flex-direction: column; - gap: 15px; + gap: variables.$spacing-lg; // TODO: We may be able to get rid of this. &:not(:last-child) { From d7953abfaf0dd0cf5b256d280daa46409561f75a Mon Sep 17 00:00:00 2001 From: tealjulia Date: Fri, 30 Sep 2022 11:13:57 -0400 Subject: [PATCH 7/9] cleanup from rebase --- .../CreateConnection/CreateConnection.tsx | 2 +- .../components/TryAfterErrorBlock.module.scss | 14 ---------- .../components/TryAfterErrorBlock.tsx | 27 ------------------- .../ConnectionReplicationTab.module.scss | 2 +- 4 files changed, 2 insertions(+), 43 deletions(-) delete mode 100644 airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss delete mode 100644 airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.tsx diff --git a/airbyte-webapp/src/components/CreateConnection/CreateConnection.tsx b/airbyte-webapp/src/components/CreateConnection/CreateConnection.tsx index 2a27f73bc0eb..d84727c643bd 100644 --- a/airbyte-webapp/src/components/CreateConnection/CreateConnection.tsx +++ b/airbyte-webapp/src/components/CreateConnection/CreateConnection.tsx @@ -16,8 +16,8 @@ import { ConnectionForm } from "views/Connection/ConnectionForm"; import { DestinationRead, SourceRead } from "../../core/request/AirbyteClient"; import { useDiscoverSchema } from "../../hooks/services/useSourceHook"; -import TryAfterErrorBlock from "./components/TryAfterErrorBlock"; import styles from "./CreateConnection.module.scss"; +import TryAfterErrorBlock from "./TryAfterErrorBlock"; interface CreateConnectionProps { source: SourceRead; diff --git a/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss b/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss deleted file mode 100644 index 5b73e2b8991b..000000000000 --- a/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.module.scss +++ /dev/null @@ -1,14 +0,0 @@ -@use "../../scss/variables"; - -.container { - padding: variables.$spacing-2xl; - text-align: center; -} - -.message { - padding: variables.$spacing-lg 0 variables.$spacing-md; -} - -.retryButton { - min-width: 239px; -} diff --git a/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.tsx b/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.tsx deleted file mode 100644 index 4c7a1145e86d..000000000000 --- a/airbyte-webapp/src/components/CreateConnection/components/TryAfterErrorBlock.tsx +++ /dev/null @@ -1,27 +0,0 @@ -import React from "react"; -import { FormattedMessage } from "react-intl"; - -import { StatusIcon } from "components/StatusIcon"; -import { Button } from "components/ui/Button"; -import { Text } from "components/ui/Text"; - -import styles from "./TryAfterErrorBlock.module.scss"; - -interface TryAfterErrorBlockProps { - message?: React.ReactNode; - onClick: () => void; -} - -const TryAfterErrorBlock: React.FC = ({ message, onClick }) => ( -
- - - {message || } - - -
-); - -export default TryAfterErrorBlock; diff --git a/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.module.scss b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.module.scss index 1973c031da26..10360aaf922e 100644 --- a/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.module.scss +++ b/airbyte-webapp/src/pages/ConnectionPage/pages/ConnectionItemPage/ConnectionReplicationTab.module.scss @@ -1,4 +1,4 @@ -@use "../../../../../scss/variables"; +@use "../../../../scss/variables"; .tryArrow { margin: 0 variables.$spacing-md -1px 0; From 15fa6712325c6a3d3929e5614af5a13439937991 Mon Sep 17 00:00:00 2001 From: tealjulia Date: Fri, 30 Sep 2022 11:17:57 -0400 Subject: [PATCH 8/9] remove bad card --- .../ConnectionForm/ConnectionForm.tsx | 113 +++++++++--------- 1 file changed, 55 insertions(+), 58 deletions(-) diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx index d004446c7542..1c0601e46b61 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx @@ -7,7 +7,6 @@ import styled from "styled-components"; import { FormChangeTracker } from "components/FormChangeTracker"; import { ControlLabels } from "components/LabeledControl"; -import { Card } from "components/ui/Card"; import { Input } from "components/ui/Input"; import { Text } from "components/ui/Text"; @@ -102,78 +101,76 @@ export const ConnectionForm: React.FC = ({
}>
- -
- - - - - - - {values.namespaceDefinition === NamespaceDefinitionType.customformat && ( - - {({ field, meta }: FieldProps) => ( -
-
- } - message={} - /> -
-
- -
-
- )} -
- )} - - {({ field }: FieldProps) => ( +
+ + + + + + + {values.namespaceDefinition === NamespaceDefinitionType.customformat && ( + + {({ field, meta }: FieldProps) => (
} + message={} />
-
+
)} -
-
- -
- + )} + + {({ field }: FieldProps) => ( +
+
+ +
+
+ +
+
+ )} +
+
+
+ +
{mode === "edit" && ( Date: Fri, 30 Sep 2022 16:31:58 -0400 Subject: [PATCH 9/9] make the form a form --- .../src/views/Connection/ConnectionForm/ConnectionForm.tsx | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx index 1c0601e46b61..d574fc05ee36 100644 --- a/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx +++ b/airbyte-webapp/src/views/Connection/ConnectionForm/ConnectionForm.tsx @@ -1,5 +1,5 @@ import classNames from "classnames"; -import { Field, FieldProps, Formik } from "formik"; +import { Field, FieldProps, Form, Formik } from "formik"; import React from "react"; import { FormattedMessage, useIntl } from "react-intl"; import { useToggle } from "react-use"; @@ -62,7 +62,7 @@ export const ConnectionForm: React.FC = ({ onSubmit={onFormSubmit} > {({ isSubmitting, isValid, dirty, resetForm, values }) => ( -
+
{mode === "create" && (
@@ -197,7 +197,7 @@ export const ConnectionForm: React.FC = ({ /> )} -
+ )} );