narou 1.2.0 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +73 -37
- package/dist/index.browser.cjs +87 -1359
- package/dist/index.browser.cjs.map +1 -1
- package/dist/index.browser.d.cts +11 -19
- package/dist/index.browser.d.mts +47 -0
- package/dist/index.browser.mjs +66 -0
- package/dist/index.browser.mjs.map +1 -0
- package/dist/index.cjs +147 -1410
- package/dist/index.cjs.map +1 -1
- package/dist/index.common-8lS2K_1Y.mjs +1166 -0
- package/dist/index.common-8lS2K_1Y.mjs.map +1 -0
- package/dist/index.common-CYj0n0aU.cjs +1346 -0
- package/dist/index.common-CYj0n0aU.cjs.map +1 -0
- package/dist/index.d.cts +28 -21
- package/dist/index.d.mts +63 -0
- package/dist/index.mjs +128 -0
- package/dist/index.mjs.map +1 -0
- package/dist/user-search-BY6FdEe7.d.cts +1394 -0
- package/dist/user-search-Besgk-Hx.d.mts +1394 -0
- package/package.json +28 -37
- package/pnpm-lock.yaml +1325 -1100
- package/src/index.ts +5 -1
- package/src/narou-fetch.ts +4 -3
- package/src/narou-jsonp.ts +4 -2
- package/src/narou.ts +50 -13
- package/src/params.ts +1 -1
- package/src/ranking.ts +20 -11
- package/src/search-builder-r18.ts +6 -2
- package/src/search-builder.ts +7 -3
- package/src/user-search.ts +9 -2
- package/dist/chunk-3A5MHPWL.js +0 -37
- package/dist/chunk-3A5MHPWL.js.map +0 -1
- package/dist/chunk-4ZP5YNWI.js +0 -1
- package/dist/chunk-4ZP5YNWI.js.map +0 -1
- package/dist/chunk-5UDKQCPJ.js +0 -407
- package/dist/chunk-5UDKQCPJ.js.map +0 -1
- package/dist/chunk-6BZWV4ZC.js +0 -75
- package/dist/chunk-6BZWV4ZC.js.map +0 -1
- package/dist/chunk-BQLSW236.js +0 -117
- package/dist/chunk-BQLSW236.js.map +0 -1
- package/dist/chunk-DEQICAN3.js +0 -94
- package/dist/chunk-DEQICAN3.js.map +0 -1
- package/dist/chunk-E2H3AJSQ.js +0 -57
- package/dist/chunk-E2H3AJSQ.js.map +0 -1
- package/dist/chunk-HOBLKBZ6.js +0 -452
- package/dist/chunk-HOBLKBZ6.js.map +0 -1
- package/dist/chunk-IPDEGCWU.js +0 -39
- package/dist/chunk-IPDEGCWU.js.map +0 -1
- package/dist/chunk-LQLNWSWV.js +0 -26
- package/dist/chunk-LQLNWSWV.js.map +0 -1
- package/dist/chunk-PLEM2AOH.js +0 -44
- package/dist/chunk-PLEM2AOH.js.map +0 -1
- package/dist/chunk-RNHRR56W.js +0 -25
- package/dist/chunk-RNHRR56W.js.map +0 -1
- package/dist/chunk-VUZIISP2.js +0 -23
- package/dist/chunk-VUZIISP2.js.map +0 -1
- package/dist/chunk-VZVUANDN.js +0 -17
- package/dist/chunk-VZVUANDN.js.map +0 -1
- package/dist/index.browser.d.ts +0 -55
- package/dist/index.browser.js +0 -126
- package/dist/index.browser.js.map +0 -1
- package/dist/index.common.cjs +0 -1187
- package/dist/index.common.cjs.map +0 -1
- package/dist/index.common.d.cts +0 -6
- package/dist/index.common.d.ts +0 -6
- package/dist/index.common.js +0 -76
- package/dist/index.common.js.map +0 -1
- package/dist/index.d.ts +0 -56
- package/dist/index.js +0 -131
- package/dist/index.js.map +0 -1
- package/dist/narou-DBa12V_l.d.ts +0 -404
- package/dist/narou-DCp4aGfA.d.cts +0 -404
- package/dist/narou-fetch.cjs +0 -164
- package/dist/narou-fetch.cjs.map +0 -1
- package/dist/narou-fetch.d.cts +0 -20
- package/dist/narou-fetch.d.ts +0 -20
- package/dist/narou-fetch.js +0 -10
- package/dist/narou-fetch.js.map +0 -1
- package/dist/narou-jsonp.cjs +0 -162
- package/dist/narou-jsonp.cjs.map +0 -1
- package/dist/narou-jsonp.d.cts +0 -13
- package/dist/narou-jsonp.d.ts +0 -13
- package/dist/narou-jsonp.js +0 -10
- package/dist/narou-jsonp.js.map +0 -1
- package/dist/narou-ranking-results.cjs +0 -19
- package/dist/narou-ranking-results.cjs.map +0 -1
- package/dist/narou-ranking-results.d.cts +0 -4
- package/dist/narou-ranking-results.d.ts +0 -4
- package/dist/narou-ranking-results.js +0 -1
- package/dist/narou-ranking-results.js.map +0 -1
- package/dist/narou-search-results-C21hWrnL.d.cts +0 -727
- package/dist/narou-search-results-DT0YdaBn.d.ts +0 -727
- package/dist/narou-search-results.cjs +0 -62
- package/dist/narou-search-results.cjs.map +0 -1
- package/dist/narou-search-results.d.cts +0 -2
- package/dist/narou-search-results.d.ts +0 -2
- package/dist/narou-search-results.js +0 -11
- package/dist/narou-search-results.js.map +0 -1
- package/dist/narou.cjs +0 -112
- package/dist/narou.cjs.map +0 -1
- package/dist/narou.d.cts +0 -4
- package/dist/narou.d.ts +0 -4
- package/dist/narou.js +0 -8
- package/dist/narou.js.map +0 -1
- package/dist/params.cjs +0 -448
- package/dist/params.cjs.map +0 -1
- package/dist/params.d.cts +0 -2
- package/dist/params.d.ts +0 -2
- package/dist/params.js +0 -41
- package/dist/params.js.map +0 -1
- package/dist/ranking-history.cjs +0 -47
- package/dist/ranking-history.cjs.map +0 -1
- package/dist/ranking-history.d.cts +0 -28
- package/dist/ranking-history.d.ts +0 -28
- package/dist/ranking-history.js +0 -8
- package/dist/ranking-history.js.map +0 -1
- package/dist/ranking.cjs +0 -783
- package/dist/ranking.cjs.map +0 -1
- package/dist/ranking.d.cts +0 -108
- package/dist/ranking.d.ts +0 -108
- package/dist/ranking.js +0 -10
- package/dist/ranking.js.map +0 -1
- package/dist/search-builder-r18.cjs +0 -547
- package/dist/search-builder-r18.cjs.map +0 -1
- package/dist/search-builder-r18.d.cts +0 -45
- package/dist/search-builder-r18.d.ts +0 -45
- package/dist/search-builder-r18.js +0 -9
- package/dist/search-builder-r18.js.map +0 -1
- package/dist/search-builder.cjs +0 -591
- package/dist/search-builder.cjs.map +0 -1
- package/dist/search-builder.d.cts +0 -4
- package/dist/search-builder.d.ts +0 -4
- package/dist/search-builder.js +0 -12
- package/dist/search-builder.js.map +0 -1
- package/dist/user-search.cjs +0 -325
- package/dist/user-search.cjs.map +0 -1
- package/dist/user-search.d.cts +0 -66
- package/dist/user-search.d.ts +0 -66
- package/dist/user-search.js +0 -9
- package/dist/user-search.js.map +0 -1
- package/dist/util/date.cjs +0 -51
- package/dist/util/date.cjs.map +0 -1
- package/dist/util/date.d.cts +0 -21
- package/dist/util/date.d.ts +0 -21
- package/dist/util/date.js +0 -11
- package/dist/util/date.js.map +0 -1
- package/dist/util/jsonp.cjs +0 -63
- package/dist/util/jsonp.cjs.map +0 -1
- package/dist/util/jsonp.d.cts +0 -49
- package/dist/util/jsonp.d.ts +0 -49
- package/dist/util/jsonp.js +0 -7
- package/dist/util/jsonp.js.map +0 -1
- package/dist/util/type.cjs +0 -19
- package/dist/util/type.cjs.map +0 -1
- package/dist/util/type.d.cts +0 -27
- package/dist/util/type.d.ts +0 -27
- package/dist/util/type.js +0 -1
- package/dist/util/type.js.map +0 -1
- package/dist/util/unzipp.cjs +0 -47
- package/dist/util/unzipp.cjs.map +0 -1
- package/dist/util/unzipp.d.cts +0 -12
- package/dist/util/unzipp.d.ts +0 -12
- package/dist/util/unzipp.js +0 -7
- package/dist/util/unzipp.js.map +0 -1
package/src/index.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type NarouNovel from "./narou.js";
|
|
2
|
+
import type { ExecuteOptions } from "./narou.js";
|
|
2
3
|
import NarouNovelFetch from "./narou-fetch.js";
|
|
3
4
|
import NarouNovelJsonp from "./narou-jsonp.js";
|
|
4
5
|
import RankingBuilder from "./ranking.js";
|
|
@@ -67,13 +68,16 @@ export function ranking(api: NarouNovel = narouNovelFetch): RankingBuilder {
|
|
|
67
68
|
/**
|
|
68
69
|
* なろう殿堂入り API でランキング履歴を取得する
|
|
69
70
|
* @param {string} ncode 小説のNコード
|
|
71
|
+
* @param {ExecuteOptions} [options] 実行オプション
|
|
72
|
+
* @param {NarouNovel} [api] API実行クラスのインスタンス
|
|
70
73
|
* @see https://dev.syosetu.com/man/rankinapi/
|
|
71
74
|
*/
|
|
72
75
|
export async function rankingHistory(
|
|
73
76
|
ncode: string,
|
|
77
|
+
options?: ExecuteOptions,
|
|
74
78
|
api: NarouNovel = narouNovelFetch
|
|
75
79
|
): Promise<RankingHistoryResult[]> {
|
|
76
|
-
const result = await api.executeRankingHistory({ ncode });
|
|
80
|
+
const result = await api.executeRankingHistory({ ncode }, options);
|
|
77
81
|
if (Array.isArray(result)) {
|
|
78
82
|
return result.map(formatRankingHistory);
|
|
79
83
|
} else {
|
package/src/narou-fetch.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { unzipp } from "./util/unzipp.js";
|
|
2
2
|
import NarouNovel from "./narou.js";
|
|
3
|
-
import type { NarouParams } from "./narou.js";
|
|
3
|
+
import type { NarouParams, ExecuteOptions } from "./narou.js";
|
|
4
4
|
|
|
5
5
|
type Fetch = typeof fetch;
|
|
6
6
|
|
|
@@ -18,7 +18,8 @@ export default class NarouNovelFetch extends NarouNovel {
|
|
|
18
18
|
|
|
19
19
|
protected async execute<T>(
|
|
20
20
|
params: NarouParams,
|
|
21
|
-
endpoint: string
|
|
21
|
+
endpoint: string,
|
|
22
|
+
options?: ExecuteOptions
|
|
22
23
|
): Promise<T> {
|
|
23
24
|
const query = { ...params, out: "json" };
|
|
24
25
|
|
|
@@ -36,7 +37,7 @@ export default class NarouNovelFetch extends NarouNovel {
|
|
|
36
37
|
}
|
|
37
38
|
});
|
|
38
39
|
|
|
39
|
-
const res = await (this.fetch ?? fetch)(url);
|
|
40
|
+
const res = await (this.fetch ?? fetch)(url, options?.fetchOptions);
|
|
40
41
|
|
|
41
42
|
if (!query.gzip) {
|
|
42
43
|
return (await res.json()) as T;
|
package/src/narou-jsonp.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import NarouNovel from "./narou.js";
|
|
2
|
-
import type { NarouParams } from "./narou.js";
|
|
2
|
+
import type { NarouParams, ExecuteOptions } from "./narou.js";
|
|
3
3
|
import { jsonp } from "./util/jsonp.js";
|
|
4
4
|
|
|
5
5
|
/**
|
|
@@ -8,7 +8,9 @@ import { jsonp } from "./util/jsonp.js";
|
|
|
8
8
|
export default class NarouNovelJsonp extends NarouNovel {
|
|
9
9
|
protected async execute<T>(
|
|
10
10
|
params: NarouParams,
|
|
11
|
-
endpoint: string
|
|
11
|
+
endpoint: string,
|
|
12
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
13
|
+
_options?: ExecuteOptions
|
|
12
14
|
): Promise<T> {
|
|
13
15
|
const query = { ...params, out: "jsonp" };
|
|
14
16
|
query.gzip = 0;
|
package/src/narou.ts
CHANGED
|
@@ -21,6 +21,16 @@ export type NarouParams =
|
|
|
21
21
|
| RankingHistoryParams
|
|
22
22
|
| UserSearchParams;
|
|
23
23
|
|
|
24
|
+
/**
|
|
25
|
+
* なろう小説APIへのリクエストオプション
|
|
26
|
+
*/
|
|
27
|
+
export interface ExecuteOptions {
|
|
28
|
+
/**
|
|
29
|
+
* fetch関数のオプション
|
|
30
|
+
*/
|
|
31
|
+
fetchOptions?: RequestInit;
|
|
32
|
+
}
|
|
33
|
+
|
|
24
34
|
/**
|
|
25
35
|
* なろう小説APIへのリクエストを実行する
|
|
26
36
|
* @class NarouNovel
|
|
@@ -35,7 +45,8 @@ export default abstract class NarouNovel {
|
|
|
35
45
|
*/
|
|
36
46
|
protected abstract execute<T>(
|
|
37
47
|
params: NarouParams,
|
|
38
|
-
endpoint: string
|
|
48
|
+
endpoint: string,
|
|
49
|
+
options?: ExecuteOptions
|
|
39
50
|
): Promise<T>;
|
|
40
51
|
|
|
41
52
|
/**
|
|
@@ -46,9 +57,13 @@ export default abstract class NarouNovel {
|
|
|
46
57
|
*/
|
|
47
58
|
protected async executeSearch<T extends keyof NarouSearchResult>(
|
|
48
59
|
params: SearchParams,
|
|
49
|
-
endpoint = "https://api.syosetu.com/novelapi/api/"
|
|
60
|
+
endpoint = "https://api.syosetu.com/novelapi/api/",
|
|
61
|
+
options?: ExecuteOptions
|
|
50
62
|
): Promise<NarouSearchResults<NarouSearchResult, T>> {
|
|
51
|
-
return new NarouSearchResults(
|
|
63
|
+
return new NarouSearchResults(
|
|
64
|
+
await this.execute(params, endpoint, options),
|
|
65
|
+
params
|
|
66
|
+
);
|
|
52
67
|
}
|
|
53
68
|
|
|
54
69
|
/**
|
|
@@ -58,11 +73,13 @@ export default abstract class NarouNovel {
|
|
|
58
73
|
* @see https://dev.syosetu.com/man/api/
|
|
59
74
|
*/
|
|
60
75
|
async executeNovel<T extends keyof NarouSearchResult>(
|
|
61
|
-
params: SearchParams
|
|
76
|
+
params: SearchParams,
|
|
77
|
+
options?: ExecuteOptions
|
|
62
78
|
): Promise<NarouSearchResults<NarouSearchResult, T>> {
|
|
63
79
|
return await this.executeSearch(
|
|
64
80
|
params,
|
|
65
|
-
"https://api.syosetu.com/novelapi/api/"
|
|
81
|
+
"https://api.syosetu.com/novelapi/api/",
|
|
82
|
+
options
|
|
66
83
|
);
|
|
67
84
|
}
|
|
68
85
|
|
|
@@ -73,11 +90,13 @@ export default abstract class NarouNovel {
|
|
|
73
90
|
* @see https://dev.syosetu.com/xman/api/
|
|
74
91
|
*/
|
|
75
92
|
async executeNovel18<T extends keyof NarouSearchResult>(
|
|
76
|
-
params: SearchParams
|
|
93
|
+
params: SearchParams,
|
|
94
|
+
options?: ExecuteOptions
|
|
77
95
|
): Promise<NarouSearchResults<NarouSearchResult, T>> {
|
|
78
96
|
return await this.executeSearch(
|
|
79
97
|
params,
|
|
80
|
-
"https://api.syosetu.com/novel18api/api/"
|
|
98
|
+
"https://api.syosetu.com/novel18api/api/",
|
|
99
|
+
options
|
|
81
100
|
);
|
|
82
101
|
}
|
|
83
102
|
|
|
@@ -87,20 +106,33 @@ export default abstract class NarouNovel {
|
|
|
87
106
|
* @returns ランキング結果
|
|
88
107
|
* @see https://dev.syosetu.com/man/rankapi/
|
|
89
108
|
*/
|
|
90
|
-
async executeRanking(
|
|
91
|
-
|
|
109
|
+
async executeRanking(
|
|
110
|
+
params: RankingParams,
|
|
111
|
+
options?: ExecuteOptions
|
|
112
|
+
): Promise<NarouRankingResult[]> {
|
|
113
|
+
return await this.execute(
|
|
114
|
+
params,
|
|
115
|
+
"https://api.syosetu.com/rank/rankget/",
|
|
116
|
+
options
|
|
117
|
+
);
|
|
92
118
|
}
|
|
93
119
|
|
|
94
120
|
/**
|
|
95
121
|
* 殿堂入りAPiへのリクエストを実行する
|
|
96
122
|
* @param params クエリパラメータ
|
|
123
|
+
* @param options 実行オプション
|
|
97
124
|
* @returns ランキング履歴結果
|
|
98
125
|
* @see https://dev.syosetu.com/man/rankinapi/
|
|
99
126
|
*/
|
|
100
127
|
async executeRankingHistory(
|
|
101
|
-
params: RankingHistoryParams
|
|
128
|
+
params: RankingHistoryParams,
|
|
129
|
+
options?: ExecuteOptions
|
|
102
130
|
): Promise<RankingHistoryRawResult[]> {
|
|
103
|
-
return await this.execute(
|
|
131
|
+
return await this.execute(
|
|
132
|
+
params,
|
|
133
|
+
"https://api.syosetu.com/rank/rankin/",
|
|
134
|
+
options
|
|
135
|
+
);
|
|
104
136
|
}
|
|
105
137
|
|
|
106
138
|
/**
|
|
@@ -110,10 +142,15 @@ export default abstract class NarouNovel {
|
|
|
110
142
|
* @see https://dev.syosetu.com/man/userapi/
|
|
111
143
|
*/
|
|
112
144
|
async executeUserSearch<T extends keyof UserSearchResult>(
|
|
113
|
-
params: UserSearchParams
|
|
145
|
+
params: UserSearchParams,
|
|
146
|
+
options?: ExecuteOptions
|
|
114
147
|
): Promise<NarouSearchResults<UserSearchResult, T>> {
|
|
115
148
|
return new NarouSearchResults<UserSearchResult, T>(
|
|
116
|
-
await this.execute(
|
|
149
|
+
await this.execute(
|
|
150
|
+
params,
|
|
151
|
+
"https://api.syosetu.com/userapi/api/",
|
|
152
|
+
options
|
|
153
|
+
),
|
|
117
154
|
params
|
|
118
155
|
);
|
|
119
156
|
}
|
package/src/params.ts
CHANGED
package/src/ranking.ts
CHANGED
|
@@ -11,6 +11,7 @@ import {
|
|
|
11
11
|
Fields,
|
|
12
12
|
} from "./params.js";
|
|
13
13
|
import type NarouNovel from "./narou.js";
|
|
14
|
+
import type { ExecuteOptions } from "./narou.js";
|
|
14
15
|
import type { SearchResultFields } from "./narou-search-results.js";
|
|
15
16
|
import { addDays, formatDate } from "./util/date.js";
|
|
16
17
|
|
|
@@ -108,21 +109,24 @@ export default class RankingBuilder {
|
|
|
108
109
|
* 設定されたパラメータに基づき、なろう小説ランキングAPIへのリクエストを実行します。
|
|
109
110
|
*
|
|
110
111
|
* 返される結果には、Nコード、ポイント、順位が含まれます。
|
|
112
|
+
* @param options 実行オプション
|
|
111
113
|
* @returns {Promise<NarouRankingResult[]>} ランキング結果の配列
|
|
112
114
|
* @see https://dev.syosetu.com/man/rankapi/#output
|
|
113
115
|
*/
|
|
114
|
-
execute(): Promise<NarouRankingResult[]> {
|
|
116
|
+
execute(options?: ExecuteOptions): Promise<NarouRankingResult[]> {
|
|
115
117
|
const date = formatDate(this.date$);
|
|
116
118
|
this.set({ rtype: `${date}-${this.type$}` });
|
|
117
|
-
return this.api.executeRanking(this.params as RankingParams);
|
|
119
|
+
return this.api.executeRanking(this.params as RankingParams, options);
|
|
118
120
|
}
|
|
119
121
|
|
|
120
122
|
/**
|
|
121
123
|
* ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。
|
|
122
124
|
*/
|
|
123
|
-
async executeWithFields(
|
|
124
|
-
|
|
125
|
-
|
|
125
|
+
async executeWithFields(
|
|
126
|
+
fields?: never[] | undefined,
|
|
127
|
+
opt?: never[] | undefined,
|
|
128
|
+
options?: ExecuteOptions
|
|
129
|
+
): Promise<RankingResult<DefaultSearchResultFields>[]>;
|
|
126
130
|
/**
|
|
127
131
|
* ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。
|
|
128
132
|
*
|
|
@@ -131,7 +135,9 @@ export default class RankingBuilder {
|
|
|
131
135
|
* @returns {Promise<RankingResult<SearchResultFields<TFields>>[]>} 詳細情報を含むランキング結果の配列
|
|
132
136
|
*/
|
|
133
137
|
async executeWithFields<TFields extends Fields>(
|
|
134
|
-
fields: TFields | TFields[]
|
|
138
|
+
fields: TFields | TFields[],
|
|
139
|
+
opt?: never | never[],
|
|
140
|
+
options?: ExecuteOptions
|
|
135
141
|
): Promise<RankingResult<SearchResultFields<TFields>>[]>;
|
|
136
142
|
/**
|
|
137
143
|
* ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。
|
|
@@ -141,7 +147,8 @@ export default class RankingBuilder {
|
|
|
141
147
|
*/
|
|
142
148
|
async executeWithFields(
|
|
143
149
|
fields: never[],
|
|
144
|
-
opt: OptionalFields | OptionalFields[]
|
|
150
|
+
opt: OptionalFields | OptionalFields[],
|
|
151
|
+
options?: ExecuteOptions
|
|
145
152
|
): Promise<RankingResult<DefaultSearchResultFields | "weekly_unique">[]>;
|
|
146
153
|
/**
|
|
147
154
|
* ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。
|
|
@@ -153,7 +160,8 @@ export default class RankingBuilder {
|
|
|
153
160
|
*/
|
|
154
161
|
async executeWithFields<TFields extends Fields>(
|
|
155
162
|
fields: TFields | TFields[],
|
|
156
|
-
opt: OptionalFields | OptionalFields[]
|
|
163
|
+
opt: OptionalFields | OptionalFields[],
|
|
164
|
+
options?: ExecuteOptions
|
|
157
165
|
): Promise<RankingResult<SearchResultFields<TFields> | "weekly_unique">[]>;
|
|
158
166
|
/**
|
|
159
167
|
* ランキングAPIを実行し、取得したNコードを元になろう小説APIで詳細情報を取得して結合します。
|
|
@@ -169,9 +177,10 @@ export default class RankingBuilder {
|
|
|
169
177
|
TOpt extends OptionalFields | undefined = undefined
|
|
170
178
|
>(
|
|
171
179
|
fields: TFields | TFields[] = [],
|
|
172
|
-
opt?: TOpt
|
|
180
|
+
opt?: TOpt,
|
|
181
|
+
options?: ExecuteOptions
|
|
173
182
|
): Promise<RankingResult<SearchResultFields<TFields>>[]> {
|
|
174
|
-
const ranking = await this.execute();
|
|
183
|
+
const ranking = await this.execute(options);
|
|
175
184
|
const fields$ = Array.isArray(fields)
|
|
176
185
|
? fields.length == 0
|
|
177
186
|
? []
|
|
@@ -186,7 +195,7 @@ export default class RankingBuilder {
|
|
|
186
195
|
}
|
|
187
196
|
builder.ncode(rankingNcodes);
|
|
188
197
|
builder.limit(ranking.length);
|
|
189
|
-
const result = await builder.execute();
|
|
198
|
+
const result = await builder.execute(options);
|
|
190
199
|
|
|
191
200
|
return ranking.map<
|
|
192
201
|
RankingResult<
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { NovelSearchBuilderBase } from "./search-builder.js";
|
|
2
|
+
import type { ExecuteOptions } from "./narou.js";
|
|
2
3
|
import type NarouSearchResults from "./narou-search-results.js";
|
|
3
4
|
import type {
|
|
4
5
|
NarouSearchResult,
|
|
@@ -28,10 +29,13 @@ export default class SearchBuilderR18<
|
|
|
28
29
|
/**
|
|
29
30
|
* なろう小説APIへの検索リクエストを実行する
|
|
30
31
|
* @override
|
|
32
|
+
* @param options 実行オプション
|
|
31
33
|
* @returns {Promise<NarouSearchResults>} 検索結果
|
|
32
34
|
*/
|
|
33
|
-
execute(
|
|
34
|
-
|
|
35
|
+
execute(
|
|
36
|
+
options?: ExecuteOptions
|
|
37
|
+
): Promise<NarouSearchResults<NarouSearchResult, T | TOpt>> {
|
|
38
|
+
return this.api.executeNovel18(this.params, options);
|
|
35
39
|
}
|
|
36
40
|
|
|
37
41
|
/**
|
package/src/search-builder.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type NarouNovel from "./narou.js";
|
|
2
|
+
import type { ExecuteOptions } from "./narou.js";
|
|
2
3
|
import type {
|
|
3
4
|
NarouSearchResult,
|
|
4
5
|
SearchResultFields,
|
|
@@ -40,7 +41,7 @@ export abstract class SearchBuilderBase<
|
|
|
40
41
|
constructor(
|
|
41
42
|
protected params: TParams = {} as TParams,
|
|
42
43
|
protected api: NarouNovel
|
|
43
|
-
) {}
|
|
44
|
+
) { }
|
|
44
45
|
|
|
45
46
|
/**
|
|
46
47
|
* 配列から重複を除去する
|
|
@@ -472,10 +473,13 @@ export abstract class NovelSearchBuilderBase<
|
|
|
472
473
|
|
|
473
474
|
/**
|
|
474
475
|
* なろう小説APIへの検索リクエストを実行する
|
|
476
|
+
* @param options 実行オプション
|
|
475
477
|
* @returns {Promise<NarouSearchResults>} 検索結果
|
|
476
478
|
*/
|
|
477
|
-
execute(
|
|
478
|
-
|
|
479
|
+
execute(
|
|
480
|
+
options?: ExecuteOptions
|
|
481
|
+
): Promise<NarouSearchResults<NarouSearchResult, T>> {
|
|
482
|
+
return this.api.executeNovel(this.params, options);
|
|
479
483
|
}
|
|
480
484
|
}
|
|
481
485
|
|
package/src/user-search.ts
CHANGED
|
@@ -5,6 +5,7 @@ import type {
|
|
|
5
5
|
} from "./narou-search-results.js";
|
|
6
6
|
import type { UserFields, UserOrder, UserSearchParams } from "./params.js";
|
|
7
7
|
import { SearchBuilderBase } from "./search-builder.js";
|
|
8
|
+
import type { ExecuteOptions } from "./narou.js";
|
|
8
9
|
|
|
9
10
|
/**
|
|
10
11
|
* なろうユーザ検索API
|
|
@@ -102,9 +103,15 @@ export default class UserSearchBuilder<
|
|
|
102
103
|
|
|
103
104
|
/**
|
|
104
105
|
* なろう小説APIへのリクエストを実行する
|
|
106
|
+
* @param options 実行オプション
|
|
105
107
|
* @returns ランキング
|
|
106
108
|
*/
|
|
107
|
-
execute(
|
|
108
|
-
|
|
109
|
+
execute(
|
|
110
|
+
options?: ExecuteOptions
|
|
111
|
+
): Promise<NarouSearchResults<UserSearchResult, TField>> {
|
|
112
|
+
return this.api.executeUserSearch(
|
|
113
|
+
this.params as UserSearchParams,
|
|
114
|
+
options
|
|
115
|
+
);
|
|
109
116
|
}
|
|
110
117
|
}
|
package/dist/chunk-3A5MHPWL.js
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
// src/narou-search-results.ts
|
|
2
|
-
var NarouSearchResults = class {
|
|
3
|
-
/**
|
|
4
|
-
* @constractor
|
|
5
|
-
* @private
|
|
6
|
-
*/
|
|
7
|
-
constructor([header, ...result], params) {
|
|
8
|
-
const count = header.allcount;
|
|
9
|
-
const limit = params.lim ?? 20;
|
|
10
|
-
const start = params.st ?? 0;
|
|
11
|
-
this.allcount = count;
|
|
12
|
-
this.limit = limit;
|
|
13
|
-
this.start = start;
|
|
14
|
-
this.page = start / limit;
|
|
15
|
-
this.length = result.length;
|
|
16
|
-
this.values = result;
|
|
17
|
-
}
|
|
18
|
-
};
|
|
19
|
-
var NovelType = {
|
|
20
|
-
/** 連載 */
|
|
21
|
-
Rensai: 1,
|
|
22
|
-
/** 短編 */
|
|
23
|
-
Tanpen: 2
|
|
24
|
-
};
|
|
25
|
-
var End = {
|
|
26
|
-
/** 短編小説と完結済小説 */
|
|
27
|
-
KanketsuOrTanpen: 0,
|
|
28
|
-
/** 連載中 */
|
|
29
|
-
Rensai: 1
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
export {
|
|
33
|
-
NarouSearchResults,
|
|
34
|
-
NovelType,
|
|
35
|
-
End
|
|
36
|
-
};
|
|
37
|
-
//# sourceMappingURL=chunk-3A5MHPWL.js.map
|
|
@@ -1 +0,0 @@
|
|
|
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":[]}
|
package/dist/chunk-4ZP5YNWI.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=chunk-4ZP5YNWI.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|