templating
This commit is contained in:
parent
b8ae357805
commit
e38e8b231d
339
wp-content/plugins/blocksy-companion/LICENSE.txt
Normal file
339
wp-content/plugins/blocksy-companion/LICENSE.txt
Normal file
@ -0,0 +1,339 @@
|
|||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
Version 2, June 1991
|
||||||
|
|
||||||
|
Copyright (C) 1989, 1991 Free Software Foundation, Inc., <http://fsf.org/>
|
||||||
|
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 origina
|
||||||
|
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.
|
||||||
|
|
||||||
|
{description}
|
||||||
|
Copyright (C) {year} {fullname}
|
||||||
|
|
||||||
|
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
|
||||||
145
wp-content/plugins/blocksy-companion/blocksy-companion.php
Normal file
145
wp-content/plugins/blocksy-companion/blocksy-companion.php
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
Plugin Name: Blocksy Companion
|
||||||
|
Description: This plugin is the companion for the Blocksy theme, it runs and adds its enhacements only if the Blocksy theme is installed and active.
|
||||||
|
Version: 2.0.37
|
||||||
|
Author: CreativeThemes
|
||||||
|
Author URI: https://creativethemes.com
|
||||||
|
Text Domain: blocksy-companion
|
||||||
|
Domain Path: /languages/
|
||||||
|
License: GPLv2 or later
|
||||||
|
License URI: http://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
*/
|
||||||
|
|
||||||
|
if ( !defined( 'ABSPATH' ) ) {
|
||||||
|
exit;
|
||||||
|
// Exit if accessed directly.
|
||||||
|
}
|
||||||
|
|
||||||
|
register_activation_hook( __FILE__, function () {
|
||||||
|
|
||||||
|
if ( class_exists( '\\Blocksy\\Plugin' ) && !function_exists( 'blc_fs' ) ) {
|
||||||
|
$to_deactivate = plugin_basename( str_replace( '-pro/', '/', __FILE__ ) );
|
||||||
|
if ( is_plugin_active( $to_deactivate ) ) {
|
||||||
|
deactivate_plugins( $to_deactivate );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( isset( $_REQUEST['action'] ) && 'activate-selected' === $_REQUEST['action'] && isset( $_POST['checked'] ) && count( $_POST['checked'] ) > 1 ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
add_option( 'blc_activation_redirect', wp_get_current_user()->ID );
|
||||||
|
} );
|
||||||
|
|
||||||
|
if ( function_exists( 'blc_fs' ) || class_exists( '\\Blocksy\\Plugin' ) ) {
|
||||||
|
if ( function_exists( 'blc_fs' ) ) {
|
||||||
|
blc_fs()->set_basename( false, __FILE__ );
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
|
||||||
|
if ( !function_exists( 'blc_fs' ) && file_exists( dirname( __FILE__ ) . '/freemius/start.php' ) && is_admin() ) {
|
||||||
|
global $blc_fs ;
|
||||||
|
|
||||||
|
if ( !isset( $blc_fs ) ) {
|
||||||
|
if ( !defined( 'WP_FS__PRODUCT_5115_MULTISITE' ) ) {
|
||||||
|
define( 'WP_FS__PRODUCT_5115_MULTISITE', true );
|
||||||
|
}
|
||||||
|
require_once dirname( __FILE__ ) . '/freemius/start.php';
|
||||||
|
$has_account = true;
|
||||||
|
$instance = \Freemius::instance( 5115, 'blocksy-companion', true );
|
||||||
|
|
||||||
|
if ( in_array( 'white-label', get_option( 'blocksy_active_extensions', [] ) ) && ($instance->is_plan( 'agency' ) || $instance->is_plan( 'agency_v2' )) ) {
|
||||||
|
$settings = get_option( 'blocksy_ext_white_label_settings', [] );
|
||||||
|
if ( $settings && isset( $settings['hide_billing_account'] ) && $settings['hide_billing_account'] ) {
|
||||||
|
$has_account = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$blc_fs = fs_dynamic_init( array(
|
||||||
|
'id' => '5115',
|
||||||
|
'slug' => 'blocksy-companion',
|
||||||
|
'premium_slug' => 'blocksy-companion-pro',
|
||||||
|
'type' => 'plugin',
|
||||||
|
'public_key' => 'pk_b00a5cbae90b2e948015a7d0710f5',
|
||||||
|
'premium_suffix' => 'PRO',
|
||||||
|
'is_premium' => false,
|
||||||
|
'has_addons' => false,
|
||||||
|
'has_paid_plans' => true,
|
||||||
|
'menu' => ( true ? [
|
||||||
|
'slug' => 'ct-dashboard',
|
||||||
|
'support' => false,
|
||||||
|
'contact' => false,
|
||||||
|
'pricing' => true,
|
||||||
|
'account' => $has_account,
|
||||||
|
] : [
|
||||||
|
'support' => false,
|
||||||
|
'contact' => false,
|
||||||
|
'pricing' => false,
|
||||||
|
'account' => false,
|
||||||
|
] ),
|
||||||
|
'is_live' => true,
|
||||||
|
) );
|
||||||
|
function blc_fs()
|
||||||
|
{
|
||||||
|
global $blc_fs ;
|
||||||
|
// if (! is_admin()) {
|
||||||
|
// throw new Error('Called in frontend!');
|
||||||
|
// }
|
||||||
|
return $blc_fs;
|
||||||
|
}
|
||||||
|
|
||||||
|
blc_fs();
|
||||||
|
do_action( 'blc_fs_loaded' );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
define( 'BLOCKSY__FILE__', __FILE__ );
|
||||||
|
define( 'BLOCKSY_PLUGIN_BASE', plugin_basename( BLOCKSY__FILE__ ) );
|
||||||
|
define( 'BLOCKSY_PATH', plugin_dir_path( BLOCKSY__FILE__ ) );
|
||||||
|
define( 'BLOCKSY_URL', plugin_dir_url( BLOCKSY__FILE__ ) );
|
||||||
|
add_action( 'init', function () {
|
||||||
|
/**
|
||||||
|
* Load Blocksy textdomain.
|
||||||
|
*
|
||||||
|
* Load gettext translate for Blocksy text domain.
|
||||||
|
*/
|
||||||
|
load_plugin_textdomain( 'blocksy-companion', false, dirname( BLOCKSY_PLUGIN_BASE ) . '/languages' );
|
||||||
|
} );
|
||||||
|
|
||||||
|
if ( !version_compare( PHP_VERSION, '7.0', '>=' ) ) {
|
||||||
|
add_action( 'admin_notices', 'blc_fail_php_version' );
|
||||||
|
} elseif ( !version_compare( get_bloginfo( 'version' ), '5.0', '>=' ) ) {
|
||||||
|
add_action( 'admin_notices', 'blc_fail_wp_version' );
|
||||||
|
} else {
|
||||||
|
require BLOCKSY_PATH . 'plugin.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Blocksy admin notice for minimum PHP version.
|
||||||
|
*
|
||||||
|
* Warning when the site doesn't have the minimum required PHP version.
|
||||||
|
*/
|
||||||
|
function blc_fail_php_version()
|
||||||
|
{
|
||||||
|
/* translators: %s: PHP version */
|
||||||
|
$message = sprintf( esc_html__( 'Blocksy requires PHP version %s+, plugin is currently NOT RUNNING.', 'blocksy-companion' ), '7.0' );
|
||||||
|
$html_message = sprintf( '<div class="error">%s</div>', wpautop( $message ) );
|
||||||
|
echo wp_kses_post( $html_message ) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Blocksy admin notice for minimum WordPress version.
|
||||||
|
*
|
||||||
|
* Warning when the site doesn't have the minimum required WordPress version.
|
||||||
|
*/
|
||||||
|
function blc_fail_wp_version()
|
||||||
|
{
|
||||||
|
/* translators: %s: WordPress version */
|
||||||
|
$message = sprintf( esc_html__( 'Blocksy requires WordPress version %s+. Because you are using an earlier version, the plugin is currently NOT RUNNING.', 'blocksy-companion' ), '5.0' );
|
||||||
|
$html_message = sprintf( '<div class="error">%s</div>', wpautop( $message ) );
|
||||||
|
echo wp_kses_post( $html_message ) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
158
wp-content/plugins/blocksy-companion/framework/autoload.php
Normal file
158
wp-content/plugins/blocksy-companion/framework/autoload.php
Normal file
@ -0,0 +1,158 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy;
|
||||||
|
|
||||||
|
if (! defined('ABSPATH')) {
|
||||||
|
exit; // Exit if accessed directly.
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Blocksy autoloader.
|
||||||
|
*/
|
||||||
|
class Autoloader {
|
||||||
|
private static $classes_map = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Classes map.
|
||||||
|
*
|
||||||
|
* Maps Blocksy classes to file names.
|
||||||
|
*
|
||||||
|
* @static
|
||||||
|
*
|
||||||
|
* @var array Classes used by blocksy.
|
||||||
|
*/
|
||||||
|
private static function get_classes_map() {
|
||||||
|
if (self::$classes_map) {
|
||||||
|
return self::$classes_map;
|
||||||
|
}
|
||||||
|
|
||||||
|
self::$classes_map = [
|
||||||
|
'Capabilities' => 'framework/includes/capabilities.php',
|
||||||
|
|
||||||
|
'ExtensionsManager' => 'framework/includes/extensions-manager.php',
|
||||||
|
'ExtensionWithFeatures' => 'framework/includes/extension-with-features.php',
|
||||||
|
'ExtensionsManagerApi' => 'framework/includes/extensions-manager-api.php',
|
||||||
|
|
||||||
|
'Dashboard' => 'framework/dashboard.php',
|
||||||
|
'ThemeIntegration' => 'framework/theme-integration.php',
|
||||||
|
'AccountAuth' => 'framework/features/account-auth.php',
|
||||||
|
'CacheResetManager' => 'framework/cache-reset-manager.php',
|
||||||
|
|
||||||
|
'GoogleAnalytics' => 'framework/features/google-analytics.php',
|
||||||
|
'OpenGraphMetaData' => 'framework/features/opengraph-meta-data.php',
|
||||||
|
'HeaderAdditions' => 'framework/features/header.php',
|
||||||
|
'ConditionsManager' => 'framework/features/conditions-manager.php',
|
||||||
|
'ConditionsRulesResolver' => 'framework/features/conditions/rules-resolver.php',
|
||||||
|
|
||||||
|
'Cli' => 'framework/cli.php',
|
||||||
|
|
||||||
|
'SvgHandling' => 'framework/features/svg.php',
|
||||||
|
'DynamicCss' => 'framework/features/dynamic-css.php',
|
||||||
|
'CustomizerOptionsManager' => 'framework/features/customizer-options-manager.php',
|
||||||
|
'DemoInstall' => 'framework/features/demo-install.php',
|
||||||
|
'DemoInstallContentExport' => 'framework/features/demo-install/content-export.php',
|
||||||
|
'DemoInstallWidgetsExport' => 'framework/features/demo-install/widgets-export.php',
|
||||||
|
'DemoInstallOptionsExport' => 'framework/features/demo-install/options-export.php',
|
||||||
|
|
||||||
|
'DemoInstallChildThemeInstaller' => 'framework/features/demo-install/child-theme.php',
|
||||||
|
'DemoInstallPluginsInstaller' => 'framework/features/demo-install/required-plugins.php',
|
||||||
|
'DemoInstallPluginsUninstaller' => 'framework/features/demo-install/plugins-uninstaller.php',
|
||||||
|
'DemoInstallContentInstaller' => 'framework/features/demo-install/content-installer.php',
|
||||||
|
'DemoInstallOptionsInstaller' => 'framework/features/demo-install/options-import.php',
|
||||||
|
'DemoInstallWidgetsInstaller' => 'framework/features/demo-install/widgets-import.php',
|
||||||
|
'DemoInstallContentEraser' => 'framework/features/demo-install/content-eraser.php',
|
||||||
|
'DemoInstallFakeContentEraser' => 'framework/features/demo-install/fake-content-eraser.php',
|
||||||
|
'DemoInstallFinalActions' => 'framework/features/demo-install/install-finish.php',
|
||||||
|
'Premium' => 'framework/premium/pro.php',
|
||||||
|
|
||||||
|
/**
|
||||||
|
* No namespace
|
||||||
|
*/
|
||||||
|
'_Blocksy_WP_Import' => 'framework/features/demo-install/wp-importer.php',
|
||||||
|
];
|
||||||
|
|
||||||
|
$autoload = [];
|
||||||
|
|
||||||
|
if (is_readable(dirname(__FILE__) . '/premium/autoload.php')) {
|
||||||
|
require dirname(__FILE__) . '/premium/autoload.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($autoload as $class_name => $file_name) {
|
||||||
|
self::$classes_map[$class_name] = $file_name;
|
||||||
|
}
|
||||||
|
|
||||||
|
return self::$classes_map;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Run autoloader.
|
||||||
|
*
|
||||||
|
* Register a function as `__autoload()` implementation.
|
||||||
|
*
|
||||||
|
* @static
|
||||||
|
*/
|
||||||
|
public static function run() {
|
||||||
|
spl_autoload_register([__CLASS__, 'autoload']);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load class.
|
||||||
|
*
|
||||||
|
* For a given class name, require the class file.
|
||||||
|
*
|
||||||
|
* @static
|
||||||
|
*
|
||||||
|
* @param string $relative_class_name Class name.
|
||||||
|
*/
|
||||||
|
private static function load_class($relative_class_name) {
|
||||||
|
if (isset(self::get_classes_map()[$relative_class_name])) {
|
||||||
|
$filename = BLOCKSY_PATH . '/' . self::get_classes_map()[$relative_class_name];
|
||||||
|
} else {
|
||||||
|
$filename = strtolower(
|
||||||
|
preg_replace(
|
||||||
|
['/([a-z])([A-Z])/', '/_/', '/\\\/'],
|
||||||
|
['$1-$2', '-', DIRECTORY_SEPARATOR],
|
||||||
|
$relative_class_name
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$filename = BLOCKSY_PATH . $filename . '.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_readable($filename)) {
|
||||||
|
require $filename;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Autoload.
|
||||||
|
*
|
||||||
|
* For a given class, check if it exist and load it.
|
||||||
|
*
|
||||||
|
* @static
|
||||||
|
*
|
||||||
|
* @param string $class Class name.
|
||||||
|
*/
|
||||||
|
private static function autoload($class) {
|
||||||
|
if (
|
||||||
|
0 !== strpos($class, __NAMESPACE__ . '\\')
|
||||||
|
&&
|
||||||
|
! isset(self::get_classes_map()['_' . $class])
|
||||||
|
) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$relative_class_name = preg_replace('/^' . __NAMESPACE__ . '\\\/', '', $class);
|
||||||
|
|
||||||
|
$final_class_name = __NAMESPACE__ . '\\' . $relative_class_name;
|
||||||
|
|
||||||
|
if (isset(self::get_classes_map()['_' . $relative_class_name])) {
|
||||||
|
$final_class_name = $relative_class_name;
|
||||||
|
$relative_class_name = '_' . $relative_class_name;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! class_exists($final_class_name)) {
|
||||||
|
self::load_class($relative_class_name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,65 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy;
|
||||||
|
|
||||||
|
class CacheResetManager {
|
||||||
|
public function is_there_any_page_caching() {
|
||||||
|
$page_is_cached = false;
|
||||||
|
|
||||||
|
if (class_exists('W3TC\Cache')) {
|
||||||
|
$w3_conf = \W3TC\Dispatcher::config();
|
||||||
|
$page_is_cached = !! $w3_conf->get_boolean('pgcache.enabled');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (class_exists('LiteSpeed\Control')) {
|
||||||
|
$control = \LiteSpeed\Root::cls('Control');
|
||||||
|
|
||||||
|
$page_is_cached = (
|
||||||
|
$control->conf('cache') && \LiteSpeed\Control::is_cacheable()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (class_exists('WPO_Cache_Config')) {
|
||||||
|
$cache_config = \WPO_Cache_Config::instance();
|
||||||
|
$page_is_cached = !! $cache_config->get_option('enable_page_caching');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (class_exists('SiteGround_Optimizer\Options\Options')) {
|
||||||
|
$siteground_optimizer_file_caching = \SiteGround_Optimizer\Options\Options::is_enabled(
|
||||||
|
'siteground_optimizer_file_caching'
|
||||||
|
);
|
||||||
|
|
||||||
|
$siteground_optimizer_enable_cache = \SiteGround_Optimizer\Options\Options::is_enabled(
|
||||||
|
'siteground_optimizer_enable_cache'
|
||||||
|
);
|
||||||
|
|
||||||
|
$page_is_cached = (
|
||||||
|
$siteground_optimizer_file_caching
|
||||||
|
||
|
||||||
|
$siteground_optimizer_enable_cache
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (class_exists('\WP_Rocket\Buffer\Cache')) {
|
||||||
|
$page_is_cached = \WP_Rocket\Buffer\Cache::can_generate_caching_files();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (class_exists("\CF\API\Plugin")) {
|
||||||
|
if (\CF\API\Plugin::SETTING_PLUGIN_SPECIFIC_CACHE === "plugin_specific_cache") {
|
||||||
|
$page_is_cached = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
global $super_cache_enabled;
|
||||||
|
|
||||||
|
if (isset($super_cache_enabled)) {
|
||||||
|
$page_is_cached = $super_cache_enabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
return apply_filters(
|
||||||
|
'blocksy:cache-manager:page-is-cached',
|
||||||
|
$page_is_cached
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
212
wp-content/plugins/blocksy-companion/framework/cli.php
Normal file
212
wp-content/plugins/blocksy-companion/framework/cli.php
Normal file
@ -0,0 +1,212 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy;
|
||||||
|
|
||||||
|
/*
|
||||||
|
add_action('blocksy:customizer:load:before', function () {
|
||||||
|
$_REQUEST['wp_customize'] = 'on';
|
||||||
|
_wp_customize_include();
|
||||||
|
|
||||||
|
global $wp_customize;
|
||||||
|
|
||||||
|
$wp_customize->wp_loaded();
|
||||||
|
});
|
||||||
|
*/
|
||||||
|
|
||||||
|
class Cli {
|
||||||
|
public function __construct() {
|
||||||
|
/**
|
||||||
|
* Move all widgets to the inactive widgets area.
|
||||||
|
*/
|
||||||
|
\WP_CLI::add_command('blocksy widgets drop', function ($args) {
|
||||||
|
$sidebars_widgets = get_option('sidebars_widgets', array());
|
||||||
|
|
||||||
|
if (! isset($sidebars_widgets['wp_inactive_widgets'])) {
|
||||||
|
$sidebars_widgets['wp_inactive_widgets'] = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($sidebars_widgets as $sidebar_id => $widgets) {
|
||||||
|
if (! $widgets) continue;
|
||||||
|
if ($sidebar_id === 'wp_inactive_widgets') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($sidebar_id === 'array_version') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($widgets as $widget_id) {
|
||||||
|
$sidebars_widgets['wp_inactive_widgets'][] = $widget_id;
|
||||||
|
}
|
||||||
|
|
||||||
|
$sidebars_widgets[$sidebar_id] = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
update_option('sidebars_widgets', $sidebars_widgets);
|
||||||
|
unset($sidebars_widgets['array_version']);
|
||||||
|
|
||||||
|
set_theme_mod('sidebars_widgets', [
|
||||||
|
'time' => time(),
|
||||||
|
'data' => $sidebars_widgets
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Kick start the demo import process.
|
||||||
|
*
|
||||||
|
* ## OPTIONS
|
||||||
|
*
|
||||||
|
* <demo>
|
||||||
|
* : The demo name.
|
||||||
|
*
|
||||||
|
* <builder>
|
||||||
|
* : The builder name. Default to `gutenberg`.
|
||||||
|
*/
|
||||||
|
\WP_CLI::add_command('blocksy demo import:start', function ($cli_argv) {
|
||||||
|
$args = $this->get_demo_args($cli_argv);
|
||||||
|
|
||||||
|
Plugin::instance()->demo->set_current_demo(
|
||||||
|
$args['demo'] . ':' . $args['builder']
|
||||||
|
);
|
||||||
|
|
||||||
|
$demo_data = Plugin::instance()->demo->fetch_single_demo([
|
||||||
|
'demo' => $args['demo'],
|
||||||
|
'builder' => $args['builder']
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Import the plugins required by the demo.
|
||||||
|
*
|
||||||
|
* ## OPTIONS
|
||||||
|
*
|
||||||
|
* <demo>
|
||||||
|
* : The demo name.
|
||||||
|
*
|
||||||
|
* <builder>
|
||||||
|
* : The builder name. Default to `gutenberg`.
|
||||||
|
*/
|
||||||
|
\WP_CLI::add_command('blocksy demo import:plugins', function ($cli_argv) {
|
||||||
|
$args = $this->get_demo_args($cli_argv);
|
||||||
|
|
||||||
|
$demo_data = Plugin::instance()->demo->fetch_single_demo([
|
||||||
|
'demo' => $args['demo'],
|
||||||
|
'builder' => $args['builder']
|
||||||
|
]);
|
||||||
|
|
||||||
|
$plugins = new DemoInstallPluginsInstaller([
|
||||||
|
'has_streaming' => false,
|
||||||
|
'plugins' => implode(':', $demo_data['plugins'])
|
||||||
|
]);
|
||||||
|
|
||||||
|
$plugins->import();
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Import the options required by the demo.
|
||||||
|
*
|
||||||
|
* ## OPTIONS
|
||||||
|
*
|
||||||
|
* <demo>
|
||||||
|
* : The demo name.
|
||||||
|
*
|
||||||
|
* <builder>
|
||||||
|
* : The builder name. Default to `gutenberg`.
|
||||||
|
*/
|
||||||
|
\WP_CLI::add_command('blocksy demo import:options', function ($cli_argv) {
|
||||||
|
$args = $this->get_demo_args($cli_argv);
|
||||||
|
|
||||||
|
$options = new DemoInstallOptionsInstaller([
|
||||||
|
'has_streaming' => false,
|
||||||
|
'demo_name' => $args['demo'] . ':' . $args['builder']
|
||||||
|
]);
|
||||||
|
|
||||||
|
$options->import();
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Import the widgets required by the demo.
|
||||||
|
*
|
||||||
|
* ## OPTIONS
|
||||||
|
*
|
||||||
|
* <demo>
|
||||||
|
* : The demo name.
|
||||||
|
*
|
||||||
|
* <builder>
|
||||||
|
* : The builder name. Default to `gutenberg`.
|
||||||
|
*/
|
||||||
|
\WP_CLI::add_command('blocksy demo import:widgets', function ($cli_argv) {
|
||||||
|
$args = $this->get_demo_args($cli_argv);
|
||||||
|
|
||||||
|
$widgets = new DemoInstallWidgetsInstaller([
|
||||||
|
'has_streaming' => false,
|
||||||
|
'demo_name' => $args['demo'] . ':' . $args['builder']
|
||||||
|
]);
|
||||||
|
|
||||||
|
$widgets->import();
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Import the content required by the demo.
|
||||||
|
*
|
||||||
|
* ## OPTIONS
|
||||||
|
*
|
||||||
|
* <demo>
|
||||||
|
* : The demo name.
|
||||||
|
*
|
||||||
|
* <builder>
|
||||||
|
* : The builder name. Default to `gutenberg`.
|
||||||
|
*/
|
||||||
|
\WP_CLI::add_command('blocksy demo import:content', function ($cli_argv) {
|
||||||
|
$args = $this->get_demo_args($cli_argv);
|
||||||
|
|
||||||
|
$content = new DemoInstallContentInstaller([
|
||||||
|
'has_streaming' => false,
|
||||||
|
'demo_name' => $args['demo'] . ':' . $args['builder']
|
||||||
|
]);
|
||||||
|
|
||||||
|
$content->import();
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clean the currently installed demo.
|
||||||
|
*/
|
||||||
|
\WP_CLI::add_command('blocksy demo clean', function ($cli_argv) {
|
||||||
|
update_option('blocksy_ext_demos_current_demo', null);
|
||||||
|
|
||||||
|
$eraser = new DemoInstallContentEraser([
|
||||||
|
'has_streaming' => false
|
||||||
|
]);
|
||||||
|
|
||||||
|
$eraser->import();
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Finish the demo import process.
|
||||||
|
*/
|
||||||
|
\WP_CLI::add_command('blocksy demo import:finish', function ($args) {
|
||||||
|
$finish = new DemoInstallFinalActions([
|
||||||
|
'has_streaming' => false
|
||||||
|
]);
|
||||||
|
|
||||||
|
$finish->import();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private function get_demo_args($cli_argv) {
|
||||||
|
if (empty($cli_argv)) {
|
||||||
|
echo 'Please provide demo name.';
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! isset($cli_argv[1])) {
|
||||||
|
$cli_argv[1] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'demo' => $cli_argv[0],
|
||||||
|
'builder' => $cli_argv[1]
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
425
wp-content/plugins/blocksy-companion/framework/dashboard.php
Normal file
425
wp-content/plugins/blocksy-companion/framework/dashboard.php
Normal file
@ -0,0 +1,425 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy;
|
||||||
|
|
||||||
|
class Dashboard {
|
||||||
|
public function __construct() {
|
||||||
|
add_filter(
|
||||||
|
'blocksy:dashboard:redirect-after-activation',
|
||||||
|
function ($url) {
|
||||||
|
return add_query_arg(
|
||||||
|
'page',
|
||||||
|
'ct-dashboard',
|
||||||
|
admin_url('admin.php')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy_add_menu_page',
|
||||||
|
function ($res, $options) {
|
||||||
|
add_menu_page(
|
||||||
|
$options['title'],
|
||||||
|
$options['menu-title'],
|
||||||
|
$options['permision'],
|
||||||
|
$options['top-level-handle'],
|
||||||
|
$options['callback'],
|
||||||
|
$options['icon-url'],
|
||||||
|
2
|
||||||
|
);
|
||||||
|
|
||||||
|
add_submenu_page(
|
||||||
|
$options['top-level-handle'],
|
||||||
|
$options['title'],
|
||||||
|
__('Dashboard', 'blocksy-companion'),
|
||||||
|
$options['permision'],
|
||||||
|
$options['top-level-handle']
|
||||||
|
);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
},
|
||||||
|
10, 2
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'admin_menu',
|
||||||
|
[$this, 'setup_framework_page'],
|
||||||
|
5
|
||||||
|
);
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy:dashboard:redirect-after-activation',
|
||||||
|
function ($url) {
|
||||||
|
return add_query_arg(
|
||||||
|
'page',
|
||||||
|
'ct-dashboard',
|
||||||
|
admin_url('admin.php')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'admin_menu',
|
||||||
|
function () {
|
||||||
|
if (Plugin::instance()->check_if_blocksy_is_activated()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$menu_slug = plugin_basename('ct-dashboard');
|
||||||
|
$hookname = get_plugin_page_hookname('ct-dashboard', '');
|
||||||
|
remove_all_actions($hookname);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
$hookname,
|
||||||
|
function () {
|
||||||
|
$this->welcome_page_template();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
},
|
||||||
|
99999999999
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'admin_enqueue_scripts',
|
||||||
|
[$this, 'enqueue_static'],
|
||||||
|
100
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action('admin_body_class', function ($class) {
|
||||||
|
if (! Plugin::instance()->check_if_blocksy_is_activated()) {
|
||||||
|
return $class;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (function_exists('blc_fs') && blc_fs()->is_activation_mode()) {
|
||||||
|
$class .= ' blocksy-fs-optin-dashboard';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $class;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (function_exists('blc_fs')) {
|
||||||
|
blc_fs()->add_filter('hide_plan_change', '__return_true');
|
||||||
|
blc_fs()->add_filter(
|
||||||
|
'plugin_icon',
|
||||||
|
function ($url) {
|
||||||
|
return BLOCKSY_PATH . '/static/img/logo.jpg';
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
blc_fs()->add_filter(
|
||||||
|
'permission_diagnostic_default',
|
||||||
|
'__return_false'
|
||||||
|
);
|
||||||
|
|
||||||
|
blc_fs()->add_filter(
|
||||||
|
'show_deactivation_feedback_form',
|
||||||
|
'__return_false'
|
||||||
|
);
|
||||||
|
|
||||||
|
blc_fs()->add_filter('hide_freemius_powered_by', '__return_true');
|
||||||
|
|
||||||
|
blc_fs()->add_filter( 'show_deactivation_subscription_cancellation', '__return_false' );
|
||||||
|
|
||||||
|
blc_fs()->add_filter(
|
||||||
|
'connect-message_on-premium',
|
||||||
|
function ($text) {
|
||||||
|
if (strpos($text, '<br>') !== false) {
|
||||||
|
$exploded_message = explode('<br>', $text);
|
||||||
|
|
||||||
|
$text = '<span>' . $exploded_message[0] . '</span>' . $exploded_message[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
return $text;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
blc_fs()->add_filter(
|
||||||
|
'connect_message_on_update',
|
||||||
|
function (
|
||||||
|
$message,
|
||||||
|
$user_first_name,
|
||||||
|
$product_title,
|
||||||
|
$user_login,
|
||||||
|
$site_link,
|
||||||
|
$freemius_link
|
||||||
|
) {
|
||||||
|
$is_network_upgrade_mode = ( fs_is_network_admin() && blc_fs()->is_network_upgrade_mode() );
|
||||||
|
$slug = blc_fs()->get_slug();
|
||||||
|
$is_gdpr_required = \FS_GDPR_Manager::instance()->is_required();
|
||||||
|
$hey_x_text = esc_html( blc_safe_sprintf( fs_text_x_inline( 'Hey %s,', 'greeting', 'hey-x', $slug ), $user_first_name ) );
|
||||||
|
|
||||||
|
$default_optin_message = $is_gdpr_required ?
|
||||||
|
fs_text_inline( 'Never miss an important update - opt in to our security & feature updates notifications, educational content, offers, and non-sensitive diagnostic tracking with %4$s. If you skip this, that\'s okay! %1$s will still work just fine.', 'connect-message_on-update', $slug ) :
|
||||||
|
fs_text_inline( 'Never miss an important update - opt in to our security & feature updates notifications, and non-sensitive diagnostic tracking with %4$s. If you skip this, that\'s okay! %1$s will still work just fine.', 'connect-message_on-update', $slug );
|
||||||
|
|
||||||
|
$default_optin_message = 'Never miss an important update - opt in to our security & feature updates notifications, educational content, offers, and non-sensitive diagnostic tracking with.';
|
||||||
|
|
||||||
|
return (($is_network_upgrade_mode ?
|
||||||
|
'' :
|
||||||
|
/* translators: %s: name (e.g. Hey John,) */
|
||||||
|
'<span>' . $hey_x_text . '</span>'
|
||||||
|
) .
|
||||||
|
blc_safe_sprintf(
|
||||||
|
esc_html( $default_optin_message ),
|
||||||
|
'<b>' . esc_html( blc_fs()->get_plugin_name() ) . '</b>',
|
||||||
|
'<b>' . $user_login . '</b>',
|
||||||
|
$site_link,
|
||||||
|
$freemius_link
|
||||||
|
));
|
||||||
|
|
||||||
|
}, 10, 6
|
||||||
|
);
|
||||||
|
|
||||||
|
blc_fs()->add_action('connect/before', function () {
|
||||||
|
$path = dirname(__FILE__) . '/views/optin.php';
|
||||||
|
|
||||||
|
echo blocksy_render_view(
|
||||||
|
$path,
|
||||||
|
[]
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
blc_fs()->add_action('connect/after', function () {
|
||||||
|
echo '</div>';
|
||||||
|
});
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'wp_ajax_blocksy_fs_connect_again',
|
||||||
|
function () {
|
||||||
|
if (! current_user_can('edit_theme_options')) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
blc_fs()->connect_again();
|
||||||
|
wp_send_json_success();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy_dashboard_localizations',
|
||||||
|
function ($d) {
|
||||||
|
$result = [
|
||||||
|
'is_pro' => false,
|
||||||
|
'is_anonymous' => false,
|
||||||
|
'connect_template' => ''
|
||||||
|
];
|
||||||
|
|
||||||
|
if (function_exists('blc_fs')) {
|
||||||
|
$is_anonymous = blc_fs()->is_anonymous();
|
||||||
|
$connect_template = '';
|
||||||
|
|
||||||
|
if ($is_anonymous) {
|
||||||
|
ob_start();
|
||||||
|
blc_fs()->_connect_page_render();
|
||||||
|
$connect_template = ob_get_clean();
|
||||||
|
}
|
||||||
|
|
||||||
|
$current_plan = blc_get_capabilities()->get_plan();
|
||||||
|
|
||||||
|
// $current_plan = 'free';
|
||||||
|
|
||||||
|
$result = [
|
||||||
|
'is_pro' => $current_plan !== 'free',
|
||||||
|
'current_plan' => $current_plan,
|
||||||
|
|
||||||
|
'pro_starter_sites' => blc_get_capabilities()->get_features()['pro_starter_sites'],
|
||||||
|
'pro_starter_sites_enhanced' => blc_get_capabilities()->get_features()['pro_starter_sites_enhanced'],
|
||||||
|
|
||||||
|
'is_anonymous' => $is_anonymous,
|
||||||
|
'connect_template' => $connect_template
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
Plugin::instance()->premium
|
||||||
|
&&
|
||||||
|
is_callable([
|
||||||
|
Plugin::instance()->premium,
|
||||||
|
'user_wants_beta_updates'
|
||||||
|
])
|
||||||
|
) {
|
||||||
|
$result['has_beta_consent'] = Plugin::instance()->premium->user_wants_beta_updates();
|
||||||
|
}
|
||||||
|
|
||||||
|
return array_merge($result, $d);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action('admin_init', function ($plugin) {
|
||||||
|
if (wp_doing_ajax()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! is_admin()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! is_user_logged_in()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_network_admin()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (intval(get_option('blc_activation_redirect', false)) === wp_get_current_user()->ID) {
|
||||||
|
delete_option('blc_activation_redirect');
|
||||||
|
exit(wp_redirect(admin_url('admin.php?page=ct-dashboard')));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public function enqueue_static() {
|
||||||
|
if (! $this->is_dashboard_page()) return;
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
$deps = apply_filters('blocksy-dashboard-scripts-dependencies', [
|
||||||
|
'wp-i18n',
|
||||||
|
'ct-events',
|
||||||
|
'ct-options-scripts'
|
||||||
|
]);
|
||||||
|
|
||||||
|
if (Plugin::instance()->check_if_blocksy_is_activated()) {
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy-dashboard-scripts',
|
||||||
|
BLOCKSY_URL . 'static/bundle/dashboard.js',
|
||||||
|
$deps,
|
||||||
|
$data['Version'],
|
||||||
|
false
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy-dashboard-scripts',
|
||||||
|
BLOCKSY_URL . 'static/bundle/dashboard-no-theme.js',
|
||||||
|
[
|
||||||
|
'underscore',
|
||||||
|
'react',
|
||||||
|
'react-dom',
|
||||||
|
'wp-element',
|
||||||
|
'wp-date',
|
||||||
|
'wp-i18n',
|
||||||
|
'updates'
|
||||||
|
],
|
||||||
|
$data['Version'],
|
||||||
|
false
|
||||||
|
);
|
||||||
|
|
||||||
|
$slug = 'blocksy';
|
||||||
|
|
||||||
|
$localize_data = [
|
||||||
|
'themeIsInstalled' => (
|
||||||
|
!! wp_get_theme($slug)
|
||||||
|
&&
|
||||||
|
! wp_get_theme($slug)->errors()
|
||||||
|
),
|
||||||
|
'activate'=> current_user_can('switch_themes') ? wp_nonce_url(admin_url('themes.php?action=activate&stylesheet=' . $slug), 'switch-theme_' . $slug) : null
|
||||||
|
];
|
||||||
|
|
||||||
|
$blocksy_data = Plugin::instance()->is_blocksy_data;
|
||||||
|
|
||||||
|
if ($blocksy_data && $blocksy_data['is_correct_theme']) {
|
||||||
|
$localize_data['theme_version_mismatch'] = true;
|
||||||
|
$localize_data['run_updates'] = self_admin_url('update-core.php');
|
||||||
|
}
|
||||||
|
|
||||||
|
wp_localize_script(
|
||||||
|
'blocksy-dashboard-scripts',
|
||||||
|
'ctDashboardLocalizations',
|
||||||
|
$localize_data
|
||||||
|
);
|
||||||
|
|
||||||
|
wp_dequeue_style('ct-dashboard-styles');
|
||||||
|
}
|
||||||
|
|
||||||
|
wp_enqueue_style(
|
||||||
|
'blocksy-dashboard-styles',
|
||||||
|
BLOCKSY_URL . 'static/bundle/dashboard.min.css',
|
||||||
|
['wp-components'],
|
||||||
|
$data['Version']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setup_framework_page() {
|
||||||
|
if (! current_user_can('manage_options')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
$options = [
|
||||||
|
'title' => __('Blocksy', 'blocksy-companion'),
|
||||||
|
'menu-title' => __('Blocksy', 'blocksy-companion'),
|
||||||
|
'permision' => 'manage_options',
|
||||||
|
'top-level-handle' => 'ct-dashboard',
|
||||||
|
'callback' => [$this, 'welcome_page_template'],
|
||||||
|
'icon-url' => apply_filters(
|
||||||
|
'blocksy:dashboard:icon-url',
|
||||||
|
''
|
||||||
|
),
|
||||||
|
'position' => 2,
|
||||||
|
];
|
||||||
|
|
||||||
|
add_menu_page(
|
||||||
|
$options['title'],
|
||||||
|
$options['menu-title'],
|
||||||
|
$options['permision'],
|
||||||
|
$options['top-level-handle'],
|
||||||
|
$options['callback'],
|
||||||
|
$options['icon-url'],
|
||||||
|
2
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function is_dashboard_page() {
|
||||||
|
global $pagenow;
|
||||||
|
|
||||||
|
if (is_network_admin()) {
|
||||||
|
$is_ct_settings =
|
||||||
|
// 'themes.php' === $pagenow &&
|
||||||
|
isset( $_GET['page'] ) && 'blocksy-companion' === $_GET['page'];
|
||||||
|
|
||||||
|
return $is_ct_settings;
|
||||||
|
}
|
||||||
|
|
||||||
|
$is_ct_settings =
|
||||||
|
// 'themes.php' === $pagenow &&
|
||||||
|
isset( $_GET['page'] ) && 'ct-dashboard' === $_GET['page'];
|
||||||
|
|
||||||
|
return $is_ct_settings;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function welcome_page_template() {
|
||||||
|
if (! current_user_can('manage_options')) {
|
||||||
|
wp_die(
|
||||||
|
esc_html(
|
||||||
|
__( 'You do not have sufficient permissions to access this page.', 'blocksy-companion' )
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '<div id="ct-dashboard"></div>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! function_exists('blocksy_render_view')) {
|
||||||
|
function blocksy_render_view(
|
||||||
|
$file_path,
|
||||||
|
$view_variables = [],
|
||||||
|
$default_value = ''
|
||||||
|
) {
|
||||||
|
if (! is_file($file_path)) {
|
||||||
|
return $default_value;
|
||||||
|
}
|
||||||
|
|
||||||
|
// phpcs:ignore WordPress.PHP.DontExtract.extract_extract
|
||||||
|
extract($view_variables, EXTR_REFS);
|
||||||
|
unset($view_variables);
|
||||||
|
|
||||||
|
ob_start();
|
||||||
|
require $file_path;
|
||||||
|
|
||||||
|
return ob_get_clean();
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$config = [
|
||||||
|
// translators: This is a brand name. Preferably to not be translated
|
||||||
|
'name' => _x('Cookies Consent', 'Extension Brand Name', 'blocksy-companion'),
|
||||||
|
'description' => __('Display a cookie acceptance box in order to comply with the privacy regulations in your country.', 'blocksy-companion'),
|
||||||
|
|
||||||
|
'documentation' => 'https://creativethemes.com/blocksy/docs/extensions/cookies-consent/',
|
||||||
|
// 'video' => 'https://www.youtube.com/watch?v=6ZQY9Z9ZQZQ',
|
||||||
|
'customize' => admin_url('customize.php?ct_autofocus=cookie_consent_ext'),
|
||||||
|
'icon' => '<svg with="16" height="16" viewBox="0 0 16 16"><path d="M0 8c0-4.4 3.6-8 8-8 .6 0 1.3.1 1.9.2.2 0 .3.2.4.4 0 .2 0 .4-.1.5-.5.3-.7.8-.7 1.4 0 1 .7 1.8 1.6 2 .3.1.4.3.4.5 0 1.1.9 2 2 2 .6 0 1.1-.3 1.5-.7.1-.1.3-.2.5-.2.2.1.3.2.4.4.1.5.1 1 .1 1.5 0 4.4-3.6 8-8 8s-8-3.6-8-8zm5-2c0-.6-.4-1-1-1s-1 .4-1 1 .4 1 1 1 1-.4 1-1zm3 3c.6 0 1-.4 1-1s-.4-1-1-1-1 .4-1 1 .4 1 1 1zm3 3c0-.6-.4-1-1-1s-1 .4-1 1 .4 1 1 1 1-.4 1-1zm-6 0c.6 0 1-.4 1-1s-.4-1-1-1-1 .4-1 1 .4 1 1 1z"/></svg>',
|
||||||
|
];
|
||||||
|
|
||||||
@ -0,0 +1,333 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$options = [
|
||||||
|
// translators: This is a brand name. Preferably to not be translated
|
||||||
|
'title' => _x('Cookies Consent', 'Extension Brand Name', 'blocksy-companion'),
|
||||||
|
'container' => [ 'priority' => 8 ],
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'cookie_consent_section_options' => [
|
||||||
|
'type' => 'ct-options',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'inner-options' => [
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'General', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'cookie_consent_type' => [
|
||||||
|
'label' => false,
|
||||||
|
'type' => 'ct-image-picker',
|
||||||
|
'value' => 'type-1',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'choices' => [
|
||||||
|
|
||||||
|
'type-1' => [
|
||||||
|
'src' => BLOCKSY_URL . 'framework/extensions/cookies-consent/static/images/type-1.svg',
|
||||||
|
'title' => __( 'Type 1', 'blocksy-companion' ),
|
||||||
|
],
|
||||||
|
|
||||||
|
'type-2' => [
|
||||||
|
'src' => BLOCKSY_URL . 'framework/extensions/cookies-consent/static/images/type-2.svg',
|
||||||
|
'title' => __( 'Type 2', 'blocksy-companion' ),
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'cookie_consent_period' => [
|
||||||
|
'label' => __('Cookie period', 'blocksy-companion'),
|
||||||
|
'type' => 'ct-select',
|
||||||
|
'value' => 'forever',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'choices' => blocksy_ordered_keys(
|
||||||
|
|
||||||
|
[
|
||||||
|
'onehour' => __( 'One hour', 'blocksy-companion' ),
|
||||||
|
'oneday' => __( 'One day', 'blocksy-companion' ),
|
||||||
|
'oneweek' => __( 'One week', 'blocksy-companion' ),
|
||||||
|
'onemonth' => __( 'One month', 'blocksy-companion' ),
|
||||||
|
'threemonths' => __( 'Three months', 'blocksy-companion' ),
|
||||||
|
'sixmonths' => __( 'Six months', 'blocksy-companion' ),
|
||||||
|
'oneyear' => __( 'One year', 'blocksy-companion' ),
|
||||||
|
'forever' => __('Forever', 'blocksy-companion')
|
||||||
|
]
|
||||||
|
|
||||||
|
),
|
||||||
|
],
|
||||||
|
|
||||||
|
'cookie_consent_content' => [
|
||||||
|
'label' => __( 'Content', 'blocksy-companion' ),
|
||||||
|
'type' => 'wp-editor',
|
||||||
|
'value' => __('We use cookies to ensure that we give you the best experience on our website.', 'blocksy-companion'),
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'quicktags' => false,
|
||||||
|
'mediaButtons' => false,
|
||||||
|
'tinymce' => [
|
||||||
|
'toolbar1' => 'bold,italic,link,alignleft,aligncenter,alignright,undo,redo',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'cookie_consent_button_text' => [
|
||||||
|
'label' => __( 'Accept Button text', 'blocksy-companion' ),
|
||||||
|
'type' => 'text',
|
||||||
|
'design' => 'block',
|
||||||
|
'divider' => 'top',
|
||||||
|
'value' => __('Accept', 'blocksy-companion'),
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
'cookie_consent_decline_button_text' => [
|
||||||
|
'label' => __( 'Decline Button text', 'blocksy-companion' ),
|
||||||
|
'type' => 'text',
|
||||||
|
'design' => 'block',
|
||||||
|
'value' => __('Decline', 'blocksy-companion'),
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => [ 'cookie_consent_type' => 'type-1' ],
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'cookieMaxWidth' => [
|
||||||
|
'label' => __( 'Maximum Width', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-slider',
|
||||||
|
'value' => 400,
|
||||||
|
'min' => 200,
|
||||||
|
'max' => 500,
|
||||||
|
'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-title',
|
||||||
|
'label' => __( 'Forms Cookies Content', 'blocksy-companion' ),
|
||||||
|
],
|
||||||
|
|
||||||
|
'forms_cookie_consent_content' => [
|
||||||
|
'label' => false,
|
||||||
|
'type' => 'wp-editor',
|
||||||
|
'value' => blc_safe_sprintf(
|
||||||
|
__('I accept the %sPrivacy Policy%s*', 'blocksy-companion'),
|
||||||
|
'<a href="' . get_privacy_policy_url() . '">',
|
||||||
|
'</a>'
|
||||||
|
),
|
||||||
|
'desc' => __( 'This text will appear under each comment form and subscribe form.', 'blocksy-companion' ),
|
||||||
|
// 'attr' => [ 'data-height' => 'heading-label' ],
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'quicktags' => false,
|
||||||
|
'mediaButtons' => false,
|
||||||
|
'tinymce' => [
|
||||||
|
'toolbar1' => 'bold,italic,link,alignleft,aligncenter,alignright,undo,redo',
|
||||||
|
'forced_root_block' => '',
|
||||||
|
'force_br_newlines' => true,
|
||||||
|
'force_p_newlines' => false
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'Design', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'cookieContentColor' => [
|
||||||
|
'label' => __( 'Text Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-text-color)'
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Hover', 'blocksy-companion' ),
|
||||||
|
'id' => 'hover',
|
||||||
|
'inherit' => 'var(--theme-link-hover-color)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'cookieBackground' => [
|
||||||
|
'label' => __( 'Background Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => 'var(--theme-palette-color-8)',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-title',
|
||||||
|
'label' => __( 'Accept Button', 'blocksy-companion' ),
|
||||||
|
],
|
||||||
|
|
||||||
|
'cookieButtonText' => [
|
||||||
|
'label' => __( 'Font Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
// 'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-button-text-initial-color)',
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Hover', 'blocksy-companion' ),
|
||||||
|
'id' => 'hover',
|
||||||
|
'inherit' => 'var(--theme-button-text-hover-color)',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'cookieButtonBackground' => [
|
||||||
|
'label' => __( 'Background Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
// 'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-button-background-initial-color)'
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Hover', 'blocksy-companion' ),
|
||||||
|
'id' => 'hover',
|
||||||
|
'inherit' => 'var(--theme-button-background-hover-color)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-title',
|
||||||
|
'label' => __( 'Decline Button', 'blocksy-companion' ),
|
||||||
|
],
|
||||||
|
|
||||||
|
'cookieDeclineButtonText' => [
|
||||||
|
'label' => __( 'Font Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
// 'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => 'var(--theme-palette-color-3)',
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'color' => 'var(--theme-palette-color-3)',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Hover', 'blocksy-companion' ),
|
||||||
|
'id' => 'hover',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'cookieDeclineButtonBackground' => [
|
||||||
|
'label' => __( 'Background Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
// 'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => 'rgba(224, 229, 235, 0.6)',
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'color' => 'rgba(224, 229, 235, 1)',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Hover', 'blocksy-companion' ),
|
||||||
|
'id' => 'hover',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
];
|
||||||
@ -0,0 +1,171 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/helpers.php';
|
||||||
|
|
||||||
|
class BlocksyExtensionCookiesConsent {
|
||||||
|
public static function should_display_notification() {
|
||||||
|
return ! isset($_COOKIE['blocksy_cookies_consent_accepted']);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function has_consent() {
|
||||||
|
return (
|
||||||
|
isset($_COOKIE['blocksy_cookies_consent_accepted'])
|
||||||
|
&&
|
||||||
|
$_COOKIE['blocksy_cookies_consent_accepted'] === 'true'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __construct() {
|
||||||
|
add_filter('blocksy-async-scripts-handles', function ($d) {
|
||||||
|
$d[] = 'blocksy-ext-cookies-consent-scripts';
|
||||||
|
return $d;
|
||||||
|
});
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy_extensions_customizer_options',
|
||||||
|
[$this, 'add_options_panel']
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'customize_preview_init',
|
||||||
|
function () {
|
||||||
|
if (! function_exists('get_plugin_data')){
|
||||||
|
require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy-cookies-consent-customizer-sync',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/cookies-consent/static/bundle/sync.js',
|
||||||
|
[ 'ct-scripts', 'customize-preview' ],
|
||||||
|
$data['Version'],
|
||||||
|
true
|
||||||
|
);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action('wp_enqueue_scripts', function () {
|
||||||
|
if (! function_exists('get_plugin_data')) {
|
||||||
|
require_once(ABSPATH . 'wp-admin/includes/plugin.php');
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
if (is_admin()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy-ext-cookies-consent-scripts',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/cookies-consent/static/bundle/main.js',
|
||||||
|
['ct-scripts'],
|
||||||
|
$data['Version'],
|
||||||
|
true
|
||||||
|
);
|
||||||
|
}, 50);
|
||||||
|
|
||||||
|
add_filter('blocksy:general:ct-scripts-localizations', function ($data) {
|
||||||
|
$data['dynamic_styles']['cookie_notification'] = blocksy_cdn_url(
|
||||||
|
BLOCKSY_URL . 'framework/extensions/cookies-consent/static/bundle/main.min.css'
|
||||||
|
);
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
});
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'blocksy:global-dynamic-css:enqueue',
|
||||||
|
'BlocksyExtensionCookiesConsent::add_global_styles',
|
||||||
|
10, 3
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'pre_comment_on_post',
|
||||||
|
function ($post_id) {
|
||||||
|
$data = wp_unslash($_POST);
|
||||||
|
|
||||||
|
if (! isset($data['comment_post_ID'])) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
! isset($data['ct_has_gdprconfirm'])
|
||||||
|
||
|
||||||
|
$data['ct_has_gdprconfirm'] !== 'yes'
|
||||||
|
) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
! isset($data['gdprconfirm'])
|
||||||
|
||
|
||||||
|
$data['gdprconfirm'] !== 'on'
|
||||||
|
) {
|
||||||
|
wp_die(
|
||||||
|
'<p>' . __('Please accept the Privacy Policy in order to comment.', 'blocksy-companion') . '</p>',
|
||||||
|
__('Comment Submission Failure', 'blocksy-companion'),
|
||||||
|
array(
|
||||||
|
'response' => $data,
|
||||||
|
'back_link' => true,
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action('wp', function() {
|
||||||
|
add_filter('woocommerce_product_review_comment_form_args', [$this, 'change_comment_form']);
|
||||||
|
}, 999);
|
||||||
|
|
||||||
|
add_action('wp_ajax_blc_load_cookies_consent_data', [
|
||||||
|
$this,
|
||||||
|
'blc_load_cookies_consent_data',
|
||||||
|
]);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'wp_ajax_nopriv_blc_load_cookies_consent_data',
|
||||||
|
[$this, 'blc_load_cookies_consent_data']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function blc_load_cookies_consent_data() {
|
||||||
|
$scripts = apply_filters('blocksy:cookies-consent:scripts-to-load', [], PHP_INT_MAX);
|
||||||
|
|
||||||
|
wp_send_json_success([
|
||||||
|
'scripts' => $scripts,
|
||||||
|
'consent_output' => blocksy_ext_cookies_consent_output(),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function change_comment_form($comment_form) {
|
||||||
|
$comment_form['comment_field'] .= blocksy_ext_cookies_checkbox('reviews');
|
||||||
|
|
||||||
|
return $comment_form;
|
||||||
|
}
|
||||||
|
|
||||||
|
static public function add_global_styles($args) {
|
||||||
|
blocksy_theme_get_dynamic_styles(array_merge([
|
||||||
|
'path' => dirname(__FILE__) . '/global.php',
|
||||||
|
'chunk' => 'global',
|
||||||
|
], $args));
|
||||||
|
}
|
||||||
|
|
||||||
|
static public function onDeactivation() {
|
||||||
|
remove_action(
|
||||||
|
'blocksy:global-dynamic-css:enqueue',
|
||||||
|
'BlocksyExtensionCookiesConsent::add_global_styles',
|
||||||
|
10, 3
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function add_options_panel($options) {
|
||||||
|
$options['cookie_consent_ext'] = blocksy_get_options(
|
||||||
|
dirname(__FILE__) . '/customizer.php',
|
||||||
|
[],
|
||||||
|
false
|
||||||
|
);
|
||||||
|
|
||||||
|
return $options;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1,127 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// Content color
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('cookieContentColor'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
'hover' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.cookie-notification',
|
||||||
|
'variable' => 'theme-text-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'selector' => '.cookie-notification',
|
||||||
|
'variable' => 'theme-link-hover-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
// Accept button color
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('cookieButtonText'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
'hover' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.cookie-notification .ct-cookies-accept-button',
|
||||||
|
'variable' => 'theme-button-text-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'selector' => '.cookie-notification .ct-cookies-accept-button',
|
||||||
|
'variable' => 'theme-button-text-hover-color'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('cookieButtonBackground'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
'hover' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.cookie-notification .ct-cookies-accept-button',
|
||||||
|
'variable' => 'theme-button-background-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'selector' => '.cookie-notification .ct-cookies-accept-button',
|
||||||
|
'variable' => 'theme-button-background-hover-color'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
// Decline button color
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('cookieDeclineButtonText'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => 'var(--theme-palette-color-3)' ],
|
||||||
|
'hover' => [ 'color' => 'var(--theme-palette-color-3)' ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.cookie-notification .ct-cookies-decline-button',
|
||||||
|
'variable' => 'theme-button-text-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'selector' => '.cookie-notification .ct-cookies-decline-button',
|
||||||
|
'variable' => 'theme-button-text-hover-color'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('cookieDeclineButtonBackground'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => 'rgba(224, 229, 235, 0.6)' ],
|
||||||
|
'hover' => [ 'color' => 'rgba(224, 229, 235, 1)' ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.cookie-notification .ct-cookies-decline-button',
|
||||||
|
'variable' => 'theme-button-background-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'selector' => '.cookie-notification .ct-cookies-decline-button',
|
||||||
|
'variable' => 'theme-button-background-hover-color'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
|
||||||
|
// Background color
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('cookieBackground'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => 'var(--theme-palette-color-8)' ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.cookie-notification',
|
||||||
|
'variable' => 'backgroundColor'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
$cookieMaxWidth = blocksy_get_theme_mod( 'cookieMaxWidth', 400 );
|
||||||
|
$css->put(
|
||||||
|
'.cookie-notification',
|
||||||
|
'--maxWidth: ' . $cookieMaxWidth . 'px'
|
||||||
|
);
|
||||||
|
|
||||||
@ -0,0 +1,71 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
function blocksy_ext_cookies_consent_output() {
|
||||||
|
$content = blocksy_get_theme_mod(
|
||||||
|
'cookie_consent_content',
|
||||||
|
__('We use cookies to ensure that we give you the best experience on our website.', 'blocksy-companion')
|
||||||
|
);
|
||||||
|
|
||||||
|
$accept_button_text = blocksy_get_theme_mod('cookie_consent_button_text', __('Accept', 'blocksy-companion'));
|
||||||
|
$decline_button_text = blocksy_get_theme_mod('cookie_consent_decline_button_text', __('Decline', 'blocksy-companion'));
|
||||||
|
|
||||||
|
$period = blocksy_get_theme_mod('cookie_consent_period', 'forever');
|
||||||
|
$type = blocksy_get_theme_mod('cookie_consent_type', 'type-1');
|
||||||
|
|
||||||
|
$class = 'container';
|
||||||
|
|
||||||
|
if ( $type === 'type-2' ) {
|
||||||
|
$class = 'ct-container';
|
||||||
|
}
|
||||||
|
|
||||||
|
ob_start();
|
||||||
|
|
||||||
|
?>
|
||||||
|
|
||||||
|
<div class="cookie-notification ct-fade-in-start" data-period="<?php echo esc_attr($period) ?>" data-type="<?php echo esc_attr($type) ?>">
|
||||||
|
|
||||||
|
<div class="<?php echo esc_attr($class) ?>">
|
||||||
|
<?php if (!empty($content)) { ?>
|
||||||
|
<div class="ct-cookies-content"><?php echo wp_kses_post($content) ?></div>
|
||||||
|
<?php } ?>
|
||||||
|
|
||||||
|
<div class="ct-button-group">
|
||||||
|
<button type="button" class="ct-button ct-cookies-accept-button"><?php echo esc_html($accept_button_text) ?></button>
|
||||||
|
|
||||||
|
<button type="button" class="ct-button ct-cookies-decline-button"><?php echo esc_html($decline_button_text) ?></button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<?php
|
||||||
|
|
||||||
|
return ob_get_clean();
|
||||||
|
}
|
||||||
|
|
||||||
|
function blocksy_ext_cookies_checkbox($prefix = '') {
|
||||||
|
ob_start();
|
||||||
|
|
||||||
|
if (! empty($prefix)) {
|
||||||
|
$prefix = '_' . $prefix;
|
||||||
|
}
|
||||||
|
|
||||||
|
$message = blocksy_get_theme_mod(
|
||||||
|
'forms_cookie_consent_content',
|
||||||
|
blc_safe_sprintf(
|
||||||
|
__('I accept the %sPrivacy Policy%s', 'blocksy-companion'),
|
||||||
|
'<a href="' . get_privacy_policy_url() . '">',
|
||||||
|
'</a>'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
?>
|
||||||
|
|
||||||
|
<p class="gdpr-confirm-policy">
|
||||||
|
<input name="ct_has_gdprconfirm" type="hidden" value="yes">
|
||||||
|
<input id="gdprconfirm<?php echo $prefix ?>" class="ct-checkbox" name="gdprconfirm" type="checkbox" required><label for="gdprconfirm<?php echo $prefix ?>"><?php echo $message ?></label>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<?php
|
||||||
|
|
||||||
|
return ob_get_clean();
|
||||||
|
}
|
||||||
File diff suppressed because one or more lines are too long
@ -0,0 +1,8 @@
|
|||||||
|
/**
|
||||||
|
* - v2.0.37
|
||||||
|
*
|
||||||
|
* Copyright (c) 2024
|
||||||
|
* Licensed GPLv2+
|
||||||
|
*/
|
||||||
|
|
||||||
|
.cookie-notification{position:fixed;inset-inline-start:var(--theme-frame-size, 0px);bottom:var(--theme-frame-size, 0px);z-index:999999;color:var(--theme-text-color)}@media(max-width: 689.98px){.cookie-notification{inset-inline-end:var(--theme-frame-size, 0px)}}.cookie-notification>div{display:flex;flex-direction:column;gap:20px;padding:20px 0}@media(max-width: 689.98px){.cookie-notification>div{align-items:center}}@media(max-width: 689.98px){.cookie-notification[data-type=type-1]{background:var(--backgroundColor)}}@media(min-width: 690px){.cookie-notification[data-type=type-1]{padding:0 25px 25px 25px}}.cookie-notification[data-type=type-1] .container{position:relative}@media(max-width: 689.98px){.cookie-notification[data-type=type-1] .container{width:88%;margin:0 auto}}@media(min-width: 690px){.cookie-notification[data-type=type-1] .container{background:var(--backgroundColor);box-shadow:0px 5px 30px -5px rgba(34,56,101,.15);padding:30px;border-radius:3px;max-width:var(--maxWidth)}}.cookie-notification[data-type=type-2]{inset-inline-end:var(--theme-frame-size, 0px);padding-inline-end:var(--scrollbar-width, 0px);background:var(--backgroundColor)}@media(min-width: 690px){.cookie-notification[data-type=type-2] .ct-container{flex-direction:initial;align-items:center;justify-content:center}}.cookie-notification .ct-cookies-content{font-size:14px;line-height:1.4}.cookie-notification .ct-cookies-content>*:last-child{margin-bottom:0}.cookie-notification .ct-cookies-content a{text-decoration:underline}@media(max-width: 689.98px){.cookie-notification .ct-cookies-content{text-align:center}}.cookie-notification .ct-button-group{display:flex;gap:10px}.cookie-notification .ct-button-group .ct-button{--theme-button-font-size: 13px;--theme-button-min-height: 35px;--theme-button-padding: 0 20px;--theme-button-shadow: none;--theme-button-transform: none}@media(max-width: 479.98px){.cookie-notification .ct-button-group .ct-button{flex:1}}.cookie-notification.ct-fade-in-start,.cookie-notification.ct-fade-in-end,.cookie-notification.ct-fade-start,.cookie-notification.ct-fade-end{transition:all .3s ease}.cookie-notification.ct-fade-in-start{opacity:0;transform:translate3d(0, 15px, 0)}.cookie-notification.ct-fade-end{opacity:0;transform:translate3d(0, 15px, 0)}
|
||||||
@ -0,0 +1 @@
|
|||||||
|
!function(){"use strict";var t={n:function(e){var o=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(o,{a:o}),o},d:function(e,o){for(var n in o)t.o(o,n)&&!t.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:o[n]})},o:function(t,e){return Object.prototype.hasOwnProperty.call(t,e)}},e=window.ctEvents;function o(t,e){var o=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),o.push.apply(o,n)}return o}function n(t){for(var e=1;e<arguments.length;e++){var n=null!=arguments[e]?arguments[e]:{};e%2?o(Object(n),!0).forEach((function(e){r(t,e,n[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(n)):o(Object(n)).forEach((function(e){Object.defineProperty(t,e,Object.getOwnPropertyDescriptor(n,e))}))}return t}function r(t,e,o){return e in t?Object.defineProperty(t,e,{value:o,enumerable:!0,configurable:!0,writable:!0}):t[e]=o,t}function c(t){return function(t){if(Array.isArray(t))return i(t)}(t)||function(t){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(t))return Array.from(t)}(t)||function(t,e){if(!t)return;if("string"==typeof t)return i(t,e);var o=Object.prototype.toString.call(t).slice(8,-1);"Object"===o&&t.constructor&&(o=t.constructor.name);if("Map"===o||"Set"===o)return Array.from(t);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return i(t,e)}(t)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function i(t,e){(null==e||e>t.length)&&(e=t.length);for(var o=0,n=new Array(e);o<e;o++)n[o]=t[o];return n}t.n(e)().on("ct:customizer:sync:collect-variable-descriptors",(function(t){t.result=n(n({},t.result),{},{cookieContentColor:[{selector:".cookie-notification",variable:"theme-text-color",type:"color:default"},{selector:".cookie-notification",variable:"theme-link-hover-color",type:"color:hover"}],cookieBackground:{selector:".cookie-notification",variable:"backgroundColor",type:"color"},cookieButtonText:[{selector:".cookie-notification .ct-cookies-accept-button",variable:"theme-button-text-initial-color",type:"color:default"},{selector:".cookie-notification .ct-cookies-accept-button",variable:"theme-button-text-hover-color",type:"color:hover"}],cookieButtonBackground:[{selector:".cookie-notification .ct-cookies-accept-button",variable:"theme-button-background-initial-color",type:"color:default"},{selector:".cookie-notification .ct-cookies-accept-button",variable:"theme-button-background-hover-color",type:"color:hover"}],cookieDeclineButtonText:[{selector:".cookie-notification .ct-cookies-decline-button",variable:"theme-button-text-initial-color",type:"color:default"},{selector:".cookie-notification .ct-cookies-decline-button",variable:"theme-button-text-hover-color",type:"color:hover"}],cookieDeclineButtonBackground:[{selector:".cookie-notification .ct-cookies-decline-button",variable:"theme-button-background-initial-color",type:"color:default"},{selector:".cookie-notification .ct-cookies-decline-button",variable:"theme-button-background-hover-color",type:"color:hover"}],cookieMaxWidth:{selector:".cookie-notification",variable:"maxWidth",unit:"px"}})}));var u=function(){var t=document.querySelector(".cookie-notification");if(t){t.querySelector(".ct-cookies-content")&&(t.querySelector(".ct-cookies-content").innerHTML=wp.customize("cookie_consent_content")()),t.querySelector("button.ct-cookies-accept-button").innerHTML=wp.customize("cookie_consent_button_text")();var e=wp.customize("cookie_consent_type")();t.dataset.type=e,t.firstElementChild.classList.remove("ct-container","container"),t.firstElementChild.classList.add("type-1"===e?"container":"ct-container")}};wp.customize("cookie_consent_content",(function(t){return t.bind((function(t){u()}))})),wp.customize("cookie_consent_button_text",(function(t){return t.bind((function(t){return u()}))})),wp.customize("cookie_consent_type",(function(t){return t.bind((function(t){return u()}))})),wp.customize("forms_cookie_consent_content",(function(t){return t.bind((function(t){return c(document.querySelectorAll(".gdpr-confirm-policy label")).map((function(e){return e.innerHTML=t}))}))}))}();
|
||||||
@ -0,0 +1,37 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Generator: Adobe Illustrator 23.0.4, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
||||||
|
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
||||||
|
viewBox="0 0 100 70" style="enable-background:new 0 0 100 70;" xml:space="preserve">
|
||||||
|
<style type="text/css">
|
||||||
|
.st0{fill:#FFFFFF;}
|
||||||
|
.st1{fill:#EDEFF0;}
|
||||||
|
.st2{fill:#565D66;}
|
||||||
|
.st3{fill:#4F5459;}
|
||||||
|
.st4{fill:#6E747A;}
|
||||||
|
</style>
|
||||||
|
<path class="st0" d="M13,73.5c-1.4,0-2.5-1.1-2.5-2.5V13c0-1.4,1.1-2.5,2.5-2.5h74c1.4,0,2.5,1.1,2.5,2.5v58c0,1.4-1.1,2.5-2.5,2.5
|
||||||
|
H13z"/>
|
||||||
|
<path class="st1" d="M11,11h78v14H11V11z"/>
|
||||||
|
<path class="st2" d="M87,11c1.1,0,2,0.9,2,2v58c0,1.1-0.9,2-2,2H13c-1.1,0-2-0.9-2-2V13c0-1.1,0.9-2,2-2H87 M87,10H13
|
||||||
|
c-1.7,0-3,1.3-3,3v58c0,1.7,1.3,3,3,3h74c1.6,0,3-1.3,3-3V13C90,11.3,88.6,10,87,10z"/>
|
||||||
|
<path class="st3" d="M77.5,18.5h-4c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h4c0.3,0,0.5,0.2,0.5,0.5S77.8,18.5,77.5,18.5z
|
||||||
|
M70.5,18.5h-4c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h4c0.3,0,0.5,0.2,0.5,0.5S70.8,18.5,70.5,18.5z M63.5,18.5h-4
|
||||||
|
c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h4c0.3,0,0.5,0.2,0.5,0.5S63.8,18.5,63.5,18.5z M22.4,16.5c0.5-0.9,1.4-1.4,2.4-1.4
|
||||||
|
c0.7,0,1.3,0.3,1.8,0.7c-0.1,0-0.3,0-0.4,0.1c-0.4,0.2-0.5,0.8,0,1.1c0.3,0.2,0.4,0.6,0.4,0.9s-0.7,1.5-0.7,1.5l-0.6-2.2V17
|
||||||
|
c0-0.1,0-0.1,0.1-0.2l0.1-0.1h0.3v-0.2H24v0.2h0.1c0.1,0,0.1,0.1,0.2,0.1c0.1,0.1,0.1,0.3,0.2,0.5l0.2,0.8l-0.5,1.2L23.6,17
|
||||||
|
c0,0,0-0.2,0.1-0.2l0.1-0.1v-0.2C23.8,16.5,22.4,16.5,22.4,16.5z M22.7,16.9c0,0-0.1-0.2-0.3-0.2h-0.1c-0.1,0.3-0.2,0.7-0.2,1.1
|
||||||
|
c0,1.1,0.7,2.1,1.7,2.5L22.7,16.9z M27.2,16.5c0.1,0.2,0,0.5-0.1,0.9c-0.3,0.9-0.9,2.4-1.2,3c1-0.4,1.6-1.4,1.6-2.5
|
||||||
|
C27.6,17.4,27.4,16.9,27.2,16.5 M24.9,18.8l-0.7,1.7c0.2,0,0.4,0.1,0.6,0.1s0.5,0,0.7-0.1L24.9,18.8z"/>
|
||||||
|
<g>
|
||||||
|
<path class="st4" d="M48.2,65.9H16.6c-0.5,0-1-0.5-1-1V45.7c0-0.6,0.5-1,1-1h31.6c0.5,0,1,0.4,1,1v19.1
|
||||||
|
C49.2,65.4,48.8,65.9,48.2,65.9z"/>
|
||||||
|
<path class="st0" d="M35.9,53.3h-17c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h17c0.3,0,0.5,0.2,0.5,0.5S36.2,53.3,35.9,53.3z"/>
|
||||||
|
<path class="st0" d="M24.7,56.3h-5.8c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h5.8c0.3,0,0.5,0.2,0.5,0.5S25,56.3,24.7,56.3z"/>
|
||||||
|
<path class="st0" d="M35.9,56.3h-9.2c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h9.2c0.3,0,0.5,0.2,0.5,0.5S36.2,56.3,35.9,56.3z"/>
|
||||||
|
<path class="st0" d="M27.8,63.2h-7.3c-1.1,0-2.1-0.9-2.1-2.1l0,0c0-1.1,0.9-2.1,2.1-2.1h7.3c1.1,0,2.1,0.9,2.1,2.1l0,0
|
||||||
|
C29.9,62.3,28.9,63.2,27.8,63.2z"/>
|
||||||
|
<path class="st0" d="M43.7,53.3h-5.8c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h5.8c0.3,0,0.5,0.2,0.5,0.5S44,53.3,43.7,53.3z"/>
|
||||||
|
<path class="st0" d="M38.7,49.9H19.4c-0.6,0-1-0.5-1-1l0,0c0-0.6,0.5-1,1-1h19.2c0.6,0,1,0.5,1,1l0,0
|
||||||
|
C39.7,49.4,39.2,49.9,38.7,49.9z"/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 2.7 KiB |
@ -0,0 +1,34 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Generator: Adobe Illustrator 23.0.4, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
||||||
|
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
||||||
|
viewBox="0 0 100 70" style="enable-background:new 0 0 100 70;" xml:space="preserve">
|
||||||
|
<style type="text/css">
|
||||||
|
.st0{fill:#FFFFFF;}
|
||||||
|
.st1{fill:#6E747A;}
|
||||||
|
.st2{fill:#EDEFF0;}
|
||||||
|
.st3{fill:#565D66;}
|
||||||
|
.st4{fill:#4F5459;}
|
||||||
|
</style>
|
||||||
|
<path class="st0" d="M13,73.5c-1.4,0-2.5-1.1-2.5-2.5V13c0-1.4,1.1-2.5,2.5-2.5h74c1.4,0,2.5,1.1,2.5,2.5v58c0,1.4-1.1,2.5-2.5,2.5
|
||||||
|
H13z"/>
|
||||||
|
<g>
|
||||||
|
<rect x="10.4" y="57.2" class="st1" width="79.1" height="13"/>
|
||||||
|
<path class="st0" d="M32.3,66.5h-17c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h17c0.3,0,0.5,0.2,0.5,0.5S32.6,66.5,32.3,66.5z"/>
|
||||||
|
<path class="st0" d="M43.9,66.5h-9.2c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h9.2c0.3,0,0.5,0.2,0.5,0.5S44.2,66.5,43.9,66.5z"/>
|
||||||
|
<path class="st0" d="M84.2,66.1h-7.3c-1.1,0-2.1-0.9-2.1-2.1l0,0c0-1.1,0.9-2.1,2.1-2.1h7.3c1.1,0,2.1,0.9,2.1,2.1l0,0
|
||||||
|
C86.3,65.2,85.4,66.1,84.2,66.1z"/>
|
||||||
|
<path class="st0" d="M51.9,66.5h-5.8c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h5.8c0.3,0,0.5,0.2,0.5,0.5S52.2,66.5,51.9,66.5z"/>
|
||||||
|
<path class="st0" d="M35.1,63H15.9c-0.6,0-1-0.5-1-1l0,0c0-0.6,0.5-1,1-1h19.2c0.6,0,1,0.5,1,1l0,0C36.1,62.6,35.7,63,35.1,63z"/>
|
||||||
|
</g>
|
||||||
|
<path class="st2" d="M11,11h78v14H11V11z"/>
|
||||||
|
<path class="st3" d="M87,11c1.1,0,2,0.9,2,2v58c0,1.1-0.9,2-2,2H13c-1.1,0-2-0.9-2-2V13c0-1.1,0.9-2,2-2H87 M87,10H13
|
||||||
|
c-1.7,0-3,1.3-3,3v58c0,1.7,1.3,3,3,3h74c1.6,0,3-1.3,3-3V13C90,11.3,88.6,10,87,10z"/>
|
||||||
|
<path class="st4" d="M77.5,18.5h-4c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h4c0.3,0,0.5,0.2,0.5,0.5S77.8,18.5,77.5,18.5z
|
||||||
|
M70.5,18.5h-4c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h4c0.3,0,0.5,0.2,0.5,0.5S70.8,18.5,70.5,18.5z M63.5,18.5h-4
|
||||||
|
c-0.3,0-0.5-0.2-0.5-0.5s0.2-0.5,0.5-0.5h4c0.3,0,0.5,0.2,0.5,0.5S63.8,18.5,63.5,18.5z M22.4,16.5c0.5-0.9,1.4-1.4,2.4-1.4
|
||||||
|
c0.7,0,1.3,0.3,1.8,0.7c-0.1,0-0.3,0-0.4,0.1c-0.4,0.2-0.5,0.8,0,1.1c0.3,0.2,0.4,0.6,0.4,0.9s-0.7,1.5-0.7,1.5l-0.6-2.2V17
|
||||||
|
c0-0.1,0-0.1,0.1-0.2l0.1-0.1h0.3v-0.2H24v0.2h0.1c0.1,0,0.1,0.1,0.2,0.1c0.1,0.1,0.1,0.3,0.2,0.5l0.2,0.8l-0.5,1.2L23.6,17
|
||||||
|
c0,0,0-0.2,0.1-0.2l0.1-0.1v-0.2C23.8,16.5,22.4,16.5,22.4,16.5z M22.7,16.9c0,0-0.1-0.2-0.3-0.2h-0.1c-0.1,0.3-0.2,0.7-0.2,1.1
|
||||||
|
c0,1.1,0.7,2.1,1.7,2.5L22.7,16.9z M27.2,16.5c0.1,0.2,0,0.5-0.1,0.9c-0.3,0.9-0.9,2.4-1.2,3c1-0.4,1.6-1.4,1.6-2.5
|
||||||
|
C27.6,17.4,27.4,16.9,27.2,16.5 M24.9,18.8l-0.7,1.7c0.2,0,0.4,0.1,0.6,0.1s0.5,0,0.7-0.1L24.9,18.8z"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 2.5 KiB |
@ -0,0 +1,270 @@
|
|||||||
|
/**
|
||||||
|
* Listen and trigger custom events to communicate between javascript components
|
||||||
|
*/
|
||||||
|
window.ctEvents =
|
||||||
|
window.ctEvents ||
|
||||||
|
new (function () {
|
||||||
|
var _events = {}
|
||||||
|
var currentIndentation = 1
|
||||||
|
var debug = false
|
||||||
|
|
||||||
|
this.countAll = function (topic) {
|
||||||
|
return _events[topic]
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make log helper public
|
||||||
|
*
|
||||||
|
* @param {String} [message]
|
||||||
|
* @param {Object} [data]
|
||||||
|
*/
|
||||||
|
this.log = log
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enable/Disable Debug
|
||||||
|
* @param {Boolean} enabled
|
||||||
|
*/
|
||||||
|
this.debug = function (enabled) {
|
||||||
|
debug = Boolean(enabled)
|
||||||
|
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add event listener
|
||||||
|
*
|
||||||
|
* @param event {String | Object}
|
||||||
|
* Can be a:
|
||||||
|
* - single event: 'event1'
|
||||||
|
* - space separated event list: 'event1 event2 event2'
|
||||||
|
* - an object: {event1: function () {}, event2: function () {}}
|
||||||
|
*
|
||||||
|
* @param callback {Function}
|
||||||
|
*/
|
||||||
|
this.on = function (topicStringOrObject, listener) {
|
||||||
|
objectMap(
|
||||||
|
splitTopicStringOrObject(topicStringOrObject, listener),
|
||||||
|
function (eventName, listener) {
|
||||||
|
;(_events[eventName] || (_events[eventName] = [])).push(
|
||||||
|
listener
|
||||||
|
)
|
||||||
|
|
||||||
|
debug && log('✚ ' + eventName)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Same as .on(), but callback will executed only once
|
||||||
|
*/
|
||||||
|
this.one = function (topicStringOrObject, listener) {
|
||||||
|
objectMap(
|
||||||
|
splitTopicStringOrObject(topicStringOrObject, listener),
|
||||||
|
function (eventName, listener) {
|
||||||
|
;(_events[eventName] || (_events[eventName] = [])).push(
|
||||||
|
once(listener)
|
||||||
|
)
|
||||||
|
|
||||||
|
debug && log('✚ [' + eventName + ']')
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
return this
|
||||||
|
|
||||||
|
// https://github.com/jashkenas/underscore/blob/8fc7032295d60aff3620ef85d4aa6549a55688a0/underscore.js#L946
|
||||||
|
function once(func) {
|
||||||
|
var memo
|
||||||
|
|
||||||
|
var times = 2
|
||||||
|
|
||||||
|
return function () {
|
||||||
|
if (--times > 0) {
|
||||||
|
memo = func.apply(this, arguments)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (times <= 1) func = null
|
||||||
|
|
||||||
|
return memo
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* In order to remove one single listener you should give as an argument
|
||||||
|
* the same callback function. If you want to remove *all* listeners from
|
||||||
|
* a particular event you should not pass the second argument.
|
||||||
|
*
|
||||||
|
* @param topicStringOrObject {String | Object}
|
||||||
|
* @param listener {Function | false}
|
||||||
|
*/
|
||||||
|
this.off = function (topicStringOrObject, listener) {
|
||||||
|
objectMap(
|
||||||
|
splitTopicStringOrObject(topicStringOrObject, listener),
|
||||||
|
function (eventName, listener) {
|
||||||
|
if (_events[eventName]) {
|
||||||
|
if (listener) {
|
||||||
|
_events[eventName].splice(
|
||||||
|
_events[eventName].indexOf(listener) >>> 0,
|
||||||
|
1
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
_events[eventName] = []
|
||||||
|
}
|
||||||
|
|
||||||
|
debug && log('✖ ' + eventName)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Trigger an event. In case you provide multiple events via space-separated
|
||||||
|
* string or an object of events it will execute listeners for each event
|
||||||
|
* separatedly. You can use the "all" event to trigger all events.
|
||||||
|
*
|
||||||
|
* @param topicStringOrObject {String | Object}
|
||||||
|
* @param data {Object}
|
||||||
|
*/
|
||||||
|
this.trigger = function (eventName, data) {
|
||||||
|
objectMap(splitTopicStringOrObject(eventName), function (
|
||||||
|
eventName
|
||||||
|
) {
|
||||||
|
log('╭─ ' + eventName, data)
|
||||||
|
|
||||||
|
changeIndentation(+1)
|
||||||
|
|
||||||
|
try {
|
||||||
|
// TODO: REFACTOR THAT!!!!!!!!!
|
||||||
|
// Maybe this is an occasion for using 'all' event???
|
||||||
|
if (eventName === 'fw:options:init') {
|
||||||
|
fw.options.startListeningToEvents(
|
||||||
|
data.$elements || document.body
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
;(_events[eventName] || []).map(dispatchSingleEvent)
|
||||||
|
;(_events['all'] || []).map(dispatchSingleEvent)
|
||||||
|
} catch (e) {
|
||||||
|
console.log(
|
||||||
|
'%c [Events] Exception raised.',
|
||||||
|
'color: red; font-weight: bold;'
|
||||||
|
)
|
||||||
|
|
||||||
|
if (typeof console !== 'undefined') {
|
||||||
|
console.error(e)
|
||||||
|
} else {
|
||||||
|
throw e
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
changeIndentation(-1)
|
||||||
|
|
||||||
|
log('╰─ ' + eventName, data)
|
||||||
|
|
||||||
|
function dispatchSingleEvent(listenerDescriptor) {
|
||||||
|
if (!listenerDescriptor) return
|
||||||
|
|
||||||
|
listenerDescriptor.call(window, data)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
return this
|
||||||
|
|
||||||
|
function changeIndentation(increment) {
|
||||||
|
if (typeof increment != 'undefined') {
|
||||||
|
currentIndentation += increment > 0 ? +1 : -1
|
||||||
|
}
|
||||||
|
|
||||||
|
if (currentIndentation < 0) {
|
||||||
|
currentIndentation = 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if an event has listeners
|
||||||
|
* @param {String} [event]
|
||||||
|
* @return {Boolean}
|
||||||
|
*/
|
||||||
|
this.hasListeners = function (eventName) {
|
||||||
|
if (!_events) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
return (_events[eventName] || []).length > 0
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Probably split string into general purpose object representation for
|
||||||
|
* event names and listeners. This function leaves objects un-modified.
|
||||||
|
*
|
||||||
|
* @param topicStringOrObject {String | Object}
|
||||||
|
* @param listener {Function | false}
|
||||||
|
*
|
||||||
|
* @returns {Object} {
|
||||||
|
* eventname: listener,
|
||||||
|
* otherevent: listener
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
function splitTopicStringOrObject(topicStringOrObject, listener) {
|
||||||
|
if (typeof topicStringOrObject !== 'string') {
|
||||||
|
return topicStringOrObject
|
||||||
|
}
|
||||||
|
|
||||||
|
var arrayOfEvents = topicStringOrObject
|
||||||
|
.replace(/\s\s+/g, ' ')
|
||||||
|
.trim()
|
||||||
|
.split(' ')
|
||||||
|
|
||||||
|
var len = arrayOfEvents.length
|
||||||
|
|
||||||
|
var listenerDescriptor = Object.create(null)
|
||||||
|
|
||||||
|
for (var i = 0; i < len; i++) {
|
||||||
|
listenerDescriptor[arrayOfEvents[i]] = listener
|
||||||
|
}
|
||||||
|
|
||||||
|
return listenerDescriptor
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns a new object with the predicate applied to each value
|
||||||
|
* objectMap({a: 3, b: 5, c: 9}, (key, value) => value + 1); // {a: 4, b: 6, c: 10}
|
||||||
|
* objectMap({a: 3, b: 5, c: 9}, (key, value) => key); // {a: 'a', b: 'b', c: 'c'}
|
||||||
|
* objectMap({a: 3, b: 5, c: 9}, (key, value) => key + value); // {a: 'a3', b: 'b5', c: 'c9'}
|
||||||
|
*
|
||||||
|
* https://github.com/angus-c/just/tree/master/packages/object-map
|
||||||
|
*/
|
||||||
|
function objectMap(obj, predicate) {
|
||||||
|
var result = {}
|
||||||
|
var keys = Object.keys(obj)
|
||||||
|
var len = keys.length
|
||||||
|
|
||||||
|
for (var i = 0; i < len; i++) {
|
||||||
|
var key = keys[i]
|
||||||
|
result[key] = predicate(key, obj[key])
|
||||||
|
}
|
||||||
|
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
||||||
|
function log(message, data) {
|
||||||
|
if (!debug) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof data != 'undefined') {
|
||||||
|
console.log('[Event] ' + getIndentation() + message, '─', data)
|
||||||
|
} else {
|
||||||
|
console.log('[Event] ' + getIndentation() + message)
|
||||||
|
}
|
||||||
|
|
||||||
|
function getIndentation() {
|
||||||
|
return new Array(currentIndentation).join('│ ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})()
|
||||||
@ -0,0 +1,192 @@
|
|||||||
|
import ctEvents from 'ct-events'
|
||||||
|
import cookie from 'js-cookie'
|
||||||
|
|
||||||
|
import { loadStyle } from 'blocksy-frontend'
|
||||||
|
|
||||||
|
const onKeydown = (event) => {
|
||||||
|
if (event.keyCode !== 27) return
|
||||||
|
hideCookieConsent(document.querySelector('.cookie-notification'))
|
||||||
|
}
|
||||||
|
|
||||||
|
const showCookieConsent = (node) => {
|
||||||
|
document.addEventListener('keyup', onKeydown)
|
||||||
|
|
||||||
|
requestAnimationFrame(() => {
|
||||||
|
node.classList.remove('ct-fade-in-start')
|
||||||
|
node.classList.add('ct-fade-in-end')
|
||||||
|
|
||||||
|
whenTransitionEnds(node, () => {
|
||||||
|
node.classList.remove('ct-fade-in-end')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
const hideCookieConsent = (node) => {
|
||||||
|
document.removeEventListener('keyup', onKeydown)
|
||||||
|
|
||||||
|
node.classList.add('ct-fade-start')
|
||||||
|
|
||||||
|
requestAnimationFrame(() => {
|
||||||
|
node.classList.remove('ct-fade-start')
|
||||||
|
node.classList.add('ct-fade-end')
|
||||||
|
|
||||||
|
whenTransitionEnds(node, () => {
|
||||||
|
node.parentNode.removeChild(node)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
export const onDocumentLoaded = (cb) => {
|
||||||
|
if (/comp|inter|loaded/.test(document.readyState)) {
|
||||||
|
cb()
|
||||||
|
} else {
|
||||||
|
document.addEventListener('DOMContentLoaded', cb, false)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let cookiesData = {}
|
||||||
|
|
||||||
|
const mountCookieNotification = () => {
|
||||||
|
const notification = document.querySelector('.cookie-notification')
|
||||||
|
|
||||||
|
showCookieConsent(notification)
|
||||||
|
;[...notification.querySelectorAll('button')].map((el) => {
|
||||||
|
el.addEventListener('click', (e) => {
|
||||||
|
e.preventDefault()
|
||||||
|
|
||||||
|
if (el.classList.contains('ct-cookies-accept-button')) {
|
||||||
|
const periods = {
|
||||||
|
onehour: 36e5,
|
||||||
|
oneday: 864e5,
|
||||||
|
oneweek: 7 * 864e5,
|
||||||
|
onemonth: 31 * 864e5,
|
||||||
|
threemonths: 3 * 31 * 864e5,
|
||||||
|
sixmonths: 6 * 31 * 864e5,
|
||||||
|
oneyear: 365 * 864e5,
|
||||||
|
forever: 10000 * 864e5,
|
||||||
|
}
|
||||||
|
|
||||||
|
cookie.set('blocksy_cookies_consent_accepted', 'true', {
|
||||||
|
expires: new Date(
|
||||||
|
new Date() * 1 +
|
||||||
|
periods[el.closest('[data-period]').dataset.period]
|
||||||
|
),
|
||||||
|
sameSite: 'lax',
|
||||||
|
})
|
||||||
|
|
||||||
|
if (cookiesData && cookiesData.scripts) {
|
||||||
|
cookiesData.scripts.map((scriptTag) => {
|
||||||
|
const parser = new DOMParser()
|
||||||
|
const html = parser.parseFromString(
|
||||||
|
scriptTag,
|
||||||
|
'text/html'
|
||||||
|
)
|
||||||
|
|
||||||
|
const scriptsToLoad = html.querySelectorAll('script')
|
||||||
|
|
||||||
|
if (!scriptsToLoad) return
|
||||||
|
;[...scriptsToLoad].map((script) => {
|
||||||
|
const newTag = document.createElement('script')
|
||||||
|
|
||||||
|
if (script.innerHTML) {
|
||||||
|
newTag.innerHTML = script.innerHTML
|
||||||
|
}
|
||||||
|
|
||||||
|
;[...script.attributes].map(({ name, value }) => {
|
||||||
|
newTag.setAttribute(name, value)
|
||||||
|
})
|
||||||
|
|
||||||
|
document.head.appendChild(newTag)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (el.classList.contains('ct-cookies-decline-button')) {
|
||||||
|
const periods = {
|
||||||
|
onehour: 36e5,
|
||||||
|
oneday: 864e5,
|
||||||
|
oneweek: 7 * 864e5,
|
||||||
|
onemonth: 31 * 864e5,
|
||||||
|
threemonths: 3 * 31 * 864e5,
|
||||||
|
sixmonths: 6 * 31 * 864e5,
|
||||||
|
oneyear: 365 * 864e5,
|
||||||
|
forever: 10000 * 864e5,
|
||||||
|
}
|
||||||
|
|
||||||
|
cookie.set('blocksy_cookies_consent_accepted', 'no', {
|
||||||
|
expires: new Date(
|
||||||
|
new Date() * 1 +
|
||||||
|
periods[el.closest('[data-period]').dataset.period]
|
||||||
|
),
|
||||||
|
sameSite: 'lax',
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
hideCookieConsent(notification)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
const initCookies = () => {
|
||||||
|
if (cookie.get('blocksy_cookies_consent_accepted')) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
const body = new FormData()
|
||||||
|
body.append('action', 'blc_load_cookies_consent_data')
|
||||||
|
|
||||||
|
fetch(ct_localizations.ajax_url, {
|
||||||
|
method: 'POST',
|
||||||
|
body,
|
||||||
|
})
|
||||||
|
.then((r) => r.json())
|
||||||
|
.then(({ data }) => {
|
||||||
|
cookiesData = data
|
||||||
|
|
||||||
|
const drawerCanvas = document.querySelector(
|
||||||
|
'.ct-drawer-canvas[data-location="start"]'
|
||||||
|
)
|
||||||
|
|
||||||
|
loadStyle(ct_localizations.dynamic_styles.cookie_notification).then(
|
||||||
|
() => {
|
||||||
|
drawerCanvas.insertAdjacentHTML(
|
||||||
|
'beforeend',
|
||||||
|
cookiesData.consent_output
|
||||||
|
)
|
||||||
|
|
||||||
|
mountCookieNotification()
|
||||||
|
}
|
||||||
|
)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
onDocumentLoaded(() => {
|
||||||
|
initCookies()
|
||||||
|
|
||||||
|
if (ctEvents) {
|
||||||
|
ctEvents.on('blocksy:cookies:init', () => {
|
||||||
|
initCookies()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
function whenTransitionEnds(el, cb) {
|
||||||
|
setTimeout(() => {
|
||||||
|
cb()
|
||||||
|
}, 300)
|
||||||
|
return
|
||||||
|
|
||||||
|
const end = () => {
|
||||||
|
el.removeEventListener('transitionend', onEnd)
|
||||||
|
cb()
|
||||||
|
}
|
||||||
|
|
||||||
|
const onEnd = (e) => {
|
||||||
|
if (e.target === el) {
|
||||||
|
end()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
el.addEventListener('transitionend', onEnd)
|
||||||
|
}
|
||||||
@ -0,0 +1,43 @@
|
|||||||
|
import './variables'
|
||||||
|
import ctEvents from 'ct-events'
|
||||||
|
|
||||||
|
const render = () => {
|
||||||
|
const notification = document.querySelector('.cookie-notification')
|
||||||
|
|
||||||
|
if (!notification) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (notification.querySelector('.ct-cookies-content')) {
|
||||||
|
notification.querySelector('.ct-cookies-content').innerHTML =
|
||||||
|
wp.customize('cookie_consent_content')()
|
||||||
|
}
|
||||||
|
|
||||||
|
notification.querySelector('button.ct-cookies-accept-button').innerHTML =
|
||||||
|
wp.customize('cookie_consent_button_text')()
|
||||||
|
|
||||||
|
const type = wp.customize('cookie_consent_type')()
|
||||||
|
|
||||||
|
notification.dataset.type = type
|
||||||
|
|
||||||
|
notification.firstElementChild.classList.remove('ct-container', 'container')
|
||||||
|
notification.firstElementChild.classList.add(
|
||||||
|
type === 'type-1' ? 'container' : 'ct-container'
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
wp.customize('cookie_consent_content', (val) =>
|
||||||
|
val.bind((to) => {
|
||||||
|
render()
|
||||||
|
})
|
||||||
|
)
|
||||||
|
wp.customize('cookie_consent_button_text', (val) => val.bind((to) => render()))
|
||||||
|
wp.customize('cookie_consent_type', (val) => val.bind((to) => render()))
|
||||||
|
|
||||||
|
wp.customize('forms_cookie_consent_content', (val) =>
|
||||||
|
val.bind((to) =>
|
||||||
|
[...document.querySelectorAll('.gdpr-confirm-policy label')].map(
|
||||||
|
(el) => (el.innerHTML = to)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
@ -0,0 +1,23 @@
|
|||||||
|
export const responsiveClassesFor = (id, el) => {
|
||||||
|
el.classList.remove('ct-hidden-sm', 'ct-hidden-md', 'ct-hidden-lg')
|
||||||
|
|
||||||
|
if (!wp.customize(id)) return
|
||||||
|
|
||||||
|
const data = wp.customize(id)() || {
|
||||||
|
mobile: false,
|
||||||
|
tablet: true,
|
||||||
|
desktop: true,
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!data.mobile) {
|
||||||
|
el.classList.add('ct-hidden-sm')
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!data.tablet) {
|
||||||
|
el.classList.add('ct-hidden-md')
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!data.desktop) {
|
||||||
|
el.classList.add('ct-hidden-lg')
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,91 @@
|
|||||||
|
import ctEvents from 'ct-events'
|
||||||
|
|
||||||
|
ctEvents.on(
|
||||||
|
'ct:customizer:sync:collect-variable-descriptors',
|
||||||
|
(allVariables) => {
|
||||||
|
allVariables.result = {
|
||||||
|
...allVariables.result,
|
||||||
|
cookieContentColor: [
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification',
|
||||||
|
variable: 'theme-text-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification',
|
||||||
|
variable: 'theme-link-hover-color',
|
||||||
|
type: 'color:hover',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
cookieBackground: {
|
||||||
|
selector: '.cookie-notification',
|
||||||
|
variable: 'backgroundColor',
|
||||||
|
type: 'color',
|
||||||
|
},
|
||||||
|
|
||||||
|
cookieButtonText: [
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification .ct-cookies-accept-button',
|
||||||
|
variable: 'theme-button-text-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification .ct-cookies-accept-button',
|
||||||
|
variable: 'theme-button-text-hover-color',
|
||||||
|
type: 'color:hover',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
cookieButtonBackground: [
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification .ct-cookies-accept-button',
|
||||||
|
variable: 'theme-button-background-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification .ct-cookies-accept-button',
|
||||||
|
variable: 'theme-button-background-hover-color',
|
||||||
|
type: 'color:hover',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
cookieDeclineButtonText: [
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification .ct-cookies-decline-button',
|
||||||
|
variable: 'theme-button-text-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification .ct-cookies-decline-button',
|
||||||
|
variable: 'theme-button-text-hover-color',
|
||||||
|
type: 'color:hover',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
cookieDeclineButtonBackground: [
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification .ct-cookies-decline-button',
|
||||||
|
variable: 'theme-button-background-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.cookie-notification .ct-cookies-decline-button',
|
||||||
|
variable: 'theme-button-background-hover-color',
|
||||||
|
type: 'color:hover',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
cookieMaxWidth: {
|
||||||
|
selector: '.cookie-notification',
|
||||||
|
variable: 'maxWidth',
|
||||||
|
unit: 'px',
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
@ -0,0 +1,124 @@
|
|||||||
|
@import '../../../../../static/sass/frontend/common-frontend/functions';
|
||||||
|
@import '../../../../../static/sass/frontend/common-frontend/mixins';
|
||||||
|
|
||||||
|
.cookie-notification {
|
||||||
|
position: fixed;
|
||||||
|
inset-inline-start: var(--theme-frame-size, 0px);
|
||||||
|
bottom: var(--theme-frame-size, 0px);
|
||||||
|
z-index: 999999;
|
||||||
|
color: var(--theme-text-color);
|
||||||
|
|
||||||
|
@include media-breakpoint-down (sm) {
|
||||||
|
inset-inline-end: var(--theme-frame-size, 0px);
|
||||||
|
}
|
||||||
|
|
||||||
|
> div {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: 20px;
|
||||||
|
padding: 20px 0;
|
||||||
|
|
||||||
|
@include media-breakpoint-down (sm) {
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// type 1
|
||||||
|
&[data-type='type-1'] {
|
||||||
|
@include media-breakpoint-down (sm) {
|
||||||
|
background: var(--backgroundColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
@include media-breakpoint-up (md) {
|
||||||
|
padding: 0 25px 25px 25px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.container {
|
||||||
|
position: relative;
|
||||||
|
|
||||||
|
@include media-breakpoint-down (sm) {
|
||||||
|
width: 88%;
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
@include media-breakpoint-up (md) {
|
||||||
|
background: var(--backgroundColor);
|
||||||
|
box-shadow: 0px 5px 30px -5px rgba(34, 56, 101, 0.15);
|
||||||
|
padding: 30px;
|
||||||
|
border-radius: 3px;
|
||||||
|
max-width: var(--maxWidth);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// type 2
|
||||||
|
&[data-type='type-2'] {
|
||||||
|
inset-inline-end: var(--theme-frame-size, 0px);
|
||||||
|
padding-inline-end: var(--scrollbar-width, 0px);
|
||||||
|
background: var(--backgroundColor);
|
||||||
|
|
||||||
|
@include media-breakpoint-up (md) {
|
||||||
|
.ct-container {
|
||||||
|
flex-direction: initial;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.ct-cookies-content {
|
||||||
|
font-size: 14px;
|
||||||
|
line-height: 1.4;
|
||||||
|
|
||||||
|
> *:last-child {
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
@include media-breakpoint-down (sm) {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.ct-button-group {
|
||||||
|
display: flex;
|
||||||
|
gap: 10px;
|
||||||
|
|
||||||
|
.ct-button {
|
||||||
|
--theme-button-font-size: 13px;
|
||||||
|
--theme-button-min-height: 35px;
|
||||||
|
--theme-button-padding: 0 20px;
|
||||||
|
--theme-button-shadow: none;
|
||||||
|
--theme-button-transform: none;
|
||||||
|
|
||||||
|
@include media-breakpoint-down (xs) {
|
||||||
|
flex: 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// animation
|
||||||
|
&.ct-fade-in-start,
|
||||||
|
&.ct-fade-in-end,
|
||||||
|
&.ct-fade-start,
|
||||||
|
&.ct-fade-end {
|
||||||
|
transition: all 0.3s ease;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.ct-fade-in-start {
|
||||||
|
opacity: 0;
|
||||||
|
transform: translate3d(0, 15px, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
&.ct-fade-end {
|
||||||
|
opacity: 0;
|
||||||
|
transform: translate3d(0, 15px, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
File diff suppressed because one or more lines are too long
@ -0,0 +1 @@
|
|||||||
|
"use strict";(globalThis.blocksyNewsletterSubscribeExtJsonp=globalThis.blocksyNewsletterSubscribeExtJsonp||[]).push([[564],{564:function(e,t,n){n.r(t);var r=n(381),a=n(343),o=n(652),i=n(184),c=n.n(i);function u(){return u=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},u.apply(this,arguments)}function s(e,t,n,r,a,o,i){try{var c=e[o](i),u=c.value}catch(e){return void n(e)}c.done?t(u):Promise.resolve(u).then(r,a)}function l(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){if("undefined"==typeof Symbol||!(Symbol.iterator in Object(e)))return;var n=[],r=!0,a=!1,o=void 0;try{for(var i,c=e[Symbol.iterator]();!(r=(i=c.next()).done)&&(n.push(i.value),!t||n.length!==t);r=!0);}catch(e){a=!0,o=e}finally{try{r||null==c.return||c.return()}finally{if(a)throw o}}return n}(e,t)||function(e,t){if(!e)return;if("string"==typeof e)return d(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);"Object"===n&&e.constructor&&(n=e.constructor.name);if("Map"===n||"Set"===n)return Array.from(e);if("Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return d(e,t)}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function d(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}var f=null;t.default=function(e){var t=e.value,n=e.onChange,i=l((0,r.useState)(f||[]),2),d=i[0],p=i[1],m=l((0,r.useState)(!f),2),b=m[0],v=m[1],h=function(){var e,t=(e=regeneratorRuntime.mark((function e(){var t,n,r,a=arguments;return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return(!(a.length>0&&void 0!==a[0])||a[0])&&v(!0),(t=new FormData).append("action","blocksy_ext_newsletter_subscribe_get_actual_lists"),t.append("nonce",(window.ctDashboardLocalizations||window.ct_localizations||window.ct_customizer_localizations).dashboard_actions_nonce),e.prev=5,e.next=8,fetch(ajaxurl,{method:"POST",body:t});case 8:if(200!==(n=e.sent).status){e.next=19;break}return e.next=12,n.json();case 12:if(!(r=e.sent).success){e.next=19;break}if("api_key_invalid"===r.data.result){e.next=19;break}return v(!1),p(r.data.result),f=r.data.result,e.abrupt("return");case 19:e.next=23;break;case 21:e.prev=21,e.t0=e.catch(5);case 23:v(!1);case 24:case"end":return e.stop()}}),e,null,[[5,21]])})),function(){var t=this,n=arguments;return new Promise((function(r,a){var o=e.apply(t,n);function i(e){s(o,r,a,i,c,"next",e)}function c(e){s(o,r,a,i,c,"throw",e)}i(void 0)}))});return function(){return t.apply(this,arguments)}}();return(0,r.useEffect)((function(){h(!f)}),[]),0===d.length?(0,r.createElement)("div",{className:"ct-select-input"},(0,r.createElement)("input",{disabled:!0,placeholder:b?(0,o.__)("Loading...","blocksy-companion"):(0,o.__)("Invalid API Key...","blocksy-companion")})):(0,r.createElement)(a.ZP,{selectedItem:t||d[0].id,onChange:function(e){return n(e)},itemToString:function(e){return e?(d.find((function(t){return t.id===e}))||{}).name:""}},(function(e){var t=e.getInputProps,n=e.getItemProps,a=(e.getLabelProps,e.getMenuProps),i=e.isOpen,s=(e.inputValue,e.highlightedIndex),l=e.selectedItem,f=e.openMenu;return(0,r.createElement)("div",{className:"ct-select-input"},(0,r.createElement)("input",u({},t({onFocus:function(){return f()},onClick:function(){return f()}}),{placeholder:(0,o.__)("Select list...","blocksy-companion"),readOnly:!0})),i&&(0,r.createElement)("div",a({className:"ct-select-dropdown"}),d.map((function(e,t){return(0,r.createElement)("div",n({key:e.id,index:t,item:e.id,className:c()("ct-select-dropdown-item",{active:s===t,selected:l===e.id})}),e.name)}))))}))}}}]);
|
||||||
@ -0,0 +1,8 @@
|
|||||||
|
/**
|
||||||
|
* - v2.0.37
|
||||||
|
*
|
||||||
|
* Copyright (c) 2024
|
||||||
|
* Licensed GPLv2+
|
||||||
|
*/
|
||||||
|
|
||||||
|
.ct-newsletter-subscribe-form{display:grid;gap:var(--theme-form-field-gap, 10px);--theme-link-initial-color: var(--text-color, var(--theme-text-color))}@media(min-width: 690px){.ct-newsletter-subscribe-form[data-columns="2"]{grid-template-columns:1fr auto}}@media(min-width: 690px){.ct-newsletter-subscribe-form[data-columns="3"]{grid-template-columns:1fr 1fr auto}}.ct-newsletter-subscribe-form .wp-element-button{width:100%;--theme-button-min-height: var(--theme-form-field-height, 40px);--theme-button-border-radius: var(--theme-form-field-border-radius, 3px)}.ct-newsletter-subscribe-form .gdpr-confirm-policy,.ct-newsletter-subscribe-form .ct-newsletter-subscribe-message{grid-column:1/-1;margin:0}.ct-newsletter-subscribe-form .ct-newsletter-subscribe-message{display:none}.ct-newsletter-subscribe-form .ct-newsletter-subscribe-message a{text-decoration:underline}.ct-newsletter-subscribe-form.subscribe-error .ct-newsletter-subscribe-message,.ct-newsletter-subscribe-form.subscribe-success .ct-newsletter-subscribe-message{display:block}.ct-newsletter-subscribe-form.subscribe-error .ct-newsletter-subscribe-message{color:#e42b2b;font-size:14px}.ct-newsletter-subscribe-form.subscribe-success *:not(.ct-newsletter-subscribe-message){display:none}.ct-newsletter-subscribe-container{margin-top:60px;padding:var(--padding, 30px);color:var(--text-color, var(--theme-text-color));border-radius:var(--theme-border-radius, 0px);border:var(--newsletter-container-border, none);box-shadow:var(--theme-box-shadow, 0px 12px 18px -6px rgba(34, 56, 101, 0.04))}.ct-newsletter-subscribe-container h3{font-size:20px}.ct-newsletter-subscribe-container>*{text-align:center;margin-inline:auto}@media(min-width: 690px){.ct-newsletter-subscribe-container>*{width:80%}}.ct-newsletter-subscribe-container>*:first-child{margin-top:20px}.ct-newsletter-subscribe-container>*:last-child{margin-bottom:20px}.ct-newsletter-subscribe-block form .wp-element-button{border:none;box-sizing:border-box}.ct-newsletter-subscribe-block .gdpr-confirm-policy{pointer-events:none}.ct-newsletter-subscribe-block .gdpr-confirm-policy label{font-size:13px}
|
||||||
@ -0,0 +1 @@
|
|||||||
|
!function(){var e,t,n={427:function(e,t,n){n.p=blocksy_ext_newsletter_subscribe_localization.public_url},313:function(e){"use strict";e.exports=window.React},381:function(e){"use strict";e.exports=window.wp.element},652:function(e){"use strict";e.exports=window.wp.i18n}},r={};function o(e){var t=r[e];if(void 0!==t)return t.exports;var i=r[e]={exports:{}};return n[e](i,i.exports,o),i.exports}o.m=n,o.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(t,{a:t}),t},o.d=function(e,t){for(var n in t)o.o(t,n)&&!o.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},o.f={},o.e=function(e){return Promise.all(Object.keys(o.f).reduce((function(t,n){return o.f[n](e,t),t}),[]))},o.u=function(e){return e+"."+{260:"08e21e7588d65a504adc",564:"64a07c0cc89e5f236217"}[e]+".js"},o.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},e={},t="blocksy-companion:",o.l=function(n,r,i,c){if(e[n])e[n].push(r);else{var u,a;if(void 0!==i)for(var l=document.getElementsByTagName("script"),s=0;s<l.length;s++){var f=l[s];if(f.getAttribute("src")==n||f.getAttribute("data-webpack")==t+i){u=f;break}}u||(a=!0,(u=document.createElement("script")).charset="utf-8",u.timeout=120,o.nc&&u.setAttribute("nonce",o.nc),u.setAttribute("data-webpack",t+i),u.src=n),e[n]=[r];var d=function(t,r){u.onerror=u.onload=null,clearTimeout(p);var o=e[n];if(delete e[n],u.parentNode&&u.parentNode.removeChild(u),o&&o.forEach((function(e){return e(r)})),t)return t(r)},p=setTimeout(d.bind(null,void 0,{type:"timeout",target:u}),12e4);u.onerror=d.bind(null,u.onerror),u.onload=d.bind(null,u.onload),a&&document.head.appendChild(u)}},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},function(){var e;o.g.importScripts&&(e=o.g.location+"");var t=o.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var n=t.getElementsByTagName("script");n.length&&(e=n[n.length-1].src)}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),o.p=e}(),function(){var e={179:0};o.f.j=function(t,n){var r=o.o(e,t)?e[t]:void 0;if(0!==r)if(r)n.push(r[2]);else{var i=new Promise((function(n,o){r=e[t]=[n,o]}));n.push(r[2]=i);var c=o.p+o.u(t),u=new Error;o.l(c,(function(n){if(o.o(e,t)&&(0!==(r=e[t])&&(e[t]=void 0),r)){var i=n&&("load"===n.type?"missing":n.type),c=n&&n.target&&n.target.src;u.message="Loading chunk "+t+" failed.\n("+i+": "+c+")",u.name="ChunkLoadError",u.type=i,u.request=c,r[1](u)}}),"chunk-"+t,t)}};var t=function(t,n){var r,i,[c,u,a]=n,l=0;if(c.some((function(t){return 0!==e[t]}))){for(r in u)o.o(u,r)&&(o.m[r]=u[r]);if(a)a(o)}for(t&&t(n);l<c.length;l++)i=c[l],o.o(e,i)&&e[i]&&e[i][0](),e[i]=0},n=globalThis.blocksyNewsletterSubscribeExtJsonp=globalThis.blocksyNewsletterSubscribeExtJsonp||[];n.forEach(t.bind(null,0)),n.push=t.bind(null,n.push.bind(n))}(),function(){"use strict";o(427);var e=o(381),t=o(652),n=o(313),r=(0,n.lazy)((function(){return Promise.all([o.e(260),o.e(564)]).then(o.bind(o,564))})),i=function(o){return(0,e.createElement)("div",null,(0,e.createElement)(n.Suspense,{fallback:(0,e.createElement)("div",{className:"ct-select-input"},(0,e.createElement)("input",{disabled:!0,placeholder:(0,t.__)("Loading...","blocksy-companion")}))},(0,e.createElement)(r,o)))},c=window.ctEvents,u=o.n(c);document.addEventListener("DOMContentLoaded",(function(){return u().on("blocksy:options:register",(function(e){e["blocksy-newsletter-subscribe"]=i}))}))}()}();
|
||||||
File diff suppressed because one or more lines are too long
@ -0,0 +1 @@
|
|||||||
|
!function(){"use strict";var e={n:function(t){var r=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(r,{a:r}),r},d:function(t,r){for(var s in r)e.o(r,s)&&!e.o(t,s)&&Object.defineProperty(t,s,{enumerable:!0,get:r[s]})},o:function(e,t){return Object.prototype.hasOwnProperty.call(e,t)}},t=window.blocksyCustomizerSync,r=window.ctEvents;function s(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var s=Object.getOwnPropertySymbols(e);t&&(s=s.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,s)}return r}function n(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?s(Object(r),!0).forEach((function(t){o(e,t,r[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):s(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}function o(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}e.n(r)().on("ct:customizer:sync:collect-variable-descriptors",(function(e){e.result=n(n(n({},e.result),{},{newsletter_subscribe_title_color:{selector:".ct-newsletter-subscribe-container",variable:"theme-heading-color",type:"color:default",responsive:!0},newsletter_subscribe_content:[{selector:".ct-newsletter-subscribe-container",variable:"text-color",type:"color:default"},{selector:".ct-newsletter-subscribe-container",variable:"theme-link-hover-color",type:"color:hover"}],newsletter_subscribe_button:[{selector:".ct-newsletter-subscribe-container",variable:"theme-button-background-initial-color",type:"color:default"},{selector:".ct-newsletter-subscribe-container",variable:"theme-button-background-hover-color",type:"color:hover"}],newsletter_subscribe_input_font_color:[{selector:".ct-newsletter-subscribe-container",variable:"theme-form-text-initial-color",type:"color:default"},{selector:".ct-newsletter-subscribe-container",variable:"theme-form-text-focus-color",type:"color:focus"}],newsletter_subscribe_border_color:[{selector:".ct-newsletter-subscribe-container",variable:"theme-form-field-border-initial-color",type:"color:default"},{selector:".ct-newsletter-subscribe-container",variable:"theme-form-field-border-focus-color",type:"color:focus"}],newsletter_subscribe_input_background:[{selector:".ct-newsletter-subscribe-container",variable:"theme-form-field-background-initial-color",type:"color:default"},{selector:".ct-newsletter-subscribe-container",variable:"theme-form-field-background-focus-color",type:"color:focus"}]},(0,t.handleBackgroundOptionFor)({id:"newsletter_subscribe_container_background",selector:".ct-newsletter-subscribe-container",responsive:!0})),{},{newsletter_subscribe_container_border:{selector:".ct-newsletter-subscribe-container",variable:"newsletter-container-border",type:"border",responsive:!0,skip_none:!0},newsletter_subscribe_shadow:{selector:".ct-newsletter-subscribe-container",type:"box-shadow",variable:"theme-box-shadow",responsive:!0},newsletter_subscribe_container_spacing:{selector:".ct-newsletter-subscribe-container",type:"spacing",variable:"padding",responsive:!0},newsletter_subscribe_container_border_radius:{selector:".ct-newsletter-subscribe-container",type:"spacing",variable:"theme-border-radius",responsive:!0}})})),wp.customize("newsletter_subscribe_subscribe_visibility",(function(e){return e.bind((function(e){var r=document.querySelector(".ct-newsletter-subscribe-container");(0,t.responsiveClassesFor)("newsletter_subscribe_subscribe_visibility",r)}))})),(document.body.classList.contains("single")||document.body.classList.contains("page"))&&(0,t.watchOptionsWithPrefix)({getPrefix:function(){return""},getOptionsForPrefix:function(){return["newsletter_subscribe_button_text","newsletter_subscribe_title","newsletter_subscribe_text","newsletter_subscribe_name_label","newsletter_subscribe_mail_label"]},render:function(){if(document.body.classList.contains("single")||document.body.classList.contains("page")){var e=document.querySelector(".ct-newsletter-subscribe-container");e&&((0,t.responsiveClassesFor)("newsletter_subscribe_subscribe_visibility",e),e.querySelector('[name="FNAME"]')&&e.querySelector('[name="FNAME"]').setAttribute("placeholder","".concat(wp.customize("newsletter_subscribe_name_label")())),e.querySelector('[name="EMAIL"]').setAttribute("placeholder","".concat(wp.customize("newsletter_subscribe_mail_label")()," *")),e.querySelector("button").innerHTML=wp.customize("newsletter_subscribe_button_text")(),e.querySelector("h3").innerHTML=wp.customize("newsletter_subscribe_title")(),e.querySelector(".ct-newsletter-subscribe-container > p").innerHTML=wp.customize("newsletter_subscribe_text")())}}})}();
|
||||||
@ -0,0 +1,22 @@
|
|||||||
|
import { createElement, Component } from '@wordpress/element'
|
||||||
|
import { __ } from 'ct-i18n'
|
||||||
|
import { lazy, Suspense } from 'react'
|
||||||
|
|
||||||
|
const ListPickerImplementation = lazy(() =>
|
||||||
|
import('./ListPicker/Implementation')
|
||||||
|
)
|
||||||
|
|
||||||
|
const ListPicker = (props) => (
|
||||||
|
<div>
|
||||||
|
<Suspense
|
||||||
|
fallback={
|
||||||
|
<div className="ct-select-input">
|
||||||
|
<input disabled placeholder={__('Loading...', 'blocksy-companion')} />
|
||||||
|
</div>
|
||||||
|
}>
|
||||||
|
<ListPickerImplementation {...props} />
|
||||||
|
</Suspense>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
|
||||||
|
export default ListPicker
|
||||||
@ -0,0 +1,137 @@
|
|||||||
|
import {
|
||||||
|
createElement,
|
||||||
|
Component,
|
||||||
|
useState,
|
||||||
|
useEffect,
|
||||||
|
Fragment,
|
||||||
|
} from '@wordpress/element'
|
||||||
|
import Downshift from 'downshift'
|
||||||
|
import { __ } from 'ct-i18n'
|
||||||
|
import classnames from 'classnames'
|
||||||
|
|
||||||
|
let listsCache = null
|
||||||
|
|
||||||
|
const ListPickerImplementation = ({ value, onChange }) => {
|
||||||
|
const [lists, setLists] = useState(listsCache || [])
|
||||||
|
const [isLoadingLists, setListsLoading] = useState(!listsCache)
|
||||||
|
|
||||||
|
const maybeFetchLists = async (verbose = true) => {
|
||||||
|
if (verbose) {
|
||||||
|
setListsLoading(true)
|
||||||
|
}
|
||||||
|
|
||||||
|
const body = new FormData()
|
||||||
|
body.append(
|
||||||
|
'action',
|
||||||
|
'blocksy_ext_newsletter_subscribe_get_actual_lists'
|
||||||
|
)
|
||||||
|
|
||||||
|
body.append(
|
||||||
|
'nonce',
|
||||||
|
(
|
||||||
|
window.ctDashboardLocalizations ||
|
||||||
|
window.ct_localizations ||
|
||||||
|
window.ct_customizer_localizations
|
||||||
|
).dashboard_actions_nonce
|
||||||
|
)
|
||||||
|
|
||||||
|
try {
|
||||||
|
const response = await fetch(ajaxurl, {
|
||||||
|
method: 'POST',
|
||||||
|
body,
|
||||||
|
})
|
||||||
|
|
||||||
|
if (response.status === 200) {
|
||||||
|
const body = await response.json()
|
||||||
|
|
||||||
|
if (body.success) {
|
||||||
|
if (body.data.result !== 'api_key_invalid') {
|
||||||
|
setListsLoading(false)
|
||||||
|
setLists(body.data.result)
|
||||||
|
listsCache = body.data.result
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e) {}
|
||||||
|
|
||||||
|
setListsLoading(false)
|
||||||
|
}
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
maybeFetchLists(!listsCache)
|
||||||
|
}, [])
|
||||||
|
|
||||||
|
return lists.length === 0 ? (
|
||||||
|
<div className="ct-select-input">
|
||||||
|
<input
|
||||||
|
disabled
|
||||||
|
placeholder={
|
||||||
|
isLoadingLists
|
||||||
|
? __('Loading...', 'blocksy-companion')
|
||||||
|
: __('Invalid API Key...', 'blocksy-companion')
|
||||||
|
}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
<Downshift
|
||||||
|
selectedItem={value || lists[0].id}
|
||||||
|
onChange={(selection) => onChange(selection)}
|
||||||
|
itemToString={(item) =>
|
||||||
|
item ? (lists.find(({ id }) => id === item) || {}).name : ''
|
||||||
|
}>
|
||||||
|
{({
|
||||||
|
getInputProps,
|
||||||
|
getItemProps,
|
||||||
|
getLabelProps,
|
||||||
|
getMenuProps,
|
||||||
|
isOpen,
|
||||||
|
inputValue,
|
||||||
|
highlightedIndex,
|
||||||
|
selectedItem,
|
||||||
|
openMenu,
|
||||||
|
}) => (
|
||||||
|
<div className="ct-select-input">
|
||||||
|
<input
|
||||||
|
{...getInputProps({
|
||||||
|
onFocus: () => openMenu(),
|
||||||
|
onClick: () => openMenu(),
|
||||||
|
})}
|
||||||
|
placeholder={__('Select list...', 'blocksy-companion')}
|
||||||
|
readOnly
|
||||||
|
/>
|
||||||
|
|
||||||
|
{isOpen && (
|
||||||
|
<div
|
||||||
|
{...getMenuProps({
|
||||||
|
className: 'ct-select-dropdown',
|
||||||
|
})}>
|
||||||
|
{lists.map((item, index) => (
|
||||||
|
<div
|
||||||
|
{...getItemProps({
|
||||||
|
key: item.id,
|
||||||
|
index,
|
||||||
|
item: item.id,
|
||||||
|
className: classnames(
|
||||||
|
'ct-select-dropdown-item',
|
||||||
|
{
|
||||||
|
active:
|
||||||
|
highlightedIndex === index,
|
||||||
|
selected:
|
||||||
|
selectedItem === item.id,
|
||||||
|
}
|
||||||
|
),
|
||||||
|
})}>
|
||||||
|
{item.name}
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</Downshift>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ListPickerImplementation
|
||||||
@ -0,0 +1,10 @@
|
|||||||
|
import './public-path'
|
||||||
|
import { createElement, Fragment, Component } from '@wordpress/element'
|
||||||
|
import ListPicker from './ListPicker'
|
||||||
|
import ctEvents from 'ct-events'
|
||||||
|
|
||||||
|
document.addEventListener('DOMContentLoaded', () =>
|
||||||
|
ctEvents.on('blocksy:options:register', (opts) => {
|
||||||
|
opts['blocksy-newsletter-subscribe'] = ListPicker
|
||||||
|
})
|
||||||
|
)
|
||||||
@ -0,0 +1,294 @@
|
|||||||
|
import { createElement } from '@wordpress/element'
|
||||||
|
import { __ } from 'ct-i18n'
|
||||||
|
import { colors } from './colors'
|
||||||
|
|
||||||
|
import {
|
||||||
|
InspectorControls,
|
||||||
|
useBlockProps,
|
||||||
|
withColors,
|
||||||
|
} from '@wordpress/block-editor'
|
||||||
|
import { PanelBody } from '@wordpress/components'
|
||||||
|
|
||||||
|
import { OptionsPanel, ColorsPanel } from 'blocksy-options'
|
||||||
|
import Preview from './Preview'
|
||||||
|
import { options } from '.'
|
||||||
|
|
||||||
|
const Edit = ({
|
||||||
|
attributes,
|
||||||
|
setAttributes,
|
||||||
|
clientId,
|
||||||
|
|
||||||
|
inputFontColor,
|
||||||
|
setInputFontColor,
|
||||||
|
inputFontColorFocus,
|
||||||
|
setInputFontColorFocus,
|
||||||
|
inputIconColor,
|
||||||
|
setInputIconColor,
|
||||||
|
inputIconColorFocus,
|
||||||
|
setInputIconColorFocus,
|
||||||
|
inputBorderColor,
|
||||||
|
setInputBorderColor,
|
||||||
|
inputBorderColorFocus,
|
||||||
|
setInputBorderColorFocus,
|
||||||
|
inputBackgroundColor,
|
||||||
|
setInputBackgroundColor,
|
||||||
|
inputBackgroundColorFocus,
|
||||||
|
setInputBackgroundColorFocus,
|
||||||
|
|
||||||
|
buttonBackgroundColor,
|
||||||
|
setButtonBackgroundColor,
|
||||||
|
buttonBackgroundColorHover,
|
||||||
|
setButtonBackgroundColorHover,
|
||||||
|
}) => {
|
||||||
|
const radius = attributes?.style?.border?.radius
|
||||||
|
|
||||||
|
const blockProps = useBlockProps({
|
||||||
|
style: {
|
||||||
|
'--theme-form-text-initial-color': inputFontColor?.color,
|
||||||
|
'--theme-form-text-focus-color': inputFontColorFocus?.color,
|
||||||
|
|
||||||
|
'--theme-form-field-border-initial-color': inputBorderColor?.color,
|
||||||
|
'--theme-form-field-border-focus-color':
|
||||||
|
inputBorderColorFocus?.color,
|
||||||
|
|
||||||
|
'--theme-form-field-background-initial-color':
|
||||||
|
inputBackgroundColor?.color,
|
||||||
|
'--theme-form-field-background-focus-color':
|
||||||
|
inputBackgroundColorFocus?.color,
|
||||||
|
...(attributes?.newsletter_subscribe_height
|
||||||
|
? {
|
||||||
|
'--theme-form-field-height': `${attributes.newsletter_subscribe_height}px`,
|
||||||
|
}
|
||||||
|
: {}),
|
||||||
|
...(radius
|
||||||
|
? {
|
||||||
|
'--theme-form-field-border-radius': `${
|
||||||
|
typeof radius === 'string'
|
||||||
|
? radius
|
||||||
|
: `${radius.topLeft} ${radius.topRight} ${radius.bottomLeft} ${radius.bottomRight}`
|
||||||
|
}`,
|
||||||
|
}
|
||||||
|
: {}),
|
||||||
|
...(attributes?.newsletter_subscribe_gap
|
||||||
|
? {
|
||||||
|
'--theme-form-field-gap': `${attributes.newsletter_subscribe_gap}px`,
|
||||||
|
}
|
||||||
|
: {}),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div {...blockProps}>
|
||||||
|
<Preview
|
||||||
|
attributes={attributes}
|
||||||
|
setAttributes={setAttributes}
|
||||||
|
buttonStyles={{
|
||||||
|
...(inputIconColor?.color
|
||||||
|
? {
|
||||||
|
'--theme-button-text-initial-color':
|
||||||
|
inputIconColor.color,
|
||||||
|
}
|
||||||
|
: {}),
|
||||||
|
...(inputIconColorFocus?.color
|
||||||
|
? {
|
||||||
|
'--theme-button-text-hover-color':
|
||||||
|
inputIconColorFocus.color,
|
||||||
|
}
|
||||||
|
: {}),
|
||||||
|
...(buttonBackgroundColor?.color
|
||||||
|
? {
|
||||||
|
'--theme-button-background-initial-color':
|
||||||
|
buttonBackgroundColor.color,
|
||||||
|
}
|
||||||
|
: {}),
|
||||||
|
...(buttonBackgroundColorHover?.color
|
||||||
|
? {
|
||||||
|
'--theme-button-background-hover-color':
|
||||||
|
buttonBackgroundColorHover.color,
|
||||||
|
}
|
||||||
|
: {}),
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
<InspectorControls>
|
||||||
|
<PanelBody>
|
||||||
|
<OptionsPanel
|
||||||
|
purpose={'gutenberg'}
|
||||||
|
onChange={(optionId, optionValue) => {
|
||||||
|
setAttributes({
|
||||||
|
[optionId]: optionValue,
|
||||||
|
})
|
||||||
|
}}
|
||||||
|
options={options}
|
||||||
|
value={attributes}
|
||||||
|
hasRevertButton={false}
|
||||||
|
/>
|
||||||
|
</PanelBody>
|
||||||
|
</InspectorControls>
|
||||||
|
|
||||||
|
<InspectorControls group="styles">
|
||||||
|
<ColorsPanel
|
||||||
|
label={__('Input Font Color', 'blocksy')}
|
||||||
|
resetAll={() => {
|
||||||
|
setInputFontColor(colors.inputFontColor)
|
||||||
|
setInputFontColorFocus(colors.inputFontColorFocus)
|
||||||
|
}}
|
||||||
|
panelId={clientId}
|
||||||
|
settings={[
|
||||||
|
{
|
||||||
|
colorValue: inputFontColor.color,
|
||||||
|
label: __('Initial', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setInputFontColor(
|
||||||
|
value || colors.inputFontColor
|
||||||
|
),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
colorValue: inputFontColorFocus.color,
|
||||||
|
label: __('Focus', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setInputFontColorFocus(
|
||||||
|
value || colors.inputFontColorFocus
|
||||||
|
),
|
||||||
|
},
|
||||||
|
]}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<ColorsPanel
|
||||||
|
label={__('Input Border Color', 'blocksy')}
|
||||||
|
resetAll={() => {
|
||||||
|
setInputBorderColor(colors.inputBorderColor)
|
||||||
|
setInputBorderColorFocus(colors.inputBorderColorFocus)
|
||||||
|
}}
|
||||||
|
panelId={clientId}
|
||||||
|
settings={[
|
||||||
|
{
|
||||||
|
colorValue: inputBorderColor.color,
|
||||||
|
label: __('Initial', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setInputBorderColor(
|
||||||
|
value || colors.inputBorderColor
|
||||||
|
),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
colorValue: inputBorderColorFocus.color,
|
||||||
|
label: __('Focus', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setInputBorderColorFocus(
|
||||||
|
value || colors.inputBorderColorFocus
|
||||||
|
),
|
||||||
|
},
|
||||||
|
]}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<ColorsPanel
|
||||||
|
label={__('Input Background Color', 'blocksy')}
|
||||||
|
resetAll={() => {
|
||||||
|
setInputBackgroundColor(colors.inputBackgroundColor)
|
||||||
|
setInputBackgroundColorFocus(
|
||||||
|
colors.inputBackgroundColorFocus
|
||||||
|
)
|
||||||
|
}}
|
||||||
|
panelId={clientId}
|
||||||
|
settings={[
|
||||||
|
{
|
||||||
|
colorValue: inputBackgroundColor.color,
|
||||||
|
label: __('Initial', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setInputBackgroundColor(
|
||||||
|
value || colors.inputBackgroundColor
|
||||||
|
),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
colorValue: inputBackgroundColorFocus.color,
|
||||||
|
label: __('Focus', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setInputBackgroundColorFocus(
|
||||||
|
value || colors.inputBackgroundColorFocus
|
||||||
|
),
|
||||||
|
},
|
||||||
|
]}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<ColorsPanel
|
||||||
|
label={__('Button Text Color', 'blocksy')}
|
||||||
|
resetAll={() => {
|
||||||
|
setInputIconColor(colors.inputIconColor)
|
||||||
|
setInputIconColorFocus(colors.inputIconColorFocus)
|
||||||
|
}}
|
||||||
|
panelId={clientId}
|
||||||
|
settings={[
|
||||||
|
{
|
||||||
|
colorValue: inputIconColor.color,
|
||||||
|
label: __('Initial', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setInputIconColor(
|
||||||
|
value || colors.inputIconColor
|
||||||
|
),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
colorValue: inputIconColorFocus.color,
|
||||||
|
label: __('Hover', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setInputIconColorFocus(
|
||||||
|
value || colors.inputIconColorFocus
|
||||||
|
),
|
||||||
|
},
|
||||||
|
]}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<ColorsPanel
|
||||||
|
label={__('Button Background Color', 'blocksy')}
|
||||||
|
resetAll={() => {
|
||||||
|
setButtonBackgroundColor(colors.buttonBackgroundColor)
|
||||||
|
setButtonBackgroundColorHover(
|
||||||
|
colors.buttonBackgroundColorHover
|
||||||
|
)
|
||||||
|
}}
|
||||||
|
panelId={clientId}
|
||||||
|
settings={[
|
||||||
|
{
|
||||||
|
colorValue: buttonBackgroundColor.color,
|
||||||
|
label: __('Initial', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setButtonBackgroundColor(
|
||||||
|
value || colors.buttonBackgroundColor
|
||||||
|
),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
colorValue: buttonBackgroundColorHover.color,
|
||||||
|
label: __('Hover', 'blocksy'),
|
||||||
|
enableAlpha: true,
|
||||||
|
onColorChange: (value) =>
|
||||||
|
setButtonBackgroundColorHover(
|
||||||
|
value || colors.buttonBackgroundColorHover
|
||||||
|
),
|
||||||
|
},
|
||||||
|
]}
|
||||||
|
/>
|
||||||
|
</InspectorControls>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default withColors(
|
||||||
|
{ textColor: 'color' },
|
||||||
|
{ inputFontColor: 'color' },
|
||||||
|
{ inputFontColorFocus: 'color' },
|
||||||
|
{ inputIconColor: 'color' },
|
||||||
|
{ inputIconColorFocus: 'color' },
|
||||||
|
{ inputBorderColor: 'color' },
|
||||||
|
{ inputBorderColorFocus: 'color' },
|
||||||
|
{ inputBackgroundColor: 'color' },
|
||||||
|
{ inputBackgroundColorFocus: 'color' },
|
||||||
|
{ buttonBackgroundColor: 'color' },
|
||||||
|
{ buttonBackgroundColorHover: 'color' }
|
||||||
|
)(Edit)
|
||||||
@ -0,0 +1,98 @@
|
|||||||
|
import { createElement } from '@wordpress/element'
|
||||||
|
import { RichText } from '@wordpress/block-editor'
|
||||||
|
import { __ } from 'ct-i18n'
|
||||||
|
|
||||||
|
const { has_cookies_checkbox } = window.blc_newsletter_data
|
||||||
|
|
||||||
|
const cookies_checkbox_enabled = !!parseInt(has_cookies_checkbox)
|
||||||
|
|
||||||
|
const Preview = ({ attributes, buttonStyles, setAttributes }) => {
|
||||||
|
const {
|
||||||
|
newsletter_subscribe_view_type,
|
||||||
|
newsletter_subscribe_name_label,
|
||||||
|
newsletter_subscribe_button_text,
|
||||||
|
has_newsletter_subscribe_name,
|
||||||
|
newsletter_subscribe_mail_label,
|
||||||
|
} = attributes
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className="ct-newsletter-subscribe-block">
|
||||||
|
<form
|
||||||
|
action="#"
|
||||||
|
method="post"
|
||||||
|
target="_blank"
|
||||||
|
className="ct-newsletter-subscribe-form"
|
||||||
|
{...(newsletter_subscribe_view_type !== 'inline'
|
||||||
|
? {}
|
||||||
|
: {
|
||||||
|
'data-columns':
|
||||||
|
has_newsletter_subscribe_name === 'yes' ? 3 : 2,
|
||||||
|
})}
|
||||||
|
data-provider="convertkit">
|
||||||
|
{has_newsletter_subscribe_name === 'yes' ? (
|
||||||
|
<input
|
||||||
|
type="text"
|
||||||
|
name="FNAME"
|
||||||
|
title="Name"
|
||||||
|
value={newsletter_subscribe_name_label}
|
||||||
|
onChange={(e) => {
|
||||||
|
setAttributes({
|
||||||
|
newsletter_subscribe_name_label: e.target.value,
|
||||||
|
})
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
) : null}
|
||||||
|
<input
|
||||||
|
type="email"
|
||||||
|
name="EMAIL"
|
||||||
|
title="Email"
|
||||||
|
required=""
|
||||||
|
value={newsletter_subscribe_mail_label}
|
||||||
|
onChange={(e) => {
|
||||||
|
setAttributes({
|
||||||
|
newsletter_subscribe_mail_label: e.target.value,
|
||||||
|
})
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
<RichText
|
||||||
|
className="wp-element-button"
|
||||||
|
style={{ ...buttonStyles }}
|
||||||
|
tagName="span"
|
||||||
|
value={newsletter_subscribe_button_text}
|
||||||
|
placeholder="Search"
|
||||||
|
allowedFormats={[]}
|
||||||
|
onChange={(content) =>
|
||||||
|
setAttributes({
|
||||||
|
newsletter_subscribe_button_text: content,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
/>
|
||||||
|
|
||||||
|
{cookies_checkbox_enabled ? (
|
||||||
|
<p className="gdpr-confirm-policy">
|
||||||
|
<input
|
||||||
|
name="ct_has_gdprconfirm"
|
||||||
|
type="hidden"
|
||||||
|
value="yes"
|
||||||
|
/>
|
||||||
|
<input
|
||||||
|
id="gdprconfirm_newsletter-subscribe"
|
||||||
|
className="ct-checkbox"
|
||||||
|
name="gdprconfirm"
|
||||||
|
type="checkbox"
|
||||||
|
required=""
|
||||||
|
/>
|
||||||
|
<label for="gdprconfirm_newsletter-subscribe">
|
||||||
|
I accept the{' '}
|
||||||
|
<a href="/privacy-policy">Privacy Policy</a>
|
||||||
|
</label>
|
||||||
|
</p>
|
||||||
|
) : null}
|
||||||
|
|
||||||
|
<div className="ct-newsletter-subscribe-message"></div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Preview
|
||||||
@ -0,0 +1,30 @@
|
|||||||
|
import { getColorsDefaults } from 'blocksy-options'
|
||||||
|
|
||||||
|
export const colors = {
|
||||||
|
inputFontColor: '',
|
||||||
|
customInputFontColor: '',
|
||||||
|
inputFontColorFocus: '',
|
||||||
|
customInputFontColorFocus: '',
|
||||||
|
|
||||||
|
inputIconColor: '',
|
||||||
|
customInputIconColor: '',
|
||||||
|
inputIconColorFocus: '',
|
||||||
|
customInputIconColorFocus: '',
|
||||||
|
|
||||||
|
inputBorderColor: '',
|
||||||
|
customInputBorderColor: '',
|
||||||
|
inputBorderColorFocus: '',
|
||||||
|
customInputBorderColorFocus: '',
|
||||||
|
|
||||||
|
inputBackgroundColor: '',
|
||||||
|
customInputBackgroundColor: '',
|
||||||
|
inputBackgroundColorFocus: '',
|
||||||
|
customInputBackgroundColorFocus: '',
|
||||||
|
|
||||||
|
buttonBackgroundColor: '',
|
||||||
|
customButtonBackgroundColor: '',
|
||||||
|
buttonBackgroundColorHover: '',
|
||||||
|
customButtonBackgroundColorHover: '',
|
||||||
|
}
|
||||||
|
|
||||||
|
export const colorsDefaults = getColorsDefaults(colors)
|
||||||
@ -0,0 +1,73 @@
|
|||||||
|
import { createElement } from '@wordpress/element'
|
||||||
|
|
||||||
|
import { __ } from 'ct-i18n'
|
||||||
|
import { registerBlockType } from '@wordpress/blocks'
|
||||||
|
|
||||||
|
import Edit from './Edit'
|
||||||
|
import { getAttributesFromOptions, getOptionsForBlock } from 'blocksy-options'
|
||||||
|
|
||||||
|
import { colorsDefaults } from './colors'
|
||||||
|
|
||||||
|
export const options = getOptionsForBlock('newsletter')
|
||||||
|
export const defaultAttributes = getAttributesFromOptions(options)
|
||||||
|
|
||||||
|
registerBlockType('blocksy/newsletter', {
|
||||||
|
apiVersion: 3,
|
||||||
|
title: __('Newsletter Controls', 'blocksy-companion'),
|
||||||
|
icon: {
|
||||||
|
src: (
|
||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
className="wc-block-editor-components-block-icon">
|
||||||
|
<path d="M19 5H5c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zM5 6.5h14c.3 0 .5.2.5.5v.9L12 13.6 4.5 7.9V7c0-.3.2-.5.5-.5zm14 11H5c-.3 0-.5-.2-.5-.5V9.8l7.5 5.6 7.5-5.6V17c0 .3-.2.5-.5.5z" />
|
||||||
|
</svg>
|
||||||
|
),
|
||||||
|
},
|
||||||
|
category: 'widgets',
|
||||||
|
supports: {
|
||||||
|
html: false,
|
||||||
|
multiple: false,
|
||||||
|
inserter: false,
|
||||||
|
lock: false,
|
||||||
|
|
||||||
|
__experimentalBorder: {
|
||||||
|
color: false,
|
||||||
|
radius: true,
|
||||||
|
width: false,
|
||||||
|
__experimentalSkipSerialization: true,
|
||||||
|
__experimentalDefaultControls: {
|
||||||
|
color: false,
|
||||||
|
radius: true,
|
||||||
|
width: false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
parent: ['blocksy/widgets-wrapper'],
|
||||||
|
attributes: { ...defaultAttributes, ...colorsDefaults },
|
||||||
|
edit: (props) => <Edit {...props} />,
|
||||||
|
save: () => <div>Blocksy: Newsletter</div>,
|
||||||
|
})
|
||||||
|
|
||||||
|
wp.blocks.registerBlockVariation('blocksy/widgets-wrapper', {
|
||||||
|
name: 'blocksy-newsletter',
|
||||||
|
title: __('Newsletter', 'blocksy-companion'),
|
||||||
|
attributes: {
|
||||||
|
heading: __('Newsletter', 'blocksy-companion'),
|
||||||
|
block: 'blocksy/newsletter',
|
||||||
|
hasDescription: true,
|
||||||
|
description:
|
||||||
|
defaultAttributes?.newsletter_subscribe_text?.default || '',
|
||||||
|
},
|
||||||
|
isActive: (attributes) => attributes.block === 'blocksy/newsletter',
|
||||||
|
icon: {
|
||||||
|
src: (
|
||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
className="wc-block-editor-components-block-icon">
|
||||||
|
<path d="M19 5H5c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zM5 6.5h14c.3 0 .5.2.5.5v.9L12 13.6 4.5 7.9V7c0-.3.2-.5.5-.5zm14 11H5c-.3 0-.5-.2-.5-.5V9.8l7.5 5.6 7.5-5.6V17c0 .3-.2.5-.5.5z" />
|
||||||
|
</svg>
|
||||||
|
),
|
||||||
|
},
|
||||||
|
})
|
||||||
@ -0,0 +1 @@
|
|||||||
|
__webpack_public_path__ = blocksy_ext_newsletter_subscribe_localization.public_url
|
||||||
@ -0,0 +1,79 @@
|
|||||||
|
import {
|
||||||
|
responsiveClassesFor,
|
||||||
|
watchOptionsWithPrefix,
|
||||||
|
} from 'blocksy-customizer-sync'
|
||||||
|
|
||||||
|
import './variables'
|
||||||
|
|
||||||
|
wp.customize('newsletter_subscribe_subscribe_visibility', (val) =>
|
||||||
|
val.bind((to) => {
|
||||||
|
const block = document.querySelector('.ct-newsletter-subscribe-container')
|
||||||
|
responsiveClassesFor('newsletter_subscribe_subscribe_visibility', block)
|
||||||
|
})
|
||||||
|
)
|
||||||
|
|
||||||
|
if (
|
||||||
|
document.body.classList.contains('single') ||
|
||||||
|
document.body.classList.contains('page')
|
||||||
|
) {
|
||||||
|
watchOptionsWithPrefix({
|
||||||
|
getPrefix: () => '',
|
||||||
|
getOptionsForPrefix: () => [
|
||||||
|
'newsletter_subscribe_button_text',
|
||||||
|
'newsletter_subscribe_title',
|
||||||
|
'newsletter_subscribe_text',
|
||||||
|
'newsletter_subscribe_name_label',
|
||||||
|
'newsletter_subscribe_mail_label',
|
||||||
|
],
|
||||||
|
|
||||||
|
render: () => {
|
||||||
|
if (
|
||||||
|
!document.body.classList.contains('single') &&
|
||||||
|
!document.body.classList.contains('page')
|
||||||
|
) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
const block = document.querySelector(
|
||||||
|
'.ct-newsletter-subscribe-container'
|
||||||
|
)
|
||||||
|
|
||||||
|
if (!block) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
responsiveClassesFor(
|
||||||
|
'newsletter_subscribe_subscribe_visibility',
|
||||||
|
block
|
||||||
|
)
|
||||||
|
|
||||||
|
if (block.querySelector('[name="FNAME"]')) {
|
||||||
|
block
|
||||||
|
.querySelector('[name="FNAME"]')
|
||||||
|
.setAttribute(
|
||||||
|
'placeholder',
|
||||||
|
`${wp.customize('newsletter_subscribe_name_label')()}`
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
block
|
||||||
|
.querySelector('[name="EMAIL"]')
|
||||||
|
.setAttribute(
|
||||||
|
'placeholder',
|
||||||
|
`${wp.customize('newsletter_subscribe_mail_label')()} *`
|
||||||
|
)
|
||||||
|
|
||||||
|
block.querySelector('button').innerHTML = wp.customize(
|
||||||
|
'newsletter_subscribe_button_text'
|
||||||
|
)()
|
||||||
|
|
||||||
|
block.querySelector('h3').innerHTML = wp.customize(
|
||||||
|
'newsletter_subscribe_title'
|
||||||
|
)()
|
||||||
|
|
||||||
|
block.querySelector(
|
||||||
|
'.ct-newsletter-subscribe-container > p'
|
||||||
|
).innerHTML = wp.customize('newsletter_subscribe_text')()
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
@ -0,0 +1,122 @@
|
|||||||
|
import { handleBackgroundOptionFor } from 'blocksy-customizer-sync'
|
||||||
|
import ctEvents from 'ct-events'
|
||||||
|
|
||||||
|
ctEvents.on(
|
||||||
|
'ct:customizer:sync:collect-variable-descriptors',
|
||||||
|
(allVariables) => {
|
||||||
|
allVariables.result = {
|
||||||
|
...allVariables.result,
|
||||||
|
newsletter_subscribe_title_color: {
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-heading-color',
|
||||||
|
type: 'color:default',
|
||||||
|
responsive: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
newsletter_subscribe_content: [
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'text-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-link-hover-color',
|
||||||
|
type: 'color:hover',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
newsletter_subscribe_button: [
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-button-background-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-button-background-hover-color',
|
||||||
|
type: 'color:hover',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
newsletter_subscribe_input_font_color: [
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-form-text-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-form-text-focus-color',
|
||||||
|
type: 'color:focus',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
newsletter_subscribe_border_color: [
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-form-field-border-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-form-field-border-focus-color',
|
||||||
|
type: 'color:focus',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
newsletter_subscribe_input_background: [
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-form-field-background-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'theme-form-field-background-focus-color',
|
||||||
|
type: 'color:focus',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
...handleBackgroundOptionFor({
|
||||||
|
id: 'newsletter_subscribe_container_background',
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
responsive: true,
|
||||||
|
}),
|
||||||
|
|
||||||
|
newsletter_subscribe_container_border: {
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
variable: 'newsletter-container-border',
|
||||||
|
type: 'border',
|
||||||
|
responsive: true,
|
||||||
|
skip_none: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
newsletter_subscribe_shadow: {
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
type: 'box-shadow',
|
||||||
|
variable: 'theme-box-shadow',
|
||||||
|
responsive: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
newsletter_subscribe_container_spacing: {
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
type: 'spacing',
|
||||||
|
variable: 'padding',
|
||||||
|
responsive: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
newsletter_subscribe_container_border_radius: {
|
||||||
|
selector: '.ct-newsletter-subscribe-container',
|
||||||
|
type: 'spacing',
|
||||||
|
variable: 'theme-border-radius',
|
||||||
|
responsive: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
@ -0,0 +1,58 @@
|
|||||||
|
@import "../../static/sass/main.scss";
|
||||||
|
|
||||||
|
.ct-newsletter-subscribe-block {
|
||||||
|
|
||||||
|
form {
|
||||||
|
|
||||||
|
// input[type="text"],
|
||||||
|
// input[type="email"] {
|
||||||
|
// height: var(--theme-form-field-height, 40px);
|
||||||
|
// font-size: var(--theme-form-font-size, 16px);
|
||||||
|
// color: var(--theme-form-text-initial-color, var(--theme-text-color));
|
||||||
|
// padding: var(--has-classic-forms, var(--theme-form-field-padding, 0 12px));
|
||||||
|
// margin-inline: 0;
|
||||||
|
// border-width: var(--theme-form-field-border-width, 1px);
|
||||||
|
// border-style: var(--theme-form-field-border-style, solid);
|
||||||
|
// border-color: var(--theme-form-field-border-initial-color);
|
||||||
|
// border-radius: var(--has-classic-forms, var(--theme-form-field-border-radius, 3px));
|
||||||
|
// background-color: var(--has-classic-forms, var(--theme-form-field-background-initial-color));
|
||||||
|
|
||||||
|
// &::placeholder {
|
||||||
|
// opacity: 0.6;
|
||||||
|
// color: inherit;
|
||||||
|
// }
|
||||||
|
|
||||||
|
// &:focus {
|
||||||
|
// outline: none;
|
||||||
|
// box-shadow: none;
|
||||||
|
// color: var(--theme-form-text-focus-color, var(--theme-text-color));
|
||||||
|
// border-color: var(--theme-form-field-border-focus-color);
|
||||||
|
// background-color: var(--has-classic-forms, var(--theme-form-field-background-focus-color));
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// input[type="checkbox"] {
|
||||||
|
// margin: 0;
|
||||||
|
// margin-inline-end: 0.7em;
|
||||||
|
// box-shadow: none;
|
||||||
|
// background: transparent;
|
||||||
|
// border-width: var(--form-selection-control-border-width, var(--theme-form-field-border-width, 1px));
|
||||||
|
// border-style: solid;
|
||||||
|
// border-color: var(--theme-form-selection-field-initial-color);
|
||||||
|
// border-radius: var(--theme-form-checkbox-border-radius, 3px);
|
||||||
|
// }
|
||||||
|
|
||||||
|
.wp-element-button {
|
||||||
|
border: none;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.gdpr-confirm-policy {
|
||||||
|
pointer-events: none;
|
||||||
|
|
||||||
|
label {
|
||||||
|
font-size: 13px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,14 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$autoload = [
|
||||||
|
'Provider' => 'includes/provider.php',
|
||||||
|
|
||||||
|
'MailchimpProvider' => 'providers/mailchimp.php',
|
||||||
|
'BrevoProvider' => 'providers/brevo.php',
|
||||||
|
'CampaignMonitorProvider' => 'providers/campaign-monitor.php',
|
||||||
|
'MailerliteClassicProvider' => 'providers/mailerlite-classic.php',
|
||||||
|
'MailerliteNewProvider' => 'providers/mailerlite-new.php',
|
||||||
|
'ConvertKitProvider' => 'providers/convertkit.php',
|
||||||
|
'DemoProvider' => 'providers/demo.php'
|
||||||
|
];
|
||||||
|
|
||||||
@ -0,0 +1,12 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$config = [
|
||||||
|
// translators: This is a brand name. Preferably to not be translated
|
||||||
|
'name' => _x('Newsletter Subscribe', 'Extension Brand Name', 'blocksy-companion'),
|
||||||
|
'description' => __('Easily capture new leads for your newsletter with the help of a widget, shortcode or even a block inserted on your pages or posts.', 'blocksy-companion'),
|
||||||
|
'documentation' => 'https://creativethemes.com/blocksy/docs/extensions/newsletter-subscribe/',
|
||||||
|
'video' => 'https://creativethemes.com/blocksy/video-tutorials/shorts/newsletter-everywhere/',
|
||||||
|
'customize' => admin_url('customize.php?ct_autofocus=single_blog_posts:newsletter_subscribe_single_post_enabled'),
|
||||||
|
'icon' => '<svg width="16" height="16" viewBox="0 0 16 16"><path d="M13.8 1.5H2.2C1 1.5 0 2.4 0 3.6v8.7c0 1.2 1 2.2 2.2 2.2h11.6c1.2 0 2.2-1 2.2-2.2V3.6c0-1.2-1-2.1-2.2-2.1zm-.2 3.9L10.7 8 9.6 9c-1 .6-2.2.6-3.2 0L5.3 8 2.4 5.4c-.3-.3-.3-.7 0-1 .3-.3.7-.3 1 0L7 7.6c.6.5 1.4.5 2 0l3.6-3.3c.3-.3.8-.2 1 0 .3.4.3.8 0 1.1z"/></svg>',
|
||||||
|
];
|
||||||
|
|
||||||
@ -0,0 +1,124 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Newsletter Subscribe widget
|
||||||
|
*
|
||||||
|
* @copyright 2019-present Creative Themes
|
||||||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU General Public License
|
||||||
|
* @package Blocksy
|
||||||
|
*/
|
||||||
|
|
||||||
|
$options = [
|
||||||
|
|
||||||
|
'newsletter_subscribe_text' => [
|
||||||
|
'label' => __('Text', 'blocksy-companion'),
|
||||||
|
'type' => 'hidden',
|
||||||
|
'value' => __(
|
||||||
|
'Enter your email address below and subscribe to our newsletter',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
'desc' => __(
|
||||||
|
'You can add here some arbitrary HTML code.',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'setting' => ['transport' => 'postMessage'],
|
||||||
|
|
||||||
|
'mediaButtons' => false,
|
||||||
|
'tinymce' => [
|
||||||
|
'toolbar1' => 'bold,italic,link,undo,redo',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_list_id_source' => [
|
||||||
|
'type' => 'ct-radio',
|
||||||
|
'label' => __('List Source', 'blocksy-companion'),
|
||||||
|
'value' => 'default',
|
||||||
|
'view' => 'radio',
|
||||||
|
'inline' => true,
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'choices' => [
|
||||||
|
'default' => __('Default', 'blocksy-companion'),
|
||||||
|
'custom' => __('Custom', 'blocksy-companion'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => ['newsletter_subscribe_list_id_source' => 'custom'],
|
||||||
|
'options' => [
|
||||||
|
'newsletter_subscribe_list_id' => [
|
||||||
|
'label' => __('List ID', 'blocksy-companion'),
|
||||||
|
'type' => 'blocksy-newsletter-subscribe',
|
||||||
|
'value' => '',
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_view_type' => [
|
||||||
|
'type' => 'ct-radio',
|
||||||
|
'label' => __('Form Style', 'blocksy-companion'),
|
||||||
|
'value' => 'inline',
|
||||||
|
'view' => 'radio',
|
||||||
|
'inline' => true,
|
||||||
|
'divider' => 'top:full',
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'choices' => [
|
||||||
|
'inline' => __('Inline', 'blocksy-companion'),
|
||||||
|
'stacked' => __('Stacked', 'blocksy-companion'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_height' => [
|
||||||
|
'label' => __( 'Input Height', 'blocksy' ),
|
||||||
|
'type' => 'ct-slider',
|
||||||
|
'min' => 40,
|
||||||
|
'max' => 80,
|
||||||
|
'value' => '',
|
||||||
|
'responsive' => false,
|
||||||
|
'divider' => 'top:full',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_gap' => [
|
||||||
|
'label' => __( 'Fields Gap', 'blocksy' ),
|
||||||
|
'type' => 'ct-slider',
|
||||||
|
'min' => 0,
|
||||||
|
'max' => 50,
|
||||||
|
'value' => '',
|
||||||
|
'responsive' => false,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
'has_newsletter_subscribe_name' => [
|
||||||
|
'type' => 'ct-switch',
|
||||||
|
'label' => __('Name Field', 'blocksy-companion'),
|
||||||
|
'value' => 'no',
|
||||||
|
'divider' => 'top:full',
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => ['has_newsletter_subscribe_name' => 'yes'],
|
||||||
|
'options' => [
|
||||||
|
'newsletter_subscribe_name_label' => [
|
||||||
|
'type' => 'hidden',
|
||||||
|
'label' => __('Name Label', 'blocksy-companion'),
|
||||||
|
'value' => __('Your name', 'blocksy-companion'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_mail_label' => [
|
||||||
|
'type' => 'hidden',
|
||||||
|
'label' => __('Mail Label', 'blocksy-companion'),
|
||||||
|
'value' => __('Your email *', 'blocksy-companion'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_button_text' => [
|
||||||
|
'type' => 'hidden',
|
||||||
|
'label' => __('Button Label', 'blocksy-companion'),
|
||||||
|
'value' => __('Subscribe', 'blocksy-companion'),
|
||||||
|
],
|
||||||
|
];
|
||||||
@ -0,0 +1,254 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Newsletter Subscribe widget
|
||||||
|
*
|
||||||
|
* @copyright 2019-present Creative Themes
|
||||||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU General Public License
|
||||||
|
* @package Blocksy
|
||||||
|
*/
|
||||||
|
|
||||||
|
// Widget title
|
||||||
|
$title = blocksy_default_akg(
|
||||||
|
'title',
|
||||||
|
$atts,
|
||||||
|
__('Newsletter', 'blocksy-companion')
|
||||||
|
);
|
||||||
|
|
||||||
|
// Button text
|
||||||
|
$button_text = blocksy_default_akg(
|
||||||
|
'newsletter_subscribe_button_text',
|
||||||
|
$atts,
|
||||||
|
__('Subscribe', 'blocksy-companion')
|
||||||
|
);
|
||||||
|
|
||||||
|
$style = '';
|
||||||
|
|
||||||
|
$newsletter_subscribe_height = blocksy_default_akg('newsletter_subscribe_height', $atts, '');
|
||||||
|
$newsletter_subscribe_gap = blocksy_default_akg('newsletter_subscribe_gap', $atts, '');
|
||||||
|
|
||||||
|
if (! empty($newsletter_subscribe_height)) {
|
||||||
|
$style .= '--theme-form-field-height:' . $newsletter_subscribe_height . 'px;';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! empty($newsletter_subscribe_gap)) {
|
||||||
|
$style .= '--theme-form-field-gap:' . $newsletter_subscribe_gap . 'px;';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($atts['style']['border']['radius'])) {
|
||||||
|
if (
|
||||||
|
gettype($atts['style']['border']['radius']) === 'string'
|
||||||
|
&&
|
||||||
|
! empty(gettype($atts['style']['border']['radius']))
|
||||||
|
) {
|
||||||
|
$style .= '--theme-form-field-border-radius:' . $atts['style']['border']['radius'] . ';';
|
||||||
|
} else if (
|
||||||
|
gettype($atts['style']['border']['radius']) === 'array'
|
||||||
|
&&
|
||||||
|
! empty($atts['style']['border']['radius'])
|
||||||
|
) {
|
||||||
|
$style .= '--theme-form-field-border-radius:' . $atts['style']['border']['radius']['topLeft'] . $atts['style']['border']['radius']['topRight'] . $atts['style']['border']['radius']['bottomLeft'] . $atts['style']['border']['radius']['bottomRight'] . ';';
|
||||||
|
}
|
||||||
|
|
||||||
|
unset($atts['style']['border']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$colors = [
|
||||||
|
'--theme-form-text-initial-color' => blocksy_default_akg('customInputFontColor', $atts, ''),
|
||||||
|
'--theme-form-text-focus-color' => blocksy_default_akg('customInputFontFocusColor', $atts, ''),
|
||||||
|
'--theme-form-field-border-initial-color' => blocksy_default_akg('customInputBorderColor', $atts, ''),
|
||||||
|
'--theme-form-field-border-focus-color' => blocksy_default_akg('customInputBorderColorFocus', $atts, ''),
|
||||||
|
'--theme-form-field-background-initial-color' => blocksy_default_akg('customInputBackgroundColor', $atts, ''),
|
||||||
|
'--theme-form-field-background-focus-color' => blocksy_default_akg('customInputBackgroundColorFocus', $atts, ''),
|
||||||
|
];
|
||||||
|
|
||||||
|
if (isset($atts['inputFontColor'])) {
|
||||||
|
$var = $atts['inputFontColor'];
|
||||||
|
$colors['--theme-form-text-initial-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($atts['inputFontColorFocus'])) {
|
||||||
|
$var = $atts['inputFontColorFocus'];
|
||||||
|
$colors['--theme-form-text-focus-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($atts['inputBorderColor'])) {
|
||||||
|
$var = $atts['inputBorderColor'];
|
||||||
|
$colors['--theme-form-field-border-initial-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($atts['inputBorderColorFocus'])) {
|
||||||
|
$var = $atts['inputBorderColorFocus'];
|
||||||
|
$colors['--theme-form-field-border-focus-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($atts['inputBackgroundColor'])) {
|
||||||
|
$var = $atts['inputBackgroundColor'];
|
||||||
|
$colors['--theme-form-field-background-initial-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($atts['inputBackgroundColorFocus'])) {
|
||||||
|
$var = $atts['inputBackgroundColorFocus'];
|
||||||
|
$colors['--theme-form-field-background-focus-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
$colors_css = '';
|
||||||
|
|
||||||
|
foreach ($colors as $key => $value) {
|
||||||
|
if (empty($value)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$colors_css .= $key . ':' . $value . ';';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Form name
|
||||||
|
$has_name =
|
||||||
|
blocksy_default_akg('has_newsletter_subscribe_name', $atts, 'no') === 'yes';
|
||||||
|
|
||||||
|
$list_id = null;
|
||||||
|
|
||||||
|
if (
|
||||||
|
blocksy_default_akg(
|
||||||
|
'newsletter_subscribe_list_id_source',
|
||||||
|
$atts,
|
||||||
|
'default'
|
||||||
|
) === 'custom'
|
||||||
|
) {
|
||||||
|
$list_id = blocksy_default_akg('newsletter_subscribe_list_id', $atts, '');
|
||||||
|
}
|
||||||
|
|
||||||
|
$manager = \Blocksy\Extensions\NewsletterSubscribe\Provider::get_for_settings();
|
||||||
|
|
||||||
|
// Button value
|
||||||
|
$provider_data = $manager->get_form_url_and_gdpr_for($list_id);
|
||||||
|
|
||||||
|
if (!$provider_data) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($provider_data['provider'] === 'mailerlite') {
|
||||||
|
$settings = $manager->get_settings();
|
||||||
|
$provider_data['provider'] .= ':' . $settings['list_id'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$form_url = $provider_data['form_url'];
|
||||||
|
$has_gdpr_fields = $provider_data['has_gdpr_fields'];
|
||||||
|
|
||||||
|
$name_label = blocksy_default_akg(
|
||||||
|
'newsletter_subscribe_name_label',
|
||||||
|
$atts,
|
||||||
|
__('Your name', 'blocksy-companion')
|
||||||
|
);
|
||||||
|
$email_label = blocksy_default_akg(
|
||||||
|
'newsletter_subscribe_mail_label',
|
||||||
|
$atts,
|
||||||
|
__('Your email *', 'blocksy-companion')
|
||||||
|
);
|
||||||
|
|
||||||
|
$view_type = blocksy_default_akg(
|
||||||
|
'newsletter_subscribe_view_type',
|
||||||
|
$atts,
|
||||||
|
'inline'
|
||||||
|
);
|
||||||
|
|
||||||
|
$fields_number = '2';
|
||||||
|
|
||||||
|
if ($has_name) {
|
||||||
|
$fields_number = '3';
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '<div class="ct-newsletter-subscribe-block">';
|
||||||
|
|
||||||
|
$form_attrs = [
|
||||||
|
'action' => esc_attr($form_url),
|
||||||
|
'method' => 'post',
|
||||||
|
'target' => '_blank',
|
||||||
|
'class' => 'ct-newsletter-subscribe-form',
|
||||||
|
'data-provider' => $provider_data['provider'],
|
||||||
|
];
|
||||||
|
|
||||||
|
if ($view_type === 'inline') {
|
||||||
|
$form_attrs['data-columns'] = $fields_number;
|
||||||
|
}
|
||||||
|
|
||||||
|
$skip_submit_output = '';
|
||||||
|
|
||||||
|
if ($has_gdpr_fields) {
|
||||||
|
$form_attrs['data-skip-submit'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! empty($style) || ! empty($colors_css)) {
|
||||||
|
$form_attrs['style'] = $style . $colors_css;
|
||||||
|
}
|
||||||
|
|
||||||
|
$button_colors = [];
|
||||||
|
|
||||||
|
$button_colors = array_merge(
|
||||||
|
$button_colors,
|
||||||
|
[
|
||||||
|
'--theme-button-text-initial-color' => blocksy_default_akg('customInputIconColor', $atts, ''),
|
||||||
|
'--theme-button-text-hover-color' => blocksy_default_akg('customInputIconColorFocus', $atts, ''),
|
||||||
|
'--theme-button-background-initial-color' => blocksy_default_akg('customButtonBackgroundColor', $atts, ''),
|
||||||
|
'--theme-button-background-hover-color' => blocksy_default_akg('customButtonBackgroundColorHover', $atts, ''),
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
if (isset($atts['inputIconColor'])) {
|
||||||
|
$var = $atts['inputIconColor'];
|
||||||
|
$button_colors['--theme-button-text-initial-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($atts['inputIconColorFocus'])) {
|
||||||
|
$var = $atts['inputIconColorFocus'];
|
||||||
|
$button_colors['--theme-button-text-hover-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($atts['buttonBackgroundColor'])) {
|
||||||
|
$var = $atts['buttonBackgroundColor'];
|
||||||
|
$button_colors['--theme-button-background-initial-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($atts['buttonBackgroundColorHover'])) {
|
||||||
|
$var = $atts['buttonBackgroundColorHover'];
|
||||||
|
$button_colors['--theme-button-background-hover-color'] = "var(--wp--preset--color--$var)";
|
||||||
|
}
|
||||||
|
|
||||||
|
$button_colors_css = '';
|
||||||
|
|
||||||
|
foreach ($button_colors as $key => $value) {
|
||||||
|
if (empty($value)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$button_colors_css .= $key . ':' . $value . ';';
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
|
<form <?php echo blocksy_attr_to_html($form_attrs); ?>>
|
||||||
|
<?php if ($has_name) { ?>
|
||||||
|
<input
|
||||||
|
type="text"
|
||||||
|
name="FNAME"
|
||||||
|
placeholder="<?php esc_attr_e($name_label, 'blocksy-companion'); ?>"
|
||||||
|
title="<?php echo __('Name', 'blocksy-companion'); ?>">
|
||||||
|
<?php } ?>
|
||||||
|
|
||||||
|
<input
|
||||||
|
type="email"
|
||||||
|
name="EMAIL"
|
||||||
|
placeholder="<?php esc_attr_e($email_label, 'blocksy-companion'); ?>"
|
||||||
|
title="<?php echo __('Email', 'blocksy-companion'); ?>"
|
||||||
|
required>
|
||||||
|
|
||||||
|
<button class="wp-element-button" <?php echo ! empty($button_colors_css) ? 'style="' . esc_attr($button_colors_css) . '"' : '' ?>>
|
||||||
|
<?php echo esc_html($button_text); ?>
|
||||||
|
</button>
|
||||||
|
|
||||||
|
<?php
|
||||||
|
if (function_exists('blocksy_ext_cookies_checkbox')) {
|
||||||
|
echo blocksy_ext_cookies_checkbox('newsletter-subscribe');
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
|
||||||
|
<div class="ct-newsletter-subscribe-message"></div>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
</div>
|
||||||
@ -0,0 +1,411 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$options = [
|
||||||
|
'label' => __( 'Subscribe Form', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-panel',
|
||||||
|
'switch' => true,
|
||||||
|
'value' => 'yes',
|
||||||
|
'sync' => blocksy_sync_single_post_container(),
|
||||||
|
'inner-options' => [
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'General', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'newsletter_subscribe_title' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __( 'Title', 'blocksy-companion' ),
|
||||||
|
'design' => 'block',
|
||||||
|
'value' => __( 'Newsletter Updates', 'blocksy-companion' ),
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_text' => [
|
||||||
|
'label' => __( 'Description', 'blocksy-companion' ),
|
||||||
|
'type' => 'textarea',
|
||||||
|
'value' => __( 'Enter your email address below and subscribe to our newsletter', 'blocksy-companion' ),
|
||||||
|
'design' => 'block',
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
'attr' => [ 'data-type' => 'small' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_list_id_source' => [
|
||||||
|
'type' => 'ct-radio',
|
||||||
|
'label' => __( 'List Source', 'blocksy-companion' ),
|
||||||
|
'value' => 'default',
|
||||||
|
'view' => 'radio',
|
||||||
|
'inline' => true,
|
||||||
|
'design' => 'inline',
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'choices' => [
|
||||||
|
'default' => __('Default', 'blocksy-companion'),
|
||||||
|
'custom' => __('Custom', 'blocksy-companion'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => [ 'newsletter_subscribe_list_id_source' => 'custom' ],
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'newsletter_subscribe_list_id' => [
|
||||||
|
'label' => __( 'List ID', 'blocksy-companion' ),
|
||||||
|
'type' => 'blocksy-newsletter-subscribe',
|
||||||
|
'value' => '',
|
||||||
|
'design' => 'inline',
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
'attr' => [ 'data-type' => 'small' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
'has_newsletter_subscribe_name' => [
|
||||||
|
'type' => 'ct-switch',
|
||||||
|
'label' => __( 'Name Field', 'blocksy-companion' ),
|
||||||
|
'value' => 'no',
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'sync' => blocksy_sync_single_post_container([
|
||||||
|
'loader_selector' => '.ct-newsletter-subscribe-container'
|
||||||
|
]),
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => [ 'has_newsletter_subscribe_name' => 'yes' ],
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'newsletter_subscribe_name_label' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __( 'Name Label', 'blocksy-companion' ),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => __( 'Your name', 'blocksy-companion' ),
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_mail_label' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __( 'Mail Label', 'blocksy-companion' ),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => __( 'Your email', 'blocksy-companion' ),
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_button_text' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __( 'Button Label', 'blocksy-companion' ),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => __( 'Subscribe', 'blocksy-companion' ),
|
||||||
|
'disableRevertButton' => true,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_subscribe_visibility' => [
|
||||||
|
'label' => __( 'Visibility', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-visibility',
|
||||||
|
'design' => 'block',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'value' => [
|
||||||
|
'desktop' => true,
|
||||||
|
'tablet' => true,
|
||||||
|
'mobile' => false,
|
||||||
|
],
|
||||||
|
|
||||||
|
'choices' => blocksy_ordered_keys([
|
||||||
|
'desktop' => __( 'Desktop', 'blocksy-companion' ),
|
||||||
|
'tablet' => __( 'Tablet', 'blocksy-companion' ),
|
||||||
|
'mobile' => __( 'Mobile', 'blocksy-companion' ),
|
||||||
|
]),
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'Design', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'newsletter_subscribe_title_color' => [
|
||||||
|
'label' => __( 'Title Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-heading-color, var(--theme-heading-3-color, var(--theme-headings-color)))'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_content' => [
|
||||||
|
'label' => __( 'Text Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-text-color)'
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Hover', 'blocksy-companion' ),
|
||||||
|
'id' => 'hover',
|
||||||
|
'inherit' => 'var(--theme-link-hover-color)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_input_font_color' => [
|
||||||
|
'label' => __( 'Input Font Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'focus' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-form-text-initial-color, var(--theme-text-color))'
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Focus', 'blocksy-companion' ),
|
||||||
|
'id' => 'focus',
|
||||||
|
'inherit' => 'var(--theme-form-text-focus-color, var(--theme-text-color))'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_border_color' => [
|
||||||
|
'label' => __( 'Input Border Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'focus' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-form-field-border-initial-color)'
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Focus', 'blocksy-companion' ),
|
||||||
|
'id' => 'focus',
|
||||||
|
'inherit' => 'var(--theme-form-field-border-focus-color)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => ['forms_type' => 'classic-forms'],
|
||||||
|
'values_source' => 'global',
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'newsletter_subscribe_input_background' => [
|
||||||
|
'label' => __( 'Input Background Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword(),
|
||||||
|
],
|
||||||
|
|
||||||
|
'focus' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword(),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Focus', 'blocksy-companion' ),
|
||||||
|
'id' => 'focus',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_button' => [
|
||||||
|
'label' => __( 'Button Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => 'var(--theme-palette-color-1)',
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'color' => 'var(--theme-palette-color-2)',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Hover', 'blocksy-companion' ),
|
||||||
|
'id' => 'hover',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_container_background' => [
|
||||||
|
'label' => __( 'Container Background', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-background',
|
||||||
|
'design' => 'block:right',
|
||||||
|
'responsive' => true,
|
||||||
|
'divider' => 'top:full',
|
||||||
|
'sync' => 'live',
|
||||||
|
'value' => blocksy_background_default_value([
|
||||||
|
'backgroundColor' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => 'var(--theme-palette-color-8)',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
])
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_container_border' => [
|
||||||
|
'label' => __( 'Container Border', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-border',
|
||||||
|
'sync' => 'live',
|
||||||
|
'design' => 'block',
|
||||||
|
'divider' => 'top',
|
||||||
|
'value' => [
|
||||||
|
'width' => 1,
|
||||||
|
'style' => 'none',
|
||||||
|
'color' => [
|
||||||
|
'color' => 'var(--theme-palette-color-5)',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'responsive' => true,
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_shadow' => [
|
||||||
|
'label' => __( 'Container Shadow', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-box-shadow',
|
||||||
|
'responsive' => true,
|
||||||
|
'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'value' => blocksy_box_shadow_value([
|
||||||
|
'enable' => true,
|
||||||
|
'h_offset' => 0,
|
||||||
|
'v_offset' => 50,
|
||||||
|
'blur' => 90,
|
||||||
|
'spread' => 0,
|
||||||
|
'inset' => false,
|
||||||
|
'color' => [
|
||||||
|
'color' => 'rgba(210, 213, 218, 0.4)',
|
||||||
|
],
|
||||||
|
])
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_container_spacing' => [
|
||||||
|
'label' => __( 'Container Inner Spacing', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-spacing',
|
||||||
|
'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'value' => blocksy_spacing_value([
|
||||||
|
'top' => '30px',
|
||||||
|
'left' => '30px',
|
||||||
|
'right' => '30px',
|
||||||
|
'bottom' => '30px',
|
||||||
|
]),
|
||||||
|
'responsive' => true
|
||||||
|
],
|
||||||
|
|
||||||
|
'newsletter_subscribe_container_border_radius' => [
|
||||||
|
'label' => __( 'Container Border Radius', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-spacing',
|
||||||
|
'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'value' => blocksy_spacing_value(),
|
||||||
|
'responsive' => true
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
];
|
||||||
File diff suppressed because one or more lines are too long
@ -0,0 +1,334 @@
|
|||||||
|
import {
|
||||||
|
createElement,
|
||||||
|
Component,
|
||||||
|
useEffect,
|
||||||
|
useState,
|
||||||
|
useMemo,
|
||||||
|
useReducer,
|
||||||
|
Fragment,
|
||||||
|
} from '@wordpress/element'
|
||||||
|
|
||||||
|
import classnames from 'classnames'
|
||||||
|
import { __, sprintf } from 'ct-i18n'
|
||||||
|
import ListPicker from './ListPicker'
|
||||||
|
import Overlay from '../../../../../static/js/helpers/Overlay'
|
||||||
|
import { Select } from 'blocksy-options'
|
||||||
|
|
||||||
|
import useProExtensionInFree from '../../../../../static/js/dashboard/helpers/useProExtensionInFree'
|
||||||
|
|
||||||
|
const freeProviders = ['mailchimp', 'demo']
|
||||||
|
|
||||||
|
const EditCredentials = ({ extension, onCredentialsValidated }) => {
|
||||||
|
const [provider, setProvider] = useState(extension.data.provider)
|
||||||
|
|
||||||
|
const [apiKey, setApiKey] = useState(extension.data.api_key)
|
||||||
|
const [listId, setListId] = useState(extension.data.list_id)
|
||||||
|
const [isLoading, setIsLoading] = useState(false)
|
||||||
|
|
||||||
|
const { isPro, showNotice, content } = useProExtensionInFree(extension, {
|
||||||
|
strategy: 'pro',
|
||||||
|
})
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (
|
||||||
|
extension.data &&
|
||||||
|
!freeProviders.includes(extension.data.provider) &&
|
||||||
|
!isPro
|
||||||
|
) {
|
||||||
|
setProvider(freeProviders[0])
|
||||||
|
}
|
||||||
|
}, [])
|
||||||
|
|
||||||
|
const attemptToSaveCredentials = async () => {
|
||||||
|
const body = new FormData()
|
||||||
|
|
||||||
|
body.append('provider', provider)
|
||||||
|
body.append('api_key', apiKey)
|
||||||
|
body.append('list_id', listId)
|
||||||
|
|
||||||
|
body.append(
|
||||||
|
'action',
|
||||||
|
'blocksy_ext_newsletter_subscribe_maybe_save_credentials'
|
||||||
|
)
|
||||||
|
|
||||||
|
body.append('nonce', ctDashboardLocalizations.dashboard_actions_nonce)
|
||||||
|
|
||||||
|
setIsLoading(true)
|
||||||
|
|
||||||
|
try {
|
||||||
|
const response = await fetch(ctDashboardLocalizations.ajax_url, {
|
||||||
|
method: 'POST',
|
||||||
|
body,
|
||||||
|
})
|
||||||
|
|
||||||
|
if (response.status === 200) {
|
||||||
|
const body = await response.json()
|
||||||
|
|
||||||
|
if (body.success) {
|
||||||
|
if (body.data.result !== 'api_key_invalid') {
|
||||||
|
onCredentialsValidated()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e) {}
|
||||||
|
|
||||||
|
await new Promise((r) => setTimeout(() => r(), 1000))
|
||||||
|
|
||||||
|
setIsLoading(false)
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div
|
||||||
|
className={classnames(
|
||||||
|
'ct-extension-options ct-newsletter-subscribe-options'
|
||||||
|
)}>
|
||||||
|
<h4>{__('Connect Newsletter Provider', 'blocksy-companion')}</h4>
|
||||||
|
|
||||||
|
<div
|
||||||
|
className="ct-newsletter-credentials"
|
||||||
|
data-columns={provider.indexOf('mailerlite') > -1 ? 4 : 3}>
|
||||||
|
<section>
|
||||||
|
<label>{__('Provider', 'blocksy-companion')}</label>
|
||||||
|
<Select
|
||||||
|
onChange={(copy) => {
|
||||||
|
if (!isPro && !freeProviders.includes(copy)) {
|
||||||
|
setProvider(copy)
|
||||||
|
setTimeout(() => {
|
||||||
|
setProvider(freeProviders[0])
|
||||||
|
})
|
||||||
|
showNotice()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
setProvider(copy)
|
||||||
|
}}
|
||||||
|
option={{
|
||||||
|
placeholder: __(
|
||||||
|
'Pick Mailing Service',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
choices: [
|
||||||
|
{
|
||||||
|
key: 'mailchimp',
|
||||||
|
value: 'Mailchimp',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
key: 'mailerlite-new',
|
||||||
|
value: 'Mailerlite',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
key: 'brevo',
|
||||||
|
value: 'Brevo (Sendinblue)',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
key: 'campaignmonitor',
|
||||||
|
value: 'Campaign Monitor',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
key: 'convertkit',
|
||||||
|
value: 'ConvertKit',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
key: 'demo',
|
||||||
|
value: 'Demo',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}}
|
||||||
|
value={
|
||||||
|
provider.indexOf('mailerlite') > -1
|
||||||
|
? 'mailerlite'
|
||||||
|
: provider
|
||||||
|
}
|
||||||
|
/>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
{provider.indexOf('mailerlite') > -1 && (
|
||||||
|
<section>
|
||||||
|
<label>{__('API Version', 'blocksy-companion')}</label>
|
||||||
|
<Select
|
||||||
|
onChange={(copy) => {
|
||||||
|
setProvider(
|
||||||
|
copy === 'new'
|
||||||
|
? 'mailerlite-new'
|
||||||
|
: 'mailerlite'
|
||||||
|
)
|
||||||
|
}}
|
||||||
|
option={{
|
||||||
|
placeholder: __(
|
||||||
|
'Pick Mailing Service',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
choices: [
|
||||||
|
{
|
||||||
|
key: 'classic',
|
||||||
|
value: 'Classic',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
key: 'new',
|
||||||
|
value: 'New',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}}
|
||||||
|
value={
|
||||||
|
provider === 'mailerlite-new'
|
||||||
|
? 'new'
|
||||||
|
: 'classic'
|
||||||
|
}
|
||||||
|
/>
|
||||||
|
</section>
|
||||||
|
)}
|
||||||
|
|
||||||
|
{(freeProviders.includes(provider) ||
|
||||||
|
ctDashboardLocalizations.plugin_data.is_pro) && (
|
||||||
|
<Fragment>
|
||||||
|
<section>
|
||||||
|
<label>{__('API Key', 'blocksy-companion')}</label>
|
||||||
|
|
||||||
|
<div className="ct-option-input">
|
||||||
|
<input
|
||||||
|
type="text"
|
||||||
|
onChange={({ target: { value } }) =>
|
||||||
|
setApiKey(value)
|
||||||
|
}
|
||||||
|
value={apiKey || ''}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
<section>
|
||||||
|
<label>{__('List ID', 'blocksy-companion')}</label>
|
||||||
|
|
||||||
|
<ListPicker
|
||||||
|
listId={listId}
|
||||||
|
onChange={(id) => setListId(id)}
|
||||||
|
provider={provider}
|
||||||
|
apiKey={apiKey}
|
||||||
|
/>
|
||||||
|
</section>
|
||||||
|
</Fragment>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{provider === 'mailchimp' && (
|
||||||
|
<span
|
||||||
|
className="ct-option-description"
|
||||||
|
dangerouslySetInnerHTML={{
|
||||||
|
__html: sprintf(
|
||||||
|
__(
|
||||||
|
'More information on how to generate an API key for Mailchimp can be found %shere%s.',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
|
||||||
|
'<a target="_blank" href="https://mailchimp.com/help/about-api-keys/">',
|
||||||
|
'</a>'
|
||||||
|
),
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
|
|
||||||
|
{ctDashboardLocalizations.plugin_data.is_pro &&
|
||||||
|
provider.indexOf('mailerlite') > -1 && (
|
||||||
|
<span
|
||||||
|
className="ct-option-description"
|
||||||
|
dangerouslySetInnerHTML={{
|
||||||
|
__html: sprintf(
|
||||||
|
__(
|
||||||
|
'More information on how to generate an API key for Mailerlite can be found %shere%s. Please note that it is required at least one group to be created in your account for the integration to work. More info on how to create a group %shere%s.',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
|
||||||
|
'<a target="_blank" href="https://www.mailerlite.com/help/where-to-find-the-mailerlite-api-key-and-documentation">',
|
||||||
|
'</a>',
|
||||||
|
'<a target="_blank" href="https://www.mailerlite.com/help/how-to-create-and-use-groups">',
|
||||||
|
'</a>'
|
||||||
|
),
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
|
|
||||||
|
{provider.indexOf('demo') > -1 && (
|
||||||
|
<span
|
||||||
|
className="ct-option-description"
|
||||||
|
dangerouslySetInnerHTML={{
|
||||||
|
__html: __(
|
||||||
|
'This provider is used only for testing purposes. It doesnt register any real subscribers.',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
|
|
||||||
|
{ctDashboardLocalizations.plugin_data.is_pro &&
|
||||||
|
provider === 'brevo' && (
|
||||||
|
<span
|
||||||
|
className="ct-option-description"
|
||||||
|
dangerouslySetInnerHTML={{
|
||||||
|
__html: sprintf(
|
||||||
|
__(
|
||||||
|
'More information on how to generate an API key for Brevo can be found %shere%s.',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
|
||||||
|
'<a target="_blank" href="https://help.brevo.com/hc/en-us/articles/209467485-Create-and-manage-your-API-keys">',
|
||||||
|
'</a>'
|
||||||
|
),
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
|
|
||||||
|
{ctDashboardLocalizations.plugin_data.is_pro &&
|
||||||
|
provider === 'convertkit' && (
|
||||||
|
<span
|
||||||
|
className="ct-option-description"
|
||||||
|
dangerouslySetInnerHTML={{
|
||||||
|
__html: sprintf(
|
||||||
|
__(
|
||||||
|
'More information on how to generate an API key for ConvertKit can be found %shere%s.',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
|
||||||
|
'<a target="_blank" href="https://developers.convertkit.com/#api-basics">',
|
||||||
|
'</a>'
|
||||||
|
),
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
|
|
||||||
|
{ctDashboardLocalizations.plugin_data.is_pro &&
|
||||||
|
provider === 'campaignmonitor' && (
|
||||||
|
<span
|
||||||
|
className="ct-option-description"
|
||||||
|
dangerouslySetInnerHTML={{
|
||||||
|
__html: sprintf(
|
||||||
|
__(
|
||||||
|
'More information on how to generate an API key for Campaign Monitor can be found %shere%s.',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
|
||||||
|
'<a target="_blank" href="https://help.campaignmonitor.com/api-keys">',
|
||||||
|
'</a>'
|
||||||
|
),
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
|
|
||||||
|
<button
|
||||||
|
className="ct-button-primary"
|
||||||
|
disabled={!apiKey || !listId || isLoading}
|
||||||
|
onClick={() => attemptToSaveCredentials()}>
|
||||||
|
{isLoading
|
||||||
|
? __('Loading...', 'blocksy-companion')
|
||||||
|
: __('Save Settings', 'blocksy-companion')}
|
||||||
|
</button>
|
||||||
|
|
||||||
|
{content}
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default EditCredentials
|
||||||
@ -0,0 +1,154 @@
|
|||||||
|
import {
|
||||||
|
createElement,
|
||||||
|
Component,
|
||||||
|
useEffect,
|
||||||
|
useState,
|
||||||
|
Fragment,
|
||||||
|
} from '@wordpress/element'
|
||||||
|
import Downshift from 'downshift'
|
||||||
|
import { __ } from 'ct-i18n'
|
||||||
|
import classnames from 'classnames'
|
||||||
|
|
||||||
|
const ListPicker = ({ listId, provider, apiKey, onChange }) => {
|
||||||
|
const [lists, setLists] = useState([])
|
||||||
|
const [isLoadingLists, setListsLoading] = useState(false)
|
||||||
|
|
||||||
|
let [{ controller }, setAbortState] = useState({
|
||||||
|
controller: null,
|
||||||
|
})
|
||||||
|
|
||||||
|
const maybeFetchLists = async () => {
|
||||||
|
if (controller) {
|
||||||
|
controller.abort()
|
||||||
|
}
|
||||||
|
|
||||||
|
setListsLoading(true)
|
||||||
|
|
||||||
|
if ('AbortController' in window) {
|
||||||
|
controller = new AbortController()
|
||||||
|
|
||||||
|
setAbortState({
|
||||||
|
controller,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
const body = new FormData()
|
||||||
|
|
||||||
|
body.append('api_key', apiKey)
|
||||||
|
body.append('provider', provider)
|
||||||
|
body.append(
|
||||||
|
'action',
|
||||||
|
'blocksy_ext_newsletter_subscribe_maybe_get_lists'
|
||||||
|
)
|
||||||
|
|
||||||
|
body.append('nonce', ctDashboardLocalizations.dashboard_actions_nonce)
|
||||||
|
|
||||||
|
try {
|
||||||
|
const response = await fetch(ctDashboardLocalizations.ajax_url, {
|
||||||
|
method: 'POST',
|
||||||
|
signal: controller.signal,
|
||||||
|
body,
|
||||||
|
})
|
||||||
|
|
||||||
|
if (response.status === 200) {
|
||||||
|
const body = await response.json()
|
||||||
|
|
||||||
|
if (body.success) {
|
||||||
|
if (body.data.result !== 'api_key_invalid') {
|
||||||
|
setListsLoading(false)
|
||||||
|
setLists(
|
||||||
|
body.data.result.map((list) => ({
|
||||||
|
...list,
|
||||||
|
id: list.id.toString(),
|
||||||
|
}))
|
||||||
|
)
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e) {}
|
||||||
|
|
||||||
|
setLists([])
|
||||||
|
setListsLoading(false)
|
||||||
|
}
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (!apiKey) {
|
||||||
|
setLists([])
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
maybeFetchLists()
|
||||||
|
}, [provider, apiKey])
|
||||||
|
|
||||||
|
return lists.length === 0 ? (
|
||||||
|
<div className={classnames('ct-select-input', 'ct-no-results')}>
|
||||||
|
<input
|
||||||
|
disabled
|
||||||
|
placeholder={
|
||||||
|
isLoadingLists ? __('Fetching...', 'blocksy-companion') : ''
|
||||||
|
}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
<Downshift
|
||||||
|
selectedItem={listId || ''}
|
||||||
|
onChange={(selection) => onChange(selection)}
|
||||||
|
itemToString={(item) =>
|
||||||
|
item ? (lists.find(({ id }) => id === item) || {}).name : ''
|
||||||
|
}>
|
||||||
|
{({
|
||||||
|
getInputProps,
|
||||||
|
getItemProps,
|
||||||
|
getLabelProps,
|
||||||
|
getMenuProps,
|
||||||
|
isOpen,
|
||||||
|
inputValue,
|
||||||
|
highlightedIndex,
|
||||||
|
selectedItem,
|
||||||
|
openMenu,
|
||||||
|
}) => (
|
||||||
|
<div className="ct-select-input">
|
||||||
|
<input
|
||||||
|
{...getInputProps({
|
||||||
|
onFocus: () => openMenu(),
|
||||||
|
onClick: () => openMenu(),
|
||||||
|
})}
|
||||||
|
placeholder={__('Select list...', 'blocksy-companion')}
|
||||||
|
readOnly
|
||||||
|
/>
|
||||||
|
|
||||||
|
{isOpen && (
|
||||||
|
<div
|
||||||
|
{...getMenuProps({
|
||||||
|
className: 'ct-select-dropdown',
|
||||||
|
})}>
|
||||||
|
{lists.map((item, index) => (
|
||||||
|
<div
|
||||||
|
{...getItemProps({
|
||||||
|
key: item.id,
|
||||||
|
index,
|
||||||
|
item: item.id,
|
||||||
|
className: classnames(
|
||||||
|
'ct-select-dropdown-item',
|
||||||
|
{
|
||||||
|
active:
|
||||||
|
highlightedIndex === index,
|
||||||
|
selected:
|
||||||
|
selectedItem === item.id,
|
||||||
|
}
|
||||||
|
),
|
||||||
|
})}>
|
||||||
|
{item.name}
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</Downshift>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ListPicker
|
||||||
@ -0,0 +1,45 @@
|
|||||||
|
import { createElement, useState, Fragment } from '@wordpress/element'
|
||||||
|
import { __ } from 'ct-i18n'
|
||||||
|
import classnames from 'classnames'
|
||||||
|
|
||||||
|
import EditCredentials from './EditCredentials'
|
||||||
|
|
||||||
|
const NewsletterSubscribe = ({ extension, onExtsSync }) => {
|
||||||
|
const toggleActivationState = async () => {
|
||||||
|
const body = new FormData()
|
||||||
|
|
||||||
|
body.append('ext', extension.name)
|
||||||
|
body.append(
|
||||||
|
'action',
|
||||||
|
extension.__object
|
||||||
|
? 'blocksy_extension_deactivate'
|
||||||
|
: 'blocksy_extension_activate'
|
||||||
|
)
|
||||||
|
|
||||||
|
body.append('nonce', ctDashboardLocalizations.dashboard_actions_nonce)
|
||||||
|
|
||||||
|
try {
|
||||||
|
await fetch(ctDashboardLocalizations.ajax_url, {
|
||||||
|
method: 'POST',
|
||||||
|
body,
|
||||||
|
})
|
||||||
|
|
||||||
|
onExtsSync()
|
||||||
|
} catch (e) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<EditCredentials
|
||||||
|
extension={extension}
|
||||||
|
onCredentialsValidated={() => {
|
||||||
|
if (extension.__object) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
toggleActivationState()
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default NewsletterSubscribe
|
||||||
@ -0,0 +1,27 @@
|
|||||||
|
import { createElement } from '@wordpress/element'
|
||||||
|
import { addFilter } from '@wordpress/hooks'
|
||||||
|
|
||||||
|
import NewsletterSubscribe from './NewsletterSubscribe'
|
||||||
|
|
||||||
|
addFilter(
|
||||||
|
'blocksy.extensions.current_extension_content',
|
||||||
|
'blocksy',
|
||||||
|
(contentDescriptor, { extension, onExtsSync }) => {
|
||||||
|
if (extension.name !== 'newsletter-subscribe') return contentDescriptor
|
||||||
|
|
||||||
|
return {
|
||||||
|
...contentDescriptor,
|
||||||
|
...(extension.data.api_key
|
||||||
|
? {}
|
||||||
|
: {
|
||||||
|
activationStrategy: 'from-custom-content',
|
||||||
|
}),
|
||||||
|
content: (
|
||||||
|
<NewsletterSubscribe
|
||||||
|
extension={extension}
|
||||||
|
onExtsSync={onExtsSync}
|
||||||
|
/>
|
||||||
|
),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
@ -0,0 +1,49 @@
|
|||||||
|
.ct-newsletter-subscribe-options {
|
||||||
|
padding-top: 40px;
|
||||||
|
border-top: 1px dashed #eee;
|
||||||
|
|
||||||
|
.ct-newsletter-credentials {
|
||||||
|
display: grid;
|
||||||
|
grid-column-gap: 10px;
|
||||||
|
|
||||||
|
&[data-columns="3"] {
|
||||||
|
grid-template-columns: repeat(3, 1fr);
|
||||||
|
}
|
||||||
|
|
||||||
|
&[data-columns="4"] {
|
||||||
|
grid-template-columns: repeat(4, 1fr);
|
||||||
|
}
|
||||||
|
|
||||||
|
section {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
min-width: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
label {
|
||||||
|
display: block;
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: 500;
|
||||||
|
letter-spacing: 0.1px;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
input {
|
||||||
|
--input-height: 35px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-select-input {
|
||||||
|
|
||||||
|
&.ct-no-results:after {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-option-description {
|
||||||
|
display: block;
|
||||||
|
opacity: 0.8;
|
||||||
|
color: inherit;
|
||||||
|
margin-bottom: 30px;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,355 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/helpers.php';
|
||||||
|
|
||||||
|
class BlocksyExtensionNewsletterSubscribe {
|
||||||
|
public function __construct() {
|
||||||
|
add_action('enqueue_block_editor_assets', function () {
|
||||||
|
if (! function_exists('get_plugin_data')) {
|
||||||
|
require_once ABSPATH . 'wp-admin/includes/plugin.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy-ext-newsletter-subscribe-admin-scripts',
|
||||||
|
BLOCKSY_URL .
|
||||||
|
'framework/extensions/newsletter-subscribe/admin-static/bundle/main.js',
|
||||||
|
['ct-options-scripts'],
|
||||||
|
$data['Version']
|
||||||
|
);
|
||||||
|
|
||||||
|
wp_localize_script(
|
||||||
|
'blocksy-ext-newsletter-subscribe-admin-scripts',
|
||||||
|
'blocksy_ext_newsletter_subscribe_localization',
|
||||||
|
[
|
||||||
|
'public_url' =>
|
||||||
|
BLOCKSY_URL .
|
||||||
|
'framework/extensions/newsletter-subscribe/admin-static/bundle/',
|
||||||
|
]
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
add_action('customize_controls_enqueue_scripts', function () {
|
||||||
|
if (! function_exists('get_plugin_data')) {
|
||||||
|
require_once ABSPATH . 'wp-admin/includes/plugin.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
wp_register_script(
|
||||||
|
'blocksy-ext-newsletter-subscribe-admin-scripts',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/newsletter-subscribe/admin-static/bundle/main.js',
|
||||||
|
[],
|
||||||
|
$data['Version'],
|
||||||
|
true
|
||||||
|
);
|
||||||
|
|
||||||
|
wp_localize_script(
|
||||||
|
'blocksy-ext-newsletter-subscribe-admin-scripts',
|
||||||
|
'blocksy_ext_newsletter_subscribe_localization',
|
||||||
|
[
|
||||||
|
'public_url' => BLOCKSY_URL . 'framework/extensions/newsletter-subscribe/admin-static/bundle/',
|
||||||
|
]
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'render_block',
|
||||||
|
function ($block_content, $block) {
|
||||||
|
if ($block['blockName'] === 'blocksy/newsletter') {
|
||||||
|
wp_enqueue_style('blocksy-block-newsletter-styles');
|
||||||
|
}
|
||||||
|
|
||||||
|
return $block_content;
|
||||||
|
},
|
||||||
|
10,
|
||||||
|
2
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'wp_enqueue_scripts',
|
||||||
|
function () {
|
||||||
|
if (! function_exists('get_plugin_data')) {
|
||||||
|
require_once ABSPATH . 'wp-admin/includes/plugin.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
if (is_admin()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
wp_register_style(
|
||||||
|
'blocksy-block-newsletter-styles',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/newsletter-subscribe/static/bundle/main.min.css',
|
||||||
|
['ct-main-styles'],
|
||||||
|
$data['Version']
|
||||||
|
);
|
||||||
|
|
||||||
|
$obj = get_queried_object();
|
||||||
|
|
||||||
|
if (
|
||||||
|
$obj
|
||||||
|
&&
|
||||||
|
! empty($obj->post_content)
|
||||||
|
&&
|
||||||
|
has_shortcode(
|
||||||
|
$obj->post_content,
|
||||||
|
'blocksy_newsletter_subscribe'
|
||||||
|
)
|
||||||
|
) {
|
||||||
|
wp_enqueue_style('blocksy-block-newsletter-styles');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
blocksy_get_theme_mod('newsletter_subscribe_single_post_enabled', 'yes') === 'yes'
|
||||||
|
&&
|
||||||
|
get_post_type() === 'post'
|
||||||
|
) {
|
||||||
|
wp_enqueue_style('blocksy-block-newsletter-styles');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
45
|
||||||
|
);
|
||||||
|
|
||||||
|
add_filter('blocksy:frontend:dynamic-js-chunks', function ($chunks) {
|
||||||
|
$chunks[] = [
|
||||||
|
'id' => 'blocksy_ext_newsletter_subscribe',
|
||||||
|
'selector' => implode(', ', [
|
||||||
|
'.ct-newsletter-subscribe-form:not([data-skip-submit])',
|
||||||
|
]),
|
||||||
|
'url' => blocksy_cdn_url(
|
||||||
|
BLOCKSY_URL .
|
||||||
|
'framework/extensions/newsletter-subscribe/static/bundle/main.js'
|
||||||
|
),
|
||||||
|
'trigger' => 'submit',
|
||||||
|
];
|
||||||
|
|
||||||
|
return $chunks;
|
||||||
|
});
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy_single_posts_end_customizer_options',
|
||||||
|
function ($opts, $prefix) {
|
||||||
|
if ($prefix !== 'single_blog_post') {
|
||||||
|
return $opts;
|
||||||
|
}
|
||||||
|
|
||||||
|
$opts['newsletter_subscribe_single_post_enabled'] = blocksy_get_options(
|
||||||
|
dirname(__FILE__) . '/customizer.php',
|
||||||
|
[],
|
||||||
|
false
|
||||||
|
);
|
||||||
|
|
||||||
|
return $opts;
|
||||||
|
},
|
||||||
|
10,
|
||||||
|
2
|
||||||
|
);
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy_extensions_metabox_post:elements:before',
|
||||||
|
function ($opts) {
|
||||||
|
$opts['disable_subscribe_form'] = [
|
||||||
|
'label' => __(
|
||||||
|
'Disable Subscribe Form',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
'type' => 'ct-switch',
|
||||||
|
'value' => 'no',
|
||||||
|
];
|
||||||
|
|
||||||
|
return $opts;
|
||||||
|
},
|
||||||
|
5
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action('customize_preview_init', function () {
|
||||||
|
if (!function_exists('get_plugin_data')) {
|
||||||
|
require_once ABSPATH . 'wp-admin/includes/plugin.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy-newsletter-subscribe-customizer-sync',
|
||||||
|
BLOCKSY_URL .
|
||||||
|
'framework/extensions/newsletter-subscribe/admin-static/bundle/sync.js',
|
||||||
|
['customize-preview', 'ct-customizer'],
|
||||||
|
$data['Version'],
|
||||||
|
true
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
add_action('wp_ajax_blc_newsletter_subscribe_process_ajax_subscribe', [
|
||||||
|
$this,
|
||||||
|
'newsletter_subscribe_process_ajax_subscribe',
|
||||||
|
]);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'wp_ajax_nopriv_blc_newsletter_subscribe_process_ajax_subscribe',
|
||||||
|
[$this, 'newsletter_subscribe_process_ajax_subscribe']
|
||||||
|
);
|
||||||
|
|
||||||
|
add_shortcode('blocksy_newsletter_subscribe', function (
|
||||||
|
$args,
|
||||||
|
$content
|
||||||
|
) {
|
||||||
|
$args = wp_parse_args($args, [
|
||||||
|
'has_title' => false,
|
||||||
|
'has_description' => false,
|
||||||
|
|
||||||
|
'button_text' => __('Subscribe', 'blocksy-companion'),
|
||||||
|
|
||||||
|
// no | yes
|
||||||
|
'has_name' => 'no',
|
||||||
|
|
||||||
|
'name_label' => __('Your name', 'blocksy-companion'),
|
||||||
|
'email_label' => __('Your email', 'blocksy-companion'),
|
||||||
|
'list_id' => '',
|
||||||
|
'class' => '',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$args['class'] =
|
||||||
|
'ct-newsletter-subscribe-shortcode ' . $args['class'];
|
||||||
|
|
||||||
|
return blc_ext_newsletter_subscribe_output_form($args);
|
||||||
|
});
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'blocksy:global-dynamic-css:enqueue',
|
||||||
|
'BlocksyExtensionNewsletterSubscribe::add_global_styles',
|
||||||
|
10,
|
||||||
|
3
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action('init', [$this, 'blocksy_newsletter_block']);
|
||||||
|
add_action('enqueue_block_editor_assets', [$this, 'enqueue_admin']);
|
||||||
|
|
||||||
|
|
||||||
|
add_filter('blocksy:gutenberg-blocks-data', function ($data) {
|
||||||
|
$options_file =
|
||||||
|
BLOCKSY_PATH .
|
||||||
|
'framework/extensions/newsletter-subscribe/ct-newsletter-subscribe/options.php';
|
||||||
|
|
||||||
|
$options = blocksy_akg(
|
||||||
|
'options',
|
||||||
|
blocksy_get_variables_from_file(
|
||||||
|
$options_file,
|
||||||
|
['options' => []]
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$data['newsletter'] = $options;
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public function render_block($attributes) {
|
||||||
|
$file_path = BLOCKSY_PATH . 'framework/extensions/newsletter-subscribe/ct-newsletter-subscribe/view.php';
|
||||||
|
|
||||||
|
if (! file_exists($file_path)) {
|
||||||
|
return '<p>Default widget view. Please create a <i>view.php</i> file.</p>';
|
||||||
|
}
|
||||||
|
|
||||||
|
return blocksy_render_view($file_path, [
|
||||||
|
'atts' => $attributes,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function blocksy_newsletter_block() {
|
||||||
|
register_block_type('blocksy/newsletter', [
|
||||||
|
'render_callback' => [$this, 'render_block'],
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function enqueue_admin() {
|
||||||
|
$deps = [
|
||||||
|
'wp-blocks',
|
||||||
|
'wp-element',
|
||||||
|
'wp-block-editor',
|
||||||
|
];
|
||||||
|
|
||||||
|
global $wp_customize;
|
||||||
|
|
||||||
|
if ($wp_customize) {
|
||||||
|
$deps[] = 'ct-customizer-controls';
|
||||||
|
} else {
|
||||||
|
$deps[] = 'ct-options-scripts';
|
||||||
|
}
|
||||||
|
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy/newsletter',
|
||||||
|
BLOCKSY_URL .
|
||||||
|
'framework/extensions/newsletter-subscribe/admin-static/bundle/newsletter-block.js',
|
||||||
|
$deps
|
||||||
|
);
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
'has_cookies_checkbox' => function_exists('blocksy_ext_cookies_checkbox'),
|
||||||
|
];
|
||||||
|
|
||||||
|
wp_localize_script(
|
||||||
|
'blocksy/newsletter',
|
||||||
|
'blc_newsletter_data',
|
||||||
|
$data
|
||||||
|
);
|
||||||
|
|
||||||
|
wp_enqueue_style(
|
||||||
|
'blocksy/newsletter',
|
||||||
|
BLOCKSY_URL .
|
||||||
|
'framework/extensions/newsletter-subscribe/admin-static/bundle/admin.min.css'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function add_global_styles($args) {
|
||||||
|
blocksy_theme_get_dynamic_styles(
|
||||||
|
array_merge(
|
||||||
|
[
|
||||||
|
'path' => dirname(__FILE__) . '/global.php',
|
||||||
|
'chunk' => 'global',
|
||||||
|
],
|
||||||
|
$args
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function onDeactivation() {
|
||||||
|
remove_action(
|
||||||
|
'blocksy:global-dynamic-css:enqueue',
|
||||||
|
'BlocksyExtensionNewsletterSubscribe::add_global_styles',
|
||||||
|
10,
|
||||||
|
3
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function newsletter_subscribe_process_ajax_subscribe() {
|
||||||
|
if (!isset($_POST['EMAIL'])) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isset($_POST['GROUP'])) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
$email = $_POST['EMAIL'];
|
||||||
|
$name = '';
|
||||||
|
$group = $_POST['GROUP'];
|
||||||
|
|
||||||
|
if (isset($_POST['FNAME'])) {
|
||||||
|
$name = $_POST['FNAME'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$manager = \Blocksy\Extensions\NewsletterSubscribe\Provider::get_for_settings();
|
||||||
|
|
||||||
|
$result = $manager->subscribe_form([
|
||||||
|
'email' => $email,
|
||||||
|
'name' => $name,
|
||||||
|
'group' => $group,
|
||||||
|
]);
|
||||||
|
|
||||||
|
wp_send_json_success($result);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,207 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$forms_type = blocksy_get_theme_mod('forms_type', 'classic-forms');
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('newsletter_subscribe_title_color'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-heading-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('newsletter_subscribe_content'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
'hover' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'text-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-link-hover-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('newsletter_subscribe_button'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => 'var(--theme-palette-color-1)' ],
|
||||||
|
'hover' => [ 'color' => 'var(--theme-palette-color-2)' ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-button-background-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-button-background-hover-color'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('newsletter_subscribe_input_font_color'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
'focus' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-form-text-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'focus' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-form-text-focus-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('newsletter_subscribe_border_color'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
'focus' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-form-field-border-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'focus' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-form-field-border-focus-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
if ($forms_type !== 'classic-forms' || is_customize_preview()) {
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('newsletter_subscribe_input_background'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword() ],
|
||||||
|
'focus' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword() ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-form-field-background-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'focus' => [
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variable' => 'theme-form-field-background-focus-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
blocksy_output_background_css([
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'value' => blocksy_get_theme_mod(
|
||||||
|
'newsletter_subscribe_container_background',
|
||||||
|
blocksy_background_default_value([
|
||||||
|
'backgroundColor' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => 'var(--theme-palette-color-8)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
])
|
||||||
|
),
|
||||||
|
'responsive' => true,
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_border([
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'variableName' => 'newsletter-container-border',
|
||||||
|
'value' => blocksy_get_theme_mod('newsletter_subscribe_container_border'),
|
||||||
|
'skip_none' => true,
|
||||||
|
'default' => [
|
||||||
|
'width' => 1,
|
||||||
|
'style' => 'none',
|
||||||
|
'color' => [
|
||||||
|
'color' => 'var(--theme-palette-color-5)',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'responsive' => true,
|
||||||
|
'skip_none' => true
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_box_shadow([
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'value' => blocksy_get_theme_mod(
|
||||||
|
'newsletter_subscribe_shadow',
|
||||||
|
blocksy_box_shadow_value([
|
||||||
|
'enable' => true,
|
||||||
|
'h_offset' => 0,
|
||||||
|
'v_offset' => 50,
|
||||||
|
'blur' => 90,
|
||||||
|
'spread' => 0,
|
||||||
|
'inset' => false,
|
||||||
|
'color' => [
|
||||||
|
'color' => 'rgba(210, 213, 218, 0.4)',
|
||||||
|
],
|
||||||
|
])
|
||||||
|
),
|
||||||
|
'responsive' => true
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_spacing([
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'property' => 'padding',
|
||||||
|
'value' => blocksy_get_theme_mod(
|
||||||
|
'newsletter_subscribe_container_spacing',
|
||||||
|
blocksy_spacing_value([
|
||||||
|
'top' => '30px',
|
||||||
|
'left' => '30px',
|
||||||
|
'right' => '30px',
|
||||||
|
'bottom' => '30px',
|
||||||
|
])
|
||||||
|
)
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_spacing([
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'selector' => '.ct-newsletter-subscribe-container',
|
||||||
|
'property' => 'theme-border-radius',
|
||||||
|
'value' => blocksy_get_theme_mod(
|
||||||
|
'newsletter_subscribe_container_border_radius',
|
||||||
|
blocksy_spacing_value()
|
||||||
|
)
|
||||||
|
]);
|
||||||
@ -0,0 +1,157 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
function blc_ext_newsletter_subscribe_form() {
|
||||||
|
if (blocksy_get_theme_mod('newsletter_subscribe_single_post_enabled', 'yes') !== 'yes') {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
blocksy_default_akg(
|
||||||
|
'disable_subscribe_form',
|
||||||
|
blocksy_get_post_options(),
|
||||||
|
'no'
|
||||||
|
) === 'yes'
|
||||||
|
) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$args = [
|
||||||
|
'title' => blocksy_get_theme_mod(
|
||||||
|
'newsletter_subscribe_title',
|
||||||
|
__('Newsletter Updates', 'blocksy-companion')
|
||||||
|
),
|
||||||
|
|
||||||
|
'description' => blocksy_get_theme_mod('newsletter_subscribe_text', __(
|
||||||
|
'Enter your email address below and subscribe to our newsletter',
|
||||||
|
'blocksy-companion'
|
||||||
|
)),
|
||||||
|
|
||||||
|
'button_text' => blocksy_get_theme_mod(
|
||||||
|
'newsletter_subscribe_button_text',
|
||||||
|
__('Subscribe', 'blocksy-companion')
|
||||||
|
),
|
||||||
|
'has_name' => blocksy_get_theme_mod('has_newsletter_subscribe_name', 'no'),
|
||||||
|
'name_label' => blocksy_get_theme_mod(
|
||||||
|
'newsletter_subscribe_name_label',
|
||||||
|
__('Your name', 'blocksy-companion')
|
||||||
|
),
|
||||||
|
'email_label' => blocksy_get_theme_mod(
|
||||||
|
'newsletter_subscribe_mail_label',
|
||||||
|
__('Your email', 'blocksy-companion')
|
||||||
|
)
|
||||||
|
];
|
||||||
|
|
||||||
|
$list_id = null;
|
||||||
|
|
||||||
|
if (blocksy_get_theme_mod(
|
||||||
|
'newsletter_subscribe_list_id_source',
|
||||||
|
'default'
|
||||||
|
) === 'custom') {
|
||||||
|
$args['list_id'] = blocksy_get_theme_mod('newsletter_subscribe_list_id', '');
|
||||||
|
}
|
||||||
|
|
||||||
|
$args['class'] = 'ct-newsletter-subscribe-container ' . blocksy_visibility_classes(
|
||||||
|
blocksy_get_theme_mod('newsletter_subscribe_subscribe_visibility', [
|
||||||
|
'desktop' => true,
|
||||||
|
'tablet' => true,
|
||||||
|
'mobile' => false,
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
return blc_ext_newsletter_subscribe_output_form($args);
|
||||||
|
}
|
||||||
|
|
||||||
|
function blc_ext_newsletter_subscribe_output_form($args = []) {
|
||||||
|
$args = wp_parse_args($args, [
|
||||||
|
'has_title' => true,
|
||||||
|
'has_description' => true,
|
||||||
|
'title' => __(
|
||||||
|
'Newsletter Updates', 'blocksy-companion'
|
||||||
|
),
|
||||||
|
'description' => __(
|
||||||
|
'Enter your email address below to subscribe to our newsletter',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
'button_text' => __(
|
||||||
|
'Subscribe', 'blocksy-companion'
|
||||||
|
),
|
||||||
|
'has_name' => 'no',
|
||||||
|
'name_label' => __('Your name', 'blocksy-companion'),
|
||||||
|
'email_label' => __('Your email', 'blocksy-companion'),
|
||||||
|
'list_id' => '',
|
||||||
|
'class' => ''
|
||||||
|
]);
|
||||||
|
|
||||||
|
$has_name = $args['has_name'] === 'yes';
|
||||||
|
|
||||||
|
$manager = \Blocksy\Extensions\NewsletterSubscribe\Provider::get_for_settings();
|
||||||
|
$provider_data = $manager->get_form_url_and_gdpr_for($args['list_id']);
|
||||||
|
|
||||||
|
if (! $provider_data) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($provider_data['provider'] !== 'mailchimp') {
|
||||||
|
$settings = $manager->get_settings();
|
||||||
|
$provider_data['provider'] .= ':' . $settings['list_id'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$form_url = $provider_data['form_url'];
|
||||||
|
$has_gdpr_fields = $provider_data['has_gdpr_fields'];
|
||||||
|
|
||||||
|
$skip_submit_output = '';
|
||||||
|
|
||||||
|
if ($has_gdpr_fields) {
|
||||||
|
$skip_submit_output = 'data-skip-submit';
|
||||||
|
}
|
||||||
|
|
||||||
|
$fields_number = '2';
|
||||||
|
|
||||||
|
if ($has_name) {
|
||||||
|
$fields_number = '3';
|
||||||
|
}
|
||||||
|
|
||||||
|
ob_start();
|
||||||
|
|
||||||
|
?>
|
||||||
|
|
||||||
|
<div class="<?php echo esc_attr(trim($args['class'])) ?>">
|
||||||
|
<?php if ($args['has_title']) { ?>
|
||||||
|
<h3><?php echo esc_html($args['title']) ?></h3>
|
||||||
|
<?php } ?>
|
||||||
|
|
||||||
|
<?php if ($args['has_description'] && ! empty($args['description'])) { ?>
|
||||||
|
<p>
|
||||||
|
<?php echo $args['description'] ?>
|
||||||
|
</p>
|
||||||
|
<?php } ?>
|
||||||
|
|
||||||
|
<form target="_blank" action="<?php echo esc_attr($form_url) ?>" method="post"
|
||||||
|
data-provider="<?php echo $provider_data['provider'] ?>"
|
||||||
|
class="ct-newsletter-subscribe-form"
|
||||||
|
data-columns="<?php echo $fields_number ?>"
|
||||||
|
<?php echo $skip_submit_output ?>>
|
||||||
|
|
||||||
|
<?php if ($has_name) { ?>
|
||||||
|
<input type="text" name="FNAME" placeholder="<?php esc_attr_e($args['name_label'], 'blocksy-companion'); ?>" aria-label="<?php echo __('First name', 'blocksy-companion') ?>">
|
||||||
|
<?php } ?>
|
||||||
|
|
||||||
|
<input type="email" name="EMAIL" placeholder="<?php esc_attr_e($args['email_label'], 'blocksy-companion'); ?> *" aria-label="<?php echo __('Email address', 'blocksy-companion') ?>" required>
|
||||||
|
|
||||||
|
<button class="wp-element-button">
|
||||||
|
<?php echo esc_html($args['button_text']) ?>
|
||||||
|
</button>
|
||||||
|
|
||||||
|
<?php if (function_exists('blocksy_ext_cookies_checkbox')) {
|
||||||
|
echo blocksy_ext_cookies_checkbox('subscribe');
|
||||||
|
} ?>
|
||||||
|
|
||||||
|
<div class="ct-newsletter-subscribe-message"></div>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<?php
|
||||||
|
|
||||||
|
return ob_get_clean();
|
||||||
|
}
|
||||||
@ -0,0 +1,97 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy\Extensions\NewsletterSubscribe;
|
||||||
|
|
||||||
|
class Provider {
|
||||||
|
static public function get_for_settings() {
|
||||||
|
$m = new Provider();
|
||||||
|
$settings = $m->get_settings();
|
||||||
|
|
||||||
|
return Provider::get_for_provider(
|
||||||
|
$settings['provider']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
static public function get_for_provider($provider) {
|
||||||
|
if ($provider === 'mailchimp') {
|
||||||
|
return new MailchimpProvider();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($provider === 'brevo') {
|
||||||
|
return new BrevoProvider();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($provider === 'campaignmonitor') {
|
||||||
|
return new CampaignMonitorProvider();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($provider === 'mailerlite-new') {
|
||||||
|
return new MailerliteNewProvider();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($provider === 'convertkit') {
|
||||||
|
return new ConvertKitProvider();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($provider === 'demo') {
|
||||||
|
return new DemoProvider();
|
||||||
|
}
|
||||||
|
|
||||||
|
return new MailerliteClassicProvider();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function fetch_lists($api_key) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_settings() {
|
||||||
|
$option = get_option('blocksy_ext_mailchimp_credentials', []);
|
||||||
|
|
||||||
|
if (empty($option)) {
|
||||||
|
$option = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
$free_providers = ['mailchimp', 'demo'];
|
||||||
|
|
||||||
|
if (
|
||||||
|
isset($option['provider'])
|
||||||
|
&&
|
||||||
|
! in_array($option['provider'], $free_providers)
|
||||||
|
&&
|
||||||
|
blc_get_capabilities()->get_plan() === 'free'
|
||||||
|
) {
|
||||||
|
$option['provider'] = $free_providers[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
return array_merge([
|
||||||
|
'provider' => 'mailchimp',
|
||||||
|
'api_key' => null,
|
||||||
|
'list_id' => null
|
||||||
|
], $option);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function set_settings($vals) {
|
||||||
|
update_option('blocksy_ext_mailchimp_credentials', array_merge([
|
||||||
|
'provider' => 'mailchimp',
|
||||||
|
'api_key' => null,
|
||||||
|
'list_id' => null
|
||||||
|
], $vals));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function can($capability = 'manage_options') {
|
||||||
|
if (is_multisite()) {
|
||||||
|
// Only network admin can change files that affects the entire network.
|
||||||
|
$can = current_user_can_for_blog( get_current_blog_id(), $capability );
|
||||||
|
} else {
|
||||||
|
$can = current_user_can( $capability );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($can) {
|
||||||
|
// Also you can use this method to get the capability.
|
||||||
|
$can = $capability;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $can;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1,132 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class BlocksyExtensionNewsletterSubscribePreBoot {
|
||||||
|
public function __construct() {
|
||||||
|
add_filter('blocksy-dashboard-scripts-dependencies', function ($s) {
|
||||||
|
$s[] = 'blocksy-ext-mailchimp-dashboard-scripts';
|
||||||
|
return $s;
|
||||||
|
});
|
||||||
|
|
||||||
|
add_action('admin_enqueue_scripts', function () {
|
||||||
|
if (! function_exists('get_plugin_data')) {
|
||||||
|
require_once(ABSPATH . 'wp-admin/includes/plugin.php');
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
wp_register_script(
|
||||||
|
'blocksy-ext-mailchimp-dashboard-scripts',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/newsletter-subscribe/dashboard-static/bundle/main.js',
|
||||||
|
[],
|
||||||
|
$data['Version'],
|
||||||
|
true
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'wp_ajax_blocksy_ext_newsletter_subscribe_maybe_get_lists',
|
||||||
|
[$this, 'get_lists']
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'wp_ajax_blocksy_ext_newsletter_subscribe_get_actual_lists',
|
||||||
|
[$this, 'get_actual_lists']
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'wp_ajax_blocksy_ext_newsletter_subscribe_maybe_save_credentials',
|
||||||
|
[$this, 'save_credentials']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function ext_data() {
|
||||||
|
$m = new \Blocksy\Extensions\NewsletterSubscribe\MailchimpProvider();
|
||||||
|
return $m->get_settings();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function save_credentials() {
|
||||||
|
if (! check_ajax_referer('ct-dashboard', 'nonce', false)) {
|
||||||
|
wp_send_json_error('nonce');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->maybe_save_credentials();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_actual_lists() {
|
||||||
|
if (! check_ajax_referer('ct-dashboard', 'nonce', false)) {
|
||||||
|
wp_send_json_error('nonce');
|
||||||
|
}
|
||||||
|
|
||||||
|
$m = \Blocksy\Extensions\NewsletterSubscribe\Provider::get_for_settings();
|
||||||
|
|
||||||
|
if (! $m->can()) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
$settings = $m->get_settings();
|
||||||
|
|
||||||
|
$lists = $m->fetch_lists($settings['api_key']);
|
||||||
|
|
||||||
|
wp_send_json_success([
|
||||||
|
'result' => $lists
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_lists() {
|
||||||
|
if (! check_ajax_referer('ct-dashboard', 'nonce', false)) {
|
||||||
|
wp_send_json_error('nonce');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->maybe_save_credentials(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function maybe_save_credentials($save = true) {
|
||||||
|
$provider = $this->get_provider_from_request();
|
||||||
|
|
||||||
|
$m = \Blocksy\Extensions\NewsletterSubscribe\Provider::get_for_provider($provider);
|
||||||
|
|
||||||
|
if (! $m->can()) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
$lists = $m->fetch_lists($this->get_api_key_from_request());
|
||||||
|
|
||||||
|
if ($save) {
|
||||||
|
if (is_array($lists)) {
|
||||||
|
$m->set_settings([
|
||||||
|
'provider' => $this->get_provider_from_request(),
|
||||||
|
'api_key' => $this->get_api_key_from_request(),
|
||||||
|
'list_id' => $this->get_list_id_from_request(),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
wp_send_json_success([
|
||||||
|
'result' => $lists
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_provider_from_request() {
|
||||||
|
if (! isset($_POST['provider'])) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
return addslashes($_POST['provider']);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_api_key_from_request() {
|
||||||
|
if (! isset($_POST['api_key'])) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
return addslashes($_POST['api_key']);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_list_id_from_request() {
|
||||||
|
if (! isset($_POST['list_id'])) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
return addslashes($_POST['list_id']);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,121 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy\Extensions\NewsletterSubscribe;
|
||||||
|
|
||||||
|
class BrevoProvider extends Provider {
|
||||||
|
public function fetch_lists($api_key) {
|
||||||
|
if (! $api_key) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = wp_remote_get(
|
||||||
|
'https://api.brevo.com/v3/contacts/lists?limit=50&offset=0&sort=desc',
|
||||||
|
[
|
||||||
|
'headers' => [
|
||||||
|
'api-key' => $api_key
|
||||||
|
]
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
if (! is_wp_error($response)) {
|
||||||
|
if (200 !== wp_remote_retrieve_response_code($response)) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$body = json_decode(wp_remote_retrieve_body($response), true);
|
||||||
|
|
||||||
|
if (! $body || ! isset($body['lists'])) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
return array_map(function($list) {
|
||||||
|
return [
|
||||||
|
'name' => $list['name'],
|
||||||
|
'id' => $list['id'],
|
||||||
|
];
|
||||||
|
}, $body['lists']);
|
||||||
|
} else {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_form_url_and_gdpr_for($maybe_custom_list = null) {
|
||||||
|
return [
|
||||||
|
'form_url' => '#',
|
||||||
|
'has_gdpr_fields' => false,
|
||||||
|
'provider' => 'brevo'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function subscribe_form($args = []) {
|
||||||
|
$args = wp_parse_args($args, [
|
||||||
|
'email' => '',
|
||||||
|
'name' => '',
|
||||||
|
'group' => ''
|
||||||
|
]);
|
||||||
|
|
||||||
|
$settings = $this->get_settings();
|
||||||
|
|
||||||
|
$curl = curl_init();
|
||||||
|
|
||||||
|
$lname = '';
|
||||||
|
$fname = '';
|
||||||
|
|
||||||
|
if (! empty($args['name'])) {
|
||||||
|
$parts = explode(' ', $args['name']);
|
||||||
|
|
||||||
|
$lname = array_pop($parts);
|
||||||
|
$fname = implode(' ', $parts);
|
||||||
|
}
|
||||||
|
|
||||||
|
curl_setopt_array($curl, array(
|
||||||
|
// CURLOPT_URL => "https://api.mailerlite.com/api/v2/groups/" . $args['group'] . "/subscribers",
|
||||||
|
CURLOPT_URL => 'https://api.brevo.com/v3/contacts',
|
||||||
|
CURLOPT_RETURNTRANSFER => true,
|
||||||
|
CURLOPT_ENCODING => "",
|
||||||
|
CURLOPT_MAXREDIRS => 10,
|
||||||
|
CURLOPT_TIMEOUT => 30,
|
||||||
|
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
|
||||||
|
CURLOPT_CUSTOMREQUEST => "POST",
|
||||||
|
CURLOPT_POSTFIELDS => json_encode([
|
||||||
|
'email' => $args['email'],
|
||||||
|
'attributes' => [
|
||||||
|
'FIRSTNAME' => $fname,
|
||||||
|
'LASTNAME' => $lname
|
||||||
|
],
|
||||||
|
'listIds' => [intval($settings['list_id'])]
|
||||||
|
]),
|
||||||
|
CURLOPT_HTTPHEADER => array(
|
||||||
|
"content-type: application/json",
|
||||||
|
"api-key: " . $settings['api_key']
|
||||||
|
),
|
||||||
|
));
|
||||||
|
|
||||||
|
$response = curl_exec($curl);
|
||||||
|
$err = curl_error($curl);
|
||||||
|
|
||||||
|
curl_close($curl);
|
||||||
|
|
||||||
|
if ($err) {
|
||||||
|
return [
|
||||||
|
'result' => 'no',
|
||||||
|
'error' => $err
|
||||||
|
];
|
||||||
|
} else {
|
||||||
|
$response = json_decode($response, true);
|
||||||
|
|
||||||
|
if (isset($response['code'])) {
|
||||||
|
return [
|
||||||
|
'result' => 'no',
|
||||||
|
'message' => $response['message']
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'result' => 'yes',
|
||||||
|
'message' => __('Thank you for subscribing to our newsletter!', 'blocksy-companion')
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1,141 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy\Extensions\NewsletterSubscribe;
|
||||||
|
|
||||||
|
class CampaignMonitorProvider extends Provider {
|
||||||
|
public function fetch_lists($api_key) {
|
||||||
|
if (! $api_key) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = wp_remote_get(
|
||||||
|
'https://api.createsend.com/api/v3.3/clients.json',
|
||||||
|
[
|
||||||
|
'headers' => [
|
||||||
|
'Authorization' => 'Basic ' . base64_encode($api_key . ':x')
|
||||||
|
]
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
if (is_wp_error($response)) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (200 !== wp_remote_retrieve_response_code($response)) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$clients = json_decode(wp_remote_retrieve_body($response), true);
|
||||||
|
|
||||||
|
if (
|
||||||
|
! $clients
|
||||||
|
||
|
||||||
|
empty($clients)
|
||||||
|
||
|
||||||
|
! isset($clients[0]['ClientID'])
|
||||||
|
) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = wp_remote_get(
|
||||||
|
'https://api.createsend.com/api/v3.3/clients/' . $clients[0]['ClientID'] . '/lists.json',
|
||||||
|
[
|
||||||
|
'headers' => [
|
||||||
|
'Authorization' => 'Basic ' . base64_encode($api_key . ':x')
|
||||||
|
]
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
if (is_wp_error($response)) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (200 !== wp_remote_retrieve_response_code($response)) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$lists = json_decode(wp_remote_retrieve_body($response), true);
|
||||||
|
|
||||||
|
if (
|
||||||
|
! $lists
|
||||||
|
||
|
||||||
|
empty($lists)
|
||||||
|
) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
return array_map(function($list) {
|
||||||
|
return [
|
||||||
|
'name' => $list['Name'],
|
||||||
|
'id' => $list['ListID']
|
||||||
|
];
|
||||||
|
}, $lists);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_form_url_and_gdpr_for($maybe_custom_list = null) {
|
||||||
|
return [
|
||||||
|
'form_url' => '#',
|
||||||
|
'has_gdpr_fields' => false,
|
||||||
|
'provider' => 'campaignmonitor'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function subscribe_form($args = []) {
|
||||||
|
$args = wp_parse_args($args, [
|
||||||
|
'email' => '',
|
||||||
|
'name' => '',
|
||||||
|
'group' => ''
|
||||||
|
]);
|
||||||
|
|
||||||
|
$settings = $this->get_settings();
|
||||||
|
|
||||||
|
$curl = curl_init();
|
||||||
|
|
||||||
|
curl_setopt_array($curl, array(
|
||||||
|
CURLOPT_URL => 'https://api.createsend.com/api/v3.3/subscribers/' . $args['group'] . '.json',
|
||||||
|
CURLOPT_RETURNTRANSFER => true,
|
||||||
|
CURLOPT_ENCODING => "",
|
||||||
|
CURLOPT_MAXREDIRS => 10,
|
||||||
|
CURLOPT_TIMEOUT => 30,
|
||||||
|
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
|
||||||
|
CURLOPT_CUSTOMREQUEST => "POST",
|
||||||
|
CURLOPT_POSTFIELDS => json_encode([
|
||||||
|
'EmailAddress' => $args['email'],
|
||||||
|
'Name' => $args['name'],
|
||||||
|
'ConsentToTrack' => 'Yes'
|
||||||
|
]),
|
||||||
|
CURLOPT_HTTPHEADER => [
|
||||||
|
"content-type: application/json"
|
||||||
|
],
|
||||||
|
CURLOPT_HTTPAUTH => CURLAUTH_BASIC,
|
||||||
|
CURLOPT_USERPWD => $settings['api_key'] . ':x'
|
||||||
|
));
|
||||||
|
|
||||||
|
$response = curl_exec($curl);
|
||||||
|
$err = curl_error($curl);
|
||||||
|
|
||||||
|
curl_close($curl);
|
||||||
|
|
||||||
|
if ($err) {
|
||||||
|
return [
|
||||||
|
'result' => 'no',
|
||||||
|
'error' => $err
|
||||||
|
];
|
||||||
|
} else {
|
||||||
|
$response = json_decode($response, true);
|
||||||
|
|
||||||
|
if (isset($response['Code'])) {
|
||||||
|
return [
|
||||||
|
'result' => 'no',
|
||||||
|
'message' => $response['Message']
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'result' => 'yes',
|
||||||
|
'message' => __('Thank you for subscribing to our newsletter!', 'blocksy-companion')
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1,102 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy\Extensions\NewsletterSubscribe;
|
||||||
|
|
||||||
|
class ConvertKitProvider extends Provider {
|
||||||
|
public function fetch_lists($api_key) {
|
||||||
|
|
||||||
|
if (! $api_key) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = wp_remote_get(
|
||||||
|
'https://api.convertkit.com/v3/forms/?api_key=' . $api_key,
|
||||||
|
[]
|
||||||
|
);
|
||||||
|
|
||||||
|
if (! is_wp_error($response)) {
|
||||||
|
if (200 !== wp_remote_retrieve_response_code($response)) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$body = json_decode(wp_remote_retrieve_body($response), true);
|
||||||
|
|
||||||
|
if (! $body || ! isset($body['forms'])) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
return array_map(function($list) {
|
||||||
|
return [
|
||||||
|
'name' => $list['name'],
|
||||||
|
'id' => $list['id'],
|
||||||
|
];
|
||||||
|
}, $body['forms']);
|
||||||
|
} else {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_form_url_and_gdpr_for($maybe_custom_list = null) {
|
||||||
|
return [
|
||||||
|
'form_url' => '#',
|
||||||
|
'has_gdpr_fields' => false,
|
||||||
|
'provider' => 'convertkit'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function subscribe_form($args = []) {
|
||||||
|
$args = wp_parse_args($args, [
|
||||||
|
'email' => '',
|
||||||
|
'name' => '',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$settings = $this->get_settings();
|
||||||
|
|
||||||
|
$curl = curl_init();
|
||||||
|
|
||||||
|
curl_setopt_array($curl, array(
|
||||||
|
CURLOPT_URL => 'https://api.convertkit.com/v3/forms/' . $settings['list_id'] . '/subscribe',
|
||||||
|
CURLOPT_RETURNTRANSFER => true,
|
||||||
|
CURLOPT_ENCODING => "",
|
||||||
|
CURLOPT_MAXREDIRS => 10,
|
||||||
|
CURLOPT_TIMEOUT => 30,
|
||||||
|
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
|
||||||
|
CURLOPT_CUSTOMREQUEST => "POST",
|
||||||
|
CURLOPT_POSTFIELDS => json_encode([
|
||||||
|
'api_key' => $settings['api_key'],
|
||||||
|
'email' => $args['email'],
|
||||||
|
'first_name' => $args['name'],
|
||||||
|
]),
|
||||||
|
CURLOPT_HTTPHEADER => array(
|
||||||
|
"content-type: application/json; charset=utf-8"
|
||||||
|
),
|
||||||
|
));
|
||||||
|
|
||||||
|
$response = curl_exec($curl);
|
||||||
|
$err = curl_error($curl);
|
||||||
|
|
||||||
|
curl_close($curl);
|
||||||
|
|
||||||
|
if ($err) {
|
||||||
|
return [
|
||||||
|
'result' => 'no',
|
||||||
|
'error' => $err
|
||||||
|
];
|
||||||
|
} else {
|
||||||
|
$response = json_decode($response, true);
|
||||||
|
|
||||||
|
if (isset($response['code'])) {
|
||||||
|
return [
|
||||||
|
'result' => 'no',
|
||||||
|
'message' => $response['message']
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'result' => 'yes',
|
||||||
|
'message' => __('Thank you for subscribing to our newsletter!', 'blocksy-companion')
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1,45 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy\Extensions\NewsletterSubscribe;
|
||||||
|
|
||||||
|
class DemoProvider extends Provider {
|
||||||
|
public function __construct() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public function fetch_lists($api_key) {
|
||||||
|
if (! $api_key) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
[
|
||||||
|
'name' => __('Demo List', 'blocksy-companion'),
|
||||||
|
'id' => 'demolist'
|
||||||
|
]
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_form_url_and_gdpr_for($maybe_custom_list = null) {
|
||||||
|
return [
|
||||||
|
'form_url' => '#',
|
||||||
|
'has_gdpr_fields' => false,
|
||||||
|
'provider' => 'demo'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function subscribe_form($args = []) {
|
||||||
|
$args = wp_parse_args($args, [
|
||||||
|
'email' => '',
|
||||||
|
'name' => '',
|
||||||
|
'group' => ''
|
||||||
|
]);
|
||||||
|
|
||||||
|
return [
|
||||||
|
// 'response' => $response,
|
||||||
|
'result' => 'yes',
|
||||||
|
'message' => __('Thank you for subscribing to our newsletter!', 'blocksy-companion')
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -0,0 +1,117 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy\Extensions\NewsletterSubscribe;
|
||||||
|
|
||||||
|
class MailchimpProvider extends Provider {
|
||||||
|
public function __construct() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public function fetch_lists($api_key) {
|
||||||
|
if (! $api_key) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strpos($api_key, '-') === false) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$region = explode('-', $api_key);
|
||||||
|
|
||||||
|
$response = wp_remote_get(
|
||||||
|
'https://' . $region[1] . '.api.mailchimp.com/3.0/lists?count=1000',
|
||||||
|
[
|
||||||
|
'timeout' => 2,
|
||||||
|
'headers' => [
|
||||||
|
'Authorization' => 'Basic ' . base64_encode(
|
||||||
|
'asd:' . $api_key
|
||||||
|
)
|
||||||
|
]
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
if (! is_wp_error($response)) {
|
||||||
|
if (200 !== wp_remote_retrieve_response_code($response)) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$body = json_decode(wp_remote_retrieve_body($response), true);
|
||||||
|
|
||||||
|
if (! $body) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! isset($body['lists'])) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
return array_map(function($list) {
|
||||||
|
return [
|
||||||
|
'name' => $list['name'],
|
||||||
|
'id' => $list['id'],
|
||||||
|
'subscribe_url_long' => $list['subscribe_url_long'],
|
||||||
|
|
||||||
|
'subscribe_url_long_json' => str_replace(
|
||||||
|
'subscribe',
|
||||||
|
'subscribe/post-json',
|
||||||
|
$list['subscribe_url_long'] . '&c=callback'
|
||||||
|
),
|
||||||
|
|
||||||
|
'has_gdpr_fields' => $list['marketing_permissions']
|
||||||
|
];
|
||||||
|
}, $body['lists']);
|
||||||
|
} else {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_form_url_and_gdpr_for($maybe_custom_list = null) {
|
||||||
|
$settings = $this->get_settings();
|
||||||
|
|
||||||
|
if (! isset($settings['api_key'])) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! $settings['api_key']) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$lists = $this->fetch_lists($settings['api_key']);
|
||||||
|
|
||||||
|
if (! is_array($lists)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($lists)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($maybe_custom_list) {
|
||||||
|
$settings['list_id'] = $maybe_custom_list;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! $settings['list_id']) {
|
||||||
|
return [
|
||||||
|
'form_url' => $lists[0]['subscribe_url_long'],
|
||||||
|
'has_gdpr_fields' => $lists[0]['has_gdpr_fields'],
|
||||||
|
'provider' => 'mailchimp'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($lists as $single_list) {
|
||||||
|
if ($single_list['id'] === $settings['list_id']) {
|
||||||
|
return [
|
||||||
|
'form_url' => $single_list['subscribe_url_long'],
|
||||||
|
'has_gdpr_fields' => $single_list['has_gdpr_fields'],
|
||||||
|
'provider' => 'mailchimp'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'form_url' => $lists[0]['subscribe_url_long'],
|
||||||
|
'has_gdpr_fields' => $lists[0]['has_gdpr_fields'],
|
||||||
|
'provider' => 'mailchimp'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1,107 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy\Extensions\NewsletterSubscribe;
|
||||||
|
|
||||||
|
class MailerliteClassicProvider extends Provider {
|
||||||
|
public function fetch_lists($api_key) {
|
||||||
|
if (! $api_key) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = wp_remote_get(
|
||||||
|
'https://api.mailerlite.com/api/v2/groups',
|
||||||
|
[
|
||||||
|
'headers' => [
|
||||||
|
'X-MailerLite-ApiKey' => $api_key
|
||||||
|
]
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
if (! is_wp_error($response)) {
|
||||||
|
if (200 !== wp_remote_retrieve_response_code($response)) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$body = json_decode(wp_remote_retrieve_body($response), true);
|
||||||
|
|
||||||
|
if (! $body) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
return array_map(function($list) {
|
||||||
|
return [
|
||||||
|
'name' => $list['name'],
|
||||||
|
'id' => $list['id'],
|
||||||
|
];
|
||||||
|
}, $body);
|
||||||
|
} else {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_form_url_and_gdpr_for($maybe_custom_list = null) {
|
||||||
|
return [
|
||||||
|
'form_url' => '#',
|
||||||
|
'has_gdpr_fields' => false,
|
||||||
|
'provider' => 'mailerlite'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function subscribe_form($args = []) {
|
||||||
|
$args = wp_parse_args($args, [
|
||||||
|
'email' => '',
|
||||||
|
'name' => '',
|
||||||
|
'group' => ''
|
||||||
|
]);
|
||||||
|
|
||||||
|
$settings = $this->get_settings();
|
||||||
|
|
||||||
|
$curl = curl_init();
|
||||||
|
|
||||||
|
curl_setopt_array($curl, array(
|
||||||
|
CURLOPT_URL => "https://api.mailerlite.com/api/v2/groups/" . $args['group'] . "/subscribers",
|
||||||
|
CURLOPT_RETURNTRANSFER => true,
|
||||||
|
CURLOPT_ENCODING => "",
|
||||||
|
CURLOPT_MAXREDIRS => 10,
|
||||||
|
CURLOPT_TIMEOUT => 30,
|
||||||
|
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
|
||||||
|
CURLOPT_CUSTOMREQUEST => "POST",
|
||||||
|
CURLOPT_POSTFIELDS => json_encode([
|
||||||
|
'email' => $args['email'],
|
||||||
|
'name' => $args['name']
|
||||||
|
]),
|
||||||
|
CURLOPT_HTTPHEADER => array(
|
||||||
|
"content-type: application/json",
|
||||||
|
"x-mailerlite-apikey: " . $settings['api_key']
|
||||||
|
),
|
||||||
|
));
|
||||||
|
|
||||||
|
$response = curl_exec($curl);
|
||||||
|
$err = curl_error($curl);
|
||||||
|
|
||||||
|
curl_close($curl);
|
||||||
|
|
||||||
|
if ($err) {
|
||||||
|
return [
|
||||||
|
'result' => 'no',
|
||||||
|
'error' => $err
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = json_decode($response, true);
|
||||||
|
|
||||||
|
if (isset($response['error'])) {
|
||||||
|
return [
|
||||||
|
// 'response' => $response,
|
||||||
|
'result' => 'no',
|
||||||
|
'message' => $response['error']['message']
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
// 'response' => $response,
|
||||||
|
'result' => 'yes',
|
||||||
|
'message' => __('Thank you for subscribing to our newsletter!', 'blocksy-companion')
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,127 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Blocksy\Extensions\NewsletterSubscribe;
|
||||||
|
|
||||||
|
class MailerliteNewProvider extends Provider {
|
||||||
|
public function fetch_lists($api_key) {
|
||||||
|
if (! $api_key) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$curl = curl_init();
|
||||||
|
|
||||||
|
curl_setopt_array($curl, array(
|
||||||
|
CURLOPT_URL => 'https://connect.mailerlite.com/api/groups',
|
||||||
|
CURLOPT_RETURNTRANSFER => true,
|
||||||
|
CURLOPT_ENCODING => "",
|
||||||
|
CURLOPT_MAXREDIRS => 10,
|
||||||
|
CURLOPT_TIMEOUT => 30,
|
||||||
|
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
|
||||||
|
CURLOPT_CUSTOMREQUEST => "GET",
|
||||||
|
CURLOPT_HTTPHEADER => array(
|
||||||
|
"content-type: application/json",
|
||||||
|
"Authorization: Bearer " . $api_key
|
||||||
|
),
|
||||||
|
));
|
||||||
|
|
||||||
|
$response = curl_exec($curl);
|
||||||
|
$err = curl_error($curl);
|
||||||
|
|
||||||
|
curl_close($curl);
|
||||||
|
|
||||||
|
if ($err) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = json_decode($response, true);
|
||||||
|
|
||||||
|
if (
|
||||||
|
isset($response['error'])
|
||||||
|
||
|
||||||
|
! isset($response['data'])
|
||||||
|
||
|
||||||
|
! is_array($response['data'])
|
||||||
|
) {
|
||||||
|
return 'api_key_invalid';
|
||||||
|
}
|
||||||
|
|
||||||
|
return array_map(function($list) {
|
||||||
|
return [
|
||||||
|
'name' => $list['name'],
|
||||||
|
'id' => $list['id'],
|
||||||
|
];
|
||||||
|
}, $response['data']);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_form_url_and_gdpr_for($maybe_custom_list = null) {
|
||||||
|
return [
|
||||||
|
'form_url' => '#',
|
||||||
|
'has_gdpr_fields' => false,
|
||||||
|
'provider' => 'mailerlite'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function subscribe_form($args = []) {
|
||||||
|
$args = wp_parse_args($args, [
|
||||||
|
'email' => '',
|
||||||
|
'name' => '',
|
||||||
|
'group' => ''
|
||||||
|
]);
|
||||||
|
|
||||||
|
$settings = $this->get_settings();
|
||||||
|
|
||||||
|
$curl = curl_init();
|
||||||
|
|
||||||
|
curl_setopt_array($curl, array(
|
||||||
|
CURLOPT_URL => 'https://connect.mailerlite.com/api/subscribers',
|
||||||
|
CURLOPT_RETURNTRANSFER => true,
|
||||||
|
CURLOPT_ENCODING => "",
|
||||||
|
CURLOPT_MAXREDIRS => 10,
|
||||||
|
CURLOPT_TIMEOUT => 30,
|
||||||
|
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
|
||||||
|
CURLOPT_CUSTOMREQUEST => "POST",
|
||||||
|
CURLOPT_POSTFIELDS => json_encode([
|
||||||
|
'email' => $args['email'],
|
||||||
|
'fields' => [
|
||||||
|
'name' => $args['name']
|
||||||
|
],
|
||||||
|
'groups' => [
|
||||||
|
$args['group']
|
||||||
|
]
|
||||||
|
]),
|
||||||
|
CURLOPT_HTTPHEADER => array(
|
||||||
|
"content-type: application/json",
|
||||||
|
"Authorization: Bearer " . $settings['api_key']
|
||||||
|
),
|
||||||
|
));
|
||||||
|
|
||||||
|
$response = curl_exec($curl);
|
||||||
|
$err = curl_error($curl);
|
||||||
|
|
||||||
|
curl_close($curl);
|
||||||
|
|
||||||
|
if ($err) {
|
||||||
|
return [
|
||||||
|
'result' => 'no',
|
||||||
|
'error' => $err
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = json_decode($response, true);
|
||||||
|
|
||||||
|
if (isset($response['error'])) {
|
||||||
|
return [
|
||||||
|
// 'response' => $response,
|
||||||
|
'result' => 'no',
|
||||||
|
'message' => $response['error']['message']
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
// 'response' => $response,
|
||||||
|
'result' => 'yes',
|
||||||
|
'message' => __('Thank you for subscribing to our newsletter!', 'blocksy-companion')
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1 @@
|
|||||||
|
!function(){"use strict";var e=window.ctFrontend;(0,e.registerDynamicChunk)("blocksy_ext_newsletter_subscribe",{mount:function(e,s){var r=s.event.target;"mailchimp"===r.dataset.provider&&function(e){if(e.querySelector('[type="email"]').value.trim()){if(document.getElementById("js-validate-robot")&&""!==document.getElementById("js-validate-robot").value)return!1;for(var s=e.action.replace("subscribe","subscribe/post-json"),r="",t="mailchimpCallback",c=e.querySelectorAll("input"),i=0;i<c.length;i++)r+="&"+c[i].name+"="+encodeURIComponent(c[i].value);r+="&c=".concat(t);var a=document.createElement("script");a.src=s+r,document.body.appendChild(a),e.classList.remove("subscribe-error","subscribe-success"),e.classList.add("subscribe-loading"),window[t]=function(s){delete window[t],document.body.removeChild(a),e.classList.remove("subscribe-loading"),s&&(e.classList.add("error"===s.result?"subscribe-error":"subscribe-success"),e.querySelector(".ct-newsletter-subscribe-message").innerHTML=s.msg.replace("0 - ",""))}}}(r),-1===r.dataset.provider.indexOf("mailchimp")&&function(e){var s=new FormData(e);s.append("action","blc_newsletter_subscribe_process_ajax_subscribe"),s.append("GROUP",e.dataset.provider.split(":")[1]),e.classList.remove("subscribe-error","subscribe-success"),e.classList.add("subscribe-loading"),fetch(ct_localizations.ajax_url,{method:"POST",body:s}).then((function(e){return e.json()})).then((function(s){s.success;var r=s.data;e.classList.remove("subscribe-loading"),e.classList.add("no"===r.result?"subscribe-error":"subscribe-success"),e.querySelector(".ct-newsletter-subscribe-message").innerHTML=r.message}))}(r)}})}();
|
||||||
@ -0,0 +1,8 @@
|
|||||||
|
/**
|
||||||
|
* - v2.0.37
|
||||||
|
*
|
||||||
|
* Copyright (c) 2024
|
||||||
|
* Licensed GPLv2+
|
||||||
|
*/
|
||||||
|
|
||||||
|
.ct-newsletter-subscribe-form{display:grid;gap:var(--theme-form-field-gap, 10px);--theme-link-initial-color: var(--text-color, var(--theme-text-color))}@media(min-width: 690px){.ct-newsletter-subscribe-form[data-columns="2"]{grid-template-columns:1fr auto}}@media(min-width: 690px){.ct-newsletter-subscribe-form[data-columns="3"]{grid-template-columns:1fr 1fr auto}}.ct-newsletter-subscribe-form .wp-element-button{width:100%;--theme-button-min-height: var(--theme-form-field-height, 40px);--theme-button-border-radius: var(--theme-form-field-border-radius, 3px)}.ct-newsletter-subscribe-form .gdpr-confirm-policy,.ct-newsletter-subscribe-form .ct-newsletter-subscribe-message{grid-column:1/-1;margin:0}.ct-newsletter-subscribe-form .ct-newsletter-subscribe-message{display:none}.ct-newsletter-subscribe-form .ct-newsletter-subscribe-message a{text-decoration:underline}.ct-newsletter-subscribe-form.subscribe-error .ct-newsletter-subscribe-message,.ct-newsletter-subscribe-form.subscribe-success .ct-newsletter-subscribe-message{display:block}.ct-newsletter-subscribe-form.subscribe-error .ct-newsletter-subscribe-message{color:#e42b2b;font-size:14px}.ct-newsletter-subscribe-form.subscribe-success *:not(.ct-newsletter-subscribe-message){display:none}.ct-newsletter-subscribe-container{margin-top:60px;padding:var(--padding, 30px);color:var(--text-color, var(--theme-text-color));border-radius:var(--theme-border-radius, 0px);border:var(--newsletter-container-border, none);box-shadow:var(--theme-box-shadow, 0px 12px 18px -6px rgba(34, 56, 101, 0.04))}.ct-newsletter-subscribe-container h3{font-size:20px}.ct-newsletter-subscribe-container>*{text-align:center;margin-inline:auto}@media(min-width: 690px){.ct-newsletter-subscribe-container>*{width:80%}}.ct-newsletter-subscribe-container>*:first-child{margin-top:20px}.ct-newsletter-subscribe-container>*:last-child{margin-bottom:20px}
|
||||||
@ -0,0 +1,101 @@
|
|||||||
|
import { registerDynamicChunk } from 'blocksy-frontend'
|
||||||
|
|
||||||
|
const submitMailchimp = (form) => {
|
||||||
|
if (!form.querySelector('[type="email"]').value.trim()) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check for spam
|
||||||
|
if (
|
||||||
|
document.getElementById('js-validate-robot') &&
|
||||||
|
document.getElementById('js-validate-robot').value !== ''
|
||||||
|
) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get url for mailchimp
|
||||||
|
var url = form.action.replace('subscribe', 'subscribe/post-json')
|
||||||
|
|
||||||
|
// Add form data to object
|
||||||
|
var data = ''
|
||||||
|
|
||||||
|
var callback = 'mailchimpCallback'
|
||||||
|
|
||||||
|
var inputs = form.querySelectorAll('input')
|
||||||
|
|
||||||
|
for (var i = 0; i < inputs.length; i++) {
|
||||||
|
data += '&' + inputs[i].name + '=' + encodeURIComponent(inputs[i].value)
|
||||||
|
}
|
||||||
|
|
||||||
|
data += `&c=${callback}`
|
||||||
|
|
||||||
|
// Create & add post script to the DOM
|
||||||
|
var script = document.createElement('script')
|
||||||
|
script.src = url + data
|
||||||
|
|
||||||
|
document.body.appendChild(script)
|
||||||
|
|
||||||
|
form.classList.remove('subscribe-error', 'subscribe-success')
|
||||||
|
form.classList.add('subscribe-loading')
|
||||||
|
|
||||||
|
// Callback function
|
||||||
|
window[callback] = function (data) {
|
||||||
|
// Remove post script from the DOM
|
||||||
|
delete window[callback]
|
||||||
|
document.body.removeChild(script)
|
||||||
|
|
||||||
|
form.classList.remove('subscribe-loading')
|
||||||
|
|
||||||
|
if (!data) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
form.classList.add(
|
||||||
|
data.result === 'error' ? 'subscribe-error' : 'subscribe-success'
|
||||||
|
)
|
||||||
|
|
||||||
|
form.querySelector('.ct-newsletter-subscribe-message').innerHTML =
|
||||||
|
data.msg.replace('0 - ', '')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const submitAjax = (form) => {
|
||||||
|
const body = new FormData(form)
|
||||||
|
|
||||||
|
body.append('action', 'blc_newsletter_subscribe_process_ajax_subscribe')
|
||||||
|
|
||||||
|
body.append('GROUP', form.dataset.provider.split(':')[1])
|
||||||
|
|
||||||
|
form.classList.remove('subscribe-error', 'subscribe-success')
|
||||||
|
form.classList.add('subscribe-loading')
|
||||||
|
|
||||||
|
fetch(ct_localizations.ajax_url, {
|
||||||
|
method: 'POST',
|
||||||
|
body,
|
||||||
|
})
|
||||||
|
.then((r) => r.json())
|
||||||
|
.then(({ success, data }) => {
|
||||||
|
form.classList.remove('subscribe-loading')
|
||||||
|
|
||||||
|
form.classList.add(
|
||||||
|
data.result === 'no' ? 'subscribe-error' : 'subscribe-success'
|
||||||
|
)
|
||||||
|
|
||||||
|
form.querySelector('.ct-newsletter-subscribe-message').innerHTML =
|
||||||
|
data.message
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
registerDynamicChunk('blocksy_ext_newsletter_subscribe', {
|
||||||
|
mount: (el, { event }) => {
|
||||||
|
const form = event.target
|
||||||
|
|
||||||
|
if (form.dataset.provider === 'mailchimp') {
|
||||||
|
submitMailchimp(form)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (form.dataset.provider.indexOf('mailchimp') === -1) {
|
||||||
|
submitAjax(form)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
})
|
||||||
@ -0,0 +1,63 @@
|
|||||||
|
.ct-newsletter-subscribe-form {
|
||||||
|
display: grid;
|
||||||
|
gap: var(--theme-form-field-gap, 10px);
|
||||||
|
|
||||||
|
--theme-link-initial-color: var(--text-color, var(--theme-text-color));
|
||||||
|
|
||||||
|
&[data-columns="2"] {
|
||||||
|
@include media-breakpoint-up(md) {
|
||||||
|
grid-template-columns: 1fr auto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&[data-columns="3"] {
|
||||||
|
@include media-breakpoint-up(md) {
|
||||||
|
grid-template-columns: 1fr 1fr auto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.wp-element-button {
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
|
--theme-button-min-height: var(--theme-form-field-height, 40px);
|
||||||
|
--theme-button-border-radius: var(--theme-form-field-border-radius, 3px);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.gdpr-confirm-policy,
|
||||||
|
.ct-newsletter-subscribe-message {
|
||||||
|
grid-column: 1/-1;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-newsletter-subscribe-message {
|
||||||
|
display: none;
|
||||||
|
|
||||||
|
a {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.subscribe-error,
|
||||||
|
&.subscribe-success {
|
||||||
|
|
||||||
|
.ct-newsletter-subscribe-message {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.subscribe-error {
|
||||||
|
|
||||||
|
.ct-newsletter-subscribe-message {
|
||||||
|
color: #e42b2b;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.subscribe-success {
|
||||||
|
|
||||||
|
*:not(.ct-newsletter-subscribe-message) {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,5 @@
|
|||||||
|
@import '../../../../../static/sass/frontend/common-frontend/functions';
|
||||||
|
@import '../../../../../static/sass/frontend/common-frontend/mixins';
|
||||||
|
|
||||||
|
@import 'common';
|
||||||
|
@import 'single-block';
|
||||||
@ -0,0 +1,29 @@
|
|||||||
|
.ct-newsletter-subscribe-container {
|
||||||
|
margin-top: 60px;
|
||||||
|
padding: var(--padding, 30px);
|
||||||
|
color: var(--text-color, var(--theme-text-color));
|
||||||
|
border-radius: var(--theme-border-radius, 0px);
|
||||||
|
border: var(--newsletter-container-border, none);
|
||||||
|
box-shadow: var(--theme-box-shadow, 0px 12px 18px -6px rgba(34, 56, 101, 0.04));
|
||||||
|
|
||||||
|
h3 {
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
> * {
|
||||||
|
text-align: center;
|
||||||
|
margin-inline: auto;
|
||||||
|
|
||||||
|
@include media-breakpoint-up(md) {
|
||||||
|
width: 80%;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:first-child {
|
||||||
|
margin-top: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:last-child {
|
||||||
|
margin-bottom: 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$config = [
|
||||||
|
// translators: This is a brand name. Preferably to not be translated
|
||||||
|
'name' => _x('Product Reviews', 'Extension Brand Name', 'blocksy-companion'),
|
||||||
|
'description' => __('This extension lets you easily create an affiliate marketing type of website by giving you options to create a personalized product review and use your affiliate links to direct your readers to the purchase page.', 'blocksy-companion'),
|
||||||
|
|
||||||
|
'documentation' => 'https://creativethemes.com/blocksy/docs/extensions/product-reviews/',
|
||||||
|
'video' => 'https://youtu.be/Zv31rmKgaZw',
|
||||||
|
'customize' => admin_url('customize.php?ct_autofocus=post_type_archive_blc-product-review'),
|
||||||
|
'icon' => '<svg width="16" height="16" viewBox="0 0 16 16"><path d="m8.7.5 1.8 4c.1.2.3.4.6.5l4.1.6c.7 0 1 .8.5 1.3l-3 3.1c-.2.2-.2.5-.2.7l.7 4.3c.1.6-.6 1.2-1.1.9l-3.7-2.1c-.2-.2-.5-.2-.7 0L4 15.9c-.6.3-1.3-.2-1.1-.9l.7-4.3c.1-.2-.1-.6-.2-.7l-3-3.1c-.6-.5-.4-1.3.3-1.4l4.1-.6c.2 0 .5-.2.6-.5l1.8-4c.4-.5 1.2-.5 1.5.1z"/></svg>',
|
||||||
|
];
|
||||||
|
|
||||||
@ -0,0 +1,21 @@
|
|||||||
|
.ct-product-reviews-options {
|
||||||
|
padding-top: 40px;
|
||||||
|
border-top: 1px dashed #eee;
|
||||||
|
|
||||||
|
form {
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: 1fr 1fr 150px;
|
||||||
|
gap: 10px;
|
||||||
|
align-items: end;
|
||||||
|
margin-top: 25px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-control {
|
||||||
|
--options-vertical-spacing: 0;
|
||||||
|
--options-horizontal-spacing: 0;
|
||||||
|
|
||||||
|
.ct-option-input {
|
||||||
|
--input-height: 35px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,715 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/helpers.php';
|
||||||
|
|
||||||
|
class BlocksyExtensionProductReviews {
|
||||||
|
public function __construct() {
|
||||||
|
add_action(
|
||||||
|
'blocksy:hero:title:before',
|
||||||
|
function () {
|
||||||
|
if (! is_singular('blc-product-review')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$atts = apply_filters(
|
||||||
|
'blocksy:ext:product-reviews:frontend:atts',
|
||||||
|
blocksy_get_post_options(null, [
|
||||||
|
'meta_id' => 'blocksy_product_review_options'
|
||||||
|
]),
|
||||||
|
get_the_ID()
|
||||||
|
);
|
||||||
|
|
||||||
|
$product_review_entity = blocksy_akg(
|
||||||
|
'product_review_entity',
|
||||||
|
$atts,
|
||||||
|
'Thing'
|
||||||
|
);
|
||||||
|
|
||||||
|
$maybe_schema = blocksy_schema_org_definitions('itemReviewed', [
|
||||||
|
'to_merge' => [
|
||||||
|
'itemtype' => "https://schema.org/" . $product_review_entity
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
|
||||||
|
if (! $maybe_schema) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '<div ' . $maybe_schema . '>';
|
||||||
|
echo '<meta itemprop="name" content="' . get_the_title() . '">';
|
||||||
|
if (get_the_post_thumbnail_url()) {
|
||||||
|
echo '<meta itemprop="image" content="' . get_the_post_thumbnail_url() . '">';
|
||||||
|
}
|
||||||
|
|
||||||
|
$product_description = blocksy_akg('product_description', $atts, '');
|
||||||
|
|
||||||
|
if (! empty($product_description)) {
|
||||||
|
echo blocksy_html_tag('meta', [
|
||||||
|
'itemprop' => 'description',
|
||||||
|
'content' => strip_tags($product_description)
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($product_review_entity === 'Product') {
|
||||||
|
$product_entity_sku = blocksy_akg('product_entity_sku', $atts, '');
|
||||||
|
$product_entity_brand = blocksy_akg('product_entity_brand', $atts, '');
|
||||||
|
$product_entity_price = blocksy_akg('product_entity_price', $atts, '');
|
||||||
|
|
||||||
|
if (! empty($product_entity_sku)) {
|
||||||
|
echo blocksy_html_tag('meta', [
|
||||||
|
'itemprop' => 'sku',
|
||||||
|
'content' => $product_entity_sku
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! empty($product_entity_brand)) {
|
||||||
|
echo blocksy_html_tag(
|
||||||
|
'div',
|
||||||
|
[
|
||||||
|
'itemprop' => 'brand',
|
||||||
|
'itemscope' => '',
|
||||||
|
'itemtype' => 'https://schema.org/Brand'
|
||||||
|
],
|
||||||
|
blocksy_html_tag(
|
||||||
|
'meta',
|
||||||
|
[
|
||||||
|
'itemprop' => 'name',
|
||||||
|
'content' => $product_entity_brand
|
||||||
|
]
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$product_link = blocksy_akg('product_link', $atts, '#');
|
||||||
|
|
||||||
|
$offers_contents = '';
|
||||||
|
|
||||||
|
if (! empty($product_link)) {
|
||||||
|
$offers_contents .= blocksy_html_tag('link', [
|
||||||
|
'itemprop' => 'url',
|
||||||
|
'href' => $product_link
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
$offers_contents .= blocksy_html_tag('meta', [
|
||||||
|
'itemprop' => 'availability',
|
||||||
|
'content' => 'https://schema.org/InStock'
|
||||||
|
]);
|
||||||
|
|
||||||
|
if (! empty($product_entity_price)) {
|
||||||
|
$parsed_price = preg_replace(
|
||||||
|
"/[^0-9.,]/",
|
||||||
|
"",
|
||||||
|
$product_entity_price
|
||||||
|
);
|
||||||
|
|
||||||
|
$parsed_currency = preg_replace(
|
||||||
|
"/[0-9.,]/",
|
||||||
|
"",
|
||||||
|
$product_entity_price
|
||||||
|
);
|
||||||
|
|
||||||
|
$offers_contents .= blocksy_html_tag('meta', [
|
||||||
|
'itemprop' => 'price',
|
||||||
|
'content' => $parsed_price
|
||||||
|
]);
|
||||||
|
|
||||||
|
$currencies = [
|
||||||
|
'$' => 'USD',
|
||||||
|
'€' => 'EUR',
|
||||||
|
'₡' => 'CRC',
|
||||||
|
'£' => 'GBP',
|
||||||
|
'₪' => 'ILS',
|
||||||
|
'₹' => 'INR',
|
||||||
|
'¥' => 'JPY',
|
||||||
|
'₩' => 'KRW',
|
||||||
|
'₦' => 'NGN',
|
||||||
|
'₱' => 'PHP',
|
||||||
|
'zł' => 'PLN',
|
||||||
|
'₲' => 'PYG',
|
||||||
|
'฿' => 'THB',
|
||||||
|
'₴' => 'UAH',
|
||||||
|
'₫' => 'VND'
|
||||||
|
];
|
||||||
|
|
||||||
|
if ($parsed_currency && isset($currencies[$parsed_currency])) {
|
||||||
|
$parsed_currency = $currencies[$parsed_currency];
|
||||||
|
}
|
||||||
|
|
||||||
|
$offers_contents .= blocksy_html_tag('meta', [
|
||||||
|
'itemprop' => 'priceCurrency',
|
||||||
|
'content' => $parsed_currency
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
echo blocksy_html_tag(
|
||||||
|
'div',
|
||||||
|
[
|
||||||
|
'itemprop' => 'offers',
|
||||||
|
'itemscope' => '',
|
||||||
|
'itemtype' => 'https://schema.org/Offer'
|
||||||
|
],
|
||||||
|
$offers_contents
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'blocksy:hero:title:after',
|
||||||
|
function () {
|
||||||
|
if (! is_singular('blc-product-review')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$maybe_schema = blocksy_schema_org_definitions('itemReviewed');
|
||||||
|
|
||||||
|
if (! $maybe_schema) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '</div>';
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy:options:cpt:page-title-args',
|
||||||
|
function ($args, $cpt) {
|
||||||
|
if ($cpt === 'blc-product-review') {
|
||||||
|
$args['has_hero_type'] = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $args;
|
||||||
|
},
|
||||||
|
10, 2
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'customize_preview_init',
|
||||||
|
function () {
|
||||||
|
if (! function_exists('get_plugin_data')){
|
||||||
|
require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy-product-reviews-customizer-sync',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/product-reviews/static/bundle/sync.js',
|
||||||
|
[ 'ct-scripts', 'customize-preview', 'blocksy-companion-sync-scripts' ],
|
||||||
|
$data['Version'],
|
||||||
|
true
|
||||||
|
);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
add_action('init', [$this, 'declare_cpt']);
|
||||||
|
|
||||||
|
add_action('load-post.php', [$this, 'init_metabox']);
|
||||||
|
add_action('load-post-new.php', [$this, 'init_metabox']);
|
||||||
|
|
||||||
|
add_filter('blocksy:single:has-default-hero', function ($def) {
|
||||||
|
if (! is_singular('blc-product-review')) {
|
||||||
|
return $def;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy:hero:type-1:default-alignment',
|
||||||
|
function ($default, $prefix) {
|
||||||
|
if ($prefix === 'blc-product-review_single') {
|
||||||
|
return 'center';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $default;
|
||||||
|
},
|
||||||
|
10, 2
|
||||||
|
);
|
||||||
|
|
||||||
|
add_filter('blocksy:archive:render-card-layers', function ($layers, $prefix) {
|
||||||
|
if ($prefix !== 'blc-product-review_archive') {
|
||||||
|
return $layers;
|
||||||
|
}
|
||||||
|
|
||||||
|
$layers['overall_score'] = blocksy_get_product_review_overall_score();
|
||||||
|
|
||||||
|
return $layers;
|
||||||
|
}, 10, 2);
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy:options:posts-listing:design:before_card_background',
|
||||||
|
function ($opts, $prefix) {
|
||||||
|
if ($prefix !== 'blc-product-review_archive') {
|
||||||
|
return $opts;
|
||||||
|
}
|
||||||
|
|
||||||
|
$opts[blocksy_rand_md5()] = [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => [
|
||||||
|
$prefix . '_archive_order:array-ids:overall_score:enabled' => '!no'
|
||||||
|
],
|
||||||
|
'options' => [
|
||||||
|
$prefix . '_star_rating_color' => [
|
||||||
|
'label' => __( 'Star Rating Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'divider' => 'top:full',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'inactive' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Active', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => '#FDA256'
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Inactive', 'blocksy-companion' ),
|
||||||
|
'id' => 'inactive',
|
||||||
|
'inherit' => '#F9DFCC'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]
|
||||||
|
]
|
||||||
|
];
|
||||||
|
|
||||||
|
return $opts;
|
||||||
|
},
|
||||||
|
10, 2
|
||||||
|
);
|
||||||
|
|
||||||
|
add_filter('blocksy:posts-listing:archive-order:default', function ($default, $prefix) {
|
||||||
|
if ($prefix !== 'blc-product-review_archive') {
|
||||||
|
return $default;
|
||||||
|
}
|
||||||
|
|
||||||
|
$default[] = [
|
||||||
|
'id' => 'overall_score',
|
||||||
|
'enabled' => true
|
||||||
|
];
|
||||||
|
|
||||||
|
return $default;
|
||||||
|
}, 10, 2);
|
||||||
|
|
||||||
|
add_filter('blocksy:options:posts-listing-archive-order', function ($option, $prefix) {
|
||||||
|
if ($prefix !== 'blc-product-review_archive') {
|
||||||
|
return $option;
|
||||||
|
}
|
||||||
|
|
||||||
|
$option['value'][] = [
|
||||||
|
'id' => 'overall_score',
|
||||||
|
'enabled' => true
|
||||||
|
];
|
||||||
|
|
||||||
|
$option['settings']['overall_score'] = [
|
||||||
|
'label' => __('Overall Score', 'blocksy-companion'),
|
||||||
|
/*
|
||||||
|
'options' => [
|
||||||
|
'excerpt_length' => [
|
||||||
|
'label' => __('Length', 'blocksy-companion'),
|
||||||
|
'type' => 'ct-number',
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => 40,
|
||||||
|
'min' => 10,
|
||||||
|
'max' => 100,
|
||||||
|
],
|
||||||
|
],
|
||||||
|
*/
|
||||||
|
];
|
||||||
|
|
||||||
|
return $option;
|
||||||
|
}, 10, 2);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'blocksy:template:before',
|
||||||
|
function () {
|
||||||
|
if (! is_singular('blc-product-review')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
echo blocksy_render_view(
|
||||||
|
dirname(__FILE__) . '/views/single-top.php',
|
||||||
|
[]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action('wp_enqueue_scripts', function () {
|
||||||
|
if (! function_exists('get_plugin_data')) {
|
||||||
|
require_once(ABSPATH . 'wp-admin/includes/plugin.php');
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
if (is_admin()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
wp_enqueue_style(
|
||||||
|
'blocksy-ext-product-reviews-styles',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/product-reviews/static/bundle/main.min.css',
|
||||||
|
['ct-main-styles'],
|
||||||
|
$data['Version']
|
||||||
|
);
|
||||||
|
}, 50);
|
||||||
|
|
||||||
|
add_filter('blocksy_single_posts_post_elements_start', function ($options, $prefix) {
|
||||||
|
if ($prefix !== 'blc-product-review_single') {
|
||||||
|
return $options;
|
||||||
|
}
|
||||||
|
|
||||||
|
$options[$prefix . '_reviews_summary'] = [
|
||||||
|
'label' => __( 'Review Summary', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-panel',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'inner-options' => [
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'General', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
$prefix . '_product_scores_width' => [
|
||||||
|
'label' => __( 'Scores Box Width', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-slider',
|
||||||
|
'min' => 0,
|
||||||
|
'max' => 1200,
|
||||||
|
'value' => 800,
|
||||||
|
// 'responsive' => true,
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
$prefix . '_has_read_more' => [
|
||||||
|
'label' => __('Read More Button', 'blocksy-companion'),
|
||||||
|
'type' => 'ct-switch',
|
||||||
|
'value' => 'yes',
|
||||||
|
'divider' => 'top',
|
||||||
|
'sync' => blocksy_sync_single_post_container([
|
||||||
|
'prefix' => $prefix,
|
||||||
|
'loader_selector' => '.ct-product-actions-group'
|
||||||
|
])
|
||||||
|
],
|
||||||
|
|
||||||
|
$prefix . '_has_buy_now' => [
|
||||||
|
'label' => __('Buy Now Button', 'blocksy-companion'),
|
||||||
|
'type' => 'ct-switch',
|
||||||
|
'value' => 'yes',
|
||||||
|
'divider' => 'top',
|
||||||
|
'sync' => blocksy_sync_single_post_container([
|
||||||
|
'prefix' => $prefix,
|
||||||
|
'loader_selector' => '.ct-product-actions-group'
|
||||||
|
])
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'Design', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
$prefix . '_star_rating_color' => [
|
||||||
|
'label' => __( 'Star Rating Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'inactive' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Active', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => '#FDA256'
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Inactive', 'blocksy-companion' ),
|
||||||
|
'id' => 'inactive',
|
||||||
|
'inherit' => '#F9DFCC'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
$prefix . '_overall_score_text' => [
|
||||||
|
'label' => __( 'Overll Score Text', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'divider' => 'top',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Active', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-palette-color-8)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
$prefix . '_overall_score_backgroud' => [
|
||||||
|
'label' => __( 'Overll Score Background', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Active', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-palette-color-4)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
]
|
||||||
|
];
|
||||||
|
|
||||||
|
return $options;
|
||||||
|
}, 10, 2);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'blocksy:global-dynamic-css:enqueue',
|
||||||
|
'BlocksyExtensionProductReviews::add_global_styles',
|
||||||
|
10, 3
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
static public function add_global_styles($args) {
|
||||||
|
blocksy_theme_get_dynamic_styles(array_merge([
|
||||||
|
'path' => dirname(__FILE__) . '/global.php',
|
||||||
|
'chunk' => 'global',
|
||||||
|
], $args));
|
||||||
|
}
|
||||||
|
|
||||||
|
static public function onDeactivation() {
|
||||||
|
remove_action(
|
||||||
|
'blocksy:global-dynamic-css:enqueue',
|
||||||
|
'BlocksyExtensionProductReviews::add_global_styles',
|
||||||
|
10, 3
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function init_metabox() {
|
||||||
|
add_action('add_meta_boxes', [$this, 'setup_meta_box']);
|
||||||
|
add_action('save_post', [$this, 'save_meta_box']);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function declare_cpt() {
|
||||||
|
$settings = $this->get_settings();
|
||||||
|
|
||||||
|
register_post_type('blc-product-review', [
|
||||||
|
'label' => __('Product Reviews', 'blocksy-companion'),
|
||||||
|
'description' => __( 'Product Reviews', 'blocksy-companion'),
|
||||||
|
'menu_icon' => 'dashicons-star-filled',
|
||||||
|
'labels' => [
|
||||||
|
'name' => __('Product Reviews', 'blocksy-companion'),
|
||||||
|
'singular_name' => __('Product Review', 'blocksy-companion'),
|
||||||
|
'menu_name' => __('Product Reviews', 'blocksy-companion'),
|
||||||
|
'parent_item_colon' => __('Parent Product Review', 'blocksy-companion'),
|
||||||
|
'all_items' => __('All Reviews', 'blocksy-companion'),
|
||||||
|
'view_item' => __('View Product Review', 'blocksy-companion'),
|
||||||
|
'add_new_item' => __('Add New Product Review', 'blocksy-companion'),
|
||||||
|
'add_new' => __('Add New Review', 'blocksy-companion'),
|
||||||
|
'edit_item' => __('Edit Product Review', 'blocksy-companion'),
|
||||||
|
'update_item' => __('Update Product Review', 'blocksy-companion'),
|
||||||
|
'search_items' => __('Search Product Review', 'blocksy-companion'),
|
||||||
|
'not_found' => __('Not Found', 'blocksy-companion'),
|
||||||
|
'not_found_in_trash' => __('Not found in Trash', 'blocksy-companion')
|
||||||
|
],
|
||||||
|
'supports' => [
|
||||||
|
'comments',
|
||||||
|
'title', 'editor', 'excerpt',
|
||||||
|
'author', 'thumbnail', 'revisions',
|
||||||
|
'custom-fields'
|
||||||
|
],
|
||||||
|
'show_in_rest' => true,
|
||||||
|
'public' => true,
|
||||||
|
'hierarchical' => false,
|
||||||
|
'show_ui' => true,
|
||||||
|
'show_in_menu' => true,
|
||||||
|
'show_in_nav_menus' => true,
|
||||||
|
'show_in_admin_bar' => true,
|
||||||
|
'has_archive' => true,
|
||||||
|
'can_export' => true,
|
||||||
|
'exclude_from_search' => false,
|
||||||
|
// 'taxonomies' => array('post_tag'),
|
||||||
|
'publicly_queryable' => true,
|
||||||
|
'capability_type' => 'page',
|
||||||
|
'rewrite' => [
|
||||||
|
'slug' => $settings['single_slug']
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
register_taxonomy(
|
||||||
|
'blc-product-review-categories',
|
||||||
|
[
|
||||||
|
'blc-product-review'
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'hierarchical' => true,
|
||||||
|
'labels' => [
|
||||||
|
'name' => __('Categories', 'blocksy-companion'),
|
||||||
|
'singular_name' => __('Category', 'blocksy-companion'),
|
||||||
|
'search_items' => __('Search Category', 'blocksy-companion'),
|
||||||
|
'all_items' => __('All Categories', 'blocksy-companion'),
|
||||||
|
'parent_item' => __('Parent Category', 'blocksy-companion'),
|
||||||
|
'parent_item_colon' => __('Parent Category:', 'blocksy-companion'),
|
||||||
|
'edit_item' => __('Edit Category', 'blocksy-companion'),
|
||||||
|
'update_item' => __('Update Category', 'blocksy-companion'),
|
||||||
|
'add_new_item' => __('Add New Category', 'blocksy-companion'),
|
||||||
|
'new_item_name' => __('New Category Name', 'blocksy-companion'),
|
||||||
|
'menu_name' => __('Categories', 'blocksy-companion'),
|
||||||
|
],
|
||||||
|
'show_ui' => true,
|
||||||
|
'show_admin_column' => true,
|
||||||
|
'query_var' => true,
|
||||||
|
'show_in_rest' => true,
|
||||||
|
'rewrite' => [
|
||||||
|
'slug' => $settings['category_slug']
|
||||||
|
],
|
||||||
|
]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setup_meta_box() {
|
||||||
|
add_meta_box(
|
||||||
|
'blocksy_settings_meta_box',
|
||||||
|
blc_safe_sprintf(
|
||||||
|
// Translators: %s is the theme name.
|
||||||
|
__( '%s Settings', 'blocksy-companion' ),
|
||||||
|
__( 'Blocksy', 'blocksy-companion' )
|
||||||
|
),
|
||||||
|
function ($post) {
|
||||||
|
$values = get_post_meta($post->ID, 'blocksy_product_review_options');
|
||||||
|
|
||||||
|
if (empty($values)) {
|
||||||
|
$values = [[]];
|
||||||
|
}
|
||||||
|
|
||||||
|
$options = blocksy_get_options(
|
||||||
|
dirname(__FILE__) . '/metabox.php',
|
||||||
|
[],
|
||||||
|
false
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Note to code reviewers: This line doesn't need to be escaped.
|
||||||
|
* Function blocksy_output_options_panel() used here escapes the value properly.
|
||||||
|
*/
|
||||||
|
echo blocksy_output_options_panel(
|
||||||
|
[
|
||||||
|
'options' => $options,
|
||||||
|
'values' => $values[0],
|
||||||
|
'id_prefix' => 'ct-post-meta-options',
|
||||||
|
'name_prefix' => 'blocksy_product_review_options',
|
||||||
|
'attr' => [
|
||||||
|
'class' => 'ct-meta-box',
|
||||||
|
'data-disable-reverse-button' => 'yes'
|
||||||
|
]
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
wp_nonce_field(basename(__FILE__), 'blocksy_settings_meta_box');
|
||||||
|
},
|
||||||
|
'blc-product-review', 'normal', 'default'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function save_meta_box($post_id) {
|
||||||
|
$is_autosave = wp_is_post_autosave($post_id);
|
||||||
|
$is_revision = wp_is_post_revision($post_id);
|
||||||
|
$is_valid_nonce = !! (
|
||||||
|
isset($_POST['blocksy_settings_meta_box']) && wp_verify_nonce(
|
||||||
|
sanitize_text_field(wp_unslash($_POST['blocksy_settings_meta_box'])),
|
||||||
|
basename(__FILE__)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
if ($is_autosave || $is_revision || !$is_valid_nonce) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$values = [];
|
||||||
|
|
||||||
|
if (isset($_POST['blocksy_product_review_options'][blocksy_post_name()])) {
|
||||||
|
$values = json_decode(
|
||||||
|
wp_unslash($_POST['blocksy_product_review_options'][blocksy_post_name()]),
|
||||||
|
true
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
update_post_meta(
|
||||||
|
$post_id,
|
||||||
|
'blocksy_product_review_options',
|
||||||
|
$values
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get_settings() {
|
||||||
|
if (wp_doing_ajax()) {
|
||||||
|
$maybe_input = json_decode(file_get_contents('php://input'), true);
|
||||||
|
|
||||||
|
if (
|
||||||
|
$maybe_input
|
||||||
|
&&
|
||||||
|
isset($maybe_input['extension'])
|
||||||
|
&&
|
||||||
|
$maybe_input['extension'] === 'product-reviews'
|
||||||
|
&&
|
||||||
|
isset($maybe_input['extAction'])
|
||||||
|
&&
|
||||||
|
$maybe_input['extAction']['type'] === 'persist'
|
||||||
|
) {
|
||||||
|
return $maybe_input['extAction']['settings'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return get_option('blocksy_ext_product_reviews_settings', [
|
||||||
|
'single_slug' => 'product-review',
|
||||||
|
'category_slug' => 'product-review-category',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function set_settings($value) {
|
||||||
|
update_option('blocksy_ext_product_reviews_settings', $value);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@ -0,0 +1,126 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$prefix = 'blc-product-review_single';
|
||||||
|
|
||||||
|
|
||||||
|
$product_scores_width = blocksy_get_theme_mod($prefix . '_product_scores_width', 800);
|
||||||
|
|
||||||
|
if ($product_scores_width !== 800) {
|
||||||
|
$css->put(
|
||||||
|
blocksy_prefix_selector('.ct-product-scores', $prefix),
|
||||||
|
'--product-scores-width: ' . $product_scores_width . 'px'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod(
|
||||||
|
$prefix . '_star_rating_color',
|
||||||
|
[]
|
||||||
|
),
|
||||||
|
'default' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT')
|
||||||
|
],
|
||||||
|
'inactive' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT')
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => blocksy_prefix_selector(
|
||||||
|
'.ct-product-scores',
|
||||||
|
$prefix
|
||||||
|
),
|
||||||
|
'variable' => 'star-rating-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'inactive' => [
|
||||||
|
'selector' => blocksy_prefix_selector(
|
||||||
|
'.ct-product-scores',
|
||||||
|
$prefix
|
||||||
|
),
|
||||||
|
'variable' => 'star-rating-inactive-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod(
|
||||||
|
$prefix . '_overall_score_text',
|
||||||
|
[]
|
||||||
|
),
|
||||||
|
'default' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT')
|
||||||
|
]
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => blocksy_prefix_selector(
|
||||||
|
'.ct-product-scores',
|
||||||
|
$prefix
|
||||||
|
),
|
||||||
|
'variable' => 'overall-score-text-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod(
|
||||||
|
$prefix . '_overall_score_backgroud',
|
||||||
|
[]
|
||||||
|
),
|
||||||
|
'default' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT')
|
||||||
|
]
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => blocksy_prefix_selector(
|
||||||
|
'.ct-product-scores',
|
||||||
|
$prefix
|
||||||
|
),
|
||||||
|
'variable' => 'overall-score-box-background'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
|
||||||
|
$prefix = 'blc-product-review_archive';
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod(
|
||||||
|
$prefix . '_star_rating_color',
|
||||||
|
[]
|
||||||
|
),
|
||||||
|
'default' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT')
|
||||||
|
],
|
||||||
|
'inactive' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT')
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => blocksy_prefix_selector(
|
||||||
|
'.star-rating',
|
||||||
|
$prefix
|
||||||
|
),
|
||||||
|
'variable' => 'star-rating-initial-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'inactive' => [
|
||||||
|
'selector' => blocksy_prefix_selector(
|
||||||
|
'.star-rating',
|
||||||
|
$prefix
|
||||||
|
),
|
||||||
|
'variable' => 'star-rating-inactive-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]);
|
||||||
@ -0,0 +1,43 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
function blocksy_get_product_review_overall_score($post_id = null) {
|
||||||
|
if (! $post_id) {
|
||||||
|
global $post;
|
||||||
|
$post_id = $post->ID;
|
||||||
|
}
|
||||||
|
|
||||||
|
$atts = blocksy_get_post_options($post_id, [
|
||||||
|
'meta_id' => 'blocksy_product_review_options'
|
||||||
|
]);
|
||||||
|
|
||||||
|
$scores = blocksy_akg('scores', $atts, []);
|
||||||
|
|
||||||
|
if (empty($scores)) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$output = '<div class="ct-overall-score-layer">';
|
||||||
|
|
||||||
|
$avg_score = apply_filters(
|
||||||
|
'blocksy:ext:product-reviews:overall-score',
|
||||||
|
round(array_reduce($scores, function ($carry, $score) {
|
||||||
|
return $carry + floatval($score['score']);
|
||||||
|
}, 0) / count($scores) * 10) / 10,
|
||||||
|
$scores
|
||||||
|
);
|
||||||
|
|
||||||
|
$output .= '<span class="ct-score-label">';
|
||||||
|
$output .= __('Rating', 'blocksy-companion');
|
||||||
|
$output .= ':</span>';
|
||||||
|
|
||||||
|
$output .= '<span class="ct-average-score">' . $avg_score . '/5</span>';
|
||||||
|
|
||||||
|
$output .= '<div class="star-rating" role="img">';
|
||||||
|
$width = (($avg_score / 5) * 100);
|
||||||
|
$output .= '<span style="width: ' . $width . '%;"></span>';
|
||||||
|
$output .= '</div>';
|
||||||
|
|
||||||
|
$output .= '</div>';
|
||||||
|
|
||||||
|
return $output;
|
||||||
|
}
|
||||||
@ -0,0 +1,295 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$options = [
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'General', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
'product_review_entity' => [
|
||||||
|
'label' => __( 'Review Entity', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-select',
|
||||||
|
'value' => 'Thing',
|
||||||
|
'view' => 'text',
|
||||||
|
'design' => 'inline',
|
||||||
|
'choices' => blocksy_ordered_keys(
|
||||||
|
[
|
||||||
|
'Thing' => __( 'Default', 'blocksy-companion' ),
|
||||||
|
'Product' => __( 'Product', 'blocksy-companion' ),
|
||||||
|
'Book' => __( 'Book', 'blocksy-companion' ),
|
||||||
|
// 'Course' => __( 'Course', 'blocksy-companion' ),
|
||||||
|
'CreativeWorkSeason' => __( 'Creative Work Season', 'blocksy-companion' ),
|
||||||
|
'CreativeWorkSeries' => __( 'Creative Work Series', 'blocksy-companion' ),
|
||||||
|
'Episode' => __( 'Episode', 'blocksy-companion' ),
|
||||||
|
// 'Event' => __( 'Event', 'blocksy-companion' ),
|
||||||
|
'Game' => __( 'Game', 'blocksy-companion' ),
|
||||||
|
// 'HowTo' => __( 'How To', 'blocksy-companion' ),
|
||||||
|
'LocalBusiness' => __( 'Local Business', 'blocksy-companion' ),
|
||||||
|
'MediaObject' => __( 'Media Object', 'blocksy-companion' ),
|
||||||
|
'Movie' => __( 'Movie', 'blocksy-companion' ),
|
||||||
|
'MusicPlaylist' => __( 'Music Playlist', 'blocksy-companion' ),
|
||||||
|
'MusicRecording' => __( 'Music Recording', 'blocksy-companion' ),
|
||||||
|
'Organization' => __( 'Organization', 'blocksy-companion' ),
|
||||||
|
// 'Recipe' => __( 'Recipe', 'blocksy-companion' ),
|
||||||
|
// 'SoftwareApplication' => __( 'Software Application', 'blocksy-companion' ),
|
||||||
|
]
|
||||||
|
),
|
||||||
|
'desc' => blc_safe_sprintf(
|
||||||
|
__(
|
||||||
|
'More info about review entity and how to choose the right one can be found %shere%s.',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
'<a href="https://developers.google.com/search/blog/2019/09/making-review-rich-results-more-helpful" target="_blank">',
|
||||||
|
'</a>'
|
||||||
|
),
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => ['product_review_entity' => 'Product'],
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-group',
|
||||||
|
'label' => ' ',
|
||||||
|
'wrapperAttr' => ['data-design' => 'inline'],
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-notification',
|
||||||
|
'text' => __( 'Please note that some of this information (price, sku, brand) won\'t be displayed on the front-end. It is solely used for Google\'s Schema.org markup.', 'blocksy-companion' ),
|
||||||
|
'attr' => ['data-type' => 'background:yellow']
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_entity_price' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __('Product Price', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => '',
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_entity_sku' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __('Product SKU', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => '',
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_entity_brand' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __('Product Brand', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => '',
|
||||||
|
],
|
||||||
|
]
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
],
|
||||||
|
|
||||||
|
'gallery' => [
|
||||||
|
'type' => 'ct-multi-image-uploader',
|
||||||
|
'label' => __('Gallery', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => []
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_button_label' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __('Affiliate Button Label', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => __('Buy Now', 'blocksy-companion')
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_link' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __('Affiliate Link', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => '#'
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_link_target' => [
|
||||||
|
'label' => __( 'Open Link In New Tab', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-switch',
|
||||||
|
'value' => 'no',
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_link_sponsored' => [
|
||||||
|
'label' => __( 'Sponsored Attribute', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-switch',
|
||||||
|
'value' => 'no',
|
||||||
|
],
|
||||||
|
|
||||||
|
/*
|
||||||
|
'product_button_icon' => [
|
||||||
|
'type' => 'icon-picker',
|
||||||
|
'label' => __('Button Icon', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => [
|
||||||
|
'icon' => 'fas fa-shopping-cart'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
*/
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_read_content_button_label' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'label' => __('Read More Button Label', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => __('Read More', 'blocksy-companion')
|
||||||
|
],
|
||||||
|
|
||||||
|
/*
|
||||||
|
'product_read_content_button_icon' => [
|
||||||
|
'type' => 'icon-picker',
|
||||||
|
'label' => __('Button Icon', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => [
|
||||||
|
'icon' => 'fas fa-arrow-down'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
*/
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_description' => [
|
||||||
|
'type' => 'wp-editor',
|
||||||
|
'label' => __('Short Description', 'blocksy-companion'),
|
||||||
|
'value' => '',
|
||||||
|
'design' => 'inline',
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'Rating', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'scores' => [
|
||||||
|
'type' => 'ct-addable-box',
|
||||||
|
'label' => __('Scores', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'preview-template' => '<%= label %> (<%= score === 1 ? "1 star" : score + " stars" %>)',
|
||||||
|
|
||||||
|
'inner-options' => [
|
||||||
|
'label' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => 'Default'
|
||||||
|
],
|
||||||
|
|
||||||
|
'score' => [
|
||||||
|
'type' => 'ct-number',
|
||||||
|
'value' => 5,
|
||||||
|
'step' => 0.1,
|
||||||
|
'min' => 1,
|
||||||
|
'max' => 5
|
||||||
|
]
|
||||||
|
],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
/*
|
||||||
|
[
|
||||||
|
'label' => 'Features',
|
||||||
|
'score' => 5
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'label' => 'Quality',
|
||||||
|
'score' => 5
|
||||||
|
]
|
||||||
|
*/
|
||||||
|
]
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_specs' => [
|
||||||
|
'type' => 'ct-addable-box',
|
||||||
|
'label' => __('Product specs', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'preview-template' => '<%= label %>',
|
||||||
|
|
||||||
|
'inner-options' => [
|
||||||
|
'label' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => 'Default'
|
||||||
|
],
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => ''
|
||||||
|
]
|
||||||
|
],
|
||||||
|
|
||||||
|
'value' => []
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_pros' => [
|
||||||
|
'type' => 'ct-addable-box',
|
||||||
|
'label' => __('Pros', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'preview-template' => '<%= label %>',
|
||||||
|
|
||||||
|
'inner-options' => [
|
||||||
|
'label' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => 'Default'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'value' => []
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
],
|
||||||
|
|
||||||
|
'product_cons' => [
|
||||||
|
'type' => 'ct-addable-box',
|
||||||
|
'label' => __('Cons', 'blocksy-companion'),
|
||||||
|
'design' => 'inline',
|
||||||
|
'preview-template' => '<%= label %>',
|
||||||
|
|
||||||
|
'inner-options' => [
|
||||||
|
'label' => [
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => 'Default'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'value' => []
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
// blocksy_rand_md5() => [
|
||||||
|
// 'title' => __( 'Design', 'blocksy-companion' ),
|
||||||
|
// 'type' => 'tab',
|
||||||
|
// 'options' => [
|
||||||
|
|
||||||
|
// ],
|
||||||
|
// ],
|
||||||
|
];
|
||||||
|
|
||||||
@ -0,0 +1,65 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class BlocksyExtensionProductReviewsPreBoot {
|
||||||
|
public function __construct() {
|
||||||
|
add_action('admin_enqueue_scripts', function () {
|
||||||
|
if (! function_exists('get_plugin_data')) {
|
||||||
|
require_once(ABSPATH . 'wp-admin/includes/plugin.php');
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
if (! function_exists('blocksy_is_dashboard_page')) return;
|
||||||
|
if (! blocksy_is_dashboard_page()) return;
|
||||||
|
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy-ext-product-reviews-admin-dashboard-scripts',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/product-reviews/static/bundle/dashboard.js',
|
||||||
|
['ct-options-scripts', 'ct-dashboard-scripts'],
|
||||||
|
$data['Version']
|
||||||
|
);
|
||||||
|
|
||||||
|
wp_enqueue_style(
|
||||||
|
'blocksy-ext-product-reviews-admin-dashboard-styles',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/product-reviews/static/bundle/main-admin.min.css',
|
||||||
|
[],
|
||||||
|
$data['Version']
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public function ext_action($payload) {
|
||||||
|
$ext = \Blocksy\Plugin::instance()->extensions->get('product-reviews');
|
||||||
|
|
||||||
|
if (
|
||||||
|
! isset($payload['type'])
|
||||||
|
||
|
||||||
|
! isset($payload['settings'])
|
||||||
|
||
|
||||||
|
$payload['type'] !== 'persist'
|
||||||
|
||
|
||||||
|
! $ext
|
||||||
|
) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$ext->set_settings($payload['settings']);
|
||||||
|
|
||||||
|
global $wp_rewrite;
|
||||||
|
$wp_rewrite->flush_rules();
|
||||||
|
|
||||||
|
return $this->ext_data([
|
||||||
|
'settings' => $payload['settings']
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function ext_data($args = []) {
|
||||||
|
return wp_parse_args($args, [
|
||||||
|
'settings' => get_option('blocksy_ext_product_reviews_settings', [
|
||||||
|
'single_slug' => 'product-review',
|
||||||
|
'category_slug' => 'product-review-category',
|
||||||
|
])
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
File diff suppressed because one or more lines are too long
@ -0,0 +1,8 @@
|
|||||||
|
/**
|
||||||
|
* - v2.0.37
|
||||||
|
*
|
||||||
|
* Copyright (c) 2024
|
||||||
|
* Licensed GPLv2+
|
||||||
|
*/
|
||||||
|
|
||||||
|
.ct-product-reviews-settings-modal .ct-controls-group{padding-top:30px;margin-top:5px;border-top:1px dashed #eee}
|
||||||
@ -0,0 +1,8 @@
|
|||||||
|
/**
|
||||||
|
* - v2.0.37
|
||||||
|
*
|
||||||
|
* Copyright (c) 2024
|
||||||
|
* Licensed GPLv2+
|
||||||
|
*/
|
||||||
|
|
||||||
|
.ct-product-hero .flexy-container{overflow:hidden}@media(max-width: 999.98px){.ct-product-hero .flexy-pills{--thumbs-spacing: 10px}}@media(min-width: 1000px){.ct-product-hero .flexy-pills{max-width:70%;margin:-8% auto 0 auto;--thumbs-spacing: 20px}}.ct-product-hero .flexy-pills ol{margin:0 calc(var(--thumbs-spacing)*-1)}.ct-product-hero .flexy-pills li{padding-top:var(--thumbs-spacing);padding-inline:var(--thumbs-spacing)}.ct-product-hero .flexy-pills li img{width:100%;border-radius:2px;border:3px solid #fff}.ct-product-hero .hero-section:not(:first-child){margin-top:var(--margin-bottom, 40px)}.ct-product-scores{display:grid;grid-column-gap:25px;grid-row-gap:25px;margin:0 auto;max-width:var(--product-scores-width, 800px)}@media(min-width: 690px){.ct-product-scores{grid-template-columns:2fr 1fr}}.ct-product-scores:not(:last-child){margin-bottom:60px}.ct-product-scores li{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;position:relative;padding:10px 20px}.ct-product-scores li:before{position:absolute;z-index:0;inset:0;content:"";border-radius:2px;opacity:.2;background:var(--theme-border-color)}.ct-product-scores li>span{font-size:15px;font-weight:500;position:relative}.ct-overall-score{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;color:var(--overall-score-text-color, var(--theme-palette-color-8));border-radius:2px;background:var(--overall-score-box-background, var(--theme-palette-color-4))}.ct-overall-score .ct-average-score{font-size:55px;font-weight:800;line-height:normal;margin-bottom:10px}.ct-overall-score .ct-score-label{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;margin:15px 0 0 0}.ct-overall-score-layer{display:flex;flex-wrap:wrap;align-items:center}.ct-overall-score-layer .ct-score-label,.ct-overall-score-layer .ct-average-score{font-size:14px;font-weight:600}.ct-overall-score-layer .ct-average-score{margin:0 5px;margin-inline-end:auto}.ct-overall-score-layer .star-rating{margin:3px 0}.ct-product-actions-group{display:flex;align-items:center;justify-content:center}.ct-product-actions-group:not(:last-child){margin-bottom:60px}.ct-product-actions-group .ct-button:not(:last-child){margin-inline-end:25px}.ct-product-actions-group .ct-icon-container{color:inherit;margin-inline-start:10px}.ct-product-description:not(:last-child){margin-bottom:60px}.ct-product-info{display:grid;grid-template-columns:var(--grid-template-columns);grid-column-gap:40px;grid-row-gap:40px;border-top:1px solid var(--theme-border-color);padding-top:var(--theme-content-vertical-spacing, 60px)}@media(min-width: 1000px){.ct-product-info{--grid-template-columns: 1.5fr 1fr 1fr}}@media(min-width: 690px)and (max-width: 999.98px){.ct-product-info{--grid-template-columns: 1fr 1fr}}.ct-product-info li{position:relative;padding-inline-start:22px}.ct-product-info .ct-icon-container{position:absolute;inset-inline-start:0;top:.4em;opacity:.8;--theme-icon-size: 13px}@media(min-width: 690px)and (max-width: 999.98px){.ct-specs{grid-column:1/-1}}.ct-specs ul{display:grid;grid-column-gap:40px}@media(min-width: 690px){.ct-specs ul{grid-template-columns:repeat(2, 1fr)}}.ct-product-hero{padding-top:var(--theme-content-vertical-spacing, 60px)}.ct-product-hero .ct-container{padding-bottom:var(--theme-content-vertical-spacing, 60px);border-bottom:1px solid var(--theme-border-color)}.ct-product-hero ul li:not(:last-child){margin-bottom:.3em}
|
||||||
@ -0,0 +1 @@
|
|||||||
|
!function(){"use strict";var r={n:function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,{a:t}),t},d:function(e,t){for(var o in t)r.o(t,o)&&!r.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:t[o]})},o:function(r,e){return Object.prototype.hasOwnProperty.call(r,e)}},e=window.blocksyCustomizerSync,t=window.ctEvents,o=r.n(t);function c(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(r);e&&(o=o.filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),t.push.apply(t,o)}return t}function n(r){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{};e%2?c(Object(t),!0).forEach((function(e){a(r,e,t[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):c(Object(t)).forEach((function(e){Object.defineProperty(r,e,Object.getOwnPropertyDescriptor(t,e))}))}return r}function a(r,e,t){return e in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}var i="blc-product-review_single";o().on("ct:customizer:sync:collect-variable-descriptors",(function(r){var t;r.result=n(n({},r.result),{},(a(t={},"".concat(i,"_product_scores_width"),{selector:(0,e.applyPrefixFor)(".ct-product-scores",i),variable:"product-scores-width",unit:"px"}),a(t,"".concat(i,"_star_rating_color"),[{selector:(0,e.applyPrefixFor)(".ct-product-scores",i),variable:"star-rating-initial-color",type:"color:default"},{selector:(0,e.applyPrefixFor)(".ct-product-scores",i),variable:"star-rating-inactive-color",type:"color:inactive"}]),a(t,"".concat(i,"_overall_score_text"),[{selector:(0,e.applyPrefixFor)(".ct-product-scores",i),variable:"overall-score-text-color",type:"color:default"}]),a(t,"".concat(i,"_overall_score_backgroud"),[{selector:(0,e.applyPrefixFor)(".ct-product-scores",i),variable:"overall-score-box-background",type:"color:default"}]),t))}));var l="blc-product-review_archive";o().on("ct:customizer:sync:collect-variable-descriptors",(function(r){r.result=n(n({},r.result),{},a({},"".concat(l,"_star_rating_color"),[{selector:(0,e.applyPrefixFor)(".star-rating",l),variable:"star-rating-initial-color",type:"color:default"},{selector:(0,e.applyPrefixFor)(".star-rating",l),variable:"star-rating-inactive-color",type:"color:inactive"}]))}))}();
|
||||||
@ -0,0 +1,101 @@
|
|||||||
|
import {
|
||||||
|
createElement,
|
||||||
|
Component,
|
||||||
|
useEffect,
|
||||||
|
useState,
|
||||||
|
Fragment,
|
||||||
|
} from '@wordpress/element'
|
||||||
|
import ctEvents from 'ct-events'
|
||||||
|
|
||||||
|
import { OptionsPanel } from 'blocksy-options'
|
||||||
|
import nanoid from 'nanoid'
|
||||||
|
|
||||||
|
import classnames from 'classnames'
|
||||||
|
import { __, sprintf } from 'ct-i18n'
|
||||||
|
import Overlay from '../../../../../static/js/helpers/Overlay'
|
||||||
|
|
||||||
|
const ProductReviews = ({ setExtsStatus, extension, onExtsSync }) => {
|
||||||
|
const [settings, setSettings] = useState(null)
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className={classnames('ct-extension-options ct-product-reviews-options')}>
|
||||||
|
<h4>{__('Product Reviews Settings', 'blocksy-companion')}</h4>
|
||||||
|
|
||||||
|
<p className="ct-modal-description">
|
||||||
|
{__(
|
||||||
|
'Configure the slugs for single and category pages of the product review custom post type.',
|
||||||
|
'blocksy-companion'
|
||||||
|
)}
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<form>
|
||||||
|
<OptionsPanel
|
||||||
|
onChange={(optionId, optionValue) =>
|
||||||
|
setSettings((settings) => ({
|
||||||
|
...settings,
|
||||||
|
[optionId]: optionValue,
|
||||||
|
}))
|
||||||
|
}
|
||||||
|
options={{
|
||||||
|
single_slug: {
|
||||||
|
type: 'text',
|
||||||
|
value: '',
|
||||||
|
label: __('Single Slug', 'blocksy-companion'),
|
||||||
|
},
|
||||||
|
|
||||||
|
category_slug: {
|
||||||
|
type: 'text',
|
||||||
|
value: '',
|
||||||
|
label: __('Category Slug', 'blocksy-companion'),
|
||||||
|
},
|
||||||
|
}}
|
||||||
|
value={{
|
||||||
|
...extension.data.settings,
|
||||||
|
...(settings || {}),
|
||||||
|
}}
|
||||||
|
hasRevertButton={false}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<button
|
||||||
|
className="ct-button-primary"
|
||||||
|
disabled={!settings}
|
||||||
|
onClick={(e) => {
|
||||||
|
e.preventDefault()
|
||||||
|
|
||||||
|
if (!settings) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
const newSettings = {
|
||||||
|
...extension.data.settings,
|
||||||
|
...settings,
|
||||||
|
}
|
||||||
|
|
||||||
|
setExtsStatus((extStatus) => ({
|
||||||
|
...extStatus,
|
||||||
|
[extension.name]: {
|
||||||
|
...extStatus[extension.name],
|
||||||
|
data: {
|
||||||
|
...extStatus[extension.name].data,
|
||||||
|
settings: newSettings,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}))
|
||||||
|
|
||||||
|
onExtsSync({
|
||||||
|
extAction: {
|
||||||
|
type: 'persist',
|
||||||
|
settings: newSettings,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
setSettings(null)
|
||||||
|
}}>
|
||||||
|
{__('Save Settings', 'blocksy-companion')}
|
||||||
|
</button>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ProductReviews
|
||||||
@ -0,0 +1,25 @@
|
|||||||
|
import { createElement } from '@wordpress/element'
|
||||||
|
import { addFilter } from '@wordpress/hooks'
|
||||||
|
|
||||||
|
import ProductReviews from './ProductReviews'
|
||||||
|
|
||||||
|
import ctEvents from 'ct-events'
|
||||||
|
|
||||||
|
addFilter(
|
||||||
|
'blocksy.extensions.current_extension_content',
|
||||||
|
'blocksy',
|
||||||
|
(contentDescriptor, { extension, onExtsSync, setExtsStatus }) => {
|
||||||
|
if (extension.name !== 'product-reviews') return contentDescriptor
|
||||||
|
|
||||||
|
return {
|
||||||
|
...contentDescriptor,
|
||||||
|
content: (
|
||||||
|
<ProductReviews
|
||||||
|
setExtsStatus={setExtsStatus}
|
||||||
|
extension={extension}
|
||||||
|
onExtsSync={onExtsSync}
|
||||||
|
/>
|
||||||
|
),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
@ -0,0 +1,73 @@
|
|||||||
|
import { applyPrefixFor } from 'blocksy-customizer-sync'
|
||||||
|
import ctEvents from 'ct-events'
|
||||||
|
|
||||||
|
const prefix = 'blc-product-review_single'
|
||||||
|
|
||||||
|
ctEvents.on(
|
||||||
|
'ct:customizer:sync:collect-variable-descriptors',
|
||||||
|
(allVariables) => {
|
||||||
|
allVariables.result = {
|
||||||
|
...allVariables.result,
|
||||||
|
[`${prefix}_product_scores_width`]: {
|
||||||
|
selector: applyPrefixFor('.ct-product-scores', prefix),
|
||||||
|
variable: 'product-scores-width',
|
||||||
|
unit: 'px',
|
||||||
|
},
|
||||||
|
|
||||||
|
[`${prefix}_star_rating_color`]: [
|
||||||
|
{
|
||||||
|
selector: applyPrefixFor('.ct-product-scores', prefix),
|
||||||
|
variable: 'star-rating-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: applyPrefixFor('.ct-product-scores', prefix),
|
||||||
|
variable: 'star-rating-inactive-color',
|
||||||
|
type: 'color:inactive',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
[`${prefix}_overall_score_text`]: [
|
||||||
|
{
|
||||||
|
selector: applyPrefixFor('.ct-product-scores', prefix),
|
||||||
|
variable: 'overall-score-text-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
[`${prefix}_overall_score_backgroud`]: [
|
||||||
|
{
|
||||||
|
selector: applyPrefixFor('.ct-product-scores', prefix),
|
||||||
|
variable: 'overall-score-box-background',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
const archivePrefix = 'blc-product-review_archive'
|
||||||
|
|
||||||
|
ctEvents.on(
|
||||||
|
'ct:customizer:sync:collect-variable-descriptors',
|
||||||
|
(allVariables) => {
|
||||||
|
allVariables.result = {
|
||||||
|
...allVariables.result,
|
||||||
|
|
||||||
|
[`${archivePrefix}_star_rating_color`]: [
|
||||||
|
{
|
||||||
|
selector: applyPrefixFor('.star-rating', archivePrefix),
|
||||||
|
variable: 'star-rating-initial-color',
|
||||||
|
type: 'color:default',
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
selector: applyPrefixFor('.star-rating', archivePrefix),
|
||||||
|
variable: 'star-rating-inactive-color',
|
||||||
|
type: 'color:inactive',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
@ -0,0 +1,18 @@
|
|||||||
|
.ct-product-actions-group {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
|
||||||
|
&:not(:last-child) {
|
||||||
|
margin-bottom: 60px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-button:not(:last-child) {
|
||||||
|
margin-inline-end: 25px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-icon-container {
|
||||||
|
color: inherit;
|
||||||
|
margin-inline-start: 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,5 @@
|
|||||||
|
.ct-product-description {
|
||||||
|
&:not(:last-child) {
|
||||||
|
margin-bottom: 60px;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,8 @@
|
|||||||
|
.ct-product-reviews-settings-modal {
|
||||||
|
|
||||||
|
.ct-controls-group {
|
||||||
|
padding-top: 30px;
|
||||||
|
margin-top: 5px;
|
||||||
|
border-top: 1px dashed #eee;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,25 @@
|
|||||||
|
@import '../../../../../static/sass/frontend/common-frontend/functions';
|
||||||
|
@import '../../../../../static/sass/frontend/common-frontend/mixins';
|
||||||
|
|
||||||
|
@import 'slider';
|
||||||
|
@import 'title';
|
||||||
|
@import 'scores';
|
||||||
|
@import 'actions';
|
||||||
|
@import 'description';
|
||||||
|
@import 'quick-info';
|
||||||
|
|
||||||
|
.ct-product-hero {
|
||||||
|
padding-top: var(--theme-content-vertical-spacing, 60px);
|
||||||
|
|
||||||
|
.ct-container {
|
||||||
|
padding-bottom: var(--theme-content-vertical-spacing, 60px);
|
||||||
|
border-bottom: 1px solid var(--theme-border-color);
|
||||||
|
}
|
||||||
|
|
||||||
|
ul li {
|
||||||
|
|
||||||
|
&:not(:last-child) {
|
||||||
|
margin-bottom: 0.3em;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,45 @@
|
|||||||
|
.ct-product-info {
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: var(--grid-template-columns);
|
||||||
|
grid-column-gap: 40px;
|
||||||
|
grid-row-gap: 40px;
|
||||||
|
border-top: 1px solid var(--theme-border-color);
|
||||||
|
padding-top: var(--theme-content-vertical-spacing, 60px);
|
||||||
|
|
||||||
|
@include media-breakpoint-up (lg) {
|
||||||
|
--grid-template-columns: 1.5fr 1fr 1fr;
|
||||||
|
}
|
||||||
|
|
||||||
|
@include media-breakpoint-only (md) {
|
||||||
|
--grid-template-columns: 1fr 1fr;
|
||||||
|
}
|
||||||
|
|
||||||
|
li {
|
||||||
|
position: relative;
|
||||||
|
padding-inline-start: 22px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-icon-container {
|
||||||
|
position: absolute;
|
||||||
|
inset-inline-start: 0;
|
||||||
|
top: 0.4em;
|
||||||
|
opacity: 0.8;
|
||||||
|
|
||||||
|
--theme-icon-size: 13px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-specs {
|
||||||
|
@include media-breakpoint-only (md) {
|
||||||
|
grid-column: 1/-1;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul {
|
||||||
|
display: grid;
|
||||||
|
grid-column-gap: 40px;
|
||||||
|
|
||||||
|
@include media-breakpoint-up (md) {
|
||||||
|
grid-template-columns: repeat(2, 1fr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,88 @@
|
|||||||
|
.ct-product-scores {
|
||||||
|
display: grid;
|
||||||
|
grid-column-gap: 25px;
|
||||||
|
grid-row-gap: 25px;
|
||||||
|
margin: 0 auto;
|
||||||
|
max-width: var(--product-scores-width, 800px);
|
||||||
|
|
||||||
|
@include media-breakpoint-up (md) {
|
||||||
|
grid-template-columns: 2fr 1fr;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:not(:last-child) {
|
||||||
|
margin-bottom: 60px;
|
||||||
|
}
|
||||||
|
|
||||||
|
li {
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: space-between;
|
||||||
|
position: relative;
|
||||||
|
padding: 10px 20px;
|
||||||
|
|
||||||
|
&:before {
|
||||||
|
position: absolute;
|
||||||
|
z-index: 0;
|
||||||
|
inset: 0;
|
||||||
|
content: '';
|
||||||
|
border-radius: 2px;
|
||||||
|
opacity: 0.2;
|
||||||
|
background: var(--theme-border-color);
|
||||||
|
}
|
||||||
|
|
||||||
|
> span {
|
||||||
|
font-size: 15px;
|
||||||
|
font-weight: 500;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-overall-score {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
padding: 20px;
|
||||||
|
color: var(--overall-score-text-color, var(--theme-palette-color-8));
|
||||||
|
border-radius: 2px;
|
||||||
|
background: var(--overall-score-box-background, var(--theme-palette-color-4));
|
||||||
|
|
||||||
|
.ct-average-score {
|
||||||
|
font-size: 55px;
|
||||||
|
font-weight: 800;
|
||||||
|
line-height: normal;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-score-label {
|
||||||
|
font-size: 15px;
|
||||||
|
font-weight: 700;
|
||||||
|
text-transform: uppercase;
|
||||||
|
letter-spacing: 0.02em;
|
||||||
|
margin: 15px 0 0 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// layer
|
||||||
|
.ct-overall-score-layer {
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
align-items: center;
|
||||||
|
|
||||||
|
.ct-score-label,
|
||||||
|
.ct-average-score {
|
||||||
|
font-size: 14px;
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ct-average-score {
|
||||||
|
margin: 0 5px;
|
||||||
|
margin-inline-end: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.star-rating {
|
||||||
|
margin: 3px 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,34 @@
|
|||||||
|
.ct-product-hero {
|
||||||
|
|
||||||
|
.flexy-container {
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flexy-pills {
|
||||||
|
@include media-breakpoint-down (md) {
|
||||||
|
--thumbs-spacing: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@include media-breakpoint-up (lg) {
|
||||||
|
max-width: 70%;
|
||||||
|
margin: -8% auto 0 auto;
|
||||||
|
|
||||||
|
--thumbs-spacing: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
ol {
|
||||||
|
margin: 0 calc(var(--thumbs-spacing) * -1);
|
||||||
|
}
|
||||||
|
|
||||||
|
li {
|
||||||
|
padding-top: var(--thumbs-spacing);
|
||||||
|
padding-inline: var(--thumbs-spacing);
|
||||||
|
|
||||||
|
img {
|
||||||
|
width: 100%;
|
||||||
|
border-radius: 2px;
|
||||||
|
border: 3px solid #fff;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,6 @@
|
|||||||
|
.ct-product-hero {
|
||||||
|
|
||||||
|
.hero-section:not(:first-child) {
|
||||||
|
margin-top: var(--margin-bottom, 40px);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,310 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$prefix = 'blc-product-review_single';
|
||||||
|
|
||||||
|
$atts = apply_filters(
|
||||||
|
'blocksy:ext:product-reviews:frontend:atts',
|
||||||
|
blocksy_get_post_options(null, [
|
||||||
|
'meta_id' => 'blocksy_product_review_options'
|
||||||
|
]),
|
||||||
|
get_the_ID()
|
||||||
|
);
|
||||||
|
|
||||||
|
$gallery_images = array_map(function ($item) {
|
||||||
|
return $item['attachment_id'];
|
||||||
|
}, blocksy_akg('gallery', $atts, []));
|
||||||
|
|
||||||
|
$thumb_id = get_post_thumbnail_id();
|
||||||
|
|
||||||
|
if ($thumb_id) {
|
||||||
|
array_unshift($gallery_images, intval($thumb_id));
|
||||||
|
} else {
|
||||||
|
$gallery_images = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
$link_atts = [];
|
||||||
|
|
||||||
|
if (blocksy_akg('product_link_sponsored', $atts, 'no') === 'yes') {
|
||||||
|
$link_atts['rel'] = 'sponsored';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (blocksy_akg('product_link_target', $atts, 'no') === 'yes') {
|
||||||
|
$link_atts['target'] = '_blank';
|
||||||
|
|
||||||
|
if (! isset($link_atts['rel'])) {
|
||||||
|
$link_atts['rel'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$link_atts['rel'] .= ' noopener noreferrer';
|
||||||
|
$link_atts['rel'] = trim($link_atts['rel']);
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '<section class="ct-product-hero">';
|
||||||
|
echo '<div class="ct-container">';
|
||||||
|
if (count($gallery_images) === 1) {
|
||||||
|
$attachment_id = $gallery_images[0];
|
||||||
|
|
||||||
|
$image_href = wp_get_attachment_image_src(
|
||||||
|
$attachment_id,
|
||||||
|
'full'
|
||||||
|
);
|
||||||
|
|
||||||
|
$width = null;
|
||||||
|
$height = null;
|
||||||
|
|
||||||
|
if ($image_href) {
|
||||||
|
$width = $image_href[1];
|
||||||
|
$height = $image_href[2];
|
||||||
|
|
||||||
|
$image_href = $image_href[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
echo blocksy_media([
|
||||||
|
'attachment_id' => $gallery_images[0],
|
||||||
|
'size' => 'full',
|
||||||
|
'ratio' => apply_filters('blocksy:ext:product-reviews:gallery:ratio', '2/1'),
|
||||||
|
'tag_name' => 'a',
|
||||||
|
'html_atts' => array_merge([
|
||||||
|
'href' => $image_href
|
||||||
|
], $width ? [
|
||||||
|
'data-width' => $width,
|
||||||
|
'data-height' => $height
|
||||||
|
] : []),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count($gallery_images) > 1) {
|
||||||
|
$args = [
|
||||||
|
'images' => $gallery_images,
|
||||||
|
'size' => 'full',
|
||||||
|
'images_ratio' => apply_filters('blocksy:ext:product-reviews:gallery:ratio', '2/1')
|
||||||
|
];
|
||||||
|
|
||||||
|
$args['pills_images'] = $gallery_images;
|
||||||
|
|
||||||
|
if (count($gallery_images) <= 5) {
|
||||||
|
} else {
|
||||||
|
$args['pills_have_arrows'] = true;
|
||||||
|
$args['pills_container_attr'] = [
|
||||||
|
'data-flexy' => 'no'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
echo blocksy_flexy($args);
|
||||||
|
}
|
||||||
|
|
||||||
|
echo blocksy_output_hero_section([
|
||||||
|
'type' => 'type-1'
|
||||||
|
]);
|
||||||
|
|
||||||
|
$scores = blocksy_akg('scores', $atts, []);
|
||||||
|
|
||||||
|
if (! empty($scores)) {
|
||||||
|
echo '<div class="ct-product-scores">';
|
||||||
|
|
||||||
|
echo '<ul>';
|
||||||
|
|
||||||
|
foreach ($scores as $single_score) {
|
||||||
|
echo '<li>';
|
||||||
|
echo '<span>' . $single_score['label'] . '</span>';
|
||||||
|
|
||||||
|
echo '<div class="star-rating" role="img">';
|
||||||
|
$width = ((floatval($single_score['score']) / 5) * 100);
|
||||||
|
|
||||||
|
echo '<span style="width: ' . $width . '%;">Rated <strong class="rating">3</strong> out of 5</span>';
|
||||||
|
echo '</div>';
|
||||||
|
echo '</li>';
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '</ul>';
|
||||||
|
|
||||||
|
echo '<div class="ct-overall-score" ' . blocksy_schema_org_definitions('reviewRating') . '>';
|
||||||
|
|
||||||
|
$avg_score = apply_filters(
|
||||||
|
'blocksy:ext:product-reviews:overall-score',
|
||||||
|
round(array_reduce($scores, function ($carry, $score) {
|
||||||
|
return $carry + floatval($score['score']);
|
||||||
|
}, 0) / count($scores) * 10) / 10,
|
||||||
|
$scores
|
||||||
|
);
|
||||||
|
|
||||||
|
echo '<span class="ct-average-score" ' . blocksy_schema_org_definitions('ratingValue') . '>' . $avg_score . '/5</span>';
|
||||||
|
|
||||||
|
echo '<div class="star-rating" role="img">';
|
||||||
|
$width = ( ( $avg_score / 5 ) * 100 );
|
||||||
|
echo '<span style="width: ' . $width . '%;"></span>';
|
||||||
|
echo '</div>';
|
||||||
|
|
||||||
|
echo '<span class="ct-score-label">';
|
||||||
|
echo __('Overall Score', 'blocksy-companion');
|
||||||
|
echo '</span>';
|
||||||
|
echo '</div>';
|
||||||
|
|
||||||
|
echo '</div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
$has_read_more = blocksy_get_theme_mod($prefix . '_has_read_more', 'yes') === 'yes';
|
||||||
|
$has_buy_now = blocksy_get_theme_mod($prefix . '_has_buy_now', 'yes') === 'yes';
|
||||||
|
|
||||||
|
if ($has_read_more || $has_buy_now) {
|
||||||
|
echo '<div class="ct-product-actions-group">';
|
||||||
|
|
||||||
|
$product_link = blocksy_akg('product_link', $atts, '#');
|
||||||
|
$product_button_label = blocksy_akg(
|
||||||
|
'product_button_label',
|
||||||
|
$atts,
|
||||||
|
__('Buy Now', 'blocksy-companion')
|
||||||
|
);
|
||||||
|
|
||||||
|
$product_read_content_button_label = blocksy_akg(
|
||||||
|
'product_read_content_button_label',
|
||||||
|
$atts,
|
||||||
|
__('Read More', 'blocksy-companion')
|
||||||
|
);
|
||||||
|
|
||||||
|
if (
|
||||||
|
! empty($product_button_label)
|
||||||
|
&&
|
||||||
|
$has_read_more
|
||||||
|
) {
|
||||||
|
echo '<a href="#post-' . get_the_ID() . '" class="ct-button">';
|
||||||
|
echo $product_read_content_button_label;
|
||||||
|
|
||||||
|
/*
|
||||||
|
echo blc_get_icon([
|
||||||
|
'icon_descriptor' => blocksy_akg('product_read_content_button_icon', $atts, [
|
||||||
|
'icon' => 'fas fa-arrow-down'
|
||||||
|
]),
|
||||||
|
]);
|
||||||
|
*/
|
||||||
|
|
||||||
|
echo '</a>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
! empty($product_button_label)
|
||||||
|
&&
|
||||||
|
! empty($product_link)
|
||||||
|
&&
|
||||||
|
$has_buy_now
|
||||||
|
) {
|
||||||
|
echo blocksy_html_tag(
|
||||||
|
'a',
|
||||||
|
array_merge([
|
||||||
|
'href' => esc_url($product_link),
|
||||||
|
'class' => 'ct-button'
|
||||||
|
], $link_atts),
|
||||||
|
$product_button_label
|
||||||
|
);
|
||||||
|
|
||||||
|
/*
|
||||||
|
echo blc_get_icon([
|
||||||
|
'icon_descriptor' => blocksy_akg('product_button_icon', $atts, [
|
||||||
|
'icon' => 'fas fa-cart-arrow-down'
|
||||||
|
]),
|
||||||
|
]);
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '</div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
$product_specs = blocksy_akg('product_specs', $atts, []);
|
||||||
|
$product_pros = blocksy_akg('product_pros', $atts, []);
|
||||||
|
$product_cons = blocksy_akg('product_cons', $atts, []);
|
||||||
|
$product_description = blocksy_akg('product_description', $atts, '');
|
||||||
|
|
||||||
|
if (! empty($product_description)) {
|
||||||
|
echo '<div class="ct-product-description" ' . blocksy_schema_org_definitions('reviewBody') . '>';
|
||||||
|
|
||||||
|
echo '<div class="entry-content">';
|
||||||
|
echo do_shortcode($product_description);
|
||||||
|
echo '</div>';
|
||||||
|
|
||||||
|
echo '</div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
! empty($product_specs)
|
||||||
|
||
|
||||||
|
! empty($product_pros)
|
||||||
|
||
|
||||||
|
! empty($product_cons)
|
||||||
|
) {
|
||||||
|
echo '<div class="ct-product-info">';
|
||||||
|
|
||||||
|
if (! empty($product_specs)) {
|
||||||
|
echo '<div class="ct-specs">';
|
||||||
|
echo '<h5>' . __('Specs', 'blocksy-companion') . '</h5>';
|
||||||
|
|
||||||
|
echo '<ul>';
|
||||||
|
|
||||||
|
foreach ($product_specs as $single_spec) {
|
||||||
|
echo '<li>';
|
||||||
|
echo blocksy_html_tag(
|
||||||
|
'span',
|
||||||
|
[
|
||||||
|
'class' => 'ct-icon-container'
|
||||||
|
],
|
||||||
|
"<svg width='13' height='13' viewBox='0 0 13 13'><path d='M5.3 0l-.2 1.7c-.8.2-1.5.7-2.1 1.2l-1.5-.7-1.2 2 1.4 1c-.1.5-.2.9-.2 1.3s.1.8.2 1.2l-1.4 1 1.2 2 1.5-.6c.6.6 1.3 1 2.1 1.2l.2 1.7h2.3l.2-1.7c.8-.2 1.5-.6 2.1-1.2l1.6.7 1.2-2-1.4-1c.1-.4.2-.8.2-1.2s-.1-.8-.2-1.2l1.4-1-1.2-2-1.5.5c-.6-.6-1.3-1-2.1-1.2L7.7 0H5.3zm1.2 4.5c1.1 0 2 .9 2 2s-.9 2-2 2-2-.9-2-2 .9-2 2-2z'/></svg>"
|
||||||
|
);
|
||||||
|
echo '<b>' . blocksy_akg('label', $single_spec, '') . ': </b>';
|
||||||
|
echo blocksy_akg('value', $single_spec, '');
|
||||||
|
echo '</li>';
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '</ul>';
|
||||||
|
echo '</div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! empty($product_pros)) {
|
||||||
|
echo '<div class="ct-product-review-pros" ' . blocksy_schema_org_definitions('positiveNotes') . '>';
|
||||||
|
echo '<h5>' . __('Pros', 'blocksy-companion') . '</h5>';
|
||||||
|
|
||||||
|
echo '<ul>';
|
||||||
|
|
||||||
|
foreach ($product_pros as $single_pro) {
|
||||||
|
echo '<li>';
|
||||||
|
echo blocksy_html_tag(
|
||||||
|
'span',
|
||||||
|
[
|
||||||
|
'class' => 'ct-icon-container'
|
||||||
|
],
|
||||||
|
"<svg width='13' height='13' viewBox='0 0 13 13'><path d='M6.4.3c-.3 0-.5.3-.6.5l-.6 1.7-1.7 2c-.3.3-.4.5-.4.9v6c0 .7.6 1.3 1.3 1.3h5.2c.5 0 1-.3 1.1-.7l2-4.4c.2-.3.3-.6.3-.8v-.6c0-.7-.6-1.3-1.3-1.3H7.2s.7-1.6.7-2.7c0-1-.7-1.6-1.2-1.7-.2-.2-.2-.2-.3-.2zM1 4.8c-.5 0-1 .4-1 1v5.9c0 .6.4 1 1 1s1-.4 1-1V5.8c-.1-.5-.5-1-1-1z'/></svg>"
|
||||||
|
);
|
||||||
|
echo blocksy_akg('label', $single_pro, '');
|
||||||
|
echo '</li>';
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '</ul>';
|
||||||
|
echo '</div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! empty($product_cons)) {
|
||||||
|
echo '<div class="ct-product-review-cons" ' . blocksy_schema_org_definitions('negativeNotes') . '>';
|
||||||
|
echo '<h5>' . __('Cons', 'blocksy-companion') . '</h5>';
|
||||||
|
|
||||||
|
echo '<ul>';
|
||||||
|
|
||||||
|
foreach ($product_cons as $single_cons) {
|
||||||
|
echo '<li>';
|
||||||
|
echo blocksy_html_tag(
|
||||||
|
'span',
|
||||||
|
[
|
||||||
|
'class' => 'ct-icon-container'
|
||||||
|
],
|
||||||
|
"<svg width='13' height='13' viewBox='0 0 13 13'><path d='M6.6 12.6c.5-.2 1.2-.7 1.2-1.7 0-1.1-.7-2.7-.7-2.7h4.5c.7 0 1.3-.6 1.3-1.3v-.7c0-.3-.1-.5-.2-.8l-2-4.4c-.2-.4-.6-.7-1.1-.7H4.4c-.7 0-1.3.6-1.3 1.3v6c0 .3.1.6.3.9l1.7 2 .5 1.7c.1.3.3.5.6.5s.3 0 .4-.1zM1.9 7.2V1.4c0-.5-.4-1-1-1s-1 .3-1 1v5.9c0 .5.4 1 1 1s1-.6 1-1.1z'/></svg>"
|
||||||
|
);
|
||||||
|
echo blocksy_akg('label', $single_cons, '');
|
||||||
|
echo '</li>';
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '</ul>';
|
||||||
|
echo '</div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '</div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '</div>';
|
||||||
|
echo '</section>';
|
||||||
@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$config = [
|
||||||
|
// translators: This is a brand name. Preferably to not be translated
|
||||||
|
'name' => _x('Trending Posts', 'Extension Brand Name', 'blocksy-companion'),
|
||||||
|
'description' => __('Highlight your most popular posts or products based on the number of comments or reviews they have gotten in the specified period of time.', 'blocksy-companion'),
|
||||||
|
|
||||||
|
'documentation' => 'https://creativethemes.com/blocksy/docs/extensions/trending-posts/',
|
||||||
|
'video' => 'https://creativethemes.com/blocksy/video-tutorials/customization/exploring-the-trending-posts-extension/',
|
||||||
|
'customize' => admin_url('customize.php?ct_autofocus=trending_posts_ext'),
|
||||||
|
'icon' => '<svg width="16" height="16" viewBox="0 0 16 16"><path d="M13 4c-.9-1.5-2.2-2.8-3.2-3.9-.2-.1-.3-.1-.5-.1s-.4.2-.5.3L6.6 5 4.3 3.5c-.2-.1-.3-.2-.5-.1-.2 0-.3.1-.4.2-1.3 2.1-2.1 4.1-2.1 5.7a6.7 6.7 0 0 0 13.4 0c0-1.8-.6-3.5-1.7-5.3zm-.5 5.8c-.3 2.1-2 3.7-4 4h-.1c-.4 0-.6-.3-.6-.6s.2-.6.5-.6c1.5-.2 2.7-1.4 3-3 0-.4.4-.6.7-.6.3.1.6.4.5.8z"/></svg>',
|
||||||
|
];
|
||||||
|
|
||||||
@ -0,0 +1,568 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$all_post_types = [
|
||||||
|
'post' => __('Posts', 'blocksy-companion')
|
||||||
|
];
|
||||||
|
|
||||||
|
if (class_exists('WooCommerce')) {
|
||||||
|
$all_post_types['product'] = __('Products', 'blocksy-companion');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (function_exists('blocksy_manager')) {
|
||||||
|
$post_types = blocksy_manager()->post_types->get_supported_post_types();
|
||||||
|
|
||||||
|
foreach ($post_types as $single_post_type) {
|
||||||
|
$post_type_object = get_post_type_object($single_post_type);
|
||||||
|
|
||||||
|
if (! $post_type_object) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$all_post_types[
|
||||||
|
$single_post_type
|
||||||
|
] = $post_type_object->labels->singular_name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$cpt_options = [];
|
||||||
|
|
||||||
|
foreach ($all_post_types as $custom_post_type => $label) {
|
||||||
|
if ($custom_post_type === 'page') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$opt_id = 'trending_block_category';
|
||||||
|
$label = __('Category', 'blocksy-companion');
|
||||||
|
$label_multiple = __('All categories', 'blocksy-companion');
|
||||||
|
$taxonomy = 'category';
|
||||||
|
|
||||||
|
if ($custom_post_type !== 'post') {
|
||||||
|
$opt_id = 'trending_block_' . $custom_post_type . '_taxonomy';
|
||||||
|
$label = __('Taxonomy', 'blocksy-companion');
|
||||||
|
$label_multiple = __('All taxonomies', 'blocksy-companion');
|
||||||
|
|
||||||
|
$taxonomies = get_object_taxonomies($custom_post_type);
|
||||||
|
|
||||||
|
if (count($taxonomies) > 0) {
|
||||||
|
$taxonomy = array_slice($taxonomies, 0, 20);
|
||||||
|
} else {
|
||||||
|
$taxonomy = 'nonexistent';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$categories = get_terms([
|
||||||
|
'taxonomy' => $taxonomy,
|
||||||
|
// 'post_type' => $custom_post_type,
|
||||||
|
'orderby' => 'name',
|
||||||
|
'order' => 'ASC',
|
||||||
|
'hide_empty' => false
|
||||||
|
]);
|
||||||
|
|
||||||
|
$category_choices = [
|
||||||
|
'all_categories' => $label_multiple
|
||||||
|
];
|
||||||
|
|
||||||
|
if (! is_wp_error($categories)) {
|
||||||
|
foreach ($categories as $category) {
|
||||||
|
$category_choices[$category->term_id] = $category->name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$cpt_options[blocksy_rand_md5()] = [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => [
|
||||||
|
'trending_block_post_type' => $custom_post_type,
|
||||||
|
'trending_block_post_source' => '!custom'
|
||||||
|
],
|
||||||
|
'options' => [
|
||||||
|
$opt_id => [
|
||||||
|
'type' => 'ct-select',
|
||||||
|
'label' => $label,
|
||||||
|
'value' => 'all_categories',
|
||||||
|
'choices' => blocksy_ordered_keys($category_choices),
|
||||||
|
'design' => 'inline',
|
||||||
|
'sync' => [
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'render' => function () {
|
||||||
|
echo blc_get_trending_block();
|
||||||
|
}
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
$options = [
|
||||||
|
// translators: This is a brand name. Preferably to not be translated
|
||||||
|
'title' => _x('Trending Posts', 'Extension Brand Name', 'blocksy-companion'),
|
||||||
|
'container' => [ 'priority' => 8 ],
|
||||||
|
'options' => [
|
||||||
|
'trending_posts_section_options' => [
|
||||||
|
'type' => 'ct-options',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'inner-options' => [
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-title',
|
||||||
|
'label' => __( 'Trending Posts', 'blocksy-companion' ),
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'General', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
[
|
||||||
|
[
|
||||||
|
'trending_block_label' => [
|
||||||
|
'label' => __( 'Module Title', 'blocksy-companion' ),
|
||||||
|
'type' => 'text',
|
||||||
|
'design' => 'inline',
|
||||||
|
'value' => __( 'Trending now', 'blocksy-companion' ),
|
||||||
|
'sync' => 'live',
|
||||||
|
],
|
||||||
|
|
||||||
|
'trending_block_label_tag' => [
|
||||||
|
'label' => __( 'Module Title Tag', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-select',
|
||||||
|
'value' => 'h3',
|
||||||
|
'view' => 'text',
|
||||||
|
'design' => 'inline',
|
||||||
|
'choices' => blocksy_ordered_keys(
|
||||||
|
[
|
||||||
|
'h1' => 'H1',
|
||||||
|
'h2' => 'H2',
|
||||||
|
'h3' => 'H3',
|
||||||
|
'h4' => 'H4',
|
||||||
|
'h5' => 'H5',
|
||||||
|
'h6' => 'H6',
|
||||||
|
'p' => 'p',
|
||||||
|
'span' => 'span',
|
||||||
|
]
|
||||||
|
),
|
||||||
|
'sync' => [
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'render' => function () {
|
||||||
|
echo blc_get_trending_block();
|
||||||
|
}
|
||||||
|
]
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blc_site_has_feature()
|
||||||
|
? [
|
||||||
|
'trending_block_icon_source' => [
|
||||||
|
'label' => __(
|
||||||
|
'Module Title Icon Source',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
'type' => 'ct-radio',
|
||||||
|
'value' => 'default',
|
||||||
|
'view' => 'text',
|
||||||
|
'design' => 'block',
|
||||||
|
'divider' => 'top',
|
||||||
|
'sync' => [
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'render' => function () {
|
||||||
|
echo blc_get_trending_block();
|
||||||
|
}
|
||||||
|
],
|
||||||
|
'choices' => [
|
||||||
|
'default' => __(
|
||||||
|
'Default',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
'custom' => __(
|
||||||
|
'Custom',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => [
|
||||||
|
'trending_block_icon_source' => 'custom',
|
||||||
|
],
|
||||||
|
'options' => [
|
||||||
|
'trending_block_custom_icon' => [
|
||||||
|
'type' => 'icon-picker',
|
||||||
|
'label' => __(
|
||||||
|
'Icon',
|
||||||
|
'blocksy-companion'
|
||||||
|
),
|
||||||
|
'design' => 'inline',
|
||||||
|
'divider' => 'top',
|
||||||
|
'value' => [
|
||||||
|
'icon' => 'fas fa-fire',
|
||||||
|
],
|
||||||
|
'sync' => [
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'render' => function () {
|
||||||
|
echo blc_get_trending_block();
|
||||||
|
}
|
||||||
|
]
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]
|
||||||
|
: [],
|
||||||
|
|
||||||
|
'trending_block_post_type' => count($all_post_types) > 1 ? [
|
||||||
|
'label' => __( 'Post Type', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-select',
|
||||||
|
'value' => 'post',
|
||||||
|
'design' => 'inline',
|
||||||
|
'divider' => 'top:full',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'choices' => blocksy_ordered_keys($all_post_types),
|
||||||
|
'sync' => [
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'render' => function () {
|
||||||
|
echo blc_get_trending_block();
|
||||||
|
}
|
||||||
|
],
|
||||||
|
] : [
|
||||||
|
'label' => __('Post Type', 'blocksy-companion'),
|
||||||
|
'type' => 'hidden',
|
||||||
|
'value' => 'post',
|
||||||
|
'design' => 'none',
|
||||||
|
'setting' => ['transport' => 'postMessage'],
|
||||||
|
],
|
||||||
|
|
||||||
|
'trending_block_post_source' => [
|
||||||
|
'type' => 'ct-select',
|
||||||
|
'label' => __( 'Source', 'blocksy-companion' ),
|
||||||
|
'value' => 'categories',
|
||||||
|
'design' => 'inline',
|
||||||
|
'choices' => blocksy_ordered_keys(
|
||||||
|
[
|
||||||
|
'categories' => __('Taxonomies', 'blocksy-companion'),
|
||||||
|
'custom' => __( 'Custom Query', 'blocksy-companion' ),
|
||||||
|
]
|
||||||
|
),
|
||||||
|
'sync' => [
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'render' => function () {
|
||||||
|
echo blc_get_trending_block();
|
||||||
|
}
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
$cpt_options,
|
||||||
|
|
||||||
|
[
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-condition',
|
||||||
|
'condition' => [
|
||||||
|
'trending_block_post_source' => 'custom'
|
||||||
|
],
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'trending_block_post_id' => [
|
||||||
|
'label' => __( 'Posts ID', 'blocksy-companion' ),
|
||||||
|
'type' => 'text',
|
||||||
|
'design' => 'inline',
|
||||||
|
'desc' => blc_safe_sprintf(
|
||||||
|
__('Separate posts ID by comma. How to find the %spost ID%s.', 'blocksy-companion'),
|
||||||
|
'<a href="https://www.wpbeginner.com/beginners-guide/how-to-find-post-category-tag-comments-or-user-id-in-wordpress/" target="_blank">',
|
||||||
|
'</a>'
|
||||||
|
),
|
||||||
|
'sync' => [
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'render' => function () {
|
||||||
|
echo blc_get_trending_block();
|
||||||
|
}
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'trending_block_filter' => [
|
||||||
|
'label' => __( 'Trending From', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-select',
|
||||||
|
'divider' => 'top',
|
||||||
|
'value' => 'all_time',
|
||||||
|
'view' => 'text',
|
||||||
|
'design' => 'inline',
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
'choices' => blocksy_ordered_keys(
|
||||||
|
[
|
||||||
|
'all_time' => __( 'All Time', 'blocksy-companion' ),
|
||||||
|
'last_24_hours' => __( 'Last 24 Hours', 'blocksy-companion' ),
|
||||||
|
'last_7_days' => __( 'Last 7 Days', 'blocksy-companion' ),
|
||||||
|
'last_month' => __( 'Last Month', 'blocksy-companion' ),
|
||||||
|
]
|
||||||
|
),
|
||||||
|
|
||||||
|
'sync' => [
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'render' => function () {
|
||||||
|
echo blc_get_trending_block();
|
||||||
|
}
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'trending_block_thumbnails_size' => [
|
||||||
|
'label' => __('Image Size', 'blocksy-companion'),
|
||||||
|
'type' => 'ct-select',
|
||||||
|
'value' => 'thumbnail',
|
||||||
|
'view' => 'text',
|
||||||
|
'design' => 'inline',
|
||||||
|
'divider' => 'top',
|
||||||
|
'choices' => blocksy_ordered_keys(
|
||||||
|
blocksy_get_all_image_sizes()
|
||||||
|
),
|
||||||
|
'sync' => [
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'render' => function () {
|
||||||
|
echo blc_get_trending_block();
|
||||||
|
}
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'type' => 'ct-divider',
|
||||||
|
],
|
||||||
|
|
||||||
|
'trending_block_visibility' => [
|
||||||
|
'label' => __( 'Container Visibility', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-visibility',
|
||||||
|
'design' => 'block',
|
||||||
|
'sync' => 'live',
|
||||||
|
|
||||||
|
'value' => [
|
||||||
|
'desktop' => true,
|
||||||
|
'tablet' => true,
|
||||||
|
'mobile' => false,
|
||||||
|
],
|
||||||
|
|
||||||
|
'choices' => blocksy_ordered_keys([
|
||||||
|
'desktop' => __( 'Desktop', 'blocksy-companion' ),
|
||||||
|
'tablet' => __( 'Tablet', 'blocksy-companion' ),
|
||||||
|
'mobile' => __( 'Mobile', 'blocksy-companion' ),
|
||||||
|
]),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blc_site_has_feature() ? [
|
||||||
|
'trending_block_location' => [
|
||||||
|
'label' => __('Display Location', 'blocksy-companion'),
|
||||||
|
'type' => 'ct-select',
|
||||||
|
'design' => 'inline',
|
||||||
|
'divider' => 'top',
|
||||||
|
'value' => 'blocksy:content:bottom',
|
||||||
|
'choices' => [
|
||||||
|
[
|
||||||
|
'key' => 'blocksy:content:bottom',
|
||||||
|
'value' => __('Before Footer', 'blocksy-companion')
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'key' => 'blocksy:footer:after',
|
||||||
|
'value' => __('After Footer', 'blocksy-companion')
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'key' => 'blocksy:header:after',
|
||||||
|
'value' => __('After Header', 'blocksy-companion')
|
||||||
|
]
|
||||||
|
]
|
||||||
|
],
|
||||||
|
|
||||||
|
'trending_block_conditions' => [
|
||||||
|
'label' => __('Display Conditions', 'blocksy-companion'),
|
||||||
|
'type' => 'blocksy-display-condition',
|
||||||
|
'divider' => 'top',
|
||||||
|
'value' => [
|
||||||
|
[
|
||||||
|
'type' => 'include',
|
||||||
|
'rule' => 'everywhere',
|
||||||
|
]
|
||||||
|
],
|
||||||
|
'display' => 'modal',
|
||||||
|
|
||||||
|
'modalTitle' => __('Trending Block Display Conditions', 'blocksy-companion'),
|
||||||
|
'modalDescription' => __('Add one or more conditions to display the trending block.', 'blocksy-companion'),
|
||||||
|
'design' => 'block',
|
||||||
|
'sync' => 'live'
|
||||||
|
],
|
||||||
|
] : [],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
blocksy_rand_md5() => [
|
||||||
|
'title' => __( 'Design', 'blocksy-companion' ),
|
||||||
|
'type' => 'tab',
|
||||||
|
'options' => [
|
||||||
|
|
||||||
|
'trendingBlockHeadingFont' => [
|
||||||
|
'type' => 'ct-typography',
|
||||||
|
'label' => __( 'Module Title Font', 'blocksy-companion' ),
|
||||||
|
'value' => blocksy_typography_default_values([
|
||||||
|
'size' => '15px',
|
||||||
|
]),
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
'trendingBlockHeadingFontColor' => [
|
||||||
|
'label' => __( 'Module Title Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'block:right',
|
||||||
|
'responsive' => true,
|
||||||
|
'sync' => 'live',
|
||||||
|
'divider' => 'bottom',
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => [
|
||||||
|
'var(--theme-heading-1-color, var(--theme-headings-color))' => [
|
||||||
|
'trending_block_label_tag' => 'h1'
|
||||||
|
],
|
||||||
|
|
||||||
|
'var(--theme-heading-2-color, var(--theme-headings-color))' => [
|
||||||
|
'trending_block_label_tag' => 'h2'
|
||||||
|
],
|
||||||
|
|
||||||
|
'var(--theme-heading-3-color, var(--theme-headings-color))' => [
|
||||||
|
'trending_block_label_tag' => 'h3'
|
||||||
|
],
|
||||||
|
|
||||||
|
'var(--theme-heading-4-color, var(--theme-headings-color))' => [
|
||||||
|
'trending_block_label_tag' => 'h4'
|
||||||
|
],
|
||||||
|
|
||||||
|
'var(--theme-heading-5-color, var(--theme-headings-color))' => [
|
||||||
|
'trending_block_label_tag' => 'h5'
|
||||||
|
],
|
||||||
|
|
||||||
|
'var(--theme-heading-6-color, var(--theme-headings-color))' => [
|
||||||
|
'trending_block_label_tag' => 'h6'
|
||||||
|
],
|
||||||
|
|
||||||
|
'var(--theme-text-color)' => [
|
||||||
|
'trending_block_label_tag' => 'span|p'
|
||||||
|
],
|
||||||
|
]
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'trendingBlockPostsFont' => [
|
||||||
|
'type' => 'ct-typography',
|
||||||
|
'label' => __( 'Posts Title Font', 'blocksy-companion' ),
|
||||||
|
'value' => blocksy_typography_default_values([
|
||||||
|
'size' => '15px',
|
||||||
|
'variation' => 'n5',
|
||||||
|
]),
|
||||||
|
'setting' => [ 'transport' => 'postMessage' ],
|
||||||
|
],
|
||||||
|
|
||||||
|
'trendingBlockFontColor' => [
|
||||||
|
'label' => __( 'Posts Title Font Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'block:right',
|
||||||
|
'responsive' => true,
|
||||||
|
'sync' => 'live',
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-text-color)'
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Hover', 'blocksy-companion' ),
|
||||||
|
'id' => 'hover',
|
||||||
|
'inherit' => 'var(--theme-link-hover-color)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'trendingBlockArrowsColor' => [
|
||||||
|
'label' => __( 'Arrows Color', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-color-picker',
|
||||||
|
'design' => 'block:right',
|
||||||
|
'responsive' => true,
|
||||||
|
'divider' => 'top',
|
||||||
|
'sync' => 'live',
|
||||||
|
'value' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT'),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'pickers' => [
|
||||||
|
[
|
||||||
|
'title' => __( 'Initial', 'blocksy-companion' ),
|
||||||
|
'id' => 'default',
|
||||||
|
'inherit' => 'var(--theme-text-color)'
|
||||||
|
],
|
||||||
|
|
||||||
|
[
|
||||||
|
'title' => __( 'Hover', 'blocksy-companion' ),
|
||||||
|
'id' => 'hover',
|
||||||
|
'inherit' => 'var(--theme-link-hover-color)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
|
||||||
|
'trending_block_background' => [
|
||||||
|
'label' => __( 'Container Background', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-background',
|
||||||
|
'design' => 'block:right',
|
||||||
|
'responsive' => true,
|
||||||
|
'divider' => 'top',
|
||||||
|
'sync' => 'live',
|
||||||
|
'value' => blocksy_background_default_value([
|
||||||
|
'backgroundColor' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => 'var(--theme-palette-color-5)',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
])
|
||||||
|
],
|
||||||
|
|
||||||
|
'trendingBlockContainerSpacing' => [
|
||||||
|
'label' => __( 'Container Inner Spacing', 'blocksy-companion' ),
|
||||||
|
'type' => 'ct-slider',
|
||||||
|
'divider' => 'top',
|
||||||
|
'value' => '30px',
|
||||||
|
'units' => blocksy_units_config([
|
||||||
|
[
|
||||||
|
'unit' => 'px',
|
||||||
|
'min' => 0,
|
||||||
|
'max' => 100,
|
||||||
|
],
|
||||||
|
]),
|
||||||
|
'responsive' => true,
|
||||||
|
'sync' => 'live',
|
||||||
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
],
|
||||||
|
]
|
||||||
|
]
|
||||||
|
]
|
||||||
|
];
|
||||||
@ -0,0 +1,134 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/helpers.php';
|
||||||
|
|
||||||
|
class BlocksyExtensionTrending {
|
||||||
|
private $result = null;
|
||||||
|
|
||||||
|
public function __construct() {
|
||||||
|
add_action('wp_enqueue_scripts', function () {
|
||||||
|
if (! function_exists('get_plugin_data')) {
|
||||||
|
require_once(ABSPATH . 'wp-admin/includes/plugin.php');
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
if (is_admin()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
wp_enqueue_style(
|
||||||
|
'blocksy-ext-trending-styles',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/trending/static/bundle/main.min.css',
|
||||||
|
['ct-main-styles'],
|
||||||
|
$data['Version']
|
||||||
|
);
|
||||||
|
}, 50);
|
||||||
|
|
||||||
|
add_filter('blocksy:frontend:dynamic-js-chunks', function ($chunks) {
|
||||||
|
$chunks[] = [
|
||||||
|
'id' => 'blocksy_ext_trending',
|
||||||
|
'selector' => '.ct-trending-block [class*="ct-arrow"]',
|
||||||
|
'url' => blocksy_cdn_url(
|
||||||
|
BLOCKSY_URL . 'framework/extensions/trending/static/bundle/main.js'
|
||||||
|
),
|
||||||
|
'trigger' => 'click'
|
||||||
|
];
|
||||||
|
|
||||||
|
return $chunks;
|
||||||
|
});
|
||||||
|
|
||||||
|
add_filter(
|
||||||
|
'blocksy_extensions_customizer_options',
|
||||||
|
function ($opts) {
|
||||||
|
$opts['trending_posts_ext'] = blocksy_get_options(
|
||||||
|
dirname(__FILE__) . '/customizer.php',
|
||||||
|
[],
|
||||||
|
false
|
||||||
|
);
|
||||||
|
|
||||||
|
return $opts;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action('wp', function () {
|
||||||
|
$location = 'blocksy:template:after';
|
||||||
|
|
||||||
|
if (blc_site_has_feature()) {
|
||||||
|
$location = blocksy_get_theme_mod(
|
||||||
|
'trending_block_location',
|
||||||
|
'blocksy:content:bottom'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->result = blc_get_trending_posts_value();
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
$location,
|
||||||
|
function () {
|
||||||
|
if (blc_site_has_feature()) {
|
||||||
|
$conditions = blocksy_get_theme_mod(
|
||||||
|
'trending_block_conditions',
|
||||||
|
[
|
||||||
|
[
|
||||||
|
'type' => 'include',
|
||||||
|
'rule' => 'everywhere',
|
||||||
|
]
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
$conditions_manager = new \Blocksy\ConditionsManager();
|
||||||
|
|
||||||
|
if (! $conditions_manager->condition_matches($conditions)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
echo blc_get_trending_block($this->result);
|
||||||
|
},
|
||||||
|
50
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'customize_preview_init',
|
||||||
|
function () {
|
||||||
|
if (! function_exists('get_plugin_data')) {
|
||||||
|
require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = get_plugin_data(BLOCKSY__FILE__);
|
||||||
|
|
||||||
|
wp_enqueue_script(
|
||||||
|
'blocksy-trending-customizer-sync',
|
||||||
|
BLOCKSY_URL . 'framework/extensions/trending/static/bundle/sync.js',
|
||||||
|
['customize-preview', 'ct-scripts', 'ct-customizer'],
|
||||||
|
$data['Version'],
|
||||||
|
true
|
||||||
|
);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
add_action(
|
||||||
|
'blocksy:global-dynamic-css:enqueue',
|
||||||
|
'BlocksyExtensionTrending::add_global_styles',
|
||||||
|
10, 3
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
static public function add_global_styles($args) {
|
||||||
|
blocksy_theme_get_dynamic_styles(array_merge([
|
||||||
|
'path' => dirname(__FILE__) . '/global.php',
|
||||||
|
'chunk' => 'global',
|
||||||
|
], $args));
|
||||||
|
}
|
||||||
|
|
||||||
|
static public function onDeactivation() {
|
||||||
|
remove_action(
|
||||||
|
'blocksy:global-dynamic-css:enqueue',
|
||||||
|
'BlocksyExtensionTrending::add_global_styles',
|
||||||
|
10, 3
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,122 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
blocksy_output_font_css([
|
||||||
|
'font_value' => blocksy_get_theme_mod( 'trendingBlockHeadingFont',
|
||||||
|
blocksy_typography_default_values([
|
||||||
|
'size' => '15px',
|
||||||
|
])
|
||||||
|
),
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'selector' => '.ct-trending-block .ct-module-title',
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('trendingBlockHeadingFontColor'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.ct-trending-block .ct-module-title',
|
||||||
|
'variable' => 'theme-heading-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'responsive' => true,
|
||||||
|
]);
|
||||||
|
|
||||||
|
|
||||||
|
blocksy_output_font_css([
|
||||||
|
'font_value' => blocksy_get_theme_mod( 'trendingBlockPostsFont',
|
||||||
|
blocksy_typography_default_values([
|
||||||
|
'size' => '15px',
|
||||||
|
'variation' => 'n5',
|
||||||
|
])
|
||||||
|
),
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'selector' => '.ct-trending-block .ct-post-title',
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('trendingBlockFontColor'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
'hover' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.ct-trending-block a',
|
||||||
|
'variable' => 'theme-text-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'selector' => '.ct-trending-block a',
|
||||||
|
'variable' => 'theme-link-hover-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'responsive' => true,
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_colors([
|
||||||
|
'value' => blocksy_get_theme_mod('trendingBlockArrowsColor'),
|
||||||
|
'default' => [
|
||||||
|
'default' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
'hover' => [ 'color' => Blocksy_Css_Injector::get_skip_rule_keyword('DEFAULT') ],
|
||||||
|
],
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'variables' => [
|
||||||
|
'default' => [
|
||||||
|
'selector' => '.ct-trending-block [class*="ct-arrow"]',
|
||||||
|
'variable' => 'theme-text-color'
|
||||||
|
],
|
||||||
|
|
||||||
|
'hover' => [
|
||||||
|
'selector' => '.ct-trending-block [class*="ct-arrow"]',
|
||||||
|
'variable' => 'theme-link-hover-color'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'responsive' => true,
|
||||||
|
]);
|
||||||
|
|
||||||
|
blocksy_output_background_css([
|
||||||
|
'selector' => '.ct-trending-block',
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'value' => blocksy_get_theme_mod(
|
||||||
|
'trending_block_background',
|
||||||
|
blocksy_background_default_value([
|
||||||
|
'backgroundColor' => [
|
||||||
|
'default' => [
|
||||||
|
'color' => 'var(--theme-palette-color-5)'
|
||||||
|
],
|
||||||
|
],
|
||||||
|
])
|
||||||
|
),
|
||||||
|
'responsive' => true,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$container_inner_spacing = blocksy_get_theme_mod( 'trendingBlockContainerSpacing', '30px' );
|
||||||
|
|
||||||
|
if ($container_inner_spacing !== '30px') {
|
||||||
|
blocksy_output_responsive([
|
||||||
|
'css' => $css,
|
||||||
|
'tablet_css' => $tablet_css,
|
||||||
|
'mobile_css' => $mobile_css,
|
||||||
|
'selector' => ".ct-trending-block",
|
||||||
|
'variableName' => 'padding',
|
||||||
|
'value' => $container_inner_spacing,
|
||||||
|
'unit' => ''
|
||||||
|
]);
|
||||||
|
}
|
||||||
@ -0,0 +1,295 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
add_action('wp_ajax_blocksy_get_trending_posts', 'blc_get_trending_posts');
|
||||||
|
add_action('wp_ajax_nopriv_blocksy_get_trending_posts', 'blc_get_trending_posts');
|
||||||
|
|
||||||
|
if (! function_exists('blc_get_trending_posts')) {
|
||||||
|
function blc_get_trending_posts() {
|
||||||
|
if (! isset($_REQUEST['page'])) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
$page = intval(sanitize_text_field($_REQUEST['page']));
|
||||||
|
|
||||||
|
if (! $page) {
|
||||||
|
wp_send_json_error();
|
||||||
|
}
|
||||||
|
|
||||||
|
wp_send_json_success([
|
||||||
|
'posts' => blc_get_trending_posts_value([
|
||||||
|
'paged' => $page
|
||||||
|
])
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! function_exists('blc_get_trending_posts_value')) {
|
||||||
|
function blc_get_trending_posts_value($args = []) {
|
||||||
|
$args = wp_parse_args(
|
||||||
|
$args,
|
||||||
|
[
|
||||||
|
'paged' => 1
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
$date_query = [];
|
||||||
|
|
||||||
|
$date_filter = blocksy_get_theme_mod('trending_block_filter', 'all_time');
|
||||||
|
|
||||||
|
if ($date_filter && 'all_time' !== $date_filter) {
|
||||||
|
$days = [
|
||||||
|
'last_24_hours' => 1,
|
||||||
|
'last_7_days' => 7,
|
||||||
|
'last_month' => 30
|
||||||
|
][$date_filter];
|
||||||
|
|
||||||
|
if (! $days) {
|
||||||
|
$days = 30;
|
||||||
|
}
|
||||||
|
|
||||||
|
$time = time() - (intval($days) * 24 * 60 * 60);
|
||||||
|
|
||||||
|
$date_query = array(
|
||||||
|
'after' => [
|
||||||
|
'year' => date('Y', $time),
|
||||||
|
'month' => date('n', $time),
|
||||||
|
'days' => date('j', $time),
|
||||||
|
],
|
||||||
|
'before' => [
|
||||||
|
'year' => date('Y'),
|
||||||
|
'month' => date('n'),
|
||||||
|
'days' => date('j'),
|
||||||
|
],
|
||||||
|
'inclusive' => true,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$post_type = blocksy_get_theme_mod('trending_block_post_type', 'post');
|
||||||
|
|
||||||
|
if ($post_type === 'product' && ! class_exists('WooCommerce')) {
|
||||||
|
$post_type = 'post';
|
||||||
|
}
|
||||||
|
|
||||||
|
$source = blocksy_get_theme_mod('trending_block_post_source', 'categories');
|
||||||
|
|
||||||
|
$query_args = [
|
||||||
|
'post_type' => $post_type,
|
||||||
|
'order' => 'DESC',
|
||||||
|
'posts_per_page' => 4,
|
||||||
|
'orderby' => 'comment_count',
|
||||||
|
'paged' => $args['paged'],
|
||||||
|
'ignore_sticky_posts' => true,
|
||||||
|
'post_status' => 'publish'
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
if ($source === 'categories') {
|
||||||
|
$query_args['date_query'] = $date_query;
|
||||||
|
$cat_option_id = 'trending_block_category';
|
||||||
|
|
||||||
|
if ($post_type !== 'post') {
|
||||||
|
$cat_option_id = 'trending_block_' . $post_type . '_taxonomy';
|
||||||
|
}
|
||||||
|
|
||||||
|
$cat_id = blocksy_get_theme_mod($cat_option_id, 'all_categories');
|
||||||
|
$cat_id = (empty($cat_id) || 'all_categories' === $cat_id) ? '' : $cat_id;
|
||||||
|
|
||||||
|
if (! empty($cat_id)) {
|
||||||
|
$terms = get_terms(['include' => $cat_id]);
|
||||||
|
|
||||||
|
if (! empty($terms)) {
|
||||||
|
$query_args['tax_query'] = [
|
||||||
|
[
|
||||||
|
'taxonomy' => $terms[0]->taxonomy,
|
||||||
|
'field' => 'term_id',
|
||||||
|
'terms' => [$cat_id]
|
||||||
|
]
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($source === 'custom') {
|
||||||
|
$post_id = blocksy_get_theme_mod('trending_block_post_id', '');
|
||||||
|
|
||||||
|
$query_args['orderby'] = 'post__in';
|
||||||
|
$query_args['post__in'] = ['__INEXISTING__'];
|
||||||
|
|
||||||
|
if (! empty(trim($post_id))) {
|
||||||
|
$query_args['post__in'] = explode(',', str_replace(' ', '', trim(
|
||||||
|
$post_id
|
||||||
|
)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$query = new WP_Query(apply_filters(
|
||||||
|
'blocksy:trending-posts:query-args',
|
||||||
|
$query_args
|
||||||
|
));
|
||||||
|
|
||||||
|
if (! $query->have_posts()) {
|
||||||
|
return [
|
||||||
|
'posts' => [],
|
||||||
|
'is_last_page' => false
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
$result = [];
|
||||||
|
|
||||||
|
while ($query->have_posts()) {
|
||||||
|
$query->the_post();
|
||||||
|
|
||||||
|
$individual_entry = [
|
||||||
|
'id' => get_the_ID(),
|
||||||
|
'attachment_id' => get_post_thumbnail_id(),
|
||||||
|
'title' => get_the_title(),
|
||||||
|
'url' => get_permalink(),
|
||||||
|
'image' => ''
|
||||||
|
];
|
||||||
|
|
||||||
|
if (get_post_thumbnail_id()) {
|
||||||
|
$individual_entry['image'] = blocksy_media(
|
||||||
|
[
|
||||||
|
'attachment_id' => get_post_thumbnail_id(),
|
||||||
|
'size' => blocksy_get_theme_mod(
|
||||||
|
'trending_block_thumbnails_size',
|
||||||
|
'thumbnail'
|
||||||
|
),
|
||||||
|
'ratio' => '1/1',
|
||||||
|
'tag_name' => 'div',
|
||||||
|
]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$result[] = $individual_entry;
|
||||||
|
}
|
||||||
|
|
||||||
|
$is_last = intval($query->max_num_pages) === intval($args['paged']);
|
||||||
|
|
||||||
|
wp_reset_postdata();
|
||||||
|
|
||||||
|
return [
|
||||||
|
'posts' => $result,
|
||||||
|
'is_last_page' => $is_last
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! function_exists('blc_get_trending_block')) {
|
||||||
|
function blc_get_trending_block($result = null) {
|
||||||
|
if (! $result) {
|
||||||
|
$result = blc_get_trending_posts_value();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (empty($result['posts'])) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
ob_start();
|
||||||
|
|
||||||
|
$data_page = 'data-page="1"';
|
||||||
|
|
||||||
|
if ($result['is_last_page']) {
|
||||||
|
$data_page = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$class = 'ct-trending-block';
|
||||||
|
|
||||||
|
$class .= ' ' . blocksy_visibility_classes(
|
||||||
|
blocksy_get_theme_mod('trending_block_visibility', [
|
||||||
|
'desktop' => true,
|
||||||
|
'tablet' => true,
|
||||||
|
'mobile' => false,
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
$attr = [
|
||||||
|
'class' => $class
|
||||||
|
];
|
||||||
|
|
||||||
|
if (is_customize_preview()) {
|
||||||
|
$attr['data-shortcut'] = 'border';
|
||||||
|
$attr['data-shortcut-location'] = 'trending_posts_ext';
|
||||||
|
}
|
||||||
|
|
||||||
|
$label_tag = blocksy_get_theme_mod('trending_block_label_tag', 'h3');
|
||||||
|
|
||||||
|
$trending_label = blocksy_get_theme_mod(
|
||||||
|
'trending_block_label',
|
||||||
|
__('Trending now', 'blocksy-companion')
|
||||||
|
);
|
||||||
|
|
||||||
|
$icon = '<svg width="13" height="13" viewBox="0 0 13 13" fill="currentColor"><path d="M13 5.8V9c0 .4-.2.6-.5.6s-.5-.2-.5-.5V7.2l-4.3 4.2c-.2.2-.6.2-.8 0L4.6 9.1.9 12.8c-.1.1-.2.2-.4.2s-.3-.1-.4-.2c-.2-.2-.2-.6 0-.8l4.1-4.1c.2-.2.6-.2.8 0l2.3 2.3 3.8-3.8H9.2c-.3 0-.5-.2-.5-.5s.2-.5.5-.5h3.4c.2 0 .3.1.4.2v.2z"/></svg>';
|
||||||
|
|
||||||
|
if (function_exists('blc_get_icon')) {
|
||||||
|
$icon_source = blocksy_get_theme_mod('trending_block_icon_source', 'default');
|
||||||
|
|
||||||
|
if ($icon_source === 'custom') {
|
||||||
|
$icon = blc_get_icon([
|
||||||
|
'icon_descriptor' => blocksy_get_theme_mod('trending_block_custom_icon', [
|
||||||
|
'icon' => 'fas fa-fire',
|
||||||
|
]),
|
||||||
|
'icon_container' => false,
|
||||||
|
'icon_html_atts' => [
|
||||||
|
'width' => '13',
|
||||||
|
'height' => '13',
|
||||||
|
'fill' => 'currentColor'
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
|
|
||||||
|
<section <?php echo blocksy_attr_to_html($attr) ?>>
|
||||||
|
<div class="ct-container" <?php echo $data_page ?>>
|
||||||
|
<<?php echo $label_tag ?> class="ct-module-title">
|
||||||
|
<?php
|
||||||
|
echo $trending_label;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Note to code reviewers: This line doesn't need to be escaped.
|
||||||
|
* The value used here escapes the value properly.
|
||||||
|
* It contains an inline SVG, which is safe.
|
||||||
|
*/
|
||||||
|
echo $icon;
|
||||||
|
?>
|
||||||
|
|
||||||
|
<?php if (! $result['is_last_page']) { ?>
|
||||||
|
<span class="ct-arrow-left">
|
||||||
|
</span>
|
||||||
|
|
||||||
|
<span class="ct-arrow-right">
|
||||||
|
</span>
|
||||||
|
<?php } ?>
|
||||||
|
</<?php echo $label_tag ?>>
|
||||||
|
|
||||||
|
<?php
|
||||||
|
foreach ($result['posts'] as $post) {
|
||||||
|
echo blocksy_html_tag(
|
||||||
|
'a',
|
||||||
|
[
|
||||||
|
'href' => $post['url'],
|
||||||
|
],
|
||||||
|
|
||||||
|
$post['image'] . blocksy_html_tag(
|
||||||
|
'span',
|
||||||
|
[
|
||||||
|
'class' => 'ct-post-title',
|
||||||
|
],
|
||||||
|
$post['title']
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<?php
|
||||||
|
|
||||||
|
return ob_get_clean();
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1 @@
|
|||||||
|
!function(){"use strict";function t(t){return function(t){if(Array.isArray(t))return r(t)}(t)||function(t){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(t))return Array.from(t)}(t)||n(t)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function e(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){if("undefined"==typeof Symbol||!(Symbol.iterator in Object(t)))return;var n=[],r=!0,o=!1,a=void 0;try{for(var c,i=t[Symbol.iterator]();!(r=(c=i.next()).done)&&(n.push(c.value),!e||n.length!==e);r=!0);}catch(t){o=!0,a=t}finally{try{r||null==i.return||i.return()}finally{if(o)throw a}}return n}(t,e)||n(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function n(t,e){if(t){if("string"==typeof t)return r(t,e);var n=Object.prototype.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?r(t,e):void 0}}function r(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,r=new Array(e);n<e;n++)r[n]=t[n];return r}function o(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function a(t,e,n){return e in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}var c={},i=function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if(n=function(t){for(var e=1;e<arguments.length;e++){var n=null!=arguments[e]?arguments[e]:{};e%2?o(Object(n),!0).forEach((function(e){a(t,e,n[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(n)):o(Object(n)).forEach((function(e){Object.defineProperty(t,e,Object.getOwnPropertyDescriptor(n,e))}))}return t}({el:null,action:null},n),n.el&&n.action&&!n.el.classList.contains("ct-loading")){var r=parseInt(n.el.dataset.page,10);if(("prev"!==n.action||1!==r)&&!(n.el.querySelectorAll(".ct-container > a").length<4&&1===r||n.el.dataset.page.indexOf("last")>-1&&"next"===n.action)){n.el.classList.add("ct-loading");var i,l="prev"===n.action?r-1:r+1;Promise.all([new Promise((function(t){n.el.classList.add("ct-leave-active"),requestAnimationFrame((function(){n.el.classList.remove("ct-leave-active"),n.el.classList.add("ct-leave"),setTimeout((function(){return t()}),650)}))})),(i="".concat(ct_localizations.ajax_url,"?action=blocksy_get_trending_posts&page=").concat(l),c[i]?new Promise((function(t){t(c[i]),window.ct_customizer_localizations||(c[i]=c[i].clone())})):new Promise((function(t){return fetch(i).then((function(e){t(e),window.ct_customizer_localizations||(c[i]=e.clone())}))}))).then((function(t){return t.json()}))]).then((function(r){var o=e(r,2),a=(o[0],o[1]),c=a.success,i=a.data;if(c){var s=i.posts,u=s.is_last_page,f=s.posts;n.el.dataset.page="".concat(l).concat(u?":last":""),t(n.el.querySelectorAll("a")).map((function(t){return t.remove()})),f.map((function(t){return n.el.insertAdjacentHTML("beforeend",'<a href="'.concat(t.url,'">\n ').concat(t.image,'\n <span class="ct-post-title">\n ').concat(t.title,"\n </span>\n </a>"))})),setTimeout((function(){n.el.classList.remove("ct-leave"),n.el.classList.add("ct-enter-active"),requestAnimationFrame((function(){n.el.classList.remove("ct-enter-active"),n.el.classList.add("ct-active"),setTimeout((function(){n.el.classList.remove("ct-active"),n.el.classList.remove("ct-loading")}),650)}))}),50)}}))}}};(0,window.ctFrontend.registerDynamicChunk)("blocksy_ext_trending",{mount:function(t,e){e.event;var n=t.closest("[data-page]");t.classList.contains("ct-arrow-left")&&i({el:n,action:"prev"}),t.classList.contains("ct-arrow-right")&&i({el:n,action:"next"})}})}();
|
||||||
@ -0,0 +1,8 @@
|
|||||||
|
/**
|
||||||
|
* - v2.0.37
|
||||||
|
*
|
||||||
|
* Copyright (c) 2024
|
||||||
|
* Licensed GPLv2+
|
||||||
|
*/
|
||||||
|
|
||||||
|
.ct-trending-block{padding:var(--padding, 30px) 0}.ct-trending-block>div{display:grid;grid-template-columns:var(--grid-template-columns);grid-column-gap:30px;grid-row-gap:20px;margin-bottom:5px}@media(min-width: 690px)and (max-width: 999.98px){.ct-trending-block>div{--grid-template-columns: repeat(2, 1fr)}}@media(min-width: 1000px){.ct-trending-block>div{--grid-template-columns: repeat(4, 1fr)}}.ct-trending-block>div.ct-leave-active>a,.ct-trending-block>div.ct-leave>a{transition:opacity .3s ease,transform .3s ease}.ct-trending-block>div.ct-leave-active>a:nth-of-type(1),.ct-trending-block>div.ct-leave>a:nth-of-type(1){transition-delay:0s}.ct-trending-block>div.ct-leave-active>a:nth-of-type(2),.ct-trending-block>div.ct-leave>a:nth-of-type(2){transition-delay:.15s}.ct-trending-block>div.ct-leave-active>a:nth-of-type(3),.ct-trending-block>div.ct-leave>a:nth-of-type(3){transition-delay:.25s}.ct-trending-block>div.ct-leave-active>a:nth-of-type(4),.ct-trending-block>div.ct-leave>a:nth-of-type(4){transition-delay:.35s}.ct-trending-block>div.ct-leave-active>a{opacity:1;transform:translateY(0)}.ct-trending-block>div.ct-leave>a{opacity:0;transform:translateY(3px)}.ct-trending-block>div.ct-enter-active>a,.ct-trending-block>div.ct-active>a{transition:opacity .3s ease,transform .3s ease}.ct-trending-block>div.ct-enter-active>a:nth-of-type(1),.ct-trending-block>div.ct-active>a:nth-of-type(1){transition-delay:0s}.ct-trending-block>div.ct-enter-active>a:nth-of-type(2),.ct-trending-block>div.ct-active>a:nth-of-type(2){transition-delay:.15s}.ct-trending-block>div.ct-enter-active>a:nth-of-type(3),.ct-trending-block>div.ct-active>a:nth-of-type(3){transition-delay:.25s}.ct-trending-block>div.ct-enter-active>a:nth-of-type(4),.ct-trending-block>div.ct-active>a:nth-of-type(4){transition-delay:.35s}.ct-trending-block>div.ct-enter-active>a{opacity:0;transform:translateY(3px)}.ct-trending-block>div.ct-active>a{opacity:1;transform:translateY(0)}.ct-trending-block .ct-module-title{grid-column:1/-1;display:flex;align-items:center;margin-bottom:10px}.ct-trending-block .ct-module-title>svg{margin-inline-start:10px}.ct-trending-block a{display:flex;align-items:center;--theme-link-initial-color: var(--theme-text-color)}.ct-trending-block .ct-media-container{flex:0 0 60px;border-radius:100%;margin-inline-end:20px;-webkit-mask-image:-webkit-radial-gradient(white, black)}.ct-trending-block .ct-post-title{word-break:break-word}.ct-trending-block [class*=ct-arrow]{display:flex;align-items:center;justify-content:center;width:23px;height:23px;cursor:pointer;background:rgba(0,0,0,0);border-radius:2px;opacity:.5;color:var(--theme-text-color);border:1px solid currentColor;transition:var(--theme-transition)}.ct-trending-block [class*=ct-arrow]:before{content:"";width:5px;height:5px;border:1px solid currentColor;border-right:none;border-bottom:none}.ct-trending-block [class*=ct-arrow]:hover{opacity:1;color:#fff;border-color:var(--theme-link-hover-color);background:var(--theme-link-hover-color)}.ct-trending-block .ct-arrow-left{margin-inline-start:auto;margin-inline-end:8px;padding-inline-start:1px}.ct-trending-block .ct-arrow-left:before{transform:rotate(-45deg)}.ct-trending-block .ct-arrow-right{padding-inline-end:1px}.ct-trending-block .ct-arrow-right:before{transform:rotate(135deg)}.ct-trending-block [data-page="1"] .ct-arrow-left,.ct-trending-block [data-page*=last] .ct-arrow-right{opacity:.2;pointer-events:none}
|
||||||
@ -0,0 +1 @@
|
|||||||
|
!function(){"use strict";var e={n:function(t){var r=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(r,{a:r}),r},d:function(t,r){for(var n in r)e.o(r,n)&&!e.o(t,n)&&Object.defineProperty(t,n,{enumerable:!0,get:r[n]})},o:function(e,t){return Object.prototype.hasOwnProperty.call(e,t)}},t=window.blocksyCustomizerSync,r=window.ctEvents;function n(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function o(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?n(Object(r),!0).forEach((function(t){c(e,t,r[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):n(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}function c(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}e.n(r)().on("ct:customizer:sync:collect-variable-descriptors",(function(e){e.result=o(o(o(o(o({},(0,t.typographyOption)({id:"trendingBlockHeadingFont",selector:".ct-trending-block .ct-module-title"})),{},{trendingBlockHeadingFontColor:{selector:".ct-trending-block .ct-module-title",variable:"theme-heading-color",type:"color",responsive:!0}},(0,t.typographyOption)({id:"trendingBlockPostsFont",selector:".ct-trending-block .ct-post-title"})),{},{trendingBlockFontColor:[{selector:".ct-trending-block a",variable:"theme-text-color",type:"color:default",responsive:!0},{selector:".ct-trending-block a",variable:"theme-link-hover-color",type:"color:hover",responsive:!0}],trendingBlockArrowsColor:[{selector:'.ct-trending-block [class*="ct-arrow"]',variable:"theme-text-color",type:"color:default",responsive:!0},{selector:'.ct-trending-block [class*="ct-arrow"]',variable:"theme-link-hover-color",type:"color:hover",responsive:!0}]},(0,t.handleBackgroundOptionFor)({id:"trending_block_background",selector:".ct-trending-block",responsive:!0})),e.result),{},{trendingBlockContainerSpacing:{selector:".ct-trending-block",variable:"padding",responsive:!0,unit:""}})})),wp.customize("trending_block_visibility",(function(e){return e.bind((function(e){return(0,t.responsiveClassesFor)("trending_block_visibility",document.querySelector(".ct-trending-block"))}))})),wp.customize("trending_block_label",(function(e){return e.bind((function(e){var t=document.querySelector(".ct-trending-block .ct-module-title");if(t){var r=t.innerHTML.split("<svg");r[0]=e,t.innerHTML=r.join("<svg")}}))}))}();
|
||||||
@ -0,0 +1,16 @@
|
|||||||
|
import { loadPage } from './trending-block'
|
||||||
|
import { registerDynamicChunk } from 'blocksy-frontend'
|
||||||
|
|
||||||
|
registerDynamicChunk('blocksy_ext_trending', {
|
||||||
|
mount: (el, { event }) => {
|
||||||
|
const loadingEl = el.closest('[data-page]')
|
||||||
|
|
||||||
|
if (el.classList.contains('ct-arrow-left')) {
|
||||||
|
loadPage({ el: loadingEl, action: 'prev' })
|
||||||
|
}
|
||||||
|
|
||||||
|
if (el.classList.contains('ct-arrow-right')) {
|
||||||
|
loadPage({ el: loadingEl, action: 'next' })
|
||||||
|
}
|
||||||
|
},
|
||||||
|
})
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user