kitchen-simulator 5.0.0-test.18 → 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 (179) hide show
  1. package/package.json +8 -26
  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 -3
  7. package/src/components/catalog-view/catalog-breadcrumb.jsx +53 -0
  8. package/src/components/catalog-view/catalog-item.jsx +229 -0
  9. package/src/components/catalog-view/catalog-list.jsx +173 -0
  10. package/src/components/catalog-view/catalog-page-item.jsx +110 -0
  11. package/src/components/catalog-view/catalog-turn-back-page-item.jsx +80 -0
  12. package/src/components/configurator/custom-configurator.jsx +77 -0
  13. package/src/components/configurator/project-configurator.jsx +120 -0
  14. package/src/components/export.js +36 -0
  15. package/src/components/firstsetting/button/styles.js +223 -0
  16. package/src/components/firstsetting/export.js +9 -0
  17. package/src/components/firstsetting/firstsetting-content-button.jsx +198 -0
  18. package/src/components/firstsetting/firstsetting-toggle-button.jsx +101 -0
  19. package/src/components/firstsetting/firstsetting.jsx +814 -0
  20. package/src/components/footerbar/button/ControlButton.jsx +43 -0
  21. package/src/components/footerbar/button/DirectionButton.jsx +54 -0
  22. package/src/components/footerbar/button/DirectionPanSpinButton.jsx +36 -0
  23. package/src/components/footerbar/button/ToggleButton.jsx +58 -0
  24. package/src/components/footerbar/button/ToggleConvertButton.jsx +48 -0
  25. package/src/components/footerbar/button/ToggleMeasureButton.jsx +33 -0
  26. package/src/components/footerbar/button/styles.js +217 -0
  27. package/src/components/footerbar/export.js +9 -0
  28. package/src/components/footerbar/footer-content-button.jsx +198 -0
  29. package/src/components/footerbar/footer-toggle-button.jsx +101 -0
  30. package/src/components/footerbar/footerbar.jsx +1103 -0
  31. package/src/components/footerbar/styles.js +263 -0
  32. package/src/components/header/button/MenuButton.jsx +46 -0
  33. package/src/components/header/button/SaveButton.jsx +54 -0
  34. package/src/components/header/button/styles.js +181 -0
  35. package/src/components/header/export.js +5 -0
  36. package/src/components/header/header.jsx +631 -0
  37. package/src/components/header/header.style.css +47 -0
  38. package/src/components/header/styles.js +320 -0
  39. package/src/components/login/Login.js +77 -0
  40. package/src/components/login/LoginForm/index.js +108 -0
  41. package/src/components/login/Register.js +82 -0
  42. package/src/components/login/RegisterForm/index.js +171 -0
  43. package/src/components/login/jwtService.js +201 -0
  44. package/src/components/login/style.css +158 -0
  45. package/src/components/login/style.scss +260 -0
  46. package/src/components/myprojects/export.js +5 -0
  47. package/src/components/myprojects/index.jsx +445 -0
  48. package/src/components/myprojects/styles.js +241 -0
  49. package/src/components/sidebar/custom-accordion.jsx +48 -0
  50. package/src/components/sidebar/export.js +15 -0
  51. package/src/components/sidebar/panel-element-editor/attributes-editor/attributes-editor.jsx +73 -0
  52. package/src/components/sidebar/panel-element-editor/attributes-editor/confirm-popup.jsx +101 -0
  53. package/src/components/sidebar/panel-element-editor/attributes-editor/hole-attributes-editor.jsx +149 -0
  54. package/src/components/sidebar/panel-element-editor/attributes-editor/item-attributes-editor.jsx +316 -0
  55. package/src/components/sidebar/panel-element-editor/attributes-editor/line-attributes-editor.jsx +108 -0
  56. package/src/components/sidebar/panel-element-editor/element-editor.jsx +1070 -0
  57. package/src/components/sidebar/panel-element-editor/multi-elements-editor.jsx +0 -0
  58. package/src/components/sidebar/panel-element-editor/panel-element-editor.jsx +104 -0
  59. package/src/components/sidebar/panel-element-editor/panel-multi-elements-editor.jsx +155 -0
  60. package/src/components/sidebar/panel-group-editor.jsx +272 -0
  61. package/src/components/sidebar/panel-groups.jsx +310 -0
  62. package/src/components/sidebar/panel-guides.jsx +192 -0
  63. package/src/components/sidebar/panel-layer-elements.jsx +298 -0
  64. package/src/components/sidebar/panel-layers.jsx +381 -0
  65. package/src/components/sidebar/panel.jsx +71 -0
  66. package/src/components/sidebar/sidebar.jsx +106 -0
  67. package/src/components/sidebar/toolbar-panel.jsx +139 -0
  68. package/src/components/sign/export.js +7 -0
  69. package/src/components/sign/main/index.jsx +523 -0
  70. package/src/components/sign/main/styles.js +163 -0
  71. package/src/components/toolbar/button/ControlButton.jsx +41 -0
  72. package/src/components/toolbar/button/DirectionButton.jsx +34 -0
  73. package/src/components/toolbar/button/RightButton.jsx +103 -0
  74. package/src/components/toolbar/button/ToggleButton.jsx +41 -0
  75. package/src/components/toolbar/button/index.jsx +55 -0
  76. package/src/components/toolbar/button/styles.js +127 -0
  77. package/src/components/toolbar/components/DoorStyleMenu.jsx +103 -0
  78. package/src/components/toolbar/components/Pricing.jsx +126 -0
  79. package/src/components/toolbar/components/ReviewForQuote.jsx +635 -0
  80. package/src/components/toolbar/export.js +21 -0
  81. package/src/components/toolbar/main/Alert.js +122 -0
  82. package/src/components/toolbar/main/TakePictureModal.jsx +104 -0
  83. package/src/components/toolbar/main/confirm-popup.jsx +99 -0
  84. package/src/components/toolbar/main/index.jsx +5627 -0
  85. package/src/components/toolbar/main/lShaped.json +311 -0
  86. package/src/components/toolbar/main/longNarrow.json +238 -0
  87. package/src/components/toolbar/main/myComponents.js +123 -0
  88. package/src/components/toolbar/main/oRectangle.json +220 -0
  89. package/src/components/toolbar/main/rectangle.json +238 -0
  90. package/src/components/toolbar/main/style.css +107 -0
  91. package/src/components/toolbar/main/styles.js +696 -0
  92. package/src/components/toolbar/plugin-item.jsx +123 -0
  93. package/src/components/toolbar/popup/appliance/appliance-category/index.jsx +73 -0
  94. package/src/components/toolbar/popup/appliance/choose-appliance/index.jsx +102 -0
  95. package/src/components/toolbar/popup/appliance/index.jsx +83 -0
  96. package/src/components/toolbar/popup/autosaveprompt/index.jsx +150 -0
  97. package/src/components/toolbar/popup/autosaveprompt/styles.css +64 -0
  98. package/src/components/toolbar/popup/autosaveprompt/styles.js +40 -0
  99. package/src/components/toolbar/popup/cabinet/cabinet-category/index.jsx +73 -0
  100. package/src/components/toolbar/popup/cabinet/choose-product/index.jsx +119 -0
  101. package/src/components/toolbar/popup/cabinet/index.jsx +85 -0
  102. package/src/components/toolbar/popup/doorStyle/choose-style/index.jsx +63 -0
  103. package/src/components/toolbar/popup/doorStyle/index.jsx +71 -0
  104. package/src/components/toolbar/popup/doorStyle/style-category/index.jsx +139 -0
  105. package/src/components/toolbar/popup/downloadsummary/downloadSummaryContext.js +2 -0
  106. package/src/components/toolbar/popup/downloadsummary/downloadSummaryTemp.jsx +157 -0
  107. package/src/components/toolbar/popup/downloadsummary/index.jsx +643 -0
  108. package/src/components/toolbar/popup/downloadsummary/show2D/show2DView.jsx +51 -0
  109. package/src/components/toolbar/popup/downloadsummary/show2D/viewer2DDownLoad.jsx +175 -0
  110. package/src/components/toolbar/popup/downloadsummary/show3D/show3DView.jsx +283 -0
  111. package/src/components/toolbar/popup/downloadsummary/show3D/viewer3DDownLoad.jsx +2257 -0
  112. package/src/components/toolbar/popup/downloadsummary/showCabinetInfo.js +93 -0
  113. package/src/components/toolbar/popup/downloadsummary/showElevation/showElevationView.jsx +132 -0
  114. package/src/components/toolbar/popup/downloadsummary/showElevation/viewer3DElevationDownload.jsx +2198 -0
  115. package/src/components/toolbar/popup/downloadsummary/showElevation/viewerElevationDownload.jsx +152 -0
  116. package/src/components/toolbar/popup/downloadsummary/showWarranty.jsx +149 -0
  117. package/src/components/toolbar/popup/downloadsummary/styles.css +177 -0
  118. package/src/components/toolbar/popup/downloadsummary/styles.js +453 -0
  119. package/src/components/toolbar/popup/finishingtouch/category/index.jsx +34 -0
  120. package/src/components/toolbar/popup/finishingtouch/index.jsx +58 -0
  121. package/src/components/toolbar/popup/finishingtouch/material-edit.jsx +112 -0
  122. package/src/components/toolbar/popup/finishingtouch/product/index.jsx +116 -0
  123. package/src/components/toolbar/popup/floorplan/choose-floor/confirm-popup.jsx +101 -0
  124. package/src/components/toolbar/popup/floorplan/choose-floor/index.jsx +254 -0
  125. package/src/components/toolbar/popup/floorplan/choose-floor/lShaped.json +311 -0
  126. package/src/components/toolbar/popup/floorplan/choose-floor/longNarrow.json +238 -0
  127. package/src/components/toolbar/popup/floorplan/choose-floor/oRectangle.json +220 -0
  128. package/src/components/toolbar/popup/floorplan/choose-floor/rectangle.json +238 -0
  129. package/src/components/toolbar/popup/floorplan/choose-floor/styles.js +86 -0
  130. package/src/components/toolbar/popup/floorplan/floor-category/index.jsx +109 -0
  131. package/src/components/toolbar/popup/floorplan/index.jsx +60 -0
  132. package/src/components/toolbar/popup/index.jsx +241 -0
  133. package/src/components/toolbar/popup/newproject/index.jsx +59 -0
  134. package/src/components/toolbar/popup/newproject/styles.css +64 -0
  135. package/src/components/toolbar/popup/newproject/styles.js +41 -0
  136. package/src/components/toolbar/popup/product/appliance.jsx +54 -0
  137. package/src/components/toolbar/popup/product/cabinetproduct.jsx +15 -0
  138. package/src/components/toolbar/popup/product/doorstyle.jsx +58 -0
  139. package/src/components/toolbar/popup/product/doorstyleproduct.jsx +47 -0
  140. package/src/components/toolbar/popup/product/floor.jsx +36 -0
  141. package/src/components/toolbar/popup/product/floorproduct.jsx +42 -0
  142. package/src/components/toolbar/popup/product/index.jsx +36 -0
  143. package/src/components/toolbar/popup/product/primary.jsx +77 -0
  144. package/src/components/toolbar/popup/product/productline.jsx +93 -0
  145. package/src/components/toolbar/popup/product/reviewItem.jsx +427 -0
  146. package/src/components/toolbar/popup/product/reviewMolding.jsx +310 -0
  147. package/src/components/toolbar/popup/product/style.css +54 -0
  148. package/src/components/toolbar/popup/product/styles.js +260 -0
  149. package/src/components/toolbar/popup/savedesign/FullPictureForm.jsx +146 -0
  150. package/src/components/toolbar/popup/savedesign/index.jsx +495 -0
  151. package/src/components/toolbar/popup/savedesign/savedesign.style.css +16 -0
  152. package/src/components/toolbar/popup/savedesign/styles.js +151 -0
  153. package/src/components/toolbar/popup/setDoorStyleOption/index.jsx +87 -0
  154. package/src/components/toolbar/popup/styles.js +909 -0
  155. package/src/components/toolbar/popup/submitforquote/AddToCartOptions.jsx +192 -0
  156. package/src/components/toolbar/popup/submitforquote/CustomerRequestsForm.jsx +96 -0
  157. package/src/components/toolbar/popup/submitforquote/SkipDesignerReview.jsx +54 -0
  158. package/src/components/toolbar/popup/submitforquote/StepDots.jsx +25 -0
  159. package/src/components/toolbar/popup/submitforquote/cart-choice.jsx +116 -0
  160. package/src/components/toolbar/popup/submitforquote/doorstyle-menus.js +38 -0
  161. package/src/components/toolbar/popup/submitforquote/index.jsx +698 -0
  162. package/src/components/toolbar/popup/submitforquote/styles.css +105 -0
  163. package/src/components/toolbar/popup/submitforquote/styles.js +294 -0
  164. package/src/components/toolbar/popup/submitprompt/index.jsx +89 -0
  165. package/src/components/toolbar/popup/submitprompt/styles.css +64 -0
  166. package/src/components/toolbar/popup/submitprompt/styles.js +42 -0
  167. package/src/components/toolbar/toolbar-button.jsx +90 -0
  168. package/src/components/toolbar/toolbar-load-button.jsx +36 -0
  169. package/src/components/toolbar/toolbar-save-button.jsx +32 -0
  170. package/src/components/wizardstep/button/styles.js +677 -0
  171. package/src/components/wizardstep/export.js +5 -0
  172. package/src/components/wizardstep/index.jsx +1372 -0
  173. package/src/components/wizardstep/styles.js +688 -0
  174. package/src/components/wizardstep/wizardstep-content-button.jsx +198 -0
  175. package/src/components/wizardstep/wizardstep-toggle-button.jsx +101 -0
  176. package/src/{_index.js → index.js} +4 -4
  177. package/src/renderer.jsx +466 -0
  178. package/src/actions/_export.js +0 -35
  179. package/src/components/_export.js +0 -11
