mirror of
https://github.com/Steffo99/bluelib.git
synced 2025-01-08 19:29:48 +00:00
✨ Add Ruby
annotations
This commit is contained in:
parent
d72dc52fda
commit
0ab75379a1
7 changed files with 133 additions and 0 deletions
21
src/components/annotations/Ruby.stories.jsx
Normal file
21
src/components/annotations/Ruby.stories.jsx
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
import * as React from "react"
|
||||||
|
import * as ReactDOM from "react-dom"
|
||||||
|
import * as Decorators from "../../utils/Decorators"
|
||||||
|
import { Ruby as RubyComponent } from "./Ruby"
|
||||||
|
|
||||||
|
|
||||||
|
export default {
|
||||||
|
component: RubyComponent,
|
||||||
|
title: "Annotations/Ruby",
|
||||||
|
decorators: [Decorators.Bluelib],
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export const Ruby = props => (
|
||||||
|
<RubyComponent {...props}>
|
||||||
|
<RubyComponent.Block text={"Mo"} annotation={"ˈmɒ"} open={"/"} close={"/"}/>
|
||||||
|
<RubyComponent.Block text={"de"} annotation={"dɪ"} open={"/"} close={"/"}/>
|
||||||
|
<RubyComponent.Block text={"na"} annotation={"nə"} open={"/"} close={"/"}/>
|
||||||
|
</RubyComponent>
|
||||||
|
)
|
||||||
|
Ruby.args = {}
|
27
src/components/annotations/Ruby.tsx
Normal file
27
src/components/annotations/Ruby.tsx
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
import * as React from "react"
|
||||||
|
import * as ReactDOM from "react-dom"
|
||||||
|
import * as Types from "../../types"
|
||||||
|
import {BaseElement} from "../BaseElement"
|
||||||
|
import mergeClassNames from "classnames"
|
||||||
|
import {RubyBlock} from "./RubyBlock";
|
||||||
|
import {RubyParenthesis} from "./RubyParenthesis";
|
||||||
|
|
||||||
|
|
||||||
|
export interface RubyProps extends Types.BluelibHTMLProps<HTMLElement> {}
|
||||||
|
|
||||||
|
|
||||||
|
export function Ruby({...props}: RubyProps): JSX.Element {
|
||||||
|
props.bluelibClassNames = mergeClassNames(props.bluelibClassNames, "ruby")
|
||||||
|
|
||||||
|
return (
|
||||||
|
<BaseElement kind={"ruby"} {...props}/>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Ruby.Block = RubyBlock
|
||||||
|
|
||||||
|
Ruby.Internals = {
|
||||||
|
Parenthesis: RubyParenthesis,
|
||||||
|
Block: RubyBlock,
|
||||||
|
}
|
22
src/components/annotations/RubyBlock.stories.jsx
Normal file
22
src/components/annotations/RubyBlock.stories.jsx
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
import * as React from "react"
|
||||||
|
import * as ReactDOM from "react-dom"
|
||||||
|
import * as Decorators from "../../utils/Decorators"
|
||||||
|
import { RubyBlock as RubyBlockComponent } from "./RubyBlock"
|
||||||
|
|
||||||
|
|
||||||
|
export default {
|
||||||
|
component: RubyBlockComponent,
|
||||||
|
title: "Annotations/Ruby Block",
|
||||||
|
decorators: [Decorators.Ruby, Decorators.Bluelib],
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export const RubyBlock = props => (
|
||||||
|
<RubyBlockComponent {...props}/>
|
||||||
|
)
|
||||||
|
RubyBlock.args = {
|
||||||
|
text: "Mo",
|
||||||
|
annotation: "ˈmɒ",
|
||||||
|
open: "/",
|
||||||
|
close: "/",
|
||||||
|
}
|
26
src/components/annotations/RubyBlock.tsx
Normal file
26
src/components/annotations/RubyBlock.tsx
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
import * as React from "react"
|
||||||
|
import * as ReactDOM from "react-dom"
|
||||||
|
import * as Types from "../../types"
|
||||||
|
import {BaseElement} from "../BaseElement"
|
||||||
|
import mergeClassNames from "classnames"
|
||||||
|
import {RubyParenthesis} from "./RubyParenthesis";
|
||||||
|
import {RubyText} from "./RubyText";
|
||||||
|
|
||||||
|
|
||||||
|
export interface RubyBlockProps extends Types.BluelibProps {
|
||||||
|
text: string,
|
||||||
|
open?: string,
|
||||||
|
annotation: string,
|
||||||
|
close: string,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export function RubyBlock({text, open = "(", annotation, close = ")"}: RubyBlockProps): JSX.Element {
|
||||||
|
return <>
|
||||||
|
{text}
|
||||||
|
<RubyParenthesis>{open}</RubyParenthesis>
|
||||||
|
<RubyText>{annotation}</RubyText>
|
||||||
|
<RubyParenthesis>{close}</RubyParenthesis>
|
||||||
|
</>
|
||||||
|
|
||||||
|
}
|
17
src/components/annotations/RubyParenthesis.tsx
Normal file
17
src/components/annotations/RubyParenthesis.tsx
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
import * as React from "react"
|
||||||
|
import * as ReactDOM from "react-dom"
|
||||||
|
import * as Types from "../../types"
|
||||||
|
import {BaseElement} from "../BaseElement"
|
||||||
|
import mergeClassNames from "classnames"
|
||||||
|
|
||||||
|
|
||||||
|
export interface RubyParenthesisProps extends Types.BluelibHTMLProps<HTMLElement> {}
|
||||||
|
|
||||||
|
|
||||||
|
export function RubyParenthesis({...props}: RubyParenthesisProps): JSX.Element {
|
||||||
|
props.bluelibClassNames = mergeClassNames(props.bluelibClassNames, "ruby-parenthesis")
|
||||||
|
|
||||||
|
return (
|
||||||
|
<BaseElement kind={"rp"} {...props}/>
|
||||||
|
)
|
||||||
|
}
|
17
src/components/annotations/RubyText.tsx
Normal file
17
src/components/annotations/RubyText.tsx
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
import * as React from "react"
|
||||||
|
import * as ReactDOM from "react-dom"
|
||||||
|
import * as Types from "../../types"
|
||||||
|
import {BaseElement} from "../BaseElement"
|
||||||
|
import mergeClassNames from "classnames"
|
||||||
|
|
||||||
|
|
||||||
|
export interface RubyTextProps extends Types.BluelibHTMLProps<HTMLElement> {}
|
||||||
|
|
||||||
|
|
||||||
|
export function RubyText({...props}: RubyTextProps): JSX.Element {
|
||||||
|
props.bluelibClassNames = mergeClassNames(props.bluelibClassNames, "ruby-text")
|
||||||
|
|
||||||
|
return (
|
||||||
|
<BaseElement kind={"rt"} {...props}/>
|
||||||
|
)
|
||||||
|
}
|
|
@ -1,6 +1,7 @@
|
||||||
import { Bluelib as BluelibComponent } from "../components/Bluelib"
|
import { Bluelib as BluelibComponent } from "../components/Bluelib"
|
||||||
import { Box as BoxComponent } from "../components/panels/Box"
|
import { Box as BoxComponent } from "../components/panels/Box"
|
||||||
import { Form as FormComponent } from "../components/forms/Form"
|
import { Form as FormComponent } from "../components/forms/Form"
|
||||||
|
import { Ruby as RubyComponent } from "../components/annotations/Ruby"
|
||||||
|
|
||||||
|
|
||||||
export const Bluelib = Story => <BluelibComponent theme={"paper"} style={{backgroundColor: "transparent"}}><Story/></BluelibComponent>
|
export const Bluelib = Story => <BluelibComponent theme={"paper"} style={{backgroundColor: "transparent"}}><Story/></BluelibComponent>
|
||||||
|
@ -10,3 +11,5 @@ export const Fill = Story => <div style={{height: "100vh"}}><Story/></div>
|
||||||
export const Box = Story => <BoxComponent><Story/></BoxComponent>
|
export const Box = Story => <BoxComponent><Story/></BoxComponent>
|
||||||
|
|
||||||
export const Form = Story => <FormComponent><Story/></FormComponent>
|
export const Form = Story => <FormComponent><Story/></FormComponent>
|
||||||
|
|
||||||
|
export const Ruby = Story => <RubyComponent><Story/></RubyComponent>
|
||||||
|
|
Loading…
Reference in a new issue