@bpd-library/utilities 1.3.2-beta.7 → 1.3.2-beta.8
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/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/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/hooks/use-form-changes.d.ts +12 -0
- package/dist/hooks/use-form-changes.js +27 -0
- package/dist/hooks/use-form-changes.js.map +1 -0
- 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
- package/dist/hooks/use-partition.d.ts +0 -1
- package/dist/hooks/use-partition.js +0 -11
- package/dist/hooks/use-partition.js.map +0 -1
|
@@ -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"]}
|
|
@@ -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;;;;"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { calculateCenter } from '../../geometry/geometry.js';
|
|
2
|
+
|
|
3
|
+
const validateCoordinates = (coordinates) => {
|
|
4
|
+
const validates = coordinates.every((coordinate) => coordinate.every(([longitude, latitude]) => {
|
|
5
|
+
return longitude < 180 && longitude > -180 && latitude > -90 && latitude < 90;
|
|
6
|
+
}));
|
|
7
|
+
return validates;
|
|
8
|
+
};
|
|
9
|
+
const getApiObjectCenter = (apiObject) => {
|
|
10
|
+
const { location } = apiObject;
|
|
11
|
+
let coordinates;
|
|
12
|
+
if (location) {
|
|
13
|
+
coordinates = [[location]];
|
|
14
|
+
}
|
|
15
|
+
else if (getApiObjectCoordinates(apiObject)) {
|
|
16
|
+
coordinates = getApiObjectCoordinates(apiObject);
|
|
17
|
+
coordinates = coordinates ? [[calculateCenter(coordinates)]] : undefined;
|
|
18
|
+
}
|
|
19
|
+
return coordinates && validateCoordinates(coordinates) ? coordinates : false;
|
|
20
|
+
};
|
|
21
|
+
const getApiObjectCoordinates = ({ geometry, }) => {
|
|
22
|
+
if (!(geometry === null || geometry === void 0 ? void 0 : geometry.length))
|
|
23
|
+
return;
|
|
24
|
+
const coordinates = geometry
|
|
25
|
+
.filter(({ coordinates }) => !!coordinates)
|
|
26
|
+
.map(({ coordinates }) => coordinates);
|
|
27
|
+
return (coordinates === null || coordinates === void 0 ? void 0 : coordinates.length) ? coordinates : undefined;
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
export { getApiObjectCenter, getApiObjectCoordinates, validateCoordinates };
|
|
31
|
+
//# sourceMappingURL=coordinates.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coordinates.js","sources":["../../../../src/api-utilities/get/coordinates.ts"],"sourcesContent":["import { Coordinates } from '@bpd-library/types';\n\nimport {\n AreaProjectModel,\n ConstructionNumberModel,\n DistrictModel,\n ProjectPhaseModel,\n PropertyTypeModel,\n} from '../../generated';\nimport { calculateCenter } from '../../geometry';\n\nconst validateCoordinates = (coordinates: Coordinates) => {\n const validates = coordinates.every((coordinate) =>\n coordinate.every(([longitude, latitude]) => {\n return longitude < 180 && longitude > -180 && latitude > -90 && latitude < 90;\n }),\n );\n\n return validates;\n};\n\nconst getApiObjectCenter = (\n apiObject: AreaProjectModel | ProjectPhaseModel | DistrictModel,\n): Coordinates | false => {\n const { location } = apiObject;\n\n let coordinates: Coordinates | undefined;\n\n if (location) {\n coordinates = [[location as [number, number]]];\n } else if (getApiObjectCoordinates(apiObject)) {\n coordinates = getApiObjectCoordinates(apiObject);\n coordinates = coordinates ? [[calculateCenter(coordinates)]] : undefined;\n }\n\n return coordinates && validateCoordinates(coordinates) ? coordinates : false;\n};\n\nconst getApiObjectCoordinates = ({\n geometry,\n}: DistrictModel | ProjectPhaseModel | PropertyTypeModel | ConstructionNumberModel):\n | Coordinates\n | undefined => {\n if (!geometry?.length) return;\n\n const coordinates = geometry\n .filter(({ coordinates }) => !!coordinates)\n .map(({ coordinates }) => coordinates as [number, number][]);\n\n return coordinates?.length ? coordinates : undefined;\n};\n\nexport { validateCoordinates, getApiObjectCenter, getApiObjectCoordinates };\n"],"names":[],"mappings":";;MAWM,mBAAmB,GAAG,CAAC,WAAwB;IACjD,MAAM,SAAS,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,UAAU,KAC3C,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,EAAE,QAAQ,CAAC;QACnC,OAAO,SAAS,GAAG,GAAG,IAAI,SAAS,GAAG,CAAC,GAAG,IAAI,QAAQ,GAAG,CAAC,EAAE,IAAI,QAAQ,GAAG,EAAE,CAAC;KACjF,CAAC,CACL,CAAC;IAEF,OAAO,SAAS,CAAC;AACrB,EAAE;MAEI,kBAAkB,GAAG,CACvB,SAA+D;IAE/D,MAAM,EAAE,QAAQ,EAAE,GAAG,SAAS,CAAC;IAE/B,IAAI,WAAoC,CAAC;IAEzC,IAAI,QAAQ,EAAE;QACV,WAAW,GAAG,CAAC,CAAC,QAA4B,CAAC,CAAC,CAAC;KAClD;SAAM,IAAI,uBAAuB,CAAC,SAAS,CAAC,EAAE;QAC3C,WAAW,GAAG,uBAAuB,CAAC,SAAS,CAAC,CAAC;QACjD,WAAW,GAAG,WAAW,GAAG,CAAC,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;KAC5E;IAED,OAAO,WAAW,IAAI,mBAAmB,CAAC,WAAW,CAAC,GAAG,WAAW,GAAG,KAAK,CAAC;AACjF,EAAE;MAEI,uBAAuB,GAAG,CAAC,EAC7B,QAAQ,GACsE;IAG9E,IAAI,EAAC,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,MAAM,CAAA;QAAE,OAAO;IAE9B,MAAM,WAAW,GAAG,QAAQ;SACvB,MAAM,CAAC,CAAC,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC,WAAW,CAAC;SAC1C,GAAG,CAAC,CAAC,EAAE,WAAW,EAAE,KAAK,WAAiC,CAAC,CAAC;IAEjE,OAAO,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,MAAM,IAAG,WAAW,GAAG,SAAS,CAAC;AACzD;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"layer-raster.js","sources":["../../../../src/api-utilities/get/layer-raster.ts"],"sourcesContent":["import { AreaProjectModel } from '../../generated';\n\nconst getApiObjectLayerRaster = ({ mapboxTilesetId }: AreaProjectModel) =>\n mapboxTilesetId ? `https://api.mapbox.com/v4/${mapboxTilesetId}` : null;\n\nexport { getApiObjectLayerRaster };\n"],"names":[],"mappings":"MAEM,uBAAuB,GAAG,CAAC,EAAE,eAAe,EAAoB,KAClE,eAAe,GAAG,6BAA6B,eAAe,EAAE,GAAG;;;;"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
const showMortgagePrice = (constructionNumber) => {
|
|
2
|
+
var _a, _b, _c, _d;
|
|
3
|
+
if (((_a = constructionNumber.projectPhase) === null || _a === void 0 ? void 0 : _a.isRental) ||
|
|
4
|
+
((_b = constructionNumber.salesPrice) === null || _b === void 0 ? void 0 : _b.priceType) == 'PriceOnRequest') {
|
|
5
|
+
return;
|
|
6
|
+
}
|
|
7
|
+
return (_d = (_c = constructionNumber.salesPrice) === null || _c === void 0 ? void 0 : _c.amount) === null || _d === void 0 ? void 0 : _d.from;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
export { showMortgagePrice };
|
|
11
|
+
//# sourceMappingURL=show-mortgage-price.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"show-mortgage-price.js","sources":["../../../src/api-utilities/show-mortgage-price.ts"],"sourcesContent":["import { ExtendedConstructionNumber } from './api-utilities.types';\n\nconst showMortgagePrice = (constructionNumber: ExtendedConstructionNumber): number | undefined => {\n if (\n constructionNumber.projectPhase?.isRental ||\n constructionNumber.salesPrice?.priceType == 'PriceOnRequest'\n ) {\n return;\n }\n return constructionNumber.salesPrice?.amount?.from;\n};\n\nexport { showMortgagePrice };\n"],"names":[],"mappings":"MAEM,iBAAiB,GAAG,CAAC,kBAA8C;;IACrE,IACI,OAAA,kBAAkB,CAAC,YAAY,0CAAE,QAAQ;QACzC,OAAA,kBAAkB,CAAC,UAAU,0CAAE,SAAS,KAAI,gBAAgB,EAC9D;QACE,OAAO;KACV;IACD,mBAAO,kBAAkB,CAAC,UAAU,0CAAE,MAAM,0CAAE,IAAI,CAAC;AACvD;;;;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
const showPrice = ({ constructionNumber, apartmentBuilding, propertyType, }) => {
|
|
2
|
+
const { status } = constructionNumber || propertyType || apartmentBuilding || {};
|
|
3
|
+
const { salesPrice } = constructionNumber || propertyType || {};
|
|
4
|
+
if (salesPrice) {
|
|
5
|
+
const { priceType } = salesPrice;
|
|
6
|
+
if (priceType === 'PriceOnRequest')
|
|
7
|
+
return false;
|
|
8
|
+
}
|
|
9
|
+
return !!status && !['Rented', 'Sold', 'UnderConstruction'].includes(status);
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export { showPrice };
|
|
13
|
+
//# sourceMappingURL=show-price.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"show-price.js","sources":["../../../src/api-utilities/show-price.ts"],"sourcesContent":["import {\n ExtendedApartmentBuilding,\n ExtendedConstructionNumber,\n ExtendedPropertyType,\n} from './api-utilities.types';\n\nconst showPrice = ({\n constructionNumber,\n apartmentBuilding,\n propertyType,\n}: {\n constructionNumber?: ExtendedConstructionNumber;\n propertyType?: ExtendedPropertyType;\n apartmentBuilding?: ExtendedApartmentBuilding;\n}): boolean => {\n const { status } = constructionNumber || propertyType || apartmentBuilding || {};\n const { salesPrice } = constructionNumber || propertyType || {};\n\n if (salesPrice) {\n const { priceType } = salesPrice;\n if (priceType === 'PriceOnRequest') return false;\n }\n\n return !!status && !['Rented', 'Sold', 'UnderConstruction'].includes(status);\n};\n\nexport { showPrice };\n"],"names":[],"mappings":"MAMM,SAAS,GAAG,CAAC,EACf,kBAAkB,EAClB,iBAAiB,EACjB,YAAY,GAKf;IACG,MAAM,EAAE,MAAM,EAAE,GAAG,kBAAkB,IAAI,YAAY,IAAI,iBAAiB,IAAI,EAAE,CAAC;IACjF,MAAM,EAAE,UAAU,EAAE,GAAG,kBAAkB,IAAI,YAAY,IAAI,EAAE,CAAC;IAEhE,IAAI,UAAU,EAAE;QACZ,MAAM,EAAE,SAAS,EAAE,GAAG,UAAU,CAAC;QACjC,IAAI,SAAS,KAAK,gBAAgB;YAAE,OAAO,KAAK,CAAC;KACpD;IAED,OAAO,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,QAAQ,EAAE,MAAM,EAAE,mBAAmB,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;AACjF;;;;"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
const DESIGN_SYSTEM = 'Design System';
|
|
2
|
+
const ATOMS = `${DESIGN_SYSTEM}|Atoms`;
|
|
3
|
+
const MOLECULES = `${DESIGN_SYSTEM}|Molecules`;
|
|
4
|
+
const ORGANISMS = `${DESIGN_SYSTEM}|Organisms`;
|
|
5
|
+
|
|
6
|
+
export { ATOMS, DESIGN_SYSTEM, MOLECULES, ORGANISMS };
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/constants/index.ts"],"sourcesContent":["export const DESIGN_SYSTEM = 'Design System';\nexport const ATOMS = `${DESIGN_SYSTEM}|Atoms`;\nexport const MOLECULES = `${DESIGN_SYSTEM}|Molecules`;\nexport const ORGANISMS = `${DESIGN_SYSTEM}|Organisms`;\n"],"names":[],"mappings":"MAAa,aAAa,GAAG,gBAAgB;MAChC,KAAK,GAAG,GAAG,aAAa,SAAS;MACjC,SAAS,GAAG,GAAG,aAAa,aAAa;MACzC,SAAS,GAAG,GAAG,aAAa;;;;"}
|
package/dist/esm/date.js
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
const calculateDifferenceInDays = (date1, date2) => {
|
|
2
|
+
return Math.abs((date2.getTime() - date1.getTime()) / (1000 * 3600 * 24));
|
|
3
|
+
};
|
|
4
|
+
const betweenDates = (dateStart, dateBetween, dateEnd) => {
|
|
5
|
+
const afterDateStart = dateBetween > dateStart;
|
|
6
|
+
const beforeDateEnd = dateBetween < dateEnd;
|
|
7
|
+
return afterDateStart && beforeDateEnd;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
export { betweenDates, calculateDifferenceInDays };
|
|
11
|
+
//# sourceMappingURL=date.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date.js","sources":["../../src/date.ts"],"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"],"names":[],"mappings":"MAAM,yBAAyB,GAAG,CAAC,KAAW,EAAE,KAAW;IACvD,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,KAAK,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC;AAC9E,EAAE;MAEI,YAAY,GAAG,CAAC,SAAe,EAAE,WAAiB,EAAE,OAAa;IACnE,MAAM,cAAc,GAAG,WAAW,GAAG,SAAS,CAAC;IAC/C,MAAM,aAAa,GAAG,WAAW,GAAG,OAAO,CAAC;IAE5C,OAAO,cAAc,IAAI,aAAa,CAAC;AAC3C;;;;"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
function debounce(func, waitMilliseconds = 50, options = {
|
|
2
|
+
isImmediate: false,
|
|
3
|
+
}) {
|
|
4
|
+
let timeoutId;
|
|
5
|
+
return function (...args) {
|
|
6
|
+
const context = this;
|
|
7
|
+
const doLater = function () {
|
|
8
|
+
timeoutId = undefined;
|
|
9
|
+
if (!options.isImmediate) {
|
|
10
|
+
func.apply(context, args);
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
const shouldCallNow = options.isImmediate && timeoutId === undefined;
|
|
14
|
+
if (timeoutId !== undefined) {
|
|
15
|
+
clearTimeout(timeoutId);
|
|
16
|
+
}
|
|
17
|
+
timeoutId = setTimeout(doLater, waitMilliseconds);
|
|
18
|
+
if (shouldCallNow) {
|
|
19
|
+
func.apply(context, args);
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export { debounce };
|
|
25
|
+
//# sourceMappingURL=debounce.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"debounce.js","sources":["../../src/debounce.ts"],"sourcesContent":["/**\n * A function that emits a side effect and does not return anything.\n */\nexport type Procedure = (...args: any[]) => void;\n\nexport type DebounceOptions = {\n isImmediate: boolean;\n};\n\n/**\n * Debounce function\n */\nexport function debounce<F extends Procedure>(\n func: F,\n waitMilliseconds = 50,\n options: DebounceOptions = {\n isImmediate: false,\n },\n): (this: ThisParameterType<F>, ...args: Parameters<F>) => void {\n let timeoutId: ReturnType<typeof setTimeout> | undefined;\n\n return function (this: ThisParameterType<F>, ...args: Parameters<F>) {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const context = this;\n\n const doLater = function () {\n timeoutId = undefined;\n if (!options.isImmediate) {\n func.apply(context, args);\n }\n };\n\n const shouldCallNow = options.isImmediate && timeoutId === undefined;\n\n if (timeoutId !== undefined) {\n clearTimeout(timeoutId);\n }\n\n timeoutId = setTimeout(doLater, waitMilliseconds);\n\n if (shouldCallNow) {\n func.apply(context, args);\n }\n };\n}\n"],"names":[],"mappings":"SAYgB,QAAQ,CACpB,IAAO,EACP,gBAAgB,GAAG,EAAE,EACrB,UAA2B;IACvB,WAAW,EAAE,KAAK;CACrB;IAED,IAAI,SAAoD,CAAC;IAEzD,OAAO,UAAsC,GAAG,IAAmB;QAE/D,MAAM,OAAO,GAAG,IAAI,CAAC;QAErB,MAAM,OAAO,GAAG;YACZ,SAAS,GAAG,SAAS,CAAC;YACtB,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;gBACtB,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;aAC7B;SACJ,CAAC;QAEF,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,IAAI,SAAS,KAAK,SAAS,CAAC;QAErE,IAAI,SAAS,KAAK,SAAS,EAAE;YACzB,YAAY,CAAC,SAAS,CAAC,CAAC;SAC3B;QAED,SAAS,GAAG,UAAU,CAAC,OAAO,EAAE,gBAAgB,CAAC,CAAC;QAElD,IAAI,aAAa,EAAE;YACf,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;SAC7B;KACJ,CAAC;AACN;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dom.js","sources":["../../../src/dom/dom.ts"],"sourcesContent":["const html = document.documentElement;\nconst body = document.body;\n\ninterface Elements {\n body: HTMLElement;\n html: HTMLElement;\n}\n\nexport const elements: Elements = {\n html,\n body,\n};\n"],"names":[],"mappings":"AAAA,MAAM,IAAI,GAAG,QAAQ,CAAC,eAAe,CAAC;AACtC,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;MAOd,QAAQ,GAAa;IAC9B,IAAI;IACJ,IAAI;;;;;"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
const ENVIRONMENT_LOCAL = 'local';
|
|
2
|
+
const ENVIRONMENT_TEST = 'test';
|
|
3
|
+
const ENVIRONMENT_ACCEPTANCE = 'acceptance';
|
|
4
|
+
const ENVIRONMENT_PRODUCTION = 'production';
|
|
5
|
+
const ENVIRONMENT_DEFAULT = ENVIRONMENT_LOCAL;
|
|
6
|
+
const ENVIRONMENT = window.__ENVIRONMENT_DETAILS__.environment;
|
|
7
|
+
class Environment {
|
|
8
|
+
get get() {
|
|
9
|
+
return ENVIRONMENT || ENVIRONMENT_DEFAULT;
|
|
10
|
+
}
|
|
11
|
+
get isLocal() {
|
|
12
|
+
return this.get === ENVIRONMENT_LOCAL;
|
|
13
|
+
}
|
|
14
|
+
get isTest() {
|
|
15
|
+
return this.get === ENVIRONMENT_TEST;
|
|
16
|
+
}
|
|
17
|
+
get isAcceptance() {
|
|
18
|
+
return this.get === ENVIRONMENT_ACCEPTANCE;
|
|
19
|
+
}
|
|
20
|
+
get isProduction() {
|
|
21
|
+
return this.get === ENVIRONMENT_PRODUCTION;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
const environment = new Environment();
|
|
25
|
+
|
|
26
|
+
export { environment };
|
|
27
|
+
//# sourceMappingURL=environment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"environment.js","sources":["../../src/environment.ts"],"sourcesContent":["const ENVIRONMENT_LOCAL = 'local';\nconst ENVIRONMENT_TEST = 'test';\nconst ENVIRONMENT_ACCEPTANCE = 'acceptance';\nconst ENVIRONMENT_PRODUCTION = 'production';\n\nconst ENVIRONMENT_DEFAULT = ENVIRONMENT_LOCAL;\nconst ENVIRONMENT = window.__ENVIRONMENT_DETAILS__.environment;\n\n/**\n * Simple Object to check in which environment we are on based on the hostname\n */\nclass Environment {\n get get() {\n return ENVIRONMENT || ENVIRONMENT_DEFAULT;\n }\n\n get isLocal() {\n return this.get === ENVIRONMENT_LOCAL;\n }\n\n get isTest() {\n return this.get === ENVIRONMENT_TEST;\n }\n\n get isAcceptance() {\n return this.get === ENVIRONMENT_ACCEPTANCE;\n }\n\n get isProduction() {\n return this.get === ENVIRONMENT_PRODUCTION;\n }\n}\n\nexport const environment = new Environment();\n"],"names":[],"mappings":"AAAA,MAAM,iBAAiB,GAAG,OAAO,CAAC;AAClC,MAAM,gBAAgB,GAAG,MAAM,CAAC;AAChC,MAAM,sBAAsB,GAAG,YAAY,CAAC;AAC5C,MAAM,sBAAsB,GAAG,YAAY,CAAC;AAE5C,MAAM,mBAAmB,GAAG,iBAAiB,CAAC;AAC9C,MAAM,WAAW,GAAG,MAAM,CAAC,uBAAuB,CAAC,WAAW,CAAC;AAK/D,MAAM,WAAW;IACb,IAAI,GAAG;QACH,OAAO,WAAW,IAAI,mBAAmB,CAAC;KAC7C;IAED,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,GAAG,KAAK,iBAAiB,CAAC;KACzC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,GAAG,KAAK,gBAAgB,CAAC;KACxC;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,GAAG,KAAK,sBAAsB,CAAC;KAC9C;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,GAAG,KAAK,sBAAsB,CAAC;KAC9C;CACJ;MAEY,WAAW,GAAG,IAAI,WAAW;;;;"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
const EXCLUDED_CONSTRUCTION_NUMBER_PROPERTIES = [
|
|
2
|
+
'shortDescription',
|
|
3
|
+
'longDescription',
|
|
4
|
+
'resources',
|
|
5
|
+
'gardens',
|
|
6
|
+
'outbuildings',
|
|
7
|
+
'groundLease',
|
|
8
|
+
'floors',
|
|
9
|
+
'outsideSpace',
|
|
10
|
+
'extraSpecifications',
|
|
11
|
+
'landRegistration',
|
|
12
|
+
];
|
|
13
|
+
const EXCLUDED_PROPERTY_TYPE_PROPERTIES = [
|
|
14
|
+
'shortDescription',
|
|
15
|
+
'longDescription',
|
|
16
|
+
'environmentTypes',
|
|
17
|
+
'groundLease',
|
|
18
|
+
'resources',
|
|
19
|
+
'constructionStartDate',
|
|
20
|
+
'indicationServiceCosts',
|
|
21
|
+
'indicationSecurity',
|
|
22
|
+
'floors',
|
|
23
|
+
'gardens',
|
|
24
|
+
'outbuildings',
|
|
25
|
+
'usp1Title',
|
|
26
|
+
'usp1Text',
|
|
27
|
+
'usp2Title',
|
|
28
|
+
'usp2Text',
|
|
29
|
+
];
|
|
30
|
+
const EXCLUDED_PROJECT_PHASE_PROPERTIES = [
|
|
31
|
+
'longDescription',
|
|
32
|
+
'resources',
|
|
33
|
+
];
|
|
34
|
+
|
|
35
|
+
export { EXCLUDED_CONSTRUCTION_NUMBER_PROPERTIES, EXCLUDED_PROJECT_PHASE_PROPERTIES, EXCLUDED_PROPERTY_TYPE_PROPERTIES };
|
|
36
|
+
//# sourceMappingURL=excluded-properties.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excluded-properties.js","sources":["../../../src/extended-api-models/excluded-properties.ts"],"sourcesContent":["import { ConstructionNumberModel, ProjectPhaseModel, PropertyTypeModel } from '@/generated';\n\n/*\n THE EXCLUDED VALUES ALSO NEED TO BE CHANGED IN api-utilitites.types.ts\n*/\nconst EXCLUDED_CONSTRUCTION_NUMBER_PROPERTIES: (keyof ConstructionNumberModel)[] = [\n 'shortDescription',\n 'longDescription',\n 'resources',\n 'gardens',\n 'outbuildings',\n 'groundLease',\n 'floors',\n 'outsideSpace',\n 'extraSpecifications',\n 'landRegistration',\n];\n\n/*\n THE EXCLUDED VALUES ALSO NEED TO BE CHANGED IN api-utilitites.types.ts\n*/\nconst EXCLUDED_PROPERTY_TYPE_PROPERTIES: (keyof PropertyTypeModel)[] = [\n 'shortDescription',\n 'longDescription',\n 'environmentTypes',\n 'groundLease',\n 'resources',\n 'constructionStartDate',\n 'indicationServiceCosts',\n 'indicationSecurity',\n 'floors',\n 'gardens',\n 'outbuildings',\n 'usp1Title',\n 'usp1Text',\n 'usp2Title',\n 'usp2Text',\n];\n\n/*\n THE EXCLUDED VALUES ALSO NEED TO BE CHANGED IN api-utilitites.types.ts\n*/\nconst EXCLUDED_PROJECT_PHASE_PROPERTIES: (keyof ProjectPhaseModel)[] = [\n 'longDescription',\n 'resources',\n];\n\nexport {\n EXCLUDED_CONSTRUCTION_NUMBER_PROPERTIES,\n EXCLUDED_PROPERTY_TYPE_PROPERTIES,\n EXCLUDED_PROJECT_PHASE_PROPERTIES,\n};\n"],"names":[],"mappings":"MAKM,uCAAuC,GAAsC;IAC/E,kBAAkB;IAClB,iBAAiB;IACjB,WAAW;IACX,SAAS;IACT,cAAc;IACd,aAAa;IACb,QAAQ;IACR,cAAc;IACd,qBAAqB;IACrB,kBAAkB;EACpB;MAKI,iCAAiC,GAAgC;IACnE,kBAAkB;IAClB,iBAAiB;IACjB,kBAAkB;IAClB,aAAa;IACb,WAAW;IACX,uBAAuB;IACvB,wBAAwB;IACxB,oBAAoB;IACpB,QAAQ;IACR,SAAS;IACT,cAAc;IACd,WAAW;IACX,UAAU;IACV,WAAW;IACX,UAAU;EACZ;MAKI,iCAAiC,GAAgC;IACnE,iBAAiB;IACjB,WAAW;;;;;"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { areaProjectQuery } from '../generated/bpd-client.js';
|
|
2
|
+
|
|
3
|
+
const getExtendedAreaProjects = async () => {
|
|
4
|
+
const areaProjects = (await areaProjectQuery());
|
|
5
|
+
areaProjects.forEach((areaProject) => {
|
|
6
|
+
areaProject.objectType = 'areaProject';
|
|
7
|
+
});
|
|
8
|
+
return areaProjects;
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export { getExtendedAreaProjects };
|
|
12
|
+
//# sourceMappingURL=extended-area-projects.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extended-area-projects.js","sources":["../../../src/extended-api-models/extended-area-projects.ts"],"sourcesContent":["import { ExtendedAreaProject } from '../api-utilities';\nimport { areaProjectQuery } from '../generated';\n\n/**\n * @description Returns an array of all areaProjects extended.\n * @return {*} {Promise<ExtendedAreaProject[]>}\n */\nconst getExtendedAreaProjects = async (): Promise<ExtendedAreaProject[]> => {\n const areaProjects = (await areaProjectQuery()) as ExtendedAreaProject[];\n\n areaProjects.forEach((areaProject) => {\n areaProject.objectType = 'areaProject';\n });\n\n return areaProjects;\n};\n\nexport { getExtendedAreaProjects };\n"],"names":[],"mappings":";;MAOM,uBAAuB,GAAG;IAC5B,MAAM,YAAY,IAAI,MAAM,gBAAgB,EAAE,CAA0B,CAAC;IAEzE,YAAY,CAAC,OAAO,CAAC,CAAC,WAAW;QAC7B,WAAW,CAAC,UAAU,GAAG,aAAa,CAAC;KAC1C,CAAC,CAAC;IAEH,OAAO,YAAY,CAAC;AACxB;;;;"}
|