narou 1.2.0 → 2.0.1

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 (166) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +73 -37
  3. package/dist/index.browser.cjs +90 -1360
  4. package/dist/index.browser.cjs.map +1 -1
  5. package/dist/index.browser.d.cts +14 -20
  6. package/dist/index.browser.d.mts +49 -0
  7. package/dist/index.browser.mjs +68 -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.browser.ts +5 -1
  24. package/src/index.ts +5 -1
  25. package/src/narou-fetch.ts +4 -3
  26. package/src/narou-jsonp.ts +4 -2
  27. package/src/narou.ts +50 -13
  28. package/src/params.ts +1 -1
  29. package/src/ranking.ts +20 -11
  30. package/src/search-builder-r18.ts +6 -2
  31. package/src/search-builder.ts +7 -3
  32. package/src/user-search.ts +9 -2
  33. package/dist/chunk-3A5MHPWL.js +0 -37
  34. package/dist/chunk-3A5MHPWL.js.map +0 -1
  35. package/dist/chunk-4ZP5YNWI.js +0 -1
  36. package/dist/chunk-4ZP5YNWI.js.map +0 -1
  37. package/dist/chunk-5UDKQCPJ.js +0 -407
  38. package/dist/chunk-5UDKQCPJ.js.map +0 -1
  39. package/dist/chunk-6BZWV4ZC.js +0 -75
  40. package/dist/chunk-6BZWV4ZC.js.map +0 -1
  41. package/dist/chunk-BQLSW236.js +0 -117
  42. package/dist/chunk-BQLSW236.js.map +0 -1
  43. package/dist/chunk-DEQICAN3.js +0 -94
  44. package/dist/chunk-DEQICAN3.js.map +0 -1
  45. package/dist/chunk-E2H3AJSQ.js +0 -57
  46. package/dist/chunk-E2H3AJSQ.js.map +0 -1
  47. package/dist/chunk-HOBLKBZ6.js +0 -452
  48. package/dist/chunk-HOBLKBZ6.js.map +0 -1
  49. package/dist/chunk-IPDEGCWU.js +0 -39
  50. package/dist/chunk-IPDEGCWU.js.map +0 -1
  51. package/dist/chunk-LQLNWSWV.js +0 -26
  52. package/dist/chunk-LQLNWSWV.js.map +0 -1
  53. package/dist/chunk-PLEM2AOH.js +0 -44
  54. package/dist/chunk-PLEM2AOH.js.map +0 -1
  55. package/dist/chunk-RNHRR56W.js +0 -25
  56. package/dist/chunk-RNHRR56W.js.map +0 -1
  57. package/dist/chunk-VUZIISP2.js +0 -23
  58. package/dist/chunk-VUZIISP2.js.map +0 -1
  59. package/dist/chunk-VZVUANDN.js +0 -17
  60. package/dist/chunk-VZVUANDN.js.map +0 -1
  61. package/dist/index.browser.d.ts +0 -55
  62. package/dist/index.browser.js +0 -126
  63. package/dist/index.browser.js.map +0 -1
  64. package/dist/index.common.cjs +0 -1187
  65. package/dist/index.common.cjs.map +0 -1
  66. package/dist/index.common.d.cts +0 -6
  67. package/dist/index.common.d.ts +0 -6
  68. package/dist/index.common.js +0 -76
  69. package/dist/index.common.js.map +0 -1
  70. package/dist/index.d.ts +0 -56
  71. package/dist/index.js +0 -131
  72. package/dist/index.js.map +0 -1
  73. package/dist/narou-DBa12V_l.d.ts +0 -404
  74. package/dist/narou-DCp4aGfA.d.cts +0 -404
  75. package/dist/narou-fetch.cjs +0 -164
  76. package/dist/narou-fetch.cjs.map +0 -1
  77. package/dist/narou-fetch.d.cts +0 -20
  78. package/dist/narou-fetch.d.ts +0 -20
  79. package/dist/narou-fetch.js +0 -10
  80. package/dist/narou-fetch.js.map +0 -1
  81. package/dist/narou-jsonp.cjs +0 -162
  82. package/dist/narou-jsonp.cjs.map +0 -1
  83. package/dist/narou-jsonp.d.cts +0 -13
  84. package/dist/narou-jsonp.d.ts +0 -13
  85. package/dist/narou-jsonp.js +0 -10
  86. package/dist/narou-jsonp.js.map +0 -1
  87. package/dist/narou-ranking-results.cjs +0 -19
  88. package/dist/narou-ranking-results.cjs.map +0 -1
  89. package/dist/narou-ranking-results.d.cts +0 -4
  90. package/dist/narou-ranking-results.d.ts +0 -4
  91. package/dist/narou-ranking-results.js +0 -1
  92. package/dist/narou-ranking-results.js.map +0 -1
  93. package/dist/narou-search-results-C21hWrnL.d.cts +0 -727
  94. package/dist/narou-search-results-DT0YdaBn.d.ts +0 -727
  95. package/dist/narou-search-results.cjs +0 -62
  96. package/dist/narou-search-results.cjs.map +0 -1
  97. package/dist/narou-search-results.d.cts +0 -2
  98. package/dist/narou-search-results.d.ts +0 -2
  99. package/dist/narou-search-results.js +0 -11
  100. package/dist/narou-search-results.js.map +0 -1
  101. package/dist/narou.cjs +0 -112
  102. package/dist/narou.cjs.map +0 -1
  103. package/dist/narou.d.cts +0 -4
  104. package/dist/narou.d.ts +0 -4
  105. package/dist/narou.js +0 -8
  106. package/dist/narou.js.map +0 -1
  107. package/dist/params.cjs +0 -448
  108. package/dist/params.cjs.map +0 -1
  109. package/dist/params.d.cts +0 -2
  110. package/dist/params.d.ts +0 -2
  111. package/dist/params.js +0 -41
  112. package/dist/params.js.map +0 -1
  113. package/dist/ranking-history.cjs +0 -47
  114. package/dist/ranking-history.cjs.map +0 -1
  115. package/dist/ranking-history.d.cts +0 -28
  116. package/dist/ranking-history.d.ts +0 -28
  117. package/dist/ranking-history.js +0 -8
  118. package/dist/ranking-history.js.map +0 -1
  119. package/dist/ranking.cjs +0 -783
  120. package/dist/ranking.cjs.map +0 -1
  121. package/dist/ranking.d.cts +0 -108
  122. package/dist/ranking.d.ts +0 -108
  123. package/dist/ranking.js +0 -10
  124. package/dist/ranking.js.map +0 -1
  125. package/dist/search-builder-r18.cjs +0 -547
  126. package/dist/search-builder-r18.cjs.map +0 -1
  127. package/dist/search-builder-r18.d.cts +0 -45
  128. package/dist/search-builder-r18.d.ts +0 -45
  129. package/dist/search-builder-r18.js +0 -9
  130. package/dist/search-builder-r18.js.map +0 -1
  131. package/dist/search-builder.cjs +0 -591
  132. package/dist/search-builder.cjs.map +0 -1
  133. package/dist/search-builder.d.cts +0 -4
  134. package/dist/search-builder.d.ts +0 -4
  135. package/dist/search-builder.js +0 -12
  136. package/dist/search-builder.js.map +0 -1
  137. package/dist/user-search.cjs +0 -325
  138. package/dist/user-search.cjs.map +0 -1
  139. package/dist/user-search.d.cts +0 -66
  140. package/dist/user-search.d.ts +0 -66
  141. package/dist/user-search.js +0 -9
  142. package/dist/user-search.js.map +0 -1
  143. package/dist/util/date.cjs +0 -51
  144. package/dist/util/date.cjs.map +0 -1
  145. package/dist/util/date.d.cts +0 -21
  146. package/dist/util/date.d.ts +0 -21
  147. package/dist/util/date.js +0 -11
  148. package/dist/util/date.js.map +0 -1
  149. package/dist/util/jsonp.cjs +0 -63
  150. package/dist/util/jsonp.cjs.map +0 -1
  151. package/dist/util/jsonp.d.cts +0 -49
  152. package/dist/util/jsonp.d.ts +0 -49
  153. package/dist/util/jsonp.js +0 -7
  154. package/dist/util/jsonp.js.map +0 -1
  155. package/dist/util/type.cjs +0 -19
  156. package/dist/util/type.cjs.map +0 -1
  157. package/dist/util/type.d.cts +0 -27
  158. package/dist/util/type.d.ts +0 -27
  159. package/dist/util/type.js +0 -1
  160. package/dist/util/type.js.map +0 -1
  161. package/dist/util/unzipp.cjs +0 -47
  162. package/dist/util/unzipp.cjs.map +0 -1
  163. package/dist/util/unzipp.d.cts +0 -12
  164. package/dist/util/unzipp.d.ts +0 -12
  165. package/dist/util/unzipp.js +0 -7
  166. package/dist/util/unzipp.js.map +0 -1
