pds-dev-kit-web-test 0.0.6 → 0.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 (156) hide show
  1. package/README.md +1 -1
  2. package/dist/index.d.ts +4 -4
  3. package/dist/index.js +7 -3
  4. package/dist/src/GlobalStyle.js +1 -1
  5. package/dist/src/common/assets/icons/line/Ghost.d.ts +4 -0
  6. package/dist/src/common/assets/icons/line/Ghost.js +36 -0
  7. package/dist/src/common/assets/icons/line/PaymentFreeTrial.d.ts +4 -0
  8. package/dist/src/common/assets/icons/line/PaymentFreeTrial.js +34 -0
  9. package/dist/src/common/assets/icons/line/PaymentOnetime.js +1 -1
  10. package/dist/src/common/assets/icons/line/PaymentRegularly.js +2 -1
  11. package/dist/src/common/assets/icons/line/PostColumn.d.ts +4 -0
  12. package/dist/src/common/assets/icons/line/PostColumn.js +34 -0
  13. package/dist/src/common/assets/icons/line/index.d.ts +3 -0
  14. package/dist/src/common/assets/icons/line/index.js +6 -0
  15. package/dist/src/common/components/BoxLayout/Row.js +1 -1
  16. package/dist/src/common/components/Navigations/ContextTextLabelNav.d.ts +3 -2
  17. package/dist/src/common/components/Navigations/ContextTextLabelNav.js +10 -5
  18. package/dist/src/common/hooks/useDetectOverflow.js +1 -1
  19. package/dist/src/common/styles/colorSet/PaletteColor_Dark.json +3 -1
  20. package/dist/src/common/styles/colorSet/PaletteColor_light.json +3 -1
  21. package/dist/src/common/styles/colorSet/UIColor.json +5 -1
  22. package/dist/src/common/styles/colorSet/index.d.ts +8 -0
  23. package/dist/src/common/styles/colorSet/ui-type.d.ts +4 -0
  24. package/dist/src/desktop/components/AdminList/AdminList.d.ts +4 -1
  25. package/dist/src/desktop/components/AdminList/AdminList.js +2 -2
  26. package/dist/src/desktop/components/AdminList/BulkActionBar.d.ts +4 -1
  27. package/dist/src/desktop/components/AdminList/BulkActionBar.js +4 -4
  28. package/dist/src/desktop/components/AdminListHeader/HeaderBar.js +1 -1
  29. package/dist/src/desktop/components/BasicChatListItem/BasicChatListItem.d.ts +15 -0
  30. package/dist/src/desktop/components/BasicChatListItem/BasicChatListItem.js +121 -0
  31. package/dist/src/desktop/components/BasicChatListItem/Popup.d.ts +19 -0
  32. package/dist/src/desktop/components/BasicChatListItem/Popup.js +238 -0
  33. package/dist/src/desktop/components/BasicChatListItem/index.d.ts +1 -0
  34. package/dist/src/desktop/components/BasicChatListItem/index.js +8 -0
  35. package/dist/src/desktop/components/BodyTextGroup/BodyTextGroup.d.ts +4 -1
  36. package/dist/src/desktop/components/BodyTextGroup/BodyTextGroup.js +4 -4
  37. package/dist/src/desktop/components/ChatList/Body.d.ts +7 -0
  38. package/dist/src/desktop/components/ChatList/Body.js +89 -0
  39. package/dist/src/desktop/components/ChatList/ChatList.d.ts +24 -0
  40. package/dist/src/desktop/components/ChatList/ChatList.js +93 -0
  41. package/dist/src/desktop/components/ChatList/ChatTextField.d.ts +7 -0
  42. package/dist/src/desktop/components/ChatList/ChatTextField.js +41 -0
  43. package/dist/src/desktop/components/ChatList/Footer.d.ts +7 -0
  44. package/dist/src/desktop/components/ChatList/Footer.js +27 -0
  45. package/dist/src/desktop/components/ChatList/Header.d.ts +5 -0
  46. package/dist/src/desktop/components/ChatList/Header.js +50 -0
  47. package/dist/src/desktop/components/ChatList/index.d.ts +1 -0
  48. package/dist/src/desktop/components/ChatList/index.js +8 -0
  49. package/dist/src/desktop/components/ChatList/useAutoScrollToBottom.d.ts +10 -0
  50. package/dist/src/desktop/components/ChatList/useAutoScrollToBottom.js +48 -0
  51. package/dist/src/desktop/components/Chip/Chip.js +14 -14
  52. package/dist/src/desktop/components/ContextMenu/ContextMenu.d.ts +2 -1
  53. package/dist/src/desktop/components/ContextMenu/ContextMenu.js +14 -5
  54. package/dist/src/desktop/components/ContextMenuItem/ContextMenuItem.js +4 -4
  55. package/dist/src/desktop/components/Dropdown/Dropdown.d.ts +2 -2
  56. package/dist/src/desktop/components/Dropdown/Dropdown.js +30 -13
  57. package/dist/src/desktop/components/DynamicDesktopNavBar/blocks/PrimaryMenu.js +1 -1
  58. package/dist/src/desktop/components/DynamicDesktopNavBar/blocks/SecondaryMenu.js +1 -1
  59. package/dist/src/desktop/components/DynamicDesktopNavBar/components/ContextMenuNavs/ContextMenuItemNav.js +4 -38
  60. package/dist/src/desktop/components/DynamicDesktopNavBar/components/IconNav.d.ts +2 -1
  61. package/dist/src/desktop/components/DynamicDesktopNavBar/components/IconNav.js +2 -2
  62. package/dist/src/desktop/components/DynamicDesktopNavBar/components/ImageIconNav.d.ts +2 -1
  63. package/dist/src/desktop/components/DynamicDesktopNavBar/components/ImageIconNav.js +2 -2
  64. package/dist/src/desktop/components/DynamicDesktopNavBar/components/MenuItemNav/MenuItemNav.d.ts +1 -2
  65. package/dist/src/desktop/components/DynamicDesktopNavBar/components/MenuItemNav/MenuItemNav.js +2 -2
  66. package/dist/src/desktop/components/DynamicDesktopNavBar/components/MenuItemNav/components/InternalLinkMenuItemNav.d.ts +1 -2
  67. package/dist/src/desktop/components/DynamicDesktopNavBar/components/MenuItemNav/components/InternalLinkMenuItemNav.js +4 -4
  68. package/dist/src/desktop/components/DynamicDesktopNavBar/components/MenuItemNav/components/PAppMenuItemNav.d.ts +1 -2
  69. package/dist/src/desktop/components/DynamicDesktopNavBar/components/MenuItemNav/components/PAppMenuItemNav.js +1 -1
  70. package/dist/src/desktop/components/EditApplyTextField/EditApplyTextField.d.ts +2 -1
  71. package/dist/src/desktop/components/EditApplyTextField/EditApplyTextField.js +12 -11
  72. package/dist/src/desktop/components/MainButton/MainButton.js +5 -5
  73. package/dist/src/desktop/components/Select/Select.d.ts +3 -2
  74. package/dist/src/desktop/components/Select/Select.js +11 -5
  75. package/dist/src/desktop/components/StatusBlock/StatusBlock.js +11 -5
  76. package/dist/src/desktop/components/TextButton/TextButton.js +5 -5
  77. package/dist/src/desktop/components/TextField/TextField.d.ts +2 -1
  78. package/dist/src/desktop/components/TextField/TextField.js +11 -5
  79. package/dist/src/desktop/components/UploadMainButton/UploadMainButton.js +7 -7
  80. package/dist/src/desktop/components/UploadTextButton/UploadTextButton.js +5 -5
  81. package/dist/src/desktop/components/index.d.ts +3 -1
  82. package/dist/src/desktop/components/index.js +5 -1
  83. package/dist/src/desktop/index.d.ts +2 -2
  84. package/dist/src/desktop/index.js +4 -2
  85. package/dist/src/desktop/layout/LayoutWF/Containers/ContentsContainer/ContentsContainer.d.ts +1 -1
  86. package/dist/src/desktop/layout/LayoutWF/Containers/ContentsContainer/ContentsContainer.js +2 -1
  87. package/dist/src/desktop/layout/LayoutWF/Containers/ContentsContainer/variation/WFE.d.ts +2 -1
  88. package/dist/src/desktop/layout/LayoutWF/Containers/ContentsContainer/variation/WFE.js +41 -11
  89. package/dist/src/desktop/layout/LayoutWF/ContainersBox/ContainersBox.d.ts +1 -1
  90. package/dist/src/desktop/layout/LayoutWF/ContainersBox/ContainersBox.js +2 -0
  91. package/dist/src/desktop/layout/LayoutWS/Containers/ContentsContainer/ContentsContainer.d.ts +1 -1
  92. package/dist/src/desktop/layout/LayoutWS/Containers/ContentsContainer/ContentsContainer.js +2 -1
  93. package/dist/src/desktop/layout/LayoutWS/Containers/ContentsContainer/variation/WSG.d.ts +1 -1
  94. package/dist/src/desktop/layout/LayoutWS/Containers/ContentsContainer/variation/WSG.js +16 -10
  95. package/dist/src/desktop/layout/LayoutWS/ContainersBox/ContainersBox.d.ts +1 -1
  96. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/ContentsContainer.d.ts +1 -1
  97. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/ContentsContainer.js +5 -3
  98. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/variation/WTO.d.ts +3 -2
  99. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/variation/WTO.js +8 -10
  100. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/variation/WTP.d.ts +3 -2
  101. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/variation/WTP.js +8 -10
  102. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/variation/WTQ.js +5 -5
  103. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/variation/WTT.d.ts +11 -0
  104. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/variation/WTT.js +65 -0
  105. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/variation/index.d.ts +1 -0
  106. package/dist/src/desktop/layout/LayoutWT/Containers/ContentsContainer/variation/index.js +3 -1
  107. package/dist/src/desktop/layout/LayoutWT/Containers/SubMenuContainer/variation/LeftSubMenu.js +1 -1
  108. package/dist/src/desktop/layout/LayoutWT/ContainersBox/ContainersBox.d.ts +1 -1
  109. package/dist/src/desktop/layout/LayoutWT/ContainersBox/ContainersBox.js +16 -11
  110. package/dist/src/hybrid/components/Divider/Divider.js +4 -1
  111. package/dist/src/hybrid/components/Spacing/Spacing.js +1 -1
  112. package/dist/src/mobile/components/BasicChatListItem/BasicChatListItem.d.ts +15 -0
  113. package/dist/src/mobile/components/BasicChatListItem/BasicChatListItem.js +121 -0
  114. package/dist/src/mobile/components/BasicChatListItem/Popup.d.ts +19 -0
  115. package/dist/src/mobile/components/BasicChatListItem/Popup.js +238 -0
  116. package/dist/src/mobile/components/BasicChatListItem/index.d.ts +1 -0
  117. package/dist/src/mobile/components/BasicChatListItem/index.js +8 -0
  118. package/dist/src/mobile/components/BodyTextGroup/BodyTextGroup.d.ts +4 -1
  119. package/dist/src/mobile/components/BodyTextGroup/BodyTextGroup.js +4 -4
  120. package/dist/src/mobile/components/ChatList/Body.d.ts +7 -0
  121. package/dist/src/mobile/components/ChatList/Body.js +94 -0
  122. package/dist/src/mobile/components/ChatList/ChatList.d.ts +24 -0
  123. package/dist/src/mobile/components/ChatList/ChatList.js +93 -0
  124. package/dist/src/mobile/components/ChatList/ChatTextField.d.ts +7 -0
  125. package/dist/src/mobile/components/ChatList/ChatTextField.js +41 -0
  126. package/dist/src/mobile/components/ChatList/Footer.d.ts +7 -0
  127. package/dist/src/mobile/components/ChatList/Footer.js +27 -0
  128. package/dist/src/mobile/components/ChatList/Header.d.ts +5 -0
  129. package/dist/src/mobile/components/ChatList/Header.js +50 -0
  130. package/dist/src/mobile/components/ChatList/index.d.ts +1 -0
  131. package/dist/src/mobile/components/ChatList/index.js +8 -0
  132. package/dist/src/mobile/components/ChatList/useAutoScrollToBottom.d.ts +10 -0
  133. package/dist/src/mobile/components/ChatList/useAutoScrollToBottom.js +48 -0
  134. package/dist/src/mobile/components/ChatList/useTimeout.d.ts +6 -0
  135. package/dist/src/mobile/components/ChatList/useTimeout.js +11 -0
  136. package/dist/src/mobile/components/Chip/Chip.js +14 -14
  137. package/dist/src/mobile/components/ContextMenu/ContextMenu.d.ts +2 -1
  138. package/dist/src/mobile/components/ContextMenu/ContextMenu.js +14 -5
  139. package/dist/src/mobile/components/ContextMenuItem/ContextMenuItem.js +4 -4
  140. package/dist/src/mobile/components/Dropdown/Dropdown.d.ts +2 -2
  141. package/dist/src/mobile/components/Dropdown/Dropdown.js +30 -13
  142. package/dist/src/mobile/components/MainButton/MainButton.js +5 -5
  143. package/dist/src/mobile/components/Select/Select.d.ts +3 -2
  144. package/dist/src/mobile/components/Select/Select.js +11 -5
  145. package/dist/src/mobile/components/StatusBlock/StatusBlock.js +4 -4
  146. package/dist/src/mobile/components/TextButton/TextButton.js +4 -4
  147. package/dist/src/mobile/components/TextField/TextField.d.ts +2 -1
  148. package/dist/src/mobile/components/TextField/TextField.js +11 -5
  149. package/dist/src/mobile/components/UploadMainButton/UploadMainButton.js +7 -7
  150. package/dist/src/mobile/components/UploadTextButton/UploadTextButton.js +5 -5
  151. package/dist/src/mobile/components/index.d.ts +3 -1
  152. package/dist/src/mobile/components/index.js +5 -1
  153. package/dist/src/mobile/index.d.ts +2 -2
  154. package/dist/src/mobile/index.js +3 -1
  155. package/package.json +1 -1
  156. package/release-note.md +3 -2
