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
package/README.md
CHANGED
|
@@ -1,5 +1,12 @@
|
|
|
1
1
|
# node-narou
|
|
2
2
|
|
|
3
|
+
[](https://badge.fury.io/js/narou)
|
|
4
|
+
[](https://github.com/deflis/node-narou/actions/workflows/nodejs-test.yml)
|
|
5
|
+
|
|
6
|
+
[](https://deepwiki.com/deflis/node-narou)
|
|
7
|
+
<!-- DeepWiki badge generated by https://deepwiki.ryoppippi.com/ -->
|
|
8
|
+
|
|
9
|
+
|
|
3
10
|
[なろうデベロッパー](https://dev.syosetu.com/)の API を fluent interface で利用できるラッパーライブラリです。
|
|
4
11
|
ブラウザでの JSONP の利用も可能です。
|
|
5
12
|
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/narou-search-results.ts"],"sourcesContent":["import type {\n BooleanNumber as BooleanNumber,\n Genre,\n R18Site,\n SearchParams,\n Fields,\n BigGenre,\n R18Fields,\n OptionalFields,\n UserFields,\n UserSearchParams,\n} from \"./params.js\";\n\n/**\n * なろう小説API検索結果\n */\nexport default class NarouSearchResults<T, TKey extends keyof T> {\n /**\n * 検索結果数\n */\n allcount: number;\n /**\n * 結果表示上限数\n */\n limit: number;\n /**\n * 結果表示開始数\n */\n start: number;\n /**\n * 結果表示の現在ページ(=start/limit)\n */\n page: number;\n /**\n * 今回取得できた検索結果の数\n */\n length: number;\n /**\n * 検索結果\n */\n values: readonly Pick<T, TKey>[];\n\n /**\n * @constractor\n * @private\n */\n constructor(\n [header, ...result]: [{ allcount: number }, ...Pick<T, TKey>[]],\n params: SearchParams | UserSearchParams\n ) {\n const count = header.allcount;\n const limit = params.lim ?? 20;\n const start = params.st ?? 0;\n\n this.allcount = count;\n this.limit = limit;\n this.start = start;\n this.page = start / limit;\n this.length = result.length;\n this.values = result;\n }\n}\n\n/**\n * 小説情報\n * @see https://dev.syosetu.com/man/api/#output\n * @see https://dev.syosetu.com/xman/api/#output\n */\nexport interface NarouSearchResult {\n /** 小説名 */\n title: string;\n /** Nコード */\n ncode: string;\n /** 作者のユーザID(数値) */\n userid: number;\n /** 作者名 */\n writer: string;\n /** 小説のあらすじ */\n story: string;\n /** 掲載サイト */\n nocgenre: R18Site;\n /** 大ジャンル */\n biggenre: BigGenre;\n /** ジャンル */\n genre: Genre;\n /** キーワード */\n keyword: string;\n /** 初回掲載日 YYYY-MM-DD HH:MM:SSの形式 */\n general_firstup: string;\n /** 最終掲載日 YYYY-MM-DD HH:MM:SSの形式 */\n general_lastup: string;\n /** 連載の場合は1、短編の場合は2 */\n novel_type: NovelType;\n /** 連載の場合は1、短編の場合は2 */\n noveltype: NovelType;\n /** 短編小説と完結済小説は0となっています。連載中は1です。 */\n end: End;\n /** 全掲載話数です。短編の場合は1です。 */\n general_all_no: number;\n /** 小説文字数です。スペースや改行は文字数としてカウントしません。 */\n length: number;\n /** 読了時間(分単位)です。読了時間は小説文字数÷500を切り上げした数値です。 */\n time: number;\n /** 長期連載中は1、それ以外は0です。 */\n isstop: BooleanNumber;\n /** 登録必須キーワードに「R15」が含まれる場合は1、それ以外は0です。 */\n isr15: BooleanNumber;\n /** 登録必須キーワードに「ボーイズラブ」が含まれる場合は1、それ以外は0です。 */\n isbl: BooleanNumber;\n /** 登録必須キーワードに「ガールズラブ」が含まれる場合は1、それ以外は0です。 */\n isgl: BooleanNumber;\n /** 登録必須キーワードに「残酷な描写あり」が含まれる場合は1、それ以外は0です。 */\n iszankoku: BooleanNumber;\n /** 登録必須キーワードに「異世界転生」が含まれる場合は1、それ以外は0です。 */\n istensei: BooleanNumber;\n /** 登録必須キーワードに「異世界転移」が含まれる場合は1、それ以外は0です。 */\n istenni: BooleanNumber;\n /** 総合得点(=(ブックマーク数×2)+評価点) */\n global_point: number;\n /**\n * 日間ポイント\n * ランキング集計時点から過去24時間以内で新たに登録されたブックマークや評価が対象\n */\n daily_point: number;\n /**\n * 週間ポイント\n * ランキング集計時点から過去7日以内で新たに登録されたブックマークや評価が対象\n */\n weekly_point: number;\n /**\n * 月間ポイント\n * ランキング集計時点から過去30日以内で新たに登録されたブックマークや評価が対象\n */\n monthly_point: number;\n /**\n * 四半期ポイント\n * ランキング集計時点から過去90日以内で新たに登録されたブックマークや評価が対象\n */\n quarter_point: number;\n /**\n * 年間ポイント\n * ランキング集計時点から過去365日以内で新たに登録されたブックマークや評価が対象\n */\n yearly_point: number;\n /** ブックマーク数 */\n fav_novel_cnt: number;\n /** 感想数 */\n impression_cnt: number;\n /** レビュー数 */\n review_cnt: number;\n /** 評価ポイント */\n all_point: number;\n /** 評価者数 */\n all_hyoka_cnt: number;\n /** 挿絵の数 */\n sasie_cnt: number;\n /**\n * 会話率\n * @see https://dev.syosetu.com/man/kaiwa/\n */\n kaiwaritu: number;\n /**\n * 小説の更新日時\n */\n novelupdated_at: string;\n /**\n * 最終更新日時\n * システム用で小説更新時とは関係ありません\n */\n updated_at: string;\n /** 週間ユニークユーザー数 */\n weekly_unique: number;\n}\n\n/**\n * ユーザ情報\n * @see https://dev.syosetu.com/man/userapi/#output\n */\nexport interface UserSearchResult {\n /** ユーザID */\n userid: number;\n /** ユーザ名 */\n name: string;\n /** ユーザ名のフリガナ */\n yomikata: string;\n /**\n * ユーザ名のフリガナの頭文字\n * ひらがな以外の場合はnullまたは空文字となります。\n */\n name1st: string;\n /** 小説投稿数 */\n novel_cnt: number;\n /** レビュー投稿数 */\n review_cnt: number;\n /**\n * 小説累計文字数\n * スペースや改行は文字数としてカウントしません。\n */\n novel_length: number;\n /**\n * 総合評価ポイントの合計\n * 投稿済小説でそれぞれ獲得した総合評価ポイントの合計です。\n */\n sum_global_point: number;\n}\n\n/**\n * noveltype/novel_typeの値ヘルパー\n */\nexport const NovelType = {\n /** 連載 */\n Rensai: 1,\n /** 短編 */\n Tanpen: 2,\n} as const;\nexport type NovelType = typeof NovelType[keyof typeof NovelType];\n\n/**\n * endの値ヘルパー\n */\nexport const End = {\n /** 短編小説と完結済小説 */\n KanketsuOrTanpen: 0,\n /** 連載中 */\n Rensai: 1,\n} as const;\nexport type End = typeof End[keyof typeof End];\n\nexport type SearchResultFields<T extends Fields> = {\n [K in keyof typeof Fields]: typeof Fields[K] extends T ? K : never;\n}[keyof typeof Fields];\n\nexport type SearchResultOptionalFields<T extends OptionalFields> = {\n [K in keyof typeof OptionalFields]: typeof OptionalFields[K] extends T\n ? K\n : never;\n}[keyof typeof OptionalFields];\n\nexport type SearchResultR18Fields<T extends R18Fields> = {\n [K in keyof typeof R18Fields]: typeof R18Fields[K] extends T ? K : never;\n}[keyof typeof R18Fields];\n\nexport type UserSearchResultFields<T extends UserFields> = {\n [K in keyof typeof UserFields]: typeof UserFields[K] extends T ? K : never;\n}[keyof typeof UserFields];\n\nexport type PickedNarouSearchResult<T extends keyof NarouSearchResult> = Pick<\n NarouSearchResult,\n T\n>;\n"],"mappings":";AAgBA,IAAqB,qBAArB,MAAiE;AAAA;AAAA;AAAA;AAAA;AAAA,EA8B/D,YACE,CAAC,QAAQ,GAAG,MAAM,GAClB,QACA;AACA,UAAM,QAAQ,OAAO;AACrB,UAAM,QAAQ,OAAO,OAAO;AAC5B,UAAM,QAAQ,OAAO,MAAM;AAE3B,SAAK,WAAW;AAChB,SAAK,QAAQ;AACb,SAAK,QAAQ;AACb,SAAK,OAAO,QAAQ;AACpB,SAAK,SAAS,OAAO;AACrB,SAAK,SAAS;AAAA,EAChB;AACF;AAoJO,IAAM,YAAY;AAAA;AAAA,EAEvB,QAAQ;AAAA;AAAA,EAER,QAAQ;AACV;AAMO,IAAM,MAAM;AAAA;AAAA,EAEjB,kBAAkB;AAAA;AAAA,EAElB,QAAQ;AACV;","names":[]}
|
|
@@ -225,7 +225,9 @@ var Order = {
|
|
|
225
225
|
/** 四半期ポイントの高い順 */
|
|
226
226
|
QuarterPoint: "quarterpoint",
|
|
227
227
|
/** 年間ポイントの高い順 */
|
|
228
|
-
YearlyPoint: "yearlypoint"
|
|
228
|
+
YearlyPoint: "yearlypoint",
|
|
229
|
+
/** 初回掲載順 */
|
|
230
|
+
GeneralFirstUp: "generalfirstup"
|
|
229
231
|
};
|
|
230
232
|
var R18Site = {
|
|
231
233
|
/** ノクターンノベルズ(男性向け) */
|
|
@@ -360,6 +362,13 @@ var NovelTypeParam = {
|
|
|
360
362
|
/** 短編と完結済連載小説 */
|
|
361
363
|
ShortAndRensai: "ter"
|
|
362
364
|
};
|
|
365
|
+
var DateParam = {
|
|
366
|
+
ThisWeek: "thisweek",
|
|
367
|
+
LastWeek: "lastweek",
|
|
368
|
+
SevenDays: "sevenday",
|
|
369
|
+
ThisMonth: "thismonth",
|
|
370
|
+
LastMonth: "lastmonth"
|
|
371
|
+
};
|
|
363
372
|
var UserOrder = {
|
|
364
373
|
/** ユーザIDの新しい順 */
|
|
365
374
|
New: "new",
|
|
@@ -392,6 +401,7 @@ export {
|
|
|
392
401
|
BuntaiParam,
|
|
393
402
|
StopParam,
|
|
394
403
|
NovelTypeParam,
|
|
404
|
+
DateParam,
|
|
395
405
|
UserOrder
|
|
396
406
|
};
|
|
397
|
-
//# sourceMappingURL=chunk-
|
|
407
|
+
//# sourceMappingURL=chunk-5UDKQCPJ.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/params.ts"],"sourcesContent":["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"],"mappings":"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","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
NarouSearchResults
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-3A5MHPWL.js";
|
|
4
4
|
|
|
5
5
|
// src/narou.ts
|
|
6
6
|
var NarouNovel = class {
|
|
@@ -62,11 +62,14 @@ var NarouNovel = class {
|
|
|
62
62
|
* @see https://dev.syosetu.com/man/userapi/
|
|
63
63
|
*/
|
|
64
64
|
async executeUserSearch(params) {
|
|
65
|
-
return
|
|
65
|
+
return new NarouSearchResults(
|
|
66
|
+
await this.execute(params, "https://api.syosetu.com/userapi/api/"),
|
|
67
|
+
params
|
|
68
|
+
);
|
|
66
69
|
}
|
|
67
70
|
};
|
|
68
71
|
|
|
69
72
|
export {
|
|
70
73
|
NarouNovel
|
|
71
74
|
};
|
|
72
|
-
//# sourceMappingURL=chunk-
|
|
75
|
+
//# sourceMappingURL=chunk-6BZWV4ZC.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/narou.ts"],"sourcesContent":["import type { NarouRankingResult } from \"./narou-ranking-results.js\";\nimport NarouSearchResults from \"./narou-search-results.js\";\nimport type {\n NarouSearchResult,\n UserSearchResult,\n} from \"./narou-search-results.js\";\nimport type {\n RankingHistoryParams,\n RankingParams,\n SearchParams,\n UserSearchParams,\n} from \"./params.js\";\nimport type { RankingHistoryRawResult } from \"./ranking-history.js\";\n\n/**\n * なろう小説APIへのリクエストパラメータ\n */\nexport type NarouParams =\n | SearchParams\n | RankingParams\n | RankingHistoryParams\n | UserSearchParams;\n\n/**\n * なろう小説APIへのリクエストを実行する\n * @class NarouNovel\n * @private\n */\nexport default abstract class NarouNovel {\n /**\n * なろうAPIへのAPIリクエストを実行する\n * @param params クエリパラメータ\n * @param endpoint APIエンドポイント\n * @returns 実行結果\n */\n protected abstract execute<T>(\n params: NarouParams,\n endpoint: string\n ): Promise<T>;\n\n /**\n * APIへの検索リクエストを実行する\n * @param params クエリパラメータ\n * @param endpoint APIエンドポイント\n * @returns 検索結果\n */\n protected async executeSearch<T extends keyof NarouSearchResult>(\n params: SearchParams,\n endpoint = \"https://api.syosetu.com/novelapi/api/\"\n ): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return new NarouSearchResults(await this.execute(params, endpoint), params);\n }\n\n /**\n * 小説APIへの検索リクエストを実行する\n * @param params クエリパラメータ\n * @returns 検索結果\n * @see https://dev.syosetu.com/man/api/\n */\n async executeNovel<T extends keyof NarouSearchResult>(\n params: SearchParams\n ): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return await this.executeSearch(\n params,\n \"https://api.syosetu.com/novelapi/api/\"\n );\n }\n\n /**\n * R18小説APIへの検索リクエストを実行する\n * @param params クエリパラメータ\n * @returns 検索結果\n * @see https://dev.syosetu.com/xman/api/\n */\n async executeNovel18<T extends keyof NarouSearchResult>(\n params: SearchParams\n ): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return await this.executeSearch(\n params,\n \"https://api.syosetu.com/novel18api/api/\"\n );\n }\n\n /**\n * ランキングAPIへのリクエストを実行する\n * @param params クエリパラメータ\n * @returns ランキング結果\n * @see https://dev.syosetu.com/man/rankapi/\n */\n async executeRanking(params: RankingParams): Promise<NarouRankingResult[]> {\n return await this.execute(params, \"https://api.syosetu.com/rank/rankget/\");\n }\n\n /**\n * 殿堂入りAPiへのリクエストを実行する\n * @param params クエリパラメータ\n * @returns ランキング履歴結果\n * @see https://dev.syosetu.com/man/rankinapi/\n */\n async executeRankingHistory(\n params: RankingHistoryParams\n ): Promise<RankingHistoryRawResult[]> {\n return await this.execute(params, \"https://api.syosetu.com/rank/rankin/\");\n }\n\n /**\n * ユーザー検索APIへのリクエストを実行する\n * @param params クエリパラメータ\n * @returns 検索結果\n * @see https://dev.syosetu.com/man/userapi/\n */\n async executeUserSearch<T extends keyof UserSearchResult>(\n params: UserSearchParams\n ): Promise<NarouSearchResults<UserSearchResult, T>> {\n return await this.execute(params, \"https://api.syosetu.com/userapi/api/\");\n }\n}\n"],"mappings":";;;;;AA4BA,IAA8B,aAA9B,MAAyC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBvC,MAAgB,cACd,QACA,WAAW,yCACwC;AACnD,WAAO,IAAI,mBAAmB,MAAM,KAAK,QAAQ,QAAQ,QAAQ,GAAG,MAAM;AAAA,EAC5E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,aACJ,QACmD;AACnD,WAAO,MAAM,KAAK;AAAA,MAChB;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,eACJ,QACmD;AACnD,WAAO,MAAM,KAAK;AAAA,MAChB;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,eAAe,QAAsD;AACzE,WAAO,MAAM,KAAK,QAAQ,QAAQ,uCAAuC;AAAA,EAC3E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,sBACJ,QACoC;AACpC,WAAO,MAAM,KAAK,QAAQ,QAAQ,sCAAsC;AAAA,EAC1E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,kBACJ,QACkD;AAClD,WAAO,MAAM,KAAK,QAAQ,QAAQ,sCAAsC;AAAA,
|
|
1
|
+
{"version":3,"sources":["../src/narou.ts"],"sourcesContent":["import type { NarouRankingResult } from \"./narou-ranking-results.js\";\nimport NarouSearchResults from \"./narou-search-results.js\";\nimport type {\n NarouSearchResult,\n UserSearchResult,\n} from \"./narou-search-results.js\";\nimport type {\n RankingHistoryParams,\n RankingParams,\n SearchParams,\n UserSearchParams,\n} from \"./params.js\";\nimport type { RankingHistoryRawResult } from \"./ranking-history.js\";\n\n/**\n * なろう小説APIへのリクエストパラメータ\n */\nexport type NarouParams =\n | SearchParams\n | RankingParams\n | RankingHistoryParams\n | UserSearchParams;\n\n/**\n * なろう小説APIへのリクエストを実行する\n * @class NarouNovel\n * @private\n */\nexport default abstract class NarouNovel {\n /**\n * なろうAPIへのAPIリクエストを実行する\n * @param params クエリパラメータ\n * @param endpoint APIエンドポイント\n * @returns 実行結果\n */\n protected abstract execute<T>(\n params: NarouParams,\n endpoint: string\n ): Promise<T>;\n\n /**\n * APIへの検索リクエストを実行する\n * @param params クエリパラメータ\n * @param endpoint APIエンドポイント\n * @returns 検索結果\n */\n protected async executeSearch<T extends keyof NarouSearchResult>(\n params: SearchParams,\n endpoint = \"https://api.syosetu.com/novelapi/api/\"\n ): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return new NarouSearchResults(await this.execute(params, endpoint), params);\n }\n\n /**\n * 小説APIへの検索リクエストを実行する\n * @param params クエリパラメータ\n * @returns 検索結果\n * @see https://dev.syosetu.com/man/api/\n */\n async executeNovel<T extends keyof NarouSearchResult>(\n params: SearchParams\n ): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return await this.executeSearch(\n params,\n \"https://api.syosetu.com/novelapi/api/\"\n );\n }\n\n /**\n * R18小説APIへの検索リクエストを実行する\n * @param params クエリパラメータ\n * @returns 検索結果\n * @see https://dev.syosetu.com/xman/api/\n */\n async executeNovel18<T extends keyof NarouSearchResult>(\n params: SearchParams\n ): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return await this.executeSearch(\n params,\n \"https://api.syosetu.com/novel18api/api/\"\n );\n }\n\n /**\n * ランキングAPIへのリクエストを実行する\n * @param params クエリパラメータ\n * @returns ランキング結果\n * @see https://dev.syosetu.com/man/rankapi/\n */\n async executeRanking(params: RankingParams): Promise<NarouRankingResult[]> {\n return await this.execute(params, \"https://api.syosetu.com/rank/rankget/\");\n }\n\n /**\n * 殿堂入りAPiへのリクエストを実行する\n * @param params クエリパラメータ\n * @returns ランキング履歴結果\n * @see https://dev.syosetu.com/man/rankinapi/\n */\n async executeRankingHistory(\n params: RankingHistoryParams\n ): Promise<RankingHistoryRawResult[]> {\n return await this.execute(params, \"https://api.syosetu.com/rank/rankin/\");\n }\n\n /**\n * ユーザー検索APIへのリクエストを実行する\n * @param params クエリパラメータ\n * @returns 検索結果\n * @see https://dev.syosetu.com/man/userapi/\n */\n async executeUserSearch<T extends keyof UserSearchResult>(\n params: UserSearchParams\n ): Promise<NarouSearchResults<UserSearchResult, T>> {\n return new NarouSearchResults<UserSearchResult, T>(\n await this.execute(params, \"https://api.syosetu.com/userapi/api/\"),\n params\n );\n }\n}\n"],"mappings":";;;;;AA4BA,IAA8B,aAA9B,MAAyC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBvC,MAAgB,cACd,QACA,WAAW,yCACwC;AACnD,WAAO,IAAI,mBAAmB,MAAM,KAAK,QAAQ,QAAQ,QAAQ,GAAG,MAAM;AAAA,EAC5E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,aACJ,QACmD;AACnD,WAAO,MAAM,KAAK;AAAA,MAChB;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,eACJ,QACmD;AACnD,WAAO,MAAM,KAAK;AAAA,MAChB;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,eAAe,QAAsD;AACzE,WAAO,MAAM,KAAK,QAAQ,QAAQ,uCAAuC;AAAA,EAC3E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,sBACJ,QACoC;AACpC,WAAO,MAAM,KAAK,QAAQ,QAAQ,sCAAsC;AAAA,EAC1E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,kBACJ,QACkD;AAClD,WAAO,IAAI;AAAA,MACT,MAAM,KAAK,QAAQ,QAAQ,sCAAsC;AAAA,MACjE;AAAA,IACF;AAAA,EACF;AACF;","names":[]}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import {
|
|
2
|
+
SearchBuilder
|
|
3
|
+
} from "./chunk-HOBLKBZ6.js";
|
|
4
|
+
import {
|
|
5
|
+
Fields,
|
|
6
|
+
RankingType
|
|
7
|
+
} from "./chunk-5UDKQCPJ.js";
|
|
8
|
+
import {
|
|
9
|
+
addDays,
|
|
10
|
+
formatDate
|
|
11
|
+
} from "./chunk-RNHRR56W.js";
|
|
12
|
+
|
|
13
|
+
// src/ranking.ts
|
|
14
|
+
var RankingBuilder = class {
|
|
15
|
+
/**
|
|
16
|
+
* constructor
|
|
17
|
+
* @param params - 初期クエリパラメータ
|
|
18
|
+
* @param api - API実行クラスのインスタンス
|
|
19
|
+
* @private
|
|
20
|
+
*/
|
|
21
|
+
constructor(params = {}, api) {
|
|
22
|
+
this.params = params;
|
|
23
|
+
this.api = api;
|
|
24
|
+
this.date$ = addDays(/* @__PURE__ */ new Date(), -1);
|
|
25
|
+
this.type$ = RankingType.Daily;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* ランキング集計対象の日付を指定します。
|
|
29
|
+
*
|
|
30
|
+
* - 日間: 任意の日付
|
|
31
|
+
* - 週間: 火曜日の日付
|
|
32
|
+
* - 月間・四半期: 1日の日付
|
|
33
|
+
*
|
|
34
|
+
* @param date 集計対象の日付
|
|
35
|
+
* @returns {RankingBuilder} this
|
|
36
|
+
* @see https://dev.syosetu.com/man/rankapi/
|
|
37
|
+
*/
|
|
38
|
+
date(date) {
|
|
39
|
+
this.date$ = date;
|
|
40
|
+
return this;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* ランキング種別を指定します。
|
|
44
|
+
* @param type ランキング種別
|
|
45
|
+
* @returns {RankingBuilder} this
|
|
46
|
+
* @see https://dev.syosetu.com/man/rankapi/
|
|
47
|
+
*/
|
|
48
|
+
type(type) {
|
|
49
|
+
this.type$ = type;
|
|
50
|
+
return this;
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* gzip圧縮する。
|
|
54
|
+
*
|
|
55
|
+
* 転送量上限を減らすためにも推奨
|
|
56
|
+
* @param {GzipLevel} level gzip圧縮レベル(1~5)
|
|
57
|
+
* @return {RankingBuilder} this
|
|
58
|
+
*/
|
|
59
|
+
gzip(level) {
|
|
60
|
+
this.set({ gzip: level });
|
|
61
|
+
return this;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* クエリパラメータを内部的にセットします。
|
|
65
|
+
* @param obj - セットするパラメータオブジェクト
|
|
66
|
+
* @returns {RankingBuilder} this
|
|
67
|
+
* @private
|
|
68
|
+
*/
|
|
69
|
+
set(obj) {
|
|
70
|
+
Object.assign(this.params, obj);
|
|
71
|
+
return this;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* 設定されたパラメータに基づき、なろう小説ランキングAPIへのリクエストを実行します。
|
|
75
|
+
*
|
|
76
|
+
* 返される結果には、Nコード、ポイント、順位が含まれます。
|
|
77
|
+
* @returns {Promise<NarouRankingResult[]>} ランキング結果の配列
|
|
78
|
+
* @see https://dev.syosetu.com/man/rankapi/#output
|
|
79
|
+
*/
|
|
80
|
+
execute() {
|
|
81
|
+
const date = formatDate(this.date$);
|
|
82
|
+
this.set({ rtype: `${date}-${this.type$}` });
|
|
83
|
+
return this.api.executeRanking(this.params);
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。
|
|
87
|
+
*
|
|
88
|
+
* @template TFields - 取得する小説情報のフィールド型
|
|
89
|
+
* @template TOpt - オプショナルな取得フィールドの型
|
|
90
|
+
* @param fields - 取得するフィールドの配列 (省略時はデフォルトフィールド)
|
|
91
|
+
* @param opt - オプショナルな取得フィールド (`weekly` など)
|
|
92
|
+
* @returns {Promise<RankingResult<SearchResultFields<TFields>>[]>} 詳細情報を含むランキング結果の配列
|
|
93
|
+
*/
|
|
94
|
+
async executeWithFields(fields = [], opt) {
|
|
95
|
+
const ranking = await this.execute();
|
|
96
|
+
const fields$ = Array.isArray(fields) ? fields.length == 0 ? [] : [...fields, Fields.ncode] : [fields, Fields.ncode];
|
|
97
|
+
const rankingNcodes = ranking.map(({ ncode }) => ncode);
|
|
98
|
+
const builder = new SearchBuilder({}, this.api);
|
|
99
|
+
builder.fields(fields$);
|
|
100
|
+
if (opt) {
|
|
101
|
+
builder.opt(opt);
|
|
102
|
+
}
|
|
103
|
+
builder.ncode(rankingNcodes);
|
|
104
|
+
builder.limit(ranking.length);
|
|
105
|
+
const result = await builder.execute();
|
|
106
|
+
return ranking.map((r) => ({
|
|
107
|
+
...r,
|
|
108
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
109
|
+
...result.values.find((novel) => novel.ncode == r.ncode)
|
|
110
|
+
}));
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
export {
|
|
115
|
+
RankingBuilder
|
|
116
|
+
};
|
|
117
|
+
//# sourceMappingURL=chunk-BQLSW236.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/ranking.ts"],"sourcesContent":["import type { NarouRankingResult, RankingResult } from \"./narou-ranking-results.js\";\nimport SearchBuilder from \"./search-builder.js\";\nimport type { DefaultSearchResultFields } from \"./search-builder.js\";\nimport type {\n GzipLevel,\n OptionalFields,\n} from \"./params.js\";\nimport {\n RankingParams,\n RankingType,\n Fields,\n} from \"./params.js\";\nimport type NarouNovel from \"./narou.js\";\nimport type { SearchResultFields } from \"./narou-search-results.js\";\nimport { addDays, formatDate } from \"./util/date.js\";\n\n/**\n * なろう小説ランキングAPIのヘルパークラス。\n *\n * ランキング種別や日付を指定してランキングデータを取得します。\n * また、取得したランキングデータに含まれるNコードを元に、\n * なろう小説APIを利用して詳細な小説情報を取得することも可能です。\n *\n * @class RankingBuilder\n * @see https://dev.syosetu.com/man/rankapi/ なろう小説ランキングAPI仕様\n */\nexport default class RankingBuilder {\n /**\n * ランキング集計対象の日付\n * @protected\n */\n protected date$: Date;\n /**\n * ランキング種別\n * @protected\n */\n protected type$: RankingType;\n\n /**\n * constructor\n * @param params - 初期クエリパラメータ\n * @param api - API実行クラスのインスタンス\n * @private\n */\n constructor(\n protected params: Partial<RankingParams> = {},\n protected api: NarouNovel\n ) {\n /**\n * クエリパラメータ\n * @protected\n */\n this.date$ = addDays(new Date(), -1);\n this.type$ = RankingType.Daily;\n }\n\n /**\n * ランキング集計対象の日付を指定します。\n *\n * - 日間: 任意の日付\n * - 週間: 火曜日の日付\n * - 月間・四半期: 1日の日付\n *\n * @param date 集計対象の日付\n * @returns {RankingBuilder} this\n * @see https://dev.syosetu.com/man/rankapi/\n */\n date(date: Date) {\n this.date$ = date;\n return this;\n }\n\n /**\n * ランキング種別を指定します。\n * @param type ランキング種別\n * @returns {RankingBuilder} this\n * @see https://dev.syosetu.com/man/rankapi/\n */\n type(type: RankingType) {\n this.type$ = type;\n return this;\n }\n\n /**\n * gzip圧縮する。\n *\n * 転送量上限を減らすためにも推奨\n * @param {GzipLevel} level gzip圧縮レベル(1~5)\n * @return {RankingBuilder} this\n */\n gzip(level: GzipLevel) {\n this.set({ gzip: level });\n return this;\n }\n\n /**\n * クエリパラメータを内部的にセットします。\n * @param obj - セットするパラメータオブジェクト\n * @returns {RankingBuilder} this\n * @private\n */\n protected set(obj: Partial<RankingParams>) {\n Object.assign(this.params, obj);\n return this;\n }\n\n /**\n * 設定されたパラメータに基づき、なろう小説ランキングAPIへのリクエストを実行します。\n *\n * 返される結果には、Nコード、ポイント、順位が含まれます。\n * @returns {Promise<NarouRankingResult[]>} ランキング結果の配列\n * @see https://dev.syosetu.com/man/rankapi/#output\n */\n execute(): Promise<NarouRankingResult[]> {\n const date = formatDate(this.date$);\n this.set({ rtype: `${date}-${this.type$}` });\n return this.api.executeRanking(this.params as RankingParams);\n }\n\n /**\n * ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。\n */\n async executeWithFields(): Promise<\n RankingResult<DefaultSearchResultFields>[]\n >;\n /**\n * ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。\n *\n * @template TFields - 取得する小説情報のフィールド型\n * @param fields - 取得するフィールドの配列\n * @returns {Promise<RankingResult<SearchResultFields<TFields>>[]>} 詳細情報を含むランキング結果の配列\n */\n async executeWithFields<TFields extends Fields>(\n fields: TFields | TFields[]\n ): Promise<RankingResult<SearchResultFields<TFields>>[]>;\n /**\n * ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。\n *\n * @param opt - オプショナルな取得フィールド (`weekly` など)\n * @returns {Promise<RankingResult<DefaultSearchResultFields | \"weekly_unique\">[]>} 詳細情報を含むランキング結果の配列\n */\n async executeWithFields(\n fields: never[],\n opt: OptionalFields | OptionalFields[]\n ): Promise<RankingResult<DefaultSearchResultFields | \"weekly_unique\">[]>;\n /**\n * ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。\n *\n * @template TFields - 取得する小説情報のフィールド型\n * @param fields - 取得するフィールドの配列\n * @param opt - オプショナルな取得フィールド (`weekly` など)\n * @returns {Promise<RankingResult<SearchResultFields<TFields> | \"weekly_unique\">[]>} 詳細情報を含むランキング結果の配列\n */\n async executeWithFields<TFields extends Fields>(\n fields: TFields | TFields[],\n opt: OptionalFields | OptionalFields[]\n ): Promise<RankingResult<SearchResultFields<TFields> | \"weekly_unique\">[]>;\n /**\n * ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。\n *\n * @template TFields - 取得する小説情報のフィールド型\n * @template TOpt - オプショナルな取得フィールドの型\n * @param fields - 取得するフィールドの配列 (省略時はデフォルトフィールド)\n * @param opt - オプショナルな取得フィールド (`weekly` など)\n * @returns {Promise<RankingResult<SearchResultFields<TFields>>[]>} 詳細情報を含むランキング結果の配列\n */\n async executeWithFields<\n TFields extends Fields,\n TOpt extends OptionalFields | undefined = undefined\n >(\n fields: TFields | TFields[] = [],\n opt?: TOpt\n ): Promise<RankingResult<SearchResultFields<TFields>>[]> {\n const ranking = await this.execute();\n const fields$ = Array.isArray(fields)\n ? fields.length == 0\n ? []\n : ([...fields, Fields.ncode] as const)\n : ([fields, Fields.ncode] as const);\n\n const rankingNcodes = ranking.map(({ ncode }) => ncode);\n const builder = new SearchBuilder({}, this.api);\n builder.fields(fields$);\n if (opt) {\n builder.opt(opt);\n }\n builder.ncode(rankingNcodes);\n builder.limit(ranking.length);\n const result = await builder.execute();\n\n return ranking.map<\n RankingResult<\n | SearchResultFields<TFields>\n | (TOpt extends \"weekly\" ? \"weekly_unique\" : never)\n >\n >((r) => ({\n ...r,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ...(result.values.find((novel) => novel.ncode == r.ncode) as any),\n }));\n }\n}\n"],"mappings":";;;;;;;;;;;;;AA0BA,IAAqB,iBAArB,MAAoC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBlC,YACY,SAAiC,CAAC,GAClC,KACV;AAFU;AACA;AAMV,SAAK,QAAQ,QAAQ,oBAAI,KAAK,GAAG,EAAE;AACnC,SAAK,QAAQ,YAAY;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaA,KAAK,MAAY;AACf,SAAK,QAAQ;AACb,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,KAAK,MAAmB;AACtB,SAAK,QAAQ;AACb,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,KAAK,OAAkB;AACrB,SAAK,IAAI,EAAE,MAAM,MAAM,CAAC;AACxB,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQU,IAAI,KAA6B;AACzC,WAAO,OAAO,KAAK,QAAQ,GAAG;AAC9B,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,UAAyC;AACvC,UAAM,OAAO,WAAW,KAAK,KAAK;AAClC,SAAK,IAAI,EAAE,OAAO,GAAG,IAAI,IAAI,KAAK,KAAK,GAAG,CAAC;AAC3C,WAAO,KAAK,IAAI,eAAe,KAAK,MAAuB;AAAA,EAC7D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAiDA,MAAM,kBAIJ,SAA8B,CAAC,GAC/B,KACuD;AACvD,UAAM,UAAU,MAAM,KAAK,QAAQ;AACnC,UAAM,UAAU,MAAM,QAAQ,MAAM,IAChC,OAAO,UAAU,IACf,CAAC,IACA,CAAC,GAAG,QAAQ,OAAO,KAAK,IAC1B,CAAC,QAAQ,OAAO,KAAK;AAE1B,UAAM,gBAAgB,QAAQ,IAAI,CAAC,EAAE,MAAM,MAAM,KAAK;AACtD,UAAM,UAAU,IAAI,cAAc,CAAC,GAAG,KAAK,GAAG;AAC9C,YAAQ,OAAO,OAAO;AACtB,QAAI,KAAK;AACP,cAAQ,IAAI,GAAG;AAAA,IACjB;AACA,YAAQ,MAAM,aAAa;AAC3B,YAAQ,MAAM,QAAQ,MAAM;AAC5B,UAAM,SAAS,MAAM,QAAQ,QAAQ;AAErC,WAAO,QAAQ,IAKb,CAAC,OAAO;AAAA,MACR,GAAG;AAAA;AAAA,MAEH,GAAI,OAAO,OAAO,KAAK,CAAC,UAAU,MAAM,SAAS,EAAE,KAAK;AAAA,IAC1D,EAAE;AAAA,EACJ;AACF;","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
SearchBuilderBase
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-HOBLKBZ6.js";
|
|
4
4
|
|
|
5
5
|
// src/user-search.ts
|
|
6
6
|
var UserSearchBuilder = class _UserSearchBuilder extends SearchBuilderBase {
|
|
@@ -91,4 +91,4 @@ var UserSearchBuilder = class _UserSearchBuilder extends SearchBuilderBase {
|
|
|
91
91
|
export {
|
|
92
92
|
UserSearchBuilder
|
|
93
93
|
};
|
|
94
|
-
//# sourceMappingURL=chunk-
|
|
94
|
+
//# sourceMappingURL=chunk-DEQICAN3.js.map
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import {
|
|
2
|
+
NovelSearchBuilderBase
|
|
3
|
+
} from "./chunk-HOBLKBZ6.js";
|
|
4
|
+
|
|
5
|
+
// src/search-builder-r18.ts
|
|
6
|
+
var SearchBuilderR18 = class extends NovelSearchBuilderBase {
|
|
7
|
+
/**
|
|
8
|
+
* なろう小説APIへの検索リクエストを実行する
|
|
9
|
+
* @override
|
|
10
|
+
* @returns {Promise<NarouSearchResults>} 検索結果
|
|
11
|
+
*/
|
|
12
|
+
execute() {
|
|
13
|
+
return this.api.executeNovel18(this.params);
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* 抽出するR18サイトを指定します (nocgenre)。
|
|
17
|
+
* @param sites R18サイトコード、またはR18サイトコードの配列 (1: ノクターンノベルズ, 2: ムーンライトノベルズ(男性向け), 3: ムーンライトノベルズ(BL), 4: ミッドナイトノベルズ)
|
|
18
|
+
* @return {this}
|
|
19
|
+
*/
|
|
20
|
+
r18Site(sites) {
|
|
21
|
+
this.set({ nocgenre: NovelSearchBuilderBase.array2string(sites) });
|
|
22
|
+
return this;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* X-IDを指定して取得します (xid)。
|
|
26
|
+
* @param ids X-ID、またはX-IDの配列
|
|
27
|
+
* @return {this}
|
|
28
|
+
*/
|
|
29
|
+
xid(ids) {
|
|
30
|
+
this.set({ xid: NovelSearchBuilderBase.array2string(ids) });
|
|
31
|
+
return this;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* 出力する項目を個別に指定します (of)。
|
|
35
|
+
* 未指定時は全項目出力されます。転送量軽減のため、このパラメータの使用が推奨されます。
|
|
36
|
+
* @param fields 出力するR18フィールド名、またはR18フィールド名の配列
|
|
37
|
+
* @return {SearchBuilderR18<SearchResultR18Fields<R18Fields>>} 型が更新されたビルダー
|
|
38
|
+
*/
|
|
39
|
+
fields(fields) {
|
|
40
|
+
this.set({ of: NovelSearchBuilderBase.array2string(fields) });
|
|
41
|
+
return this;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* 出力オプション項目を指定します (opt)。
|
|
45
|
+
* @param option 出力するオプションフィールド名、またはオプションフィールド名の配列
|
|
46
|
+
* @return {SearchBuilderR18<T, SearchResultOptionalFields<TFields>>} 型が更新されたビルダー
|
|
47
|
+
*/
|
|
48
|
+
opt(option) {
|
|
49
|
+
this.set({ opt: NovelSearchBuilderBase.array2string(option) });
|
|
50
|
+
return this;
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
export {
|
|
55
|
+
SearchBuilderR18
|
|
56
|
+
};
|
|
57
|
+
//# sourceMappingURL=chunk-E2H3AJSQ.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/search-builder-r18.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"],"mappings":";;;;;AAuBA,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":[]}
|