@@ -1,1373 +1,103 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/index.browser.ts
21
- var index_browser_exports = {};
22
- __export(index_browser_exports, {
23
- BigGenre: () => BigGenre,
24
- BigGenreNotation: () => BigGenreNotation,
25
- BooleanNumber: () => BooleanNumber,
26
- BuntaiParam: () => BuntaiParam,
27
- DateParam: () => DateParam,
28
- End: () => End,
29
- Fields: () => Fields,
30
- Genre: () => Genre,
31
- GenreNotation: () => GenreNotation,
32
- NarouNovel: () => NarouNovel,
33
- NarouNovelJsonp: () => NarouNovelJsonp,
34
- NarouSearchResults: () => NarouSearchResults,
35
- NovelSearchBuilderBase: () => NovelSearchBuilderBase,
36
- NovelType: () => NovelType,
37
- NovelTypeParam: () => NovelTypeParam,
38
- OptionalFields: () => OptionalFields,
39
- Order: () => Order,
40
- R18Fields: () => R18Fields,
41
- R18Site: () => R18Site,
42
- R18SiteNotation: () => R18SiteNotation,
43
- RankingBuilder: () => RankingBuilder,
44
- RankingType: () => RankingType,
45
- SearchBuilder: () => SearchBuilder,
46
- SearchBuilderBase: () => SearchBuilderBase,
47
- SearchBuilderR18: () => SearchBuilderR18,
48
- StopParam: () => StopParam,
49
- UserFields: () => UserFields,
50
- UserOrder: () => UserOrder,
51
- default: () => index_browser_default,
52
- formatRankingHistory: () => formatRankingHistory,
53
- ranking: () => ranking,
54
- rankingHistory: () => rankingHistory,
55
- search: () => search,
56
- searchR18: () => searchR18,
57
- searchUser: () => searchUser
58
- });
59
- module.exports = __toCommonJS(index_browser_exports);
60
-
61
- // src/narou-search-results.ts
62
- var NarouSearchResults = class {
63
- /**
64
- * @constractor
65
- * @private
66
- */
67
- constructor([header, ...result], params) {
68
- const count2 = header.allcount;
69
- const limit = params.lim ?? 20;
70
- const start = params.st ?? 0;
71
- this.allcount = count2;
72
- this.limit = limit;
73
- this.start = start;
74
- this.page = start / limit;
75
- this.length = result.length;
76
- this.values = result;
77
- }
78
- };
79
- var NovelType = {
80
- /** 連載 */
81
- Rensai: 1,
82
- /** 短編 */
83
- Tanpen: 2
84
- };
85
- var End = {
86
- /** 短編小説と完結済小説 */
87
- KanketsuOrTanpen: 0,
88
- /** 連載中 */
89
- Rensai: 1
90
- };
91
-
92
- // src/narou.ts
93
- var NarouNovel = class {
94
- /**
95
- * APIへの検索リクエストを実行する
96
- * @param params クエリパラメータ
97
- * @param endpoint APIエンドポイント
98
- * @returns 検索結果
99
- */
100
- async executeSearch(params, endpoint = "https://api.syosetu.com/novelapi/api/") {
101
- return new NarouSearchResults(await this.execute(params, endpoint), params);
102
- }
103
- /**
104
- * 小説APIへの検索リクエストを実行する
105
- * @param params クエリパラメータ
106
- * @returns 検索結果
107
- * @see https://dev.syosetu.com/man/api/
108
- */
109
- async executeNovel(params) {
110
- return await this.executeSearch(
111
- params,
112
- "https://api.syosetu.com/novelapi/api/"
113
- );
114
- }
115
- /**
116
- * R18小説APIへの検索リクエストを実行する
117
- * @param params クエリパラメータ
118
- * @returns 検索結果
119
- * @see https://dev.syosetu.com/xman/api/
120
- */
121
- async executeNovel18(params) {
122
- return await this.executeSearch(
123
- params,
124
- "https://api.syosetu.com/novel18api/api/"
125
- );
126
- }
127
- /**
128
- * ランキングAPIへのリクエストを実行する
129
- * @param params クエリパラメータ
130
- * @returns ランキング結果
131
- * @see https://dev.syosetu.com/man/rankapi/
132
- */
133
- async executeRanking(params) {
134
- return await this.execute(params, "https://api.syosetu.com/rank/rankget/");
135
- }
136
- /**
137
- * 殿堂入りAPiへのリクエストを実行する
138
- * @param params クエリパラメータ
139
- * @returns ランキング履歴結果
140
- * @see https://dev.syosetu.com/man/rankinapi/
141
- */
142
- async executeRankingHistory(params) {
143
- return await this.execute(params, "https://api.syosetu.com/rank/rankin/");
144
- }
145
- /**
146
- * ユーザー検索APIへのリクエストを実行する
147
- * @param params クエリパラメータ
148
- * @returns 検索結果
149
- * @see https://dev.syosetu.com/man/userapi/
150
- */
151
- async executeUserSearch(params) {
152
- return new NarouSearchResults(
153
- await this.execute(params, "https://api.syosetu.com/userapi/api/"),
154
- params
155
- );
156
- }
157
- };
158
-
159
- // src/util/jsonp.ts
160
- var count = 0;
161
- var noop = function() {
162
- };
163
- function jsonp(url, { prefix = "__jp", param = "callback", timeout = 15e3 } = {}) {
164
- return new Promise(function(resolve, reject) {
165
- const targetChild = document.getElementsByTagName("script").item(0);
166
- const target = targetChild?.parentNode ?? document.head;
167
- const id = `${prefix}${count++}`;
168
- const cleanup = function() {
169
- if (script && script.parentNode) {
170
- script.parentNode.removeChild(script);
171
- }
172
- window[id] = noop;
173
- if (timer) {
174
- clearTimeout(timer);
175
- }
176
- };
177
- const timer = timeout > 0 ? setTimeout(() => {
178
- cleanup();
179
- reject(new Error("Timeout"));
180
- }, timeout) : void 0;
181
- const callback = (data) => {
182
- cleanup();
183
- resolve(data);
184
- };
185
- window[id] = callback;
186
- const script = document.createElement("script");
187
- const urlObj = new URL(url);
188
- urlObj.searchParams.set(param, id);
189
- script.setAttribute("src", urlObj.toString());
190
- target.insertBefore(script, targetChild);
191
- });
192
- }
193
-
194
- // src/narou-jsonp.ts
195
- var NarouNovelJsonp = class extends NarouNovel {
196
- async execute(params, endpoint) {
197
- const query = { ...params, out: "jsonp" };
198
- query.gzip = 0;
199
- const url = new URL(endpoint);
200
- Object.entries(query).forEach(([key, value]) => {
201
- if (value !== void 0) {
202
- url.searchParams.append(key, value.toString());
203
- }
204
- });
205
- return await jsonp(url.toString());
206
- }
207
- };
208
-
209
- // src/params.ts
210
- var RankingType = {
211
- Daily: "d",
212
- Weekly: "w",
213
- Monthly: "m",
214
- Quarterly: "q"
215
- };
216
- var BooleanNumber = {
217
- True: 1,
218
- False: 0
219
- };
220
- var Fields = {
221
- /** 小説名 */
222
- title: "t",
223
- /** Nコード */
224
- ncode: "n",
225
- /** 作者のユーザID(数値) */
226
- userid: "u",
227
- /** 作者名 */
228
- writer: "w",
229
- /** 小説のあらすじ */
230
- story: "s",
231
- /** 大ジャンル */
232
- biggenre: "bg",
233
- /** ジャンル */
234
- genre: "g",
235
- /** キーワード */
236
- keyword: "k",
237
- /** 初回掲載日 */
238
- general_firstup: "gf",
239
- /** 最終掲載日 */
240
- general_lastup: "gl",
241
- /** 連載の場合は1、短編の場合は2 */
242
- noveltype: "nt",
243
- /** 短編小説と完結済小説は0となっています。連載中は1です。 */
244
- end: "e",
245
- /** 全掲載部分数 */
246
- general_all_no: "ga",
247
- /** 小説文字数 */
248
- length: "l",
249
- /** 読了時間(分単位) */
250
- time: "ti",
251
- /** 長期連載停止中 */
252
- isstop: "i",
253
- /** 登録必須キーワードに「R15」が含まれる場合は1、それ以外は0です。 */
254
- isr15: "isr",
255
- /** 登録必須キーワードに「ボーイズラブ」が含まれる場合は1、それ以外は0です。 */
256
- isbl: "ibl",
257
- /** 登録必須キーワードに「ガールズラブ」が含まれる場合は1、それ以外は0です。 */
258
- isgl: "igl",
259
- /** 登録必須キーワードに「残酷な描写あり」が含まれる場合は1、それ以外は0です。 */
260
- iszankoku: "izk",
261
- /** 登録必須キーワードに「異世界転生」が含まれる場合は1、それ以外は0です。 */
262
- istensei: "its",
263
- /** 登録必須キーワードに「異世界転移」が含まれる場合は1、それ以外は0です。 */
264
- istenni: "iti",
265
- /** 総合評価ポイント */
266
- global_point: "gp",
267
- /** 日間ポイント */
268
- daily_point: "dp",
269
- /** 週間ポイント */
270
- weekly_point: "wp",
271
- /** 月間ポイント */
272
- monthly_point: "mp",
273
- /** 四半期ポイント */
274
- quarter_point: "qp",
275
- /** 年間ポイント */
276
- yearly_point: "yp",
277
- /** ブックマーク数 */
278
- fav_novel_cnt: "f",
279
- /** 感想数 */
280
- impression_cnt: "imp",
281
- /** レビュー数 */
282
- review_cnt: "r",
283
- /** 評価ポイント */
284
- all_point: "a",
285
- /** 評価者数 */
286
- all_hyoka_cnt: "ah",
287
- /** 挿絵の数 */
288
- sasie_cnt: "sa",
289
- /** 会話率 */
290
- kaiwaritu: "ka",
291
- /** 小説の更新日時 */
292
- novelupdated_at: "nu",
293
- /**
294
- * 最終更新日時
295
- * システム用で小説更新時とは関係ありません
296
- */
297
- updated_at: "ua"
298
- };
299
- var R18Fields = {
300
- /** 小説名 */
301
- title: "t",
302
- /** Nコード */
303
- ncode: "n",
304
- /** 作者のユーザID(数値) */
305
- userid: "u",
306
- /** 作者名 */
307
- writer: "w",
308
- /** 小説のあらすじ */
309
- story: "s",
310
- /** 掲載サイト */
311
- nocgenre: "ng",
312
- /** キーワード */
313
- keyword: "k",
314
- /** 初回掲載日 */
315
- general_firstup: "gf",
316
- /** 最終掲載日 */
317
- general_lastup: "gl",
318
- /** 連載の場合は1、短編の場合は2 */
319
- noveltype: "nt",
320
- /** 短編小説と完結済小説は0となっています。連載中は1です。 */
321
- end: "e",
322
- /** 全掲載部分数 */
323
- general_all_no: "ga",
324
- /** 小説文字数 */
325
- length: "l",
326
- /** 読了時間(分単位) */
327
- time: "ti",
328
- /** 長期連載停止中 */
329
- isstop: "i",
330
- /** 登録必須キーワードに「ボーイズラブ」が含まれる場合は1、それ以外は0です。 */
331
- isbl: "ibl",
332
- /** 登録必須キーワードに「ガールズラブ」が含まれる場合は1、それ以外は0です。 */
333
- isgl: "igl",
334
- /** 登録必須キーワードに「残酷な描写あり」が含まれる場合は1、それ以外は0です。 */
335
- iszankoku: "izk",
336
- /** 登録必須キーワードに「異世界転生」が含まれる場合は1、それ以外は0です。 */
337
- istensei: "its",
338
- /** 登録必須キーワードに「異世界転移」が含まれる場合は1、それ以外は0です。 */
339
- istenni: "iti",
340
- /** 総合評価ポイント */
341
- global_point: "gp",
342
- /** 日間ポイント */
343
- daily_point: "dp",
344
- /** 週間ポイント */
345
- weekly_point: "wp",
346
- /** 月間ポイント */
347
- monthly_point: "mp",
348
- /** 四半期ポイント */
349
- quarter_point: "qp",
350
- /** 年間ポイント */
351
- yearly_point: "yp",
352
- /** R18ブックマーク数 */
353
- fav_novel_cnt: "f",
354
- /** 感想数 */
355
- impression_cnt: "imp",
356
- /** レビュー数 */
357
- review_cnt: "r",
358
- /** 評価ポイント */
359
- all_point: "a",
360
- /** 評価者数 */
361
- all_hyoka_cnt: "ah",
362
- /** 挿絵の数 */
363
- sasie_cnt: "sa",
364
- /** 会話率 */
365
- kaiwaritu: "ka",
366
- /** 小説の更新日時 */
367
- novelupdated_at: "nu",
368
- /**
369
- * 最終更新日時
370
- * システム用で小説更新時とは関係ありません
371
- */
372
- updated_at: "ua"
373
- };
374
- var OptionalFields = {
375
- /**
376
- * 週間ユニークユーザ[項目名:weekly_unique]が追加されます。
377
- * 週間ユニークユーザは前週の日曜日から土曜日分のユニークの合計です。
378
- * 毎週火曜日早朝に更新されます。
379
- */
380
- weekly_unique: "weekly"
381
- };
382
- var UserFields = {
383
- /** ユーザID */
384
- userid: "u",
385
- /** ユーザ名 */
386
- name: "n",
387
- /** ユーザ名のフリガナ */
388
- yomikata: "y",
389
- /** ユーザ名のフリガナの頭文字 */
390
- name1st: "1",
391
- /** 小説投稿数 */
392
- novel_cnt: "nc",
393
- /** レビュー投稿数 */
394
- review_cnt: "rc",
395
- /** 小説累計文字数 */
396
- novel_length: "nl",
397
- /** 総合評価ポイントの合計 */
398
- sum_global_point: "sg"
399
- };
400
- var Order = {
401
- /** ブックマーク数の多い順 */
402
- FavoriteNovelCount: "favnovelcnt",
403
- /** レビュー数の多い順 */
404
- ReviewCount: "favnovelcnt",
405
- /** 総合ポイントの高い順 */
406
- HyokaDesc: "hyoka",
407
- /** 総合ポイントの低い順 */
408
- HyokaAsc: "hyokaasc",
409
- /** 感想の多い順 */
410
- ImpressionCount: "impressioncnt",
411
- /** 評価者数の多い順 */
412
- HyokaCountDesc: "hyokacnt",
413
- /** 評価者数の少ない順 */
414
- HyokaCountAsc: "hyokacntasc",
415
- /** 週間ユニークユーザの多い順 */
416
- Weekly: "weekly",
417
- /** 小説本文の文字数が多い順 */
418
- LengthDesc: "lengthdesc",
419
- /** 小説本文の文字数が少ない順 */
420
- LengthAsc: "lengthasc",
421
- /** Nコードが新しい順 */
422
- NCodeDesc: "ncodedesc",
423
- /** 新着更新順 */
424
- New: "new",
425
- /** 古い順 */
426
- Old: "old",
427
- /** 日間ポイントの高い順 */
428
- DailyPoint: "dailypoint",
429
- /** 週間ポイントの高い順 */
430
- WeeklyPoint: "weeklypoint",
431
- /** 月間ポイントの高い順 */
432
- MonthlyPoint: "monthlypoint",
433
- /** 四半期ポイントの高い順 */
434
- QuarterPoint: "quarterpoint",
435
- /** 年間ポイントの高い順 */
436
- YearlyPoint: "yearlypoint",
437
- /** 初回掲載順 */
438
- GeneralFirstUp: "generalfirstup"
439
- };
440
- var R18Site = {
441
- /** ノクターンノベルズ(男性向け) */
442
- Nocturne: 1,
443
- /** ムーンライトノベルズ(女性向け) */
444
- MoonLight: 2,
445
- /** ムーンライトノベルズ(BL) */
446
- MoonLightBL: 3,
447
- /** ミッドナイトノベルズ(大人向け) */
448
- Midnight: 4
449
- };
450
- var R18SiteNotation = {
451
- [R18Site.Nocturne]: "\u30CE\u30AF\u30BF\u30FC\u30F3\u30CE\u30D9\u30EB\u30BA(\u7537\u6027\u5411\u3051)",
452
- [R18Site.MoonLight]: "\u30E0\u30FC\u30F3\u30E9\u30A4\u30C8\u30CE\u30D9\u30EB\u30BA(\u5973\u6027\u5411\u3051)",
453
- [R18Site.MoonLightBL]: "\u30E0\u30FC\u30F3\u30E9\u30A4\u30C8\u30CE\u30D9\u30EB\u30BA(BL)",
454
- [R18Site.Midnight]: "\u30DF\u30C3\u30C9\u30CA\u30A4\u30C8\u30CE\u30D9\u30EB\u30BA(\u5927\u4EBA\u5411\u3051)"
455
- };
456
- var BigGenre = {
457
- /** 恋愛 */
458
- Renai: 1,
459
- /** ファンタジー */
460
- Fantasy: 2,
461
- /** 文芸 */
462
- Bungei: 3,
463
- /** SF */
464
- Sf: 4,
465
- /** その他 */
466
- Sonota: 99,
467
- /** ノンジャンル */
468
- NonGenre: 98
469
- };
470
- var BigGenreNotation = {
471
- [BigGenre.Renai]: "\u604B\u611B",
472
- [BigGenre.Fantasy]: "\u30D5\u30A1\u30F3\u30BF\u30B8\u30FC",
473
- [BigGenre.Bungei]: "\u6587\u82B8",
474
- [BigGenre.Sf]: "SF",
475
- [BigGenre.Sonota]: "\u305D\u306E\u4ED6",
476
- [BigGenre.NonGenre]: "\u30CE\u30F3\u30B8\u30E3\u30F3\u30EB"
477
- };
478
- var Genre = {
479
- /** 異世界〔恋愛〕*/
480
- RenaiIsekai: 101,
481
- /** 現実世界〔恋愛〕*/
482
- RenaiGenjitsusekai: 102,
483
- /** ハイファンタジー〔ファンタジー〕*/
484
- FantasyHigh: 201,
485
- /** ローファンタジー〔ファンタジー〕*/
486
- FantasyLow: 202,
487
- /** 純文学〔文芸〕*/
488
- BungeiJyunbungei: 301,
489
- /** ヒューマンドラマ〔文芸〕*/
490
- BungeiHumanDrama: 302,
491
- /** 歴史〔文芸〕*/
492
- BungeiHistory: 303,
493
- /** 推理〔文芸〕*/
494
- BungeiSuiri: 304,
495
- /** ホラー〔文芸〕*/
496
- BungeiHorror: 305,
497
- /** アクション〔文芸〕*/
498
- BungeiAction: 306,
499
- /** コメディー〔文芸〕*/
500
- BungeiComedy: 307,
501
- /** VRゲーム〔SF〕*/
502
- SfVrgame: 401,
503
- /** 宇宙〔SF〕*/
504
- SfSpace: 402,
505
- /** 空想科学〔SF〕*/
506
- SfKuusoukagaku: 403,
507
- /** パニック〔SF〕*/
508
- SfPanic: 404,
509
- /** 童話〔その他〕*/
510
- SonotaDouwa: 9901,
511
- /** 詩〔その他〕*/
512
- SonotaShi: 9902,
513
- /** エッセイ〔その他〕*/
514
- SonotaEssei: 9903,
515
- /** リプレイ〔その他〕*/
516
- SonotaReplay: 9904,
517
- /** その他〔その他〕 */
518
- SonotaSonota: 9999,
519
- /** ノンジャンル〔ノンジャンル〕*/
520
- NonGenre: 9801
521
- };
522
- var GenreNotation = {
523
- [Genre.RenaiIsekai]: "\u7570\u4E16\u754C\u3014\u604B\u611B\u3015",
524
- [Genre.RenaiGenjitsusekai]: "\u73FE\u5B9F\u4E16\u754C\u3014\u604B\u611B\u3015",
525
- [Genre.FantasyHigh]: "\u30CF\u30A4\u30D5\u30A1\u30F3\u30BF\u30B8\u30FC\u3014\u30D5\u30A1\u30F3\u30BF\u30B8\u30FC\u3015",
526
- [Genre.FantasyLow]: "\u30ED\u30FC\u30D5\u30A1\u30F3\u30BF\u30B8\u30FC\u3014\u30D5\u30A1\u30F3\u30BF\u30B8\u30FC\u3015",
527
- [Genre.BungeiJyunbungei]: "\u7D14\u6587\u5B66\u3014\u6587\u82B8\u3015",
528
- [Genre.BungeiHumanDrama]: "\u30D2\u30E5\u30FC\u30DE\u30F3\u30C9\u30E9\u30DE\u3014\u6587\u82B8\u3015",
529
- [Genre.BungeiHistory]: "\u6B74\u53F2\u3014\u6587\u82B8\u3015",
530
- [Genre.BungeiSuiri]: "\u63A8\u7406\u3014\u6587\u82B8\u3015",
531
- [Genre.BungeiHorror]: "\u30DB\u30E9\u30FC\u3014\u6587\u82B8\u3015",
532
- [Genre.BungeiAction]: "\u30A2\u30AF\u30B7\u30E7\u30F3\u3014\u6587\u82B8\u3015",
533
- [Genre.BungeiComedy]: "\u30B3\u30E1\u30C7\u30A3\u30FC\u3014\u6587\u82B8\u3015",
534
- [Genre.SfVrgame]: "VR\u30B2\u30FC\u30E0\u3014SF\u3015",
535
- [Genre.SfSpace]: "\u5B87\u5B99\u3014SF\u3015",
536
- [Genre.SfKuusoukagaku]: "\u7A7A\u60F3\u79D1\u5B66\u3014SF\u3015",
537
- [Genre.SfPanic]: "\u30D1\u30CB\u30C3\u30AF\u3014SF\u3015",
538
- [Genre.SonotaDouwa]: "\u7AE5\u8A71\u3014\u305D\u306E\u4ED6\u3015",
539
- [Genre.SonotaShi]: "\u8A69\u3014\u305D\u306E\u4ED6\u3015",
540
- [Genre.SonotaEssei]: "\u30A8\u30C3\u30BB\u30A4\u3014\u305D\u306E\u4ED6\u3015",
541
- [Genre.SonotaReplay]: "\u30EA\u30D7\u30EC\u30A4\u3014\u305D\u306E\u4ED6\u3015",
542
- [Genre.SonotaSonota]: "\u305D\u306E\u4ED6\u3014\u305D\u306E\u4ED6\u3015",
543
- [Genre.NonGenre]: "\u30CE\u30F3\u30B8\u30E3\u30F3\u30EB\u3014\u30CE\u30F3\u30B8\u30E3\u30F3\u30EB\u3015"
544
- };
545
- var BuntaiParam = {
546
- /** 字下げされておらず、連続改行が多い作品 */
547
- NoJisageKaigyouOoi: 1,
548
- /** 字下げされていないが、改行数は平均な作品 */
549
- NoJisageKaigyoHutsuu: 2,
550
- /** 字下げが適切だが、連続改行が多い作品 */
551
- JisageKaigyoOoi: 4,
552
- /** 字下げが適切でかつ改行数も平均な作品 */
553
- JisageKaigyoHutsuu: 6
554
- };
555
- var StopParam = {
556
- /** 長期連載停止中を除きます */
557
- NoStopping: 1,
558
- /** 長期連載停止中のみ取得します */
559
- Stopping: 2
560
- };
561
- var NovelTypeParam = {
562
- /** 短編 */
563
- Short: "t",
564
- /** 連載中 */
565
- RensaiNow: "r",
566
- /** 完結済連載小説 */
567
- RensaiEnd: "er",
568
- /** すべての連載小説(連載中および完結済) */
569
- Rensai: "re",
570
- /** 短編と完結済連載小説 */
571
- ShortAndRensai: "ter"
572
- };
573
- var DateParam = {
574
- ThisWeek: "thisweek",
575
- LastWeek: "lastweek",
576
- SevenDays: "sevenday",
577
- ThisMonth: "thismonth",
578
- LastMonth: "lastmonth"
579
- };
580
- var UserOrder = {
581
- /** ユーザIDの新しい順 */
582
- New: "new",
583
- /** 小説投稿数の多い順 */
584
- NovelCount: "novelcnt",
585
- /** レビュー投稿数の多い順 */
586
- ReviewCount: "reviewcnt",
587
- /** 小説累計文字数の多い順 */
588
- NovelLength: "novellength",
589
- /** 総合評価ポイントの合計の多い順 */
590
- SumGlobalPoint: "sumglobalpoint",
591
- /** ユーザIDの古い順 */
592
- Old: "old"
593
- };
594
-
595
- // src/search-builder.ts
596
- var SearchBuilderBase = class {
597
- /**
598
- * constructor
599
- * @private
600
- * @param params クエリパラメータ
601
- * @param api NarouNovel インスタンス
602
- */
603
- constructor(params = {}, api) {
604
- this.params = params;
605
- this.api = api;
606
- }
607
- /**
608
- * 配列から重複を除去する
609
- * @protected
610
- * @static
611
- * @param array 配列
612
- * @returns 重複を除去した配列
613
- */
614
- static distinct(array) {
615
- return Array.from(new Set(array));
616
- }
617
- /**
618
- * 配列をハイフン区切りの文字列に変換する
619
- * @protected
620
- * @static
621
- * @param n 文字列または数値の配列、あるいは単一の文字列または数値
622
- * @returns ハイフン区切りの文字列
623
- */
624
- static array2string(n) {
625
- if (Array.isArray(n)) {
626
- return this.distinct(n).join("-");
627
- } else {
628
- return n.toString();
629
- }
630
- }
631
- /**
632
- * 取得件数を指定する (lim)
633
- * @param num 取得件数 (1-500)
634
- * @return {this}
635
- */
636
- limit(num) {
637
- this.set({ lim: num });
638
- return this;
639
- }
640
- /**
641
- * 取得開始位置を指定する (st)
642
- * @param num 取得開始位置 (1-)
643
- * @return {this}
644
- */
645
- start(num) {
646
- this.set({ st: num });
647
- return this;
648
- }
649
- /**
650
- * ページ番号と1ページあたりの件数で取得範囲を指定する
651
- * @param no ページ番号 (0-)
652
- * @param count 1ページあたりの件数 (デフォルト: 20)
653
- * @return {this}
654
- */
655
- page(no, count2 = 20) {
656
- return this.limit(count2).start(no * count2);
657
- }
658
- /**
659
- * 出力順序を指定する (order)
660
- * 指定しない場合は新着順となります。
661
- * @param {TOrder} order 出力順序
662
- * @return {this}
663
- */
664
- order(order) {
665
- this.set({ order });
666
- return this;
667
- }
668
- /**
669
- * gzip圧縮レベルを指定する (gzip)
670
- *
671
- * 転送量上限を減らすためにも推奨
672
- * @param {GzipLevel} level gzip圧縮レベル(1~5)
673
- * @return {this}
674
- */
675
- gzip(level) {
676
- this.set({ gzip: level });
677
- return this;
678
- }
679
- /**
680
- * クエリパラメータをセットする
681
- * @protected
682
- * @param obj セットするパラメータ
683
- * @return {this}
684
- */
685
- set(obj) {
686
- this.params = { ...this.params, ...obj };
687
- return this;
688
- }
689
- /**
690
- * クエリパラメータを削除する
691
- * @protected
692
- * @param key 削除するパラメータのキー
693
- * @returns {this}
694
- */
695
- unset(key) {
696
- delete this.params[key];
697
- return this;
698
- }
699
- };
700
- var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilderBase {
701
- /**
702
- * 検索語を指定します (word)。
703
- * 半角または全角スペースで区切るとAND抽出になります。部分一致でHITします。
704
- * @param word 検索語
705
- * @return {this}
706
- */
707
- word(word) {
708
- this.set({ word });
709
- return this;
710
- }
711
- /**
712
- * 除外したい単語を指定します (notword)。
713
- * スペースで区切ることにより除外する単語を増やせます。部分一致で除外されます。
714
- * @param word 除外語
715
- * @return {this}
716
- */
717
- notWord(word) {
718
- this.set({ notword: word });
719
- return this;
720
- }
721
- /**
722
- * 検索対象を作品名に限定するかどうかを指定します (title)。
723
- * @param bool trueの場合、作品名を検索対象とする (デフォルト: true)
724
- * @return {this}
725
- */
726
- byTitle(bool = true) {
727
- this.set({ title: bool ? BooleanNumber.True : BooleanNumber.False });
728
- return this;
729
- }
730
- /**
731
- * 検索対象をあらすじに限定するかどうかを指定します (ex)。
732
- * @param bool trueの場合、あらすじを検索対象とする (デフォルト: true)
733
- * @return {this}
734
- */
735
- byOutline(bool = true) {
736
- this.set({ ex: bool ? BooleanNumber.True : BooleanNumber.False });
737
- return this;
738
- }
739
- /**
740
- * 検索対象をキーワードに限定するかどうかを指定します (keyword)。
741
- * @param bool trueの場合、キーワードを検索対象とする (デフォルト: true)
742
- * @return {this}
743
- */
744
- byKeyword(bool = true) {
745
- this.set({ keyword: bool ? BooleanNumber.True : BooleanNumber.False });
746
- return this;
747
- }
748
- /**
749
- * 検索対象を作者名に限定するかどうかを指定します (wname)。
750
- * @param bool trueの場合、作者名を検索対象とする (デフォルト: true)
751
- * @return {this}
752
- */
753
- byAuthor(bool = true) {
754
- this.set({ wname: bool ? BooleanNumber.True : BooleanNumber.False });
755
- return this;
756
- }
757
- /**
758
- * ボーイズラブ作品を抽出または除外します (isbl/notbl)。
759
- * @param bool trueの場合、ボーイズラブ作品を抽出する (デフォルト: true)。falseの場合、除外する。
760
- * @return {this}
761
- */
762
- isBL(bool = true) {
763
- if (bool) {
764
- this.set({ isbl: BooleanNumber.True });
765
- } else {
766
- this.set({ notbl: BooleanNumber.True });
767
- }
768
- return this;
769
- }
770
- /**
771
- * ガールズラブ作品を抽出または除外します (isgl/notgl)。
772
- * @param bool trueの場合、ガールズラブ作品を抽出する (デフォルト: true)。falseの場合、除外する。
773
- * @return {this}
774
- */
775
- isGL(bool = true) {
776
- if (bool) {
777
- this.set({ isgl: BooleanNumber.True });
778
- } else {
779
- this.set({ notgl: BooleanNumber.True });
780
- }
781
- return this;
782
- }
783
- /**
784
- * 残酷な描写あり作品を抽出または除外します (iszankoku/notzankoku)。
785
- * @param bool trueの場合、残酷な描写あり作品を抽出する (デフォルト: true)。falseの場合、除外する。
786
- * @return {this}
787
- */
788
- isZankoku(bool = true) {
789
- if (bool) {
790
- this.set({ iszankoku: BooleanNumber.True });
791
- } else {
792
- this.set({ notzankoku: BooleanNumber.True });
793
- }
794
- return this;
795
- }
796
- /**
797
- * 異世界転生作品を抽出または除外します (istensei/nottensei)。
798
- * @param bool trueの場合、異世界転生作品を抽出する (デフォルト: true)。falseの場合、除外する。
799
- * @return {this}
800
- */
801
- isTensei(bool = true) {
802
- if (bool) {
803
- this.set({ istensei: BooleanNumber.True });
804
- } else {
805
- this.set({ nottensei: BooleanNumber.True });
806
- }
807
- return this;
808
- }
809
- /**
810
- * 異世界転移作品を抽出または除外します (istenni/nottenni)。
811
- * @param bool trueの場合、異世界転移作品を抽出する (デフォルト: true)。falseの場合、除外する。
812
- * @return {this}
813
- */
814
- isTenni(bool = true) {
815
- if (bool) {
816
- this.set({ istenni: BooleanNumber.True });
817
- } else {
818
- this.set({ nottenni: BooleanNumber.True });
819
- }
820
- return this;
821
- }
822
- /**
823
- * 異世界転生または異世界転移作品を抽出します (istt)。
824
- * @return {this}
825
- */
826
- isTT() {
827
- this.set({ istt: BooleanNumber.True });
828
- return this;
829
- }
830
- /**
831
- * 抽出する作品の文字数を指定します (length)。
832
- * 範囲指定する場合は、最小文字数と最大文字数をハイフン(-)記号で区切ってください。
833
- * @param length 文字数、または[最小文字数, 最大文字数]
834
- * @return {this}
835
- */
836
- length(length) {
837
- this.set({ length: _NovelSearchBuilderBase.array2string(length) });
838
- return this;
839
- }
840
- kaiwaritu(min, max) {
841
- let n;
842
- if (max != null) {
843
- n = `${min}-${max}`;
844
- } else {
845
- n = min;
846
- }
847
- this.set({ kaiwaritu: n });
848
- return this;
849
- }
850
- /**
851
- * 抽出する作品の挿絵数を指定します (sasie)。
852
- * @param num 挿絵数、または[最小挿絵数, 最大挿絵数]
853
- * @return {this}
854
- */
855
- sasie(num) {
856
- this.set({ sasie: _NovelSearchBuilderBase.array2string(num) });
857
- return this;
858
- }
859
- /**
860
- * 抽出する作品の予想読了時間を分単位で指定します (time)。
861
- * @param num 読了時間(分)、または[最小読了時間, 最大読了時間]
862
- * @return {this}
863
- */
864
- time(num) {
865
- this.set({ time: _NovelSearchBuilderBase.array2string(num) });
866
- return this;
867
- }
868
- /**
869
- * Nコードを指定して取得します (ncode)。
870
- * @param ncodes Nコード、またはNコードの配列
871
- * @return {this}
872
- */
873
- ncode(ncodes) {
874
- this.set({ ncode: _NovelSearchBuilderBase.array2string(ncodes) });
875
- return this;
876
- }
877
- /**
878
- * 抽出する小説タイプを指定します (type)。
879
- * @param type 小説タイプ (t: 短編, r: 連載中, er: 完結済連載小説, ter: 短編と完結済連載小説, re: 連載中と完結済連載小説)
880
- * @return {this}
881
- */
882
- type(type) {
883
- this.set({ type });
884
- return this;
885
- }
886
- /**
887
- * 抽出する作品の文体を指定します (buntai)。
888
- * 複数指定する場合はハイフン(-)で区切ってください。
889
- * @param buntai 文体コード、または文体コードの配列
890
- * @return {this}
891
- */
892
- buntai(buntai) {
893
- this.set({ buntai: _NovelSearchBuilderBase.array2string(buntai) });
894
- return this;
895
- }
896
- /**
897
- * 連載停止中作品に関する指定をします (stop)。
898
- * @param bool trueの場合、長期連載停止中のみ取得する (デフォルト: true)。falseの場合、長期連載停止中を除外する。
899
- * @return {this}
900
- */
901
- isStop(bool = true) {
902
- this.set({ stop: bool ? StopParam.Stopping : StopParam.NoStopping });
903
- return this;
904
- }
905
- /**
906
- * ピックアップ作品のみを取得します (ispickup)。
907
- * @return {this}
908
- */
909
- isPickup() {
910
- this.set({ ispickup: BooleanNumber.True });
911
- return this;
912
- }
913
- lastUpdate(x, y) {
914
- let date;
915
- if (typeof x == "string") {
916
- date = x;
917
- } else if (x instanceof Date && y instanceof Date) {
918
- date = `${Math.floor(x.getTime() / 1e3)}-${Math.floor(
919
- y.getTime() / 1e3
920
- )}`;
921
- } else {
922
- date = `${x}-${y}`;
923
- }
924
- this.set({ lastup: date });
925
- return this;
926
- }
927
- lastNovelUpdate(x, y) {
928
- let date;
929
- if (typeof x == "string") {
930
- date = x;
931
- } else if (x instanceof Date && y instanceof Date) {
932
- date = `${Math.floor(x.getTime() / 1e3)}-${Math.floor(
933
- y.getTime() / 1e3
934
- )}`;
935
- } else {
936
- date = `${x}-${y}`;
937
- }
938
- this.set({ lastupdate: date });
939
- return this;
940
- }
941
- /**
942
- * なろう小説APIへの検索リクエストを実行する
943
- * @returns {Promise<NarouSearchResults>} 検索結果
944
- */
945
- execute() {
946
- return this.api.executeNovel(this.params);
947
- }
948
- };
949
- var SearchBuilder = class _SearchBuilder extends NovelSearchBuilderBase {
950
- /**
951
- * 大ジャンルを指定して取得します (biggenre)。
952
- * 複数指定する場合はハイフン(-)で区切ってください。
953
- * @param genre 大ジャンルコード、または大ジャンルコードの配列
954
- * @return {this}
955
- */
956
- bigGenre(genre) {
957
- this.set({ biggenre: _SearchBuilder.array2string(genre) });
958
- return this;
959
- }
960
- /**
961
- * 除外したい大ジャンルを指定します (notbiggenre)。
962
- * 複数指定する場合はハイフン(-)で区切ってください。
963
- * @param genre 除外する大ジャンルコード、または大ジャンルコードの配列
964
- * @return {this}
965
- */
966
- notBigGenre(genre) {
967
- this.set({ notbiggenre: _SearchBuilder.array2string(genre) });
968
- return this;
969
- }
970
- /**
971
- * ジャンルを指定して取得します (genre)。
972
- * 複数指定する場合はハイフン(-)で区切ってください。
973
- * @param genre ジャンルコード、またはジャンルコードの配列
974
- * @return {this}
975
- */
976
- genre(genre) {
977
- this.set({ genre: _SearchBuilder.array2string(genre) });
978
- return this;
979
- }
980
- /**
981
- * 除外したいジャンルを指定します (notgenre)。
982
- * 複数指定する場合はハイフン(-)で区切ってください。
983
- * @param genre 除外するジャンルコード、またはジャンルコードの配列
984
- * @return {this}
985
- */
986
- notGenre(genre) {
987
- this.set({ notgenre: _SearchBuilder.array2string(genre) });
988
- return this;
989
- }
990
- /**
991
- * ユーザIDを指定して取得します (userid)。
992
- * 複数指定する場合はハイフン(-)で区切ってください。
993
- * @param ids ユーザID、またはユーザIDの配列
994
- * @return {this}
995
- */
996
- userId(ids) {
997
- this.set({ userid: _SearchBuilder.array2string(ids) });
998
- return this;
999
- }
1000
- /**
1001
- * R15作品を抽出または除外します (isr15/notr15)。
1002
- * @param bool trueの場合、R15作品を抽出する (デフォルト: true)。falseの場合、除外する。
1003
- * @return {this}
1004
- */
1005
- isR15(bool = true) {
1006
- if (bool) {
1007
- this.set({ isr15: 1 });
1008
- } else {
1009
- this.set({ notr15: 1 });
1010
- }
1011
- return this;
1012
- }
1013
- /**
1014
- * 出力する項目を個別に指定します (of)。
1015
- * 未指定時は全項目出力されます。転送量軽減のため、このパラメータの使用が推奨されます。
1016
- * 複数項目を出力する場合はハイフン(-)記号で区切ってください。
1017
- * @param fields 出力するフィールド名、またはフィールド名の配列
1018
- * @return {SearchBuilder<SearchResultFields<TFields>, TOpt>} 型が更新されたビルダー
1019
- */
1020
- fields(fields) {
1021
- this.set({ of: _SearchBuilder.array2string(fields) });
1022
- return this;
1023
- }
1024
- /**
1025
- * 出力オプション項目を指定します (opt)。
1026
- * 複数項目を出力する場合はハイフン(-)記号で区切ってください。
1027
- * @param option 出力するオプションフィールド名、またはオプションフィールド名の配列
1028
- * @return {SearchBuilder<T, SearchResultOptionalFields<TFields>>} 型が更新されたビルダー
1029
- */
1030
- opt(option) {
1031
- this.set({ opt: _SearchBuilder.array2string(option) });
1032
- return this;
1033
- }
1034
- };
1
+ Object.defineProperty(exports, '__esModule', { value: true });
2
+ const require_index_common = require('./index.common-CYj0n0aU.cjs');
1035
3
 