@@ -0,0 +1,238 @@
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
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
+ if (k2 === undefined) k2 = k;
8
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.Popup = exports.PopupProvider = void 0;
30
+ var react_1 = __importStar(require("react"));
31
+ var react_dom_1 = require("react-dom");
32
+ var styled_components_1 = __importDefault(require("styled-components"));
33
+ var PopupContext = (0, react_1.createContext)({
34
+ current: null
35
+ });
36
+ function getHAutoPlacement(_a) {
37
+ var targetRect = _a.targetRect, popupRect = _a.popupRect;
38
+ var leftSpaced = targetRect.right + popupRect.width > window.innerWidth;
39
+ var topSpaced = targetRect.bottom + popupRect.height > window.innerHeight;
40
+ return (leftSpaced ? 'left' : 'right') + "-" + (topSpaced ? 'end' : 'start');
41
+ }
42
+ function getVAutoPlacement(_a) {
43
+ var targetRect = _a.targetRect, popupRect = _a.popupRect, wrapperHeight = _a.wrapperHeight;
44
+ var leftSpaced = targetRect.right + popupRect.width > window.innerWidth;
45
+ var topSpaced = targetRect.bottom + popupRect.height > (wrapperHeight || window.innerWidth);
46
+ return (topSpaced ? 'top' : 'bottom') + "-" + (leftSpaced ? 'end' : 'start');
47
+ }
48
+ function getVCenterPlacement(_a) {
49
+ var targetRect = _a.targetRect, popupRect = _a.popupRect;
50
+ var leftSpaced = targetRect.right + popupRect.width > window.innerWidth;
51
+ return leftSpaced ? 'left-center' : 'right-center';
52
+ }
53
+ function getHCenterPlacement(_a) {
54
+ var targetRect = _a.targetRect, popupRect = _a.popupRect;
55
+ var topSpaced = targetRect.bottom + popupRect.height > window.innerHeight;
56
+ return topSpaced ? 'top-center' : 'bottom-center';
57
+ }
58
+ /**
59
+ * 위치 정규화
60
+ */
61
+ function getNormalizedPlacement(_a) {
62
+ var placement = _a.placement, targetRect = _a.targetRect, popupRect = _a.popupRect, wrapperHeight = _a.wrapperHeight;
63
+ switch (placement) {
64
+ case 'v-auto':
65
+ return getVAutoPlacement({ targetRect: targetRect, popupRect: popupRect, wrapperHeight: wrapperHeight });
66
+ case 'h-auto':
67
+ return getHAutoPlacement({ targetRect: targetRect, popupRect: popupRect, wrapperHeight: wrapperHeight });
68
+ case 'v-center':
69
+ return getVCenterPlacement({ targetRect: targetRect, popupRect: popupRect, wrapperHeight: wrapperHeight });
70
+ case 'h-center':
71
+ return getHCenterPlacement({ targetRect: targetRect, popupRect: popupRect, wrapperHeight: wrapperHeight });
72
+ default:
73
+ return placement;
74
+ }
75
+ }
76
+ function updatePosition(_a) {
77
+ var targetElem = _a.targetElem, popupElem = _a.popupElem, placement = _a.placement, wrapperHeight = _a.wrapperHeight;
78
+ var targetRect = targetElem.getBoundingClientRect();
79
+ var popupRect = popupElem.getBoundingClientRect();
80
+ var normPlacement = getNormalizedPlacement({ placement: placement, targetRect: targetRect, popupRect: popupRect, wrapperHeight: wrapperHeight });
81
+ switch (normPlacement) {
82
+ case 'top':
83
+ popupElem.style.top = targetRect.top - popupRect.height + "px";
84
+ popupElem.style.left = targetRect.left - (popupRect.width - targetRect.width) / 2 + "px";
85
+ popupElem.style.width = 'auto';
86
+ break;
87
+ case 'top-start':
88
+ popupElem.style.top = targetRect.top - popupRect.height + "px";
89
+ popupElem.style.left = targetRect.left + "px";
90
+ popupElem.style.width = 'auto';
91
+ break;
92
+ case 'top-end':
93
+ popupElem.style.top = targetRect.top - popupRect.height + "px";
94
+ popupElem.style.left = targetRect.left + targetRect.width - popupRect.width + "px";
95
+ popupElem.style.width = 'auto';
96
+ break;
97
+ case 'top-both':
98
+ popupElem.style.top = targetRect.top - popupRect.height + "px";
99
+ popupElem.style.left = targetRect.left + "px";
100
+ popupElem.style.width = targetRect.width + "px";
101
+ break;
102
+ case 'top-center':
103
+ popupElem.style.top = targetRect.top - popupRect.height + "px";
104
+ popupElem.style.left = targetRect.left - (popupRect.width - targetRect.width) / 2 + "px";
105
+ popupElem.style.width = 'auto';
106
+ break;
107
+ case 'bottom':
108
+ popupElem.style.top = targetRect.bottom + "px";
109
+ popupElem.style.left = targetRect.left - (popupRect.width - targetRect.width) / 2 + "px";
110
+ popupElem.style.width = 'auto';
111
+ break;
112
+ case 'bottom-start':
113
+ popupElem.style.top = targetRect.bottom + "px";
114
+ popupElem.style.left = targetRect.left + "px";
115
+ popupElem.style.width = 'auto';
116
+ break;
117
+ case 'bottom-end':
118
+ popupElem.style.top = targetRect.bottom + "px";
119
+ popupElem.style.left = targetRect.right - popupRect.width + "px";
120
+ popupElem.style.width = 'auto';
121
+ break;
122
+ case 'bottom-both':
123
+ popupElem.style.top = targetRect.bottom + "px";
124
+ popupElem.style.left = targetRect.left + "px";
125
+ popupElem.style.width = targetRect.width + "px";
126
+ break;
127
+ case 'bottom-center':
128
+ popupElem.style.top = targetRect.bottom + "px";
129
+ popupElem.style.left = targetRect.left - (popupRect.width - targetRect.width) / 2 + "px";
130
+ popupElem.style.width = 'auto';
131
+ break;
132
+ case 'left':
133
+ popupElem.style.top = targetRect.top - (popupRect.height - targetRect.height) / 2 + "px";
134
+ popupElem.style.left = targetRect.left - popupRect.width + "px";
135
+ popupElem.style.width = 'auto';
136
+ break;
137
+ case 'left-start':
138
+ popupElem.style.top = targetRect.top + "px";
139
+ popupElem.style.left = targetRect.left - popupRect.width + "px";
140
+ popupElem.style.width = 'auto';
141
+ break;
142
+ case 'left-end':
143
+ popupElem.style.top = targetRect.top - (popupRect.height - targetRect.height) + "px";
144
+ popupElem.style.left = targetRect.left - popupRect.width + "px";
145
+ popupElem.style.width = 'auto';
146
+ break;
147
+ case 'left-center':
148
+ popupElem.style.top = targetRect.top - (popupRect.height - targetRect.height) / 2 + "px";
149
+ popupElem.style.left = targetRect.left - popupRect.width + "px";
150
+ popupElem.style.width = 'auto';
151
+ break;
152
+ case 'right':
153
+ popupElem.style.top = targetRect.top - (popupRect.height - targetRect.height) / 2 + "px";
154
+ popupElem.style.left = targetRect.left + targetRect.width + "px";
155
+ popupElem.style.width = 'auto';
156
+ break;
157
+ case 'right-start':
158
+ popupElem.style.top = targetRect.top + "px";
159
+ popupElem.style.left = targetRect.left + targetRect.width + "px";
160
+ popupElem.style.width = 'auto';
161
+ break;
162
+ case 'right-end':
163
+ popupElem.style.top = targetRect.top - (popupRect.height - targetRect.height) + "px";
164
+ popupElem.style.left = targetRect.left + targetRect.width + "px";
165
+ popupElem.style.width = 'auto';
166
+ break;
167
+ case 'right-center':
168
+ popupElem.style.top = targetRect.top - (popupRect.height - targetRect.height) / 2 + "px";
169
+ popupElem.style.left = targetRect.left + targetRect.width + "px";
170
+ popupElem.style.width = 'auto';
171
+ break;
172
+ default:
173
+ break;
174
+ }
175
+ return normPlacement;
176
+ }
177
+ function Popup(_a) {
178
+ var targetRef = _a.targetRef, _b = _a.isOpen, isOpen = _b === void 0 ? false : _b, onClickOutside = _a.onClickOutside, onClick = _a.onClick, _c = _a.placement, placement = _c === void 0 ? 'bottom-start' : _c, wrapperHeight = _a.wrapperHeight, children = _a.children;
179
+ var popupRootRef = (0, react_1.useContext)(PopupContext);
180
+ var _d = (0, react_1.useState)('bottom'), normPlacement = _d[0], setNormPlacement = _d[1];
181
+ var popupRef = (0, react_1.useRef)(null);
182
+ /**
183
+ * 팝업 외의 다른 요소 클릭시 팝업이 닫히도록 합니다.
184
+ */
185
+ (0, react_1.useEffect)(function () {
186
+ function handleClickOutside(e) {
187
+ if (popupRootRef.current && !popupRootRef.current.contains(e.target)) {
188
+ if (onClickOutside) {
189
+ onClickOutside();
190
+ }
191
+ }
192
+ }
193
+ window.document.addEventListener('mousedown', handleClickOutside);
194
+ return function () {
195
+ window.document.removeEventListener('mousedown', handleClickOutside);
196
+ };
197
+ }, [popupRootRef, onClickOutside]);
198
+ /**
199
+ * 전체 UI 렌더링이 한 프레임 완료된 후에 팝업 위치를 결정합니다.
200
+ */
201
+ (0, react_1.useEffect)(function () {
202
+ window.requestAnimationFrame(function () {
203
+ if (!targetRef.current || !popupRef.current) {
204
+ return;
205
+ }
206
+ var targetElem = targetRef.current;
207
+ var popupElem = popupRef.current;
208
+ var updatedPlacement = updatePosition({ targetElem: targetElem, popupElem: popupElem, placement: placement, wrapperHeight: wrapperHeight });
209
+ setNormPlacement(updatedPlacement);
210
+ });
211
+ }, [isOpen, placement, wrapperHeight, targetRef, popupRef]);
212
+ function handlePopupClick(e) {
213
+ e.stopPropagation();
214
+ if (onClick) {
215
+ onClick(e);
216
+ }
217
+ }
218
+ if (!popupRootRef || !popupRootRef.current || !isOpen) {
219
+ return react_1.default.createElement(react_1.default.Fragment, null);
220
+ }
221
+ var popupComponent = (react_1.default.createElement(S_Popup, { ref: popupRef, onClick: function (e) { return handlePopupClick(e); } }, typeof children === 'function' ? children(normPlacement) : children));
222
+ return (0, react_dom_1.createPortal)(popupComponent, popupRootRef.current);
223
+ }
224
+ exports.Popup = Popup;
225
+ var S_Popup = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n left: -1000px;\n position: fixed;\n top: -1000px;\n z-index: 1000;\n"], ["\n left: -1000px;\n position: fixed;\n top: -1000px;\n z-index: 1000;\n"])));
226
+ /**
227
+ * 팝업 루트 프로바이더
228
+ * 팝업을 사용하기 위해서는 팝업 프로바이더가 상위 컴포넌트로 있어야 합니다.
229
+ */
230
+ function PopupProvider(_a) {
231
+ var children = _a.children;
232
+ var ref = (0, react_1.useRef)();
233
+ return (react_1.default.createElement(react_1.default.Fragment, null,
234
+ react_1.default.createElement(PopupContext.Provider, { value: ref }, children),
235
+ react_1.default.createElement("div", { ref: ref })));
236
+ }
237
+ exports.PopupProvider = PopupProvider;
238
+ var templateObject_1;
@@ -0,0 +1 @@
1
+ export { default as BasicChatListItem } from './BasicChatListItem';
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.BasicChatListItem = void 0;
7
+ var BasicChatListItem_1 = require("./BasicChatListItem");
8
+ Object.defineProperty(exports, "BasicChatListItem", { enumerable: true, get: function () { return __importDefault(BasicChatListItem_1).default; } });
@@ -4,7 +4,10 @@ declare type BodyTextGroupProps = {
4
4
  titleText: PDSTextType;
5
5
  descText?: PDSTextType;
6
6
  contentText?: PDSTextType;
7
+ titleTextWordBreak?: 'normal' | 'break_all' | 'keep_all' | 'break_word';
8
+ descTextWordBreak?: 'normal' | 'break_all' | 'keep_all' | 'break_word';
9
+ contentTextWordBreak?: 'normal' | 'break_all' | 'keep_all' | 'break_word';
7
10
  contentFontWeight?: 'regular' | 'bold';
8
11
  };
