| 1 | <?php |
|---|
| 2 | require_once(MOD_PATH.'Dictionaries/Projects/services/ProjectsImportService.inc'); |
|---|
| 3 | |
|---|
| 4 | /** |
|---|
| 5 | * ProjectsImportDialog |
|---|
| 6 | * |
|---|
| 7 | * @author Tomasz Świenty |
|---|
| 8 | * @version 2.0 |
|---|
| 9 | * @copyright Copyright (c) eDokumenty |
|---|
| 10 | */ |
|---|
| 11 | class ProjectsImportDialog extends DialogForm { |
|---|
| 12 | |
|---|
| 13 | |
|---|
| 14 | /** |
|---|
| 15 | * @var string[] |
|---|
| 16 | */ |
|---|
| 17 | protected static $cMethods = array( |
|---|
| 18 | 'import', |
|---|
| 19 | ); |
|---|
| 20 | |
|---|
| 21 | |
|---|
| 22 | /** |
|---|
| 23 | * @var SimpleUploader |
|---|
| 24 | */ |
|---|
| 25 | private $importFile; |
|---|
| 26 | |
|---|
| 27 | |
|---|
| 28 | /** |
|---|
| 29 | * @var int|string |
|---|
| 30 | */ |
|---|
| 31 | private $HWND; |
|---|
| 32 | |
|---|
| 33 | |
|---|
| 34 | /** |
|---|
| 35 | * ProjectsImportDialog constructor. |
|---|
| 36 | * @param $name |
|---|
| 37 | * @param null $caption |
|---|
| 38 | * @param int $dstyle |
|---|
| 39 | */ |
|---|
| 40 | public function __construct($name, $caption = NULL, $dstyle = BS_DIALOG) { |
|---|
| 41 | |
|---|
| 42 | parent::__construct($name, Translator::translate('Import projektów z szablonu'), DS_POPUP); |
|---|
| 43 | |
|---|
| 44 | $this->path = Application::makeRelativePath(__FILE__); |
|---|
| 45 | $this->HWND = $this->createHWND(); |
|---|
| 46 | |
|---|
| 47 | $this->width = '470px'; |
|---|
| 48 | $this->height = '210px'; |
|---|
| 49 | |
|---|
| 50 | if ($this->isOpened() AND !$this->noNeedForCreate() AND !Request::hasMethodCall($this->HWND, array_keys(self::$cMethods))) { |
|---|
| 51 | $this->create(); |
|---|
| 52 | } |
|---|
| 53 | |
|---|
| 54 | } |
|---|
| 55 | |
|---|
| 56 | |
|---|
| 57 | /** |
|---|
| 58 | * @return string[] |
|---|
| 59 | */ |
|---|
| 60 | public function getCallableMethods(): array { |
|---|
| 61 | |
|---|
| 62 | return self::$cMethods; |
|---|
| 63 | |
|---|
| 64 | } |
|---|
| 65 | |
|---|
| 66 | |
|---|
| 67 | /** |
|---|
| 68 | * @return bool |
|---|
| 69 | */ |
|---|
| 70 | public function import(): bool { |
|---|
| 71 | |
|---|
| 72 | $sData = $this->getSData(); |
|---|
| 73 | |
|---|
| 74 | $importFileData = $sData['importFile'] ?? NULL; |
|---|
| 75 | |
|---|
| 76 | $options = [ |
|---|
| 77 | 'ifFound' => ($sData['ifFound'] ?? NULL), |
|---|
| 78 | 'ifFoundAndDeleted' => ($sData['ifFoundAndDeleted'] ?? NULL) |
|---|
| 79 | ]; |
|---|
| 80 | |
|---|
| 81 | $progressBar = new ProgressBar($this->name.'PB'); |
|---|
| 82 | $progressBar->init(); |
|---|
| 83 | $progressBar->updateEvery(1000); |
|---|
| 84 | |
|---|
| 85 | $db = PgManager::getInstance(); |
|---|
| 86 | $counter = 0; |
|---|
| 87 | |
|---|
| 88 | ErrorHandler::tryBegin(); |
|---|
| 89 | try { |
|---|
| 90 | ProjectsImportService::checkFileExtension($importFileData[1]); |
|---|
| 91 | $counter = ProjectsImportService::importFromFile($sData['file'], $options, $progressBar); |
|---|
| 92 | } catch (Exception $exception) { |
|---|
| 93 | $db->rollback(); |
|---|
| 94 | |
|---|
| 95 | (new WidgetException($this->name.'file', $exception->getMessage()))->show(); |
|---|
| 96 | } |
|---|
| 97 | ErrorHandler::tryEnd(); |
|---|
| 98 | |
|---|
| 99 | $progressBar->close(); |
|---|
| 100 | |
|---|
| 101 | if (!isset($exception)) { |
|---|
| 102 | if ($counter) { |
|---|
| 103 | JScript::sweetAlert(sprintf(Translator::translate('Zaimportowano projektów: %d'), $counter), ['type' => 'success']); |
|---|
| 104 | } |
|---|
| 105 | |
|---|
| 106 | $this->jsClose(TRUE, FALSE); |
|---|
| 107 | } |
|---|
| 108 | |
|---|
| 109 | return TRUE; |
|---|
| 110 | |
|---|
| 111 | } |
|---|
| 112 | |
|---|
| 113 | |
|---|
| 114 | /** |
|---|
| 115 | * @param array $params |
|---|
| 116 | * @param array $data |
|---|
| 117 | * @return bool|void |
|---|
| 118 | * @throws UserRightsException |
|---|
| 119 | */ |
|---|
| 120 | public function open($params = [], &$data = []) { |
|---|
| 121 | |
|---|
| 122 | require_once('./classes/FieldTools/RightCheckers/ControlPanelRightsChecker.inc'); |
|---|
| 123 | $rightsChecker = new ControlPanelRightsChecker(); |
|---|
| 124 | if (!UserRights::checkSysAcc('bswfms.settings.level2') AND !$rightsChecker->isPermitted('PROJECTS', FieldsAccessLevel::READ, TRUE)) { |
|---|
| 125 | throw new UserRightsException(NULL, 'bswfms.settings.level2'); |
|---|
| 126 | } |
|---|
| 127 | |
|---|
| 128 | require_once('./classes/Calendars/services/CalendarsDefService.inc'); |
|---|
| 129 | $calendar = (new CalendarsDefService)->getDefaultCalendar(); |
|---|
| 130 | if (!$calendar) { |
|---|
| 131 | if (!UserRights::checkSysAcc('bswfms.settings.level2')) { |
|---|
| 132 | throw new UserRightsException(NULL, 'bswfms.settings.level2'); |
|---|
| 133 | } |
|---|
| 134 | |
|---|
| 135 | JScript::registerOnLoad('App.openDialogEx(\''.App::registerDialog(App::getShortName('Calendars'), 'Calendars', './classes/Calendars/forms/Calendars.inc').'\', null, null);'); |
|---|
| 136 | JScript::info(Translator::translate('Brak domyślnego kalendarza')); |
|---|
| 137 | |
|---|
| 138 | return FALSE; |
|---|
| 139 | } |
|---|
| 140 | |
|---|
| 141 | parent::open($params, $data); |
|---|
| 142 | $this->setData($data); |
|---|
| 143 | $this->create(); |
|---|
| 144 | |
|---|
| 145 | } |
|---|
| 146 | |
|---|
| 147 | |
|---|
| 148 | /** |
|---|
| 149 | * @return bool |
|---|
| 150 | * @throws WidgetException |
|---|
| 151 | */ |
|---|
| 152 | public function save(): bool { |
|---|
| 153 | |
|---|
| 154 | if (!$this->isOpened()) { |
|---|
| 155 | return FALSE; |
|---|
| 156 | } |
|---|
| 157 | |
|---|
| 158 | $wData = $this->getWData(); |
|---|
| 159 | $importFileData = $this->importFile->getUploadedFile(); |
|---|
| 160 | |
|---|
| 161 | if (!is_array($importFileData) OR !$importFileData OR !array_key_exists('file', $wData) OR bs_empty_str($wData['file'])) { |
|---|
| 162 | throw new WidgetException($this->name.'file_l', Translator::translate('Wskaż plik do importu'), 'NOTICE', ['highlightFieldsWithLabel' => [$this->name.'file'], 'highlightDelay' => 5000]); |
|---|
| 163 | } |
|---|
| 164 | |
|---|
| 165 | $this->setSData(array_merge(['importFile' => $importFileData], $wData)); |
|---|
| 166 | |
|---|
| 167 | $progressBar = new ProgressBar($this->name.'PB'); |
|---|
| 168 | |
|---|
| 169 | JScript::add(' |
|---|
| 170 | App.'.$progressBar->getName().'showProgressBar = function() { |
|---|
| 171 | var box = $(\''.$this->name.'progHandlerBox\'); |
|---|
| 172 | box.style.left = \'0px\'; |
|---|
| 173 | |
|---|
| 174 | Tooltip.hide(); |
|---|
| 175 | BalloonHint.hide(); |
|---|
| 176 | ProgressBar.show(\''.$progressBar->getName().'\', unescape(\''.Translator::translate('Import projektów').'\'), 100, function(text){return App.'.$progressBar->getName().'handle(text);}, false, {interval:1200, retries:30, width:'.((int)$this->width + 6).', height:96, inline:box}); |
|---|
| 177 | } |
|---|
| 178 | |
|---|
| 179 | App.'.$progressBar->getName().'handle = function(text) { |
|---|
| 180 | if (text == \'\') { |
|---|
| 181 | return false; |
|---|
| 182 | } |
|---|
| 183 | |
|---|
| 184 | var ss = text.split(\':\'); |
|---|
| 185 | $(\''.$progressBar->getName().'_dlg\').lastChild.firstChild.innerHTML = \''.Translator::translate('Import projektów').'<br><br>\'; |
|---|
| 186 | $(\''.$progressBar->getName().'_txt\').innerHTML = ss[1]+\' / \'+ss[0] + \' %\'; |
|---|
| 187 | return ss.join(\':\'); |
|---|
| 188 | } |
|---|
| 189 | '); |
|---|
| 190 | |
|---|
| 191 | JScript::addAfter(' |
|---|
| 192 | Dialog.disable(\''.$this->name.'\'); |
|---|
| 193 | |
|---|
| 194 | App.'.$progressBar->getName().'showProgressBar(); |
|---|
| 195 | $A1(\''.$this->HWND.'\', \''.$this->name.'\', '.(int)array_search('import', self::$cMethods).', null, \'$(\\\''.$this->name.'progHandlerBox\\\').style.left = \\\'-100%\\\'; Dialog.enable(\\\''.$this->name.'\\\');\', 0, false); |
|---|
| 196 | '); |
|---|
| 197 | |
|---|
| 198 | return TRUE; |
|---|
| 199 | |
|---|
| 200 | } |
|---|
| 201 | |
|---|
| 202 | |
|---|
| 203 | /** |
|---|
| 204 | * @return bool |
|---|
| 205 | */ |
|---|
| 206 | protected function create(): bool { |
|---|
| 207 | |
|---|
| 208 | if (!$this->isOpened()) { |
|---|
| 209 | return FALSE; |
|---|
| 210 | } |
|---|
| 211 | |
|---|
| 212 | $composer = new DialogComposer($this); |
|---|
| 213 | $composer->addModernHeader(Translator::translate('Wybierz plik, który zawiera listę projektów.')); |
|---|
| 214 | |
|---|
| 215 | $this->importFile = new SimpleUploader($this->name.'file'); |
|---|
| 216 | $this->importFile->bindDropZoneTo = $this->name.'rightPanelInner'; |
|---|
| 217 | $this->importFile->dropZoneStyle = 'background-color: white;'; |
|---|
| 218 | $this->importFile->position = 'absolute'; |
|---|
| 219 | $this->importFile->width = ''; |
|---|
| 220 | |
|---|
| 221 | $label = $this->importFile->setLabel(Translator::translate('Wybierz plik do importu')); |
|---|
| 222 | $label->setRequired(TRUE); |
|---|
| 223 | |
|---|
| 224 | $templateDownloadJS = ''; |
|---|
| 225 | FileManager::getJSForFileDownloadByURI('./share/import/templates/projects.xlsx', $templateDownloadJS, 'projects.xlsx'); |
|---|
| 226 | |
|---|
| 227 | $optionsPanel = new FieldsSet($this->name.'optionsPanel', FieldsSet::STYLE4); |
|---|
| 228 | $optionsPanel->clearPositionString(TRUE); |
|---|
| 229 | $optionsPanel->setLabelText(Translator::translate('Opcje importu')); |
|---|
| 230 | $optionsPanel->class = 'b-s-b'; |
|---|
| 231 | $optionsPanel->height = 'auto'; |
|---|
| 232 | $optionsPanel->top = '80px'; |
|---|
| 233 | $optionsPanel->width = 'calc(100% - '.(Dialog::SPACE_LEFT + Dialog::SPACE_RIGHT).'px)'; |
|---|
| 234 | |
|---|
| 235 | $labelIfFound = new Label($this->name.'labelIfFound'); |
|---|
| 236 | $labelIfFound->top = (Dialog::SPACE_TOP + Dialog::SPACE1).'px'; |
|---|
| 237 | $labelIfFound->text = Translator::translate('Jeśli projekt zostanie znaleziony:'); |
|---|
| 238 | $labelIfFound->helpText = Translator::translate('Wykrywanie czy projekt istnieje w systemie następuje poprzez porównanie nazwy projektu oraz numeru (wystarczy, że wartość jednego z tych atrybutów zostanie znaleziona w bazie).'); |
|---|
| 239 | $labelIfFound->width = 'calc(100% - 140px - '.(Dialog::SPACE_LEFT + Dialog::SPACE_RIGHT).'px)'; |
|---|
| 240 | |
|---|
| 241 | $optionsIfFound = new ExtSelect($this->name.'optionsIfFound'); |
|---|
| 242 | $optionsIfFound->width = '170px'; |
|---|
| 243 | $optionsIfFound->addItem(ProjectsImportService::IF_FOUND_OPTION_BREAK, Translator::translate('Przerwij cały import')); |
|---|
| 244 | $optionsIfFound->addItem(ProjectsImportService::IF_FOUND_OPTION_SKIP, Translator::translate('Pomiń projekt i kontynuuj import')); |
|---|
| 245 | $optionsIfFound->addItem(ProjectsImportService::IF_FOUND_OPTION_UPDATE, Translator::translate('Aktualizuj projekt')); |
|---|
| 246 | $optionsIfFound->onChange = 'if (this.value == \'update\') {$(\''.$this->name.'\').style.height = \'468px\';} else {$(\''.$this->name.'\').style.height = \'414px\';}'; |
|---|
| 247 | |
|---|
| 248 | $ifFoundAndDeletedPanel = new Panel($this->name.'ifFoundAndDeletedPanel'); |
|---|
| 249 | $ifFoundAndDeletedPanel->height = '50px'; |
|---|
| 250 | $ifFoundAndDeletedPanel->width = '100%'; |
|---|
| 251 | |
|---|
| 252 | $labelIfFoundAndDeleted = new Label($this->name.'labelIfFoundAndDeleted'); |
|---|
| 253 | $labelIfFoundAndDeleted->text = Translator::translate('Jeśli znaleziony projekt jest usunięty:'); |
|---|
| 254 | $labelIfFoundAndDeleted->width = 'calc(100% - 140px - '.(Dialog::SPACE_LEFT + Dialog::SPACE_RIGHT).'px)'; |
|---|
| 255 | |
|---|
| 256 | $optionsIfFoundAndDeleted = new ExtSelect($this->name.'optionsIfFoundAndDeleted'); |
|---|
| 257 | $optionsIfFoundAndDeleted->width = '170px'; |
|---|
| 258 | $optionsIfFoundAndDeleted->addItem(ProjectsImportService::IF_FOUND_AND_DELETED_OPTION_BREAK, Translator::translate('Przerwij cały import')); |
|---|
| 259 | $optionsIfFoundAndDeleted->addItem(ProjectsImportService::IF_FOUND_AND_DELETED_OPTION_SKIP, Translator::translate('Pomiń projekt i kontynuuj import')); |
|---|
| 260 | $optionsIfFoundAndDeleted->addItem(ProjectsImportService::IF_FOUND_AND_DELETED_OPTION_RESTORE, Translator::translate('Przywróć projekt i zaktualizuj')); |
|---|
| 261 | |
|---|
| 262 | $ifFoundAndDeletedPanel->addNext($labelIfFoundAndDeleted, NULL, Widget::P_TO_LEFT_L); |
|---|
| 263 | $ifFoundAndDeletedPanel->addNext($optionsIfFoundAndDeleted, 'ifFoundAndDeleted', Widget::P_TO_RIGHT_R); |
|---|
| 264 | |
|---|
| 265 | $optionsPanel->addNext($labelIfFound, NULL, Widget::P_TO_LEFT_L); |
|---|
| 266 | $optionsPanel->addNext($optionsIfFound, 'ifFound', Widget::P_TO_RIGHT_R); |
|---|
| 267 | $optionsPanel->addNext($ifFoundAndDeletedPanel, NULL, Widget::P_TO_LEFT_L); |
|---|
| 268 | |
|---|
| 269 | $infoPanel = new Panel($this->name.'infoPanel'); |
|---|
| 270 | $infoPanel->class = 'b-s-b'; |
|---|
| 271 | $infoPanel->height = '140px'; |
|---|
| 272 | $infoPanel->left = '0px'; |
|---|
| 273 | $infoPanel->width = '100%'; |
|---|
| 274 | $infoPanel->display = 'flex'; |
|---|
| 275 | $infoPanel->top = 'auto'; |
|---|
| 276 | $infoPanel->bottom = '0px'; |
|---|
| 277 | $infoPanel->style = 'border: 1px solid rgba(0,0,0,.04); border-width: 1px 0 0 0; background-color: #f1f1f1; display: flex; flex-direction: row; align-items: center;'; |
|---|
| 278 | $infoPanel->addHtml(' |
|---|
| 279 | <div style="flex-shrink: 0; align-self: center; height: 100%; display: flex; width: 80px; align-items: center; justify-content: center;"> |
|---|
| 280 | <i class="eic eic-microsoft-excel-filled eic-ef-xls" style="font-size: 48px; align-items: baseline; position: relative;"></i> |
|---|
| 281 | </div> |
|---|
| 282 | <div style="padding: 0 10px; color: #002627 !important;"> |
|---|
| 283 | <div class="rbos-font-block-header" style="line-height: 22px; margin-bottom: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;">Szablon importu</div> |
|---|
| 284 | <div class="rbos-font-list-header" style="line-height: 16px;"> |
|---|
| 285 | <div style="font-weight: normal !important; padding-left: 24px; position: relative;"><div style="width: 16px; height: 16px; display: inline-block; color: white; background-color: #2980b9; text-align: center; line-height: 16px; position: absolute; left: 0;">1</div>Pobierz szablon importu'.($templateDownloadJS ? '<span class="ActionLink" style="line-height: 16px; font-weight: normal !important; margin-left: 10px;" onclick="'.$templateDownloadJS.'">Pobierz</span>' : '').'</div> |
|---|
| 286 | <div style="margin-top: 8px; font-weight: normal !important; padding-left: 24px; position: relative;"><div style="width: 16px; height: 16px; display: inline-block; color: white; background-color: #2980b9; text-align: center; line-height: 16px; position: absolute; left: 0;">2</div>Przygotuj Twój plik zgodnie z pobranym szablonem</div> |
|---|
| 287 | <div style="margin-top: 8px; font-weight: normal !important; padding-left: 24px; position: relative;"><div style="width: 16px; height: 16px; display: inline-block; color: white; background-color: #2980b9; text-align: center; line-height: 16px; position: absolute; left: 0;">3</div>Wybierz przygotowany plik do importu i kliknij przycisk Importuj</div> |
|---|
| 288 | </div> |
|---|
| 289 | </div> |
|---|
| 290 | '); |
|---|
| 291 | |
|---|
| 292 | $progHandlerBox = new Panel($this->name.'progHandlerBox'); |
|---|
| 293 | $progHandlerBox->position = 'absolute'; |
|---|
| 294 | $progHandlerBox->bottom = '51px'; |
|---|
| 295 | $progHandlerBox->height = '139px'; |
|---|
| 296 | $progHandlerBox->left = '-100%'; |
|---|
| 297 | $progHandlerBox->class = 'b-s-b'; |
|---|
| 298 | $progHandlerBox->width = '100%'; |
|---|
| 299 | $progHandlerBox->style = 'transition: all 200ms; flex-direction: row; align-items: center; background-color: #f1f1f1;'; |
|---|
| 300 | $progHandlerBox->display = 'flex'; |
|---|
| 301 | |
|---|
| 302 | $composer->addNext($this->importFile, 'file'); |
|---|
| 303 | $composer->addNext($optionsPanel); |
|---|
| 304 | $composer->addNext($infoPanel); |
|---|
| 305 | |
|---|
| 306 | $composer->addModernButtonsPanel(array('bSave', 'bCancel')); |
|---|
| 307 | |
|---|
| 308 | $this->height = '460px'; |
|---|
| 309 | |
|---|
| 310 | $this->bSave->caption = Translator::translate('Importuj'); |
|---|
| 311 | $this->bSave->title = Translator::translate('Importuj z pliku do systemu'); |
|---|
| 312 | $this->onbSaveClick = 'if (!ROS.RG.canInvoke(this)) {return false;} asyncLibrary.doAsyncWait = false; ROS.RG.Request = '; |
|---|
| 313 | |
|---|
| 314 | $this->add($composer); |
|---|
| 315 | $this->add($progHandlerBox); |
|---|
| 316 | |
|---|
| 317 | return TRUE; |
|---|
| 318 | |
|---|
| 319 | } |
|---|
| 320 | |
|---|
| 321 | } |
|---|