narou 1.2.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (165) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +73 -37
  3. package/dist/index.browser.cjs +87 -1359
  4. package/dist/index.browser.cjs.map +1 -1
  5. package/dist/index.browser.d.cts +11 -19
  6. package/dist/index.browser.d.mts +47 -0
  7. package/dist/index.browser.mjs +66 -0
  8. package/dist/index.browser.mjs.map +1 -0
  9. package/dist/index.cjs +147 -1410
  10. package/dist/index.cjs.map +1 -1
  11. package/dist/index.common-8lS2K_1Y.mjs +1166 -0
  12. package/dist/index.common-8lS2K_1Y.mjs.map +1 -0
  13. package/dist/index.common-CYj0n0aU.cjs +1346 -0
  14. package/dist/index.common-CYj0n0aU.cjs.map +1 -0
  15. package/dist/index.d.cts +28 -21
  16. package/dist/index.d.mts +63 -0
  17. package/dist/index.mjs +128 -0
  18. package/dist/index.mjs.map +1 -0
  19. package/dist/user-search-BY6FdEe7.d.cts +1394 -0
  20. package/dist/user-search-Besgk-Hx.d.mts +1394 -0
  21. package/package.json +28 -37
  22. package/pnpm-lock.yaml +1325 -1100
  23. package/src/index.ts +5 -1
  24. package/src/narou-fetch.ts +4 -3
  25. package/src/narou-jsonp.ts +4 -2
  26. package/src/narou.ts +50 -13
  27. package/src/params.ts +1 -1
  28. package/src/ranking.ts +20 -11
  29. package/src/search-builder-r18.ts +6 -2
  30. package/src/search-builder.ts +7 -3
  31. package/src/user-search.ts +9 -2
  32. package/dist/chunk-3A5MHPWL.js +0 -37
  33. package/dist/chunk-3A5MHPWL.js.map +0 -1
  34. package/dist/chunk-4ZP5YNWI.js +0 -1
  35. package/dist/chunk-4ZP5YNWI.js.map +0 -1
  36. package/dist/chunk-5UDKQCPJ.js +0 -407
  37. package/dist/chunk-5UDKQCPJ.js.map +0 -1
  38. package/dist/chunk-6BZWV4ZC.js +0 -75
  39. package/dist/chunk-6BZWV4ZC.js.map +0 -1
  40. package/dist/chunk-BQLSW236.js +0 -117
  41. package/dist/chunk-BQLSW236.js.map +0 -1
  42. package/dist/chunk-DEQICAN3.js +0 -94
  43. package/dist/chunk-DEQICAN3.js.map +0 -1
  44. package/dist/chunk-E2H3AJSQ.js +0 -57
  45. package/dist/chunk-E2H3AJSQ.js.map +0 -1
  46. package/dist/chunk-HOBLKBZ6.js +0 -452
  47. package/dist/chunk-HOBLKBZ6.js.map +0 -1
  48. package/dist/chunk-IPDEGCWU.js +0 -39
  49. package/dist/chunk-IPDEGCWU.js.map +0 -1
  50. package/dist/chunk-LQLNWSWV.js +0 -26
  51. package/dist/chunk-LQLNWSWV.js.map +0 -1
  52. package/dist/chunk-PLEM2AOH.js +0 -44
  53. package/dist/chunk-PLEM2AOH.js.map +0 -1
  54. package/dist/chunk-RNHRR56W.js +0 -25
  55. package/dist/chunk-RNHRR56W.js.map +0 -1
  56. package/dist/chunk-VUZIISP2.js +0 -23
  57. package/dist/chunk-VUZIISP2.js.map +0 -1
  58. package/dist/chunk-VZVUANDN.js +0 -17
  59. package/dist/chunk-VZVUANDN.js.map +0 -1
  60. package/dist/index.browser.d.ts +0 -55
  61. package/dist/index.browser.js +0 -126
  62. package/dist/index.browser.js.map +0 -1
  63. package/dist/index.common.cjs +0 -1187
  64. package/dist/index.common.cjs.map +0 -1
  65. package/dist/index.common.d.cts +0 -6
  66. package/dist/index.common.d.ts +0 -6
  67. package/dist/index.common.js +0 -76
  68. package/dist/index.common.js.map +0 -1
  69. package/dist/index.d.ts +0 -56
  70. package/dist/index.js +0 -131
  71. package/dist/index.js.map +0 -1
  72. package/dist/narou-DBa12V_l.d.ts +0 -404
  73. package/dist/narou-DCp4aGfA.d.cts +0 -404
  74. package/dist/narou-fetch.cjs +0 -164
  75. package/dist/narou-fetch.cjs.map +0 -1
  76. package/dist/narou-fetch.d.cts +0 -20
  77. package/dist/narou-fetch.d.ts +0 -20
  78. package/dist/narou-fetch.js +0 -10
  79. package/dist/narou-fetch.js.map +0 -1
  80. package/dist/narou-jsonp.cjs +0 -162
  81. package/dist/narou-jsonp.cjs.map +0 -1
  82. package/dist/narou-jsonp.d.cts +0 -13
  83. package/dist/narou-jsonp.d.ts +0 -13
  84. package/dist/narou-jsonp.js +0 -10
  85. package/dist/narou-jsonp.js.map +0 -1
  86. package/dist/narou-ranking-results.cjs +0 -19
  87. package/dist/narou-ranking-results.cjs.map +0 -1
  88. package/dist/narou-ranking-results.d.cts +0 -4
  89. package/dist/narou-ranking-results.d.ts +0 -4
  90. package/dist/narou-ranking-results.js +0 -1
  91. package/dist/narou-ranking-results.js.map +0 -1
  92. package/dist/narou-search-results-C21hWrnL.d.cts +0 -727
  93. package/dist/narou-search-results-DT0YdaBn.d.ts +0 -727
  94. package/dist/narou-search-results.cjs +0 -62
  95. package/dist/narou-search-results.cjs.map +0 -1
  96. package/dist/narou-search-results.d.cts +0 -2
  97. package/dist/narou-search-results.d.ts +0 -2
  98. package/dist/narou-search-results.js +0 -11
  99. package/dist/narou-search-results.js.map +0 -1
  100. package/dist/narou.cjs +0 -112
  101. package/dist/narou.cjs.map +0 -1
  102. package/dist/narou.d.cts +0 -4
  103. package/dist/narou.d.ts +0 -4
  104. package/dist/narou.js +0 -8
  105. package/dist/narou.js.map +0 -1
  106. package/dist/params.cjs +0 -448
  107. package/dist/params.cjs.map +0 -1
  108. package/dist/params.d.cts +0 -2
  109. package/dist/params.d.ts +0 -2
  110. package/dist/params.js +0 -41
  111. package/dist/params.js.map +0 -1
  112. package/dist/ranking-history.cjs +0 -47
  113. package/dist/ranking-history.cjs.map +0 -1
  114. package/dist/ranking-history.d.cts +0 -28
  115. package/dist/ranking-history.d.ts +0 -28
  116. package/dist/ranking-history.js +0 -8
  117. package/dist/ranking-history.js.map +0 -1
  118. package/dist/ranking.cjs +0 -783
  119. package/dist/ranking.cjs.map +0 -1
  120. package/dist/ranking.d.cts +0 -108
  121. package/dist/ranking.d.ts +0 -108
  122. package/dist/ranking.js +0 -10
  123. package/dist/ranking.js.map +0 -1
  124. package/dist/search-builder-r18.cjs +0 -547
  125. package/dist/search-builder-r18.cjs.map +0 -1
  126. package/dist/search-builder-r18.d.cts +0 -45
  127. package/dist/search-builder-r18.d.ts +0 -45
  128. package/dist/search-builder-r18.js +0 -9
  129. package/dist/search-builder-r18.js.map +0 -1
  130. package/dist/search-builder.cjs +0 -591
  131. package/dist/search-builder.cjs.map +0 -1
  132. package/dist/search-builder.d.cts +0 -4
  133. package/dist/search-builder.d.ts +0 -4
  134. package/dist/search-builder.js +0 -12
  135. package/dist/search-builder.js.map +0 -1
  136. package/dist/user-search.cjs +0 -325
  137. package/dist/user-search.cjs.map +0 -1
  138. package/dist/user-search.d.cts +0 -66
  139. package/dist/user-search.d.ts +0 -66
  140. package/dist/user-search.js +0 -9
  141. package/dist/user-search.js.map +0 -1
  142. package/dist/util/date.cjs +0 -51
  143. package/dist/util/date.cjs.map +0 -1
  144. package/dist/util/date.d.cts +0 -21
  145. package/dist/util/date.d.ts +0 -21
  146. package/dist/util/date.js +0 -11
  147. package/dist/util/date.js.map +0 -1
  148. package/dist/util/jsonp.cjs +0 -63
  149. package/dist/util/jsonp.cjs.map +0 -1
  150. package/dist/util/jsonp.d.cts +0 -49
  151. package/dist/util/jsonp.d.ts +0 -49
  152. package/dist/util/jsonp.js +0 -7
  153. package/dist/util/jsonp.js.map +0 -1
  154. package/dist/util/type.cjs +0 -19
  155. package/dist/util/type.cjs.map +0 -1
  156. package/dist/util/type.d.cts +0 -27
  157. package/dist/util/type.d.ts +0 -27
  158. package/dist/util/type.js +0 -1
  159. package/dist/util/type.js.map +0 -1
  160. package/dist/util/unzipp.cjs +0 -47
  161. package/dist/util/unzipp.cjs.map +0 -1
  162. package/dist/util/unzipp.d.cts +0 -12
  163. package/dist/util/unzipp.d.ts +0 -12
  164. package/dist/util/unzipp.js +0 -7
  165. package/dist/util/unzipp.js.map +0 -1
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2015 deflis
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md CHANGED
@@ -1,41 +1,74 @@
1
- # node-narou
1
+ # 📚 node-narou
2
2
 
