narou 1.0.0 → 1.2.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.
- package/README.md +7 -0
- package/dist/{chunk-RITMMCZE.js → chunk-3A5MHPWL.js} +1 -1
- package/dist/chunk-3A5MHPWL.js.map +1 -0
- package/dist/{chunk-6RIDVTFQ.js → chunk-5UDKQCPJ.js} +12 -2
- package/dist/chunk-5UDKQCPJ.js.map +1 -0
- package/dist/{chunk-UN3W2CT3.js → chunk-6BZWV4ZC.js} +6 -3
- package/dist/{chunk-UN3W2CT3.js.map → chunk-6BZWV4ZC.js.map} +1 -1
- package/dist/chunk-BQLSW236.js +117 -0
- package/dist/chunk-BQLSW236.js.map +1 -0
- package/dist/{chunk-DBCAWGIX.js → chunk-DEQICAN3.js} +2 -2
- package/dist/chunk-E2H3AJSQ.js +57 -0
- package/dist/chunk-E2H3AJSQ.js.map +1 -0
- package/dist/chunk-HOBLKBZ6.js +452 -0
- package/dist/chunk-HOBLKBZ6.js.map +1 -0
- package/dist/{chunk-TNDGN3EF.js → chunk-IPDEGCWU.js} +1 -1
- package/dist/chunk-IPDEGCWU.js.map +1 -0
- package/dist/{chunk-GAEL5UWA.js → chunk-LQLNWSWV.js} +4 -4
- package/dist/{chunk-GAEL5UWA.js.map → chunk-LQLNWSWV.js.map} +1 -1
- package/dist/{chunk-NP5NZV5Q.js → chunk-PLEM2AOH.js} +8 -5
- package/dist/chunk-PLEM2AOH.js.map +1 -0
- package/dist/chunk-RNHRR56W.js +25 -0
- package/dist/chunk-RNHRR56W.js.map +1 -0
- package/dist/{chunk-JMTNQTNC.js → chunk-VUZIISP2.js} +2 -3
- package/dist/chunk-VUZIISP2.js.map +1 -0
- package/dist/{chunk-XAUB42TO.js → chunk-VZVUANDN.js} +6 -4
- package/dist/chunk-VZVUANDN.js.map +1 -0
- package/dist/index.browser.cjs +245 -94
- package/dist/index.browser.cjs.map +1 -1
- package/dist/index.browser.d.cts +24 -9
- package/dist/index.browser.d.ts +24 -9
- package/dist/index.browser.js +16 -16
- package/dist/index.browser.js.map +1 -1
- package/dist/index.cjs +256 -103
- package/dist/index.cjs.map +1 -1
- package/dist/index.common.cjs +241 -87
- package/dist/index.common.cjs.map +1 -1
- package/dist/index.common.d.cts +2 -2
- package/dist/index.common.d.ts +2 -2
- package/dist/index.common.js +11 -8
- package/dist/index.d.cts +15 -6
- package/dist/index.d.ts +15 -6
- package/dist/index.js +20 -20
- package/dist/index.js.map +1 -1
- package/dist/narou-DBa12V_l.d.ts +404 -0
- package/dist/narou-DCp4aGfA.d.cts +404 -0
- package/dist/narou-fetch.cjs +10 -5
- package/dist/narou-fetch.cjs.map +1 -1
- package/dist/narou-fetch.d.cts +4 -3
- package/dist/narou-fetch.d.ts +4 -3
- package/dist/narou-fetch.js +4 -4
- package/dist/narou-jsonp.cjs +5 -2
- package/dist/narou-jsonp.cjs.map +1 -1
- package/dist/narou-jsonp.d.cts +2 -2
- package/dist/narou-jsonp.d.ts +2 -2
- package/dist/narou-jsonp.js +4 -4
- package/dist/narou-ranking-results.d.cts +2 -2
- package/dist/narou-ranking-results.d.ts +2 -2
- package/dist/{narou-search-results-D_vbjc_I.d.cts → narou-search-results-C21hWrnL.d.cts} +30 -19
- package/dist/{narou-search-results-CvMcnYqe.d.ts → narou-search-results-DT0YdaBn.d.ts} +30 -19
- package/dist/narou-search-results.cjs.map +1 -1
- package/dist/narou-search-results.d.cts +1 -1
- package/dist/narou-search-results.d.ts +1 -1
- package/dist/narou-search-results.js +1 -1
- package/dist/narou.cjs +4 -1
- package/dist/narou.cjs.map +1 -1
- package/dist/narou.d.cts +2 -2
- package/dist/narou.d.ts +2 -2
- package/dist/narou.js +2 -2
- package/dist/params.cjs +12 -1
- package/dist/params.cjs.map +1 -1
- package/dist/params.d.cts +1 -1
- package/dist/params.d.ts +1 -1
- package/dist/params.js +3 -1
- package/dist/ranking-history.cjs +11 -3
- package/dist/ranking-history.cjs.map +1 -1
- package/dist/ranking-history.d.cts +12 -1
- package/dist/ranking-history.d.ts +12 -1
- package/dist/ranking-history.js +2 -1
- package/dist/ranking.cjs +201 -78
- package/dist/ranking.cjs.map +1 -1
- package/dist/ranking.d.cts +70 -9
- package/dist/ranking.d.ts +70 -9
- package/dist/ranking.js +4 -3
- package/dist/search-builder-r18.cjs +133 -60
- package/dist/search-builder-r18.cjs.map +1 -1
- package/dist/search-builder-r18.d.cts +19 -6
- package/dist/search-builder-r18.d.ts +19 -6
- package/dist/search-builder-r18.js +3 -3
- package/dist/search-builder.cjs +150 -70
- package/dist/search-builder.cjs.map +1 -1
- package/dist/search-builder.d.cts +2 -2
- package/dist/search-builder.d.ts +2 -2
- package/dist/search-builder.js +2 -2
- package/dist/user-search.cjs +37 -13
- package/dist/user-search.cjs.map +1 -1
- package/dist/user-search.d.cts +2 -2
- package/dist/user-search.d.ts +2 -2
- package/dist/user-search.js +3 -3
- package/dist/util/date.cjs +51 -0
- package/dist/util/date.cjs.map +1 -0
- package/dist/util/date.d.cts +21 -0
- package/dist/util/date.d.ts +21 -0
- package/dist/util/date.js +11 -0
- package/dist/util/date.js.map +1 -0
- package/dist/util/jsonp.cjs.map +1 -1
- package/dist/util/jsonp.d.cts +36 -0
- package/dist/util/jsonp.d.ts +36 -0
- package/dist/util/jsonp.js +1 -1
- package/dist/util/type.cjs.map +1 -1
- package/dist/util/type.d.cts +23 -0
- package/dist/util/type.d.ts +23 -0
- package/dist/util/unzipp.cjs +1 -2
- package/dist/util/unzipp.cjs.map +1 -1
- package/dist/util/unzipp.d.cts +9 -0
- package/dist/util/unzipp.d.ts +9 -0
- package/dist/util/unzipp.js +1 -1
- package/package.json +47 -46
- package/pnpm-lock.yaml +3041 -0
- package/src/index.browser.ts +21 -5
- package/src/index.ts +11 -2
- package/src/narou-fetch.ts +5 -2
- package/src/narou-jsonp.ts +1 -1
- package/src/narou-search-results.ts +2 -1
- package/src/narou.ts +4 -1
- package/src/params.ts +34 -18
- package/src/ranking-history.ts +13 -4
- package/src/ranking.ts +79 -15
- package/src/search-builder-r18.ts +17 -4
- package/src/search-builder.ts +203 -79
- package/src/util/date.ts +38 -0
- package/src/util/jsonp.ts +61 -6
- package/src/util/type.ts +23 -0
- package/src/util/unzipp.ts +9 -0
- package/dist/chunk-6RIDVTFQ.js.map +0 -1
- package/dist/chunk-JMTNQTNC.js.map +0 -1
- package/dist/chunk-NP5NZV5Q.js.map +0 -1
- package/dist/chunk-OJGRUQEQ.js +0 -372
- package/dist/chunk-OJGRUQEQ.js.map +0 -1
- package/dist/chunk-QQYQ4GQF.js +0 -83
- package/dist/chunk-QQYQ4GQF.js.map +0 -1
- package/dist/chunk-RITMMCZE.js.map +0 -1
- package/dist/chunk-TNDGN3EF.js.map +0 -1
- package/dist/chunk-XAUB42TO.js.map +0 -1
- package/dist/chunk-YJQXIVFD.js +0 -44
- package/dist/chunk-YJQXIVFD.js.map +0 -1
- package/dist/narou-CosGR0J9.d.cts +0 -298
- package/dist/narou-CutsOEgk.d.ts +0 -298
- /package/dist/{chunk-DBCAWGIX.js.map → chunk-DEQICAN3.js.map} +0 -0
|
@@ -146,14 +146,30 @@ var SearchBuilderBase = class {
|
|
|
146
146
|
/**
|
|
147
147
|
* constructor
|
|
148
148
|
* @private
|
|
149
|
+
* @param params クエリパラメータ
|
|
150
|
+
* @param api NarouNovel インスタンス
|
|
149
151
|
*/
|
|
150
152
|
constructor(params = {}, api) {
|
|
151
153
|
this.params = params;
|
|
152
154
|
this.api = api;
|
|
153
155
|
}
|
|
156
|
+
/**
|
|
157
|
+
* 配列から重複を除去する
|
|
158
|
+
* @protected
|
|
159
|
+
* @static
|
|
160
|
+
* @param array 配列
|
|
161
|
+
* @returns 重複を除去した配列
|
|
162
|
+
*/
|
|
154
163
|
static distinct(array) {
|
|
155
164
|
return Array.from(new Set(array));
|
|
156
165
|
}
|
|
166
|
+
/**
|
|
167
|
+
* 配列をハイフン区切りの文字列に変換する
|
|
168
|
+
* @protected
|
|
169
|
+
* @static
|
|
170
|
+
* @param n 文字列または数値の配列、あるいは単一の文字列または数値
|
|
171
|
+
* @returns ハイフン区切りの文字列
|
|
172
|
+
*/
|
|
157
173
|
static array2string(n) {
|
|
158
174
|
if (Array.isArray(n)) {
|
|
159
175
|
return this.distinct(n).join("-");
|
|
@@ -162,44 +178,48 @@ var SearchBuilderBase = class {
|
|
|
162
178
|
}
|
|
163
179
|
}
|
|
164
180
|
/**
|
|
165
|
-
*
|
|
166
|
-
* @
|
|
181
|
+
* 取得件数を指定する (lim)
|
|
182
|
+
* @param num 取得件数 (1-500)
|
|
183
|
+
* @return {this}
|
|
167
184
|
*/
|
|
168
185
|
limit(num) {
|
|
169
186
|
this.set({ lim: num });
|
|
170
187
|
return this;
|
|
171
188
|
}
|
|
172
189
|
/**
|
|
173
|
-
*
|
|
174
|
-
* @
|
|
190
|
+
* 取得開始位置を指定する (st)
|
|
191
|
+
* @param num 取得開始位置 (1-)
|
|
192
|
+
* @return {this}
|
|
175
193
|
*/
|
|
176
194
|
start(num) {
|
|
177
195
|
this.set({ st: num });
|
|
178
196
|
return this;
|
|
179
197
|
}
|
|
180
198
|
/**
|
|
181
|
-
*
|
|
182
|
-
* @
|
|
199
|
+
* ページ番号と1ページあたりの件数で取得範囲を指定する
|
|
200
|
+
* @param no ページ番号 (0-)
|
|
201
|
+
* @param count 1ページあたりの件数 (デフォルト: 20)
|
|
202
|
+
* @return {this}
|
|
183
203
|
*/
|
|
184
204
|
page(no, count = 20) {
|
|
185
205
|
return this.limit(count).start(no * count);
|
|
186
206
|
}
|
|
187
207
|
/**
|
|
188
|
-
*
|
|
189
|
-
*
|
|
208
|
+
* 出力順序を指定する (order)
|
|
209
|
+
* 指定しない場合は新着順となります。
|
|
190
210
|
* @param {TOrder} order 出力順序
|
|
191
|
-
* @return {
|
|
211
|
+
* @return {this}
|
|
192
212
|
*/
|
|
193
213
|
order(order) {
|
|
194
214
|
this.set({ order });
|
|
195
215
|
return this;
|
|
196
216
|
}
|
|
197
217
|
/**
|
|
198
|
-
* gzip
|
|
218
|
+
* gzip圧縮レベルを指定する (gzip)
|
|
199
219
|
*
|
|
200
220
|
* 転送量上限を減らすためにも推奨
|
|
201
221
|
* @param {GzipLevel} level gzip圧縮レベル(1~5)
|
|
202
|
-
* @return {
|
|
222
|
+
* @return {this}
|
|
203
223
|
*/
|
|
204
224
|
gzip(level) {
|
|
205
225
|
this.set({ gzip: level });
|
|
@@ -207,8 +227,9 @@ var SearchBuilderBase = class {
|
|
|
207
227
|
}
|
|
208
228
|
/**
|
|
209
229
|
* クエリパラメータをセットする
|
|
210
|
-
* @
|
|
211
|
-
* @
|
|
230
|
+
* @protected
|
|
231
|
+
* @param obj セットするパラメータ
|
|
232
|
+
* @return {this}
|
|
212
233
|
*/
|
|
213
234
|
set(obj) {
|
|
214
235
|
this.params = { ...this.params, ...obj };
|
|
@@ -216,6 +237,9 @@ var SearchBuilderBase = class {
|
|
|
216
237
|
}
|
|
217
238
|
/**
|
|
218
239
|
* クエリパラメータを削除する
|
|
240
|
+
* @protected
|
|
241
|
+
* @param key 削除するパラメータのキー
|
|
242
|
+
* @returns {this}
|
|
219
243
|
*/
|
|
220
244
|
unset(key) {
|
|
221
245
|
delete this.params[key];
|
|
@@ -224,56 +248,65 @@ var SearchBuilderBase = class {
|
|
|
224
248
|
};
|
|
225
249
|
var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilderBase {
|
|
226
250
|
/**
|
|
227
|
-
*
|
|
228
|
-
*
|
|
251
|
+
* 検索語を指定します (word)。
|
|
252
|
+
* 半角または全角スペースで区切るとAND抽出になります。部分一致でHITします。
|
|
253
|
+
* @param word 検索語
|
|
254
|
+
* @return {this}
|
|
229
255
|
*/
|
|
230
256
|
word(word) {
|
|
231
257
|
this.set({ word });
|
|
232
258
|
return this;
|
|
233
259
|
}
|
|
234
260
|
/**
|
|
235
|
-
*
|
|
236
|
-
*
|
|
261
|
+
* 除外したい単語を指定します (notword)。
|
|
262
|
+
* スペースで区切ることにより除外する単語を増やせます。部分一致で除外されます。
|
|
263
|
+
* @param word 除外語
|
|
264
|
+
* @return {this}
|
|
237
265
|
*/
|
|
238
266
|
notWord(word) {
|
|
239
267
|
this.set({ notword: word });
|
|
240
268
|
return this;
|
|
241
269
|
}
|
|
242
270
|
/**
|
|
243
|
-
*
|
|
244
|
-
* @
|
|
271
|
+
* 検索対象を作品名に限定するかどうかを指定します (title)。
|
|
272
|
+
* @param bool trueの場合、作品名を検索対象とする (デフォルト: true)
|
|
273
|
+
* @return {this}
|
|
245
274
|
*/
|
|
246
275
|
byTitle(bool = true) {
|
|
247
276
|
this.set({ title: bool ? BooleanNumber.True : BooleanNumber.False });
|
|
248
277
|
return this;
|
|
249
278
|
}
|
|
250
279
|
/**
|
|
251
|
-
*
|
|
252
|
-
* @
|
|
280
|
+
* 検索対象をあらすじに限定するかどうかを指定します (ex)。
|
|
281
|
+
* @param bool trueの場合、あらすじを検索対象とする (デフォルト: true)
|
|
282
|
+
* @return {this}
|
|
253
283
|
*/
|
|
254
284
|
byOutline(bool = true) {
|
|
255
285
|
this.set({ ex: bool ? BooleanNumber.True : BooleanNumber.False });
|
|
256
286
|
return this;
|
|
257
287
|
}
|
|
258
288
|
/**
|
|
259
|
-
*
|
|
260
|
-
* @
|
|
289
|
+
* 検索対象をキーワードに限定するかどうかを指定します (keyword)。
|
|
290
|
+
* @param bool trueの場合、キーワードを検索対象とする (デフォルト: true)
|
|
291
|
+
* @return {this}
|
|
261
292
|
*/
|
|
262
293
|
byKeyword(bool = true) {
|
|
263
294
|
this.set({ keyword: bool ? BooleanNumber.True : BooleanNumber.False });
|
|
264
295
|
return this;
|
|
265
296
|
}
|
|
266
297
|
/**
|
|
267
|
-
*
|
|
268
|
-
* @
|
|
298
|
+
* 検索対象を作者名に限定するかどうかを指定します (wname)。
|
|
299
|
+
* @param bool trueの場合、作者名を検索対象とする (デフォルト: true)
|
|
300
|
+
* @return {this}
|
|
269
301
|
*/
|
|
270
302
|
byAuthor(bool = true) {
|
|
271
303
|
this.set({ wname: bool ? BooleanNumber.True : BooleanNumber.False });
|
|
272
304
|
return this;
|
|
273
305
|
}
|
|
274
306
|
/**
|
|
275
|
-
*
|
|
276
|
-
* @
|
|
307
|
+
* ボーイズラブ作品を抽出または除外します (isbl/notbl)。
|
|
308
|
+
* @param bool trueの場合、ボーイズラブ作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
309
|
+
* @return {this}
|
|
277
310
|
*/
|
|
278
311
|
isBL(bool = true) {
|
|
279
312
|
if (bool) {
|
|
@@ -284,8 +317,9 @@ var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilder
|
|
|
284
317
|
return this;
|
|
285
318
|
}
|
|
286
319
|
/**
|
|
287
|
-
*
|
|
288
|
-
* @
|
|
320
|
+
* ガールズラブ作品を抽出または除外します (isgl/notgl)。
|
|
321
|
+
* @param bool trueの場合、ガールズラブ作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
322
|
+
* @return {this}
|
|
289
323
|
*/
|
|
290
324
|
isGL(bool = true) {
|
|
291
325
|
if (bool) {
|
|
@@ -296,8 +330,9 @@ var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilder
|
|
|
296
330
|
return this;
|
|
297
331
|
}
|
|
298
332
|
/**
|
|
299
|
-
*
|
|
300
|
-
* @
|
|
333
|
+
* 残酷な描写あり作品を抽出または除外します (iszankoku/notzankoku)。
|
|
334
|
+
* @param bool trueの場合、残酷な描写あり作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
335
|
+
* @return {this}
|
|
301
336
|
*/
|
|
302
337
|
isZankoku(bool = true) {
|
|
303
338
|
if (bool) {
|
|
@@ -308,8 +343,9 @@ var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilder
|
|
|
308
343
|
return this;
|
|
309
344
|
}
|
|
310
345
|
/**
|
|
311
|
-
*
|
|
312
|
-
* @
|
|
346
|
+
* 異世界転生作品を抽出または除外します (istensei/nottensei)。
|
|
347
|
+
* @param bool trueの場合、異世界転生作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
348
|
+
* @return {this}
|
|
313
349
|
*/
|
|
314
350
|
isTensei(bool = true) {
|
|
315
351
|
if (bool) {
|
|
@@ -320,8 +356,9 @@ var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilder
|
|
|
320
356
|
return this;
|
|
321
357
|
}
|
|
322
358
|
/**
|
|
323
|
-
*
|
|
324
|
-
* @
|
|
359
|
+
* 異世界転移作品を抽出または除外します (istenni/nottenni)。
|
|
360
|
+
* @param bool trueの場合、異世界転移作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
361
|
+
* @return {this}
|
|
325
362
|
*/
|
|
326
363
|
isTenni(bool = true) {
|
|
327
364
|
if (bool) {
|
|
@@ -332,16 +369,18 @@ var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilder
|
|
|
332
369
|
return this;
|
|
333
370
|
}
|
|
334
371
|
/**
|
|
335
|
-
*
|
|
336
|
-
* @return {
|
|
372
|
+
* 異世界転生または異世界転移作品を抽出します (istt)。
|
|
373
|
+
* @return {this}
|
|
337
374
|
*/
|
|
338
375
|
isTT() {
|
|
339
376
|
this.set({ istt: BooleanNumber.True });
|
|
340
377
|
return this;
|
|
341
378
|
}
|
|
342
379
|
/**
|
|
343
|
-
*
|
|
344
|
-
*
|
|
380
|
+
* 抽出する作品の文字数を指定します (length)。
|
|
381
|
+
* 範囲指定する場合は、最小文字数と最大文字数をハイフン(-)記号で区切ってください。
|
|
382
|
+
* @param length 文字数、または[最小文字数, 最大文字数]
|
|
383
|
+
* @return {this}
|
|
345
384
|
*/
|
|
346
385
|
length(length) {
|
|
347
386
|
this.set({ length: _NovelSearchBuilderBase.array2string(length) });
|
|
@@ -358,59 +397,66 @@ var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilder
|
|
|
358
397
|
return this;
|
|
359
398
|
}
|
|
360
399
|
/**
|
|
361
|
-
*
|
|
362
|
-
* @
|
|
400
|
+
* 抽出する作品の挿絵数を指定します (sasie)。
|
|
401
|
+
* @param num 挿絵数、または[最小挿絵数, 最大挿絵数]
|
|
402
|
+
* @return {this}
|
|
363
403
|
*/
|
|
364
404
|
sasie(num) {
|
|
365
405
|
this.set({ sasie: _NovelSearchBuilderBase.array2string(num) });
|
|
366
406
|
return this;
|
|
367
407
|
}
|
|
368
408
|
/**
|
|
369
|
-
*
|
|
370
|
-
* @
|
|
409
|
+
* 抽出する作品の予想読了時間を分単位で指定します (time)。
|
|
410
|
+
* @param num 読了時間(分)、または[最小読了時間, 最大読了時間]
|
|
411
|
+
* @return {this}
|
|
371
412
|
*/
|
|
372
413
|
time(num) {
|
|
373
414
|
this.set({ time: _NovelSearchBuilderBase.array2string(num) });
|
|
374
415
|
return this;
|
|
375
416
|
}
|
|
376
417
|
/**
|
|
377
|
-
*
|
|
378
|
-
* @
|
|
418
|
+
* Nコードを指定して取得します (ncode)。
|
|
419
|
+
* @param ncodes Nコード、またはNコードの配列
|
|
420
|
+
* @return {this}
|
|
379
421
|
*/
|
|
380
422
|
ncode(ncodes) {
|
|
381
423
|
this.set({ ncode: _NovelSearchBuilderBase.array2string(ncodes) });
|
|
382
424
|
return this;
|
|
383
425
|
}
|
|
384
426
|
/**
|
|
385
|
-
*
|
|
386
|
-
* @
|
|
427
|
+
* 抽出する小説タイプを指定します (type)。
|
|
428
|
+
* @param type 小説タイプ (t: 短編, r: 連載中, er: 完結済連載小説, ter: 短編と完結済連載小説, re: 連載中と完結済連載小説)
|
|
429
|
+
* @return {this}
|
|
387
430
|
*/
|
|
388
431
|
type(type) {
|
|
389
432
|
this.set({ type });
|
|
390
433
|
return this;
|
|
391
434
|
}
|
|
392
435
|
/**
|
|
393
|
-
*
|
|
394
|
-
*
|
|
436
|
+
* 抽出する作品の文体を指定します (buntai)。
|
|
437
|
+
* 複数指定する場合はハイフン(-)で区切ってください。
|
|
438
|
+
* @param buntai 文体コード、または文体コードの配列
|
|
439
|
+
* @return {this}
|
|
395
440
|
*/
|
|
396
441
|
buntai(buntai) {
|
|
397
442
|
this.set({ buntai: _NovelSearchBuilderBase.array2string(buntai) });
|
|
398
443
|
return this;
|
|
399
444
|
}
|
|
400
445
|
/**
|
|
401
|
-
*
|
|
402
|
-
* @
|
|
446
|
+
* 連載停止中作品に関する指定をします (stop)。
|
|
447
|
+
* @param bool trueの場合、長期連載停止中のみ取得する (デフォルト: true)。falseの場合、長期連載停止中を除外する。
|
|
448
|
+
* @return {this}
|
|
403
449
|
*/
|
|
404
450
|
isStop(bool = true) {
|
|
405
451
|
this.set({ stop: bool ? StopParam.Stopping : StopParam.NoStopping });
|
|
406
452
|
return this;
|
|
407
453
|
}
|
|
408
454
|
/**
|
|
409
|
-
*
|
|
410
|
-
* @return {
|
|
455
|
+
* ピックアップ作品のみを取得します (ispickup)。
|
|
456
|
+
* @return {this}
|
|
411
457
|
*/
|
|
412
|
-
isPickup(
|
|
413
|
-
this.set({ ispickup:
|
|
458
|
+
isPickup() {
|
|
459
|
+
this.set({ ispickup: BooleanNumber.True });
|
|
414
460
|
return this;
|
|
415
461
|
}
|
|
416
462
|
lastUpdate(x, y) {
|
|
@@ -419,7 +465,7 @@ var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilder
|
|
|
419
465
|
date = x;
|
|
420
466
|
} else if (x instanceof Date && y instanceof Date) {
|
|
421
467
|
date = `${Math.floor(x.getTime() / 1e3)}-${Math.floor(
|
|
422
|
-
|
|
468
|
+
y.getTime() / 1e3
|
|
423
469
|
)}`;
|
|
424
470
|
} else {
|
|
425
471
|
date = `${x}-${y}`;
|
|
@@ -427,6 +473,20 @@ var NovelSearchBuilderBase = class _NovelSearchBuilderBase extends SearchBuilder
|
|
|
427
473
|
this.set({ lastup: date });
|
|
428
474
|
return this;
|
|
429
475
|
}
|
|
476
|
+
lastNovelUpdate(x, y) {
|
|
477
|
+
let date;
|
|
478
|
+
if (typeof x == "string") {
|
|
479
|
+
date = x;
|
|
480
|
+
} else if (x instanceof Date && y instanceof Date) {
|
|
481
|
+
date = `${Math.floor(x.getTime() / 1e3)}-${Math.floor(
|
|
482
|
+
y.getTime() / 1e3
|
|
483
|
+
)}`;
|
|
484
|
+
} else {
|
|
485
|
+
date = `${x}-${y}`;
|
|
486
|
+
}
|
|
487
|
+
this.set({ lastupdate: date });
|
|
488
|
+
return this;
|
|
489
|
+
}
|
|
430
490
|
/**
|
|
431
491
|
* なろう小説APIへの検索リクエストを実行する
|
|
432
492
|
* @returns {Promise<NarouSearchResults>} 検索結果
|
|
@@ -446,26 +506,39 @@ var SearchBuilderR18 = class extends NovelSearchBuilderBase {
|
|
|
446
506
|
execute() {
|
|
447
507
|
return this.api.executeNovel18(this.params);
|
|
448
508
|
}
|
|
509
|
+
/**
|
|
510
|
+
* 抽出するR18サイトを指定します (nocgenre)。
|
|
511
|
+
* @param sites R18サイトコード、またはR18サイトコードの配列 (1: ノクターンノベルズ, 2: ムーンライトノベルズ(男性向け), 3: ムーンライトノベルズ(BL), 4: ミッドナイトノベルズ)
|
|
512
|
+
* @return {this}
|
|
513
|
+
*/
|
|
449
514
|
r18Site(sites) {
|
|
450
515
|
this.set({ nocgenre: NovelSearchBuilderBase.array2string(sites) });
|
|
451
516
|
return this;
|
|
452
517
|
}
|
|
453
518
|
/**
|
|
454
|
-
*
|
|
455
|
-
* @
|
|
519
|
+
* X-IDを指定して取得します (xid)。
|
|
520
|
+
* @param ids X-ID、またはX-IDの配列
|
|
521
|
+
* @return {this}
|
|
456
522
|
*/
|
|
457
523
|
xid(ids) {
|
|
458
524
|
this.set({ xid: NovelSearchBuilderBase.array2string(ids) });
|
|
459
525
|
return this;
|
|
460
526
|
}
|
|
461
527
|
/**
|
|
462
|
-
*
|
|
463
|
-
*
|
|
528
|
+
* 出力する項目を個別に指定します (of)。
|
|
529
|
+
* 未指定時は全項目出力されます。転送量軽減のため、このパラメータの使用が推奨されます。
|
|
530
|
+
* @param fields 出力するR18フィールド名、またはR18フィールド名の配列
|
|
531
|
+
* @return {SearchBuilderR18<SearchResultR18Fields<R18Fields>>} 型が更新されたビルダー
|
|
464
532
|
*/
|
|
465
533
|
fields(fields) {
|
|
466
534
|
this.set({ of: NovelSearchBuilderBase.array2string(fields) });
|
|
467
535
|
return this;
|
|
468
536
|
}
|
|
537
|
+
/**
|
|
538
|
+
* 出力オプション項目を指定します (opt)。
|
|
539
|
+
* @param option 出力するオプションフィールド名、またはオプションフィールド名の配列
|
|
540
|
+
* @return {SearchBuilderR18<T, SearchResultOptionalFields<TFields>>} 型が更新されたビルダー
|
|
541
|
+
*/
|
|
469
542
|
opt(option) {
|
|
470
543
|
this.set({ opt: NovelSearchBuilderBase.array2string(option) });
|
|
471
544
|
return this;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/search-builder-r18.ts","../src/params.ts","../src/search-builder.ts"],"sourcesContent":["import { NovelSearchBuilderBase } from \"./search-builder.js\";\nimport type NarouSearchResults from \"./narou-search-results.js\";\nimport type {\n NarouSearchResult,\n SearchResultR18Fields,\n SearchResultOptionalFields,\n} from \"./narou-search-results.js\";\nimport type {\n R18Site,\n SearchResultFieldNames,\n R18Fields,\n OptionalFields,\n} from \"./params.js\";\n\nexport type DefaultR18SearchResultFields = keyof Omit<\n NarouSearchResult,\n \"weekly_unique\" | \"noveltype\" | \"biggenre\" | \"genre\" | \"isr15\" | \"id\"\n>;\n\n/**\n * 18禁API検索ヘルパー\n * @class SearchBuilderR18\n */\nexport default class SearchBuilderR18<\n T extends SearchResultFieldNames = DefaultR18SearchResultFields,\n TOpt extends keyof NarouSearchResult = never\n> extends NovelSearchBuilderBase<T | TOpt> {\n /**\n * なろう小説APIへの検索リクエストを実行する\n * @override\n * @returns {Promise<NarouSearchResults>} 検索結果\n */\n execute(): Promise<NarouSearchResults<NarouSearchResult, T | TOpt>> {\n return this.api.executeNovel18(this.params);\n }\n\n r18Site(sites: R18Site | readonly R18Site[]) {\n this.set({ nocgenre: NovelSearchBuilderBase.array2string(sites) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n xid(ids: number | readonly number[]) {\n this.set({ xid: NovelSearchBuilderBase.array2string(ids) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n fields<TFields extends R18Fields>(\n fields: TFields | readonly TFields[]\n ): SearchBuilderR18<SearchResultR18Fields<R18Fields>> {\n this.set({ of: NovelSearchBuilderBase.array2string(fields) });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this as any;\n }\n\n opt<TFields extends OptionalFields>(\n option: TFields | readonly TFields[]\n ): SearchBuilderR18<T, SearchResultOptionalFields<TFields>> {\n this.set({ opt: NovelSearchBuilderBase.array2string(option) });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this as any;\n }\n}\n","import type { NarouSearchResult, UserSearchResult } from \"./narou-search-results.js\";\nimport type { Join } from \"./util/type.js\";\n\nexport const RankingType = {\n Daily: \"d\",\n Weekly: \"w\",\n Monthly: \"m\",\n Quarterly: \"q\",\n} as const;\nexport type RankingType = typeof RankingType[keyof typeof RankingType];\n\n/**\n * すべてのAPIで共通のクエリパラメータ\n */\nexport interface ParamsBase {\n /**\n * gzip圧縮してgzipファイルとして返します。\n * gzip圧縮レベルを1~5で指定できます。\n * 転送量上限を減らすためにも推奨\n */\n gzip?: GzipLevel;\n /**\n * 出力形式を指定\n * 本ライブラリはJSONとJSONPのみ対応\n */\n out?: \"json\" | \"jsonp\";\n}\n\n/**\n * 検索APIで共通のクエリパラメータ\n */\nexport interface ParamsBaseWithOrder<TOrder extends string> extends ParamsBase {\n /**\n * 出力する項目を個別に指定できます。未指定時は全項目出力されます。\n * 転送量軽減のため、このパラメータの使用が推奨されます。\n */\n of?: string;\n /**\n * 最大出力数を指定できます。指定しない場合は20件になります。\n */\n lim?: number;\n /**\t表示開始位置の指定です。 */\n st?: number;\n /** 出力順序を指定できます。 */\n order?: TOrder;\n}\n\n/**\n * メソッドにパラメータを指定する際のヘルパー。\n * @see https://dev.syosetu.com/man/api/\n * @see https://dev.syosetu.com/xman/atom/\n */\nexport interface SearchParams extends ParamsBaseWithOrder<Order> {\n word?: string;\n notword?: string;\n title?: BooleanNumber;\n ex?: BooleanNumber;\n keyword?: BooleanNumber;\n wname?: BooleanNumber;\n\n biggenre?: Join<BigGenre> | BigGenre;\n notbiggenre?: Join<BigGenre> | BigGenre;\n genre?: Join<Genre> | Genre;\n notgenre?: Join<Genre> | Genre;\n userid?: Join<number> | number;\n\n nocgenre?: Join<R18Site> | R18Site;\n notnocgenre?: Join<R18Site> | R18Site;\n xid?: Join<number> | number;\n\n isr15?: BooleanNumber;\n isbl?: BooleanNumber;\n isgl?: BooleanNumber;\n iszankoku?: BooleanNumber;\n istensei?: BooleanNumber;\n istenni?: BooleanNumber;\n istt?: BooleanNumber;\n\n notr15?: BooleanNumber;\n notbl?: BooleanNumber;\n notgl?: BooleanNumber;\n notzankoku?: BooleanNumber;\n nottensei?: BooleanNumber;\n nottenni?: BooleanNumber;\n nottt?: BooleanNumber;\n\n minlen?: number;\n maxlen?: number;\n length?: number | Join<number>;\n\n kaiwaritu?: number | string;\n sasie?: number | string;\n\n mintime?: number;\n maxtime?: number;\n time?: number | string;\n\n ncode?: string | Join<string>;\n\n type?: NovelTypeParam;\n\n buntai?: BuntaiParam | Join<BuntaiParam>;\n\n stop?: StopParam;\n\n ispickup?: BooleanNumber;\n lastup?: string;\n\n opt?: Join<OptionalFields>;\n}\n\nexport interface RankingParams extends ParamsBase {\n rtype: `${string}-${RankingType}`;\n}\n\nexport interface RankingHistoryParams extends ParamsBase {\n ncode: string;\n}\n\n/**\n * ユーザー検索パラメータ\n */\nexport interface UserSearchParams extends ParamsBaseWithOrder<UserOrder> {\n /** 単語を指定できます。半角または全角スペースで区切るとAND抽出になります。部分一致でHITします。検索の対象はユーザ名とユーザ名のフリガナです。 */\n word?: string;\n /** 含みたくない単語を指定できます。スペースで区切ることにより含ませない単語を増やせます。部分一致で除外されます。除外の対象はユーザ名とユーザ名のフリガナです。 */\n notword?: string;\n /** ユーザIDで抽出可能。 */\n userid?: number;\n /** 抽出するユーザのユーザ名のフリガナの頭文字を指定できます。頭文字はユーザ名のフリガナをひらがなに変換し、最初の1文字が「ぁ」~「ん」の場合に対象となります。 */\n name1st?: string;\n /** 抽出するユーザの小説投稿数の下限を指定できます。小説投稿件数が指定された数値以上のユーザを抽出します。 */\n minnovel?: number;\n /** 抽出するユーザの小説投稿数の上限を指定できます。小説投稿件数が指定された数値以下のユーザを抽出します。 */\n maxnovel?: number;\n /** 抽出するユーザのレビュー投稿数の下限を指定できます。レビュー投稿件数が指定された数値以上のユーザを抽出します。 */\n minreview?: number;\n /** 抽出するユーザのレビュー投稿数の上限を指定できます。レビュー投稿件数が指定された数値以下のユーザを抽出します。 */\n maxreview?: number;\n}\n\nexport const BooleanNumber = {\n True: 1,\n False: 0,\n} as const;\nexport type BooleanNumber = typeof BooleanNumber[keyof typeof BooleanNumber];\n\nexport type SearchResultFieldNames = keyof NarouSearchResult;\n\n/**\n * なろう小説APIのofパラメータに指定できる出力する項目\n * @see https://dev.syosetu.com/man/api/#output\n */\nexport const Fields = {\n /** 小説名 */\n title: \"t\",\n /** Nコード */\n ncode: \"n\",\n /** 作者のユーザID(数値) */\n userid: \"u\",\n /** 作者名 */\n writer: \"w\",\n /** 小説のあらすじ */\n story: \"s\",\n /** 大ジャンル */\n biggenre: \"bg\",\n /** ジャンル */\n genre: \"g\",\n /** キーワード */\n keyword: \"k\",\n /** 初回掲載日 */\n general_firstup: \"gf\",\n /** 最終掲載日 */\n general_lastup: \"gl\",\n /** 連載の場合は1、短編の場合は2 */\n noveltype: \"nt\",\n /** 短編小説と完結済小説は0となっています。連載中は1です。 */\n end: \"e\",\n /** 全掲載部分数 */\n general_all_no: \"ga\",\n /** 小説文字数 */\n length: \"l\",\n /** 読了時間(分単位) */\n time: \"ti\",\n /** 長期連載停止中 */\n isstop: \"i\",\n /** 登録必須キーワードに「R15」が含まれる場合は1、それ以外は0です。 */\n isr15: \"isr\",\n /** 登録必須キーワードに「ボーイズラブ」が含まれる場合は1、それ以外は0です。 */\n isbl: \"ibl\",\n /** 登録必須キーワードに「ガールズラブ」が含まれる場合は1、それ以外は0です。 */\n isgl: \"igl\",\n /** 登録必須キーワードに「残酷な描写あり」が含まれる場合は1、それ以外は0です。 */\n iszankoku: \"izk\",\n /** 登録必須キーワードに「異世界転生」が含まれる場合は1、それ以外は0です。 */\n istensei: \"its\",\n /** 登録必須キーワードに「異世界転移」が含まれる場合は1、それ以外は0です。 */\n istenni: \"iti\",\n /** 総合評価ポイント */\n global_point: \"gp\",\n /** 日間ポイント */\n daily_point: \"dp\",\n /** 週間ポイント */\n weekly_point: \"wp\",\n /** 月間ポイント */\n monthly_point: \"mp\",\n /** 四半期ポイント */\n quarter_point: \"qp\",\n /** 年間ポイント */\n yearly_point: \"yp\",\n /** ブックマーク数 */\n fav_novel_cnt: \"f\",\n /** 感想数 */\n impression_cnt: \"imp\",\n /** レビュー数 */\n review_cnt: \"r\",\n /** 評価ポイント */\n all_point: \"a\",\n /** 評価者数 */\n all_hyoka_cnt: \"ah\",\n /** 挿絵の数 */\n sasie_cnt: \"sa\",\n /** 会話率 */\n kaiwaritu: \"ka\",\n /** 小説の更新日時 */\n novelupdated_at: \"nu\",\n /**\n * 最終更新日時\n * システム用で小説更新時とは関係ありません\n */\n updated_at: \"ua\",\n} as const;\n\nexport type Fields = typeof Fields[keyof Omit<\n NarouSearchResult,\n \"novel_type\" | \"weekly_unique\" | \"nocgenre\"\n>];\n\n/**\n * なろうR18小説APIのofパラメータに指定できる出力する項目\n * @see https://dev.syosetu.com/xman/api/#output\n */\nexport const R18Fields = {\n /** 小説名 */\n title: \"t\",\n /** Nコード */\n ncode: \"n\",\n /** 作者のユーザID(数値) */\n userid: \"u\",\n /** 作者名 */\n writer: \"w\",\n /** 小説のあらすじ */\n story: \"s\",\n /** 掲載サイト */\n nocgenre: \"ng\",\n /** キーワード */\n keyword: \"k\",\n /** 初回掲載日 */\n general_firstup: \"gf\",\n /** 最終掲載日 */\n general_lastup: \"gl\",\n /** 連載の場合は1、短編の場合は2 */\n noveltype: \"nt\",\n /** 短編小説と完結済小説は0となっています。連載中は1です。 */\n end: \"e\",\n /** 全掲載部分数 */\n general_all_no: \"ga\",\n /** 小説文字数 */\n length: \"l\",\n /** 読了時間(分単位) */\n time: \"ti\",\n /** 長期連載停止中 */\n isstop: \"i\",\n /** 登録必須キーワードに「ボーイズラブ」が含まれる場合は1、それ以外は0です。 */\n isbl: \"ibl\",\n /** 登録必須キーワードに「ガールズラブ」が含まれる場合は1、それ以外は0です。 */\n isgl: \"igl\",\n /** 登録必須キーワードに「残酷な描写あり」が含まれる場合は1、それ以外は0です。 */\n iszankoku: \"izk\",\n /** 登録必須キーワードに「異世界転生」が含まれる場合は1、それ以外は0です。 */\n istensei: \"its\",\n /** 登録必須キーワードに「異世界転移」が含まれる場合は1、それ以外は0です。 */\n istenni: \"iti\",\n /** 総合評価ポイント */\n global_point: \"gp\",\n /** 日間ポイント */\n daily_point: \"dp\",\n /** 週間ポイント */\n weekly_point: \"wp\",\n /** 月間ポイント */\n monthly_point: \"mp\",\n /** 四半期ポイント */\n quarter_point: \"qp\",\n /** 年間ポイント */\n yearly_point: \"yp\",\n /** R18ブックマーク数 */\n fav_novel_cnt: \"f\",\n /** 感想数 */\n impression_cnt: \"imp\",\n /** レビュー数 */\n review_cnt: \"r\",\n /** 評価ポイント */\n all_point: \"a\",\n /** 評価者数 */\n all_hyoka_cnt: \"ah\",\n /** 挿絵の数 */\n sasie_cnt: \"sa\",\n /** 会話率 */\n kaiwaritu: \"ka\",\n /** 小説の更新日時 */\n novelupdated_at: \"nu\",\n /**\n * 最終更新日時\n * システム用で小説更新時とは関係ありません\n */\n updated_at: \"ua\",\n} as const;\n\nexport type R18Fields = typeof R18Fields[keyof Omit<\n NarouSearchResult,\n \"novel_type\" | \"weekly_unique\" | \"biggenre\" | \"genre\" | \"isr15\"\n>];\n\n/**\n * オプション項目\n */\nexport const OptionalFields = {\n /**\n * 週間ユニークユーザ[項目名:weekly_unique]が追加されます。\n * 週間ユニークユーザは前週の日曜日から土曜日分のユニークの合計です。\n * 毎週火曜日早朝に更新されます。\n */\n weekly_unique: \"weekly\",\n} as const;\n\nexport type OptionalFields = typeof OptionalFields[keyof Pick<\n NarouSearchResult,\n \"weekly_unique\"\n>];\n\n/**\n * ユーザ検索APIのofパラメータに指定できる出力する項目\n * @see https://dev.syosetu.com/man/userapi/#output\n */\nexport const UserFields = {\n /** ユーザID */\n userid: \"u\",\n /** ユーザ名 */\n name: \"n\",\n /** ユーザ名のフリガナ */\n yomikata: \"y\",\n /** ユーザ名のフリガナの頭文字 */\n name1st: \"1\",\n /** 小説投稿数 */\n novel_cnt: \"nc\",\n /** レビュー投稿数 */\n review_cnt: \"rc\",\n /** 小説累計文字数 */\n novel_length: \"nl\",\n /** 総合評価ポイントの合計 */\n sum_global_point: \"sg\",\n} as const;\nexport type UserFields = typeof UserFields[keyof UserSearchResult];\n\n/**\n * 出力順序\n */\nexport const Order = {\n /** ブックマーク数の多い順 */\n FavoriteNovelCount: \"favnovelcnt\",\n /** レビュー数の多い順 */\n ReviewCount: \"favnovelcnt\",\n /** 総合ポイントの高い順 */\n HyokaDesc: \"hyoka\",\n /** 総合ポイントの低い順 */\n HyokaAsc: \"hyokaasc\",\n /** 感想の多い順 */\n ImpressionCount: \"impressioncnt\",\n /** 評価者数の多い順 */\n HyokaCountDesc: \"hyokacnt\",\n /** 評価者数の少ない順 */\n HyokaCountAsc: \"hyokacntasc\",\n /** 週間ユニークユーザの多い順 */\n Weekly: \"weekly\",\n /** 小説本文の文字数が多い順 */\n LengthDesc: \"lengthdesc\",\n /** 小説本文の文字数が少ない順 */\n LengthAsc: \"lengthasc\",\n /** Nコードが新しい順 */\n NCodeDesc: \"ncodedesc\",\n /** 新着更新順 */\n New: \"new\",\n /** 古い順 */\n Old: \"old\",\n /** 日間ポイントの高い順 */\n DailyPoint: \"dailypoint\",\n /** 週間ポイントの高い順 */\n WeeklyPoint: \"weeklypoint\",\n /** 月間ポイントの高い順 */\n MonthlyPoint: \"monthlypoint\",\n /** 四半期ポイントの高い順 */\n QuarterPoint: \"quarterpoint\",\n /** 年間ポイントの高い順 */\n YearlyPoint: \"yearlypoint\",\n} as const;\n\nexport type Order = typeof Order[keyof typeof Order];\n\n/** R18掲載サイト */\nexport const R18Site = {\n /** ノクターンノベルズ(男性向け) */\n Nocturne: 1,\n /** ムーンライトノベルズ(女性向け) */\n MoonLight: 2,\n /** ムーンライトノベルズ(BL) */\n MoonLightBL: 3,\n /** ミッドナイトノベルズ(大人向け) */\n Midnight: 4,\n} as const;\n\nexport type R18Site = typeof R18Site[keyof typeof R18Site];\n\n/** R18掲載サイト表記ヘルパー */\nexport const R18SiteNotation: { readonly [K in R18Site]: string } = {\n [R18Site.Nocturne]: \"ノクターンノベルズ(男性向け)\",\n [R18Site.MoonLight]: \"ムーンライトノベルズ(女性向け)\",\n [R18Site.MoonLightBL]: \"ムーンライトノベルズ(BL)\",\n [R18Site.Midnight]: \"ミッドナイトノベルズ(大人向け)\",\n} as const;\n\n/** 大ジャンル */\nexport const BigGenre = {\n /** 恋愛 */\n Renai: 1,\n /** ファンタジー */\n Fantasy: 2,\n /** 文芸 */\n Bungei: 3,\n /** SF */\n Sf: 4,\n /** その他 */\n Sonota: 99,\n /** ノンジャンル */\n NonGenre: 98,\n} as const;\n\nexport type BigGenre = typeof BigGenre[keyof typeof BigGenre];\n\n/** 大ジャンル表記ヘルパー */\nexport const BigGenreNotation: { readonly [K in BigGenre]: string } = {\n [BigGenre.Renai]: \"恋愛\",\n [BigGenre.Fantasy]: \"ファンタジー\",\n [BigGenre.Bungei]: \"文芸\",\n [BigGenre.Sf]: \"SF\",\n [BigGenre.Sonota]: \"その他\",\n [BigGenre.NonGenre]: \"ノンジャンル\",\n} as const;\n\n/** ジャンル */\nexport const Genre = {\n /** 異世界〔恋愛〕*/\n RenaiIsekai: 101,\n /** 現実世界〔恋愛〕*/\n RenaiGenjitsusekai: 102,\n /** ハイファンタジー〔ファンタジー〕*/\n FantasyHigh: 201,\n /** ローファンタジー〔ファンタジー〕*/\n FantasyLow: 202,\n /** 純文学〔文芸〕*/\n BungeiJyunbungei: 301,\n /** ヒューマンドラマ〔文芸〕*/\n BungeiHumanDrama: 302,\n /** 歴史〔文芸〕*/\n BungeiHistory: 303,\n /** 推理〔文芸〕*/\n BungeiSuiri: 304,\n /** ホラー〔文芸〕*/\n BungeiHorror: 305,\n /** アクション〔文芸〕*/\n BungeiAction: 306,\n /** コメディー〔文芸〕*/\n BungeiComedy: 307,\n /** VRゲーム〔SF〕*/\n SfVrgame: 401,\n /** 宇宙〔SF〕*/\n SfSpace: 402,\n /** 空想科学〔SF〕*/\n SfKuusoukagaku: 403,\n /** パニック〔SF〕*/\n SfPanic: 404,\n /** 童話〔その他〕*/\n SonotaDouwa: 9901,\n /** 詩〔その他〕*/\n SonotaShi: 9902,\n /** エッセイ〔その他〕*/\n SonotaEssei: 9903,\n /** リプレイ〔その他〕*/\n SonotaReplay: 9904,\n /** その他〔その他〕 */\n SonotaSonota: 9999,\n /** ノンジャンル〔ノンジャンル〕*/\n NonGenre: 9801,\n} as const;\nexport type Genre = typeof Genre[keyof typeof Genre];\n\n/** ジャンル表記ヘルパー */\nexport const GenreNotation: { readonly [K in Genre]: string } = {\n [Genre.RenaiIsekai]: \"異世界〔恋愛〕\",\n [Genre.RenaiGenjitsusekai]: \"現実世界〔恋愛〕\",\n [Genre.FantasyHigh]: \"ハイファンタジー〔ファンタジー〕\",\n [Genre.FantasyLow]: \"ローファンタジー〔ファンタジー〕\",\n [Genre.BungeiJyunbungei]: \"純文学〔文芸〕\",\n [Genre.BungeiHumanDrama]: \"ヒューマンドラマ〔文芸〕\",\n [Genre.BungeiHistory]: \"歴史〔文芸〕\",\n [Genre.BungeiSuiri]: \"推理〔文芸〕\",\n [Genre.BungeiHorror]: \"ホラー〔文芸〕\",\n [Genre.BungeiAction]: \"アクション〔文芸〕\",\n [Genre.BungeiComedy]: \"コメディー〔文芸〕\",\n [Genre.SfVrgame]: \"VRゲーム〔SF〕\",\n [Genre.SfSpace]: \"宇宙〔SF〕\",\n [Genre.SfKuusoukagaku]: \"空想科学〔SF〕\",\n [Genre.SfPanic]: \"パニック〔SF〕\",\n [Genre.SonotaDouwa]: \"童話〔その他〕\",\n [Genre.SonotaShi]: \"詩〔その他〕\",\n [Genre.SonotaEssei]: \"エッセイ〔その他〕\",\n [Genre.SonotaReplay]: \"リプレイ〔その他〕\",\n [Genre.SonotaSonota]: \"その他〔その他〕\",\n [Genre.NonGenre]: \"ノンジャンル〔ノンジャンル〕\",\n} as const;\n\n/** 文体指定 */\nexport const BuntaiParam = {\n /** 字下げされておらず、連続改行が多い作品 */\n NoJisageKaigyouOoi: 1,\n /** 字下げされていないが、改行数は平均な作品 */\n NoJisageKaigyoHutsuu: 2,\n /** 字下げが適切だが、連続改行が多い作品 */\n JisageKaigyoOoi: 4,\n /** 字下げが適切でかつ改行数も平均な作品 */\n JisageKaigyoHutsuu: 6,\n} as const;\n\nexport type BuntaiParam = typeof BuntaiParam[keyof typeof BuntaiParam];\n\n/** 連載停止中指定 */\nexport const StopParam = {\n /** 長期連載停止中を除きます */\n NoStopping: 1,\n /** 長期連載停止中のみ取得します */\n Stopping: 2,\n} as const;\n\nexport type StopParam = typeof StopParam[keyof typeof StopParam];\n\n/** 小説タイプ指定 */\nexport const NovelTypeParam = {\n /** 短編 */\n Short: \"t\",\n /** 連載中 */\n RensaiNow: \"r\",\n /** 完結済連載小説 */\n RensaiEnd: \"er\",\n /** すべての連載小説(連載中および完結済) */\n Rensai: \"re\",\n /** 短編と完結済連載小説 */\n ShortAndRensai: \"ter\",\n} as const;\nexport type NovelTypeParam = typeof NovelTypeParam[keyof typeof NovelTypeParam];\n\nexport const UserOrder = {\n /** ユーザIDの新しい順 */\n New: \"new\",\n /** 小説投稿数の多い順 */\n NovelCount: \"novelcnt\",\n /** レビュー投稿数の多い順 */\n ReviewCount: \"reviewcnt\",\n /** 小説累計文字数の多い順 */\n NovelLength: \"novellength\",\n /** 総合評価ポイントの合計の多い順 */\n SumGlobalPoint: \"sumglobalpoint\",\n /** ユーザIDの古い順 */\n Old: \"old\",\n} as const;\nexport type UserOrder = typeof UserOrder[keyof typeof UserOrder];\n\nexport type GzipLevel = 0 | 1 | 2 | 3 | 4 | 5;\n","import type NarouNovel from \"./narou.js\";\nimport type {\n NarouSearchResult,\n SearchResultFields,\n SearchResultOptionalFields,\n} from \"./narou-search-results.js\";\nimport type NarouSearchResults from \"./narou-search-results.js\";\nimport type {\n BigGenre,\n SearchResultFieldNames,\n Genre,\n SearchParams,\n Fields,\n Order,\n BuntaiParam,\n NovelTypeParam,\n GzipLevel,\n OptionalFields,\n ParamsBaseWithOrder,\n} from \"./params.js\";\nimport { BooleanNumber, StopParam } from \"./params.js\";\nimport type { Join } from \"./util/type.js\";\n\nexport type DefaultSearchResultFields = keyof Omit<\n NarouSearchResult,\n \"weekly_unique\" | \"noveltype\" | \"nocgenre\" | \"xid\"\n>;\n\nexport abstract class SearchBuilderBase<\n TParams extends ParamsBaseWithOrder<TOrder>,\n TOrder extends string\n> {\n /**\n * constructor\n * @private\n */\n constructor(\n protected params: TParams = {} as TParams,\n protected api: NarouNovel\n ) { }\n\n protected static distinct<T>(array: readonly T[]): T[] {\n return Array.from(new Set(array));\n }\n\n protected static array2string<T extends string | number>(\n n: T | readonly T[]\n ): Join<T> {\n if (Array.isArray(n)) {\n return this.distinct(n).join(\"-\") as Join<T>;\n } else {\n return n.toString() as Join<T>;\n }\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n limit(num: number): this {\n this.set({ lim: num } as TParams);\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n start(num: number): this {\n this.set({ st: num } as TParams);\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n page(no: number, count = 20): this {\n return this.limit(count).start(no * count);\n }\n\n /**\n * 出力順序を指定する。指定しない場合は新着順となります。\n * old\t古い順\n * @param {TOrder} order 出力順序\n * @return {SearchBuilder} this\n */\n order(order: TOrder): this {\n this.set({ order: order } as TParams);\n return this;\n }\n\n /**\n * gzip圧縮する。\n *\n * 転送量上限を減らすためにも推奨\n * @param {GzipLevel} level gzip圧縮レベル(1~5)\n * @return {SearchBuilder} this\n */\n gzip(level: GzipLevel): this {\n this.set({ gzip: level } as TParams);\n return this;\n }\n\n /**\n * クエリパラメータをセットする\n * @private\n * @return {SearchBuilder} this\n */\n protected set(obj: TParams): this {\n this.params = { ...this.params, ...obj };\n return this;\n }\n\n /**\n * クエリパラメータを削除する\n */\n protected unset(key: keyof TParams): this {\n delete this.params[key];\n return this;\n }\n}\n\nexport abstract class NovelSearchBuilderBase<\n T extends SearchResultFieldNames\n> extends SearchBuilderBase<SearchParams, Order> {\n /**\n * a\n * @return {SearchBuilder} this\n */\n word(word: string): this {\n this.set({ word: word });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n notWord(word: string): this {\n this.set({ notword: word });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n byTitle(bool = true): this {\n this.set({ title: bool ? BooleanNumber.True : BooleanNumber.False });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n byOutline(bool = true): this {\n this.set({ ex: bool ? BooleanNumber.True : BooleanNumber.False });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n byKeyword(bool = true): this {\n this.set({ keyword: bool ? BooleanNumber.True : BooleanNumber.False });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n byAuthor(bool = true): this {\n this.set({ wname: bool ? BooleanNumber.True : BooleanNumber.False });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n isBL(bool = true): this {\n if (bool) {\n this.set({ isbl: BooleanNumber.True });\n } else {\n this.set({ notbl: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n isGL(bool = true): this {\n if (bool) {\n this.set({ isgl: BooleanNumber.True });\n } else {\n this.set({ notgl: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n isZankoku(bool = true): this {\n if (bool) {\n this.set({ iszankoku: BooleanNumber.True });\n } else {\n this.set({ notzankoku: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n isTensei(bool = true): this {\n if (bool) {\n this.set({ istensei: BooleanNumber.True });\n } else {\n this.set({ nottensei: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n isTenni(bool = true): this {\n if (bool) {\n this.set({ istenni: BooleanNumber.True });\n } else {\n this.set({ nottenni: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n isTT(): this {\n this.set({ istt: BooleanNumber.True });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n length(length: number | readonly number[]): this {\n this.set({ length: NovelSearchBuilderBase.array2string(length) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n kaiwaritu(num: number): this;\n kaiwaritu(min: number, max: number): this;\n\n kaiwaritu(min: number, max?: number): this {\n let n: number | string;\n if (max != null) {\n n = `${min}-${max}`;\n } else {\n n = min;\n }\n this.set({ kaiwaritu: n });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n sasie(num: number | readonly number[]): this {\n this.set({ sasie: NovelSearchBuilderBase.array2string(num) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n time(num: number | readonly number[]): this {\n this.set({ time: NovelSearchBuilderBase.array2string(num) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n ncode(ncodes: string | readonly string[]): this {\n this.set({ ncode: NovelSearchBuilderBase.array2string(ncodes) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n type(type: NovelTypeParam): this {\n this.set({ type });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n buntai(buntai: BuntaiParam | readonly BuntaiParam[]): this {\n this.set({ buntai: NovelSearchBuilderBase.array2string(buntai) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n isStop(bool = true): this {\n this.set({ stop: bool ? StopParam.Stopping : StopParam.NoStopping });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n isPickup(bool = true): this {\n this.set({ ispickup: bool ? BooleanNumber.True : BooleanNumber.False });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n lastUpdate(date: string): this;\n lastUpdate(from: number, to: number): this;\n lastUpdate(from: Date, to: Date): this;\n\n lastUpdate(x: string | number | Date, y?: number | Date): this {\n let date: string;\n if (typeof x == \"string\") {\n date = x;\n } else if (x instanceof Date && y instanceof Date) {\n date = `${Math.floor(x.getTime() / 1000)}-${Math.floor(\n x.getTime() / 1000\n )}`;\n } else {\n date = `${x}-${y}`;\n }\n\n this.set({ lastup: date });\n return this;\n }\n\n /**\n * なろう小説APIへの検索リクエストを実行する\n * @returns {Promise<NarouSearchResults>} 検索結果\n */\n execute(): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return this.api.executeNovel(this.params);\n }\n}\n\n/**\n * 検索ヘルパー\n * @class SearchBuilder\n */\nexport default class SearchBuilder<\n T extends keyof NarouSearchResult = DefaultSearchResultFields,\n TOpt extends keyof NarouSearchResult = never\n> extends NovelSearchBuilderBase<T | TOpt> {\n /**\n *\n * @return {SearchBuilder} this\n */\n bigGenre(genre: BigGenre | readonly BigGenre[]): this {\n this.set({ biggenre: SearchBuilder.array2string(genre) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n notBigGenre(genre: BigGenre | readonly BigGenre[]): this {\n this.set({ notbiggenre: SearchBuilder.array2string(genre) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n genre(genre: Genre | readonly Genre[]): this {\n this.set({ genre: SearchBuilder.array2string(genre) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n notGenre(genre: Genre | readonly Genre[]): this {\n this.set({ notgenre: SearchBuilder.array2string(genre) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n userId(ids: number | readonly number[]): this {\n this.set({ userid: SearchBuilder.array2string(ids) });\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n isR15(bool = true): this {\n if (bool) {\n this.set({ isr15: 1 });\n } else {\n this.set({ notr15: 1 });\n }\n return this;\n }\n\n /**\n *\n * @return {SearchBuilder} this\n */\n fields<TFields extends Fields>(\n fields: TFields | readonly TFields[]\n ): SearchBuilder<SearchResultFields<TFields>, TOpt> {\n this.set({ of: SearchBuilder.array2string(fields) });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this as any;\n }\n\n opt<TFields extends OptionalFields>(\n option: TFields | readonly TFields[]\n ): SearchBuilder<T, SearchResultOptionalFields<TFields>> {\n this.set({ opt: SearchBuilder.array2string(option) });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this as any;\n }\n}\n"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/search-builder-r18.ts","../src/params.ts","../src/search-builder.ts"],"sourcesContent":["import { NovelSearchBuilderBase } from \"./search-builder.js\";\nimport type NarouSearchResults from \"./narou-search-results.js\";\nimport type {\n NarouSearchResult,\n SearchResultR18Fields,\n SearchResultOptionalFields,\n} from \"./narou-search-results.js\";\nimport type {\n R18Site,\n SearchResultFieldNames,\n R18Fields,\n OptionalFields,\n} from \"./params.js\";\n\nexport type DefaultR18SearchResultFields = keyof Omit<\n NarouSearchResult,\n \"weekly_unique\" | \"noveltype\" | \"biggenre\" | \"genre\" | \"isr15\" | \"id\"\n>;\n\n/**\n * 18禁API検索ヘルパー\n * @class SearchBuilderR18\n */\nexport default class SearchBuilderR18<\n T extends SearchResultFieldNames = DefaultR18SearchResultFields,\n TOpt extends keyof NarouSearchResult = never\n> extends NovelSearchBuilderBase<T | TOpt> {\n /**\n * なろう小説APIへの検索リクエストを実行する\n * @override\n * @returns {Promise<NarouSearchResults>} 検索結果\n */\n execute(): Promise<NarouSearchResults<NarouSearchResult, T | TOpt>> {\n return this.api.executeNovel18(this.params);\n }\n\n /**\n * 抽出するR18サイトを指定します (nocgenre)。\n * @param sites R18サイトコード、またはR18サイトコードの配列 (1: ノクターンノベルズ, 2: ムーンライトノベルズ(男性向け), 3: ムーンライトノベルズ(BL), 4: ミッドナイトノベルズ)\n * @return {this}\n */\n r18Site(sites: R18Site | readonly R18Site[]) {\n this.set({ nocgenre: NovelSearchBuilderBase.array2string(sites) });\n return this;\n }\n\n /**\n * X-IDを指定して取得します (xid)。\n * @param ids X-ID、またはX-IDの配列\n * @return {this}\n */\n xid(ids: number | readonly number[]) {\n this.set({ xid: NovelSearchBuilderBase.array2string(ids) });\n return this;\n }\n\n /**\n * 出力する項目を個別に指定します (of)。\n * 未指定時は全項目出力されます。転送量軽減のため、このパラメータの使用が推奨されます。\n * @param fields 出力するR18フィールド名、またはR18フィールド名の配列\n * @return {SearchBuilderR18<SearchResultR18Fields<R18Fields>>} 型が更新されたビルダー\n */\n fields<TFields extends R18Fields>(\n fields: TFields | readonly TFields[]\n ): SearchBuilderR18<SearchResultR18Fields<R18Fields>> {\n this.set({ of: NovelSearchBuilderBase.array2string(fields) });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this as any;\n }\n\n /**\n * 出力オプション項目を指定します (opt)。\n * @param option 出力するオプションフィールド名、またはオプションフィールド名の配列\n * @return {SearchBuilderR18<T, SearchResultOptionalFields<TFields>>} 型が更新されたビルダー\n */\n opt<TFields extends OptionalFields>(\n option: TFields | readonly TFields[]\n ): SearchBuilderR18<T, SearchResultOptionalFields<TFields>> {\n this.set({ opt: NovelSearchBuilderBase.array2string(option) });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this as any;\n }\n}\n","import type {\n NarouSearchResult,\n UserSearchResult,\n} from \"./narou-search-results.js\";\nimport type { Join } from \"./util/type.js\";\n\nexport const RankingType = {\n Daily: \"d\",\n Weekly: \"w\",\n Monthly: \"m\",\n Quarterly: \"q\",\n} as const;\nexport type RankingType = (typeof RankingType)[keyof typeof RankingType];\n\n/**\n * すべてのAPIで共通のクエリパラメータ\n */\nexport interface ParamsBase {\n /**\n * gzip圧縮してgzipファイルとして返します。\n * gzip圧縮レベルを1~5で指定できます。\n * 転送量上限を減らすためにも推奨\n */\n gzip?: GzipLevel;\n /**\n * 出力形式を指定\n * 本ライブラリはJSONとJSONPのみ対応\n */\n out?: \"json\" | \"jsonp\";\n}\n\n/**\n * 検索APIで共通のクエリパラメータ\n */\nexport interface ParamsBaseWithOrder<TOrder extends string> extends ParamsBase {\n /**\n * 出力する項目を個別に指定できます。未指定時は全項目出力されます。\n * 転送量軽減のため、このパラメータの使用が推奨されます。\n */\n of?: string;\n /**\n * 最大出力数を指定できます。指定しない場合は20件になります。\n */\n lim?: number;\n /**\t表示開始位置の指定です。 */\n st?: number;\n /** 出力順序を指定できます。 */\n order?: TOrder;\n}\n\n/**\n * メソッドにパラメータを指定する際のヘルパー。\n * @see https://dev.syosetu.com/man/api/\n * @see https://dev.syosetu.com/xman/atom/\n */\nexport interface SearchParams extends ParamsBaseWithOrder<Order> {\n word?: string;\n notword?: string;\n title?: BooleanNumber;\n ex?: BooleanNumber;\n keyword?: BooleanNumber;\n wname?: BooleanNumber;\n\n biggenre?: Join<BigGenre> | BigGenre;\n notbiggenre?: Join<BigGenre> | BigGenre;\n genre?: Join<Genre> | Genre;\n notgenre?: Join<Genre> | Genre;\n userid?: Join<number> | number;\n\n nocgenre?: Join<R18Site> | R18Site;\n notnocgenre?: Join<R18Site> | R18Site;\n xid?: Join<number> | number;\n\n isr15?: BooleanNumber;\n isbl?: BooleanNumber;\n isgl?: BooleanNumber;\n iszankoku?: BooleanNumber;\n istensei?: BooleanNumber;\n istenni?: BooleanNumber;\n istt?: BooleanNumber;\n\n notr15?: BooleanNumber;\n notbl?: BooleanNumber;\n notgl?: BooleanNumber;\n notzankoku?: BooleanNumber;\n nottensei?: BooleanNumber;\n nottenni?: BooleanNumber;\n\n minlen?: number;\n maxlen?: number;\n length?: number | Join<number | \"\">;\n\n kaiwaritu?: number | string;\n sasie?: number | string;\n\n mintime?: number;\n maxtime?: number;\n time?: number | string;\n\n ncode?: string | Join<string>;\n\n type?: NovelTypeParam;\n\n buntai?: BuntaiParam | Join<BuntaiParam>;\n\n stop?: StopParam;\n\n ispickup?: typeof BooleanNumber.True;\n lastup?: string;\n lastupdate?: string;\n\n opt?: Join<OptionalFields>;\n}\n\nexport interface RankingParams extends ParamsBase {\n rtype: `${string}-${RankingType}`;\n}\n\nexport interface RankingHistoryParams extends ParamsBase {\n ncode: string;\n}\n\n/**\n * ユーザー検索パラメータ\n */\nexport interface UserSearchParams extends ParamsBaseWithOrder<UserOrder> {\n /** 単語を指定できます。半角または全角スペースで区切るとAND抽出になります。部分一致でHITします。検索の対象はユーザ名とユーザ名のフリガナです。 */\n word?: string;\n /** 含みたくない単語を指定できます。スペースで区切ることにより含ませない単語を増やせます。部分一致で除外されます。除外の対象はユーザ名とユーザ名のフリガナです。 */\n notword?: string;\n /** ユーザIDで抽出可能。 */\n userid?: number;\n /** 抽出するユーザのユーザ名のフリガナの頭文字を指定できます。頭文字はユーザ名のフリガナをひらがなに変換し、最初の1文字が「ぁ」~「ん」の場合に対象となります。 */\n name1st?: string;\n /** 抽出するユーザの小説投稿数の下限を指定できます。小説投稿件数が指定された数値以上のユーザを抽出します。 */\n minnovel?: number;\n /** 抽出するユーザの小説投稿数の上限を指定できます。小説投稿件数が指定された数値以下のユーザを抽出します。 */\n maxnovel?: number;\n /** 抽出するユーザのレビュー投稿数の下限を指定できます。レビュー投稿件数が指定された数値以上のユーザを抽出します。 */\n minreview?: number;\n /** 抽出するユーザのレビュー投稿数の上限を指定できます。レビュー投稿件数が指定された数値以下のユーザを抽出します。 */\n maxreview?: number;\n}\n\nexport const BooleanNumber = {\n True: 1,\n False: 0,\n} as const;\nexport type BooleanNumber = (typeof BooleanNumber)[keyof typeof BooleanNumber];\n\nexport type SearchResultFieldNames = keyof NarouSearchResult;\n\n/**\n * なろう小説APIのofパラメータに指定できる出力する項目\n * @see https://dev.syosetu.com/man/api/#output\n */\nexport const Fields = {\n /** 小説名 */\n title: \"t\",\n /** Nコード */\n ncode: \"n\",\n /** 作者のユーザID(数値) */\n userid: \"u\",\n /** 作者名 */\n writer: \"w\",\n /** 小説のあらすじ */\n story: \"s\",\n /** 大ジャンル */\n biggenre: \"bg\",\n /** ジャンル */\n genre: \"g\",\n /** キーワード */\n keyword: \"k\",\n /** 初回掲載日 */\n general_firstup: \"gf\",\n /** 最終掲載日 */\n general_lastup: \"gl\",\n /** 連載の場合は1、短編の場合は2 */\n noveltype: \"nt\",\n /** 短編小説と完結済小説は0となっています。連載中は1です。 */\n end: \"e\",\n /** 全掲載部分数 */\n general_all_no: \"ga\",\n /** 小説文字数 */\n length: \"l\",\n /** 読了時間(分単位) */\n time: \"ti\",\n /** 長期連載停止中 */\n isstop: \"i\",\n /** 登録必須キーワードに「R15」が含まれる場合は1、それ以外は0です。 */\n isr15: \"isr\",\n /** 登録必須キーワードに「ボーイズラブ」が含まれる場合は1、それ以外は0です。 */\n isbl: \"ibl\",\n /** 登録必須キーワードに「ガールズラブ」が含まれる場合は1、それ以外は0です。 */\n isgl: \"igl\",\n /** 登録必須キーワードに「残酷な描写あり」が含まれる場合は1、それ以外は0です。 */\n iszankoku: \"izk\",\n /** 登録必須キーワードに「異世界転生」が含まれる場合は1、それ以外は0です。 */\n istensei: \"its\",\n /** 登録必須キーワードに「異世界転移」が含まれる場合は1、それ以外は0です。 */\n istenni: \"iti\",\n /** 総合評価ポイント */\n global_point: \"gp\",\n /** 日間ポイント */\n daily_point: \"dp\",\n /** 週間ポイント */\n weekly_point: \"wp\",\n /** 月間ポイント */\n monthly_point: \"mp\",\n /** 四半期ポイント */\n quarter_point: \"qp\",\n /** 年間ポイント */\n yearly_point: \"yp\",\n /** ブックマーク数 */\n fav_novel_cnt: \"f\",\n /** 感想数 */\n impression_cnt: \"imp\",\n /** レビュー数 */\n review_cnt: \"r\",\n /** 評価ポイント */\n all_point: \"a\",\n /** 評価者数 */\n all_hyoka_cnt: \"ah\",\n /** 挿絵の数 */\n sasie_cnt: \"sa\",\n /** 会話率 */\n kaiwaritu: \"ka\",\n /** 小説の更新日時 */\n novelupdated_at: \"nu\",\n /**\n * 最終更新日時\n * システム用で小説更新時とは関係ありません\n */\n updated_at: \"ua\",\n} as const;\n\nexport type Fields = (typeof Fields)[keyof Omit<\n NarouSearchResult,\n \"novel_type\" | \"weekly_unique\" | \"nocgenre\"\n>];\n\n/**\n * なろうR18小説APIのofパラメータに指定できる出力する項目\n * @see https://dev.syosetu.com/xman/api/#output\n */\nexport const R18Fields = {\n /** 小説名 */\n title: \"t\",\n /** Nコード */\n ncode: \"n\",\n /** 作者のユーザID(数値) */\n userid: \"u\",\n /** 作者名 */\n writer: \"w\",\n /** 小説のあらすじ */\n story: \"s\",\n /** 掲載サイト */\n nocgenre: \"ng\",\n /** キーワード */\n keyword: \"k\",\n /** 初回掲載日 */\n general_firstup: \"gf\",\n /** 最終掲載日 */\n general_lastup: \"gl\",\n /** 連載の場合は1、短編の場合は2 */\n noveltype: \"nt\",\n /** 短編小説と完結済小説は0となっています。連載中は1です。 */\n end: \"e\",\n /** 全掲載部分数 */\n general_all_no: \"ga\",\n /** 小説文字数 */\n length: \"l\",\n /** 読了時間(分単位) */\n time: \"ti\",\n /** 長期連載停止中 */\n isstop: \"i\",\n /** 登録必須キーワードに「ボーイズラブ」が含まれる場合は1、それ以外は0です。 */\n isbl: \"ibl\",\n /** 登録必須キーワードに「ガールズラブ」が含まれる場合は1、それ以外は0です。 */\n isgl: \"igl\",\n /** 登録必須キーワードに「残酷な描写あり」が含まれる場合は1、それ以外は0です。 */\n iszankoku: \"izk\",\n /** 登録必須キーワードに「異世界転生」が含まれる場合は1、それ以外は0です。 */\n istensei: \"its\",\n /** 登録必須キーワードに「異世界転移」が含まれる場合は1、それ以外は0です。 */\n istenni: \"iti\",\n /** 総合評価ポイント */\n global_point: \"gp\",\n /** 日間ポイント */\n daily_point: \"dp\",\n /** 週間ポイント */\n weekly_point: \"wp\",\n /** 月間ポイント */\n monthly_point: \"mp\",\n /** 四半期ポイント */\n quarter_point: \"qp\",\n /** 年間ポイント */\n yearly_point: \"yp\",\n /** R18ブックマーク数 */\n fav_novel_cnt: \"f\",\n /** 感想数 */\n impression_cnt: \"imp\",\n /** レビュー数 */\n review_cnt: \"r\",\n /** 評価ポイント */\n all_point: \"a\",\n /** 評価者数 */\n all_hyoka_cnt: \"ah\",\n /** 挿絵の数 */\n sasie_cnt: \"sa\",\n /** 会話率 */\n kaiwaritu: \"ka\",\n /** 小説の更新日時 */\n novelupdated_at: \"nu\",\n /**\n * 最終更新日時\n * システム用で小説更新時とは関係ありません\n */\n updated_at: \"ua\",\n} as const;\n\nexport type R18Fields = (typeof R18Fields)[keyof Omit<\n NarouSearchResult,\n \"novel_type\" | \"weekly_unique\" | \"biggenre\" | \"genre\" | \"isr15\"\n>];\n\n/**\n * オプション項目\n */\nexport const OptionalFields = {\n /**\n * 週間ユニークユーザ[項目名:weekly_unique]が追加されます。\n * 週間ユニークユーザは前週の日曜日から土曜日分のユニークの合計です。\n * 毎週火曜日早朝に更新されます。\n */\n weekly_unique: \"weekly\",\n} as const;\n\nexport type OptionalFields = (typeof OptionalFields)[keyof Pick<\n NarouSearchResult,\n \"weekly_unique\"\n>];\n\n/**\n * ユーザ検索APIのofパラメータに指定できる出力する項目\n * @see https://dev.syosetu.com/man/userapi/#output\n */\nexport const UserFields = {\n /** ユーザID */\n userid: \"u\",\n /** ユーザ名 */\n name: \"n\",\n /** ユーザ名のフリガナ */\n yomikata: \"y\",\n /** ユーザ名のフリガナの頭文字 */\n name1st: \"1\",\n /** 小説投稿数 */\n novel_cnt: \"nc\",\n /** レビュー投稿数 */\n review_cnt: \"rc\",\n /** 小説累計文字数 */\n novel_length: \"nl\",\n /** 総合評価ポイントの合計 */\n sum_global_point: \"sg\",\n} as const;\nexport type UserFields = (typeof UserFields)[keyof UserSearchResult];\n\n/**\n * 出力順序\n */\nexport const Order = {\n /** ブックマーク数の多い順 */\n FavoriteNovelCount: \"favnovelcnt\",\n /** レビュー数の多い順 */\n ReviewCount: \"favnovelcnt\",\n /** 総合ポイントの高い順 */\n HyokaDesc: \"hyoka\",\n /** 総合ポイントの低い順 */\n HyokaAsc: \"hyokaasc\",\n /** 感想の多い順 */\n ImpressionCount: \"impressioncnt\",\n /** 評価者数の多い順 */\n HyokaCountDesc: \"hyokacnt\",\n /** 評価者数の少ない順 */\n HyokaCountAsc: \"hyokacntasc\",\n /** 週間ユニークユーザの多い順 */\n Weekly: \"weekly\",\n /** 小説本文の文字数が多い順 */\n LengthDesc: \"lengthdesc\",\n /** 小説本文の文字数が少ない順 */\n LengthAsc: \"lengthasc\",\n /** Nコードが新しい順 */\n NCodeDesc: \"ncodedesc\",\n /** 新着更新順 */\n New: \"new\",\n /** 古い順 */\n Old: \"old\",\n /** 日間ポイントの高い順 */\n DailyPoint: \"dailypoint\",\n /** 週間ポイントの高い順 */\n WeeklyPoint: \"weeklypoint\",\n /** 月間ポイントの高い順 */\n MonthlyPoint: \"monthlypoint\",\n /** 四半期ポイントの高い順 */\n QuarterPoint: \"quarterpoint\",\n /** 年間ポイントの高い順 */\n YearlyPoint: \"yearlypoint\",\n /** 初回掲載順 */\n GeneralFirstUp: \"generalfirstup\",\n} as const;\n\nexport type Order = (typeof Order)[keyof typeof Order];\n\n/** R18掲載サイト */\nexport const R18Site = {\n /** ノクターンノベルズ(男性向け) */\n Nocturne: 1,\n /** ムーンライトノベルズ(女性向け) */\n MoonLight: 2,\n /** ムーンライトノベルズ(BL) */\n MoonLightBL: 3,\n /** ミッドナイトノベルズ(大人向け) */\n Midnight: 4,\n} as const;\n\nexport type R18Site = (typeof R18Site)[keyof typeof R18Site];\n\n/** R18掲載サイト表記ヘルパー */\nexport const R18SiteNotation: { readonly [K in R18Site]: string } = {\n [R18Site.Nocturne]: \"ノクターンノベルズ(男性向け)\",\n [R18Site.MoonLight]: \"ムーンライトノベルズ(女性向け)\",\n [R18Site.MoonLightBL]: \"ムーンライトノベルズ(BL)\",\n [R18Site.Midnight]: \"ミッドナイトノベルズ(大人向け)\",\n} as const;\n\n/** 大ジャンル */\nexport const BigGenre = {\n /** 恋愛 */\n Renai: 1,\n /** ファンタジー */\n Fantasy: 2,\n /** 文芸 */\n Bungei: 3,\n /** SF */\n Sf: 4,\n /** その他 */\n Sonota: 99,\n /** ノンジャンル */\n NonGenre: 98,\n} as const;\n\nexport type BigGenre = (typeof BigGenre)[keyof typeof BigGenre];\n\n/** 大ジャンル表記ヘルパー */\nexport const BigGenreNotation: { readonly [K in BigGenre]: string } = {\n [BigGenre.Renai]: \"恋愛\",\n [BigGenre.Fantasy]: \"ファンタジー\",\n [BigGenre.Bungei]: \"文芸\",\n [BigGenre.Sf]: \"SF\",\n [BigGenre.Sonota]: \"その他\",\n [BigGenre.NonGenre]: \"ノンジャンル\",\n} as const;\n\n/** ジャンル */\nexport const Genre = {\n /** 異世界〔恋愛〕*/\n RenaiIsekai: 101,\n /** 現実世界〔恋愛〕*/\n RenaiGenjitsusekai: 102,\n /** ハイファンタジー〔ファンタジー〕*/\n FantasyHigh: 201,\n /** ローファンタジー〔ファンタジー〕*/\n FantasyLow: 202,\n /** 純文学〔文芸〕*/\n BungeiJyunbungei: 301,\n /** ヒューマンドラマ〔文芸〕*/\n BungeiHumanDrama: 302,\n /** 歴史〔文芸〕*/\n BungeiHistory: 303,\n /** 推理〔文芸〕*/\n BungeiSuiri: 304,\n /** ホラー〔文芸〕*/\n BungeiHorror: 305,\n /** アクション〔文芸〕*/\n BungeiAction: 306,\n /** コメディー〔文芸〕*/\n BungeiComedy: 307,\n /** VRゲーム〔SF〕*/\n SfVrgame: 401,\n /** 宇宙〔SF〕*/\n SfSpace: 402,\n /** 空想科学〔SF〕*/\n SfKuusoukagaku: 403,\n /** パニック〔SF〕*/\n SfPanic: 404,\n /** 童話〔その他〕*/\n SonotaDouwa: 9901,\n /** 詩〔その他〕*/\n SonotaShi: 9902,\n /** エッセイ〔その他〕*/\n SonotaEssei: 9903,\n /** リプレイ〔その他〕*/\n SonotaReplay: 9904,\n /** その他〔その他〕 */\n SonotaSonota: 9999,\n /** ノンジャンル〔ノンジャンル〕*/\n NonGenre: 9801,\n} as const;\nexport type Genre = (typeof Genre)[keyof typeof Genre];\n\n/** ジャンル表記ヘルパー */\nexport const GenreNotation: { readonly [K in Genre]: string } = {\n [Genre.RenaiIsekai]: \"異世界〔恋愛〕\",\n [Genre.RenaiGenjitsusekai]: \"現実世界〔恋愛〕\",\n [Genre.FantasyHigh]: \"ハイファンタジー〔ファンタジー〕\",\n [Genre.FantasyLow]: \"ローファンタジー〔ファンタジー〕\",\n [Genre.BungeiJyunbungei]: \"純文学〔文芸〕\",\n [Genre.BungeiHumanDrama]: \"ヒューマンドラマ〔文芸〕\",\n [Genre.BungeiHistory]: \"歴史〔文芸〕\",\n [Genre.BungeiSuiri]: \"推理〔文芸〕\",\n [Genre.BungeiHorror]: \"ホラー〔文芸〕\",\n [Genre.BungeiAction]: \"アクション〔文芸〕\",\n [Genre.BungeiComedy]: \"コメディー〔文芸〕\",\n [Genre.SfVrgame]: \"VRゲーム〔SF〕\",\n [Genre.SfSpace]: \"宇宙〔SF〕\",\n [Genre.SfKuusoukagaku]: \"空想科学〔SF〕\",\n [Genre.SfPanic]: \"パニック〔SF〕\",\n [Genre.SonotaDouwa]: \"童話〔その他〕\",\n [Genre.SonotaShi]: \"詩〔その他〕\",\n [Genre.SonotaEssei]: \"エッセイ〔その他〕\",\n [Genre.SonotaReplay]: \"リプレイ〔その他〕\",\n [Genre.SonotaSonota]: \"その他〔その他〕\",\n [Genre.NonGenre]: \"ノンジャンル〔ノンジャンル〕\",\n} as const;\n\n/** 文体指定 */\nexport const BuntaiParam = {\n /** 字下げされておらず、連続改行が多い作品 */\n NoJisageKaigyouOoi: 1,\n /** 字下げされていないが、改行数は平均な作品 */\n NoJisageKaigyoHutsuu: 2,\n /** 字下げが適切だが、連続改行が多い作品 */\n JisageKaigyoOoi: 4,\n /** 字下げが適切でかつ改行数も平均な作品 */\n JisageKaigyoHutsuu: 6,\n} as const;\n\nexport type BuntaiParam = (typeof BuntaiParam)[keyof typeof BuntaiParam];\n\n/** 連載停止中指定 */\nexport const StopParam = {\n /** 長期連載停止中を除きます */\n NoStopping: 1,\n /** 長期連載停止中のみ取得します */\n Stopping: 2,\n} as const;\n\nexport type StopParam = (typeof StopParam)[keyof typeof StopParam];\n\n/** 小説タイプ指定 */\nexport const NovelTypeParam = {\n /** 短編 */\n Short: \"t\",\n /** 連載中 */\n RensaiNow: \"r\",\n /** 完結済連載小説 */\n RensaiEnd: \"er\",\n /** すべての連載小説(連載中および完結済) */\n Rensai: \"re\",\n /** 短編と完結済連載小説 */\n ShortAndRensai: \"ter\",\n} as const;\nexport type NovelTypeParam =\n (typeof NovelTypeParam)[keyof typeof NovelTypeParam];\n\n/** 日付指定パラメータ */\nexport const DateParam = {\n ThisWeek: \"thisweek\",\n LastWeek: \"lastweek\",\n SevenDays: \"sevenday\",\n ThisMonth: \"thismonth\",\n LastMonth: \"lastmonth\",\n};\nexport type DateParam = (typeof DateParam)[keyof typeof DateParam];\n\nexport const UserOrder = {\n /** ユーザIDの新しい順 */\n New: \"new\",\n /** 小説投稿数の多い順 */\n NovelCount: \"novelcnt\",\n /** レビュー投稿数の多い順 */\n ReviewCount: \"reviewcnt\",\n /** 小説累計文字数の多い順 */\n NovelLength: \"novellength\",\n /** 総合評価ポイントの合計の多い順 */\n SumGlobalPoint: \"sumglobalpoint\",\n /** ユーザIDの古い順 */\n Old: \"old\",\n} as const;\nexport type UserOrder = (typeof UserOrder)[keyof typeof UserOrder];\n\nexport type GzipLevel = 0 | 1 | 2 | 3 | 4 | 5;\n","import type NarouNovel from \"./narou.js\";\nimport type {\n NarouSearchResult,\n SearchResultFields,\n SearchResultOptionalFields,\n} from \"./narou-search-results.js\";\nimport type NarouSearchResults from \"./narou-search-results.js\";\nimport type {\n BigGenre,\n SearchResultFieldNames,\n Genre,\n SearchParams,\n Fields,\n Order,\n BuntaiParam,\n NovelTypeParam,\n GzipLevel,\n OptionalFields,\n ParamsBaseWithOrder,\n DateParam,\n} from \"./params.js\";\nimport { BooleanNumber, StopParam } from \"./params.js\";\nimport type { Join } from \"./util/type.js\";\n\nexport type DefaultSearchResultFields = keyof Omit<\n NarouSearchResult,\n \"weekly_unique\" | \"noveltype\" | \"nocgenre\" | \"xid\"\n>;\n\nexport abstract class SearchBuilderBase<\n TParams extends ParamsBaseWithOrder<TOrder>,\n TOrder extends string,\n> {\n /**\n * constructor\n * @private\n * @param params クエリパラメータ\n * @param api NarouNovel インスタンス\n */\n constructor(\n protected params: TParams = {} as TParams,\n protected api: NarouNovel\n ) {}\n\n /**\n * 配列から重複を除去する\n * @protected\n * @static\n * @param array 配列\n * @returns 重複を除去した配列\n */\n protected static distinct<T>(array: readonly T[]): T[] {\n return Array.from(new Set(array));\n }\n\n /**\n * 配列をハイフン区切りの文字列に変換する\n * @protected\n * @static\n * @param n 文字列または数値の配列、あるいは単一の文字列または数値\n * @returns ハイフン区切りの文字列\n */\n protected static array2string<T extends string | number>(\n n: T | readonly T[]\n ): Join<T> {\n if (Array.isArray(n)) {\n return this.distinct(n).join(\"-\") as Join<T>;\n } else {\n return n.toString() as Join<T>;\n }\n }\n\n /**\n * 取得件数を指定する (lim)\n * @param num 取得件数 (1-500)\n * @return {this}\n */\n limit(num: number): this {\n this.set({ lim: num } as TParams);\n return this;\n }\n\n /**\n * 取得開始位置を指定する (st)\n * @param num 取得開始位置 (1-)\n * @return {this}\n */\n start(num: number): this {\n this.set({ st: num } as TParams);\n return this;\n }\n\n /**\n * ページ番号と1ページあたりの件数で取得範囲を指定する\n * @param no ページ番号 (0-)\n * @param count 1ページあたりの件数 (デフォルト: 20)\n * @return {this}\n */\n page(no: number, count = 20): this {\n return this.limit(count).start(no * count);\n }\n\n /**\n * 出力順序を指定する (order)\n * 指定しない場合は新着順となります。\n * @param {TOrder} order 出力順序\n * @return {this}\n */\n order(order: TOrder): this {\n this.set({ order: order } as TParams);\n return this;\n }\n\n /**\n * gzip圧縮レベルを指定する (gzip)\n *\n * 転送量上限を減らすためにも推奨\n * @param {GzipLevel} level gzip圧縮レベル(1~5)\n * @return {this}\n */\n gzip(level: GzipLevel): this {\n this.set({ gzip: level } as TParams);\n return this;\n }\n\n /**\n * クエリパラメータをセットする\n * @protected\n * @param obj セットするパラメータ\n * @return {this}\n */\n protected set(obj: TParams): this {\n this.params = { ...this.params, ...obj };\n return this;\n }\n\n /**\n * クエリパラメータを削除する\n * @protected\n * @param key 削除するパラメータのキー\n * @returns {this}\n */\n protected unset(key: keyof TParams): this {\n delete this.params[key];\n return this;\n }\n}\n\nexport abstract class NovelSearchBuilderBase<\n T extends SearchResultFieldNames,\n> extends SearchBuilderBase<SearchParams, Order> {\n /**\n * 検索語を指定します (word)。\n * 半角または全角スペースで区切るとAND抽出になります。部分一致でHITします。\n * @param word 検索語\n * @return {this}\n */\n word(word: string): this {\n this.set({ word: word });\n return this;\n }\n\n /**\n * 除外したい単語を指定します (notword)。\n * スペースで区切ることにより除外する単語を増やせます。部分一致で除外されます。\n * @param word 除外語\n * @return {this}\n */\n notWord(word: string): this {\n this.set({ notword: word });\n return this;\n }\n\n /**\n * 検索対象を作品名に限定するかどうかを指定します (title)。\n * @param bool trueの場合、作品名を検索対象とする (デフォルト: true)\n * @return {this}\n */\n byTitle(bool = true): this {\n this.set({ title: bool ? BooleanNumber.True : BooleanNumber.False });\n return this;\n }\n\n /**\n * 検索対象をあらすじに限定するかどうかを指定します (ex)。\n * @param bool trueの場合、あらすじを検索対象とする (デフォルト: true)\n * @return {this}\n */\n byOutline(bool = true): this {\n this.set({ ex: bool ? BooleanNumber.True : BooleanNumber.False });\n return this;\n }\n\n /**\n * 検索対象をキーワードに限定するかどうかを指定します (keyword)。\n * @param bool trueの場合、キーワードを検索対象とする (デフォルト: true)\n * @return {this}\n */\n byKeyword(bool = true): this {\n this.set({ keyword: bool ? BooleanNumber.True : BooleanNumber.False });\n return this;\n }\n\n /**\n * 検索対象を作者名に限定するかどうかを指定します (wname)。\n * @param bool trueの場合、作者名を検索対象とする (デフォルト: true)\n * @return {this}\n */\n byAuthor(bool = true): this {\n this.set({ wname: bool ? BooleanNumber.True : BooleanNumber.False });\n return this;\n }\n\n /**\n * ボーイズラブ作品を抽出または除外します (isbl/notbl)。\n * @param bool trueの場合、ボーイズラブ作品を抽出する (デフォルト: true)。falseの場合、除外する。\n * @return {this}\n */\n isBL(bool = true): this {\n if (bool) {\n this.set({ isbl: BooleanNumber.True });\n } else {\n this.set({ notbl: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n * ガールズラブ作品を抽出または除外します (isgl/notgl)。\n * @param bool trueの場合、ガールズラブ作品を抽出する (デフォルト: true)。falseの場合、除外する。\n * @return {this}\n */\n isGL(bool = true): this {\n if (bool) {\n this.set({ isgl: BooleanNumber.True });\n } else {\n this.set({ notgl: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n * 残酷な描写あり作品を抽出または除外します (iszankoku/notzankoku)。\n * @param bool trueの場合、残酷な描写あり作品を抽出する (デフォルト: true)。falseの場合、除外する。\n * @return {this}\n */\n isZankoku(bool = true): this {\n if (bool) {\n this.set({ iszankoku: BooleanNumber.True });\n } else {\n this.set({ notzankoku: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n * 異世界転生作品を抽出または除外します (istensei/nottensei)。\n * @param bool trueの場合、異世界転生作品を抽出する (デフォルト: true)。falseの場合、除外する。\n * @return {this}\n */\n isTensei(bool = true): this {\n if (bool) {\n this.set({ istensei: BooleanNumber.True });\n } else {\n this.set({ nottensei: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n * 異世界転移作品を抽出または除外します (istenni/nottenni)。\n * @param bool trueの場合、異世界転移作品を抽出する (デフォルト: true)。falseの場合、除外する。\n * @return {this}\n */\n isTenni(bool = true): this {\n if (bool) {\n this.set({ istenni: BooleanNumber.True });\n } else {\n this.set({ nottenni: BooleanNumber.True });\n }\n return this;\n }\n\n /**\n * 異世界転生または異世界転移作品を抽出します (istt)。\n * @return {this}\n */\n isTT(): this {\n this.set({ istt: BooleanNumber.True });\n return this;\n }\n\n /**\n * 抽出する作品の文字数を指定します (length)。\n * 範囲指定する場合は、最小文字数と最大文字数をハイフン(-)記号で区切ってください。\n * @param length 文字数、または[最小文字数, 最大文字数]\n * @return {this}\n */\n length(length: number | readonly number[]): this {\n this.set({ length: NovelSearchBuilderBase.array2string(length) });\n return this;\n }\n\n /**\n * 抽出する作品の会話率を%単位で指定します (kaiwaritu)。\n * @param num 会話率(%)\n * @return {this}\n */\n kaiwaritu(num: number): this;\n /**\n * 抽出する作品の会話率を%単位で範囲指定します (kaiwaritu)。\n * @param min 最低会話率(%)\n * @param max 最高会話率(%)\n * @return {this}\n */\n kaiwaritu(min: number, max: number): this;\n\n kaiwaritu(min: number, max?: number): this {\n let n: number | string;\n if (max != null) {\n n = `${min}-${max}`;\n } else {\n n = min;\n }\n this.set({ kaiwaritu: n });\n return this;\n }\n\n /**\n * 抽出する作品の挿絵数を指定します (sasie)。\n * @param num 挿絵数、または[最小挿絵数, 最大挿絵数]\n * @return {this}\n */\n sasie(num: number | readonly number[]): this {\n this.set({ sasie: NovelSearchBuilderBase.array2string(num) });\n return this;\n }\n\n /**\n * 抽出する作品の予想読了時間を分単位で指定します (time)。\n * @param num 読了時間(分)、または[最小読了時間, 最大読了時間]\n * @return {this}\n */\n time(num: number | readonly number[]): this {\n this.set({ time: NovelSearchBuilderBase.array2string(num) });\n return this;\n }\n\n /**\n * Nコードを指定して取得します (ncode)。\n * @param ncodes Nコード、またはNコードの配列\n * @return {this}\n */\n ncode(ncodes: string | readonly string[]): this {\n this.set({ ncode: NovelSearchBuilderBase.array2string(ncodes) });\n return this;\n }\n\n /**\n * 抽出する小説タイプを指定します (type)。\n * @param type 小説タイプ (t: 短編, r: 連載中, er: 完結済連載小説, ter: 短編と完結済連載小説, re: 連載中と完結済連載小説)\n * @return {this}\n */\n type(type: NovelTypeParam): this {\n this.set({ type });\n return this;\n }\n\n /**\n * 抽出する作品の文体を指定します (buntai)。\n * 複数指定する場合はハイフン(-)で区切ってください。\n * @param buntai 文体コード、または文体コードの配列\n * @return {this}\n */\n buntai(buntai: BuntaiParam | readonly BuntaiParam[]): this {\n this.set({ buntai: NovelSearchBuilderBase.array2string(buntai) });\n return this;\n }\n\n /**\n * 連載停止中作品に関する指定をします (stop)。\n * @param bool trueの場合、長期連載停止中のみ取得する (デフォルト: true)。falseの場合、長期連載停止中を除外する。\n * @return {this}\n */\n isStop(bool = true): this {\n this.set({ stop: bool ? StopParam.Stopping : StopParam.NoStopping });\n return this;\n }\n\n /**\n * ピックアップ作品のみを取得します (ispickup)。\n * @return {this}\n */\n isPickup(): this {\n this.set({ ispickup: BooleanNumber.True });\n return this;\n }\n\n /**\n * 最終更新日時を指定します (lastup)。\n * @param date 最終更新日時 (YYYYMMDDhhmmss形式またはUNIXタイムスタンプ)\n * @return {this}\n */\n lastUpdate(date: DateParam): this;\n /**\n * 最終更新日時の範囲を指定します (lastup)。\n * @param from 開始日時 (UNIXタイムスタンプ)\n * @param to 終了日時 (UNIXタイムスタンプ)\n * @return {this}\n */\n lastUpdate(from: number, to: number): this;\n /**\n * 最終更新日時の範囲を指定します (lastup)。\n * @param from 開始日時 (Dateオブジェクト)\n * @param to 終了日時 (Dateオブジェクト)\n * @return {this}\n */\n lastUpdate(from: Date, to: Date): this;\n\n lastUpdate(x: string | number | Date, y?: number | Date): this {\n let date: string;\n if (typeof x == \"string\") {\n date = x;\n } else if (x instanceof Date && y instanceof Date) {\n date = `${Math.floor(x.getTime() / 1000)}-${Math.floor(\n y.getTime() / 1000\n )}`;\n } else {\n date = `${x}-${y}`;\n }\n\n this.set({ lastup: date });\n return this;\n }\n\n /**\n * 作品の更新日時を指定します (lastupdate)。\n * @param date 作品の更新日時 (YYYYMMDDhhmmss形式またはUNIXタイムスタンプ)\n * @return {this}\n */\n lastNovelUpdate(date: DateParam): this;\n /**\n * 作品の更新日時の範囲を指定します (lastupdate)。\n * @param from 開始日時 (UNIXタイムスタンプ)\n * @param to 終了日時 (UNIXタイムスタンプ)\n * @return {this}\n */\n lastNovelUpdate(from: number, to: number): this;\n /**\n * 作品の更新日時の範囲を指定します (lastupdate)。\n * @param from 開始日時 (Dateオブジェクト)\n * @param to 終了日時 (Dateオブジェクト)\n * @return {this}\n */\n lastNovelUpdate(from: Date, to: Date): this;\n\n lastNovelUpdate(x: string | number | Date, y?: number | Date): this {\n let date: string;\n if (typeof x == \"string\") {\n date = x;\n } else if (x instanceof Date && y instanceof Date) {\n date = `${Math.floor(x.getTime() / 1000)}-${Math.floor(\n y.getTime() / 1000\n )}`;\n } else {\n date = `${x}-${y}`;\n }\n\n this.set({ lastupdate: date });\n return this;\n }\n\n /**\n * なろう小説APIへの検索リクエストを実行する\n * @returns {Promise<NarouSearchResults>} 検索結果\n */\n execute(): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return this.api.executeNovel(this.params);\n }\n}\n\n/**\n * 検索ヘルパー\n * @class SearchBuilder\n */\nexport default class SearchBuilder<\n T extends keyof NarouSearchResult = DefaultSearchResultFields,\n TOpt extends keyof NarouSearchResult = never,\n> extends NovelSearchBuilderBase<T | TOpt> {\n /**\n * 大ジャンルを指定して取得します (biggenre)。\n * 複数指定する場合はハイフン(-)で区切ってください。\n * @param genre 大ジャンルコード、または大ジャンルコードの配列\n * @return {this}\n */\n bigGenre(genre: BigGenre | readonly BigGenre[]): this {\n this.set({ biggenre: SearchBuilder.array2string(genre) });\n return this;\n }\n\n /**\n * 除外したい大ジャンルを指定します (notbiggenre)。\n * 複数指定する場合はハイフン(-)で区切ってください。\n * @param genre 除外する大ジャンルコード、または大ジャンルコードの配列\n * @return {this}\n */\n notBigGenre(genre: BigGenre | readonly BigGenre[]): this {\n this.set({ notbiggenre: SearchBuilder.array2string(genre) });\n return this;\n }\n\n /**\n * ジャンルを指定して取得します (genre)。\n * 複数指定する場合はハイフン(-)で区切ってください。\n * @param genre ジャンルコード、またはジャンルコードの配列\n * @return {this}\n */\n genre(genre: Genre | readonly Genre[]): this {\n this.set({ genre: SearchBuilder.array2string(genre) });\n return this;\n }\n\n /**\n * 除外したいジャンルを指定します (notgenre)。\n * 複数指定する場合はハイフン(-)で区切ってください。\n * @param genre 除外するジャンルコード、またはジャンルコードの配列\n * @return {this}\n */\n notGenre(genre: Genre | readonly Genre[]): this {\n this.set({ notgenre: SearchBuilder.array2string(genre) });\n return this;\n }\n\n /**\n * ユーザIDを指定して取得します (userid)。\n * 複数指定する場合はハイフン(-)で区切ってください。\n * @param ids ユーザID、またはユーザIDの配列\n * @return {this}\n */\n userId(ids: number | readonly number[]): this {\n this.set({ userid: SearchBuilder.array2string(ids) });\n return this;\n }\n\n /**\n * R15作品を抽出または除外します (isr15/notr15)。\n * @param bool trueの場合、R15作品を抽出する (デフォルト: true)。falseの場合、除外する。\n * @return {this}\n */\n isR15(bool = true): this {\n if (bool) {\n this.set({ isr15: 1 });\n } else {\n this.set({ notr15: 1 });\n }\n return this;\n }\n\n /**\n * 出力する項目を個別に指定します (of)。\n * 未指定時は全項目出力されます。転送量軽減のため、このパラメータの使用が推奨されます。\n * 複数項目を出力する場合はハイフン(-)記号で区切ってください。\n * @param fields 出力するフィールド名、またはフィールド名の配列\n * @return {SearchBuilder<SearchResultFields<TFields>, TOpt>} 型が更新されたビルダー\n */\n fields<TFields extends Fields>(\n fields: TFields | readonly TFields[]\n ): SearchBuilder<SearchResultFields<TFields>, TOpt> {\n this.set({ of: SearchBuilder.array2string(fields) });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this as any;\n }\n\n /**\n * 出力オプション項目を指定します (opt)。\n * 複数項目を出力する場合はハイフン(-)記号で区切ってください。\n * @param option 出力するオプションフィールド名、またはオプションフィールド名の配列\n * @return {SearchBuilder<T, SearchResultOptionalFields<TFields>>} 型が更新されたビルダー\n */\n opt<TFields extends OptionalFields>(\n option: TFields | readonly TFields[]\n ): SearchBuilder<T, SearchResultOptionalFields<TFields>> {\n this.set({ opt: SearchBuilder.array2string(option) });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this as any;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACgJO,IAAM,gBAAgB;AAAA,EAC3B,MAAM;AAAA,EACN,OAAO;AACT;AA2QO,IAAM,UAAU;AAAA;AAAA,EAErB,UAAU;AAAA;AAAA,EAEV,WAAW;AAAA;AAAA,EAEX,aAAa;AAAA;AAAA,EAEb,UAAU;AACZ;AAKO,IAAM,kBAAuD;AAAA,EAClE,CAAC,QAAQ,QAAQ,GAAG;AAAA,EACpB,CAAC,QAAQ,SAAS,GAAG;AAAA,EACrB,CAAC,QAAQ,WAAW,GAAG;AAAA,EACvB,CAAC,QAAQ,QAAQ,GAAG;AACtB;AAGO,IAAM,WAAW;AAAA;AAAA,EAEtB,OAAO;AAAA;AAAA,EAEP,SAAS;AAAA;AAAA,EAET,QAAQ;AAAA;AAAA,EAER,IAAI;AAAA;AAAA,EAEJ,QAAQ;AAAA;AAAA,EAER,UAAU;AACZ;AAKO,IAAM,mBAAyD;AAAA,EACpE,CAAC,SAAS,KAAK,GAAG;AAAA,EAClB,CAAC,SAAS,OAAO,GAAG;AAAA,EACpB,CAAC,SAAS,MAAM,GAAG;AAAA,EACnB,CAAC,SAAS,EAAE,GAAG;AAAA,EACf,CAAC,SAAS,MAAM,GAAG;AAAA,EACnB,CAAC,SAAS,QAAQ,GAAG;AACvB;AAGO,IAAM,QAAQ;AAAA;AAAA,EAEnB,aAAa;AAAA;AAAA,EAEb,oBAAoB;AAAA;AAAA,EAEpB,aAAa;AAAA;AAAA,EAEb,YAAY;AAAA;AAAA,EAEZ,kBAAkB;AAAA;AAAA,EAElB,kBAAkB;AAAA;AAAA,EAElB,eAAe;AAAA;AAAA,EAEf,aAAa;AAAA;AAAA,EAEb,cAAc;AAAA;AAAA,EAEd,cAAc;AAAA;AAAA,EAEd,cAAc;AAAA;AAAA,EAEd,UAAU;AAAA;AAAA,EAEV,SAAS;AAAA;AAAA,EAET,gBAAgB;AAAA;AAAA,EAEhB,SAAS;AAAA;AAAA,EAET,aAAa;AAAA;AAAA,EAEb,WAAW;AAAA;AAAA,EAEX,aAAa;AAAA;AAAA,EAEb,cAAc;AAAA;AAAA,EAEd,cAAc;AAAA;AAAA,EAEd,UAAU;AACZ;AAIO,IAAM,gBAAmD;AAAA,EAC9D,CAAC,MAAM,WAAW,GAAG;AAAA,EACrB,CAAC,MAAM,kBAAkB,GAAG;AAAA,EAC5B,CAAC,MAAM,WAAW,GAAG;AAAA,EACrB,CAAC,MAAM,UAAU,GAAG;AAAA,EACpB,CAAC,MAAM,gBAAgB,GAAG;AAAA,EAC1B,CAAC,MAAM,gBAAgB,GAAG;AAAA,EAC1B,CAAC,MAAM,aAAa,GAAG;AAAA,EACvB,CAAC,MAAM,WAAW,GAAG;AAAA,EACrB,CAAC,MAAM,YAAY,GAAG;AAAA,EACtB,CAAC,MAAM,YAAY,GAAG;AAAA,EACtB,CAAC,MAAM,YAAY,GAAG;AAAA,EACtB,CAAC,MAAM,QAAQ,GAAG;AAAA,EAClB,CAAC,MAAM,OAAO,GAAG;AAAA,EACjB,CAAC,MAAM,cAAc,GAAG;AAAA,EACxB,CAAC,MAAM,OAAO,GAAG;AAAA,EACjB,CAAC,MAAM,WAAW,GAAG;AAAA,EACrB,CAAC,MAAM,SAAS,GAAG;AAAA,EACnB,CAAC,MAAM,WAAW,GAAG;AAAA,EACrB,CAAC,MAAM,YAAY,GAAG;AAAA,EACtB,CAAC,MAAM,YAAY,GAAG;AAAA,EACtB,CAAC,MAAM,QAAQ,GAAG;AACpB;AAiBO,IAAM,YAAY;AAAA;AAAA,EAEvB,YAAY;AAAA;AAAA,EAEZ,UAAU;AACZ;;;AC9gBO,IAAe,oBAAf,MAGL;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,YACY,SAAkB,CAAC,GACnB,KACV;AAFU;AACA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASH,OAAiB,SAAY,OAA0B;AACrD,WAAO,MAAM,KAAK,IAAI,IAAI,KAAK,CAAC;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAiB,aACf,GACS;AACT,QAAI,MAAM,QAAQ,CAAC,GAAG;AACpB,aAAO,KAAK,SAAS,CAAC,EAAE,KAAK,GAAG;AAAA,IAClC,OAAO;AACL,aAAO,EAAE,SAAS;AAAA,IACpB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,KAAmB;AACvB,SAAK,IAAI,EAAE,KAAK,IAAI,CAAY;AAChC,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,KAAmB;AACvB,SAAK,IAAI,EAAE,IAAI,IAAI,CAAY;AAC/B,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,KAAK,IAAY,QAAQ,IAAU;AACjC,WAAO,KAAK,MAAM,KAAK,EAAE,MAAM,KAAK,KAAK;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,OAAqB;AACzB,SAAK,IAAI,EAAE,MAAa,CAAY;AACpC,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,KAAK,OAAwB;AAC3B,SAAK,IAAI,EAAE,MAAM,MAAM,CAAY;AACnC,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQU,IAAI,KAAoB;AAChC,SAAK,SAAS,EAAE,GAAG,KAAK,QAAQ,GAAG,IAAI;AACvC,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQU,MAAM,KAA0B;AACxC,WAAO,KAAK,OAAO,GAAG;AACtB,WAAO;AAAA,EACT;AACF;AAEO,IAAe,yBAAf,MAAe,gCAEZ,kBAAuC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAO/C,KAAK,MAAoB;AACvB,SAAK,IAAI,EAAE,KAAW,CAAC;AACvB,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,QAAQ,MAAoB;AAC1B,SAAK,IAAI,EAAE,SAAS,KAAK,CAAC;AAC1B,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,QAAQ,OAAO,MAAY;AACzB,SAAK,IAAI,EAAE,OAAO,OAAO,cAAc,OAAO,cAAc,MAAM,CAAC;AACnE,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,UAAU,OAAO,MAAY;AAC3B,SAAK,IAAI,EAAE,IAAI,OAAO,cAAc,OAAO,cAAc,MAAM,CAAC;AAChE,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,UAAU,OAAO,MAAY;AAC3B,SAAK,IAAI,EAAE,SAAS,OAAO,cAAc,OAAO,cAAc,MAAM,CAAC;AACrE,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,SAAS,OAAO,MAAY;AAC1B,SAAK,IAAI,EAAE,OAAO,OAAO,cAAc,OAAO,cAAc,MAAM,CAAC;AACnE,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,KAAK,OAAO,MAAY;AACtB,QAAI,MAAM;AACR,WAAK,IAAI,EAAE,MAAM,cAAc,KAAK,CAAC;AAAA,IACvC,OAAO;AACL,WAAK,IAAI,EAAE,OAAO,cAAc,KAAK,CAAC;AAAA,IACxC;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,KAAK,OAAO,MAAY;AACtB,QAAI,MAAM;AACR,WAAK,IAAI,EAAE,MAAM,cAAc,KAAK,CAAC;AAAA,IACvC,OAAO;AACL,WAAK,IAAI,EAAE,OAAO,cAAc,KAAK,CAAC;AAAA,IACxC;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,UAAU,OAAO,MAAY;AAC3B,QAAI,MAAM;AACR,WAAK,IAAI,EAAE,WAAW,cAAc,KAAK,CAAC;AAAA,IAC5C,OAAO;AACL,WAAK,IAAI,EAAE,YAAY,cAAc,KAAK,CAAC;AAAA,IAC7C;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,SAAS,OAAO,MAAY;AAC1B,QAAI,MAAM;AACR,WAAK,IAAI,EAAE,UAAU,cAAc,KAAK,CAAC;AAAA,IAC3C,OAAO;AACL,WAAK,IAAI,EAAE,WAAW,cAAc,KAAK,CAAC;AAAA,IAC5C;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,QAAQ,OAAO,MAAY;AACzB,QAAI,MAAM;AACR,WAAK,IAAI,EAAE,SAAS,cAAc,KAAK,CAAC;AAAA,IAC1C,OAAO;AACL,WAAK,IAAI,EAAE,UAAU,cAAc,KAAK,CAAC;AAAA,IAC3C;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAa;AACX,SAAK,IAAI,EAAE,MAAM,cAAc,KAAK,CAAC;AACrC,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAO,QAA0C;AAC/C,SAAK,IAAI,EAAE,QAAQ,wBAAuB,aAAa,MAAM,EAAE,CAAC;AAChE,WAAO;AAAA,EACT;AAAA,EAgBA,UAAU,KAAa,KAAoB;AACzC,QAAI;AACJ,QAAI,OAAO,MAAM;AACf,UAAI,GAAG,GAAG,IAAI,GAAG;AAAA,IACnB,OAAO;AACL,UAAI;AAAA,IACN;AACA,SAAK,IAAI,EAAE,WAAW,EAAE,CAAC;AACzB,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,KAAuC;AAC3C,SAAK,IAAI,EAAE,OAAO,wBAAuB,aAAa,GAAG,EAAE,CAAC;AAC5D,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,KAAK,KAAuC;AAC1C,SAAK,IAAI,EAAE,MAAM,wBAAuB,aAAa,GAAG,EAAE,CAAC;AAC3D,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,QAA0C;AAC9C,SAAK,IAAI,EAAE,OAAO,wBAAuB,aAAa,MAAM,EAAE,CAAC;AAC/D,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,KAAK,MAA4B;AAC/B,SAAK,IAAI,EAAE,KAAK,CAAC;AACjB,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAO,QAAoD;AACzD,SAAK,IAAI,EAAE,QAAQ,wBAAuB,aAAa,MAAM,EAAE,CAAC;AAChE,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,OAAO,MAAY;AACxB,SAAK,IAAI,EAAE,MAAM,OAAO,UAAU,WAAW,UAAU,WAAW,CAAC;AACnE,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,WAAiB;AACf,SAAK,IAAI,EAAE,UAAU,cAAc,KAAK,CAAC;AACzC,WAAO;AAAA,EACT;AAAA,EAuBA,WAAW,GAA2B,GAAyB;AAC7D,QAAI;AACJ,QAAI,OAAO,KAAK,UAAU;AACxB,aAAO;AAAA,IACT,WAAW,aAAa,QAAQ,aAAa,MAAM;AACjD,aAAO,GAAG,KAAK,MAAM,EAAE,QAAQ,IAAI,GAAI,CAAC,IAAI,KAAK;AAAA,QAC/C,EAAE,QAAQ,IAAI;AAAA,MAChB,CAAC;AAAA,IACH,OAAO;AACL,aAAO,GAAG,CAAC,IAAI,CAAC;AAAA,IAClB;AAEA,SAAK,IAAI,EAAE,QAAQ,KAAK,CAAC;AACzB,WAAO;AAAA,EACT;AAAA,EAuBA,gBAAgB,GAA2B,GAAyB;AAClE,QAAI;AACJ,QAAI,OAAO,KAAK,UAAU;AACxB,aAAO;AAAA,IACT,WAAW,aAAa,QAAQ,aAAa,MAAM;AACjD,aAAO,GAAG,KAAK,MAAM,EAAE,QAAQ,IAAI,GAAI,CAAC,IAAI,KAAK;AAAA,QAC/C,EAAE,QAAQ,IAAI;AAAA,MAChB,CAAC;AAAA,IACH,OAAO;AACL,aAAO,GAAG,CAAC,IAAI,CAAC;AAAA,IAClB;AAEA,SAAK,IAAI,EAAE,YAAY,KAAK,CAAC;AAC7B,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,UAA6D;AAC3D,WAAO,KAAK,IAAI,aAAa,KAAK,MAAM;AAAA,EAC1C;AACF;;;AFxcA,IAAqB,mBAArB,cAGU,uBAAiC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMzC,UAAoE;AAClE,WAAO,KAAK,IAAI,eAAe,KAAK,MAAM;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,QAAQ,OAAqC;AAC3C,SAAK,IAAI,EAAE,UAAU,uBAAuB,aAAa,KAAK,EAAE,CAAC;AACjE,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAI,KAAiC;AACnC,SAAK,IAAI,EAAE,KAAK,uBAAuB,aAAa,GAAG,EAAE,CAAC;AAC1D,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OACE,QACoD;AACpD,SAAK,IAAI,EAAE,IAAI,uBAAuB,aAAa,MAAM,EAAE,CAAC;AAE5D,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IACE,QAC0D;AAC1D,SAAK,IAAI,EAAE,KAAK,uBAAuB,aAAa,MAAM,EAAE,CAAC;AAE7D,WAAO;AAAA,EACT;AACF;","names":[]}
|