favesalon-embed 1.0.5 → 1.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/dist/custom-elements/index.d.ts +36 -0
  2. package/dist/favesalon-embed/activate-form.entry.js +70 -0
  3. package/dist/favesalon-embed/change-password-form.entry.js +81 -0
  4. package/dist/favesalon-embed/chat-box.entry.js +1 -1
  5. package/dist/favesalon-embed/chat-button.entry.js +43 -12
  6. package/dist/favesalon-embed/chat-form.entry.js +1 -1
  7. package/dist/favesalon-embed/chat-messages.entry.js +1 -1
  8. package/dist/favesalon-embed/chat-rooms.entry.js +1 -1
  9. package/dist/favesalon-embed/favesalon-embed.esm.js +1 -1
  10. package/dist/favesalon-embed/login-form.entry.js +67 -0
  11. package/dist/favesalon-embed/notify-sounds.entry.js +1 -1
  12. package/dist/favesalon-embed/register-form.entry.js +88 -0
  13. package/dist/favesalon-embed/reset-password-form.entry.js +47 -0
  14. package/dist/favesalon-embed/salon-booking.entry.js +1 -1
  15. package/dist/favesalon-embed/salon-gift-card.entry.js +1 -1
  16. package/dist/favesalon-embed/salon-info.entry.js +1 -1
  17. package/dist/favesalon-embed/salon-latest-reviews.entry.js +19 -3
  18. package/dist/favesalon-embed/salon-latest-styles.entry.js +14 -7
  19. package/dist/favesalon-embed/salon-locations.entry.js +1 -1
  20. package/dist/favesalon-embed/salon-lookbook.entry.js +16 -4
  21. package/dist/favesalon-embed/salon-reviews.entry.js +18 -4
  22. package/dist/favesalon-embed/salon-schedules.entry.js +1 -1
  23. package/dist/favesalon-embed/salon-services.entry.js +23 -11
  24. package/dist/favesalon-embed/salon-stylists.entry.js +1 -1
  25. package/dist/favesalon-embed/{services-260ea6eb.js → services-d71be591.js} +36 -0
  26. package/dist/favesalon-embed/style-detail.entry.js +26 -8
  27. package/dist/favesalon-embed/user-avatar.entry.js +3 -1
  28. package/dist/favesalon-embed/user-form.entry.js +44 -0
  29. package/dist/types/components/activate-form/activate-form.d.ts +12 -0
  30. package/dist/types/components/change-password-form/change-password-form.d.ts +12 -0
  31. package/dist/types/components/chat-button/index.d.ts +6 -2
  32. package/dist/types/components/login-form/login-form.d.ts +10 -0
  33. package/dist/types/components/register-form/register-form.d.ts +13 -0
  34. package/dist/types/components/reset-password-form/reset-password-form.d.ts +9 -0
  35. package/dist/types/components/user-form/user-form.d.ts +7 -0
  36. package/dist/types/components.d.ts +106 -2
  37. package/dist/types/services/services.d.ts +16 -0
  38. package/dist/types/types/user.d.ts +6 -0
  39. package/package.json +1 -1
  40. package/dist/favesalon-embed/services-122dcf73.js +0 -23886
  41. package/dist/favesalon-embed/services-23eda072.js +0 -23877
  42. package/dist/favesalon-embed/services-243eef47.js +0 -23880
  43. package/dist/favesalon-embed/services-27607998.js +0 -23886
  44. package/dist/favesalon-embed/services-46b2f0aa.js +0 -23867
  45. package/dist/favesalon-embed/services-65a8cf4a.js +0 -23887
  46. package/dist/favesalon-embed/services-8f52210f.js +0 -23880
  47. package/dist/favesalon-embed/services-de32365e.js +0 -23880
  48. package/dist/favesalon-embed/services-e9cfcd2b.js +0 -23885
  49. package/dist/favesalon-embed/services-f7278483.js +0 -23880
  50. package/dist/favesalon-embed/services-f9872bea.js +0 -23880
  51. package/dist/favesalon-embed/utils-2c19db45.js +0 -25
  52. package/dist/favesalon-embed/utils-89c2cff2.js +0 -32
  53. package/dist/favesalon-embed/utils-e226fa04.js +0 -32
@@ -2,6 +2,18 @@
2
2
 
3
3
  import type { Components, JSX } from "../types/components";
4
4
 
5
+ interface ActivateForm extends Components.ActivateForm, HTMLElement {}
6
+ export const ActivateForm: {
7
+ prototype: ActivateForm;
8
+ new (): ActivateForm;
9
+ };
10
+
11
+ interface ChangePasswordForm extends Components.ChangePasswordForm, HTMLElement {}
12
+ export const ChangePasswordForm: {
13
+ prototype: ChangePasswordForm;
14
+ new (): ChangePasswordForm;
15
+ };
16
+
5
17
  interface ChatBox extends Components.ChatBox, HTMLElement {}
