Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[DP-180] Fixed mobile display of lesson pages #229

Open
wants to merge 4 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
117 changes: 117 additions & 0 deletions website/src/components/lesson.css.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
import { globalStyle, style } from "@vanilla-extract/css"
import { important, padding } from "polished"
import { Styles } from "polished/lib/types/style"
import {
colors,
hsize,
hspace,
space,
thickness,
vspace,
} from "src/style/constants"
import { marginY, paddingX } from "src/style/utils"

// Parent class defining a Wordpress page.
// All classes defined in this file begin with this generated className to control the scope of these styles.
export const lesson = style({})

const mobileQuery = "screen and (max-width: 52em)"
chanmioh marked this conversation as resolved.
Show resolved Hide resolved

//// INPUT STYLES
const mobileInputSize = `calc(1rem * 2)`
chanmioh marked this conversation as resolved.
Show resolved Hide resolved

// On mobile, increases width and height of input boxes for better mobile visibility.
globalStyle(`${lesson} input`, {
"@media": {
[mobileQuery]: important({
width: hsize.full,
height: mobileInputSize,
}),
},
})

// A global style that styles fill in the blank sentences where a word
// appears below the input box.
globalStyle(`${lesson} .fill-blank span`, {
display: "inline-flex",
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What does inline-flex do? Why not normal flex?

flexDirection: "column",
alignItems: "center",
...paddingX(hspace.halfEdge),
})

//// IMAGE AND CAPTION STYLES
const figure = `${lesson} figure`
// Gives flexbox items (image and caption) a column look only on mobile.
globalStyle(figure, {
display: "flex",
flexDirection: "row",
alignItems: "center",
textAlign: "left",
gap: `calc(${space.large} * 2)`,
chanmioh marked this conversation as resolved.
Show resolved Hide resolved

"@media": {
[mobileQuery]: important({
flexDirection: "column",
gap: 0,
}),
},
})

// Styles the caption text of figures.
globalStyle(`${figure} figcaption > *`, {
color: colors.primary,
display: "flex",
flexDirection: "column",
alignItems: "start",
})

/// TABLE STYLES
// Styles rows of a table.
// On mobile, since row width is limited, convert each row into a "column-like" element
// and space out their margins.
globalStyle(`${lesson} table tr`, {
"@media": {
[mobileQuery]: important({
display: "flex",
flexDirection: "column",
border: `${thickness.thin} solid ${colors.text}`,
...(marginY(vspace.large) as Styles),
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm surprised this as clause is necessary, it wasn't passing typecheck? Later on, padding seems to work fine so maybe revise the type of the marginY function.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you mean revise the type that marginY returns? Since it looks like the padding functions that work return a Styles instead of StyleRules which allows them to work

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's try this out chanmi, and deploy changes after @GracefulLemming reviews.

}),
},
})

// Styles columns of a table.
// On mobile, give columns full width with equally sized padding.
globalStyle(`${lesson} table td`, {
"@media": {
[mobileQuery]: important({
width: hsize.full,
...padding(hspace.medium),
}),
},
})

/// HORIZONTAL LINE STYLES
globalStyle(
`${lesson} hr`,
important({ width: hsize.full, marginBottom: vspace["1.5"] })
)

/// BLOCKQUOTES STYLES
// By default, set this width to 500px, but on mobile make width auto to
// compensate for the smaller size screen.
globalStyle(`${lesson} blockquote`, {
width: `calc(${hsize.large} / 2)`,
chanmioh marked this conversation as resolved.
Show resolved Hide resolved
"@media": {
[mobileQuery]: important({
width: hsize.auto,
}),
},
})

/// MODULE BUTTON STYLES
// Styles the position of the module buttons at the end of every lesson.
globalStyle(`${lesson} .module-buttons`, {
display: "flex",
justifyContent: "space-between",
})
15 changes: 14 additions & 1 deletion website/src/components/wordpress.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,12 @@ import { Button, Link } from "src/components"
import * as Dailp from "src/graphql/dailp"
import * as Wordpress from "src/graphql/wordpress"
import { usePreferences } from "src/preferences-context"
import { useRouteParams } from "src/renderer/PageShell"
import { AnnotatedForm } from "src/segment"
import { annotationSection } from "src/segment.css"
import { wordpressUrl } from "src/theme.css"
import { BasicMorphemeSegment, LevelOfDetail } from "src/types"
import * as lessonCSS from "./lesson.css"

interface Props {
slug: string
Expand Down Expand Up @@ -44,8 +46,19 @@ export const WordpressPageContents = ({
}: {
content: string | null
}) => {
const { "*": slug } = useRouteParams()

let parsed

if (content) {
const parsed = parse(content, parseOptions)
chanmioh marked this conversation as resolved.
Show resolved Hide resolved
// If the slug includes "lessons/", include a parent element that styles its children's elements for printed media.
if (slug?.includes("lessons/")) {
parsed = (
<div className={lessonCSS.lesson}>{parse(content, parseOptions)}</div>
)
} else {
parsed = parse(content, parseOptions)
}
return <>{parsed}</>
} else {
return null
Expand Down