kitchen-simulator 5.0.0-test.17 → 5.0.0-test.19

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 (206) hide show
  1. package/package.json +8 -18
  2. package/src/@history.js +3 -0
  3. package/src/CrossSignOn.jsx +94 -0
  4. package/src/KitchenConfigurator.jsx +1526 -0
  5. package/src/KitchenConfiguratorApp.jsx +1 -1
  6. package/src/_KitchenConfigurator.jsx +3 -91
  7. package/src/components/atoms/Snackbar/index.jsx +43 -0
  8. package/src/components/atoms/radio-button/index.jsx +20 -0
  9. package/src/components/atoms/radio-button/styles.js +56 -0
  10. package/src/components/button/MainButton.jsx +157 -0
  11. package/src/components/button/ToggleMeasureButton.jsx +65 -0
  12. package/src/components/catalog-view/catalog-breadcrumb.jsx +53 -0
  13. package/src/components/catalog-view/catalog-item.jsx +229 -0
  14. package/src/components/catalog-view/catalog-list.jsx +173 -0
  15. package/src/components/catalog-view/catalog-page-item.jsx +110 -0
  16. package/src/components/catalog-view/catalog-turn-back-page-item.jsx +80 -0
  17. package/src/components/configurator/custom-configurator.jsx +77 -0
  18. package/src/components/configurator/project-configurator.jsx +120 -0
  19. package/src/components/content.jsx +136 -0
  20. package/src/components/export.js +36 -0
  21. package/src/components/firstsetting/button/styles.js +223 -0
  22. package/src/components/firstsetting/export.js +9 -0
  23. package/src/components/firstsetting/firstsetting-content-button.jsx +198 -0
  24. package/src/components/firstsetting/firstsetting-toggle-button.jsx +101 -0
  25. package/src/components/firstsetting/firstsetting.jsx +814 -0
  26. package/src/components/footerbar/button/ControlButton.jsx +43 -0
  27. package/src/components/footerbar/button/DirectionButton.jsx +54 -0
  28. package/src/components/footerbar/button/DirectionPanSpinButton.jsx +36 -0
  29. package/src/components/footerbar/button/ToggleButton.jsx +58 -0
  30. package/src/components/footerbar/button/ToggleConvertButton.jsx +48 -0
  31. package/src/components/footerbar/button/ToggleMeasureButton.jsx +33 -0
  32. package/src/components/footerbar/button/styles.js +217 -0
  33. package/src/components/footerbar/export.js +9 -0
  34. package/src/components/footerbar/footer-content-button.jsx +198 -0
  35. package/src/components/footerbar/footer-toggle-button.jsx +101 -0
  36. package/src/components/footerbar/footerbar.jsx +1103 -0
  37. package/src/components/footerbar/styles.js +263 -0
  38. package/src/components/header/button/MenuButton.jsx +46 -0
  39. package/src/components/header/button/SaveButton.jsx +54 -0
  40. package/src/components/header/button/styles.js +181 -0
  41. package/src/components/header/export.js +5 -0
  42. package/src/components/header/header.jsx +631 -0
  43. package/src/components/header/header.style.css +47 -0
  44. package/src/components/header/styles.js +320 -0
  45. package/src/components/login/Login.js +77 -0
  46. package/src/components/login/LoginForm/index.js +108 -0
  47. package/src/components/login/Register.js +82 -0
  48. package/src/components/login/RegisterForm/index.js +171 -0
  49. package/src/components/login/jwtService.js +201 -0
  50. package/src/components/login/style.css +158 -0
  51. package/src/components/login/style.scss +260 -0
  52. package/src/components/molecules/slider/index.jsx +15 -0
  53. package/src/components/molecules/slider/styles.js +0 -0
  54. package/src/components/molecules/slider/styles.scss +3 -0
  55. package/src/components/myprojects/export.js +5 -0
  56. package/src/components/myprojects/index.jsx +445 -0
  57. package/src/components/myprojects/styles.js +241 -0
  58. package/src/components/sidebar/custom-accordion.jsx +48 -0
  59. package/src/components/sidebar/export.js +15 -0
  60. package/src/components/sidebar/panel-element-editor/attributes-editor/attributes-editor.jsx +73 -0
  61. package/src/components/sidebar/panel-element-editor/attributes-editor/confirm-popup.jsx +101 -0
  62. package/src/components/sidebar/panel-element-editor/attributes-editor/hole-attributes-editor.jsx +149 -0
  63. package/src/components/sidebar/panel-element-editor/attributes-editor/item-attributes-editor.jsx +316 -0
  64. package/src/components/sidebar/panel-element-editor/attributes-editor/line-attributes-editor.jsx +108 -0
  65. package/src/components/sidebar/panel-element-editor/element-editor.jsx +1070 -0
  66. package/src/components/sidebar/panel-element-editor/multi-elements-editor.jsx +0 -0
  67. package/src/components/sidebar/panel-element-editor/panel-element-editor.jsx +104 -0
  68. package/src/components/sidebar/panel-element-editor/panel-multi-elements-editor.jsx +155 -0
  69. package/src/components/sidebar/panel-group-editor.jsx +272 -0
  70. package/src/components/sidebar/panel-groups.jsx +310 -0
  71. package/src/components/sidebar/panel-guides.jsx +192 -0
  72. package/src/components/sidebar/panel-layer-elements.jsx +298 -0
  73. package/src/components/sidebar/panel-layers.jsx +381 -0
  74. package/src/components/sidebar/panel.jsx +71 -0
  75. package/src/components/sidebar/sidebar.jsx +106 -0
  76. package/src/components/sidebar/toolbar-panel.jsx +139 -0
  77. package/src/components/sign/export.js +7 -0
  78. package/src/components/sign/main/index.jsx +523 -0
  79. package/src/components/sign/main/styles.js +163 -0
  80. package/src/components/style/button.jsx +95 -0
  81. package/src/components/style/cancel-button.jsx +20 -0
  82. package/src/components/style/content-container.jsx +29 -0
  83. package/src/components/style/content-title.jsx +20 -0
  84. package/src/components/style/delete-button.jsx +23 -0
  85. package/src/components/style/export.jsx +48 -0
  86. package/src/components/style/form-block.jsx +13 -0
  87. package/src/components/style/form-color-input.jsx +27 -0
  88. package/src/components/style/form-label.jsx +15 -0
  89. package/src/components/style/form-number-input.jsx +196 -0
  90. package/src/components/style/form-number-input_2.jsx +191 -0
  91. package/src/components/style/form-select.jsx +38 -0
  92. package/src/components/style/form-slider.jsx +36 -0
  93. package/src/components/style/form-submit-button.jsx +23 -0
  94. package/src/components/style/form-text-input.jsx +65 -0
  95. package/src/components/toolbar/button/ControlButton.jsx +41 -0
  96. package/src/components/toolbar/button/DirectionButton.jsx +34 -0
  97. package/src/components/toolbar/button/RightButton.jsx +103 -0
  98. package/src/components/toolbar/button/ToggleButton.jsx +41 -0
  99. package/src/components/toolbar/button/index.jsx +55 -0
  100. package/src/components/toolbar/button/styles.js +127 -0
  101. package/src/components/toolbar/components/DoorStyleMenu.jsx +103 -0
  102. package/src/components/toolbar/components/Pricing.jsx +126 -0
  103. package/src/components/toolbar/components/ReviewForQuote.jsx +635 -0
  104. package/src/components/toolbar/export.js +21 -0
  105. package/src/components/toolbar/main/Alert.js +122 -0
  106. package/src/components/toolbar/main/TakePictureModal.jsx +104 -0
  107. package/src/components/toolbar/main/confirm-popup.jsx +99 -0
  108. package/src/components/toolbar/main/index.jsx +5627 -0
  109. package/src/components/toolbar/main/lShaped.json +311 -0
  110. package/src/components/toolbar/main/longNarrow.json +238 -0
  111. package/src/components/toolbar/main/myComponents.js +123 -0
  112. package/src/components/toolbar/main/oRectangle.json +220 -0
  113. package/src/components/toolbar/main/rectangle.json +238 -0
  114. package/src/components/toolbar/main/style.css +107 -0
  115. package/src/components/toolbar/main/styles.js +696 -0
  116. package/src/components/toolbar/plugin-item.jsx +123 -0
  117. package/src/components/toolbar/popup/appliance/appliance-category/index.jsx +73 -0
  118. package/src/components/toolbar/popup/appliance/choose-appliance/index.jsx +102 -0
  119. package/src/components/toolbar/popup/appliance/index.jsx +83 -0
  120. package/src/components/toolbar/popup/autosaveprompt/index.jsx +150 -0
  121. package/src/components/toolbar/popup/autosaveprompt/styles.css +64 -0
  122. package/src/components/toolbar/popup/autosaveprompt/styles.js +40 -0
  123. package/src/components/toolbar/popup/cabinet/cabinet-category/index.jsx +73 -0
  124. package/src/components/toolbar/popup/cabinet/choose-product/index.jsx +119 -0
  125. package/src/components/toolbar/popup/cabinet/index.jsx +85 -0
  126. package/src/components/toolbar/popup/doorStyle/choose-style/index.jsx +63 -0
  127. package/src/components/toolbar/popup/doorStyle/index.jsx +71 -0
  128. package/src/components/toolbar/popup/doorStyle/style-category/index.jsx +139 -0
  129. package/src/components/toolbar/popup/downloadsummary/downloadSummaryContext.js +2 -0
  130. package/src/components/toolbar/popup/downloadsummary/downloadSummaryTemp.jsx +157 -0
  131. package/src/components/toolbar/popup/downloadsummary/index.jsx +643 -0
  132. package/src/components/toolbar/popup/downloadsummary/show2D/show2DView.jsx +51 -0
  133. package/src/components/toolbar/popup/downloadsummary/show2D/viewer2DDownLoad.jsx +175 -0
  134. package/src/components/toolbar/popup/downloadsummary/show3D/show3DView.jsx +283 -0
  135. package/src/components/toolbar/popup/downloadsummary/show3D/viewer3DDownLoad.jsx +2257 -0
  136. package/src/components/toolbar/popup/downloadsummary/showCabinetInfo.js +93 -0
  137. package/src/components/toolbar/popup/downloadsummary/showElevation/showElevationView.jsx +132 -0
  138. package/src/components/toolbar/popup/downloadsummary/showElevation/viewer3DElevationDownload.jsx +2198 -0
  139. package/src/components/toolbar/popup/downloadsummary/showElevation/viewerElevationDownload.jsx +152 -0
  140. package/src/components/toolbar/popup/downloadsummary/showWarranty.jsx +149 -0
  141. package/src/components/toolbar/popup/downloadsummary/styles.css +177 -0
  142. package/src/components/toolbar/popup/downloadsummary/styles.js +453 -0
  143. package/src/components/toolbar/popup/finishingtouch/category/index.jsx +34 -0
  144. package/src/components/toolbar/popup/finishingtouch/index.jsx +58 -0
  145. package/src/components/toolbar/popup/finishingtouch/material-edit.jsx +112 -0
  146. package/src/components/toolbar/popup/finishingtouch/product/index.jsx +116 -0
  147. package/src/components/toolbar/popup/floorplan/choose-floor/confirm-popup.jsx +101 -0
  148. package/src/components/toolbar/popup/floorplan/choose-floor/index.jsx +254 -0
  149. package/src/components/toolbar/popup/floorplan/choose-floor/lShaped.json +311 -0
  150. package/src/components/toolbar/popup/floorplan/choose-floor/longNarrow.json +238 -0
  151. package/src/components/toolbar/popup/floorplan/choose-floor/oRectangle.json +220 -0
  152. package/src/components/toolbar/popup/floorplan/choose-floor/rectangle.json +238 -0
  153. package/src/components/toolbar/popup/floorplan/choose-floor/styles.js +86 -0
  154. package/src/components/toolbar/popup/floorplan/floor-category/index.jsx +109 -0
  155. package/src/components/toolbar/popup/floorplan/index.jsx +60 -0
  156. package/src/components/toolbar/popup/index.jsx +241 -0
  157. package/src/components/toolbar/popup/newproject/index.jsx +59 -0
  158. package/src/components/toolbar/popup/newproject/styles.css +64 -0
  159. package/src/components/toolbar/popup/newproject/styles.js +41 -0
  160. package/src/components/toolbar/popup/product/appliance.jsx +54 -0
  161. package/src/components/toolbar/popup/product/cabinetproduct.jsx +15 -0
  162. package/src/components/toolbar/popup/product/doorstyle.jsx +58 -0
  163. package/src/components/toolbar/popup/product/doorstyleproduct.jsx +47 -0
  164. package/src/components/toolbar/popup/product/floor.jsx +36 -0
  165. package/src/components/toolbar/popup/product/floorproduct.jsx +42 -0
  166. package/src/components/toolbar/popup/product/index.jsx +36 -0
  167. package/src/components/toolbar/popup/product/primary.jsx +77 -0
  168. package/src/components/toolbar/popup/product/productline.jsx +93 -0
  169. package/src/components/toolbar/popup/product/reviewItem.jsx +427 -0
  170. package/src/components/toolbar/popup/product/reviewMolding.jsx +310 -0
  171. package/src/components/toolbar/popup/product/style.css +54 -0
  172. package/src/components/toolbar/popup/product/styles.js +260 -0
  173. package/src/components/toolbar/popup/savedesign/FullPictureForm.jsx +146 -0
  174. package/src/components/toolbar/popup/savedesign/index.jsx +495 -0
  175. package/src/components/toolbar/popup/savedesign/savedesign.style.css +16 -0
  176. package/src/components/toolbar/popup/savedesign/styles.js +151 -0
  177. package/src/components/toolbar/popup/setDoorStyleOption/index.jsx +87 -0
  178. package/src/components/toolbar/popup/styles.js +909 -0
  179. package/src/components/toolbar/popup/submitforquote/AddToCartOptions.jsx +192 -0
  180. package/src/components/toolbar/popup/submitforquote/CustomerRequestsForm.jsx +96 -0
  181. package/src/components/toolbar/popup/submitforquote/SkipDesignerReview.jsx +54 -0
  182. package/src/components/toolbar/popup/submitforquote/StepDots.jsx +25 -0
  183. package/src/components/toolbar/popup/submitforquote/cart-choice.jsx +116 -0
  184. package/src/components/toolbar/popup/submitforquote/doorstyle-menus.js +38 -0
  185. package/src/components/toolbar/popup/submitforquote/index.jsx +698 -0
  186. package/src/components/toolbar/popup/submitforquote/styles.css +105 -0
  187. package/src/components/toolbar/popup/submitforquote/styles.js +294 -0
  188. package/src/components/toolbar/popup/submitprompt/index.jsx +89 -0
  189. package/src/components/toolbar/popup/submitprompt/styles.css +64 -0
  190. package/src/components/toolbar/popup/submitprompt/styles.js +42 -0
  191. package/src/components/toolbar/toolbar-button.jsx +90 -0
  192. package/src/components/toolbar/toolbar-load-button.jsx +36 -0
  193. package/src/components/toolbar/toolbar-save-button.jsx +32 -0
  194. package/src/components/tutorial-view/Modal.jsx +584 -0
  195. package/src/components/tutorial-view/style.css +111 -0
  196. package/src/components/tutorial-view/styles.js +65 -0
  197. package/src/components/wizardstep/button/styles.js +677 -0
  198. package/src/components/wizardstep/export.js +5 -0
  199. package/src/components/wizardstep/index.jsx +1372 -0
  200. package/src/components/wizardstep/styles.js +688 -0
  201. package/src/components/wizardstep/wizardstep-content-button.jsx +198 -0
  202. package/src/components/wizardstep/wizardstep-toggle-button.jsx +101 -0
  203. package/src/{_index.js → index.js} +4 -4
  204. package/src/renderer.jsx +466 -0
  205. package/src/actions/_export.js +0 -35
  206. package/src/components/_export.js +0 -11
