C:\xampp\phpMyAdmin\libraries\classes\Plugins\Import\AbstractImportCsv.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
 * Super class of CSV import plugins for phpMyAdmin
 *
 * @package    PhpMyAdmin-Import
 * @subpackage CSV
 */
namespace PhpMyAdmin\Plugins\Import;

use 
PhpMyAdmin\Properties\Options\Items\BoolPropertyItem;
use 
PhpMyAdmin\Properties\Plugins\ImportPluginProperties;
use 
PhpMyAdmin\Properties\Options\Groups\OptionsPropertyMainGroup;
use 
PhpMyAdmin\Properties\Options\Groups\OptionsPropertyRootGroup;
use 
PhpMyAdmin\Plugins\ImportPlugin;
use 
PhpMyAdmin\Properties\Options\Items\TextPropertyItem;

/**
 * Super class of the import plugins for the CSV format
 *
 * @package    PhpMyAdmin-Import
 * @subpackage CSV
 */
abstract class AbstractImportCsv extends ImportPlugin
{
    
/**
     * Sets the import plugin properties.
     * Called in the constructor.
     *
     * @return \PhpMyAdmin\Properties\Options\Groups\OptionsPropertyMainGroup PhpMyAdmin\Properties\Options\Groups\OptionsPropertyMainGroup object of the plugin
     */
    
protected function setProperties()
    {
        
$importPluginProperties = new ImportPluginProperties();
        
$importPluginProperties->setOptionsText(__('Options'));

        
// create the root group that will be the options field for
        // $importPluginProperties
        // this will be shown as "Format specific options"
        
$importSpecificOptions = new OptionsPropertyRootGroup(
            
"Format Specific Options"
        
);

        
// general options main group
        
$generalOptions = new OptionsPropertyMainGroup("general_opts");

        
// create common items and add them to the group
        
$leaf = new BoolPropertyItem(
            
"replace",
            
__(
                
'Update data when duplicate keys found on import (add ON DUPLICATE '
                
'KEY UPDATE)'
            
)
        );
        
$generalOptions->addProperty($leaf);
        
$leaf = new TextPropertyItem(
            
"terminated",
            
__('Columns separated with:')
        );
        
$leaf->setSize(2);
        
$generalOptions->addProperty($leaf);
        
$leaf = new TextPropertyItem(
            
"enclosed",
            
__('Columns enclosed with:')
        );
        
$leaf->setSize(2);
        
$leaf->setLen(2);
        
$generalOptions->addProperty($leaf);
        
$leaf = new TextPropertyItem(
            
"escaped",
            
__('Columns escaped with:')
        );
        
$leaf->setSize(2);
        
$leaf->setLen(2);
        
$generalOptions->addProperty($leaf);
        
$leaf = new TextPropertyItem(
            
"new_line",
            
__('Lines terminated with:')
        );
        
$leaf->setSize(2);
        
$generalOptions->addProperty($leaf);

        
// add the main group to the root group
        
$importSpecificOptions->addProperty($generalOptions);

        
// set the options for the import plugin property item
        
$importPluginProperties->setOptions($importSpecificOptions);
        
$this->properties $importPluginProperties;

        return 
$generalOptions;
    }
}
x

Windows NT KPTV 6.2 build 9200 (Windows Server 2012 Datacenter Edition) i586