1036
- // src/search-builder-r18.ts
1037
- var SearchBuilderR18 = class extends NovelSearchBuilderBase {
1038
- /**
1039
- * なろう小説APIへの検索リクエストを実行する
1040
- * @override
1041
- * @returns {Promise<NarouSearchResults>} 検索結果
1042
- */
1043
- execute() {
1044
- return this.api.executeNovel18(this.params);
1045
- }
1046
- /**
1047
- * 抽出するR18サイトを指定します (nocgenre)。
1048
- * @param sites R18サイトコード、またはR18サイトコードの配列 (1: ノクターンノベルズ, 2: ムーンライトノベルズ(男性向け), 3: ムーンライトノベルズ(BL), 4: ミッドナイトノベルズ)
1049
- * @return {this}
1050
- */
1051
- r18Site(sites) {
1052
- this.set({ nocgenre: NovelSearchBuilderBase.array2string(sites) });
1053
- return this;
1054
- }
1055
- /**
1056
- * X-IDを指定して取得します (xid)。
1057
- * @param ids X-ID、またはX-IDの配列
1058
- * @return {this}
1059
- */
1060
- xid(ids) {
1061
- this.set({ xid: NovelSearchBuilderBase.array2string(ids) });
1062
- return this;
1063
- }
1064
- /**
1065
- * 出力する項目を個別に指定します (of)。
1066
- * 未指定時は全項目出力されます。転送量軽減のため、このパラメータの使用が推奨されます。
1067
- * @param fields 出力するR18フィールド名、またはR18フィールド名の配列
1068
- * @return {SearchBuilderR18<SearchResultR18Fields<R18Fields>>} 型が更新されたビルダー
1069
- */
1070
- fields(fields) {
1071
- this.set({ of: NovelSearchBuilderBase.array2string(fields) });
1072
- return this;
1073
- }
1074
- /**
1075
- * 出力オプション項目を指定します (opt)。
1076
- * @param option 出力するオプションフィールド名、またはオプションフィールド名の配列
1077
- * @return {SearchBuilderR18<T, SearchResultOptionalFields<TFields>>} 型が更新されたビルダー
1078
- */
1079
- opt(option) {
1080
- this.set({ opt: NovelSearchBuilderBase.array2string(option) });
1081
- return this;
1082
- }
1083
- };
1084
-
1085
- // src/util/date.ts
1086
- function parseDate(dateStr) {
1087
- const year = parseInt(dateStr.substring(0, 4), 10);
1088
- const month = parseInt(dateStr.substring(4, 6), 10) - 1;
1089
- const day = parseInt(dateStr.substring(6, 8), 10);
1090
- return new Date(year, month, day, 0, 0, 0, 0);
1091
- }
1092
- function formatDate(date) {
1093
- const year = date.getFullYear();
1094
- const month = String(date.getMonth() + 1).padStart(2, "0");
1095
- const day = String(date.getDate()).padStart(2, "0");
1096
- return `${year}${month}${day}`;
1097
- }
1098
- function addDays(date, days) {
1099
- const result = new Date(date);
1100
- result.setDate(result.getDate() + days);
1101
- return result;
1102
- }
1103
-
1104
- // src/ranking.ts
1105
- var RankingBuilder = class {
1106
- /**
1107
- * constructor
1108
- * @param params - 初期クエリパラメータ
1109
- * @param api - API実行クラスのインスタンス
1110
- * @private
1111
- */
1112
- constructor(params = {}, api) {
1113
- this.params = params;
1114
- this.api = api;
1115
- this.date$ = addDays(/* @__PURE__ */ new Date(), -1);
1116
- this.type$ = RankingType.Daily;
1117
- }
1118
- /**
1119
- * ランキング集計対象の日付を指定します。
1120
- *
1121
- * - 日間: 任意の日付
1122
- * - 週間: 火曜日の日付
1123
- * - 月間・四半期: 1日の日付
1124
- *
1125
- * @param date 集計対象の日付
1126
- * @returns {RankingBuilder} this
1127
- * @see https://dev.syosetu.com/man/rankapi/
1128
- */
1129
- date(date) {
1130
- this.date$ = date;
1131
- return this;
1132
- }
1133
- /**
1134
- * ランキング種別を指定します。
1135
- * @param type ランキング種別
1136
- * @returns {RankingBuilder} this
1137
- * @see https://dev.syosetu.com/man/rankapi/
1138
- */
1139
- type(type) {
1140
- this.type$ = type;
1141
- return this;
1142
- }
1143
- /**
1144
- * gzip圧縮する。
1145
- *
1146
- * 転送量上限を減らすためにも推奨
1147
- * @param {GzipLevel} level gzip圧縮レベル(1~5)
1148
- * @return {RankingBuilder} this
1149
- */
1150
- gzip(level) {
1151
- this.set({ gzip: level });
1152
- return this;
1153
- }
1154
- /**
1155
- * クエリパラメータを内部的にセットします。
1156
- * @param obj - セットするパラメータオブジェクト
1157
- * @returns {RankingBuilder} this
1158
- * @private
1159
- */
1160
- set(obj) {
1161
- Object.assign(this.params, obj);
1162
- return this;
1163
- }
1164
- /**
1165
- * 設定されたパラメータに基づき、なろう小説ランキングAPIへのリクエストを実行します。
1166
- *
1167
- * 返される結果には、Nコード、ポイント、順位が含まれます。
1168
- * @returns {Promise<NarouRankingResult[]>} ランキング結果の配列
1169
- * @see https://dev.syosetu.com/man/rankapi/#output
1170
- */
1171
- execute() {
1172
- const date = formatDate(this.date$);
1173
- this.set({ rtype: `${date}-${this.type$}` });
1174
- return this.api.executeRanking(this.params);
1175
- }
1176
- /**
1177
- * ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。
1178
- *
1179
- * @template TFields - 取得する小説情報のフィールド型
1180
- * @template TOpt - オプショナルな取得フィールドの型
1181
- * @param fields - 取得するフィールドの配列 (省略時はデフォルトフィールド)
1182
- * @param opt - オプショナルな取得フィールド (`weekly` など)
1183
- * @returns {Promise<RankingResult<SearchResultFields<TFields>>[]>} 詳細情報を含むランキング結果の配列
1184
- */
1185
- async executeWithFields(fields = [], opt) {
1186
- const ranking2 = await this.execute();
1187
- const fields$ = Array.isArray(fields) ? fields.length == 0 ? [] : [...fields, Fields.ncode] : [fields, Fields.ncode];
1188
- const rankingNcodes = ranking2.map(({ ncode }) => ncode);
1189
- const builder = new SearchBuilder({}, this.api);
1190
- builder.fields(fields$);
1191
- if (opt) {
1192
- builder.opt(opt);
1193
- }
1194
- builder.ncode(rankingNcodes);
1195
- builder.limit(ranking2.length);
1196
- const result = await builder.execute();
1197
- return ranking2.map((r) => ({
1198
- ...r,
1199
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1200
- ...result.values.find((novel) => novel.ncode == r.ncode)
1201
- }));
1202
- }
1203
- };
1204
-
1205
- // src/ranking-history.ts
1206
- function formatRankingHistory(rankin) {
1207
- const { rtype, pt, rank } = rankin;
1208
- const [_date, _type] = rtype.split("-");
1209
- const date = parseDate(_date);
1210
- const type = _type;
1211
- return { type, date, pt, rank };
1212
- }
1213
-
1214
- // src/user-search.ts
1215
- var UserSearchBuilder = class _UserSearchBuilder extends SearchBuilderBase {
1216
- /**
1217
- * 単語を指定できます。
1218
- * 半角または全角スペースで区切るとAND抽出になります。
1219
- * 部分一致でHITします。検索の対象はユーザ名とユーザ名のフリガナです。
1220
- */
1221
- word(word) {
1222
- this.set({ word });
1223
- return this;
1224
- }
1225
- /**
1226
- * 含みたくない単語を指定できます。
1227
- * スペースで区切ることにより含ませない単語を増やせます。部分一致で除外されます。
1228
- * 除外の対象はユーザ名とユーザ名のフリガナです。
1229
- */
1230
- notWord(notword) {
1231
- this.set({ notword });
1232
- return this;
1233
- }
1234
- /**
1235
- * ユーザIDで抽出可能。
1236
- */
1237
- userId(userid) {
1238
- this.set({ userid });
1239
- return this;
1240
- }
1241
- /**
1242
- * 抽出するユーザのユーザ名のフリガナの頭文字を指定できます。
1243
- * 頭文字はユーザ名のフリガナをひらがなに変換し、最初の1文字が「ぁ」~「ん」の場合に対象となります。
1244
- * 「ぱ」や「ば」等の半濁音や濁音は清音として扱われます。
1245
- * 漢字や英数字が頭文字のユーザは対象外です。
1246
- */
1247
- name1st(name1st) {
1248
- this.set({ name1st });
1249
- return this;
1250
- }
1251
- /**
1252
- * 抽出するユーザの小説投稿数の下限を指定できます。
1253
- * 小説投稿件数が指定された数値以上のユーザを抽出します。
1254
- */
1255
- minNovel(minnovel) {
1256
- this.set({ minnovel });
1257
- return this;
1258
- }
1259
- /**
1260
- * 抽出するユーザの小説投稿数の上限を指定できます。
1261
- * 小説投稿件数が指定された数値以下のユーザを抽出します。
1262
- */
1263
- maxNovel(maxnovel) {
1264
- this.set({ maxnovel });
1265
- return this;
1266
- }
1267
- /**
1268
- * 抽出するユーザのレビュー投稿数の下限を指定できます。
1269
- * レビュー投稿件数が指定された数値以上のユーザを抽出します。
1270
- */
1271
- minReview(minreview) {
1272
- this.set({ minreview });
1273
- return this;
1274
- }
1275
- /**
1276
- * 抽出するユーザのレビュー投稿数の上限を指定できます。
1277
- * レビュー投稿件数が指定された数値以下のユーザを抽出します。
1278
- */
1279
- maxReview(maxreview) {
1280
- this.set({ maxreview });
1281
- return this;
1282
- }
1283
- /**
1284
- * 出力する項目を個別に指定できます。未指定時は全項目出力されます。転送量軽減のため、このパラメータの使用が推奨されます。
1285
- * @return {SearchBuilder} this
1286
- */
1287
- fields(fields) {
1288
- this.set({ of: _UserSearchBuilder.array2string(fields) });
1289
- return this;
1290
- }
1291
- /**
1292
- * なろう小説APIへのリクエストを実行する
1293
- * @returns ランキング
1294
- */
1295
- execute() {
1296
- return this.api.executeUserSearch(this.params);
1297
- }
1298
- };
1299
-
1300
- // src/index.browser.ts
1301
- var narouNovelJsonp = new NarouNovelJsonp();
4
+ //#region src/index.browser.ts
5
+ const narouNovelJsonp = new require_index_common.NarouNovelJsonp();
6
+ /**
7
+ * なろう小説 API で小説を検索する
8
+ * @param {string} [word] 検索ワード
9
+ * @returns {SearchBuilder}
10
+ * @see https://dev.syosetu.com/man/api/
11
+ */
1302
12
  function search(word = "", api = narouNovelJsonp) {
1303
- const builder = new SearchBuilder({}, api);
1304
- if (word != "") builder.word(word);
1305
- return builder;
13
+ const builder = new require_index_common.SearchBuilder({}, api);
14
+ if (word != "") builder.word(word);
15
+ return builder;
1306
16
  }
