@bpd-library/utilities 1.2.9 → 1.2.10-beta.2
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/config/oats-generator.config.js +2 -0
- package/dist/api/http.d.ts +1 -0
- package/dist/api/http.js +3 -2
- package/dist/api/http.js.map +1 -1
- package/dist/api/index.js +0 -1
- package/dist/api/index.js.map +1 -1
- package/dist/api-utilities/api-utilities.types.d.ts +1 -1
- package/dist/api-utilities/api-utilities.types.js.map +1 -1
- package/dist/api-utilities/compose-exclude-string.d.ts +3 -0
- package/dist/api-utilities/compose-exclude-string.js +5 -0
- package/dist/api-utilities/compose-exclude-string.js.map +1 -0
- package/dist/date.d.ts +2 -1
- package/dist/date.js +6 -1
- package/dist/date.js.map +1 -1
- package/dist/environment.d.ts +15 -3
- package/dist/environment.js +14 -14
- package/dist/environment.js.map +1 -1
- package/dist/esm/api/http.js +120 -0
- package/dist/esm/api/http.js.map +1 -0
- package/dist/esm/api/index.js +11 -0
- package/dist/esm/api/index.js.map +1 -0
- package/dist/esm/api-utilities/compose-exclude-string.js +6 -0
- package/dist/esm/api-utilities/compose-exclude-string.js.map +1 -0
- package/dist/esm/api-utilities/decimal-range/merge-decimal-range.js +13 -0
- package/dist/esm/api-utilities/decimal-range/merge-decimal-range.js.map +1 -0
- package/dist/esm/api-utilities/decimal-range/merge-specification-range.js +29 -0
- package/dist/esm/api-utilities/decimal-range/merge-specification-range.js.map +1 -0
- package/dist/esm/api-utilities/district-status.js +14 -0
- package/dist/esm/api-utilities/district-status.js.map +1 -0
- package/dist/esm/api-utilities/find-filter.js +41 -0
- package/dist/esm/api-utilities/find-filter.js.map +1 -0
- package/dist/esm/api-utilities/get/coordinates.js +31 -0
- package/dist/esm/api-utilities/get/coordinates.js.map +1 -0
- package/dist/esm/api-utilities/get/layer-raster.js +4 -0
- package/dist/esm/api-utilities/get/layer-raster.js.map +1 -0
- package/dist/esm/api-utilities/show-mortgage-price.js +11 -0
- package/dist/esm/api-utilities/show-mortgage-price.js.map +1 -0
- package/dist/esm/api-utilities/show-price.js +13 -0
- package/dist/esm/api-utilities/show-price.js.map +1 -0
- package/dist/esm/constants/index.js +7 -0
- package/dist/esm/constants/index.js.map +1 -0
- package/dist/esm/date.js +11 -0
- package/dist/esm/date.js.map +1 -0
- package/dist/esm/debounce.js +25 -0
- package/dist/esm/debounce.js.map +1 -0
- package/dist/esm/dom/dom.js +9 -0
- package/dist/esm/dom/dom.js.map +1 -0
- package/dist/esm/environment.js +27 -0
- package/dist/esm/environment.js.map +1 -0
- package/dist/esm/extended-api-models/excluded-properties.js +36 -0
- package/dist/esm/extended-api-models/excluded-properties.js.map +1 -0
- package/dist/esm/extended-api-models/extended-area-projects.js +12 -0
- package/dist/esm/extended-api-models/extended-area-projects.js.map +1 -0
- package/dist/esm/extended-api-models/extended-area.js +182 -0
- package/dist/esm/extended-api-models/extended-area.js.map +1 -0
- package/dist/esm/extended-api-models/status/apartment-building-status.js +60 -0
- package/dist/esm/extended-api-models/status/apartment-building-status.js.map +1 -0
- package/dist/esm/extended-api-models/status/construction-number-status.js +20 -0
- package/dist/esm/extended-api-models/status/construction-number-status.js.map +1 -0
- package/dist/esm/extended-api-models/status/property-type-status.js +60 -0
- package/dist/esm/extended-api-models/status/property-type-status.js.map +1 -0
- package/dist/esm/extended-api-models/utilities/apartment-building-view.js +5 -0
- package/dist/esm/extended-api-models/utilities/apartment-building-view.js.map +1 -0
- package/dist/esm/extended-api-models/utilities/extended-model-price-range.js +37 -0
- package/dist/esm/extended-api-models/utilities/extended-model-price-range.js.map +1 -0
- package/dist/esm/extended-api-models/utilities/find-extended-object.js +23 -0
- package/dist/esm/extended-api-models/utilities/find-extended-object.js.map +1 -0
- package/dist/esm/extended-api-models/utilities/is-apartment.js +14 -0
- package/dist/esm/extended-api-models/utilities/is-apartment.js.map +1 -0
- package/dist/esm/function-is-true.js +13 -0
- package/dist/esm/function-is-true.js.map +1 -0
- package/dist/esm/generated/bpd-client.js +53 -0
- package/dist/esm/generated/bpd-client.js.map +1 -0
- package/dist/esm/geometry/country-bounding-box.js +14 -0
- package/dist/esm/geometry/country-bounding-box.js.map +1 -0
- package/dist/esm/geometry/geometry.js +65 -0
- package/dist/esm/geometry/geometry.js.map +1 -0
- package/dist/esm/hooks/use-click-outside.js +34 -0
- package/dist/esm/hooks/use-click-outside.js.map +1 -0
- package/dist/esm/hooks/use-form-changes.js +30 -0
- package/dist/esm/hooks/use-form-changes.js.map +1 -0
- package/dist/esm/hooks/use-history.js +15 -0
- package/dist/esm/hooks/use-history.js.map +1 -0
- package/dist/esm/hooks/use-keyboard-focus.js +14 -0
- package/dist/esm/hooks/use-keyboard-focus.js.map +1 -0
- package/dist/esm/hooks/use-lazy.js +47 -0
- package/dist/esm/hooks/use-lazy.js.map +1 -0
- package/dist/esm/hooks/use-map-storage.js +16 -0
- package/dist/esm/hooks/use-map-storage.js.map +1 -0
- package/dist/esm/hooks/use-scroll-position.js +23 -0
- package/dist/esm/hooks/use-scroll-position.js.map +1 -0
- package/dist/esm/hooks/use-scroll-to.js +66 -0
- package/dist/esm/hooks/use-scroll-to.js.map +1 -0
- package/dist/esm/hooks/use-stylesheet.js +8 -0
- package/dist/esm/hooks/use-stylesheet.js.map +1 -0
- package/dist/esm/hooks/use-url-params.js +31 -0
- package/dist/esm/hooks/use-url-params.js.map +1 -0
- package/dist/esm/index.js +40 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/is-touch.js +32 -0
- package/dist/esm/is-touch.js.map +1 -0
- package/dist/esm/media-query/breakpoints.js +29 -0
- package/dist/esm/media-query/breakpoints.js.map +1 -0
- package/dist/esm/media-query/media-query.js +39 -0
- package/dist/esm/media-query/media-query.js.map +1 -0
- package/dist/esm/media-query/utils/index.js +35 -0
- package/dist/esm/media-query/utils/index.js.map +1 -0
- package/dist/esm/raf-throttle.js +24 -0
- package/dist/esm/raf-throttle.js.map +1 -0
- package/dist/esm/throttle.js +23 -0
- package/dist/esm/throttle.js.map +1 -0
- package/dist/esm/to-currency.js +26 -0
- package/dist/esm/to-currency.js.map +1 -0
- package/dist/extended-api-models/excluded-properties.d.ts +5 -0
- package/dist/extended-api-models/excluded-properties.js +35 -0
- package/dist/extended-api-models/excluded-properties.js.map +1 -0
- package/dist/extended-api-models/status/construction-number-status.js +8 -1
- package/dist/extended-api-models/status/construction-number-status.js.map +1 -1
- package/dist/generated/bpd-client.d.ts +72 -9
- package/dist/generated/bpd-client.js +21 -13
- package/dist/generated/bpd-client.js.map +1 -1
- package/dist/hooks/use-stylesheet.d.ts +1 -0
- package/dist/hooks/use-stylesheet.js +5 -0
- package/dist/hooks/use-stylesheet.js.map +1 -0
- package/dist/lib/api/http.js +117 -0
- package/dist/lib/api/http.js.map +1 -0
- package/dist/lib/api/index.js +8 -0
- package/dist/lib/api/index.js.map +1 -0
- package/dist/lib/api-utilities/api-utilities.js +9 -0
- package/dist/lib/api-utilities/api-utilities.js.map +1 -0
- package/dist/lib/api-utilities/api-utilities.test.js +122 -0
- package/dist/lib/api-utilities/api-utilities.test.js.map +1 -0
- package/dist/lib/api-utilities/api-utilities.types.js +1 -0
- package/dist/lib/api-utilities/api-utilities.types.js.map +1 -0
- package/dist/lib/api-utilities/compose-exclude-string.js +5 -0
- package/dist/lib/api-utilities/compose-exclude-string.js.map +1 -0
- package/dist/lib/api-utilities/decimal-range/merge-decimal-range.js +12 -0
- package/dist/lib/api-utilities/decimal-range/merge-decimal-range.js.map +1 -0
- package/dist/lib/api-utilities/decimal-range/merge-specification-range.js +27 -0
- package/dist/lib/api-utilities/decimal-range/merge-specification-range.js.map +1 -0
- package/dist/lib/api-utilities/district-status.js +13 -0
- package/dist/lib/api-utilities/district-status.js.map +1 -0
- package/dist/lib/api-utilities/find-filter.js +40 -0
- package/dist/lib/api-utilities/find-filter.js.map +1 -0
- package/dist/lib/api-utilities/get/coordinates.js +29 -0
- package/dist/lib/api-utilities/get/coordinates.js.map +1 -0
- package/dist/lib/api-utilities/get/layer-raster.js +3 -0
- package/dist/lib/api-utilities/get/layer-raster.js.map +1 -0
- package/dist/lib/api-utilities/index.js +2 -0
- package/dist/lib/api-utilities/index.js.map +1 -0
- package/dist/lib/api-utilities/show-mortgage-price.js +10 -0
- package/dist/lib/api-utilities/show-mortgage-price.js.map +1 -0
- package/dist/lib/api-utilities/show-price.js +12 -0
- package/dist/lib/api-utilities/show-price.js.map +1 -0
- package/dist/lib/constants/index.js +5 -0
- package/dist/lib/constants/index.js.map +1 -0
- package/dist/lib/date.js +10 -0
- package/dist/lib/date.js.map +1 -0
- package/dist/lib/debounce.js +23 -0
- package/dist/lib/debounce.js.map +1 -0
- package/dist/lib/dom/dom.js +7 -0
- package/dist/lib/dom/dom.js.map +1 -0
- package/dist/lib/dom/index.js +2 -0
- package/dist/lib/dom/index.js.map +1 -0
- package/dist/lib/environment.js +25 -0
- package/dist/lib/environment.js.map +1 -0
- package/dist/lib/extended-api-models/excluded-properties.js +35 -0
- package/dist/lib/extended-api-models/excluded-properties.js.map +1 -0
- package/dist/lib/extended-api-models/extended-area-projects.js +10 -0
- package/dist/lib/extended-api-models/extended-area-projects.js.map +1 -0
- package/dist/lib/extended-api-models/extended-area.js +179 -0
- package/dist/lib/extended-api-models/extended-area.js.map +1 -0
- package/dist/lib/extended-api-models/index.js +7 -0
- package/dist/lib/extended-api-models/index.js.map +1 -0
- package/dist/lib/extended-api-models/status/apartment-building-status.js +58 -0
- package/dist/lib/extended-api-models/status/apartment-building-status.js.map +1 -0
- package/dist/lib/extended-api-models/status/construction-number-status.js +19 -0
- package/dist/lib/extended-api-models/status/construction-number-status.js.map +1 -0
- package/dist/lib/extended-api-models/status/property-type-status.js +58 -0
- package/dist/lib/extended-api-models/status/property-type-status.js.map +1 -0
- package/dist/lib/extended-api-models/utilities/apartment-building-view.js +4 -0
- package/dist/lib/extended-api-models/utilities/apartment-building-view.js.map +1 -0
- package/dist/lib/extended-api-models/utilities/extended-model-price-range.js +35 -0
- package/dist/lib/extended-api-models/utilities/extended-model-price-range.js.map +1 -0
- package/dist/lib/extended-api-models/utilities/find-extended-object.js +21 -0
- package/dist/lib/extended-api-models/utilities/find-extended-object.js.map +1 -0
- package/dist/lib/extended-api-models/utilities/is-apartment.js +13 -0
- package/dist/lib/extended-api-models/utilities/is-apartment.js.map +1 -0
- package/dist/lib/function-is-true.js +11 -0
- package/dist/lib/function-is-true.js.map +1 -0
- package/dist/lib/generated/bpd-client.js +50 -0
- package/dist/lib/generated/bpd-client.js.map +1 -0
- package/dist/lib/generated/index.js +2 -0
- package/dist/lib/generated/index.js.map +1 -0
- package/dist/lib/geometry/country-bounding-box.js +12 -0
- package/dist/lib/geometry/country-bounding-box.js.map +1 -0
- package/dist/lib/geometry/geometry.js +64 -0
- package/dist/lib/geometry/geometry.js.map +1 -0
- package/dist/lib/geometry/geometry.test.js +87 -0
- package/dist/lib/geometry/geometry.test.js.map +1 -0
- package/dist/lib/geometry/index.js +3 -0
- package/dist/lib/geometry/index.js.map +1 -0
- package/dist/lib/hooks/index.js +11 -0
- package/dist/lib/hooks/index.js.map +1 -0
- package/dist/lib/hooks/use-click-outside.js +32 -0
- package/dist/lib/hooks/use-click-outside.js.map +1 -0
- package/dist/lib/hooks/use-delegate-listen.js +10 -0
- package/dist/lib/hooks/use-delegate-listen.js.map +1 -0
- package/dist/lib/hooks/use-form-changes.js +27 -0
- package/dist/lib/hooks/use-form-changes.js.map +1 -0
- package/dist/lib/hooks/use-history.js +13 -0
- package/dist/lib/hooks/use-history.js.map +1 -0
- package/dist/lib/hooks/use-input.js +28 -0
- package/dist/lib/hooks/use-input.js.map +1 -0
- package/dist/lib/hooks/use-keyboard-focus.js +11 -0
- package/dist/lib/hooks/use-keyboard-focus.js.map +1 -0
- package/dist/lib/hooks/use-lazy.js +44 -0
- package/dist/lib/hooks/use-lazy.js.map +1 -0
- package/dist/lib/hooks/use-map-storage.js +14 -0
- package/dist/lib/hooks/use-map-storage.js.map +1 -0
- package/dist/lib/hooks/use-scroll-position.js +20 -0
- package/dist/lib/hooks/use-scroll-position.js.map +1 -0
- package/dist/lib/hooks/use-scroll-to.js +64 -0
- package/dist/lib/hooks/use-scroll-to.js.map +1 -0
- package/dist/lib/hooks/use-stylesheet.js +5 -0
- package/dist/lib/hooks/use-stylesheet.js.map +1 -0
- package/dist/lib/hooks/use-text.js +16 -0
- package/dist/lib/hooks/use-text.js.map +1 -0
- package/dist/lib/hooks/use-url-params.js +28 -0
- package/dist/lib/hooks/use-url-params.js.map +1 -0
- package/dist/lib/index.js +18 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/is-touch.js +30 -0
- package/dist/lib/is-touch.js.map +1 -0
- package/dist/lib/media-query/breakpoints.js +27 -0
- package/dist/lib/media-query/breakpoints.js.map +1 -0
- package/dist/lib/media-query/index.js +2 -0
- package/dist/lib/media-query/index.js.map +1 -0
- package/dist/lib/media-query/media-query.js +36 -0
- package/dist/lib/media-query/media-query.js.map +1 -0
- package/dist/lib/media-query/media-query.types.js +1 -0
- package/dist/lib/media-query/media-query.types.js.map +1 -0
- package/dist/lib/media-query/utils/index.js +32 -0
- package/dist/lib/media-query/utils/index.js.map +1 -0
- package/dist/lib/raf-throttle.js +22 -0
- package/dist/lib/raf-throttle.js.map +1 -0
- package/dist/lib/throttle.js +22 -0
- package/dist/lib/throttle.js.map +1 -0
- package/dist/lib/to-currency.js +24 -0
- package/dist/lib/to-currency.js.map +1 -0
- package/dist/types/api/http.d.ts +47 -0
- package/dist/types/api/index.d.ts +2 -0
- package/dist/types/api-utilities/api-utilities.d.ts +8 -0
- package/dist/types/api-utilities/api-utilities.test.d.ts +1 -0
- package/dist/types/api-utilities/api-utilities.types.d.ts +46 -0
- package/dist/types/api-utilities/compose-exclude-string.d.ts +3 -0
- package/dist/types/api-utilities/decimal-range/merge-decimal-range.d.ts +3 -0
- package/dist/types/api-utilities/decimal-range/merge-specification-range.d.ts +13 -0
- package/dist/types/api-utilities/district-status.d.ts +3 -0
- package/dist/types/api-utilities/find-filter.d.ts +32 -0
- package/dist/types/api-utilities/get/coordinates.d.ts +6 -0
- package/dist/types/api-utilities/get/layer-raster.d.ts +3 -0
- package/dist/types/api-utilities/index.d.ts +1 -0
- package/dist/types/api-utilities/show-mortgage-price.d.ts +3 -0
- package/dist/types/api-utilities/show-price.d.ts +7 -0
- package/dist/types/constants/index.d.ts +4 -0
- package/dist/types/date.d.ts +3 -0
- package/dist/types/debounce.d.ts +5 -0
- package/dist/types/dom/dom.d.ts +6 -0
- package/dist/types/dom/index.d.ts +1 -0
- package/dist/types/environment.d.ts +9 -0
- package/dist/types/extended-api-models/excluded-properties.d.ts +5 -0
- package/dist/types/extended-api-models/extended-area-projects.d.ts +3 -0
- package/dist/types/extended-api-models/extended-area.d.ts +13 -0
- package/dist/types/extended-api-models/index.d.ts +6 -0
- package/dist/types/extended-api-models/status/apartment-building-status.d.ts +3 -0
- package/dist/types/extended-api-models/status/construction-number-status.d.ts +3 -0
- package/dist/types/extended-api-models/status/property-type-status.d.ts +4 -0
- package/dist/types/extended-api-models/utilities/apartment-building-view.d.ts +4 -0
- package/dist/types/extended-api-models/utilities/extended-model-price-range.d.ts +4 -0
- package/dist/types/extended-api-models/utilities/find-extended-object.d.ts +4 -0
- package/dist/types/extended-api-models/utilities/is-apartment.d.ts +11 -0
- package/dist/types/function-is-true.d.ts +1 -0
- package/dist/types/generated/bpd-client.d.ts +808 -0
- package/dist/types/generated/index.d.ts +1 -0
- package/dist/types/geometry/country-bounding-box.d.ts +6 -0
- package/dist/types/geometry/geometry.d.ts +11 -0
- package/dist/types/geometry/geometry.test.d.ts +8 -0
- package/dist/types/geometry/index.d.ts +2 -0
- package/dist/types/hooks/index.d.ts +10 -0
- package/dist/types/hooks/use-click-outside.d.ts +6 -0
- package/dist/types/hooks/use-delegate-listen.d.ts +6 -0
- package/dist/types/hooks/use-form-changes.d.ts +12 -0
- package/dist/types/hooks/use-history.d.ts +4 -0
- package/dist/types/hooks/use-input.d.ts +41 -0
- package/dist/types/hooks/use-keyboard-focus.d.ts +6 -0
- package/dist/types/hooks/use-lazy.d.ts +21 -0
- package/dist/types/hooks/use-map-storage.d.ts +6 -0
- package/dist/types/hooks/use-scroll-position.d.ts +10 -0
- package/dist/types/hooks/use-scroll-to.d.ts +8 -0
- package/dist/types/hooks/use-stylesheet.d.ts +1 -0
- package/dist/types/hooks/use-text.d.ts +1 -0
- package/dist/types/hooks/use-url-params.d.ts +5 -0
- package/dist/types/index.d.ts +17 -0
- package/dist/types/is-touch.d.ts +8 -0
- package/dist/types/media-query/breakpoints.d.ts +26 -0
- package/dist/types/media-query/index.d.ts +1 -0
- package/dist/types/media-query/media-query.d.ts +13 -0
- package/dist/types/media-query/media-query.types.d.ts +14 -0
- package/dist/types/media-query/utils/index.d.ts +3 -0
- package/dist/types/raf-throttle.d.ts +4 -0
- package/dist/types/throttle.d.ts +2 -0
- package/dist/types/to-currency.d.ts +3 -0
- package/package.json +3 -3
|
@@ -39,6 +39,8 @@ module.exports = {
|
|
|
39
39
|
return camel([verb, ...entities, ...operators].join(' '));
|
|
40
40
|
},
|
|
41
41
|
customImport: `
|
|
42
|
+
/* eslint-disable @typescript-eslint/interface-name-prefix */
|
|
43
|
+
|
|
42
44
|
import { APIClient } from '../api'
|
|
43
45
|
import { RequestConfig } from '../api/http';
|
|
44
46
|
`,
|
package/dist/api/http.d.ts
CHANGED
|
@@ -36,6 +36,7 @@ export declare class HttpClient {
|
|
|
36
36
|
patch: RequestFn;
|
|
37
37
|
delete: RequestFn;
|
|
38
38
|
setToken: (token: string | undefined) => string | undefined;
|
|
39
|
+
setBaseUrl: (baseUrl: string) => string;
|
|
39
40
|
private setAuthenticationHeaders;
|
|
40
41
|
private setAbortController;
|
|
41
42
|
request<T>(url: string | URL, requestConfig?: RequestConfig): Promise<T>;
|
package/dist/api/http.js
CHANGED
|
@@ -20,6 +20,7 @@ export class HttpClient {
|
|
|
20
20
|
this.patch = this.createRequest('PATCH');
|
|
21
21
|
this.delete = this.createRequest('DELETE');
|
|
22
22
|
this.setToken = (token) => (this.token = token);
|
|
23
|
+
this.setBaseUrl = (baseUrl) => (this.config.baseUrl = baseUrl);
|
|
23
24
|
this.setAbortController = (config) => {
|
|
24
25
|
const { createAbort } = config;
|
|
25
26
|
if (createAbort) {
|
|
@@ -65,8 +66,8 @@ export class HttpClient {
|
|
|
65
66
|
this.setAuthenticationHeaders(config);
|
|
66
67
|
const requestFn = fetch(baseUrl + url, config)
|
|
67
68
|
.then(this.handleError)
|
|
68
|
-
.then(res => this.handleSuccess(res, config));
|
|
69
|
-
return requestFn.catch(err => this.onError(err, () => this.request(url, requestConfig)));
|
|
69
|
+
.then((res) => this.handleSuccess(res, config));
|
|
70
|
+
return requestFn.catch((err) => this.onError(err, () => this.request(url, requestConfig)));
|
|
70
71
|
}
|
|
71
72
|
handleSuccess(res, config) {
|
|
72
73
|
const { returnType = 'json' } = config;
|
package/dist/api/http.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http.js","sourceRoot":"","sources":["../../src/api/http.ts"],"names":[],"mappings":"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","sourcesContent":["import qs from 'qs';\n\nexport interface HttpErrorInput {\n message: string;\n statusCode: number;\n response?: Response;\n body?: any;\n}\n\nexport class HttpError extends Error {\n statusCode: number;\n response?: Response;\n body?: any;\n\n constructor(input: HttpErrorInput) {\n super(input.message);\n this.response = input.response;\n this.statusCode = input.statusCode;\n this.body = input.body;\n this.name = 'HttpError';\n }\n}\n\nexport type AbortFunction = () => void;\ntype Token = string | undefined;\ntype RequestFn = <T = any, I = any>(url: string, data: I, config?: RequestConfig) => Promise<T>;\ntype RequestGetFn = <T = any, I = any>(url: string, data?: I, config?: RequestConfig) => Promise<T>;\ntype BeforeHook = (client: HttpClient) => Promise<void> | void;\ntype ErrorHook = <T = any>(err: HttpError, request: () => Promise<T>) => any;\ntype HttpClientInit = RequestInit & {\n baseUrl?: string;\n returnType?: 'json' | 'text' | 'blob';\n /** This function is called before every request. This is where you would check if your token is still valid */\n beforeHook?: BeforeHook;\n /** Function that is called if an error occurs */\n onError?: ErrorHook;\n};\nexport type RequestConfig = HttpClientInit & {\n createAbort?: (abortFunction: AbortFunction) => void;\n};\n\n/**\n * Wrapper around fetch\n */\nexport class HttpClient {\n private defaultConfig: RequestConfig = {\n returnType: 'json',\n };\n\n private config: RequestConfig = {};\n private token: Token;\n\n constructor(config: HttpClientInit = {}) {\n this.config = {\n ...this.defaultConfig,\n ...config,\n };\n }\n\n /**\n *\n *\n * @private\n * @param {'GET'} method\n * @returns {RequestGetFn}\n * @memberof HttpClient\n */\n private createRequest(method: 'GET'): RequestGetFn;\n private createRequest(method: string): RequestFn;\n private createRequest(method: 'GET' | string): RequestFn {\n return (url, data, config) => {\n if (method === 'GET') {\n let getUrl = url;\n if (data) {\n getUrl = url + '?' + qs.stringify(data);\n }\n\n return this.request(getUrl, {\n ...config,\n method: 'GET',\n });\n }\n\n const contentType = config && config.headers && (config.headers as any)['Content-Type'];\n\n return this.request(url, {\n ...config,\n method,\n body: this.createBody(data, contentType),\n });\n };\n }\n\n public get = this.createRequest('GET');\n public post = this.createRequest('POST');\n public put = this.createRequest('PUT');\n public patch = this.createRequest('PATCH');\n public delete = this.createRequest('DELETE');\n\n public setToken = (token: Token) => (this.token = token);\n\n private setAuthenticationHeaders(config: RequestConfig) {\n // if authenticated set bearer token\n if (this.token) {\n config.headers = {\n ...config.headers,\n Authorization: `Bearer ${this.token}`,\n };\n }\n }\n\n /**\n *\n *\n * @private\n * @memberof HttpClient\n */\n private setAbortController = (config: RequestConfig) => {\n const { createAbort } = config;\n if (createAbort) {\n if (typeof AbortController !== undefined) {\n const controller = new AbortController();\n const { signal } = controller;\n config.signal = signal;\n createAbort(controller.abort.bind(controller));\n } else {\n createAbort(() =>\n console.log('The AbortController api isnt available in your browser'),\n );\n }\n }\n };\n\n /**\n *\n *\n * @template T\n * @param {(string | URL)} url\n * @param {RequestConfig} [requestConfig={}]\n * @returns {Promise<T>}\n * @memberof HttpClient\n */\n public async request<T>(url: string | URL, requestConfig: RequestConfig = {}): Promise<T> {\n const { beforeHook } = this.config;\n\n const config: RequestConfig = {\n ...this.config,\n ...requestConfig,\n };\n\n const { baseUrl = '' } = config;\n\n this.setAbortController(config);\n\n if (beforeHook) {\n await beforeHook(this);\n }\n\n this.setAuthenticationHeaders(config);\n\n const requestFn = fetch(baseUrl + url, config)\n .then(this.handleError)\n .then(res => this.handleSuccess(res, config)) as Promise<T>;\n\n return requestFn.catch(err => this.onError<T>(err, () => this.request(url, requestConfig)));\n }\n\n /**\n *\n *\n * @private\n * @param {Response} res\n * @param {RequestConfig} config\n * @returns\n * @memberof HttpClient\n */\n private handleSuccess(res: Response, config: RequestConfig) {\n const { returnType = 'json' } = config;\n\n if (res.status === 204 || res.status === 201 || !res[returnType]) {\n return res;\n }\n\n return res[returnType]();\n }\n\n private async onError<T = any>(err: HttpError, requestFn: () => Promise<T>) {\n const { onError } = this.config;\n\n if (onError) {\n return onError(err, requestFn);\n }\n\n throw err;\n }\n\n /**\n * createBody is responsible for creating a body based on the content type\n *\n * @param body The body\n * @param contentType The content type\n */\n private createBody(body: any, contentType: string): any {\n switch (contentType) {\n case 'application/json':\n return JSON.stringify(body);\n case 'application/x-www-form-urlencoded':\n return new URLSearchParams(body);\n default:\n return JSON.stringify(body);\n }\n }\n\n /**\n * Handles the errors if the fetch request fails and throws a HttpError\n * @param response\n */\n private async handleError(response: Response) {\n if (response.ok) {\n return response;\n }\n\n const responseBody = await response.text();\n let body: any = response;\n\n try {\n body = JSON.parse(responseBody);\n } catch (err) {\n body = responseBody;\n }\n\n const error = {\n message: `HttpError: ${response.status} - ${response.statusText}`,\n statusCode: response.status,\n response,\n body,\n };\n\n console.error(error);\n throw new HttpError(error);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"http.js","sourceRoot":"","sources":["../../src/api/http.ts"],"names":[],"mappings":"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","sourcesContent":["import qs from 'qs';\n\nexport interface HttpErrorInput {\n message: string;\n statusCode: number;\n response?: Response;\n body?: any;\n}\n\nexport class HttpError extends Error {\n statusCode: number;\n response?: Response;\n body?: any;\n\n constructor(input: HttpErrorInput) {\n super(input.message);\n this.response = input.response;\n this.statusCode = input.statusCode;\n this.body = input.body;\n this.name = 'HttpError';\n }\n}\n\nexport type AbortFunction = () => void;\ntype Token = string | undefined;\ntype RequestFn = <T = any, I = any>(url: string, data: I, config?: RequestConfig) => Promise<T>;\ntype RequestGetFn = <T = any, I = any>(url: string, data?: I, config?: RequestConfig) => Promise<T>;\ntype BeforeHook = (client: HttpClient) => Promise<void> | void;\ntype ErrorHook = <T = any>(err: HttpError, request: () => Promise<T>) => any;\ntype HttpClientInit = RequestInit & {\n baseUrl?: string;\n returnType?: 'json' | 'text' | 'blob';\n /** This function is called before every request. This is where you would check if your token is still valid */\n beforeHook?: BeforeHook;\n /** Function that is called if an error occurs */\n onError?: ErrorHook;\n};\nexport type RequestConfig = HttpClientInit & {\n createAbort?: (abortFunction: AbortFunction) => void;\n};\n\n/**\n * Wrapper around fetch\n */\nexport class HttpClient {\n private defaultConfig: RequestConfig = {\n returnType: 'json',\n };\n\n private config: RequestConfig = {};\n private token: Token;\n\n constructor(config: HttpClientInit = {}) {\n this.config = {\n ...this.defaultConfig,\n ...config,\n };\n }\n\n /**\n *\n *\n * @private\n * @param {'GET'} method\n * @returns {RequestGetFn}\n * @memberof HttpClient\n */\n private createRequest(method: 'GET'): RequestGetFn;\n private createRequest(method: string): RequestFn;\n private createRequest(method: 'GET' | string): RequestFn {\n return (url, data, config) => {\n if (method === 'GET') {\n let getUrl = url;\n if (data) {\n getUrl = url + '?' + qs.stringify(data);\n }\n\n return this.request(getUrl, {\n ...config,\n method: 'GET',\n });\n }\n\n const contentType = config && config.headers && (config.headers as any)['Content-Type'];\n\n return this.request(url, {\n ...config,\n method,\n body: this.createBody(data, contentType),\n });\n };\n }\n\n public get = this.createRequest('GET');\n public post = this.createRequest('POST');\n public put = this.createRequest('PUT');\n public patch = this.createRequest('PATCH');\n public delete = this.createRequest('DELETE');\n\n public setToken = (token: Token) => (this.token = token);\n public setBaseUrl = (baseUrl: string) => (this.config.baseUrl = baseUrl);\n\n private setAuthenticationHeaders(config: RequestConfig) {\n // if authenticated set bearer token\n if (this.token) {\n config.headers = {\n ...config.headers,\n Authorization: `Bearer ${this.token}`,\n };\n }\n }\n\n /**\n *\n *\n * @private\n * @memberof HttpClient\n */\n private setAbortController = (config: RequestConfig) => {\n const { createAbort } = config;\n if (createAbort) {\n if (typeof AbortController !== undefined) {\n const controller = new AbortController();\n const { signal } = controller;\n config.signal = signal;\n createAbort(controller.abort.bind(controller));\n } else {\n createAbort(() =>\n console.log('The AbortController api isnt available in your browser'),\n );\n }\n }\n };\n\n /**\n *\n *\n * @template T\n * @param {(string | URL)} url\n * @param {RequestConfig} [requestConfig={}]\n * @returns {Promise<T>}\n * @memberof HttpClient\n */\n public async request<T>(url: string | URL, requestConfig: RequestConfig = {}): Promise<T> {\n const { beforeHook } = this.config;\n\n const config: RequestConfig = {\n ...this.config,\n ...requestConfig,\n };\n\n const { baseUrl = '' } = config;\n\n this.setAbortController(config);\n\n if (beforeHook) {\n await beforeHook(this);\n }\n\n this.setAuthenticationHeaders(config);\n\n const requestFn = fetch(baseUrl + url, config)\n .then(this.handleError)\n .then((res) => this.handleSuccess(res, config)) as Promise<T>;\n\n return requestFn.catch((err) =>\n this.onError<T>(err, () => this.request(url, requestConfig)),\n );\n }\n\n /**\n *\n *\n * @private\n * @param {Response} res\n * @param {RequestConfig} config\n * @returns\n * @memberof HttpClient\n */\n private handleSuccess(res: Response, config: RequestConfig) {\n const { returnType = 'json' } = config;\n\n if (res.status === 204 || res.status === 201 || !res[returnType]) {\n return res;\n }\n\n return res[returnType]();\n }\n\n private async onError<T = any>(err: HttpError, requestFn: () => Promise<T>) {\n const { onError } = this.config;\n\n if (onError) {\n return onError(err, requestFn);\n }\n\n throw err;\n }\n\n /**\n * createBody is responsible for creating a body based on the content type\n *\n * @param body The body\n * @param contentType The content type\n */\n private createBody(body: any, contentType: string): any {\n switch (contentType) {\n case 'application/json':\n return JSON.stringify(body);\n case 'application/x-www-form-urlencoded':\n return new URLSearchParams(body);\n default:\n return JSON.stringify(body);\n }\n }\n\n /**\n * Handles the errors if the fetch request fails and throws a HttpError\n * @param response\n */\n private async handleError(response: Response) {\n if (response.ok) {\n return response;\n }\n\n const responseBody = await response.text();\n let body: any = response;\n\n try {\n body = JSON.parse(responseBody);\n } catch (err) {\n body = responseBody;\n }\n\n const error = {\n message: `HttpError: ${response.status} - ${response.statusText}`,\n statusCode: response.status,\n response,\n body,\n };\n\n console.error(error);\n throw new HttpError(error);\n }\n}\n"]}
|
package/dist/api/index.js
CHANGED
package/dist/api/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEpC,MAAM,CAAC,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC;IACpC,OAAO,EAAE
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEpC,MAAM,CAAC,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC;IACpC,OAAO,EAAE;QACL,cAAc,EAAE,kBAAkB;KACrC;CACJ,CAAC,CAAC","sourcesContent":["import { HttpClient } from './http';\n\nexport const APIClient = new HttpClient({\n headers: {\n 'Content-Type': 'application/json',\n },\n});\n"]}
|
|
@@ -3,7 +3,7 @@ import { INCLUDED_PROPERTIES } from '../extended-api-models/included-properties'
|
|
|
3
3
|
import { ApartmentBuildingModel, AreaProjectModel, ConstructionNumberModel, DistrictModel, ProjectPhaseModel, ProjectPhaseStatus, PropertyTypeModel } from '../generated';
|
|
4
4
|
declare type PropertyTypeStatus = 'InPreparation' | 'SaleSoon' | 'SaleStarted' | 'AssigningOn' | 'AmountAvailable' | 'InOption' | 'Sold' | 'UnderConstruction' | 'ForRent' | 'Rented';
|
|
5
5
|
declare type ApartmentBuildingStatus = 'InPreparation' | 'SaleSoon' | 'SaleStarted' | 'AssigningOn' | 'AmountAvailable' | 'Available' | 'ForRent' | 'InOption' | 'Sold' | 'Rented' | 'UnderConstruction';
|
|
6
|
-
declare type GeneratedConstructionNumberStatus = 'InPreparation' | 'InOption' | 'Available' | 'Sold' | 'Rented' | 'UnderConstruction';
|
|
6
|
+
declare type GeneratedConstructionNumberStatus = 'InPreparation' | 'InOption' | 'Available' | 'Sold' | 'Rented' | 'Reserved' | 'UnderConstruction';
|
|
7
7
|
interface ExtendedConstructionNumber extends Pick<ConstructionNumberModel, 'id' | typeof INCLUDED_PROPERTIES.constructionNumber[number]> {
|
|
8
8
|
areaProject?: AreaProjectModel;
|
|
9
9
|
propertyType?: ExtendedPropertyType;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api-utilities.types.js","sourceRoot":"","sources":["../../src/api-utilities/api-utilities.types.ts"],"names":[],"mappings":"","sourcesContent":["import { MapDataItem } from '@bpd-library/types';\n\nimport { INCLUDED_PROPERTIES } from '../extended-api-models/included-properties';\nimport {\n ApartmentBuildingModel,\n AreaProjectModel,\n ConstructionNumberModel,\n DistrictModel,\n ProjectPhaseModel,\n ProjectPhaseStatus,\n PropertyTypeModel,\n} from '../generated';\n\ntype PropertyTypeStatus =\n | 'InPreparation'\n | 'SaleSoon'\n | 'SaleStarted'\n | 'AssigningOn'\n | 'AmountAvailable'\n | 'InOption'\n | 'Sold'\n | 'UnderConstruction'\n | 'ForRent'\n | 'Rented';\n\ntype ApartmentBuildingStatus =\n | 'InPreparation'\n | 'SaleSoon'\n | 'SaleStarted'\n | 'AssigningOn'\n | 'AmountAvailable'\n | 'Available'\n | 'ForRent'\n | 'InOption'\n | 'Sold'\n | 'Rented'\n | 'UnderConstruction';\n\ntype GeneratedConstructionNumberStatus =\n | 'InPreparation'\n | 'InOption'\n | 'Available'\n | 'Sold'\n | 'Rented'\n | 'UnderConstruction';\n\ninterface ExtendedConstructionNumber\n extends Pick<\n ConstructionNumberModel,\n 'id' | typeof INCLUDED_PROPERTIES.constructionNumber[number]\n > {\n areaProject?: AreaProjectModel;\n propertyType?: ExtendedPropertyType;\n projectPhase?: ExtendedProjectPhase;\n mapDataItems?: MapDataItem[];\n apartmentBuilding?: ExtendedApartmentBuilding;\n status?: GeneratedConstructionNumberStatus;\n objectType: 'constructionNumber';\n}\n\ninterface ExtendedPropertyType\n extends Pick<PropertyTypeModel, 'id' | typeof INCLUDED_PROPERTIES.propertyType[number]> {\n constructionNumbers?: ExtendedConstructionNumber[];\n projectPhase?: ExtendedProjectPhase;\n mapDataItems?: MapDataItem[];\n status?: PropertyTypeStatus;\n apartmentBuildings?: ExtendedApartmentBuilding[];\n objectType: 'propertyType';\n}\n\ninterface ExtendedProjectPhase\n extends Pick<ProjectPhaseModel, 'id' | typeof INCLUDED_PROPERTIES.projectPhase[number]> {\n constructionNumbers?: ExtendedConstructionNumber[];\n propertyTypes?: ExtendedPropertyType[];\n mapDataItems?: MapDataItem[];\n objectType: 'projectPhase';\n}\n\ninterface ExtendedApartmentBuilding\n extends Pick<\n ApartmentBuildingModel,\n 'id' | typeof INCLUDED_PROPERTIES.apartmentBuilding[number]\n > {\n constructionNumbers?: ExtendedConstructionNumber[];\n propertyTypes?: ExtendedPropertyType[];\n projectPhase?: ExtendedProjectPhase;\n mapDataItems?: MapDataItem[];\n status?: ApartmentBuildingStatus;\n objectType: 'apartmentBuilding';\n}\n\ninterface ExtendedDistrict\n extends Pick<DistrictModel, 'id' | typeof INCLUDED_PROPERTIES.district[number]> {\n status?: ProjectPhaseStatus;\n mapDataItems?: MapDataItem[];\n objectType: 'district';\n}\n\ninterface ExtendedAreaProject\n extends Pick<AreaProjectModel, 'id' | typeof INCLUDED_PROPERTIES.areaProject[number]> {\n mapDataItems?: MapDataItem[];\n objectType: 'areaProject';\n}\n\nexport {\n ExtendedConstructionNumber,\n ExtendedPropertyType,\n ExtendedApartmentBuilding,\n ExtendedProjectPhase,\n ExtendedDistrict,\n ExtendedAreaProject,\n PropertyTypeStatus,\n ApartmentBuildingStatus,\n GeneratedConstructionNumberStatus,\n};\n"]}
|
|
1
|
+
{"version":3,"file":"api-utilities.types.js","sourceRoot":"","sources":["../../src/api-utilities/api-utilities.types.ts"],"names":[],"mappings":"","sourcesContent":["import { MapDataItem } from '@bpd-library/types';\n\nimport { INCLUDED_PROPERTIES } from '../extended-api-models/included-properties';\nimport {\n ApartmentBuildingModel,\n AreaProjectModel,\n ConstructionNumberModel,\n DistrictModel,\n ProjectPhaseModel,\n ProjectPhaseStatus,\n PropertyTypeModel,\n} from '../generated';\n\ntype PropertyTypeStatus =\n | 'InPreparation'\n | 'SaleSoon'\n | 'SaleStarted'\n | 'AssigningOn'\n | 'AmountAvailable'\n | 'InOption'\n | 'Sold'\n | 'UnderConstruction'\n | 'ForRent'\n | 'Rented';\n\ntype ApartmentBuildingStatus =\n | 'InPreparation'\n | 'SaleSoon'\n | 'SaleStarted'\n | 'AssigningOn'\n | 'AmountAvailable'\n | 'Available'\n | 'ForRent'\n | 'InOption'\n | 'Sold'\n | 'Rented'\n | 'UnderConstruction';\n\ntype GeneratedConstructionNumberStatus =\n | 'InPreparation'\n | 'InOption'\n | 'Available'\n | 'Sold'\n | 'Rented'\n | 'Reserved'\n | 'UnderConstruction';\n\ninterface ExtendedConstructionNumber\n extends Pick<\n ConstructionNumberModel,\n 'id' | typeof INCLUDED_PROPERTIES.constructionNumber[number]\n > {\n areaProject?: AreaProjectModel;\n propertyType?: ExtendedPropertyType;\n projectPhase?: ExtendedProjectPhase;\n mapDataItems?: MapDataItem[];\n apartmentBuilding?: ExtendedApartmentBuilding;\n status?: GeneratedConstructionNumberStatus;\n objectType: 'constructionNumber';\n}\n\ninterface ExtendedPropertyType\n extends Pick<PropertyTypeModel, 'id' | typeof INCLUDED_PROPERTIES.propertyType[number]> {\n constructionNumbers?: ExtendedConstructionNumber[];\n projectPhase?: ExtendedProjectPhase;\n mapDataItems?: MapDataItem[];\n status?: PropertyTypeStatus;\n apartmentBuildings?: ExtendedApartmentBuilding[];\n objectType: 'propertyType';\n}\n\ninterface ExtendedProjectPhase\n extends Pick<ProjectPhaseModel, 'id' | typeof INCLUDED_PROPERTIES.projectPhase[number]> {\n constructionNumbers?: ExtendedConstructionNumber[];\n propertyTypes?: ExtendedPropertyType[];\n mapDataItems?: MapDataItem[];\n objectType: 'projectPhase';\n}\n\ninterface ExtendedApartmentBuilding\n extends Pick<\n ApartmentBuildingModel,\n 'id' | typeof INCLUDED_PROPERTIES.apartmentBuilding[number]\n > {\n constructionNumbers?: ExtendedConstructionNumber[];\n propertyTypes?: ExtendedPropertyType[];\n projectPhase?: ExtendedProjectPhase;\n mapDataItems?: MapDataItem[];\n status?: ApartmentBuildingStatus;\n objectType: 'apartmentBuilding';\n}\n\ninterface ExtendedDistrict\n extends Pick<DistrictModel, 'id' | typeof INCLUDED_PROPERTIES.district[number]> {\n status?: ProjectPhaseStatus;\n mapDataItems?: MapDataItem[];\n objectType: 'district';\n}\n\ninterface ExtendedAreaProject\n extends Pick<AreaProjectModel, 'id' | typeof INCLUDED_PROPERTIES.areaProject[number]> {\n mapDataItems?: MapDataItem[];\n objectType: 'areaProject';\n}\n\nexport {\n ExtendedConstructionNumber,\n ExtendedPropertyType,\n ExtendedApartmentBuilding,\n ExtendedProjectPhase,\n ExtendedDistrict,\n ExtendedAreaProject,\n PropertyTypeStatus,\n ApartmentBuildingStatus,\n GeneratedConstructionNumberStatus,\n};\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { ApartmentBuildingModel, AreaProjectModel, ConstructionNumberModel, DistrictModel, ProjectPhaseModel, PropertyTypeModel } from '../generated';
|
|
2
|
+
declare const composeExcludeString: (keys: (keyof ConstructionNumberModel | keyof PropertyTypeModel | keyof ApartmentBuildingModel | keyof ProjectPhaseModel | keyof DistrictModel | keyof AreaProjectModel)[]) => string;
|
|
3
|
+
export { composeExcludeString };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compose-exclude-string.js","sourceRoot":"","sources":["../../src/api-utilities/compose-exclude-string.ts"],"names":[],"mappings":"AASA,MAAM,oBAAoB,GAAG,CACzB,IAOG,EACL,EAAE;IACA,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC1B,CAAC,CAAC;AAEF,OAAO,EAAE,oBAAoB,EAAE,CAAC","sourcesContent":["import {\n ApartmentBuildingModel,\n AreaProjectModel,\n ConstructionNumberModel,\n DistrictModel,\n ProjectPhaseModel,\n PropertyTypeModel,\n} from '../generated';\n\nconst composeExcludeString = (\n keys: (\n | keyof ConstructionNumberModel\n | keyof PropertyTypeModel\n | keyof ApartmentBuildingModel\n | keyof ProjectPhaseModel\n | keyof DistrictModel\n | keyof AreaProjectModel\n )[],\n) => {\n return keys.join(',');\n};\n\nexport { composeExcludeString };\n"]}
|
package/dist/date.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
declare const calculateDifferenceInDays: (date1: Date, date2: Date) => number;
|
|
2
|
+
declare const hasDatePassed: (date: Date | string) => boolean;
|
|
2
3
|
declare const betweenDates: (dateStart: Date, dateBetween: Date, dateEnd: Date) => boolean;
|
|
3
|
-
export { calculateDifferenceInDays, betweenDates };
|
|
4
|
+
export { calculateDifferenceInDays, hasDatePassed, betweenDates };
|
package/dist/date.js
CHANGED
|
@@ -1,10 +1,15 @@
|
|
|
1
1
|
const calculateDifferenceInDays = (date1, date2) => {
|
|
2
2
|
return Math.abs((date2.getTime() - date1.getTime()) / (1000 * 3600 * 24));
|
|
3
3
|
};
|
|
4
|
+
const hasDatePassed = (date) => {
|
|
5
|
+
if (typeof date === 'string')
|
|
6
|
+
date = new Date(date);
|
|
7
|
+
return Date.now() > date.getTime();
|
|
8
|
+
};
|
|
4
9
|
const betweenDates = (dateStart, dateBetween, dateEnd) => {
|
|
5
10
|
const afterDateStart = dateBetween > dateStart;
|
|
6
11
|
const beforeDateEnd = dateBetween < dateEnd;
|
|
7
12
|
return afterDateStart && beforeDateEnd;
|
|
8
13
|
};
|
|
9
|
-
export { calculateDifferenceInDays, betweenDates };
|
|
14
|
+
export { calculateDifferenceInDays, hasDatePassed, betweenDates };
|
|
10
15
|
//# sourceMappingURL=date.js.map
|
package/dist/date.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"date.js","sourceRoot":"","sources":["../src/date.ts"],"names":[],"mappings":"AAAA,MAAM,yBAAyB,GAAG,CAAC,KAAW,EAAE,KAAW,EAAU,EAAE;IACnE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC;AAC9E,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,SAAe,EAAE,WAAiB,EAAE,OAAa,EAAW,EAAE;IAChF,MAAM,cAAc,GAAG,WAAW,GAAG,SAAS,CAAC;IAC/C,MAAM,aAAa,GAAG,WAAW,GAAG,OAAO,CAAC;IAE5C,OAAO,cAAc,IAAI,aAAa,CAAC;AAC3C,CAAC,CAAC;AAEF,OAAO,EAAE,yBAAyB,EAAE,YAAY,EAAE,CAAC","sourcesContent":["const calculateDifferenceInDays = (date1: Date, date2: Date): number => {\n return Math.abs((date2.getTime() - date1.getTime()) / (1000 * 3600 * 24));\n};\n\nconst betweenDates = (dateStart: Date, dateBetween: Date, dateEnd: Date): boolean => {\n const afterDateStart = dateBetween > dateStart;\n const beforeDateEnd = dateBetween < dateEnd;\n\n return afterDateStart && beforeDateEnd;\n};\n\nexport { calculateDifferenceInDays, betweenDates };\n"]}
|
|
1
|
+
{"version":3,"file":"date.js","sourceRoot":"","sources":["../src/date.ts"],"names":[],"mappings":"AAAA,MAAM,yBAAyB,GAAG,CAAC,KAAW,EAAE,KAAW,EAAU,EAAE;IACnE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC;AAC9E,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,IAAmB,EAAE,EAAE;IAC1C,IAAI,OAAO,IAAI,KAAK,QAAQ;QAAE,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC;IACpD,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;AACvC,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,SAAe,EAAE,WAAiB,EAAE,OAAa,EAAW,EAAE;IAChF,MAAM,cAAc,GAAG,WAAW,GAAG,SAAS,CAAC;IAC/C,MAAM,aAAa,GAAG,WAAW,GAAG,OAAO,CAAC;IAE5C,OAAO,cAAc,IAAI,aAAa,CAAC;AAC3C,CAAC,CAAC;AAEF,OAAO,EAAE,yBAAyB,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC","sourcesContent":["const calculateDifferenceInDays = (date1: Date, date2: Date): number => {\n return Math.abs((date2.getTime() - date1.getTime()) / (1000 * 3600 * 24));\n};\n\nconst hasDatePassed = (date: Date | string) => {\n if (typeof date === 'string') date = new Date(date);\n return Date.now() > date.getTime();\n};\n\nconst betweenDates = (dateStart: Date, dateBetween: Date, dateEnd: Date): boolean => {\n const afterDateStart = dateBetween > dateStart;\n const beforeDateEnd = dateBetween < dateEnd;\n\n return afterDateStart && beforeDateEnd;\n};\n\nexport { calculateDifferenceInDays, hasDatePassed, betweenDates };\n"]}
|
package/dist/environment.d.ts
CHANGED
|
@@ -1,9 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
interface EnvironmentDetailsConfig {
|
|
2
|
+
environment: string;
|
|
3
|
+
mapboxAccessToken: string;
|
|
4
|
+
mapboxStyle: string;
|
|
5
|
+
apiBaseUrl: string;
|
|
6
|
+
languageIsoCode: string;
|
|
7
|
+
}
|
|
8
|
+
declare class EnvironmentDetails implements Partial<EnvironmentDetailsConfig> {
|
|
9
|
+
environment?: string;
|
|
10
|
+
mapboxAccessToken?: string;
|
|
11
|
+
mapboxStyle?: string;
|
|
12
|
+
apiBaseUrl?: string;
|
|
13
|
+
languageIsoCode?: string;
|
|
14
|
+
init({ environment, mapboxAccessToken, apiBaseUrl, mapboxStyle, languageIsoCode, }: EnvironmentDetailsConfig): void;
|
|
3
15
|
get isLocal(): boolean;
|
|
4
16
|
get isTest(): boolean;
|
|
5
17
|
get isAcceptance(): boolean;
|
|
6
18
|
get isProduction(): boolean;
|
|
7
19
|
}
|
|
8
|
-
export declare const
|
|
20
|
+
export declare const environmentDetails: EnvironmentDetails;
|
|
9
21
|
export {};
|
package/dist/environment.js
CHANGED
|
@@ -1,25 +1,25 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
1
|
+
import { APIClient } from './api';
|
|
2
|
+
class EnvironmentDetails {
|
|
3
|
+
init({ environment, mapboxAccessToken, apiBaseUrl, mapboxStyle, languageIsoCode, }) {
|
|
4
|
+
this.environment = environment;
|
|
5
|
+
this.mapboxAccessToken = mapboxAccessToken;
|
|
6
|
+
this.mapboxStyle = mapboxStyle;
|
|
7
|
+
this.apiBaseUrl = apiBaseUrl;
|
|
8
|
+
this.languageIsoCode = languageIsoCode;
|
|
9
|
+
APIClient.setBaseUrl(apiBaseUrl);
|
|
10
10
|
}
|
|
11
11
|
get isLocal() {
|
|
12
|
-
return this.
|
|
12
|
+
return this.environment === 'local';
|
|
13
13
|
}
|
|
14
14
|
get isTest() {
|
|
15
|
-
return this.
|
|
15
|
+
return this.environment === 'test';
|
|
16
16
|
}
|
|
17
17
|
get isAcceptance() {
|
|
18
|
-
return this.
|
|
18
|
+
return this.environment === 'acceptance';
|
|
19
19
|
}
|
|
20
20
|
get isProduction() {
|
|
21
|
-
return this.
|
|
21
|
+
return this.environment === 'production';
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
|
-
export const
|
|
24
|
+
export const environmentDetails = new EnvironmentDetails();
|
|
25
25
|
//# sourceMappingURL=environment.js.map
|
package/dist/environment.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"environment.js","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"environment.js","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAelC,MAAM,kBAAkB;IAOpB,IAAI,CAAC,EACD,WAAW,EACX,iBAAiB,EACjB,UAAU,EACV,WAAW,EACX,eAAe,GACQ;QACvB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC3C,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QAEvC,SAAS,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IACrC,CAAC;IAED,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,WAAW,KAAK,OAAO,CAAC;IACxC,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,WAAW,KAAK,MAAM,CAAC;IACvC,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,WAAW,KAAK,YAAY,CAAC;IAC7C,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,WAAW,KAAK,YAAY,CAAC;IAC7C,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,kBAAkB,GAAG,IAAI,kBAAkB,EAAE,CAAC","sourcesContent":["import { APIClient } from './api';\n\ninterface EnvironmentDetailsConfig {\n environment: string;\n mapboxAccessToken: string;\n mapboxStyle: string;\n apiBaseUrl: string;\n languageIsoCode: string;\n}\n\n/**\n * @description Sets up the environment details for the Shared Repo. init method must be called in the entry file before importing components.\n * @class EnvironmentDetails\n * @implements {Partial<EnvironmentDetailsConfig>}\n */\nclass EnvironmentDetails implements Partial<EnvironmentDetailsConfig> {\n environment?: string;\n mapboxAccessToken?: string;\n mapboxStyle?: string;\n apiBaseUrl?: string;\n languageIsoCode?: string;\n\n init({\n environment,\n mapboxAccessToken,\n apiBaseUrl,\n mapboxStyle,\n languageIsoCode,\n }: EnvironmentDetailsConfig) {\n this.environment = environment;\n this.mapboxAccessToken = mapboxAccessToken;\n this.mapboxStyle = mapboxStyle;\n this.apiBaseUrl = apiBaseUrl;\n this.languageIsoCode = languageIsoCode;\n\n APIClient.setBaseUrl(apiBaseUrl);\n }\n\n get isLocal() {\n return this.environment === 'local';\n }\n\n get isTest() {\n return this.environment === 'test';\n }\n\n get isAcceptance() {\n return this.environment === 'acceptance';\n }\n\n get isProduction() {\n return this.environment === 'production';\n }\n}\n\nexport const environmentDetails = new EnvironmentDetails();\n"]}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import qs from 'qs';
|
|
2
|
+
|
|
3
|
+
class HttpError extends Error {
|
|
4
|
+
constructor(input) {
|
|
5
|
+
super(input.message);
|
|
6
|
+
this.response = input.response;
|
|
7
|
+
this.statusCode = input.statusCode;
|
|
8
|
+
this.body = input.body;
|
|
9
|
+
this.name = 'HttpError';
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
class HttpClient {
|
|
13
|
+
constructor(config = {}) {
|
|
14
|
+
this.defaultConfig = {
|
|
15
|
+
returnType: 'json',
|
|
16
|
+
};
|
|
17
|
+
this.config = {};
|
|
18
|
+
this.get = this.createRequest('GET');
|
|
19
|
+
this.post = this.createRequest('POST');
|
|
20
|
+
this.put = this.createRequest('PUT');
|
|
21
|
+
this.patch = this.createRequest('PATCH');
|
|
22
|
+
this.delete = this.createRequest('DELETE');
|
|
23
|
+
this.setToken = (token) => (this.token = token);
|
|
24
|
+
this.setAbortController = (config) => {
|
|
25
|
+
const { createAbort } = config;
|
|
26
|
+
if (createAbort) {
|
|
27
|
+
if (typeof AbortController !== undefined) {
|
|
28
|
+
const controller = new AbortController();
|
|
29
|
+
const { signal } = controller;
|
|
30
|
+
config.signal = signal;
|
|
31
|
+
createAbort(controller.abort.bind(controller));
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
createAbort(() => console.log('The AbortController api isnt available in your browser'));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
this.config = Object.assign(Object.assign({}, this.defaultConfig), config);
|
|
39
|
+
}
|
|
40
|
+
createRequest(method) {
|
|
41
|
+
return (url, data, config) => {
|
|
42
|
+
if (method === 'GET') {
|
|
43
|
+
let getUrl = url;
|
|
44
|
+
if (data) {
|
|
45
|
+
getUrl = url + '?' + qs.stringify(data);
|
|
46
|
+
}
|
|
47
|
+
return this.request(getUrl, Object.assign(Object.assign({}, config), { method: 'GET' }));
|
|
48
|
+
}
|
|
49
|
+
const contentType = config && config.headers && config.headers['Content-Type'];
|
|
50
|
+
return this.request(url, Object.assign(Object.assign({}, config), { method, body: this.createBody(data, contentType) }));
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
setAuthenticationHeaders(config) {
|
|
54
|
+
if (this.token) {
|
|
55
|
+
config.headers = Object.assign(Object.assign({}, config.headers), { Authorization: `Bearer ${this.token}` });
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
async request(url, requestConfig = {}) {
|
|
59
|
+
const { beforeHook } = this.config;
|
|
60
|
+
const config = Object.assign(Object.assign({}, this.config), requestConfig);
|
|
61
|
+
const { baseUrl = '' } = config;
|
|
62
|
+
this.setAbortController(config);
|
|
63
|
+
if (beforeHook) {
|
|
64
|
+
await beforeHook(this);
|
|
65
|
+
}
|
|
66
|
+
this.setAuthenticationHeaders(config);
|
|
67
|
+
const requestFn = fetch(baseUrl + url, config)
|
|
68
|
+
.then(this.handleError)
|
|
69
|
+
.then(res => this.handleSuccess(res, config));
|
|
70
|
+
return requestFn.catch(err => this.onError(err, () => this.request(url, requestConfig)));
|
|
71
|
+
}
|
|
72
|
+
handleSuccess(res, config) {
|
|
73
|
+
const { returnType = 'json' } = config;
|
|
74
|
+
if (res.status === 204 || res.status === 201 || !res[returnType]) {
|
|
75
|
+
return res;
|
|
76
|
+
}
|
|
77
|
+
return res[returnType]();
|
|
78
|
+
}
|
|
79
|
+
async onError(err, requestFn) {
|
|
80
|
+
const { onError } = this.config;
|
|
81
|
+
if (onError) {
|
|
82
|
+
return onError(err, requestFn);
|
|
83
|
+
}
|
|
84
|
+
throw err;
|
|
85
|
+
}
|
|
86
|
+
createBody(body, contentType) {
|
|
87
|
+
switch (contentType) {
|
|
88
|
+
case 'application/json':
|
|
89
|
+
return JSON.stringify(body);
|
|
90
|
+
case 'application/x-www-form-urlencoded':
|
|
91
|
+
return new URLSearchParams(body);
|
|
92
|
+
default:
|
|
93
|
+
return JSON.stringify(body);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
async handleError(response) {
|
|
97
|
+
if (response.ok) {
|
|
98
|
+
return response;
|
|
99
|
+
}
|
|
100
|
+
const responseBody = await response.text();
|
|
101
|
+
let body = response;
|
|
102
|
+
try {
|
|
103
|
+
body = JSON.parse(responseBody);
|
|
104
|
+
}
|
|
105
|
+
catch (err) {
|
|
106
|
+
body = responseBody;
|
|
107
|
+
}
|
|
108
|
+
const error = {
|
|
109
|
+
message: `HttpError: ${response.status} - ${response.statusText}`,
|
|
110
|
+
statusCode: response.status,
|
|
111
|
+
response,
|
|
112
|
+
body,
|
|
113
|
+
};
|
|
114
|
+
console.error(error);
|
|
115
|
+
throw new HttpError(error);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
export { HttpClient, HttpError };
|
|
120
|
+
//# sourceMappingURL=http.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http.js","sources":["../../../src/api/http.ts"],"sourcesContent":["import qs from 'qs';\n\nexport interface HttpErrorInput {\n message: string;\n statusCode: number;\n response?: Response;\n body?: any;\n}\n\nexport class HttpError extends Error {\n statusCode: number;\n response?: Response;\n body?: any;\n\n constructor(input: HttpErrorInput) {\n super(input.message);\n this.response = input.response;\n this.statusCode = input.statusCode;\n this.body = input.body;\n this.name = 'HttpError';\n }\n}\n\nexport type AbortFunction = () => void;\ntype Token = string | undefined;\ntype RequestFn = <T = any, I = any>(url: string, data: I, config?: RequestConfig) => Promise<T>;\ntype RequestGetFn = <T = any, I = any>(url: string, data?: I, config?: RequestConfig) => Promise<T>;\ntype BeforeHook = (client: HttpClient) => Promise<void> | void;\ntype ErrorHook = <T = any>(err: HttpError, request: () => Promise<T>) => any;\ntype HttpClientInit = RequestInit & {\n baseUrl?: string;\n returnType?: 'json' | 'text' | 'blob';\n /** This function is called before every request. This is where you would check if your token is still valid */\n beforeHook?: BeforeHook;\n /** Function that is called if an error occurs */\n onError?: ErrorHook;\n};\nexport type RequestConfig = HttpClientInit & {\n createAbort?: (abortFunction: AbortFunction) => void;\n};\n\n/**\n * Wrapper around fetch\n */\nexport class HttpClient {\n private defaultConfig: RequestConfig = {\n returnType: 'json',\n };\n\n private config: RequestConfig = {};\n private token: Token;\n\n constructor(config: HttpClientInit = {}) {\n this.config = {\n ...this.defaultConfig,\n ...config,\n };\n }\n\n /**\n *\n *\n * @private\n * @param {'GET'} method\n * @returns {RequestGetFn}\n * @memberof HttpClient\n */\n private createRequest(method: 'GET'): RequestGetFn;\n private createRequest(method: string): RequestFn;\n private createRequest(method: 'GET' | string): RequestFn {\n return (url, data, config) => {\n if (method === 'GET') {\n let getUrl = url;\n if (data) {\n getUrl = url + '?' + qs.stringify(data);\n }\n\n return this.request(getUrl, {\n ...config,\n method: 'GET',\n });\n }\n\n const contentType = config && config.headers && (config.headers as any)['Content-Type'];\n\n return this.request(url, {\n ...config,\n method,\n body: this.createBody(data, contentType),\n });\n };\n }\n\n public get = this.createRequest('GET');\n public post = this.createRequest('POST');\n public put = this.createRequest('PUT');\n public patch = this.createRequest('PATCH');\n public delete = this.createRequest('DELETE');\n\n public setToken = (token: Token) => (this.token = token);\n\n private setAuthenticationHeaders(config: RequestConfig) {\n // if authenticated set bearer token\n if (this.token) {\n config.headers = {\n ...config.headers,\n Authorization: `Bearer ${this.token}`,\n };\n }\n }\n\n /**\n *\n *\n * @private\n * @memberof HttpClient\n */\n private setAbortController = (config: RequestConfig) => {\n const { createAbort } = config;\n if (createAbort) {\n if (typeof AbortController !== undefined) {\n const controller = new AbortController();\n const { signal } = controller;\n config.signal = signal;\n createAbort(controller.abort.bind(controller));\n } else {\n createAbort(() =>\n console.log('The AbortController api isnt available in your browser'),\n );\n }\n }\n };\n\n /**\n *\n *\n * @template T\n * @param {(string | URL)} url\n * @param {RequestConfig} [requestConfig={}]\n * @returns {Promise<T>}\n * @memberof HttpClient\n */\n public async request<T>(url: string | URL, requestConfig: RequestConfig = {}): Promise<T> {\n const { beforeHook } = this.config;\n\n const config: RequestConfig = {\n ...this.config,\n ...requestConfig,\n };\n\n const { baseUrl = '' } = config;\n\n this.setAbortController(config);\n\n if (beforeHook) {\n await beforeHook(this);\n }\n\n this.setAuthenticationHeaders(config);\n\n const requestFn = fetch(baseUrl + url, config)\n .then(this.handleError)\n .then(res => this.handleSuccess(res, config)) as Promise<T>;\n\n return requestFn.catch(err => this.onError<T>(err, () => this.request(url, requestConfig)));\n }\n\n /**\n *\n *\n * @private\n * @param {Response} res\n * @param {RequestConfig} config\n * @returns\n * @memberof HttpClient\n */\n private handleSuccess(res: Response, config: RequestConfig) {\n const { returnType = 'json' } = config;\n\n if (res.status === 204 || res.status === 201 || !res[returnType]) {\n return res;\n }\n\n return res[returnType]();\n }\n\n private async onError<T = any>(err: HttpError, requestFn: () => Promise<T>) {\n const { onError } = this.config;\n\n if (onError) {\n return onError(err, requestFn);\n }\n\n throw err;\n }\n\n /**\n * createBody is responsible for creating a body based on the content type\n *\n * @param body The body\n * @param contentType The content type\n */\n private createBody(body: any, contentType: string): any {\n switch (contentType) {\n case 'application/json':\n return JSON.stringify(body);\n case 'application/x-www-form-urlencoded':\n return new URLSearchParams(body);\n default:\n return JSON.stringify(body);\n }\n }\n\n /**\n * Handles the errors if the fetch request fails and throws a HttpError\n * @param response\n */\n private async handleError(response: Response) {\n if (response.ok) {\n return response;\n }\n\n const responseBody = await response.text();\n let body: any = response;\n\n try {\n body = JSON.parse(responseBody);\n } catch (err) {\n body = responseBody;\n }\n\n const error = {\n message: `HttpError: ${response.status} - ${response.statusText}`,\n statusCode: response.status,\n response,\n body,\n };\n\n console.error(error);\n throw new HttpError(error);\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/api/index.ts"],"sourcesContent":["import { HttpClient } from './http';\n\nexport const APIClient = new HttpClient({\n baseUrl: window.__ENVIRONMENT_DETAILS__.apiBaseUrl,\n headers: {\n 'Content-Type': 'application/json',\n },\n});\n"],"names":[],"mappings":";;MAEa,SAAS,GAAG,IAAI,UAAU,CAAC;IACpC,OAAO,EAAE,MAAM,CAAC,uBAAuB,CAAC,UAAU;IAClD,OAAO,EAAE;QACL,cAAc,EAAE,kBAAkB;KACrC;CACJ;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compose-exclude-string.js","sources":["../../../src/api-utilities/compose-exclude-string.ts"],"sourcesContent":["import {\n ApartmentBuildingModel,\n AreaProjectModel,\n ConstructionNumberModel,\n DistrictModel,\n ProjectPhaseModel,\n PropertyTypeModel,\n} from '../generated';\n\nconst composeExcludeString = (\n keys: (\n | keyof ConstructionNumberModel\n | keyof PropertyTypeModel\n | keyof ApartmentBuildingModel\n | keyof ProjectPhaseModel\n | keyof DistrictModel\n | keyof AreaProjectModel\n )[],\n) => {\n return keys.join(',');\n};\n\nexport { composeExcludeString };\n"],"names":[],"mappings":"MASM,oBAAoB,GAAG,CACzB,IAOG;IAEH,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC1B;;;;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
const filterNumbers = (values) => values.filter(Number.isInteger);
|
|
2
|
+
const mergeDecimalRange = ({ from: fromA, to: toA }, { from: fromB, to: toB }) => {
|
|
3
|
+
const mergedRange = {};
|
|
4
|
+
const filteredNumbers = filterNumbers([fromA, toA, fromB, toB]);
|
|
5
|
+
if (!filteredNumbers.length)
|
|
6
|
+
return {};
|
|
7
|
+
mergedRange.from = Math.min(...filteredNumbers);
|
|
8
|
+
mergedRange.to = Math.max(...filteredNumbers);
|
|
9
|
+
return mergedRange;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export { mergeDecimalRange };
|
|
13
|
+
//# sourceMappingURL=merge-decimal-range.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"merge-decimal-range.js","sources":["../../../../src/api-utilities/decimal-range/merge-decimal-range.ts"],"sourcesContent":["import { DecimalRange } from '../../generated';\n\nconst filterNumbers = (values: (number | null | undefined)[]): number[] =>\n values.filter(Number.isInteger) as number[];\n\nconst mergeDecimalRange = (\n { from: fromA, to: toA }: DecimalRange,\n { from: fromB, to: toB }: DecimalRange,\n) => {\n const mergedRange: DecimalRange = {};\n const filteredNumbers = filterNumbers([fromA, toA, fromB, toB]);\n\n if (!filteredNumbers.length) return {};\n\n mergedRange.from = Math.min(...filteredNumbers);\n mergedRange.to = Math.max(...filteredNumbers);\n\n return mergedRange;\n};\n\nexport { mergeDecimalRange };\n"],"names":[],"mappings":"AAEA,MAAM,aAAa,GAAG,CAAC,MAAqC,KACxD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAa,CAAC;MAE1C,iBAAiB,GAAG,CACtB,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAgB,EACtC,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAgB;IAEtC,MAAM,WAAW,GAAiB,EAAE,CAAC;IACrC,MAAM,eAAe,GAAG,aAAa,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IAEhE,IAAI,CAAC,eAAe,CAAC,MAAM;QAAE,OAAO,EAAE,CAAC;IAEvC,WAAW,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,eAAe,CAAC,CAAC;IAChD,WAAW,CAAC,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,eAAe,CAAC,CAAC;IAE9C,OAAO,WAAW,CAAC;AACvB;;;;"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { mergeDecimalRange } from './merge-decimal-range.js';
|
|
2
|
+
|
|
3
|
+
const mergeSpecification = (range, key, specifications) => {
|
|
4
|
+
if (specifications && specifications[key]) {
|
|
5
|
+
return mergeDecimalRange(range, specifications[key]);
|
|
6
|
+
}
|
|
7
|
+
return range;
|
|
8
|
+
};
|
|
9
|
+
const mergePropertySpecification = ({ propertyTypes, projectPhases, }, key) => {
|
|
10
|
+
if (propertyTypes) {
|
|
11
|
+
return propertyTypes.reduce((range, propertyType) => {
|
|
12
|
+
return mergeSpecification(range, key, propertyType.specifications);
|
|
13
|
+
}, {});
|
|
14
|
+
}
|
|
15
|
+
if (projectPhases) {
|
|
16
|
+
return projectPhases.reduce((range, projectPhase) => {
|
|
17
|
+
return mergeSpecification(range, key, projectPhase.propertySpecifications);
|
|
18
|
+
}, {});
|
|
19
|
+
}
|
|
20
|
+
return {};
|
|
21
|
+
};
|
|
22
|
+
const mergeConstructionNumberSpecification = (constructionNumbers, key) => {
|
|
23
|
+
return constructionNumbers.reduce((range, constructionNumber) => {
|
|
24
|
+
return mergeSpecification(range, key, constructionNumber.specifications);
|
|
25
|
+
}, {});
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
export { mergeConstructionNumberSpecification, mergePropertySpecification };
|
|
29
|
+
//# sourceMappingURL=merge-specification-range.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"merge-specification-range.js","sources":["../../../../src/api-utilities/decimal-range/merge-specification-range.ts"],"sourcesContent":["import {\n ConstructionNumberModel,\n ConstructionNumberSpecifications,\n DecimalRange,\n ProjectPhaseModel,\n PropertySpecifications,\n PropertyTypeModel,\n} from '../../generated';\nimport { mergeDecimalRange } from './merge-decimal-range';\n\ntype PropertyKeys = keyof PropertySpecifications;\n\ninterface MergeSpecificationRange {\n (obj: { propertyTypes: PropertyTypeModel[] }, key: PropertyKeys): DecimalRange;\n (obj: { projectPhases: ProjectPhaseModel[] }, key: PropertyKeys): DecimalRange;\n}\n\nconst mergeSpecification = <Specifications>(\n range: DecimalRange,\n key: keyof Specifications,\n specifications?: Specifications,\n): DecimalRange => {\n if (specifications && specifications[key]) {\n return mergeDecimalRange(range, specifications[key]!);\n }\n\n return range;\n};\n\n/**\n * Merges all specification properties of an array of apiObjects:\n *\n * @param {{\n * propertyTypes?: PropertyTypeModel[];\n * projectPhases?: ProjectPhaseModel[];\n * }} {\n * propertyTypes,\n * projectPhases,\n * }\n * @param {keyof PropertySpecifications} key\n * @return {*} {DecimalRange}\n */\nconst mergePropertySpecification: MergeSpecificationRange = (\n {\n propertyTypes,\n projectPhases,\n }: {\n propertyTypes?: PropertyTypeModel[];\n projectPhases?: ProjectPhaseModel[];\n },\n key: keyof PropertySpecifications,\n): DecimalRange => {\n if (propertyTypes) {\n return propertyTypes.reduce<DecimalRange>((range, propertyType) => {\n return mergeSpecification<PropertySpecifications>(\n range,\n key,\n propertyType.specifications,\n );\n }, {});\n }\n\n if (projectPhases) {\n return projectPhases.reduce<DecimalRange>((range, projectPhase) => {\n return mergeSpecification<PropertySpecifications>(\n range,\n key,\n projectPhase.propertySpecifications,\n );\n }, {});\n }\n\n return {};\n};\n\n/**\n * Merges all specification properties of an array of constructionNumbers\n *\n * @param {ConstructionNumberModel[]} constructionNumbers\n * @param {keyof ConstructionNumberSpecifications} key\n * @return {*} {DecimalRange}\n */\nconst mergeConstructionNumberSpecification = (\n constructionNumbers: ConstructionNumberModel[],\n key: keyof ConstructionNumberSpecifications,\n): DecimalRange => {\n return constructionNumbers.reduce<DecimalRange>((range, constructionNumber) => {\n return mergeSpecification<ConstructionNumberSpecifications>(\n range,\n key,\n constructionNumber.specifications,\n );\n }, {});\n};\n\nexport { mergePropertySpecification, mergeConstructionNumberSpecification };\n"],"names":[],"mappings":";;AAiBA,MAAM,kBAAkB,GAAG,CACvB,KAAmB,EACnB,GAAyB,EACzB,cAA+B;IAE/B,IAAI,cAAc,IAAI,cAAc,CAAC,GAAG,CAAC,EAAE;QACvC,OAAO,iBAAiB,CAAC,KAAK,EAAE,cAAc,CAAC,GAAG,CAAE,CAAC,CAAC;KACzD;IAED,OAAO,KAAK,CAAC;AACjB,CAAC,CAAC;MAeI,0BAA0B,GAA4B,CACxD,EACI,aAAa,EACb,aAAa,GAIhB,EACD,GAAiC;IAEjC,IAAI,aAAa,EAAE;QACf,OAAO,aAAa,CAAC,MAAM,CAAe,CAAC,KAAK,EAAE,YAAY;YAC1D,OAAO,kBAAkB,CACrB,KAAK,EACL,GAAG,EACH,YAAY,CAAC,cAAc,CAC9B,CAAC;SACL,EAAE,EAAE,CAAC,CAAC;KACV;IAED,IAAI,aAAa,EAAE;QACf,OAAO,aAAa,CAAC,MAAM,CAAe,CAAC,KAAK,EAAE,YAAY;YAC1D,OAAO,kBAAkB,CACrB,KAAK,EACL,GAAG,EACH,YAAY,CAAC,sBAAsB,CACtC,CAAC;SACL,EAAE,EAAE,CAAC,CAAC;KACV;IAED,OAAO,EAAE,CAAC;AACd,EAAE;MASI,oCAAoC,GAAG,CACzC,mBAA8C,EAC9C,GAA2C;IAE3C,OAAO,mBAAmB,CAAC,MAAM,CAAe,CAAC,KAAK,EAAE,kBAAkB;QACtE,OAAO,kBAAkB,CACrB,KAAK,EACL,GAAG,EACH,kBAAkB,CAAC,cAAc,CACpC,CAAC;KACL,EAAE,EAAE,CAAC,CAAC;AACX;;;;"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
const getDistrictStatus = (district, projectPhases) => {
|
|
2
|
+
const filteredProjectPhases = projectPhases.filter(({ districtId }) => district.id === districtId);
|
|
3
|
+
const statuses = filteredProjectPhases
|
|
4
|
+
.map((item) => item.status)
|
|
5
|
+
.filter((status, index, self) => status && self.indexOf(status) === index);
|
|
6
|
+
if (statuses.length === 1 && statuses[0])
|
|
7
|
+
return statuses[0];
|
|
8
|
+
if (statuses.indexOf('OnSale') > -1)
|
|
9
|
+
return 'OnSale';
|
|
10
|
+
return 'InPreparation';
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export { getDistrictStatus };
|
|
14
|
+
//# sourceMappingURL=district-status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"district-status.js","sources":["../../../src/api-utilities/district-status.ts"],"sourcesContent":["import { DistrictModel, ProjectPhaseModel, ProjectPhaseStatus } from '../generated';\n\n/*\n Returns a status based on related projectPhases\n*/\nconst getDistrictStatus = (\n district: DistrictModel,\n projectPhases: ProjectPhaseModel[],\n): ProjectPhaseStatus => {\n // Filter related project phases\n const filteredProjectPhases = projectPhases.filter(\n ({ districtId }) => district.id === districtId,\n );\n\n const statuses = filteredProjectPhases\n .map((item) => item.status)\n .filter((status, index, self) => status && self.indexOf(status) === index);\n\n // Return correct district status\n if (statuses.length === 1 && statuses[0]) return statuses[0];\n\n if (statuses.indexOf('OnSale') > -1) return 'OnSale';\n\n return 'InPreparation';\n};\n\nexport { getDistrictStatus };\n"],"names":[],"mappings":"MAKM,iBAAiB,GAAG,CACtB,QAAuB,EACvB,aAAkC;IAGlC,MAAM,qBAAqB,GAAG,aAAa,CAAC,MAAM,CAC9C,CAAC,EAAE,UAAU,EAAE,KAAK,QAAQ,CAAC,EAAE,KAAK,UAAU,CACjD,CAAC;IAEF,MAAM,QAAQ,GAAG,qBAAqB;SACjC,GAAG,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,CAAC;SAC1B,MAAM,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,KAAK,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,KAAK,CAAC,CAAC;IAG/E,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC;QAAE,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC;IAE7D,IAAI,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAAE,OAAO,QAAQ,CAAC;IAErD,OAAO,eAAe,CAAC;AAC3B;;;;"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
const filterApiObjects = () => {
|
|
2
|
+
return (objects, conditions) => objects.filter((object) => {
|
|
3
|
+
const match = [];
|
|
4
|
+
Object.keys(conditions).forEach((key) => {
|
|
5
|
+
const condition = conditions[key];
|
|
6
|
+
if (condition === null || condition === undefined)
|
|
7
|
+
return;
|
|
8
|
+
const conditionMatches = object[key] === condition;
|
|
9
|
+
match.push(conditionMatches);
|
|
10
|
+
});
|
|
11
|
+
return match.indexOf(false) === -1;
|
|
12
|
+
});
|
|
13
|
+
};
|
|
14
|
+
const findApiObject = () => {
|
|
15
|
+
return (objects, conditions) => objects.find((object) => {
|
|
16
|
+
const match = [];
|
|
17
|
+
Object.keys(conditions).forEach((key) => {
|
|
18
|
+
const condition = conditions[key];
|
|
19
|
+
if (condition === null || condition === undefined)
|
|
20
|
+
return;
|
|
21
|
+
const conditionMatches = object[key] === condition;
|
|
22
|
+
match.push(conditionMatches);
|
|
23
|
+
});
|
|
24
|
+
return match.indexOf(false) === -1;
|
|
25
|
+
});
|
|
26
|
+
};
|
|
27
|
+
const filterConstructionNumbers = filterApiObjects();
|
|
28
|
+
const filterPropertyTypes = filterApiObjects();
|
|
29
|
+
const filterProjectPhases = filterApiObjects();
|
|
30
|
+
const filterDistricts = filterApiObjects();
|
|
31
|
+
const filterAreaProjects = filterApiObjects();
|
|
32
|
+
const filterApartmentBuildings = filterApiObjects();
|
|
33
|
+
const findConstructionNumber = findApiObject();
|
|
34
|
+
const findPropertyType = findApiObject();
|
|
35
|
+
const findProjectPhase = findApiObject();
|
|
36
|
+
const findDistrict = findApiObject();
|
|
37
|
+
const findAreaProject = findApiObject();
|
|
38
|
+
const findApartmentBuilding = findApiObject();
|
|
39
|
+
|
|
40
|
+
export { filterApartmentBuildings, filterAreaProjects, filterConstructionNumbers, filterDistricts, filterProjectPhases, filterPropertyTypes, findApartmentBuilding, findAreaProject, findConstructionNumber, findDistrict, findProjectPhase, findPropertyType };
|
|
41
|
+
//# sourceMappingURL=find-filter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find-filter.js","sources":["../../../src/api-utilities/find-filter.ts"],"sourcesContent":["import {\n ApartmentBuildingModel,\n AreaProjectModel,\n ConstructionNumberModel,\n DistrictModel,\n ProjectPhaseModel,\n PropertyTypeModel,\n} from '../generated';\n\nconst filterApiObjects = <ApiObject, Conditions>() => {\n return <T = ApiObject>(objects: T[], conditions: Conditions): T[] =>\n objects.filter((object) => {\n const match: boolean[] = [];\n\n Object.keys(conditions).forEach((key) => {\n const condition = conditions[key as keyof typeof conditions] as any;\n\n if (condition === null || condition === undefined) return;\n\n const conditionMatches = object[key as keyof T] === condition;\n\n match.push(conditionMatches);\n });\n\n return match.indexOf(false) === -1;\n });\n};\n\nconst findApiObject = <ApiObject, Conditions>() => {\n return <T = ApiObject>(objects: T[], conditions: Conditions): T | undefined =>\n objects.find((object) => {\n const match: boolean[] = [];\n\n Object.keys(conditions).forEach((key) => {\n const condition = conditions[key as keyof typeof conditions] as any;\n\n if (condition === null || condition === undefined) return;\n\n const conditionMatches = object[key as keyof T] === condition;\n\n match.push(conditionMatches);\n });\n\n return match.indexOf(false) === -1;\n });\n};\n\ninterface ConstructionNumberConditions extends Omit<ConstructionNumberModel, 'id'> {\n id?: string;\n}\n\ninterface PropertyTypeConditions extends Omit<PropertyTypeModel, 'id'> {\n id?: string;\n}\n\ninterface ProjectPhaseConditions extends Omit<ProjectPhaseModel, 'id'> {\n id?: string;\n}\n\ninterface DistrictConditions extends Omit<DistrictModel, 'id'> {\n id?: string;\n}\n\ninterface AreaProjectConditions extends Omit<AreaProjectModel, 'id'> {\n id?: string;\n}\n\ninterface ApartmentBuildingConditions extends Omit<ApartmentBuildingModel, 'id'> {\n id?: string;\n}\n\nconst filterConstructionNumbers = filterApiObjects<\n ConstructionNumberModel,\n ConstructionNumberConditions\n>();\nconst filterPropertyTypes = filterApiObjects<PropertyTypeModel, PropertyTypeConditions>();\nconst filterProjectPhases = filterApiObjects<ProjectPhaseModel, ProjectPhaseConditions>();\nconst filterDistricts = filterApiObjects<DistrictModel, DistrictConditions>();\nconst filterAreaProjects = filterApiObjects<AreaProjectModel, AreaProjectConditions>();\nconst filterApartmentBuildings = filterApiObjects<\n ApartmentBuildingModel,\n ApartmentBuildingConditions\n>();\n\nconst findConstructionNumber = findApiObject<\n ConstructionNumberModel,\n ConstructionNumberConditions\n>();\nconst findPropertyType = findApiObject<PropertyTypeModel, PropertyTypeConditions>();\nconst findProjectPhase = findApiObject<ProjectPhaseModel, ProjectPhaseConditions>();\nconst findDistrict = findApiObject<DistrictModel, DistrictConditions>();\nconst findAreaProject = findApiObject<AreaProjectModel, AreaProjectConditions>();\nconst findApartmentBuilding = findApiObject<ApartmentBuildingModel, ApartmentBuildingConditions>();\n\nexport {\n filterConstructionNumbers,\n filterPropertyTypes,\n filterProjectPhases,\n filterDistricts,\n filterAreaProjects,\n filterApartmentBuildings,\n findConstructionNumber,\n findPropertyType,\n findProjectPhase,\n findDistrict,\n findAreaProject,\n findApartmentBuilding,\n};\n"],"names":[],"mappings":"AASA,MAAM,gBAAgB,GAAG;IACrB,OAAO,CAAgB,OAAY,EAAE,UAAsB,KACvD,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM;QAClB,MAAM,KAAK,GAAc,EAAE,CAAC;QAE5B,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG;YAChC,MAAM,SAAS,GAAG,UAAU,CAAC,GAA8B,CAAQ,CAAC;YAEpE,IAAI,SAAS,KAAK,IAAI,IAAI,SAAS,KAAK,SAAS;gBAAE,OAAO;YAE1D,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAc,CAAC,KAAK,SAAS,CAAC;YAE9D,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SAChC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;KACtC,CAAC,CAAC;AACX,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG;IAClB,OAAO,CAAgB,OAAY,EAAE,UAAsB,KACvD,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM;QAChB,MAAM,KAAK,GAAc,EAAE,CAAC;QAE5B,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG;YAChC,MAAM,SAAS,GAAG,UAAU,CAAC,GAA8B,CAAQ,CAAC;YAEpE,IAAI,SAAS,KAAK,IAAI,IAAI,SAAS,KAAK,SAAS;gBAAE,OAAO;YAE1D,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAc,CAAC,KAAK,SAAS,CAAC;YAE9D,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SAChC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;KACtC,CAAC,CAAC;AACX,CAAC,CAAC;MA0BI,yBAAyB,GAAG,gBAAgB,GAG9C;MACE,mBAAmB,GAAG,gBAAgB,GAA8C;MACpF,mBAAmB,GAAG,gBAAgB,GAA8C;MACpF,eAAe,GAAG,gBAAgB,GAAsC;MACxE,kBAAkB,GAAG,gBAAgB,GAA4C;MACjF,wBAAwB,GAAG,gBAAgB,GAG7C;MAEE,sBAAsB,GAAG,aAAa,GAGxC;MACE,gBAAgB,GAAG,aAAa,GAA8C;MAC9E,gBAAgB,GAAG,aAAa,GAA8C;MAC9E,YAAY,GAAG,aAAa,GAAsC;MAClE,eAAe,GAAG,aAAa,GAA4C;MAC3E,qBAAqB,GAAG,aAAa;;;;"}
|