@mapcreator/api 0.0.0-fonts.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 (265) hide show
  1. package/LICENSE +29 -0
  2. package/README.md +86 -0
  3. package/cjs/api/apiCommon.d.ts +7 -0
  4. package/cjs/api/apiCommon.d.ts.map +1 -0
  5. package/cjs/api/apiCommon.js +31 -0
  6. package/cjs/api/apiCommon.js.map +1 -0
  7. package/cjs/api/choropleth.d.ts +61 -0
  8. package/cjs/api/choropleth.d.ts.map +1 -0
  9. package/cjs/api/choropleth.js +32 -0
  10. package/cjs/api/choropleth.js.map +1 -0
  11. package/cjs/api/color.d.ts +16 -0
  12. package/cjs/api/color.d.ts.map +1 -0
  13. package/cjs/api/color.js +8 -0
  14. package/cjs/api/color.js.map +1 -0
  15. package/cjs/api/dimension.d.ts +25 -0
  16. package/cjs/api/dimension.d.ts.map +1 -0
  17. package/cjs/api/dimension.js +14 -0
  18. package/cjs/api/dimension.js.map +1 -0
  19. package/cjs/api/dimensionSet.d.ts +15 -0
  20. package/cjs/api/dimensionSet.d.ts.map +1 -0
  21. package/cjs/api/dimensionSet.js +7 -0
  22. package/cjs/api/dimensionSet.js.map +1 -0
  23. package/cjs/api/feature.d.ts +16 -0
  24. package/cjs/api/feature.d.ts.map +1 -0
  25. package/cjs/api/feature.js +8 -0
  26. package/cjs/api/feature.js.map +1 -0
  27. package/cjs/api/font.d.ts +31 -0
  28. package/cjs/api/font.d.ts.map +1 -0
  29. package/cjs/api/font.js +16 -0
  30. package/cjs/api/font.js.map +1 -0
  31. package/cjs/api/fontFamily.d.ts +17 -0
  32. package/cjs/api/fontFamily.d.ts.map +1 -0
  33. package/cjs/api/fontFamily.js +17 -0
  34. package/cjs/api/fontFamily.js.map +1 -0
  35. package/cjs/api/highlight.d.ts +41 -0
  36. package/cjs/api/highlight.d.ts.map +1 -0
  37. package/cjs/api/highlight.js +25 -0
  38. package/cjs/api/highlight.js.map +1 -0
  39. package/cjs/api/insetMap.d.ts +37 -0
  40. package/cjs/api/insetMap.d.ts.map +1 -0
  41. package/cjs/api/insetMap.js +49 -0
  42. package/cjs/api/insetMap.js.map +1 -0
  43. package/cjs/api/job.d.ts +42 -0
  44. package/cjs/api/job.d.ts.map +1 -0
  45. package/cjs/api/job.js +71 -0
  46. package/cjs/api/job.js.map +1 -0
  47. package/cjs/api/jobResult.d.ts +40 -0
  48. package/cjs/api/jobResult.d.ts.map +1 -0
  49. package/cjs/api/jobResult.js +35 -0
  50. package/cjs/api/jobResult.js.map +1 -0
  51. package/cjs/api/jobRevision.d.ts +76 -0
  52. package/cjs/api/jobRevision.d.ts.map +1 -0
  53. package/cjs/api/jobRevision.js +132 -0
  54. package/cjs/api/jobRevision.js.map +1 -0
  55. package/cjs/api/jobShare.d.ts +26 -0
  56. package/cjs/api/jobShare.d.ts.map +1 -0
  57. package/cjs/api/jobShare.js +9 -0
  58. package/cjs/api/jobShare.js.map +1 -0
  59. package/cjs/api/jobType.d.ts +17 -0
  60. package/cjs/api/jobType.d.ts.map +1 -0
  61. package/cjs/api/jobType.js +11 -0
  62. package/cjs/api/jobType.js.map +1 -0
  63. package/cjs/api/language.d.ts +17 -0
  64. package/cjs/api/language.d.ts.map +1 -0
  65. package/cjs/api/language.js +3 -0
  66. package/cjs/api/language.js.map +1 -0
  67. package/cjs/api/layer.d.ts +26 -0
  68. package/cjs/api/layer.d.ts.map +1 -0
  69. package/cjs/api/layer.js +14 -0
  70. package/cjs/api/layer.js.map +1 -0
  71. package/cjs/api/layerFaq.d.ts +27 -0
  72. package/cjs/api/layerFaq.d.ts.map +1 -0
  73. package/cjs/api/layerFaq.js +16 -0
  74. package/cjs/api/layerFaq.js.map +1 -0
  75. package/cjs/api/layerGroup.d.ts +16 -0
  76. package/cjs/api/layerGroup.d.ts.map +1 -0
  77. package/cjs/api/layerGroup.js +36 -0
  78. package/cjs/api/layerGroup.js.map +1 -0
  79. package/cjs/api/mapstyleSet.d.ts +31 -0
  80. package/cjs/api/mapstyleSet.d.ts.map +1 -0
  81. package/cjs/api/mapstyleSet.js +19 -0
  82. package/cjs/api/mapstyleSet.js.map +1 -0
  83. package/cjs/api/message.d.ts +32 -0
  84. package/cjs/api/message.d.ts.map +1 -0
  85. package/cjs/api/message.js +37 -0
  86. package/cjs/api/message.js.map +1 -0
  87. package/cjs/api/organisation.d.ts +41 -0
  88. package/cjs/api/organisation.d.ts.map +1 -0
  89. package/cjs/api/organisation.js +41 -0
  90. package/cjs/api/organisation.js.map +1 -0
  91. package/cjs/api/resources.d.ts +65 -0
  92. package/cjs/api/resources.d.ts.map +1 -0
  93. package/cjs/api/resources.js +61 -0
  94. package/cjs/api/resources.js.map +1 -0
  95. package/cjs/api/svg.d.ts +21 -0
  96. package/cjs/api/svg.d.ts.map +1 -0
  97. package/cjs/api/svg.js +15 -0
  98. package/cjs/api/svg.js.map +1 -0
  99. package/cjs/api/svgSet.d.ts +22 -0
  100. package/cjs/api/svgSet.d.ts.map +1 -0
  101. package/cjs/api/svgSet.js +25 -0
  102. package/cjs/api/svgSet.js.map +1 -0
  103. package/cjs/api/user.d.ts +128 -0
  104. package/cjs/api/user.d.ts.map +1 -0
  105. package/cjs/api/user.js +146 -0
  106. package/cjs/api/user.js.map +1 -0
  107. package/cjs/index.d.ts +27 -0
  108. package/cjs/index.d.ts.map +1 -0
  109. package/cjs/index.js +52 -0
  110. package/cjs/index.js.map +1 -0
  111. package/cjs/oauth.d.ts +27 -0
  112. package/cjs/oauth.d.ts.map +1 -0
  113. package/cjs/oauth.js +245 -0
  114. package/cjs/oauth.js.map +1 -0
  115. package/cjs/utils.d.ts +72 -0
  116. package/cjs/utils.d.ts.map +1 -0
  117. package/cjs/utils.js +220 -0
  118. package/cjs/utils.js.map +1 -0
  119. package/esm/api/apiCommon.d.ts +7 -0
  120. package/esm/api/apiCommon.d.ts.map +1 -0
  121. package/esm/api/apiCommon.js +28 -0
  122. package/esm/api/apiCommon.js.map +1 -0
  123. package/esm/api/choropleth.d.ts +61 -0
  124. package/esm/api/choropleth.d.ts.map +1 -0
  125. package/esm/api/choropleth.js +27 -0
  126. package/esm/api/choropleth.js.map +1 -0
  127. package/esm/api/color.d.ts +16 -0
  128. package/esm/api/color.d.ts.map +1 -0
  129. package/esm/api/color.js +5 -0
  130. package/esm/api/color.js.map +1 -0
  131. package/esm/api/dimension.d.ts +25 -0
  132. package/esm/api/dimension.d.ts.map +1 -0
  133. package/esm/api/dimension.js +11 -0
  134. package/esm/api/dimension.js.map +1 -0
  135. package/esm/api/dimensionSet.d.ts +15 -0
  136. package/esm/api/dimensionSet.d.ts.map +1 -0
  137. package/esm/api/dimensionSet.js +4 -0
  138. package/esm/api/dimensionSet.js.map +1 -0
  139. package/esm/api/feature.d.ts +16 -0
  140. package/esm/api/feature.d.ts.map +1 -0
  141. package/esm/api/feature.js +5 -0
  142. package/esm/api/feature.js.map +1 -0
  143. package/esm/api/font.d.ts +31 -0
  144. package/esm/api/font.d.ts.map +1 -0
  145. package/esm/api/font.js +12 -0
  146. package/esm/api/font.js.map +1 -0
  147. package/esm/api/fontFamily.d.ts +17 -0
  148. package/esm/api/fontFamily.d.ts.map +1 -0
  149. package/esm/api/fontFamily.js +13 -0
  150. package/esm/api/fontFamily.js.map +1 -0
  151. package/esm/api/highlight.d.ts +41 -0
  152. package/esm/api/highlight.d.ts.map +1 -0
  153. package/esm/api/highlight.js +21 -0
  154. package/esm/api/highlight.js.map +1 -0
  155. package/esm/api/insetMap.d.ts +37 -0
  156. package/esm/api/insetMap.d.ts.map +1 -0
  157. package/esm/api/insetMap.js +44 -0
  158. package/esm/api/insetMap.js.map +1 -0
  159. package/esm/api/job.d.ts +42 -0
  160. package/esm/api/job.d.ts.map +1 -0
  161. package/esm/api/job.js +59 -0
  162. package/esm/api/job.js.map +1 -0
  163. package/esm/api/jobResult.d.ts +40 -0
  164. package/esm/api/jobResult.d.ts.map +1 -0
  165. package/esm/api/jobResult.js +30 -0
  166. package/esm/api/jobResult.js.map +1 -0
  167. package/esm/api/jobRevision.d.ts +76 -0
  168. package/esm/api/jobRevision.d.ts.map +1 -0
  169. package/esm/api/jobRevision.js +120 -0
  170. package/esm/api/jobRevision.js.map +1 -0
  171. package/esm/api/jobShare.d.ts +26 -0
  172. package/esm/api/jobShare.d.ts.map +1 -0
  173. package/esm/api/jobShare.js +6 -0
  174. package/esm/api/jobShare.js.map +1 -0
  175. package/esm/api/jobType.d.ts +17 -0
  176. package/esm/api/jobType.d.ts.map +1 -0
  177. package/esm/api/jobType.js +8 -0
  178. package/esm/api/jobType.js.map +1 -0
  179. package/esm/api/language.d.ts +17 -0
  180. package/esm/api/language.d.ts.map +1 -0
  181. package/esm/api/language.js +2 -0
  182. package/esm/api/language.js.map +1 -0
  183. package/esm/api/layer.d.ts +26 -0
  184. package/esm/api/layer.d.ts.map +1 -0
  185. package/esm/api/layer.js +11 -0
  186. package/esm/api/layer.js.map +1 -0
  187. package/esm/api/layerFaq.d.ts +27 -0
  188. package/esm/api/layerFaq.d.ts.map +1 -0
  189. package/esm/api/layerFaq.js +12 -0
  190. package/esm/api/layerFaq.js.map +1 -0
  191. package/esm/api/layerGroup.d.ts +16 -0
  192. package/esm/api/layerGroup.d.ts.map +1 -0
  193. package/esm/api/layerGroup.js +33 -0
  194. package/esm/api/layerGroup.js.map +1 -0
  195. package/esm/api/mapstyleSet.d.ts +31 -0
  196. package/esm/api/mapstyleSet.d.ts.map +1 -0
  197. package/esm/api/mapstyleSet.js +16 -0
  198. package/esm/api/mapstyleSet.js.map +1 -0
  199. package/esm/api/message.d.ts +32 -0
  200. package/esm/api/message.d.ts.map +1 -0
  201. package/esm/api/message.js +32 -0
  202. package/esm/api/message.js.map +1 -0
  203. package/esm/api/organisation.d.ts +41 -0
  204. package/esm/api/organisation.d.ts.map +1 -0
  205. package/esm/api/organisation.js +35 -0
  206. package/esm/api/organisation.js.map +1 -0
  207. package/esm/api/resources.d.ts +65 -0
  208. package/esm/api/resources.d.ts.map +1 -0
  209. package/esm/api/resources.js +55 -0
  210. package/esm/api/resources.js.map +1 -0
  211. package/esm/api/svg.d.ts +21 -0
  212. package/esm/api/svg.d.ts.map +1 -0
  213. package/esm/api/svg.js +11 -0
  214. package/esm/api/svg.js.map +1 -0
  215. package/esm/api/svgSet.d.ts +22 -0
  216. package/esm/api/svgSet.d.ts.map +1 -0
  217. package/esm/api/svgSet.js +21 -0
  218. package/esm/api/svgSet.js.map +1 -0
  219. package/esm/api/user.d.ts +128 -0
  220. package/esm/api/user.d.ts.map +1 -0
  221. package/esm/api/user.js +127 -0
  222. package/esm/api/user.js.map +1 -0
  223. package/esm/index.d.ts +27 -0
  224. package/esm/index.d.ts.map +1 -0
  225. package/esm/index.js +27 -0
  226. package/esm/index.js.map +1 -0
  227. package/esm/oauth.d.ts +27 -0
  228. package/esm/oauth.d.ts.map +1 -0
  229. package/esm/oauth.js +237 -0
  230. package/esm/oauth.js.map +1 -0
  231. package/esm/utils.d.ts +72 -0
  232. package/esm/utils.d.ts.map +1 -0
  233. package/esm/utils.js +206 -0
  234. package/esm/utils.js.map +1 -0
  235. package/package.json +80 -0
  236. package/src/README.md +126 -0
  237. package/src/api/apiCommon.ts +70 -0
  238. package/src/api/choropleth.ts +132 -0
  239. package/src/api/color.ts +22 -0
  240. package/src/api/dimension.ts +44 -0
  241. package/src/api/dimensionSet.ts +20 -0
  242. package/src/api/feature.ts +22 -0
  243. package/src/api/font.ts +49 -0
  244. package/src/api/fontFamily.ts +43 -0
  245. package/src/api/highlight.ts +87 -0
  246. package/src/api/insetMap.ts +96 -0
  247. package/src/api/job.ts +130 -0
  248. package/src/api/jobResult.ts +95 -0
  249. package/src/api/jobRevision.ts +279 -0
  250. package/src/api/jobShare.ts +35 -0
  251. package/src/api/jobType.ts +26 -0
  252. package/src/api/language.ts +19 -0
  253. package/src/api/layer.ts +38 -0
  254. package/src/api/layerFaq.ts +53 -0
  255. package/src/api/layerGroup.ts +69 -0
  256. package/src/api/mapstyleSet.ts +48 -0
  257. package/src/api/message.ts +80 -0
  258. package/src/api/organisation.ts +95 -0
  259. package/src/api/resources.ts +153 -0
  260. package/src/api/svg.ts +33 -0
  261. package/src/api/svgSet.ts +56 -0
  262. package/src/api/user.ts +327 -0
  263. package/src/index.ts +43 -0
  264. package/src/oauth.ts +314 -0
  265. package/src/utils.ts +342 -0
