не помню что там да и похуй абсолютно
This commit is contained in:
		
							
								
								
									
										0
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								composer.json
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								composer.json
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								composer.lock
									
									
									
										generated
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								composer.lock
									
									
									
										generated
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/public/markets.php
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/public/markets.php
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										2
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/public/workers.php
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										2
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/public/workers.php
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -79,7 +79,7 @@ function convertNumber(string $number): string | |||||||
| { | { | ||||||
|  |  | ||||||
| 	// Очистка всего кроме цифр, а потом поиск 10 первых чисел (без восьмёрки) | 	// Очистка всего кроме цифр, а потом поиск 10 первых чисел (без восьмёрки) | ||||||
| 	preg_match('/^8(\d{10})/', preg_replace("/[^\d]/", "", $number), $matches); | 	preg_match('/\d?(\d{10})/', preg_replace("/[^\d]/", "", $number), $matches); | ||||||
|  |  | ||||||
| 	// Инициализация номера | 	// Инициализация номера | ||||||
| 	$number = isset($matches[1]) ? 7 . $matches[1] : $number; | 	$number = isset($matches[1]) ? 7 . $matches[1] : $number; | ||||||
|   | |||||||
							
								
								
									
										189
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/public/works.php
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										189
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/public/works.php
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -32,29 +32,22 @@ $arangodb = new connection(require __DIR__ . '/../settings/arangodb.php'); | |||||||
| function generateLabel(string $name): string | function generateLabel(string $name): string | ||||||
| { | { | ||||||
| 	return match ($name) { | 	return match ($name) { | ||||||
| 		'imported_created_in_sheets', 'Отметка времени' => 'imported_created_in_sheets', | 		'created_in_sheets', 'Отметка времени' => 'created_in_sheets', | ||||||
| 		'imported_date', 'Дата заявки' => 'imported_date', | 		'updated_in_sheets', 'время последнего изменения' => 'updated_in_sheets', | ||||||
| 		'imported_market', 'Ваш магазин' => 'imported_market', | 		'date', 'дата заявки' => 'date', | ||||||
| 		'imported_worker', 'Требуемый сотрудник' => 'imported_worker', | 		'market', '№ магазина' => 'market', | ||||||
| 		'imported_work', 'Вид работы' => 'imported_work', | 		'type', 'формат' => 'type', | ||||||
| 		'imported_start', 'Начало работы' => 'imported_start', | 		'address', 'адрес' => 'address', | ||||||
| 		'imported_end', 'Конец работы' => 'imported_end', | 		'worker', 'Код сотрудника (000000)' => 'worker', | ||||||
| 		'imported_hours', 'Часы работы' => 'imported_hours', |  | ||||||
| 		'created_in_sheets', 'Создано' => 'created_in_sheets', |  | ||||||
| 		'date', 'Дата' => 'date', |  | ||||||
| 		'market', 'Магазин' => 'market', |  | ||||||
| 		'type', 'Тип' => 'type', |  | ||||||
| 		'address', 'Адрес' => 'address', |  | ||||||
| 		'worker', 'Сотрудник' => 'worker', |  | ||||||
| 		'name', 'ФИО' => 'name', | 		'name', 'ФИО' => 'name', | ||||||
| 		'work', 'Работа' => 'work', | 		'work', 'Вид работ' => 'work', | ||||||
| 		'start', 'Начало' => 'start', | 		'start', 'Время начала заявки' => 'start', | ||||||
| 		'end', 'Конец' => 'end', | 		'end', 'Время окончания заявки' => 'end', | ||||||
| 		'hours', 'Часы' => 'hours', | 		'hours', 'Количество часов по заявке' => 'hours', | ||||||
| 		'tax', 'ИНН' => 'tax', | 		'tax', 'ИНН' => 'tax', | ||||||
| 		'confirmed', 'Подтверждено' => 'confirmed', | 		'confirmed', 'подтверждение' => 'confirmed', | ||||||
| 		'commentary', 'Комментарий' => 'commentary', | 		'commentary', 'примечание от ТТ' => 'commentary', | ||||||
| 		'response', 'Ответ' => 'response', | 		'response', 'ответ от контрагента' => 'response', | ||||||
| 		'_id', 'ID'  => '_id', | 		'_id', 'ID'  => '_id', | ||||||
| 		default => $name | 		default => $name | ||||||
| 	}; | 	}; | ||||||
| @@ -63,29 +56,22 @@ function generateLabel(string $name): string | |||||||
| function degenerateLabel(string $name): string | function degenerateLabel(string $name): string | ||||||
| { | { | ||||||
| 	return match ($name) { | 	return match ($name) { | ||||||
| 		'Отметка времени', 'imported_created_in_sheets' => 'Отметка времени', | 		'Отметка времени', 'created_in_sheets' => 'Отметка времени', | ||||||
| 		'Дата заявки', 'imported_date' => 'Дата заявки', | 		'время последнего изменения', 'updated_in_sheets' => 'время последнего изменения', | ||||||
| 		'Ваш магазин', 'imported_market' => 'Ваш магазин', | 		'дата заявки', 'date' => 'дата заявки', | ||||||
| 		'Требуемый сотрудник', 'imported_worker' => 'Требуемый сотрудник', | 		'№ магазина', 'market' => '№ магазина', | ||||||
| 		'Вид работы', 'imported_work' => 'Вид работы', | 		'формат', 'type' => 'формат', | ||||||
| 		'Начало работы', 'imported_start' => 'Начало работы', | 		'адрес', 'address' => 'адрес', | ||||||
| 		'Конец работы', 'imported_end' => 'Конец работы', | 		'Код сотрудника (000000)', 'worker' => 'Код сотрудника (000000)', | ||||||
| 		'Часы работы', 'imported_hours' => 'Часы работы', |  | ||||||
| 		'Создано', 'created_in_sheets' => 'Создано', |  | ||||||
| 		'Дата', 'date' => 'Дата', |  | ||||||
| 		'Магазин', 'market' => 'Магазин', |  | ||||||
| 		'Тип', 'type' => 'Тип', |  | ||||||
| 		'Адрес', 'address' => 'Адрес', |  | ||||||
| 		'Сотрудник', 'worker' => 'Сотрудник', |  | ||||||
| 		'ФИО', 'name' => 'ФИО', | 		'ФИО', 'name' => 'ФИО', | ||||||
| 		'Работа', 'work' => 'Работа', | 		'Вид работ', 'work' => 'Вид работ', | ||||||
| 		'Начало', 'start' => 'Начало', | 		'Время начала заявки', 'start' => 'Время начала заявки', | ||||||
| 		'Конец', 'end' => 'Конец', | 		'Время окончания заявки', 'end' => 'Время окончания заявки', | ||||||
| 		'Часы', 'hours' => 'Часы', | 		'Количество часов по заявке', 'hours' => 'Количество часов по заявке', | ||||||
| 		'ИНН', 'tax' => 'ИНН', | 		'ИНН', 'tax' => 'ИНН', | ||||||
| 		'Подтверждено', 'confirmed' => 'Подтверждено', | 		'подтверждение', 'confirmed' => 'подтверждение', | ||||||
| 		'Комментарий', 'commentary' => 'Комментарий', | 		'примечание от ТТ', 'commentary' => 'примечание от ТТ', | ||||||
| 		'Ответ', 'response' => 'Ответ', | 		'ответ от контрагента', 'response' => 'ответ от контрагента', | ||||||
| 		'ID', '_id' => 'ID', | 		'ID', '_id' => 'ID', | ||||||
| 		default => $name | 		default => $name | ||||||
| 	}; | 	}; | ||||||
| @@ -95,11 +81,12 @@ function filterWorker(?string $worker): string | |||||||
| { | { | ||||||
| 	global $arangodb; | 	global $arangodb; | ||||||
|  |  | ||||||
| 	return match ((int) $worker) { | 	return match ($worker) { | ||||||
| 		'Отмена', 'отмена', 'ОТМЕНА' => 'Отмена', | 		'Отмена', 'отмена', 'ОТМЕНА' => 'Отмена', | ||||||
| 		'', 0, 00, 000, 0000, 00000, 000000, 0000000, 00000000, 000000000, 0000000000 => '', | 		'', 0, 00, 000, 0000, 00000, 000000, 0000000, 00000000, 000000000, 0000000000 => '', | ||||||
| 		default => (function () use ($worker, $arangodb) { | 		default => (function () use ($worker, $arangodb) { | ||||||
| 			if ( | 			return $worker; | ||||||
|  | 			/* if ( | ||||||
| 				collection::init($arangodb->session, 'workers') | 				collection::init($arangodb->session, 'workers') | ||||||
| 				&& collection::search( | 				&& collection::search( | ||||||
| 					$arangodb->session, | 					$arangodb->session, | ||||||
| @@ -109,7 +96,7 @@ function filterWorker(?string $worker): string | |||||||
| 					) | 					) | ||||||
| 				) | 				) | ||||||
| 			) return $worker; | 			) return $worker; | ||||||
| 			else return ''; | 			else return $worker; */ | ||||||
| 		})() | 		})() | ||||||
| 	}; | 	}; | ||||||
| } | } | ||||||
| @@ -144,29 +131,22 @@ function sync(int $_i, Row &$row, ?array $raw = null): void | |||||||
|  |  | ||||||
| 				// Инициализация данных для записи в таблицу | 				// Инициализация данных для записи в таблицу | ||||||
| 				$new = [ | 				$new = [ | ||||||
| 					'imported_created_in_sheets' => $work->imported_created_in_sheets['converted'], | 					'created_in_sheets' => $work->created_in_sheets, | ||||||
| 					'imported_date' => $work->imported_date['converted'], | 					'date' => $work->date, | ||||||
| 					'imported_market' => $work->imported_market, |  | ||||||
| 					'imported_worker' => $work->imported_worker, |  | ||||||
| 					'imported_work' => $work->imported_work, |  | ||||||
| 					'imported_start' => $work->imported_start['converted'], |  | ||||||
| 					'imported_end' => $work->imported_end['converted'], |  | ||||||
| 					'imported_hours' => $work->imported_hours, |  | ||||||
| 					'created_in_sheets' => $work->created_in_sheets['converted'], |  | ||||||
| 					'date' => $work->date['converted'], |  | ||||||
| 					'market' => $work->market, |  | ||||||
| 					'type' => $work->type, |  | ||||||
| 					'address' => $work->address, |  | ||||||
| 					'worker' => $work->worker, | 					'worker' => $work->worker, | ||||||
| 					'name' => $work->name, | 					'name' => $work->name, | ||||||
| 					'work' => $work->work, | 					'work' => $work->work, | ||||||
| 					'start' => $work->start['converted'], | 					'start' => $work->start, | ||||||
| 					'end' => $work->end['converted'], | 					'end' => $work->end, | ||||||
| 					'hours' => $work->hours, | 					'hours' => $work->hours, | ||||||
| 					'tax' => $work->tax, | 					'market' => $work->market, | ||||||
|  | 					'type' => $work->type, | ||||||
|  | 					'address' => $work->address, | ||||||
| 					'confirmed' => $work->confirmed, | 					'confirmed' => $work->confirmed, | ||||||
| 					'commentary' => $work->commentary, | 					'commentary' => $work->commentary, | ||||||
| 					'response' => $work->response, | 					'response' => $work->response, | ||||||
|  | 					'updated_in_sheets' => $work->updated_in_sheets, | ||||||
|  | 					'tax' => $work->tax, | ||||||
| 					'_id' => $work->getId(), | 					'_id' => $work->getId(), | ||||||
| 				]; | 				]; | ||||||
|  |  | ||||||
| @@ -245,7 +225,6 @@ function sync(int $_i, Row &$row, ?array $raw = null): void | |||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
|  |  | ||||||
| 				if ( | 				if ( | ||||||
| 					collection::init($arangodb->session, 'requests', true)	&& collection::init($arangodb->session, 'markets') | 					collection::init($arangodb->session, 'requests', true)	&& collection::init($arangodb->session, 'markets') | ||||||
| 					&& ($market = collection::search( | 					&& ($market = collection::search( | ||||||
| @@ -313,29 +292,22 @@ function sync(int $_i, Row &$row, ?array $raw = null): void | |||||||
| 				sprintf( | 				sprintf( | ||||||
| 					"FOR d IN works FILTER d._id == '%s' RETURN d", | 					"FOR d IN works FILTER d._id == '%s' RETURN d", | ||||||
| 					document::write($arangodb->session,	'works', [ | 					document::write($arangodb->session,	'works', [ | ||||||
| 						'imported_created_in_sheets' => ['number' => $_row['imported_created_in_sheets'] ?? '', 'converted' => $raw[0] ?? ''], | 						'created_in_sheets' => $raw[0] ?? '', | ||||||
| 						'imported_date' => ['number' => $_row['imported_date'] ?? '', 'converted' => $raw[1] ?? ''], | 						'date' => $raw[1] ?? '', | ||||||
| 						'imported_market' => $_row['imported_market'] ?? '', | 						'worker' => filterWorker($_row['worker'] ?? ''), | ||||||
| 						'imported_worker' => $_row['imported_worker'] ?? '', | 						'name' => "=ЕСЛИ(СОВПАД(\$A$_i;\"\");\"\"; ЕСЛИ( НЕ(СОВПАД(IFNA(ВПР(\$C$_i;part_import_KRSK!\$R$2:\$R$4999;1;);\"\");\$C$_i)); ЕСЛИ((СОВПАД(IFNA(ВПР(\$C$_i;part_import_KRSK!\$I\$2:\$L\$4999;4);\"\");\"\")); IFNA(ВПР(\$C$_i;part_import_KRSK!\$I\$2:\$J\$4999;2;); \"Сотрудник не назначен\"); \"УВОЛЕН (В списке работающих)\"); \"УВОЛЕН (В списке уволенных)\"))", | ||||||
| 						'imported_work' => $_row['imported_work'] ?? '', | 						'work' => $_row['work'] ?? '', | ||||||
| 						'imported_start' => ['number' => $_row['imported_start'] ?? '', 'converted' => $raw[5] ?? ''], | 						'start' => $raw[5] ?? '', | ||||||
| 						'imported_end' => ['number' => $_row['imported_end'] ?? '', 'converted' => $raw[6] ?? ''], | 						'end' => $raw[6] ?? '', | ||||||
| 						'imported_hours' => $_row['imported_hours'] ?? '', | 						'hours' => $_row['hours'] ?? '', | ||||||
| 						'created_in_sheets' => ['number' => $_row['imported_created_in_sheets'] ?? '', 'converted' => $raw[0] ?? ''], | 						'market' => $_row['market'] ?? '', | ||||||
| 						'date' => ['number' => $_row['imported_date'] ?? '', 'converted' => $raw[1] ?? ''], | 						'type' => "=ЕСЛИ(СОВПАД(A$_i;\"\");\"\"; IFNA(ВПР(I$_i;part_import_KRSK!\$B\$2:\$E\$15603;2;);\"Нет в базе\"))", | ||||||
| 						'market' => $_row['imported_market'] ?? '', | 						'address' => "=ЕСЛИ(СОВПАД(A$_i;\"\");\"\"; IFNA(ВПР(I$_i;part_import_KRSK!\$B\$2:\$E\$15603;4;);\"Нет в базе\"))", | ||||||
| 						'type' => empty($_row['type']) ? "=ЕСЛИ(СОВПАД(I$_i;\"\");\"\"; IFNA(ВПР(K$_i;part_import_KRSK!\$B\$2:\$E\$15603;2;);\"Нет в базе\"))" : $_row['type'], |  | ||||||
| 						'address' => empty($_row['address']) ? "=ЕСЛИ(СОВПАД(I$_i;\"\");\"\"; IFNA(ВПР(K$_i;part_import_KRSK!\$B\$2:\$E\$15603;4;);\"Нет в базе\"))" : $_row['address'], |  | ||||||
| 						'worker' => $_row['imported_worker'] ?? '', |  | ||||||
| 						'name' => empty($_row['name']) ? "=ЕСЛИ(СОВПАД(\$I$_i;\"\");\"\"; ЕСЛИ( НЕ(СОВПАД(IFNA(ВПР(\$N$_i;part_import_KRSK!\$R$2:\$R$4999;1;);\"\");\$N$_i)); ЕСЛИ((СОВПАД(IFNA(ВПР(\$N$_i;part_import_KRSK!\$I\$2:\$L\$4999;4);\"\");\"\")); IFNA(ВПР(\$N$_i;part_import_KRSK!\$I\$2:\$J\$4999;2;); \"Сотрудник не назначен\"); \"УВОЛЕН (В списке работающих)\"); \"УВОЛЕН (В списке уволенных)\"))" : $_row['name'], |  | ||||||
| 						'work' => $_row['imported_work'] ?? '', |  | ||||||
| 						'start' => ['number' => $_row['imported_start'] ?? '', 'converted' => $raw[5] ?? ''], |  | ||||||
| 						'end' => ['number' => $_row['imported_end'] ?? '', 'converted' => $raw[6] ?? ''], |  | ||||||
| 						'hours' => $_row['imported_hours'] ?? '', |  | ||||||
| 						'tax' => empty($_row['tax']) ? "=ЕСЛИ(СОВПАД(\$I$_i;\"\");\"\"; IFNA(ВПР(\$N$_i;part_import_KRSK!\$I\$2:\$K\$5000;3;); IFNA(ВПР(\$N$_i;part_import_KRSK!\$R\$2:\$T\$5000;3;);\"000000000000\")))" : $_row['tax'], |  | ||||||
| 						'confirmed' => $_row['confirmed'] ?? '', | 						'confirmed' => $_row['confirmed'] ?? '', | ||||||
| 						'commentary' => $_row['commentary'] ?? '', | 						'commentary' => $_row['commentary'] ?? '', | ||||||
| 						'response' => $_row['response'] ?? '', | 						'response' => $_row['response'] ?? '', | ||||||
|  | 						'updated_in_sheets' => $raw[14] ?? '', | ||||||
|  | 						'tax' => "=ЕСЛИ(СОВПАД(\$A$_i;\"\");\"\"; IFNA(ВПР(\$C$_i;part_import_KRSK!\$I\$2:\$K\$5000;3;); IFNA(ВПР(\$C$_i;part_import_KRSK!\$R\$2:\$T\$5000;3;);\"000000000000\")))", | ||||||
| 						'transfer_to_sheets' => false | 						'transfer_to_sheets' => false | ||||||
| 					]) | 					]) | ||||||
| 				) | 				) | ||||||
| @@ -374,30 +346,23 @@ function sync(int $_i, Row &$row, ?array $raw = null): void | |||||||
|  |  | ||||||
| 			// Реинициализация строки с новыми данными по ссылке (приоритет из Google Sheets) | 			// Реинициализация строки с новыми данными по ссылке (приоритет из Google Sheets) | ||||||
| 			$row = $row->set((new Flow())->read(From::array([init([ | 			$row = $row->set((new Flow())->read(From::array([init([ | ||||||
| 				'imported_created_in_sheets' => $raw[0] ?? '', | 				'created_in_sheets' => $raw[0] ?? '', | ||||||
| 				'imported_date' => $raw[1] ?? '', | 				'date' => $raw[1] ?? '', | ||||||
| 				'imported_market' => $_row['imported_market'] ?? '', | 				'worker' => filterWorker($_row['worker'] ?? ''), | ||||||
| 				'imported_worker' => $_row['imported_worker'] ?? '', | 				'name' => "=ЕСЛИ(СОВПАД(\$A$_i;\"\");\"\"; ЕСЛИ( НЕ(СОВПАД(IFNA(ВПР(\$C$_i;part_import_KRSK!\$R$2:\$R$4999;1;);\"\");\$C$_i)); ЕСЛИ((СОВПАД(IFNA(ВПР(\$C$_i;part_import_KRSK!\$I\$2:\$L\$4999;4);\"\");\"\")); IFNA(ВПР(\$C$_i;part_import_KRSK!\$I\$2:\$J\$4999;2;); \"Сотрудник не назначен\"); \"УВОЛЕН (В списке работающих)\"); \"УВОЛЕН (В списке уволенных)\"))", | ||||||
| 				'imported_work' => $_row['imported_work'] ?? '', | 				'work' => $_row['work'] ?? '', | ||||||
| 				'imported_start' => $raw[5] ?? '', | 				'start' => $raw[5] ?? '', | ||||||
| 				'imported_end' => $raw[6] ?? '', | 				'end' => $raw[6] ?? '', | ||||||
| 				'imported_hours' => $_row['imported_hours'] ?? '', | 				'hours' => $_row['hours'] ?? '', | ||||||
| 				'created_in_sheets' => $raw[0] ?? $raw[8] ?? '', | 				'market' => $_row['market'] ?? '', | ||||||
| 				'date' => $raw[1] ?? $raw[9] ?? '', | 				'type' => "=ЕСЛИ(СОВПАД(A$_i;\"\");\"\"; IFNA(ВПР(I$_i;part_import_KRSK!\$B\$2:\$E\$15603;2;);\"Нет в базе\"))", | ||||||
| 				'market' => $_row['imported_market'] ?? $_row['market'] ?? '', | 				'address' => "=ЕСЛИ(СОВПАД(A$_i;\"\");\"\"; IFNA(ВПР(I$_i;part_import_KRSK!\$B\$2:\$E\$15603;4;);\"Нет в базе\"))", | ||||||
| 				'type' => empty($_row['type']) ? "=ЕСЛИ(СОВПАД(I$_i;\"\");\"\"; IFNA(ВПР(K$_i;part_import_KRSK!\$B\$2:\$E\$15603;2;);\"Нет в базе\"))" : $_row['type'], |  | ||||||
| 				'address' => empty($_row['address']) ? "=ЕСЛИ(СОВПАД(I$_i;\"\");\"\"; IFNA(ВПР(K$_i;part_import_KRSK!\$B\$2:\$E\$15603;4;);\"Нет в базе\"))" : $_row['address'], |  | ||||||
| 				'worker' => filterWorker($_row['imported_worker'] ?? $_row['worker'] ?? ''), |  | ||||||
| 				'name' => empty($_row['name']) ? "=ЕСЛИ(СОВПАД(\$I$_i;\"\");\"\"; ЕСЛИ( НЕ(СОВПАД(IFNA(ВПР(\$N$_i;part_import_KRSK!\$R$2:\$R$4999;1;);\"\");\$N$_i)); ЕСЛИ((СОВПАД(IFNA(ВПР(\$N$_i;part_import_KRSK!\$I\$2:\$L\$4999;4);\"\");\"\")); IFNA(ВПР(\$N$_i;part_import_KRSK!\$I\$2:\$J\$4999;2;); \"Сотрудник не назначен\"); \"УВОЛЕН (В списке работающих)\"); \"УВОЛЕН (В списке уволенных)\"))" : $_row['name'], |  | ||||||
| 				'work' => $_row['imported_work'] ?? $_row['work'] ?? '', |  | ||||||
| 				'start' => $raw[5] ?? $raw[16] ?? '', |  | ||||||
| 				'end' => $raw[6] ?? $raw[17] ?? '', |  | ||||||
| 				'hours' => $_row['imported_hours'] ?? $_row['hours'] ?? '', |  | ||||||
| 				'tax' => empty($_row['tax']) ? "=ЕСЛИ(СОВПАД(\$I$_i;\"\");\"\"; IFNA(ВПР(\$N$_i;part_import_KRSK!\$I\$2:\$K\$5000;3;); IFNA(ВПР(\$N$_i;part_import_KRSK!\$R\$2:\$T\$5000;3;);\"000000000000\")))" : $_row['tax'], |  | ||||||
| 				'confirmed' => $_row['confirmed'] ?? '', | 				'confirmed' => $_row['confirmed'] ?? '', | ||||||
| 				'commentary' => $_row['commentary'] ?? '', | 				'commentary' => $_row['commentary'] ?? '', | ||||||
| 				'response' => $_row['response'] ?? '', | 				'response' => $_row['response'] ?? '', | ||||||
| 				'_id' => $_row['_id'] ?? '', | 				'updated_in_sheets' => $raw[14] ?? '', | ||||||
|  | 				'tax' => "=ЕСЛИ(СОВПАД(\$A$_i;\"\");\"\"; IFNA(ВПР(\$C$_i;part_import_KRSK!\$I\$2:\$K\$5000;3;); IFNA(ВПР(\$C$_i;part_import_KRSK!\$R\$2:\$T\$5000;3;);\"000000000000\")))", | ||||||
|  | 				'_id' => $_row['_id'] ?? '' | ||||||
| 			], true)]))->fetch(1)[0]->get('row')); | 			], true)]))->fetch(1)[0]->get('row')); | ||||||
| 		} else return; | 		} else return; | ||||||
| 	else throw new exception('Не удалось инициализировать коллекцию'); | 	else throw new exception('Не удалось инициализировать коллекцию'); | ||||||
| @@ -417,30 +382,32 @@ foreach ($sheets as $sheet) { | |||||||
| 	// Инициализация обработчика таблиц | 	// Инициализация обработчика таблиц | ||||||
| 	$sheets = new Sheets($client); | 	$sheets = new Sheets($client); | ||||||
|  |  | ||||||
| 	// Инициализация инстанции Flow для Google Sheet API | 	// Инициализация инстанций Flow для Google Sheet API | ||||||
| 	$rows = (new Flow())->read(new GoogleSheetExtractor($sheets, $document, new Columns($sheet, 'A', 'X'), true, 1000, 'row', ['valueRenderOption' => 'FORMULA'])); | 	$formulas = (new Flow())->read(new GoogleSheetExtractor($sheets, $document, new Columns($sheet, 'A', 'Q'), true, 1000, 'row', ['valueRenderOption' => 'FORMULA'])); | ||||||
|  | 	$rows = $sheets->spreadsheets_values->get($document, "$sheet!A:Q"); | ||||||
|  |  | ||||||
| 	// Инициализация счётчика итераций | 	// Инициализация счётчика итераций | ||||||
| 	$i = 1; | 	$i = 1; | ||||||
|  |  | ||||||
| 	foreach ($rows->fetch(10000) as $row) { | 	foreach ($formulas->fetch(50000) as $formula) { | ||||||
|  |  | ||||||
| 		// Перебор строк | 		// Перебор строк | ||||||
|  |  | ||||||
| 		// Запись счётчика | 		// Запись счётчика | ||||||
| 		++$i; | 		++$i; | ||||||
|  |  | ||||||
| 		// Инициализация буфера строки | 		// Инициализация буфера строки | ||||||
| 		$buffer = $row; | 		$buffer = $formula; | ||||||
|  |  | ||||||
| 		// Синхронизация с базой данных | 		// Синхронизация с базой данных | ||||||
| 		sync($i, $row, $sheets->spreadsheets_values->get($document, "$sheet!A$i:X$i")[0] ?? null); | 		sync($i, $formula, $rows[$i - 1] ?? null); | ||||||
|  |  | ||||||
| 		// Запись изменений строки в Google Sheet | 		// Запись изменений строки в Google Sheet | ||||||
| 		if ($buffer !== $row) { | 		if ($buffer !== $formula) { | ||||||
| 			$sheets->spreadsheets_values->update( | 			$sheets->spreadsheets_values->update( | ||||||
| 				$document, | 				$document, | ||||||
| 				"$sheet!A$i:X$i", | 				"$sheet!A$i:Q$i", | ||||||
| 				new ValueRange(['values' => [array_values($row->entries()->toArray()['row'])]]), | 				new ValueRange(['values' => [array_values($formula->entries()->toArray()['row'])]]), | ||||||
| 				['valueInputOption' => 'USER_ENTERED'] | 				['valueInputOption' => 'USER_ENTERED'] | ||||||
| 			); | 			); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/arangodb.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/arangodb.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/markets/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/markets/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/markets/document.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/markets/document.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/markets/google.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/markets/google.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/markets/sheets.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/markets/sheets.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/workers/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/workers/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/workers/document.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/workers/document.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/workers/google.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/workers/google.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/workers/sheets.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/workers/sheets.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/works/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/works/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/works/document.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/works/document.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/works/google.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/works/google.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/works/sheets.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								mirzaev/spetsresurs/google_sheets/parser/system/settings/works/sheets.php.sample
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								sheets/markets.xlsx
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								sheets/markets.xlsx
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								sheets/workers.xlsx
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								sheets/workers.xlsx
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								sheets/works.xlsx
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								sheets/works.xlsx
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
		Reference in New Issue
	
	Block a user