17
+ /**
18
+ * 18禁小説 API で小説を検索する
19
+ * @param {string} [word] 検索ワード
20
+ * @returns {SearchBuilder}
21
+ * @see https://dev.syosetu.com/xman/api/
22
+ */
1307
23
  function searchR18(word = "", api = narouNovelJsonp) {
1308
- const builder = new SearchBuilderR18({}, api);
1309
- if (word != "") builder.word(word);
1310
- return builder;
24
+ const builder = new require_index_common.SearchBuilderR18({}, api);
25
+ if (word != "") builder.word(word);
26
+ return builder;
1311
27
  }
28
+ /**
29
+ * なろうユーザ検索 API でユーザを検索する
30
+ * @param {string} [word] - 検索ワード
31
+ * @returns {UserSearchBuilder}
32
+ * @see https://dev.syosetu.com/man/userapi/
33
+ */
1312
34
  function searchUser(word = "", api = narouNovelJsonp) {
1313
- const builder = new UserSearchBuilder({}, api);
1314
- if (word != "") builder.word(word);
1315
- return builder;
35
+ const builder = new require_index_common.UserSearchBuilder({}, api);
36
+ if (word != "") builder.word(word);
37
+ return builder;
1316
38
  }
39
+ /**
40
+ * なろう小説ランキング API でランキングを取得する
41
+ * @returns {RankingBuilder}
42
+ * @see https://dev.syosetu.com/man/rankapi/
43
+ */
1317
44
  function ranking(api = narouNovelJsonp) {
1318
- const builder = new RankingBuilder({}, api);
1319
- return builder;
45
+ return new require_index_common.RankingBuilder({}, api);
1320
46
  }
