Виджет amoCRM: экспорт данных в Google Docs - IT-C@FE
×
Masterpro Nivo Slider (06 фев 2023)

Это форк Vinaora Nivo Slider, пришлось переименовать, в силу требования JED. Даже старую версию качать можно было только с варезных сайтов, нашпигованную троянами. Зачем оно такое, согласитесь.

× Время от времени - и не так чтобы редко - на форуме звучат вопросы по нативному PHP... решили собирать их в этой ветке.

Идея Виджет amoCRM: экспорт данных в Google Docs

Подробнее
6 года 3 мес. назад - 6 года 3 мес. назад #1 от Aleksej
Код, прокомментированный в материале блога Виджет amoCRM: экспорт данных в Google Docs . Также, возможно, нелишне ознакомиться с топиком Загрузка файлов через API Google Drive , где показан код файла index.phtml.


<?php
session_start();
$url_array = explode('?', 'http://'.$_SERVER ['HTTP_HOST'].$_SERVER['REQUEST_URI']);
$url = $url_array[0];
require_once 'google-api-php-client/src/Google_Client.php';
require_once 'google-api-php-client/src/contrib/Google_DriveService.php';
$client = new Google_Client();
$client->setClientId('your client id');
$client->setClientSecret('your client secret');
$client->setRedirectUri($url);
$client->setScopes(array('https://www.googleapis.com/auth/drive'));
if (isset($_GET['code'])) {
    $_SESSION['accessToken'] = $client->authenticate($_GET['code']);
    header('location:'.$url);exit;
} elseif (!isset($_SESSION['accessToken'])) {
    $client->authenticate();
}
$files= array();
$dir = dir('files');
while ($file = $dir->read()) {
    if ($file != '.' && $file != '..') {
        $files[] = $file;
    }
}
$dir->close();
if (!empty($_POST)) {
    $client->setAccessToken($_SESSION['accessToken']);
    $service = new Google_DriveService($client);
    $finfo = finfo_open(FILEINFO_MIME_TYPE);
    $file = new Google_DriveFile();
    foreach ($files as $file_name) {
        $file_path = 'files/'.$file_name;
        $mime_type = finfo_file($finfo, $file_path);
        $file->setTitle($file_name);
        $file->setDescription('This is a '.$mime_type.' document');
        $file->setMimeType($mime_type);
        $service->files->insert(
            $file,
            array(
                'data' => file_get_contents($file_path),
                'mimeType' => $mime_type
            )
        );
    }
    finfo_close($finfo);
    header('location:'.$url);exit;
}
include 'index.phtml';
require_once 'amocrm.phar';
try {
    $amo = new \AmoCRM\Client('SUBDOMAIN', 'LOGIN', 'HASH');
    $account = $amo->account;
    
    $arr = ($amo->lead->apiList([
        // 'query' => 'Илья',
    ]));

} catch (\AmoCRM\Exception $e) {
    printf('Error (%d): %s' . PHP_EOL, $e->getCode(), $e->getMessage());
}

require_once 'vsword/VsWord.php'; 
VsWord::autoLoad();

$doc = new VsWord(); 
$parser = new HtmlParser($doc);
$parser->parse('<h3>Сделки</h3>');
$parser->parse('<p>ID сделки = ' . $arr[0]['id'] . '</p>');
$parser->parse('<p>Название = ' . $arr[0]['name'] . '</p>');
$parser->parse('<p>Стоимость = ' . $arr[0]['price'] . '</p>');
$parser->parse('<p>ID сделки = ' . $arr[1]['id'] . '</p>');
$parser->parse('<p>Название = ' . $arr[1]['name'] . '</p>');
$parser->parse('<p>Стоимость = ' . $arr[1]['price'] . '</p>');
$parser->parse('<p>ID сделки = ' . $arr[2]['id'] . '</p>');
$parser->parse('<p>Название = ' . $arr[2]['name'] . '</p>');
$parser->parse('<p>Стоимость = ' . $arr[2]['price'] . '</p>');
$parser->parse($html);

$doc->saveAs('files/deal.docx');
Последнее редактирование: 6 года 3 мес. назад пользователем Aleksej.

Пожалуйста Войти или Регистрация, чтобы присоединиться к беседе.

Работает на Kunena форум