lerna-changelogで始める頑張りすぎないリリースノート自動生成

hothouseというpackage.jsonとlockfileを更新してPR出すツールを公開するときに、
「リリースノート頑張りたくないな」と思い、なるべく楽にそれなりのリリースノートを残せる方法を探った結果、
lerna-changelogというLerna公式のツールが良さそうだったので、採用しました。

hothouseではlerna-changelogで自動生成されたリリースノートを公開してます。
https://github.com/Leko/hothouse/releases
規模が大きくなったり、需要が高まったらしっかり書こうと思いながら、
何も書かないのは嫌だし、とは言えまだこの規模でリリース作業に苦労をしたくない
そんな温度感にちょうどマッチしてくれるツールです。

あまり使ってるリポジトリを見かけないので、紹介してみようと思います。

lernaでnpmにpublicなscoped packageをpublishする方法

hothouseという、package.jsonを更新してPRを作成するGreenkeeperのようなOSSを作る際に、
プラグイン開発用の内部I/Fを@hothouse/typesというpublicなパッケージとしてpublishしようとしたところ、失敗しました。

公開する時はnpm publish --access=publicとするだけです。(デフォルトが--access=restrictedであるため明示する必要がある)

npmで名前空間を持ったモジュールを公開する方法(scoped modules) | Web Scratch

単一のnpm packageなら--accessをつければ良いのですが、(少なくとも2.11.0時点で)lernaでpublishする際に--accessを指定できる余地がない。
ということで調べてみました。

ReactのNew Context APIは便利だけどreduxを使うのはやめないと思った

Reduxの新しいContext APIが発表され、2ヶ月くらいが経過した。

React’s ⚛️ new Context API – DailyJS – Medium

私は少しバージョンの古いReactを主に使っているため、しばらく情報を追わずにいたが、

Reactの新Context APIとRedux is deadはどう関係するのか? – terrierscript – Medium

React v16で実装された new Context APIを使って、Reduxへ別れを告げる - Qiita

などの記事が登場するようになったので、自分は新しいContext APIとどう向き合うのかを考えてみた。

Algoliaを利用してサイト内検索機能を実装する

こんにちは。
当ブログのサイト内検索をしたことある方はお気づきかもしれませんが、サイト内検索にAlgoliaを利用しています。
(後述の事情により月初に使えなくなることがたまにありますが)動作速度もかなり早く、安定して稼働してます。

運用コストもゼロで、記事書いてPRをマージすれば記事公開日に勝手にコンテンツが検索対象に一手間加えてあります。
Algoliaを1ヶ月実運用してみたので、Algoliaはいいぞという紹介記事を書きたいと思います。

また、CQRS・DDDの勉強のために、フロントはReactとAlminで実装してみました。
Almin、CQRS、Fluxの小さな実装例の1つとしても参考になるかと思います。

MiddlemanのビルドにWebpackを組み込む方法

こんにちは。
当ブログはMiddlemanにて運用しているのですが、検索機能や遅延ロードなどで実装したJavaScriptのビルドにはAsset pipelineなどは使わずにwebpackでビルドしています。

Rails5.1が今betaで出ていますね。中でも目玉はwebpacker.gemによるモダンなフロントエンド開発がRailsに導入されることでしょう。 今までのRailsのasset pipelineとは別に、yarnによって依存性を管理しwebpackで結合する独立したjsのビルドシステムがサポートされます。 これによって、以下のような従来のasset pip

Rails5.1から導入されるwebpacker.gemは本当にRailsのフロントエンド開発に福音をもたらすのか? - Qiita

私も同意で、Railsはあくまでサーバサイドアプリケーションで、今まで対してフロントに気を使ってこなかったのだから、中途半端に内部に組み込むのやめてくれ派です。
MiddlemanはRailsのビュー層の部分だけ持ってきたようなものなので、当然同じ問題が発生します。

ということで、MiddlemanとWebpackが共存できる妥協点を探って、実際にこのブログに取り入れてみた結果を残します。

CLIアプリに使えそうな特殊文字たちで遊んでみた

こんにちは。
Githubのトレンドにvadimdemedes/inkというツールが上がっており、CLIといえばchjj/blessedやReact版のYomguithereal/react-blessedとかあったなぁ、と懐かしみつつ

そういえばPowerlineもシェルのアスキーアート的に表現されてるんだよな、
どうやってパンくずっぽいもの描画してるんだろう?

というのが気になったので調べてみたらおもったより面白そうだったので遊んでみました。