Skip to content

Commit

Permalink
Merge pull request #23 from chakkun1121/dev
Browse files Browse the repository at this point in the history
v1.0.3
  • Loading branch information
chakkun1121 authored Jan 18, 2024
2 parents 2ba9cb0 + 6b716e2 commit cd62a97
Show file tree
Hide file tree
Showing 8 changed files with 125 additions and 23 deletions.
2 changes: 1 addition & 1 deletion .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
{
"cSpell.words": ["vocabphrase"]
"cSpell.words": ["anikilot", "vocabphrase"]
}
57 changes: 50 additions & 7 deletions app/(app)/app/ImportForm.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
"use client";
import { fileType } from "@/@types/fileType";
import { uuidv7 as createUUID } from "uuidv7";
import React, { useState } from "react";
import React, { MouseEventHandler, useState } from "react";
import { wayakuFile2file } from "./_library/wayaku";
import { uploadFile } from "./_library/uploadFile";
import { csvToFileContent } from "./_library/csvToFileContent";

export default function ImportForm({
close,
Expand Down Expand Up @@ -30,6 +32,27 @@ export default function ImportForm({
setTitle(title);
close();
}
async function importFromCsv(mode?: "en-ja" | "ja-en") {
/**
* ファイル形式(ヘッダー行は基本的になしだが、含まれている場合はユーザーによって除去してもらう)
* 1. |表|裏|
* 2. |index|表|裏|
* 3. |表|(表ヒント(最後にカッコの中に入れる))|裏|(裏ヒント)|
* 4. |index|表|(表ヒント)|裏|(裏ヒント)|
*/
const { content, fileName } = await uploadFile([
{
description: "csvファイル(anikilot形式)",
accept: { "text/csv": [".csv"] },
},
]);
if (!content) return;
const csv = content.split("\n").map((line) => line.split(","));
const fileContent = csvToFileContent(csv, mode);
const title = fileName.split(".").slice(0, -1).join(".");
setFileContent({ content: fileContent, mode: null });
setTitle(title);
}
return (
<div className="w-full p-4 rounded bg-gray-200">
<p>Excel,Googleスプレッドシートなどからコピペできます</p>
Expand All @@ -46,12 +69,32 @@ export default function ImportForm({
>
キャンセル
</button>
<button
className="flex-none rounded-full bg-gray-300 hover:bg-gray-400 p-4"
onClick={uploadWayakuFile}
>
和訳ファイルからのインポート
</button>
<div className="flex-none [&>ul]:hover:inline-block">
<p className="block rounded-full bg-gray-300 hover:bg-gray-400 p-4">
その他ファイルからのインポート
</p>
<ul className="absolute bg-gray-300 m-0 rounded-b hidden ">
{[
{
name: "和訳ファイル(.wayaku)",
onClick: uploadWayakuFile,
},
{
name: "csvファイル(ankilot形式のもの)",
onClick: () => importFromCsv(),
},
].map(({ name, onClick }, i) => (
<li className="list-none text-center relative " key={i}>
<button
onClick={onClick}
className="rounded hover:bg-gray-400 p-4"
>
{name}
</button>
</li>
))}
</ul>
</div>
<button
className="flex-1 rounded-full bg-gray-300 hover:bg-gray-400 p-4 disabled:bg-gray-400"
onClick={importFromBox}
Expand Down
53 changes: 53 additions & 0 deletions app/(app)/app/_library/csvToFileContent.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
import { fileType } from "@/@types/fileType";
import { uuidv7 as createUUID } from "uuidv7";

export function csvToFileContent(
csv: string[][],
mode?: "en-ja" | "ja-en"
): fileType["content"] {
const lines = csv[1].length;
if (!mode) mode = isEnglish(csv[1][lines % 2]) ? "en-ja" : "ja-en";
let fileContent: fileType["content"];
if (lines === 2) {
fileContent = csv.map((line) => ({
id: createUUID(),
en: line[mode === "en-ja" ? 0 : 1],
ja: line[mode === "ja-en" ? 0 : 1],
}));
} else if (lines === 3) {
fileContent = csv.map((line) => ({
id: createUUID(),
en: line[mode === "en-ja" ? 0 : 1],
ja: line[mode === "ja-en" ? 0 : 1],
hint: line[2],
}));
} else if (lines === 4) {
fileContent = csv.map((line) => ({
id: createUUID(),
en: `${line[mode === "en-ja" ? 0 : 1]} ${
line[mode === "en-ja" ? 2 : 3] ? `(${[mode === "en-ja" ? 2 : 3]})` : ``
}`,
ja: `${line[mode === "ja-en" ? 0 : 1]}${
line[mode === "ja-en" ? 2 : 3] ? `(${[mode === "ja-en" ? 2 : 3]})` : ``
}`,
}));
} else if (lines === 5) {
fileContent = csv.map((line) => ({
id: createUUID(),
en: `${line[mode === "en-ja" ? 1 : 2]} ${
line[mode === "en-ja" ? 3 : 4] ? `(${[mode === "en-ja" ? 3 : 4]})` : ``
}`,
ja: `${line[mode === "ja-en" ? 1 : 2]}${
line[mode === "ja-en" ? 3 : 4] ? `(${[mode === "ja-en" ? 3 : 4]})` : ``
}`,
}));
} else throw new Error("ファイル形式が不正です");
return fileContent;
}
export function isEnglish(text: string) {
/**
* 英語の判定(unicode上で225以上の数が入っていないか)
* @param text 判定する文字列
*/
return !text.split("").some((char) => char.charCodeAt(0) >= 225);
}
22 changes: 14 additions & 8 deletions app/(app)/app/_library/uploadFile.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,14 @@
export async function uploadFile(): Promise<{
export async function uploadFile(
acceptType: {
description: string;
accept: Record<string, string[]>;
}[] = [
{
description: "和訳ファイル",
accept: { "application/wayaku": [".wayaku"] },
},
]
): Promise<{
content: string;
fileName: string;
fileHandle?: FileSystemFileHandle;
Expand All @@ -8,12 +18,8 @@ export async function uploadFile(): Promise<{
throw new Error("showOpenFilePicker is not defined");
const FileSystemFileHandles: FileSystemFileHandle[] =
await window.showOpenFilePicker({
types: [
{
description: "和訳ファイル",
accept: { "application/wayaku": ".wayaku" },
},
],
types: acceptType,
excludeAcceptAllOption: false,
});
const FileSystemFileHandle: FileSystemFileHandle = FileSystemFileHandles[0];
return FileSystemFileHandle;
Expand All @@ -28,7 +34,7 @@ export async function uploadFile(): Promise<{
}
const fileInput = document.createElement("input");
fileInput.type = "file";
fileInput.accept = "application/wayaku";
fileInput.accept = Object.keys(acceptType[0].accept)[0];
fileInput.click();
const file = await new Promise<File>((resolve) => {
fileInput.addEventListener("change", () => {
Expand Down
12 changes: 6 additions & 6 deletions app/(top)/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ export default function Home() {
<div className="flex-1 flex">
<Link
href="/"
aria-label="ホームへ"
className="text-black hover:text-black visited:text-black no-underline"
>
<h1>VocabPhrase</h1>
Expand All @@ -32,6 +31,7 @@ export default function Home() {
width={800}
height={452}
className="max-w-full"
// priority={true} //画像サイズがでかすぎて遅延読み込みのほうが早かった
/>
</div>
</section>
Expand All @@ -54,7 +54,7 @@ export default function Home() {
</div>
<Image
className="flex-none max-w-full"
src="/img/createfile.gif"
src="/img/createfile-animation.webp"
alt="単語帳を作る"
width={600}
height={336}
Expand All @@ -72,8 +72,8 @@ export default function Home() {
</p>
</div>
<Image
className="flex-none"
src="/img/flashcard.gif"
className="flex-none max-w-full"
src="/img/flashcard-animation.webp"
alt="フラッシュカード"
width={600}
height={336}
Expand All @@ -87,8 +87,8 @@ export default function Home() {
</p>
</div>
<Image
className="flex-none"
src="/img/speaking.gif"
className="flex-none max-w-full"
src="/img/speaking-animation.webp"
alt="スピーキング練習ページ"
width={600}
height={336}
Expand Down
Binary file added public/img/createfile-animation.webp
Binary file not shown.
Binary file added public/img/flashcard-animation.webp
Binary file not shown.
2 changes: 1 addition & 1 deletion tsconfig.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"compilerOptions": {
"target": "es5",
"target": "es2022",
"lib": ["dom", "dom.iterable", "esnext"],
"allowJs": true,
"skipLibCheck": true,
Expand Down

0 comments on commit cd62a97

Please sign in to comment.