@@ -0,0 +1,260 @@
1
+ $white: #ffffff;
2
+
3
+ $text: #74708d;
4
+ $text-lighten: #c0bdd0;
5
+ $text-darken: #615d7c;
6
+ $text-darken-more: #514d6a;
7
+
8
+ $gray: #d2d9e5;
9
+ $gray-lighten: #eef0f4;
10
+ $gray-lighten-more: #f2f4f8;
11
+ $gray-lighten-more-more: #f9fafc;
12
+ $gray-darken: #b8beca;
13
+ $gray-border: #e4e9f0;
14
+
15
+ $black: #0e0b20;
16
+ $black-lighten: #222034;
17
+ $black-lighten-more: #393749;
18
+
19
+ $blue: #0088ff;
20
+ $blue-darken: #0072d6;
21
+ $orange: #f2a654;
22
+ $yellow: yellow;
23
+
24
+ $menuBg: #001529;
25
+ $menuBg-darken: #000c17;
26
+
27
+ // Accent colors
28
+ $default: #acb7bf;
29
+ $primary: #0190fe;
30
+ $secondary: #6a7a84;
31
+ $success: #46be8a;
32
+ $info: #0887c9;
33
+ $warning: #f39834;
34
+ $danger: #fb434a;
35
+
36
+ // Font Family
37
+ $base__font-family: 'Nunito Sans', sans-serif !important;
38
+
39
+ // Font Size
40
+ $base__font-size: 13 !default;
41
+
42
+ // Convert value rem() sass mixin
43
+ @function rem($px, $base: $base__font-size) {
44
+ @return #{floor(($px/$base) * 100) / 100}rem; // to REMs
45
+ // comment code above and uncomment below for change REMs to PXs
46
+ //@return #{$px}px;
47
+ }
48
+
49
+ // Transitions
50
+ @mixin transition-fast() {
51
+ transition: all 0.05s ease-in-out;
52
+ }
53
+ @mixin transition-middle() {
54
+ transition: all 0.1s ease-in-out;
55
+ }
56
+ @mixin transition-slow() {
57
+ transition: all 0.2s ease-in-out;
58
+ }
59
+ @mixin transition-very-slow() {
60
+ transition: all 0.4s ease-in-out;
61
+ }
62
+ @mixin transition-color() {
63
+ transition: color 0.2s ease-in-out;
64
+ }
65
+
66
+ // Responsive utils
67
+ $xxl-min-width: 1600px;
68
+ $xxl-max-width: 1599px;
69
+ $xl-min-width: 1200px;
70
+ $xl-max-width: 1199px;
71
+ $md-min-width: 992px;
72
+ $md-max-width: 991px;
73
+ $sm-min-width: 768px;
74
+ $sm-max-width: 767px;
75
+ $xs-min-width: 576px;
76
+ $xs-max-width: 575px;
77
+
78
+ .login {
79
+ background-size: cover;
80
+ background-color: $gray-lighten-more;
81
+ background-position: center center;
82
+
83
+ &--fullscreen {
84
+ position: fixed;
85
+ z-index: 20000;
86
+ top: 0;
87
+ left: 0;
88
+ height: 100%;
89
+ width: 100%;
90
+ overflow-y: auto;
91
+ }
92
+
93
+ &__block {
94
+ padding: rem(80) rem(40) rem(80);
95
+ margin-bottom: rem(70);
96
+ width: 100%;
97
+ align-self: center;
98
+ position: relative;
99
+ z-index: 2;
100
+
101
+ @media (max-width: $md-max-width) {
102
+ padding: rem(40) rem(20) rem(80);
103
+ }
104
+
105
+ &__inner {
106
+ min-width: rem(300);
107
+ max-width: rem(500);
108
+ margin: 0 auto;
109
+ padding: rem(50) rem(40) rem(20);
110
+ border-radius: 10px;
111
+ overflow: hidden;
112
+ background-color: $white;
113
+ position: relative;
114
+ }
115
+ &__form {
116
+ position: relative;
117
+ z-index: 2;
118
+ }
119
+ &__promo {
120
+ padding: 0 0 rem(60);
121
+ max-width: rem(800);
122
+ font-size: rem(16);
123
+ line-height: rem(26);
124
+ text-align: center;
125
+ margin: 0 auto;
126
+ }
127
+
128
+ &__sidebar {
129
+ display: none;
130
+ }
131
+
132
+ @media (min-width: $md-min-width) {
133
+ &--extended {
134
+ .login__block__inner {
135
+ max-width: rem(800);
136
+ padding: rem(80) rem(80) rem(50);
137
+ }
138
+
139
+ .login__block__form {
140
+ margin-right: rem(300);
141
+ }
142
+
143
+ .login__block__sidebar {
144
+ display: block;
145
+ position: absolute;
146
+ top: 0;
147
+ right: 0;
148
+ bottom: 0;
149
+ width: rem(300);
150
+ padding: rem(80) rem(40);
151
+ color: $white;
152
+ background: $black-lighten;
153
+
154
+ &__item {
155
+ padding-left: rem(20);
156
+ border-left: 2px solid $text;
157
+ margin-bottom: rem(20);
158
+ color: $text;
159
+ }
160
+ &__title {
161
+ margin-bottom: rem(20);
162
+ line-height: 1.5;
163
+ }
164
+ &__place {
165
+ font-size: rem(14);
166
+ font-weight: bold;
167
+ position: absolute;
168
+ z-index: 2;
169
+ bottom: rem(40);
170
+ left: rem(40);
171
+ }
172
+ }
173
+ }
174
+ }
175
+ }
176
+
177
+ &__header {
178
+ align-self: flex-start;
179
+ width: 100%;
180
+ color: $white;
181
+ padding: rem(40);
182
+
183
+ @media (max-width: $md-max-width) {
184
+ padding: rem(40) rem(20) rem(40);
185
+ }
186
+
187
+ &__logo {
188
+ img {
189
+ max-width: rem(150);
190
+ max-height: rem(50);
191
+ }
192
+ }
193
+ &__menu {
194
+ text-align: right;
195
+ margin-top: rem(10);
196
+
197
+ @media (max-width: $md-max-width) {
198
+ text-align: left;
199
+ }
200
+
201
+ ul {
202
+ font-size: rem(16);
203
+ li {
204
+ margin-right: rem(20);
205
+ text-transform: uppercase;
206
+ &:last-child {
207
+ margin-right: 0;
208
+ }
209
+ &.active {
210
+ a {
211
+ border-bottom: 1px solid rgba($white, 0.5);
212
+ }
213
+ }
214
+ a {
215
+ color: $white !important;
216
+ line-height: 1.4;
217
+ display: inline-block;
218
+ margin-right: rem(10);
219
+ font-weight: bold;
220
+ &:hover {
221
+ border-bottom: 1px solid rgba($white, 0.5);
222
+ }
223
+ }
224
+ }
225
+ }
226
+ }
227
+ }
228
+
229
+ &__footer {
230
+ align-self: flex-end;
231
+ width: 100%;
232
+ color: white;
233
+ padding: rem(40);
234
+
235
+ @media (max-width: $md-max-width) {
236
+ padding: rem(40) rem(20) rem(40);
237
+ }
238
+
239
+ ul {
240
+ margin-bottom: 0;
241
+ li {
242
+ margin-right: rem(20);
243
+ text-transform: uppercase;
244
+ &:last-child {
245
+ margin-right: 0;
246
+ }
247
+ a {
248
+ color: $white;
249
+ opacity: 0.7;
250
+ line-height: 1.4;
251
+ display: inline-block;
252
+ margin-right: rem(10);
253
+ &:hover {
254
+ opacity: 1;
255
+ }
256
+ }
257
+ }
258
+ }
259
+ }
260
+ }
@@ -0,0 +1,5 @@
1
+ import MyProjects from './index';
2
+
3
+ export default {
4
+ MyProjects
5
+ };
@@ -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
+ };