3
3
  [![npm version](https://badge.fury.io/js/narou.svg)](https://badge.fury.io/js/narou)
4
4
  [![Node.js CI](https://github.com/deflis/node-narou/actions/workflows/nodejs-test.yml/badge.svg)](https://github.com/deflis/node-narou/actions/workflows/nodejs-test.yml)
5
+ [![Ask DeepWiki](https://deepwiki.com/badge.svg)](https://deepwiki.com/deflis/node-narou)
5
6
 
6
- [![DeepWiki](https://img.shields.io/badge/DeepWiki-deflis%2Fnode--narou-blue.svg?logo=data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACwAAAAyCAYAAAAnWDnqAAAAAXNSR0IArs4c6QAAA05JREFUaEPtmUtyEzEQhtWTQyQLHNak2AB7ZnyXZMEjXMGeK/AIi+QuHrMnbChYY7MIh8g01fJoopFb0uhhEqqcbWTp06/uv1saEDv4O3n3dV60RfP947Mm9/SQc0ICFQgzfc4CYZoTPAswgSJCCUJUnAAoRHOAUOcATwbmVLWdGoH//PB8mnKqScAhsD0kYP3j/Yt5LPQe2KvcXmGvRHcDnpxfL2zOYJ1mFwrryWTz0advv1Ut4CJgf5uhDuDj5eUcAUoahrdY/56ebRWeraTjMt/00Sh3UDtjgHtQNHwcRGOC98BJEAEymycmYcWwOprTgcB6VZ5JK5TAJ+fXGLBm3FDAmn6oPPjR4rKCAoJCal2eAiQp2x0vxTPB3ALO2CRkwmDy5WohzBDwSEFKRwPbknEggCPB/imwrycgxX2NzoMCHhPkDwqYMr9tRcP5qNrMZHkVnOjRMWwLCcr8ohBVb1OMjxLwGCvjTikrsBOiA6fNyCrm8V1rP93iVPpwaE+gO0SsWmPiXB+jikdf6SizrT5qKasx5j8ABbHpFTx+vFXp9EnYQmLx02h1QTTrl6eDqxLnGjporxl3NL3agEvXdT0WmEost648sQOYAeJS9Q7bfUVoMGnjo4AZdUMQku50McDcMWcBPvr0SzbTAFDfvJqwLzgxwATnCgnp4wDl6Aa+Ax283gghmj+vj7feE2KBBRMW3FzOpLOADl0Isb5587h/U4gGvkt5v60Z1VLG8BhYjbzRwyQZemwAd6cCR5/XFWLYZRIMpX39AR0tjaGGiGzLVyhse5C9RKC6ai42ppWPKiBagOvaYk8lO7DajerabOZP46Lby5wKjw1HCRx7p9sVMOWGzb/vA1hwiWc6jm3MvQDTogQkiqIhJV0nBQBTU+3okKCFDy9WwferkHjtxib7t3xIUQtHxnIwtx4mpg26/HfwVNVDb4oI9RHmx5WGelRVlrtiw43zboCLaxv46AZeB3IlTkwouebTr1y2NjSpHz68WNFjHvupy3q8TFn3Hos2IAk4Ju5dCo8B3wP7VPr/FGaKiG+T+v+TQqIrOqMTL1VdWV1DdmcbO8KXBz6esmYWYKPwDL5b5FA1a0hwapHiom0r/cKaoqr+27/XcrS5UwSMbQAAAABJRU5ErkJggg==)](https://deepwiki.com/deflis/node-narou)
7
- <!-- DeepWiki badge generated by https://deepwiki.ryoppippi.com/ -->
7
+ [なろうデベロッパー](https://dev.syosetu.com/)の API を fluent interface で利用できる TypeScript ライブラリです。
8
+ A TypeScript wrapper library for Narou Developer APIs with fluent interface.
8
9
 
10
+ ## ✨ 特徴
9
11
 
10
- [なろうデベロッパー](https://dev.syosetu.com/)の API fluent interface で利用できるラッパーライブラリです。
11
- ブラウザでの JSONP の利用も可能です。
12
+ - 🔗 **メソッドチェーン対応**: 直感的な fluent interface で API を操作
13
+ - 🌐 **マルチ環境対応**: Node.js とブラウザの両方で動作
14
+ - 📝 **TypeScript 完全対応**: 型安全性と IntelliSense サポート
15
+ - 🔀 **デュアル実装**: fetch (Node.js) と JSONP (ブラウザ) を自動選択
16
+ - 📚 **全 API カバー**: なろうデベロッパーの全 API に対応
12
17
 
13
- 以下の API をラップしています。
18
+ ## 🚀 対応 API
14
19
 
15
- - [なろう小説 API](https://dev.syosetu.com/man/api/)
16
- - [なろう小説ランキング API](https://dev.syosetu.com/man/rankapi/)
17
- - [なろう殿堂入り API](https://dev.syosetu.com/man/rankinapi/)
18
- - [なろう R18 小説 API](https://dev.syosetu.com/xman/api/)
20
+ | API | 説明 | 関数 |
21
+ |-----|------|------|
22
+ | [なろう小説 API](https://dev.syosetu.com/man/api/) | 小説の検索・絞り込み | `search()` |
23
+ | [なろう小説ランキング API](https://dev.syosetu.com/man/rankapi/) | ランキング取得 | `ranking()` |
24
+ | [なろう殿堂入り API](https://dev.syosetu.com/man/rankinapi/) | ランキング履歴取得 | `rankingHistory()` |
25
+ | [なろう R18 小説 API](https://dev.syosetu.com/xman/api/) | 18禁小説検索 | `searchR18()` |
26
+ | [なろうユーザ検索 API](https://dev.syosetu.com/man/userapi/) | ユーザー検索 | `searchUser()` |
19
27
 
20
- ## Installation
28
+ ## 📦 インストール
21
29
 
22
- 以下のコマンドでインストールできます。
30
+ ```bash
31
+ # 推奨: pnpm
32
+ pnpm add narou
23
33
 
24
- ```
34
+ # または
25
35
  npm install narou
36
+ yarn add narou
26
37
  ```
27
38
 
28
- ## Usage - API
39
+ ## 🚀 クイックスタート
29
40
 
30
- https://deflis.github.io/node-narou/ を参照してください。
41
+ ### Node.js での使用
31
42
 
32
- ブラウザで利用したい場合 `narou/browser` をimportしてください。こちらを利用することで自動的にfetch(nodejs)への依存がなくなり、JSONPを利用するようになります。
43
+ ```typescript
44
+ import { search, ranking } from "narou";
45
+ import { Genre, Order, RankingType } from "narou";
46
+
47
+ // 異世界恋愛小説を検索
48
+ const result = await search("異世界")
49
+ .genre(Genre.RenaiIsekai)
50
+ .order(Order.FavoriteNovelCount)
51
+ .limit(10)
52
+ .execute();
33
53
 
34
- すでにサポート終了していますがfetchをサポートしないNode.jsバージョンで利用する場合は 、 `NarouNovelFetch` にfetchのNode.js実装を渡してください。
35
- なお、その場合の動作は確認していないので動かなければIssueを立ててください。
54
+ console.log(`${result.allcount}件の小説が見つかりました`);
55
+ ```
36
56
 
57
+ ### ブラウザでの使用
37
58
 
38
- ## Example
59
+ ```typescript
60
+ // ブラウザでは専用のインポートを使用(JSONP対応)
61
+ import { search } from "narou/browser";
62
+
63
+ const result = await search("魔法").execute();
64
+ ```
65
+
66
+ ## 📖 詳細な API ドキュメント
67
+
68
+ - **🔗 [完全な API ドキュメント](https://deflis.github.io/node-narou/)** - TypeDoc で生成された詳細なドキュメント
69
+ - **🤖 [LLM 向けドキュメント](https://deflis.github.io/node-narou/llms.txt)** - AI/LLM が理解しやすい形式のドキュメント(TypeDoc JSON から自動生成)
70
+
71
+ ## 📝 使用例
39
72
 
40
73
  ```typescript
41
74
  import { search, ranking, rankingHistory, searchR18 } from "narou";
@@ -115,32 +148,35 @@ for (const novel of searchR18Result.values) {
115
148
  }
116
149
  ```
117
150
 
118
- ## Development
119
-
120
- ```
121
-
122
- # watch
151
+ ## 🛠️ 開発
123
152
 
124
- npm run watch
153
+ このプロジェクトでは pnpm を使用しています。
125
154
 
126
- # build
155
+ ```bash
156
+ # 依存関係のインストール
157
+ pnpm install
127
158
 
128
- npm run build
159
+ # ビルド
160
+ pnpm run build
129
161
 
130
- # test
162
+ # テスト実行
163
+ pnpm run test
131
164
 
132
- npm run test
165
+ # 型チェック
166
+ pnpm run check
133
167
 
168
+ # ドキュメント生成(TypeDoc + llms.txt)
169
+ pnpm run docs
134
170
  ```
135
171
 
136
- ## Contributing
172
+ ## 🤝 コントリビューション
137
173
 
138
- 1. Fork it!
139
- 2. Create your feature branch: `git checkout -b my-new-feature`
140
- 3. Commit your changes: `git commit -am 'Add some feature'`
141
- 4. Push to the branch: `git push origin my-new-feature`
142
- 5. Submit a pull request :D
174
+ 1. このリポジトリをフォーク
175
+ 2. フィーチャーブランチを作成: `git checkout -b my-new-feature`
176
+ 3. 変更をコミット: `git commit -am 'Add some feature'`
177
+ 4. ブランチにプッシュ: `git push origin my-new-feature`
178
+ 5. プルリクエストを作成
143
179
 
144
- ## License
180
+ ## 📄 ライセンス
145
181
 
146
- MIT
182
+ MIT License - 詳細は [LICENSE](LICENSE) ファイルを参照してください。