Cambios
git-svn-id: https://192.168.0.254/svn/Proyectos.FundacionLQDVI_Web/trunk@9 77ab8c26-3d69-2c4d-86f2-786f4ba54905
658
db/lqdvi.sql
BIN
src/webcam/images/0C700EE0-4C10-15EB-0272-68B33B80ADC2.jpg
Normal file
|
After Width: | Height: | Size: 11 KiB |
BIN
src/webcam/images/1167FFDE-1BBE-D1D5-36FF-C406C5FCABA7.jpg
Normal file
|
After Width: | Height: | Size: 9.7 KiB |
BIN
src/webcam/images/181F7930-21AE-BD3D-6F7E-DD7449700587.jpg
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
src/webcam/images/2A33C8F9-4905-7A2C-62D3-CCCD8D9F994F.jpg
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
src/webcam/images/2E948482-F797-CC56-9145-C785BF1A91D1.jpg
Normal file
|
After Width: | Height: | Size: 11 KiB |
BIN
src/webcam/images/2FC678DC-239B-411B-7289-F0CC12EF18B5.jpg
Normal file
|
After Width: | Height: | Size: 11 KiB |
BIN
src/webcam/images/38A217F5-EEAB-D63F-1253-FC88FEA2C1FA.jpg
Normal file
|
After Width: | Height: | Size: 8.4 KiB |
BIN
src/webcam/images/3D364F2A-DCE9-D20A-995A-764316350163.jpg
Normal file
|
After Width: | Height: | Size: 10 KiB |
BIN
src/webcam/images/493FC6C7-17ED-25B4-DD1F-948DB3406735.jpg
Normal file
|
After Width: | Height: | Size: 11 KiB |
BIN
src/webcam/images/4A724669-CCE0-3EBF-7A7C-E74973F96C95.jpg
Normal file
|
After Width: | Height: | Size: 8.4 KiB |
BIN
src/webcam/images/50BF232A-3AB4-EDBB-EBDB-B6E5F2307F6A.jpg
Normal file
|
After Width: | Height: | Size: 8.5 KiB |
BIN
src/webcam/images/71581A49-9BF2-8969-9E72-04FF4859B82C.jpg
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
src/webcam/images/7783D792-8B3B-9456-4CB4-F3FF9B05165C.jpg
Normal file
|
After Width: | Height: | Size: 6.9 KiB |
BIN
src/webcam/images/95D91170-1F0D-CB6B-139D-23BE7B3A4388.jpg
Normal file
|
After Width: | Height: | Size: 8.6 KiB |
BIN
src/webcam/images/99FC1D38-C7B6-0237-6E09-55A8E3B6E0B8.jpg
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
src/webcam/images/A05C1D8C-FB01-EE14-1C17-1769EBC291F9.jpg
Normal file
|
After Width: | Height: | Size: 12 KiB |
BIN
src/webcam/images/AAD23011-19AC-719C-5DFD-7FC61AFF513F.jpg
Normal file
|
After Width: | Height: | Size: 8.5 KiB |
BIN
src/webcam/images/B1F78801-1A28-6D55-F47C-06A30BD3A4BE.jpg
Normal file
|
After Width: | Height: | Size: 8.4 KiB |
BIN
src/webcam/images/BBCBF736-6009-5B53-F63F-0926C8F0D6C3.jpg
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
src/webcam/images/C55DF279-E87F-631A-D2B1-6FDAF2397AE6.jpg
Normal file
|
After Width: | Height: | Size: 8.4 KiB |
BIN
src/webcam/images/C68FE4CC-8596-4ED3-18F5-DEAC90D2ACBA.jpg
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
src/webcam/images/CA662185-EC7F-D00C-EC6B-16017788C074.jpg
Normal file
|
After Width: | Height: | Size: 6.9 KiB |
BIN
src/webcam/images/D4D10163-90B2-9178-A993-A92C451714DD.jpg
Normal file
|
After Width: | Height: | Size: 8.5 KiB |
BIN
src/webcam/images/D5075A9C-30B2-C867-5039-340ED263977E.jpg
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
src/webcam/images/D724ECAA-3795-57E8-6C48-6AD52DC2DDA5.jpg
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
src/webcam/images/DA5F7E2C-4DB2-3C7F-3D81-38F12B72916C.jpg
Normal file
|
After Width: | Height: | Size: 8.5 KiB |
BIN
src/webcam/images/DC376E0C-C1D4-DD9E-D76D-737C21C7B10A.jpg
Normal file
|
After Width: | Height: | Size: 8.4 KiB |
BIN
src/webcam/images/F2294993-A7F6-CDC1-53B1-A8BE1579CBBF.jpg
Normal file
|
After Width: | Height: | Size: 12 KiB |
BIN
src/webcam/images/F54C564B-2B49-1EC5-79D8-C42B2D459CAA.jpg
Normal file
|
After Width: | Height: | Size: 9.5 KiB |
0
src/wp-content/mm-forms-community.tmp
Normal file
0
src/wp-content/mm-forms-community1.tmp
Normal file
@ -140,6 +140,29 @@ function wpcf7_hidden_shortcode_handler( $tag ) {
|
||||
}
|
||||
|
||||
|
||||
/* Validation filter */
|
||||
|
||||
add_filter( 'wpcf7_validate_hidden', 'wpcf7_hidden_validation_filter', 10, 2 );
|
||||
add_filter( 'wpcf7_validate_hidden*', 'wpcf7_hidden_validation_filter', 10, 2 );
|
||||
|
||||
function wpcf7_hidden_validation_filter( $result, $tag ) {
|
||||
$type = $tag['type'];
|
||||
$name = $tag['name'];
|
||||
|
||||
$_POST[$name] = trim( strtr( (string) $_POST[$name], "\n", " " ) );
|
||||
|
||||
if ( 'hidden*' == $type ) {
|
||||
if ( '' == $_POST[$name] ) {
|
||||
$result['valid'] = false;
|
||||
$result['reason'][$name] = wpcf7_get_message( 'invalid_required' );
|
||||
}
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* Tag generator */
|
||||
|
||||
add_action( 'admin_init', 'wpcf7_add_tag_generator_hidden', 30 );
|
||||
|
||||
@ -1,31 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
"Contact Form to Database Extension" Copyright (C) 2011 Michael Simpson (email : michael.d.simpson@gmail.com)
|
||||
|
||||
This file is part of Contact Form to Database Extension.
|
||||
|
||||
Contact Form to Database Extension is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
Contact Form to Database Extension is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Contact Form to Database Extension.
|
||||
If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
interface CF7DBEvalutator {
|
||||
|
||||
/**
|
||||
* Evaluate expression against input data
|
||||
* @param $data array [ key => value]
|
||||
* @return boolean result of evaluating $data against expression
|
||||
*/
|
||||
public function evaluate(&$data);
|
||||
|
||||
}
|
||||
@ -1,32 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
"Contact Form to Database Extension" Copyright (C) 2011 Michael Simpson (email : michael.d.simpson@gmail.com)
|
||||
|
||||
This file is part of Contact Form to Database Extension.
|
||||
|
||||
Contact Form to Database Extension is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
Contact Form to Database Extension is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Contact Form to Database Extension.
|
||||
If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
require_once('CFDBShortcodeValue.php');
|
||||
|
||||
class CFDBShortcodeCount extends CFDBShortcodeValue {
|
||||
|
||||
public function handleShortcode($atts) {
|
||||
$atts['function'] = 'count';
|
||||
unset($atts['show']);
|
||||
unset($atts['hide']);
|
||||
return parent::handleShortcode($atts);
|
||||
}
|
||||
}
|
||||
@ -1,69 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
"Contact Form to Database Extension" Copyright (C) 2011 Michael Simpson (email : michael.d.simpson@gmail.com)
|
||||
|
||||
This file is part of Contact Form to Database Extension.
|
||||
|
||||
Contact Form to Database Extension is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
Contact Form to Database Extension is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Contact Form to Database Extension.
|
||||
If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
require_once('ShortCodeLoader.php');
|
||||
|
||||
class CFDBShortcodeExportUrl extends ShortCodeLoader {
|
||||
|
||||
/**
|
||||
* @param $atts array of short code attributes
|
||||
* @return string JSON. See ExportToJson.php
|
||||
*/
|
||||
public function handleShortcode($atts) {
|
||||
$params = array();
|
||||
$params[] = admin_url('admin-ajax.php');
|
||||
$params[] = '?action=cfdb-export';
|
||||
if (isset($atts['form'])) {
|
||||
$params[] = '&form=' . urlencode($atts['form']);
|
||||
}
|
||||
if (isset($atts['show'])) {
|
||||
$params[] = '&show=' . urlencode($atts['show']);
|
||||
}
|
||||
if (isset($atts['hide'])) {
|
||||
$params[] = '&hide=' . urlencode($atts['hide']);
|
||||
}
|
||||
if (isset($atts['limit'])) {
|
||||
$params[] = '&limit=' . urlencode($atts['limit']);
|
||||
}
|
||||
if (isset($atts['search'])) {
|
||||
$params[] = '&search=' . urlencode($atts['search']);
|
||||
}
|
||||
if (isset($atts['filter'])) {
|
||||
$params[] = '&filter=' . urlencode($atts['filter']);
|
||||
}
|
||||
if (isset($atts['enc'])) {
|
||||
$params[] = '&enc=' . urlencode($atts['enc']);
|
||||
}
|
||||
|
||||
$url = implode($params);
|
||||
|
||||
if (isset($atts['urlonly']) && $atts['urlonly'] == 'true') {
|
||||
return $url;
|
||||
}
|
||||
|
||||
$linkText = __('Export', 'contact-form-7-to-database-extension');
|
||||
if (isset($atts['linktext'])) {
|
||||
$linkText = $atts['linktext'];
|
||||
}
|
||||
|
||||
return sprintf('<a href="%s">%s</a>', $url, $linkText);
|
||||
}
|
||||
}
|
||||
@ -1,37 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
"Contact Form to Database Extension" Copyright (C) 2011 Michael Simpson (email : michael.d.simpson@gmail.com)
|
||||
|
||||
This file is part of Contact Form to Database Extension.
|
||||
|
||||
Contact Form to Database Extension is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
Contact Form to Database Extension is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Contact Form to Database Extension.
|
||||
If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
require_once('ShortCodeLoader.php');
|
||||
|
||||
class CFDBShortcodeJson extends ShortCodeLoader {
|
||||
|
||||
/**
|
||||
* @param $atts array of short code attributes
|
||||
* @return string JSON. See ExportToJson.php
|
||||
*/
|
||||
public function handleShortcode($atts) {
|
||||
$atts['html'] = true;
|
||||
$atts['fromshortcode'] = true;
|
||||
require_once('ExportToJson.php');
|
||||
$export = new ExportToJson();
|
||||
return $export->export($atts['form'], $atts);
|
||||
}
|
||||
}
|
||||
@ -1,90 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
"Contact Form to Database Extension" Copyright (C) 2011 Michael Simpson (email : michael.d.simpson@gmail.com)
|
||||
|
||||
This file is part of Contact Form to Database Extension.
|
||||
|
||||
Contact Form to Database Extension is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
Contact Form to Database Extension is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Contact Form to Database Extension.
|
||||
If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
abstract class CFDBView {
|
||||
|
||||
/**
|
||||
* @abstract
|
||||
* @param $plugin CF7DBPlugin
|
||||
* @return void
|
||||
*/
|
||||
abstract function display(&$plugin);
|
||||
|
||||
protected function pageHeader(&$plugin) {
|
||||
$this->sponsorLink($plugin);
|
||||
$this->headerLinks();
|
||||
}
|
||||
|
||||
|
||||
protected function sponsorLink(&$plugin) {
|
||||
if ('true' != $plugin->getOption('Donated')) {
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
var psHost = (("https:" == document.location.protocol) ? "https://" : "http://");
|
||||
document.write(unescape("%3Cscript src='" + psHost + "pluginsponsors.com/direct/spsn/display.php?client=contact-form-7-to-database-extension&spot='type='text/javascript'%3E%3C/script%3E"));
|
||||
</script>
|
||||
<?php
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
protected function headerLinks() {
|
||||
?>
|
||||
<table style="width:100%;">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td width="20%" style="font-size:x-small;">
|
||||
<a target="_donate"
|
||||
href="https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=NEVDJ792HKGFN&lc=US&item_name=Wordpress%20Plugin&item_number=cf7%2dto%2ddb%2dextension¤cy_code=USD&bn=PP%2dDonationsBF%3abtn_donateCC_LG%2egif%3aNonHosted">
|
||||
<img src="https://www.paypal.com/en_US/i/btn/btn_donate_SM.gif" alt="Donate">
|
||||
</a>
|
||||
</td>
|
||||
<td width="20%" style="font-size:x-small;">
|
||||
<a target="_cf7todb"
|
||||
href="http://wordpress.org/extend/plugins/contact-form-7-to-database-extension">
|
||||
<?php _e('Rate this Plugin', 'contact-form-7-to-database-extension') ?>
|
||||
</a>
|
||||
</td>
|
||||
<td width="20%" style="font-size:x-small;">
|
||||
<a target="_cf7todb"
|
||||
href="http://cfdbplugin.com/">
|
||||
<?php _e('Documentation', 'contact-form-7-to-database-extension') ?>
|
||||
</a>
|
||||
</td>
|
||||
<td width="20%" style="font-size:x-small;">
|
||||
<a target="_cf7todb"
|
||||
href="http://wordpress.org/tags/contact-form-7-to-database-extension">
|
||||
<?php _e('Support', 'contact-form-7-to-database-extension') ?>
|
||||
</a>
|
||||
</td>
|
||||
<td width="20%" style="font-size:x-small;">
|
||||
<a target="_cf7todb"
|
||||
href="http://pluginsponsors.com/privacy.html">
|
||||
<?php _e('Privacy Policy', 'contact-form-7-to-database-extension') ?>
|
||||
</a>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<?php
|
||||
|
||||
}
|
||||
}
|
||||
@ -1,11 +0,0 @@
|
||||
This DataTables plugin (v1.7.x) for jQuery was developed out of the desire to allow highly configurable access to HTML tables with advanced access features.
|
||||
|
||||
For detailed installation, usage and API instructions, please refer to the DataTables web-pages: http://www.datatables.net
|
||||
|
||||
Questions, feature requests and bug reports (etc) can all be asked on the DataTables forums: http://www.datatables.net/forums/
|
||||
|
||||
The DataTables source can be found in the media/js/ directory of this archive.
|
||||
|
||||
DataTables is released with dual licensing, using the GPL v2 (license-gpl2.txt) and an BSD style license (license-bsd.txt). Please see the corresponding license file for details of these licenses. You are free to use, modify and distribute this software, but all copyright information must remain.
|
||||
|
||||
If you discover any bugs in DataTables, have any suggestions for improvements or even if you just like using it, please free to get in touch with me: www.datatables.net/contact
|
||||
@ -1,10 +0,0 @@
|
||||
Copyright (c) 2008-2010, Allan Jardine
|
||||
All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
|
||||
|
||||
* Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
|
||||
* Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
|
||||
* Neither the name of Allan Jardine nor SpryMedia UK may be used to endorse or promote products derived from this software without specific prior written permission.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
@ -1,339 +0,0 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
Version 2, June 1991
|
||||
|
||||
Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
|
||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The licenses for most software are designed to take away your
|
||||
freedom to share and change it. By contrast, the GNU General Public
|
||||
License is intended to guarantee your freedom to share and change free
|
||||
software--to make sure the software is free for all its users. This
|
||||
General Public License applies to most of the Free Software
|
||||
Foundation's software and to any other program whose authors commit to
|
||||
using it. (Some other Free Software Foundation software is covered by
|
||||
the GNU Lesser General Public License instead.) You can apply it to
|
||||
your programs, too.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not
|
||||
price. Our General Public Licenses are designed to make sure that you
|
||||
have the freedom to distribute copies of free software (and charge for
|
||||
this service if you wish), that you receive source code or can get it
|
||||
if you want it, that you can change the software or use pieces of it
|
||||
in new free programs; and that you know you can do these things.
|
||||
|
||||
To protect your rights, we need to make restrictions that forbid
|
||||
anyone to deny you these rights or to ask you to surrender the rights.
|
||||
These restrictions translate to certain responsibilities for you if you
|
||||
distribute copies of the software, or if you modify it.
|
||||
|
||||
For example, if you distribute copies of such a program, whether
|
||||
gratis or for a fee, you must give the recipients all the rights that
|
||||
you have. You must make sure that they, too, receive or can get the
|
||||
source code. And you must show them these terms so they know their
|
||||
rights.
|
||||
|
||||
We protect your rights with two steps: (1) copyright the software, and
|
||||
(2) offer you this license which gives you legal permission to copy,
|
||||
distribute and/or modify the software.
|
||||
|
||||
Also, for each author's protection and ours, we want to make certain
|
||||
that everyone understands that there is no warranty for this free
|
||||
software. If the software is modified by someone else and passed on, we
|
||||
want its recipients to know that what they have is not the original, so
|
||||
that any problems introduced by others will not reflect on the original
|
||||
authors' reputations.
|
||||
|
||||
Finally, any free program is threatened constantly by software
|
||||
patents. We wish to avoid the danger that redistributors of a free
|
||||
program will individually obtain patent licenses, in effect making the
|
||||
program proprietary. To prevent this, we have made it clear that any
|
||||
patent must be licensed for everyone's free use or not licensed at all.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow.
|
||||
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||
|
||||
0. This License applies to any program or other work which contains
|
||||
a notice placed by the copyright holder saying it may be distributed
|
||||
under the terms of this General Public License. The "Program", below,
|
||||
refers to any such program or work, and a "work based on the Program"
|
||||
means either the Program or any derivative work under copyright law:
|
||||
that is to say, a work containing the Program or a portion of it,
|
||||
either verbatim or with modifications and/or translated into another
|
||||
language. (Hereinafter, translation is included without limitation in
|
||||
the term "modification".) Each licensee is addressed as "you".
|
||||
|
||||
Activities other than copying, distribution and modification are not
|
||||
covered by this License; they are outside its scope. The act of
|
||||
running the Program is not restricted, and the output from the Program
|
||||
is covered only if its contents constitute a work based on the
|
||||
Program (independent of having been made by running the Program).
|
||||
Whether that is true depends on what the Program does.
|
||||
|
||||
1. You may copy and distribute verbatim copies of the Program's
|
||||
source code as you receive it, in any medium, provided that you
|
||||
conspicuously and appropriately publish on each copy an appropriate
|
||||
copyright notice and disclaimer of warranty; keep intact all the
|
||||
notices that refer to this License and to the absence of any warranty;
|
||||
and give any other recipients of the Program a copy of this License
|
||||
along with the Program.
|
||||
|
||||
You may charge a fee for the physical act of transferring a copy, and
|
||||
you may at your option offer warranty protection in exchange for a fee.
|
||||
|
||||
2. You may modify your copy or copies of the Program or any portion
|
||||
of it, thus forming a work based on the Program, and copy and
|
||||
distribute such modifications or work under the terms of Section 1
|
||||
above, provided that you also meet all of these conditions:
|
||||
|
||||
a) You must cause the modified files to carry prominent notices
|
||||
stating that you changed the files and the date of any change.
|
||||
|
||||
b) You must cause any work that you distribute or publish, that in
|
||||
whole or in part contains or is derived from the Program or any
|
||||
part thereof, to be licensed as a whole at no charge to all third
|
||||
parties under the terms of this License.
|
||||
|
||||
c) If the modified program normally reads commands interactively
|
||||
when run, you must cause it, when started running for such
|
||||
interactive use in the most ordinary way, to print or display an
|
||||
announcement including an appropriate copyright notice and a
|
||||
notice that there is no warranty (or else, saying that you provide
|
||||
a warranty) and that users may redistribute the program under
|
||||
these conditions, and telling the user how to view a copy of this
|
||||
License. (Exception: if the Program itself is interactive but
|
||||
does not normally print such an announcement, your work based on
|
||||
the Program is not required to print an announcement.)
|
||||
|
||||
These requirements apply to the modified work as a whole. If
|
||||
identifiable sections of that work are not derived from the Program,
|
||||
and can be reasonably considered independent and separate works in
|
||||
themselves, then this License, and its terms, do not apply to those
|
||||
sections when you distribute them as separate works. But when you
|
||||
distribute the same sections as part of a whole which is a work based
|
||||
on the Program, the distribution of the whole must be on the terms of
|
||||
this License, whose permissions for other licensees extend to the
|
||||
entire whole, and thus to each and every part regardless of who wrote it.
|
||||
|
||||
Thus, it is not the intent of this section to claim rights or contest
|
||||
your rights to work written entirely by you; rather, the intent is to
|
||||
exercise the right to control the distribution of derivative or
|
||||
collective works based on the Program.
|
||||
|
||||
In addition, mere aggregation of another work not based on the Program
|
||||
with the Program (or with a work based on the Program) on a volume of
|
||||
a storage or distribution medium does not bring the other work under
|
||||
the scope of this License.
|
||||
|
||||
3. You may copy and distribute the Program (or a work based on it,
|
||||
under Section 2) in object code or executable form under the terms of
|
||||
Sections 1 and 2 above provided that you also do one of the following:
|
||||
|
||||
a) Accompany it with the complete corresponding machine-readable
|
||||
source code, which must be distributed under the terms of Sections
|
||||
1 and 2 above on a medium customarily used for software interchange; or,
|
||||
|
||||
b) Accompany it with a written offer, valid for at least three
|
||||
years, to give any third party, for a charge no more than your
|
||||
cost of physically performing source distribution, a complete
|
||||
machine-readable copy of the corresponding source code, to be
|
||||
distributed under the terms of Sections 1 and 2 above on a medium
|
||||
customarily used for software interchange; or,
|
||||
|
||||
c) Accompany it with the information you received as to the offer
|
||||
to distribute corresponding source code. (This alternative is
|
||||
allowed only for noncommercial distribution and only if you
|
||||
received the program in object code or executable form with such
|
||||
an offer, in accord with Subsection b above.)
|
||||
|
||||
The source code for a work means the preferred form of the work for
|
||||
making modifications to it. For an executable work, complete source
|
||||
code means all the source code for all modules it contains, plus any
|
||||
associated interface definition files, plus the scripts used to
|
||||
control compilation and installation of the executable. However, as a
|
||||
special exception, the source code distributed need not include
|
||||
anything that is normally distributed (in either source or binary
|
||||
form) with the major components (compiler, kernel, and so on) of the
|
||||
operating system on which the executable runs, unless that component
|
||||
itself accompanies the executable.
|
||||
|
||||
If distribution of executable or object code is made by offering
|
||||
access to copy from a designated place, then offering equivalent
|
||||
access to copy the source code from the same place counts as
|
||||
distribution of the source code, even though third parties are not
|
||||
compelled to copy the source along with the object code.
|
||||
|
||||
4. You may not copy, modify, sublicense, or distribute the Program
|
||||
except as expressly provided under this License. Any attempt
|
||||
otherwise to copy, modify, sublicense or distribute the Program is
|
||||
void, and will automatically terminate your rights under this License.
|
||||
However, parties who have received copies, or rights, from you under
|
||||
this License will not have their licenses terminated so long as such
|
||||
parties remain in full compliance.
|
||||
|
||||
5. You are not required to accept this License, since you have not
|
||||
signed it. However, nothing else grants you permission to modify or
|
||||
distribute the Program or its derivative works. These actions are
|
||||
prohibited by law if you do not accept this License. Therefore, by
|
||||
modifying or distributing the Program (or any work based on the
|
||||
Program), you indicate your acceptance of this License to do so, and
|
||||
all its terms and conditions for copying, distributing or modifying
|
||||
the Program or works based on it.
|
||||
|
||||
6. Each time you redistribute the Program (or any work based on the
|
||||
Program), the recipient automatically receives a license from the
|
||||
original licensor to copy, distribute or modify the Program subject to
|
||||
these terms and conditions. You may not impose any further
|
||||
restrictions on the recipients' exercise of the rights granted herein.
|
||||
You are not responsible for enforcing compliance by third parties to
|
||||
this License.
|
||||
|
||||
7. If, as a consequence of a court judgment or allegation of patent
|
||||
infringement or for any other reason (not limited to patent issues),
|
||||
conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot
|
||||
distribute so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you
|
||||
may not distribute the Program at all. For example, if a patent
|
||||
license would not permit royalty-free redistribution of the Program by
|
||||
all those who receive copies directly or indirectly through you, then
|
||||
the only way you could satisfy both it and this License would be to
|
||||
refrain entirely from distribution of the Program.
|
||||
|
||||
If any portion of this section is held invalid or unenforceable under
|
||||
any particular circumstance, the balance of the section is intended to
|
||||
apply and the section as a whole is intended to apply in other
|
||||
circumstances.
|
||||
|
||||
It is not the purpose of this section to induce you to infringe any
|
||||
patents or other property right claims or to contest validity of any
|
||||
such claims; this section has the sole purpose of protecting the
|
||||
integrity of the free software distribution system, which is
|
||||
implemented by public license practices. Many people have made
|
||||
generous contributions to the wide range of software distributed
|
||||
through that system in reliance on consistent application of that
|
||||
system; it is up to the author/donor to decide if he or she is willing
|
||||
to distribute software through any other system and a licensee cannot
|
||||
impose that choice.
|
||||
|
||||
This section is intended to make thoroughly clear what is believed to
|
||||
be a consequence of the rest of this License.
|
||||
|
||||
8. If the distribution and/or use of the Program is restricted in
|
||||
certain countries either by patents or by copyrighted interfaces, the
|
||||
original copyright holder who places the Program under this License
|
||||
may add an explicit geographical distribution limitation excluding
|
||||
those countries, so that distribution is permitted only in or among
|
||||
countries not thus excluded. In such case, this License incorporates
|
||||
the limitation as if written in the body of this License.
|
||||
|
||||
9. The Free Software Foundation may publish revised and/or new versions
|
||||
of the General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to
|
||||
address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the Program
|
||||
specifies a version number of this License which applies to it and "any
|
||||
later version", you have the option of following the terms and conditions
|
||||
either of that version or of any later version published by the Free
|
||||
Software Foundation. If the Program does not specify a version number of
|
||||
this License, you may choose any version ever published by the Free Software
|
||||
Foundation.
|
||||
|
||||
10. If you wish to incorporate parts of the Program into other free
|
||||
programs whose distribution conditions are different, write to the author
|
||||
to ask for permission. For software which is copyrighted by the Free
|
||||
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||
make exceptions for this. Our decision will be guided by the two goals
|
||||
of preserving the free status of all derivatives of our free software and
|
||||
of promoting the sharing and reuse of software generally.
|
||||
|
||||
NO WARRANTY
|
||||
|
||||
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||
REPAIR OR CORRECTION.
|
||||
|
||||
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||
POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
How to Apply These Terms to Your New Programs
|
||||
|
||||
If you develop a new program, and you want it to be of the greatest
|
||||
possible use to the public, the best way to achieve this is to make it
|
||||
free software which everyone can redistribute and change under these terms.
|
||||
|
||||
To do so, attach the following notices to the program. It is safest
|
||||
to attach them to the start of each source file to most effectively
|
||||
convey the exclusion of warranty; and each file should have at least
|
||||
the "copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
Copyright (C) <year> <name of author>
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License along
|
||||
with this program; if not, write to the Free Software Foundation, Inc.,
|
||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If the program is interactive, make it output a short notice like this
|
||||
when it starts in an interactive mode:
|
||||
|
||||
Gnomovision version 69, Copyright (C) year name of author
|
||||
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||
This is free software, and you are welcome to redistribute it
|
||||
under certain conditions; type `show c' for details.
|
||||
|
||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||
parts of the General Public License. Of course, the commands you use may
|
||||
be called something other than `show w' and `show c'; they could even be
|
||||
mouse-clicks or menu items--whatever suits your program.
|
||||
|
||||
You should also get your employer (if you work as a programmer) or your
|
||||
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||
necessary. Here is a sample; alter the names:
|
||||
|
||||
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
||||
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
||||
|
||||
<signature of Ty Coon>, 1 April 1989
|
||||
Ty Coon, President of Vice
|
||||
|
||||
This General Public License does not permit incorporating your program into
|
||||
proprietary programs. If your program is a subroutine library, you may
|
||||
consider it more useful to permit linking proprietary applications with the
|
||||
library. If this is what you want to do, use the GNU Lesser General
|
||||
Public License instead of this License.
|
||||
@ -1,93 +0,0 @@
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* General page setup
|
||||
*/
|
||||
#dt_example {
|
||||
font: 80%/1.45em "Lucida Grande", Verdana, Arial, Helvetica, sans-serif;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
color: #333;
|
||||
background-color: #fff;
|
||||
}
|
||||
|
||||
|
||||
#dt_example #container {
|
||||
width: 800px;
|
||||
margin: 30px auto;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
|
||||
#dt_example #footer {
|
||||
margin: 50px auto 0 auto;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
#dt_example #demo {
|
||||
margin: 30px auto 0 auto;
|
||||
}
|
||||
|
||||
#dt_example .demo_jui {
|
||||
margin: 30px auto 0 auto;
|
||||
}
|
||||
|
||||
#dt_example .big {
|
||||
font-size: 1.3em;
|
||||
font-weight: bold;
|
||||
line-height: 1.6em;
|
||||
color: #4E6CA3;
|
||||
}
|
||||
|
||||
#dt_example .spacer {
|
||||
height: 20px;
|
||||
clear: both;
|
||||
}
|
||||
|
||||
#dt_example .clear {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
#dt_example pre {
|
||||
padding: 15px;
|
||||
background-color: #F5F5F5;
|
||||
border: 1px solid #CCCCCC;
|
||||
}
|
||||
|
||||
#dt_example h1 {
|
||||
margin-top: 2em;
|
||||
font-size: 1.3em;
|
||||
font-weight: normal;
|
||||
line-height: 1.6em;
|
||||
color: #4E6CA3;
|
||||
border-bottom: 1px solid #B0BED9;
|
||||
clear: both;
|
||||
}
|
||||
|
||||
#dt_example h2 {
|
||||
font-size: 1.2em;
|
||||
font-weight: normal;
|
||||
line-height: 1.6em;
|
||||
color: #4E6CA3;
|
||||
clear: both;
|
||||
}
|
||||
|
||||
#dt_example a {
|
||||
color: #0063DC;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
#dt_example a:hover {
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
#dt_example ul {
|
||||
color: #4E6CA3;
|
||||
}
|
||||
|
||||
.css_right {
|
||||
float: right;
|
||||
}
|
||||
|
||||
.css_left {
|
||||
float: left;
|
||||
}
|
||||
@ -1,538 +0,0 @@
|
||||
/*
|
||||
* File: demo_table.css
|
||||
* CVS: $Id$
|
||||
* Description: CSS descriptions for DataTables demo pages
|
||||
* Author: Allan Jardine
|
||||
* Created: Tue May 12 06:47:22 BST 2009
|
||||
* Modified: $Date$ by $Author$
|
||||
* Language: CSS
|
||||
* Project: DataTables
|
||||
*
|
||||
* Copyright 2009 Allan Jardine. All Rights Reserved.
|
||||
*
|
||||
* ***************************************************************************
|
||||
* DESCRIPTION
|
||||
*
|
||||
* The styles given here are suitable for the demos that are used with the standard DataTables
|
||||
* distribution (see www.datatables.net). You will most likely wish to modify these styles to
|
||||
* meet the layout requirements of your site.
|
||||
*
|
||||
* Common issues:
|
||||
* 'full_numbers' pagination - I use an extra selector on the body tag to ensure that there is
|
||||
* no conflict between the two pagination types. If you want to use full_numbers pagination
|
||||
* ensure that you either have "example_alt_pagination" as a body class name, or better yet,
|
||||
* modify that selector.
|
||||
* Note that the path used for Images is relative. All images are by default located in
|
||||
* ../images/ - relative to this CSS file.
|
||||
*/
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables features
|
||||
*/
|
||||
|
||||
.dataTables_wrapper {
|
||||
position: relative;
|
||||
min-height: 302px;
|
||||
clear: both;
|
||||
_height: 302px;
|
||||
zoom: 1; /* Feeling sorry for IE */
|
||||
}
|
||||
|
||||
.dataTables_processing {
|
||||
position: absolute;
|
||||
top: 50%;
|
||||
left: 50%;
|
||||
width: 250px;
|
||||
height: 30px;
|
||||
margin-left: -125px;
|
||||
margin-top: -15px;
|
||||
padding: 14px 0 2px 0;
|
||||
border: 1px solid #ddd;
|
||||
text-align: center;
|
||||
color: #999;
|
||||
font-size: 14px;
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
.dataTables_length {
|
||||
width: 40%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.dataTables_filter {
|
||||
width: 50%;
|
||||
float: right;
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
.dataTables_info {
|
||||
width: 60%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.dataTables_paginate {
|
||||
width: 44px;
|
||||
* width: 50px;
|
||||
float: right;
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
/* Pagination nested */
|
||||
.paginate_disabled_previous, .paginate_enabled_previous, .paginate_disabled_next, .paginate_enabled_next {
|
||||
height: 19px;
|
||||
width: 19px;
|
||||
margin-left: 3px;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.paginate_disabled_previous {
|
||||
background-image: url('../images/back_disabled.jpg');
|
||||
}
|
||||
|
||||
.paginate_enabled_previous {
|
||||
background-image: url('../images/back_enabled.jpg');
|
||||
}
|
||||
|
||||
.paginate_disabled_next {
|
||||
background-image: url('../images/forward_disabled.jpg');
|
||||
}
|
||||
|
||||
.paginate_enabled_next {
|
||||
background-image: url('../images/forward_enabled.jpg');
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables display
|
||||
*/
|
||||
table.display {
|
||||
margin: 0 auto;
|
||||
clear: both;
|
||||
width: 100%;
|
||||
|
||||
/* Note Firefox 3.5 and before have a bug with border-collapse
|
||||
* ( https://bugzilla.mozilla.org/show%5Fbug.cgi?id=155955 )
|
||||
* border-spacing: 0; is one possible option. Conditional-css.com is
|
||||
* useful for this kind of thing
|
||||
*
|
||||
* Further note IE 6/7 has problems when calculating widths with border width.
|
||||
* It subtracts one px relative to the other browsers from the first column, and
|
||||
* adds one to the end...
|
||||
*
|
||||
* If you want that effect I'd suggest setting a border-top/left on th/td's and
|
||||
* then filling in the gaps with other borders.
|
||||
*/
|
||||
}
|
||||
|
||||
table.display thead th {
|
||||
padding: 3px 18px 3px 10px;
|
||||
border-bottom: 1px solid black;
|
||||
font-weight: bold;
|
||||
cursor: pointer;
|
||||
* cursor: hand;
|
||||
}
|
||||
|
||||
table.display tfoot th {
|
||||
padding: 3px 18px 3px 10px;
|
||||
border-top: 1px solid black;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
table.display tr.heading2 td {
|
||||
border-bottom: 1px solid #aaa;
|
||||
}
|
||||
|
||||
table.display td {
|
||||
padding: 3px 10px;
|
||||
}
|
||||
|
||||
table.display td.center {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables sorting
|
||||
*/
|
||||
|
||||
.sorting_asc {
|
||||
background: url('../images/sort_asc.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting_desc {
|
||||
background: url('../images/sort_desc.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting {
|
||||
background: url('../images/sort_both.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting_asc_disabled {
|
||||
background: url('../images/sort_asc_disabled.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting_desc_disabled {
|
||||
background: url('../images/sort_desc_disabled.png') no-repeat center right;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables row classes
|
||||
*/
|
||||
table.display tr.odd.gradeA {
|
||||
background-color: #ddffdd;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeA {
|
||||
background-color: #eeffee;
|
||||
}
|
||||
|
||||
table.display tr.odd.gradeC {
|
||||
background-color: #ddddff;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeC {
|
||||
background-color: #eeeeff;
|
||||
}
|
||||
|
||||
table.display tr.odd.gradeX {
|
||||
background-color: #ffdddd;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeX {
|
||||
background-color: #ffeeee;
|
||||
}
|
||||
|
||||
table.display tr.odd.gradeU {
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeU {
|
||||
background-color: #eee;
|
||||
}
|
||||
|
||||
|
||||
tr.odd {
|
||||
background-color: #E2E4FF;
|
||||
}
|
||||
|
||||
tr.even {
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Misc
|
||||
*/
|
||||
.dataTables_scroll {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.dataTables_scrollBody {
|
||||
*margin-top: -1px;
|
||||
}
|
||||
|
||||
.top, .bottom {
|
||||
padding: 15px;
|
||||
background-color: #F5F5F5;
|
||||
border: 1px solid #CCCCCC;
|
||||
}
|
||||
|
||||
.top .dataTables_info {
|
||||
float: none;
|
||||
}
|
||||
|
||||
.clear {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.dataTables_empty {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
tfoot input {
|
||||
margin: 0.5em 0;
|
||||
width: 100%;
|
||||
color: #444;
|
||||
}
|
||||
|
||||
tfoot input.search_init {
|
||||
color: #999;
|
||||
}
|
||||
|
||||
td.group {
|
||||
background-color: #d1cfd0;
|
||||
border-bottom: 2px solid #A19B9E;
|
||||
border-top: 2px solid #A19B9E;
|
||||
}
|
||||
|
||||
td.details {
|
||||
background-color: #d1cfd0;
|
||||
border: 2px solid #A19B9E;
|
||||
}
|
||||
|
||||
|
||||
.example_alt_pagination div.dataTables_info {
|
||||
width: 40%;
|
||||
}
|
||||
|
||||
.paging_full_numbers {
|
||||
width: 400px;
|
||||
height: 22px;
|
||||
line-height: 22px;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_button,
|
||||
.paging_full_numbers span.paginate_active {
|
||||
border: 1px solid #aaa;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
padding: 2px 5px;
|
||||
margin: 0 3px;
|
||||
cursor: pointer;
|
||||
*cursor: hand;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_button {
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_button:hover {
|
||||
background-color: #ccc;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_active {
|
||||
background-color: #99B3FF;
|
||||
}
|
||||
|
||||
table.display tr.even.row_selected td {
|
||||
background-color: #B0BED9;
|
||||
}
|
||||
|
||||
table.display tr.odd.row_selected td {
|
||||
background-color: #9FAFD1;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Sorting classes for columns
|
||||
*/
|
||||
/* For the standard odd/even */
|
||||
tr.odd td.sorting_1 {
|
||||
background-color: #D3D6FF;
|
||||
}
|
||||
|
||||
tr.odd td.sorting_2 {
|
||||
background-color: #DADCFF;
|
||||
}
|
||||
|
||||
tr.odd td.sorting_3 {
|
||||
background-color: #E0E2FF;
|
||||
}
|
||||
|
||||
tr.even td.sorting_1 {
|
||||
background-color: #EAEBFF;
|
||||
}
|
||||
|
||||
tr.even td.sorting_2 {
|
||||
background-color: #F2F3FF;
|
||||
}
|
||||
|
||||
tr.even td.sorting_3 {
|
||||
background-color: #F9F9FF;
|
||||
}
|
||||
|
||||
|
||||
/* For the Conditional-CSS grading rows */
|
||||
/*
|
||||
Colour calculations (based off the main row colours)
|
||||
Level 1:
|
||||
dd > c4
|
||||
ee > d5
|
||||
Level 2:
|
||||
dd > d1
|
||||
ee > e2
|
||||
*/
|
||||
tr.odd.gradeA td.sorting_1 {
|
||||
background-color: #c4ffc4;
|
||||
}
|
||||
|
||||
tr.odd.gradeA td.sorting_2 {
|
||||
background-color: #d1ffd1;
|
||||
}
|
||||
|
||||
tr.odd.gradeA td.sorting_3 {
|
||||
background-color: #d1ffd1;
|
||||
}
|
||||
|
||||
tr.even.gradeA td.sorting_1 {
|
||||
background-color: #d5ffd5;
|
||||
}
|
||||
|
||||
tr.even.gradeA td.sorting_2 {
|
||||
background-color: #e2ffe2;
|
||||
}
|
||||
|
||||
tr.even.gradeA td.sorting_3 {
|
||||
background-color: #e2ffe2;
|
||||
}
|
||||
|
||||
tr.odd.gradeC td.sorting_1 {
|
||||
background-color: #c4c4ff;
|
||||
}
|
||||
|
||||
tr.odd.gradeC td.sorting_2 {
|
||||
background-color: #d1d1ff;
|
||||
}
|
||||
|
||||
tr.odd.gradeC td.sorting_3 {
|
||||
background-color: #d1d1ff;
|
||||
}
|
||||
|
||||
tr.even.gradeC td.sorting_1 {
|
||||
background-color: #d5d5ff;
|
||||
}
|
||||
|
||||
tr.even.gradeC td.sorting_2 {
|
||||
background-color: #e2e2ff;
|
||||
}
|
||||
|
||||
tr.even.gradeC td.sorting_3 {
|
||||
background-color: #e2e2ff;
|
||||
}
|
||||
|
||||
tr.odd.gradeX td.sorting_1 {
|
||||
background-color: #ffc4c4;
|
||||
}
|
||||
|
||||
tr.odd.gradeX td.sorting_2 {
|
||||
background-color: #ffd1d1;
|
||||
}
|
||||
|
||||
tr.odd.gradeX td.sorting_3 {
|
||||
background-color: #ffd1d1;
|
||||
}
|
||||
|
||||
tr.even.gradeX td.sorting_1 {
|
||||
background-color: #ffd5d5;
|
||||
}
|
||||
|
||||
tr.even.gradeX td.sorting_2 {
|
||||
background-color: #ffe2e2;
|
||||
}
|
||||
|
||||
tr.even.gradeX td.sorting_3 {
|
||||
background-color: #ffe2e2;
|
||||
}
|
||||
|
||||
tr.odd.gradeU td.sorting_1 {
|
||||
background-color: #c4c4c4;
|
||||
}
|
||||
|
||||
tr.odd.gradeU td.sorting_2 {
|
||||
background-color: #d1d1d1;
|
||||
}
|
||||
|
||||
tr.odd.gradeU td.sorting_3 {
|
||||
background-color: #d1d1d1;
|
||||
}
|
||||
|
||||
tr.even.gradeU td.sorting_1 {
|
||||
background-color: #d5d5d5;
|
||||
}
|
||||
|
||||
tr.even.gradeU td.sorting_2 {
|
||||
background-color: #e2e2e2;
|
||||
}
|
||||
|
||||
tr.even.gradeU td.sorting_3 {
|
||||
background-color: #e2e2e2;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Row highlighting example
|
||||
*/
|
||||
.ex_highlight #example tbody tr.even:hover, #example tbody tr.even td.highlighted {
|
||||
background-color: #ECFFB3;
|
||||
}
|
||||
|
||||
.ex_highlight #example tbody tr.odd:hover, #example tbody tr.odd td.highlighted {
|
||||
background-color: #E6FF99;
|
||||
}
|
||||
|
||||
.ex_highlight_row #example tr.even:hover {
|
||||
background-color: #ECFFB3;
|
||||
}
|
||||
|
||||
.ex_highlight_row #example tr.even:hover td.sorting_1 {
|
||||
background-color: #DDFF75;
|
||||
}
|
||||
|
||||
.ex_highlight_row #example tr.even:hover td.sorting_2 {
|
||||
background-color: #E7FF9E;
|
||||
}
|
||||
|
||||
.ex_highlight_row #example tr.even:hover td.sorting_3 {
|
||||
background-color: #E2FF89;
|
||||
}
|
||||
|
||||
.ex_highlight_row #example tr.odd:hover {
|
||||
background-color: #E6FF99;
|
||||
}
|
||||
|
||||
.ex_highlight_row #example tr.odd:hover td.sorting_1 {
|
||||
background-color: #D6FF5C;
|
||||
}
|
||||
|
||||
.ex_highlight_row #example tr.odd:hover td.sorting_2 {
|
||||
background-color: #E0FF84;
|
||||
}
|
||||
|
||||
.ex_highlight_row #example tr.odd:hover td.sorting_3 {
|
||||
background-color: #DBFF70;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* KeyTable
|
||||
*/
|
||||
table.KeyTable td {
|
||||
border: 3px solid transparent;
|
||||
}
|
||||
|
||||
table.KeyTable td.focus {
|
||||
border: 3px solid #3366FF;
|
||||
}
|
||||
|
||||
table.display tr.gradeA {
|
||||
background-color: #eeffee;
|
||||
}
|
||||
|
||||
table.display tr.gradeC {
|
||||
background-color: #ddddff;
|
||||
}
|
||||
|
||||
table.display tr.gradeX {
|
||||
background-color: #ffdddd;
|
||||
}
|
||||
|
||||
table.display tr.gradeU {
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
div.box {
|
||||
height: 100px;
|
||||
padding: 10px;
|
||||
overflow: auto;
|
||||
border: 1px solid #8080FF;
|
||||
background-color: #E5E5FF;
|
||||
}
|
||||
@ -1,521 +0,0 @@
|
||||
/*
|
||||
* File: demo_table_jui.css
|
||||
* CVS: $Id$
|
||||
* Description: CSS descriptions for DataTables demo pages
|
||||
* Author: Allan Jardine
|
||||
* Created: Tue May 12 06:47:22 BST 2009
|
||||
* Modified: $Date$ by $Author$
|
||||
* Language: CSS
|
||||
* Project: DataTables
|
||||
*
|
||||
* Copyright 2009 Allan Jardine. All Rights Reserved.
|
||||
*
|
||||
* ***************************************************************************
|
||||
* DESCRIPTION
|
||||
*
|
||||
* The styles given here are suitable for the demos that are used with the standard DataTables
|
||||
* distribution (see www.datatables.net). You will most likely wish to modify these styles to
|
||||
* meet the layout requirements of your site.
|
||||
*
|
||||
* Common issues:
|
||||
* 'full_numbers' pagination - I use an extra selector on the body tag to ensure that there is
|
||||
* no conflict between the two pagination types. If you want to use full_numbers pagination
|
||||
* ensure that you either have "example_alt_pagination" as a body class name, or better yet,
|
||||
* modify that selector.
|
||||
* Note that the path used for Images is relative. All images are by default located in
|
||||
* ../images/ - relative to this CSS file.
|
||||
*/
|
||||
|
||||
|
||||
/*
|
||||
* jQuery UI specific styling
|
||||
*/
|
||||
|
||||
.paging_two_button .ui-button {
|
||||
float: left;
|
||||
cursor: pointer;
|
||||
* cursor: hand;
|
||||
}
|
||||
|
||||
.paging_full_numbers .ui-button {
|
||||
padding: 2px 6px;
|
||||
margin: 0;
|
||||
cursor: pointer;
|
||||
* cursor: hand;
|
||||
}
|
||||
|
||||
.dataTables_paginate .ui-button {
|
||||
margin-right: -0.1em !important;
|
||||
}
|
||||
|
||||
.paging_full_numbers {
|
||||
width: 350px !important;
|
||||
}
|
||||
|
||||
.dataTables_wrapper .ui-toolbar {
|
||||
padding: 5px;
|
||||
}
|
||||
|
||||
.dataTables_paginate {
|
||||
width: auto;
|
||||
}
|
||||
|
||||
.dataTables_info {
|
||||
padding-top: 3px;
|
||||
}
|
||||
|
||||
table.display thead th {
|
||||
padding: 3px 0px 3px 10px;
|
||||
cursor: pointer;
|
||||
* cursor: hand;
|
||||
}
|
||||
|
||||
div.dataTables_wrapper .ui-widget-header {
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Sort arrow icon positioning
|
||||
*/
|
||||
table.display thead th div.DataTables_sort_wrapper {
|
||||
position: relative;
|
||||
padding-right: 20px;
|
||||
padding-right: 20px;
|
||||
}
|
||||
|
||||
table.display thead th div.DataTables_sort_wrapper span {
|
||||
position: absolute;
|
||||
top: 50%;
|
||||
margin-top: -8px;
|
||||
right: 0;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Everything below this line is the same as demo_table.css. This file is
|
||||
* required for 'cleanliness' of the markup
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables features
|
||||
*/
|
||||
|
||||
.dataTables_wrapper {
|
||||
position: relative;
|
||||
min-height: 302px;
|
||||
_height: 302px;
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.dataTables_processing {
|
||||
position: absolute;
|
||||
top: 0px;
|
||||
left: 50%;
|
||||
width: 250px;
|
||||
margin-left: -125px;
|
||||
border: 1px solid #ddd;
|
||||
text-align: center;
|
||||
color: #999;
|
||||
font-size: 11px;
|
||||
padding: 2px 0;
|
||||
}
|
||||
|
||||
.dataTables_length {
|
||||
width: 40%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.dataTables_filter {
|
||||
width: 50%;
|
||||
float: right;
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
.dataTables_info {
|
||||
width: 50%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.dataTables_paginate {
|
||||
float: right;
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
/* Pagination nested */
|
||||
.paginate_disabled_previous, .paginate_enabled_previous, .paginate_disabled_next, .paginate_enabled_next {
|
||||
height: 19px;
|
||||
width: 19px;
|
||||
margin-left: 3px;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.paginate_disabled_previous {
|
||||
background-image: url('../images/back_disabled.jpg');
|
||||
}
|
||||
|
||||
.paginate_enabled_previous {
|
||||
background-image: url('../images/back_enabled.jpg');
|
||||
}
|
||||
|
||||
.paginate_disabled_next {
|
||||
background-image: url('../images/forward_disabled.jpg');
|
||||
}
|
||||
|
||||
.paginate_enabled_next {
|
||||
background-image: url('../images/forward_enabled.jpg');
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables display
|
||||
*/
|
||||
table.display {
|
||||
margin: 0 auto;
|
||||
width: 100%;
|
||||
clear: both;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
table.display tfoot th {
|
||||
padding: 3px 0px 3px 10px;
|
||||
font-weight: bold;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
table.display tr.heading2 td {
|
||||
border-bottom: 1px solid #aaa;
|
||||
}
|
||||
|
||||
table.display td {
|
||||
padding: 3px 10px;
|
||||
}
|
||||
|
||||
table.display td.center {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables sorting
|
||||
*/
|
||||
|
||||
.sorting_asc {
|
||||
background: url('../images/sort_asc.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting_desc {
|
||||
background: url('../images/sort_desc.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting {
|
||||
background: url('../images/sort_both.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting_asc_disabled {
|
||||
background: url('../images/sort_asc_disabled.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting_desc_disabled {
|
||||
background: url('../images/sort_desc_disabled.png') no-repeat center right;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables row classes
|
||||
*/
|
||||
table.display tr.odd.gradeA {
|
||||
background-color: #ddffdd;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeA {
|
||||
background-color: #eeffee;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
table.display tr.odd.gradeA {
|
||||
background-color: #ddffdd;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeA {
|
||||
background-color: #eeffee;
|
||||
}
|
||||
|
||||
table.display tr.odd.gradeC {
|
||||
background-color: #ddddff;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeC {
|
||||
background-color: #eeeeff;
|
||||
}
|
||||
|
||||
table.display tr.odd.gradeX {
|
||||
background-color: #ffdddd;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeX {
|
||||
background-color: #ffeeee;
|
||||
}
|
||||
|
||||
table.display tr.odd.gradeU {
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeU {
|
||||
background-color: #eee;
|
||||
}
|
||||
|
||||
|
||||
tr.odd {
|
||||
background-color: #E2E4FF;
|
||||
}
|
||||
|
||||
tr.even {
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Misc
|
||||
*/
|
||||
.dataTables_scroll {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.top, .bottom {
|
||||
padding: 15px;
|
||||
background-color: #F5F5F5;
|
||||
border: 1px solid #CCCCCC;
|
||||
}
|
||||
|
||||
.top .dataTables_info {
|
||||
float: none;
|
||||
}
|
||||
|
||||
.clear {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.dataTables_empty {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
tfoot input {
|
||||
margin: 0.5em 0;
|
||||
width: 100%;
|
||||
color: #444;
|
||||
}
|
||||
|
||||
tfoot input.search_init {
|
||||
color: #999;
|
||||
}
|
||||
|
||||
td.group {
|
||||
background-color: #d1cfd0;
|
||||
border-bottom: 2px solid #A19B9E;
|
||||
border-top: 2px solid #A19B9E;
|
||||
}
|
||||
|
||||
td.details {
|
||||
background-color: #d1cfd0;
|
||||
border: 2px solid #A19B9E;
|
||||
}
|
||||
|
||||
|
||||
.example_alt_pagination div.dataTables_info {
|
||||
width: 40%;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_button,
|
||||
.paging_full_numbers span.paginate_active {
|
||||
border: 1px solid #aaa;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
padding: 2px 5px;
|
||||
margin: 0 3px;
|
||||
cursor: pointer;
|
||||
*cursor: hand;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_button {
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_button:hover {
|
||||
background-color: #ccc;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_active {
|
||||
background-color: #99B3FF;
|
||||
}
|
||||
|
||||
table.display tr.even.row_selected td {
|
||||
background-color: #B0BED9;
|
||||
}
|
||||
|
||||
table.display tr.odd.row_selected td {
|
||||
background-color: #9FAFD1;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Sorting classes for columns
|
||||
*/
|
||||
/* For the standard odd/even */
|
||||
tr.odd td.sorting_1 {
|
||||
background-color: #D3D6FF;
|
||||
}
|
||||
|
||||
tr.odd td.sorting_2 {
|
||||
background-color: #DADCFF;
|
||||
}
|
||||
|
||||
tr.odd td.sorting_3 {
|
||||
background-color: #E0E2FF;
|
||||
}
|
||||
|
||||
tr.even td.sorting_1 {
|
||||
background-color: #EAEBFF;
|
||||
}
|
||||
|
||||
tr.even td.sorting_2 {
|
||||
background-color: #F2F3FF;
|
||||
}
|
||||
|
||||
tr.even td.sorting_3 {
|
||||
background-color: #F9F9FF;
|
||||
}
|
||||
|
||||
|
||||
/* For the Conditional-CSS grading rows */
|
||||
/*
|
||||
Colour calculations (based off the main row colours)
|
||||
Level 1:
|
||||
dd > c4
|
||||
ee > d5
|
||||
Level 2:
|
||||
dd > d1
|
||||
ee > e2
|
||||
*/
|
||||
tr.odd.gradeA td.sorting_1 {
|
||||
background-color: #c4ffc4;
|
||||
}
|
||||
|
||||
tr.odd.gradeA td.sorting_2 {
|
||||
background-color: #d1ffd1;
|
||||
}
|
||||
|
||||
tr.odd.gradeA td.sorting_3 {
|
||||
background-color: #d1ffd1;
|
||||
}
|
||||
|
||||
tr.even.gradeA td.sorting_1 {
|
||||
background-color: #d5ffd5;
|
||||
}
|
||||
|
||||
tr.even.gradeA td.sorting_2 {
|
||||
background-color: #e2ffe2;
|
||||
}
|
||||
|
||||
tr.even.gradeA td.sorting_3 {
|
||||
background-color: #e2ffe2;
|
||||
}
|
||||
|
||||
tr.odd.gradeC td.sorting_1 {
|
||||
background-color: #c4c4ff;
|
||||
}
|
||||
|
||||
tr.odd.gradeC td.sorting_2 {
|
||||
background-color: #d1d1ff;
|
||||
}
|
||||
|
||||
tr.odd.gradeC td.sorting_3 {
|
||||
background-color: #d1d1ff;
|
||||
}
|
||||
|
||||
tr.even.gradeC td.sorting_1 {
|
||||
background-color: #d5d5ff;
|
||||
}
|
||||
|
||||
tr.even.gradeC td.sorting_2 {
|
||||
background-color: #e2e2ff;
|
||||
}
|
||||
|
||||
tr.even.gradeC td.sorting_3 {
|
||||
background-color: #e2e2ff;
|
||||
}
|
||||
|
||||
tr.odd.gradeX td.sorting_1 {
|
||||
background-color: #ffc4c4;
|
||||
}
|
||||
|
||||
tr.odd.gradeX td.sorting_2 {
|
||||
background-color: #ffd1d1;
|
||||
}
|
||||
|
||||
tr.odd.gradeX td.sorting_3 {
|
||||
background-color: #ffd1d1;
|
||||
}
|
||||
|
||||
tr.even.gradeX td.sorting_1 {
|
||||
background-color: #ffd5d5;
|
||||
}
|
||||
|
||||
tr.even.gradeX td.sorting_2 {
|
||||
background-color: #ffe2e2;
|
||||
}
|
||||
|
||||
tr.even.gradeX td.sorting_3 {
|
||||
background-color: #ffe2e2;
|
||||
}
|
||||
|
||||
tr.odd.gradeU td.sorting_1 {
|
||||
background-color: #c4c4c4;
|
||||
}
|
||||
|
||||
tr.odd.gradeU td.sorting_2 {
|
||||
background-color: #d1d1d1;
|
||||
}
|
||||
|
||||
tr.odd.gradeU td.sorting_3 {
|
||||
background-color: #d1d1d1;
|
||||
}
|
||||
|
||||
tr.even.gradeU td.sorting_1 {
|
||||
background-color: #d5d5d5;
|
||||
}
|
||||
|
||||
tr.even.gradeU td.sorting_2 {
|
||||
background-color: #e2e2e2;
|
||||
}
|
||||
|
||||
tr.even.gradeU td.sorting_3 {
|
||||
background-color: #e2e2e2;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Row highlighting example
|
||||
*/
|
||||
.ex_highlight #example tbody tr.even:hover, #example tbody tr.even td.highlighted {
|
||||
background-color: #ECFFB3;
|
||||
}
|
||||
|
||||
.ex_highlight #example tbody tr.odd:hover, #example tbody tr.odd td.highlighted {
|
||||
background-color: #E6FF99;
|
||||
}
|
||||
@ -1,415 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
"Contact Form to Database Extension" Copyright (C) 2011 Michael Simpson (email : michael.d.simpson@gmail.com)
|
||||
|
||||
This file is part of Contact Form to Database Extension.
|
||||
|
||||
Contact Form to Database Extension is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
Contact Form to Database Extension is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Contact Form to Database Extension.
|
||||
If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
require_once('CF7DBPlugin.php');
|
||||
require_once('CFDBQueryResultIterator.php');
|
||||
|
||||
class ExportBase {
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
var $defaultTableClass = 'cf7-db-table';
|
||||
|
||||
/**
|
||||
* @var array
|
||||
*/
|
||||
var $options;
|
||||
|
||||
/**
|
||||
* @var bool
|
||||
*/
|
||||
var $debug = false;
|
||||
|
||||
/**
|
||||
* @var array
|
||||
*/
|
||||
var $showColumns;
|
||||
|
||||
/**
|
||||
* @var array
|
||||
*/
|
||||
var $hideColumns;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
var $htmlTableId;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
var $htmlTableClass;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
var $style;
|
||||
|
||||
/**
|
||||
* @var CF7DBEvalutator|CF7FilterParser|CF7SearchEvaluator
|
||||
*/
|
||||
var $rowFilter;
|
||||
|
||||
/**
|
||||
* @var bool
|
||||
*/
|
||||
var $isFromShortCode = false;
|
||||
|
||||
/**
|
||||
* @var bool
|
||||
*/
|
||||
var $showSubmitField;
|
||||
|
||||
/**
|
||||
* @var CF7DBPlugin
|
||||
*/
|
||||
var $plugin;
|
||||
|
||||
/**
|
||||
* @var CFDBQueryResultIterator
|
||||
*/
|
||||
var $dataIterator;
|
||||
|
||||
function __construct() {
|
||||
$this->plugin = new CF7DBPlugin();
|
||||
}
|
||||
|
||||
/**
|
||||
* This method is the first thing to call after construction to set state for other methods to work
|
||||
* @param $options array|null
|
||||
* @return void
|
||||
*/
|
||||
protected function setOptions($options) {
|
||||
$this->options = $options;
|
||||
}
|
||||
|
||||
protected function setCommonOptions($htmlOptions = false) {
|
||||
|
||||
if ($this->options && is_array($this->options)) {
|
||||
if (isset($this->options['debug']) && $this->options['debug'] != 'false') {
|
||||
$this->debug = true;
|
||||
}
|
||||
|
||||
if (isset($this->options['showColumns'])) {
|
||||
$this->showColumns = $this->options['showColumns'];
|
||||
}
|
||||
else if (isset($this->options['show'])) {
|
||||
$this->showColumns = preg_split('/,/', $this->options['show'], -1, PREG_SPLIT_NO_EMPTY);
|
||||
}
|
||||
|
||||
if (isset($this->options['hideColumns'])) {
|
||||
$this->hideColumns = $this->options['hideColumns'];
|
||||
}
|
||||
else if (isset($this->options['hide'])) {
|
||||
$this->hideColumns = preg_split('/,/', $this->options['hide'], -1, PREG_SPLIT_NO_EMPTY);
|
||||
}
|
||||
|
||||
$this->isFromShortCode = isset($this->options['fromshortcode']) &&
|
||||
$this->options['fromshortcode'] === true;
|
||||
|
||||
if ($htmlOptions) {
|
||||
if (isset($this->options['class'])) {
|
||||
$this->htmlTableClass = $this->options['class'];
|
||||
}
|
||||
else {
|
||||
$this->htmlTableClass = $this->defaultTableClass;
|
||||
}
|
||||
|
||||
if (isset($this->options['id'])) {
|
||||
$this->htmlTableId = $this->options['id'];
|
||||
}
|
||||
else {
|
||||
$this->htmlTableId = 'cftble_' . rand();
|
||||
}
|
||||
|
||||
if (isset($this->options['style'])) {
|
||||
$this->style = $this->options['style'];
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (isset($this->options['filter'])) {
|
||||
require_once('CF7FilterParser.php');
|
||||
require_once('DereferenceShortcodeVars.php');
|
||||
$this->rowFilter = new CF7FilterParser;
|
||||
$this->rowFilter->setComparisonValuePreprocessor(new DereferenceShortcodeVars);
|
||||
$this->rowFilter->parseFilterString($this->options['filter']);
|
||||
if ($this->debug) {
|
||||
echo '<pre>';
|
||||
print_r($this->rowFilter->getFilterTree());
|
||||
echo '</pre>';
|
||||
}
|
||||
}
|
||||
else if (isset($this->options['search'])) {
|
||||
require_once('CF7SearchEvaluator.php');
|
||||
$this->rowFilter = new CF7SearchEvaluator;
|
||||
$this->rowFilter->setSearch($this->options['search']);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
protected function isAuthorized() {
|
||||
return $this->isFromShortCode ?
|
||||
$this->plugin->canUserDoRoleOption('CanSeeSubmitDataViaShortcode') :
|
||||
$this->plugin->canUserDoRoleOption('CanSeeSubmitData');
|
||||
}
|
||||
|
||||
protected function assertSecurityErrorMessage() {
|
||||
$errMsg = __('You do not have sufficient permissions to access this data.', 'contact-form-7-to-database-extension');
|
||||
if ($this->isFromShortCode) {
|
||||
echo $errMsg;
|
||||
}
|
||||
else {
|
||||
include_once('CFDBDie.php');
|
||||
CFDBDie::wp_die($errMsg);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param string|array|null $headers mixed string header-string or array of header strings.
|
||||
* E.g. Content-Type, Content-Disposition, etc.
|
||||
* @return void
|
||||
*/
|
||||
protected function echoHeaders($headers = null) {
|
||||
if (!headers_sent()) {
|
||||
header('Expires: 0');
|
||||
header('Cache-Control: no-store, no-cache, must-revalidate');
|
||||
// Hoping to keep the browser from timing out if connection from Google SS Live Data
|
||||
// script is calling this page to get information
|
||||
header("Keep-Alive: timeout=60"); // Not a standard HTTP header; browsers may disregard
|
||||
|
||||
if ($headers) {
|
||||
if (is_array($headers)) {
|
||||
foreach ($headers as $aheader) {
|
||||
header($aheader);
|
||||
}
|
||||
}
|
||||
else {
|
||||
header($headers);
|
||||
}
|
||||
}
|
||||
flush();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param $dataColumns array
|
||||
* @return array
|
||||
*/
|
||||
protected function &getColumnsToDisplay($dataColumns) {
|
||||
|
||||
//$dataColumns = array_merge(array('Submitted'), $dataColumns);
|
||||
$showCols = empty($this->showColumns) ? $dataColumns : $this->matchColumns($this->showColumns, $dataColumns);
|
||||
if (empty($this->hideColumns)) {
|
||||
return $showCols;
|
||||
}
|
||||
|
||||
$hideCols = $this->matchColumns($this->hideColumns, $dataColumns);
|
||||
if (empty($hideCols)) {
|
||||
return $showCols;
|
||||
}
|
||||
|
||||
$retCols = array();
|
||||
foreach ($showCols as $aShowCol) {
|
||||
if (!in_array($aShowCol, $hideCols)) {
|
||||
$retCols[] = $aShowCol;
|
||||
}
|
||||
}
|
||||
return $retCols;
|
||||
}
|
||||
|
||||
protected function matchColumns(&$patterns, &$subject) {
|
||||
$returnCols = array();
|
||||
foreach ($patterns as $pCol) {
|
||||
if (substr($pCol, 0, 1) == '/') {
|
||||
// Show column value is a REGEX
|
||||
foreach($subject as $sCol) {
|
||||
if (preg_match($pCol, $sCol) && !in_array($sCol, $returnCols)) {
|
||||
$returnCols[] = $sCol;
|
||||
}
|
||||
}
|
||||
}
|
||||
else {
|
||||
$returnCols[] = $pCol;
|
||||
}
|
||||
}
|
||||
return $returnCols;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return bool
|
||||
*/
|
||||
protected function getShowSubmitField() {
|
||||
$showSubmitField = true;
|
||||
if ($this->hideColumns != null && is_array($this->hideColumns) && in_array('Submitted', $this->hideColumns)) {
|
||||
$showSubmitField = false;
|
||||
}
|
||||
else if ($this->showColumns != null && is_array($this->showColumns)) {
|
||||
$showSubmitField = in_array('Submitted', $this->showColumns);
|
||||
}
|
||||
return $showSubmitField;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string|array of string $formName
|
||||
* @param null|string $submitTimeKeyName
|
||||
* @return void
|
||||
*/
|
||||
protected function setDataIterator($formName, $submitTimeKeyName = null) {
|
||||
$sql = $this->getPivotQuery($formName);
|
||||
$this->dataIterator = new CFDBQueryResultIterator();
|
||||
// $this->dataIterator->fileColumns = $this->getFileMetaData($formName);
|
||||
|
||||
$queryOptions = array();
|
||||
if ($submitTimeKeyName) {
|
||||
$queryOptions['submitTimeKeyName'] = $submitTimeKeyName;
|
||||
}
|
||||
if (!empty($this->rowFilter) && isset($this->options['limit'])) {
|
||||
// have data iterator apply the limit if it is not areadly
|
||||
// being applied in SQL directly, which we do where there are
|
||||
// no filter constraints.
|
||||
$queryOptions['limit'] = $this->options['limit'];
|
||||
}
|
||||
|
||||
$this->dataIterator->query($sql, $this->rowFilter, $queryOptions);
|
||||
$this->dataIterator->displayColumns = $this->getColumnsToDisplay($this->dataIterator->columns);
|
||||
}
|
||||
|
||||
// protected function &getFileMetaData($formName) {
|
||||
// global $wpdb;
|
||||
// $tableName = $this->plugin->getSubmitsTableName();
|
||||
// $rows = $wpdb->get_results(
|
||||
// "select distinct `field_name`
|
||||
//from `$tableName`
|
||||
//where `form_name` = '$formName'
|
||||
//and `file` is not null");
|
||||
//
|
||||
// $fileColumns = array();
|
||||
// foreach ($rows as $aRow) {
|
||||
// $files[] = $aRow->field_name;
|
||||
// }
|
||||
// return $fileColumns;
|
||||
// }
|
||||
|
||||
/**
|
||||
* @param string|array of string $formName
|
||||
* @param bool $count
|
||||
* @return string
|
||||
*/
|
||||
public function &getPivotQuery($formName, $count = false) {
|
||||
global $wpdb;
|
||||
$tableName = $this->plugin->getSubmitsTableName();
|
||||
|
||||
$formNameClause = '';
|
||||
if (is_array($formName)) {
|
||||
$formNameClause = 'WHERE `form_name` in ( \'' . implode('\', \'', $formName) . '\' )';
|
||||
}
|
||||
else if ($formName !== null) {
|
||||
$formNameClause = "WHERE `form_name` = '$formName'";
|
||||
}
|
||||
|
||||
$rows = $wpdb->get_results("SELECT DISTINCT `field_name`, `field_order` FROM `$tableName` $formNameClause ORDER BY field_order");
|
||||
$fields = array();
|
||||
foreach ($rows as $aRow) {
|
||||
if (!in_array($aRow->field_name, $fields)) {
|
||||
$fields[] = $aRow->field_name;
|
||||
}
|
||||
}
|
||||
$sql = '';
|
||||
if ($count) {
|
||||
$sql .= 'SELECT count(*) as count FROM (';
|
||||
}
|
||||
$sql .= "SELECT `submit_time` AS 'Submitted'";
|
||||
foreach ($fields as $aCol) {
|
||||
$sql .= ",\n max(if(`field_name`='$aCol', `field_value`, null )) AS '$aCol'";
|
||||
}
|
||||
if (!$count) {
|
||||
$sql .= ",\n GROUP_CONCAT(if(`file` is null or length(file) = 0, null, `field_name`)) AS fields_with_file";
|
||||
}
|
||||
$sql .= "\nFROM `$tableName` \n$formNameClause \nGROUP BY `submit_time` ";
|
||||
if ($count) {
|
||||
$sql .= ') form';
|
||||
}
|
||||
else {
|
||||
$orderBys = array();
|
||||
if ($this->options && isset($this->options['orderby'])) {
|
||||
$orderByStrings = explode(',', $this->options['orderby']);
|
||||
foreach ($orderByStrings as $anOrderBy) {
|
||||
$anOrderBy = trim($anOrderBy);
|
||||
$ascOrDesc = null;
|
||||
if (strtoupper(substr($anOrderBy, -5)) == ' DESC'){
|
||||
$ascOrDesc = " DESC";
|
||||
$anOrderBy = trim(substr($anOrderBy, 0, -5));
|
||||
}
|
||||
else if (strtoupper(substr($anOrderBy, -4)) == ' ASC'){
|
||||
$ascOrDesc = " ASC";
|
||||
$anOrderBy = trim(substr($anOrderBy, 0, -4));
|
||||
}
|
||||
if ($anOrderBy == 'Submitted') {
|
||||
$anOrderBy = "submit_time";
|
||||
}
|
||||
if (in_array($anOrderBy, $fields)) {
|
||||
$orderBys[] = '`' . $anOrderBy . '`' . $ascOrDesc;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (empty($orderBys)) {
|
||||
$sql .= "\nORDER BY `submit_time` DESC";
|
||||
}
|
||||
else {
|
||||
$sql .= "\nORDER BY ";
|
||||
$first = true;
|
||||
foreach ($orderBys as $anOrderBy) {
|
||||
if ($first) {
|
||||
$sql .= $anOrderBy;
|
||||
$first = false;
|
||||
}
|
||||
else {
|
||||
$sql .= ', ' . $anOrderBy;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (empty($this->rowFilter) && $this->options && isset($this->options['limit'])) {
|
||||
// If no filter constraints and have a limit, add limit to the SQL
|
||||
$sql .= "\nLIMIT " . $this->options['limit'];
|
||||
}
|
||||
}
|
||||
return $sql;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string|array of string $formName
|
||||
* @return int
|
||||
*/
|
||||
public function getDBRowCount($formName) {
|
||||
global $wpdb;
|
||||
$count = 0;
|
||||
$rows = $wpdb->get_results($this->getPivotQuery($formName, true));
|
||||
foreach ($rows as $aRow) {
|
||||
$count = $aRow->count;
|
||||
break;
|
||||
}
|
||||
return $count;
|
||||
}
|
||||
}
|
||||
@ -1,101 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
"Contact Form to Database Extension" Copyright (C) 2011 Michael Simpson (email : michael.d.simpson@gmail.com)
|
||||
|
||||
This file is part of Contact Form to Database Extension.
|
||||
|
||||
Contact Form to Database Extension is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
Contact Form to Database Extension is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Contact Form to Database Extension.
|
||||
If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
require_once('ExportBase.php');
|
||||
require_once('CFDBExport.php');
|
||||
|
||||
class ExportToCsvUtf8 extends ExportBase implements CFDBExport {
|
||||
|
||||
var $useBom = false;
|
||||
|
||||
public function setUseBom($use) {
|
||||
$this->useBom = $use;
|
||||
}
|
||||
|
||||
public function export($formName, $options = null) {
|
||||
$this->setOptions($options);
|
||||
$this->setCommonOptions();
|
||||
|
||||
// Security Check
|
||||
if (!$this->isAuthorized()) {
|
||||
$this->assertSecurityErrorMessage();
|
||||
return;
|
||||
}
|
||||
|
||||
if ($this->options && is_array($this->options)) {
|
||||
if (isset($this->options['bom'])) {
|
||||
$this->useBom = $this->options['bom'] == 'true';
|
||||
}
|
||||
}
|
||||
|
||||
// Headers
|
||||
$this->echoHeaders(
|
||||
array('Content-Type: text/html; charset=UTF-8',
|
||||
"Content-Disposition: attachment; filename=\"$formName.csv\""));
|
||||
|
||||
$this->echoCsv($formName);
|
||||
}
|
||||
|
||||
public function echoCsv($formName) {
|
||||
if ($this->useBom) {
|
||||
// File encoding UTF-8 Byte Order Mark (BOM) http://wiki.sdn.sap.com/wiki/display/ABAP/Excel+files+-+CSV+format
|
||||
echo chr(239) . chr(187) . chr(191);
|
||||
}
|
||||
|
||||
$eol = "\n";
|
||||
|
||||
// Query DB for the data for that form
|
||||
$submitTimeKeyName = 'Submit_Time_Key';
|
||||
$this->setDataIterator($formName, $submitTimeKeyName);
|
||||
|
||||
|
||||
// Column Headers
|
||||
foreach ($this->dataIterator->displayColumns as $aCol) {
|
||||
printf('"%s",', str_replace('"', '""', $aCol));
|
||||
}
|
||||
echo $eol;
|
||||
|
||||
|
||||
// Rows
|
||||
$showFileUrlsInExport = $this->plugin->getOption('ShowFileUrlsInExport') == 'true';
|
||||
while ($this->dataIterator->nextRow()) {
|
||||
$fields_with_file = null;
|
||||
if ($showFileUrlsInExport &&
|
||||
isset($this->dataIterator->row['fields_with_file']) &&
|
||||
$this->dataIterator->row['fields_with_file'] != null) {
|
||||
$fields_with_file = explode(',', $this->dataIterator->row['fields_with_file']);
|
||||
}
|
||||
foreach ($this->dataIterator->displayColumns as $aCol) {
|
||||
$cell = isset($this->dataIterator->row[$aCol]) ? $this->dataIterator->row[$aCol] : '';
|
||||
if ($showFileUrlsInExport &&
|
||||
$fields_with_file &&
|
||||
$cell &&
|
||||
in_array($aCol, $fields_with_file)) {
|
||||
$cell = $this->plugin->getFileUrl($this->dataIterator->row[$submitTimeKeyName], $formName, $aCol);
|
||||
}
|
||||
printf('"%s",', str_replace('"', '""', $cell));
|
||||
}
|
||||
echo $eol;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
@ -1,175 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
"Contact Form to Database Extension" Copyright (C) 2011 Michael Simpson (email : michael.d.simpson@gmail.com)
|
||||
|
||||
This file is part of Contact Form to Database Extension.
|
||||
|
||||
Contact Form to Database Extension is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
Contact Form to Database Extension is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Contact Form to Database Extension.
|
||||
If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
require_once('ExportBase.php');
|
||||
require_once('CFDBExport.php');
|
||||
|
||||
class ExportToJson extends ExportBase implements CFDBExport {
|
||||
|
||||
public function export($formName, $options = null) {
|
||||
$this->setOptions($options);
|
||||
$this->setCommonOptions();
|
||||
|
||||
$varName = 'cf7db';
|
||||
$html = false; // i.e. whether to create an HTML script tag and Javascript variable
|
||||
|
||||
if ($options && is_array($options)) {
|
||||
|
||||
if (isset($options['html'])) {
|
||||
$html = $options['html'];
|
||||
}
|
||||
|
||||
if (isset($options['var'])) {
|
||||
$varName = $options['var'];
|
||||
}
|
||||
}
|
||||
|
||||
// Security Check
|
||||
if (!$this->isAuthorized()) {
|
||||
$this->assertSecurityErrorMessage();
|
||||
return;
|
||||
}
|
||||
|
||||
// Headers
|
||||
$contentType = $html ? 'Content-Type: text/html; charset=UTF-8' : 'Content-Type: application/json; charset=UTF-8';
|
||||
$this->echoHeaders($contentType);
|
||||
|
||||
// Get the data
|
||||
$this->setDataIterator($formName);
|
||||
|
||||
if ($this->isFromShortCode) {
|
||||
ob_start();
|
||||
}
|
||||
|
||||
if ($html) {
|
||||
?>
|
||||
<script type="text/javascript" language="JavaScript">
|
||||
<!--
|
||||
var <?php echo $varName; ?> = <?php $this->echoJsonEncode(); ?>;
|
||||
//-->
|
||||
</script>
|
||||
<?php
|
||||
|
||||
}
|
||||
else {
|
||||
echo $this->echoJsonEncode();
|
||||
}
|
||||
|
||||
if ($this->isFromShortCode) {
|
||||
// If called from a shortcode, need to return the text,
|
||||
// otherwise it can appear out of order on the page
|
||||
$output = ob_get_contents();
|
||||
ob_end_clean();
|
||||
return $output;
|
||||
}
|
||||
}
|
||||
|
||||
protected function echoJsonEncode() {
|
||||
$format = 'map';
|
||||
if ($this->options && isset($this->options['format'])) {
|
||||
if ($this->options['format'] == 'array' || $this->options['format'] == 'arraynoheader') {
|
||||
$format = $this->options['format'];
|
||||
}
|
||||
}
|
||||
|
||||
// Avoid use of json_encode() so we don't have to buffer all the data
|
||||
$search = array('"', "\n"); // Things we need to escape in JSON
|
||||
$replace = array('\"', '\\n');
|
||||
|
||||
if ($format == 'map') {
|
||||
|
||||
// Create the column name JSON values only once
|
||||
$jsonEscapedColumns = array();
|
||||
foreach ($this->dataIterator->displayColumns as $col) {
|
||||
$jsonEscapedColumns[$col] = str_replace($search, $replace, $col);
|
||||
}
|
||||
|
||||
echo "[\n";
|
||||
$firstRow = true;
|
||||
while ($this->dataIterator->nextRow()) {
|
||||
if ($firstRow) {
|
||||
$firstRow = false;
|
||||
}
|
||||
else {
|
||||
echo ",\n";
|
||||
}
|
||||
echo '{';
|
||||
$firstCol = true;
|
||||
foreach ($this->dataIterator->displayColumns as $col) {
|
||||
if ($firstCol) {
|
||||
$firstCol = false;
|
||||
}
|
||||
else {
|
||||
echo ',';
|
||||
}
|
||||
printf('"%s":"%s"',
|
||||
$jsonEscapedColumns[$col],
|
||||
str_replace($search, $replace, $this->dataIterator->row[$col]));
|
||||
}
|
||||
echo '}';
|
||||
}
|
||||
echo "\n]";
|
||||
}
|
||||
else { // 'array' || 'arraynoheader'
|
||||
echo "[\n";
|
||||
$firstRow = true;
|
||||
if ($format == 'array') {
|
||||
// Add header
|
||||
$firstCol = true;
|
||||
echo '[';
|
||||
foreach ($this->dataIterator->displayColumns as $col) {
|
||||
if ($firstCol) {
|
||||
$firstCol = false;
|
||||
}
|
||||
else {
|
||||
echo ',';
|
||||
}
|
||||
printf('"%s"', str_replace($search, $replace, $col));
|
||||
}
|
||||
echo ']';
|
||||
$firstRow = false;
|
||||
}
|
||||
// Export data rows
|
||||
while ($this->dataIterator->nextRow()) {
|
||||
if ($firstRow) {
|
||||
$firstRow = false;
|
||||
}
|
||||
else {
|
||||
echo ",\n";
|
||||
}
|
||||
$firstCol = true;
|
||||
echo '[';
|
||||
foreach ($this->dataIterator->displayColumns as $col) {
|
||||
if ($firstCol) {
|
||||
$firstCol = false;
|
||||
}
|
||||
else {
|
||||
echo ',';
|
||||
}
|
||||
printf('"%s"', str_replace($search, $replace, $this->dataIterator->row[$col]));
|
||||
}
|
||||
echo "]";
|
||||
}
|
||||
echo "\n]";
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@ -1,70 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
Plugin Name: Contact Form to DB Extension
|
||||
Plugin URI: http://wordpress.org/extend/plugins/contact-form-7-to-database-extension/
|
||||
Version: 1.8.7
|
||||
Author: Michael Simpson
|
||||
Description: Captures form submissions from Contact Form 7 and Fast Secure Contact Form plugins and writes the form data to the database | <a href="admin.php?page=CF7DBPluginSubmissions">Data</a> | <a href="admin.php?page=CF7DBPluginSettings">Settings</a> | <a href="http://wordpress.org/extend/plugins/contact-form-7-to-database-extension/faq/">FAQ</a>
|
||||
Text Domain: contact-form-7-to-database-extension
|
||||
License: GPL3
|
||||
*/
|
||||
|
||||
/**
|
||||
* Check the PHP version and give a useful error message if the user's version is less than the required version
|
||||
* @return boolean true if version check passed. If false, triggers an error which WP will handle, by displaying
|
||||
* an error message on the Admin page
|
||||
*/
|
||||
function CF7DBPlugin_PhpVersionCheck() {
|
||||
$minimalRequiredPhpVersion = '5.0';
|
||||
if (version_compare(phpversion(), $minimalRequiredPhpVersion) < 0) {
|
||||
trigger_error(
|
||||
'<p>' . __('Error: Contact Form to DB Plugin requires a newer version of PHP to be running.', 'contact-form-7-to-database-extension') . '</p>' .
|
||||
'<ul>' .
|
||||
'<li>' . __('Minimal version of PHP required: ', 'contact-form-7-to-database-extension') . '<strong>' . $minimalRequiredPhpVersion . '</strong></li>' .
|
||||
'<li>' . __('Your server\'s PHP version: ', 'contact-form-7-to-database-extension') . '<strong>' . phpversion() . '</strong></li>' .
|
||||
'</ul>' .
|
||||
|
||||
'<p>' . __('When using the Apache web server, typically you can configure it to use PHP5 by doing the following:', 'contact-form-7-to-database-extension') .
|
||||
'<ul>' .
|
||||
'<li>' . __('Locate and edit this file, located at the top directory of your WordPress installation: ', 'contact-form-7-to-database-extension') .
|
||||
'<strong><code>.htaccess</code></strong></li>' .
|
||||
'<li>' . __('Add these two lines to the file:', 'contact-form-7-to-database-extension') .
|
||||
'<br/><code><pre>
|
||||
AddType x-mapp-php5 .php
|
||||
AddHandler x-mapp-php5 .php
|
||||
</pre></code></ul>'
|
||||
, E_USER_ERROR); // E_USER_ERROR seems to be handled OK in WP. It gives a notice in the Plugins Page
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Initialize internationalization (i18n) for this plugin.
|
||||
* References:
|
||||
* http://codex.wordpress.org/I18n_for_WordPress_Developers
|
||||
* http://www.wdmac.com/how-to-create-a-po-language-translation#more-631
|
||||
* @return void
|
||||
*/
|
||||
function CF7DBPlugin_i18n_init() {
|
||||
$pluginDir = dirname(plugin_basename(__FILE__));
|
||||
load_plugin_textdomain('contact-form-7-to-database-extension', false, $pluginDir . '/languages/');
|
||||
}
|
||||
|
||||
|
||||
//////////////////////////////////
|
||||
// Run initialization
|
||||
/////////////////////////////////
|
||||
|
||||
// First initialize i18n
|
||||
CF7DBPlugin_i18n_init();
|
||||
|
||||
|
||||
// Next, run the version check.
|
||||
// If it is successful, continue with initialization for this plugin
|
||||
if (CF7DBPlugin_PhpVersionCheck()) {
|
||||
// Only load and run the init function if we know PHP version can parse it
|
||||
include_once('CF7DBPlugin_init.php');
|
||||
CF7DBPlugin_init(__FILE__);
|
||||
}
|
||||
@ -1,33 +0,0 @@
|
||||
div.cfdb_paginate {
|
||||
padding: 3px;
|
||||
margin: 3px;
|
||||
}
|
||||
|
||||
div.cfdb_paginate a {
|
||||
padding: 2px 5px 2px 5px;
|
||||
margin: 2px;
|
||||
border: 1px solid #AAAADD;
|
||||
text-decoration: none; /* no underline */
|
||||
color: #000099;
|
||||
}
|
||||
|
||||
div.cfdb_paginate a:hover, div.cfdb_paginate a:active {
|
||||
border: 1px solid #000099;
|
||||
color: #000;
|
||||
}
|
||||
|
||||
div.cfdb_paginate span.current {
|
||||
padding: 2px 5px 2px 5px;
|
||||
margin: 2px;
|
||||
border: 1px solid #000099;
|
||||
font-weight: bold;
|
||||
background-color: #000099;
|
||||
color: #FFF;
|
||||
}
|
||||
|
||||
div.cfdb_paginate span.disabled {
|
||||
padding: 2px 5px 2px 5px;
|
||||
margin: 2px;
|
||||
border: 1px solid #EEE;
|
||||
color: #DDD;
|
||||
}
|
||||
@ -1,221 +0,0 @@
|
||||
// Taken from: http://www.teslacore.it/sssup1/destest.html
|
||||
|
||||
//Paul Tero, July 2001
|
||||
//http://www.shopable.co.uk/des.html
|
||||
//
|
||||
//Optimised for performance with large blocks by Michael Hayworth, November 2001
|
||||
//http://www.netdealing.com
|
||||
//
|
||||
//THIS SOFTWARE IS PROVIDED "AS IS" AND
|
||||
//ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
//IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
//ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
//FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
//DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
//OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
//HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
//LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
//OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
//SUCH DAMAGE.
|
||||
|
||||
//des
|
||||
//this takes the key, the message, and whether to encrypt or decrypt
|
||||
function des (key, message, encrypt, mode, iv) {
|
||||
//declaring this locally speeds things up a bit
|
||||
var spfunction1 = new Array (0x1010400,0,0x10000,0x1010404,0x1010004,0x10404,0x4,0x10000,0x400,0x1010400,0x1010404,0x400,0x1000404,0x1010004,0x1000000,0x4,0x404,0x1000400,0x1000400,0x10400,0x10400,0x1010000,0x1010000,0x1000404,0x10004,0x1000004,0x1000004,0x10004,0,0x404,0x10404,0x1000000,0x10000,0x1010404,0x4,0x1010000,0x1010400,0x1000000,0x1000000,0x400,0x1010004,0x10000,0x10400,0x1000004,0x400,0x4,0x1000404,0x10404,0x1010404,0x10004,0x1010000,0x1000404,0x1000004,0x404,0x10404,0x1010400,0x404,0x1000400,0x1000400,0,0x10004,0x10400,0,0x1010004);
|
||||
var spfunction2 = new Array (0x80108020,0x80008000,0x8000,0x108020,0x100000,0x20,0x80100020,0x80008020,0x80000020,0x80108020,0x80108000,0x80000000,0x80008000,0x100000,0x20,0x80100020,0x108000,0x100020,0x80008020,0,0x80000000,0x8000,0x108020,0x80100000,0x100020,0x80000020,0,0x108000,0x8020,0x80108000,0x80100000,0x8020,0,0x108020,0x80100020,0x100000,0x80008020,0x80100000,0x80108000,0x8000,0x80100000,0x80008000,0x20,0x80108020,0x108020,0x20,0x8000,0x80000000,0x8020,0x80108000,0x100000,0x80000020,0x100020,0x80008020,0x80000020,0x100020,0x108000,0,0x80008000,0x8020,0x80000000,0x80100020,0x80108020,0x108000);
|
||||
var spfunction3 = new Array (0x208,0x8020200,0,0x8020008,0x8000200,0,0x20208,0x8000200,0x20008,0x8000008,0x8000008,0x20000,0x8020208,0x20008,0x8020000,0x208,0x8000000,0x8,0x8020200,0x200,0x20200,0x8020000,0x8020008,0x20208,0x8000208,0x20200,0x20000,0x8000208,0x8,0x8020208,0x200,0x8000000,0x8020200,0x8000000,0x20008,0x208,0x20000,0x8020200,0x8000200,0,0x200,0x20008,0x8020208,0x8000200,0x8000008,0x200,0,0x8020008,0x8000208,0x20000,0x8000000,0x8020208,0x8,0x20208,0x20200,0x8000008,0x8020000,0x8000208,0x208,0x8020000,0x20208,0x8,0x8020008,0x20200);
|
||||
var spfunction4 = new Array (0x802001,0x2081,0x2081,0x80,0x802080,0x800081,0x800001,0x2001,0,0x802000,0x802000,0x802081,0x81,0,0x800080,0x800001,0x1,0x2000,0x800000,0x802001,0x80,0x800000,0x2001,0x2080,0x800081,0x1,0x2080,0x800080,0x2000,0x802080,0x802081,0x81,0x800080,0x800001,0x802000,0x802081,0x81,0,0,0x802000,0x2080,0x800080,0x800081,0x1,0x802001,0x2081,0x2081,0x80,0x802081,0x81,0x1,0x2000,0x800001,0x2001,0x802080,0x800081,0x2001,0x2080,0x800000,0x802001,0x80,0x800000,0x2000,0x802080);
|
||||
var spfunction5 = new Array (0x100,0x2080100,0x2080000,0x42000100,0x80000,0x100,0x40000000,0x2080000,0x40080100,0x80000,0x2000100,0x40080100,0x42000100,0x42080000,0x80100,0x40000000,0x2000000,0x40080000,0x40080000,0,0x40000100,0x42080100,0x42080100,0x2000100,0x42080000,0x40000100,0,0x42000000,0x2080100,0x2000000,0x42000000,0x80100,0x80000,0x42000100,0x100,0x2000000,0x40000000,0x2080000,0x42000100,0x40080100,0x2000100,0x40000000,0x42080000,0x2080100,0x40080100,0x100,0x2000000,0x42080000,0x42080100,0x80100,0x42000000,0x42080100,0x2080000,0,0x40080000,0x42000000,0x80100,0x2000100,0x40000100,0x80000,0,0x40080000,0x2080100,0x40000100);
|
||||
var spfunction6 = new Array (0x20000010,0x20400000,0x4000,0x20404010,0x20400000,0x10,0x20404010,0x400000,0x20004000,0x404010,0x400000,0x20000010,0x400010,0x20004000,0x20000000,0x4010,0,0x400010,0x20004010,0x4000,0x404000,0x20004010,0x10,0x20400010,0x20400010,0,0x404010,0x20404000,0x4010,0x404000,0x20404000,0x20000000,0x20004000,0x10,0x20400010,0x404000,0x20404010,0x400000,0x4010,0x20000010,0x400000,0x20004000,0x20000000,0x4010,0x20000010,0x20404010,0x404000,0x20400000,0x404010,0x20404000,0,0x20400010,0x10,0x4000,0x20400000,0x404010,0x4000,0x400010,0x20004010,0,0x20404000,0x20000000,0x400010,0x20004010);
|
||||
var spfunction7 = new Array (0x200000,0x4200002,0x4000802,0,0x800,0x4000802,0x200802,0x4200800,0x4200802,0x200000,0,0x4000002,0x2,0x4000000,0x4200002,0x802,0x4000800,0x200802,0x200002,0x4000800,0x4000002,0x4200000,0x4200800,0x200002,0x4200000,0x800,0x802,0x4200802,0x200800,0x2,0x4000000,0x200800,0x4000000,0x200800,0x200000,0x4000802,0x4000802,0x4200002,0x4200002,0x2,0x200002,0x4000000,0x4000800,0x200000,0x4200800,0x802,0x200802,0x4200800,0x802,0x4000002,0x4200802,0x4200000,0x200800,0,0x2,0x4200802,0,0x200802,0x4200000,0x800,0x4000002,0x4000800,0x800,0x200002);
|
||||
var spfunction8 = new Array (0x10001040,0x1000,0x40000,0x10041040,0x10000000,0x10001040,0x40,0x10000000,0x40040,0x10040000,0x10041040,0x41000,0x10041000,0x41040,0x1000,0x40,0x10040000,0x10000040,0x10001000,0x1040,0x41000,0x40040,0x10040040,0x10041000,0x1040,0,0,0x10040040,0x10000040,0x10001000,0x41040,0x40000,0x41040,0x40000,0x10041000,0x1000,0x40,0x10040040,0x1000,0x41040,0x10001000,0x40,0x10000040,0x10040000,0x10040040,0x10000000,0x40000,0x10001040,0,0x10041040,0x40040,0x10000040,0x10040000,0x10001000,0x10001040,0,0x10041040,0x41000,0x41000,0x1040,0x1040,0x40040,0x10000000,0x10041000);
|
||||
|
||||
//create the 16 or 48 subkeys we will need
|
||||
var keys = des_createKeys (key);
|
||||
var m=0, i, j, temp, temp2, right1, right2, left, right, looping;
|
||||
var cbcleft, cbcleft2, cbcright, cbcright2
|
||||
var endloop, loopinc;
|
||||
var len = message.length;
|
||||
var chunk = 0;
|
||||
//set up the loops for single and triple des
|
||||
var iterations = keys.length == 32 ? 3 : 9; //single or triple des
|
||||
if (iterations == 3) {looping = encrypt ? new Array (0, 32, 2) : new Array (30, -2, -2);}
|
||||
else {looping = encrypt ? new Array (0, 32, 2, 62, 30, -2, 64, 96, 2) : new Array (94, 62, -2, 32, 64, 2, 30, -2, -2);}
|
||||
|
||||
message += "\0\0\0\0\0\0\0\0"; //pad the message out with null bytes
|
||||
//store the result here
|
||||
result = "";
|
||||
tempresult = "";
|
||||
|
||||
if (mode == 1) { //CBC mode
|
||||
cbcleft = (iv.charCodeAt(m++) << 24) | (iv.charCodeAt(m++) << 16) | (iv.charCodeAt(m++) << 8) | iv.charCodeAt(m++);
|
||||
cbcright = (iv.charCodeAt(m++) << 24) | (iv.charCodeAt(m++) << 16) | (iv.charCodeAt(m++) << 8) | iv.charCodeAt(m++);
|
||||
m=0;
|
||||
}
|
||||
|
||||
//loop through each 64 bit chunk of the message
|
||||
while (m < len) {
|
||||
left = (message.charCodeAt(m++) << 24) | (message.charCodeAt(m++) << 16) | (message.charCodeAt(m++) << 8) | message.charCodeAt(m++);
|
||||
right = (message.charCodeAt(m++) << 24) | (message.charCodeAt(m++) << 16) | (message.charCodeAt(m++) << 8) | message.charCodeAt(m++);
|
||||
|
||||
//for Cipher Block Chaining mode, xor the message with the previous result
|
||||
if (mode == 1) {if (encrypt) {left ^= cbcleft; right ^= cbcright;} else {cbcleft2 = cbcleft; cbcright2 = cbcright; cbcleft = left; cbcright = right;}}
|
||||
|
||||
//first each 64 but chunk of the message must be permuted according to IP
|
||||
temp = ((left >>> 4) ^ right) & 0x0f0f0f0f; right ^= temp; left ^= (temp << 4);
|
||||
temp = ((left >>> 16) ^ right) & 0x0000ffff; right ^= temp; left ^= (temp << 16);
|
||||
temp = ((right >>> 2) ^ left) & 0x33333333; left ^= temp; right ^= (temp << 2);
|
||||
temp = ((right >>> 8) ^ left) & 0x00ff00ff; left ^= temp; right ^= (temp << 8);
|
||||
temp = ((left >>> 1) ^ right) & 0x55555555; right ^= temp; left ^= (temp << 1);
|
||||
|
||||
left = ((left << 1) | (left >>> 31));
|
||||
right = ((right << 1) | (right >>> 31));
|
||||
|
||||
//do this either 1 or 3 times for each chunk of the message
|
||||
for (j=0; j<iterations; j+=3) {
|
||||
endloop = looping[j+1];
|
||||
loopinc = looping[j+2];
|
||||
//now go through and perform the encryption or decryption
|
||||
for (i=looping[j]; i!=endloop; i+=loopinc) { //for efficiency
|
||||
right1 = right ^ keys[i];
|
||||
right2 = ((right >>> 4) | (right << 28)) ^ keys[i+1];
|
||||
//the result is attained by passing these bytes through the S selection functions
|
||||
temp = left;
|
||||
left = right;
|
||||
right = temp ^ (spfunction2[(right1 >>> 24) & 0x3f] | spfunction4[(right1 >>> 16) & 0x3f]
|
||||
| spfunction6[(right1 >>> 8) & 0x3f] | spfunction8[right1 & 0x3f]
|
||||
| spfunction1[(right2 >>> 24) & 0x3f] | spfunction3[(right2 >>> 16) & 0x3f]
|
||||
| spfunction5[(right2 >>> 8) & 0x3f] | spfunction7[right2 & 0x3f]);
|
||||
}
|
||||
temp = left; left = right; right = temp; //unreverse left and right
|
||||
} //for either 1 or 3 iterations
|
||||
|
||||
//move then each one bit to the right
|
||||
left = ((left >>> 1) | (left << 31));
|
||||
right = ((right >>> 1) | (right << 31));
|
||||
|
||||
//now perform IP-1, which is IP in the opposite direction
|
||||
temp = ((left >>> 1) ^ right) & 0x55555555; right ^= temp; left ^= (temp << 1);
|
||||
temp = ((right >>> 8) ^ left) & 0x00ff00ff; left ^= temp; right ^= (temp << 8);
|
||||
temp = ((right >>> 2) ^ left) & 0x33333333; left ^= temp; right ^= (temp << 2);
|
||||
temp = ((left >>> 16) ^ right) & 0x0000ffff; right ^= temp; left ^= (temp << 16);
|
||||
temp = ((left >>> 4) ^ right) & 0x0f0f0f0f; right ^= temp; left ^= (temp << 4);
|
||||
|
||||
//for Cipher Block Chaining mode, xor the message with the previous result
|
||||
if (mode == 1) {if (encrypt) {cbcleft = left; cbcright = right;} else {left ^= cbcleft2; right ^= cbcright2;}}
|
||||
tempresult += String.fromCharCode ((left>>>24), ((left>>>16) & 0xff), ((left>>>8) & 0xff), (left & 0xff), (right>>>24), ((right>>>16) & 0xff), ((right>>>8) & 0xff), (right & 0xff));
|
||||
|
||||
chunk += 8;
|
||||
if (chunk == 512) {result += tempresult; tempresult = ""; chunk = 0;}
|
||||
} //for every 8 characters, or 64 bits in the message
|
||||
|
||||
//return the result as an array
|
||||
return result + tempresult;
|
||||
} //end of des
|
||||
|
||||
|
||||
|
||||
//des_createKeys
|
||||
//this takes as input a 64 bit key (even though only 56 bits are used)
|
||||
//as an array of 2 integers, and returns 16 48 bit keys
|
||||
function des_createKeys (key) {
|
||||
//declaring this locally speeds things up a bit
|
||||
pc2bytes0 = new Array (0,0x4,0x20000000,0x20000004,0x10000,0x10004,0x20010000,0x20010004,0x200,0x204,0x20000200,0x20000204,0x10200,0x10204,0x20010200,0x20010204);
|
||||
pc2bytes1 = new Array (0,0x1,0x100000,0x100001,0x4000000,0x4000001,0x4100000,0x4100001,0x100,0x101,0x100100,0x100101,0x4000100,0x4000101,0x4100100,0x4100101);
|
||||
pc2bytes2 = new Array (0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808,0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808);
|
||||
pc2bytes3 = new Array (0,0x200000,0x8000000,0x8200000,0x2000,0x202000,0x8002000,0x8202000,0x20000,0x220000,0x8020000,0x8220000,0x22000,0x222000,0x8022000,0x8222000);
|
||||
pc2bytes4 = new Array (0,0x40000,0x10,0x40010,0,0x40000,0x10,0x40010,0x1000,0x41000,0x1010,0x41010,0x1000,0x41000,0x1010,0x41010);
|
||||
pc2bytes5 = new Array (0,0x400,0x20,0x420,0,0x400,0x20,0x420,0x2000000,0x2000400,0x2000020,0x2000420,0x2000000,0x2000400,0x2000020,0x2000420);
|
||||
pc2bytes6 = new Array (0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002,0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002);
|
||||
pc2bytes7 = new Array (0,0x10000,0x800,0x10800,0x20000000,0x20010000,0x20000800,0x20010800,0x20000,0x30000,0x20800,0x30800,0x20020000,0x20030000,0x20020800,0x20030800);
|
||||
pc2bytes8 = new Array (0,0x40000,0,0x40000,0x2,0x40002,0x2,0x40002,0x2000000,0x2040000,0x2000000,0x2040000,0x2000002,0x2040002,0x2000002,0x2040002);
|
||||
pc2bytes9 = new Array (0,0x10000000,0x8,0x10000008,0,0x10000000,0x8,0x10000008,0x400,0x10000400,0x408,0x10000408,0x400,0x10000400,0x408,0x10000408);
|
||||
pc2bytes10 = new Array (0,0x20,0,0x20,0x100000,0x100020,0x100000,0x100020,0x2000,0x2020,0x2000,0x2020,0x102000,0x102020,0x102000,0x102020);
|
||||
pc2bytes11 = new Array (0,0x1000000,0x200,0x1000200,0x200000,0x1200000,0x200200,0x1200200,0x4000000,0x5000000,0x4000200,0x5000200,0x4200000,0x5200000,0x4200200,0x5200200);
|
||||
pc2bytes12 = new Array (0,0x1000,0x8000000,0x8001000,0x80000,0x81000,0x8080000,0x8081000,0x10,0x1010,0x8000010,0x8001010,0x80010,0x81010,0x8080010,0x8081010);
|
||||
pc2bytes13 = new Array (0,0x4,0x100,0x104,0,0x4,0x100,0x104,0x1,0x5,0x101,0x105,0x1,0x5,0x101,0x105);
|
||||
|
||||
//how many iterations (1 for des, 3 for triple des)
|
||||
var iterations = key.length >= 24 ? 3 : 1;
|
||||
//stores the return keys
|
||||
var keys = new Array (32 * iterations);
|
||||
//now define the left shifts which need to be done
|
||||
var shifts = new Array (0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0);
|
||||
//other variables
|
||||
var lefttemp, righttemp, m=0, n=0, temp;
|
||||
|
||||
for (var j=0; j<iterations; j++) { //either 1 or 3 iterations
|
||||
left = (key.charCodeAt(m++) << 24) | (key.charCodeAt(m++) << 16) | (key.charCodeAt(m++) << 8) | key.charCodeAt(m++);
|
||||
right = (key.charCodeAt(m++) << 24) | (key.charCodeAt(m++) << 16) | (key.charCodeAt(m++) << 8) | key.charCodeAt(m++);
|
||||
|
||||
temp = ((left >>> 4) ^ right) & 0x0f0f0f0f; right ^= temp; left ^= (temp << 4);
|
||||
temp = ((right >>> -16) ^ left) & 0x0000ffff; left ^= temp; right ^= (temp << -16);
|
||||
temp = ((left >>> 2) ^ right) & 0x33333333; right ^= temp; left ^= (temp << 2);
|
||||
temp = ((right >>> -16) ^ left) & 0x0000ffff; left ^= temp; right ^= (temp << -16);
|
||||
temp = ((left >>> 1) ^ right) & 0x55555555; right ^= temp; left ^= (temp << 1);
|
||||
temp = ((right >>> 8) ^ left) & 0x00ff00ff; left ^= temp; right ^= (temp << 8);
|
||||
temp = ((left >>> 1) ^ right) & 0x55555555; right ^= temp; left ^= (temp << 1);
|
||||
|
||||
//the right side needs to be shifted and to get the last four bits of the left side
|
||||
temp = (left << 8) | ((right >>> 20) & 0x000000f0);
|
||||
//left needs to be put upside down
|
||||
left = (right << 24) | ((right << 8) & 0xff0000) | ((right >>> 8) & 0xff00) | ((right >>> 24) & 0xf0);
|
||||
right = temp;
|
||||
|
||||
//now go through and perform these shifts on the left and right keys
|
||||
for (i=0; i < shifts.length; i++) {
|
||||
//shift the keys either one or two bits to the left
|
||||
if (shifts[i]) {left = (left << 2) | (left >>> 26); right = (right << 2) | (right >>> 26);}
|
||||
else {left = (left << 1) | (left >>> 27); right = (right << 1) | (right >>> 27);}
|
||||
left &= 0xfffffff0; right &= 0xfffffff0;
|
||||
|
||||
//now apply PC-2, in such a way that E is easier when encrypting or decrypting
|
||||
//this conversion will look like PC-2 except only the last 6 bits of each byte are used
|
||||
//rather than 48 consecutive bits and the order of lines will be according to
|
||||
//how the S selection functions will be applied: S2, S4, S6, S8, S1, S3, S5, S7
|
||||
lefttemp = pc2bytes0[left >>> 28] | pc2bytes1[(left >>> 24) & 0xf]
|
||||
| pc2bytes2[(left >>> 20) & 0xf] | pc2bytes3[(left >>> 16) & 0xf]
|
||||
| pc2bytes4[(left >>> 12) & 0xf] | pc2bytes5[(left >>> 8) & 0xf]
|
||||
| pc2bytes6[(left >>> 4) & 0xf];
|
||||
righttemp = pc2bytes7[right >>> 28] | pc2bytes8[(right >>> 24) & 0xf]
|
||||
| pc2bytes9[(right >>> 20) & 0xf] | pc2bytes10[(right >>> 16) & 0xf]
|
||||
| pc2bytes11[(right >>> 12) & 0xf] | pc2bytes12[(right >>> 8) & 0xf]
|
||||
| pc2bytes13[(right >>> 4) & 0xf];
|
||||
temp = ((righttemp >>> 16) ^ lefttemp) & 0x0000ffff;
|
||||
keys[n++] = lefttemp ^ temp; keys[n++] = righttemp ^ (temp << 16);
|
||||
}
|
||||
} //for each iterations
|
||||
//return the keys we've created
|
||||
return keys;
|
||||
} //end of des_createKeys
|
||||
|
||||
|
||||
////////////////////////////// TEST //////////////////////////////
|
||||
//printHexArray
|
||||
function printHex (s) {
|
||||
//var r = "0x"; // Don't prepend "0x"
|
||||
var r = "";
|
||||
var hexes = new Array ("0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f");
|
||||
for (var i=0; i<s.length; i++) {r += hexes [s.charCodeAt(i) >> 4] + hexes [s.charCodeAt(i) & 0xf];}
|
||||
return r;
|
||||
}
|
||||
|
||||
function unHex(s)
|
||||
{
|
||||
var r = "";
|
||||
// for (var i=2; i<s.length;i+=2) { // No "0x" prepended
|
||||
for (var i=0; i<s.length;i+=2) {
|
||||
x1 = s.charCodeAt(i);
|
||||
x1 = x1 >= 48 && x1 < 58 ? x1 - 48 : x1 - 97 + 10;
|
||||
x2 = s.charCodeAt(i+1);
|
||||
x2 = x2 >= 48 && x2 < 58 ? x2 - 48 : x2 - 97 + 10;
|
||||
r += String.fromCharCode (((x1 << 4) & 0xF0) | (x2 & 0x0F));
|
||||
}
|
||||
return r;
|
||||
}
|
||||
|
||||
//var key = "this is a 24 byte key !!";
|
||||
//var message = "This is a test message";
|
||||
//var ciphertext = des (key, message, 1, 0);
|
||||
//document.writeln ("DES Test: " + printHex (ciphertext));
|
||||
@ -1,25 +0,0 @@
|
||||
This directory is for the i18n translations for the DataTable widget that is used by this plugin.
|
||||
Most translations herein were take from DataTables.net: http://www.datatables.net/plug-ins/i18n
|
||||
|
||||
To create a file for a language, give it a name following the format:
|
||||
ll.json
|
||||
|
||||
And to create a file specific to a language and country, give it a name following the format:
|
||||
ll_CC.json
|
||||
|
||||
Or use whatever the locale string in for your system:
|
||||
locale.json
|
||||
|
||||
Where:
|
||||
"ll" is an ISO 639 two- or three-letter language code
|
||||
http://www.gnu.org/software/autoconf/manual/gettext/Language-Codes.html#Language-Codes
|
||||
|
||||
"CC" is an ISO 3166 two-letter country code
|
||||
http://www.gnu.org/software/autoconf/manual/gettext/Country-Codes.html#Country-Codes
|
||||
|
||||
locale is your locale string, which is typically in the form "ll_CC", but is whatever
|
||||
is returned from WordPress function get_locale()
|
||||
|
||||
** If you create a new translation file, please send a copy to the author of this plugin
|
||||
so he can share it with others. Also, send it to a contact at DataTable.net.
|
||||
email: michael_d_simpson@gmail.com
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "جاري التحميل...",
|
||||
"sLengthMenu": "أظهر مُدخلات _MENU_",
|
||||
"sZeroRecords": "لم يُعثر على أية سجلات",
|
||||
"sInfo": "إظهار _START_ إلى _END_ من أصل _TOTAL_ مُدخل",
|
||||
"sInfoEmpty": "يعرض 0 إلى 0 من أصل 0 سجلّ",
|
||||
"sInfoFiltered": "(منتقاة من مجموع _MAX_ مُدخل)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "ابحث:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "الأول",
|
||||
"sPrevious": "السابق",
|
||||
"sNext": "التالي",
|
||||
"sLast": "الأخير"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Обработка на резултатите...",
|
||||
"sLengthMenu": "Показване на _MENU_ резултата",
|
||||
"sZeroRecords": "Няма намерени резултати",
|
||||
"sInfo": "Показване на резултати от _START_ до _END_ от общо _TOTAL_",
|
||||
"sInfoEmpty": "Показване на резултати от 0 до 0 от общо 0",
|
||||
"sInfoFiltered": "(филтрирани от общо _MAX_ резултата)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Търсене във всички колони:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Първа",
|
||||
"sPrevious": "Предишна",
|
||||
"sNext": "Следваща",
|
||||
"sLast": "Последна"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Processant...",
|
||||
"sLengthMenu": "Mostra _MENU_ registres",
|
||||
"sZeroRecords": "No s'han trobat registres.",
|
||||
"sInfo": "Mostrant de _START_ a _END_ de _TOTAL_ registres",
|
||||
"sInfoEmpty": "Mostrant de 0 a 0 de 0 registres",
|
||||
"sInfoFiltered": "(filtrat de _MAX_ total registres)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Filtrar:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Primer",
|
||||
"sPrevious": "Anterior",
|
||||
"sNext": "Següent",
|
||||
"sLast": "Últim"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Provádím...",
|
||||
"sLengthMenu": "Zobraz záznamů _MENU_",
|
||||
"sZeroRecords": "Žádné záznamy nebyly nalezeny",
|
||||
"sInfo": "Zobrazuji _START_ až _END_ z celkem _TOTAL_ záznamů",
|
||||
"sInfoEmpty": "Zobrazuji 0 až 0 z 0 záznamů",
|
||||
"sInfoFiltered": "(filtrováno z celkem _MAX_ záznamů)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Hledat:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "První",
|
||||
"sPrevious": "Předchozí",
|
||||
"sNext": "Další",
|
||||
"sLast": "Poslední"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Henter...",
|
||||
"sLengthMenu": "Vis: _MENU_ linjer",
|
||||
"sZeroRecords": "Ingen linjer matcher søgningen",
|
||||
"sInfo": "Viser _START_ til _END_ af _TOTAL_ linjer",
|
||||
"sInfoEmpty": "Viser 0 til 0 af 0 linjer",
|
||||
"sInfoFiltered": "(filtreret fra _MAX_ linjer)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Søg:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Første",
|
||||
"sPrevious": "Forrige",
|
||||
"sNext": "Næste",
|
||||
"sLast": "Sidste"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Bitte warten...",
|
||||
"sLengthMenu": "_MENU_ Einträge anzeigen",
|
||||
"sZeroRecords": "Keine Einträge vorhanden.",
|
||||
"sInfo": "_START_ bis _END_ von _TOTAL_ Einträgen",
|
||||
"sInfoEmpty": "0 bis 0 von 0 Einträgen",
|
||||
"sInfoFiltered": "(gefiltert von _MAX_ Einträgen)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Suchen",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Erster",
|
||||
"sPrevious": "Zurück",
|
||||
"sNext": "Nächster",
|
||||
"sLast": "Letzter"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Επεξεργασία...",
|
||||
"sLengthMenu": "Δείξε _MENU_ εγγραφές",
|
||||
"sZeroRecords": "Δεν βρέθηκαν εγγραφές που να ταιριάζουν",
|
||||
"sInfo": "Δείχνοντας _START_ εως _END_ από _TOTAL_ εγγραφές",
|
||||
"sInfoEmpty": "Δείχνοντας 0 εως 0 από 0 εγγραφές",
|
||||
"sInfoFiltered": "(φιλτραρισμένες από _MAX_ συνολικά εγγραφές)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Αναζήτηση:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Πρώτη",
|
||||
"sPrevious": "Προηγούμενη",
|
||||
"sNext": "Επόμενη",
|
||||
"sLast": "Τελευταία"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Procesando...",
|
||||
"sLengthMenu": "Mostrar _MENU_ registros",
|
||||
"sZeroRecords": "No se encontraron resultados",
|
||||
"sInfo": "Mostrando desde _START_ hasta _END_ de _TOTAL_ registros",
|
||||
"sInfoEmpty": "Mostrando desde 0 hasta 0 de 0 registros",
|
||||
"sInfoFiltered": "(filtrado de _MAX_ registros en total)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Buscar:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Primero",
|
||||
"sPrevious": "Anterior",
|
||||
"sNext": "Siguiente",
|
||||
"sLast": "Último"
|
||||
}
|
||||
}
|
||||
@ -1,16 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Palun oodake, koostan kuvamiseks nimekirja!",
|
||||
"sLengthMenu": "Näita kirjeid _MENU_ kaupa",
|
||||
"sZeroRecords": "Otsitavat vastet ei leitud.",
|
||||
"sInfo": "Kuvatud: _TOTAL_ kirjet (_START_-_END_)",
|
||||
"sInfoEmpty": "Otsinguvasteid ei leitud",
|
||||
"sInfoFiltered": " - filteeritud _MAX_ kirje seast.",
|
||||
"sInfoPostFix": "Kõik kuvatud kirjed põhinevad reaalsetel tulemustel.",
|
||||
"sSearch": "Otsi kõikide tulemuste seast:",
|
||||
"oPaginate": {
|
||||
"sFirst": "Algus",
|
||||
"sPrevious": "Eelmine",
|
||||
"sNext": "Järgmine",
|
||||
"sLast": "Viimane"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "درحال پردازش...",
|
||||
"sLengthMenu": "نمایش محتویات _MENU_",
|
||||
"sZeroRecords": "موردی یافت نشد",
|
||||
"sInfo": "نمایش _START_ تا _END_ از مجموع _TOTAL_ مورد",
|
||||
"sInfoEmpty": "تهی",
|
||||
"sInfoFiltered": "(فیلتر شده از مجموع _MAX_ مورد)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "جستجو:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "ابتدا",
|
||||
"sPrevious": "قبلی",
|
||||
"sNext": "بعدی",
|
||||
"sLast": "انتها"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Hetkinen...",
|
||||
"sLengthMenu": "Näytä kerralla _MENU_ riviä",
|
||||
"sZeroRecords": "Tietoja ei löytynyt",
|
||||
"sInfo": "Näytetään rivit _START_ - _END_ (yhteensä _TOTAL_ )",
|
||||
"sInfoEmpty": "Näytetään 0 - 0 (yhteensä 0)",
|
||||
"sInfoFiltered": "(suodatettu _MAX_ tuloksen joukosta)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Etsi:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Ensimmäinen",
|
||||
"sPrevious": "Edellinen",
|
||||
"sNext": "Seuraava",
|
||||
"sLast": "Viimeinen"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Traitement en cours...",
|
||||
"sLengthMenu": "Afficher _MENU_ éléments",
|
||||
"sZeroRecords": "Aucun élément à afficher",
|
||||
"sInfo": "Affichage de l'élement _START_ à _END_ sur _TOTAL_ éléments",
|
||||
"sInfoEmpty": "Affichage de l'élement 0 à 0 sur 0 éléments",
|
||||
"sInfoFiltered": "(filtré de _MAX_ éléments au total)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Rechercher :",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Premier",
|
||||
"sPrevious": "Précédent",
|
||||
"sNext": "Suivant",
|
||||
"sLast": "Dernier"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "מעבד...",
|
||||
"sLengthMenu": "הצג _MENU_ פריטים",
|
||||
"sZeroRecords": "לא נמצאו רשומות מתאימות",
|
||||
"sInfo": "_START_ עד _END_ מתוך _TOTAL_ רשומות" ,
|
||||
"sInfoEmpty": "0 עד 0 מתוך 0 רשומות",
|
||||
"sInfoFiltered": "(מסונן מסך _MAX_ רשומות)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "חפש:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "ראשון",
|
||||
"sPrevious": "קודם",
|
||||
"sNext": "הבא",
|
||||
"sLast": "אחרון"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "प्रगति पे हैं ...",
|
||||
"sLengthMenu": " _MENU_ प्रविष्टियां दिखाएं ",
|
||||
"sZeroRecords": "रिकॉर्ड्स का मेल नहीं मिला",
|
||||
"sInfo": "_START_ to _END_ of _TOTAL_ प्रविष्टियां दिखा रहे हैं",
|
||||
"sInfoEmpty": "0 में से 0 से 0 प्रविष्टियां दिखा रहे हैं",
|
||||
"sInfoFiltered": "(_MAX_ कुल प्रविष्टियों में से छठा हुआ)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "खोजें:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "प्रथम",
|
||||
"sPrevious": "पिछला",
|
||||
"sNext": "अगला",
|
||||
"sLast": "अंतिम"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Procesiram...",
|
||||
"sLengthMenu": "Prikaži _MENU_ rezultata po stranici",
|
||||
"sZeroRecords": "Ništa nije pronađeno",
|
||||
"sInfo": "Prikazano _START_ do _END_ od _TOTAL_ rezultata",
|
||||
"sInfoEmtpy": "Prikazano 0 do 0 od 0 rezultata",
|
||||
"sInfoFiltered": "(filtrirano iz _MAX_ ukupnih rezultata)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Filter",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Prva",
|
||||
"sPrevious": "Nazad",
|
||||
"sNext": "Naprijed",
|
||||
"sLast": "Zadnja"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Feldolgozás...",
|
||||
"sLengthMenu": "_MENU_ találat oldalanként",
|
||||
"sZeroRecords": "Nincs a keresésnek megfelelő találat",
|
||||
"sInfo": "Találatok: _START_ - _END_ Összesen: _TOTAL_",
|
||||
"sInfoEmpty": "Nulla találat",
|
||||
"sInfoFiltered": "(_MAX_ összes rekord közül szűrve)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Keresés:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Első",
|
||||
"sPrevious": "Előző",
|
||||
"sNext": "Következő",
|
||||
"sLast": "Utolsó"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Sedang memproses...",
|
||||
"sLengthMenu": "Tampilkan _MENU_ entri",
|
||||
"sZeroRecords": "Tidak ditemukan data yang sesuai",
|
||||
"sInfo": "Menampilkan _START_ sampai _END_ dari _TOTAL_ entri",
|
||||
"sInfoEmpty": "Menampilkan 0 sampai 0 dari 0 entri",
|
||||
"sInfoFiltered": "(disaring dari _MAX_ entri keseluruhan)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Cari:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Pertama",
|
||||
"sPrevious": "Sebelumnya",
|
||||
"sNext": "Selanjutnya",
|
||||
"sLast": "Terakhir"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Caricamento...",
|
||||
"sLengthMenu": "Visualizza _MENU_ elementi",
|
||||
"sZeroRecords": "La ricerca non ha portato alcun risultato.",
|
||||
"sInfo": "Vista da _START_ a _END_ di _TOTAL_ elementi",
|
||||
"sInfoEmpty": "Vista da 0 a 0 di 0 elementi",
|
||||
"sInfoFiltered": "(filtrati da _MAX_ elementi totali)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Cerca:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Inizio",
|
||||
"sPrevious": "Precedente",
|
||||
"sNext": "Successivo",
|
||||
"sLast": "Fine"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "მიმდინარეობს დამუშავება...",
|
||||
"sLengthMenu": "აჩვენე _MENU_ ჩანაწერი",
|
||||
"sZeroRecords": "არაფერი მოიძებნა",
|
||||
"sInfo": "ნაჩვენებია ჩანაწერები _START_–დან _END_–მდე, სულ _TOTAL_ ჩანაწერია",
|
||||
"sInfoEmpty": "ნაჩვენებია ჩანაწერები 0–დან 0–მდე, სულ 0 ჩანაწერია",
|
||||
"sInfoFiltered": "(გაფილტრული შედეგი _MAX_ ჩანაწერიდან)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "ძიება:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "პირველი",
|
||||
"sPrevious": "წინა",
|
||||
"sNext": "შემდეგი",
|
||||
"sLast": "ბოლო"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Apdorojama...",
|
||||
"sLengthMenu": "Rodyti _MENU_ įrašus",
|
||||
"sZeroRecords": "Įrašų nerasta",
|
||||
"sInfo": "Rodomi įrašai nuo _START_ iki _END_ iš _TOTAL_ įrašų",
|
||||
"sInfoEmpty": "Rodomi įrašai nuo 0 iki 0 iš 0",
|
||||
"sInfoFiltered": "(atrinkta iš _MAX_ įrašų)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Ieškoti:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Pirmas",
|
||||
"sPrevious": "Ankstesnis",
|
||||
"sNext": "Tolimesnis",
|
||||
"sLast": "Paskutinis"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Uzgaidiet...",
|
||||
"sLengthMenu": "Rādīt _MENU_ ierakstus",
|
||||
"sZeroRecords": "Nav atrasti vaicājumam atbilstoši ieraksti",
|
||||
"sInfo": "Parādīti _START_. līdz _END_. no _TOTAL_ ierakstiem",
|
||||
"sInfoEmpty": "Nav ierakstu",
|
||||
"sInfoFiltered": "(atlasīts no pavisam _MAX_ ierakstiem)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Meklēt:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Pirmā",
|
||||
"sPrevious": "Iepriekšējā",
|
||||
"sNext": "Nākošā",
|
||||
"sLast": "Pēdējā"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Laster...",
|
||||
"sLengthMenu": "Vis: _MENU_ linjer",
|
||||
"sZeroRecords": "Ingen linjer matcher søket",
|
||||
"sInfo": "Viser _START_ til _END_ av _TOTAL_ linjer",
|
||||
"sInfoEmpty": "Viser 0 til 0 av 0 linjer",
|
||||
"sInfoFiltered": "(filtrert fra _MAX_ totalt antall linjer)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Søk:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Første",
|
||||
"sPrevious": "Forrige",
|
||||
"sNext": "Neste",
|
||||
"sLast": "Siste"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Bezig met verwerken...",
|
||||
"sLengthMenu": "Toon _MENU_ rijen",
|
||||
"sZeroRecords": "Geen resultaten gevonden",
|
||||
"sInfo": "_START_ tot _END_ van _TOTAL_ rijen",
|
||||
"sInfoEmpty": "Er zijn geen records om te tonen",
|
||||
"sInfoFiltered": "(gefilterd uit _MAX_ rijen)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Zoek:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Eerste",
|
||||
"sPrevious": "Vorige",
|
||||
"sNext": "Volgende",
|
||||
"sLast": "Laatste"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Proszę czekać...",
|
||||
"sLengthMenu": "Pokaż _MENU_ pozycji",
|
||||
"sZeroRecords": "Nie znaleziono żadnych pasujących indeksów",
|
||||
"sInfo": "Pozycje od _START_ do _END_ z _TOTAL_ łącznie",
|
||||
"sInfoEmpty": "Pozycji 0 z 0 dostępnych",
|
||||
"sInfoFiltered": "(filtrowanie spośród _MAX_ dostępnych pozycji)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Szukaj:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Pierwsza",
|
||||
"sPrevious": "Poprzednia",
|
||||
"sNext": "Następna",
|
||||
"sLast": "Ostatnia"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "A processar...",
|
||||
"sLengthMenu": "Mostrar _MENU_ registos",
|
||||
"sZeroRecords": "Não foram encontrados resultados",
|
||||
"sInfo": "Mostrando de _START_ até _END_ de _TOTAL_ registos",
|
||||
"sInfoEmpty": "Mostrando de 0 até 0 de 0 registros",
|
||||
"sInfoFiltered": "(filtrado de _MAX_ registos no total)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Procurar:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Primeiro",
|
||||
"sPrevious": "Anterior",
|
||||
"sNext": "Seguinte",
|
||||
"sLast": "Último"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Processando...",
|
||||
"sLengthMenu": "Mostrar _MENU_ registros",
|
||||
"sZeroRecords": "Não foram encontrados resultados",
|
||||
"sInfo": "Mostrando de _START_ até _END_ de _TOTAL_ registros",
|
||||
"sInfoEmpty": "Mostrando de 0 até 0 de 0 registros",
|
||||
"sInfoFiltered": "(filtrado de _MAX_ registros no total)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Buscar:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Primeiro",
|
||||
"sPrevious": "Anterior",
|
||||
"sNext": "Seguinte",
|
||||
"sLast": "Último"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Proceseaza...",
|
||||
"sLengthMenu": "Afiseaza _MENU_ inregistrari pe pagina",
|
||||
"sZeroRecords": "Nu am gasit nimic - ne pare rau",
|
||||
"sInfo": "Afisate de la _START_ la _END_ din _TOTAL_ inregistrari",
|
||||
"sInfoEmpty": "Afisate de la 0 la 0 din 0 inregistrari",
|
||||
"sInfoFiltered": "(filtrate dintr-un total de _MAX_ inregistrari)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Cauta:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Prima",
|
||||
"sPrevious": "Precedenta",
|
||||
"sNext": "Urmatoarea",
|
||||
"sLast": "Ultima"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Подождите...",
|
||||
"sLengthMenu": "Показать _MENU_ записей",
|
||||
"sZeroRecords": "Записи отсутствуют.",
|
||||
"sInfo": "Записи с _START_ до _END_ из _TOTAL_ записей",
|
||||
"sInfoEmpty": "Записи с 0 до 0 из 0 записей",
|
||||
"sInfoFiltered": "(отфильтровано из _MAX_ записей)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Поиск:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Первая",
|
||||
"sPrevious": "Предыдущая",
|
||||
"sNext": "Следующая",
|
||||
"sLast": "Последняя"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Pracujem...",
|
||||
"sLengthMenu": "Zobraz _MENU_ záznamov",
|
||||
"sZeroRecords": "Neboli nájdené žiadne záznamy",
|
||||
"sInfo": "Záznamy _START_ až _END_ z celkovo _TOTAL_",
|
||||
"sInfoEmpty": "Záznamy 0 až 0 z celkovo 0",
|
||||
"sInfoFiltered": "(filtrované z celkovo _MAX_ záznamov)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Hľadaj:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Prvá",
|
||||
"sPrevious": "Predchádzajúca",
|
||||
"sNext": "Ďalšia",
|
||||
"sLast": "Posledná"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Obdelujem...",
|
||||
"sLengthMenu": "Prikaži _MENU_ zapisov",
|
||||
"sZeroRecords": "Noben zapis ni bil najden",
|
||||
"sInfo": "Prikazanih od _START_ do _END_ od skupno _TOTAL_ zapisov",
|
||||
"sInfoEmpty": "Prikazanih od 0 do 0 od skupno 0 zapisov",
|
||||
"sInfoFiltered": "(filtrirano po vseh _MAX_ zapisih)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Išči:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Prva",
|
||||
"sPrevious": "Nazaj",
|
||||
"sNext": "Naprej",
|
||||
"sLast": "Zadnja"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Procesiranje u toku...",
|
||||
"sLengthMenu": "Prikaži _MENU_ elemenata",
|
||||
"sZeroRecords": "Nije pronađen nijedan rezultat",
|
||||
"sInfo": "Prikaz _START_ do _END_ od ukupno _TOTAL_ elemenata",
|
||||
"sInfoEmpty": "Prikaz 0 do 0 od ukupno 0 elemenata",
|
||||
"sInfoFiltered": "(filtrirano od ukupno _MAX_ elemenata)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Pretraga:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Početna",
|
||||
"sPrevious": "Prethodna",
|
||||
"sNext": "Sledeća",
|
||||
"sLast": "Poslednja"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Procesiranje u toku...",
|
||||
"sLengthMenu": "Prikaži _MENU_ elemenata",
|
||||
"sZeroRecords": "Nije pronađen nijedan rezultat",
|
||||
"sInfo": "Prikaz _START_ do _END_ od ukupno _TOTAL_ elemenata",
|
||||
"sInfoEmpty": "Prikaz 0 do 0 od ukupno 0 elemenata",
|
||||
"sInfoFiltered": "(filtrirano od ukupno _MAX_ elemenata)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Pretraga:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Početna",
|
||||
"sPrevious": "Prethodna",
|
||||
"sNext": "Sledeća",
|
||||
"sLast": "Poslednja"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Laddar...",
|
||||
"sLengthMenu": "Visa _MENU_ rader",
|
||||
"sZeroRecords": "Inga matchande resultat funna",
|
||||
"sInfo": "Visar _START_ till _END_ av totalt _TOTAL_ rader",
|
||||
"sInfoEmpty": "Visar 0 till 0 av totalt 0 rader",
|
||||
"sInfoFiltered": "(filtrerade från totalt _MAX_ rader)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Sök:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Första",
|
||||
"sPrevious": "Föregående",
|
||||
"sNext": "Nästa",
|
||||
"sLast": "Sista"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "กำลังดำเนินการ...",
|
||||
"sLengthMenu": "แสดง_MENU_ แถว",
|
||||
"sZeroRecords": "ไม่พบข้อมูล",
|
||||
"sInfo": "แสดง _START_ ถึง _END_ จาก _TOTAL_ แถว",
|
||||
"sInfoEmpty": "แสดง 0 ถึง 0 จาก 0 แถว",
|
||||
"sInfoFiltered": "(กรองข้อมูล _MAX_ ทุกแถว)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "ค้นหา:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "เิริ่มต้น",
|
||||
"sPrevious": "ก่อนหน้า",
|
||||
"sNext": "ถัดไป",
|
||||
"sLast": "สุดท้าย"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "İşleniyor...",
|
||||
"sLengthMenu": "Sayfada _MENU_ Kayıt Göster",
|
||||
"sZeroRecords": "Eşleşen Kayıt Bulunmadı",
|
||||
"sInfo": " _TOTAL_ Kayıttan _START_ - _END_ Arası Kayıtlar",
|
||||
"sInfoEmpty": "Kayıt Yok",
|
||||
"sInfoFiltered": "( _MAX_ Kayıt İçerisinden Bulunan)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Bul:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "İlk",
|
||||
"sPrevious": "Önceki",
|
||||
"sNext": "Sonraki",
|
||||
"sLast": "Son"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Зачекайте...",
|
||||
"sLengthMenu": "Показати _MENU_ записів",
|
||||
"sZeroRecords": "Записи відсутні.",
|
||||
"sInfo": "Записи з _START_ по _END_ із _TOTAL_ записів",
|
||||
"sInfoEmpty": "Записи з 0 по 0 із 0 записів",
|
||||
"sInfoFiltered": "(відфільтровано з _MAX_ записів)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Пошук:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Перша",
|
||||
"sPrevious": "Попередня",
|
||||
"sNext": "Наступна",
|
||||
"sLast": "Остання"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "ہے جاري عملدرامد...",
|
||||
"sLengthMenu": "دکہائين شقيں کي (_MENU_) فہرست",
|
||||
"sZeroRecords": "ملے نہيں مفروضات جلتے ملتے کوئ",
|
||||
"sInfo": "فہرست کي تک _END_ سے _START_ سے ميں _TOTAL_ فہرست پوري ہے نظر پيش",
|
||||
"sInfoEmpty": "فہرست کي تک 0 سے 0 سے ميں 0 قل ہے نظر پيشّ",
|
||||
"sInfoFiltered": "(فہرست ہوئ چھني سے ميں _MAX_ قل)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "کرو تلاش:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "پہلا",
|
||||
"sPrevious": "پچہلا",
|
||||
"sNext": "اگلا",
|
||||
"sLast": "آخري"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "Đang xử lý...",
|
||||
"sLengthMenu": "Xem _MENU_ mục",
|
||||
"sZeroRecords": "Không tìm thấy dòng nào phù hợp",
|
||||
"sInfo": "Đang xem _START_ đến _END_ trong tổng số _TOTAL_ mục",
|
||||
"sInfoEmpty": "Đang xem 0 đến 0 trong tổng số 0 mục",
|
||||
"sInfoFiltered": "(được lọc từ _MAX_ mục)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "Tìm:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "Đầu",
|
||||
"sPrevious": "Trước",
|
||||
"sNext": "Tiếp",
|
||||
"sLast": "Cuối"
|
||||
}
|
||||
}
|
||||
@ -1,17 +0,0 @@
|
||||
{
|
||||
"sProcessing": "处理中...",
|
||||
"sLengthMenu": "显示 _MENU_ 项结果",
|
||||
"sZeroRecords": "没有匹配结果",
|
||||
"sInfo": "显示第 _START_ 至 _END_ 项结果,共 _TOTAL_ 项",
|
||||
"sInfoEmpty": "显示第 0 至 0 项结果,共 0 项",
|
||||
"sInfoFiltered": "(由 _MAX_ 项结果过滤)",
|
||||
"sInfoPostFix": "",
|
||||
"sSearch": "搜索:",
|
||||
"sUrl": "",
|
||||
"oPaginate": {
|
||||
"sFirst": "首页",
|
||||
"sPrevious": "上页",
|
||||
"sNext": "下页",
|
||||
"sLast": "末页"
|
||||
}
|
||||
}
|
||||
@ -1,23 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
"Contact Form to Database Extension" Copyright (C) 2011 Michael Simpson (email : michael.d.simpson@gmail.com)
|
||||
|
||||
This file is part of Contact Form to Database Extension.
|
||||
|
||||
Contact Form to Database Extension is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
Contact Form to Database Extension is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with Contact Form to Database Extension.
|
||||
If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
// Backward compatibility
|
||||
include('export.php');
|
||||
|
Before Width: | Height: | Size: 20 KiB |
|
Before Width: | Height: | Size: 19 KiB |
|
Before Width: | Height: | Size: 25 KiB |
|
Before Width: | Height: | Size: 16 KiB |
|
Before Width: | Height: | Size: 42 KiB |
@ -1,27 +0,0 @@
|
||||
Place language translation files in this directory (*.po and *.mo files).
|
||||
Translation files should be named following this convention:
|
||||
|
||||
contact-form-7-to-database-extension-ll_CC.po
|
||||
contact-form-7-to-database-extension-ll_CC.mo
|
||||
|
||||
Where:
|
||||
"ll" is an ISO 639 two- or three-letter language code
|
||||
http://www.gnu.org/software/autoconf/manual/gettext/Language-Codes.html#Language-Codes
|
||||
|
||||
"CC" is an ISO 3166 two-letter country code
|
||||
http://www.gnu.org/software/autoconf/manual/gettext/Country-Codes.html#Country-Codes
|
||||
|
||||
NOTE: Strings that decorate DataTable widgets use a different i18n file.
|
||||
Look at the file: dt_i18n/README.txt for more information
|
||||
|
||||
How can I create a new translation file?
|
||||
- Download and install Poedit from http://www.poedit.net/
|
||||
- Run Poedit
|
||||
- "File" menu, "New catalog from POT file..." and open the file from this directory:
|
||||
contact-form-7-to-database-extension.pot
|
||||
- Enter your translation for each string
|
||||
- Save
|
||||
- Rename the files to follow the convention above
|
||||
- Upload your files into this directory in your WordPress installation
|
||||
- ** Send your files to the Plugin author so he can share them with others
|
||||
email: michael_d_simpson@gmail.com
|
||||
@ -1,277 +0,0 @@
|
||||
# Copyright (C) 2011
|
||||
# This file is distributed under the same license as the package.
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: Contact Form 7 - database\n"
|
||||
"Report-Msgid-Bugs-To: http://wordpress.org/tag/contact-form-7-to-database-extension\n"
|
||||
"POT-Creation-Date: 2011-02-25 21:50:57+00:00\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: 8bit\n"
|
||||
"PO-Revision-Date: 2011-03-03 20:47+0100\n"
|
||||
"Last-Translator: GG\n"
|
||||
"Language-Team: Ateliér Gadjukin <atelier@gadjukin.net>\n"
|
||||
"X-Poedit-Language: Czech\n"
|
||||
|
||||
#: CF7DBPlugin.php:49
|
||||
msgid "Can See Submission data"
|
||||
msgstr "Může vidět uložená data"
|
||||
|
||||
#: CF7DBPlugin.php:51
|
||||
msgid "Can See Submission when using shortcodes"
|
||||
msgstr "Může vidět uložená data při použití zkratek"
|
||||
|
||||
#: CF7DBPlugin.php:53
|
||||
msgid "Can Delete Submission data"
|
||||
msgstr "Může bymazat uložená data"
|
||||
|
||||
#: CF7DBPlugin.php:55
|
||||
msgid "Use Javascript-enabled tables in Admin Database page"
|
||||
msgstr "Použít Javascript"
|
||||
|
||||
#: CF7DBPlugin.php:56
|
||||
msgid "Show line breaks in submitted data table"
|
||||
msgstr "Zobrazovat zalomení řádku v datové tabulce"
|
||||
|
||||
#: CF7DBPlugin.php:57
|
||||
msgid "Use Custom Date-Time Display Format (below)"
|
||||
msgstr "Použít uživatelské zobrazení datumu a času (níže)"
|
||||
|
||||
#: CF7DBPlugin.php:58
|
||||
msgid "Date-Time Display Format"
|
||||
msgstr "Formát zobrazení datumu a času"
|
||||
|
||||
#: CF7DBPlugin.php:59
|
||||
msgid "Export URLs instead of file names for uploaded files"
|
||||
msgstr "Exportovat URL adresu místo jména uplodovaného souboru"
|
||||
|
||||
#: CF7DBPlugin.php:60
|
||||
msgid "Do not save <u>fields</u> in DB named (comma-separated list, no spaces)"
|
||||
msgstr "Neukládat <u>pole</u> do databáze (čárkou oddělený seznam, bez mezer)"
|
||||
|
||||
#: CF7DBPlugin.php:61
|
||||
msgid "Do not save <u>forms</u> in DB named (comma-separated list, no spaces)"
|
||||
msgstr "Neukládat <u>formuláře</u> do databáze (čárkou oddělený seznam, bez mezer)"
|
||||
|
||||
#: CF7DBPlugin.php:62
|
||||
msgid "Save Cookie Data with Form Submissions"
|
||||
msgstr "Uložit data cookie"
|
||||
|
||||
#: CF7DBPlugin.php:63
|
||||
msgid "Save only cookies in DB named (comma-separated list, no spaces, and above option must be set to true)"
|
||||
msgstr "Uložit do databáze pouze cookies (čárkou oddělený seznam, bez mezer, musí být povolena předchozí volba)"
|
||||
|
||||
#: CF7DBPlugin.php:71
|
||||
#: CF7DBOptionsManager.php:380
|
||||
msgid "true"
|
||||
msgstr "ano"
|
||||
|
||||
#: CF7DBPlugin.php:73
|
||||
#: CF7DBOptionsManager.php:381
|
||||
msgid "false"
|
||||
msgstr "ne"
|
||||
|
||||
#: CF7DBPlugin.php:76
|
||||
msgid "Administrator"
|
||||
msgstr "Administrátor"
|
||||
|
||||
#: CF7DBPlugin.php:78
|
||||
msgid "Editor"
|
||||
msgstr "Redaktor"
|
||||
|
||||
#: CF7DBPlugin.php:80
|
||||
msgid "Author"
|
||||
msgstr "Autor"
|
||||
|
||||
#: CF7DBPlugin.php:82
|
||||
msgid "Contributor"
|
||||
msgstr "Přispěvatel"
|
||||
|
||||
#: CF7DBPlugin.php:84
|
||||
msgid "Subscriber"
|
||||
msgstr "Odběratel"
|
||||
|
||||
#: CF7DBPlugin.php:86
|
||||
msgid "Anyone"
|
||||
msgstr "kdokoliv"
|
||||
|
||||
#: CF7DBPlugin.php:212
|
||||
#: CF7DBPlugin.php:232
|
||||
msgid "Database Options"
|
||||
msgstr "Volby databáze"
|
||||
|
||||
#: CF7DBPlugin.php:230
|
||||
#: CF7DBPlugin.php:381
|
||||
msgid "Database"
|
||||
msgstr "Databáze"
|
||||
|
||||
#: CF7DBPlugin.php:234
|
||||
msgid "FAQ"
|
||||
msgstr "FAQ"
|
||||
|
||||
#: CF7DBPlugin.php:414
|
||||
msgid "Rate this Plugin"
|
||||
msgstr "Ohodnoťte tento plugin"
|
||||
|
||||
#: CF7DBPlugin.php:420
|
||||
msgid "Documentation"
|
||||
msgstr "Dokumentace"
|
||||
|
||||
#: CF7DBPlugin.php:426
|
||||
msgid "Support"
|
||||
msgstr "Podpora"
|
||||
|
||||
#: CF7DBPlugin.php:442
|
||||
msgid "No form submissions in the database"
|
||||
msgstr "V databázi není žádný formulář"
|
||||
|
||||
#: CF7DBPlugin.php:481
|
||||
msgid "* Select a form *"
|
||||
msgstr "* Vyberte formulář *"
|
||||
|
||||
#: CF7DBPlugin.php:510
|
||||
msgid "Google Login for Upload"
|
||||
msgstr "Google přihlášení pro nahrání"
|
||||
|
||||
#: CF7DBPlugin.php:519
|
||||
msgid "Cannot perform operation because jQuery is not loaded in this page"
|
||||
msgstr "Nelze vykonat tuto operaci, protože jQuery není na této stránce načteno"
|
||||
|
||||
#: CF7DBPlugin.php:559
|
||||
msgid "Excel Internet Query"
|
||||
msgstr "Excel Internet Query"
|
||||
|
||||
#: CF7DBPlugin.php:562
|
||||
msgid "Excel CSV (UTF8-BOM)"
|
||||
msgstr "Excel CSV (UTF8-BOM)"
|
||||
|
||||
#: CF7DBPlugin.php:565
|
||||
msgid "Excel TSV (UTF16LE-BOM)"
|
||||
msgstr "Excel TSV (UTF16LE-BOM)"
|
||||
|
||||
#: CF7DBPlugin.php:568
|
||||
msgid "Plain CSV (UTF-8)"
|
||||
msgstr "Prostý CSV (UTF-8)"
|
||||
|
||||
#: CF7DBPlugin.php:571
|
||||
msgid "Google Spreadsheet"
|
||||
msgstr "Tabulka Google"
|
||||
|
||||
#: CF7DBPlugin.php:574
|
||||
msgid "Google Spreadsheet Live Data"
|
||||
msgstr "Tabulka Google Live Data"
|
||||
|
||||
#: CF7DBPlugin.php:577
|
||||
msgid "HTML"
|
||||
msgstr "HTML"
|
||||
|
||||
#: CF7DBPlugin.php:580
|
||||
msgid "JSON"
|
||||
msgstr "JSON"
|
||||
|
||||
#: CF7DBPlugin.php:584
|
||||
msgid "Export"
|
||||
msgstr "Exportovat"
|
||||
|
||||
#: CF7DBPlugin.php:595
|
||||
msgid "Delete All This Form's Records"
|
||||
msgstr "Vymazat všechny záznamy tohoto formuláře"
|
||||
|
||||
#: CF7DBPlugin.php:657
|
||||
msgid "Did you know: This plugin captures data from both these plugins:"
|
||||
msgstr "Věděli jste, že: Tento plugin získává data z obou těchto pluginů:"
|
||||
|
||||
#: CF7DBPlugin.php:666
|
||||
msgid "Did you know: You can add this data to your posts and pages using these shortcodes:"
|
||||
msgstr "Věděli jste, že: můžete přidat tato data do vašich příspěvků a stránek pomocí těchto zkratek:"
|
||||
|
||||
#: CF7DBPlugin.php:677
|
||||
msgid "Would you like to help translate this plugin into your language?"
|
||||
msgstr "Chtěli byste pomoci s překladem tohoto pluginu do vašeho jazyka?"
|
||||
|
||||
#: CF7DBPlugin.php:678
|
||||
msgid "How to create a translation"
|
||||
msgstr "Jak vytvořit překlad"
|
||||
|
||||
#: CF7DBPlugin.php:702
|
||||
msgid "Cancel"
|
||||
msgstr "Zrušit"
|
||||
|
||||
#: CF7DBPlugin.php:704
|
||||
msgid "Upload"
|
||||
msgstr "Nahrát"
|
||||
|
||||
#: ExportBase.php:125
|
||||
msgid "You do not have sufficient permissions to access this data."
|
||||
msgstr "Nemáte dostatečná oprávnění přístupu k těmto datům."
|
||||
|
||||
#: getFile.php:32
|
||||
#: CF7DBOptionsManager.php:278
|
||||
#: ExportToGoogleLiveData.php:30
|
||||
msgid "You do not have sufficient permissions to access this page."
|
||||
msgstr "Nemáte dostatečná oprávnění pro přístup na tuto stránku."
|
||||
|
||||
#: getFile.php:39
|
||||
msgid "Missing form parameters"
|
||||
msgstr "Chybějící parametry formuláře"
|
||||
|
||||
#: getFile.php:44
|
||||
msgid "No such file."
|
||||
msgstr "Žádný soubor"
|
||||
|
||||
#: export.php:36
|
||||
msgid "Error: No \"form\" parameter submitted"
|
||||
msgstr "Chyba: Žádný parametr \"form\""
|
||||
|
||||
#: CF7DBOptionsManager.php:296
|
||||
msgid "Settings"
|
||||
msgstr "Nastavení"
|
||||
|
||||
#: CF7DBOptionsManager.php:321
|
||||
msgid "Save Changes"
|
||||
msgstr "Uložit změny"
|
||||
|
||||
#: ExportToGoogleLiveData.php:166
|
||||
msgid "How to Set up Google Spreadsheet to pull data from WordPress"
|
||||
msgstr "Jak nastavit tabulky Google pro získání dat z WordPressu"
|
||||
|
||||
#: CJ7DBCheckZendFramework.php:71
|
||||
msgid "Missing Zend Framework"
|
||||
msgstr "Chybějící Zend Framework"
|
||||
|
||||
#: ExportToGoogleSS.php:61
|
||||
msgid "Login Failed"
|
||||
msgstr "Přihlášení selhalo"
|
||||
|
||||
#: ExportToGoogleSS.php:100
|
||||
msgid "New Google Spreadsheet"
|
||||
msgstr "Nová Google tabulka"
|
||||
|
||||
#: ExportToGoogleSS.php:109
|
||||
msgid "Error"
|
||||
msgstr "Chyba"
|
||||
|
||||
#: contact-form-7-db.php:23
|
||||
msgid "Minimal version of PHP required: "
|
||||
msgstr "Minimální vyžadovaná verze PHP:"
|
||||
|
||||
#: contact-form-7-db.php:24
|
||||
msgid "Your server's PHP version: "
|
||||
msgstr "Verze PHP vašeho serveru:"
|
||||
|
||||
#: contact-form-7-db.php:27
|
||||
msgid "When using the Apache web server, typically you can configure it to use PHP5 by doing the following:"
|
||||
msgstr "Při použití webového serveru Apache, si obvykle můžete nakonfigurovat tak, aby používal PHP5 následujícím způsobem:"
|
||||
|
||||
#: contact-form-7-db.php:29
|
||||
msgid "Locate and edit this file, located at the top directory of your WordPress installation: "
|
||||
msgstr "Vyhledejte a upravte tento soubor, který se nachází v kořenovém adresáři instalace WordPress:"
|
||||
|
||||
#: contact-form-7-db.php:31
|
||||
msgid "Add these two lines to the file:"
|
||||
msgstr "Přidat tyto dva řádky do souboru:"
|
||||
|
||||
#: ExportToHtmlTable.php:135
|
||||
msgid "Delete"
|
||||
msgstr "Smazat"
|
||||
|
||||