diff --git a/app/api/workExperience/fetch.ts b/app/api/workExperience/fetch.ts new file mode 100644 index 0000000..c256a48 --- /dev/null +++ b/app/api/workExperience/fetch.ts @@ -0,0 +1,25 @@ +import type { Context } from "hono"; +import apiClient from "../apiClient"; + +type Response = { + contents: { + id: string; + span: string; + company: string; + description: string; + techStack: string; + order: number; + }[]; + totalCount: number; + offset: number; + limit: number; +}; + +const fetchWorkExperience = async (c: Context) => { + const res = await apiClient.GET(c, "/work-experience"); + return res.contents.map((content) => { + return { ...content }; + }); +}; + +export { fetchWorkExperience }; diff --git a/app/api/workExperience/index.ts b/app/api/workExperience/index.ts new file mode 100644 index 0000000..11a3610 --- /dev/null +++ b/app/api/workExperience/index.ts @@ -0,0 +1,2 @@ +export * from "./fetch"; +export * from "./model"; diff --git a/app/api/workExperience/model.ts b/app/api/workExperience/model.ts new file mode 100644 index 0000000..2d08bbe --- /dev/null +++ b/app/api/workExperience/model.ts @@ -0,0 +1,9 @@ +type WorkExperience = { + span: string; + company: string; + description: string; + techStack: string; + order: number; +}; + +export type { WorkExperience }; diff --git a/app/components/history/HistoryEducationalBackground.css.ts b/app/components/history/HistoryEducationalBackground.css.ts new file mode 100644 index 0000000..1a9da9a --- /dev/null +++ b/app/components/history/HistoryEducationalBackground.css.ts @@ -0,0 +1,15 @@ +import { css } from "hono/css"; + +const list = css` + display: flex; + flex-direction: column; + gap: 16px; + margin-top: 32px; +`; + +const listItem = css` + display: flex; + gap: 16px; +`; + +export { list, listItem }; diff --git a/app/components/history/HistoryEducationalBackground.tsx b/app/components/history/HistoryEducationalBackground.tsx new file mode 100644 index 0000000..db43fdf --- /dev/null +++ b/app/components/history/HistoryEducationalBackground.tsx @@ -0,0 +1,17 @@ +import { Section } from "../layout/Section"; +import { list, listItem } from "./HistoryEducationalBackground.css"; + +const HistoryEducationalBackground = () => { + return ( +
+ +
+ ); +}; + +export { HistoryEducationalBackground }; diff --git a/app/components/history/HistoryPresenter.css.ts b/app/components/history/HistoryPresenter.css.ts new file mode 100644 index 0000000..e588253 --- /dev/null +++ b/app/components/history/HistoryPresenter.css.ts @@ -0,0 +1,9 @@ +import { css } from "hono/css"; + +const layout = css` + display: flex; + flex-direction: column; + gap: 48px; +`; + +export { layout }; diff --git a/app/components/history/HistoryPresenter.tsx b/app/components/history/HistoryPresenter.tsx new file mode 100644 index 0000000..338d1b7 --- /dev/null +++ b/app/components/history/HistoryPresenter.tsx @@ -0,0 +1,22 @@ +import type { FC } from "hono/jsx"; +import type { WorkExperience } from "../../api/workExperience"; +import { HistoryEducationalBackground } from "./HistoryEducationalBackground"; +import { layout } from "./HistoryPresenter.css"; +import { HistoryWorkExperience } from "./HistoryWorkExperience"; + +type Props = { + workExperience: WorkExperience[]; +}; + +const HistoryPresenter: FC = (props) => { + const { workExperience } = props; + + return ( +
+ + +
+ ); +}; + +export { HistoryPresenter }; diff --git a/app/components/history/HistoryWorkExperience.css.ts b/app/components/history/HistoryWorkExperience.css.ts new file mode 100644 index 0000000..bd291ab --- /dev/null +++ b/app/components/history/HistoryWorkExperience.css.ts @@ -0,0 +1,17 @@ +import { css } from "hono/css"; + +const list = css` + display: flex; + flex-direction: column; + gap: 16px; + margin-top: 32px; +`; + +const description = css` + display: flex; + flex-direction: column; + gap: 8px; + padding: 8px; +`; + +export { list, description }; diff --git a/app/components/history/HistoryWorkExperience.tsx b/app/components/history/HistoryWorkExperience.tsx new file mode 100644 index 0000000..66a026f --- /dev/null +++ b/app/components/history/HistoryWorkExperience.tsx @@ -0,0 +1,37 @@ +import type { FC } from "hono/jsx"; +import type { WorkExperience } from "../../api/workExperience"; +import { Section } from "../layout/Section"; +import { list } from "./HistoryEducationalBackground.css"; +import { description } from "./HistoryWorkExperience.css"; + +type Props = { + workExperience: WorkExperience[]; +}; + +const HistoryWorkExperience: FC = (props) => { + const { workExperience } = props; + + return ( +
+
    + {workExperience + .toSorted((a, b) => a.order - b.order) + .map((item) => ( +
  • +
    + + {item.span}: {item.company} + +

    + {item.description} + 使用技術: {item.techStack} +

    +
    +
  • + ))} +
+
+ ); +}; + +export { HistoryWorkExperience }; diff --git a/app/routes/history.tsx b/app/routes/history.tsx index 181de21..fe66472 100644 --- a/app/routes/history.tsx +++ b/app/routes/history.tsx @@ -1,5 +1,8 @@ import { createRoute } from "honox/factory"; +import { HistoryPresenter } from "../components/history/HistoryPresenter"; +import { fetchWorkExperience } from "../api/workExperience"; export default createRoute(async (c) => { - return c.render(
history
) + const workExperience = await fetchWorkExperience(c); + return c.render(); });