1321
- async function rankingHistory(ncode, api = narouNovelJsonp) {
1322
- const result = await api.executeRankingHistory({ ncode });
1323
- if (Array.isArray(result)) {
1324
- return result.map(formatRankingHistory);
1325
- } else {
1326
- throw new Error(result);
1327
- }
47
+ /**
48
+ * なろう殿堂入り API でランキング履歴を取得する
49
+ * @param {string} ncode 小説のNコード
50
+ * @param {ExecuteOptions} [options] 実行オプション
51
+ * @param {NarouNovel} [api] API実行クラスのインスタンス
52
+ * @see https://dev.syosetu.com/man/rankinapi/
53
+ */
54
+ async function rankingHistory(ncode, options, api = narouNovelJsonp) {
55
+ const result = await api.executeRankingHistory({ ncode }, options);
56
+ if (Array.isArray(result)) return result.map(require_index_common.formatRankingHistory);
57
+ else throw new Error(result);
1328
58
  }
1329
59
  var index_browser_default = {
1330
- search,
1331
- searchR18,
1332
- searchUser,
1333
- ranking,
1334
- rankingHistory
60
+ search,
61
+ searchR18,
62
+ searchUser,
63
+ ranking,
64
+ rankingHistory
1335
65
  };
1336
- // Annotate the CommonJS export names for ESM import in node:
1337
- 0 && (module.exports = {
1338
- BigGenre,
1339
- BigGenreNotation,
1340
- BooleanNumber,
1341
- BuntaiParam,
1342
- DateParam,
1343
- End,
1344
- Fields,
1345
- Genre,
1346
- GenreNotation,
1347
- NarouNovel,
1348
- NarouNovelJsonp,
1349
- NarouSearchResults,
1350
- NovelSearchBuilderBase,
1351
- NovelType,
1352
- NovelTypeParam,
1353
- OptionalFields,
1354
- Order,
1355
- R18Fields,
1356
- R18Site,
1357
- R18SiteNotation,
1358
- RankingBuilder,
1359
- RankingType,
1360
- SearchBuilder,
1361
- SearchBuilderBase,
1362
- SearchBuilderR18,
1363
- StopParam,
1364
- UserFields,
1365
- UserOrder,
1366
- formatRankingHistory,
1367
- ranking,
1368
- rankingHistory,
1369
- search,
1370
- searchR18,
1371
- searchUser
1372
- });
66
+
67
+ //#endregion
68
+ exports.BigGenre = require_index_common.BigGenre;
69
+ exports.BigGenreNotation = require_index_common.BigGenreNotation;
70
+ exports.BooleanNumber = require_index_common.BooleanNumber;
71
+ exports.BuntaiParam = require_index_common.BuntaiParam;
72
+ exports.DateParam = require_index_common.DateParam;
73
+ exports.End = require_index_common.End;
74
+ exports.Fields = require_index_common.Fields;
75
+ exports.Genre = require_index_common.Genre;
76
+ exports.GenreNotation = require_index_common.GenreNotation;
77
+ exports.NarouNovel = require_index_common.NarouNovel;
78
+ exports.NarouNovelJsonp = require_index_common.NarouNovelJsonp;
79
+ exports.NarouSearchResults = require_index_common.NarouSearchResults;
80
+ exports.NovelSearchBuilderBase = require_index_common.NovelSearchBuilderBase;
81
+ exports.NovelType = require_index_common.NovelType;
82
+ exports.NovelTypeParam = require_index_common.NovelTypeParam;
83
+ exports.OptionalFields = require_index_common.OptionalFields;
84
+ exports.Order = require_index_common.Order;
85
+ exports.R18Fields = require_index_common.R18Fields;
86
+ exports.R18Site = require_index_common.R18Site;
87
+ exports.R18SiteNotation = require_index_common.R18SiteNotation;
88
+ exports.RankingBuilder = require_index_common.RankingBuilder;
89
+ exports.RankingType = require_index_common.RankingType;
90
+ exports.SearchBuilder = require_index_common.SearchBuilder;
91
+ exports.SearchBuilderBase = require_index_common.SearchBuilderBase;
92
+ exports.SearchBuilderR18 = require_index_common.SearchBuilderR18;
93
+ exports.StopParam = require_index_common.StopParam;
94
+ exports.UserFields = require_index_common.UserFields;
95
+ exports.UserOrder = require_index_common.UserOrder;
96
+ exports.default = index_browser_default;
97
+ exports.formatRankingHistory = require_index_common.formatRankingHistory;
98
+ exports.ranking = ranking;
99
+ exports.rankingHistory = rankingHistory;
100
+ exports.search = search;
101
+ exports.searchR18 = searchR18;
102
+ exports.searchUser = searchUser;
1373
103
  //# sourceMappingURL=index.browser.cjs.map