UNPKG

114 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, '__esModule', { value: true });
4
5function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
6
7var React = require('react');
8var React__default = _interopDefault(React);
9var filesize = _interopDefault(require('filesize'));
10var reactstrap = require('reactstrap');
11var InputStyleOne = _interopDefault(require('input-style-one'));
12var notify = require('wx-notify');
13var notify__default = _interopDefault(notify);
14var reactApollo = require('react-apollo');
15var gql = _interopDefault(require('graphql-tag'));
16var ApolloClient = _interopDefault(require('apollo-client'));
17var apolloLinkHttp = require('apollo-link-http');
18var apolloCacheInmemory = require('apollo-cache-inmemory');
19var apolloLink = require('apollo-link');
20var apolloLinkContext = require('apollo-link-context');
21var Cookies = _interopDefault(require('js-cookie'));
22var apolloUploadClient = require('apollo-upload-client');
23var accepts = _interopDefault(require('attr-accept'));
24
25const img = '';
26
27/*! *****************************************************************************
28Copyright (c) Microsoft Corporation. All rights reserved.
29Licensed under the Apache License, Version 2.0 (the "License"); you may not use
30this file except in compliance with the License. You may obtain a copy of the
31License at http://www.apache.org/licenses/LICENSE-2.0
32
33THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
34KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
35WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
36MERCHANTABLITY OR NON-INFRINGEMENT.
37
38See the Apache Version 2.0 License for specific language governing permissions
39and limitations under the License.
40***************************************************************************** */
41
42var __assign = function() {
43 __assign = Object.assign || function __assign(t) {
44 for (var s, i = 1, n = arguments.length; i < n; i++) {
45 s = arguments[i];
46 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
47 }
48 return t;
49 };
50 return __assign.apply(this, arguments);
51};
52
53function __awaiter(thisArg, _arguments, P, generator) {
54 return new (P || (P = Promise))(function (resolve, reject) {
55 function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
56 function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
57 function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
58 step((generator = generator.apply(thisArg, _arguments || [])).next());
59 });
60}
61
62function __generator(thisArg, body) {
63 var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
64 return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
65 function verb(n) { return function (v) { return step([n, v]); }; }
66 function step(op) {
67 if (f) throw new TypeError("Generator is already executing.");
68 while (_) try {
69 if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
70 if (y = 0, t) op = [op[0] & 2, t.value];
71 switch (op[0]) {
72 case 0: case 1: t = op; break;
73 case 4: _.label++; return { value: op[1], done: false };
74 case 5: _.label++; y = op[1]; op = [0]; continue;
75 case 7: op = _.ops.pop(); _.trys.pop(); continue;
76 default:
77 if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
78 if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
79 if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
80 if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
81 if (t[2]) _.ops.pop();
82 _.trys.pop(); continue;
83 }
84 op = body.call(thisArg, _);
85 } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
86 if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
87 }
88}
89
90function __makeTemplateObject(cooked, raw) {
91 if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
92 return cooked;
93}
94
95function styleInject(css, ref) {
96 if ( ref === void 0 ) ref = {};
97 var insertAt = ref.insertAt;
98
99 if (!css || typeof document === 'undefined') { return; }
100
101 var head = document.head || document.getElementsByTagName('head')[0];
102 var style = document.createElement('style');
103 style.type = 'text/css';
104
105 if (insertAt === 'top') {
106 if (head.firstChild) {
107 head.insertBefore(style, head.firstChild);
108 } else {
109 head.appendChild(style);
110 }
111 } else {
112 head.appendChild(style);
113 }
114
115 if (style.styleSheet) {
116 style.styleSheet.cssText = css;
117 } else {
118 style.appendChild(document.createTextNode(css));
119 }
120}
121
122var css = ".f-manager{display:flex;flex-direction:column;margin-bottom:10px;box-shadow:0 0 5px rgba(0,0,0,.32);background:#fff;border-radius:5px;width:100%}.f-manager .jbtn{height:35px}.f-manager__block{position:relative;padding:0 12px;display:flex;height:46px;justify-content:space-between}.f-manager__block_item1,.f-manager__block_right{display:flex;align-items:center}.f-manager__block_item1{padding-left:0;margin-right:15px;width:100%;overflow:hidden}.f-manager__block_item1 .item1-text{overflow:hidden;width:60%;justify-content:flex-start;display:grid;flex-direction:column;align-items:start;padding:0;line-height:1.2}.f-manager__block_item1 .item1-text p{line-height:1.2;margin:0;font-size:15px;font-family:dinpro-bold;color:#333;white-space:nowrap;overflow:hidden;width:100%;text-overflow:ellipsis}.f-manager__block_item1 .item1-text span{font-size:11px;color:#b3b3b3;font-family:dinpro-med;text-align:left}.f-manager__block_item1 p{margin-bottom:0}.f-manager__block_item1 img{width:21px;height:21px;margin-right:10px}.f-manager__block_item4{box-shadow:none;background-color:transparent;border-left:1px solid #ccc;padding-left:10px;margin-left:10px;display:flex;align-items:center;height:65%}.f-manager__block_item4 a,.f-manager__block_item4 button,.f-manager__block_item4 span{color:#333;font-family:dinpro-med;text-decoration:none;font-size:14px}.f-manager__block_new-doc{text-transform:uppercase;font-size:10px;border-top-right-radius:5px;border-bottom-right-radius:5px;padding:3px 15px;line-height:1;color:#fff;font-family:dinpro-bold;height:20px;position:absolute;right:0;top:14px;margin:auto -118px auto auto;background:linear-gradient(135deg,transparent 8px,#8d1843 0) 0 0,linear-gradient(45deg,transparent 8px,#8d1843 0) 0 100%;background-size:100% 50%;background-repeat:no-repeat}.f-manager__block_remove{cursor:pointer;border-left:1px solid #ccc;padding:0 7px 0 16px;background:#fff;margin-left:10px;display:flex;height:65%}.f-manager__block_remove img{width:15px}.f-manager__block_status{margin-bottom:0;font-size:12px;display:flex;line-height:1;align-items:center;font-family:dinpro-med;color:grey;max-width:176px;border:none;padding-right:10px;height:65%}.f-manager__block_status img{width:15px;margin-right:5px}.f-manager__block_status_error{color:red}.f-manager__signs{display:flex;align-items:center;justify-content:flex-end;height:46px}.f-manager__signs_label{font-size:13px;color:#333;font-family:dinpro-bold;margin-right:10px}.sign-button{margin-top:10px;display:flex;justify-content:flex-end}\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9maWxlLXZpZXdlci5zY3NzIiwic3JjL3N0eWxlcy9fZm9udHMuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxXQUNFLFlBQWEsQ0FDYixxQkFBc0IsQ0FDdEIsa0JBQWtCLENBQ2xCLGtDQUF1QyxDQUN2QyxlQUFpQixDQUNqQixpQkFBa0IsQ0FDbEIsVUFBVyxDQVBiLGlCQVNJLFdBQVksQ0FHZCxrQkFDRSxpQkFBa0IsQ0FDbEIsY0FBaUIsQ0FDakIsWUFBYSxDQUNiLFdBQVksQ0FDWiw2QkFBOEIsQ0FNOUIsZ0RBSEUsWUFBYSxDQUNiLGtCQVFnQixDQU5sQix3QkFDRSxjQUFlLENBQ2YsaUJBQWtCLENBQ2xCLFVBQVcsQ0FHWCxlQUFnQixDQU5qQixvQ0FRRyxlQUFnQixDQUNoQixTQUFVLENBQ1YsMEJBQTJCLENBQzNCLFlBQWEsQ0FDYixxQkFBc0IsQ0FDdEIsaUJBQWtCLENBQ2xCLFNBQVUsQ0FDVixlQUFnQixDQWZuQixzQ0FpQkssZUFBZ0IsQ0FDaEIsUUFBUyxDQUNULGNBQWUsQ0FDZix1QkMzQ2EsQ0Q0Q2IsVUFBYyxDQUNkLGtCQUFtQixDQUNuQixlQUFnQixDQUNoQixVQUFXLENBQ1gsc0JBQW1ELENBekJ4RCx5Q0E0QkssY0FBZSxDQUNmLGFBQWMsQ0FDZCxzQkN0RFcsQ0R1RFgsZUFBZ0IsQ0EvQnJCLDBCQW1DRyxlQUFnQixDQW5DbkIsNEJBc0NHLFVBQVcsQ0FDWCxXQUFZLENBQ1osaUJBQWtCLENBR3RCLHdCQUNFLGVBQWdCLENBQ2hCLDRCQUE2QixDQUM3QiwwQkFBOEIsQ0FDOUIsaUJBQWtCLENBRWxCLGdCQUFpQixDQUNqQixZQUFhLENBQ2Isa0JBQW1CLENBQ25CLFVBQVcsQ0FUWixzRkFXRyxVQUFjLENBQ2Qsc0JDL0VhLENEZ0ZiLG9CQUFxQixDQUNyQixjQUFlLENBR25CLDBCQUNFLHdCQUF5QixDQUN6QixjQUFlLENBQ2YsMkJBQTRCLENBQzVCLDhCQUErQixDQUMvQixnQkFBaUIsQ0FDakIsYUFBYyxDQUNkLFVBQVksQ0FDWix1QkMzRmlCLENENEZqQixXQUFZLENBRVosaUJBQWtCLENBQ2xCLE9BQVEsQ0FDUixRQUFTLENBQ1QsNEJBQW9CLENBQ3BCLHdIQUM4RCxDQUM5RCx3QkFBeUIsQ0FDekIsMkJBQTRCLENBRTlCLHlCQUNFLGNBQWUsQ0FDZiwwQkFBOEIsQ0FDOUIsb0JBQXFCLENBQ3JCLGVBQWlCLENBQ2pCLGdCQUFpQixDQUNqQixZQUFhLENBQ2IsVUFBVyxDQVBaLDZCQVNHLFVBQVcsQ0FHZix5QkFDRSxlQUFnQixDQUNoQixjQUFlLENBQ2YsWUFBYSxDQUNiLGFBQWMsQ0FDZCxrQkFBbUIsQ0FDbkIsc0JDMUhlLENEMkhmLFVBQWMsQ0FDZCxlQUFnQixDQUVoQixXQUFZLENBRVosa0JBQW1CLENBQ25CLFVBQVcsQ0FiWiw2QkFlRyxVQUFXLENBQ1gsZ0JBQWlCLENBRW5CLCtCQUNFLFNBQVUsQ0FJaEIsa0JBQ0UsWUFBYSxDQUNiLGtCQUFtQixDQUNuQix3QkFBeUIsQ0FDekIsV0FBWSxDQUNaLHdCQUNFLGNBQWUsQ0FDZixVQUFjLENBQ2QsdUJBQXdCLENBQ3hCLGlCQUFrQixDQUl4QixhQUNFLGVBQWdCLENBQ2hCLFlBQWEsQ0FDYix3QkFBeUIiLCJmaWxlIjoiZmlsZS12aWV3ZXIuc2NzcyJ9 */";
123styleInject(css);
124
125const img$1 = '';
126
127const img$2 = '';
128
129const img$3 = '';
130
131const img$4 = '';
132
133const img$5 = '';
134
135var messages = {
136 en: {
137 "chooseFile": "Choose File",
138 "download": "View",
139 "moderate": "Moderate",
140 "sign": "Sign",
141 "Select the file with EDS": "Select EDS file (GOST)",
142 "EDS": "EDS",
143 "BIN": "BIN",
144 "IIN": "IIN",
145 "Owner of EDS": "Owner of EDS",
146 "Authority issuing EDS": "Authority issuing EDS",
147 "Valid thought": "Valid thought"
148 },
149 ru: {
150 "chooseFile": "Выберите файл",
151 "download": "Просмотреть",
152 "moderate": "Модерация",
153 "sign": "Подписать",
154 "Select the file with EDS": "Выберите файл ЭЦП (GOST)",
155 "EDS": "ЭЦП",
156 "BIN": "БИН",
157 "IIN": "ИИН",
158 "Owner of EDS": "Владелец ЭЦП",
159 "Authority issuing EDS": "Орган, выдавший ЭЦП",
160 "Valid thought": "Действителен до",
161 "Key algorithm": "Алгоритм ключа"
162 },
163 kk: {
164 "chooseFile": "Файлды тандаңыз",
165 "download": "Карау",
166 "moderate": "Модерация",
167 "sign": "Қол қою",
168 "Select the file with EDS": "ЭЦҚ файлын таңданыз (GOST)",
169 "EDS": "ЭЦҚ",
170 "BIN": "БСН",
171 "BIK": "БСК",
172 "IIC": "ЖСК",
173 "IIN": "ЖСН",
174 "Beneficiary Code": "Кбе",
175 "Owner of EDS": "ЭЦҚ иесі",
176 "Authority issuing EDS": "ЭЦҚ берілген мекеме",
177 "Valid thought": "Жарамдылық мерзімі",
178 "Key algorithm": "Кілт алгоритмі"
179 }
180};
181
182var css$1 = ".loader{display:flex;flex-direction:column;align-items:center;position:absolute;left:0;bottom:0;z-index:1;width:100%;height:100%;background-color:hsla(0,0%,100%,.8);border-bottom-right-radius:10px;border-bottom-left-radius:10px}.loader:after,.loader:before{content:\"\";flex:1}.loader--eds .loader__spinner{width:100px;height:100px;background:#ffd012}.loader--modal{height:calc(100% - 81px)}.loader--modal-step{height:calc(100% - 95px)}.loader--grid-view{height:calc(100% - 38px)}.loader--goods{top:0;border-radius:10px}.loader--nav-right{top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fff}.loader__content{display:flex;flex-direction:column;align-items:center}.loader__spinner{position:relative;width:140px;height:140px;margin:0;background-color:#f7f7f7;border-radius:50%}.loader--modal-step .loader__spinner,.loader--modal .loader__spinner{width:100px;height:100px;background-color:#ffd012}.loader--main .loader__spinner{background-color:#ffd012}.loader__text{margin:0;font-family:dinpro-med;text-align:center}\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9tdWx0aXBsZS11cGxvYWRlci9tb2RhbHMvaW5kZXguc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxRQUNJLFlBQWEsQ0FDYixxQkFBc0IsQ0FDdEIsa0JBQW1CLENBRW5CLGlCQUFrQixDQUNsQixNQUFPLENBQ1AsUUFBUyxDQUNULFNBQVUsQ0FFVixVQUFXLENBQ1gsV0FBWSxDQUVaLG1DQUEwQyxDQUUxQywrQkFBZ0MsQ0FDaEMsOEJBQStCLENBaEJuQyw2QkFvQk0sVUFBVyxDQUNYLE1BQU8sQ0FFUiw4QkFFRyxXQUFZLENBQ1osWUFBYSxDQUNiLGtCQUFtQixDQUd2QixlQUNFLHdCQUF5QixDQUczQixvQkFDRSx3QkFBeUIsQ0FHM0IsbUJBQ0Usd0JBQXlCLENBRzNCLGVBQ0UsS0FBTSxDQUVOLGtCQUFtQixDQUdyQixtQkFDRSxPQUFRLENBQ1IsUUFBUyxDQUNULDhCQUFnQyxDQUNoQyxxQkFBb0MsQ0FHdEMsaUJBQ0UsWUFBYSxDQUNiLHFCQUFzQixDQUN0QixrQkFBbUIsQ0FHckIsaUJBQ0UsaUJBQWtCLENBQ2xCLFdBQVksQ0FDWixZQUFhLENBQ2IsUUFBUyxDQUVULHdCQUF5QixDQUN6QixpQkFBa0IsQ0FHcEIscUVBRUUsV0FBWSxDQUNaLFlBQWEsQ0FFYix3QkFBeUIsQ0FHM0IsK0JBQ0Usd0JBQXlCLENBVzNCLGNBQ0UsUUFBUyxDQUNULHNCQUF1QixDQUN2QixpQkFBa0IiLCJmaWxlIjoiaW5kZXguc2NzcyJ9 */";
183styleInject(css$1);
184
185const img$6 = '';
186
187var language = localStorage.getItem("i18nextLng") ? localStorage.getItem("i18nextLng") : "ru";
188var Moderate = function (props) {
189 var _a = React.useState(false), modal = _a[0], setModal = _a[1];
190 var handleModerate = props.handleModerate, fileId = props.fileId;
191 var toggle = function (e) {
192 e.preventDefault();
193 setModal(!modal);
194 };
195 return (React__default.createElement(React__default.Fragment, null,
196 React__default.createElement("span", { className: "f-manager__block_item4" },
197 React__default.createElement("a", { href: "#", target: "_blank", onClick: toggle }, messages[language].moderate)),
198 React__default.createElement(reactstrap.Modal, { isOpen: modal, className: "prompt", centered: true, toggle: toggle, backdrop: "static" },
199 React__default.createElement(reactstrap.ModalHeader, null, "\u0423\u0434\u0430\u043B\u0435\u043D\u0438\u0435 \u0434\u043E\u043A\u0443\u043C\u0435\u043D\u0442\u0430"),
200 React__default.createElement(reactstrap.ModalBody, null, "\u0412\u044B \u0443\u0432\u0435\u0440\u0435\u043D\u044B \u0447\u0442\u043E \u0445\u043E\u0442\u0438\u0442\u0435 \u0443\u0434\u0430\u043B\u0438\u0442\u044C \u0444\u0430\u0439\u043B?"),
201 React__default.createElement(reactstrap.ModalFooter, null,
202 React__default.createElement("button", { className: "jbtn jbtn-low jbtn-cancel", onClick: function (e) { return toggle(e); } }, "\u041E\u0442\u043C\u0435\u043D\u0430"),
203 React__default.createElement("button", { className: "jbtn jbtn-low jbtn-red", onClick: function (e) {
204 handleModerate(e, fileId, 0);
205 setModal(false);
206 } }, "\u0423\u0434\u0430\u043B\u0438\u0442\u044C"),
207 React__default.createElement("button", { className: "jbtn jbtn-low jbtn-green", onClick: function (e) {
208 handleModerate(e, fileId, 2);
209 setModal(false);
210 } }, "\u041F\u043E\u0434\u0432\u0435\u0440\u0434\u0438\u0442\u044C")))));
211};
212
213var grainReceiptsData = gql(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n fragment GrainReceiptsData on GrainReceiptsData {\n docNumber\n docTime\n ownerBIN\n elevator\n elevatorBIN\n specifications {\n status\n GRNumber\n createTime\n amount\n culture\n class\n cropYear\n category\n grade\n reproduction\n seedCompositionClass\n moisture\n weedyImpurity\n grainImpurity\n infection\n infectionLevel\n smell\n color\n type\n testWeight\n gluten\n glutenCU\n hoodness\n fallingNumber\n protein\n vitreousness\n otherIndicators\n }\n errors\n }\n"], ["\n fragment GrainReceiptsData on GrainReceiptsData {\n docNumber\n docTime\n ownerBIN\n elevator\n elevatorBIN\n specifications {\n status\n GRNumber\n createTime\n amount\n culture\n class\n cropYear\n category\n grade\n reproduction\n seedCompositionClass\n moisture\n weedyImpurity\n grainImpurity\n infection\n infectionLevel\n smell\n color\n type\n testWeight\n gluten\n glutenCU\n hoodness\n fallingNumber\n protein\n vitreousness\n otherIndicators\n }\n errors\n }\n"])));
214var fileFragments = {
215 common: gql(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n fragment CommonFiles on Files {\n _id\n path\n name\n size\n createTime\n metadata {\n title\n objId\n objType\n creatorId\n categoryId\n signs {\n userId\n time\n signed\n label\n }\n status\n }\n grainReceiptData {\n ...GrainReceiptsData\n }\n }\n ", "\n "], ["\n fragment CommonFiles on Files {\n _id\n path\n name\n size\n createTime\n metadata {\n title\n objId\n objType\n creatorId\n categoryId\n signs {\n userId\n time\n signed\n label\n }\n status\n }\n grainReceiptData {\n ...GrainReceiptsData\n }\n }\n ", "\n "])), grainReceiptsData)
216};
217var UPLOADFILE_LINK_MUTATION = gql(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n mutation singleUpload($file: Upload, $metadata: MetadataInput) {\n singleUpload(file: $file, metadata: $metadata) {\n ...CommonFiles\n }\n }\n ", "\n"], ["\n mutation singleUpload($file: Upload, $metadata: MetadataInput) {\n singleUpload(file: $file, metadata: $metadata) {\n ...CommonFiles\n }\n }\n ", "\n"])), fileFragments.common);
218var UPLOAD_MULTIPLE_LINK_MUTATION = gql(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n mutation multipleUpload($files: [Upload], $metadata: MetadataInput) {\n multipleUpload(files: $files, metadata: $metadata) {\n ...CommonFiles\n }\n }\n ", "\n"], ["\n mutation multipleUpload($files: [Upload], $metadata: MetadataInput) {\n multipleUpload(files: $files, metadata: $metadata) {\n ...CommonFiles\n }\n }\n ", "\n"])), fileFragments.common);
219var CHECK_EDS_DATA = gql(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n mutation checkEDSData($p12Base64: String, $password: String) {\n checkEDSData(p12Base64: $p12Base64, password: $password) {\n owner\n issuer\n expireTime\n iin\n bin\n }\n }\n"], ["\n mutation checkEDSData($p12Base64: String, $password: String) {\n checkEDSData(p12Base64: $p12Base64, password: $password) {\n owner\n issuer\n expireTime\n iin\n bin\n }\n }\n"])));
220var GET_AVERAGE_GRAIN_RECEIPT_DATA = gql(templateObject_6 || (templateObject_6 = __makeTemplateObject(["\n query getAverageGrainReceiptData($fileIds: [String]) {\n getAverageGrainReceiptData(fileIds: $fileIds) {\n ...GrainReceiptsData\n }\n }\n ", "\n"], ["\n query getAverageGrainReceiptData($fileIds: [String]) {\n getAverageGrainReceiptData(fileIds: $fileIds) {\n ...GrainReceiptsData\n }\n }\n ", "\n"])), grainReceiptsData);
221var READ_GRAIN_RECEIPT_DATA = gql(templateObject_7 || (templateObject_7 = __makeTemplateObject(["\n mutation readGrainReceiptData($fileId: String) {\n readGrainReceiptData(fileId: $fileId) {\n ...CommonFiles\n }\n }\n ", "\n"], ["\n mutation readGrainReceiptData($fileId: String) {\n readGrainReceiptData(fileId: $fileId) {\n ...CommonFiles\n }\n }\n ", "\n"])), fileFragments.common);
222var REMOVE_LINK_MUTATION = gql(templateObject_8 || (templateObject_8 = __makeTemplateObject(["\n mutation deleteFile($fileId: String) {\n deleteUpload(fileId: $fileId)\n }\n"], ["\n mutation deleteFile($fileId: String) {\n deleteUpload(fileId: $fileId)\n }\n"])));
223var MODERATE_LINK_MUTATION = gql(templateObject_9 || (templateObject_9 = __makeTemplateObject(["\n mutation moderateFile($fileId: String, $status: Int) {\n moderateUpload(fileId: $fileId, status: $status) {\n ...CommonFiles\n }\n }\n ", "\n"], ["\n mutation moderateFile($fileId: String, $status: Int) {\n moderateUpload(fileId: $fileId, status: $status) {\n ...CommonFiles\n }\n }\n ", "\n"])), fileFragments.common);
224var SIGN_FILE = gql(templateObject_10 || (templateObject_10 = __makeTemplateObject(["\n mutation signDocument($fileId: String, $p12Base64: String, $password: String) {\n signDocument(fileId: $fileId, p12Base64: $p12Base64, password: $password) {\n ...CommonFiles\n }\n }\n ", "\n"], ["\n mutation signDocument($fileId: String, $p12Base64: String, $password: String) {\n signDocument(fileId: $fileId, p12Base64: $p12Base64, password: $password) {\n ...CommonFiles\n }\n }\n ", "\n"])), fileFragments.common);
225var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6, templateObject_7, templateObject_8, templateObject_9, templateObject_10;
226
227var httpLink = function (uri) { return apolloLinkHttp.createHttpLink({ uri: uri }); };
228var authLink = apolloLinkContext.setContext(function (_, _a) {
229 var headers = _a.headers;
230 // get the authentication token from local storage if it exists
231 var token = Cookies.get("loginToken");
232 var language = "ru";
233 // return the headers to the context so httpLink can read them
234 return {
235 headers: __assign({}, headers, { "authorization": token ? token : "", "accept-language": language })
236 };
237});
238var gatewayClient = function (uri) {
239 return new ApolloClient({
240 link: apolloLink.ApolloLink.from([authLink, httpLink(uri)]),
241 cache: new apolloCacheInmemory.InMemoryCache({
242 dataIdFromObject: function (o) {
243 return o.id ? o.__typename + ":" + o.id : null;
244 }
245 })
246 });
247};
248
249var httpLink$1 = function (uri) { return apolloLinkHttp.createHttpLink({ uri: uri }); };
250var customFetch = function (uri, options) {
251 if (options.useUpload) {
252 return uploadFetch(uri, options);
253 }
254 return fetch(uri, options);
255};
256var uploadLink = function (uri) { return apolloUploadClient.createUploadLink({ uri: uri, fetch: customFetch }); };
257var authLink$1 = apolloLinkContext.setContext(function (_, _a) {
258 var headers = _a.headers;
259 // get the authentication token from local storage if it exists
260 var token = Cookies.get("loginToken");
261 var language = localStorage.getItem("i18nextLng") ? localStorage.getItem("i18nextLng") : "en-US";
262 // return the headers to the context so httpLink can read them
263 return {
264 headers: __assign({}, headers, { "authorization": token ? token : "", "accept-language": language })
265 };
266});
267var isObject = function (node) { return typeof node === "object" && node !== null; };
268var hasFiles = function (node, found) {
269 if (found === void 0) { found = []; }
270 Object.keys(node).forEach(function (key) {
271 if (!isObject(node[key]) || found.length > 0) {
272 return;
273 }
274 if ((typeof File !== "undefined" && node[key] instanceof File) ||
275 (typeof Blob !== "undefined" && node[key] instanceof Blob)) {
276 found.push(node[key]);
277 return;
278 }
279 hasFiles(node[key], found);
280 });
281 return found.length > 0;
282};
283var link2 = function (uri) { return apolloLink.split(function (_a) {
284 var variables = _a.variables;
285 return hasFiles(variables);
286}, uploadLink(uri), httpLink$1(uri)); };
287var client = function (uri) {
288 return new ApolloClient({
289 link: apolloLink.ApolloLink.from([authLink$1, link2(uri)]),
290 cache: new apolloCacheInmemory.InMemoryCache({
291 dataIdFromObject: function (o) {
292 return o.id ? o.__typename + ":" + o.id : null;
293 }
294 })
295 });
296};
297var parseHeaders = function (rawHeaders) {
298 var headers = new Headers();
299 // Replace instances of \r\n and \n followed by at least one space or horizontal tab with a space
300 // https://tools.ietf.org/html/rfc7230#section-3.2
301 var preProcessedHeaders = rawHeaders.replace(/\r?\n[\t ]+/g, " ");
302 preProcessedHeaders.split(/\r?\n/).forEach(function (line) {
303 var parts = line.split(":");
304 var key = parts.shift().trim();
305 if (key) {
306 var value = parts.join(":").trim();
307 headers.append(key, value);
308 }
309 });
310 return headers;
311};
312var uploadFetch = function (url, options) {
313 return new Promise(function (resolve, reject) {
314 var xhr = new XMLHttpRequest();
315 xhr.onload = function () {
316 var opts = {
317 status: xhr.status,
318 statusText: xhr.statusText,
319 headers: parseHeaders(xhr.getAllResponseHeaders() || "")
320 };
321 opts.url = "responseURL" in xhr ? xhr.responseURL : opts.headers.get("X-Request-URL");
322 var body = "response" in xhr ? xhr.response : xhr.responseText;
323 resolve(new Response(body, opts));
324 };
325 xhr.onerror = function () {
326 reject(new TypeError("Network request failed"));
327 };
328 xhr.ontimeout = function () {
329 reject(new TypeError("Network request failed"));
330 };
331 xhr.open(options.method, url, true);
332 Object.keys(options.headers).forEach(function (key) {
333 xhr.setRequestHeader(key, options.headers[key]);
334 });
335 if (xhr.upload) {
336 xhr.upload.onprogress = options.onProgress;
337 }
338 options.onAbortPossible(function () {
339 xhr.abort();
340 });
341 xhr.send(options.body);
342 });
343};
344
345var UploaderContext = React.createContext({
346 uploadUri: null,
347 gatewayUri: null
348});
349
350var _this = undefined;
351var language$1 = localStorage.getItem("i18nextLng") ? localStorage.getItem("i18nextLng") : "ru";
352var SignFile = function (props) {
353 var _a = React.useState(false), modal = _a[0], setModal = _a[1];
354 var _b = React.useState(false), modal2 = _b[0], setModal2 = _b[1];
355 var _c = React.useState({ value: "Qwerty12", isValid: false }), password = _c[0], setPassword = _c[1];
356 var _d = React.useState(null), p12Base64 = _d[0], setP12Base64 = _d[1];
357 var _e = React.useContext(UploaderContext), uploadUri = _e.uploadUri, gatewayUri = _e.gatewayUri;
358 React.useEffect(function () {
359 return function () {
360 setModal(false);
361 };
362 }, []);
363 /** Управление первой модалкой (данные ЭЦП) */
364 var toggle = function (e) {
365 e.preventDefault();
366 setModal(!modal);
367 };
368 /** Управление второй модалкой (пароль ЭЦП) */
369 var toggle2 = function (e) {
370 e.preventDefault();
371 setModal2(!modal2);
372 };
373 /** Обычный handler поля */
374 var handleChange = function (result, setStateCallback) {
375 var value = result.value, isValid = result.isValid;
376 setStateCallback({ value: value, isValid: isValid });
377 };
378 /** handler родителя */
379 var handleSignParent = props.handleSign;
380 /** Лучше mutation делать здесь т.к. легче хендлить loading, error непосредственно в компоненте, где она и используется */
381 var _f = reactApollo.useMutation(SIGN_FILE, { client: client(uploadUri) }), signFile = _f[0], sLoading = _f[1].loading;
382 var _g = React.useState(null), EDSdata = _g[0], setEDSData = _g[1];
383 var _h = reactApollo.useMutation(CHECK_EDS_DATA, { client: gatewayClient(gatewayUri) }), checkEDSData = _h[0], _j = _h[1], loading = _j.loading, error = _j.error;
384 var handleSign = function (e, fileId) { return __awaiter(_this, void 0, void 0, function () {
385 var file, error_1;
386 return __generator(this, function (_a) {
387 switch (_a.label) {
388 case 0:
389 e.preventDefault();
390 file = null;
391 _a.label = 1;
392 case 1:
393 _a.trys.push([1, 3, , 4]);
394 return [4 /*yield*/, signFile({ variables: { fileId: fileId, p12Base64: p12Base64, password: password.value } })];
395 case 2:
396 file = _a.sent();
397 return [3 /*break*/, 4];
398 case 3:
399 error_1 = _a.sent();
400 notify.notifyServer({
401 Content: function () {
402 return (React__default.createElement("span", null, error_1.graphQLErrors ? error_1.graphQLErrors[0].message : "Ошибка подписи, повторите попытку позже"));
403 },
404 type: "error"
405 });
406 return [3 /*break*/, 4];
407 case 4:
408 if (file) {
409 notify__default({
410 header: "Файл подписан",
411 description: "Файл успешно подписан!!!"
412 });
413 handleSignParent && handleSignParent(file.data.signDocument);
414 setModal(false);
415 }
416 else {
417 setEDSData(null);
418 }
419 return [2 /*return*/];
420 }
421 });
422 }); };
423 /**
424 * Берем содержимое файла ключа (base64) и помещаем ее в state, это много не занимает время тк. файли не весит много
425 * Потом вытаскиваем модалку с паролем
426 * @param e
427 */
428 var handleEDS = function (e) {
429 e.preventDefault();
430 var reader = new FileReader();
431 var _a = e.target, validity = _a.validity, file = _a.files[0];
432 if (validity.valid) {
433 reader.readAsDataURL(file);
434 reader.onload = function () {
435 setModal2(!modal2);
436 setP12Base64(reader.result);
437 };
438 }
439 };
440 /**
441 * У нас есть файл (base64), есть пароль - отправляем на проверку
442 * @param e
443 */
444 var handlePasswordSubmit = function (e) {
445 e.preventDefault();
446 checkEDSData({ variables: { p12Base64: p12Base64, password: password.value } })
447 .then(function (_a) {
448 var data = _a.data;
449 setEDSData(data.checkEDSData);
450 setModal2(false);
451 notify.notifyServer({ dismiss: true });
452 })
453 .catch(function (e) {
454 var errors = e.graphQLErrors[0].extensions.exception.inputErrors;
455 notify.notifyServer({
456 Content: function () {
457 return (React__default.createElement("ul", { style: { padding: 0, margin: 0 } }, errors
458 ? errors.map(function (error, key) { return React__default.createElement("li", { key: key }, error.message); })
459 : "Не удалось проверить данные. Повторите позже"));
460 },
461 type: "error"
462 });
463 });
464 };
465 var RenderContent = function () {
466 var randInd = Math.floor(Math.random() * (10000 - 1)) + 1;
467 if (EDSdata) {
468 return (React__default.createElement("ul", { className: "reg-info" },
469 React__default.createElement("li", null,
470 React__default.createElement("p", null,
471 messages[language$1]["Owner of EDS"],
472 ":"),
473 React__default.createElement("p", { className: "ecp-info" }, EDSdata.owner)),
474 React__default.createElement("li", null,
475 React__default.createElement("p", null,
476 messages[language$1]["Authority issuing EDS"],
477 ":"),
478 React__default.createElement("p", { className: "ecp-info" }, EDSdata.issuer)),
479 React__default.createElement("li", null,
480 React__default.createElement("p", null,
481 messages[language$1]["Valid thought"],
482 ":"),
483 React__default.createElement("p", { className: "ecp-info" }, EDSdata.expireTime)),
484 React__default.createElement("li", null,
485 React__default.createElement("p", null,
486 messages[language$1]["IIN"],
487 ":"),
488 React__default.createElement("p", { className: "ecp-info" }, EDSdata.iin)),
489 React__default.createElement("li", null,
490 React__default.createElement("p", null,
491 messages[language$1]["BIN"],
492 ":"),
493 React__default.createElement("p", { className: "ecp-info" }, EDSdata.bin))));
494 }
495 return (React__default.createElement("div", { style: { display: "flex", justifyContent: "center", marginBottom: "45px" } },
496 React__default.createElement("input", { type: "file", id: "EDS-sign-" + randInd, required: true, onChange: function (e) { return handleEDS(e); }, accept: ".p12", style: { display: "none" } }),
497 React__default.createElement("label", { htmlFor: "EDS-sign-" + randInd, className: "jbtn jbtn-fuksiya" }, messages[language$1]["Select the file with EDS"])));
498 };
499 return (React__default.createElement(React__default.Fragment, null,
500 React__default.createElement("div", { className: "sign-button" },
501 React__default.createElement("button", { className: "jbtn jbtn-wide jbtn-green", onClick: function (e) { return toggle(e); } }, messages[language$1].sign)),
502 React__default.createElement(reactstrap.Modal, { isOpen: modal, className: "prompt", centered: true, toggle: toggle, backdrop: "static" },
503 React__default.createElement(reactstrap.ModalHeader, null, "\u041F\u043E\u0434\u043F\u0438\u0441\u0430\u043D\u0438\u0435 \u0434\u043E\u043A\u0443\u043C\u0435\u043D\u0442\u0430"),
504 (sLoading || loading) && React__default.createElement(StdLoader, { type: "modal", text: "\u041F\u043E\u0434\u043F\u0438\u0441\u0430\u043D\u0438\u0435 \u0444\u0430\u0439\u043B\u0430, \u043F\u043E\u0434\u043E\u0436\u0434\u0438\u0442\u0435" }),
505 React__default.createElement("form", { className: "mad-form", onSubmit: function (e) { return handleSign(e, props.fileId); } },
506 React__default.createElement(reactstrap.ModalBody, null,
507 React__default.createElement("p", { style: { fontFamily: "dinpro-med", fontSize: "13px", lineHeight: "1.3" } }, "\u0421\u043E\u0433\u043B\u0430\u0441\u043D\u043E \u0441\u0442\u0430\u0442\u044C\u0438 24 \u0417\u0430\u043A\u043E\u043D\u0430 \u0420\u041A \u043E\u0442 7.01.2003 \u2116 370 \u00AB\u041E\u0431 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u043C \u0434\u043E\u043A\u0443\u043C\u0435\u043D\u0442\u0435 \u0438 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u0446\u0438\u0444\u0440\u043E\u0432\u043E\u0439 \u043F\u043E\u0434\u043F\u0438\u0441\u0438\u00BB, \u043F\u043E\u0434\u043F\u0438\u0441\u0430\u043D\u043D\u044B\u0439 \u042D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u044B\u0439 \u0434\u043E\u043A\u0443\u043C\u0435\u043D\u0442 \u0440\u0430\u0432\u043D\u043E\u0437\u043D\u0430\u0447\u0435\u043D \u0434\u043E\u043A\u0443\u043C\u0435\u043D\u0442\u0443 \u043D\u0430 \u0431\u0443\u043C\u0430\u0436\u043D\u043E\u043C \u043D\u043E\u0441\u0438\u0442\u0435\u043B\u0435."),
508 React__default.createElement("p", { style: { fontFamily: "dinpro-med", fontSize: "13px", lineHeight: "1.3" } }, "\u0414\u043B\u044F \u043F\u043E\u0434\u043F\u0438\u0441\u0430\u043D\u0438\u0435 \u044D\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0433\u043E \u0434\u043E\u043A\u0443\u043C\u0435\u043D\u0442\u0430, \u0432\u044B\u0431\u0435\u0440\u0438\u0442\u0435 \u0412\u0430\u0448 \u042D\u0426\u041F (GOST \u0438\u043B\u0438 RSA)"),
509 React__default.createElement(RenderContent, null)),
510 React__default.createElement(reactstrap.ModalFooter, null,
511 React__default.createElement("button", { className: "jbtn jbtn-low jbtn-cancel", onClick: function (e) { return toggle(e); } }, "\u041E\u0442\u043C\u0435\u043D\u0430"),
512 React__default.createElement("button", { className: "jbtn jbtn-low jbtn-green", type: "submit", disabled: !EDSdata }, "\u041F\u043E\u0434\u043F\u0438\u0441\u0430\u0442\u044C")))),
513 React__default.createElement(reactstrap.Modal, { isOpen: modal2, className: "eds-pass", centered: true, backdrop: true },
514 React__default.createElement("form", { className: "mad-form", onSubmit: function (e) { return handlePasswordSubmit(e); } },
515 loading && React__default.createElement(StdLoader, { type: "eds" }),
516 React__default.createElement(reactstrap.ModalBody, null,
517 React__default.createElement(InputStyleOne, { label: "\u041F\u0430\u0440\u043E\u043B\u044C \u042D\u0426\u041F", name: "password", value: password.value, enableTooltip: false, rules: ["required"], inputType: "password", handleChange: function (result) { return handleChange(result, setPassword); } })),
518 React__default.createElement(reactstrap.ModalFooter, null,
519 React__default.createElement("button", { className: "jbtn jbtn-low jbtn-cancel", onClick: function (e) { return toggle2(e); } }, "\u041E\u0442\u043C\u0435\u043D\u0430"),
520 React__default.createElement("button", { className: "jbtn jbtn-low jbtn-green", type: "submit", disabled: password.value == "" }, "\u041F\u043E\u0434\u0432\u0435\u0440\u0434\u0438\u0442\u044C"))))));
521};
522var StdLoader = function (_a) {
523 var _b = _a.type, type = _b === void 0 ? "" : _b, text = _a.text;
524 var clazz = type ? "loader loader--" + type : "loader";
525 return (React__default.createElement("div", { className: clazz },
526 React__default.createElement("div", { className: "loader__content" },
527 React__default.createElement("p", { className: "loader__spinner" },
528 React__default.createElement("img", { src: img$6, style: {
529 position: "absolute",
530 width: "40px",
531 left: "50%",
532 top: "50%",
533 transform: "translate(-50%, -50%)"
534 }, alt: "" })),
535 text && React__default.createElement("p", { className: "loader__text" }, text))));
536};
537
538var _this$1 = undefined;
539var OBJ_TYPE_GRAIN_RECEIPTS = 101;
540var language$2 = localStorage.getItem("i18nextLng") ? localStorage.getItem("i18nextLng") : "ru";
541var StdSpinner = function () {
542 return (React__default.createElement("div", { className: "mad-uploader-spinner" },
543 React__default.createElement("div", { className: "sk-three-bounce" },
544 React__default.createElement("div", { className: "sk-bounce-1 sk-child" }),
545 React__default.createElement("div", { className: "sk-bounce-2 sk-child" }),
546 React__default.createElement("div", { className: "sk-bounce-3 sk-child" }))));
547};
548var SignFileStatus = function (_a) {
549 var metadata = _a.metadata, showFileStatus = _a.showFileStatus;
550 var signs = metadata.signs, objType = metadata.objType, status = metadata.status;
551 if (!showFileStatus && signs.length == 0) {
552 return React__default.createElement(React__default.Fragment, null);
553 }
554 var FileStatus = function () {
555 if (!showFileStatus) {
556 return React__default.createElement(React__default.Fragment, null);
557 }
558 var data = {
559 icon: "",
560 className: "",
561 label: ""
562 };
563 // отклонен
564 if (status == 0) {
565 data = { icon: img$2, className: "f-manager__block_status_error", label: "Отклонен" };
566 }
567 //на модерации
568 if (status == 1) {
569 data = { icon: img$4, className: "", label: "Ожидает модерации" };
570 }
571 // проверен
572 if (status == 2) {
573 data = { icon: img$1, className: "", label: "Проверен" };
574 }
575 return (React__default.createElement(React__default.Fragment, null,
576 React__default.createElement("span", { className: "f-manager__signs_label" }, "\u0421\u0442\u0430\u0442\u0443\u0441 \u0434\u043E\u043A\u0443\u043C\u0435\u043D\u0442\u0430:"),
577 React__default.createElement("div", { className: "f-manager__block_status" },
578 React__default.createElement("img", { src: data.icon, alt: "" }),
579 React__default.createElement("span", { className: data.className }, data.label))));
580 };
581 var SignsStatus = function () {
582 if (signs.length == 0 || objType == OBJ_TYPE_GRAIN_RECEIPTS) {
583 return React__default.createElement(React__default.Fragment, null);
584 }
585 return (React__default.createElement(React__default.Fragment, null,
586 React__default.createElement("span", { className: "f-manager__signs_label" }, objType == OBJ_TYPE_GRAIN_RECEIPTS ? "Статус зерновой расписки:" : "Подписи:"),
587 signs.map(function (sign, key) { return (React__default.createElement("div", { className: "f-manager__block_status", key: key },
588 React__default.createElement("img", { src: sign.signed ? img$1 : img$4, alt: "" }),
589 React__default.createElement("span", null, sign.label))); })));
590 };
591 var GrainReceiptsStatus = function () {
592 if (signs.length == 0 || objType != OBJ_TYPE_GRAIN_RECEIPTS) {
593 return React__default.createElement(React__default.Fragment, null);
594 }
595 return (React__default.createElement(React__default.Fragment, null,
596 React__default.createElement("span", { className: "f-manager__signs_label" }, "\u0421\u0442\u0430\u0442\u0443\u0441 \u0437\u0435\u0440\u043D\u043E\u0432\u043E\u0439 \u0440\u0430\u0441\u043F\u0438\u0441\u043A\u0438:"),
597 signs.map(function (sign, key) { return (React__default.createElement("div", { className: "f-manager__block_status", key: key },
598 React__default.createElement("img", { src: sign.signed ? img$1 : img$2, alt: "" }),
599 React__default.createElement("span", { className: !sign.signed ? "f-manager__block_status_error" : "" }, sign.label))); })));
600 };
601 return (React__default.createElement("div", { className: "f-manager__signs" },
602 React__default.createElement(FileStatus, null),
603 React__default.createElement(GrainReceiptsStatus, null),
604 React__default.createElement(SignsStatus, null)));
605};
606var Download = function (_a) {
607 var path = _a.path;
608 return (React__default.createElement("span", { className: "f-manager__block_item4" },
609 React__default.createElement("a", { href: path, target: "_blank" }, messages[language$2].download)));
610};
611var Remove = function (_a) {
612 var removeDoc = _a.removeDoc;
613 return (React__default.createElement("span", { className: "f-manager__block_remove", onClick: function (e) { return removeDoc(e); } },
614 React__default.createElement("img", { src: img$3, alt: "" })));
615};
616var Viewer = function (_a) {
617 var _b = _a.enableRemove, enableRemove = _b === void 0 ? false : _b, _c = _a.enableModerate, enableModerate = _c === void 0 ? false : _c, file = _a.file, _d = _a.userId, userId = _d === void 0 ? null : _d, _e = _a.handleRemove, handleRemove = _e === void 0 ? null : _e, _f = _a.handleModerate, handleModerate = _f === void 0 ? null : _f, ExtraContent = _a.ExtraContent, _g = _a.handleSign, handleSign = _g === void 0 ? null : _g, showFilename = _a.showFilename, showFileStatus = _a.showFileStatus;
618 var isLoading = file ? file.loading : false;
619 var needToSign = false; // Нужно ли currentUser-у подписывать документ
620 var signed = false; // Подписал ли currentUser документ
621 /** Если он есть в списке sings то ему нужно подписать дкумент */
622 file.metadata.signs.forEach(function (sign) {
623 if (userId && sign.userId == userId) {
624 needToSign = true;
625 if (sign.signed) {
626 signed = true;
627 }
628 }
629 });
630 var onRemove = function (e, fileId) { return __awaiter(_this$1, void 0, void 0, function () {
631 return __generator(this, function (_a) {
632 e.preventDefault();
633 handleRemove(fileId);
634 return [2 /*return*/];
635 });
636 }); };
637 var onModerate = function (e, fileId, status) { return __awaiter(_this$1, void 0, void 0, function () {
638 return __generator(this, function (_a) {
639 e.preventDefault();
640 handleModerate(fileId, status);
641 return [2 /*return*/];
642 });
643 }); };
644 return (React__default.createElement(React__default.Fragment, null,
645 React__default.createElement("div", { className: "f-manager" },
646 React__default.createElement("div", { className: "f-manager__block" },
647 React__default.createElement("div", { className: "f-manager__block_item1" },
648 React__default.createElement("img", { src: img$5, alt: "" }),
649 React__default.createElement("div", { className: "item1-text" },
650 React__default.createElement("p", { title: showFilename ? file.name : file.metadata.title }, showFilename ? file.name : file.metadata.title))),
651 React__default.createElement("div", { className: "f-manager__block_right" },
652 !isLoading && enableModerate && React__default.createElement(Moderate, { fileId: file._id, handleModerate: onModerate }),
653 !isLoading && React__default.createElement(Download, { path: file.path }),
654 !isLoading && ExtraContent && React__default.createElement(ExtraContent, null),
655 !isLoading && enableRemove && React__default.createElement(Remove, { removeDoc: function (e) { return onRemove(e, file._id); } }),
656 isLoading && React__default.createElement(StdSpinner, null))),
657 !isLoading && React__default.createElement(SignFileStatus, { metadata: file.metadata, showFileStatus: showFileStatus })),
658 needToSign && !signed && React__default.createElement(SignFile, { fileId: file._id, handleSign: handleSign })));
659};
660
661var DragAndDrop = function (props) {
662 var _a = React.useState(false), drag = _a[0], setDrag = _a[1];
663 var dragCounter = 0; //, setDragCounter] = useState(0)
664 var dropRef = React.useRef();
665 // const
666 React.useEffect(function () {
667 var div = dropRef.current;
668 div.addEventListener("dragenter", handleDragIn);
669 div.addEventListener("dragleave", handleDragOut);
670 div.addEventListener("dragover", handleDrag);
671 div.addEventListener("drop", handleDrop);
672 return function () {
673 var div = dropRef.current;
674 div.removeEventListener("dragenter", handleDragIn);
675 div.removeEventListener("dragleave", handleDragOut);
676 div.removeEventListener("dragover", handleDrag);
677 div.removeEventListener("drop", handleDrop);
678 };
679 }, []);
680 var handleDrag = function (e) {
681 e.preventDefault();
682 e.stopPropagation();
683 };
684 var handleDragIn = function (e) {
685 e.preventDefault();
686 e.stopPropagation();
687 dragCounter++;
688 if (e.dataTransfer.items && e.dataTransfer.items.length > 0) {
689 setDrag(true);
690 }
691 };
692 var handleDragOut = function (e) {
693 e.preventDefault();
694 e.stopPropagation();
695 dragCounter--;
696 if (dragCounter - 1 === 0) {
697 setDrag(false);
698 }
699 };
700 var handleDrop = function (e) {
701 e.preventDefault();
702 e.stopPropagation();
703 setDrag(false);
704 if (e.dataTransfer.files && e.dataTransfer.files.length > 0) {
705 props.handleDrop(e);
706 e.dataTransfer.clearData();
707 dragCounter = 0;
708 }
709 };
710 return (React__default.createElement("div", { style: { display: "inline-block", width: "100%", position: "relative" }, ref: dropRef },
711 drag && (React__default.createElement("div", { style: {
712 // border: "dashed grey 4px",
713 backgroundColor: "rgba(255,255,255,.8)",
714 position: "absolute",
715 top: 0,
716 bottom: 0,
717 left: 0,
718 right: 0,
719 zIndex: 9999
720 } },
721 React__default.createElement("div", { style: {
722 display: "flex",
723 alignItems: "center",
724 justifyContent: "center",
725 fontFamily: "dinpro-med",
726 color: "#666666",
727 fontSize: "16px",
728 height: "100%"
729 } },
730 React__default.createElement("div", null, "\u041F\u0435\u0440\u0435\u043C\u0435\u0441\u0442\u0438\u0442\u0435 \u0444\u0430\u0439\u043B \u0441\u044E\u0434\u0430")))),
731 props.children));
732};
733
734var _this$2 = undefined;
735var OBJ_TYPE_GRAIN_RECEIPTS$1 = 101;
736var reducer = function (state, action) {
737 console.log("called twice?", state, action);
738 switch (action.type) {
739 case "loading": {
740 var file = action.file;
741 var fileObj = {
742 _id: action.file._id,
743 loading: true,
744 name: file.name,
745 size: filesize(file.size),
746 metadata: {
747 signs: [],
748 title: file.name
749 }
750 };
751 return { files: state.files.concat([fileObj]) };
752 }
753 case "uploaded": {
754 var newArr_1 = state.files.slice();
755 newArr_1.forEach(function (file, index) {
756 if (file._id == action.fileId) {
757 newArr_1[index] = action.file;
758 }
759 });
760 action.handleFileActions(newArr_1);
761 return { files: newArr_1 };
762 }
763 case "remove": {
764 var newArr = state.files.slice();
765 var filter = newArr.filter(function (file) { return file._id != action.fileId; });
766 action.handleFileActions(filter);
767 return { files: filter };
768 }
769 case "moderate": {
770 var newArr_2 = state.files.slice();
771 newArr_2.forEach(function (file, index) {
772 if (file._id == action.fileId) {
773 newArr_2[index].metadata.status = action.status;
774 }
775 });
776 return { files: newArr_2 };
777 }
778 case "sign": {
779 var newArr_3 = state.files.slice();
780 newArr_3.forEach(function (file, index) {
781 if (file._id == action.file._id) {
782 newArr_3[index] = action.file;
783 }
784 });
785 return { files: newArr_3 };
786 }
787 default:
788 return state;
789 }
790};
791var useUpload = function (_a) {
792 var metadata = _a.metadata, initialFiles = _a.initialFiles, maxFileSize = _a.maxFileSize, enableFakeRemove = _a.enableFakeRemove, extensions = _a.extensions, allowMultiple = _a.allowMultiple, _b = _a.handleFile, handleFile = _b === void 0 ? null : _b, _c = _a.handleFiles, handleFiles = _c === void 0 ? null : _c;
793 var initialState = { files: initialFiles };
794 var _d = React.useReducer(reducer, initialState), state = _d[0], dispatch = _d[1];
795 var _e = React.useContext(UploaderContext), uploadUri = _e.uploadUri, gatewayUri = _e.gatewayUri;
796 var uploadMutation = reactApollo.useMutation(UPLOADFILE_LINK_MUTATION, {
797 client: client(uploadUri),
798 context: {
799 fetchOptions: {
800 useUpload: true,
801 // signal: abortController.signal,
802 onProgress: function (ev) {
803 // console.log("loading...", ev.loaded * 100/ev.total + "%")
804 },
805 onAbortPossible: function (abortHandler) {
806 // abort = abortHandler
807 }
808 }
809 }
810 })[0];
811 var _f = reactApollo.useMutation(READ_GRAIN_RECEIPT_DATA, {
812 client: gatewayClient(gatewayUri)
813 }), readGrainReceiptData = _f[0], _g = _f[1], data = _g.data, loading = _g.loading, error = _g.error;
814 var removeMutation = reactApollo.useMutation(REMOVE_LINK_MUTATION, { client: client(uploadUri) })[0];
815 var moderateMutation = reactApollo.useMutation(MODERATE_LINK_MUTATION, { client: client(uploadUri) })[0];
816 // const [signMutation] = useMutation(SIGN_FILE, { client })
817 var handleFileActions = React.useCallback(function (files) {
818 handleFiles && allowMultiple && handleFiles(files);
819 handleFile && !allowMultiple && handleFile(files[0]);
820 }, []);
821 var upload = function (event) { return __awaiter(_this$2, void 0, void 0, function () {
822 var fileList, fileListWithIds, maxFileSizeList, invalidExtensionsList, i, fileId, file;
823 var _this = this;
824 return __generator(this, function (_a) {
825 fileList = event.dataTransfer ? event.dataTransfer.files : event.target.files;
826 fileListWithIds = [];
827 maxFileSizeList = [];
828 invalidExtensionsList = [];
829 if (!allowMultiple && fileList.length > 1) {
830 notify.notifyServer({
831 Content: function () {
832 return React__default.createElement("span", null, "\u041C\u043E\u0436\u043D\u043E \u0437\u0430\u0433\u0440\u0443\u0437\u0438\u0442\u044C \u0442\u043E\u043B\u044C\u043A\u043E \u043E\u0434\u0438\u043D \u0444\u0430\u0439\u043B!");
833 },
834 autoClose: 5000,
835 type: "error"
836 });
837 return [2 /*return*/];
838 }
839 //dobavlyaem unikalny ID
840 for (i = 0; i < fileList.length; i++) {
841 fileId = Math.random()
842 .toString(36)
843 .substring(2, 15);
844 file = fileList.item(i);
845 if (!accepts(file, extensions)) {
846 invalidExtensionsList.push(file);
847 continue;
848 }
849 if (file.size > maxFileSize) {
850 maxFileSizeList.push(file);
851 continue; //vse, 4to proisxodit dal'we avtomatom skipitsya
852 }
853 file._id = fileId;
854 fileListWithIds.push(file);
855 }
856 (invalidExtensionsList.length || maxFileSizeList.length > 0) &&
857 notify.notifyServer({
858 type: "error",
859 autoClose: 600000,
860 Content: function () {
861 return (React__default.createElement("ul", null,
862 maxFileSizeList.map(function (file, key) { return (React__default.createElement("li", { key: key },
863 "\u0420\u0430\u0437\u043C\u0435\u0440 \u0444\u0430\u0439\u043B\u0430 ",
864 file.name,
865 " \u043F\u0440\u0435\u0432\u044B\u0448\u0430\u0435\u0442\u044C \u0434\u043E\u043F\u0443\u0441\u0442\u0438\u043C\u044B\u0439 \u043B\u0438\u043C\u0438\u0442 ",
866 filesize(maxFileSize))); }),
867 invalidExtensionsList.map(function (file, key) { return (React__default.createElement("li", { key: key },
868 "\u0420\u0430\u0441\u0448\u0438\u0440\u0435\u043D\u0438\u0435 \u0444\u0430\u0439\u043B\u0430 ",
869 file.name,
870 " \u043D\u0435 \u0441\u043E\u043E\u0442\u0432\u0435\u0442\u0441\u0432\u0443\u0435\u0442 \u0442\u0440\u0435\u0431\u043E\u0432\u0430\u043D\u0438\u044F\u043C \u0444\u043E\u0440\u043C\u0430\u0442\u0430 ",
871 extensions)); })));
872 }
873 });
874 //zasovyvaem vse state s pometkoi loading
875 fileListWithIds.forEach(function (file) {
876 dispatch({ type: "loading", file: file });
877 });
878 //zagruzhem fayly na server... menyaem status uje zagruzhennogo fayla (loadin = false)
879 fileListWithIds.forEach(function (file) { return __awaiter(_this, void 0, void 0, function () {
880 var uploadedFile, isRead;
881 return __generator(this, function (_a) {
882 switch (_a.label) {
883 case 0: return [4 /*yield*/, uploadMutation({ variables: { file: file, metadata: metadata } })
884 // esly my rabotaem s zernovoi raspiskoi.. togda nuzhno poluchit' dannie zr
885 ];
886 case 1:
887 uploadedFile = _a.sent();
888 if (!(metadata.objType == OBJ_TYPE_GRAIN_RECEIPTS$1)) return [3 /*break*/, 3];
889 return [4 /*yield*/, readGrainReceiptData({ variables: { fileId: uploadedFile.data.singleUpload._id } })];
890 case 2:
891 isRead = _a.sent();
892 dispatch({
893 type: "uploaded",
894 file: isRead.data.readGrainReceiptData,
895 fileId: file._id,
896 handleFileActions: handleFileActions
897 });
898 return [3 /*break*/, 4];
899 case 3:
900 dispatch({
901 type: "uploaded",
902 file: uploadedFile.data.singleUpload,
903 fileId: file._id,
904 handleFileActions: handleFileActions
905 });
906 _a.label = 4;
907 case 4: return [2 /*return*/];
908 }
909 });
910 }); });
911 return [2 /*return*/];
912 });
913 }); };
914 var remove = function (fileId) { return __awaiter(_this$2, void 0, void 0, function () {
915 var isRemoved;
916 return __generator(this, function (_a) {
917 switch (_a.label) {
918 case 0:
919 if (!!enableFakeRemove) return [3 /*break*/, 2];
920 return [4 /*yield*/, removeMutation({ variables: { fileId: fileId } })];
921 case 1:
922 isRemoved = _a.sent();
923 _a.label = 2;
924 case 2:
925 dispatch({ type: "remove", fileId: fileId, handleFileActions: handleFileActions });
926 return [2 /*return*/];
927 }
928 });
929 }); };
930 var moderate = function (fileId, status) { return __awaiter(_this$2, void 0, void 0, function () {
931 var data;
932 return __generator(this, function (_a) {
933 switch (_a.label) {
934 case 0: return [4 /*yield*/, moderateMutation({ variables: { fileId: fileId, status: status } })];
935 case 1:
936 data = _a.sent();
937 dispatch({ type: "moderate", fileId: fileId, status: status });
938 return [2 /*return*/];
939 }
940 });
941 }); };
942 var sign = function (signedFile) { return __awaiter(_this$2, void 0, void 0, function () {
943 var newArr;
944 return __generator(this, function (_a) {
945 //Сделано по костыльски, тк. передавая и запуская функцию handleFileActions внутри reducer-a приводит
946 //к тому что dispatch срабатывает дважды, следовательно и сама функция что очен критично
947 dispatch({ type: "sign", file: signedFile });
948 newArr = state.files.slice();
949 newArr.forEach(function (file, index) {
950 if (file._id == signedFile._id) {
951 newArr[index] = signedFile;
952 }
953 });
954 handleFileActions(newArr);
955 return [2 /*return*/];
956 });
957 }); };
958 return {
959 acceptedFiles: state.files,
960 uploadFiles: upload,
961 removeFile: remove,
962 moderateFile: moderate,
963 signFile: sign,
964 cancelUpload: null
965 };
966};
967
968var css$2 = ".mad-uploader{display:flex}.mad-uploader-button input[type=file]{display:none}.mad-uploader-select-file{display:flex;flex-direction:column;align-items:flex-start;flex-grow:1;margin-bottom:10px}.mad-uploader-select-file input[type=file]{display:none}.mad-uploader-select-file>p{font-family:dinpro-med;margin-bottom:5px}.mad-uploader-select-file label{width:100%;cursor:pointer;border:2px dashed #b3b3b3;border-radius:5px;padding:9px 30px;margin-bottom:0;display:flex;justify-content:center;align-self:flex-start}.mad-uploader-select-file label img{width:25px;margin-left:4px}.mad-uploader-select-file label span{color:#999;font-size:16px;font-family:dinpro-med;margin-left:10px}.mad-uploader-uploaded{flex-grow:1;box-shadow:0 0 5px rgba(0,0,0,.32);border-radius:5px;padding:10px;margin-bottom:20px}.mad-uploader-uploaded-file{display:flex;flex-direction:row;align-items:center}.mad-uploader-uploaded img{width:25px}.mad-uploader-uploaded span{line-height:1.1;margin-left:10px}.mad-uploader-uploaded span:first-child{font-size:16px;font-family:dinpro-bold}.mad-uploader-uploaded span:nth-child(2){color:#b3b3b3;font-size:13px;font-family:dinpro-bold}.mad-uploader-spinner{align-self:center;margin-left:15px;padding-left:15px;padding-right:15px}.mad-uploader-download{align-self:center;margin-left:15px;padding:0 10px;border-left:1px solid #ccc}.mad-uploader-download a{text-decoration:none}.mad-uploader-remove{align-self:center;cursor:pointer;border-left:1px solid #ccc;padding:0 7px 0 16px}.mad-uploader-remove img{width:15px}.mad-uploader-load{display:flex;flex-direction:row;align-items:center;justify-content:center}.sk-three-bounce{width:3.2em;margin:auto;text-align:center}.sk-three-bounce .sk-child{width:.8em;height:.8em;background-color:#666;border-radius:100%;display:inline-block;animation:sk-three-bounce 1.4s ease-in-out 0s infinite both}.sk-three-bounce .sk-bounce-1{animation-delay:-.32s;margin-left:2px}.sk-three-bounce .sk-bounce-2{animation-delay:-.16s;margin-left:2px}@keyframes sk-three-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.eds-pass{display:flex;justify-content:center}.eds-pass .modal-content{width:440px}.eds-pass .modal-body{margin-top:0}.reg-info{margin-top:18px;padding-left:0;margin-bottom:18px}.reg-info li{margin-bottom:5px;list-style-type:none}.reg-info li .ecp-info{color:#4b4b4d;font-family:dinpro-bold}.reg-info li p{color:#999;font-size:12px;margin-bottom:0}.Toastify__toast-body ul{margin:0;padding:0}.Toastify__toast-body ul li{line-height:1.3;list-style:none;margin-top:15px}.Toastify__toast-body ul li:first-child{margin-top:0}\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbmRleC5zY3NzIiwic3JjL3N0eWxlcy9fZm9udHMuc2NzcyIsInNyYy9zdHlsZXMvX3ZhcmlhYmxlcy5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLGNBQ0UsWUFBYSxDQUVaLHNDQUVHLFlBQWEsQ0FHakIsMEJBQ0UsWUFBYSxDQUNiLHFCQUFzQixDQUN0QixzQkFBdUIsQ0FDdkIsV0FBWSxDQUNaLGtCQUFtQixDQUxwQiwyQ0FPRyxZQUFhLENBUGhCLDRCQVVHLHNCQ3JCZSxDRHNCZixpQkFBa0IsQ0FYckIsZ0NBY0csVUFBVyxDQUNYLGNBQWUsQ0FDZix5QkFBMEIsQ0FDMUIsaUJBQWtCLENBQ2xCLGdCQUFpQixDQUNqQixlQUFnQixDQUNoQixZQUFhLENBQ2Isc0JBQXVCLENBQ3ZCLHFCQUFzQixDQXRCekIsb0NBd0JLLFVBQVcsQ0FDWCxlQUFnQixDQXpCckIscUNBNEJLLFVBQWMsQ0FDZCxjQUFlLENBQ2Ysc0JDekNhLENEMENiLGdCQUFpQixDQUl2Qix1QkFDRSxXQUFZLENBQ1osa0NFNUNpRCxDRjZDakQsaUJBQWtCLENBQ2xCLFlBQWEsQ0FDYixrQkFBbUIsQ0FDbkIsNEJBQ0UsWUFBYSxDQUNiLGtCQUFtQixDQUNuQixrQkFBbUIsQ0FUdEIsMkJBWUcsVUFBVyxDQVpkLDRCQWVHLGVBQWdCLENBQ2hCLGdCQUFpQixDQWhCcEIsd0NBa0JLLGNBQWUsQ0FDZix1QkNoRWUsQ0Q2Q3BCLHlDQXNCSyxhQUFjLENBQ2QsY0FBZSxDQUNmLHVCQ3JFZSxDRHlFckIsc0JBQ0UsaUJBQWtCLENBQ2xCLGdCQUFpQixDQUNqQixpQkFBa0IsQ0FDbEIsa0JBQW1CLENBRXJCLHVCQUNFLGlCQUFrQixDQUNsQixnQkFBaUIsQ0FDakIsY0FBZSxDQUNmLDBCQUE4QixDQUovQix5QkFNRyxvQkFBcUIsQ0FHekIscUJBQ0UsaUJBQWtCLENBQ2xCLGNBQWUsQ0FDZiwwQkFBOEIsQ0FDOUIsb0JBQXFCLENBSnRCLHlCQU1HLFVBQVcsQ0FHZixtQkFDRSxZQUFhLENBQ2Isa0JBQW1CLENBQ25CLGtCQUFtQixDQUNuQixzQkFBdUIsQ0FPM0IsaUJBR0UsV0FBMEIsQ0FDMUIsV0FBWSxDQUNaLGlCQUFrQixDQUxwQiwyQkFRSSxVQUEwQixDQUMxQixXQUEyQixDQUMzQixxQkFYMkIsQ0FhM0Isa0JBQW1CLENBQ25CLG9CQUFxQixDQUNyQiwyREFBMEUsQ0FkOUUsOEJBa0JJLHFCQWhCZ0IsQ0FpQmhCLGVBQWdCLENBbkJwQiw4QkFzQkkscUJBQW1DLENBQ25DLGVBQWdCLENBSXBCLDJCQUNFLFVBQ0Usa0JBQW1CLENBRXJCLElBQ0Usa0JBQXFCLENBQUEsQ0FHekIsVUFDRSxZQUFhLENBQ2Isc0JBQXVCLENBRnpCLHlCQUlJLFdBQVksQ0FKaEIsc0JBT0ksWUFDRixDQUVGLFVBQ0UsZUFBZ0IsQ0FDaEIsY0FBZSxDQUNmLGtCQUFtQixDQUhyQixhQU1JLGlCQUFrQixDQUNsQixvQkFBcUIsQ0FQekIsdUJBU00sYUFBYyxDQUNkLHVCQ25LaUIsQ0R5SnZCLGVBYU0sVUFBYyxDQUNkLGNBQWUsQ0FDZixlQUFnQixDQUl0Qix5QkFFSSxRQUFTLENBQ1QsU0FBVSxDQUhkLDRCQUtNLGVBQWdCLENBQ2hCLGVBQWdCLENBQ2hCLGVBQWdCLENBUHRCLHdDQVVRLFlBQ0YiLCJmaWxlIjoiaW5kZXguc2NzcyJ9 */";
969styleInject(css$2);
970
971/**
972 * Улучшенная версия загрузчика файлов.
973 * @param props
974 */
975var FileManager = function (props) {
976 var _a = props.allowMultiple, allowMultiple = _a === void 0 ? false : _a, files = props.files, file = props.file, _b = props.handleFile, handleFile = _b === void 0 ? null : _b, _c = props.handleFiles, handleFiles = _c === void 0 ? null : _c, _d = props.ExtraContent, ExtraContent = _d === void 0 ? function () { return React__default.createElement(React__default.Fragment, null); } : _d, _e = props.ExtraContents, ExtraContents = _e === void 0 ? [] : _e, _f = props.theme, theme = _f === void 0 ? "default" : _f, _g = props.userId, userId = _g === void 0 ? null : _g, _h = props.uploadText, uploadText = _h === void 0 ? "Загрузка файлов" : _h, _j = props.extensions, extensions = _j === void 0 ? "" : _j, _k = props.objId, objId = _k === void 0 ? "" : _k, _l = props.objType, objType = _l === void 0 ? 999 : _l, _m = props.objCode, objCode = _m === void 0 ? "" : _m, _o = props.maxFileSize, maxFileSize = _o === void 0 ? 1024 * 1024 * 5 : _o, //5MB
977 _p = props.needToSign, //5MB
978 needToSign = _p === void 0 ? false : _p, _q = props.enableRemove, enableRemove = _q === void 0 ? false : _q, _r = props.enableModerate, enableModerate = _r === void 0 ? false : _r, _s = props.enableFakeRemove, enableFakeRemove = _s === void 0 ? false : _s, _t = props.showFilename, showFilename = _t === void 0 ? false : _t, _u = props.showFileStatus, showFileStatus = _u === void 0 ? false : _u;
979 var metadata = { objType: objType, objId: objId, objCode: objCode, needToSign: needToSign };
980 var _v = useUpload({
981 allowMultiple: allowMultiple,
982 metadata: metadata,
983 initialFiles: allowMultiple ? files : file ? [file] : [],
984 maxFileSize: maxFileSize,
985 enableFakeRemove: enableFakeRemove,
986 extensions: extensions,
987 handleFile: handleFile,
988 handleFiles: handleFiles
989 }), acceptedFiles = _v.acceptedFiles, uploadFiles = _v.uploadFiles, removeFile = _v.removeFile, moderateFile = _v.moderateFile, signFile = _v.signFile;
990 //Передаем файлы родителю при каждом изменении
991 // @deprecated - пришлось эту логику отправлять в useUpload, тк handleFile должен срабатывать только тогда когда
992 // реально происходит зарузка-удаление-подписание. А по ЭТОЙ логике handleFiles будет вызываться как мин когда компонент
993 // замаунтиться
994 // useEffect(() => {
995 // handleFiles && allowMultiple && handleFiles(acceptedFiles)
996 // handleFile && !allowMultiple && handleFile(acceptedFiles[0])
997 // }, [acceptedFiles])
998 /**
999 * Загрузчик файлов
1000 * Если allowMultiple = true - то отображаем ее всегда независимо от количества загруженных файлов
1001 * Если allowMultiple = false files.lengh == 1 - тогда скрыть ее, показать только когда files.lengh == 0 т.е не загружен
1002 */
1003 var Uploader = function () {
1004 if (allowMultiple == false && acceptedFiles.length > 0) {
1005 return React__default.createElement(React__default.Fragment, null);
1006 }
1007 var randId = Math.floor(Math.random() * (10000 - 1)) + 1;
1008 var Default = function () {
1009 return (React__default.createElement(React__default.Fragment, null,
1010 React__default.createElement("div", { className: "mad-uploader-select-file" },
1011 uploadText && React__default.createElement("p", null, uploadText),
1012 React__default.createElement(DragAndDrop, { handleDrop: uploadFiles },
1013 React__default.createElement("label", { htmlFor: "file-manager-" + randId },
1014 React__default.createElement("div", { className: "mad-uploader-load" },
1015 React__default.createElement("img", { src: img, alt: "" }),
1016 React__default.createElement("span", null, "\u0412\u044B\u0431\u0435\u0440\u0438\u0442\u0435 \u0444\u0430\u0439\u043B"),
1017 extensions != "*" && (React__default.createElement("span", { style: { color: "#B3B3B3", marginLeft: "5px" } },
1018 "(",
1019 extensions,
1020 ", ",
1021 filesize(maxFileSize),
1022 ")"))))))));
1023 };
1024 var Button = function () {
1025 return (React__default.createElement("label", { htmlFor: "file-manager-" + randId, className: "jbtn jbtn-green mad-uploader-button" },
1026 uploadText,
1027 extensions != "*" && (React__default.createElement("span", { style: { fontFamily: "dinpro-med" } },
1028 "(",
1029 extensions,
1030 ", ",
1031 filesize(maxFileSize),
1032 ")"))));
1033 };
1034 return (React__default.createElement(React__default.Fragment, null,
1035 React__default.createElement("input", { type: "file", name: "mad-file", id: "file-manager-" + randId, accept: extensions, style: { display: "none" }, key: randId, multiple: allowMultiple, required: true, onChange: uploadFiles }),
1036 theme == "default" && React__default.createElement(Default, null),
1037 theme == "button" && React__default.createElement(Button, null)));
1038 };
1039 return (React__default.createElement("div", { style: { display: "flex", flexDirection: "column", width: "inherit" } },
1040 React__default.createElement(Uploader, null),
1041 React__default.createElement("div", null, acceptedFiles
1042 .map(function (file, key) {
1043 return (React__default.createElement(Viewer, { file: file, key: key, userId: userId, handleRemove: removeFile, handleModerate: moderateFile, enableRemove: enableRemove, enableModerate: enableModerate, handleSign: signFile, ExtraContent: allowMultiple ? (ExtraContents.length > 0 ? ExtraContents[key] : ExtraContent) : ExtraContent, showFilename: showFilename, showFileStatus: showFileStatus }));
1044 })
1045 .reverse())));
1046};
1047
1048exports.FileManager = FileManager;