@lendi/navbar 5.2.4 → 5.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +25 -0
- package/README.md +48 -5
- package/dist/cjs/MegaNavbar/components/MegaMenu/index.js +13 -8
- package/dist/cjs/MegaNavbar/components/MegaMenu/index.js.map +1 -1
- package/dist/cjs/MegaNavbar/index.js +5 -7
- package/dist/cjs/MegaNavbar/index.js.map +1 -1
- package/dist/cjs/MultiNavbar/components/MultiOptions/index.js +13 -8
- package/dist/cjs/MultiNavbar/components/MultiOptions/index.js.map +1 -1
- package/dist/cjs/MultiNavbar/index.js +6 -9
- package/dist/cjs/MultiNavbar/index.js.map +1 -1
- package/dist/cjs/SimpleNavbar/components/DesktopAction/index.js +25 -24
- package/dist/cjs/SimpleNavbar/components/DesktopAction/index.js.map +1 -1
- package/dist/cjs/SimpleNavbar/components/DesktopAction/test.js +99 -0
- package/dist/cjs/SimpleNavbar/components/DesktopAction/test.js.map +1 -0
- package/dist/cjs/SimpleNavbar/components/LogoutComponent/index.js +0 -36
- package/dist/cjs/SimpleNavbar/components/LogoutComponent/index.js.map +1 -1
- package/dist/cjs/SimpleNavbar/components/MobileAction/index.js +20 -19
- package/dist/cjs/SimpleNavbar/components/MobileAction/index.js.map +1 -1
- package/dist/cjs/SimpleNavbar/components/MobileAction/test.js +97 -0
- package/dist/cjs/SimpleNavbar/components/MobileAction/test.js.map +1 -0
- package/dist/cjs/SimpleNavbar/index.js +10 -12
- package/dist/cjs/SimpleNavbar/index.js.map +1 -1
- package/dist/cjs/shared/components/CTA/DesktopActions/index.js +36 -0
- package/dist/cjs/shared/components/CTA/DesktopActions/index.js.map +1 -0
- package/dist/cjs/shared/components/CTA/DesktopActions/style.js +12 -0
- package/dist/cjs/shared/components/CTA/DesktopActions/style.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/constants.js +4 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/constants.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/context.js +13 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/context.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/index.js +56 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/index.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/provider.js +12 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/provider.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/state.js +7 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/state.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/style.js +21 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/style.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/test.js +80 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/DropdownMenu/test.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/index.js +38 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/index.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/style.js +12 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/style.js.map +1 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/test.js +55 -0
- package/dist/cjs/shared/components/CTA/LogoutComponent/test.js.map +1 -0
- package/dist/cjs/shared/components/CTA/MobileActions/index.js +38 -0
- package/dist/cjs/shared/components/CTA/MobileActions/index.js.map +1 -0
- package/dist/cjs/shared/components/CTA/MobileActions/style.js +13 -0
- package/dist/cjs/shared/components/CTA/MobileActions/style.js.map +1 -0
- package/dist/cjs/shared/components/CTA/index.js +16 -80
- package/dist/cjs/shared/components/CTA/index.js.map +1 -1
- package/dist/cjs/shared/components/CTA/style.js +34 -0
- package/dist/cjs/shared/components/CTA/style.js.map +1 -0
- package/dist/cjs/shared/components/CTA/test.js +112 -0
- package/dist/cjs/shared/components/CTA/test.js.map +1 -0
- package/dist/cjs/shared/components/HamBurgerMenu/index.js +6 -1
- package/dist/cjs/shared/components/HamBurgerMenu/index.js.map +1 -1
- package/dist/cjs/shared/components/LeftSidabar/Content/index.js +6 -3
- package/dist/cjs/shared/components/LeftSidabar/Content/index.js.map +1 -1
- package/dist/cjs/shared/components/LeftSidabar/FooterCTA/index.js +9 -8
- package/dist/cjs/shared/components/LeftSidabar/FooterCTA/index.js.map +1 -1
- package/dist/cjs/shared/components/LeftSidabar/FooterCTA/test.js +64 -0
- package/dist/cjs/shared/components/LeftSidabar/FooterCTA/test.js.map +1 -0
- package/dist/cjs/shared/components/Logo/index.js +2 -1
- package/dist/cjs/shared/components/Logo/index.js.map +1 -1
- package/dist/cjs/shared/constants/index.js +14 -9
- package/dist/cjs/shared/constants/index.js.map +1 -1
- package/dist/cjs/shared/hooks/useDomain.js +3 -3
- package/dist/cjs/shared/hooks/useDomain.js.map +1 -1
- package/dist/cjs/shared/hooks/useEmailOpenChat.js +2 -1
- package/dist/cjs/shared/hooks/useEmailOpenChat.js.map +1 -1
- package/dist/cjs/shared/types.js.map +1 -1
- package/dist/cjs/utils/Analytics/index.js +1 -0
- package/dist/cjs/utils/Analytics/index.js.map +1 -1
- package/dist/types/MegaNavbar/components/MegaMenu/index.style.d.ts +1 -1
- package/dist/types/MegaNavbar/index.d.ts +1 -3
- package/dist/types/MultiNavbar/components/MultiOptions/index.style.d.ts +1 -1
- package/dist/types/MultiNavbar/index.d.ts +1 -3
- package/dist/types/SimpleNavbar/components/DesktopAction/index.d.ts +3 -9
- package/dist/types/SimpleNavbar/components/DesktopAction/test.d.ts +1 -0
- package/dist/types/SimpleNavbar/components/LogoutComponent/index.d.ts +0 -3
- package/dist/types/SimpleNavbar/components/MobileAction/index.d.ts +1 -1
- package/dist/types/SimpleNavbar/components/MobileAction/test.d.ts +1 -0
- package/dist/types/SimpleNavbar/index.d.ts +1 -3
- package/dist/types/shared/components/CTA/DesktopActions/index.d.ts +4 -0
- package/dist/types/shared/components/CTA/DesktopActions/style.d.ts +1 -0
- package/dist/types/shared/components/CTA/LogoutComponent/DropdownMenu/constants.d.ts +1 -0
- package/dist/types/shared/components/CTA/LogoutComponent/DropdownMenu/context.d.ts +4 -0
- package/dist/types/shared/components/CTA/LogoutComponent/DropdownMenu/index.d.ts +2 -0
- package/dist/types/shared/components/CTA/LogoutComponent/DropdownMenu/provider.d.ts +3 -0
- package/dist/types/shared/components/CTA/LogoutComponent/DropdownMenu/state.d.ts +5 -0
- package/dist/types/shared/components/CTA/LogoutComponent/DropdownMenu/style.d.ts +6 -0
- package/dist/types/shared/components/CTA/LogoutComponent/DropdownMenu/test.d.ts +1 -0
- package/dist/types/shared/components/CTA/LogoutComponent/index.d.ts +2 -0
- package/dist/types/shared/components/CTA/LogoutComponent/style.d.ts +2 -0
- package/dist/types/shared/components/CTA/LogoutComponent/test.d.ts +1 -0
- package/dist/types/shared/components/CTA/MobileActions/index.d.ts +4 -0
- package/dist/types/shared/components/CTA/MobileActions/style.d.ts +1 -0
- package/dist/types/shared/components/CTA/index.d.ts +1 -2
- package/dist/types/shared/components/CTA/{index.style.d.ts → style.d.ts} +1 -9
- package/dist/types/shared/components/CTA/test.d.ts +1 -0
- package/dist/types/shared/components/LeftSidabar/FooterCTA/test.d.ts +1 -0
- package/dist/types/shared/components/Logo/style.d.ts +0 -1
- package/dist/types/shared/constants/index.d.ts +14 -9
- package/dist/types/shared/hooks/useDomain.d.ts +2 -2
- package/dist/types/shared/styles.d.ts +0 -1
- package/dist/types/shared/types.d.ts +2 -4
- package/dist/types/utils/Analytics/index.d.ts +3 -2
- package/package.json +6 -7
- package/dist/cjs/shared/components/CTA/index.style.js +0 -47
- package/dist/cjs/shared/components/CTA/index.style.js.map +0 -1
- package/dist/types/playground/style.d.ts +0 -4
|
@@ -2,39 +2,40 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
var navbar_base_1 = require("@lendi-ui/navbar-base");
|
|
4
4
|
var React = require("react");
|
|
5
|
-
var
|
|
5
|
+
var style_1 = require("../../../shared/components/CTA/style");
|
|
6
6
|
var constants_1 = require("../../../shared/constants");
|
|
7
7
|
var Analytics_1 = require("../../../utils/Analytics");
|
|
8
|
-
var
|
|
9
|
-
var LogoutComponent_1 = require("
|
|
8
|
+
var index_style_1 = require("../CTA/index.style");
|
|
9
|
+
var LogoutComponent_1 = require("../../../shared/components/CTA/LogoutComponent");
|
|
10
|
+
var segment_tracking_1 = require("@lendi/segment-tracking");
|
|
11
|
+
var style_2 = require("../../../shared/components/CTA/MobileActions/style");
|
|
10
12
|
var RenderMobileAction = function (_a) {
|
|
11
|
-
var isAuthenticated = _a.isAuthenticated, continueURL = _a.continueURL,
|
|
13
|
+
var isAuthenticated = _a.isAuthenticated, continueURL = _a.continueURL, teamMember = _a.teamMember, _b = _a.openCommPanel, openCommPanel = _b === void 0 ? function () { } : _b, _c = _a.showContinueAction, showContinueAction = _c === void 0 ? false : _c, _d = _a.showTalkToExpertCta, showTalkToExpertCta = _d === void 0 ? true : _d, hasUnreadMessages = _a.hasUnreadMessages;
|
|
12
14
|
var isTransparent = navbar_base_1.useNavbarBaseContext().isTransparent;
|
|
13
15
|
var needToContinue = function () { return isAuthenticated && showContinueAction; };
|
|
14
16
|
var primaryLabel = (teamMember === null || teamMember === void 0 ? void 0 : teamMember.firstName) ? "Talk to " + teamMember.firstName
|
|
15
17
|
: needToContinue()
|
|
16
18
|
? constants_1.CONTACT_US
|
|
17
|
-
: constants_1.
|
|
18
|
-
return (React.createElement(
|
|
19
|
-
showTalkToExpertCta && (React.createElement(
|
|
19
|
+
: constants_1.LABEL_TALK_TO_EXPERT;
|
|
20
|
+
return (React.createElement(style_2.MobileActionsWrapper, null,
|
|
21
|
+
showTalkToExpertCta && (React.createElement(index_style_1.TalkExpertAction, { size: "sm", isInverse: isTransparent, className: "noHover", variant: "secondary", onClick: function () {
|
|
20
22
|
openCommPanel();
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
});
|
|
23
|
+
var trackingEvent = {
|
|
24
|
+
text: 'Talk To Broker',
|
|
25
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
26
|
+
};
|
|
27
|
+
Analytics_1.analytics(trackingEvent);
|
|
27
28
|
} }, hasUnreadMessages ? (React.createElement(React.Fragment, null,
|
|
28
|
-
React.createElement(
|
|
29
|
+
React.createElement(style_1.UnreadMessageWrapper, { "data-testid": "customer-view-unread-icon", color: "primary.500", height: "2em", width: "2em" }),
|
|
29
30
|
constants_1.UNREAD_MESSAGE_MOBILE)) : (React.createElement(React.Fragment, null, primaryLabel)))),
|
|
30
|
-
needToContinue() && (React.createElement(
|
|
31
|
+
needToContinue() && (React.createElement(index_style_1.ContinueAction, { variant: "emphasis", href: continueURL, "aria-label": constants_1.LABEL_CONTINUE, size: "sm", onClick: function () {
|
|
31
32
|
return Analytics_1.analytics({
|
|
32
33
|
event_name: 'Continue to Application',
|
|
33
|
-
category:
|
|
34
|
-
label: constants_1.
|
|
34
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
35
|
+
label: constants_1.LABEL_CONTINUE,
|
|
35
36
|
});
|
|
36
|
-
} }, constants_1.
|
|
37
|
-
isAuthenticated && React.createElement(LogoutComponent_1.
|
|
37
|
+
} }, constants_1.LABEL_CONTINUE)),
|
|
38
|
+
isAuthenticated && React.createElement(LogoutComponent_1.LogoutComponent, null)));
|
|
38
39
|
};
|
|
39
40
|
exports.default = RenderMobileAction;
|
|
40
41
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/SimpleNavbar/components/MobileAction/index.tsx"],"names":[],"mappings":";;AAAA,qDAA6D;AAC7D,6BAA+B;AAE/B,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/SimpleNavbar/components/MobileAction/index.tsx"],"names":[],"mappings":";;AAAA,qDAA6D;AAC7D,6BAA+B;AAE/B,8DAA4E;AAC5E,uDAAoH;AACpH,sDAAqD;AACrD,kDAAsE;AACtE,kFAAiF;AAEjF,4DAAqE;AACrE,4EAA0F;AAE1F,IAAM,kBAAkB,GAAG,UAAC,EAQJ;QAPtB,oCAAe,EACf,4BAAW,EACX,0BAAU,EACV,qBAAwB,EAAxB,oDAAwB,EACxB,0BAA0B,EAA1B,+CAA0B,EAC1B,2BAA0B,EAA1B,+CAA0B,EAC1B,wCAAiB;IAET,IAAA,kEAAa,CAA4B;IACjD,IAAM,cAAc,GAAG,cAAM,OAAA,eAAe,IAAI,kBAAkB,EAArC,CAAqC,CAAC;IACnE,IAAM,YAAY,GAAG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,EACxC,CAAC,CAAC,aAAW,UAAU,CAAC,SAAW;QACnC,CAAC,CAAC,cAAc,EAAE;YAClB,CAAC,CAAC,sBAAU;YACZ,CAAC,CAAC,gCAAoB,CAAC;IAEzB,OAAO,CACL,oBAAC,4BAAoB;QAClB,mBAAmB,IAAI,CACtB,oBAAC,8BAAgB,IACf,IAAI,EAAC,IAAI,EACT,SAAS,EAAE,aAAa,EACxB,SAAS,EAAC,SAAS,EACnB,OAAO,EAAC,WAAW,EACnB,OAAO,EAAE;gBACP,aAAa,EAAE,CAAC;gBAChB,IAAM,aAAa,GAAgB;oBACjC,IAAI,EAAE,gBAAgB;oBACtB,QAAQ,EAAE,gCAAa,CAAC,MAAM;iBAC/B,CAAC;gBACF,qBAAS,CAAC,aAAa,CAAC,CAAC;YAC3B,CAAC,IAEA,iBAAiB,CAAC,CAAC,CAAC,CACnB;YACE,oBAAC,4BAAoB,mBACP,2BAA2B,EACvC,KAAK,EAAC,aAAa,EACnB,MAAM,EAAC,KAAK,EACZ,KAAK,EAAC,KAAK,GACX;YACD,iCAAqB,CACrB,CACJ,CAAC,CAAC,CAAC,CACF,0CAAG,YAAY,CAAI,CACpB,CACgB,CACpB;QACA,cAAc,EAAE,IAAI,CACnB,oBAAC,4BAAc,IACb,OAAO,EAAC,UAAU,EAClB,IAAI,EAAE,WAAW,gBACL,0BAAc,EAC1B,IAAI,EAAC,IAAI,EACT,OAAO,EAAE;gBACP,OAAA,qBAAS,CAAC;oBACR,UAAU,EAAE,yBAAyB;oBACrC,QAAQ,EAAE,gCAAa,CAAC,MAAM;oBAC9B,KAAK,EAAE,0BAAc;iBACtB,CAAC;YAJF,CAIE,IAGH,0BAAc,CACA,CAClB;QACA,eAAe,IAAI,oBAAC,iCAAe,OAAG,CAClB,CACxB,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
var button_1 = require("@lendi-ui/button");
|
|
15
|
+
var navbar_base_1 = require("@lendi-ui/navbar-base");
|
|
16
|
+
var theme_1 = require("@lendi-ui/theme");
|
|
17
|
+
var enzyme_1 = require("enzyme");
|
|
18
|
+
var React = require("react");
|
|
19
|
+
var constants_1 = require("../../../shared/constants");
|
|
20
|
+
var Analytics = require("../../../utils/Analytics");
|
|
21
|
+
var CTA_1 = require("../CTA");
|
|
22
|
+
var index_style_1 = require("../CTA/index.style");
|
|
23
|
+
var style_1 = require("../../../shared/components/CTA/LogoutComponent/style");
|
|
24
|
+
var Analytics_1 = require("../../../utils/Analytics");
|
|
25
|
+
var segment_tracking_1 = require("@lendi/segment-tracking");
|
|
26
|
+
var trackMock = jest.spyOn(Analytics, 'analytics');
|
|
27
|
+
trackMock.mockImplementation(function () { });
|
|
28
|
+
var element;
|
|
29
|
+
var RenderCTAs = function (props) {
|
|
30
|
+
return (React.createElement(navbar_base_1.default, { isTransparent: false },
|
|
31
|
+
React.createElement(CTA_1.default, __assign({}, props))));
|
|
32
|
+
};
|
|
33
|
+
describe('Unauth states', function () {
|
|
34
|
+
beforeEach(function () {
|
|
35
|
+
element = enzyme_1.mount(React.createElement(theme_1.default, null,
|
|
36
|
+
React.createElement(RenderCTAs, { isAuthenticated: false, continueURL: "/", dashboardVariant: false, showTalkToExpertCta: true })));
|
|
37
|
+
});
|
|
38
|
+
describe('Mobile actions', function () {
|
|
39
|
+
it('should render TalkExpertButton only', function () {
|
|
40
|
+
expect(element
|
|
41
|
+
.find(button_1.Button)
|
|
42
|
+
.at(0)
|
|
43
|
+
.text()).toEqual(constants_1.LABEL_TALK_TO_EXPERT);
|
|
44
|
+
});
|
|
45
|
+
it('should track event on signup without auth', function () {
|
|
46
|
+
element
|
|
47
|
+
.find(button_1.Button)
|
|
48
|
+
.at(0)
|
|
49
|
+
.simulate('click');
|
|
50
|
+
expect(Analytics.analytics).toHaveBeenCalledWith({
|
|
51
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
52
|
+
text: 'Talk To Broker',
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
describe('Auth states', function () {
|
|
58
|
+
beforeEach(function () {
|
|
59
|
+
element = enzyme_1.mount(React.createElement(theme_1.default, null,
|
|
60
|
+
React.createElement(RenderCTAs, { isAuthenticated: true, continueURL: "/", dashboardVariant: false, showContinueAction: true })));
|
|
61
|
+
});
|
|
62
|
+
describe('Mobile actions', function () {
|
|
63
|
+
it('should render TalkExpertButton and BookAppointmentButton', function () {
|
|
64
|
+
expect(element
|
|
65
|
+
.find(index_style_1.TalkExpertAction)
|
|
66
|
+
.at(0)
|
|
67
|
+
.text()).toEqual(constants_1.LABEL_TALK_TO_EXPERT);
|
|
68
|
+
expect(element
|
|
69
|
+
.find(button_1.Button)
|
|
70
|
+
.at(1)
|
|
71
|
+
.text()).toEqual(constants_1.LABEL_CONTINUE);
|
|
72
|
+
expect(element.find(style_1.KebabMenu).length).toEqual(2);
|
|
73
|
+
});
|
|
74
|
+
it('should track event on TalkToAnExpert', function () {
|
|
75
|
+
element
|
|
76
|
+
.find(index_style_1.TalkExpertAction)
|
|
77
|
+
.at(0)
|
|
78
|
+
.simulate('click');
|
|
79
|
+
expect(Analytics.analytics).toHaveBeenCalledWith({
|
|
80
|
+
text: 'Talk To Broker',
|
|
81
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
it('should track event on Continue', function () {
|
|
85
|
+
element
|
|
86
|
+
.find(button_1.Button)
|
|
87
|
+
.at(1)
|
|
88
|
+
.simulate('click');
|
|
89
|
+
expect(Analytics.analytics).toHaveBeenCalledWith({
|
|
90
|
+
event_name: Analytics_1.ACTION_CLICK,
|
|
91
|
+
label: constants_1.LABEL_CONTINUE,
|
|
92
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
//# sourceMappingURL=test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test.js","sourceRoot":"","sources":["../../../../../src/SimpleNavbar/components/MobileAction/test.tsx"],"names":[],"mappings":"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"}
|
|
@@ -11,20 +11,20 @@ var breakpoint_1 = require("@lendi-ui/breakpoint");
|
|
|
11
11
|
var lala_react_1 = require("@lendi/lala-react");
|
|
12
12
|
var useUserGroup_1 = require("../shared/hooks/useUserGroup");
|
|
13
13
|
var useTeamMember_1 = require("../shared/hooks/useTeamMember");
|
|
14
|
-
var styled_components_1 = require("styled-components");
|
|
15
14
|
var ErrorBoundry_1 = require("../shared/components/ErrorBoundry");
|
|
16
15
|
var useEmailOpenChat_1 = require("../shared/hooks/useEmailOpenChat");
|
|
17
16
|
var useDomain_1 = require("../shared/hooks/useDomain");
|
|
17
|
+
var provider_1 = require("../shared/components/CTA/LogoutComponent/DropdownMenu/provider");
|
|
18
18
|
var SimpleNavbarComponent = function (_a) {
|
|
19
|
-
var _b = _a.useTransparent, useTransparent = _b === void 0 ? false : _b, _c = _a.showBookanAppointmentCta, showBookanAppointmentCta = _c === void 0 ? true : _c, _d = _a.showTalkToExpertCta, showTalkToExpertCta = _d === void 0 ? true : _d, homeURL = _a.homeURL, _e = _a.params, params = _e === void 0 ? '' : _e, _f = _a.continueURL, continueURL = _f === void 0 ? '/' : _f,
|
|
20
|
-
var
|
|
21
|
-
var
|
|
22
|
-
var
|
|
23
|
-
var
|
|
19
|
+
var _b = _a.useTransparent, useTransparent = _b === void 0 ? false : _b, _c = _a.showBookanAppointmentCta, showBookanAppointmentCta = _c === void 0 ? true : _c, _d = _a.showTalkToExpertCta, showTalkToExpertCta = _d === void 0 ? true : _d, homeURL = _a.homeURL, dashboardURL = _a.dashboardURL, _e = _a.params, params = _e === void 0 ? '' : _e, _f = _a.continueURL, continueURL = _f === void 0 ? '/' : _f, onLogout = _a.onLogout, _g = _a.showContinueAction, showContinueAction = _g === void 0 ? false : _g;
|
|
20
|
+
var _h = comm_panel_1.useCommPanel(), isCommPanelOpen = _h.isCommPanelOpen, openCommPanel = _h.openCommPanel, closeCommPanel = _h.closeCommPanel, openChat = _h.openChat;
|
|
21
|
+
var _j = React.useState(false), unReadMesage = _j[0], setUnReadMessage = _j[1];
|
|
22
|
+
var _k = React.useState(false), isOtherUserOnline = _k[0], setIsOtherUserOnline = _k[1];
|
|
23
|
+
var _l = React.useState(), breakpoint = _l[0], setBreakpoint = _l[1];
|
|
24
24
|
breakpoint_1.useBreakpoint(setBreakpoint);
|
|
25
25
|
var session = lala_react_1.useSession();
|
|
26
26
|
var isAuthenticated = session.status === lala_react_1.Status.Authenticated;
|
|
27
|
-
var
|
|
27
|
+
var _m = useUserGroup_1.useUserGroup(session), userGroupHash = _m[0], teamMemberId = _m[1];
|
|
28
28
|
var latestTeamMember = useTeamMember_1.useTeamMember(session, teamMemberId);
|
|
29
29
|
useEmailOpenChat_1.useEmailOpenChat(openChat, userGroupHash);
|
|
30
30
|
return (React.createElement(ErrorBoundry_1.ErrorBoundary, null,
|
|
@@ -36,12 +36,10 @@ var SimpleNavbarComponent = function (_a) {
|
|
|
36
36
|
React.createElement(navbar_base_1.default.Left, null,
|
|
37
37
|
React.createElement(Logo_1.default, { homeURL: homeURL, params: params, "aria-label": "Lendi Logo", hasHamburgerMenu: false })),
|
|
38
38
|
React.createElement(navbar_base_1.default.Right, null,
|
|
39
|
-
React.createElement(
|
|
40
|
-
|
|
41
|
-
onLogout();
|
|
42
|
-
}, showContinueAction: showContinueAction, openCommPanel: function () { return (isCommPanelOpen ? closeCommPanel() : openCommPanel()); }, teamMember: latestTeamMember, hasUnreadMessages: unReadMesage }))),
|
|
39
|
+
React.createElement(provider_1.DropdownProvider, { dashboardURL: dashboardURL, onLogout: onLogout },
|
|
40
|
+
React.createElement(CTA_1.default, { showTalkToExpertCta: showTalkToExpertCta, showBookanAppointmentCta: showBookanAppointmentCta, isAuthenticated: isAuthenticated, continueURL: continueURL, showContinueAction: showContinueAction, openCommPanel: function () { return (isCommPanelOpen ? closeCommPanel() : openCommPanel()); }, teamMember: latestTeamMember, hasUnreadMessages: unReadMesage })))),
|
|
43
41
|
React.createElement(transition_1.default, { isActive: isCommPanelOpen, timeout: 250 }, function (state) { return (React.createElement(styles_1.CommPanelWrapper, { transition: state, toTheTop: breakpoint === 'mobile' },
|
|
44
42
|
React.createElement(comm_panel_1.CustomerCommPanel, { channelId: userGroupHash, latestTeamMember: latestTeamMember, hasNew: unReadMesage, isOtherUserOnline: isOtherUserOnline }))); }))));
|
|
45
43
|
};
|
|
46
|
-
exports.SimpleNavbar = comm_panel_1.withCommPanelProvider(
|
|
44
|
+
exports.SimpleNavbar = comm_panel_1.withCommPanelProvider(useDomain_1.withDomainChat(SimpleNavbarComponent));
|
|
47
45
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/SimpleNavbar/index.tsx"],"names":[],"mappings":";;AAAA,qDAA+C;AAC/C,6BAA+B;AAC/B,kDAAsD;AACtD,2CAAyE;AAEzE,wCAA0C;AAC1C,gDAAkH;AAClH,mDAAyD;AACzD,mDAAqE;AACrE,gDAAuD;AACvD,6DAA4D;AAC5D,+DAA8D;AAC9D,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/SimpleNavbar/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
var style_1 = require("../style");
|
|
4
|
+
var Analytics_1 = require("../../../../utils/Analytics");
|
|
5
|
+
var segment_tracking_1 = require("@lendi/segment-tracking");
|
|
6
|
+
var constants_1 = require("../../../constants");
|
|
7
|
+
var LogoutComponent_1 = require("../LogoutComponent");
|
|
8
|
+
var React = require("react");
|
|
9
|
+
var style_2 = require("./style");
|
|
10
|
+
exports.DesktopActions = function (_a) {
|
|
11
|
+
var isAuthenticated = _a.isAuthenticated, continueURL = _a.continueURL, _b = _a.showContinueAction, showContinueAction = _b === void 0 ? false : _b, _c = _a.openCommPanel, openCommPanel = _c === void 0 ? function () { } : _c, teamMember = _a.teamMember, hasUnreadMessages = _a.hasUnreadMessages, showTalkToExpertCta = _a.showTalkToExpertCta;
|
|
12
|
+
var primaryLabel = (teamMember === null || teamMember === void 0 ? void 0 : teamMember.firstName) ? "Talk to " + teamMember.firstName : constants_1.LABEL_TALK_TO_EXPERT;
|
|
13
|
+
return (React.createElement(style_2.DesktopActionsWrapper, null,
|
|
14
|
+
showTalkToExpertCta && (React.createElement(style_1.TalkExpertAction, { variant: "secondary", onClick: function () {
|
|
15
|
+
openCommPanel();
|
|
16
|
+
var trackingEvent = {
|
|
17
|
+
text: 'Talk To Broker',
|
|
18
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
19
|
+
authenticationStatus: isAuthenticated
|
|
20
|
+
? segment_tracking_1.AuthenticationStatus.AUTHENTICATED
|
|
21
|
+
: segment_tracking_1.AuthenticationStatus.UNAUTHENTICATED,
|
|
22
|
+
};
|
|
23
|
+
Analytics_1.analytics(trackingEvent);
|
|
24
|
+
}, size: "sm", bigLabelAccomodate: isAuthenticated ? !showContinueAction : false }, hasUnreadMessages ? (React.createElement(React.Fragment, null,
|
|
25
|
+
React.createElement(style_1.UnreadMessageWrapper, { "data-testid": "customer-view-unread-icon", color: "primary.500", height: "2em", width: "2em" }),
|
|
26
|
+
constants_1.UNREAD_MESSAGE)) : (React.createElement(React.Fragment, null, primaryLabel)))),
|
|
27
|
+
React.createElement(style_1.SecondaryAction, { bigLabelAccomodate: isAuthenticated ? (showContinueAction ? false : true) : false, size: "sm", variant: isAuthenticated ? (showContinueAction ? 'emphasis' : 'primary') : 'primary', href: isAuthenticated ? (showContinueAction ? continueURL : constants_1.ROUTE_BOOK_APPOINTMENT) : constants_1.ROUTE_SIGN_IN, onClick: function () {
|
|
28
|
+
return Analytics_1.analytics({
|
|
29
|
+
event_name: isAuthenticated ? (showContinueAction ? constants_1.LABEL_CONTINUE : constants_1.BOOK_AN_APPOINTMENT) : constants_1.LABEL_SIGN_IN,
|
|
30
|
+
label: isAuthenticated ? (showContinueAction ? constants_1.LABEL_CONTINUE : constants_1.BOOK_AN_APPOINTMENT) : constants_1.LABEL_SIGN_IN,
|
|
31
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
32
|
+
});
|
|
33
|
+
}, "aria-label": isAuthenticated ? (showContinueAction ? constants_1.LABEL_CONTINUE : constants_1.BOOK_AN_APPOINTMENT) : constants_1.LABEL_SIGN_IN }, isAuthenticated ? (showContinueAction ? constants_1.LABEL_CONTINUE : constants_1.BOOK_AN_APPOINTMENT) : constants_1.LABEL_SIGN_IN),
|
|
34
|
+
isAuthenticated && React.createElement(LogoutComponent_1.LogoutComponent, null)));
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/shared/components/CTA/DesktopActions/index.tsx"],"names":[],"mappings":";;AAAA,kCAAmF;AACnF,yDAAwD;AACxD,4DAA2F;AAC3F,gDAQ4B;AAC5B,sDAAqD;AACrD,6BAA+B;AAG/B,iCAAgD;AAEnC,QAAA,cAAc,GAAG,UAAC,EAQP;QAPtB,oCAAe,EACf,4BAAW,EACX,0BAA0B,EAA1B,+CAA0B,EAC1B,qBAAwB,EAAxB,oDAAwB,EACxB,0BAAU,EACV,wCAAiB,EACjB,4CAAmB;IAEnB,IAAM,YAAY,GAAG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,EAAC,CAAC,CAAC,aAAW,UAAU,CAAC,SAAW,CAAC,CAAC,CAAC,gCAAoB,CAAC;IAEtG,OAAO,CACL,oBAAC,6BAAqB;QACnB,mBAAmB,IAAI,CACtB,oBAAC,wBAAgB,IACf,OAAO,EAAC,WAAW,EACnB,OAAO,EAAE;gBACP,aAAa,EAAE,CAAC;gBAChB,IAAM,aAAa,GAAgB;oBACjC,IAAI,EAAE,gBAAgB;oBACtB,QAAQ,EAAE,gCAAa,CAAC,MAAM;oBAC9B,oBAAoB,EAAE,eAAe;wBACnC,CAAC,CAAC,uCAAoB,CAAC,aAAa;wBACpC,CAAC,CAAC,uCAAoB,CAAC,eAAe;iBACzC,CAAC;gBACF,qBAAS,CAAC,aAAa,CAAC,CAAC;YAC3B,CAAC,EACD,IAAI,EAAC,IAAI,EACT,kBAAkB,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,KAAK,IAEhE,iBAAiB,CAAC,CAAC,CAAC,CACnB;YACE,oBAAC,4BAAoB,mBACP,2BAA2B,EACvC,KAAK,EAAC,aAAa,EACnB,MAAM,EAAC,KAAK,EACZ,KAAK,EAAC,KAAK,GACX;YACD,0BAAc,CACd,CACJ,CAAC,CAAC,CAAC,CACF,0CAAG,YAAY,CAAI,CACpB,CACgB,CACpB;QACD,oBAAC,uBAAe,IACd,kBAAkB,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,EACjF,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,EACpF,IAAI,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,kCAAsB,CAAC,CAAC,CAAC,CAAC,yBAAa,EACnG,OAAO,EAAE;gBACP,OAAA,qBAAS,CAAC;oBACR,UAAU,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,0BAAc,CAAC,CAAC,CAAC,+BAAmB,CAAC,CAAC,CAAC,CAAC,yBAAa;oBACzG,KAAK,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,0BAAc,CAAC,CAAC,CAAC,+BAAmB,CAAC,CAAC,CAAC,CAAC,yBAAa;oBACpG,QAAQ,EAAE,gCAAa,CAAC,MAAM;iBAC/B,CAAC;YAJF,CAIE,gBAEQ,eAAe,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,0BAAc,CAAC,CAAC,CAAC,+BAAmB,CAAC,CAAC,CAAC,CAAC,yBAAa,IAExG,eAAe,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,0BAAc,CAAC,CAAC,CAAC,+BAAmB,CAAC,CAAC,CAAC,CAAC,yBAAa,CAC9E;QAEjB,eAAe,IAAI,oBAAC,iCAAe,OAAG,CACjB,CACzB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
|
|
3
|
+
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
|
|
4
|
+
return cooked;
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
var styled_components_1 = require("styled-components");
|
|
8
|
+
var breakpoint_1 = require("@lendi-ui/breakpoint");
|
|
9
|
+
exports.DesktopActionsWrapper = styled_components_1.default.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n display: flex;\n ", ";\n"], ["\n display: flex;\n ",
|
|
10
|
+
";\n"])), breakpoint_1.between('mobile', 'desktop')(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n display: none;\n "], ["\n display: none;\n "]))));
|
|
11
|
+
var templateObject_1, templateObject_2;
|
|
12
|
+
//# sourceMappingURL=style.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"style.js","sourceRoot":"","sources":["../../../../../../src/shared/components/CTA/DesktopActions/style.tsx"],"names":[],"mappings":";;;;;;AAAA,uDAAuC;AACvC,mDAA+C;AAElC,QAAA,qBAAqB,GAAG,2BAAM,CAAC,GAAG,kGAAA,wBAE3C;IAED,KACF,KAHG,oBAAO,CAAC,QAAQ,EAAE,SAAS,CAAC,6FAAA,0BAE7B,MACD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../../src/shared/components/CTA/LogoutComponent/DropdownMenu/constants.ts"],"names":[],"mappings":";;AAAa,QAAA,kBAAkB,GAC7B,4GAA4G,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
var React = require("react");
|
|
4
|
+
var state_1 = require("./state");
|
|
5
|
+
exports.DropdownMenuContext = React.createContext(state_1.initialState);
|
|
6
|
+
exports.useDropdownMenu = function () {
|
|
7
|
+
var state = React.useContext(exports.DropdownMenuContext);
|
|
8
|
+
if (!state) {
|
|
9
|
+
throw new Error('Please setup <DropdownMenuProvider /> as a parent component, before using useDropdownMenu().');
|
|
10
|
+
}
|
|
11
|
+
return state;
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../../../../../src/shared/components/CTA/LogoutComponent/DropdownMenu/context.ts"],"names":[],"mappings":";;AAAA,6BAA+B;AAC/B,iCAA0D;AAE7C,QAAA,mBAAmB,GAAG,KAAK,CAAC,aAAa,CAAoB,oBAAY,CAAC,CAAC;AAE3E,QAAA,eAAe,GAAG;IAC7B,IAAM,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,2BAAmB,CAAC,CAAC;IAEpD,IAAI,CAAC,KAAK,EAAE;QACV,MAAM,IAAI,KAAK,CAAC,8FAA8F,CAAC,CAAC;KACjH;IAED,OAAO,KAAK,CAAC;AACf,CAAC,CAAC"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
var React = require("react");
|
|
4
|
+
var style_1 = require("./style");
|
|
5
|
+
var Analytics_1 = require("../../../../../utils/Analytics");
|
|
6
|
+
var constants_1 = require("../../../../constants");
|
|
7
|
+
var context_1 = require("./context");
|
|
8
|
+
var lala_react_1 = require("@lendi/lala-react");
|
|
9
|
+
var segment_tracking_1 = require("@lendi/segment-tracking");
|
|
10
|
+
var lala_utils_1 = require("@lendi/lala-utils");
|
|
11
|
+
exports.DropdownMenu = function () {
|
|
12
|
+
var isDomain = lala_utils_1.getBrandFromHostname() === lala_utils_1.Brand.Domain;
|
|
13
|
+
var path = isDomain ? constants_1.PATH_DOMAIN : constants_1.PATH_LENDI;
|
|
14
|
+
var session = lala_react_1.useSession();
|
|
15
|
+
var _a = context_1.useDropdownMenu(), dashboardURL = _a.dashboardURL, onLogout = _a.onLogout;
|
|
16
|
+
return (React.createElement(style_1.LogoutWrapper, null,
|
|
17
|
+
React.createElement(style_1.MyAccountTitle, null, "My account"),
|
|
18
|
+
React.createElement(style_1.LinkWrapper, { color: "shade.700", onClick: function () {
|
|
19
|
+
Analytics_1.analytics({
|
|
20
|
+
event_name: constants_1.LABEL_APPLICATIONS,
|
|
21
|
+
action: Analytics_1.ACTION_CLICK,
|
|
22
|
+
label: constants_1.LABEL_APPLICATIONS,
|
|
23
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
24
|
+
});
|
|
25
|
+
}, href: "" + path + constants_1.ROUTE_APPLICATIONS, "aria-label": constants_1.LABEL_APPLICATIONS }, constants_1.LABEL_APPLICATIONS),
|
|
26
|
+
dashboardURL && (React.createElement(style_1.LinkWrapper, { color: "shade.700", onClick: function () {
|
|
27
|
+
session.logout();
|
|
28
|
+
onLogout();
|
|
29
|
+
Analytics_1.analytics({
|
|
30
|
+
event_name: constants_1.LABEL_DASHBOARD,
|
|
31
|
+
action: Analytics_1.ACTION_CLICK,
|
|
32
|
+
label: constants_1.LABEL_DASHBOARD,
|
|
33
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
34
|
+
});
|
|
35
|
+
}, href: "" + path + dashboardURL, "aria-label": constants_1.LABEL_DASHBOARD }, constants_1.LABEL_DASHBOARD)),
|
|
36
|
+
React.createElement(style_1.LinkWrapper, { color: "shade.700", onClick: function () {
|
|
37
|
+
Analytics_1.analytics({
|
|
38
|
+
event_name: constants_1.LABEL_PROPERTY_REPORT,
|
|
39
|
+
action: Analytics_1.ACTION_CLICK,
|
|
40
|
+
label: constants_1.LABEL_PROPERTY_REPORT,
|
|
41
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
42
|
+
});
|
|
43
|
+
}, href: "" + path + constants_1.ROUTE_PROPERTY_REPORT, target: "_blank", "aria-label": constants_1.LABEL_PROPERTY_REPORT },
|
|
44
|
+
constants_1.LABEL_PROPERTY_REPORT,
|
|
45
|
+
React.createElement(style_1.LaunchIcon, { width: "18px", height: "18px" })),
|
|
46
|
+
React.createElement(style_1.LinkWrapper, { color: "shade.700", onClick: function () {
|
|
47
|
+
onLogout();
|
|
48
|
+
Analytics_1.analytics({
|
|
49
|
+
event_name: constants_1.LABEL_LOG_OUT,
|
|
50
|
+
action: Analytics_1.ACTION_CLICK,
|
|
51
|
+
label: constants_1.LABEL_LOG_OUT,
|
|
52
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
53
|
+
});
|
|
54
|
+
}, "aria-label": constants_1.LABEL_LOG_OUT }, constants_1.LABEL_LOG_OUT)));
|
|
55
|
+
};
|
|
56
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../src/shared/components/CTA/LogoutComponent/DropdownMenu/index.tsx"],"names":[],"mappings":";;AAAA,6BAA+B;AAC/B,iCAAiF;AACjF,4DAAyE;AACzE,mDAS+B;AAC/B,qCAA4C;AAC5C,gDAA+C;AAC/C,4DAAwD;AACxD,gDAAgE;AAEnD,QAAA,YAAY,GAAG;IAC1B,IAAM,QAAQ,GAAG,iCAAoB,EAAE,KAAK,kBAAK,CAAC,MAAM,CAAC;IACzD,IAAM,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,uBAAW,CAAC,CAAC,CAAC,sBAAU,CAAC;IAEjD,IAAM,OAAO,GAAG,uBAAU,EAAE,CAAC;IACvB,IAAA,gCAA8C,EAA5C,8BAAY,EAAE,sBAA8B,CAAC;IAErD,OAAO,CACL,oBAAC,qBAAa;QACZ,oBAAC,sBAAc,qBAA4B;QAC3C,oBAAC,mBAAW,IACV,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE;gBACP,qBAAS,CAAC;oBACR,UAAU,EAAE,8BAAkB;oBAC9B,MAAM,EAAE,wBAAY;oBACpB,KAAK,EAAE,8BAAkB;oBACzB,QAAQ,EAAE,gCAAa,CAAC,MAAM;iBAC/B,CAAC,CAAC;YACL,CAAC,EACD,IAAI,EAAE,KAAG,IAAI,GAAG,8BAAoB,gBACxB,8BAAkB,IAE7B,8BAAkB,CACP;QACb,YAAY,IAAI,CACf,oBAAC,mBAAW,IACV,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE;gBACP,OAAO,CAAC,MAAM,EAAE,CAAC;gBACjB,QAAS,EAAE,CAAC;gBACZ,qBAAS,CAAC;oBACR,UAAU,EAAE,2BAAe;oBAC3B,MAAM,EAAE,wBAAY;oBACpB,KAAK,EAAE,2BAAe;oBACtB,QAAQ,EAAE,gCAAa,CAAC,MAAM;iBAC/B,CAAC,CAAC;YACL,CAAC,EACD,IAAI,EAAE,KAAG,IAAI,GAAG,YAAc,gBAClB,2BAAe,IAE1B,2BAAe,CACJ,CACf;QACD,oBAAC,mBAAW,IACV,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE;gBACP,qBAAS,CAAC;oBACR,UAAU,EAAE,iCAAqB;oBACjC,MAAM,EAAE,wBAAY;oBACpB,KAAK,EAAE,iCAAqB;oBAC5B,QAAQ,EAAE,gCAAa,CAAC,MAAM;iBAC/B,CAAC,CAAC;YACL,CAAC,EACD,IAAI,EAAE,KAAG,IAAI,GAAG,iCAAuB,EACvC,MAAM,EAAC,QAAQ,gBACH,iCAAqB;YAEhC,iCAAqB;YACtB,oBAAC,kBAAU,IAAC,KAAK,EAAC,MAAM,EAAC,MAAM,EAAC,MAAM,GAAG,CAC7B;QACd,oBAAC,mBAAW,IACV,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE;gBACP,QAAS,EAAE,CAAC;gBACZ,qBAAS,CAAC;oBACR,UAAU,EAAE,yBAAa;oBACzB,MAAM,EAAE,wBAAY;oBACpB,KAAK,EAAE,yBAAa;oBACpB,QAAQ,EAAE,gCAAa,CAAC,MAAM;iBAC/B,CAAC,CAAC;YACL,CAAC,gBACW,yBAAa,IAExB,yBAAa,CACF,CACA,CACjB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
var React = require("react");
|
|
4
|
+
var context_1 = require("./context");
|
|
5
|
+
exports.DropdownProvider = function (_a) {
|
|
6
|
+
var children = _a.children, dashboardURL = _a.dashboardURL, onLogout = _a.onLogout;
|
|
7
|
+
return (React.createElement(context_1.DropdownMenuContext.Provider, { value: {
|
|
8
|
+
dashboardURL: dashboardURL,
|
|
9
|
+
onLogout: onLogout,
|
|
10
|
+
} }, children));
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../../../../../src/shared/components/CTA/LogoutComponent/DropdownMenu/provider.tsx"],"names":[],"mappings":";;AAAA,6BAA+B;AAC/B,qCAAgD;AAGnC,QAAA,gBAAgB,GAA+C,UAAC,EAAoC;QAAlC,sBAAQ,EAAE,8BAAY,EAAE,sBAAQ;IAC7G,OAAO,CACL,oBAAC,6BAAmB,CAAC,QAAQ,IAC3B,KAAK,EAAE;YACL,YAAY,cAAA;YACZ,QAAQ,UAAA;SACT,IAEA,QAAQ,CACoB,CAChC,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../src/shared/components/CTA/LogoutComponent/DropdownMenu/state.ts"],"names":[],"mappings":";;AAKa,QAAA,YAAY,GAAsB;IAC7C,YAAY,EAAE,SAAS;IACvB,QAAQ,EAAE,SAAS;CACpB,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
|
|
3
|
+
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
|
|
4
|
+
return cooked;
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
var breakpoint_1 = require("@lendi-ui/breakpoint");
|
|
8
|
+
var color_1 = require("@lendi-ui/color");
|
|
9
|
+
var depth_1 = require("@lendi-ui/depth");
|
|
10
|
+
var Launch_1 = require("@lendi-ui/icon/Launch");
|
|
11
|
+
var spacing_1 = require("@lendi-ui/spacing");
|
|
12
|
+
var theme_1 = require("@lendi-ui/theme");
|
|
13
|
+
var typography_1 = require("@lendi-ui/typography");
|
|
14
|
+
var styled_components_1 = require("styled-components");
|
|
15
|
+
exports.LogoutWrapper = styled_components_1.default.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n position: absolute;\n right: 5px;\n top: 56px;\n\n ", ";\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n\n border-radius: ", ";\n\n ", " ", "\n"], ["\n position: absolute;\n right: 5px;\n top: 56px;\n\n ", ";\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n\n border-radius: ", ";\n\n ", " ", "\n"])), breakpoint_1.gte('desktop')(templateObject_1 || (templateObject_1 = __makeTemplateObject(["top: 70px;"], ["top: 70px;"]))), theme_1.select('borderRadius'), depth_1.depth(2), color_1.bg('shade.0'));
|
|
16
|
+
var MenuItem = styled_components_1.css(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n ", "\n ", "\n"], ["\n ", "\n ", "\n"])), spacing_1.px('sm'), spacing_1.py('sm'));
|
|
17
|
+
exports.MyAccountTitle = styled_components_1.default(typography_1.Body)(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n ", ";\n font-weight: bold;\n width: 100%;\n box-sizing: border-box;\n border-bottom: 1px solid ", ";\n"], ["\n ", ";\n font-weight: bold;\n width: 100%;\n box-sizing: border-box;\n border-bottom: 1px solid ", ";\n"])), MenuItem, color_1.color('shade.100'));
|
|
18
|
+
exports.LinkWrapper = styled_components_1.default(typography_1.Link)(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n ", ";\n overflow: hidden;\n text-decoration: none;\n font-weight: normal;\n width: 100%;\n text-align: left;\n box-sizing: border-box;\n background-color: transparent;\n"], ["\n ", ";\n overflow: hidden;\n text-decoration: none;\n font-weight: normal;\n width: 100%;\n text-align: left;\n box-sizing: border-box;\n background-color: transparent;\n"])), MenuItem);
|
|
19
|
+
exports.LaunchIcon = styled_components_1.default(Launch_1.default)(templateObject_6 || (templateObject_6 = __makeTemplateObject(["\n ", "\n"], ["\n ", "\n"])), spacing_1.mx('xl'));
|
|
20
|
+
var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6;
|
|
21
|
+
//# sourceMappingURL=style.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"style.js","sourceRoot":"","sources":["../../../../../../../src/shared/components/CTA/LogoutComponent/DropdownMenu/style.tsx"],"names":[],"mappings":";;;;;;AAAA,mDAA2C;AAC3C,yCAA4C;AAC5C,yCAAwC;AACxC,gDAA2C;AAC3C,6CAA+C;AAC/C,yCAAyC;AACzC,mDAAkD;AAClD,uDAAgD;AAEnC,QAAA,aAAa,GAAG,2BAAM,CAAC,GAAG,kRAAA,4DAKnC,EAA0B,2HAOX,EAAsB,SAErC,EAAQ,GAAI,EAAa,IAC5B,KAVG,gBAAG,CAAC,SAAS,CAAC,+EAAA,YAAY,MAOX,cAAM,CAAC,cAAc,CAAC,EAErC,aAAK,CAAC,CAAC,CAAC,EAAI,UAAE,CAAC,SAAS,CAAC,EAC3B;AAEF,IAAM,QAAQ,GAAG,uBAAG,uFAAA,MAChB,EAAQ,MACR,EAAQ,IACX,KAFG,YAAE,CAAC,IAAI,CAAC,EACR,YAAE,CAAC,IAAI,CAAC,CACX,CAAC;AAEW,QAAA,cAAc,GAAG,2BAAM,CAAC,iBAAI,CAAC,mLAAA,MACtC,EAAQ,iGAIiB,EAAkB,KAC9C,KALG,QAAQ,EAIiB,aAAK,CAAC,WAAW,CAAC,EAC7C;AAEW,QAAA,WAAW,GAAG,2BAAM,CAAC,iBAAI,CAAC,yPAAA,MACnC,EAAQ,8KAQX,KARG,QAAQ,EAQV;AAEW,QAAA,UAAU,GAAG,2BAAM,CAAC,gBAAM,CAAC,+EAAA,MACpC,EAAQ,IACX,KADG,YAAE,CAAC,IAAI,CAAC,EACV"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
var enzyme_1 = require("enzyme");
|
|
4
|
+
var theme_1 = require("@lendi-ui/theme");
|
|
5
|
+
var React = require("react");
|
|
6
|
+
var _1 = require("./");
|
|
7
|
+
var lala_react_1 = require("@lendi/lala-react");
|
|
8
|
+
var session_1 = require("@lendi/comm-panel/src/utils/session");
|
|
9
|
+
var navbar_base_1 = require("@lendi-ui/navbar-base");
|
|
10
|
+
var constants_1 = require("../../../../constants");
|
|
11
|
+
var provider_1 = require("./provider");
|
|
12
|
+
var constants_2 = require("./constants");
|
|
13
|
+
var LendiComponent = function (_a) {
|
|
14
|
+
var dashboardURL = _a.dashboardURL, onLogout = _a.onLogout;
|
|
15
|
+
return (React.createElement(theme_1.default, null,
|
|
16
|
+
React.createElement(lala_react_1.SessionProvider, { session: session_1.session },
|
|
17
|
+
React.createElement(navbar_base_1.default, { isTransparent: false },
|
|
18
|
+
React.createElement(provider_1.DropdownProvider, { dashboardURL: dashboardURL, onLogout: onLogout },
|
|
19
|
+
React.createElement(_1.DropdownMenu, null))))));
|
|
20
|
+
};
|
|
21
|
+
var element;
|
|
22
|
+
describe('DropdownMenu', function () {
|
|
23
|
+
var onLogoutMock = jest.fn();
|
|
24
|
+
beforeEach(function () {
|
|
25
|
+
element = enzyme_1.mount(React.createElement(LendiComponent, { onLogout: onLogoutMock }));
|
|
26
|
+
});
|
|
27
|
+
it('should mount', function () {
|
|
28
|
+
expect(element.find(_1.DropdownMenu)).toHaveLength(1);
|
|
29
|
+
});
|
|
30
|
+
it('should render Applications link', function () {
|
|
31
|
+
expect(element
|
|
32
|
+
.find({ 'aria-label': constants_1.LABEL_APPLICATIONS })
|
|
33
|
+
.hostNodes()
|
|
34
|
+
.prop('href')).toBe("" + constants_1.PATH_LENDI + constants_1.ROUTE_APPLICATIONS);
|
|
35
|
+
});
|
|
36
|
+
describe('if `dashboardURL` prop is provided', function () {
|
|
37
|
+
var element2 = enzyme_1.mount(React.createElement(LendiComponent, { onLogout: onLogoutMock, dashboardURL: constants_2.sampleDashboardURL }));
|
|
38
|
+
it('should render Dashboard link', function () {
|
|
39
|
+
expect(element2
|
|
40
|
+
.find({ children: constants_1.LABEL_DASHBOARD })
|
|
41
|
+
.hostNodes()
|
|
42
|
+
.exists()).toBe(true);
|
|
43
|
+
});
|
|
44
|
+
it('should render the correct Dashboard link', function () {
|
|
45
|
+
expect(element2
|
|
46
|
+
.find({ children: constants_1.LABEL_DASHBOARD })
|
|
47
|
+
.hostNodes()
|
|
48
|
+
.prop('href')).toBe("" + constants_1.PATH_LENDI + constants_2.sampleDashboardURL);
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
describe('if `dashboardURL` prop is not provided', function () {
|
|
52
|
+
var element2 = enzyme_1.mount(React.createElement(LendiComponent, { onLogout: onLogoutMock }));
|
|
53
|
+
it('should hide Dashboard link', function () {
|
|
54
|
+
expect(element2
|
|
55
|
+
.find({ children: constants_1.LABEL_DASHBOARD })
|
|
56
|
+
.hostNodes()
|
|
57
|
+
.exists()).toBe(false);
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
it('should render Property Report link', function () {
|
|
61
|
+
expect(element
|
|
62
|
+
.find({ 'aria-label': constants_1.LABEL_PROPERTY_REPORT })
|
|
63
|
+
.hostNodes()
|
|
64
|
+
.prop('href')).toBe("" + constants_1.PATH_LENDI + constants_1.ROUTE_PROPERTY_REPORT);
|
|
65
|
+
});
|
|
66
|
+
it('should open Property Report in a new tab', function () {
|
|
67
|
+
expect(element
|
|
68
|
+
.find({ 'aria-label': constants_1.LABEL_PROPERTY_REPORT })
|
|
69
|
+
.hostNodes()
|
|
70
|
+
.prop('target')).toBe('_blank');
|
|
71
|
+
});
|
|
72
|
+
it('should fire onLogout() event', function () {
|
|
73
|
+
element
|
|
74
|
+
.find({ children: constants_1.LABEL_LOG_OUT })
|
|
75
|
+
.hostNodes()
|
|
76
|
+
.simulate('click');
|
|
77
|
+
expect(onLogoutMock).toHaveBeenCalled();
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
//# sourceMappingURL=test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test.js","sourceRoot":"","sources":["../../../../../../../src/shared/components/CTA/LogoutComponent/DropdownMenu/test.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
var MoreVert_1 = require("@lendi-ui/icon/MoreVert");
|
|
4
|
+
var navbar_base_1 = require("@lendi-ui/navbar-base");
|
|
5
|
+
var React = require("react");
|
|
6
|
+
var DropdownMenu_1 = require("./DropdownMenu");
|
|
7
|
+
var Analytics_1 = require("../../../../utils/Analytics");
|
|
8
|
+
var style_1 = require("./style");
|
|
9
|
+
var constants_1 = require("../../../constants");
|
|
10
|
+
var segment_tracking_1 = require("@lendi/segment-tracking");
|
|
11
|
+
exports.LogoutComponent = function () {
|
|
12
|
+
var isTransparent = navbar_base_1.useNavbarBaseContext().isTransparent;
|
|
13
|
+
var _a = React.useState(false), isLogoutDisplay = _a[0], setIsLogoutDisplay = _a[1];
|
|
14
|
+
var logoutPanel = React.useRef();
|
|
15
|
+
var closeLogoutPanel = function (e) {
|
|
16
|
+
if (logoutPanel && logoutPanel.current && !logoutPanel.current.contains(e.target)) {
|
|
17
|
+
setIsLogoutDisplay(false);
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
React.useEffect(function () {
|
|
21
|
+
window.addEventListener('mousedown', closeLogoutPanel);
|
|
22
|
+
return function () {
|
|
23
|
+
window.removeEventListener('mousedown', closeLogoutPanel);
|
|
24
|
+
};
|
|
25
|
+
});
|
|
26
|
+
return (React.createElement("div", { ref: logoutPanel },
|
|
27
|
+
React.createElement(style_1.KebabMenu, { size: "sm", color: isTransparent ? 'shade.0' : 'secondary.500', onClick: function () {
|
|
28
|
+
setIsLogoutDisplay(!isLogoutDisplay);
|
|
29
|
+
Analytics_1.analytics({
|
|
30
|
+
event_name: constants_1.LABEL_MORE_OPTIONS,
|
|
31
|
+
action: Analytics_1.ACTION_CLICK,
|
|
32
|
+
label: constants_1.LABEL_MORE_OPTIONS,
|
|
33
|
+
category: segment_tracking_1.EventCategory.NAVBAR,
|
|
34
|
+
});
|
|
35
|
+
}, "aria-label": constants_1.LABEL_MORE_OPTIONS, icon: MoreVert_1.default }),
|
|
36
|
+
isLogoutDisplay && React.createElement(DropdownMenu_1.DropdownMenu, null)));
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/shared/components/CTA/LogoutComponent/index.tsx"],"names":[],"mappings":";;AAAA,oDAA+C;AAC/C,qDAA6D;AAC7D,6BAA+B;AAC/B,+CAA8C;AAC9C,yDAAsE;AACtE,iCAAoC;AACpC,gDAAwD;AACxD,4DAAwD;AAE3C,QAAA,eAAe,GAAG;IACrB,IAAA,kEAAa,CAA4B;IAC3C,IAAA,0BAA6D,EAA5D,uBAAe,EAAE,0BAA2C,CAAC;IACpE,IAAM,WAAW,GAAG,KAAK,CAAC,MAAM,EAA8C,CAAC;IAC/E,IAAM,gBAAgB,GAAG,UAAC,CAAa;QACrC,IAAI,WAAW,IAAI,WAAW,CAAC,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAqB,CAAC,EAAE;YAChG,kBAAkB,CAAC,KAAK,CAAC,CAAC;SAC3B;IACH,CAAC,CAAC;IAEF,KAAK,CAAC,SAAS,CAAC;QACd,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;QACvD,OAAO;YACL,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;QAC5D,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,OAAO,CACL,6BAAK,GAAG,EAAE,WAAW;QACnB,oBAAC,iBAAS,IACR,IAAI,EAAC,IAAI,EACT,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,EAClD,OAAO,EAAE;gBACP,kBAAkB,CAAC,CAAC,eAAe,CAAC,CAAC;gBACrC,qBAAS,CAAC;oBACR,UAAU,EAAE,8BAAkB;oBAC9B,MAAM,EAAE,wBAAY;oBACpB,KAAK,EAAE,8BAAkB;oBACzB,QAAQ,EAAE,gCAAa,CAAC,MAAM;iBAC/B,CAAC,CAAC;YACL,CAAC,gBACW,8BAAkB,EAC9B,IAAI,EAAE,kBAAQ,GACd;QACD,eAAe,IAAI,oBAAC,2BAAY,OAAG,CAChC,CACP,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
|
|
3
|
+
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
|
|
4
|
+
return cooked;
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
var styled_components_1 = require("styled-components");
|
|
8
|
+
var button_1 = require("@lendi-ui/button");
|
|
9
|
+
var spacing_1 = require("@lendi-ui/spacing");
|
|
10
|
+
exports.KebabMenu = styled_components_1.default(button_1.IconButton)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n ", "\n"], ["\n ", "\n"])), spacing_1.ml('xxxs'));
|
|
11
|
+
var templateObject_1;
|
|
12
|
+
//# sourceMappingURL=style.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"style.js","sourceRoot":"","sources":["../../../../../../src/shared/components/CTA/LogoutComponent/style.tsx"],"names":[],"mappings":";;;;;;AAAA,uDAAuC;AACvC,2CAA8C;AAC9C,6CAAuC;AAE1B,QAAA,SAAS,GAAG,2BAAM,CAAC,mBAAU,CAAC,+EAAA,MACvC,EAAU,IACb,KADG,YAAE,CAAC,MAAM,CAAC,EACZ"}
|