Skip to content

Commit

Permalink
Fix save newsletter
Browse files Browse the repository at this point in the history
  • Loading branch information
bivillar committed Apr 2, 2020
1 parent ab0eaac commit d93f99f
Show file tree
Hide file tree
Showing 7 changed files with 55 additions and 36 deletions.
2 changes: 1 addition & 1 deletion node/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
"eslint": "5.x",
"eslint-config-vtex": "10.x",
"prettier": "^1.18.2",
"typescript": "3.7.3"
"typescript": "3.8.3"
},
"dependencies": {
"@vtex/api": "^3.48.2"
Expand Down
8 changes: 4 additions & 4 deletions node/yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -2040,10 +2040,10 @@ type-is@^1.6.16:
media-typer "0.3.0"
mime-types "~2.1.24"

typescript@3.7.3:
version "3.7.3"
resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.7.3.tgz#b36840668a16458a7025b9eabfad11b66ab85c69"
integrity sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==
typescript@3.8.3:
version "3.8.3"
resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.8.3.tgz#409eb8544ea0335711205869ec458ab109ee1061"
integrity sha512-MYlEfn5VrLNsgudQTVJeNaQFUAI7DkhnOjdpAp4T+ku1TfQClewlbSuTVHiA+8skNBgaf02TL/kLOvig4y3G8w==

universalify@^0.1.0:
version "0.1.2"
Expand Down
40 changes: 34 additions & 6 deletions react/components/Profile/NewsletterBox.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import { compose } from 'recompose'
import { Checkbox } from 'vtex.styleguide'

import ContentBox from '../shared/ContentBox'
import GET_NEWSLETTER from '../../graphql/getNewsletterOpt.gql'
import NEWSLETTER_MUTATION from '../../graphql/setOptInNewsletter.gql'

const messages = defineMessages({
Expand All @@ -23,10 +24,13 @@ const messages = defineMessages({
})

class NewsletterBox extends Component<Props, State> {
public constructor(props: Props) {
super(props)
this.state = {
checked: this.props.isNewsletterOptIn,
public state = {
checked: false,
}

public componentDidUpdate(oldProps: Props) {
if (oldProps.isNewsletterOptIn !== this.props.isNewsletterOptIn) {
this.setState({ checked: this.props.isNewsletterOptIn })
}
}

Expand Down Expand Up @@ -79,13 +83,37 @@ interface State {
checked: boolean
}

interface Props extends InjectedIntlProps {
type Props = ExternalProps & QueryResult & Mutations & InjectedIntlProps

interface ExternalProps {
userEmail: string
}

interface QueryData {
profile: Pick<Profile, 'customFields'>
loading: boolean
}

interface QueryResult {
loading?: boolean
isNewsletterOptIn: boolean
}

interface Mutations {
setOptInNewsletter: (args: Variables<SetOptInNewsletterArgs>) => Promise<void>
}

const enhance = compose<Props, Pick<Props, 'isNewsletterOptIn' | 'userEmail'>>(
const enhance = compose<Props, ExternalProps>(
graphql<Props, QueryData, unknown, QueryResult>(GET_NEWSLETTER, {
props: ({ data }) => ({
isNewsletterOptIn:
data?.profile?.customFields?.[0].value.toLowerCase() === 'true',
loading: data?.loading,
}),
options: {
fetchPolicy: 'cache-and-network',
},
}),
graphql(NEWSLETTER_MUTATION, { name: 'setOptInNewsletter' }),
injectIntl
)
Expand Down
17 changes: 2 additions & 15 deletions react/components/pages/Profile.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -47,17 +47,9 @@ class ProfileContainer extends Component<Props> {
)
}

private getIsNewsletterOptIn = (profile: Profile) => {
const isNewsletterOptIn = profile.customFields?.find(
({ key }) => key === 'isNewsletterOptIn'
)?.value
return isNewsletterOptIn?.toLowerCase() === 'true'
}

public render() {
const { profile } = this.props
const { isEditingPassword, showToast } = this.state
const isNewsletterOptIn = this.getIsNewsletterOptIn(profile)

return (
<main className="flex flex-column-s flex-row-ns">
Expand Down Expand Up @@ -85,10 +77,7 @@ class ProfileContainer extends Component<Props> {
onEditClick={this.handleEditingPassword}
/>
)}
<NewsletterBox
isNewsletterOptIn={isNewsletterOptIn}
userEmail={profile.email}
/>
<NewsletterBox userEmail={profile.email} />
</div>
{showToast && (
<Toast messageId="alert.success" onClose={this.handleCloseToast} />
Expand All @@ -109,9 +98,7 @@ interface Props {
}

const enhance = compose<Props, void>(
graphql(GET_PROFILE, {
options: { variables: { customFields: 'isNewsletterOptIn' } },
}),
graphql(GET_PROFILE),
branch<Props>(
({ data }) => data.profile == null,
renderComponent(ProfileLoading)
Expand Down
8 changes: 8 additions & 0 deletions react/graphql/getNewsletterOpt.gql
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
query NewsletterOpt @context(scope: "private") {
profile(customFields: "isNewsletterOptIn") {
customFields {
key
value
}
}
}
8 changes: 2 additions & 6 deletions react/graphql/getProfile.gql
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
query Profile($customFields: String) @context(scope: "private") {
profile(customFields: $customFields) {
query Profile @context(scope: "private") {
profile {
cacheId
firstName
lastName
Expand All @@ -15,9 +15,5 @@ query Profile($customFields: String) @context(scope: "private") {
stateRegistration
isCorporate
passwordLastUpdate
customFields {
key
value
}
}
}
8 changes: 4 additions & 4 deletions react/yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -5203,10 +5203,10 @@ type-check@~0.3.2:
dependencies:
prelude-ls "~1.1.2"

typescript@3.7.3:
version "3.7.3"
resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.7.3.tgz#b36840668a16458a7025b9eabfad11b66ab85c69"
integrity sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==
typescript@3.8.3:
version "3.8.3"
resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.8.3.tgz#409eb8544ea0335711205869ec458ab109ee1061"
integrity sha512-MYlEfn5VrLNsgudQTVJeNaQFUAI7DkhnOjdpAp4T+ku1TfQClewlbSuTVHiA+8skNBgaf02TL/kLOvig4y3G8w==

typescript@^3.3.3333:
version "3.5.3"
Expand Down

0 comments on commit d93f99f

Please sign in to comment.