https://utelecon.adm.u-tokyo.ac.jp/
uteleconは,オンライン授業やWeb会議に関する情報をワンストップで得られることを目指して東京大学が開設したウェブサイトです.詳しくはuteleconについてをご覧ください.
Node.js が必要です.v20の最新版(LTS)をインストールしてください.
- レポジトリをクローンしたら,まず
npm install
を実行します. - プレビューを開始するには,
npm run dev
を実行します.^C
で終了します.
Markdownファイルのフロントマターにかける設定は以下の通りです:
title
:ページのタイトル.表示されるタイトルになるほか,<title>
要素の中身にもなり,Slack等でリンクを共有した際に表示される.必須.description
:ページの説明.Slack等でリンクを共有した際に表示される.h1
:ページの表示されるタイトル.title
と異なり,Markdownを含めることができる.toc
:false
とすれば,ページの目次を表示しない.sitemap
:false
とすれば,サイトマップに含まれない.author
:記事の著者をページ下部に表示する.affiliation
:所属.author
を指定する場合は必須.oes
とするとOESの説明ページへのリンクが表示される.name
:著者名.任意.
breadcrumb
:ページ上部のパンくずリストを定義する.詳しくは後述.redirect_from
・redirect_to
:リダイレクトの設定.詳しくは後述.
npm run dev
:プレビューを開始する.^C
で終了する.npm run build
:ページをビルドし,dist
に成果物を出力する.npm run find-link
:引数で指定したページへのリンクをすべて標準出力する.dist
以下のHTMLファイルを読むため,あらかじめnpm run build
してから実行する.- 例:
npm run find-link /oc/url
npm run broken-link
:サイト内リンクで壊れているものをすべて標準出力する.dist
以下のHTMLファイルを読むため,あらかじめnpm run build
してから実行する.
npm run unused-asset
:使われていないアセットをすべて標準出力する.dist
以下のHTMLファイルを読むため,あらかじめnpm run build
してから実行する.
Astroという静的サイトジェネレータを用いています.特殊な機能について以下で説明します.
- 概要
src/pages
以下のファイルはデフォルトで公開されます.画像等はsrc/pages
以下に置いてください.src/pages
以下で,_
で始まるファイルは公開されません.src/pages
以下に置きたいが公開したくないファイルは,名前を_
で始めてください.src/pages
以下で,MarkdownやMDXなどのHTMLに変換されるファイルは公開されません.
- 理由
- 多くのページで,ページのソースとそこに含まれる画像を同じディレクトリに置いて管理しています.これらのページを移行する際に,
src/pages
以下のファイルをデフォルトで公開することで,画像等のパスを変更する必要がなくなり,またファイルと画像を同じディレクトリに置いたまま管理できます.- このような状態になっているのは,移行前のJekyllでルートディレクトリのファイルがデフォルトで公開されていたためです.
- また
src/pages
以下には,_
で始まる公開したくないファイルが多く存在しています.これらの中には近隣の別ファイルで利用されているものがあります.この機能により,関連するファイルを近くのディレクトリに置いたまま管理できます.- このような状態になっているのも,Jekyllで
_
で始まるファイルは公開されなかったためです.
- このような状態になっているのも,Jekyllで
- 多くのページで,ページのソースとそこに含まれる画像を同じディレクトリに置いて管理しています.これらのページを移行する際に,
- 実装
- デフォルトで公開する機能は,設定ファイルで
publicDir: "src/pages"
とすることで実現しています. _
で始まるファイルとHTMLに変換されるファイルが公開されない機能は,CleanupIntegration.ts
で実現しています.ここでは,ビルド完了後に成果物が格納されるdist
フォルダから条件に一致するファイルを削除しています.
- デフォルトで公開する機能は,設定ファイルで
- 概要
src/pages
以下のMarkdown/MDXファイルにはデフォルトのレイアウト (@layouts/Layout.astro
) が適用されます._
で始まるファイルにはデフォルトのレイアウトは適用されません.
- 理由
- すべてのMarkdownファイルのフロントマターでレイアウトを指定するよりも,デフォルトのレイアウトを適用する方が簡潔です.
_
で始まるファイルは他のファイルに埋め込まれることがあるため,デフォルトのレイアウトを適用すると入れ子になってしまいます.
- 実装
DefaultFrontmatterPlugin.ts
で実現しています.Astroでは,レイアウトをMarkdownのフロントマターで指定します.このプラグインはRemarkプラグインで,Markdownのパース時にフロントマターにlayout
を指定または上書きすることで,要件を満たしています.
- 概要
- Markdown/MDX内で,
{:#id}
,{:.class}
,{:attribute="value"}
のような記法によって,変換されるHTMLの属性を追加することができます. - 元々はKramdownというMarkdown処理系の機能です.
- 詳しくは後述します.
- Markdown/MDX内で,
- 理由
- 多くのページで,そのソースに上の記法が使われています.移行にあたり,全てのページでこれを変更するのは非現実的でした.
- このような状態になっているのは,JekyllでKramdownが利用されていたためです.
- また,
id
属性やclass
属性を指定するためだけにHTMLを書くのは冗長です.- しかも,Astroの見出しの一覧を取得する機能を利用して目次を生成する際,MDXでは見出しがMarkdownの記法で記述されている必要があります.
- 多くのページで,そのソースに上の記法が使われています.移行にあたり,全てのページでこれを変更するのは非現実的でした.
- 実装
BlockIALPlugin.js
で実現しています.このプラグインはRemarkプラグインで,パーサーを拡張しています.
- 概要
- Remarkでは,
*
や_
を用いて太字や斜体を指定する文法が複雑です.例えば文章の**ここだけ**を太字にする
というMarkdownは太字にならず,文章の **ここだけ** を太字にする
などとする必要があります. - この機能は,そのような複雑な挙動を排し,単純に
*
や_
で囲まれた文字列を太字や斜体にします.
- Remarkでは,
- 理由
- 多くのページで,太字や斜体の指定はKramdownの単純な挙動に依存していました.これらを全て修正するのは非現実的でした.
- このような状態になっているのは,JekyllでKramdownが利用されていたためです.
- 日本語では単語間の区切りに空白を入れないため,Remarkの記法は不自然です.
- 多くのページで,太字や斜体の指定はKramdownの単純な挙動に依存していました.これらを全て修正するのは非現実的でした.
- 実装
SimpleAttentionPlugin.js
で実現しています.このプラグインはRemarkプラグインで,パーサーのうちトークナイザーの部分を上書きしています.
- 概要
- Markdownのfrontmatterで
redirect_to
およびredirect_from
を指定することで,リダイレクトを実現できます. - 詳細は後述します.
- Markdownのfrontmatterで
- 理由
- 歴史的経緯により,元々存在したURLのページが削除され,別のURLのページに誘導すべき場合があります.この場合に,リダイレクトを1つのファイルで中央集権的に管理するよりも,各ページのfrontmatterで管理する方が簡潔です.
- 多くのページで,リダイレクトの指定はfrontmatterによって行われていました.これらを全て修正するのは非現実的でした.
- このような状態になっているのは,jekyll-redirect-fromが利用されていたためです.
- 実装
RedirectIntegration.ts
で実現しています.ここではAstroのビルド前に,src/pages
内のファイルをすべて読んで設定ファイルのredirects
に必要なエントリーを追加することで,Astroにリダイレクトに必要なページを生成させています.
- 概要
- 外部リンクには自動で
target="_blank" rel="noopener noreferrer"
が付与されます.
- 外部リンクには自動で
- 理由
- 外部リンクは,別タブで開くのが一般的です.
- すべての外部リンクに対してこの属性を明示的に付与するのは冗長であり,また忘れる可能性も高いため,自動で付与すべきです.
- 実装
ExternalLinksIntegration.ts
で実現しています.ここでは,ビルド後に全てのHTMLファイルをRehypeで改めてパースし,rehype-external-links
を適用しています.
- 概要
src/pages
以下のページファイルで,src/pages/oc/index.mdx
やsrc/pages/systems/index.md
などのindex
ファイルは,/oc/
や/systems/
などのindex
を除いた/
で終わるURLにマップされます.src/pages
以下のページファイルで,src/pages/oc/movies.mdx
やsrc/pages/systems/wlan.md
などのindex
でないファイルは,/oc/movies
や/systems/wlan
などのファイル名そのままの(末尾に/
がつかない)URLにマップされます.
- 理由
- 前述の通り,多くのページは
src/pages
以下でページのソースと画像をまとめて管理し,ソースの中ではファイルシステムの相対パスを用いて画像を参照しています.ファイルシステム上での相対パスとURL上での/
で始まらない相対パスを対応させるには,上記のようなマッピングが必要です. - Astroには,このようなマッピングにする設定がありません.
- 前述の通り,多くのページは
- 実装
astro.config.ts
でformat: "preserve"
を指定し,Layout.astro
で公開時のパスを状況に応じて書き換えることで実現しています.
Markdown内で,ある要素に対してHTMLの属性を指定することができます.Kramdownに実装されているものをRemark Pluginとして移植しています.
例:見出しのid
属性を指定する
# 見出し
{:#id}
(本文)
例:画像のclass
属性を指定する
![uteleconのロゴ](/assets/images/ogp.png){:.medium}
src/pages
内のMarkdownのfrontmatterにredirect_from
/redirect_to
を記述することで,リダイレクトするように設定できます.jekyll-redirect-fromにある機能を移植する形で実装しています.
例:src/pages/docs/byod.md
にredirect_from
を記述し,/notice/byod
から/docs/byod
にリダイレクトする
---
title: 東京大学のBYOD方針
redirect_from:
- /notice/byod
---
(ページ内容)
注
redirect_from
は文字列または文字列の配列で指定することができる- 基本的に
/
で始まるパスを指定する
例:src/pages/forms/entry_trouble.md
にredirect_to
を記述し,/forms/entry_trouble
から/oc/join#form
にリダイレクトする
---
redirect_to: "/oc/join#form"
---
注
redirect_to
は文字列で指定することができる- 基本的に
/
で始まるパスを指定する - リダイレクト先のページ内の特定の場所(例では
#form
)に飛ばしたい,外部のページに飛ばしたいなど,特別の事情がなければredirect_from
の方が良い
src/emergencies
内に以下のようなMarkdownファイルを配置することで,複数のページにまとめて緊急のお知らせを掲載することができます.掲載したいページのパスにマッチする正規表現をpattern
に指定します.
例:src/emergencies/LmsFailure.mdx
を作成して,/utol/
以下のページに緊急のお知らせを掲載する
---
pattern: "^\/utol\/"
---
<div class="box">
UTOLの緊急のお知らせです.
</div>
注
pattern
には正規表現を文字列で指定してください.^\/utol\/$
のようにすると,/utol/
のみに緊急のお知らせを掲載できます.- 同じページのパスに2つ以上の緊急のお知らせがマッチする場合,ファイル名の辞書順で同時に掲載されます.ファイル名は実際のサイトには表示されないため,適宜変更して問題ありません.
breadcrumb
をMarkdownのfrontmatterに記述することで,ページ上部にパンくずリストを表示することができます.
title
:パンくずリストのそのページ自身の部分のタイトル.breadcrumb
を指定する場合は必須.親との差分だけを書く.parent
:親ページ.任意.デフォルトは../
.これを辿っていくことでパンくずリストを構成する.
ルート直下のページ(/utokyo_account/
,/oc/
など)を除き,パンくずリストを表示するには,breadcrumb
を記述した上位階層の親ページが必要です.子ページのみにbreadcrumb
を記述することはできません.
-
ルート直下の親ページ
/eccs/
(src/pages/eccs/index.mdx
)--- title: ECCS端末 breadcrumb: title: ECCS端末 ---
- ルート直下のページにはパンくずリストが表示されません.
- ただし,
breadcrumb
は子ページでパンくずリストを表示するために必須です.
-
子ページ(
parent
を指定しない場合)/eccs/support/
(src/pages/eccs/support/index.mdx
)--- title: 問い合わせ先・窓口 breadcrumb: title: 問い合わせ ---
parent
はデフォルトで../
なので,/eccs/
が親ページになります.
-
子ページ(
parent
を指定することで,/eccs/
を親ページにする場合)/eccs/features/printing/
(src/pages/eccs/features/printing/index.mdx
)--- title: 印刷 breadcrumb: title: 印刷 parent: ../../ ---
@components
に関するドキュメントがsrc/components/README.md
にあります.