narou 1.2.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (165) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +73 -37
  3. package/dist/index.browser.cjs +87 -1359
  4. package/dist/index.browser.cjs.map +1 -1
  5. package/dist/index.browser.d.cts +11 -19
  6. package/dist/index.browser.d.mts +47 -0
  7. package/dist/index.browser.mjs +66 -0
  8. package/dist/index.browser.mjs.map +1 -0
  9. package/dist/index.cjs +147 -1410
  10. package/dist/index.cjs.map +1 -1
  11. package/dist/index.common-8lS2K_1Y.mjs +1166 -0
  12. package/dist/index.common-8lS2K_1Y.mjs.map +1 -0
  13. package/dist/index.common-CYj0n0aU.cjs +1346 -0
  14. package/dist/index.common-CYj0n0aU.cjs.map +1 -0
  15. package/dist/index.d.cts +28 -21
  16. package/dist/index.d.mts +63 -0
  17. package/dist/index.mjs +128 -0
  18. package/dist/index.mjs.map +1 -0
  19. package/dist/user-search-BY6FdEe7.d.cts +1394 -0
  20. package/dist/user-search-Besgk-Hx.d.mts +1394 -0
  21. package/package.json +28 -37
  22. package/pnpm-lock.yaml +1325 -1100
  23. package/src/index.ts +5 -1
  24. package/src/narou-fetch.ts +4 -3
  25. package/src/narou-jsonp.ts +4 -2
  26. package/src/narou.ts +50 -13
  27. package/src/params.ts +1 -1
  28. package/src/ranking.ts +20 -11
  29. package/src/search-builder-r18.ts +6 -2
  30. package/src/search-builder.ts +7 -3
  31. package/src/user-search.ts +9 -2
  32. package/dist/chunk-3A5MHPWL.js +0 -37
  33. package/dist/chunk-3A5MHPWL.js.map +0 -1
  34. package/dist/chunk-4ZP5YNWI.js +0 -1
  35. package/dist/chunk-4ZP5YNWI.js.map +0 -1
  36. package/dist/chunk-5UDKQCPJ.js +0 -407
  37. package/dist/chunk-5UDKQCPJ.js.map +0 -1
  38. package/dist/chunk-6BZWV4ZC.js +0 -75
  39. package/dist/chunk-6BZWV4ZC.js.map +0 -1
  40. package/dist/chunk-BQLSW236.js +0 -117
  41. package/dist/chunk-BQLSW236.js.map +0 -1
  42. package/dist/chunk-DEQICAN3.js +0 -94
  43. package/dist/chunk-DEQICAN3.js.map +0 -1
  44. package/dist/chunk-E2H3AJSQ.js +0 -57
  45. package/dist/chunk-E2H3AJSQ.js.map +0 -1
  46. package/dist/chunk-HOBLKBZ6.js +0 -452
  47. package/dist/chunk-HOBLKBZ6.js.map +0 -1
  48. package/dist/chunk-IPDEGCWU.js +0 -39
  49. package/dist/chunk-IPDEGCWU.js.map +0 -1
  50. package/dist/chunk-LQLNWSWV.js +0 -26
  51. package/dist/chunk-LQLNWSWV.js.map +0 -1
  52. package/dist/chunk-PLEM2AOH.js +0 -44
  53. package/dist/chunk-PLEM2AOH.js.map +0 -1
  54. package/dist/chunk-RNHRR56W.js +0 -25
  55. package/dist/chunk-RNHRR56W.js.map +0 -1
  56. package/dist/chunk-VUZIISP2.js +0 -23
  57. package/dist/chunk-VUZIISP2.js.map +0 -1
  58. package/dist/chunk-VZVUANDN.js +0 -17
  59. package/dist/chunk-VZVUANDN.js.map +0 -1
  60. package/dist/index.browser.d.ts +0 -55
  61. package/dist/index.browser.js +0 -126
  62. package/dist/index.browser.js.map +0 -1
  63. package/dist/index.common.cjs +0 -1187
  64. package/dist/index.common.cjs.map +0 -1
  65. package/dist/index.common.d.cts +0 -6
  66. package/dist/index.common.d.ts +0 -6
  67. package/dist/index.common.js +0 -76
  68. package/dist/index.common.js.map +0 -1
  69. package/dist/index.d.ts +0 -56
  70. package/dist/index.js +0 -131
  71. package/dist/index.js.map +0 -1
  72. package/dist/narou-DBa12V_l.d.ts +0 -404
  73. package/dist/narou-DCp4aGfA.d.cts +0 -404
  74. package/dist/narou-fetch.cjs +0 -164
  75. package/dist/narou-fetch.cjs.map +0 -1
  76. package/dist/narou-fetch.d.cts +0 -20
  77. package/dist/narou-fetch.d.ts +0 -20
  78. package/dist/narou-fetch.js +0 -10
  79. package/dist/narou-fetch.js.map +0 -1
  80. package/dist/narou-jsonp.cjs +0 -162
  81. package/dist/narou-jsonp.cjs.map +0 -1
  82. package/dist/narou-jsonp.d.cts +0 -13
  83. package/dist/narou-jsonp.d.ts +0 -13
  84. package/dist/narou-jsonp.js +0 -10
  85. package/dist/narou-jsonp.js.map +0 -1
  86. package/dist/narou-ranking-results.cjs +0 -19
  87. package/dist/narou-ranking-results.cjs.map +0 -1
  88. package/dist/narou-ranking-results.d.cts +0 -4
  89. package/dist/narou-ranking-results.d.ts +0 -4
  90. package/dist/narou-ranking-results.js +0 -1
  91. package/dist/narou-ranking-results.js.map +0 -1
  92. package/dist/narou-search-results-C21hWrnL.d.cts +0 -727
  93. package/dist/narou-search-results-DT0YdaBn.d.ts +0 -727
  94. package/dist/narou-search-results.cjs +0 -62
  95. package/dist/narou-search-results.cjs.map +0 -1
  96. package/dist/narou-search-results.d.cts +0 -2
  97. package/dist/narou-search-results.d.ts +0 -2
  98. package/dist/narou-search-results.js +0 -11
  99. package/dist/narou-search-results.js.map +0 -1
  100. package/dist/narou.cjs +0 -112
  101. package/dist/narou.cjs.map +0 -1
  102. package/dist/narou.d.cts +0 -4
  103. package/dist/narou.d.ts +0 -4
  104. package/dist/narou.js +0 -8
  105. package/dist/narou.js.map +0 -1
  106. package/dist/params.cjs +0 -448
  107. package/dist/params.cjs.map +0 -1
  108. package/dist/params.d.cts +0 -2
  109. package/dist/params.d.ts +0 -2
  110. package/dist/params.js +0 -41
  111. package/dist/params.js.map +0 -1
  112. package/dist/ranking-history.cjs +0 -47
  113. package/dist/ranking-history.cjs.map +0 -1
  114. package/dist/ranking-history.d.cts +0 -28
  115. package/dist/ranking-history.d.ts +0 -28
  116. package/dist/ranking-history.js +0 -8
  117. package/dist/ranking-history.js.map +0 -1
  118. package/dist/ranking.cjs +0 -783
  119. package/dist/ranking.cjs.map +0 -1
  120. package/dist/ranking.d.cts +0 -108
  121. package/dist/ranking.d.ts +0 -108
  122. package/dist/ranking.js +0 -10
  123. package/dist/ranking.js.map +0 -1
  124. package/dist/search-builder-r18.cjs +0 -547
  125. package/dist/search-builder-r18.cjs.map +0 -1
  126. package/dist/search-builder-r18.d.cts +0 -45
  127. package/dist/search-builder-r18.d.ts +0 -45
  128. package/dist/search-builder-r18.js +0 -9
  129. package/dist/search-builder-r18.js.map +0 -1
  130. package/dist/search-builder.cjs +0 -591
  131. package/dist/search-builder.cjs.map +0 -1
  132. package/dist/search-builder.d.cts +0 -4
  133. package/dist/search-builder.d.ts +0 -4
  134. package/dist/search-builder.js +0 -12
  135. package/dist/search-builder.js.map +0 -1
  136. package/dist/user-search.cjs +0 -325
  137. package/dist/user-search.cjs.map +0 -1
  138. package/dist/user-search.d.cts +0 -66
  139. package/dist/user-search.d.ts +0 -66
  140. package/dist/user-search.js +0 -9
  141. package/dist/user-search.js.map +0 -1
  142. package/dist/util/date.cjs +0 -51
  143. package/dist/util/date.cjs.map +0 -1
  144. package/dist/util/date.d.cts +0 -21
  145. package/dist/util/date.d.ts +0 -21
  146. package/dist/util/date.js +0 -11
  147. package/dist/util/date.js.map +0 -1
  148. package/dist/util/jsonp.cjs +0 -63
  149. package/dist/util/jsonp.cjs.map +0 -1
  150. package/dist/util/jsonp.d.cts +0 -49
  151. package/dist/util/jsonp.d.ts +0 -49
  152. package/dist/util/jsonp.js +0 -7
  153. package/dist/util/jsonp.js.map +0 -1
  154. package/dist/util/type.cjs +0 -19
  155. package/dist/util/type.cjs.map +0 -1
  156. package/dist/util/type.d.cts +0 -27
  157. package/dist/util/type.d.ts +0 -27
  158. package/dist/util/type.js +0 -1
  159. package/dist/util/type.js.map +0 -1
  160. package/dist/util/unzipp.cjs +0 -47
  161. package/dist/util/unzipp.cjs.map +0 -1
  162. package/dist/util/unzipp.d.cts +0 -12
  163. package/dist/util/unzipp.d.ts +0 -12
  164. package/dist/util/unzipp.js +0 -7
  165. package/dist/util/unzipp.js.map +0 -1