9
- declare function BodyTextGroup({ titleText, descText, contentText, contentFontWeight }: BodyTextGroupProps): JSX.Element;
12
+ declare function BodyTextGroup({ titleText, descText, contentText, titleTextWordBreak, descTextWordBreak, contentTextWordBreak, contentFontWeight }: BodyTextGroupProps): JSX.Element;
10
13
  export default BodyTextGroup;
@@ -7,14 +7,14 @@ var react_1 = __importDefault(require("react"));
7
7
  var hybrid_1 = require("../../../hybrid");
8
8
  var TextLabel_1 = require("../TextLabel");
9
9
  function BodyTextGroup(_a) {
10
- var titleText = _a.titleText, descText = _a.descText, contentText = _a.contentText, _b = _a.contentFontWeight, contentFontWeight = _b === void 0 ? 'regular' : _b;
10
+ var titleText = _a.titleText, descText = _a.descText, contentText = _a.contentText, _b = _a.titleTextWordBreak, titleTextWordBreak = _b === void 0 ? 'keep_all' : _b, _c = _a.descTextWordBreak, descTextWordBreak = _c === void 0 ? 'keep_all' : _c, _d = _a.contentTextWordBreak, contentTextWordBreak = _d === void 0 ? 'keep_all' : _d, _e = _a.contentFontWeight, contentFontWeight = _e === void 0 ? 'regular' : _e;
11
11
  return (react_1.default.createElement(react_1.default.Fragment, null,
12
- react_1.default.createElement(TextLabel_1.TextLabel, { text: titleText, styleTheme: "subTitleBold", colorTheme: "sysTextPrimary" }),
12
+ react_1.default.createElement(TextLabel_1.TextLabel, { text: titleText, wordBreak: titleTextWordBreak, styleTheme: "subTitleBold", colorTheme: "sysTextPrimary" }),
13
13
  descText && (react_1.default.createElement(react_1.default.Fragment, null,
14
14
  react_1.default.createElement(hybrid_1.Spacing, { size: "spacing_d" }),
15
- react_1.default.createElement(TextLabel_1.TextLabel, { text: descText, styleTheme: "caption1Regular", colorTheme: "sysTextSecondary" }))),
15
+ react_1.default.createElement(TextLabel_1.TextLabel, { text: descText, wordBreak: descTextWordBreak, styleTheme: "caption1Regular", colorTheme: "sysTextSecondary" }))),
16
16
  contentText && (react_1.default.createElement("div", null,
17
17
  react_1.default.createElement(hybrid_1.Spacing, { size: "spacing_d" }),
18
- react_1.default.createElement(TextLabel_1.TextLabel, { text: contentText, styleTheme: contentFontWeight === 'regular' ? 'body2Regular' : 'body2Bold', colorTheme: "sysTextPrimary" })))));
18
+ react_1.default.createElement(TextLabel_1.TextLabel, { text: contentText, wordBreak: contentTextWordBreak, styleTheme: contentFontWeight === 'regular' ? 'body2Regular' : 'body2Bold', colorTheme: "sysTextPrimary" })))));
19
19
  }