@@ -0,0 +1,445 @@
1
+ import React, { Component } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import * as S from './styles';
4
+ import {
5
+ API_SERVER_URL,
6
+ BG_COLOR_1,
7
+ BG_COLOR_HOVER,
8
+ DEFAULT_FONT_FAMILY,
9
+ SECONDARY_PURPLE_COLOR,
10
+ TEXT_COLOR_NEUTRAL_1,
11
+ TEXT_COLOR_NEUTRAL_4
12
+ } from '../../constants';
13
+ import axios from 'axios';
14
+ import history from '../../@history';
15
+ import moment from 'moment';
16
+
17
+ const sortData = ['date', 'name'];
18
+
19
+ const thumbnail = '/assets/img/project_img.png';
20
+
21
+ export default class MyProjects extends Component {
22
+ constructor(props, context) {
23
+ super(props);
24
+
25
+ this.state = {
26
+ sortType: 'date',
27
+ searchValue: '',
28
+ viewType: 1, //1: detail, 2: tile
29
+ myProjects: []
30
+ };
31
+ }
32
+
33
+ getProjects() {
34
+ const user_email = sessionStorage.getItem('email');
35
+ const clientName = sessionStorage.getItem('visualizerName');
36
+
37
+ axios
38
+ .post(`${API_SERVER_URL}/api/project/getmyprojects`, {
39
+ email: user_email,
40
+ clientName
41
+ })
42
+ .then(res => {
43
+ if (res.data.success === true) {
44
+ this.setState({ myProjects: res.data.projects });
45
+ }
46
+ });
47
+ }
48
+ componentDidMount() {
49
+ this.getProjects();
50
+ }
51
+
52
+ openProject(role, token, pid, urmParam) {
53
+ const visualizerName = sessionStorage.getItem('visualizerName');
54
+ history.push({
55
+ pathname: `/${visualizerName}/project/${role}/${token}/${pid}?${urmParam}`
56
+ });
57
+ axios
58
+ .post(`${API_SERVER_URL}/api/project/loadPidProject`, {
59
+ pid: pid,
60
+ visualizerName: visualizerName
61
+ })
62
+ .then(async response => {
63
+ const { projectElement } = response.data;
64
+ if (projectElement.length === 0) return;
65
+ sessionStorage.setItem('projectTitle', projectElement[0].title);
66
+ this.context.projectActions.rename(projectElement[0].title);
67
+ sessionStorage.setItem('projectId', projectElement[0].id);
68
+ sessionStorage.setItem('email', projectElement[0].email);
69
+ sessionStorage.setItem('firstName', projectElement[0].firstName);
70
+ sessionStorage.setItem('lastName', projectElement[0].lastName);
71
+ sessionStorage.setItem('phone', projectElement[0].phone);
72
+ let jsonData;
73
+ if (projectElement[0].project_data) {
74
+ jsonData = JSON.parse(projectElement[0].project_data);
75
+ } else {
76
+ try {
77
+ jsonData = await axios.post(
78
+ `${constants.API_SERVER_URL}/api/project/loadPidData`,
79
+ { pid: match.params.pid }
80
+ ).data.data;
81
+ } catch (err) {
82
+ this.setState({
83
+ isSnackBarOpen: true,
84
+ snackBarMessage: err
85
+ });
86
+ }
87
+ }
88
+ jsonData.isLoadingCabinet = false;
89
+ this.context.projectActions.loadProject(
90
+ jsonData,
91
+ this.props.categoryData
92
+ );
93
+ this.props.setMyProjectsOpen(false);
94
+ });
95
+ }
96
+
97
+ getDateArray(date) {
98
+ let array = date.split(' ');
99
+ let date_array = [];
100
+ array[0].split('-').forEach(element => date_array.push(parseInt(element)));
101
+ array[1].split(':').forEach(element => date_array.push(parseInt(element)));
102
+ return date_array;
103
+ }
104
+
105
+ getDiffDate(date) {
106
+ const now_date = moment(new Date()).format('YYYY-MM-DD HH:mm:ss');
107
+ const saved_date = moment(date).format('YYYY-MM-DD HH:mm:ss');
108
+ let diffDate = '';
109
+ let now_date_array = this.getDateArray(now_date);
110
+ let saved_date_array = this.getDateArray(saved_date);
111
+ now_date_array.forEach((item, index) => {
112
+ if (item !== saved_date_array[index] && diffDate === '') {
113
+ diffDate = diffDate + (item - saved_date_array[index]);
114
+ switch (index) {
115
+ case 0:
116
+ diffDate = diffDate + ' year';
117
+ break;
118
+ case 1:
119
+ diffDate = diffDate + ' month';
120
+ break;
121
+ case 2:
122
+ diffDate = diffDate + ' day';
123
+ break;
124
+ case 3:
125
+ diffDate = diffDate + ' hour';
126
+ break;
127
+ case 4:
128
+ diffDate = diffDate + ' minute';
129
+ break;
130
+ case 5:
131
+ diffDate = diffDate + ' second';
132
+ break;
133
+ default:
134
+ break;
135
+ }
136
+ if (item - saved_date_array[index] !== 1) {
137
+ diffDate = diffDate + 's';
138
+ }
139
+ }
140
+ });
141
+ return diffDate;
142
+ }
143
+
144
+ sort(a, b) {}
145
+
146
+ render() {
147
+ const { sortType, searchValue, viewType, myProjects } = this.state;
148
+ const { token, role } = this.props.match.params;
149
+
150
+ return (
151
+ <S.DialogWrapper>
152
+ <S.Dialog>
153
+ <div
154
+ style={{ cursor: 'pointer', width: '100%', userSelect: 'none' }}
155
+ onClick={() => this.props.setMyProjectsOpen(false)}
156
+ >
157
+ <img
158
+ style={{ float: 'right', height: 25, transform: 'rotate(45deg)' }}
159
+ src="/assets/img/svg/bottombar/arrow-plus.svg"
160
+ />
161
+ </div>
162
+ <S.DialogTitle>Retrieve a saved projects</S.DialogTitle>
163
+ <S.DialogContent>
164
+ Select from the list below what file do you want to recover.
165
+ </S.DialogContent>
166
+ <S.DialogContentSelection>
167
+ <div style={{ display: 'flex', justifyContent: 'space-between' }}>
168
+ <div style={{ display: 'flex' }}>
169
+ <S.DialogContents style={{ fontSize: 13 }}>
170
+ Sort by:
171
+ </S.DialogContents>
172
+ <S.SelectWrapper>
173
+ <S.Select
174
+ id="sort_select"
175
+ onClick={() => {
176
+ document.getElementById('arrow').style.transform =
177
+ document.getElementById('arrow').style.transform ===
178
+ 'rotate(180deg)'
179
+ ? 'unset'
180
+ : 'rotate(180deg)';
181
+ document.getElementById('sort_option').style.display =
182
+ document.getElementById('sort_option').style.display ===
183
+ 'none'
184
+ ? 'flex'
185
+ : 'none';
186
+ document.getElementById(
187
+ 'sort_select'
188
+ ).style.borderBottomColor = SECONDARY_PURPLE_COLOR;
189
+ }}
190
+ >
191
+ {sortType.charAt(0).toUpperCase() + sortType.substr(1)}
192
+ </S.Select>
193
+ <S.ArrowIcon
194
+ id="arrow"
195
+ maskImage="/assets/img/svg/bottombar/arrow-down.svg"
196
+ />
197
+ <div
198
+ id="sort_option"
199
+ style={{
200
+ position: 'absolute',
201
+ display: 'none',
202
+ flexDirection: 'column',
203
+ top: 30,
204
+ zIndex: 100,
205
+ width: 150,
206
+ borderRadius: 5,
207
+ backgroundColor: BG_COLOR_1,
208
+ boxShadow:
209
+ '0px 3px 5px -1px rgba(156, 154, 154, 0.2), 0px 6px 10px 0px rgba(156, 154, 154, 0.39), 0px 1px 18px 0px rgba(156, 154, 154, 0.12)'
210
+ }}
211
+ >
212
+ {sortData.map(item => {
213
+ return (
214
+ <S.SelectOption
215
+ onClick={() => {
216
+ document.getElementById('arrow').style.transform =
217
+ 'unset';
218
+ document.getElementById(
219
+ 'sort_option'
220
+ ).style.display = 'none';
221
+ document.getElementById(
222
+ 'sort_select'
223
+ ).style.borderBottomColor = TEXT_COLOR_NEUTRAL_1;
224
+ this.setState({ sortType: item });
225
+ }}
226
+ style={{
227
+ backgroundColor:
228
+ sortType === item && TEXT_COLOR_NEUTRAL_4
229
+ }}
230
+ >
231
+ {item.charAt(0).toUpperCase() + item.substr(1)}
232
+ </S.SelectOption>
233
+ );
234
+ })}
235
+ </div>
236
+ </S.SelectWrapper>
237
+ </div>
238
+ <div style={{ position: 'relative' }}>
239
+ <img
240
+ src="/assets/img/svg/lefttoolbar/search.svg"
241
+ style={{
242
+ position: 'absolute',
243
+ left: 0,
244
+ width: 35,
245
+ height: 35,
246
+ padding: 10
247
+ }}
248
+ />
249
+ <S.SearchInput
250
+ value={searchValue}
251
+ onChange={e => this.setState({ searchValue: e.target.value })}
252
+ placeholder="Search file names"
253
+ />
254
+ </div>
255
+ <div style={{ display: 'flex' }}>
256
+ <S.ActionButton
257
+ onClick={() => this.setState({ viewType: 1 })}
258
+ style={{ backgroundColor: viewType === 1 && BG_COLOR_HOVER }}
259
+ >
260
+ <img src="/assets/img/svg/wizardstep/detail_view.svg" />
261
+ </S.ActionButton>
262
+ <S.ActionButton
263
+ onClick={() => this.setState({ viewType: 2 })}
264
+ style={{
265
+ backgroundColor: viewType === 2 && BG_COLOR_HOVER,
266
+ marginLeft: 10
267
+ }}
268
+ >
269
+ <img src="/assets/img/svg/wizardstep/tile_view.svg" />
270
+ </S.ActionButton>
271
+ </div>
272
+ </div>
273
+ <div
274
+ style={{
275
+ height: 400,
276
+ width: '100%',
277
+ scrollY: 'overflow',
278
+ marginTop: 10,
279
+ padding: 5
280
+ }}
281
+ >
282
+ {viewType === 1 ? (
283
+ <S.MyProjectsTable>
284
+ <S.MyProjectsThead>
285
+ <S.MyProjectsTh style={{ width: '40%' }}>
286
+ Name
287
+ </S.MyProjectsTh>
288
+ <S.MyProjectsTh style={{ width: '60%' }}>
289
+ Date
290
+ </S.MyProjectsTh>
291
+ </S.MyProjectsThead>
292
+ {myProjects
293
+ .sort((a, b) => {
294
+ let value0, value1;
295
+ switch (sortType) {
296
+ case 'name':
297
+ value0 = a.project_title;
298
+ value1 = b.project_title;
299
+ break;
300
+ case 'date':
301
+ value0 = b.create_date;
302
+ value1 = a.create_date;
303
+ break;
304
+ default:
305
+ break;
306
+ }
307
+ return value0 !== value1 ? (value0 < value1 ? -1 : 1) : 0;
308
+ })
309
+ .filter(
310
+ it =>
311
+ searchValue === '' ||
312
+ it.project_title.search(searchValue) !== -1 ||
313
+ it.project_title
314
+ .toLowerCase()
315
+ .search(searchValue.toLowerCase()) !== -1
316
+ )
317
+ .map(item => {
318
+ const date = this.getDiffDate(item.create_date);
319
+ return (
320
+ <S.MyProjectsThead
321
+ style={{
322
+ backgroundColor: BG_COLOR_1,
323
+ borderBottom: '2px solid #FAFAFF'
324
+ }}
325
+ >
326
+ <S.MyProjectsTh
327
+ style={{
328
+ width: '40%',
329
+ display: 'flex',
330
+ alignItems: 'center'
331
+ }}
332
+ >
333
+ <img src={thumbnail} style={{ width: 60 }} />
334
+ <span style={{ marginLeft: 10 }}>
335
+ {item.project_title.charAt(0).toUpperCase() +
336
+ item.project_title.substr(1)}
337
+ </span>
338
+ </S.MyProjectsTh>
339
+ <S.MyProjectsTh
340
+ style={{
341
+ width: '60%',
342
+ display: 'flex',
343
+ justifyContent: 'space-between',
344
+ alignItems: 'center'
345
+ }}
346
+ >
347
+ {date + ' ago'}
348
+ <S.ActionButton
349
+ onClick={() =>
350
+ this.openProject(
351
+ role,
352
+ token,
353
+ item.id,
354
+ item.urmParam
355
+ )
356
+ }
357
+ style={{ width: 'max-content' }}
358
+ >
359
+ Open
360
+ </S.ActionButton>
361
+ </S.MyProjectsTh>
362
+ </S.MyProjectsThead>
363
+ );
364
+ })}
365
+ </S.MyProjectsTable>
366
+ ) : (
367
+ <div style={{ flexWrap: 'wrap', display: 'flex' }}>
368
+ {myProjects
369
+ .sort((a, b) => {
370
+ let value0, value1;
371
+ switch (sortType) {
372
+ case 'name':
373
+ value0 = a.project_title;
374
+ value1 = b.project_title;
375
+ break;
376
+ case 'date':
377
+ value0 = b.create_date;
378
+ value1 = a.create_date;
379
+ break;
380
+ default:
381
+ break;
382
+ }
383
+ return value0 !== value1 ? (value0 < value1 ? -1 : 1) : 0;
384
+ })
385
+ .filter(
386
+ it =>
387
+ searchValue === '' ||
388
+ it.project_title.search(searchValue) !== -1 ||
389
+ it.project_title
390
+ .toLowerCase()
391
+ .search(searchValue.toLowerCase()) !== -1
392
+ )
393
+ .map(item => {
394
+ const date = this.getDiffDate(item.create_date);
395
+ return (
396
+ <S.TileItem
397
+ onClick={() =>
398
+ this.openProject(
399
+ role,
400
+ token,
401
+ item.id,
402
+ item.urmParam
403
+ )
404
+ }
405
+ >
406
+ <img src={thumbnail} style={{ width: '100%' }} />
407
+ <span style={{ marginTop: 10 }}>
408
+ {item.project_title.charAt(0).toUpperCase() +
409
+ item.project_title.substr(1)}
410
+ </span>
411
+ <span
412
+ style={{
413
+ fontSize: 13,
414
+ fontWeight: 100,
415
+ marginTop: 5
416
+ }}
417
+ >
418
+ {date + ' ago'}
419
+ </span>
420
+ </S.TileItem>
421
+ );
422
+ })}
423
+ </div>
424
+ )}
425
+ </div>
426
+ </S.DialogContentSelection>
427
+ </S.Dialog>
428
+ </S.DialogWrapper>
429
+ );
430
+ }
431
+ }
432
+
433
+ MyProjects.propTypes = {
434
+ state: PropTypes.object.isRequired,
435
+ content: PropTypes.number.isRequired
436
+ };
437
+
438
+ MyProjects.contextTypes = {
439
+ projectActions: PropTypes.object.isRequired,
440
+ viewer2DActions: PropTypes.object.isRequired,
441
+ viewer3DActions: PropTypes.object.isRequired,
442
+ linesActions: PropTypes.object.isRequired,
443
+ itemsActions: PropTypes.object.isRequired,
444
+ catalog: PropTypes.object.isRequired
445
+ };
@@ -0,0 +1,241 @@
1
+ import {
2
+ BG_COLOR_0,
3
+ BG_COLOR_HOVER,
4
+ DEFAULT_FONT_FAMILY,
5
+ SECONDARY_PURPLE_COLOR,
6
+ TEXT_COLOR_NEUTRAL_0,
7
+ TEXT_COLOR_NEUTRAL_1,
8
+ TEXT_COLOR_NEUTRAL_2,
9
+ TEXT_COLOR_NEUTRAL_3
10
+ } from '../../constants';
11
+ import styled from 'styled-components';
12
+ import MyProjects from './index';
13
+
14
+ export const DialogWrapper = styled.div`
15
+ position: absolute;
16
+ left: 0;
17
+ top: 60px;
18
+ width: 100%;
19
+ height: calc(100% - 60px);
20
+ display: flex;
21
+ `;
22
+
23
+ export const Dialog = styled.div`
24
+ position: relative;
25
+ margin: auto;
26
+ width: 600px;
27
+ display: flex;
28
+ flex-direction: column;
29
+ padding: 30px;
30
+ user-select: none;
31
+ text-align: center;
32
+ border-radius: 10px;
33
+ z-index: 10;
34
+ background-color: rgb(255, 255, 255);
35
+ box-shadow: 0px 3px 5px -1px rgba(156, 154, 154, 0.2),
36
+ 0px 6px 10px 0px rgba(156, 154, 154, 0.39),
37
+ 0px 1px 18px 0px rgba(156, 154, 154, 0.12);
38
+ `;
39
+
40
+ export const DialogTitle = styled.span`
41
+ color: ${TEXT_COLOR_NEUTRAL_1};
42
+ font-family: ${DEFAULT_FONT_FAMILY};
43
+ font-size: 22px;
44
+ font-weight: 700;
45
+ line-height: 30px;
46
+ text-align: left;
47
+ `;
48
+
49
+ export const DialogContent = styled.span`
50
+ font-family: ${DEFAULT_FONT_FAMILY};
51
+ color: ${TEXT_COLOR_NEUTRAL_1};
52
+ padding: 10px 0px;
53
+ font-size: 13px;
54
+ font-weight: 400;
55
+ line-height: 18px;
56
+ text-align: left;
57
+ width: 100%;
58
+ `;
59
+
60
+ export const DialogContentSelection = styled.div`
61
+ display: flex;
62
+ flex-direction: column;
63
+ padding: 10px 0px;
64
+ max-height: calc(100vh - 300px);
65
+ overflow-y: scroll;
66
+ `;
67
+
68
+ export const DialogContents = styled.span`
69
+ font-family: ${DEFAULT_FONT_FAMILY};
70
+ color: ${TEXT_COLOR_NEUTRAL_1};
71
+ padding: 10px 0px;
72
+
73
+ @media screen and (min-width: 1024) {
74
+ font-size: 11px;
75
+ }
76
+ @media screen and (max-width: 1024) {
77
+ font-size: 11px;
78
+ }
79
+ @media screen and (min-width: 1366) {
80
+ font-size: 13px;
81
+ }
82
+ @media screen and (max-width: 1366) {
83
+ font-size: 13px;
84
+ }
85
+ @media screen and (min-width: 1440) {
86
+ font-size: 16px;
87
+ }
88
+ @media screen and (max-width: 1440) {
89
+ font-size: 16px;
90
+ }
91
+ font-weight: 400;
92
+ line-height: 18px;
93
+ text-align: left;
94
+ `;
95
+
96
+ export const SelectWrapper = styled.div`
97
+ position: relative;
98
+ display: flex;
99
+ align-items: center;
100
+ margin-left: 10px;
101
+ `;
102
+
103
+ export const Select = styled.div`
104
+ border-bottom: 2px solid ${TEXT_COLOR_NEUTRAL_1};
105
+ width: 150px;
106
+ text-align: left;
107
+ font-family: ${DEFAULT_FONT_FAMILY};
108
+ color: ${TEXT_COLOR_NEUTRAL_1};
109
+ cursor: pointer;
110
+ :hover {
111
+ border-bottom-color: ${SECONDARY_PURPLE_COLOR};
112
+ }
113
+ `;
114
+
115
+ export const ArrowIcon = styled.img`
116
+ position: absolute;
117
+ width: 15px;
118
+ height: 9px;
119
+ background-color: ${TEXT_COLOR_NEUTRAL_3};
120
+ top: 10px;
121
+ right: 10px;
122
+ -webkit-mask-image: url(${props => props.maskImage});
123
+ -webkit-mask-size: 100% 100%;
124
+ -webkit-mask-repeat: no-repeat;
125
+ `;
126
+
127
+ export const SelectOption = styled.span`
128
+ font-size: 13px;
129
+ padding: 12px 20px;
130
+ font-family: ${DEFAULT_FONT_FAMILY};
131
+ color: ${TEXT_COLOR_NEUTRAL_0};
132
+ font-weight: 600;
133
+ text-align: left;
134
+ cursor: pointer;
135
+ :hover {
136
+ background-color: ${BG_COLOR_HOVER};
137
+ }
138
+ `;
139
+
140
+ export const SearchInput = styled.input`
141
+ outline: 0;
142
+ border: 2px solid ${TEXT_COLOR_NEUTRAL_3};
143
+ height: 35px;
144
+ padding: 5px;
145
+ padding-left: 35px;
146
+ border-radius: 7px;
147
+ `;
148
+
149
+ export const MyProjectsTable = styled.div`
150
+ display: flex;
151
+ flex-direction: column;
152
+ `;
153
+
154
+ export const MyProjectsThead = styled.div`
155
+ background-color: ${BG_COLOR_0};
156
+ display: flex;
157
+ align-items: center;
158
+ background-color: #fafaff;
159
+ `;
160
+
161
+ export const MyProjectsTh = styled.div`
162
+ font-family: ${DEFAULT_FONT_FAMILY};
163
+
164
+ @media screen and (min-width: 1024) {
165
+ font-size: 11px;
166
+ }
167
+ @media screen and (max-width: 1024) {
168
+ font-size: 11px;
169
+ }
170
+ @media screen and (min-width: 1366) {
171
+ font-size: 13px;
172
+ }
173
+ @media screen and (max-width: 1366) {
174
+ font-size: 13px;
175
+ }
176
+ @media screen and (min-width: 1440) {
177
+ font-size: 16px;
178
+ }
179
+ @media screen and (max-width: 1440) {
180
+ font-size: 16px;
181
+ }
182
+ line-height: 13px;
183
+ text-align: left;
184
+ font-weight: 600;
185
+ margin: 5px;
186
+ line-height: normal;
187
+ color: ${TEXT_COLOR_NEUTRAL_2};
188
+ `;
189
+
190
+ export const ActionButton = styled.div`
191
+ border-radius: 5px;
192
+ cursor: pointer;
193
+ display: flex;
194
+ align-items: center;
195
+ color: ${SECONDARY_PURPLE_COLOR};
196
+ width: 35px;
197
+ height: 35px;
198
+ padding: 10px;
199
+ :hover {
200
+ background-color: ${BG_COLOR_HOVER};
201
+ }
202
+ `;
203
+
204
+ export const TileItem = styled.div`
205
+ width: 150px;
206
+ display: flex;
207
+ flex-direction: column;
208
+ font-family: ${DEFAULT_FONT_FAMILY};
209
+
210
+ @media screen and (min-width: 1024) {
211
+ font-size: 11px;
212
+ }
213
+ @media screen and (max-width: 1024) {
214
+ font-size: 11px;
215
+ }
216
+ @media screen and (min-width: 1366) {
217
+ font-size: 13px;
218
+ }
219
+ @media screen and (max-width: 1366) {
220
+ font-size: 13px;
221
+ }
222
+ @media screen and (min-width: 1440) {
223
+ font-size: 16px;
224
+ }
225
+ @media screen and (max-width: 1440) {
226
+ font-size: 16px;
227
+ }
228
+ line-height: 13px;
229
+ text-align: left;
230
+ font-weight: 600;
231
+ line-height: normal;
232
+ color: ${TEXT_COLOR_NEUTRAL_2};
233
+ border-radius: 10px;
234
+ border: 2px solid #fafaff;
235
+ padding: 15px;
236
+ cursor: pointer;
237
+ margin: 10px;
238
+ :hover {
239
+ background-color: #fafaff;
240
+ }
241
+ `;