@renaissancerentals/renaissance-component 10.1.40 → 10.1.41

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.
@@ -0,0 +1,549 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.SubletSection = exports.NEW_SUBLET = void 0;
9
+
10
+ var _react = _interopRequireWildcard(require("react"));
11
+
12
+ require("./assets/SubletSection.scss");
13
+
14
+ var _muncherUi = require("@contentmunch/muncher-ui");
15
+
16
+ var _Sublet = require("./data/Sublet");
17
+
18
+ var _SubletService = require("./services/SubletService");
19
+
20
+ var _SubletNotFound = require("./SubletNotFound");
21
+
22
+ var _Utils = require("../utils/Utils");
23
+
24
+ var _Captcha = require("../input/Captcha");
25
+
26
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
27
+
28
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
29
+
30
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
31
+
32
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
33
+
34
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
35
+
36
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
37
+
38
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
39
+
40
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
41
+
42
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
43
+
44
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
45
+
46
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
47
+
48
+ var SubletSection = function SubletSection(_ref) {
49
+ var uniqueId = _ref.uniqueId;
50
+
51
+ var _useState = (0, _react.useState)(_Sublet.defaultSublet),
52
+ _useState2 = _slicedToArray(_useState, 2),
53
+ sublet = _useState2[0],
54
+ setSublet = _useState2[1];
55
+
56
+ var _useState3 = (0, _react.useState)(true),
57
+ _useState4 = _slicedToArray(_useState3, 2),
58
+ isFound = _useState4[0],
59
+ setIsFound = _useState4[1];
60
+
61
+ var _useState5 = (0, _react.useState)(""),
62
+ _useState6 = _slicedToArray(_useState5, 2),
63
+ captchaResponse = _useState6[0],
64
+ setCaptchaResponse = _useState6[1];
65
+
66
+ var _useState7 = (0, _react.useState)(false),
67
+ _useState8 = _slicedToArray(_useState7, 2),
68
+ isSubmitting = _useState8[0],
69
+ setIsSubmitting = _useState8[1];
70
+
71
+ var _useState9 = (0, _react.useState)(""),
72
+ _useState10 = _slicedToArray(_useState9, 2),
73
+ submissionErrorMessage = _useState10[0],
74
+ setSubmissionErrorMessage = _useState10[1];
75
+
76
+ var _useState11 = (0, _react.useState)(""),
77
+ _useState12 = _slicedToArray(_useState11, 2),
78
+ submissionMessage = _useState12[0],
79
+ setSubmissionMessage = _useState12[1];
80
+
81
+ var _useState13 = (0, _react.useState)(false),
82
+ _useState14 = _slicedToArray(_useState13, 2),
83
+ submitted = _useState14[0],
84
+ setSubmitted = _useState14[1];
85
+
86
+ var _useState15 = (0, _react.useState)([]),
87
+ _useState16 = _slicedToArray(_useState15, 2),
88
+ files = _useState16[0],
89
+ _setFiles = _useState16[1];
90
+
91
+ var _useState17 = (0, _react.useState)(""),
92
+ _useState18 = _slicedToArray(_useState17, 2),
93
+ filesError = _useState18[0],
94
+ setFilesError = _useState18[1];
95
+
96
+ var _useState19 = (0, _react.useState)(""),
97
+ _useState20 = _slicedToArray(_useState19, 2),
98
+ zipcodeError = _useState20[0],
99
+ setZipcodeError = _useState20[1];
100
+
101
+ var _useState21 = (0, _react.useState)(""),
102
+ _useState22 = _slicedToArray(_useState21, 2),
103
+ availableToError = _useState22[0],
104
+ setAvailableToError = _useState22[1];
105
+
106
+ var _useState23 = (0, _react.useState)(""),
107
+ _useState24 = _slicedToArray(_useState23, 2),
108
+ captchaError = _useState24[0],
109
+ setCaptchaError = _useState24[1];
110
+
111
+ var _useState25 = (0, _react.useState)(false),
112
+ _useState26 = _slicedToArray(_useState25, 2),
113
+ showDeactivationModal = _useState26[0],
114
+ setShowDeactivationModal = _useState26[1];
115
+
116
+ var bedroomOptions = ["0", "1", "2", "3", "4"];
117
+ var isNewSublet = (0, _react.useCallback)(function () {
118
+ return uniqueId === NEW_SUBLET;
119
+ }, [uniqueId]);
120
+ var localCity = "Bloomington IN";
121
+ var maxFileSize = 4999999;
122
+ (0, _react.useEffect)(function () {
123
+ if (!isNewSublet()) {
124
+ (0, _SubletService.getSublet)(uniqueId).then(function (data) {
125
+ setSublet(data);
126
+ }).catch(function () {
127
+ setIsFound(false);
128
+ });
129
+ }
130
+ }, [uniqueId, isNewSublet]);
131
+
132
+ var isFileInvalid = function isFileInvalid(file) {
133
+ return file.size > maxFileSize;
134
+ };
135
+
136
+ var hasFileValidationError = function hasFileValidationError() {
137
+ var fileInvalid = false;
138
+ files.forEach(function (file, index) {
139
+ if (isFileInvalid(file)) {
140
+ setFilesError(file.name + " is too big, provide a file smaller than 5mb!");
141
+ setSubmissionErrorMessage("Fix field error(s)");
142
+ fileInvalid = true;
143
+ return;
144
+ }
145
+ });
146
+ return fileInvalid;
147
+ };
148
+
149
+ var submitHandler = function submitHandler(event) {
150
+ var form = event.currentTarget;
151
+ event.preventDefault();
152
+ event.stopPropagation();
153
+ resetMessages();
154
+
155
+ if (files.length === 0) {
156
+ setFilesError("Provide at least an image!");
157
+ setSubmissionErrorMessage("Fix field error(s)");
158
+ return;
159
+ }
160
+
161
+ if (form.checkValidity()) {
162
+ if (!(0, _Utils.isZipcodeValid)(sublet.zipcode)) {
163
+ setZipcodeError("Provide valid zip code (ex: 47401)");
164
+ setSubmissionErrorMessage("Fix field error(s)");
165
+ return;
166
+ }
167
+
168
+ if ((0, _Utils.dateToMoment)(sublet.availableFrom).isAfter((0, _Utils.dateToMoment)(sublet.availableTo))) {
169
+ setAvailableToError("Should be later than Available From date");
170
+ setSubmissionErrorMessage("Fix field error(s)");
171
+ return;
172
+ }
173
+
174
+ if (captchaResponse === "") {
175
+ setCaptchaError("Provide captcha");
176
+ setSubmissionErrorMessage("Fix field error(s)");
177
+ return;
178
+ }
179
+
180
+ if (hasFileValidationError()) {
181
+ return;
182
+ }
183
+
184
+ setIsSubmitting(true);
185
+ (0, _SubletService.postSublet)(_objectSpread(_objectSpread({}, sublet), {}, {
186
+ address: sublet.address + ", " + localCity
187
+ }), captchaResponse).then(function (value) {
188
+ setSublet(value);
189
+
190
+ if (files.length > 1) {
191
+ files.push(files[0]);
192
+ }
193
+
194
+ files.forEach(function (file, index) {
195
+ setIsSubmitting(true);
196
+ (0, _SubletService.postAsset)(value.assetKey, file, index + "", index === 0).finally(function () {
197
+ setIsSubmitting(false);
198
+ });
199
+ });
200
+ setSubmissionMessage("Sublet Posted!");
201
+ setSubmitted(true);
202
+ }).catch(function (e) {
203
+ setSubmissionErrorMessage("Error posting sublet!");
204
+ console.log(e);
205
+ }).finally(function () {
206
+ setIsSubmitting(false);
207
+ });
208
+ }
209
+ };
210
+
211
+ var resetMessages = function resetMessages() {
212
+ setAvailableToError("");
213
+ setZipcodeError("");
214
+ setCaptchaError("");
215
+ setFilesError("");
216
+ setSubmissionErrorMessage("");
217
+ };
218
+
219
+ var cleanAddress = function cleanAddress(address) {
220
+ return address.replace(", " + localCity, "");
221
+ };
222
+
223
+ var handleDeleteConfirmation = function handleDeleteConfirmation() {
224
+ (0, _SubletService.deleteSublet)(uniqueId).then(function () {
225
+ setSubmissionMessage("Sublet Deleted!");
226
+ setSubmitted(true);
227
+ }).catch(function (e) {
228
+ setSubmissionErrorMessage("Error deleting sublet!");
229
+ console.log(e);
230
+ }).finally(function () {
231
+ setIsSubmitting(false);
232
+ });
233
+ };
234
+
235
+ return /*#__PURE__*/_react.default.createElement("section", {
236
+ className: "section-sublet"
237
+ }, isFound ? /*#__PURE__*/_react.default.createElement("section", {
238
+ className: "section-contact"
239
+ }, /*#__PURE__*/_react.default.createElement("div", {
240
+ className: "div-confirmation-modal"
241
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Modal, {
242
+ show: showDeactivationModal,
243
+ setShow: setShowDeactivationModal
244
+ }, /*#__PURE__*/_react.default.createElement("div", {
245
+ className: "div-alert"
246
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
247
+ name: "alert",
248
+ size: "medium"
249
+ }, "Delete Sublet?")), /*#__PURE__*/_react.default.createElement("div", {
250
+ className: "buttons"
251
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
252
+ variant: "danger",
253
+ size: "small",
254
+ onClick: function onClick() {
255
+ handleDeleteConfirmation();
256
+ setShowDeactivationModal(false);
257
+ }
258
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
259
+ name: "trash"
260
+ }, "Delete")), /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
261
+ variant: "secondary",
262
+ size: "small",
263
+ onClick: function onClick() {
264
+ return setShowDeactivationModal(false);
265
+ }
266
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
267
+ name: "close"
268
+ }, "Cancel"))))), /*#__PURE__*/_react.default.createElement("div", {
269
+ className: "container"
270
+ }, /*#__PURE__*/_react.default.createElement("h2", {
271
+ className: "heading"
272
+ }, isNewSublet() ? /*#__PURE__*/_react.default.createElement("span", {
273
+ className: "emphasized"
274
+ }, "Post your sublet for free. Listing remains active for 30 days") : /*#__PURE__*/_react.default.createElement("span", {
275
+ className: "emphasized"
276
+ }, "Your Listing")), /*#__PURE__*/_react.default.createElement("form", {
277
+ onSubmit: submitHandler
278
+ }, /*#__PURE__*/_react.default.createElement("div", {
279
+ className: "form-element"
280
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
281
+ label: "First Name",
282
+ name: "firstName",
283
+ icon: "user",
284
+ type: "text",
285
+ placeholder: "Type your first name",
286
+ readOnly: !isNewSublet(),
287
+ value: sublet.firstName,
288
+ onChange: function onChange(e) {
289
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
290
+ firstName: e.currentTarget.value
291
+ }));
292
+ },
293
+ required: true
294
+ })), /*#__PURE__*/_react.default.createElement("div", {
295
+ className: "form-element"
296
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
297
+ label: "Last Name",
298
+ name: "lastName",
299
+ icon: "user",
300
+ type: "text",
301
+ placeholder: "Type your last name",
302
+ value: sublet.lastName,
303
+ readOnly: !isNewSublet(),
304
+ onChange: function onChange(e) {
305
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
306
+ lastName: e.currentTarget.value
307
+ }));
308
+ },
309
+ required: true
310
+ })), /*#__PURE__*/_react.default.createElement("div", {
311
+ className: "form-element"
312
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
313
+ label: "Email",
314
+ name: "email",
315
+ icon: "mail",
316
+ type: "email",
317
+ placeholder: "Type your email",
318
+ value: sublet.email,
319
+ readOnly: !isNewSublet(),
320
+ onChange: function onChange(e) {
321
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
322
+ email: e.currentTarget.value
323
+ }));
324
+ },
325
+ required: true
326
+ })), /*#__PURE__*/_react.default.createElement("div", {
327
+ className: "form-element"
328
+ }, /*#__PURE__*/_react.default.createElement("p", null, "Your personal information is for verification purposes only and will not be displayed.")), /*#__PURE__*/_react.default.createElement("div", {
329
+ className: "form-element one-line"
330
+ }, /*#__PURE__*/_react.default.createElement("select", {
331
+ name: "availableBedrooms",
332
+ value: sublet.availableBedrooms,
333
+ onChange: function onChange(e) {
334
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
335
+ availableBedrooms: e.currentTarget.value
336
+ }));
337
+ },
338
+ required: true,
339
+ disabled: !isNewSublet()
340
+ }, bedroomOptions.map(function (option, i) {
341
+ return /*#__PURE__*/_react.default.createElement("option", {
342
+ key: "select-option-" + i,
343
+ value: option
344
+ }, option);
345
+ })), "\xA0 bedroom(s) available out of ", /*#__PURE__*/_react.default.createElement("select", {
346
+ name: "bedroom",
347
+ required: true,
348
+ value: sublet.bedroom,
349
+ onChange: function onChange(e) {
350
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
351
+ bedroom: e.currentTarget.value
352
+ }));
353
+ },
354
+ disabled: !isNewSublet()
355
+ }, bedroomOptions.map(function (option, i) {
356
+ return /*#__PURE__*/_react.default.createElement("option", {
357
+ key: "select-option-" + i,
358
+ value: option
359
+ }, option);
360
+ })), "\xA0bedrooms."), /*#__PURE__*/_react.default.createElement("div", {
361
+ className: "form-element"
362
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
363
+ label: "Address",
364
+ name: "address",
365
+ icon: "map",
366
+ type: "text",
367
+ value: cleanAddress(sublet.address),
368
+ onChange: function onChange(e) {
369
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
370
+ address: cleanAddress(e.currentTarget.value)
371
+ }));
372
+ },
373
+ readOnly: !isNewSublet(),
374
+ required: true
375
+ })), /*#__PURE__*/_react.default.createElement("div", {
376
+ className: "form-element"
377
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
378
+ name: "address",
379
+ icon: "map",
380
+ type: "text",
381
+ readOnly: true,
382
+ value: localCity
383
+ })), /*#__PURE__*/_react.default.createElement("div", {
384
+ className: "form-element"
385
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
386
+ label: "Zip Code",
387
+ name: "zipcode",
388
+ icon: "map",
389
+ value: sublet.zipcode,
390
+ onChange: function onChange(e) {
391
+ return setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
392
+ zipcode: e.currentTarget.value
393
+ }));
394
+ },
395
+ readOnly: !isNewSublet(),
396
+ error: zipcodeError,
397
+ placeholder: "Provide Zip Code (ex: 47404)",
398
+ required: true
399
+ })), /*#__PURE__*/_react.default.createElement("div", {
400
+ className: "form-element"
401
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
402
+ label: "Available From",
403
+ name: "availableFrom",
404
+ type: "date",
405
+ icon: "calendar",
406
+ value: sublet.availableFrom,
407
+ onChange: function onChange(e) {
408
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
409
+ availableFrom: e.currentTarget.value
410
+ }));
411
+ },
412
+ readOnly: !isNewSublet(),
413
+ required: true
414
+ })), /*#__PURE__*/_react.default.createElement("div", {
415
+ className: "form-element"
416
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
417
+ label: "Available To",
418
+ name: "availableTo",
419
+ type: "date",
420
+ icon: "calendar",
421
+ value: sublet.availableTo,
422
+ onChange: function onChange(e) {
423
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
424
+ availableTo: e.currentTarget.value
425
+ }));
426
+ },
427
+ readOnly: !isNewSublet(),
428
+ required: true,
429
+ error: availableToError
430
+ })), /*#__PURE__*/_react.default.createElement("div", {
431
+ className: "form-element"
432
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
433
+ label: "Rent",
434
+ name: "rent",
435
+ type: "number",
436
+ value: sublet.rent,
437
+ onChange: function onChange(e) {
438
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
439
+ rent: e.currentTarget.value
440
+ }));
441
+ },
442
+ readOnly: !isNewSublet(),
443
+ required: true
444
+ })), /*#__PURE__*/_react.default.createElement("div", {
445
+ className: "checkboxes form-element"
446
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Checkbox, {
447
+ label: "Including Utilities",
448
+ name: "utilitiesIncluded",
449
+ checked: sublet.utilitiesIncluded,
450
+ onChange: function onChange() {
451
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
452
+ utilitiesIncluded: !sublet.utilitiesIncluded
453
+ }));
454
+ }
455
+ }), /*#__PURE__*/_react.default.createElement(_muncherUi.Checkbox, {
456
+ label: "Pets OK",
457
+ name: "petsAllowed",
458
+ checked: sublet.petsAllowed,
459
+ onChange: function onChange() {
460
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
461
+ petsAllowed: !sublet.petsAllowed
462
+ }));
463
+ }
464
+ })), /*#__PURE__*/_react.default.createElement("div", {
465
+ className: "form-element"
466
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Input, {
467
+ label: "Title",
468
+ name: "title",
469
+ type: "text",
470
+ value: sublet.title,
471
+ onChange: function onChange(e) {
472
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
473
+ title: e.currentTarget.value
474
+ }));
475
+ },
476
+ maxLength: 50,
477
+ placeholder: "Listing title",
478
+ readOnly: !isNewSublet(),
479
+ required: true
480
+ })), /*#__PURE__*/_react.default.createElement("div", {
481
+ className: "form-element"
482
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Textarea, {
483
+ name: "description",
484
+ label: "Description",
485
+ required: true,
486
+ onChange: function onChange(e) {
487
+ setSublet(_objectSpread(_objectSpread({}, sublet), {}, {
488
+ description: e.currentTarget.value
489
+ }));
490
+ },
491
+ placeholder: "Enter a description of the rental you are subleasing",
492
+ maxLength: 500,
493
+ value: sublet.description,
494
+ readOnly: !isNewSublet()
495
+ })), /*#__PURE__*/_react.default.createElement("br", null), isNewSublet() ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
496
+ className: "form-element"
497
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.ImageInput, {
498
+ label: "Upload Images",
499
+ multiple: true,
500
+ name: "imageFiles",
501
+ required: true,
502
+ maxFiles: 5,
503
+ setFiles: function setFiles(data) {
504
+ _setFiles(data);
505
+ },
506
+ error: filesError
507
+ }), /*#__PURE__*/_react.default.createElement("div", {
508
+ className: "info"
509
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
510
+ name: "info"
511
+ }, "Upto 5 images. First image will be cover image."))), /*#__PURE__*/_react.default.createElement(_Captcha.Captcha, {
512
+ setCaptchaResponse: setCaptchaResponse,
513
+ error: captchaError
514
+ })) : "", /*#__PURE__*/_react.default.createElement("div", {
515
+ className: "form-element"
516
+ }, submissionMessage !== "" ? /*#__PURE__*/_react.default.createElement("p", {
517
+ className: "text-success message"
518
+ }, submissionMessage) : "", submissionErrorMessage !== "" ? /*#__PURE__*/_react.default.createElement("p", {
519
+ className: "text-danger message"
520
+ }, submissionErrorMessage) : ""), /*#__PURE__*/_react.default.createElement("div", {
521
+ className: "form-element form-submit"
522
+ }, isNewSublet() ? /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
523
+ variant: "primary",
524
+ size: "large",
525
+ type: "submit",
526
+ disabled: submitted
527
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
528
+ name: "send",
529
+ orientation: "right"
530
+ }, "Submit")) : /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
531
+ variant: "danger",
532
+ size: "large",
533
+ type: "button",
534
+ disabled: submitted,
535
+ onClick: function onClick() {
536
+ setShowDeactivationModal(true);
537
+ }
538
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
539
+ name: "trash",
540
+ orientation: "right"
541
+ }, "Delete")), isSubmitting ? /*#__PURE__*/_react.default.createElement(_muncherUi.Spinner, {
542
+ size: "small"
543
+ }) : "")))) : /*#__PURE__*/_react.default.createElement(_SubletNotFound.SubletNotFound, null));
544
+ };
545
+
546
+ exports.SubletSection = SubletSection;
547
+ var NEW_SUBLET = "new";
548
+ exports.NEW_SUBLET = NEW_SUBLET;
549
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SubletSection","uniqueId","useState","defaultSublet","sublet","setSublet","isFound","setIsFound","captchaResponse","setCaptchaResponse","isSubmitting","setIsSubmitting","submissionErrorMessage","setSubmissionErrorMessage","submissionMessage","setSubmissionMessage","submitted","setSubmitted","files","setFiles","filesError","setFilesError","zipcodeError","setZipcodeError","availableToError","setAvailableToError","captchaError","setCaptchaError","showDeactivationModal","setShowDeactivationModal","bedroomOptions","isNewSublet","useCallback","NEW_SUBLET","localCity","maxFileSize","useEffect","getSublet","then","data","catch","isFileInvalid","file","size","hasFileValidationError","fileInvalid","forEach","index","name","submitHandler","event","form","currentTarget","preventDefault","stopPropagation","resetMessages","length","checkValidity","isZipcodeValid","zipcode","dateToMoment","availableFrom","isAfter","availableTo","postSublet","address","value","push","postAsset","assetKey","finally","e","console","log","cleanAddress","replace","handleDeleteConfirmation","deleteSublet","firstName","lastName","email","availableBedrooms","map","option","i","bedroom","rent","utilitiesIncluded","petsAllowed","title","description"],"sources":["../../src/sublet/SubletSection.tsx"],"sourcesContent":["import React, {useCallback, useEffect, useState} from \"react\";\nimport \"./assets/SubletSection.scss\";\nimport {Button, Checkbox, Icon, ImageInput, Input, Modal, Spinner, Textarea} from \"@contentmunch/muncher-ui\";\nimport {defaultSublet, Sublet} from \"./data/Sublet\";\nimport {deleteSublet, getSublet, postAsset, postSublet} from \"./services/SubletService\";\nimport {SubletNotFound} from \"./SubletNotFound\";\nimport {dateToMoment, isZipcodeValid} from \"../utils/Utils\";\nimport {Captcha} from \"../input/Captcha\";\n\nexport const SubletSection: React.FC<SubletSectionParam> = ({uniqueId}) => {\n    const [sublet, setSublet] = useState<Sublet>(defaultSublet);\n    const [isFound, setIsFound] = useState<boolean>(true);\n    const [captchaResponse, setCaptchaResponse] = useState(\"\");\n    const [isSubmitting, setIsSubmitting] = useState(false);\n    const [submissionErrorMessage, setSubmissionErrorMessage] = useState(\"\");\n    const [submissionMessage, setSubmissionMessage] = useState(\"\");\n    const [submitted, setSubmitted] = useState(false);\n    const [files, setFiles] = useState<File[]>([]);\n    const [filesError, setFilesError] = useState(\"\");\n    const [zipcodeError, setZipcodeError] = useState(\"\");\n    const [availableToError, setAvailableToError] = useState(\"\");\n    const [captchaError, setCaptchaError] = useState(\"\");\n    const [showDeactivationModal, setShowDeactivationModal] = useState(false);\n    const bedroomOptions = [\"0\", \"1\", \"2\", \"3\", \"4\"];\n    const isNewSublet = useCallback(() => uniqueId === NEW_SUBLET, [uniqueId]);\n    const localCity = \"Bloomington IN\";\n    const maxFileSize = 4999999;\n    useEffect(() => {\n        if (!isNewSublet()) {\n            getSublet(uniqueId).then(data => {\n                setSublet(data);\n            }).catch(() => {\n                setIsFound(false);\n            });\n        }\n    }, [uniqueId, isNewSublet]);\n    const isFileInvalid = (file: File) => file.size > maxFileSize;\n\n    const hasFileValidationError = (): boolean => {\n        let fileInvalid = false;\n        files.forEach((file, index) => {\n            if (isFileInvalid(file)) {\n                setFilesError(file.name + \" is too big, provide a file smaller than 5mb!\");\n                setSubmissionErrorMessage(\"Fix field error(s)\");\n                fileInvalid = true;\n                return;\n            }\n        });\n        return fileInvalid;\n    };\n    const submitHandler = (event: React.FormEvent<HTMLFormElement>) => {\n\n        const form = event.currentTarget;\n        event.preventDefault();\n        event.stopPropagation();\n        resetMessages();\n\n        if (files.length === 0) {\n            setFilesError(\"Provide at least an image!\");\n            setSubmissionErrorMessage(\"Fix field error(s)\");\n            return;\n        }\n        if (form.checkValidity()) {\n\n            if (!isZipcodeValid(sublet.zipcode)) {\n                setZipcodeError(\"Provide valid zip code (ex: 47401)\");\n                setSubmissionErrorMessage(\"Fix field error(s)\");\n                return;\n            }\n\n            if (dateToMoment(sublet.availableFrom).isAfter(dateToMoment(sublet.availableTo))) {\n                setAvailableToError(\"Should be later than Available From date\");\n                setSubmissionErrorMessage(\"Fix field error(s)\");\n                return;\n            }\n            if (captchaResponse === \"\") {\n                setCaptchaError(\"Provide captcha\");\n                setSubmissionErrorMessage(\"Fix field error(s)\");\n                return;\n            }\n\n            if (hasFileValidationError()) {\n                return;\n            }\n            setIsSubmitting(true);\n            postSublet({...sublet, address: sublet.address + \", \" + localCity}, captchaResponse)\n                .then((value) => {\n                    setSublet(value);\n                    if (files.length > 1) {\n                        files.push(files[0]);\n                    }\n                    files.forEach((file, index) => {\n                        setIsSubmitting(true);\n                        postAsset(value.assetKey, file, index + \"\", index === 0)\n                            .finally(() => {\n                                setIsSubmitting(false);\n                            });\n                    });\n                    setSubmissionMessage(\"Sublet Posted!\");\n                    setSubmitted(true);\n                })\n                .catch((e: any) => {\n                    setSubmissionErrorMessage(\"Error posting sublet!\");\n                    console.log(e);\n                }).finally(() => {\n                setIsSubmitting(false);\n            });\n\n\n        }\n    }\n    const resetMessages = () => {\n        setAvailableToError(\"\");\n        setZipcodeError(\"\");\n        setCaptchaError(\"\");\n        setFilesError(\"\");\n        setSubmissionErrorMessage(\"\");\n    };\n\n    const cleanAddress = (address: string) => address.replace(\", \" + localCity, \"\");\n\n    const handleDeleteConfirmation = () => {\n        deleteSublet(uniqueId).then(() => {\n            setSubmissionMessage(\"Sublet Deleted!\");\n            setSubmitted(true);\n        }).catch((e: any) => {\n            setSubmissionErrorMessage(\"Error deleting sublet!\");\n            console.log(e);\n        }).finally(() => {\n            setIsSubmitting(false);\n        });\n    }\n    return (\n        <section className=\"section-sublet\">\n            {isFound ?\n                <section className=\"section-contact\">\n                    <div className=\"div-confirmation-modal\">\n                        <Modal show={showDeactivationModal} setShow={setShowDeactivationModal}>\n                            <div className=\"div-alert\">\n                                <Icon name=\"alert\" size=\"medium\">Delete Sublet?</Icon>\n                            </div>\n\n                            <div className=\"buttons\">\n                                <Button variant=\"danger\" size=\"small\"\n                                        onClick={() => {\n                                            handleDeleteConfirmation();\n                                            setShowDeactivationModal(false);\n                                        }}>\n\n                                    <Icon name=\"trash\">Delete</Icon>\n                                </Button>\n                                <Button variant=\"secondary\" size=\"small\"\n                                        onClick={() => setShowDeactivationModal(false)}>\n                                    <Icon name=\"close\">Cancel</Icon>\n                                </Button>\n                            </div>\n                        </Modal>\n                    </div>\n                    <div className=\"container\">\n                        <h2 className=\"heading\">\n                            {isNewSublet() ?\n                                <span className=\"emphasized\">Post your sublet for free. Listing remains active for 30 days</span>\n                                :\n                                <span\n                                    className=\"emphasized\">Your Listing</span>\n                            }\n                        </h2>\n\n                        <form onSubmit={submitHandler}>\n                            <div className=\"form-element\">\n                                <Input label=\"First Name\" name=\"firstName\" icon=\"user\" type=\"text\"\n                                       placeholder=\"Type your first name\"\n                                       readOnly={!isNewSublet()}\n                                       value={sublet.firstName}\n                                       onChange={e => {\n                                           setSublet({...sublet, firstName: e.currentTarget.value})\n                                       }}\n                                       required/>\n                            </div>\n                            <div className=\"form-element\">\n                                <Input label=\"Last Name\" name=\"lastName\" icon=\"user\" type=\"text\"\n                                       placeholder=\"Type your last name\"\n                                       value={sublet.lastName}\n                                       readOnly={!isNewSublet()}\n                                       onChange={e => {\n                                           setSublet({...sublet, lastName: e.currentTarget.value})\n                                       }}\n                                       required/>\n                            </div>\n\n                            <div className=\"form-element\">\n                                <Input label=\"Email\" name=\"email\" icon=\"mail\" type=\"email\"\n                                       placeholder=\"Type your email\"\n                                       value={sublet.email}\n                                       readOnly={!isNewSublet()}\n                                       onChange={e => {\n                                           setSublet({...sublet, email: e.currentTarget.value})\n                                       }}\n                                       required/>\n                            </div>\n                            <div className=\"form-element\">\n                                <p>Your personal information is for verification purposes only and will not be\n                                    displayed.</p>\n                            </div>\n                            <div className=\"form-element one-line\">\n                                <select name=\"availableBedrooms\"\n                                        value={sublet.availableBedrooms}\n\n                                        onChange={e => {\n                                            setSublet({...sublet, availableBedrooms: e.currentTarget.value})\n                                        }}\n                                        required={true}\n                                        disabled={!isNewSublet()}\n                                >\n                                    {\n                                        bedroomOptions.map((option, i) =>\n                                            <option key={\"select-option-\" + i} value={option}>{option}</option>)\n                                    }\n                                </select>\n\n                                &nbsp; bedroom(s) available out of <select name=\"bedroom\"\n                                                                           required={true}\n                                                                           value={sublet.bedroom}\n                                                                           onChange={e => {\n                                                                               setSublet({\n                                                                                   ...sublet,\n                                                                                   bedroom: e.currentTarget.value\n                                                                               })\n                                                                           }}\n                                                                           disabled={!isNewSublet()}\n                            >\n                                {\n                                    bedroomOptions.map((option, i) =>\n                                        <option key={\"select-option-\" + i} value={option}>{option}</option>)\n                                }\n                            </select>\n                                &nbsp;bedrooms.\n                            </div>\n                            <div className=\"form-element\">\n                                <Input label=\"Address\" name=\"address\" icon=\"map\" type=\"text\"\n                                       value={cleanAddress(sublet.address)}\n                                       onChange={e => {\n                                           setSublet({...sublet, address: cleanAddress(e.currentTarget.value)})\n                                       }}\n                                       readOnly={!isNewSublet()}\n                                       required/>\n                            </div>\n                            <div className=\"form-element\">\n                                <Input name=\"address\" icon=\"map\" type=\"text\" readOnly={true}\n                                       value={localCity}/>\n                            </div>\n                            <div className=\"form-element\">\n                                <Input label=\"Zip Code\" name=\"zipcode\" icon=\"map\"\n                                       value={sublet.zipcode}\n                                       onChange={(e) => setSublet({\n                                           ...sublet,\n                                           zipcode: e.currentTarget.value\n                                       })}\n                                       readOnly={!isNewSublet()}\n                                       error={zipcodeError}\n                                       placeholder=\"Provide Zip Code (ex: 47404)\"\n                                       required\n                                />\n\n                            </div>\n\n                            <div className=\"form-element\">\n                                <Input label=\"Available From\" name=\"availableFrom\"\n                                       type=\"date\" icon=\"calendar\"\n                                       value={sublet.availableFrom}\n                                       onChange={(e) => {\n                                           setSublet({...sublet, availableFrom: e.currentTarget.value});\n                                       }}\n                                       readOnly={!isNewSublet()}\n                                       required\n                                />\n                            </div>\n                            <div className=\"form-element\">\n                                <Input label=\"Available To\" name=\"availableTo\"\n                                       type=\"date\" icon=\"calendar\"\n                                       value={sublet.availableTo}\n                                       onChange={(e) => {\n                                           setSublet({...sublet, availableTo: e.currentTarget.value});\n                                       }}\n                                       readOnly={!isNewSublet()}\n                                       required\n                                       error={availableToError}\n                                />\n                            </div>\n\n                            <div className=\"form-element\">\n                                <Input label=\"Rent\" name=\"rent\" type=\"number\"\n                                       value={sublet.rent}\n                                       onChange={(e) => {\n                                           setSublet({...sublet, rent: e.currentTarget.value});\n                                       }}\n                                       readOnly={!isNewSublet()}\n                                       required/>\n                            </div>\n                            <div className=\"checkboxes form-element\">\n                                <Checkbox label=\"Including Utilities\" name=\"utilitiesIncluded\"\n                                          checked={sublet.utilitiesIncluded}\n                                          onChange={() => {\n                                              setSublet({\n                                                  ...sublet,\n                                                  utilitiesIncluded: !sublet.utilitiesIncluded\n                                              });\n                                          }}\n\n                                />\n                                <Checkbox label=\"Pets OK\" name=\"petsAllowed\"\n                                          checked={sublet.petsAllowed}\n                                          onChange={() => {\n                                              setSublet({\n                                                  ...sublet,\n                                                  petsAllowed: !sublet.petsAllowed\n                                              });\n                                          }}\n                                />\n                            </div>\n\n                            <div className=\"form-element\">\n                                <Input label=\"Title\" name=\"title\"  type=\"text\"\n                                       value={sublet.title}\n                                       onChange={e => {\n                                           setSublet({...sublet, title: e.currentTarget.value})\n                                       }}\n                                       maxLength={50}\n                                       placeholder=\"Listing title\"\n                                       readOnly={!isNewSublet()}\n                                       required/>\n                            </div>\n\n                            <div className=\"form-element\">\n                                <Textarea\n                                    name=\"description\"\n                                    label=\"Description\"\n                                    required={true}\n                                    onChange={(e) => {\n                                        setSublet({...sublet, description: e.currentTarget.value});\n                                    }}\n                                    placeholder=\"Enter a description of the rental you are subleasing\"\n                                    maxLength={500}\n                                    value={sublet.description}\n                                    readOnly={!isNewSublet()}\n\n                                />\n                            </div>\n                            <br/>\n                            {isNewSublet() ?\n                                <>\n                                    <div className=\"form-element\">\n\n                                        <ImageInput\n                                            label=\"Upload Images\"\n                                            multiple\n                                            name=\"imageFiles\"\n                                            required\n                                            maxFiles={5}\n                                            setFiles={data => {\n                                                setFiles(data);\n                                            }}\n                                            error={filesError}\n\n                                        />\n                                        <div className=\"info\"><Icon name=\"info\">Upto 5 images. First image will be cover\n                                            image.</Icon></div>\n                                    </div>\n                                    <Captcha setCaptchaResponse={setCaptchaResponse} error={captchaError}/>\n                                </>\n                                : \"\"\n\n                            }\n\n\n                            <div className=\"form-element\">\n                                {submissionMessage !== \"\" ?\n                                    <p className=\"text-success message\">{submissionMessage}</p> : \"\"}\n                                {submissionErrorMessage !== \"\" ?\n                                    <p className=\"text-danger message\">{submissionErrorMessage}</p> : \"\"}\n                            </div>\n\n                            <div className=\"form-element form-submit\">\n                                {isNewSublet() ?\n                                    <Button variant=\"primary\" size=\"large\" type=\"submit\" disabled={submitted}>\n                                        <Icon name=\"send\" orientation=\"right\">Submit</Icon>\n\n                                    </Button>\n                                    :\n                                    <Button variant=\"danger\" size=\"large\" type=\"button\" disabled={submitted}\n                                            onClick={() => {\n                                                setShowDeactivationModal(true)\n                                            }}\n                                    >\n                                        <Icon name=\"trash\" orientation=\"right\">Delete</Icon>\n                                    </Button>\n                                }\n                                {isSubmitting ? <Spinner size=\"small\"/> : \"\"}\n                            </div>\n\n                        </form>\n                    </div>\n\n                </section>\n                :\n                <SubletNotFound/>\n            }\n        </section>\n    );\n}\n\nexport const NEW_SUBLET = \"new\";\n\nexport interface SubletSectionParam {\n    uniqueId: string\n}"],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import React from "react";
2
+ import "./assets/SubletsSection.scss";
3
+ export declare const SubletsSection: React.FC<SubletsSectionProps>;
4
+ export interface SubletsSectionProps {
5
+ linkToSubletCreatePage: string;
6
+ }