6
18
  export const ChatBox: {
7
19
  prototype: ChatBox;
@@ -38,12 +50,30 @@ export const GoogleMap: {
38
50
  new (): GoogleMap;
39
51
  };
40
52
 
53
+ interface LoginForm extends Components.LoginForm, HTMLElement {}
54
+ export const LoginForm: {
55
+ prototype: LoginForm;
56
+ new (): LoginForm;
57
+ };
58
+
41
59
  interface NotifySounds extends Components.NotifySounds, HTMLElement {}
42
60
  export const NotifySounds: {
43
61
  prototype: NotifySounds;
44
62
  new (): NotifySounds;
45
63
  };
46
64
 
65
+ interface RegisterForm extends Components.RegisterForm, HTMLElement {}
66
+ export const RegisterForm: {
67
+ prototype: RegisterForm;
68
+ new (): RegisterForm;
69
+ };
70
+
71
+ interface ResetPasswordForm extends Components.ResetPasswordForm, HTMLElement {}
72
+ export const ResetPasswordForm: {
73
+ prototype: ResetPasswordForm;
74
+ new (): ResetPasswordForm;
75
+ };
76
+
47
77
  interface SalonBooking extends Components.SalonBooking, HTMLElement {}
48
78
  export const SalonBooking: {
49
79
  prototype: SalonBooking;
@@ -140,6 +170,12 @@ export const UserAvatar: {
140
170
  new (): UserAvatar;
141
171
  };
142
172
 
173
+ interface UserForm extends Components.UserForm, HTMLElement {}
174
+ export const UserForm: {
175
+ prototype: UserForm;
176
+ new (): UserForm;
177
+ };
178
+
143
179
  /**
144
180
  * Utility to define all custom elements within this package using the tag name provided in the component's source.
145
181
  * When defining each custom element, it will also check it's safe to define by:
@@ -0,0 +1,70 @@
1
+ import { r as registerInstance, h } from './index-888e99e3.js';
2
+ import { C as Colors } from './colors-ea36347a.js';
3
+ import { H as HttpService } from './services-d71be591.js';
4
+ import './_commonjsHelpers-a4f66ccd.js';
5
+
6
+ const activateFormCss = ".form--user-activate-account .form--login-label{cursor:pointer;display:block;margin-bottom:6px}.form--user-activate-account input,.form--user-activate-account button{border:1px solid #cecece;box-sizing:border-box;display:inline-block;width:100%;padding:4px 11px;min-height:40px;-moz-transition:all 0.3s;-webkit-transition:all 0.3s;transition:all 0.3s;-moz-border-radius:6px;-webkit-border-radius:6px;border-radius:6px}.form--user-activate-account button{background-color:#001529;border:1px solid #001529;color:#fff;cursor:pointer}.form--user-activate-account button.btn--default{background-color:#fff;border:1px solid #F5F5F5;color:#141414}.form--user-activate-account button:disabled{background-color:#cecece;border:1px solid #cecece;color:#212121}";
7
+
8
+ const ActivateForm = class {
9
+ constructor(hostRef) {
10
+ registerInstance(this, hostRef);
11
+ this.username = undefined;
12
+ this.password = undefined;
13
+ this.onSuccess = undefined;
14
+ this.isSubmitting = undefined;
15
+ this.error = undefined;
16
+ this.confirmCode = undefined;
17
+ }
18
+ async onSubmit(evt) {
19
+ evt.preventDefault();
20
+ this.error = null;
21
+ this.isSubmitting = true;
22
+ if (this.username && this.confirmCode && this.password) {
23
+ try {
24
+ await HttpService().activateAccount(this.username, this.confirmCode);
25
+ const apiUrl = window.location.origin.indexOf('localhost') > -1 || window.location.origin.indexOf('favesalon.com') > -1
26
+ ? 'https://favesalon.com'
27
+ : window.location.origin;
28
+ const userInfo = await HttpService().login(apiUrl, {
29
+ email: this.username,
30
+ password: this.password,
31
+ });
32
+ this.onSuccess(userInfo);
33
+ }
34
+ catch (e) {
35
+ this.error = e.message || `Something went wrong when changing your new password`;
36
+ }
37
+ }
38
+ else {
39
+ this.error = 'Please enter your received code or password to change your password';
40
+ }
41
+ this.isSubmitting = false;
42
+ }
43
+ async resendCode(evt) {
44
+ evt.preventDefault();
45
+ this.error = null;
46
+ try {
47
+ await HttpService().resendActivateCode(this.username);
48
+ }
49
+ catch (e) {
50
+ this.error = e.message || `Something went wrong when sending the confirm code`;
51
+ }
52
+ }
53
+ render() {
54
+ return (h("form", { class: "form--user-activate-account", onSubmit: (evt) => this.onSubmit(evt) }, this.error && (h("div", { style: {
55
+ backgroundColor: Colors.Red01,
56
+ border: `1px solid ${Colors.Red02}`,
57
+ marginBottom: '24px',
58
+ padding: '12px',
59
+ } }, this.error)), h("div", { style: { marginBottom: '24px' } }, h("label", { ...{ for: "form--login-username" }, class: "form--login-label" }, "Confirmation code"), h("input", { id: "form--login-username", type: "text", onInput: (evt) => {
60
+ this.confirmCode = evt.target.value;
61
+ } })), h("div", { style: { marginBottom: '24px' } }, h("button", { type: "submit", disabled: this.isSubmitting }, "SUBMIT")), h("div", { style: { marginTop: '32px', marginBottom: '24px', textAlign: 'center' } }, "I didn\u2019t receive my confirmation code yet?"), h("div", { style: { marginBottom: '24px' } }, h("button", { class: "btn--default", style: {
62
+ backgrourColor: `${Colors.Gray02} !important`,
63
+ border: `1px solid ${Colors.Gray02} !important`,
64
+ color: `${Colors.TextColor} !important`,
65
+ }, onClick: (evt) => this.resendCode(evt) }, "Resend"))));
66
+ }
67
+ };
68
+ ActivateForm.style = activateFormCss;
69
+
70
+ export { ActivateForm as activate_form };
@@ -0,0 +1,81 @@
1
+ import { r as registerInstance, h } from './index-888e99e3.js';
2
+ import { C as Colors } from './colors-ea36347a.js';
3
+ import { H as HttpService } from './services-d71be591.js';
4
+ import './_commonjsHelpers-a4f66ccd.js';
5
+
6
+ const changePasswordFormCss = ".form--user-change-password .form--login-label{cursor:pointer;display:block;margin-bottom:6px}.form--user-change-password input,.form--user-change-password button{border:1px solid #cecece;box-sizing:border-box;display:inline-block;width:100%;padding:4px 11px;min-height:40px;-moz-transition:all 0.3s;-webkit-transition:all 0.3s;transition:all 0.3s;-moz-border-radius:6px;-webkit-border-radius:6px;border-radius:6px}.form--user-change-password button{background-color:#001529;border:1px solid #001529;color:#fff;cursor:pointer}.form--user-change-password button.btn--default{background-color:#fff;border:1px solid #F5F5F5;color:#141414}.form--user-change-password button:disabled{background-color:#cecece;border:1px solid #cecece;color:#212121}";
7
+
8
+ const ChangePasswordForm = class {
9
+ constructor(hostRef) {
10
+ registerInstance(this, hostRef);
11
+ this.username = undefined;
12
+ this.onSuccess = undefined;
13
+ this.isSubmitting = undefined;
14
+ this.error = undefined;
15
+ this.confirmCode = undefined;
16
+ this.password = undefined;
17
+ }
18
+ async onSubmit(evt) {
19
+ evt.preventDefault();
20
+ this.error = null;
21
+ this.isSubmitting = true;
22
+ if (this.username && this.confirmCode && this.password) {
23
+ try {
24
+ await HttpService().onChangePassword({
25
+ email: this.username,
26
+ password: this.password,
27
+ code: this.confirmCode,
28
+ });
29
+ const apiUrl = window.location.origin.indexOf('localhost') > -1 || window.location.origin.indexOf('favesalon.com') > -1
30
+ ? 'https://favesalon.com'
31
+ : window.location.origin;
32
+ const userInfo = await HttpService().login(apiUrl, {
33
+ email: this.username,
34
+ password: this.password,
35
+ });
36
+ this.onSuccess(userInfo);
37
+ }
38
+ catch (e) {
39
+ this.error = e.message || `Something went wrong when changing your new password`;
40
+ }
41
+ }
42
+ else {
43
+ this.error = 'Please enter your received code or password to change your password';
44
+ }
45
+ this.isSubmitting = false;
46
+ }
47
+ async resendCode(evt) {
48
+ evt.preventDefault();
49
+ this.error = null;
50
+ if (this.username) {
51
+ try {
52
+ await HttpService().resetPassword(this.username);
53
+ }
54
+ catch (e) {
55
+ this.error = e.message || `Something went wrong when sending the confirm code`;
56
+ }
57
+ }
58
+ else {
59
+ this.error = 'Please enter your phone or email to reset your password';
60
+ }
61
+ }
62
+ render() {
63
+ return (h("form", { class: "form--user-change-password", onSubmit: (evt) => this.onSubmit(evt) }, this.error && (h("div", { style: {
64
+ backgroundColor: Colors.Red01,
65
+ border: `1px solid ${Colors.Red02}`,
66
+ marginBottom: '24px',
67
+ padding: '12px',
68
+ } }, this.error)), h("div", { style: { marginBottom: '24px' } }, h("label", { ...{ for: "form--login-username" }, class: "form--login-label" }, "Confirmation code"), h("input", { id: "form--login-username", type: "text", onInput: (evt) => {
69
+ this.confirmCode = evt.target.value;
70
+ } })), h("div", { style: { marginBottom: '24px' } }, h("label", { ...{ for: "form--login-password" }, class: "form--login-label" }, "Password"), h("input", { id: "form--login-password", type: "password", onInput: (evt) => {
71
+ this.password = evt.target.value;
72
+ } })), h("div", { style: { marginBottom: '24px' } }, h("button", { type: "submit", disabled: this.isSubmitting }, "SAVE")), h("div", { style: { marginTop: '32px', marginBottom: '24px', textAlign: 'center' } }, "I didn\u2019t receive my confirmation code yet?"), h("div", { style: { marginBottom: '24px' } }, h("button", { class: "btn--default", style: {
73
+ backgrourColor: `${Colors.Gray02} !important`,
74
+ border: `1px solid ${Colors.Gray02} !important`,
75
+ color: `${Colors.TextColor} !important`,
76
+ }, onClick: (evt) => this.resendCode(evt) }, "Resend"))));
77
+ }
78
+ };
79
+ ChangePasswordForm.style = changePasswordFormCss;
80
+
81
+ export { ChangePasswordForm as change_password_form };
@@ -1,6 +1,6 @@
1
1
  import { r as registerInstance, h } from './index-888e99e3.js';
2
2
  import { C as Colors } from './colors-ea36347a.js';
3
- import { H as HttpService } from './services-260ea6eb.js';
3
+ import { H as HttpService } from './services-d71be591.js';
4
4
  import './_commonjsHelpers-a4f66ccd.js';
5
5
 
6
6
  const indexCss = ".chat-widget,.chat-widget--sidebar,.chat-widget--content{display:flex;height:100%;width:100%}.chat-widget{font-size:16px;position:relative;font-family:'Roboto', sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.chat-widget--sidebar,.chat-widget--content{background-color:#fff;border:1px solid #EFEFEF;position:absolute;inset:0;flex-direction:column}.chat-widget .chat-widget--sidebar{z-index:10}.chat-widget .chat-widget--content{z-index:5}.chat-widget.has-chat-room .chat-widget--content{z-index:10}.chat-widget--content-header{background-color:#001529;border-bottom:1px solid #EFEFEF;display:flex;align-items:center;justify-content:space-between;padding:16px}.chat-widget--content-title{font-size:20px;font-weight:600;line-height:1;margin:0}.chat-widget--content-close{border:1px solid #fff;cursor:pointer;display:block;position:absolute;z-index:1000;top:50%;right:0;width:30px;height:30px;transform:translate(0, -50%);-moz-border-radius:30px;-webkit-border-radius:30px;border-radius:30px;background-size:contain;background-repeat:no-repeat;background-position:center center;background-image:url('')}@media (min-width: 992px){.chat-widget--sidebar,.chat-widget--content{position:static;width:auto;-moz-border-radius:8px;-webkit-border-radius:8px;border-radius:8px}.chat-widget--sidebar{min-width:320px;max-width:320px;margin-right:24px}.chat-widget--content{flex-grow:1;flex-shrink:1}.chat-rooms--search,.chat-widget--content-header{-moz-border-radius:8px 8px 0 0;-webkit-border-radius:8px 8px 0 0;border-radius:8px 8px 0 0}}";
@@ -1,17 +1,20 @@
1
1
  import { r as registerInstance, h } from './index-888e99e3.js';
2
2
  import { C as Colors } from './colors-ea36347a.js';
3
- import { H as HttpService } from './services-260ea6eb.js';
3
+ import { H as HttpService } from './services-d71be591.js';
4
4
  import './_commonjsHelpers-a4f66ccd.js';
5
5
 
6
- const indexCss = "@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,400;0,500;0,700;1,400;1,500;1,700&display=swap'); chat-button{position:relative}.chat-button--indicator{cursor:pointer;position:absolute;inset:0}.chat-button--counter{background-color:rgb(240, 90, 97);border:1px solid rgb(255, 255, 255);position:absolute;right:6px;top:0px;height:8px;width:8px;-moz-border-radius:8px;-webkit-border-radius:8px;border-radius:8px}.chat-box{font-family:'Roboto', sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;display:flex;flex-direction:column;position:fixed;inset:0px;z-index:20000;font-size:16px;text-align:left;color:#141414}.chat-box--header{display:flex;justify-content:space-between;padding:16px;position:relative}.chat-box--title{color:#fff;font-size:20px;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:space-between;margin:0}.chat-box--close{cursor:pointer;display:block;position:absolute;z-index:1000;top:50%;right:0;width:30px;height:30px;transform:translate(0, -50%);background-size:contain;background-repeat:no-repeat;background-position:center center;background-image:url('')}@media (min-width: 768px){.chat-box{border:1px solid #fff;left:unset;top:unset;right:1px;bottom:0px;height:420px;max-height:90vh;width:600px;-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px;-moz-box-shadow:rgba(0, 0, 0, 0.1) 0px 0px 24px;-webkit-box-shadow:rgba(0, 0, 0, 0.1) 0px 0px 24px;box-shadow:rgba(0, 0, 0, 0.1) 0px 0px 24px}.chat-box--header{-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px}}";
6
+ const indexCss = "@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,400;0,500;0,700;1,400;1,500;1,700&display=swap'); chat-button{position:relative}.chat-button--indicator{cursor:pointer;position:absolute;inset:0}.chat-button--counter{background-color:rgb(240, 90, 97);border:1px solid rgb(255, 255, 255);position:absolute;right:6px;top:0px;height:8px;width:8px;-moz-border-radius:8px;-webkit-border-radius:8px;border-radius:8px}.chat-box{font-family:'Roboto', sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px;-moz-box-shadow:rgba(0, 0, 0, 0.25) 0px 0px 24px;-webkit-box-shadow:rgba(0, 0, 0, 0.25) 0px 0px 24px;box-shadow:rgba(0, 0, 0, 0.25) 0px 0px 24px;background-color:#fff;display:flex;flex-direction:column;position:fixed;right:1px;bottom:0px;z-index:20000;font-size:16px;text-align:left;color:#141414;width:80vw;height:480px;max-height:80vh}.chat-box--header{display:flex;justify-content:space-between;padding:16px;position:relative;-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px}.chat-box--title{color:#fff;font-size:20px;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:space-between;margin:0}.chat-box--close{cursor:pointer;display:block;position:absolute;z-index:1000;top:50%;right:0;width:30px;height:30px;transform:translate(0, -50%);background-size:contain;background-repeat:no-repeat;background-position:center center;background-image:url('')}@media (min-width: 768px){.chat-box{border:1px solid #fff;height:480px;max-height:90vh;width:560px}.chat-box--header{-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px}}";
7
7
 
8
8
  const ChatButton = class {
9
9
  constructor(hostRef) {
10
10
  registerInstance(this, hostRef);
11
11
  this.primaryColor = undefined;
12
+ this.receiverId = undefined;
12
13
  this.accessToken = undefined;
13
14
  this.senderId = undefined;
14
- this.receiverId = undefined;
15
+ this.senderIdState = undefined;
16
+ this.accessTokenState = undefined;
17
+ this.isChatVerificationExpanded = undefined;
15
18
  this.senderInfo = {};
16
19
  this.receiverInfo = {};
17
20
  this.chatRoom = {};
@@ -19,31 +22,59 @@ const ChatButton = class {
19
22
  this.isChatExpanded = undefined;
20
23
  }
21
24
  componentWillLoad() {
22
- this.fetchData();
25
+ this.senderIdState = this.senderId;
26
+ this.accessTokenState = this.accessToken;
27
+ this.senderIdState && this.accessTokenState && this.fetchData();
28
+ setTimeout(() => {
29
+ if (this.senderIdState && this.accessTokenState) {
30
+ this.isChatExpanded = true;
31
+ }
32
+ else {
33
+ this.isChatVerificationExpanded = true;
34
+ }
35
+ }, 1000);
23
36
  }
24
37
  async fetchData() {
25
38
  try {
26
- this.chatRoom = await HttpService().createChatRoom(this.receiverId, this.accessToken);
39
+ this.chatRoom = await HttpService().createChatRoom(this.receiverId, this.accessTokenState);
27
40
  if (this.chatRoom) {
28
41
  HttpService().fetchChatMessages(this.chatRoom.uid, (messages) => this.chatMessages = messages);
29
- this.senderInfo = this.chatRoom.members.find(user => user.id === Number(this.senderId));
42
+ this.senderInfo = this.chatRoom.members.find(user => user.id === Number(this.senderIdState));
30
43
  this.receiverInfo = this.chatRoom.members.find(user => user.id === Number(this.receiverId));
31
44
  }
32
45
  }
33
46
  catch (e) { }
34
47
  }
48
+ onVerificationSuccess(user) {
49
+ if (user.id && user.accessToken) {
50
+ this.isChatExpanded = true;
51
+ this.senderIdState = String(user.id);
52
+ this.accessTokenState = user.accessToken;
53
+ setTimeout(() => this.fetchData(), 350);
54
+ }
55
+ }
35
56
  render() {
36
- const unreadMessages = (this.chatMessages || []).filter(message => {
37
- return Boolean(message.unRead) && message.senderId !== this.senderInfo.id;
38
- });
39
- return (h("div", null, unreadMessages.length > 0 && h("notify-sounds", null), h("div", { class: "chat-button--indicator", onClick: () => this.isChatExpanded = true }, unreadMessages.length > 0 && h("span", { class: "chat-button--counter" })), h("div", { class: "chat-box", style: this.isChatExpanded ? {} : { display: 'none' } }, h("div", { class: "chat-box--header", style: {
57
+ if (this.senderIdState && this.accessTokenState) {
58
+ const unreadMessages = (this.chatMessages || []).filter(message => {
59
+ return Boolean(message.unRead) && message.senderId !== this.senderInfo.id;
60
+ });
61
+ return (h("div", null, unreadMessages.length > 0 && h("notify-sounds", null), h("div", { class: "chat-button--indicator", onClick: () => this.isChatExpanded = true }, unreadMessages.length > 0 && h("span", { class: "chat-button--counter" })), h("div", { class: "chat-box", style: this.isChatExpanded ? {} : { display: 'none' } }, h("div", { class: "chat-box--header", style: {
62
+ backgroundColor: this.primaryColor || '#f05a61',
63
+ } }, h("h3", { class: "chat-box--title" }, "Chat"), h("div", { style: { position: 'relative' } }, h("div", { class: "chat-box--close", onClick: () => this.isChatExpanded = false }))), h("div", { style: {
64
+ flexShrink: '1',
65
+ flexGrow: '1',
66
+ overflowY: 'auto',
67
+ padding: '16px',
68
+ } }, h("chat-messages", { sender: this.senderInfo, receiver: this.receiverInfo, messages: this.chatMessages || [], "chat-room-id": this.chatRoom.uid })), h("div", { style: { borderTop: `1px solid ${Colors.Gray02}` } }, h("chat-form", { "sender-id": this.senderInfo.id ? Number(this.senderInfo.id) : null, "chat-room-id": this.chatRoom.uid })))));
69
+ }
70
+ return (h("div", null, h("div", { class: "chat-button--indicator", onClick: () => this.isChatVerificationExpanded = true }), h("div", { class: "chat-box", style: this.isChatVerificationExpanded ? {} : { display: 'none' } }, h("div", { class: "chat-box--header", style: {
40
71
  backgroundColor: this.primaryColor || '#f05a61',
41
- } }, h("h3", { class: "chat-box--title" }, "Chat"), h("div", { style: { position: 'relative' } }, h("div", { class: "chat-box--close", onClick: () => this.isChatExpanded = false }))), h("div", { style: {
72
+ } }, h("h3", { class: "chat-box--title" }, "Chat"), h("div", { style: { position: 'relative' } }, h("div", { class: "chat-box--close", onClick: () => this.isChatVerificationExpanded = false }))), h("div", { style: {
42
73
  flexShrink: '1',
43
74
  flexGrow: '1',
44
75
  overflowY: 'auto',
45
76
  padding: '16px',
46
- } }, h("chat-messages", { sender: this.senderInfo, receiver: this.receiverInfo, messages: this.chatMessages || [], "chat-room-id": this.chatRoom.uid })), h("div", { style: { borderTop: `1px solid ${Colors.Gray02}` } }, h("chat-form", { "sender-id": this.senderInfo.id ? Number(this.senderInfo.id) : null, "chat-room-id": this.chatRoom.uid })))));
77
+ } }, h("user-form", { onSuccess: user => this.onVerificationSuccess(user) })))));
47
78
  }
48
79
  };
49
80
  ChatButton.style = indexCss;
@@ -1,5 +1,5 @@
1
1
  import { r as registerInstance, h } from './index-888e99e3.js';
2
- import { H as HttpService } from './services-260ea6eb.js';
2
+ import { H as HttpService } from './services-d71be591.js';
3
3
  import './_commonjsHelpers-a4f66ccd.js';
4
4
  import './colors-ea36347a.js';
5
5
 
@@ -1,5 +1,5 @@
1
1
  import { r as registerInstance, h } from './index-888e99e3.js';
2
- import { d as dayjs_min, H as HttpService, t as timeFormatAmPm } from './services-260ea6eb.js';
2
+ import { d as dayjs_min, H as HttpService, t as timeFormatAmPm } from './services-d71be591.js';
3
3
  import { l as lodash } from './lodash-d5526b38.js';
4
4
  import { C as Colors } from './colors-ea36347a.js';
5
5
  import { r as relativeTime } from './relativeTime-268e64b0.js';
@@ -1,7 +1,7 @@
1
1
  import { r as registerInstance, h } from './index-888e99e3.js';
2
2
  import { l as lodash } from './lodash-d5526b38.js';
3
3
  import { C as Colors } from './colors-ea36347a.js';
4
- import { H as HttpService } from './services-260ea6eb.js';
4
+ import { H as HttpService } from './services-d71be591.js';
5
5
  import { f as formatPhoneNumber } from './utils-fd30fb29.js';
6
6
  import './_commonjsHelpers-a4f66ccd.js';
7
7
 
@@ -144,5 +144,5 @@ const patchCloneNodeFix = (HTMLElementPrototype) => {
144
144
 
145
145
  patchBrowser().then(options => {
146
146
  globalScripts();
147
- return bootstrapLazy([["chat-box",[[0,"chat-box",{"primaryColor":[1,"primary-color"],"accessToken":[1,"access-token"],"senderId":[1,"sender-id"],"salonId":[1,"salon-id"],"chatRooms":[32],"activeRoom":[32],"fetchData":[64]}]]],["chat-button",[[0,"chat-button",{"primaryColor":[1,"primary-color"],"accessToken":[1,"access-token"],"senderId":[1,"sender-id"],"receiverId":[1,"receiver-id"],"senderInfo":[32],"receiverInfo":[32],"chatRoom":[32],"chatMessages":[32],"isChatExpanded":[32],"fetchData":[64]}]]],["salon-info",[[0,"salon-info",{"salonId":[2,"salon-id"],"salonInfo":[32],"fetchData":[64]}]]],["salon-latest-reviews",[[0,"salon-latest-reviews",{"salonId":[2,"salon-id"],"primaryColor":[1,"primary-color"],"salonReviews":[32],"isLoading":[32],"fetchData":[64]}]]],["salon-lookbook",[[0,"salon-lookbook",{"salonId":[2,"salon-id"],"isLoading":[32],"isLoadingMore":[32],"hideLoadMore":[32],"currentPage":[32],"totalLookbooks":[32],"salonCategories":[32],"salonLookbooks":[32],"sortBy":[32],"filterBy":[32],"isLayoutSetup":[32],"fetchData":[64],"fetchLookbooks":[64],"onChangeFiltering":[64],"onChangeSorting":[64],"onLoadMore":[64],"fetchCategories":[64]}]]],["salon-reviews",[[0,"salon-reviews",{"salonId":[2,"salon-id"],"primaryColor":[1,"primary-color"],"salonInfo":[32],"stats":[32],"totalReviews":[32],"allReviews":[32],"isLoading":[32],"isSorting":[32],"isFiltering":[32],"isLoadingMore":[32],"canLoadMore":[32],"page":[32],"filterBy":[32],"sortBy":[32]}]]],["style-detail",[[0,"style-detail",{"salonId":[2,"salon-id"],"salonLookbook":[1,"salon-lookbook"],"lookbookInfo":[32],"isModalOpen":[32],"currentMediaIdx":[32],"currentMedia":[32],"albumMedias":[32],"similarStyles":[32],"totalComments":[32],"lookbookComments":[32],"isLayoutSetup":[32],"fetchData":[64]}]]],["salon-booking",[[0,"salon-booking",{"salonId":[2,"salon-id"],"buttonClass":[1,"button-class"],"buttonText":[1,"button-text"],"primaryColor":[1,"primary-color"]}]]],["salon-booking-modal",[[0,"salon-booking-modal",{"salonId":[2,"salon-id"],"primaryColor":[1,"primary-color"],"redirectUrl":[1,"redirect-url"],"isModalOpen":[32]}]]],["salon-gift-card",[[0,"salon-gift-card",{"salonId":[2,"salon-id"],"buttonClass":[1,"button-class"],"buttonText":[1,"button-text"],"primaryColor":[1,"primary-color"]}]]],["salon-gift-card-modal",[[0,"salon-gift-card-modal",{"salonId":[2,"salon-id"],"primaryColor":[1,"primary-color"],"isModalOpen":[32]}]]],["salon-ranking",[[0,"salon-ranking",{"ranking":[2],"height":[2],"width":[2]}]]],["salon-services",[[0,"salon-services",{"salonId":[2,"salon-id"],"buttonClass":[1,"button-class"],"salonServices":[32],"isLoading":[32],"fetchData":[64]}]]],["salon-stylists",[[0,"salon-stylists",{"salonId":[2,"salon-id"],"salonStylists":[32],"totalStylists":[32],"page":[32],"isLoading":[32],"isLoadingMore":[32],"canLoadMore":[32],"fetchData":[64],"onLoadMore":[64]}]]],["chat-rooms",[[0,"chat-rooms",{"senderId":[2,"sender-id"],"salonId":[2,"salon-id"],"chatRooms":[16],"clients":[16],"activeRoom":[16],"accessToken":[1,"access-token"],"onClickRoom":[16],"keyword":[32]}]]],["salon-locations",[[0,"salon-locations",{"salonId":[2,"salon-id"],"salonInfo":[1,"salon-info"],"isLoading":[4,"is-loading"],"withBorder":[4,"with-border"],"salonInfoState":[32]}]]],["notify-sounds",[[0,"notify-sounds"]]],["salon-latest-styles",[[0,"salon-latest-styles",{"salonId":[2,"salon-id"],"isLoading":[4,"is-loading"],"withBorder":[4,"with-border"],"isLoadingState":[32],"latestStyles":[32],"fetchData":[64]}]]],["salon-schedules",[[0,"salon-schedules",{"salonId":[2,"salon-id"],"salonInfo":[1,"salon-info"],"isLoading":[4,"is-loading"],"withBorder":[4,"with-border"],"salonInfoState":[32]}]]],["chat-messages",[[0,"chat-messages",{"sender":[16],"receiver":[16],"messages":[16],"chatRoomId":[1,"chat-room-id"]}]]],["chat-form",[[0,"chat-form",{"senderId":[2,"sender-id"],"chatRoomId":[1,"chat-room-id"]}]]],["google-map",[[0,"google-map",{"locationName":[1,"location-name"],"locationAddress":[1,"location-address"]}]]],["user-avatar",[[0,"user-avatar",{"size":[2],"name":[1],"description":[1],"nameStyle":[16],"shortName":[1,"short-name"],"avatar":[1]}]]]], options);
147
+ return bootstrapLazy([["chat-button",[[0,"chat-button",{"primaryColor":[1,"primary-color"],"receiverId":[1,"receiver-id"],"accessToken":[1,"access-token"],"senderId":[1,"sender-id"],"senderIdState":[32],"accessTokenState":[32],"isChatVerificationExpanded":[32],"senderInfo":[32],"receiverInfo":[32],"chatRoom":[32],"chatMessages":[32],"isChatExpanded":[32],"fetchData":[64],"onVerificationSuccess":[64]}]]],["chat-box",[[0,"chat-box",{"primaryColor":[1,"primary-color"],"accessToken":[1,"access-token"],"senderId":[1,"sender-id"],"salonId":[1,"salon-id"],"chatRooms":[32],"activeRoom":[32],"fetchData":[64]}]]],["salon-info",[[0,"salon-info",{"salonId":[2,"salon-id"],"salonInfo":[32],"fetchData":[64]}]]],["salon-latest-reviews",[[0,"salon-latest-reviews",{"salonId":[2,"salon-id"],"primaryColor":[1,"primary-color"],"salonReviews":[32],"isLoading":[32],"fetchData":[64]}]]],["salon-lookbook",[[0,"salon-lookbook",{"salonId":[2,"salon-id"],"isLoading":[32],"isLoadingMore":[32],"hideLoadMore":[32],"currentPage":[32],"totalLookbooks":[32],"salonCategories":[32],"salonLookbooks":[32],"sortBy":[32],"filterBy":[32],"isLayoutSetup":[32],"fetchData":[64],"fetchLookbooks":[64],"onChangeFiltering":[64],"onChangeSorting":[64],"onLoadMore":[64],"fetchCategories":[64]}]]],["salon-reviews",[[0,"salon-reviews",{"salonId":[2,"salon-id"],"primaryColor":[1,"primary-color"],"salonInfo":[32],"stats":[32],"totalReviews":[32],"allReviews":[32],"isLoading":[32],"isSorting":[32],"isFiltering":[32],"isLoadingMore":[32],"canLoadMore":[32],"page":[32],"filterBy":[32],"sortBy":[32]}]]],["style-detail",[[0,"style-detail",{"salonId":[2,"salon-id"],"salonLookbook":[1,"salon-lookbook"],"lookbookInfo":[32],"isModalOpen":[32],"currentMediaIdx":[32],"currentMedia":[32],"albumMedias":[32],"similarStyles":[32],"totalComments":[32],"lookbookComments":[32],"isLayoutSetup":[32],"fetchData":[64]}]]],["salon-booking",[[0,"salon-booking",{"salonId":[2,"salon-id"],"buttonClass":[1,"button-class"],"buttonText":[1,"button-text"],"primaryColor":[1,"primary-color"]}]]],["salon-booking-modal",[[0,"salon-booking-modal",{"salonId":[2,"salon-id"],"primaryColor":[1,"primary-color"],"redirectUrl":[1,"redirect-url"],"isModalOpen":[32]}]]],["salon-gift-card",[[0,"salon-gift-card",{"salonId":[2,"salon-id"],"buttonClass":[1,"button-class"],"buttonText":[1,"button-text"],"primaryColor":[1,"primary-color"]}]]],["salon-gift-card-modal",[[0,"salon-gift-card-modal",{"salonId":[2,"salon-id"],"primaryColor":[1,"primary-color"],"isModalOpen":[32]}]]],["salon-ranking",[[0,"salon-ranking",{"ranking":[2],"height":[2],"width":[2]}]]],["salon-services",[[0,"salon-services",{"salonId":[2,"salon-id"],"buttonClass":[1,"button-class"],"salonServices":[32],"isLoading":[32],"fetchData":[64]}]]],["salon-stylists",[[0,"salon-stylists",{"salonId":[2,"salon-id"],"salonStylists":[32],"totalStylists":[32],"page":[32],"isLoading":[32],"isLoadingMore":[32],"canLoadMore":[32],"fetchData":[64],"onLoadMore":[64]}]]],["user-form",[[0,"user-form",{"onSuccess":[16],"type":[32],"currentUser":[32]}]]],["chat-rooms",[[0,"chat-rooms",{"senderId":[2,"sender-id"],"salonId":[2,"salon-id"],"chatRooms":[16],"clients":[16],"activeRoom":[16],"accessToken":[1,"access-token"],"onClickRoom":[16],"keyword":[32]}]]],["salon-locations",[[0,"salon-locations",{"salonId":[2,"salon-id"],"salonInfo":[1,"salon-info"],"isLoading":[4,"is-loading"],"withBorder":[4,"with-border"],"salonInfoState":[32]}]]],["notify-sounds",[[0,"notify-sounds"]]],["salon-latest-styles",[[0,"salon-latest-styles",{"salonId":[2,"salon-id"],"isLoading":[4,"is-loading"],"withBorder":[4,"with-border"],"isLoadingState":[32],"latestStyles":[32],"fetchData":[64]}]]],["salon-schedules",[[0,"salon-schedules",{"salonId":[2,"salon-id"],"salonInfo":[1,"salon-info"],"isLoading":[4,"is-loading"],"withBorder":[4,"with-border"],"salonInfoState":[32]}]]],["chat-messages",[[0,"chat-messages",{"sender":[16],"receiver":[16],"messages":[16],"chatRoomId":[1,"chat-room-id"]}]]],["activate-form",[[0,"activate-form",{"username":[1],"password":[1],"onSuccess":[16],"isSubmitting":[32],"error":[32],"confirmCode":[32],"onSubmit":[64],"resendCode":[64]}]]],["change-password-form",[[0,"change-password-form",{"username":[1],"onSuccess":[16],"isSubmitting":[32],"error":[32],"confirmCode":[32],"password":[32],"onSubmit":[64],"resendCode":[64]}]]],["chat-form",[[0,"chat-form",{"senderId":[2,"sender-id"],"chatRoomId":[1,"chat-room-id"]}]]],["google-map",[[0,"google-map",{"locationName":[1,"location-name"],"locationAddress":[1,"location-address"]}]]],["login-form",[[0,"login-form",{"onSuccess":[16],"isSubmitting":[32],"error":[32],"username":[32],"password":[32],"onSubmit":[64]}]]],["register-form",[[0,"register-form",{"onSuccess":[16],"isSubmitting":[32],"error":[32],"firstName":[32],"lastName":[32],"email":[32],"phone":[32],"password":[32],"onSubmit":[64]}]]],["reset-password-form",[[0,"reset-password-form",{"onSuccess":[16],"isSubmitting":[32],"error":[32],"username":[32],"onSubmit":[64]}]]],["user-avatar",[[0,"user-avatar",{"size":[2],"name":[1],"description":[1],"nameStyle":[16],"shortName":[1,"short-name"],"avatar":[1]}]]]], options);
148
148
  });
@@ -0,0 +1,67 @@
1
+ import { r as registerInstance, h } from './index-888e99e3.js';
2
+ import { C as Colors } from './colors-ea36347a.js';
3
+ import { H as HttpService } from './services-d71be591.js';
4
+ import './_commonjsHelpers-a4f66ccd.js';
5
+
6
+ const loginFormCss = ".form--user-login .form--login-label{cursor:pointer;display:block;margin-bottom:6px}.form--user-login input,.form--user-login button{border:1px solid #cecece;box-sizing:border-box;display:inline-block;width:100%;padding:4px 11px;min-height:40px;-moz-transition:all 0.3s;-webkit-transition:all 0.3s;transition:all 0.3s;-moz-border-radius:6px;-webkit-border-radius:6px;border-radius:6px}.form--user-login button{background-color:#001529;border:1px solid #001529;color:#fff;cursor:pointer}.form--user-login button:disabled{background-color:#cecece;border:1px solid #cecece;color:#212121}";
7
+
8
+ const LoginForm = class {
9
+ constructor(hostRef) {
10
+ registerInstance(this, hostRef);
11
+ this.onSuccess = undefined;
12
+ this.isSubmitting = undefined;
13
+ this.error = undefined;
14
+ this.username = undefined;
15
+ this.password = undefined;
16
+ }
17
+ async onSubmit(evt) {
18
+ evt.preventDefault();
19
+ this.error = null;
20
+ this.isSubmitting = true;
21
+ if (this.username && this.password) {
22
+ try {
23
+ const apiUrl = window.location.origin.indexOf('localhost') > -1 || window.location.origin.indexOf('favesalon.com') > -1
24
+ ? 'https://favesalon.com'
25
+ : window.location.origin;
26
+ const userInfo = await HttpService().login(apiUrl, {
27
+ email: this.username,
28
+ password: this.password,
29
+ });
30
+ this.onSuccess(userInfo);
31
+ }
32
+ catch (e) {
33
+ let errorMessage = e.message || `Something went wrong when logging your account`;
34
+ if (errorMessage.indexOf('404') > -1) {
35
+ errorMessage = 'You have entered an invalid username or password';
36
+ }
37
+ this.error = errorMessage;
38
+ }
39
+ }
40
+ else {
41
+ this.error = 'Please enter your username and password';
42
+ }
43
+ this.isSubmitting = false;
44
+ }
45
+ render() {
46
+ return (h("form", { class: "form--user-login", onSubmit: (evt) => this.onSubmit(evt) }, this.error && (h("div", { style: {
47
+ backgroundColor: Colors.Red01,
48
+ border: `1px solid ${Colors.Red02}`,
49
+ marginBottom: '24px',
50
+ padding: '12px',
51
+ } }, this.error)), h("div", { style: { marginBottom: '24px' } }, h("label", { ...{ for: "form--login-username" }, class: "form--login-label" }, "Phone or Email"), h("input", { id: "form--login-username", type: "text", onInput: (evt) => {
52
+ this.username = evt.target.value;
53
+ } })), h("div", { style: {
54
+ display: 'flex',
55
+ marginBottom: '24px',
56
+ width: '100%',
57
+ } }, h("div", { style: {
58
+ flexShrink: '1',
59
+ flexGrow: '1',
60
+ } }, h("label", { ...{ for: "form--login-password" }, class: "form--login-label" }, "Password"), h("input", { id: "form--login-password", type: "password", onInput: (evt) => {
61
+ this.password = evt.target.value;
62
+ } })), h("div", { style: { width: '100px', marginLeft: '12px' } }, h("label", { style: { display: 'inline-block', marginBottom: '6px' } }, "\u00A0"), h("button", { type: "submit", disabled: this.isSubmitting }, "SIGN IN")))));
63
+ }
64
+ };
65
+ LoginForm.style = loginFormCss;
66
+
67
+ export { LoginForm as login_form };
@@ -1,6 +1,6 @@
1
1
  import { r as registerInstance, h } from './index-888e99e3.js';
2
2
 
3
- const indexCss = "@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,400;0,500;0,700;1,400;1,500;1,700&display=swap'); chat-button{position:relative}.chat-button--indicator{cursor:pointer;position:absolute;inset:0}.chat-button--counter{background-color:rgb(240, 90, 97);border:1px solid rgb(255, 255, 255);position:absolute;right:6px;top:0px;height:8px;width:8px;-moz-border-radius:8px;-webkit-border-radius:8px;border-radius:8px}.chat-box{font-family:'Roboto', sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;display:flex;flex-direction:column;position:fixed;inset:0px;z-index:20000;font-size:16px;text-align:left;color:#141414}.chat-box--header{display:flex;justify-content:space-between;padding:16px;position:relative}.chat-box--title{color:#fff;font-size:20px;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:space-between;margin:0}.chat-box--close{cursor:pointer;display:block;position:absolute;z-index:1000;top:50%;right:0;width:30px;height:30px;transform:translate(0, -50%);background-size:contain;background-repeat:no-repeat;background-position:center center;background-image:url('')}@media (min-width: 768px){.chat-box{border:1px solid #fff;left:unset;top:unset;right:1px;bottom:0px;height:420px;max-height:90vh;width:600px;-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px;-moz-box-shadow:rgba(0, 0, 0, 0.1) 0px 0px 24px;-webkit-box-shadow:rgba(0, 0, 0, 0.1) 0px 0px 24px;box-shadow:rgba(0, 0, 0, 0.1) 0px 0px 24px}.chat-box--header{-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px}}";
3
+ const indexCss = "@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,400;0,500;0,700;1,400;1,500;1,700&display=swap'); chat-button{position:relative}.chat-button--indicator{cursor:pointer;position:absolute;inset:0}.chat-button--counter{background-color:rgb(240, 90, 97);border:1px solid rgb(255, 255, 255);position:absolute;right:6px;top:0px;height:8px;width:8px;-moz-border-radius:8px;-webkit-border-radius:8px;border-radius:8px}.chat-box{font-family:'Roboto', sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px;-moz-box-shadow:rgba(0, 0, 0, 0.25) 0px 0px 24px;-webkit-box-shadow:rgba(0, 0, 0, 0.25) 0px 0px 24px;box-shadow:rgba(0, 0, 0, 0.25) 0px 0px 24px;background-color:#fff;display:flex;flex-direction:column;position:fixed;right:1px;bottom:0px;z-index:20000;font-size:16px;text-align:left;color:#141414;width:80vw;height:480px;max-height:80vh}.chat-box--header{display:flex;justify-content:space-between;padding:16px;position:relative;-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px}.chat-box--title{color:#fff;font-size:20px;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:space-between;margin:0}.chat-box--close{cursor:pointer;display:block;position:absolute;z-index:1000;top:50%;right:0;width:30px;height:30px;transform:translate(0, -50%);background-size:contain;background-repeat:no-repeat;background-position:center center;background-image:url('')}@media (min-width: 768px){.chat-box{border:1px solid #fff;height:480px;max-height:90vh;width:560px}.chat-box--header{-moz-border-radius:8px 8px 0px 0px;-webkit-border-radius:8px 8px 0px 0px;border-radius:8px 8px 0px 0px}}";
4
4
 
5
5
  const NotifySounds = class {
6
6
  constructor(hostRef) {
@@ -0,0 +1,88 @@
1
+ import { r as registerInstance, h } from './index-888e99e3.js';
2
+ import { C as Colors } from './colors-ea36347a.js';
3
+ import { H as HttpService } from './services-d71be591.js';
4
+ import './_commonjsHelpers-a4f66ccd.js';
5
+
6
+ const registerFormCss = ".form--user-register .form--login-label{cursor:pointer;display:block;margin-bottom:6px}.form--user-register input,.form--user-register button{border:1px solid #cecece;box-sizing:border-box;display:inline-block;width:100%;padding:4px 11px;min-height:40px;-moz-transition:all 0.3s;-webkit-transition:all 0.3s;transition:all 0.3s;-moz-border-radius:6px;-webkit-border-radius:6px;border-radius:6px}.form--user-register button{background-color:#001529;border:1px solid #001529;color:#fff;cursor:pointer}.form--user-register button:disabled{background-color:#cecece;border:1px solid #cecece;color:#212121}";
7
+
8
+ const RegisterForm = class {
9
+ constructor(hostRef) {
10
+ registerInstance(this, hostRef);
11
+ this.onSuccess = undefined;
12
+ this.isSubmitting = undefined;
13
+ this.error = undefined;
14
+ this.firstName = undefined;
15
+ this.lastName = undefined;
16
+ this.email = undefined;
17
+ this.phone = undefined;
18
+ this.password = undefined;
19
+ }
20
+ async onSubmit(evt) {
21
+ evt.preventDefault();
22
+ this.error = null;
23
+ this.isSubmitting = true;
24
+ if (this.firstName && this.lastName && this.email && this.phone && this.password) {
25
+ try {
26
+ await HttpService().register({
27
+ email: this.email,
28
+ password: this.password,
29
+ mobile_phone: this.phone,
30
+ first_name: this.firstName,
31
+ last_name: this.lastName,
32
+ user_type: 1, // Consumer account
33
+ });
34
+ this.onSuccess({
35
+ email: this.email,
36
+ password: this.password,
37
+ });
38
+ }
39
+ catch (e) {
40
+ let errorMessage = e.message || `Something went wrong when creating your account`;
41
+ if (errorMessage.indexOf('Email has been exists') > -1) {
42
+ errorMessage = 'There was an existing account with your inputted info';
43
+ }
44
+ this.error = errorMessage;
45
+ }
46
+ }
47
+ else {
48
+ this.error = 'Please enter your username and password';
49
+ }
50
+ this.isSubmitting = false;
51
+ }
52
+ render() {
53
+ return (h("form", { class: "form--user-register", onSubmit: (evt) => this.onSubmit(evt) }, this.error && (h("div", { style: {
54
+ backgroundColor: Colors.Red01,
55
+ border: `1px solid ${Colors.Red02}`,
56
+ marginBottom: '24px',
57
+ padding: '12px',
58
+ } }, this.error)), h("div", { style: {
59
+ display: 'flex',
60
+ marginBottom: '24px',
61
+ width: '100%',
62
+ } }, h("div", { style: { width: '48%', marginRight: '4%' } }, h("label", { ...{ for: "form--login-firstname" }, class: "form--login-label" }, "First name"), h("input", { id: "form--login-firstname", type: "text", onInput: (evt) => {
63
+ this.firstName = evt.target.value;
64
+ } })), h("div", { style: { width: '48%' } }, h("label", { ...{ for: "form--login-lastname" }, class: "form--login-label" }, "Last name"), h("input", { id: "form--login-lastname", type: "text", onInput: (evt) => {
65
+ this.lastName = evt.target.value;
66
+ } }))), h("div", { style: {
67
+ display: 'flex',
68
+ marginBottom: '24px',
69
+ width: '100%',
70
+ } }, h("div", { style: { width: '48%', marginRight: '4%' } }, h("label", { ...{ for: "form--login-email" }, class: "form--login-label" }, "Email"), h("input", { id: "form--login-email", type: "text", onInput: (evt) => {
71
+ this.email = evt.target.value;
72
+ } })), h("div", { style: { width: '48%' } }, h("label", { ...{ for: "form--login-phone" }, class: "form--login-label" }, "Phone"), h("input", { id: "form--login-phone", type: "text", onInput: (evt) => {
73
+ this.phone = evt.target.value;
74
+ } }))), h("div", { style: {
75
+ display: 'flex',
76
+ marginBottom: '24px',
77
+ width: '100%',
78
+ } }, h("div", { style: {
79
+ flexShrink: '1',
80
+ flexGrow: '1',
81
+ } }, h("label", { ...{ for: "form--login-password" }, class: "form--login-label" }, "Password"), h("input", { id: "form--login-password", type: "password", onInput: (evt) => {
82
+ this.password = evt.target.value;
83
+ } })), h("div", { style: { width: '100px', marginLeft: '12px' } }, h("label", { style: { display: 'inline-block', marginBottom: '6px' } }, "\u00A0"), h("button", { type: "submit", disabled: this.isSubmitting }, "SIGN UP"))), h("div", { style: { marginBottom: '24px' } }, "By submitting, you agree to our ", h("a", { target: "_blank", rel: "noopener noreferrer", href: "https://fave.salon/r/terms-for-client", style: { color: Colors.TextColor, cursor: 'pointer', display: 'inline', textDecoration: 'underline' } }, "Terms of Clients"), ", ", h("a", { target: "_blank", rel: "noopener noreferrer", href: "https://fave.salon/r/terms-for-business", style: { color: Colors.TextColor, cursor: 'pointer', display: 'inline', textDecoration: 'underline' } }, "Terms of Salons & Stylist"), " and ", h("a", { target: "_blank", rel: "noopener noreferrer", href: "https://fave.salon/r/privacy-policy", style: { color: Colors.TextColor, cursor: 'pointer', display: 'inline', textDecoration: 'underline' } }, "Private Policy"))));
84
+ }
85
+ };
86
+ RegisterForm.style = registerFormCss;
87
+
88
+ export { RegisterForm as register_form };
@@ -0,0 +1,47 @@
1
+ import { r as registerInstance, h } from './index-888e99e3.js';
2
+ import { C as Colors } from './colors-ea36347a.js';
3
+ import { H as HttpService } from './services-d71be591.js';
4
+ import './_commonjsHelpers-a4f66ccd.js';
5
+
6
+ const resetPasswordFormCss = ".form--user-reset-password .form--login-label{cursor:pointer;display:block;margin-bottom:6px}.form--user-reset-password input,.form--user-reset-password button{border:1px solid #cecece;box-sizing:border-box;display:inline-block;width:100%;padding:4px 11px;min-height:40px;-moz-transition:all 0.3s;-webkit-transition:all 0.3s;transition:all 0.3s;-moz-border-radius:6px;-webkit-border-radius:6px;border-radius:6px}.form--user-reset-password button{background-color:#001529;border:1px solid #001529;color:#fff;cursor:pointer}.form--user-reset-password button:disabled{background-color:#cecece;border:1px solid #cecece;color:#212121}";
7
+
8
+ const ResetPasswordForm = class {
9
+ constructor(hostRef) {
10
+ registerInstance(this, hostRef);
11
+ this.onSuccess = undefined;
12
+ this.isSubmitting = undefined;
13
+ this.error = undefined;
14
+ this.username = undefined;
15
+ }
16
+ async onSubmit(evt) {
17
+ evt.preventDefault();
18
+ this.error = null;
19
+ this.isSubmitting = true;
20
+ if (this.username) {
21
+ try {
22
+ await HttpService().resetPassword(this.username);
23
+ this.onSuccess({ email: this.username });
24
+ }
25
+ catch (e) {
26
+ this.error = e.message || `Something went wrong when setting your new password`;
27
+ }
28
+ }
29
+ else {
30
+ this.error = 'Please enter your phone or email to reset your password';
31
+ }
32
+ this.isSubmitting = false;
33
+ }
34
+ render() {
35
+ return (h("form", { class: "form--user-reset-password", onSubmit: (evt) => this.onSubmit(evt) }, this.error && (h("div", { style: {
36
+ backgroundColor: Colors.Red01,
37
+ border: `1px solid ${Colors.Red02}`,
38
+ marginBottom: '24px',
39
+ padding: '12px',
40
+ } }, this.error)), h("div", { style: { marginBottom: '24px' } }, h("label", { ...{ for: "form--login-username" }, class: "form--login-label" }, "Phone or Email"), h("input", { id: "form--login-username", type: "text", onInput: (evt) => {
41
+ this.username = evt.target.value;
42
+ } })), h("div", { style: { marginBottom: '24px' } }, h("button", { type: "submit", disabled: this.isSubmitting }, "RESET NOW"))));
43
+ }
44
+ };
45
+ ResetPasswordForm.style = resetPasswordFormCss;
46
+
47
+ export { ResetPasswordForm as reset_password_form };