package/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 {
@@ -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;
@@ -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(await this.execute(params, endpoint), params);
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(params: RankingParams): Promise<NarouRankingResult[]> {
91
- return await this.execute(params, "https://api.syosetu.com/rank/rankget/");
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(params, "https://api.syosetu.com/rank/rankin/");
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(params, "https://api.syosetu.com/userapi/api/"),
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
@@ -372,7 +372,7 @@ export const Order = {
372
372
  /** ブックマーク数の多い順 */
373
373
  FavoriteNovelCount: "favnovelcnt",
374
374
  /** レビュー数の多い順 */
375
- ReviewCount: "favnovelcnt",
375
+ ReviewCount: "reviewcnt",
376
376
  /** 総合ポイントの高い順 */
377
377
  HyokaDesc: "hyoka",
378
378
  /** 総合ポイントの低い順 */
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(): Promise<
124
- RankingResult<DefaultSearchResultFields>[]
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(): Promise<NarouSearchResults<NarouSearchResult, T | TOpt>> {
34
- return this.api.executeNovel18(this.params);
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
  /**
@@ -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(): Promise<NarouSearchResults<NarouSearchResult, T>> {
478
- return this.api.executeNovel(this.params);
479
+ execute(
480
+ options?: ExecuteOptions
481
+ ): Promise<NarouSearchResults<NarouSearchResult, T>> {
482
+ return this.api.executeNovel(this.params, options);
479
483
  }
480
484
  }
481
485
 
@@ -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(): Promise<NarouSearchResults<UserSearchResult, TField>> {
108
- return this.api.executeUserSearch(this.params as UserSearchParams);
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
  }
@@ -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":[]}
@@ -1 +0,0 @@
1
- //# sourceMappingURL=chunk-4ZP5YNWI.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}