package/esm/utils.js ADDED
@@ -0,0 +1,206 @@
1
+ import { apiHost, authenticate, token } from './oauth.js';
2
+ export const myUser = 'me';
3
+ export const myOrganisations = 'mine';
4
+ export const lastJobRevision = 'last';
5
+ export const defaultListHeader = { 'X-Per-Page': '50' };
6
+ export const deletedNoneParam = getSearchParams({ deleted: 'none' });
7
+ export const keysToRemove = ['created_at', 'deleted_at', 'updated_at'];
8
+ export const staticContext = { keysToRemove: new Set(keysToRemove), keysToAdd: [], revivers: {} };
9
+ // class AuthorizationError extends Error {}
10
+ export class NetworkError extends Error {
11
+ }
12
+ export class HTTPError extends Error {
13
+ constructor(response) {
14
+ super(response.statusText);
15
+ this.statusCode = response.status;
16
+ }
17
+ }
18
+ export class APIError extends Error {
19
+ constructor(apiError) {
20
+ super(apiError.error.message);
21
+ this.code = apiError.error.type;
22
+ }
23
+ }
24
+ export function getSearchParams(search) {
25
+ return new URLSearchParams(Object.entries(search).reduce((arr, [key, value]) => {
26
+ if (Array.isArray(value)) {
27
+ arr.push(...value.map(val => [`${key}[]`, String(val)]));
28
+ }
29
+ else if (value !== null && typeof value === 'object') {
30
+ const params = getSearchParams(value);
31
+ arr.push(...Array.from(params.entries()).map(([subKey, val]) => [
32
+ ~subKey.indexOf('[')
33
+ ? `${key}[${subKey.slice(0, subKey.indexOf('['))}]${subKey.slice(subKey.indexOf('['))}`
34
+ : `${key}[${subKey}]`,
35
+ val,
36
+ ]));
37
+ }
38
+ else {
39
+ arr.push([key, String(value)]);
40
+ }
41
+ return arr;
42
+ }, []));
43
+ }
44
+ export class APIMeta extends Error {
45
+ constructor(data, headers, status) {
46
+ super();
47
+ this.data = data;
48
+ this.status = status;
49
+ this.headers = headers;
50
+ }
51
+ }
52
+ export async function request(path, body, extraHeaders, extraOptions) {
53
+ const href = `${apiHost}${path}`;
54
+ const init = getRequestInit(body, extraHeaders, extraOptions);
55
+ const response = await fetch(href, init).catch((error) => {
56
+ var _a;
57
+ throw new NetworkError((_a = error === null || error === void 0 ? void 0 : error.message) !== null && _a !== void 0 ? _a : error);
58
+ });
59
+ if (response.ok) {
60
+ const json = (await response.json().catch(() => ({
61
+ success: false,
62
+ error: { type: 'SyntaxError', message: 'Malformed JSON response' },
63
+ })));
64
+ if (json.success) {
65
+ const { data } = json;
66
+ const withMeta = extraOptions === null || extraOptions === void 0 ? void 0 : extraOptions.withMeta;
67
+ const revivers = extraOptions === null || extraOptions === void 0 ? void 0 : extraOptions.revivers;
68
+ const keys = revivers ? Object.keys(revivers) : [];
69
+ const context = revivers && keys.length
70
+ ? getContext(revivers, keys)
71
+ : staticContext;
72
+ let result;
73
+ if (Array.isArray(data)) {
74
+ let moreData = [];
75
+ const headers = response.headers;
76
+ // @ts-expect-error TS2362, get valid number or 0
77
+ const total = headers.get('X-Paginate-Total') | 0;
78
+ if (!withMeta && ((data.length && total > data.length) || response.status === 206)) {
79
+ // @ts-expect-error TS2362, get valid number or 0
80
+ const offset = `${(headers.get('X-Paginate-Offset') | 0) + data.length}`;
81
+ moreData = await request(path, body, Object.assign(Object.assign({}, extraHeaders), { 'X-Offset': offset }), extraOptions);
82
+ }
83
+ if (data.length) {
84
+ result = (typeof data[0] !== 'string'
85
+ ? data.map(processData, context)
86
+ : data).concat(moreData);
87
+ }
88
+ else {
89
+ result = moreData;
90
+ }
91
+ }
92
+ else {
93
+ if (data !== undefined) {
94
+ // @ts-expect-error TS2345, TODO: fix type error for the `context` object
95
+ result = (typeof data !== 'string' ? processData.call(context, data) : data);
96
+ }
97
+ else {
98
+ result = {};
99
+ }
100
+ }
101
+ if (withMeta) {
102
+ throw new APIMeta(result, response.headers, response.status);
103
+ }
104
+ return result;
105
+ }
106
+ else {
107
+ throw new APIError(json);
108
+ }
109
+ }
110
+ else {
111
+ // TODO: parse and process all typical errors
112
+ // eslint-disable-next-line default-case
113
+ switch (response.status) {
114
+ case 401:
115
+ await authenticate();
116
+ break; // NO-OP
117
+ case 403:
118
+ case 404:
119
+ case 406:
120
+ throw new APIError((await response.json().catch(() => ({
121
+ success: false,
122
+ error: { type: 'HttpException', message: response.statusText },
123
+ }))));
124
+ case 429:
125
+ await new Promise((resolve) => { setTimeout(resolve, response.headers.get('X-RateLimit-Reset') * 1000 || 500); });
126
+ return request(path, body, extraHeaders, extraOptions);
127
+ }
128
+ throw new HTTPError(response);
129
+ }
130
+ }
131
+ function getRequestInit(body, extraHeaders, extraOptions) {
132
+ var _a;
133
+ const authorization = token ? { Authorization: token.toString() } : null;
134
+ let contentType = null;
135
+ if (body !== undefined) {
136
+ switch (true) {
137
+ case typeof body === 'string':
138
+ contentType = { 'Content-Type': 'text/plain' };
139
+ break;
140
+ case body instanceof FormData: // Autofilled with 'multipart/form-data'
141
+ case body instanceof URLSearchParams: // Autofilled with 'application/x-www-form-urlencoded'
142
+ break;
143
+ case body instanceof Blob: // File is instance of Blob too
144
+ contentType = { 'Content-Type': body.type || 'application/octet-stream' };
145
+ break;
146
+ case body instanceof ArrayBuffer:
147
+ case ArrayBuffer.isView(body):
148
+ contentType = { 'Content-Type': 'application/octet-stream' };
149
+ break;
150
+ case body === null && !(extraOptions === null || extraOptions === void 0 ? void 0 : extraOptions.sendNull):
151
+ break;
152
+ default:
153
+ contentType = { 'Content-Type': 'application/json' };
154
+ body = JSON.stringify(body);
155
+ }
156
+ }
157
+ const headers = Object.assign(Object.assign(Object.assign({ Accept: 'application/json' }, authorization), contentType), extraHeaders);
158
+ const method = (_a = extraOptions === null || extraOptions === void 0 ? void 0 : extraOptions.method) !== null && _a !== void 0 ? _a : (body != null ? 'POST' : 'GET'); // don't touch `!=` please
159
+ return { body, headers, method };
160
+ }
161
+ export function getContext(revivers, keys = Object.keys(revivers)) {
162
+ return {
163
+ keysToRemove: new Set(keys.filter(isUndefined, revivers).concat(keysToRemove)),
164
+ keysToAdd: keys.filter(isReviver, revivers),
165
+ revivers,
166
+ };
167
+ }
168
+ export function processData(data) {
169
+ const result = {};
170
+ const keys = Object.keys(data).filter(isPreserved, this.keysToRemove);
171
+ for (let i = 0; i < keys.length; ++i) {
172
+ result[toCamelCase(keys[i])] = data[keys[i]];
173
+ }
174
+ if (this.keysToAdd.length) {
175
+ const keys = this.keysToAdd;
176
+ for (let i = 0; i < keys.length; ++i) {
177
+ result[keys[i]] = this.revivers[keys[i]](data);
178
+ }
179
+ }
180
+ return result;
181
+ } /* eslint-enable @typescript-eslint/prefer-for-of */
182
+ export function toApiType(body) {
183
+ return Object.fromEntries(Object.entries(body).map(([k, v]) => [toSnakeCase(k), v]));
184
+ }
185
+ export function toAppType(body) {
186
+ return Object.fromEntries(Object.entries(body).map(([k, v]) => [toCamelCase(k), v]));
187
+ }
188
+ export function ensureArray(data) {
189
+ return Array.isArray(data) ? data : [data];
190
+ }
191
+ function toCamelCase(key) {
192
+ return key.replace(/_+(.)/g, (_, c) => c.toUpperCase());
193
+ }
194
+ function toSnakeCase(key) {
195
+ return key.replace(/[A-Z]/g, '_$&').toLowerCase();
196
+ }
197
+ function isUndefined(key) {
198
+ return this[key] === undefined;
199
+ }
200
+ function isReviver(key) {
201
+ return this[key] !== undefined;
202
+ }
203
+ function isPreserved(key) {
204
+ return !this.has(key);
205
+ }
206
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,80 @@
1
+ {
2
+ "name": "@mapcreator/api",
3
+ "version": "0.0.0-fonts.0",
4
+ "description": "Mapcreator JavaScript API",
5
+ "license": "BSD-3-Clause",
6
+ "main": "./cjs/index.js",
7
+ "types": "./cjs/index.d.ts",
8
+ "exports": {
9
+ ".": {
10
+ "types": "./esm/index.d.ts",
11
+ "import": "./esm/index.js",
12
+ "require": "./cjs/index.js"
13
+ },
14
+ "./oauth": {
15
+ "types": "./esm/oauth.d.ts",
16
+ "import": "./esm/oauth.js",
17
+ "require": "./cjs/oauth.js"
18
+ },
19
+ "./oauth.js": {
20
+ "types": "./esm/oauth.d.ts",
21
+ "import": "./esm/oauth.js",
22
+ "require": "./cjs/oauth.js"
23
+ },
24
+ "./utils": {
25
+ "types": "./esm/utils.d.ts",
26
+ "import": "./esm/utils.js",
27
+ "require": "./cjs/utils.js"
28
+ },
29
+ "./utils.js": {
30
+ "types": "./esm/utils.d.ts",
31
+ "import": "./esm/utils.js",
32
+ "require": "./cjs/utils.js"
33
+ },
34
+ "./package.json": "./package.json",
35
+ "./*": {
36
+ "types": "./esm/api/*.d.ts",
37
+ "import": "./esm/api/*.js",
38
+ "require": "./cjs/api/*.js"
39
+ },
40
+ "./*.js": {
41
+ "types": "./esm/api/*.d.ts",
42
+ "import": "./esm/api/*.js",
43
+ "require": "./cjs/api/*.js"
44
+ }
45
+ },
46
+ "scripts": {
47
+ "build": "tsc --outDir esm && tsc -m commonjs --outDir cjs",
48
+ "clean": "npx rimraf esm/ cjs/",
49
+ "lint": "eslint --ext .ts src",
50
+ "prepublishOnly": "npm run lint && npm run clean && npm run build",
51
+ "test": "echo \"Error: no test specified\" && exit 1"
52
+ },
53
+ "repository": {
54
+ "type": "git",
55
+ "url": "git+https://gitlab.com/mapcreator/api-wrapper.git"
56
+ },
57
+ "publishConfig": {
58
+ "registry": "https://registry.npmjs.org/"
59
+ },
60
+ "files": [
61
+ "cjs",
62
+ "esm",
63
+ "src"
64
+ ],
65
+ "bugs": {
66
+ "url": "https://gitlab.com/mapcreator/api-wrapper/issues"
67
+ },
68
+ "homepage": "https://gitlab.com/mapcreator/api-wrapper#readme",
69
+ "dependencies": {
70
+ "@types/geojson": "^7946.0.14",
71
+ "type-fest": "^4.10"
72
+ },
73
+ "devDependencies": {
74
+ "@stylistic/eslint-plugin": "~1.5",
75
+ "@typescript-eslint/eslint-plugin": "~6.15",
76
+ "@typescript-eslint/parser": "~6.15",
77
+ "eslint": "~8.57",
78
+ "typescript": "~5.8.3"
79
+ }
80
+ }
package/src/README.md ADDED
@@ -0,0 +1,126 @@
1
+ ### Used type system
2
+
3
+ We use type declarations for both the data coming over the wire and the data used by the application. In general, these types differ only in the presence of additional fields in the data arriving over the network (like `created_at`), and used naming convention. Data over the network uses the so-called snake case.
4
+
5
+ All in all, we can use TypeScript's native mechanisms to convert one type to another and fully define just one type:
6
+
7
+ ```typescript
8
+ import type { CamelCasedProperties } from 'type-fest';
9
+
10
+ type ApiType =
11
+ | ({
12
+ data: {
13
+ prop: unknown;
14
+ } & ApiCommonData;
15
+ } & Omit<ApiSuccess, 'data'>)
16
+ | ApiError;
17
+
18
+ type AppType = CamelCasedProperties<Omit<Exclude<ApiType, ApiError>['data'], keyof ApiCommonData>>;
19
+ ```
20
+
21
+ or in reverse order:
22
+
23
+ ```typescript
24
+ import type { SnakeCasedProperties } from 'type-fest';
25
+
26
+ type AppType = {
27
+ prop: unknown;
28
+ };
29
+
30
+ type ApiType =
31
+ | ({
32
+ data: SnakeCasedProperties<AppType> & ApiCommonData;
33
+ } & Omit<ApiSuccess, 'data'>)
34
+ | ApiError;
35
+ ```
36
+
37
+ But the decision was made not to do this, since it may be more difficult for the developer to make the conversion in their head than to see it in front of their eyes.
38
+
39
+ ### Using a `request()`
40
+
41
+ The function has the following signature:
42
+
43
+ ```typescript
44
+ async function request<I extends ApiCommon, O extends Record<string, unknown> | string>(
45
+ path: string,
46
+ body?: XMLHttpRequestBodyInit | Record<string | number, unknown> | null,
47
+ extraHeaders?: Record<string, string> | null,
48
+ extraOptions?: ExtraOptions<I, O>,
49
+ ): Promise<O | O[]> { /* ... */ }
50
+ ```
51
+
52
+ Let's take it step by step.
53
+
54
+ `I extends ApiCommon` - represents the type of data we receive over the network.
55
+
56
+ `O extends Record<string, unknown> | string` - represents the data type that will be used in the application.
57
+
58
+ Ideally you should describe and convey both types. This will help to check the data types in the arguments passed.
59
+ See current data types for an example.
60
+
61
+ `path: string` - the path to the resource, must include the API version, but must not include the schema or authority.
62
+ Example: `/v1/jobs/12345`
63
+
64
+ `body?: XMLHttpRequestBodyInit | Record<string | number, unknown> | null` - any meaningful body type. In general,
65
+ the presence of an JSON object is assumed (or the absence of one for methods that only request data), but you can
66
+ also pass `Blob`, `FormData`, `URLSearchParams` or just `ArrayBuffer`. The required content type will be added to
67
+ the headers automatically.
68
+
69
+ `extraHeaders?: Record<string, string> | null` - the object with additional headers.
70
+
71
+ `extraOptions?: ExtraOptions<I, O>` - where `ExtraOptions<I, O>` is defined like this:
72
+
73
+ ```typescript
74
+ interface ExtraOptions<I extends ApiCommon, O extends Record<string, unknown> | string> {
75
+ method?: 'GET' | 'HEAD' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';
76
+ revivers?: O extends Record<string, unknown> ? Revivers<I, O> : never;
77
+ sendNull?: boolean;
78
+ withMeta?: boolean;
79
+ }
80
+ ```
81
+
82
+ Most fields are self-explanatory.
83
+
84
+ `sendNull` can be used if you really want to pass `null` as body content.
85
+
86
+ `revivers` is used to specify an object that can modify the behavior of the internal handler of data coming over
87
+ the network. Let's take a closer look at this moment.
88
+
89
+ #### Revivers
90
+
91
+ By default, the `request()` function does the following things with data coming over the network:
92
+
93
+ - It removes `created_at`, `updated_at`, `deleted_at` fields from the output objects.
94
+ - It preserves all the remaining fields but converts their names into camelCase.
95
+
96
+ When passing an object with revivers you can a couple of things:
97
+
98
+ - You can list the fields that you want **to exclude** from the result object. To do this, the field must be assigned an
99
+ `undefined` value.
100
+ - You can **add** new fields or **modify** the type of existing ones. To do this, you need to pass a function as a field
101
+ value, which will receive the original object as input.
102
+
103
+ Example:
104
+
105
+ ```typescript
106
+ const jobRevivers: Revivers<ApiJob, Job> = {
107
+ user_id: undefined,
108
+ description: undefined,
109
+ share_token: undefined,
110
+ autosave_preview_path: undefined,
111
+ job_folder_id: undefined,
112
+
113
+ jobTypeId: () => 9,
114
+ createdAt: (data: ApiJobData) => data.created_at as string,
115
+ previewPath: (data: ApiJobData) => data.autosave_preview_path ?? undefined,
116
+ };
117
+ ```
118
+
119
+ `user_id`, `description`, `share_token`, `autosave_preview_path`, `job_folder_id` fields will be excluded from the
120
+ result object.
121
+
122
+ `jobTypeId` will be always **9**.
123
+
124
+ `createdAt` will be returned (please note that that field is excluded by default)
125
+
126
+ `previewPath` - some actions will be performed with the source data.
@@ -0,0 +1,70 @@
1
+ import { type ApiJobData, type Job, jobRevivers } from './job.js';
2
+ import {
3
+ APIMeta,
4
+ type ApiError,
5
+ type ApiSuccess,
6
+ type Revivers,
7
+ defaultListHeader,
8
+ getSearchParams,
9
+ request,
10
+ } from '../utils.js';
11
+
12
+ export interface JobSearchResult {
13
+ pageCount: number;
14
+ data: Job[];
15
+ }
16
+
17
+ export async function listJobs(
18
+ pathname: string,
19
+ title: string,
20
+ page: number,
21
+ searchOptions?: Record<string, unknown>,
22
+ ): Promise<JobSearchResult> {
23
+ const defaultSearchOptions = {
24
+ sort: '-updated',
25
+ only_downloaded: false,
26
+ };
27
+
28
+ const search = { ...defaultSearchOptions, ...searchOptions };
29
+
30
+ const query = getSearchParams({
31
+ only_with_revisions: true,
32
+ search: {
33
+ job_type_id: '9',
34
+ ...(title.length > 0 && { title: `~:${title}` }),
35
+ },
36
+ ...search,
37
+ });
38
+
39
+ const path = `${pathname}?${query}`;
40
+
41
+ const headers = {
42
+ ...defaultListHeader,
43
+ 'X-Page': `${page}`,
44
+ };
45
+ const options = {
46
+ revivers: jobRevivers as Revivers<ApiJobArray, Job>,
47
+ withMeta: true,
48
+ };
49
+
50
+ type ApiJobArray = {
51
+ data: ApiJobData[];
52
+ } & Omit<ApiSuccess, 'data'> | ApiError;
53
+
54
+ const result = (await request<ApiJobArray, Job>(path, null, headers, options).catch(
55
+ (error: Error) => {
56
+ if (error instanceof APIMeta) {
57
+ const { data, headers, status } = error as APIMeta<ApiJobArray, Job>;
58
+
59
+ return { data, headers, status };
60
+ }
61
+
62
+ throw error;
63
+ },
64
+ )) as APIMeta<ApiJobArray, Job>;
65
+
66
+ return {
67
+ data: result.data,
68
+ pageCount: Number(result.headers.get('X-Paginate-Pages')),
69
+ };
70
+ }
@@ -0,0 +1,132 @@
1
+ import { type ApiError, type ApiSuccess, Flatten, Revivers, getSearchParams, request } from '../utils.js';
2
+ import type { Polygon } from 'geojson';
3
+ import { RequireAtLeastOne } from 'type-fest';
4
+
5
+ export type ApiSearchPoint = {
6
+ lat: number;
7
+ lng: number;
8
+ };
9
+
10
+ export type ApiSearchBounds = {
11
+ min_lat: number;
12
+ min_lng: number;
13
+ max_lat: number;
14
+ max_lng: number;
15
+ };
16
+
17
+ type ApiSingleOrGroupedArea = {
18
+ id: number;
19
+ title: string;
20
+ subtitle: string;
21
+ svg_preview: string;
22
+ bounding_box: string;
23
+ is_group: boolean;
24
+ vector_source: string | null;
25
+ source_layer: string | null;
26
+ feature_id: number | null;
27
+ properties: Record<string, string> | null;
28
+ };
29
+
30
+ type ApiSingleOrGroupedAreaArray = {
31
+ data: ApiSingleOrGroupedArea[];
32
+ } & Omit<ApiSuccess, 'data'> | ApiError;
33
+
34
+ type SingleOrGroupedAreaBase = {
35
+ id: number;
36
+ title: string;
37
+ subtitle: string;
38
+ svgPreview: string;
39
+ boundingBox: Polygon;
40
+ };
41
+
42
+ // TODO don't export this once search on click is out
43
+ export type GroupedArea = SingleOrGroupedAreaBase & {
44
+ isGroup: true;
45
+ };
46
+
47
+ // TODO don't export this once search on click is out
48
+ export type SingleArea = SingleOrGroupedAreaBase & {
49
+ isGroup: false;
50
+ vectorSource: string;
51
+ sourceLayer: string;
52
+ featureId: number;
53
+ properties: Record<string, string>;
54
+ };
55
+
56
+ export type SingleOrGroupedArea = SingleArea | GroupedArea;
57
+
58
+ export async function searchSingleOrGroupedAreas(
59
+ language: string,
60
+ search: RequireAtLeastOne<{
61
+ searchBounds?: ApiSearchBounds;
62
+ query?: string;
63
+ searchPoint?: ApiSearchPoint;
64
+ }>,
65
+ mode: 'polygon' | 'group' | 'both' = 'both',
66
+ ): Promise<SingleOrGroupedArea[]> {
67
+ /**
68
+ * TODO When SAGA search on click is implemented, remove mode and make searchBounds required
69
+ */
70
+ return request<ApiSingleOrGroupedAreaArray, SingleOrGroupedArea>(
71
+ `/v1/choropleth/polygons/search?${getSearchParams({
72
+ language,
73
+ ...search.searchBounds,
74
+ ...(search.query && { query: search.query }),
75
+ ...(search.searchPoint && { point: search.searchPoint }),
76
+ mode,
77
+ })}`,
78
+ ).then(result => {
79
+ result.forEach(
80
+ elem => {
81
+ elem.boundingBox = JSON.parse(elem.boundingBox as unknown as string) as Polygon;
82
+ if (!elem.isGroup) {
83
+ elem.properties = JSON.parse(elem.properties as unknown as string) as Record<string, string>;
84
+ }
85
+ },
86
+ );
87
+
88
+ return result;
89
+ });
90
+ }
91
+
92
+ export type GroupedAreaChild = {
93
+ id: number;
94
+ title: string;
95
+ vectorSource: string;
96
+ sourceLayer: string;
97
+ featureId: number;
98
+ boundingBox: Polygon;
99
+ properties: Record<string, string>;
100
+ };
101
+
102
+ type ApiGroupedAreaChild = {
103
+ data: {
104
+ id: number;
105
+ title: string;
106
+ vector_source: string;
107
+ source_layer: string;
108
+ feature_id: number;
109
+ bounding_box: string;
110
+ properties: string;
111
+ };
112
+ } & Omit<ApiSuccess, 'data'> | ApiError;
113
+
114
+ export type ApiGroupedAreaChildData = Flatten<Exclude<ApiGroupedAreaChild, ApiError>['data']>;
115
+
116
+ export const groupedAreaChildRevivers: Revivers<ApiGroupedAreaChild, GroupedAreaChild> = {
117
+ boundingBox: (data: ApiGroupedAreaChildData) => JSON.parse(data.bounding_box) as Polygon,
118
+ properties: (data: ApiGroupedAreaChildData) => JSON.parse(data.properties) as Record<string, string>,
119
+ };
120
+
121
+ export async function groupedAreaChildren(groupId: number, language: string): Promise<GroupedAreaChild[]> {
122
+ const pathname = `/v1/choropleth/groups/${groupId}/children-optimized`;
123
+ const query = getSearchParams({ language });
124
+ const path = `${pathname}?${query}`;
125
+ const options = { revivers: groupedAreaChildRevivers };
126
+
127
+ type ApiApiGroupedAreaChildArray = {
128
+ data: ApiGroupedAreaChildData[];
129
+ } & Omit<ApiSuccess, 'data'> | ApiError;
130
+
131
+ return request<ApiApiGroupedAreaChildArray, GroupedAreaChild>(path, null, null, options);
132
+ }
@@ -0,0 +1,22 @@
1
+ import type { ApiCommonData, ApiError, ApiSuccess, Flatten, Revivers } from '../utils.js';
2
+
3
+ export type Color = {
4
+ id: number;
5
+ hex: string;
6
+ };
7
+
8
+ export type ApiColor = {
9
+ data: {
10
+ id: number; // The color id (sortable)
11
+ name: string; // The name of the color (searchable, sortable)
12
+ hex: string; // The hex value of the color (searchable, sortable)
13
+ order?: number; // TODO: not present in API specification!
14
+ } & ApiCommonData;
15
+ } & Omit<ApiSuccess, 'data'> | ApiError;
16
+
17
+ export type ApiColorData = Flatten<Exclude<ApiColor, ApiError>['data']>;
18
+
19
+ export const colorRevivers: Revivers<ApiColor, Color> = {
20
+ name: undefined,
21
+ order: undefined,
22
+ };