20
20
  exports.default = BodyTextGroup;
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import type { Props as ChatListProps } from './ChatList';
3
+ declare type Props = Pick<ChatListProps, 'scrollVisibleType' | 'children' | 'bodyMBtnText'> & {
4
+ isSubmitted: boolean;
5
+ };
6
+ declare function Body({ scrollVisibleType, children, isSubmitted, bodyMBtnText }: Props): JSX.Element;
7
+ export default Body;
@@ -0,0 +1,94 @@
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
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
+ if (k2 === undefined) k2 = k;
8
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ var react_1 = __importStar(require("react"));
30
+ var styled_components_1 = __importStar(require("styled-components"));
31
+ var MainButton_1 = require("../MainButton");
32
+ var useAutoScrollToBottom_1 = __importDefault(require("./useAutoScrollToBottom"));
33
+ var useTimeout_1 = __importDefault(require("./useTimeout"));
34
+ function Body(_a) {
35
+ var scrollVisibleType = _a.scrollVisibleType, children = _a.children, isSubmitted = _a.isSubmitted, bodyMBtnText = _a.bodyMBtnText;
36
+ var _b = (0, react_1.useState)(false), isButtonShow = _b[0], setIsButtonShow = _b[1];
37
+ var _c = (0, useAutoScrollToBottom_1.default)(), triggerScrollToBottom = _c.triggerScrollToBottom, EndOfList = _c.EndOfList;
38
+ var scrollRef = (0, react_1.useRef)(null);
39
+ var childrenLength = react_1.default.Children.count(children);
40
+ var handleTriggerScroll = function () {
41
+ if (isButtonShow) {
42
+ if (isSubmitted) {
43
+ triggerScrollToBottom();
44
+ }
45
+ return;
46
+ }
47
+ triggerScrollToBottom();
48
+ };
49
+ /**
50
+ * @when 스크롤을 하고 있지 않은 상황에서 chatMessages가 업데이트 될 때마다
51
+ * @expected 채팅 리스트의 맨 밑으로 스크롤 내린다.
52
+ * @clear -
53
+ */
54
+ (0, useTimeout_1.default)({ callback: handleTriggerScroll, target: childrenLength }, 200);
55
+ var handleClickMBtn = function () {
56
+ triggerScrollToBottom();
57
+ };
58
+ var handleScroll = function () {
59
+ if (scrollRef.current) {
60
+ var _a = scrollRef.current, scrollTop = _a.scrollTop, scrollHeight = _a.scrollHeight, clientHeight = _a.clientHeight;
61
+ var BUTTON_SHOW_UP_HEIGHT = 100;
62
+ if (Math.ceil(scrollTop) + clientHeight + BUTTON_SHOW_UP_HEIGHT > scrollHeight) {
63
+ setIsButtonShow(false);
64
+ return;
65
+ }
66
+ setIsButtonShow(true);
67
+ }
68
+ };
69
+ return (react_1.default.createElement(S_Body, null,
70
+ react_1.default.createElement(S_ChatMessageBox, { onScroll: handleScroll, ref: scrollRef, scrollVisibleType: scrollVisibleType },
71
+ children,
72
+ react_1.default.createElement(EndOfList, null)),
73
+ isButtonShow && (react_1.default.createElement(S_BottomButtonWrapper, null,
74
+ react_1.default.createElement(MainButton_1.MainButton, { text: bodyMBtnText, size: "small", onClick: handleClickMBtn })))));
75
+ }
76
+ var S_Body = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n flex: 1;\n overflow-x: hidden;\n overflow-y: hidden;\n position: relative;\n"], ["\n flex: 1;\n overflow-x: hidden;\n overflow-y: hidden;\n position: relative;\n"])));
77
+ var scrollVisibleStyle = (0, styled_components_1.css)(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n ::-webkit-scrollbar {\n display: block;\n }\n"], ["\n ::-webkit-scrollbar {\n display: block;\n }\n"])));
78
+ var scrollHiddenStyle = (0, styled_components_1.css)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n -ms-overflow-style: none;\n scrollbar-width: none;\n\n ::-webkit-scrollbar {\n display: none;\n }\n"], ["\n -ms-overflow-style: none;\n scrollbar-width: none;\n\n ::-webkit-scrollbar {\n display: none;\n }\n"])));
79
+ var S_ChatMessageBox = styled_components_1.default.div(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n height: 100%;\n overflow-y: auto;\n\n ", "\n"], ["\n height: 100%;\n overflow-y: auto;\n\n ", "\n"])), function (_a) {
80
+ var scrollVisibleType = _a.scrollVisibleType;
81
+ if (!scrollVisibleType || scrollVisibleType === 'moving') {
82
+ return;
83
+ }
84
+ return {
85
+ visible: scrollVisibleStyle,
86
+ hidden: scrollHiddenStyle
87
+ }[scrollVisibleType];
88
+ });
89
+ var S_BottomButtonWrapper = styled_components_1.default.div(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n position: absolute;\n bottom: ", ";\n left: 50%;\n transform: translate(-50%, 0);\n"], ["\n position: absolute;\n bottom: ", ";\n left: 50%;\n transform: translate(-50%, 0);\n"])), function (_a) {
90
+ var theme = _a.theme;
91
+ return theme.spacing.spacingC;
92
+ });
93
+ exports.default = Body;
94
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5;
@@ -0,0 +1,24 @@
1
+ import React from 'react';
2
+ import { FillIconNameKeys, LineIconNameKeys, PDSTextType } from '../../../common';
3
+ export declare type Props = {
4
+ styleTheme?: 'solid' | 'translucent' | 'transparent';
5
+ headerMode?: 'none' | 'use';
6
+ titleText?: PDSTextType;
7
+ captionText?: PDSTextType;
8
+ headerDisplayType?: 'none' | 'ibtn1';
9
+ headerIBtn1IconName?: FillIconNameKeys | LineIconNameKeys;
10
+ headerIBtn1IconFillType?: 'line' | 'fill';
11
+ children?: React.ReactNode;
12
+ textFieldState?: 'normal' | 'read_only' | 'disabled';
13
+ textFieldHintText?: PDSTextType;
14
+ textFieldDefaultText?: PDSTextType;
15
+ textFieldMaxLength?: number;
16
+ scrollVisibleType?: 'moving' | 'hidden' | 'visible';
17
+ footerChildren?: React.ReactNode;
18
+ submitIBtnState?: 'disabled' | 'normal';
19
+ bodyMBtnText?: PDSTextType;
20
+ onSubmit: (value: string) => void;
21
+ onClickHeaderIBtn1?: () => void;
22
+ };
23
+ declare function ChatList({ styleTheme, headerMode, titleText, captionText, headerDisplayType, headerIBtn1IconName, headerIBtn1IconFillType, children, textFieldState, textFieldHintText, textFieldDefaultText, textFieldMaxLength, scrollVisibleType, footerChildren, submitIBtnState, bodyMBtnText, onSubmit, onClickHeaderIBtn1 }: Props): JSX.Element;
24
+ export default ChatList;
@@ -0,0 +1,93 @@
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
+ var __assign = (this && this.__assign) || function () {
7
+ __assign = Object.assign || function(t) {
8
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
9
+ s = arguments[i];
10
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
11
+ t[p] = s[p];
12
+ }
13
+ return t;
14
+ };
15
+ return __assign.apply(this, arguments);
16
+ };
17
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
18
+ if (k2 === undefined) k2 = k;
19
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
20
+ }) : (function(o, m, k, k2) {
21
+ if (k2 === undefined) k2 = k;
22
+ o[k2] = m[k];
23
+ }));
24
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
26
+ }) : function(o, v) {
27
+ o["default"] = v;
28
+ });
29
+ var __importStar = (this && this.__importStar) || function (mod) {
30
+ if (mod && mod.__esModule) return mod;
31
+ var result = {};
32
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
33
+ __setModuleDefault(result, mod);
34
+ return result;
35
+ };
36
+ var __importDefault = (this && this.__importDefault) || function (mod) {
37
+ return (mod && mod.__esModule) ? mod : { "default": mod };
38
+ };
39
+ Object.defineProperty(exports, "__esModule", { value: true });
40
+ var react_1 = __importStar(require("react"));
41
+ var react_hook_form_1 = require("react-hook-form");
42
+ var styled_components_1 = __importDefault(require("styled-components"));
43
+ var hybrid_1 = require("../../../hybrid");
44
+ var Body_1 = __importDefault(require("./Body"));
45
+ var Footer_1 = __importDefault(require("./Footer"));
46
+ var Header_1 = __importDefault(require("./Header"));
47
+ var baseBackgroundColors = {
48
+ solid: 'ui_cpnt_list_base_area_solid',
49
+ translucent: 'ui_cpnt_list_base_area_translucent',
50
+ transparent: 'ui_cpnt_list_base_area_translucent'
51
+ };
52
+ function ChatList(_a) {
53
+ var _b = _a.styleTheme, styleTheme = _b === void 0 ? 'solid' : _b, _c = _a.headerMode, headerMode = _c === void 0 ? 'use' : _c, titleText = _a.titleText, captionText = _a.captionText, _d = _a.headerDisplayType, headerDisplayType = _d === void 0 ? 'none' : _d, _e = _a.headerIBtn1IconName, headerIBtn1IconName = _e === void 0 ? 'ic_xmark' : _e, _f = _a.headerIBtn1IconFillType, headerIBtn1IconFillType = _f === void 0 ? 'line' : _f, children = _a.children, _g = _a.textFieldState, textFieldState = _g === void 0 ? 'normal' : _g, textFieldHintText = _a.textFieldHintText, textFieldDefaultText = _a.textFieldDefaultText, textFieldMaxLength = _a.textFieldMaxLength, _h = _a.scrollVisibleType, scrollVisibleType = _h === void 0 ? 'moving' : _h, footerChildren = _a.footerChildren, _j = _a.submitIBtnState, submitIBtnState = _j === void 0 ? 'normal' : _j, bodyMBtnText = _a.bodyMBtnText, onSubmit = _a.onSubmit, onClickHeaderIBtn1 = _a.onClickHeaderIBtn1;
54
+ var methods = (0, react_hook_form_1.useForm)({
55
+ mode: 'onChange',
56
+ defaultValues: {
57
+ chat: ''
58
+ }
59
+ });
60
+ var reset = methods.reset, handleSubmit = methods.handleSubmit, control = methods.control, _k = methods.formState, isSubmitted = _k.isSubmitted, isValid = _k.isValid, isDirty = _k.isDirty;
61
+ var inputValue = (0, react_hook_form_1.useWatch)({ name: 'chat', control: control });
62
+ var isSubmitButtonActive = (0, react_1.useMemo)(function () {
63
+ if (!submitIBtnState) {
64
+ return false;
65
+ }
66
+ return isDirty && isValid && inputValue.length > 0 && submitIBtnState === 'normal';
67
+ }, [isDirty, isValid, inputValue, submitIBtnState]);
68
+ var handleSubmitChat = function (_a) {
69
+ var chat = _a.chat;
70
+ if (!chat || !isSubmitButtonActive) {
71
+ return;
72
+ }
73
+ onSubmit(chat);
74
+ reset({ chat: '' });
75
+ };
76
+ return (react_1.default.createElement(S_ChatList, { backgroundColor: baseBackgroundColors[styleTheme], id: "chatList" },
77
+ headerMode === 'use' && (react_1.default.createElement(react_1.default.Fragment, null,
78
+ react_1.default.createElement(Header_1.default, { styleTheme: styleTheme, titleText: titleText, captionText: captionText, headerDisplayType: headerDisplayType, headerIBtn1IconName: headerIBtn1IconName, headerIBtn1IconFillType: headerIBtn1IconFillType, onClickHeaderIBtn1: onClickHeaderIBtn1 }),
79
+ react_1.default.createElement(hybrid_1.Divider, null))),
80
+ react_1.default.createElement(Body_1.default, { scrollVisibleType: scrollVisibleType, isSubmitted: isSubmitted, bodyMBtnText: bodyMBtnText }, children),
81
+ react_1.default.createElement(hybrid_1.Divider, null),
82
+ react_1.default.createElement(hybrid_1.Spacing, { size: "spacing_d" }),
83
+ react_1.default.createElement(react_hook_form_1.FormProvider, __assign({}, methods),
84
+ react_1.default.createElement("form", { onSubmit: handleSubmit(handleSubmitChat) },
85
+ react_1.default.createElement(Footer_1.default, { textFieldDefaultText: textFieldDefaultText, textFieldHintText: textFieldHintText, textFieldState: textFieldState, textFieldMaxLength: textFieldMaxLength, footerChildren: footerChildren, isSubmitBtnActive: isSubmitButtonActive }))),
86
+ react_1.default.createElement(hybrid_1.Spacing, { size: "spacing_d" })));
87
+ }
88
+ var S_ChatList = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n background-color: ", ";\n display: flex;\n flex-direction: column;\n height: 100%;\n"], ["\n background-color: ", ";\n display: flex;\n flex-direction: column;\n height: 100%;\n"])), function (_a) {
89
+ var backgroundColor = _a.backgroundColor, theme = _a.theme;
90
+ return theme[backgroundColor];
91
+ });
92
+ exports.default = ChatList;
93
+ var templateObject_1;
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import type { Props as ChatListProps } from './ChatList';
3
+ declare type Props = Pick<ChatListProps, 'textFieldDefaultText' | 'textFieldHintText' | 'textFieldState' | 'textFieldMaxLength'> & {
4
+ isSubmitBtnActive: boolean;
5
+ };
6
+ declare function ChatTextField({ textFieldDefaultText, textFieldHintText, textFieldState, textFieldMaxLength, isSubmitBtnActive }: Props): JSX.Element;
7
+ export default ChatTextField;
@@ -0,0 +1,41 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
7
+ return (mod && mod.__esModule) ? mod : { "default": mod };
8
+ };
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ var react_1 = __importDefault(require("react"));
11
+ var styled_components_1 = __importDefault(require("styled-components"));
12
+ var IconButton_1 = require("../IconButton");
13
+ var TextField_1 = require("../TextField");
14
+ function ChatTextField(_a) {
15
+ var textFieldDefaultText = _a.textFieldDefaultText, textFieldHintText = _a.textFieldHintText, textFieldState = _a.textFieldState, textFieldMaxLength = _a.textFieldMaxLength, isSubmitBtnActive = _a.isSubmitBtnActive;
16
+ var chatValidation = {
17
+ validate: function (value) {
18
+ if (!value)
19
+ return true;
20
+ return value.trim().length ? true : false;
21
+ }
22
+ };
23
+ return (react_1.default.createElement(react_1.default.Fragment, null,
24
+ react_1.default.createElement(S_FooterContentWrapper, null,
25
+ react_1.default.createElement(S_TextFieldWrapper, null,
26
+ react_1.default.createElement(TextField_1.TextField, { name: "chat", responsiveMode: "use", textLineType: "single", inputType: "text", hintText: textFieldHintText, defaultText: textFieldDefaultText, validation: chatValidation, maxLength: textFieldMaxLength, enterSubmitMode: "use", validationPoint: "onChange", state: textFieldState })),
27
+ react_1.default.createElement(IconButton_1.IconButton, { iconName: "ic_paper_plane", baseSize: "large", baseColorKey: "ui_cpnt_button_fill_base_transparent", iconColorKey: isSubmitBtnActive ? 'ui_cpnt_button_icon_primary' : 'ui_cpnt_button_icon_disabled', iconSize: 24, type: "submit", state: isSubmitBtnActive ? 'normal' : 'disabled' }))));
28
+ }
29
+ var S_FooterContentWrapper = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n align-items: center;\n display: flex;\n padding-left: ", ";\n padding-right: ", ";\n"], ["\n align-items: center;\n display: flex;\n padding-left: ", ";\n padding-right: ", ";\n"])), function (_a) {
30
+ var theme = _a.theme;
31
+ return theme.spacing.spacingE;
32
+ }, function (_a) {
33
+ var theme = _a.theme;
34
+ return theme.spacing.spacingC;
35
+ });
36
+ var S_TextFieldWrapper = styled_components_1.default.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n flex: 1;\n margin-right: ", ";\n"], ["\n flex: 1;\n margin-right: ", ";\n"])), function (_a) {
37
+ var theme = _a.theme;
38
+ return theme.spacing.spacingB;
39
+ });
40
+ exports.default = ChatTextField;
41
+ var templateObject_1, templateObject_2;
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import type { Props as ChatListProps } from './ChatList';
3
+ declare type Props = Pick<ChatListProps, 'footerChildren' | 'textFieldDefaultText' | 'textFieldHintText' | 'textFieldState' | 'textFieldMaxLength'> & {
4
+ isSubmitBtnActive: boolean;
5
+ };
6
+ declare function Footer({ footerChildren, textFieldDefaultText, textFieldHintText, textFieldState, textFieldMaxLength, isSubmitBtnActive }: Props): JSX.Element;
7
+ export default Footer;
@@ -0,0 +1,27 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
7
+ return (mod && mod.__esModule) ? mod : { "default": mod };
8
+ };
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ var react_1 = __importDefault(require("react"));
11
+ var styled_components_1 = __importDefault(require("styled-components"));
12
+ var ChatTextField_1 = __importDefault(require("./ChatTextField"));
13
+ function Footer(_a) {
14
+ var footerChildren = _a.footerChildren, textFieldDefaultText = _a.textFieldDefaultText, textFieldHintText = _a.textFieldHintText, textFieldState = _a.textFieldState, textFieldMaxLength = _a.textFieldMaxLength, isSubmitBtnActive = _a.isSubmitBtnActive;
15
+ return (react_1.default.createElement(react_1.default.Fragment, null,
16
+ react_1.default.createElement(ChatTextField_1.default, { textFieldDefaultText: textFieldDefaultText, textFieldHintText: textFieldHintText, textFieldState: textFieldState, textFieldMaxLength: textFieldMaxLength, isSubmitBtnActive: isSubmitBtnActive }),
17
+ react_1.default.createElement(S_FooterChildrenWrapper, null, footerChildren)));
18
+ }
19
+ var S_FooterChildrenWrapper = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n padding-left: ", ";\n padding-right: ", ";\n"], ["\n padding-left: ", ";\n padding-right: ", ";\n"])), function (_a) {
20
+ var theme = _a.theme;
21
+ return theme.spacing.spacingE;
22
+ }, function (_a) {
23
+ var theme = _a.theme;
24
+ return theme.spacing.spacingC;
25
+ });
26
+ exports.default = Footer;
27
+ var templateObject_1;
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ import type { Props as ChatListProps } from './ChatList';
3
+ declare type Props = Required<Pick<ChatListProps, 'styleTheme'>> & Pick<ChatListProps, 'titleText' | 'captionText' | 'headerDisplayType' | 'headerIBtn1IconName' | 'headerIBtn1IconFillType' | 'onClickHeaderIBtn1'>;
4
+ declare function Header({ styleTheme, titleText, captionText, headerDisplayType, headerIBtn1IconName, headerIBtn1IconFillType, onClickHeaderIBtn1 }: Props): JSX.Element;
5
+ export default Header;